@dcl/ecs 7.22.4-24525731607.commit-cda77a9 → 7.22.5-24776890516.commit-b10e9ab
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/generated/component-names.gen.js +0 -3
- package/dist/components/generated/global.gen.d.ts +0 -6
- package/dist/components/generated/global.gen.js +0 -3
- package/dist/components/generated/index.gen.d.ts +0 -12
- package/dist/components/generated/index.gen.js +0 -15
- package/dist/components/generated/pb/decentraland/common/colors.gen.d.ts +0 -15
- package/dist/components/generated/pb/decentraland/common/colors.gen.js +0 -47
- package/dist/components/generated/pb/decentraland/sdk/components/avatar_shape.gen.d.ts +0 -8
- package/dist/components/generated/pb/decentraland/sdk/components/avatar_shape.gen.js +0 -9
- package/dist/components/generated/pb/decentraland/sdk/components/common/input_action.gen.d.ts +2 -12
- package/dist/components/generated/pb/decentraland/sdk/components/common/input_action.gen.js +0 -11
- package/dist/components/generated/pb/decentraland/sdk/components/pointer_events.gen.d.ts +1 -5
- package/dist/components/generated/pb/decentraland/sdk/components/pointer_events.gen.js +1 -20
- package/dist/components/generated/pb/decentraland/sdk/components/virtual_camera.gen.d.ts +0 -3
- package/dist/components/generated/pb/decentraland/sdk/components/virtual_camera.gen.js +1 -10
- package/dist/components/generated/types.gen.d.ts +0 -2
- package/dist/components/generated/types.gen.js +0 -3
- package/dist/components/index.d.ts +5 -6
- package/dist/components/index.js +5 -8
- package/dist/components/manual/CreatedBy.d.ts +9 -0
- package/dist/components/manual/CreatedBy.js +8 -0
- package/dist/components/manual/Transform.d.ts +9 -13
- package/dist/components/manual/Transform.js +3 -11
- package/dist/components/types.d.ts +1 -2
- package/dist/engine/component.d.ts +52 -1
- package/dist/engine/grow-only-value-set-component-definition.js +45 -2
- package/dist/engine/lww-element-set-component-definition.d.ts +5 -3
- package/dist/engine/lww-element-set-component-definition.js +70 -35
- package/dist/index.d.ts +2 -4
- package/dist/index.js +1 -4
- package/dist/runtime/helpers/index.d.ts +0 -1
- package/dist/runtime/helpers/index.js +0 -1
- package/dist/runtime/helpers/tree.d.ts +0 -6
- package/dist/runtime/helpers/tree.js +2 -2
- package/dist/runtime/initialization/index.d.ts +0 -7
- package/dist/runtime/initialization/index.js +0 -6
- package/dist/serialization/crdt/authoritativePutComponent.d.ts +15 -0
- package/dist/serialization/crdt/authoritativePutComponent.js +47 -0
- package/dist/serialization/crdt/index.d.ts +1 -0
- package/dist/serialization/crdt/index.js +1 -0
- package/dist/serialization/crdt/types.d.ts +25 -3
- package/dist/serialization/crdt/types.js +3 -1
- package/dist/systems/crdt/index.d.ts +0 -1
- package/dist/systems/crdt/index.js +55 -146
- package/dist/systems/events.d.ts +0 -65
- package/dist/systems/events.js +8 -70
- package/dist-cjs/components/generated/component-names.gen.js +0 -3
- package/dist-cjs/components/generated/global.gen.d.ts +0 -6
- package/dist-cjs/components/generated/global.gen.js +1 -5
- package/dist-cjs/components/generated/index.gen.d.ts +0 -12
- package/dist-cjs/components/generated/index.gen.js +2 -20
- package/dist-cjs/components/generated/pb/decentraland/common/colors.gen.d.ts +0 -15
- package/dist-cjs/components/generated/pb/decentraland/common/colors.gen.js +1 -48
- package/dist-cjs/components/generated/pb/decentraland/sdk/components/avatar_shape.gen.d.ts +0 -8
- package/dist-cjs/components/generated/pb/decentraland/sdk/components/avatar_shape.gen.js +1 -10
- package/dist-cjs/components/generated/pb/decentraland/sdk/components/common/input_action.gen.d.ts +2 -12
- package/dist-cjs/components/generated/pb/decentraland/sdk/components/common/input_action.gen.js +1 -12
- package/dist-cjs/components/generated/pb/decentraland/sdk/components/pointer_events.gen.d.ts +1 -5
- package/dist-cjs/components/generated/pb/decentraland/sdk/components/pointer_events.gen.js +1 -20
- package/dist-cjs/components/generated/pb/decentraland/sdk/components/virtual_camera.gen.d.ts +0 -3
- package/dist-cjs/components/generated/pb/decentraland/sdk/components/virtual_camera.gen.js +1 -10
- package/dist-cjs/components/generated/types.gen.d.ts +0 -2
- package/dist-cjs/components/generated/types.gen.js +0 -5
- package/dist-cjs/components/index.d.ts +5 -6
- package/dist-cjs/components/index.js +7 -11
- package/dist-cjs/components/manual/CreatedBy.d.ts +9 -0
- package/dist-cjs/components/manual/CreatedBy.js +10 -0
- package/dist-cjs/components/manual/Transform.d.ts +9 -13
- package/dist-cjs/components/manual/Transform.js +3 -34
- package/dist-cjs/components/types.d.ts +1 -2
- package/dist-cjs/engine/component.d.ts +52 -1
- package/dist-cjs/engine/grow-only-value-set-component-definition.js +44 -1
- package/dist-cjs/engine/lww-element-set-component-definition.d.ts +5 -3
- package/dist-cjs/engine/lww-element-set-component-definition.js +73 -36
- package/dist-cjs/index.d.ts +2 -4
- package/dist-cjs/index.js +2 -5
- package/dist-cjs/runtime/helpers/index.d.ts +0 -1
- package/dist-cjs/runtime/helpers/index.js +0 -1
- package/dist-cjs/runtime/helpers/tree.d.ts +0 -6
- package/dist-cjs/runtime/helpers/tree.js +2 -3
- package/dist-cjs/runtime/initialization/index.d.ts +0 -7
- package/dist-cjs/runtime/initialization/index.js +1 -7
- package/dist-cjs/serialization/crdt/authoritativePutComponent.d.ts +15 -0
- package/dist-cjs/serialization/crdt/authoritativePutComponent.js +50 -0
- package/dist-cjs/serialization/crdt/index.d.ts +1 -0
- package/dist-cjs/serialization/crdt/index.js +1 -0
- package/dist-cjs/serialization/crdt/types.d.ts +25 -3
- package/dist-cjs/serialization/crdt/types.js +3 -1
- package/dist-cjs/systems/crdt/index.d.ts +0 -1
- package/dist-cjs/systems/crdt/index.js +55 -169
- package/dist-cjs/systems/events.d.ts +0 -65
- package/dist-cjs/systems/events.js +8 -70
- package/package.json +2 -3
- package/dist/components/extended/AudioAnalysis.d.ts +0 -55
- package/dist/components/extended/AudioAnalysis.js +0 -66
- package/dist/components/extended/ParticleSystem.d.ts +0 -24
- package/dist/components/extended/ParticleSystem.js +0 -23
- package/dist/components/generated/AudioAnalysis.gen.d.ts +0 -1
- package/dist/components/generated/AudioAnalysis.gen.js +0 -25
- package/dist/components/generated/AvatarLocomotionSettings.gen.d.ts +0 -1
- package/dist/components/generated/AvatarLocomotionSettings.gen.js +0 -25
- package/dist/components/generated/ParticleSystem.gen.d.ts +0 -1
- package/dist/components/generated/ParticleSystem.gen.js +0 -25
- package/dist/components/generated/pb/decentraland/common/floats.gen.d.ts +0 -16
- package/dist/components/generated/pb/decentraland/common/floats.gen.js +0 -50
- package/dist/components/generated/pb/decentraland/sdk/components/audio_analysis.gen.d.ts +0 -37
- package/dist/components/generated/pb/decentraland/sdk/components/audio_analysis.gen.js +0 -161
- package/dist/components/generated/pb/decentraland/sdk/components/avatar_locomotion_settings.gen.d.ts +0 -35
- package/dist/components/generated/pb/decentraland/sdk/components/avatar_locomotion_settings.gen.js +0 -123
- package/dist/components/generated/pb/decentraland/sdk/components/particle_system.gen.d.ts +0 -241
- package/dist/components/generated/pb/decentraland/sdk/components/particle_system.gen.js +0 -717
- package/dist/runtime/helpers/vectors.d.ts +0 -1
- package/dist/runtime/helpers/vectors.js +0 -36
- package/dist/serialization/crdt/network/utils.d.ts +0 -9
- package/dist/serialization/crdt/network/utils.js +0 -60
- package/dist/systems/physics-force.d.ts +0 -1
- package/dist/systems/physics-force.js +0 -140
- package/dist/systems/physics-impulse.d.ts +0 -12
- package/dist/systems/physics-impulse.js +0 -85
- package/dist/systems/physics.d.ts +0 -77
- package/dist/systems/physics.js +0 -18
- package/dist-cjs/components/extended/AudioAnalysis.d.ts +0 -55
- package/dist-cjs/components/extended/AudioAnalysis.js +0 -70
- package/dist-cjs/components/extended/ParticleSystem.d.ts +0 -24
- package/dist-cjs/components/extended/ParticleSystem.js +0 -28
- package/dist-cjs/components/generated/AudioAnalysis.gen.d.ts +0 -1
- package/dist-cjs/components/generated/AudioAnalysis.gen.js +0 -28
- package/dist-cjs/components/generated/AvatarLocomotionSettings.gen.d.ts +0 -1
- package/dist-cjs/components/generated/AvatarLocomotionSettings.gen.js +0 -28
- package/dist-cjs/components/generated/ParticleSystem.gen.d.ts +0 -1
- package/dist-cjs/components/generated/ParticleSystem.gen.js +0 -28
- package/dist-cjs/components/generated/pb/decentraland/common/floats.gen.d.ts +0 -16
- package/dist-cjs/components/generated/pb/decentraland/common/floats.gen.js +0 -56
- package/dist-cjs/components/generated/pb/decentraland/sdk/components/audio_analysis.gen.d.ts +0 -37
- package/dist-cjs/components/generated/pb/decentraland/sdk/components/audio_analysis.gen.js +0 -167
- package/dist-cjs/components/generated/pb/decentraland/sdk/components/avatar_locomotion_settings.gen.d.ts +0 -35
- package/dist-cjs/components/generated/pb/decentraland/sdk/components/avatar_locomotion_settings.gen.js +0 -129
- package/dist-cjs/components/generated/pb/decentraland/sdk/components/particle_system.gen.d.ts +0 -241
- package/dist-cjs/components/generated/pb/decentraland/sdk/components/particle_system.gen.js +0 -723
- package/dist-cjs/runtime/helpers/vectors.d.ts +0 -1
- package/dist-cjs/runtime/helpers/vectors.js +0 -39
- package/dist-cjs/serialization/crdt/network/utils.d.ts +0 -9
- package/dist-cjs/serialization/crdt/network/utils.js +0 -67
- package/dist-cjs/systems/physics-force.d.ts +0 -1
- package/dist-cjs/systems/physics-force.js +0 -167
- package/dist-cjs/systems/physics-impulse.d.ts +0 -12
- package/dist-cjs/systems/physics-impulse.js +0 -112
- package/dist-cjs/systems/physics.d.ts +0 -77
- package/dist-cjs/systems/physics.js +0 -23
|
@@ -2,8 +2,6 @@ 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 { AudioAnalysisComponentDefinitionExtended } from './extended/AudioAnalysis';
|
|
6
|
-
import type { AudioAnalysisView } from './extended/AudioAnalysis';
|
|
7
5
|
import { MaterialComponentDefinitionExtended } from './extended/Material';
|
|
8
6
|
import { MeshColliderComponentDefinitionExtended } from './extended/MeshCollider';
|
|
9
7
|
import { MeshRendererComponentDefinitionExtended } from './extended/MeshRenderer';
|
|
@@ -20,15 +18,14 @@ import { VirtualCameraComponentDefinitionExtended } from './extended/VirtualCame
|
|
|
20
18
|
import { InputModifierComponentDefinitionExtended } from './extended/InputModifier';
|
|
21
19
|
import { LightSourceComponentDefinitionExtended } from './extended/LightSource';
|
|
22
20
|
import { TriggerAreaComponentDefinitionExtended } from './extended/TriggerArea';
|
|
23
|
-
import { ParticleSystemComponentDefinitionExtended } from './extended/ParticleSystem';
|
|
24
21
|
import { TagsComponentDefinitionExtended } from './manual/Tags';
|
|
22
|
+
import { ICreatedByType } from './manual/CreatedBy';
|
|
25
23
|
export * from './generated/index.gen';
|
|
26
24
|
export type { GrowOnlyValueSetComponentDefinition, LastWriteWinElementSetComponentDefinition, LwwComponentGetter, GSetComponentGetter };
|
|
27
25
|
export declare const Transform: LwwComponentGetter<TransformComponentExtended>;
|
|
28
26
|
export declare const Material: LwwComponentGetter<MaterialComponentDefinitionExtended>;
|
|
29
27
|
export declare const Animator: LwwComponentGetter<AnimatorComponentDefinitionExtended>;
|
|
30
28
|
export declare const AudioSource: LwwComponentGetter<AudioSourceComponentDefinitionExtended>;
|
|
31
|
-
export declare const AudioAnalysis: LwwComponentGetter<AudioAnalysisComponentDefinitionExtended>;
|
|
32
29
|
export declare const AudioStream: (engine: Pick<IEngine, 'defineComponentFromSchema' | 'defineValueSetComponentFromSchema'>) => AudioStreamComponentDefinitionExtended;
|
|
33
30
|
export declare const MeshRenderer: LwwComponentGetter<MeshRendererComponentDefinitionExtended>;
|
|
34
31
|
export declare const MeshCollider: LwwComponentGetter<MeshColliderComponentDefinitionExtended>;
|
|
@@ -37,7 +34,6 @@ export declare const VirtualCamera: LwwComponentGetter<VirtualCameraComponentDef
|
|
|
37
34
|
export declare const InputModifier: LwwComponentGetter<InputModifierComponentDefinitionExtended>;
|
|
38
35
|
export declare const LightSource: LwwComponentGetter<LightSourceComponentDefinitionExtended>;
|
|
39
36
|
export declare const TriggerArea: LwwComponentGetter<TriggerAreaComponentDefinitionExtended>;
|
|
40
|
-
export declare const ParticleSystem: LwwComponentGetter<ParticleSystemComponentDefinitionExtended>;
|
|
41
37
|
/**
|
|
42
38
|
* @alpha
|
|
43
39
|
*/
|
|
@@ -55,5 +51,8 @@ export declare const NetworkEntity: (engine: Pick<IEngine, 'defineComponent'>) =
|
|
|
55
51
|
* @alpha
|
|
56
52
|
*/
|
|
57
53
|
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
58
|
export { MediaState };
|
|
59
|
-
export type { AudioAnalysisView };
|
package/dist/components/index.js
CHANGED
|
@@ -1,6 +1,5 @@
|
|
|
1
1
|
import { defineAnimatorComponent } from './extended/Animator';
|
|
2
2
|
import { defineAudioSourceComponent } from './extended/AudioSource';
|
|
3
|
-
import { defineAudioAnalysisComponent } from './extended/AudioAnalysis';
|
|
4
3
|
import { defineMaterialComponent } from './extended/Material';
|
|
5
4
|
import { defineMeshColliderComponent } from './extended/MeshCollider';
|
|
6
5
|
import { defineMeshRendererComponent } from './extended/MeshRenderer';
|
|
@@ -16,8 +15,8 @@ import { defineVirtualCameraComponent } from './extended/VirtualCamera';
|
|
|
16
15
|
import { defineInputModifierComponent } from './extended/InputModifier';
|
|
17
16
|
import { defineLightSourceComponent } from './extended/LightSource';
|
|
18
17
|
import { defineTriggerAreaComponent } from './extended/TriggerArea';
|
|
19
|
-
import { defineParticleSystemComponent } from './extended/ParticleSystem';
|
|
20
18
|
import defineTagsComponent from './manual/Tags';
|
|
19
|
+
import defineCreatedBy from './manual/CreatedBy';
|
|
21
20
|
export * from './generated/index.gen';
|
|
22
21
|
/* @__PURE__ */
|
|
23
22
|
export const Transform = (engine) => defineTransformComponent(engine);
|
|
@@ -28,8 +27,6 @@ export const Animator = (engine) => defineAnimatorComponent(engine);
|
|
|
28
27
|
/* @__PURE__ */
|
|
29
28
|
export const AudioSource = (engine) => defineAudioSourceComponent(engine);
|
|
30
29
|
/* @__PURE__ */
|
|
31
|
-
export const AudioAnalysis = (engine) => defineAudioAnalysisComponent(engine);
|
|
32
|
-
/* @__PURE__ */
|
|
33
30
|
export const AudioStream = (engine) => defineAudioStreamComponent(engine);
|
|
34
31
|
/* @__PURE__ */
|
|
35
32
|
export const MeshRenderer = (engine) => defineMeshRendererComponent(engine);
|
|
@@ -45,8 +42,6 @@ export const InputModifier = (engine) => defineInputModifierComponent(engine);
|
|
|
45
42
|
export const LightSource = (engine) => defineLightSourceComponent(engine);
|
|
46
43
|
/* @__PURE__ */
|
|
47
44
|
export const TriggerArea = (engine) => defineTriggerAreaComponent(engine);
|
|
48
|
-
/* @__PURE__ */
|
|
49
|
-
export const ParticleSystem = (engine) => defineParticleSystemComponent(engine);
|
|
50
45
|
/**
|
|
51
46
|
* @alpha
|
|
52
47
|
*/
|
|
@@ -62,11 +57,13 @@ export const SyncComponents = (engine) => defineSyncComponent(engine);
|
|
|
62
57
|
/**
|
|
63
58
|
* @alpha
|
|
64
59
|
*/
|
|
65
|
-
/* @__PURE__ */
|
|
66
60
|
export const NetworkEntity = (engine) => defineNetworkEntity(engine);
|
|
67
61
|
/**
|
|
68
62
|
* @alpha
|
|
69
63
|
*/
|
|
70
|
-
/* @__PURE__ */
|
|
71
64
|
export const NetworkParent = (engine) => defineNetworkParent(engine);
|
|
65
|
+
/**
|
|
66
|
+
* @public
|
|
67
|
+
*/
|
|
68
|
+
export const CreatedBy = (engine) => defineCreatedBy(engine);
|
|
72
69
|
export { MediaState };
|
|
@@ -0,0 +1,9 @@
|
|
|
1
|
+
import { IEngine, LastWriteWinElementSetComponentDefinition } from '../../engine/types';
|
|
2
|
+
export interface ICreatedByType {
|
|
3
|
+
address: string;
|
|
4
|
+
}
|
|
5
|
+
export type ICreatedBy = LastWriteWinElementSetComponentDefinition<ICreatedByType>;
|
|
6
|
+
declare function defineCreatedBy(engine: Pick<IEngine, 'defineComponent'>): import("../../engine/types").MapComponentDefinition<import("../..").MapResult<{
|
|
7
|
+
address: import("../../schemas").ISchema<string>;
|
|
8
|
+
}>>;
|
|
9
|
+
export default defineCreatedBy;
|
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
import { LastWriteWinElementSetComponentDefinition, IEngine } from '../../engine';
|
|
2
2
|
import { Entity } from '../../engine/entity';
|
|
3
|
-
import type {
|
|
3
|
+
import type { ISchema } from '../../schemas/ISchema';
|
|
4
4
|
/**
|
|
5
5
|
* @public
|
|
6
6
|
*/
|
|
@@ -11,19 +11,11 @@ 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;
|
|
26
14
|
}
|
|
15
|
+
/**
|
|
16
|
+
* @public
|
|
17
|
+
*/
|
|
18
|
+
export declare const COMPONENT_ID = 1;
|
|
27
19
|
/**
|
|
28
20
|
* @public
|
|
29
21
|
*/
|
|
@@ -46,6 +38,10 @@ export type TransformType = {
|
|
|
46
38
|
};
|
|
47
39
|
parent?: Entity;
|
|
48
40
|
};
|
|
41
|
+
/** @public */
|
|
42
|
+
export declare const TRANSFORM_LENGTH = 44;
|
|
43
|
+
/** @public */
|
|
44
|
+
export declare const TransformSchema: ISchema<TransformType>;
|
|
49
45
|
/**
|
|
50
46
|
* @public
|
|
51
47
|
*/
|
|
@@ -1,14 +1,10 @@
|
|
|
1
|
-
// Use import * to safely handle circular dependency (tree.ts → components → Transform.ts → tree.ts).
|
|
2
|
-
// With import *, the namespace object's properties are resolved at access time (live bindings in ESM,
|
|
3
|
-
// getters via __importStar in CJS), so by the time methods are called all exports are available.
|
|
4
|
-
import * as treeHelpers from '../../runtime/helpers/tree';
|
|
5
1
|
/**
|
|
6
|
-
* @
|
|
2
|
+
* @public
|
|
7
3
|
*/
|
|
8
4
|
export const COMPONENT_ID = 1;
|
|
9
|
-
/** @
|
|
5
|
+
/** @public */
|
|
10
6
|
export const TRANSFORM_LENGTH = 44;
|
|
11
|
-
/** @
|
|
7
|
+
/** @public */
|
|
12
8
|
export const TransformSchema = {
|
|
13
9
|
serialize(value, builder) {
|
|
14
10
|
const ptr = builder.incrementWriteOffset(TRANSFORM_LENGTH);
|
|
@@ -105,10 +101,6 @@ export function defineTransformComponent(engine) {
|
|
|
105
101
|
},
|
|
106
102
|
createOrReplace(entity, val) {
|
|
107
103
|
return transformDef.createOrReplace(entity, TransformSchema.extend(val));
|
|
108
|
-
},
|
|
109
|
-
localToWorldDirection(entity, localDirection) {
|
|
110
|
-
const worldRotation = treeHelpers.getWorldRotation(engine, entity);
|
|
111
|
-
return treeHelpers.rotateVectorByQuaternion(localDirection, worldRotation);
|
|
112
104
|
}
|
|
113
105
|
};
|
|
114
106
|
}
|
|
@@ -1,6 +1,5 @@
|
|
|
1
1
|
export type { AnimatorComponentDefinitionExtended } from './extended/Animator';
|
|
2
2
|
export type { AudioSourceComponentDefinitionExtended } from './extended/AudioSource';
|
|
3
|
-
export type { AudioAnalysisComponentDefinitionExtended, AudioAnalysisView } from './extended/AudioAnalysis';
|
|
4
3
|
export type { AudioStreamComponentDefinitionExtended } from './extended/AudioStream';
|
|
5
4
|
export type { MeshRendererComponentDefinitionExtended } from './extended/MeshRenderer';
|
|
6
5
|
export type { MeshColliderComponentDefinitionExtended } from './extended/MeshCollider';
|
|
@@ -13,7 +12,7 @@ export type { TagsComponentDefinitionExtended, TagsType } from './manual/Tags';
|
|
|
13
12
|
export type { ISyncComponents, ISyncComponentsType } from './manual/SyncComponents';
|
|
14
13
|
export type { INetowrkEntity, INetowrkEntityType } from './manual/NetworkEntity';
|
|
15
14
|
export type { INetowrkParent, INetowrkParentType } from './manual/NetworkParent';
|
|
15
|
+
export type { ICreatedBy, ICreatedByType } from './manual/CreatedBy';
|
|
16
16
|
export type { InputModifierHelper, InputModifierComponentDefinitionExtended } from './extended/InputModifier';
|
|
17
17
|
export type { LightSourceHelper, LightSourceComponentDefinitionExtended } from './extended/LightSource';
|
|
18
18
|
export type { TriggerAreaComponentDefinitionExtended } from './extended/TriggerArea';
|
|
19
|
-
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, PutComponentMessageBody } from '../serialization/crdt';
|
|
3
|
+
import { CrdtMessageBody, DeleteComponentMessageBody, ProcessMessageResultType, PutComponentMessageBody } from '../serialization/crdt';
|
|
4
4
|
import { Entity } from './entity';
|
|
5
5
|
import { DeepReadonly, DeepReadonlySet } from './readonly';
|
|
6
6
|
/**
|
|
@@ -70,7 +70,58 @@ 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;
|
|
73
117
|
}
|
|
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;
|
|
74
125
|
/**
|
|
75
126
|
* @public
|
|
76
127
|
*/
|
|
@@ -1,7 +1,8 @@
|
|
|
1
1
|
import { ReadWriteByteBuffer } from '../serialization/ByteBuffer';
|
|
2
|
-
import { AppendValueOperation, CrdtMessageType } from '../serialization/crdt';
|
|
2
|
+
import { AppendValueOperation, CrdtMessageType, ProcessMessageResultType } from '../serialization/crdt';
|
|
3
3
|
import { __DEV__ } from '../runtime/invariant';
|
|
4
4
|
const emptyReadonlySet = freezeSet(new Set());
|
|
5
|
+
const __GLOBAL_ENTITY = '__GLOBAL_ENTITY';
|
|
5
6
|
function frozenError() {
|
|
6
7
|
throw new Error('The set is frozen');
|
|
7
8
|
}
|
|
@@ -22,6 +23,7 @@ export function createValueSetComponentDefinitionFromSchema(componentName, compo
|
|
|
22
23
|
const dirtyIterator = new Set();
|
|
23
24
|
const queuedCommands = [];
|
|
24
25
|
const onChangeCallbacks = new Map();
|
|
26
|
+
const validateCallbacks = new Map();
|
|
25
27
|
// only sort the array if the latest (N) element has a timestamp <= N-1
|
|
26
28
|
function shouldSort(row) {
|
|
27
29
|
const len = row.raw.length;
|
|
@@ -80,8 +82,11 @@ export function createValueSetComponentDefinitionFromSchema(componentName, compo
|
|
|
80
82
|
has(entity) {
|
|
81
83
|
return data.has(entity);
|
|
82
84
|
},
|
|
83
|
-
entityDeleted(entity) {
|
|
85
|
+
entityDeleted(entity, markAsDirty) {
|
|
84
86
|
data.delete(entity);
|
|
87
|
+
if (markAsDirty) {
|
|
88
|
+
// For grow-only sets, we don't need to mark as dirty since deletion doesn't generate CRDT messages
|
|
89
|
+
}
|
|
85
90
|
},
|
|
86
91
|
get(entity) {
|
|
87
92
|
const values = data.get(entity);
|
|
@@ -152,6 +157,44 @@ export function createValueSetComponentDefinitionFromSchema(componentName, compo
|
|
|
152
157
|
for (const cb of cbs) {
|
|
153
158
|
cb(value);
|
|
154
159
|
}
|
|
160
|
+
},
|
|
161
|
+
__dry_run_updateFromCrdt(_body) {
|
|
162
|
+
return ProcessMessageResultType.StateUpdatedData;
|
|
163
|
+
},
|
|
164
|
+
validateBeforeChange(entityOrCb, cb) {
|
|
165
|
+
if (arguments.length === 1) {
|
|
166
|
+
// Second overload: just callback (global validation)
|
|
167
|
+
validateCallbacks.set(__GLOBAL_ENTITY, entityOrCb);
|
|
168
|
+
}
|
|
169
|
+
else {
|
|
170
|
+
if (cb) {
|
|
171
|
+
validateCallbacks.set(entityOrCb, cb);
|
|
172
|
+
}
|
|
173
|
+
}
|
|
174
|
+
},
|
|
175
|
+
__run_validateBeforeChange(entity, newValue, senderAddress, createdBy) {
|
|
176
|
+
const cb = entity && validateCallbacks.get(entity);
|
|
177
|
+
const globalCb = validateCallbacks.get(__GLOBAL_ENTITY);
|
|
178
|
+
const currentValue = [...this.get(entity).values()];
|
|
179
|
+
const value = { entity, currentValue: currentValue, newValue, senderAddress, createdBy };
|
|
180
|
+
const globalResult = globalCb?.(value) ?? true;
|
|
181
|
+
const entityResult = (globalResult && cb?.(value)) ?? true;
|
|
182
|
+
return globalResult && entityResult;
|
|
183
|
+
},
|
|
184
|
+
getCrdtState(entity) {
|
|
185
|
+
const row = data.get(entity);
|
|
186
|
+
if (!row || row.raw.length === 0) {
|
|
187
|
+
return null;
|
|
188
|
+
}
|
|
189
|
+
// For GrowOnlySet, we need to return the complete CRDT messages for all values
|
|
190
|
+
// This is complex because GrowOnlySet uses APPEND messages, not a single PUT
|
|
191
|
+
// For now, return null to indicate this component type doesn't support simple corrections
|
|
192
|
+
return null;
|
|
193
|
+
},
|
|
194
|
+
__forceUpdateFromCrdt(_msg) {
|
|
195
|
+
// GrowOnlySet doesn't support authoritative corrections in the same way as LWW
|
|
196
|
+
// since it uses APPEND_VALUE messages instead of PUT_COMPONENT messages
|
|
197
|
+
return [null, undefined];
|
|
155
198
|
}
|
|
156
199
|
};
|
|
157
200
|
return ret;
|
|
@@ -1,8 +1,10 @@
|
|
|
1
1
|
import { ISchema } from '../schemas';
|
|
2
2
|
import { ByteBuffer } from '../serialization/ByteBuffer';
|
|
3
|
-
import { PutComponentMessageBody, DeleteComponentMessageBody, CrdtMessageBody } from '../serialization/crdt';
|
|
3
|
+
import { PutComponentMessageBody, DeleteComponentMessageBody, ProcessMessageResultType, CrdtMessageBody, PutNetworkComponentMessageBody, DeleteComponentNetworkMessageBody, AuthoritativePutComponentMessageBody } 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
|
|
7
|
+
export declare function createCrdtRuleValidator(timestamps: Map<Entity, number>, schema: Pick<ISchema<any>, 'serialize' | 'deserialize'>, data: Map<Entity, unknown>): (message: PutComponentMessageBody | DeleteComponentMessageBody | PutNetworkComponentMessageBody | DeleteComponentNetworkMessageBody) => ProcessMessageResultType;
|
|
8
|
+
export declare function createForceUpdateLwwFromCrdt(componentId: number, timestamps: Map<Entity, number>, schema: Pick<ISchema<any>, 'serialize' | 'deserialize'>, data: Map<Entity, unknown>): (msg: AuthoritativePutComponentMessageBody) => [null, any];
|
|
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>;
|
|
@@ -30,16 +30,12 @@ export function createDumpLwwFunctionFromCrdt(componentId, timestamps, schema, d
|
|
|
30
30
|
}
|
|
31
31
|
};
|
|
32
32
|
}
|
|
33
|
-
|
|
33
|
+
const __GLOBAL_ENTITY = '__GLOBAL_ENTITY';
|
|
34
|
+
export function createCrdtRuleValidator(timestamps, schema, data) {
|
|
34
35
|
/**
|
|
35
|
-
*
|
|
36
|
-
*
|
|
37
|
-
|
|
38
|
-
|
|
39
|
-
* Returns the recieved data if the lamport number was bigger than ours.
|
|
40
|
-
* If it was an outdated message, then we return void
|
|
41
|
-
* @public
|
|
42
|
-
*/
|
|
36
|
+
* Shared CRDT conflict resolution logic
|
|
37
|
+
* @public
|
|
38
|
+
*/
|
|
43
39
|
function crdtRuleForCurrentState(message) {
|
|
44
40
|
const { entityId, timestamp } = message;
|
|
45
41
|
const currentTimestamp = timestamps.get(entityId);
|
|
@@ -49,7 +45,6 @@ export function createUpdateLwwFromCrdt(componentId, timestamps, schema, data, l
|
|
|
49
45
|
}
|
|
50
46
|
// Outdated Message. Resend our state message through the wire.
|
|
51
47
|
if (currentTimestamp > timestamp) {
|
|
52
|
-
// console.log('2', currentTimestamp, timestamp)
|
|
53
48
|
return ProcessMessageResultType.StateOutdatedTimestamp;
|
|
54
49
|
}
|
|
55
50
|
// Deletes are idempotent
|
|
@@ -66,7 +61,6 @@ export function createUpdateLwwFromCrdt(componentId, timestamps, schema, data, l
|
|
|
66
61
|
currentDataGreater = dataCompare(null, message.data);
|
|
67
62
|
}
|
|
68
63
|
// Same data, same timestamp. Weirdo echo message.
|
|
69
|
-
// console.log('3', currentDataGreater, writeBuffer.toBinary(), (message as any).data || null)
|
|
70
64
|
if (currentDataGreater === 0) {
|
|
71
65
|
return ProcessMessageResultType.NoChanges;
|
|
72
66
|
}
|
|
@@ -75,10 +69,35 @@ export function createUpdateLwwFromCrdt(componentId, timestamps, schema, data, l
|
|
|
75
69
|
return ProcessMessageResultType.StateOutdatedData;
|
|
76
70
|
}
|
|
77
71
|
else {
|
|
78
|
-
//
|
|
72
|
+
// Current data is lower
|
|
79
73
|
return ProcessMessageResultType.StateUpdatedData;
|
|
80
74
|
}
|
|
81
75
|
}
|
|
76
|
+
return crdtRuleForCurrentState;
|
|
77
|
+
}
|
|
78
|
+
export function createForceUpdateLwwFromCrdt(componentId, timestamps, schema, data) {
|
|
79
|
+
/**
|
|
80
|
+
* Force update component state regardless of timestamp - used for server authoritative messages
|
|
81
|
+
*/
|
|
82
|
+
return (msg) => {
|
|
83
|
+
const buffer = new ReadWriteByteBuffer(msg.data);
|
|
84
|
+
const deserializedValue = schema.deserialize(buffer);
|
|
85
|
+
data.set(msg.entityId, deserializedValue);
|
|
86
|
+
timestamps.set(msg.entityId, msg.timestamp);
|
|
87
|
+
return [null, deserializedValue];
|
|
88
|
+
};
|
|
89
|
+
}
|
|
90
|
+
export function createUpdateLwwFromCrdt(componentId, timestamps, schema, data) {
|
|
91
|
+
/**
|
|
92
|
+
* Process the received message only if the lamport number recieved is higher
|
|
93
|
+
* than the stored one. If its lower, we spread it to the network to correct the peer.
|
|
94
|
+
* If they are equal, the bigger raw data wins.
|
|
95
|
+
|
|
96
|
+
* Returns the recieved data if the lamport number was bigger than ours.
|
|
97
|
+
* If it was an outdated message, then we return void
|
|
98
|
+
* @public
|
|
99
|
+
*/
|
|
100
|
+
const crdtRuleForCurrentState = createCrdtRuleValidator(timestamps, schema, data);
|
|
82
101
|
return (msg) => {
|
|
83
102
|
/* istanbul ignore next */
|
|
84
103
|
if (msg.type !== CrdtMessageType.PUT_COMPONENT &&
|
|
@@ -96,11 +115,9 @@ export function createUpdateLwwFromCrdt(componentId, timestamps, schema, data, l
|
|
|
96
115
|
if (msg.type === CrdtMessageType.PUT_COMPONENT || msg.type === CrdtMessageType.PUT_COMPONENT_NETWORK) {
|
|
97
116
|
const buf = new ReadWriteByteBuffer(msg.data);
|
|
98
117
|
data.set(entity, schema.deserialize(buf));
|
|
99
|
-
lastSentData.set(entity, new Uint8Array(msg.data));
|
|
100
118
|
}
|
|
101
119
|
else {
|
|
102
120
|
data.delete(entity);
|
|
103
|
-
lastSentData.delete(entity);
|
|
104
121
|
}
|
|
105
122
|
return [null, data.get(entity)];
|
|
106
123
|
}
|
|
@@ -136,34 +153,23 @@ export function createUpdateLwwFromCrdt(componentId, timestamps, schema, data, l
|
|
|
136
153
|
return [null, data.get(entity)];
|
|
137
154
|
};
|
|
138
155
|
}
|
|
139
|
-
export function createGetCrdtMessagesForLww(componentId, timestamps, dirtyIterator, schema, data
|
|
156
|
+
export function createGetCrdtMessagesForLww(componentId, timestamps, dirtyIterator, schema, data) {
|
|
140
157
|
return function* () {
|
|
141
|
-
const writeBuffer = new ReadWriteByteBuffer();
|
|
142
158
|
for (const entity of dirtyIterator) {
|
|
159
|
+
const newTimestamp = incrementTimestamp(entity, timestamps);
|
|
143
160
|
if (data.has(entity)) {
|
|
144
|
-
writeBuffer
|
|
161
|
+
const writeBuffer = new ReadWriteByteBuffer();
|
|
145
162
|
schema.serialize(data.get(entity), writeBuffer);
|
|
146
|
-
// Compare against last-sent snapshot using the zero-copy subarray view.
|
|
147
|
-
// Only allocate a copy when bytes actually differ.
|
|
148
|
-
const previousBytes = lastSentData.get(entity);
|
|
149
|
-
if (previousBytes && dataCompare(writeBuffer.toBinary(), previousBytes) === 0) {
|
|
150
|
-
continue;
|
|
151
|
-
}
|
|
152
|
-
const currentBytes = writeBuffer.toCopiedBinary();
|
|
153
|
-
const newTimestamp = incrementTimestamp(entity, timestamps);
|
|
154
|
-
lastSentData.set(entity, currentBytes);
|
|
155
163
|
const msg = {
|
|
156
164
|
type: CrdtMessageType.PUT_COMPONENT,
|
|
157
165
|
componentId,
|
|
158
166
|
entityId: entity,
|
|
159
|
-
data:
|
|
167
|
+
data: writeBuffer.toBinary(),
|
|
160
168
|
timestamp: newTimestamp
|
|
161
169
|
};
|
|
162
170
|
yield msg;
|
|
163
171
|
}
|
|
164
172
|
else {
|
|
165
|
-
lastSentData.delete(entity);
|
|
166
|
-
const newTimestamp = incrementTimestamp(entity, timestamps);
|
|
167
173
|
const msg = {
|
|
168
174
|
type: CrdtMessageType.DELETE_COMPONENT,
|
|
169
175
|
componentId,
|
|
@@ -183,8 +189,8 @@ export function createComponentDefinitionFromSchema(componentName, componentId,
|
|
|
183
189
|
const data = new Map();
|
|
184
190
|
const dirtyIterator = new Set();
|
|
185
191
|
const timestamps = new Map();
|
|
186
|
-
const lastSentData = new Map();
|
|
187
192
|
const onChangeCallbacks = new Map();
|
|
193
|
+
const validateCallbacks = new Map();
|
|
188
194
|
return {
|
|
189
195
|
get componentId() {
|
|
190
196
|
return componentId;
|
|
@@ -205,14 +211,12 @@ export function createComponentDefinitionFromSchema(componentName, componentId,
|
|
|
205
211
|
if (data.delete(entity) && markAsDirty) {
|
|
206
212
|
dirtyIterator.add(entity);
|
|
207
213
|
}
|
|
208
|
-
lastSentData.delete(entity);
|
|
209
214
|
return component || null;
|
|
210
215
|
},
|
|
211
216
|
entityDeleted(entity, markAsDirty) {
|
|
212
217
|
if (data.delete(entity) && markAsDirty) {
|
|
213
218
|
dirtyIterator.add(entity);
|
|
214
219
|
}
|
|
215
|
-
lastSentData.delete(entity);
|
|
216
220
|
},
|
|
217
221
|
getOrNull(entity) {
|
|
218
222
|
const component = data.get(entity);
|
|
@@ -239,7 +243,6 @@ export function createComponentDefinitionFromSchema(componentName, componentId,
|
|
|
239
243
|
const usedValue = value === undefined ? schema.create() : schema.extend ? schema.extend(value) : value;
|
|
240
244
|
data.set(entity, usedValue);
|
|
241
245
|
dirtyIterator.add(entity);
|
|
242
|
-
lastSentData.delete(entity);
|
|
243
246
|
return usedValue;
|
|
244
247
|
},
|
|
245
248
|
getMutableOrNull(entity) {
|
|
@@ -277,9 +280,41 @@ export function createComponentDefinitionFromSchema(componentName, componentId,
|
|
|
277
280
|
yield entity;
|
|
278
281
|
}
|
|
279
282
|
},
|
|
280
|
-
getCrdtUpdates: createGetCrdtMessagesForLww(componentId, timestamps, dirtyIterator, schema, data
|
|
281
|
-
updateFromCrdt: createUpdateLwwFromCrdt(componentId, timestamps, schema, data
|
|
283
|
+
getCrdtUpdates: createGetCrdtMessagesForLww(componentId, timestamps, dirtyIterator, schema, data),
|
|
284
|
+
updateFromCrdt: createUpdateLwwFromCrdt(componentId, timestamps, schema, data),
|
|
285
|
+
__forceUpdateFromCrdt: createForceUpdateLwwFromCrdt(componentId, timestamps, schema, data),
|
|
286
|
+
__dry_run_updateFromCrdt: createCrdtRuleValidator(timestamps, schema, data),
|
|
282
287
|
dumpCrdtStateToBuffer: createDumpLwwFunctionFromCrdt(componentId, timestamps, schema, data),
|
|
288
|
+
validateBeforeChange(entityOrCb, cb) {
|
|
289
|
+
if (arguments.length === 1) {
|
|
290
|
+
// Second overload: just callback (global validation)
|
|
291
|
+
validateCallbacks.set(__GLOBAL_ENTITY, entityOrCb);
|
|
292
|
+
}
|
|
293
|
+
else {
|
|
294
|
+
if (cb) {
|
|
295
|
+
validateCallbacks.set(entityOrCb, cb);
|
|
296
|
+
}
|
|
297
|
+
}
|
|
298
|
+
},
|
|
299
|
+
__run_validateBeforeChange(entity, newValue, senderAddress, createdBy) {
|
|
300
|
+
const cb = entity && validateCallbacks.get(entity);
|
|
301
|
+
const globalCb = validateCallbacks.get(__GLOBAL_ENTITY);
|
|
302
|
+
const currentValue = data.get(entity);
|
|
303
|
+
const value = { entity, currentValue, newValue, senderAddress, createdBy };
|
|
304
|
+
const globalResult = globalCb?.(value) ?? true;
|
|
305
|
+
const entityResult = (globalResult && cb?.(value)) ?? true;
|
|
306
|
+
return globalResult && entityResult;
|
|
307
|
+
},
|
|
308
|
+
getCrdtState(entity) {
|
|
309
|
+
const componentData = data.get(entity);
|
|
310
|
+
const timestamp = timestamps.get(entity);
|
|
311
|
+
if (componentData && timestamp !== undefined) {
|
|
312
|
+
const buffer = new ReadWriteByteBuffer();
|
|
313
|
+
schema.serialize(deepReadonly(componentData), buffer);
|
|
314
|
+
return { data: buffer.toBinary(), timestamp };
|
|
315
|
+
}
|
|
316
|
+
return null;
|
|
317
|
+
},
|
|
283
318
|
onChange(entity, cb) {
|
|
284
319
|
const cbs = onChangeCallbacks.get(entity) ?? [];
|
|
285
320
|
cbs.push(cb);
|
package/dist/index.d.ts
CHANGED
|
@@ -12,16 +12,14 @@ export * from './systems/assetLoad';
|
|
|
12
12
|
export * from './systems/async-task';
|
|
13
13
|
export * from './systems/tween';
|
|
14
14
|
export * from './systems/triggerArea';
|
|
15
|
-
export * from './systems/physics';
|
|
16
15
|
export * from './engine/entity';
|
|
17
16
|
export * from './components/types';
|
|
18
|
-
import { MaterialComponentDefinitionExtended, MeshColliderComponentDefinitionExtended, MeshRendererComponentDefinitionExtended, TransformComponentExtended, AnimatorComponentDefinitionExtended, AudioSourceComponentDefinitionExtended,
|
|
17
|
+
import { MaterialComponentDefinitionExtended, MeshColliderComponentDefinitionExtended, MeshRendererComponentDefinitionExtended, TransformComponentExtended, AnimatorComponentDefinitionExtended, AudioSourceComponentDefinitionExtended, AudioStreamComponentDefinitionExtended, ISyncComponents, TweenComponentDefinitionExtended, INetowrkEntity, INetowrkParent, VirtualCameraComponentDefinitionExtended, InputModifierComponentDefinitionExtended, LightSourceComponentDefinitionExtended, TriggerAreaComponentDefinitionExtended, ICreatedBy } from './components/types';
|
|
19
18
|
import { NameComponent } from './components/manual/Name';
|
|
20
19
|
import { TagsComponentDefinitionExtended } from './components/manual/Tags';
|
|
21
20
|
export declare const Transform: TransformComponentExtended;
|
|
22
21
|
export declare const Animator: AnimatorComponentDefinitionExtended;
|
|
23
22
|
export declare const AudioSource: AudioSourceComponentDefinitionExtended;
|
|
24
|
-
export declare const AudioAnalysis: AudioAnalysisComponentDefinitionExtended;
|
|
25
23
|
export declare const AudioStream: AudioStreamComponentDefinitionExtended;
|
|
26
24
|
export declare const Material: MaterialComponentDefinitionExtended;
|
|
27
25
|
export declare const MeshRenderer: MeshRendererComponentDefinitionExtended;
|
|
@@ -33,7 +31,6 @@ export declare const VirtualCamera: VirtualCameraComponentDefinitionExtended;
|
|
|
33
31
|
export declare const InputModifier: InputModifierComponentDefinitionExtended;
|
|
34
32
|
export declare const LightSource: LightSourceComponentDefinitionExtended;
|
|
35
33
|
export declare const TriggerArea: TriggerAreaComponentDefinitionExtended;
|
|
36
|
-
export declare const ParticleSystem: ParticleSystemComponentDefinitionExtended;
|
|
37
34
|
/**
|
|
38
35
|
* @alpha
|
|
39
36
|
* This is going to be used for sync components through a server.
|
|
@@ -50,6 +47,7 @@ export declare const NetworkEntity: INetowrkEntity;
|
|
|
50
47
|
* Tag a entity to be syncronized through comms
|
|
51
48
|
*/
|
|
52
49
|
export declare const NetworkParent: INetowrkParent;
|
|
50
|
+
export declare const CreatedBy: ICreatedBy;
|
|
53
51
|
export * from './components/generated/global.gen';
|
|
54
52
|
export * from './components/generated/types.gen';
|
|
55
53
|
export * from './serialization/crdt';
|
package/dist/index.js
CHANGED
|
@@ -13,7 +13,6 @@ export * from './systems/assetLoad';
|
|
|
13
13
|
export * from './systems/async-task';
|
|
14
14
|
export * from './systems/tween';
|
|
15
15
|
export * from './systems/triggerArea';
|
|
16
|
-
export * from './systems/physics';
|
|
17
16
|
export * from './engine/entity';
|
|
18
17
|
export * from './components/types';
|
|
19
18
|
// @internal
|
|
@@ -25,7 +24,6 @@ import { engine } from './runtime/initialization';
|
|
|
25
24
|
export const Transform = /* @__PURE__*/ components.Transform(engine);
|
|
26
25
|
export const Animator = /* @__PURE__*/ components.Animator(engine);
|
|
27
26
|
export const AudioSource = /* @__PURE__*/ components.AudioSource(engine);
|
|
28
|
-
export const AudioAnalysis = /* @__PURE__*/ components.AudioAnalysis(engine);
|
|
29
27
|
export const AudioStream = /* @__PURE__*/ components.AudioStream(engine);
|
|
30
28
|
export const Material = /* @__PURE__*/ components.Material(engine);
|
|
31
29
|
export const MeshRenderer = /* @__PURE__*/ components.MeshRenderer(engine);
|
|
@@ -37,8 +35,6 @@ export const VirtualCamera = /* @__PURE__*/ components.VirtualCamera(engine);
|
|
|
37
35
|
export const InputModifier = /* @__PURE__*/ components.InputModifier(engine);
|
|
38
36
|
export const LightSource = /* @__PURE__*/ components.LightSource(engine);
|
|
39
37
|
export const TriggerArea = /* @__PURE__*/ components.TriggerArea(engine);
|
|
40
|
-
export const ParticleSystem =
|
|
41
|
-
/* @__PURE__*/ components.ParticleSystem(engine);
|
|
42
38
|
/**
|
|
43
39
|
* @alpha
|
|
44
40
|
* This is going to be used for sync components through a server.
|
|
@@ -55,6 +51,7 @@ export const NetworkEntity = /* @__PURE__*/ components.NetworkEntity(engine);
|
|
|
55
51
|
* Tag a entity to be syncronized through comms
|
|
56
52
|
*/
|
|
57
53
|
export const NetworkParent = /* @__PURE__*/ components.NetworkParent(engine);
|
|
54
|
+
export const CreatedBy = /* @__PURE__*/ components.CreatedBy(engine);
|
|
58
55
|
// export components for global engine
|
|
59
56
|
export * from './components/generated/global.gen';
|
|
60
57
|
export * from './components/generated/types.gen';
|