@dcl/ecs 7.13.0 → 7.13.1-19516109426.commit-e1e79aa

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 (163) hide show
  1. package/dist/components/extended/AvatarEquippedData.d.ts +10 -0
  2. package/dist/components/extended/AvatarEquippedData.js +15 -0
  3. package/dist/components/extended/AvatarShape.d.ts +10 -0
  4. package/dist/components/extended/AvatarShape.js +15 -0
  5. package/dist/components/extended/MeshCollider.d.ts +8 -0
  6. package/dist/components/extended/MeshCollider.js +6 -0
  7. package/dist/components/extended/MeshRenderer.d.ts +8 -0
  8. package/dist/components/extended/MeshRenderer.js +5 -0
  9. package/dist/components/generated/CameraLayer.gen.d.ts +1 -0
  10. package/dist/components/generated/CameraLayer.gen.js +25 -0
  11. package/dist/components/generated/CameraLayers.gen.d.ts +1 -0
  12. package/dist/components/generated/CameraLayers.gen.js +25 -0
  13. package/dist/components/generated/GlobalLight.gen.d.ts +1 -0
  14. package/dist/components/generated/GlobalLight.gen.js +25 -0
  15. package/dist/components/generated/GltfNode.gen.d.ts +1 -0
  16. package/dist/components/generated/GltfNode.gen.js +25 -0
  17. package/dist/components/generated/GltfNodeState.gen.d.ts +1 -0
  18. package/dist/components/generated/GltfNodeState.gen.js +25 -0
  19. package/dist/components/generated/TextureCamera.gen.d.ts +1 -0
  20. package/dist/components/generated/TextureCamera.gen.js +25 -0
  21. package/dist/components/generated/UiCanvas.gen.d.ts +1 -0
  22. package/dist/components/generated/UiCanvas.gen.js +25 -0
  23. package/dist/components/generated/UiScrollResult.gen.d.ts +1 -0
  24. package/dist/components/generated/UiScrollResult.gen.js +25 -0
  25. package/dist/components/generated/component-names.gen.js +8 -0
  26. package/dist/components/generated/global.gen.d.ts +16 -0
  27. package/dist/components/generated/global.gen.js +8 -0
  28. package/dist/components/generated/index.gen.d.ts +32 -0
  29. package/dist/components/generated/index.gen.js +40 -0
  30. package/dist/components/generated/pb/decentraland/common/texture.gen.d.ts +20 -0
  31. package/dist/components/generated/pb/decentraland/common/texture.gen.js +65 -0
  32. package/dist/components/generated/pb/decentraland/sdk/components/avatar_equipped_data.gen.d.ts +2 -0
  33. package/dist/components/generated/pb/decentraland/sdk/components/avatar_equipped_data.gen.js +10 -1
  34. package/dist/components/generated/pb/decentraland/sdk/components/avatar_modifier_area.gen.d.ts +43 -0
  35. package/dist/components/generated/pb/decentraland/sdk/components/avatar_modifier_area.gen.js +151 -1
  36. package/dist/components/generated/pb/decentraland/sdk/components/avatar_shape.gen.d.ts +2 -0
  37. package/dist/components/generated/pb/decentraland/sdk/components/avatar_shape.gen.js +10 -0
  38. package/dist/components/generated/pb/decentraland/sdk/components/camera_layer.gen.d.ts +30 -0
  39. package/dist/components/generated/pb/decentraland/sdk/components/camera_layer.gen.js +104 -0
  40. package/dist/components/generated/pb/decentraland/sdk/components/camera_layers.gen.d.ts +14 -0
  41. package/dist/components/generated/pb/decentraland/sdk/components/camera_layers.gen.js +50 -0
  42. package/dist/components/generated/pb/decentraland/sdk/components/camera_mode_area.gen.d.ts +37 -1
  43. package/dist/components/generated/pb/decentraland/sdk/components/camera_mode_area.gen.js +119 -1
  44. package/dist/components/generated/pb/decentraland/sdk/components/common/input_action.gen.d.ts +4 -1
  45. package/dist/components/generated/pb/decentraland/sdk/components/common/input_action.gen.js +3 -0
  46. package/dist/components/generated/pb/decentraland/sdk/components/global_light.gen.d.ts +34 -0
  47. package/dist/components/generated/pb/decentraland/sdk/components/global_light.gen.js +61 -0
  48. package/dist/components/generated/pb/decentraland/sdk/components/gltf_container_loading_state.gen.d.ts +19 -0
  49. package/dist/components/generated/pb/decentraland/sdk/components/gltf_container_loading_state.gen.js +46 -1
  50. package/dist/components/generated/pb/decentraland/sdk/components/gltf_node.gen.d.ts +50 -0
  51. package/dist/components/generated/pb/decentraland/sdk/components/gltf_node.gen.js +41 -0
  52. package/dist/components/generated/pb/decentraland/sdk/components/gltf_node_state.gen.d.ts +27 -0
  53. package/dist/components/generated/pb/decentraland/sdk/components/gltf_node_state.gen.js +59 -0
  54. package/dist/components/generated/pb/decentraland/sdk/components/material.gen.d.ts +22 -0
  55. package/dist/components/generated/pb/decentraland/sdk/components/material.gen.js +57 -1
  56. package/dist/components/generated/pb/decentraland/sdk/components/mesh_collider.gen.d.ts +20 -0
  57. package/dist/components/generated/pb/decentraland/sdk/components/mesh_collider.gen.js +56 -0
  58. package/dist/components/generated/pb/decentraland/sdk/components/mesh_renderer.gen.d.ts +21 -3
  59. package/dist/components/generated/pb/decentraland/sdk/components/mesh_renderer.gen.js +56 -0
  60. package/dist/components/generated/pb/decentraland/sdk/components/primary_pointer_info.gen.d.ts +8 -2
  61. package/dist/components/generated/pb/decentraland/sdk/components/primary_pointer_info.gen.js +3 -0
  62. package/dist/components/generated/pb/decentraland/sdk/components/texture_camera.gen.d.ts +74 -0
  63. package/dist/components/generated/pb/decentraland/sdk/components/texture_camera.gen.js +191 -0
  64. package/dist/components/generated/pb/decentraland/sdk/components/ui_canvas.gen.d.ts +19 -0
  65. package/dist/components/generated/pb/decentraland/sdk/components/ui_canvas.gen.js +60 -0
  66. package/dist/components/generated/pb/decentraland/sdk/components/ui_scroll_result.gen.d.ts +15 -0
  67. package/dist/components/generated/pb/decentraland/sdk/components/ui_scroll_result.gen.js +42 -0
  68. package/dist/components/generated/pb/decentraland/sdk/components/ui_text.gen.d.ts +4 -0
  69. package/dist/components/generated/pb/decentraland/sdk/components/ui_text.gen.js +20 -0
  70. package/dist/components/generated/pb/decentraland/sdk/components/ui_transform.gen.d.ts +35 -0
  71. package/dist/components/generated/pb/decentraland/sdk/components/ui_transform.gen.js +90 -0
  72. package/dist/components/index.d.ts +11 -7
  73. package/dist/components/index.js +11 -5
  74. package/dist/components/types.d.ts +2 -0
  75. package/dist/engine/input.d.ts +6 -0
  76. package/dist/engine/input.js +7 -1
  77. package/dist/runtime/initialization/index.d.ts +1 -1
  78. package/dist/runtime/initialization/index.js +1 -1
  79. package/dist/systems/events.d.ts +100 -1
  80. package/dist/systems/events.js +143 -65
  81. package/dist/systems/tween.js +63 -88
  82. package/dist-cjs/components/extended/AvatarEquippedData.d.ts +10 -0
  83. package/dist-cjs/components/extended/AvatarEquippedData.js +19 -0
  84. package/dist-cjs/components/extended/AvatarShape.d.ts +10 -0
  85. package/dist-cjs/components/extended/AvatarShape.js +19 -0
  86. package/dist-cjs/components/extended/MeshCollider.d.ts +8 -0
  87. package/dist-cjs/components/extended/MeshCollider.js +6 -0
  88. package/dist-cjs/components/extended/MeshRenderer.d.ts +8 -0
  89. package/dist-cjs/components/extended/MeshRenderer.js +5 -0
  90. package/dist-cjs/components/generated/CameraLayer.gen.d.ts +1 -0
  91. package/dist-cjs/components/generated/CameraLayer.gen.js +28 -0
  92. package/dist-cjs/components/generated/CameraLayers.gen.d.ts +1 -0
  93. package/dist-cjs/components/generated/CameraLayers.gen.js +28 -0
  94. package/dist-cjs/components/generated/GlobalLight.gen.d.ts +1 -0
  95. package/dist-cjs/components/generated/GlobalLight.gen.js +28 -0
  96. package/dist-cjs/components/generated/GltfNode.gen.d.ts +1 -0
  97. package/dist-cjs/components/generated/GltfNode.gen.js +28 -0
  98. package/dist-cjs/components/generated/GltfNodeState.gen.d.ts +1 -0
  99. package/dist-cjs/components/generated/GltfNodeState.gen.js +28 -0
  100. package/dist-cjs/components/generated/TextureCamera.gen.d.ts +1 -0
  101. package/dist-cjs/components/generated/TextureCamera.gen.js +28 -0
  102. package/dist-cjs/components/generated/UiCanvas.gen.d.ts +1 -0
  103. package/dist-cjs/components/generated/UiCanvas.gen.js +28 -0
  104. package/dist-cjs/components/generated/UiScrollResult.gen.d.ts +1 -0
  105. package/dist-cjs/components/generated/UiScrollResult.gen.js +28 -0
  106. package/dist-cjs/components/generated/component-names.gen.js +8 -0
  107. package/dist-cjs/components/generated/global.gen.d.ts +16 -0
  108. package/dist-cjs/components/generated/global.gen.js +10 -1
  109. package/dist-cjs/components/generated/index.gen.d.ts +32 -0
  110. package/dist-cjs/components/generated/index.gen.js +50 -2
  111. package/dist-cjs/components/generated/pb/decentraland/common/texture.gen.d.ts +20 -0
  112. package/dist-cjs/components/generated/pb/decentraland/common/texture.gen.js +66 -1
  113. package/dist-cjs/components/generated/pb/decentraland/sdk/components/avatar_equipped_data.gen.d.ts +2 -0
  114. package/dist-cjs/components/generated/pb/decentraland/sdk/components/avatar_equipped_data.gen.js +10 -1
  115. package/dist-cjs/components/generated/pb/decentraland/sdk/components/avatar_modifier_area.gen.d.ts +43 -0
  116. package/dist-cjs/components/generated/pb/decentraland/sdk/components/avatar_modifier_area.gen.js +152 -2
  117. package/dist-cjs/components/generated/pb/decentraland/sdk/components/avatar_shape.gen.d.ts +2 -0
  118. package/dist-cjs/components/generated/pb/decentraland/sdk/components/avatar_shape.gen.js +10 -0
  119. package/dist-cjs/components/generated/pb/decentraland/sdk/components/camera_layer.gen.d.ts +30 -0
  120. package/dist-cjs/components/generated/pb/decentraland/sdk/components/camera_layer.gen.js +110 -0
  121. package/dist-cjs/components/generated/pb/decentraland/sdk/components/camera_layers.gen.d.ts +14 -0
  122. package/dist-cjs/components/generated/pb/decentraland/sdk/components/camera_layers.gen.js +56 -0
  123. package/dist-cjs/components/generated/pb/decentraland/sdk/components/camera_mode_area.gen.d.ts +37 -1
  124. package/dist-cjs/components/generated/pb/decentraland/sdk/components/camera_mode_area.gen.js +120 -2
  125. package/dist-cjs/components/generated/pb/decentraland/sdk/components/common/input_action.gen.d.ts +4 -1
  126. package/dist-cjs/components/generated/pb/decentraland/sdk/components/common/input_action.gen.js +3 -0
  127. package/dist-cjs/components/generated/pb/decentraland/sdk/components/global_light.gen.d.ts +34 -0
  128. package/dist-cjs/components/generated/pb/decentraland/sdk/components/global_light.gen.js +67 -0
  129. package/dist-cjs/components/generated/pb/decentraland/sdk/components/gltf_container_loading_state.gen.d.ts +19 -0
  130. package/dist-cjs/components/generated/pb/decentraland/sdk/components/gltf_container_loading_state.gen.js +46 -1
  131. package/dist-cjs/components/generated/pb/decentraland/sdk/components/gltf_node.gen.d.ts +50 -0
  132. package/dist-cjs/components/generated/pb/decentraland/sdk/components/gltf_node.gen.js +47 -0
  133. package/dist-cjs/components/generated/pb/decentraland/sdk/components/gltf_node_state.gen.d.ts +27 -0
  134. package/dist-cjs/components/generated/pb/decentraland/sdk/components/gltf_node_state.gen.js +65 -0
  135. package/dist-cjs/components/generated/pb/decentraland/sdk/components/material.gen.d.ts +22 -0
  136. package/dist-cjs/components/generated/pb/decentraland/sdk/components/material.gen.js +58 -2
  137. package/dist-cjs/components/generated/pb/decentraland/sdk/components/mesh_collider.gen.d.ts +20 -0
  138. package/dist-cjs/components/generated/pb/decentraland/sdk/components/mesh_collider.gen.js +57 -1
  139. package/dist-cjs/components/generated/pb/decentraland/sdk/components/mesh_renderer.gen.d.ts +21 -3
  140. package/dist-cjs/components/generated/pb/decentraland/sdk/components/mesh_renderer.gen.js +57 -1
  141. package/dist-cjs/components/generated/pb/decentraland/sdk/components/primary_pointer_info.gen.d.ts +8 -2
  142. package/dist-cjs/components/generated/pb/decentraland/sdk/components/primary_pointer_info.gen.js +3 -0
  143. package/dist-cjs/components/generated/pb/decentraland/sdk/components/texture_camera.gen.d.ts +74 -0
  144. package/dist-cjs/components/generated/pb/decentraland/sdk/components/texture_camera.gen.js +197 -0
  145. package/dist-cjs/components/generated/pb/decentraland/sdk/components/ui_canvas.gen.d.ts +19 -0
  146. package/dist-cjs/components/generated/pb/decentraland/sdk/components/ui_canvas.gen.js +66 -0
  147. package/dist-cjs/components/generated/pb/decentraland/sdk/components/ui_scroll_result.gen.d.ts +15 -0
  148. package/dist-cjs/components/generated/pb/decentraland/sdk/components/ui_scroll_result.gen.js +48 -0
  149. package/dist-cjs/components/generated/pb/decentraland/sdk/components/ui_text.gen.d.ts +4 -0
  150. package/dist-cjs/components/generated/pb/decentraland/sdk/components/ui_text.gen.js +20 -0
  151. package/dist-cjs/components/generated/pb/decentraland/sdk/components/ui_transform.gen.d.ts +35 -0
  152. package/dist-cjs/components/generated/pb/decentraland/sdk/components/ui_transform.gen.js +91 -1
  153. package/dist-cjs/components/index.d.ts +11 -7
  154. package/dist-cjs/components/index.js +15 -7
  155. package/dist-cjs/components/types.d.ts +2 -0
  156. package/dist-cjs/engine/input.d.ts +6 -0
  157. package/dist-cjs/engine/input.js +7 -1
  158. package/dist-cjs/runtime/initialization/index.d.ts +1 -1
  159. package/dist-cjs/runtime/initialization/index.js +1 -1
  160. package/dist-cjs/systems/events.d.ts +100 -1
  161. package/dist-cjs/systems/events.js +143 -65
  162. package/dist-cjs/systems/tween.js +63 -88
  163. package/package.json +2 -2
@@ -1,6 +1,7 @@
1
1
  /* eslint-disable */
2
2
  import _m0 from "protobufjs/minimal";
3
3
  import { Color4 } from "../../common/colors.gen";
4
+ import { Vector2 } from "../../common/vectors.gen";
4
5
  const protobufPackageSarasa = "decentraland.sdk.components";
5
6
  /**
6
7
  * @public
@@ -105,6 +106,65 @@ export var PointerFilterMode;
105
106
  PointerFilterMode[PointerFilterMode["PFM_NONE"] = 0] = "PFM_NONE";
106
107
  PointerFilterMode[PointerFilterMode["PFM_BLOCK"] = 1] = "PFM_BLOCK";
107
108
  })(PointerFilterMode || (PointerFilterMode = {}));
109
+ /**
110
+ * @public
111
+ */
112
+ export var ShowScrollBar;
113
+ (function (ShowScrollBar) {
114
+ ShowScrollBar[ShowScrollBar["SSB_BOTH"] = 0] = "SSB_BOTH";
115
+ ShowScrollBar[ShowScrollBar["SSB_ONLY_VERTICAL"] = 1] = "SSB_ONLY_VERTICAL";
116
+ ShowScrollBar[ShowScrollBar["SSB_ONLY_HORIZONTAL"] = 2] = "SSB_ONLY_HORIZONTAL";
117
+ ShowScrollBar[ShowScrollBar["SSB_HIDDEN"] = 3] = "SSB_HIDDEN";
118
+ })(ShowScrollBar || (ShowScrollBar = {}));
119
+ function createBaseScrollPositionValue() {
120
+ return { value: undefined };
121
+ }
122
+ /**
123
+ * @public
124
+ */
125
+ export var ScrollPositionValue;
126
+ (function (ScrollPositionValue) {
127
+ function encode(message, writer = _m0.Writer.create()) {
128
+ switch (message.value?.$case) {
129
+ case "position":
130
+ Vector2.encode(message.value.position, writer.uint32(10).fork()).ldelim();
131
+ break;
132
+ case "reference":
133
+ writer.uint32(18).string(message.value.reference);
134
+ break;
135
+ }
136
+ return writer;
137
+ }
138
+ ScrollPositionValue.encode = encode;
139
+ function decode(input, length) {
140
+ const reader = input instanceof _m0.Reader ? input : _m0.Reader.create(input);
141
+ let end = length === undefined ? reader.len : reader.pos + length;
142
+ const message = createBaseScrollPositionValue();
143
+ while (reader.pos < end) {
144
+ const tag = reader.uint32();
145
+ switch (tag >>> 3) {
146
+ case 1:
147
+ if (tag !== 10) {
148
+ break;
149
+ }
150
+ message.value = { $case: "position", position: Vector2.decode(reader, reader.uint32()) };
151
+ continue;
152
+ case 2:
153
+ if (tag !== 18) {
154
+ break;
155
+ }
156
+ message.value = { $case: "reference", reference: reader.string() };
157
+ continue;
158
+ }
159
+ if ((tag & 7) === 4 || tag === 0) {
160
+ break;
161
+ }
162
+ reader.skipType(tag & 7);
163
+ }
164
+ return message;
165
+ }
166
+ ScrollPositionValue.decode = decode;
167
+ })(ScrollPositionValue || (ScrollPositionValue = {}));
108
168
  function createBasePBUiTransform() {
109
169
  return {
110
170
  parent: 0,
@@ -180,6 +240,9 @@ function createBasePBUiTransform() {
180
240
  borderLeftColor: undefined,
181
241
  borderRightColor: undefined,
182
242
  opacity: undefined,
243
+ elementId: undefined,
244
+ scrollPosition: undefined,
245
+ scrollVisible: undefined,
183
246
  zIndex: undefined,
184
247
  };
185
248
  }
@@ -408,6 +471,15 @@ export var PBUiTransform;
408
471
  if (message.opacity !== undefined) {
409
472
  writer.uint32(589).float(message.opacity);
410
473
  }
474
+ if (message.elementId !== undefined) {
475
+ writer.uint32(594).string(message.elementId);
476
+ }
477
+ if (message.scrollPosition !== undefined) {
478
+ ScrollPositionValue.encode(message.scrollPosition, writer.uint32(602).fork()).ldelim();
479
+ }
480
+ if (message.scrollVisible !== undefined) {
481
+ writer.uint32(608).int32(message.scrollVisible);
482
+ }
411
483
  if (message.zIndex !== undefined) {
412
484
  writer.uint32(616).int32(message.zIndex);
413
485
  }
@@ -859,6 +931,24 @@ export var PBUiTransform;
859
931
  }
860
932
  message.opacity = reader.float();
861
933
  continue;
934
+ case 74:
935
+ if (tag !== 594) {
936
+ break;
937
+ }
938
+ message.elementId = reader.string();
939
+ continue;
940
+ case 75:
941
+ if (tag !== 602) {
942
+ break;
943
+ }
944
+ message.scrollPosition = ScrollPositionValue.decode(reader, reader.uint32());
945
+ continue;
946
+ case 76:
947
+ if (tag !== 608) {
948
+ break;
949
+ }
950
+ message.scrollVisible = reader.int32();
951
+ continue;
862
952
  case 77:
863
953
  if (tag !== 616) {
864
954
  break;
@@ -2,25 +2,27 @@ import { GrowOnlyValueSetComponentDefinition, LastWriteWinElementSetComponentDef
2
2
  import { IEngine } from '../engine/types';
3
3
  import { AnimatorComponentDefinitionExtended } from './extended/Animator';
4
4
  import { AudioSourceComponentDefinitionExtended } from './extended/AudioSource';
5
+ import { AudioStreamComponentDefinitionExtended } from './extended/AudioStream';
6
+ import { AvatarEquippedDataComponentDefinitionExtended } from './extended/AvatarEquippedData';
7
+ import { AvatarShapeComponentDefinitionExtended } from './extended/AvatarShape';
8
+ import { InputModifierComponentDefinitionExtended } from './extended/InputModifier';
5
9
  import { MaterialComponentDefinitionExtended } from './extended/Material';
6
10
  import { MeshColliderComponentDefinitionExtended } from './extended/MeshCollider';
7
11
  import { MeshRendererComponentDefinitionExtended } from './extended/MeshRenderer';
8
12
  import { TweenComponentDefinitionExtended } from './extended/Tween';
9
- import { LwwComponentGetter, GSetComponentGetter } from './generated/index.gen';
13
+ import { VirtualCameraComponentDefinitionExtended } from './extended/VirtualCamera';
14
+ import { GSetComponentGetter, LwwComponentGetter } from './generated/index.gen';
15
+ import { MediaState } from './generated/pb/decentraland/sdk/components/common/media_state.gen';
10
16
  import { NameType } from './manual/Name';
11
- import { ISyncComponentsType } from './manual/SyncComponents';
12
17
  import { INetowrkEntityType } from './manual/NetworkEntity';
13
18
  import { INetowrkParentType } from './manual/NetworkParent';
19
+ import { ISyncComponentsType } from './manual/SyncComponents';
14
20
  import { TransformComponentExtended } from './manual/Transform';
15
- import { AudioStreamComponentDefinitionExtended } from './extended/AudioStream';
16
- import { MediaState } from './generated/pb/decentraland/sdk/components/common/media_state.gen';
17
- import { VirtualCameraComponentDefinitionExtended } from './extended/VirtualCamera';
18
- import { InputModifierComponentDefinitionExtended } from './extended/InputModifier';
19
21
  import { LightSourceComponentDefinitionExtended } from './extended/LightSource';
20
22
  import { TriggerAreaComponentDefinitionExtended } from './extended/TriggerArea';
21
23
  import { TagsComponentDefinitionExtended } from './manual/Tags';
22
24
  export * from './generated/index.gen';
23
- export type { GrowOnlyValueSetComponentDefinition, LastWriteWinElementSetComponentDefinition, LwwComponentGetter, GSetComponentGetter };
25
+ export type { GrowOnlyValueSetComponentDefinition, GSetComponentGetter, LastWriteWinElementSetComponentDefinition, LwwComponentGetter };
24
26
  export declare const Transform: LwwComponentGetter<TransformComponentExtended>;
25
27
  export declare const Material: LwwComponentGetter<MaterialComponentDefinitionExtended>;
26
28
  export declare const Animator: LwwComponentGetter<AnimatorComponentDefinitionExtended>;
@@ -29,6 +31,8 @@ export declare const AudioStream: (engine: Pick<IEngine, 'defineComponentFromSch
29
31
  export declare const MeshRenderer: LwwComponentGetter<MeshRendererComponentDefinitionExtended>;
30
32
  export declare const MeshCollider: LwwComponentGetter<MeshColliderComponentDefinitionExtended>;
31
33
  export declare const Tween: LwwComponentGetter<TweenComponentDefinitionExtended>;
34
+ export declare const AvatarShape: LwwComponentGetter<AvatarShapeComponentDefinitionExtended>;
35
+ export declare const AvatarEquippedData: LwwComponentGetter<AvatarEquippedDataComponentDefinitionExtended>;
32
36
  export declare const VirtualCamera: LwwComponentGetter<VirtualCameraComponentDefinitionExtended>;
33
37
  export declare const InputModifier: LwwComponentGetter<InputModifierComponentDefinitionExtended>;
34
38
  export declare const LightSource: LwwComponentGetter<LightSourceComponentDefinitionExtended>;
@@ -1,18 +1,20 @@
1
1
  import { defineAnimatorComponent } from './extended/Animator';
2
2
  import { defineAudioSourceComponent } from './extended/AudioSource';
3
+ import { defineAudioStreamComponent } from './extended/AudioStream';
4
+ import { defineAvatarEquippedDataComponent } from './extended/AvatarEquippedData';
5
+ import { defineAvatarShapeComponent } from './extended/AvatarShape';
6
+ import { defineInputModifierComponent } from './extended/InputModifier';
3
7
  import { defineMaterialComponent } from './extended/Material';
4
8
  import { defineMeshColliderComponent } from './extended/MeshCollider';
5
9
  import { defineMeshRendererComponent } from './extended/MeshRenderer';
6
10
  import { defineTweenComponent } from './extended/Tween';
11
+ import { defineVirtualCameraComponent } from './extended/VirtualCamera';
12
+ import { MediaState } from './generated/pb/decentraland/sdk/components/common/media_state.gen';
7
13
  import defineNameComponent from './manual/Name';
8
- import defineSyncComponent from './manual/SyncComponents';
9
14
  import defineNetworkEntity from './manual/NetworkEntity';
10
15
  import defineNetworkParent from './manual/NetworkParent';
16
+ import defineSyncComponent from './manual/SyncComponents';
11
17
  import { defineTransformComponent } from './manual/Transform';
12
- import { defineAudioStreamComponent } from './extended/AudioStream';
13
- import { MediaState } from './generated/pb/decentraland/sdk/components/common/media_state.gen';
14
- import { defineVirtualCameraComponent } from './extended/VirtualCamera';
15
- import { defineInputModifierComponent } from './extended/InputModifier';
16
18
  import { defineLightSourceComponent } from './extended/LightSource';
17
19
  import { defineTriggerAreaComponent } from './extended/TriggerArea';
18
20
  import defineTagsComponent from './manual/Tags';
@@ -34,6 +36,10 @@ export const MeshCollider = (engine) => defineMeshColliderComponent(engine);
34
36
  /* @__PURE__ */
35
37
  export const Tween = (engine) => defineTweenComponent(engine);
36
38
  /* @__PURE__ */
39
+ export const AvatarShape = (engine) => defineAvatarShapeComponent(engine);
40
+ /* @__PURE__ */
41
+ export const AvatarEquippedData = (engine) => defineAvatarEquippedDataComponent(engine);
42
+ /* @__PURE__ */
37
43
  export const VirtualCamera = (engine) => defineVirtualCameraComponent(engine);
38
44
  /* @__PURE__*/
39
45
  export const InputModifier = (engine) => defineInputModifierComponent(engine);
@@ -3,6 +3,8 @@ export type { AudioSourceComponentDefinitionExtended } from './extended/AudioSou
3
3
  export type { AudioStreamComponentDefinitionExtended } from './extended/AudioStream';
4
4
  export type { MeshRendererComponentDefinitionExtended } from './extended/MeshRenderer';
5
5
  export type { MeshColliderComponentDefinitionExtended } from './extended/MeshCollider';
6
+ export type { AvatarEquippedDataComponentDefinitionExtended, AvatarEquippedDataType } from './extended/AvatarEquippedData';
7
+ export type { AvatarShapeComponentDefinitionExtended, AvatarShapeType } from './extended/AvatarShape';
6
8
  export type { TextureHelper, MaterialComponentDefinitionExtended } from './extended/Material';
7
9
  export type { TweenHelper, TweenComponentDefinitionExtended } from './extended/Tween';
8
10
  export type { CameraTransitionHelper, VirtualCameraComponentDefinitionExtended } from './extended/VirtualCamera';
@@ -32,6 +32,12 @@ export type IInputSystem = {
32
32
  * @returns the input command info or undefined if there is no command in the last tick-update
33
33
  */
34
34
  getInputCommand: (inputAction: InputAction, pointerEventType: PointerEventType, entity?: Entity) => PBPointerEventsResult | null;
35
+ /**
36
+ * @public
37
+ * Get an ordered iterator over events received within the current frame.
38
+ * @returns the iterator
39
+ */
40
+ getInputCommands: () => Generator<PBPointerEventsResult>;
35
41
  };
36
42
  /**
37
43
  * @public
@@ -185,11 +185,17 @@ export function createInputSystem(engine) {
185
185
  function isPressed(inputAction) {
186
186
  return globalState.buttonState.get(inputAction)?.state === 1 /* PointerEventType.PET_DOWN */;
187
187
  }
188
+ function* getInputCommands() {
189
+ for (let i = globalState.thisFrameCommands.length - 1; i >= 0; i--) {
190
+ yield globalState.thisFrameCommands[i];
191
+ }
192
+ }
188
193
  return {
189
194
  isPressed,
190
195
  getClick,
191
196
  getInputCommand,
192
197
  isClicked,
193
- isTriggered
198
+ isTriggered,
199
+ getInputCommands
194
200
  };
195
201
  }
@@ -53,7 +53,7 @@ export declare const videoEventsSystem: VideoEventsSystem;
53
53
  export { VideoEventsSystem };
54
54
  /**
55
55
  * @public
56
- * Register callback functions to a particular entity on tween events.
56
+ * Register callback functions to a particular entity on video events.
57
57
  */
58
58
  export declare const tweenSystem: TweenSystem;
59
59
  export { TweenSystem };
@@ -50,7 +50,7 @@ export const raycastSystem = /* @__PURE__ */ createRaycastSystem(engine);
50
50
  export const videoEventsSystem = /* @__PURE__ */ createVideoEventsSystem(engine);
51
51
  /**
52
52
  * @public
53
- * Register callback functions to a particular entity on tween events.
53
+ * Register callback functions to a particular entity on video events.
54
54
  */
55
55
  export const tweenSystem = createTweenSystem(engine);
56
56
  /**
@@ -17,6 +17,12 @@ export type EventSystemOptions = {
17
17
  showFeedback?: boolean;
18
18
  showHighlight?: boolean;
19
19
  };
20
+ /**
21
+ * @public
22
+ */
23
+ export type EventSystemOptionsCallback = EventSystemOptions & {
24
+ cb: EventSystemCallback;
25
+ };
20
26
  export declare const getDefaultOpts: (opts?: Partial<EventSystemOptions>) => EventSystemOptions;
21
27
  /**
22
28
  * @public
@@ -46,11 +52,37 @@ export interface PointerEventsSystem {
46
52
  * @param entity - Entity where the callback was attached
47
53
  */
48
54
  removeOnPointerHoverLeave(entity: Entity): void;
55
+ /**
56
+ * @public
57
+ * Remove the callback for onPointerDrag event
58
+ * @param entity - Entity where the callback was attached
59
+ */
60
+ removeOnPointerDrag(entity: Entity): void;
61
+ /**
62
+ * @public
63
+ * Remove the callback for onPointerDragLocked event
64
+ * @param entity - Entity where the callback was attached
65
+ */
66
+ removeOnPointerDragLocked(entity: Entity): void;
67
+ /**
68
+ * @public
69
+ * Remove the callback for onPointerDragEnd event
70
+ * @param entity - Entity where the callback was attached
71
+ */
72
+ removeOnPointerDragEnd(entity: Entity): void;
73
+ /**
74
+ * @public
75
+ * Execute callbacks when the user presses one of the InputButtons pointing at the entity
76
+ * @param pointerData - Entity to attach the callbacks, list of options to trigger Feedback, Button, and Callback
77
+ */
78
+ onPointerDown(pointerData: {
79
+ entity: Entity;
80
+ optsList: EventSystemOptionsCallback[];
81
+ }): void;
49
82
  /**
50
83
  * @public
51
84
  * Execute callback when the user press the InputButton pointing at the entity
52
85
  * @param pointerData - Entity to attach the callback, Opts to trigger Feedback and Button
53
- * @param cb - Function to execute when click fires
54
86
  */
55
87
  onPointerDown(pointerData: {
56
88
  entity: Entity;
@@ -63,6 +95,15 @@ export interface PointerEventsSystem {
63
95
  * @param opts - Opts to trigger Feedback and Button
64
96
  */
65
97
  onPointerDown(entity: Entity, cb: EventSystemCallback, opts?: Partial<EventSystemOptions>): void;
98
+ /**
99
+ * @public
100
+ * Execute callbacks when the user releases one of the InputButtons pointing at the entity
101
+ * @param pointerData - Entity to attach the callbacks, list of options to trigger Feedback, Button, and Callback
102
+ */
103
+ onPointerUp(pointerData: {
104
+ entity: Entity;
105
+ optsList: EventSystemOptionsCallback[];
106
+ }): void;
66
107
  /**
67
108
  * @public
68
109
  * Execute callback when the user releases the InputButton pointing at the entity
@@ -100,6 +141,64 @@ export interface PointerEventsSystem {
100
141
  entity: Entity;
101
142
  opts?: Partial<EventSystemOptions>;
102
143
  }, cb: EventSystemCallback): void;
144
+ /**
145
+ * @public
146
+ * Execute callbacks when the user drags the pointer from inside the entity
147
+ * @param pointerData - Entity to attach the callbacks, list of options to trigger Feedback, Button, and Callback
148
+ */
149
+ onPointerDrag(pointerData: {
150
+ entity: Entity;
151
+ optsList: EventSystemOptionsCallback[];
152
+ }): void;
153
+ /**
154
+ * @public
155
+ * Execute callback when the user clicks and drags the pointer from inside the entity
156
+ * @param pointerData - Entity to attach the callback - Opts to trigger Feedback and Button
157
+ * @param cb - Function to execute when click fires
158
+ */
159
+ onPointerDrag(pointerData: {
160
+ entity: Entity;
161
+ opts?: Partial<EventSystemOptions>;
162
+ }, cb: EventSystemCallback): void;
163
+ /**
164
+ * @public
165
+ * Execute callbacks when the user drags the pointer from inside the entity, locking the cursor in place.
166
+ * @param pointerData - Entity to attach the callbacks, list of options to trigger Feedback, Button, and Callback
167
+ */
168
+ onPointerDragLocked(pointerData: {
169
+ entity: Entity;
170
+ optsList: EventSystemOptionsCallback[];
171
+ }): void;
172
+ /**
173
+ * @public
174
+ * Execute callback when the user clicks and drags the pointer from inside the entity,
175
+ * locking the cursor in place
176
+ * @param pointerData - Entity to attach the callback - Opts to trigger Feedback and Button
177
+ * @param cb - Function to execute when click fires
178
+ */
179
+ onPointerDragLocked(pointerData: {
180
+ entity: Entity;
181
+ opts?: Partial<EventSystemOptions>;
182
+ }, cb: EventSystemCallback): void;
183
+ /**
184
+ * @public
185
+ * Execute callbacks when the user releases a button after a drag
186
+ * @param pointerData - Entity to attach the callbacks, list of options to trigger Feedback, Button, and Callback
187
+ */
188
+ onPointerDragEnd(pointerData: {
189
+ entity: Entity;
190
+ optsList: EventSystemOptionsCallback[];
191
+ }): void;
192
+ /**
193
+ * @public
194
+ * Execute callback when the user releases the button after a drag
195
+ * @param pointerData - Entity to attach the callback - Opts to trigger Feedback and Button
196
+ * @param cb - Function to execute when click fires
197
+ */
198
+ onPointerDragEnd(pointerData: {
199
+ entity: Entity;
200
+ opts?: Partial<EventSystemOptions>;
201
+ }, cb: EventSystemCallback): void;
103
202
  }
104
203
  /**
105
204
  * @public
@@ -18,6 +18,9 @@ export function createPointerEventsSystem(engine, inputSystem) {
18
18
  EventType[EventType["Up"] = 2] = "Up";
19
19
  EventType[EventType["HoverEnter"] = 3] = "HoverEnter";
20
20
  EventType[EventType["HoverLeave"] = 4] = "HoverLeave";
21
+ EventType[EventType["Drag"] = 5] = "Drag";
22
+ EventType[EventType["DragLocked"] = 6] = "DragLocked";
23
+ EventType[EventType["DragEnd"] = 7] = "DragEnd";
21
24
  })(EventType || (EventType = {}));
22
25
  const eventsMap = new Map();
23
26
  function getEvent(entity) {
@@ -52,77 +55,148 @@ export function createPointerEventsSystem(engine, inputSystem) {
52
55
  else if (eventType === EventType.HoverEnter) {
53
56
  return 2 /* PointerEventType.PET_HOVER_ENTER */;
54
57
  }
58
+ else if (eventType === EventType.Drag) {
59
+ return 5 /* PointerEventType.PET_DRAG */;
60
+ }
61
+ else if (eventType === EventType.DragLocked) {
62
+ return 4 /* PointerEventType.PET_DRAG_LOCKED */;
63
+ }
64
+ else if (eventType === EventType.DragEnd) {
65
+ return 6 /* PointerEventType.PET_DRAG_END */;
66
+ }
55
67
  return 1 /* PointerEventType.PET_DOWN */;
56
68
  }
69
+ function getEventType(pet) {
70
+ if (pet === 0 /* PointerEventType.PET_UP */) {
71
+ return EventType.Up;
72
+ }
73
+ else if (pet === 2 /* PointerEventType.PET_HOVER_ENTER */) {
74
+ return EventType.HoverEnter;
75
+ }
76
+ else if (pet === 3 /* PointerEventType.PET_HOVER_LEAVE */) {
77
+ return EventType.HoverLeave;
78
+ }
79
+ else if (pet === 5 /* PointerEventType.PET_DRAG */) {
80
+ return EventType.Drag;
81
+ }
82
+ else if (pet === 4 /* PointerEventType.PET_DRAG_LOCKED */) {
83
+ return EventType.DragLocked;
84
+ }
85
+ else if (pet === 6 /* PointerEventType.PET_DRAG_END */) {
86
+ return EventType.DragEnd;
87
+ }
88
+ else {
89
+ return EventType.Down;
90
+ }
91
+ }
57
92
  function removeEvent(entity, type) {
58
93
  const event = getEvent(entity);
59
- const pointerEvent = event.get(type);
60
- if (pointerEvent?.opts.hoverText) {
61
- removePointerEvent(entity, getPointerEvent(type), pointerEvent.opts.button);
94
+ const pointerEventList = event.get(type);
95
+ if (pointerEventList === undefined) {
96
+ return;
97
+ }
98
+ for (const button of pointerEventList.keys()) {
99
+ removePointerEvent(entity, getPointerEvent(type), button);
62
100
  }
63
101
  event.delete(type);
64
102
  }
65
103
  engine.addSystem(function EventSystem() {
66
- for (const [entity, event] of eventsMap) {
104
+ if (eventsMap.size === 0) {
105
+ return;
106
+ }
107
+ for (const entity of eventsMap.keys()) {
67
108
  if (engine.getEntityState(entity) === EntityState.Removed) {
68
109
  eventsMap.delete(entity);
110
+ }
111
+ }
112
+ for (const command of inputSystem.getInputCommands()) {
113
+ const entity = command.hit?.entityId;
114
+ if (entity === undefined) {
115
+ continue;
116
+ }
117
+ const entityMap = eventsMap.get(entity);
118
+ if (entityMap === undefined) {
69
119
  continue;
70
120
  }
71
- for (const [eventType, { cb, opts }] of event) {
72
- if (eventType === EventType.Click) {
73
- const command = inputSystem.getClick(opts.button, entity);
74
- if (command)
75
- checkNotThenable(cb(command.up), 'Click event returned a thenable. Only synchronous functions are allowed');
121
+ const typeMap = entityMap.get(getEventType(command.state));
122
+ if (typeMap) {
123
+ const data = typeMap.get(command.button);
124
+ if (data) {
125
+ checkNotThenable(data.cb(command), 'Event handler returned a thenable. Only synchronous functions are allowed');
76
126
  }
77
- if (eventType === EventType.Down ||
78
- eventType === EventType.Up ||
79
- eventType === EventType.HoverEnter ||
80
- eventType === EventType.HoverLeave) {
81
- const command = inputSystem.getInputCommand(opts.button, getPointerEvent(eventType), entity);
82
- if (command) {
83
- checkNotThenable(cb(command), 'Event handler returned a thenable. Only synchronous functions are allowed');
127
+ const anyData = typeMap.get(3 /* InputAction.IA_ANY */);
128
+ if (anyData) {
129
+ checkNotThenable(anyData.cb(command), 'Event handler returned a thenable. Only synchronous functions are allowed');
130
+ }
131
+ }
132
+ // check clicks separately
133
+ if (command.state === 0 /* PointerEventType.PET_UP */) {
134
+ const clickMap = entityMap.get(EventType.Click);
135
+ if (clickMap) {
136
+ const data = clickMap.get(command.button);
137
+ if (data && inputSystem.getClick(command.button, entity)) {
138
+ checkNotThenable(data.cb(command), 'Click event returned a thenable. Only synchronous functions are allowed');
139
+ }
140
+ const anyData = clickMap.get(3 /* InputAction.IA_ANY */);
141
+ if (anyData && inputSystem.getClick(command.button, entity)) {
142
+ checkNotThenable(anyData.cb(command), 'Event handler returned a thenable. Only synchronous functions are allowed');
84
143
  }
85
144
  }
86
145
  }
87
146
  }
88
147
  });
89
- const onPointerDown = (...args) => {
90
- const [data, cb, maybeOpts] = args;
91
- if (typeof data === 'number') {
92
- return onPointerDown({ entity: data, opts: maybeOpts ?? {} }, cb);
93
- }
94
- const { entity, opts } = data;
95
- const options = getDefaultOpts(opts);
96
- removeEvent(entity, EventType.Down);
97
- getEvent(entity).set(EventType.Down, { cb, opts: options });
98
- setPointerEvent(entity, 1 /* PointerEventType.PET_DOWN */, options);
99
- };
100
- const onPointerUp = (...args) => {
101
- const [data, cb, maybeOpts] = args;
102
- if (typeof data === 'number') {
103
- return onPointerUp({ entity: data, opts: maybeOpts ?? {} }, cb);
104
- }
105
- const { entity, opts } = data;
106
- const options = getDefaultOpts(opts);
107
- removeEvent(entity, EventType.Up);
108
- getEvent(entity).set(EventType.Up, { cb, opts: options });
109
- setPointerEvent(entity, 0 /* PointerEventType.PET_UP */, options);
110
- };
111
- const onPointerHoverEnter = (...args) => {
112
- const [data, cb] = args;
113
- const { entity, opts } = data;
114
- const options = getDefaultOpts(opts);
115
- removeEvent(entity, EventType.HoverEnter);
116
- getEvent(entity).set(EventType.HoverEnter, { cb, opts: options });
117
- setPointerEvent(entity, 2 /* PointerEventType.PET_HOVER_ENTER */, options);
118
- };
119
- const onPointerHoverLeave = (...args) => {
120
- const [data, cb] = args;
121
- const { entity, opts } = data;
122
- const options = getDefaultOpts(opts);
123
- removeEvent(entity, EventType.HoverLeave);
124
- getEvent(entity).set(EventType.HoverLeave, { cb, opts: options });
125
- setPointerEvent(entity, 3 /* PointerEventType.PET_HOVER_LEAVE */, options);
148
+ // return a function with the correct event type.
149
+ // we use onPointerDown as the "archetype" for the returned function, but it fits with
150
+ // all the onPointer* declarations
151
+ const onPointerFunction = (ty) => {
152
+ return (arg0, arg1, arg2) => {
153
+ let entity;
154
+ let optsList;
155
+ if (typeof arg0 === 'number') {
156
+ // called as onPointerDown(entity: Entity, cb: EventSystemCallback, opts?: Partial<EventSystemOptions>): void
157
+ entity = arg0;
158
+ const cb = arg1;
159
+ const opts = arg2;
160
+ optsList = [{ cb, ...getDefaultOpts(opts) }];
161
+ }
162
+ else if (typeof arg1 === 'function') {
163
+ // called as onPointerDown(pointerData: { entity: Entity; opts?: Partial<EventSystemOptions> }, cb: EventSystemCallback): void
164
+ const { entity: e, opts } = arg0;
165
+ const cb = arg1;
166
+ entity = e;
167
+ optsList = [{ cb, ...getDefaultOpts(opts) }];
168
+ }
169
+ else {
170
+ // called as onPointerDown(pointerData: { entity: Entity; optsList: EventSystemOptionsCallback[] }): void
171
+ const { entity: e, optsList: o } = arg0;
172
+ entity = e;
173
+ optsList = o;
174
+ }
175
+ const previous = getEvent(entity).get(ty) ?? new Map();
176
+ const callbacks = new Map();
177
+ for (const opts of optsList) {
178
+ const prevOpts = previous.get(opts.button);
179
+ if (prevOpts !== undefined) {
180
+ if (prevOpts.hoverText !== opts.hoverText ||
181
+ prevOpts.maxDistance !== opts.maxDistance ||
182
+ prevOpts.showFeedback !== opts.showFeedback ||
183
+ prevOpts.showHighlight !== opts.showHighlight) {
184
+ removePointerEvent(entity, getPointerEvent(ty), opts.button);
185
+ setPointerEvent(entity, getPointerEvent(ty), opts);
186
+ }
187
+ }
188
+ else {
189
+ setPointerEvent(entity, getPointerEvent(ty), opts);
190
+ }
191
+ callbacks.set(opts.button, opts);
192
+ }
193
+ for (const button of previous.keys()) {
194
+ if (!callbacks.has(button)) {
195
+ removePointerEvent(entity, getPointerEvent(ty), button);
196
+ }
197
+ }
198
+ getEvent(entity).set(ty, callbacks);
199
+ };
126
200
  };
127
201
  return {
128
202
  removeOnClick(entity) {
@@ -140,18 +214,22 @@ export function createPointerEventsSystem(engine, inputSystem) {
140
214
  removeOnPointerHoverLeave(entity) {
141
215
  removeEvent(entity, EventType.HoverLeave);
142
216
  },
143
- onClick(value, cb) {
144
- const { entity } = value;
145
- const options = getDefaultOpts(value.opts);
146
- // Clear previous event with over feedback included
147
- removeEvent(entity, EventType.Click);
148
- // Set new event
149
- getEvent(entity).set(EventType.Click, { cb, opts: options });
150
- setPointerEvent(entity, 1 /* PointerEventType.PET_DOWN */, options);
217
+ removeOnPointerDrag(entity) {
218
+ removeEvent(entity, EventType.Drag);
219
+ },
220
+ removeOnPointerDragLocked(entity) {
221
+ removeEvent(entity, EventType.DragLocked);
222
+ },
223
+ removeOnPointerDragEnd(entity) {
224
+ removeEvent(entity, EventType.DragEnd);
151
225
  },
152
- onPointerDown,
153
- onPointerUp,
154
- onPointerHoverEnter,
155
- onPointerHoverLeave
226
+ onClick: onPointerFunction(EventType.Click),
227
+ onPointerDown: onPointerFunction(EventType.Down),
228
+ onPointerUp: onPointerFunction(EventType.Up),
229
+ onPointerHoverEnter: onPointerFunction(EventType.HoverEnter),
230
+ onPointerHoverLeave: onPointerFunction(EventType.HoverLeave),
231
+ onPointerDrag: onPointerFunction(EventType.Drag),
232
+ onPointerDragLocked: onPointerFunction(EventType.DragLocked),
233
+ onPointerDragEnd: onPointerFunction(EventType.DragEnd)
156
234
  };
157
235
  }