-
Notifications
You must be signed in to change notification settings - Fork 2
/
watch-proxy.js
50 lines (44 loc) Β· 1.68 KB
/
watch-proxy.js
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
/**
/* WATCH - create a proxy watcher in order to listen for properties changes */
/* @param {object} obj - object with properties you wan to listen */
/* @return {object} proxy - proxy object you can change to be listened */
/* */
export default watch = function(obj){
const restricted = function(){};
let proxy = new restricted();
proxy.values = {};
proxy.listening = {};
// define getter/setter in proxy
for(let prop in obj){
if(obj.hasOwnProperty(prop)){
proxy.values[prop] = obj[prop];
Object.defineProperty(proxy, prop, {
set: function(newValue){
this.values[prop] = newValue;
this.listening[prop] && this.listening[prop](newValue);
},
get: function(){
return this.values[prop];
}
});
}
}
// allocation listener function
restricted.prototype.addListener = function(property, handler){
for(let prop in proxy.values){
if(!Object.prototype.hasOwnProperty.call(proxy.values, property)) throw "Watch function - listener variable '"+ property +"' don't exist on the proxy watcher";
Object.prototype.hasOwnProperty.call(proxy.values, prop) && prop == property && (proxy.listening[prop] = handler);
return proxy.listening[prop];
}
};
// remove listener function
restricted.prototype.removeListener = function(listener){
for(let listened in proxy.listening){
if(Object.prototype.hasOwnProperty.call(proxy.listening, listened) && proxy.listening[listened] === listener){
proxy.listening[listened] = null;
delete proxy.listening[listened];
}
}
};
return proxy
};