shop-components 0.3.6 → 0.3.8

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.
@@ -1,4 +1,4 @@
1
- "use strict";var Wr=Object.create;var pi=Object.defineProperty;var Gr=Object.getOwnPropertyDescriptor;var qr=Object.getOwnPropertyNames;var jr=Object.getPrototypeOf,Yr=Object.prototype.hasOwnProperty;var Qr=(n,e,t)=>e in n?pi(n,e,{enumerable:!0,configurable:!0,writable:!0,value:t}):n[e]=t;var Zr=(n,e,t,i)=>{if(e&&typeof e=="object"||typeof e=="function")for(let s of qr(e))!Yr.call(n,s)&&s!==t&&pi(n,s,{get:()=>e[s],enumerable:!(i=Gr(e,s))||i.enumerable});return n};var Xr=(n,e,t)=>(t=n!=null?Wr(jr(n)):{},Zr(e||!n||!n.__esModule?pi(t,"default",{value:n,enumerable:!0}):t,n));var L=(n,e,t)=>(Qr(n,typeof e!="symbol"?e+"":e,t),t),ps=(n,e,t)=>{if(!e.has(n))throw TypeError("Cannot "+t)};var z=(n,e,t)=>(ps(n,e,"read from private field"),t?t.call(n):e.get(n)),be=(n,e,t)=>{if(e.has(n))throw TypeError("Cannot add the same private member more than once");e instanceof WeakSet?e.add(n):e.set(n,t)},ue=(n,e,t,i)=>(ps(n,e,"write to private field"),i?i.call(n,t):e.set(n,t),t);Object.defineProperty(exports,Symbol.toStringTag,{value:"Module"});const d=require("three"),Kr=require("three/examples/jsm/loaders/HDRLoader.js"),ms=require("three/examples/jsm/postprocessing/RenderPass"),gs=require("three/examples/jsm/postprocessing/OutlinePass"),Jr=require("three/examples/jsm/postprocessing/ShaderPass"),$r=require("three/examples/jsm/shaders/FXAAShader"),en=require("three/examples/jsm/postprocessing/UnrealBloomPass"),tn=require("three/examples/jsm/controls/OrbitControls"),sn=require("three/examples/jsm/postprocessing/OutputPass"),rn=require("three/examples/jsm/postprocessing/EffectComposer"),fe=require("three/examples/jsm/renderers/CSS2DRenderer"),nn=require("three/examples/jsm/loaders/FontLoader"),is=require("three/examples/jsm/loaders/GLTFLoader.js"),on=require("three/examples/jsm/libs/meshopt_decoder.module.js"),an=require("three/examples/jsm/loaders/DRACOLoader.js"),ln=require("three/examples/jsm/loaders/GLTFLoader"),cn=require("three/examples/jsm/loaders/DRACOLoader"),un=require("three/examples/jsm/exporters/DRACOExporter"),hn=require("three/examples/jsm/exporters/GLTFExporter"),fn=require("three/examples/jsm/utils/SkeletonUtils.js"),dn=require("three/examples/jsm/lines/Line2.js"),pn=require("three/examples/jsm/lines/LineMaterial.js"),vs=require("three/examples/jsm/lines/LineGeometry.js"),mn=require("three/examples/jsm/renderers/CSS3DRenderer");require("three/examples/jsm/utils/BufferGeometryUtils");const Ce=require("three-mesh-bvh"),nt=require("three/examples/jsm/postprocessing/Pass.js");var ot=typeof document<"u"?document.currentScript:null;function gn(n){const e=Object.create(null,{[Symbol.toStringTag]:{value:"Module"}});if(n){for(const t in n)if(t!=="default"){const i=Object.getOwnPropertyDescriptor(n,t);Object.defineProperty(e,t,i.get?i:{enumerable:!0,get:()=>n[t]})}}return e.default=n,Object.freeze(e)}const vn=gn(fn);function ur(n,e,t=0){if(n.isInterleavedBufferAttribute){const i=n.itemSize;for(let s=0,a=n.count;s<a;s++){const o=s+t;e.setX(o,n.getX(s)),i>=2&&e.setY(o,n.getY(s)),i>=3&&e.setZ(o,n.getZ(s)),i>=4&&e.setW(o,n.getW(s))}}else{const i=e.array,s=i.constructor,a=i.BYTES_PER_ELEMENT*n.itemSize*t;new s(i.buffer,a,n.array.length).set(n.array)}}function St(n,e=null){const t=n.array.constructor,i=n.normalized,s=n.itemSize,a=e===null?n.count:e;return new d.BufferAttribute(new t(s*a),s,i)}function Ke(n,e){if(!n&&!e)return!0;if(!!n!=!!e)return!1;const t=n.count===e.count,i=n.normalized===e.normalized,s=n.array.constructor===e.array.constructor,a=n.itemSize===e.itemSize;return!(!t||!i||!s||!a)}function _n(n){const e=n[0].index!==null,t=new Set(Object.keys(n[0].attributes));if(!n[0].getAttribute("position"))throw new Error("StaticGeometryGenerator: position attribute is required.");for(let i=0;i<n.length;++i){const s=n[i];let a=0;if(e!==(s.index!==null))throw new Error("StaticGeometryGenerator: All geometries must have compatible attributes; make sure index attribute exists among all geometries, or in none of them.");for(const o in s.attributes){if(!t.has(o))throw new Error('StaticGeometryGenerator: All geometries must have compatible attributes; make sure "'+o+'" attribute exists among all geometries, or in none of them.');a++}if(a!==t.size)throw new Error("StaticGeometryGenerator: All geometries must have the same number of attributes.")}}function yn(n){let e=0;for(let t=0,i=n.length;t<i;t++)e+=n[t].getIndex().count;return e}function xn(n){let e=0;for(let t=0,i=n.length;t<i;t++)e+=n[t].getAttribute("position").count;return e}function wn(n,e,t){n.index&&n.index.count!==e&&n.setIndex(null);const i=n.attributes;for(const s in i)i[s].count!==t&&n.deleteAttribute(s)}function bn(n,e={},t=new d.BufferGeometry){const{useGroups:i=!1,forceUpdate:s=!1,skipAssigningAttributes:a=[],overwriteIndex:o=!0}=e;_n(n);const c=n[0].index!==null,u=c?yn(n):-1,f=xn(n);if(wn(t,u,f),i){let r=0;for(let l=0,h=n.length;l<h;l++){const g=n[l];let _;c?_=g.getIndex().count:_=g.getAttribute("position").count,t.addGroup(r,_,l),r+=_}}if(c){let r=!1;if(t.index||(t.setIndex(new d.BufferAttribute(new Uint32Array(u),1,!1)),r=!0),r||o){let l=0,h=0;const g=t.getIndex();for(let _=0,m=n.length;_<m;_++){const v=n[_],y=v.getIndex();if(!(!s&&!r&&a[_]))for(let w=0;w<y.count;++w)g.setX(l+w,y.getX(w)+h);l+=y.count,h+=v.getAttribute("position").count}}}const p=Object.keys(n[0].attributes);for(let r=0,l=p.length;r<l;r++){let h=!1;const g=p[r];if(!t.getAttribute(g)){const v=n[0].getAttribute(g);t.setAttribute(g,St(v,f)),h=!0}let _=0;const m=t.getAttribute(g);for(let v=0,y=n.length;v<y;v++){const x=n[v],w=!s&&!h&&a[v],b=x.getAttribute(g);w||ur(b,m,_),_+=b.count}}}function An(n,e,t){const i=n.index,a=n.attributes.position.count,o=i?i.count:a;let c=n.groups;c.length===0&&(c=[{count:o,start:0,materialIndex:0}]);let u=n.getAttribute("materialIndex");if(!u||u.count!==a){let p;t.length<=255?p=new Uint8Array(a):p=new Uint16Array(a),u=new d.BufferAttribute(p,1,!1),n.deleteAttribute("materialIndex"),n.setAttribute("materialIndex",u)}const f=u.array;for(let p=0;p<c.length;p++){const r=c[p],l=r.start,h=r.count,g=Math.min(h,o-l),_=Array.isArray(e)?e[r.materialIndex]:e,m=t.indexOf(_);for(let v=0;v<g;v++){let y=l+v;i&&(y=i.getX(y)),f[y]=m}}}function Tn(n,e){if(!n.index){const t=n.attributes.position.count,i=new Array(t);for(let s=0;s<t;s++)i[s]=s;n.setIndex(i)}if(!n.attributes.normal&&e&&e.includes("normal")&&n.computeVertexNormals(),!n.attributes.uv&&e&&e.includes("uv")){const t=n.attributes.position.count;n.setAttribute("uv",new d.BufferAttribute(new Float32Array(t*2),2,!1))}if(!n.attributes.uv2&&e&&e.includes("uv2")){const t=n.attributes.position.count;n.setAttribute("uv2",new d.BufferAttribute(new Float32Array(t*2),2,!1))}if(!n.attributes.tangent&&e&&e.includes("tangent"))if(n.attributes.uv&&n.attributes.normal)n.computeTangents();else{const t=n.attributes.position.count;n.setAttribute("tangent",new d.BufferAttribute(new Float32Array(t*4),4,!1))}if(!n.attributes.color&&e&&e.includes("color")){const t=n.attributes.position.count,i=new Float32Array(t*4);i.fill(1),n.setAttribute("color",new d.BufferAttribute(i,4))}}function ss(n){let e=0;if(n.byteLength!==0){const t=new Uint8Array(n);for(let i=0;i<n.byteLength;i++){const s=t[i];e=(e<<5)-e+s,e|=0}}return e}function _s(n){let e=n.uuid;const t=Object.values(n.attributes);n.index&&(t.push(n.index),e+=`index|${n.index.version}`);const i=Object.keys(t).sort();for(const s of i){const a=t[s];e+=`${s}_${a.version}|`}return e}function ys(n){const e=n.skeleton;return e?(e.boneTexture||e.computeBoneTexture(),`${ss(e.boneTexture.image.data.buffer)}_${e.boneTexture.uuid}`):null}class Sn{constructor(e=null){this.matrixWorld=new d.Matrix4,this.geometryHash=null,this.skeletonHash=null,this.primitiveCount=-1,e!==null&&this.updateFrom(e)}updateFrom(e){const t=e.geometry,i=(t.index?t.index.count:t.attributes.position.count)/3;this.matrixWorld.copy(e.matrixWorld),this.geometryHash=_s(t),this.primitiveCount=i,this.skeletonHash=ys(e)}didChange(e){const t=e.geometry,i=(t.index?t.index.count:t.attributes.position.count)/3;return!(this.matrixWorld.equals(e.matrixWorld)&&this.geometryHash===_s(t)&&this.skeletonHash===ys(e)&&this.primitiveCount===i)}}const De=new d.Vector3,Le=new d.Vector3,Ee=new d.Vector3,xs=new d.Vector4,Et=new d.Vector3,mi=new d.Vector3,ws=new d.Vector4,bs=new d.Vector4,Ft=new d.Matrix4,As=new d.Matrix4;function Ts(n,e,t){const i=n.skeleton,s=n.geometry,a=i.bones,o=i.boneInverses;ws.fromBufferAttribute(s.attributes.skinIndex,e),bs.fromBufferAttribute(s.attributes.skinWeight,e),Ft.elements.fill(0);for(let c=0;c<4;c++){const u=bs.getComponent(c);if(u!==0){const f=ws.getComponent(c);As.multiplyMatrices(a[f].matrixWorld,o[f]),Mn(Ft,As,u)}}return Ft.multiply(n.bindMatrix).premultiply(n.bindMatrixInverse),t.transformDirection(Ft),t}function gi(n,e,t,i,s){Et.set(0,0,0);for(let a=0,o=n.length;a<o;a++){const c=e[a],u=n[a];c!==0&&(mi.fromBufferAttribute(u,i),t?Et.addScaledVector(mi,c):Et.addScaledVector(mi.sub(s),c))}s.add(Et)}function Mn(n,e,t){const i=n.elements,s=e.elements;for(let a=0,o=s.length;a<o;a++)i[a]+=s[a]*t}function Cn(n){const{index:e,attributes:t}=n;if(e)for(let i=0,s=e.count;i<s;i+=3){const a=e.getX(i),o=e.getX(i+2);e.setX(i,o),e.setX(i+2,a)}else for(const i in t){const s=t[i],a=s.itemSize;for(let o=0,c=s.count;o<c;o+=3)for(let u=0;u<a;u++){const f=s.getComponent(o,u),p=s.getComponent(o+2,u);s.setComponent(o,u,p),s.setComponent(o+2,u,f)}}return n}function In(n,e={},t=new d.BufferGeometry){e={applyWorldTransforms:!0,attributes:[],...e};const i=n.geometry,s=e.applyWorldTransforms,a=e.attributes.includes("normal"),o=e.attributes.includes("tangent"),c=i.attributes,u=t.attributes;for(const y in t.attributes)(!e.attributes.includes(y)||!(y in i.attributes))&&t.deleteAttribute(y);!t.index&&i.index&&(t.index=i.index.clone()),u.position||t.setAttribute("position",St(c.position)),a&&!u.normal&&c.normal&&t.setAttribute("normal",St(c.normal)),o&&!u.tangent&&c.tangent&&t.setAttribute("tangent",St(c.tangent)),Ke(i.index,t.index),Ke(c.position,u.position),a&&Ke(c.normal,u.normal),o&&Ke(c.tangent,u.tangent);const f=c.position,p=a?c.normal:null,r=o?c.tangent:null,l=i.morphAttributes.position,h=i.morphAttributes.normal,g=i.morphAttributes.tangent,_=i.morphTargetsRelative,m=n.morphTargetInfluences,v=new d.Matrix3;v.getNormalMatrix(n.matrixWorld),i.index&&t.index.array.set(i.index.array);for(let y=0,x=c.position.count;y<x;y++)De.fromBufferAttribute(f,y),p&&Le.fromBufferAttribute(p,y),r&&(xs.fromBufferAttribute(r,y),Ee.fromBufferAttribute(r,y)),m&&(l&&gi(l,m,_,y,De),h&&gi(h,m,_,y,Le),g&&gi(g,m,_,y,Ee)),n.isSkinnedMesh&&(n.applyBoneTransform(y,De),p&&Ts(n,y,Le),r&&Ts(n,y,Ee)),s&&De.applyMatrix4(n.matrixWorld),u.position.setXYZ(y,De.x,De.y,De.z),p&&(s&&Le.applyNormalMatrix(v),u.normal.setXYZ(y,Le.x,Le.y,Le.z)),r&&(s&&Ee.transformDirection(n.matrixWorld),u.tangent.setXYZW(y,Ee.x,Ee.y,Ee.z,xs.w));for(const y in e.attributes){const x=e.attributes[y];x==="position"||x==="tangent"||x==="normal"||!(x in c)||(u[x]||t.setAttribute(x,St(c[x])),Ke(c[x],u[x]),ur(c[x],u[x]))}return n.matrixWorld.determinant()<0&&Cn(t),t}class Rn extends d.BufferGeometry{constructor(){super(),this.version=0,this.hash=null,this._diff=new Sn}isCompatible(e,t){const i=e.geometry;for(let s=0;s<t.length;s++){const a=t[s],o=i.attributes[a],c=this.attributes[a];if(o&&!Ke(o,c))return!1}return!0}updateFrom(e,t){const i=this._diff;return i.didChange(e)?(In(e,t,this),i.updateFrom(e),this.version++,this.hash=`${this.uuid}_${this.version}`,!0):!1}}const Bi=0,hr=1,fr=2;function Pn(n,e){for(let t=0,i=n.length;t<i;t++)n[t].traverseVisible(a=>{a.isMesh&&e(a)})}function Dn(n){const e=[];for(let t=0,i=n.length;t<i;t++){const s=n[t];Array.isArray(s.material)?e.push(...s.material):e.push(s.material)}return e}function Ln(n,e,t){if(n.length===0){e.setIndex(null);const i=e.attributes;for(const s in i)e.deleteAttribute(s);for(const s in t.attributes)e.setAttribute(t.attributes[s],new d.BufferAttribute(new Float32Array(0),4,!1))}else bn(n,t,e);for(const i in e.attributes)e.attributes[i].needsUpdate=!0}class En{constructor(e){this.objects=null,this.useGroups=!0,this.applyWorldTransforms=!0,this.generateMissingAttributes=!0,this.overwriteIndex=!0,this.attributes=["position","normal","color","tangent","uv","uv2"],this._intermediateGeometry=new Map,this._geometryMergeSets=new WeakMap,this._mergeOrder=[],this._dummyMesh=null,this.setObjects(e||[])}_getDummyMesh(){if(!this._dummyMesh){const e=new d.MeshBasicMaterial,t=new d.BufferGeometry;t.setAttribute("position",new d.BufferAttribute(new Float32Array(9),3)),this._dummyMesh=new d.Mesh(t,e)}return this._dummyMesh}_getMeshes(){const e=[];return Pn(this.objects,t=>{e.push(t)}),e.sort((t,i)=>t.uuid>i.uuid?1:t.uuid<i.uuid?-1:0),e.length===0&&e.push(this._getDummyMesh()),e}_updateIntermediateGeometries(){const{_intermediateGeometry:e}=this,t=this._getMeshes(),i=new Set(e.keys()),s={attributes:this.attributes,applyWorldTransforms:this.applyWorldTransforms};for(let a=0,o=t.length;a<o;a++){const c=t[a],u=c.uuid;i.delete(u);let f=e.get(u);(!f||!f.isCompatible(c,this.attributes))&&(f&&f.dispose(),f=new Rn,e.set(u,f)),f.updateFrom(c,s)&&this.generateMissingAttributes&&Tn(f,this.attributes)}i.forEach(a=>{e.delete(a)})}setObjects(e){Array.isArray(e)?this.objects=[...e]:this.objects=[e]}generate(e=new d.BufferGeometry){const{useGroups:t,overwriteIndex:i,_intermediateGeometry:s,_geometryMergeSets:a}=this,o=this._getMeshes(),c=[],u=[],f=a.get(e)||[];this._updateIntermediateGeometries();let p=!1;o.length!==f.length&&(p=!0);for(let l=0,h=o.length;l<h;l++){const g=o[l],_=s.get(g.uuid);u.push(_);const m=f[l];!m||m.uuid!==_.uuid?(c.push(!1),p=!0):m.version!==_.version?c.push(!1):c.push(!0)}Ln(u,e,{useGroups:t,forceUpdate:p,skipAssigningAttributes:c,overwriteIndex:i}),p&&e.dispose(),a.set(e,u.map(l=>({version:l.version,uuid:l.uuid})));let r=Bi;return p?r=fr:c.includes(!1)&&(r=hr),{changeType:r,materials:Dn(o),geometry:e}}}function Fn(n){const e=new Set;for(let t=0,i=n.length;t<i;t++){const s=n[t];for(const a in s){const o=s[a];o&&o.isTexture&&e.add(o)}}return Array.from(e)}function Bn(n){const e=[],t=new Set;for(let s=0,a=n.length;s<a;s++)n[s].traverse(o=>{o.visible&&(o.isRectAreaLight||o.isSpotLight||o.isPointLight||o.isDirectionalLight)&&(e.push(o),o.iesMap&&t.add(o.iesMap))});const i=Array.from(t).sort((s,a)=>s.uuid<a.uuid?1:s.uuid>a.uuid?-1:0);return{lights:e,iesTextures:i}}class kn{get initialized(){return!!this.bvh}constructor(e){this.bvhOptions={},this.attributes=["position","normal","tangent","color","uv","uv2"],this.generateBVH=!0,this.bvh=null,this.geometry=new d.BufferGeometry,this.staticGeometryGenerator=new En(e),this._bvhWorker=null,this._pendingGenerate=null,this._buildAsync=!1}setObjects(e){this.staticGeometryGenerator.setObjects(e)}setBVHWorker(e){this._bvhWorker=e}async generateAsync(e=null){if(!this._bvhWorker)throw new Error('PathTracingSceneGenerator: "setBVHWorker" must be called before "generateAsync" can be called.');if(this.bvh instanceof Promise)return this._pendingGenerate||(this._pendingGenerate=new Promise(async()=>(await this.bvh,this._pendingGenerate=null,this.generateAsync(e)))),this._pendingGenerate;{this._buildAsync=!0;const t=this.generate(e);return this._buildAsync=!1,t.bvh=this.bvh=await t.bvh,t}}generate(e=null){const{staticGeometryGenerator:t,geometry:i,attributes:s}=this,a=t.objects;t.attributes=s,a.forEach(r=>{r.traverse(l=>{l.isSkinnedMesh&&l.skeleton&&l.skeleton.update()})});const o=t.generate(i),c=o.materials,u=Fn(c),{lights:f,iesTextures:p}=Bn(a);if(o.changeType!==Bi&&An(i,c,c),this.generateBVH){if(this.bvh instanceof Promise)throw new Error("PathTracingSceneGenerator: BVH is already building asynchronously.");if(o.changeType===fr){const r={strategy:Ce.SAH,maxLeafTris:1,indirect:!0,onProgress:e,...this.bvhOptions};this._buildAsync?this.bvh=this._bvhWorker.generate(i,r):this.bvh=new Ce.MeshBVH(i,r)}else o.changeType===hr&&this.bvh.refit()}return{bvhChanged:o.changeType!==Bi,bvh:this.bvh,lights:f,iesTextures:p,geometry:i,materials:c,textures:u,objects:a}}}class rs extends d.ShaderMaterial{set needsUpdate(e){super.needsUpdate=!0,this.dispatchEvent({type:"recompilation"})}constructor(e){super(e);for(const t in this.uniforms)Object.defineProperty(this,t,{get(){return this.uniforms[t].value},set(i){this.uniforms[t].value=i}})}setDefine(e,t=void 0){if(t==null){if(e in this.defines)return delete this.defines[e],this.needsUpdate=!0,!0}else if(this.defines[e]!==t)return this.defines[e]=t,this.needsUpdate=!0,!0;return!1}}class On extends rs{constructor(e){super({blending:d.NoBlending,uniforms:{target1:{value:null},target2:{value:null},opacity:{value:1}},vertexShader:`
1
+ "use strict";var Gr=Object.create;var pi=Object.defineProperty;var qr=Object.getOwnPropertyDescriptor;var jr=Object.getOwnPropertyNames;var Yr=Object.getPrototypeOf,Qr=Object.prototype.hasOwnProperty;var Zr=(n,e,t)=>e in n?pi(n,e,{enumerable:!0,configurable:!0,writable:!0,value:t}):n[e]=t;var Xr=(n,e,t,i)=>{if(e&&typeof e=="object"||typeof e=="function")for(let s of jr(e))!Qr.call(n,s)&&s!==t&&pi(n,s,{get:()=>e[s],enumerable:!(i=qr(e,s))||i.enumerable});return n};var Kr=(n,e,t)=>(t=n!=null?Gr(Yr(n)):{},Xr(e||!n||!n.__esModule?pi(t,"default",{value:n,enumerable:!0}):t,n));var L=(n,e,t)=>(Zr(n,typeof e!="symbol"?e+"":e,t),t),ms=(n,e,t)=>{if(!e.has(n))throw TypeError("Cannot "+t)};var z=(n,e,t)=>(ms(n,e,"read from private field"),t?t.call(n):e.get(n)),be=(n,e,t)=>{if(e.has(n))throw TypeError("Cannot add the same private member more than once");e instanceof WeakSet?e.add(n):e.set(n,t)},ue=(n,e,t,i)=>(ms(n,e,"write to private field"),i?i.call(n,t):e.set(n,t),t);Object.defineProperty(exports,Symbol.toStringTag,{value:"Module"});const d=require("three"),Jr=require("three/examples/jsm/loaders/HDRLoader.js"),gs=require("three/examples/jsm/postprocessing/RenderPass"),vs=require("three/examples/jsm/postprocessing/OutlinePass"),$r=require("three/examples/jsm/postprocessing/ShaderPass"),en=require("three/examples/jsm/shaders/FXAAShader"),tn=require("three/examples/jsm/postprocessing/UnrealBloomPass"),sn=require("three/examples/jsm/controls/OrbitControls"),rn=require("three/examples/jsm/postprocessing/OutputPass"),nn=require("three/examples/jsm/postprocessing/EffectComposer"),fe=require("three/examples/jsm/renderers/CSS2DRenderer"),on=require("three/examples/jsm/loaders/FontLoader"),ss=require("three/examples/jsm/loaders/GLTFLoader.js"),an=require("three/examples/jsm/libs/meshopt_decoder.module.js"),ln=require("three/examples/jsm/loaders/DRACOLoader.js"),cn=require("three/examples/jsm/loaders/GLTFLoader"),un=require("three/examples/jsm/loaders/DRACOLoader"),hn=require("three/examples/jsm/exporters/DRACOExporter"),fn=require("three/examples/jsm/exporters/GLTFExporter"),dn=require("three/examples/jsm/utils/SkeletonUtils.js"),pn=require("three/examples/jsm/lines/Line2.js"),mn=require("three/examples/jsm/lines/LineMaterial.js"),_s=require("three/examples/jsm/lines/LineGeometry.js"),gn=require("three/examples/jsm/renderers/CSS3DRenderer");require("three/examples/jsm/utils/BufferGeometryUtils");const Ce=require("three-mesh-bvh"),ot=require("three/examples/jsm/postprocessing/Pass.js");var at=typeof document<"u"?document.currentScript:null;function vn(n){const e=Object.create(null,{[Symbol.toStringTag]:{value:"Module"}});if(n){for(const t in n)if(t!=="default"){const i=Object.getOwnPropertyDescriptor(n,t);Object.defineProperty(e,t,i.get?i:{enumerable:!0,get:()=>n[t]})}}return e.default=n,Object.freeze(e)}const mi=vn(dn);function hr(n,e,t=0){if(n.isInterleavedBufferAttribute){const i=n.itemSize;for(let s=0,a=n.count;s<a;s++){const o=s+t;e.setX(o,n.getX(s)),i>=2&&e.setY(o,n.getY(s)),i>=3&&e.setZ(o,n.getZ(s)),i>=4&&e.setW(o,n.getW(s))}}else{const i=e.array,s=i.constructor,a=i.BYTES_PER_ELEMENT*n.itemSize*t;new s(i.buffer,a,n.array.length).set(n.array)}}function St(n,e=null){const t=n.array.constructor,i=n.normalized,s=n.itemSize,a=e===null?n.count:e;return new d.BufferAttribute(new t(s*a),s,i)}function Je(n,e){if(!n&&!e)return!0;if(!!n!=!!e)return!1;const t=n.count===e.count,i=n.normalized===e.normalized,s=n.array.constructor===e.array.constructor,a=n.itemSize===e.itemSize;return!(!t||!i||!s||!a)}function _n(n){const e=n[0].index!==null,t=new Set(Object.keys(n[0].attributes));if(!n[0].getAttribute("position"))throw new Error("StaticGeometryGenerator: position attribute is required.");for(let i=0;i<n.length;++i){const s=n[i];let a=0;if(e!==(s.index!==null))throw new Error("StaticGeometryGenerator: All geometries must have compatible attributes; make sure index attribute exists among all geometries, or in none of them.");for(const o in s.attributes){if(!t.has(o))throw new Error('StaticGeometryGenerator: All geometries must have compatible attributes; make sure "'+o+'" attribute exists among all geometries, or in none of them.');a++}if(a!==t.size)throw new Error("StaticGeometryGenerator: All geometries must have the same number of attributes.")}}function yn(n){let e=0;for(let t=0,i=n.length;t<i;t++)e+=n[t].getIndex().count;return e}function xn(n){let e=0;for(let t=0,i=n.length;t<i;t++)e+=n[t].getAttribute("position").count;return e}function wn(n,e,t){n.index&&n.index.count!==e&&n.setIndex(null);const i=n.attributes;for(const s in i)i[s].count!==t&&n.deleteAttribute(s)}function bn(n,e={},t=new d.BufferGeometry){const{useGroups:i=!1,forceUpdate:s=!1,skipAssigningAttributes:a=[],overwriteIndex:o=!0}=e;_n(n);const c=n[0].index!==null,u=c?yn(n):-1,f=xn(n);if(wn(t,u,f),i){let r=0;for(let l=0,h=n.length;l<h;l++){const g=n[l];let _;c?_=g.getIndex().count:_=g.getAttribute("position").count,t.addGroup(r,_,l),r+=_}}if(c){let r=!1;if(t.index||(t.setIndex(new d.BufferAttribute(new Uint32Array(u),1,!1)),r=!0),r||o){let l=0,h=0;const g=t.getIndex();for(let _=0,m=n.length;_<m;_++){const v=n[_],y=v.getIndex();if(!(!s&&!r&&a[_]))for(let w=0;w<y.count;++w)g.setX(l+w,y.getX(w)+h);l+=y.count,h+=v.getAttribute("position").count}}}const p=Object.keys(n[0].attributes);for(let r=0,l=p.length;r<l;r++){let h=!1;const g=p[r];if(!t.getAttribute(g)){const v=n[0].getAttribute(g);t.setAttribute(g,St(v,f)),h=!0}let _=0;const m=t.getAttribute(g);for(let v=0,y=n.length;v<y;v++){const x=n[v],w=!s&&!h&&a[v],b=x.getAttribute(g);w||hr(b,m,_),_+=b.count}}}function An(n,e,t){const i=n.index,a=n.attributes.position.count,o=i?i.count:a;let c=n.groups;c.length===0&&(c=[{count:o,start:0,materialIndex:0}]);let u=n.getAttribute("materialIndex");if(!u||u.count!==a){let p;t.length<=255?p=new Uint8Array(a):p=new Uint16Array(a),u=new d.BufferAttribute(p,1,!1),n.deleteAttribute("materialIndex"),n.setAttribute("materialIndex",u)}const f=u.array;for(let p=0;p<c.length;p++){const r=c[p],l=r.start,h=r.count,g=Math.min(h,o-l),_=Array.isArray(e)?e[r.materialIndex]:e,m=t.indexOf(_);for(let v=0;v<g;v++){let y=l+v;i&&(y=i.getX(y)),f[y]=m}}}function Tn(n,e){if(!n.index){const t=n.attributes.position.count,i=new Array(t);for(let s=0;s<t;s++)i[s]=s;n.setIndex(i)}if(!n.attributes.normal&&e&&e.includes("normal")&&n.computeVertexNormals(),!n.attributes.uv&&e&&e.includes("uv")){const t=n.attributes.position.count;n.setAttribute("uv",new d.BufferAttribute(new Float32Array(t*2),2,!1))}if(!n.attributes.uv2&&e&&e.includes("uv2")){const t=n.attributes.position.count;n.setAttribute("uv2",new d.BufferAttribute(new Float32Array(t*2),2,!1))}if(!n.attributes.tangent&&e&&e.includes("tangent"))if(n.attributes.uv&&n.attributes.normal)n.computeTangents();else{const t=n.attributes.position.count;n.setAttribute("tangent",new d.BufferAttribute(new Float32Array(t*4),4,!1))}if(!n.attributes.color&&e&&e.includes("color")){const t=n.attributes.position.count,i=new Float32Array(t*4);i.fill(1),n.setAttribute("color",new d.BufferAttribute(i,4))}}function rs(n){let e=0;if(n.byteLength!==0){const t=new Uint8Array(n);for(let i=0;i<n.byteLength;i++){const s=t[i];e=(e<<5)-e+s,e|=0}}return e}function ys(n){let e=n.uuid;const t=Object.values(n.attributes);n.index&&(t.push(n.index),e+=`index|${n.index.version}`);const i=Object.keys(t).sort();for(const s of i){const a=t[s];e+=`${s}_${a.version}|`}return e}function xs(n){const e=n.skeleton;return e?(e.boneTexture||e.computeBoneTexture(),`${rs(e.boneTexture.image.data.buffer)}_${e.boneTexture.uuid}`):null}class Sn{constructor(e=null){this.matrixWorld=new d.Matrix4,this.geometryHash=null,this.skeletonHash=null,this.primitiveCount=-1,e!==null&&this.updateFrom(e)}updateFrom(e){const t=e.geometry,i=(t.index?t.index.count:t.attributes.position.count)/3;this.matrixWorld.copy(e.matrixWorld),this.geometryHash=ys(t),this.primitiveCount=i,this.skeletonHash=xs(e)}didChange(e){const t=e.geometry,i=(t.index?t.index.count:t.attributes.position.count)/3;return!(this.matrixWorld.equals(e.matrixWorld)&&this.geometryHash===ys(t)&&this.skeletonHash===xs(e)&&this.primitiveCount===i)}}const De=new d.Vector3,Le=new d.Vector3,Ee=new d.Vector3,ws=new d.Vector4,Et=new d.Vector3,gi=new d.Vector3,bs=new d.Vector4,As=new d.Vector4,Ft=new d.Matrix4,Ts=new d.Matrix4;function Ss(n,e,t){const i=n.skeleton,s=n.geometry,a=i.bones,o=i.boneInverses;bs.fromBufferAttribute(s.attributes.skinIndex,e),As.fromBufferAttribute(s.attributes.skinWeight,e),Ft.elements.fill(0);for(let c=0;c<4;c++){const u=As.getComponent(c);if(u!==0){const f=bs.getComponent(c);Ts.multiplyMatrices(a[f].matrixWorld,o[f]),Mn(Ft,Ts,u)}}return Ft.multiply(n.bindMatrix).premultiply(n.bindMatrixInverse),t.transformDirection(Ft),t}function vi(n,e,t,i,s){Et.set(0,0,0);for(let a=0,o=n.length;a<o;a++){const c=e[a],u=n[a];c!==0&&(gi.fromBufferAttribute(u,i),t?Et.addScaledVector(gi,c):Et.addScaledVector(gi.sub(s),c))}s.add(Et)}function Mn(n,e,t){const i=n.elements,s=e.elements;for(let a=0,o=s.length;a<o;a++)i[a]+=s[a]*t}function Cn(n){const{index:e,attributes:t}=n;if(e)for(let i=0,s=e.count;i<s;i+=3){const a=e.getX(i),o=e.getX(i+2);e.setX(i,o),e.setX(i+2,a)}else for(const i in t){const s=t[i],a=s.itemSize;for(let o=0,c=s.count;o<c;o+=3)for(let u=0;u<a;u++){const f=s.getComponent(o,u),p=s.getComponent(o+2,u);s.setComponent(o,u,p),s.setComponent(o+2,u,f)}}return n}function In(n,e={},t=new d.BufferGeometry){e={applyWorldTransforms:!0,attributes:[],...e};const i=n.geometry,s=e.applyWorldTransforms,a=e.attributes.includes("normal"),o=e.attributes.includes("tangent"),c=i.attributes,u=t.attributes;for(const y in t.attributes)(!e.attributes.includes(y)||!(y in i.attributes))&&t.deleteAttribute(y);!t.index&&i.index&&(t.index=i.index.clone()),u.position||t.setAttribute("position",St(c.position)),a&&!u.normal&&c.normal&&t.setAttribute("normal",St(c.normal)),o&&!u.tangent&&c.tangent&&t.setAttribute("tangent",St(c.tangent)),Je(i.index,t.index),Je(c.position,u.position),a&&Je(c.normal,u.normal),o&&Je(c.tangent,u.tangent);const f=c.position,p=a?c.normal:null,r=o?c.tangent:null,l=i.morphAttributes.position,h=i.morphAttributes.normal,g=i.morphAttributes.tangent,_=i.morphTargetsRelative,m=n.morphTargetInfluences,v=new d.Matrix3;v.getNormalMatrix(n.matrixWorld),i.index&&t.index.array.set(i.index.array);for(let y=0,x=c.position.count;y<x;y++)De.fromBufferAttribute(f,y),p&&Le.fromBufferAttribute(p,y),r&&(ws.fromBufferAttribute(r,y),Ee.fromBufferAttribute(r,y)),m&&(l&&vi(l,m,_,y,De),h&&vi(h,m,_,y,Le),g&&vi(g,m,_,y,Ee)),n.isSkinnedMesh&&(n.applyBoneTransform(y,De),p&&Ss(n,y,Le),r&&Ss(n,y,Ee)),s&&De.applyMatrix4(n.matrixWorld),u.position.setXYZ(y,De.x,De.y,De.z),p&&(s&&Le.applyNormalMatrix(v),u.normal.setXYZ(y,Le.x,Le.y,Le.z)),r&&(s&&Ee.transformDirection(n.matrixWorld),u.tangent.setXYZW(y,Ee.x,Ee.y,Ee.z,ws.w));for(const y in e.attributes){const x=e.attributes[y];x==="position"||x==="tangent"||x==="normal"||!(x in c)||(u[x]||t.setAttribute(x,St(c[x])),Je(c[x],u[x]),hr(c[x],u[x]))}return n.matrixWorld.determinant()<0&&Cn(t),t}class Rn extends d.BufferGeometry{constructor(){super(),this.version=0,this.hash=null,this._diff=new Sn}isCompatible(e,t){const i=e.geometry;for(let s=0;s<t.length;s++){const a=t[s],o=i.attributes[a],c=this.attributes[a];if(o&&!Je(o,c))return!1}return!0}updateFrom(e,t){const i=this._diff;return i.didChange(e)?(In(e,t,this),i.updateFrom(e),this.version++,this.hash=`${this.uuid}_${this.version}`,!0):!1}}const ki=0,fr=1,dr=2;function Pn(n,e){for(let t=0,i=n.length;t<i;t++)n[t].traverseVisible(a=>{a.isMesh&&e(a)})}function Dn(n){const e=[];for(let t=0,i=n.length;t<i;t++){const s=n[t];Array.isArray(s.material)?e.push(...s.material):e.push(s.material)}return e}function Ln(n,e,t){if(n.length===0){e.setIndex(null);const i=e.attributes;for(const s in i)e.deleteAttribute(s);for(const s in t.attributes)e.setAttribute(t.attributes[s],new d.BufferAttribute(new Float32Array(0),4,!1))}else bn(n,t,e);for(const i in e.attributes)e.attributes[i].needsUpdate=!0}class En{constructor(e){this.objects=null,this.useGroups=!0,this.applyWorldTransforms=!0,this.generateMissingAttributes=!0,this.overwriteIndex=!0,this.attributes=["position","normal","color","tangent","uv","uv2"],this._intermediateGeometry=new Map,this._geometryMergeSets=new WeakMap,this._mergeOrder=[],this._dummyMesh=null,this.setObjects(e||[])}_getDummyMesh(){if(!this._dummyMesh){const e=new d.MeshBasicMaterial,t=new d.BufferGeometry;t.setAttribute("position",new d.BufferAttribute(new Float32Array(9),3)),this._dummyMesh=new d.Mesh(t,e)}return this._dummyMesh}_getMeshes(){const e=[];return Pn(this.objects,t=>{e.push(t)}),e.sort((t,i)=>t.uuid>i.uuid?1:t.uuid<i.uuid?-1:0),e.length===0&&e.push(this._getDummyMesh()),e}_updateIntermediateGeometries(){const{_intermediateGeometry:e}=this,t=this._getMeshes(),i=new Set(e.keys()),s={attributes:this.attributes,applyWorldTransforms:this.applyWorldTransforms};for(let a=0,o=t.length;a<o;a++){const c=t[a],u=c.uuid;i.delete(u);let f=e.get(u);(!f||!f.isCompatible(c,this.attributes))&&(f&&f.dispose(),f=new Rn,e.set(u,f)),f.updateFrom(c,s)&&this.generateMissingAttributes&&Tn(f,this.attributes)}i.forEach(a=>{e.delete(a)})}setObjects(e){Array.isArray(e)?this.objects=[...e]:this.objects=[e]}generate(e=new d.BufferGeometry){const{useGroups:t,overwriteIndex:i,_intermediateGeometry:s,_geometryMergeSets:a}=this,o=this._getMeshes(),c=[],u=[],f=a.get(e)||[];this._updateIntermediateGeometries();let p=!1;o.length!==f.length&&(p=!0);for(let l=0,h=o.length;l<h;l++){const g=o[l],_=s.get(g.uuid);u.push(_);const m=f[l];!m||m.uuid!==_.uuid?(c.push(!1),p=!0):m.version!==_.version?c.push(!1):c.push(!0)}Ln(u,e,{useGroups:t,forceUpdate:p,skipAssigningAttributes:c,overwriteIndex:i}),p&&e.dispose(),a.set(e,u.map(l=>({version:l.version,uuid:l.uuid})));let r=ki;return p?r=dr:c.includes(!1)&&(r=fr),{changeType:r,materials:Dn(o),geometry:e}}}function Fn(n){const e=new Set;for(let t=0,i=n.length;t<i;t++){const s=n[t];for(const a in s){const o=s[a];o&&o.isTexture&&e.add(o)}}return Array.from(e)}function Bn(n){const e=[],t=new Set;for(let s=0,a=n.length;s<a;s++)n[s].traverse(o=>{o.visible&&(o.isRectAreaLight||o.isSpotLight||o.isPointLight||o.isDirectionalLight)&&(e.push(o),o.iesMap&&t.add(o.iesMap))});const i=Array.from(t).sort((s,a)=>s.uuid<a.uuid?1:s.uuid>a.uuid?-1:0);return{lights:e,iesTextures:i}}class kn{get initialized(){return!!this.bvh}constructor(e){this.bvhOptions={},this.attributes=["position","normal","tangent","color","uv","uv2"],this.generateBVH=!0,this.bvh=null,this.geometry=new d.BufferGeometry,this.staticGeometryGenerator=new En(e),this._bvhWorker=null,this._pendingGenerate=null,this._buildAsync=!1}setObjects(e){this.staticGeometryGenerator.setObjects(e)}setBVHWorker(e){this._bvhWorker=e}async generateAsync(e=null){if(!this._bvhWorker)throw new Error('PathTracingSceneGenerator: "setBVHWorker" must be called before "generateAsync" can be called.');if(this.bvh instanceof Promise)return this._pendingGenerate||(this._pendingGenerate=new Promise(async()=>(await this.bvh,this._pendingGenerate=null,this.generateAsync(e)))),this._pendingGenerate;{this._buildAsync=!0;const t=this.generate(e);return this._buildAsync=!1,t.bvh=this.bvh=await t.bvh,t}}generate(e=null){const{staticGeometryGenerator:t,geometry:i,attributes:s}=this,a=t.objects;t.attributes=s,a.forEach(r=>{r.traverse(l=>{l.isSkinnedMesh&&l.skeleton&&l.skeleton.update()})});const o=t.generate(i),c=o.materials,u=Fn(c),{lights:f,iesTextures:p}=Bn(a);if(o.changeType!==ki&&An(i,c,c),this.generateBVH){if(this.bvh instanceof Promise)throw new Error("PathTracingSceneGenerator: BVH is already building asynchronously.");if(o.changeType===dr){const r={strategy:Ce.SAH,maxLeafTris:1,indirect:!0,onProgress:e,...this.bvhOptions};this._buildAsync?this.bvh=this._bvhWorker.generate(i,r):this.bvh=new Ce.MeshBVH(i,r)}else o.changeType===fr&&this.bvh.refit()}return{bvhChanged:o.changeType!==ki,bvh:this.bvh,lights:f,iesTextures:p,geometry:i,materials:c,textures:u,objects:a}}}class ns extends d.ShaderMaterial{set needsUpdate(e){super.needsUpdate=!0,this.dispatchEvent({type:"recompilation"})}constructor(e){super(e);for(const t in this.uniforms)Object.defineProperty(this,t,{get(){return this.uniforms[t].value},set(i){this.uniforms[t].value=i}})}setDefine(e,t=void 0){if(t==null){if(e in this.defines)return delete this.defines[e],this.needsUpdate=!0,!0}else if(this.defines[e]!==t)return this.defines[e]=t,this.needsUpdate=!0,!0;return!1}}class On extends ns{constructor(e){super({blending:d.NoBlending,uniforms:{target1:{value:null},target2:{value:null},opacity:{value:1}},vertexShader:`
2
2
 
3
3
  varying vec2 vUv;
4
4
 
@@ -88,7 +88,7 @@
88
88
  return SOBOL_FACTOR * ${t}( result >> 8 );
89
89
 
90
90
  }
91
- `}const dr=`
91
+ `}const pr=`
92
92
 
93
93
  // Utils
94
94
  const float SOBOL_FACTOR = 1.0 / 16777216.0;
@@ -232,7 +232,7 @@
232
232
  ${kt(3)}
233
233
  ${kt(4)}
234
234
 
235
- `;class Un extends rs{constructor(){super({blending:d.NoBlending,uniforms:{resolution:{value:new d.Vector2}},vertexShader:`
235
+ `;class Un extends ns{constructor(){super({blending:d.NoBlending,uniforms:{resolution:{value:new d.Vector2}},vertexShader:`
236
236
 
237
237
  varying vec2 vUv;
238
238
  void main() {
@@ -243,7 +243,7 @@
243
243
  }
244
244
  `,fragmentShader:`
245
245
 
246
- ${dr}
246
+ ${pr}
247
247
  ${zn}
248
248
 
249
249
  varying vec2 vUv;
@@ -254,7 +254,7 @@
254
254
  gl_FragColor = generateSobolPoint( index );
255
255
 
256
256
  }
257
- `})}}class Hn{generate(e,t=256){const i=new d.WebGLRenderTarget(t,t,{type:d.FloatType,format:d.RGBAFormat,minFilter:d.NearestFilter,magFilter:d.NearestFilter,generateMipmaps:!1}),s=e.getRenderTarget();e.setRenderTarget(i);const a=new nt.FullScreenQuad(new Un);return a.material.resolution.set(t,t),a.render(e),e.setRenderTarget(s),a.dispose(),i}}class Nn extends d.PerspectiveCamera{set bokehSize(e){this.fStop=this.getFocalLength()/e}get bokehSize(){return this.getFocalLength()/this.fStop}constructor(...e){super(...e),this.fStop=1.4,this.apertureBlades=0,this.apertureRotation=0,this.focusDistance=25,this.anamorphicRatio=1}copy(e,t){return super.copy(e,t),this.fStop=e.fStop,this.apertureBlades=e.apertureBlades,this.apertureRotation=e.apertureRotation,this.focusDistance=e.focusDistance,this.anamorphicRatio=e.anamorphicRatio,this}}class Wn{constructor(){this.bokehSize=0,this.apertureBlades=0,this.apertureRotation=0,this.focusDistance=10,this.anamorphicRatio=1}updateFrom(e){e instanceof Nn?(this.bokehSize=e.bokehSize,this.apertureBlades=e.apertureBlades,this.apertureRotation=e.apertureRotation,this.focusDistance=e.focusDistance,this.anamorphicRatio=e.anamorphicRatio):(this.bokehSize=0,this.apertureRotation=0,this.apertureBlades=0,this.focusDistance=10,this.anamorphicRatio=1)}}function vi(n){const e=new Uint16Array(n.length);for(let t=0,i=n.length;t<i;++t)e[t]=d.DataUtils.toHalfFloat(n[t]);return e}function Ss(n,e,t=0,i=n.length){let s=t,a=t+i-1;for(;s<a;){const o=s+a>>1;n[o]<e?s=o+1:a=o}return s-t}function Gn(n,e,t){return .2126*n+.7152*e+.0722*t}function qn(n,e=d.HalfFloatType){const t=n.clone();t.source=new d.Source({...t.image});const{width:i,height:s,data:a}=t.image;let o=a;if(t.type!==e){e===d.HalfFloatType?o=new Uint16Array(a.length):o=new Float32Array(a.length);let c;a instanceof Int8Array||a instanceof Int16Array||a instanceof Int32Array?c=2**(8*a.BYTES_PER_ELEMENT-1)-1:c=2**(8*a.BYTES_PER_ELEMENT)-1;for(let u=0,f=a.length;u<f;u++){let p=a[u];t.type===d.HalfFloatType&&(p=d.DataUtils.fromHalfFloat(a[u])),t.type!==d.FloatType&&t.type!==d.HalfFloatType&&(p/=c),e===d.HalfFloatType&&(o[u]=d.DataUtils.toHalfFloat(p))}t.image.data=o,t.type=e}if(t.flipY){const c=o;o=o.slice();for(let u=0;u<s;u++)for(let f=0;f<i;f++){const p=s-u-1,r=4*(u*i+f),l=4*(p*i+f);o[l+0]=c[r+0],o[l+1]=c[r+1],o[l+2]=c[r+2],o[l+3]=c[r+3]}t.flipY=!1,t.image.data=o}return t}class jn{constructor(){const e=new d.DataTexture(vi(new Float32Array([0,0,0,0])),1,1);e.type=d.HalfFloatType,e.format=d.RGBAFormat,e.minFilter=d.LinearFilter,e.magFilter=d.LinearFilter,e.wrapS=d.RepeatWrapping,e.wrapT=d.RepeatWrapping,e.generateMipmaps=!1,e.needsUpdate=!0;const t=new d.DataTexture(vi(new Float32Array([0,1])),1,2);t.type=d.HalfFloatType,t.format=d.RedFormat,t.minFilter=d.LinearFilter,t.magFilter=d.LinearFilter,t.generateMipmaps=!1,t.needsUpdate=!0;const i=new d.DataTexture(vi(new Float32Array([0,0,1,1])),2,2);i.type=d.HalfFloatType,i.format=d.RedFormat,i.minFilter=d.LinearFilter,i.magFilter=d.LinearFilter,i.generateMipmaps=!1,i.needsUpdate=!0,this.map=e,this.marginalWeights=t,this.conditionalWeights=i,this.totalSum=0}dispose(){this.marginalWeights.dispose(),this.conditionalWeights.dispose(),this.map.dispose()}updateFrom(e){const t=qn(e);t.wrapS=d.RepeatWrapping,t.wrapT=d.ClampToEdgeWrapping;const{width:i,height:s,data:a}=t.image,o=new Float32Array(i*s),c=new Float32Array(i*s),u=new Float32Array(s),f=new Float32Array(s);let p=0,r=0;for(let m=0;m<s;m++){let v=0;for(let y=0;y<i;y++){const x=m*i+y,w=d.DataUtils.fromHalfFloat(a[4*x+0]),b=d.DataUtils.fromHalfFloat(a[4*x+1]),A=d.DataUtils.fromHalfFloat(a[4*x+2]),T=Gn(w,b,A);v+=T,p+=T,o[x]=T,c[x]=v}if(v!==0)for(let y=m*i,x=m*i+i;y<x;y++)o[y]/=v,c[y]/=v;r+=v,u[m]=v,f[m]=r}if(r!==0)for(let m=0,v=u.length;m<v;m++)u[m]/=r,f[m]/=r;const l=new Uint16Array(s),h=new Uint16Array(i*s);for(let m=0;m<s;m++){const v=(m+1)/s,y=Ss(f,v);l[m]=d.DataUtils.toHalfFloat((y+.5)/s)}for(let m=0;m<s;m++)for(let v=0;v<i;v++){const y=m*i+v,x=(v+1)/i,w=Ss(c,x,m*i,i);h[y]=d.DataUtils.toHalfFloat((w+.5)/i)}this.dispose();const{marginalWeights:g,conditionalWeights:_}=this;g.image={width:s,height:1,data:l},g.needsUpdate=!0,_.image={width:i,height:s,data:h},_.needsUpdate=!0,this.totalSum=p,this.map=t}}const _i=6,Yn=0,Qn=1,Zn=2,Xn=3,Kn=4,ne=new d.Vector3,Z=new d.Vector3,Ms=new d.Matrix4,ze=new d.Quaternion,Cs=new d.Vector3,Ve=new d.Vector3,Jn=new d.Vector3(0,1,0);class $n{constructor(){const e=new d.DataTexture(new Float32Array(4),1,1);e.format=d.RGBAFormat,e.type=d.FloatType,e.wrapS=d.ClampToEdgeWrapping,e.wrapT=d.ClampToEdgeWrapping,e.generateMipmaps=!1,e.minFilter=d.NearestFilter,e.magFilter=d.NearestFilter,this.tex=e,this.count=0}updateFrom(e,t=[]){const i=this.tex,s=Math.max(e.length*_i,1),a=Math.ceil(Math.sqrt(s));i.image.width!==a&&(i.dispose(),i.image.data=new Float32Array(a*a*4),i.image.width=a,i.image.height=a);const o=i.image.data;for(let u=0,f=e.length;u<f;u++){const p=e[u],r=u*_i*4;let l=0;for(let g=0;g<_i*4;g++)o[r+g]=0;p.getWorldPosition(Z),o[r+l++]=Z.x,o[r+l++]=Z.y,o[r+l++]=Z.z;let h=Yn;if(p.isRectAreaLight&&p.isCircular?h=Qn:p.isSpotLight?h=Zn:p.isDirectionalLight?h=Xn:p.isPointLight&&(h=Kn),o[r+l++]=h,o[r+l++]=p.color.r,o[r+l++]=p.color.g,o[r+l++]=p.color.b,o[r+l++]=p.intensity,p.getWorldQuaternion(ze),p.isRectAreaLight)ne.set(p.width,0,0).applyQuaternion(ze),o[r+l++]=ne.x,o[r+l++]=ne.y,o[r+l++]=ne.z,l++,Z.set(0,p.height,0).applyQuaternion(ze),o[r+l++]=Z.x,o[r+l++]=Z.y,o[r+l++]=Z.z,o[r+l++]=ne.cross(Z).length()*(p.isCircular?Math.PI/4:1);else if(p.isSpotLight){const g=p.radius||0;Cs.setFromMatrixPosition(p.matrixWorld),Ve.setFromMatrixPosition(p.target.matrixWorld),Ms.lookAt(Cs,Ve,Jn),ze.setFromRotationMatrix(Ms),ne.set(1,0,0).applyQuaternion(ze),o[r+l++]=ne.x,o[r+l++]=ne.y,o[r+l++]=ne.z,l++,Z.set(0,1,0).applyQuaternion(ze),o[r+l++]=Z.x,o[r+l++]=Z.y,o[r+l++]=Z.z,o[r+l++]=Math.PI*g*g,o[r+l++]=g,o[r+l++]=p.decay,o[r+l++]=p.distance,o[r+l++]=Math.cos(p.angle),o[r+l++]=Math.cos(p.angle*(1-p.penumbra)),o[r+l++]=p.iesMap?t.indexOf(p.iesMap):-1}else if(p.isPointLight){const g=ne.setFromMatrixPosition(p.matrixWorld);o[r+l++]=g.x,o[r+l++]=g.y,o[r+l++]=g.z,l++,l+=4,l+=1,o[r+l++]=p.decay,o[r+l++]=p.distance}else if(p.isDirectionalLight){const g=ne.setFromMatrixPosition(p.matrixWorld),_=Z.setFromMatrixPosition(p.target.matrixWorld);Ve.subVectors(g,_).normalize(),o[r+l++]=Ve.x,o[r+l++]=Ve.y,o[r+l++]=Ve.z}}this.count=e.length;const c=ss(o.buffer);return this.hash!==c?(this.hash=c,i.needsUpdate=!0,!0):!1}}function Is(n,e,t,i,s){if(e>i)throw new Error;const a=n.length/e,o=n.constructor.BYTES_PER_ELEMENT*8;let c=1;switch(n.constructor){case Uint8Array:case Uint16Array:case Uint32Array:c=2**o-1;break;case Int8Array:case Int16Array:case Int32Array:c=2**(o-1)-1;break}for(let u=0;u<a;u++){const f=4*u,p=e*u;for(let r=0;r<i;r++)t[s+f+r]=e>=r+1?n[p+r]/c:0}}class eo extends d.DataArrayTexture{constructor(){super(),this._textures=[],this.type=d.FloatType,this.format=d.RGBAFormat,this.internalFormat="RGBA32F"}updateAttribute(e,t){const i=this._textures[e];i.updateFrom(t);const s=i.image,a=this.image;if(s.width!==a.width||s.height!==a.height)throw new Error("FloatAttributeTextureArray: Attribute must be the same dimensions when updating single layer.");const{width:o,height:c,data:u}=a,p=o*c*4*e;let r=t.itemSize;r===3&&(r=4),Is(i.image.data,r,u,4,p),this.dispose(),this.needsUpdate=!0}setAttributes(e){const t=e[0].count,i=e.length;for(let r=0,l=i;r<l;r++)if(e[r].count!==t)throw new Error("FloatAttributeTextureArray: All attributes must have the same item count.");const s=this._textures;for(;s.length<i;){const r=new Ce.FloatVertexAttributeTexture;s.push(r)}for(;s.length>i;)s.pop();for(let r=0,l=i;r<l;r++)s[r].updateFrom(e[r]);const o=s[0].image,c=this.image;(o.width!==c.width||o.height!==c.height||o.depth!==i)&&(c.width=o.width,c.height=o.height,c.depth=i,c.data=new Float32Array(c.width*c.height*c.depth*4));const{data:u,width:f,height:p}=c;for(let r=0,l=i;r<l;r++){const h=s[r],_=f*p*4*r;let m=e[r].itemSize;m===3&&(m=4),Is(h.image.data,m,u,4,_)}this.dispose(),this.needsUpdate=!0}}class to extends eo{updateNormalAttribute(e){this.updateAttribute(0,e)}updateTangentAttribute(e){this.updateAttribute(1,e)}updateUvAttribute(e){this.updateAttribute(2,e)}updateColorAttribute(e){this.updateAttribute(3,e)}updateFrom(e,t,i,s){this.setAttributes([e,t,i,s])}}function ns(n,e){return n.uuid<e.uuid?1:n.uuid>e.uuid?-1:0}function ki(n){return`${n.source.uuid}:${n.colorSpace}`}function io(n){const e=new Set,t=[];for(let i=0,s=n.length;i<s;i++){const a=n[i],o=ki(a);e.has(o)||(e.add(o),t.push(a))}return t}function so(n){const e=n.map(i=>i.iesMap||null).filter(i=>i),t=new Set(e);return Array.from(t).sort(ns)}function ro(n){const e=new Set;for(let i=0,s=n.length;i<s;i++){const a=n[i];for(const o in a){const c=a[o];c&&c.isTexture&&e.add(c)}}const t=Array.from(e);return io(t).sort(ns)}function no(n){const e=[];return n.traverse(t=>{t.visible&&(t.isRectAreaLight||t.isSpotLight||t.isPointLight||t.isDirectionalLight)&&e.push(t)}),e.sort(ns)}const pr=45,Rs=pr*4;class oo{constructor(){this._features={}}isUsed(e){return e in this._features}setUsed(e,t=!0){t===!1?delete this._features[e]:this._features[e]=!0}reset(){this._features={}}}class ao extends d.DataTexture{constructor(){super(new Float32Array(4),1,1),this.format=d.RGBAFormat,this.type=d.FloatType,this.wrapS=d.ClampToEdgeWrapping,this.wrapT=d.ClampToEdgeWrapping,this.minFilter=d.NearestFilter,this.magFilter=d.NearestFilter,this.generateMipmaps=!1,this.features=new oo}updateFrom(e,t){function i(g,_,m=-1){if(_ in g&&g[_]){const v=ki(g[_]);return r[v]}else return m}function s(g,_,m){return _ in g?g[_]:m}function a(g,_,m,v){const y=g[_]&&g[_].isTexture?g[_]:null;if(y){y.matrixAutoUpdate&&y.updateMatrix();const x=y.matrix.elements;let w=0;m[v+w++]=x[0],m[v+w++]=x[3],m[v+w++]=x[6],w++,m[v+w++]=x[1],m[v+w++]=x[4],m[v+w++]=x[7],w++}return 8}let o=0;const c=e.length*pr,u=Math.ceil(Math.sqrt(c))||1,{image:f,features:p}=this,r={};for(let g=0,_=t.length;g<_;g++)r[ki(t[g])]=g;f.width!==u&&(this.dispose(),f.data=new Float32Array(u*u*4),f.width=u,f.height=u);const l=f.data;p.reset();for(let g=0,_=e.length;g<_;g++){const m=e[g];if(m.isFogVolumeMaterial){p.setUsed("FOG");for(let x=0;x<Rs;x++)l[o+x]=0;l[o+0*4+0]=m.color.r,l[o+0*4+1]=m.color.g,l[o+0*4+2]=m.color.b,l[o+2*4+3]=s(m,"emissiveIntensity",0),l[o+3*4+0]=m.emissive.r,l[o+3*4+1]=m.emissive.g,l[o+3*4+2]=m.emissive.b,l[o+13*4+1]=m.density,l[o+13*4+3]=0,l[o+14*4+2]=4,o+=Rs;continue}l[o++]=m.color.r,l[o++]=m.color.g,l[o++]=m.color.b,l[o++]=i(m,"map"),l[o++]=s(m,"metalness",0),l[o++]=i(m,"metalnessMap"),l[o++]=s(m,"roughness",0),l[o++]=i(m,"roughnessMap"),l[o++]=s(m,"ior",1.5),l[o++]=s(m,"transmission",0),l[o++]=i(m,"transmissionMap"),l[o++]=s(m,"emissiveIntensity",0),"emissive"in m?(l[o++]=m.emissive.r,l[o++]=m.emissive.g,l[o++]=m.emissive.b):(l[o++]=0,l[o++]=0,l[o++]=0),l[o++]=i(m,"emissiveMap"),l[o++]=i(m,"normalMap"),"normalScale"in m?(l[o++]=m.normalScale.x,l[o++]=m.normalScale.y):(l[o++]=1,l[o++]=1),l[o++]=s(m,"clearcoat",0),l[o++]=i(m,"clearcoatMap"),l[o++]=s(m,"clearcoatRoughness",0),l[o++]=i(m,"clearcoatRoughnessMap"),l[o++]=i(m,"clearcoatNormalMap"),"clearcoatNormalScale"in m?(l[o++]=m.clearcoatNormalScale.x,l[o++]=m.clearcoatNormalScale.y):(l[o++]=1,l[o++]=1),o++,l[o++]=s(m,"sheen",0),"sheenColor"in m?(l[o++]=m.sheenColor.r,l[o++]=m.sheenColor.g,l[o++]=m.sheenColor.b):(l[o++]=0,l[o++]=0,l[o++]=0),l[o++]=i(m,"sheenColorMap"),l[o++]=s(m,"sheenRoughness",0),l[o++]=i(m,"sheenRoughnessMap"),l[o++]=i(m,"iridescenceMap"),l[o++]=i(m,"iridescenceThicknessMap"),l[o++]=s(m,"iridescence",0),l[o++]=s(m,"iridescenceIOR",1.3);const v=s(m,"iridescenceThicknessRange",[100,400]);l[o++]=v[0],l[o++]=v[1],"specularColor"in m?(l[o++]=m.specularColor.r,l[o++]=m.specularColor.g,l[o++]=m.specularColor.b):(l[o++]=1,l[o++]=1,l[o++]=1),l[o++]=i(m,"specularColorMap"),l[o++]=s(m,"specularIntensity",1),l[o++]=i(m,"specularIntensityMap");const y=s(m,"thickness",0)===0&&s(m,"attenuationDistance",1/0)===1/0;if(l[o++]=Number(y),o++,"attenuationColor"in m?(l[o++]=m.attenuationColor.r,l[o++]=m.attenuationColor.g,l[o++]=m.attenuationColor.b):(l[o++]=1,l[o++]=1,l[o++]=1),l[o++]=s(m,"attenuationDistance",1/0),l[o++]=i(m,"alphaMap"),l[o++]=m.opacity,l[o++]=m.alphaTest,!y&&m.transmission>0)l[o++]=0;else switch(m.side){case d.FrontSide:l[o++]=1;break;case d.BackSide:l[o++]=-1;break;case d.DoubleSide:l[o++]=0;break}l[o++]=Number(s(m,"matte",!1)),l[o++]=Number(s(m,"castShadow",!0)),l[o++]=Number(m.vertexColors)|Number(m.flatShading)<<1,l[o++]=Number(m.transparent),o+=a(m,"map",l,o),o+=a(m,"metalnessMap",l,o),o+=a(m,"roughnessMap",l,o),o+=a(m,"transmissionMap",l,o),o+=a(m,"emissiveMap",l,o),o+=a(m,"normalMap",l,o),o+=a(m,"clearcoatMap",l,o),o+=a(m,"clearcoatNormalMap",l,o),o+=a(m,"clearcoatRoughnessMap",l,o),o+=a(m,"sheenColorMap",l,o),o+=a(m,"sheenRoughnessMap",l,o),o+=a(m,"iridescenceMap",l,o),o+=a(m,"iridescenceThicknessMap",l,o),o+=a(m,"specularColorMap",l,o),o+=a(m,"specularIntensityMap",l,o)}const h=ss(l.buffer);return this.hash!==h?(this.hash=h,this.needsUpdate=!0,!0):!1}}const Ps=new d.Color;function lo(n){return n?`${n.uuid}:${n.version}`:null}function co(n,e){for(const t in e)t in n&&(n[t]=e[t])}class Ds extends d.WebGLArrayRenderTarget{constructor(e,t,i){const s={format:d.RGBAFormat,type:d.UnsignedByteType,minFilter:d.LinearFilter,magFilter:d.LinearFilter,wrapS:d.RepeatWrapping,wrapT:d.RepeatWrapping,generateMipmaps:!1,...i};super(e,t,1,s),co(this.texture,s),this.texture.setTextures=(...o)=>{this.setTextures(...o)},this.hashes=[null];const a=new nt.FullScreenQuad(new uo);this.fsQuad=a}setTextures(e,t,i=this.width,s=this.height){const a=e.getRenderTarget(),o=e.toneMapping,c=e.getClearAlpha();e.getClearColor(Ps);const u=t.length||1;(i!==this.width||s!==this.height||this.depth!==u)&&(this.setSize(i,s,u),this.hashes=new Array(u).fill(null)),e.setClearColor(0,0),e.toneMapping=d.NoToneMapping;const f=this.fsQuad,p=this.hashes;let r=!1;for(let l=0,h=u;l<h;l++){const g=t[l],_=lo(g);g&&(p[l]!==_||g.isWebGLRenderTarget)&&(g.matrixAutoUpdate=!1,g.matrix.identity(),f.material.map=g,e.setRenderTarget(this,l),f.render(e),g.updateMatrix(),g.matrixAutoUpdate=!0,p[l]=_,r=!0)}return f.material.map=null,e.setClearColor(Ps,c),e.setRenderTarget(a),e.toneMapping=o,r}dispose(){super.dispose(),this.fsQuad.dispose()}}class uo extends d.ShaderMaterial{get map(){return this.uniforms.map.value}set map(e){this.uniforms.map.value=e}constructor(){super({uniforms:{map:{value:null}},vertexShader:`
257
+ `})}}class Hn{generate(e,t=256){const i=new d.WebGLRenderTarget(t,t,{type:d.FloatType,format:d.RGBAFormat,minFilter:d.NearestFilter,magFilter:d.NearestFilter,generateMipmaps:!1}),s=e.getRenderTarget();e.setRenderTarget(i);const a=new ot.FullScreenQuad(new Un);return a.material.resolution.set(t,t),a.render(e),e.setRenderTarget(s),a.dispose(),i}}class Nn extends d.PerspectiveCamera{set bokehSize(e){this.fStop=this.getFocalLength()/e}get bokehSize(){return this.getFocalLength()/this.fStop}constructor(...e){super(...e),this.fStop=1.4,this.apertureBlades=0,this.apertureRotation=0,this.focusDistance=25,this.anamorphicRatio=1}copy(e,t){return super.copy(e,t),this.fStop=e.fStop,this.apertureBlades=e.apertureBlades,this.apertureRotation=e.apertureRotation,this.focusDistance=e.focusDistance,this.anamorphicRatio=e.anamorphicRatio,this}}class Wn{constructor(){this.bokehSize=0,this.apertureBlades=0,this.apertureRotation=0,this.focusDistance=10,this.anamorphicRatio=1}updateFrom(e){e instanceof Nn?(this.bokehSize=e.bokehSize,this.apertureBlades=e.apertureBlades,this.apertureRotation=e.apertureRotation,this.focusDistance=e.focusDistance,this.anamorphicRatio=e.anamorphicRatio):(this.bokehSize=0,this.apertureRotation=0,this.apertureBlades=0,this.focusDistance=10,this.anamorphicRatio=1)}}function _i(n){const e=new Uint16Array(n.length);for(let t=0,i=n.length;t<i;++t)e[t]=d.DataUtils.toHalfFloat(n[t]);return e}function Ms(n,e,t=0,i=n.length){let s=t,a=t+i-1;for(;s<a;){const o=s+a>>1;n[o]<e?s=o+1:a=o}return s-t}function Gn(n,e,t){return .2126*n+.7152*e+.0722*t}function qn(n,e=d.HalfFloatType){const t=n.clone();t.source=new d.Source({...t.image});const{width:i,height:s,data:a}=t.image;let o=a;if(t.type!==e){e===d.HalfFloatType?o=new Uint16Array(a.length):o=new Float32Array(a.length);let c;a instanceof Int8Array||a instanceof Int16Array||a instanceof Int32Array?c=2**(8*a.BYTES_PER_ELEMENT-1)-1:c=2**(8*a.BYTES_PER_ELEMENT)-1;for(let u=0,f=a.length;u<f;u++){let p=a[u];t.type===d.HalfFloatType&&(p=d.DataUtils.fromHalfFloat(a[u])),t.type!==d.FloatType&&t.type!==d.HalfFloatType&&(p/=c),e===d.HalfFloatType&&(o[u]=d.DataUtils.toHalfFloat(p))}t.image.data=o,t.type=e}if(t.flipY){const c=o;o=o.slice();for(let u=0;u<s;u++)for(let f=0;f<i;f++){const p=s-u-1,r=4*(u*i+f),l=4*(p*i+f);o[l+0]=c[r+0],o[l+1]=c[r+1],o[l+2]=c[r+2],o[l+3]=c[r+3]}t.flipY=!1,t.image.data=o}return t}class jn{constructor(){const e=new d.DataTexture(_i(new Float32Array([0,0,0,0])),1,1);e.type=d.HalfFloatType,e.format=d.RGBAFormat,e.minFilter=d.LinearFilter,e.magFilter=d.LinearFilter,e.wrapS=d.RepeatWrapping,e.wrapT=d.RepeatWrapping,e.generateMipmaps=!1,e.needsUpdate=!0;const t=new d.DataTexture(_i(new Float32Array([0,1])),1,2);t.type=d.HalfFloatType,t.format=d.RedFormat,t.minFilter=d.LinearFilter,t.magFilter=d.LinearFilter,t.generateMipmaps=!1,t.needsUpdate=!0;const i=new d.DataTexture(_i(new Float32Array([0,0,1,1])),2,2);i.type=d.HalfFloatType,i.format=d.RedFormat,i.minFilter=d.LinearFilter,i.magFilter=d.LinearFilter,i.generateMipmaps=!1,i.needsUpdate=!0,this.map=e,this.marginalWeights=t,this.conditionalWeights=i,this.totalSum=0}dispose(){this.marginalWeights.dispose(),this.conditionalWeights.dispose(),this.map.dispose()}updateFrom(e){const t=qn(e);t.wrapS=d.RepeatWrapping,t.wrapT=d.ClampToEdgeWrapping;const{width:i,height:s,data:a}=t.image,o=new Float32Array(i*s),c=new Float32Array(i*s),u=new Float32Array(s),f=new Float32Array(s);let p=0,r=0;for(let m=0;m<s;m++){let v=0;for(let y=0;y<i;y++){const x=m*i+y,w=d.DataUtils.fromHalfFloat(a[4*x+0]),b=d.DataUtils.fromHalfFloat(a[4*x+1]),A=d.DataUtils.fromHalfFloat(a[4*x+2]),T=Gn(w,b,A);v+=T,p+=T,o[x]=T,c[x]=v}if(v!==0)for(let y=m*i,x=m*i+i;y<x;y++)o[y]/=v,c[y]/=v;r+=v,u[m]=v,f[m]=r}if(r!==0)for(let m=0,v=u.length;m<v;m++)u[m]/=r,f[m]/=r;const l=new Uint16Array(s),h=new Uint16Array(i*s);for(let m=0;m<s;m++){const v=(m+1)/s,y=Ms(f,v);l[m]=d.DataUtils.toHalfFloat((y+.5)/s)}for(let m=0;m<s;m++)for(let v=0;v<i;v++){const y=m*i+v,x=(v+1)/i,w=Ms(c,x,m*i,i);h[y]=d.DataUtils.toHalfFloat((w+.5)/i)}this.dispose();const{marginalWeights:g,conditionalWeights:_}=this;g.image={width:s,height:1,data:l},g.needsUpdate=!0,_.image={width:i,height:s,data:h},_.needsUpdate=!0,this.totalSum=p,this.map=t}}const yi=6,Yn=0,Qn=1,Zn=2,Xn=3,Kn=4,ne=new d.Vector3,Z=new d.Vector3,Cs=new d.Matrix4,Ve=new d.Quaternion,Is=new d.Vector3,Ue=new d.Vector3,Jn=new d.Vector3(0,1,0);class $n{constructor(){const e=new d.DataTexture(new Float32Array(4),1,1);e.format=d.RGBAFormat,e.type=d.FloatType,e.wrapS=d.ClampToEdgeWrapping,e.wrapT=d.ClampToEdgeWrapping,e.generateMipmaps=!1,e.minFilter=d.NearestFilter,e.magFilter=d.NearestFilter,this.tex=e,this.count=0}updateFrom(e,t=[]){const i=this.tex,s=Math.max(e.length*yi,1),a=Math.ceil(Math.sqrt(s));i.image.width!==a&&(i.dispose(),i.image.data=new Float32Array(a*a*4),i.image.width=a,i.image.height=a);const o=i.image.data;for(let u=0,f=e.length;u<f;u++){const p=e[u],r=u*yi*4;let l=0;for(let g=0;g<yi*4;g++)o[r+g]=0;p.getWorldPosition(Z),o[r+l++]=Z.x,o[r+l++]=Z.y,o[r+l++]=Z.z;let h=Yn;if(p.isRectAreaLight&&p.isCircular?h=Qn:p.isSpotLight?h=Zn:p.isDirectionalLight?h=Xn:p.isPointLight&&(h=Kn),o[r+l++]=h,o[r+l++]=p.color.r,o[r+l++]=p.color.g,o[r+l++]=p.color.b,o[r+l++]=p.intensity,p.getWorldQuaternion(Ve),p.isRectAreaLight)ne.set(p.width,0,0).applyQuaternion(Ve),o[r+l++]=ne.x,o[r+l++]=ne.y,o[r+l++]=ne.z,l++,Z.set(0,p.height,0).applyQuaternion(Ve),o[r+l++]=Z.x,o[r+l++]=Z.y,o[r+l++]=Z.z,o[r+l++]=ne.cross(Z).length()*(p.isCircular?Math.PI/4:1);else if(p.isSpotLight){const g=p.radius||0;Is.setFromMatrixPosition(p.matrixWorld),Ue.setFromMatrixPosition(p.target.matrixWorld),Cs.lookAt(Is,Ue,Jn),Ve.setFromRotationMatrix(Cs),ne.set(1,0,0).applyQuaternion(Ve),o[r+l++]=ne.x,o[r+l++]=ne.y,o[r+l++]=ne.z,l++,Z.set(0,1,0).applyQuaternion(Ve),o[r+l++]=Z.x,o[r+l++]=Z.y,o[r+l++]=Z.z,o[r+l++]=Math.PI*g*g,o[r+l++]=g,o[r+l++]=p.decay,o[r+l++]=p.distance,o[r+l++]=Math.cos(p.angle),o[r+l++]=Math.cos(p.angle*(1-p.penumbra)),o[r+l++]=p.iesMap?t.indexOf(p.iesMap):-1}else if(p.isPointLight){const g=ne.setFromMatrixPosition(p.matrixWorld);o[r+l++]=g.x,o[r+l++]=g.y,o[r+l++]=g.z,l++,l+=4,l+=1,o[r+l++]=p.decay,o[r+l++]=p.distance}else if(p.isDirectionalLight){const g=ne.setFromMatrixPosition(p.matrixWorld),_=Z.setFromMatrixPosition(p.target.matrixWorld);Ue.subVectors(g,_).normalize(),o[r+l++]=Ue.x,o[r+l++]=Ue.y,o[r+l++]=Ue.z}}this.count=e.length;const c=rs(o.buffer);return this.hash!==c?(this.hash=c,i.needsUpdate=!0,!0):!1}}function Rs(n,e,t,i,s){if(e>i)throw new Error;const a=n.length/e,o=n.constructor.BYTES_PER_ELEMENT*8;let c=1;switch(n.constructor){case Uint8Array:case Uint16Array:case Uint32Array:c=2**o-1;break;case Int8Array:case Int16Array:case Int32Array:c=2**(o-1)-1;break}for(let u=0;u<a;u++){const f=4*u,p=e*u;for(let r=0;r<i;r++)t[s+f+r]=e>=r+1?n[p+r]/c:0}}class eo extends d.DataArrayTexture{constructor(){super(),this._textures=[],this.type=d.FloatType,this.format=d.RGBAFormat,this.internalFormat="RGBA32F"}updateAttribute(e,t){const i=this._textures[e];i.updateFrom(t);const s=i.image,a=this.image;if(s.width!==a.width||s.height!==a.height)throw new Error("FloatAttributeTextureArray: Attribute must be the same dimensions when updating single layer.");const{width:o,height:c,data:u}=a,p=o*c*4*e;let r=t.itemSize;r===3&&(r=4),Rs(i.image.data,r,u,4,p),this.dispose(),this.needsUpdate=!0}setAttributes(e){const t=e[0].count,i=e.length;for(let r=0,l=i;r<l;r++)if(e[r].count!==t)throw new Error("FloatAttributeTextureArray: All attributes must have the same item count.");const s=this._textures;for(;s.length<i;){const r=new Ce.FloatVertexAttributeTexture;s.push(r)}for(;s.length>i;)s.pop();for(let r=0,l=i;r<l;r++)s[r].updateFrom(e[r]);const o=s[0].image,c=this.image;(o.width!==c.width||o.height!==c.height||o.depth!==i)&&(c.width=o.width,c.height=o.height,c.depth=i,c.data=new Float32Array(c.width*c.height*c.depth*4));const{data:u,width:f,height:p}=c;for(let r=0,l=i;r<l;r++){const h=s[r],_=f*p*4*r;let m=e[r].itemSize;m===3&&(m=4),Rs(h.image.data,m,u,4,_)}this.dispose(),this.needsUpdate=!0}}class to extends eo{updateNormalAttribute(e){this.updateAttribute(0,e)}updateTangentAttribute(e){this.updateAttribute(1,e)}updateUvAttribute(e){this.updateAttribute(2,e)}updateColorAttribute(e){this.updateAttribute(3,e)}updateFrom(e,t,i,s){this.setAttributes([e,t,i,s])}}function os(n,e){return n.uuid<e.uuid?1:n.uuid>e.uuid?-1:0}function Oi(n){return`${n.source.uuid}:${n.colorSpace}`}function io(n){const e=new Set,t=[];for(let i=0,s=n.length;i<s;i++){const a=n[i],o=Oi(a);e.has(o)||(e.add(o),t.push(a))}return t}function so(n){const e=n.map(i=>i.iesMap||null).filter(i=>i),t=new Set(e);return Array.from(t).sort(os)}function ro(n){const e=new Set;for(let i=0,s=n.length;i<s;i++){const a=n[i];for(const o in a){const c=a[o];c&&c.isTexture&&e.add(c)}}const t=Array.from(e);return io(t).sort(os)}function no(n){const e=[];return n.traverse(t=>{t.visible&&(t.isRectAreaLight||t.isSpotLight||t.isPointLight||t.isDirectionalLight)&&e.push(t)}),e.sort(os)}const mr=45,Ps=mr*4;class oo{constructor(){this._features={}}isUsed(e){return e in this._features}setUsed(e,t=!0){t===!1?delete this._features[e]:this._features[e]=!0}reset(){this._features={}}}class ao extends d.DataTexture{constructor(){super(new Float32Array(4),1,1),this.format=d.RGBAFormat,this.type=d.FloatType,this.wrapS=d.ClampToEdgeWrapping,this.wrapT=d.ClampToEdgeWrapping,this.minFilter=d.NearestFilter,this.magFilter=d.NearestFilter,this.generateMipmaps=!1,this.features=new oo}updateFrom(e,t){function i(g,_,m=-1){if(_ in g&&g[_]){const v=Oi(g[_]);return r[v]}else return m}function s(g,_,m){return _ in g?g[_]:m}function a(g,_,m,v){const y=g[_]&&g[_].isTexture?g[_]:null;if(y){y.matrixAutoUpdate&&y.updateMatrix();const x=y.matrix.elements;let w=0;m[v+w++]=x[0],m[v+w++]=x[3],m[v+w++]=x[6],w++,m[v+w++]=x[1],m[v+w++]=x[4],m[v+w++]=x[7],w++}return 8}let o=0;const c=e.length*mr,u=Math.ceil(Math.sqrt(c))||1,{image:f,features:p}=this,r={};for(let g=0,_=t.length;g<_;g++)r[Oi(t[g])]=g;f.width!==u&&(this.dispose(),f.data=new Float32Array(u*u*4),f.width=u,f.height=u);const l=f.data;p.reset();for(let g=0,_=e.length;g<_;g++){const m=e[g];if(m.isFogVolumeMaterial){p.setUsed("FOG");for(let x=0;x<Ps;x++)l[o+x]=0;l[o+0*4+0]=m.color.r,l[o+0*4+1]=m.color.g,l[o+0*4+2]=m.color.b,l[o+2*4+3]=s(m,"emissiveIntensity",0),l[o+3*4+0]=m.emissive.r,l[o+3*4+1]=m.emissive.g,l[o+3*4+2]=m.emissive.b,l[o+13*4+1]=m.density,l[o+13*4+3]=0,l[o+14*4+2]=4,o+=Ps;continue}l[o++]=m.color.r,l[o++]=m.color.g,l[o++]=m.color.b,l[o++]=i(m,"map"),l[o++]=s(m,"metalness",0),l[o++]=i(m,"metalnessMap"),l[o++]=s(m,"roughness",0),l[o++]=i(m,"roughnessMap"),l[o++]=s(m,"ior",1.5),l[o++]=s(m,"transmission",0),l[o++]=i(m,"transmissionMap"),l[o++]=s(m,"emissiveIntensity",0),"emissive"in m?(l[o++]=m.emissive.r,l[o++]=m.emissive.g,l[o++]=m.emissive.b):(l[o++]=0,l[o++]=0,l[o++]=0),l[o++]=i(m,"emissiveMap"),l[o++]=i(m,"normalMap"),"normalScale"in m?(l[o++]=m.normalScale.x,l[o++]=m.normalScale.y):(l[o++]=1,l[o++]=1),l[o++]=s(m,"clearcoat",0),l[o++]=i(m,"clearcoatMap"),l[o++]=s(m,"clearcoatRoughness",0),l[o++]=i(m,"clearcoatRoughnessMap"),l[o++]=i(m,"clearcoatNormalMap"),"clearcoatNormalScale"in m?(l[o++]=m.clearcoatNormalScale.x,l[o++]=m.clearcoatNormalScale.y):(l[o++]=1,l[o++]=1),o++,l[o++]=s(m,"sheen",0),"sheenColor"in m?(l[o++]=m.sheenColor.r,l[o++]=m.sheenColor.g,l[o++]=m.sheenColor.b):(l[o++]=0,l[o++]=0,l[o++]=0),l[o++]=i(m,"sheenColorMap"),l[o++]=s(m,"sheenRoughness",0),l[o++]=i(m,"sheenRoughnessMap"),l[o++]=i(m,"iridescenceMap"),l[o++]=i(m,"iridescenceThicknessMap"),l[o++]=s(m,"iridescence",0),l[o++]=s(m,"iridescenceIOR",1.3);const v=s(m,"iridescenceThicknessRange",[100,400]);l[o++]=v[0],l[o++]=v[1],"specularColor"in m?(l[o++]=m.specularColor.r,l[o++]=m.specularColor.g,l[o++]=m.specularColor.b):(l[o++]=1,l[o++]=1,l[o++]=1),l[o++]=i(m,"specularColorMap"),l[o++]=s(m,"specularIntensity",1),l[o++]=i(m,"specularIntensityMap");const y=s(m,"thickness",0)===0&&s(m,"attenuationDistance",1/0)===1/0;if(l[o++]=Number(y),o++,"attenuationColor"in m?(l[o++]=m.attenuationColor.r,l[o++]=m.attenuationColor.g,l[o++]=m.attenuationColor.b):(l[o++]=1,l[o++]=1,l[o++]=1),l[o++]=s(m,"attenuationDistance",1/0),l[o++]=i(m,"alphaMap"),l[o++]=m.opacity,l[o++]=m.alphaTest,!y&&m.transmission>0)l[o++]=0;else switch(m.side){case d.FrontSide:l[o++]=1;break;case d.BackSide:l[o++]=-1;break;case d.DoubleSide:l[o++]=0;break}l[o++]=Number(s(m,"matte",!1)),l[o++]=Number(s(m,"castShadow",!0)),l[o++]=Number(m.vertexColors)|Number(m.flatShading)<<1,l[o++]=Number(m.transparent),o+=a(m,"map",l,o),o+=a(m,"metalnessMap",l,o),o+=a(m,"roughnessMap",l,o),o+=a(m,"transmissionMap",l,o),o+=a(m,"emissiveMap",l,o),o+=a(m,"normalMap",l,o),o+=a(m,"clearcoatMap",l,o),o+=a(m,"clearcoatNormalMap",l,o),o+=a(m,"clearcoatRoughnessMap",l,o),o+=a(m,"sheenColorMap",l,o),o+=a(m,"sheenRoughnessMap",l,o),o+=a(m,"iridescenceMap",l,o),o+=a(m,"iridescenceThicknessMap",l,o),o+=a(m,"specularColorMap",l,o),o+=a(m,"specularIntensityMap",l,o)}const h=rs(l.buffer);return this.hash!==h?(this.hash=h,this.needsUpdate=!0,!0):!1}}const Ds=new d.Color;function lo(n){return n?`${n.uuid}:${n.version}`:null}function co(n,e){for(const t in e)t in n&&(n[t]=e[t])}class Ls extends d.WebGLArrayRenderTarget{constructor(e,t,i){const s={format:d.RGBAFormat,type:d.UnsignedByteType,minFilter:d.LinearFilter,magFilter:d.LinearFilter,wrapS:d.RepeatWrapping,wrapT:d.RepeatWrapping,generateMipmaps:!1,...i};super(e,t,1,s),co(this.texture,s),this.texture.setTextures=(...o)=>{this.setTextures(...o)},this.hashes=[null];const a=new ot.FullScreenQuad(new uo);this.fsQuad=a}setTextures(e,t,i=this.width,s=this.height){const a=e.getRenderTarget(),o=e.toneMapping,c=e.getClearAlpha();e.getClearColor(Ds);const u=t.length||1;(i!==this.width||s!==this.height||this.depth!==u)&&(this.setSize(i,s,u),this.hashes=new Array(u).fill(null)),e.setClearColor(0,0),e.toneMapping=d.NoToneMapping;const f=this.fsQuad,p=this.hashes;let r=!1;for(let l=0,h=u;l<h;l++){const g=t[l],_=lo(g);g&&(p[l]!==_||g.isWebGLRenderTarget)&&(g.matrixAutoUpdate=!1,g.matrix.identity(),f.material.map=g,e.setRenderTarget(this,l),f.render(e),g.updateMatrix(),g.matrixAutoUpdate=!0,p[l]=_,r=!0)}return f.material.map=null,e.setClearColor(Ds,c),e.setRenderTarget(a),e.toneMapping=o,r}dispose(){super.dispose(),this.fsQuad.dispose()}}class uo extends d.ShaderMaterial{get map(){return this.uniforms.map.value}set map(e){this.uniforms.map.value=e}constructor(){super({uniforms:{map:{value:null}},vertexShader:`
258
258
  varying vec2 vUv;
259
259
  void main() {
260
260
 
@@ -270,7 +270,7 @@
270
270
  gl_FragColor = texture2D( map, vUv );
271
271
 
272
272
  }
273
- `})}}function ho(n,e=Math.random()){for(let t=n.length-1;t>0;t--){const i=Math.floor(e()*(t+1)),s=n[t];n[t]=n[i],n[i]=s}return n}class fo{constructor(e,t,i=Math.random){const s=e**t,a=new Uint16Array(s);let o=s;for(let c=0;c<s;c++)a[c]=c;this.samples=new Float32Array(t),this.strataCount=e,this.reset=function(){for(let c=0;c<s;c++)a[c]=c;o=0},this.reshuffle=function(){o=0},this.next=function(){const{samples:c}=this;o>=a.length&&(ho(a,i),this.reshuffle());let u=a[o++];for(let f=0;f<t;f++)c[f]=(u%e+i())/e,u=Math.floor(u/e);return c}}}class po{constructor(e,t,i=Math.random){let s=0;for(const u of t)s+=u;const a=new Float32Array(s),o=[];let c=0;for(const u of t){const f=new fo(e,u,i);f.samples=new Float32Array(a.buffer,c,f.samples.length),c+=f.samples.length*4,o.push(f)}this.samples=a,this.strataCount=e,this.next=function(){for(const u of o)u.next();return a},this.reshuffle=function(){for(const u of o)u.reshuffle()},this.reset=function(){for(const u of o)u.reset()}}}class mo{constructor(e=0){this.m=2147483648,this.a=1103515245,this.c=12345,this.seed=e}nextInt(){return this.seed=(this.a*this.seed+this.c)%this.m,this.seed}nextFloat(){return this.nextInt()/(this.m-1)}}class go extends d.DataTexture{constructor(e=1,t=1,i=8){super(new Float32Array(1),1,1,d.RGBAFormat,d.FloatType),this.minFilter=d.NearestFilter,this.magFilter=d.NearestFilter,this.strata=i,this.sampler=null,this.generator=new mo,this.stableNoise=!1,this.random=()=>this.stableNoise?this.generator.nextFloat():Math.random(),this.init(e,t,i)}init(e=this.image.height,t=this.image.width,i=this.strata){const{image:s}=this;if(s.width===t&&s.height===e&&this.sampler!==null)return;const a=new Array(e*t).fill(4),o=new po(i,a,this.random);s.width=t,s.height=e,s.data=o.samples,this.sampler=o,this.dispose(),this.next()}next(){this.sampler.next(),this.needsUpdate=!0}reset(){this.sampler.reset(),this.generator.seed=0}}function vo(n,e=Math.random){for(let t=n.length-1;t>0;t--){const i=~~((e()-1e-6)*t),s=n[t];n[t]=n[i],n[i]=s}}function _o(n,e){n.fill(0);for(let t=0;t<e;t++)n[t]=1}class Ls{constructor(e){this.count=0,this.size=-1,this.sigma=-1,this.radius=-1,this.lookupTable=null,this.score=null,this.binaryPattern=null,this.resize(e),this.setSigma(1.5)}findVoid(){const{score:e,binaryPattern:t}=this;let i=1/0,s=-1;for(let a=0,o=t.length;a<o;a++){if(t[a]!==0)continue;const c=e[a];c<i&&(i=c,s=a)}return s}findCluster(){const{score:e,binaryPattern:t}=this;let i=-1/0,s=-1;for(let a=0,o=t.length;a<o;a++){if(t[a]!==1)continue;const c=e[a];c>i&&(i=c,s=a)}return s}setSigma(e){if(e===this.sigma)return;const t=~~(Math.sqrt(10*2*e**2)+1),i=2*t+1,s=new Float32Array(i*i),a=e*e;for(let o=-t;o<=t;o++)for(let c=-t;c<=t;c++){const u=(t+c)*i+o+t,f=o*o+c*c;s[u]=Math.E**(-f/(2*a))}this.lookupTable=s,this.sigma=e,this.radius=t}resize(e){this.size!==e&&(this.size=e,this.score=new Float32Array(e*e),this.binaryPattern=new Uint8Array(e*e))}invert(){const{binaryPattern:e,score:t,size:i}=this;t.fill(0);for(let s=0,a=e.length;s<a;s++)if(e[s]===0){const o=~~(s/i),c=s-o*i;this.updateScore(c,o,1),e[s]=1}else e[s]=0}updateScore(e,t,i){const{size:s,score:a,lookupTable:o}=this,c=this.radius,u=2*c+1;for(let f=-c;f<=c;f++)for(let p=-c;p<=c;p++){const r=(c+p)*u+f+c,l=o[r];let h=e+f;h=h<0?s+h:h%s;let g=t+p;g=g<0?s+g:g%s;const _=g*s+h;a[_]+=i*l}}addPointIndex(e){this.binaryPattern[e]=1;const t=this.size,i=~~(e/t),s=e-i*t;this.updateScore(s,i,1),this.count++}removePointIndex(e){this.binaryPattern[e]=0;const t=this.size,i=~~(e/t),s=e-i*t;this.updateScore(s,i,-1),this.count--}copy(e){this.resize(e.size),this.score.set(e.score),this.binaryPattern.set(e.binaryPattern),this.setSigma(e.sigma),this.count=e.count}}class yo{constructor(){this.random=Math.random,this.sigma=1.5,this.size=64,this.majorityPointsRatio=.1,this.samples=new Ls(1),this.savedSamples=new Ls(1)}generate(){const{samples:e,savedSamples:t,sigma:i,majorityPointsRatio:s,size:a}=this;e.resize(a),e.setSigma(i);const o=Math.floor(a*a*s),c=e.binaryPattern;_o(c,o),vo(c,this.random);for(let r=0,l=c.length;r<l;r++)c[r]===1&&e.addPointIndex(r);for(;;){const r=e.findCluster();e.removePointIndex(r);const l=e.findVoid();if(r===l){e.addPointIndex(r);break}e.addPointIndex(l)}const u=new Uint32Array(a*a);t.copy(e);let f;for(f=e.count-1;f>=0;){const r=e.findCluster();e.removePointIndex(r),u[r]=f,f--}const p=a*a;for(f=t.count;f<p/2;){const r=t.findVoid();t.addPointIndex(r),u[r]=f,f++}for(t.invert();f<p;){const r=t.findCluster();t.removePointIndex(r),u[r]=f,f++}return{data:u,maxValue:p}}}function xo(n){return n>=3?4:n}function wo(n){switch(n){case 1:return d.RedFormat;case 2:return d.RGFormat;default:return d.RGBAFormat}}class bo extends d.DataTexture{constructor(e=64,t=1){super(new Float32Array(4),1,1,d.RGBAFormat,d.FloatType),this.minFilter=d.NearestFilter,this.magFilter=d.NearestFilter,this.size=e,this.channels=t,this.update()}update(){const e=this.channels,t=this.size,i=new yo;i.channels=e,i.size=t;const s=xo(e),a=wo(s);(this.image.width!==t||a!==this.format)&&(this.image.width=t,this.image.height=t,this.image.data=new Float32Array(t**2*s),this.format=a,this.dispose());const o=this.image.data;for(let c=0,u=e;c<u;c++){const f=i.generate(),p=f.data,r=f.maxValue;for(let l=0,h=p.length;l<h;l++){const g=p[l]/r;o[l*s+c]=g}}this.needsUpdate=!0}}const Ao=`
273
+ `})}}function ho(n,e=Math.random()){for(let t=n.length-1;t>0;t--){const i=Math.floor(e()*(t+1)),s=n[t];n[t]=n[i],n[i]=s}return n}class fo{constructor(e,t,i=Math.random){const s=e**t,a=new Uint16Array(s);let o=s;for(let c=0;c<s;c++)a[c]=c;this.samples=new Float32Array(t),this.strataCount=e,this.reset=function(){for(let c=0;c<s;c++)a[c]=c;o=0},this.reshuffle=function(){o=0},this.next=function(){const{samples:c}=this;o>=a.length&&(ho(a,i),this.reshuffle());let u=a[o++];for(let f=0;f<t;f++)c[f]=(u%e+i())/e,u=Math.floor(u/e);return c}}}class po{constructor(e,t,i=Math.random){let s=0;for(const u of t)s+=u;const a=new Float32Array(s),o=[];let c=0;for(const u of t){const f=new fo(e,u,i);f.samples=new Float32Array(a.buffer,c,f.samples.length),c+=f.samples.length*4,o.push(f)}this.samples=a,this.strataCount=e,this.next=function(){for(const u of o)u.next();return a},this.reshuffle=function(){for(const u of o)u.reshuffle()},this.reset=function(){for(const u of o)u.reset()}}}class mo{constructor(e=0){this.m=2147483648,this.a=1103515245,this.c=12345,this.seed=e}nextInt(){return this.seed=(this.a*this.seed+this.c)%this.m,this.seed}nextFloat(){return this.nextInt()/(this.m-1)}}class go extends d.DataTexture{constructor(e=1,t=1,i=8){super(new Float32Array(1),1,1,d.RGBAFormat,d.FloatType),this.minFilter=d.NearestFilter,this.magFilter=d.NearestFilter,this.strata=i,this.sampler=null,this.generator=new mo,this.stableNoise=!1,this.random=()=>this.stableNoise?this.generator.nextFloat():Math.random(),this.init(e,t,i)}init(e=this.image.height,t=this.image.width,i=this.strata){const{image:s}=this;if(s.width===t&&s.height===e&&this.sampler!==null)return;const a=new Array(e*t).fill(4),o=new po(i,a,this.random);s.width=t,s.height=e,s.data=o.samples,this.sampler=o,this.dispose(),this.next()}next(){this.sampler.next(),this.needsUpdate=!0}reset(){this.sampler.reset(),this.generator.seed=0}}function vo(n,e=Math.random){for(let t=n.length-1;t>0;t--){const i=~~((e()-1e-6)*t),s=n[t];n[t]=n[i],n[i]=s}}function _o(n,e){n.fill(0);for(let t=0;t<e;t++)n[t]=1}class Es{constructor(e){this.count=0,this.size=-1,this.sigma=-1,this.radius=-1,this.lookupTable=null,this.score=null,this.binaryPattern=null,this.resize(e),this.setSigma(1.5)}findVoid(){const{score:e,binaryPattern:t}=this;let i=1/0,s=-1;for(let a=0,o=t.length;a<o;a++){if(t[a]!==0)continue;const c=e[a];c<i&&(i=c,s=a)}return s}findCluster(){const{score:e,binaryPattern:t}=this;let i=-1/0,s=-1;for(let a=0,o=t.length;a<o;a++){if(t[a]!==1)continue;const c=e[a];c>i&&(i=c,s=a)}return s}setSigma(e){if(e===this.sigma)return;const t=~~(Math.sqrt(10*2*e**2)+1),i=2*t+1,s=new Float32Array(i*i),a=e*e;for(let o=-t;o<=t;o++)for(let c=-t;c<=t;c++){const u=(t+c)*i+o+t,f=o*o+c*c;s[u]=Math.E**(-f/(2*a))}this.lookupTable=s,this.sigma=e,this.radius=t}resize(e){this.size!==e&&(this.size=e,this.score=new Float32Array(e*e),this.binaryPattern=new Uint8Array(e*e))}invert(){const{binaryPattern:e,score:t,size:i}=this;t.fill(0);for(let s=0,a=e.length;s<a;s++)if(e[s]===0){const o=~~(s/i),c=s-o*i;this.updateScore(c,o,1),e[s]=1}else e[s]=0}updateScore(e,t,i){const{size:s,score:a,lookupTable:o}=this,c=this.radius,u=2*c+1;for(let f=-c;f<=c;f++)for(let p=-c;p<=c;p++){const r=(c+p)*u+f+c,l=o[r];let h=e+f;h=h<0?s+h:h%s;let g=t+p;g=g<0?s+g:g%s;const _=g*s+h;a[_]+=i*l}}addPointIndex(e){this.binaryPattern[e]=1;const t=this.size,i=~~(e/t),s=e-i*t;this.updateScore(s,i,1),this.count++}removePointIndex(e){this.binaryPattern[e]=0;const t=this.size,i=~~(e/t),s=e-i*t;this.updateScore(s,i,-1),this.count--}copy(e){this.resize(e.size),this.score.set(e.score),this.binaryPattern.set(e.binaryPattern),this.setSigma(e.sigma),this.count=e.count}}class yo{constructor(){this.random=Math.random,this.sigma=1.5,this.size=64,this.majorityPointsRatio=.1,this.samples=new Es(1),this.savedSamples=new Es(1)}generate(){const{samples:e,savedSamples:t,sigma:i,majorityPointsRatio:s,size:a}=this;e.resize(a),e.setSigma(i);const o=Math.floor(a*a*s),c=e.binaryPattern;_o(c,o),vo(c,this.random);for(let r=0,l=c.length;r<l;r++)c[r]===1&&e.addPointIndex(r);for(;;){const r=e.findCluster();e.removePointIndex(r);const l=e.findVoid();if(r===l){e.addPointIndex(r);break}e.addPointIndex(l)}const u=new Uint32Array(a*a);t.copy(e);let f;for(f=e.count-1;f>=0;){const r=e.findCluster();e.removePointIndex(r),u[r]=f,f--}const p=a*a;for(f=t.count;f<p/2;){const r=t.findVoid();t.addPointIndex(r),u[r]=f,f++}for(t.invert();f<p;){const r=t.findCluster();t.removePointIndex(r),u[r]=f,f++}return{data:u,maxValue:p}}}function xo(n){return n>=3?4:n}function wo(n){switch(n){case 1:return d.RedFormat;case 2:return d.RGFormat;default:return d.RGBAFormat}}class bo extends d.DataTexture{constructor(e=64,t=1){super(new Float32Array(4),1,1,d.RGBAFormat,d.FloatType),this.minFilter=d.NearestFilter,this.magFilter=d.NearestFilter,this.size=e,this.channels=t,this.update()}update(){const e=this.channels,t=this.size,i=new yo;i.channels=e,i.size=t;const s=xo(e),a=wo(s);(this.image.width!==t||a!==this.format)&&(this.image.width=t,this.image.height=t,this.image.data=new Float32Array(t**2*s),this.format=a,this.dispose());const o=this.image.data;for(let c=0,u=e;c<u;c++){const f=i.generate(),p=f.data,r=f.maxValue;for(let l=0,h=p.length;l<h;l++){const g=p[l]/r;o[l*s+c]=g}}this.needsUpdate=!0}}const Ao=`
274
274
 
275
275
  struct PhysicalCamera {
276
276
 
@@ -1283,7 +1283,7 @@
1283
1283
 
1284
1284
  }
1285
1285
 
1286
- `,mr=`
1286
+ `,gr=`
1287
1287
 
1288
1288
  // TODO: possibly this should be renamed something related to material or path tracing logic
1289
1289
 
@@ -1398,7 +1398,7 @@
1398
1398
  return x < 0.5 ? sqrt( 2.0 * x ) - 1.0 : 1.0 - sqrt( 2.0 - ( 2.0 * x ) );
1399
1399
 
1400
1400
  }
1401
- `,Es=`
1401
+ `,Fs=`
1402
1402
 
1403
1403
  // https://www.shadertoy.com/view/wltcRS
1404
1404
  uvec4 WHITE_NOISE_SEED;
@@ -3129,7 +3129,7 @@ bool bvhIntersectFogVolumeHit(
3129
3129
 
3130
3130
  }
3131
3131
 
3132
- `;class Qo extends rs{onBeforeRender(){this.setDefine("FEATURE_DOF",this.physicalCamera.bokehSize===0?0:1),this.setDefine("FEATURE_BACKGROUND_MAP",this.backgroundMap?1:0),this.setDefine("FEATURE_FOG",this.materials.features.isUsed("FOG")?1:0)}constructor(e){super({transparent:!0,depthWrite:!1,defines:{FEATURE_MIS:1,FEATURE_RUSSIAN_ROULETTE:1,FEATURE_DOF:1,FEATURE_BACKGROUND_MAP:0,FEATURE_FOG:1,RANDOM_TYPE:2,CAMERA_TYPE:0,DEBUG_MODE:0,ATTR_NORMAL:0,ATTR_TANGENT:1,ATTR_UV:2,ATTR_COLOR:3},uniforms:{resolution:{value:new d.Vector2},opacity:{value:1},bounces:{value:10},transmissiveBounces:{value:10},filterGlossyFactor:{value:0},physicalCamera:{value:new Wn},cameraWorldMatrix:{value:new d.Matrix4},invProjectionMatrix:{value:new d.Matrix4},bvh:{value:new Ce.MeshBVHUniformStruct},attributesArray:{value:new to},materialIndexAttribute:{value:new Ce.UIntVertexAttributeTexture},materials:{value:new ao},textures:{value:new Ds().texture},lights:{value:new $n},iesProfiles:{value:new Ds(360,180,{type:d.HalfFloatType,wrapS:d.ClampToEdgeWrapping,wrapT:d.ClampToEdgeWrapping}).texture},environmentIntensity:{value:1},environmentRotation:{value:new d.Matrix4},envMapInfo:{value:new jn},backgroundBlur:{value:0},backgroundMap:{value:null},backgroundAlpha:{value:1},backgroundIntensity:{value:1},backgroundRotation:{value:new d.Matrix4},seed:{value:0},sobolTexture:{value:null},stratifiedTexture:{value:new go},stratifiedOffsetTexture:{value:new bo(64,1)}},vertexShader:`
3132
+ `;class Qo extends ns{onBeforeRender(){this.setDefine("FEATURE_DOF",this.physicalCamera.bokehSize===0?0:1),this.setDefine("FEATURE_BACKGROUND_MAP",this.backgroundMap?1:0),this.setDefine("FEATURE_FOG",this.materials.features.isUsed("FOG")?1:0)}constructor(e){super({transparent:!0,depthWrite:!1,defines:{FEATURE_MIS:1,FEATURE_RUSSIAN_ROULETTE:1,FEATURE_DOF:1,FEATURE_BACKGROUND_MAP:0,FEATURE_FOG:1,RANDOM_TYPE:2,CAMERA_TYPE:0,DEBUG_MODE:0,ATTR_NORMAL:0,ATTR_TANGENT:1,ATTR_UV:2,ATTR_COLOR:3},uniforms:{resolution:{value:new d.Vector2},opacity:{value:1},bounces:{value:10},transmissiveBounces:{value:10},filterGlossyFactor:{value:0},physicalCamera:{value:new Wn},cameraWorldMatrix:{value:new d.Matrix4},invProjectionMatrix:{value:new d.Matrix4},bvh:{value:new Ce.MeshBVHUniformStruct},attributesArray:{value:new to},materialIndexAttribute:{value:new Ce.UIntVertexAttributeTexture},materials:{value:new ao},textures:{value:new Ls().texture},lights:{value:new $n},iesProfiles:{value:new Ls(360,180,{type:d.HalfFloatType,wrapS:d.ClampToEdgeWrapping,wrapT:d.ClampToEdgeWrapping}).texture},environmentIntensity:{value:1},environmentRotation:{value:new d.Matrix4},envMapInfo:{value:new jn},backgroundBlur:{value:0},backgroundMap:{value:null},backgroundAlpha:{value:1},backgroundIntensity:{value:1},backgroundRotation:{value:new d.Matrix4},seed:{value:0},sobolTexture:{value:null},stratifiedTexture:{value:new go},stratifiedOffsetTexture:{value:new bo(64,1)}},vertexShader:`
3133
3133
 
3134
3134
  varying vec2 vUv;
3135
3135
  void main() {
@@ -3171,8 +3171,8 @@ bool bvhIntersectFogVolumeHit(
3171
3171
 
3172
3172
  #elif RANDOM_TYPE == 1 // Sobol
3173
3173
 
3174
- ${Es}
3175
- ${dr}
3174
+ ${Fs}
3175
+ ${pr}
3176
3176
  ${Vn}
3177
3177
 
3178
3178
  #define rand(v) sobol(v)
@@ -3182,7 +3182,7 @@ bool bvhIntersectFogVolumeHit(
3182
3182
 
3183
3183
  #else // PCG
3184
3184
 
3185
- ${Es}
3185
+ ${Fs}
3186
3186
 
3187
3187
  // Using the sobol functions seems to break the the compiler on MacOS
3188
3188
  // - specifically the "sobolReverseBits" function.
@@ -3200,7 +3200,7 @@ bool bvhIntersectFogVolumeHit(
3200
3200
  // common
3201
3201
  ${Fo}
3202
3202
  ${Do}
3203
- ${mr}
3203
+ ${gr}
3204
3204
  ${Lo}
3205
3205
  ${Eo}
3206
3206
 
@@ -3596,7 +3596,7 @@ bool bvhIntersectFogVolumeHit(
3596
3596
 
3597
3597
  }
3598
3598
 
3599
- `}),this.setValues(e)}}function*Zo(){const{_renderer:n,_fsQuad:e,_blendQuad:t,_primaryTarget:i,_blendTargets:s,_sobolTarget:a,_subframe:o,alpha:c,material:u}=this,f=new d.Vector4,p=new d.Vector4,r=t.material;let[l,h]=s;for(;;){c?(r.opacity=this._opacityFactor/(this.samples+1),u.blending=d.NoBlending,u.opacity=1):(u.opacity=this._opacityFactor/(this.samples+1),u.blending=d.NormalBlending);const[g,_,m,v]=o,y=i.width,x=i.height;u.resolution.set(y*m,x*v),u.sobolTexture=a.texture,u.stratifiedTexture.init(20,u.bounces+u.transmissiveBounces+5),u.stratifiedTexture.next(),u.seed++;const w=this.tiles.x||1,b=this.tiles.y||1,A=w*b,T=Math.ceil(y*m),I=Math.ceil(x*v),C=Math.floor(g*y),P=Math.floor(_*x),D=Math.ceil(T/w),S=Math.ceil(I/b);for(let M=0;M<b;M++)for(let R=0;R<w;R++){const E=n.getRenderTarget(),F=n.autoClear,O=n.getScissorTest();n.getScissor(f),n.getViewport(p);let H=R,W=M;if(!this.stableTiles){const Y=this._currentTile%(w*b);H=Y%w,W=~~(Y/w),this._currentTile=Y+1}const j=b-W-1;i.scissor.set(C+H*D,P+j*S,Math.min(D,T-H*D),Math.min(S,I-j*S)),i.viewport.set(C,P,T,I),n.setRenderTarget(i),n.setScissorTest(!0),n.autoClear=!1,e.render(n),n.setViewport(p),n.setScissor(f),n.setScissorTest(O),n.setRenderTarget(E),n.autoClear=F,c&&(r.target1=l.texture,r.target2=i.texture,n.setRenderTarget(h),t.render(n),n.setRenderTarget(E)),this.samples+=1/A,R===w-1&&M===b-1&&(this.samples=Math.round(this.samples)),yield}[l,h]=[h,l]}}const Fs=new d.Color;class Bs{get material(){return this._fsQuad.material}set material(e){this._fsQuad.material.removeEventListener("recompilation",this._compileFunction),e.addEventListener("recompilation",this._compileFunction),this._fsQuad.material=e}get target(){return this._alpha?this._blendTargets[1]:this._primaryTarget}set alpha(e){this._alpha!==e&&(e||(this._blendTargets[0].dispose(),this._blendTargets[1].dispose()),this._alpha=e,this.reset())}get alpha(){return this._alpha}get isCompiling(){return!!this._compilePromise}constructor(e){this.camera=null,this.tiles=new d.Vector2(3,3),this.stableNoise=!1,this.stableTiles=!0,this.samples=0,this._subframe=new d.Vector4(0,0,1,1),this._opacityFactor=1,this._renderer=e,this._alpha=!1,this._fsQuad=new nt.FullScreenQuad(new Qo),this._blendQuad=new nt.FullScreenQuad(new On),this._task=null,this._currentTile=0,this._compilePromise=null,this._sobolTarget=new Hn().generate(e),this._primaryTarget=new d.WebGLRenderTarget(1,1,{format:d.RGBAFormat,type:d.FloatType,magFilter:d.NearestFilter,minFilter:d.NearestFilter}),this._blendTargets=[new d.WebGLRenderTarget(1,1,{format:d.RGBAFormat,type:d.FloatType,magFilter:d.NearestFilter,minFilter:d.NearestFilter}),new d.WebGLRenderTarget(1,1,{format:d.RGBAFormat,type:d.FloatType,magFilter:d.NearestFilter,minFilter:d.NearestFilter})],this._compileFunction=()=>{const t=this.compileMaterial(this._fsQuad._mesh);t.then(()=>{this._compilePromise===t&&(this._compilePromise=null)}),this._compilePromise=t},this.material.addEventListener("recompilation",this._compileFunction)}compileMaterial(){return this._renderer.compileAsync(this._fsQuad._mesh)}setCamera(e){const{material:t}=this;t.cameraWorldMatrix.copy(e.matrixWorld),t.invProjectionMatrix.copy(e.projectionMatrixInverse),t.physicalCamera.updateFrom(e);let i=0;e.projectionMatrix.elements[15]>0&&(i=1),e.isEquirectCamera&&(i=2),t.setDefine("CAMERA_TYPE",i),this.camera=e}setSize(e,t){e=Math.ceil(e),t=Math.ceil(t),!(this._primaryTarget.width===e&&this._primaryTarget.height===t)&&(this._primaryTarget.setSize(e,t),this._blendTargets[0].setSize(e,t),this._blendTargets[1].setSize(e,t),this.reset())}getSize(e){e.x=this._primaryTarget.width,e.y=this._primaryTarget.height}dispose(){this._primaryTarget.dispose(),this._blendTargets[0].dispose(),this._blendTargets[1].dispose(),this._sobolTarget.dispose(),this._fsQuad.dispose(),this._blendQuad.dispose(),this._task=null}reset(){const{_renderer:e,_primaryTarget:t,_blendTargets:i}=this,s=e.getRenderTarget(),a=e.getClearAlpha();e.getClearColor(Fs),e.setRenderTarget(t),e.setClearColor(0,0),e.clearColor(),e.setRenderTarget(i[0]),e.setClearColor(0,0),e.clearColor(),e.setRenderTarget(i[1]),e.setClearColor(0,0),e.clearColor(),e.setClearColor(Fs,a),e.setRenderTarget(s),this.samples=0,this._task=null,this.material.stratifiedTexture.stableNoise=this.stableNoise,this.stableNoise&&(this.material.seed=0,this.material.stratifiedTexture.reset())}update(){this.material.onBeforeRender(),!this.isCompiling&&(this._task||(this._task=Zo.call(this)),this._task.next())}}const Fe=new d.Vector2,ks=new d.Vector2,Ot=new d.Spherical,zt=new d.Color;class Xo extends d.DataTexture{constructor(e=512,t=512){super(new Float32Array(e*t*4),e,t,d.RGBAFormat,d.FloatType,d.EquirectangularReflectionMapping,d.RepeatWrapping,d.ClampToEdgeWrapping,d.LinearFilter,d.LinearFilter),this.generationCallback=null}update(){this.dispose(),this.needsUpdate=!0;const{data:e,width:t,height:i}=this.image;for(let s=0;s<t;s++)for(let a=0;a<i;a++){ks.set(t,i),Fe.set(s/t,a/i),Fe.x-=.5,Fe.y=1-Fe.y,Ot.theta=Fe.x*2*Math.PI,Ot.phi=Fe.y*Math.PI,Ot.radius=1,this.generationCallback(Ot,Fe,ks,zt);const c=4*(a*t+s);e[c+0]=zt.r,e[c+1]=zt.g,e[c+2]=zt.b,e[c+3]=1}}copy(e){return super.copy(e),this.generationCallback=e.generationCallback,this}}const Os=new d.Vector3;class Ko extends Xo{constructor(e=512){super(e,e),this.topColor=new d.Color().set(16777215),this.bottomColor=new d.Color().set(0),this.exponent=2,this.generationCallback=(t,i,s,a)=>{Os.setFromSpherical(t);const o=Os.y*.5+.5;a.lerpColors(this.bottomColor,this.topColor,o**this.exponent)}}copy(e){return super.copy(e),this.topColor.copy(e.topColor),this.bottomColor.copy(e.bottomColor),this}}class Jo extends d.ShaderMaterial{get map(){return this.uniforms.map.value}set map(e){this.uniforms.map.value=e}get opacity(){return this.uniforms.opacity.value}set opacity(e){this.uniforms&&(this.uniforms.opacity.value=e)}constructor(e){super({uniforms:{map:{value:null},opacity:{value:1}},vertexShader:`
3599
+ `}),this.setValues(e)}}function*Zo(){const{_renderer:n,_fsQuad:e,_blendQuad:t,_primaryTarget:i,_blendTargets:s,_sobolTarget:a,_subframe:o,alpha:c,material:u}=this,f=new d.Vector4,p=new d.Vector4,r=t.material;let[l,h]=s;for(;;){c?(r.opacity=this._opacityFactor/(this.samples+1),u.blending=d.NoBlending,u.opacity=1):(u.opacity=this._opacityFactor/(this.samples+1),u.blending=d.NormalBlending);const[g,_,m,v]=o,y=i.width,x=i.height;u.resolution.set(y*m,x*v),u.sobolTexture=a.texture,u.stratifiedTexture.init(20,u.bounces+u.transmissiveBounces+5),u.stratifiedTexture.next(),u.seed++;const w=this.tiles.x||1,b=this.tiles.y||1,A=w*b,T=Math.ceil(y*m),I=Math.ceil(x*v),C=Math.floor(g*y),P=Math.floor(_*x),D=Math.ceil(T/w),S=Math.ceil(I/b);for(let M=0;M<b;M++)for(let R=0;R<w;R++){const E=n.getRenderTarget(),F=n.autoClear,O=n.getScissorTest();n.getScissor(f),n.getViewport(p);let H=R,W=M;if(!this.stableTiles){const Y=this._currentTile%(w*b);H=Y%w,W=~~(Y/w),this._currentTile=Y+1}const j=b-W-1;i.scissor.set(C+H*D,P+j*S,Math.min(D,T-H*D),Math.min(S,I-j*S)),i.viewport.set(C,P,T,I),n.setRenderTarget(i),n.setScissorTest(!0),n.autoClear=!1,e.render(n),n.setViewport(p),n.setScissor(f),n.setScissorTest(O),n.setRenderTarget(E),n.autoClear=F,c&&(r.target1=l.texture,r.target2=i.texture,n.setRenderTarget(h),t.render(n),n.setRenderTarget(E)),this.samples+=1/A,R===w-1&&M===b-1&&(this.samples=Math.round(this.samples)),yield}[l,h]=[h,l]}}const Bs=new d.Color;class ks{get material(){return this._fsQuad.material}set material(e){this._fsQuad.material.removeEventListener("recompilation",this._compileFunction),e.addEventListener("recompilation",this._compileFunction),this._fsQuad.material=e}get target(){return this._alpha?this._blendTargets[1]:this._primaryTarget}set alpha(e){this._alpha!==e&&(e||(this._blendTargets[0].dispose(),this._blendTargets[1].dispose()),this._alpha=e,this.reset())}get alpha(){return this._alpha}get isCompiling(){return!!this._compilePromise}constructor(e){this.camera=null,this.tiles=new d.Vector2(3,3),this.stableNoise=!1,this.stableTiles=!0,this.samples=0,this._subframe=new d.Vector4(0,0,1,1),this._opacityFactor=1,this._renderer=e,this._alpha=!1,this._fsQuad=new ot.FullScreenQuad(new Qo),this._blendQuad=new ot.FullScreenQuad(new On),this._task=null,this._currentTile=0,this._compilePromise=null,this._sobolTarget=new Hn().generate(e),this._primaryTarget=new d.WebGLRenderTarget(1,1,{format:d.RGBAFormat,type:d.FloatType,magFilter:d.NearestFilter,minFilter:d.NearestFilter}),this._blendTargets=[new d.WebGLRenderTarget(1,1,{format:d.RGBAFormat,type:d.FloatType,magFilter:d.NearestFilter,minFilter:d.NearestFilter}),new d.WebGLRenderTarget(1,1,{format:d.RGBAFormat,type:d.FloatType,magFilter:d.NearestFilter,minFilter:d.NearestFilter})],this._compileFunction=()=>{const t=this.compileMaterial(this._fsQuad._mesh);t.then(()=>{this._compilePromise===t&&(this._compilePromise=null)}),this._compilePromise=t},this.material.addEventListener("recompilation",this._compileFunction)}compileMaterial(){return this._renderer.compileAsync(this._fsQuad._mesh)}setCamera(e){const{material:t}=this;t.cameraWorldMatrix.copy(e.matrixWorld),t.invProjectionMatrix.copy(e.projectionMatrixInverse),t.physicalCamera.updateFrom(e);let i=0;e.projectionMatrix.elements[15]>0&&(i=1),e.isEquirectCamera&&(i=2),t.setDefine("CAMERA_TYPE",i),this.camera=e}setSize(e,t){e=Math.ceil(e),t=Math.ceil(t),!(this._primaryTarget.width===e&&this._primaryTarget.height===t)&&(this._primaryTarget.setSize(e,t),this._blendTargets[0].setSize(e,t),this._blendTargets[1].setSize(e,t),this.reset())}getSize(e){e.x=this._primaryTarget.width,e.y=this._primaryTarget.height}dispose(){this._primaryTarget.dispose(),this._blendTargets[0].dispose(),this._blendTargets[1].dispose(),this._sobolTarget.dispose(),this._fsQuad.dispose(),this._blendQuad.dispose(),this._task=null}reset(){const{_renderer:e,_primaryTarget:t,_blendTargets:i}=this,s=e.getRenderTarget(),a=e.getClearAlpha();e.getClearColor(Bs),e.setRenderTarget(t),e.setClearColor(0,0),e.clearColor(),e.setRenderTarget(i[0]),e.setClearColor(0,0),e.clearColor(),e.setRenderTarget(i[1]),e.setClearColor(0,0),e.clearColor(),e.setClearColor(Bs,a),e.setRenderTarget(s),this.samples=0,this._task=null,this.material.stratifiedTexture.stableNoise=this.stableNoise,this.stableNoise&&(this.material.seed=0,this.material.stratifiedTexture.reset())}update(){this.material.onBeforeRender(),!this.isCompiling&&(this._task||(this._task=Zo.call(this)),this._task.next())}}const Fe=new d.Vector2,Os=new d.Vector2,Ot=new d.Spherical,zt=new d.Color;class Xo extends d.DataTexture{constructor(e=512,t=512){super(new Float32Array(e*t*4),e,t,d.RGBAFormat,d.FloatType,d.EquirectangularReflectionMapping,d.RepeatWrapping,d.ClampToEdgeWrapping,d.LinearFilter,d.LinearFilter),this.generationCallback=null}update(){this.dispose(),this.needsUpdate=!0;const{data:e,width:t,height:i}=this.image;for(let s=0;s<t;s++)for(let a=0;a<i;a++){Os.set(t,i),Fe.set(s/t,a/i),Fe.x-=.5,Fe.y=1-Fe.y,Ot.theta=Fe.x*2*Math.PI,Ot.phi=Fe.y*Math.PI,Ot.radius=1,this.generationCallback(Ot,Fe,Os,zt);const c=4*(a*t+s);e[c+0]=zt.r,e[c+1]=zt.g,e[c+2]=zt.b,e[c+3]=1}}copy(e){return super.copy(e),this.generationCallback=e.generationCallback,this}}const zs=new d.Vector3;class Ko extends Xo{constructor(e=512){super(e,e),this.topColor=new d.Color().set(16777215),this.bottomColor=new d.Color().set(0),this.exponent=2,this.generationCallback=(t,i,s,a)=>{zs.setFromSpherical(t);const o=zs.y*.5+.5;a.lerpColors(this.bottomColor,this.topColor,o**this.exponent)}}copy(e){return super.copy(e),this.topColor.copy(e.topColor),this.bottomColor.copy(e.bottomColor),this}}class Jo extends d.ShaderMaterial{get map(){return this.uniforms.map.value}set map(e){this.uniforms.map.value=e}get opacity(){return this.uniforms.opacity.value}set opacity(e){this.uniforms&&(this.uniforms.opacity.value=e)}constructor(e){super({uniforms:{map:{value:null},opacity:{value:1}},vertexShader:`
3600
3600
  varying vec2 vUv;
3601
3601
  void main() {
3602
3602
 
@@ -3670,7 +3670,7 @@ bool bvhIntersectFogVolumeHit(
3670
3670
  #include <common>
3671
3671
  #include <cube_uv_reflection_fragment>
3672
3672
 
3673
- ${mr}
3673
+ ${gr}
3674
3674
 
3675
3675
  void main() {
3676
3676
 
@@ -3678,14 +3678,14 @@ bool bvhIntersectFogVolumeHit(
3678
3678
  rayDirection.x *= flipEnvMap;
3679
3679
  gl_FragColor = textureCube( envMap, rayDirection );
3680
3680
 
3681
- }`}),this.depthWrite=!1,this.depthTest=!1}}class zs{constructor(e){this._renderer=e,this._quad=new nt.FullScreenQuad(new $o)}generate(e,t=null,i=null){if(!e.isCubeTexture)throw new Error("CubeToEquirectMaterial: Source can only be cube textures.");const s=e.images[0],a=this._renderer,o=this._quad;t===null&&(t=4*s.height),i===null&&(i=2*s.height);const c=new d.WebGLRenderTarget(t,i,{type:d.FloatType,colorSpace:s.colorSpace}),u=s.height,f=Math.log2(u)-2,p=1/u,r=1/(3*Math.max(Math.pow(2,f),7*16));o.material.defines.CUBEUV_MAX_MIP=`${f}.0`,o.material.defines.CUBEUV_TEXEL_WIDTH=r,o.material.defines.CUBEUV_TEXEL_HEIGHT=p,o.material.uniforms.envMap.value=e,o.material.uniforms.flipEnvMap.value=e.isRenderTargetTexture?1:-1,o.material.needsUpdate=!0;const l=a.getRenderTarget(),h=a.autoClear;a.autoClear=!0,a.setRenderTarget(c),o.render(a),a.setRenderTarget(l),a.autoClear=h;const g=new Uint16Array(t*i*4),_=new Float32Array(t*i*4);a.readRenderTargetPixels(c,0,0,t,i,_),c.dispose();for(let v=0,y=_.length;v<y;v++)g[v]=d.DataUtils.toHalfFloat(_[v]);const m=new d.DataTexture(g,t,i,d.RGBAFormat,d.HalfFloatType);return m.minFilter=d.LinearMipMapLinearFilter,m.magFilter=d.LinearFilter,m.wrapS=d.RepeatWrapping,m.wrapT=d.RepeatWrapping,m.mapping=d.EquirectangularReflectionMapping,m.needsUpdate=!0,m}dispose(){this._quad.dispose()}}function ea(n){return n.extensions.get("EXT_float_blend")}const Ue=new d.Vector2;class ta{get multipleImportanceSampling(){return!!this._pathTracer.material.defines.FEATURE_MIS}set multipleImportanceSampling(e){this._pathTracer.material.setDefine("FEATURE_MIS",e?1:0)}get transmissiveBounces(){return this._pathTracer.material.transmissiveBounces}set transmissiveBounces(e){this._pathTracer.material.transmissiveBounces=e}get bounces(){return this._pathTracer.material.bounces}set bounces(e){this._pathTracer.material.bounces=e}get filterGlossyFactor(){return this._pathTracer.material.filterGlossyFactor}set filterGlossyFactor(e){this._pathTracer.material.filterGlossyFactor=e}get samples(){return this._pathTracer.samples}get target(){return this._pathTracer.target}get tiles(){return this._pathTracer.tiles}get stableNoise(){return this._pathTracer.stableNoise}set stableNoise(e){this._pathTracer.stableNoise=e}get isCompiling(){return!!this._pathTracer.isCompiling}constructor(e){this._renderer=e,this._generator=new kn,this._pathTracer=new Bs(e),this._queueReset=!1,this._clock=new d.Clock,this._compilePromise=null,this._lowResPathTracer=new Bs(e),this._lowResPathTracer.tiles.set(1,1),this._quad=new nt.FullScreenQuad(new Jo({map:null,transparent:!0,blending:d.NoBlending,premultipliedAlpha:e.getContextAttributes().premultipliedAlpha})),this._materials=null,this._previousEnvironment=null,this._previousBackground=null,this._internalBackground=null,this.renderDelay=100,this.minSamples=5,this.fadeDuration=500,this.enablePathTracing=!0,this.pausePathTracing=!1,this.dynamicLowRes=!1,this.lowResScale=.25,this.renderScale=1,this.synchronizeRenderSize=!0,this.rasterizeScene=!0,this.renderToCanvas=!0,this.textureSize=new d.Vector2(1024,1024),this.rasterizeSceneCallback=(t,i)=>{this._renderer.render(t,i)},this.renderToCanvasCallback=(t,i,s)=>{const a=i.autoClear;i.autoClear=!1,s.render(i),i.autoClear=a},this.setScene(new d.Scene,new d.PerspectiveCamera)}setBVHWorker(e){this._generator.setBVHWorker(e)}setScene(e,t,i={}){e.updateMatrixWorld(!0),t.updateMatrixWorld();const s=this._generator;if(s.setObjects(e),this._buildAsync)return s.generateAsync(i.onProgress).then(a=>this._updateFromResults(e,t,a));{const a=s.generate();return this._updateFromResults(e,t,a)}}setSceneAsync(...e){this._buildAsync=!0;const t=this.setScene(...e);return this._buildAsync=!1,t}setCamera(e){this.camera=e,this.updateCamera()}updateCamera(){const e=this.camera;e.updateMatrixWorld(),this._pathTracer.setCamera(e),this._lowResPathTracer.setCamera(e),this.reset()}updateMaterials(){const e=this._pathTracer.material,t=this._renderer,i=this._materials,s=this.textureSize,a=ro(i);e.textures.setTextures(t,a,s.x,s.y),e.materials.updateFrom(i,a),this.reset()}updateLights(){const e=this.scene,t=this._renderer,i=this._pathTracer.material,s=no(e),a=so(s);i.lights.updateFrom(s,a),i.iesProfiles.setTextures(t,a),this.reset()}updateEnvironment(){const e=this.scene,t=this._pathTracer.material;if(this._internalBackground&&(this._internalBackground.dispose(),this._internalBackground=null),t.backgroundBlur=e.backgroundBlurriness,t.backgroundIntensity=e.backgroundIntensity??1,t.backgroundRotation.makeRotationFromEuler(e.backgroundRotation).invert(),e.background===null)t.backgroundMap=null,t.backgroundAlpha=0;else if(e.background.isColor){this._colorBackground=this._colorBackground||new Ko(16);const i=this._colorBackground;i.topColor.equals(e.background)||(i.topColor.set(e.background),i.bottomColor.set(e.background),i.update()),t.backgroundMap=i,t.backgroundAlpha=1}else if(e.background.isCubeTexture){if(e.background!==this._previousBackground){const i=new zs(this._renderer).generate(e.background);this._internalBackground=i,t.backgroundMap=i,t.backgroundAlpha=1}}else t.backgroundMap=e.background,t.backgroundAlpha=1;if(t.environmentIntensity=e.environmentIntensity??1,t.environmentRotation.makeRotationFromEuler(e.environmentRotation).invert(),this._previousEnvironment!==e.environment)if(e.environment!==null)if(e.environment.isCubeTexture){const i=new zs(this._renderer).generate(e.environment);t.envMapInfo.updateFrom(i)}else t.envMapInfo.updateFrom(e.environment);else t.environmentIntensity=0;this._previousEnvironment=e.environment,this._previousBackground=e.background,this.reset()}_updateFromResults(e,t,i){const{materials:s,geometry:a,bvh:o,bvhChanged:c}=i;this._materials=s;const f=this._pathTracer.material;return c&&(f.bvh.updateFrom(o),f.attributesArray.updateFrom(a.attributes.normal,a.attributes.tangent,a.attributes.uv,a.attributes.color),f.materialIndexAttribute.updateFrom(a.attributes.materialIndex)),this._previousScene=e,this.scene=e,this.camera=t,this.updateCamera(),this.updateMaterials(),this.updateEnvironment(),this.updateLights(),i}renderSample(){const e=this._lowResPathTracer,t=this._pathTracer,i=this._renderer,s=this._clock,a=this._quad;this._updateScale(),this._queueReset&&(t.reset(),e.reset(),this._queueReset=!1,a.material.opacity=0,s.start());const o=s.getDelta()*1e3,c=s.getElapsedTime()*1e3;if(!this.pausePathTracing&&this.enablePathTracing&&this.renderDelay<=c&&!this.isCompiling&&t.update(),t.alpha=t.material.backgroundAlpha!==1||!ea(i),e.alpha=t.alpha,this.renderToCanvas){const u=this._renderer,f=this.minSamples;if(c>=this.renderDelay&&this.samples>=this.minSamples&&(this.fadeDuration!==0?a.material.opacity=Math.min(a.material.opacity+o/this.fadeDuration,1):a.material.opacity=1),!this.enablePathTracing||this.samples<f||a.material.opacity<1){if(this.dynamicLowRes&&!this.isCompiling){e.samples<1&&(e.material=t.material,e.update());const p=a.material.opacity;a.material.opacity=1-a.material.opacity,a.material.map=e.target.texture,a.render(u),a.material.opacity=p}(!this.dynamicLowRes&&this.rasterizeScene||this.dynamicLowRes&&this.isCompiling)&&this.rasterizeSceneCallback(this.scene,this.camera)}this.enablePathTracing&&a.material.opacity>0&&(a.material.opacity<1&&(a.material.blending=this.dynamicLowRes?d.AdditiveBlending:d.NormalBlending),a.material.map=t.target.texture,this.renderToCanvasCallback(t.target,u,a),a.material.blending=d.NoBlending)}}reset(){this._queueReset=!0,this._pathTracer.samples=0}dispose(){this._renderQuad.dispose(),this._renderQuad.material.dispose(),this._pathTracer.dispose()}_updateScale(){if(this.synchronizeRenderSize){this._renderer.getDrawingBufferSize(Ue);const e=Math.floor(this.renderScale*Ue.x),t=Math.floor(this.renderScale*Ue.y);if(this._pathTracer.getSize(Ue),Ue.x!==e||Ue.y!==t){const i=this.lowResScale;this._pathTracer.setSize(e,t),this._lowResPathTracer.setSize(Math.floor(e*i),Math.floor(t*i))}}}}const ia="";globalThis.GLTF_PROGRESSIVE_VERSION=ia;console.debug("[gltf-progressive] version -");let le="https://www.gstatic.com/draco/versioned/decoders/1.5.7/",ci="https://cdn.needle.tools/static/three/0.179.1/basis2/";const sa=le,ra=ci,gr=new URL(le+"draco_decoder.js");gr.searchParams.append("range","true");fetch(gr,{method:"GET",headers:{Range:"bytes=0-1"}}).catch(n=>{console.debug(`Failed to fetch remote Draco decoder from ${le} (offline: ${typeof navigator<"u"?navigator.onLine:"unknown"})`),le===sa&&oa("./include/draco/"),ci===ra&&aa("./include/ktx2/")}).finally(()=>{_r()});const na=()=>({dracoDecoderPath:le,ktx2TranscoderPath:ci});function oa(n){le=n,$&&$[Oi]!=le?(console.debug("Updating Draco decoder path to "+n),$[Oi]=le,$.setDecoderPath(le),$.preload()):console.debug("Setting Draco decoder path to "+n)}function aa(n){ci=n}function os(n){return _r(),{dracoLoader:$,meshoptDecoder:ri}}function vr(n){n.dracoLoader||n.setDRACOLoader($),n.meshoptDecoder||n.setMeshoptDecoder(ri)}const Oi=Symbol("dracoDecoderPath");let $,ri;function _r(){$||($=new an.DRACOLoader,$[Oi]=le,$.setDecoderPath(le),$.setDecoderConfig({type:"js"}),$.preload()),ri||(ri=on.MeshoptDecoder)}const zi=new WeakMap;function yr(n,e){let t=zi.get(n);t?t=Object.assign(t,e):t=e,zi.set(n,t)}const yi=is.GLTFLoader.prototype.load;function la(...n){const e=zi.get(this);let t=n[0];const i=new URL(t,window.location.href);if(i.hostname.endsWith("needle.tools")){const a=(e==null?void 0:e.progressive)!==void 0?e.progressive:!0,o=e!=null&&e.usecase?e.usecase:"default";a?this.requestHeader.Accept=`*/*;progressive=allowed;usecase=${o}`:this.requestHeader.Accept=`*/*;usecase=${o}`,t=i.toString()}return n[0]=t,yi==null?void 0:yi.call(this,...n)}is.GLTFLoader.prototype.load=la;Oe("debugprogressive");function Oe(n){if(typeof window>"u")return!1;const t=new URL(window.location.href).searchParams.get(n);return t==null||t==="0"||t==="false"?!1:t===""?!0:t}function ca(n,e){if(e===void 0||n===void 0||e.startsWith("./")||e.startsWith("http")||e.startsWith("data:")||e.startsWith("blob:"))return e;const t=n.lastIndexOf("/");if(t>=0){const i=n.substring(0,t+1);for(;i.endsWith("/")&&e.startsWith("/");)e=e.substring(1);return i+e}return e}function xr(){return dt!==void 0||(dt=/iPhone|iPad|iPod|Android|IEMobile/i.test(navigator.userAgent),Oe("debugprogressive")&&console.log("[glTF Progressive]: isMobileDevice",dt)),dt}let dt;function Vs(){if(typeof window>"u")return!1;const n=new URL(window.location.href),e=n.hostname==="localhost"||/^\d{1,3}\.\d{1,3}\.\d{1,3}\.\d{1,3}$/.test(n.hostname);return n.hostname==="127.0.0.1"||e}class ua{constructor(e=100,t={}){L(this,"_running",new Map);L(this,"_queue",[]);L(this,"debug",!1);L(this,"tick",()=>{this.internalUpdate(),setTimeout(this.tick,10)});this.maxConcurrent=e,this.debug=t.debug??!1,window.requestAnimationFrame(this.tick)}slot(e){return this.debug&&console.debug(`[PromiseQueue]: Requesting slot for key ${e}, running: ${this._running.size}, waiting: ${this._queue.length}`),new Promise(t=>{this._queue.push({key:e,resolve:t})})}add(e,t){this._running.has(e)||(this._running.set(e,t),t.finally(()=>{this._running.delete(e),this.debug&&console.debug(`[PromiseQueue]: Promise finished now running: ${this._running.size}, waiting: ${this._queue.length}. (finished ${e})`)}),this.debug&&console.debug(`[PromiseQueue]: Added new promise, now running: ${this._running.size}, waiting: ${this._queue.length}. (added ${e})`))}internalUpdate(){const e=this.maxConcurrent-this._running.size;for(let t=0;t<e&&this._queue.length>0;t++){this.debug&&console.debug(`[PromiseQueue]: Running ${this._running.size} promises, waiting for ${this._queue.length} more.`);const{key:i,resolve:s}=this._queue.shift();s({use:a=>this.add(i,a)})}}}const ha=typeof window>"u"&&typeof document>"u",Vi=Symbol("needle:raycast-mesh");function Lt(n){return(n==null?void 0:n[Vi])instanceof d.BufferGeometry?n[Vi]:null}function fa(n,e){if((n.type==="Mesh"||n.type==="SkinnedMesh")&&!Lt(n)){const i=pa(e);i.userData={isRaycastMesh:!0},n[Vi]=i}}function da(n=!0){if(n){if(pt)return;const e=pt=d.Mesh.prototype.raycast;d.Mesh.prototype.raycast=function(t,i){const s=this,a=Lt(s);let o;a&&s.isMesh&&(o=s.geometry,s.geometry=a),e.call(this,t,i),o&&(s.geometry=o)}}else{if(!pt)return;d.Mesh.prototype.raycast=pt,pt=null}}let pt=null;function pa(n){const e=new d.BufferGeometry;for(const t in n.attributes)e.setAttribute(t,n.getAttribute(t));return e.setIndex(n.getIndex()),e}const Se=new Array,k=Oe("debugprogressive");let Ct,Be=-1;if(k){let n=function(){Be+=1,Be>=e&&(Be=-1),console.log(`Toggle LOD level [${Be}]`)},e=6;window.addEventListener("keyup",t=>{t.key==="p"&&n(),t.key==="w"&&(Ct=!Ct,console.log(`Toggle wireframe [${Ct}]`));const i=parseInt(t.key);!isNaN(i)&&i>=0&&(Be=i,console.log(`Set LOD level to [${Be}]`))})}function wr(n){if(k&&Ct!==void 0)if(Array.isArray(n))for(const e of n)wr(e);else n&&"wireframe"in n&&(n.wireframe=Ct===!0)}const mt=new Array;let ma=0;const ga=xr()?2:10;function va(n){if(mt.length<ga){const i=mt.length;k&&console.warn(`[Worker] Creating new worker #${i}`);const s=as.createWorker(n||{});return mt.push(s),s}const e=ma++%mt.length;return mt[e]}class as{constructor(e,t){L(this,"_running",[]);L(this,"_webglRenderer",null);L(this,"_debug",!1);this.worker=e,this._debug=t.debug??!1,e.onmessage=i=>{const s=i.data;switch(this._debug&&console.log("[Worker] EVENT",s),s.type){case"loaded-gltf":for(const a of this._running)if(a.url===s.result.url){_a(s.result),a.resolve(s.result);const o=a.url;o.startsWith("blob:")&&URL.revokeObjectURL(o)}}},e.onerror=i=>{console.error("[Worker] Error in gltf-progressive worker:",i)},e.postMessage({type:"init"})}static async createWorker(e){const t=new Worker(new URL(""+(typeof document>"u"?require("url").pathToFileURL(__dirname+"/assets/loader.worker-fysOIq2s.js").href:new URL("assets/loader.worker-fysOIq2s.js",document.currentScript&&document.currentScript.src||document.baseURI).href),typeof document>"u"?require("url").pathToFileURL(__filename).href:ot&&ot.src||new URL("shop-components.cjs",document.baseURI).href),{type:"module"});return new as(t,e)}async load(e,t){const i=na();let s=t==null?void 0:t.renderer;s||(this._webglRenderer??(this._webglRenderer=(async()=>{const{WebGLRenderer:f}=await import("three");return new f})()),s=await this._webglRenderer);const c=os().ktx2Loader.workerConfig;e instanceof URL?e=e.toString():e.startsWith("file:")?e=URL.createObjectURL(new Blob([e])):!e.startsWith("blob:")&&!e.startsWith("http:")&&!e.startsWith("https:")&&(e=new URL(e,window.location.href).toString());const u={type:"load",url:e,dracoDecoderPath:i.dracoDecoderPath,ktx2TranscoderPath:i.ktx2TranscoderPath,ktx2LoaderConfig:c};return this._debug&&console.debug("[Worker] Sending load request",u),this.worker.postMessage(u),new Promise(f=>{this._running.push({url:e.toString(),resolve:f})})}}function _a(n){var e,t,i,s,a,o,c,u,f,p,r,l,h,g,_,m;for(const v of n.geometries){const y=v.geometry,x=new d.BufferGeometry;if(x.name=y.name||"",y.index){const w=y.index;x.setIndex(xi(w))}for(const w in y.attributes){const b=y.attributes[w],A=xi(b);x.setAttribute(w,A)}if(y.morphAttributes)for(const w in y.morphAttributes){const A=y.morphAttributes[w].map(T=>xi(T));x.morphAttributes[w]=A}if(x.morphTargetsRelative=y.morphTargetsRelative??!1,x.boundingBox=new d.Box3,x.boundingBox.min=new d.Vector3((e=y.boundingBox)==null?void 0:e.min.x,(t=y.boundingBox)==null?void 0:t.min.y,(i=y.boundingBox)==null?void 0:i.min.z),x.boundingBox.max=new d.Vector3((s=y.boundingBox)==null?void 0:s.max.x,(a=y.boundingBox)==null?void 0:a.max.y,(o=y.boundingBox)==null?void 0:o.max.z),x.boundingSphere=new d.Sphere(new d.Vector3((c=y.boundingSphere)==null?void 0:c.center.x,(u=y.boundingSphere)==null?void 0:u.center.y,(f=y.boundingSphere)==null?void 0:f.center.z),(p=y.boundingSphere)==null?void 0:p.radius),y.groups)for(const w of y.groups)x.addGroup(w.start,w.count,w.materialIndex);y.userData&&(x.userData=y.userData),v.geometry=x}for(const v of n.textures){const y=v.texture;let x=null;if(y.isCompressedTexture){const w=y.mipmaps,b=((r=y.image)==null?void 0:r.width)||((h=(l=y.source)==null?void 0:l.data)==null?void 0:h.width)||-1,A=((g=y.image)==null?void 0:g.height)||((m=(_=y.source)==null?void 0:_.data)==null?void 0:m.height)||-1;x=new d.CompressedTexture(w,b,A,y.format,y.type,y.mapping,y.wrapS,y.wrapT,y.magFilter,y.minFilter,y.anisotropy,y.colorSpace)}else x=new d.Texture(y.image,y.mapping,y.wrapS,y.wrapT,y.magFilter,y.minFilter,y.format,y.type,y.anisotropy,y.colorSpace),x.mipmaps=y.mipmaps,x.channel=y.channel,x.source.data=y.source.data,x.flipY=y.flipY,x.premultiplyAlpha=y.premultiplyAlpha,x.unpackAlignment=y.unpackAlignment,x.matrix=new d.Matrix3(...y.matrix.elements);if(!x){console.error("[Worker] Failed to create new texture from received data. Texture is not a CompressedTexture or Texture.");continue}v.texture=x}return n}function xi(n){let e=n;if("isInterleavedBufferAttribute"in n&&n.isInterleavedBufferAttribute){const t=n.data,i=t.array,s=new d.InterleavedBuffer(i,t.stride);e=new d.InterleavedBufferAttribute(s,n.itemSize,i.byteOffset,n.normalized),e.offset=n.offset}else"isBufferAttribute"in n&&n.isBufferAttribute&&(e=new d.BufferAttribute(n.array,n.itemSize,n.normalized),e.usage=n.usage,e.gpuType=n.gpuType,e.updateRanges=n.updateRanges);return e}const ya=Oe("gltf-progressive-worker"),xa=Oe("gltf-progressive-reduce-mipmaps"),wi=Symbol("needle-progressive-texture"),ge="NEEDLE_progressive",B=class B{constructor(e){L(this,"parser");L(this,"url");L(this,"_isLoadingMesh");L(this,"loadMesh",e=>{var i,s;if(this._isLoadingMesh)return null;const t=(s=(i=this.parser.json.meshes[e])==null?void 0:i.extensions)==null?void 0:s[ge];return t?(this._isLoadingMesh=!0,this.parser.getDependency("mesh",e).then(a=>{var o;return this._isLoadingMesh=!1,a&&B.registerMesh(this.url,t.guid,a,(o=t.lods)==null?void 0:o.length,0,t),a})):null});const t=e.options.path;k&&console.log("Progressive extension registered for",t),this.parser=e,this.url=t}get name(){return ge}static getMeshLODExtension(e){const t=this.getAssignedLODInformation(e);return t!=null&&t.key?this.lodInfos.get(t.key):null}static getPrimitiveIndex(e){var i;const t=(i=this.getAssignedLODInformation(e))==null?void 0:i.index;return t??-1}static getMaterialMinMaxLODsCount(e,t){const i=this,s="LODS:minmax",a=e[s];if(a!=null)return a;if(t||(t={min_count:1/0,max_count:0,lods:[]}),Array.isArray(e)){for(const c of e)this.getMaterialMinMaxLODsCount(c,t);return e[s]=t,t}if(k==="verbose"&&console.log("getMaterialMinMaxLODsCount",e),e.type==="ShaderMaterial"||e.type==="RawShaderMaterial"){const c=e;for(const u of Object.keys(c.uniforms)){const f=c.uniforms[u].value;(f==null?void 0:f.isTexture)===!0&&o(f,t)}}else if(e.isMaterial)for(const c of Object.keys(e)){const u=e[c];(u==null?void 0:u.isTexture)===!0&&o(u,t)}else k&&console.warn(`[getMaterialMinMaxLODsCount] Unsupported material type: ${e.type}`);return e[s]=t,t;function o(c,u){const f=i.getAssignedLODInformation(c);if(f){const p=i.lodInfos.get(f.key);if(p&&p.lods){u.min_count=Math.min(u.min_count,p.lods.length),u.max_count=Math.max(u.max_count,p.lods.length);for(let r=0;r<p.lods.length;r++){const l=p.lods[r];l.width&&(u.lods[r]=u.lods[r]||{min_height:1/0,max_height:0},u.lods[r].min_height=Math.min(u.lods[r].min_height,l.height),u.lods[r].max_height=Math.max(u.lods[r].max_height,l.height))}}}}}static hasLODLevelAvailable(e,t){var a;if(Array.isArray(e)){for(const o of e)if(this.hasLODLevelAvailable(o,t))return!0;return!1}if(e.isMaterial===!0){for(const o of Object.keys(e)){const c=e[o];if(c&&c.isTexture&&this.hasLODLevelAvailable(c,t))return!0}return!1}else if(e.isGroup===!0){for(const o of e.children)if(o.isMesh===!0&&this.hasLODLevelAvailable(o,t))return!0}let i,s;if(e.isMesh?i=e.geometry:(e.isBufferGeometry||e.isTexture)&&(i=e),i&&(a=i==null?void 0:i.userData)!=null&&a.LODS){const o=i.userData.LODS;if(s=this.lodInfos.get(o.key),t===void 0)return s!=null;if(s)return Array.isArray(s.lods)?t<s.lods.length:t===0}return!1}static assignMeshLOD(e,t){var i;if(!e)return Promise.resolve(null);if(e instanceof d.Mesh||e.isMesh===!0){const s=e.geometry,a=this.getAssignedLODInformation(s);if(!a)return Promise.resolve(null);for(const o of Se)(i=o.onBeforeGetLODMesh)==null||i.call(o,e,t);return e["LOD:requested level"]=t,B.getOrLoadLOD(s,t).then(o=>{if(Array.isArray(o)){const c=a.index||0;o=o[c]}return e["LOD:requested level"]===t&&(delete e["LOD:requested level"],o&&s!=o&&((o==null?void 0:o.isBufferGeometry)?e.geometry=o:k&&console.error("Invalid LOD geometry",o))),o}).catch(o=>(console.error("Error loading mesh LOD",e,o),null))}else k&&console.error("Invalid call to assignMeshLOD: Request mesh LOD but the object is not a mesh",e);return Promise.resolve(null)}static assignTextureLOD(e,t=0){if(!e)return Promise.resolve(null);if(e.isMesh===!0){const i=e;if(Array.isArray(i.material)){const s=new Array;for(const a of i.material){const o=this.assignTextureLOD(a,t);s.push(o)}return Promise.all(s).then(a=>{const o=new Array;for(const c of a)Array.isArray(c)&&o.push(...c);return o})}else return this.assignTextureLOD(i.material,t)}if(e.isMaterial===!0){const i=e,s=[],a=new Array;if(i.uniforms&&(i.isRawShaderMaterial||i.isShaderMaterial===!0)){const o=i;for(const c of Object.keys(o.uniforms)){const u=o.uniforms[c].value;if((u==null?void 0:u.isTexture)===!0){const f=this.assignTextureLODForSlot(u,t,i,c).then(p=>(p&&o.uniforms[c].value!=p&&(o.uniforms[c].value=p,o.uniformsNeedUpdate=!0),p));s.push(f),a.push(c)}}}else for(const o of Object.keys(i)){const c=i[o];if((c==null?void 0:c.isTexture)===!0){const u=this.assignTextureLODForSlot(c,t,i,o);s.push(u),a.push(o)}}return Promise.all(s).then(o=>{const c=new Array;for(let u=0;u<o.length;u++){const f=o[u],p=a[u];f&&f.isTexture===!0?c.push({material:i,slot:p,texture:f,level:t}):c.push({material:i,slot:p,texture:null,level:t})}return c})}if(e instanceof d.Texture||e.isTexture===!0){const i=e;return this.assignTextureLODForSlot(i,t,null,null)}return Promise.resolve(null)}static assignTextureLODForSlot(e,t,i,s){return(e==null?void 0:e.isTexture)!==!0?Promise.resolve(null):s==="glyphMap"?Promise.resolve(e):B.getOrLoadLOD(e,t).then(a=>{var o,c;if(Array.isArray(a))return console.warn("Progressive: Got an array of textures for a texture slot, this should not happen..."),null;if((a==null?void 0:a.isTexture)===!0){if(a!=e&&i&&s){const u=i[s];if(u&&!k){const f=this.getAssignedLODInformation(u);if(f&&(f==null?void 0:f.level)<t)return k==="verbose"&&console.warn("Assigned texture level is already higher: ",f.level,t,i,u,a),null}if(xa&&a.mipmaps){const f=a.mipmaps.length;a.mipmaps.length=Math.min(a.mipmaps.length,3),f!==a.mipmaps.length&&k&&console.debug(`Reduced mipmap count from ${f} to ${a.mipmaps.length} for ${a.uuid}: ${(o=a.image)==null?void 0:o.width}x${(c=a.image)==null?void 0:c.height}.`)}i[s]=a}return a}else k=="verbose"&&console.warn("No LOD found for",e,t);return null}).catch(a=>(console.error("Error loading LOD",e,a),null))}afterRoot(e){var t,i;return k&&console.log("AFTER",this.url,e),(t=this.parser.json.textures)==null||t.forEach((s,a)=>{var o;if(s!=null&&s.extensions){const c=s==null?void 0:s.extensions[ge];if(c){if(!c.lods){k&&console.warn("Texture has no LODs",c);return}let u=!1;for(const f of this.parser.associations.keys())if(f.isTexture===!0){const p=this.parser.associations.get(f);(p==null?void 0:p.textures)===a&&(u=!0,B.registerTexture(this.url,f,(o=c.lods)==null?void 0:o.length,a,c))}u||this.parser.getDependency("texture",a).then(f=>{var p;f&&B.registerTexture(this.url,f,(p=c.lods)==null?void 0:p.length,a,c)})}}}),(i=this.parser.json.meshes)==null||i.forEach((s,a)=>{if(s!=null&&s.extensions){const o=s==null?void 0:s.extensions[ge];if(o&&o.lods){for(const c of this.parser.associations.keys())if(c.isMesh){const u=this.parser.associations.get(c);(u==null?void 0:u.meshes)===a&&B.registerMesh(this.url,o.guid,c,o.lods.length,u.primitives,o)}}}}),null}static async getOrLoadLOD(e,t){var u,f,p,r;const i=k=="verbose",s=this.getAssignedLODInformation(e);if(!s)return k&&console.warn(`[gltf-progressive] No LOD information found: ${e.name}, uuid: ${e.uuid}, type: ${e.type}`,e),null;const a=s==null?void 0:s.key;let o;if(e.isTexture===!0){const l=e;l.source&&l.source[wi]&&(o=l.source[wi])}if(o||(o=B.lodInfos.get(a)),!o)k&&console.warn(`Can not load LOD ${t}: no LOD info found for "${a}" ${e.name}`,e.type,B.lodInfos);else{if(t>0){let g=!1;const _=Array.isArray(o.lods);if(_&&t>=o.lods.length?g=!0:_||(g=!0),g)return this.lowresCache.get(a)}const l=Array.isArray(o.lods)?(u=o.lods[t])==null?void 0:u.path:o.lods;if(!l)return k&&!o["missing:uri"]&&(o["missing:uri"]=!0,console.warn("Missing uri for progressive asset for LOD "+t,o)),null;const h=ca(s.url,l);if(h.endsWith(".glb")||h.endsWith(".gltf")){if(!o.guid)return console.warn("missing pointer for glb/gltf texture",o),null;const g=h+"_"+o.guid,_=await this.queue.slot(h),m=this.previouslyLoaded.get(g);if(m!==void 0){i&&console.log(`LOD ${t} was already loading/loaded: ${g}`);let w=await m.catch(A=>(console.error(`Error loading LOD ${t} from ${h}
3682
- `,A),null)),b=!1;if(w==null||(w instanceof d.Texture&&e instanceof d.Texture?(f=w.image)!=null&&f.data||(p=w.source)!=null&&p.data?w=this.copySettings(e,w):(b=!0,this.previouslyLoaded.delete(g)):w instanceof d.BufferGeometry&&e instanceof d.BufferGeometry&&((r=w.attributes.position)!=null&&r.array||(b=!0,this.previouslyLoaded.delete(g)))),!b)return w}if(!_.use)return k&&console.log(`LOD ${t} was aborted: ${h}`),null;const v=o,y=new Promise(async(w,b)=>{if(ya){const S=await(await va({})).load(h);if(S.textures.length>0)for(const M of S.textures){let R=M.texture;return B.assignLODInformation(s.url,R,a,t,void 0),e instanceof d.Texture&&(R=this.copySettings(e,R)),R&&(R.guid=v.guid),w(R)}if(S.geometries.length>0){const M=new Array;for(const R of S.geometries){const E=R.geometry;B.assignLODInformation(s.url,E,a,t,R.primitiveIndex),M.push(E)}return w(M)}return w(null)}const A=new is.GLTFLoader;vr(A),k&&(await new Promise(D=>setTimeout(D,1e3)),i&&console.warn("Start loading (delayed) "+h,v.guid));let T=h;if(v&&Array.isArray(v.lods)){const D=v.lods[t];D.hash&&(T+="?v="+D.hash)}const I=await A.loadAsync(T).catch(D=>(console.error(`Error loading LOD ${t} from ${h}
3681
+ }`}),this.depthWrite=!1,this.depthTest=!1}}class Vs{constructor(e){this._renderer=e,this._quad=new ot.FullScreenQuad(new $o)}generate(e,t=null,i=null){if(!e.isCubeTexture)throw new Error("CubeToEquirectMaterial: Source can only be cube textures.");const s=e.images[0],a=this._renderer,o=this._quad;t===null&&(t=4*s.height),i===null&&(i=2*s.height);const c=new d.WebGLRenderTarget(t,i,{type:d.FloatType,colorSpace:s.colorSpace}),u=s.height,f=Math.log2(u)-2,p=1/u,r=1/(3*Math.max(Math.pow(2,f),7*16));o.material.defines.CUBEUV_MAX_MIP=`${f}.0`,o.material.defines.CUBEUV_TEXEL_WIDTH=r,o.material.defines.CUBEUV_TEXEL_HEIGHT=p,o.material.uniforms.envMap.value=e,o.material.uniforms.flipEnvMap.value=e.isRenderTargetTexture?1:-1,o.material.needsUpdate=!0;const l=a.getRenderTarget(),h=a.autoClear;a.autoClear=!0,a.setRenderTarget(c),o.render(a),a.setRenderTarget(l),a.autoClear=h;const g=new Uint16Array(t*i*4),_=new Float32Array(t*i*4);a.readRenderTargetPixels(c,0,0,t,i,_),c.dispose();for(let v=0,y=_.length;v<y;v++)g[v]=d.DataUtils.toHalfFloat(_[v]);const m=new d.DataTexture(g,t,i,d.RGBAFormat,d.HalfFloatType);return m.minFilter=d.LinearMipMapLinearFilter,m.magFilter=d.LinearFilter,m.wrapS=d.RepeatWrapping,m.wrapT=d.RepeatWrapping,m.mapping=d.EquirectangularReflectionMapping,m.needsUpdate=!0,m}dispose(){this._quad.dispose()}}function ea(n){return n.extensions.get("EXT_float_blend")}const He=new d.Vector2;class ta{get multipleImportanceSampling(){return!!this._pathTracer.material.defines.FEATURE_MIS}set multipleImportanceSampling(e){this._pathTracer.material.setDefine("FEATURE_MIS",e?1:0)}get transmissiveBounces(){return this._pathTracer.material.transmissiveBounces}set transmissiveBounces(e){this._pathTracer.material.transmissiveBounces=e}get bounces(){return this._pathTracer.material.bounces}set bounces(e){this._pathTracer.material.bounces=e}get filterGlossyFactor(){return this._pathTracer.material.filterGlossyFactor}set filterGlossyFactor(e){this._pathTracer.material.filterGlossyFactor=e}get samples(){return this._pathTracer.samples}get target(){return this._pathTracer.target}get tiles(){return this._pathTracer.tiles}get stableNoise(){return this._pathTracer.stableNoise}set stableNoise(e){this._pathTracer.stableNoise=e}get isCompiling(){return!!this._pathTracer.isCompiling}constructor(e){this._renderer=e,this._generator=new kn,this._pathTracer=new ks(e),this._queueReset=!1,this._clock=new d.Clock,this._compilePromise=null,this._lowResPathTracer=new ks(e),this._lowResPathTracer.tiles.set(1,1),this._quad=new ot.FullScreenQuad(new Jo({map:null,transparent:!0,blending:d.NoBlending,premultipliedAlpha:e.getContextAttributes().premultipliedAlpha})),this._materials=null,this._previousEnvironment=null,this._previousBackground=null,this._internalBackground=null,this.renderDelay=100,this.minSamples=5,this.fadeDuration=500,this.enablePathTracing=!0,this.pausePathTracing=!1,this.dynamicLowRes=!1,this.lowResScale=.25,this.renderScale=1,this.synchronizeRenderSize=!0,this.rasterizeScene=!0,this.renderToCanvas=!0,this.textureSize=new d.Vector2(1024,1024),this.rasterizeSceneCallback=(t,i)=>{this._renderer.render(t,i)},this.renderToCanvasCallback=(t,i,s)=>{const a=i.autoClear;i.autoClear=!1,s.render(i),i.autoClear=a},this.setScene(new d.Scene,new d.PerspectiveCamera)}setBVHWorker(e){this._generator.setBVHWorker(e)}setScene(e,t,i={}){e.updateMatrixWorld(!0),t.updateMatrixWorld();const s=this._generator;if(s.setObjects(e),this._buildAsync)return s.generateAsync(i.onProgress).then(a=>this._updateFromResults(e,t,a));{const a=s.generate();return this._updateFromResults(e,t,a)}}setSceneAsync(...e){this._buildAsync=!0;const t=this.setScene(...e);return this._buildAsync=!1,t}setCamera(e){this.camera=e,this.updateCamera()}updateCamera(){const e=this.camera;e.updateMatrixWorld(),this._pathTracer.setCamera(e),this._lowResPathTracer.setCamera(e),this.reset()}updateMaterials(){const e=this._pathTracer.material,t=this._renderer,i=this._materials,s=this.textureSize,a=ro(i);e.textures.setTextures(t,a,s.x,s.y),e.materials.updateFrom(i,a),this.reset()}updateLights(){const e=this.scene,t=this._renderer,i=this._pathTracer.material,s=no(e),a=so(s);i.lights.updateFrom(s,a),i.iesProfiles.setTextures(t,a),this.reset()}updateEnvironment(){const e=this.scene,t=this._pathTracer.material;if(this._internalBackground&&(this._internalBackground.dispose(),this._internalBackground=null),t.backgroundBlur=e.backgroundBlurriness,t.backgroundIntensity=e.backgroundIntensity??1,t.backgroundRotation.makeRotationFromEuler(e.backgroundRotation).invert(),e.background===null)t.backgroundMap=null,t.backgroundAlpha=0;else if(e.background.isColor){this._colorBackground=this._colorBackground||new Ko(16);const i=this._colorBackground;i.topColor.equals(e.background)||(i.topColor.set(e.background),i.bottomColor.set(e.background),i.update()),t.backgroundMap=i,t.backgroundAlpha=1}else if(e.background.isCubeTexture){if(e.background!==this._previousBackground){const i=new Vs(this._renderer).generate(e.background);this._internalBackground=i,t.backgroundMap=i,t.backgroundAlpha=1}}else t.backgroundMap=e.background,t.backgroundAlpha=1;if(t.environmentIntensity=e.environmentIntensity??1,t.environmentRotation.makeRotationFromEuler(e.environmentRotation).invert(),this._previousEnvironment!==e.environment)if(e.environment!==null)if(e.environment.isCubeTexture){const i=new Vs(this._renderer).generate(e.environment);t.envMapInfo.updateFrom(i)}else t.envMapInfo.updateFrom(e.environment);else t.environmentIntensity=0;this._previousEnvironment=e.environment,this._previousBackground=e.background,this.reset()}_updateFromResults(e,t,i){const{materials:s,geometry:a,bvh:o,bvhChanged:c}=i;this._materials=s;const f=this._pathTracer.material;return c&&(f.bvh.updateFrom(o),f.attributesArray.updateFrom(a.attributes.normal,a.attributes.tangent,a.attributes.uv,a.attributes.color),f.materialIndexAttribute.updateFrom(a.attributes.materialIndex)),this._previousScene=e,this.scene=e,this.camera=t,this.updateCamera(),this.updateMaterials(),this.updateEnvironment(),this.updateLights(),i}renderSample(){const e=this._lowResPathTracer,t=this._pathTracer,i=this._renderer,s=this._clock,a=this._quad;this._updateScale(),this._queueReset&&(t.reset(),e.reset(),this._queueReset=!1,a.material.opacity=0,s.start());const o=s.getDelta()*1e3,c=s.getElapsedTime()*1e3;if(!this.pausePathTracing&&this.enablePathTracing&&this.renderDelay<=c&&!this.isCompiling&&t.update(),t.alpha=t.material.backgroundAlpha!==1||!ea(i),e.alpha=t.alpha,this.renderToCanvas){const u=this._renderer,f=this.minSamples;if(c>=this.renderDelay&&this.samples>=this.minSamples&&(this.fadeDuration!==0?a.material.opacity=Math.min(a.material.opacity+o/this.fadeDuration,1):a.material.opacity=1),!this.enablePathTracing||this.samples<f||a.material.opacity<1){if(this.dynamicLowRes&&!this.isCompiling){e.samples<1&&(e.material=t.material,e.update());const p=a.material.opacity;a.material.opacity=1-a.material.opacity,a.material.map=e.target.texture,a.render(u),a.material.opacity=p}(!this.dynamicLowRes&&this.rasterizeScene||this.dynamicLowRes&&this.isCompiling)&&this.rasterizeSceneCallback(this.scene,this.camera)}this.enablePathTracing&&a.material.opacity>0&&(a.material.opacity<1&&(a.material.blending=this.dynamicLowRes?d.AdditiveBlending:d.NormalBlending),a.material.map=t.target.texture,this.renderToCanvasCallback(t.target,u,a),a.material.blending=d.NoBlending)}}reset(){this._queueReset=!0,this._pathTracer.samples=0}dispose(){this._renderQuad.dispose(),this._renderQuad.material.dispose(),this._pathTracer.dispose()}_updateScale(){if(this.synchronizeRenderSize){this._renderer.getDrawingBufferSize(He);const e=Math.floor(this.renderScale*He.x),t=Math.floor(this.renderScale*He.y);if(this._pathTracer.getSize(He),He.x!==e||He.y!==t){const i=this.lowResScale;this._pathTracer.setSize(e,t),this._lowResPathTracer.setSize(Math.floor(e*i),Math.floor(t*i))}}}}const ia="";globalThis.GLTF_PROGRESSIVE_VERSION=ia;console.debug("[gltf-progressive] version -");let le="https://www.gstatic.com/draco/versioned/decoders/1.5.7/",ci="https://cdn.needle.tools/static/three/0.179.1/basis2/";const sa=le,ra=ci,vr=new URL(le+"draco_decoder.js");vr.searchParams.append("range","true");fetch(vr,{method:"GET",headers:{Range:"bytes=0-1"}}).catch(n=>{console.debug(`Failed to fetch remote Draco decoder from ${le} (offline: ${typeof navigator<"u"?navigator.onLine:"unknown"})`),le===sa&&oa("./include/draco/"),ci===ra&&aa("./include/ktx2/")}).finally(()=>{yr()});const na=()=>({dracoDecoderPath:le,ktx2TranscoderPath:ci});function oa(n){le=n,$&&$[zi]!=le?(console.debug("Updating Draco decoder path to "+n),$[zi]=le,$.setDecoderPath(le),$.preload()):console.debug("Setting Draco decoder path to "+n)}function aa(n){ci=n}function as(n){return yr(),{dracoLoader:$,meshoptDecoder:ri}}function _r(n){n.dracoLoader||n.setDRACOLoader($),n.meshoptDecoder||n.setMeshoptDecoder(ri)}const zi=Symbol("dracoDecoderPath");let $,ri;function yr(){$||($=new ln.DRACOLoader,$[zi]=le,$.setDecoderPath(le),$.setDecoderConfig({type:"js"}),$.preload()),ri||(ri=an.MeshoptDecoder)}const Vi=new WeakMap;function xr(n,e){let t=Vi.get(n);t?t=Object.assign(t,e):t=e,Vi.set(n,t)}const xi=ss.GLTFLoader.prototype.load;function la(...n){const e=Vi.get(this);let t=n[0];const i=new URL(t,window.location.href);if(i.hostname.endsWith("needle.tools")){const a=(e==null?void 0:e.progressive)!==void 0?e.progressive:!0,o=e!=null&&e.usecase?e.usecase:"default";a?this.requestHeader.Accept=`*/*;progressive=allowed;usecase=${o}`:this.requestHeader.Accept=`*/*;usecase=${o}`,t=i.toString()}return n[0]=t,xi==null?void 0:xi.call(this,...n)}ss.GLTFLoader.prototype.load=la;ze("debugprogressive");function ze(n){if(typeof window>"u")return!1;const t=new URL(window.location.href).searchParams.get(n);return t==null||t==="0"||t==="false"?!1:t===""?!0:t}function ca(n,e){if(e===void 0||n===void 0||e.startsWith("./")||e.startsWith("http")||e.startsWith("data:")||e.startsWith("blob:"))return e;const t=n.lastIndexOf("/");if(t>=0){const i=n.substring(0,t+1);for(;i.endsWith("/")&&e.startsWith("/");)e=e.substring(1);return i+e}return e}function wr(){return dt!==void 0||(dt=/iPhone|iPad|iPod|Android|IEMobile/i.test(navigator.userAgent),ze("debugprogressive")&&console.log("[glTF Progressive]: isMobileDevice",dt)),dt}let dt;function Us(){if(typeof window>"u")return!1;const n=new URL(window.location.href),e=n.hostname==="localhost"||/^\d{1,3}\.\d{1,3}\.\d{1,3}\.\d{1,3}$/.test(n.hostname);return n.hostname==="127.0.0.1"||e}class ua{constructor(e=100,t={}){L(this,"_running",new Map);L(this,"_queue",[]);L(this,"debug",!1);L(this,"tick",()=>{this.internalUpdate(),setTimeout(this.tick,10)});this.maxConcurrent=e,this.debug=t.debug??!1,window.requestAnimationFrame(this.tick)}slot(e){return this.debug&&console.debug(`[PromiseQueue]: Requesting slot for key ${e}, running: ${this._running.size}, waiting: ${this._queue.length}`),new Promise(t=>{this._queue.push({key:e,resolve:t})})}add(e,t){this._running.has(e)||(this._running.set(e,t),t.finally(()=>{this._running.delete(e),this.debug&&console.debug(`[PromiseQueue]: Promise finished now running: ${this._running.size}, waiting: ${this._queue.length}. (finished ${e})`)}),this.debug&&console.debug(`[PromiseQueue]: Added new promise, now running: ${this._running.size}, waiting: ${this._queue.length}. (added ${e})`))}internalUpdate(){const e=this.maxConcurrent-this._running.size;for(let t=0;t<e&&this._queue.length>0;t++){this.debug&&console.debug(`[PromiseQueue]: Running ${this._running.size} promises, waiting for ${this._queue.length} more.`);const{key:i,resolve:s}=this._queue.shift();s({use:a=>this.add(i,a)})}}}const ha=typeof window>"u"&&typeof document>"u",Ui=Symbol("needle:raycast-mesh");function Lt(n){return(n==null?void 0:n[Ui])instanceof d.BufferGeometry?n[Ui]:null}function fa(n,e){if((n.type==="Mesh"||n.type==="SkinnedMesh")&&!Lt(n)){const i=pa(e);i.userData={isRaycastMesh:!0},n[Ui]=i}}function da(n=!0){if(n){if(pt)return;const e=pt=d.Mesh.prototype.raycast;d.Mesh.prototype.raycast=function(t,i){const s=this,a=Lt(s);let o;a&&s.isMesh&&(o=s.geometry,s.geometry=a),e.call(this,t,i),o&&(s.geometry=o)}}else{if(!pt)return;d.Mesh.prototype.raycast=pt,pt=null}}let pt=null;function pa(n){const e=new d.BufferGeometry;for(const t in n.attributes)e.setAttribute(t,n.getAttribute(t));return e.setIndex(n.getIndex()),e}const Se=new Array,k=ze("debugprogressive");let Ct,Be=-1;if(k){let n=function(){Be+=1,Be>=e&&(Be=-1),console.log(`Toggle LOD level [${Be}]`)},e=6;window.addEventListener("keyup",t=>{t.key==="p"&&n(),t.key==="w"&&(Ct=!Ct,console.log(`Toggle wireframe [${Ct}]`));const i=parseInt(t.key);!isNaN(i)&&i>=0&&(Be=i,console.log(`Set LOD level to [${Be}]`))})}function br(n){if(k&&Ct!==void 0)if(Array.isArray(n))for(const e of n)br(e);else n&&"wireframe"in n&&(n.wireframe=Ct===!0)}const mt=new Array;let ma=0;const ga=wr()?2:10;function va(n){if(mt.length<ga){const i=mt.length;k&&console.warn(`[Worker] Creating new worker #${i}`);const s=ls.createWorker(n||{});return mt.push(s),s}const e=ma++%mt.length;return mt[e]}class ls{constructor(e,t){L(this,"_running",[]);L(this,"_webglRenderer",null);L(this,"_debug",!1);this.worker=e,this._debug=t.debug??!1,e.onmessage=i=>{const s=i.data;switch(this._debug&&console.log("[Worker] EVENT",s),s.type){case"loaded-gltf":for(const a of this._running)if(a.url===s.result.url){_a(s.result),a.resolve(s.result);const o=a.url;o.startsWith("blob:")&&URL.revokeObjectURL(o)}}},e.onerror=i=>{console.error("[Worker] Error in gltf-progressive worker:",i)},e.postMessage({type:"init"})}static async createWorker(e){const t=new Worker(new URL(""+(typeof document>"u"?require("url").pathToFileURL(__dirname+"/assets/loader.worker-fysOIq2s.js").href:new URL("assets/loader.worker-fysOIq2s.js",document.currentScript&&document.currentScript.src||document.baseURI).href),typeof document>"u"?require("url").pathToFileURL(__filename).href:at&&at.src||new URL("shop-components.cjs",document.baseURI).href),{type:"module"});return new ls(t,e)}async load(e,t){const i=na();let s=t==null?void 0:t.renderer;s||(this._webglRenderer??(this._webglRenderer=(async()=>{const{WebGLRenderer:f}=await import("three");return new f})()),s=await this._webglRenderer);const c=as().ktx2Loader.workerConfig;e instanceof URL?e=e.toString():e.startsWith("file:")?e=URL.createObjectURL(new Blob([e])):!e.startsWith("blob:")&&!e.startsWith("http:")&&!e.startsWith("https:")&&(e=new URL(e,window.location.href).toString());const u={type:"load",url:e,dracoDecoderPath:i.dracoDecoderPath,ktx2TranscoderPath:i.ktx2TranscoderPath,ktx2LoaderConfig:c};return this._debug&&console.debug("[Worker] Sending load request",u),this.worker.postMessage(u),new Promise(f=>{this._running.push({url:e.toString(),resolve:f})})}}function _a(n){var e,t,i,s,a,o,c,u,f,p,r,l,h,g,_,m;for(const v of n.geometries){const y=v.geometry,x=new d.BufferGeometry;if(x.name=y.name||"",y.index){const w=y.index;x.setIndex(wi(w))}for(const w in y.attributes){const b=y.attributes[w],A=wi(b);x.setAttribute(w,A)}if(y.morphAttributes)for(const w in y.morphAttributes){const A=y.morphAttributes[w].map(T=>wi(T));x.morphAttributes[w]=A}if(x.morphTargetsRelative=y.morphTargetsRelative??!1,x.boundingBox=new d.Box3,x.boundingBox.min=new d.Vector3((e=y.boundingBox)==null?void 0:e.min.x,(t=y.boundingBox)==null?void 0:t.min.y,(i=y.boundingBox)==null?void 0:i.min.z),x.boundingBox.max=new d.Vector3((s=y.boundingBox)==null?void 0:s.max.x,(a=y.boundingBox)==null?void 0:a.max.y,(o=y.boundingBox)==null?void 0:o.max.z),x.boundingSphere=new d.Sphere(new d.Vector3((c=y.boundingSphere)==null?void 0:c.center.x,(u=y.boundingSphere)==null?void 0:u.center.y,(f=y.boundingSphere)==null?void 0:f.center.z),(p=y.boundingSphere)==null?void 0:p.radius),y.groups)for(const w of y.groups)x.addGroup(w.start,w.count,w.materialIndex);y.userData&&(x.userData=y.userData),v.geometry=x}for(const v of n.textures){const y=v.texture;let x=null;if(y.isCompressedTexture){const w=y.mipmaps,b=((r=y.image)==null?void 0:r.width)||((h=(l=y.source)==null?void 0:l.data)==null?void 0:h.width)||-1,A=((g=y.image)==null?void 0:g.height)||((m=(_=y.source)==null?void 0:_.data)==null?void 0:m.height)||-1;x=new d.CompressedTexture(w,b,A,y.format,y.type,y.mapping,y.wrapS,y.wrapT,y.magFilter,y.minFilter,y.anisotropy,y.colorSpace)}else x=new d.Texture(y.image,y.mapping,y.wrapS,y.wrapT,y.magFilter,y.minFilter,y.format,y.type,y.anisotropy,y.colorSpace),x.mipmaps=y.mipmaps,x.channel=y.channel,x.source.data=y.source.data,x.flipY=y.flipY,x.premultiplyAlpha=y.premultiplyAlpha,x.unpackAlignment=y.unpackAlignment,x.matrix=new d.Matrix3(...y.matrix.elements);if(!x){console.error("[Worker] Failed to create new texture from received data. Texture is not a CompressedTexture or Texture.");continue}v.texture=x}return n}function wi(n){let e=n;if("isInterleavedBufferAttribute"in n&&n.isInterleavedBufferAttribute){const t=n.data,i=t.array,s=new d.InterleavedBuffer(i,t.stride);e=new d.InterleavedBufferAttribute(s,n.itemSize,i.byteOffset,n.normalized),e.offset=n.offset}else"isBufferAttribute"in n&&n.isBufferAttribute&&(e=new d.BufferAttribute(n.array,n.itemSize,n.normalized),e.usage=n.usage,e.gpuType=n.gpuType,e.updateRanges=n.updateRanges);return e}const ya=ze("gltf-progressive-worker"),xa=ze("gltf-progressive-reduce-mipmaps"),bi=Symbol("needle-progressive-texture"),ge="NEEDLE_progressive",B=class B{constructor(e){L(this,"parser");L(this,"url");L(this,"_isLoadingMesh");L(this,"loadMesh",e=>{var i,s;if(this._isLoadingMesh)return null;const t=(s=(i=this.parser.json.meshes[e])==null?void 0:i.extensions)==null?void 0:s[ge];return t?(this._isLoadingMesh=!0,this.parser.getDependency("mesh",e).then(a=>{var o;return this._isLoadingMesh=!1,a&&B.registerMesh(this.url,t.guid,a,(o=t.lods)==null?void 0:o.length,0,t),a})):null});const t=e.options.path;k&&console.log("Progressive extension registered for",t),this.parser=e,this.url=t}get name(){return ge}static getMeshLODExtension(e){const t=this.getAssignedLODInformation(e);return t!=null&&t.key?this.lodInfos.get(t.key):null}static getPrimitiveIndex(e){var i;const t=(i=this.getAssignedLODInformation(e))==null?void 0:i.index;return t??-1}static getMaterialMinMaxLODsCount(e,t){const i=this,s="LODS:minmax",a=e[s];if(a!=null)return a;if(t||(t={min_count:1/0,max_count:0,lods:[]}),Array.isArray(e)){for(const c of e)this.getMaterialMinMaxLODsCount(c,t);return e[s]=t,t}if(k==="verbose"&&console.log("getMaterialMinMaxLODsCount",e),e.type==="ShaderMaterial"||e.type==="RawShaderMaterial"){const c=e;for(const u of Object.keys(c.uniforms)){const f=c.uniforms[u].value;(f==null?void 0:f.isTexture)===!0&&o(f,t)}}else if(e.isMaterial)for(const c of Object.keys(e)){const u=e[c];(u==null?void 0:u.isTexture)===!0&&o(u,t)}else k&&console.warn(`[getMaterialMinMaxLODsCount] Unsupported material type: ${e.type}`);return e[s]=t,t;function o(c,u){const f=i.getAssignedLODInformation(c);if(f){const p=i.lodInfos.get(f.key);if(p&&p.lods){u.min_count=Math.min(u.min_count,p.lods.length),u.max_count=Math.max(u.max_count,p.lods.length);for(let r=0;r<p.lods.length;r++){const l=p.lods[r];l.width&&(u.lods[r]=u.lods[r]||{min_height:1/0,max_height:0},u.lods[r].min_height=Math.min(u.lods[r].min_height,l.height),u.lods[r].max_height=Math.max(u.lods[r].max_height,l.height))}}}}}static hasLODLevelAvailable(e,t){var a;if(Array.isArray(e)){for(const o of e)if(this.hasLODLevelAvailable(o,t))return!0;return!1}if(e.isMaterial===!0){for(const o of Object.keys(e)){const c=e[o];if(c&&c.isTexture&&this.hasLODLevelAvailable(c,t))return!0}return!1}else if(e.isGroup===!0){for(const o of e.children)if(o.isMesh===!0&&this.hasLODLevelAvailable(o,t))return!0}let i,s;if(e.isMesh?i=e.geometry:(e.isBufferGeometry||e.isTexture)&&(i=e),i&&(a=i==null?void 0:i.userData)!=null&&a.LODS){const o=i.userData.LODS;if(s=this.lodInfos.get(o.key),t===void 0)return s!=null;if(s)return Array.isArray(s.lods)?t<s.lods.length:t===0}return!1}static assignMeshLOD(e,t){var i;if(!e)return Promise.resolve(null);if(e instanceof d.Mesh||e.isMesh===!0){const s=e.geometry,a=this.getAssignedLODInformation(s);if(!a)return Promise.resolve(null);for(const o of Se)(i=o.onBeforeGetLODMesh)==null||i.call(o,e,t);return e["LOD:requested level"]=t,B.getOrLoadLOD(s,t).then(o=>{if(Array.isArray(o)){const c=a.index||0;o=o[c]}return e["LOD:requested level"]===t&&(delete e["LOD:requested level"],o&&s!=o&&((o==null?void 0:o.isBufferGeometry)?e.geometry=o:k&&console.error("Invalid LOD geometry",o))),o}).catch(o=>(console.error("Error loading mesh LOD",e,o),null))}else k&&console.error("Invalid call to assignMeshLOD: Request mesh LOD but the object is not a mesh",e);return Promise.resolve(null)}static assignTextureLOD(e,t=0){if(!e)return Promise.resolve(null);if(e.isMesh===!0){const i=e;if(Array.isArray(i.material)){const s=new Array;for(const a of i.material){const o=this.assignTextureLOD(a,t);s.push(o)}return Promise.all(s).then(a=>{const o=new Array;for(const c of a)Array.isArray(c)&&o.push(...c);return o})}else return this.assignTextureLOD(i.material,t)}if(e.isMaterial===!0){const i=e,s=[],a=new Array;if(i.uniforms&&(i.isRawShaderMaterial||i.isShaderMaterial===!0)){const o=i;for(const c of Object.keys(o.uniforms)){const u=o.uniforms[c].value;if((u==null?void 0:u.isTexture)===!0){const f=this.assignTextureLODForSlot(u,t,i,c).then(p=>(p&&o.uniforms[c].value!=p&&(o.uniforms[c].value=p,o.uniformsNeedUpdate=!0),p));s.push(f),a.push(c)}}}else for(const o of Object.keys(i)){const c=i[o];if((c==null?void 0:c.isTexture)===!0){const u=this.assignTextureLODForSlot(c,t,i,o);s.push(u),a.push(o)}}return Promise.all(s).then(o=>{const c=new Array;for(let u=0;u<o.length;u++){const f=o[u],p=a[u];f&&f.isTexture===!0?c.push({material:i,slot:p,texture:f,level:t}):c.push({material:i,slot:p,texture:null,level:t})}return c})}if(e instanceof d.Texture||e.isTexture===!0){const i=e;return this.assignTextureLODForSlot(i,t,null,null)}return Promise.resolve(null)}static assignTextureLODForSlot(e,t,i,s){return(e==null?void 0:e.isTexture)!==!0?Promise.resolve(null):s==="glyphMap"?Promise.resolve(e):B.getOrLoadLOD(e,t).then(a=>{var o,c;if(Array.isArray(a))return console.warn("Progressive: Got an array of textures for a texture slot, this should not happen..."),null;if((a==null?void 0:a.isTexture)===!0){if(a!=e&&i&&s){const u=i[s];if(u&&!k){const f=this.getAssignedLODInformation(u);if(f&&(f==null?void 0:f.level)<t)return k==="verbose"&&console.warn("Assigned texture level is already higher: ",f.level,t,i,u,a),null}if(xa&&a.mipmaps){const f=a.mipmaps.length;a.mipmaps.length=Math.min(a.mipmaps.length,3),f!==a.mipmaps.length&&k&&console.debug(`Reduced mipmap count from ${f} to ${a.mipmaps.length} for ${a.uuid}: ${(o=a.image)==null?void 0:o.width}x${(c=a.image)==null?void 0:c.height}.`)}i[s]=a}return a}else k=="verbose"&&console.warn("No LOD found for",e,t);return null}).catch(a=>(console.error("Error loading LOD",e,a),null))}afterRoot(e){var t,i;return k&&console.log("AFTER",this.url,e),(t=this.parser.json.textures)==null||t.forEach((s,a)=>{var o;if(s!=null&&s.extensions){const c=s==null?void 0:s.extensions[ge];if(c){if(!c.lods){k&&console.warn("Texture has no LODs",c);return}let u=!1;for(const f of this.parser.associations.keys())if(f.isTexture===!0){const p=this.parser.associations.get(f);(p==null?void 0:p.textures)===a&&(u=!0,B.registerTexture(this.url,f,(o=c.lods)==null?void 0:o.length,a,c))}u||this.parser.getDependency("texture",a).then(f=>{var p;f&&B.registerTexture(this.url,f,(p=c.lods)==null?void 0:p.length,a,c)})}}}),(i=this.parser.json.meshes)==null||i.forEach((s,a)=>{if(s!=null&&s.extensions){const o=s==null?void 0:s.extensions[ge];if(o&&o.lods){for(const c of this.parser.associations.keys())if(c.isMesh){const u=this.parser.associations.get(c);(u==null?void 0:u.meshes)===a&&B.registerMesh(this.url,o.guid,c,o.lods.length,u.primitives,o)}}}}),null}static async getOrLoadLOD(e,t){var u,f,p,r;const i=k=="verbose",s=this.getAssignedLODInformation(e);if(!s)return k&&console.warn(`[gltf-progressive] No LOD information found: ${e.name}, uuid: ${e.uuid}, type: ${e.type}`,e),null;const a=s==null?void 0:s.key;let o;if(e.isTexture===!0){const l=e;l.source&&l.source[bi]&&(o=l.source[bi])}if(o||(o=B.lodInfos.get(a)),!o)k&&console.warn(`Can not load LOD ${t}: no LOD info found for "${a}" ${e.name}`,e.type,B.lodInfos);else{if(t>0){let g=!1;const _=Array.isArray(o.lods);if(_&&t>=o.lods.length?g=!0:_||(g=!0),g)return this.lowresCache.get(a)}const l=Array.isArray(o.lods)?(u=o.lods[t])==null?void 0:u.path:o.lods;if(!l)return k&&!o["missing:uri"]&&(o["missing:uri"]=!0,console.warn("Missing uri for progressive asset for LOD "+t,o)),null;const h=ca(s.url,l);if(h.endsWith(".glb")||h.endsWith(".gltf")){if(!o.guid)return console.warn("missing pointer for glb/gltf texture",o),null;const g=h+"_"+o.guid,_=await this.queue.slot(h),m=this.previouslyLoaded.get(g);if(m!==void 0){i&&console.log(`LOD ${t} was already loading/loaded: ${g}`);let w=await m.catch(A=>(console.error(`Error loading LOD ${t} from ${h}
3682
+ `,A),null)),b=!1;if(w==null||(w instanceof d.Texture&&e instanceof d.Texture?(f=w.image)!=null&&f.data||(p=w.source)!=null&&p.data?w=this.copySettings(e,w):(b=!0,this.previouslyLoaded.delete(g)):w instanceof d.BufferGeometry&&e instanceof d.BufferGeometry&&((r=w.attributes.position)!=null&&r.array||(b=!0,this.previouslyLoaded.delete(g)))),!b)return w}if(!_.use)return k&&console.log(`LOD ${t} was aborted: ${h}`),null;const v=o,y=new Promise(async(w,b)=>{if(ya){const S=await(await va({})).load(h);if(S.textures.length>0)for(const M of S.textures){let R=M.texture;return B.assignLODInformation(s.url,R,a,t,void 0),e instanceof d.Texture&&(R=this.copySettings(e,R)),R&&(R.guid=v.guid),w(R)}if(S.geometries.length>0){const M=new Array;for(const R of S.geometries){const E=R.geometry;B.assignLODInformation(s.url,E,a,t,R.primitiveIndex),M.push(E)}return w(M)}return w(null)}const A=new ss.GLTFLoader;_r(A),k&&(await new Promise(D=>setTimeout(D,1e3)),i&&console.warn("Start loading (delayed) "+h,v.guid));let T=h;if(v&&Array.isArray(v.lods)){const D=v.lods[t];D.hash&&(T+="?v="+D.hash)}const I=await A.loadAsync(T).catch(D=>(console.error(`Error loading LOD ${t} from ${h}
3683
3683
  `,D),w(null)));if(!I)return w(null);const C=I.parser;i&&console.log("Loading finished "+h,v.guid);let P=0;if(I.parser.json.textures){let D=!1;for(const S of I.parser.json.textures){if(S!=null&&S.extensions){const M=S==null?void 0:S.extensions[ge];if(M!=null&&M.guid&&M.guid===v.guid){D=!0;break}}P++}if(D){let S=await C.getDependency("texture",P);return S&&B.assignLODInformation(s.url,S,a,t,void 0),i&&console.log('change "'+e.name+'" → "'+S.name+'"',h,P,S,g),e instanceof d.Texture&&(S=this.copySettings(e,S)),S&&(S.guid=v.guid),w(S)}else k&&console.warn("Could not find texture with guid",v.guid,I.parser.json)}if(P=0,I.parser.json.meshes){let D=!1;for(const S of I.parser.json.meshes){if(S!=null&&S.extensions){const M=S==null?void 0:S.extensions[ge];if(M!=null&&M.guid&&M.guid===v.guid){D=!0;break}}P++}if(D){const S=await C.getDependency("mesh",P);if(i&&console.log(`Loaded Mesh "${S.name}"`,h,P,S,g),S.isMesh===!0){const M=S.geometry;return B.assignLODInformation(s.url,M,a,t,0),w(M)}else{const M=new Array;for(let R=0;R<S.children.length;R++){const E=S.children[R];if(E.isMesh===!0){const F=E.geometry;B.assignLODInformation(s.url,F,a,t,R),M.push(F)}}return w(M)}}else k&&console.warn("Could not find mesh with guid",v.guid,I.parser.json)}return w(null)});return this.previouslyLoaded.set(g,y),_.use(y),await y}else if(e instanceof d.Texture){i&&console.log("Load texture from uri: "+h);const _=await new d.TextureLoader().loadAsync(h);return _?(_.guid=o.guid,_.flipY=!1,_.needsUpdate=!0,_.colorSpace=e.colorSpace,i&&console.log(o,_)):k&&console.warn("failed loading",h),_}}return null}static assignLODInformation(e,t,i,s,a){if(!t)return;t.userData||(t.userData={});const o=new wa(e,i,s,a);t.userData.LODS=o,"source"in t&&typeof t.source=="object"&&(t.source.LODS=o)}static getAssignedLODInformation(e){var t,i;return e?(t=e.userData)!=null&&t.LODS?e.userData.LODS:"source"in e&&((i=e.source)!=null&&i.LODS)?e.source.LODS:null:null}static copySettings(e,t){return t?(k==="verbose"&&console.debug(`Copy texture settings
3684
3684
  `,e.uuid,`
3685
- `,t.uuid),t=t.clone(),t.offset=e.offset,t.repeat=e.repeat,t.colorSpace=e.colorSpace,t.magFilter=e.magFilter,t.minFilter=e.minFilter,t.wrapS=e.wrapS,t.wrapT=e.wrapT,t.flipY=e.flipY,t.anisotropy=e.anisotropy,t.mipmaps||(t.generateMipmaps=e.generateMipmaps),t):e}};L(B,"registerTexture",(e,t,i,s,a)=>{var c,u,f,p,r,l,h,g;if(!t){k&&console.error("!! gltf-progressive: Called register texture without texture");return}if(k){const _=((c=t.image)==null?void 0:c.width)||((f=(u=t.source)==null?void 0:u.data)==null?void 0:f.width)||0,m=((p=t.image)==null?void 0:p.height)||((l=(r=t.source)==null?void 0:r.data)==null?void 0:l.height)||0;console.log(`> gltf-progressive: register texture[${s}] "${t.name||t.uuid}", Current: ${_}x${m}, Max: ${(h=a.lods[0])==null?void 0:h.width}x${(g=a.lods[0])==null?void 0:g.height}, uuid: ${t.uuid}`,a,t)}t.source&&(t.source[wi]=a);const o=a.guid;B.assignLODInformation(e,t,o,i,s),B.lodInfos.set(o,a),B.lowresCache.set(o,t)}),L(B,"registerMesh",(e,t,i,s,a,o)=>{var f;const c=i.geometry;if(!c){k&&console.warn("gltf-progressive: Register mesh without geometry");return}c.userData||(c.userData={}),k&&console.log("> Progressive: register mesh "+i.name,{index:a,uuid:i.uuid},o,i),B.assignLODInformation(e,c,t,s,a),B.lodInfos.set(t,o);let u=B.lowresCache.get(t);u?u.push(i.geometry):u=[i.geometry],B.lowresCache.set(t,u),s>0&&!Lt(i)&&fa(i,c);for(const p of Se)(f=p.onRegisteredNewMesh)==null||f.call(p,i,o)}),L(B,"lodInfos",new Map),L(B,"previouslyLoaded",new Map),L(B,"lowresCache",new Map),L(B,"workers",[]),L(B,"_workersIndex",0),L(B,"maxConcurrent",50),L(B,"queue",new ua(B.maxConcurrent,{debug:k!=!1}));let he=B;class wa{constructor(e,t,i,s){L(this,"url");L(this,"key");L(this,"level");L(this,"index");this.url=e,this.key=t,this.level=i,s!=null&&(this.index=s)}}class ei{constructor(e,t){L(this,"ready");L(this,"_resolve");L(this,"_signal");L(this,"_frame_start");L(this,"_frames_to_capture");L(this,"_resolved",!1);L(this,"_addedCount",0);L(this,"_resolvedCount",0);L(this,"_awaiting",[]);L(this,"_maxPromisesPerObject",1);L(this,"_currentFrame",0);L(this,"_seen",new WeakMap);var a;const s=Math.max(t.frames??2,2);this._frame_start=t.waitForFirstCapture?void 0:e,this._frames_to_capture=s,this.ready=new Promise(o=>{this._resolve=o}),this.ready.finally(()=>{this._resolved=!0,this._awaiting.length=0}),this._signal=t.signal,(a=this._signal)==null||a.addEventListener("abort",()=>{this.resolveNow()}),this._maxPromisesPerObject=Math.max(1,t.maxPromisesPerObject??1)}get awaitedCount(){return this._addedCount}get resolvedCount(){return this._resolvedCount}get currentlyAwaiting(){return this._awaiting.length}update(e){var t;this._currentFrame=e,this._frame_start===void 0&&this._addedCount>0&&(this._frame_start=e),((t=this._signal)!=null&&t.aborted||this._awaiting.length===0&&this._frame_start!==void 0&&e>this._frame_start+this._frames_to_capture)&&this.resolveNow()}add(e,t,i){if(this._resolved){k&&console.warn("PromiseGroup: Trying to add a promise to a resolved group, ignoring.");return}if(!(this._frame_start!==void 0&&this._currentFrame>this._frame_start+this._frames_to_capture)){if(this._maxPromisesPerObject>=1)if(this._seen.has(t)){let s=this._seen.get(t);if(s>=this._maxPromisesPerObject){k&&console.warn("PromiseGroup: Already awaiting object ignoring new promise for it.");return}this._seen.set(t,s+1)}else this._seen.set(t,1);this._awaiting.push(i),this._addedCount++,i.finally(()=>{this._resolvedCount++,this._awaiting.splice(this._awaiting.indexOf(i),1)})}}resolveNow(){var e,t;this._resolved||(t=this._resolve)==null||t.call(this,{awaited_count:this._addedCount,resolved_count:this._resolvedCount,cancelled:((e=this._signal)==null?void 0:e.aborted)??!1})}}L(ei,"addPromise",(e,t,i,s)=>{s.forEach(a=>{a.add(e,t,i)})});const oe=Oe("debugprogressive"),ba=Oe("noprogressive"),bi=Symbol("Needle:LODSManager"),Ai=Symbol("Needle:LODState"),Ae=Symbol("Needle:CurrentLOD"),X={mesh_lod:-1,texture_lod:-1};var J,ve,ai,Ie,rt,li,_e;const V=class V{constructor(e,t){L(this,"renderer");L(this,"context");L(this,"projectionScreenMatrix",new d.Matrix4);L(this,"overrideLodLevel");L(this,"targetTriangleDensity",2e5);L(this,"skinnedMeshAutoUpdateBoundsInterval",30);L(this,"updateInterval","auto");be(this,J,1);L(this,"pause",!1);L(this,"manual",!1);L(this,"_newPromiseGroups",[]);L(this,"_promiseGroupIds",0);L(this,"_lodchangedlisteners",[]);be(this,ve,void 0);be(this,ai,new d.Clock);be(this,Ie,0);be(this,rt,0);be(this,li,0);be(this,_e,0);L(this,"_fpsBuffer",[60,60,60,60,60]);L(this,"_sphere",new d.Sphere);L(this,"_tempBox",new d.Box3);L(this,"_tempBox2",new d.Box3);L(this,"tempMatrix",new d.Matrix4);L(this,"_tempWorldPosition",new d.Vector3);L(this,"_tempBoxSize",new d.Vector3);L(this,"_tempBox2Size",new d.Vector3);this.renderer=e,this.context={...t}}static getObjectLODState(e){return e[Ai]}static addPlugin(e){Se.push(e)}static removePlugin(e){const t=Se.indexOf(e);t>=0&&Se.splice(t,1)}static get(e,t){if(e[bi])return console.debug("[gltf-progressive] LODsManager already exists for this renderer"),e[bi];const i=new V(e,{engine:"unknown",...t});return e[bi]=i,i}get plugins(){return Se}awaitLoading(e){const t=this._promiseGroupIds++,i=new ei(z(this,Ie),{...e});this._newPromiseGroups.push(i);const s=performance.now();return i.ready.finally(()=>{const a=this._newPromiseGroups.indexOf(i);a>=0&&(this._newPromiseGroups.splice(a,1),Vs()&&performance.measure("LODsManager:awaitLoading",{start:s,detail:{id:t,name:e==null?void 0:e.name,awaited:i.awaitedCount,resolved:i.resolvedCount}}))}),i.ready}_postprocessPromiseGroups(){if(this._newPromiseGroups.length!==0)for(let e=this._newPromiseGroups.length-1;e>=0;e--)this._newPromiseGroups[e].update(z(this,Ie))}addEventListener(e,t){e==="changed"&&this._lodchangedlisteners.push(t)}removeEventListener(e,t){if(e==="changed"){const i=this._lodchangedlisteners.indexOf(t);i>=0&&this._lodchangedlisteners.splice(i,1)}}enable(){if(z(this,ve))return;console.debug("[gltf-progressive] Enabling LODsManager for renderer");let e=0;ue(this,ve,this.renderer.render);const t=this;os(this.renderer),this.renderer.render=function(i,s){const a=t.renderer.getRenderTarget();(a==null||"isXRRenderTarget"in a&&a.isXRRenderTarget)&&(e=0,ue(t,Ie,z(t,Ie)+1),ue(t,rt,z(t,ai).getDelta()),ue(t,li,z(t,li)+z(t,rt)),t._fpsBuffer.shift(),t._fpsBuffer.push(1/z(t,rt)),ue(t,_e,t._fpsBuffer.reduce((c,u)=>c+u)/t._fpsBuffer.length),oe&&z(t,Ie)%200===0&&console.log("FPS",Math.round(z(t,_e)),"Interval:",z(t,J)));const o=e++;z(t,ve).call(this,i,s),t.onAfterRender(i,s,o)}}disable(){z(this,ve)&&(console.debug("[gltf-progressive] Disabling LODsManager for renderer"),this.renderer.render=z(this,ve),ue(this,ve,void 0))}update(e,t){this.internalUpdate(e,t)}onAfterRender(e,t,i){if(this.pause)return;const a=this.renderer.renderLists.get(e,0).opaque;let o=!0;if(a.length===1){const c=a[0].material;(c.name==="EffectMaterial"||c.name==="CopyShader")&&(o=!1)}if((t.parent&&t.parent.type==="CubeCamera"||i>=1&&t.type==="OrthographicCamera")&&(o=!1),o){if(ba||(this.updateInterval==="auto"?z(this,_e)<40&&z(this,J)<10?(ue(this,J,z(this,J)+1),oe&&console.warn("↓ Reducing LOD updates",z(this,J),z(this,_e).toFixed(0))):z(this,_e)>=60&&z(this,J)>1&&(ue(this,J,z(this,J)-1),oe&&console.warn("↑ Increasing LOD updates",z(this,J),z(this,_e).toFixed(0))):ue(this,J,this.updateInterval),z(this,J)>0&&z(this,Ie)%z(this,J)!=0))return;this.internalUpdate(e,t),this._postprocessPromiseGroups()}}internalUpdate(e,t){var u,f;const i=this.renderer.renderLists.get(e,0),s=i.opaque;this.projectionScreenMatrix.multiplyMatrices(t.projectionMatrix,t.matrixWorldInverse);const a=this.targetTriangleDensity;for(const p of s){if(p.material&&(((u=p.geometry)==null?void 0:u.type)==="BoxGeometry"||((f=p.geometry)==null?void 0:f.type)==="BufferGeometry")&&(p.material.name==="SphericalGaussianBlur"||p.material.name=="BackgroundCubeMaterial"||p.material.name==="CubemapFromEquirect"||p.material.name==="EquirectangularToCubeUV")){oe&&(p.material["NEEDLE_PROGRESSIVE:IGNORE-WARNING"]||(p.material["NEEDLE_PROGRESSIVE:IGNORE-WARNING"]=!0,console.warn("Ignoring skybox or BLIT object",p,p.material.name,p.material.type)));continue}switch(p.material.type){case"LineBasicMaterial":case"LineDashedMaterial":case"PointsMaterial":case"ShadowMaterial":case"MeshDistanceMaterial":case"MeshDepthMaterial":continue}if(oe==="color"&&p.material&&!p.object.progressive_debug_color){p.object.progressive_debug_color=!0;const l=Math.random()*16777215,h=new d.MeshStandardMaterial({color:l});p.object.material=h}const r=p.object;(r instanceof d.Mesh||r.isMesh)&&this.updateLODs(e,t,r,a)}const o=i.transparent;for(const p of o){const r=p.object;(r instanceof d.Mesh||r.isMesh)&&this.updateLODs(e,t,r,a)}const c=i.transmissive;for(const p of c){const r=p.object;(r instanceof d.Mesh||r.isMesh)&&this.updateLODs(e,t,r,a)}}updateLODs(e,t,i,s){var c,u;i.userData||(i.userData={});let a=i[Ai];if(a||(a=new Aa,i[Ai]=a),a.frames++<2)return;for(const f of Se)(c=f.onBeforeUpdateLOD)==null||c.call(f,this.renderer,e,t,i);const o=this.overrideLodLevel!==void 0?this.overrideLodLevel:Be;o>=0?(X.mesh_lod=o,X.texture_lod=o):(this.calculateLodLevel(t,i,a,s,X),X.mesh_lod=Math.round(X.mesh_lod),X.texture_lod=Math.round(X.texture_lod)),X.mesh_lod>=0&&this.loadProgressiveMeshes(i,X.mesh_lod),i.material&&X.texture_lod>=0&&this.loadProgressiveTextures(i.material,X.texture_lod,o),k&&i.material&&!i.isGizmo&&wr(i.material);for(const f of Se)(u=f.onAfterUpdatedLOD)==null||u.call(f,this.renderer,e,t,i,X);a.lastLodLevel_Mesh=X.mesh_lod,a.lastLodLevel_Texture=X.texture_lod}loadProgressiveTextures(e,t,i){if(!e)return;if(Array.isArray(e)){for(const a of e)this.loadProgressiveTextures(a,t);return}let s=!1;if((e[Ae]===void 0||t<e[Ae])&&(s=!0),i!==void 0&&i>=0&&(s=e[Ae]!=i,t=i),s){e[Ae]=t;const a=he.assignTextureLOD(e,t).then(o=>{this._lodchangedlisteners.forEach(c=>c({type:"texture",level:t,object:e}))});ei.addPromise("texture",e,a,this._newPromiseGroups)}}loadProgressiveMeshes(e,t){if(!e)return Promise.resolve(null);let i=e[Ae]!==t;const s=e["DEBUG:LOD"];if(s!=null&&(i=e[Ae]!=s,t=s),i){e[Ae]=t;const a=e.geometry,o=he.assignMeshLOD(e,t).then(c=>(c&&e[Ae]==t&&a!=e.geometry&&this._lodchangedlisteners.forEach(u=>u({type:"mesh",level:t,object:e})),c));return ei.addPromise("mesh",e,o,this._newPromiseGroups),o}return Promise.resolve(null)}static isInside(e,t){const i=e.min,s=e.max,a=(i.x+s.x)*.5,o=(i.y+s.y)*.5;return this._tempPtInside.set(a,o,i.z).applyMatrix4(t).z<0}calculateLodLevel(e,t,i,s,a){var m,v,y,x;if(!t){a.mesh_lod=-1,a.texture_lod=-1;return}if(!e){a.mesh_lod=-1,a.texture_lod=-1;return}let c=10+1,u=!1;if(oe&&t["DEBUG:LOD"]!=null)return t["DEBUG:LOD"];const f=(m=he.getMeshLODExtension(t.geometry))==null?void 0:m.lods,p=he.getPrimitiveIndex(t.geometry),r=f&&f.length>0,l=he.getMaterialMinMaxLODsCount(t.material),h=l.min_count!==1/0&&l.min_count>=0&&l.max_count>=0;if(!r&&!h){a.mesh_lod=0,a.texture_lod=0;return}r||(u=!0,c=0);const g=this.renderer.domElement.clientHeight||this.renderer.domElement.height;let _=t.geometry.boundingBox;if(t.type==="SkinnedMesh"){const w=t;if(!w.boundingBox)w.computeBoundingBox();else if(this.skinnedMeshAutoUpdateBoundsInterval>0){if(!w[V.$skinnedMeshBoundsOffset]){const A=V.skinnedMeshBoundsFrameOffsetCounter++;w[V.$skinnedMeshBoundsOffset]=A}const b=w[V.$skinnedMeshBoundsOffset];if((i.frames+b)%this.skinnedMeshAutoUpdateBoundsInterval===0){const A=Lt(w),T=w.geometry;A&&(w.geometry=A),w.computeBoundingBox(),w.geometry=T}}_=w.boundingBox}if(_){const w=e;if(t.geometry.attributes.color&&t.geometry.attributes.color.count<100&&t.geometry.boundingSphere){this._sphere.copy(t.geometry.boundingSphere),this._sphere.applyMatrix4(t.matrixWorld);const M=e.getWorldPosition(this._tempWorldPosition);if(this._sphere.containsPoint(M)){a.mesh_lod=0,a.texture_lod=0;return}}if(this._tempBox.copy(_),this._tempBox.applyMatrix4(t.matrixWorld),w.isPerspectiveCamera&&V.isInside(this._tempBox,this.projectionScreenMatrix)){a.mesh_lod=0,a.texture_lod=0;return}if(this._tempBox.applyMatrix4(this.projectionScreenMatrix),this.renderer.xr.enabled&&w.isPerspectiveCamera&&w.fov>70){const M=this._tempBox.min,R=this._tempBox.max;let E=M.x,F=M.y,O=R.x,H=R.y;const W=2,j=1.5,Y=(M.x+R.x)*.5,pe=(M.y+R.y)*.5;E=(E-Y)*W+Y,F=(F-pe)*W+pe,O=(O-Y)*W+Y,H=(H-pe)*W+pe;const ht=E<0&&O>0?0:Math.min(Math.abs(M.x),Math.abs(R.x)),di=F<0&&H>0?0:Math.min(Math.abs(M.y),Math.abs(R.y)),ft=Math.max(ht,di);i.lastCentrality=(j-ft)*(j-ft)*(j-ft)}else i.lastCentrality=1;const b=this._tempBox.getSize(this._tempBoxSize);b.multiplyScalar(.5),screen.availHeight>0&&g>0&&b.multiplyScalar(g/screen.availHeight),e.isPerspectiveCamera?b.x*=e.aspect:e.isOrthographicCamera;const A=e.matrixWorldInverse,T=this._tempBox2;T.copy(_),T.applyMatrix4(t.matrixWorld),T.applyMatrix4(A);const I=T.getSize(this._tempBox2Size),C=Math.max(I.x,I.y);if(Math.max(b.x,b.y)!=0&&C!=0&&(b.z=I.z/Math.max(I.x,I.y)*Math.max(b.x,b.y)),i.lastScreenCoverage=Math.max(b.x,b.y,b.z),i.lastScreenspaceVolume.copy(b),i.lastScreenCoverage*=i.lastCentrality,oe&&V.debugDrawLine){const M=this.tempMatrix.copy(this.projectionScreenMatrix);M.invert();const R=V.corner0,E=V.corner1,F=V.corner2,O=V.corner3;R.copy(this._tempBox.min),E.copy(this._tempBox.max),E.x=R.x,F.copy(this._tempBox.max),F.y=R.y,O.copy(this._tempBox.max);const H=(R.z+O.z)*.5;R.z=E.z=F.z=O.z=H,R.applyMatrix4(M),E.applyMatrix4(M),F.applyMatrix4(M),O.applyMatrix4(M),V.debugDrawLine(R,E,255),V.debugDrawLine(R,F,255),V.debugDrawLine(E,O,255),V.debugDrawLine(F,O,255)}let D=999;if(f&&i.lastScreenCoverage>0)for(let M=0;M<f.length;M++){const R=f[M],F=(((v=R.densities)==null?void 0:v[p])||R.density||1e-5)/i.lastScreenCoverage;if(p>0&&Vs()&&!R.densities&&!globalThis["NEEDLE:MISSING_LOD_PRIMITIVE_DENSITIES"]&&(window["NEEDLE:MISSING_LOD_PRIMITIVE_DENSITIES"]=!0,console.warn("[Needle Progressive] Detected usage of mesh without primitive densities. This might cause incorrect LOD level selection: Consider re-optimizing your model by updating your Needle Integration, Needle glTF Pipeline or running optimization again on Needle Cloud.")),F<s){D=M;break}}D<c&&(c=D,u=!0)}if(u?a.mesh_lod=c:a.mesh_lod=i.lastLodLevel_Mesh,oe&&a.mesh_lod!=i.lastLodLevel_Mesh){const b=f==null?void 0:f[a.mesh_lod];b&&console.log(`Mesh LOD changed: ${i.lastLodLevel_Mesh} → ${a.mesh_lod} (density: ${(y=b.densities)==null?void 0:y[p].toFixed(0)}) | ${t.name}`)}if(h){const w="saveData"in globalThis.navigator&&globalThis.navigator.saveData===!0;if(i.lastLodLevel_Texture<0){if(a.texture_lod=l.max_count-1,oe){const b=l.lods[l.max_count-1];oe&&console.log(`First Texture LOD ${a.texture_lod} (${b.max_height}px) - ${t.name}`)}}else{const b=i.lastScreenspaceVolume.x+i.lastScreenspaceVolume.y+i.lastScreenspaceVolume.z;let A=i.lastScreenCoverage*4;((x=this.context)==null?void 0:x.engine)==="model-viewer"&&(A*=1.5);const I=g/window.devicePixelRatio*A;let C=!1;for(let P=l.lods.length-1;P>=0;P--){const D=l.lods[P];if(!(w&&D.max_height>=2048)&&!(xr()&&D.max_height>4096)&&(D.max_height>I||!C&&P===0)){if(C=!0,a.texture_lod=P,oe&&a.texture_lod<i.lastLodLevel_Texture){const S=D.max_height;console.log(`Texture LOD changed: ${i.lastLodLevel_Texture} → ${a.texture_lod} = ${S}px
3685
+ `,t.uuid),t=t.clone(),t.offset=e.offset,t.repeat=e.repeat,t.colorSpace=e.colorSpace,t.magFilter=e.magFilter,t.minFilter=e.minFilter,t.wrapS=e.wrapS,t.wrapT=e.wrapT,t.flipY=e.flipY,t.anisotropy=e.anisotropy,t.mipmaps||(t.generateMipmaps=e.generateMipmaps),t):e}};L(B,"registerTexture",(e,t,i,s,a)=>{var c,u,f,p,r,l,h,g;if(!t){k&&console.error("!! gltf-progressive: Called register texture without texture");return}if(k){const _=((c=t.image)==null?void 0:c.width)||((f=(u=t.source)==null?void 0:u.data)==null?void 0:f.width)||0,m=((p=t.image)==null?void 0:p.height)||((l=(r=t.source)==null?void 0:r.data)==null?void 0:l.height)||0;console.log(`> gltf-progressive: register texture[${s}] "${t.name||t.uuid}", Current: ${_}x${m}, Max: ${(h=a.lods[0])==null?void 0:h.width}x${(g=a.lods[0])==null?void 0:g.height}, uuid: ${t.uuid}`,a,t)}t.source&&(t.source[bi]=a);const o=a.guid;B.assignLODInformation(e,t,o,i,s),B.lodInfos.set(o,a),B.lowresCache.set(o,t)}),L(B,"registerMesh",(e,t,i,s,a,o)=>{var f;const c=i.geometry;if(!c){k&&console.warn("gltf-progressive: Register mesh without geometry");return}c.userData||(c.userData={}),k&&console.log("> Progressive: register mesh "+i.name,{index:a,uuid:i.uuid},o,i),B.assignLODInformation(e,c,t,s,a),B.lodInfos.set(t,o);let u=B.lowresCache.get(t);u?u.push(i.geometry):u=[i.geometry],B.lowresCache.set(t,u),s>0&&!Lt(i)&&fa(i,c);for(const p of Se)(f=p.onRegisteredNewMesh)==null||f.call(p,i,o)}),L(B,"lodInfos",new Map),L(B,"previouslyLoaded",new Map),L(B,"lowresCache",new Map),L(B,"workers",[]),L(B,"_workersIndex",0),L(B,"maxConcurrent",50),L(B,"queue",new ua(B.maxConcurrent,{debug:k!=!1}));let he=B;class wa{constructor(e,t,i,s){L(this,"url");L(this,"key");L(this,"level");L(this,"index");this.url=e,this.key=t,this.level=i,s!=null&&(this.index=s)}}class ei{constructor(e,t){L(this,"ready");L(this,"_resolve");L(this,"_signal");L(this,"_frame_start");L(this,"_frames_to_capture");L(this,"_resolved",!1);L(this,"_addedCount",0);L(this,"_resolvedCount",0);L(this,"_awaiting",[]);L(this,"_maxPromisesPerObject",1);L(this,"_currentFrame",0);L(this,"_seen",new WeakMap);var a;const s=Math.max(t.frames??2,2);this._frame_start=t.waitForFirstCapture?void 0:e,this._frames_to_capture=s,this.ready=new Promise(o=>{this._resolve=o}),this.ready.finally(()=>{this._resolved=!0,this._awaiting.length=0}),this._signal=t.signal,(a=this._signal)==null||a.addEventListener("abort",()=>{this.resolveNow()}),this._maxPromisesPerObject=Math.max(1,t.maxPromisesPerObject??1)}get awaitedCount(){return this._addedCount}get resolvedCount(){return this._resolvedCount}get currentlyAwaiting(){return this._awaiting.length}update(e){var t;this._currentFrame=e,this._frame_start===void 0&&this._addedCount>0&&(this._frame_start=e),((t=this._signal)!=null&&t.aborted||this._awaiting.length===0&&this._frame_start!==void 0&&e>this._frame_start+this._frames_to_capture)&&this.resolveNow()}add(e,t,i){if(this._resolved){k&&console.warn("PromiseGroup: Trying to add a promise to a resolved group, ignoring.");return}if(!(this._frame_start!==void 0&&this._currentFrame>this._frame_start+this._frames_to_capture)){if(this._maxPromisesPerObject>=1)if(this._seen.has(t)){let s=this._seen.get(t);if(s>=this._maxPromisesPerObject){k&&console.warn("PromiseGroup: Already awaiting object ignoring new promise for it.");return}this._seen.set(t,s+1)}else this._seen.set(t,1);this._awaiting.push(i),this._addedCount++,i.finally(()=>{this._resolvedCount++,this._awaiting.splice(this._awaiting.indexOf(i),1)})}}resolveNow(){var e,t;this._resolved||(t=this._resolve)==null||t.call(this,{awaited_count:this._addedCount,resolved_count:this._resolvedCount,cancelled:((e=this._signal)==null?void 0:e.aborted)??!1})}}L(ei,"addPromise",(e,t,i,s)=>{s.forEach(a=>{a.add(e,t,i)})});const oe=ze("debugprogressive"),ba=ze("noprogressive"),Ai=Symbol("Needle:LODSManager"),Ti=Symbol("Needle:LODState"),Ae=Symbol("Needle:CurrentLOD"),X={mesh_lod:-1,texture_lod:-1};var J,ve,ai,Ie,nt,li,_e;const V=class V{constructor(e,t){L(this,"renderer");L(this,"context");L(this,"projectionScreenMatrix",new d.Matrix4);L(this,"overrideLodLevel");L(this,"targetTriangleDensity",2e5);L(this,"skinnedMeshAutoUpdateBoundsInterval",30);L(this,"updateInterval","auto");be(this,J,1);L(this,"pause",!1);L(this,"manual",!1);L(this,"_newPromiseGroups",[]);L(this,"_promiseGroupIds",0);L(this,"_lodchangedlisteners",[]);be(this,ve,void 0);be(this,ai,new d.Clock);be(this,Ie,0);be(this,nt,0);be(this,li,0);be(this,_e,0);L(this,"_fpsBuffer",[60,60,60,60,60]);L(this,"_sphere",new d.Sphere);L(this,"_tempBox",new d.Box3);L(this,"_tempBox2",new d.Box3);L(this,"tempMatrix",new d.Matrix4);L(this,"_tempWorldPosition",new d.Vector3);L(this,"_tempBoxSize",new d.Vector3);L(this,"_tempBox2Size",new d.Vector3);this.renderer=e,this.context={...t}}static getObjectLODState(e){return e[Ti]}static addPlugin(e){Se.push(e)}static removePlugin(e){const t=Se.indexOf(e);t>=0&&Se.splice(t,1)}static get(e,t){if(e[Ai])return console.debug("[gltf-progressive] LODsManager already exists for this renderer"),e[Ai];const i=new V(e,{engine:"unknown",...t});return e[Ai]=i,i}get plugins(){return Se}awaitLoading(e){const t=this._promiseGroupIds++,i=new ei(z(this,Ie),{...e});this._newPromiseGroups.push(i);const s=performance.now();return i.ready.finally(()=>{const a=this._newPromiseGroups.indexOf(i);a>=0&&(this._newPromiseGroups.splice(a,1),Us()&&performance.measure("LODsManager:awaitLoading",{start:s,detail:{id:t,name:e==null?void 0:e.name,awaited:i.awaitedCount,resolved:i.resolvedCount}}))}),i.ready}_postprocessPromiseGroups(){if(this._newPromiseGroups.length!==0)for(let e=this._newPromiseGroups.length-1;e>=0;e--)this._newPromiseGroups[e].update(z(this,Ie))}addEventListener(e,t){e==="changed"&&this._lodchangedlisteners.push(t)}removeEventListener(e,t){if(e==="changed"){const i=this._lodchangedlisteners.indexOf(t);i>=0&&this._lodchangedlisteners.splice(i,1)}}enable(){if(z(this,ve))return;console.debug("[gltf-progressive] Enabling LODsManager for renderer");let e=0;ue(this,ve,this.renderer.render);const t=this;as(this.renderer),this.renderer.render=function(i,s){const a=t.renderer.getRenderTarget();(a==null||"isXRRenderTarget"in a&&a.isXRRenderTarget)&&(e=0,ue(t,Ie,z(t,Ie)+1),ue(t,nt,z(t,ai).getDelta()),ue(t,li,z(t,li)+z(t,nt)),t._fpsBuffer.shift(),t._fpsBuffer.push(1/z(t,nt)),ue(t,_e,t._fpsBuffer.reduce((c,u)=>c+u)/t._fpsBuffer.length),oe&&z(t,Ie)%200===0&&console.log("FPS",Math.round(z(t,_e)),"Interval:",z(t,J)));const o=e++;z(t,ve).call(this,i,s),t.onAfterRender(i,s,o)}}disable(){z(this,ve)&&(console.debug("[gltf-progressive] Disabling LODsManager for renderer"),this.renderer.render=z(this,ve),ue(this,ve,void 0))}update(e,t){this.internalUpdate(e,t)}onAfterRender(e,t,i){if(this.pause)return;const a=this.renderer.renderLists.get(e,0).opaque;let o=!0;if(a.length===1){const c=a[0].material;(c.name==="EffectMaterial"||c.name==="CopyShader")&&(o=!1)}if((t.parent&&t.parent.type==="CubeCamera"||i>=1&&t.type==="OrthographicCamera")&&(o=!1),o){if(ba||(this.updateInterval==="auto"?z(this,_e)<40&&z(this,J)<10?(ue(this,J,z(this,J)+1),oe&&console.warn("↓ Reducing LOD updates",z(this,J),z(this,_e).toFixed(0))):z(this,_e)>=60&&z(this,J)>1&&(ue(this,J,z(this,J)-1),oe&&console.warn("↑ Increasing LOD updates",z(this,J),z(this,_e).toFixed(0))):ue(this,J,this.updateInterval),z(this,J)>0&&z(this,Ie)%z(this,J)!=0))return;this.internalUpdate(e,t),this._postprocessPromiseGroups()}}internalUpdate(e,t){var u,f;const i=this.renderer.renderLists.get(e,0),s=i.opaque;this.projectionScreenMatrix.multiplyMatrices(t.projectionMatrix,t.matrixWorldInverse);const a=this.targetTriangleDensity;for(const p of s){if(p.material&&(((u=p.geometry)==null?void 0:u.type)==="BoxGeometry"||((f=p.geometry)==null?void 0:f.type)==="BufferGeometry")&&(p.material.name==="SphericalGaussianBlur"||p.material.name=="BackgroundCubeMaterial"||p.material.name==="CubemapFromEquirect"||p.material.name==="EquirectangularToCubeUV")){oe&&(p.material["NEEDLE_PROGRESSIVE:IGNORE-WARNING"]||(p.material["NEEDLE_PROGRESSIVE:IGNORE-WARNING"]=!0,console.warn("Ignoring skybox or BLIT object",p,p.material.name,p.material.type)));continue}switch(p.material.type){case"LineBasicMaterial":case"LineDashedMaterial":case"PointsMaterial":case"ShadowMaterial":case"MeshDistanceMaterial":case"MeshDepthMaterial":continue}if(oe==="color"&&p.material&&!p.object.progressive_debug_color){p.object.progressive_debug_color=!0;const l=Math.random()*16777215,h=new d.MeshStandardMaterial({color:l});p.object.material=h}const r=p.object;(r instanceof d.Mesh||r.isMesh)&&this.updateLODs(e,t,r,a)}const o=i.transparent;for(const p of o){const r=p.object;(r instanceof d.Mesh||r.isMesh)&&this.updateLODs(e,t,r,a)}const c=i.transmissive;for(const p of c){const r=p.object;(r instanceof d.Mesh||r.isMesh)&&this.updateLODs(e,t,r,a)}}updateLODs(e,t,i,s){var c,u;i.userData||(i.userData={});let a=i[Ti];if(a||(a=new Aa,i[Ti]=a),a.frames++<2)return;for(const f of Se)(c=f.onBeforeUpdateLOD)==null||c.call(f,this.renderer,e,t,i);const o=this.overrideLodLevel!==void 0?this.overrideLodLevel:Be;o>=0?(X.mesh_lod=o,X.texture_lod=o):(this.calculateLodLevel(t,i,a,s,X),X.mesh_lod=Math.round(X.mesh_lod),X.texture_lod=Math.round(X.texture_lod)),X.mesh_lod>=0&&this.loadProgressiveMeshes(i,X.mesh_lod),i.material&&X.texture_lod>=0&&this.loadProgressiveTextures(i.material,X.texture_lod,o),k&&i.material&&!i.isGizmo&&br(i.material);for(const f of Se)(u=f.onAfterUpdatedLOD)==null||u.call(f,this.renderer,e,t,i,X);a.lastLodLevel_Mesh=X.mesh_lod,a.lastLodLevel_Texture=X.texture_lod}loadProgressiveTextures(e,t,i){if(!e)return;if(Array.isArray(e)){for(const a of e)this.loadProgressiveTextures(a,t);return}let s=!1;if((e[Ae]===void 0||t<e[Ae])&&(s=!0),i!==void 0&&i>=0&&(s=e[Ae]!=i,t=i),s){e[Ae]=t;const a=he.assignTextureLOD(e,t).then(o=>{this._lodchangedlisteners.forEach(c=>c({type:"texture",level:t,object:e}))});ei.addPromise("texture",e,a,this._newPromiseGroups)}}loadProgressiveMeshes(e,t){if(!e)return Promise.resolve(null);let i=e[Ae]!==t;const s=e["DEBUG:LOD"];if(s!=null&&(i=e[Ae]!=s,t=s),i){e[Ae]=t;const a=e.geometry,o=he.assignMeshLOD(e,t).then(c=>(c&&e[Ae]==t&&a!=e.geometry&&this._lodchangedlisteners.forEach(u=>u({type:"mesh",level:t,object:e})),c));return ei.addPromise("mesh",e,o,this._newPromiseGroups),o}return Promise.resolve(null)}static isInside(e,t){const i=e.min,s=e.max,a=(i.x+s.x)*.5,o=(i.y+s.y)*.5;return this._tempPtInside.set(a,o,i.z).applyMatrix4(t).z<0}calculateLodLevel(e,t,i,s,a){var m,v,y,x;if(!t){a.mesh_lod=-1,a.texture_lod=-1;return}if(!e){a.mesh_lod=-1,a.texture_lod=-1;return}let c=10+1,u=!1;if(oe&&t["DEBUG:LOD"]!=null)return t["DEBUG:LOD"];const f=(m=he.getMeshLODExtension(t.geometry))==null?void 0:m.lods,p=he.getPrimitiveIndex(t.geometry),r=f&&f.length>0,l=he.getMaterialMinMaxLODsCount(t.material),h=l.min_count!==1/0&&l.min_count>=0&&l.max_count>=0;if(!r&&!h){a.mesh_lod=0,a.texture_lod=0;return}r||(u=!0,c=0);const g=this.renderer.domElement.clientHeight||this.renderer.domElement.height;let _=t.geometry.boundingBox;if(t.type==="SkinnedMesh"){const w=t;if(!w.boundingBox)w.computeBoundingBox();else if(this.skinnedMeshAutoUpdateBoundsInterval>0){if(!w[V.$skinnedMeshBoundsOffset]){const A=V.skinnedMeshBoundsFrameOffsetCounter++;w[V.$skinnedMeshBoundsOffset]=A}const b=w[V.$skinnedMeshBoundsOffset];if((i.frames+b)%this.skinnedMeshAutoUpdateBoundsInterval===0){const A=Lt(w),T=w.geometry;A&&(w.geometry=A),w.computeBoundingBox(),w.geometry=T}}_=w.boundingBox}if(_){const w=e;if(t.geometry.attributes.color&&t.geometry.attributes.color.count<100&&t.geometry.boundingSphere){this._sphere.copy(t.geometry.boundingSphere),this._sphere.applyMatrix4(t.matrixWorld);const M=e.getWorldPosition(this._tempWorldPosition);if(this._sphere.containsPoint(M)){a.mesh_lod=0,a.texture_lod=0;return}}if(this._tempBox.copy(_),this._tempBox.applyMatrix4(t.matrixWorld),w.isPerspectiveCamera&&V.isInside(this._tempBox,this.projectionScreenMatrix)){a.mesh_lod=0,a.texture_lod=0;return}if(this._tempBox.applyMatrix4(this.projectionScreenMatrix),this.renderer.xr.enabled&&w.isPerspectiveCamera&&w.fov>70){const M=this._tempBox.min,R=this._tempBox.max;let E=M.x,F=M.y,O=R.x,H=R.y;const W=2,j=1.5,Y=(M.x+R.x)*.5,pe=(M.y+R.y)*.5;E=(E-Y)*W+Y,F=(F-pe)*W+pe,O=(O-Y)*W+Y,H=(H-pe)*W+pe;const ht=E<0&&O>0?0:Math.min(Math.abs(M.x),Math.abs(R.x)),di=F<0&&H>0?0:Math.min(Math.abs(M.y),Math.abs(R.y)),ft=Math.max(ht,di);i.lastCentrality=(j-ft)*(j-ft)*(j-ft)}else i.lastCentrality=1;const b=this._tempBox.getSize(this._tempBoxSize);b.multiplyScalar(.5),screen.availHeight>0&&g>0&&b.multiplyScalar(g/screen.availHeight),e.isPerspectiveCamera?b.x*=e.aspect:e.isOrthographicCamera;const A=e.matrixWorldInverse,T=this._tempBox2;T.copy(_),T.applyMatrix4(t.matrixWorld),T.applyMatrix4(A);const I=T.getSize(this._tempBox2Size),C=Math.max(I.x,I.y);if(Math.max(b.x,b.y)!=0&&C!=0&&(b.z=I.z/Math.max(I.x,I.y)*Math.max(b.x,b.y)),i.lastScreenCoverage=Math.max(b.x,b.y,b.z),i.lastScreenspaceVolume.copy(b),i.lastScreenCoverage*=i.lastCentrality,oe&&V.debugDrawLine){const M=this.tempMatrix.copy(this.projectionScreenMatrix);M.invert();const R=V.corner0,E=V.corner1,F=V.corner2,O=V.corner3;R.copy(this._tempBox.min),E.copy(this._tempBox.max),E.x=R.x,F.copy(this._tempBox.max),F.y=R.y,O.copy(this._tempBox.max);const H=(R.z+O.z)*.5;R.z=E.z=F.z=O.z=H,R.applyMatrix4(M),E.applyMatrix4(M),F.applyMatrix4(M),O.applyMatrix4(M),V.debugDrawLine(R,E,255),V.debugDrawLine(R,F,255),V.debugDrawLine(E,O,255),V.debugDrawLine(F,O,255)}let D=999;if(f&&i.lastScreenCoverage>0)for(let M=0;M<f.length;M++){const R=f[M],F=(((v=R.densities)==null?void 0:v[p])||R.density||1e-5)/i.lastScreenCoverage;if(p>0&&Us()&&!R.densities&&!globalThis["NEEDLE:MISSING_LOD_PRIMITIVE_DENSITIES"]&&(window["NEEDLE:MISSING_LOD_PRIMITIVE_DENSITIES"]=!0,console.warn("[Needle Progressive] Detected usage of mesh without primitive densities. This might cause incorrect LOD level selection: Consider re-optimizing your model by updating your Needle Integration, Needle glTF Pipeline or running optimization again on Needle Cloud.")),F<s){D=M;break}}D<c&&(c=D,u=!0)}if(u?a.mesh_lod=c:a.mesh_lod=i.lastLodLevel_Mesh,oe&&a.mesh_lod!=i.lastLodLevel_Mesh){const b=f==null?void 0:f[a.mesh_lod];b&&console.log(`Mesh LOD changed: ${i.lastLodLevel_Mesh} → ${a.mesh_lod} (density: ${(y=b.densities)==null?void 0:y[p].toFixed(0)}) | ${t.name}`)}if(h){const w="saveData"in globalThis.navigator&&globalThis.navigator.saveData===!0;if(i.lastLodLevel_Texture<0){if(a.texture_lod=l.max_count-1,oe){const b=l.lods[l.max_count-1];oe&&console.log(`First Texture LOD ${a.texture_lod} (${b.max_height}px) - ${t.name}`)}}else{const b=i.lastScreenspaceVolume.x+i.lastScreenspaceVolume.y+i.lastScreenspaceVolume.z;let A=i.lastScreenCoverage*4;((x=this.context)==null?void 0:x.engine)==="model-viewer"&&(A*=1.5);const I=g/window.devicePixelRatio*A;let C=!1;for(let P=l.lods.length-1;P>=0;P--){const D=l.lods[P];if(!(w&&D.max_height>=2048)&&!(wr()&&D.max_height>4096)&&(D.max_height>I||!C&&P===0)){if(C=!0,a.texture_lod=P,oe&&a.texture_lod<i.lastLodLevel_Texture){const S=D.max_height;console.log(`Texture LOD changed: ${i.lastLodLevel_Texture} → ${a.texture_lod} = ${S}px
3686
3686
  Screensize: ${I.toFixed(0)}px, Coverage: ${(100*i.lastScreenCoverage).toFixed(2)}%, Volume ${b.toFixed(1)}
3687
- ${t.name}`)}break}}}}else a.texture_lod=0}};J=new WeakMap,ve=new WeakMap,ai=new WeakMap,Ie=new WeakMap,rt=new WeakMap,li=new WeakMap,_e=new WeakMap,L(V,"debugDrawLine"),L(V,"corner0",new d.Vector3),L(V,"corner1",new d.Vector3),L(V,"corner2",new d.Vector3),L(V,"corner3",new d.Vector3),L(V,"_tempPtInside",new d.Vector3),L(V,"skinnedMeshBoundsFrameOffsetCounter",0),L(V,"$skinnedMeshBoundsOffset",Symbol("gltf-progressive-skinnedMeshBoundsOffset"));let at=V;class Aa{constructor(){L(this,"frames",0);L(this,"lastLodLevel_Mesh",-1);L(this,"lastLodLevel_Texture",-1);L(this,"lastScreenCoverage",0);L(this,"lastScreenspaceVolume",new d.Vector3);L(this,"lastCentrality",0)}}const Us=Symbol("NEEDLE_mesh_lod"),Vt=Symbol("NEEDLE_texture_lod");let gt=null;function br(){const n=Ta();n&&(n.mapURLs(function(e){return Hs(),e}),Hs(),gt==null||gt.disconnect(),gt=new MutationObserver(e=>{e.forEach(t=>{t.addedNodes.forEach(i=>{i instanceof HTMLElement&&i.tagName.toLowerCase()==="model-viewer"&&Ar(i)})})}),gt.observe(document,{childList:!0,subtree:!0}))}function Ta(){if(typeof customElements>"u")return null;const n=customElements.get("model-viewer");return n||(customElements.whenDefined("model-viewer").then(()=>{console.debug("[gltf-progressive] model-viewer defined"),br()}),null)}function Hs(){if(typeof document>"u")return;document.querySelectorAll("model-viewer").forEach(e=>{Ar(e)})}const Ns=new WeakSet;let Sa=0;function Ar(n){if(!n||Ns.has(n))return null;Ns.add(n),console.debug("[gltf-progressive] found new model-viewer..."+ ++Sa+`
3688
- `,n.getAttribute("src"));let e=null,t=null,i=null;for(let s=n;s!=null;s=Object.getPrototypeOf(s)){const a=Object.getOwnPropertySymbols(s),o=a.find(f=>f.toString()=="Symbol(renderer)"),c=a.find(f=>f.toString()=="Symbol(scene)"),u=a.find(f=>f.toString()=="Symbol(needsRender)");!e&&o!=null&&(e=n[o].threeRenderer),!t&&c!=null&&(t=n[c]),!i&&u!=null&&(i=n[u])}if(e&&t){let s=function(){if(i){let o=0,c=setInterval(()=>{if(o++>5){clearInterval(c);return}i==null||i.call(n)},300)}};console.debug("[gltf-progressive] setup model-viewer");const a=at.get(e,{engine:"model-viewer"});return at.addPlugin(new Ma),a.enable(),a.addEventListener("changed",()=>{i==null||i.call(n)}),n.addEventListener("model-visibility",o=>{o.detail.visible&&(i==null||i.call(n))}),n.addEventListener("load",()=>{s()}),()=>{a.disable()}}return null}class Ma{constructor(){L(this,"_didWarnAboutMissingUrl",!1)}onBeforeUpdateLOD(e,t,i,s){this.tryParseMeshLOD(t,s),this.tryParseTextureLOD(t,s)}getUrl(e){if(!e)return null;let t=e.getAttribute("src");return t||(t=e.src),t||(this._didWarnAboutMissingUrl||console.warn("No url found in modelviewer",e),this._didWarnAboutMissingUrl=!0),t}tryGetCurrentGLTF(e){return e._currentGLTF}tryGetCurrentModelViewer(e){return e.element}tryParseTextureLOD(e,t){if(t[Vt]==!0)return;t[Vt]=!0;const i=this.tryGetCurrentGLTF(e),s=this.tryGetCurrentModelViewer(e),a=this.getUrl(s);if(a&&i&&t.material){let o=function(u){var p,r,l;if(u[Vt]==!0)return;u[Vt]=!0,u.userData&&(u.userData.LOD=-1);const f=Object.keys(u);for(let h=0;h<f.length;h++){const g=f[h],_=u[g];if((_==null?void 0:_.isTexture)===!0){const m=(r=(p=_.userData)==null?void 0:p.associations)==null?void 0:r.textures;if(m==null)continue;const v=i.parser.json.textures[m];if(!v){console.warn("Texture data not found for texture index "+m);continue}if((l=v==null?void 0:v.extensions)!=null&&l[ge]){const y=v.extensions[ge];y&&a&&he.registerTexture(a,_,y.lods.length,m,y)}}}};const c=t.material;if(Array.isArray(c))for(const u of c)o(u);else o(c)}}tryParseMeshLOD(e,t){var o,c;if(t[Us]==!0)return;t[Us]=!0;const i=this.tryGetCurrentModelViewer(e),s=this.getUrl(i);if(!s)return;const a=(c=(o=t.userData)==null?void 0:o.gltfExtensions)==null?void 0:c[ge];if(a&&s){const u=t.uuid;he.registerMesh(s,u,t,0,a.lods.length,a)}}}function Tr(...n){let e,t,i,s;switch(n.length){case 2:[i,t]=n,s={};break;case 3:[i,t,s]=n;break;case 4:[e,t,i,s]=n;break;default:throw new Error("Invalid arguments")}os(),vr(i),yr(i,{progressive:!0,...s==null?void 0:s.hints}),i.register(o=>new he(o));const a=at.get(t);return(s==null?void 0:s.enableLODsManager)!==!1&&a.enable(),a}br();if(!ha){const n={gltfProgressive:{useNeedleProgressive:Tr,LODsManager:at,configureLoader:yr,getRaycastMesh:Lt,useRaycastMeshes:da}};if(!globalThis.Needle)globalThis.Needle=n;else for(const e in n)globalThis.Needle[e]=n[e]}var it=Object.freeze({Linear:Object.freeze({None:function(n){return n},In:function(n){return n},Out:function(n){return n},InOut:function(n){return n}}),Quadratic:Object.freeze({In:function(n){return n*n},Out:function(n){return n*(2-n)},InOut:function(n){return(n*=2)<1?.5*n*n:-.5*(--n*(n-2)-1)}}),Cubic:Object.freeze({In:function(n){return n*n*n},Out:function(n){return--n*n*n+1},InOut:function(n){return(n*=2)<1?.5*n*n*n:.5*((n-=2)*n*n+2)}}),Quartic:Object.freeze({In:function(n){return n*n*n*n},Out:function(n){return 1- --n*n*n*n},InOut:function(n){return(n*=2)<1?.5*n*n*n*n:-.5*((n-=2)*n*n*n-2)}}),Quintic:Object.freeze({In:function(n){return n*n*n*n*n},Out:function(n){return--n*n*n*n*n+1},InOut:function(n){return(n*=2)<1?.5*n*n*n*n*n:.5*((n-=2)*n*n*n*n+2)}}),Sinusoidal:Object.freeze({In:function(n){return 1-Math.sin((1-n)*Math.PI/2)},Out:function(n){return Math.sin(n*Math.PI/2)},InOut:function(n){return .5*(1-Math.sin(Math.PI*(.5-n)))}}),Exponential:Object.freeze({In:function(n){return n===0?0:Math.pow(1024,n-1)},Out:function(n){return n===1?1:1-Math.pow(2,-10*n)},InOut:function(n){return n===0?0:n===1?1:(n*=2)<1?.5*Math.pow(1024,n-1):.5*(-Math.pow(2,-10*(n-1))+2)}}),Circular:Object.freeze({In:function(n){return 1-Math.sqrt(1-n*n)},Out:function(n){return Math.sqrt(1- --n*n)},InOut:function(n){return(n*=2)<1?-.5*(Math.sqrt(1-n*n)-1):.5*(Math.sqrt(1-(n-=2)*n)+1)}}),Elastic:Object.freeze({In:function(n){return n===0?0:n===1?1:-Math.pow(2,10*(n-1))*Math.sin((n-1.1)*5*Math.PI)},Out:function(n){return n===0?0:n===1?1:Math.pow(2,-10*n)*Math.sin((n-.1)*5*Math.PI)+1},InOut:function(n){return n===0?0:n===1?1:(n*=2,n<1?-.5*Math.pow(2,10*(n-1))*Math.sin((n-1.1)*5*Math.PI):.5*Math.pow(2,-10*(n-1))*Math.sin((n-1.1)*5*Math.PI)+1)}}),Back:Object.freeze({In:function(n){var e=1.70158;return n===1?1:n*n*((e+1)*n-e)},Out:function(n){var e=1.70158;return n===0?0:--n*n*((e+1)*n+e)+1},InOut:function(n){var e=2.5949095;return(n*=2)<1?.5*(n*n*((e+1)*n-e)):.5*((n-=2)*n*((e+1)*n+e)+2)}}),Bounce:Object.freeze({In:function(n){return 1-it.Bounce.Out(1-n)},Out:function(n){return n<1/2.75?7.5625*n*n:n<2/2.75?7.5625*(n-=1.5/2.75)*n+.75:n<2.5/2.75?7.5625*(n-=2.25/2.75)*n+.9375:7.5625*(n-=2.625/2.75)*n+.984375},InOut:function(n){return n<.5?it.Bounce.In(n*2)*.5:it.Bounce.Out(n*2-1)*.5+.5}}),generatePow:function(n){return n===void 0&&(n=4),n=n<Number.EPSILON?Number.EPSILON:n,n=n>1e4?1e4:n,{In:function(e){return Math.pow(e,n)},Out:function(e){return 1-Math.pow(1-e,n)},InOut:function(e){return e<.5?Math.pow(e*2,n)/2:(1-Math.pow(2-e*2,n))/2+.5}}}}),$e=function(){return performance.now()},Sr=function(){function n(){this._tweens={},this._tweensAddedDuringUpdate={}}return n.prototype.getAll=function(){var e=this;return Object.keys(this._tweens).map(function(t){return e._tweens[t]})},n.prototype.removeAll=function(){this._tweens={}},n.prototype.add=function(e){this._tweens[e.getId()]=e,this._tweensAddedDuringUpdate[e.getId()]=e},n.prototype.remove=function(e){delete this._tweens[e.getId()],delete this._tweensAddedDuringUpdate[e.getId()]},n.prototype.update=function(e,t){e===void 0&&(e=$e()),t===void 0&&(t=!1);var i=Object.keys(this._tweens);if(i.length===0)return!1;for(;i.length>0;){this._tweensAddedDuringUpdate={};for(var s=0;s<i.length;s++){var a=this._tweens[i[s]],o=!t;a&&a.update(e,o)===!1&&!t&&delete this._tweens[i[s]]}i=Object.keys(this._tweensAddedDuringUpdate)}return!0},n}(),ke={Linear:function(n,e){var t=n.length-1,i=t*e,s=Math.floor(i),a=ke.Utils.Linear;return e<0?a(n[0],n[1],i):e>1?a(n[t],n[t-1],t-i):a(n[s],n[s+1>t?t:s+1],i-s)},Bezier:function(n,e){for(var t=0,i=n.length-1,s=Math.pow,a=ke.Utils.Bernstein,o=0;o<=i;o++)t+=s(1-e,i-o)*s(e,o)*n[o]*a(i,o);return t},CatmullRom:function(n,e){var t=n.length-1,i=t*e,s=Math.floor(i),a=ke.Utils.CatmullRom;return n[0]===n[t]?(e<0&&(s=Math.floor(i=t*(1+e))),a(n[(s-1+t)%t],n[s],n[(s+1)%t],n[(s+2)%t],i-s)):e<0?n[0]-(a(n[0],n[0],n[1],n[1],-i)-n[0]):e>1?n[t]-(a(n[t],n[t],n[t-1],n[t-1],i-t)-n[t]):a(n[s?s-1:0],n[s],n[t<s+1?t:s+1],n[t<s+2?t:s+2],i-s)},Utils:{Linear:function(n,e,t){return(e-n)*t+n},Bernstein:function(n,e){var t=ke.Utils.Factorial;return t(n)/t(e)/t(n-e)},Factorial:function(){var n=[1];return function(e){var t=1;if(n[e])return n[e];for(var i=e;i>1;i--)t*=i;return n[e]=t,t}}(),CatmullRom:function(n,e,t,i,s){var a=(t-n)*.5,o=(i-e)*.5,c=s*s,u=s*c;return(2*e-2*t+a+o)*u+(-3*e+3*t-2*a-o)*c+a*s+e}}},ls=function(){function n(){}return n.nextId=function(){return n._nextId++},n._nextId=0,n}(),Ui=new Sr,It=function(){function n(e,t){t===void 0&&(t=Ui),this._object=e,this._group=t,this._isPaused=!1,this._pauseStart=0,this._valuesStart={},this._valuesEnd={},this._valuesStartRepeat={},this._duration=1e3,this._isDynamic=!1,this._initialRepeat=0,this._repeat=0,this._yoyo=!1,this._isPlaying=!1,this._reversed=!1,this._delayTime=0,this._startTime=0,this._easingFunction=it.Linear.None,this._interpolationFunction=ke.Linear,this._chainedTweens=[],this._onStartCallbackFired=!1,this._onEveryStartCallbackFired=!1,this._id=ls.nextId(),this._isChainStopped=!1,this._propertiesAreSetUp=!1,this._goToEnd=!1}return n.prototype.getId=function(){return this._id},n.prototype.isPlaying=function(){return this._isPlaying},n.prototype.isPaused=function(){return this._isPaused},n.prototype.getDuration=function(){return this._duration},n.prototype.to=function(e,t){if(t===void 0&&(t=1e3),this._isPlaying)throw new Error("Can not call Tween.to() while Tween is already started or paused. Stop the Tween first.");return this._valuesEnd=e,this._propertiesAreSetUp=!1,this._duration=t<0?0:t,this},n.prototype.duration=function(e){return e===void 0&&(e=1e3),this._duration=e<0?0:e,this},n.prototype.dynamic=function(e){return e===void 0&&(e=!1),this._isDynamic=e,this},n.prototype.start=function(e,t){if(e===void 0&&(e=$e()),t===void 0&&(t=!1),this._isPlaying)return this;if(this._group&&this._group.add(this),this._repeat=this._initialRepeat,this._reversed){this._reversed=!1;for(var i in this._valuesStartRepeat)this._swapEndStartRepeatValues(i),this._valuesStart[i]=this._valuesStartRepeat[i]}if(this._isPlaying=!0,this._isPaused=!1,this._onStartCallbackFired=!1,this._onEveryStartCallbackFired=!1,this._isChainStopped=!1,this._startTime=e,this._startTime+=this._delayTime,!this._propertiesAreSetUp||t){if(this._propertiesAreSetUp=!0,!this._isDynamic){var s={};for(var a in this._valuesEnd)s[a]=this._valuesEnd[a];this._valuesEnd=s}this._setupProperties(this._object,this._valuesStart,this._valuesEnd,this._valuesStartRepeat,t)}return this},n.prototype.startFromCurrentValues=function(e){return this.start(e,!0)},n.prototype._setupProperties=function(e,t,i,s,a){for(var o in i){var c=e[o],u=Array.isArray(c),f=u?"array":typeof c,p=!u&&Array.isArray(i[o]);if(!(f==="undefined"||f==="function")){if(p){var r=i[o];if(r.length===0)continue;for(var l=[c],h=0,g=r.length;h<g;h+=1){var _=this._handleRelativeValue(c,r[h]);if(isNaN(_)){p=!1,console.warn("Found invalid interpolation list. Skipping.");break}l.push(_)}p&&(i[o]=l)}if((f==="object"||u)&&c&&!p){t[o]=u?[]:{};var m=c;for(var v in m)t[o][v]=m[v];s[o]=u?[]:{};var r=i[o];if(!this._isDynamic){var y={};for(var v in r)y[v]=r[v];i[o]=r=y}this._setupProperties(m,t[o],r,s[o],a)}else(typeof t[o]>"u"||a)&&(t[o]=c),u||(t[o]*=1),p?s[o]=i[o].slice().reverse():s[o]=t[o]||0}}},n.prototype.stop=function(){return this._isChainStopped||(this._isChainStopped=!0,this.stopChainedTweens()),this._isPlaying?(this._group&&this._group.remove(this),this._isPlaying=!1,this._isPaused=!1,this._onStopCallback&&this._onStopCallback(this._object),this):this},n.prototype.end=function(){return this._goToEnd=!0,this.update(1/0),this},n.prototype.pause=function(e){return e===void 0&&(e=$e()),this._isPaused||!this._isPlaying?this:(this._isPaused=!0,this._pauseStart=e,this._group&&this._group.remove(this),this)},n.prototype.resume=function(e){return e===void 0&&(e=$e()),!this._isPaused||!this._isPlaying?this:(this._isPaused=!1,this._startTime+=e-this._pauseStart,this._pauseStart=0,this._group&&this._group.add(this),this)},n.prototype.stopChainedTweens=function(){for(var e=0,t=this._chainedTweens.length;e<t;e++)this._chainedTweens[e].stop();return this},n.prototype.group=function(e){return e===void 0&&(e=Ui),this._group=e,this},n.prototype.delay=function(e){return e===void 0&&(e=0),this._delayTime=e,this},n.prototype.repeat=function(e){return e===void 0&&(e=0),this._initialRepeat=e,this._repeat=e,this},n.prototype.repeatDelay=function(e){return this._repeatDelayTime=e,this},n.prototype.yoyo=function(e){return e===void 0&&(e=!1),this._yoyo=e,this},n.prototype.easing=function(e){return e===void 0&&(e=it.Linear.None),this._easingFunction=e,this},n.prototype.interpolation=function(e){return e===void 0&&(e=ke.Linear),this._interpolationFunction=e,this},n.prototype.chain=function(){for(var e=[],t=0;t<arguments.length;t++)e[t]=arguments[t];return this._chainedTweens=e,this},n.prototype.onStart=function(e){return this._onStartCallback=e,this},n.prototype.onEveryStart=function(e){return this._onEveryStartCallback=e,this},n.prototype.onUpdate=function(e){return this._onUpdateCallback=e,this},n.prototype.onRepeat=function(e){return this._onRepeatCallback=e,this},n.prototype.onComplete=function(e){return this._onCompleteCallback=e,this},n.prototype.onStop=function(e){return this._onStopCallback=e,this},n.prototype.update=function(e,t){var i=this,s;if(e===void 0&&(e=$e()),t===void 0&&(t=!0),this._isPaused)return!0;var a,o=this._startTime+this._duration;if(!this._goToEnd&&!this._isPlaying){if(e>o)return!1;t&&this.start(e,!0)}if(this._goToEnd=!1,e<this._startTime)return!0;this._onStartCallbackFired===!1&&(this._onStartCallback&&this._onStartCallback(this._object),this._onStartCallbackFired=!0),this._onEveryStartCallbackFired===!1&&(this._onEveryStartCallback&&this._onEveryStartCallback(this._object),this._onEveryStartCallbackFired=!0);var c=e-this._startTime,u=this._duration+((s=this._repeatDelayTime)!==null&&s!==void 0?s:this._delayTime),f=this._duration+this._repeat*u,p=function(){if(i._duration===0||c>f)return 1;var m=Math.trunc(c/u),v=c-m*u,y=Math.min(v/i._duration,1);return y===0&&c===i._duration?1:y},r=p(),l=this._easingFunction(r);if(this._updateProperties(this._object,this._valuesStart,this._valuesEnd,l),this._onUpdateCallback&&this._onUpdateCallback(this._object,r),this._duration===0||c>=this._duration)if(this._repeat>0){var h=Math.min(Math.trunc((c-this._duration)/u)+1,this._repeat);isFinite(this._repeat)&&(this._repeat-=h);for(a in this._valuesStartRepeat)!this._yoyo&&typeof this._valuesEnd[a]=="string"&&(this._valuesStartRepeat[a]=this._valuesStartRepeat[a]+parseFloat(this._valuesEnd[a])),this._yoyo&&this._swapEndStartRepeatValues(a),this._valuesStart[a]=this._valuesStartRepeat[a];return this._yoyo&&(this._reversed=!this._reversed),this._startTime+=u*h,this._onRepeatCallback&&this._onRepeatCallback(this._object),this._onEveryStartCallbackFired=!1,!0}else{this._onCompleteCallback&&this._onCompleteCallback(this._object);for(var g=0,_=this._chainedTweens.length;g<_;g++)this._chainedTweens[g].start(this._startTime+this._duration,!1);return this._isPlaying=!1,!1}return!0},n.prototype._updateProperties=function(e,t,i,s){for(var a in i)if(t[a]!==void 0){var o=t[a]||0,c=i[a],u=Array.isArray(e[a]),f=Array.isArray(c),p=!u&&f;p?e[a]=this._interpolationFunction(c,s):typeof c=="object"&&c?this._updateProperties(e[a],o,c,s):(c=this._handleRelativeValue(o,c),typeof c=="number"&&(e[a]=o+(c-o)*s))}},n.prototype._handleRelativeValue=function(e,t){return typeof t!="string"?t:t.charAt(0)==="+"||t.charAt(0)==="-"?e+parseFloat(t):parseFloat(t)},n.prototype._swapEndStartRepeatValues=function(e){var t=this._valuesStartRepeat[e],i=this._valuesEnd[e];typeof i=="string"?this._valuesStartRepeat[e]=this._valuesStartRepeat[e]+parseFloat(i):this._valuesStartRepeat[e]=this._valuesEnd[e],this._valuesEnd[e]=t},n}(),Ca="23.1.3",Ia=ls.nextId,de=Ui,Ra=de.getAll.bind(de),Pa=de.removeAll.bind(de),Da=de.add.bind(de),La=de.remove.bind(de),Ea=de.update.bind(de),ye={Easing:it,Group:Sr,Interpolation:ke,now:$e,Sequence:ls,nextId:Ia,Tween:It,VERSION:Ca,getAll:Ra,removeAll:Pa,add:Da,remove:La,update:Ea},vt=typeof globalThis<"u"?globalThis:typeof window<"u"?window:typeof global<"u"?global:typeof self<"u"?self:{};function Fa(n){return n&&n.__esModule&&Object.prototype.hasOwnProperty.call(n,"default")?n.default:n}var Mr={exports:{}};(function(n){var e=Object.prototype.hasOwnProperty,t="~";function i(){}Object.create&&(i.prototype=Object.create(null),new i().__proto__||(t=!1));function s(u,f,p){this.fn=u,this.context=f,this.once=p||!1}function a(u,f,p,r,l){if(typeof p!="function")throw new TypeError("The listener must be a function");var h=new s(p,r||u,l),g=t?t+f:f;return u._events[g]?u._events[g].fn?u._events[g]=[u._events[g],h]:u._events[g].push(h):(u._events[g]=h,u._eventsCount++),u}function o(u,f){--u._eventsCount===0?u._events=new i:delete u._events[f]}function c(){this._events=new i,this._eventsCount=0}c.prototype.eventNames=function(){var f=[],p,r;if(this._eventsCount===0)return f;for(r in p=this._events)e.call(p,r)&&f.push(t?r.slice(1):r);return Object.getOwnPropertySymbols?f.concat(Object.getOwnPropertySymbols(p)):f},c.prototype.listeners=function(f){var p=t?t+f:f,r=this._events[p];if(!r)return[];if(r.fn)return[r.fn];for(var l=0,h=r.length,g=new Array(h);l<h;l++)g[l]=r[l].fn;return g},c.prototype.listenerCount=function(f){var p=t?t+f:f,r=this._events[p];return r?r.fn?1:r.length:0},c.prototype.emit=function(f,p,r,l,h,g){var _=t?t+f:f;if(!this._events[_])return!1;var m=this._events[_],v=arguments.length,y,x;if(m.fn){switch(m.once&&this.removeListener(f,m.fn,void 0,!0),v){case 1:return m.fn.call(m.context),!0;case 2:return m.fn.call(m.context,p),!0;case 3:return m.fn.call(m.context,p,r),!0;case 4:return m.fn.call(m.context,p,r,l),!0;case 5:return m.fn.call(m.context,p,r,l,h),!0;case 6:return m.fn.call(m.context,p,r,l,h,g),!0}for(x=1,y=new Array(v-1);x<v;x++)y[x-1]=arguments[x];m.fn.apply(m.context,y)}else{var w=m.length,b;for(x=0;x<w;x++)switch(m[x].once&&this.removeListener(f,m[x].fn,void 0,!0),v){case 1:m[x].fn.call(m[x].context);break;case 2:m[x].fn.call(m[x].context,p);break;case 3:m[x].fn.call(m[x].context,p,r);break;case 4:m[x].fn.call(m[x].context,p,r,l);break;default:if(!y)for(b=1,y=new Array(v-1);b<v;b++)y[b-1]=arguments[b];m[x].fn.apply(m[x].context,y)}}return!0},c.prototype.on=function(f,p,r){return a(this,f,p,r,!1)},c.prototype.once=function(f,p,r){return a(this,f,p,r,!0)},c.prototype.removeListener=function(f,p,r,l){var h=t?t+f:f;if(!this._events[h])return this;if(!p)return o(this,h),this;var g=this._events[h];if(g.fn)g.fn===p&&(!l||g.once)&&(!r||g.context===r)&&o(this,h);else{for(var _=0,m=[],v=g.length;_<v;_++)(g[_].fn!==p||l&&!g[_].once||r&&g[_].context!==r)&&m.push(g[_]);m.length?this._events[h]=m.length===1?m[0]:m:o(this,h)}return this},c.prototype.removeAllListeners=function(f){var p;return f?(p=t?t+f:f,this._events[p]&&o(this,p)):(this._events=new i,this._eventsCount=0),this},c.prototype.off=c.prototype.removeListener,c.prototype.addListener=c.prototype.on,c.prefixed=t,c.EventEmitter=c,n.exports=c})(Mr);var Ba=Mr.exports;const ct=Fa(Ba);var Rt=function(){var n=0,e=document.createElement("div");e.style.cssText="position:fixed;top:0;left:0;cursor:pointer;opacity:0.9;z-index:10000",e.addEventListener("click",function(r){r.preventDefault(),i(++n%e.children.length)},!1);function t(r){return e.appendChild(r.dom),r}function i(r){for(var l=0;l<e.children.length;l++)e.children[l].style.display=l===r?"block":"none";n=r}var s=(performance||Date).now(),a=s,o=0,c=t(new Rt.Panel("FPS","#0ff","#002")),u=t(new Rt.Panel("MS","#0f0","#020"));if(self.performance&&self.performance.memory)var f=t(new Rt.Panel("MB","#f08","#201"));i(0);var p=0;return{REVISION:16,dom:e,fps:function(){return p&&parseInt(p.toFixed(0))},addPanel:t,showPanel:i,begin:function(){s=(performance||Date).now()},end:function(){o++;var r=(performance||Date).now();if(u.update(r-s,200),r>=a+1e3&&(p=o*1e3/(r-a),c.update(p,100),a=r,o=0,f)){var l=performance.memory;f.update(l.usedJSHeapSize/1048576,l.jsHeapSizeLimit/1048576)}return r},update:function(){s=this.end()},domElement:e,setMode:i}};Rt.Panel=function(n,e,t){var i=1/0,s=0,a=Math.round,o=a(window.devicePixelRatio||1),c=80*o,u=48*o,f=3*o,p=2*o,r=3*o,l=15*o,h=74*o,g=30*o,_=document.createElement("canvas");_.width=c,_.height=u,_.style.cssText="width:80px;height:48px";var m=_.getContext("2d");return m.font="bold "+9*o+"px Helvetica,Arial,sans-serif",m.textBaseline="top",m.fillStyle=t,m.fillRect(0,0,c,u),m.fillStyle=e,m.fillText(n,f,p),m.fillRect(r,l,h,g),m.fillStyle=t,m.globalAlpha=.9,m.fillRect(r,l,h,g),{dom:_,update:function(v,y){i=Math.min(i,v),s=Math.max(s,v),m.fillStyle=t,m.globalAlpha=1,m.fillRect(0,0,c,l),m.fillStyle=e,m.fillText(a(v)+" "+n+" ("+a(i)+"-"+a(s)+")",f,p),m.drawImage(_,r+o,l,h-o,g,r,l,h-o,g),m.fillRect(r+h-o,l,o,g),m.fillStyle=t,m.globalAlpha=.9,m.fillRect(r+h-o,l,o,a((1-v/y)*g))}}};function ka(n,e){const t=URL.createObjectURL(n),i=document.createElement("a");i.href=t,i.download=e,document.body.appendChild(i),i.click(),document.body.removeChild(i),URL.revokeObjectURL(t)}function Cr(n){return n.length===0?0:n.reduce((t,i)=>t+i,0)/n.length}function Hi(n,e){const t=new Blob([n],{type:e});return URL.createObjectURL(t)}function Ir(){return/Mac|iPod|iPhone|iPad/.test(navigator==null?void 0:navigator.platform)||/Mac OS|iOS/.test(navigator==null?void 0:navigator.userAgent)}function Ni(n){let e=document.createElement("canvas");const t=e.getContext("2d");return e.width=n.width,e.height=n.height,t?(t.drawImage(n,0,0),e.toDataURL("image/png",.75)):void 0}function Oa(n,e=43){const t=n*Math.PI/180;return e/(2*Math.tan(t/2))}var Rr={};/*!
3687
+ ${t.name}`)}break}}}}else a.texture_lod=0}};J=new WeakMap,ve=new WeakMap,ai=new WeakMap,Ie=new WeakMap,nt=new WeakMap,li=new WeakMap,_e=new WeakMap,L(V,"debugDrawLine"),L(V,"corner0",new d.Vector3),L(V,"corner1",new d.Vector3),L(V,"corner2",new d.Vector3),L(V,"corner3",new d.Vector3),L(V,"_tempPtInside",new d.Vector3),L(V,"skinnedMeshBoundsFrameOffsetCounter",0),L(V,"$skinnedMeshBoundsOffset",Symbol("gltf-progressive-skinnedMeshBoundsOffset"));let lt=V;class Aa{constructor(){L(this,"frames",0);L(this,"lastLodLevel_Mesh",-1);L(this,"lastLodLevel_Texture",-1);L(this,"lastScreenCoverage",0);L(this,"lastScreenspaceVolume",new d.Vector3);L(this,"lastCentrality",0)}}const Hs=Symbol("NEEDLE_mesh_lod"),Vt=Symbol("NEEDLE_texture_lod");let gt=null;function Ar(){const n=Ta();n&&(n.mapURLs(function(e){return Ns(),e}),Ns(),gt==null||gt.disconnect(),gt=new MutationObserver(e=>{e.forEach(t=>{t.addedNodes.forEach(i=>{i instanceof HTMLElement&&i.tagName.toLowerCase()==="model-viewer"&&Tr(i)})})}),gt.observe(document,{childList:!0,subtree:!0}))}function Ta(){if(typeof customElements>"u")return null;const n=customElements.get("model-viewer");return n||(customElements.whenDefined("model-viewer").then(()=>{console.debug("[gltf-progressive] model-viewer defined"),Ar()}),null)}function Ns(){if(typeof document>"u")return;document.querySelectorAll("model-viewer").forEach(e=>{Tr(e)})}const Ws=new WeakSet;let Sa=0;function Tr(n){if(!n||Ws.has(n))return null;Ws.add(n),console.debug("[gltf-progressive] found new model-viewer..."+ ++Sa+`
3688
+ `,n.getAttribute("src"));let e=null,t=null,i=null;for(let s=n;s!=null;s=Object.getPrototypeOf(s)){const a=Object.getOwnPropertySymbols(s),o=a.find(f=>f.toString()=="Symbol(renderer)"),c=a.find(f=>f.toString()=="Symbol(scene)"),u=a.find(f=>f.toString()=="Symbol(needsRender)");!e&&o!=null&&(e=n[o].threeRenderer),!t&&c!=null&&(t=n[c]),!i&&u!=null&&(i=n[u])}if(e&&t){let s=function(){if(i){let o=0,c=setInterval(()=>{if(o++>5){clearInterval(c);return}i==null||i.call(n)},300)}};console.debug("[gltf-progressive] setup model-viewer");const a=lt.get(e,{engine:"model-viewer"});return lt.addPlugin(new Ma),a.enable(),a.addEventListener("changed",()=>{i==null||i.call(n)}),n.addEventListener("model-visibility",o=>{o.detail.visible&&(i==null||i.call(n))}),n.addEventListener("load",()=>{s()}),()=>{a.disable()}}return null}class Ma{constructor(){L(this,"_didWarnAboutMissingUrl",!1)}onBeforeUpdateLOD(e,t,i,s){this.tryParseMeshLOD(t,s),this.tryParseTextureLOD(t,s)}getUrl(e){if(!e)return null;let t=e.getAttribute("src");return t||(t=e.src),t||(this._didWarnAboutMissingUrl||console.warn("No url found in modelviewer",e),this._didWarnAboutMissingUrl=!0),t}tryGetCurrentGLTF(e){return e._currentGLTF}tryGetCurrentModelViewer(e){return e.element}tryParseTextureLOD(e,t){if(t[Vt]==!0)return;t[Vt]=!0;const i=this.tryGetCurrentGLTF(e),s=this.tryGetCurrentModelViewer(e),a=this.getUrl(s);if(a&&i&&t.material){let o=function(u){var p,r,l;if(u[Vt]==!0)return;u[Vt]=!0,u.userData&&(u.userData.LOD=-1);const f=Object.keys(u);for(let h=0;h<f.length;h++){const g=f[h],_=u[g];if((_==null?void 0:_.isTexture)===!0){const m=(r=(p=_.userData)==null?void 0:p.associations)==null?void 0:r.textures;if(m==null)continue;const v=i.parser.json.textures[m];if(!v){console.warn("Texture data not found for texture index "+m);continue}if((l=v==null?void 0:v.extensions)!=null&&l[ge]){const y=v.extensions[ge];y&&a&&he.registerTexture(a,_,y.lods.length,m,y)}}}};const c=t.material;if(Array.isArray(c))for(const u of c)o(u);else o(c)}}tryParseMeshLOD(e,t){var o,c;if(t[Hs]==!0)return;t[Hs]=!0;const i=this.tryGetCurrentModelViewer(e),s=this.getUrl(i);if(!s)return;const a=(c=(o=t.userData)==null?void 0:o.gltfExtensions)==null?void 0:c[ge];if(a&&s){const u=t.uuid;he.registerMesh(s,u,t,0,a.lods.length,a)}}}function Sr(...n){let e,t,i,s;switch(n.length){case 2:[i,t]=n,s={};break;case 3:[i,t,s]=n;break;case 4:[e,t,i,s]=n;break;default:throw new Error("Invalid arguments")}as(),_r(i),xr(i,{progressive:!0,...s==null?void 0:s.hints}),i.register(o=>new he(o));const a=lt.get(t);return(s==null?void 0:s.enableLODsManager)!==!1&&a.enable(),a}Ar();if(!ha){const n={gltfProgressive:{useNeedleProgressive:Sr,LODsManager:lt,configureLoader:xr,getRaycastMesh:Lt,useRaycastMeshes:da}};if(!globalThis.Needle)globalThis.Needle=n;else for(const e in n)globalThis.Needle[e]=n[e]}var st=Object.freeze({Linear:Object.freeze({None:function(n){return n},In:function(n){return n},Out:function(n){return n},InOut:function(n){return n}}),Quadratic:Object.freeze({In:function(n){return n*n},Out:function(n){return n*(2-n)},InOut:function(n){return(n*=2)<1?.5*n*n:-.5*(--n*(n-2)-1)}}),Cubic:Object.freeze({In:function(n){return n*n*n},Out:function(n){return--n*n*n+1},InOut:function(n){return(n*=2)<1?.5*n*n*n:.5*((n-=2)*n*n+2)}}),Quartic:Object.freeze({In:function(n){return n*n*n*n},Out:function(n){return 1- --n*n*n*n},InOut:function(n){return(n*=2)<1?.5*n*n*n*n:-.5*((n-=2)*n*n*n-2)}}),Quintic:Object.freeze({In:function(n){return n*n*n*n*n},Out:function(n){return--n*n*n*n*n+1},InOut:function(n){return(n*=2)<1?.5*n*n*n*n*n:.5*((n-=2)*n*n*n*n+2)}}),Sinusoidal:Object.freeze({In:function(n){return 1-Math.sin((1-n)*Math.PI/2)},Out:function(n){return Math.sin(n*Math.PI/2)},InOut:function(n){return .5*(1-Math.sin(Math.PI*(.5-n)))}}),Exponential:Object.freeze({In:function(n){return n===0?0:Math.pow(1024,n-1)},Out:function(n){return n===1?1:1-Math.pow(2,-10*n)},InOut:function(n){return n===0?0:n===1?1:(n*=2)<1?.5*Math.pow(1024,n-1):.5*(-Math.pow(2,-10*(n-1))+2)}}),Circular:Object.freeze({In:function(n){return 1-Math.sqrt(1-n*n)},Out:function(n){return Math.sqrt(1- --n*n)},InOut:function(n){return(n*=2)<1?-.5*(Math.sqrt(1-n*n)-1):.5*(Math.sqrt(1-(n-=2)*n)+1)}}),Elastic:Object.freeze({In:function(n){return n===0?0:n===1?1:-Math.pow(2,10*(n-1))*Math.sin((n-1.1)*5*Math.PI)},Out:function(n){return n===0?0:n===1?1:Math.pow(2,-10*n)*Math.sin((n-.1)*5*Math.PI)+1},InOut:function(n){return n===0?0:n===1?1:(n*=2,n<1?-.5*Math.pow(2,10*(n-1))*Math.sin((n-1.1)*5*Math.PI):.5*Math.pow(2,-10*(n-1))*Math.sin((n-1.1)*5*Math.PI)+1)}}),Back:Object.freeze({In:function(n){var e=1.70158;return n===1?1:n*n*((e+1)*n-e)},Out:function(n){var e=1.70158;return n===0?0:--n*n*((e+1)*n+e)+1},InOut:function(n){var e=2.5949095;return(n*=2)<1?.5*(n*n*((e+1)*n-e)):.5*((n-=2)*n*((e+1)*n+e)+2)}}),Bounce:Object.freeze({In:function(n){return 1-st.Bounce.Out(1-n)},Out:function(n){return n<1/2.75?7.5625*n*n:n<2/2.75?7.5625*(n-=1.5/2.75)*n+.75:n<2.5/2.75?7.5625*(n-=2.25/2.75)*n+.9375:7.5625*(n-=2.625/2.75)*n+.984375},InOut:function(n){return n<.5?st.Bounce.In(n*2)*.5:st.Bounce.Out(n*2-1)*.5+.5}}),generatePow:function(n){return n===void 0&&(n=4),n=n<Number.EPSILON?Number.EPSILON:n,n=n>1e4?1e4:n,{In:function(e){return Math.pow(e,n)},Out:function(e){return 1-Math.pow(1-e,n)},InOut:function(e){return e<.5?Math.pow(e*2,n)/2:(1-Math.pow(2-e*2,n))/2+.5}}}}),et=function(){return performance.now()},Mr=function(){function n(){this._tweens={},this._tweensAddedDuringUpdate={}}return n.prototype.getAll=function(){var e=this;return Object.keys(this._tweens).map(function(t){return e._tweens[t]})},n.prototype.removeAll=function(){this._tweens={}},n.prototype.add=function(e){this._tweens[e.getId()]=e,this._tweensAddedDuringUpdate[e.getId()]=e},n.prototype.remove=function(e){delete this._tweens[e.getId()],delete this._tweensAddedDuringUpdate[e.getId()]},n.prototype.update=function(e,t){e===void 0&&(e=et()),t===void 0&&(t=!1);var i=Object.keys(this._tweens);if(i.length===0)return!1;for(;i.length>0;){this._tweensAddedDuringUpdate={};for(var s=0;s<i.length;s++){var a=this._tweens[i[s]],o=!t;a&&a.update(e,o)===!1&&!t&&delete this._tweens[i[s]]}i=Object.keys(this._tweensAddedDuringUpdate)}return!0},n}(),ke={Linear:function(n,e){var t=n.length-1,i=t*e,s=Math.floor(i),a=ke.Utils.Linear;return e<0?a(n[0],n[1],i):e>1?a(n[t],n[t-1],t-i):a(n[s],n[s+1>t?t:s+1],i-s)},Bezier:function(n,e){for(var t=0,i=n.length-1,s=Math.pow,a=ke.Utils.Bernstein,o=0;o<=i;o++)t+=s(1-e,i-o)*s(e,o)*n[o]*a(i,o);return t},CatmullRom:function(n,e){var t=n.length-1,i=t*e,s=Math.floor(i),a=ke.Utils.CatmullRom;return n[0]===n[t]?(e<0&&(s=Math.floor(i=t*(1+e))),a(n[(s-1+t)%t],n[s],n[(s+1)%t],n[(s+2)%t],i-s)):e<0?n[0]-(a(n[0],n[0],n[1],n[1],-i)-n[0]):e>1?n[t]-(a(n[t],n[t],n[t-1],n[t-1],i-t)-n[t]):a(n[s?s-1:0],n[s],n[t<s+1?t:s+1],n[t<s+2?t:s+2],i-s)},Utils:{Linear:function(n,e,t){return(e-n)*t+n},Bernstein:function(n,e){var t=ke.Utils.Factorial;return t(n)/t(e)/t(n-e)},Factorial:function(){var n=[1];return function(e){var t=1;if(n[e])return n[e];for(var i=e;i>1;i--)t*=i;return n[e]=t,t}}(),CatmullRom:function(n,e,t,i,s){var a=(t-n)*.5,o=(i-e)*.5,c=s*s,u=s*c;return(2*e-2*t+a+o)*u+(-3*e+3*t-2*a-o)*c+a*s+e}}},cs=function(){function n(){}return n.nextId=function(){return n._nextId++},n._nextId=0,n}(),Hi=new Mr,It=function(){function n(e,t){t===void 0&&(t=Hi),this._object=e,this._group=t,this._isPaused=!1,this._pauseStart=0,this._valuesStart={},this._valuesEnd={},this._valuesStartRepeat={},this._duration=1e3,this._isDynamic=!1,this._initialRepeat=0,this._repeat=0,this._yoyo=!1,this._isPlaying=!1,this._reversed=!1,this._delayTime=0,this._startTime=0,this._easingFunction=st.Linear.None,this._interpolationFunction=ke.Linear,this._chainedTweens=[],this._onStartCallbackFired=!1,this._onEveryStartCallbackFired=!1,this._id=cs.nextId(),this._isChainStopped=!1,this._propertiesAreSetUp=!1,this._goToEnd=!1}return n.prototype.getId=function(){return this._id},n.prototype.isPlaying=function(){return this._isPlaying},n.prototype.isPaused=function(){return this._isPaused},n.prototype.getDuration=function(){return this._duration},n.prototype.to=function(e,t){if(t===void 0&&(t=1e3),this._isPlaying)throw new Error("Can not call Tween.to() while Tween is already started or paused. Stop the Tween first.");return this._valuesEnd=e,this._propertiesAreSetUp=!1,this._duration=t<0?0:t,this},n.prototype.duration=function(e){return e===void 0&&(e=1e3),this._duration=e<0?0:e,this},n.prototype.dynamic=function(e){return e===void 0&&(e=!1),this._isDynamic=e,this},n.prototype.start=function(e,t){if(e===void 0&&(e=et()),t===void 0&&(t=!1),this._isPlaying)return this;if(this._group&&this._group.add(this),this._repeat=this._initialRepeat,this._reversed){this._reversed=!1;for(var i in this._valuesStartRepeat)this._swapEndStartRepeatValues(i),this._valuesStart[i]=this._valuesStartRepeat[i]}if(this._isPlaying=!0,this._isPaused=!1,this._onStartCallbackFired=!1,this._onEveryStartCallbackFired=!1,this._isChainStopped=!1,this._startTime=e,this._startTime+=this._delayTime,!this._propertiesAreSetUp||t){if(this._propertiesAreSetUp=!0,!this._isDynamic){var s={};for(var a in this._valuesEnd)s[a]=this._valuesEnd[a];this._valuesEnd=s}this._setupProperties(this._object,this._valuesStart,this._valuesEnd,this._valuesStartRepeat,t)}return this},n.prototype.startFromCurrentValues=function(e){return this.start(e,!0)},n.prototype._setupProperties=function(e,t,i,s,a){for(var o in i){var c=e[o],u=Array.isArray(c),f=u?"array":typeof c,p=!u&&Array.isArray(i[o]);if(!(f==="undefined"||f==="function")){if(p){var r=i[o];if(r.length===0)continue;for(var l=[c],h=0,g=r.length;h<g;h+=1){var _=this._handleRelativeValue(c,r[h]);if(isNaN(_)){p=!1,console.warn("Found invalid interpolation list. Skipping.");break}l.push(_)}p&&(i[o]=l)}if((f==="object"||u)&&c&&!p){t[o]=u?[]:{};var m=c;for(var v in m)t[o][v]=m[v];s[o]=u?[]:{};var r=i[o];if(!this._isDynamic){var y={};for(var v in r)y[v]=r[v];i[o]=r=y}this._setupProperties(m,t[o],r,s[o],a)}else(typeof t[o]>"u"||a)&&(t[o]=c),u||(t[o]*=1),p?s[o]=i[o].slice().reverse():s[o]=t[o]||0}}},n.prototype.stop=function(){return this._isChainStopped||(this._isChainStopped=!0,this.stopChainedTweens()),this._isPlaying?(this._group&&this._group.remove(this),this._isPlaying=!1,this._isPaused=!1,this._onStopCallback&&this._onStopCallback(this._object),this):this},n.prototype.end=function(){return this._goToEnd=!0,this.update(1/0),this},n.prototype.pause=function(e){return e===void 0&&(e=et()),this._isPaused||!this._isPlaying?this:(this._isPaused=!0,this._pauseStart=e,this._group&&this._group.remove(this),this)},n.prototype.resume=function(e){return e===void 0&&(e=et()),!this._isPaused||!this._isPlaying?this:(this._isPaused=!1,this._startTime+=e-this._pauseStart,this._pauseStart=0,this._group&&this._group.add(this),this)},n.prototype.stopChainedTweens=function(){for(var e=0,t=this._chainedTweens.length;e<t;e++)this._chainedTweens[e].stop();return this},n.prototype.group=function(e){return e===void 0&&(e=Hi),this._group=e,this},n.prototype.delay=function(e){return e===void 0&&(e=0),this._delayTime=e,this},n.prototype.repeat=function(e){return e===void 0&&(e=0),this._initialRepeat=e,this._repeat=e,this},n.prototype.repeatDelay=function(e){return this._repeatDelayTime=e,this},n.prototype.yoyo=function(e){return e===void 0&&(e=!1),this._yoyo=e,this},n.prototype.easing=function(e){return e===void 0&&(e=st.Linear.None),this._easingFunction=e,this},n.prototype.interpolation=function(e){return e===void 0&&(e=ke.Linear),this._interpolationFunction=e,this},n.prototype.chain=function(){for(var e=[],t=0;t<arguments.length;t++)e[t]=arguments[t];return this._chainedTweens=e,this},n.prototype.onStart=function(e){return this._onStartCallback=e,this},n.prototype.onEveryStart=function(e){return this._onEveryStartCallback=e,this},n.prototype.onUpdate=function(e){return this._onUpdateCallback=e,this},n.prototype.onRepeat=function(e){return this._onRepeatCallback=e,this},n.prototype.onComplete=function(e){return this._onCompleteCallback=e,this},n.prototype.onStop=function(e){return this._onStopCallback=e,this},n.prototype.update=function(e,t){var i=this,s;if(e===void 0&&(e=et()),t===void 0&&(t=!0),this._isPaused)return!0;var a,o=this._startTime+this._duration;if(!this._goToEnd&&!this._isPlaying){if(e>o)return!1;t&&this.start(e,!0)}if(this._goToEnd=!1,e<this._startTime)return!0;this._onStartCallbackFired===!1&&(this._onStartCallback&&this._onStartCallback(this._object),this._onStartCallbackFired=!0),this._onEveryStartCallbackFired===!1&&(this._onEveryStartCallback&&this._onEveryStartCallback(this._object),this._onEveryStartCallbackFired=!0);var c=e-this._startTime,u=this._duration+((s=this._repeatDelayTime)!==null&&s!==void 0?s:this._delayTime),f=this._duration+this._repeat*u,p=function(){if(i._duration===0||c>f)return 1;var m=Math.trunc(c/u),v=c-m*u,y=Math.min(v/i._duration,1);return y===0&&c===i._duration?1:y},r=p(),l=this._easingFunction(r);if(this._updateProperties(this._object,this._valuesStart,this._valuesEnd,l),this._onUpdateCallback&&this._onUpdateCallback(this._object,r),this._duration===0||c>=this._duration)if(this._repeat>0){var h=Math.min(Math.trunc((c-this._duration)/u)+1,this._repeat);isFinite(this._repeat)&&(this._repeat-=h);for(a in this._valuesStartRepeat)!this._yoyo&&typeof this._valuesEnd[a]=="string"&&(this._valuesStartRepeat[a]=this._valuesStartRepeat[a]+parseFloat(this._valuesEnd[a])),this._yoyo&&this._swapEndStartRepeatValues(a),this._valuesStart[a]=this._valuesStartRepeat[a];return this._yoyo&&(this._reversed=!this._reversed),this._startTime+=u*h,this._onRepeatCallback&&this._onRepeatCallback(this._object),this._onEveryStartCallbackFired=!1,!0}else{this._onCompleteCallback&&this._onCompleteCallback(this._object);for(var g=0,_=this._chainedTweens.length;g<_;g++)this._chainedTweens[g].start(this._startTime+this._duration,!1);return this._isPlaying=!1,!1}return!0},n.prototype._updateProperties=function(e,t,i,s){for(var a in i)if(t[a]!==void 0){var o=t[a]||0,c=i[a],u=Array.isArray(e[a]),f=Array.isArray(c),p=!u&&f;p?e[a]=this._interpolationFunction(c,s):typeof c=="object"&&c?this._updateProperties(e[a],o,c,s):(c=this._handleRelativeValue(o,c),typeof c=="number"&&(e[a]=o+(c-o)*s))}},n.prototype._handleRelativeValue=function(e,t){return typeof t!="string"?t:t.charAt(0)==="+"||t.charAt(0)==="-"?e+parseFloat(t):parseFloat(t)},n.prototype._swapEndStartRepeatValues=function(e){var t=this._valuesStartRepeat[e],i=this._valuesEnd[e];typeof i=="string"?this._valuesStartRepeat[e]=this._valuesStartRepeat[e]+parseFloat(i):this._valuesStartRepeat[e]=this._valuesEnd[e],this._valuesEnd[e]=t},n}(),Ca="23.1.3",Ia=cs.nextId,de=Hi,Ra=de.getAll.bind(de),Pa=de.removeAll.bind(de),Da=de.add.bind(de),La=de.remove.bind(de),Ea=de.update.bind(de),ye={Easing:st,Group:Mr,Interpolation:ke,now:et,Sequence:cs,nextId:Ia,Tween:It,VERSION:Ca,getAll:Ra,removeAll:Pa,add:Da,remove:La,update:Ea},vt=typeof globalThis<"u"?globalThis:typeof window<"u"?window:typeof global<"u"?global:typeof self<"u"?self:{};function Fa(n){return n&&n.__esModule&&Object.prototype.hasOwnProperty.call(n,"default")?n.default:n}var Cr={exports:{}};(function(n){var e=Object.prototype.hasOwnProperty,t="~";function i(){}Object.create&&(i.prototype=Object.create(null),new i().__proto__||(t=!1));function s(u,f,p){this.fn=u,this.context=f,this.once=p||!1}function a(u,f,p,r,l){if(typeof p!="function")throw new TypeError("The listener must be a function");var h=new s(p,r||u,l),g=t?t+f:f;return u._events[g]?u._events[g].fn?u._events[g]=[u._events[g],h]:u._events[g].push(h):(u._events[g]=h,u._eventsCount++),u}function o(u,f){--u._eventsCount===0?u._events=new i:delete u._events[f]}function c(){this._events=new i,this._eventsCount=0}c.prototype.eventNames=function(){var f=[],p,r;if(this._eventsCount===0)return f;for(r in p=this._events)e.call(p,r)&&f.push(t?r.slice(1):r);return Object.getOwnPropertySymbols?f.concat(Object.getOwnPropertySymbols(p)):f},c.prototype.listeners=function(f){var p=t?t+f:f,r=this._events[p];if(!r)return[];if(r.fn)return[r.fn];for(var l=0,h=r.length,g=new Array(h);l<h;l++)g[l]=r[l].fn;return g},c.prototype.listenerCount=function(f){var p=t?t+f:f,r=this._events[p];return r?r.fn?1:r.length:0},c.prototype.emit=function(f,p,r,l,h,g){var _=t?t+f:f;if(!this._events[_])return!1;var m=this._events[_],v=arguments.length,y,x;if(m.fn){switch(m.once&&this.removeListener(f,m.fn,void 0,!0),v){case 1:return m.fn.call(m.context),!0;case 2:return m.fn.call(m.context,p),!0;case 3:return m.fn.call(m.context,p,r),!0;case 4:return m.fn.call(m.context,p,r,l),!0;case 5:return m.fn.call(m.context,p,r,l,h),!0;case 6:return m.fn.call(m.context,p,r,l,h,g),!0}for(x=1,y=new Array(v-1);x<v;x++)y[x-1]=arguments[x];m.fn.apply(m.context,y)}else{var w=m.length,b;for(x=0;x<w;x++)switch(m[x].once&&this.removeListener(f,m[x].fn,void 0,!0),v){case 1:m[x].fn.call(m[x].context);break;case 2:m[x].fn.call(m[x].context,p);break;case 3:m[x].fn.call(m[x].context,p,r);break;case 4:m[x].fn.call(m[x].context,p,r,l);break;default:if(!y)for(b=1,y=new Array(v-1);b<v;b++)y[b-1]=arguments[b];m[x].fn.apply(m[x].context,y)}}return!0},c.prototype.on=function(f,p,r){return a(this,f,p,r,!1)},c.prototype.once=function(f,p,r){return a(this,f,p,r,!0)},c.prototype.removeListener=function(f,p,r,l){var h=t?t+f:f;if(!this._events[h])return this;if(!p)return o(this,h),this;var g=this._events[h];if(g.fn)g.fn===p&&(!l||g.once)&&(!r||g.context===r)&&o(this,h);else{for(var _=0,m=[],v=g.length;_<v;_++)(g[_].fn!==p||l&&!g[_].once||r&&g[_].context!==r)&&m.push(g[_]);m.length?this._events[h]=m.length===1?m[0]:m:o(this,h)}return this},c.prototype.removeAllListeners=function(f){var p;return f?(p=t?t+f:f,this._events[p]&&o(this,p)):(this._events=new i,this._eventsCount=0),this},c.prototype.off=c.prototype.removeListener,c.prototype.addListener=c.prototype.on,c.prefixed=t,c.EventEmitter=c,n.exports=c})(Cr);var Ba=Cr.exports;const ct=Fa(Ba);var Rt=function(){var n=0,e=document.createElement("div");e.style.cssText="position:fixed;top:0;left:0;cursor:pointer;opacity:0.9;z-index:10000",e.addEventListener("click",function(r){r.preventDefault(),i(++n%e.children.length)},!1);function t(r){return e.appendChild(r.dom),r}function i(r){for(var l=0;l<e.children.length;l++)e.children[l].style.display=l===r?"block":"none";n=r}var s=(performance||Date).now(),a=s,o=0,c=t(new Rt.Panel("FPS","#0ff","#002")),u=t(new Rt.Panel("MS","#0f0","#020"));if(self.performance&&self.performance.memory)var f=t(new Rt.Panel("MB","#f08","#201"));i(0);var p=0;return{REVISION:16,dom:e,fps:function(){return p&&parseInt(p.toFixed(0))},addPanel:t,showPanel:i,begin:function(){s=(performance||Date).now()},end:function(){o++;var r=(performance||Date).now();if(u.update(r-s,200),r>=a+1e3&&(p=o*1e3/(r-a),c.update(p,100),a=r,o=0,f)){var l=performance.memory;f.update(l.usedJSHeapSize/1048576,l.jsHeapSizeLimit/1048576)}return r},update:function(){s=this.end()},domElement:e,setMode:i}};Rt.Panel=function(n,e,t){var i=1/0,s=0,a=Math.round,o=a(window.devicePixelRatio||1),c=80*o,u=48*o,f=3*o,p=2*o,r=3*o,l=15*o,h=74*o,g=30*o,_=document.createElement("canvas");_.width=c,_.height=u,_.style.cssText="width:80px;height:48px";var m=_.getContext("2d");return m.font="bold "+9*o+"px Helvetica,Arial,sans-serif",m.textBaseline="top",m.fillStyle=t,m.fillRect(0,0,c,u),m.fillStyle=e,m.fillText(n,f,p),m.fillRect(r,l,h,g),m.fillStyle=t,m.globalAlpha=.9,m.fillRect(r,l,h,g),{dom:_,update:function(v,y){i=Math.min(i,v),s=Math.max(s,v),m.fillStyle=t,m.globalAlpha=1,m.fillRect(0,0,c,l),m.fillStyle=e,m.fillText(a(v)+" "+n+" ("+a(i)+"-"+a(s)+")",f,p),m.drawImage(_,r+o,l,h-o,g,r,l,h-o,g),m.fillRect(r+h-o,l,o,g),m.fillStyle=t,m.globalAlpha=.9,m.fillRect(r+h-o,l,o,a((1-v/y)*g))}}};function ka(n,e){const t=URL.createObjectURL(n),i=document.createElement("a");i.href=t,i.download=e,document.body.appendChild(i),i.click(),document.body.removeChild(i),URL.revokeObjectURL(t)}function Ir(n){return n.length===0?0:n.reduce((t,i)=>t+i,0)/n.length}function Ni(n,e){const t=new Blob([n],{type:e});return URL.createObjectURL(t)}function Rr(){return/Mac|iPod|iPhone|iPad/.test(navigator==null?void 0:navigator.platform)||/Mac OS|iOS/.test(navigator==null?void 0:navigator.userAgent)}function Wi(n){let e=document.createElement("canvas");const t=e.getContext("2d");return e.width=n.width,e.height=n.height,t?(t.drawImage(n,0,0),e.toDataURL("image/png",.75)):void 0}function Oa(n,e=43){const t=n*Math.PI/180;return e/(2*Math.tan(t/2))}var Pr={};/*!
3689
3689
  * howler.js v2.2.4
3690
3690
  * howlerjs.com
3691
3691
  *
@@ -3703,7 +3703,7 @@ ${t.name}`)}break}}}}else a.texture_lod=0}};J=new WeakMap,ve=new WeakMap,ai=new
3703
3703
  * goldfirestudios.com
3704
3704
  *
3705
3705
  * MIT License
3706
- */(function(){HowlerGlobal.prototype._pos=[0,0,0],HowlerGlobal.prototype._orientation=[0,0,-1,0,1,0],HowlerGlobal.prototype.stereo=function(t){var i=this;if(!i.ctx||!i.ctx.listener)return i;for(var s=i._howls.length-1;s>=0;s--)i._howls[s].stereo(t);return i},HowlerGlobal.prototype.pos=function(t,i,s){var a=this;if(!a.ctx||!a.ctx.listener)return a;if(i=typeof i!="number"?a._pos[1]:i,s=typeof s!="number"?a._pos[2]:s,typeof t=="number")a._pos=[t,i,s],typeof a.ctx.listener.positionX<"u"?(a.ctx.listener.positionX.setTargetAtTime(a._pos[0],Howler.ctx.currentTime,.1),a.ctx.listener.positionY.setTargetAtTime(a._pos[1],Howler.ctx.currentTime,.1),a.ctx.listener.positionZ.setTargetAtTime(a._pos[2],Howler.ctx.currentTime,.1)):a.ctx.listener.setPosition(a._pos[0],a._pos[1],a._pos[2]);else return a._pos;return a},HowlerGlobal.prototype.orientation=function(t,i,s,a,o,c){var u=this;if(!u.ctx||!u.ctx.listener)return u;var f=u._orientation;if(i=typeof i!="number"?f[1]:i,s=typeof s!="number"?f[2]:s,a=typeof a!="number"?f[3]:a,o=typeof o!="number"?f[4]:o,c=typeof c!="number"?f[5]:c,typeof t=="number")u._orientation=[t,i,s,a,o,c],typeof u.ctx.listener.forwardX<"u"?(u.ctx.listener.forwardX.setTargetAtTime(t,Howler.ctx.currentTime,.1),u.ctx.listener.forwardY.setTargetAtTime(i,Howler.ctx.currentTime,.1),u.ctx.listener.forwardZ.setTargetAtTime(s,Howler.ctx.currentTime,.1),u.ctx.listener.upX.setTargetAtTime(a,Howler.ctx.currentTime,.1),u.ctx.listener.upY.setTargetAtTime(o,Howler.ctx.currentTime,.1),u.ctx.listener.upZ.setTargetAtTime(c,Howler.ctx.currentTime,.1)):u.ctx.listener.setOrientation(t,i,s,a,o,c);else return f;return u},Howl.prototype.init=function(t){return function(i){var s=this;return s._orientation=i.orientation||[1,0,0],s._stereo=i.stereo||null,s._pos=i.pos||null,s._pannerAttr={coneInnerAngle:typeof i.coneInnerAngle<"u"?i.coneInnerAngle:360,coneOuterAngle:typeof i.coneOuterAngle<"u"?i.coneOuterAngle:360,coneOuterGain:typeof i.coneOuterGain<"u"?i.coneOuterGain:0,distanceModel:typeof i.distanceModel<"u"?i.distanceModel:"inverse",maxDistance:typeof i.maxDistance<"u"?i.maxDistance:1e4,panningModel:typeof i.panningModel<"u"?i.panningModel:"HRTF",refDistance:typeof i.refDistance<"u"?i.refDistance:1,rolloffFactor:typeof i.rolloffFactor<"u"?i.rolloffFactor:1},s._onstereo=i.onstereo?[{fn:i.onstereo}]:[],s._onpos=i.onpos?[{fn:i.onpos}]:[],s._onorientation=i.onorientation?[{fn:i.onorientation}]:[],t.call(this,i)}}(Howl.prototype.init),Howl.prototype.stereo=function(t,i){var s=this;if(!s._webAudio)return s;if(s._state!=="loaded")return s._queue.push({event:"stereo",action:function(){s.stereo(t,i)}}),s;var a=typeof Howler.ctx.createStereoPanner>"u"?"spatial":"stereo";if(typeof i>"u")if(typeof t=="number")s._stereo=t,s._pos=[t,0,0];else return s._stereo;for(var o=s._getSoundIds(i),c=0;c<o.length;c++){var u=s._soundById(o[c]);if(u)if(typeof t=="number")u._stereo=t,u._pos=[t,0,0],u._node&&(u._pannerAttr.panningModel="equalpower",(!u._panner||!u._panner.pan)&&e(u,a),a==="spatial"?typeof u._panner.positionX<"u"?(u._panner.positionX.setValueAtTime(t,Howler.ctx.currentTime),u._panner.positionY.setValueAtTime(0,Howler.ctx.currentTime),u._panner.positionZ.setValueAtTime(0,Howler.ctx.currentTime)):u._panner.setPosition(t,0,0):u._panner.pan.setValueAtTime(t,Howler.ctx.currentTime)),s._emit("stereo",u._id);else return u._stereo}return s},Howl.prototype.pos=function(t,i,s,a){var o=this;if(!o._webAudio)return o;if(o._state!=="loaded")return o._queue.push({event:"pos",action:function(){o.pos(t,i,s,a)}}),o;if(i=typeof i!="number"?0:i,s=typeof s!="number"?-.5:s,typeof a>"u")if(typeof t=="number")o._pos=[t,i,s];else return o._pos;for(var c=o._getSoundIds(a),u=0;u<c.length;u++){var f=o._soundById(c[u]);if(f)if(typeof t=="number")f._pos=[t,i,s],f._node&&((!f._panner||f._panner.pan)&&e(f,"spatial"),typeof f._panner.positionX<"u"?(f._panner.positionX.setValueAtTime(t,Howler.ctx.currentTime),f._panner.positionY.setValueAtTime(i,Howler.ctx.currentTime),f._panner.positionZ.setValueAtTime(s,Howler.ctx.currentTime)):f._panner.setPosition(t,i,s)),o._emit("pos",f._id);else return f._pos}return o},Howl.prototype.orientation=function(t,i,s,a){var o=this;if(!o._webAudio)return o;if(o._state!=="loaded")return o._queue.push({event:"orientation",action:function(){o.orientation(t,i,s,a)}}),o;if(i=typeof i!="number"?o._orientation[1]:i,s=typeof s!="number"?o._orientation[2]:s,typeof a>"u")if(typeof t=="number")o._orientation=[t,i,s];else return o._orientation;for(var c=o._getSoundIds(a),u=0;u<c.length;u++){var f=o._soundById(c[u]);if(f)if(typeof t=="number")f._orientation=[t,i,s],f._node&&(f._panner||(f._pos||(f._pos=o._pos||[0,0,-.5]),e(f,"spatial")),typeof f._panner.orientationX<"u"?(f._panner.orientationX.setValueAtTime(t,Howler.ctx.currentTime),f._panner.orientationY.setValueAtTime(i,Howler.ctx.currentTime),f._panner.orientationZ.setValueAtTime(s,Howler.ctx.currentTime)):f._panner.setOrientation(t,i,s)),o._emit("orientation",f._id);else return f._orientation}return o},Howl.prototype.pannerAttr=function(){var t=this,i=arguments,s,a,o;if(!t._webAudio)return t;if(i.length===0)return t._pannerAttr;if(i.length===1)if(typeof i[0]=="object")s=i[0],typeof a>"u"&&(s.pannerAttr||(s.pannerAttr={coneInnerAngle:s.coneInnerAngle,coneOuterAngle:s.coneOuterAngle,coneOuterGain:s.coneOuterGain,distanceModel:s.distanceModel,maxDistance:s.maxDistance,refDistance:s.refDistance,rolloffFactor:s.rolloffFactor,panningModel:s.panningModel}),t._pannerAttr={coneInnerAngle:typeof s.pannerAttr.coneInnerAngle<"u"?s.pannerAttr.coneInnerAngle:t._coneInnerAngle,coneOuterAngle:typeof s.pannerAttr.coneOuterAngle<"u"?s.pannerAttr.coneOuterAngle:t._coneOuterAngle,coneOuterGain:typeof s.pannerAttr.coneOuterGain<"u"?s.pannerAttr.coneOuterGain:t._coneOuterGain,distanceModel:typeof s.pannerAttr.distanceModel<"u"?s.pannerAttr.distanceModel:t._distanceModel,maxDistance:typeof s.pannerAttr.maxDistance<"u"?s.pannerAttr.maxDistance:t._maxDistance,refDistance:typeof s.pannerAttr.refDistance<"u"?s.pannerAttr.refDistance:t._refDistance,rolloffFactor:typeof s.pannerAttr.rolloffFactor<"u"?s.pannerAttr.rolloffFactor:t._rolloffFactor,panningModel:typeof s.pannerAttr.panningModel<"u"?s.pannerAttr.panningModel:t._panningModel});else return o=t._soundById(parseInt(i[0],10)),o?o._pannerAttr:t._pannerAttr;else i.length===2&&(s=i[0],a=parseInt(i[1],10));for(var c=t._getSoundIds(a),u=0;u<c.length;u++)if(o=t._soundById(c[u]),o){var f=o._pannerAttr;f={coneInnerAngle:typeof s.coneInnerAngle<"u"?s.coneInnerAngle:f.coneInnerAngle,coneOuterAngle:typeof s.coneOuterAngle<"u"?s.coneOuterAngle:f.coneOuterAngle,coneOuterGain:typeof s.coneOuterGain<"u"?s.coneOuterGain:f.coneOuterGain,distanceModel:typeof s.distanceModel<"u"?s.distanceModel:f.distanceModel,maxDistance:typeof s.maxDistance<"u"?s.maxDistance:f.maxDistance,refDistance:typeof s.refDistance<"u"?s.refDistance:f.refDistance,rolloffFactor:typeof s.rolloffFactor<"u"?s.rolloffFactor:f.rolloffFactor,panningModel:typeof s.panningModel<"u"?s.panningModel:f.panningModel};var p=o._panner;p||(o._pos||(o._pos=t._pos||[0,0,-.5]),e(o,"spatial"),p=o._panner),p.coneInnerAngle=f.coneInnerAngle,p.coneOuterAngle=f.coneOuterAngle,p.coneOuterGain=f.coneOuterGain,p.distanceModel=f.distanceModel,p.maxDistance=f.maxDistance,p.refDistance=f.refDistance,p.rolloffFactor=f.rolloffFactor,p.panningModel=f.panningModel}return t},Sound.prototype.init=function(t){return function(){var i=this,s=i._parent;i._orientation=s._orientation,i._stereo=s._stereo,i._pos=s._pos,i._pannerAttr=s._pannerAttr,t.call(this),i._stereo?s.stereo(i._stereo):i._pos&&s.pos(i._pos[0],i._pos[1],i._pos[2],i._id)}}(Sound.prototype.init),Sound.prototype.reset=function(t){return function(){var i=this,s=i._parent;return i._orientation=s._orientation,i._stereo=s._stereo,i._pos=s._pos,i._pannerAttr=s._pannerAttr,i._stereo?s.stereo(i._stereo):i._pos?s.pos(i._pos[0],i._pos[1],i._pos[2],i._id):i._panner&&(i._panner.disconnect(0),i._panner=void 0,s._refreshBuffer(i)),t.call(this)}}(Sound.prototype.reset);var e=function(t,i){i=i||"spatial",i==="spatial"?(t._panner=Howler.ctx.createPanner(),t._panner.coneInnerAngle=t._pannerAttr.coneInnerAngle,t._panner.coneOuterAngle=t._pannerAttr.coneOuterAngle,t._panner.coneOuterGain=t._pannerAttr.coneOuterGain,t._panner.distanceModel=t._pannerAttr.distanceModel,t._panner.maxDistance=t._pannerAttr.maxDistance,t._panner.refDistance=t._pannerAttr.refDistance,t._panner.rolloffFactor=t._pannerAttr.rolloffFactor,t._panner.panningModel=t._pannerAttr.panningModel,typeof t._panner.positionX<"u"?(t._panner.positionX.setValueAtTime(t._pos[0],Howler.ctx.currentTime),t._panner.positionY.setValueAtTime(t._pos[1],Howler.ctx.currentTime),t._panner.positionZ.setValueAtTime(t._pos[2],Howler.ctx.currentTime)):t._panner.setPosition(t._pos[0],t._pos[1],t._pos[2]),typeof t._panner.orientationX<"u"?(t._panner.orientationX.setValueAtTime(t._orientation[0],Howler.ctx.currentTime),t._panner.orientationY.setValueAtTime(t._orientation[1],Howler.ctx.currentTime),t._panner.orientationZ.setValueAtTime(t._orientation[2],Howler.ctx.currentTime)):t._panner.setOrientation(t._orientation[0],t._orientation[1],t._orientation[2])):(t._panner=Howler.ctx.createStereoPanner(),t._panner.pan.setValueAtTime(t._stereo,Howler.ctx.currentTime)),t._panner.connect(t._node),t._paused||t._parent.pause(t._id,!0).play(t._id,!0)}})()})(Rr);const za="data:audio/mpeg;base64,SUQzBAAAAAAAI1RTU0UAAAAPAAADTGF2ZjU4LjQxLjEwMAAAAAAAAAAAAAAA//NwwAAAAAAAAAAAAEluZm8AAAAPAAAAFAAACOAAICAgICwsLCwsNzc3NzdDQ0NDQ09PT09PW1tbW1tmZmZmZnJycnJyfn5+fn6KioqKipWVlZWVoaGhoaGtra2trbm5ubm5xcXFxcXQ0NDQ0Nzc3Nzc6Ojo6Oj09PT09P//////AAAAAExhdmM1OC43NQAAAAAAAAAAAAAAACQCwAAAAAAAAAjgTZykiAAAAAAAAAAAAAAAAAD/80DEABJhFmQCwwYUIDsKrsHAWBMRyeJYliQJBg5RYsWU/W3z/8OLc/3AAAQiIAIjv+7vUCJXd4jucQABAE3lwffiDBD+JC58oCH8H/1h/WH//1HPwTUMFrULH9ELKxULyTodFKYbO//zQsQRFFkScKDSRhyGWpIFpG91I7Fi/F6D2RWwN6TN/t9CiVSG5wMw74ogYcHoEwTFyMmTf4KkxEwmRfjXIYv1tpIOZRv/3O9ibtjR6gYmbGCgQ+Fk0mfSmybOX1cf78g7D6nP6qxCgf/zQMQbF+EacktaSABfy+3JKszHdMgcwwcl/kNFIuAo0I0DD1fWVs/crTSTTRInof3cmIwyLBwGQqCSLq7hyvtRPBB4aFyyXHov9X///7UXKqoIIcgcHict89/0y+n+nf/C0DIjB/+P//NCxBYZU9q0AYpoAHNyXSLn/+EjEbJclC4eJT//8e5aMAWeE4////wvAyAvYjZLjAD0Lg9D0kCU/////zwwBdJcYAehKBIwtYyx6FyXC4XP//////x7l83NDpfqd6gAcA/+wu9A2FGg//NAxAwXCnsq/5M4AhQKAOwmRvQRhjhOe5S8UkAmVHpU8IVU3lwejjIcayXOOceGwjf+D05I8oAu2x382o1ZHHV//31NU4441lmqcv///+RNGrUJKImnTf//iVYK1UZquoZESSy3egH/80LEChchBtMfyzAAk191v20qimbuNqavb211BthJKSJAG2aucbdLeVFVmRjZEVvzOggIwuUFDgvEZA7UeuUqNMLOraDQ5CVCk5m9BsmT3kbNrBdolcFSsqXGwQTWyYUX2wEDEgKkvZb/80DECRYRUpWsikYY1HXLbDZksYxtCHBShdHt/DgYCOM6r8AmUSpfGZYzH7ARMBCj1JtmY/hmwoGio0XBUShoklC5GsNeDR38RQ6d01DyrENtqp6mCJ5GJUckmpUBaIgYK6C0fPjmUf/zQsQLFil+cajTBhydxPRO4mLMWWSGQF2qa1f3PPlHQDJdzCxnwgkzB1SQohrpNRYRgtobv07tBLUFc27jQdWoQY0JNpiMJy654enBVoqnQR571uq/i9rpL1oAqAupJATLLk5L+QT3Kf/zQMQOE9D2bWFaGACZyWQZdt1rd3OVY8s/y2dBlg0m12PFzdFSlYrboY6gMOE1hJp7iFqmDcopF8F2OKEPnktdThRLoy9iuyj//0vD4+qf///++38OsIIFFhpEFZMC4s+gZmilJz1X//NCxBkaW8allZI4AWPWKBoLFWrwfuYvukbk4Rt9tBuJYOBoWpfzfjQaNMp//+OGEzzzDIif3+n/4PBIEt5hjDc9zxv/////nseeNDHGg0MQwxBEFn//////4TpB9d/s9thcHddpssFg//NAxAsVCT8GX5BAAigUAPBBdOBaKEIpaajR1VyCNH/gAwAfjRX8G7B4zfx0HANA8BpjQ6FhfqKxRBQURleGbrufzJywVGVfRdOzp5///ERCxhb//8wqijBAwUYMBCjVWZsv26uwYU3/80LEERRTIuTLwxABmdQgEBGKFNo9amfRWcpnayOUsKJ/UpWo/qyL////sj1b+pc3oarStSWpf/VP+hlotDN/0MVjKMKDAZGL/Ar8QWpCR0msAoVgrMoeT3xHIZd3qARkQge7hzlejQD/80DEGxPQ5sryeYYUBCI58AEvohe5nAMDcPxAbUxN6VCB4xCid97iaTyonF0l4upInmIpD//V0f/OllFls0vEBipVlYYRWhuzlHgpEiJSRmYJQaiptezfqvKm1PBRJKiq7M3s1yoqKv/zQsQmFBEGuojBkAQdCzTSpHY0FSwdboEQKi7pZN986g7UVOkf5ZR6VdbbQwZ+79PW6VoWdwZqA4VT2QGoxuuO0VZgbATjSNkSqqresUZ4lDGM5tfbuZzGHYfri5YKg0eDjgQjhm0Wpf/zQMQxE1jyoqhoxFD16D4jzQUUULEB1QXZhRIdIbHFtSlSvX5anFh11QTHaABkiBXOXoXxGW9galRr4fRiew3yOag/4HjxOydOM9ZyyokPlRKdFBa0CjY1luBiKXXwLw6oeMWEhjoS//NCxD4TUNKKIJpMJNTRh7nf/3kekmjdSWypy9UZXQgZMDh3pnAWB4O2M6nAaelR4r1OmVPFSwoksiWRUE1zc+f1lPc0ZudtdFDr4LLpoSwwGkpVO+oD6Tlb3HsYL7d+R1//td2LQMNF//NAxEwTaP5xYqJMCFlqIwAbEoCJNDEp9/3itYVbV6Yx/v0nuLdzyy50qHQw3cafmKlb6zBo0yXeRMnQG5J4jE7j4PFAkTSpQ9pexojMMsL0PIqP/Z1Xp/TpnVZZ27eWtNWRSSSyWyz/80LEWRSo1nDhWhgAlsstlkskgADyNOHqG5rlhLnSyI0a5oClU7uw0JnJQq2kTMBUYADEskGQ9wdHohh2xMKnCubKTIdyRgT83NEIrcfJpJOL3fV7l9cyXXJwJRDGpJLTZJF1+3OPUX3/80DEYiVyorJfmlgDRVRdYm21rHJXTVH0+ajd35ouiSF1tVcmLGnFummxbrhsXfHNzcf/2qgd/7XhppiSaYkmmQGRpnCsAMAEB4tQrXVA0VOiINSMWfljtMTHsRdZ3iL/V1neW6zvLf/zQsQnDSAiMFXMGADWd4i6zvEX+W/yzud5ZUxBTUUzLjEwMFVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVQ==";let Va=class{constructor(){this.sound=new Rr.Howl({src:[za]})}play(){this.sound.play()}};const xe=n=>{var e,t;if(typeof n.destroy=="function"){n.destroy();return}for(;n.children.length>0;)xe(n.children[0]),(e=n.children[0])==null||e.removeFromParent();if(n instanceof d.Mesh)try{(t=n.geometry)==null||t.dispose()}catch{}};function Ua(n){return new d.Vector3(n[0],n[1],n[2])}function Ha(){let n=3,e=Math.max(1/window.devicePixelRatio,.5);return window.innerWidth/window.innerHeight<.65&&(n=4,e=1/window.devicePixelRatio),{tiles:n,renderScale:e}}function Na(n){let e=!1,t=!1,i=!1,s=1/0,a=1/0,o=1/0,c=-1/0,u=-1/0,f=-1/0,p=0,r=0;return n.traverse(h=>{if(h.isMesh&&h.geometry){const g=h;if(g.userData.ignoreSize||g.material.userData.isLOGO)return;g.geometry.computeBoundingBox();let _=g.geometry.attributes.position;const m=g.geometry.morphAttributes.position;let v=g.morphTargetInfluences;const y=Object.keys(g.morphTargetDictionary||{});y.includes("width")&&(t=!0),y.includes("length")&&(e=!0),y.includes("height")&&(i=!0);for(let x=0;x<_.count;x++){let w=_.getX(x),b=_.getY(x),A=_.getZ(x);r=Math.max(b,r),m&&v&&m.forEach((I,C)=>{const P=v&&v[C]||0;w+=I.getX(x)*P,b+=I.getY(x)*P,A+=I.getZ(x)*P}),w<s&&(s=w),b<a&&(a=b),A<o&&(o=A),w>c&&(c=w),b>u&&(u=b),A>f&&(f=A);const T=Math.sqrt(w*w+b*b);T>p&&(p=T)}}}),{box:new d.Box3(new d.Vector3(s,a,o),new d.Vector3(c,u,f)),maxRadius:p,height:r,hasWidth:t,hasLength:e,hasHeight:i}}function Wa(n,e,t=null){let i=0;return function(){let s=t||this,a=arguments;clearTimeout(i),i=window.setTimeout(function(){n.apply(s,a)},e)}}class Ga{constructor(e,t,i){this.length=e,this.width=t,this.height=i}}const Ws=n=>{var i;let e=0,t=0;if(n.geometry){n.geometry.computeBoundingBox();const s=new d.Vector3;(i=n.geometry.boundingBox)==null||i.getSize(s),s.y?(t=s.y,!s.x&&s.z?e=s.z:s.x&&!s.z?e=s.x:s.x&&s.z&&(e=s.z)):(e=s.z,t=s.x)}return{width:e,height:t}};function cs(){var e;if(typeof navigator>"u")return!1;if(qa())return!0;const n=(e=navigator.userAgent)==null?void 0:e.toLowerCase();return/iphone|ipad|ipod|android|mobile|blackberry|iemobile|opera mini/.test(n)}function qa(){try{if(typeof wx<"u"&&wx.getSystemInfo||typeof my<"u"&&my.alert||typeof tt<"u"&&tt.getSystemInfo||typeof swan<"u"&&swan.getSystemInfo)return!0}catch{}return!1}const Pr=new hn.GLTFExporter,lt=new ln.GLTFLoader,ui=new cn.DRACOLoader;let st="./draco/";try{st=new URL("./draco/",typeof document>"u"?require("url").pathToFileURL(__filename).href:ot&&ot.src||new URL("shop-components.cjs",document.baseURI).href).href}catch{st="./draco/"}typeof window<"u"&&window.dracoPath&&(st=window.dracoPath);ui.setDecoderConfig({type:"wasm"});ui.setDecoderPath(st.endsWith("/")?st:`${st}/`);ui.preload();lt.setDRACOLoader(ui);const ja=new un.DRACOExporter,Gs=[115,103,108,98];function Ya(n,e,t){const i=JSON.stringify(e),s=new TextEncoder().encode(i),a=new Uint8Array([115,103,108,98]),o=new Uint8Array(2);o[0]=t>>8,o[1]=t&255;const c=new Uint8Array(4);c[0]=s.length>>24,c[1]=s.length>>16&255,c[2]=s.length>>8&255,c[3]=s.length&255;const u=new Uint8Array(n),f=a.length+o.length+c.length+s.length+u.length,p=new Uint8Array(f);let r=0;return p.set(a,r),r+=a.length,p.set(o,r),r+=o.length,p.set(c,r),r+=c.length,p.set(s,r),r+=s.length,p.set(u,r),p.buffer}function Qa(n){const e=new Uint8Array(n.slice(0,4));let t=!0;for(let r=0;r<Gs.length;r++)if(e[r]!==Gs[r]){t=!1;break}if(!t)throw new Error("Invalid file format");const s=new DataView(n,4,2).getUint16(0,!1),o=new DataView(n,6,4).getUint32(0,!1),c=new Uint8Array(n.slice(10,10+o)),u=new TextDecoder().decode(c),f=JSON.parse(u),p=n.slice(10+o);return{version:s,jsonDescription:f,glbContent:p}}class ni{constructor(e){this.props=e,this.cache=new Map}load(e,t,i,s){if(this.props.useCache&&this.cache.has(e)){t(this.cache.get(e));return}const a=this;fetch(e).then(o=>{if(!o.ok){s==null||s(new ErrorEvent("NetworkError",{message:"NetworkError for "+e+": "+o.statusText}));return}return o.arrayBuffer()}).then(async o=>{o||s==null||s(new ErrorEvent("Error",{message:"Not a valid sglb file."}));try{const c=a.parse(o);if(!c.glbContent){s==null||s(new ErrorEvent("Error",{message:"No glb content."}));return}const u=Hi(c.glbContent,"model/gltf-binary"),f=await lt.loadAsync(u);URL.revokeObjectURL(u),c.glbContent=void 0,c.glb=f.scene,o=void 0,this.cache.set(e,c),t(c)}catch(c){s==null||s(new ErrorEvent("Error",{message:c==null?void 0:c.message}))}}).catch(o=>{s==null||s(new ErrorEvent("Error",{message:o.message}))})}async loadAsync(e){if(this.props.useCache&&this.cache.has(e))return this.cache.get(e);try{const t=await fetch(e);if(!t.ok)throw new Error(`NetworkError for ${e}: ${t.statusText}`);const i=await t.arrayBuffer();if(!i)throw new Error("Not a valid sglb file.");const s=this.parse(i);if(!s.glbContent)throw new Error("No GLB content.");const a=Hi(s.glbContent,"model/gltf-binary");console.log(a);const o=await lt.loadAsync(a);return URL.revokeObjectURL(a),s.glbContent=void 0,s.glb=o.scene,this.cache.set(e,s),s}catch(t){throw t}}parse(e){return Qa(e)}clear(){[...this.cache.values()]}}const Za=`*{box-sizing:border-box}.slot-item-container.is-mobile .main{pointer-events:none;border-width:1px;opacity:.8}.slot-item-container.is-mobile .main.focus{width:18px!important;height:18px!important;border-width:2px;opacity:1}.slot-item-container.is-mobile .main.filled{opacity:1;border-width:1px;width:14px!important;height:14px!important;background-image:none;border-radius:50%}.slot-item-container.is-mobile .main.to-be-installed{opacity:1;pointer-events:auto;width:38px!important;height:38px!important;border-color:#000;border-width:1px;background-image:url("data:image/svg+xml,%3csvg%20xmlns='http://www.w3.org/2000/svg'%20xmlns:xlink='http://www.w3.org/1999/xlink'%20fill='none'%20version='1.1'%20width='20'%20height='20'%20viewBox='0%200%2020%2020'%3e%3cg%3e%3cg%3e%3cpath%20d='M20,10.75L0,10.75L0,9.25L20,9.25L20,10.75Z'%20fill-rule='evenodd'%20fill='%23000000'%20fill-opacity='1'/%3e%3c/g%3e%3cg%20transform='matrix(0,1,1,0,10,-10)'%3e%3cpath%20d='M30,0.75L10,0.75L10,-0.75L30,-0.75L30,0.75Z'%20fill-rule='evenodd'%20fill='%23000000'%20fill-opacity='1'/%3e%3c/g%3e%3c/g%3e%3c/svg%3e");background-size:20px auto;background-repeat:no-repeat;background-position:center;background-color:#fff9}.slot-item-container.is-mobile .main.to-be-installed+.info{pointer-events:auto;overflow:visible;width:auto}.slot-item-container.is-mobile .main.to-be-installed.filled{opacity:1;border-width:2px;width:18px!important;height:18px!important;background-image:none;border-radius:50%;border-color:#00ff95}.slot-item-container.is-mobile .main.to-be-installed.to-be-replaced{opacity:1;border-width:1px;pointer-events:auto;width:38px!important;height:38px!important;border-radius:50%;background-image:url("data:image/svg+xml,%3csvg%20xmlns='http://www.w3.org/2000/svg'%20xmlns:xlink='http://www.w3.org/1999/xlink'%20fill='none'%20version='1.1'%20width='40'%20height='40'%20viewBox='0%200%2040%2040'%3e%3cdefs%3e%3cclipPath%20id='master_svg0_504_014299'%3e%3crect%20x='0'%20y='0'%20width='40'%20height='40'%20rx='20'/%3e%3c/clipPath%3e%3c/defs%3e%3cg%20clip-path='url(%23master_svg0_504_014299)'%3e%3cg%3e%3cg%3e%3cpath%20d='M31.695414,17L26.009501,10.74549544L24.899591,11.75450456L28.304586,15.5L8.75,15.5L8.75,17L31.695414,17Z'%20fill-rule='evenodd'%20fill='%23000000'%20fill-opacity='1'/%3e%3c/g%3e%3cg%3e%3cpath%20d='M8.3045862,23L13.9904997,29.2545042L15.10041,28.2454953L11.6954139,24.5L31.25,24.5L31.25,23L8.3045862,23Z'%20fill-rule='evenodd'%20fill='%23000000'%20fill-opacity='1'/%3e%3c/g%3e%3c/g%3e%3c/g%3e%3c/svg%3e");background-size:38px auto;border-color:#000}.slot-item-container.is-mobile .info{left:100%;margin-top:0;margin-left:4px}.slot-item-container.is-mobile .info .name-wrapper{margin-top:0;border-radius:0;background:#000;color:#fff}.slot-item-container.is-mobile .info>img{display:none}.slot-item-container .main{pointer-events:auto;cursor:pointer;font-size:12px;color:#fff;width:22px;height:22px;background:#fff0;border:1.5px solid #fff;border-radius:0;transition:background .2s,width .14s,height .14s,border .14s}.slot-item-container .main.disable{cursor:not-allowed}.slot-item-container .main.drag-over{border-color:red}.slot-item-container .main.can-install{position:relative;width:44px;height:44px;background:#0066ff1a;border-color:#06f}.slot-item-container .main.filled{border-color:#00ff95;border-radius:50%}.slot-item-container .main.selected{border-width:4px}.slot-item-container .main.selected+.info{pointer-events:auto;overflow:visible;width:auto}.slot-item-container .main.focus{border-color:#000}.slot-item-container .main.focus+.info{pointer-events:auto;overflow:visible;width:auto}.slot-item-container .main.has-error{border-color:red}.slot-item-container .main.hidden{display:none}.slot-item-container .main.hidden+.info{display:none}.slot-item-container .main:after{pointer-events:none;content:attr(data-name);transition:all .2s .3s;opacity:0;position:absolute;left:50%;bottom:100%;transform:translate3d(-50%,5px,0);white-space:nowrap;font-size:12px;color:#000;padding:2px 8px;border-radius:2px;background:#fff}.slot-item-container .main:hover{background:#ffffff80}.slot-item-container .main:hover+.info{pointer-events:auto;overflow:visible;width:auto}.slot-item-container .name{position:relative}.slot-item-container .name-wrapper{margin-top:-10px;white-space:nowrap;font-size:12px;color:#fff;padding:2px 8px;background:#000}.slot-item-container .functions-wrapper{z-index:20000;position:absolute;left:0;top:100%}.slot-item-container .functions-wrapper>.functions{display:inline-block;min-width:100px;padding:6px 0;border-left:1px solid #00ff95;border-radius:0 2px 2px 0;background:#0003;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px)}.slot-item-container .functions-wrapper>.functions .btn-add{cursor:pointer;padding:2px 0;margin:0 8px;display:flex;justify-content:center;align-content:center;align-items:center;border:1px dashed #eee;font-size:12px;color:#eee;border-radius:2px;-webkit-backdrop-filter:none;backdrop-filter:none;background:#00050a80}.slot-item-container .functions-wrapper>.functions .btn-add.btn-not-allowed{cursor:not-allowed}.slot-item-container .functions-wrapper>.functions .function{display:flex;justify-content:space-between;white-space:nowrap;margin-bottom:6px;padding:0 8px;font-size:12px;color:#fff}.slot-item-container .functions-wrapper>.functions .function span{margin-right:4px}.slot-item-container .functions-wrapper>.functions .function .btn-remove{pointer-events:none;opacity:0;cursor:pointer;align-self:center;margin-right:0;height:14px;width:14px;background:url(data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAABgAAAAYCAYAAADgdz34AAAAAXNSR0IArs4c6QAAAARzQklUCAgICHwIZIgAAACnSURBVEiJxZaxFcMgDETPTuUtWCWTM4pZAq5RojRpnOfEyEKxSnh3HySeBEhNjZJJTRgUG89GyZWilbKOgJCaKmWtFG2UvFnwQr56jYAcengg3dozELPGIjh96x6hu26/DIa9vD0jq/nUA3nikQEkAOW9nACUGbf7skxlX2mIj1Ob0jK76QdxbYpGFNlk3rPnNndDQltFaLMLbdehAyd8ZP5l6Ed+W17xG7oN9QkytAAAAABJRU5ErkJggg==) center no-repeat;background-size:10px 10px}.slot-item-container .functions-wrapper>.functions .function:hover .btn-remove{pointer-events:auto;opacity:1;transform:scale(1.2)}.slot-item-container .device-name{position:relative;margin:2px 0;display:flex;min-width:120px;align-items:center;align-content:center;justify-content:space-between;white-space:nowrap;height:30px;padding:0 8px;font-size:14px;font-weight:700;color:#000;background:#fff}.slot-item-container .device-name .device-logo{margin-left:-8px;margin-right:4px;width:30px;height:30px;object-fit:contain}.slot-item-container .device-name span{display:block;white-space:nowrap;text-overflow:ellipsis;overflow:hidden;max-width:250px}.slot-item-container .device-name .btn-close{margin-left:8px;cursor:pointer;height:20px;width:20px;background:url("data:image/svg+xml,%3csvg%20xmlns='http://www.w3.org/2000/svg'%20xmlns:xlink='http://www.w3.org/1999/xlink'%20fill='none'%20version='1.1'%20width='20'%20height='20'%20viewBox='0%200%2020%2020'%3e%3cdefs%3e%3cclipPath%20id='master_svg0_504_017509'%3e%3crect%20x='0'%20y='0'%20width='20'%20height='20'%20rx='0'/%3e%3c/clipPath%3e%3c/defs%3e%3cg%20clip-path='url(%23master_svg0_504_017509)'%3e%3cg%3e%3cpath%20d='M4.375,16.875L4.375,4.375L15.625,4.375L15.625,16.875L4.375,16.875ZM14.375,5.625L5.625,5.625L5.625,15.625L14.375,15.625L14.375,5.625Z'%20fill-rule='evenodd'%20fill='%23999999'%20fill-opacity='1'/%3e%3c/g%3e%3cg%3e%3cpath%20d='M8.125,12.1875L8.125,8.125L9.375,8.125L9.375,12.1875L8.125,12.1875Z'%20fill-rule='evenodd'%20fill='%23999999'%20fill-opacity='1'/%3e%3c/g%3e%3cg%3e%3cpath%20d='M10.625,12.1875L10.625,8.125L11.875,8.125L11.875,12.1875L10.625,12.1875Z'%20fill-rule='evenodd'%20fill='%23999999'%20fill-opacity='1'/%3e%3c/g%3e%3cg%3e%3cpath%20d='M16.875,5.625L3.125,5.625L3.125,4.375L16.875,4.375L16.875,5.625Z'%20fill-rule='evenodd'%20fill='%23999999'%20fill-opacity='1'/%3e%3c/g%3e%3cg%3e%3cpath%20d='M6.4446528999999995,5.625L13.545177899999999,5.625L11.8665838,2.5L8.15767372,2.5L6.4446528999999995,5.625ZM11.4548223,4.3749999L8.5553472,4.3749999L8.8979512,3.75L11.1191032,3.75L11.4548223,4.3749999Z'%20fill-rule='evenodd'%20fill='%23999999'%20fill-opacity='1'/%3e%3c/g%3e%3c/g%3e%3c/svg%3e") center no-repeat;background-size:100% auto}.slot-item-container .device-name.empty{color:#000c;font-weight:400}.slot-item-container .device-name.empty .btn-close{display:none}.slot-item-container .device-name.empty:before{height:0}.slot-item-container .all-functions{opacity:0;pointer-events:none;min-width:80px;position:absolute;left:-10px;margin-left:100%;bottom:0;padding:6px 0;background:#fff;transition:all .3s}.slot-item-container .all-functions.show{opacity:1;pointer-events:auto;left:16px}.slot-item-container .all-functions label{margin-left:8px;margin-bottom:20px;color:#444e69;font-size:14px}.slot-item-container .all-functions .btn-close{cursor:pointer;position:absolute;right:7px;top:7px;height:16px;width:16px;background:url(data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAABAAAAAQCAYAAAAf8/9hAAAAAXNSR0IArs4c6QAAAARzQklUCAgICHwIZIgAAAB4SURBVDiNpZPLEYAgDAUXe6MuoK4UpwdBwQkQJDcyb9+QnxORCOC9jyxE4Y78DiWxAIcmISKnxaSrtZhMNSOB+ZeacAS7ngl3k1JOBSBpk1INPib0YHjH+Du2S1DhlSZOYbPJ1iLtrLKrG2a9yJopYzTD8Jx+ArgAylOzjm1WpDwAAAAASUVORK5CYII=) center no-repeat;background-size:10px 10px}.slot-item-container .all-functions .functions{display:inline-block;max-height:200px;overflow-x:hidden;overflow-y:auto}.slot-item-container .all-functions .functions::-webkit-scrollbar{width:4px}.slot-item-container .all-functions .functions::-webkit-scrollbar-track{background-color:#fff}.slot-item-container .all-functions .functions::-webkit-scrollbar-thumb{background:#787878;border-radius:25px}.slot-item-container .all-functions .function{display:flex;justify-content:space-between;white-space:nowrap;padding:5px 10px;font-size:12px;color:#787878}.slot-item-container .all-functions .function span{display:flex;align-content:center;align-items:center;margin-right:4px}.slot-item-container .all-functions .function:hover{background:#444e6933}.slot-item-container .all-functions .btn-add{cursor:pointer;width:16px;font-size:16px;text-align:center;font-style:normal}.slot-item-container .info{overflow:hidden;margin-left:-2px;margin-top:-19px;position:absolute;left:100%;top:50%;transform:translateY(-50%);width:0;display:flex;align-items:flex-start;transition:all .3s}.slot-item-container .info>img{flex:0 0 auto;width:53px;height:29px}`,Xa="data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAAGsAAAA7CAYAAAB8MXT7AAAAAXNSR0IArs4c6QAAAARzQklUCAgICHwIZIgAAAGTSURBVHic7dxLbQNBEIThnigADGEhxAwcBoZgCIZgBoZgCIZgCIaQMIgZVC4daw/xXPLoqdX/3fbW0milUtfutMCdpCkiLhEx1U6CLkkvkt4k7atnQYekfR7US/Us6JB0yIOaqmfBA5JWks6SrhzUwCRN+TYdq2dBx+ygDtWzoEPSNg9qVz0LOmZBgsQ3sqUkvufqAf6SpFVEnCPiFhHr1tqteCR8hyBhYrY6OlTPgo5cHX1I2lbPgo6lBInFk3Rc+uroqXqAn8ogcc3H19bae+U8eIDEZ0LSJoMEZeHIWB2ZIPEZoCw0QVlogsRnYlYWsjoaGUHCRK6OOKiRfa2OMvWtqufBAwQJE5SFJmZl4aZ6FnSQ+Azk6mjxZeFv+/fycfbDWrTW1pSFgyLxmcjVEWXh6CgLTZD4DMzKwguro4ERJEywOjIhaUdZaIAgYYKy0ABloQkSnwlxKZUHcSmVBxKfgVwdnSgLB8d35iZIfCYoC01QFpog8Y3rftFWrotO+cilVKMiSJigLDSS30hQFhr4BEcKZN0LNhDxAAAAAElFTkSuQmCC",qs={name:"",isMobile:!1},Ka={"&":"&amp;","<":"&lt;",">":"&gt;",'"':"&quot;","'":"&#39;"};function _t(n){return n==null?"":String(n).replace(/[&<>"']/g,e=>Ka[e])}function js(...n){return n.filter(Boolean).join(" ")}class Dr extends HTMLElement{constructor(e){super(),this._size=12,this._showDialog=!1,this._selected=!1,this._focused=!1,this._toBeInstalled=!1,this._toBeReplaced=!1,this._hasError=!1,this._canInstall=!1,this._hide=!1,this._disable=!1,this._filled=!1,this._allFunctions=[],this._functions=[],this._deviceName="",this._deviceLogo="",this._renderQueued=!1,this._needsRender=!0,this.attachShadow({mode:"open"}),this._props={...qs,...e??{}},this.handleShadowClick=this.handleShadowClick.bind(this),this.shadowRoot.addEventListener("click",this.handleShadowClick),this.render()}connectedCallback(){this._needsRender&&(this._needsRender=!1,this.render())}get props(){return this._props}set props(e){this._props={...qs,...e},this.scheduleRender()}get slot(){return this._slot}set slot(e){this._slot=e,this.scheduleRender()}get selected(){return this._selected}set selected(e){const t=!!e;this._selected!==t&&(this._selected=t,this.scheduleRender())}get focused(){return this._focused}set focused(e){const t=!!e;this._focused!==t&&(this._focused=t,this.scheduleRender())}get toBeInstalled(){return this._toBeInstalled}set toBeInstalled(e){const t=!!e;this._toBeInstalled!==t&&(this._toBeInstalled=t,this.scheduleRender())}get toBeReplaced(){return this._toBeReplaced}set toBeReplaced(e){const t=!!e;this._toBeReplaced!==t&&(this._toBeReplaced=t,this.scheduleRender())}get hasError(){return this._hasError}set hasError(e){const t=!!e;this._hasError!==t&&(this._hasError=t,this.scheduleRender())}get canInstall(){return this._canInstall}set canInstall(e){var s;const t=!!e,i=(s=this.shadowRoot)==null?void 0:s.querySelector(".main");if(i){e?i.classList.add("can-install"):i.classList.remove("can-install");return}this._canInstall!==t&&(this._canInstall=t,this.scheduleRender())}get hide(){return this._hide}set hide(e){const t=!!e;this._hide!==t&&(this._hide=t,this.scheduleRender())}get disable(){return this._disable}set disable(e){const t=!!e;this._disable!==t&&(this._disable=t,this.scheduleRender())}get filled(){return this._filled}set filled(e){var s;const t=!!e,i=(s=this.shadowRoot)==null?void 0:s.querySelector(".main");if(i){e?i.classList.add("filled"):i.classList.remove("filled");return}this._filled!==t&&(this._filled=t,this.scheduleRender())}get allFunctions(){return[...this._allFunctions]}set allFunctions(e){this._allFunctions=Array.isArray(e)?[...e]:[],this.hasMoreFunctions||(this._showDialog=!1),this.scheduleRender()}get functions(){return[...this._functions]}set functions(e){this._functions=Array.isArray(e)?[...e]:[],this.hasMoreFunctions||(this._showDialog=!1),this.scheduleRender()}get deviceName(){return this._deviceName}set deviceName(e){this._deviceName=e??"",this.scheduleRender()}get deviceLogo(){return this._deviceLogo}set deviceLogo(e){this._deviceLogo=e??"",this.scheduleRender()}get hasMoreFunctions(){return this._allFunctions.some(e=>!this._functions.includes(e))}setSize(e=12){var s;const t=Number.isFinite(e)?Number(e):12,i=(s=this.shadowRoot)==null?void 0:s.querySelector(".main");if(i){i.style.width=i.style.height=`${e}px`;return}this._size!==t&&(this._size=t,this.scheduleRender())}removeDevice(){var e,t;this._showDialog=!1,this.scheduleRender(),(t=(e=this._props).onRemove)==null||t.call(e)}addFunction(e){this.dispatchEvent(new CustomEvent("function-added",{detail:e}))}scheduleRender(){if(!this.isConnected){this._needsRender=!0;return}this._renderQueued||(this._renderQueued=!0,queueMicrotask(()=>{this._renderQueued=!1,this.render()}))}render(){var p;if(!this.shadowRoot)return;const e=js("slot-item-container",this._props.isMobile&&"is-mobile"),t=js("main",this._selected&&"selected",this._focused&&"focus",this._toBeInstalled&&"to-be-installed",this._toBeReplaced&&"to-be-replaced",this._hasError&&"has-error",this._canInstall&&"can-install",this._hide&&"hidden",this._disable&&"disable",this._filled&&"filled"),i=this._functions.map(r=>{const l=_t(r);return`<div class="function" data-function="${l}"><span>${l}</span><i class="btn btn-remove" data-action="remove-function" data-function="${l}"></i></div>`}).join(""),s=this._allFunctions.filter(r=>!this._functions.includes(r)),a=this._allFunctions.length?`<div class="functions">${i}${`<div class="btn btn-add ${this.hasMoreFunctions?"":"btn-not-allowed"}" data-action="toggle-dialog">+添加</div>`}</div>`:"",o=s.length?`<div class="all-functions ${this._showDialog?"show":""}">
3706
+ */(function(){HowlerGlobal.prototype._pos=[0,0,0],HowlerGlobal.prototype._orientation=[0,0,-1,0,1,0],HowlerGlobal.prototype.stereo=function(t){var i=this;if(!i.ctx||!i.ctx.listener)return i;for(var s=i._howls.length-1;s>=0;s--)i._howls[s].stereo(t);return i},HowlerGlobal.prototype.pos=function(t,i,s){var a=this;if(!a.ctx||!a.ctx.listener)return a;if(i=typeof i!="number"?a._pos[1]:i,s=typeof s!="number"?a._pos[2]:s,typeof t=="number")a._pos=[t,i,s],typeof a.ctx.listener.positionX<"u"?(a.ctx.listener.positionX.setTargetAtTime(a._pos[0],Howler.ctx.currentTime,.1),a.ctx.listener.positionY.setTargetAtTime(a._pos[1],Howler.ctx.currentTime,.1),a.ctx.listener.positionZ.setTargetAtTime(a._pos[2],Howler.ctx.currentTime,.1)):a.ctx.listener.setPosition(a._pos[0],a._pos[1],a._pos[2]);else return a._pos;return a},HowlerGlobal.prototype.orientation=function(t,i,s,a,o,c){var u=this;if(!u.ctx||!u.ctx.listener)return u;var f=u._orientation;if(i=typeof i!="number"?f[1]:i,s=typeof s!="number"?f[2]:s,a=typeof a!="number"?f[3]:a,o=typeof o!="number"?f[4]:o,c=typeof c!="number"?f[5]:c,typeof t=="number")u._orientation=[t,i,s,a,o,c],typeof u.ctx.listener.forwardX<"u"?(u.ctx.listener.forwardX.setTargetAtTime(t,Howler.ctx.currentTime,.1),u.ctx.listener.forwardY.setTargetAtTime(i,Howler.ctx.currentTime,.1),u.ctx.listener.forwardZ.setTargetAtTime(s,Howler.ctx.currentTime,.1),u.ctx.listener.upX.setTargetAtTime(a,Howler.ctx.currentTime,.1),u.ctx.listener.upY.setTargetAtTime(o,Howler.ctx.currentTime,.1),u.ctx.listener.upZ.setTargetAtTime(c,Howler.ctx.currentTime,.1)):u.ctx.listener.setOrientation(t,i,s,a,o,c);else return f;return u},Howl.prototype.init=function(t){return function(i){var s=this;return s._orientation=i.orientation||[1,0,0],s._stereo=i.stereo||null,s._pos=i.pos||null,s._pannerAttr={coneInnerAngle:typeof i.coneInnerAngle<"u"?i.coneInnerAngle:360,coneOuterAngle:typeof i.coneOuterAngle<"u"?i.coneOuterAngle:360,coneOuterGain:typeof i.coneOuterGain<"u"?i.coneOuterGain:0,distanceModel:typeof i.distanceModel<"u"?i.distanceModel:"inverse",maxDistance:typeof i.maxDistance<"u"?i.maxDistance:1e4,panningModel:typeof i.panningModel<"u"?i.panningModel:"HRTF",refDistance:typeof i.refDistance<"u"?i.refDistance:1,rolloffFactor:typeof i.rolloffFactor<"u"?i.rolloffFactor:1},s._onstereo=i.onstereo?[{fn:i.onstereo}]:[],s._onpos=i.onpos?[{fn:i.onpos}]:[],s._onorientation=i.onorientation?[{fn:i.onorientation}]:[],t.call(this,i)}}(Howl.prototype.init),Howl.prototype.stereo=function(t,i){var s=this;if(!s._webAudio)return s;if(s._state!=="loaded")return s._queue.push({event:"stereo",action:function(){s.stereo(t,i)}}),s;var a=typeof Howler.ctx.createStereoPanner>"u"?"spatial":"stereo";if(typeof i>"u")if(typeof t=="number")s._stereo=t,s._pos=[t,0,0];else return s._stereo;for(var o=s._getSoundIds(i),c=0;c<o.length;c++){var u=s._soundById(o[c]);if(u)if(typeof t=="number")u._stereo=t,u._pos=[t,0,0],u._node&&(u._pannerAttr.panningModel="equalpower",(!u._panner||!u._panner.pan)&&e(u,a),a==="spatial"?typeof u._panner.positionX<"u"?(u._panner.positionX.setValueAtTime(t,Howler.ctx.currentTime),u._panner.positionY.setValueAtTime(0,Howler.ctx.currentTime),u._panner.positionZ.setValueAtTime(0,Howler.ctx.currentTime)):u._panner.setPosition(t,0,0):u._panner.pan.setValueAtTime(t,Howler.ctx.currentTime)),s._emit("stereo",u._id);else return u._stereo}return s},Howl.prototype.pos=function(t,i,s,a){var o=this;if(!o._webAudio)return o;if(o._state!=="loaded")return o._queue.push({event:"pos",action:function(){o.pos(t,i,s,a)}}),o;if(i=typeof i!="number"?0:i,s=typeof s!="number"?-.5:s,typeof a>"u")if(typeof t=="number")o._pos=[t,i,s];else return o._pos;for(var c=o._getSoundIds(a),u=0;u<c.length;u++){var f=o._soundById(c[u]);if(f)if(typeof t=="number")f._pos=[t,i,s],f._node&&((!f._panner||f._panner.pan)&&e(f,"spatial"),typeof f._panner.positionX<"u"?(f._panner.positionX.setValueAtTime(t,Howler.ctx.currentTime),f._panner.positionY.setValueAtTime(i,Howler.ctx.currentTime),f._panner.positionZ.setValueAtTime(s,Howler.ctx.currentTime)):f._panner.setPosition(t,i,s)),o._emit("pos",f._id);else return f._pos}return o},Howl.prototype.orientation=function(t,i,s,a){var o=this;if(!o._webAudio)return o;if(o._state!=="loaded")return o._queue.push({event:"orientation",action:function(){o.orientation(t,i,s,a)}}),o;if(i=typeof i!="number"?o._orientation[1]:i,s=typeof s!="number"?o._orientation[2]:s,typeof a>"u")if(typeof t=="number")o._orientation=[t,i,s];else return o._orientation;for(var c=o._getSoundIds(a),u=0;u<c.length;u++){var f=o._soundById(c[u]);if(f)if(typeof t=="number")f._orientation=[t,i,s],f._node&&(f._panner||(f._pos||(f._pos=o._pos||[0,0,-.5]),e(f,"spatial")),typeof f._panner.orientationX<"u"?(f._panner.orientationX.setValueAtTime(t,Howler.ctx.currentTime),f._panner.orientationY.setValueAtTime(i,Howler.ctx.currentTime),f._panner.orientationZ.setValueAtTime(s,Howler.ctx.currentTime)):f._panner.setOrientation(t,i,s)),o._emit("orientation",f._id);else return f._orientation}return o},Howl.prototype.pannerAttr=function(){var t=this,i=arguments,s,a,o;if(!t._webAudio)return t;if(i.length===0)return t._pannerAttr;if(i.length===1)if(typeof i[0]=="object")s=i[0],typeof a>"u"&&(s.pannerAttr||(s.pannerAttr={coneInnerAngle:s.coneInnerAngle,coneOuterAngle:s.coneOuterAngle,coneOuterGain:s.coneOuterGain,distanceModel:s.distanceModel,maxDistance:s.maxDistance,refDistance:s.refDistance,rolloffFactor:s.rolloffFactor,panningModel:s.panningModel}),t._pannerAttr={coneInnerAngle:typeof s.pannerAttr.coneInnerAngle<"u"?s.pannerAttr.coneInnerAngle:t._coneInnerAngle,coneOuterAngle:typeof s.pannerAttr.coneOuterAngle<"u"?s.pannerAttr.coneOuterAngle:t._coneOuterAngle,coneOuterGain:typeof s.pannerAttr.coneOuterGain<"u"?s.pannerAttr.coneOuterGain:t._coneOuterGain,distanceModel:typeof s.pannerAttr.distanceModel<"u"?s.pannerAttr.distanceModel:t._distanceModel,maxDistance:typeof s.pannerAttr.maxDistance<"u"?s.pannerAttr.maxDistance:t._maxDistance,refDistance:typeof s.pannerAttr.refDistance<"u"?s.pannerAttr.refDistance:t._refDistance,rolloffFactor:typeof s.pannerAttr.rolloffFactor<"u"?s.pannerAttr.rolloffFactor:t._rolloffFactor,panningModel:typeof s.pannerAttr.panningModel<"u"?s.pannerAttr.panningModel:t._panningModel});else return o=t._soundById(parseInt(i[0],10)),o?o._pannerAttr:t._pannerAttr;else i.length===2&&(s=i[0],a=parseInt(i[1],10));for(var c=t._getSoundIds(a),u=0;u<c.length;u++)if(o=t._soundById(c[u]),o){var f=o._pannerAttr;f={coneInnerAngle:typeof s.coneInnerAngle<"u"?s.coneInnerAngle:f.coneInnerAngle,coneOuterAngle:typeof s.coneOuterAngle<"u"?s.coneOuterAngle:f.coneOuterAngle,coneOuterGain:typeof s.coneOuterGain<"u"?s.coneOuterGain:f.coneOuterGain,distanceModel:typeof s.distanceModel<"u"?s.distanceModel:f.distanceModel,maxDistance:typeof s.maxDistance<"u"?s.maxDistance:f.maxDistance,refDistance:typeof s.refDistance<"u"?s.refDistance:f.refDistance,rolloffFactor:typeof s.rolloffFactor<"u"?s.rolloffFactor:f.rolloffFactor,panningModel:typeof s.panningModel<"u"?s.panningModel:f.panningModel};var p=o._panner;p||(o._pos||(o._pos=t._pos||[0,0,-.5]),e(o,"spatial"),p=o._panner),p.coneInnerAngle=f.coneInnerAngle,p.coneOuterAngle=f.coneOuterAngle,p.coneOuterGain=f.coneOuterGain,p.distanceModel=f.distanceModel,p.maxDistance=f.maxDistance,p.refDistance=f.refDistance,p.rolloffFactor=f.rolloffFactor,p.panningModel=f.panningModel}return t},Sound.prototype.init=function(t){return function(){var i=this,s=i._parent;i._orientation=s._orientation,i._stereo=s._stereo,i._pos=s._pos,i._pannerAttr=s._pannerAttr,t.call(this),i._stereo?s.stereo(i._stereo):i._pos&&s.pos(i._pos[0],i._pos[1],i._pos[2],i._id)}}(Sound.prototype.init),Sound.prototype.reset=function(t){return function(){var i=this,s=i._parent;return i._orientation=s._orientation,i._stereo=s._stereo,i._pos=s._pos,i._pannerAttr=s._pannerAttr,i._stereo?s.stereo(i._stereo):i._pos?s.pos(i._pos[0],i._pos[1],i._pos[2],i._id):i._panner&&(i._panner.disconnect(0),i._panner=void 0,s._refreshBuffer(i)),t.call(this)}}(Sound.prototype.reset);var e=function(t,i){i=i||"spatial",i==="spatial"?(t._panner=Howler.ctx.createPanner(),t._panner.coneInnerAngle=t._pannerAttr.coneInnerAngle,t._panner.coneOuterAngle=t._pannerAttr.coneOuterAngle,t._panner.coneOuterGain=t._pannerAttr.coneOuterGain,t._panner.distanceModel=t._pannerAttr.distanceModel,t._panner.maxDistance=t._pannerAttr.maxDistance,t._panner.refDistance=t._pannerAttr.refDistance,t._panner.rolloffFactor=t._pannerAttr.rolloffFactor,t._panner.panningModel=t._pannerAttr.panningModel,typeof t._panner.positionX<"u"?(t._panner.positionX.setValueAtTime(t._pos[0],Howler.ctx.currentTime),t._panner.positionY.setValueAtTime(t._pos[1],Howler.ctx.currentTime),t._panner.positionZ.setValueAtTime(t._pos[2],Howler.ctx.currentTime)):t._panner.setPosition(t._pos[0],t._pos[1],t._pos[2]),typeof t._panner.orientationX<"u"?(t._panner.orientationX.setValueAtTime(t._orientation[0],Howler.ctx.currentTime),t._panner.orientationY.setValueAtTime(t._orientation[1],Howler.ctx.currentTime),t._panner.orientationZ.setValueAtTime(t._orientation[2],Howler.ctx.currentTime)):t._panner.setOrientation(t._orientation[0],t._orientation[1],t._orientation[2])):(t._panner=Howler.ctx.createStereoPanner(),t._panner.pan.setValueAtTime(t._stereo,Howler.ctx.currentTime)),t._panner.connect(t._node),t._paused||t._parent.pause(t._id,!0).play(t._id,!0)}})()})(Pr);const za="data:audio/mpeg;base64,SUQzBAAAAAAAI1RTU0UAAAAPAAADTGF2ZjU4LjQxLjEwMAAAAAAAAAAAAAAA//NwwAAAAAAAAAAAAEluZm8AAAAPAAAAFAAACOAAICAgICwsLCwsNzc3NzdDQ0NDQ09PT09PW1tbW1tmZmZmZnJycnJyfn5+fn6KioqKipWVlZWVoaGhoaGtra2trbm5ubm5xcXFxcXQ0NDQ0Nzc3Nzc6Ojo6Oj09PT09P//////AAAAAExhdmM1OC43NQAAAAAAAAAAAAAAACQCwAAAAAAAAAjgTZykiAAAAAAAAAAAAAAAAAD/80DEABJhFmQCwwYUIDsKrsHAWBMRyeJYliQJBg5RYsWU/W3z/8OLc/3AAAQiIAIjv+7vUCJXd4jucQABAE3lwffiDBD+JC58oCH8H/1h/WH//1HPwTUMFrULH9ELKxULyTodFKYbO//zQsQRFFkScKDSRhyGWpIFpG91I7Fi/F6D2RWwN6TN/t9CiVSG5wMw74ogYcHoEwTFyMmTf4KkxEwmRfjXIYv1tpIOZRv/3O9ibtjR6gYmbGCgQ+Fk0mfSmybOX1cf78g7D6nP6qxCgf/zQMQbF+EacktaSABfy+3JKszHdMgcwwcl/kNFIuAo0I0DD1fWVs/crTSTTRInof3cmIwyLBwGQqCSLq7hyvtRPBB4aFyyXHov9X///7UXKqoIIcgcHict89/0y+n+nf/C0DIjB/+P//NCxBYZU9q0AYpoAHNyXSLn/+EjEbJclC4eJT//8e5aMAWeE4////wvAyAvYjZLjAD0Lg9D0kCU/////zwwBdJcYAehKBIwtYyx6FyXC4XP//////x7l83NDpfqd6gAcA/+wu9A2FGg//NAxAwXCnsq/5M4AhQKAOwmRvQRhjhOe5S8UkAmVHpU8IVU3lwejjIcayXOOceGwjf+D05I8oAu2x382o1ZHHV//31NU4441lmqcv///+RNGrUJKImnTf//iVYK1UZquoZESSy3egH/80LEChchBtMfyzAAk191v20qimbuNqavb211BthJKSJAG2aucbdLeVFVmRjZEVvzOggIwuUFDgvEZA7UeuUqNMLOraDQ5CVCk5m9BsmT3kbNrBdolcFSsqXGwQTWyYUX2wEDEgKkvZb/80DECRYRUpWsikYY1HXLbDZksYxtCHBShdHt/DgYCOM6r8AmUSpfGZYzH7ARMBCj1JtmY/hmwoGio0XBUShoklC5GsNeDR38RQ6d01DyrENtqp6mCJ5GJUckmpUBaIgYK6C0fPjmUf/zQsQLFil+cajTBhydxPRO4mLMWWSGQF2qa1f3PPlHQDJdzCxnwgkzB1SQohrpNRYRgtobv07tBLUFc27jQdWoQY0JNpiMJy654enBVoqnQR571uq/i9rpL1oAqAupJATLLk5L+QT3Kf/zQMQOE9D2bWFaGACZyWQZdt1rd3OVY8s/y2dBlg0m12PFzdFSlYrboY6gMOE1hJp7iFqmDcopF8F2OKEPnktdThRLoy9iuyj//0vD4+qf///++38OsIIFFhpEFZMC4s+gZmilJz1X//NCxBkaW8allZI4AWPWKBoLFWrwfuYvukbk4Rt9tBuJYOBoWpfzfjQaNMp//+OGEzzzDIif3+n/4PBIEt5hjDc9zxv/////nseeNDHGg0MQwxBEFn//////4TpB9d/s9thcHddpssFg//NAxAsVCT8GX5BAAigUAPBBdOBaKEIpaajR1VyCNH/gAwAfjRX8G7B4zfx0HANA8BpjQ6FhfqKxRBQURleGbrufzJywVGVfRdOzp5///ERCxhb//8wqijBAwUYMBCjVWZsv26uwYU3/80LEERRTIuTLwxABmdQgEBGKFNo9amfRWcpnayOUsKJ/UpWo/qyL////sj1b+pc3oarStSWpf/VP+hlotDN/0MVjKMKDAZGL/Ar8QWpCR0msAoVgrMoeT3xHIZd3qARkQge7hzlejQD/80DEGxPQ5sryeYYUBCI58AEvohe5nAMDcPxAbUxN6VCB4xCid97iaTyonF0l4upInmIpD//V0f/OllFls0vEBipVlYYRWhuzlHgpEiJSRmYJQaiptezfqvKm1PBRJKiq7M3s1yoqKv/zQsQmFBEGuojBkAQdCzTSpHY0FSwdboEQKi7pZN986g7UVOkf5ZR6VdbbQwZ+79PW6VoWdwZqA4VT2QGoxuuO0VZgbATjSNkSqqresUZ4lDGM5tfbuZzGHYfri5YKg0eDjgQjhm0Wpf/zQMQxE1jyoqhoxFD16D4jzQUUULEB1QXZhRIdIbHFtSlSvX5anFh11QTHaABkiBXOXoXxGW9galRr4fRiew3yOag/4HjxOydOM9ZyyokPlRKdFBa0CjY1luBiKXXwLw6oeMWEhjoS//NCxD4TUNKKIJpMJNTRh7nf/3kekmjdSWypy9UZXQgZMDh3pnAWB4O2M6nAaelR4r1OmVPFSwoksiWRUE1zc+f1lPc0ZudtdFDr4LLpoSwwGkpVO+oD6Tlb3HsYL7d+R1//td2LQMNF//NAxEwTaP5xYqJMCFlqIwAbEoCJNDEp9/3itYVbV6Yx/v0nuLdzyy50qHQw3cafmKlb6zBo0yXeRMnQG5J4jE7j4PFAkTSpQ9pexojMMsL0PIqP/Z1Xp/TpnVZZ27eWtNWRSSSyWyz/80LEWRSo1nDhWhgAlsstlkskgADyNOHqG5rlhLnSyI0a5oClU7uw0JnJQq2kTMBUYADEskGQ9wdHohh2xMKnCubKTIdyRgT83NEIrcfJpJOL3fV7l9cyXXJwJRDGpJLTZJF1+3OPUX3/80DEYiVyorJfmlgDRVRdYm21rHJXTVH0+ajd35ouiSF1tVcmLGnFummxbrhsXfHNzcf/2qgd/7XhppiSaYkmmQGRpnCsAMAEB4tQrXVA0VOiINSMWfljtMTHsRdZ3iL/V1neW6zvLf/zQsQnDSAiMFXMGADWd4i6zvEX+W/yzud5ZUxBTUUzLjEwMFVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVQ==";let Va=class{constructor(){this.sound=new Pr.Howl({src:[za]})}play(){this.sound.play()}};const xe=n=>{var e,t;if(typeof n.destroy=="function"){n.destroy();return}for(;n.children.length>0;)xe(n.children[0]),(e=n.children[0])==null||e.removeFromParent();if(n instanceof d.Mesh)try{(t=n.geometry)==null||t.dispose()}catch{}};function Ua(n){return new d.Vector3(n[0],n[1],n[2])}function Ha(){let n=3,e=Math.max(1/window.devicePixelRatio,.5);return window.innerWidth/window.innerHeight<.65&&(n=4,e=1/window.devicePixelRatio),{tiles:n,renderScale:e}}function Na(n){let e=!1,t=!1,i=!1,s=1/0,a=1/0,o=1/0,c=-1/0,u=-1/0,f=-1/0,p=0,r=0;return n.traverse(h=>{if(h.isMesh&&h.geometry){const g=h;if(g.userData.ignoreSize||g.material.userData.isLOGO)return;g.geometry.computeBoundingBox();let _=g.geometry.attributes.position;const m=g.geometry.morphAttributes.position;let v=g.morphTargetInfluences;const y=Object.keys(g.morphTargetDictionary||{});y.includes("width")&&(t=!0),y.includes("length")&&(e=!0),y.includes("height")&&(i=!0);for(let x=0;x<_.count;x++){let w=_.getX(x),b=_.getY(x),A=_.getZ(x);r=Math.max(b,r),m&&v&&m.forEach((I,C)=>{const P=v&&v[C]||0;w+=I.getX(x)*P,b+=I.getY(x)*P,A+=I.getZ(x)*P}),w<s&&(s=w),b<a&&(a=b),A<o&&(o=A),w>c&&(c=w),b>u&&(u=b),A>f&&(f=A);const T=Math.sqrt(w*w+b*b);T>p&&(p=T)}}}),{box:new d.Box3(new d.Vector3(s,a,o),new d.Vector3(c,u,f)),maxRadius:p,height:r,hasWidth:t,hasLength:e,hasHeight:i}}function Wa(n,e,t=null){let i=0;return function(){let s=t||this,a=arguments;clearTimeout(i),i=window.setTimeout(function(){n.apply(s,a)},e)}}class Ga{constructor(e,t,i){this.length=e,this.width=t,this.height=i}}const Gs=n=>{var i;let e=0,t=0;if(n.geometry){n.geometry.computeBoundingBox();const s=new d.Vector3;(i=n.geometry.boundingBox)==null||i.getSize(s),s.y?(t=s.y,!s.x&&s.z?e=s.z:s.x&&!s.z?e=s.x:s.x&&s.z&&(e=s.z)):(e=s.z,t=s.x)}return{width:e,height:t}};function us(){var e;if(typeof navigator>"u")return!1;if(qa())return!0;const n=(e=navigator.userAgent)==null?void 0:e.toLowerCase();return/iphone|ipad|ipod|android|mobile|blackberry|iemobile|opera mini/.test(n)}function qa(){try{if(typeof wx<"u"&&wx.getSystemInfo||typeof my<"u"&&my.alert||typeof tt<"u"&&tt.getSystemInfo||typeof swan<"u"&&swan.getSystemInfo)return!0}catch{}return!1}const Dr=new fn.GLTFExporter,Oe=new cn.GLTFLoader,ui=new un.DRACOLoader;let rt="./draco/";try{rt=new URL("./draco/",typeof document>"u"?require("url").pathToFileURL(__filename).href:at&&at.src||new URL("shop-components.cjs",document.baseURI).href).href}catch{rt="./draco/"}typeof window<"u"&&window.dracoPath&&(rt=window.dracoPath);ui.setDecoderConfig({type:"wasm"});ui.setDecoderPath(rt.endsWith("/")?rt:`${rt}/`);ui.preload();Oe.setDRACOLoader(ui);const ja=new hn.DRACOExporter,qs=[115,103,108,98];function Ya(n,e,t){const i=JSON.stringify(e),s=new TextEncoder().encode(i),a=new Uint8Array([115,103,108,98]),o=new Uint8Array(2);o[0]=t>>8,o[1]=t&255;const c=new Uint8Array(4);c[0]=s.length>>24,c[1]=s.length>>16&255,c[2]=s.length>>8&255,c[3]=s.length&255;const u=new Uint8Array(n),f=a.length+o.length+c.length+s.length+u.length,p=new Uint8Array(f);let r=0;return p.set(a,r),r+=a.length,p.set(o,r),r+=o.length,p.set(c,r),r+=c.length,p.set(s,r),r+=s.length,p.set(u,r),p.buffer}function Qa(n){const e=new Uint8Array(n.slice(0,4));let t=!0;for(let r=0;r<qs.length;r++)if(e[r]!==qs[r]){t=!1;break}if(!t)throw new Error("Invalid file format");const s=new DataView(n,4,2).getUint16(0,!1),o=new DataView(n,6,4).getUint32(0,!1),c=new Uint8Array(n.slice(10,10+o)),u=new TextDecoder().decode(c),f=JSON.parse(u),p=n.slice(10+o);return{version:s,jsonDescription:f,glbContent:p}}class ni{constructor(e){this.props=e,this.cache=new Map}load(e,t,i,s){if(this.props.useCache&&this.cache.has(e)){t(this.cache.get(e));return}const a=this;fetch(e).then(o=>{if(!o.ok){s==null||s(new ErrorEvent("NetworkError",{message:"NetworkError for "+e+": "+o.statusText}));return}return o.arrayBuffer()}).then(async o=>{o||s==null||s(new ErrorEvent("Error",{message:"Not a valid sglb file."}));try{const c=a.parse(o);if(!c.glbContent){s==null||s(new ErrorEvent("Error",{message:"No glb content."}));return}const u=Ni(c.glbContent,"model/gltf-binary"),f=await Oe.loadAsync(u);URL.revokeObjectURL(u),c.glbContent=void 0,c.glb=f.scene,o=void 0,this.cache.set(e,c),t(c)}catch(c){s==null||s(new ErrorEvent("Error",{message:c==null?void 0:c.message}))}}).catch(o=>{s==null||s(new ErrorEvent("Error",{message:o.message}))})}async loadAsync(e){if(this.props.useCache&&this.cache.has(e))return this.cache.get(e);try{const t=await fetch(e);if(!t.ok)throw new Error(`NetworkError for ${e}: ${t.statusText}`);const i=await t.arrayBuffer();if(!i)throw new Error("Not a valid sglb file.");const s=this.parse(i);if(!s.glbContent)throw new Error("No GLB content.");const a=Ni(s.glbContent,"model/gltf-binary");console.log(a);const o=await Oe.loadAsync(a);return URL.revokeObjectURL(a),s.glbContent=void 0,s.glb=o.scene,this.cache.set(e,s),s}catch(t){throw t}}parse(e){return Qa(e)}clear(){[...this.cache.values()]}}const Za=`*{box-sizing:border-box}.slot-item-container.is-mobile .main{pointer-events:none;border-width:1px;opacity:.8}.slot-item-container.is-mobile .main.focus{width:18px!important;height:18px!important;border-width:2px;opacity:1}.slot-item-container.is-mobile .main.filled{opacity:1;border-width:1px;width:14px!important;height:14px!important;background-image:none;border-radius:50%}.slot-item-container.is-mobile .main.to-be-installed{opacity:1;pointer-events:auto;width:38px!important;height:38px!important;border-color:#000;border-width:1px;background-image:url("data:image/svg+xml,%3csvg%20xmlns='http://www.w3.org/2000/svg'%20xmlns:xlink='http://www.w3.org/1999/xlink'%20fill='none'%20version='1.1'%20width='20'%20height='20'%20viewBox='0%200%2020%2020'%3e%3cg%3e%3cg%3e%3cpath%20d='M20,10.75L0,10.75L0,9.25L20,9.25L20,10.75Z'%20fill-rule='evenodd'%20fill='%23000000'%20fill-opacity='1'/%3e%3c/g%3e%3cg%20transform='matrix(0,1,1,0,10,-10)'%3e%3cpath%20d='M30,0.75L10,0.75L10,-0.75L30,-0.75L30,0.75Z'%20fill-rule='evenodd'%20fill='%23000000'%20fill-opacity='1'/%3e%3c/g%3e%3c/g%3e%3c/svg%3e");background-size:20px auto;background-repeat:no-repeat;background-position:center;background-color:#fff9}.slot-item-container.is-mobile .main.to-be-installed+.info{pointer-events:auto;overflow:visible;width:auto}.slot-item-container.is-mobile .main.to-be-installed.filled{opacity:1;border-width:2px;width:18px!important;height:18px!important;background-image:none;border-radius:50%;border-color:#00ff95}.slot-item-container.is-mobile .main.to-be-installed.to-be-replaced{opacity:1;border-width:1px;pointer-events:auto;width:38px!important;height:38px!important;border-radius:50%;background-image:url("data:image/svg+xml,%3csvg%20xmlns='http://www.w3.org/2000/svg'%20xmlns:xlink='http://www.w3.org/1999/xlink'%20fill='none'%20version='1.1'%20width='40'%20height='40'%20viewBox='0%200%2040%2040'%3e%3cdefs%3e%3cclipPath%20id='master_svg0_504_014299'%3e%3crect%20x='0'%20y='0'%20width='40'%20height='40'%20rx='20'/%3e%3c/clipPath%3e%3c/defs%3e%3cg%20clip-path='url(%23master_svg0_504_014299)'%3e%3cg%3e%3cg%3e%3cpath%20d='M31.695414,17L26.009501,10.74549544L24.899591,11.75450456L28.304586,15.5L8.75,15.5L8.75,17L31.695414,17Z'%20fill-rule='evenodd'%20fill='%23000000'%20fill-opacity='1'/%3e%3c/g%3e%3cg%3e%3cpath%20d='M8.3045862,23L13.9904997,29.2545042L15.10041,28.2454953L11.6954139,24.5L31.25,24.5L31.25,23L8.3045862,23Z'%20fill-rule='evenodd'%20fill='%23000000'%20fill-opacity='1'/%3e%3c/g%3e%3c/g%3e%3c/g%3e%3c/svg%3e");background-size:38px auto;border-color:#000}.slot-item-container.is-mobile .info{left:100%;margin-top:0;margin-left:4px}.slot-item-container.is-mobile .info .name-wrapper{margin-top:0;border-radius:0;background:#000;color:#fff}.slot-item-container.is-mobile .info>img{display:none}.slot-item-container .main{pointer-events:auto;cursor:pointer;font-size:12px;color:#fff;width:22px;height:22px;background:#fff0;border:1.5px solid #fff;border-radius:0;transition:background .2s,width .14s,height .14s,border .14s}.slot-item-container .main.disable{cursor:not-allowed}.slot-item-container .main.drag-over{border-color:red}.slot-item-container .main.can-install{position:relative;width:44px;height:44px;background:#0066ff1a;border-color:#06f}.slot-item-container .main.filled{border-color:#00ff95;border-radius:50%}.slot-item-container .main.selected{border-width:4px}.slot-item-container .main.selected+.info{pointer-events:auto;overflow:visible;width:auto}.slot-item-container .main.focus{border-color:#000}.slot-item-container .main.focus+.info{pointer-events:auto;overflow:visible;width:auto}.slot-item-container .main.has-error{border-color:red}.slot-item-container .main.hidden{display:none}.slot-item-container .main.hidden+.info{display:none}.slot-item-container .main:after{pointer-events:none;content:attr(data-name);transition:all .2s .3s;opacity:0;position:absolute;left:50%;bottom:100%;transform:translate3d(-50%,5px,0);white-space:nowrap;font-size:12px;color:#000;padding:2px 8px;border-radius:2px;background:#fff}.slot-item-container .main:hover{background:#ffffff80}.slot-item-container .main:hover+.info{pointer-events:auto;overflow:visible;width:auto}.slot-item-container .name{position:relative}.slot-item-container .name-wrapper{margin-top:-10px;white-space:nowrap;font-size:12px;color:#fff;padding:2px 8px;background:#000}.slot-item-container .functions-wrapper{z-index:20000;position:absolute;left:0;top:100%}.slot-item-container .functions-wrapper>.functions{display:inline-block;min-width:100px;padding:6px 0;border-left:1px solid #00ff95;border-radius:0 2px 2px 0;background:#0003;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px)}.slot-item-container .functions-wrapper>.functions .btn-add{cursor:pointer;padding:2px 0;margin:0 8px;display:flex;justify-content:center;align-content:center;align-items:center;border:1px dashed #eee;font-size:12px;color:#eee;border-radius:2px;-webkit-backdrop-filter:none;backdrop-filter:none;background:#00050a80}.slot-item-container .functions-wrapper>.functions .btn-add.btn-not-allowed{cursor:not-allowed}.slot-item-container .functions-wrapper>.functions .function{display:flex;justify-content:space-between;white-space:nowrap;margin-bottom:6px;padding:0 8px;font-size:12px;color:#fff}.slot-item-container .functions-wrapper>.functions .function span{margin-right:4px}.slot-item-container .functions-wrapper>.functions .function .btn-remove{pointer-events:none;opacity:0;cursor:pointer;align-self:center;margin-right:0;height:14px;width:14px;background:url(data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAABgAAAAYCAYAAADgdz34AAAAAXNSR0IArs4c6QAAAARzQklUCAgICHwIZIgAAACnSURBVEiJxZaxFcMgDETPTuUtWCWTM4pZAq5RojRpnOfEyEKxSnh3HySeBEhNjZJJTRgUG89GyZWilbKOgJCaKmWtFG2UvFnwQr56jYAcengg3dozELPGIjh96x6hu26/DIa9vD0jq/nUA3nikQEkAOW9nACUGbf7skxlX2mIj1Ob0jK76QdxbYpGFNlk3rPnNndDQltFaLMLbdehAyd8ZP5l6Ed+W17xG7oN9QkytAAAAABJRU5ErkJggg==) center no-repeat;background-size:10px 10px}.slot-item-container .functions-wrapper>.functions .function:hover .btn-remove{pointer-events:auto;opacity:1;transform:scale(1.2)}.slot-item-container .device-name{position:relative;margin:2px 0;display:flex;min-width:120px;align-items:center;align-content:center;justify-content:space-between;white-space:nowrap;height:30px;padding:0 8px;font-size:14px;font-weight:700;color:#000;background:#fff}.slot-item-container .device-name .device-logo{margin-left:-8px;margin-right:4px;width:30px;height:30px;object-fit:contain}.slot-item-container .device-name span{display:block;white-space:nowrap;text-overflow:ellipsis;overflow:hidden;max-width:250px}.slot-item-container .device-name .btn-close{margin-left:8px;cursor:pointer;height:20px;width:20px;background:url("data:image/svg+xml,%3csvg%20xmlns='http://www.w3.org/2000/svg'%20xmlns:xlink='http://www.w3.org/1999/xlink'%20fill='none'%20version='1.1'%20width='20'%20height='20'%20viewBox='0%200%2020%2020'%3e%3cdefs%3e%3cclipPath%20id='master_svg0_504_017509'%3e%3crect%20x='0'%20y='0'%20width='20'%20height='20'%20rx='0'/%3e%3c/clipPath%3e%3c/defs%3e%3cg%20clip-path='url(%23master_svg0_504_017509)'%3e%3cg%3e%3cpath%20d='M4.375,16.875L4.375,4.375L15.625,4.375L15.625,16.875L4.375,16.875ZM14.375,5.625L5.625,5.625L5.625,15.625L14.375,15.625L14.375,5.625Z'%20fill-rule='evenodd'%20fill='%23999999'%20fill-opacity='1'/%3e%3c/g%3e%3cg%3e%3cpath%20d='M8.125,12.1875L8.125,8.125L9.375,8.125L9.375,12.1875L8.125,12.1875Z'%20fill-rule='evenodd'%20fill='%23999999'%20fill-opacity='1'/%3e%3c/g%3e%3cg%3e%3cpath%20d='M10.625,12.1875L10.625,8.125L11.875,8.125L11.875,12.1875L10.625,12.1875Z'%20fill-rule='evenodd'%20fill='%23999999'%20fill-opacity='1'/%3e%3c/g%3e%3cg%3e%3cpath%20d='M16.875,5.625L3.125,5.625L3.125,4.375L16.875,4.375L16.875,5.625Z'%20fill-rule='evenodd'%20fill='%23999999'%20fill-opacity='1'/%3e%3c/g%3e%3cg%3e%3cpath%20d='M6.4446528999999995,5.625L13.545177899999999,5.625L11.8665838,2.5L8.15767372,2.5L6.4446528999999995,5.625ZM11.4548223,4.3749999L8.5553472,4.3749999L8.8979512,3.75L11.1191032,3.75L11.4548223,4.3749999Z'%20fill-rule='evenodd'%20fill='%23999999'%20fill-opacity='1'/%3e%3c/g%3e%3c/g%3e%3c/svg%3e") center no-repeat;background-size:100% auto}.slot-item-container .device-name.empty{color:#000c;font-weight:400}.slot-item-container .device-name.empty .btn-close{display:none}.slot-item-container .device-name.empty:before{height:0}.slot-item-container .all-functions{opacity:0;pointer-events:none;min-width:80px;position:absolute;left:-10px;margin-left:100%;bottom:0;padding:6px 0;background:#fff;transition:all .3s}.slot-item-container .all-functions.show{opacity:1;pointer-events:auto;left:16px}.slot-item-container .all-functions label{margin-left:8px;margin-bottom:20px;color:#444e69;font-size:14px}.slot-item-container .all-functions .btn-close{cursor:pointer;position:absolute;right:7px;top:7px;height:16px;width:16px;background:url(data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAABAAAAAQCAYAAAAf8/9hAAAAAXNSR0IArs4c6QAAAARzQklUCAgICHwIZIgAAAB4SURBVDiNpZPLEYAgDAUXe6MuoK4UpwdBwQkQJDcyb9+QnxORCOC9jyxE4Y78DiWxAIcmISKnxaSrtZhMNSOB+ZeacAS7ngl3k1JOBSBpk1INPib0YHjH+Du2S1DhlSZOYbPJ1iLtrLKrG2a9yJopYzTD8Jx+ArgAylOzjm1WpDwAAAAASUVORK5CYII=) center no-repeat;background-size:10px 10px}.slot-item-container .all-functions .functions{display:inline-block;max-height:200px;overflow-x:hidden;overflow-y:auto}.slot-item-container .all-functions .functions::-webkit-scrollbar{width:4px}.slot-item-container .all-functions .functions::-webkit-scrollbar-track{background-color:#fff}.slot-item-container .all-functions .functions::-webkit-scrollbar-thumb{background:#787878;border-radius:25px}.slot-item-container .all-functions .function{display:flex;justify-content:space-between;white-space:nowrap;padding:5px 10px;font-size:12px;color:#787878}.slot-item-container .all-functions .function span{display:flex;align-content:center;align-items:center;margin-right:4px}.slot-item-container .all-functions .function:hover{background:#444e6933}.slot-item-container .all-functions .btn-add{cursor:pointer;width:16px;font-size:16px;text-align:center;font-style:normal}.slot-item-container .info{overflow:hidden;margin-left:-2px;margin-top:-19px;position:absolute;left:100%;top:50%;transform:translateY(-50%);width:0;display:flex;align-items:flex-start;transition:all .3s}.slot-item-container .info>img{flex:0 0 auto;width:53px;height:29px}`,Xa="data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAAGsAAAA7CAYAAAB8MXT7AAAAAXNSR0IArs4c6QAAAARzQklUCAgICHwIZIgAAAGTSURBVHic7dxLbQNBEIThnigADGEhxAwcBoZgCIZgBoZgCIZgCIaQMIgZVC4daw/xXPLoqdX/3fbW0milUtfutMCdpCkiLhEx1U6CLkkvkt4k7atnQYekfR7US/Us6JB0yIOaqmfBA5JWks6SrhzUwCRN+TYdq2dBx+ygDtWzoEPSNg9qVz0LOmZBgsQ3sqUkvufqAf6SpFVEnCPiFhHr1tqteCR8hyBhYrY6OlTPgo5cHX1I2lbPgo6lBInFk3Rc+uroqXqAn8ogcc3H19bae+U8eIDEZ0LSJoMEZeHIWB2ZIPEZoCw0QVlogsRnYlYWsjoaGUHCRK6OOKiRfa2OMvWtqufBAwQJE5SFJmZl4aZ6FnSQ+Azk6mjxZeFv+/fycfbDWrTW1pSFgyLxmcjVEWXh6CgLTZD4DMzKwguro4ERJEywOjIhaUdZaIAgYYKy0ABloQkSnwlxKZUHcSmVBxKfgVwdnSgLB8d35iZIfCYoC01QFpog8Y3rftFWrotO+cilVKMiSJigLDSS30hQFhr4BEcKZN0LNhDxAAAAAElFTkSuQmCC",js={name:"",isMobile:!1},Ka={"&":"&amp;","<":"&lt;",">":"&gt;",'"':"&quot;","'":"&#39;"};function _t(n){return n==null?"":String(n).replace(/[&<>"']/g,e=>Ka[e])}function Ys(...n){return n.filter(Boolean).join(" ")}class Lr extends HTMLElement{constructor(e){super(),this._size=12,this._showDialog=!1,this._selected=!1,this._focused=!1,this._toBeInstalled=!1,this._toBeReplaced=!1,this._hasError=!1,this._canInstall=!1,this._hide=!1,this._disable=!1,this._filled=!1,this._allFunctions=[],this._functions=[],this._deviceName="",this._deviceLogo="",this._renderQueued=!1,this._needsRender=!0,this.attachShadow({mode:"open"}),this._props={...js,...e??{}},this.handleShadowClick=this.handleShadowClick.bind(this),this.shadowRoot.addEventListener("click",this.handleShadowClick),this.render()}connectedCallback(){this._needsRender&&(this._needsRender=!1,this.render())}get props(){return this._props}set props(e){this._props={...js,...e},this.scheduleRender()}get slot(){return this._slot}set slot(e){this._slot=e,this.scheduleRender()}get selected(){return this._selected}set selected(e){const t=!!e;this._selected!==t&&(this._selected=t,this.scheduleRender())}get focused(){return this._focused}set focused(e){const t=!!e;this._focused!==t&&(this._focused=t,this.scheduleRender())}get toBeInstalled(){return this._toBeInstalled}set toBeInstalled(e){const t=!!e;this._toBeInstalled!==t&&(this._toBeInstalled=t,this.scheduleRender())}get toBeReplaced(){return this._toBeReplaced}set toBeReplaced(e){const t=!!e;this._toBeReplaced!==t&&(this._toBeReplaced=t,this.scheduleRender())}get hasError(){return this._hasError}set hasError(e){const t=!!e;this._hasError!==t&&(this._hasError=t,this.scheduleRender())}get canInstall(){return this._canInstall}set canInstall(e){var s;const t=!!e,i=(s=this.shadowRoot)==null?void 0:s.querySelector(".main");if(i){e?i.classList.add("can-install"):i.classList.remove("can-install");return}this._canInstall!==t&&(this._canInstall=t,this.scheduleRender())}get hide(){return this._hide}set hide(e){const t=!!e;this._hide!==t&&(this._hide=t,this.scheduleRender())}get disable(){return this._disable}set disable(e){const t=!!e;this._disable!==t&&(this._disable=t,this.scheduleRender())}get filled(){return this._filled}set filled(e){var s;const t=!!e,i=(s=this.shadowRoot)==null?void 0:s.querySelector(".main");if(i){e?i.classList.add("filled"):i.classList.remove("filled");return}this._filled!==t&&(this._filled=t,this.scheduleRender())}get allFunctions(){return[...this._allFunctions]}set allFunctions(e){this._allFunctions=Array.isArray(e)?[...e]:[],this.hasMoreFunctions||(this._showDialog=!1),this.scheduleRender()}get functions(){return[...this._functions]}set functions(e){this._functions=Array.isArray(e)?[...e]:[],this.hasMoreFunctions||(this._showDialog=!1),this.scheduleRender()}get deviceName(){return this._deviceName}set deviceName(e){this._deviceName=e??"",this.scheduleRender()}get deviceLogo(){return this._deviceLogo}set deviceLogo(e){this._deviceLogo=e??"",this.scheduleRender()}get hasMoreFunctions(){return this._allFunctions.some(e=>!this._functions.includes(e))}setSize(e=12){var s;const t=Number.isFinite(e)?Number(e):12,i=(s=this.shadowRoot)==null?void 0:s.querySelector(".main");if(i){i.style.width=i.style.height=`${e}px`;return}this._size!==t&&(this._size=t,this.scheduleRender())}removeDevice(){var e,t;this._showDialog=!1,this.scheduleRender(),(t=(e=this._props).onRemove)==null||t.call(e)}addFunction(e){this.dispatchEvent(new CustomEvent("function-added",{detail:e}))}scheduleRender(){if(!this.isConnected){this._needsRender=!0;return}this._renderQueued||(this._renderQueued=!0,queueMicrotask(()=>{this._renderQueued=!1,this.render()}))}render(){var p;if(!this.shadowRoot)return;const e=Ys("slot-item-container",this._props.isMobile&&"is-mobile"),t=Ys("main",this._selected&&"selected",this._focused&&"focus",this._toBeInstalled&&"to-be-installed",this._toBeReplaced&&"to-be-replaced",this._hasError&&"has-error",this._canInstall&&"can-install",this._hide&&"hidden",this._disable&&"disable",this._filled&&"filled"),i=this._functions.map(r=>{const l=_t(r);return`<div class="function" data-function="${l}"><span>${l}</span><i class="btn btn-remove" data-action="remove-function" data-function="${l}"></i></div>`}).join(""),s=this._allFunctions.filter(r=>!this._functions.includes(r)),a=this._allFunctions.length?`<div class="functions">${i}${`<div class="btn btn-add ${this.hasMoreFunctions?"":"btn-not-allowed"}" data-action="toggle-dialog">+添加</div>`}</div>`:"",o=s.length?`<div class="all-functions ${this._showDialog?"show":""}">
3707
3707
  <label>添加功能<i class="btn btn-close" data-action="toggle-dialog"></i></label>
3708
3708
  <div class="functions">
3709
3709
  ${s.map(r=>{const l=_t(r);return`<div class="function"><span>${l}</span><i class="btn btn-add" data-action="add-function" data-function="${l}">+</i></div>`}).join("")}
@@ -3728,7 +3728,7 @@ ${t.name}`)}break}}}}else a.texture_lod=0}};J=new WeakMap,ve=new WeakMap,ai=new
3728
3728
  </div>
3729
3729
  </div>
3730
3730
  </div>
3731
- `,this._needsRender=!1}handleShadowClick(e){const t=e.target;if(!t)return;t.closest(".info")&&(e.preventDefault(),e.stopPropagation());const i=t.closest("[data-action]");if(!i)return;const s=i.getAttribute("data-action");if(s)switch(e.preventDefault(),e.stopPropagation(),s){case"remove-device":this.removeDevice();break;case"remove-function":{const a=i.getAttribute("data-function");a&&this.dispatchEvent(new CustomEvent("function-removed",{detail:a}));break}case"toggle-dialog":if(!this.hasMoreFunctions)return;this._showDialog=!this._showDialog,this.scheduleRender();break;case"add-function":{const a=i.getAttribute("data-function");a&&(this.dispatchEvent(new CustomEvent("function-added",{detail:a})),this._showDialog=!1,this.scheduleRender());break}}}}customElements.get("slot-item")||customElements.define("slot-item",Dr);const q={ON_DROP:"slot-on-drop",ON_DEVICE_DELETED:"slot-on-device-deleted",ON_DEVICE_REPLACED:"slot-on-device-replaced",ON_BEFORE_SELECTED:"slot-on-before-selected",ON_SELECTED:"slot-on-selected",ON_ADD_BUTTON_CLICKED:"slot-add-button-clicked",ON_DEVICE_SELECTED:"slot-on-device-selected",ON_DROP_ERROR:"slot-on-drop-error",ON_ERROR_STATE_CHANGE:"slot-on-error-state-change",ON_FUNCTION_REMOVED:"slot-on-function-removed",ON_FUNCTION_ADDED:"slot-on-function-added"};class Wi extends fe.CSS2DObject{constructor(e){const t=document.createElement("div");super(t),this.props=e,this._emitter=new ct,this._slotContainer=new d.Group,this._bracketSlots=[],this._hasError=!1,this.useBracket=!1,this.addEventListener=this._emitter.addListener.bind(this._emitter),this.removeEventListener=this._emitter.removeListener.bind(this._emitter),this._canInstall=!1,this._loading=!1,this._selected=!1,this._deviceSelected=!1,this._focused=!1,this._toBeInstalled=!1,this._toBeReplaced=!1,this._allFunctions=new Set,this._functions=new Set,this._timer=0,this._parentPos=new d.Vector3,this._wrapper=new d.Group,this._showSlot=!0,this._isMirror=!1,this._preventDefaults=i=>{i.preventDefault(),i.stopPropagation()},this.getWP=this._slotContainer.getWorldPosition.bind(this._slotContainer),this._showSlot=typeof e.show=="boolean"?e.show:!0,this.name=e.name,this._isMirror=e.isMirror,this._slotUI=new Dr({name:e.name,isMobile:e.isMobile,onRemove:()=>{this.clearSlot(),this._emitter.emit(q.ON_DEVICE_DELETED)}}),this._slotUI.slot=this,this._slotUI.hide=!this._showSlot||this.isMirror,t.append(this._slotUI),this._parentPos.copy(this.props.slot.position),this._slotUI.addEventListener("function-removed",({detail:i})=>{this.removeFunction(i)}),this._slotUI.addEventListener("function-added",({detail:i})=>{this.addFunction(i)}),this.add(this._slotContainer),this.props.slot.add(this),setTimeout(()=>{var i;(i=this.props.slot.parent)==null||i.add(this._wrapper),this._wrapper.add(this.props.slot)},10),["dragenter","dragover","dragleave","drop"].forEach(i=>{t.addEventListener(i,this._preventDefaults,!1)}),t.addEventListener("click",i=>{i.preventDefault(),i.stopPropagation(),this.toBeInstalled?this._emitter.emit(q.ON_ADD_BUTTON_CLICKED):this.selected=!this.selected}),t.addEventListener("dragover",i=>{if(i.preventDefault(),i.dataTransfer.dropEffect="copy",!this._canInstall){i.dataTransfer&&(i.dataTransfer.dropEffect="none");return}}),t.addEventListener("drop",async i=>{var a;if(i.preventDefault(),i.stopPropagation(),!this._canInstall)return;const s=(a=i.dataTransfer)==null?void 0:a.getData("application/json");if(s){const o=JSON.parse(s);try{await this.install(o),this._emitter.emit(q.ON_DROP,this)}catch(c){this._emitter.emit(q.ON_DROP_ERROR,c)}}else this._emitter.emit(q.ON_DROP_ERROR,new Error("No device info"))})}get hasDevice(){return this._slotContainer.children.length>0}get isMirror(){return this._isMirror}shapeKeyChanged(e,t){var i;if(this.props.follows.has(e)){const s=this.props.follows.get(e);if(s){let a="x";["height","mast"].includes(e)?a="y":["width","liftOuterWidth"].includes(e)&&(a="z");const o=((i=this.props.slot)==null?void 0:i.position[a])>0?1:-1;this._wrapper.position[a]=(t-s.origin)*s.scale*o}}}async loadGlb(e){const i=await new ni({useCache:!0}).loadAsync(e);if(i.glb)return i.glb.clone(!0)}async installBracket(e){const i=await new ni({useCache:!0}).loadAsync(e);if(!i.glb)return;const s=i.glb.clone(!0);s.traverse(a=>{a.userData.isBracket=!0}),this.useBracket=!0,this._slotContainer.add(s)}async install(e){if(!this._loading){this._loading=!0;try{const t=await this.loadGlb(e.url);if(!t)throw new Error(`Fail to load device from: ${e.url}`);if(t.traverse(i=>{i.userData.isDevice=!0}),this.isMirror&&t.scale.set(1,1,-1),e.bracketUrl){const i=await this.loadGlb(e.bracketUrl);if(i)this.clearSlot(),this._emitter.emit(q.ON_DEVICE_REPLACED),i.traverse(s=>{s.name.startsWith("Slot")&&this._bracketSlots.push(s),s.userData.isBracket=!0}),this._slotContainer.add(i);else throw new Error(`Fail to load bracket from: ${e.bracketUrl}`);this._bracketSlots.forEach(s=>{s.add(t)})}else this.clearSlot(),this._emitter.emit(q.ON_DEVICE_REPLACED),this._slotContainer.add(t);this.mirrorTarget&&this.mirrorTarget.install(e),this.deviceInfo=e,this._slotUI.deviceLogo=e.logo||"",this._slotUI.deviceName=e.name,this._slotUI.filled=!0,this.holeTarget&&(this.holeTarget.visible=!1)}catch(t){throw t}finally{this._loading=!1}}}get device(){return this._slotContainer.children.length?this._slotContainer.children[0]:null}get allFunctions(){return[...this._allFunctions]}set allFunctions(e){this._functions.forEach(t=>{e.includes(t)||this._functions.delete(t)}),this._allFunctions=new Set(e),this._slotUI.allFunctions=e}get functions(){return[...this._functions]}addFunction(e){this._allFunctions.has(e)&&(this._functions.add(e),this._slotUI.functions=[...this.functions],this._emitter.emit(q.ON_FUNCTION_ADDED,e))}removeFunction(e){this._functions.has(e)&&(this._functions.delete(e),this._slotUI.functions=[...this.functions],this._emitter.emit(q.ON_FUNCTION_REMOVED,e))}clearFunctions(){this._functions.forEach(e=>this.removeFunction(e))}addFunctions(e){e.forEach(t=>this.addFunction(t)),this._slotUI.functions=this.functions}changeName(e){var t;this.name=e,this.props.slot.userData.name=e,this.props.name=e,(t=this.element)==null||t.setAttribute("data-name",this.props.name)}clearSlot(){this._bracketSlots=[],this._slotContainer.children.forEach(e=>{e.removeFromParent(),xe(e)}),this._slotUI.filled=!1,this.deviceInfo=void 0,this._slotUI.deviceName="",this._slotUI.deviceLogo="",this.holeTarget&&(this.holeTarget.visible=!0),this.mirrorTarget&&this.mirrorTarget.clearSlot()}get disabled(){return this._slotUI.disable}enable(){this.show(),this._slotUI.disable=!1}disable(){this._slotUI.disable=!0,this.hide()}hide(){this._slotUI.hide=!0}show(){this.isMirror||this.disabled||(this._slotUI.hide=!1)}get selected(){return this._selected}get focused(){return this._focused}set focused(e){this._focused=e,this._slotUI.focused=e}get toBeInstalled(){return this._toBeInstalled}set toBeInstalled(e){this._toBeInstalled=e,this._slotUI.toBeInstalled=e}get toBeReplaced(){return this._toBeReplaced}set toBeReplaced(e){this._toBeReplaced=e,this._slotUI.toBeReplaced=e}set selected(e){this.disabled||(e&&this._emitter.emit(q.ON_BEFORE_SELECTED,e),this._selected=e,this._slotUI.selected=e,this._emitter.emit(q.ON_SELECTED,e),this.element.style.zIndex="100",this.selected?this.renderOrder=1/0:this.renderOrder=1)}get deviceSelected(){return this._deviceSelected}set deviceSelected(e){this._deviceSelected=e,this._emitter.emit(q.ON_DEVICE_SELECTED,e)}get error(){return this._hasError}set error(e){this._loading&&setTimeout(()=>{this.error=e},100),this._hasError=e,this._slotUI.hasError=e,this._emitter.emit(q.ON_ERROR_STATE_CHANGE,e)}getCanInstall(){return this._canInstall}canInstall(e){this._canInstall=e,this._slotUI.canInstall=e}dispose(){cancelAnimationFrame(this._timer),["dragenter","dragover","dragleave","drop"].forEach(e=>{this.element.addEventListener(e,this._preventDefaults,!1)}),this.clearSlot(),this._emitter.removeAllListeners(),xe(this._slotContainer),this.element.remove()}render(e){const t=this.element.style.transform,i=/translate\(-?\d*\.?\d*%?,?\s-?\d*\.?\d*%?\)\s*translate\((-?\d*\.?\d*)px,\s*(-?\d*\.?\d*)px\)/.exec(t);if(!i)return;const s=new d.Vector2(parseFloat(i[1]),parseFloat(i[2])),a=e.mousePos.distanceTo(s);let o=this.props.isMobile?12:18,c=38,u=30;if(this._canInstall&&(o=34,c=60,u=60),a<u){let f=(u-a)*1+o;a<20&&(f=c),f>c&&(f=c),this._slotUI.setSize(f)}else this._slotUI.setSize(o)}clone(e){return new d.Group}}class Ja extends fe.CSS2DObject{constructor(e){const t=document.createElement("div");super(t),this._text=document.createElement("div");const i=cs(),s=i?"#ddd":"#eee";this.element.style.pointerEvents="auto",this.element.style.padding=i?"2px 6px":"3px 12px",this.element.style.borderTop=`1px solid ${s}`,this.element.style.borderBottom=this.element.style.borderTop;const a="6px",o=document.createElement("div");o.style.pointerEvents="none",Object.assign(o.style,{pointerEvents:"none",borderLeft:`1px solid ${s}`,borderRight:`1px solid ${s}`,position:"absolute",left:"0",top:"0",boxSizing:"border-box",height:a,width:"100%"}),this.element.append(o);const c=document.createElement("div");c.style.pointerEvents="none",Object.assign(c.style,{pointerEvents:"none",borderLeft:`1px solid ${s}`,borderRight:`1px solid ${s}`,position:"absolute",left:"0",bottom:"0",boxSizing:"border-box",height:a,width:"100%"}),this.element.append(c),this._text.style.fontSize=i?"10px":"14px",this._text.style.font="SF Pro SC,SF Pro Text,SF Pro Icons,PingFang SC,Helvetica Neue,Helvetica,Arial,sans-serif",this._text.style.color="#fff",this._text.style.fontWeight="500",this._text.style.transition="all .16s",this._text.innerText=e,this.element.append(this._text),this._text.addEventListener("pointermove",()=>{var u;o.style.borderColor=c.style.borderColor=this.element.style.borderColor="#666",this._text.style.color="#000",(u=this.onPointMove)==null||u.call(this)}),this._text.addEventListener("pointerleave",()=>{var u;o.style.borderColor=c.style.borderColor=this.element.style.borderColor=s,this._text.style.transform="scale(1)",this._text.style.color="#fff",(u=this.onPointLeave)==null||u.call(this)})}set text(e){this._text.innerText=e}dispose(){this.element&&this.element.parentNode&&this.element.parentNode.removeChild(this.element)}}class ti extends d.Group{constructor(e,t=!0,i=!0){super(),this._startWith=e,this._showText=t,this.useStartEnd=i,this._line2Length=.01,this._line=new d.LineSegments(new d.BufferGeometry,new d.LineBasicMaterial({color:"#666",linewidth:2})),this._line2=new d.LineSegments(new d.BufferGeometry,new d.LineBasicMaterial({color:"#666",linewidth:2})),this._text=new Ja(""),this._line.frustumCulled=!1,this.add(this._line,this._line2),this._showText&&(this.add(this._text),this._text.onPointMove=()=>{this._line.material.color.set("#000"),this._line2.material.color.set("#000")},this._text.onPointLeave=()=>{this._line.material.color.set("#666"),this._line2.material.color.set("#666")})}updateMaterial(e){this._line.material=e}reset(){var e;(e=this._line.geometry)==null||e.dispose(),this._line.computeLineDistances()}update(e,t,i=0){var h,g;(h=this._line.geometry)==null||h.dispose(),this._line.geometry.setFromPoints([e,t]),this._line.computeLineDistances();const s=this._line2Length+i*.02,a=new d.Vector3().subVectors(t,e).normalize();let o;Math.abs(a.z)>Math.abs(a.x)&&Math.abs(a.z)>Math.abs(a.y)?o=new d.Vector3(-a.y,a.x,0):Math.abs(a.y)>Math.abs(a.x)?o=new d.Vector3(1,0,0):o=new d.Vector3(0,1,0),o.length()<.001&&(Math.abs(a.x)<.9?o=new d.Vector3(1,0,0):o=new d.Vector3(0,1,0)),o.normalize();const c=new d.Vector3().addVectors(e,o.clone().multiplyScalar(s)),u=new d.Vector3().addVectors(e,o.clone().multiplyScalar(-s)),f=new d.Vector3().addVectors(t,o.clone().multiplyScalar(s)),p=new d.Vector3().addVectors(t,o.clone().multiplyScalar(-s));(g=this._line2.geometry)==null||g.dispose(),this._line2.geometry=new d.BufferGeometry,this._line2.geometry.setFromPoints([c,u,f,p]),this._line2.computeLineDistances();const r=e.distanceTo(t);this._startWith?this._text.text=`${this._startWith}${(r*1e3).toFixed(0)} mm`:this._text.text=`${(r*1e3).toFixed(0)} mm`;const l=new d.Vector3;l.addVectors(e,t).multiplyScalar(.5),this._text.position.copy(l),this.useStartEnd||(this._line2.visible=!1)}destroy(){this._text.dispose(),this.children.forEach(e=>xe(e)),this.removeFromParent()}}class Lr extends d.Object3D{constructor(e,t){super(),this.radius=e,this._text=new $a(""),this._line=new ti(void 0,!1,!1),this._box=new d.Mesh,this._arc=new dn.Line2,this._previousPosition=null,this._updateTimer=null,this._updateDelay=300,this._accumulatedAngle=0,this._lastAngle=null,this._line.updateMaterial(new d.LineDashedMaterial({color:"#555",dashSize:.06,gapSize:.06})),this._line.renderOrder=0,this._box.geometry=new d.RingGeometry(e,e+.003,128),this._box.material=new d.MeshBasicMaterial({color:"#666",side:d.DoubleSide}),this._arc.geometry=new vs.LineGeometry,this._arc.geometry.setPositions([0,0,0,0,0,0]),this._arc.geometry.instanceCount=0,this._arc.material=new pn.LineMaterial({color:"#eee",linewidth:2,resolution:new d.Vector2(window.innerWidth,window.innerHeight)}),this._arc.visible=!1,this._arc.rotateX(-Math.PI/2),this.position.y=t,this._arc.position.y=.001,this.add(this._box),this.add(this._arc),this.add(this._line),this.add(this._text)}hide(){this._text.hide(),this._line.visible=!1,this._arc.visible=!1}show(){this._text.show(),this._line.visible=!0}dispose(){this._updateTimer&&(clearTimeout(this._updateTimer),this._updateTimer=null),this._box.geometry&&this._box.geometry.dispose(),this._arc.geometry&&this._arc.geometry.dispose(),this._arc.visible=!1,this._previousPosition=null}update(e){var t;this.radius=e,(t=this._box.geometry)==null||t.dispose(),this._box.geometry=new d.RingGeometry(e,e+.003,128),this._line.updateMaterial(new d.LineDashedMaterial({color:"#555",dashSize:.06*e,gapSize:.06*e})),this._text.update((e*1e3).toFixed(0))}change(e){const t=e.clone();t.setZ(0),t.normalize().multiplyScalar(this.radius),this._text.position.set(t.x,t.y,t.z),this._text.updateColor("#eee"),this._line.update(t,new d.Vector3),this._previousPosition&&this._updateArc(this._previousPosition,t),this._updateTimer&&clearTimeout(this._updateTimer),this._updateTimer=setTimeout(()=>{this._previousPosition=null,this._accumulatedAngle=0,this._lastAngle=null,this._clearArc(),this._updateTimer=null},this._updateDelay),this._previousPosition||(this._previousPosition=t.clone(),this._lastAngle=Math.atan2(t.y,t.x),this._accumulatedAngle=0)}_updateArc(e,t){const i=Math.atan2(t.y,t.x);if(this._lastAngle!==null){let u=i-this._lastAngle;u>Math.PI?u-=2*Math.PI:u<-Math.PI&&(u+=2*Math.PI),this._accumulatedAngle+=u}if(this._lastAngle=i,Math.abs(this._accumulatedAngle)<.01){this._arc.visible=!1;return}const s=Math.atan2(e.y,e.x),a=s+this._accumulatedAngle;let o=.006*this.radius;o<.003&&(o=.003),o>.006&&(o=.006);const c=this._createArcGeometry(s,a,this.radius+o);this._arc.geometry&&this._arc.geometry.dispose(),this._arc.geometry=c,this._arc.visible=!0}_clearArc(){this._text.updateColor(),this._arc.geometry&&(this._arc.geometry.setPositions([0,0,0,0,0,0]),this._arc.geometry.instanceCount=0,this._arc.computeLineDistances()),this._arc.visible=!1}_createArcGeometry(e,t,i){const s=[],a=t-e,o=Math.max(128,Math.floor(Math.abs(a)/(Math.PI/128))),c=a/o;for(let f=0;f<=o;f++){const p=e+f*c,r=Math.cos(p),l=Math.sin(p);s.push(i*r,0,i*l)}const u=new vs.LineGeometry;return u.setPositions(s),u.instanceCount=Math.max(0,s.length/3-1),u}}class $a extends fe.CSS2DObject{constructor(e){const t=document.createElement("div");super(t),this._wrapper=document.createElement("div"),this._circle=document.createElement("div");const i=cs();this._wrapper.style.fontSize=i?"10px":"11px",this._wrapper.style.color="#fff",this._wrapper.style.whiteSpace="nowrap",this._wrapper.style.position="absolute",this._wrapper.style.transform="translateX(-50%)",this._wrapper.style.top="6px",this._wrapper.style.font="SF Pro SC,SF Pro Text,SF Pro Icons,PingFang SC,Helvetica Neue,Helvetica,Arial,sans-serif";const s=this._circle;s.style.position="relative",s.style.zIndex="10",s.style.width=s.style.height="5px",s.style.borderRadius="50%",s.style.background="#666",t.append(this._wrapper,s),this.update(e)}show(){this.element.style.display="block"}hide(){this.element.style.display="none"}update(e){this._wrapper.innerText="旋转半径:"+e+" mm",this.updateColor("#eee")}updateColor(e="#666"){this._circle.style.background=e}}const el="data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAADgAAAAUCAYAAADY6P5TAAAAAXNSR0IArs4c6QAAAARzQklUCAgICHwIZIgAAAEvSURBVFiFzZdbFYMwEEQroRKQgAQkVEIlICEOkFAJlRAJSIgEJNx+sPS0nGxIaOhyv3nM7mTmwOViDHAFesADD+BqrakKQAcMwMQ3AWis9e1C3HLASJoAdNZ6sxG3/MZQMZy1dhWgFbfWRzDGlFjAwFlyyXdh5OD5OIqykBgBy1yiF0aMUQaJugLclOcEoP3nULmFgQgeyCwOoJGBYrijByspDM98ZIszJAt8Ks8dag/VUFYYLtetjHdruRz5JZf8WBg1Ae7KcgOluaSsMAKJwqgJ6Vz2WzcvhZHjVlFh1ESG1DQ67SYtyGs8OwujNpTkUtw4nVtbyLK1XDafF3aKW90Z3EpBbi5lE0u9n3qoNTKk9rHh3heZqqwA8Vw6a11VkVwuPK31HALzb5pfovYC2xSs5LCDIUcAAAAASUVORK5CYII=",tl="data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAABwAAAAKCAYAAACngj4SAAAAAXNSR0IArs4c6QAAAARzQklUCAgICHwIZIgAAAChSURBVDiNrdJbFYMwEIRhJFQCEpCAhEqIhDhBAlKQgAQkIOHrSziHpmkbLvua7P4zO9s0FYUeM0b0NT2nC9FnLQho7wQ9MOwgQ3K4ZPDrrtGmFcKKkL0HTAXXw2HX6HYuFnR/hMWC6ykX+W1AzJqq1abDGguux6LoPK9aUGFOm1Y+F+Bh+7DlsSKehRXgnfdDm5od7GdeN8ADnpuKQ3ldqReHZFd3742nZgAAAABJRU5ErkJggg==",Ys="data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAAGwAAABsCAYAAACPZlfNAAAAAXNSR0IArs4c6QAAAARzQklUCAgICHwIZIgAAAdzSURBVHic7Z3hlZs6EIUvW4E7CB3EHcQdxB08OngugVTg8yrwSQVOKnBSwW4qsFOB3cF9PxhZQsYYjEAS1neOD7ssCwPXMxoNIGWIDJJLAAsASwCfAOTyey6bLOQDABf5qJ9P8vkry48sy05j2+ySzLcBjyC5QiXOV1kuWv+hPxcAvwD8BvCBSsRL6394JDjBSC4ArFEJtG7Y5ILqwp4A/JHlxfyoC04yN/4vh/bEz9Dim9uY+/8O4EfI4nmFZEFyz1veSe5Iri0BXB13Icfekjxaxz6TPMixXXt2fJDM5WLZF+og63MPNi1IbsQGW7zyJYUToXZyEUxP8iLSPUS80hLvdYQTobbWN3fHKvMLGpKrBq/bzla4htC3C8mbutIg3JnkxrddzhCvil4omwbhDqy6IPEisV5xJFn4tsk1rDJI8wtZ+rapN+JV73PzqnuwSk7MtvkQzflabdUxGsMdIGFSnfuZZFPHPxysELjnXDOoFsTbzAJA6dumRiyxSt/2+Ma6Hlvf9lyRb9QumjAwIZKQqOLAznvEEbFUcvFS7VVXWO/WvHsTLYnVnSBEM8JgEqsDlmi7qQ++TWL1xxKtnOqgKvs5J7H6I6KdJxFNsh5FygafxLqOxVgHme6b8QIYkWqcZoW6Mr13vvMXhboi8u56x+a34eXKTWMhXSO3SQirgqZi5WSniSvS1ChyFztUoTCcetjMoNGnHbqjTQqF42P1z4pnd7IwssKUwo8Mq/uIz2eN1NWMg3vzxoUWvu3pihEa+zU/4l3RJhoRC/ZcAkKdxkfnXUC8ggE1L+tWILbartW45o1D5IIpL+tWq43du4C4BQNqXlY82jB67wJmIdhSTG/vl1FXkaP1LiB+wQCA+m5+Ya5/s7b7V5a/J7Eq0cZ/svza+FcrHEZd1ZiJh5kp/q0e1D3tqMMhMA/BgFodt1DrzJD4jyx/TmpVoo3vsqyHxTmFQ2BWHpY3ngP1Pa9h5f1AmItgQC1bXAE6JKpXVn94sSrRxocsl4AW7Iss/0xuTuIRKqfQ7dic2i9gdiHxWlu0V8yi/QLmJRhQc6jlG3T7lYboCRfVji3eoMda+mjeNhEAJ1ku31ANYQekhCNklDafTA87eTEl0YWTLHNTsNSGhYvSZvEGPWDkyY8t1xt2ua/jd0Uyah/jYinBcvt+2OTIBTgAOHi6GJ3wbKeOfkaOn09sRNM4VGcXF8N1P0wiwNmyMx+63x7HV48dnuHqpJ40ZMNbBovmUrAGsRSTjuB2PRefgokhZcPFGCSaK8FaxCqf3ecAW66Cea8juhbNhWCBiaXridRtSD61IZZRzkQbKlhIYok9ut5rCOY9Q3Ml2hDBQhNLbKoJdpBfVr4MMnEh2rOChSiW2KWeCHg3X4wO5h2woaI9I1ioYolt6gHf/RuMOpU/k+pkWVYC+GatXmCkTit1p9hOvL6JLb7JZXky+0LTjn/UgWc9rY+HhexZCuqXIzZmfAzyAdJnROsqWAxiAbUnp9bmmxJn34bdo69oXQSLRSwAt10veqwndqVFtKJh21bBWD2WHotYuo5orDzIymAyxSbuiEZbtDbBqN8hCF4soGbv3lwZbOJh00W0e4LFJhZQG81hY67UHbMIeCRak2AxigXU2q+V/QdF7sWynrSJ1nFdDGJd2y/axXnqikfhx7z+tIjWhdK3/Y+gbqpuu1yM9IU+Nt8EfUQU00ex4YU+84/m6Df55NYNgPdDXhOFb3u7wLZwaGwUXVhUdBSt8G1nV9hlvBTjpKPIFm0eiFb4tq8P7No3ZkA3NJ/hjmiFb7v6QN3Nuh8OjY3VCQffib6HJVrh256+GN5Vdtk4ZwS1xUeIaIVvO/rSy7uMf9rF7mWx0su7jH9SD31E7WWxwfoI5v0eO6QuOiYvmwgOGcGcLkZ6TnSG+kGb7m1Xw05UtnVMoXE8WJ8hYljZjL4mKXsh6HIE85SAjAvHmCqFabKcUeAYk+UYO1ePWqXpqBxBXWx3f0vLyhpL5wd4MYyoNd7bnKzX6IJ+wipkOOXUlJN8M2YMfUxNaSUh+SQHnQFWszLtfGxME2/3whJr+j4t09T2nbHE8jO1vRiSRHtAMGIZBi2M8HhO2aNGskGVYOy8i2VCXQ+bLvsJGNYfci1929OIZeQ+qG/UREjE2QcvlsIKA0cGMjrBFFjt1ZGx3EcUww/Gt2w7Z2+T890Z5/seZQJmhcjjHBMSVuW6o3GepW+bBsHqfo/pbYc5hMkGrzpG6VX3YPWWyTl24e4IVfi2axRYZVBm+h+NcKxGHdhZtm9n5VX3EOHKBo8rGVByIt5UUFdzKDbvXkIomzvCKfE2PsQzRDpYNh1lfT61TcEhwq3lItniHSX0FGMIKAKtxWveecueAbVRmW8DbESUNaopHpe4HbDrhGqU6Q9UMyao309qgyzLTsa+7E8O4LMsm/YPVPOo/QTwI8uyoMbzD04wE7ngS/l8AbBC8wUeghL/J4CPLMt+Od6/U4IWrAlpQ5aoPOSTLHNoIRfGzxfoMd9P0J74F5VIlyzLopok6H/tVqA8kSYfTwAAAABJRU5ErkJggg==",il="data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAAYwAAACsCAYAAABo4pvIAAAAAXNSR0IArs4c6QAAAARzQklUCAgICHwIZIgAAAzYSURBVHic7d3hcdtIEobhD05gmYGRgbkRLDKwMjiGoBCUgeoi0F0Evo1AdASiIxAcgbkR9P1Aj9mESIm2QMwAeJ8qlihKomeXwHzsHgCsBBTOzGpJK7+pd7/2r3+ceCw69Vh8nkvt/fbW4/H7vaR//H4bfqeNX6uqij8DilPlHgCWxcxW6ibvNFmn+x/DY/Fn0mHyPXVLE7F0ejKOf3/SpRO1B9c55wJNOg6rfrD1/5v7/31pbN97j7WS9lVVnf3vAoZGYGAwPqHW6ia+tbrJce0/Tj+Lk176+k/4/ui2tAnRA/VUaNbqQjXdr8PvtDoOku/xeyoXDIXAwMXMbK1DGHzUcTikiatVN1l9Uy8YmLiG1wuY2r9+0vHrUuvwOux0/PrseF1wKQIDR06EQvw+TTatunexrXgXOwmh+ku31AJc6xAoMUxaESboITAWyoOhVjdhfAr307vQnbpQ2KlrDe2yDBSj8EBJ20S/Qml12B7S/XZp7UIQGLMX3lk2Og6Gnbqd/1u4zySAI+EghRQmH9VtS7W6bWYrKpLFIDBmJFQNf6nbwdOCc6oYvqqrFrY5xof56AXJJ53e3r5J2hIi80FgTFRoIcRwaP32Vb7TUjFgTCdaW426thYhMgMExgT4u7m1Dm2lxn+UqoatCAcUyrffRodqpPEfbcWbm0khMAoUdrBUPTTyUFC3g7UsQmPKvBJpdNzOiq3TLQFSHgKjAKGM/6xDOb+T9Le6d17bXGMDxmJmjY73g1aHRfX/ESD5ERgZhBbTZx2OOCEggOCVAEn7CQEyMgJjJL2Nv9Hxhr/NNS5gKnr7UK0uQNiHMH1mtjKzGzN7MLNnvz34Rg/gHXz/aszs3vetH75/bbyCB8pmZrVvsI/WeTSzWz8/AsCV+L536/vcj7Dv1bnHBvxkZmt/l/MUqogb3uUAefSqjx++X95R3SOLEBK0moDCER4Y3YmQuKfVBEyLh8dd2I8JDwzD+6J3hAQwP2fCo849LkyI9z/TwnVqNxESwIyF8IgL5qxD4jTfYB786KYvZnaTe0wAxudzQTraivVJdE60nDaUpACkn92GuxAed1QdCxSqCY5wAvCm3pFWj8wZM2eHk+p+VhO5xwRgWrzqSCcIPrHWMTMeFGltgmoCwCB6ax33tLMnzM+biG2nOveYAMxPWAulXTU1vUNiuRAZgFGERfJngqNwrE8AKEVoVz0xHxWEoABQqhAczE85ERQApiIEB62qMREUAKaK4BiJH4nwRFAAmDqC40rCeRQEBYBZ8Y5JumZVnXs8k9U7RO0u93gA4Br6cx2nAvyisE5B6gJYBA+OB684uFr2W3rtpzr3eABgbL31jTr3eIoUTq2/yz0WAMjNugsbPpvZbe6xFMOrimfSFACO+fyYzhhvco8nq1BVkKAAcIZXGz/M7D73WEYXqgoWtQHgAr1qo849nlGEvtwm91gAYGoWsbbBEVAAMIxw5YvH2Z23EVpQy+u/AcAV+Hkb9z63rnOPZxBhsWa+5RMAZDKbFlVIvzr3WABgrsbq4ny4xpOm/pqklaQ/q6pqr/HvAAAkn2P/lLSa1FFUIenuco8FAJYmXMiwzj2WVxEWAJBfCI0yF8PN7MYXtze5xwIASxeu+t3kHsuRMLAy0wwAFsjM1kW9kQ9hUeceCwDgWFgq2OQeSPp4wTrrQAAAZ3lo5Ks0QljQhgKAwmVrT1n3iVCEBQBMSAiNcebuUNrwmbMAMDF+ROv11539Ylf5F08AAL8tXH+qvuY/8sgVZwFg+vzkvqdrPfm9mT1e5ckBAKPz604NWwSM1vMCAIxm8HM0wiI3R0QBwMz4kVPDFAS+bjHtD+YAAJzli+DvW3IY5EkAAMV715XGaUUBwHKEOb/+nT/+wudaAMBy+KG2D7/6R42XJ6srjQsAUCCf+y+/kocvdDfXGxIAoETpIysu/eWGhW4AWK6Lz83w6oILCwLAQl1UZaS1i5HGBAAo1JtrGV5dbMYbEgCgRF5lnF6e8EuX/xh5TACAQvUvGfIh/OxW0n/GHhAAoFhbSS/bUp4kzdijAQCU6eS6dvqM7kxjAgAUKhYTqSW1Fu0oAMBLW3UZ0eHMbgDAKUcnc6ejo7huFACgzzPCpK4lVUvaV1W1zzoqAEBxPBt2ZtZ8UNeb2uYdEgCgYK2k9QdJnyR9yzsWAEDBvkr6mFpSbdahAABKtpNXGGtJrF8AAF6zSudhtDlHAQAo2l4hMAAAOGcvaaV0fC0AAOeYmVFhAAAu8kHSPl7vHACAyDOi/aDUmwIA4BUEBgDgLbV0CAwAAM5ZSdp9kJ/Bl3kwAIBy1fI1jO+S/so7FgBAwT5J+pYqjDrvWAAABWvUZUV3QgYfoAQA6IsfspdO3NuKdQwAwEtrSbuqqvYpMP6W9K+MAwIAlOmzuozo+Id8P+cbDwCgRN6OavoPPr94EACwWP1iIl588N+iLQUAOPgs6b8vHjWzmrYUACBJR0el739WGFVVtZJaM9tkGBcAoCCeBbuqqk5fPsrMbqgyAAAXrWv7L21GGREAoDhePDxe8osbqgwAWC4ze7z4qFmqDABYJj+U9u3qIvwBaxkAsDB+3ahfPyfPzB7M7O4qowIAFMfM7szsy+/8Ye3H4NbDDwsAUBIzW79rzve0oTUFADPnC923+Z8EAFAsM7v9pYXuV56o9kUQPi8DAGbm3a2oE0+48dAY5gkBANmFguBm6Ce+N7OnQZ8UAJCNLzncX+vJnzjUFgCmz4uA969bvPIPpPKFRXAAmKiwzLB6+7ff9w9dp+cFALg6v5LHeOfYhVV1jpwCgIkIc3cz9j+8ITQAYBpCWGxyDWAzamkDAPhl4VJPm9wD4RwNAChUWHfe5B6LJNpTAFAib0OVExaJf+hGeQMDgAUKb+TLPKI1pNld7rEAwFKlK40Xv1QQ+mV3uccCAEszmbBIPDSe/FP7rnsmIQAgfbzqg8+9de7x/DK/Vsl0kg4AJih0dq5zIcGx+AdzcP0pALgCn2N/zGaODYvh97SoAGAYs+3ieH/tcbL9NQAoRGhBPcx6PqVFBQC/L1xdYxlzaDiK6nHW6QgAA/F582GWLahLeP9tPos1AHAFYWH7LvdYsvJLilBtAECPVxWPi60qzmFtAwAO/IxtqopzQpo+2tifCAUABVjMEVBDscNnznJpEQCL0FvU3uQez6T4eRvpIlp3BAeAuWKuG0hI3fwfLwgAAwrnVNB+GpIfTcX6BoDJC0HBlS+uieAAMFUhKFinGBPBAWAqCIpChBeC4ABQFIKiUP7CPBEcAHIjKCYitKo4RA3AaPxUgNjx2OQeEy4UguOHB0ede0wA5qd3wt2Dma1zjwm/yV/MdFVc2lUABuFvSh+sw3kUc+Ll4m1Y57ilXQXgV/XXJwiKmeu1q+6pOgC8JlQTqe3U5B4TRmaH61WldhWL5AAk/Wxnx2qCtVB0wjsI1jqABbPuatlfwtpEk3tMKFRY64hHWDW5xwXgesxsHVpOj15Z0G3A5bwkTZcdfiY8gPnwkLin5YTBecuK8AAm7ERI3HPeBK6qFx4caQUUrHeEEyGBfM6FB/1PIA9fh7wJIfFESKA4vuYRF8wf/fs699iAOfNWU9r3LCxc17nHBrzJDhciS4fqplKY6gMYwIlW04NXFuxfV1LlHsBS+BrHWtJnSbWkVtLfknZVVW1zjQuYit4+1Ejain1oVARGBv4OKG74taSd2PiBn3oBsVb3Jmurw36yzzW2pSIwCuABciPpkwgQLNSZgIj7QZtrbOgQGAXyAGkk/aVux1mr23F2kr5J2rLzYMr8iKVah228UVc97CR9VbeNU0EUhsCYgNDCWqvbwRr/0VZdgOzEDoZChe230SEgpMP2uxUtpkkgMCbKDxds1LWxUpjsddgJW1HGY2Qn3tzUOrRYU/XAdjlRBMaMnAkR6bidtZPU8m4O7+VrDisdt06l43Boq6raZRkgBkdgzJyHSOoXx0X1Vl018l2HxUWCBEe8Yqj9tla3DaX7O3XbTmortVQO80ZgLFCYBFKQfAz39+omgr1obS2GL0KndlLaHtJjMRjSGwuqhgUiMHDkREWyCt+3OoRJqkxa8c6yeP66xttH/5pe3/S67tS9tjtJe4IBEYGBi4UwWek4TFLF0uplhbIPj+9peQ0vhMEqfP0Uvq91/Lq0IhTwGwgMDKb3Lnalw7vY9H0tDw4dqhPpUK1IIVy0wIDxduGpWy3pD70MhpWO/1/uJP2jEA5UfxgKgYFRhQmx1vGk99F/JT6WbvverfXf3aubHJM23E+/27//wqUT6htXPk1jTeoz9//Q6UCIf9/q5X/zd/WqNXGQAkZGYKB4YaLuf43300QsvZy8+9+/9fhrzoVP+8pjMdjiY0eBRiWA0v0fPGR4m68wwtkAAAAASUVORK5CYII=";class Qs extends fe.CSS2DObject{constructor(e,t){const i=document.createElement("div");super(i),this.props=e,this.amr=t,this._direction=1,this._controllingRotate=!1,this._controlling=!1,this._startAt=0,this._looper=0,this._initial=0,this._canRotate=!1,this._emitter=new ct,this.addListener=this._emitter.addListener.bind(this._emitter),this.removeListener=this._emitter.removeListener.bind(this._emitter),this._update=()=>{if(this._looper=requestAnimationFrame(this._update),this._controlling){let c=(Date.now()-this._startAt)/200;c>4&&(c=4);let u=this._initial+.005*c*this._direction;if(u>this.props.max||u<this.props.min){this.mechanism&&(u<this.props.min?(this.mechanism.position.setZ(this.props.min),this._emitter.emit("change",this.props.min)):u>this.props.max&&(this.mechanism.position.setZ(this.props.max),this._emitter.emit("change",this.props.max)));return}if(this._initial=u,!this.mechanism)return;this.mechanism.position.setZ(u),this._emitter.emit("change",u)}};const s=cs();e.userData&&e.userData.target&&(this.name=e.userData.target.name,t.traverse(c=>{c.name===e.userData.target.name&&(this.mechanism=c)})),i.style.fontSize="30px",i.style.color="#0066FF",i.style.cursor="pointer",i.style.pointerEvents="auto";const a=document.createElement("div");a.style.position="absolute",a.style.left="0",a.style.transform="translateX(-50%) rotate(-180deg)",a.style.marginBottom="5px",a.style.width=a.style.height=s?"34px":"44px",a.style.background=`url(${Ys}) center no-repeat`,a.style.backgroundSize="100% auto",a.setAttribute("data-direction","up"),a.style.transition="all .2s";const o=document.createElement("div");if(o.style.position="absolute",o.style.left="0",o.style.transform="translateX(-50%)",a.style.bottom=o.style.top="8px",o.style.width=o.style.height=a.style.width,o.style.background=`url(${Ys}) center no-repeat`,o.style.backgroundSize="100% auto",o.style.transition="all .2s",o.setAttribute("data-direction","down"),Array.from([a,o]).forEach(c=>{s||c.addEventListener("mousemove",()=>{c.style.filter="invert(100%)"}),c.addEventListener("mouseleave",()=>{c.style.filter=""}),c.addEventListener("pointerdown",()=>{this.mechanism&&(c.style.filter="invert(100%)",this._controlling=!0,this._startAt=Date.now(),this._initial=this.mechanism.position.z,this._direction=c.getAttribute("data-direction")==="up"?1:-1,this._update())}),c.addEventListener("pointerup",()=>{this._controlling=!1,cancelAnimationFrame(this._looper),c.style.filter=""}),c.addEventListener("pointerleave",()=>{this._controlling=!1,cancelAnimationFrame(this._looper),c.style.filter=""})}),e.userData&&(this._canRotate=e.userData.canRotate,this._canRotate)){const{rotateTarget:c,rotateDuration:u,rotateStep:f,rotateMax:p,rotateMin:r}=e.userData;let l;if(c&&(t.traverse(h=>{h.name===c.name&&(l=h)}),l)){const h=document.createElement("div");h.style.background=`url(${il}) center no-repeat`,h.style.backgroundSize="100% auto",h.style.position="absolute",h.style.top="-50%",h.style.left="-50%",h.style.width=s?"140px":"160px",h.style.height=s?"70px":"80px",h.style.transform="translateX(-50%) translateY(-50%)",i.append(h);const g=document.createElement("div");g.style.background=`url(${tl}) center no-repeat`,g.style.backgroundSize="100% auto",g.style.width=g.style.height=s?"20px":"26px",g.style.position="absolute",g.style.top="0",g.style.transform="translateY(-50%)",g.style.marginBottom="5px",g.setAttribute("data-direction","left"),i.append(g);const _=document.createElement("div");_.style.background=`url(${el}) center no-repeat`,_.style.backgroundSize="100% auto",_.style.width=_.style.height=s?"20px":"26px",_.style.position="absolute",g.style.left=_.style.right=s?"62px":"69px",_.style.top="0",_.style.transform="translateY(-50%)",_.style.marginBottom="5px",_.setAttribute("data-direction","right"),i.append(_),Array.from([g,_]).forEach(m=>{s||m.addEventListener("mousemove",()=>{m.style.filter="invert(100%)"}),m.addEventListener("mouseleave",()=>{m.style.filter=""}),m.addEventListener("pointerdown",()=>{if(this._timer&&this._timer.isPlaying())return;m.style.filter="invert(100%)",this._controllingRotate=!0,this._startAt=Date.now(),this._direction=m.getAttribute("data-direction")==="left"?1:-1;let v=f/180*Math.PI*this._direction+l.rotation.z;v>p/180*Math.PI?v=p/180*Math.PI:v<r/180*Math.PI&&(v=r/180*Math.PI),this._timer=new It(l.rotation).to({z:v}).duration(u).start(),this._update()}),m.addEventListener("pointerup",()=>{this._controllingRotate=!1,cancelAnimationFrame(this._looper),m.style.filter=""}),m.addEventListener("pointerleave",()=>{this._controllingRotate=!1,cancelAnimationFrame(this._looper),m.style.filter=""})})}}i.append(a,o),this.scale.set(.01,.01,.01),this.matrixAutoUpdate=!1,this.updateMatrix()}hide(){this.element.style.display="none",this.traverse(e=>{e.visible=!1,e instanceof fe.CSS2DObject&&(e.element.style.visibility="hidden")}),this.visible=!1}show(){this.element.style.display="auto",this.traverse(e=>{e.visible=!0,e instanceof fe.CSS2DObject&&(e.element.style.visibility="visible")}),this.visible=!0}dispose(){this._emitter.removeAllListeners(),cancelAnimationFrame(this._looper),this.element.remove()}}class sl extends mn.CSS3DObject{constructor(e){const t=document.createElement("div");super(t),this.props=e,this._scale=.01,this._emitter=new ct,this.addEventListener=this._emitter.on.bind(this._emitter),this.removeEventListener=this._emitter.on.bind(this._emitter),this._mouseStart=new d.Vector2,this._targetSize=new d.Vector2,this._caches=[],this._sizeFlag="width",this._direction=1,this._lines=[],this._pointerdown=u=>{const{pageX:f,pageY:p}=u;this.endNode.setPointerCapture(u.pointerId),this._mouseStart.set(f,p),this._targetSize.setX(parseFloat(this.endNode.parentElement.style.width)),this._targetSize.setY(parseFloat(this.endNode.parentElement.style.height))},this._pointermove=u=>{if(!this._mouseStart.x)return;const{pageX:f,pageY:p}=u;let r=f-this._mouseStart.x,l=r+this._targetSize.x;this._sizeFlag==="height"&&(r=p-this._mouseStart.y,l=r*this._direction+this._targetSize.y);const h=l%10;l=l-h,r=(l-this._targetSize.x)*this._direction,this._sizeFlag==="height"&&(r=(l-this._targetSize.y)*this._direction),this._textNode.innerText=(l/100).toFixed(2)+" m",this.endNode.parentElement.style[this._sizeFlag]=`${l}px`},this._pointercancel=u=>{this.endNode.releasePointerCapture(u.pointerId),this._mouseStart.set(0,0)};const{start:i,end:s}=e,a=s.distanceTo(i);this.props.axios==="z"?this.props.axios="y":this.props.axios==="y"&&(this.props.axios="z"),this.props.axios==="y"&&(this._sizeFlag="height");const o=document.createElement("div");o.style.position="absolute",o.style.left="0",o.style.bottom="0",t.append(o),this._textNode=document.createElement("div"),this._textNode.innerText=a.toFixed(2)+" m",o.append(this._textNode);const c=document.createElement("div");this.endNode=c,c.style.position="absolute",c.style.left="auto",c.style.right="0",c.style.width="4px",c.style.height="4px",c.style.background="#0066FF",c.style.borderRadius="50%",c.style.margin="-2px -2px 0 0",c.style.cursor="pointer",o.append(c),this.scale.set(this._scale,this._scale,this._scale),t.style.fontSize="6px",t.style.color="#fff",o.style[this._sizeFlag]=a*100+"px",o.style.textAlign="center",this._sizeFlag==="height"?(o.style.borderLeft="0.1px dashed #fff",o.style.display="flex",o.style.alignItems="center",o.style.justifyContent="center",o.style.whiteSpace="nowrap",c.style.top="0",c.style.left="0",c.style.right="auto",c.style.margin="-2px 0 0 -2px"):o.style.borderBottom="0.1px dashed #fff",c.addEventListener("pointerdown",this._pointerdown),c.addEventListener("pointermove",this._pointermove),c.addEventListener("pointerup",this._pointercancel),s[this.props.axios]<i[this.props.axios]?this.rotateY(Math.PI):this._direction=-1}_getIndexByAxios(){return this.props.axios==="y"?1:this.props.axios==="z"?2:0}dispose(){this._lines.forEach(e=>e.dispose()),this._emitter.removeAllListeners(),this.endNode.removeEventListener("pointerdown",this._pointerdown),this.endNode.removeEventListener("pointermove",this._pointermove),this.endNode.removeEventListener("pointerup",this._pointercancel),this.element.remove(),this._caches.forEach(e=>e.clear()),this._caches=[]}}class rl extends d.Object3D{constructor(){super(),this._box3=new d.Box3,this._line11=new ti("长:"),this._line12=new ti("宽:"),this._line13=new ti("高:"),this._outline=new Lr(0,0),this._radius=0,this._hasWidthConfig=!1,this._hasLengthConfig=!1,this._hasHeightConfig=!1,this.follow="",this.followOrigin=0,this.followScale=1,this.originOffset=0,this.translateCache=0,this.head=0,this.tail=0,this._change=()=>{if(!this._app)return;const e=this._app.camera;e&&this._outline.change(e.position)},this.add(this._outline,this._line11,this._line12,this._line13)}get hasSizeConfig(){return{length:this._hasLengthConfig,width:this._hasWidthConfig,height:this._hasHeightConfig}}get size(){return this._box3.clone()}get radius(){return this._radius}init(e){this._app=e,this._app.controls.addEventListener("change",this._change)}reset(){this.hide(),this._line11.reset()}generate(e,t=0){e&&(this._object=e),this.update(t)}show(e=!0){const t=[this._line11,this._line12,this._line13];e&&(this.visible=!0,this._outline.visible=!0,this._outline.show(),t.push(this._outline)),t.forEach(i=>{i.traverse(s=>{s.visible=!0,s instanceof fe.CSS2DObject&&(s.element.style.visibility="visible")})})}hide(e=!0){const t=[this._line11,this._line12,this._line13];e&&(this.visible=!1,this._outline.visible=!1,this._outline.hide(),t.push(this._outline)),t.forEach(i=>{i.traverse(s=>{s.visible=!1,s instanceof fe.CSS2DObject&&(s.element.style.visibility="hidden")})})}destroy(){var e;(e=this._app)==null||e.controls.removeEventListener("change",this._change),this._line11.destroy(),this._line12.destroy(),this._line13.destroy()}update(e=0){if(!this._object)return;const t=this._object,{box:i,maxRadius:s,hasLength:a,hasHeight:o,hasWidth:c}=Na(t);this.tail=Math.abs(i.min.x),this.head=Math.abs(i.max.x),this._hasWidthConfig=c,this._hasLengthConfig=a,this._hasHeightConfig=o,this._box3.copy(i),this._radius=s,this.follow&&e&&(this.originOffset=(this.followOrigin-e)*this.followScale),this._outline.update(this._radius),this._change();const u=this._box3.min.x,f=this._box3.max.x,p=this._box3.min.z,r=this._box3.max.z,l=this._box3.min.y,h=this._box3.max.y;let g=.2;const _=new d.Vector3(u,h,0),m=new d.Vector3(f,h,0);this._line11.update(_.clone().sub(new d.Vector3(0,-g/1.8,0)),m.clone().sub(new d.Vector3(0,-g/1.8,0)),this._radius);const v=new d.Vector3(f,l,0);this._line12.update(m.clone().add(new d.Vector3(g,0,0)),v.clone().add(new d.Vector3(g,0,0)),this._radius);const y=new d.Vector3(u,h,p),x=new d.Vector3(u,h,r),w=y.clone();w.y-=g/6;const b=x.clone();b.y-=g/6,this._line13.update(w,b,this._radius)}}class Zs extends d.Object3D{constructor(e=.6,t=.4,i=.2){super(),this.isGoods=!0,this._generate(e,t,i)}updateSize(e=.1,t=.1,i=.1){this._generate(e,t,i)}clearAll(){xe(this)}hide(){this.traverse(e=>e.visible=!1)}show(){this.traverse(e=>e.visible=!0)}_generate(e,t,i){this.clearAll();const s=new d.Mesh(new d.BoxGeometry(e,t,i),new d.MeshBasicMaterial({color:new d.Color("#0f5fd5"),transparent:!0,opacity:.4}));s.geometry.translate(0,0,i/2);const a=new d.EdgesGeometry(s.geometry),o=new d.LineDashedMaterial({color:new d.Color("#000"),dashSize:.015,gapSize:.015}),c=new d.LineSegments(a,o);c.computeLineDistances(),this.add(s,c)}}const nl="data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAAAEAAAABCAYAAAAfFcSJAAAAAXNSR0IArs4c6QAAAARzQklUCAgICHwIZIgAAAALSURBVAiZY2AAAgAABQABYlUyiAAAAABJRU5ErkJggg==";class Gi{constructor(e){this._props=e,this.name="",this.transparentTexture=us.load(nl),this._offscreen=new OffscreenCanvas(0,0),this._defaults={...e},this.target=e.target,this.parent=this.target.parent,this.reset()}get imageSize(){return this._props.imageSize}get size(){return this._props.size}get defaultConfigs(){return{canvasWidth:200,canvasHeight:200,scaleX:1,scaleY:1,x:0,y:0,ox:0,oy:0,url:this._defaults.imageUrl}}clear(){this.change()}change(e,t=new d.Vector2(1,1),i=new d.Vector2){this.imageUrl=e;let s;if(e){const a=new Image;a.crossOrigin="anonymous",a.src=e,a.onload=async()=>{var f;let o=window.devicePixelRatio*2;this._offscreen.width=a.width+o,this._offscreen.height=a.height+o;const c=this._offscreen.getContext("2d");c==null||c.clearRect(0,0,this._offscreen.width,this._offscreen.height),c==null||c.drawImage(a,o/2,o/2,a.width,a.height),s=new d.Texture(this._offscreen),s.minFilter=1003,s.colorSpace=d.SRGBColorSpace,s.wrapS=s.wrapT=d.ClampToEdgeWrapping,s.repeat.set(1/t.x,1/t.y),s.offset.set(i.x,i.y),s.flipY=!1,s.needsUpdate=!0;const u=this._props.target;u.material&&((f=u.material.map)==null||f.dispose(),s?(u.material.map=s,u.material.opacity=1):(u.material.map=this.transparentTexture,u.material.opacity=0))}}else{const a=this._props.target;a.material&&(a.material.map=this.transparentTexture)}}reset(){this._props=this._defaults,this.name=this._props.name,this.imageUrl=this._props.imageUrl,this.target=this._props.target,this.change(this.imageUrl||"")}dispose(){this._offscreen=null}}function ol(n){return n.type?n.type==="Mesh":n.isMesh}const us=new d.TextureLoader;us.crossOrigin="anonymous";class Er extends d.Object3D{constructor(e){super(),this._props=e,this._emitter=new ct,this.addEventListener=this._emitter.addListener.bind(this._emitter),this._container=new d.Group,this.lines=new d.Group,this._clips=[],this._actionsMap=new Map,this._animationClock=new d.Clock,this.sizeBox=new rl,this._goodsSize=new Ga(0,0,0),this._slots=[],this._logos=[],this._skins=[],this._levels=new Map,this._bodyOpacity=1,this._masts=new Map,this._liftMaxHeight=0,this._jackMaxHeight=0,this._forkMaxHeight=0,this.controllers=[],this.goods=[],this._breathLights=[],this._shelves=new Map,this._shelfMaxLevel=1,this._url="",this._showController=!0,this._showSlots=!0,this._shapeKeys=new Map,this._shapeKeyTimer=0,this._shapeKeyCache="",this._materialsCache=new Map,this.opacityCache=void 0,this.actions=[],this._url=e.url||"",this._url&&this.load(this._url).then(),this.add(this._container,this.lines),this._props.showSizeBox&&this.add(this.sizeBox),this.showController=typeof e.showController=="boolean"?e.showController:!0,this._showSlots=typeof e.showSlots=="boolean"?e.showSlots:!0}get shapeKeys(){return this._shapeKeys}get size(){const e=this.sizeBox.size.getSize(new d.Vector3);return{width:e.z,length:e.x,height:e.y}}get goodsSize(){return this._goodsSize}get showController(){return this._showController}set showController(e){this._showController=e,this.controllers.forEach(t=>e?t.show():t.hide())}get slots(){return this._slots}get logos(){return this._logos}get skins(){return this._skins}get bodyOpacity(){return this._bodyOpacity}get fork(){return this._fork}get forkHeight(){var e;return((e=this._fork)==null?void 0:e.position.z)||0}get liftHeight(){var e;return((e=this._lift)==null?void 0:e.position.z)||0}get jack(){return this._jack}get jackHeight(){var e;return((e=this._jack)==null?void 0:e.position.z)||0}get lift(){return this._lift}set bodyOpacity(e){this._bodyOpacity=e,e<1?this._materialsCache.forEach(t=>{t.mat.transparent=!0,t.mat.opacity=e,t.mat.metalness=0,t.mat.roughness=1,t.mat.color=new d.Color("#3859be"),t.mat.needsUpdate=!0}):this._materialsCache.forEach(t=>{t.mat.transparent=t.transparent,t.mat.opacity=t.opacity,t.mat.metalness=t.metalness,t.mat.roughness=t.roughness,t.mat.color=t.color,t.mat.needsUpdate=!0})}init(e){this._app=e,this.sizeBox.init(e),this._onTicker&&this._app.renderer.domElement.removeEventListener("ticker",this._onTicker),this._onTicker=()=>{if(this._mixer){const t=this._animationClock.getDelta();this._mixer.update(t)}else this._animationClock.getDelta()},this._app.renderer.domElement.addEventListener("ticker",this._onTicker),this.addEventListener("shape-key-changed",(t,i)=>{this._slots.forEach(s=>s.shapeKeyChanged(t,i)),this.sizeBox.follow===t?(this.sizeBox.generate(this._container,i),this.sizeBox.originOffset&&(this._container.traverse(s=>{s instanceof d.Mesh&&!s.userData.isDevice&&!s.userData.isBracket&&s.geometry.translate(this.sizeBox.originOffset-this.sizeBox.translateCache,0,0),s instanceof Wi&&!s.props.slot.userData.ignoreOriginChanged&&s.parent&&s.parent.position.add(new d.Vector3(this.sizeBox.originOffset-this.sizeBox.translateCache,0,0))}),this.sizeBox.translateCache=this.sizeBox.originOffset,this.sizeBox.generate(this._container))):this.sizeBox.generate(this._container),["width","length","height"].includes(t)&&this._emitter.emit("size-changed",t,i)})}async load(e,t=""){this._url=e,this.name||(this.name=e.substring(e.lastIndexOf("/")+1,e.lastIndexOf("."))),!e.startsWith("blob")&&e.endsWith(".sglb");let i,s;if(t==="glb"||e.endsWith(".glb")){let o=await lt.loadAsync(e);i=o.scene,s=o.animations||[]}else{const c=await new ni({useCache:!0}).loadAsync(e);if(!c.glb)return;i=c.glb}const a=vn.clone(i);this._generateAmr(a,s),i=null,this._emitter.emit("amr-loaded")}changeSkin(e,t){e&&(e.change(t),this._app&&this._app.usePathTracing&&(this._app.sampleCount=0,this._app.usePathTracing&&(this._app.pathTracer.pausePathTracing=!1,this._app.pathTracer.updateMaterials())))}changeLogo(e,t){e.change(t.url,new d.Vector2(t.scaleX,t.scaleY),new d.Vector2(t.ox,t.oy))}setShapeKey(e,t,i=!0){i&&this._shapeKeyTimer&&e===this._shapeKeyCache&&clearTimeout(this._shapeKeyTimer),this._shapeKeyCache=e,this._shapeKeyTimer=window.setTimeout(()=>{this._container.traverse(s=>{if(!Object.keys(s.morphTargetDictionary||{}).includes(e))return;let a=t;s.userData[`origin_${e}`]&&(a-=s.userData[`origin_${e}`]);const o=s.morphTargetDictionary[e];s.morphTargetInfluences&&(s.morphTargetInfluences[o]=a),s instanceof d.Mesh&&s.geometry.translate(0,0,1e-5)}),i&&this._emitter.emit("shape-key-changed",e,t)},100)}_generateAmr(e,t){this._modelRoot=e,this._actionsMap.clear(),this.actions=[],this._clips=[],t&&t.length&&(this._mixer=new d.AnimationMixer(e),this._clips=t,t.forEach(i=>{const s=this._mixer.clipAction(i);this._actionsMap.set(i.name,s)}),this.actions=t.map(i=>i.name)),e.traverse(i=>{i.userData.isShelf&&(this._shelf=i),i.userData.isFork&&(this._fork=i),i.userData.isMast&&i.userData.mastLevel&&this._masts.set(i.userData.mastLevel,i),i.userData.isJack&&(this._jack=i),i.userData.isLift&&(this._lift=i),Object.keys(i.morphTargetDictionary||{}).forEach(s=>{let a=i.morphTargetInfluences[i.morphTargetDictionary[s]];i.userData[`origin_${s}`]&&(a+=i.userData[`origin_${s}`]),this._shapeKeys.has(s)||this._shapeKeys.set(s,a)})}),e.traverse(i=>{if(i instanceof d.Mesh){if(i.castShadow=!0,i.receiveShadow=!0,i.material)if(Array.isArray(i.material))i.material.forEach(a=>{a.userData.changeColor&&(this.skins.find(o=>o.name===a.userData.name)||this.skins.push(new es({name:a.userData.name,target:a})))});else{if(i.material.userData.isBreathLight&&i.material.emissiveIntensity){i.material.emissive||(i.material.emissive=new d.Color(16777215)),i.material.emissiveIntensity=2,i.material.toneMapped=!1;const a=1e3,o=new ye.Tween(i.material).to({emissiveIntensity:.2}).easing(ye.Easing.Quintic.InOut).duration(a),c=new ye.Tween(i.material).to({emissiveIntensity:2}).easing(ye.Easing.Quintic.InOut).duration(a);o.onComplete(()=>c.start()),c.onComplete(()=>o.start()),o.start(),this._breathLights.push(o,c)}i.material.userData.changeColor&&(this.skins.find(a=>a.name===i.material.userData.name)||this.skins.push(new es({name:i.material.userData.name,target:i.material})))}if(i.material)if(Array.isArray(i.material))i.material.forEach(o=>{if(o.userData.isLOGO){i.material.transparent=!0;let c;const u={width:0,height:0};i.material.map&&i.material.map.image&&(u.width=i.material.map.image.width,u.height=i.material.map.image.height,c=Ni(i.material.map.image));const f=new Gi({name:o.userData.name,target:i,size:Ws(i),imageSize:u,imageUrl:c});this._logos.push(f)}o.userData.isTransparent&&(o.transparent=!0),this._materialsCache.set(o.uuid,{opacity:o.opacity,transparent:o.transparent,roughness:o.roughness,metalness:o.metalness,color:o.color,mat:o})});else{const a=i.material;if(a.userData.isLOGO){i.material.transparent=!0;let o;const c={width:0,height:0};i.material.map&&i.material.map.image&&(c.width=i.material.map.image.width,c.height=i.material.map.image.height,o=Ni(i.material.map.image));const u=new Gi({name:a.userData.name,target:i,size:Ws(i),imageSize:c,imageUrl:o});this._logos.push(u)}a.userData.isTransparent&&(a.transparent=!0),this._materialsCache.set(a.uuid,{opacity:a.opacity,transparent:a.transparent,roughness:a.roughness,metalness:a.metalness,color:a.color,mat:a})}}this.generateController(i,e),this.generateDimension(i,e);const s=this.generateSlot(i,e);s&&this._slots.push(s),i.userData.isOrigin&&Object.keys(i.userData).forEach(o=>{if(o.startsWith("follow_")){const c=o.replace("follow_","");this.shapeKeys.has(c)&&(this.sizeBox.follow=c,this.sizeBox.followOrigin=this._shapeKeys.get(c)||0,this.sizeBox.followScale=i.userData[o])}})}),this.slots.forEach(i=>{i.props.mirrorTarget&&(i.mirrorTarget=this.slots.find(s=>s.props.slot.name===i.props.mirrorTarget))}),e.updateMatrixWorld(!0),this._container.add(e),this.sizeBox.generate(e),this.sizeBox.show()}setHeight(e){this.setShapeKey("height",e)}setWeight(e){this.setShapeKey("width",e)}setLength(e){this.setShapeKey("length",e)}limitValue(e){this.name==="SFL-CDD14"&&(e>1.6?this.setShapeKey("mast",1):this.setShapeKey("mast",0)),["SFL-CDD20","SFL-CDD20-Y"].includes(this.name)&&(e>1.6?this.setShapeKey("mast",1):this.setShapeKey("mast",0)),this.name==="SFL-CDD15"&&(e>2.43?this.setShapeKey("mast",1):this.setShapeKey("mast",0)),["SFL-CPD20-Y","SFL-CPD30-Y"].includes(this.name)&&(e>3.5?this.setShapeKey("mast",2):e>3?this.setShapeKey("mast",1):this.setShapeKey("mast",0))}setForkHeight(e){if(this._fork){if(e>this._forkMaxHeight&&(e=this._forkMaxHeight),this._fork.position.z=e,this._masts.size===1){const t=this._masts.get(2),i=(t==null?void 0:t.userData.startHeight)||.1;t&&(t.position.z=(e-i)*.5)}this._emitter.emit("fork-height-change",e)}}setForkMaxHeight(e){this._fork&&(this._forkMaxHeight=e,this.limitValue(e),this.controllers.forEach(t=>{t.name.toLowerCase().includes("fork")&&(t.props.max=e)}),this._fork&&this.forkHeight>this._forkMaxHeight&&this.setForkHeight(e))}setLiftHeight(e){this._lift&&(e>this._liftMaxHeight&&(e=this._liftMaxHeight),this._lift.position.z=e)}getLiftMaxHeight(){return this._liftMaxHeight}setLiftMaxHeight(e){if(!this._lift)return;this._liftMaxHeight=e,this.limitValue(e),this.controllers.forEach(a=>{a.name.toLowerCase().includes("lift")&&(a.props.max=e)}),this.liftHeight>this._liftMaxHeight&&this.setLiftHeight(e);let t=.46;this.levelOffset&&(t=this.levelOffset+.1);let i=e+t;const s=this.getShelfMinHeight()+t||0;i<s&&(i=s),this.setHeight(i)}setJackMaxHeight(e){this._jack&&(this._jackMaxHeight=e,this.limitValue(e),this.controllers.forEach(t=>{t.name.toLowerCase().includes("jack")&&(t.props.max=e)}),this.jackHeight>this._jackMaxHeight&&this.setJackHeight(e))}setJackHeight(e){this._jack&&(e>this._jackMaxHeight&&(e=this._jackMaxHeight),requestAnimationFrame(()=>{this.setShapeKey("jackHeight",e,!1)}),this._jack.position.z=e)}setLevel(e){}setGoodsSize(e){this._goodsSize.length=e.length,this._goodsSize.width=e.width,this._goodsSize.height=e.height,this.setShelfLevel(this._shelfMaxLevel)}getShelfMinHeight(){const e=this.levelOffset,t=this._shelfMaxLevel,i=this._shelves.get(0);return i?i.position.z+e*t+.1:0}getShelfMaxShelfHeight(){const e=this.levelOffset,t=this._shelfMaxLevel,i=this._shelves.get(0);if(i)return i.position.z+e*(t-1)}get levelOffset(){return this._goodsSize.height+.2}setShapeKeyToMesh(e,t,i){if(!Object.keys(e.morphTargetDictionary||{}).includes(t))return;const s=e.morphTargetDictionary[t];e.morphTargetInfluences&&(e.morphTargetInfluences[s]=i),e.geometry.translate(0,0,1e-5)}setShelfLevel(e=3){var s;if(!this._shelf)return;this._shelfMaxLevel=e;const t=this.levelOffset;this._shelves.delete(0),this._shelves.forEach(a=>{xe(a),a.parent&&a.removeFromParent()}),this.goods=[],this._shelves.clear(),this._shelves.set(0,this._shelf);for(let a=1;a<e;a++){if(!this._shelf)return;this._shelf.traverse(u=>{ol(u)&&(this.setShapeKeyToMesh(u,"goodsWidth",this._goodsSize.width),this.setShapeKeyToMesh(u,"goodsLength",this._goodsSize.length))});const o=this._shelf.clone(!0);o.position.z+=t*a,this._shelves.set(a,o),(s=this._shelf.parent)==null||s.add(o);let c;if(o.traverse(u=>{u.userData.isShelfContainer&&(c=u)}),(this.shapeKeys.has("goodsLength")||this.shapeKeys.has("goodsWidth"))&&(c==null||c.position.setX((c==null?void 0:c.position.x)-this._goodsSize.length/2)),c){const u=new Zs(this._goodsSize.length,this._goodsSize.width,this._goodsSize.height);if(c.add(u),this.goods.push(u),a===1){const f=new Zs(this._goodsSize.length,this._goodsSize.width,this._goodsSize.height);f.position.z-=t,c.add(f),this.goods.push(f)}}}const i=this.getShelfMinHeight()||0;this._liftMaxHeight<i&&this.setLiftMaxHeight(i)}generateOuterLine(){this.traverse(e=>{if(e.userData.isOuterObject){const t=this.sizeBox.radius;this._outline?this._outline.update(t):(this._outline=new Lr(t,0),this.add(this._outline))}})}generateController(e,t){if(this.showController){if(e.userData.isForkController&&e.userData.target){const i=e.userData.target.name,{min:s,max:a}=e.userData;let o;if(t.traverse(u=>{u.name===i&&(o=u)}),!o)return;const c=new Qs({name:"",target:i,default:0,min:s,max:a},o);e.add(c)}else if(e.userData.isController&&e.userData.target){const i=e.userData.target.name,{min:s,max:a}=e.userData;let o;if(t.traverse(u=>{u.name===i&&(o=u)}),!o)return;const c=new Qs({name:"",userData:e.userData,target:e.userData.key,default:0,min:s||0,max:a||1},o);e.add(c),this.controllers.push(c),(o.userData.isFork||o.userData.isLift||o.userData.isJack)&&(this._forkMaxHeight=a||1,this._liftMaxHeight=a||1,this._jackMaxHeight=a||1,c.addListener("change",u=>{this.setForkHeight(u),this.setLiftHeight(u),this.setJackHeight(u)}))}}}generateDimension(e,t){if(e.userData.isDimension){const i=e.userData.divider,s=Ua(e.userData.startOrigin),a=e.userData.axios;let o,c;if(a==="x"?(o=new d.Vector3(e.userData.start-e.position.x,0,0),c=o.clone().setX(e.userData.end-e.position.x)):a==="z"?(o=new d.Vector3(0,e.userData.start-e.position.y,0),c=o.clone().setY(e.userData.end-e.position.y)):(o=new d.Vector3(0,0,e.userData.start-e.position.z),c=o.clone().setZ(e.userData.end-e.position.z)),!Object.keys(e.userData).flatMap(r=>r.startsWith("target")?e.userData[r].name:[]).length)return;const p=new sl({start:o,end:c,startOrigin:s,axios:a,divider:i});e.add(p)}}generateSlot(e,t){var i,s;if(e.userData.isSlot){const a=e.userData.name,o=e.userData.isMirror,c=(i=e.userData.mirrorSlot)==null?void 0:i.name;if(a){const u=e.userData.holeTarget&&e.userData.holeTarget.name;let f;u&&t.traverse(h=>{h.name===u&&(f=h)});const p=new Map;Object.keys(e.userData).forEach(h=>{if(h.startsWith("follow_")){const g=h.split("_")[1];if(g){let _=e.userData[h];p.set(g,{scale:_,origin:this.shapeKeys.get(g)||0})}}});const r=(s=this._app)==null?void 0:s.props.isMobile,l=new Wi({name:a,follows:p,slot:e,show:this._showSlots,isMirror:o,mirrorTarget:c,isMobile:r});return l.holeTarget=f,l.addEventListener(q.ON_DROP,h=>{this._app&&this._app.props.useSound&&this._app.sound.play()}),l.addEventListener(q.ON_BEFORE_SELECTED,h=>{this._slots.forEach(g=>{g.selected&&(g.selected=!1)})}),l.addEventListener(q.ON_ERROR_STATE_CHANGE,h=>{if(this._app)if(this._app._outlinePassError.selectedObjects=this._app._outlinePassError.selectedObjects.filter(g=>!!g.parent),h){if(l.device){if(this._app._outlinePassError.selectedObjects.find(_=>{var m;return _.parent==((m=l.device)==null?void 0:m.parent)}))return;this._app._outlinePassError.selectedObjects=[l.device,...this._app._outlinePassError.selectedObjects]}}else l.device&&(this._app._outlinePassError.selectedObjects=this._app._outlinePassError.selectedObjects.filter(g=>{var _;return g.parent!=((_=l.device)==null?void 0:_.parent)}))}),l}}}clean(){this._emitter.removeAllListeners(),this.controllers.forEach(e=>e.dispose()),this.controllers=[],xe(this._container),this._levels.forEach(e=>e.destroy()),this._levels.clear(),this._slots=[],this._logos=[],this._skins=[],this._materialsCache.clear(),this.opacityCache=void 0,this._breathLights.forEach(e=>e.stop()),this._breathLights=[],this.sizeBox.reset(),this._mixer&&this._mixer.stopAllAction(),this._mixer=void 0,this._clips=[],this._actionsMap.clear(),this.actions=[],this._app&&this._onTicker&&this._app.renderer.domElement.removeEventListener("ticker",this._onTicker),this._onTicker=void 0}destroy(){this.clean(),this.sizeBox.destroy()}playAction(e,t=!0,i){const s=this._actionsMap.get(e);return!s||!this._mixer?Promise.reject(new Error(`Action "${e}" not found or mixer not initialized.`)):(t&&s.reset(),this._actionsMap.forEach((a,o)=>{o!==e&&a.stop()}),s.enabled=!0,s.paused=!1,s.setLoop(d.LoopOnce,0),s.setEffectiveTimeScale((i==null?void 0:i.timeScale)??1),s.setEffectiveWeight(1),s.clampWhenFinished=(i==null?void 0:i.clampWhenFinished)??!0,i!=null&&i.fadeIn&&i.fadeIn>0&&s.fadeIn(i.fadeIn),new Promise(a=>{const o=c=>{var u;c.action===s&&((u=this._mixer)==null||u.removeEventListener("finished",o),a())};this._mixer.addEventListener("finished",o),s.play()}))}pauseAction(e){const t=this._actionsMap.get(e);t&&(t.paused=!0)}}const Fr=0,al=1,ll=2,Xs=2,Ti=1.25,Ks=1,Pt=6*4+4+4,hi=65535,cl=Math.pow(2,-24),Si=Symbol("SKIP_GENERATION");function ul(n){return n.index?n.index.count:n.attributes.position.count}function ut(n){return ul(n)/3}function hl(n,e=ArrayBuffer){return n>65535?new Uint32Array(new e(4*n)):new Uint16Array(new e(2*n))}function fl(n,e){if(!n.index){const t=n.attributes.position.count,i=e.useSharedArrayBuffer?SharedArrayBuffer:ArrayBuffer,s=hl(t,i);n.setIndex(new d.BufferAttribute(s,1));for(let a=0;a<t;a++)s[a]=a}}function Br(n){const e=ut(n),t=n.drawRange,i=t.start/3,s=(t.start+t.count)/3,a=Math.max(0,i),o=Math.min(e,s)-a;return[{offset:Math.floor(a),count:Math.floor(o)}]}function kr(n){if(!n.groups||!n.groups.length)return Br(n);const e=[],t=new Set,i=n.drawRange,s=i.start/3,a=(i.start+i.count)/3;for(const c of n.groups){const u=c.start/3,f=(c.start+c.count)/3;t.add(Math.max(s,u)),t.add(Math.min(a,f))}const o=Array.from(t.values()).sort((c,u)=>c-u);for(let c=0;c<o.length-1;c++){const u=o[c],f=o[c+1];e.push({offset:Math.floor(u),count:Math.floor(f-u)})}return e}function dl(n){if(n.groups.length===0)return!1;const e=ut(n),t=kr(n).sort((a,o)=>a.offset-o.offset),i=t[t.length-1];i.count=Math.min(e-i.offset,i.count);let s=0;return t.forEach(({count:a})=>s+=a),e!==s}function Mi(n,e,t,i,s){let a=1/0,o=1/0,c=1/0,u=-1/0,f=-1/0,p=-1/0,r=1/0,l=1/0,h=1/0,g=-1/0,_=-1/0,m=-1/0;for(let v=e*6,y=(e+t)*6;v<y;v+=6){const x=n[v+0],w=n[v+1],b=x-w,A=x+w;b<a&&(a=b),A>u&&(u=A),x<r&&(r=x),x>g&&(g=x);const T=n[v+2],I=n[v+3],C=T-I,P=T+I;C<o&&(o=C),P>f&&(f=P),T<l&&(l=T),T>_&&(_=T);const D=n[v+4],S=n[v+5],M=D-S,R=D+S;M<c&&(c=M),R>p&&(p=R),D<h&&(h=D),D>m&&(m=D)}i[0]=a,i[1]=o,i[2]=c,i[3]=u,i[4]=f,i[5]=p,s[0]=r,s[1]=l,s[2]=h,s[3]=g,s[4]=_,s[5]=m}function pl(n,e=null,t=null,i=null){const s=n.attributes.position,a=n.index?n.index.array:null,o=ut(n),c=s.normalized;let u;e===null?(u=new Float32Array(o*6*4),t=0,i=o):(u=e,t=t||0,i=i||o);const f=s.array,p=s.offset||0;let r=3;s.isInterleavedBufferAttribute&&(r=s.data.stride);const l=["getX","getY","getZ"];for(let h=t;h<t+i;h++){const g=h*3,_=h*6;let m=g+0,v=g+1,y=g+2;a&&(m=a[m],v=a[v],y=a[y]),c||(m=m*r+p,v=v*r+p,y=y*r+p);for(let x=0;x<3;x++){let w,b,A;c?(w=s[l[x]](m),b=s[l[x]](v),A=s[l[x]](y)):(w=f[m+x],b=f[v+x],A=f[y+x]);let T=w;b<T&&(T=b),A<T&&(T=A);let I=w;b>I&&(I=b),A>I&&(I=A);const C=(I-T)/2,P=x*2;u[_+P+0]=T+C,u[_+P+1]=C+(Math.abs(T)+C)*cl}}return u}function N(n,e,t){return t.min.x=e[n],t.min.y=e[n+1],t.min.z=e[n+2],t.max.x=e[n+3],t.max.y=e[n+4],t.max.z=e[n+5],t}function Js(n){let e=-1,t=-1/0;for(let i=0;i<3;i++){const s=n[i+3]-n[i];s>t&&(t=s,e=i)}return e}function $s(n,e){e.set(n)}function er(n,e,t){let i,s;for(let a=0;a<3;a++){const o=a+3;i=n[a],s=e[a],t[a]=i<s?i:s,i=n[o],s=e[o],t[o]=i>s?i:s}}function Ut(n,e,t){for(let i=0;i<3;i++){const s=e[n+2*i],a=e[n+2*i+1],o=s-a,c=s+a;o<t[i]&&(t[i]=o),c>t[i+3]&&(t[i+3]=c)}}function yt(n){const e=n[3]-n[0],t=n[4]-n[1],i=n[5]-n[2];return 2*(e*t+t*i+i*e)}const me=32,ml=(n,e)=>n.candidate-e.candidate,Te=new Array(me).fill().map(()=>({count:0,bounds:new Float32Array(6),rightCacheBounds:new Float32Array(6),leftCacheBounds:new Float32Array(6),candidate:0})),Ht=new Float32Array(6);function gl(n,e,t,i,s,a){let o=-1,c=0;if(a===Fr)o=Js(e),o!==-1&&(c=(e[o]+e[o+3])/2);else if(a===al)o=Js(n),o!==-1&&(c=vl(t,i,s,o));else if(a===ll){const u=yt(n);let f=Ti*s;const p=i*6,r=(i+s)*6;for(let l=0;l<3;l++){const h=e[l],m=(e[l+3]-h)/me;if(s<me/4){const v=[...Te];v.length=s;let y=0;for(let w=p;w<r;w+=6,y++){const b=v[y];b.candidate=t[w+2*l],b.count=0;const{bounds:A,leftCacheBounds:T,rightCacheBounds:I}=b;for(let C=0;C<3;C++)I[C]=1/0,I[C+3]=-1/0,T[C]=1/0,T[C+3]=-1/0,A[C]=1/0,A[C+3]=-1/0;Ut(w,t,A)}v.sort(ml);let x=s;for(let w=0;w<x;w++){const b=v[w];for(;w+1<x&&v[w+1].candidate===b.candidate;)v.splice(w+1,1),x--}for(let w=p;w<r;w+=6){const b=t[w+2*l];for(let A=0;A<x;A++){const T=v[A];b>=T.candidate?Ut(w,t,T.rightCacheBounds):(Ut(w,t,T.leftCacheBounds),T.count++)}}for(let w=0;w<x;w++){const b=v[w],A=b.count,T=s-b.count,I=b.leftCacheBounds,C=b.rightCacheBounds;let P=0;A!==0&&(P=yt(I)/u);let D=0;T!==0&&(D=yt(C)/u);const S=Ks+Ti*(P*A+D*T);S<f&&(o=l,f=S,c=b.candidate)}}else{for(let x=0;x<me;x++){const w=Te[x];w.count=0,w.candidate=h+m+x*m;const b=w.bounds;for(let A=0;A<3;A++)b[A]=1/0,b[A+3]=-1/0}for(let x=p;x<r;x+=6){let A=~~((t[x+2*l]-h)/m);A>=me&&(A=me-1);const T=Te[A];T.count++,Ut(x,t,T.bounds)}const v=Te[me-1];$s(v.bounds,v.rightCacheBounds);for(let x=me-2;x>=0;x--){const w=Te[x],b=Te[x+1];er(w.bounds,b.rightCacheBounds,w.rightCacheBounds)}let y=0;for(let x=0;x<me-1;x++){const w=Te[x],b=w.count,A=w.bounds,I=Te[x+1].rightCacheBounds;b!==0&&(y===0?$s(A,Ht):er(A,Ht,Ht)),y+=b;let C=0,P=0;y!==0&&(C=yt(Ht)/u);const D=s-y;D!==0&&(P=yt(I)/u);const S=Ks+Ti*(C*y+P*D);S<f&&(o=l,f=S,c=w.candidate)}}}}else console.warn(`MeshBVH: Invalid build strategy value ${a} used.`);return{axis:o,pos:c}}function vl(n,e,t,i){let s=0;for(let a=e,o=e+t;a<o;a++)s+=n[a*6+i*2];return s/t}class Ci{constructor(){this.boundingData=new Float32Array(6)}}function _l(n,e,t,i,s,a){let o=i,c=i+s-1;const u=a.pos,f=a.axis*2;for(;;){for(;o<=c&&t[o*6+f]<u;)o++;for(;o<=c&&t[c*6+f]>=u;)c--;if(o<c){for(let p=0;p<3;p++){let r=e[o*3+p];e[o*3+p]=e[c*3+p],e[c*3+p]=r}for(let p=0;p<6;p++){let r=t[o*6+p];t[o*6+p]=t[c*6+p],t[c*6+p]=r}o++,c--}else return o}}function yl(n,e,t,i,s,a){let o=i,c=i+s-1;const u=a.pos,f=a.axis*2;for(;;){for(;o<=c&&t[o*6+f]<u;)o++;for(;o<=c&&t[c*6+f]>=u;)c--;if(o<c){let p=n[o];n[o]=n[c],n[c]=p;for(let r=0;r<6;r++){let l=t[o*6+r];t[o*6+r]=t[c*6+r],t[c*6+r]=l}o++,c--}else return o}}function K(n,e){return e[n+15]===65535}function ee(n,e){return e[n+6]}function te(n,e){return e[n+14]}function ie(n){return n+8}function se(n,e){return e[n+6]}function Or(n,e){return e[n+7]}let zr,Mt,ii,Vr;const xl=Math.pow(2,32);function qi(n){return"count"in n?1:1+qi(n.left)+qi(n.right)}function wl(n,e,t){return zr=new Float32Array(t),Mt=new Uint32Array(t),ii=new Uint16Array(t),Vr=new Uint8Array(t),ji(n,e)}function ji(n,e){const t=n/4,i=n/2,s="count"in e,a=e.boundingData;for(let o=0;o<6;o++)zr[t+o]=a[o];if(s)if(e.buffer){const o=e.buffer;Vr.set(new Uint8Array(o),n);for(let c=n,u=n+o.byteLength;c<u;c+=Pt){const f=c/2;K(f,ii)||(Mt[c/4+6]+=t)}return n+o.byteLength}else{const o=e.offset,c=e.count;return Mt[t+6]=o,ii[i+14]=c,ii[i+15]=hi,n+Pt}else{const o=e.left,c=e.right,u=e.splitAxis;let f;if(f=ji(n+Pt,o),f/4>xl)throw new Error("MeshBVH: Cannot store child pointer greater than 32 bits.");return Mt[t+6]=f/4,f=ji(f,c),Mt[t+7]=u,f}}function bl(n,e){const t=(n.index?n.index.count:n.attributes.position.count)/3,i=t>2**16,s=i?4:2,a=e?new SharedArrayBuffer(t*s):new ArrayBuffer(t*s),o=i?new Uint32Array(a):new Uint16Array(a);for(let c=0,u=o.length;c<u;c++)o[c]=c;return o}function Al(n,e,t,i,s){const{maxDepth:a,verbose:o,maxLeafTris:c,strategy:u,onProgress:f,indirect:p}=s,r=n._indirectBuffer,l=n.geometry,h=l.index?l.index.array:null,g=p?yl:_l,_=ut(l),m=new Float32Array(6);let v=!1;const y=new Ci;return Mi(e,t,i,y.boundingData,m),w(y,t,i,m),y;function x(b){f&&f(b/_)}function w(b,A,T,I=null,C=0){if(!v&&C>=a&&(v=!0,o&&(console.warn(`MeshBVH: Max depth of ${a} reached when generating BVH. Consider increasing maxDepth.`),console.warn(l))),T<=c||C>=a)return x(A+T),b.offset=A,b.count=T,b;const P=gl(b.boundingData,I,e,A,T,u);if(P.axis===-1)return x(A+T),b.offset=A,b.count=T,b;const D=g(r,h,e,A,T,P);if(D===A||D===A+T)x(A+T),b.offset=A,b.count=T;else{b.splitAxis=P.axis;const S=new Ci,M=A,R=D-A;b.left=S,Mi(e,M,R,S.boundingData,m),w(S,M,R,m,C+1);const E=new Ci,F=D,O=T-R;b.right=E,Mi(e,F,O,E.boundingData,m),w(E,F,O,m,C+1)}return b}}function Tl(n,e){const t=n.geometry;e.indirect&&(n._indirectBuffer=bl(t,e.useSharedArrayBuffer),dl(t)&&!e.verbose&&console.warn('MeshBVH: Provided geometry contains groups that do not fully span the vertex contents while using the "indirect" option. BVH may incorrectly report intersections on unrendered portions of the geometry.')),n._indirectBuffer||fl(t,e);const i=e.useSharedArrayBuffer?SharedArrayBuffer:ArrayBuffer,s=pl(t),a=e.indirect?Br(t):kr(t);n._roots=a.map(o=>{const c=Al(n,s,o.offset,o.count,e),u=qi(c),f=new i(Pt*u);return wl(0,c,f),f})}class we{constructor(){this.min=1/0,this.max=-1/0}setFromPointsField(e,t){let i=1/0,s=-1/0;for(let a=0,o=e.length;a<o;a++){const u=e[a][t];i=u<i?u:i,s=u>s?u:s}this.min=i,this.max=s}setFromPoints(e,t){let i=1/0,s=-1/0;for(let a=0,o=t.length;a<o;a++){const c=t[a],u=e.dot(c);i=u<i?u:i,s=u>s?u:s}this.min=i,this.max=s}isSeparated(e){return this.min>e.max||e.min>this.max}}we.prototype.setFromBox=function(){const n=new d.Vector3;return function(t,i){const s=i.min,a=i.max;let o=1/0,c=-1/0;for(let u=0;u<=1;u++)for(let f=0;f<=1;f++)for(let p=0;p<=1;p++){n.x=s.x*u+a.x*(1-u),n.y=s.y*f+a.y*(1-f),n.z=s.z*p+a.z*(1-p);const r=t.dot(n);o=Math.min(r,o),c=Math.max(r,c)}this.min=o,this.max=c}}();const Sl=function(){const n=new d.Vector3,e=new d.Vector3,t=new d.Vector3;return function(s,a,o){const c=s.start,u=n,f=a.start,p=e;t.subVectors(c,f),n.subVectors(s.end,s.start),e.subVectors(a.end,a.start);const r=t.dot(p),l=p.dot(u),h=p.dot(p),g=t.dot(u),m=u.dot(u)*h-l*l;let v,y;m!==0?v=(r*l-g*h)/m:v=0,y=(r+v*l)/h,o.x=v,o.y=y}}(),hs=function(){const n=new d.Vector2,e=new d.Vector3,t=new d.Vector3;return function(s,a,o,c){Sl(s,a,n);let u=n.x,f=n.y;if(u>=0&&u<=1&&f>=0&&f<=1){s.at(u,o),a.at(f,c);return}else if(u>=0&&u<=1){f<0?a.at(0,c):a.at(1,c),s.closestPointToPoint(c,!0,o);return}else if(f>=0&&f<=1){u<0?s.at(0,o):s.at(1,o),a.closestPointToPoint(o,!0,c);return}else{let p;u<0?p=s.start:p=s.end;let r;f<0?r=a.start:r=a.end;const l=e,h=t;if(s.closestPointToPoint(r,!0,e),a.closestPointToPoint(p,!0,t),l.distanceToSquared(r)<=h.distanceToSquared(p)){o.copy(l),c.copy(r);return}else{o.copy(p),c.copy(h);return}}}}(),Ml=function(){const n=new d.Vector3,e=new d.Vector3,t=new d.Plane,i=new d.Line3;return function(a,o){const{radius:c,center:u}=a,{a:f,b:p,c:r}=o;if(i.start=f,i.end=p,i.closestPointToPoint(u,!0,n).distanceTo(u)<=c||(i.start=f,i.end=r,i.closestPointToPoint(u,!0,n).distanceTo(u)<=c)||(i.start=p,i.end=r,i.closestPointToPoint(u,!0,n).distanceTo(u)<=c))return!0;const _=o.getPlane(t);if(Math.abs(_.distanceToPoint(u))<=c){const v=_.projectPoint(u,e);if(o.containsPoint(v))return!0}return!1}}(),Cl=1e-15;function Ii(n){return Math.abs(n)<Cl}class ce extends d.Triangle{constructor(...e){super(...e),this.isExtendedTriangle=!0,this.satAxes=new Array(4).fill().map(()=>new d.Vector3),this.satBounds=new Array(4).fill().map(()=>new we),this.points=[this.a,this.b,this.c],this.sphere=new d.Sphere,this.plane=new d.Plane,this.needsUpdate=!0}intersectsSphere(e){return Ml(e,this)}update(){const e=this.a,t=this.b,i=this.c,s=this.points,a=this.satAxes,o=this.satBounds,c=a[0],u=o[0];this.getNormal(c),u.setFromPoints(c,s);const f=a[1],p=o[1];f.subVectors(e,t),p.setFromPoints(f,s);const r=a[2],l=o[2];r.subVectors(t,i),l.setFromPoints(r,s);const h=a[3],g=o[3];h.subVectors(i,e),g.setFromPoints(h,s),this.sphere.setFromPoints(this.points),this.plane.setFromNormalAndCoplanarPoint(c,e),this.needsUpdate=!1}}ce.prototype.closestPointToSegment=function(){const n=new d.Vector3,e=new d.Vector3,t=new d.Line3;return function(s,a=null,o=null){const{start:c,end:u}=s,f=this.points;let p,r=1/0;for(let l=0;l<3;l++){const h=(l+1)%3;t.start.copy(f[l]),t.end.copy(f[h]),hs(t,s,n,e),p=n.distanceToSquared(e),p<r&&(r=p,a&&a.copy(n),o&&o.copy(e))}return this.closestPointToPoint(c,n),p=c.distanceToSquared(n),p<r&&(r=p,a&&a.copy(n),o&&o.copy(c)),this.closestPointToPoint(u,n),p=u.distanceToSquared(n),p<r&&(r=p,a&&a.copy(n),o&&o.copy(u)),Math.sqrt(r)}}();ce.prototype.intersectsTriangle=function(){const n=new ce,e=new Array(3),t=new Array(3),i=new we,s=new we,a=new d.Vector3,o=new d.Vector3,c=new d.Vector3,u=new d.Vector3,f=new d.Vector3,p=new d.Line3,r=new d.Line3,l=new d.Line3,h=new d.Vector3;function g(_,m,v){const y=_.points;let x=0,w=-1;for(let b=0;b<3;b++){const{start:A,end:T}=p;A.copy(y[b]),T.copy(y[(b+1)%3]),p.delta(o);const I=Ii(m.distanceToPoint(A));if(Ii(m.normal.dot(o))&&I){v.copy(p),x=2;break}const C=m.intersectLine(p,h);if(!C&&I&&h.copy(A),(C||I)&&!Ii(h.distanceTo(T))){if(x<=1)(x===1?v.start:v.end).copy(h),I&&(w=x);else if(x>=2){(w===1?v.start:v.end).copy(h),x=2;break}if(x++,x===2&&w===-1)break}}return x}return function(m,v=null,y=!1){this.needsUpdate&&this.update(),m.isExtendedTriangle?m.needsUpdate&&m.update():(n.copy(m),n.update(),m=n);const x=this.plane,w=m.plane;if(Math.abs(x.normal.dot(w.normal))>1-1e-10){const b=this.satBounds,A=this.satAxes;t[0]=m.a,t[1]=m.b,t[2]=m.c;for(let C=0;C<4;C++){const P=b[C],D=A[C];if(i.setFromPoints(D,t),P.isSeparated(i))return!1}const T=m.satBounds,I=m.satAxes;e[0]=this.a,e[1]=this.b,e[2]=this.c;for(let C=0;C<4;C++){const P=T[C],D=I[C];if(i.setFromPoints(D,e),P.isSeparated(i))return!1}for(let C=0;C<4;C++){const P=A[C];for(let D=0;D<4;D++){const S=I[D];if(a.crossVectors(P,S),i.setFromPoints(a,e),s.setFromPoints(a,t),i.isSeparated(s))return!1}}return v&&(y||console.warn("ExtendedTriangle.intersectsTriangle: Triangles are coplanar which does not support an output edge. Setting edge to 0, 0, 0."),v.start.set(0,0,0),v.end.set(0,0,0)),!0}else{const b=g(this,w,r);if(b===1&&m.containsPoint(r.end))return v&&(v.start.copy(r.end),v.end.copy(r.end)),!0;if(b!==2)return!1;const A=g(m,x,l);if(A===1&&this.containsPoint(l.end))return v&&(v.start.copy(l.end),v.end.copy(l.end)),!0;if(A!==2)return!1;if(r.delta(c),l.delta(u),c.dot(u)<0){let M=l.start;l.start=l.end,l.end=M}const T=r.start.dot(c),I=r.end.dot(c),C=l.start.dot(c),P=l.end.dot(c),D=I<C,S=T<P;return T!==P&&C!==I&&D===S?!1:(v&&(f.subVectors(r.start,l.start),f.dot(c)>0?v.start.copy(r.start):v.start.copy(l.start),f.subVectors(r.end,l.end),f.dot(c)<0?v.end.copy(r.end):v.end.copy(l.end)),!0)}}}();ce.prototype.distanceToPoint=function(){const n=new d.Vector3;return function(t){return this.closestPointToPoint(t,n),t.distanceTo(n)}}();ce.prototype.distanceToTriangle=function(){const n=new d.Vector3,e=new d.Vector3,t=["a","b","c"],i=new d.Line3,s=new d.Line3;return function(o,c=null,u=null){const f=c||u?i:null;if(this.intersectsTriangle(o,f))return(c||u)&&(c&&f.getCenter(c),u&&f.getCenter(u)),0;let p=1/0;for(let r=0;r<3;r++){let l;const h=t[r],g=o[h];this.closestPointToPoint(g,n),l=g.distanceToSquared(n),l<p&&(p=l,c&&c.copy(n),u&&u.copy(g));const _=this[h];o.closestPointToPoint(_,n),l=_.distanceToSquared(n),l<p&&(p=l,c&&c.copy(_),u&&u.copy(n))}for(let r=0;r<3;r++){const l=t[r],h=t[(r+1)%3];i.set(this[l],this[h]);for(let g=0;g<3;g++){const _=t[g],m=t[(g+1)%3];s.set(o[_],o[m]),hs(i,s,n,e);const v=n.distanceToSquared(e);v<p&&(p=v,c&&c.copy(n),u&&u.copy(e))}}return Math.sqrt(p)}}();class Q{constructor(e,t,i){this.isOrientedBox=!0,this.min=new d.Vector3,this.max=new d.Vector3,this.matrix=new d.Matrix4,this.invMatrix=new d.Matrix4,this.points=new Array(8).fill().map(()=>new d.Vector3),this.satAxes=new Array(3).fill().map(()=>new d.Vector3),this.satBounds=new Array(3).fill().map(()=>new we),this.alignedSatBounds=new Array(3).fill().map(()=>new we),this.needsUpdate=!1,e&&this.min.copy(e),t&&this.max.copy(t),i&&this.matrix.copy(i)}set(e,t,i){this.min.copy(e),this.max.copy(t),this.matrix.copy(i),this.needsUpdate=!0}copy(e){this.min.copy(e.min),this.max.copy(e.max),this.matrix.copy(e.matrix),this.needsUpdate=!0}}Q.prototype.update=function(){return function(){const e=this.matrix,t=this.min,i=this.max,s=this.points;for(let f=0;f<=1;f++)for(let p=0;p<=1;p++)for(let r=0;r<=1;r++){const l=1*f|2*p|4*r,h=s[l];h.x=f?i.x:t.x,h.y=p?i.y:t.y,h.z=r?i.z:t.z,h.applyMatrix4(e)}const a=this.satBounds,o=this.satAxes,c=s[0];for(let f=0;f<3;f++){const p=o[f],r=a[f],l=1<<f,h=s[l];p.subVectors(c,h),r.setFromPoints(p,s)}const u=this.alignedSatBounds;u[0].setFromPointsField(s,"x"),u[1].setFromPointsField(s,"y"),u[2].setFromPointsField(s,"z"),this.invMatrix.copy(this.matrix).invert(),this.needsUpdate=!1}}();Q.prototype.intersectsBox=function(){const n=new we;return function(t){this.needsUpdate&&this.update();const i=t.min,s=t.max,a=this.satBounds,o=this.satAxes,c=this.alignedSatBounds;if(n.min=i.x,n.max=s.x,c[0].isSeparated(n)||(n.min=i.y,n.max=s.y,c[1].isSeparated(n))||(n.min=i.z,n.max=s.z,c[2].isSeparated(n)))return!1;for(let u=0;u<3;u++){const f=o[u],p=a[u];if(n.setFromBox(f,t),p.isSeparated(n))return!1}return!0}}();Q.prototype.intersectsTriangle=function(){const n=new ce,e=new Array(3),t=new we,i=new we,s=new d.Vector3;return function(o){this.needsUpdate&&this.update(),o.isExtendedTriangle?o.needsUpdate&&o.update():(n.copy(o),n.update(),o=n);const c=this.satBounds,u=this.satAxes;e[0]=o.a,e[1]=o.b,e[2]=o.c;for(let l=0;l<3;l++){const h=c[l],g=u[l];if(t.setFromPoints(g,e),h.isSeparated(t))return!1}const f=o.satBounds,p=o.satAxes,r=this.points;for(let l=0;l<3;l++){const h=f[l],g=p[l];if(t.setFromPoints(g,r),h.isSeparated(t))return!1}for(let l=0;l<3;l++){const h=u[l];for(let g=0;g<4;g++){const _=p[g];if(s.crossVectors(h,_),t.setFromPoints(s,e),i.setFromPoints(s,r),t.isSeparated(i))return!1}}return!0}}();Q.prototype.closestPointToPoint=function(){return function(e,t){return this.needsUpdate&&this.update(),t.copy(e).applyMatrix4(this.invMatrix).clamp(this.min,this.max).applyMatrix4(this.matrix),t}}();Q.prototype.distanceToPoint=function(){const n=new d.Vector3;return function(t){return this.closestPointToPoint(t,n),t.distanceTo(n)}}();Q.prototype.distanceToBox=function(){const n=["x","y","z"],e=new Array(12).fill().map(()=>new d.Line3),t=new Array(12).fill().map(()=>new d.Line3),i=new d.Vector3,s=new d.Vector3;return function(o,c=0,u=null,f=null){if(this.needsUpdate&&this.update(),this.intersectsBox(o))return(u||f)&&(o.getCenter(s),this.closestPointToPoint(s,i),o.closestPointToPoint(i,s),u&&u.copy(i),f&&f.copy(s)),0;const p=c*c,r=o.min,l=o.max,h=this.points;let g=1/0;for(let m=0;m<8;m++){const v=h[m];s.copy(v).clamp(r,l);const y=v.distanceToSquared(s);if(y<g&&(g=y,u&&u.copy(v),f&&f.copy(s),y<p))return Math.sqrt(y)}let _=0;for(let m=0;m<3;m++)for(let v=0;v<=1;v++)for(let y=0;y<=1;y++){const x=(m+1)%3,w=(m+2)%3,b=v<<x|y<<w,A=1<<m|v<<x|y<<w,T=h[b],I=h[A];e[_].set(T,I);const P=n[m],D=n[x],S=n[w],M=t[_],R=M.start,E=M.end;R[P]=r[P],R[D]=v?r[D]:l[D],R[S]=y?r[S]:l[D],E[P]=l[P],E[D]=v?r[D]:l[D],E[S]=y?r[S]:l[D],_++}for(let m=0;m<=1;m++)for(let v=0;v<=1;v++)for(let y=0;y<=1;y++){s.x=m?l.x:r.x,s.y=v?l.y:r.y,s.z=y?l.z:r.z,this.closestPointToPoint(s,i);const x=s.distanceToSquared(i);if(x<g&&(g=x,u&&u.copy(i),f&&f.copy(s),x<p))return Math.sqrt(x)}for(let m=0;m<12;m++){const v=e[m];for(let y=0;y<12;y++){const x=t[y];hs(v,x,i,s);const w=i.distanceToSquared(s);if(w<g&&(g=w,u&&u.copy(i),f&&f.copy(s),w<p))return Math.sqrt(w)}}return Math.sqrt(g)}}();class fs{constructor(e){this._getNewPrimitive=e,this._primitives=[]}getPrimitive(){const e=this._primitives;return e.length===0?this._getNewPrimitive():e.pop()}releasePrimitive(e){this._primitives.push(e)}}class Il extends fs{constructor(){super(()=>new ce)}}const re=new Il;class Rl{constructor(){this.float32Array=null,this.uint16Array=null,this.uint32Array=null;const e=[];let t=null;this.setBuffer=i=>{t&&e.push(t),t=i,this.float32Array=new Float32Array(i),this.uint16Array=new Uint16Array(i),this.uint32Array=new Uint32Array(i)},this.clearBuffer=()=>{t=null,this.float32Array=null,this.uint16Array=null,this.uint32Array=null,e.length!==0&&this.setBuffer(e.pop())}}}const U=new Rl;let Re,et;const He=[],Nt=new fs(()=>new d.Box3);function Pl(n,e,t,i,s,a){Re=Nt.getPrimitive(),et=Nt.getPrimitive(),He.push(Re,et),U.setBuffer(n._roots[e]);const o=Yi(0,n.geometry,t,i,s,a);U.clearBuffer(),Nt.releasePrimitive(Re),Nt.releasePrimitive(et),He.pop(),He.pop();const c=He.length;return c>0&&(et=He[c-1],Re=He[c-2]),o}function Yi(n,e,t,i,s=null,a=0,o=0){const{float32Array:c,uint16Array:u,uint32Array:f}=U;let p=n*2;if(K(p,u)){const l=ee(n,f),h=te(p,u);return N(n,c,Re),i(l,h,!1,o,a+n,Re)}else{let P=function(S){const{uint16Array:M,uint32Array:R}=U;let E=S*2;for(;!K(E,M);)S=ie(S),E=S*2;return ee(S,R)},D=function(S){const{uint16Array:M,uint32Array:R}=U;let E=S*2;for(;!K(E,M);)S=se(S,R),E=S*2;return ee(S,R)+te(E,M)};const l=ie(n),h=se(n,f);let g=l,_=h,m,v,y,x;if(s&&(y=Re,x=et,N(g,c,y),N(_,c,x),m=s(y),v=s(x),v<m)){g=h,_=l;const S=m;m=v,v=S,y=x}y||(y=Re,N(g,c,y));const w=K(g*2,u),b=t(y,w,m,o+1,a+g);let A;if(b===Xs){const S=P(g),R=D(g)-S;A=i(S,R,!0,o+1,a+g,y)}else A=b&&Yi(g,e,t,i,s,a,o+1);if(A)return!0;x=et,N(_,c,x);const T=K(_*2,u),I=t(x,T,v,o+1,a+_);let C;if(I===Xs){const S=P(_),R=D(_)-S;C=i(S,R,!0,o+1,a+_,x)}else C=I&&Yi(_,e,t,i,s,a,o+1);return!!C}}const xt=new d.Vector3,Ri=new d.Vector3;function Dl(n,e,t={},i=0,s=1/0){const a=i*i,o=s*s;let c=1/0,u=null;if(n.shapecast({boundsTraverseOrder:p=>(xt.copy(e).clamp(p.min,p.max),xt.distanceToSquared(e)),intersectsBounds:(p,r,l)=>l<c&&l<o,intersectsTriangle:(p,r)=>{p.closestPointToPoint(e,xt);const l=e.distanceToSquared(xt);return l<c&&(Ri.copy(xt),c=l,u=r),l<a}}),c===1/0)return null;const f=Math.sqrt(c);return t.point?t.point.copy(Ri):t.point=Ri.clone(),t.distance=f,t.faceIndex=u,t}const Ne=new d.Vector3,We=new d.Vector3,Ge=new d.Vector3,Wt=new d.Vector2,Gt=new d.Vector2,qt=new d.Vector2,tr=new d.Vector3,ir=new d.Vector3,sr=new d.Vector3,jt=new d.Vector3;function Ll(n,e,t,i,s,a,o,c){let u;if(a===d.BackSide?u=n.intersectTriangle(i,t,e,!0,s):u=n.intersectTriangle(e,t,i,a!==d.DoubleSide,s),u===null)return null;const f=n.origin.distanceTo(s);return f<o||f>c?null:{distance:f,point:s.clone()}}function El(n,e,t,i,s,a,o,c,u,f,p){Ne.fromBufferAttribute(e,a),We.fromBufferAttribute(e,o),Ge.fromBufferAttribute(e,c);const r=Ll(n,Ne,We,Ge,jt,u,f,p);if(r){i&&(Wt.fromBufferAttribute(i,a),Gt.fromBufferAttribute(i,o),qt.fromBufferAttribute(i,c),r.uv=d.Triangle.getInterpolation(jt,Ne,We,Ge,Wt,Gt,qt,new d.Vector2)),s&&(Wt.fromBufferAttribute(s,a),Gt.fromBufferAttribute(s,o),qt.fromBufferAttribute(s,c),r.uv1=d.Triangle.getInterpolation(jt,Ne,We,Ge,Wt,Gt,qt,new d.Vector2)),t&&(tr.fromBufferAttribute(t,a),ir.fromBufferAttribute(t,o),sr.fromBufferAttribute(t,c),r.normal=d.Triangle.getInterpolation(jt,Ne,We,Ge,tr,ir,sr,new d.Vector3),r.normal.dot(n.direction)>0&&r.normal.multiplyScalar(-1));const l={a,b:o,c,normal:new d.Vector3,materialIndex:0};d.Triangle.getNormal(Ne,We,Ge,l.normal),r.face=l,r.faceIndex=a}return r}function fi(n,e,t,i,s,a,o){const c=i*3;let u=c+0,f=c+1,p=c+2;const r=n.index;n.index&&(u=r.getX(u),f=r.getX(f),p=r.getX(p));const{position:l,normal:h,uv:g,uv1:_}=n.attributes,m=El(t,l,h,g,_,u,f,p,e,a,o);return m?(m.faceIndex=i,s&&s.push(m),m):null}function G(n,e,t,i){const s=n.a,a=n.b,o=n.c;let c=e,u=e+1,f=e+2;t&&(c=t.getX(c),u=t.getX(u),f=t.getX(f)),s.x=i.getX(c),s.y=i.getY(c),s.z=i.getZ(c),a.x=i.getX(u),a.y=i.getY(u),a.z=i.getZ(u),o.x=i.getX(f),o.y=i.getY(f),o.z=i.getZ(f)}function Fl(n,e,t,i,s,a,o,c){const{geometry:u,_indirectBuffer:f}=n;for(let p=i,r=i+s;p<r;p++)fi(u,e,t,p,a,o,c)}function Bl(n,e,t,i,s,a,o){const{geometry:c,_indirectBuffer:u}=n;let f=1/0,p=null;for(let r=i,l=i+s;r<l;r++){let h;h=fi(c,e,t,r,null,a,o),h&&h.distance<f&&(p=h,f=h.distance)}return p}function kl(n,e,t,i,s,a,o){const{geometry:c}=t,{index:u}=c,f=c.attributes.position;for(let p=n,r=e+n;p<r;p++){let l;if(l=p,G(o,l*3,u,f),o.needsUpdate=!0,i(o,l,s,a))return!0}return!1}function Ol(n,e=null){e&&Array.isArray(e)&&(e=new Set(e));const t=n.geometry,i=t.index?t.index.array:null,s=t.attributes.position;let a,o,c,u,f=0;const p=n._roots;for(let l=0,h=p.length;l<h;l++)a=p[l],o=new Uint32Array(a),c=new Uint16Array(a),u=new Float32Array(a),r(0,f),f+=a.byteLength;function r(l,h,g=!1){const _=l*2;if(c[_+15]===hi){const v=o[l+6],y=c[_+14];let x=1/0,w=1/0,b=1/0,A=-1/0,T=-1/0,I=-1/0;for(let C=3*v,P=3*(v+y);C<P;C++){let D=i[C];const S=s.getX(D),M=s.getY(D),R=s.getZ(D);S<x&&(x=S),S>A&&(A=S),M<w&&(w=M),M>T&&(T=M),R<b&&(b=R),R>I&&(I=R)}return u[l+0]!==x||u[l+1]!==w||u[l+2]!==b||u[l+3]!==A||u[l+4]!==T||u[l+5]!==I?(u[l+0]=x,u[l+1]=w,u[l+2]=b,u[l+3]=A,u[l+4]=T,u[l+5]=I,!0):!1}else{const v=l+8,y=o[l+6],x=v+h,w=y+h;let b=g,A=!1,T=!1;e?b||(A=e.has(x),T=e.has(w),b=!A&&!T):(A=!0,T=!0);const I=b||A,C=b||T;let P=!1;I&&(P=r(v,h,b));let D=!1;C&&(D=r(y,h,b));const S=P||D;if(S)for(let M=0;M<3;M++){const R=v+M,E=y+M,F=u[R],O=u[R+3],H=u[E],W=u[E+3];u[l+M]=F<H?F:H,u[l+M+3]=O>W?O:W}return S}}}function Pe(n,e,t,i,s){let a,o,c,u,f,p;const r=1/t.direction.x,l=1/t.direction.y,h=1/t.direction.z,g=t.origin.x,_=t.origin.y,m=t.origin.z;let v=e[n],y=e[n+3],x=e[n+1],w=e[n+3+1],b=e[n+2],A=e[n+3+2];return r>=0?(a=(v-g)*r,o=(y-g)*r):(a=(y-g)*r,o=(v-g)*r),l>=0?(c=(x-_)*l,u=(w-_)*l):(c=(w-_)*l,u=(x-_)*l),a>u||c>o||((c>a||isNaN(a))&&(a=c),(u<o||isNaN(o))&&(o=u),h>=0?(f=(b-m)*h,p=(A-m)*h):(f=(A-m)*h,p=(b-m)*h),a>p||f>o)?!1:((f>a||a!==a)&&(a=f),(p<o||o!==o)&&(o=p),a<=s&&o>=i)}function zl(n,e,t,i,s,a,o,c){const{geometry:u,_indirectBuffer:f}=n;for(let p=i,r=i+s;p<r;p++){let l=f?f[p]:p;fi(u,e,t,l,a,o,c)}}function Vl(n,e,t,i,s,a,o){const{geometry:c,_indirectBuffer:u}=n;let f=1/0,p=null;for(let r=i,l=i+s;r<l;r++){let h;h=fi(c,e,t,u?u[r]:r,null,a,o),h&&h.distance<f&&(p=h,f=h.distance)}return p}function Ul(n,e,t,i,s,a,o){const{geometry:c}=t,{index:u}=c,f=c.attributes.position;for(let p=n,r=e+n;p<r;p++){let l;if(l=t.resolveTriangleIndex(p),G(o,l*3,u,f),o.needsUpdate=!0,i(o,l,s,a))return!0}return!1}function Hl(n,e,t,i,s,a,o){U.setBuffer(n._roots[e]),Qi(0,n,t,i,s,a,o),U.clearBuffer()}function Qi(n,e,t,i,s,a,o){const{float32Array:c,uint16Array:u,uint32Array:f}=U,p=n*2;if(K(p,u)){const l=ee(n,f),h=te(p,u);Fl(e,t,i,l,h,s,a,o)}else{const l=ie(n);Pe(l,c,i,a,o)&&Qi(l,e,t,i,s,a,o);const h=se(n,f);Pe(h,c,i,a,o)&&Qi(h,e,t,i,s,a,o)}}const Nl=["x","y","z"];function Wl(n,e,t,i,s,a){U.setBuffer(n._roots[e]);const o=Zi(0,n,t,i,s,a);return U.clearBuffer(),o}function Zi(n,e,t,i,s,a){const{float32Array:o,uint16Array:c,uint32Array:u}=U;let f=n*2;if(K(f,c)){const r=ee(n,u),l=te(f,c);return Bl(e,t,i,r,l,s,a)}else{const r=Or(n,u),l=Nl[r],g=i.direction[l]>=0;let _,m;g?(_=ie(n),m=se(n,u)):(_=se(n,u),m=ie(n));const y=Pe(_,o,i,s,a)?Zi(_,e,t,i,s,a):null;if(y){const b=y.point[l];if(g?b<=o[m+r]:b>=o[m+r+3])return y}const w=Pe(m,o,i,s,a)?Zi(m,e,t,i,s,a):null;return y&&w?y.distance<=w.distance?y:w:y||w||null}}const Yt=new d.Box3,qe=new ce,je=new ce,wt=new d.Matrix4,rr=new Q,Qt=new Q;function Gl(n,e,t,i){U.setBuffer(n._roots[e]);const s=Xi(0,n,t,i);return U.clearBuffer(),s}function Xi(n,e,t,i,s=null){const{float32Array:a,uint16Array:o,uint32Array:c}=U;let u=n*2;if(s===null&&(t.boundingBox||t.computeBoundingBox(),rr.set(t.boundingBox.min,t.boundingBox.max,i),s=rr),K(u,o)){const p=e.geometry,r=p.index,l=p.attributes.position,h=t.index,g=t.attributes.position,_=ee(n,c),m=te(u,o);if(wt.copy(i).invert(),t.boundsTree)return N(n,a,Qt),Qt.matrix.copy(wt),Qt.needsUpdate=!0,t.boundsTree.shapecast({intersectsBounds:y=>Qt.intersectsBox(y),intersectsTriangle:y=>{y.a.applyMatrix4(i),y.b.applyMatrix4(i),y.c.applyMatrix4(i),y.needsUpdate=!0;for(let x=_*3,w=(m+_)*3;x<w;x+=3)if(G(je,x,r,l),je.needsUpdate=!0,y.intersectsTriangle(je))return!0;return!1}});for(let v=_*3,y=(m+_)*3;v<y;v+=3){G(qe,v,r,l),qe.a.applyMatrix4(wt),qe.b.applyMatrix4(wt),qe.c.applyMatrix4(wt),qe.needsUpdate=!0;for(let x=0,w=h.count;x<w;x+=3)if(G(je,x,h,g),je.needsUpdate=!0,qe.intersectsTriangle(je))return!0}}else{const p=n+8,r=c[n+6];return N(p,a,Yt),!!(s.intersectsBox(Yt)&&Xi(p,e,t,i,s)||(N(r,a,Yt),s.intersectsBox(Yt)&&Xi(r,e,t,i,s)))}}const Zt=new d.Matrix4,Pi=new Q,bt=new Q,ql=new d.Vector3,jl=new d.Vector3,Yl=new d.Vector3,Ql=new d.Vector3;function Zl(n,e,t,i={},s={},a=0,o=1/0){e.boundingBox||e.computeBoundingBox(),Pi.set(e.boundingBox.min,e.boundingBox.max,t),Pi.needsUpdate=!0;const c=n.geometry,u=c.attributes.position,f=c.index,p=e.attributes.position,r=e.index,l=re.getPrimitive(),h=re.getPrimitive();let g=ql,_=jl,m=null,v=null;s&&(m=Yl,v=Ql);let y=1/0,x=null,w=null;return Zt.copy(t).invert(),bt.matrix.copy(Zt),n.shapecast({boundsTraverseOrder:b=>Pi.distanceToBox(b),intersectsBounds:(b,A,T)=>T<y&&T<o?(A&&(bt.min.copy(b.min),bt.max.copy(b.max),bt.needsUpdate=!0),!0):!1,intersectsRange:(b,A)=>{if(e.boundsTree)return e.boundsTree.shapecast({boundsTraverseOrder:I=>bt.distanceToBox(I),intersectsBounds:(I,C,P)=>P<y&&P<o,intersectsRange:(I,C)=>{for(let P=I,D=I+C;P<D;P++){G(h,3*P,r,p),h.a.applyMatrix4(t),h.b.applyMatrix4(t),h.c.applyMatrix4(t),h.needsUpdate=!0;for(let S=b,M=b+A;S<M;S++){G(l,3*S,f,u),l.needsUpdate=!0;const R=l.distanceToTriangle(h,g,m);if(R<y&&(_.copy(g),v&&v.copy(m),y=R,x=S,w=P),R<a)return!0}}}});{const T=ut(e);for(let I=0,C=T;I<C;I++){G(h,3*I,r,p),h.a.applyMatrix4(t),h.b.applyMatrix4(t),h.c.applyMatrix4(t),h.needsUpdate=!0;for(let P=b,D=b+A;P<D;P++){G(l,3*P,f,u),l.needsUpdate=!0;const S=l.distanceToTriangle(h,g,m);if(S<y&&(_.copy(g),v&&v.copy(m),y=S,x=P,w=I),S<a)return!0}}}}}),re.releasePrimitive(l),re.releasePrimitive(h),y===1/0?null:(i.point?i.point.copy(_):i.point=_.clone(),i.distance=y,i.faceIndex=x,s&&(s.point?s.point.copy(v):s.point=v.clone(),s.point.applyMatrix4(Zt),_.applyMatrix4(Zt),s.distance=_.sub(s.point).length(),s.faceIndex=w),i)}function Xl(n,e=null){e&&Array.isArray(e)&&(e=new Set(e));const t=n.geometry,i=t.index?t.index.array:null,s=t.attributes.position;let a,o,c,u,f=0;const p=n._roots;for(let l=0,h=p.length;l<h;l++)a=p[l],o=new Uint32Array(a),c=new Uint16Array(a),u=new Float32Array(a),r(0,f),f+=a.byteLength;function r(l,h,g=!1){const _=l*2;if(c[_+15]===hi){const v=o[l+6],y=c[_+14];let x=1/0,w=1/0,b=1/0,A=-1/0,T=-1/0,I=-1/0;for(let C=v,P=v+y;C<P;C++){const D=3*n.resolveTriangleIndex(C);for(let S=0;S<3;S++){let M=D+S;M=i?i[M]:M;const R=s.getX(M),E=s.getY(M),F=s.getZ(M);R<x&&(x=R),R>A&&(A=R),E<w&&(w=E),E>T&&(T=E),F<b&&(b=F),F>I&&(I=F)}}return u[l+0]!==x||u[l+1]!==w||u[l+2]!==b||u[l+3]!==A||u[l+4]!==T||u[l+5]!==I?(u[l+0]=x,u[l+1]=w,u[l+2]=b,u[l+3]=A,u[l+4]=T,u[l+5]=I,!0):!1}else{const v=l+8,y=o[l+6],x=v+h,w=y+h;let b=g,A=!1,T=!1;e?b||(A=e.has(x),T=e.has(w),b=!A&&!T):(A=!0,T=!0);const I=b||A,C=b||T;let P=!1;I&&(P=r(v,h,b));let D=!1;C&&(D=r(y,h,b));const S=P||D;if(S)for(let M=0;M<3;M++){const R=v+M,E=y+M,F=u[R],O=u[R+3],H=u[E],W=u[E+3];u[l+M]=F<H?F:H,u[l+M+3]=O>W?O:W}return S}}}function Kl(n,e,t,i,s,a,o){U.setBuffer(n._roots[e]),Ki(0,n,t,i,s,a,o),U.clearBuffer()}function Ki(n,e,t,i,s,a,o){const{float32Array:c,uint16Array:u,uint32Array:f}=U,p=n*2;if(K(p,u)){const l=ee(n,f),h=te(p,u);zl(e,t,i,l,h,s,a,o)}else{const l=ie(n);Pe(l,c,i,a,o)&&Ki(l,e,t,i,s,a,o);const h=se(n,f);Pe(h,c,i,a,o)&&Ki(h,e,t,i,s,a,o)}}const Jl=["x","y","z"];function $l(n,e,t,i,s,a){U.setBuffer(n._roots[e]);const o=Ji(0,n,t,i,s,a);return U.clearBuffer(),o}function Ji(n,e,t,i,s,a){const{float32Array:o,uint16Array:c,uint32Array:u}=U;let f=n*2;if(K(f,c)){const r=ee(n,u),l=te(f,c);return Vl(e,t,i,r,l,s,a)}else{const r=Or(n,u),l=Jl[r],g=i.direction[l]>=0;let _,m;g?(_=ie(n),m=se(n,u)):(_=se(n,u),m=ie(n));const y=Pe(_,o,i,s,a)?Ji(_,e,t,i,s,a):null;if(y){const b=y.point[l];if(g?b<=o[m+r]:b>=o[m+r+3])return y}const w=Pe(m,o,i,s,a)?Ji(m,e,t,i,s,a):null;return y&&w?y.distance<=w.distance?y:w:y||w||null}}const Xt=new d.Box3,Ye=new ce,Qe=new ce,At=new d.Matrix4,nr=new Q,Kt=new Q;function ec(n,e,t,i){U.setBuffer(n._roots[e]);const s=$i(0,n,t,i);return U.clearBuffer(),s}function $i(n,e,t,i,s=null){const{float32Array:a,uint16Array:o,uint32Array:c}=U;let u=n*2;if(s===null&&(t.boundingBox||t.computeBoundingBox(),nr.set(t.boundingBox.min,t.boundingBox.max,i),s=nr),K(u,o)){const p=e.geometry,r=p.index,l=p.attributes.position,h=t.index,g=t.attributes.position,_=ee(n,c),m=te(u,o);if(At.copy(i).invert(),t.boundsTree)return N(n,a,Kt),Kt.matrix.copy(At),Kt.needsUpdate=!0,t.boundsTree.shapecast({intersectsBounds:y=>Kt.intersectsBox(y),intersectsTriangle:y=>{y.a.applyMatrix4(i),y.b.applyMatrix4(i),y.c.applyMatrix4(i),y.needsUpdate=!0;for(let x=_,w=m+_;x<w;x++)if(G(Qe,3*e.resolveTriangleIndex(x),r,l),Qe.needsUpdate=!0,y.intersectsTriangle(Qe))return!0;return!1}});for(let v=_,y=m+_;v<y;v++){const x=e.resolveTriangleIndex(v);G(Ye,3*x,r,l),Ye.a.applyMatrix4(At),Ye.b.applyMatrix4(At),Ye.c.applyMatrix4(At),Ye.needsUpdate=!0;for(let w=0,b=h.count;w<b;w+=3)if(G(Qe,w,h,g),Qe.needsUpdate=!0,Ye.intersectsTriangle(Qe))return!0}}else{const p=n+8,r=c[n+6];return N(p,a,Xt),!!(s.intersectsBox(Xt)&&$i(p,e,t,i,s)||(N(r,a,Xt),s.intersectsBox(Xt)&&$i(r,e,t,i,s)))}}const Jt=new d.Matrix4,Di=new Q,Tt=new Q,tc=new d.Vector3,ic=new d.Vector3,sc=new d.Vector3,rc=new d.Vector3;function nc(n,e,t,i={},s={},a=0,o=1/0){e.boundingBox||e.computeBoundingBox(),Di.set(e.boundingBox.min,e.boundingBox.max,t),Di.needsUpdate=!0;const c=n.geometry,u=c.attributes.position,f=c.index,p=e.attributes.position,r=e.index,l=re.getPrimitive(),h=re.getPrimitive();let g=tc,_=ic,m=null,v=null;s&&(m=sc,v=rc);let y=1/0,x=null,w=null;return Jt.copy(t).invert(),Tt.matrix.copy(Jt),n.shapecast({boundsTraverseOrder:b=>Di.distanceToBox(b),intersectsBounds:(b,A,T)=>T<y&&T<o?(A&&(Tt.min.copy(b.min),Tt.max.copy(b.max),Tt.needsUpdate=!0),!0):!1,intersectsRange:(b,A)=>{if(e.boundsTree){const T=e.boundsTree;return T.shapecast({boundsTraverseOrder:I=>Tt.distanceToBox(I),intersectsBounds:(I,C,P)=>P<y&&P<o,intersectsRange:(I,C)=>{for(let P=I,D=I+C;P<D;P++){const S=T.resolveTriangleIndex(P);G(h,3*S,r,p),h.a.applyMatrix4(t),h.b.applyMatrix4(t),h.c.applyMatrix4(t),h.needsUpdate=!0;for(let M=b,R=b+A;M<R;M++){const E=n.resolveTriangleIndex(M);G(l,3*E,f,u),l.needsUpdate=!0;const F=l.distanceToTriangle(h,g,m);if(F<y&&(_.copy(g),v&&v.copy(m),y=F,x=M,w=P),F<a)return!0}}}})}else{const T=ut(e);for(let I=0,C=T;I<C;I++){G(h,3*I,r,p),h.a.applyMatrix4(t),h.b.applyMatrix4(t),h.c.applyMatrix4(t),h.needsUpdate=!0;for(let P=b,D=b+A;P<D;P++){const S=n.resolveTriangleIndex(P);G(l,3*S,f,u),l.needsUpdate=!0;const M=l.distanceToTriangle(h,g,m);if(M<y&&(_.copy(g),v&&v.copy(m),y=M,x=P,w=I),M<a)return!0}}}}}),re.releasePrimitive(l),re.releasePrimitive(h),y===1/0?null:(i.point?i.point.copy(_):i.point=_.clone(),i.distance=y,i.faceIndex=x,s&&(s.point?s.point.copy(v):s.point=v.clone(),s.point.applyMatrix4(Jt),_.applyMatrix4(Jt),s.distance=_.sub(s.point).length(),s.faceIndex=w),i)}function oc(){return typeof SharedArrayBuffer<"u"}const Dt=new U.constructor,oi=new U.constructor,Me=new fs(()=>new d.Box3),Ze=new d.Box3,Xe=new d.Box3,Li=new d.Box3,Ei=new d.Box3;let Fi=!1;function ac(n,e,t,i){if(Fi)throw new Error("MeshBVH: Recursive calls to bvhcast not supported.");Fi=!0;const s=n._roots,a=e._roots;let o,c=0,u=0;const f=new d.Matrix4().copy(t).invert();for(let p=0,r=s.length;p<r;p++){Dt.setBuffer(s[p]),u=0;const l=Me.getPrimitive();N(0,Dt.float32Array,l),l.applyMatrix4(f);for(let h=0,g=a.length;h<g&&(oi.setBuffer(a[p]),o=ae(0,0,t,f,i,c,u,0,0,l),oi.clearBuffer(),u+=a[h].length,!o);h++);if(Me.releasePrimitive(l),Dt.clearBuffer(),c+=s[p].length,o)break}return Fi=!1,o}function ae(n,e,t,i,s,a=0,o=0,c=0,u=0,f=null,p=!1){let r,l;p?(r=oi,l=Dt):(r=Dt,l=oi);const h=r.float32Array,g=r.uint32Array,_=r.uint16Array,m=l.float32Array,v=l.uint32Array,y=l.uint16Array,x=n*2,w=e*2,b=K(x,_),A=K(w,y);let T=!1;if(A&&b)p?T=s(ee(e,v),te(e*2,y),ee(n,g),te(n*2,_),u,o+e,c,a+n):T=s(ee(n,g),te(n*2,_),ee(e,v),te(e*2,y),c,a+n,u,o+e);else if(A){const I=Me.getPrimitive();N(e,m,I),I.applyMatrix4(t);const C=ie(n),P=se(n,g);N(C,h,Ze),N(P,h,Xe);const D=I.intersectsBox(Ze),S=I.intersectsBox(Xe);T=D&&ae(e,C,i,t,s,o,a,u,c+1,I,!p)||S&&ae(e,P,i,t,s,o,a,u,c+1,I,!p),Me.releasePrimitive(I)}else{const I=ie(e),C=se(e,v);N(I,m,Li),N(C,m,Ei);const P=f.intersectsBox(Li),D=f.intersectsBox(Ei);if(P&&D)T=ae(n,I,t,i,s,a,o,c,u+1,f,p)||ae(n,C,t,i,s,a,o,c,u+1,f,p);else if(P)if(b)T=ae(n,I,t,i,s,a,o,c,u+1,f,p);else{const S=Me.getPrimitive();S.copy(Li).applyMatrix4(t);const M=ie(n),R=se(n,g);N(M,h,Ze),N(R,h,Xe);const E=S.intersectsBox(Ze),F=S.intersectsBox(Xe);T=E&&ae(I,M,i,t,s,o,a,u,c+1,S,!p)||F&&ae(I,R,i,t,s,o,a,u,c+1,S,!p),Me.releasePrimitive(S)}else if(D)if(b)T=ae(n,C,t,i,s,a,o,c,u+1,f,p);else{const S=Me.getPrimitive();S.copy(Ei).applyMatrix4(t);const M=ie(n),R=se(n,g);N(M,h,Ze),N(R,h,Xe);const E=S.intersectsBox(Ze),F=S.intersectsBox(Xe);T=E&&ae(C,M,i,t,s,o,a,u,c+1,S,!p)||F&&ae(C,R,i,t,s,o,a,u,c+1,S,!p),Me.releasePrimitive(S)}}return T}const $t=new Q,or=new d.Box3,lc={strategy:Fr,maxDepth:40,maxLeafTris:10,useSharedArrayBuffer:!1,setBoundingBox:!0,onProgress:null,indirect:!1,verbose:!0};class ds{static serialize(e,t={}){t={cloneBuffers:!0,...t};const i=e.geometry,s=e._roots,a=e._indirectBuffer,o=i.getIndex();let c;return t.cloneBuffers?c={roots:s.map(u=>u.slice()),index:o?o.array.slice():null,indirectBuffer:a?a.slice():null}:c={roots:s,index:o?o.array:null,indirectBuffer:a},c}static deserialize(e,t,i={}){i={setIndex:!0,indirect:!!e.indirectBuffer,...i};const{index:s,roots:a,indirectBuffer:o}=e,c=new ds(t,{...i,[Si]:!0});if(c._roots=a,c._indirectBuffer=o||null,i.setIndex){const u=t.getIndex();if(u===null){const f=new d.BufferAttribute(e.index,1,!1);t.setIndex(f)}else u.array!==s&&(u.array.set(s),u.needsUpdate=!0)}return c}get indirect(){return!!this._indirectBuffer}constructor(e,t={}){if(e.isBufferGeometry){if(e.index&&e.index.isInterleavedBufferAttribute)throw new Error("MeshBVH: InterleavedBufferAttribute is not supported for the index attribute.")}else throw new Error("MeshBVH: Only BufferGeometries are supported.");if(t=Object.assign({...lc,[Si]:!1},t),t.useSharedArrayBuffer&&!oc())throw new Error("MeshBVH: SharedArrayBuffer is not available.");this.geometry=e,this._roots=null,this._indirectBuffer=null,t[Si]||(Tl(this,t),!e.boundingBox&&t.setBoundingBox&&(e.boundingBox=this.getBoundingBox(new d.Box3))),this.resolveTriangleIndex=t.indirect?i=>this._indirectBuffer[i]:i=>i}refit(e=null){return(this.indirect?Xl:Ol)(this,e)}traverse(e,t=0){const i=this._roots[t],s=new Uint32Array(i),a=new Uint16Array(i);o(0);function o(c,u=0){const f=c*2,p=a[f+15]===hi;if(p){const r=s[c+6],l=a[f+14];e(u,p,new Float32Array(i,c*4,6),r,l)}else{const r=c+Pt/4,l=s[c+6],h=s[c+7];e(u,p,new Float32Array(i,c*4,6),h)||(o(r,u+1),o(l,u+1))}}}raycast(e,t=d.FrontSide,i=0,s=1/0){const a=this._roots,o=this.geometry,c=[],u=t.isMaterial,f=Array.isArray(t),p=o.groups,r=u?t.side:t,l=this.indirect?Kl:Hl;for(let h=0,g=a.length;h<g;h++){const _=f?t[p[h].materialIndex].side:r,m=c.length;if(l(this,h,_,e,c,i,s),f){const v=p[h].materialIndex;for(let y=m,x=c.length;y<x;y++)c[y].face.materialIndex=v}}return c}raycastFirst(e,t=d.FrontSide,i=0,s=1/0){const a=this._roots,o=this.geometry,c=t.isMaterial,u=Array.isArray(t);let f=null;const p=o.groups,r=c?t.side:t,l=this.indirect?$l:Wl;for(let h=0,g=a.length;h<g;h++){const _=u?t[p[h].materialIndex].side:r,m=l(this,h,_,e,i,s);m!=null&&(f==null||m.distance<f.distance)&&(f=m,u&&(m.face.materialIndex=p[h].materialIndex))}return f}intersectsGeometry(e,t){let i=!1;const s=this._roots,a=this.indirect?ec:Gl;for(let o=0,c=s.length;o<c&&(i=a(this,o,e,t),!i);o++);return i}shapecast(e){const t=re.getPrimitive(),i=this.indirect?Ul:kl;let{boundsTraverseOrder:s,intersectsBounds:a,intersectsRange:o,intersectsTriangle:c}=e;if(o&&c){const r=o;o=(l,h,g,_,m)=>r(l,h,g,_,m)?!0:i(l,h,this,c,g,_,t)}else o||(c?o=(r,l,h,g)=>i(r,l,this,c,h,g,t):o=(r,l,h)=>h);let u=!1,f=0;const p=this._roots;for(let r=0,l=p.length;r<l;r++){const h=p[r];if(u=Pl(this,r,a,o,s,f),u)break;f+=h.byteLength}return re.releasePrimitive(t),u}bvhcast(e,t,i){let{intersectsRanges:s,intersectsTriangles:a}=i;const o=re.getPrimitive(),c=this.geometry.index,u=this.geometry.attributes.position,f=this.indirect?g=>{const _=this.resolveTriangleIndex(g);G(o,_*3,c,u)}:g=>{G(o,g*3,c,u)},p=re.getPrimitive(),r=e.geometry.index,l=e.geometry.attributes.position,h=e.indirect?g=>{const _=e.resolveTriangleIndex(g);G(p,_*3,r,l)}:g=>{G(p,g*3,r,l)};if(a){const g=(_,m,v,y,x,w,b,A)=>{for(let T=v,I=v+y;T<I;T++){h(T),p.a.applyMatrix4(t),p.b.applyMatrix4(t),p.c.applyMatrix4(t),p.needsUpdate=!0;for(let C=_,P=_+m;C<P;C++)if(f(C),o.needsUpdate=!0,a(o,p,C,T,x,w,b,A))return!0}return!1};if(s){const _=s;s=function(m,v,y,x,w,b,A,T){return _(m,v,y,x,w,b,A,T)?!0:g(m,v,y,x,w,b,A,T)}}else s=g}return ac(this,e,t,s)}intersectsBox(e,t){return $t.set(e.min,e.max,t),$t.needsUpdate=!0,this.shapecast({intersectsBounds:i=>$t.intersectsBox(i),intersectsTriangle:i=>$t.intersectsTriangle(i)})}intersectsSphere(e){return this.shapecast({intersectsBounds:t=>e.intersectsBox(t),intersectsTriangle:t=>t.intersectsSphere(e)})}closestPointToGeometry(e,t,i={},s={},a=0,o=1/0){return(this.indirect?nc:Zl)(this,e,t,i,s,a,o)}closestPointToPoint(e,t={},i=0,s=1/0){return Dl(this,e,t,i,s)}getBoundingBox(e){return e.makeEmpty(),this._roots.forEach(i=>{N(0,new Float32Array(i),or),e.union(or)}),e}}class cc{constructor(e){this.name="WorkerBase",this.running=!1,this.worker=e,this.worker.onerror=t=>{throw t.message?new Error(`${this.name}: Could not create Web Worker with error "${t.message}"`):new Error(`${this.name}: Could not create Web Worker.`)}}runTask(){}generate(...e){if(this.running)throw new Error("GenerateMeshBVHWorker: Already running job.");if(this.worker===null)throw new Error("GenerateMeshBVHWorker: Worker has been disposed.");this.running=!0;const t=this.runTask(this.worker,...e);return t.finally(()=>{this.running=!1}),t}dispose(){this.worker.terminate(),this.worker=null}}class uc extends cc{constructor(e){const t=new Worker(e||new URL("data:text/javascript;base64,aW1wb3J0IHsKCUJ1ZmZlckdlb21ldHJ5LAoJQnVmZmVyQXR0cmlidXRlLAp9IGZyb20gJ3RocmVlJzsKaW1wb3J0IHsgTWVzaEJWSCB9IGZyb20gJy4uL2NvcmUvTWVzaEJWSC5qcyc7Cgpvbm1lc3NhZ2UgPSAoIHsgZGF0YSB9ICkgPT4gewoKCWxldCBwcmV2VGltZSA9IHBlcmZvcm1hbmNlLm5vdygpOwoJZnVuY3Rpb24gb25Qcm9ncmVzc0NhbGxiYWNrKCBwcm9ncmVzcyApIHsKCgkJLy8gYWNjb3VudCBmb3IgZXJyb3IKCQlwcm9ncmVzcyA9IE1hdGgubWluKCBwcm9ncmVzcywgMSApOwoKCQljb25zdCBjdXJyVGltZSA9IHBlcmZvcm1hbmNlLm5vdygpOwoJCWlmICggY3VyclRpbWUgLSBwcmV2VGltZSA+PSAxMCAmJiBwcm9ncmVzcyAhPT0gMS4wICkgewoKCQkJcG9zdE1lc3NhZ2UoIHsKCgkJCQllcnJvcjogbnVsbCwKCQkJCXNlcmlhbGl6ZWQ6IG51bGwsCgkJCQlwb3NpdGlvbjogbnVsbCwKCQkJCXByb2dyZXNzLAoKCQkJfSApOwoJCQlwcmV2VGltZSA9IGN1cnJUaW1lOwoKCQl9CgoJfQoKCWNvbnN0IHsgaW5kZXgsIHBvc2l0aW9uLCBvcHRpb25zIH0gPSBkYXRhOwoJdHJ5IHsKCgkJY29uc3QgZ2VvbWV0cnkgPSBuZXcgQnVmZmVyR2VvbWV0cnkoKTsKCQlnZW9tZXRyeS5zZXRBdHRyaWJ1dGUoICdwb3NpdGlvbicsIG5ldyBCdWZmZXJBdHRyaWJ1dGUoIHBvc2l0aW9uLCAzLCBmYWxzZSApICk7CgkJaWYgKCBpbmRleCApIHsKCgkJCWdlb21ldHJ5LnNldEluZGV4KCBuZXcgQnVmZmVyQXR0cmlidXRlKCBpbmRleCwgMSwgZmFsc2UgKSApOwoKCQl9CgoJCWlmICggb3B0aW9ucy5pbmNsdWRlZFByb2dyZXNzQ2FsbGJhY2sgKSB7CgoJCQlvcHRpb25zLm9uUHJvZ3Jlc3MgPSBvblByb2dyZXNzQ2FsbGJhY2s7CgoJCX0KCgkJaWYgKCBvcHRpb25zLmdyb3VwcyApIHsKCgkJCWNvbnN0IGdyb3VwcyA9IG9wdGlvbnMuZ3JvdXBzOwoJCQlmb3IgKCBjb25zdCBpIGluIGdyb3VwcyApIHsKCgkJCQljb25zdCBncm91cCA9IGdyb3Vwc1sgaSBdOwoJCQkJZ2VvbWV0cnkuYWRkR3JvdXAoIGdyb3VwLnN0YXJ0LCBncm91cC5jb3VudCwgZ3JvdXAubWF0ZXJpYWxJbmRleCApOwoKCQkJfQoKCQl9CgoJCWNvbnN0IGJ2aCA9IG5ldyBNZXNoQlZIKCBnZW9tZXRyeSwgb3B0aW9ucyApOwoJCWNvbnN0IHNlcmlhbGl6ZWQgPSBNZXNoQlZILnNlcmlhbGl6ZSggYnZoLCB7IGNvcHlJbmRleEJ1ZmZlcjogZmFsc2UgfSApOwoJCWxldCB0b1RyYW5zZmVyID0gWyBwb3NpdGlvbi5idWZmZXIsIC4uLnNlcmlhbGl6ZWQucm9vdHMgXTsKCQlpZiAoIHNlcmlhbGl6ZWQuaW5kZXggKSB7CgoJCQl0b1RyYW5zZmVyLnB1c2goIHNlcmlhbGl6ZWQuaW5kZXguYnVmZmVyICk7CgoJCX0KCgkJdG9UcmFuc2ZlciA9IHRvVHJhbnNmZXIuZmlsdGVyKCB2ID0+ICggdHlwZW9mIFNoYXJlZEFycmF5QnVmZmVyID09PSAndW5kZWZpbmVkJyApIHx8ICEgKCB2IGluc3RhbmNlb2YgU2hhcmVkQXJyYXlCdWZmZXIgKSApOwoKCQlpZiAoIGJ2aC5faW5kaXJlY3RCdWZmZXIgKSB7CgoJCQl0b1RyYW5zZmVyLnB1c2goIHNlcmlhbGl6ZWQuaW5kaXJlY3RCdWZmZXIuYnVmZmVyICk7CgoJCX0KCgkJcG9zdE1lc3NhZ2UoIHsKCgkJCWVycm9yOiBudWxsLAoJCQlzZXJpYWxpemVkLAoJCQlwb3NpdGlvbiwKCQkJcHJvZ3Jlc3M6IDEsCgoJCX0sIHRvVHJhbnNmZXIgKTsKCgl9IGNhdGNoICggZXJyb3IgKSB7CgoJCXBvc3RNZXNzYWdlKCB7CgoJCQllcnJvciwKCQkJc2VyaWFsaXplZDogbnVsbCwKCQkJcG9zaXRpb246IG51bGwsCgkJCXByb2dyZXNzOiAxLAoKCQl9ICk7CgoJfQoKfTsK",typeof document>"u"?require("url").pathToFileURL(__filename).href:ot&&ot.src||new URL("shop-components.cjs",document.baseURI).href),{type:"module"});super(t),this.name="GenerateMeshBVHWorker"}runTask(e,t,i={}){return new Promise((s,a)=>{if(t.getAttribute("position").isInterleavedBufferAttribute||t.index&&t.index.isInterleavedBufferAttribute)throw new Error("GenerateMeshBVHWorker: InterleavedBufferAttribute are not supported for the geometry attributes.");e.onerror=f=>{a(new Error(`GenerateMeshBVHWorker: ${f.message}`))},e.onmessage=f=>{const{data:p}=f;if(p.error)a(new Error(p.error)),e.onmessage=null;else if(p.serialized){const{serialized:r,position:l}=p,h=ds.deserialize(r,t,{setIndex:!1}),g=Object.assign({setBoundingBox:!0},i);if(t.attributes.position.array=l,r.index)if(t.index)t.index.array=r.index;else{const _=new d.BufferAttribute(r.index,1,!1);t.setIndex(_)}g.setBoundingBox&&(t.boundingBox=h.getBoundingBox(new d.Box3)),i.onProgress&&i.onProgress(p.progress),s(h),e.onmessage=null}else i.onProgress&&i.onProgress(p.progress)};const o=t.index?t.index.array:null,c=t.attributes.position.array,u=[c];o&&u.push(o),e.postMessage({index:o,position:c,options:{...i,onProgress:null,includedProgressCallback:!!i.onProgress,groups:[...t.groups]}},u.map(f=>f.buffer).filter(f=>typeof SharedArrayBuffer>"u"||!(f instanceof SharedArrayBuffer)))})}}class hc{constructor(e,t){this.lock=!1,this.lockX=!1,this.lockY=!1,this.invRotMat=new d.Matrix4,this.mouse=new d.Vector3,this.rotateStart=new d.Vector2,this.rotateEnd=new d.Vector2,this.rotateDelta=new d.Vector2,this.selectedAxis=null,this.isDragging=!1,this.context=null,this.orbitState=!0,this._animator=0,this._emitter=new ct,this.addListener=this._emitter.addListener.bind(this._emitter),this.removeAllListeners=this._emitter.removeAllListeners.bind(this._emitter),this._text=document.createElement("div"),this._textTimer=0,this._update=()=>{this.lock||(this._textTimer&&(window.clearTimeout(this._textTimer),this._textTimer=0),this._textTimer=window.setTimeout(()=>{this._text.style.opacity="0"},800),this.camera.updateMatrix(),this.invRotMat.extractRotation(this.camera.matrix).invert(),this.axes.forEach(s=>{this.setAxisPosition(s)}),this.axes.sort((s,a)=>s.position.z>a.position.z?1:-1),this.drawLayers(!0),this._text.style.opacity="1",this._text.innerText=this.camera.position.distanceTo(this.orbit.target).toFixed(2)+" m")},this.updateMouseFromEvent=s=>{this.rect=this.domElement.getBoundingClientRect();const a=this.domElement.width/this.domElement.clientWidth,o=this.domElement.height/this.domElement.clientHeight,{left:c,top:u}=this.rect;this.mouse.set((s.clientX-c)*a,(s.clientY-u)*o,0)},this.updateSelectedAxisUnderMouse=()=>{this.selectedAxis=null,this.axes.forEach(s=>{this.mouse.distanceTo(s.position)<s.size&&(this.selectedAxis=s)})},this.onPointerDown=s=>{this.rotateStart.set(s.clientX,s.clientY),this.updateMouseFromEvent(s),this.updateSelectedAxisUnderMouse(),this.orbitState=this.orbit.enabled,this.orbit.enabled=!1,window.addEventListener("pointermove",this.onDrag,!1),window.addEventListener("pointerup",this.onPointerUp,!1)},this.onPointerUp=()=>{this.domElement.style.backgroundColor="#FFF0",setTimeout(()=>this.isDragging=!1,0),this.domElement.classList.remove("dragging"),this.orbit.enabled=this.orbitState,window.removeEventListener("pointermove",this.onDrag,!1),window.removeEventListener("pointerup",this.onPointerUp,!1)},this.onPointerEnter=()=>{this.domElement.style.backgroundColor="#FFF3",this.rect=this.domElement.getBoundingClientRect()},this.onPointerMove=s=>{if(this.lock||this.isDragging)return;const a=this.selectedAxis;s&&(this.updateMouseFromEvent(s),this.updateSelectedAxisUnderMouse()),a!==this.selectedAxis&&this.drawLayers()},this.onDrag=s=>{this.lock||(this.isDragging||this.domElement.classList.add("dragging"),this.isDragging=!0,this.selectedAxis=null,this.rotateEnd.set(s.clientX,s.clientY),this.rotateDelta.subVectors(this.rotateEnd,this.rotateStart).multiplyScalar(.5),this.rotateStart.copy(this.rotateEnd),this.orbit.update())},this.onMouseClick=s=>{if(this.lock||(this.updateMouseFromEvent(s),this.updateSelectedAxisUnderMouse(),this.isDragging||!this.selectedAxis))return;this._animator&&cancelAnimationFrame(this._animator);const a=this.selectedAxis.direction.clone();this.camera.lookAt(0,0,0);const o=this.camera.position.distanceTo(this.orbit.target);a.multiplyScalar(o),this.selectedAxis.axis==="z"?a.setZ(this.orbit.target.z+o):this.selectedAxis.axis==="-z"?a.setZ(this.orbit.target.z-o):a.setZ(this.orbit.target.z);const c=500,u=performance.now(),f=1,p=this.selectedAxis.axis,r=()=>{const h=performance.now()-u,g=Math.min(h/c,f);if(this.camera.position.lerp(a,g),this.orbit.update(),g!==f){this._animator=window.requestAnimationFrame(r);return}else this._animator=0,this.onPointerMove(void 0),this._emitter.emit("axis-select-end",p);this.onPointerMove(void 0)};this._emitter.emit("axis-select-start",p),r()},this.drawCircle=(s,a=10,o="#FF0000")=>{this.context&&(this.context.beginPath(),this.context.rect(s.x-a,s.y-a,a*2,a*2),this.context.fillStyle=o,this.context.fill(),this.context.closePath())},this.drawLine=(s,a,o=1,c="#FF0000")=>{this.context&&(this.context.beginPath(),this.context.moveTo(s.x,s.y),this.context.lineTo(a.x,a.y),this.context.lineWidth=o,this.context.strokeStyle=c,this.context.stroke(),this.context.closePath())},this.drawLayers=(s=!1)=>{this.context&&(s&&this.context.clearRect(0,0,this.domElement.width,this.domElement.height),this.axes.forEach(a=>{const o=this.selectedAxis===a,c=a.position.z>=-.01?a.color[0]:a.color[1];if(a.line&&this.drawLine(this.center,a.position,a.line,c),this.drawCircle(a.position,a.size,o?"#0066ff":c),a.label){const u=a.axis==="-x"?this.options.fontSize-3:this.options.fontSize;this.context.font=[this.options.fontWeight,u+"px",this.options.fontFamily].join(" "),this.context.fillStyle=this.options.fontColor,this.context.textBaseline="middle",this.context.textAlign="center",this.context.fillText(a.label,a.position.x,a.position.y)}}))},this.setAxisPosition=s=>{const a=s.direction.clone().applyMatrix4(this.invRotMat),o=s.size;s.position.set(a.x*(this.center.x-o/2-this.options.padding)+this.center.x,this.center.y-a.y*(this.center.y-o/2-this.options.padding),a.z)};const i={offset:new d.Vector2,size:90,padding:8,bubbleSizePrimary:8,bubbleSizeSecondary:6,lineWidth:2,fontSize:11,fontFamily:"arial",fontWeight:"normal",fontColor:"#fff",className:"orbit-controls-gizmo",colors:{x:["#f35f5f","#902525"],y:["#78da2f","#71ae45"],z:["#1d92fa","#d0d1d1"]}};this.options={...i,...t},this.orbit=e,this.camera=e.object,this.center=new d.Vector3(this.options.size/2,this.options.size/2,0),this.axes=this.createAxes(),this.domElement=this.createCanvas(this.options),this.orbit.addEventListener("change",this._update),this._text.style.cssText=`
3731
+ `,this._needsRender=!1}handleShadowClick(e){const t=e.target;if(!t)return;t.closest(".info")&&(e.preventDefault(),e.stopPropagation());const i=t.closest("[data-action]");if(!i)return;const s=i.getAttribute("data-action");if(s)switch(e.preventDefault(),e.stopPropagation(),s){case"remove-device":this.removeDevice();break;case"remove-function":{const a=i.getAttribute("data-function");a&&this.dispatchEvent(new CustomEvent("function-removed",{detail:a}));break}case"toggle-dialog":if(!this.hasMoreFunctions)return;this._showDialog=!this._showDialog,this.scheduleRender();break;case"add-function":{const a=i.getAttribute("data-function");a&&(this.dispatchEvent(new CustomEvent("function-added",{detail:a})),this._showDialog=!1,this.scheduleRender());break}}}}customElements.get("slot-item")||customElements.define("slot-item",Lr);const q={ON_DROP:"slot-on-drop",ON_DEVICE_DELETED:"slot-on-device-deleted",ON_DEVICE_REPLACED:"slot-on-device-replaced",ON_BEFORE_SELECTED:"slot-on-before-selected",ON_SELECTED:"slot-on-selected",ON_ADD_BUTTON_CLICKED:"slot-add-button-clicked",ON_DEVICE_SELECTED:"slot-on-device-selected",ON_DROP_ERROR:"slot-on-drop-error",ON_ERROR_STATE_CHANGE:"slot-on-error-state-change",ON_FUNCTION_REMOVED:"slot-on-function-removed",ON_FUNCTION_ADDED:"slot-on-function-added"};class Gi extends fe.CSS2DObject{constructor(e){const t=document.createElement("div");super(t),this.props=e,this._emitter=new ct,this._slotContainer=new d.Group,this._bracketSlots=[],this._hasError=!1,this.useBracket=!1,this.addEventListener=this._emitter.addListener.bind(this._emitter),this.removeEventListener=this._emitter.removeListener.bind(this._emitter),this._canInstall=!1,this._loading=!1,this._selected=!1,this._deviceSelected=!1,this._focused=!1,this._toBeInstalled=!1,this._toBeReplaced=!1,this._allFunctions=new Set,this._functions=new Set,this._timer=0,this._parentPos=new d.Vector3,this._wrapper=new d.Group,this._showSlot=!0,this._isMirror=!1,this.beforeInstall=void 0,this._preventDefaults=i=>{i.preventDefault(),i.stopPropagation()},this.getWP=this._slotContainer.getWorldPosition.bind(this._slotContainer),this._showSlot=typeof e.show=="boolean"?e.show:!0,this.name=e.name,this._isMirror=e.isMirror,this._slotUI=new Lr({name:e.name,isMobile:e.isMobile,onRemove:()=>{this.clearSlot(),this._emitter.emit(q.ON_DEVICE_DELETED)}}),this._slotUI.slot=this,this._slotUI.hide=!this._showSlot||this.isMirror,t.append(this._slotUI),this._parentPos.copy(this.props.slot.position),this._slotUI.addEventListener("function-removed",({detail:i})=>{this.removeFunction(i)}),this._slotUI.addEventListener("function-added",({detail:i})=>{this.addFunction(i)}),this.add(this._slotContainer),this.props.slot.add(this),setTimeout(()=>{var i;(i=this.props.slot.parent)==null||i.add(this._wrapper),this._wrapper.add(this.props.slot)},10),["dragenter","dragover","dragleave","drop"].forEach(i=>{t.addEventListener(i,this._preventDefaults,!1)}),t.addEventListener("click",i=>{i.preventDefault(),i.stopPropagation(),this.toBeInstalled?this._emitter.emit(q.ON_ADD_BUTTON_CLICKED):this.selected=!this.selected}),t.addEventListener("dragover",i=>{if(i.preventDefault(),i.dataTransfer.dropEffect="copy",!this._canInstall){i.dataTransfer&&(i.dataTransfer.dropEffect="none");return}}),t.addEventListener("drop",async i=>{var a;if(i.preventDefault(),i.stopPropagation(),!this._canInstall)return;const s=(a=i.dataTransfer)==null?void 0:a.getData("application/json");if(s){const o=JSON.parse(s);try{await this.install(o),this._emitter.emit(q.ON_DROP,this)}catch(c){this._emitter.emit(q.ON_DROP_ERROR,c)}}else this._emitter.emit(q.ON_DROP_ERROR,new Error("No device info"))})}get hasDevice(){return this._slotContainer.children.length>0}get isMirror(){return this._isMirror}shapeKeyChanged(e,t){var i;if(this.props.follows.has(e)){const s=this.props.follows.get(e);if(s){let a="x";["height","mast"].includes(e)?a="z":["width","liftOuterWidth"].includes(e)&&(a="y");const o=((i=this.props.slot)==null?void 0:i.position[a])>0?1:-1;this._wrapper.position[a]=(t-s.origin)*s.scale*o}}}async loadGlb(e){const i=await new ni({useCache:!0}).loadAsync(e);if(i.glb)return i.glb.clone(!0)}async installBracket(e){const i=await new ni({useCache:!0}).loadAsync(e);if(!i.glb)return;const s=i.glb.clone(!0);s.traverse(a=>{a.userData.isBracket=!0}),this.useBracket=!0,this._slotContainer.add(s)}async install(e){var t;if(!this._loading){this._loading=!0,this.beforeInstall&&typeof this.beforeInstall=="function"&&await((t=this.beforeInstall)==null?void 0:t.call(this,e));try{const i=await this.loadGlb(e.url);if(!i)throw new Error(`Fail to load device from: ${e.url}`);if(i.traverse(s=>{s.userData.isDevice=!0}),this.isMirror&&i.scale.set(1,1,-1),e.bracketUrl){const s=await this.loadGlb(e.bracketUrl);if(s)this.clearSlot(),this._emitter.emit(q.ON_DEVICE_REPLACED),s.traverse(a=>{a.name.startsWith("Slot")&&this._bracketSlots.push(a),a.userData.isBracket=!0}),this._slotContainer.add(s);else throw new Error(`Fail to load bracket from: ${e.bracketUrl}`);this._bracketSlots.forEach(a=>{a.add(i)})}else this.clearSlot(),this._emitter.emit(q.ON_DEVICE_REPLACED),this._slotContainer.add(i);this.mirrorTarget&&this.mirrorTarget.install(e),this.deviceInfo=e,this._slotUI.deviceLogo=e.logo||"",this._slotUI.deviceName=e.name,this._slotUI.filled=!0,this.holeTarget&&(this.holeTarget.visible=!1)}catch(i){throw i}finally{this._loading=!1}}}get device(){return this._slotContainer.children.length?this._slotContainer.children[0]:null}get allFunctions(){return[...this._allFunctions]}set allFunctions(e){this._functions.forEach(t=>{e.includes(t)||this._functions.delete(t)}),this._allFunctions=new Set(e),this._slotUI.allFunctions=e}get functions(){return[...this._functions]}addFunction(e){this._allFunctions.has(e)&&(this._functions.add(e),this._slotUI.functions=[...this.functions],this._emitter.emit(q.ON_FUNCTION_ADDED,e))}removeFunction(e){this._functions.has(e)&&(this._functions.delete(e),this._slotUI.functions=[...this.functions],this._emitter.emit(q.ON_FUNCTION_REMOVED,e))}clearFunctions(){this._functions.forEach(e=>this.removeFunction(e))}addFunctions(e){e.forEach(t=>this.addFunction(t)),this._slotUI.functions=this.functions}changeName(e){var t;this.name=e,this.props.slot.userData.name=e,this.props.name=e,(t=this.element)==null||t.setAttribute("data-name",this.props.name)}clearSlot(){this._bracketSlots=[],this._slotContainer.children.forEach(e=>{e.removeFromParent(),xe(e)}),this._slotUI.filled=!1,this.deviceInfo=void 0,this._slotUI.deviceName="",this._slotUI.deviceLogo="",this.holeTarget&&(this.holeTarget.visible=!0),this.mirrorTarget&&this.mirrorTarget.clearSlot()}get disabled(){return this._slotUI.disable}enable(){this.show(),this._slotUI.disable=!1}disable(){this._slotUI.disable=!0,this.hide()}hide(){this._slotUI.hide=!0}show(){this.isMirror||this.disabled||(this._slotUI.hide=!1)}get selected(){return this._selected}get focused(){return this._focused}set focused(e){this._focused=e,this._slotUI.focused=e}get toBeInstalled(){return this._toBeInstalled}set toBeInstalled(e){this._toBeInstalled=e,this._slotUI.toBeInstalled=e}get toBeReplaced(){return this._toBeReplaced}set toBeReplaced(e){this._toBeReplaced=e,this._slotUI.toBeReplaced=e}set selected(e){this.disabled||(e&&this._emitter.emit(q.ON_BEFORE_SELECTED,e),this._selected=e,this._slotUI.selected=e,this._emitter.emit(q.ON_SELECTED,e),this.element.style.zIndex="100",this.selected?this.renderOrder=1/0:this.renderOrder=1)}get deviceSelected(){return this._deviceSelected}set deviceSelected(e){this._deviceSelected=e,this._emitter.emit(q.ON_DEVICE_SELECTED,e)}get error(){return this._hasError}set error(e){this._loading&&setTimeout(()=>{this.error=e},100),this._hasError=e,this._slotUI.hasError=e,this._emitter.emit(q.ON_ERROR_STATE_CHANGE,e)}getCanInstall(){return this._canInstall}canInstall(e){this._canInstall=e,this._slotUI.canInstall=e}dispose(){cancelAnimationFrame(this._timer),["dragenter","dragover","dragleave","drop"].forEach(e=>{this.element.addEventListener(e,this._preventDefaults,!1)}),this.clearSlot(),this._emitter.removeAllListeners(),xe(this._slotContainer),this.element.remove()}render(e){const t=this.element.style.transform,i=/translate\(-?\d*\.?\d*%?,?\s-?\d*\.?\d*%?\)\s*translate\((-?\d*\.?\d*)px,\s*(-?\d*\.?\d*)px\)/.exec(t);if(!i)return;const s=new d.Vector2(parseFloat(i[1]),parseFloat(i[2])),a=e.mousePos.distanceTo(s);let o=this.props.isMobile?12:18,c=38,u=30;if(this._canInstall&&(o=34,c=60,u=60),a<u){let f=(u-a)*1+o;a<20&&(f=c),f>c&&(f=c),this._slotUI.setSize(f)}else this._slotUI.setSize(o)}clone(e){return new d.Group}}class Ja extends fe.CSS2DObject{constructor(e){const t=document.createElement("div");super(t),this._text=document.createElement("div");const i=us(),s=i?"#ddd":"#eee";this.element.style.pointerEvents="auto",this.element.style.padding=i?"2px 6px":"3px 12px",this.element.style.borderTop=`1px solid ${s}`,this.element.style.borderBottom=this.element.style.borderTop;const a="6px",o=document.createElement("div");o.style.pointerEvents="none",Object.assign(o.style,{pointerEvents:"none",borderLeft:`1px solid ${s}`,borderRight:`1px solid ${s}`,position:"absolute",left:"0",top:"0",boxSizing:"border-box",height:a,width:"100%"}),this.element.append(o);const c=document.createElement("div");c.style.pointerEvents="none",Object.assign(c.style,{pointerEvents:"none",borderLeft:`1px solid ${s}`,borderRight:`1px solid ${s}`,position:"absolute",left:"0",bottom:"0",boxSizing:"border-box",height:a,width:"100%"}),this.element.append(c),this._text.style.fontSize=i?"10px":"14px",this._text.style.font="SF Pro SC,SF Pro Text,SF Pro Icons,PingFang SC,Helvetica Neue,Helvetica,Arial,sans-serif",this._text.style.color="#fff",this._text.style.fontWeight="500",this._text.style.transition="all .16s",this._text.innerText=e,this.element.append(this._text),this._text.addEventListener("pointermove",()=>{var u;o.style.borderColor=c.style.borderColor=this.element.style.borderColor="#666",this._text.style.color="#000",(u=this.onPointMove)==null||u.call(this)}),this._text.addEventListener("pointerleave",()=>{var u;o.style.borderColor=c.style.borderColor=this.element.style.borderColor=s,this._text.style.transform="scale(1)",this._text.style.color="#fff",(u=this.onPointLeave)==null||u.call(this)})}set text(e){this._text.innerText=e}dispose(){this.element&&this.element.parentNode&&this.element.parentNode.removeChild(this.element)}}class ti extends d.Group{constructor(e,t=!0,i=!0){super(),this._startWith=e,this._showText=t,this.useStartEnd=i,this._line2Length=.01,this._line=new d.LineSegments(new d.BufferGeometry,new d.LineBasicMaterial({color:"#666",linewidth:2})),this._line2=new d.LineSegments(new d.BufferGeometry,new d.LineBasicMaterial({color:"#666",linewidth:2})),this._text=new Ja(""),this._line.frustumCulled=!1,this.add(this._line,this._line2),this._showText&&(this.add(this._text),this._text.onPointMove=()=>{this._line.material.color.set("#000"),this._line2.material.color.set("#000")},this._text.onPointLeave=()=>{this._line.material.color.set("#666"),this._line2.material.color.set("#666")})}updateMaterial(e){this._line.material=e}reset(){var e;(e=this._line.geometry)==null||e.dispose(),this._line.computeLineDistances()}update(e,t,i=0){var h,g;(h=this._line.geometry)==null||h.dispose(),this._line.geometry.setFromPoints([e,t]),this._line.computeLineDistances();const s=this._line2Length+i*.02,a=new d.Vector3().subVectors(t,e).normalize();let o;Math.abs(a.z)>Math.abs(a.x)&&Math.abs(a.z)>Math.abs(a.y)?o=new d.Vector3(-a.y,a.x,0):Math.abs(a.y)>Math.abs(a.x)?o=new d.Vector3(1,0,0):o=new d.Vector3(0,1,0),o.length()<.001&&(Math.abs(a.x)<.9?o=new d.Vector3(1,0,0):o=new d.Vector3(0,1,0)),o.normalize();const c=new d.Vector3().addVectors(e,o.clone().multiplyScalar(s)),u=new d.Vector3().addVectors(e,o.clone().multiplyScalar(-s)),f=new d.Vector3().addVectors(t,o.clone().multiplyScalar(s)),p=new d.Vector3().addVectors(t,o.clone().multiplyScalar(-s));(g=this._line2.geometry)==null||g.dispose(),this._line2.geometry=new d.BufferGeometry,this._line2.geometry.setFromPoints([c,u,f,p]),this._line2.computeLineDistances();const r=e.distanceTo(t);this._startWith?this._text.text=`${this._startWith}${(r*1e3).toFixed(0)} mm`:this._text.text=`${(r*1e3).toFixed(0)} mm`;const l=new d.Vector3;l.addVectors(e,t).multiplyScalar(.5),this._text.position.copy(l),this.useStartEnd||(this._line2.visible=!1)}destroy(){this._text.dispose(),this.children.forEach(e=>xe(e)),this.removeFromParent()}}class Er extends d.Object3D{constructor(e,t){super(),this.radius=e,this._text=new $a(""),this._line=new ti(void 0,!1,!1),this._box=new d.Mesh,this._arc=new pn.Line2,this._previousPosition=null,this._updateTimer=null,this._updateDelay=300,this._accumulatedAngle=0,this._lastAngle=null,this._line.updateMaterial(new d.LineDashedMaterial({color:"#555",dashSize:.06,gapSize:.06})),this._line.renderOrder=0,this._box.geometry=new d.RingGeometry(e,e+.003,128),this._box.material=new d.MeshBasicMaterial({color:"#666",side:d.DoubleSide}),this._arc.geometry=new _s.LineGeometry,this._arc.geometry.setPositions([0,0,0,0,0,0]),this._arc.geometry.instanceCount=0,this._arc.material=new mn.LineMaterial({color:"#eee",linewidth:2,resolution:new d.Vector2(window.innerWidth,window.innerHeight)}),this._arc.visible=!1,this._arc.rotateX(-Math.PI/2),this.position.y=t,this._arc.position.y=.001,this.add(this._box),this.add(this._arc),this.add(this._line),this.add(this._text)}hide(){this._text.hide(),this._line.visible=!1,this._arc.visible=!1}show(){this._text.show(),this._line.visible=!0}dispose(){this._updateTimer&&(clearTimeout(this._updateTimer),this._updateTimer=null),this._box.geometry&&this._box.geometry.dispose(),this._arc.geometry&&this._arc.geometry.dispose(),this._arc.visible=!1,this._previousPosition=null}update(e){var t;this.radius=e,(t=this._box.geometry)==null||t.dispose(),this._box.geometry=new d.RingGeometry(e,e+.003,128),this._line.updateMaterial(new d.LineDashedMaterial({color:"#555",dashSize:.06*e,gapSize:.06*e})),this._text.update((e*1e3).toFixed(0))}change(e){const t=e.clone();t.setZ(0),t.normalize().multiplyScalar(this.radius),this._text.position.set(t.x,t.y,t.z),this._text.updateColor("#eee"),this._line.update(t,new d.Vector3),this._previousPosition&&this._updateArc(this._previousPosition,t),this._updateTimer&&clearTimeout(this._updateTimer),this._updateTimer=setTimeout(()=>{this._previousPosition=null,this._accumulatedAngle=0,this._lastAngle=null,this._clearArc(),this._updateTimer=null},this._updateDelay),this._previousPosition||(this._previousPosition=t.clone(),this._lastAngle=Math.atan2(t.y,t.x),this._accumulatedAngle=0)}_updateArc(e,t){const i=Math.atan2(t.y,t.x);if(this._lastAngle!==null){let u=i-this._lastAngle;u>Math.PI?u-=2*Math.PI:u<-Math.PI&&(u+=2*Math.PI),this._accumulatedAngle+=u}if(this._lastAngle=i,Math.abs(this._accumulatedAngle)<.01){this._arc.visible=!1;return}const s=Math.atan2(e.y,e.x),a=s+this._accumulatedAngle;let o=.006*this.radius;o<.003&&(o=.003),o>.006&&(o=.006);const c=this._createArcGeometry(s,a,this.radius+o);this._arc.geometry&&this._arc.geometry.dispose(),this._arc.geometry=c,this._arc.visible=!0}_clearArc(){this._text.updateColor(),this._arc.geometry&&(this._arc.geometry.setPositions([0,0,0,0,0,0]),this._arc.geometry.instanceCount=0,this._arc.computeLineDistances()),this._arc.visible=!1}_createArcGeometry(e,t,i){const s=[],a=t-e,o=Math.max(128,Math.floor(Math.abs(a)/(Math.PI/128))),c=a/o;for(let f=0;f<=o;f++){const p=e+f*c,r=Math.cos(p),l=Math.sin(p);s.push(i*r,0,i*l)}const u=new _s.LineGeometry;return u.setPositions(s),u.instanceCount=Math.max(0,s.length/3-1),u}}class $a extends fe.CSS2DObject{constructor(e){const t=document.createElement("div");super(t),this._wrapper=document.createElement("div"),this._circle=document.createElement("div");const i=us();this._wrapper.style.fontSize=i?"10px":"11px",this._wrapper.style.color="#fff",this._wrapper.style.whiteSpace="nowrap",this._wrapper.style.position="absolute",this._wrapper.style.transform="translateX(-50%)",this._wrapper.style.top="6px",this._wrapper.style.font="SF Pro SC,SF Pro Text,SF Pro Icons,PingFang SC,Helvetica Neue,Helvetica,Arial,sans-serif";const s=this._circle;s.style.position="relative",s.style.zIndex="10",s.style.width=s.style.height="5px",s.style.borderRadius="50%",s.style.background="#666",t.append(this._wrapper,s),this.update(e)}show(){this.element.style.display="block"}hide(){this.element.style.display="none"}update(e){this._wrapper.innerText="旋转半径:"+e+" mm",this.updateColor("#eee")}updateColor(e="#666"){this._circle.style.background=e}}const el="data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAADgAAAAUCAYAAADY6P5TAAAAAXNSR0IArs4c6QAAAARzQklUCAgICHwIZIgAAAEvSURBVFiFzZdbFYMwEEQroRKQgAQkVEIlICEOkFAJlRAJSIgEJNx+sPS0nGxIaOhyv3nM7mTmwOViDHAFesADD+BqrakKQAcMwMQ3AWis9e1C3HLASJoAdNZ6sxG3/MZQMZy1dhWgFbfWRzDGlFjAwFlyyXdh5OD5OIqykBgBy1yiF0aMUQaJugLclOcEoP3nULmFgQgeyCwOoJGBYrijByspDM98ZIszJAt8Ks8dag/VUFYYLtetjHdruRz5JZf8WBg1Ae7KcgOluaSsMAKJwqgJ6Vz2WzcvhZHjVlFh1ESG1DQ67SYtyGs8OwujNpTkUtw4nVtbyLK1XDafF3aKW90Z3EpBbi5lE0u9n3qoNTKk9rHh3heZqqwA8Vw6a11VkVwuPK31HALzb5pfovYC2xSs5LCDIUcAAAAASUVORK5CYII=",tl="data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAABwAAAAKCAYAAACngj4SAAAAAXNSR0IArs4c6QAAAARzQklUCAgICHwIZIgAAAChSURBVDiNrdJbFYMwEIRhJFQCEpCAhEqIhDhBAlKQgAQkIOHrSziHpmkbLvua7P4zO9s0FYUeM0b0NT2nC9FnLQho7wQ9MOwgQ3K4ZPDrrtGmFcKKkL0HTAXXw2HX6HYuFnR/hMWC6ykX+W1AzJqq1abDGguux6LoPK9aUGFOm1Y+F+Bh+7DlsSKehRXgnfdDm5od7GdeN8ADnpuKQ3ldqReHZFd3742nZgAAAABJRU5ErkJggg==",Qs="data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAAGwAAABsCAYAAACPZlfNAAAAAXNSR0IArs4c6QAAAARzQklUCAgICHwIZIgAAAdzSURBVHic7Z3hlZs6EIUvW4E7CB3EHcQdxB08OngugVTg8yrwSQVOKnBSwW4qsFOB3cF9PxhZQsYYjEAS1neOD7ssCwPXMxoNIGWIDJJLAAsASwCfAOTyey6bLOQDABf5qJ9P8vkry48sy05j2+ySzLcBjyC5QiXOV1kuWv+hPxcAvwD8BvCBSsRL6394JDjBSC4ArFEJtG7Y5ILqwp4A/JHlxfyoC04yN/4vh/bEz9Dim9uY+/8O4EfI4nmFZEFyz1veSe5Iri0BXB13Icfekjxaxz6TPMixXXt2fJDM5WLZF+og63MPNi1IbsQGW7zyJYUToXZyEUxP8iLSPUS80hLvdYQTobbWN3fHKvMLGpKrBq/bzla4htC3C8mbutIg3JnkxrddzhCvil4omwbhDqy6IPEisV5xJFn4tsk1rDJI8wtZ+rapN+JV73PzqnuwSk7MtvkQzflabdUxGsMdIGFSnfuZZFPHPxysELjnXDOoFsTbzAJA6dumRiyxSt/2+Ma6Hlvf9lyRb9QumjAwIZKQqOLAznvEEbFUcvFS7VVXWO/WvHsTLYnVnSBEM8JgEqsDlmi7qQ++TWL1xxKtnOqgKvs5J7H6I6KdJxFNsh5FygafxLqOxVgHme6b8QIYkWqcZoW6Mr13vvMXhboi8u56x+a34eXKTWMhXSO3SQirgqZi5WSniSvS1ChyFztUoTCcetjMoNGnHbqjTQqF42P1z4pnd7IwssKUwo8Mq/uIz2eN1NWMg3vzxoUWvu3pihEa+zU/4l3RJhoRC/ZcAkKdxkfnXUC8ggE1L+tWILbartW45o1D5IIpL+tWq43du4C4BQNqXlY82jB67wJmIdhSTG/vl1FXkaP1LiB+wQCA+m5+Ya5/s7b7V5a/J7Eq0cZ/svza+FcrHEZd1ZiJh5kp/q0e1D3tqMMhMA/BgFodt1DrzJD4jyx/TmpVoo3vsqyHxTmFQ2BWHpY3ngP1Pa9h5f1AmItgQC1bXAE6JKpXVn94sSrRxocsl4AW7Iss/0xuTuIRKqfQ7dic2i9gdiHxWlu0V8yi/QLmJRhQc6jlG3T7lYboCRfVji3eoMda+mjeNhEAJ1ku31ANYQekhCNklDafTA87eTEl0YWTLHNTsNSGhYvSZvEGPWDkyY8t1xt2ua/jd0Uyah/jYinBcvt+2OTIBTgAOHi6GJ3wbKeOfkaOn09sRNM4VGcXF8N1P0wiwNmyMx+63x7HV48dnuHqpJ40ZMNbBovmUrAGsRSTjuB2PRefgokhZcPFGCSaK8FaxCqf3ecAW66Cea8juhbNhWCBiaXridRtSD61IZZRzkQbKlhIYok9ut5rCOY9Q3Ml2hDBQhNLbKoJdpBfVr4MMnEh2rOChSiW2KWeCHg3X4wO5h2woaI9I1ioYolt6gHf/RuMOpU/k+pkWVYC+GatXmCkTit1p9hOvL6JLb7JZXky+0LTjn/UgWc9rY+HhexZCuqXIzZmfAzyAdJnROsqWAxiAbUnp9bmmxJn34bdo69oXQSLRSwAt10veqwndqVFtKJh21bBWD2WHotYuo5orDzIymAyxSbuiEZbtDbBqN8hCF4soGbv3lwZbOJh00W0e4LFJhZQG81hY67UHbMIeCRak2AxigXU2q+V/QdF7sWynrSJ1nFdDGJd2y/axXnqikfhx7z+tIjWhdK3/Y+gbqpuu1yM9IU+Nt8EfUQU00ex4YU+84/m6Df55NYNgPdDXhOFb3u7wLZwaGwUXVhUdBSt8G1nV9hlvBTjpKPIFm0eiFb4tq8P7No3ZkA3NJ/hjmiFb7v6QN3Nuh8OjY3VCQffib6HJVrh256+GN5Vdtk4ZwS1xUeIaIVvO/rSy7uMf9rF7mWx0su7jH9SD31E7WWxwfoI5v0eO6QuOiYvmwgOGcGcLkZ6TnSG+kGb7m1Xw05UtnVMoXE8WJ8hYljZjL4mKXsh6HIE85SAjAvHmCqFabKcUeAYk+UYO1ePWqXpqBxBXWx3f0vLyhpL5wd4MYyoNd7bnKzX6IJ+wipkOOXUlJN8M2YMfUxNaSUh+SQHnQFWszLtfGxME2/3whJr+j4t09T2nbHE8jO1vRiSRHtAMGIZBi2M8HhO2aNGskGVYOy8i2VCXQ+bLvsJGNYfci1929OIZeQ+qG/UREjE2QcvlsIKA0cGMjrBFFjt1ZGx3EcUww/Gt2w7Z2+T890Z5/seZQJmhcjjHBMSVuW6o3GepW+bBsHqfo/pbYc5hMkGrzpG6VX3YPWWyTl24e4IVfi2axRYZVBm+h+NcKxGHdhZtm9n5VX3EOHKBo8rGVByIt5UUFdzKDbvXkIomzvCKfE2PsQzRDpYNh1lfT61TcEhwq3lItniHSX0FGMIKAKtxWveecueAbVRmW8DbESUNaopHpe4HbDrhGqU6Q9UMyao309qgyzLTsa+7E8O4LMsm/YPVPOo/QTwI8uyoMbzD04wE7ngS/l8AbBC8wUeghL/J4CPLMt+Od6/U4IWrAlpQ5aoPOSTLHNoIRfGzxfoMd9P0J74F5VIlyzLopok6H/tVqA8kSYfTwAAAABJRU5ErkJggg==",il="data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAAYwAAACsCAYAAABo4pvIAAAAAXNSR0IArs4c6QAAAARzQklUCAgICHwIZIgAAAzYSURBVHic7d3hcdtIEobhD05gmYGRgbkRLDKwMjiGoBCUgeoi0F0Evo1AdASiIxAcgbkR9P1Aj9mESIm2QMwAeJ8qlihKomeXwHzsHgCsBBTOzGpJK7+pd7/2r3+ceCw69Vh8nkvt/fbW4/H7vaR//H4bfqeNX6uqij8DilPlHgCWxcxW6ibvNFmn+x/DY/Fn0mHyPXVLE7F0ejKOf3/SpRO1B9c55wJNOg6rfrD1/5v7/31pbN97j7WS9lVVnf3vAoZGYGAwPqHW6ia+tbrJce0/Tj+Lk176+k/4/ui2tAnRA/VUaNbqQjXdr8PvtDoOku/xeyoXDIXAwMXMbK1DGHzUcTikiatVN1l9Uy8YmLiG1wuY2r9+0vHrUuvwOux0/PrseF1wKQIDR06EQvw+TTatunexrXgXOwmh+ku31AJc6xAoMUxaESboITAWyoOhVjdhfAr307vQnbpQ2KlrDe2yDBSj8EBJ20S/Qml12B7S/XZp7UIQGLMX3lk2Og6Gnbqd/1u4zySAI+EghRQmH9VtS7W6bWYrKpLFIDBmJFQNf6nbwdOCc6oYvqqrFrY5xof56AXJJ53e3r5J2hIi80FgTFRoIcRwaP32Vb7TUjFgTCdaW426thYhMgMExgT4u7m1Dm2lxn+UqoatCAcUyrffRodqpPEfbcWbm0khMAoUdrBUPTTyUFC3g7UsQmPKvBJpdNzOiq3TLQFSHgKjAKGM/6xDOb+T9Le6d17bXGMDxmJmjY73g1aHRfX/ESD5ERgZhBbTZx2OOCEggOCVAEn7CQEyMgJjJL2Nv9Hxhr/NNS5gKnr7UK0uQNiHMH1mtjKzGzN7MLNnvz34Rg/gHXz/aszs3vetH75/bbyCB8pmZrVvsI/WeTSzWz8/AsCV+L536/vcj7Dv1bnHBvxkZmt/l/MUqogb3uUAefSqjx++X95R3SOLEBK0moDCER4Y3YmQuKfVBEyLh8dd2I8JDwzD+6J3hAQwP2fCo849LkyI9z/TwnVqNxESwIyF8IgL5qxD4jTfYB786KYvZnaTe0wAxudzQTraivVJdE60nDaUpACkn92GuxAed1QdCxSqCY5wAvCm3pFWj8wZM2eHk+p+VhO5xwRgWrzqSCcIPrHWMTMeFGltgmoCwCB6ax33tLMnzM+biG2nOveYAMxPWAulXTU1vUNiuRAZgFGERfJngqNwrE8AKEVoVz0xHxWEoABQqhAczE85ERQApiIEB62qMREUAKaK4BiJH4nwRFAAmDqC40rCeRQEBYBZ8Y5JumZVnXs8k9U7RO0u93gA4Br6cx2nAvyisE5B6gJYBA+OB684uFr2W3rtpzr3eABgbL31jTr3eIoUTq2/yz0WAMjNugsbPpvZbe6xFMOrimfSFACO+fyYzhhvco8nq1BVkKAAcIZXGz/M7D73WEYXqgoWtQHgAr1qo849nlGEvtwm91gAYGoWsbbBEVAAMIxw5YvH2Z23EVpQy+u/AcAV+Hkb9z63rnOPZxBhsWa+5RMAZDKbFlVIvzr3WABgrsbq4ny4xpOm/pqklaQ/q6pqr/HvAAAkn2P/lLSa1FFUIenuco8FAJYmXMiwzj2WVxEWAJBfCI0yF8PN7MYXtze5xwIASxeu+t3kHsuRMLAy0wwAFsjM1kW9kQ9hUeceCwDgWFgq2OQeSPp4wTrrQAAAZ3lo5Ks0QljQhgKAwmVrT1n3iVCEBQBMSAiNcebuUNrwmbMAMDF+ROv11539Ylf5F08AAL8tXH+qvuY/8sgVZwFg+vzkvqdrPfm9mT1e5ckBAKPz604NWwSM1vMCAIxm8HM0wiI3R0QBwMz4kVPDFAS+bjHtD+YAAJzli+DvW3IY5EkAAMV715XGaUUBwHKEOb/+nT/+wudaAMBy+KG2D7/6R42XJ6srjQsAUCCf+y+/kocvdDfXGxIAoETpIysu/eWGhW4AWK6Lz83w6oILCwLAQl1UZaS1i5HGBAAo1JtrGV5dbMYbEgCgRF5lnF6e8EuX/xh5TACAQvUvGfIh/OxW0n/GHhAAoFhbSS/bUp4kzdijAQCU6eS6dvqM7kxjAgAUKhYTqSW1Fu0oAMBLW3UZ0eHMbgDAKUcnc6ejo7huFACgzzPCpK4lVUvaV1W1zzoqAEBxPBt2ZtZ8UNeb2uYdEgCgYK2k9QdJnyR9yzsWAEDBvkr6mFpSbdahAABKtpNXGGtJrF8AAF6zSudhtDlHAQAo2l4hMAAAOGcvaaV0fC0AAOeYmVFhAAAu8kHSPl7vHACAyDOi/aDUmwIA4BUEBgDgLbV0CAwAAM5ZSdp9kJ/Bl3kwAIBy1fI1jO+S/so7FgBAwT5J+pYqjDrvWAAABWvUZUV3QgYfoAQA6IsfspdO3NuKdQwAwEtrSbuqqvYpMP6W9K+MAwIAlOmzuozo+Id8P+cbDwCgRN6OavoPPr94EACwWP1iIl588N+iLQUAOPgs6b8vHjWzmrYUACBJR0el739WGFVVtZJaM9tkGBcAoCCeBbuqqk5fPsrMbqgyAAAXrWv7L21GGREAoDhePDxe8osbqgwAWC4ze7z4qFmqDABYJj+U9u3qIvwBaxkAsDB+3ahfPyfPzB7M7O4qowIAFMfM7szsy+/8Ye3H4NbDDwsAUBIzW79rzve0oTUFADPnC923+Z8EAFAsM7v9pYXuV56o9kUQPi8DAGbm3a2oE0+48dAY5gkBANmFguBm6Ce+N7OnQZ8UAJCNLzncX+vJnzjUFgCmz4uA969bvPIPpPKFRXAAmKiwzLB6+7ff9w9dp+cFALg6v5LHeOfYhVV1jpwCgIkIc3cz9j+8ITQAYBpCWGxyDWAzamkDAPhl4VJPm9wD4RwNAChUWHfe5B6LJNpTAFAib0OVExaJf+hGeQMDgAUKb+TLPKI1pNld7rEAwFKlK40Xv1QQ+mV3uccCAEszmbBIPDSe/FP7rnsmIQAgfbzqg8+9de7x/DK/Vsl0kg4AJih0dq5zIcGx+AdzcP0pALgCn2N/zGaODYvh97SoAGAYs+3ieH/tcbL9NQAoRGhBPcx6PqVFBQC/L1xdYxlzaDiK6nHW6QgAA/F582GWLahLeP9tPos1AHAFYWH7LvdYsvJLilBtAECPVxWPi60qzmFtAwAO/IxtqopzQpo+2tifCAUABVjMEVBDscNnznJpEQCL0FvU3uQez6T4eRvpIlp3BAeAuWKuG0hI3fwfLwgAAwrnVNB+GpIfTcX6BoDJC0HBlS+uieAAMFUhKFinGBPBAWAqCIpChBeC4ABQFIKiUP7CPBEcAHIjKCYitKo4RA3AaPxUgNjx2OQeEy4UguOHB0ede0wA5qd3wt2Dma1zjwm/yV/MdFVc2lUABuFvSh+sw3kUc+Ll4m1Y57ilXQXgV/XXJwiKmeu1q+6pOgC8JlQTqe3U5B4TRmaH61WldhWL5AAk/Wxnx2qCtVB0wjsI1jqABbPuatlfwtpEk3tMKFRY64hHWDW5xwXgesxsHVpOj15Z0G3A5bwkTZcdfiY8gPnwkLin5YTBecuK8AAm7ERI3HPeBK6qFx4caQUUrHeEEyGBfM6FB/1PIA9fh7wJIfFESKA4vuYRF8wf/fs699iAOfNWU9r3LCxc17nHBrzJDhciS4fqplKY6gMYwIlW04NXFuxfV1LlHsBS+BrHWtJnSbWkVtLfknZVVW1zjQuYit4+1Ejain1oVARGBv4OKG74taSd2PiBn3oBsVb3Jmurw36yzzW2pSIwCuABciPpkwgQLNSZgIj7QZtrbOgQGAXyAGkk/aVux1mr23F2kr5J2rLzYMr8iKVah228UVc97CR9VbeNU0EUhsCYgNDCWqvbwRr/0VZdgOzEDoZChe230SEgpMP2uxUtpkkgMCbKDxds1LWxUpjsddgJW1HGY2Qn3tzUOrRYU/XAdjlRBMaMnAkR6bidtZPU8m4O7+VrDisdt06l43Boq6raZRkgBkdgzJyHSOoXx0X1Vl018l2HxUWCBEe8Yqj9tla3DaX7O3XbTmortVQO80ZgLFCYBFKQfAz39+omgr1obS2GL0KndlLaHtJjMRjSGwuqhgUiMHDkREWyCt+3OoRJqkxa8c6yeP66xttH/5pe3/S67tS9tjtJe4IBEYGBi4UwWek4TFLF0uplhbIPj+9peQ0vhMEqfP0Uvq91/Lq0IhTwGwgMDKb3Lnalw7vY9H0tDw4dqhPpUK1IIVy0wIDxduGpWy3pD70MhpWO/1/uJP2jEA5UfxgKgYFRhQmx1vGk99F/JT6WbvverfXf3aubHJM23E+/27//wqUT6htXPk1jTeoz9//Q6UCIf9/q5X/zd/WqNXGQAkZGYKB4YaLuf43300QsvZy8+9+/9fhrzoVP+8pjMdjiY0eBRiWA0v0fPGR4m68wwtkAAAAASUVORK5CYII=";class Zs extends fe.CSS2DObject{constructor(e,t){const i=document.createElement("div");super(i),this.props=e,this.amr=t,this._direction=1,this._controllingRotate=!1,this._controlling=!1,this._startAt=0,this._looper=0,this._initial=0,this._canRotate=!1,this._emitter=new ct,this.addListener=this._emitter.addListener.bind(this._emitter),this.removeListener=this._emitter.removeListener.bind(this._emitter),this._update=()=>{if(this._looper=requestAnimationFrame(this._update),this._controlling){let c=(Date.now()-this._startAt)/200;c>4&&(c=4);let u=this._initial+.005*c*this._direction;if(u>this.props.max||u<this.props.min){this.mechanism&&(u<this.props.min?(this.mechanism.position.setZ(this.props.min),this._emitter.emit("change",this.props.min)):u>this.props.max&&(this.mechanism.position.setZ(this.props.max),this._emitter.emit("change",this.props.max)));return}if(this._initial=u,!this.mechanism)return;this.mechanism.position.setZ(u),this._emitter.emit("change",u)}};const s=us();e.userData&&e.userData.target&&(this.name=e.userData.target.name,t.traverse(c=>{c.name===e.userData.target.name&&(this.mechanism=c)})),i.style.fontSize="30px",i.style.color="#0066FF",i.style.cursor="pointer",i.style.pointerEvents="auto";const a=document.createElement("div");a.style.position="absolute",a.style.left="0",a.style.transform="translateX(-50%) rotate(-180deg)",a.style.marginBottom="5px",a.style.width=a.style.height=s?"34px":"44px",a.style.background=`url(${Qs}) center no-repeat`,a.style.backgroundSize="100% auto",a.setAttribute("data-direction","up"),a.style.transition="all .2s";const o=document.createElement("div");if(o.style.position="absolute",o.style.left="0",o.style.transform="translateX(-50%)",a.style.bottom=o.style.top="8px",o.style.width=o.style.height=a.style.width,o.style.background=`url(${Qs}) center no-repeat`,o.style.backgroundSize="100% auto",o.style.transition="all .2s",o.setAttribute("data-direction","down"),Array.from([a,o]).forEach(c=>{s||c.addEventListener("mousemove",()=>{c.style.filter="invert(100%)"}),c.addEventListener("mouseleave",()=>{c.style.filter=""}),c.addEventListener("pointerdown",()=>{this.mechanism&&(c.style.filter="invert(100%)",this._controlling=!0,this._startAt=Date.now(),this._initial=this.mechanism.position.z,this._direction=c.getAttribute("data-direction")==="up"?1:-1,this._update())}),c.addEventListener("pointerup",()=>{this._controlling=!1,cancelAnimationFrame(this._looper),c.style.filter=""}),c.addEventListener("pointerleave",()=>{this._controlling=!1,cancelAnimationFrame(this._looper),c.style.filter=""})}),e.userData&&(this._canRotate=e.userData.canRotate,this._canRotate)){const{rotateTarget:c,rotateDuration:u,rotateStep:f,rotateMax:p,rotateMin:r}=e.userData;let l;if(c&&(t.traverse(h=>{h.name===c.name&&(l=h)}),l)){const h=document.createElement("div");h.style.background=`url(${il}) center no-repeat`,h.style.backgroundSize="100% auto",h.style.position="absolute",h.style.top="-50%",h.style.left="-50%",h.style.width=s?"140px":"160px",h.style.height=s?"70px":"80px",h.style.transform="translateX(-50%) translateY(-50%)",i.append(h);const g=document.createElement("div");g.style.background=`url(${tl}) center no-repeat`,g.style.backgroundSize="100% auto",g.style.width=g.style.height=s?"20px":"26px",g.style.position="absolute",g.style.top="0",g.style.transform="translateY(-50%)",g.style.marginBottom="5px",g.setAttribute("data-direction","left"),i.append(g);const _=document.createElement("div");_.style.background=`url(${el}) center no-repeat`,_.style.backgroundSize="100% auto",_.style.width=_.style.height=s?"20px":"26px",_.style.position="absolute",g.style.left=_.style.right=s?"62px":"69px",_.style.top="0",_.style.transform="translateY(-50%)",_.style.marginBottom="5px",_.setAttribute("data-direction","right"),i.append(_),Array.from([g,_]).forEach(m=>{s||m.addEventListener("mousemove",()=>{m.style.filter="invert(100%)"}),m.addEventListener("mouseleave",()=>{m.style.filter=""}),m.addEventListener("pointerdown",()=>{if(this._timer&&this._timer.isPlaying())return;m.style.filter="invert(100%)",this._controllingRotate=!0,this._startAt=Date.now(),this._direction=m.getAttribute("data-direction")==="left"?1:-1;let v=f/180*Math.PI*this._direction+l.rotation.z;v>p/180*Math.PI?v=p/180*Math.PI:v<r/180*Math.PI&&(v=r/180*Math.PI),this._timer=new It(l.rotation).to({z:v}).duration(u).start(),this._update()}),m.addEventListener("pointerup",()=>{this._controllingRotate=!1,cancelAnimationFrame(this._looper),m.style.filter=""}),m.addEventListener("pointerleave",()=>{this._controllingRotate=!1,cancelAnimationFrame(this._looper),m.style.filter=""})})}}i.append(a,o),this.scale.set(.01,.01,.01),this.matrixAutoUpdate=!1,this.updateMatrix()}hide(){this.element.style.display="none",this.traverse(e=>{e.visible=!1,e instanceof fe.CSS2DObject&&(e.element.style.visibility="hidden")}),this.visible=!1}show(){this.element.style.display="auto",this.traverse(e=>{e.visible=!0,e instanceof fe.CSS2DObject&&(e.element.style.visibility="visible")}),this.visible=!0}dispose(){this._emitter.removeAllListeners(),cancelAnimationFrame(this._looper),this.element.remove()}}class sl extends gn.CSS3DObject{constructor(e){const t=document.createElement("div");super(t),this.props=e,this._scale=.01,this._emitter=new ct,this.addEventListener=this._emitter.on.bind(this._emitter),this.removeEventListener=this._emitter.on.bind(this._emitter),this._mouseStart=new d.Vector2,this._targetSize=new d.Vector2,this._caches=[],this._sizeFlag="width",this._direction=1,this._lines=[],this._pointerdown=u=>{const{pageX:f,pageY:p}=u;this.endNode.setPointerCapture(u.pointerId),this._mouseStart.set(f,p),this._targetSize.setX(parseFloat(this.endNode.parentElement.style.width)),this._targetSize.setY(parseFloat(this.endNode.parentElement.style.height))},this._pointermove=u=>{if(!this._mouseStart.x)return;const{pageX:f,pageY:p}=u;let r=f-this._mouseStart.x,l=r+this._targetSize.x;this._sizeFlag==="height"&&(r=p-this._mouseStart.y,l=r*this._direction+this._targetSize.y);const h=l%10;l=l-h,r=(l-this._targetSize.x)*this._direction,this._sizeFlag==="height"&&(r=(l-this._targetSize.y)*this._direction),this._textNode.innerText=(l/100).toFixed(2)+" m",this.endNode.parentElement.style[this._sizeFlag]=`${l}px`},this._pointercancel=u=>{this.endNode.releasePointerCapture(u.pointerId),this._mouseStart.set(0,0)};const{start:i,end:s}=e,a=s.distanceTo(i);this.props.axios==="z"?this.props.axios="y":this.props.axios==="y"&&(this.props.axios="z"),this.props.axios==="y"&&(this._sizeFlag="height");const o=document.createElement("div");o.style.position="absolute",o.style.left="0",o.style.bottom="0",t.append(o),this._textNode=document.createElement("div"),this._textNode.innerText=a.toFixed(2)+" m",o.append(this._textNode);const c=document.createElement("div");this.endNode=c,c.style.position="absolute",c.style.left="auto",c.style.right="0",c.style.width="4px",c.style.height="4px",c.style.background="#0066FF",c.style.borderRadius="50%",c.style.margin="-2px -2px 0 0",c.style.cursor="pointer",o.append(c),this.scale.set(this._scale,this._scale,this._scale),t.style.fontSize="6px",t.style.color="#fff",o.style[this._sizeFlag]=a*100+"px",o.style.textAlign="center",this._sizeFlag==="height"?(o.style.borderLeft="0.1px dashed #fff",o.style.display="flex",o.style.alignItems="center",o.style.justifyContent="center",o.style.whiteSpace="nowrap",c.style.top="0",c.style.left="0",c.style.right="auto",c.style.margin="-2px 0 0 -2px"):o.style.borderBottom="0.1px dashed #fff",c.addEventListener("pointerdown",this._pointerdown),c.addEventListener("pointermove",this._pointermove),c.addEventListener("pointerup",this._pointercancel),s[this.props.axios]<i[this.props.axios]?this.rotateY(Math.PI):this._direction=-1}_getIndexByAxios(){return this.props.axios==="y"?1:this.props.axios==="z"?2:0}dispose(){this._lines.forEach(e=>e.dispose()),this._emitter.removeAllListeners(),this.endNode.removeEventListener("pointerdown",this._pointerdown),this.endNode.removeEventListener("pointermove",this._pointermove),this.endNode.removeEventListener("pointerup",this._pointercancel),this.element.remove(),this._caches.forEach(e=>e.clear()),this._caches=[]}}class rl extends d.Object3D{constructor(){super(),this._box3=new d.Box3,this._line11=new ti("长:"),this._line12=new ti("宽:"),this._line13=new ti("高:"),this._outline=new Er(0,0),this._radius=0,this._hasWidthConfig=!1,this._hasLengthConfig=!1,this._hasHeightConfig=!1,this.follow="",this.followOrigin=0,this.followScale=1,this.originOffset=0,this.translateCache=0,this.head=0,this.tail=0,this._change=()=>{if(!this._app)return;const e=this._app.camera;e&&this._outline.change(e.position)},this.add(this._outline,this._line11,this._line12,this._line13)}get hasSizeConfig(){return{length:this._hasLengthConfig,width:this._hasWidthConfig,height:this._hasHeightConfig}}get size(){return this._box3.clone()}get radius(){return this._radius}init(e){this._app=e,this._app.controls.addEventListener("change",this._change)}reset(){this.hide(),this._line11.reset()}generate(e,t=0){e&&(this._object=e),this.update(t)}show(e=!0){const t=[this._line11,this._line12,this._line13];e&&(this.visible=!0,this._outline.visible=!0,this._outline.show(),t.push(this._outline)),t.forEach(i=>{i.traverse(s=>{s.visible=!0,s instanceof fe.CSS2DObject&&(s.element.style.visibility="visible")})})}hide(e=!0){const t=[this._line11,this._line12,this._line13];e&&(this.visible=!1,this._outline.visible=!1,this._outline.hide(),t.push(this._outline)),t.forEach(i=>{i.traverse(s=>{s.visible=!1,s instanceof fe.CSS2DObject&&(s.element.style.visibility="hidden")})})}destroy(){var e;(e=this._app)==null||e.controls.removeEventListener("change",this._change),this._line11.destroy(),this._line12.destroy(),this._line13.destroy()}update(e=0){if(!this._object)return;const t=this._object,{box:i,maxRadius:s,hasLength:a,hasHeight:o,hasWidth:c}=Na(t);this.tail=Math.abs(i.min.x),this.head=Math.abs(i.max.x),this._hasWidthConfig=c,this._hasLengthConfig=a,this._hasHeightConfig=o,this._box3.copy(i),this._radius=s,this.follow&&e&&(this.originOffset=(this.followOrigin-e)*this.followScale),this._outline.update(this._radius),this._change();const u=this._box3.min.x,f=this._box3.max.x,p=this._box3.min.z,r=this._box3.max.z,l=this._box3.min.y,h=this._box3.max.y;let g=.2;const _=new d.Vector3(u,h,0),m=new d.Vector3(f,h,0);this._line11.update(_.clone().sub(new d.Vector3(0,-g/1.8,0)),m.clone().sub(new d.Vector3(0,-g/1.8,0)),this._radius);const v=new d.Vector3(f,l,0);this._line12.update(m.clone().add(new d.Vector3(g,0,0)),v.clone().add(new d.Vector3(g,0,0)),this._radius);const y=new d.Vector3(u,h,p),x=new d.Vector3(u,h,r),w=y.clone();w.y-=g/6;const b=x.clone();b.y-=g/6,this._line13.update(w,b,this._radius)}}class Xs extends d.Object3D{constructor(e=.6,t=.4,i=.2){super(),this.isGoods=!0,this._generate(e,t,i)}updateSize(e=.1,t=.1,i=.1){this._generate(e,t,i)}clearAll(){xe(this)}hide(){this.traverse(e=>e.visible=!1)}show(){this.traverse(e=>e.visible=!0)}_generate(e,t,i){this.clearAll();const s=new d.Mesh(new d.BoxGeometry(e,t,i),new d.MeshBasicMaterial({color:new d.Color("#0f5fd5"),transparent:!0,opacity:.4}));s.geometry.translate(0,0,i/2);const a=new d.EdgesGeometry(s.geometry),o=new d.LineDashedMaterial({color:new d.Color("#000"),dashSize:.015,gapSize:.015}),c=new d.LineSegments(a,o);c.computeLineDistances(),this.add(s,c)}}const nl="data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAAAEAAAABCAYAAAAfFcSJAAAAAXNSR0IArs4c6QAAAARzQklUCAgICHwIZIgAAAALSURBVAiZY2AAAgAABQABYlUyiAAAAABJRU5ErkJggg==";class qi{constructor(e){this._props=e,this.name="",this.transparentTexture=hs.load(nl),this._offscreen=new OffscreenCanvas(0,0),this._defaults={...e},this.target=e.target,this.parent=this.target.parent,this.reset()}get imageSize(){return this._props.imageSize}get size(){return this._props.size}get defaultConfigs(){return{canvasWidth:200,canvasHeight:200,scaleX:1,scaleY:1,x:0,y:0,ox:0,oy:0,url:this._defaults.imageUrl}}clear(){this.change()}change(e,t=new d.Vector2(1,1),i=new d.Vector2){this.imageUrl=e;let s;if(e){const a=new Image;a.crossOrigin="anonymous",a.src=e,a.onload=async()=>{var f;let o=window.devicePixelRatio*2;this._offscreen.width=a.width+o,this._offscreen.height=a.height+o;const c=this._offscreen.getContext("2d");c==null||c.clearRect(0,0,this._offscreen.width,this._offscreen.height),c==null||c.drawImage(a,o/2,o/2,a.width,a.height),s=new d.Texture(this._offscreen),s.minFilter=1003,s.colorSpace=d.SRGBColorSpace,s.wrapS=s.wrapT=d.ClampToEdgeWrapping,s.repeat.set(1/t.x,1/t.y),s.offset.set(i.x,i.y),s.flipY=!1,s.needsUpdate=!0;const u=this._props.target;u.material&&((f=u.material.map)==null||f.dispose(),s?(u.material.map=s,u.material.opacity=1):(u.material.map=this.transparentTexture,u.material.opacity=0))}}else{const a=this._props.target;a.material&&(a.material.map=this.transparentTexture)}}reset(){this._props=this._defaults,this.name=this._props.name,this.imageUrl=this._props.imageUrl,this.target=this._props.target,this.change(this.imageUrl||"")}dispose(){this._offscreen=null}}function ol(n){return n.type?n.type==="Mesh":n.isMesh}const hs=new d.TextureLoader;hs.crossOrigin="anonymous";class Fr extends d.Object3D{constructor(e){super(),this._props=e,this._emitter=new ct,this.addEventListener=this._emitter.addListener.bind(this._emitter),this._container=new d.Group,this.lines=new d.Group,this._clips=[],this._actionsMap=new Map,this._animationClock=new d.Clock,this.sizeBox=new rl,this._goodsSize=new Ga(0,0,0),this._slots=[],this._logos=[],this._skins=[],this._levels=new Map,this._bodyOpacity=1,this._masts=new Map,this._liftMaxHeight=0,this._jackMaxHeight=0,this._forkMaxHeight=0,this.controllers=[],this.goods=[],this._breathLights=[],this._shelves=new Map,this._shelfMaxLevel=1,this._url="",this._showController=!0,this._showSlots=!0,this._shapeKeys=new Map,this._shapeKeyTimer=0,this._shapeKeyCache="",this._materialsCache=new Map,this.opacityCache=void 0,this.actions=[],this._url=e.url||"",this._url&&this.load(this._url).then(),this.add(this._container,this.lines),this._props.showSizeBox&&this.add(this.sizeBox),this.showController=typeof e.showController=="boolean"?e.showController:!0,this._showSlots=typeof e.showSlots=="boolean"?e.showSlots:!0}get shapeKeys(){return this._shapeKeys}get size(){const e=this.sizeBox.size.getSize(new d.Vector3);return{width:e.z,length:e.x,height:e.y}}get goodsSize(){return this._goodsSize}get showController(){return this._showController}set showController(e){this._showController=e,this.controllers.forEach(t=>e?t.show():t.hide())}get slots(){return this._slots}get logos(){return this._logos}get skins(){return this._skins}get bodyOpacity(){return this._bodyOpacity}get fork(){return this._fork}get forkHeight(){var e;return((e=this._fork)==null?void 0:e.position.z)||0}get liftHeight(){var e;return((e=this._lift)==null?void 0:e.position.z)||0}get jack(){return this._jack}get jackHeight(){var e;return((e=this._jack)==null?void 0:e.position.z)||0}get lift(){return this._lift}set bodyOpacity(e){this._bodyOpacity=e,e<1?this._materialsCache.forEach(t=>{t.mat.transparent=!0,t.mat.opacity=e,t.mat.metalness=0,t.mat.roughness=1,t.mat.color=new d.Color("#3859be"),t.mat.needsUpdate=!0}):this._materialsCache.forEach(t=>{t.mat.transparent=t.transparent,t.mat.opacity=t.opacity,t.mat.metalness=t.metalness,t.mat.roughness=t.roughness,t.mat.color=t.color,t.mat.needsUpdate=!0})}init(e){this._app=e,this.sizeBox.init(e),this._onTicker&&this._app.renderer.domElement.removeEventListener("ticker",this._onTicker),this._onTicker=()=>{if(this._mixer){const t=this._animationClock.getDelta();this._mixer.update(t)}else this._animationClock.getDelta()},this._app.renderer.domElement.addEventListener("ticker",this._onTicker),this.addEventListener("shape-key-changed",(t,i)=>{this._slots.forEach(s=>s.shapeKeyChanged(t,i)),this.sizeBox.follow===t?(this.sizeBox.generate(this._container,i),this.sizeBox.originOffset&&(this._container.traverse(s=>{s instanceof d.Mesh&&!s.userData.isDevice&&!s.userData.isBracket&&s.geometry.translate(this.sizeBox.originOffset-this.sizeBox.translateCache,0,0),s instanceof Gi&&!s.props.slot.userData.ignoreOriginChanged&&s.parent&&s.parent.position.add(new d.Vector3(this.sizeBox.originOffset-this.sizeBox.translateCache,0,0))}),this.sizeBox.translateCache=this.sizeBox.originOffset,this.sizeBox.generate(this._container))):this.sizeBox.generate(this._container),["width","length","height"].includes(t)&&this._emitter.emit("size-changed",t,i)})}_findFirstSkinnedMesh(e){if(!e)return;let t;return e.traverse(i=>{!t&&i.isSkinnedMesh&&(t=i)}),t}async loadAnimation(e,t="glb"){let i,s;if(t==="glb"||e.endsWith(".glb")){const u=await Oe.loadAsync(e);i=u.animations||[],s=u.scene}else{console.warn("[Amr.loadAnimation] 目前仅支持 glb 动画文件",{url:e,type:t});return}if(!i||i.length===0){console.warn("[Amr.loadAnimation] 文件中未找到动画",e);return}if(!this._modelRoot){console.warn("[Amr.loadAnimation] 模型尚未加载,无法绑定动画",e);return}if(!s){console.warn("[Amr.loadAnimation] 动画文件中缺少 scene,无法执行重定向",e);return}const a=this._findFirstSkinnedMesh(s),o=this._findFirstSkinnedMesh(this._modelRoot);(!a||!o)&&console.warn("[Amr.loadAnimation] 在动画或目标模型中未找到 SkinnedMesh,使用原始动画 clip",e),this._mixer||(this._mixer=new d.AnimationMixer(this._modelRoot));const c=typeof mi.retargetClip=="function";i.forEach(u=>{let f=u;if(c&&a&&o)try{f=mi.retargetClip(o,a,u)}catch(r){console.warn("[Amr.loadAnimation] 重定向动画失败,回退到原始 clip",u.name,r)}this._clips=this._clips.filter(r=>r.name!==f.name),this._clips.push(f);const p=this._mixer.clipAction(f);this._actionsMap.set(f.name,p)}),this.actions=Array.from(this._actionsMap.keys())}async load(e,t=""){this._url=e,this.name||(this.name=e.substring(e.lastIndexOf("/")+1,e.lastIndexOf("."))),!e.startsWith("blob")&&e.endsWith(".sglb");let i,s;if(t==="glb"||e.endsWith(".glb")){let o=await Oe.loadAsync(e);i=o.scene,s=o.animations||[]}else{const c=await new ni({useCache:!0}).loadAsync(e);if(!c.glb)return;i=c.glb}const a=mi.clone(i);this._generateAmr(a,s),i=null,this._emitter.emit("amr-loaded")}changeSkin(e,t){e&&(e.change(t),this._app&&this._app.usePathTracing&&(this._app.sampleCount=0,this._app.usePathTracing&&(this._app.pathTracer.pausePathTracing=!1,this._app.pathTracer.updateMaterials())))}changeLogo(e,t){e.change(t.url,new d.Vector2(t.scaleX,t.scaleY),new d.Vector2(t.ox,t.oy))}setShapeKey(e,t,i=!0){i&&this._shapeKeyTimer&&e===this._shapeKeyCache&&clearTimeout(this._shapeKeyTimer),this._shapeKeyCache=e,this._shapeKeyTimer=window.setTimeout(()=>{this._container.traverse(s=>{if(!Object.keys(s.morphTargetDictionary||{}).includes(e))return;let a=t;s.userData[`origin_${e}`]&&(a-=s.userData[`origin_${e}`]);const o=s.morphTargetDictionary[e];s.morphTargetInfluences&&(s.morphTargetInfluences[o]=a),s instanceof d.Mesh&&s.geometry.translate(0,0,1e-5)}),i&&this._emitter.emit("shape-key-changed",e,t)},100)}_generateAmr(e,t){this._modelRoot=e,this._actionsMap.clear(),this.actions=[],this._clips=[],t&&t.length&&(this._mixer=new d.AnimationMixer(e),this._clips=t,t.forEach(i=>{const s=this._mixer.clipAction(i);this._actionsMap.set(i.name,s)}),this.actions=t.map(i=>i.name)),e.traverse(i=>{i.userData.isShelf&&(this._shelf=i),i.userData.isFork&&(this._fork=i),i.userData.isMast&&i.userData.mastLevel&&this._masts.set(i.userData.mastLevel,i),i.userData.isJack&&(this._jack=i),i.userData.isLift&&(this._lift=i),Object.keys(i.morphTargetDictionary||{}).forEach(s=>{let a=i.morphTargetInfluences[i.morphTargetDictionary[s]];i.userData[`origin_${s}`]&&(a+=i.userData[`origin_${s}`]),this._shapeKeys.has(s)||this._shapeKeys.set(s,a)})}),e.traverse(i=>{if(i instanceof d.Mesh){if(i.castShadow=!0,i.receiveShadow=!0,i.material)if(Array.isArray(i.material))i.material.forEach(a=>{a.userData.changeColor&&(this.skins.find(o=>o.name===a.userData.name)||this.skins.push(new ts({name:a.userData.name,target:a})))});else{if(i.material.userData.isBreathLight&&i.material.emissiveIntensity){i.material.emissive||(i.material.emissive=new d.Color(16777215)),i.material.emissiveIntensity=2,i.material.toneMapped=!1;const a=1e3,o=new ye.Tween(i.material).to({emissiveIntensity:.2}).easing(ye.Easing.Quintic.InOut).duration(a),c=new ye.Tween(i.material).to({emissiveIntensity:2}).easing(ye.Easing.Quintic.InOut).duration(a);o.onComplete(()=>c.start()),c.onComplete(()=>o.start()),o.start(),this._breathLights.push(o,c)}i.material.userData.changeColor&&(this.skins.find(a=>a.name===i.material.userData.name)||this.skins.push(new ts({name:i.material.userData.name,target:i.material})))}if(i.material)if(Array.isArray(i.material))i.material.forEach(o=>{if(o.userData.isLOGO){i.material.transparent=!0;let c;const u={width:0,height:0};i.material.map&&i.material.map.image&&(u.width=i.material.map.image.width,u.height=i.material.map.image.height,c=Wi(i.material.map.image));const f=new qi({name:o.userData.name,target:i,size:Gs(i),imageSize:u,imageUrl:c});this._logos.push(f)}o.userData.isTransparent&&(o.transparent=!0),this._materialsCache.set(o.uuid,{opacity:o.opacity,transparent:o.transparent,roughness:o.roughness,metalness:o.metalness,color:o.color,mat:o})});else{const a=i.material;if(a.userData.isLOGO){i.material.transparent=!0;let o;const c={width:0,height:0};i.material.map&&i.material.map.image&&(c.width=i.material.map.image.width,c.height=i.material.map.image.height,o=Wi(i.material.map.image));const u=new qi({name:a.userData.name,target:i,size:Gs(i),imageSize:c,imageUrl:o});this._logos.push(u)}a.userData.isTransparent&&(a.transparent=!0),this._materialsCache.set(a.uuid,{opacity:a.opacity,transparent:a.transparent,roughness:a.roughness,metalness:a.metalness,color:a.color,mat:a})}}this.generateController(i,e),this.generateDimension(i,e);const s=this.generateSlot(i,e);s&&this._slots.push(s),i.userData.isOrigin&&Object.keys(i.userData).forEach(o=>{if(o.startsWith("follow_")){const c=o.replace("follow_","");this.shapeKeys.has(c)&&(this.sizeBox.follow=c,this.sizeBox.followOrigin=this._shapeKeys.get(c)||0,this.sizeBox.followScale=i.userData[o])}})}),this.slots.forEach(i=>{i.props.mirrorTarget&&(i.mirrorTarget=this.slots.find(s=>s.props.slot.name===i.props.mirrorTarget))}),e.updateMatrixWorld(!0),this._container.add(e),this.sizeBox.generate(e),this.sizeBox.show()}setHeight(e){this.setShapeKey("height",e)}setWeight(e){this.setShapeKey("width",e)}setLength(e){this.setShapeKey("length",e)}limitValue(e){this.name==="SFL-CDD14"&&(e>1.6?this.setShapeKey("mast",1):this.setShapeKey("mast",0)),["SFL-CDD20","SFL-CDD20-Y"].includes(this.name)&&(e>1.6?this.setShapeKey("mast",1):this.setShapeKey("mast",0)),this.name==="SFL-CDD15"&&(e>2.43?this.setShapeKey("mast",1):this.setShapeKey("mast",0)),["SFL-CPD20-Y","SFL-CPD30-Y"].includes(this.name)&&(e>3.5?this.setShapeKey("mast",2):e>3?this.setShapeKey("mast",1):this.setShapeKey("mast",0))}setForkHeight(e){if(this._fork){if(e>this._forkMaxHeight&&(e=this._forkMaxHeight),this._fork.position.z=e,this._masts.size===1){const t=this._masts.get(2),i=(t==null?void 0:t.userData.startHeight)||.1;t&&(t.position.z=(e-i)*.5)}this._emitter.emit("fork-height-change",e)}}setForkMaxHeight(e){this._fork&&(this._forkMaxHeight=e,this.limitValue(e),this.controllers.forEach(t=>{t.name.toLowerCase().includes("fork")&&(t.props.max=e)}),this._fork&&this.forkHeight>this._forkMaxHeight&&this.setForkHeight(e))}setLiftHeight(e){this._lift&&(e>this._liftMaxHeight&&(e=this._liftMaxHeight),this._lift.position.z=e)}getLiftMaxHeight(){return this._liftMaxHeight}setLiftMaxHeight(e){if(!this._lift)return;this._liftMaxHeight=e,this.limitValue(e),this.controllers.forEach(a=>{a.name.toLowerCase().includes("lift")&&(a.props.max=e)}),this.liftHeight>this._liftMaxHeight&&this.setLiftHeight(e);let t=.46;this.levelOffset&&(t=this.levelOffset+.1);let i=e+t;const s=this.getShelfMinHeight()+t||0;i<s&&(i=s),this.setHeight(i)}setJackMaxHeight(e){this._jack&&(this._jackMaxHeight=e,this.limitValue(e),this.controllers.forEach(t=>{t.name.toLowerCase().includes("jack")&&(t.props.max=e)}),this.jackHeight>this._jackMaxHeight&&this.setJackHeight(e))}setJackHeight(e){this._jack&&(e>this._jackMaxHeight&&(e=this._jackMaxHeight),requestAnimationFrame(()=>{this.setShapeKey("jackHeight",e,!1)}),this._jack.position.z=e)}setLevel(e){}setGoodsSize(e){this._goodsSize.length=e.length,this._goodsSize.width=e.width,this._goodsSize.height=e.height,this.setShelfLevel(this._shelfMaxLevel)}getShelfMinHeight(){const e=this.levelOffset,t=this._shelfMaxLevel,i=this._shelves.get(0);return i?i.position.z+e*t+.1:0}getShelfMaxShelfHeight(){const e=this.levelOffset,t=this._shelfMaxLevel,i=this._shelves.get(0);if(i)return i.position.z+e*(t-1)}get levelOffset(){return this._goodsSize.height+.2}setShapeKeyToMesh(e,t,i){if(!Object.keys(e.morphTargetDictionary||{}).includes(t))return;const s=e.morphTargetDictionary[t];e.morphTargetInfluences&&(e.morphTargetInfluences[s]=i),e.geometry.translate(0,0,1e-5)}setShelfLevel(e=3){var s;if(!this._shelf)return;this._shelfMaxLevel=e;const t=this.levelOffset;this._shelves.delete(0),this._shelves.forEach(a=>{xe(a),a.parent&&a.removeFromParent()}),this.goods=[],this._shelves.clear(),this._shelves.set(0,this._shelf);for(let a=1;a<e;a++){if(!this._shelf)return;this._shelf.traverse(u=>{ol(u)&&(this.setShapeKeyToMesh(u,"goodsWidth",this._goodsSize.width),this.setShapeKeyToMesh(u,"goodsLength",this._goodsSize.length))});const o=this._shelf.clone(!0);o.position.z+=t*a,this._shelves.set(a,o),(s=this._shelf.parent)==null||s.add(o);let c;if(o.traverse(u=>{u.userData.isShelfContainer&&(c=u)}),(this.shapeKeys.has("goodsLength")||this.shapeKeys.has("goodsWidth"))&&(c==null||c.position.setX((c==null?void 0:c.position.x)-this._goodsSize.length/2)),c){const u=new Xs(this._goodsSize.length,this._goodsSize.width,this._goodsSize.height);if(c.add(u),this.goods.push(u),a===1){const f=new Xs(this._goodsSize.length,this._goodsSize.width,this._goodsSize.height);f.position.z-=t,c.add(f),this.goods.push(f)}}}const i=this.getShelfMinHeight()||0;this._liftMaxHeight<i&&this.setLiftMaxHeight(i)}generateOuterLine(){this.traverse(e=>{if(e.userData.isOuterObject){const t=this.sizeBox.radius;this._outline?this._outline.update(t):(this._outline=new Er(t,0),this.add(this._outline))}})}generateController(e,t){if(this.showController){if(e.userData.isForkController&&e.userData.target){const i=e.userData.target.name,{min:s,max:a}=e.userData;let o;if(t.traverse(u=>{u.name===i&&(o=u)}),!o)return;const c=new Zs({name:"",target:i,default:0,min:s,max:a},o);e.add(c)}else if(e.userData.isController&&e.userData.target){const i=e.userData.target.name,{min:s,max:a}=e.userData;let o;if(t.traverse(u=>{u.name===i&&(o=u)}),!o)return;const c=new Zs({name:"",userData:e.userData,target:e.userData.key,default:0,min:s||0,max:a||1},o);e.add(c),this.controllers.push(c),(o.userData.isFork||o.userData.isLift||o.userData.isJack)&&(this._forkMaxHeight=a||1,this._liftMaxHeight=a||1,this._jackMaxHeight=a||1,c.addListener("change",u=>{this.setForkHeight(u),this.setLiftHeight(u),this.setJackHeight(u)}))}}}generateDimension(e,t){if(e.userData.isDimension){const i=e.userData.divider,s=Ua(e.userData.startOrigin),a=e.userData.axios;let o,c;if(a==="x"?(o=new d.Vector3(e.userData.start-e.position.x,0,0),c=o.clone().setX(e.userData.end-e.position.x)):a==="z"?(o=new d.Vector3(0,e.userData.start-e.position.y,0),c=o.clone().setY(e.userData.end-e.position.y)):(o=new d.Vector3(0,0,e.userData.start-e.position.z),c=o.clone().setZ(e.userData.end-e.position.z)),!Object.keys(e.userData).flatMap(r=>r.startsWith("target")?e.userData[r].name:[]).length)return;const p=new sl({start:o,end:c,startOrigin:s,axios:a,divider:i});e.add(p)}}generateSlot(e,t){var i,s;if(e.userData.isSlot){const a=e.userData.name,o=e.userData.isMirror,c=(i=e.userData.mirrorSlot)==null?void 0:i.name;if(a){const u=e.userData.holeTarget&&e.userData.holeTarget.name;let f;u&&t.traverse(h=>{h.name===u&&(f=h)});const p=new Map;Object.keys(e.userData).forEach(h=>{if(h.startsWith("follow_")){const g=h.split("_")[1];if(g){let _=e.userData[h];p.set(g,{scale:_,origin:this.shapeKeys.get(g)||0})}}});const r=(s=this._app)==null?void 0:s.props.isMobile,l=new Gi({name:a,follows:p,slot:e,show:this._showSlots,isMirror:o,mirrorTarget:c,isMobile:r});return l.holeTarget=f,l.addEventListener(q.ON_DROP,h=>{this._app&&this._app.props.useSound&&this._app.sound.play()}),l.addEventListener(q.ON_BEFORE_SELECTED,h=>{this._slots.forEach(g=>{g.selected&&(g.selected=!1)})}),l.addEventListener(q.ON_ERROR_STATE_CHANGE,h=>{if(this._app)if(this._app._outlinePassError.selectedObjects=this._app._outlinePassError.selectedObjects.filter(g=>!!g.parent),h){if(l.device){if(this._app._outlinePassError.selectedObjects.find(_=>{var m;return _.parent==((m=l.device)==null?void 0:m.parent)}))return;this._app._outlinePassError.selectedObjects=[l.device,...this._app._outlinePassError.selectedObjects]}}else l.device&&(this._app._outlinePassError.selectedObjects=this._app._outlinePassError.selectedObjects.filter(g=>{var _;return g.parent!=((_=l.device)==null?void 0:_.parent)}))}),l}}}clean(){this._emitter.removeAllListeners(),this.controllers.forEach(e=>e.dispose()),this.controllers=[],xe(this._container),this._levels.forEach(e=>e.destroy()),this._levels.clear(),this._slots=[],this._logos=[],this._skins=[],this._materialsCache.clear(),this.opacityCache=void 0,this._breathLights.forEach(e=>e.stop()),this._breathLights=[],this.sizeBox.reset(),this._mixer&&this._mixer.stopAllAction(),this._mixer=void 0,this._clips=[],this._actionsMap.clear(),this.actions=[],this._app&&this._onTicker&&this._app.renderer.domElement.removeEventListener("ticker",this._onTicker),this._onTicker=void 0}destroy(){this.clean(),this.sizeBox.destroy()}playAction(e,t=!0,i){const s=this._actionsMap.get(e);return!s||!this._mixer?Promise.reject(new Error(`Action "${e}" not found or mixer not initialized.`)):(t&&s.reset(),this._actionsMap.forEach((a,o)=>{o!==e&&a.stop()}),s.enabled=!0,s.paused=!1,s.setLoop(d.LoopOnce,0),s.setEffectiveTimeScale((i==null?void 0:i.timeScale)??1),s.setEffectiveWeight(1),s.clampWhenFinished=(i==null?void 0:i.clampWhenFinished)??!0,i!=null&&i.fadeIn&&i.fadeIn>0&&s.fadeIn(i.fadeIn),new Promise(a=>{const o=c=>{var u;c.action===s&&((u=this._mixer)==null||u.removeEventListener("finished",o),a())};this._mixer.addEventListener("finished",o),s.play()}))}pauseAction(e){const t=this._actionsMap.get(e);t&&(t.paused=!0)}}const Br=0,al=1,ll=2,Ks=2,Si=1.25,Js=1,Pt=6*4+4+4,hi=65535,cl=Math.pow(2,-24),Mi=Symbol("SKIP_GENERATION");function ul(n){return n.index?n.index.count:n.attributes.position.count}function ut(n){return ul(n)/3}function hl(n,e=ArrayBuffer){return n>65535?new Uint32Array(new e(4*n)):new Uint16Array(new e(2*n))}function fl(n,e){if(!n.index){const t=n.attributes.position.count,i=e.useSharedArrayBuffer?SharedArrayBuffer:ArrayBuffer,s=hl(t,i);n.setIndex(new d.BufferAttribute(s,1));for(let a=0;a<t;a++)s[a]=a}}function kr(n){const e=ut(n),t=n.drawRange,i=t.start/3,s=(t.start+t.count)/3,a=Math.max(0,i),o=Math.min(e,s)-a;return[{offset:Math.floor(a),count:Math.floor(o)}]}function Or(n){if(!n.groups||!n.groups.length)return kr(n);const e=[],t=new Set,i=n.drawRange,s=i.start/3,a=(i.start+i.count)/3;for(const c of n.groups){const u=c.start/3,f=(c.start+c.count)/3;t.add(Math.max(s,u)),t.add(Math.min(a,f))}const o=Array.from(t.values()).sort((c,u)=>c-u);for(let c=0;c<o.length-1;c++){const u=o[c],f=o[c+1];e.push({offset:Math.floor(u),count:Math.floor(f-u)})}return e}function dl(n){if(n.groups.length===0)return!1;const e=ut(n),t=Or(n).sort((a,o)=>a.offset-o.offset),i=t[t.length-1];i.count=Math.min(e-i.offset,i.count);let s=0;return t.forEach(({count:a})=>s+=a),e!==s}function Ci(n,e,t,i,s){let a=1/0,o=1/0,c=1/0,u=-1/0,f=-1/0,p=-1/0,r=1/0,l=1/0,h=1/0,g=-1/0,_=-1/0,m=-1/0;for(let v=e*6,y=(e+t)*6;v<y;v+=6){const x=n[v+0],w=n[v+1],b=x-w,A=x+w;b<a&&(a=b),A>u&&(u=A),x<r&&(r=x),x>g&&(g=x);const T=n[v+2],I=n[v+3],C=T-I,P=T+I;C<o&&(o=C),P>f&&(f=P),T<l&&(l=T),T>_&&(_=T);const D=n[v+4],S=n[v+5],M=D-S,R=D+S;M<c&&(c=M),R>p&&(p=R),D<h&&(h=D),D>m&&(m=D)}i[0]=a,i[1]=o,i[2]=c,i[3]=u,i[4]=f,i[5]=p,s[0]=r,s[1]=l,s[2]=h,s[3]=g,s[4]=_,s[5]=m}function pl(n,e=null,t=null,i=null){const s=n.attributes.position,a=n.index?n.index.array:null,o=ut(n),c=s.normalized;let u;e===null?(u=new Float32Array(o*6*4),t=0,i=o):(u=e,t=t||0,i=i||o);const f=s.array,p=s.offset||0;let r=3;s.isInterleavedBufferAttribute&&(r=s.data.stride);const l=["getX","getY","getZ"];for(let h=t;h<t+i;h++){const g=h*3,_=h*6;let m=g+0,v=g+1,y=g+2;a&&(m=a[m],v=a[v],y=a[y]),c||(m=m*r+p,v=v*r+p,y=y*r+p);for(let x=0;x<3;x++){let w,b,A;c?(w=s[l[x]](m),b=s[l[x]](v),A=s[l[x]](y)):(w=f[m+x],b=f[v+x],A=f[y+x]);let T=w;b<T&&(T=b),A<T&&(T=A);let I=w;b>I&&(I=b),A>I&&(I=A);const C=(I-T)/2,P=x*2;u[_+P+0]=T+C,u[_+P+1]=C+(Math.abs(T)+C)*cl}}return u}function N(n,e,t){return t.min.x=e[n],t.min.y=e[n+1],t.min.z=e[n+2],t.max.x=e[n+3],t.max.y=e[n+4],t.max.z=e[n+5],t}function $s(n){let e=-1,t=-1/0;for(let i=0;i<3;i++){const s=n[i+3]-n[i];s>t&&(t=s,e=i)}return e}function er(n,e){e.set(n)}function tr(n,e,t){let i,s;for(let a=0;a<3;a++){const o=a+3;i=n[a],s=e[a],t[a]=i<s?i:s,i=n[o],s=e[o],t[o]=i>s?i:s}}function Ut(n,e,t){for(let i=0;i<3;i++){const s=e[n+2*i],a=e[n+2*i+1],o=s-a,c=s+a;o<t[i]&&(t[i]=o),c>t[i+3]&&(t[i+3]=c)}}function yt(n){const e=n[3]-n[0],t=n[4]-n[1],i=n[5]-n[2];return 2*(e*t+t*i+i*e)}const me=32,ml=(n,e)=>n.candidate-e.candidate,Te=new Array(me).fill().map(()=>({count:0,bounds:new Float32Array(6),rightCacheBounds:new Float32Array(6),leftCacheBounds:new Float32Array(6),candidate:0})),Ht=new Float32Array(6);function gl(n,e,t,i,s,a){let o=-1,c=0;if(a===Br)o=$s(e),o!==-1&&(c=(e[o]+e[o+3])/2);else if(a===al)o=$s(n),o!==-1&&(c=vl(t,i,s,o));else if(a===ll){const u=yt(n);let f=Si*s;const p=i*6,r=(i+s)*6;for(let l=0;l<3;l++){const h=e[l],m=(e[l+3]-h)/me;if(s<me/4){const v=[...Te];v.length=s;let y=0;for(let w=p;w<r;w+=6,y++){const b=v[y];b.candidate=t[w+2*l],b.count=0;const{bounds:A,leftCacheBounds:T,rightCacheBounds:I}=b;for(let C=0;C<3;C++)I[C]=1/0,I[C+3]=-1/0,T[C]=1/0,T[C+3]=-1/0,A[C]=1/0,A[C+3]=-1/0;Ut(w,t,A)}v.sort(ml);let x=s;for(let w=0;w<x;w++){const b=v[w];for(;w+1<x&&v[w+1].candidate===b.candidate;)v.splice(w+1,1),x--}for(let w=p;w<r;w+=6){const b=t[w+2*l];for(let A=0;A<x;A++){const T=v[A];b>=T.candidate?Ut(w,t,T.rightCacheBounds):(Ut(w,t,T.leftCacheBounds),T.count++)}}for(let w=0;w<x;w++){const b=v[w],A=b.count,T=s-b.count,I=b.leftCacheBounds,C=b.rightCacheBounds;let P=0;A!==0&&(P=yt(I)/u);let D=0;T!==0&&(D=yt(C)/u);const S=Js+Si*(P*A+D*T);S<f&&(o=l,f=S,c=b.candidate)}}else{for(let x=0;x<me;x++){const w=Te[x];w.count=0,w.candidate=h+m+x*m;const b=w.bounds;for(let A=0;A<3;A++)b[A]=1/0,b[A+3]=-1/0}for(let x=p;x<r;x+=6){let A=~~((t[x+2*l]-h)/m);A>=me&&(A=me-1);const T=Te[A];T.count++,Ut(x,t,T.bounds)}const v=Te[me-1];er(v.bounds,v.rightCacheBounds);for(let x=me-2;x>=0;x--){const w=Te[x],b=Te[x+1];tr(w.bounds,b.rightCacheBounds,w.rightCacheBounds)}let y=0;for(let x=0;x<me-1;x++){const w=Te[x],b=w.count,A=w.bounds,I=Te[x+1].rightCacheBounds;b!==0&&(y===0?er(A,Ht):tr(A,Ht,Ht)),y+=b;let C=0,P=0;y!==0&&(C=yt(Ht)/u);const D=s-y;D!==0&&(P=yt(I)/u);const S=Js+Si*(C*y+P*D);S<f&&(o=l,f=S,c=w.candidate)}}}}else console.warn(`MeshBVH: Invalid build strategy value ${a} used.`);return{axis:o,pos:c}}function vl(n,e,t,i){let s=0;for(let a=e,o=e+t;a<o;a++)s+=n[a*6+i*2];return s/t}class Ii{constructor(){this.boundingData=new Float32Array(6)}}function _l(n,e,t,i,s,a){let o=i,c=i+s-1;const u=a.pos,f=a.axis*2;for(;;){for(;o<=c&&t[o*6+f]<u;)o++;for(;o<=c&&t[c*6+f]>=u;)c--;if(o<c){for(let p=0;p<3;p++){let r=e[o*3+p];e[o*3+p]=e[c*3+p],e[c*3+p]=r}for(let p=0;p<6;p++){let r=t[o*6+p];t[o*6+p]=t[c*6+p],t[c*6+p]=r}o++,c--}else return o}}function yl(n,e,t,i,s,a){let o=i,c=i+s-1;const u=a.pos,f=a.axis*2;for(;;){for(;o<=c&&t[o*6+f]<u;)o++;for(;o<=c&&t[c*6+f]>=u;)c--;if(o<c){let p=n[o];n[o]=n[c],n[c]=p;for(let r=0;r<6;r++){let l=t[o*6+r];t[o*6+r]=t[c*6+r],t[c*6+r]=l}o++,c--}else return o}}function K(n,e){return e[n+15]===65535}function ee(n,e){return e[n+6]}function te(n,e){return e[n+14]}function ie(n){return n+8}function se(n,e){return e[n+6]}function zr(n,e){return e[n+7]}let Vr,Mt,ii,Ur;const xl=Math.pow(2,32);function ji(n){return"count"in n?1:1+ji(n.left)+ji(n.right)}function wl(n,e,t){return Vr=new Float32Array(t),Mt=new Uint32Array(t),ii=new Uint16Array(t),Ur=new Uint8Array(t),Yi(n,e)}function Yi(n,e){const t=n/4,i=n/2,s="count"in e,a=e.boundingData;for(let o=0;o<6;o++)Vr[t+o]=a[o];if(s)if(e.buffer){const o=e.buffer;Ur.set(new Uint8Array(o),n);for(let c=n,u=n+o.byteLength;c<u;c+=Pt){const f=c/2;K(f,ii)||(Mt[c/4+6]+=t)}return n+o.byteLength}else{const o=e.offset,c=e.count;return Mt[t+6]=o,ii[i+14]=c,ii[i+15]=hi,n+Pt}else{const o=e.left,c=e.right,u=e.splitAxis;let f;if(f=Yi(n+Pt,o),f/4>xl)throw new Error("MeshBVH: Cannot store child pointer greater than 32 bits.");return Mt[t+6]=f/4,f=Yi(f,c),Mt[t+7]=u,f}}function bl(n,e){const t=(n.index?n.index.count:n.attributes.position.count)/3,i=t>2**16,s=i?4:2,a=e?new SharedArrayBuffer(t*s):new ArrayBuffer(t*s),o=i?new Uint32Array(a):new Uint16Array(a);for(let c=0,u=o.length;c<u;c++)o[c]=c;return o}function Al(n,e,t,i,s){const{maxDepth:a,verbose:o,maxLeafTris:c,strategy:u,onProgress:f,indirect:p}=s,r=n._indirectBuffer,l=n.geometry,h=l.index?l.index.array:null,g=p?yl:_l,_=ut(l),m=new Float32Array(6);let v=!1;const y=new Ii;return Ci(e,t,i,y.boundingData,m),w(y,t,i,m),y;function x(b){f&&f(b/_)}function w(b,A,T,I=null,C=0){if(!v&&C>=a&&(v=!0,o&&(console.warn(`MeshBVH: Max depth of ${a} reached when generating BVH. Consider increasing maxDepth.`),console.warn(l))),T<=c||C>=a)return x(A+T),b.offset=A,b.count=T,b;const P=gl(b.boundingData,I,e,A,T,u);if(P.axis===-1)return x(A+T),b.offset=A,b.count=T,b;const D=g(r,h,e,A,T,P);if(D===A||D===A+T)x(A+T),b.offset=A,b.count=T;else{b.splitAxis=P.axis;const S=new Ii,M=A,R=D-A;b.left=S,Ci(e,M,R,S.boundingData,m),w(S,M,R,m,C+1);const E=new Ii,F=D,O=T-R;b.right=E,Ci(e,F,O,E.boundingData,m),w(E,F,O,m,C+1)}return b}}function Tl(n,e){const t=n.geometry;e.indirect&&(n._indirectBuffer=bl(t,e.useSharedArrayBuffer),dl(t)&&!e.verbose&&console.warn('MeshBVH: Provided geometry contains groups that do not fully span the vertex contents while using the "indirect" option. BVH may incorrectly report intersections on unrendered portions of the geometry.')),n._indirectBuffer||fl(t,e);const i=e.useSharedArrayBuffer?SharedArrayBuffer:ArrayBuffer,s=pl(t),a=e.indirect?kr(t):Or(t);n._roots=a.map(o=>{const c=Al(n,s,o.offset,o.count,e),u=ji(c),f=new i(Pt*u);return wl(0,c,f),f})}class we{constructor(){this.min=1/0,this.max=-1/0}setFromPointsField(e,t){let i=1/0,s=-1/0;for(let a=0,o=e.length;a<o;a++){const u=e[a][t];i=u<i?u:i,s=u>s?u:s}this.min=i,this.max=s}setFromPoints(e,t){let i=1/0,s=-1/0;for(let a=0,o=t.length;a<o;a++){const c=t[a],u=e.dot(c);i=u<i?u:i,s=u>s?u:s}this.min=i,this.max=s}isSeparated(e){return this.min>e.max||e.min>this.max}}we.prototype.setFromBox=function(){const n=new d.Vector3;return function(t,i){const s=i.min,a=i.max;let o=1/0,c=-1/0;for(let u=0;u<=1;u++)for(let f=0;f<=1;f++)for(let p=0;p<=1;p++){n.x=s.x*u+a.x*(1-u),n.y=s.y*f+a.y*(1-f),n.z=s.z*p+a.z*(1-p);const r=t.dot(n);o=Math.min(r,o),c=Math.max(r,c)}this.min=o,this.max=c}}();const Sl=function(){const n=new d.Vector3,e=new d.Vector3,t=new d.Vector3;return function(s,a,o){const c=s.start,u=n,f=a.start,p=e;t.subVectors(c,f),n.subVectors(s.end,s.start),e.subVectors(a.end,a.start);const r=t.dot(p),l=p.dot(u),h=p.dot(p),g=t.dot(u),m=u.dot(u)*h-l*l;let v,y;m!==0?v=(r*l-g*h)/m:v=0,y=(r+v*l)/h,o.x=v,o.y=y}}(),fs=function(){const n=new d.Vector2,e=new d.Vector3,t=new d.Vector3;return function(s,a,o,c){Sl(s,a,n);let u=n.x,f=n.y;if(u>=0&&u<=1&&f>=0&&f<=1){s.at(u,o),a.at(f,c);return}else if(u>=0&&u<=1){f<0?a.at(0,c):a.at(1,c),s.closestPointToPoint(c,!0,o);return}else if(f>=0&&f<=1){u<0?s.at(0,o):s.at(1,o),a.closestPointToPoint(o,!0,c);return}else{let p;u<0?p=s.start:p=s.end;let r;f<0?r=a.start:r=a.end;const l=e,h=t;if(s.closestPointToPoint(r,!0,e),a.closestPointToPoint(p,!0,t),l.distanceToSquared(r)<=h.distanceToSquared(p)){o.copy(l),c.copy(r);return}else{o.copy(p),c.copy(h);return}}}}(),Ml=function(){const n=new d.Vector3,e=new d.Vector3,t=new d.Plane,i=new d.Line3;return function(a,o){const{radius:c,center:u}=a,{a:f,b:p,c:r}=o;if(i.start=f,i.end=p,i.closestPointToPoint(u,!0,n).distanceTo(u)<=c||(i.start=f,i.end=r,i.closestPointToPoint(u,!0,n).distanceTo(u)<=c)||(i.start=p,i.end=r,i.closestPointToPoint(u,!0,n).distanceTo(u)<=c))return!0;const _=o.getPlane(t);if(Math.abs(_.distanceToPoint(u))<=c){const v=_.projectPoint(u,e);if(o.containsPoint(v))return!0}return!1}}(),Cl=1e-15;function Ri(n){return Math.abs(n)<Cl}class ce extends d.Triangle{constructor(...e){super(...e),this.isExtendedTriangle=!0,this.satAxes=new Array(4).fill().map(()=>new d.Vector3),this.satBounds=new Array(4).fill().map(()=>new we),this.points=[this.a,this.b,this.c],this.sphere=new d.Sphere,this.plane=new d.Plane,this.needsUpdate=!0}intersectsSphere(e){return Ml(e,this)}update(){const e=this.a,t=this.b,i=this.c,s=this.points,a=this.satAxes,o=this.satBounds,c=a[0],u=o[0];this.getNormal(c),u.setFromPoints(c,s);const f=a[1],p=o[1];f.subVectors(e,t),p.setFromPoints(f,s);const r=a[2],l=o[2];r.subVectors(t,i),l.setFromPoints(r,s);const h=a[3],g=o[3];h.subVectors(i,e),g.setFromPoints(h,s),this.sphere.setFromPoints(this.points),this.plane.setFromNormalAndCoplanarPoint(c,e),this.needsUpdate=!1}}ce.prototype.closestPointToSegment=function(){const n=new d.Vector3,e=new d.Vector3,t=new d.Line3;return function(s,a=null,o=null){const{start:c,end:u}=s,f=this.points;let p,r=1/0;for(let l=0;l<3;l++){const h=(l+1)%3;t.start.copy(f[l]),t.end.copy(f[h]),fs(t,s,n,e),p=n.distanceToSquared(e),p<r&&(r=p,a&&a.copy(n),o&&o.copy(e))}return this.closestPointToPoint(c,n),p=c.distanceToSquared(n),p<r&&(r=p,a&&a.copy(n),o&&o.copy(c)),this.closestPointToPoint(u,n),p=u.distanceToSquared(n),p<r&&(r=p,a&&a.copy(n),o&&o.copy(u)),Math.sqrt(r)}}();ce.prototype.intersectsTriangle=function(){const n=new ce,e=new Array(3),t=new Array(3),i=new we,s=new we,a=new d.Vector3,o=new d.Vector3,c=new d.Vector3,u=new d.Vector3,f=new d.Vector3,p=new d.Line3,r=new d.Line3,l=new d.Line3,h=new d.Vector3;function g(_,m,v){const y=_.points;let x=0,w=-1;for(let b=0;b<3;b++){const{start:A,end:T}=p;A.copy(y[b]),T.copy(y[(b+1)%3]),p.delta(o);const I=Ri(m.distanceToPoint(A));if(Ri(m.normal.dot(o))&&I){v.copy(p),x=2;break}const C=m.intersectLine(p,h);if(!C&&I&&h.copy(A),(C||I)&&!Ri(h.distanceTo(T))){if(x<=1)(x===1?v.start:v.end).copy(h),I&&(w=x);else if(x>=2){(w===1?v.start:v.end).copy(h),x=2;break}if(x++,x===2&&w===-1)break}}return x}return function(m,v=null,y=!1){this.needsUpdate&&this.update(),m.isExtendedTriangle?m.needsUpdate&&m.update():(n.copy(m),n.update(),m=n);const x=this.plane,w=m.plane;if(Math.abs(x.normal.dot(w.normal))>1-1e-10){const b=this.satBounds,A=this.satAxes;t[0]=m.a,t[1]=m.b,t[2]=m.c;for(let C=0;C<4;C++){const P=b[C],D=A[C];if(i.setFromPoints(D,t),P.isSeparated(i))return!1}const T=m.satBounds,I=m.satAxes;e[0]=this.a,e[1]=this.b,e[2]=this.c;for(let C=0;C<4;C++){const P=T[C],D=I[C];if(i.setFromPoints(D,e),P.isSeparated(i))return!1}for(let C=0;C<4;C++){const P=A[C];for(let D=0;D<4;D++){const S=I[D];if(a.crossVectors(P,S),i.setFromPoints(a,e),s.setFromPoints(a,t),i.isSeparated(s))return!1}}return v&&(y||console.warn("ExtendedTriangle.intersectsTriangle: Triangles are coplanar which does not support an output edge. Setting edge to 0, 0, 0."),v.start.set(0,0,0),v.end.set(0,0,0)),!0}else{const b=g(this,w,r);if(b===1&&m.containsPoint(r.end))return v&&(v.start.copy(r.end),v.end.copy(r.end)),!0;if(b!==2)return!1;const A=g(m,x,l);if(A===1&&this.containsPoint(l.end))return v&&(v.start.copy(l.end),v.end.copy(l.end)),!0;if(A!==2)return!1;if(r.delta(c),l.delta(u),c.dot(u)<0){let M=l.start;l.start=l.end,l.end=M}const T=r.start.dot(c),I=r.end.dot(c),C=l.start.dot(c),P=l.end.dot(c),D=I<C,S=T<P;return T!==P&&C!==I&&D===S?!1:(v&&(f.subVectors(r.start,l.start),f.dot(c)>0?v.start.copy(r.start):v.start.copy(l.start),f.subVectors(r.end,l.end),f.dot(c)<0?v.end.copy(r.end):v.end.copy(l.end)),!0)}}}();ce.prototype.distanceToPoint=function(){const n=new d.Vector3;return function(t){return this.closestPointToPoint(t,n),t.distanceTo(n)}}();ce.prototype.distanceToTriangle=function(){const n=new d.Vector3,e=new d.Vector3,t=["a","b","c"],i=new d.Line3,s=new d.Line3;return function(o,c=null,u=null){const f=c||u?i:null;if(this.intersectsTriangle(o,f))return(c||u)&&(c&&f.getCenter(c),u&&f.getCenter(u)),0;let p=1/0;for(let r=0;r<3;r++){let l;const h=t[r],g=o[h];this.closestPointToPoint(g,n),l=g.distanceToSquared(n),l<p&&(p=l,c&&c.copy(n),u&&u.copy(g));const _=this[h];o.closestPointToPoint(_,n),l=_.distanceToSquared(n),l<p&&(p=l,c&&c.copy(_),u&&u.copy(n))}for(let r=0;r<3;r++){const l=t[r],h=t[(r+1)%3];i.set(this[l],this[h]);for(let g=0;g<3;g++){const _=t[g],m=t[(g+1)%3];s.set(o[_],o[m]),fs(i,s,n,e);const v=n.distanceToSquared(e);v<p&&(p=v,c&&c.copy(n),u&&u.copy(e))}}return Math.sqrt(p)}}();class Q{constructor(e,t,i){this.isOrientedBox=!0,this.min=new d.Vector3,this.max=new d.Vector3,this.matrix=new d.Matrix4,this.invMatrix=new d.Matrix4,this.points=new Array(8).fill().map(()=>new d.Vector3),this.satAxes=new Array(3).fill().map(()=>new d.Vector3),this.satBounds=new Array(3).fill().map(()=>new we),this.alignedSatBounds=new Array(3).fill().map(()=>new we),this.needsUpdate=!1,e&&this.min.copy(e),t&&this.max.copy(t),i&&this.matrix.copy(i)}set(e,t,i){this.min.copy(e),this.max.copy(t),this.matrix.copy(i),this.needsUpdate=!0}copy(e){this.min.copy(e.min),this.max.copy(e.max),this.matrix.copy(e.matrix),this.needsUpdate=!0}}Q.prototype.update=function(){return function(){const e=this.matrix,t=this.min,i=this.max,s=this.points;for(let f=0;f<=1;f++)for(let p=0;p<=1;p++)for(let r=0;r<=1;r++){const l=1*f|2*p|4*r,h=s[l];h.x=f?i.x:t.x,h.y=p?i.y:t.y,h.z=r?i.z:t.z,h.applyMatrix4(e)}const a=this.satBounds,o=this.satAxes,c=s[0];for(let f=0;f<3;f++){const p=o[f],r=a[f],l=1<<f,h=s[l];p.subVectors(c,h),r.setFromPoints(p,s)}const u=this.alignedSatBounds;u[0].setFromPointsField(s,"x"),u[1].setFromPointsField(s,"y"),u[2].setFromPointsField(s,"z"),this.invMatrix.copy(this.matrix).invert(),this.needsUpdate=!1}}();Q.prototype.intersectsBox=function(){const n=new we;return function(t){this.needsUpdate&&this.update();const i=t.min,s=t.max,a=this.satBounds,o=this.satAxes,c=this.alignedSatBounds;if(n.min=i.x,n.max=s.x,c[0].isSeparated(n)||(n.min=i.y,n.max=s.y,c[1].isSeparated(n))||(n.min=i.z,n.max=s.z,c[2].isSeparated(n)))return!1;for(let u=0;u<3;u++){const f=o[u],p=a[u];if(n.setFromBox(f,t),p.isSeparated(n))return!1}return!0}}();Q.prototype.intersectsTriangle=function(){const n=new ce,e=new Array(3),t=new we,i=new we,s=new d.Vector3;return function(o){this.needsUpdate&&this.update(),o.isExtendedTriangle?o.needsUpdate&&o.update():(n.copy(o),n.update(),o=n);const c=this.satBounds,u=this.satAxes;e[0]=o.a,e[1]=o.b,e[2]=o.c;for(let l=0;l<3;l++){const h=c[l],g=u[l];if(t.setFromPoints(g,e),h.isSeparated(t))return!1}const f=o.satBounds,p=o.satAxes,r=this.points;for(let l=0;l<3;l++){const h=f[l],g=p[l];if(t.setFromPoints(g,r),h.isSeparated(t))return!1}for(let l=0;l<3;l++){const h=u[l];for(let g=0;g<4;g++){const _=p[g];if(s.crossVectors(h,_),t.setFromPoints(s,e),i.setFromPoints(s,r),t.isSeparated(i))return!1}}return!0}}();Q.prototype.closestPointToPoint=function(){return function(e,t){return this.needsUpdate&&this.update(),t.copy(e).applyMatrix4(this.invMatrix).clamp(this.min,this.max).applyMatrix4(this.matrix),t}}();Q.prototype.distanceToPoint=function(){const n=new d.Vector3;return function(t){return this.closestPointToPoint(t,n),t.distanceTo(n)}}();Q.prototype.distanceToBox=function(){const n=["x","y","z"],e=new Array(12).fill().map(()=>new d.Line3),t=new Array(12).fill().map(()=>new d.Line3),i=new d.Vector3,s=new d.Vector3;return function(o,c=0,u=null,f=null){if(this.needsUpdate&&this.update(),this.intersectsBox(o))return(u||f)&&(o.getCenter(s),this.closestPointToPoint(s,i),o.closestPointToPoint(i,s),u&&u.copy(i),f&&f.copy(s)),0;const p=c*c,r=o.min,l=o.max,h=this.points;let g=1/0;for(let m=0;m<8;m++){const v=h[m];s.copy(v).clamp(r,l);const y=v.distanceToSquared(s);if(y<g&&(g=y,u&&u.copy(v),f&&f.copy(s),y<p))return Math.sqrt(y)}let _=0;for(let m=0;m<3;m++)for(let v=0;v<=1;v++)for(let y=0;y<=1;y++){const x=(m+1)%3,w=(m+2)%3,b=v<<x|y<<w,A=1<<m|v<<x|y<<w,T=h[b],I=h[A];e[_].set(T,I);const P=n[m],D=n[x],S=n[w],M=t[_],R=M.start,E=M.end;R[P]=r[P],R[D]=v?r[D]:l[D],R[S]=y?r[S]:l[D],E[P]=l[P],E[D]=v?r[D]:l[D],E[S]=y?r[S]:l[D],_++}for(let m=0;m<=1;m++)for(let v=0;v<=1;v++)for(let y=0;y<=1;y++){s.x=m?l.x:r.x,s.y=v?l.y:r.y,s.z=y?l.z:r.z,this.closestPointToPoint(s,i);const x=s.distanceToSquared(i);if(x<g&&(g=x,u&&u.copy(i),f&&f.copy(s),x<p))return Math.sqrt(x)}for(let m=0;m<12;m++){const v=e[m];for(let y=0;y<12;y++){const x=t[y];fs(v,x,i,s);const w=i.distanceToSquared(s);if(w<g&&(g=w,u&&u.copy(i),f&&f.copy(s),w<p))return Math.sqrt(w)}}return Math.sqrt(g)}}();class ds{constructor(e){this._getNewPrimitive=e,this._primitives=[]}getPrimitive(){const e=this._primitives;return e.length===0?this._getNewPrimitive():e.pop()}releasePrimitive(e){this._primitives.push(e)}}class Il extends ds{constructor(){super(()=>new ce)}}const re=new Il;class Rl{constructor(){this.float32Array=null,this.uint16Array=null,this.uint32Array=null;const e=[];let t=null;this.setBuffer=i=>{t&&e.push(t),t=i,this.float32Array=new Float32Array(i),this.uint16Array=new Uint16Array(i),this.uint32Array=new Uint32Array(i)},this.clearBuffer=()=>{t=null,this.float32Array=null,this.uint16Array=null,this.uint32Array=null,e.length!==0&&this.setBuffer(e.pop())}}}const U=new Rl;let Re,it;const Ne=[],Nt=new ds(()=>new d.Box3);function Pl(n,e,t,i,s,a){Re=Nt.getPrimitive(),it=Nt.getPrimitive(),Ne.push(Re,it),U.setBuffer(n._roots[e]);const o=Qi(0,n.geometry,t,i,s,a);U.clearBuffer(),Nt.releasePrimitive(Re),Nt.releasePrimitive(it),Ne.pop(),Ne.pop();const c=Ne.length;return c>0&&(it=Ne[c-1],Re=Ne[c-2]),o}function Qi(n,e,t,i,s=null,a=0,o=0){const{float32Array:c,uint16Array:u,uint32Array:f}=U;let p=n*2;if(K(p,u)){const l=ee(n,f),h=te(p,u);return N(n,c,Re),i(l,h,!1,o,a+n,Re)}else{let P=function(S){const{uint16Array:M,uint32Array:R}=U;let E=S*2;for(;!K(E,M);)S=ie(S),E=S*2;return ee(S,R)},D=function(S){const{uint16Array:M,uint32Array:R}=U;let E=S*2;for(;!K(E,M);)S=se(S,R),E=S*2;return ee(S,R)+te(E,M)};const l=ie(n),h=se(n,f);let g=l,_=h,m,v,y,x;if(s&&(y=Re,x=it,N(g,c,y),N(_,c,x),m=s(y),v=s(x),v<m)){g=h,_=l;const S=m;m=v,v=S,y=x}y||(y=Re,N(g,c,y));const w=K(g*2,u),b=t(y,w,m,o+1,a+g);let A;if(b===Ks){const S=P(g),R=D(g)-S;A=i(S,R,!0,o+1,a+g,y)}else A=b&&Qi(g,e,t,i,s,a,o+1);if(A)return!0;x=it,N(_,c,x);const T=K(_*2,u),I=t(x,T,v,o+1,a+_);let C;if(I===Ks){const S=P(_),R=D(_)-S;C=i(S,R,!0,o+1,a+_,x)}else C=I&&Qi(_,e,t,i,s,a,o+1);return!!C}}const xt=new d.Vector3,Pi=new d.Vector3;function Dl(n,e,t={},i=0,s=1/0){const a=i*i,o=s*s;let c=1/0,u=null;if(n.shapecast({boundsTraverseOrder:p=>(xt.copy(e).clamp(p.min,p.max),xt.distanceToSquared(e)),intersectsBounds:(p,r,l)=>l<c&&l<o,intersectsTriangle:(p,r)=>{p.closestPointToPoint(e,xt);const l=e.distanceToSquared(xt);return l<c&&(Pi.copy(xt),c=l,u=r),l<a}}),c===1/0)return null;const f=Math.sqrt(c);return t.point?t.point.copy(Pi):t.point=Pi.clone(),t.distance=f,t.faceIndex=u,t}const We=new d.Vector3,Ge=new d.Vector3,qe=new d.Vector3,Wt=new d.Vector2,Gt=new d.Vector2,qt=new d.Vector2,ir=new d.Vector3,sr=new d.Vector3,rr=new d.Vector3,jt=new d.Vector3;function Ll(n,e,t,i,s,a,o,c){let u;if(a===d.BackSide?u=n.intersectTriangle(i,t,e,!0,s):u=n.intersectTriangle(e,t,i,a!==d.DoubleSide,s),u===null)return null;const f=n.origin.distanceTo(s);return f<o||f>c?null:{distance:f,point:s.clone()}}function El(n,e,t,i,s,a,o,c,u,f,p){We.fromBufferAttribute(e,a),Ge.fromBufferAttribute(e,o),qe.fromBufferAttribute(e,c);const r=Ll(n,We,Ge,qe,jt,u,f,p);if(r){i&&(Wt.fromBufferAttribute(i,a),Gt.fromBufferAttribute(i,o),qt.fromBufferAttribute(i,c),r.uv=d.Triangle.getInterpolation(jt,We,Ge,qe,Wt,Gt,qt,new d.Vector2)),s&&(Wt.fromBufferAttribute(s,a),Gt.fromBufferAttribute(s,o),qt.fromBufferAttribute(s,c),r.uv1=d.Triangle.getInterpolation(jt,We,Ge,qe,Wt,Gt,qt,new d.Vector2)),t&&(ir.fromBufferAttribute(t,a),sr.fromBufferAttribute(t,o),rr.fromBufferAttribute(t,c),r.normal=d.Triangle.getInterpolation(jt,We,Ge,qe,ir,sr,rr,new d.Vector3),r.normal.dot(n.direction)>0&&r.normal.multiplyScalar(-1));const l={a,b:o,c,normal:new d.Vector3,materialIndex:0};d.Triangle.getNormal(We,Ge,qe,l.normal),r.face=l,r.faceIndex=a}return r}function fi(n,e,t,i,s,a,o){const c=i*3;let u=c+0,f=c+1,p=c+2;const r=n.index;n.index&&(u=r.getX(u),f=r.getX(f),p=r.getX(p));const{position:l,normal:h,uv:g,uv1:_}=n.attributes,m=El(t,l,h,g,_,u,f,p,e,a,o);return m?(m.faceIndex=i,s&&s.push(m),m):null}function G(n,e,t,i){const s=n.a,a=n.b,o=n.c;let c=e,u=e+1,f=e+2;t&&(c=t.getX(c),u=t.getX(u),f=t.getX(f)),s.x=i.getX(c),s.y=i.getY(c),s.z=i.getZ(c),a.x=i.getX(u),a.y=i.getY(u),a.z=i.getZ(u),o.x=i.getX(f),o.y=i.getY(f),o.z=i.getZ(f)}function Fl(n,e,t,i,s,a,o,c){const{geometry:u,_indirectBuffer:f}=n;for(let p=i,r=i+s;p<r;p++)fi(u,e,t,p,a,o,c)}function Bl(n,e,t,i,s,a,o){const{geometry:c,_indirectBuffer:u}=n;let f=1/0,p=null;for(let r=i,l=i+s;r<l;r++){let h;h=fi(c,e,t,r,null,a,o),h&&h.distance<f&&(p=h,f=h.distance)}return p}function kl(n,e,t,i,s,a,o){const{geometry:c}=t,{index:u}=c,f=c.attributes.position;for(let p=n,r=e+n;p<r;p++){let l;if(l=p,G(o,l*3,u,f),o.needsUpdate=!0,i(o,l,s,a))return!0}return!1}function Ol(n,e=null){e&&Array.isArray(e)&&(e=new Set(e));const t=n.geometry,i=t.index?t.index.array:null,s=t.attributes.position;let a,o,c,u,f=0;const p=n._roots;for(let l=0,h=p.length;l<h;l++)a=p[l],o=new Uint32Array(a),c=new Uint16Array(a),u=new Float32Array(a),r(0,f),f+=a.byteLength;function r(l,h,g=!1){const _=l*2;if(c[_+15]===hi){const v=o[l+6],y=c[_+14];let x=1/0,w=1/0,b=1/0,A=-1/0,T=-1/0,I=-1/0;for(let C=3*v,P=3*(v+y);C<P;C++){let D=i[C];const S=s.getX(D),M=s.getY(D),R=s.getZ(D);S<x&&(x=S),S>A&&(A=S),M<w&&(w=M),M>T&&(T=M),R<b&&(b=R),R>I&&(I=R)}return u[l+0]!==x||u[l+1]!==w||u[l+2]!==b||u[l+3]!==A||u[l+4]!==T||u[l+5]!==I?(u[l+0]=x,u[l+1]=w,u[l+2]=b,u[l+3]=A,u[l+4]=T,u[l+5]=I,!0):!1}else{const v=l+8,y=o[l+6],x=v+h,w=y+h;let b=g,A=!1,T=!1;e?b||(A=e.has(x),T=e.has(w),b=!A&&!T):(A=!0,T=!0);const I=b||A,C=b||T;let P=!1;I&&(P=r(v,h,b));let D=!1;C&&(D=r(y,h,b));const S=P||D;if(S)for(let M=0;M<3;M++){const R=v+M,E=y+M,F=u[R],O=u[R+3],H=u[E],W=u[E+3];u[l+M]=F<H?F:H,u[l+M+3]=O>W?O:W}return S}}}function Pe(n,e,t,i,s){let a,o,c,u,f,p;const r=1/t.direction.x,l=1/t.direction.y,h=1/t.direction.z,g=t.origin.x,_=t.origin.y,m=t.origin.z;let v=e[n],y=e[n+3],x=e[n+1],w=e[n+3+1],b=e[n+2],A=e[n+3+2];return r>=0?(a=(v-g)*r,o=(y-g)*r):(a=(y-g)*r,o=(v-g)*r),l>=0?(c=(x-_)*l,u=(w-_)*l):(c=(w-_)*l,u=(x-_)*l),a>u||c>o||((c>a||isNaN(a))&&(a=c),(u<o||isNaN(o))&&(o=u),h>=0?(f=(b-m)*h,p=(A-m)*h):(f=(A-m)*h,p=(b-m)*h),a>p||f>o)?!1:((f>a||a!==a)&&(a=f),(p<o||o!==o)&&(o=p),a<=s&&o>=i)}function zl(n,e,t,i,s,a,o,c){const{geometry:u,_indirectBuffer:f}=n;for(let p=i,r=i+s;p<r;p++){let l=f?f[p]:p;fi(u,e,t,l,a,o,c)}}function Vl(n,e,t,i,s,a,o){const{geometry:c,_indirectBuffer:u}=n;let f=1/0,p=null;for(let r=i,l=i+s;r<l;r++){let h;h=fi(c,e,t,u?u[r]:r,null,a,o),h&&h.distance<f&&(p=h,f=h.distance)}return p}function Ul(n,e,t,i,s,a,o){const{geometry:c}=t,{index:u}=c,f=c.attributes.position;for(let p=n,r=e+n;p<r;p++){let l;if(l=t.resolveTriangleIndex(p),G(o,l*3,u,f),o.needsUpdate=!0,i(o,l,s,a))return!0}return!1}function Hl(n,e,t,i,s,a,o){U.setBuffer(n._roots[e]),Zi(0,n,t,i,s,a,o),U.clearBuffer()}function Zi(n,e,t,i,s,a,o){const{float32Array:c,uint16Array:u,uint32Array:f}=U,p=n*2;if(K(p,u)){const l=ee(n,f),h=te(p,u);Fl(e,t,i,l,h,s,a,o)}else{const l=ie(n);Pe(l,c,i,a,o)&&Zi(l,e,t,i,s,a,o);const h=se(n,f);Pe(h,c,i,a,o)&&Zi(h,e,t,i,s,a,o)}}const Nl=["x","y","z"];function Wl(n,e,t,i,s,a){U.setBuffer(n._roots[e]);const o=Xi(0,n,t,i,s,a);return U.clearBuffer(),o}function Xi(n,e,t,i,s,a){const{float32Array:o,uint16Array:c,uint32Array:u}=U;let f=n*2;if(K(f,c)){const r=ee(n,u),l=te(f,c);return Bl(e,t,i,r,l,s,a)}else{const r=zr(n,u),l=Nl[r],g=i.direction[l]>=0;let _,m;g?(_=ie(n),m=se(n,u)):(_=se(n,u),m=ie(n));const y=Pe(_,o,i,s,a)?Xi(_,e,t,i,s,a):null;if(y){const b=y.point[l];if(g?b<=o[m+r]:b>=o[m+r+3])return y}const w=Pe(m,o,i,s,a)?Xi(m,e,t,i,s,a):null;return y&&w?y.distance<=w.distance?y:w:y||w||null}}const Yt=new d.Box3,je=new ce,Ye=new ce,wt=new d.Matrix4,nr=new Q,Qt=new Q;function Gl(n,e,t,i){U.setBuffer(n._roots[e]);const s=Ki(0,n,t,i);return U.clearBuffer(),s}function Ki(n,e,t,i,s=null){const{float32Array:a,uint16Array:o,uint32Array:c}=U;let u=n*2;if(s===null&&(t.boundingBox||t.computeBoundingBox(),nr.set(t.boundingBox.min,t.boundingBox.max,i),s=nr),K(u,o)){const p=e.geometry,r=p.index,l=p.attributes.position,h=t.index,g=t.attributes.position,_=ee(n,c),m=te(u,o);if(wt.copy(i).invert(),t.boundsTree)return N(n,a,Qt),Qt.matrix.copy(wt),Qt.needsUpdate=!0,t.boundsTree.shapecast({intersectsBounds:y=>Qt.intersectsBox(y),intersectsTriangle:y=>{y.a.applyMatrix4(i),y.b.applyMatrix4(i),y.c.applyMatrix4(i),y.needsUpdate=!0;for(let x=_*3,w=(m+_)*3;x<w;x+=3)if(G(Ye,x,r,l),Ye.needsUpdate=!0,y.intersectsTriangle(Ye))return!0;return!1}});for(let v=_*3,y=(m+_)*3;v<y;v+=3){G(je,v,r,l),je.a.applyMatrix4(wt),je.b.applyMatrix4(wt),je.c.applyMatrix4(wt),je.needsUpdate=!0;for(let x=0,w=h.count;x<w;x+=3)if(G(Ye,x,h,g),Ye.needsUpdate=!0,je.intersectsTriangle(Ye))return!0}}else{const p=n+8,r=c[n+6];return N(p,a,Yt),!!(s.intersectsBox(Yt)&&Ki(p,e,t,i,s)||(N(r,a,Yt),s.intersectsBox(Yt)&&Ki(r,e,t,i,s)))}}const Zt=new d.Matrix4,Di=new Q,bt=new Q,ql=new d.Vector3,jl=new d.Vector3,Yl=new d.Vector3,Ql=new d.Vector3;function Zl(n,e,t,i={},s={},a=0,o=1/0){e.boundingBox||e.computeBoundingBox(),Di.set(e.boundingBox.min,e.boundingBox.max,t),Di.needsUpdate=!0;const c=n.geometry,u=c.attributes.position,f=c.index,p=e.attributes.position,r=e.index,l=re.getPrimitive(),h=re.getPrimitive();let g=ql,_=jl,m=null,v=null;s&&(m=Yl,v=Ql);let y=1/0,x=null,w=null;return Zt.copy(t).invert(),bt.matrix.copy(Zt),n.shapecast({boundsTraverseOrder:b=>Di.distanceToBox(b),intersectsBounds:(b,A,T)=>T<y&&T<o?(A&&(bt.min.copy(b.min),bt.max.copy(b.max),bt.needsUpdate=!0),!0):!1,intersectsRange:(b,A)=>{if(e.boundsTree)return e.boundsTree.shapecast({boundsTraverseOrder:I=>bt.distanceToBox(I),intersectsBounds:(I,C,P)=>P<y&&P<o,intersectsRange:(I,C)=>{for(let P=I,D=I+C;P<D;P++){G(h,3*P,r,p),h.a.applyMatrix4(t),h.b.applyMatrix4(t),h.c.applyMatrix4(t),h.needsUpdate=!0;for(let S=b,M=b+A;S<M;S++){G(l,3*S,f,u),l.needsUpdate=!0;const R=l.distanceToTriangle(h,g,m);if(R<y&&(_.copy(g),v&&v.copy(m),y=R,x=S,w=P),R<a)return!0}}}});{const T=ut(e);for(let I=0,C=T;I<C;I++){G(h,3*I,r,p),h.a.applyMatrix4(t),h.b.applyMatrix4(t),h.c.applyMatrix4(t),h.needsUpdate=!0;for(let P=b,D=b+A;P<D;P++){G(l,3*P,f,u),l.needsUpdate=!0;const S=l.distanceToTriangle(h,g,m);if(S<y&&(_.copy(g),v&&v.copy(m),y=S,x=P,w=I),S<a)return!0}}}}}),re.releasePrimitive(l),re.releasePrimitive(h),y===1/0?null:(i.point?i.point.copy(_):i.point=_.clone(),i.distance=y,i.faceIndex=x,s&&(s.point?s.point.copy(v):s.point=v.clone(),s.point.applyMatrix4(Zt),_.applyMatrix4(Zt),s.distance=_.sub(s.point).length(),s.faceIndex=w),i)}function Xl(n,e=null){e&&Array.isArray(e)&&(e=new Set(e));const t=n.geometry,i=t.index?t.index.array:null,s=t.attributes.position;let a,o,c,u,f=0;const p=n._roots;for(let l=0,h=p.length;l<h;l++)a=p[l],o=new Uint32Array(a),c=new Uint16Array(a),u=new Float32Array(a),r(0,f),f+=a.byteLength;function r(l,h,g=!1){const _=l*2;if(c[_+15]===hi){const v=o[l+6],y=c[_+14];let x=1/0,w=1/0,b=1/0,A=-1/0,T=-1/0,I=-1/0;for(let C=v,P=v+y;C<P;C++){const D=3*n.resolveTriangleIndex(C);for(let S=0;S<3;S++){let M=D+S;M=i?i[M]:M;const R=s.getX(M),E=s.getY(M),F=s.getZ(M);R<x&&(x=R),R>A&&(A=R),E<w&&(w=E),E>T&&(T=E),F<b&&(b=F),F>I&&(I=F)}}return u[l+0]!==x||u[l+1]!==w||u[l+2]!==b||u[l+3]!==A||u[l+4]!==T||u[l+5]!==I?(u[l+0]=x,u[l+1]=w,u[l+2]=b,u[l+3]=A,u[l+4]=T,u[l+5]=I,!0):!1}else{const v=l+8,y=o[l+6],x=v+h,w=y+h;let b=g,A=!1,T=!1;e?b||(A=e.has(x),T=e.has(w),b=!A&&!T):(A=!0,T=!0);const I=b||A,C=b||T;let P=!1;I&&(P=r(v,h,b));let D=!1;C&&(D=r(y,h,b));const S=P||D;if(S)for(let M=0;M<3;M++){const R=v+M,E=y+M,F=u[R],O=u[R+3],H=u[E],W=u[E+3];u[l+M]=F<H?F:H,u[l+M+3]=O>W?O:W}return S}}}function Kl(n,e,t,i,s,a,o){U.setBuffer(n._roots[e]),Ji(0,n,t,i,s,a,o),U.clearBuffer()}function Ji(n,e,t,i,s,a,o){const{float32Array:c,uint16Array:u,uint32Array:f}=U,p=n*2;if(K(p,u)){const l=ee(n,f),h=te(p,u);zl(e,t,i,l,h,s,a,o)}else{const l=ie(n);Pe(l,c,i,a,o)&&Ji(l,e,t,i,s,a,o);const h=se(n,f);Pe(h,c,i,a,o)&&Ji(h,e,t,i,s,a,o)}}const Jl=["x","y","z"];function $l(n,e,t,i,s,a){U.setBuffer(n._roots[e]);const o=$i(0,n,t,i,s,a);return U.clearBuffer(),o}function $i(n,e,t,i,s,a){const{float32Array:o,uint16Array:c,uint32Array:u}=U;let f=n*2;if(K(f,c)){const r=ee(n,u),l=te(f,c);return Vl(e,t,i,r,l,s,a)}else{const r=zr(n,u),l=Jl[r],g=i.direction[l]>=0;let _,m;g?(_=ie(n),m=se(n,u)):(_=se(n,u),m=ie(n));const y=Pe(_,o,i,s,a)?$i(_,e,t,i,s,a):null;if(y){const b=y.point[l];if(g?b<=o[m+r]:b>=o[m+r+3])return y}const w=Pe(m,o,i,s,a)?$i(m,e,t,i,s,a):null;return y&&w?y.distance<=w.distance?y:w:y||w||null}}const Xt=new d.Box3,Qe=new ce,Ze=new ce,At=new d.Matrix4,or=new Q,Kt=new Q;function ec(n,e,t,i){U.setBuffer(n._roots[e]);const s=es(0,n,t,i);return U.clearBuffer(),s}function es(n,e,t,i,s=null){const{float32Array:a,uint16Array:o,uint32Array:c}=U;let u=n*2;if(s===null&&(t.boundingBox||t.computeBoundingBox(),or.set(t.boundingBox.min,t.boundingBox.max,i),s=or),K(u,o)){const p=e.geometry,r=p.index,l=p.attributes.position,h=t.index,g=t.attributes.position,_=ee(n,c),m=te(u,o);if(At.copy(i).invert(),t.boundsTree)return N(n,a,Kt),Kt.matrix.copy(At),Kt.needsUpdate=!0,t.boundsTree.shapecast({intersectsBounds:y=>Kt.intersectsBox(y),intersectsTriangle:y=>{y.a.applyMatrix4(i),y.b.applyMatrix4(i),y.c.applyMatrix4(i),y.needsUpdate=!0;for(let x=_,w=m+_;x<w;x++)if(G(Ze,3*e.resolveTriangleIndex(x),r,l),Ze.needsUpdate=!0,y.intersectsTriangle(Ze))return!0;return!1}});for(let v=_,y=m+_;v<y;v++){const x=e.resolveTriangleIndex(v);G(Qe,3*x,r,l),Qe.a.applyMatrix4(At),Qe.b.applyMatrix4(At),Qe.c.applyMatrix4(At),Qe.needsUpdate=!0;for(let w=0,b=h.count;w<b;w+=3)if(G(Ze,w,h,g),Ze.needsUpdate=!0,Qe.intersectsTriangle(Ze))return!0}}else{const p=n+8,r=c[n+6];return N(p,a,Xt),!!(s.intersectsBox(Xt)&&es(p,e,t,i,s)||(N(r,a,Xt),s.intersectsBox(Xt)&&es(r,e,t,i,s)))}}const Jt=new d.Matrix4,Li=new Q,Tt=new Q,tc=new d.Vector3,ic=new d.Vector3,sc=new d.Vector3,rc=new d.Vector3;function nc(n,e,t,i={},s={},a=0,o=1/0){e.boundingBox||e.computeBoundingBox(),Li.set(e.boundingBox.min,e.boundingBox.max,t),Li.needsUpdate=!0;const c=n.geometry,u=c.attributes.position,f=c.index,p=e.attributes.position,r=e.index,l=re.getPrimitive(),h=re.getPrimitive();let g=tc,_=ic,m=null,v=null;s&&(m=sc,v=rc);let y=1/0,x=null,w=null;return Jt.copy(t).invert(),Tt.matrix.copy(Jt),n.shapecast({boundsTraverseOrder:b=>Li.distanceToBox(b),intersectsBounds:(b,A,T)=>T<y&&T<o?(A&&(Tt.min.copy(b.min),Tt.max.copy(b.max),Tt.needsUpdate=!0),!0):!1,intersectsRange:(b,A)=>{if(e.boundsTree){const T=e.boundsTree;return T.shapecast({boundsTraverseOrder:I=>Tt.distanceToBox(I),intersectsBounds:(I,C,P)=>P<y&&P<o,intersectsRange:(I,C)=>{for(let P=I,D=I+C;P<D;P++){const S=T.resolveTriangleIndex(P);G(h,3*S,r,p),h.a.applyMatrix4(t),h.b.applyMatrix4(t),h.c.applyMatrix4(t),h.needsUpdate=!0;for(let M=b,R=b+A;M<R;M++){const E=n.resolveTriangleIndex(M);G(l,3*E,f,u),l.needsUpdate=!0;const F=l.distanceToTriangle(h,g,m);if(F<y&&(_.copy(g),v&&v.copy(m),y=F,x=M,w=P),F<a)return!0}}}})}else{const T=ut(e);for(let I=0,C=T;I<C;I++){G(h,3*I,r,p),h.a.applyMatrix4(t),h.b.applyMatrix4(t),h.c.applyMatrix4(t),h.needsUpdate=!0;for(let P=b,D=b+A;P<D;P++){const S=n.resolveTriangleIndex(P);G(l,3*S,f,u),l.needsUpdate=!0;const M=l.distanceToTriangle(h,g,m);if(M<y&&(_.copy(g),v&&v.copy(m),y=M,x=P,w=I),M<a)return!0}}}}}),re.releasePrimitive(l),re.releasePrimitive(h),y===1/0?null:(i.point?i.point.copy(_):i.point=_.clone(),i.distance=y,i.faceIndex=x,s&&(s.point?s.point.copy(v):s.point=v.clone(),s.point.applyMatrix4(Jt),_.applyMatrix4(Jt),s.distance=_.sub(s.point).length(),s.faceIndex=w),i)}function oc(){return typeof SharedArrayBuffer<"u"}const Dt=new U.constructor,oi=new U.constructor,Me=new ds(()=>new d.Box3),Xe=new d.Box3,Ke=new d.Box3,Ei=new d.Box3,Fi=new d.Box3;let Bi=!1;function ac(n,e,t,i){if(Bi)throw new Error("MeshBVH: Recursive calls to bvhcast not supported.");Bi=!0;const s=n._roots,a=e._roots;let o,c=0,u=0;const f=new d.Matrix4().copy(t).invert();for(let p=0,r=s.length;p<r;p++){Dt.setBuffer(s[p]),u=0;const l=Me.getPrimitive();N(0,Dt.float32Array,l),l.applyMatrix4(f);for(let h=0,g=a.length;h<g&&(oi.setBuffer(a[p]),o=ae(0,0,t,f,i,c,u,0,0,l),oi.clearBuffer(),u+=a[h].length,!o);h++);if(Me.releasePrimitive(l),Dt.clearBuffer(),c+=s[p].length,o)break}return Bi=!1,o}function ae(n,e,t,i,s,a=0,o=0,c=0,u=0,f=null,p=!1){let r,l;p?(r=oi,l=Dt):(r=Dt,l=oi);const h=r.float32Array,g=r.uint32Array,_=r.uint16Array,m=l.float32Array,v=l.uint32Array,y=l.uint16Array,x=n*2,w=e*2,b=K(x,_),A=K(w,y);let T=!1;if(A&&b)p?T=s(ee(e,v),te(e*2,y),ee(n,g),te(n*2,_),u,o+e,c,a+n):T=s(ee(n,g),te(n*2,_),ee(e,v),te(e*2,y),c,a+n,u,o+e);else if(A){const I=Me.getPrimitive();N(e,m,I),I.applyMatrix4(t);const C=ie(n),P=se(n,g);N(C,h,Xe),N(P,h,Ke);const D=I.intersectsBox(Xe),S=I.intersectsBox(Ke);T=D&&ae(e,C,i,t,s,o,a,u,c+1,I,!p)||S&&ae(e,P,i,t,s,o,a,u,c+1,I,!p),Me.releasePrimitive(I)}else{const I=ie(e),C=se(e,v);N(I,m,Ei),N(C,m,Fi);const P=f.intersectsBox(Ei),D=f.intersectsBox(Fi);if(P&&D)T=ae(n,I,t,i,s,a,o,c,u+1,f,p)||ae(n,C,t,i,s,a,o,c,u+1,f,p);else if(P)if(b)T=ae(n,I,t,i,s,a,o,c,u+1,f,p);else{const S=Me.getPrimitive();S.copy(Ei).applyMatrix4(t);const M=ie(n),R=se(n,g);N(M,h,Xe),N(R,h,Ke);const E=S.intersectsBox(Xe),F=S.intersectsBox(Ke);T=E&&ae(I,M,i,t,s,o,a,u,c+1,S,!p)||F&&ae(I,R,i,t,s,o,a,u,c+1,S,!p),Me.releasePrimitive(S)}else if(D)if(b)T=ae(n,C,t,i,s,a,o,c,u+1,f,p);else{const S=Me.getPrimitive();S.copy(Fi).applyMatrix4(t);const M=ie(n),R=se(n,g);N(M,h,Xe),N(R,h,Ke);const E=S.intersectsBox(Xe),F=S.intersectsBox(Ke);T=E&&ae(C,M,i,t,s,o,a,u,c+1,S,!p)||F&&ae(C,R,i,t,s,o,a,u,c+1,S,!p),Me.releasePrimitive(S)}}return T}const $t=new Q,ar=new d.Box3,lc={strategy:Br,maxDepth:40,maxLeafTris:10,useSharedArrayBuffer:!1,setBoundingBox:!0,onProgress:null,indirect:!1,verbose:!0};class ps{static serialize(e,t={}){t={cloneBuffers:!0,...t};const i=e.geometry,s=e._roots,a=e._indirectBuffer,o=i.getIndex();let c;return t.cloneBuffers?c={roots:s.map(u=>u.slice()),index:o?o.array.slice():null,indirectBuffer:a?a.slice():null}:c={roots:s,index:o?o.array:null,indirectBuffer:a},c}static deserialize(e,t,i={}){i={setIndex:!0,indirect:!!e.indirectBuffer,...i};const{index:s,roots:a,indirectBuffer:o}=e,c=new ps(t,{...i,[Mi]:!0});if(c._roots=a,c._indirectBuffer=o||null,i.setIndex){const u=t.getIndex();if(u===null){const f=new d.BufferAttribute(e.index,1,!1);t.setIndex(f)}else u.array!==s&&(u.array.set(s),u.needsUpdate=!0)}return c}get indirect(){return!!this._indirectBuffer}constructor(e,t={}){if(e.isBufferGeometry){if(e.index&&e.index.isInterleavedBufferAttribute)throw new Error("MeshBVH: InterleavedBufferAttribute is not supported for the index attribute.")}else throw new Error("MeshBVH: Only BufferGeometries are supported.");if(t=Object.assign({...lc,[Mi]:!1},t),t.useSharedArrayBuffer&&!oc())throw new Error("MeshBVH: SharedArrayBuffer is not available.");this.geometry=e,this._roots=null,this._indirectBuffer=null,t[Mi]||(Tl(this,t),!e.boundingBox&&t.setBoundingBox&&(e.boundingBox=this.getBoundingBox(new d.Box3))),this.resolveTriangleIndex=t.indirect?i=>this._indirectBuffer[i]:i=>i}refit(e=null){return(this.indirect?Xl:Ol)(this,e)}traverse(e,t=0){const i=this._roots[t],s=new Uint32Array(i),a=new Uint16Array(i);o(0);function o(c,u=0){const f=c*2,p=a[f+15]===hi;if(p){const r=s[c+6],l=a[f+14];e(u,p,new Float32Array(i,c*4,6),r,l)}else{const r=c+Pt/4,l=s[c+6],h=s[c+7];e(u,p,new Float32Array(i,c*4,6),h)||(o(r,u+1),o(l,u+1))}}}raycast(e,t=d.FrontSide,i=0,s=1/0){const a=this._roots,o=this.geometry,c=[],u=t.isMaterial,f=Array.isArray(t),p=o.groups,r=u?t.side:t,l=this.indirect?Kl:Hl;for(let h=0,g=a.length;h<g;h++){const _=f?t[p[h].materialIndex].side:r,m=c.length;if(l(this,h,_,e,c,i,s),f){const v=p[h].materialIndex;for(let y=m,x=c.length;y<x;y++)c[y].face.materialIndex=v}}return c}raycastFirst(e,t=d.FrontSide,i=0,s=1/0){const a=this._roots,o=this.geometry,c=t.isMaterial,u=Array.isArray(t);let f=null;const p=o.groups,r=c?t.side:t,l=this.indirect?$l:Wl;for(let h=0,g=a.length;h<g;h++){const _=u?t[p[h].materialIndex].side:r,m=l(this,h,_,e,i,s);m!=null&&(f==null||m.distance<f.distance)&&(f=m,u&&(m.face.materialIndex=p[h].materialIndex))}return f}intersectsGeometry(e,t){let i=!1;const s=this._roots,a=this.indirect?ec:Gl;for(let o=0,c=s.length;o<c&&(i=a(this,o,e,t),!i);o++);return i}shapecast(e){const t=re.getPrimitive(),i=this.indirect?Ul:kl;let{boundsTraverseOrder:s,intersectsBounds:a,intersectsRange:o,intersectsTriangle:c}=e;if(o&&c){const r=o;o=(l,h,g,_,m)=>r(l,h,g,_,m)?!0:i(l,h,this,c,g,_,t)}else o||(c?o=(r,l,h,g)=>i(r,l,this,c,h,g,t):o=(r,l,h)=>h);let u=!1,f=0;const p=this._roots;for(let r=0,l=p.length;r<l;r++){const h=p[r];if(u=Pl(this,r,a,o,s,f),u)break;f+=h.byteLength}return re.releasePrimitive(t),u}bvhcast(e,t,i){let{intersectsRanges:s,intersectsTriangles:a}=i;const o=re.getPrimitive(),c=this.geometry.index,u=this.geometry.attributes.position,f=this.indirect?g=>{const _=this.resolveTriangleIndex(g);G(o,_*3,c,u)}:g=>{G(o,g*3,c,u)},p=re.getPrimitive(),r=e.geometry.index,l=e.geometry.attributes.position,h=e.indirect?g=>{const _=e.resolveTriangleIndex(g);G(p,_*3,r,l)}:g=>{G(p,g*3,r,l)};if(a){const g=(_,m,v,y,x,w,b,A)=>{for(let T=v,I=v+y;T<I;T++){h(T),p.a.applyMatrix4(t),p.b.applyMatrix4(t),p.c.applyMatrix4(t),p.needsUpdate=!0;for(let C=_,P=_+m;C<P;C++)if(f(C),o.needsUpdate=!0,a(o,p,C,T,x,w,b,A))return!0}return!1};if(s){const _=s;s=function(m,v,y,x,w,b,A,T){return _(m,v,y,x,w,b,A,T)?!0:g(m,v,y,x,w,b,A,T)}}else s=g}return ac(this,e,t,s)}intersectsBox(e,t){return $t.set(e.min,e.max,t),$t.needsUpdate=!0,this.shapecast({intersectsBounds:i=>$t.intersectsBox(i),intersectsTriangle:i=>$t.intersectsTriangle(i)})}intersectsSphere(e){return this.shapecast({intersectsBounds:t=>e.intersectsBox(t),intersectsTriangle:t=>t.intersectsSphere(e)})}closestPointToGeometry(e,t,i={},s={},a=0,o=1/0){return(this.indirect?nc:Zl)(this,e,t,i,s,a,o)}closestPointToPoint(e,t={},i=0,s=1/0){return Dl(this,e,t,i,s)}getBoundingBox(e){return e.makeEmpty(),this._roots.forEach(i=>{N(0,new Float32Array(i),ar),e.union(ar)}),e}}class cc{constructor(e){this.name="WorkerBase",this.running=!1,this.worker=e,this.worker.onerror=t=>{throw t.message?new Error(`${this.name}: Could not create Web Worker with error "${t.message}"`):new Error(`${this.name}: Could not create Web Worker.`)}}runTask(){}generate(...e){if(this.running)throw new Error("GenerateMeshBVHWorker: Already running job.");if(this.worker===null)throw new Error("GenerateMeshBVHWorker: Worker has been disposed.");this.running=!0;const t=this.runTask(this.worker,...e);return t.finally(()=>{this.running=!1}),t}dispose(){this.worker.terminate(),this.worker=null}}class uc extends cc{constructor(e){const t=new Worker(e||new URL("data:text/javascript;base64,aW1wb3J0IHsKCUJ1ZmZlckdlb21ldHJ5LAoJQnVmZmVyQXR0cmlidXRlLAp9IGZyb20gJ3RocmVlJzsKaW1wb3J0IHsgTWVzaEJWSCB9IGZyb20gJy4uL2NvcmUvTWVzaEJWSC5qcyc7Cgpvbm1lc3NhZ2UgPSAoIHsgZGF0YSB9ICkgPT4gewoKCWxldCBwcmV2VGltZSA9IHBlcmZvcm1hbmNlLm5vdygpOwoJZnVuY3Rpb24gb25Qcm9ncmVzc0NhbGxiYWNrKCBwcm9ncmVzcyApIHsKCgkJLy8gYWNjb3VudCBmb3IgZXJyb3IKCQlwcm9ncmVzcyA9IE1hdGgubWluKCBwcm9ncmVzcywgMSApOwoKCQljb25zdCBjdXJyVGltZSA9IHBlcmZvcm1hbmNlLm5vdygpOwoJCWlmICggY3VyclRpbWUgLSBwcmV2VGltZSA+PSAxMCAmJiBwcm9ncmVzcyAhPT0gMS4wICkgewoKCQkJcG9zdE1lc3NhZ2UoIHsKCgkJCQllcnJvcjogbnVsbCwKCQkJCXNlcmlhbGl6ZWQ6IG51bGwsCgkJCQlwb3NpdGlvbjogbnVsbCwKCQkJCXByb2dyZXNzLAoKCQkJfSApOwoJCQlwcmV2VGltZSA9IGN1cnJUaW1lOwoKCQl9CgoJfQoKCWNvbnN0IHsgaW5kZXgsIHBvc2l0aW9uLCBvcHRpb25zIH0gPSBkYXRhOwoJdHJ5IHsKCgkJY29uc3QgZ2VvbWV0cnkgPSBuZXcgQnVmZmVyR2VvbWV0cnkoKTsKCQlnZW9tZXRyeS5zZXRBdHRyaWJ1dGUoICdwb3NpdGlvbicsIG5ldyBCdWZmZXJBdHRyaWJ1dGUoIHBvc2l0aW9uLCAzLCBmYWxzZSApICk7CgkJaWYgKCBpbmRleCApIHsKCgkJCWdlb21ldHJ5LnNldEluZGV4KCBuZXcgQnVmZmVyQXR0cmlidXRlKCBpbmRleCwgMSwgZmFsc2UgKSApOwoKCQl9CgoJCWlmICggb3B0aW9ucy5pbmNsdWRlZFByb2dyZXNzQ2FsbGJhY2sgKSB7CgoJCQlvcHRpb25zLm9uUHJvZ3Jlc3MgPSBvblByb2dyZXNzQ2FsbGJhY2s7CgoJCX0KCgkJaWYgKCBvcHRpb25zLmdyb3VwcyApIHsKCgkJCWNvbnN0IGdyb3VwcyA9IG9wdGlvbnMuZ3JvdXBzOwoJCQlmb3IgKCBjb25zdCBpIGluIGdyb3VwcyApIHsKCgkJCQljb25zdCBncm91cCA9IGdyb3Vwc1sgaSBdOwoJCQkJZ2VvbWV0cnkuYWRkR3JvdXAoIGdyb3VwLnN0YXJ0LCBncm91cC5jb3VudCwgZ3JvdXAubWF0ZXJpYWxJbmRleCApOwoKCQkJfQoKCQl9CgoJCWNvbnN0IGJ2aCA9IG5ldyBNZXNoQlZIKCBnZW9tZXRyeSwgb3B0aW9ucyApOwoJCWNvbnN0IHNlcmlhbGl6ZWQgPSBNZXNoQlZILnNlcmlhbGl6ZSggYnZoLCB7IGNvcHlJbmRleEJ1ZmZlcjogZmFsc2UgfSApOwoJCWxldCB0b1RyYW5zZmVyID0gWyBwb3NpdGlvbi5idWZmZXIsIC4uLnNlcmlhbGl6ZWQucm9vdHMgXTsKCQlpZiAoIHNlcmlhbGl6ZWQuaW5kZXggKSB7CgoJCQl0b1RyYW5zZmVyLnB1c2goIHNlcmlhbGl6ZWQuaW5kZXguYnVmZmVyICk7CgoJCX0KCgkJdG9UcmFuc2ZlciA9IHRvVHJhbnNmZXIuZmlsdGVyKCB2ID0+ICggdHlwZW9mIFNoYXJlZEFycmF5QnVmZmVyID09PSAndW5kZWZpbmVkJyApIHx8ICEgKCB2IGluc3RhbmNlb2YgU2hhcmVkQXJyYXlCdWZmZXIgKSApOwoKCQlpZiAoIGJ2aC5faW5kaXJlY3RCdWZmZXIgKSB7CgoJCQl0b1RyYW5zZmVyLnB1c2goIHNlcmlhbGl6ZWQuaW5kaXJlY3RCdWZmZXIuYnVmZmVyICk7CgoJCX0KCgkJcG9zdE1lc3NhZ2UoIHsKCgkJCWVycm9yOiBudWxsLAoJCQlzZXJpYWxpemVkLAoJCQlwb3NpdGlvbiwKCQkJcHJvZ3Jlc3M6IDEsCgoJCX0sIHRvVHJhbnNmZXIgKTsKCgl9IGNhdGNoICggZXJyb3IgKSB7CgoJCXBvc3RNZXNzYWdlKCB7CgoJCQllcnJvciwKCQkJc2VyaWFsaXplZDogbnVsbCwKCQkJcG9zaXRpb246IG51bGwsCgkJCXByb2dyZXNzOiAxLAoKCQl9ICk7CgoJfQoKfTsK",typeof document>"u"?require("url").pathToFileURL(__filename).href:at&&at.src||new URL("shop-components.cjs",document.baseURI).href),{type:"module"});super(t),this.name="GenerateMeshBVHWorker"}runTask(e,t,i={}){return new Promise((s,a)=>{if(t.getAttribute("position").isInterleavedBufferAttribute||t.index&&t.index.isInterleavedBufferAttribute)throw new Error("GenerateMeshBVHWorker: InterleavedBufferAttribute are not supported for the geometry attributes.");e.onerror=f=>{a(new Error(`GenerateMeshBVHWorker: ${f.message}`))},e.onmessage=f=>{const{data:p}=f;if(p.error)a(new Error(p.error)),e.onmessage=null;else if(p.serialized){const{serialized:r,position:l}=p,h=ps.deserialize(r,t,{setIndex:!1}),g=Object.assign({setBoundingBox:!0},i);if(t.attributes.position.array=l,r.index)if(t.index)t.index.array=r.index;else{const _=new d.BufferAttribute(r.index,1,!1);t.setIndex(_)}g.setBoundingBox&&(t.boundingBox=h.getBoundingBox(new d.Box3)),i.onProgress&&i.onProgress(p.progress),s(h),e.onmessage=null}else i.onProgress&&i.onProgress(p.progress)};const o=t.index?t.index.array:null,c=t.attributes.position.array,u=[c];o&&u.push(o),e.postMessage({index:o,position:c,options:{...i,onProgress:null,includedProgressCallback:!!i.onProgress,groups:[...t.groups]}},u.map(f=>f.buffer).filter(f=>typeof SharedArrayBuffer>"u"||!(f instanceof SharedArrayBuffer)))})}}class hc{constructor(e,t){this.lock=!1,this.lockX=!1,this.lockY=!1,this.invRotMat=new d.Matrix4,this.mouse=new d.Vector3,this.rotateStart=new d.Vector2,this.rotateEnd=new d.Vector2,this.rotateDelta=new d.Vector2,this.selectedAxis=null,this.isDragging=!1,this.context=null,this.orbitState=!0,this._animator=0,this._emitter=new ct,this.addListener=this._emitter.addListener.bind(this._emitter),this.removeAllListeners=this._emitter.removeAllListeners.bind(this._emitter),this._text=document.createElement("div"),this._textTimer=0,this._update=()=>{this.lock||(this._textTimer&&(window.clearTimeout(this._textTimer),this._textTimer=0),this._textTimer=window.setTimeout(()=>{this._text.style.opacity="0"},800),this.camera.updateMatrix(),this.invRotMat.extractRotation(this.camera.matrix).invert(),this.axes.forEach(s=>{this.setAxisPosition(s)}),this.axes.sort((s,a)=>s.position.z>a.position.z?1:-1),this.drawLayers(!0),this._text.style.opacity="1",this._text.innerText=this.camera.position.distanceTo(this.orbit.target).toFixed(2)+" m")},this.updateMouseFromEvent=s=>{this.rect=this.domElement.getBoundingClientRect();const a=this.domElement.width/this.domElement.clientWidth,o=this.domElement.height/this.domElement.clientHeight,{left:c,top:u}=this.rect;this.mouse.set((s.clientX-c)*a,(s.clientY-u)*o,0)},this.updateSelectedAxisUnderMouse=()=>{this.selectedAxis=null,this.axes.forEach(s=>{this.mouse.distanceTo(s.position)<s.size&&(this.selectedAxis=s)})},this.onPointerDown=s=>{this.rotateStart.set(s.clientX,s.clientY),this.updateMouseFromEvent(s),this.updateSelectedAxisUnderMouse(),this.orbitState=this.orbit.enabled,this.orbit.enabled=!1,window.addEventListener("pointermove",this.onDrag,!1),window.addEventListener("pointerup",this.onPointerUp,!1)},this.onPointerUp=()=>{this.domElement.style.backgroundColor="#FFF0",setTimeout(()=>this.isDragging=!1,0),this.domElement.classList.remove("dragging"),this.orbit.enabled=this.orbitState,window.removeEventListener("pointermove",this.onDrag,!1),window.removeEventListener("pointerup",this.onPointerUp,!1)},this.onPointerEnter=()=>{this.domElement.style.backgroundColor="#FFF3",this.rect=this.domElement.getBoundingClientRect()},this.onPointerMove=s=>{if(this.lock||this.isDragging)return;const a=this.selectedAxis;s&&(this.updateMouseFromEvent(s),this.updateSelectedAxisUnderMouse()),a!==this.selectedAxis&&this.drawLayers()},this.onDrag=s=>{this.lock||(this.isDragging||this.domElement.classList.add("dragging"),this.isDragging=!0,this.selectedAxis=null,this.rotateEnd.set(s.clientX,s.clientY),this.rotateDelta.subVectors(this.rotateEnd,this.rotateStart).multiplyScalar(.5),this.rotateStart.copy(this.rotateEnd),this.orbit.update())},this.onMouseClick=s=>{if(this.lock||(this.updateMouseFromEvent(s),this.updateSelectedAxisUnderMouse(),this.isDragging||!this.selectedAxis))return;this._animator&&cancelAnimationFrame(this._animator);const a=this.selectedAxis.direction.clone();this.camera.lookAt(0,0,0);const o=this.camera.position.distanceTo(this.orbit.target);a.multiplyScalar(o),this.selectedAxis.axis==="z"?a.setZ(this.orbit.target.z+o):this.selectedAxis.axis==="-z"?a.setZ(this.orbit.target.z-o):a.setZ(this.orbit.target.z);const c=500,u=performance.now(),f=1,p=this.selectedAxis.axis,r=()=>{const h=performance.now()-u,g=Math.min(h/c,f);if(this.camera.position.lerp(a,g),this.orbit.update(),g!==f){this._animator=window.requestAnimationFrame(r);return}else this._animator=0,this.onPointerMove(void 0),this._emitter.emit("axis-select-end",p);this.onPointerMove(void 0)};this._emitter.emit("axis-select-start",p),r()},this.drawCircle=(s,a=10,o="#FF0000")=>{this.context&&(this.context.beginPath(),this.context.rect(s.x-a,s.y-a,a*2,a*2),this.context.fillStyle=o,this.context.fill(),this.context.closePath())},this.drawLine=(s,a,o=1,c="#FF0000")=>{this.context&&(this.context.beginPath(),this.context.moveTo(s.x,s.y),this.context.lineTo(a.x,a.y),this.context.lineWidth=o,this.context.strokeStyle=c,this.context.stroke(),this.context.closePath())},this.drawLayers=(s=!1)=>{this.context&&(s&&this.context.clearRect(0,0,this.domElement.width,this.domElement.height),this.axes.forEach(a=>{const o=this.selectedAxis===a,c=a.position.z>=-.01?a.color[0]:a.color[1];if(a.line&&this.drawLine(this.center,a.position,a.line,c),this.drawCircle(a.position,a.size,o?"#0066ff":c),a.label){const u=a.axis==="-x"?this.options.fontSize-3:this.options.fontSize;this.context.font=[this.options.fontWeight,u+"px",this.options.fontFamily].join(" "),this.context.fillStyle=this.options.fontColor,this.context.textBaseline="middle",this.context.textAlign="center",this.context.fillText(a.label,a.position.x,a.position.y)}}))},this.setAxisPosition=s=>{const a=s.direction.clone().applyMatrix4(this.invRotMat),o=s.size;s.position.set(a.x*(this.center.x-o/2-this.options.padding)+this.center.x,this.center.y-a.y*(this.center.y-o/2-this.options.padding),a.z)};const i={offset:new d.Vector2,size:90,padding:8,bubbleSizePrimary:8,bubbleSizeSecondary:6,lineWidth:2,fontSize:11,fontFamily:"arial",fontWeight:"normal",fontColor:"#fff",className:"orbit-controls-gizmo",colors:{x:["#f35f5f","#902525"],y:["#78da2f","#71ae45"],z:["#1d92fa","#d0d1d1"]}};this.options={...i,...t},this.orbit=e,this.camera=e.object,this.center=new d.Vector3(this.options.size/2,this.options.size/2,0),this.axes=this.createAxes(),this.domElement=this.createCanvas(this.options),this.orbit.addEventListener("change",this._update),this._text.style.cssText=`
3732
3732
  transition: all 0.8s ease-in-out;
3733
3733
  color: rgb(68, 78, 105);
3734
3734
  position: absolute;
@@ -3758,7 +3758,7 @@ ${t.name}`)}break}}}}else a.texture_lod=0}};J=new WeakMap,ve=new WeakMap,ai=new
3758
3758
  `+m.fragmentShader.slice(v-1,-1)+`
3759
3759
  vec3 texelOld = texture2D(previousShadowMap, vUv).rgb;
3760
3760
  gl_FragColor.rgb = mix(texelOld, gl_FragColor.rgb, 1.0/ averagingWindow);
3761
- }`,m.uniforms.previousShadowMap=this.previousShadowMap,m.uniforms.averagingWindow=this.averagingWindow}}renderOnRenderTargets(e){this.prepare(),this.averagingWindow.value=this.params.frames;const t=this.buffer1Active?this.progressiveLightMap1:this.progressiveLightMap2,i=this.buffer1Active?this.progressiveLightMap2:this.progressiveLightMap1;this.renderer.setRenderTarget(t),this.previousShadowMap.value=i.texture,this.buffer1Active=!this.buffer1Active,this.renderer.render(this.scene,e),this.finish(),this.renderer.setRenderTarget(null)}showDebugHelpers(e){if(!this.debugHelpersGroup.children.length){const t=new d.Mesh(new d.PlaneGeometry(2,2),new d.MeshBasicMaterial({map:this.progressiveLightMap1.texture,side:d.DoubleSide}));this.isZUp?t.position.z=this.params.size/2:t.position.y=this.params.size/2;for(const a of this.dirLights){const o=new d.DirectionalLightHelper(a);this.dirLightsHelpers.push(o)}const i=this.isZUp?new d.Vector3(0,0,1):new d.Vector3(0,1,0),s=new d.PlaneHelper(new d.Plane(i,.001),this.params.size,16776960);this.debugHelpersGroup.add(t,s,...this.dirLightsHelpers)}e?(this.progShadowGrp.add(this.debugHelpersGroup),this.dirLightsHelpers.forEach(t=>{t.update()})):this.progShadowGrp.remove(this.debugHelpersGroup)}randomiseLights(){const e=this.lightOrigin.position.length();for(let t=0;t<this.dirLights.length;t++){if(Math.random()>this.params.ambientWeight)this.dirLights[t].position.set(this.lightOrigin.position.x+d.MathUtils.randFloatSpread(this.params.lightRadius),this.lightOrigin.position.y+d.MathUtils.randFloatSpread(this.params.lightRadius),this.lightOrigin.position.z+d.MathUtils.randFloatSpread(this.params.lightRadius));else{const i=Math.acos(2*Math.random()-1)-1.570795,s=2*3.14159*Math.random();this.isZUp?this.dirLights[t].position.set(Math.cos(i)*Math.cos(s)*e,Math.cos(i)*Math.sin(s)*e,Math.abs(Math.sin(i)*e)):this.dirLights[t].position.set(Math.cos(i)*Math.cos(s)*e,Math.abs(Math.cos(i)*Math.sin(s)*e),Math.sin(i)*e)}this.params.debugHelpers&&this.dirLightsHelpers[t].update()}}async recalculate(){this.params.enabled&&(this.clear(),this.framesDone=0,this.fixedCamera=null,this.isRendering=!1)}prepare(){this.lights.forEach(t=>{t.object.intensity=0}),this.meshes.forEach(t=>{t.object.material=this.discardMaterial}),this.autoHiddenObjects.length=0;const e=t=>this.objectsToShowAncestors.has(t);this.scene.traverse(t=>{t!==this.scene&&(this.isExcludedObject(t)||e(t)||t.isLight||t.isCamera||t.visible&&(this.autoHiddenObjects.push({object:t,visible:t.visible}),t.visible=!1))}),this.lightGroup.visible=!0,this.shadowCatcherMesh.material=this.targetMat,this.params.debugHelpers&&this.showDebugHelpers(!1)}finish(){this.lights.forEach(e=>{e.object.intensity=e.intensity}),this.meshes.forEach(e=>{e.object.material=e.material}),this.autoHiddenObjects.forEach(e=>{e.object.visible=e.visible}),this.autoHiddenObjects.length=0,this.lightGroup.visible=!1,this.shadowCatcherMesh.material=this.shadowCatcherMaterial,this.params.debugHelpers&&this.showDebugHelpers(!0)}clear(){this.renderer.getClearColor(this.clearColor),this.clearAlpha=this.renderer.getClearAlpha(),this.renderer.setClearColor("black",1),this.renderer.setRenderTarget(this.progressiveLightMap1),this.renderer.clear(),this.renderer.setRenderTarget(this.progressiveLightMap2),this.renderer.clear(),this.renderer.setRenderTarget(null),this.renderer.setClearColor(this.clearColor,this.clearAlpha),this.shadowCatcherMesh.material.alphaTest=0,this.updateShadowObjectsList()}updateShadowObjectsList(){this.lights.length=0,this.meshes.length=0,this.objectsToShow.length=0,this.objectsToShowSet.clear(),this.addObjectToShow(this.progShadowGrp),this.addObjectToShow(this.lightGroup),this.addObjectToShow(this.lightOrigin),this.addObjectToShow(this.shadowCatcherMesh),this.scene.traverse(e=>{if(e!==this.scene){if(this.isExcludedObject(e)){this.addObjectToShow(e);return}if(e===this.progShadowGrp||e===this.lightGroup||e===this.lightOrigin){this.addObjectToShow(e);return}if(e===this.shadowCatcherMesh){this.addObjectToShow(e);return}if(e.isLight&&e.parent!==this.lightGroup){this.lights.push({object:e,intensity:e.intensity});return}e.isGoods||e.isTransformControls||e.geometry&&e!==this.shadowCatcherMesh&&e.castShadow&&(this.meshes.push({object:e,material:e.material}),this.addObjectToShow(e))}}),this.rebuildObjectsToShowAncestors()}addObjectToShow(e){e&&(this.objectsToShowSet.has(e)||(this.objectsToShow.push({object:e,visible:e.visible}),this.objectsToShowSet.add(e)))}rebuildObjectsToShowAncestors(){this.objectsToShowAncestors.clear();const e=t=>{let i=t;for(;i&&!this.objectsToShowAncestors.has(i);)this.objectsToShowAncestors.add(i),i=i.parent};this.objectsToShow.forEach(({object:t})=>{e(t)})}isExcludedObject(e){const t=e;return!!(t.isCSS2DObject||t.isCSS3DObject||t.isHelper||typeof e.type=="string"&&e.type.endsWith("Helper")||typeof e.name=="string"&&e.name.toLowerCase().includes("helper"))}update(e){!this.params||!this.shadowCatcherMesh||!this.progressiveLightMap1||!this.progressiveLightMap2||!this.params.enabled||this.framesDone>=this.params.frames||this.params.paused||!this.shadowCatcherMesh.visible||!this.progShadowGrp.visible||(this.framesDone===0&&(this.fixedCamera=e.clone(),this.isRendering=!0),this.shadowCatcherMesh.material.alphaTest=d.MathUtils.clamp(d.MathUtils.mapLinear(this.framesDone,2,this.params.frames-1,0,this.params.alphaTest),0,1),this.renderOnRenderTargets(this.fixedCamera||e),this.randomiseLights(),this.progress=d.MathUtils.mapLinear(this.framesDone,0,this.params.frames-1,0,100),this.framesDone++,this.framesDone>=this.params.frames&&(this.fixedCamera=null,this.isRendering=!1))}destroy(){this.scene&&this.progShadowGrp&&this.scene.remove(this.progShadowGrp),this.progressiveLightMap1&&(this.progressiveLightMap1.dispose(),this.progressiveLightMap1=null),this.progressiveLightMap2&&(this.progressiveLightMap2.dispose(),this.progressiveLightMap2=null),this.shadowCatcherMaterial&&(this.shadowCatcherMaterial.dispose(),this.shadowCatcherMaterial=null),this.targetMat&&(this.targetMat.dispose(),this.targetMat=null),this.discardMaterial&&(this.discardMaterial.dispose(),this.discardMaterial=null),this.shadowCatcherMesh&&(this.shadowCatcherMesh.geometry&&this.shadowCatcherMesh.geometry.dispose(),this.shadowCatcherMesh=null),this.dirLights.forEach(e=>{e.parent&&e.parent.remove(e);const t=e;t.dispose&&typeof t.dispose=="function"&&t.dispose()}),this.dirLights=[],this.dirLightsHelpers.forEach(e=>{e.parent&&e.parent.remove(e);const t=e;t.dispose&&typeof t.dispose=="function"&&t.dispose()}),this.dirLightsHelpers=[],this.debugHelpersGroup&&(this.debugHelpersGroup.children.forEach(e=>{e.geometry&&e.geometry.dispose(),e.material&&e.material.dispose()}),this.debugHelpersGroup.clear(),this.debugHelpersGroup=null),this.progShadowGrp&&(this.progShadowGrp.clear(),this.progShadowGrp=null),this.lightGroup&&(this.lightGroup.clear(),this.lightGroup=null),this.lightOrigin&&(this.lightOrigin.clear(),this.lightOrigin=null),this.lights=[],this.meshes=[],this.objectsToShow=[],this.autoHiddenObjects=[],this.objectsToShowSet=new Set,this.objectsToShowAncestors=new Set,this.scene=null,this.renderer=null,this.fixedCamera=null,this.clearColor=null,this.previousShadowMap=null,this.averagingWindow=null,this.params=null}}function Ur(n={},e,t,i=s=>{}){const s=class extends d.ShaderMaterial{constructor(a={}){const o=Object.entries(n);super({uniforms:o.reduce((c,[u,f])=>{const p=d.UniformsUtils.clone({[u]:{value:f}});return{...c,...p}},{}),vertexShader:e,fragmentShader:t}),o.forEach(([c])=>Object.defineProperty(this,c,{get:()=>this.uniforms[c].value,set:u=>this.uniforms[c].value=u})),Object.assign(this,a),i&&i(this)}};return s.key=d.MathUtils.generateUUID(),s}const dc=Ur({transparent:!0,color:new d.Color(0,0,0),alphaTest:0,opacity:1,map:null,depthWrite:!1,toneMapped:!1,blend:2},`varying vec2 vUv;
3761
+ }`,m.uniforms.previousShadowMap=this.previousShadowMap,m.uniforms.averagingWindow=this.averagingWindow}}renderOnRenderTargets(e){this.prepare(),this.averagingWindow.value=this.params.frames;const t=this.buffer1Active?this.progressiveLightMap1:this.progressiveLightMap2,i=this.buffer1Active?this.progressiveLightMap2:this.progressiveLightMap1;this.renderer.setRenderTarget(t),this.previousShadowMap.value=i.texture,this.buffer1Active=!this.buffer1Active,this.renderer.render(this.scene,e),this.finish(),this.renderer.setRenderTarget(null)}showDebugHelpers(e){if(!this.debugHelpersGroup.children.length){const t=new d.Mesh(new d.PlaneGeometry(2,2),new d.MeshBasicMaterial({map:this.progressiveLightMap1.texture,side:d.DoubleSide}));this.isZUp?t.position.z=this.params.size/2:t.position.y=this.params.size/2;for(const a of this.dirLights){const o=new d.DirectionalLightHelper(a);this.dirLightsHelpers.push(o)}const i=this.isZUp?new d.Vector3(0,0,1):new d.Vector3(0,1,0),s=new d.PlaneHelper(new d.Plane(i,.001),this.params.size,16776960);this.debugHelpersGroup.add(t,s,...this.dirLightsHelpers)}e?(this.progShadowGrp.add(this.debugHelpersGroup),this.dirLightsHelpers.forEach(t=>{t.update()})):this.progShadowGrp.remove(this.debugHelpersGroup)}randomiseLights(){const e=this.lightOrigin.position.length();for(let t=0;t<this.dirLights.length;t++){if(Math.random()>this.params.ambientWeight)this.dirLights[t].position.set(this.lightOrigin.position.x+d.MathUtils.randFloatSpread(this.params.lightRadius),this.lightOrigin.position.y+d.MathUtils.randFloatSpread(this.params.lightRadius),this.lightOrigin.position.z+d.MathUtils.randFloatSpread(this.params.lightRadius));else{const i=Math.acos(2*Math.random()-1)-1.570795,s=2*3.14159*Math.random();this.isZUp?this.dirLights[t].position.set(Math.cos(i)*Math.cos(s)*e,Math.cos(i)*Math.sin(s)*e,Math.abs(Math.sin(i)*e)):this.dirLights[t].position.set(Math.cos(i)*Math.cos(s)*e,Math.abs(Math.cos(i)*Math.sin(s)*e),Math.sin(i)*e)}this.params.debugHelpers&&this.dirLightsHelpers[t].update()}}async recalculate(){this.params.enabled&&(this.clear(),this.framesDone=0,this.fixedCamera=null,this.isRendering=!1)}prepare(){this.lights.forEach(t=>{t.object.intensity=0}),this.meshes.forEach(t=>{t.object.material=this.discardMaterial}),this.autoHiddenObjects.length=0;const e=t=>this.objectsToShowAncestors.has(t);this.scene.traverse(t=>{t!==this.scene&&(this.isExcludedObject(t)||e(t)||t.isLight||t.isCamera||t.visible&&(this.autoHiddenObjects.push({object:t,visible:t.visible}),t.visible=!1))}),this.lightGroup.visible=!0,this.shadowCatcherMesh.material=this.targetMat,this.params.debugHelpers&&this.showDebugHelpers(!1)}finish(){this.lights.forEach(e=>{e.object.intensity=e.intensity}),this.meshes.forEach(e=>{e.object.material=e.material}),this.autoHiddenObjects.forEach(e=>{e.object.visible=e.visible}),this.autoHiddenObjects.length=0,this.lightGroup.visible=!1,this.shadowCatcherMesh.material=this.shadowCatcherMaterial,this.params.debugHelpers&&this.showDebugHelpers(!0)}clear(){this.renderer.getClearColor(this.clearColor),this.clearAlpha=this.renderer.getClearAlpha(),this.renderer.setClearColor("black",1),this.renderer.setRenderTarget(this.progressiveLightMap1),this.renderer.clear(),this.renderer.setRenderTarget(this.progressiveLightMap2),this.renderer.clear(),this.renderer.setRenderTarget(null),this.renderer.setClearColor(this.clearColor,this.clearAlpha),this.shadowCatcherMesh.material.alphaTest=0,this.updateShadowObjectsList()}updateShadowObjectsList(){this.lights.length=0,this.meshes.length=0,this.objectsToShow.length=0,this.objectsToShowSet.clear(),this.addObjectToShow(this.progShadowGrp),this.addObjectToShow(this.lightGroup),this.addObjectToShow(this.lightOrigin),this.addObjectToShow(this.shadowCatcherMesh),this.scene.traverse(e=>{if(e!==this.scene){if(this.isExcludedObject(e)){this.addObjectToShow(e);return}if(e===this.progShadowGrp||e===this.lightGroup||e===this.lightOrigin){this.addObjectToShow(e);return}if(e===this.shadowCatcherMesh){this.addObjectToShow(e);return}if(e.isLight&&e.parent!==this.lightGroup){this.lights.push({object:e,intensity:e.intensity});return}e.isGoods||e.isTransformControls||e.geometry&&e!==this.shadowCatcherMesh&&e.castShadow&&(this.meshes.push({object:e,material:e.material}),this.addObjectToShow(e))}}),this.rebuildObjectsToShowAncestors()}addObjectToShow(e){e&&(this.objectsToShowSet.has(e)||(this.objectsToShow.push({object:e,visible:e.visible}),this.objectsToShowSet.add(e)))}rebuildObjectsToShowAncestors(){this.objectsToShowAncestors.clear();const e=t=>{let i=t;for(;i&&!this.objectsToShowAncestors.has(i);)this.objectsToShowAncestors.add(i),i=i.parent};this.objectsToShow.forEach(({object:t})=>{e(t)})}isExcludedObject(e){const t=e;return!!(t.isCSS2DObject||t.isCSS3DObject||t.isHelper||typeof e.type=="string"&&e.type.endsWith("Helper")||typeof e.name=="string"&&e.name.toLowerCase().includes("helper"))}update(e){!this.params||!this.shadowCatcherMesh||!this.progressiveLightMap1||!this.progressiveLightMap2||!this.params.enabled||this.framesDone>=this.params.frames||this.params.paused||!this.shadowCatcherMesh.visible||!this.progShadowGrp.visible||(this.framesDone===0&&(this.fixedCamera=e.clone(),this.isRendering=!0),this.shadowCatcherMesh.material.alphaTest=d.MathUtils.clamp(d.MathUtils.mapLinear(this.framesDone,2,this.params.frames-1,0,this.params.alphaTest),0,1),this.renderOnRenderTargets(this.fixedCamera||e),this.randomiseLights(),this.progress=d.MathUtils.mapLinear(this.framesDone,0,this.params.frames-1,0,100),this.framesDone++,this.framesDone>=this.params.frames&&(this.fixedCamera=null,this.isRendering=!1))}destroy(){this.scene&&this.progShadowGrp&&this.scene.remove(this.progShadowGrp),this.progressiveLightMap1&&(this.progressiveLightMap1.dispose(),this.progressiveLightMap1=null),this.progressiveLightMap2&&(this.progressiveLightMap2.dispose(),this.progressiveLightMap2=null),this.shadowCatcherMaterial&&(this.shadowCatcherMaterial.dispose(),this.shadowCatcherMaterial=null),this.targetMat&&(this.targetMat.dispose(),this.targetMat=null),this.discardMaterial&&(this.discardMaterial.dispose(),this.discardMaterial=null),this.shadowCatcherMesh&&(this.shadowCatcherMesh.geometry&&this.shadowCatcherMesh.geometry.dispose(),this.shadowCatcherMesh=null),this.dirLights.forEach(e=>{e.parent&&e.parent.remove(e);const t=e;t.dispose&&typeof t.dispose=="function"&&t.dispose()}),this.dirLights=[],this.dirLightsHelpers.forEach(e=>{e.parent&&e.parent.remove(e);const t=e;t.dispose&&typeof t.dispose=="function"&&t.dispose()}),this.dirLightsHelpers=[],this.debugHelpersGroup&&(this.debugHelpersGroup.children.forEach(e=>{e.geometry&&e.geometry.dispose(),e.material&&e.material.dispose()}),this.debugHelpersGroup.clear(),this.debugHelpersGroup=null),this.progShadowGrp&&(this.progShadowGrp.clear(),this.progShadowGrp=null),this.lightGroup&&(this.lightGroup.clear(),this.lightGroup=null),this.lightOrigin&&(this.lightOrigin.clear(),this.lightOrigin=null),this.lights=[],this.meshes=[],this.objectsToShow=[],this.autoHiddenObjects=[],this.objectsToShowSet=new Set,this.objectsToShowAncestors=new Set,this.scene=null,this.renderer=null,this.fixedCamera=null,this.clearColor=null,this.previousShadowMap=null,this.averagingWindow=null,this.params=null}}function Hr(n={},e,t,i=s=>{}){const s=class extends d.ShaderMaterial{constructor(a={}){const o=Object.entries(n);super({uniforms:o.reduce((c,[u,f])=>{const p=d.UniformsUtils.clone({[u]:{value:f}});return{...c,...p}},{}),vertexShader:e,fragmentShader:t}),o.forEach(([c])=>Object.defineProperty(this,c,{get:()=>this.uniforms[c].value,set:u=>this.uniforms[c].value=u})),Object.assign(this,a),i&&i(this)}};return s.key=d.MathUtils.generateUUID(),s}const dc=Hr({transparent:!0,color:new d.Color(0,0,0),alphaTest:0,opacity:1,map:null,depthWrite:!1,toneMapped:!1,blend:2},`varying vec2 vUv;
3762
3762
  void main() {
3763
3763
  gl_Position = projectionMatrix * viewMatrix * modelMatrix * vec4(position, 1.);
3764
3764
  vUv = uv;
@@ -3773,7 +3773,7 @@ vec3 texelOld = texture2D(previousShadowMap, vUv).rgb;
3773
3773
  gl_FragColor = vec4(color * sampledDiffuseColor.r * blend, max(0.0, (1.0 - (sampledDiffuseColor.r + sampledDiffuseColor.g + sampledDiffuseColor.b) / alphaTest)) * opacity);
3774
3774
  #include <tonemapping_fragment>
3775
3775
  #include <colorspace_fragment>
3776
- }`),pc=Ur({},"void main() { }","void main() { gl_FragColor = vec4(0.0, 0.0, 0.0, 0.0); discard; }");class mc extends fe.CSS2DObject{constructor(e){const t=document.createElement("div");super(t),this._controls=e}}const gc="https://cdn2.seer-group.com/libs/hdr/aristea_wreck_512.hdr",vc="https://cdn2.seer-group.com/libs/fonts.type.json",_c=new nn.Font(vc);class es{constructor(e){var t;this._props=e,this.name="",this._defaults={color:""},this.color="",this.name=this._props.name,this.color=this._defaults.color="#"+((t=e.target.color)==null?void 0:t.getHexString())}change(e){var t;this.color=e,(t=this._props.target.color)==null||t.set(e)}reset(){this.change(this._defaults.color)}}var Hr=(n=>(n[n.DEFAULT=0]="DEFAULT",n[n.CAN_INSTALL=1]="CAN_INSTALL",n))(Hr||{});const ar=.15;d.Object3D.DEFAULT_UP.set(0,0,1);let Je,si=0,ts=0;const yc=()=>{Je=void 0,si=0,ts=0},xc=new d.MeshBasicMaterial({colorWrite:!1});class wc{constructor(e){this.props=e,this.stats=new Rt,this.scene=new d.Scene,this.overlayScene=new d.Scene,this.renderer=new d.WebGLRenderer({antialias:!0,alpha:!0,logarithmicDepthBuffer:!0,powerPreference:"high-performance",preserveDrawingBuffer:!0}),this.css2dRenderer=new fe.CSS2DRenderer,this.mousePos=new d.Vector2,this.mouseCoord=new d.Vector2,this.offset=new d.Vector2,this.size=new d.Vector2,this.amr=new Er({showSizeBox:!0,showController:!0}),this._clock=new d.Clock(!0),this._uiHiddenTime=this._clock.getElapsedTime(),this.camera=new d.PerspectiveCamera(39.6,window.innerWidth/window.innerHeight,.1,1e4),this.d=2,this.orthographicCamera=new d.OrthographicCamera(-this.d*(window.innerWidth/window.innerHeight),this.d*(window.innerWidth/window.innerHeight),this.d,-this.d,.1,1e3),this._axisMoving=!1,this._container=new d.Group,this._raycaster=new d.Raycaster,this._selected=[],this._pointerDownTimeout=0,this._dragging=!1,this.maxSample=1024*2,this.sampleCount=0,this._usePathTracing=!1,this._fpsCache=[],this._fpsCacheMax=20,this._emitter=new ct,this.sound=new Va,this._rafId=null,this._destroyed=!1,this._ground=new d.Mesh(new d.PlaneGeometry(100,100),new d.MeshPhysicalMaterial({color:new d.Color("#eee"),metalness:.4,roughness:.1,clearcoat:1,clearcoatRoughness:.1})),this.light=new d.PointLight(16777215,10,30),this._amrRender=new d.WebGLRenderTarget(1024,1024,{format:d.RGBAFormat,type:d.UnsignedByteType,colorSpace:d.SRGBColorSpace,samples:8}),this._lastTarget=new d.Vector3,this._shadowMode=!1,this.addEventListener=this._emitter.on.bind(this._emitter),this.removeEventListener=this._emitter.on.bind(this._emitter),this._showSlots=!0,this._showSize=!0,this._showControls=!0,this._drag=u=>{this._dragging=!0,this._pointermove(u)},this._dragend=u=>{this._dragging=!1},this._pointermove=u=>{if(this._pointerDownTimeout)return clearTimeout(this._pointerDownTimeout),this._pointerDownTimeout=0;let{top:f,left:p}=this.renderer.domElement.getBoundingClientRect();this.offset.set(p,f),this.mousePos.set(u.clientX-p,u.clientY-f),this.mouseCoord.set((u.clientX-p)/this.size.x*2-1,-((u.clientY-f)/this.size.y)*2+1),this._raycaster.setFromCamera(this.mouseCoord,this.camera)},this._pointerdown=u=>{const f=()=>{let p=[...this._outlinePass.selectedObjects];this._outlinePass.selectedObjects=[],this.amr.slots.forEach(h=>h.selected=!1);const l=this._raycaster.intersectObjects(this.amr.slots,!1)[0];l&&this.amr.slots.forEach(h=>{h.traverse(g=>{g==l.object?p!=null&&p.includes(h)?(p=void 0,h.deviceSelected=!1):(this._outlinePass.selectedObjects=[h],h.deviceSelected=!0):h.deviceSelected=!1})}),this._pointerDownTimeout=0};this._pointerDownTimeout=window.setTimeout(f,200)},this._detectTrackpad=()=>{Je||typeof Je<"u"||(si===0&&(ts=performance.now()),si++,performance.now()-ts>66&&(si>5?Je=!0:Je=!1,Je?this.controls.zoomSpeed=.2:this.controls.zoomSpeed=1,setTimeout(yc,2e3)))},this.debounceForkHeightChange=Wa(()=>{var u;(u=this._progressShadow)==null||u.recalculate()},300),this.focusSlots=u=>{var P,D,S;if(this.amr.slots.forEach(M=>{M.focused=!1,M.hide()}),!u.length)if(this._lastTarget.set(0,0,this._lastTarget.z),this.amr.slots.forEach(M=>{M.show()}),this.shadowMode=!1,this._focusRestoreView){const M=this._focusRestoreView;this._focusRestoreView=void 0;const R=this.camera.position.clone(),E=this.controls.target.clone(),F=M.position.clone(),O=M.target.clone(),H={t:0};let W=500;const j=R.distanceTo(F)+E.distanceTo(O);j>.001&&(W=Math.min(1e3,Math.max(450,j*45))),(P=this._fitAnimation)==null||P.stop(),this._fitAnimation=new It(H).to({t:1},W).easing(ye.Easing.Quadratic.InOut).onStart(()=>{this.controls.enabled=!1}).onUpdate(()=>{const Y=H.t;this.camera.position.lerpVectors(R,F,Y),this.controls.target.lerpVectors(E,O,Y)}).onComplete(()=>{this.controls.enabled=!0,this.camera.up.copy(M.up)}).start();return}else{this.fit();return}(D=this._fitAnimation)!=null&&D.isPlaying()||this.shadowMode||(this._focusRestoreView={position:this.camera.position.clone(),target:new d.Vector3(0,0,this.controls.target.z),up:this.camera.up.clone()}),(S=this._fitAnimation)==null||S.stop(),this.shadowMode=!0;const f=u.flatMap(M=>{if(M.show(),M.focused=!0,!M.parent)return[];const R=new d.Vector3;return M.parent.getWorldPosition(R),[R]});if(!f.length)return;const p=f.reduce((M,R)=>M.add(R),new d.Vector3).multiplyScalar(1/f.length),r=this.controls.target.clone(),l=this.camera.position.clone().sub(r).normalize();let h=0;for(const M of f){const R=M.clone().sub(p),E=R.dot(l),F=Math.sqrt(Math.max(0,R.lengthSq()-E*E));F>h&&(h=F)}h=h+.4;const g=this.camera.fov*Math.PI/180,_=2*Math.atan(Math.tan(g/2)*this.camera.aspect),m=h/Math.tan(_/2),v=h/Math.tan(g/2),y=Math.max(m,v),x=p.clone(),w=p.clone().add(l.clone().multiplyScalar(y<1?1:y)),b=this.camera.position.clone(),A=r.clone(),T={t:0};let I=500;const C=b.distanceTo(w)+A.distanceTo(x);C>.001&&(I=Math.min(1e3,Math.max(450,C*45))),this._lastTarget=x.clone(),this._fitAnimation=new It(T).to({t:1},I).easing(ye.Easing.Quadratic.InOut).onStart(()=>{this.controls.enabled=!1}).onUpdate(()=>{const M=T.t;this.camera.position.lerpVectors(b,w,M),this.controls.target.lerpVectors(A,x,M)}).onComplete(()=>{this.controls.enabled=!0}).start()},this.fit=()=>{this._focusRestoreView=void 0,new d.Box3().setFromObject(this._container);const f=this.amr.sizeBox.size.getSize(new d.Vector3),p=f.clone().multiplyScalar(.5),r=new d.Vector3(0,0,p.z);this._lastTarget.copy(r);let l=p.clone().sub(r);l.lengthSq()<1e-6&&(l=new d.Vector3(1,0,0));const h=l.clone().normalize(),g=f.clone().multiplyScalar(.5),_=[new d.Vector3(g.x,g.y,g.z),new d.Vector3(g.x,g.y,-g.z),new d.Vector3(g.x,-g.y,g.z),new d.Vector3(g.x,-g.y,-g.z),new d.Vector3(-g.x,g.y,g.z),new d.Vector3(-g.x,g.y,-g.z),new d.Vector3(-g.x,-g.y,g.z),new d.Vector3(-g.x,-g.y,-g.z)];let m=0;for(const E of _){const F=E.dot(h),O=Math.sqrt(Math.max(0,E.lengthSq()-F*F));O>m&&(m=O)}m=m*1.05;const v=this.camera.fov*Math.PI/180,y=2*Math.atan(Math.tan(v/2)*this.camera.aspect),x=m/Math.tan(y/2),w=m/Math.tan(v/2),b=Math.max(x,w),A=p.clone();let T=f.z/3;f.z<f.x&&f.z<f.y&&(T=f.x*.8),f.z>f.x&&f.z>f.y&&(T=0),A.z+=T;const I=l.clone().normalize().multiplyScalar(b<1?1:b).add(A),C=Math.max(f.x*2,5);this.light.position.set(C,0,f.z*2);const P=this.camera.position.clone(),D=this.controls.target.clone(),S={t:0};let M=600;const R=P.distanceTo(I)+D.distanceTo(r);R>.001&&(M=Math.min(800,Math.max(650,R*45))),this._fitAnimation=new It(S).to({t:1},M).easing(ye.Easing.Quadratic.InOut).onStart(()=>{this.controls.enabled=!1}).onUpdate(()=>{const E=S.t;this.camera.position.lerpVectors(P,I,E),this.controls.target.lerpVectors(D,r,E)}).onComplete(()=>{this.controls.enabled=!0,!this.shadowMode&&(this._progressShadow.visible=!0,this._progressShadow.isFinished||this._progressShadow.recalculate())}).start(),this.controls.minDistance=Math.max(.2,Math.min(b*.25,b-.1)),this.controls.maxDistance=b*4},this.resize=()=>{var h;const u=this.renderer.domElement.parentElement;if(!u)return;u.style.display="flex",this.renderer.domElement.style.width="100%",this.renderer.domElement.style.height="100%",this.renderer.domElement.style.flexGrow="1";const f=u.clientWidth,p=u.clientHeight;this.size.set(f,p),this.camera.aspect=f/p,this.camera.updateProjectionMatrix(),this._amrRender.setSize(f,p),this._updateCamera(),this.css2dRenderer.setSize(f,p);const r=this.renderer.getPixelRatio();(h=this.pathTracer)==null||h.updateCamera(),this.sampleCount=0,this.renderer.setSize(f,p),this._composer.setSize(f,p),this._composer.passes.forEach(g=>g.setSize(f,p));const l=this._fxaaPass.material.uniforms;l.resolution.value.x=1/(f*r),l.resolution.value.y=1/(p*r),this._bloomPass&&this._bloomPass.setSize(f,p)},this.ticker=()=>{if(!this._destroyed){if(this.stats.begin(),this.renderer.domElement.dispatchEvent(new CustomEvent("ticker")),this._rafId=requestAnimationFrame(this.ticker),this.renderer.autoClear=!1,this.renderer.clear(),this.usePathTracing){this.hideAmrUI(),this.sampleCount<this.maxSample?this.sampleCount++:this.pathTracer.pausePathTracing=!0,this.pathTracer.renderSample();const u=this.renderer.autoClear;this.renderer.autoClear=!1,this.scene.overrideMaterial=xc,this.renderer.clearDepth(),this.renderer.render(this.scene,this.mainCamera),this.scene.overrideMaterial=null,this.renderer.render(this.overlayScene,this.mainCamera),this.renderer.autoClear=u}else{this._clock.getElapsedTime()-this._uiHiddenTime>.15?this.showControls&&this.amr.controllers.forEach(p=>p.show()):this.amr.controllers.forEach(p=>p.hide());const f=this.stats.fps();this.usePathTracing||(this._fpsCache.length>this._fpsCacheMax&&this._fpsCache.shift(),this._fpsCache.push(f)),this.amr.slots.forEach(p=>{this._dragging?p.getCanInstall()&&p.render(this):p.render(this)}),ye.update(),this.controls.update(),this._progressShadow.update(this.mainCamera),this.css2dRenderer.render(this.scene,this.mainCamera),this.updatePosition(),this.scene.overrideMaterial=null,this.renderer.render(this.scene,this.mainCamera)}this.stats.end()}},this.stats.showPanel(0),this.hideState(),e.fov&&(this.camera.fov=e.fov,this.camera.updateProjectionMatrix()),Tr(lt,this.renderer),this._ground.visible=!1,this.controls=new tn.OrbitControls(this.camera,this.renderer.domElement),this.controls.enablePan=!0,this.controls.rotateSpeed=this.props.isMobile?.6:.5,this.controls.dampingFactor=ar,this.controls.enableDamping=!0,this.controls.maxDistance=10,this.controls.minDistance=1,this.controls.zoomSpeed=this.props.isMobile?.3:Ir()?.2:1,this._cameraPositionUI=new mc(this.controls),this.renderer.setPixelRatio(window.devicePixelRatio||1),this.renderer.autoClear=!0,this.renderer.toneMapping=d.ACESFilmicToneMapping,this.renderer.toneMappingExposure=1.4,this.renderer.outputColorSpace=d.SRGBColorSpace,this.renderer.localClippingEnabled=!0,this.renderer.shadowMap.enabled=!0,this.css2dRenderer.domElement.style.pointerEvents="none",this.css2dRenderer.domElement.style.position="absolute",this.css2dRenderer.domElement.style.top="0px",d.ShaderChunk.tonemapping_pars_fragment=d.ShaderChunk.tonemapping_pars_fragment.replace("vec3 CustomToneMapping( vec3 color ) { return color; }",`
3776
+ }`),pc=Hr({},"void main() { }","void main() { gl_FragColor = vec4(0.0, 0.0, 0.0, 0.0); discard; }");class mc extends fe.CSS2DObject{constructor(e){const t=document.createElement("div");super(t),this._controls=e}}const gc="https://cdn2.seer-group.com/libs/hdr/aristea_wreck_512.hdr",vc="https://cdn2.seer-group.com/libs/fonts.type.json",_c=new on.Font(vc);class ts{constructor(e){var t;this._props=e,this.name="",this._defaults={color:""},this.color="",this.name=this._props.name,this.color=this._defaults.color="#"+((t=e.target.color)==null?void 0:t.getHexString())}change(e){var t;this.color=e,(t=this._props.target.color)==null||t.set(e)}reset(){this.change(this._defaults.color)}}var Nr=(n=>(n[n.DEFAULT=0]="DEFAULT",n[n.CAN_INSTALL=1]="CAN_INSTALL",n))(Nr||{});const lr=.15;d.Object3D.DEFAULT_UP.set(0,0,1);let $e,si=0,is=0;const yc=()=>{$e=void 0,si=0,is=0},xc=new d.MeshBasicMaterial({colorWrite:!1});class wc{constructor(e){this.props=e,this.stats=new Rt,this.scene=new d.Scene,this.overlayScene=new d.Scene,this.renderer=new d.WebGLRenderer({antialias:!0,alpha:!0,logarithmicDepthBuffer:!0,powerPreference:"high-performance",preserveDrawingBuffer:!0}),this.css2dRenderer=new fe.CSS2DRenderer,this.mousePos=new d.Vector2,this.mouseCoord=new d.Vector2,this.offset=new d.Vector2,this.size=new d.Vector2,this.amr=new Fr({showSizeBox:!0,showController:!0}),this._clock=new d.Clock(!0),this._uiHiddenTime=this._clock.getElapsedTime(),this.camera=new d.PerspectiveCamera(39.6,window.innerWidth/window.innerHeight,.1,1e4),this.d=2,this.orthographicCamera=new d.OrthographicCamera(-this.d*(window.innerWidth/window.innerHeight),this.d*(window.innerWidth/window.innerHeight),this.d,-this.d,.1,1e3),this._axisMoving=!1,this._container=new d.Group,this._raycaster=new d.Raycaster,this._selected=[],this._pointerDownTimeout=0,this._dragging=!1,this.maxSample=1024*2,this.sampleCount=0,this._usePathTracing=!1,this._fpsCache=[],this._fpsCacheMax=20,this._emitter=new ct,this.sound=new Va,this._rafId=null,this._destroyed=!1,this._ground=new d.Mesh(new d.PlaneGeometry(100,100),new d.MeshPhysicalMaterial({color:new d.Color("#eee"),metalness:.4,roughness:.1,clearcoat:1,clearcoatRoughness:.1})),this.light=new d.PointLight(16777215,10,30),this._amrRender=new d.WebGLRenderTarget(1024,1024,{format:d.RGBAFormat,type:d.UnsignedByteType,colorSpace:d.SRGBColorSpace,samples:8}),this._lastTarget=new d.Vector3,this._shadowMode=!1,this.addEventListener=this._emitter.on.bind(this._emitter),this.removeEventListener=this._emitter.on.bind(this._emitter),this._showSlots=!0,this._showSize=!0,this._showControls=!0,this._drag=u=>{this._dragging=!0,this._pointermove(u)},this._dragend=u=>{this._dragging=!1},this._pointermove=u=>{if(this._pointerDownTimeout)return clearTimeout(this._pointerDownTimeout),this._pointerDownTimeout=0;let{top:f,left:p}=this.renderer.domElement.getBoundingClientRect();this.offset.set(p,f),this.mousePos.set(u.clientX-p,u.clientY-f),this.mouseCoord.set((u.clientX-p)/this.size.x*2-1,-((u.clientY-f)/this.size.y)*2+1),this._raycaster.setFromCamera(this.mouseCoord,this.camera)},this._pointerdown=u=>{const f=()=>{let p=[...this._outlinePass.selectedObjects];this._outlinePass.selectedObjects=[],this.amr.slots.forEach(h=>h.selected=!1);const l=this._raycaster.intersectObjects(this.amr.slots,!1)[0];l&&this.amr.slots.forEach(h=>{h.traverse(g=>{g==l.object?p!=null&&p.includes(h)?(p=void 0,h.deviceSelected=!1):(this._outlinePass.selectedObjects=[h],h.deviceSelected=!0):h.deviceSelected=!1})}),this._pointerDownTimeout=0};this._pointerDownTimeout=window.setTimeout(f,200)},this._detectTrackpad=()=>{$e||typeof $e<"u"||(si===0&&(is=performance.now()),si++,performance.now()-is>66&&(si>5?$e=!0:$e=!1,$e?this.controls.zoomSpeed=.2:this.controls.zoomSpeed=1,setTimeout(yc,2e3)))},this.debounceForkHeightChange=Wa(()=>{var u;(u=this._progressShadow)==null||u.recalculate()},300),this.focusSlots=u=>{var P,D,S;if(this.amr.slots.forEach(M=>{M.focused=!1,M.hide()}),!u.length)if(this._lastTarget.set(0,0,this._lastTarget.z),this.amr.slots.forEach(M=>{M.show()}),this.shadowMode=!1,this._focusRestoreView){const M=this._focusRestoreView;this._focusRestoreView=void 0;const R=this.camera.position.clone(),E=this.controls.target.clone(),F=M.position.clone(),O=M.target.clone(),H={t:0};let W=500;const j=R.distanceTo(F)+E.distanceTo(O);j>.001&&(W=Math.min(1e3,Math.max(450,j*45))),(P=this._fitAnimation)==null||P.stop(),this._fitAnimation=new It(H).to({t:1},W).easing(ye.Easing.Quadratic.InOut).onStart(()=>{this.controls.enabled=!1}).onUpdate(()=>{const Y=H.t;this.camera.position.lerpVectors(R,F,Y),this.controls.target.lerpVectors(E,O,Y)}).onComplete(()=>{this.controls.enabled=!0,this.camera.up.copy(M.up)}).start();return}else{this.fit();return}(D=this._fitAnimation)!=null&&D.isPlaying()||this.shadowMode||(this._focusRestoreView={position:this.camera.position.clone(),target:new d.Vector3(0,0,this.controls.target.z),up:this.camera.up.clone()}),(S=this._fitAnimation)==null||S.stop(),this.shadowMode=!0;const f=u.flatMap(M=>{if(M.show(),M.focused=!0,!M.parent)return[];const R=new d.Vector3;return M.parent.getWorldPosition(R),[R]});if(!f.length)return;const p=f.reduce((M,R)=>M.add(R),new d.Vector3).multiplyScalar(1/f.length),r=this.controls.target.clone(),l=this.camera.position.clone().sub(r).normalize();let h=0;for(const M of f){const R=M.clone().sub(p),E=R.dot(l),F=Math.sqrt(Math.max(0,R.lengthSq()-E*E));F>h&&(h=F)}h=h+.4;const g=this.camera.fov*Math.PI/180,_=2*Math.atan(Math.tan(g/2)*this.camera.aspect),m=h/Math.tan(_/2),v=h/Math.tan(g/2),y=Math.max(m,v),x=p.clone(),w=p.clone().add(l.clone().multiplyScalar(y<1?1:y)),b=this.camera.position.clone(),A=r.clone(),T={t:0};let I=500;const C=b.distanceTo(w)+A.distanceTo(x);C>.001&&(I=Math.min(1e3,Math.max(450,C*45))),this._lastTarget=x.clone(),this._fitAnimation=new It(T).to({t:1},I).easing(ye.Easing.Quadratic.InOut).onStart(()=>{this.controls.enabled=!1}).onUpdate(()=>{const M=T.t;this.camera.position.lerpVectors(b,w,M),this.controls.target.lerpVectors(A,x,M)}).onComplete(()=>{this.controls.enabled=!0}).start()},this.fit=()=>{this._focusRestoreView=void 0,new d.Box3().setFromObject(this._container);const f=this.amr.sizeBox.size.getSize(new d.Vector3),p=f.clone().multiplyScalar(.5),r=new d.Vector3(0,0,p.z);this._lastTarget.copy(r);let l=p.clone().sub(r);l.lengthSq()<1e-6&&(l=new d.Vector3(1,0,0));const h=l.clone().normalize(),g=f.clone().multiplyScalar(.5),_=[new d.Vector3(g.x,g.y,g.z),new d.Vector3(g.x,g.y,-g.z),new d.Vector3(g.x,-g.y,g.z),new d.Vector3(g.x,-g.y,-g.z),new d.Vector3(-g.x,g.y,g.z),new d.Vector3(-g.x,g.y,-g.z),new d.Vector3(-g.x,-g.y,g.z),new d.Vector3(-g.x,-g.y,-g.z)];let m=0;for(const E of _){const F=E.dot(h),O=Math.sqrt(Math.max(0,E.lengthSq()-F*F));O>m&&(m=O)}m=m*1.05;const v=this.camera.fov*Math.PI/180,y=2*Math.atan(Math.tan(v/2)*this.camera.aspect),x=m/Math.tan(y/2),w=m/Math.tan(v/2),b=Math.max(x,w),A=p.clone();let T=f.z/3;f.z<f.x&&f.z<f.y&&(T=f.x*.8),f.z>f.x&&f.z>f.y&&(T=0),A.z+=T;const I=l.clone().normalize().multiplyScalar(b<1?1:b).add(A),C=Math.max(f.x*2,5);this.light.position.set(C,0,f.z*2);const P=this.camera.position.clone(),D=this.controls.target.clone(),S={t:0};let M=600;const R=P.distanceTo(I)+D.distanceTo(r);R>.001&&(M=Math.min(800,Math.max(650,R*45))),this._fitAnimation=new It(S).to({t:1},M).easing(ye.Easing.Quadratic.InOut).onStart(()=>{this.controls.enabled=!1}).onUpdate(()=>{const E=S.t;this.camera.position.lerpVectors(P,I,E),this.controls.target.lerpVectors(D,r,E)}).onComplete(()=>{this.controls.enabled=!0,!this.shadowMode&&(this._progressShadow.visible=!0,this._progressShadow.isFinished||this._progressShadow.recalculate())}).start(),this.controls.minDistance=Math.max(.2,Math.min(b*.25,b-.1)),this.controls.maxDistance=b*4},this.resize=()=>{var h;const u=this.renderer.domElement.parentElement;if(!u)return;u.style.display="flex",this.renderer.domElement.style.width="100%",this.renderer.domElement.style.height="100%",this.renderer.domElement.style.flexGrow="1";const f=u.clientWidth,p=u.clientHeight;this.size.set(f,p),this.camera.aspect=f/p,this.camera.updateProjectionMatrix(),this._amrRender.setSize(f,p),this._updateCamera(),this.css2dRenderer.setSize(f,p);const r=this.renderer.getPixelRatio();(h=this.pathTracer)==null||h.updateCamera(),this.sampleCount=0,this.renderer.setSize(f,p),this._composer.setSize(f,p),this._composer.passes.forEach(g=>g.setSize(f,p));const l=this._fxaaPass.material.uniforms;l.resolution.value.x=1/(f*r),l.resolution.value.y=1/(p*r),this._bloomPass&&this._bloomPass.setSize(f,p)},this.ticker=()=>{if(!this._destroyed){if(this.stats.begin(),this.renderer.domElement.dispatchEvent(new CustomEvent("ticker")),this._rafId=requestAnimationFrame(this.ticker),this.renderer.autoClear=!1,this.renderer.clear(),this.usePathTracing){this.hideAmrUI(),this.sampleCount<this.maxSample?this.sampleCount++:this.pathTracer.pausePathTracing=!0,this.pathTracer.renderSample();const u=this.renderer.autoClear;this.renderer.autoClear=!1,this.scene.overrideMaterial=xc,this.renderer.clearDepth(),this.renderer.render(this.scene,this.mainCamera),this.scene.overrideMaterial=null,this.renderer.render(this.overlayScene,this.mainCamera),this.renderer.autoClear=u}else{this._clock.getElapsedTime()-this._uiHiddenTime>.15?this.showControls&&this.amr.controllers.forEach(p=>p.show()):this.amr.controllers.forEach(p=>p.hide());const f=this.stats.fps();this.usePathTracing||(this._fpsCache.length>this._fpsCacheMax&&this._fpsCache.shift(),this._fpsCache.push(f)),this.amr.slots.forEach(p=>{this._dragging?p.getCanInstall()&&p.render(this):p.render(this)}),ye.update(),this.controls.update(),this._progressShadow.update(this.mainCamera),this.css2dRenderer.render(this.scene,this.mainCamera),this.updatePosition(),this.scene.overrideMaterial=null,this.renderer.render(this.scene,this.mainCamera)}this.stats.end()}},this.stats.showPanel(0),this.hideState(),e.fov&&(this.camera.fov=e.fov,this.camera.updateProjectionMatrix()),Sr(Oe,this.renderer),this._ground.visible=!1,this.controls=new sn.OrbitControls(this.camera,this.renderer.domElement),this.controls.enablePan=!0,this.controls.rotateSpeed=this.props.isMobile?.6:.5,this.controls.dampingFactor=lr,this.controls.enableDamping=!0,this.controls.maxDistance=10,this.controls.minDistance=1,this.controls.zoomSpeed=this.props.isMobile?.3:Rr()?.2:1,this._cameraPositionUI=new mc(this.controls),this.renderer.setPixelRatio(window.devicePixelRatio||1),this.renderer.autoClear=!0,this.renderer.toneMapping=d.ACESFilmicToneMapping,this.renderer.toneMappingExposure=1.4,this.renderer.outputColorSpace=d.SRGBColorSpace,this.renderer.localClippingEnabled=!0,this.renderer.shadowMap.enabled=!0,this.css2dRenderer.domElement.style.pointerEvents="none",this.css2dRenderer.domElement.style.position="absolute",this.css2dRenderer.domElement.style.top="0px",d.ShaderChunk.tonemapping_pars_fragment=d.ShaderChunk.tonemapping_pars_fragment.replace("vec3 CustomToneMapping( vec3 color ) { return color; }",`
3777
3777
  float startCompression = 0.8;
3778
3778
  float desaturation = 0.5;
3779
3779
  vec3 CustomToneMapping( vec3 color ) {
@@ -3792,9 +3792,9 @@ vec3 texelOld = texture2D(previousShadowMap, vUv).rgb;
3792
3792
  color *= newPeak * invPeak;
3793
3793
  float g = 1. - 3. / (desaturation * extraBrightness + 3.);
3794
3794
  return mix(color, vec3(1, 1, 1), g);
3795
- }`),this.camera.position.set(10,-10,5),this.camera.lookAt(new d.Vector3);const{tiles:t}=Ha();this.pathTracer=new ta(this.renderer),this.pathTracer.filterGlossyFactor=.6;let i=window.devicePixelRatio;i<2&&(i=2),this.pathTracer.renderScale=this.props.isMobile?1:i,this.pathTracer.bounces=this.props.isMobile?8:10,this.pathTracer.transmissiveBounces=this.props.isMobile?1:3,this.pathTracer.tiles.set(t,t),this.pathTracer.fadeDuration=0;const s=new uc(e.workerUrl),a=typeof navigator<"u"?navigator.hardwareConcurrency:4;s.maxWorkerCount=a,this.pathTracer.setBVHWorker(s),this.orthographicCamera.left=-20,this.orthographicCamera.right=20,this.orthographicCamera.top=-20,this.orthographicCamera.bottom=20,this._lastTarget=this.controls.target.clone();const o=()=>{let u=this._lastTarget.x,f=this._lastTarget.y;this.controls.target.x=u,this.controls.target.y=f};this.controls.addEventListener("change",()=>{var u;this.sampleCount=0,o(),this._uiHiddenTime=this._clock.getElapsedTime(),this.orthographicCamera.position.copy(this.camera.position),this.orthographicCamera.lookAt(this.controls.target),this.usePathTracing&&(this.pathTracer.pausePathTracing=!1,(u=this.pathTracer)==null||u.updateCamera()),this._updateCamera(),!(Math.abs(this.camera.position.x)<.001||Math.abs(this.camera.position.y)<.001)&&(this._axisMoving||(this.mainCamera=this.camera,this.usePathTracing&&this.generateBVH().then()))}),this._mainCamera=this.camera,this._composer=new rn.EffectComposer(this.renderer),this._composer.setPixelRatio(window.devicePixelRatio);const c=new ms.RenderPass(this.scene,this.camera);this._composer.addPass(c),this._composer.addPass(new sn.OutputPass),this._outlinePass=new gs.OutlinePass(new d.Vector2(window.innerWidth,window.innerHeight),this.scene,this.camera),this._outlinePass.visibleEdgeColor.set(26367),this._outlinePass.edgeThickness=.5,this._outlinePass.hiddenEdgeColor.set(26367),this._outlinePass.edgeStrength=3,this._outlinePass.edgeGlow=0,this._composer.addPass(this._outlinePass),this._outlinePassError=new gs.OutlinePass(new d.Vector2(window.innerWidth,window.innerHeight),this.scene,this.camera),this._outlinePassError.visibleEdgeColor.set(16711680),this._outlinePassError.edgeThickness=.5,this._outlinePassError.hiddenEdgeColor.set(16711680),this._outlinePassError.edgeStrength=3,this._outlinePassError.edgeGlow=0,this._composer.addPass(this._outlinePassError),this._bloomPass=new en.UnrealBloomPass(new d.Vector2(window.innerWidth,window.innerHeight),.1,.1,.2),this._bloomPass.enabled=!1,this._bloomPass.renderToScreen=!1,this._composer.addPass(this._bloomPass),this._composer.renderTarget1.texture.colorSpace=d.SRGBColorSpace,this._composer.renderTarget2.texture.colorSpace=d.SRGBColorSpace,this._fxaaPass=new Jr.ShaderPass($r.FXAAShader),this._composer.addPass(this._fxaaPass),this._progressShadow=new fc(this.renderer,this.scene,{size:8,lightCount:e.isMobile?6:12,frames:e.isMobile?80:120,lightRadius:8,ambientWeight:.8}),this._progressShadow.lightOrigin.position.set(3,2.5,6),this._progressShadow.visible=!1,this._container.add(this.amr),this.scene.add(this._container),this.ticker(),this._loadEnv(),this._initEvents(),this.scene.add(this._cameraPositionUI),this._ground.rotateX(-Math.PI/2),this.scene.add(this._ground),(typeof e.useAxisBall!="boolean"||e.useAxisBall)&&(this._controlsGizmo=new hc(this.controls,{size:160,padding:12,offset:e.axisBallOffset||new d.Vector2(10,10),fontSize:17,bubbleSizePrimary:18,bubbleSizeSecondary:14}),this._controlsGizmo.addListener("axis-select-start",()=>{this._axisMoving=!0,this.mainCamera=this.orthographicCamera,this.usePathTracing&&this.generateBVH().then()}),this._controlsGizmo.addListener("axis-select-end",()=>{this._axisMoving=!1})),this.test=new d.Mesh(new d.PlaneGeometry(2,2),new d.MeshBasicMaterial({map:this._amrRender.texture,opacity:.5,transparent:!0,side:d.DoubleSide})),this.test.position.set(0,1,0),this.test.visible=!1,this.scene.add(this.test)}get usePathTracing(){return this._usePathTracing}_clearAmrContent(){const e=this.renderer.getRenderTarget();this.renderer.setRenderTarget(this._amrRender),this.renderer.setClearColor(0,0),this.renderer.clear(!0,!0,!0),this.renderer.setRenderTarget(e)}get shadowMode(){return this._shadowMode}set shadowMode(e){e?(this._progressShadow.visible=!1,this.amr.bodyOpacity=.2):(this._progressShadow.visible=!0,this.amr.bodyOpacity=1,this._progressShadow.isFinished||this._progressShadow.recalculate().then()),this._shadowMode=e}set usePathTracing(e){this._clearAmrContent(),e?(this.scene.add(this.light),this.renderer.toneMappingExposure=1.8,this.overlayScene.add(this._progressShadow.shadowCatcherMesh),this.amr&&(this.amr.bodyOpacity=1),this.hideAmrUI(),this.pathTracer.renderToCanvas=!0,this.scene.background=null):(this.light.removeFromParent(),this.renderer.toneMappingExposure=1.4,this.scene.add(this._progressShadow.shadowCatcherMesh),this.pathTracer.renderToCanvas=!1,this.amr.logos.forEach(t=>{var i;(i=t.parent)==null||i.add(t.target)}),this.showAmrUI(),this.amr&&this.amr.opacityCache!==void 0?(this.amr.bodyOpacity=this.amr.opacityCache,this.amr.opacityCache=void 0):this.amr&&(this.amr.bodyOpacity=1),this.pathTracer.reset(),this._ground.visible=!1,this.scene.background=this.scene.environment),this._usePathTracing=e,this.controls.dampingFactor=e?1:ar,this.sampleCount=0}get fpsAverage(){return Cr(this._fpsCache)}get mainCamera(){return this._mainCamera}set mainCamera(e){this._mainCamera=e,this._composer.passes.forEach(t=>{t instanceof ms.RenderPass&&(t.camera=e)}),e instanceof d.OrthographicCamera?this.scene.background=null:this.scene.background=this.scene.environment}showState(){this.stats.dom.style.display="block"}hideState(){this.stats.dom.style.display="none"}hideAmrUI(e=!0,t=!0){this.shadowMode||this.amr.slots.forEach(i=>i.hide()),this.amr.sizeBox.hide(e),this.amr.controllers.forEach(i=>i.hide()),t&&this.amr.goods.forEach(i=>i.hide())}showAmrUI(e=!0){this.showSlots&&this.amr.slots.forEach(t=>t.show()),this.showSize&&this.amr.sizeBox.show(e),this.showControls&&this.amr.controllers.forEach(t=>t.show()),this.amr.goods.forEach(t=>t.show())}get showSlots(){return this._showSlots}set showSlots(e){this._showSlots=e,this.amr.slots.forEach(t=>e?t.show():t.hide())}get showSize(){return this._showSize}set showSize(e){this._showSize=e,e?this.amr.sizeBox.show(!0):this.amr.sizeBox.hide(!0)}get showControls(){return this._showControls}set showControls(e){this._showControls=e,this.amr.controllers.forEach(t=>e?t.show():t.hide())}_updateCamera(){const e=this.mainCamera.position.distanceTo(this.controls.target),t=2*Math.tan(this.camera.fov*.5*Math.PI/180)*e,i=this.size.x/this.size.y;this.orthographicCamera.left=-t*i/2,this.orthographicCamera.right=t*i/2,this.orthographicCamera.top=t/2,this.orthographicCamera.bottom=-t/2,this.orthographicCamera.updateProjectionMatrix()}_loadEnv(){new Kr.HDRLoader().load(gc,t=>{t.mapping=d.EquirectangularReflectionMapping,this._usePathTracing||(this.scene.background=t,this.scene.backgroundBlurriness=1,this.scene.backgroundIntensity=1,this.scene.backgroundRotation=new d.Euler(Math.PI/2,0,Math.PI*.98*.8),this.scene.environment=t,this.overlayScene.environment=t,this.scene.environmentRotation=this.scene.backgroundRotation,this.overlayScene.environmentRotation=this.scene.environmentRotation,this.scene.environmentIntensity=1.4,this.overlayScene.environmentIntensity=this.scene.environmentIntensity),this.pathTracer.updateEnvironment()},()=>{},()=>{})}_initEvents(){window.addEventListener("drag",this._drag),window.addEventListener("dragend",this._dragend),document.addEventListener("wheel",this._detectTrackpad),window.addEventListener("pointermove",this._pointermove),this.renderer.domElement.addEventListener("pointerdown",this._pointerdown)}switchCamera(){this.mainCamera=this.mainCamera===this.camera?this.orthographicCamera:this.camera}toCameraTop(){const e=this.camera.position.distanceTo(this.controls.target);this.camera.position.copy(new d.Vector3(0,e+this.controls.target.y,0))}toCameraRight(){const e=this.camera.position.distanceTo(this.controls.target);this.camera.position.copy(new d.Vector3(0,this.controls.target.y,e))}toCameraFace(){const e=this.camera.position.distanceTo(this.controls.target);this.camera.position.copy(new d.Vector3(e,this.controls.target.y,0))}async generateBVH(){this.pathTracer.pausePathTracing=!1,this.amr.slots.forEach(e=>e.hide()),this.amr&&(this.amr.opacityCache=this.amr.bodyOpacity,this.amr.bodyOpacity=1,this.overlayScene.clear(),this.amr.logos.forEach(e=>{const t=new d.Group;e.target.updateMatrixWorld(!0),t.applyMatrix4(e.target.matrixWorld),t.add(e.target),this.overlayScene.add(t)})),this.usePathTracing=!0,this.pathTracer.setScene(this.scene,this.mainCamera)}async download(e=!1){if(e&&!this.usePathTracing){const t=this._amrRender.width,i=this._amrRender.height,s=new Uint8Array(t*i*4);this.renderer.setRenderTarget(this._amrRender),this.renderer.readRenderTargetPixels(this._amrRender,0,0,t,i,s),this.renderer.setRenderTarget(null);const a=document.createElement("canvas");a.width=t,a.height=i;const o=a.getContext("2d"),c=new ImageData(t,i);for(let u=0;u<i;u++)for(let f=0;f<t;f++){const p=((i-u-1)*t+f)*4,r=(u*t+f)*4;c.data[r]=s[p],c.data[r+1]=s[p+1],c.data[r+2]=s[p+2],c.data[r+3]=s[p+3]}return o.putImageData(c,0,0),a.toDataURL("image/png")}else return new Promise((t,i)=>{this._uiHiddenTime=this._clock.getElapsedTime(),this.hideAmrUI();const s=this.scene.background;this.scene.background=null,setTimeout(()=>{const a=this.renderer.domElement.toDataURL("image/png");return this.scene.background=s,t(a)},this.fpsAverage)})}async captureTriViews(e){var o;const t=(e==null?void 0:e.subject)??this._container;(o=this._progressShadow)==null||o.visible;const i=this.scene.background,s=this.showSize;return new Nr({renderer:this.renderer,scene:this.scene,overlayScene:this.overlayScene,subject:t,onBeforeCapture:()=>{this.scene.background=null,this.hideAmrUI(),this.showSize=!1,this.usePathTracing&&(this.usePathTracing=!1),this._progressShadow.visible=!1},onAfterCapture:()=>{this.scene.background=i,this.showAmrUI(),this.showSize=s,this._progressShadow.visible=!0}}).capture(e)}clearAMR(){xe(this.overlayScene),this.amr.clean(),this.usePathTracing=!1}async exportAMR(){const e=this._container.clone(!0);return e.traverse(t=>{t.dispose&&(t.dispose(),t.removeFromParent())}),await Pr.parseAsync(e,{onlyVisible:!0,binary:!0})}async addAMR(e,t=""){this.amr.init(this),await this.amr.load(e,t),this._progressShadow.clear(),this.amr.addEventListener("fork-height-change",this.debounceForkHeightChange),this.amr.addEventListener("shape-key-changed",(i,s)=>{this.pathTracer.reset(),this.sampleCount=0,this.pathTracer.setScene(this.scene,this.camera),this.overlayScene.traverse(a=>{if(!Object.keys(a.morphTargetDictionary||{}).includes(i))return;let o=s;a.userData[`origin_${i}`]&&(o-=a.userData[`origin_${i}`]);const c=a.morphTargetDictionary[i];a.morphTargetInfluences&&(a.morphTargetInfluences[c]=o),a instanceof d.Mesh&&a.geometry.translate(0,0,1e-5)}),["width","length"].includes(i)&&(this._progressShadow.clear(),this._progressShadow.recalculate())})}select(e){typeof e=="string"||(Array.isArray(e)?this._outlinePass.selectedObjects=[...e]:this._outlinePass.selectedObjects=[e])}appendTo(e){e.append(this.renderer.domElement),e.append(this.stats.dom),e.append(this.css2dRenderer.domElement),this.props.isMobile&&(e.classList.add("is-mobile"),e.style.cssText=`
3795
+ }`),this.camera.position.set(10,-10,5),this.camera.lookAt(new d.Vector3);const{tiles:t}=Ha();this.pathTracer=new ta(this.renderer),this.pathTracer.filterGlossyFactor=.6;let i=window.devicePixelRatio;i<2&&(i=2),this.pathTracer.renderScale=this.props.isMobile?1:i,this.pathTracer.bounces=this.props.isMobile?8:10,this.pathTracer.transmissiveBounces=this.props.isMobile?1:3,this.pathTracer.tiles.set(t,t),this.pathTracer.fadeDuration=0;const s=new uc(e.workerUrl),a=typeof navigator<"u"?navigator.hardwareConcurrency:4;s.maxWorkerCount=a,this.pathTracer.setBVHWorker(s),this.orthographicCamera.left=-20,this.orthographicCamera.right=20,this.orthographicCamera.top=-20,this.orthographicCamera.bottom=20,this._lastTarget=this.controls.target.clone();const o=()=>{let u=this._lastTarget.x,f=this._lastTarget.y;this.controls.target.x=u,this.controls.target.y=f};this.controls.addEventListener("change",()=>{var u;this.sampleCount=0,o(),this._uiHiddenTime=this._clock.getElapsedTime(),this.orthographicCamera.position.copy(this.camera.position),this.orthographicCamera.lookAt(this.controls.target),this.usePathTracing&&(this.pathTracer.pausePathTracing=!1,(u=this.pathTracer)==null||u.updateCamera()),this._updateCamera(),!(Math.abs(this.camera.position.x)<.001||Math.abs(this.camera.position.y)<.001)&&(this._axisMoving||(this.mainCamera=this.camera,this.usePathTracing&&this.generateBVH().then()))}),this._mainCamera=this.camera,this._composer=new nn.EffectComposer(this.renderer),this._composer.setPixelRatio(window.devicePixelRatio);const c=new gs.RenderPass(this.scene,this.camera);this._composer.addPass(c),this._composer.addPass(new rn.OutputPass),this._outlinePass=new vs.OutlinePass(new d.Vector2(window.innerWidth,window.innerHeight),this.scene,this.camera),this._outlinePass.visibleEdgeColor.set(26367),this._outlinePass.edgeThickness=.5,this._outlinePass.hiddenEdgeColor.set(26367),this._outlinePass.edgeStrength=3,this._outlinePass.edgeGlow=0,this._composer.addPass(this._outlinePass),this._outlinePassError=new vs.OutlinePass(new d.Vector2(window.innerWidth,window.innerHeight),this.scene,this.camera),this._outlinePassError.visibleEdgeColor.set(16711680),this._outlinePassError.edgeThickness=.5,this._outlinePassError.hiddenEdgeColor.set(16711680),this._outlinePassError.edgeStrength=3,this._outlinePassError.edgeGlow=0,this._composer.addPass(this._outlinePassError),this._bloomPass=new tn.UnrealBloomPass(new d.Vector2(window.innerWidth,window.innerHeight),.1,.1,.2),this._bloomPass.enabled=!1,this._bloomPass.renderToScreen=!1,this._composer.addPass(this._bloomPass),this._composer.renderTarget1.texture.colorSpace=d.SRGBColorSpace,this._composer.renderTarget2.texture.colorSpace=d.SRGBColorSpace,this._fxaaPass=new $r.ShaderPass(en.FXAAShader),this._composer.addPass(this._fxaaPass),this._progressShadow=new fc(this.renderer,this.scene,{size:8,lightCount:e.isMobile?6:12,frames:e.isMobile?80:120,lightRadius:8,ambientWeight:.8}),this._progressShadow.lightOrigin.position.set(3,2.5,6),this._progressShadow.visible=!1,this._container.add(this.amr),this.scene.add(this._container),this.ticker(),this._loadEnv(),this._initEvents(),this.scene.add(this._cameraPositionUI),this._ground.rotateX(-Math.PI/2),this.scene.add(this._ground),(typeof e.useAxisBall!="boolean"||e.useAxisBall)&&(this._controlsGizmo=new hc(this.controls,{size:160,padding:12,offset:e.axisBallOffset||new d.Vector2(10,10),fontSize:17,bubbleSizePrimary:18,bubbleSizeSecondary:14}),this._controlsGizmo.addListener("axis-select-start",()=>{this._axisMoving=!0,this.mainCamera=this.orthographicCamera,this.usePathTracing&&this.generateBVH().then()}),this._controlsGizmo.addListener("axis-select-end",()=>{this._axisMoving=!1}))}get usePathTracing(){return this._usePathTracing}_clearAmrContent(){const e=this.renderer.getRenderTarget();this.renderer.setRenderTarget(this._amrRender),this.renderer.setClearColor(0,0),this.renderer.clear(!0,!0,!0),this.renderer.setRenderTarget(e)}get shadowMode(){return this._shadowMode}set shadowMode(e){e?(this._progressShadow.visible=!1,this.amr.bodyOpacity=.2):(this._progressShadow.visible=!0,this.amr.bodyOpacity=1,this._progressShadow.isFinished||this._progressShadow.recalculate().then()),this._shadowMode=e}set usePathTracing(e){this._clearAmrContent(),e?(this.scene.add(this.light),this.renderer.toneMappingExposure=1.8,this.overlayScene.add(this._progressShadow.shadowCatcherMesh),this.amr&&(this.amr.bodyOpacity=1),this.hideAmrUI(),this.pathTracer.renderToCanvas=!0,this.scene.background=null):(this.light.removeFromParent(),this.renderer.toneMappingExposure=1.4,this.scene.add(this._progressShadow.shadowCatcherMesh),this.pathTracer.renderToCanvas=!1,this.amr.logos.forEach(t=>{var i;(i=t.parent)==null||i.add(t.target)}),this.showAmrUI(),this.amr&&this.amr.opacityCache!==void 0?(this.amr.bodyOpacity=this.amr.opacityCache,this.amr.opacityCache=void 0):this.amr&&(this.amr.bodyOpacity=1),this.pathTracer.reset(),this._ground.visible=!1,this.scene.background=this.scene.environment),this._usePathTracing=e,this.controls.dampingFactor=e?1:lr,this.sampleCount=0}get fpsAverage(){return Ir(this._fpsCache)}get mainCamera(){return this._mainCamera}set mainCamera(e){this._mainCamera=e,this._composer.passes.forEach(t=>{t instanceof gs.RenderPass&&(t.camera=e)}),e instanceof d.OrthographicCamera?this.scene.background=null:this.scene.background=this.scene.environment}showState(){this.stats.dom.style.display="block"}hideState(){this.stats.dom.style.display="none"}hideAmrUI(e=!0,t=!0){this.shadowMode||this.amr.slots.forEach(i=>i.hide()),this.amr.sizeBox.hide(e),this.amr.controllers.forEach(i=>i.hide()),t&&this.amr.goods.forEach(i=>i.hide())}showAmrUI(e=!0){this.showSlots&&this.amr.slots.forEach(t=>t.show()),this.showSize&&this.amr.sizeBox.show(e),this.showControls&&this.amr.controllers.forEach(t=>t.show()),this.amr.goods.forEach(t=>t.show())}get showSlots(){return this._showSlots}set showSlots(e){this._showSlots=e,this.amr.slots.forEach(t=>e?t.show():t.hide())}get showSize(){return this._showSize}set showSize(e){this._showSize=e,e?this.amr.sizeBox.show(!0):this.amr.sizeBox.hide(!0)}get showControls(){return this._showControls}set showControls(e){this._showControls=e,this.amr.controllers.forEach(t=>e?t.show():t.hide())}_updateCamera(){const e=this.mainCamera.position.distanceTo(this.controls.target),t=2*Math.tan(this.camera.fov*.5*Math.PI/180)*e,i=this.size.x/this.size.y;this.orthographicCamera.left=-t*i/2,this.orthographicCamera.right=t*i/2,this.orthographicCamera.top=t/2,this.orthographicCamera.bottom=-t/2,this.orthographicCamera.updateProjectionMatrix()}_loadEnv(){new Jr.HDRLoader().load(gc,t=>{t.mapping=d.EquirectangularReflectionMapping,this._usePathTracing||(this.scene.background=t,this.scene.backgroundBlurriness=1,this.scene.backgroundIntensity=1,this.scene.backgroundRotation=new d.Euler(Math.PI/2,0,Math.PI*.98*.8),this.scene.environment=t,this.overlayScene.environment=t,this.scene.environmentRotation=this.scene.backgroundRotation,this.overlayScene.environmentRotation=this.scene.environmentRotation,this.scene.environmentIntensity=1.4,this.overlayScene.environmentIntensity=this.scene.environmentIntensity),this.pathTracer.updateEnvironment()},()=>{},()=>{})}_initEvents(){window.addEventListener("drag",this._drag),window.addEventListener("dragend",this._dragend),document.addEventListener("wheel",this._detectTrackpad),window.addEventListener("pointermove",this._pointermove),this.renderer.domElement.addEventListener("pointerdown",this._pointerdown)}switchCamera(){this.mainCamera=this.mainCamera===this.camera?this.orthographicCamera:this.camera}toCameraTop(){const e=this.camera.position.distanceTo(this.controls.target);this.camera.position.copy(new d.Vector3(0,e+this.controls.target.y,0))}toCameraRight(){const e=this.camera.position.distanceTo(this.controls.target);this.camera.position.copy(new d.Vector3(0,this.controls.target.y,e))}toCameraFace(){const e=this.camera.position.distanceTo(this.controls.target);this.camera.position.copy(new d.Vector3(e,this.controls.target.y,0))}async generateBVH(){this.pathTracer.pausePathTracing=!1,this.amr.slots.forEach(e=>e.hide()),this.amr&&(this.amr.opacityCache=this.amr.bodyOpacity,this.amr.bodyOpacity=1,this.overlayScene.clear(),this.amr.logos.forEach(e=>{const t=new d.Group;e.target.updateMatrixWorld(!0),t.applyMatrix4(e.target.matrixWorld),t.add(e.target),this.overlayScene.add(t)})),this.usePathTracing=!0,this.pathTracer.setScene(this.scene,this.mainCamera)}async download(e=!1){if(e&&!this.usePathTracing){const t=this._amrRender.width,i=this._amrRender.height,s=new Uint8Array(t*i*4);this.renderer.setRenderTarget(this._amrRender),this.renderer.readRenderTargetPixels(this._amrRender,0,0,t,i,s),this.renderer.setRenderTarget(null);const a=document.createElement("canvas");a.width=t,a.height=i;const o=a.getContext("2d"),c=new ImageData(t,i);for(let u=0;u<i;u++)for(let f=0;f<t;f++){const p=((i-u-1)*t+f)*4,r=(u*t+f)*4;c.data[r]=s[p],c.data[r+1]=s[p+1],c.data[r+2]=s[p+2],c.data[r+3]=s[p+3]}return o.putImageData(c,0,0),a.toDataURL("image/png")}else return new Promise((t,i)=>{this._uiHiddenTime=this._clock.getElapsedTime(),this.hideAmrUI();const s=this.scene.background;this.scene.background=null,setTimeout(()=>{const a=this.renderer.domElement.toDataURL("image/png");return this.scene.background=s,t(a)},this.fpsAverage)})}async captureTriViews(e){var o;const t=(e==null?void 0:e.subject)??this._container;(o=this._progressShadow)==null||o.visible;const i=this.scene.background,s=this.showSize;return new Wr({renderer:this.renderer,scene:this.scene,overlayScene:this.overlayScene,subject:t,onBeforeCapture:()=>{this.scene.background=null,this.hideAmrUI(),this.showSize=!1,this.usePathTracing&&(this.usePathTracing=!1),this._progressShadow.visible=!1},onAfterCapture:()=>{this.scene.background=i,this.showAmrUI(),this.showSize=s,this._progressShadow.visible=!0}}).capture(e)}clearAMR(){xe(this.overlayScene),this.amr.clean(),this.usePathTracing=!1}async exportAMR(){const e=this._container.clone(!0);return e.traverse(t=>{t.dispose&&(t.dispose(),t.removeFromParent())}),await Dr.parseAsync(e,{onlyVisible:!0,binary:!0})}async addAMR(e,t=""){this.amr.init(this),await this.amr.load(e,t),this._progressShadow.clear(),this.amr.addEventListener("fork-height-change",this.debounceForkHeightChange),this.amr.addEventListener("shape-key-changed",(i,s)=>{this.pathTracer.reset(),this.sampleCount=0,this.pathTracer.setScene(this.scene,this.camera),this.overlayScene.traverse(a=>{if(!Object.keys(a.morphTargetDictionary||{}).includes(i))return;let o=s;a.userData[`origin_${i}`]&&(o-=a.userData[`origin_${i}`]);const c=a.morphTargetDictionary[i];a.morphTargetInfluences&&(a.morphTargetInfluences[c]=o),a instanceof d.Mesh&&a.geometry.translate(0,0,1e-5)}),["width","length"].includes(i)&&(this._progressShadow.clear(),this._progressShadow.recalculate())})}select(e){typeof e=="string"||(Array.isArray(e)?this._outlinePass.selectedObjects=[...e]:this._outlinePass.selectedObjects=[e])}appendTo(e){e.append(this.renderer.domElement),e.append(this.stats.dom),e.append(this.css2dRenderer.domElement),this.props.isMobile&&(e.classList.add("is-mobile"),e.style.cssText=`
3796
3796
  -webkit-user-select: none;
3797
3797
  user-select: none;
3798
3798
  touch-action: none;
3799
3799
  -webkit-touch-callout: none;
3800
- `),this._controlsGizmo&&this._controlsGizmo.appendTo(e),this.stats.dom.style.bottom="0",this.stats.dom.style.top="auto",this.resize(),this._resizeObserver=new ResizeObserver(this.resize.bind(this)),this._resizeObserver.observe(e)}add(e){this._container.add(e)}updatePosition(){}removeFromParent(){var t;const e=this.renderer.domElement.parentElement;e&&((t=this._resizeObserver)==null||t.unobserve(e),e.removeChild(this.renderer.domElement))}clean(){this.amr.clean(),this._progressShadow.clear()}destroy(){var t,i,s;this._destroyed=!0,this._rafId!==null&&(cancelAnimationFrame(this._rafId),this._rafId=null),this._clock.stop(),(t=this._controlsGizmo)==null||t.destroy(),this.amr.destroy(),this.amr.removeFromParent(),this._progressShadow.destroy(),ye.removeAll(),this.stats.dom.remove(),this._emitter.removeAllListeners(),(i=this._fitAnimation)==null||i.stop(),window.removeEventListener("drag",this._drag),document.removeEventListener("wheel",this._detectTrackpad),window.removeEventListener("pointermove",this._pointermove),this.renderer.domElement.removeEventListener("pointerdown",this._pointerdown);const e=this.renderer.domElement.parentElement;e&&((s=this._resizeObserver)==null||s.unobserve(e)),this.controls.dispose(),this.renderer.domElement.remove(),this.renderer.dispose(),this._composer.dispose(),xe(this.scene),this.scene.clear()}}class Nr{constructor(e){this.deps=e,this.canvas=null,this.pixelBuffer=null,this.orthoCamera=new d.OrthographicCamera(-1,1,1,-1,.1,1e3),this.orthoCamera.position.set(0,0,5),this.perspectiveCamera=new d.PerspectiveCamera(45,1,.1,2e3)}async capture(e){var g,_,m,v,y,x;const t=this.deps.renderer,i=(e==null?void 0:e.subject)??this.deps.subject;if(!i)throw new Error("TriViewCapture: subject is required.");const s=new d.Vector2;t.getSize(s);const a=((g=e==null?void 0:e.size)==null?void 0:g.width)??Math.round(s.x),o=((_=e==null?void 0:e.size)==null?void 0:_.height)??Math.round(s.y),c=(e==null?void 0:e.margin)??.15,u=(e==null?void 0:e.includeOverlay)??!1,f=a/o||1,p=this.resolveViews(e==null?void 0:e.views),r=new d.WebGLRenderTarget(a,o,{format:d.RGBAFormat,type:d.UnsignedByteType});r.texture.colorSpace=d.SRGBColorSpace,r.texture.generateMipmaps=!1,r.depthBuffer=!0;const l=this.storeRendererState(t),h={};try{(v=(m=this.deps).onBeforeCapture)==null||v.call(m);const w=this.computeBounds(i);this.applyRendererState(t,a,o,e==null?void 0:e.backgroundColor);for(const b of p){const A=this.configureCamera(w,b,f,c,a,o);t.setRenderTarget(r),t.clear(!0,!0,!0),t.render(this.deps.scene,A),u&&this.deps.overlayScene&&(t.clearDepth(),t.render(this.deps.overlayScene,A));const T=this.readPixels(t,r,a,o);h[b.key]=T}}finally{r.dispose(),this.restoreRendererState(t,l),(x=(y=this.deps).onAfterCapture)==null||x.call(y)}return h}resolveViews(e){return e&&e.length?e.map(t=>({key:t.key,direction:t.direction.clone(),up:t.up.clone(),plane:t.plane})):[{key:"top",direction:new d.Vector3(0,0,1),up:new d.Vector3(0,1,0),plane:{width:"x",height:"y",depth:"z"}},{key:"front",direction:new d.Vector3(0,-1,0),up:new d.Vector3(0,0,1),plane:{width:"x",height:"z",depth:"y"}},{key:"side",direction:new d.Vector3(1,0,0),up:new d.Vector3(0,0,1),plane:{width:"y",height:"z",depth:"x"}},{key:"perspective",direction:new d.Vector3(1,1,1),up:new d.Vector3(0,0,1),plane:{width:"x",height:"z",depth:"y"},mode:"perspective",fov:39.6}]}computeBounds(e){const t=new d.Box3,i=new d.Box3,s=new d.Vector3,a=new d.Vector3,o=new d.Sphere;return e.updateMatrixWorld(!0),e.traverse(c=>{if(!c.visible)return;const f=c.geometry;if(!f)return;f.boundingBox||f.computeBoundingBox();const p=f.boundingBox;p&&(i.copy(p).applyMatrix4(c.matrixWorld),t.union(i))}),t.isEmpty()?(t.setFromCenterAndSize(s,new d.Vector3(.001,.001,.001)),a.set(.001,.001,.001),o.center.copy(s),o.radius=.001):(t.getCenter(s),t.getSize(a),t.getBoundingSphere(o)),(!Number.isFinite(o.radius)||o.radius<=0)&&(o.radius=Math.max(a.length()*.5,.001)),{box:t,center:s,size:a,sphere:o}}configureCamera(e,t,i,s,a,o){const c=t.direction.clone().normalize();c.lengthSq()===0&&c.set(0,0,1);const u=t.up.clone().normalize();if(Math.abs(u.dot(c))>.999&&(u.set(0,0,1),Math.abs(u.dot(c))>.999&&u.set(0,1,0)),(t.mode??"orthographic")==="perspective"){const w=this.perspectiveCamera,b=t.fov??45,A=d.MathUtils.degToRad(b),T=Math.max(Math.tan(A/2),1e-4),I=Math.max(T*(i||1),1e-4),C=this.getPerspectiveDirection(t,e.size).normalize(),P=new d.Vector3().crossVectors(C,u).normalize();P.lengthSq()<1e-6&&P.set(1,0,0);const D=new d.Vector3().crossVectors(P,C).normalize(),S=Math.max(e.size.x*.5,1e-4),M=Math.max(e.size.y*.5,1e-4),R=Math.max(e.size.z*.5,1e-4),E=[new d.Vector3(-S,-M,-R),new d.Vector3(-S,-M,R),new d.Vector3(-S,M,-R),new d.Vector3(-S,M,R),new d.Vector3(S,-M,-R),new d.Vector3(S,-M,R),new d.Vector3(S,M,-R),new d.Vector3(S,M,R)];let F=0,O=-1/0;for(const j of E){const Y=P.dot(j),pe=D.dot(j),ht=C.dot(j);O=Math.max(O,ht);const di=ht+Math.abs(Y)/I,ft=ht+Math.abs(pe)/T;F=Math.max(F,di,ft)}F=Math.max(F,O+.1);const H=F*(1+s);let W=1/0;for(const j of E){const Y=C.dot(j),pe=H-Y;pe>.001&&(W=Math.min(W,pe))}return w.fov=b,w.aspect=i||a/Math.max(o,1),w.near=Math.max(.1,Number.isFinite(W)?W*.5:H*.1),w.far=Math.max(w.near+1,H+e.sphere.radius*3),w.position.copy(e.center).add(C.clone().multiplyScalar(H)),w.up.copy(D),w.lookAt(e.center),w.updateProjectionMatrix(),w.updateMatrixWorld(!0),w}const p=this.orthoCamera,r=e.size,l=e.center,h=Math.max(r[t.plane.width]*.5,.01),g=Math.max(r[t.plane.height]*.5,.01),_=Math.max(r[t.plane.depth]*.5,.01);let m=h*(1+s),v=g*(1+s);m/i>v?v=m/i:m=v*i;const y=_*(1+s)+Math.max(m,v),x=l.clone().add(c.multiplyScalar(y));return p.left=-m,p.right=m,p.top=v,p.bottom=-v,p.near=.1,p.far=y*4,p.zoom=1,p.position.copy(x),p.up.copy(u),p.lookAt(l),p.updateProjectionMatrix(),p.updateMatrixWorld(!0),p}getPerspectiveDirection(e,t){const i=e.direction.clone();i.lengthSq()===0&&i.set(1,1,1);const s=new d.Vector3(Math.abs(i.x)||1,Math.abs(i.y)||1,Math.abs(i.z)||1),a=new d.Vector3(Math.sign(i.x||1),Math.sign(i.y||1),Math.sign(i.z||1)),o=.25,c=new d.Vector3(Math.max(o,s.x)*Math.max(t.x,.001),Math.max(o,s.y)*Math.max(t.y,.001),0),u=Math.max((t.x+t.y)*.5,.001),f=Math.max(t.z,.001),p=Math.max(o,s.z),r=f*.5+u*.5;return c.z=p*r,c.multiply(a),c}storeRendererState(e){const t=new d.Vector2;e.getSize(t);const i=new d.Vector4;e.getViewport(i);const s=new d.Vector4;e.getScissor(s);const a=e.getClearColor(new d.Color),o=e.getClearAlpha();return{size:t,pixelRatio:e.getPixelRatio(),viewport:i,scissor:s,scissorTest:e.getScissorTest(),autoClear:e.autoClear,target:e.getRenderTarget(),clearColor:a,clearAlpha:o}}applyRendererState(e,t,i,s){if(e.setPixelRatio(1),e.setSize(t,i,!1),e.setViewport(0,0,t,i),e.setScissor(0,0,t,i),e.setScissorTest(!1),e.autoClear=!0,s!==void 0)if(s===null){const a=e.getClearColor(new d.Color);e.setClearColor(a,0)}else s instanceof d.Color?e.setClearColor(s,1):e.setClearColor(new d.Color(s),1);else{const a=e.getClearColor(new d.Color);e.setClearColor(a,0)}}restoreRendererState(e,t){e.setPixelRatio(t.pixelRatio),e.setSize(t.size.x,t.size.y,!1),e.setViewport(t.viewport.x,t.viewport.y,t.viewport.z,t.viewport.w),e.setScissor(t.scissor.x,t.scissor.y,t.scissor.z,t.scissor.w),e.setScissorTest(t.scissorTest),e.autoClear=t.autoClear,e.setRenderTarget(t.target),e.setClearColor(t.clearColor,t.clearAlpha)}readPixels(e,t,i,s){const a=i*s*4;(!this.pixelBuffer||this.pixelBuffer.length!==a)&&(this.pixelBuffer=new Uint8Array(a)),e.readRenderTargetPixels(t,0,0,i,s,this.pixelBuffer);const o=this.ensureCanvas(i,s),c=o.getContext("2d");if(!c)throw new Error("TriViewCapture: failed to get 2D context.");const u=c.createImageData(i,s),f=u.data,p=this.pixelBuffer;for(let r=0;r<s;r+=1){const h=(s-r-1)*i*4,g=r*i*4;f.set(p.subarray(h,h+i*4),g)}return c.putImageData(u,0,0),o.toDataURL("image/png")}ensureCanvas(e,t){if(typeof document>"u")throw new Error("TriViewCapture: document is not available in this environment.");return this.canvas||(this.canvas=document.createElement("canvas")),(this.canvas.width!==e||this.canvas.height!==t)&&(this.canvas.width=e,this.canvas.height=t),this.canvas}}const bc="shop-components",Ac="0.3.6",Tc="Shop components",Sc="dist/shop-components.umd.js",Mc="dist/shop-components.mjs",Cc="dist/main.d.ts",Ic={dts:"tsc --emitDeclarationOnly & tsc & storybook build -o dist",dev:"vite dev",build:"vite build",v:"auto-changelog -p && git add CHANGELOG.md"},Rc=["dist","package.json"],Pc=[],Dc="machengda<machengda@seer-group.com>",Lc="ISC",Ec={"@needle-tools/gltf-progressive":"^3.3.5","auto-changelog":"^2.4.0",vite:"5.1.6","vite-plugin-dts":"^3.7.3"},Fc={"string-width":"4.2.3"},Bc={"@nodetoy/three-nodetoy":"^0.1.36","@tweakpane/core":"^2.0.3","@tweenjs/tween.js":"^23.1.2","@types/bezier-js":"^4.1.1","@types/howler":"^2.2.11","@types/three":"0.180.0","bezier-js":"^6.1.4",eventemitter3:"^5.0.1",howler:"^2.2.4","stats-fps.js":"0.0.6",stylus:"^0.63.0",terser:"^5.44.0",three:"^0.180.0","three-gpu-pathtracer":"^0.0.23","three-mesh-bvh":"^0.7.5","troika-three-text":"^0.49.1",tweakpane:"^4.0.3"},kc={name:bc,version:Ac,description:Tc,main:Sc,module:Mc,types:Cc,scripts:Ic,files:Rc,keywords:Pc,author:Dc,license:Lc,devDependencies:Ec,resolutions:Fc,dependencies:Bc};function lr(){const n="Nebular Engin",e=kc.version,t=`%c ${n} %c v${e} `;console.log(t,"background:#111827;color:#ffffff;padding:4px 10px;border-radius:4px 0 0 4px;font-weight:700;","background:#10B981;color:#ffffff;padding:4px 10px;border-radius:0 4px 4px 0;font-weight:700;")}const cr="__SHOP_COMPONENTS_BANNER_PRINTED__";try{const n=globalThis;n[cr]||(n[cr]=!0,lr())}catch{lr()}exports.Amr=Er;exports.Logo=Gi;exports.SGLBLoader=ni;exports.SLOT_EVENTS=q;exports.Scene3D=wc;exports.Skin=es;exports.Slot=Wi;exports.SlotState=Hr;exports.TriViewCapture=Nr;exports.arrayBufferToUrl=Hi;exports.calculateArrayAverage=Cr;exports.calculateFocalLength=Oa;exports.createSGLBFile=Ya;exports.downloadBlob=ka;exports.dracoExporter=ja;exports.font=_c;exports.gltfExporter=Pr;exports.gltfLoader=lt;exports.imageBitmapToUrl=Ni;exports.isAppleDevice=Ir;exports.textureLoader=us;
3800
+ `),this._controlsGizmo&&this._controlsGizmo.appendTo(e),this.stats.dom.style.bottom="0",this.stats.dom.style.top="auto",this.resize(),this._resizeObserver=new ResizeObserver(this.resize.bind(this)),this._resizeObserver.observe(e)}add(e){this._container.add(e)}updatePosition(){}removeFromParent(){var t;const e=this.renderer.domElement.parentElement;e&&((t=this._resizeObserver)==null||t.unobserve(e),e.removeChild(this.renderer.domElement))}clean(){this.amr.clean(),this._progressShadow.clear()}destroy(){var t,i,s;this._destroyed=!0,this._rafId!==null&&(cancelAnimationFrame(this._rafId),this._rafId=null),this._clock.stop(),(t=this._controlsGizmo)==null||t.destroy(),this.amr.destroy(),this.amr.removeFromParent(),this._progressShadow.destroy(),ye.removeAll(),this.stats.dom.remove(),this._emitter.removeAllListeners(),(i=this._fitAnimation)==null||i.stop(),window.removeEventListener("drag",this._drag),document.removeEventListener("wheel",this._detectTrackpad),window.removeEventListener("pointermove",this._pointermove),this.renderer.domElement.removeEventListener("pointerdown",this._pointerdown);const e=this.renderer.domElement.parentElement;e&&((s=this._resizeObserver)==null||s.unobserve(e)),this.controls.dispose(),this.renderer.domElement.remove(),this.renderer.dispose(),this._composer.dispose(),xe(this.scene),this.scene.clear()}}class Wr{constructor(e){this.deps=e,this.canvas=null,this.pixelBuffer=null,this.orthoCamera=new d.OrthographicCamera(-1,1,1,-1,.1,1e3),this.orthoCamera.position.set(0,0,5),this.perspectiveCamera=new d.PerspectiveCamera(45,1,.1,2e3)}async capture(e){var g,_,m,v,y,x;const t=this.deps.renderer,i=(e==null?void 0:e.subject)??this.deps.subject;if(!i)throw new Error("TriViewCapture: subject is required.");const s=new d.Vector2;t.getSize(s);const a=((g=e==null?void 0:e.size)==null?void 0:g.width)??Math.round(s.x),o=((_=e==null?void 0:e.size)==null?void 0:_.height)??Math.round(s.y),c=(e==null?void 0:e.margin)??.15,u=(e==null?void 0:e.includeOverlay)??!1,f=a/o||1,p=this.resolveViews(e==null?void 0:e.views),r=new d.WebGLRenderTarget(a,o,{format:d.RGBAFormat,type:d.UnsignedByteType});r.texture.colorSpace=d.SRGBColorSpace,r.texture.generateMipmaps=!1,r.depthBuffer=!0;const l=this.storeRendererState(t),h={};try{(v=(m=this.deps).onBeforeCapture)==null||v.call(m);const w=this.computeBounds(i);this.applyRendererState(t,a,o,e==null?void 0:e.backgroundColor);for(const b of p){const A=this.configureCamera(w,b,f,c,a,o);t.setRenderTarget(r),t.clear(!0,!0,!0),t.render(this.deps.scene,A),u&&this.deps.overlayScene&&(t.clearDepth(),t.render(this.deps.overlayScene,A));const T=this.readPixels(t,r,a,o);h[b.key]=T}}finally{r.dispose(),this.restoreRendererState(t,l),(x=(y=this.deps).onAfterCapture)==null||x.call(y)}return h}resolveViews(e){return e&&e.length?e.map(t=>({key:t.key,direction:t.direction.clone(),up:t.up.clone(),plane:t.plane})):[{key:"top",direction:new d.Vector3(0,0,1),up:new d.Vector3(0,1,0),plane:{width:"x",height:"y",depth:"z"}},{key:"front",direction:new d.Vector3(0,-1,0),up:new d.Vector3(0,0,1),plane:{width:"x",height:"z",depth:"y"}},{key:"side",direction:new d.Vector3(1,0,0),up:new d.Vector3(0,0,1),plane:{width:"y",height:"z",depth:"x"}},{key:"perspective",direction:new d.Vector3(1,1,1),up:new d.Vector3(0,0,1),plane:{width:"x",height:"z",depth:"y"},mode:"perspective",fov:39.6}]}computeBounds(e){const t=new d.Box3,i=new d.Box3,s=new d.Vector3,a=new d.Vector3,o=new d.Sphere;return e.updateMatrixWorld(!0),e.traverse(c=>{if(!c.visible)return;const f=c.geometry;if(!f)return;f.boundingBox||f.computeBoundingBox();const p=f.boundingBox;p&&(i.copy(p).applyMatrix4(c.matrixWorld),t.union(i))}),t.isEmpty()?(t.setFromCenterAndSize(s,new d.Vector3(.001,.001,.001)),a.set(.001,.001,.001),o.center.copy(s),o.radius=.001):(t.getCenter(s),t.getSize(a),t.getBoundingSphere(o)),(!Number.isFinite(o.radius)||o.radius<=0)&&(o.radius=Math.max(a.length()*.5,.001)),{box:t,center:s,size:a,sphere:o}}configureCamera(e,t,i,s,a,o){const c=t.direction.clone().normalize();c.lengthSq()===0&&c.set(0,0,1);const u=t.up.clone().normalize();if(Math.abs(u.dot(c))>.999&&(u.set(0,0,1),Math.abs(u.dot(c))>.999&&u.set(0,1,0)),(t.mode??"orthographic")==="perspective"){const w=this.perspectiveCamera,b=t.fov??45,A=d.MathUtils.degToRad(b),T=Math.max(Math.tan(A/2),1e-4),I=Math.max(T*(i||1),1e-4),C=this.getPerspectiveDirection(t,e.size).normalize(),P=new d.Vector3().crossVectors(C,u).normalize();P.lengthSq()<1e-6&&P.set(1,0,0);const D=new d.Vector3().crossVectors(P,C).normalize(),S=Math.max(e.size.x*.5,1e-4),M=Math.max(e.size.y*.5,1e-4),R=Math.max(e.size.z*.5,1e-4),E=[new d.Vector3(-S,-M,-R),new d.Vector3(-S,-M,R),new d.Vector3(-S,M,-R),new d.Vector3(-S,M,R),new d.Vector3(S,-M,-R),new d.Vector3(S,-M,R),new d.Vector3(S,M,-R),new d.Vector3(S,M,R)];let F=0,O=-1/0;for(const j of E){const Y=P.dot(j),pe=D.dot(j),ht=C.dot(j);O=Math.max(O,ht);const di=ht+Math.abs(Y)/I,ft=ht+Math.abs(pe)/T;F=Math.max(F,di,ft)}F=Math.max(F,O+.1);const H=F*(1+s);let W=1/0;for(const j of E){const Y=C.dot(j),pe=H-Y;pe>.001&&(W=Math.min(W,pe))}return w.fov=b,w.aspect=i||a/Math.max(o,1),w.near=Math.max(.1,Number.isFinite(W)?W*.5:H*.1),w.far=Math.max(w.near+1,H+e.sphere.radius*3),w.position.copy(e.center).add(C.clone().multiplyScalar(H)),w.up.copy(D),w.lookAt(e.center),w.updateProjectionMatrix(),w.updateMatrixWorld(!0),w}const p=this.orthoCamera,r=e.size,l=e.center,h=Math.max(r[t.plane.width]*.5,.01),g=Math.max(r[t.plane.height]*.5,.01),_=Math.max(r[t.plane.depth]*.5,.01);let m=h*(1+s),v=g*(1+s);m/i>v?v=m/i:m=v*i;const y=_*(1+s)+Math.max(m,v),x=l.clone().add(c.multiplyScalar(y));return p.left=-m,p.right=m,p.top=v,p.bottom=-v,p.near=.1,p.far=y*4,p.zoom=1,p.position.copy(x),p.up.copy(u),p.lookAt(l),p.updateProjectionMatrix(),p.updateMatrixWorld(!0),p}getPerspectiveDirection(e,t){const i=e.direction.clone();i.lengthSq()===0&&i.set(1,1,1);const s=new d.Vector3(Math.abs(i.x)||1,Math.abs(i.y)||1,Math.abs(i.z)||1),a=new d.Vector3(Math.sign(i.x||1),Math.sign(i.y||1),Math.sign(i.z||1)),o=.25,c=new d.Vector3(Math.max(o,s.x)*Math.max(t.x,.001),Math.max(o,s.y)*Math.max(t.y,.001),0),u=Math.max((t.x+t.y)*.5,.001),f=Math.max(t.z,.001),p=Math.max(o,s.z),r=f*.5+u*.5;return c.z=p*r,c.multiply(a),c}storeRendererState(e){const t=new d.Vector2;e.getSize(t);const i=new d.Vector4;e.getViewport(i);const s=new d.Vector4;e.getScissor(s);const a=e.getClearColor(new d.Color),o=e.getClearAlpha();return{size:t,pixelRatio:e.getPixelRatio(),viewport:i,scissor:s,scissorTest:e.getScissorTest(),autoClear:e.autoClear,target:e.getRenderTarget(),clearColor:a,clearAlpha:o}}applyRendererState(e,t,i,s){if(e.setPixelRatio(1),e.setSize(t,i,!1),e.setViewport(0,0,t,i),e.setScissor(0,0,t,i),e.setScissorTest(!1),e.autoClear=!0,s!==void 0)if(s===null){const a=e.getClearColor(new d.Color);e.setClearColor(a,0)}else s instanceof d.Color?e.setClearColor(s,1):e.setClearColor(new d.Color(s),1);else{const a=e.getClearColor(new d.Color);e.setClearColor(a,0)}}restoreRendererState(e,t){e.setPixelRatio(t.pixelRatio),e.setSize(t.size.x,t.size.y,!1),e.setViewport(t.viewport.x,t.viewport.y,t.viewport.z,t.viewport.w),e.setScissor(t.scissor.x,t.scissor.y,t.scissor.z,t.scissor.w),e.setScissorTest(t.scissorTest),e.autoClear=t.autoClear,e.setRenderTarget(t.target),e.setClearColor(t.clearColor,t.clearAlpha)}readPixels(e,t,i,s){const a=i*s*4;(!this.pixelBuffer||this.pixelBuffer.length!==a)&&(this.pixelBuffer=new Uint8Array(a)),e.readRenderTargetPixels(t,0,0,i,s,this.pixelBuffer);const o=this.ensureCanvas(i,s),c=o.getContext("2d");if(!c)throw new Error("TriViewCapture: failed to get 2D context.");const u=c.createImageData(i,s),f=u.data,p=this.pixelBuffer;for(let r=0;r<s;r+=1){const h=(s-r-1)*i*4,g=r*i*4;f.set(p.subarray(h,h+i*4),g)}return c.putImageData(u,0,0),o.toDataURL("image/png")}ensureCanvas(e,t){if(typeof document>"u")throw new Error("TriViewCapture: document is not available in this environment.");return this.canvas||(this.canvas=document.createElement("canvas")),(this.canvas.width!==e||this.canvas.height!==t)&&(this.canvas.width=e,this.canvas.height=t),this.canvas}}const bc="shop-components",Ac="0.3.7",Tc="Shop components",Sc="dist/shop-components.umd.js",Mc="dist/shop-components.mjs",Cc="dist/main.d.ts",Ic={dts:"tsc --emitDeclarationOnly & tsc & storybook build -o dist",dev:"vite dev",build:"vite build",v:"auto-changelog -p && git add CHANGELOG.md"},Rc=["dist","package.json"],Pc=[],Dc="machengda<machengda@seer-group.com>",Lc="ISC",Ec={"@needle-tools/gltf-progressive":"^3.3.5","auto-changelog":"^2.4.0",vite:"5.1.6","vite-plugin-dts":"^3.7.3"},Fc={"string-width":"4.2.3"},Bc={"@nodetoy/three-nodetoy":"^0.1.36","@tweakpane/core":"^2.0.3","@tweenjs/tween.js":"^23.1.2","@types/bezier-js":"^4.1.1","@types/howler":"^2.2.11","@types/three":"0.180.0","bezier-js":"^6.1.4",eventemitter3:"^5.0.1",howler:"^2.2.4","stats-fps.js":"0.0.6",stylus:"^0.63.0",terser:"^5.44.0",three:"^0.180.0","three-gpu-pathtracer":"^0.0.23","three-mesh-bvh":"^0.7.5","troika-three-text":"^0.49.1",tweakpane:"^4.0.3"},kc={name:bc,version:Ac,description:Tc,main:Sc,module:Mc,types:Cc,scripts:Ic,files:Rc,keywords:Pc,author:Dc,license:Lc,devDependencies:Ec,resolutions:Fc,dependencies:Bc};function cr(){const n="Nebular Engin",e=kc.version,t=`%c ${n} %c v${e} `;console.log(t,"background:#111827;color:#ffffff;padding:4px 10px;border-radius:4px 0 0 4px;font-weight:700;","background:#10B981;color:#ffffff;padding:4px 10px;border-radius:0 4px 4px 0;font-weight:700;")}const ur="__SHOP_COMPONENTS_BANNER_PRINTED__";try{const n=globalThis;n[ur]||(n[ur]=!0,cr())}catch{cr()}exports.Amr=Fr;exports.Logo=qi;exports.SGLBLoader=ni;exports.SLOT_EVENTS=q;exports.Scene3D=wc;exports.Skin=ts;exports.Slot=Gi;exports.SlotState=Nr;exports.TriViewCapture=Wr;exports.arrayBufferToUrl=Ni;exports.calculateArrayAverage=Ir;exports.calculateFocalLength=Oa;exports.createSGLBFile=Ya;exports.downloadBlob=ka;exports.dracoExporter=ja;exports.font=_c;exports.gltfExporter=Dr;exports.gltfLoader=Oe;exports.imageBitmapToUrl=Wi;exports.isAppleDevice=Rr;exports.textureLoader=hs;