From a303a83ad7d69509eaa14d07558039f87dc36e06 Mon Sep 17 00:00:00 2001 From: DarkWiiPlayer Date: Mon, 13 Sep 2021 19:21:00 +0200 Subject: [PATCH] Add support for repeated callbacks to listener It is now possible to attach several callbacks to the same prop on a single listener object. --- listener.js | 18 +++++++++++------- 1 file changed, 11 insertions(+), 7 deletions(-) diff --git a/listener.js b/listener.js index 04a6c84..cd3b5d3 100644 --- a/listener.js +++ b/listener.js @@ -8,20 +8,24 @@ Example: l.contract = new Contract() */ -export const listener = (target={}) => { +export default (target={}) => { let callbacks = new Map() function listen(prop, callback) { - if ("object" == typeof prop && "forEach" in prop) + if ("object" == typeof prop && "forEach" in prop) { prop.forEach(prop => this.listen(prop, callback)) - else if (callback) - callbacks.set(prop, callback) - else + } else if (callback) { + let list = callbacks.get(prop) + if (!list) callbacks.set(prop, list=[]) + list.push(callback) + } else { callbacks.delete(prop) + } } let proxy = new Proxy(target, { set: (target, prop, value) => { - if (callbacks.has("*")) callbacks.get("*")(value, prop) - if (callbacks.has(prop)) callbacks.get(prop)(value, prop) + console.log(callbacks) + if (callbacks.has("*")) callbacks.get("*").forEach(callback => callback(value, prop)) + if (callbacks.has(prop)) callbacks.get(prop).forEach(callback => callback(value, prop)) return Reflect.set(target, prop, value) }, get: (target, prop, value) => {