@dcl/sdk 7.0.6-3999809037.commit-0a47a3c → 7.0.6-4009020955.commit-08722f5

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.
Files changed (94) hide show
  1. package/cli/commands/build/helpers.d.ts +25 -0
  2. package/cli/commands/build/helpers.js +50 -0
  3. package/cli/commands/build/helpers.ts +95 -0
  4. package/cli/commands/build/index.d.ts +19 -0
  5. package/cli/commands/build/index.js +64 -0
  6. package/cli/commands/build/index.ts +91 -0
  7. package/cli/commands/init/index.d.ts +3 -1
  8. package/cli/commands/init/index.js +9 -15
  9. package/cli/commands/init/index.ts +12 -16
  10. package/cli/commands/init/repos.js +1 -1
  11. package/cli/commands/init/repos.ts +1 -2
  12. package/cli/commands/preview/bff.d.ts +3 -0
  13. package/cli/commands/preview/bff.js +50 -0
  14. package/cli/commands/preview/bff.ts +59 -0
  15. package/cli/commands/preview/catalyst.d.ts +5 -0
  16. package/cli/commands/preview/catalyst.js +24 -0
  17. package/cli/commands/preview/catalyst.ts +31 -0
  18. package/cli/commands/preview/coordinates.d.ts +20 -0
  19. package/cli/commands/preview/coordinates.js +90 -0
  20. package/cli/commands/preview/coordinates.ts +146 -0
  21. package/cli/commands/preview/endpoints.d.ts +10 -0
  22. package/cli/commands/preview/endpoints.js +500 -0
  23. package/cli/commands/preview/endpoints.ts +594 -0
  24. package/cli/commands/preview/eth.d.ts +2 -0
  25. package/cli/commands/preview/eth.js +6 -0
  26. package/cli/commands/preview/eth.ts +3 -0
  27. package/cli/commands/preview/index.d.ts +18 -0
  28. package/cli/commands/preview/index.js +75 -0
  29. package/cli/commands/preview/index.ts +88 -0
  30. package/cli/commands/preview/port.d.ts +1 -0
  31. package/cli/commands/preview/port.js +21 -0
  32. package/cli/commands/preview/port.ts +15 -0
  33. package/cli/commands/preview/project.d.ts +14 -0
  34. package/cli/commands/preview/project.js +77 -0
  35. package/cli/commands/preview/project.ts +112 -0
  36. package/cli/commands/preview/types.d.ts +13 -0
  37. package/cli/commands/preview/types.js +3 -0
  38. package/cli/commands/preview/types.ts +19 -0
  39. package/cli/commands/preview/wire.d.ts +14 -0
  40. package/cli/commands/preview/wire.js +28 -0
  41. package/cli/commands/preview/wire.ts +48 -0
  42. package/cli/commands/preview/ws.d.ts +7 -0
  43. package/cli/commands/preview/ws.js +16 -0
  44. package/cli/commands/preview/ws.ts +24 -0
  45. package/cli/commands/start/index.d.ts +29 -0
  46. package/cli/commands/start/index.js +121 -0
  47. package/cli/commands/start/index.ts +132 -0
  48. package/cli/components/fetch.d.ts +5 -0
  49. package/cli/components/fetch.js +34 -0
  50. package/cli/components/fetch.ts +11 -0
  51. package/cli/components/fs.d.ts +11 -0
  52. package/cli/components/fs.js +58 -0
  53. package/cli/components/fs.ts +48 -0
  54. package/cli/components/index.d.ts +7 -0
  55. package/cli/components/index.js +13 -0
  56. package/cli/components/index.ts +14 -0
  57. package/cli/index.d.ts +2 -0
  58. package/cli/index.js +8 -8
  59. package/cli/index.ts +15 -12
  60. package/cli/utils/args.js +2 -2
  61. package/cli/utils/args.ts +2 -8
  62. package/cli/utils/commands.d.ts +2 -1
  63. package/cli/utils/commands.js +8 -8
  64. package/cli/utils/commands.ts +11 -11
  65. package/cli/utils/exec.d.ts +8 -0
  66. package/cli/utils/exec.js +33 -0
  67. package/cli/utils/exec.ts +38 -0
  68. package/cli/utils/fs.d.ts +9 -8
  69. package/cli/utils/fs.js +7 -47
  70. package/cli/utils/fs.ts +11 -67
  71. package/cli/utils/handler.d.ts +6 -0
  72. package/cli/utils/handler.js +19 -0
  73. package/cli/utils/handler.ts +23 -0
  74. package/cli/utils/object.d.ts +9 -0
  75. package/cli/utils/object.js +45 -0
  76. package/cli/utils/object.ts +62 -0
  77. package/cli/utils/out-messages.d.ts +1 -0
  78. package/cli/utils/out-messages.js +8 -0
  79. package/cli/utils/out-messages.ts +3 -0
  80. package/internal/Observable.js +3 -7
  81. package/internal/provider.js +1 -1
  82. package/internal/transports/rendererTransport.js +2 -3
  83. package/messageBus.js +1 -1
  84. package/observables.js +1 -1
  85. package/package.json +18 -7
  86. package/src/internal/Observable.ts +9 -44
  87. package/src/internal/provider.ts +3 -11
  88. package/src/internal/transports/rendererTransport.ts +4 -12
  89. package/src/messageBus.ts +1 -4
  90. package/src/observables.ts +27 -63
  91. package/tsconfig.cli.json +10 -1
  92. package/cli/utils/spinner.d.ts +0 -15
  93. package/cli/utils/spinner.js +0 -41
  94. package/cli/utils/spinner.ts +0 -44
@@ -0,0 +1,62 @@
1
+ export type Primitive = string | number
2
+ export type Dict = { [key: string]: Dict | Primitive | Primitive[] }
3
+
4
+ /*
5
+ * Returns true if value is a "Primitive"
6
+ */
7
+ export const isPrimitive = (value: any): value is Primitive =>
8
+ (typeof value === 'string' && value.length > 0) || (typeof value === 'number' && !Number.isNaN(value))
9
+
10
+ /*
11
+ * Returns true if both parameters are equal
12
+ */
13
+ export const eqPrimitive = (value: Primitive, value2: Primitive): boolean => value === value2
14
+
15
+ /*
16
+ * Returns true if value is a JS Object
17
+ */
18
+ export const isObject = (value: any): value is Dict =>
19
+ typeof value === 'object' && !Array.isArray(value) && value !== null
20
+
21
+ /*
22
+ * Returns true if second paramter is a "Primitive" and equal to first parameter
23
+ */
24
+ export const isPrimitiveEqualTo = (val: Primitive, val2: any): val2 is Primitive =>
25
+ isPrimitive(val2) && eqPrimitive(val, val2)
26
+
27
+ /*
28
+ * Returns true if "original" has all of the props described in "comparator"
29
+ * NOTE: comparator can provide a list of valid "Primitives" to match values from "original"
30
+ * EX:
31
+ * original = { prop1: "some-val" }
32
+ * comparator = { prop1: [1, 2, "some-val"] }
33
+ * will return true
34
+ */
35
+ export const hasPrimitiveKeys = <T extends Dict>(original: Record<string, unknown>, comparator: T): boolean => {
36
+ for (const [key, value] of Object.entries(comparator)) {
37
+ const originalValue = original[key]
38
+ if (originalValue === undefined) {
39
+ return false
40
+ } else if (isPrimitive(value) && !isPrimitiveEqualTo(value, originalValue)) {
41
+ return false
42
+ } else if (Array.isArray(value)) {
43
+ if (Array.isArray(originalValue)) {
44
+ const set = new Set(value)
45
+ for (const v of originalValue) {
46
+ if (!set.has(v)) return false
47
+ }
48
+ } else {
49
+ const foundPrimitive = value.some((val) => isPrimitive(val) && isPrimitiveEqualTo(val, originalValue))
50
+ if (!foundPrimitive) {
51
+ return false
52
+ }
53
+ }
54
+ } else if (isObject(value)) {
55
+ if (isObject(originalValue) && !hasPrimitiveKeys(originalValue, value)) {
56
+ return false
57
+ }
58
+ }
59
+ }
60
+
61
+ return true
62
+ }
@@ -0,0 +1 @@
1
+ export declare function toStringList(strs: string[]): string;
@@ -0,0 +1,8 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ exports.toStringList = void 0;
4
+ function toStringList(strs) {
5
+ return strs.map(($) => `\t* ${$}\n`).join('');
6
+ }
7
+ exports.toStringList = toStringList;
8
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoib3V0LW1lc3NhZ2VzLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsib3V0LW1lc3NhZ2VzLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiI7OztBQUFBLFNBQWdCLFlBQVksQ0FBQyxJQUFjO0lBQ3pDLE9BQU8sSUFBSSxDQUFDLEdBQUcsQ0FBQyxDQUFDLENBQUMsRUFBRSxFQUFFLENBQUMsT0FBTyxDQUFDLElBQUksQ0FBQyxDQUFDLElBQUksQ0FBQyxFQUFFLENBQUMsQ0FBQTtBQUMvQyxDQUFDO0FBRkQsb0NBRUMiLCJzb3VyY2VzQ29udGVudCI6WyJleHBvcnQgZnVuY3Rpb24gdG9TdHJpbmdMaXN0KHN0cnM6IHN0cmluZ1tdKTogc3RyaW5nIHtcbiAgcmV0dXJuIHN0cnMubWFwKCgkKSA9PiBgXFx0KiAkeyR9XFxuYCkuam9pbignJylcbn1cbiJdfQ==
@@ -0,0 +1,3 @@
1
+ export function toStringList(strs: string[]): string {
2
+ return strs.map(($) => `\t* ${$}\n`).join('')
3
+ }
@@ -61,8 +61,7 @@ export class Observable {
61
61
  }
62
62
  removeCallback(callback, scope) {
63
63
  for (let index = 0; index < this._observers.length; index++) {
64
- if (this._observers[index].callback === callback &&
65
- (!scope || scope === this._observers[index].scope)) {
64
+ if (this._observers[index].callback === callback && (!scope || scope === this._observers[index].scope)) {
66
65
  this._deferUnregister(this._observers[index]);
67
66
  return true;
68
67
  }
@@ -85,10 +84,7 @@ export class Observable {
85
84
  }
86
85
  if (obs.mask & mask) {
87
86
  if (obs.scope) {
88
- state.lastReturnValue = obs.callback.apply(obs.scope, [
89
- eventData,
90
- state
91
- ]);
87
+ state.lastReturnValue = obs.callback.apply(obs.scope, [eventData, state]);
92
88
  }
93
89
  else {
94
90
  state.lastReturnValue = obs.callback(eventData, state);
@@ -187,4 +183,4 @@ export class Observable {
187
183
  return false;
188
184
  }
189
185
  }
190
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"Observable.js","sourceRoot":"","sources":["../src/internal/Observable.ts"],"names":[],"mappings":"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","sourcesContent":["/**\n * A class serves as a medium between the observable and its observers\n * @deprecated This function is an inheritance of ECS6, it's here temporary for the feature parity, please read the news and docs to know how handle when it's removed\n */\nexport class ObserverEventState {\n  /**\n   * An Observer can set this property to true to prevent subsequent observers of being notified\n   */\n  public skipNextObservers!: boolean\n\n  /**\n   * Get the mask value that were used to trigger the event corresponding to this EventState object\n   */\n  public mask!: number\n\n  /**\n   * The object that originally notified the event\n   */\n  public target?: any\n\n  /**\n   * The current object in the bubbling phase\n   */\n  public currentTarget?: any\n\n  /**\n   * This will be populated with the return value of the last function that was executed.\n   * If it is the first function in the callback chain it will be the event data.\n   */\n  public lastReturnValue?: any\n\n  /**\n   * Create a new EventState\n   * @param mask - defines the mask associated with this state\n   * @param skipNextObservers - defines a flag which will instruct the observable to skip following observers when set to true\n   * @param target - defines the original target of the state\n   * @param currentTarget - defines the current target of the state\n   */\n  constructor(\n    mask: number,\n    skipNextObservers = false,\n    target?: any,\n    currentTarget?: any\n  ) {\n    this.initalize(mask, skipNextObservers, target, currentTarget)\n  }\n\n  /**\n   * Initialize the current event state\n   * @param mask - defines the mask associated with this state\n   * @param skipNextObservers - defines a flag which will instruct the observable to skip following observers when set to true\n   * @param target - defines the original target of the state\n   * @param currentTarget - defines the current target of the state\n   * @returns the current event state\n   */\n  public initalize(\n    mask: number,\n    skipNextObservers = false,\n    target?: any,\n    currentTarget?: any\n  ): ObserverEventState {\n    this.mask = mask\n    this.skipNextObservers = skipNextObservers\n    this.target = target\n    this.currentTarget = currentTarget\n    return this\n  }\n}\n\n/**\n * Represent an Observer registered to a given Observable object.\n * @deprecated This function is an inheritance of ECS6, it's here temporary for the feature parity, please read the news and docs to know how handle when it's removed\n */\nexport class Observer<T> {\n  /**\n   * Gets or sets a property defining that the observer as to be unregistered after the next notification\n   */\n  public unregisterOnNextCall = false\n\n  /** For internal usage */\n  public _willBeUnregistered = false\n\n  /**\n   * Creates a new observer\n   * @param callback - defines the callback to call when the observer is notified\n   * @param mask - defines the mask of the observer (used to filter notifications)\n   * @param scope - defines the current scope used to restore the JS context\n   */\n  constructor(\n    /**\n     * Defines the callback to call when the observer is notified\n     */\n    public callback: (eventData: T, eventState: ObserverEventState) => void,\n    /**\n     * Defines the mask of the observer (used to filter notifications)\n     */\n    public mask: number,\n    /**\n     * Defines the current scope used to restore the JS context\n     */\n    public scope: any = null\n  ) {}\n}\n\n/**\n * The Observable class is a simple implementation of the Observable pattern.\n *\n * There's one slight particularity though: a given Observable can notify its observer using a particular mask value, only the Observers registered with this mask value will be notified.\n * This enable a more fine grained execution without having to rely on multiple different Observable objects.\n * For instance you may have a given Observable that have four different types of notifications: Move (mask = 0x01), Stop (mask = 0x02), Turn Right (mask = 0X04), Turn Left (mask = 0X08).\n * A given observer can register itself with only Move and Stop (mask = 0x03), then it will only be notified when one of these two occurs and will never be for Turn Left/Right.\n *\n * @deprecated This function is an inheritance of ECS6, it's here temporary for the feature parity, please read the news and docs to know how handle when it's removed\n */\nexport class Observable<T> {\n  private _observers = new Array<Observer<T>>()\n\n  private _eventState: ObserverEventState\n\n  private _onObserverAdded: null | ((observer: Observer<T>) => void) = null\n\n  /**\n   * Creates a new observable\n   * @param onObserverAdded - defines a callback to call when a new observer is added\n   */\n  constructor(onObserverAdded?: (observer: Observer<T>) => void) {\n    this._eventState = new ObserverEventState(0)\n\n    if (onObserverAdded) {\n      this._onObserverAdded = onObserverAdded\n    }\n  }\n\n  /**\n   * Create a new Observer with the specified callback\n   * @param callback - the callback that will be executed for that Observer\n   * @param mask - the mask used to filter observers\n   * @param insertFirst - if true the callback will be inserted at the first position, hence executed before the others ones. If false (default behavior) the callback will be inserted at the last position, executed after all the others already present.\n   * @param scope - optional scope for the callback to be called from\n   * @param unregisterOnFirstCall - defines if the observer as to be unregistered after the next notification\n   * @returns the new observer created for the callback\n   */\n  public add(\n    callback: (eventData: T, eventState: ObserverEventState) => void,\n    mask: number = -1,\n    insertFirst = false,\n    scope: any = null,\n    unregisterOnFirstCall = false\n  ): null | Observer<T> {\n    if (!callback) {\n      return null\n    }\n\n    const observer = new Observer(callback, mask, scope)\n    observer.unregisterOnNextCall = unregisterOnFirstCall\n\n    if (insertFirst) {\n      this._observers.unshift(observer)\n    } else {\n      this._observers.push(observer)\n    }\n\n    if (this._onObserverAdded) {\n      this._onObserverAdded(observer)\n    }\n\n    return observer\n  }\n\n  /**\n   * Create a new Observer with the specified callback and unregisters after the next notification\n   * @param callback - the callback that will be executed for that Observer\n   * @returns the new observer created for the callback\n   */\n  public addOnce(\n    callback: (eventData: T, eventState: ObserverEventState) => void\n  ): null | Observer<T> {\n    return this.add(callback, undefined, undefined, undefined, true)\n  }\n\n  /**\n   * Remove an Observer from the Observable object\n   * @param observer - the instance of the Observer to remove\n   * @returns false if it doesn't belong to this Observable\n   */\n  public remove(observer: null | Observer<T>): boolean {\n    if (!observer) {\n      return false\n    }\n\n    const index = this._observers.indexOf(observer)\n\n    if (index !== -1) {\n      this._deferUnregister(observer)\n      return true\n    }\n\n    return false\n  }\n\n  /**\n   * Remove a callback from the Observable object\n   * @param callback - the callback to remove\n   * @param scope - optional scope. If used only the callbacks with this scope will be removed\n   * @returns false if it doesn't belong to this Observable\n   */\n  public removeCallback(\n    callback: (eventData: T, eventState: ObserverEventState) => void,\n    scope?: any\n  ): boolean {\n    for (let index = 0; index < this._observers.length; index++) {\n      if (\n        this._observers[index].callback === callback &&\n        (!scope || scope === this._observers[index].scope)\n      ) {\n        this._deferUnregister(this._observers[index])\n        return true\n      }\n    }\n\n    return false\n  }\n\n  /**\n   * Notify all Observers by calling their respective callback with the given data\n   * Will return true if all observers were executed, false if an observer set skipNextObservers to true, then prevent the subsequent ones to execute\n   * @param eventData - defines the data to send to all observers\n   * @param mask - defines the mask of the current notification (observers with incompatible mask (ie mask & observer.mask === 0) will not be notified)\n   * @param target - defines the original target of the state\n   * @param currentTarget - defines the current target of the state\n   * @returns false if the complete observer chain was not processed (because one observer set the skipNextObservers to true)\n   */\n  public notifyObservers(\n    eventData: T,\n    mask: number = -1,\n    target?: any,\n    currentTarget?: any\n  ): boolean {\n    if (!this._observers.length) {\n      return true\n    }\n\n    const state = this._eventState\n    state.mask = mask\n    state.target = target\n    state.currentTarget = currentTarget\n    state.skipNextObservers = false\n    state.lastReturnValue = eventData\n\n    for (const obs of this._observers) {\n      if (obs._willBeUnregistered) {\n        continue\n      }\n\n      if (obs.mask & mask) {\n        if (obs.scope) {\n          state.lastReturnValue = obs.callback.apply(obs.scope, [\n            eventData,\n            state\n          ])\n        } else {\n          state.lastReturnValue = obs.callback(eventData, state)\n        }\n\n        if (obs.unregisterOnNextCall) {\n          this._deferUnregister(obs)\n        }\n      }\n      if (state.skipNextObservers) {\n        return false\n      }\n    }\n    return true\n  }\n\n  /**\n   * Calling this will execute each callback, expecting it to be a promise or return a value.\n   * If at any point in the chain one function fails, the promise will fail and the execution will not continue.\n   * This is useful when a chain of events (sometimes async events) is needed to initialize a certain object\n   * and it is crucial that all callbacks will be executed.\n   * The order of the callbacks is kept, callbacks are not executed parallel.\n   *\n   * @param eventData - The data to be sent to each callback\n   * @param mask - is used to filter observers defaults to -1\n   * @param target - defines the callback target (see EventState)\n   * @param currentTarget - defines he current object in the bubbling phase\n   * @returns will return a Promise than resolves when all callbacks executed successfully.\n   */\n  public notifyObserversWithPromise(\n    eventData: T,\n    mask: number = -1,\n    target?: any,\n    currentTarget?: any\n  ): Promise<T> {\n    // create an empty promise\n    let p: Promise<any> = Promise.resolve(eventData)\n\n    // no observers? return this promise.\n    if (!this._observers.length) {\n      return p\n    }\n\n    const state = this._eventState\n    state.mask = mask\n    state.target = target\n    state.currentTarget = currentTarget\n    state.skipNextObservers = false\n\n    // execute one callback after another (not using Promise.all, the order is important)\n    this._observers.forEach((obs) => {\n      if (state.skipNextObservers) {\n        return\n      }\n      if (obs._willBeUnregistered) {\n        return\n      }\n      if (obs.mask & mask) {\n        if (obs.scope) {\n          p = p.then((lastReturnedValue) => {\n            state.lastReturnValue = lastReturnedValue\n            return obs.callback.apply(obs.scope, [eventData, state])\n          })\n        } else {\n          p = p.then((lastReturnedValue) => {\n            state.lastReturnValue = lastReturnedValue\n            return obs.callback(eventData, state)\n          })\n        }\n        if (obs.unregisterOnNextCall) {\n          this._deferUnregister(obs)\n        }\n      }\n    })\n\n    // return the eventData\n    return p.then(() => {\n      return eventData\n    })\n  }\n\n  /**\n   * Notify a specific observer\n   * @param observer - defines the observer to notify\n   * @param eventData - defines the data to be sent to each callback\n   * @param mask - is used to filter observers defaults to -1\n   */\n  public notifyObserver(\n    observer: Observer<T>,\n    eventData: T,\n    mask: number = -1\n  ): void {\n    const state = this._eventState\n    state.mask = mask\n    state.skipNextObservers = false\n\n    observer.callback(eventData, state)\n  }\n\n  /**\n   * Gets a boolean indicating if the observable has at least one observer\n   * @returns true is the Observable has at least one Observer registered\n   */\n  public hasObservers(): boolean {\n    return this._observers.length > 0\n  }\n\n  /**\n   * Clear the list of observers\n   */\n  public clear(): void {\n    this._observers = new Array<Observer<T>>()\n    this._onObserverAdded = null\n  }\n\n  /**\n   * Clone the current observable\n   * @returns a new observable\n   */\n  public clone(): Observable<T> {\n    const result = new Observable<T>()\n\n    result._observers = this._observers.slice(0)\n\n    return result\n  }\n\n  /**\n   * Does this observable handles observer registered with a given mask\n   * @param mask - defines the mask to be tested\n   * @returns whether or not one observer registered with the given mask is handeled\n   */\n  public hasSpecificMask(mask: number = -1): boolean {\n    for (const obs of this._observers) {\n      if (obs.mask & mask || obs.mask === mask) {\n        return true\n      }\n    }\n    return false\n  }\n\n  private _deferUnregister(observer: Observer<T>): void {\n    observer.unregisterOnNextCall = false\n    observer._willBeUnregistered = true\n    Promise.resolve()\n      .then.bind(Promise.resolve())(async () => this._remove(observer))\n      .catch(console.error)\n  }\n\n  // This should only be called when not iterating over _observers to avoid callback skipping.\n  // Removes an observer from the _observer Array.\n  private _remove(observer: null | Observer<T>): boolean {\n    if (!observer) {\n      return false\n    }\n\n    const index = this._observers.indexOf(observer)\n\n    if (index !== -1) {\n      this._observers.splice(index, 1)\n      return true\n    }\n\n    return false\n  }\n}\n"]}
186
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"Observable.js","sourceRoot":"","sources":["../src/internal/Observable.ts"],"names":[],"mappings":"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","sourcesContent":["/**\n * A class serves as a medium between the observable and its observers\n * @deprecated This function is an inheritance of ECS6, it's here temporary for the feature parity, please read the news and docs to know how handle when it's removed\n */\nexport class ObserverEventState {\n  /**\n   * An Observer can set this property to true to prevent subsequent observers of being notified\n   */\n  public skipNextObservers!: boolean\n\n  /**\n   * Get the mask value that were used to trigger the event corresponding to this EventState object\n   */\n  public mask!: number\n\n  /**\n   * The object that originally notified the event\n   */\n  public target?: any\n\n  /**\n   * The current object in the bubbling phase\n   */\n  public currentTarget?: any\n\n  /**\n   * This will be populated with the return value of the last function that was executed.\n   * If it is the first function in the callback chain it will be the event data.\n   */\n  public lastReturnValue?: any\n\n  /**\n   * Create a new EventState\n   * @param mask - defines the mask associated with this state\n   * @param skipNextObservers - defines a flag which will instruct the observable to skip following observers when set to true\n   * @param target - defines the original target of the state\n   * @param currentTarget - defines the current target of the state\n   */\n  constructor(mask: number, skipNextObservers = false, target?: any, currentTarget?: any) {\n    this.initalize(mask, skipNextObservers, target, currentTarget)\n  }\n\n  /**\n   * Initialize the current event state\n   * @param mask - defines the mask associated with this state\n   * @param skipNextObservers - defines a flag which will instruct the observable to skip following observers when set to true\n   * @param target - defines the original target of the state\n   * @param currentTarget - defines the current target of the state\n   * @returns the current event state\n   */\n  public initalize(mask: number, skipNextObservers = false, target?: any, currentTarget?: any): ObserverEventState {\n    this.mask = mask\n    this.skipNextObservers = skipNextObservers\n    this.target = target\n    this.currentTarget = currentTarget\n    return this\n  }\n}\n\n/**\n * Represent an Observer registered to a given Observable object.\n * @deprecated This function is an inheritance of ECS6, it's here temporary for the feature parity, please read the news and docs to know how handle when it's removed\n */\nexport class Observer<T> {\n  /**\n   * Gets or sets a property defining that the observer as to be unregistered after the next notification\n   */\n  public unregisterOnNextCall = false\n\n  /** For internal usage */\n  public _willBeUnregistered = false\n\n  /**\n   * Creates a new observer\n   * @param callback - defines the callback to call when the observer is notified\n   * @param mask - defines the mask of the observer (used to filter notifications)\n   * @param scope - defines the current scope used to restore the JS context\n   */\n  constructor(\n    /**\n     * Defines the callback to call when the observer is notified\n     */\n    public callback: (eventData: T, eventState: ObserverEventState) => void,\n    /**\n     * Defines the mask of the observer (used to filter notifications)\n     */\n    public mask: number,\n    /**\n     * Defines the current scope used to restore the JS context\n     */\n    public scope: any = null\n  ) {}\n}\n\n/**\n * The Observable class is a simple implementation of the Observable pattern.\n *\n * There's one slight particularity though: a given Observable can notify its observer using a particular mask value, only the Observers registered with this mask value will be notified.\n * This enable a more fine grained execution without having to rely on multiple different Observable objects.\n * For instance you may have a given Observable that have four different types of notifications: Move (mask = 0x01), Stop (mask = 0x02), Turn Right (mask = 0X04), Turn Left (mask = 0X08).\n * A given observer can register itself with only Move and Stop (mask = 0x03), then it will only be notified when one of these two occurs and will never be for Turn Left/Right.\n *\n * @deprecated This function is an inheritance of ECS6, it's here temporary for the feature parity, please read the news and docs to know how handle when it's removed\n */\nexport class Observable<T> {\n  private _observers = new Array<Observer<T>>()\n\n  private _eventState: ObserverEventState\n\n  private _onObserverAdded: null | ((observer: Observer<T>) => void) = null\n\n  /**\n   * Creates a new observable\n   * @param onObserverAdded - defines a callback to call when a new observer is added\n   */\n  constructor(onObserverAdded?: (observer: Observer<T>) => void) {\n    this._eventState = new ObserverEventState(0)\n\n    if (onObserverAdded) {\n      this._onObserverAdded = onObserverAdded\n    }\n  }\n\n  /**\n   * Create a new Observer with the specified callback\n   * @param callback - the callback that will be executed for that Observer\n   * @param mask - the mask used to filter observers\n   * @param insertFirst - if true the callback will be inserted at the first position, hence executed before the others ones. If false (default behavior) the callback will be inserted at the last position, executed after all the others already present.\n   * @param scope - optional scope for the callback to be called from\n   * @param unregisterOnFirstCall - defines if the observer as to be unregistered after the next notification\n   * @returns the new observer created for the callback\n   */\n  public add(\n    callback: (eventData: T, eventState: ObserverEventState) => void,\n    mask: number = -1,\n    insertFirst = false,\n    scope: any = null,\n    unregisterOnFirstCall = false\n  ): null | Observer<T> {\n    if (!callback) {\n      return null\n    }\n\n    const observer = new Observer(callback, mask, scope)\n    observer.unregisterOnNextCall = unregisterOnFirstCall\n\n    if (insertFirst) {\n      this._observers.unshift(observer)\n    } else {\n      this._observers.push(observer)\n    }\n\n    if (this._onObserverAdded) {\n      this._onObserverAdded(observer)\n    }\n\n    return observer\n  }\n\n  /**\n   * Create a new Observer with the specified callback and unregisters after the next notification\n   * @param callback - the callback that will be executed for that Observer\n   * @returns the new observer created for the callback\n   */\n  public addOnce(callback: (eventData: T, eventState: ObserverEventState) => void): null | Observer<T> {\n    return this.add(callback, undefined, undefined, undefined, true)\n  }\n\n  /**\n   * Remove an Observer from the Observable object\n   * @param observer - the instance of the Observer to remove\n   * @returns false if it doesn't belong to this Observable\n   */\n  public remove(observer: null | Observer<T>): boolean {\n    if (!observer) {\n      return false\n    }\n\n    const index = this._observers.indexOf(observer)\n\n    if (index !== -1) {\n      this._deferUnregister(observer)\n      return true\n    }\n\n    return false\n  }\n\n  /**\n   * Remove a callback from the Observable object\n   * @param callback - the callback to remove\n   * @param scope - optional scope. If used only the callbacks with this scope will be removed\n   * @returns false if it doesn't belong to this Observable\n   */\n  public removeCallback(callback: (eventData: T, eventState: ObserverEventState) => void, scope?: any): boolean {\n    for (let index = 0; index < this._observers.length; index++) {\n      if (this._observers[index].callback === callback && (!scope || scope === this._observers[index].scope)) {\n        this._deferUnregister(this._observers[index])\n        return true\n      }\n    }\n\n    return false\n  }\n\n  /**\n   * Notify all Observers by calling their respective callback with the given data\n   * Will return true if all observers were executed, false if an observer set skipNextObservers to true, then prevent the subsequent ones to execute\n   * @param eventData - defines the data to send to all observers\n   * @param mask - defines the mask of the current notification (observers with incompatible mask (ie mask & observer.mask === 0) will not be notified)\n   * @param target - defines the original target of the state\n   * @param currentTarget - defines the current target of the state\n   * @returns false if the complete observer chain was not processed (because one observer set the skipNextObservers to true)\n   */\n  public notifyObservers(eventData: T, mask: number = -1, target?: any, currentTarget?: any): boolean {\n    if (!this._observers.length) {\n      return true\n    }\n\n    const state = this._eventState\n    state.mask = mask\n    state.target = target\n    state.currentTarget = currentTarget\n    state.skipNextObservers = false\n    state.lastReturnValue = eventData\n\n    for (const obs of this._observers) {\n      if (obs._willBeUnregistered) {\n        continue\n      }\n\n      if (obs.mask & mask) {\n        if (obs.scope) {\n          state.lastReturnValue = obs.callback.apply(obs.scope, [eventData, state])\n        } else {\n          state.lastReturnValue = obs.callback(eventData, state)\n        }\n\n        if (obs.unregisterOnNextCall) {\n          this._deferUnregister(obs)\n        }\n      }\n      if (state.skipNextObservers) {\n        return false\n      }\n    }\n    return true\n  }\n\n  /**\n   * Calling this will execute each callback, expecting it to be a promise or return a value.\n   * If at any point in the chain one function fails, the promise will fail and the execution will not continue.\n   * This is useful when a chain of events (sometimes async events) is needed to initialize a certain object\n   * and it is crucial that all callbacks will be executed.\n   * The order of the callbacks is kept, callbacks are not executed parallel.\n   *\n   * @param eventData - The data to be sent to each callback\n   * @param mask - is used to filter observers defaults to -1\n   * @param target - defines the callback target (see EventState)\n   * @param currentTarget - defines he current object in the bubbling phase\n   * @returns will return a Promise than resolves when all callbacks executed successfully.\n   */\n  public notifyObserversWithPromise(eventData: T, mask: number = -1, target?: any, currentTarget?: any): Promise<T> {\n    // create an empty promise\n    let p: Promise<any> = Promise.resolve(eventData)\n\n    // no observers? return this promise.\n    if (!this._observers.length) {\n      return p\n    }\n\n    const state = this._eventState\n    state.mask = mask\n    state.target = target\n    state.currentTarget = currentTarget\n    state.skipNextObservers = false\n\n    // execute one callback after another (not using Promise.all, the order is important)\n    this._observers.forEach((obs) => {\n      if (state.skipNextObservers) {\n        return\n      }\n      if (obs._willBeUnregistered) {\n        return\n      }\n      if (obs.mask & mask) {\n        if (obs.scope) {\n          p = p.then((lastReturnedValue) => {\n            state.lastReturnValue = lastReturnedValue\n            return obs.callback.apply(obs.scope, [eventData, state])\n          })\n        } else {\n          p = p.then((lastReturnedValue) => {\n            state.lastReturnValue = lastReturnedValue\n            return obs.callback(eventData, state)\n          })\n        }\n        if (obs.unregisterOnNextCall) {\n          this._deferUnregister(obs)\n        }\n      }\n    })\n\n    // return the eventData\n    return p.then(() => {\n      return eventData\n    })\n  }\n\n  /**\n   * Notify a specific observer\n   * @param observer - defines the observer to notify\n   * @param eventData - defines the data to be sent to each callback\n   * @param mask - is used to filter observers defaults to -1\n   */\n  public notifyObserver(observer: Observer<T>, eventData: T, mask: number = -1): void {\n    const state = this._eventState\n    state.mask = mask\n    state.skipNextObservers = false\n\n    observer.callback(eventData, state)\n  }\n\n  /**\n   * Gets a boolean indicating if the observable has at least one observer\n   * @returns true is the Observable has at least one Observer registered\n   */\n  public hasObservers(): boolean {\n    return this._observers.length > 0\n  }\n\n  /**\n   * Clear the list of observers\n   */\n  public clear(): void {\n    this._observers = new Array<Observer<T>>()\n    this._onObserverAdded = null\n  }\n\n  /**\n   * Clone the current observable\n   * @returns a new observable\n   */\n  public clone(): Observable<T> {\n    const result = new Observable<T>()\n\n    result._observers = this._observers.slice(0)\n\n    return result\n  }\n\n  /**\n   * Does this observable handles observer registered with a given mask\n   * @param mask - defines the mask to be tested\n   * @returns whether or not one observer registered with the given mask is handeled\n   */\n  public hasSpecificMask(mask: number = -1): boolean {\n    for (const obs of this._observers) {\n      if (obs.mask & mask || obs.mask === mask) {\n        return true\n      }\n    }\n    return false\n  }\n\n  private _deferUnregister(observer: Observer<T>): void {\n    observer.unregisterOnNextCall = false\n    observer._willBeUnregistered = true\n    Promise.resolve()\n      .then.bind(Promise.resolve())(async () => this._remove(observer))\n      .catch(console.error)\n  }\n\n  // This should only be called when not iterating over _observers to avoid callback skipping.\n  // Removes an observer from the _observer Array.\n  private _remove(observer: null | Observer<T>): boolean {\n    if (!observer) {\n      return false\n    }\n\n    const index = this._observers.indexOf(observer)\n\n    if (index !== -1) {\n      this._observers.splice(index, 1)\n      return true\n    }\n\n    return false\n  }\n}\n"]}
@@ -25,4 +25,4 @@ export function getEthereumProvider(sendAsync) {
25
25
  }
26
26
  };
27
27
  }
28
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicHJvdmlkZXIuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi9zcmMvaW50ZXJuYWwvcHJvdmlkZXIudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBeUJBLE1BQU0sVUFBVSxtQkFBbUIsQ0FBQyxTQUF3QjtJQUMxRCxLQUFLLFVBQVUsT0FBTyxDQUFDLE9BQTJCO1FBQ2hELE1BQU0sUUFBUSxHQUFHLE1BQU0sU0FBUyxDQUFDO1lBQy9CLEVBQUUsRUFBRSxPQUFPLENBQUMsRUFBRTtZQUNkLE1BQU0sRUFBRSxPQUFPLENBQUMsTUFBTTtZQUN0QixVQUFVLEVBQUUsSUFBSSxDQUFDLFNBQVMsQ0FBQyxPQUFPLENBQUMsTUFBTSxDQUFDO1NBQzNDLENBQUMsQ0FBQTtRQUNGLE9BQU8sSUFBSSxDQUFDLEtBQUssQ0FBQyxRQUFRLENBQUMsZUFBZSxDQUFDLENBQUE7SUFDN0MsQ0FBQztJQUVELE9BQU87UUFFTCxJQUFJLENBQ0YsT0FBMkIsRUFDM0IsUUFBc0Q7WUFFdEQsSUFBSSxPQUFPLElBQUksUUFBUSxJQUFJLFFBQVEsWUFBWSxRQUFRLEVBQUU7Z0JBQ3ZELE9BQU8sQ0FBQyxPQUFPLENBQUM7cUJBQ2IsSUFBSSxDQUFDLENBQUMsQ0FBTSxFQUFFLEVBQUUsQ0FBQyxRQUFRLENBQUMsSUFBSSxFQUFFLENBQUMsQ0FBQyxDQUFDO3FCQUNuQyxLQUFLLENBQUMsUUFBUSxDQUFDLENBQUE7YUFDbkI7aUJBQU07Z0JBQ0wsTUFBTSxJQUFJLEtBQUssQ0FBQywrQ0FBK0MsQ0FBQyxDQUFBO2FBQ2pFO1FBQ0gsQ0FBQztRQUNELFNBQVMsQ0FDUCxPQUEyQixFQUMzQixRQUFxRDtZQUVyRCxPQUFPLENBQUMsT0FBTyxDQUFDO2lCQUNiLElBQUksQ0FBQyxDQUFDLENBQU0sRUFBRSxFQUFFLENBQUMsUUFBUSxDQUFDLElBQUksRUFBRSxDQUFDLENBQUMsQ0FBQztpQkFDbkMsS0FBSyxDQUFDLFFBQVEsQ0FBQyxDQUFBO1FBQ3BCLENBQUM7S0FDRixDQUFBO0FBQ0gsQ0FBQyIsInNvdXJjZXNDb250ZW50IjpbImV4cG9ydCBpbnRlcmZhY2UgU2VuZEFzeW5jUmVzcG9uc2Uge1xuICBqc29uQW55UmVzcG9uc2U6IHN0cmluZ1xufVxuXG5leHBvcnQgaW50ZXJmYWNlIFNlbmRBc3luY1JlcXVlc3Qge1xuICBpZDogbnVtYmVyXG4gIG1ldGhvZDogc3RyaW5nXG4gIGpzb25QYXJhbXM6IHN0cmluZ1xufVxuXG5leHBvcnQgdHlwZSBSUENTZW5kYWJsZU1lc3NhZ2UgPSB7XG4gIGpzb25ycGM6ICcyLjAnXG4gIGlkOiBudW1iZXJcbiAgbWV0aG9kOiBzdHJpbmdcbiAgcGFyYW1zOiBhbnlbXVxufVxuXG5leHBvcnQgaW50ZXJmYWNlIE1lc3NhZ2VEaWN0IHtcbiAgW2tleTogc3RyaW5nXTogc3RyaW5nXG59XG5cbmV4cG9ydCB0eXBlIFNlbmRBc3luY1R5cGUgPSAoXG4gIHBhcmFtczogU2VuZEFzeW5jUmVxdWVzdFxuKSA9PiBQcm9taXNlPFNlbmRBc3luY1Jlc3BvbnNlPlxuXG5leHBvcnQgZnVuY3Rpb24gZ2V0RXRoZXJldW1Qcm92aWRlcihzZW5kQXN5bmM6IFNlbmRBc3luY1R5cGUpIHtcbiAgYXN5bmMgZnVuY3Rpb24gcmVxdWVzdChtZXNzYWdlOiBSUENTZW5kYWJsZU1lc3NhZ2UpIHtcbiAgICBjb25zdCByZXNwb25zZSA9IGF3YWl0IHNlbmRBc3luYyh7XG4gICAgICBpZDogbWVzc2FnZS5pZCxcbiAgICAgIG1ldGhvZDogbWVzc2FnZS5tZXRob2QsXG4gICAgICBqc29uUGFyYW1zOiBKU09OLnN0cmluZ2lmeShtZXNzYWdlLnBhcmFtcylcbiAgICB9KVxuICAgIHJldHVybiBKU09OLnBhcnNlKHJlc3BvbnNlLmpzb25BbnlSZXNwb25zZSlcbiAgfVxuXG4gIHJldHVybiB7XG4gICAgLy8gQGludGVybmFsXG4gICAgc2VuZChcbiAgICAgIG1lc3NhZ2U6IFJQQ1NlbmRhYmxlTWVzc2FnZSxcbiAgICAgIGNhbGxiYWNrPzogKGVycm9yOiBFcnJvciB8IG51bGwsIHJlc3VsdD86IGFueSkgPT4gdm9pZFxuICAgICk6IHZvaWQge1xuICAgICAgaWYgKG1lc3NhZ2UgJiYgY2FsbGJhY2sgJiYgY2FsbGJhY2sgaW5zdGFuY2VvZiBGdW5jdGlvbikge1xuICAgICAgICByZXF1ZXN0KG1lc3NhZ2UpXG4gICAgICAgICAgLnRoZW4oKHg6IGFueSkgPT4gY2FsbGJhY2sobnVsbCwgeCkpXG4gICAgICAgICAgLmNhdGNoKGNhbGxiYWNrKVxuICAgICAgfSBlbHNlIHtcbiAgICAgICAgdGhyb3cgbmV3IEVycm9yKCdEZWNlbnRyYWxhbmQgcHJvdmlkZXIgb25seSBhbGxvd3MgYXN5bmMgY2FsbHMnKVxuICAgICAgfVxuICAgIH0sXG4gICAgc2VuZEFzeW5jKFxuICAgICAgbWVzc2FnZTogUlBDU2VuZGFibGVNZXNzYWdlLFxuICAgICAgY2FsbGJhY2s6IChlcnJvcjogRXJyb3IgfCBudWxsLCByZXN1bHQ/OiBhbnkpID0+IHZvaWRcbiAgICApOiB2b2lkIHtcbiAgICAgIHJlcXVlc3QobWVzc2FnZSlcbiAgICAgICAgLnRoZW4oKHg6IGFueSkgPT4gY2FsbGJhY2sobnVsbCwgeCkpXG4gICAgICAgIC5jYXRjaChjYWxsYmFjaylcbiAgICB9XG4gIH1cbn1cbiJdfQ==
28
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicHJvdmlkZXIuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi9zcmMvaW50ZXJuYWwvcHJvdmlkZXIudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBdUJBLE1BQU0sVUFBVSxtQkFBbUIsQ0FBQyxTQUF3QjtJQUMxRCxLQUFLLFVBQVUsT0FBTyxDQUFDLE9BQTJCO1FBQ2hELE1BQU0sUUFBUSxHQUFHLE1BQU0sU0FBUyxDQUFDO1lBQy9CLEVBQUUsRUFBRSxPQUFPLENBQUMsRUFBRTtZQUNkLE1BQU0sRUFBRSxPQUFPLENBQUMsTUFBTTtZQUN0QixVQUFVLEVBQUUsSUFBSSxDQUFDLFNBQVMsQ0FBQyxPQUFPLENBQUMsTUFBTSxDQUFDO1NBQzNDLENBQUMsQ0FBQTtRQUNGLE9BQU8sSUFBSSxDQUFDLEtBQUssQ0FBQyxRQUFRLENBQUMsZUFBZSxDQUFDLENBQUE7SUFDN0MsQ0FBQztJQUVELE9BQU87UUFFTCxJQUFJLENBQUMsT0FBMkIsRUFBRSxRQUFzRDtZQUN0RixJQUFJLE9BQU8sSUFBSSxRQUFRLElBQUksUUFBUSxZQUFZLFFBQVEsRUFBRTtnQkFDdkQsT0FBTyxDQUFDLE9BQU8sQ0FBQztxQkFDYixJQUFJLENBQUMsQ0FBQyxDQUFNLEVBQUUsRUFBRSxDQUFDLFFBQVEsQ0FBQyxJQUFJLEVBQUUsQ0FBQyxDQUFDLENBQUM7cUJBQ25DLEtBQUssQ0FBQyxRQUFRLENBQUMsQ0FBQTthQUNuQjtpQkFBTTtnQkFDTCxNQUFNLElBQUksS0FBSyxDQUFDLCtDQUErQyxDQUFDLENBQUE7YUFDakU7UUFDSCxDQUFDO1FBQ0QsU0FBUyxDQUFDLE9BQTJCLEVBQUUsUUFBcUQ7WUFDMUYsT0FBTyxDQUFDLE9BQU8sQ0FBQztpQkFDYixJQUFJLENBQUMsQ0FBQyxDQUFNLEVBQUUsRUFBRSxDQUFDLFFBQVEsQ0FBQyxJQUFJLEVBQUUsQ0FBQyxDQUFDLENBQUM7aUJBQ25DLEtBQUssQ0FBQyxRQUFRLENBQUMsQ0FBQTtRQUNwQixDQUFDO0tBQ0YsQ0FBQTtBQUNILENBQUMiLCJzb3VyY2VzQ29udGVudCI6WyJleHBvcnQgaW50ZXJmYWNlIFNlbmRBc3luY1Jlc3BvbnNlIHtcbiAganNvbkFueVJlc3BvbnNlOiBzdHJpbmdcbn1cblxuZXhwb3J0IGludGVyZmFjZSBTZW5kQXN5bmNSZXF1ZXN0IHtcbiAgaWQ6IG51bWJlclxuICBtZXRob2Q6IHN0cmluZ1xuICBqc29uUGFyYW1zOiBzdHJpbmdcbn1cblxuZXhwb3J0IHR5cGUgUlBDU2VuZGFibGVNZXNzYWdlID0ge1xuICBqc29ucnBjOiAnMi4wJ1xuICBpZDogbnVtYmVyXG4gIG1ldGhvZDogc3RyaW5nXG4gIHBhcmFtczogYW55W11cbn1cblxuZXhwb3J0IGludGVyZmFjZSBNZXNzYWdlRGljdCB7XG4gIFtrZXk6IHN0cmluZ106IHN0cmluZ1xufVxuXG5leHBvcnQgdHlwZSBTZW5kQXN5bmNUeXBlID0gKHBhcmFtczogU2VuZEFzeW5jUmVxdWVzdCkgPT4gUHJvbWlzZTxTZW5kQXN5bmNSZXNwb25zZT5cblxuZXhwb3J0IGZ1bmN0aW9uIGdldEV0aGVyZXVtUHJvdmlkZXIoc2VuZEFzeW5jOiBTZW5kQXN5bmNUeXBlKSB7XG4gIGFzeW5jIGZ1bmN0aW9uIHJlcXVlc3QobWVzc2FnZTogUlBDU2VuZGFibGVNZXNzYWdlKSB7XG4gICAgY29uc3QgcmVzcG9uc2UgPSBhd2FpdCBzZW5kQXN5bmMoe1xuICAgICAgaWQ6IG1lc3NhZ2UuaWQsXG4gICAgICBtZXRob2Q6IG1lc3NhZ2UubWV0aG9kLFxuICAgICAganNvblBhcmFtczogSlNPTi5zdHJpbmdpZnkobWVzc2FnZS5wYXJhbXMpXG4gICAgfSlcbiAgICByZXR1cm4gSlNPTi5wYXJzZShyZXNwb25zZS5qc29uQW55UmVzcG9uc2UpXG4gIH1cblxuICByZXR1cm4ge1xuICAgIC8vIEBpbnRlcm5hbFxuICAgIHNlbmQobWVzc2FnZTogUlBDU2VuZGFibGVNZXNzYWdlLCBjYWxsYmFjaz86IChlcnJvcjogRXJyb3IgfCBudWxsLCByZXN1bHQ/OiBhbnkpID0+IHZvaWQpOiB2b2lkIHtcbiAgICAgIGlmIChtZXNzYWdlICYmIGNhbGxiYWNrICYmIGNhbGxiYWNrIGluc3RhbmNlb2YgRnVuY3Rpb24pIHtcbiAgICAgICAgcmVxdWVzdChtZXNzYWdlKVxuICAgICAgICAgIC50aGVuKCh4OiBhbnkpID0+IGNhbGxiYWNrKG51bGwsIHgpKVxuICAgICAgICAgIC5jYXRjaChjYWxsYmFjaylcbiAgICAgIH0gZWxzZSB7XG4gICAgICAgIHRocm93IG5ldyBFcnJvcignRGVjZW50cmFsYW5kIHByb3ZpZGVyIG9ubHkgYWxsb3dzIGFzeW5jIGNhbGxzJylcbiAgICAgIH1cbiAgICB9LFxuICAgIHNlbmRBc3luYyhtZXNzYWdlOiBSUENTZW5kYWJsZU1lc3NhZ2UsIGNhbGxiYWNrOiAoZXJyb3I6IEVycm9yIHwgbnVsbCwgcmVzdWx0PzogYW55KSA9PiB2b2lkKTogdm9pZCB7XG4gICAgICByZXF1ZXN0KG1lc3NhZ2UpXG4gICAgICAgIC50aGVuKCh4OiBhbnkpID0+IGNhbGxiYWNrKG51bGwsIHgpKVxuICAgICAgICAuY2F0Y2goY2FsbGJhY2spXG4gICAgfVxuICB9XG59XG4iXX0=
@@ -24,8 +24,7 @@ export function createRendererTransport(engineApi) {
24
24
  }
25
25
  },
26
26
  filter(message) {
27
- if ((message.type === CrdtMessageType.PUT_COMPONENT ||
28
- message.type === CrdtMessageType.DELETE_COMPONENT) &&
27
+ if ((message.type === CrdtMessageType.PUT_COMPONENT || message.type === CrdtMessageType.DELETE_COMPONENT) &&
29
28
  message.componentId > MAX_STATIC_COMPONENT) {
30
29
  return false;
31
30
  }
@@ -34,4 +33,4 @@ export function createRendererTransport(engineApi) {
34
33
  };
35
34
  return rendererTransport;
36
35
  }
37
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicmVuZGVyZXJUcmFuc3BvcnQuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi9zcmMvaW50ZXJuYWwvdHJhbnNwb3J0cy9yZW5kZXJlclRyYW5zcG9ydC50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQStCLGVBQWUsRUFBRSxNQUFNLFVBQVUsQ0FBQTtBQUN2RSxPQUFPLEVBQUUsb0JBQW9CLEVBQUUsTUFBTSwyQ0FBMkMsQ0FBQTtBQVloRixNQUFNLFVBQVUsdUJBQXVCLENBQ3JDLFNBQWdDO0lBRWhDLEtBQUssVUFBVSxjQUFjLENBQUMsT0FBbUI7UUFDL0MsTUFBTSxRQUFRLEdBQUcsTUFBTSxTQUFTLENBQUMsa0JBQWtCLENBQUM7WUFDbEQsSUFBSSxFQUFFLElBQUksVUFBVSxDQUFDLE9BQU8sQ0FBQztTQUM5QixDQUFDLENBQUE7UUFFRixJQUFJLFFBQVEsSUFBSSxRQUFRLENBQUMsSUFBSSxJQUFJLFFBQVEsQ0FBQyxJQUFJLENBQUMsTUFBTSxFQUFFO1lBQ3JELElBQUksaUJBQWlCLENBQUMsU0FBUyxFQUFFO2dCQUMvQixLQUFLLE1BQU0sU0FBUyxJQUFJLFFBQVEsQ0FBQyxJQUFJLEVBQUU7b0JBQ3JDLGlCQUFpQixDQUFDLFNBQVMsQ0FBQyxTQUFTLENBQUMsQ0FBQTtpQkFDdkM7YUFDRjtTQUNGO0lBQ0gsQ0FBQztJQUVELE1BQU0saUJBQWlCLEdBQWM7UUFDbkMsS0FBSyxDQUFDLElBQUksQ0FBQyxPQUFPO1lBQ2hCLElBQUk7Z0JBQ0YsTUFBTSxjQUFjLENBQUMsT0FBTyxDQUFDLENBQUE7YUFDOUI7WUFBQyxPQUFPLEtBQUssRUFBRTtnQkFDZCxPQUFPLENBQUMsS0FBSyxDQUFDLEtBQUssQ0FBQyxDQUFBO2dCQUNwQixRQUFRLENBQUE7YUFDVDtRQUNILENBQUM7UUFDRCxNQUFNLENBQUMsT0FBeUI7WUFFOUIsSUFDRSxDQUFDLE9BQU8sQ0FBQyxJQUFJLEtBQUssZUFBZSxDQUFDLGFBQWE7Z0JBQzdDLE9BQU8sQ0FBQyxJQUFJLEtBQUssZUFBZSxDQUFDLGdCQUFnQixDQUFDO2dCQUVuRCxPQUFlLENBQUMsV0FBVyxHQUFHLG9CQUFvQixFQUNuRDtnQkFDQSxPQUFPLEtBQUssQ0FBQTthQUNiO1lBRUQsT0FBTyxDQUFDLENBQUMsT0FBTyxDQUFBO1FBQ2xCLENBQUM7S0FDRixDQUFBO0lBRUQsT0FBTyxpQkFBaUIsQ0FBQTtBQUMxQixDQUFDIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgVHJhbnNwb3J0LCBUcmFuc3BvcnRNZXNzYWdlLCBDcmR0TWVzc2FnZVR5cGUgfSBmcm9tICdAZGNsL2VjcydcbmltcG9ydCB7IE1BWF9TVEFUSUNfQ09NUE9ORU5UIH0gZnJvbSAnQGRjbC9lY3MvZGlzdC9jb21wb25lbnRzL2NvbXBvbmVudC1udW1iZXInXG5pbXBvcnQgdHlwZSB7XG4gIENyZHRTZW5kVG9SZW5kZXJlclJlcXVlc3QsXG4gIENyZHRTZW5kVG9SZXNwb25zZVxufSBmcm9tICd+c3lzdGVtL0VuZ2luZUFwaSdcblxuZXhwb3J0IHR5cGUgRW5naW5lQXBpRm9yVHJhbnNwb3J0ID0ge1xuICBjcmR0U2VuZFRvUmVuZGVyZXIoXG4gICAgYm9keTogQ3JkdFNlbmRUb1JlbmRlcmVyUmVxdWVzdFxuICApOiBQcm9taXNlPENyZHRTZW5kVG9SZXNwb25zZT5cbn1cblxuZXhwb3J0IGZ1bmN0aW9uIGNyZWF0ZVJlbmRlcmVyVHJhbnNwb3J0KFxuICBlbmdpbmVBcGk6IEVuZ2luZUFwaUZvclRyYW5zcG9ydFxuKTogVHJhbnNwb3J0IHtcbiAgYXN5bmMgZnVuY3Rpb24gc2VuZFRvUmVuZGVyZXIobWVzc2FnZTogVWludDhBcnJheSkge1xuICAgIGNvbnN0IHJlc3BvbnNlID0gYXdhaXQgZW5naW5lQXBpLmNyZHRTZW5kVG9SZW5kZXJlcih7XG4gICAgICBkYXRhOiBuZXcgVWludDhBcnJheShtZXNzYWdlKVxuICAgIH0pXG5cbiAgICBpZiAocmVzcG9uc2UgJiYgcmVzcG9uc2UuZGF0YSAmJiByZXNwb25zZS5kYXRhLmxlbmd0aCkge1xuICAgICAgaWYgKHJlbmRlcmVyVHJhbnNwb3J0Lm9ubWVzc2FnZSkge1xuICAgICAgICBmb3IgKGNvbnN0IGJ5dGVBcnJheSBvZiByZXNwb25zZS5kYXRhKSB7XG4gICAgICAgICAgcmVuZGVyZXJUcmFuc3BvcnQub25tZXNzYWdlKGJ5dGVBcnJheSlcbiAgICAgICAgfVxuICAgICAgfVxuICAgIH1cbiAgfVxuXG4gIGNvbnN0IHJlbmRlcmVyVHJhbnNwb3J0OiBUcmFuc3BvcnQgPSB7XG4gICAgYXN5bmMgc2VuZChtZXNzYWdlKSB7XG4gICAgICB0cnkge1xuICAgICAgICBhd2FpdCBzZW5kVG9SZW5kZXJlcihtZXNzYWdlKVxuICAgICAgfSBjYXRjaCAoZXJyb3IpIHtcbiAgICAgICAgY29uc29sZS5lcnJvcihlcnJvcilcbiAgICAgICAgZGVidWdnZXJcbiAgICAgIH1cbiAgICB9LFxuICAgIGZpbHRlcihtZXNzYWdlOiBUcmFuc3BvcnRNZXNzYWdlKSB7XG4gICAgICAvLyBPbmx5IHNlbmQgcmVuZGVyZXIgY29tcG9uZW50cyAoUHJvdG8gR2VuZXJhdGVkKVxuICAgICAgaWYgKFxuICAgICAgICAobWVzc2FnZS50eXBlID09PSBDcmR0TWVzc2FnZVR5cGUuUFVUX0NPTVBPTkVOVCB8fFxuICAgICAgICAgIG1lc3NhZ2UudHlwZSA9PT0gQ3JkdE1lc3NhZ2VUeXBlLkRFTEVURV9DT01QT05FTlQpICYmXG4gICAgICAgIC8vIGZpbHRlciBvdXQgbWVzc2FnZXMgZm9yIG5vbi1jb3JlIGNvbXBvbmVudHNcbiAgICAgICAgKG1lc3NhZ2UgYXMgYW55KS5jb21wb25lbnRJZCA+IE1BWF9TVEFUSUNfQ09NUE9ORU5UXG4gICAgICApIHtcbiAgICAgICAgcmV0dXJuIGZhbHNlXG4gICAgICB9XG5cbiAgICAgIHJldHVybiAhIW1lc3NhZ2VcbiAgICB9XG4gIH1cblxuICByZXR1cm4gcmVuZGVyZXJUcmFuc3BvcnRcbn1cbiJdfQ==
36
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicmVuZGVyZXJUcmFuc3BvcnQuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi9zcmMvaW50ZXJuYWwvdHJhbnNwb3J0cy9yZW5kZXJlclRyYW5zcG9ydC50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQStCLGVBQWUsRUFBRSxNQUFNLFVBQVUsQ0FBQTtBQUN2RSxPQUFPLEVBQUUsb0JBQW9CLEVBQUUsTUFBTSwyQ0FBMkMsQ0FBQTtBQU9oRixNQUFNLFVBQVUsdUJBQXVCLENBQUMsU0FBZ0M7SUFDdEUsS0FBSyxVQUFVLGNBQWMsQ0FBQyxPQUFtQjtRQUMvQyxNQUFNLFFBQVEsR0FBRyxNQUFNLFNBQVMsQ0FBQyxrQkFBa0IsQ0FBQztZQUNsRCxJQUFJLEVBQUUsSUFBSSxVQUFVLENBQUMsT0FBTyxDQUFDO1NBQzlCLENBQUMsQ0FBQTtRQUVGLElBQUksUUFBUSxJQUFJLFFBQVEsQ0FBQyxJQUFJLElBQUksUUFBUSxDQUFDLElBQUksQ0FBQyxNQUFNLEVBQUU7WUFDckQsSUFBSSxpQkFBaUIsQ0FBQyxTQUFTLEVBQUU7Z0JBQy9CLEtBQUssTUFBTSxTQUFTLElBQUksUUFBUSxDQUFDLElBQUksRUFBRTtvQkFDckMsaUJBQWlCLENBQUMsU0FBUyxDQUFDLFNBQVMsQ0FBQyxDQUFBO2lCQUN2QzthQUNGO1NBQ0Y7SUFDSCxDQUFDO0lBRUQsTUFBTSxpQkFBaUIsR0FBYztRQUNuQyxLQUFLLENBQUMsSUFBSSxDQUFDLE9BQU87WUFDaEIsSUFBSTtnQkFDRixNQUFNLGNBQWMsQ0FBQyxPQUFPLENBQUMsQ0FBQTthQUM5QjtZQUFDLE9BQU8sS0FBSyxFQUFFO2dCQUNkLE9BQU8sQ0FBQyxLQUFLLENBQUMsS0FBSyxDQUFDLENBQUE7Z0JBQ3BCLFFBQVEsQ0FBQTthQUNUO1FBQ0gsQ0FBQztRQUNELE1BQU0sQ0FBQyxPQUF5QjtZQUU5QixJQUNFLENBQUMsT0FBTyxDQUFDLElBQUksS0FBSyxlQUFlLENBQUMsYUFBYSxJQUFJLE9BQU8sQ0FBQyxJQUFJLEtBQUssZUFBZSxDQUFDLGdCQUFnQixDQUFDO2dCQUVwRyxPQUFlLENBQUMsV0FBVyxHQUFHLG9CQUFvQixFQUNuRDtnQkFDQSxPQUFPLEtBQUssQ0FBQTthQUNiO1lBRUQsT0FBTyxDQUFDLENBQUMsT0FBTyxDQUFBO1FBQ2xCLENBQUM7S0FDRixDQUFBO0lBRUQsT0FBTyxpQkFBaUIsQ0FBQTtBQUMxQixDQUFDIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgVHJhbnNwb3J0LCBUcmFuc3BvcnRNZXNzYWdlLCBDcmR0TWVzc2FnZVR5cGUgfSBmcm9tICdAZGNsL2VjcydcbmltcG9ydCB7IE1BWF9TVEFUSUNfQ09NUE9ORU5UIH0gZnJvbSAnQGRjbC9lY3MvZGlzdC9jb21wb25lbnRzL2NvbXBvbmVudC1udW1iZXInXG5pbXBvcnQgdHlwZSB7IENyZHRTZW5kVG9SZW5kZXJlclJlcXVlc3QsIENyZHRTZW5kVG9SZXNwb25zZSB9IGZyb20gJ35zeXN0ZW0vRW5naW5lQXBpJ1xuXG5leHBvcnQgdHlwZSBFbmdpbmVBcGlGb3JUcmFuc3BvcnQgPSB7XG4gIGNyZHRTZW5kVG9SZW5kZXJlcihib2R5OiBDcmR0U2VuZFRvUmVuZGVyZXJSZXF1ZXN0KTogUHJvbWlzZTxDcmR0U2VuZFRvUmVzcG9uc2U+XG59XG5cbmV4cG9ydCBmdW5jdGlvbiBjcmVhdGVSZW5kZXJlclRyYW5zcG9ydChlbmdpbmVBcGk6IEVuZ2luZUFwaUZvclRyYW5zcG9ydCk6IFRyYW5zcG9ydCB7XG4gIGFzeW5jIGZ1bmN0aW9uIHNlbmRUb1JlbmRlcmVyKG1lc3NhZ2U6IFVpbnQ4QXJyYXkpIHtcbiAgICBjb25zdCByZXNwb25zZSA9IGF3YWl0IGVuZ2luZUFwaS5jcmR0U2VuZFRvUmVuZGVyZXIoe1xuICAgICAgZGF0YTogbmV3IFVpbnQ4QXJyYXkobWVzc2FnZSlcbiAgICB9KVxuXG4gICAgaWYgKHJlc3BvbnNlICYmIHJlc3BvbnNlLmRhdGEgJiYgcmVzcG9uc2UuZGF0YS5sZW5ndGgpIHtcbiAgICAgIGlmIChyZW5kZXJlclRyYW5zcG9ydC5vbm1lc3NhZ2UpIHtcbiAgICAgICAgZm9yIChjb25zdCBieXRlQXJyYXkgb2YgcmVzcG9uc2UuZGF0YSkge1xuICAgICAgICAgIHJlbmRlcmVyVHJhbnNwb3J0Lm9ubWVzc2FnZShieXRlQXJyYXkpXG4gICAgICAgIH1cbiAgICAgIH1cbiAgICB9XG4gIH1cblxuICBjb25zdCByZW5kZXJlclRyYW5zcG9ydDogVHJhbnNwb3J0ID0ge1xuICAgIGFzeW5jIHNlbmQobWVzc2FnZSkge1xuICAgICAgdHJ5IHtcbiAgICAgICAgYXdhaXQgc2VuZFRvUmVuZGVyZXIobWVzc2FnZSlcbiAgICAgIH0gY2F0Y2ggKGVycm9yKSB7XG4gICAgICAgIGNvbnNvbGUuZXJyb3IoZXJyb3IpXG4gICAgICAgIGRlYnVnZ2VyXG4gICAgICB9XG4gICAgfSxcbiAgICBmaWx0ZXIobWVzc2FnZTogVHJhbnNwb3J0TWVzc2FnZSkge1xuICAgICAgLy8gT25seSBzZW5kIHJlbmRlcmVyIGNvbXBvbmVudHMgKFByb3RvIEdlbmVyYXRlZClcbiAgICAgIGlmIChcbiAgICAgICAgKG1lc3NhZ2UudHlwZSA9PT0gQ3JkdE1lc3NhZ2VUeXBlLlBVVF9DT01QT05FTlQgfHwgbWVzc2FnZS50eXBlID09PSBDcmR0TWVzc2FnZVR5cGUuREVMRVRFX0NPTVBPTkVOVCkgJiZcbiAgICAgICAgLy8gZmlsdGVyIG91dCBtZXNzYWdlcyBmb3Igbm9uLWNvcmUgY29tcG9uZW50c1xuICAgICAgICAobWVzc2FnZSBhcyBhbnkpLmNvbXBvbmVudElkID4gTUFYX1NUQVRJQ19DT01QT05FTlRcbiAgICAgICkge1xuICAgICAgICByZXR1cm4gZmFsc2VcbiAgICAgIH1cblxuICAgICAgcmV0dXJuICEhbWVzc2FnZVxuICAgIH1cbiAgfVxuXG4gIHJldHVybiByZW5kZXJlclRyYW5zcG9ydFxufVxuIl19
package/messageBus.js CHANGED
@@ -40,4 +40,4 @@ export class MessageBus {
40
40
  });
41
41
  }
42
42
  }
43
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoibWVzc2FnZUJ1cy5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbInNyYy9tZXNzYWdlQnVzLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUNBLE9BQU8sRUFBVyxjQUFjLEVBQUUsTUFBTSxlQUFlLENBQUE7QUFDdkQsT0FBTyxLQUFLLHdCQUF3QixNQUFNLGtDQUFrQyxDQUFBO0FBTTVFLE1BQU0sT0FBTyxVQUFVO0lBSXJCO1FBSFEsaUJBQVksR0FBYSxFQUFFLENBQUE7UUFDM0IsYUFBUSxHQUFHLEtBQUssQ0FBQTtJQUVULENBQUM7SUFFaEIsRUFBRSxDQUNBLE9BQWUsRUFDZixRQUE4QztRQUU5QyxPQUFPLGNBQWMsQ0FBQyxHQUFHLENBQUMsQ0FBQyxDQUFDLEVBQUUsRUFBRTtZQUM5QixNQUFNLENBQUMsR0FBRyxJQUFJLENBQUMsS0FBSyxDQUFDLENBQUMsQ0FBQyxPQUFPLENBQUMsQ0FBQTtZQUUvQixJQUFJLENBQUMsQ0FBQyxPQUFPLEtBQUssT0FBTyxFQUFFO2dCQUN6QixRQUFRLENBQUMsQ0FBQyxDQUFDLE9BQU8sRUFBRSxDQUFDLENBQUMsTUFBTSxDQUFDLENBQUE7YUFDOUI7UUFDSCxDQUFDLENBQUUsQ0FBQTtJQUNMLENBQUM7SUFHRCxPQUFPLENBQUMsT0FBZTtRQUNyQixJQUFJLENBQUMsWUFBWSxDQUFDLElBQUksQ0FBQyxPQUFPLENBQUMsQ0FBQTtRQUUvQixJQUFJLENBQUMsS0FBSyxFQUFFLENBQUE7SUFDZCxDQUFDO0lBRUQsSUFBSSxDQUFDLE9BQWUsRUFBRSxPQUF5QjtRQUM3QyxNQUFNLGFBQWEsR0FBRyxJQUFJLENBQUMsU0FBUyxDQUFDLEVBQUUsT0FBTyxFQUFFLE9BQU8sRUFBRSxDQUFDLENBQUE7UUFDMUQsSUFBSSxDQUFDLE9BQU8sQ0FBQyxhQUFhLENBQUMsQ0FBQTtRQUMzQixjQUFjLENBQUMsZUFBZSxDQUFDO1lBQzdCLE9BQU8sRUFBRSxhQUFhO1lBQ3RCLE1BQU0sRUFBRSxNQUFNO1NBQ2YsQ0FBQyxDQUFBO0lBQ0osQ0FBQztJQUVPLEtBQUs7UUFDWCxJQUFJLElBQUksQ0FBQyxZQUFZLENBQUMsTUFBTSxLQUFLLENBQUM7WUFBRSxPQUFNO1FBQzFDLElBQUksSUFBSSxDQUFDLFFBQVE7WUFBRSxPQUFNO1FBRXpCLE1BQU0sT0FBTyxHQUFHLElBQUksQ0FBQyxZQUFZLENBQUMsS0FBSyxFQUFHLENBQUE7UUFFMUMsSUFBSSxDQUFDLFFBQVEsR0FBRyxJQUFJLENBQUE7UUFFcEIsd0JBQXdCLENBQUMsSUFBSSxDQUFDLEVBQUUsT0FBTyxFQUFFLENBQUMsQ0FBQyxJQUFJLENBQzdDLENBQUMsQ0FBQyxFQUFFLEVBQUU7WUFDSixJQUFJLENBQUMsUUFBUSxHQUFHLEtBQUssQ0FBQTtZQUNyQixJQUFJLENBQUMsS0FBSyxFQUFFLENBQUE7UUFDZCxDQUFDLEVBQ0QsQ0FBQyxDQUFDLEVBQUUsRUFBRTtZQUNKLElBQUksQ0FBQyxRQUFRLEdBQUcsS0FBSyxDQUFBO1FBQ3ZCLENBQUMsQ0FDRixDQUFBO0lBQ0gsQ0FBQztDQUNGIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgT2JzZXJ2ZXIgfSBmcm9tICcuL2ludGVybmFsL09ic2VydmFibGUnXG5pbXBvcnQgeyBJRXZlbnRzLCBvbkNvbW1zTWVzc2FnZSB9IGZyb20gJy4vb2JzZXJ2YWJsZXMnXG5pbXBvcnQgKiBhcyBjb21tdW5pY2F0aW9uc0NvbnRyb2xsZXIgZnJvbSAnfnN5c3RlbS9Db21tdW5pY2F0aW9uc0NvbnRyb2xsZXInXG5cbi8qKlxuICogQGFscGhhXG4gKiBAZGVwcmVjYXRlZCB0aGlzIHdpbGwgb25seSBleGlzdCBmb3IgYSBmZXcgcmVsZWFzZXMgaW4gRUNTN1xuICovXG5leHBvcnQgY2xhc3MgTWVzc2FnZUJ1cyB7XG4gIHByaXZhdGUgbWVzc2FnZVF1ZXVlOiBzdHJpbmdbXSA9IFtdXG4gIHByaXZhdGUgZmx1c2hpbmcgPSBmYWxzZVxuXG4gIGNvbnN0cnVjdG9yKCkge31cblxuICBvbihcbiAgICBtZXNzYWdlOiBzdHJpbmcsXG4gICAgY2FsbGJhY2s6ICh2YWx1ZTogYW55LCBzZW5kZXI6IHN0cmluZykgPT4gdm9pZFxuICApOiBPYnNlcnZlcjxJRXZlbnRzWydjb21tcyddPiB7XG4gICAgcmV0dXJuIG9uQ29tbXNNZXNzYWdlLmFkZCgoZSkgPT4ge1xuICAgICAgY29uc3QgbSA9IEpTT04ucGFyc2UoZS5tZXNzYWdlKVxuXG4gICAgICBpZiAobS5tZXNzYWdlID09PSBtZXNzYWdlKSB7XG4gICAgICAgIGNhbGxiYWNrKG0ucGF5bG9hZCwgZS5zZW5kZXIpXG4gICAgICB9XG4gICAgfSkhXG4gIH1cblxuICAvLyBAaW50ZXJuYWxcbiAgc2VuZFJhdyhtZXNzYWdlOiBzdHJpbmcpIHtcbiAgICB0aGlzLm1lc3NhZ2VRdWV1ZS5wdXNoKG1lc3NhZ2UpXG5cbiAgICB0aGlzLmZsdXNoKClcbiAgfVxuXG4gIGVtaXQobWVzc2FnZTogc3RyaW5nLCBwYXlsb2FkOiBSZWNvcmQ8YW55LCBhbnk+KSB7XG4gICAgY29uc3QgbWVzc2FnZVRvU2VuZCA9IEpTT04uc3RyaW5naWZ5KHsgbWVzc2FnZSwgcGF5bG9hZCB9KVxuICAgIHRoaXMuc2VuZFJhdyhtZXNzYWdlVG9TZW5kKVxuICAgIG9uQ29tbXNNZXNzYWdlLm5vdGlmeU9ic2VydmVycyh7XG4gICAgICBtZXNzYWdlOiBtZXNzYWdlVG9TZW5kLFxuICAgICAgc2VuZGVyOiAnc2VsZidcbiAgICB9KVxuICB9XG5cbiAgcHJpdmF0ZSBmbHVzaCgpIHtcbiAgICBpZiAodGhpcy5tZXNzYWdlUXVldWUubGVuZ3RoID09PSAwKSByZXR1cm5cbiAgICBpZiAodGhpcy5mbHVzaGluZykgcmV0dXJuXG5cbiAgICBjb25zdCBtZXNzYWdlID0gdGhpcy5tZXNzYWdlUXVldWUuc2hpZnQoKSFcblxuICAgIHRoaXMuZmx1c2hpbmcgPSB0cnVlXG5cbiAgICBjb21tdW5pY2F0aW9uc0NvbnRyb2xsZXIuc2VuZCh7IG1lc3NhZ2UgfSkudGhlbihcbiAgICAgIChfKSA9PiB7XG4gICAgICAgIHRoaXMuZmx1c2hpbmcgPSBmYWxzZVxuICAgICAgICB0aGlzLmZsdXNoKClcbiAgICAgIH0sXG4gICAgICAoXykgPT4ge1xuICAgICAgICB0aGlzLmZsdXNoaW5nID0gZmFsc2VcbiAgICAgIH1cbiAgICApXG4gIH1cbn1cbiJdfQ==
43
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoibWVzc2FnZUJ1cy5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbInNyYy9tZXNzYWdlQnVzLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUNBLE9BQU8sRUFBVyxjQUFjLEVBQUUsTUFBTSxlQUFlLENBQUE7QUFDdkQsT0FBTyxLQUFLLHdCQUF3QixNQUFNLGtDQUFrQyxDQUFBO0FBTTVFLE1BQU0sT0FBTyxVQUFVO0lBSXJCO1FBSFEsaUJBQVksR0FBYSxFQUFFLENBQUE7UUFDM0IsYUFBUSxHQUFHLEtBQUssQ0FBQTtJQUVULENBQUM7SUFFaEIsRUFBRSxDQUFDLE9BQWUsRUFBRSxRQUE4QztRQUNoRSxPQUFPLGNBQWMsQ0FBQyxHQUFHLENBQUMsQ0FBQyxDQUFDLEVBQUUsRUFBRTtZQUM5QixNQUFNLENBQUMsR0FBRyxJQUFJLENBQUMsS0FBSyxDQUFDLENBQUMsQ0FBQyxPQUFPLENBQUMsQ0FBQTtZQUUvQixJQUFJLENBQUMsQ0FBQyxPQUFPLEtBQUssT0FBTyxFQUFFO2dCQUN6QixRQUFRLENBQUMsQ0FBQyxDQUFDLE9BQU8sRUFBRSxDQUFDLENBQUMsTUFBTSxDQUFDLENBQUE7YUFDOUI7UUFDSCxDQUFDLENBQUUsQ0FBQTtJQUNMLENBQUM7SUFHRCxPQUFPLENBQUMsT0FBZTtRQUNyQixJQUFJLENBQUMsWUFBWSxDQUFDLElBQUksQ0FBQyxPQUFPLENBQUMsQ0FBQTtRQUUvQixJQUFJLENBQUMsS0FBSyxFQUFFLENBQUE7SUFDZCxDQUFDO0lBRUQsSUFBSSxDQUFDLE9BQWUsRUFBRSxPQUF5QjtRQUM3QyxNQUFNLGFBQWEsR0FBRyxJQUFJLENBQUMsU0FBUyxDQUFDLEVBQUUsT0FBTyxFQUFFLE9BQU8sRUFBRSxDQUFDLENBQUE7UUFDMUQsSUFBSSxDQUFDLE9BQU8sQ0FBQyxhQUFhLENBQUMsQ0FBQTtRQUMzQixjQUFjLENBQUMsZUFBZSxDQUFDO1lBQzdCLE9BQU8sRUFBRSxhQUFhO1lBQ3RCLE1BQU0sRUFBRSxNQUFNO1NBQ2YsQ0FBQyxDQUFBO0lBQ0osQ0FBQztJQUVPLEtBQUs7UUFDWCxJQUFJLElBQUksQ0FBQyxZQUFZLENBQUMsTUFBTSxLQUFLLENBQUM7WUFBRSxPQUFNO1FBQzFDLElBQUksSUFBSSxDQUFDLFFBQVE7WUFBRSxPQUFNO1FBRXpCLE1BQU0sT0FBTyxHQUFHLElBQUksQ0FBQyxZQUFZLENBQUMsS0FBSyxFQUFHLENBQUE7UUFFMUMsSUFBSSxDQUFDLFFBQVEsR0FBRyxJQUFJLENBQUE7UUFFcEIsd0JBQXdCLENBQUMsSUFBSSxDQUFDLEVBQUUsT0FBTyxFQUFFLENBQUMsQ0FBQyxJQUFJLENBQzdDLENBQUMsQ0FBQyxFQUFFLEVBQUU7WUFDSixJQUFJLENBQUMsUUFBUSxHQUFHLEtBQUssQ0FBQTtZQUNyQixJQUFJLENBQUMsS0FBSyxFQUFFLENBQUE7UUFDZCxDQUFDLEVBQ0QsQ0FBQyxDQUFDLEVBQUUsRUFBRTtZQUNKLElBQUksQ0FBQyxRQUFRLEdBQUcsS0FBSyxDQUFBO1FBQ3ZCLENBQUMsQ0FDRixDQUFBO0lBQ0gsQ0FBQztDQUNGIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgT2JzZXJ2ZXIgfSBmcm9tICcuL2ludGVybmFsL09ic2VydmFibGUnXG5pbXBvcnQgeyBJRXZlbnRzLCBvbkNvbW1zTWVzc2FnZSB9IGZyb20gJy4vb2JzZXJ2YWJsZXMnXG5pbXBvcnQgKiBhcyBjb21tdW5pY2F0aW9uc0NvbnRyb2xsZXIgZnJvbSAnfnN5c3RlbS9Db21tdW5pY2F0aW9uc0NvbnRyb2xsZXInXG5cbi8qKlxuICogQGFscGhhXG4gKiBAZGVwcmVjYXRlZCB0aGlzIHdpbGwgb25seSBleGlzdCBmb3IgYSBmZXcgcmVsZWFzZXMgaW4gRUNTN1xuICovXG5leHBvcnQgY2xhc3MgTWVzc2FnZUJ1cyB7XG4gIHByaXZhdGUgbWVzc2FnZVF1ZXVlOiBzdHJpbmdbXSA9IFtdXG4gIHByaXZhdGUgZmx1c2hpbmcgPSBmYWxzZVxuXG4gIGNvbnN0cnVjdG9yKCkge31cblxuICBvbihtZXNzYWdlOiBzdHJpbmcsIGNhbGxiYWNrOiAodmFsdWU6IGFueSwgc2VuZGVyOiBzdHJpbmcpID0+IHZvaWQpOiBPYnNlcnZlcjxJRXZlbnRzWydjb21tcyddPiB7XG4gICAgcmV0dXJuIG9uQ29tbXNNZXNzYWdlLmFkZCgoZSkgPT4ge1xuICAgICAgY29uc3QgbSA9IEpTT04ucGFyc2UoZS5tZXNzYWdlKVxuXG4gICAgICBpZiAobS5tZXNzYWdlID09PSBtZXNzYWdlKSB7XG4gICAgICAgIGNhbGxiYWNrKG0ucGF5bG9hZCwgZS5zZW5kZXIpXG4gICAgICB9XG4gICAgfSkhXG4gIH1cblxuICAvLyBAaW50ZXJuYWxcbiAgc2VuZFJhdyhtZXNzYWdlOiBzdHJpbmcpIHtcbiAgICB0aGlzLm1lc3NhZ2VRdWV1ZS5wdXNoKG1lc3NhZ2UpXG5cbiAgICB0aGlzLmZsdXNoKClcbiAgfVxuXG4gIGVtaXQobWVzc2FnZTogc3RyaW5nLCBwYXlsb2FkOiBSZWNvcmQ8YW55LCBhbnk+KSB7XG4gICAgY29uc3QgbWVzc2FnZVRvU2VuZCA9IEpTT04uc3RyaW5naWZ5KHsgbWVzc2FnZSwgcGF5bG9hZCB9KVxuICAgIHRoaXMuc2VuZFJhdyhtZXNzYWdlVG9TZW5kKVxuICAgIG9uQ29tbXNNZXNzYWdlLm5vdGlmeU9ic2VydmVycyh7XG4gICAgICBtZXNzYWdlOiBtZXNzYWdlVG9TZW5kLFxuICAgICAgc2VuZGVyOiAnc2VsZidcbiAgICB9KVxuICB9XG5cbiAgcHJpdmF0ZSBmbHVzaCgpIHtcbiAgICBpZiAodGhpcy5tZXNzYWdlUXVldWUubGVuZ3RoID09PSAwKSByZXR1cm5cbiAgICBpZiAodGhpcy5mbHVzaGluZykgcmV0dXJuXG5cbiAgICBjb25zdCBtZXNzYWdlID0gdGhpcy5tZXNzYWdlUXVldWUuc2hpZnQoKSFcblxuICAgIHRoaXMuZmx1c2hpbmcgPSB0cnVlXG5cbiAgICBjb21tdW5pY2F0aW9uc0NvbnRyb2xsZXIuc2VuZCh7IG1lc3NhZ2UgfSkudGhlbihcbiAgICAgIChfKSA9PiB7XG4gICAgICAgIHRoaXMuZmx1c2hpbmcgPSBmYWxzZVxuICAgICAgICB0aGlzLmZsdXNoKClcbiAgICAgIH0sXG4gICAgICAoXykgPT4ge1xuICAgICAgICB0aGlzLmZsdXNoaW5nID0gZmFsc2VcbiAgICAgIH1cbiAgICApXG4gIH1cbn1cbiJdfQ==
package/observables.js CHANGED
@@ -72,4 +72,4 @@ export async function pollEvents(sendBatch) {
72
72
  }
73
73
  }
74
74
  }
75
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"observables.js","sourceRoot":"","sources":["src/observables.ts"],"names":[],"mappings":"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","sourcesContent":["import { Observable } from './internal/Observable'\nimport { QuaternionType, Vector3Type } from '@dcl/ecs'\nimport { ManyEntityAction, SendBatchResponse } from '~system/EngineApi'\n\nlet subscribeFunction: (event: {\n  eventId: string\n}) => Promise<any> = async () => {}\n\n/** @public */\nexport type InputEventResult = {\n  /** Origin of the ray, relative to the scene */\n  origin: Vector3Type\n  /** Direction vector of the ray (normalized) */\n  direction: Vector3Type\n  /** ID of the pointer that triggered the event */\n  buttonId: number\n  /** Does this pointer event hit any object? */\n  hit?: {\n    /** Length of the ray */\n    length: number\n    /** If the ray hits a mesh the intersection point will be this */\n    hitPoint: Vector3Type\n    /** If the mesh has a name, it will be assigned to meshName */\n    meshName: string\n    /** Normal of the hit */\n    normal: Vector3Type\n    /** Normal of the hit, in world space */\n    worldNormal: Vector3Type\n    /** Hit entity ID if any */\n    entityId: unknown\n  }\n}\n\n/** @public */\nexport type GlobalInputEventResult = InputEventResult & {\n  /**\n   * DOWN = 0,\n   * UP = 1\n   */\n  type: 0 | 1\n}\n\n/** @public */\nexport type RaycastResponsePayload<T> = {\n  queryId: string\n  queryType: string\n  payload: T\n}\n\n/** @public */\nexport type GizmoDragEndEvent = {\n  type: 'gizmoDragEnded'\n  transforms: Array<{\n    position: Vector3Type\n    rotation: QuaternionType\n    scale: Vector3Type\n    entityId: unknown\n  }>\n}\n\n/** @public */\nexport type GizmoSelectedEvent = {\n  type: 'gizmoSelected'\n  gizmoType: 'MOVE' | 'ROTATE' | 'SCALE' | 'NONE'\n  entities: string[]\n}\n\n/// --- EVENTS ---\n\n/** @public */\nexport type IEventNames = keyof IEvents\n\n/** @public */\nexport type EngineEvent<T extends IEventNames = IEventNames, V = IEvents[T]> = {\n  /** eventName */\n  type: T\n  data: Readonly<V>\n}\n\n/**\n * @public\n * Note: Don't use `on` prefix for IEvents to avoid redundancy with `event.on(\"onEventName\")` syntax.\n */\nexport interface IEvents {\n  /**\n   * `positionChanged` is triggered when the position of the camera changes\n   * This event is throttled to 10 times per second.\n   */\n  positionChanged: {\n    /** Camera position relative to the base parcel of the scene */\n    position: Vector3Type\n\n    /** Camera position, this is a absolute world position */\n    cameraPosition: Vector3Type\n\n    /** Eye height, in meters. */\n    playerHeight: number\n  }\n\n  /**\n   * `rotationChanged` is triggered when the rotation of the camera changes.\n   * This event is throttled to 10 times per second.\n   */\n  rotationChanged: {\n    /** Degree vector. Same as entities */\n    rotation: Vector3Type\n    /** Rotation quaternion, useful in some scenarios. */\n    quaternion: QuaternionType\n  }\n\n  /**\n   * `cameraModeChanged` is triggered when the user changes the camera mode\n   */\n  cameraModeChanged: {\n    /**\n     * FIRST_PERSON = 0,\n     * THIRD_PERSON = 1,\n     * FREE_CAMERA = 2\n     */\n    cameraMode: 0 | 1 | 2\n  }\n\n  /**\n   * `idleStateChanged` is triggered when the user not moves for a defined period of time\n   */\n  idleStateChanged: {\n    isIdle: boolean\n  }\n\n  playerExpression: {\n    expressionId: string\n  }\n\n  /**\n   * `pointerUp` is triggered when the user releases an input pointer.\n   * It could be a VR controller, a touch screen or the mouse.\n   */\n  pointerUp: InputEventResult\n\n  /**\n   * `pointerDown` is triggered when the user press an input pointer.\n   * It could be a VR controller, a touch screen or the mouse.\n   */\n  pointerDown: InputEventResult\n\n  /**\n   * `pointerEvent` is triggered when the user press or releases an input pointer.\n   * It could be a VR controller, a touch screen or the mouse.\n   *\n   * @deprecated use actionButtonEvent instead\n   */\n  pointerEvent: GlobalInputEventResult\n\n  /**\n   * `actionButtonEvent` is triggered when the user press or releases an input pointer.\n   * It could be a VR controller, a touch screen or the mouse.\n   *\n   * This event is exactly the same as `pointerEvent` but the logic in the ECS had an unsolvable\n   * condition that required us to create this new event to handle more cases for new buttons.\n   */\n  actionButtonEvent: GlobalInputEventResult\n\n  /**\n   * `raycastResponse` is triggered in response to a raycast query\n   */\n  raycastResponse: RaycastResponsePayload<any>\n\n  /**\n   * `chatMessage` is triggered when the user sends a message through chat entity.\n   */\n  chatMessage: {\n    id: string\n    sender: string\n    message: string\n    isCommand: boolean\n  }\n\n  /**\n   * `onChange` is triggered when an entity changes its own internal state.\n   * Dispatched by the `ui-*` entities when their value is changed. It triggers a callback.\n   * Notice: Only entities with ID will be listening for click events.\n   */\n  onChange: {\n    value?: any\n    /** ID of the pointer that triggered the event */\n    pointerId?: number\n  }\n\n  /**\n   * `onEnter` is triggered when the user hits the \"Enter\" key from the keyboard\n   * Used principally by the Chat internal scene\n   */\n  onEnter: unknown\n\n  /**\n   * `onPointerLock` is triggered when the user clicks the world canvas and the\n   * pointer locks to it so the pointer moves the camera\n   */\n  onPointerLock: {\n    locked?: boolean\n  }\n\n  /**\n   * `onAnimationEnd` is triggered when an animation clip gets finish\n   */\n  onAnimationEnd: {\n    clipName: string\n  }\n\n  /**\n   * `onFocus` is triggered when an entity focus is active.\n   * Dispatched by the `ui-input` and `ui-password` entities when the value is changed.\n   * It triggers a callback.\n   *\n   * Notice: Only entities with ID will be listening for click events.\n   */\n  onFocus: {\n    /** ID of the entitiy of the event */\n    entityId: unknown\n    /** ID of the pointer that triggered the event */\n    pointerId: number\n  }\n\n  /**\n   * `onBlur` is triggered when an entity loses its focus.\n   * Dispatched by the `ui-input` and `ui-password` entities when the value is changed.\n   *  It triggers a callback.\n   *\n   * Notice: Only entities with ID will be listening for click events.\n   */\n  onBlur: {\n    /** ID of the entitiy of the event */\n    entityId: unknown\n    /** ID of the pointer that triggered the event */\n    pointerId: number\n  }\n\n  /** The onClick event is only used for UI elements */\n  onClick: {\n    entityId: unknown\n  }\n\n  /**\n   * This event gets triggered when an entity leaves the scene fences.\n   */\n  entityOutOfScene: {\n    entityId: unknown\n  }\n\n  /**\n   * This event gets triggered when an entity enters the scene fences.\n   */\n  entityBackInScene: {\n    entityId: unknown\n  }\n\n  /**\n   * This event gets triggered when the user enters the scene\n   */\n  onEnterScene: {\n    userId: string\n  }\n\n  /**\n   * This event gets triggered when the user leaves the scene\n   */\n  onLeaveScene: {\n    userId: string\n  }\n\n  /**\n   * This event gets triggered after receiving a comms message.\n   */\n  comms: {\n    sender: string\n    message: string\n  }\n\n  /**\n   * This is triggered once the scene should start.\n   */\n  sceneStart: unknown\n\n  /**\n   * This is triggered once the builder scene is loaded.\n   */\n  builderSceneStart: unknown\n\n  /**\n   * This is triggered once the builder scene is unloaded.\n   */\n  builderSceneUnloaded: unknown\n\n  /**\n   * After checking entities outside the fences, if any is outside, this event\n   * will be triggered with all the entities outside the scene.\n   */\n  entitiesOutOfBoundaries: {\n    entities: string[]\n  }\n\n  uuidEvent: {\n    uuid: string\n    payload: any\n  }\n\n  onTextSubmit: {\n    text: string\n  }\n\n  metricsUpdate: {\n    given: Record<string, number>\n    limit: Record<string, number>\n  }\n\n  limitsExceeded: {\n    given: Record<string, number>\n    limit: Record<string, number>\n  }\n\n  /** For gizmos */\n  gizmoEvent: GizmoDragEndEvent | GizmoSelectedEvent\n\n  externalAction: {\n    type: string\n    [key: string]: any\n  }\n\n  stateEvent: {\n    type: string\n    payload: any\n  }\n\n  /** This is triggered at least for each videoStatus change */\n  videoEvent: {\n    componentId: string\n    videoClipId: string\n    /** Status, can be NONE = 0, ERROR = 1, LOADING = 2, READY = 3, PLAYING = 4,BUFFERING = 5 */\n    videoStatus: number\n    /** Current offset position in seconds */\n    currentOffset: number\n    /** Video length in seconds. Can be -1 */\n    totalVideoLength: number\n  }\n\n  /** This is trigger everytime a profile is changed */\n  profileChanged: {\n    ethAddress: string\n    version: number\n  }\n\n  /** Triggered when peer's avatar is connected and visible */\n  playerConnected: {\n    userId: string\n  }\n\n  /** Triggered when peer disconnect and/or it avatar is set invisible by comms */\n  playerDisconnected: {\n    userId: string\n  }\n\n  /** Triggered when current realm or island changes */\n  onRealmChanged: {\n    domain: string\n    room: string\n    serverName: string\n    displayName: string\n  }\n\n  /** Triggered when other player's avatar is clicked */\n  playerClicked: {\n    userId: string\n    ray: {\n      origin: Vector3Type\n      direction: Vector3Type\n      distance: number\n    }\n  }\n\n  /** Triggered when pointer start hovering an entities' shape */\n  pointerHoverEnter: unknown\n\n  /** Triggered when pointer stop hovering an entities' shape */\n  pointerHoverExit: unknown\n}\n\n/**\n * @internal\n * This function generates a callback that is passed to the Observable\n * constructor to subscribe to the events of the DecentralandInterface\n */\nfunction createSubscriber(eventName: string) {\n  return () => {\n    subscribeFunction({ eventId: eventName }).catch(console.error)\n  }\n}\n\n/**\n * These events are triggered after your character enters the scene.\n * @public\n * @deprecated This function is an inheritance of ECS6, it's here temporary for the feature parity, please read the news and docs to know how handle when it's removed.\n */\nexport const onEnterSceneObservable = new Observable<IEvents['onEnterScene']>(\n  createSubscriber('onEnterScene')\n)\n\n/** @public\n * @deprecated This function is an inheritance of ECS6, it's here temporary for the feature parity, please read the news and docs to know how handle when it's removed.\n * @deprecated This function is an inheritance of ECS6, it's here temporary for the feature parity, please read the news and docs to know how handle when it's removed. Use onEnterSceneObservable instead. */\nexport const onEnterScene = onEnterSceneObservable\n\n/**\n * These events are triggered after your character leaves the scene.\n * @public\n * @deprecated This function is an inheritance of ECS6, it's here temporary for the feature parity, please read the news and docs to know how handle when it's removed.\n */\nexport const onLeaveSceneObservable = new Observable<IEvents['onLeaveScene']>(\n  createSubscriber('onLeaveScene')\n)\n\n/** @public\n * @deprecated This function is an inheritance of ECS6, it's here temporary for the feature parity, please read the news and docs to know how handle when it's removed.\n * @deprecated This function is an inheritance of ECS6, it's here temporary for the feature parity, please read the news and docs to know how handle when it's removed. Use onLeaveSceneObservable instead. */\nexport const onLeaveScene = onLeaveSceneObservable\n\n/**\n * This event is triggered after all the resources of the scene were loaded (models, textures, etc...)\n * @public\n * @deprecated This function is an inheritance of ECS6, it's here temporary for the feature parity, please read the news and docs to know how handle when it's removed.\n */\nexport const onSceneReadyObservable = new Observable<IEvents['sceneStart']>(\n  createSubscriber('sceneStart')\n)\n\n/**\n * @public\n * @deprecated This function is an inheritance of ECS6, it's here temporary for the feature parity, please read the news and docs to know how handle when it's removed.\n */\nexport const onPlayerExpressionObservable = new Observable<\n  IEvents['playerExpression']\n>(createSubscriber('playerExpression'))\n\n/**\n * @public\n * @deprecated This function is an inheritance of ECS6, it's here temporary for the feature parity, please read the news and docs to know how handle when it's removed.\n */\nexport const onVideoEvent = new Observable<IEvents['videoEvent']>(\n  createSubscriber('videoEvent')\n)\n\n/**\n * @public\n * @deprecated This function is an inheritance of ECS6, it's here temporary for the feature parity, please read the news and docs to know how handle when it's removed.\n */\nexport const onProfileChanged = new Observable<IEvents['profileChanged']>(\n  createSubscriber('profileChanged')\n)\n\n/**\n * @public\n * @deprecated This function is an inheritance of ECS6, it's here temporary for the feature parity, please read the news and docs to know how handle when it's removed.\n */\nexport const onPlayerConnectedObservable = new Observable<\n  IEvents['playerConnected']\n>(createSubscriber('playerConnected'))\n\n/**\n * @public\n * @deprecated This function is an inheritance of ECS6, it's here temporary for the feature parity, please read the news and docs to know how handle when it's removed.\n */\nexport const onPlayerDisconnectedObservable = new Observable<\n  IEvents['playerDisconnected']\n>(createSubscriber('playerDisconnected'))\n\n/**\n * @public\n * @deprecated This function is an inheritance of ECS6, it's here temporary for the feature parity, please read the news and docs to know how handle when it's removed.\n */\nexport const onRealmChangedObservable = new Observable<\n  IEvents['onRealmChanged']\n>(createSubscriber('onRealmChanged'))\n\n/**\n * @public\n * @deprecated This function is an inheritance of ECS6, it's here temporary for the feature parity, please read the news and docs to know how handle when it's removed.\n */\nexport const onPlayerClickedObservable = new Observable<\n  IEvents['playerClicked']\n>(createSubscriber('playerClicked'))\n\n/**\n * @interternal\n * @deprecated This function is an inheritance of ECS6, it's here temporary for the feature parity, please read the news and docs to know how handle when it's removed.\n */\nexport const onCommsMessage = new Observable<IEvents['comms']>(\n  createSubscriber('comms')\n)\n\n/**\n * @internal\n */\nexport function setSubscribeFunction(\n  fn: (event: { eventId: string }) => Promise<any>\n) {\n  subscribeFunction = fn\n}\n\n/**\n * @internal\n * @deprecated this is an OLD API.\n * This function uses the SDK6 sendBatch to poll events from the renderer\n */\nexport async function pollEvents(\n  sendBatch: (body: ManyEntityAction) => Promise<SendBatchResponse>\n) {\n  const { events } = await sendBatch({ actions: [] })\n  for (const e of events) {\n    if (e.generic) {\n      const data = JSON.parse(e.generic.eventData)\n      switch (e.generic.eventId) {\n        case 'onEnterScene': {\n          onEnterSceneObservable.notifyObservers(\n            data as IEvents['onEnterScene']\n          )\n          break\n        }\n        case 'onLeaveScene': {\n          onLeaveSceneObservable.notifyObservers(\n            data as IEvents['onLeaveScene']\n          )\n          break\n        }\n        case 'sceneStart': {\n          onSceneReadyObservable.notifyObservers(data as IEvents['sceneStart'])\n          break\n        }\n        case 'playerExpression': {\n          onPlayerExpressionObservable.notifyObservers(\n            data as IEvents['playerExpression']\n          )\n          break\n        }\n        case 'videoEvent': {\n          const videoData = data as IEvents['videoEvent']\n          onVideoEvent.notifyObservers(videoData)\n          break\n        }\n        case 'profileChanged': {\n          onProfileChanged.notifyObservers(data as IEvents['profileChanged'])\n          break\n        }\n        case 'playerConnected': {\n          onPlayerConnectedObservable.notifyObservers(\n            data as IEvents['playerConnected']\n          )\n          break\n        }\n        case 'playerDisconnected': {\n          onPlayerDisconnectedObservable.notifyObservers(\n            data as IEvents['playerDisconnected']\n          )\n          break\n        }\n        case 'onRealmChanged': {\n          onRealmChangedObservable.notifyObservers(\n            data as IEvents['onRealmChanged']\n          )\n          break\n        }\n        case 'playerClicked': {\n          onPlayerClickedObservable.notifyObservers(\n            data as IEvents['playerClicked']\n          )\n          break\n        }\n      }\n    }\n  }\n}\n"]}
75
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"observables.js","sourceRoot":"","sources":["src/observables.ts"],"names":[],"mappings":"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","sourcesContent":["import { Observable } from './internal/Observable'\nimport { QuaternionType, Vector3Type } from '@dcl/ecs'\nimport { ManyEntityAction, SendBatchResponse } from '~system/EngineApi'\n\nlet subscribeFunction: (event: { eventId: string }) => Promise<any> = async () => {}\n\n/** @public */\nexport type InputEventResult = {\n  /** Origin of the ray, relative to the scene */\n  origin: Vector3Type\n  /** Direction vector of the ray (normalized) */\n  direction: Vector3Type\n  /** ID of the pointer that triggered the event */\n  buttonId: number\n  /** Does this pointer event hit any object? */\n  hit?: {\n    /** Length of the ray */\n    length: number\n    /** If the ray hits a mesh the intersection point will be this */\n    hitPoint: Vector3Type\n    /** If the mesh has a name, it will be assigned to meshName */\n    meshName: string\n    /** Normal of the hit */\n    normal: Vector3Type\n    /** Normal of the hit, in world space */\n    worldNormal: Vector3Type\n    /** Hit entity ID if any */\n    entityId: unknown\n  }\n}\n\n/** @public */\nexport type GlobalInputEventResult = InputEventResult & {\n  /**\n   * DOWN = 0,\n   * UP = 1\n   */\n  type: 0 | 1\n}\n\n/** @public */\nexport type RaycastResponsePayload<T> = {\n  queryId: string\n  queryType: string\n  payload: T\n}\n\n/** @public */\nexport type GizmoDragEndEvent = {\n  type: 'gizmoDragEnded'\n  transforms: Array<{\n    position: Vector3Type\n    rotation: QuaternionType\n    scale: Vector3Type\n    entityId: unknown\n  }>\n}\n\n/** @public */\nexport type GizmoSelectedEvent = {\n  type: 'gizmoSelected'\n  gizmoType: 'MOVE' | 'ROTATE' | 'SCALE' | 'NONE'\n  entities: string[]\n}\n\n/// --- EVENTS ---\n\n/** @public */\nexport type IEventNames = keyof IEvents\n\n/** @public */\nexport type EngineEvent<T extends IEventNames = IEventNames, V = IEvents[T]> = {\n  /** eventName */\n  type: T\n  data: Readonly<V>\n}\n\n/**\n * @public\n * Note: Don't use `on` prefix for IEvents to avoid redundancy with `event.on(\"onEventName\")` syntax.\n */\nexport interface IEvents {\n  /**\n   * `positionChanged` is triggered when the position of the camera changes\n   * This event is throttled to 10 times per second.\n   */\n  positionChanged: {\n    /** Camera position relative to the base parcel of the scene */\n    position: Vector3Type\n\n    /** Camera position, this is a absolute world position */\n    cameraPosition: Vector3Type\n\n    /** Eye height, in meters. */\n    playerHeight: number\n  }\n\n  /**\n   * `rotationChanged` is triggered when the rotation of the camera changes.\n   * This event is throttled to 10 times per second.\n   */\n  rotationChanged: {\n    /** Degree vector. Same as entities */\n    rotation: Vector3Type\n    /** Rotation quaternion, useful in some scenarios. */\n    quaternion: QuaternionType\n  }\n\n  /**\n   * `cameraModeChanged` is triggered when the user changes the camera mode\n   */\n  cameraModeChanged: {\n    /**\n     * FIRST_PERSON = 0,\n     * THIRD_PERSON = 1,\n     * FREE_CAMERA = 2\n     */\n    cameraMode: 0 | 1 | 2\n  }\n\n  /**\n   * `idleStateChanged` is triggered when the user not moves for a defined period of time\n   */\n  idleStateChanged: {\n    isIdle: boolean\n  }\n\n  playerExpression: {\n    expressionId: string\n  }\n\n  /**\n   * `pointerUp` is triggered when the user releases an input pointer.\n   * It could be a VR controller, a touch screen or the mouse.\n   */\n  pointerUp: InputEventResult\n\n  /**\n   * `pointerDown` is triggered when the user press an input pointer.\n   * It could be a VR controller, a touch screen or the mouse.\n   */\n  pointerDown: InputEventResult\n\n  /**\n   * `pointerEvent` is triggered when the user press or releases an input pointer.\n   * It could be a VR controller, a touch screen or the mouse.\n   *\n   * @deprecated use actionButtonEvent instead\n   */\n  pointerEvent: GlobalInputEventResult\n\n  /**\n   * `actionButtonEvent` is triggered when the user press or releases an input pointer.\n   * It could be a VR controller, a touch screen or the mouse.\n   *\n   * This event is exactly the same as `pointerEvent` but the logic in the ECS had an unsolvable\n   * condition that required us to create this new event to handle more cases for new buttons.\n   */\n  actionButtonEvent: GlobalInputEventResult\n\n  /**\n   * `raycastResponse` is triggered in response to a raycast query\n   */\n  raycastResponse: RaycastResponsePayload<any>\n\n  /**\n   * `chatMessage` is triggered when the user sends a message through chat entity.\n   */\n  chatMessage: {\n    id: string\n    sender: string\n    message: string\n    isCommand: boolean\n  }\n\n  /**\n   * `onChange` is triggered when an entity changes its own internal state.\n   * Dispatched by the `ui-*` entities when their value is changed. It triggers a callback.\n   * Notice: Only entities with ID will be listening for click events.\n   */\n  onChange: {\n    value?: any\n    /** ID of the pointer that triggered the event */\n    pointerId?: number\n  }\n\n  /**\n   * `onEnter` is triggered when the user hits the \"Enter\" key from the keyboard\n   * Used principally by the Chat internal scene\n   */\n  onEnter: unknown\n\n  /**\n   * `onPointerLock` is triggered when the user clicks the world canvas and the\n   * pointer locks to it so the pointer moves the camera\n   */\n  onPointerLock: {\n    locked?: boolean\n  }\n\n  /**\n   * `onAnimationEnd` is triggered when an animation clip gets finish\n   */\n  onAnimationEnd: {\n    clipName: string\n  }\n\n  /**\n   * `onFocus` is triggered when an entity focus is active.\n   * Dispatched by the `ui-input` and `ui-password` entities when the value is changed.\n   * It triggers a callback.\n   *\n   * Notice: Only entities with ID will be listening for click events.\n   */\n  onFocus: {\n    /** ID of the entitiy of the event */\n    entityId: unknown\n    /** ID of the pointer that triggered the event */\n    pointerId: number\n  }\n\n  /**\n   * `onBlur` is triggered when an entity loses its focus.\n   * Dispatched by the `ui-input` and `ui-password` entities when the value is changed.\n   *  It triggers a callback.\n   *\n   * Notice: Only entities with ID will be listening for click events.\n   */\n  onBlur: {\n    /** ID of the entitiy of the event */\n    entityId: unknown\n    /** ID of the pointer that triggered the event */\n    pointerId: number\n  }\n\n  /** The onClick event is only used for UI elements */\n  onClick: {\n    entityId: unknown\n  }\n\n  /**\n   * This event gets triggered when an entity leaves the scene fences.\n   */\n  entityOutOfScene: {\n    entityId: unknown\n  }\n\n  /**\n   * This event gets triggered when an entity enters the scene fences.\n   */\n  entityBackInScene: {\n    entityId: unknown\n  }\n\n  /**\n   * This event gets triggered when the user enters the scene\n   */\n  onEnterScene: {\n    userId: string\n  }\n\n  /**\n   * This event gets triggered when the user leaves the scene\n   */\n  onLeaveScene: {\n    userId: string\n  }\n\n  /**\n   * This event gets triggered after receiving a comms message.\n   */\n  comms: {\n    sender: string\n    message: string\n  }\n\n  /**\n   * This is triggered once the scene should start.\n   */\n  sceneStart: unknown\n\n  /**\n   * This is triggered once the builder scene is loaded.\n   */\n  builderSceneStart: unknown\n\n  /**\n   * This is triggered once the builder scene is unloaded.\n   */\n  builderSceneUnloaded: unknown\n\n  /**\n   * After checking entities outside the fences, if any is outside, this event\n   * will be triggered with all the entities outside the scene.\n   */\n  entitiesOutOfBoundaries: {\n    entities: string[]\n  }\n\n  uuidEvent: {\n    uuid: string\n    payload: any\n  }\n\n  onTextSubmit: {\n    text: string\n  }\n\n  metricsUpdate: {\n    given: Record<string, number>\n    limit: Record<string, number>\n  }\n\n  limitsExceeded: {\n    given: Record<string, number>\n    limit: Record<string, number>\n  }\n\n  /** For gizmos */\n  gizmoEvent: GizmoDragEndEvent | GizmoSelectedEvent\n\n  externalAction: {\n    type: string\n    [key: string]: any\n  }\n\n  stateEvent: {\n    type: string\n    payload: any\n  }\n\n  /** This is triggered at least for each videoStatus change */\n  videoEvent: {\n    componentId: string\n    videoClipId: string\n    /** Status, can be NONE = 0, ERROR = 1, LOADING = 2, READY = 3, PLAYING = 4,BUFFERING = 5 */\n    videoStatus: number\n    /** Current offset position in seconds */\n    currentOffset: number\n    /** Video length in seconds. Can be -1 */\n    totalVideoLength: number\n  }\n\n  /** This is trigger everytime a profile is changed */\n  profileChanged: {\n    ethAddress: string\n    version: number\n  }\n\n  /** Triggered when peer's avatar is connected and visible */\n  playerConnected: {\n    userId: string\n  }\n\n  /** Triggered when peer disconnect and/or it avatar is set invisible by comms */\n  playerDisconnected: {\n    userId: string\n  }\n\n  /** Triggered when current realm or island changes */\n  onRealmChanged: {\n    domain: string\n    room: string\n    serverName: string\n    displayName: string\n  }\n\n  /** Triggered when other player's avatar is clicked */\n  playerClicked: {\n    userId: string\n    ray: {\n      origin: Vector3Type\n      direction: Vector3Type\n      distance: number\n    }\n  }\n\n  /** Triggered when pointer start hovering an entities' shape */\n  pointerHoverEnter: unknown\n\n  /** Triggered when pointer stop hovering an entities' shape */\n  pointerHoverExit: unknown\n}\n\n/**\n * @internal\n * This function generates a callback that is passed to the Observable\n * constructor to subscribe to the events of the DecentralandInterface\n */\nfunction createSubscriber(eventName: string) {\n  return () => {\n    subscribeFunction({ eventId: eventName }).catch(console.error)\n  }\n}\n\n/**\n * These events are triggered after your character enters the scene.\n * @public\n * @deprecated This function is an inheritance of ECS6, it's here temporary for the feature parity, please read the news and docs to know how handle when it's removed.\n */\nexport const onEnterSceneObservable = new Observable<IEvents['onEnterScene']>(createSubscriber('onEnterScene'))\n\n/** @public\n * @deprecated This function is an inheritance of ECS6, it's here temporary for the feature parity, please read the news and docs to know how handle when it's removed.\n * @deprecated This function is an inheritance of ECS6, it's here temporary for the feature parity, please read the news and docs to know how handle when it's removed. Use onEnterSceneObservable instead. */\nexport const onEnterScene = onEnterSceneObservable\n\n/**\n * These events are triggered after your character leaves the scene.\n * @public\n * @deprecated This function is an inheritance of ECS6, it's here temporary for the feature parity, please read the news and docs to know how handle when it's removed.\n */\nexport const onLeaveSceneObservable = new Observable<IEvents['onLeaveScene']>(createSubscriber('onLeaveScene'))\n\n/** @public\n * @deprecated This function is an inheritance of ECS6, it's here temporary for the feature parity, please read the news and docs to know how handle when it's removed.\n * @deprecated This function is an inheritance of ECS6, it's here temporary for the feature parity, please read the news and docs to know how handle when it's removed. Use onLeaveSceneObservable instead. */\nexport const onLeaveScene = onLeaveSceneObservable\n\n/**\n * This event is triggered after all the resources of the scene were loaded (models, textures, etc...)\n * @public\n * @deprecated This function is an inheritance of ECS6, it's here temporary for the feature parity, please read the news and docs to know how handle when it's removed.\n */\nexport const onSceneReadyObservable = new Observable<IEvents['sceneStart']>(createSubscriber('sceneStart'))\n\n/**\n * @public\n * @deprecated This function is an inheritance of ECS6, it's here temporary for the feature parity, please read the news and docs to know how handle when it's removed.\n */\nexport const onPlayerExpressionObservable = new Observable<IEvents['playerExpression']>(\n  createSubscriber('playerExpression')\n)\n\n/**\n * @public\n * @deprecated This function is an inheritance of ECS6, it's here temporary for the feature parity, please read the news and docs to know how handle when it's removed.\n */\nexport const onVideoEvent = new Observable<IEvents['videoEvent']>(createSubscriber('videoEvent'))\n\n/**\n * @public\n * @deprecated This function is an inheritance of ECS6, it's here temporary for the feature parity, please read the news and docs to know how handle when it's removed.\n */\nexport const onProfileChanged = new Observable<IEvents['profileChanged']>(createSubscriber('profileChanged'))\n\n/**\n * @public\n * @deprecated This function is an inheritance of ECS6, it's here temporary for the feature parity, please read the news and docs to know how handle when it's removed.\n */\nexport const onPlayerConnectedObservable = new Observable<IEvents['playerConnected']>(\n  createSubscriber('playerConnected')\n)\n\n/**\n * @public\n * @deprecated This function is an inheritance of ECS6, it's here temporary for the feature parity, please read the news and docs to know how handle when it's removed.\n */\nexport const onPlayerDisconnectedObservable = new Observable<IEvents['playerDisconnected']>(\n  createSubscriber('playerDisconnected')\n)\n\n/**\n * @public\n * @deprecated This function is an inheritance of ECS6, it's here temporary for the feature parity, please read the news and docs to know how handle when it's removed.\n */\nexport const onRealmChangedObservable = new Observable<IEvents['onRealmChanged']>(createSubscriber('onRealmChanged'))\n\n/**\n * @public\n * @deprecated This function is an inheritance of ECS6, it's here temporary for the feature parity, please read the news and docs to know how handle when it's removed.\n */\nexport const onPlayerClickedObservable = new Observable<IEvents['playerClicked']>(createSubscriber('playerClicked'))\n\n/**\n * @interternal\n * @deprecated This function is an inheritance of ECS6, it's here temporary for the feature parity, please read the news and docs to know how handle when it's removed.\n */\nexport const onCommsMessage = new Observable<IEvents['comms']>(createSubscriber('comms'))\n\n/**\n * @internal\n */\nexport function setSubscribeFunction(fn: (event: { eventId: string }) => Promise<any>) {\n  subscribeFunction = fn\n}\n\n/**\n * @internal\n * @deprecated this is an OLD API.\n * This function uses the SDK6 sendBatch to poll events from the renderer\n */\nexport async function pollEvents(sendBatch: (body: ManyEntityAction) => Promise<SendBatchResponse>) {\n  const { events } = await sendBatch({ actions: [] })\n  for (const e of events) {\n    if (e.generic) {\n      const data = JSON.parse(e.generic.eventData)\n      switch (e.generic.eventId) {\n        case 'onEnterScene': {\n          onEnterSceneObservable.notifyObservers(data as IEvents['onEnterScene'])\n          break\n        }\n        case 'onLeaveScene': {\n          onLeaveSceneObservable.notifyObservers(data as IEvents['onLeaveScene'])\n          break\n        }\n        case 'sceneStart': {\n          onSceneReadyObservable.notifyObservers(data as IEvents['sceneStart'])\n          break\n        }\n        case 'playerExpression': {\n          onPlayerExpressionObservable.notifyObservers(data as IEvents['playerExpression'])\n          break\n        }\n        case 'videoEvent': {\n          const videoData = data as IEvents['videoEvent']\n          onVideoEvent.notifyObservers(videoData)\n          break\n        }\n        case 'profileChanged': {\n          onProfileChanged.notifyObservers(data as IEvents['profileChanged'])\n          break\n        }\n        case 'playerConnected': {\n          onPlayerConnectedObservable.notifyObservers(data as IEvents['playerConnected'])\n          break\n        }\n        case 'playerDisconnected': {\n          onPlayerDisconnectedObservable.notifyObservers(data as IEvents['playerDisconnected'])\n          break\n        }\n        case 'onRealmChanged': {\n          onRealmChangedObservable.notifyObservers(data as IEvents['onRealmChanged'])\n          break\n        }\n        case 'playerClicked': {\n          onPlayerClickedObservable.notifyObservers(data as IEvents['playerClicked'])\n          break\n        }\n      }\n    }\n  }\n}\n"]}
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "@dcl/sdk",
3
- "version": "7.0.6-3999809037.commit-0a47a3c",
3
+ "version": "7.0.6-4009020955.commit-08722f5",
4
4
  "description": "",
5
5
  "main": "./index.js",
6
6
  "typings": "./index.d.ts",
@@ -20,21 +20,32 @@
20
20
  "author": "Decentraland",
21
21
  "license": "Apache-2.0",
22
22
  "dependencies": {
23
- "@dcl/dcl-rollup": "7.0.6-3999809037.commit-0a47a3c",
24
- "@dcl/ecs": "7.0.6-3999809037.commit-0a47a3c",
23
+ "@dcl/dcl-rollup": "7.0.6-4009020955.commit-08722f5",
24
+ "@dcl/ecs": "7.0.6-4009020955.commit-08722f5",
25
25
  "@dcl/ecs-math": "2.0.1-20221129185242.commit-40495c1",
26
- "@dcl/js-runtime": "7.0.6-3999809037.commit-0a47a3c",
26
+ "@dcl/js-runtime": "7.0.6-4009020955.commit-08722f5",
27
27
  "@dcl/kernel": "2.0.0-3766760530.commit-239d2a9",
28
- "@dcl/react-ecs": "7.0.6-3999809037.commit-0a47a3c",
28
+ "@dcl/mini-comms": "1.0.0",
29
+ "@dcl/react-ecs": "7.0.6-4009020955.commit-08722f5",
30
+ "@dcl/schemas": "5.14.0",
29
31
  "@dcl/unity-renderer": "1.0.68557-20221221195847.commit-f743b85",
32
+ "@types/inquirer": "^8.2.5",
33
+ "@well-known-components/env-config-provider": "^1.1.2-20220801195549.commit-101c273",
34
+ "@well-known-components/http-server": "^1.1.6-20220927190058.commit-2dfb235",
35
+ "@well-known-components/logger": "^3.0.0",
36
+ "@well-known-components/metrics": "^2.0.1-20220909150423.commit-8f7e5bc",
30
37
  "arg": "5.0.2",
31
38
  "extract-zip": "2.0.1",
32
39
  "inquirer": "^8.2.5",
40
+ "node-fetch": "^2.6.8",
41
+ "open": "^8.4.0",
33
42
  "ora": "6.1.2",
43
+ "portfinder": "^1.0.32",
34
44
  "undici": "^5.14.0"
35
45
  },
36
46
  "devDependencies": {
37
- "@types/inquirer": "^8.2.5"
47
+ "@types/node-fetch": "^2.6.1",
48
+ "@types/ws": "^8.5.4"
38
49
  },
39
50
  "minCliVersion": "3.14.1",
40
51
  "typedoc": {
@@ -43,5 +54,5 @@
43
54
  "displayName": "SDK",
44
55
  "tsconfig": "./tsconfig.json"
45
56
  },
46
- "commit": "0a47a3c6e7e075d98d04c5ceab1eb8185c70bd9c"
57
+ "commit": "08722f5fb9539e46f90cc94b5f9634ef0ef314ea"
47
58
  }
@@ -36,12 +36,7 @@ export class ObserverEventState {
36
36
  * @param target - defines the original target of the state
37
37
  * @param currentTarget - defines the current target of the state
38
38
  */
39
- constructor(
40
- mask: number,
41
- skipNextObservers = false,
42
- target?: any,
43
- currentTarget?: any
44
- ) {
39
+ constructor(mask: number, skipNextObservers = false, target?: any, currentTarget?: any) {
45
40
  this.initalize(mask, skipNextObservers, target, currentTarget)
46
41
  }
47
42
 
@@ -53,12 +48,7 @@ export class ObserverEventState {
53
48
  * @param currentTarget - defines the current target of the state
54
49
  * @returns the current event state
55
50
  */
56
- public initalize(
57
- mask: number,
58
- skipNextObservers = false,
59
- target?: any,
60
- currentTarget?: any
61
- ): ObserverEventState {
51
+ public initalize(mask: number, skipNextObservers = false, target?: any, currentTarget?: any): ObserverEventState {
62
52
  this.mask = mask
63
53
  this.skipNextObservers = skipNextObservers
64
54
  this.target = target
@@ -172,9 +162,7 @@ export class Observable<T> {
172
162
  * @param callback - the callback that will be executed for that Observer
173
163
  * @returns the new observer created for the callback
174
164
  */
175
- public addOnce(
176
- callback: (eventData: T, eventState: ObserverEventState) => void
177
- ): null | Observer<T> {
165
+ public addOnce(callback: (eventData: T, eventState: ObserverEventState) => void): null | Observer<T> {
178
166
  return this.add(callback, undefined, undefined, undefined, true)
179
167
  }
180
168
 
@@ -204,15 +192,9 @@ export class Observable<T> {
204
192
  * @param scope - optional scope. If used only the callbacks with this scope will be removed
205
193
  * @returns false if it doesn't belong to this Observable
206
194
  */
207
- public removeCallback(
208
- callback: (eventData: T, eventState: ObserverEventState) => void,
209
- scope?: any
210
- ): boolean {
195
+ public removeCallback(callback: (eventData: T, eventState: ObserverEventState) => void, scope?: any): boolean {
211
196
  for (let index = 0; index < this._observers.length; index++) {
212
- if (
213
- this._observers[index].callback === callback &&
214
- (!scope || scope === this._observers[index].scope)
215
- ) {
197
+ if (this._observers[index].callback === callback && (!scope || scope === this._observers[index].scope)) {
216
198
  this._deferUnregister(this._observers[index])
217
199
  return true
218
200
  }
@@ -230,12 +212,7 @@ export class Observable<T> {
230
212
  * @param currentTarget - defines the current target of the state
231
213
  * @returns false if the complete observer chain was not processed (because one observer set the skipNextObservers to true)
232
214
  */
233
- public notifyObservers(
234
- eventData: T,
235
- mask: number = -1,
236
- target?: any,
237
- currentTarget?: any
238
- ): boolean {
215
+ public notifyObservers(eventData: T, mask: number = -1, target?: any, currentTarget?: any): boolean {
239
216
  if (!this._observers.length) {
240
217
  return true
241
218
  }
@@ -254,10 +231,7 @@ export class Observable<T> {
254
231
 
255
232
  if (obs.mask & mask) {
256
233
  if (obs.scope) {
257
- state.lastReturnValue = obs.callback.apply(obs.scope, [
258
- eventData,
259
- state
260
- ])
234
+ state.lastReturnValue = obs.callback.apply(obs.scope, [eventData, state])
261
235
  } else {
262
236
  state.lastReturnValue = obs.callback(eventData, state)
263
237
  }
@@ -286,12 +260,7 @@ export class Observable<T> {
286
260
  * @param currentTarget - defines he current object in the bubbling phase
287
261
  * @returns will return a Promise than resolves when all callbacks executed successfully.
288
262
  */
289
- public notifyObserversWithPromise(
290
- eventData: T,
291
- mask: number = -1,
292
- target?: any,
293
- currentTarget?: any
294
- ): Promise<T> {
263
+ public notifyObserversWithPromise(eventData: T, mask: number = -1, target?: any, currentTarget?: any): Promise<T> {
295
264
  // create an empty promise
296
265
  let p: Promise<any> = Promise.resolve(eventData)
297
266
 
@@ -344,11 +313,7 @@ export class Observable<T> {
344
313
  * @param eventData - defines the data to be sent to each callback
345
314
  * @param mask - is used to filter observers defaults to -1
346
315
  */
347
- public notifyObserver(
348
- observer: Observer<T>,
349
- eventData: T,
350
- mask: number = -1
351
- ): void {
316
+ public notifyObserver(observer: Observer<T>, eventData: T, mask: number = -1): void {
352
317
  const state = this._eventState
353
318
  state.mask = mask
354
319
  state.skipNextObservers = false
@@ -19,9 +19,7 @@ export interface MessageDict {
19
19
  [key: string]: string
20
20
  }
21
21
 
22
- export type SendAsyncType = (
23
- params: SendAsyncRequest
24
- ) => Promise<SendAsyncResponse>
22
+ export type SendAsyncType = (params: SendAsyncRequest) => Promise<SendAsyncResponse>
25
23
 
26
24
  export function getEthereumProvider(sendAsync: SendAsyncType) {
27
25
  async function request(message: RPCSendableMessage) {
@@ -35,10 +33,7 @@ export function getEthereumProvider(sendAsync: SendAsyncType) {
35
33
 
36
34
  return {
37
35
  // @internal
38
- send(
39
- message: RPCSendableMessage,
40
- callback?: (error: Error | null, result?: any) => void
41
- ): void {
36
+ send(message: RPCSendableMessage, callback?: (error: Error | null, result?: any) => void): void {
42
37
  if (message && callback && callback instanceof Function) {
43
38
  request(message)
44
39
  .then((x: any) => callback(null, x))
@@ -47,10 +42,7 @@ export function getEthereumProvider(sendAsync: SendAsyncType) {
47
42
  throw new Error('Decentraland provider only allows async calls')
48
43
  }
49
44
  },
50
- sendAsync(
51
- message: RPCSendableMessage,
52
- callback: (error: Error | null, result?: any) => void
53
- ): void {
45
+ sendAsync(message: RPCSendableMessage, callback: (error: Error | null, result?: any) => void): void {
54
46
  request(message)
55
47
  .then((x: any) => callback(null, x))
56
48
  .catch(callback)