@needle-tools/engine 4.8.2-next.f60a325 → 4.8.2

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/CHANGELOG.md CHANGED
@@ -4,6 +4,11 @@ All notable changes to this package will be documented in this file.
4
4
  The format is based on [Keep a Changelog](http://keepachangelog.com/en/1.0.0/)
5
5
  and this project adheres to [Semantic Versioning](http://semver.org/spec/v2.0.0.html).
6
6
 
7
+ ## [4.8.2] - 2025-08-18
8
+ - Change: Clamp devicePixelRatio to `2` by default. This can be overriden by setting the Needle Engine Context's `devicePixelRatio` to e.g. `window.devicePixelRatio`
9
+ - Update `@needle-tools/gltf-progressive` dependency to expose `overrideLodLevel`. This can be used to override which LOD level will be loaded instead of calculating the LOD level based on screen coverage:
10
+ For example `context.lodsManager.manager!.overrideLodLevel = 0;` will always load the highest quality mesh + texture
11
+
7
12
  ## [4.8.1] - 2025-08-14
8
13
  - Fix: SceneSwitcher dispose of background and environment texture causing lighting issues when `useSceneLight` is disabled in SceneSwitcher component
9
14
  - Fix: Detection of model/gltf+json by file header
@@ -142,7 +142,7 @@ Open this page to get the console: `+e.toString())}const s=exports.DeviceUtiliti
142
142
  #__vconsole .vc-mask {
143
143
  overflow: hidden;
144
144
  }
145
- `,Qi?.prepend(i),s===!0&&Fp()<=0&&bb(),console.log("🌵 Debug console has loaded")}},e.onerror=()=>{console.warn("🌵 Debug console failed to load."+(window.crossOriginIsolated?"This page is using cross-origin isolation, so external scripts can't be loaded.":"")),Ba=!1,ni=null},e.src="https://cdn.jsdelivr.net/npm/vconsole@3.9.1/dist/vconsole.min.js",document.body.appendChild(e)}function qx(){if(!globalThis.VConsole)return;const s=new VConsole.VConsolePlugin("needle-console","🌵 Inspect glTF"),e=()=>document.querySelector("#__vc_plug_"+s._id+" iframe");return s.on("renderTab",function(t){const i=globalThis["needle:codegen_files"];if(!i||i.length===0)return;let n=globalThis["needle:codegen_files"][0];const o=n.indexOf("?");o>-1&&(n=n.substring(0,o));const a=location.protocol+"//"+location.host+location.pathname+"/"+n,l=encodeURIComponent(a);s.fullUrl="https://viewer.needle.tools?inspect&file="+l;var h='<iframe src="" style="width: 100%; height: 99%; border: none;"></iframe>';t(h)}),s.on("show",function(){const t=e();t&&t.src!==s.fullUrl&&(t.src=s.fullUrl)}),s.on("hide",function(){const t=e();t&&(t.src="")}),s.on("addTopBar",function(t){var i=new Array;i.push({name:"Open in new window ↗",onClick:function(n){window.open(s.fullUrl,"_blank"),ni?.hide()}}),i.push({name:"Reload",onClick:function(n){const o=e();o&&(o.src=s.fullUrl)}}),i.push({name:"Fullscreen",onClick:function(n){const o=e();o.requestFullscreen?o.requestFullscreen():o.webkitRequestFullscreen instanceof Function&&o.webkitRequestFullscreen()}}),t(i)}),s}function Xx(){const s=document.querySelector("#__vconsole .vc-switch");return s||null}function Qx(){const s=document.querySelector("#__vconsole");return s||null}const xb=w("debugdefines");Zs('if(!globalThis["NEEDLE_ENGINE_VERSION"]) globalThis["NEEDLE_ENGINE_VERSION"] = "0.0.0";');Zs('if(!globalThis["NEEDLE_ENGINE_GENERATOR"]) globalThis["NEEDLE_ENGINE_GENERATOR"] = "unknown";');Zs('if(!globalThis["NEEDLE_PROJECT_BUILD_TIME"]) globalThis["NEEDLE_PROJECT_BUILD_TIME"] = "unknown";');Zs('if(!globalThis["NEEDLE_PUBLIC_KEY"]) globalThis["NEEDLE_PUBLIC_KEY"] = "unknown";');Zs('globalThis["__NEEDLE_ENGINE_VERSION__"] = "4.8.2-alpha";');Zs('globalThis["__NEEDLE_ENGINE_GENERATOR__"] = "undefined";');Zs('globalThis["__NEEDLE_PROJECT_BUILD_TIME__"] = "Fri Aug 15 2025 11:22:58 GMT+0000 (Coordinated Universal Time)";');Zs('globalThis["__NEEDLE_PUBLIC_KEY__"] = "'+NEEDLE_PUBLIC_KEY+'";');const Ji="4.8.2-alpha",kd="undefined",qp="Fri Aug 15 2025 11:22:58 GMT+0000 (Coordinated Universal Time)";xb&&console.log(`Engine version: ${Ji} (generator: ${kd})
145
+ `,Qi?.prepend(i),s===!0&&Fp()<=0&&bb(),console.log("🌵 Debug console has loaded")}},e.onerror=()=>{console.warn("🌵 Debug console failed to load."+(window.crossOriginIsolated?"This page is using cross-origin isolation, so external scripts can't be loaded.":"")),Ba=!1,ni=null},e.src="https://cdn.jsdelivr.net/npm/vconsole@3.9.1/dist/vconsole.min.js",document.body.appendChild(e)}function qx(){if(!globalThis.VConsole)return;const s=new VConsole.VConsolePlugin("needle-console","🌵 Inspect glTF"),e=()=>document.querySelector("#__vc_plug_"+s._id+" iframe");return s.on("renderTab",function(t){const i=globalThis["needle:codegen_files"];if(!i||i.length===0)return;let n=globalThis["needle:codegen_files"][0];const o=n.indexOf("?");o>-1&&(n=n.substring(0,o));const a=location.protocol+"//"+location.host+location.pathname+"/"+n,l=encodeURIComponent(a);s.fullUrl="https://viewer.needle.tools?inspect&file="+l;var h='<iframe src="" style="width: 100%; height: 99%; border: none;"></iframe>';t(h)}),s.on("show",function(){const t=e();t&&t.src!==s.fullUrl&&(t.src=s.fullUrl)}),s.on("hide",function(){const t=e();t&&(t.src="")}),s.on("addTopBar",function(t){var i=new Array;i.push({name:"Open in new window ↗",onClick:function(n){window.open(s.fullUrl,"_blank"),ni?.hide()}}),i.push({name:"Reload",onClick:function(n){const o=e();o&&(o.src=s.fullUrl)}}),i.push({name:"Fullscreen",onClick:function(n){const o=e();o.requestFullscreen?o.requestFullscreen():o.webkitRequestFullscreen instanceof Function&&o.webkitRequestFullscreen()}}),t(i)}),s}function Xx(){const s=document.querySelector("#__vconsole .vc-switch");return s||null}function Qx(){const s=document.querySelector("#__vconsole");return s||null}const xb=w("debugdefines");Zs('if(!globalThis["NEEDLE_ENGINE_VERSION"]) globalThis["NEEDLE_ENGINE_VERSION"] = "0.0.0";');Zs('if(!globalThis["NEEDLE_ENGINE_GENERATOR"]) globalThis["NEEDLE_ENGINE_GENERATOR"] = "unknown";');Zs('if(!globalThis["NEEDLE_PROJECT_BUILD_TIME"]) globalThis["NEEDLE_PROJECT_BUILD_TIME"] = "unknown";');Zs('if(!globalThis["NEEDLE_PUBLIC_KEY"]) globalThis["NEEDLE_PUBLIC_KEY"] = "unknown";');Zs('globalThis["__NEEDLE_ENGINE_VERSION__"] = "4.8.2";');Zs('globalThis["__NEEDLE_ENGINE_GENERATOR__"] = "undefined";');Zs('globalThis["__NEEDLE_PROJECT_BUILD_TIME__"] = "Mon Aug 18 2025 09:21:15 GMT+0000 (Coordinated Universal Time)";');Zs('globalThis["__NEEDLE_PUBLIC_KEY__"] = "'+NEEDLE_PUBLIC_KEY+'";');const Ji="4.8.2",kd="undefined",qp="Mon Aug 18 2025 09:21:15 GMT+0000 (Coordinated Universal Time)";xb&&console.log(`Engine version: ${Ji} (generator: ${kd})
146
146
  Project built at ${qp}`);const Br=NEEDLE_PUBLIC_KEY,rs="needle_isActiveInHierarchy",xo="builtin_components",xl="needle_editor_guid";function Zs(s){try{(0,eval)(s)}catch(e){xb&&console.error(e)}}let Sb,ny=null;function en(){return Sb}function Xp(s){if(s==null){console.warn("Oh no: someone tried registering a non-existend gltf-loader. When you see this log it might mean that needle-engine is being imported multiple times. Please check your project setup.");return}ny!==s&&(ny=s,Sb=new s)}const si=Symbol("shadowDomOwner"),Yx=w("debugpatch");function Rd(s,e,t,i){const n=Yx===e;if(!t&&!i)return;const o=e+"___needle";Zx(s,e,t,i);const r=Object.getOwnPropertyDescriptor(s,e),a=s[e];n&&console.log("Patch",s.constructor.name,e,r,a),r?(n&&console.log("Apply patch with existing descriptor",s.constructor.name,e,r),typeof r.value=="function"&&(s[e]=oy(r.value,s,e))):(n&&console.log("Create patch with new property",s.constructor.name,e,r),Object.defineProperty(s,e,{set:function(l){if(typeof l=="function")this[o]=oy(l,s,e);else{const h=this[o];Cb(s,e,this,h,l),this[o]=l,Pb(s,e,this,h,l)}},get:function(){const l=this[o];return typeof l=="function"&&l[o]?l[o]:l}}))}function Kx(s,e,t){const i=Qp(s,e);if(i)for(let n=i.length-1;n>=0;n--){const o=i[n];o.prefix===t&&(o.prefix=null),o.postfix===t&&(o.postfix=null),!o.prefix&&!o.postfix&&i.splice(n,1)}}const sy=Symbol("Needle:Patches:WrappedFunction");function oy(s,e,t){if(s[sy])return s;const i=function(...n){Cb(e,t,this,...n);const o=s.apply(this,n);return Pb(e,t,this,o,...n),o};return i[sy]=!0,i}const Eh="Needle:Patches";function qf(){return globalThis[Eh]||(globalThis[Eh]=new WeakMap),globalThis[Eh]}function Qp(s,e){const t=qf().get(s);return t?t.get(e):null}function Zx(s,e,t,i){let n=qf().get(s);n||(n=new Map,qf().set(s,n));let o=n.get(e);o||(o=[],n.set(e,o)),o.push({prefix:t,postfix:i})}function Cb(s,e,t,...i){if(!t)return;const n=Qp(s,e);if(n)for(const o of n)o.prefix?.call(t,...i)}function Pb(s,e,t,i,...n){if(!t)return;const o=Qp(s,e);if(o)for(const r of o)r.postfix?.call(t,i,...n)}const ea=[];function Ed(s){ea.indexOf(s)===-1&&ea.push(s)}function Jx(s){const e=ea.indexOf(s);e!==-1&&ea.splice(e,1)}const ta=[];function Yp(s){ta.indexOf(s)===-1&&ta.push(s)}function eS(s){const e=ta.indexOf(s);e!==-1&&ta.splice(e,1)}function Mb(s){globalThis.dispatchEvent(new CustomEvent("needle-xrsession-start",{detail:s}));for(let e=0;e<ea.length;e++)ea[e](s)}function Ob(s){globalThis.dispatchEvent(new CustomEvent("needle-xrsession-end",{detail:s}));for(let e=0;e<ta.length;e++)ta[e](s)}const He=w("debuginput");var Td=(s=>(s.Mouse="mouse",s.Touch="touch",s.Controller="controller",s.Hand="hand",s))(Td||{}),we=(s=>(s.PointerDown="pointerdown",s.PointerUp="pointerup",s.PointerMove="pointermove",s.KeyDown="keydown",s.KeyUp="keyup",s.KeyPressed="keypress",s))(we||{});class Yn extends PointerEvent{clientZ;deviceIndex;origin;source;mode;get isSpatial(){return this.mode!="screen"}get ray(){return this._ray||(this._ray=new c.Ray(this.space.worldPosition.clone(),this.space.worldForward.clone())),this._ray}set ray(e){this._ray=e}get hasRay(){return this._ray!==void 0}_ray;space;isClick=!1;isDoubleClick=!1;get used(){return this._used}_used=!1;use(){this._used=!0}get pointerId(){return this._pointerid}_pointerid;get pointerType(){return this._pointerType}_pointerType;get type(){return this._type}_type;metadata={};intersections=new Array;constructor(e,t,i){super(e,i),this.clientZ=i.clientZ,this._pointerid=i.pointerId,this._pointerType=i.pointerType,this._type=e,this.deviceIndex=i.deviceIndex,this.origin=i.origin,this.source=t,this.mode=i.mode,this._ray=i.ray,this.space=i.device}_immediatePropagationStopped=!1;get immediatePropagationStopped(){return this._immediatePropagationStopped}_propagationStopped=!1;get propagationStopped(){return this._immediatePropagationStopped||this._propagationStopped}stopImmediatePropagation(){this._immediatePropagationStopped=!0,super.stopImmediatePropagation(),this.source?.stopImmediatePropagation()}stopPropagation(){this._propagationStopped=!0,super.stopPropagation(),this.source?.stopPropagation(),He&&console.warn("Stop propagation...",this.pointerId,this.pointerType)}}class nl extends KeyboardEvent{source;constructor(e,t,i){super(e,i),this.source=t}stopImmediatePropagation(){super.stopImmediatePropagation(),this.source?.stopImmediatePropagation()}}class tS{key;keyType;source;constructor(e){this.key=e.key,this.keyType=e.type,this.source=e}}var $t=(s=>(s[s.Early=-100]="Early",s[s.Default=0]="Default",s[s.Late=100]="Late",s))($t||{});class kb{_eventListeners={};addEventListener(e,t,i){if(this._eventListeners[e]||(this._eventListeners[e]=[]),!t||typeof t!="function"){console.error("Invalid call to addEventListener: callback is required and must be a function!");return}i?i={...i}:i={};let n=0;i?.queue!=null&&(n=i.queue);const o=this._eventListeners[e],r=o.find(a=>a.priority===n);r?r.listeners.push({callback:t,options:i}):(o.push({priority:n,listeners:[{callback:t,options:i}]}),o.sort((a,l)=>a.priority-l.priority))}removeEventListener(e,t,i){if(!this._eventListeners[e]||!t)return;const n=this._eventListeners[e];if(i?.queue!=null){const o=n.find(a=>a.priority===i.queue);if(!o)return;const r=o.listeners.findIndex(a=>a.callback===t);r>=0&&o.listeners.splice(r,1)}else for(const o of n){const r=o.listeners.findIndex(a=>a.callback===t);r>=0&&o.listeners.splice(r,1)}}dispatchEvent(e){let t=!1;if(e instanceof nl){const i=this._eventListeners[e.type];if(i)for(const n of i)for(let o=0;o<n.listeners.length;o++){const r=n.listeners[o];if(r.options?.signal?.aborted){n.listeners.splice(o,1),o--;continue}r.options.once&&(n.listeners.splice(o,1),o--),r.callback(e)}}if(e instanceof Yn){const i=this._eventListeners[e.type];if(i)for(const n of i){if(t)break;for(let o=0;o<n.listeners.length;o++){const r=n.listeners[o];if(r.options?.signal?.aborted){n.listeners.splice(o,1),o--;continue}if(e.immediatePropagationStopped){t=!0,He&&console.log("immediatePropagationStopped",e.type);break}else e.propagationStopped&&(t=!0,He&&console.log("propagationStopped",e.type));r.options.once&&(n.listeners.splice(o,1),o--),r.callback(e)}}}}_doubleClickTimeThreshold=.2;_longPressTimeThreshold=1;get mousePosition(){return this._pointerPositions[0]}get mousePositionRC(){return this._pointerPositionsRC[0]}get mouseDown(){return this._pointerDown[0]}get mouseUp(){return this._pointerUp[0]}get mouseClick(){return this._pointerClick[0]}get mouseDoubleClick(){return this._pointerDoubleClick[0]}get mousePressed(){return this._pointerPressed[0]}get mouseWheelChanged(){return this.getMouseWheelChanged(0)}get click(){return this._pointerClick[0]}get doubleClick(){return this._pointerDoubleClick[0]}getGamepad(e=0){return typeof navigator<"u"&&"getGamepads"in navigator&&navigator.getGamepads()[e]||null}_setCursorTypes=[];setCursorPointer(){this.setCursor("pointer")}setCursorNormal(){this.unsetCursor("pointer")}setCursor(e){this._setCursorTypes.push(e),this._setCursorTypes.length>10&&this._setCursorTypes.shift(),this.updateCursor()}unsetCursor(e){for(let t=this._setCursorTypes.length-1;t>=0;t--)if(this._setCursorTypes[t]===e){this._setCursorTypes.splice(t,1),this.updateCursor();break}}updateCursor(){this._setCursorTypes?.length==0?this.context.domElement.style.cursor="default":this.context.domElement.style.cursor=this._setCursorTypes[this._setCursorTypes.length-1]}getIsPointerIdInUse(e){for(const t of this._pointerEventsPressed)if(t.pointerId===e&&t.used)return!0;return!1}getPointerPressedCount(){let e=0;for(let t=0;t<this._pointerPressed.length;t++)this._pointerPressed[t]&&e++;return e}getPointerPosition(e){return e>=this._pointerPositions.length?null:this._pointerPositions[e]}getPointerPositionLastFrame(e){return e>=this._pointerPositionsLastFrame.length?null:this._pointerPositionsLastFrame[e]}getPointerPositionDelta(e){return e>=this._pointerPositionsDelta.length?null:this._pointerPositionsDelta[e]}getPointerPositionRC(e){return e>=this._pointerPositionsRC.length?null:this._pointerPositionsRC[e]}getPointerDown(e){return e>=this._pointerDown.length?!1:this._pointerDown[e]}getPointerUp(e){return e>=this._pointerUp.length?!1:this._pointerUp[e]}getPointerPressed(e){return e>=this._pointerPressed.length?!1:this._pointerPressed[e]}getPointerClicked(e){return e>=this._pointerClick.length?!1:this._pointerClick[e]}getPointerDoubleClicked(e){return e>=this._pointerDoubleClick.length?!1:this._pointerDoubleClick[e]}getPointerDownTime(e){return e>=this._pointerDownTime.length?-1:this._pointerDownTime[e]}getPointerUpTime(e){return e>=this._pointerUpTime.length?-1:this._pointerUpTime[e]}getPointerLongPress(e){return e>=this._pointerDownTime.length?!1:this.getPointerPressed(e)&&this.context.time.time-this._pointerDownTime[e]>this._longPressTimeThreshold}getIsMouse(e){return e<0||e>=this._pointerTypes.length?!1:this._pointerTypes[e]==="mouse"}getIsTouch(e){return e<0||e>=this._pointerTypes.length?!1:this._pointerTypes[e]==="touch"}getTouchesPressedCount(){let e=0;for(let t=0;t<this._pointerPressed.length;t++)this._pointerPressed[t]&&this.getIsTouch(t)&&e++;return e}getMouseWheelChanged(e=0){return e>=this._mouseWheelChanged.length?!1:this._mouseWheelChanged[e]}getMouseWheelDeltaY(e=0){return e>=this._mouseWheelDeltaY.length?0:this._mouseWheelDeltaY[e]}getPointerEvent(e){if(!(e>=this._pointerEvent.length))return this._pointerEvent[e]??void 0}*foreachPointerId(e){for(let t=0;t<this._pointerTypes.length;t++)if(this._pointerIsActive(t)){if(e!==void 0){const i=this._pointerTypes[t];if(Array.isArray(e)){let n=!1;for(const o of e)if(i===o){n=!0;break}if(!n)continue}else if(e!==i)continue}yield t}}*foreachTouchId(){for(let e=0;e<this._pointerTypes.length;e++)this._pointerTypes[e]==="touch"&&this._pointerIsActive[e]&&(yield e)}_pointerIsActive(e){return e<0?!1:this._pointerPressed[e]||this._pointerDown[e]||this._pointerUp[e]}context;_pointerDown=[!1];_pointerUp=[!1];_pointerClick=[!1];_pointerDoubleClick=[!1];_pointerPressed=[!1];_pointerPositions=[new c.Vector2];_pointerPositionsLastFrame=[new c.Vector2];_pointerPositionsDelta=[new c.Vector2];_pointerPositionsRC=[new c.Vector2];_pointerPositionDown=[new c.Vector3];_pointerDownTime=[];_pointerUpTime=[];_pointerUpTimestamp=[];_pointerIds=[];_pointerTypes=[""];_mouseWheelChanged=[!1];_mouseWheelDeltaY=[0];_pointerEvent=[];_pointerEventsPressed=[];_pointerSpace=[];_pressedStack=new Map;onDownButton(e,t){let i=this._pressedStack.get(e);i||(i=[],this._pressedStack.set(e,i)),i.push(t)}onReleaseButton(e,t){const i=this._pressedStack.get(e);if(!i)return;const n=i.indexOf(t);n>=0&&i.splice(n,1)}getFirstPressedButtonForPointer(e){const t=this._pressedStack.get(e);if(t)return t[0]}getLatestPressedButtonForPointer(e){const t=this._pressedStack.get(e);if(t)return t[t.length-1]}getKeyDown(e){if(e!==void 0)return this.isKeyDown(e);for(const t in this.keysPressed){const i=this.keysPressed[t];if(i.startFrame===this.context.time.frameCount)return i.key}return null}getKeyPressed(e){if(e!==void 0)return this.isKeyPressed(e);for(const t in this.keysPressed){const i=this.keysPressed[t];if(i.pressed)return i.key}return null}getKeyUp(e){if(e!==void 0)return this.isKeyUp(e);for(const t in this.keysPressed){const i=this.keysPressed[t];return i.pressed===!1&&i.frame===this.context.time.frameCount}return null}isKeyDown(e){if(!this.context.application.isVisible||!this.context.application.hasFocus)return!1;const t=this.getCodeForCommonKeyName(e);if(t!==null){for(const n of t)if(this.isKeyDown(n))return!0;return!1}const i=this.keysPressed[e];return i?i.startFrame===this.context.time.frameCount&&i.pressed:!1}isKeyUp(e){if(!this.context.application.isVisible||!this.context.application.hasFocus)return!1;const t=this.getCodeForCommonKeyName(e);if(t!==null){for(const n of t)if(this.isKeyUp(n))return!0;return!1}const i=this.keysPressed[e];return i?i.frame===this.context.time.frameCount&&i.pressed===!1:!1}isKeyPressed(e){if(!this.context.application.isVisible||!this.context.application.hasFocus)return!1;const t=this.getCodeForCommonKeyName(e);if(t!==null){for(const n of t)if(this.isKeyPressed(n))return!0;return!1}const i=this.keysPressed[e];return i&&i.pressed||!1}getCodeForCommonKeyName(e){if(e.length===1){if(e>="0"&&e<="9")return["Digit"+e];if(e>="a"&&e<="z")return["Key"+e.toUpperCase()];if(e==" ")return["Space"]}switch(e){case"shift":case"Shift":return["ShiftLeft","ShiftRight"];case"control":case"Control":return["ControlLeft","ControlRight"];case"alt":case"Alt":return["AltLeft","AltRight"]}return null}createInputEvent(e){switch(e.type){case"pointerdown":He&&Se("Create Pointer down"),this.onDownButton(e.deviceIndex,e.button),this.onDown(e);break;case"pointermove":He&&Se("Create Pointer move"),this.onMove(e);break;case"pointerup":He&&Se("Create Pointer up"),this.onUp(e),this.onReleaseButton(e.deviceIndex,e.button);break}}convertScreenspaceToRaycastSpace(e){return e.x=(e.x-this.context.domX)/this.context.domWidth*2-1,e.y=-((e.y-this.context.domY)/this.context.domHeight)*2+1,e}constructor(e){this.context=e,this.context.post_render_callbacks.push(this.onEndOfFrame)}_htmlEventSource;bindEvents(){this.unbindEvents(),this._htmlEventSource=this.context.renderer.domElement,window.addEventListener("contextmenu",this.onContextMenu),this._htmlEventSource.addEventListener("pointerdown",this.onPointerDown,{passive:!0}),window.addEventListener("pointermove",this.onPointerMove,{passive:!0,capture:!0}),window.addEventListener("pointerup",this.onPointerUp,{passive:!0}),window.addEventListener("pointercancel",this.onPointerCancel,{passive:!0}),window.addEventListener("touchstart",this.onTouchStart,{passive:!0}),window.addEventListener("touchmove",this.onTouchMove,{passive:!0}),window.addEventListener("touchend",this.onTouchEnd,{passive:!0}),this._htmlEventSource.addEventListener("wheel",this.onMouseWheel,{passive:!0}),window.addEventListener("wheel",this.onWheelWindow,{passive:!0}),window.addEventListener("keydown",this.onKeyDown,!1),window.addEventListener("keypress",this.onKeyPressed,!1),window.addEventListener("keyup",this.onKeyUp,!1),window.addEventListener("blur",this.onLostFocus)}unbindEvents(){for(const e in this._eventListeners)this._eventListeners[e].length=0;window.removeEventListener("contextmenu",this.onContextMenu),this._htmlEventSource?.removeEventListener("pointerdown",this.onPointerDown),window.removeEventListener("pointermove",this.onPointerMove),window.removeEventListener("pointerup",this.onPointerUp),window.removeEventListener("pointercancel",this.onPointerCancel),window.removeEventListener("touchstart",this.onTouchStart),window.removeEventListener("touchmove",this.onTouchMove),window.removeEventListener("touchend",this.onTouchEnd),this._htmlEventSource?.removeEventListener("wheel",this.onMouseWheel,!1),window.removeEventListener("wheel",this.onWheelWindow,!1),window.removeEventListener("keydown",this.onKeyDown,!1),window.removeEventListener("keypress",this.onKeyPressed,!1),window.removeEventListener("keyup",this.onKeyUp,!1),window.removeEventListener("blur",this.onLostFocus)}dispose(){const e=this.context.post_render_callbacks.indexOf(this.onEndOfFrame);e>=0&&this.context.post_render_callbacks.splice(e,1),this.unbindEvents()}onLostFocus=()=>{for(const e in this.keysPressed)this.keysPressed[e].pressed=!1};_receivedPointerMoveEventsThisFrame=new Array;onEndOfFrame=()=>{this._receivedPointerMoveEventsThisFrame.length=0;for(let e=0;e<this._pointerUp.length;e++)this._pointerUp[e]=!1;for(let e=0;e<this._pointerDown.length;e++)this._pointerDown[e]=!1;for(let e=0;e<this._pointerClick.length;e++)this._pointerClick[e]=!1;for(let e=0;e<this._pointerDoubleClick.length;e++)this._pointerDoubleClick[e]=!1;for(const e of this._pointerPositionsDelta)e.set(0,0);for(let e=0;e<this._mouseWheelChanged.length;e++)this._mouseWheelChanged[e]=!1;for(let e=0;e<this._mouseWheelDeltaY.length;e++)this._mouseWheelDeltaY[e]=0};canReceiveInput(e){return e.target===this.context.renderer?.domElement||e.target===this.context.domElement||this.context.isInAR||this.context.isInAR&&e.target===document.body&&exports.DeviceUtilities.isMozillaXR()?!0:(He&&console.warn("CanReceiveInput:False for",e.target),!1)}onContextMenu=e=>{this.canReceiveInput(e)!==!1&&e instanceof PointerEvent&&e.pointerType};keysPressed={};onKeyDown=e=>{if(He&&console.log(`key down ${e.code}, ${this.context.application.hasFocus}`,e),!this.context.application.hasFocus)return;const t=this.keysPressed[e.code];if(t&&t.pressed)return;this.keysPressed[e.code]={pressed:!0,frame:this.context.time.frameCount+1,startFrame:this.context.time.frameCount+1,key:e.key,code:e.code};const i=new nl("keydown",e,e);this.onDispatchEvent(i)};onKeyPressed=e=>{if(!this.context.application.hasFocus)return;const t=this.keysPressed[e.code];if(!t)return;t.pressed=!0,t.frame=this.context.time.frameCount+1;const i=new nl("keypress",e,e);this.onDispatchEvent(i)};onKeyUp=e=>{if(!this.context.application.hasFocus)return;const t=this.keysPressed[e.code];if(!t)return;t.pressed=!1,t.frame=this.context.time.frameCount+1;const i=new nl("keyup",e,e);this.onDispatchEvent(i)};onWheelWindow=e=>{document.pointerLockElement&&this.onMouseWheel(e)};onMouseWheel=e=>{if(this.canReceiveInput(e)===!1)return;this._mouseWheelDeltaY.length<=0&&this._mouseWheelDeltaY.push(0),this._mouseWheelChanged.length<=0&&this._mouseWheelChanged.push(!1),this._mouseWheelChanged[0]=!0;const t=this._mouseWheelDeltaY[0];this._mouseWheelDeltaY[0]=t+e.deltaY};onPointerDown=e=>{if(this.context.isInAR||this.canReceiveInput(e)===!1)return;e.target instanceof HTMLElement&&e.target.setPointerCapture(e.pointerId);const t=this.getPointerId(e);He&&Se(`pointer down #${t}, identifier:${e.pointerId}`);const i=this.getAndUpdateSpatialObjectForScreenPosition(t,e.clientX,e.clientY),n=new Yn("pointerdown",e,{origin:this,mode:"screen",deviceIndex:0,pointerId:t,button:e.button,clientX:e.clientX,clientY:e.clientY,pointerType:e.pointerType,buttonName:this.getButtonName(e),device:i,pressure:e.pressure});this.onDown(n)};onPointerMove=e=>{if(this.context.isInAR||this._receivedPointerMoveEventsThisFrame.includes(e.pointerId))return;this._receivedPointerMoveEventsThisFrame.push(e.pointerId);let t=e.button;e.pointerType==="mouse"&&(t=this.getFirstPressedButtonForPointer(0)??0);const i=this.getPointerId(e,t);t===-1&&(t=i);const n=this.getAndUpdateSpatialObjectForScreenPosition(i,e.clientX,e.clientY),o=new Yn("pointermove",e,{origin:this,mode:"screen",deviceIndex:0,pointerId:i,button:t,clientX:e.clientX,clientY:e.clientY,pointerType:e.pointerType,buttonName:this.getButtonName(e),device:n,pressure:e.pressure});this.onMove(o)};onPointerCancel=e=>{this.context.isInAR||(He&&console.log("Pointer cancel",e),this.onPointerUp(e))};onPointerUp=e=>{if(this.context.isInAR)return;e.target instanceof HTMLElement&&e.target.releasePointerCapture(e.pointerId);const t=this.getPointerId(e),i=new Yn("pointerup",e,{origin:this,mode:"screen",deviceIndex:0,pointerId:t,button:e.button,clientX:e.clientX,clientY:e.clientY,pointerType:e.pointerType,buttonName:this.getButtonName(e),device:this.getAndUpdateSpatialObjectForScreenPosition(t,e.clientX,e.clientY),pressure:e.pressure});this.onUp(i),this._pointerIds[t]=-1,He&&console.log("ID="+t,"PointerId="+e.pointerId,"ALL:",[...this._pointerIds])};getPointerId(e,t){return e.pointerType==="mouse"?0+(t??e.button):this.getPointerIndex(e.pointerId)}getButtonName(e){const t=e.button;if(e.pointerType==="mouse")switch(t){case 0:return"left";case 1:return"middle";case 2:return"right"}return"unknown"}onTouchStart=e=>{if(this.context.isInAR)for(let t=0;t<e.changedTouches.length;t++){const i=e.changedTouches[t],n=this.getPointerIndex(i.identifier),o=this.getAndUpdateSpatialObjectForScreenPosition(n,i.clientX,i.clientY),r=new Yn("pointerdown",e,{origin:this,mode:"screen",deviceIndex:0,pointerId:n,button:0,clientX:i.clientX,clientY:i.clientY,pointerType:"touch",buttonName:"unknown",device:o,pressure:i.force});this.onDown(r)}};onTouchMove=e=>{if(this.context.isInAR)for(let t=0;t<e.changedTouches.length;t++){const i=e.changedTouches[t],n=this.getPointerIndex(i.identifier),o=this.getAndUpdateSpatialObjectForScreenPosition(n,i.clientX,i.clientY),r=new Yn("pointermove",e,{origin:this,mode:"screen",deviceIndex:0,pointerId:n,button:0,clientX:i.clientX,clientY:i.clientY,pointerType:"touch",buttonName:"unknown",device:o,pressure:i.force});this.onMove(r)}};onTouchEnd=e=>{if(this.context.isInAR)for(let t=0;t<e.changedTouches.length;t++){const i=e.changedTouches[t],n=this.getPointerIndex(i.identifier),o=new Yn("pointerup",e,{origin:this,mode:"screen",deviceIndex:0,pointerId:n,button:0,clientX:i.clientX,clientY:i.clientY,pointerType:"touch",buttonName:"unknown",device:this.getAndUpdateSpatialObjectForScreenPosition(n,i.clientX,i.clientY),pressure:i.force});this.onUp(o),this._pointerIds[n]=-1}};tempNearPlaneVector=new c.Vector3;tempFarPlaneVector=new c.Vector3;tempLookMatrix=new c.Matrix4;getAndUpdateSpatialObjectForScreenPosition(e,t,i){let n=this._pointerSpace[e];n||(n=new c.Object3D,this._pointerSpace[e]=n),this._pointerSpace[e]=n;const o=this.context.mainCamera;if(o){const r=this.tempNearPlaneVector.set(t,i,-1);this.convertScreenspaceToRaycastSpace(r);const a=this.tempFarPlaneVector.set(r.x,r.y,1);r.unproject(o),a.unproject(o);const l=o.worldUp||V(0,1,0).applyQuaternion(ue(o));this.tempLookMatrix.lookAt(a,r,l),n.position.set(r.x,r.y,r.z),n.quaternion.setFromRotationMatrix(this.tempLookMatrix)}return n}isInRect(e){if(this.context.isInXR)return!0;const t=this.context.domElement.getBoundingClientRect(),i=e.clientX,n=e.clientY,o=i>=t.x&&i<=t.right&&n>=t.y&&n<=t.bottom;return He&&!o&&console.log("Not in rect",t,i,n),o}onDown(e){const t=e.pointerId;if(this.getPointerPressed(t)&&console.warn(`Received pointerDown for pointerId that is already pressed: ${t}`,He?e:""),He&&console.log(e.pointerType,"DOWN",t),!!this.isInRect(e)){for(this.setPointerState(t,this._pointerPressed,!0),this.setPointerState(t,this._pointerDown,!0),this.setPointerStateT(t,this._pointerEvent,e.source);t>=this._pointerTypes.length;)this._pointerTypes.push(e.pointerType);for(this._pointerTypes[t]=e.pointerType;t>=this._pointerPositionDown.length;)this._pointerPositionDown.push(new c.Vector3);for(this._pointerPositionDown[t].set(e.clientX,e.clientY,e.clientZ??0);t>=this._pointerPositions.length;)this._pointerPositions.push(new c.Vector2);this._pointerPositions[t].set(e.clientX,e.clientY),t>=this._pointerDownTime.length&&this._pointerDownTime.push(0),this._pointerDownTime[t]=this.context.time.realtimeSinceStartup,this.updatePointerPosition(e),this._pointerEventsPressed.push(e),this.onDispatchEvent(e)}}onMove(e){const t=e.pointerId,i=this.getPointerPressed(t);i===!1&&!this.isInRect(e)||e.pointerType==="touch"&&!i||(this.updatePointerPosition(e),this.setPointerStateT(t,this._pointerEvent,e.source),this.onDispatchEvent(e))}onUp(e){const t=e.pointerId;if(!this.getPointerPressed(t)){He&&console.log(e.pointerType,"UP",t,"was not down");return}He&&console.log(e.pointerType,"UP",t),this.setPointerState(t,this._pointerPressed,!1),this.setPointerStateT(t,this._pointerEvent,e.source),this.setPointerState(t,this._pointerUp,!0),this.updatePointerPosition(e);for(let l=this._pointerEventsPressed.length-1;l>=0;l--)if(this._pointerEventsPressed[l].pointerId===t){this._pointerEventsPressed.splice(l,1);break}if(!this._pointerPositionDown[t]){He&&ce("Received pointer up event without matching down event for button: "+t),console.warn("Received pointer up event without matching down event for button: "+t);return}const n=this._pointerUpTime[t],o=this._pointerDownTime[t],r=this.context.time.realtimeSinceStartup,a=r-o;if(t>=this._pointerUpTime.length&&this._pointerUpTime.push(-99),this._pointerUpTime[t]=r,a<1){let l=e.clientX-this._pointerPositionDown[t].x,h=e.clientY-this._pointerPositionDown[t].y,d=0;if(e.isSpatial&&e.clientZ!=null&&(d=e.clientZ-this._pointerPositionDown[t].z,l*=200,h*=200,d*=200),Math.abs(l)<5&&Math.abs(h)<5&&Math.abs(d)<5){this.setPointerState(t,this._pointerClick,!0),e.isClick=!0;const u=r-n;He&&console.log("CLICK",t,l,h,d,u),u<this._doubleClickTimeThreshold&&u>0&&(this.setPointerState(t,this._pointerDoubleClick,!0),e.isDoubleClick=!0)}}this.onDispatchEvent(e)}updatePointerPosition(e){const t=e.pointerId;for(;t>=this._pointerPositions.length;)this._pointerPositions.push(new c.Vector2);for(;t>=this._pointerPositionsLastFrame.length;)this._pointerPositionsLastFrame.push(new c.Vector2);for(;t>=this._pointerPositionsDelta.length;)this._pointerPositionsDelta.push(new c.Vector2);const i=this._pointerPositionsLastFrame[t];i.copy(this._pointerPositions[t]);const n=this._pointerPositionsDelta[t];let o=e.clientX-i.x,r=e.clientY-i.y;if(e.source instanceof MouseEvent||e.source instanceof TouchEvent){const d=e.source;o===0&&d.movementX!==0&&(o=d.movementX||0),r===0&&d.movementY!==0&&(r=d.movementY||0)}n.x+=o,n.y+=r,this._pointerPositions[t].x=e.clientX,this._pointerPositions[t].y=e.clientY;const a=e.clientX,l=e.clientY;for(;t>=this._pointerPositionsRC.length;)this._pointerPositionsRC.push(new c.Vector2);const h=this._pointerPositionsRC[t];h.set(a,l),this.convertScreenspaceToRaycastSpace(h)}getPointerIndex(e){let t=-1;for(let i=0;i<this._pointerIds.length;i++){if(this._pointerIds[i]===e)return i;t===-1&&this._pointerIds[i]===-1&&(t=i)}return t!==-1?(this._pointerIds[t]=e,t):(He&&console.log("PUSH pointerId:",e),this._pointerIds.push(e),this._pointerIds.length-1)}setPointerState(e,t,i){t[e]=i}setPointerStateT(e,t,i){return t[e]=i,i}onDispatchEvent(e){const t=U.Current;try{U.Current=this.context,this.dispatchEvent(e)}finally{U.Current=t}}}const Wr=new c.Matrix4().makeRotationY(Math.PI),ki=new c.Quaternion().setFromAxisAngle(new c.Vector3(0,1,0),Math.PI),iS=w("debugwebxr");class nS{priority=-1e5;gameObject;isXRRig(){return!0}get isActive(){return this.gameObject.visible}constructor(){if(this.gameObject=new c.Object3D,this.gameObject.name="Implicit XR Rig",iS){const e=nm(16733661);e.position.y+=.5,this.gameObject.add(e)}}}const zn=w("debugwebxr"),Jc=w("debugcustomgesture"),sS="https://cdn.jsdelivr.net/npm/@webxr-input-profiles/assets@1.0/dist/profiles",oS="generic-trigger",rS=new c.Quaternion().setFromEuler(new c.Euler(c.MathUtils.degToRad(0),c.MathUtils.degToRad(-90),c.MathUtils.degToRad(-90))),aS=new c.Vector3(.04,-.04,0);class Kp{xr;get context(){return this.xr.context}inputSource;index=0;emitEvents=!0;get connected(){return this._connected}_connected=!0;get isTracking(){return this._isTracking}_isTracking=!1;get gamepad(){return this.__gamepad??=this.inputSource.gamepad}__gamepad;get isHand(){return this.hand!=null}get hand(){return this.__hand??=this.inputSource.hand}__hand;get handObject(){return this.context.renderer.xr.getHand(this.index)}get profiles(){return this.inputSource.profiles}get layout(){return this._layout}get targetRayMode(){return this.inputSource.targetRayMode}get targetRaySpace(){return this.inputSource.targetRaySpace}get gripSpace(){return this.inputSource.gripSpace}get side(){return this.__side??=this.inputSource.handedness}__side=void 0;get isRight(){return this.side==="right"}get isLeft(){return this.side==="left"}get isStylus(){return this._isMxInk}getHitTestSource(){return this._hitTestSource||this._requestHitTestSource(),this._hitTestSource}get hasHitTestSource(){return this._hitTestSource}cancelHitTestSource(){this._hitTestSource&&(this._hitTestSource.cancel(),this._hitTestSource=void 0)}_hitTestSource=void 0;_hasSelectEvent=!1;get hasSelectEvent(){return this._hasSelectEvent}_isMxInk=!1;_isMetaQuestTouchController=!1;getHitTest(){return this.xr.getHitTest(this)}_handJointPoses=new Map;getHandJointPose(e,t){if(t=t||this.xr.frame,!this.hand||!t?.getJointPose||!this.xr.referenceSpace)return null;let i=this._handJointPoses?.get(e);return i||(i=t.getJointPose(e,this.xr.referenceSpace),i&&this._handJointPoses.set(e,i),i)}_gripMatrix=new c.Matrix4;_gripPosition=new c.Vector3;_gripQuaternion=new c.Quaternion;_linearVelocity=new c.Vector3;_rayPositionRaw=new c.Vector3;_rayRotationRaw=new c.Quaternion;_rayMatrix=new c.Matrix4;_rayPosition=new c.Vector3;_rayQuaternion=new c.Quaternion;get gripPosition(){return V(this._gripPosition)}get gripQuaternion(){return Xi(this._gripQuaternion)}get gripMatrix(){return this._gripMatrix}get gripLinearVelocity(){return V(this._linearVelocity).applyQuaternion(ki)}get rayPosition(){return V(this._rayPosition)}get rayQuaternion(){return Xi(this._rayQuaternion)}get gripWorldPosition(){return V(this._gripWorldPosition)}_gripWorldPosition=new c.Vector3;get gripWorldQuaternion(){return Xi(this._gripWorldQuaternion)}_gripWorldQuaternion=new c.Quaternion;get rayWorldPosition(){return V(this._rayWorldPosition)}_rayWorldPosition=new c.Vector3;updateRayWorldPosition(){const e=this.xr.context.mainCamera?.parent;this._rayWorldPosition.copy(this._rayPositionRaw),e&&this._rayWorldPosition.applyMatrix4(e.matrixWorld)}get rayWorldQuaternion(){return Xi(this._rayWorldQuaternion)}_rayWorldQuaternion=new c.Quaternion;get pinchPosition(){return V(this._pinchPosition)}_pinchPosition=new c.Vector3;updateRayWorldQuaternion(){const e=this.xr.context.mainCamera?.parent,t=e?ue(e):void 0;this._rayWorldQuaternion.copy(this._rayRotationRaw).multiply(ki),t&&this._rayWorldQuaternion.premultiply(t)}get ray(){return this._ray.origin.copy(this.rayWorldPosition),this._ray.direction.copy(V(0,0,1).applyQuaternion(this.rayWorldQuaternion)),this._ray}_ray;_hand_wristDotUp=void 0;get handWristDotUp(){if(this._hand_wristDotUp!==void 0)return this._hand_wristDotUp;const e=this.handObject?.joints.wrist;if(e){const t=V(0,1,0).applyQuaternion(e.quaternion),i=V(0,1,0).dot(t);return this._hand_wristDotUp=i}}get isHandUpsideDown(){return this.handWristDotUp!==void 0?this.handWristDotUp<-.7:!1}get isTeleportGesture(){return this.isHandUpsideDown&&this.getGesture("pinch")?.isDown}get object(){return this._object}_object;_gripSpaceObject;_raySpaceObject;model=null;_debugAxesHelper=new c.AxesHelper(.15);_debugGripAxesHelper=new c.AxesHelper(.07);_debugRayAxesHelper=new c.AxesHelper(.07);async getModelUrl(){return this.getMotionController?.then(e=>e?.assetUrl||null)}constructor(e,t,i){this.xr=e,this.inputSource=t,this.index=i,this._object=new c.Object3D,this._object.name=`NeedleXRController_${i}`,zn&&(this._object.add(this._debugAxesHelper),this._gripSpaceObject=new c.Object3D,this._raySpaceObject=new c.Object3D,this._gripSpaceObject.name=`NeedleXRController_${i}_gripSpace`,this._raySpaceObject.name=`NeedleXRController_${i}_raySpace`,this._gripSpaceObject.add(this._debugGripAxesHelper),this._raySpaceObject.add(this._debugRayAxesHelper),this.xr.context.scene.add(this._gripSpaceObject),this.xr.context.scene.add(this._raySpaceObject)),this.xr.context.scene.add(this._object),this._ray=new c.Ray,this.pointerInit={origin:this,pointerType:this.hand?"hand":"controller",deviceIndex:this.index,pointerId:-1,mode:this.inputSource.targetRayMode,ray:this._ray,device:this._object,buttonName:"none"},this.initialize(),this.subscribeEvents()}_hitTestSourcePromise=null;_requestHitTestSource(){return this._hitTestSourcePromise?this._hitTestSourcePromise:this.xr.mode==="immersive-ar"&&this.inputSource.targetRayMode==="tracked-pointer"&&this.xr.session.requestHitTestSourceForTransientInput?this._hitTestSourcePromise=this.xr.session.requestHitTestSourceForTransientInput({profile:this.inputSource.profiles[0],offsetRay:new XRRay})?.then(e=>(this._hitTestSourcePromise=null,this.connected?this._hitTestSource=e:(e.cancel(),null)))??null:null}onPointerHits=e=>{};onUpdate(e){this.onUpdateFrame(e),this.updateInputEvents(),this.onUpdateMove()}onRenderDebug(){j.DrawSphere(this.rayWorldPosition,.003),j.DrawDirection(this.rayWorldPosition,V(0,0,10).applyQuaternion(this.rayWorldQuaternion));const t=(this.inputSource.gripSpace?this.gripWorldPosition:this.object.worldPosition).sub(this.object.worldForward.multiplyScalar(.1)),i=this.inputSource.profiles.join(`
147
147
  `);let n=`Controller[${this.index}] (${this.inputSource.targetRayMode}, ${this.side})
148
148
  C:${this.connected?"x":"-"} T:${this.isTracking?"x":"-"} Hand:${this.inputSource.hand?"x":"-"} Pen: ${this._isMxInk?"x":"-"}`;if(this.inputSource.hand&&(n+=`
@@ -770,7 +770,7 @@ vec3 AgXToneMapping( vec3 color ) {
770
770
  The script will be ignored. Please make sure your component extends "Behaviour" imported from "@needle-tools/engine"
771
771
  `,s);return}e||(e=U.Current,Fe&&console.warn("> Registering component without context"));const t=e?.new_scripts;t.includes(s)||t.push(s)}class U{static _defaultTargetFramerate={value:90,toString(){return this.value}};static get DefaultTargetFrameRate(){return U._defaultTargetFramerate.value}static set DefaultTargetFrameRate(e){U._defaultTargetFramerate.value=e}static _defaultWebglRendererParameters={antialias:!0,alpha:!1,powerPreference:exports.DeviceUtilities.isiOS()||exports.DeviceUtilities.isMacOS()?"default":"high-performance",stencil:!0};static get DefaultWebGLRendererParameters(){return U._defaultWebglRendererParameters}get version(){return Ji}static get Current(){return re.Current}static set Current(e){re.Current=e}static get All(){return re.All}name;alias;isManagedExternally=!1;isPaused=!1;runInBackground=!1;targetFrameRate;physicsSteps=1;hash;domElement;appendHTMLElement(e){return this.domElement.shadowRoot?this.domElement.shadowRoot.appendChild(e):this.domElement.appendChild(e)}get resolutionScaleFactor(){return this._resolutionScaleFactor}set resolutionScaleFactor(e){if(e!==this._resolutionScaleFactor&&typeof e=="number"){if(e<=0){console.error("Invalid resolution scale factor",e);return}this._resolutionScaleFactor=e,this.updateSize()}}_resolutionScaleFactor=1;_boundingClientRectFrame=-1;_boundingClientRect=null;_domX;_domY;calculateBoundingClientRect(){if(this.xr){this._domX=0,this._domY=0;return}this._boundingClientRectFrame!==this.time.frame&&(this._boundingClientRectFrame=this.time.frame,this._boundingClientRect=this.domElement.getBoundingClientRect(),this._domX=this._boundingClientRect.x,this._domY=this._boundingClientRect.y)}get domWidth(){return this.isInAR?window.innerWidth:this.domElement.clientWidth}get domHeight(){return this.isInAR?window.innerHeight:this.domElement.clientHeight}get domX(){return this.calculateBoundingClientRect(),this._domX}get domY(){return this.calculateBoundingClientRect(),this._domY}get isInXR(){return this.renderer?.xr?.isPresenting||!1}xr=null;get xrSessionMode(){return this.xr?.mode}get isInVR(){return this.xrSessionMode==="immersive-vr"}get isInAR(){return this.xrSessionMode==="immersive-ar"}get isInPassThrough(){return this.xr?this.xr.isPassThrough:!1}get xrSession(){return this.renderer?.xr?.getSession()}get xrFrame(){return this._xrFrame}get xrCamera(){return this.renderer.xr.isPresenting?this.renderer?.xr?.getCamera():void 0}_xrFrame=null;get arOverlayElement(){const e=this.domElement;return typeof e.getAROverlayContainer=="function"?e.getAROverlayContainer():this.domElement}get currentFrameEvent(){return this._currentFrameEvent}_currentFrameEvent=-1;scene;renderer;composer=null;scripts=[];scripts_pausedChanged=[];scripts_earlyUpdate=[];scripts_update=[];scripts_lateUpdate=[];scripts_onBeforeRender=[];scripts_onAfterRender=[];scripts_WithCorroutines=[];scripts_immersive_vr=[];scripts_immersive_ar=[];coroutines={};post_setup_callbacks=[];pre_update_callbacks=[];pre_render_callbacks=[];post_render_callbacks=[];pre_update_oneshot_callbacks=[];new_scripts=[];new_script_start=[];new_scripts_pre_setup_callbacks=[];new_scripts_post_setup_callbacks=[];new_scripts_xr=[];mainCameraComponent=void 0;get mainCamera(){if(this._mainCamera)return this._mainCamera;if(this.mainCameraComponent){const e=this.mainCameraComponent;return e.threeCamera||e.buildCamera(),e.threeCamera}return this._fallbackCamera||(this._fallbackCamera=new c.PerspectiveCamera(75,this.domWidth/this.domHeight,.1,1e3)),this._fallbackCamera}set mainCamera(e){this._mainCamera=e}_mainCamera=null;_fallbackCamera=null;application;animations;time;input;physics;connection;assets;mainLight=null;get rendererData(){return this.sceneLighting}sceneLighting;addressables;lightmaps;players;lodsManager;menu;get isCreated(){return this._isCreated}_needsUpdateSize=!1;_isCreated=!1;_isCreating=!1;_isVisible=!1;_stats=AC?new G.Stats:null;constructor(e){this.name=e?.name||"",this.alias=e?.alias,this.domElement=e?.domElement||document.body,this.hash=e?.hash,e?.renderer&&(this.renderer=e.renderer,this.isManagedExternally=!0),e?.runInBackground!==void 0&&(this.runInBackground=e.runInBackground),e?.scene?this.scene=e.scene:this.scene=new c.Scene,e?.camera&&(this._mainCamera=e.camera),this.application=new tn(this),this.time=new T0,this.input=new kb(this),this.physics=new na(this),this.connection=new jb(this),this.assets=new zb,this.sceneLighting=new R0(this),this.addressables=new S0(this),this.lightmaps=new _C(this),this.players=new k0(this),this.menu=new TC(this),this.lodsManager=new bC(this),this.animations=new mC(this);const t=()=>this._needsUpdateSize=!0;window.addEventListener("resize",t),this._disposeCallbacks.push(()=>window.removeEventListener("resize",t));const i=new ResizeObserver(n=>this._needsUpdateSize=!0);i.observe(this.domElement),this._disposeCallbacks.push(()=>i.disconnect()),this._intersectionObserver=new IntersectionObserver(n=>{this._isVisible=n[0].isIntersecting}),this._disposeCallbacks.push(()=>this._intersectionObserver?.disconnect()),re.register(this)}createNewRenderer(e){if(this.renderer?.dispose(),e={...U.DefaultWebGLRendererParameters,...e},!e.canvas){const t=this.domElement?.shadowRoot?.querySelector("canvas");t&&(e.canvas=t,Fe&&console.log("Using canvas from shadow root",t))}return Fe&&console.log("Using Renderer Parameters:",e,this.domElement),this.renderer=new c.WebGLRenderer(e),this.renderer.debug.checkShaderErrors=A()||w("checkshadererrors")===!0,this.renderer.toneMappingExposure=1,this.renderer.toneMapping=c.NoToneMapping,this.renderer.setClearColor(new c.Color("lightgrey"),0),this.renderer.shadowMap.enabled=!0,this.renderer.shadowMap.type=c.PCFSoftShadowMap$1,this.renderer.setSize(this.domWidth,this.domHeight),this.renderer.outputColorSpace=c.SRGBColorSpace,this.renderer.nodes={library:new c.BasicNodeLibrary,modelViewMatrix:null,modelNormalViewMatrix:null},this.lodsManager.setRenderer(this.renderer),this.input.bindEvents(),this.renderer}_intersectionObserver=null;internalOnUpdateVisible(){this._intersectionObserver?.disconnect(),this._intersectionObserver?.observe(this.domElement)}_disposeCallbacks=[];requestSizeUpdate(){this._needsUpdateSize=!0}maxRenderResolution;get devicePixelRatio(){return this._devicePixelRatio}set devicePixelRatio(e){e!==this._devicePixelRatio&&(this._devicePixelRatio=e,this._needsUpdateSize=!0)}_devicePixelRatio="auto";updateSize(e=!1){if(e||!this.isManagedExternally&&this.renderer.xr?.isPresenting===!1){this._needsUpdateSize=!1;const t=this.resolutionScaleFactor;let i=this.domWidth*t,n=this.domHeight*t;this.maxRenderResolution&&(this.maxRenderResolution.x=Math.max(1,this.maxRenderResolution.x),i=Math.min(this.maxRenderResolution.x,i),this.maxRenderResolution.y=Math.max(1,this.maxRenderResolution.y),n=Math.min(this.maxRenderResolution.y,n));const o=this.mainCamera;this.updateAspect(o),this.renderer.setSize(i,n,!0),this.renderer.domElement.style.width="100%",this.renderer.domElement.style.height="100%";const r=typeof this.devicePixelRatio=="number"?this.devicePixelRatio:this.devicePixelRatio==="auto"?Math.min(2,window.devicePixelRatio):void 0;r!==void 0&&this.renderer.setPixelRatio(r),this.composer&&(this.composer.setSize?.call(this.composer,i,n),r!==void 0&&"setPixelRatio"in this.composer&&typeof this.composer.setPixelRatio=="function"&&this.composer.setPixelRatio?.call(this.composer,window.devicePixelRatio))}}updateAspect(e,t,i){if(!e)return;t===void 0&&(t=this.domWidth),i===void 0&&(i=this.domHeight);const n=t/i;if(e.isPerspectiveCamera){const o=e,r=o.aspect;o.aspect=n,r!==o.aspect&&e.updateProjectionMatrix()}else if(e.isOrthographicCamera){const o=e,r=o.top-o.bottom,l=r*n/2,h=r/2;(o.left!=-l||o.top!=h)&&(o.left=-l,o.right=l,o.top=h,o.bottom=-h,e.updateProjectionMatrix())}}recreate(){this.clear(),this.create(this._originalCreationArgs)}_originalCreationArgs;async onCreate(e){return this.create(e)}async create(e){try{this._isCreating=!0,e!==this._originalCreationArgs&&(this._originalCreationArgs=Jl(e)),window.addEventListener("unhandledrejection",this.onUnhandledRejection);const t=await this.internalOnCreate(e);return this._isCreated=t,t}finally{window.removeEventListener("unhandledrejection",this.onUnhandledRejection),this._isCreating=!1}}onUnhandledRejection=e=>{this.onError(e.reason)};onError(e){this.domElement.dispatchEvent(new CustomEvent("error",{detail:e}))}clear(){re.dispatchCallback(oe.ContextClearing,this),hn(this,oe.ContextClearing),di(this.scene,!0,!0),this.scene=new c.Scene,this.addressables?.dispose(),this.lightmaps?.clear(),this.physics?.engine?.clearCaches(),this.lodsManager.disable(),this._onBeforeRenderListeners.clear(),this._onAfterRenderListeners.clear(),this.isManagedExternally||this.renderer&&(this.renderer.renderLists.dispose(),this.renderer.state.reset(),this.renderer.resetState()),re.dispatchCallback(oe.ContextCleared,this)}dispose(){this.internalOnDestroy()}onDestroy(){this.internalOnDestroy()}internalOnDestroy(){U.Current=this,re.dispatchCallback(oe.ContextDestroying,this),hn(this,oe.ContextDestroying),this.clear(),this.renderer?.setAnimationLoop(null),this.renderer&&(this.renderer.setClearAlpha(0),this.renderer.clear(),this.isManagedExternally||(Fe&&console.log("Disposing renderer"),this.renderer.dispose())),this.scene=null,this.renderer=null,this.input.dispose(),this.menu.onDestroy(),this.animations.onDestroy();for(const e of this._disposeCallbacks)try{e()}catch(t){console.error("Error in on dispose callback:",t,e)}this.domElement?.parentElement&&this.domElement.parentElement.removeChild(this.domElement),this._isCreated=!1,re.dispatchCallback(oe.ContextDestroyed,this),hn(this,oe.ContextDestroyed),re.unregister(this),U.Current===this&&(U.Current=null)}registerCoroutineUpdate(e,t,i){return typeof t?.next!="function"?(console.error("Registered invalid coroutine function from "+e.name+`
772
772
  Coroutine functions must be generators: "*myCoroutine() {...}"
773
- Start a coroutine from a component by calling "this.startCoroutine(myCoroutine())"`),t):(this.coroutines[i]||(this.coroutines[i]=[]),this.coroutines[i].push({comp:e,main:t}),t)}unregisterCoroutineUpdate(e,t){if(!this.coroutines[t])return;const i=this.coroutines[t].findIndex(n=>n.main===e);i>=0&&this.coroutines[t].splice(i,1)}stopAllCoroutinesFrom(e){for(const t in this.coroutines){const i=this.coroutines[t];for(let n=i.length-1;n>=0;n--)i[n].comp===e&&i.splice(n,1)}}_cameraStack=[];setCurrentCamera(e){if(!e)return;if(e.threeCamera||e.buildCamera(),!e.threeCamera){console.warn("Camera component is missing camera",e);return}const t=this._cameraStack.indexOf(e);t>=0&&this._cameraStack.splice(t,1),this._cameraStack.push(e),this.mainCameraComponent=e;const i=e.threeCamera;i.isPerspectiveCamera&&this.updateAspect(i),this.mainCameraComponent?.applyClearFlagsIfIsActiveCamera()}removeCamera(e){if(!e)return;const t=this._cameraStack.indexOf(e);if(t>=0&&this._cameraStack.splice(t,1),this.mainCameraComponent===e&&(this.mainCameraComponent=void 0,this._cameraStack.length>0)){const i=this._cameraStack[this._cameraStack.length-1];this.setCurrentCamera(i)}}_onBeforeRenderListeners=new Map;_onAfterRenderListeners=new Map;addBeforeRenderListener(e,t){if(!this._onBeforeRenderListeners.has(e.uuid)){const i=[];this._onBeforeRenderListeners.set(e.uuid,i),e.onBeforeRender=this._createRenderCallbackWrapper(i)}this._onBeforeRenderListeners.get(e.uuid).push(t)}removeBeforeRenderListener(e,t){if(this._onBeforeRenderListeners.has(e.uuid)){const i=this._onBeforeRenderListeners.get(e.uuid),n=i.indexOf(t);n>=0&&i.splice(n,1)}}addAfterRenderListener(e,t){if(!this._onAfterRenderListeners.has(e.uuid)){const i=[];this._onAfterRenderListeners.set(e.uuid,i),e.onAfterRender=this._createRenderCallbackWrapper(i)}this._onAfterRenderListeners.get(e.uuid)?.push(t)}removeAfterRenderListener(e,t){if(this._onAfterRenderListeners.has(e.uuid)){const i=this._onAfterRenderListeners.get(e.uuid),n=i.indexOf(t);n>=0&&i.splice(n,1)}}_createRenderCallbackWrapper(e){return(t,i,n,o,r,a)=>{for(let l=0;l<e.length;l++){const h=e[l];h(t,i,n,o,r,a)}}}_requireDepthTexture=!1;_requireColorTexture=!1;_renderTarget;_isRendering=!1;get isRendering(){return this._isRendering}setRequireDepth(e){this._requireDepthTexture=e}setRequireColor(e){this._requireColorTexture=e}get depthTexture(){return this._renderTarget?.depthTexture||null}get opaqueColorTexture(){return this._renderTarget?.texture||null}get isVisibleToUser(){if(this.isInXR)return!0;if(!this._isVisible)return!1;const e=getComputedStyle(this.domElement);return e.visibility!=="hidden"&&e.display!=="none"&&e.opacity!=="0"}_createId=0;async internalOnCreate(e){const t=++this._createId;Fe&&console.log("Creating context",this.name,e);const i=globalThis["needle:dependencies:ready"];i instanceof Promise&&(Fe&&console.log("Waiting for dependencies to be ready"),await i.catch(h=>{if(Fe||A()){if(nc("Needle Engine dependencies failed to load. Please check the console for more details"),h instanceof ReferenceError){let d="YourComponentName";const u=h.message.indexOf("'");if(u>0){const p=h.message.indexOf("'",u+1);if(p>0){const m=h.message.substring(u+1,p);m.length>3&&(d=m)}}console.error(`Needle Engine dependencies failed to load:
773
+ Start a coroutine from a component by calling "this.startCoroutine(myCoroutine())"`),t):(this.coroutines[i]||(this.coroutines[i]=[]),this.coroutines[i].push({comp:e,main:t}),t)}unregisterCoroutineUpdate(e,t){if(!this.coroutines[t])return;const i=this.coroutines[t].findIndex(n=>n.main===e);i>=0&&this.coroutines[t].splice(i,1)}stopAllCoroutinesFrom(e){for(const t in this.coroutines){const i=this.coroutines[t];for(let n=i.length-1;n>=0;n--)i[n].comp===e&&i.splice(n,1)}}_cameraStack=[];setCurrentCamera(e){if(!e)return;if(e.threeCamera||e.buildCamera(),!e.threeCamera){console.warn("Camera component is missing camera",e);return}const t=this._cameraStack.indexOf(e);t>=0&&this._cameraStack.splice(t,1),this._cameraStack.push(e),this.mainCameraComponent=e;const i=e.threeCamera;i.isPerspectiveCamera&&this.updateAspect(i),this.mainCameraComponent?.applyClearFlagsIfIsActiveCamera()}removeCamera(e){if(!e)return;const t=this._cameraStack.indexOf(e);if(t>=0&&this._cameraStack.splice(t,1),this.mainCameraComponent===e&&(this.mainCameraComponent=void 0,this._cameraStack.length>0)){const i=this._cameraStack[this._cameraStack.length-1];this.setCurrentCamera(i)}}_onBeforeRenderListeners=new Map;_onAfterRenderListeners=new Map;addBeforeRenderListener(e,t){if(!this._onBeforeRenderListeners.has(e.uuid)){const i=[];this._onBeforeRenderListeners.set(e.uuid,i),e.onBeforeRender=this._createRenderCallbackWrapper(i)}this._onBeforeRenderListeners.get(e.uuid).push(t)}removeBeforeRenderListener(e,t){if(this._onBeforeRenderListeners.has(e.uuid)){const i=this._onBeforeRenderListeners.get(e.uuid),n=i.indexOf(t);n>=0&&i.splice(n,1)}}addAfterRenderListener(e,t){if(!this._onAfterRenderListeners.has(e.uuid)){const i=[];this._onAfterRenderListeners.set(e.uuid,i),e.onAfterRender=this._createRenderCallbackWrapper(i)}this._onAfterRenderListeners.get(e.uuid)?.push(t)}removeAfterRenderListener(e,t){if(this._onAfterRenderListeners.has(e.uuid)){const i=this._onAfterRenderListeners.get(e.uuid),n=i.indexOf(t);n>=0&&i.splice(n,1)}}_createRenderCallbackWrapper(e){return(t,i,n,o,r,a)=>{for(let l=0;l<e.length;l++){const h=e[l];h(t,i,n,o,r,a)}}}_requireDepthTexture=!1;_requireColorTexture=!1;_renderTarget;_isRendering=!1;get isRendering(){return this._isRendering}setRequireDepth(e){this._requireDepthTexture=e}setRequireColor(e){this._requireColorTexture=e}get depthTexture(){return this._renderTarget?.depthTexture||null}get opaqueColorTexture(){return this._renderTarget?.texture||null}get isVisibleToUser(){if(this.isInXR)return!0;if(!this._isVisible)return!1;if(this.time.frame===this._lastStyleComputedFrame)return this._lastStyleComputedResult;this._lastStyleComputedFrame=this.time.frame;const e=getComputedStyle(this.domElement);return this._lastStyleComputedResult=e.visibility!=="hidden"&&e.display!=="none"&&e.opacity!=="0",this._lastStyleComputedResult}_lastStyleComputedFrame=-1;_lastStyleComputedResult=!0;_createId=0;async internalOnCreate(e){const t=++this._createId;Fe&&console.log("Creating context",this.name,e);const i=globalThis["needle:dependencies:ready"];i instanceof Promise&&(Fe&&console.log("Waiting for dependencies to be ready"),await i.catch(h=>{if(Fe||A()){if(nc("Needle Engine dependencies failed to load. Please check the console for more details"),h instanceof ReferenceError){let d="YourComponentName";const u=h.message.indexOf("'");if(u>0){const p=h.message.indexOf("'",u+1);if(p>0){const m=h.message.substring(u+1,p);m.length>3&&(d=m)}}console.error(`Needle Engine dependencies failed to load:
774
774
 
775
775
  # Make sure you don't have circular imports in your scripts!
776
776
 
@@ -782,7 +782,7 @@ Possible solutions:
782
782
  `,i),this._renderlooperrors>=3&&(console.warn("Stopping render loop due to error"),this.renderer.setAnimationLoop(null)),this.domElement.dispatchEvent(new CustomEvent("error",{detail:i}))}else this.internalStep(e,t)}updatePhysics(e){this.internalUpdatePhysics(e)}_lastTimestamp=0;_accumulatedTime=0;_dispatchReadyAfterFrame=!1;internalStep(e,t){this.internalOnBeforeRender(e,t)!==!1&&(this.internalOnRender(),this.internalOnAfterRender())}internalOnBeforeRender(e,t){this.renderer.info.autoReset=!!t,this.renderer.info.autoReset===!1&&this.renderer.info.reset();const i=t!==null&&this._xrFrame===null;if(this._xrFrame=t,i&&this.domElement.dispatchEvent(new CustomEvent("xr-session-started",{detail:{context:this,session:this.xrSession,frame:t}})),this._currentFrameEvent=-1,this.isManagedExternally===!1&&this.isInXR===!1&&this.targetFrameRate!==void 0){this._lastTimestamp===0&&(this._lastTimestamp=e),this._accumulatedTime+=(e-this._lastTimestamp)/1e3,this._lastTimestamp=e;let n=this.targetFrameRate;if(typeof n=="object"&&(n=n.value),this._accumulatedTime<1/(n+1))return!1;this._accumulatedTime=0}if(this._stats?.begin(),U.Current=this,this.onHandlePaused())return!1;for(U.Current=this,this.time.update(),DC&&console.log("FPS",this.time.smoothedFps.toFixed(0)),id(this),Th(this.scene),Xb(this),hn(this,-1);this._cameraStack.length>0&&(!this.mainCameraComponent||this.mainCameraComponent.destroyed);){this._cameraStack.splice(this._cameraStack.length-1,1);const n=this._cameraStack[this._cameraStack.length-1];this.setCurrentCamera(n)}if(this.pre_update_oneshot_callbacks){for(const n in this.pre_update_oneshot_callbacks)this.pre_update_oneshot_callbacks[n]();this.pre_update_oneshot_callbacks.length=0}if(this.pre_update_callbacks)for(const n in this.pre_update_callbacks)this.pre_update_callbacks[n]();this._currentFrameEvent=0;for(let n=0;n<this.scripts_earlyUpdate.length;n++){const o=this.scripts_earlyUpdate[n];o.activeAndEnabled&&o.earlyUpdate!==void 0&&(U.Current=this,o.earlyUpdate())}if(this.executeCoroutines(0),hn(this,0),this.onHandlePaused())return!1;this._currentFrameEvent=1;for(let n=0;n<this.scripts_update.length;n++){const o=this.scripts_update[n];o.activeAndEnabled&&o.update!==void 0&&(U.Current=this,o.update())}if(this.executeCoroutines(1),hn(this,1),this.onHandlePaused())return!1;this._currentFrameEvent=2;for(let n=0;n<this.scripts_lateUpdate.length;n++){const o=this.scripts_lateUpdate[n];o.activeAndEnabled&&o.lateUpdate!==void 0&&(U.Current=this,o.lateUpdate())}if(this.executeCoroutines(2),hn(this,2),this.onHandlePaused()||(this.physicsSteps===void 0&&(this.physicsSteps=1),this.physics.engine&&this.physicsSteps>0&&this.internalUpdatePhysics(this.physicsSteps),this.onHandlePaused()))return!1;if(this.isVisibleToUser||this.runInBackground){this._currentFrameEvent=3;for(let n=0;n<this.scripts_onBeforeRender.length;n++){const o=this.scripts_onBeforeRender[n];o.activeAndEnabled&&o.onBeforeRender!==void 0&&(U.Current=this,o.onBeforeRender(t))}if(this.executeCoroutines(3),hn(this,3),this._needsUpdateSize&&this.updateSize(),this.pre_render_callbacks)for(const n in this.pre_render_callbacks)this.pre_render_callbacks[n](t)}return!0}internalUpdatePhysics(e){if(!this.physics.engine)return!1;const t=e,i=this.time.deltaTime/t;for(let n=0;n<t;n++)this._currentFrameEvent=9,this.executeCoroutines(9),this.physics.engine.step(i),this._currentFrameEvent=10,this.executeCoroutines(10);return this.physics.engine.postStep(),!0}internalOnRender(){this.isManagedExternally||(US(this),this._currentFrameEvent=-1,G.nodeFrame.update(),this.renderNow(),this._currentFrameEvent=4)}internalOnAfterRender(){if(this.isVisibleToUser||this.runInBackground){for(let e=0;e<this.scripts_onAfterRender.length;e++){const t=this.scripts_onAfterRender[e];t.activeAndEnabled&&t.onAfterRender!==void 0&&(U.Current=this,t.onAfterRender())}if(this.executeCoroutines(4),hn(this,4),this.post_render_callbacks)for(const e in this.post_render_callbacks)this.post_render_callbacks[e]()}this._currentFrameEvent=-1,this.connection.sendBufferedMessagesNow(),this._stats&&(this._stats.end(),this.time.frameCount%150===0&&console.log(this.renderer.info.render.calls+" DrawCalls",`
783
783
  Render:`,{...this.renderer.info.render},`
784
784
  Memory:`,{...this.renderer.info.memory},`
785
- Target Framerate: `+this.targetFrameRate)),this._dispatchReadyAfterFrame&&(this._dispatchReadyAfterFrame=!1,this.domElement.dispatchEvent(new CustomEvent("ready")),re.dispatchCallback(oe.ContextFirstFrameRendered,this))}_tempClearColor=new c.Color;_tempClearColor2=new c.Color;renderNow(e){if(!e&&(e=this.mainCamera,!e))return!1;if(this.handleRendererContextLost(),this._isRendering=!0,this.renderRequiredTextures(),this.renderer.toneMapping!==c.NoToneMapping&&A0(),this.composer&&!this.isInXR){e&&"setMainCamera"in this.composer&&this.composer.passes[0]?.mainCamera!=e&&this.composer.setMainCamera(e);const t=this.renderer.getClearColor(this._tempClearColor),i=this.renderer.getClearAlpha();this._tempClearColor2.copy(t),this.renderer.setClearColor(t.convertSRGBToLinear(),this.renderer.getClearAlpha()),this.composer.render(this.time.deltaTime),this.renderer.setClearColor(this._tempClearColor2,i)}else e&&(this.isInXR&&exports.DeviceUtilities.isMacOS()&&this.renderer.clearDepth(),this.renderer.render(this.scene,e));return this._isRendering=!1,!0}_contextRestoreTries=0;handleRendererContextLost(){this.time.frame%10&&this.renderer.getContext().isContextLost()&&this._contextRestoreTries++<100&&(console.warn("Attempting to recover WebGL context..."),this.renderer.forceContextRestore())}_wasPaused=!1;onHandlePaused(){const e=this.evaluatePaused();if(this._wasPaused!==e){LC&&console.log("Paused?",e,"context:"+this.alias);for(let t=0;t<this.scripts_pausedChanged.length;t++){const i=this.scripts_pausedChanged[t];i.activeAndEnabled&&i.onPausedChanged!==void 0&&(U.Current=this,i.onPausedChanged(e,this._wasPaused))}}return this._wasPaused=e,e}evaluatePaused(){return this.isInXR?!1:this.isPaused?!0:this.runInBackground?!1:!this.isVisibleToUser}renderRequiredTextures(){if(!this.mainCamera||!this._requireDepthTexture&&!this._requireColorTexture)return;if(!this._renderTarget){if(this._renderTarget=new c.WebGLRenderTarget(this.domWidth,this.domHeight),this._requireDepthTexture){const i=new c.DepthTexture(this.domWidth,this.domHeight);this._renderTarget.depthTexture=i}this._requireColorTexture&&(this._renderTarget.texture=new c.Texture,this._renderTarget.texture.generateMipmaps=!1,this._renderTarget.texture.minFilter=c.NearestFilter,this._renderTarget.texture.magFilter=c.NearestFilter,this._renderTarget.texture.format=c.RGBAFormat)}const e=this._renderTarget;e.texture&&(e.texture.colorSpace=this.renderer.outputColorSpace);const t=this.renderer.getRenderTarget();this.renderer.setRenderTarget(e),this.renderer.render(this.scene,this.mainCamera),this.renderer.setRenderTarget(t)}executeCoroutines(e){if(this.coroutines[e]){const i=this.coroutines[e];for(let n=0;n<i.length;n++)try{const o=i[n];if(!o.comp||o.comp.destroyed||!o.main||o.comp.enabled===!1){IC&&console.log("Removing coroutine",o.comp,o.comp.enabled),i.splice(n,1),--n;continue}const a=o.chained;if(a&&a.length>0){const u=a[a.length-1].next();if(u.done&&a.pop(),t(u)&&(o.chained||(o.chained=[]),o.chained.push(u.value)),!u.done)continue}const l=o.main.next();if(l.done===!0){i.splice(n,1),--n;continue}const h=l.value;if(t(h)){if(h.next().done)continue;o.chained||(o.chained=[]),o.chained.push(h)}else if(h instanceof Promise){const d=h;o.chained||(o.chained=[]);const u=M0(d);o.chained?.push(u);continue}}catch(o){console.error(o)}}function t(i){return!!(i&&i.next&&i.return)}}}const oi=w("debuglicense"),B0=[];let On="basic";oi&&console.log("License Type: "+On);function kn(){switch(On){case"pro":case"enterprise":return!0}return!1}function dc(){switch(On){case"indie":return!0}return!1}function gm(){switch(On){case"edu":return!0}return!1}function Rn(){return kn()||dc()||gm()}function FC(s){if(kn()||dc()||gm())return s(!0);B0.push(s)}function ah(s){for(const e of B0)try{e(s)}catch{}}re.registerCallback(oe.ContextRegistered,s=>{NC(s.context),zC(s.context),setTimeout(()=>$C(s.context),2e3)});let ra,cp=!1,hp="";async function UC(){if(ra)return ra;if(On==="basic")try{const s="https://engine.needle.tools/licensing/check?location="+encodeURIComponent(window.location.href)+"&version="+Ji+"&generator="+encodeURIComponent(kd),e=await fetch(s,{method:"GET"}).catch(t=>{oi&&console.error("License check failed",t)});e?.status===200?(cp=!1,oi&&console.log("License check succeeded"),On="pro",ah(!0)):e?.status===403?(ah(!1),cp=!0,hp=await e.text()):(ah(!1),oi&&console.log("License check failed with status "+e?.status))}catch(s){ah(!1),oi&&console.error("License check failed",s)}else oi&&console.log('Runtime license check is skipped because license is already applied as "'+On+'"')}ra=UC();async function zC(s){function e(){const n=document.createElement("div");n.className="needle-forbidden",n.style.cssText=`
785
+ Target Framerate: `+this.targetFrameRate)),this._dispatchReadyAfterFrame&&(this._dispatchReadyAfterFrame=!1,this.domElement.dispatchEvent(new CustomEvent("ready")),re.dispatchCallback(oe.ContextFirstFrameRendered,this))}_tempClearColor=new c.Color;_tempClearColor2=new c.Color;renderNow(e){if(!e&&(e=this.mainCamera,!e))return!1;if(this.handleRendererContextLost(),this.time.frame%10===0){if(this._isRendering=!0,this.renderRequiredTextures(),this.renderer.toneMapping!==c.NoToneMapping&&A0(),this.composer&&!this.isInXR){e&&"setMainCamera"in this.composer&&this.composer.passes[0]?.mainCamera!=e&&this.composer.setMainCamera(e);const t=this.renderer.getClearColor(this._tempClearColor),i=this.renderer.getClearAlpha();this._tempClearColor2.copy(t),this.renderer.setClearColor(t.convertSRGBToLinear(),this.renderer.getClearAlpha()),this.composer.render(this.time.deltaTime),this.renderer.setClearColor(this._tempClearColor2,i)}else e&&(this.isInXR&&exports.DeviceUtilities.isMacOS()&&this.renderer.clearDepth(),this.renderer.render(this.scene,e));return this._isRendering=!1,!0}}_contextRestoreTries=0;handleRendererContextLost(){this.time.frame%10&&this.renderer.getContext().isContextLost()&&this._contextRestoreTries++<100&&(console.warn("Attempting to recover WebGL context..."),this.renderer.forceContextRestore())}_wasPaused=!1;onHandlePaused(){const e=this.evaluatePaused();if(this._wasPaused!==e){LC&&console.log("Paused?",e,"context:"+this.alias);for(let t=0;t<this.scripts_pausedChanged.length;t++){const i=this.scripts_pausedChanged[t];i.activeAndEnabled&&i.onPausedChanged!==void 0&&(U.Current=this,i.onPausedChanged(e,this._wasPaused))}}return this._wasPaused=e,e}evaluatePaused(){return this.isInXR?!1:this.isPaused?!0:this.runInBackground?!1:!this.isVisibleToUser}renderRequiredTextures(){if(!this.mainCamera||!this._requireDepthTexture&&!this._requireColorTexture)return;if(!this._renderTarget){if(this._renderTarget=new c.WebGLRenderTarget(this.domWidth,this.domHeight),this._requireDepthTexture){const i=new c.DepthTexture(this.domWidth,this.domHeight);this._renderTarget.depthTexture=i}this._requireColorTexture&&(this._renderTarget.texture=new c.Texture,this._renderTarget.texture.generateMipmaps=!1,this._renderTarget.texture.minFilter=c.NearestFilter,this._renderTarget.texture.magFilter=c.NearestFilter,this._renderTarget.texture.format=c.RGBAFormat)}const e=this._renderTarget;e.texture&&(e.texture.colorSpace=this.renderer.outputColorSpace);const t=this.renderer.getRenderTarget();this.renderer.setRenderTarget(e),this.renderer.render(this.scene,this.mainCamera),this.renderer.setRenderTarget(t)}executeCoroutines(e){if(this.coroutines[e]){const i=this.coroutines[e];for(let n=0;n<i.length;n++)try{const o=i[n];if(!o.comp||o.comp.destroyed||!o.main||o.comp.enabled===!1){IC&&console.log("Removing coroutine",o.comp,o.comp.enabled),i.splice(n,1),--n;continue}const a=o.chained;if(a&&a.length>0){const u=a[a.length-1].next();if(u.done&&a.pop(),t(u)&&(o.chained||(o.chained=[]),o.chained.push(u.value)),!u.done)continue}const l=o.main.next();if(l.done===!0){i.splice(n,1),--n;continue}const h=l.value;if(t(h)){if(h.next().done)continue;o.chained||(o.chained=[]),o.chained.push(h)}else if(h instanceof Promise){const d=h;o.chained||(o.chained=[]);const u=M0(d);o.chained?.push(u);continue}}catch(o){console.error(o)}}function t(i){return!!(i&&i.next&&i.return)}}}const oi=w("debuglicense"),B0=[];let On="basic";oi&&console.log("License Type: "+On);function kn(){switch(On){case"pro":case"enterprise":return!0}return!1}function dc(){switch(On){case"indie":return!0}return!1}function gm(){switch(On){case"edu":return!0}return!1}function Rn(){return kn()||dc()||gm()}function FC(s){if(kn()||dc()||gm())return s(!0);B0.push(s)}function ah(s){for(const e of B0)try{e(s)}catch{}}re.registerCallback(oe.ContextRegistered,s=>{NC(s.context),zC(s.context),setTimeout(()=>$C(s.context),2e3)});let ra,cp=!1,hp="";async function UC(){if(ra)return ra;if(On==="basic")try{const s="https://engine.needle.tools/licensing/check?location="+encodeURIComponent(window.location.href)+"&version="+Ji+"&generator="+encodeURIComponent(kd),e=await fetch(s,{method:"GET"}).catch(t=>{oi&&console.error("License check failed",t)});e?.status===200?(cp=!1,oi&&console.log("License check succeeded"),On="pro",ah(!0)):e?.status===403?(ah(!1),cp=!0,hp=await e.text()):(ah(!1),oi&&console.log("License check failed with status "+e?.status))}catch(s){ah(!1),oi&&console.error("License check failed",s)}else oi&&console.log('Runtime license check is skipped because license is already applied as "'+On+'"')}ra=UC();async function zC(s){function e(){const n=document.createElement("div");n.className="needle-forbidden",n.style.cssText=`
786
786
  position: fixed;
787
787
  top: 0;
788
788
  left: 0;
@@ -1604,4 +1604,4 @@ Error:`,r),null}}updateColliderCollisionGroups(e){const t=e[Et],i=e.membership;l
1604
1604
  justify-content: center;
1605
1605
  gap: .5rem;
1606
1606
  }
1607
- `),this.#n.innerHTML=this.#e.innerHTML,this.#n.style.cssText="display: flex; align-items: center; justify-content: center;",this.#e.innerHTML=this.#n.outerHTML,this.#t.innerHTML=this.#e.outerHTML,this.#t.prepend(this.#s),ld(lp,{element:this.#t}),this.#o?.disconnect(),this.#o??=new MutationObserver(()=>this.#l()),this.#o.observe(this.#e,{attributes:!0}),Bf&&console.log("Needle Button updated")}#l(){this.#e&&(this.#e.style.display==="none"?this.style.display="none":this.style.display==="none"&&(this.style.display=""))}#r=e=>{Bf&&console.log("Needle Button clicked"),!e.defaultPrevented&&this.#e&&this.#e.click()}}typeof window<"u"&&!window.customElements.get($_)&&window.customElements.define($_,Rw);const tl=w("debugavatar");class $g{root;head;leftHand;rigthHand;get isValid(){return this.head!==null&&this.head!==void 0}constructor(e,t,i,n){this.root=e,this.head=t,this.leftHand=i,this.rigthHand=n,this.root?.traverse(o=>o.layers.set(2))}}class Ew{avatarRegistryUrl=null;async getOrCreateNewAvatarInstance(e,t){if(!t)return console.error("Can not create avatar: failed to provide id or root object"),null;let i=null;if(typeof t=="string"){if(i=await this.loadAvatar(e,t),!i){const o=new sn;i=x.instantiate(Zr(t,e.scene),o)}}else i=t;if(!i)return null;const n=this.findAvatar(i);return n.isValid?(tl&&console.log("[Custom Avatar] valid config",t,tl?n:""),n):(console.warn("[Custom Avatar] config isn't valid",t,tl?n:""),null)}async loadAvatar(e,t){if(console.assert(t!=null&&typeof t=="string","Avatar id must not be null"),t.length<=0||!t)return null;if(tl&&console.log("[Custom Avatar] "+t+", loading..."),t.endsWith(".glb")||(t+=".glb"),this.avatarRegistryUrl===null){const n=await fetch("./"+t);let o=null;if(n.ok){const a=await n.blob();a&&(o=await a.arrayBuffer())}return o?(await en().parseSync(e,o,null,0))?.scene??null:null}const i=new G.GLTFLoader;return _m(i,e),new Promise((n,o)=>{const r=this.avatarRegistryUrl+"/"+t;i.load(r,async a=>{await en().createBuiltinComponents(e,r,a,null,void 0),n(a.scene)},a=>{tl&&console.log("[Custom Avatar] "+a.loaded/a.total*100+"% loaded of "+a.total/1024+"kB")},a=>{console.error("[Custom Avatar] Error when loading: "+a),n(null)})})}cacheModel(e,t){}findAvatar(e){const t=e;let i=t;i.children.length==1&&(i=e.children[0]);let n=this.findAvatarPart(i,["head"]);const o=this.findAvatarPart(i,["left","hand"]),r=this.findAvatarPart(i,["right","hand"]);if(!n){n=t;const l=new c.Vector3;new c.Box3().setFromObject(n).getSize(l);const h=Math.max(l.x,l.y,l.z);console.warn("[Custom Avatar] Normalizing head scale, it's too big: "+h+" meters! Should be < 0.3m"),h>.3&&n.scale.multiplyScalar(1/h*.3)}return new $g(t,n,o,r)}findAvatarPart(e,t){const i=e.name.toLowerCase();let n=!0;for(const o of t){if(!n)break;i.indexOf(o)===-1&&(n=!1)}if(n)return e;if(e.children)for(const o of e.children){const r=this.findAvatarPart(o,t);if(r)return r}return null}handleCustomAvatarErrors(e){if(!e.ok)throw Error(e.statusText);return e}}class Tw{get extensionName(){return"DocumentExtension"}onAfterBuildDocument(e){}}class Aw{}const ZR=Object.freeze(Object.defineProperty({__proto__:null,ActionBuilder:ae,ActionCollection:Uv,ActionModel:Vt,AlignmentConstraint:uc,Animation:wt,AnimationCurve:Tc,AnimationExtension:Jd,AnimationTrackHandler:xu,Animator:mt,AnimatorController:Li,Antialiasing:Lc,AudioExtension:ar,AudioListener:is,AudioSource:Ii,AudioTrackHandler:ss,Avatar:Xs,AvatarBlink_Simple:nr,AvatarEyeLook_Rotation:Om,AvatarLoader:Ew,AvatarMarker:xe,AvatarModel:$g,Avatar_Brain_LookAt:$l,Avatar_MouthShapes:gc,Avatar_MustacheShake:Pm,Avatar_POI:Fo,AxesHelper:ma,BaseUIComponent:Bi,BasicIKConstraint:Rm,BehaviorExtension:sg,BehaviorModel:pt,BloomEffect:fu,BoxCollider:Xd,BoxGizmo:dr,BoxHelperComponent:nt,Button:bs,CallInfo:ts,Camera:Wt,CameraTargetReachedEvent:Vl,Canvas:ca,CanvasGroup:Qs,CapsuleCollider:as,ChangeMaterialOnClick:Qm,ChangeTransformOnClick:lr,CharacterController:sr,CharacterControllerInput:ds,ChromaticAberration:Dc,Collider:Qt,ColorAdjustments:co,ColorBySpeedModule:Oa,ColorOverLifetimeModule:hu,ContactShadows:yc,ControlTrackHandler:Su,CustomBranding:hr,Deletable:Lm,DeleteBox:$s,DepthOfField:an,DeviceFlag:Qd,DocumentExtension:Tw,DragControls:Mo,DropListener:us,Duplicatable:jm,EffectWrapper:Xl,EmissionModule:ys,EmphasizeOnClick:ba,EnvironmentScene:ku,EventList:de,EventListEvent:$d,EventSystem:jt,EventTrigger:Kd,FieldWithDefault:Cv,FixedJoint:_g,Fog:Ca,GltfExport:Gm,GltfExportBox:$m,Gradient:fr,Graphic:Mc,GraphicRaycaster:Wd,GridHelper:Pa,GridLayoutGroup:hg,GroundProjectedEnv:Dn,GroupActionModel:Oo,HideOnStart:Ri,HingeJoint:kc,HorizontalLayoutGroup:cg,Image:Ea,InheritVelocityModule:xg,InputField:Ig,InstanceHandle:Uo,InstancingHandler:qo,Interactable:Am,Keyframe:Gt,LODGroup:Ec,LODModel:Ma,Light:yi,LimitVelocityOverLifetimeModule:et,LogStats:Tm,LookAt:jg,LookAtConstraint:ir,MainModule:Pt,MaskableGraphic:Oc,MeshCollider:io,MeshRenderer:bc,MinMaxCurve:H,MinMaxGradient:pr,NeedleMenu:jn,NestedGltf:au,Networking:vg,NoiseModule:fe,ObjectRaycaster:ui,OffsetConstraint:ur,OpenURL:Ta,OrbitControls:he,Outline:Sa,Padding:cr,ParticleBurst:wd,ParticleSubEmitter:Sg,ParticleSystem:ql,ParticleSystemRenderer:Vi,PhysicsExtension:og,PixelationEffect:Ic,PlayAnimationOnClick:Gl,PlayAudioOnClick:qs,PlayableDirector:da,PlayerColor:ha,PointerEventData:pc,PostProcessingHandler:Og,PreliminaryAction:va,PreliminaryTrigger:xc,RawImage:Mu,Rect:Wv,RectTransform:nn,ReflectionProbe:Wl,RegisteredAnimationInfo:zs,RemoteSkybox:mu,Renderer:fi,RendererLightmap:yd,Rigidbody:Ke,RotationBySpeedModule:Ni,RotationOverLifetimeModule:rn,SceneSwitcher:Ie,ScreenCapture:ho,ScreenSpaceAmbientOcclusion:_s,ScreenSpaceAmbientOcclusionN8:ln,SetActiveOnClick:Ym,ShadowCatcher:Uc,ShapeModule:wg,SharpeningEffect:Bc,SignalAsset:wu,SignalReceiver:Wc,SignalReceiverEvent:$c,SignalTrackHandler:Ql,Size:$v,SizeBySpeedModule:Zt,SizeOverLifetimeModule:mr,SkinnedMeshRenderer:Vm,SmoothFollow:yu,SpatialGrabRaycaster:Go,SpatialHtml:qc,SpatialTrigger:_u,SpatialTriggerReceiver:Tn,SpectatorCamera:bu,SphereCollider:ga,Sprite:ps,SpriteData:Yr,SpriteRenderer:Yt,SpriteSheet:la,SubEmitterSystem:xd,SyncedCamera:Rg,SyncedRoom:cn,SyncedTransform:Ln,TapGestureTrigger:Zm,TeleportTarget:su,TestRunner:Eg,TestSimulateUserData:Tg,Text:Ct,TextBuilder:ag,TextExtension:ru,TextureSheetAnimationModule:Mt,TiltShiftEffect:Un,ToneMappingEffect:Ys,TrailModule:Re,TransformData:Oe,TransformGizmo:br,TriggerBuilder:xt,TriggerModel:Ws,UIRaycastUtils:wm,UIRootComponent:Cc,USDZExporter:En,USDZText:Vr,USDZUIExtension:ug,UsageMarker:_c,VariantAction:Xm,VelocityOverLifetimeModule:Ae,VerticalLayoutGroup:lg,VideoPlayer:Ze,Vignette:_r,VisibilityAction:Sc,Voip:to,Volume:Ra,VolumeParameter:D,VolumeProfile:du,WebARCameraBackground:Qc,WebARSessionRoot:li,WebXR:ou,WebXRImageTracking:Yl,WebXRImageTrackingModel:ws,WebXRPlaneTracking:xs,WebXRTrackedImage:ua,XRControllerFollow:vs,XRControllerModel:ls,XRControllerMovement:pi,XRFlag:Ei,XRRig:Eu,XRState:It,__Ignore:Aw},Symbol.toStringTag,{value:"Module"})),Pd=w("debugmissingcamera");re.registerCallback(oe.MissingCamera,s=>{Pd&&console.warn("Creating missing camera");const e=s.context.scene,t=new c.PerspectiveCamera;t.name="Default Fallback Camera",e.add(t);const i=new Wt;if(i.sourceId=s.files?.[0]?.src??"unknown",i.fieldOfView=35,s.context.domElement.getAttribute("transparent")!=null)i.clearFlags=Bo.Uninitialized;else if(s.context.domElement.getAttribute("background-image")?.length||s.context.lightmaps.tryGetSkybox(i.sourceId))i.clearFlags=Bo.Skybox,s.context.domElement.getAttribute("background-blurriness")===null&&(s.context.scene.backgroundBlurriness=.2);else{if(i.clearFlags=Bo.SolidColor,!s.context.domElement.getAttribute("background-color")){let a="#efefef";typeof window!==void 0&&window.matchMedia("(prefers-color-scheme: dark)").matches&&(a="#1f1f1f"),e.background=new c.Color(a)}if(!e.environment){const a=new c.PMREMGenerator$1(s.context.renderer),l=new ku("neutral");e.environment=a.fromScene(l,.025).texture}}const o=Ao(t,i,!0);return t.position.x=0,t.position.y=1,t.position.z=2,s.context.domElement?.cameraControls!=!1&&Lw(s.context,o),o});re.registerCallback(oe.ContextCreated,s=>{if(!s.context.mainCamera){Pd&&console.log("Will not auto-fit because a default camera exists");return}if(s.context.domElement?.cameraControls==!0){if(rb(s.context.mainCamera)?.isCameraController==!0){Pd&&console.log("Will not auto-fit because a camera controller exists");return}Lw(s.context)}});function Lw(s,e){e=e??s.mainCameraComponent;const t=e?.gameObject;if(Pd&&console.log("Creating default camera controls",e?.name),t){const i=rc(t,he);i.sourceId=e?.sourceId??"unknown";const n=s.domElement.getAttribute("auto-rotate");if(i.autoRotate=n!=null&&n!="0"&&n?.toLowerCase()!="false",i.autoRotateSpeed=.5,i.autoFit=!0,i.autoRotate&&n){const o=parseFloat(n);isNaN(o)||(i.autoRotateSpeed=o)}}else console.warn("Missing camera object, can not add orbit controls")}re.registerCallback(oe.ContextCreated,s=>{const e=s.context.domElement.getAttribute("autoplay");if(e!==void 0&&(e===""||e==="true"||e==="1")&&s.files)for(const t of s.files)x.foreachComponent(t.file.scene,n=>{if(n.enabled!==!1){if(n instanceof wt&&n.playAutomatically||n instanceof mt||n instanceof da&&n.playOnAwake===!0)return!0;if(n instanceof wt)return n.playAutomatically=!0,!0;if(n instanceof da)return n.playOnAwake=!0,!0}},!0)!==!0&&oa.assignAnimationsFromFile(t.file,{createAnimationComponent:(n,o)=>ci(n,wt)})});class JR extends se.WorkerBase{constructor(){super(new Worker(new URL("/generateMeshBVH.worker-2qGLkQjg.js",typeof document>"u"?require("url").pathToFileURL(__filename).href:Au&&Au.tagName.toUpperCase()==="SCRIPT"&&Au.src||new URL("needle-engine.bundle-D8-9woI_.umd.cjs",document.baseURI).href),{type:"module"})),this.name="GenerateMeshBVHWorker"}runTask(e,t,i={}){return new Promise((n,o)=>{if(t.getAttribute("position").isInterleavedBufferAttribute||t.index&&t.index.isInterleavedBufferAttribute)throw new Error("GenerateMeshBVHWorker: InterleavedBufferAttribute are not supported for the geometry attributes.");e.onerror=h=>{o(new Error(`[GenerateMeshBVHWorker] ${h.message||"Unknown error. Please check the server console. If you're using vite try adding 'three-mesh-bvh' to 'optimizeDeps.exclude' in your vite.config.js"}`))},e.onmessage=h=>{const{data:d}=h;if(d.error)o(new Error(d.error)),e.onmessage=null;else if(d.serialized){const{serialized:u,position:p}=d,m=se.MeshBVH.deserialize(u,t,{setIndex:!1}),y=Object.assign({setBoundingBox:!0},i);if(t.attributes.position.array=p,u.index)if(t.index)t.index.array=u.index;else{const b=new c.BufferAttribute(u.index,1,!1);t.setIndex(b)}y.setBoundingBox&&(t.boundingBox=m.getBoundingBox(new c.Box3)),i.onProgress&&i.onProgress(d.progress),n(m),e.onmessage=null}else i.onProgress&&i.onProgress(d.progress)};const r=t.index?t.index.array:null,a=t.attributes.position.array,l=[a];r&&l.push(r),e.postMessage({index:r,position:a,options:{...i,onProgress:null,includedProgressCallback:!!i.onProgress,groups:[...t.groups]}},l.map(h=>h.buffer).filter(h=>typeof SharedArrayBuffer>"u"||!(h instanceof SharedArrayBuffer)))})}}const eE=Object.freeze(Object.defineProperty({__proto__:null,GenerateMeshBVHWorker:JR},Symbol.toStringTag,{value:"Module"}));exports.$physicsKey=$1;exports.ActionBuilder=ae;exports.ActionCollection=Uv;exports.ActionModel=Vt;exports.Addressables=S0;exports.AlignmentConstraint=uc;exports.AmbientMode=Xr;exports.Animation=wt;exports.AnimationCurve=Tc;exports.AnimationExtension=Jd;exports.AnimationTrackHandler=xu;exports.AnimationUtils=oa;exports.Animator=mt;exports.AnimatorConditionMode=Is;exports.AnimatorController=Li;exports.AnimatorControllerParameterType=bm;exports.AnimatorStateInfo=al;exports.Antialiasing=Lc;exports.Application=tn;exports.AssetDatabase=zb;exports.AssetReference=Y;exports.AudioExtension=ar;exports.AudioListener=is;exports.AudioSource=Ii;exports.AudioTrackHandler=ss;exports.Avatar=Xs;exports.AvatarBlink_Simple=nr;exports.AvatarEyeLook_Rotation=Om;exports.AvatarLoader=Ew;exports.AvatarMarker=xe;exports.AvatarModel=$g;exports.Avatar_Brain_LookAt=$l;exports.Avatar_MouthShapes=gc;exports.Avatar_MustacheShake=Pm;exports.Avatar_POI=Fo;exports.Axes=zr;exports.AxesHelper=ma;exports.BUILD_TIME=qp;exports.BaseUIComponent=Bi;exports.BasicIKConstraint=Rm;exports.BehaviorExtension=sg;exports.BehaviorModel=pt;exports.BloomEffect=fu;exports.BoxCollider=Xd;exports.BoxGizmo=dr;exports.BoxHelperComponent=nt;exports.Button=bs;exports.ButtonsFactory=Ki;exports.CallDirection=sv;exports.CallInfo=ts;exports.Camera=Wt;exports.CameraTargetReachedEvent=Vl;exports.Canvas=ca;exports.CanvasGroup=Qs;exports.CapsuleCollider=as;exports.ChangeMaterialOnClick=Qm;exports.ChangeTransformOnClick=lr;exports.CharacterController=sr;exports.CharacterControllerInput=ds;exports.ChromaticAberration=Dc;exports.CircularBuffer=hi;exports.ClearFlags=Bo;exports.ClipExtrapolation=pn;exports.Collider=Qt;exports.Collision=tv;exports.CollisionDetectionMode=Vd;exports.ColorAdjustments=co;exports.ColorBySpeedModule=Oa;exports.ColorOverLifetimeModule=hu;exports.Component=ZC;exports.Component$1=k;exports.ComponentLifecycleEvents=Dd;exports.Components=ZR;exports.ConnectionEvents=Db;exports.ContactPoint=ev;exports.ContactShadows=yc;exports.Context=U;exports.ContextArgs=BC;exports.ContextEvent=oe;exports.ContextRegistry=re;exports.ControlTrackHandler=Su;exports.CustomBranding=hr;exports.CustomShader=_e;exports.DefaultReflectionMode=ad;exports.Deletable=Lm;exports.DeleteBox=$s;exports.DepthOfField=an;exports.DeviceFlag=Qd;exports.DocumentExtension=Tw;exports.DragControls=Mo;exports.DragMode=Dm;exports.DropListener=us;exports.Duplicatable=jm;exports.EffectWrapper=Xl;exports.EmissionModule=ys;exports.EmphasizeOnClick=ba;exports.EngineLoadingView=Kl;exports.EnvironmentScene=ku;exports.EventList=de;exports.EventListEvent=$d;exports.EventSystem=jt;exports.EventTrigger=Kd;exports.FieldWithDefault=Cv;exports.FileReference=Io;exports.FileReferenceSerializer=P0;exports.FileSpawnModel=uP;exports.File_Event=dv;exports.FixedJoint=_g;exports.Fog=Ca;exports.FrameEvent=pe;exports.GENERATOR=kd;exports.GameObject=x;exports.Gizmos=j;exports.GltfExport=Gm;exports.GltfExportBox=$m;exports.Gradient=fr;exports.Graphic=Mc;exports.GraphicRaycaster=Wd;exports.Graphics=Hs;exports.GridHelper=Pa;exports.GridLayoutGroup=hg;exports.GroundProjectedEnv=Dn;exports.GroupActionModel=Oo;exports.HideFlags=Gd;exports.HideOnStart=Ri;exports.HingeJoint=kc;exports.HorizontalLayoutGroup=cg;exports.HostData=NS;exports.Image=Ea;exports.ImageReference=Do;exports.ImageReferenceSerializer=C0;exports.InheritVelocityModule=xg;exports.Input=kb;exports.InputEventQueue=$t;exports.InputEvents=we;exports.InputField=Ig;exports.InstanceHandle=Uo;exports.InstancingHandler=qo;exports.InstancingUtil=Ai;exports.InstantiateEvent=Kb;exports.InstantiateIdProvider=ft;exports.InstantiateOptions=sn;exports.Interactable=Am;exports.JoinedRoomResponse=uS;exports.KeyEventArgs=tS;exports.Keyframe=Gt;exports.LODGroup=Ec;exports.LODModel=Ma;exports.LeftRoomResponse=fS;exports.Light=yi;exports.LightData=E0;exports.LimitVelocityOverLifetimeModule=et;exports.LoadingElementOptions=BR;exports.LogStats=Tm;exports.LogType=ai;exports.LookAt=jg;exports.LookAtConstraint=ir;exports.MainModule=Pt;exports.MarkerType=Ag;exports.MaskableGraphic=Oc;exports.Mathf=I;exports.MeshCollider=io;exports.MeshRenderer=bc;exports.MinMaxCurve=H;exports.MinMaxGradient=pr;exports.NEKeyboardEvent=nl;exports.NEPointerEvent=Yn;exports.NeedleButtonElement=Rw;exports.NeedleEngineWebComponent=Vg;exports.NeedleMenu=jn;exports.NeedlePatchesKey=Eh;exports.NeedleXRController=Kp;exports.NeedleXRSession=q;exports.NeedleXRSync=Bb;exports.NeedleXRUtils=Ub;exports.NestedGltf=au;exports.NetworkConnection=jb;exports.NetworkedStreamEvents=Sn;exports.NetworkedStreams=mc;exports.Networking=vg;exports.NewInstanceModel=Jb;exports.NoiseModule=fe;exports.ObjectRaycaster=ui;exports.ObjectUtils=Ko;exports.OffsetConstraint=ur;exports.OneEuroFilter=kh;exports.OneEuroFilterXYZ=Up;exports.OpenURL=Ta;exports.OrbitControls=he;exports.Outline=Sa;exports.OwnershipEvent=Ib;exports.OwnershipModel=tm;exports.PUBLIC_KEY=Br;exports.Padding=cr;exports.ParticleBurst=wd;exports.ParticleSubEmitter=Sg;exports.ParticleSystem=ql;exports.ParticleSystemBaseBehaviour=lo;exports.ParticleSystemRenderer=Vi;exports.ParticleSystemShapeType=vd;exports.PeerHandle=ns;exports.PeerNetworking=Lb;exports.Physics=na;exports.PhysicsExtension=og;exports.PhysicsMaterialCombine=it;exports.PixelationEffect=Ic;exports.PlayAnimationOnClick=Gl;exports.PlayAudioOnClick=qs;exports.PlayableDirector=da;exports.PlayerColor=ha;exports.PlayerState=Zi;exports.PlayerStateEvent=Vv;exports.PlayerSync=ig;exports.PlayerView=O0;exports.PlayerViewManager=k0;exports.PointerEventData=pc;exports.PointerType=Td;exports.PostProcessingEffect=Ne;exports.PostProcessingEffectOrder=Qe;exports.PostProcessingHandler=Og;exports.PreliminaryAction=va;exports.PreliminaryTrigger=xc;exports.PrimitiveType=No;exports.Progress=ie;exports.PromiseAllWithErrors=Bp;exports.PromiseErrorResult=zf;exports.RGBAColor=Z;exports.RapierPhysics=Kr;exports.RawImage=Mu;exports.RaycastOptions=eo;exports.Rect=Wv;exports.RectTransform=nn;exports.ReflectionProbe=Wl;exports.RegisteredAnimationInfo=zs;exports.RemoteSkybox=mu;exports.RenderTexture=xn;exports.RenderTextureSerializer=Y0;exports.Renderer=fi;exports.RendererData=R0;exports.RendererLightmap=yd;exports.Rigidbody=Ke;exports.RigidbodyConstraints=Le;exports.RoomEvents=Q;exports.RotationBySpeedModule=Ni;exports.RotationOverLifetimeModule=rn;exports.SceneLightSettings=pd;exports.SceneSwitcher=Ie;exports.ScreenCapture=ho;exports.ScreenSpaceAmbientOcclusion=_s;exports.ScreenSpaceAmbientOcclusionN8=ln;exports.SendQueue=Yi;exports.SerializationContext=dm;exports.SetActiveOnClick=Ym;exports.ShadowCatcher=Uc;exports.ShapeModule=wg;exports.ShapeOverlapResult=iv;exports.SharpeningEffect=Bc;exports.SignalAsset=wu;exports.SignalReceiver=Wc;exports.SignalReceiverEvent=$c;exports.SignalTrackHandler=Ql;exports.Size=$v;exports.SizeBySpeedModule=Zt;exports.SizeOverLifetimeModule=mr;exports.SkinnedMeshRenderer=Vm;exports.SmoothFollow=yu;exports.SpatialGrabRaycaster=Go;exports.SpatialHtml=qc;exports.SpatialTrigger=_u;exports.SpatialTriggerReceiver=Tn;exports.SpectatorCamera=bu;exports.SphereCollider=ga;exports.SphereIntersection=sm;exports.Sprite=ps;exports.SpriteData=Yr;exports.SpriteRenderer=Yt;exports.SpriteSheet=la;exports.StateMachineBehaviour=s1;exports.StreamEndedEvent=Sm;exports.StreamReceivedEvent=nv;exports.SubEmitterSystem=xd;exports.SyncedCamera=Rg;exports.SyncedRoom=cn;exports.SyncedTransform=Ln;exports.TapGestureTrigger=Zm;exports.TeleportTarget=su;exports.TestRunner=Eg;exports.TestSceneUtils=HR;exports.TestSimulateUserData=Tg;exports.Text=Ct;exports.TextBuilder=ag;exports.TextExtension=ru;exports.TextureSheetAnimationModule=Mt;exports.TiltShiftEffect=Un;exports.Time=T0;exports.ToneMappingEffect=Ys;exports.TrackHandler=Gc;exports.TrackType=ti;exports.TrailModule=Re;exports.TransformData=Oe;exports.TransformGizmo=br;exports.TriggerBuilder=xt;exports.TriggerModel=Ws;exports.TypeStore=P;exports.UIRaycastUtils=wm;exports.UIRootComponent=Cc;exports.USDDocument=Hm;exports.USDObject=ze;exports.USDWriter=Ev;exports.USDZExporter=En;exports.USDZExporter$1=Tv;exports.USDZText=Vr;exports.USDZUIExtension=ug;exports.UriSerializer=K0;exports.UsageMarker=_c;exports.UserJoinedOrLeftRoomModel=pS;exports.VERSION=Ji;exports.VariantAction=Xm;exports.VelocityOverLifetimeModule=Ae;exports.VerticalLayoutGroup=lg;exports.VideoPlayer=Ze;exports.ViewDevice=Ns;exports.Vignette=_r;exports.VisibilityAction=Sc;exports.Voip=to;exports.Volume=Ra;exports.VolumeParameter=D;exports.VolumeProfile=du;exports.WaitForFrames=gC;exports.WaitForPromise=M0;exports.WaitForSeconds=pm;exports.Watch=os;exports.WebARCameraBackground=Qc;exports.WebARSessionRoot=li;exports.WebXR=ou;exports.WebXRButtonFactory=Gs;exports.WebXRImageTracking=Yl;exports.WebXRImageTrackingModel=ws;exports.WebXRPlaneTracking=xs;exports.WebXRTrackedImage=ua;exports.XRControllerFollow=vs;exports.XRControllerModel=ls;exports.XRControllerMovement=pi;exports.XRFlag=Ei;exports.XRRig=Eu;exports.XRState=It;exports.XRStateFlag=bn;exports.__Ignore=Aw;exports.__internalNotifyObjectDestroyed=Gb;exports.activeInHierarchyFieldName=rs;exports.addAttributeChangeCallback=K_;exports.addComponent=ci;exports.addCustomExtensionPlugin=DP;exports.addNewComponent=Ao;exports.addPatch=Rd;exports.apply=jd;exports.applyHMRChanges=KC;exports.applyPrototypeExtensions=d0;exports.beginListenDestroy=Zb;exports.beginListenInstantiate=t0;exports.binaryIdentifierCasts=Zp;exports.build_scene_functions=jC;exports.builtinComponentKeyName=xo;exports.calculateProgress01=Ng;exports.clearMessages=mx;exports.colorSerializer=w1;exports.compareAssociation=o0;exports.componentSerializer=Uh;exports.copyTexture=fb;exports.createMotion=H0;exports.debugNet=Ut;exports.debugOwner=sl;exports.decompressGpuTexture=Iv;exports.deepClone=Jl;exports.delay=An;exports.delayForFrames=ec;exports.deserializeObject=od;exports.destroy=di;exports.destroyComponentInstance=p0;exports.determineMimeTypeFromExtension=uv;exports.disposeObjectResources=ge;exports.disposeStream=Cn;exports.editorGuidKeyName=xl;exports.enableSpatialConsole=Ro;exports.euler=S1;exports.eventListSerializer=O1;exports.exportAsGLTF=QR;exports.findByGuid=fm;exports.findObjectOfType=cc;exports.findObjectsOfType=g0;exports.findResourceUsers=om;exports.fitObjectIntoVolume=mb;exports.foreachComponent=$o;exports.foreachComponentEnumerator=Fd;exports.forward=Ex;exports.generateQRCode=J_;exports.generateSeed=e0;exports.getBoundingBox=Ht;exports.getCameraController=rb;exports.getComponent=Jo;exports.getComponentInChildren=lc;exports.getComponentInParent=Ul;exports.getComponents=ac;exports.getComponentsInChildren=fa;exports.getComponentsInParent=Id;exports.getFormattedDate=Mv;exports.getIconElement=ut;exports.getIconTexture=ap;exports.getLoader=en;exports.getOrAddComponent=rc;exports.getParam=w;exports.getParentHierarchyPath=Lx;exports.getPath=Xw;exports.getPeerOptions=lS;exports.getPeerjsInstance=Ab;exports.getResourceUserCount=AS;exports.getTempColor=cb;exports.getTempQuaternion=Xi;exports.getTempVector=V;exports.getUrlParams=Zl;exports.getVisibleInCustomShadowRendering=pb;exports.getWorldDirection=hb;exports.getWorldEuler=Vp;exports.getWorldPosition=X;exports.getWorldQuaternion=ue;exports.getWorldRotation=Od;exports.getWorldScale=Te;exports.hasCommercialLicense=Rn;exports.hasIndieLicense=dc;exports.hasPointerEventComponent=hd;exports.hasProLicense=kn;exports.hideDebugConsole=bb;exports.imageToCanvas=jv;exports.instantiate=Wo;exports.invokeLoadedImportPluginHooks=wv;exports.invokeXRSessionEnd=Ob;exports.invokeXRSessionStart=Mb;exports.isActiveInHierarchy=y0;exports.isActiveSelf=pa;exports.isAndroidDevice=ex;exports.isAnimationAction=ub;exports.isComponent=J0;exports.isDebugMode=Ww;exports.isDesktop=Yw;exports.isDestroyed=Vo;exports.isDevEnvironment=A;exports.isDisposed=ES;exports.isExporting=qR;exports.isGLTFModel=Z0;exports.isHostedOnGlitch=W_;exports.isHotReloadEnabled=up;exports.isHotReloading=QC;exports.isIPad=Zw;exports.isIconElement=D0;exports.isLocalNetwork=Bt;exports.isMacOS=ix;exports.isMobileDevice=Kw;exports.isMozillaXR=tx;exports.isQuest=ox;exports.isResourceTrackingEnabled=Vb;exports.isSafari=sx;exports.isUsingInstancing=Bd;exports.isiOS=nx;exports.isiPad=Jw;exports.loadAsset=TR;exports.loadSync=zg;exports.logHierarchy=Kh;exports.lookAtInverse=xx;exports.lookAtObject=tc;exports.lookAtScreenPoint=Sx;exports.makeId=Hw;exports.makeIdFromRandomWords=X_;exports.makeNameSafe=ji;exports.markAsInstancedRendered=_0;exports.microphonePermissionsGranted=rx;exports.nameof=$w;exports.nameofFactory=H_;exports.objectSerializer=Q0;exports.offXRSessionEnd=eS;exports.offXRSessionStart=Jx;exports.onAfterRender=qC;exports.onBeforeRender=HC;exports.onClear=WC;exports.onDestroy=GC;exports.onInitialized=U0;exports.onStart=ym;exports.onUpdate=z0;exports.onXRSessionEnd=Yp;exports.onXRSessionStart=Ed;exports.parseSync=Cw;exports.placeOnSurface=gb;exports.postprocessFBXMaterials=Gp;exports.prefix=m1;exports.pushState=q_;exports.randomNumber=qw;exports.registerBinaryType=Jp;exports.registerComponent=zd;exports.registerComponentExtension=Um;exports.registerCustomEffectType=$i;exports.registerExportExtensions=zm;exports.registerExtensions=gd;exports.registerHotReloadType=V0;exports.registerLoader=Xp;exports.registerPrefabProvider=n0;exports.registerPrototypeExtensions=u0;exports.registerType=HS;exports.relativePathPrefix=Y_;exports.removeAttributeChangeCallback=Z_;exports.removeComponent=um;exports.removeCustomImportExtensionType=IP;exports.removePatch=Kx;exports.resolveUrl=Ks;exports.sanitizeString=Q_;exports.saveImage=vw;exports.screenshot=pR;exports.screenshot2=Fg;exports.sendDestroyed=am;exports.serializable=f;exports.serializeObject=a0;exports.serializeable=er;exports.setActive=Pl;exports.setAllowBalloonMessages=nb;exports.setAllowOverlayMessages=dx;exports.setAutoFitEnabled=Qh;exports.setCameraController=$f;exports.setDestroyed=v0;exports.setDevEnvironment=Nx;exports.setDisposable=Ld;exports.setDontDestroy=Tr;exports.setOrAddParamsToUrl=Uf;exports.setParam=Gw;exports.setParamWithoutReload=Dl;exports.setPeerOptions=cS;exports.setResourceTrackingEnabled=RS;exports.setState=Ip;exports.setVisibleInCustomShadowRendering=Wp;exports.setWorldEuler=$p;exports.setWorldPosition=Ye;exports.setWorldPositionXYZ=zo;exports.setWorldQuaternion=Di;exports.setWorldQuaternionXYZW=Np;exports.setWorldRotation=db;exports.setWorldRotationXYZ=ic;exports.setWorldScale=Jr;exports.showBalloonError=nc;exports.showBalloonMessage=Se;exports.showBalloonWarning=ce;exports.showDebugConsole=Hp;exports.slerp=wx;exports.syncDestroy=sc;exports.syncField=tg;exports.syncInstantiate=lm;exports.textureToCanvas=Dx;exports.tryCastBinary=Eb;exports.tryDetermineMimetypeFromBinary=pv;exports.tryDetermineMimetypeFromURL=fv;exports.tryFindObject=Zr;exports.tryGetGuid=Tb;exports.unregisterHotReloadType=$0;exports.unwatchWrite=jp;exports.useForAutoFit=ab;exports.validate=gt;exports.watchWrite=Md;
1607
+ `),this.#n.innerHTML=this.#e.innerHTML,this.#n.style.cssText="display: flex; align-items: center; justify-content: center;",this.#e.innerHTML=this.#n.outerHTML,this.#t.innerHTML=this.#e.outerHTML,this.#t.prepend(this.#s),ld(lp,{element:this.#t}),this.#o?.disconnect(),this.#o??=new MutationObserver(()=>this.#l()),this.#o.observe(this.#e,{attributes:!0}),Bf&&console.log("Needle Button updated")}#l(){this.#e&&(this.#e.style.display==="none"?this.style.display="none":this.style.display==="none"&&(this.style.display=""))}#r=e=>{Bf&&console.log("Needle Button clicked"),!e.defaultPrevented&&this.#e&&this.#e.click()}}typeof window<"u"&&!window.customElements.get($_)&&window.customElements.define($_,Rw);const tl=w("debugavatar");class $g{root;head;leftHand;rigthHand;get isValid(){return this.head!==null&&this.head!==void 0}constructor(e,t,i,n){this.root=e,this.head=t,this.leftHand=i,this.rigthHand=n,this.root?.traverse(o=>o.layers.set(2))}}class Ew{avatarRegistryUrl=null;async getOrCreateNewAvatarInstance(e,t){if(!t)return console.error("Can not create avatar: failed to provide id or root object"),null;let i=null;if(typeof t=="string"){if(i=await this.loadAvatar(e,t),!i){const o=new sn;i=x.instantiate(Zr(t,e.scene),o)}}else i=t;if(!i)return null;const n=this.findAvatar(i);return n.isValid?(tl&&console.log("[Custom Avatar] valid config",t,tl?n:""),n):(console.warn("[Custom Avatar] config isn't valid",t,tl?n:""),null)}async loadAvatar(e,t){if(console.assert(t!=null&&typeof t=="string","Avatar id must not be null"),t.length<=0||!t)return null;if(tl&&console.log("[Custom Avatar] "+t+", loading..."),t.endsWith(".glb")||(t+=".glb"),this.avatarRegistryUrl===null){const n=await fetch("./"+t);let o=null;if(n.ok){const a=await n.blob();a&&(o=await a.arrayBuffer())}return o?(await en().parseSync(e,o,null,0))?.scene??null:null}const i=new G.GLTFLoader;return _m(i,e),new Promise((n,o)=>{const r=this.avatarRegistryUrl+"/"+t;i.load(r,async a=>{await en().createBuiltinComponents(e,r,a,null,void 0),n(a.scene)},a=>{tl&&console.log("[Custom Avatar] "+a.loaded/a.total*100+"% loaded of "+a.total/1024+"kB")},a=>{console.error("[Custom Avatar] Error when loading: "+a),n(null)})})}cacheModel(e,t){}findAvatar(e){const t=e;let i=t;i.children.length==1&&(i=e.children[0]);let n=this.findAvatarPart(i,["head"]);const o=this.findAvatarPart(i,["left","hand"]),r=this.findAvatarPart(i,["right","hand"]);if(!n){n=t;const l=new c.Vector3;new c.Box3().setFromObject(n).getSize(l);const h=Math.max(l.x,l.y,l.z);console.warn("[Custom Avatar] Normalizing head scale, it's too big: "+h+" meters! Should be < 0.3m"),h>.3&&n.scale.multiplyScalar(1/h*.3)}return new $g(t,n,o,r)}findAvatarPart(e,t){const i=e.name.toLowerCase();let n=!0;for(const o of t){if(!n)break;i.indexOf(o)===-1&&(n=!1)}if(n)return e;if(e.children)for(const o of e.children){const r=this.findAvatarPart(o,t);if(r)return r}return null}handleCustomAvatarErrors(e){if(!e.ok)throw Error(e.statusText);return e}}class Tw{get extensionName(){return"DocumentExtension"}onAfterBuildDocument(e){}}class Aw{}const ZR=Object.freeze(Object.defineProperty({__proto__:null,ActionBuilder:ae,ActionCollection:Uv,ActionModel:Vt,AlignmentConstraint:uc,Animation:wt,AnimationCurve:Tc,AnimationExtension:Jd,AnimationTrackHandler:xu,Animator:mt,AnimatorController:Li,Antialiasing:Lc,AudioExtension:ar,AudioListener:is,AudioSource:Ii,AudioTrackHandler:ss,Avatar:Xs,AvatarBlink_Simple:nr,AvatarEyeLook_Rotation:Om,AvatarLoader:Ew,AvatarMarker:xe,AvatarModel:$g,Avatar_Brain_LookAt:$l,Avatar_MouthShapes:gc,Avatar_MustacheShake:Pm,Avatar_POI:Fo,AxesHelper:ma,BaseUIComponent:Bi,BasicIKConstraint:Rm,BehaviorExtension:sg,BehaviorModel:pt,BloomEffect:fu,BoxCollider:Xd,BoxGizmo:dr,BoxHelperComponent:nt,Button:bs,CallInfo:ts,Camera:Wt,CameraTargetReachedEvent:Vl,Canvas:ca,CanvasGroup:Qs,CapsuleCollider:as,ChangeMaterialOnClick:Qm,ChangeTransformOnClick:lr,CharacterController:sr,CharacterControllerInput:ds,ChromaticAberration:Dc,Collider:Qt,ColorAdjustments:co,ColorBySpeedModule:Oa,ColorOverLifetimeModule:hu,ContactShadows:yc,ControlTrackHandler:Su,CustomBranding:hr,Deletable:Lm,DeleteBox:$s,DepthOfField:an,DeviceFlag:Qd,DocumentExtension:Tw,DragControls:Mo,DropListener:us,Duplicatable:jm,EffectWrapper:Xl,EmissionModule:ys,EmphasizeOnClick:ba,EnvironmentScene:ku,EventList:de,EventListEvent:$d,EventSystem:jt,EventTrigger:Kd,FieldWithDefault:Cv,FixedJoint:_g,Fog:Ca,GltfExport:Gm,GltfExportBox:$m,Gradient:fr,Graphic:Mc,GraphicRaycaster:Wd,GridHelper:Pa,GridLayoutGroup:hg,GroundProjectedEnv:Dn,GroupActionModel:Oo,HideOnStart:Ri,HingeJoint:kc,HorizontalLayoutGroup:cg,Image:Ea,InheritVelocityModule:xg,InputField:Ig,InstanceHandle:Uo,InstancingHandler:qo,Interactable:Am,Keyframe:Gt,LODGroup:Ec,LODModel:Ma,Light:yi,LimitVelocityOverLifetimeModule:et,LogStats:Tm,LookAt:jg,LookAtConstraint:ir,MainModule:Pt,MaskableGraphic:Oc,MeshCollider:io,MeshRenderer:bc,MinMaxCurve:H,MinMaxGradient:pr,NeedleMenu:jn,NestedGltf:au,Networking:vg,NoiseModule:fe,ObjectRaycaster:ui,OffsetConstraint:ur,OpenURL:Ta,OrbitControls:he,Outline:Sa,Padding:cr,ParticleBurst:wd,ParticleSubEmitter:Sg,ParticleSystem:ql,ParticleSystemRenderer:Vi,PhysicsExtension:og,PixelationEffect:Ic,PlayAnimationOnClick:Gl,PlayAudioOnClick:qs,PlayableDirector:da,PlayerColor:ha,PointerEventData:pc,PostProcessingHandler:Og,PreliminaryAction:va,PreliminaryTrigger:xc,RawImage:Mu,Rect:Wv,RectTransform:nn,ReflectionProbe:Wl,RegisteredAnimationInfo:zs,RemoteSkybox:mu,Renderer:fi,RendererLightmap:yd,Rigidbody:Ke,RotationBySpeedModule:Ni,RotationOverLifetimeModule:rn,SceneSwitcher:Ie,ScreenCapture:ho,ScreenSpaceAmbientOcclusion:_s,ScreenSpaceAmbientOcclusionN8:ln,SetActiveOnClick:Ym,ShadowCatcher:Uc,ShapeModule:wg,SharpeningEffect:Bc,SignalAsset:wu,SignalReceiver:Wc,SignalReceiverEvent:$c,SignalTrackHandler:Ql,Size:$v,SizeBySpeedModule:Zt,SizeOverLifetimeModule:mr,SkinnedMeshRenderer:Vm,SmoothFollow:yu,SpatialGrabRaycaster:Go,SpatialHtml:qc,SpatialTrigger:_u,SpatialTriggerReceiver:Tn,SpectatorCamera:bu,SphereCollider:ga,Sprite:ps,SpriteData:Yr,SpriteRenderer:Yt,SpriteSheet:la,SubEmitterSystem:xd,SyncedCamera:Rg,SyncedRoom:cn,SyncedTransform:Ln,TapGestureTrigger:Zm,TeleportTarget:su,TestRunner:Eg,TestSimulateUserData:Tg,Text:Ct,TextBuilder:ag,TextExtension:ru,TextureSheetAnimationModule:Mt,TiltShiftEffect:Un,ToneMappingEffect:Ys,TrailModule:Re,TransformData:Oe,TransformGizmo:br,TriggerBuilder:xt,TriggerModel:Ws,UIRaycastUtils:wm,UIRootComponent:Cc,USDZExporter:En,USDZText:Vr,USDZUIExtension:ug,UsageMarker:_c,VariantAction:Xm,VelocityOverLifetimeModule:Ae,VerticalLayoutGroup:lg,VideoPlayer:Ze,Vignette:_r,VisibilityAction:Sc,Voip:to,Volume:Ra,VolumeParameter:D,VolumeProfile:du,WebARCameraBackground:Qc,WebARSessionRoot:li,WebXR:ou,WebXRImageTracking:Yl,WebXRImageTrackingModel:ws,WebXRPlaneTracking:xs,WebXRTrackedImage:ua,XRControllerFollow:vs,XRControllerModel:ls,XRControllerMovement:pi,XRFlag:Ei,XRRig:Eu,XRState:It,__Ignore:Aw},Symbol.toStringTag,{value:"Module"})),Pd=w("debugmissingcamera");re.registerCallback(oe.MissingCamera,s=>{Pd&&console.warn("Creating missing camera");const e=s.context.scene,t=new c.PerspectiveCamera;t.name="Default Fallback Camera",e.add(t);const i=new Wt;if(i.sourceId=s.files?.[0]?.src??"unknown",i.fieldOfView=35,s.context.domElement.getAttribute("transparent")!=null)i.clearFlags=Bo.Uninitialized;else if(s.context.domElement.getAttribute("background-image")?.length||s.context.lightmaps.tryGetSkybox(i.sourceId))i.clearFlags=Bo.Skybox,s.context.domElement.getAttribute("background-blurriness")===null&&(s.context.scene.backgroundBlurriness=.2);else{if(i.clearFlags=Bo.SolidColor,!s.context.domElement.getAttribute("background-color")){let a="#efefef";typeof window!==void 0&&window.matchMedia("(prefers-color-scheme: dark)").matches&&(a="#1f1f1f"),e.background=new c.Color(a)}if(!e.environment){const a=new c.PMREMGenerator$1(s.context.renderer),l=new ku("neutral");e.environment=a.fromScene(l,.025).texture}}const o=Ao(t,i,!0);return t.position.x=0,t.position.y=1,t.position.z=2,s.context.domElement?.cameraControls!=!1&&Lw(s.context,o),o});re.registerCallback(oe.ContextCreated,s=>{if(!s.context.mainCamera){Pd&&console.log("Will not auto-fit because a default camera exists");return}if(s.context.domElement?.cameraControls==!0){if(rb(s.context.mainCamera)?.isCameraController==!0){Pd&&console.log("Will not auto-fit because a camera controller exists");return}Lw(s.context)}});function Lw(s,e){e=e??s.mainCameraComponent;const t=e?.gameObject;if(Pd&&console.log("Creating default camera controls",e?.name),t){const i=rc(t,he);i.sourceId=e?.sourceId??"unknown";const n=s.domElement.getAttribute("auto-rotate");if(i.autoRotate=n!=null&&n!="0"&&n?.toLowerCase()!="false",i.autoRotateSpeed=.5,i.autoFit=!0,i.autoRotate&&n){const o=parseFloat(n);isNaN(o)||(i.autoRotateSpeed=o)}}else console.warn("Missing camera object, can not add orbit controls")}re.registerCallback(oe.ContextCreated,s=>{const e=s.context.domElement.getAttribute("autoplay");if(e!==void 0&&(e===""||e==="true"||e==="1")&&s.files)for(const t of s.files)x.foreachComponent(t.file.scene,n=>{if(n.enabled!==!1){if(n instanceof wt&&n.playAutomatically||n instanceof mt||n instanceof da&&n.playOnAwake===!0)return!0;if(n instanceof wt)return n.playAutomatically=!0,!0;if(n instanceof da)return n.playOnAwake=!0,!0}},!0)!==!0&&oa.assignAnimationsFromFile(t.file,{createAnimationComponent:(n,o)=>ci(n,wt)})});class JR extends se.WorkerBase{constructor(){super(new Worker(new URL("/generateMeshBVH.worker-2qGLkQjg.js",typeof document>"u"?require("url").pathToFileURL(__filename).href:Au&&Au.tagName.toUpperCase()==="SCRIPT"&&Au.src||new URL("needle-engine.bundle-C5G_xBUc.umd.cjs",document.baseURI).href),{type:"module"})),this.name="GenerateMeshBVHWorker"}runTask(e,t,i={}){return new Promise((n,o)=>{if(t.getAttribute("position").isInterleavedBufferAttribute||t.index&&t.index.isInterleavedBufferAttribute)throw new Error("GenerateMeshBVHWorker: InterleavedBufferAttribute are not supported for the geometry attributes.");e.onerror=h=>{o(new Error(`[GenerateMeshBVHWorker] ${h.message||"Unknown error. Please check the server console. If you're using vite try adding 'three-mesh-bvh' to 'optimizeDeps.exclude' in your vite.config.js"}`))},e.onmessage=h=>{const{data:d}=h;if(d.error)o(new Error(d.error)),e.onmessage=null;else if(d.serialized){const{serialized:u,position:p}=d,m=se.MeshBVH.deserialize(u,t,{setIndex:!1}),y=Object.assign({setBoundingBox:!0},i);if(t.attributes.position.array=p,u.index)if(t.index)t.index.array=u.index;else{const b=new c.BufferAttribute(u.index,1,!1);t.setIndex(b)}y.setBoundingBox&&(t.boundingBox=m.getBoundingBox(new c.Box3)),i.onProgress&&i.onProgress(d.progress),n(m),e.onmessage=null}else i.onProgress&&i.onProgress(d.progress)};const r=t.index?t.index.array:null,a=t.attributes.position.array,l=[a];r&&l.push(r),e.postMessage({index:r,position:a,options:{...i,onProgress:null,includedProgressCallback:!!i.onProgress,groups:[...t.groups]}},l.map(h=>h.buffer).filter(h=>typeof SharedArrayBuffer>"u"||!(h instanceof SharedArrayBuffer)))})}}const eE=Object.freeze(Object.defineProperty({__proto__:null,GenerateMeshBVHWorker:JR},Symbol.toStringTag,{value:"Module"}));exports.$physicsKey=$1;exports.ActionBuilder=ae;exports.ActionCollection=Uv;exports.ActionModel=Vt;exports.Addressables=S0;exports.AlignmentConstraint=uc;exports.AmbientMode=Xr;exports.Animation=wt;exports.AnimationCurve=Tc;exports.AnimationExtension=Jd;exports.AnimationTrackHandler=xu;exports.AnimationUtils=oa;exports.Animator=mt;exports.AnimatorConditionMode=Is;exports.AnimatorController=Li;exports.AnimatorControllerParameterType=bm;exports.AnimatorStateInfo=al;exports.Antialiasing=Lc;exports.Application=tn;exports.AssetDatabase=zb;exports.AssetReference=Y;exports.AudioExtension=ar;exports.AudioListener=is;exports.AudioSource=Ii;exports.AudioTrackHandler=ss;exports.Avatar=Xs;exports.AvatarBlink_Simple=nr;exports.AvatarEyeLook_Rotation=Om;exports.AvatarLoader=Ew;exports.AvatarMarker=xe;exports.AvatarModel=$g;exports.Avatar_Brain_LookAt=$l;exports.Avatar_MouthShapes=gc;exports.Avatar_MustacheShake=Pm;exports.Avatar_POI=Fo;exports.Axes=zr;exports.AxesHelper=ma;exports.BUILD_TIME=qp;exports.BaseUIComponent=Bi;exports.BasicIKConstraint=Rm;exports.BehaviorExtension=sg;exports.BehaviorModel=pt;exports.BloomEffect=fu;exports.BoxCollider=Xd;exports.BoxGizmo=dr;exports.BoxHelperComponent=nt;exports.Button=bs;exports.ButtonsFactory=Ki;exports.CallDirection=sv;exports.CallInfo=ts;exports.Camera=Wt;exports.CameraTargetReachedEvent=Vl;exports.Canvas=ca;exports.CanvasGroup=Qs;exports.CapsuleCollider=as;exports.ChangeMaterialOnClick=Qm;exports.ChangeTransformOnClick=lr;exports.CharacterController=sr;exports.CharacterControllerInput=ds;exports.ChromaticAberration=Dc;exports.CircularBuffer=hi;exports.ClearFlags=Bo;exports.ClipExtrapolation=pn;exports.Collider=Qt;exports.Collision=tv;exports.CollisionDetectionMode=Vd;exports.ColorAdjustments=co;exports.ColorBySpeedModule=Oa;exports.ColorOverLifetimeModule=hu;exports.Component=ZC;exports.Component$1=k;exports.ComponentLifecycleEvents=Dd;exports.Components=ZR;exports.ConnectionEvents=Db;exports.ContactPoint=ev;exports.ContactShadows=yc;exports.Context=U;exports.ContextArgs=BC;exports.ContextEvent=oe;exports.ContextRegistry=re;exports.ControlTrackHandler=Su;exports.CustomBranding=hr;exports.CustomShader=_e;exports.DefaultReflectionMode=ad;exports.Deletable=Lm;exports.DeleteBox=$s;exports.DepthOfField=an;exports.DeviceFlag=Qd;exports.DocumentExtension=Tw;exports.DragControls=Mo;exports.DragMode=Dm;exports.DropListener=us;exports.Duplicatable=jm;exports.EffectWrapper=Xl;exports.EmissionModule=ys;exports.EmphasizeOnClick=ba;exports.EngineLoadingView=Kl;exports.EnvironmentScene=ku;exports.EventList=de;exports.EventListEvent=$d;exports.EventSystem=jt;exports.EventTrigger=Kd;exports.FieldWithDefault=Cv;exports.FileReference=Io;exports.FileReferenceSerializer=P0;exports.FileSpawnModel=uP;exports.File_Event=dv;exports.FixedJoint=_g;exports.Fog=Ca;exports.FrameEvent=pe;exports.GENERATOR=kd;exports.GameObject=x;exports.Gizmos=j;exports.GltfExport=Gm;exports.GltfExportBox=$m;exports.Gradient=fr;exports.Graphic=Mc;exports.GraphicRaycaster=Wd;exports.Graphics=Hs;exports.GridHelper=Pa;exports.GridLayoutGroup=hg;exports.GroundProjectedEnv=Dn;exports.GroupActionModel=Oo;exports.HideFlags=Gd;exports.HideOnStart=Ri;exports.HingeJoint=kc;exports.HorizontalLayoutGroup=cg;exports.HostData=NS;exports.Image=Ea;exports.ImageReference=Do;exports.ImageReferenceSerializer=C0;exports.InheritVelocityModule=xg;exports.Input=kb;exports.InputEventQueue=$t;exports.InputEvents=we;exports.InputField=Ig;exports.InstanceHandle=Uo;exports.InstancingHandler=qo;exports.InstancingUtil=Ai;exports.InstantiateEvent=Kb;exports.InstantiateIdProvider=ft;exports.InstantiateOptions=sn;exports.Interactable=Am;exports.JoinedRoomResponse=uS;exports.KeyEventArgs=tS;exports.Keyframe=Gt;exports.LODGroup=Ec;exports.LODModel=Ma;exports.LeftRoomResponse=fS;exports.Light=yi;exports.LightData=E0;exports.LimitVelocityOverLifetimeModule=et;exports.LoadingElementOptions=BR;exports.LogStats=Tm;exports.LogType=ai;exports.LookAt=jg;exports.LookAtConstraint=ir;exports.MainModule=Pt;exports.MarkerType=Ag;exports.MaskableGraphic=Oc;exports.Mathf=I;exports.MeshCollider=io;exports.MeshRenderer=bc;exports.MinMaxCurve=H;exports.MinMaxGradient=pr;exports.NEKeyboardEvent=nl;exports.NEPointerEvent=Yn;exports.NeedleButtonElement=Rw;exports.NeedleEngineWebComponent=Vg;exports.NeedleMenu=jn;exports.NeedlePatchesKey=Eh;exports.NeedleXRController=Kp;exports.NeedleXRSession=q;exports.NeedleXRSync=Bb;exports.NeedleXRUtils=Ub;exports.NestedGltf=au;exports.NetworkConnection=jb;exports.NetworkedStreamEvents=Sn;exports.NetworkedStreams=mc;exports.Networking=vg;exports.NewInstanceModel=Jb;exports.NoiseModule=fe;exports.ObjectRaycaster=ui;exports.ObjectUtils=Ko;exports.OffsetConstraint=ur;exports.OneEuroFilter=kh;exports.OneEuroFilterXYZ=Up;exports.OpenURL=Ta;exports.OrbitControls=he;exports.Outline=Sa;exports.OwnershipEvent=Ib;exports.OwnershipModel=tm;exports.PUBLIC_KEY=Br;exports.Padding=cr;exports.ParticleBurst=wd;exports.ParticleSubEmitter=Sg;exports.ParticleSystem=ql;exports.ParticleSystemBaseBehaviour=lo;exports.ParticleSystemRenderer=Vi;exports.ParticleSystemShapeType=vd;exports.PeerHandle=ns;exports.PeerNetworking=Lb;exports.Physics=na;exports.PhysicsExtension=og;exports.PhysicsMaterialCombine=it;exports.PixelationEffect=Ic;exports.PlayAnimationOnClick=Gl;exports.PlayAudioOnClick=qs;exports.PlayableDirector=da;exports.PlayerColor=ha;exports.PlayerState=Zi;exports.PlayerStateEvent=Vv;exports.PlayerSync=ig;exports.PlayerView=O0;exports.PlayerViewManager=k0;exports.PointerEventData=pc;exports.PointerType=Td;exports.PostProcessingEffect=Ne;exports.PostProcessingEffectOrder=Qe;exports.PostProcessingHandler=Og;exports.PreliminaryAction=va;exports.PreliminaryTrigger=xc;exports.PrimitiveType=No;exports.Progress=ie;exports.PromiseAllWithErrors=Bp;exports.PromiseErrorResult=zf;exports.RGBAColor=Z;exports.RapierPhysics=Kr;exports.RawImage=Mu;exports.RaycastOptions=eo;exports.Rect=Wv;exports.RectTransform=nn;exports.ReflectionProbe=Wl;exports.RegisteredAnimationInfo=zs;exports.RemoteSkybox=mu;exports.RenderTexture=xn;exports.RenderTextureSerializer=Y0;exports.Renderer=fi;exports.RendererData=R0;exports.RendererLightmap=yd;exports.Rigidbody=Ke;exports.RigidbodyConstraints=Le;exports.RoomEvents=Q;exports.RotationBySpeedModule=Ni;exports.RotationOverLifetimeModule=rn;exports.SceneLightSettings=pd;exports.SceneSwitcher=Ie;exports.ScreenCapture=ho;exports.ScreenSpaceAmbientOcclusion=_s;exports.ScreenSpaceAmbientOcclusionN8=ln;exports.SendQueue=Yi;exports.SerializationContext=dm;exports.SetActiveOnClick=Ym;exports.ShadowCatcher=Uc;exports.ShapeModule=wg;exports.ShapeOverlapResult=iv;exports.SharpeningEffect=Bc;exports.SignalAsset=wu;exports.SignalReceiver=Wc;exports.SignalReceiverEvent=$c;exports.SignalTrackHandler=Ql;exports.Size=$v;exports.SizeBySpeedModule=Zt;exports.SizeOverLifetimeModule=mr;exports.SkinnedMeshRenderer=Vm;exports.SmoothFollow=yu;exports.SpatialGrabRaycaster=Go;exports.SpatialHtml=qc;exports.SpatialTrigger=_u;exports.SpatialTriggerReceiver=Tn;exports.SpectatorCamera=bu;exports.SphereCollider=ga;exports.SphereIntersection=sm;exports.Sprite=ps;exports.SpriteData=Yr;exports.SpriteRenderer=Yt;exports.SpriteSheet=la;exports.StateMachineBehaviour=s1;exports.StreamEndedEvent=Sm;exports.StreamReceivedEvent=nv;exports.SubEmitterSystem=xd;exports.SyncedCamera=Rg;exports.SyncedRoom=cn;exports.SyncedTransform=Ln;exports.TapGestureTrigger=Zm;exports.TeleportTarget=su;exports.TestRunner=Eg;exports.TestSceneUtils=HR;exports.TestSimulateUserData=Tg;exports.Text=Ct;exports.TextBuilder=ag;exports.TextExtension=ru;exports.TextureSheetAnimationModule=Mt;exports.TiltShiftEffect=Un;exports.Time=T0;exports.ToneMappingEffect=Ys;exports.TrackHandler=Gc;exports.TrackType=ti;exports.TrailModule=Re;exports.TransformData=Oe;exports.TransformGizmo=br;exports.TriggerBuilder=xt;exports.TriggerModel=Ws;exports.TypeStore=P;exports.UIRaycastUtils=wm;exports.UIRootComponent=Cc;exports.USDDocument=Hm;exports.USDObject=ze;exports.USDWriter=Ev;exports.USDZExporter=En;exports.USDZExporter$1=Tv;exports.USDZText=Vr;exports.USDZUIExtension=ug;exports.UriSerializer=K0;exports.UsageMarker=_c;exports.UserJoinedOrLeftRoomModel=pS;exports.VERSION=Ji;exports.VariantAction=Xm;exports.VelocityOverLifetimeModule=Ae;exports.VerticalLayoutGroup=lg;exports.VideoPlayer=Ze;exports.ViewDevice=Ns;exports.Vignette=_r;exports.VisibilityAction=Sc;exports.Voip=to;exports.Volume=Ra;exports.VolumeParameter=D;exports.VolumeProfile=du;exports.WaitForFrames=gC;exports.WaitForPromise=M0;exports.WaitForSeconds=pm;exports.Watch=os;exports.WebARCameraBackground=Qc;exports.WebARSessionRoot=li;exports.WebXR=ou;exports.WebXRButtonFactory=Gs;exports.WebXRImageTracking=Yl;exports.WebXRImageTrackingModel=ws;exports.WebXRPlaneTracking=xs;exports.WebXRTrackedImage=ua;exports.XRControllerFollow=vs;exports.XRControllerModel=ls;exports.XRControllerMovement=pi;exports.XRFlag=Ei;exports.XRRig=Eu;exports.XRState=It;exports.XRStateFlag=bn;exports.__Ignore=Aw;exports.__internalNotifyObjectDestroyed=Gb;exports.activeInHierarchyFieldName=rs;exports.addAttributeChangeCallback=K_;exports.addComponent=ci;exports.addCustomExtensionPlugin=DP;exports.addNewComponent=Ao;exports.addPatch=Rd;exports.apply=jd;exports.applyHMRChanges=KC;exports.applyPrototypeExtensions=d0;exports.beginListenDestroy=Zb;exports.beginListenInstantiate=t0;exports.binaryIdentifierCasts=Zp;exports.build_scene_functions=jC;exports.builtinComponentKeyName=xo;exports.calculateProgress01=Ng;exports.clearMessages=mx;exports.colorSerializer=w1;exports.compareAssociation=o0;exports.componentSerializer=Uh;exports.copyTexture=fb;exports.createMotion=H0;exports.debugNet=Ut;exports.debugOwner=sl;exports.decompressGpuTexture=Iv;exports.deepClone=Jl;exports.delay=An;exports.delayForFrames=ec;exports.deserializeObject=od;exports.destroy=di;exports.destroyComponentInstance=p0;exports.determineMimeTypeFromExtension=uv;exports.disposeObjectResources=ge;exports.disposeStream=Cn;exports.editorGuidKeyName=xl;exports.enableSpatialConsole=Ro;exports.euler=S1;exports.eventListSerializer=O1;exports.exportAsGLTF=QR;exports.findByGuid=fm;exports.findObjectOfType=cc;exports.findObjectsOfType=g0;exports.findResourceUsers=om;exports.fitObjectIntoVolume=mb;exports.foreachComponent=$o;exports.foreachComponentEnumerator=Fd;exports.forward=Ex;exports.generateQRCode=J_;exports.generateSeed=e0;exports.getBoundingBox=Ht;exports.getCameraController=rb;exports.getComponent=Jo;exports.getComponentInChildren=lc;exports.getComponentInParent=Ul;exports.getComponents=ac;exports.getComponentsInChildren=fa;exports.getComponentsInParent=Id;exports.getFormattedDate=Mv;exports.getIconElement=ut;exports.getIconTexture=ap;exports.getLoader=en;exports.getOrAddComponent=rc;exports.getParam=w;exports.getParentHierarchyPath=Lx;exports.getPath=Xw;exports.getPeerOptions=lS;exports.getPeerjsInstance=Ab;exports.getResourceUserCount=AS;exports.getTempColor=cb;exports.getTempQuaternion=Xi;exports.getTempVector=V;exports.getUrlParams=Zl;exports.getVisibleInCustomShadowRendering=pb;exports.getWorldDirection=hb;exports.getWorldEuler=Vp;exports.getWorldPosition=X;exports.getWorldQuaternion=ue;exports.getWorldRotation=Od;exports.getWorldScale=Te;exports.hasCommercialLicense=Rn;exports.hasIndieLicense=dc;exports.hasPointerEventComponent=hd;exports.hasProLicense=kn;exports.hideDebugConsole=bb;exports.imageToCanvas=jv;exports.instantiate=Wo;exports.invokeLoadedImportPluginHooks=wv;exports.invokeXRSessionEnd=Ob;exports.invokeXRSessionStart=Mb;exports.isActiveInHierarchy=y0;exports.isActiveSelf=pa;exports.isAndroidDevice=ex;exports.isAnimationAction=ub;exports.isComponent=J0;exports.isDebugMode=Ww;exports.isDesktop=Yw;exports.isDestroyed=Vo;exports.isDevEnvironment=A;exports.isDisposed=ES;exports.isExporting=qR;exports.isGLTFModel=Z0;exports.isHostedOnGlitch=W_;exports.isHotReloadEnabled=up;exports.isHotReloading=QC;exports.isIPad=Zw;exports.isIconElement=D0;exports.isLocalNetwork=Bt;exports.isMacOS=ix;exports.isMobileDevice=Kw;exports.isMozillaXR=tx;exports.isQuest=ox;exports.isResourceTrackingEnabled=Vb;exports.isSafari=sx;exports.isUsingInstancing=Bd;exports.isiOS=nx;exports.isiPad=Jw;exports.loadAsset=TR;exports.loadSync=zg;exports.logHierarchy=Kh;exports.lookAtInverse=xx;exports.lookAtObject=tc;exports.lookAtScreenPoint=Sx;exports.makeId=Hw;exports.makeIdFromRandomWords=X_;exports.makeNameSafe=ji;exports.markAsInstancedRendered=_0;exports.microphonePermissionsGranted=rx;exports.nameof=$w;exports.nameofFactory=H_;exports.objectSerializer=Q0;exports.offXRSessionEnd=eS;exports.offXRSessionStart=Jx;exports.onAfterRender=qC;exports.onBeforeRender=HC;exports.onClear=WC;exports.onDestroy=GC;exports.onInitialized=U0;exports.onStart=ym;exports.onUpdate=z0;exports.onXRSessionEnd=Yp;exports.onXRSessionStart=Ed;exports.parseSync=Cw;exports.placeOnSurface=gb;exports.postprocessFBXMaterials=Gp;exports.prefix=m1;exports.pushState=q_;exports.randomNumber=qw;exports.registerBinaryType=Jp;exports.registerComponent=zd;exports.registerComponentExtension=Um;exports.registerCustomEffectType=$i;exports.registerExportExtensions=zm;exports.registerExtensions=gd;exports.registerHotReloadType=V0;exports.registerLoader=Xp;exports.registerPrefabProvider=n0;exports.registerPrototypeExtensions=u0;exports.registerType=HS;exports.relativePathPrefix=Y_;exports.removeAttributeChangeCallback=Z_;exports.removeComponent=um;exports.removeCustomImportExtensionType=IP;exports.removePatch=Kx;exports.resolveUrl=Ks;exports.sanitizeString=Q_;exports.saveImage=vw;exports.screenshot=pR;exports.screenshot2=Fg;exports.sendDestroyed=am;exports.serializable=f;exports.serializeObject=a0;exports.serializeable=er;exports.setActive=Pl;exports.setAllowBalloonMessages=nb;exports.setAllowOverlayMessages=dx;exports.setAutoFitEnabled=Qh;exports.setCameraController=$f;exports.setDestroyed=v0;exports.setDevEnvironment=Nx;exports.setDisposable=Ld;exports.setDontDestroy=Tr;exports.setOrAddParamsToUrl=Uf;exports.setParam=Gw;exports.setParamWithoutReload=Dl;exports.setPeerOptions=cS;exports.setResourceTrackingEnabled=RS;exports.setState=Ip;exports.setVisibleInCustomShadowRendering=Wp;exports.setWorldEuler=$p;exports.setWorldPosition=Ye;exports.setWorldPositionXYZ=zo;exports.setWorldQuaternion=Di;exports.setWorldQuaternionXYZW=Np;exports.setWorldRotation=db;exports.setWorldRotationXYZ=ic;exports.setWorldScale=Jr;exports.showBalloonError=nc;exports.showBalloonMessage=Se;exports.showBalloonWarning=ce;exports.showDebugConsole=Hp;exports.slerp=wx;exports.syncDestroy=sc;exports.syncField=tg;exports.syncInstantiate=lm;exports.textureToCanvas=Dx;exports.tryCastBinary=Eb;exports.tryDetermineMimetypeFromBinary=pv;exports.tryDetermineMimetypeFromURL=fv;exports.tryFindObject=Zr;exports.tryGetGuid=Tb;exports.unregisterHotReloadType=$0;exports.unwatchWrite=jp;exports.useForAutoFit=ab;exports.validate=gt;exports.watchWrite=Md;
@@ -1785,11 +1785,11 @@ po('if(!globalThis["NEEDLE_ENGINE_VERSION"]) globalThis["NEEDLE_ENGINE_VERSION"]
1785
1785
  po('if(!globalThis["NEEDLE_ENGINE_GENERATOR"]) globalThis["NEEDLE_ENGINE_GENERATOR"] = "unknown";');
1786
1786
  po('if(!globalThis["NEEDLE_PROJECT_BUILD_TIME"]) globalThis["NEEDLE_PROJECT_BUILD_TIME"] = "unknown";');
1787
1787
  po('if(!globalThis["NEEDLE_PUBLIC_KEY"]) globalThis["NEEDLE_PUBLIC_KEY"] = "unknown";');
1788
- po('globalThis["__NEEDLE_ENGINE_VERSION__"] = "4.8.2-alpha";');
1788
+ po('globalThis["__NEEDLE_ENGINE_VERSION__"] = "4.8.2";');
1789
1789
  po('globalThis["__NEEDLE_ENGINE_GENERATOR__"] = "undefined";');
1790
- po('globalThis["__NEEDLE_PROJECT_BUILD_TIME__"] = "Fri Aug 15 2025 11:22:58 GMT+0000 (Coordinated Universal Time)";');
1790
+ po('globalThis["__NEEDLE_PROJECT_BUILD_TIME__"] = "Mon Aug 18 2025 09:21:15 GMT+0000 (Coordinated Universal Time)";');
1791
1791
  po('globalThis["__NEEDLE_PUBLIC_KEY__"] = "' + NEEDLE_PUBLIC_KEY + '";');
1792
- const Ln = "4.8.2-alpha", wm = "undefined", Qb = "Fri Aug 15 2025 11:22:58 GMT+0000 (Coordinated Universal Time)";
1792
+ const Ln = "4.8.2", wm = "undefined", Qb = "Mon Aug 18 2025 09:21:15 GMT+0000 (Coordinated Universal Time)";
1793
1793
  Xb && console.log(`Engine version: ${Ln} (generator: ${wm})
1794
1794
  Project built at ${Qb}`);
1795
1795
  const vl = NEEDLE_PUBLIC_KEY, ro = "needle_isActiveInHierarchy", jr = "builtin_components", Oh = "needle_editor_guid";
@@ -10983,9 +10983,13 @@ Start a coroutine from a component by calling "this.startCoroutine(myCoroutine()
10983
10983
  get isVisibleToUser() {
10984
10984
  if (this.isInXR) return !0;
10985
10985
  if (!this._isVisible) return !1;
10986
+ if (this.time.frame === this._lastStyleComputedFrame) return this._lastStyleComputedResult;
10987
+ this._lastStyleComputedFrame = this.time.frame;
10986
10988
  const e = getComputedStyle(this.domElement);
10987
- return e.visibility !== "hidden" && e.display !== "none" && e.opacity !== "0";
10989
+ return this._lastStyleComputedResult = e.visibility !== "hidden" && e.display !== "none" && e.opacity !== "0", this._lastStyleComputedResult;
10988
10990
  }
10991
+ _lastStyleComputedFrame = -1;
10992
+ _lastStyleComputedResult = !0;
10989
10993
  _createId = 0;
10990
10994
  async internalOnCreate(e) {
10991
10995
  const t = ++this._createId;
@@ -11286,12 +11290,14 @@ Target Framerate: ` + this.targetFrameRate)), this._dispatchReadyAfterFrame && (
11286
11290
  renderNow(e) {
11287
11291
  if (!e && (e = this.mainCamera, !e))
11288
11292
  return !1;
11289
- if (this.handleRendererContextLost(), this._isRendering = !0, this.renderRequiredTextures(), this.renderer.toneMapping !== Vh && L0(), this.composer && !this.isInXR) {
11290
- e && "setMainCamera" in this.composer && this.composer.passes[0]?.mainCamera != e && this.composer.setMainCamera(e);
11291
- const t = this.renderer.getClearColor(this._tempClearColor), i = this.renderer.getClearAlpha();
11292
- this._tempClearColor2.copy(t), this.renderer.setClearColor(t.convertSRGBToLinear(), this.renderer.getClearAlpha()), this.composer.render(this.time.deltaTime), this.renderer.setClearColor(this._tempClearColor2, i);
11293
- } else e && (this.isInXR && q.isMacOS() && this.renderer.clearDepth(), this.renderer.render(this.scene, e));
11294
- return this._isRendering = !1, !0;
11293
+ if (this.handleRendererContextLost(), this.time.frame % 10 === 0) {
11294
+ if (this._isRendering = !0, this.renderRequiredTextures(), this.renderer.toneMapping !== Vh && L0(), this.composer && !this.isInXR) {
11295
+ e && "setMainCamera" in this.composer && this.composer.passes[0]?.mainCamera != e && this.composer.setMainCamera(e);
11296
+ const t = this.renderer.getClearColor(this._tempClearColor), i = this.renderer.getClearAlpha();
11297
+ this._tempClearColor2.copy(t), this.renderer.setClearColor(t.convertSRGBToLinear(), this.renderer.getClearAlpha()), this.composer.render(this.time.deltaTime), this.renderer.setClearColor(this._tempClearColor2, i);
11298
+ } else e && (this.isInXR && q.isMacOS() && this.renderer.clearDepth(), this.renderer.render(this.scene, e));
11299
+ return this._isRendering = !1, !0;
11300
+ }
11295
11301
  }
11296
11302
  _contextRestoreTries = 0;
11297
11303
  handleRendererContextLost() {
@@ -142,7 +142,7 @@ Open this page to get the console: `+e.toString())}const o=G.isMobileDevice()||G
142
142
  #__vconsole .vc-mask {
143
143
  overflow: hidden;
144
144
  }
145
- `,pn?.prepend(i),o===!0&&um()<=0&&Ab(),console.log("\u{1F335} Debug console has loaded")}},e.onerror=()=>{console.warn("\u{1F335} Debug console failed to load."+(window.crossOriginIsolated?"This page is using cross-origin isolation, so external scripts can't be loaded.":"")),zl=!1,vi=null},e.src="https://cdn.jsdelivr.net/npm/vconsole@3.9.1/dist/vconsole.min.js",document.body.appendChild(e)}function GP(){if(!globalThis.VConsole)return;const o=new VConsole.VConsolePlugin("needle-console","\u{1F335} Inspect glTF"),e=()=>document.querySelector("#__vc_plug_"+o._id+" iframe");return o.on("renderTab",function(t){const i=globalThis["needle:codegen_files"];if(!i||i.length===0)return;let n=globalThis["needle:codegen_files"][0];const s=n.indexOf("?");s>-1&&(n=n.substring(0,s));const r=location.protocol+"//"+location.host+location.pathname+"/"+n,a=encodeURIComponent(r);o.fullUrl="https://viewer.needle.tools?inspect&file="+a;var l='<iframe src="" style="width: 100%; height: 99%; border: none;"></iframe>';t(l)}),o.on("show",function(){const t=e();t&&t.src!==o.fullUrl&&(t.src=o.fullUrl)}),o.on("hide",function(){const t=e();t&&(t.src="")}),o.on("addTopBar",function(t){var i=new Array;i.push({name:"Open in new window \u2197",onClick:function(n){window.open(o.fullUrl,"_blank"),vi?.hide()}}),i.push({name:"Reload",onClick:function(n){const s=e();s&&(s.src=o.fullUrl)}}),i.push({name:"Fullscreen",onClick:function(n){const s=e();s.requestFullscreen?s.requestFullscreen():s.webkitRequestFullscreen instanceof Function&&s.webkitRequestFullscreen()}}),t(i)}),o}function qP(){return document.querySelector("#__vconsole .vc-switch")||null}function XP(){return document.querySelector("#__vconsole")||null}const Db=w("debugdefines");cs('if(!globalThis["NEEDLE_ENGINE_VERSION"]) globalThis["NEEDLE_ENGINE_VERSION"] = "0.0.0";'),cs('if(!globalThis["NEEDLE_ENGINE_GENERATOR"]) globalThis["NEEDLE_ENGINE_GENERATOR"] = "unknown";'),cs('if(!globalThis["NEEDLE_PROJECT_BUILD_TIME"]) globalThis["NEEDLE_PROJECT_BUILD_TIME"] = "unknown";'),cs('if(!globalThis["NEEDLE_PUBLIC_KEY"]) globalThis["NEEDLE_PUBLIC_KEY"] = "unknown";'),cs('globalThis["__NEEDLE_ENGINE_VERSION__"] = "4.8.2-alpha";'),cs('globalThis["__NEEDLE_ENGINE_GENERATOR__"] = "undefined";'),cs('globalThis["__NEEDLE_PROJECT_BUILD_TIME__"] = "Fri Aug 15 2025 11:22:58 GMT+0000 (Coordinated Universal Time)";'),cs('globalThis["__NEEDLE_PUBLIC_KEY__"] = "'+NEEDLE_PUBLIC_KEY+'";');const mn="4.8.2-alpha",md="undefined",Em="Fri Aug 15 2025 11:22:58 GMT+0000 (Coordinated Universal Time)";Db&&console.log(`Engine version: ${mn} (generator: ${md})
145
+ `,pn?.prepend(i),o===!0&&um()<=0&&Ab(),console.log("\u{1F335} Debug console has loaded")}},e.onerror=()=>{console.warn("\u{1F335} Debug console failed to load."+(window.crossOriginIsolated?"This page is using cross-origin isolation, so external scripts can't be loaded.":"")),zl=!1,vi=null},e.src="https://cdn.jsdelivr.net/npm/vconsole@3.9.1/dist/vconsole.min.js",document.body.appendChild(e)}function GP(){if(!globalThis.VConsole)return;const o=new VConsole.VConsolePlugin("needle-console","\u{1F335} Inspect glTF"),e=()=>document.querySelector("#__vc_plug_"+o._id+" iframe");return o.on("renderTab",function(t){const i=globalThis["needle:codegen_files"];if(!i||i.length===0)return;let n=globalThis["needle:codegen_files"][0];const s=n.indexOf("?");s>-1&&(n=n.substring(0,s));const r=location.protocol+"//"+location.host+location.pathname+"/"+n,a=encodeURIComponent(r);o.fullUrl="https://viewer.needle.tools?inspect&file="+a;var l='<iframe src="" style="width: 100%; height: 99%; border: none;"></iframe>';t(l)}),o.on("show",function(){const t=e();t&&t.src!==o.fullUrl&&(t.src=o.fullUrl)}),o.on("hide",function(){const t=e();t&&(t.src="")}),o.on("addTopBar",function(t){var i=new Array;i.push({name:"Open in new window \u2197",onClick:function(n){window.open(o.fullUrl,"_blank"),vi?.hide()}}),i.push({name:"Reload",onClick:function(n){const s=e();s&&(s.src=o.fullUrl)}}),i.push({name:"Fullscreen",onClick:function(n){const s=e();s.requestFullscreen?s.requestFullscreen():s.webkitRequestFullscreen instanceof Function&&s.webkitRequestFullscreen()}}),t(i)}),o}function qP(){return document.querySelector("#__vconsole .vc-switch")||null}function XP(){return document.querySelector("#__vconsole")||null}const Db=w("debugdefines");cs('if(!globalThis["NEEDLE_ENGINE_VERSION"]) globalThis["NEEDLE_ENGINE_VERSION"] = "0.0.0";'),cs('if(!globalThis["NEEDLE_ENGINE_GENERATOR"]) globalThis["NEEDLE_ENGINE_GENERATOR"] = "unknown";'),cs('if(!globalThis["NEEDLE_PROJECT_BUILD_TIME"]) globalThis["NEEDLE_PROJECT_BUILD_TIME"] = "unknown";'),cs('if(!globalThis["NEEDLE_PUBLIC_KEY"]) globalThis["NEEDLE_PUBLIC_KEY"] = "unknown";'),cs('globalThis["__NEEDLE_ENGINE_VERSION__"] = "4.8.2";'),cs('globalThis["__NEEDLE_ENGINE_GENERATOR__"] = "undefined";'),cs('globalThis["__NEEDLE_PROJECT_BUILD_TIME__"] = "Mon Aug 18 2025 09:21:15 GMT+0000 (Coordinated Universal Time)";'),cs('globalThis["__NEEDLE_PUBLIC_KEY__"] = "'+NEEDLE_PUBLIC_KEY+'";');const mn="4.8.2",md="undefined",Em="Mon Aug 18 2025 09:21:15 GMT+0000 (Coordinated Universal Time)";Db&&console.log(`Engine version: ${mn} (generator: ${md})
146
146
  Project built at ${Em}`);const ga=NEEDLE_PUBLIC_KEY,bo="needle_isActiveInHierarchy",rr="builtin_components",Wl="needle_editor_guid";function cs(o){try{(0,eval)(o)}catch(e){Db&&console.error(e)}}let Bb,Fb=null;function gn(){return Bb}function Am(o){if(o==null){console.warn("Oh no: someone tried registering a non-existend gltf-loader. When you see this log it might mean that needle-engine is being imported multiple times. Please check your project setup.");return}Fb!==o&&(Fb=o,Bb=new o)}const wi=Symbol("shadowDomOwner"),QP=w("debugpatch");function gd(o,e,t,i){const n=QP===e;if(!t&&!i)return;const s=e+"___needle";KP(o,e,t,i);const r=Object.getOwnPropertyDescriptor(o,e),a=o[e];n&&console.log("Patch",o.constructor.name,e,r,a),r?(n&&console.log("Apply patch with existing descriptor",o.constructor.name,e,r),typeof r.value=="function"&&(o[e]=zb(r.value,o,e))):(n&&console.log("Create patch with new property",o.constructor.name,e,r),Object.defineProperty(o,e,{set:function(l){if(typeof l=="function")this[s]=zb(l,o,e);else{const c=this[s];Nb(o,e,this,c,l),this[s]=l,Wb(o,e,this,c,l)}},get:function(){const l=this[s];return typeof l=="function"&&l[s]?l[s]:l}}))}function YP(o,e,t){const i=Lm(o,e);if(i)for(let n=i.length-1;n>=0;n--){const s=i[n];s.prefix===t&&(s.prefix=null),s.postfix===t&&(s.postfix=null),!s.prefix&&!s.postfix&&i.splice(n,1)}}const Ub=Symbol("Needle:Patches:WrappedFunction");function zb(o,e,t){if(o[Ub])return o;const i=function(...n){Nb(e,t,this,...n);const s=o.apply(this,n);return Wb(e,t,this,s,...n),s};return i[Ub]=!0,i}const fd="Needle:Patches";function Im(){return globalThis[fd]||(globalThis[fd]=new WeakMap),globalThis[fd]}function Lm(o,e){const t=Im().get(o);return t?t.get(e):null}function KP(o,e,t,i){let n=Im().get(o);n||(n=new Map,Im().set(o,n));let s=n.get(e);s||(s=[],n.set(e,s)),s.push({prefix:t,postfix:i})}function Nb(o,e,t,...i){if(!t)return;const n=Lm(o,e);if(n)for(const s of n)s.prefix?.call(t,...i)}function Wb(o,e,t,i,...n){if(!t)return;const s=Lm(o,e);if(s)for(const r of s)r.postfix?.call(t,i,...n)}const fa=[];function yd(o){fa.indexOf(o)===-1&&fa.push(o)}function ZP(o){const e=fa.indexOf(o);e!==-1&&fa.splice(e,1)}const ya=[];function jm(o){ya.indexOf(o)===-1&&ya.push(o)}function JP(o){const e=ya.indexOf(o);e!==-1&&ya.splice(e,1)}function Vb(o){globalThis.dispatchEvent(new CustomEvent("needle-xrsession-start",{detail:o}));for(let e=0;e<fa.length;e++)fa[e](o)}function $b(o){globalThis.dispatchEvent(new CustomEvent("needle-xrsession-end",{detail:o}));for(let e=0;e<ya.length;e++)ya[e](o)}const it=w("debuginput");var bd=(o=>(o.Mouse="mouse",o.Touch="touch",o.Controller="controller",o.Hand="hand",o))(bd||{}),Ee=(o=>(o.PointerDown="pointerdown",o.PointerUp="pointerup",o.PointerMove="pointermove",o.KeyDown="keydown",o.KeyUp="keyup",o.KeyPressed="keypress",o))(Ee||{});class _o extends PointerEvent{clientZ;deviceIndex;origin;source;mode;get isSpatial(){return this.mode!="screen"}get ray(){return this._ray||(this._ray=new ns(this.space.worldPosition.clone(),this.space.worldForward.clone())),this._ray}set ray(e){this._ray=e}get hasRay(){return this._ray!==void 0}_ray;space;isClick=!1;isDoubleClick=!1;get used(){return this._used}_used=!1;use(){this._used=!0}get pointerId(){return this._pointerid}_pointerid;get pointerType(){return this._pointerType}_pointerType;get type(){return this._type}_type;metadata={};intersections=new Array;constructor(e,t,i){super(e,i),this.clientZ=i.clientZ,this._pointerid=i.pointerId,this._pointerType=i.pointerType,this._type=e,this.deviceIndex=i.deviceIndex,this.origin=i.origin,this.source=t,this.mode=i.mode,this._ray=i.ray,this.space=i.device}_immediatePropagationStopped=!1;get immediatePropagationStopped(){return this._immediatePropagationStopped}_propagationStopped=!1;get propagationStopped(){return this._immediatePropagationStopped||this._propagationStopped}stopImmediatePropagation(){this._immediatePropagationStopped=!0,super.stopImmediatePropagation(),this.source?.stopImmediatePropagation()}stopPropagation(){this._propagationStopped=!0,super.stopPropagation(),this.source?.stopPropagation(),it&&console.warn("Stop propagation...",this.pointerId,this.pointerType)}}class Vl extends KeyboardEvent{source;constructor(e,t,i){super(e,i),this.source=t}stopImmediatePropagation(){super.stopImmediatePropagation(),this.source?.stopImmediatePropagation()}}class eO{key;keyType;source;constructor(e){this.key=e.key,this.keyType=e.type,this.source=e}}var ti=(o=>(o[o.Early=-100]="Early",o[o.Default=0]="Default",o[o.Late=100]="Late",o))(ti||{});class Hb{_eventListeners={};addEventListener(e,t,i){if(this._eventListeners[e]||(this._eventListeners[e]=[]),!t||typeof t!="function"){console.error("Invalid call to addEventListener: callback is required and must be a function!");return}i?i={...i}:i={};let n=0;i?.queue!=null&&(n=i.queue);const s=this._eventListeners[e],r=s.find(a=>a.priority===n);r?r.listeners.push({callback:t,options:i}):(s.push({priority:n,listeners:[{callback:t,options:i}]}),s.sort((a,l)=>a.priority-l.priority))}removeEventListener(e,t,i){if(!this._eventListeners[e]||!t)return;const n=this._eventListeners[e];if(i?.queue!=null){const s=n.find(a=>a.priority===i.queue);if(!s)return;const r=s.listeners.findIndex(a=>a.callback===t);r>=0&&s.listeners.splice(r,1)}else for(const s of n){const r=s.listeners.findIndex(a=>a.callback===t);r>=0&&s.listeners.splice(r,1)}}dispatchEvent(e){let t=!1;if(e instanceof Vl){const i=this._eventListeners[e.type];if(i)for(const n of i)for(let s=0;s<n.listeners.length;s++){const r=n.listeners[s];if(r.options?.signal?.aborted){n.listeners.splice(s,1),s--;continue}r.options.once&&(n.listeners.splice(s,1),s--),r.callback(e)}}if(e instanceof _o){const i=this._eventListeners[e.type];if(i)for(const n of i){if(t)break;for(let s=0;s<n.listeners.length;s++){const r=n.listeners[s];if(r.options?.signal?.aborted){n.listeners.splice(s,1),s--;continue}if(e.immediatePropagationStopped){t=!0,it&&console.log("immediatePropagationStopped",e.type);break}else e.propagationStopped&&(t=!0,it&&console.log("propagationStopped",e.type));r.options.once&&(n.listeners.splice(s,1),s--),r.callback(e)}}}}_doubleClickTimeThreshold=.2;_longPressTimeThreshold=1;get mousePosition(){return this._pointerPositions[0]}get mousePositionRC(){return this._pointerPositionsRC[0]}get mouseDown(){return this._pointerDown[0]}get mouseUp(){return this._pointerUp[0]}get mouseClick(){return this._pointerClick[0]}get mouseDoubleClick(){return this._pointerDoubleClick[0]}get mousePressed(){return this._pointerPressed[0]}get mouseWheelChanged(){return this.getMouseWheelChanged(0)}get click(){return this._pointerClick[0]}get doubleClick(){return this._pointerDoubleClick[0]}getGamepad(e=0){return typeof navigator<"u"&&"getGamepads"in navigator&&navigator.getGamepads()[e]||null}_setCursorTypes=[];setCursorPointer(){this.setCursor("pointer")}setCursorNormal(){this.unsetCursor("pointer")}setCursor(e){this._setCursorTypes.push(e),this._setCursorTypes.length>10&&this._setCursorTypes.shift(),this.updateCursor()}unsetCursor(e){for(let t=this._setCursorTypes.length-1;t>=0;t--)if(this._setCursorTypes[t]===e){this._setCursorTypes.splice(t,1),this.updateCursor();break}}updateCursor(){this._setCursorTypes?.length==0?this.context.domElement.style.cursor="default":this.context.domElement.style.cursor=this._setCursorTypes[this._setCursorTypes.length-1]}getIsPointerIdInUse(e){for(const t of this._pointerEventsPressed)if(t.pointerId===e&&t.used)return!0;return!1}getPointerPressedCount(){let e=0;for(let t=0;t<this._pointerPressed.length;t++)this._pointerPressed[t]&&e++;return e}getPointerPosition(e){return e>=this._pointerPositions.length?null:this._pointerPositions[e]}getPointerPositionLastFrame(e){return e>=this._pointerPositionsLastFrame.length?null:this._pointerPositionsLastFrame[e]}getPointerPositionDelta(e){return e>=this._pointerPositionsDelta.length?null:this._pointerPositionsDelta[e]}getPointerPositionRC(e){return e>=this._pointerPositionsRC.length?null:this._pointerPositionsRC[e]}getPointerDown(e){return e>=this._pointerDown.length?!1:this._pointerDown[e]}getPointerUp(e){return e>=this._pointerUp.length?!1:this._pointerUp[e]}getPointerPressed(e){return e>=this._pointerPressed.length?!1:this._pointerPressed[e]}getPointerClicked(e){return e>=this._pointerClick.length?!1:this._pointerClick[e]}getPointerDoubleClicked(e){return e>=this._pointerDoubleClick.length?!1:this._pointerDoubleClick[e]}getPointerDownTime(e){return e>=this._pointerDownTime.length?-1:this._pointerDownTime[e]}getPointerUpTime(e){return e>=this._pointerUpTime.length?-1:this._pointerUpTime[e]}getPointerLongPress(e){return e>=this._pointerDownTime.length?!1:this.getPointerPressed(e)&&this.context.time.time-this._pointerDownTime[e]>this._longPressTimeThreshold}getIsMouse(e){return e<0||e>=this._pointerTypes.length?!1:this._pointerTypes[e]==="mouse"}getIsTouch(e){return e<0||e>=this._pointerTypes.length?!1:this._pointerTypes[e]==="touch"}getTouchesPressedCount(){let e=0;for(let t=0;t<this._pointerPressed.length;t++)this._pointerPressed[t]&&this.getIsTouch(t)&&e++;return e}getMouseWheelChanged(e=0){return e>=this._mouseWheelChanged.length?!1:this._mouseWheelChanged[e]}getMouseWheelDeltaY(e=0){return e>=this._mouseWheelDeltaY.length?0:this._mouseWheelDeltaY[e]}getPointerEvent(e){if(!(e>=this._pointerEvent.length))return this._pointerEvent[e]??void 0}*foreachPointerId(e){for(let t=0;t<this._pointerTypes.length;t++)if(this._pointerIsActive(t)){if(e!==void 0){const i=this._pointerTypes[t];if(Array.isArray(e)){let n=!1;for(const s of e)if(i===s){n=!0;break}if(!n)continue}else if(e!==i)continue}yield t}}*foreachTouchId(){for(let e=0;e<this._pointerTypes.length;e++)this._pointerTypes[e]==="touch"&&this._pointerIsActive[e]&&(yield e)}_pointerIsActive(e){return e<0?!1:this._pointerPressed[e]||this._pointerDown[e]||this._pointerUp[e]}context;_pointerDown=[!1];_pointerUp=[!1];_pointerClick=[!1];_pointerDoubleClick=[!1];_pointerPressed=[!1];_pointerPositions=[new J];_pointerPositionsLastFrame=[new J];_pointerPositionsDelta=[new J];_pointerPositionsRC=[new J];_pointerPositionDown=[new b];_pointerDownTime=[];_pointerUpTime=[];_pointerUpTimestamp=[];_pointerIds=[];_pointerTypes=[""];_mouseWheelChanged=[!1];_mouseWheelDeltaY=[0];_pointerEvent=[];_pointerEventsPressed=[];_pointerSpace=[];_pressedStack=new Map;onDownButton(e,t){let i=this._pressedStack.get(e);i||(i=[],this._pressedStack.set(e,i)),i.push(t)}onReleaseButton(e,t){const i=this._pressedStack.get(e);if(!i)return;const n=i.indexOf(t);n>=0&&i.splice(n,1)}getFirstPressedButtonForPointer(e){const t=this._pressedStack.get(e);if(t)return t[0]}getLatestPressedButtonForPointer(e){const t=this._pressedStack.get(e);if(t)return t[t.length-1]}getKeyDown(e){if(e!==void 0)return this.isKeyDown(e);for(const t in this.keysPressed){const i=this.keysPressed[t];if(i.startFrame===this.context.time.frameCount)return i.key}return null}getKeyPressed(e){if(e!==void 0)return this.isKeyPressed(e);for(const t in this.keysPressed){const i=this.keysPressed[t];if(i.pressed)return i.key}return null}getKeyUp(e){if(e!==void 0)return this.isKeyUp(e);for(const t in this.keysPressed){const i=this.keysPressed[t];return i.pressed===!1&&i.frame===this.context.time.frameCount}return null}isKeyDown(e){if(!this.context.application.isVisible||!this.context.application.hasFocus)return!1;const t=this.getCodeForCommonKeyName(e);if(t!==null){for(const n of t)if(this.isKeyDown(n))return!0;return!1}const i=this.keysPressed[e];return i?i.startFrame===this.context.time.frameCount&&i.pressed:!1}isKeyUp(e){if(!this.context.application.isVisible||!this.context.application.hasFocus)return!1;const t=this.getCodeForCommonKeyName(e);if(t!==null){for(const n of t)if(this.isKeyUp(n))return!0;return!1}const i=this.keysPressed[e];return i?i.frame===this.context.time.frameCount&&i.pressed===!1:!1}isKeyPressed(e){if(!this.context.application.isVisible||!this.context.application.hasFocus)return!1;const t=this.getCodeForCommonKeyName(e);if(t!==null){for(const n of t)if(this.isKeyPressed(n))return!0;return!1}const i=this.keysPressed[e];return i&&i.pressed||!1}getCodeForCommonKeyName(e){if(e.length===1){if(e>="0"&&e<="9")return["Digit"+e];if(e>="a"&&e<="z")return["Key"+e.toUpperCase()];if(e==" ")return["Space"]}switch(e){case"shift":case"Shift":return["ShiftLeft","ShiftRight"];case"control":case"Control":return["ControlLeft","ControlRight"];case"alt":case"Alt":return["AltLeft","AltRight"]}return null}createInputEvent(e){switch(e.type){case"pointerdown":it&&Te("Create Pointer down"),this.onDownButton(e.deviceIndex,e.button),this.onDown(e);break;case"pointermove":it&&Te("Create Pointer move"),this.onMove(e);break;case"pointerup":it&&Te("Create Pointer up"),this.onUp(e),this.onReleaseButton(e.deviceIndex,e.button);break}}convertScreenspaceToRaycastSpace(e){return e.x=(e.x-this.context.domX)/this.context.domWidth*2-1,e.y=-((e.y-this.context.domY)/this.context.domHeight)*2+1,e}constructor(e){this.context=e,this.context.post_render_callbacks.push(this.onEndOfFrame)}_htmlEventSource;bindEvents(){this.unbindEvents(),this._htmlEventSource=this.context.renderer.domElement,window.addEventListener("contextmenu",this.onContextMenu),this._htmlEventSource.addEventListener("pointerdown",this.onPointerDown,{passive:!0}),window.addEventListener("pointermove",this.onPointerMove,{passive:!0,capture:!0}),window.addEventListener("pointerup",this.onPointerUp,{passive:!0}),window.addEventListener("pointercancel",this.onPointerCancel,{passive:!0}),window.addEventListener("touchstart",this.onTouchStart,{passive:!0}),window.addEventListener("touchmove",this.onTouchMove,{passive:!0}),window.addEventListener("touchend",this.onTouchEnd,{passive:!0}),this._htmlEventSource.addEventListener("wheel",this.onMouseWheel,{passive:!0}),window.addEventListener("wheel",this.onWheelWindow,{passive:!0}),window.addEventListener("keydown",this.onKeyDown,!1),window.addEventListener("keypress",this.onKeyPressed,!1),window.addEventListener("keyup",this.onKeyUp,!1),window.addEventListener("blur",this.onLostFocus)}unbindEvents(){for(const e in this._eventListeners)this._eventListeners[e].length=0;window.removeEventListener("contextmenu",this.onContextMenu),this._htmlEventSource?.removeEventListener("pointerdown",this.onPointerDown),window.removeEventListener("pointermove",this.onPointerMove),window.removeEventListener("pointerup",this.onPointerUp),window.removeEventListener("pointercancel",this.onPointerCancel),window.removeEventListener("touchstart",this.onTouchStart),window.removeEventListener("touchmove",this.onTouchMove),window.removeEventListener("touchend",this.onTouchEnd),this._htmlEventSource?.removeEventListener("wheel",this.onMouseWheel,!1),window.removeEventListener("wheel",this.onWheelWindow,!1),window.removeEventListener("keydown",this.onKeyDown,!1),window.removeEventListener("keypress",this.onKeyPressed,!1),window.removeEventListener("keyup",this.onKeyUp,!1),window.removeEventListener("blur",this.onLostFocus)}dispose(){const e=this.context.post_render_callbacks.indexOf(this.onEndOfFrame);e>=0&&this.context.post_render_callbacks.splice(e,1),this.unbindEvents()}onLostFocus=()=>{for(const e in this.keysPressed)this.keysPressed[e].pressed=!1};_receivedPointerMoveEventsThisFrame=new Array;onEndOfFrame=()=>{this._receivedPointerMoveEventsThisFrame.length=0;for(let e=0;e<this._pointerUp.length;e++)this._pointerUp[e]=!1;for(let e=0;e<this._pointerDown.length;e++)this._pointerDown[e]=!1;for(let e=0;e<this._pointerClick.length;e++)this._pointerClick[e]=!1;for(let e=0;e<this._pointerDoubleClick.length;e++)this._pointerDoubleClick[e]=!1;for(const e of this._pointerPositionsDelta)e.set(0,0);for(let e=0;e<this._mouseWheelChanged.length;e++)this._mouseWheelChanged[e]=!1;for(let e=0;e<this._mouseWheelDeltaY.length;e++)this._mouseWheelDeltaY[e]=0};canReceiveInput(e){return e.target===this.context.renderer?.domElement||e.target===this.context.domElement||this.context.isInAR||this.context.isInAR&&e.target===document.body&&G.isMozillaXR()?!0:(it&&console.warn("CanReceiveInput:False for",e.target),!1)}onContextMenu=e=>{this.canReceiveInput(e)!==!1&&e instanceof PointerEvent&&e.pointerType};keysPressed={};onKeyDown=e=>{if(it&&console.log(`key down ${e.code}, ${this.context.application.hasFocus}`,e),!this.context.application.hasFocus)return;const t=this.keysPressed[e.code];if(t&&t.pressed)return;this.keysPressed[e.code]={pressed:!0,frame:this.context.time.frameCount+1,startFrame:this.context.time.frameCount+1,key:e.key,code:e.code};const i=new Vl("keydown",e,e);this.onDispatchEvent(i)};onKeyPressed=e=>{if(!this.context.application.hasFocus)return;const t=this.keysPressed[e.code];if(!t)return;t.pressed=!0,t.frame=this.context.time.frameCount+1;const i=new Vl("keypress",e,e);this.onDispatchEvent(i)};onKeyUp=e=>{if(!this.context.application.hasFocus)return;const t=this.keysPressed[e.code];if(!t)return;t.pressed=!1,t.frame=this.context.time.frameCount+1;const i=new Vl("keyup",e,e);this.onDispatchEvent(i)};onWheelWindow=e=>{document.pointerLockElement&&this.onMouseWheel(e)};onMouseWheel=e=>{if(this.canReceiveInput(e)===!1)return;this._mouseWheelDeltaY.length<=0&&this._mouseWheelDeltaY.push(0),this._mouseWheelChanged.length<=0&&this._mouseWheelChanged.push(!1),this._mouseWheelChanged[0]=!0;const t=this._mouseWheelDeltaY[0];this._mouseWheelDeltaY[0]=t+e.deltaY};onPointerDown=e=>{if(this.context.isInAR||this.canReceiveInput(e)===!1)return;e.target instanceof HTMLElement&&e.target.setPointerCapture(e.pointerId);const t=this.getPointerId(e);it&&Te(`pointer down #${t}, identifier:${e.pointerId}`);const i=this.getAndUpdateSpatialObjectForScreenPosition(t,e.clientX,e.clientY),n=new _o("pointerdown",e,{origin:this,mode:"screen",deviceIndex:0,pointerId:t,button:e.button,clientX:e.clientX,clientY:e.clientY,pointerType:e.pointerType,buttonName:this.getButtonName(e),device:i,pressure:e.pressure});this.onDown(n)};onPointerMove=e=>{if(this.context.isInAR||this._receivedPointerMoveEventsThisFrame.includes(e.pointerId))return;this._receivedPointerMoveEventsThisFrame.push(e.pointerId);let t=e.button;e.pointerType==="mouse"&&(t=this.getFirstPressedButtonForPointer(0)??0);const i=this.getPointerId(e,t);t===-1&&(t=i);const n=this.getAndUpdateSpatialObjectForScreenPosition(i,e.clientX,e.clientY),s=new _o("pointermove",e,{origin:this,mode:"screen",deviceIndex:0,pointerId:i,button:t,clientX:e.clientX,clientY:e.clientY,pointerType:e.pointerType,buttonName:this.getButtonName(e),device:n,pressure:e.pressure});this.onMove(s)};onPointerCancel=e=>{this.context.isInAR||(it&&console.log("Pointer cancel",e),this.onPointerUp(e))};onPointerUp=e=>{if(this.context.isInAR)return;e.target instanceof HTMLElement&&e.target.releasePointerCapture(e.pointerId);const t=this.getPointerId(e),i=new _o("pointerup",e,{origin:this,mode:"screen",deviceIndex:0,pointerId:t,button:e.button,clientX:e.clientX,clientY:e.clientY,pointerType:e.pointerType,buttonName:this.getButtonName(e),device:this.getAndUpdateSpatialObjectForScreenPosition(t,e.clientX,e.clientY),pressure:e.pressure});this.onUp(i),this._pointerIds[t]=-1,it&&console.log("ID="+t,"PointerId="+e.pointerId,"ALL:",[...this._pointerIds])};getPointerId(e,t){return e.pointerType==="mouse"?0+(t??e.button):this.getPointerIndex(e.pointerId)}getButtonName(e){const t=e.button;if(e.pointerType==="mouse")switch(t){case 0:return"left";case 1:return"middle";case 2:return"right"}return"unknown"}onTouchStart=e=>{if(this.context.isInAR)for(let t=0;t<e.changedTouches.length;t++){const i=e.changedTouches[t],n=this.getPointerIndex(i.identifier),s=this.getAndUpdateSpatialObjectForScreenPosition(n,i.clientX,i.clientY),r=new _o("pointerdown",e,{origin:this,mode:"screen",deviceIndex:0,pointerId:n,button:0,clientX:i.clientX,clientY:i.clientY,pointerType:"touch",buttonName:"unknown",device:s,pressure:i.force});this.onDown(r)}};onTouchMove=e=>{if(this.context.isInAR)for(let t=0;t<e.changedTouches.length;t++){const i=e.changedTouches[t],n=this.getPointerIndex(i.identifier),s=this.getAndUpdateSpatialObjectForScreenPosition(n,i.clientX,i.clientY),r=new _o("pointermove",e,{origin:this,mode:"screen",deviceIndex:0,pointerId:n,button:0,clientX:i.clientX,clientY:i.clientY,pointerType:"touch",buttonName:"unknown",device:s,pressure:i.force});this.onMove(r)}};onTouchEnd=e=>{if(this.context.isInAR)for(let t=0;t<e.changedTouches.length;t++){const i=e.changedTouches[t],n=this.getPointerIndex(i.identifier),s=new _o("pointerup",e,{origin:this,mode:"screen",deviceIndex:0,pointerId:n,button:0,clientX:i.clientX,clientY:i.clientY,pointerType:"touch",buttonName:"unknown",device:this.getAndUpdateSpatialObjectForScreenPosition(n,i.clientX,i.clientY),pressure:i.force});this.onUp(s),this._pointerIds[n]=-1}};tempNearPlaneVector=new b;tempFarPlaneVector=new b;tempLookMatrix=new te;getAndUpdateSpatialObjectForScreenPosition(e,t,i){let n=this._pointerSpace[e];n||(n=new M,this._pointerSpace[e]=n),this._pointerSpace[e]=n;const s=this.context.mainCamera;if(s){const r=this.tempNearPlaneVector.set(t,i,-1);this.convertScreenspaceToRaycastSpace(r);const a=this.tempFarPlaneVector.set(r.x,r.y,1);r.unproject(s),a.unproject(s);const l=s.worldUp||H(0,1,0).applyQuaternion(be(s));this.tempLookMatrix.lookAt(a,r,l),n.position.set(r.x,r.y,r.z),n.quaternion.setFromRotationMatrix(this.tempLookMatrix)}return n}isInRect(e){if(this.context.isInXR)return!0;const t=this.context.domElement.getBoundingClientRect(),i=e.clientX,n=e.clientY,s=i>=t.x&&i<=t.right&&n>=t.y&&n<=t.bottom;return it&&!s&&console.log("Not in rect",t,i,n),s}onDown(e){const t=e.pointerId;if(this.getPointerPressed(t)&&console.warn(`Received pointerDown for pointerId that is already pressed: ${t}`,it?e:""),it&&console.log(e.pointerType,"DOWN",t),!!this.isInRect(e)){for(this.setPointerState(t,this._pointerPressed,!0),this.setPointerState(t,this._pointerDown,!0),this.setPointerStateT(t,this._pointerEvent,e.source);t>=this._pointerTypes.length;)this._pointerTypes.push(e.pointerType);for(this._pointerTypes[t]=e.pointerType;t>=this._pointerPositionDown.length;)this._pointerPositionDown.push(new b);for(this._pointerPositionDown[t].set(e.clientX,e.clientY,e.clientZ??0);t>=this._pointerPositions.length;)this._pointerPositions.push(new J);this._pointerPositions[t].set(e.clientX,e.clientY),t>=this._pointerDownTime.length&&this._pointerDownTime.push(0),this._pointerDownTime[t]=this.context.time.realtimeSinceStartup,this.updatePointerPosition(e),this._pointerEventsPressed.push(e),this.onDispatchEvent(e)}}onMove(e){const t=e.pointerId,i=this.getPointerPressed(t);i===!1&&!this.isInRect(e)||e.pointerType==="touch"&&!i||(this.updatePointerPosition(e),this.setPointerStateT(t,this._pointerEvent,e.source),this.onDispatchEvent(e))}onUp(e){const t=e.pointerId;if(!this.getPointerPressed(t)){it&&console.log(e.pointerType,"UP",t,"was not down");return}it&&console.log(e.pointerType,"UP",t),this.setPointerState(t,this._pointerPressed,!1),this.setPointerStateT(t,this._pointerEvent,e.source),this.setPointerState(t,this._pointerUp,!0),this.updatePointerPosition(e);for(let a=this._pointerEventsPressed.length-1;a>=0;a--)if(this._pointerEventsPressed[a].pointerId===t){this._pointerEventsPressed.splice(a,1);break}if(!this._pointerPositionDown[t]){it&&pe("Received pointer up event without matching down event for button: "+t),console.warn("Received pointer up event without matching down event for button: "+t);return}const i=this._pointerUpTime[t],n=this._pointerDownTime[t],s=this.context.time.realtimeSinceStartup,r=s-n;if(t>=this._pointerUpTime.length&&this._pointerUpTime.push(-99),this._pointerUpTime[t]=s,r<1){let a=e.clientX-this._pointerPositionDown[t].x,l=e.clientY-this._pointerPositionDown[t].y,c=0;if(e.isSpatial&&e.clientZ!=null&&(c=e.clientZ-this._pointerPositionDown[t].z,a*=200,l*=200,c*=200),Math.abs(a)<5&&Math.abs(l)<5&&Math.abs(c)<5){this.setPointerState(t,this._pointerClick,!0),e.isClick=!0;const h=s-i;it&&console.log("CLICK",t,a,l,c,h),h<this._doubleClickTimeThreshold&&h>0&&(this.setPointerState(t,this._pointerDoubleClick,!0),e.isDoubleClick=!0)}}this.onDispatchEvent(e)}updatePointerPosition(e){const t=e.pointerId;for(;t>=this._pointerPositions.length;)this._pointerPositions.push(new J);for(;t>=this._pointerPositionsLastFrame.length;)this._pointerPositionsLastFrame.push(new J);for(;t>=this._pointerPositionsDelta.length;)this._pointerPositionsDelta.push(new J);const i=this._pointerPositionsLastFrame[t];i.copy(this._pointerPositions[t]);const n=this._pointerPositionsDelta[t];let s=e.clientX-i.x,r=e.clientY-i.y;if(e.source instanceof MouseEvent||e.source instanceof TouchEvent){const h=e.source;s===0&&h.movementX!==0&&(s=h.movementX||0),r===0&&h.movementY!==0&&(r=h.movementY||0)}n.x+=s,n.y+=r,this._pointerPositions[t].x=e.clientX,this._pointerPositions[t].y=e.clientY;const a=e.clientX,l=e.clientY;for(;t>=this._pointerPositionsRC.length;)this._pointerPositionsRC.push(new J);const c=this._pointerPositionsRC[t];c.set(a,l),this.convertScreenspaceToRaycastSpace(c)}getPointerIndex(e){let t=-1;for(let i=0;i<this._pointerIds.length;i++){if(this._pointerIds[i]===e)return i;t===-1&&this._pointerIds[i]===-1&&(t=i)}return t!==-1?(this._pointerIds[t]=e,t):(it&&console.log("PUSH pointerId:",e),this._pointerIds.push(e),this._pointerIds.length-1)}setPointerState(e,t,i){t[e]=i}setPointerStateT(e,t,i){return t[e]=i,i}onDispatchEvent(e){const t=U.Current;try{U.Current=this.context,this.dispatchEvent(e)}finally{U.Current=t}}}const ba=new te().makeRotationY(Math.PI),Wi=new z().setFromAxisAngle(new b(0,1,0),Math.PI),tO=w("debugwebxr");class iO{priority=-1e5;gameObject;isXRRig(){return!0}get isActive(){return this.gameObject.visible}constructor(){if(this.gameObject=new M,this.gameObject.name="Implicit XR Rig",tO){const e=Ym(16733661);e.position.y+=.5,this.gameObject.add(e)}}}const vo=w("debugwebxr"),_d=w("debugcustomgesture"),nO="https://cdn.jsdelivr.net/npm/@webxr-input-profiles/assets@1.0/dist/profiles",oO="generic-trigger",sO=new z().setFromEuler(new Et(ho.degToRad(0),ho.degToRad(-90),ho.degToRad(-90))),rO=new b(.04,-.04,0);class Dm{xr;get context(){return this.xr.context}inputSource;index=0;emitEvents=!0;get connected(){return this._connected}_connected=!0;get isTracking(){return this._isTracking}_isTracking=!1;get gamepad(){return this.__gamepad??=this.inputSource.gamepad}__gamepad;get isHand(){return this.hand!=null}get hand(){return this.__hand??=this.inputSource.hand}__hand;get handObject(){return this.context.renderer.xr.getHand(this.index)}get profiles(){return this.inputSource.profiles}get layout(){return this._layout}get targetRayMode(){return this.inputSource.targetRayMode}get targetRaySpace(){return this.inputSource.targetRaySpace}get gripSpace(){return this.inputSource.gripSpace}get side(){return this.__side??=this.inputSource.handedness}__side=void 0;get isRight(){return this.side==="right"}get isLeft(){return this.side==="left"}get isStylus(){return this._isMxInk}getHitTestSource(){return this._hitTestSource||this._requestHitTestSource(),this._hitTestSource}get hasHitTestSource(){return this._hitTestSource}cancelHitTestSource(){this._hitTestSource&&(this._hitTestSource.cancel(),this._hitTestSource=void 0)}_hitTestSource=void 0;_hasSelectEvent=!1;get hasSelectEvent(){return this._hasSelectEvent}_isMxInk=!1;_isMetaQuestTouchController=!1;getHitTest(){return this.xr.getHitTest(this)}_handJointPoses=new Map;getHandJointPose(e,t){if(t=t||this.xr.frame,!this.hand||!t?.getJointPose||!this.xr.referenceSpace)return null;let i=this._handJointPoses?.get(e);return i||(i=t.getJointPose(e,this.xr.referenceSpace),i&&this._handJointPoses.set(e,i),i)}_gripMatrix=new te;_gripPosition=new b;_gripQuaternion=new z;_linearVelocity=new b;_rayPositionRaw=new b;_rayRotationRaw=new z;_rayMatrix=new te;_rayPosition=new b;_rayQuaternion=new z;get gripPosition(){return H(this._gripPosition)}get gripQuaternion(){return un(this._gripQuaternion)}get gripMatrix(){return this._gripMatrix}get gripLinearVelocity(){return H(this._linearVelocity).applyQuaternion(Wi)}get rayPosition(){return H(this._rayPosition)}get rayQuaternion(){return un(this._rayQuaternion)}get gripWorldPosition(){return H(this._gripWorldPosition)}_gripWorldPosition=new b;get gripWorldQuaternion(){return un(this._gripWorldQuaternion)}_gripWorldQuaternion=new z;get rayWorldPosition(){return H(this._rayWorldPosition)}_rayWorldPosition=new b;updateRayWorldPosition(){const e=this.xr.context.mainCamera?.parent;this._rayWorldPosition.copy(this._rayPositionRaw),e&&this._rayWorldPosition.applyMatrix4(e.matrixWorld)}get rayWorldQuaternion(){return un(this._rayWorldQuaternion)}_rayWorldQuaternion=new z;get pinchPosition(){return H(this._pinchPosition)}_pinchPosition=new b;updateRayWorldQuaternion(){const e=this.xr.context.mainCamera?.parent,t=e?be(e):void 0;this._rayWorldQuaternion.copy(this._rayRotationRaw).multiply(Wi),t&&this._rayWorldQuaternion.premultiply(t)}get ray(){return this._ray.origin.copy(this.rayWorldPosition),this._ray.direction.copy(H(0,0,1).applyQuaternion(this.rayWorldQuaternion)),this._ray}_ray;_hand_wristDotUp=void 0;get handWristDotUp(){if(this._hand_wristDotUp!==void 0)return this._hand_wristDotUp;const e=this.handObject?.joints.wrist;if(e){const t=H(0,1,0).applyQuaternion(e.quaternion),i=H(0,1,0).dot(t);return this._hand_wristDotUp=i}}get isHandUpsideDown(){return this.handWristDotUp!==void 0?this.handWristDotUp<-.7:!1}get isTeleportGesture(){return this.isHandUpsideDown&&this.getGesture("pinch")?.isDown}get object(){return this._object}_object;_gripSpaceObject;_raySpaceObject;model=null;_debugAxesHelper=new fi(.15);_debugGripAxesHelper=new fi(.07);_debugRayAxesHelper=new fi(.07);async getModelUrl(){return this.getMotionController?.then(e=>e?.assetUrl||null)}constructor(e,t,i){this.xr=e,this.inputSource=t,this.index=i,this._object=new M,this._object.name=`NeedleXRController_${i}`,vo&&(this._object.add(this._debugAxesHelper),this._gripSpaceObject=new M,this._raySpaceObject=new M,this._gripSpaceObject.name=`NeedleXRController_${i}_gripSpace`,this._raySpaceObject.name=`NeedleXRController_${i}_raySpace`,this._gripSpaceObject.add(this._debugGripAxesHelper),this._raySpaceObject.add(this._debugRayAxesHelper),this.xr.context.scene.add(this._gripSpaceObject),this.xr.context.scene.add(this._raySpaceObject)),this.xr.context.scene.add(this._object),this._ray=new ns,this.pointerInit={origin:this,pointerType:this.hand?"hand":"controller",deviceIndex:this.index,pointerId:-1,mode:this.inputSource.targetRayMode,ray:this._ray,device:this._object,buttonName:"none"},this.initialize(),this.subscribeEvents()}_hitTestSourcePromise=null;_requestHitTestSource(){return this._hitTestSourcePromise?this._hitTestSourcePromise:this.xr.mode==="immersive-ar"&&this.inputSource.targetRayMode==="tracked-pointer"&&this.xr.session.requestHitTestSourceForTransientInput?this._hitTestSourcePromise=this.xr.session.requestHitTestSourceForTransientInput({profile:this.inputSource.profiles[0],offsetRay:new XRRay})?.then(e=>(this._hitTestSourcePromise=null,this.connected?this._hitTestSource=e:(e.cancel(),null)))??null:null}onPointerHits=e=>{};onUpdate(e){this.onUpdateFrame(e),this.updateInputEvents(),this.onUpdateMove()}onRenderDebug(){F.DrawSphere(this.rayWorldPosition,.003),F.DrawDirection(this.rayWorldPosition,H(0,0,10).applyQuaternion(this.rayWorldQuaternion));const e=(this.inputSource.gripSpace?this.gripWorldPosition:this.object.worldPosition).sub(this.object.worldForward.multiplyScalar(.1)),t=this.inputSource.profiles.join(`
147
147
  `);let i=`Controller[${this.index}] (${this.inputSource.targetRayMode}, ${this.side})
148
148
  C:${this.connected?"x":"-"} T:${this.isTracking?"x":"-"} Hand:${this.inputSource.hand?"x":"-"} Pen: ${this._isMxInk?"x":"-"}`;if(this.inputSource.hand&&(i+=`
@@ -770,7 +770,7 @@ vec3 AgXToneMapping( vec3 color ) {
770
770
  The script will be ignored. Please make sure your component extends "Behaviour" imported from "@needle-tools/engine"
771
771
  `,o);return}e||(e=U.Current,Xe&&console.warn("> Registering component without context"));const t=e?.new_scripts;t.includes(o)||t.push(o)}class U{static _defaultTargetFramerate={value:90,toString(){return this.value}};static get DefaultTargetFrameRate(){return U._defaultTargetFramerate.value}static set DefaultTargetFrameRate(e){U._defaultTargetFramerate.value=e}static _defaultWebglRendererParameters={antialias:!0,alpha:!1,powerPreference:G.isiOS()||G.isMacOS()?"default":"high-performance",stencil:!0};static get DefaultWebGLRendererParameters(){return U._defaultWebglRendererParameters}get version(){return mn}static get Current(){return he.Current}static set Current(e){he.Current=e}static get All(){return he.All}name;alias;isManagedExternally=!1;isPaused=!1;runInBackground=!1;targetFrameRate;physicsSteps=1;hash;domElement;appendHTMLElement(e){return this.domElement.shadowRoot?this.domElement.shadowRoot.appendChild(e):this.domElement.appendChild(e)}get resolutionScaleFactor(){return this._resolutionScaleFactor}set resolutionScaleFactor(e){if(e!==this._resolutionScaleFactor&&typeof e=="number"){if(e<=0){console.error("Invalid resolution scale factor",e);return}this._resolutionScaleFactor=e,this.updateSize()}}_resolutionScaleFactor=1;_boundingClientRectFrame=-1;_boundingClientRect=null;_domX;_domY;calculateBoundingClientRect(){if(this.xr){this._domX=0,this._domY=0;return}this._boundingClientRectFrame!==this.time.frame&&(this._boundingClientRectFrame=this.time.frame,this._boundingClientRect=this.domElement.getBoundingClientRect(),this._domX=this._boundingClientRect.x,this._domY=this._boundingClientRect.y)}get domWidth(){return this.isInAR?window.innerWidth:this.domElement.clientWidth}get domHeight(){return this.isInAR?window.innerHeight:this.domElement.clientHeight}get domX(){return this.calculateBoundingClientRect(),this._domX}get domY(){return this.calculateBoundingClientRect(),this._domY}get isInXR(){return this.renderer?.xr?.isPresenting||!1}xr=null;get xrSessionMode(){return this.xr?.mode}get isInVR(){return this.xrSessionMode==="immersive-vr"}get isInAR(){return this.xrSessionMode==="immersive-ar"}get isInPassThrough(){return this.xr?this.xr.isPassThrough:!1}get xrSession(){return this.renderer?.xr?.getSession()}get xrFrame(){return this._xrFrame}get xrCamera(){return this.renderer.xr.isPresenting?this.renderer?.xr?.getCamera():void 0}_xrFrame=null;get arOverlayElement(){const e=this.domElement;return typeof e.getAROverlayContainer=="function"?e.getAROverlayContainer():this.domElement}get currentFrameEvent(){return this._currentFrameEvent}_currentFrameEvent=-1;scene;renderer;composer=null;scripts=[];scripts_pausedChanged=[];scripts_earlyUpdate=[];scripts_update=[];scripts_lateUpdate=[];scripts_onBeforeRender=[];scripts_onAfterRender=[];scripts_WithCorroutines=[];scripts_immersive_vr=[];scripts_immersive_ar=[];coroutines={};post_setup_callbacks=[];pre_update_callbacks=[];pre_render_callbacks=[];post_render_callbacks=[];pre_update_oneshot_callbacks=[];new_scripts=[];new_script_start=[];new_scripts_pre_setup_callbacks=[];new_scripts_post_setup_callbacks=[];new_scripts_xr=[];mainCameraComponent=void 0;get mainCamera(){if(this._mainCamera)return this._mainCamera;if(this.mainCameraComponent){const e=this.mainCameraComponent;return e.threeCamera||e.buildCamera(),e.threeCamera}return this._fallbackCamera||(this._fallbackCamera=new fe(75,this.domWidth/this.domHeight,.1,1e3)),this._fallbackCamera}set mainCamera(e){this._mainCamera=e}_mainCamera=null;_fallbackCamera=null;application;animations;time;input;physics;connection;assets;mainLight=null;get rendererData(){return this.sceneLighting}sceneLighting;addressables;lightmaps;players;lodsManager;menu;get isCreated(){return this._isCreated}_needsUpdateSize=!1;_isCreated=!1;_isCreating=!1;_isVisible=!1;_stats=Ek?new nC:null;constructor(e){this.name=e?.name||"",this.alias=e?.alias,this.domElement=e?.domElement||document.body,this.hash=e?.hash,e?.renderer&&(this.renderer=e.renderer,this.isManagedExternally=!0),e?.runInBackground!==void 0&&(this.runInBackground=e.runInBackground),e?.scene?this.scene=e.scene:this.scene=new mi,e?.camera&&(this._mainCamera=e.camera),this.application=new kn(this),this.time=new Pv,this.input=new Hb(this),this.physics=new wl(this),this.connection=new r_(this),this.assets=new __,this.sceneLighting=new xv(this),this.addressables=new pv(this),this.lightmaps=new yk(this),this.players=new _v(this),this.menu=new Tk(this),this.lodsManager=new bk(this),this.animations=new mk(this);const t=()=>this._needsUpdateSize=!0;window.addEventListener("resize",t),this._disposeCallbacks.push(()=>window.removeEventListener("resize",t));const i=new ResizeObserver(n=>this._needsUpdateSize=!0);i.observe(this.domElement),this._disposeCallbacks.push(()=>i.disconnect()),this._intersectionObserver=new IntersectionObserver(n=>{this._isVisible=n[0].isIntersecting}),this._disposeCallbacks.push(()=>this._intersectionObserver?.disconnect()),he.register(this)}createNewRenderer(e){if(this.renderer?.dispose(),e={...U.DefaultWebGLRendererParameters,...e},!e.canvas){const t=this.domElement?.shadowRoot?.querySelector("canvas");t&&(e.canvas=t,Xe&&console.log("Using canvas from shadow root",t))}return Xe&&console.log("Using Renderer Parameters:",e,this.domElement),this.renderer=new Zs(e),this.renderer.debug.checkShaderErrors=A()||w("checkshadererrors")===!0,this.renderer.toneMappingExposure=1,this.renderer.toneMapping=Zh,this.renderer.setClearColor(new ne("lightgrey"),0),this.renderer.shadowMap.enabled=!0,this.renderer.shadowMap.type=Q1,this.renderer.setSize(this.domWidth,this.domHeight),this.renderer.outputColorSpace=go,this.renderer.nodes={library:new Y1,modelViewMatrix:null,modelNormalViewMatrix:null},this.lodsManager.setRenderer(this.renderer),this.input.bindEvents(),this.renderer}_intersectionObserver=null;internalOnUpdateVisible(){this._intersectionObserver?.disconnect(),this._intersectionObserver?.observe(this.domElement)}_disposeCallbacks=[];requestSizeUpdate(){this._needsUpdateSize=!0}maxRenderResolution;get devicePixelRatio(){return this._devicePixelRatio}set devicePixelRatio(e){e!==this._devicePixelRatio&&(this._devicePixelRatio=e,this._needsUpdateSize=!0)}_devicePixelRatio="auto";updateSize(e=!1){if(e||!this.isManagedExternally&&this.renderer.xr?.isPresenting===!1){this._needsUpdateSize=!1;const t=this.resolutionScaleFactor;let i=this.domWidth*t,n=this.domHeight*t;this.maxRenderResolution&&(this.maxRenderResolution.x=Math.max(1,this.maxRenderResolution.x),i=Math.min(this.maxRenderResolution.x,i),this.maxRenderResolution.y=Math.max(1,this.maxRenderResolution.y),n=Math.min(this.maxRenderResolution.y,n));const s=this.mainCamera;this.updateAspect(s),this.renderer.setSize(i,n,!0),this.renderer.domElement.style.width="100%",this.renderer.domElement.style.height="100%";const r=typeof this.devicePixelRatio=="number"?this.devicePixelRatio:this.devicePixelRatio==="auto"?Math.min(2,window.devicePixelRatio):void 0;r!==void 0&&this.renderer.setPixelRatio(r),this.composer&&(this.composer.setSize?.call(this.composer,i,n),r!==void 0&&"setPixelRatio"in this.composer&&typeof this.composer.setPixelRatio=="function"&&this.composer.setPixelRatio?.call(this.composer,window.devicePixelRatio))}}updateAspect(e,t,i){if(!e)return;t===void 0&&(t=this.domWidth),i===void 0&&(i=this.domHeight);const n=t/i;if(e.isPerspectiveCamera){const s=e,r=s.aspect;s.aspect=n,r!==s.aspect&&e.updateProjectionMatrix()}else if(e.isOrthographicCamera){const s=e,r=s.top-s.bottom,a=r*n/2,l=r/2;(s.left!=-a||s.top!=l)&&(s.left=-a,s.right=a,s.top=l,s.bottom=-l,e.updateProjectionMatrix())}}recreate(){this.clear(),this.create(this._originalCreationArgs)}_originalCreationArgs;async onCreate(e){return this.create(e)}async create(e){try{this._isCreating=!0,e!==this._originalCreationArgs&&(this._originalCreationArgs=El(e)),window.addEventListener("unhandledrejection",this.onUnhandledRejection);const t=await this.internalOnCreate(e);return this._isCreated=t,t}finally{window.removeEventListener("unhandledrejection",this.onUnhandledRejection),this._isCreating=!1}}onUnhandledRejection=e=>{this.onError(e.reason)};onError(e){this.domElement.dispatchEvent(new CustomEvent("error",{detail:e}))}clear(){he.dispatchCallback(ce.ContextClearing,this),Bn(this,ce.ContextClearing),Si(this.scene,!0,!0),this.scene=new mi,this.addressables?.dispose(),this.lightmaps?.clear(),this.physics?.engine?.clearCaches(),this.lodsManager.disable(),this._onBeforeRenderListeners.clear(),this._onAfterRenderListeners.clear(),this.isManagedExternally||this.renderer&&(this.renderer.renderLists.dispose(),this.renderer.state.reset(),this.renderer.resetState()),he.dispatchCallback(ce.ContextCleared,this)}dispose(){this.internalOnDestroy()}onDestroy(){this.internalOnDestroy()}internalOnDestroy(){U.Current=this,he.dispatchCallback(ce.ContextDestroying,this),Bn(this,ce.ContextDestroying),this.clear(),this.renderer?.setAnimationLoop(null),this.renderer&&(this.renderer.setClearAlpha(0),this.renderer.clear(),this.isManagedExternally||(Xe&&console.log("Disposing renderer"),this.renderer.dispose())),this.scene=null,this.renderer=null,this.input.dispose(),this.menu.onDestroy(),this.animations.onDestroy();for(const e of this._disposeCallbacks)try{e()}catch(t){console.error("Error in on dispose callback:",t,e)}this.domElement?.parentElement&&this.domElement.parentElement.removeChild(this.domElement),this._isCreated=!1,he.dispatchCallback(ce.ContextDestroyed,this),Bn(this,ce.ContextDestroyed),he.unregister(this),U.Current===this&&(U.Current=null)}registerCoroutineUpdate(e,t,i){return typeof t?.next!="function"?(console.error("Registered invalid coroutine function from "+e.name+`
772
772
  Coroutine functions must be generators: "*myCoroutine() {...}"
773
- Start a coroutine from a component by calling "this.startCoroutine(myCoroutine())"`),t):(this.coroutines[i]||(this.coroutines[i]=[]),this.coroutines[i].push({comp:e,main:t}),t)}unregisterCoroutineUpdate(e,t){if(!this.coroutines[t])return;const i=this.coroutines[t].findIndex(n=>n.main===e);i>=0&&this.coroutines[t].splice(i,1)}stopAllCoroutinesFrom(e){for(const t in this.coroutines){const i=this.coroutines[t];for(let n=i.length-1;n>=0;n--)i[n].comp===e&&i.splice(n,1)}}_cameraStack=[];setCurrentCamera(e){if(!e)return;if(e.threeCamera||e.buildCamera(),!e.threeCamera){console.warn("Camera component is missing camera",e);return}const t=this._cameraStack.indexOf(e);t>=0&&this._cameraStack.splice(t,1),this._cameraStack.push(e),this.mainCameraComponent=e;const i=e.threeCamera;i.isPerspectiveCamera&&this.updateAspect(i),this.mainCameraComponent?.applyClearFlagsIfIsActiveCamera()}removeCamera(e){if(!e)return;const t=this._cameraStack.indexOf(e);if(t>=0&&this._cameraStack.splice(t,1),this.mainCameraComponent===e&&(this.mainCameraComponent=void 0,this._cameraStack.length>0)){const i=this._cameraStack[this._cameraStack.length-1];this.setCurrentCamera(i)}}_onBeforeRenderListeners=new Map;_onAfterRenderListeners=new Map;addBeforeRenderListener(e,t){if(!this._onBeforeRenderListeners.has(e.uuid)){const i=[];this._onBeforeRenderListeners.set(e.uuid,i),e.onBeforeRender=this._createRenderCallbackWrapper(i)}this._onBeforeRenderListeners.get(e.uuid).push(t)}removeBeforeRenderListener(e,t){if(this._onBeforeRenderListeners.has(e.uuid)){const i=this._onBeforeRenderListeners.get(e.uuid),n=i.indexOf(t);n>=0&&i.splice(n,1)}}addAfterRenderListener(e,t){if(!this._onAfterRenderListeners.has(e.uuid)){const i=[];this._onAfterRenderListeners.set(e.uuid,i),e.onAfterRender=this._createRenderCallbackWrapper(i)}this._onAfterRenderListeners.get(e.uuid)?.push(t)}removeAfterRenderListener(e,t){if(this._onAfterRenderListeners.has(e.uuid)){const i=this._onAfterRenderListeners.get(e.uuid),n=i.indexOf(t);n>=0&&i.splice(n,1)}}_createRenderCallbackWrapper(e){return(t,i,n,s,r,a)=>{for(let l=0;l<e.length;l++){const c=e[l];c(t,i,n,s,r,a)}}}_requireDepthTexture=!1;_requireColorTexture=!1;_renderTarget;_isRendering=!1;get isRendering(){return this._isRendering}setRequireDepth(e){this._requireDepthTexture=e}setRequireColor(e){this._requireColorTexture=e}get depthTexture(){return this._renderTarget?.depthTexture||null}get opaqueColorTexture(){return this._renderTarget?.texture||null}get isVisibleToUser(){if(this.isInXR)return!0;if(!this._isVisible)return!1;const e=getComputedStyle(this.domElement);return e.visibility!=="hidden"&&e.display!=="none"&&e.opacity!=="0"}_createId=0;async internalOnCreate(e){const t=++this._createId;Xe&&console.log("Creating context",this.name,e);const i=globalThis["needle:dependencies:ready"];i instanceof Promise&&(Xe&&console.log("Waiting for dependencies to be ready"),await i.catch(c=>{if(Xe||A()){if(Ul("Needle Engine dependencies failed to load. Please check the console for more details"),c instanceof ReferenceError){let h="YourComponentName";const d=c.message.indexOf("'");if(d>0){const p=c.message.indexOf("'",d+1);if(p>0){const m=c.message.substring(d+1,p);m.length>3&&(h=m)}}console.error(`Needle Engine dependencies failed to load:
773
+ Start a coroutine from a component by calling "this.startCoroutine(myCoroutine())"`),t):(this.coroutines[i]||(this.coroutines[i]=[]),this.coroutines[i].push({comp:e,main:t}),t)}unregisterCoroutineUpdate(e,t){if(!this.coroutines[t])return;const i=this.coroutines[t].findIndex(n=>n.main===e);i>=0&&this.coroutines[t].splice(i,1)}stopAllCoroutinesFrom(e){for(const t in this.coroutines){const i=this.coroutines[t];for(let n=i.length-1;n>=0;n--)i[n].comp===e&&i.splice(n,1)}}_cameraStack=[];setCurrentCamera(e){if(!e)return;if(e.threeCamera||e.buildCamera(),!e.threeCamera){console.warn("Camera component is missing camera",e);return}const t=this._cameraStack.indexOf(e);t>=0&&this._cameraStack.splice(t,1),this._cameraStack.push(e),this.mainCameraComponent=e;const i=e.threeCamera;i.isPerspectiveCamera&&this.updateAspect(i),this.mainCameraComponent?.applyClearFlagsIfIsActiveCamera()}removeCamera(e){if(!e)return;const t=this._cameraStack.indexOf(e);if(t>=0&&this._cameraStack.splice(t,1),this.mainCameraComponent===e&&(this.mainCameraComponent=void 0,this._cameraStack.length>0)){const i=this._cameraStack[this._cameraStack.length-1];this.setCurrentCamera(i)}}_onBeforeRenderListeners=new Map;_onAfterRenderListeners=new Map;addBeforeRenderListener(e,t){if(!this._onBeforeRenderListeners.has(e.uuid)){const i=[];this._onBeforeRenderListeners.set(e.uuid,i),e.onBeforeRender=this._createRenderCallbackWrapper(i)}this._onBeforeRenderListeners.get(e.uuid).push(t)}removeBeforeRenderListener(e,t){if(this._onBeforeRenderListeners.has(e.uuid)){const i=this._onBeforeRenderListeners.get(e.uuid),n=i.indexOf(t);n>=0&&i.splice(n,1)}}addAfterRenderListener(e,t){if(!this._onAfterRenderListeners.has(e.uuid)){const i=[];this._onAfterRenderListeners.set(e.uuid,i),e.onAfterRender=this._createRenderCallbackWrapper(i)}this._onAfterRenderListeners.get(e.uuid)?.push(t)}removeAfterRenderListener(e,t){if(this._onAfterRenderListeners.has(e.uuid)){const i=this._onAfterRenderListeners.get(e.uuid),n=i.indexOf(t);n>=0&&i.splice(n,1)}}_createRenderCallbackWrapper(e){return(t,i,n,s,r,a)=>{for(let l=0;l<e.length;l++){const c=e[l];c(t,i,n,s,r,a)}}}_requireDepthTexture=!1;_requireColorTexture=!1;_renderTarget;_isRendering=!1;get isRendering(){return this._isRendering}setRequireDepth(e){this._requireDepthTexture=e}setRequireColor(e){this._requireColorTexture=e}get depthTexture(){return this._renderTarget?.depthTexture||null}get opaqueColorTexture(){return this._renderTarget?.texture||null}get isVisibleToUser(){if(this.isInXR)return!0;if(!this._isVisible)return!1;if(this.time.frame===this._lastStyleComputedFrame)return this._lastStyleComputedResult;this._lastStyleComputedFrame=this.time.frame;const e=getComputedStyle(this.domElement);return this._lastStyleComputedResult=e.visibility!=="hidden"&&e.display!=="none"&&e.opacity!=="0",this._lastStyleComputedResult}_lastStyleComputedFrame=-1;_lastStyleComputedResult=!0;_createId=0;async internalOnCreate(e){const t=++this._createId;Xe&&console.log("Creating context",this.name,e);const i=globalThis["needle:dependencies:ready"];i instanceof Promise&&(Xe&&console.log("Waiting for dependencies to be ready"),await i.catch(c=>{if(Xe||A()){if(Ul("Needle Engine dependencies failed to load. Please check the console for more details"),c instanceof ReferenceError){let h="YourComponentName";const d=c.message.indexOf("'");if(d>0){const p=c.message.indexOf("'",d+1);if(p>0){const m=c.message.substring(d+1,p);m.length>3&&(h=m)}}console.error(`Needle Engine dependencies failed to load:
774
774
 
775
775
  # Make sure you don't have circular imports in your scripts!
776
776
 
@@ -782,7 +782,7 @@ Possible solutions:
782
782
  `,i),this._renderlooperrors>=3&&(console.warn("Stopping render loop due to error"),this.renderer.setAnimationLoop(null)),this.domElement.dispatchEvent(new CustomEvent("error",{detail:i}))}else this.internalStep(e,t)}updatePhysics(e){this.internalUpdatePhysics(e)}_lastTimestamp=0;_accumulatedTime=0;_dispatchReadyAfterFrame=!1;internalStep(e,t){this.internalOnBeforeRender(e,t)!==!1&&(this.internalOnRender(),this.internalOnAfterRender())}internalOnBeforeRender(e,t){this.renderer.info.autoReset=!!t,this.renderer.info.autoReset===!1&&this.renderer.info.reset();const i=t!==null&&this._xrFrame===null;if(this._xrFrame=t,i&&this.domElement.dispatchEvent(new CustomEvent("xr-session-started",{detail:{context:this,session:this.xrSession,frame:t}})),this._currentFrameEvent=-1,this.isManagedExternally===!1&&this.isInXR===!1&&this.targetFrameRate!==void 0){this._lastTimestamp===0&&(this._lastTimestamp=e),this._accumulatedTime+=(e-this._lastTimestamp)/1e3,this._lastTimestamp=e;let n=this.targetFrameRate;if(typeof n=="object"&&(n=n.value),this._accumulatedTime<1/(n+1))return!1;this._accumulatedTime=0}if(this._stats?.begin(),U.Current=this,this.onHandlePaused())return!1;for(U.Current=this,this.time.update(),Ik&&console.log("FPS",this.time.smoothedFps.toFixed(0)),Td(this),Ed(this.scene),M_(this),Bn(this,-1);this._cameraStack.length>0&&(!this.mainCameraComponent||this.mainCameraComponent.destroyed);){this._cameraStack.splice(this._cameraStack.length-1,1);const n=this._cameraStack[this._cameraStack.length-1];this.setCurrentCamera(n)}if(this.pre_update_oneshot_callbacks){for(const n in this.pre_update_oneshot_callbacks)this.pre_update_oneshot_callbacks[n]();this.pre_update_oneshot_callbacks.length=0}if(this.pre_update_callbacks)for(const n in this.pre_update_callbacks)this.pre_update_callbacks[n]();this._currentFrameEvent=0;for(let n=0;n<this.scripts_earlyUpdate.length;n++){const s=this.scripts_earlyUpdate[n];s.activeAndEnabled&&s.earlyUpdate!==void 0&&(U.Current=this,s.earlyUpdate())}if(this.executeCoroutines(0),Bn(this,0),this.onHandlePaused())return!1;this._currentFrameEvent=1;for(let n=0;n<this.scripts_update.length;n++){const s=this.scripts_update[n];s.activeAndEnabled&&s.update!==void 0&&(U.Current=this,s.update())}if(this.executeCoroutines(1),Bn(this,1),this.onHandlePaused())return!1;this._currentFrameEvent=2;for(let n=0;n<this.scripts_lateUpdate.length;n++){const s=this.scripts_lateUpdate[n];s.activeAndEnabled&&s.lateUpdate!==void 0&&(U.Current=this,s.lateUpdate())}if(this.executeCoroutines(2),Bn(this,2),this.onHandlePaused()||(this.physicsSteps===void 0&&(this.physicsSteps=1),this.physics.engine&&this.physicsSteps>0&&this.internalUpdatePhysics(this.physicsSteps),this.onHandlePaused()))return!1;if(this.isVisibleToUser||this.runInBackground){this._currentFrameEvent=3;for(let n=0;n<this.scripts_onBeforeRender.length;n++){const s=this.scripts_onBeforeRender[n];s.activeAndEnabled&&s.onBeforeRender!==void 0&&(U.Current=this,s.onBeforeRender(t))}if(this.executeCoroutines(3),Bn(this,3),this._needsUpdateSize&&this.updateSize(),this.pre_render_callbacks)for(const n in this.pre_render_callbacks)this.pre_render_callbacks[n](t)}return!0}internalUpdatePhysics(e){if(!this.physics.engine)return!1;const t=e,i=this.time.deltaTime/t;for(let n=0;n<t;n++)this._currentFrameEvent=9,this.executeCoroutines(9),this.physics.engine.step(i),this._currentFrameEvent=10,this.executeCoroutines(10);return this.physics.engine.postStep(),!0}internalOnRender(){this.isManagedExternally||(FO(this),this._currentFrameEvent=-1,oC.update(),this.renderNow(),this._currentFrameEvent=4)}internalOnAfterRender(){if(this.isVisibleToUser||this.runInBackground){for(let e=0;e<this.scripts_onAfterRender.length;e++){const t=this.scripts_onAfterRender[e];t.activeAndEnabled&&t.onAfterRender!==void 0&&(U.Current=this,t.onAfterRender())}if(this.executeCoroutines(4),Bn(this,4),this.post_render_callbacks)for(const e in this.post_render_callbacks)this.post_render_callbacks[e]()}this._currentFrameEvent=-1,this.connection.sendBufferedMessagesNow(),this._stats&&(this._stats.end(),this.time.frameCount%150===0&&console.log(this.renderer.info.render.calls+" DrawCalls",`
783
783
  Render:`,{...this.renderer.info.render},`
784
784
  Memory:`,{...this.renderer.info.memory},`
785
- Target Framerate: `+this.targetFrameRate)),this._dispatchReadyAfterFrame&&(this._dispatchReadyAfterFrame=!1,this.domElement.dispatchEvent(new CustomEvent("ready")),he.dispatchCallback(ce.ContextFirstFrameRendered,this))}_tempClearColor=new ne;_tempClearColor2=new ne;renderNow(e){if(!e&&(e=this.mainCamera,!e))return!1;if(this.handleRendererContextLost(),this._isRendering=!0,this.renderRequiredTextures(),this.renderer.toneMapping!==Zh&&kv(),this.composer&&!this.isInXR){e&&"setMainCamera"in this.composer&&this.composer.passes[0]?.mainCamera!=e&&this.composer.setMainCamera(e);const t=this.renderer.getClearColor(this._tempClearColor),i=this.renderer.getClearAlpha();this._tempClearColor2.copy(t),this.renderer.setClearColor(t.convertSRGBToLinear(),this.renderer.getClearAlpha()),this.composer.render(this.time.deltaTime),this.renderer.setClearColor(this._tempClearColor2,i)}else e&&(this.isInXR&&G.isMacOS()&&this.renderer.clearDepth(),this.renderer.render(this.scene,e));return this._isRendering=!1,!0}_contextRestoreTries=0;handleRendererContextLost(){this.time.frame%10&&this.renderer.getContext().isContextLost()&&this._contextRestoreTries++<100&&(console.warn("Attempting to recover WebGL context..."),this.renderer.forceContextRestore())}_wasPaused=!1;onHandlePaused(){const e=this.evaluatePaused();if(this._wasPaused!==e){Ak&&console.log("Paused?",e,"context:"+this.alias);for(let t=0;t<this.scripts_pausedChanged.length;t++){const i=this.scripts_pausedChanged[t];i.activeAndEnabled&&i.onPausedChanged!==void 0&&(U.Current=this,i.onPausedChanged(e,this._wasPaused))}}return this._wasPaused=e,e}evaluatePaused(){return this.isInXR?!1:this.isPaused?!0:this.runInBackground?!1:!this.isVisibleToUser}renderRequiredTextures(){if(!this.mainCamera||!this._requireDepthTexture&&!this._requireColorTexture)return;if(!this._renderTarget){if(this._renderTarget=new In(this.domWidth,this.domHeight),this._requireDepthTexture){const i=new S0(this.domWidth,this.domHeight);this._renderTarget.depthTexture=i}this._requireColorTexture&&(this._renderTarget.texture=new Re,this._renderTarget.texture.generateMipmaps=!1,this._renderTarget.texture.minFilter=Jh,this._renderTarget.texture.magFilter=Jh,this._renderTarget.texture.format=Qh)}const e=this._renderTarget;e.texture&&(e.texture.colorSpace=this.renderer.outputColorSpace);const t=this.renderer.getRenderTarget();this.renderer.setRenderTarget(e),this.renderer.render(this.scene,this.mainCamera),this.renderer.setRenderTarget(t)}executeCoroutines(e){if(this.coroutines[e]){const i=this.coroutines[e];for(let n=0;n<i.length;n++)try{const s=i[n];if(!s.comp||s.comp.destroyed||!s.main||s.comp.enabled===!1){Lk&&console.log("Removing coroutine",s.comp,s.comp.enabled),i.splice(n,1),--n;continue}const r=s.chained;if(r&&r.length>0){const c=r[r.length-1].next();if(c.done&&r.pop(),t(c)&&(s.chained||(s.chained=[]),s.chained.push(c.value)),!c.done)continue}const a=s.main.next();if(a.done===!0){i.splice(n,1),--n;continue}const l=a.value;if(t(l)){if(l.next().done)continue;s.chained||(s.chained=[]),s.chained.push(l)}else if(l instanceof Promise){const c=l;s.chained||(s.chained=[]);const h=fv(c);s.chained?.push(h);continue}}catch(s){console.error(s)}}function t(i){return!!(i&&i.next&&i.return)}}}const Ci=w("debuglicense"),Lv=[];let zn="basic";Ci&&console.log("License Type: "+zn);function Nn(){switch(zn){case"pro":case"enterprise":return!0}return!1}function cc(){switch(zn){case"indie":return!0}return!1}function Rg(){switch(zn){case"edu":return!0}return!1}function Wn(){return Nn()||cc()||Rg()}function Bk(o){if(Nn()||cc()||Rg())return o(!0);Lv.push(o)}function Zd(o){for(const e of Lv)try{e(o)}catch{}}he.registerCallback(ce.ContextRegistered,o=>{zk(o.context),Uk(o.context),setTimeout(()=>Wk(o.context),2e3)});let Ia,Tg=!1,Eg="";async function Fk(){if(Ia)return Ia;if(zn==="basic")try{const o="https://engine.needle.tools/licensing/check?location="+encodeURIComponent(window.location.href)+"&version="+mn+"&generator="+encodeURIComponent(md),e=await fetch(o,{method:"GET"}).catch(t=>{Ci&&console.error("License check failed",t)});e?.status===200?(Tg=!1,Ci&&console.log("License check succeeded"),zn="pro",Zd(!0)):e?.status===403?(Zd(!1),Tg=!0,Eg=await e.text()):(Zd(!1),Ci&&console.log("License check failed with status "+e?.status))}catch(o){Zd(!1),Ci&&console.error("License check failed",o)}else Ci&&console.log('Runtime license check is skipped because license is already applied as "'+zn+'"')}Ia=Fk();async function Uk(o){function e(){const n=document.createElement("div");n.className="needle-forbidden",n.style.cssText=`
785
+ Target Framerate: `+this.targetFrameRate)),this._dispatchReadyAfterFrame&&(this._dispatchReadyAfterFrame=!1,this.domElement.dispatchEvent(new CustomEvent("ready")),he.dispatchCallback(ce.ContextFirstFrameRendered,this))}_tempClearColor=new ne;_tempClearColor2=new ne;renderNow(e){if(!e&&(e=this.mainCamera,!e))return!1;if(this.handleRendererContextLost(),this.time.frame%10===0){if(this._isRendering=!0,this.renderRequiredTextures(),this.renderer.toneMapping!==Zh&&kv(),this.composer&&!this.isInXR){e&&"setMainCamera"in this.composer&&this.composer.passes[0]?.mainCamera!=e&&this.composer.setMainCamera(e);const t=this.renderer.getClearColor(this._tempClearColor),i=this.renderer.getClearAlpha();this._tempClearColor2.copy(t),this.renderer.setClearColor(t.convertSRGBToLinear(),this.renderer.getClearAlpha()),this.composer.render(this.time.deltaTime),this.renderer.setClearColor(this._tempClearColor2,i)}else e&&(this.isInXR&&G.isMacOS()&&this.renderer.clearDepth(),this.renderer.render(this.scene,e));return this._isRendering=!1,!0}}_contextRestoreTries=0;handleRendererContextLost(){this.time.frame%10&&this.renderer.getContext().isContextLost()&&this._contextRestoreTries++<100&&(console.warn("Attempting to recover WebGL context..."),this.renderer.forceContextRestore())}_wasPaused=!1;onHandlePaused(){const e=this.evaluatePaused();if(this._wasPaused!==e){Ak&&console.log("Paused?",e,"context:"+this.alias);for(let t=0;t<this.scripts_pausedChanged.length;t++){const i=this.scripts_pausedChanged[t];i.activeAndEnabled&&i.onPausedChanged!==void 0&&(U.Current=this,i.onPausedChanged(e,this._wasPaused))}}return this._wasPaused=e,e}evaluatePaused(){return this.isInXR?!1:this.isPaused?!0:this.runInBackground?!1:!this.isVisibleToUser}renderRequiredTextures(){if(!this.mainCamera||!this._requireDepthTexture&&!this._requireColorTexture)return;if(!this._renderTarget){if(this._renderTarget=new In(this.domWidth,this.domHeight),this._requireDepthTexture){const i=new S0(this.domWidth,this.domHeight);this._renderTarget.depthTexture=i}this._requireColorTexture&&(this._renderTarget.texture=new Re,this._renderTarget.texture.generateMipmaps=!1,this._renderTarget.texture.minFilter=Jh,this._renderTarget.texture.magFilter=Jh,this._renderTarget.texture.format=Qh)}const e=this._renderTarget;e.texture&&(e.texture.colorSpace=this.renderer.outputColorSpace);const t=this.renderer.getRenderTarget();this.renderer.setRenderTarget(e),this.renderer.render(this.scene,this.mainCamera),this.renderer.setRenderTarget(t)}executeCoroutines(e){if(this.coroutines[e]){const i=this.coroutines[e];for(let n=0;n<i.length;n++)try{const s=i[n];if(!s.comp||s.comp.destroyed||!s.main||s.comp.enabled===!1){Lk&&console.log("Removing coroutine",s.comp,s.comp.enabled),i.splice(n,1),--n;continue}const r=s.chained;if(r&&r.length>0){const c=r[r.length-1].next();if(c.done&&r.pop(),t(c)&&(s.chained||(s.chained=[]),s.chained.push(c.value)),!c.done)continue}const a=s.main.next();if(a.done===!0){i.splice(n,1),--n;continue}const l=a.value;if(t(l)){if(l.next().done)continue;s.chained||(s.chained=[]),s.chained.push(l)}else if(l instanceof Promise){const c=l;s.chained||(s.chained=[]);const h=fv(c);s.chained?.push(h);continue}}catch(s){console.error(s)}}function t(i){return!!(i&&i.next&&i.return)}}}const Ci=w("debuglicense"),Lv=[];let zn="basic";Ci&&console.log("License Type: "+zn);function Nn(){switch(zn){case"pro":case"enterprise":return!0}return!1}function cc(){switch(zn){case"indie":return!0}return!1}function Rg(){switch(zn){case"edu":return!0}return!1}function Wn(){return Nn()||cc()||Rg()}function Bk(o){if(Nn()||cc()||Rg())return o(!0);Lv.push(o)}function Zd(o){for(const e of Lv)try{e(o)}catch{}}he.registerCallback(ce.ContextRegistered,o=>{zk(o.context),Uk(o.context),setTimeout(()=>Wk(o.context),2e3)});let Ia,Tg=!1,Eg="";async function Fk(){if(Ia)return Ia;if(zn==="basic")try{const o="https://engine.needle.tools/licensing/check?location="+encodeURIComponent(window.location.href)+"&version="+mn+"&generator="+encodeURIComponent(md),e=await fetch(o,{method:"GET"}).catch(t=>{Ci&&console.error("License check failed",t)});e?.status===200?(Tg=!1,Ci&&console.log("License check succeeded"),zn="pro",Zd(!0)):e?.status===403?(Zd(!1),Tg=!0,Eg=await e.text()):(Zd(!1),Ci&&console.log("License check failed with status "+e?.status))}catch(o){Zd(!1),Ci&&console.error("License check failed",o)}else Ci&&console.log('Runtime license check is skipped because license is already applied as "'+zn+'"')}Ia=Fk();async function Uk(o){function e(){const n=document.createElement("div");n.className="needle-forbidden",n.style.cssText=`
786
786
  position: fixed;
787
787
  top: 0;
788
788
  left: 0;