@dcl/ecs 7.22.5-24836126953.commit-ddc8da1 → 7.22.5
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/dist/components/extended/ParticleSystem.d.ts +24 -0
- package/dist/components/extended/ParticleSystem.js +23 -0
- package/dist/components/generated/ParticleSystem.gen.d.ts +1 -0
- package/dist/components/generated/ParticleSystem.gen.js +25 -0
- package/dist/components/generated/component-names.gen.js +1 -0
- package/dist/components/generated/global.gen.d.ts +2 -0
- package/dist/components/generated/global.gen.js +1 -0
- package/dist/components/generated/index.gen.d.ts +4 -0
- package/dist/components/generated/index.gen.js +5 -0
- package/dist/components/generated/pb/decentraland/common/colors.gen.d.ts +15 -0
- package/dist/components/generated/pb/decentraland/common/colors.gen.js +47 -0
- package/dist/components/generated/pb/decentraland/common/floats.gen.d.ts +16 -0
- package/dist/components/generated/pb/decentraland/common/floats.gen.js +50 -0
- package/dist/components/generated/pb/decentraland/sdk/components/common/input_action.gen.d.ts +10 -1
- package/dist/components/generated/pb/decentraland/sdk/components/common/input_action.gen.js +10 -0
- package/dist/components/generated/pb/decentraland/sdk/components/particle_system.gen.d.ts +241 -0
- package/dist/components/generated/pb/decentraland/sdk/components/particle_system.gen.js +717 -0
- package/dist/components/generated/pb/decentraland/sdk/components/pointer_events.gen.d.ts +5 -1
- package/dist/components/generated/pb/decentraland/sdk/components/pointer_events.gen.js +20 -1
- package/dist/components/generated/types.gen.d.ts +2 -0
- package/dist/components/generated/types.gen.js +3 -0
- package/dist/components/index.d.ts +2 -5
- package/dist/components/index.js +5 -5
- package/dist/components/manual/Transform.d.ts +13 -9
- package/dist/components/manual/Transform.js +11 -3
- package/dist/components/types.d.ts +1 -1
- package/dist/engine/component.d.ts +1 -52
- package/dist/engine/grow-only-value-set-component-definition.js +2 -45
- package/dist/engine/lww-element-set-component-definition.d.ts +3 -5
- package/dist/engine/lww-element-set-component-definition.js +35 -70
- package/dist/index.d.ts +3 -2
- package/dist/index.js +3 -1
- package/dist/runtime/helpers/index.d.ts +1 -0
- package/dist/runtime/helpers/index.js +1 -0
- package/dist/runtime/helpers/tree.d.ts +6 -0
- package/dist/runtime/helpers/tree.js +2 -2
- package/dist/runtime/helpers/vectors.d.ts +1 -0
- package/dist/runtime/helpers/vectors.js +36 -0
- package/dist/runtime/initialization/index.d.ts +7 -0
- package/dist/runtime/initialization/index.js +6 -0
- package/dist/serialization/crdt/index.d.ts +0 -1
- package/dist/serialization/crdt/index.js +0 -1
- package/dist/serialization/crdt/network/utils.d.ts +9 -0
- package/dist/serialization/crdt/network/utils.js +60 -0
- package/dist/serialization/crdt/types.d.ts +3 -25
- package/dist/serialization/crdt/types.js +1 -3
- package/dist/systems/crdt/index.d.ts +1 -0
- package/dist/systems/crdt/index.js +146 -55
- package/dist/systems/events.d.ts +65 -0
- package/dist/systems/events.js +70 -8
- package/dist/systems/physics-force.d.ts +1 -0
- package/dist/systems/physics-force.js +140 -0
- package/dist/systems/physics-impulse.d.ts +12 -0
- package/dist/systems/physics-impulse.js +85 -0
- package/dist/systems/physics.d.ts +77 -0
- package/dist/systems/physics.js +18 -0
- package/dist-cjs/components/extended/ParticleSystem.d.ts +24 -0
- package/dist-cjs/components/extended/ParticleSystem.js +28 -0
- package/dist-cjs/components/generated/ParticleSystem.gen.d.ts +1 -0
- package/dist-cjs/components/generated/ParticleSystem.gen.js +28 -0
- package/dist-cjs/components/generated/component-names.gen.js +1 -0
- package/dist-cjs/components/generated/global.gen.d.ts +2 -0
- package/dist-cjs/components/generated/global.gen.js +3 -1
- package/dist-cjs/components/generated/index.gen.d.ts +4 -0
- package/dist-cjs/components/generated/index.gen.js +8 -2
- package/dist-cjs/components/generated/pb/decentraland/common/colors.gen.d.ts +15 -0
- package/dist-cjs/components/generated/pb/decentraland/common/colors.gen.js +48 -1
- package/dist-cjs/components/generated/pb/decentraland/common/floats.gen.d.ts +16 -0
- package/dist-cjs/components/generated/pb/decentraland/common/floats.gen.js +56 -0
- package/dist-cjs/components/generated/pb/decentraland/sdk/components/common/input_action.gen.d.ts +10 -1
- package/dist-cjs/components/generated/pb/decentraland/sdk/components/common/input_action.gen.js +11 -1
- package/dist-cjs/components/generated/pb/decentraland/sdk/components/particle_system.gen.d.ts +241 -0
- package/dist-cjs/components/generated/pb/decentraland/sdk/components/particle_system.gen.js +723 -0
- package/dist-cjs/components/generated/pb/decentraland/sdk/components/pointer_events.gen.d.ts +5 -1
- package/dist-cjs/components/generated/pb/decentraland/sdk/components/pointer_events.gen.js +20 -1
- package/dist-cjs/components/generated/types.gen.d.ts +2 -0
- package/dist-cjs/components/generated/types.gen.js +5 -0
- package/dist-cjs/components/index.d.ts +2 -5
- package/dist-cjs/components/index.js +7 -7
- package/dist-cjs/components/manual/Transform.d.ts +13 -9
- package/dist-cjs/components/manual/Transform.js +34 -3
- package/dist-cjs/components/types.d.ts +1 -1
- package/dist-cjs/engine/component.d.ts +1 -52
- package/dist-cjs/engine/grow-only-value-set-component-definition.js +1 -44
- package/dist-cjs/engine/lww-element-set-component-definition.d.ts +3 -5
- package/dist-cjs/engine/lww-element-set-component-definition.js +36 -73
- package/dist-cjs/index.d.ts +3 -2
- package/dist-cjs/index.js +4 -2
- package/dist-cjs/runtime/helpers/index.d.ts +1 -0
- package/dist-cjs/runtime/helpers/index.js +1 -0
- package/dist-cjs/runtime/helpers/tree.d.ts +6 -0
- package/dist-cjs/runtime/helpers/tree.js +3 -2
- package/dist-cjs/runtime/helpers/vectors.d.ts +1 -0
- package/dist-cjs/runtime/helpers/vectors.js +39 -0
- package/dist-cjs/runtime/initialization/index.d.ts +7 -0
- package/dist-cjs/runtime/initialization/index.js +7 -1
- package/dist-cjs/serialization/crdt/index.d.ts +0 -1
- package/dist-cjs/serialization/crdt/index.js +0 -1
- package/dist-cjs/serialization/crdt/network/utils.d.ts +9 -0
- package/dist-cjs/serialization/crdt/network/utils.js +67 -0
- package/dist-cjs/serialization/crdt/types.d.ts +3 -25
- package/dist-cjs/serialization/crdt/types.js +1 -3
- package/dist-cjs/systems/crdt/index.d.ts +1 -0
- package/dist-cjs/systems/crdt/index.js +169 -55
- package/dist-cjs/systems/events.d.ts +65 -0
- package/dist-cjs/systems/events.js +70 -8
- package/dist-cjs/systems/physics-force.d.ts +1 -0
- package/dist-cjs/systems/physics-force.js +167 -0
- package/dist-cjs/systems/physics-impulse.d.ts +12 -0
- package/dist-cjs/systems/physics-impulse.js +112 -0
- package/dist-cjs/systems/physics.d.ts +77 -0
- package/dist-cjs/systems/physics.js +23 -0
- package/package.json +3 -2
- package/dist/components/manual/CreatedBy.d.ts +0 -9
- package/dist/components/manual/CreatedBy.js +0 -8
- package/dist/serialization/crdt/authoritativePutComponent.d.ts +0 -15
- package/dist/serialization/crdt/authoritativePutComponent.js +0 -47
- package/dist-cjs/components/manual/CreatedBy.d.ts +0 -9
- package/dist-cjs/components/manual/CreatedBy.js +0 -10
- package/dist-cjs/serialization/crdt/authoritativePutComponent.d.ts +0 -15
- package/dist-cjs/serialization/crdt/authoritativePutComponent.js +0 -50
package/dist-cjs/components/generated/pb/decentraland/sdk/components/pointer_events.gen.d.ts
CHANGED
|
@@ -1,5 +1,5 @@
|
|
|
1
1
|
import _m0 from "protobufjs/minimal";
|
|
2
|
-
import { InputAction, PointerEventType } from "./common/input_action.gen";
|
|
2
|
+
import { InputAction, InteractionType, PointerEventType } from "./common/input_action.gen";
|
|
3
3
|
/**
|
|
4
4
|
* PointerEvents adds configurable pointer-based interactions to the attached Entity.
|
|
5
5
|
*
|
|
@@ -61,6 +61,8 @@ export interface PBPointerEvents_Info {
|
|
|
61
61
|
showHighlight?: boolean | undefined;
|
|
62
62
|
/** range of interaction from the avatar's position (default 0) */
|
|
63
63
|
maxPlayerDistance?: number | undefined;
|
|
64
|
+
/** resolution order when multiple events overlap, higher wins (default 0) */
|
|
65
|
+
priority?: number | undefined;
|
|
64
66
|
}
|
|
65
67
|
/**
|
|
66
68
|
* @public
|
|
@@ -70,6 +72,8 @@ export interface PBPointerEvents_Entry {
|
|
|
70
72
|
eventType: PointerEventType;
|
|
71
73
|
/** additional configuration for this detection */
|
|
72
74
|
eventInfo: PBPointerEvents_Info | undefined;
|
|
75
|
+
/** the type of interaction source (default 0 == CURSOR) */
|
|
76
|
+
interactionType?: InteractionType | undefined;
|
|
73
77
|
}
|
|
74
78
|
/**
|
|
75
79
|
* @public
|
|
@@ -53,6 +53,7 @@ function createBasePBPointerEvents_Info() {
|
|
|
53
53
|
showFeedback: undefined,
|
|
54
54
|
showHighlight: undefined,
|
|
55
55
|
maxPlayerDistance: undefined,
|
|
56
|
+
priority: undefined,
|
|
56
57
|
};
|
|
57
58
|
}
|
|
58
59
|
/**
|
|
@@ -79,6 +80,9 @@ var PBPointerEvents_Info;
|
|
|
79
80
|
if (message.maxPlayerDistance !== undefined) {
|
|
80
81
|
writer.uint32(53).float(message.maxPlayerDistance);
|
|
81
82
|
}
|
|
83
|
+
if (message.priority !== undefined) {
|
|
84
|
+
writer.uint32(56).uint32(message.priority);
|
|
85
|
+
}
|
|
82
86
|
return writer;
|
|
83
87
|
}
|
|
84
88
|
PBPointerEvents_Info.encode = encode;
|
|
@@ -125,6 +129,12 @@ var PBPointerEvents_Info;
|
|
|
125
129
|
}
|
|
126
130
|
message.maxPlayerDistance = reader.float();
|
|
127
131
|
continue;
|
|
132
|
+
case 7:
|
|
133
|
+
if (tag !== 56) {
|
|
134
|
+
break;
|
|
135
|
+
}
|
|
136
|
+
message.priority = reader.uint32();
|
|
137
|
+
continue;
|
|
128
138
|
}
|
|
129
139
|
if ((tag & 7) === 4 || tag === 0) {
|
|
130
140
|
break;
|
|
@@ -136,7 +146,7 @@ var PBPointerEvents_Info;
|
|
|
136
146
|
PBPointerEvents_Info.decode = decode;
|
|
137
147
|
})(PBPointerEvents_Info = exports.PBPointerEvents_Info || (exports.PBPointerEvents_Info = {}));
|
|
138
148
|
function createBasePBPointerEvents_Entry() {
|
|
139
|
-
return { eventType: 0, eventInfo: undefined };
|
|
149
|
+
return { eventType: 0, eventInfo: undefined, interactionType: undefined };
|
|
140
150
|
}
|
|
141
151
|
/**
|
|
142
152
|
* @public
|
|
@@ -150,6 +160,9 @@ var PBPointerEvents_Entry;
|
|
|
150
160
|
if (message.eventInfo !== undefined) {
|
|
151
161
|
PBPointerEvents_Info.encode(message.eventInfo, writer.uint32(18).fork()).ldelim();
|
|
152
162
|
}
|
|
163
|
+
if (message.interactionType !== undefined) {
|
|
164
|
+
writer.uint32(24).int32(message.interactionType);
|
|
165
|
+
}
|
|
153
166
|
return writer;
|
|
154
167
|
}
|
|
155
168
|
PBPointerEvents_Entry.encode = encode;
|
|
@@ -172,6 +185,12 @@ var PBPointerEvents_Entry;
|
|
|
172
185
|
}
|
|
173
186
|
message.eventInfo = PBPointerEvents_Info.decode(reader, reader.uint32());
|
|
174
187
|
continue;
|
|
188
|
+
case 3:
|
|
189
|
+
if (tag !== 24) {
|
|
190
|
+
break;
|
|
191
|
+
}
|
|
192
|
+
message.interactionType = reader.int32();
|
|
193
|
+
continue;
|
|
175
194
|
}
|
|
176
195
|
if ((tag & 7) === 4 || tag === 0) {
|
|
177
196
|
break;
|
|
@@ -1,5 +1,6 @@
|
|
|
1
1
|
export type { Position as PBPosition, Vector2 as PBVector2, Vector3 as PBVector3, Quaternion as PBQuaternion } from './pb/decentraland/common/vectors.gen';
|
|
2
2
|
export type { Color3 as PBColor3, Color4 as PBColor4 } from './pb/decentraland/common/colors.gen';
|
|
3
|
+
export { ColorRange } from './pb/decentraland/common/colors.gen';
|
|
3
4
|
export * from './pb/decentraland/sdk/components/common/camera_transition.gen';
|
|
4
5
|
export * from './pb/decentraland/sdk/components/common/camera_type.gen';
|
|
5
6
|
export * from './pb/decentraland/sdk/components/common/input_action.gen';
|
|
@@ -8,4 +9,5 @@ export * from './pb/decentraland/sdk/components/common/media_state.gen';
|
|
|
8
9
|
export * from './pb/decentraland/sdk/components/common/raycast_hit.gen';
|
|
9
10
|
export * from './pb/decentraland/sdk/components/common/texts.gen';
|
|
10
11
|
export * from './pb/decentraland/common/border_rect.gen';
|
|
12
|
+
export * from './pb/decentraland/common/floats.gen';
|
|
11
13
|
export * from './pb/decentraland/common/texture.gen';
|
|
@@ -14,6 +14,9 @@ var __exportStar = (this && this.__exportStar) || function(m, exports) {
|
|
|
14
14
|
for (var p in m) if (p !== "default" && !Object.prototype.hasOwnProperty.call(exports, p)) __createBinding(exports, m, p);
|
|
15
15
|
};
|
|
16
16
|
Object.defineProperty(exports, "__esModule", { value: true });
|
|
17
|
+
exports.ColorRange = void 0;
|
|
18
|
+
var colors_gen_1 = require("./pb/decentraland/common/colors.gen");
|
|
19
|
+
Object.defineProperty(exports, "ColorRange", { enumerable: true, get: function () { return colors_gen_1.ColorRange; } });
|
|
17
20
|
__exportStar(require("./pb/decentraland/sdk/components/common/camera_transition.gen"), exports);
|
|
18
21
|
// export { PbCameraTransition }
|
|
19
22
|
__exportStar(require("./pb/decentraland/sdk/components/common/camera_type.gen"), exports);
|
|
@@ -30,5 +33,7 @@ __exportStar(require("./pb/decentraland/sdk/components/common/texts.gen"), expor
|
|
|
30
33
|
// export { PbTexts }
|
|
31
34
|
__exportStar(require("./pb/decentraland/common/border_rect.gen"), exports);
|
|
32
35
|
// export { PbBorderRect }
|
|
36
|
+
__exportStar(require("./pb/decentraland/common/floats.gen"), exports);
|
|
37
|
+
// export { PbFloats }
|
|
33
38
|
__exportStar(require("./pb/decentraland/common/texture.gen"), exports);
|
|
34
39
|
// export { PbTexture }
|
|
@@ -18,8 +18,8 @@ import { VirtualCameraComponentDefinitionExtended } from './extended/VirtualCame
|
|
|
18
18
|
import { InputModifierComponentDefinitionExtended } from './extended/InputModifier';
|
|
19
19
|
import { LightSourceComponentDefinitionExtended } from './extended/LightSource';
|
|
20
20
|
import { TriggerAreaComponentDefinitionExtended } from './extended/TriggerArea';
|
|
21
|
+
import { ParticleSystemComponentDefinitionExtended } from './extended/ParticleSystem';
|
|
21
22
|
import { TagsComponentDefinitionExtended } from './manual/Tags';
|
|
22
|
-
import { ICreatedByType } from './manual/CreatedBy';
|
|
23
23
|
export * from './generated/index.gen';
|
|
24
24
|
export type { GrowOnlyValueSetComponentDefinition, LastWriteWinElementSetComponentDefinition, LwwComponentGetter, GSetComponentGetter };
|
|
25
25
|
export declare const Transform: LwwComponentGetter<TransformComponentExtended>;
|
|
@@ -34,6 +34,7 @@ export declare const VirtualCamera: LwwComponentGetter<VirtualCameraComponentDef
|
|
|
34
34
|
export declare const InputModifier: LwwComponentGetter<InputModifierComponentDefinitionExtended>;
|
|
35
35
|
export declare const LightSource: LwwComponentGetter<LightSourceComponentDefinitionExtended>;
|
|
36
36
|
export declare const TriggerArea: LwwComponentGetter<TriggerAreaComponentDefinitionExtended>;
|
|
37
|
+
export declare const ParticleSystem: LwwComponentGetter<ParticleSystemComponentDefinitionExtended>;
|
|
37
38
|
/**
|
|
38
39
|
* @alpha
|
|
39
40
|
*/
|
|
@@ -51,8 +52,4 @@ export declare const NetworkEntity: (engine: Pick<IEngine, 'defineComponent'>) =
|
|
|
51
52
|
* @alpha
|
|
52
53
|
*/
|
|
53
54
|
export declare const NetworkParent: (engine: Pick<IEngine, 'defineComponent'>) => LastWriteWinElementSetComponentDefinition<INetowrkParentType>;
|
|
54
|
-
/**
|
|
55
|
-
* @public
|
|
56
|
-
*/
|
|
57
|
-
export declare const CreatedBy: (engine: Pick<IEngine, 'defineComponent'>) => LastWriteWinElementSetComponentDefinition<ICreatedByType>;
|
|
58
55
|
export { MediaState };
|
|
@@ -17,7 +17,7 @@ var __importDefault = (this && this.__importDefault) || function (mod) {
|
|
|
17
17
|
return (mod && mod.__esModule) ? mod : { "default": mod };
|
|
18
18
|
};
|
|
19
19
|
Object.defineProperty(exports, "__esModule", { value: true });
|
|
20
|
-
exports.MediaState = exports.
|
|
20
|
+
exports.MediaState = exports.NetworkParent = exports.NetworkEntity = exports.SyncComponents = exports.Tags = exports.Name = exports.ParticleSystem = exports.TriggerArea = exports.LightSource = exports.InputModifier = exports.VirtualCamera = exports.Tween = exports.MeshCollider = exports.MeshRenderer = exports.AudioStream = exports.AudioSource = exports.Animator = exports.Material = exports.Transform = void 0;
|
|
21
21
|
const Animator_1 = require("./extended/Animator");
|
|
22
22
|
const AudioSource_1 = require("./extended/AudioSource");
|
|
23
23
|
const Material_1 = require("./extended/Material");
|
|
@@ -36,8 +36,8 @@ const VirtualCamera_1 = require("./extended/VirtualCamera");
|
|
|
36
36
|
const InputModifier_1 = require("./extended/InputModifier");
|
|
37
37
|
const LightSource_1 = require("./extended/LightSource");
|
|
38
38
|
const TriggerArea_1 = require("./extended/TriggerArea");
|
|
39
|
+
const ParticleSystem_1 = require("./extended/ParticleSystem");
|
|
39
40
|
const Tags_1 = __importDefault(require("./manual/Tags"));
|
|
40
|
-
const CreatedBy_1 = __importDefault(require("./manual/CreatedBy"));
|
|
41
41
|
__exportStar(require("./generated/index.gen"), exports);
|
|
42
42
|
/* @__PURE__ */
|
|
43
43
|
const Transform = (engine) => (0, Transform_1.defineTransformComponent)(engine);
|
|
@@ -75,6 +75,9 @@ exports.LightSource = LightSource;
|
|
|
75
75
|
/* @__PURE__ */
|
|
76
76
|
const TriggerArea = (engine) => (0, TriggerArea_1.defineTriggerAreaComponent)(engine);
|
|
77
77
|
exports.TriggerArea = TriggerArea;
|
|
78
|
+
/* @__PURE__ */
|
|
79
|
+
const ParticleSystem = (engine) => (0, ParticleSystem_1.defineParticleSystemComponent)(engine);
|
|
80
|
+
exports.ParticleSystem = ParticleSystem;
|
|
78
81
|
/**
|
|
79
82
|
* @alpha
|
|
80
83
|
*/
|
|
@@ -93,15 +96,12 @@ exports.SyncComponents = SyncComponents;
|
|
|
93
96
|
/**
|
|
94
97
|
* @alpha
|
|
95
98
|
*/
|
|
99
|
+
/* @__PURE__ */
|
|
96
100
|
const NetworkEntity = (engine) => (0, NetworkEntity_1.default)(engine);
|
|
97
101
|
exports.NetworkEntity = NetworkEntity;
|
|
98
102
|
/**
|
|
99
103
|
* @alpha
|
|
100
104
|
*/
|
|
105
|
+
/* @__PURE__ */
|
|
101
106
|
const NetworkParent = (engine) => (0, NetworkParent_1.default)(engine);
|
|
102
107
|
exports.NetworkParent = NetworkParent;
|
|
103
|
-
/**
|
|
104
|
-
* @public
|
|
105
|
-
*/
|
|
106
|
-
const CreatedBy = (engine) => (0, CreatedBy_1.default)(engine);
|
|
107
|
-
exports.CreatedBy = CreatedBy;
|
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
import { LastWriteWinElementSetComponentDefinition, IEngine } from '../../engine';
|
|
2
2
|
import { Entity } from '../../engine/entity';
|
|
3
|
-
import type {
|
|
3
|
+
import type { Vector3Type } from '../../schemas/custom/Vector3';
|
|
4
4
|
/**
|
|
5
5
|
* @public
|
|
6
6
|
*/
|
|
@@ -11,11 +11,19 @@ export type TransformComponent = LastWriteWinElementSetComponentDefinition<Trans
|
|
|
11
11
|
export interface TransformComponentExtended extends TransformComponent {
|
|
12
12
|
create(entity: Entity, val?: TransformTypeWithOptionals): TransformType;
|
|
13
13
|
createOrReplace(entity: Entity, val?: TransformTypeWithOptionals): TransformType;
|
|
14
|
+
/**
|
|
15
|
+
* Transforms a direction vector from an entity's local coordinate space
|
|
16
|
+
* to world space, accounting for the full parent hierarchy.
|
|
17
|
+
*
|
|
18
|
+
* This applies only rotation (not translation or scale) — suitable for
|
|
19
|
+
* direction vectors like force/impulse directions.
|
|
20
|
+
*
|
|
21
|
+
* @param entity - The source entity whose local space defines the direction
|
|
22
|
+
* @param localDirection - Direction vector in the entity's local coordinates
|
|
23
|
+
* @returns The direction vector in world coordinates
|
|
24
|
+
*/
|
|
25
|
+
localToWorldDirection(entity: Entity, localDirection: Vector3Type): Vector3Type;
|
|
14
26
|
}
|
|
15
|
-
/**
|
|
16
|
-
* @public
|
|
17
|
-
*/
|
|
18
|
-
export declare const COMPONENT_ID = 1;
|
|
19
27
|
/**
|
|
20
28
|
* @public
|
|
21
29
|
*/
|
|
@@ -38,10 +46,6 @@ export type TransformType = {
|
|
|
38
46
|
};
|
|
39
47
|
parent?: Entity;
|
|
40
48
|
};
|
|
41
|
-
/** @public */
|
|
42
|
-
export declare const TRANSFORM_LENGTH = 44;
|
|
43
|
-
/** @public */
|
|
44
|
-
export declare const TransformSchema: ISchema<TransformType>;
|
|
45
49
|
/**
|
|
46
50
|
* @public
|
|
47
51
|
*/
|
|
@@ -1,13 +1,40 @@
|
|
|
1
1
|
"use strict";
|
|
2
|
+
var __createBinding = (this && this.__createBinding) || (Object.create ? (function(o, m, k, k2) {
|
|
3
|
+
if (k2 === undefined) k2 = k;
|
|
4
|
+
var desc = Object.getOwnPropertyDescriptor(m, k);
|
|
5
|
+
if (!desc || ("get" in desc ? !m.__esModule : desc.writable || desc.configurable)) {
|
|
6
|
+
desc = { enumerable: true, get: function() { return m[k]; } };
|
|
7
|
+
}
|
|
8
|
+
Object.defineProperty(o, k2, desc);
|
|
9
|
+
}) : (function(o, m, k, k2) {
|
|
10
|
+
if (k2 === undefined) k2 = k;
|
|
11
|
+
o[k2] = m[k];
|
|
12
|
+
}));
|
|
13
|
+
var __setModuleDefault = (this && this.__setModuleDefault) || (Object.create ? (function(o, v) {
|
|
14
|
+
Object.defineProperty(o, "default", { enumerable: true, value: v });
|
|
15
|
+
}) : function(o, v) {
|
|
16
|
+
o["default"] = v;
|
|
17
|
+
});
|
|
18
|
+
var __importStar = (this && this.__importStar) || function (mod) {
|
|
19
|
+
if (mod && mod.__esModule) return mod;
|
|
20
|
+
var result = {};
|
|
21
|
+
if (mod != null) for (var k in mod) if (k !== "default" && Object.prototype.hasOwnProperty.call(mod, k)) __createBinding(result, mod, k);
|
|
22
|
+
__setModuleDefault(result, mod);
|
|
23
|
+
return result;
|
|
24
|
+
};
|
|
2
25
|
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
26
|
exports.defineTransformComponent = exports.TransformSchema = exports.TRANSFORM_LENGTH = exports.COMPONENT_ID = void 0;
|
|
27
|
+
// Use import * to safely handle circular dependency (tree.ts → components → Transform.ts → tree.ts).
|
|
28
|
+
// With import *, the namespace object's properties are resolved at access time (live bindings in ESM,
|
|
29
|
+
// getters via __importStar in CJS), so by the time methods are called all exports are available.
|
|
30
|
+
const treeHelpers = __importStar(require("../../runtime/helpers/tree"));
|
|
4
31
|
/**
|
|
5
|
-
* @
|
|
32
|
+
* @internal
|
|
6
33
|
*/
|
|
7
34
|
exports.COMPONENT_ID = 1;
|
|
8
|
-
/** @
|
|
35
|
+
/** @internal */
|
|
9
36
|
exports.TRANSFORM_LENGTH = 44;
|
|
10
|
-
/** @
|
|
37
|
+
/** @internal */
|
|
11
38
|
exports.TransformSchema = {
|
|
12
39
|
serialize(value, builder) {
|
|
13
40
|
const ptr = builder.incrementWriteOffset(exports.TRANSFORM_LENGTH);
|
|
@@ -104,6 +131,10 @@ function defineTransformComponent(engine) {
|
|
|
104
131
|
},
|
|
105
132
|
createOrReplace(entity, val) {
|
|
106
133
|
return transformDef.createOrReplace(entity, exports.TransformSchema.extend(val));
|
|
134
|
+
},
|
|
135
|
+
localToWorldDirection(entity, localDirection) {
|
|
136
|
+
const worldRotation = treeHelpers.getWorldRotation(engine, entity);
|
|
137
|
+
return treeHelpers.rotateVectorByQuaternion(localDirection, worldRotation);
|
|
107
138
|
}
|
|
108
139
|
};
|
|
109
140
|
}
|
|
@@ -12,7 +12,7 @@ export type { TagsComponentDefinitionExtended, TagsType } from './manual/Tags';
|
|
|
12
12
|
export type { ISyncComponents, ISyncComponentsType } from './manual/SyncComponents';
|
|
13
13
|
export type { INetowrkEntity, INetowrkEntityType } from './manual/NetworkEntity';
|
|
14
14
|
export type { INetowrkParent, INetowrkParentType } from './manual/NetworkParent';
|
|
15
|
-
export type { ICreatedBy, ICreatedByType } from './manual/CreatedBy';
|
|
16
15
|
export type { InputModifierHelper, InputModifierComponentDefinitionExtended } from './extended/InputModifier';
|
|
17
16
|
export type { LightSourceHelper, LightSourceComponentDefinitionExtended } from './extended/LightSource';
|
|
18
17
|
export type { TriggerAreaComponentDefinitionExtended } from './extended/TriggerArea';
|
|
18
|
+
export type { ParticleSystemHelper, ParticleSystemComponentDefinitionExtended, ParticleSystemBlendMode, ParticleSystemPlaybackState } from './extended/ParticleSystem';
|
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
import { ISchema } from '../schemas';
|
|
2
2
|
import { ByteBuffer } from '../serialization/ByteBuffer';
|
|
3
|
-
import { CrdtMessageBody, DeleteComponentMessageBody,
|
|
3
|
+
import { CrdtMessageBody, DeleteComponentMessageBody, PutComponentMessageBody } from '../serialization/crdt';
|
|
4
4
|
import { Entity } from './entity';
|
|
5
5
|
import { DeepReadonly, DeepReadonlySet } from './readonly';
|
|
6
6
|
/**
|
|
@@ -70,58 +70,7 @@ export interface BaseComponent<T> {
|
|
|
70
70
|
* If the value is undefined, the component was deleted.
|
|
71
71
|
*/
|
|
72
72
|
onChange(entity: Entity, cb: (value: T | undefined) => void): void;
|
|
73
|
-
/**
|
|
74
|
-
* @public
|
|
75
|
-
*
|
|
76
|
-
*/
|
|
77
|
-
validateBeforeChange(entity: Entity, cb: ValidateCallback<T>): void;
|
|
78
|
-
validateBeforeChange(cb: ValidateCallback<T>): void;
|
|
79
|
-
/**
|
|
80
|
-
* Get the CRDT state for an entity (serialized data and timestamp)
|
|
81
|
-
* @param entity - Entity to get the CRDT state for
|
|
82
|
-
* @returns Object with serialized data and timestamp, or null if entity doesn't have the component
|
|
83
|
-
* @public
|
|
84
|
-
*/
|
|
85
|
-
getCrdtState(entity: Entity): {
|
|
86
|
-
data: Uint8Array;
|
|
87
|
-
timestamp: number;
|
|
88
|
-
} | null;
|
|
89
|
-
}
|
|
90
|
-
/**
|
|
91
|
-
* Internal component interface that exposes all internal methods for SDK use
|
|
92
|
-
* This is not exposed to users, only for internal SDK operations
|
|
93
|
-
*/
|
|
94
|
-
export interface InternalBaseComponent<T> extends BaseComponent<T> {
|
|
95
|
-
/**
|
|
96
|
-
* @public
|
|
97
|
-
* Dry run update to check if a CRDT message would be accepted without actually applying it
|
|
98
|
-
*/
|
|
99
|
-
__dry_run_updateFromCrdt(body: CrdtMessageBody): ProcessMessageResultType;
|
|
100
|
-
/**
|
|
101
|
-
* @public
|
|
102
|
-
* Get the iterator to every entity has the component
|
|
103
|
-
*/
|
|
104
|
-
iterator(): Iterable<[Entity, any]>;
|
|
105
|
-
/**
|
|
106
|
-
* @public
|
|
107
|
-
*/
|
|
108
|
-
dirtyIterator(): Iterable<Entity>;
|
|
109
|
-
/**
|
|
110
|
-
* @public
|
|
111
|
-
*/
|
|
112
|
-
__onChangeCallbacks(entity: Entity, value: T): void;
|
|
113
|
-
/**
|
|
114
|
-
* @public
|
|
115
|
-
*/
|
|
116
|
-
__run_validateBeforeChange(entity: Entity, newValue: T | undefined, senderAddress: string, createdBy: string): boolean;
|
|
117
73
|
}
|
|
118
|
-
export type ValidateCallback<T> = (value: {
|
|
119
|
-
entity: Entity;
|
|
120
|
-
currentValue: T | undefined;
|
|
121
|
-
newValue: T | undefined;
|
|
122
|
-
senderAddress: string;
|
|
123
|
-
createdBy: string;
|
|
124
|
-
}) => boolean;
|
|
125
74
|
/**
|
|
126
75
|
* @public
|
|
127
76
|
*/
|
|
@@ -5,7 +5,6 @@ const ByteBuffer_1 = require("../serialization/ByteBuffer");
|
|
|
5
5
|
const crdt_1 = require("../serialization/crdt");
|
|
6
6
|
const invariant_1 = require("../runtime/invariant");
|
|
7
7
|
const emptyReadonlySet = freezeSet(new Set());
|
|
8
|
-
const __GLOBAL_ENTITY = '__GLOBAL_ENTITY';
|
|
9
8
|
function frozenError() {
|
|
10
9
|
throw new Error('The set is frozen');
|
|
11
10
|
}
|
|
@@ -26,7 +25,6 @@ function createValueSetComponentDefinitionFromSchema(componentName, componentId,
|
|
|
26
25
|
const dirtyIterator = new Set();
|
|
27
26
|
const queuedCommands = [];
|
|
28
27
|
const onChangeCallbacks = new Map();
|
|
29
|
-
const validateCallbacks = new Map();
|
|
30
28
|
// only sort the array if the latest (N) element has a timestamp <= N-1
|
|
31
29
|
function shouldSort(row) {
|
|
32
30
|
const len = row.raw.length;
|
|
@@ -85,11 +83,8 @@ function createValueSetComponentDefinitionFromSchema(componentName, componentId,
|
|
|
85
83
|
has(entity) {
|
|
86
84
|
return data.has(entity);
|
|
87
85
|
},
|
|
88
|
-
entityDeleted(entity
|
|
86
|
+
entityDeleted(entity) {
|
|
89
87
|
data.delete(entity);
|
|
90
|
-
if (markAsDirty) {
|
|
91
|
-
// For grow-only sets, we don't need to mark as dirty since deletion doesn't generate CRDT messages
|
|
92
|
-
}
|
|
93
88
|
},
|
|
94
89
|
get(entity) {
|
|
95
90
|
const values = data.get(entity);
|
|
@@ -160,44 +155,6 @@ function createValueSetComponentDefinitionFromSchema(componentName, componentId,
|
|
|
160
155
|
for (const cb of cbs) {
|
|
161
156
|
cb(value);
|
|
162
157
|
}
|
|
163
|
-
},
|
|
164
|
-
__dry_run_updateFromCrdt(_body) {
|
|
165
|
-
return crdt_1.ProcessMessageResultType.StateUpdatedData;
|
|
166
|
-
},
|
|
167
|
-
validateBeforeChange(entityOrCb, cb) {
|
|
168
|
-
if (arguments.length === 1) {
|
|
169
|
-
// Second overload: just callback (global validation)
|
|
170
|
-
validateCallbacks.set(__GLOBAL_ENTITY, entityOrCb);
|
|
171
|
-
}
|
|
172
|
-
else {
|
|
173
|
-
if (cb) {
|
|
174
|
-
validateCallbacks.set(entityOrCb, cb);
|
|
175
|
-
}
|
|
176
|
-
}
|
|
177
|
-
},
|
|
178
|
-
__run_validateBeforeChange(entity, newValue, senderAddress, createdBy) {
|
|
179
|
-
const cb = entity && validateCallbacks.get(entity);
|
|
180
|
-
const globalCb = validateCallbacks.get(__GLOBAL_ENTITY);
|
|
181
|
-
const currentValue = [...this.get(entity).values()];
|
|
182
|
-
const value = { entity, currentValue: currentValue, newValue, senderAddress, createdBy };
|
|
183
|
-
const globalResult = globalCb?.(value) ?? true;
|
|
184
|
-
const entityResult = (globalResult && cb?.(value)) ?? true;
|
|
185
|
-
return globalResult && entityResult;
|
|
186
|
-
},
|
|
187
|
-
getCrdtState(entity) {
|
|
188
|
-
const row = data.get(entity);
|
|
189
|
-
if (!row || row.raw.length === 0) {
|
|
190
|
-
return null;
|
|
191
|
-
}
|
|
192
|
-
// For GrowOnlySet, we need to return the complete CRDT messages for all values
|
|
193
|
-
// This is complex because GrowOnlySet uses APPEND messages, not a single PUT
|
|
194
|
-
// For now, return null to indicate this component type doesn't support simple corrections
|
|
195
|
-
return null;
|
|
196
|
-
},
|
|
197
|
-
__forceUpdateFromCrdt(_msg) {
|
|
198
|
-
// GrowOnlySet doesn't support authoritative corrections in the same way as LWW
|
|
199
|
-
// since it uses APPEND_VALUE messages instead of PUT_COMPONENT messages
|
|
200
|
-
return [null, undefined];
|
|
201
158
|
}
|
|
202
159
|
};
|
|
203
160
|
return ret;
|
|
@@ -1,10 +1,8 @@
|
|
|
1
1
|
import { ISchema } from '../schemas';
|
|
2
2
|
import { ByteBuffer } from '../serialization/ByteBuffer';
|
|
3
|
-
import { PutComponentMessageBody, DeleteComponentMessageBody,
|
|
3
|
+
import { PutComponentMessageBody, DeleteComponentMessageBody, CrdtMessageBody } from '../serialization/crdt';
|
|
4
4
|
import { Entity } from './entity';
|
|
5
5
|
export declare function incrementTimestamp(entity: Entity, timestamps: Map<Entity, number>): number;
|
|
6
6
|
export declare function createDumpLwwFunctionFromCrdt(componentId: number, timestamps: Map<Entity, number>, schema: Pick<ISchema<any>, 'serialize' | 'deserialize'>, data: Map<Entity, unknown>): (buffer: ByteBuffer, filterEntity?: ((entity: Entity) => boolean) | undefined) => void;
|
|
7
|
-
export declare function
|
|
8
|
-
export declare function
|
|
9
|
-
export declare function createUpdateLwwFromCrdt(componentId: number, timestamps: Map<Entity, number>, schema: Pick<ISchema<any>, 'serialize' | 'deserialize'>, data: Map<Entity, unknown>): (msg: CrdtMessageBody) => [null | PutComponentMessageBody | DeleteComponentMessageBody, any];
|
|
10
|
-
export declare function createGetCrdtMessagesForLww(componentId: number, timestamps: Map<Entity, number>, dirtyIterator: Set<Entity>, schema: Pick<ISchema<any>, 'serialize'>, data: Map<Entity, unknown>): () => Generator<PutComponentMessageBody | DeleteComponentMessageBody, void, unknown>;
|
|
7
|
+
export declare function createUpdateLwwFromCrdt(componentId: number, timestamps: Map<Entity, number>, schema: Pick<ISchema<any>, 'serialize' | 'deserialize'>, data: Map<Entity, unknown>, lastSentData: Map<Entity, Uint8Array>): (msg: CrdtMessageBody) => [null | PutComponentMessageBody | DeleteComponentMessageBody, any];
|
|
8
|
+
export declare function createGetCrdtMessagesForLww(componentId: number, timestamps: Map<Entity, number>, dirtyIterator: Set<Entity>, schema: Pick<ISchema<any>, 'serialize'>, data: Map<Entity, unknown>, lastSentData: Map<Entity, Uint8Array>): () => Generator<PutComponentMessageBody | DeleteComponentMessageBody, void, unknown>;
|