From 9aab01ed91a996b4df6a309b65b1da35c6e3ac2a Mon Sep 17 00:00:00 2001 From: Alex LaFroscia Date: Wed, 6 Feb 2019 22:37:47 -0800 Subject: [PATCH] fix: avoid sharing values between instances with `subscribe` --- addon/decorators/subscribe.js | 38 +++++------------------------------ 1 file changed, 5 insertions(+), 33 deletions(-) diff --git a/addon/decorators/subscribe.js b/addon/decorators/subscribe.js index 6b4140b..68ae3c6 100644 --- a/addon/decorators/subscribe.js +++ b/addon/decorators/subscribe.js @@ -58,39 +58,11 @@ export default function subscribe(observableKey) { const SUBSCRIPTION = Symbol(); - return ({ kind, descriptor, initializer, ...rest }) => { - assert("Must decorator a `field`", kind === "field"); - - delete descriptor.writable; - - let lastValue, - hasEmittedValue = false; + return element => { + assert("Must decorator a `field`", element.kind === "field"); return { - ...rest, - kind: "method", - descriptor: { - ...descriptor, - get() { - if (hasEmittedValue) { - return lastValue; - } - - if (initializer) { - return initializer(); - } - }, - set(value) { - hasEmittedValue = true; - lastValue = value; - - // Ensure the Ember KVO knows that the subscription property - // has updated - if (this.notifyPropertyChange) { - this.notifyPropertyChange(rest.key); - } - } - }, + ...element, finisher: klass => { function resetSubscription() { // Unsubscribe from the old observable @@ -101,7 +73,7 @@ export default function subscribe(observableKey) { // Set up the subscription to the new observable const observable = get(this, observableKey); this[SUBSCRIPTION] = observable.subscribe(value => { - set(this, rest.key, value); + set(this, element.key, value); }); } return class extends klass { @@ -121,7 +93,7 @@ export default function subscribe(observableKey) { } this[SUBSCRIPTION] = observable.subscribe(value => { - set(this, rest.key, value); + set(this, element.key, value); }); }