@dcl/sdk 7.4.4 → 7.4.5-8054791102.commit-f06a0a7

Sign up to get free protection for your applications and to get access to all the features.
package/observables.d.ts CHANGED
@@ -1,26 +1,44 @@
1
1
  import { Observable } from './internal/Observable';
2
2
  import { QuaternionType, Vector3Type } from '@dcl/ecs';
3
+ /** @public */
3
4
  export type InputEventResult = {
5
+ /** Origin of the ray, relative to the scene */
4
6
  origin: Vector3Type;
7
+ /** Direction vector of the ray (normalized) */
5
8
  direction: Vector3Type;
9
+ /** ID of the pointer that triggered the event */
6
10
  buttonId: number;
11
+ /** Does this pointer event hit any object? */
7
12
  hit?: {
13
+ /** Length of the ray */
8
14
  length: number;
15
+ /** If the ray hits a mesh the intersection point will be this */
9
16
  hitPoint: Vector3Type;
17
+ /** If the mesh has a name, it will be assigned to meshName */
10
18
  meshName: string;
19
+ /** Normal of the hit */
11
20
  normal: Vector3Type;
21
+ /** Normal of the hit, in world space */
12
22
  worldNormal: Vector3Type;
23
+ /** Hit entity ID if any */
13
24
  entityId: unknown;
14
25
  };
15
26
  };
27
+ /** @public */
16
28
  export type GlobalInputEventResult = InputEventResult & {
29
+ /**
30
+ * DOWN = 0,
31
+ * UP = 1
32
+ */
17
33
  type: 0 | 1;
18
34
  };
35
+ /** @public */
19
36
  export type RaycastResponsePayload<T> = {
20
37
  queryId: string;
21
38
  queryType: string;
22
39
  payload: T;
23
40
  };
41
+ /** @public */
24
42
  export type GizmoDragEndEvent = {
25
43
  type: 'gizmoDragEnded';
26
44
  transforms: Array<{
@@ -30,87 +48,210 @@ export type GizmoDragEndEvent = {
30
48
  entityId: unknown;
31
49
  }>;
32
50
  };
51
+ /** @public */
33
52
  export type GizmoSelectedEvent = {
34
53
  type: 'gizmoSelected';
35
54
  gizmoType: 'MOVE' | 'ROTATE' | 'SCALE' | 'NONE';
36
55
  entities: string[];
37
56
  };
57
+ /** @public */
38
58
  export type IEventNames = keyof IEvents;
59
+ /** @public */
39
60
  export type EngineEvent<T extends IEventNames = IEventNames, V = IEvents[T]> = {
61
+ /** eventName */
40
62
  type: T;
41
63
  data: Readonly<V>;
42
64
  };
65
+ /**
66
+ * @public
67
+ * Note: Don't use `on` prefix for IEvents to avoid redundancy with `event.on("onEventName")` syntax.
68
+ */
43
69
  export interface IEvents {
70
+ /**
71
+ * `positionChanged` is triggered when the position of the camera changes
72
+ * This event is throttled to 10 times per second.
73
+ */
44
74
  positionChanged: {
75
+ /** Camera position relative to the base parcel of the scene */
45
76
  position: Vector3Type;
77
+ /** Camera position, this is a absolute world position */
46
78
  cameraPosition: Vector3Type;
79
+ /** Eye height, in meters. */
47
80
  playerHeight: number;
48
81
  };
82
+ /**
83
+ * `rotationChanged` is triggered when the rotation of the camera changes.
84
+ * This event is throttled to 10 times per second.
85
+ */
49
86
  rotationChanged: {
87
+ /** Degree vector. Same as entities */
50
88
  rotation: Vector3Type;
89
+ /** Rotation quaternion, useful in some scenarios. */
51
90
  quaternion: QuaternionType;
52
91
  };
92
+ /**
93
+ * `cameraModeChanged` is triggered when the user changes the camera mode
94
+ */
53
95
  cameraModeChanged: {
96
+ /**
97
+ * FIRST_PERSON = 0,
98
+ * THIRD_PERSON = 1,
99
+ * FREE_CAMERA = 2
100
+ */
54
101
  cameraMode: 0 | 1 | 2;
55
102
  };
103
+ /**
104
+ * `idleStateChanged` is triggered when the user not moves for a defined period of time
105
+ */
56
106
  idleStateChanged: {
57
107
  isIdle: boolean;
58
108
  };
59
109
  playerExpression: {
60
110
  expressionId: string;
61
111
  };
112
+ /**
113
+ * `pointerUp` is triggered when the user releases an input pointer.
114
+ * It could be a VR controller, a touch screen or the mouse.
115
+ */
62
116
  pointerUp: InputEventResult;
117
+ /**
118
+ * `pointerDown` is triggered when the user press an input pointer.
119
+ * It could be a VR controller, a touch screen or the mouse.
120
+ */
63
121
  pointerDown: InputEventResult;
122
+ /**
123
+ * `pointerEvent` is triggered when the user press or releases an input pointer.
124
+ * It could be a VR controller, a touch screen or the mouse.
125
+ *
126
+ * @deprecated use actionButtonEvent instead
127
+ */
64
128
  pointerEvent: GlobalInputEventResult;
129
+ /**
130
+ * `actionButtonEvent` is triggered when the user press or releases an input pointer.
131
+ * It could be a VR controller, a touch screen or the mouse.
132
+ *
133
+ * This event is exactly the same as `pointerEvent` but the logic in the ECS had an unsolvable
134
+ * condition that required us to create this new event to handle more cases for new buttons.
135
+ */
65
136
  actionButtonEvent: GlobalInputEventResult;
137
+ /**
138
+ * `raycastResponse` is triggered in response to a raycast query
139
+ */
66
140
  raycastResponse: RaycastResponsePayload<any>;
141
+ /**
142
+ * `chatMessage` is triggered when the user sends a message through chat entity.
143
+ */
67
144
  chatMessage: {
68
145
  id: string;
69
146
  sender: string;
70
147
  message: string;
71
148
  isCommand: boolean;
72
149
  };
150
+ /**
151
+ * `onChange` is triggered when an entity changes its own internal state.
152
+ * Dispatched by the `ui-*` entities when their value is changed. It triggers a callback.
153
+ * Notice: Only entities with ID will be listening for click events.
154
+ */
73
155
  onChange: {
74
156
  value?: any;
157
+ /** ID of the pointer that triggered the event */
75
158
  pointerId?: number;
76
159
  };
160
+ /**
161
+ * `onEnter` is triggered when the user hits the "Enter" key from the keyboard
162
+ * Used principally by the Chat internal scene
163
+ */
77
164
  onEnter: unknown;
165
+ /**
166
+ * `onPointerLock` is triggered when the user clicks the world canvas and the
167
+ * pointer locks to it so the pointer moves the camera
168
+ */
78
169
  onPointerLock: {
79
170
  locked?: boolean;
80
171
  };
172
+ /**
173
+ * `onAnimationEnd` is triggered when an animation clip gets finish
174
+ */
81
175
  onAnimationEnd: {
82
176
  clipName: string;
83
177
  };
178
+ /**
179
+ * `onFocus` is triggered when an entity focus is active.
180
+ * Dispatched by the `ui-input` and `ui-password` entities when the value is changed.
181
+ * It triggers a callback.
182
+ *
183
+ * Notice: Only entities with ID will be listening for click events.
184
+ */
84
185
  onFocus: {
186
+ /** ID of the entitiy of the event */
85
187
  entityId: unknown;
188
+ /** ID of the pointer that triggered the event */
86
189
  pointerId: number;
87
190
  };
191
+ /**
192
+ * `onBlur` is triggered when an entity loses its focus.
193
+ * Dispatched by the `ui-input` and `ui-password` entities when the value is changed.
194
+ * It triggers a callback.
195
+ *
196
+ * Notice: Only entities with ID will be listening for click events.
197
+ */
88
198
  onBlur: {
199
+ /** ID of the entitiy of the event */
89
200
  entityId: unknown;
201
+ /** ID of the pointer that triggered the event */
90
202
  pointerId: number;
91
203
  };
204
+ /** The onClick event is only used for UI elements */
92
205
  onClick: {
93
206
  entityId: unknown;
94
207
  };
208
+ /**
209
+ * This event gets triggered when an entity leaves the scene fences.
210
+ */
95
211
  entityOutOfScene: {
96
212
  entityId: unknown;
97
213
  };
214
+ /**
215
+ * This event gets triggered when an entity enters the scene fences.
216
+ */
98
217
  entityBackInScene: {
99
218
  entityId: unknown;
100
219
  };
220
+ /**
221
+ * This event gets triggered when the user enters the scene
222
+ */
101
223
  onEnterScene: {
102
224
  userId: string;
103
225
  };
226
+ /**
227
+ * This event gets triggered when the user leaves the scene
228
+ */
104
229
  onLeaveScene: {
105
230
  userId: string;
106
231
  };
232
+ /**
233
+ * This event gets triggered after receiving a comms message.
234
+ */
107
235
  comms: {
108
236
  sender: string;
109
237
  message: string;
110
238
  };
239
+ /**
240
+ * This is triggered once the scene should start.
241
+ */
111
242
  sceneStart: unknown;
243
+ /**
244
+ * This is triggered once the builder scene is loaded.
245
+ */
112
246
  builderSceneStart: unknown;
247
+ /**
248
+ * This is triggered once the builder scene is unloaded.
249
+ */
113
250
  builderSceneUnloaded: unknown;
251
+ /**
252
+ * After checking entities outside the fences, if any is outside, this event
253
+ * will be triggered with all the entities outside the scene.
254
+ */
114
255
  entitiesOutOfBoundaries: {
115
256
  entities: string[];
116
257
  };
@@ -129,6 +270,7 @@ export interface IEvents {
129
270
  given: Record<string, number>;
130
271
  limit: Record<string, number>;
131
272
  };
273
+ /** For gizmos */
132
274
  gizmoEvent: GizmoDragEndEvent | GizmoSelectedEvent;
133
275
  externalAction: {
134
276
  type: string;
@@ -138,29 +280,38 @@ export interface IEvents {
138
280
  type: string;
139
281
  payload: any;
140
282
  };
283
+ /** This is triggered at least for each videoStatus change */
141
284
  videoEvent: {
142
285
  componentId: string;
143
286
  videoClipId: string;
287
+ /** Status, can be NONE = 0, ERROR = 1, LOADING = 2, READY = 3, PLAYING = 4,BUFFERING = 5 */
144
288
  videoStatus: number;
289
+ /** Current offset position in seconds */
145
290
  currentOffset: number;
291
+ /** Video length in seconds. Can be -1 */
146
292
  totalVideoLength: number;
147
293
  };
294
+ /** This is trigger everytime a profile is changed */
148
295
  profileChanged: {
149
296
  ethAddress: string;
150
297
  version: number;
151
298
  };
299
+ /** Triggered when peer's avatar is connected and visible */
152
300
  playerConnected: {
153
301
  userId: string;
154
302
  };
303
+ /** Triggered when peer disconnect and/or it avatar is set invisible by comms */
155
304
  playerDisconnected: {
156
305
  userId: string;
157
306
  };
307
+ /** Triggered when current realm or island changes */
158
308
  onRealmChanged: {
159
309
  domain: string;
160
310
  room: string;
161
311
  serverName: string;
162
312
  displayName: string;
163
313
  };
314
+ /** Triggered when other player's avatar is clicked */
164
315
  playerClicked: {
165
316
  userId: string;
166
317
  ray: {
@@ -169,48 +320,102 @@ export interface IEvents {
169
320
  distance: number;
170
321
  };
171
322
  };
323
+ /** Triggered when pointer start hovering an entities' shape */
172
324
  pointerHoverEnter: unknown;
325
+ /** Triggered when pointer stop hovering an entities' shape */
173
326
  pointerHoverExit: unknown;
174
327
  }
328
+ /**
329
+ * These events are triggered after your character enters the scene.
330
+ * @public
331
+ * @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.
332
+ */
175
333
  export declare const onEnterSceneObservable: Observable<{
176
334
  userId: string;
177
335
  }>;
336
+ /** @public
337
+ * @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.
338
+ * @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. */
178
339
  export declare const onEnterScene: Observable<{
179
340
  userId: string;
180
341
  }>;
342
+ /**
343
+ * These events are triggered after your character leaves the scene.
344
+ * @public
345
+ * @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.
346
+ */
181
347
  export declare const onLeaveSceneObservable: Observable<{
182
348
  userId: string;
183
349
  }>;
350
+ /** @public
351
+ * @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.
352
+ * @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. */
184
353
  export declare const onLeaveScene: Observable<{
185
354
  userId: string;
186
355
  }>;
356
+ /**
357
+ * This event is triggered after all the resources of the scene were loaded (models, textures, etc...)
358
+ * @public
359
+ * @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.
360
+ */
187
361
  export declare const onSceneReadyObservable: Observable<unknown>;
362
+ /**
363
+ * @public
364
+ * @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.
365
+ */
188
366
  export declare const onPlayerExpressionObservable: Observable<{
189
367
  expressionId: string;
190
368
  }>;
369
+ /**
370
+ * @public
371
+ * @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.
372
+ */
191
373
  export declare const onVideoEvent: Observable<{
192
374
  componentId: string;
193
375
  videoClipId: string;
376
+ /** Status, can be NONE = 0, ERROR = 1, LOADING = 2, READY = 3, PLAYING = 4,BUFFERING = 5 */
194
377
  videoStatus: number;
378
+ /** Current offset position in seconds */
195
379
  currentOffset: number;
380
+ /** Video length in seconds. Can be -1 */
196
381
  totalVideoLength: number;
197
382
  }>;
383
+ /**
384
+ * @public
385
+ * @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.
386
+ */
198
387
  export declare const onProfileChanged: Observable<{
199
388
  ethAddress: string;
200
389
  version: number;
201
390
  }>;
391
+ /**
392
+ * @public
393
+ * @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.
394
+ */
202
395
  export declare const onPlayerConnectedObservable: Observable<{
203
396
  userId: string;
204
397
  }>;
398
+ /**
399
+ * @public
400
+ * @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.
401
+ */
205
402
  export declare const onPlayerDisconnectedObservable: Observable<{
206
403
  userId: string;
207
404
  }>;
405
+ /**
406
+ * @public
407
+ * @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.
408
+ */
208
409
  export declare const onRealmChangedObservable: Observable<{
209
410
  domain: string;
210
411
  room: string;
211
412
  serverName: string;
212
413
  displayName: string;
213
414
  }>;
415
+ /**
416
+ * @public
417
+ * @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.
418
+ */
214
419
  export declare const onPlayerClickedObservable: Observable<{
215
420
  userId: string;
216
421
  ray: {
package/observables.js CHANGED
@@ -1,27 +1,94 @@
1
1
  import { Observable } from './internal/Observable';
2
2
  import { subscribe } from '~system/EngineApi';
3
3
  let subscribeFunction = subscribe;
4
+ /**
5
+ * @internal
6
+ * This function generates a callback that is passed to the Observable
7
+ * constructor to subscribe to the events of the DecentralandInterface
8
+ */
4
9
  function createSubscriber(eventName) {
5
10
  return () => {
6
11
  subscribeFunction({ eventId: eventName }).catch(console.error);
7
12
  };
8
13
  }
14
+ /**
15
+ * These events are triggered after your character enters the scene.
16
+ * @public
17
+ * @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.
18
+ */
9
19
  export const onEnterSceneObservable = new Observable(createSubscriber('onEnterScene'));
20
+ /** @public
21
+ * @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.
22
+ * @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. */
10
23
  export const onEnterScene = onEnterSceneObservable;
24
+ /**
25
+ * These events are triggered after your character leaves the scene.
26
+ * @public
27
+ * @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.
28
+ */
11
29
  export const onLeaveSceneObservable = new Observable(createSubscriber('onLeaveScene'));
30
+ /** @public
31
+ * @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.
32
+ * @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. */
12
33
  export const onLeaveScene = onLeaveSceneObservable;
34
+ /**
35
+ * This event is triggered after all the resources of the scene were loaded (models, textures, etc...)
36
+ * @public
37
+ * @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.
38
+ */
13
39
  export const onSceneReadyObservable = new Observable(createSubscriber('sceneStart'));
40
+ /**
41
+ * @public
42
+ * @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.
43
+ */
14
44
  export const onPlayerExpressionObservable = new Observable(createSubscriber('playerExpression'));
45
+ /**
46
+ * @public
47
+ * @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.
48
+ */
15
49
  export const onVideoEvent = new Observable(createSubscriber('videoEvent'));
50
+ /**
51
+ * @public
52
+ * @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.
53
+ */
16
54
  export const onProfileChanged = new Observable(createSubscriber('profileChanged'));
55
+ /**
56
+ * @public
57
+ * @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.
58
+ */
17
59
  export const onPlayerConnectedObservable = new Observable(createSubscriber('playerConnected'));
60
+ /**
61
+ * @public
62
+ * @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.
63
+ */
18
64
  export const onPlayerDisconnectedObservable = new Observable(createSubscriber('playerDisconnected'));
65
+ /**
66
+ * @public
67
+ * @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.
68
+ */
19
69
  export const onRealmChangedObservable = new Observable(createSubscriber('onRealmChanged'));
70
+ /**
71
+ * @public
72
+ * @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.
73
+ */
20
74
  export const onPlayerClickedObservable = new Observable(createSubscriber('playerClicked'));
75
+ /**
76
+ * @internal
77
+ * @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.
78
+ */
21
79
  export const onCommsMessage = new Observable(createSubscriber('comms'));
80
+ /**
81
+ * @internal
82
+ * Used for testing purpose
83
+ */
22
84
  export function setSubscribeFunction(fn) {
23
85
  subscribeFunction = fn;
24
86
  }
87
+ /**
88
+ * @internal
89
+ * @deprecated this is an OLD API.
90
+ * This function uses the SDK6 sendBatch to poll events from the renderer
91
+ */
25
92
  export async function pollEvents(sendBatch) {
26
93
  const { events } = await sendBatch({ actions: [] });
27
94
  for (const e of events) {
@@ -77,4 +144,4 @@ export async function pollEvents(sendBatch) {
77
144
  }
78
145
  }
79
146
  }
80
- //# 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, subscribe } from '~system/EngineApi'\n\nlet subscribeFunction: typeof subscribe = subscribe\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/** @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 * @internal\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 * Used for testing purpose\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        case 'comms': {\n          onCommsMessage.notifyObservers(data as IEvents['comms'])\n          break\n        }\n      }\n    }\n  }\n}\n"]}
147
+ //# 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, subscribe } from '~system/EngineApi'\n\nlet subscribeFunction: typeof subscribe = subscribe\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/** @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 * @internal\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 * Used for testing purpose\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        case 'comms': {\n          onCommsMessage.notifyObservers(data as IEvents['comms'])\n          break\n        }\n      }\n    }\n  }\n}\n"]}
package/package.json CHANGED
@@ -1,15 +1,15 @@
1
1
  {
2
2
  "name": "@dcl/sdk",
3
3
  "description": "",
4
- "version": "7.4.4",
4
+ "version": "7.4.5-8054791102.commit-f06a0a7",
5
5
  "author": "Decentraland",
6
6
  "dependencies": {
7
- "@dcl/ecs": "7.4.4",
7
+ "@dcl/ecs": "7.4.5-8054791102.commit-f06a0a7",
8
8
  "@dcl/ecs-math": "2.0.2",
9
9
  "@dcl/explorer": "1.0.160056-20240212151637.commit-33b7e01",
10
- "@dcl/js-runtime": "7.4.4",
11
- "@dcl/react-ecs": "7.4.4",
12
- "@dcl/sdk-commands": "7.4.4",
10
+ "@dcl/js-runtime": "7.4.5-8054791102.commit-f06a0a7",
11
+ "@dcl/react-ecs": "7.4.5-8054791102.commit-f06a0a7",
12
+ "@dcl/sdk-commands": "7.4.5-8054791102.commit-f06a0a7",
13
13
  "text-encoding": "0.7.0"
14
14
  },
15
15
  "keywords": [],
@@ -35,5 +35,5 @@
35
35
  },
36
36
  "types": "./index.d.ts",
37
37
  "typings": "./index.d.ts",
38
- "commit": "35a11dbf31085c47c0a84e77c9ffbd7602de85f2"
38
+ "commit": "f06a0a76f129a1d750367ae6a491141be74abb13"
39
39
  }
@@ -16,6 +16,9 @@ type GetPlayerDataRes = {
16
16
  declare const players: {
17
17
  onEnterScene(cb: (player: GetPlayerDataRes) => void): void;
18
18
  onLeaveScene(cb: (userId: string) => void): void;
19
+ /**
20
+ * Returns the info of the player if it's in the scene.
21
+ */
19
22
  getPlayer(user?: GetPlayerDataReq): GetPlayerDataRes | null;
20
23
  };
21
24
  declare const getPlayer: (user?: GetPlayerDataReq) => GetPlayerDataRes | null, onEnterScene: (cb: (player: GetPlayerDataRes) => void) => void, onLeaveScene: (cb: (userId: string) => void) => void;