-
Notifications
You must be signed in to change notification settings - Fork 0
Expand file tree
/
Copy pathscripts.js
More file actions
79 lines (67 loc) · 2.81 KB
/
scripts.js
File metadata and controls
79 lines (67 loc) · 2.81 KB
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
/*
Reference Documentation for 'Object.defineProperty()':
https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Global_Objects/Object/defineProperty
*/
// State controller
const State = {
// Internal storage for properties
_values: {},
_listeners: {},
// Generic addEventListener method
watchman: {
addEventListener: function (property, listener) {
// If internal listeners does not have this property
if (!State._listeners[property]) {
// Create it and set it to empty
State._listeners[property] = [];
// Define getter and setter dynamically
Object.defineProperty(State, property, {
get: function () {
// Get the internal value for property
return State._values[property];
},
set: function (value) {
// Set the internal value for property
State._values[property] = value;
// Call all listeners for this property and passes in value
State._listeners[property].forEach(listener => listener(value));
},
// Allows external modification
configurable: true,
});
}
// Add the new listener
State._listeners[property].push(listener);
},
// Remove an event listener for a given property
removeEventListener: function (prop, listener) {
if (!State._listeners[prop]) return;
if (listener) {
// Remove specific listener
State._listeners[prop] = State._listeners[prop].filter(fn => fn !== listener);
} else {
// Remove all listeners for the property
delete State._listeners[prop];
}
}
}
};
// Define listeners
const listener1 = (newValue) => console.log("[INFO] Listener 1: User changed to", newValue);
const listener2 = (newValue) => console.log("[INFO] Listener 2: User changed to", newValue);
// Add listeners
State.watchman.addEventListener("user", listener1);
State.watchman.addEventListener("user", listener2);
// Change user value
console.log('Changing user value to "Alice"');
State.user = "Alice";
// Remove one listener
console.log('Removing listener1 from "user"');
State.watchman.removeEventListener("user", listener1);
// Change user value
console.log('Changing user value to "Bob"');
State.user = "Bob";
// Remove all listeners for 'user'
console.log('Removing all listeners for "user"');
State.watchman.removeEventListener("user");
console.log(`State.user = "${State.user}"`);