angular-three 2.0.0 → 2.1.0

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.
@@ -22,6 +22,9 @@ function diffProps(instance, props) {
22
22
  }
23
23
  return changes;
24
24
  }
25
+ // NOTE: this is a workaround to give the instance a change to have the store from the parent.
26
+ // we clear this property after the applyProps is done
27
+ export const NGT_APPLY_PROPS = '__ngt_apply_props__';
25
28
  // This function applies a set of changes to the instance
26
29
  export function applyProps(instance, props) {
27
30
  // if props is empty
@@ -29,7 +32,7 @@ export function applyProps(instance, props) {
29
32
  return instance;
30
33
  // filter equals, and reserved props
31
34
  const localState = getLocalState(instance);
32
- const rootState = localState?.store?.snapshot ?? {};
35
+ const rootState = localState?.store?.snapshot ?? instance[NGT_APPLY_PROPS]?.snapshot ?? {};
33
36
  const changes = diffProps(instance, props);
34
37
  for (let i = 0; i < changes.length; i++) {
35
38
  let [key, value] = changes[i];
@@ -118,6 +121,10 @@ export function applyProps(instance, props) {
118
121
  if (parent && localState?.onUpdate && changes.length) {
119
122
  localState.onUpdate(instance);
120
123
  }
124
+ // clearing the intermediate store from the instance
125
+ if (instance[NGT_APPLY_PROPS]) {
126
+ delete instance[NGT_APPLY_PROPS];
127
+ }
121
128
  return instance;
122
129
  }
123
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"apply-props.js","sourceRoot":"","sources":["../../../../../../libs/core/src/lib/utils/apply-props.ts"],"names":[],"mappings":"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","sourcesContent":["import { Color, ColorManagement, Layers, RGBAFormat, Texture, UnsignedByteType } from 'three';\nimport { getLocalState, invalidateInstance } from '../instance';\nimport { NgtAnyRecord, NgtInstanceNode, NgtState } from '../types';\nimport { is } from './is';\nimport { checkUpdate } from './update';\n\n// This function prepares a set of changes to be applied to the instance\nfunction diffProps(instance: NgtAnyRecord, props: NgtAnyRecord) {\n\tconst propsEntries = Object.entries(props);\n\tconst changes: [key: string, value: unknown][] = [];\n\n\tfor (const [propKey, propValue] of propsEntries) {\n\t\tlet key = propKey;\n\t\tif (is.colorSpaceExist(instance)) {\n\t\t\tif (propKey === 'encoding') {\n\t\t\t\tkey = 'colorSpace';\n\t\t\t} else if (propKey === 'outputEncoding') {\n\t\t\t\tkey = 'outputColorSpace';\n\t\t\t}\n\t\t}\n\t\tif (is.equ(propValue, instance[key])) continue;\n\t\tchanges.push([propKey, propValue]);\n\t}\n\n\treturn changes;\n}\n\n// This function applies a set of changes to the instance\nexport function applyProps(instance: NgtInstanceNode, props: NgtAnyRecord) {\n\t// if props is empty\n\tif (!Object.keys(props).length) return instance;\n\n\t// filter equals, and reserved props\n\tconst localState = getLocalState(instance);\n\tconst rootState = localState?.store?.snapshot ?? ({} as NgtState);\n\tconst changes = diffProps(instance, props);\n\n\tfor (let i = 0; i < changes.length; i++) {\n\t\tlet [key, value] = changes[i];\n\n\t\t// Alias (output)encoding => (output)colorSpace (since r152)\n\t\t// https://github.com/pmndrs/react-three-fiber/pull/2829\n\t\tif (is.colorSpaceExist(instance)) {\n\t\t\tconst sRGBEncoding = 3001;\n\t\t\tconst SRGBColorSpace = 'srgb';\n\t\t\tconst LinearSRGBColorSpace = 'srgb-linear';\n\n\t\t\tif (key === 'encoding') {\n\t\t\t\tkey = 'colorSpace';\n\t\t\t\tvalue = value === sRGBEncoding ? SRGBColorSpace : LinearSRGBColorSpace;\n\t\t\t} else if (key === 'outputEncoding') {\n\t\t\t\tkey = 'outputColorSpace';\n\t\t\t\tvalue = value === sRGBEncoding ? SRGBColorSpace : LinearSRGBColorSpace;\n\t\t\t}\n\t\t}\n\n\t\tconst currentInstance = instance;\n\t\tconst targetProp = currentInstance[key];\n\n\t\t// special treatmen for objects with support for set/copy, and layers\n\t\tif (targetProp && targetProp['set'] && (targetProp['copy'] || targetProp instanceof Layers)) {\n\t\t\tconst isColor = targetProp instanceof Color;\n\t\t\t// if value is an array\n\t\t\tif (Array.isArray(value)) {\n\t\t\t\tif (targetProp['fromArray']) targetProp['fromArray'](value);\n\t\t\t\telse targetProp['set'](...value);\n\t\t\t} // test again target.copy\n\t\t\telse if (\n\t\t\t\ttargetProp['copy'] &&\n\t\t\t\tvalue &&\n\t\t\t\tvalue.constructor &&\n\t\t\t\ttargetProp.constructor.name === value.constructor.name\n\t\t\t) {\n\t\t\t\ttargetProp['copy'](value);\n\t\t\t\tif (!ColorManagement && !rootState.linear && isColor) targetProp['convertSRGBToLinear']();\n\t\t\t} // if nothing else fits, just set the single value, ignore undefined\n\t\t\telse if (value !== undefined) {\n\t\t\t\tconst isColor = targetProp instanceof Color;\n\t\t\t\t// allow setting array scalars\n\t\t\t\tif (!isColor && targetProp['setScalar']) targetProp['setScalar'](value);\n\t\t\t\t// layers have no copy function, copy the mask\n\t\t\t\telse if (targetProp instanceof Layers && value instanceof Layers) targetProp.mask = value.mask;\n\t\t\t\t// otherwise just set ...\n\t\t\t\telse targetProp['set'](value);\n\n\t\t\t\t// auto-convert srgb\n\t\t\t\tif (!ColorManagement && !rootState?.linear && isColor) targetProp.convertSRGBToLinear();\n\t\t\t}\n\t\t} // else just overwrite the value\n\t\telse {\n\t\t\tcurrentInstance[key] = value;\n\t\t\t// auto-convert srgb textures\n\t\t\tif (\n\t\t\t\tcurrentInstance[key] instanceof Texture &&\n\t\t\t\tcurrentInstance[key].format === RGBAFormat &&\n\t\t\t\tcurrentInstance[key].type === UnsignedByteType\n\t\t\t) {\n\t\t\t\tconst texture = currentInstance[key] as Texture;\n\t\t\t\tif (rootState?.gl) {\n\t\t\t\t\tif (is.colorSpaceExist(texture) && is.colorSpaceExist(rootState.gl))\n\t\t\t\t\t\ttexture.colorSpace = rootState.gl.outputColorSpace;\n\t\t\t\t\t// @ts-expect-error - old version of threejs\n\t\t\t\t\telse texture.encoding = rootState.gl.outputEncoding;\n\t\t\t\t}\n\t\t\t}\n\t\t}\n\n\t\tcheckUpdate(currentInstance[key]);\n\t\tcheckUpdate(targetProp);\n\t\tinvalidateInstance(instance);\n\t}\n\n\tconst instanceHandlersCount = localState?.eventCount;\n\tconst parent = localState?.instanceStore?.get('parent');\n\n\tif (parent && rootState.internal && instance['raycast'] && instanceHandlersCount !== localState?.eventCount) {\n\t\t// Pre-emptively remove the instance from the interaction manager\n\t\tconst index = rootState.internal.interaction.indexOf(instance);\n\t\tif (index > -1) rootState.internal.interaction.splice(index, 1);\n\t\t// Add the instance to the interaction manager only when it has handlers\n\t\tif (localState?.eventCount) rootState.internal.interaction.push(instance);\n\t}\n\n\tif (parent && localState?.onUpdate && changes.length) {\n\t\tlocalState.onUpdate(instance);\n\t}\n\n\treturn instance;\n}\n"]}
130
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"apply-props.js","sourceRoot":"","sources":["../../../../../../libs/core/src/lib/utils/apply-props.ts"],"names":[],"mappings":"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","sourcesContent":["import { Color, ColorManagement, Layers, RGBAFormat, Texture, UnsignedByteType } from 'three';\nimport { getLocalState, invalidateInstance } from '../instance';\nimport { NgtAnyRecord, NgtInstanceNode, NgtState } from '../types';\nimport { is } from './is';\nimport { checkUpdate } from './update';\n\n// This function prepares a set of changes to be applied to the instance\nfunction diffProps(instance: NgtAnyRecord, props: NgtAnyRecord) {\n\tconst propsEntries = Object.entries(props);\n\tconst changes: [key: string, value: unknown][] = [];\n\n\tfor (const [propKey, propValue] of propsEntries) {\n\t\tlet key = propKey;\n\t\tif (is.colorSpaceExist(instance)) {\n\t\t\tif (propKey === 'encoding') {\n\t\t\t\tkey = 'colorSpace';\n\t\t\t} else if (propKey === 'outputEncoding') {\n\t\t\t\tkey = 'outputColorSpace';\n\t\t\t}\n\t\t}\n\t\tif (is.equ(propValue, instance[key])) continue;\n\t\tchanges.push([propKey, propValue]);\n\t}\n\n\treturn changes;\n}\n\n// NOTE: this is a workaround to give the instance a change to have the store from the parent.\n//  we clear this property after the applyProps is done\nexport const NGT_APPLY_PROPS = '__ngt_apply_props__';\n\n// This function applies a set of changes to the instance\nexport function applyProps(instance: NgtInstanceNode, props: NgtAnyRecord) {\n\t// if props is empty\n\tif (!Object.keys(props).length) return instance;\n\n\t// filter equals, and reserved props\n\tconst localState = getLocalState(instance);\n\tconst rootState = localState?.store?.snapshot ?? instance[NGT_APPLY_PROPS]?.snapshot ?? ({} as NgtState);\n\tconst changes = diffProps(instance, props);\n\n\tfor (let i = 0; i < changes.length; i++) {\n\t\tlet [key, value] = changes[i];\n\n\t\t// Alias (output)encoding => (output)colorSpace (since r152)\n\t\t// https://github.com/pmndrs/react-three-fiber/pull/2829\n\t\tif (is.colorSpaceExist(instance)) {\n\t\t\tconst sRGBEncoding = 3001;\n\t\t\tconst SRGBColorSpace = 'srgb';\n\t\t\tconst LinearSRGBColorSpace = 'srgb-linear';\n\n\t\t\tif (key === 'encoding') {\n\t\t\t\tkey = 'colorSpace';\n\t\t\t\tvalue = value === sRGBEncoding ? SRGBColorSpace : LinearSRGBColorSpace;\n\t\t\t} else if (key === 'outputEncoding') {\n\t\t\t\tkey = 'outputColorSpace';\n\t\t\t\tvalue = value === sRGBEncoding ? SRGBColorSpace : LinearSRGBColorSpace;\n\t\t\t}\n\t\t}\n\n\t\tconst currentInstance = instance;\n\t\tconst targetProp = currentInstance[key];\n\n\t\t// special treatmen for objects with support for set/copy, and layers\n\t\tif (targetProp && targetProp['set'] && (targetProp['copy'] || targetProp instanceof Layers)) {\n\t\t\tconst isColor = targetProp instanceof Color;\n\t\t\t// if value is an array\n\t\t\tif (Array.isArray(value)) {\n\t\t\t\tif (targetProp['fromArray']) targetProp['fromArray'](value);\n\t\t\t\telse targetProp['set'](...value);\n\t\t\t} // test again target.copy\n\t\t\telse if (\n\t\t\t\ttargetProp['copy'] &&\n\t\t\t\tvalue &&\n\t\t\t\tvalue.constructor &&\n\t\t\t\ttargetProp.constructor.name === value.constructor.name\n\t\t\t) {\n\t\t\t\ttargetProp['copy'](value);\n\t\t\t\tif (!ColorManagement && !rootState.linear && isColor) targetProp['convertSRGBToLinear']();\n\t\t\t} // if nothing else fits, just set the single value, ignore undefined\n\t\t\telse if (value !== undefined) {\n\t\t\t\tconst isColor = targetProp instanceof Color;\n\t\t\t\t// allow setting array scalars\n\t\t\t\tif (!isColor && targetProp['setScalar']) targetProp['setScalar'](value);\n\t\t\t\t// layers have no copy function, copy the mask\n\t\t\t\telse if (targetProp instanceof Layers && value instanceof Layers) targetProp.mask = value.mask;\n\t\t\t\t// otherwise just set ...\n\t\t\t\telse targetProp['set'](value);\n\n\t\t\t\t// auto-convert srgb\n\t\t\t\tif (!ColorManagement && !rootState?.linear && isColor) targetProp.convertSRGBToLinear();\n\t\t\t}\n\t\t} // else just overwrite the value\n\t\telse {\n\t\t\tcurrentInstance[key] = value;\n\t\t\t// auto-convert srgb textures\n\t\t\tif (\n\t\t\t\tcurrentInstance[key] instanceof Texture &&\n\t\t\t\tcurrentInstance[key].format === RGBAFormat &&\n\t\t\t\tcurrentInstance[key].type === UnsignedByteType\n\t\t\t) {\n\t\t\t\tconst texture = currentInstance[key] as Texture;\n\t\t\t\tif (rootState?.gl) {\n\t\t\t\t\tif (is.colorSpaceExist(texture) && is.colorSpaceExist(rootState.gl))\n\t\t\t\t\t\ttexture.colorSpace = rootState.gl.outputColorSpace;\n\t\t\t\t\t// @ts-expect-error - old version of threejs\n\t\t\t\t\telse texture.encoding = rootState.gl.outputEncoding;\n\t\t\t\t}\n\t\t\t}\n\t\t}\n\n\t\tcheckUpdate(currentInstance[key]);\n\t\tcheckUpdate(targetProp);\n\t\tinvalidateInstance(instance);\n\t}\n\n\tconst instanceHandlersCount = localState?.eventCount;\n\tconst parent = localState?.instanceStore?.get('parent');\n\n\tif (parent && rootState.internal && instance['raycast'] && instanceHandlersCount !== localState?.eventCount) {\n\t\t// Pre-emptively remove the instance from the interaction manager\n\t\tconst index = rootState.internal.interaction.indexOf(instance);\n\t\tif (index > -1) rootState.internal.interaction.splice(index, 1);\n\t\t// Add the instance to the interaction manager only when it has handlers\n\t\tif (localState?.eventCount) rootState.internal.interaction.push(instance);\n\t}\n\n\tif (parent && localState?.onUpdate && changes.length) {\n\t\tlocalState.onUpdate(instance);\n\t}\n\n\t// clearing the intermediate store from the instance\n\tif (instance[NGT_APPLY_PROPS]) {\n\t\tdelete instance[NGT_APPLY_PROPS];\n\t}\n\n\treturn instance;\n}\n"]}
@@ -1,5 +1,5 @@
1
1
  import { getLocalState } from '../instance';
2
- import { applyProps } from './apply-props';
2
+ import { applyProps, NGT_APPLY_PROPS } from './apply-props';
3
3
  export function attach(object, value, paths = [], useApplyProps = false) {
4
4
  const [base, ...remaining] = paths;
5
5
  if (!base)
@@ -11,7 +11,7 @@ export function attach(object, value, paths = [], useApplyProps = false) {
11
11
  object[base] = value;
12
12
  }
13
13
  else {
14
- assignEmpty(object, base);
14
+ assignEmpty(object, base, useApplyProps);
15
15
  attach(object[base], value, remaining, useApplyProps);
16
16
  }
17
17
  }
@@ -24,12 +24,23 @@ export function detach(parent, child, attachProp) {
24
24
  childLocalState.previousAttach();
25
25
  }
26
26
  }
27
- function assignEmpty(obj, base) {
27
+ function assignEmpty(obj, base, shouldAssignStoreForApplyProps = false) {
28
28
  if ((!Object.hasOwn(obj, base) && Reflect && !!Reflect.has && !Reflect.has(obj, base)) || obj[base] === undefined) {
29
29
  obj[base] = {};
30
30
  }
31
+ if (shouldAssignStoreForApplyProps) {
32
+ const localState = getLocalState(obj[base]);
33
+ // if we already have local state, bail out
34
+ if (localState)
35
+ return;
36
+ const parentLocalState = getLocalState(obj);
37
+ // if parent doesn't have local state, bail out
38
+ if (!parentLocalState)
39
+ return;
40
+ Object.assign(obj[base], { [NGT_APPLY_PROPS]: parentLocalState.store });
41
+ }
31
42
  }
32
43
  export function createAttachFunction(cb) {
33
44
  return (parent, child, store) => cb({ parent, child, store });
34
45
  }
35
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiYXR0YWNoLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vbGlicy9jb3JlL3NyYy9saWIvdXRpbHMvYXR0YWNoLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBRSxhQUFhLEVBQUUsTUFBTSxhQUFhLENBQUM7QUFFNUMsT0FBTyxFQUFFLFVBQVUsRUFBRSxNQUFNLGVBQWUsQ0FBQztBQUczQyxNQUFNLFVBQVUsTUFBTSxDQUFDLE1BQW9CLEVBQUUsS0FBYyxFQUFFLFFBQWtCLEVBQUUsRUFBRSxhQUFhLEdBQUcsS0FBSztJQUN2RyxNQUFNLENBQUMsSUFBSSxFQUFFLEdBQUcsU0FBUyxDQUFDLEdBQUcsS0FBSyxDQUFDO0lBQ25DLElBQUksQ0FBQyxJQUFJO1FBQUUsT0FBTztJQUVsQixJQUFJLFNBQVMsQ0FBQyxNQUFNLEtBQUssQ0FBQyxFQUFFLENBQUM7UUFDNUIsSUFBSSxhQUFhO1lBQUUsVUFBVSxDQUFDLE1BQU0sRUFBRSxFQUFFLENBQUMsSUFBSSxDQUFDLEVBQUUsS0FBSyxFQUFFLENBQUMsQ0FBQzs7WUFDcEQsTUFBTSxDQUFDLElBQUksQ0FBQyxHQUFHLEtBQUssQ0FBQztJQUMzQixDQUFDO1NBQU0sQ0FBQztRQUNQLFdBQVcsQ0FBQyxNQUFNLEVBQUUsSUFBSSxDQUFDLENBQUM7UUFDMUIsTUFBTSxDQUFDLE1BQU0sQ0FBQyxJQUFJLENBQUMsRUFBRSxLQUFLLEVBQUUsU0FBUyxFQUFFLGFBQWEsQ0FBQyxDQUFDO0lBQ3ZELENBQUM7QUFDRixDQUFDO0FBRUQsTUFBTSxVQUFVLE1BQU0sQ0FBQyxNQUFvQixFQUFFLEtBQW1CLEVBQUUsVUFBd0M7SUFDekcsTUFBTSxlQUFlLEdBQUcsYUFBYSxDQUFDLEtBQUssQ0FBQyxDQUFDO0lBQzdDLElBQUksZUFBZSxFQUFFLENBQUM7UUFDckIsSUFBSSxLQUFLLENBQUMsT0FBTyxDQUFDLFVBQVUsQ0FBQztZQUFFLE1BQU0sQ0FBQyxNQUFNLEVBQUUsZUFBZSxDQUFDLGNBQWMsRUFBRSxVQUFVLEVBQUUsZUFBZSxDQUFDLEtBQUssQ0FBQyxDQUFDOztZQUMzRyxlQUFlLENBQUMsY0FBNkIsRUFBRSxDQUFDO0lBQ3ZELENBQUM7QUFDRixDQUFDO0FBRUQsU0FBUyxXQUFXLENBQUMsR0FBaUIsRUFBRSxJQUFZO0lBQ25ELElBQUksQ0FBQyxDQUFDLE1BQU0sQ0FBQyxNQUFNLENBQUMsR0FBRyxFQUFFLElBQUksQ0FBQyxJQUFJLE9BQU8sSUFBSSxDQUFDLENBQUMsT0FBTyxDQUFDLEdBQUcsSUFBSSxDQUFDLE9BQU8sQ0FBQyxHQUFHLENBQUMsR0FBRyxFQUFFLElBQUksQ0FBQyxDQUFDLElBQUksR0FBRyxDQUFDLElBQUksQ0FBQyxLQUFLLFNBQVMsRUFBRSxDQUFDO1FBQ25ILEdBQUcsQ0FBQyxJQUFJLENBQUMsR0FBRyxFQUFFLENBQUM7SUFDaEIsQ0FBQztBQUNGLENBQUM7QUFFRCxNQUFNLFVBQVUsb0JBQW9CLENBQ25DLEVBQXdHO0lBRXhHLE9BQU8sQ0FBQyxNQUFNLEVBQUUsS0FBSyxFQUFFLEtBQUssRUFBRSxFQUFFLENBQUMsRUFBRSxDQUFDLEVBQUUsTUFBTSxFQUFFLEtBQUssRUFBRSxLQUFLLEVBQUUsQ0FBQyxDQUFDO0FBQy9ELENBQUMiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBnZXRMb2NhbFN0YXRlIH0gZnJvbSAnLi4vaW5zdGFuY2UnO1xuaW1wb3J0IHsgTmd0QW55UmVjb3JkLCBOZ3RBdHRhY2hGdW5jdGlvbiwgTmd0U3RhdGUgfSBmcm9tICcuLi90eXBlcyc7XG5pbXBvcnQgeyBhcHBseVByb3BzIH0gZnJvbSAnLi9hcHBseS1wcm9wcyc7XG5pbXBvcnQgeyBOZ3RTaWduYWxTdG9yZSB9IGZyb20gJy4vc2lnbmFsLXN0b3JlJztcblxuZXhwb3J0IGZ1bmN0aW9uIGF0dGFjaChvYmplY3Q6IE5ndEFueVJlY29yZCwgdmFsdWU6IHVua25vd24sIHBhdGhzOiBzdHJpbmdbXSA9IFtdLCB1c2VBcHBseVByb3BzID0gZmFsc2UpOiB2b2lkIHtcblx0Y29uc3QgW2Jhc2UsIC4uLnJlbWFpbmluZ10gPSBwYXRocztcblx0aWYgKCFiYXNlKSByZXR1cm47XG5cblx0aWYgKHJlbWFpbmluZy5sZW5ndGggPT09IDApIHtcblx0XHRpZiAodXNlQXBwbHlQcm9wcykgYXBwbHlQcm9wcyhvYmplY3QsIHsgW2Jhc2VdOiB2YWx1ZSB9KTtcblx0XHRlbHNlIG9iamVjdFtiYXNlXSA9IHZhbHVlO1xuXHR9IGVsc2Uge1xuXHRcdGFzc2lnbkVtcHR5KG9iamVjdCwgYmFzZSk7XG5cdFx0YXR0YWNoKG9iamVjdFtiYXNlXSwgdmFsdWUsIHJlbWFpbmluZywgdXNlQXBwbHlQcm9wcyk7XG5cdH1cbn1cblxuZXhwb3J0IGZ1bmN0aW9uIGRldGFjaChwYXJlbnQ6IE5ndEFueVJlY29yZCwgY2hpbGQ6IE5ndEFueVJlY29yZCwgYXR0YWNoUHJvcDogc3RyaW5nW10gfCBOZ3RBdHRhY2hGdW5jdGlvbikge1xuXHRjb25zdCBjaGlsZExvY2FsU3RhdGUgPSBnZXRMb2NhbFN0YXRlKGNoaWxkKTtcblx0aWYgKGNoaWxkTG9jYWxTdGF0ZSkge1xuXHRcdGlmIChBcnJheS5pc0FycmF5KGF0dGFjaFByb3ApKSBhdHRhY2gocGFyZW50LCBjaGlsZExvY2FsU3RhdGUucHJldmlvdXNBdHRhY2gsIGF0dGFjaFByb3AsIGNoaWxkTG9jYWxTdGF0ZS5pc1Jhdyk7XG5cdFx0ZWxzZSAoY2hpbGRMb2NhbFN0YXRlLnByZXZpb3VzQXR0YWNoIGFzICgpID0+IHZvaWQpKCk7XG5cdH1cbn1cblxuZnVuY3Rpb24gYXNzaWduRW1wdHkob2JqOiBOZ3RBbnlSZWNvcmQsIGJhc2U6IHN0cmluZykge1xuXHRpZiAoKCFPYmplY3QuaGFzT3duKG9iaiwgYmFzZSkgJiYgUmVmbGVjdCAmJiAhIVJlZmxlY3QuaGFzICYmICFSZWZsZWN0LmhhcyhvYmosIGJhc2UpKSB8fCBvYmpbYmFzZV0gPT09IHVuZGVmaW5lZCkge1xuXHRcdG9ialtiYXNlXSA9IHt9O1xuXHR9XG59XG5cbmV4cG9ydCBmdW5jdGlvbiBjcmVhdGVBdHRhY2hGdW5jdGlvbjxUQ2hpbGQgPSBhbnksIFRQYXJlbnQgPSBhbnk+KFxuXHRjYjogKHBhcmFtczogeyBwYXJlbnQ6IFRQYXJlbnQ7IGNoaWxkOiBUQ2hpbGQ7IHN0b3JlOiBOZ3RTaWduYWxTdG9yZTxOZ3RTdGF0ZT4gfSkgPT4gKCgpID0+IHZvaWQpIHwgdm9pZCxcbik6IE5ndEF0dGFjaEZ1bmN0aW9uPFRDaGlsZCwgVFBhcmVudD4ge1xuXHRyZXR1cm4gKHBhcmVudCwgY2hpbGQsIHN0b3JlKSA9PiBjYih7IHBhcmVudCwgY2hpbGQsIHN0b3JlIH0pO1xufVxuIl19
46
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiYXR0YWNoLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vbGlicy9jb3JlL3NyYy9saWIvdXRpbHMvYXR0YWNoLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBRSxhQUFhLEVBQUUsTUFBTSxhQUFhLENBQUM7QUFFNUMsT0FBTyxFQUFFLFVBQVUsRUFBRSxlQUFlLEVBQUUsTUFBTSxlQUFlLENBQUM7QUFHNUQsTUFBTSxVQUFVLE1BQU0sQ0FBQyxNQUFvQixFQUFFLEtBQWMsRUFBRSxRQUFrQixFQUFFLEVBQUUsYUFBYSxHQUFHLEtBQUs7SUFDdkcsTUFBTSxDQUFDLElBQUksRUFBRSxHQUFHLFNBQVMsQ0FBQyxHQUFHLEtBQUssQ0FBQztJQUNuQyxJQUFJLENBQUMsSUFBSTtRQUFFLE9BQU87SUFFbEIsSUFBSSxTQUFTLENBQUMsTUFBTSxLQUFLLENBQUMsRUFBRSxDQUFDO1FBQzVCLElBQUksYUFBYTtZQUFFLFVBQVUsQ0FBQyxNQUFNLEVBQUUsRUFBRSxDQUFDLElBQUksQ0FBQyxFQUFFLEtBQUssRUFBRSxDQUFDLENBQUM7O1lBQ3BELE1BQU0sQ0FBQyxJQUFJLENBQUMsR0FBRyxLQUFLLENBQUM7SUFDM0IsQ0FBQztTQUFNLENBQUM7UUFDUCxXQUFXLENBQUMsTUFBTSxFQUFFLElBQUksRUFBRSxhQUFhLENBQUMsQ0FBQztRQUN6QyxNQUFNLENBQUMsTUFBTSxDQUFDLElBQUksQ0FBQyxFQUFFLEtBQUssRUFBRSxTQUFTLEVBQUUsYUFBYSxDQUFDLENBQUM7SUFDdkQsQ0FBQztBQUNGLENBQUM7QUFFRCxNQUFNLFVBQVUsTUFBTSxDQUFDLE1BQW9CLEVBQUUsS0FBbUIsRUFBRSxVQUF3QztJQUN6RyxNQUFNLGVBQWUsR0FBRyxhQUFhLENBQUMsS0FBSyxDQUFDLENBQUM7SUFDN0MsSUFBSSxlQUFlLEVBQUUsQ0FBQztRQUNyQixJQUFJLEtBQUssQ0FBQyxPQUFPLENBQUMsVUFBVSxDQUFDO1lBQUUsTUFBTSxDQUFDLE1BQU0sRUFBRSxlQUFlLENBQUMsY0FBYyxFQUFFLFVBQVUsRUFBRSxlQUFlLENBQUMsS0FBSyxDQUFDLENBQUM7O1lBQzNHLGVBQWUsQ0FBQyxjQUE2QixFQUFFLENBQUM7SUFDdkQsQ0FBQztBQUNGLENBQUM7QUFFRCxTQUFTLFdBQVcsQ0FBQyxHQUFpQixFQUFFLElBQVksRUFBRSw4QkFBOEIsR0FBRyxLQUFLO0lBQzNGLElBQUksQ0FBQyxDQUFDLE1BQU0sQ0FBQyxNQUFNLENBQUMsR0FBRyxFQUFFLElBQUksQ0FBQyxJQUFJLE9BQU8sSUFBSSxDQUFDLENBQUMsT0FBTyxDQUFDLEdBQUcsSUFBSSxDQUFDLE9BQU8sQ0FBQyxHQUFHLENBQUMsR0FBRyxFQUFFLElBQUksQ0FBQyxDQUFDLElBQUksR0FBRyxDQUFDLElBQUksQ0FBQyxLQUFLLFNBQVMsRUFBRSxDQUFDO1FBQ25ILEdBQUcsQ0FBQyxJQUFJLENBQUMsR0FBRyxFQUFFLENBQUM7SUFDaEIsQ0FBQztJQUVELElBQUksOEJBQThCLEVBQUUsQ0FBQztRQUNwQyxNQUFNLFVBQVUsR0FBRyxhQUFhLENBQUMsR0FBRyxDQUFDLElBQUksQ0FBQyxDQUFDLENBQUM7UUFDNUMsMkNBQTJDO1FBQzNDLElBQUksVUFBVTtZQUFFLE9BQU87UUFFdkIsTUFBTSxnQkFBZ0IsR0FBRyxhQUFhLENBQUMsR0FBRyxDQUFDLENBQUM7UUFDNUMsK0NBQStDO1FBQy9DLElBQUksQ0FBQyxnQkFBZ0I7WUFBRSxPQUFPO1FBRTlCLE1BQU0sQ0FBQyxNQUFNLENBQUMsR0FBRyxDQUFDLElBQUksQ0FBQyxFQUFFLEVBQUUsQ0FBQyxlQUFlLENBQUMsRUFBRSxnQkFBZ0IsQ0FBQyxLQUFLLEVBQUUsQ0FBQyxDQUFDO0lBQ3pFLENBQUM7QUFDRixDQUFDO0FBRUQsTUFBTSxVQUFVLG9CQUFvQixDQUNuQyxFQUF3RztJQUV4RyxPQUFPLENBQUMsTUFBTSxFQUFFLEtBQUssRUFBRSxLQUFLLEVBQUUsRUFBRSxDQUFDLEVBQUUsQ0FBQyxFQUFFLE1BQU0sRUFBRSxLQUFLLEVBQUUsS0FBSyxFQUFFLENBQUMsQ0FBQztBQUMvRCxDQUFDIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgZ2V0TG9jYWxTdGF0ZSB9IGZyb20gJy4uL2luc3RhbmNlJztcbmltcG9ydCB7IE5ndEFueVJlY29yZCwgTmd0QXR0YWNoRnVuY3Rpb24sIE5ndFN0YXRlIH0gZnJvbSAnLi4vdHlwZXMnO1xuaW1wb3J0IHsgYXBwbHlQcm9wcywgTkdUX0FQUExZX1BST1BTIH0gZnJvbSAnLi9hcHBseS1wcm9wcyc7XG5pbXBvcnQgeyBOZ3RTaWduYWxTdG9yZSB9IGZyb20gJy4vc2lnbmFsLXN0b3JlJztcblxuZXhwb3J0IGZ1bmN0aW9uIGF0dGFjaChvYmplY3Q6IE5ndEFueVJlY29yZCwgdmFsdWU6IHVua25vd24sIHBhdGhzOiBzdHJpbmdbXSA9IFtdLCB1c2VBcHBseVByb3BzID0gZmFsc2UpOiB2b2lkIHtcblx0Y29uc3QgW2Jhc2UsIC4uLnJlbWFpbmluZ10gPSBwYXRocztcblx0aWYgKCFiYXNlKSByZXR1cm47XG5cblx0aWYgKHJlbWFpbmluZy5sZW5ndGggPT09IDApIHtcblx0XHRpZiAodXNlQXBwbHlQcm9wcykgYXBwbHlQcm9wcyhvYmplY3QsIHsgW2Jhc2VdOiB2YWx1ZSB9KTtcblx0XHRlbHNlIG9iamVjdFtiYXNlXSA9IHZhbHVlO1xuXHR9IGVsc2Uge1xuXHRcdGFzc2lnbkVtcHR5KG9iamVjdCwgYmFzZSwgdXNlQXBwbHlQcm9wcyk7XG5cdFx0YXR0YWNoKG9iamVjdFtiYXNlXSwgdmFsdWUsIHJlbWFpbmluZywgdXNlQXBwbHlQcm9wcyk7XG5cdH1cbn1cblxuZXhwb3J0IGZ1bmN0aW9uIGRldGFjaChwYXJlbnQ6IE5ndEFueVJlY29yZCwgY2hpbGQ6IE5ndEFueVJlY29yZCwgYXR0YWNoUHJvcDogc3RyaW5nW10gfCBOZ3RBdHRhY2hGdW5jdGlvbikge1xuXHRjb25zdCBjaGlsZExvY2FsU3RhdGUgPSBnZXRMb2NhbFN0YXRlKGNoaWxkKTtcblx0aWYgKGNoaWxkTG9jYWxTdGF0ZSkge1xuXHRcdGlmIChBcnJheS5pc0FycmF5KGF0dGFjaFByb3ApKSBhdHRhY2gocGFyZW50LCBjaGlsZExvY2FsU3RhdGUucHJldmlvdXNBdHRhY2gsIGF0dGFjaFByb3AsIGNoaWxkTG9jYWxTdGF0ZS5pc1Jhdyk7XG5cdFx0ZWxzZSAoY2hpbGRMb2NhbFN0YXRlLnByZXZpb3VzQXR0YWNoIGFzICgpID0+IHZvaWQpKCk7XG5cdH1cbn1cblxuZnVuY3Rpb24gYXNzaWduRW1wdHkob2JqOiBOZ3RBbnlSZWNvcmQsIGJhc2U6IHN0cmluZywgc2hvdWxkQXNzaWduU3RvcmVGb3JBcHBseVByb3BzID0gZmFsc2UpIHtcblx0aWYgKCghT2JqZWN0Lmhhc093bihvYmosIGJhc2UpICYmIFJlZmxlY3QgJiYgISFSZWZsZWN0LmhhcyAmJiAhUmVmbGVjdC5oYXMob2JqLCBiYXNlKSkgfHwgb2JqW2Jhc2VdID09PSB1bmRlZmluZWQpIHtcblx0XHRvYmpbYmFzZV0gPSB7fTtcblx0fVxuXG5cdGlmIChzaG91bGRBc3NpZ25TdG9yZUZvckFwcGx5UHJvcHMpIHtcblx0XHRjb25zdCBsb2NhbFN0YXRlID0gZ2V0TG9jYWxTdGF0ZShvYmpbYmFzZV0pO1xuXHRcdC8vIGlmIHdlIGFscmVhZHkgaGF2ZSBsb2NhbCBzdGF0ZSwgYmFpbCBvdXRcblx0XHRpZiAobG9jYWxTdGF0ZSkgcmV0dXJuO1xuXG5cdFx0Y29uc3QgcGFyZW50TG9jYWxTdGF0ZSA9IGdldExvY2FsU3RhdGUob2JqKTtcblx0XHQvLyBpZiBwYXJlbnQgZG9lc24ndCBoYXZlIGxvY2FsIHN0YXRlLCBiYWlsIG91dFxuXHRcdGlmICghcGFyZW50TG9jYWxTdGF0ZSkgcmV0dXJuO1xuXG5cdFx0T2JqZWN0LmFzc2lnbihvYmpbYmFzZV0sIHsgW05HVF9BUFBMWV9QUk9QU106IHBhcmVudExvY2FsU3RhdGUuc3RvcmUgfSk7XG5cdH1cbn1cblxuZXhwb3J0IGZ1bmN0aW9uIGNyZWF0ZUF0dGFjaEZ1bmN0aW9uPFRDaGlsZCA9IGFueSwgVFBhcmVudCA9IGFueT4oXG5cdGNiOiAocGFyYW1zOiB7IHBhcmVudDogVFBhcmVudDsgY2hpbGQ6IFRDaGlsZDsgc3RvcmU6IE5ndFNpZ25hbFN0b3JlPE5ndFN0YXRlPiB9KSA9PiAoKCkgPT4gdm9pZCkgfCB2b2lkLFxuKTogTmd0QXR0YWNoRnVuY3Rpb248VENoaWxkLCBUUGFyZW50PiB7XG5cdHJldHVybiAocGFyZW50LCBjaGlsZCwgc3RvcmUpID0+IGNiKHsgcGFyZW50LCBjaGlsZCwgc3RvcmUgfSk7XG59XG4iXX0=
@@ -3,7 +3,7 @@ import { untracked, computed, signal, ElementRef, input, inject, ViewContainerRe
3
3
  import { takeUntilDestroyed, outputFromObservable, toObservable } from '@angular/core/rxjs-interop';
4
4
  import { injectAutoEffect } from 'ngxtension/auto-effect';
5
5
  import { provideResizeOptions, NgxResize } from 'ngxtension/resize';
6
- import { MathUtils, WebGLRenderer, OrthographicCamera, PerspectiveCamera, Vector3, Vector2, Clock, Layers, Color, ColorManagement, Texture, RGBAFormat, UnsignedByteType, Raycaster, Scene, PCFSoftShadowMap, BasicShadowMap, PCFShadowMap, VSMShadowMap, NoToneMapping, ACESFilmicToneMapping, Vector4 } from 'three';
6
+ import { MathUtils, WebGLRenderer, OrthographicCamera, PerspectiveCamera, Vector3, Vector2, Clock, Layers, Color, ColorManagement, Texture, RGBAFormat, UnsignedByteType, EventDispatcher, Raycaster, Scene, PCFSoftShadowMap, BasicShadowMap, PCFShadowMap, VSMShadowMap, NoToneMapping, ACESFilmicToneMapping, Vector4 } from 'three';
7
7
  import { DOCUMENT } from '@angular/common';
8
8
  import { Subject, filter, map } from 'rxjs';
9
9
  import { createInjectionToken } from 'ngxtension/create-injection-token';
@@ -756,6 +756,7 @@ const SPECIAL_EVENTS = {
756
756
  UPDATED: 'updated',
757
757
  ATTACHED: 'attached',
758
758
  };
759
+ const THREE_NATIVE_EVENTS = ['added', 'removed', 'childadded', 'childremoved', 'disposed'];
759
760
 
760
761
  class NgtArgs {
761
762
  constructor() {
@@ -1142,6 +1143,9 @@ function diffProps(instance, props) {
1142
1143
  }
1143
1144
  return changes;
1144
1145
  }
1146
+ // NOTE: this is a workaround to give the instance a change to have the store from the parent.
1147
+ // we clear this property after the applyProps is done
1148
+ const NGT_APPLY_PROPS = '__ngt_apply_props__';
1145
1149
  // This function applies a set of changes to the instance
1146
1150
  function applyProps(instance, props) {
1147
1151
  // if props is empty
@@ -1149,7 +1153,7 @@ function applyProps(instance, props) {
1149
1153
  return instance;
1150
1154
  // filter equals, and reserved props
1151
1155
  const localState = getLocalState(instance);
1152
- const rootState = localState?.store?.snapshot ?? {};
1156
+ const rootState = localState?.store?.snapshot ?? instance[NGT_APPLY_PROPS]?.snapshot ?? {};
1153
1157
  const changes = diffProps(instance, props);
1154
1158
  for (let i = 0; i < changes.length; i++) {
1155
1159
  let [key, value] = changes[i];
@@ -1238,6 +1242,10 @@ function applyProps(instance, props) {
1238
1242
  if (parent && localState?.onUpdate && changes.length) {
1239
1243
  localState.onUpdate(instance);
1240
1244
  }
1245
+ // clearing the intermediate store from the instance
1246
+ if (instance[NGT_APPLY_PROPS]) {
1247
+ delete instance[NGT_APPLY_PROPS];
1248
+ }
1241
1249
  return instance;
1242
1250
  }
1243
1251
 
@@ -1311,7 +1319,7 @@ function attach(object, value, paths = [], useApplyProps = false) {
1311
1319
  object[base] = value;
1312
1320
  }
1313
1321
  else {
1314
- assignEmpty(object, base);
1322
+ assignEmpty(object, base, useApplyProps);
1315
1323
  attach(object[base], value, remaining, useApplyProps);
1316
1324
  }
1317
1325
  }
@@ -1324,10 +1332,21 @@ function detach(parent, child, attachProp) {
1324
1332
  childLocalState.previousAttach();
1325
1333
  }
1326
1334
  }
1327
- function assignEmpty(obj, base) {
1335
+ function assignEmpty(obj, base, shouldAssignStoreForApplyProps = false) {
1328
1336
  if ((!Object.hasOwn(obj, base) && Reflect && !!Reflect.has && !Reflect.has(obj, base)) || obj[base] === undefined) {
1329
1337
  obj[base] = {};
1330
1338
  }
1339
+ if (shouldAssignStoreForApplyProps) {
1340
+ const localState = getLocalState(obj[base]);
1341
+ // if we already have local state, bail out
1342
+ if (localState)
1343
+ return;
1344
+ const parentLocalState = getLocalState(obj);
1345
+ // if parent doesn't have local state, bail out
1346
+ if (!parentLocalState)
1347
+ return;
1348
+ Object.assign(obj[base], { [NGT_APPLY_PROPS]: parentLocalState.store });
1349
+ }
1331
1350
  }
1332
1351
  function createAttachFunction(cb) {
1333
1352
  return (parent, child, store) => cb({ parent, child, store });
@@ -1500,6 +1519,17 @@ function processThreeEvent(instance, priority, eventName, callback) {
1500
1519
  lS.onUpdate = undefined;
1501
1520
  };
1502
1521
  }
1522
+ if (THREE_NATIVE_EVENTS.includes(eventName) && instance instanceof EventDispatcher) {
1523
+ // NOTE: rename to dispose because that's the event type, not disposed.
1524
+ if (eventName === 'disposed') {
1525
+ eventName = 'dispose';
1526
+ }
1527
+ if (instance.parent && (eventName === 'added' || eventName === 'removed')) {
1528
+ callback({ type: eventName, target: instance });
1529
+ }
1530
+ instance.addEventListener(eventName, callback);
1531
+ return () => instance.removeEventListener(eventName, callback);
1532
+ }
1503
1533
  if (!lS.handlers)
1504
1534
  lS.handlers = {};
1505
1535
  // try to get the previous handler. compound might have one, the THREE object might also have one with the same name
@@ -2553,15 +2583,15 @@ class NgtSelect {
2553
2583
  const autoEffect = injectAutoEffect();
2554
2584
  afterNextRender(() => {
2555
2585
  autoEffect(() => {
2586
+ const enabled = this.enabled();
2587
+ if (!enabled)
2588
+ return;
2556
2589
  const host = elementRef.nativeElement;
2557
2590
  if (!host)
2558
2591
  return;
2559
2592
  const localState = getLocalState(host);
2560
2593
  if (!localState)
2561
2594
  return;
2562
- const enabled = this.enabled();
2563
- if (!enabled)
2564
- return;
2565
2595
  // ngt-mesh[ngtSelect]
2566
2596
  if (host.type === 'Mesh') {
2567
2597
  selection.update((prev) => [...prev, host]);
@@ -3181,5 +3211,5 @@ const vector4 = createVectorComputed(Vector4);
3181
3211
  * Generated bundle index. Do not edit.
3182
3212
  */
3183
3213
 
3184
- export { HTML, NGT_STORE, NgtArgs, NgtCanvas, NgtHTML, NgtHexify, NgtObjectEvents, NgtObjectEventsHostDirective, NgtPortal, NgtPortalBeforeRender, NgtPortalContent, NgtRenderer, NgtRendererFactory, NgtRoutedScene, NgtSelect, NgtSelection, ROUTED_SCENE, addAfterEffect, addEffect, addTail, applyProps, attach, checkNeedsUpdate, checkUpdate, createAttachFunction, detach, dispose, extend, flushGlobalEffects, getLocalState, injectBeforeRender, injectCanvasRootInitializer, injectLoader, injectLoop, injectNonNullish$, injectObjectEvents, injectStore, invalidateInstance, is, makeCameraInstance, makeDpr, makeId, makeObjectGraph, makeRendererInstance, merge, omit, pick, prepare, privateKeys, provideHTMLDomElement, provideNgtRenderer, provideStore, resolveRef, roots, signalStore, updateCamera, vector2, vector3, vector4 };
3214
+ export { HTML, NGT_APPLY_PROPS, NGT_STORE, NgtArgs, NgtCanvas, NgtHTML, NgtHexify, NgtObjectEvents, NgtObjectEventsHostDirective, NgtPortal, NgtPortalBeforeRender, NgtPortalContent, NgtRenderer, NgtRendererFactory, NgtRoutedScene, NgtSelect, NgtSelection, ROUTED_SCENE, addAfterEffect, addEffect, addTail, applyProps, attach, checkNeedsUpdate, checkUpdate, createAttachFunction, detach, dispose, extend, flushGlobalEffects, getLocalState, injectBeforeRender, injectCanvasRootInitializer, injectLoader, injectLoop, injectNonNullish$, injectObjectEvents, injectStore, invalidateInstance, is, makeCameraInstance, makeDpr, makeId, makeObjectGraph, makeRendererInstance, merge, omit, pick, prepare, privateKeys, provideHTMLDomElement, provideNgtRenderer, provideStore, resolveRef, roots, signalStore, updateCamera, vector2, vector3, vector4 };
3185
3215
  //# sourceMappingURL=angular-three.mjs.map