evg_observable 1.1.28 → 1.1.29

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "evg_observable",
3
- "version": "1.1.28",
3
+ "version": "1.1.29",
4
4
  "description": "Light observable",
5
5
  "main": "index.js",
6
6
  "directories": {
@@ -3,6 +3,7 @@ export declare class SubscribeObject<T> implements ISubscribeObject<T>, IMarkedF
3
3
  isMarkedForUnsubscribe: boolean;
4
4
  protected observable: IObserver<T> | undefined;
5
5
  protected listener: IListener<T> | undefined;
6
+ protected _order: number;
6
7
  private isListenPaused;
7
8
  private once;
8
9
  private unsubscribeByNegativeCondition;
@@ -10,13 +11,11 @@ export declare class SubscribeObject<T> implements ISubscribeObject<T>, IMarkedF
10
11
  private emitByNegativeCondition;
11
12
  private emitByPositiveCondition;
12
13
  private emitMatchCondition;
13
- protected _order: number;
14
14
  constructor(observable?: IObserver<T>, listener?: IListener<T>);
15
- private static asyncSend;
15
+ private static callbackSend;
16
16
  subscribe(listener: IListener<T>): ISubscriptionLike<T>;
17
17
  unsubscribe(): void;
18
18
  send(value: T): void;
19
- private sendValueToListener;
20
19
  setOnce(): ISubscribe<T>;
21
20
  unsubscribeByNegative(condition: ICallback<any>): ISubscribe<T>;
22
21
  unsubscribeByPositive(condition: ICallback<any>): ISubscribe<T>;
@@ -5,6 +5,7 @@ const FunctionLibs_1 = require("./FunctionLibs");
5
5
  class SubscribeObject {
6
6
  constructor(observable, listener) {
7
7
  this.isMarkedForUnsubscribe = false;
8
+ this._order = 0;
8
9
  this.isListenPaused = false;
9
10
  this.once = { isOnce: false, isFinished: false };
10
11
  this.unsubscribeByNegativeCondition = null;
@@ -12,77 +13,71 @@ class SubscribeObject {
12
13
  this.emitByNegativeCondition = null;
13
14
  this.emitByPositiveCondition = null;
14
15
  this.emitMatchCondition = null;
15
- this._order = 0;
16
16
  this.observable = observable;
17
17
  this.listener = listener;
18
18
  }
19
- static asyncSend(value, subsObj) {
19
+ static callbackSend(value, subsObj) {
20
20
  const listener = subsObj.listener;
21
- return new Promise((resolve => {
22
- switch (true) {
23
- case !subsObj.observable:
24
- case !listener:
21
+ switch (true) {
22
+ case !subsObj.observable:
23
+ case !listener:
24
+ subsObj.unsubscribe();
25
+ return;
26
+ case subsObj.isListenPaused:
27
+ ;
28
+ return;
29
+ case subsObj.once.isOnce:
30
+ subsObj.once.isFinished = true;
31
+ listener && listener((value));
32
+ subsObj.unsubscribe();
33
+ break;
34
+ case !!subsObj.unsubscribeByNegativeCondition:
35
+ if (!subsObj.unsubscribeByNegativeCondition()) {
36
+ subsObj.unsubscribeByNegativeCondition = null;
25
37
  subsObj.unsubscribe();
26
- resolve(false);
27
- return;
28
- case subsObj.isListenPaused:
29
- resolve(false);
30
38
  return;
31
- case subsObj.once.isOnce:
32
- subsObj.once.isFinished = true;
33
- listener && listener((value));
39
+ }
40
+ listener && listener((value));
41
+ break;
42
+ case !!subsObj.unsubscribeByPositiveCondition:
43
+ if (subsObj.unsubscribeByPositiveCondition()) {
44
+ subsObj.unsubscribeByPositiveCondition = null;
34
45
  subsObj.unsubscribe();
35
- break;
36
- case !!subsObj.unsubscribeByNegativeCondition:
37
- if (!subsObj.unsubscribeByNegativeCondition()) {
38
- subsObj.unsubscribeByNegativeCondition = null;
39
- subsObj.unsubscribe();
40
- return;
41
- }
42
- listener && listener((value));
43
- break;
44
- case !!subsObj.unsubscribeByPositiveCondition:
45
- if (subsObj.unsubscribeByPositiveCondition()) {
46
- subsObj.unsubscribeByPositiveCondition = null;
47
- subsObj.unsubscribe();
48
- return;
49
- }
50
- listener && listener((value));
51
- break;
52
- case !!subsObj.emitByNegativeCondition:
53
- !subsObj.emitByNegativeCondition() && listener && listener(value);
54
- break;
55
- case !!subsObj.emitByPositiveCondition:
56
- subsObj.emitByPositiveCondition() && listener && listener(value);
57
- break;
58
- case !!subsObj.emitMatchCondition:
59
- (subsObj.emitMatchCondition() === value) && listener && listener(value);
60
- break;
61
- default:
62
- listener && listener((value));
63
- }
64
- resolve(true);
65
- }));
46
+ return;
47
+ }
48
+ listener && listener((value));
49
+ break;
50
+ case !!subsObj.emitByNegativeCondition:
51
+ !subsObj.emitByNegativeCondition() && listener && listener(value);
52
+ break;
53
+ case !!subsObj.emitByPositiveCondition:
54
+ subsObj.emitByPositiveCondition() && listener && listener(value);
55
+ break;
56
+ case !!subsObj.emitMatchCondition:
57
+ (subsObj.emitMatchCondition() === value) && listener && listener(value);
58
+ break;
59
+ default:
60
+ listener && listener((value));
61
+ }
66
62
  }
67
63
  subscribe(listener) {
68
64
  this.listener = listener;
69
65
  return this;
70
66
  }
71
67
  unsubscribe() {
72
- if (!!this.observable) {
68
+ if (this.observable) {
73
69
  this.observable.unSubscribe(this);
74
70
  this.observable = 0;
75
71
  this.listener = 0;
76
72
  }
77
73
  }
78
74
  send(value) {
79
- this.sendValueToListener(value);
80
- }
81
- sendValueToListener(value) {
82
- SubscribeObject.asyncSend(value, this)
83
- .catch(err => {
84
- console.log('(Unit of SubscribeObject).send(value: T) call .sendValueToListener(value: T) ERROR:', err);
85
- });
75
+ try {
76
+ SubscribeObject.callbackSend(value, this);
77
+ }
78
+ catch (err) {
79
+ console.log('(Unit of SubscribeObject).send(value: T) ERROR:', err);
80
+ }
86
81
  }
87
82
  setOnce() {
88
83
  this.once.isOnce = true;
@@ -158,8 +153,8 @@ class Observable {
158
153
  return;
159
154
  this.value = value;
160
155
  this.isNextProcess = true;
161
- for (let i = 0; i < this.listeners.length; i++)
162
- this.listeners[i].send(value);
156
+ for (const listener of this.listeners)
157
+ listener && listener.send(value);
163
158
  this.isNextProcess = false;
164
159
  this.handleListenersForUnsubscribe();
165
160
  }
@@ -210,6 +205,8 @@ class Observable {
210
205
  subscribe(listener) {
211
206
  if (this._isDestroyed)
212
207
  return undefined;
208
+ if (!listener)
209
+ return undefined;
213
210
  const subscribeObject = new SubscribeObject(this, listener);
214
211
  this.listeners.push(subscribeObject);
215
212
  return subscribeObject;
@@ -1,5 +1,5 @@
1
1
  import { Observable, SubscribeObject } from "./Observable";
2
- import { ICallback, IListener, IOrdered, IOrderedSetup, IOrderedSubscribe, IOrderedSubscriptionLike, ISubscriptionLike } from "./Types";
2
+ import { ICallback, IListener, IOrdered, IOrderedSetup, IOrderedSubscribe, IOrderedSubscriptionLike } from "./Types";
3
3
  export declare class OrderedSubscribeObject<T> extends SubscribeObject<T> {
4
4
  constructor(observable: OrderedObservable<T> | IOrdered<T>, listener?: IListener<T>);
5
5
  get order(): number;
@@ -14,6 +14,6 @@ export declare class OrderedSubscribeObject<T> extends SubscribeObject<T> {
14
14
  }
15
15
  export declare class OrderedObservable<T> extends Observable<T> implements IOrdered<T> {
16
16
  sortByOrder(): void;
17
- subscribe(listener: IListener<T>): ISubscriptionLike<T> | undefined;
17
+ subscribe(listener: IListener<T>): IOrderedSubscriptionLike<T> | undefined;
18
18
  pipe(): IOrderedSetup<T> | undefined;
19
19
  }
@@ -57,6 +57,8 @@ class OrderedObservable extends Observable_1.Observable {
57
57
  subscribe(listener) {
58
58
  if (this._isDestroyed)
59
59
  return undefined;
60
+ if (!listener)
61
+ return undefined;
60
62
  const subscribeObject = new OrderedSubscribeObject(this, listener);
61
63
  this.listeners.push(subscribeObject);
62
64
  return subscribeObject;
@@ -94,7 +94,7 @@ export type IOrderedObservable = {
94
94
  sortByOrder(): void;
95
95
  };
96
96
  export type IOrdered<T> = IObserver<T> & IOrderedObservable;
97
- export type IOrderedSubscriptionLike<T> = ISubscriptionLike<T> & IOrder;
97
+ export type IOrderedSubscriptionLike<T> = (ISubscriptionLike<T> & IOrder);
98
98
  export type IOrderedSubscribe<T> = {
99
99
  subscribe(listener: IListener<T>): IOrderedSubscriptionLike<T>;
100
100
  };