@jdultra/threedtiles 11.1.13 → 12.0.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
@@ -0,0 +1,21 @@
1
+ (function(S,g){typeof exports=="object"&&typeof module<"u"?g(exports,require("three")):typeof define=="function"&&define.amd?define(["exports","three"],g):g((S=typeof globalThis<"u"?globalThis:S||self).threedtiles={},S.THREE)})(this,function(S,g){"use strict";var Pa=Object.defineProperty;var Ha=(S,g,se)=>g in S?Pa(S,g,{enumerable:!0,configurable:!0,writable:!0,value:se}):S[g]=se;var UA=(S,g,se)=>Ha(S,typeof g!="symbol"?g+"":g,se);function se(r){const e=Object.create(null,{[Symbol.toStringTag]:{value:"Module"}});if(r){for(const A in r)if(A!=="default"){const a=Object.getOwnPropertyDescriptor(r,A);Object.defineProperty(e,A,a.get?a:{enumerable:!0,get:()=>r[A]})}}return e.default=r,Object.freeze(e)}const Q=se(g);class X{constructor(e){this.center=new g.Vector3(e[0],e[1],e[2]);var A=new g.Vector3(e[3],e[4],e[4]),a=new g.Vector3(e[6],e[7],e[8]),t=new g.Vector3(e[9],e[10],e[11]);this.halfWidth=A.length(),this.halfHeight=a.length(),this.halfDepth=t.length(),this.aabb=new g.Box3;const i=new g.Vector3,s=[-1,1];for(let n of s)for(let d of s)for(let o of s)i.copy(this.center).addScaledVector(A,n).addScaledVector(a,d).addScaledVector(t,o),this.aabb.expandByPoint(i);A.normalize(),a.normalize(),t.normalize(),this.sphere=new g.Sphere(this.center,Math.sqrt(this.halfWidth*this.halfWidth+this.halfHeight*this.halfHeight+this.halfDepth*this.halfDepth)),this.matrixToOBBCoordinateSystem=new g.Matrix3,this.matrixToOBBCoordinateSystem.set(A.x,A.y,A.z,a.x,a.y,a.z,t.x,t.y,t.z)}inFrustum(e){return e.intersectsSphere(this.sphere)}distanceToPoint(e){let A=e.clone();A.sub(this.center),A.applyMatrix3(this.matrixToOBBCoordinateSystem);let a=Math.max(0,Math.max(-this.halfWidth-A.x,A.x-this.halfWidth)),t=Math.max(0,Math.max(-this.halfHeight-A.y,A.y-this.halfHeight)),i=Math.max(0,Math.max(-this.halfDepth-A.z,A.z-this.halfDepth));return Math.sqrt(a*a+t*t+i*i)}}/**
2
+ * @copyright 2021 Aaron Zhao <yujianzhao2013@gmail.com>
3
+ * @license MIT
4
+ * Heap implementation using 1-d array
5
+ * Children is index of 2n + 1 and 2n + 2 where n is the parent index
6
+ * Parent is math.floor((m - 1) / 2) where m is is the child index
7
+ * @class Heap
8
+ */var NA=class{constructor(r,e){if(this._data=[],this._comparator=function(A,a){return A>=a},r!=null){if(!Array.isArray(r))throw Error("Constructor expects data to be an array");this._data=r}if(e!=null){if(typeof e!="function")throw Error("Constructor expects comparator to be a function");this._comparator=e}}peek(){return this.size()<1?null:this._data[0]}pop(){if(this.size()<1)return null;const r=this._data[0];return this.swap(this.size()-1,0),this._data.pop(),this.heapifyDown(0),r}replaceTop(r){if(this.size()<1)return null;const e=this._data[0];return this._data[0]=r,this.heapifyDown(0),e}push(r){this._data.push(r),this.heapifyUp(this._data.length-1)}size(){return this._data.length}swap(r,e){const A=this._data[r];this._data[r]=this._data[e],this._data[e]=A}heapifyUp(r){if(r===0)return;const e=Math.floor((r-1)/2);this._comparator(this._data[r],this._data[e])||(this.swap(r,e),this.heapifyUp(e))}heapifyDown(r){const e=2*r+1,A=2*r+2;if(e>=this._data.length)return;const a=A<this._data.length&&!this._comparator(this._data[A],this._data[e])?A:e;this._comparator(this._data[r],this._data[a])&&(this.swap(r,a),this.heapifyDown(a))}};/**
9
+ * @copyright 2021 Aaron Zhao <yujianzhao2013@gmail.com>
10
+ * @license MIT
11
+ * FIFO queue data structure
12
+ * @class Queue
13
+ */var _A=class{constructor(r,e){if(this._data=[],this._head=0,this._cap=null,r!=null){if(!Array.isArray(r))throw Error("Constructor expects data to be an array");this._data=r}if(e!=null){if(typeof e!="number")throw Error("Constructor expects capacity to be a number");this._cap=e}}enqueue(r){return!(this._cap!=null&&this.size()>=this._cap)&&(this._data.push(r),!0)}dequeue(){if(this.size()===0)return null;const r=this._data[this._head];return this._head+=1,2*this._head>=this._data.length&&(this._data=this._data.slice(this._head),this._head=0),r}peek(r=!1){return this.size()>0?r?this._data[this._data.length-1]:this._data[this._head]:null}size(){return this._data.length-this._head}updateCapacity(r){this._cap=r}reset(){this._data=[],this._head=0}forEach(r){for(let e=this._head;e<this._data.length;e+=1)r(this._data[e],e-this._head)}toArray(){return this._data.slice(this._head)}};/**
14
+ * @copyright 2021 Aaron Zhao <yujianzhao2013@gmail.com>
15
+ * @license MIT
16
+ * Linked hash map data structure
17
+ * @class LinkedHashMap
18
+ */var Ye={Heap:NA,Queue:_A,LinkedHashMap:class{constructor(){this._data=new Map,this._link=new Map,this._head=void 0,this._tail=void 0}put(r,e,A=!1){this.has(r)?this._data.set(r,e):(this._data.set(r,e),this._link.set(r,{previous:void 0,next:void 0}),this._head==null?(this._head=r,this._tail=r):A?(this._link.get(this._head).previous=r,this._link.get(r).next=this._head,this._head=r):(this._link.get(this._tail).next=r,this._link.get(r).previous=this._tail,this._tail=r))}head(){return{key:this._head,value:this.get(this._head),next:()=>this.next(this._head),previous:()=>null}}tail(){return{key:this._tail,value:this.get(this._tail),next:()=>null,previous:()=>this.previous(this._tail)}}get(r){return this._data.get(r)}previousKey(r){const e=this._link.get(r);return e!=null?e.previous:void 0}previousValue(r){return this.get(this.previousKey(r))}previous(r){const e=this.previousKey(r);return{key:e,value:this.get(e),next:()=>this.next(e),previous:()=>this.previous(e)}}nextKey(r){const e=this._link.get(r);return e!=null?e.next:void 0}nextValue(r){return this.get(this.nextKey(r))}next(r){const e=this.nextKey(r);return{key:e,value:this.get(e),next:()=>this.next(e),previous:()=>this.previous(e)}}remove(r){const e=this._data.get(r);if(e!=null)if(this.size()===1)this.reset();else{if(r===this._head){const A=this._link.get(this._head);this._link.get(A.next).previous=null,this._head=A.next}else if(r===this._tail){const A=this._link.get(this._tail);this._link.get(A.previous).next=null,this._tail=A.previous}else{const A=this._link.get(r),a=this._link.get(A.previous),t=this._link.get(A.next);a.next=A.next,t.previous=A.previous}this._link.delete(r),this._data.delete(r)}return e}has(r){return this._data.has(r)}size(){return this._data.size}reset(){this._data.clear(),this._link.clear(),this._head=void 0,this._tail=void 0}keys(){return this._data.keys()}values(){return this._data.values()}entries(){return this._data.entries()}toArray(r="orderByInsert"){if(r!=="orderByInsert"){const e=[];let A=this._head;for(;A!=null;)e.push({key:A,value:this.get(A)}),A=this.nextKey(A);return e}return Array.from(this.keys()).map(e=>({key:e,value:this.get(e)}))}}};const PA=new TextDecoder;class We{constructor(e,A,a,t){this.buffer=e,this.binOffset=A+a,this.binLength=t;let i=null;if(a!==0)try{const s=new Uint8Array(e,A,a);i=JSON.parse(PA.decode(s))}catch{i={}}else i={};this.header=i}getKeys(){return Object.keys(this.header)}getData(e,A,a=null,t=null){const i=this.header;if(!(e in i))return null;const s=i[e];if(s instanceof Object){if(Array.isArray(s))return s;{const{buffer:n,binOffset:d,binLength:o}=this,b=s.byteOffset||0,c=s.type||t,h=s.componentType||a;if("type"in s&&t&&s.type!==t)throw new Error("FeatureTable: Specified type does not match expected type.");let f,l;switch(c){case"SCALAR":f=1;break;case"VEC2":f=2;break;case"VEC3":f=3;break;case"VEC4":f=4;break;default:throw new Error(`FeatureTable : Feature type not provided for "${e}".`)}const u=d+b,I=A*f;switch(h){case"BYTE":l=new Int8Array(n,u,I);break;case"UNSIGNED_BYTE":l=new Uint8Array(n,u,I);break;case"SHORT":l=new Int16Array(n,u,I);break;case"UNSIGNED_SHORT":l=new Uint16Array(n,u,I);break;case"INT":l=new Int32Array(n,u,I);break;case"UNSIGNED_INT":l=new Uint32Array(n,u,I);break;case"FLOAT":l=new Float32Array(n,u,I);break;case"DOUBLE":l=new Float64Array(n,u,I);break;default:throw new Error(`FeatureTable : Feature component type not provided for "${e}".`)}if(u+I*l.BYTES_PER_ELEMENT>d+o)throw new Error("FeatureTable: Feature data read outside binary body length.");return l}}return s}}class HA extends We{constructor(e,A,a,t,i){super(e,a,t,i),this.batchSize=A}getData(e,A=null,a=null){return super.getData(e,this.batchSize,A,a)}}function Xe(r){let e,A,a,t=-1,i=0;for(let o=0;o<r.length;++o){const b=r[o];if(e===void 0&&(e=b.array.constructor),e!==b.array.constructor)return console.error("THREE.BufferGeometryUtils: .mergeAttributes() failed. BufferAttribute.array must be of consistent array types across matching attributes."),null;if(A===void 0&&(A=b.itemSize),A!==b.itemSize)return console.error("THREE.BufferGeometryUtils: .mergeAttributes() failed. BufferAttribute.itemSize must be consistent across matching attributes."),null;if(a===void 0&&(a=b.normalized),a!==b.normalized)return console.error("THREE.BufferGeometryUtils: .mergeAttributes() failed. BufferAttribute.normalized must be consistent across matching attributes."),null;if(t===-1&&(t=b.gpuType),t!==b.gpuType)return console.error("THREE.BufferGeometryUtils: .mergeAttributes() failed. BufferAttribute.gpuType must be consistent across matching attributes."),null;i+=b.count*A}const s=new e(i),n=new g.BufferAttribute(s,A,a);let d=0;for(let o=0;o<r.length;++o){const b=r[o];if(b.isInterleavedBufferAttribute){const c=d/A;for(let h=0,f=b.count;h<f;h++)for(let l=0;l<A;l++){const u=b.getComponent(h,l);n.setComponent(h+c,l,u)}}else s.set(b.array,d);d+=b.count*A}return t!==void 0&&(n.gpuType=t),n}function Ze(r,e){if(e===g.TrianglesDrawMode)return console.warn("THREE.BufferGeometryUtils.toTrianglesDrawMode(): Geometry already defined as triangles."),r;if(e===g.TriangleFanDrawMode||e===g.TriangleStripDrawMode){let A=r.getIndex();if(A===null){const s=[],n=r.getAttribute("position");if(n===void 0)return console.error("THREE.BufferGeometryUtils.toTrianglesDrawMode(): Undefined position attribute. Processing not possible."),r;for(let d=0;d<n.count;d++)s.push(d);r.setIndex(s),A=r.getIndex()}const a=A.count-2,t=[];if(e===g.TriangleFanDrawMode)for(let s=1;s<=a;s++)t.push(A.getX(0)),t.push(A.getX(s)),t.push(A.getX(s+1));else for(let s=0;s<a;s++)s%2==0?(t.push(A.getX(s)),t.push(A.getX(s+1)),t.push(A.getX(s+2))):(t.push(A.getX(s+2)),t.push(A.getX(s+1)),t.push(A.getX(s)));t.length/3!==a&&console.error("THREE.BufferGeometryUtils.toTrianglesDrawMode(): Unable to generate correct amount of triangles.");const i=r.clone();return i.setIndex(t),i.clearGroups(),i}return console.error("THREE.BufferGeometryUtils.toTrianglesDrawMode(): Unknown draw mode:",e),r}class $e{constructor(e){UA(this,"checkLoaderInitialized",async()=>new Promise(e=>{const A=setInterval(()=>{this.gltfLoader.hasDracoLoader&&!this.gltfLoader.dracoLoader||this.gltfLoader.hasKTX2Loader&&!this.gltfLoader.ktx2Loader||(clearInterval(A),e())},10)}));this.gltfLoader=e,this.tempMatrix=new Q.Matrix4,this.zUpToYUpMatrix=new Q.Matrix4,this.zUpToYUpMatrix.set(1,0,0,0,0,0,-1,0,0,1,0,0,0,0,0,1)}parseB3DM(e,A,a,t){const i=this,s=new DataView(e),n=String.fromCharCode(s.getUint8(0))+String.fromCharCode(s.getUint8(1))+String.fromCharCode(s.getUint8(2))+String.fromCharCode(s.getUint8(3));console.assert(n==="b3dm");const d=s.getUint32(8,!0);console.assert(d===e.byteLength);const o=s.getUint32(12,!0),b=s.getUint32(16,!0),c=s.getUint32(20,!0),h=s.getUint32(24,!0),f=new We(e,28,o,b),l=28+o+b;new HA(e,f.getData("BATCH_LENGTH"),l,c,h);const u=l+c+h,I=new Uint8Array(e,u,d-u).slice().buffer;return new Promise(async(C,B)=>{await this.checkLoaderInitialized(),this.gltfLoader.parse(I,null,m=>{const E=f.getData("RTC_CENTER");E?(this.tempMatrix.makeTranslation(E[0],E[1],E[2]),m.scene.applyMatrix4(this.tempMatrix)):m.userData.gltfExtensions&&m.userData.gltfExtensions.CESIUM_RTC&&(this.tempMatrix.makeTranslation(m.userData.gltfExtensions.CESIUM_RTC.center[0],m.userData.gltfExtensions.CESIUM_RTC.center[1],m.userData.gltfExtensions.CESIUM_RTC.center[2]),m.scene.applyMatrix4(this.tempMatrix)),a&&m.scene.applyMatrix4(i.zUpToYUpMatrix),m.scene.asset=m.asset,m.scene.traverse(j=>{j.isMesh&&(t&&j.applyMatrix4(i.zUpToYUpMatrix),A&&A(j))}),C(m.scene)},m=>{console.error(m)})})}parseB3DMInstanced(e,A,a,t,i){return this.parseB3DM(e,A,t,i).then(s=>{let n,d=[],o=[];s.updateWorldMatrix(!1,!0),s.traverse(c=>{c.isMesh&&(c.geometry.applyMatrix4(c.matrixWorld),d.push(c.geometry),o.push(c.material))});let b=function(c){let h=new Set;return c.forEach(l=>{for(let u in l.attributes)h.add(u)}),c.forEach(l=>{h.forEach(u=>{if(!l.attributes[u]){const I=function(B){switch(B){case"position":case"normal":case"color":return 3;case"uv":case"uv2":return 2;default:throw new Error(`Unknown attribute ${B}`)}}(u),C=new Float32Array(I*l.getAttribute("position").count).fill(0);l.setAttribute(u,new Q.BufferAttribute(C,I))}})}),function(l,u=!1){const I=l[0].index!==null,C=new Set(Object.keys(l[0].attributes)),B=new Set(Object.keys(l[0].morphAttributes)),m={},E={},j=l[0].morphTargetsRelative,k=new g.BufferGeometry;let w=0;for(let p=0;p<l.length;++p){const y=l[p];let x=0;if(I!==(y.index!==null))return console.error("THREE.BufferGeometryUtils: .mergeGeometries() failed with geometry at index "+p+". All geometries must have compatible attributes; make sure index attribute exists among all geometries, or in none of them."),null;for(const D in y.attributes){if(!C.has(D))return console.error("THREE.BufferGeometryUtils: .mergeGeometries() failed with geometry at index "+p+'. All geometries must have compatible attributes; make sure "'+D+'" attribute exists among all geometries, or in none of them.'),null;m[D]===void 0&&(m[D]=[]),m[D].push(y.attributes[D]),x++}if(x!==C.size)return console.error("THREE.BufferGeometryUtils: .mergeGeometries() failed with geometry at index "+p+". Make sure all geometries have the same number of attributes."),null;if(j!==y.morphTargetsRelative)return console.error("THREE.BufferGeometryUtils: .mergeGeometries() failed with geometry at index "+p+". .morphTargetsRelative must be consistent throughout all geometries."),null;for(const D in y.morphAttributes){if(!B.has(D))return console.error("THREE.BufferGeometryUtils: .mergeGeometries() failed with geometry at index "+p+". .morphAttributes must be consistent throughout all geometries."),null;E[D]===void 0&&(E[D]=[]),E[D].push(y.morphAttributes[D])}if(u){let D;if(I)D=y.index.count;else{if(y.attributes.position===void 0)return console.error("THREE.BufferGeometryUtils: .mergeGeometries() failed with geometry at index "+p+". The geometry must have either an index or a position attribute"),null;D=y.attributes.position.count}k.addGroup(w,D,p),w+=D}}if(I){let p=0;const y=[];for(let x=0;x<l.length;++x){const D=l[x].index;for(let F=0;F<D.count;++F)y.push(D.getX(F)+p);p+=l[x].attributes.position.count}k.setIndex(y)}for(const p in m){const y=Xe(m[p]);if(!y)return console.error("THREE.BufferGeometryUtils: .mergeGeometries() failed while trying to merge the "+p+" attribute."),null;k.setAttribute(p,y)}for(const p in E){const y=E[p][0].length;if(y===0)break;k.morphAttributes=k.morphAttributes||{},k.morphAttributes[p]=[];for(let x=0;x<y;++x){const D=[];for(let P=0;P<E[p].length;++P)D.push(E[p][P][x]);const F=Xe(D);if(!F)return console.error("THREE.BufferGeometryUtils: .mergeGeometries() failed while trying to merge the "+p+" morphAttribute."),null;k.morphAttributes[p].push(F)}}return k}(c,!0)}(d);return n=new Q.InstancedMesh(b,o,a),n.baseMatrix=new Q.Matrix4().identity(),n})}}class eA extends g.Loader{constructor(e){super(e),this.dracoLoader=null,this.ktx2Loader=null,this.meshoptDecoder=null,this.pluginCallbacks=[],this.register(function(A){return new VA(A)}),this.register(function(A){return new zA(A)}),this.register(function(A){return new ta(A)}),this.register(function(A){return new ia(A)}),this.register(function(A){return new sa(A)}),this.register(function(A){return new WA(A)}),this.register(function(A){return new XA(A)}),this.register(function(A){return new ZA(A)}),this.register(function(A){return new $A(A)}),this.register(function(A){return new KA(A)}),this.register(function(A){return new ea(A)}),this.register(function(A){return new YA(A)}),this.register(function(A){return new aa(A)}),this.register(function(A){return new Aa(A)}),this.register(function(A){return new OA(A)}),this.register(function(A){return new ra(A)}),this.register(function(A){return new na(A)})}load(e,A,a,t){const i=this;let s;if(this.resourcePath!=="")s=this.resourcePath;else if(this.path!==""){const o=g.LoaderUtils.extractUrlBase(e);s=g.LoaderUtils.resolveURL(o,this.path)}else s=g.LoaderUtils.extractUrlBase(e);this.manager.itemStart(e);const n=function(o){t?t(o):console.error(o),i.manager.itemError(e),i.manager.itemEnd(e)},d=new g.FileLoader(this.manager);d.setPath(this.path),d.setResponseType("arraybuffer"),d.setRequestHeader(this.requestHeader),d.setWithCredentials(this.withCredentials),d.load(e,function(o){try{i.parse(o,s,function(b){A(b),i.manager.itemEnd(e)},n)}catch(b){n(b)}},a,n)}setDRACOLoader(e){return this.dracoLoader=e,this}setKTX2Loader(e){return this.ktx2Loader=e,this}setMeshoptDecoder(e){return this.meshoptDecoder=e,this}register(e){return this.pluginCallbacks.indexOf(e)===-1&&this.pluginCallbacks.push(e),this}unregister(e){return this.pluginCallbacks.indexOf(e)!==-1&&this.pluginCallbacks.splice(this.pluginCallbacks.indexOf(e),1),this}parse(e,A,a,t){let i;const s={},n={},d=new TextDecoder;if(typeof e=="string")i=JSON.parse(e);else if(e instanceof ArrayBuffer)if(d.decode(new Uint8Array(e,0,4))===AA){try{s[M.KHR_BINARY_GLTF]=new da(e)}catch(b){return void(t&&t(b))}i=JSON.parse(s[M.KHR_BINARY_GLTF].content)}else i=JSON.parse(d.decode(e));else i=e;if(i.asset===void 0||i.asset.version[0]<2)return void(t&&t(new Error("THREE.GLTFLoader: Unsupported asset. glTF versions >=2.0 are supported.")));const o=new Qa(i,{path:A||this.resourcePath||"",crossOrigin:this.crossOrigin,requestHeader:this.requestHeader,manager:this.manager,ktx2Loader:this.ktx2Loader,meshoptDecoder:this.meshoptDecoder});o.fileLoader.setRequestHeader(this.requestHeader);for(let b=0;b<this.pluginCallbacks.length;b++){const c=this.pluginCallbacks[b](o);c.name||console.error("THREE.GLTFLoader: Invalid plugin found: missing name"),n[c.name]=c,s[c.name]=!0}if(i.extensionsUsed)for(let b=0;b<i.extensionsUsed.length;++b){const c=i.extensionsUsed[b],h=i.extensionsRequired||[];switch(c){case M.KHR_MATERIALS_UNLIT:s[c]=new JA;break;case M.KHR_DRACO_MESH_COMPRESSION:s[c]=new ba(i,this.dracoLoader);break;case M.KHR_TEXTURE_TRANSFORM:s[c]=new ga;break;case M.KHR_MESH_QUANTIZATION:s[c]=new ha;break;default:h.indexOf(c)>=0&&n[c]===void 0&&console.warn('THREE.GLTFLoader: Unknown extension "'+c+'".')}}o.setExtensions(s),o.setPlugins(n),o.parse(a,t)}parseAsync(e,A){const a=this;return new Promise(function(t,i){a.parse(e,A,t,i)})}}function qA(){let r={};return{get:function(e){return r[e]},add:function(e,A){r[e]=A},remove:function(e){delete r[e]},removeAll:function(){r={}}}}const M={KHR_BINARY_GLTF:"KHR_binary_glTF",KHR_DRACO_MESH_COMPRESSION:"KHR_draco_mesh_compression",KHR_LIGHTS_PUNCTUAL:"KHR_lights_punctual",KHR_MATERIALS_CLEARCOAT:"KHR_materials_clearcoat",KHR_MATERIALS_DISPERSION:"KHR_materials_dispersion",KHR_MATERIALS_IOR:"KHR_materials_ior",KHR_MATERIALS_SHEEN:"KHR_materials_sheen",KHR_MATERIALS_SPECULAR:"KHR_materials_specular",KHR_MATERIALS_TRANSMISSION:"KHR_materials_transmission",KHR_MATERIALS_IRIDESCENCE:"KHR_materials_iridescence",KHR_MATERIALS_ANISOTROPY:"KHR_materials_anisotropy",KHR_MATERIALS_UNLIT:"KHR_materials_unlit",KHR_MATERIALS_VOLUME:"KHR_materials_volume",KHR_TEXTURE_BASISU:"KHR_texture_basisu",KHR_TEXTURE_TRANSFORM:"KHR_texture_transform",KHR_MESH_QUANTIZATION:"KHR_mesh_quantization",KHR_MATERIALS_EMISSIVE_STRENGTH:"KHR_materials_emissive_strength",EXT_MATERIALS_BUMP:"EXT_materials_bump",EXT_TEXTURE_WEBP:"EXT_texture_webp",EXT_TEXTURE_AVIF:"EXT_texture_avif",EXT_MESHOPT_COMPRESSION:"EXT_meshopt_compression",EXT_MESH_GPU_INSTANCING:"EXT_mesh_gpu_instancing"};class OA{constructor(e){this.parser=e,this.name=M.KHR_LIGHTS_PUNCTUAL,this.cache={refs:{},uses:{}}}_markDefs(){const e=this.parser,A=this.parser.json.nodes||[];for(let a=0,t=A.length;a<t;a++){const i=A[a];i.extensions&&i.extensions[this.name]&&i.extensions[this.name].light!==void 0&&e._addNodeRef(this.cache,i.extensions[this.name].light)}}_loadLight(e){const A=this.parser,a="light:"+e;let t=A.cache.get(a);if(t)return t;const i=A.json,s=((i.extensions&&i.extensions[this.name]||{}).lights||[])[e];let n;const d=new g.Color(16777215);s.color!==void 0&&d.setRGB(s.color[0],s.color[1],s.color[2],g.LinearSRGBColorSpace);const o=s.range!==void 0?s.range:0;switch(s.type){case"directional":n=new g.DirectionalLight(d),n.target.position.set(0,0,-1),n.add(n.target);break;case"point":n=new g.PointLight(d),n.distance=o;break;case"spot":n=new g.SpotLight(d),n.distance=o,s.spot=s.spot||{},s.spot.innerConeAngle=s.spot.innerConeAngle!==void 0?s.spot.innerConeAngle:0,s.spot.outerConeAngle=s.spot.outerConeAngle!==void 0?s.spot.outerConeAngle:Math.PI/4,n.angle=s.spot.outerConeAngle,n.penumbra=1-s.spot.innerConeAngle/s.spot.outerConeAngle,n.target.position.set(0,0,-1),n.add(n.target);break;default:throw new Error("THREE.GLTFLoader: Unexpected light type: "+s.type)}return n.position.set(0,0,0),n.decay=2,Y(n,s),s.intensity!==void 0&&(n.intensity=s.intensity),n.name=A.createUniqueName(s.name||"light_"+e),t=Promise.resolve(n),A.cache.add(a,t),t}getDependency(e,A){if(e==="light")return this._loadLight(A)}createNodeAttachment(e){const A=this,a=this.parser,t=a.json.nodes[e],i=(t.extensions&&t.extensions[this.name]||{}).light;return i===void 0?null:this._loadLight(i).then(function(s){return a._getNodeRef(A.cache,i,s)})}}class JA{constructor(){this.name=M.KHR_MATERIALS_UNLIT}getMaterialType(){return g.MeshBasicMaterial}extendParams(e,A,a){const t=[];e.color=new g.Color(1,1,1),e.opacity=1;const i=A.pbrMetallicRoughness;if(i){if(Array.isArray(i.baseColorFactor)){const s=i.baseColorFactor;e.color.setRGB(s[0],s[1],s[2],g.LinearSRGBColorSpace),e.opacity=s[3]}i.baseColorTexture!==void 0&&t.push(a.assignTexture(e,"map",i.baseColorTexture,g.SRGBColorSpace))}return Promise.all(t)}}class KA{constructor(e){this.parser=e,this.name=M.KHR_MATERIALS_EMISSIVE_STRENGTH}extendMaterialParams(e,A){const a=this.parser.json.materials[e];if(!a.extensions||!a.extensions[this.name])return Promise.resolve();const t=a.extensions[this.name].emissiveStrength;return t!==void 0&&(A.emissiveIntensity=t),Promise.resolve()}}class VA{constructor(e){this.parser=e,this.name=M.KHR_MATERIALS_CLEARCOAT}getMaterialType(e){const A=this.parser.json.materials[e];return A.extensions&&A.extensions[this.name]?g.MeshPhysicalMaterial:null}extendMaterialParams(e,A){const a=this.parser,t=a.json.materials[e];if(!t.extensions||!t.extensions[this.name])return Promise.resolve();const i=[],s=t.extensions[this.name];if(s.clearcoatFactor!==void 0&&(A.clearcoat=s.clearcoatFactor),s.clearcoatTexture!==void 0&&i.push(a.assignTexture(A,"clearcoatMap",s.clearcoatTexture)),s.clearcoatRoughnessFactor!==void 0&&(A.clearcoatRoughness=s.clearcoatRoughnessFactor),s.clearcoatRoughnessTexture!==void 0&&i.push(a.assignTexture(A,"clearcoatRoughnessMap",s.clearcoatRoughnessTexture)),s.clearcoatNormalTexture!==void 0&&(i.push(a.assignTexture(A,"clearcoatNormalMap",s.clearcoatNormalTexture)),s.clearcoatNormalTexture.scale!==void 0)){const n=s.clearcoatNormalTexture.scale;A.clearcoatNormalScale=new g.Vector2(n,n)}return Promise.all(i)}}class zA{constructor(e){this.parser=e,this.name=M.KHR_MATERIALS_DISPERSION}getMaterialType(e){const A=this.parser.json.materials[e];return A.extensions&&A.extensions[this.name]?g.MeshPhysicalMaterial:null}extendMaterialParams(e,A){const a=this.parser.json.materials[e];if(!a.extensions||!a.extensions[this.name])return Promise.resolve();const t=a.extensions[this.name];return A.dispersion=t.dispersion!==void 0?t.dispersion:0,Promise.resolve()}}class YA{constructor(e){this.parser=e,this.name=M.KHR_MATERIALS_IRIDESCENCE}getMaterialType(e){const A=this.parser.json.materials[e];return A.extensions&&A.extensions[this.name]?g.MeshPhysicalMaterial:null}extendMaterialParams(e,A){const a=this.parser,t=a.json.materials[e];if(!t.extensions||!t.extensions[this.name])return Promise.resolve();const i=[],s=t.extensions[this.name];return s.iridescenceFactor!==void 0&&(A.iridescence=s.iridescenceFactor),s.iridescenceTexture!==void 0&&i.push(a.assignTexture(A,"iridescenceMap",s.iridescenceTexture)),s.iridescenceIor!==void 0&&(A.iridescenceIOR=s.iridescenceIor),A.iridescenceThicknessRange===void 0&&(A.iridescenceThicknessRange=[100,400]),s.iridescenceThicknessMinimum!==void 0&&(A.iridescenceThicknessRange[0]=s.iridescenceThicknessMinimum),s.iridescenceThicknessMaximum!==void 0&&(A.iridescenceThicknessRange[1]=s.iridescenceThicknessMaximum),s.iridescenceThicknessTexture!==void 0&&i.push(a.assignTexture(A,"iridescenceThicknessMap",s.iridescenceThicknessTexture)),Promise.all(i)}}class WA{constructor(e){this.parser=e,this.name=M.KHR_MATERIALS_SHEEN}getMaterialType(e){const A=this.parser.json.materials[e];return A.extensions&&A.extensions[this.name]?g.MeshPhysicalMaterial:null}extendMaterialParams(e,A){const a=this.parser,t=a.json.materials[e];if(!t.extensions||!t.extensions[this.name])return Promise.resolve();const i=[];A.sheenColor=new g.Color(0,0,0),A.sheenRoughness=0,A.sheen=1;const s=t.extensions[this.name];if(s.sheenColorFactor!==void 0){const n=s.sheenColorFactor;A.sheenColor.setRGB(n[0],n[1],n[2],g.LinearSRGBColorSpace)}return s.sheenRoughnessFactor!==void 0&&(A.sheenRoughness=s.sheenRoughnessFactor),s.sheenColorTexture!==void 0&&i.push(a.assignTexture(A,"sheenColorMap",s.sheenColorTexture,g.SRGBColorSpace)),s.sheenRoughnessTexture!==void 0&&i.push(a.assignTexture(A,"sheenRoughnessMap",s.sheenRoughnessTexture)),Promise.all(i)}}class XA{constructor(e){this.parser=e,this.name=M.KHR_MATERIALS_TRANSMISSION}getMaterialType(e){const A=this.parser.json.materials[e];return A.extensions&&A.extensions[this.name]?g.MeshPhysicalMaterial:null}extendMaterialParams(e,A){const a=this.parser,t=a.json.materials[e];if(!t.extensions||!t.extensions[this.name])return Promise.resolve();const i=[],s=t.extensions[this.name];return s.transmissionFactor!==void 0&&(A.transmission=s.transmissionFactor),s.transmissionTexture!==void 0&&i.push(a.assignTexture(A,"transmissionMap",s.transmissionTexture)),Promise.all(i)}}class ZA{constructor(e){this.parser=e,this.name=M.KHR_MATERIALS_VOLUME}getMaterialType(e){const A=this.parser.json.materials[e];return A.extensions&&A.extensions[this.name]?g.MeshPhysicalMaterial:null}extendMaterialParams(e,A){const a=this.parser,t=a.json.materials[e];if(!t.extensions||!t.extensions[this.name])return Promise.resolve();const i=[],s=t.extensions[this.name];A.thickness=s.thicknessFactor!==void 0?s.thicknessFactor:0,s.thicknessTexture!==void 0&&i.push(a.assignTexture(A,"thicknessMap",s.thicknessTexture)),A.attenuationDistance=s.attenuationDistance||1/0;const n=s.attenuationColor||[1,1,1];return A.attenuationColor=new g.Color().setRGB(n[0],n[1],n[2],g.LinearSRGBColorSpace),Promise.all(i)}}class $A{constructor(e){this.parser=e,this.name=M.KHR_MATERIALS_IOR}getMaterialType(e){const A=this.parser.json.materials[e];return A.extensions&&A.extensions[this.name]?g.MeshPhysicalMaterial:null}extendMaterialParams(e,A){const a=this.parser.json.materials[e];if(!a.extensions||!a.extensions[this.name])return Promise.resolve();const t=a.extensions[this.name];return A.ior=t.ior!==void 0?t.ior:1.5,Promise.resolve()}}class ea{constructor(e){this.parser=e,this.name=M.KHR_MATERIALS_SPECULAR}getMaterialType(e){const A=this.parser.json.materials[e];return A.extensions&&A.extensions[this.name]?g.MeshPhysicalMaterial:null}extendMaterialParams(e,A){const a=this.parser,t=a.json.materials[e];if(!t.extensions||!t.extensions[this.name])return Promise.resolve();const i=[],s=t.extensions[this.name];A.specularIntensity=s.specularFactor!==void 0?s.specularFactor:1,s.specularTexture!==void 0&&i.push(a.assignTexture(A,"specularIntensityMap",s.specularTexture));const n=s.specularColorFactor||[1,1,1];return A.specularColor=new g.Color().setRGB(n[0],n[1],n[2],g.LinearSRGBColorSpace),s.specularColorTexture!==void 0&&i.push(a.assignTexture(A,"specularColorMap",s.specularColorTexture,g.SRGBColorSpace)),Promise.all(i)}}class Aa{constructor(e){this.parser=e,this.name=M.EXT_MATERIALS_BUMP}getMaterialType(e){const A=this.parser.json.materials[e];return A.extensions&&A.extensions[this.name]?g.MeshPhysicalMaterial:null}extendMaterialParams(e,A){const a=this.parser,t=a.json.materials[e];if(!t.extensions||!t.extensions[this.name])return Promise.resolve();const i=[],s=t.extensions[this.name];return A.bumpScale=s.bumpFactor!==void 0?s.bumpFactor:1,s.bumpTexture!==void 0&&i.push(a.assignTexture(A,"bumpMap",s.bumpTexture)),Promise.all(i)}}class aa{constructor(e){this.parser=e,this.name=M.KHR_MATERIALS_ANISOTROPY}getMaterialType(e){const A=this.parser.json.materials[e];return A.extensions&&A.extensions[this.name]?g.MeshPhysicalMaterial:null}extendMaterialParams(e,A){const a=this.parser,t=a.json.materials[e];if(!t.extensions||!t.extensions[this.name])return Promise.resolve();const i=[],s=t.extensions[this.name];return s.anisotropyStrength!==void 0&&(A.anisotropy=s.anisotropyStrength),s.anisotropyRotation!==void 0&&(A.anisotropyRotation=s.anisotropyRotation),s.anisotropyTexture!==void 0&&i.push(a.assignTexture(A,"anisotropyMap",s.anisotropyTexture)),Promise.all(i)}}class ta{constructor(e){this.parser=e,this.name=M.KHR_TEXTURE_BASISU}loadTexture(e){const A=this.parser,a=A.json,t=a.textures[e];if(!t.extensions||!t.extensions[this.name])return null;const i=t.extensions[this.name],s=A.options.ktx2Loader;if(!s){if(a.extensionsRequired&&a.extensionsRequired.indexOf(this.name)>=0)throw new Error("THREE.GLTFLoader: setKTX2Loader must be called before loading KTX2 textures");return null}return A.loadTextureImage(e,i.source,s)}}class ia{constructor(e){this.parser=e,this.name=M.EXT_TEXTURE_WEBP,this.isSupported=null}loadTexture(e){const A=this.name,a=this.parser,t=a.json,i=t.textures[e];if(!i.extensions||!i.extensions[A])return null;const s=i.extensions[A],n=t.images[s.source];let d=a.textureLoader;if(n.uri){const o=a.options.manager.getHandler(n.uri);o!==null&&(d=o)}return this.detectSupport().then(function(o){if(o)return a.loadTextureImage(e,s.source,d);if(t.extensionsRequired&&t.extensionsRequired.indexOf(A)>=0)throw new Error("THREE.GLTFLoader: WebP required by asset but unsupported.");return a.loadTexture(e)})}detectSupport(){return this.isSupported||(this.isSupported=new Promise(function(e){const A=new Image;A.src="data:image/webp;base64,UklGRiIAAABXRUJQVlA4IBYAAAAwAQCdASoBAAEADsD+JaQAA3AAAAAA",A.onload=A.onerror=function(){e(A.height===1)}})),this.isSupported}}class sa{constructor(e){this.parser=e,this.name=M.EXT_TEXTURE_AVIF,this.isSupported=null}loadTexture(e){const A=this.name,a=this.parser,t=a.json,i=t.textures[e];if(!i.extensions||!i.extensions[A])return null;const s=i.extensions[A],n=t.images[s.source];let d=a.textureLoader;if(n.uri){const o=a.options.manager.getHandler(n.uri);o!==null&&(d=o)}return this.detectSupport().then(function(o){if(o)return a.loadTextureImage(e,s.source,d);if(t.extensionsRequired&&t.extensionsRequired.indexOf(A)>=0)throw new Error("THREE.GLTFLoader: AVIF required by asset but unsupported.");return a.loadTexture(e)})}detectSupport(){return this.isSupported||(this.isSupported=new Promise(function(e){const A=new Image;A.src="data:image/avif;base64,AAAAIGZ0eXBhdmlmAAAAAGF2aWZtaWYxbWlhZk1BMUIAAADybWV0YQAAAAAAAAAoaGRscgAAAAAAAAAAcGljdAAAAAAAAAAAAAAAAGxpYmF2aWYAAAAADnBpdG0AAAAAAAEAAAAeaWxvYwAAAABEAAABAAEAAAABAAABGgAAABcAAAAoaWluZgAAAAAAAQAAABppbmZlAgAAAAABAABhdjAxQ29sb3IAAAAAamlwcnAAAABLaXBjbwAAABRpc3BlAAAAAAAAAAEAAAABAAAAEHBpeGkAAAAAAwgICAAAAAxhdjFDgQAMAAAAABNjb2xybmNseAACAAIABoAAAAAXaXBtYQAAAAAAAAABAAEEAQKDBAAAAB9tZGF0EgAKCBgABogQEDQgMgkQAAAAB8dSLfI=",A.onload=A.onerror=function(){e(A.height===1)}})),this.isSupported}}class ra{constructor(e){this.name=M.EXT_MESHOPT_COMPRESSION,this.parser=e}loadBufferView(e){const A=this.parser.json,a=A.bufferViews[e];if(a.extensions&&a.extensions[this.name]){const t=a.extensions[this.name],i=this.parser.getDependency("buffer",t.buffer),s=this.parser.options.meshoptDecoder;if(!s||!s.supported){if(A.extensionsRequired&&A.extensionsRequired.indexOf(this.name)>=0)throw new Error("THREE.GLTFLoader: setMeshoptDecoder must be called before loading compressed files");return null}return i.then(function(n){const d=t.byteOffset||0,o=t.byteLength||0,b=t.count,c=t.byteStride,h=new Uint8Array(n,d,o);return s.decodeGltfBufferAsync?s.decodeGltfBufferAsync(b,c,h,t.mode,t.filter).then(function(f){return f.buffer}):s.ready.then(function(){const f=new ArrayBuffer(b*c);return s.decodeGltfBuffer(new Uint8Array(f),b,c,h,t.mode,t.filter),f})})}return null}}class na{constructor(e){this.name=M.EXT_MESH_GPU_INSTANCING,this.parser=e}createNodeMesh(e){const A=this.parser.json,a=A.nodes[e];if(!a.extensions||!a.extensions[this.name]||a.mesh===void 0)return null;const t=A.meshes[a.mesh];for(const d of t.primitives)if(d.mode!==_.TRIANGLES&&d.mode!==_.TRIANGLE_STRIP&&d.mode!==_.TRIANGLE_FAN&&d.mode!==void 0)return null;const i=a.extensions[this.name].attributes,s=[],n={};for(const d in i)s.push(this.parser.getDependency("accessor",i[d]).then(o=>(n[d]=o,n[d])));return s.length<1?null:(s.push(this.parser.createNodeMesh(e)),Promise.all(s).then(d=>{const o=d.pop(),b=o.isGroup?o.children:[o],c=d[0].count,h=[];for(const f of b){const l=new g.Matrix4,u=new g.Vector3,I=new g.Quaternion,C=new g.Vector3(1,1,1),B=new g.InstancedMesh(f.geometry,f.material,c);for(let m=0;m<c;m++)n.TRANSLATION&&u.fromBufferAttribute(n.TRANSLATION,m),n.ROTATION&&I.fromBufferAttribute(n.ROTATION,m),n.SCALE&&C.fromBufferAttribute(n.SCALE,m),B.setMatrixAt(m,l.compose(u,I,C));for(const m in n)if(m==="_COLOR_0"){const E=n[m];B.instanceColor=new g.InstancedBufferAttribute(E.array,E.itemSize,E.normalized)}else m!=="TRANSLATION"&&m!=="ROTATION"&&m!=="SCALE"&&f.geometry.setAttribute(m,n[m]);g.Object3D.prototype.copy.call(B,f),this.parser.assignFinalMaterial(B),h.push(B)}return o.isGroup?(o.clear(),o.add(...h),o):h[0]}))}}const AA="glTF",oa=1313821514,ca=5130562;class da{constructor(e){this.name=M.KHR_BINARY_GLTF,this.content=null,this.body=null;const A=new DataView(e,0,12),a=new TextDecoder;if(this.header={magic:a.decode(new Uint8Array(e.slice(0,4))),version:A.getUint32(4,!0),length:A.getUint32(8,!0)},this.header.magic!==AA)throw new Error("THREE.GLTFLoader: Unsupported glTF-Binary header.");if(this.header.version<2)throw new Error("THREE.GLTFLoader: Legacy binary file detected.");const t=this.header.length-12,i=new DataView(e,12);let s=0;for(;s<t;){const n=i.getUint32(s,!0);s+=4;const d=i.getUint32(s,!0);if(s+=4,d===oa){const o=new Uint8Array(e,12+s,n);this.content=a.decode(o)}else if(d===ca){const o=12+s;this.body=e.slice(o,o+n)}s+=n}if(this.content===null)throw new Error("THREE.GLTFLoader: JSON content not found.")}}class ba{constructor(e,A){if(!A)throw new Error("THREE.GLTFLoader: No DRACOLoader instance provided.");this.name=M.KHR_DRACO_MESH_COMPRESSION,this.json=e,this.dracoLoader=A,this.dracoLoader.preload()}decodePrimitive(e,A){const a=this.json,t=this.dracoLoader,i=e.extensions[this.name].bufferView,s=e.extensions[this.name].attributes,n={},d={},o={};for(const b in s){const c=Qe[b]||b.toLowerCase();n[c]=s[b]}for(const b in e.attributes){const c=Qe[b]||b.toLowerCase();if(s[b]!==void 0){const h=a.accessors[e.attributes[b]],f=re[h.componentType];o[c]=f.name,d[c]=h.normalized===!0}}return A.getDependency("bufferView",i).then(function(b){return new Promise(function(c,h){t.decodeDracoFile(b,function(f){for(const l in f.attributes){const u=f.attributes[l],I=d[l];I!==void 0&&(u.normalized=I)}c(f)},n,o,g.LinearSRGBColorSpace,h)})})}}class ga{constructor(){this.name=M.KHR_TEXTURE_TRANSFORM}extendTexture(e,A){return(A.texCoord!==void 0&&A.texCoord!==e.channel||A.offset!==void 0||A.rotation!==void 0||A.scale!==void 0)&&(e=e.clone(),A.texCoord!==void 0&&(e.channel=A.texCoord),A.offset!==void 0&&e.offset.fromArray(A.offset),A.rotation!==void 0&&(e.rotation=A.rotation),A.scale!==void 0&&e.repeat.fromArray(A.scale),e.needsUpdate=!0),e}}class ha{constructor(){this.name=M.KHR_MESH_QUANTIZATION}}class aA extends g.Interpolant{constructor(e,A,a,t){super(e,A,a,t)}copySampleValue_(e){const A=this.resultBuffer,a=this.sampleValues,t=this.valueSize,i=e*t*3+t;for(let s=0;s!==t;s++)A[s]=a[i+s];return A}interpolate_(e,A,a,t){const i=this.resultBuffer,s=this.sampleValues,n=this.valueSize,d=2*n,o=3*n,b=t-A,c=(a-A)/b,h=c*c,f=h*c,l=e*o,u=l-o,I=-2*f+3*h,C=f-h,B=1-I,m=C-h+c;for(let E=0;E!==n;E++){const j=s[u+E+n],k=s[u+E+d]*b,w=s[l+E+n],p=s[l+E]*b;i[E]=B*j+m*k+I*w+C*p}return i}}const la=new g.Quaternion;class fa extends aA{interpolate_(e,A,a,t){const i=super.interpolate_(e,A,a,t);return la.fromArray(i).normalize().toArray(i),i}}const _={FLOAT:5126,FLOAT_MAT3:35675,FLOAT_MAT4:35676,FLOAT_VEC2:35664,FLOAT_VEC3:35665,FLOAT_VEC4:35666,LINEAR:9729,REPEAT:10497,SAMPLER_2D:35678,POINTS:0,LINES:1,LINE_LOOP:2,LINE_STRIP:3,TRIANGLES:4,TRIANGLE_STRIP:5,TRIANGLE_FAN:6,UNSIGNED_BYTE:5121,UNSIGNED_SHORT:5123},re={5120:Int8Array,5121:Uint8Array,5122:Int16Array,5123:Uint16Array,5125:Uint32Array,5126:Float32Array},tA={9728:g.NearestFilter,9729:g.LinearFilter,9984:g.NearestMipmapNearestFilter,9985:g.LinearMipmapNearestFilter,9986:g.NearestMipmapLinearFilter,9987:g.LinearMipmapLinearFilter},iA={33071:g.ClampToEdgeWrapping,33648:g.MirroredRepeatWrapping,10497:g.RepeatWrapping},me={SCALAR:1,VEC2:2,VEC3:3,VEC4:4,MAT2:4,MAT3:9,MAT4:16},Qe={POSITION:"position",NORMAL:"normal",TANGENT:"tangent",TEXCOORD_0:"uv",TEXCOORD_1:"uv1",TEXCOORD_2:"uv2",TEXCOORD_3:"uv3",COLOR_0:"color",WEIGHTS_0:"skinWeight",JOINTS_0:"skinIndex"},Z={scale:"scale",translation:"position",rotation:"quaternion",weights:"morphTargetInfluences"},Ia={CUBICSPLINE:void 0,LINEAR:g.InterpolateLinear,STEP:g.InterpolateDiscrete},ua="OPAQUE",Ba="MASK",Ca="BLEND";function ae(r,e,A){for(const a in A.extensions)r[a]===void 0&&(e.userData.gltfExtensions=e.userData.gltfExtensions||{},e.userData.gltfExtensions[a]=A.extensions[a])}function Y(r,e){e.extras!==void 0&&(typeof e.extras=="object"?Object.assign(r.userData,e.extras):console.warn("THREE.GLTFLoader: Ignoring primitive type .extras, "+e.extras))}function Ea(r,e){if(r.updateMorphTargets(),e.weights!==void 0)for(let A=0,a=e.weights.length;A<a;A++)r.morphTargetInfluences[A]=e.weights[A];if(e.extras&&Array.isArray(e.extras.targetNames)){const A=e.extras.targetNames;if(r.morphTargetInfluences.length===A.length){r.morphTargetDictionary={};for(let a=0,t=A.length;a<t;a++)r.morphTargetDictionary[A[a]]=a}else console.warn("THREE.GLTFLoader: Invalid extras.targetNames length. Ignoring names.")}}function pa(r){let e;const A=r.extensions&&r.extensions[M.KHR_DRACO_MESH_COMPRESSION];if(e=A?"draco:"+A.bufferView+":"+A.indices+":"+ye(A.attributes):r.indices+":"+ye(r.attributes)+":"+r.mode,r.targets!==void 0)for(let a=0,t=r.targets.length;a<t;a++)e+=":"+ye(r.targets[a]);return e}function ye(r){let e="";const A=Object.keys(r).sort();for(let a=0,t=A.length;a<t;a++)e+=A[a]+":"+r[A[a]]+";";return e}function we(r){switch(r){case Int8Array:return 1/127;case Uint8Array:return 1/255;case Int16Array:return 1/32767;case Uint16Array:return 1/65535;default:throw new Error("THREE.GLTFLoader: Unsupported normalized accessor component type.")}}const ma=new g.Matrix4;class Qa{constructor(e={},A={}){this.json=e,this.extensions={},this.plugins={},this.options=A,this.cache=new qA,this.associations=new Map,this.primitiveCache={},this.nodeCache={},this.meshCache={refs:{},uses:{}},this.cameraCache={refs:{},uses:{}},this.lightCache={refs:{},uses:{}},this.sourceCache={},this.textureCache={},this.nodeNamesUsed={};let a=!1,t=-1,i=!1,s=-1;if(typeof navigator<"u"){const n=navigator.userAgent;a=/^((?!chrome|android).)*safari/i.test(n)===!0;const d=n.match(/Version\/(\d+)/);t=a&&d?parseInt(d[1],10):-1,i=n.indexOf("Firefox")>-1,s=i?n.match(/Firefox\/([0-9]+)\./)[1]:-1}typeof createImageBitmap>"u"||a&&t<17||i&&s<98?this.textureLoader=new g.TextureLoader(this.options.manager):this.textureLoader=new g.ImageBitmapLoader(this.options.manager),this.textureLoader.setCrossOrigin(this.options.crossOrigin),this.textureLoader.setRequestHeader(this.options.requestHeader),this.fileLoader=new g.FileLoader(this.options.manager),this.fileLoader.setResponseType("arraybuffer"),this.options.crossOrigin==="use-credentials"&&this.fileLoader.setWithCredentials(!0)}setExtensions(e){this.extensions=e}setPlugins(e){this.plugins=e}parse(e,A){const a=this,t=this.json,i=this.extensions;this.cache.removeAll(),this.nodeCache={},this._invokeAll(function(s){return s._markDefs&&s._markDefs()}),Promise.all(this._invokeAll(function(s){return s.beforeRoot&&s.beforeRoot()})).then(function(){return Promise.all([a.getDependencies("scene"),a.getDependencies("animation"),a.getDependencies("camera")])}).then(function(s){const n={scene:s[0][t.scene||0],scenes:s[0],animations:s[1],cameras:s[2],asset:t.asset,parser:a,userData:{}};return ae(i,n,t),Y(n,t),Promise.all(a._invokeAll(function(d){return d.afterRoot&&d.afterRoot(n)})).then(function(){for(const d of n.scenes)d.updateMatrixWorld();e(n)})}).catch(A)}_markDefs(){const e=this.json.nodes||[],A=this.json.skins||[],a=this.json.meshes||[];for(let t=0,i=A.length;t<i;t++){const s=A[t].joints;for(let n=0,d=s.length;n<d;n++)e[s[n]].isBone=!0}for(let t=0,i=e.length;t<i;t++){const s=e[t];s.mesh!==void 0&&(this._addNodeRef(this.meshCache,s.mesh),s.skin!==void 0&&(a[s.mesh].isSkinnedMesh=!0)),s.camera!==void 0&&this._addNodeRef(this.cameraCache,s.camera)}}_addNodeRef(e,A){A!==void 0&&(e.refs[A]===void 0&&(e.refs[A]=e.uses[A]=0),e.refs[A]++)}_getNodeRef(e,A,a){if(e.refs[A]<=1)return a;const t=a.clone(),i=(s,n)=>{const d=this.associations.get(s);d!=null&&this.associations.set(n,d);for(const[o,b]of s.children.entries())i(b,n.children[o])};return i(a,t),t.name+="_instance_"+e.uses[A]++,t}_invokeOne(e){const A=Object.values(this.plugins);A.push(this);for(let a=0;a<A.length;a++){const t=e(A[a]);if(t)return t}return null}_invokeAll(e){const A=Object.values(this.plugins);A.unshift(this);const a=[];for(let t=0;t<A.length;t++){const i=e(A[t]);i&&a.push(i)}return a}getDependency(e,A){const a=e+":"+A;let t=this.cache.get(a);if(!t){switch(e){case"scene":t=this.loadScene(A);break;case"node":t=this._invokeOne(function(i){return i.loadNode&&i.loadNode(A)});break;case"mesh":t=this._invokeOne(function(i){return i.loadMesh&&i.loadMesh(A)});break;case"accessor":t=this.loadAccessor(A);break;case"bufferView":t=this._invokeOne(function(i){return i.loadBufferView&&i.loadBufferView(A)});break;case"buffer":t=this.loadBuffer(A);break;case"material":t=this._invokeOne(function(i){return i.loadMaterial&&i.loadMaterial(A)});break;case"texture":t=this._invokeOne(function(i){return i.loadTexture&&i.loadTexture(A)});break;case"skin":t=this.loadSkin(A);break;case"animation":t=this._invokeOne(function(i){return i.loadAnimation&&i.loadAnimation(A)});break;case"camera":t=this.loadCamera(A);break;default:if(t=this._invokeOne(function(i){return i!=this&&i.getDependency&&i.getDependency(e,A)}),!t)throw new Error("Unknown type: "+e)}this.cache.add(a,t)}return t}getDependencies(e){let A=this.cache.get(e);if(!A){const a=this,t=this.json[e+(e==="mesh"?"es":"s")]||[];A=Promise.all(t.map(function(i,s){return a.getDependency(e,s)})),this.cache.add(e,A)}return A}loadBuffer(e){const A=this.json.buffers[e],a=this.fileLoader;if(A.type&&A.type!=="arraybuffer")throw new Error("THREE.GLTFLoader: "+A.type+" buffer type is not supported.");if(A.uri===void 0&&e===0)return Promise.resolve(this.extensions[M.KHR_BINARY_GLTF].body);const t=this.options;return new Promise(function(i,s){a.load(g.LoaderUtils.resolveURL(A.uri,t.path),i,void 0,function(){s(new Error('THREE.GLTFLoader: Failed to load buffer "'+A.uri+'".'))})})}loadBufferView(e){const A=this.json.bufferViews[e];return this.getDependency("buffer",A.buffer).then(function(a){const t=A.byteLength||0,i=A.byteOffset||0;return a.slice(i,i+t)})}loadAccessor(e){const A=this,a=this.json,t=this.json.accessors[e];if(t.bufferView===void 0&&t.sparse===void 0){const s=me[t.type],n=re[t.componentType],d=t.normalized===!0,o=new n(t.count*s);return Promise.resolve(new g.BufferAttribute(o,s,d))}const i=[];return t.bufferView!==void 0?i.push(this.getDependency("bufferView",t.bufferView)):i.push(null),t.sparse!==void 0&&(i.push(this.getDependency("bufferView",t.sparse.indices.bufferView)),i.push(this.getDependency("bufferView",t.sparse.values.bufferView))),Promise.all(i).then(function(s){const n=s[0],d=me[t.type],o=re[t.componentType],b=o.BYTES_PER_ELEMENT,c=b*d,h=t.byteOffset||0,f=t.bufferView!==void 0?a.bufferViews[t.bufferView].byteStride:void 0,l=t.normalized===!0;let u,I;if(f&&f!==c){const C=Math.floor(h/f),B="InterleavedBuffer:"+t.bufferView+":"+t.componentType+":"+C+":"+t.count;let m=A.cache.get(B);m||(u=new o(n,C*f,t.count*f/b),m=new g.InterleavedBuffer(u,f/b),A.cache.add(B,m)),I=new g.InterleavedBufferAttribute(m,d,h%f/b,l)}else u=n===null?new o(t.count*d):new o(n,h,t.count*d),I=new g.BufferAttribute(u,d,l);if(t.sparse!==void 0){const C=me.SCALAR,B=re[t.sparse.indices.componentType],m=t.sparse.indices.byteOffset||0,E=t.sparse.values.byteOffset||0,j=new B(s[1],m,t.sparse.count*C),k=new o(s[2],E,t.sparse.count*d);n!==null&&(I=new g.BufferAttribute(I.array.slice(),I.itemSize,I.normalized)),I.normalized=!1;for(let w=0,p=j.length;w<p;w++){const y=j[w];if(I.setX(y,k[w*d]),d>=2&&I.setY(y,k[w*d+1]),d>=3&&I.setZ(y,k[w*d+2]),d>=4&&I.setW(y,k[w*d+3]),d>=5)throw new Error("THREE.GLTFLoader: Unsupported itemSize in sparse BufferAttribute.")}I.normalized=l}return I})}loadTexture(e){const A=this.json,a=this.options,t=A.textures[e].source,i=A.images[t];let s=this.textureLoader;if(i.uri){const n=a.manager.getHandler(i.uri);n!==null&&(s=n)}return this.loadTextureImage(e,t,s)}loadTextureImage(e,A,a){const t=this,i=this.json,s=i.textures[e],n=i.images[A],d=(n.uri||n.bufferView)+":"+s.sampler;if(this.textureCache[d])return this.textureCache[d];const o=this.loadImageSource(A,a).then(function(b){b.flipY=!1,b.name=s.name||n.name||"",b.name===""&&typeof n.uri=="string"&&n.uri.startsWith("data:image/")===!1&&(b.name=n.uri);const c=(i.samplers||{})[s.sampler]||{};return b.magFilter=tA[c.magFilter]||g.LinearFilter,b.minFilter=tA[c.minFilter]||g.LinearMipmapLinearFilter,b.wrapS=iA[c.wrapS]||g.RepeatWrapping,b.wrapT=iA[c.wrapT]||g.RepeatWrapping,b.generateMipmaps=!b.isCompressedTexture&&b.minFilter!==g.NearestFilter&&b.minFilter!==g.LinearFilter,t.associations.set(b,{textures:e}),b}).catch(function(){return null});return this.textureCache[d]=o,o}loadImageSource(e,A){const a=this,t=this.json,i=this.options;if(this.sourceCache[e]!==void 0)return this.sourceCache[e].then(c=>c.clone());const s=t.images[e],n=self.URL||self.webkitURL;let d=s.uri||"",o=!1;if(s.bufferView!==void 0)d=a.getDependency("bufferView",s.bufferView).then(function(c){o=!0;const h=new Blob([c],{type:s.mimeType});return d=n.createObjectURL(h),d});else if(s.uri===void 0)throw new Error("THREE.GLTFLoader: Image "+e+" is missing URI and bufferView");const b=Promise.resolve(d).then(function(c){return new Promise(function(h,f){let l=h;A.isImageBitmapLoader===!0&&(l=function(u){const I=new g.Texture(u);I.needsUpdate=!0,h(I)}),A.load(g.LoaderUtils.resolveURL(c,i.path),l,void 0,f)})}).then(function(c){var h;return o===!0&&n.revokeObjectURL(d),Y(c,s),c.userData.mimeType=s.mimeType||((h=s.uri).search(/\.jpe?g($|\?)/i)>0||h.search(/^data\:image\/jpeg/)===0?"image/jpeg":h.search(/\.webp($|\?)/i)>0||h.search(/^data\:image\/webp/)===0?"image/webp":h.search(/\.ktx2($|\?)/i)>0||h.search(/^data\:image\/ktx2/)===0?"image/ktx2":"image/png"),c}).catch(function(c){throw console.error("THREE.GLTFLoader: Couldn't load texture",d),c});return this.sourceCache[e]=b,b}assignTexture(e,A,a,t){const i=this;return this.getDependency("texture",a.index).then(function(s){if(!s)return null;if(a.texCoord!==void 0&&a.texCoord>0&&((s=s.clone()).channel=a.texCoord),i.extensions[M.KHR_TEXTURE_TRANSFORM]){const n=a.extensions!==void 0?a.extensions[M.KHR_TEXTURE_TRANSFORM]:void 0;if(n){const d=i.associations.get(s);s=i.extensions[M.KHR_TEXTURE_TRANSFORM].extendTexture(s,n),i.associations.set(s,d)}}return t!==void 0&&(s.colorSpace=t),e[A]=s,s})}assignFinalMaterial(e){const A=e.geometry;let a=e.material;const t=A.attributes.tangent===void 0,i=A.attributes.color!==void 0,s=A.attributes.normal===void 0;if(e.isPoints){const n="PointsMaterial:"+a.uuid;let d=this.cache.get(n);d||(d=new g.PointsMaterial,g.Material.prototype.copy.call(d,a),d.color.copy(a.color),d.map=a.map,d.sizeAttenuation=!1,this.cache.add(n,d)),a=d}else if(e.isLine){const n="LineBasicMaterial:"+a.uuid;let d=this.cache.get(n);d||(d=new g.LineBasicMaterial,g.Material.prototype.copy.call(d,a),d.color.copy(a.color),d.map=a.map,this.cache.add(n,d)),a=d}if(t||i||s){let n="ClonedMaterial:"+a.uuid+":";t&&(n+="derivative-tangents:"),i&&(n+="vertex-colors:"),s&&(n+="flat-shading:");let d=this.cache.get(n);d||(d=a.clone(),i&&(d.vertexColors=!0),s&&(d.flatShading=!0),t&&(d.normalScale&&(d.normalScale.y*=-1),d.clearcoatNormalScale&&(d.clearcoatNormalScale.y*=-1)),this.cache.add(n,d),this.associations.set(d,this.associations.get(a))),a=d}e.material=a}getMaterialType(){return g.MeshStandardMaterial}loadMaterial(e){const A=this,a=this.json,t=this.extensions,i=a.materials[e];let s;const n={},d=[];if((i.extensions||{})[M.KHR_MATERIALS_UNLIT]){const b=t[M.KHR_MATERIALS_UNLIT];s=b.getMaterialType(),d.push(b.extendParams(n,i,A))}else{const b=i.pbrMetallicRoughness||{};if(n.color=new g.Color(1,1,1),n.opacity=1,Array.isArray(b.baseColorFactor)){const c=b.baseColorFactor;n.color.setRGB(c[0],c[1],c[2],g.LinearSRGBColorSpace),n.opacity=c[3]}b.baseColorTexture!==void 0&&d.push(A.assignTexture(n,"map",b.baseColorTexture,g.SRGBColorSpace)),n.metalness=b.metallicFactor!==void 0?b.metallicFactor:1,n.roughness=b.roughnessFactor!==void 0?b.roughnessFactor:1,b.metallicRoughnessTexture!==void 0&&(d.push(A.assignTexture(n,"metalnessMap",b.metallicRoughnessTexture)),d.push(A.assignTexture(n,"roughnessMap",b.metallicRoughnessTexture))),s=this._invokeOne(function(c){return c.getMaterialType&&c.getMaterialType(e)}),d.push(Promise.all(this._invokeAll(function(c){return c.extendMaterialParams&&c.extendMaterialParams(e,n)})))}i.doubleSided===!0&&(n.side=g.DoubleSide);const o=i.alphaMode||ua;if(o===Ca?(n.transparent=!0,n.depthWrite=!1):(n.transparent=!1,o===Ba&&(n.alphaTest=i.alphaCutoff!==void 0?i.alphaCutoff:.5)),i.normalTexture!==void 0&&s!==g.MeshBasicMaterial&&(d.push(A.assignTexture(n,"normalMap",i.normalTexture)),n.normalScale=new g.Vector2(1,1),i.normalTexture.scale!==void 0)){const b=i.normalTexture.scale;n.normalScale.set(b,b)}if(i.occlusionTexture!==void 0&&s!==g.MeshBasicMaterial&&(d.push(A.assignTexture(n,"aoMap",i.occlusionTexture)),i.occlusionTexture.strength!==void 0&&(n.aoMapIntensity=i.occlusionTexture.strength)),i.emissiveFactor!==void 0&&s!==g.MeshBasicMaterial){const b=i.emissiveFactor;n.emissive=new g.Color().setRGB(b[0],b[1],b[2],g.LinearSRGBColorSpace)}return i.emissiveTexture!==void 0&&s!==g.MeshBasicMaterial&&d.push(A.assignTexture(n,"emissiveMap",i.emissiveTexture,g.SRGBColorSpace)),Promise.all(d).then(function(){const b=new s(n);return i.name&&(b.name=i.name),Y(b,i),A.associations.set(b,{materials:e}),i.extensions&&ae(t,b,i),b})}createUniqueName(e){const A=g.PropertyBinding.sanitizeNodeName(e||"");return A in this.nodeNamesUsed?A+"_"+ ++this.nodeNamesUsed[A]:(this.nodeNamesUsed[A]=0,A)}loadGeometries(e){const A=this,a=this.extensions,t=this.primitiveCache;function i(n){return a[M.KHR_DRACO_MESH_COMPRESSION].decodePrimitive(n,A).then(function(d){return sA(d,n,A)})}const s=[];for(let n=0,d=e.length;n<d;n++){const o=e[n],b=pa(o),c=t[b];if(c)s.push(c.promise);else{let h;h=o.extensions&&o.extensions[M.KHR_DRACO_MESH_COMPRESSION]?i(o):sA(new g.BufferGeometry,o,A),t[b]={primitive:o,promise:h},s.push(h)}}return Promise.all(s)}loadMesh(e){const A=this,a=this.json,t=this.extensions,i=a.meshes[e],s=i.primitives,n=[];for(let o=0,b=s.length;o<b;o++){const c=s[o].material===void 0?((d=this.cache).DefaultMaterial===void 0&&(d.DefaultMaterial=new g.MeshStandardMaterial({color:16777215,emissive:0,metalness:1,roughness:1,transparent:!1,depthTest:!0,side:g.FrontSide})),d.DefaultMaterial):this.getDependency("material",s[o].material);n.push(c)}var d;return n.push(A.loadGeometries(s)),Promise.all(n).then(function(o){const b=o.slice(0,o.length-1),c=o[o.length-1],h=[];for(let l=0,u=c.length;l<u;l++){const I=c[l],C=s[l];let B;const m=b[l];if(C.mode===_.TRIANGLES||C.mode===_.TRIANGLE_STRIP||C.mode===_.TRIANGLE_FAN||C.mode===void 0)B=i.isSkinnedMesh===!0?new g.SkinnedMesh(I,m):new g.Mesh(I,m),B.isSkinnedMesh===!0&&B.normalizeSkinWeights(),C.mode===_.TRIANGLE_STRIP?B.geometry=Ze(B.geometry,g.TriangleStripDrawMode):C.mode===_.TRIANGLE_FAN&&(B.geometry=Ze(B.geometry,g.TriangleFanDrawMode));else if(C.mode===_.LINES)B=new g.LineSegments(I,m);else if(C.mode===_.LINE_STRIP)B=new g.Line(I,m);else if(C.mode===_.LINE_LOOP)B=new g.LineLoop(I,m);else{if(C.mode!==_.POINTS)throw new Error("THREE.GLTFLoader: Primitive mode unsupported: "+C.mode);B=new g.Points(I,m)}Object.keys(B.geometry.morphAttributes).length>0&&Ea(B,i),B.name=A.createUniqueName(i.name||"mesh_"+e),Y(B,i),C.extensions&&ae(t,B,C),A.assignFinalMaterial(B),h.push(B)}for(let l=0,u=h.length;l<u;l++)A.associations.set(h[l],{meshes:e,primitives:l});if(h.length===1)return i.extensions&&ae(t,h[0],i),h[0];const f=new g.Group;i.extensions&&ae(t,f,i),A.associations.set(f,{meshes:e});for(let l=0,u=h.length;l<u;l++)f.add(h[l]);return f})}loadCamera(e){let A;const a=this.json.cameras[e],t=a[a.type];if(t)return a.type==="perspective"?A=new g.PerspectiveCamera(g.MathUtils.radToDeg(t.yfov),t.aspectRatio||1,t.znear||1,t.zfar||2e6):a.type==="orthographic"&&(A=new g.OrthographicCamera(-t.xmag,t.xmag,t.ymag,-t.ymag,t.znear,t.zfar)),a.name&&(A.name=this.createUniqueName(a.name)),Y(A,a),Promise.resolve(A);console.warn("THREE.GLTFLoader: Missing camera parameters.")}loadSkin(e){const A=this.json.skins[e],a=[];for(let t=0,i=A.joints.length;t<i;t++)a.push(this._loadNodeShallow(A.joints[t]));return A.inverseBindMatrices!==void 0?a.push(this.getDependency("accessor",A.inverseBindMatrices)):a.push(null),Promise.all(a).then(function(t){const i=t.pop(),s=t,n=[],d=[];for(let o=0,b=s.length;o<b;o++){const c=s[o];if(c){n.push(c);const h=new g.Matrix4;i!==null&&h.fromArray(i.array,16*o),d.push(h)}else console.warn('THREE.GLTFLoader: Joint "%s" could not be found.',A.joints[o])}return new g.Skeleton(n,d)})}loadAnimation(e){const A=this.json,a=this,t=A.animations[e],i=t.name?t.name:"animation_"+e,s=[],n=[],d=[],o=[],b=[];for(let c=0,h=t.channels.length;c<h;c++){const f=t.channels[c],l=t.samplers[f.sampler],u=f.target,I=u.node,C=t.parameters!==void 0?t.parameters[l.input]:l.input,B=t.parameters!==void 0?t.parameters[l.output]:l.output;u.node!==void 0&&(s.push(this.getDependency("node",I)),n.push(this.getDependency("accessor",C)),d.push(this.getDependency("accessor",B)),o.push(l),b.push(u))}return Promise.all([Promise.all(s),Promise.all(n),Promise.all(d),Promise.all(o),Promise.all(b)]).then(function(c){const h=c[0],f=c[1],l=c[2],u=c[3],I=c[4],C=[];for(let B=0,m=h.length;B<m;B++){const E=h[B],j=f[B],k=l[B],w=u[B],p=I[B];if(E===void 0)continue;E.updateMatrix&&E.updateMatrix();const y=a._createAnimationTracks(E,j,k,w,p);if(y)for(let x=0;x<y.length;x++)C.push(y[x])}return new g.AnimationClip(i,void 0,C)})}createNodeMesh(e){const A=this.json,a=this,t=A.nodes[e];return t.mesh===void 0?null:a.getDependency("mesh",t.mesh).then(function(i){const s=a._getNodeRef(a.meshCache,t.mesh,i);return t.weights!==void 0&&s.traverse(function(n){if(n.isMesh)for(let d=0,o=t.weights.length;d<o;d++)n.morphTargetInfluences[d]=t.weights[d]}),s})}loadNode(e){const A=this,a=this.json.nodes[e],t=A._loadNodeShallow(e),i=[],s=a.children||[];for(let d=0,o=s.length;d<o;d++)i.push(A.getDependency("node",s[d]));const n=a.skin===void 0?Promise.resolve(null):A.getDependency("skin",a.skin);return Promise.all([t,Promise.all(i),n]).then(function(d){const o=d[0],b=d[1],c=d[2];c!==null&&o.traverse(function(h){h.isSkinnedMesh&&h.bind(c,ma)});for(let h=0,f=b.length;h<f;h++)o.add(b[h]);return o})}_loadNodeShallow(e){const A=this.json,a=this.extensions,t=this;if(this.nodeCache[e]!==void 0)return this.nodeCache[e];const i=A.nodes[e],s=i.name?t.createUniqueName(i.name):"",n=[],d=t._invokeOne(function(o){return o.createNodeMesh&&o.createNodeMesh(e)});return d&&n.push(d),i.camera!==void 0&&n.push(t.getDependency("camera",i.camera).then(function(o){return t._getNodeRef(t.cameraCache,i.camera,o)})),t._invokeAll(function(o){return o.createNodeAttachment&&o.createNodeAttachment(e)}).forEach(function(o){n.push(o)}),this.nodeCache[e]=Promise.all(n).then(function(o){let b;if(b=i.isBone===!0?new g.Bone:o.length>1?new g.Group:o.length===1?o[0]:new g.Object3D,b!==o[0])for(let c=0,h=o.length;c<h;c++)b.add(o[c]);if(i.name&&(b.userData.name=i.name,b.name=s),Y(b,i),i.extensions&&ae(a,b,i),i.matrix!==void 0){const c=new g.Matrix4;c.fromArray(i.matrix),b.applyMatrix4(c)}else i.translation!==void 0&&b.position.fromArray(i.translation),i.rotation!==void 0&&b.quaternion.fromArray(i.rotation),i.scale!==void 0&&b.scale.fromArray(i.scale);return t.associations.has(b)||t.associations.set(b,{}),t.associations.get(b).nodes=e,b}),this.nodeCache[e]}loadScene(e){const A=this.extensions,a=this.json.scenes[e],t=this,i=new g.Group;a.name&&(i.name=t.createUniqueName(a.name)),Y(i,a),a.extensions&&ae(A,i,a);const s=a.nodes||[],n=[];for(let d=0,o=s.length;d<o;d++)n.push(t.getDependency("node",s[d]));return Promise.all(n).then(function(d){for(let o=0,b=d.length;o<b;o++)i.add(d[o]);return t.associations=(o=>{const b=new Map;for(const[c,h]of t.associations)(c instanceof g.Material||c instanceof g.Texture)&&b.set(c,h);return o.traverse(c=>{const h=t.associations.get(c);h!=null&&b.set(c,h)}),b})(i),i})}_createAnimationTracks(e,A,a,t,i){const s=[],n=e.name?e.name:e.uuid,d=[];let o;switch(Z[i.path]===Z.weights?e.traverse(function(h){h.morphTargetInfluences&&d.push(h.name?h.name:h.uuid)}):d.push(n),Z[i.path]){case Z.weights:o=g.NumberKeyframeTrack;break;case Z.rotation:o=g.QuaternionKeyframeTrack;break;case Z.position:case Z.scale:o=g.VectorKeyframeTrack;break;default:a.itemSize===1?o=g.NumberKeyframeTrack:o=g.VectorKeyframeTrack}const b=t.interpolation!==void 0?Ia[t.interpolation]:g.InterpolateLinear,c=this._getArrayFromAccessor(a);for(let h=0,f=d.length;h<f;h++){const l=new o(d[h]+"."+Z[i.path],A.array,c,b);t.interpolation==="CUBICSPLINE"&&this._createCubicSplineTrackInterpolant(l),s.push(l)}return s}_getArrayFromAccessor(e){let A=e.array;if(e.normalized){const a=we(A.constructor),t=new Float32Array(A.length);for(let i=0,s=A.length;i<s;i++)t[i]=A[i]*a;A=t}return A}_createCubicSplineTrackInterpolant(e){e.createInterpolant=function(A){return new(this instanceof g.QuaternionKeyframeTrack?fa:aA)(this.times,this.values,this.getValueSize()/3,A)},e.createInterpolant.isInterpolantFactoryMethodGLTFCubicSpline=!0}}function sA(r,e,A){const a=e.attributes,t=[];function i(s,n){return A.getDependency("accessor",s).then(function(d){r.setAttribute(n,d)})}for(const s in a){const n=Qe[s]||s.toLowerCase();n in r.attributes||t.push(i(a[s],n))}if(e.indices!==void 0&&!r.index){const s=A.getDependency("accessor",e.indices).then(function(n){r.setIndex(n)});t.push(s)}return g.ColorManagement.workingColorSpace!==g.LinearSRGBColorSpace&&"COLOR_0"in a&&console.warn(`THREE.GLTFLoader: Converting vertex colors from "srgb-linear" to "${g.ColorManagement.workingColorSpace}" not supported.`),Y(r,e),function(s,n,d){const o=n.attributes,b=new g.Box3;if(o.POSITION===void 0)return;{const f=d.json.accessors[o.POSITION],l=f.min,u=f.max;if(l===void 0||u===void 0)return void console.warn("THREE.GLTFLoader: Missing min/max properties for accessor POSITION.");if(b.set(new g.Vector3(l[0],l[1],l[2]),new g.Vector3(u[0],u[1],u[2])),f.normalized){const I=we(re[f.componentType]);b.min.multiplyScalar(I),b.max.multiplyScalar(I)}}const c=n.targets;if(c!==void 0){const f=new g.Vector3,l=new g.Vector3;for(let u=0,I=c.length;u<I;u++){const C=c[u];if(C.POSITION!==void 0){const B=d.json.accessors[C.POSITION],m=B.min,E=B.max;if(m!==void 0&&E!==void 0){if(l.setX(Math.max(Math.abs(m[0]),Math.abs(E[0]))),l.setY(Math.max(Math.abs(m[1]),Math.abs(E[1]))),l.setZ(Math.max(Math.abs(m[2]),Math.abs(E[2]))),B.normalized){const j=we(re[B.componentType]);l.multiplyScalar(j)}f.max(l)}else console.warn("THREE.GLTFLoader: Missing min/max properties for accessor POSITION.")}}b.expandByVector(f)}s.boundingBox=b;const h=new g.Sphere;b.getCenter(h.center),h.radius=b.min.distanceTo(b.max)/2,s.boundingSphere=h}(r,e,A),Promise.all(t).then(function(){return e.targets!==void 0?function(s,n,d){let o=!1,b=!1,c=!1;for(let u=0,I=n.length;u<I;u++){const C=n[u];if(C.POSITION!==void 0&&(o=!0),C.NORMAL!==void 0&&(b=!0),C.COLOR_0!==void 0&&(c=!0),o&&b&&c)break}if(!o&&!b&&!c)return Promise.resolve(s);const h=[],f=[],l=[];for(let u=0,I=n.length;u<I;u++){const C=n[u];if(o){const B=C.POSITION!==void 0?d.getDependency("accessor",C.POSITION):s.attributes.position;h.push(B)}if(b){const B=C.NORMAL!==void 0?d.getDependency("accessor",C.NORMAL):s.attributes.normal;f.push(B)}if(c){const B=C.COLOR_0!==void 0?d.getDependency("accessor",C.COLOR_0):s.attributes.color;l.push(B)}}return Promise.all([Promise.all(h),Promise.all(f),Promise.all(l)]).then(function(u){const I=u[0],C=u[1],B=u[2];return o&&(s.morphAttributes.position=I),b&&(s.morphAttributes.normal=C),c&&(s.morphAttributes.color=B),s.morphTargetsRelative=!0,s})}(r,e.targets,A):r})}const ke=new WeakMap;class rA extends g.Loader{constructor(e){super(e),this.decoderPath="",this.decoderConfig={},this.decoderBinary=null,this.decoderPending=null,this.workerLimit=4,this.workerPool=[],this.workerNextTaskID=1,this.workerSourceURL="",this.defaultAttributeIDs={position:"POSITION",normal:"NORMAL",color:"COLOR",uv:"TEX_COORD"},this.defaultAttributeTypes={position:"Float32Array",normal:"Float32Array",color:"Float32Array",uv:"Float32Array"}}setDecoderPath(e){return this.decoderPath=e,this}setDecoderConfig(e){return this.decoderConfig=e,this}setWorkerLimit(e){return this.workerLimit=e,this}load(e,A,a,t){const i=new g.FileLoader(this.manager);i.setPath(this.path),i.setResponseType("arraybuffer"),i.setRequestHeader(this.requestHeader),i.setWithCredentials(this.withCredentials),i.load(e,s=>{this.parse(s,A,t)},a,t)}parse(e,A,a=()=>{}){this.decodeDracoFile(e,A,null,null,g.SRGBColorSpace,a).catch(a)}decodeDracoFile(e,A,a,t,i=g.LinearSRGBColorSpace,s=()=>{}){const n={attributeIDs:a||this.defaultAttributeIDs,attributeTypes:t||this.defaultAttributeTypes,useUniqueIDs:!!a,vertexColorSpace:i};return this.decodeGeometry(e,n).then(A).catch(s)}decodeGeometry(e,A){const a=JSON.stringify(A);if(ke.has(e)){const d=ke.get(e);if(d.key===a)return d.promise;if(e.byteLength===0)throw new Error("THREE.DRACOLoader: Unable to re-decode a buffer with different settings. Buffer has already been transferred.")}let t;const i=this.workerNextTaskID++,s=e.byteLength,n=this._getWorker(i,s).then(d=>(t=d,new Promise((o,b)=>{t._callbacks[i]={resolve:o,reject:b},t.postMessage({type:"decode",id:i,taskConfig:A,buffer:e},[e])}))).then(d=>this._createGeometry(d.geometry));return n.catch(()=>!0).then(()=>{t&&i&&this._releaseTask(t,i)}),ke.set(e,{key:a,promise:n}),n}_createGeometry(e){const A=new g.BufferGeometry;e.index&&A.setIndex(new g.BufferAttribute(e.index.array,1));for(let a=0;a<e.attributes.length;a++){const t=e.attributes[a],i=t.name,s=t.array,n=t.itemSize,d=new g.BufferAttribute(s,n);i==="color"&&(this._assignVertexColorSpace(d,t.vertexColorSpace),d.normalized=!(s instanceof Float32Array)),A.setAttribute(i,d)}return A}_assignVertexColorSpace(e,A){if(A!==g.SRGBColorSpace)return;const a=new g.Color;for(let t=0,i=e.count;t<i;t++)a.fromBufferAttribute(e,t),g.ColorManagement.toWorkingColorSpace(a,g.SRGBColorSpace),e.setXYZ(t,a.r,a.g,a.b)}_loadLibrary(e,A){const a=new g.FileLoader(this.manager);return a.setPath(this.decoderPath),a.setResponseType(A),a.setWithCredentials(this.withCredentials),new Promise((t,i)=>{a.load(e,t,void 0,i)})}preload(){return this._initDecoder(),this}_initDecoder(){if(this.decoderPending)return this.decoderPending;const e=typeof WebAssembly!="object"||this.decoderConfig.type==="js",A=[];return e?A.push(this._loadLibrary("draco_decoder.js","text")):(A.push(this._loadLibrary("draco_wasm_wrapper.js","text")),A.push(this._loadLibrary("draco_decoder.wasm","arraybuffer"))),this.decoderPending=Promise.all(A).then(a=>{const t=a[0];e||(this.decoderConfig.wasmBinary=a[1]);const i=ya.toString(),s=["/* draco decoder */",t,"","/* worker */",i.substring(i.indexOf("{")+1,i.lastIndexOf("}"))].join(`
19
+ `);this.workerSourceURL=URL.createObjectURL(new Blob([s]))}),this.decoderPending}_getWorker(e,A){return this._initDecoder().then(()=>{if(this.workerPool.length<this.workerLimit){const t=new Worker(this.workerSourceURL);t._callbacks={},t._taskCosts={},t._taskLoad=0,t.postMessage({type:"init",decoderConfig:this.decoderConfig}),t.onmessage=function(i){const s=i.data;switch(s.type){case"decode":t._callbacks[s.id].resolve(s);break;case"error":t._callbacks[s.id].reject(s);break;default:console.error('THREE.DRACOLoader: Unexpected message, "'+s.type+'"')}},this.workerPool.push(t)}else this.workerPool.sort(function(t,i){return t._taskLoad>i._taskLoad?-1:1});const a=this.workerPool[this.workerPool.length-1];return a._taskCosts[e]=A,a._taskLoad+=A,a})}_releaseTask(e,A){e._taskLoad-=e._taskCosts[A],delete e._callbacks[A],delete e._taskCosts[A]}debug(){console.log("Task load: ",this.workerPool.map(e=>e._taskLoad))}dispose(){for(let e=0;e<this.workerPool.length;++e)this.workerPool[e].terminate();return this.workerPool.length=0,this.workerSourceURL!==""&&URL.revokeObjectURL(this.workerSourceURL),this}}function ya(){let r,e;function A(a,t,i,s,n,d){const o=d.num_components(),b=i.num_points()*o,c=b*n.BYTES_PER_ELEMENT,h=function(u,I){switch(I){case Float32Array:return u.DT_FLOAT32;case Int8Array:return u.DT_INT8;case Int16Array:return u.DT_INT16;case Int32Array:return u.DT_INT32;case Uint8Array:return u.DT_UINT8;case Uint16Array:return u.DT_UINT16;case Uint32Array:return u.DT_UINT32}}(a,n),f=a._malloc(c);t.GetAttributeDataArrayForAllPoints(i,d,h,c,f);const l=new n(a.HEAPF32.buffer,f,b).slice();return a._free(f),{name:s,array:l,itemSize:o}}onmessage=function(a){const t=a.data;switch(t.type){case"init":r=t.decoderConfig,e=new Promise(function(n){r.onModuleLoaded=function(d){n({draco:d})},DracoDecoderModule(r)});break;case"decode":const i=t.buffer,s=t.taskConfig;e.then(n=>{const d=n.draco,o=new d.Decoder;try{const b=function(h,f,l,u){const I=u.attributeIDs,C=u.attributeTypes;let B,m;const E=f.GetEncodedGeometryType(l);if(E===h.TRIANGULAR_MESH)B=new h.Mesh,m=f.DecodeArrayToMesh(l,l.byteLength,B);else{if(E!==h.POINT_CLOUD)throw new Error("THREE.DRACOLoader: Unexpected geometry type.");B=new h.PointCloud,m=f.DecodeArrayToPointCloud(l,l.byteLength,B)}if(!m.ok()||B.ptr===0)throw new Error("THREE.DRACOLoader: Decoding failed: "+m.error_msg());const j={index:null,attributes:[]};for(const k in I){const w=self[C[k]];let p,y;if(u.useUniqueIDs)y=I[k],p=f.GetAttributeByUniqueId(B,y);else{if(y=f.GetAttributeId(B,h[I[k]]),y===-1)continue;p=f.GetAttribute(B,y)}const x=A(h,f,B,k,w,p);k==="color"&&(x.vertexColorSpace=u.vertexColorSpace),j.attributes.push(x)}return E===h.TRIANGULAR_MESH&&(j.index=function(k,w,p){const y=p.num_faces(),x=3*y,D=4*x,F=k._malloc(D);w.GetTrianglesUInt32Array(p,D,F);const P=new Uint32Array(k.HEAPF32.buffer,F,x).slice();return k._free(F),{array:P,itemSize:1}}(h,f,B)),h.destroy(B),j}(d,o,new Int8Array(i),s),c=b.attributes.map(h=>h.array.buffer);b.index&&c.push(b.index.array.buffer),self.postMessage({type:"decode",id:t.id,geometry:b},c)}catch(b){console.error(b),self.postMessage({type:"error",id:t.id,error:b.message})}finally{d.destroy(o)}})}}}class wa{constructor(e=4){this.pool=e,this.queue=[],this.workers=[],this.workersResolve=[],this.workerStatus=0}_initWorker(e){if(!this.workers[e]){const A=this.workerCreator();A.addEventListener("message",this._onMessage.bind(this,e)),this.workers[e]=A}}_getIdleWorker(){for(let e=0;e<this.pool;e++)if(!(this.workerStatus&1<<e))return e;return-1}_onMessage(e,A){const a=this.workersResolve[e];if(a&&a(A),this.queue.length){const{resolve:t,msg:i,transfer:s}=this.queue.shift();this.workersResolve[e]=t,this.workers[e].postMessage(i,s)}else this.workerStatus^=1<<e}setWorkerCreator(e){this.workerCreator=e}setWorkerLimit(e){this.pool=e}postMessage(e,A){return new Promise(a=>{const t=this._getIdleWorker();t!==-1?(this._initWorker(t),this.workerStatus|=1<<t,this.workersResolve[t]=a,this.workers[t].postMessage(e,A)):this.queue.push({resolve:a,msg:e,transfer:A})})}dispose(){this.workers.forEach(e=>e.terminate()),this.workersResolve.length=0,this.workers.length=0,this.queue.length=0,this.workerStatus=0}}const nA=9,oA=15,cA=16,dA=22,bA=37,gA=43,hA=76,lA=83,fA=97,IA=100,uA=103,BA=109,CA=165,EA=166,xe=1000066e3;class ka{constructor(){this.vkFormat=0,this.typeSize=1,this.pixelWidth=0,this.pixelHeight=0,this.pixelDepth=0,this.layerCount=0,this.faceCount=1,this.supercompressionScheme=0,this.levels=[],this.dataFormatDescriptor=[{vendorId:0,descriptorType:0,descriptorBlockSize:0,versionNumber:2,colorModel:0,colorPrimaries:1,transferFunction:2,flags:0,texelBlockDimension:[0,0,0,0],bytesPlane:[0,0,0,0,0,0,0,0],samples:[]}],this.keyValue={},this.globalData=null}}class ge{constructor(e,A,a,t){this._dataView=void 0,this._littleEndian=void 0,this._offset=void 0,this._dataView=new DataView(e.buffer,e.byteOffset+A,a),this._littleEndian=t,this._offset=0}_nextUint8(){const e=this._dataView.getUint8(this._offset);return this._offset+=1,e}_nextUint16(){const e=this._dataView.getUint16(this._offset,this._littleEndian);return this._offset+=2,e}_nextUint32(){const e=this._dataView.getUint32(this._offset,this._littleEndian);return this._offset+=4,e}_nextUint64(){const e=this._dataView.getUint32(this._offset,this._littleEndian)+4294967296*this._dataView.getUint32(this._offset+4,this._littleEndian);return this._offset+=8,e}_nextInt32(){const e=this._dataView.getInt32(this._offset,this._littleEndian);return this._offset+=4,e}_nextUint8Array(e){const A=new Uint8Array(this._dataView.buffer,this._dataView.byteOffset+this._offset,e);return this._offset+=e,A}_skip(e){return this._offset+=e,this}_scan(e,A){A===void 0&&(A=0);const a=this._offset;let t=0;for(;this._dataView.getUint8(this._offset)!==A&&t<e;)t++,this._offset++;return t<e&&this._offset++,new Uint8Array(this._dataView.buffer,this._dataView.byteOffset+a,t)}}const v=[171,75,84,88,32,50,48,187,13,10,26,10];function pA(r){return new TextDecoder().decode(r)}let De,W,je;const Me={env:{emscripten_notify_memory_growth:function(r){je=new Uint8Array(W.exports.memory.buffer)}}};class xa{init(){return De||(De=typeof fetch<"u"?fetch("data:application/wasm;base64,"+mA).then(e=>e.arrayBuffer()).then(e=>WebAssembly.instantiate(e,Me)).then(this._init):WebAssembly.instantiate(Buffer.from(mA,"base64"),Me).then(this._init),De)}_init(e){W=e.instance,Me.env.emscripten_notify_memory_growth(0)}decode(e,A=0){if(!W)throw new Error("ZSTDDecoder: Await .init() before decoding.");const a=e.byteLength,t=W.exports.malloc(a);je.set(e,t),A=A||Number(W.exports.ZSTD_findDecompressedSize(t,a));const i=W.exports.malloc(A),s=W.exports.ZSTD_decompress(i,A,t,a),n=je.slice(i,i+s);return W.exports.free(t),W.exports.free(i),n}}const mA="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IAMNACAEQQNxBEADQCACRQ0FIAAgAkF/aiICaiIDIAEgAmotAAA6AAAgA0EDcQ0ACwsgAkEDTQ0AA0AgACACQXxqIgJqIAEgAmooAgA2AgAgAkEDSw0ACwsgAkUNAgNAIAAgAkF/aiICaiABIAJqLQAAOgAAIAINAAsMAgsgAkEDTQ0AIAIhBANAIAMgASgCADYCACABQQRqIQEgA0EEaiEDIARBfGoiBEEDSw0ACyACQQNxIQILIAJFDQADQCADIAEtAAA6AAAgA0EBaiEDIAFBAWohASACQX9qIgINAAsLIAAL8wICAn8BfgJAIAJFDQAgACACaiIDQX9qIAE6AAAgACABOgAAIAJBA0kNACADQX5qIAE6AAAgACABOgABIANBfWogAToAACAAIAE6AAIgAkEHSQ0AIANBfGogAToAACAAIAE6AAMgAkEJSQ0AIABBACAAa0EDcSIEaiIDIAFB/wFxQYGChAhsIgE2AgAgAyACIARrQXxxIgRqIgJBfGogATYCACAEQQlJDQAgAyABNgIIIAMgATYCBCACQXhqIAE2AgAgAkF0aiABNgIAIARBGUkNACADIAE2AhggAyABNgIUIAMgATYCECADIAE2AgwgAkFwaiABNgIAIAJBbGogATYCACACQWhqIAE2AgAgAkFkaiABNgIAIAQgA0EEcUEYciIEayICQSBJDQAgAa0iBUIghiAFhCEFIAMgBGohAQNAIAEgBTcDGCABIAU3AxAgASAFNwMIIAEgBTcDACABQSBqIQEgAkFgaiICQR9LDQALCyAACy8BAn8gACgCBCAAKAIAQQJ0aiICLQACIQMgACACLwEAIAEgAi0AAxAIajYCACADCy8BAn8gACgCBCAAKAIAQQJ0aiICLQACIQMgACACLwEAIAEgAi0AAxAFajYCACADCx8AIAAgASACKAIEEAg2AgAgARAEGiAAIAJBCGo2AgQLCAAgAGdBH3MLugUBDX8jAEEQayIKJAACfyAEQQNNBEAgCkEANgIMIApBDGogAyAEEAsaIAAgASACIApBDGpBBBAVIgBBbCAAEAMbIAAgACAESxsMAQsgAEEAIAEoAgBBAXRBAmoQECENQVQgAygAACIGQQ9xIgBBCksNABogAiAAQQVqNgIAIAMgBGoiAkF8aiEMIAJBeWohDiACQXtqIRAgAEEGaiELQQQh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ASIDNgLE4AEgACgCvOABIQQgACABNgK84AEgACABIAJqNgK44AEgACABIAQgA2tqNgLA4AELpgEBAX8gACAAKALs4QEQFjYCyOABIABCADcD+OABIABCADcDuOABIABBwOABakIANwMAIABBqNAAaiIBQYyAgOAANgIAIABBADYCmOIBIABCADcDiOEBIABCAzcDgOEBIABBrNABakHgEikCADcCACAAQbTQAWpB6BIoAgA2AgAgACABNgIMIAAgAEGYIGo2AgggACAAQaAwajYCBCAAIABBEGo2AgALYQEBf0G4fyEDAkAgAUEDSQ0AIAIgABAhIgFBA3YiADYCCCACIAFBAXE2AgQgAiABQQF2QQNxIgM2AgACQCADQX9qIgFBAksNAAJAIAFBAWsOAgEAAgtBbA8LIAAhAwsgAwsMACAAIAEgAkEAEC4LiAQCA38CfiADEBYhBCAAQQBBKBAQIQAgBCACSwRAIAQPCyABRQRAQX8PCwJAAkAgA0EBRg0AIAEoAAAiBkGo6r5pRg0AQXYhAyAGQXBxQdDUtMIBRw0BQQghAyACQQhJDQEgAEEAQSgQECEAIAEoAAQhASAAQQE2AhQgACABrTcDAEEADwsgASACIAMQLyIDIAJLDQAgACADNgIYQXIhAyABIARqIgVBf2otAAAiAkEIcQ0AIAJBIHEiBkUEQEFwIQMgBS0AACIFQacBSw0BIAVBB3GtQgEgBUEDdkEKaq2GIgdCA4h+IAd8IQggBEEBaiEECyACQQZ2IQMgAkECdiEFAkAgAkEDcUF/aiICQQJLBEBBACECDAELAkACQAJAIAJBAWsOAgECAAsgASAEai0AACECIARBAWohBAwCCyABIARqLwAAIQIgBEECaiEEDAELIAEgBGooAAAhAiAEQQRqIQQLIAVBAXEhBQJ+AkACQAJAIANBf2oiA0ECTQRAIANBAWsOAgIDAQtCfyAGRQ0DGiABIARqMQAADAMLIAEgBGovAACtQoACfAwCCyABIARqKAAArQwBCyABIARqKQAACyEHIAAgBTYCICAAIAI2AhwgACAHNwMAQQAhAyAAQQA2AhQgACAHIAggBhsiBzcDCCAAIAdCgIAIIAdCgIAIVBs+AhALIAMLWwEBf0G4fyEDIAIQFiICIAFNBH8gACACakF/ai0AACIAQQNxQQJ0QaAeaigC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C0Egak8NAQsgByAHKQNoNwMQIAcgBykDYDcDCCAEIA0gB0EIaiAHQdwAaiAPIA4gESAQEB4hCwwBCyACIARqIQggBCAKEAcgAkERTwRAIARBEGohAgNAIAIgCkEQaiIKEAcgAkEQaiICIAhJDQALCyAIIAlrIQIgByATNgJcIAkgCCAOa0sEQCAJIAggEWtLBEBBbCELDAILIBAgAiAOayICaiIKIANqIBBNBEAgCCAKIAMQDxoMAgsgCCAKQQAgAmsQDyEIIAcgAiADaiIDNgJkIAggAmshCCAOIQILIAlBEE8EQCADIAhqIQMDQCAIIAIQByACQRBqIQIgCEEQaiIIIANJDQALDAELAkAgCUEHTQRAIAggAi0AADoAACAIIAItAAE6AAEgCCACLQACOgACIAggAi0AAzoAAyAIQQRqIAIgCUECdCIDQcAeaigCAGoiAhAXIAIgA0HgHmooAgBrIQIgBygCZCEDDAELIAggAhAMCyADQQlJDQAgAyAIaiEDIAhBCGoiCCACQQhqIgJrQQ9MBEADQCAIIAIQDCACQQhqIQIgCEEIaiIIIANJDQAMAgALAAsDQCAIIAIQByACQRBqIQIgCEEQaiIIIANJDQALCyAHQRhqEAQaIAsgDCALEAMiAhshDCAEIAQgC2ogAhshBCAFQX9qIgUNAAsgDBADDQFBbCEMIAdBGGoQBEECSQ0BQQAhCANAIAhBA0cEQCAAIAhBAnQiAmpBrNABaiACIAdqKAJENgIAIAhBAWohCAwBCwsgBygCXCEIC0G6fyEMIA8gCGsiACANIARrSw0AIAQEfyAEIAggABALIABqBUEACyABayEMCyAHQfAAaiQAIAwLkRcCFn8FfiMAQdABayIHJAAgByAAKALw4QEiCDYCvAEgASACaiESIAggACgCgOIBaiETAkACQCAFRQRAIAEhAwwBCyAAKALE4AEhESAAKALA4AEhFSAAKAK84AEhDyAAQQE2AozhAUEAIQgDQCAIQQNHBEAgByAIQQJ0IgJqIAAgAmpBrNABaigCADYCVCAIQQFqIQgMAQsLIAcgETYCZCAHIA82AmAgByABIA9rNgJoQWwhECAHQShqIAMgBBAGEAMNASAFQQQgBUEESBshFyAHQTxqIAdBKGogACgCABATIAdBxABqIAdBKGogACgCCBATIAdBzABqIAdB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IAdB0AFqJAAgEAslACAAQgA3AgAgAEEAOwEIIABBADoACyAAIAE2AgwgACACOgAKC7QFAQN/IwBBMGsiBCQAIABB/wFqIgVBfWohBgJAIAMvAQIEQCAEQRhqIAEgAhAGIgIQAw0BIARBEGogBEEYaiADEBwgBEEIaiAEQRhqIAMQHCAAIQMDQAJAIARBGGoQBCADIAZPckUEQCADIARBEGogBEEYahASOgAAIAMgBEEIaiAEQRhqEBI6AAEgBEEYahAERQ0BIANBAmohAwsgBUF+aiEFAn8DQEG6fyECIAMiASAFSw0FIAEgBEEQaiAEQRhqEBI6AAAgAUEBaiEDIARBGGoQBEEDRgRAQQIhAiAEQQhqDAILIAMgBUsNBSABIARBCGogBEEYahASOgABIAFBAmohA0EDIQIgBEEYahAEQQNHDQALIARBEGoLIQUgAyAFIARBGGoQEjoAACABIAJqIABrIQIMAwsgAyAEQRBqIARBGGoQEjoAAiADIARBCGogBEEYahASOgADIANBBGohAwwAAAsACyAEQRhqIAEgAhAGIgIQAw0AIARBEGogBEEYaiADEBwgBEEIaiAEQRhqIAMQHCAAIQMDQAJAIARBGGoQBCADIAZPckUEQCADIARBEGogBEEYahAROgAAIAMgBEEIaiAEQRhqEBE6AAEgBEEYahAERQ0BIANBAmohAwsgBUF+aiEFAn8DQEG6fyECIAMiASAFSw0EIAEgBEEQaiAEQRhqEBE6AAAgAUEBaiEDIARBGGoQBEEDRgRAQQIhAiAEQQhqDAILIAMgBUsNBCABIARBCGogBEEYahAROgABIAFBAmohA0EDIQIgBEEYahAEQQNHDQALIARBEGoLIQUgAyAFIARBGGoQEToAACABIAJqIABrIQIMAgsgAyAEQRBqIARBGGoQEToAAiADIARBCGogBEEYahAROgADIANBBGohAwwAAAsACyAEQTBqJAAgAgtpAQF/An8CQAJAIAJBB00NACABKAAAQbfIwuF+Rw0AIAAgASgABDYCmOIBQWIgAEEQaiABIAIQPiIDEAMNAhogAEKBgICAEDcDiOEBIAAgASADaiACIANrECoMAQsgACABIAIQKgtBAAsLrQMBBn8jAEGAAWsiAyQAQWIhCAJAIAJBCUkNACAAQZjQAGogAUEIaiIEIAJBeGogAEGY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wOABCwutAgIEfwF+IwBBQGoiBCQAAkACQCACQQhJDQAgASgAAEFwcUHQ1LTCAUcNACABIAIQIiEBIABCADcDCCAAQQA2AgQgACABNgIADAELIARBGGogASACEC0iAxADBEAgACADEBoMAQsgAwRAIABBuH8QGgwBCyACIAQoAjAiA2shAiABIANqIQMDQAJAIAAgAyACIARBCGoQLCIFEAMEfyAFBSACIAVBA2oiBU8NAUG4fwsQGgwCCyAGQQFqIQYgAiAFayECIAMgBWohAyAEKAIMRQ0ACyAEKAI4BEAgAkEDTQRAIABBuH8QGgwCCyADQQRqIQMLIAQoAighAiAEKQMYIQcgAEEANgIEIAAgAyABazYCACAAIAIgBmytIAcgB0J/URs3AwgLIARBQGskAAslAQF/IwBBEGsiAiQAIAIgACABEFEgAigCACEAIAJBEGokACAAC30BBH8jAEGQBGsiBCQAIARB/wE2AggCQCAEQRBqIARBCGogBEEMaiABIAIQFSIGEAMEQCAGIQUMAQtBVCEFIAQoAgwiB0EGSw0AIAMgBEEQaiAEKAIIIAcQQSIFEAMNACAAIAEgBmogAiAGayADEDwhBQsgBEGQBGokACAFC4cBAgJ/An5BABAWIQMCQANAIAEgA08EQAJAIAAoAABBcHFB0NS0wgFGBEAgACABECIiAhADRQ0BQn4PCyAAIAEQVSIEQn1WDQMgBCAFfCIFIARUIQJCfiEEIAINAyAAIAEQUiICEAMNAwsgASACayEBIAAgAmohAAwBCwtCfiAFIAEbIQQLIAQLPwIBfwF+IwBBMGsiAiQAAn5CfiACQQhqIAAgARAtDQAaQgAgAigCHEEBRg0AGiACKQMICyEDIAJBMGokACADC40BAQJ/IwBBMGsiASQAAkAgAEUNACAAKAKI4gENACABIABB/OEBaigCADYCKCABIAApAvThATcDICAAEDAgACgCqOIBIQIgASABKAIoNgIYIAEgASkDIDcDECACIAFBEGoQGyAAQQA2AqjiASABIAEoAig2AgggASABKQMgNwMAIAAgARAbCyABQTBqJAALKgECfyMAQRBrIgAkACAAQQA2AgggAEIANwMAIAAQWCEBIABBEGokACABC4cBAQN/IwBBEGsiAiQAAkAgACgCAEUgACgCBEVzDQAgAiAAKAIINgIIIAIgACkCADcDAAJ/IAIoAgAiAQRAIAIoAghBqOMJIAERBQAMAQtBqOMJECgLIgFFDQAgASAAKQIANwL04QEgAUH84QFqIAAoAgg2AgAgARBZIAEhAwsgAkEQaiQAIAMLywEBAn8jAEEgayIBJAAgAEGBgIDAADYCtOIBIABBADYCiOIBIABBADYC7OEBIABCADcDkOIBIABBADYCpOMJIABBADYC3OIBIABCADcCzOIBIABBADYCvOIBIABBADYCxOABIABCADcCnOIBIABBpOIBakIANwIAIABBrOIBakEANgIAIAFCADcCECABQgA3AhggASABKQMYNwMIIAEgASkDEDcDACABKAIIQQh2QQFxIQIgAEEANgLg4gEgACACNgKM4gEgAUEgaiQAC3YBA38jAEEwayIBJAAgAARAIAEgAEHE0AFqIgIoAgA2AiggASAAKQK80AE3AyAgACgCACEDIAEgAigCADYCGCABIAApArzQATcDECADIAFBEGoQGyABIAEoAig2AgggASABKQMgNwMAIAAgARAbCyABQTBqJAALzAEBAX8gACABKAK00AE2ApjiASAAIAEoAgQiAjYCwOABIAAgAjYCvOABIAAgAiABKAIIaiICNgK44AEgACACNgLE4AEgASgCuNABBEAgAEKBgICAEDcDiOEBIAAgAUGk0ABqNgIMIAAgAUGUIGo2AgggACABQZwwajYCBCAAIAFBDGo2AgAgAEGs0AFqIAFBqNABaigCADYCACAAQbDQAWogAUGs0AFqKAIANgIAIABBtNABaiABQbDQAWooAgA2AgAPCyAAQgA3A4jhAQs7ACACRQRAQbp/DwsgBEUEQEFsDwsgAiAEEGAEQCAAIAEgAiADIAQgBRBhDwsgACABIAIgAyAEIAUQZQtGAQF/IwBBEGsiBSQAIAVBCGogBBAOAn8gBS0ACQRAIAAgASACIAMgBBAyDAELIAAgASACIAMgBBA0CyEAIAVBEGokACAACzQAIAAgAyAEIAUQNiIFEAMEQCAFDwsgBSAESQR/IAEgAiADIAVqIAQgBWsgABA1BUG4fwsLRgEBfyMAQRBrIgUkACAFQQhqIAQQDgJ/IAUtAAkEQCAAIAEgAiADIAQQYgwBCyAAIAEgAiADIAQQNQshACAFQRBqJAAgAAtZAQF/QQ8hAiABIABJBEAgAUEE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",Re=new WeakMap;let Fe,Se=0;class N extends g.Loader{constructor(e){super(e),this.transcoderPath="",this.transcoderBinary=null,this.transcoderPending=null,this.workerPool=new wa,this.workerSourceURL="",this.workerConfig=null,typeof MSC_TRANSCODER<"u"&&console.warn('THREE.KTX2Loader: Please update to latest "basis_transcoder". "msc_basis_transcoder" is no longer supported in three.js r125+.')}setTranscoderPath(e){return this.transcoderPath=e,this}setWorkerLimit(e){return this.workerPool.setWorkerLimit(e),this}async detectSupportAsync(e){return this.workerConfig={astcSupported:await e.hasFeatureAsync("texture-compression-astc"),astcHDRSupported:!1,etc1Supported:await e.hasFeatureAsync("texture-compression-etc1"),etc2Supported:await e.hasFeatureAsync("texture-compression-etc2"),dxtSupported:await e.hasFeatureAsync("texture-compression-bc"),bptcSupported:await e.hasFeatureAsync("texture-compression-bptc"),pvrtcSupported:await e.hasFeatureAsync("texture-compression-pvrtc")},this}detectSupport(e){return e.isWebGPURenderer===!0?this.workerConfig={astcSupported:e.hasFeature("texture-compression-astc"),astcHDRSupported:!1,etc1Supported:e.hasFeature("texture-compression-etc1"),etc2Supported:e.hasFeature("texture-compression-etc2"),dxtSupported:e.hasFeature("texture-compression-bc"),bptcSupported:e.hasFeature("texture-compression-bptc"),pvrtcSupported:e.hasFeature("texture-compression-pvrtc")}:this.workerConfig={astcSupported:e.extensions.has("WEBGL_compressed_texture_astc"),astcHDRSupported:e.extensions.has("WEBGL_compressed_texture_astc")&&e.extensions.get("WEBGL_compressed_texture_astc").getSupportedProfiles().includes("hdr"),etc1Supported:e.extensions.has("WEBGL_compressed_texture_etc1"),etc2Supported:e.extensions.has("WEBGL_compressed_texture_etc"),dxtSupported:e.extensions.has("WEBGL_compressed_texture_s3tc"),bptcSupported:e.extensions.has("EXT_texture_compression_bptc"),pvrtcSupported:e.extensions.has("WEBGL_compressed_texture_pvrtc")||e.extensions.has("WEBKIT_WEBGL_compressed_texture_pvrtc")},this}init(){if(!this.transcoderPending){const e=new g.FileLoader(this.manager);e.setPath(this.transcoderPath),e.setWithCredentials(this.withCredentials);const A=e.loadAsync("basis_transcoder.js"),a=new g.FileLoader(this.manager);a.setPath(this.transcoderPath),a.setResponseType("arraybuffer"),a.setWithCredentials(this.withCredentials);const t=a.loadAsync("basis_transcoder.wasm");this.transcoderPending=Promise.all([A,t]).then(([i,s])=>{const n=N.BasisWorker.toString(),d=["/* constants */","let _EngineFormat = "+JSON.stringify(N.EngineFormat),"let _EngineType = "+JSON.stringify(N.EngineType),"let _TranscoderFormat = "+JSON.stringify(N.TranscoderFormat),"let _BasisFormat = "+JSON.stringify(N.BasisFormat),"/* basis_transcoder.js */",i,"/* worker */",n.substring(n.indexOf("{")+1,n.lastIndexOf("}"))].join(`
20
+ `);this.workerSourceURL=URL.createObjectURL(new Blob([d])),this.transcoderBinary=s,this.workerPool.setWorkerCreator(()=>{const o=new Worker(this.workerSourceURL),b=this.transcoderBinary.slice(0);return o.postMessage({type:"init",config:this.workerConfig,transcoderBinary:b},[b]),o})}),Se>0&&console.warn("THREE.KTX2Loader: Multiple active KTX2 loaders may cause performance issues. Use a single KTX2Loader instance, or call .dispose() on old instances."),Se++}return this.transcoderPending}load(e,A,a,t){if(this.workerConfig===null)throw new Error("THREE.KTX2Loader: Missing initialization with `.detectSupport( renderer )`.");const i=new g.FileLoader(this.manager);i.setResponseType("arraybuffer"),i.setWithCredentials(this.withCredentials),i.load(e,s=>{this.parse(s,A,t)},a,t)}parse(e,A,a){if(this.workerConfig===null)throw new Error("THREE.KTX2Loader: Missing initialization with `.detectSupport( renderer )`.");if(Re.has(e))return Re.get(e).promise.then(A).catch(a);this._createTexture(e).then(t=>A?A(t):null).catch(a)}_createTextureFrom(e,A){const{type:a,error:t,data:{faces:i,width:s,height:n,format:d,type:o,dfdFlags:b}}=e;if(a==="error")return Promise.reject(t);let c;if(A.faceCount===6)c=new g.CompressedCubeTexture(i,d,o);else{const h=i[0].mipmaps;c=A.layerCount>1?new g.CompressedArrayTexture(h,s,n,A.layerCount,d,o):new g.CompressedTexture(h,s,n,d,o)}return c.minFilter=i[0].mipmaps.length===1?g.LinearFilter:g.LinearMipmapLinearFilter,c.magFilter=g.LinearFilter,c.generateMipmaps=!1,c.needsUpdate=!0,c.colorSpace=QA(A),c.premultiplyAlpha=!!(1&b),c}async _createTexture(e,A={}){const a=function(n){const d=new Uint8Array(n.buffer,n.byteOffset,v.length);if(d[0]!==v[0]||d[1]!==v[1]||d[2]!==v[2]||d[3]!==v[3]||d[4]!==v[4]||d[5]!==v[5]||d[6]!==v[6]||d[7]!==v[7]||d[8]!==v[8]||d[9]!==v[9]||d[10]!==v[10]||d[11]!==v[11])throw new Error("Missing KTX 2.0 identifier.");const o=new ka,b=17*Uint32Array.BYTES_PER_ELEMENT,c=new ge(n,v.length,b,!0);o.vkFormat=c._nextUint32(),o.typeSize=c._nextUint32(),o.pixelWidth=c._nextUint32(),o.pixelHeight=c._nextUint32(),o.pixelDepth=c._nextUint32(),o.layerCount=c._nextUint32(),o.faceCount=c._nextUint32();const h=c._nextUint32();o.supercompressionScheme=c._nextUint32();const f=c._nextUint32(),l=c._nextUint32(),u=c._nextUint32(),I=c._nextUint32(),C=c._nextUint64(),B=c._nextUint64(),m=new ge(n,v.length+b,3*h*8,!0);for(let R=0;R<h;R++)o.levels.push({levelData:new Uint8Array(n.buffer,n.byteOffset+m._nextUint64(),m._nextUint64()),uncompressedByteLength:m._nextUint64()});const E=new ge(n,f,l,!0),j={vendorId:E._skip(4)._nextUint16(),descriptorType:E._nextUint16(),versionNumber:E._nextUint16(),descriptorBlockSize:E._nextUint16(),colorModel:E._nextUint8(),colorPrimaries:E._nextUint8(),transferFunction:E._nextUint8(),flags:E._nextUint8(),texelBlockDimension:[E._nextUint8(),E._nextUint8(),E._nextUint8(),E._nextUint8()],bytesPlane:[E._nextUint8(),E._nextUint8(),E._nextUint8(),E._nextUint8(),E._nextUint8(),E._nextUint8(),E._nextUint8(),E._nextUint8()],samples:[]},k=(j.descriptorBlockSize/4-6)/4;for(let R=0;R<k;R++){const G={bitOffset:E._nextUint16(),bitLength:E._nextUint8(),channelType:E._nextUint8(),samplePosition:[E._nextUint8(),E._nextUint8(),E._nextUint8(),E._nextUint8()],sampleLower:-1/0,sampleUpper:1/0};64&G.channelType?(G.sampleLower=E._nextInt32(),G.sampleUpper=E._nextInt32()):(G.sampleLower=E._nextUint32(),G.sampleUpper=E._nextUint32()),j.samples[R]=G}o.dataFormatDescriptor.length=0,o.dataFormatDescriptor.push(j);const w=new ge(n,u,I,!0);for(;w._offset<I;){const R=w._nextUint32(),G=w._scan(R),H=pA(G);if(o.keyValue[H]=w._nextUint8Array(R-G.byteLength-1),H.match(/^ktx/i)){const z=pA(o.keyValue[H]);o.keyValue[H]=z.substring(0,z.lastIndexOf("\0"))}w._skip(R%4?4-R%4:0)}if(B<=0)return o;const p=new ge(n,C,B,!0),y=p._nextUint16(),x=p._nextUint16(),D=p._nextUint32(),F=p._nextUint32(),P=p._nextUint32(),ze=p._nextUint32(),le=[];for(let R=0;R<h;R++)le.push({imageFlags:p._nextUint32(),rgbSliceByteOffset:p._nextUint32(),rgbSliceByteLength:p._nextUint32(),alphaSliceByteOffset:p._nextUint32(),alphaSliceByteLength:p._nextUint32()});const Ce=C+p._offset,fe=Ce+D,Ie=fe+F,ue=Ie+P,Ee=new Uint8Array(n.buffer,n.byteOffset+Ce,D),pe=new Uint8Array(n.buffer,n.byteOffset+fe,F),V=new Uint8Array(n.buffer,n.byteOffset+Ie,P),oe=new Uint8Array(n.buffer,n.byteOffset+ue,ze);return o.globalData={endpointCount:y,selectorCount:x,imageDescs:le,endpointsData:Ee,selectorsData:pe,tablesData:V,extendedData:oe},o}(new Uint8Array(e)),t=a.vkFormat===xe&&a.dataFormatDescriptor[0].colorModel===167;if(!(a.vkFormat===0||t&&!this.workerConfig.astcHDRSupported))return async function(n){const{vkFormat:d}=n;if(Te[d]===void 0)throw new Error("THREE.KTX2Loader: Unsupported vkFormat.");let o;n.supercompressionScheme===2&&(Fe||(Fe=new Promise(async h=>{const f=new xa;await f.init(),h(f)})),o=await Fe);const b=[];for(let h=0;h<n.levels.length;h++){const f=Math.max(1,n.pixelWidth>>h),l=Math.max(1,n.pixelHeight>>h),u=n.pixelDepth?Math.max(1,n.pixelDepth>>h):0,I=n.levels[h];let C,B;if(n.supercompressionScheme===0)C=I.levelData;else{if(n.supercompressionScheme!==2)throw new Error("THREE.KTX2Loader: Unsupported supercompressionScheme.");C=o.decode(I.levelData,I.uncompressedByteLength)}B=Le[d]===g.FloatType?new Float32Array(C.buffer,C.byteOffset,C.byteLength/Float32Array.BYTES_PER_ELEMENT):Le[d]===g.HalfFloatType?new Uint16Array(C.buffer,C.byteOffset,C.byteLength/Uint16Array.BYTES_PER_ELEMENT):C,b.push({data:B,width:f,height:l,depth:u})}let c;if(Da.has(Te[d]))c=n.pixelDepth===0?new g.DataTexture(b[0].data,n.pixelWidth,n.pixelHeight):new g.Data3DTexture(b[0].data,n.pixelWidth,n.pixelHeight,n.pixelDepth);else{if(n.pixelDepth>0)throw new Error("THREE.KTX2Loader: Unsupported pixelDepth.");c=new g.CompressedTexture(b,n.pixelWidth,n.pixelHeight)}return c.mipmaps=b,c.type=Le[d],c.format=Te[d],c.colorSpace=QA(n),c.needsUpdate=!0,Promise.resolve(c)}(a);const i=A,s=this.init().then(()=>this.workerPool.postMessage({type:"transcode",buffer:e,taskConfig:i},[e])).then(n=>this._createTextureFrom(n.data,a));return Re.set(e,{promise:s}),s}dispose(){return this.workerPool.dispose(),this.workerSourceURL&&URL.revokeObjectURL(this.workerSourceURL),Se--,this}}N.BasisFormat={ETC1S:0,UASTC:1,UASTC_HDR:2},N.TranscoderFormat={ETC1:0,ETC2:1,BC1:2,BC3:3,BC4:4,BC5:5,BC7_M6_OPAQUE_ONLY:6,BC7_M5:7,PVRTC1_4_RGB:8,PVRTC1_4_RGBA:9,ASTC_4x4:10,ATC_RGB:11,ATC_RGBA_INTERPOLATED_ALPHA:12,RGBA32:13,RGB565:14,BGR565:15,RGBA4444:16,BC6H:22,RGB_HALF:24,RGBA_HALF:25},N.EngineFormat={RGBAFormat:g.RGBAFormat,RGBA_ASTC_4x4_Format:g.RGBA_ASTC_4x4_Format,RGB_BPTC_UNSIGNED_Format:g.RGB_BPTC_UNSIGNED_Format,RGBA_BPTC_Format:g.RGBA_BPTC_Format,RGBA_ETC2_EAC_Format:g.RGBA_ETC2_EAC_Format,RGBA_PVRTC_4BPPV1_Format:g.RGBA_PVRTC_4BPPV1_Format,RGBA_S3TC_DXT5_Format:g.RGBA_S3TC_DXT5_Format,RGB_ETC1_Format:g.RGB_ETC1_Format,RGB_ETC2_Format:g.RGB_ETC2_Format,RGB_PVRTC_4BPPV1_Format:g.RGB_PVRTC_4BPPV1_Format,RGBA_S3TC_DXT1_Format:g.RGBA_S3TC_DXT1_Format},N.EngineType={UnsignedByteType:g.UnsignedByteType,HalfFloatType:g.HalfFloatType,FloatType:g.FloatType},N.BasisWorker=function(){let r,e,A;const a=_EngineFormat,t=_EngineType,i=_TranscoderFormat,s=_BasisFormat;self.addEventListener("message",function(c){const h=c.data;switch(h.type){case"init":r=h.config,f=h.transcoderBinary,e=new Promise(l=>{A={wasmBinary:f,onRuntimeInitialized:l},BASIS(A)}).then(()=>{A.initializeBasis(),A.KTX2File===void 0&&console.warn("THREE.KTX2Loader: Please update Basis Universal transcoder.")});break;case"transcode":e.then(()=>{try{const{faces:l,buffers:u,width:I,height:C,hasAlpha:B,format:m,type:E,dfdFlags:j}=function(k){const w=new A.KTX2File(new Uint8Array(k));function p(){w.close(),w.delete()}if(!w.isValid())throw p(),new Error("THREE.KTX2Loader: Invalid or unsupported .ktx2 file");let y;if(w.isUASTC())y=s.UASTC;else if(w.isETC1S())y=s.ETC1S;else{if(!w.isHDR())throw new Error("THREE.KTX2Loader: Unknown Basis encoding");y=s.UASTC_HDR}const x=w.getWidth(),D=w.getHeight(),F=w.getLayers()||1,P=w.getLevels(),ze=w.getFaces(),le=w.getHasAlpha(),Ce=w.getDFDFlags(),{transcoderFormat:fe,engineFormat:Ie,engineType:ue}=function(V,oe,R,G){const H=d[V];for(let z=0;z<H.length;z++){const q=H[z];if(!(q.if&&!r[q.if])&&q.basisFormat.includes(V)&&!(G&&q.transcoderFormat.length<2)&&!(q.needsPowerOfTwo&&(!o(oe)||!o(R))))return{transcoderFormat:q.transcoderFormat[G?1:0],engineFormat:q.engineFormat[G?1:0],engineType:q.engineType[0]}}throw new Error("THREE.KTX2Loader: Failed to identify transcoding target.")}(y,x,D,le);if(!x||!D||!P)throw p(),new Error("THREE.KTX2Loader: Invalid texture");if(!w.startTranscoding())throw p(),new Error("THREE.KTX2Loader: .startTranscoding failed");const Ee=[],pe=[];for(let V=0;V<ze;V++){const oe=[];for(let R=0;R<P;R++){const G=[];let H,z;for(let ce=0;ce<F;ce++){const de=w.getImageLevelInfo(R,ce,V);V!==0||R!==0||ce!==0||de.origWidth%4==0&&de.origHeight%4==0||console.warn("THREE.KTX2Loader: ETC1S and UASTC textures should use multiple-of-four dimensions."),P>1?(H=de.origWidth,z=de.origHeight):(H=de.width,z=de.height);let be=new Uint8Array(w.getImageTranscodedSizeInBytes(R,ce,0,fe));const _a=w.transcodeImage(be,R,ce,V,fe,0,-1,-1);if(ue===t.HalfFloatType&&(be=new Uint16Array(be.buffer,be.byteOffset,be.byteLength/Uint16Array.BYTES_PER_ELEMENT)),!_a)throw p(),new Error("THREE.KTX2Loader: .transcodeImage failed.");G.push(be)}const q=b(G);oe.push({data:q,width:H,height:z}),pe.push(q.buffer)}Ee.push({mipmaps:oe,width:x,height:D,format:Ie,type:ue})}return p(),{faces:Ee,buffers:pe,width:x,height:D,hasAlpha:le,dfdFlags:Ce,format:Ie,type:ue}}(h.buffer);self.postMessage({type:"transcode",id:h.id,data:{faces:l,width:I,height:C,hasAlpha:B,format:m,type:E,dfdFlags:j}},u)}catch(l){console.error(l),self.postMessage({type:"error",id:h.id,error:l.message})}})}var f});const n=[{if:"astcSupported",basisFormat:[s.UASTC],transcoderFormat:[i.ASTC_4x4,i.ASTC_4x4],engineFormat:[a.RGBA_ASTC_4x4_Format,a.RGBA_ASTC_4x4_Format],engineType:[t.UnsignedByteType],priorityETC1S:1/0,priorityUASTC:1,needsPowerOfTwo:!1},{if:"bptcSupported",basisFormat:[s.ETC1S,s.UASTC],transcoderFormat:[i.BC7_M5,i.BC7_M5],engineFormat:[a.RGBA_BPTC_Format,a.RGBA_BPTC_Format],engineType:[t.UnsignedByteType],priorityETC1S:3,priorityUASTC:2,needsPowerOfTwo:!1},{if:"dxtSupported",basisFormat:[s.ETC1S,s.UASTC],transcoderFormat:[i.BC1,i.BC3],engineFormat:[a.RGBA_S3TC_DXT1_Format,a.RGBA_S3TC_DXT5_Format],engineType:[t.UnsignedByteType],priorityETC1S:4,priorityUASTC:5,needsPowerOfTwo:!1},{if:"etc2Supported",basisFormat:[s.ETC1S,s.UASTC],transcoderFormat:[i.ETC1,i.ETC2],engineFormat:[a.RGB_ETC2_Format,a.RGBA_ETC2_EAC_Format],engineType:[t.UnsignedByteType],priorityETC1S:1,priorityUASTC:3,needsPowerOfTwo:!1},{if:"etc1Supported",basisFormat:[s.ETC1S,s.UASTC],transcoderFormat:[i.ETC1],engineFormat:[a.RGB_ETC1_Format],engineType:[t.UnsignedByteType],priorityETC1S:2,priorityUASTC:4,needsPowerOfTwo:!1},{if:"pvrtcSupported",basisFormat:[s.ETC1S,s.UASTC],transcoderFormat:[i.PVRTC1_4_RGB,i.PVRTC1_4_RGBA],engineFormat:[a.RGB_PVRTC_4BPPV1_Format,a.RGBA_PVRTC_4BPPV1_Format],engineType:[t.UnsignedByteType],priorityETC1S:5,priorityUASTC:6,needsPowerOfTwo:!0},{if:"bptcSupported",basisFormat:[s.UASTC_HDR],transcoderFormat:[i.BC6H],engineFormat:[a.RGB_BPTC_UNSIGNED_Format],engineType:[t.HalfFloatType],priorityHDR:1,needsPowerOfTwo:!1},{basisFormat:[s.ETC1S,s.UASTC],transcoderFormat:[i.RGBA32,i.RGBA32],engineFormat:[a.RGBAFormat,a.RGBAFormat],engineType:[t.UnsignedByteType,t.UnsignedByteType],priorityETC1S:100,priorityUASTC:100,needsPowerOfTwo:!1},{basisFormat:[s.UASTC_HDR],transcoderFormat:[i.RGBA_HALF],engineFormat:[a.RGBAFormat],engineType:[t.HalfFloatType],priorityHDR:100,needsPowerOfTwo:!1}],d={[s.ETC1S]:n.filter(c=>c.basisFormat.includes(s.ETC1S)).sort((c,h)=>c.priorityUASTC-h.priorityUASTC),[s.UASTC]:n.filter(c=>c.basisFormat.includes(s.UASTC)).sort((c,h)=>c.priorityUASTC-h.priorityUASTC),[s.UASTC_HDR]:n.filter(c=>c.basisFormat.includes(s.UASTC_HDR)).sort((c,h)=>c.priorityHDR-h.priorityHDR)};function o(c){return c<=2||!(c&c-1)&&c!==0}function b(c){if(c.length===1)return c[0];let h=0;for(let u=0;u<c.length;u++)h+=c[u].byteLength;const f=new Uint8Array(h);let l=0;for(let u=0;u<c.length;u++){const I=c[u];f.set(I,l),l+=I.byteLength}return f}};const Da=new Set([g.RGBAFormat,g.RGFormat,g.RedFormat]),Te={[BA]:g.RGBAFormat,[fA]:g.RGBAFormat,[bA]:g.RGBAFormat,[gA]:g.RGBAFormat,[uA]:g.RGFormat,[lA]:g.RGFormat,[cA]:g.RGFormat,[dA]:g.RGFormat,[IA]:g.RedFormat,[hA]:g.RedFormat,[oA]:g.RedFormat,[nA]:g.RedFormat,[xe]:g.RGBA_ASTC_4x4_Format,[EA]:g.RGBA_ASTC_6x6_Format,[CA]:g.RGBA_ASTC_6x6_Format},Le={[BA]:g.FloatType,[fA]:g.HalfFloatType,[bA]:g.UnsignedByteType,[gA]:g.UnsignedByteType,[uA]:g.FloatType,[lA]:g.HalfFloatType,[cA]:g.UnsignedByteType,[dA]:g.UnsignedByteType,[IA]:g.FloatType,[hA]:g.HalfFloatType,[oA]:g.UnsignedByteType,[nA]:g.UnsignedByteType,[xe]:g.HalfFloatType,[EA]:g.UnsignedByteType,[CA]:g.UnsignedByteType};function QA(r){const e=r.dataFormatDescriptor[0];return e.colorPrimaries===1?e.transferFunction===2?g.SRGBColorSpace:g.LinearSRGBColorSpace:e.colorPrimaries===10?e.transferFunction===2?"display-p3":"display-p3-linear":(e.colorPrimaries===0||console.warn(`THREE.KTX2Loader: Unsupported color primaries, "${e.colorPrimaries}"`),g.NoColorSpace)}async function yA(r){const e=r.split("?")[0].split(".").pop(),A=await fetch(r);if(!A.ok)throw new Error(`Failed to fetch ${r}: ${A.statusText}`);if(e==="json"){const a=await A.json();return handleJSONSubtree(a,wA(r))}if(e==="subtree")return async function(a,t){const i=new DataView(a),s=i.getBigUint64(8,!0),n=i.getBigUint64(16,!0),d=24,o=d+Number(s),b=o+(8-o%8)%8,c=b+Number(n),h=a.slice(d,o),f=new TextDecoder().decode(h).trim(),l=JSON.parse(f);if(!l.buffers)throw new Error("subtree has no buffers");const u=l.buffers.map(async C=>{if(C.uri){const B=new URL(C.uri,t).href,m=await fetch(B);if(!m.ok)throw new Error(`Failed to fetch binary file ${B}: ${m.statusText}`);return new Uint8Array(await m.arrayBuffer())}return new Uint8Array(a.slice(b,c))}),I=await Promise.all(u);return function(C,B){function m(p,y){if(!p)throw new Error("incomplete json subtree");if(p.constant){if(p.constant==0)return!1;if(p.constant==1)return!0}if(p.bitstream==null)throw new Error('json subtree "tileAvailability" does not specify a bitstream');if(!C.bufferViews||!C.bufferViews[p.bitstream])throw new Error('json subtree "bufferViews" does not specify a bitstream');const x=C.bufferViews[p.bitstream];return E(B[x.buffer],x.byteOffset,y)}function E(p,y,x){const D=x%8;return p[y+Math.floor(x/8)]>>D&!0}function j(p){let y=0;return y=p.z==null?Ge(p.x,p.y,p.level):Ue(p.x,p.y,p.z,p.level),m(C.tileAvailability,y)}function k(p){let y=0;y=p.z==null?Ge(p.x,p.y,p.level):Ue(p.x,p.y,p.z,p.level);const x=[];return C.contentAvailability.forEach(D=>{x.push(m(D,y))}),x}function w(p){let y=0;return y=p.z==null?Ge(p.x,p.y):Ue(p.x,p.y,p.z),m(C.childSubtreeAvailability,y)}return{isTileAvailable:j,isContentAvailable:k,isChildSubtreeAvailable:w}}(l,I)}(await A.arrayBuffer(),wA(r));throw new Error(`Unsupported file extension: ${e}`)}function wA(r){const e=r.split("?")[0];return e.substring(0,e.lastIndexOf("/")+1)}function kA(r){return r=1431655765&((r=858993459&((r=252645135&((r=16711935&((r&=65535)^r<<8))^r<<4))^r<<2))^r<<1)}function Ge(r,e,A){let a=0;return A&&(a=(Math.pow(4,A)-1)/3),a+(kA(r)|kA(e)<<1)}function ve(r){return r=153391689&((r=51130563&((r=50393103&((r=4278190335&((r&=1023)^r<<16))^r<<8))^r<<4))^r<<2)}function Ue(r,e,A,a){let t=0;return a&&(t=(Math.pow(8,a)-1)/7),t+(ve(r)|ve(e)<<1|ve(A)<<2)}const he=new Map;async function Ne(r,e){if(!r.root||!r.root.implicitTiling)return r;if(!r.root.content&&!r.root.contents)throw new Error("implicit tiling requires a Template URI");let A=!0;r.root.implicitTiling.subdivisionScheme&&(A=r.root.implicitTiling.subdivisionScheme.toUpperCase()==="QUADTREE");let a="";r.root.implicitTiling.subtrees&&(r.root.implicitTiling.subtrees.uri?a=r.root.implicitTiling.subtrees.uri:r.root.implicitTiling.subtrees.url&&(a=r.root.implicitTiling.subtrees.url));let t=[];r.root.content?r.root.content.uri?t.push(r.root.content.uri):r.root.content.url&&t.push(r.root.content.url):r.root.contents&&r.root.contents.forEach(f=>{f.uri?t.push(f.uri):f.url&&t.push(f.url)});const i=function(f){const l=f.split("?")[0];return l.substring(0,l.lastIndexOf("/")+1)}(e);let s;A&&(s=a.replace("{level}",0).replace("{x}",0).replace("{y}",0)),A||(s=a.replace("{level}",0).replace("{x}",0).replace("{y}",0).replace("{z}",0));const n={level:0,x:0,y:0},d={level:0,x:0,y:0};A||(n.z=0,d.z=0),he.set(s,await yA(i+s));const o=he.get(s),b=[];o.isContentAvailable(d)&&t.forEach(f=>{let l;A&&(l=f.replace("{level}",n.level).replace("{x}",n.x).replace("{y}",n.y)),A||(l=f.replace("{level}",n.level).replace("{x}",n.x).replace("{y}",n.y).replace("{z}",n.z)),b.push({uri:l})});const c={geometricError:r.root.geometricError,boundingVolume:r.root.boundingVolume,refine:r.root.refine,globalAddress:n,localAddress:d,subtree:o,contents:b,getChildren:async()=>h(c)};return{root:c};async function h(f){const l=[];if(f.localAddress.level==r.root.implicitTiling.availableLevels-1)return l;if((f.localAddress.level+1)%r.root.implicitTiling.subtreeLevels==0){const u=Be(f.localAddress),I=Be(f.globalAddress),C=xA(A,r.root.boundingVolume,I);for(let B=0;B<u.length;B++){const m=u[B],E=I[B];f.subtree.isChildSubtreeAvailable(m)&&(A&&a.replace("{level}",E.level).replace("{x}",E.x).replace("{y}",E.y),A||a.replace("{level}",E.level).replace("{x}",E.x).replace("{y}",E.y).replace("{z}",E.z)),he.has(s)||he.set(s,await yA(i+s));const j=he.get(s),k={level:0,x:0,y:0};A||(k.z=0);const w=[];j.isContentAvailable(k)&&t.forEach(y=>{let x;A&&(x=y.replace("{level}",E.level).replace("{x}",E.x).replace("{y}",E.y)),A||(x=y.replace("{level}",E.level).replace("{x}",E.x).replace("{y}",E.y).replace("{z}",E.z)),w.push({uri:x})});const p={geometricError:f.geometricError/2,boundingVolume:C[B],refine:r.root.refine,globalAddress:E,localAddress:k,subtree:j,contents:w,getChildren:async()=>h(p)};l.push(p)}}else{const u=Be(f.localAddress),I=Be(f.globalAddress),C=xA(A,r.root.boundingVolume,I);for(let B=0;B<u.length;B++){const m=u[B],E=I[B];if(!f.subtree.isTileAvailable(m))continue;const j=[],k=f.subtree.isContentAvailable(m);for(let p=0;p<t.length;p++){if(!k[p])continue;const y=t[p];let x;A&&(x=y.replace("{level}",E.level).replace("{x}",E.x).replace("{y}",E.y)),A||(x=y.replace("{level}",E.level).replace("{x}",E.x).replace("{y}",E.y).replace("{z}",E.z)),j.push({uri:x})}const w={geometricError:f.geometricError/2,boundingVolume:C[B],refine:r.root.refine,globalAddress:E,localAddress:m,subtree:f.subtree,contents:j,getChildren:async()=>h(w)};l.push(w)}}return l.length>0?l:void 0}}function Be(r){const{level:e,x:A,y:a,z:t}=r,i=e+1;let s=[];return s=t===void 0?[{level:i,x:2*A,y:2*a},{level:i,x:2*A+1,y:2*a},{level:i,x:2*A,y:2*a+1},{level:i,x:2*A+1,y:2*a+1}]:[{level:i,x:2*A,y:2*a,z:2*t},{level:i,x:2*A+1,y:2*a,z:2*t},{level:i,x:2*A,y:2*a+1,z:2*t},{level:i,x:2*A+1,y:2*a+1,z:2*t},{level:i,x:2*A,y:2*a,z:2*t+1},{level:i,x:2*A+1,y:2*a,z:2*t+1},{level:i,x:2*A,y:2*a+1,z:2*t+1},{level:i,x:2*A+1,y:2*a+1,z:2*t+1}],s}function xA(r,e,A){const a=[];for(let t=0;t<A.length;t++)a.push(ja(r,e,A[t]));return a}function ja(r,e,A){if(e.region)return function(a,t,i){const[s,n,d,o,b,c]=t,h=(d-s)/2**i.level,f=(o-n)/2**i.level,l=a?0:(c-b)/2**i.level,u=s+h*i.x,I=n+f*i.y,C=u+h,B=I+f,m=a?b:b+l*i.z,E=a?c:m+l;return{region:[u,I,C,B,m,E]}}(r,e.region,A);if(e.box)return function(a,t,i){const s=t.slice(0,3),n=[t.slice(3,6),t.slice(6,9),t.slice(9,12)],d=1/Math.pow(2,i.level),o=[d,d,a?1:d],b=n.map((f,l)=>f.map(u=>u*o[l])),c=[s[0]-n[0][0]-n[1][0]-n[2][0],s[1]-n[0][1]-n[1][1]-n[2][1],s[2]-n[0][2]-n[1][2]-n[2][2]];return{box:[c[0]+(2*i.x+1)*(b[0][0]+b[1][0]+b[2][0]),c[1]+(2*i.y+1)*(b[0][1]+b[1][1]+b[2][1]),a?s[2]:c[2]+(2*i.z+1)*(b[0][2]+b[1][2]+b[2][2])].concat(...b)}}(r,e.box,A);throw new Error("Unsupported bounding volume type")}(function(){var r,e=new Uint8Array([32,0,65,2,1,106,34,33,3,128,11,4,13,64,6,253,10,7,15,116,127,5,8,12,40,16,19,54,20,9,27,255,113,17,42,67,24,23,146,148,18,14,22,45,70,69,56,114,101,21,25,63,75,136,108,28,118,29,73,115]);if(typeof WebAssembly!="object")return{supported:!1};var A=WebAssembly.instantiate(function(o){for(var b=new Uint8Array(o.length),c=0;c<o.length;++c){var h=o.charCodeAt(c);b[c]=h>96?h-97:h>64?h-39:h+4}var f=0;for(c=0;c<o.length;++c)b[f++]=b[c]<60?e[b[c]]:64*(b[c]-60)+b[++c];return b.buffer.slice(0,f)}("b9H79TebbbeJq9Geueu9Geub9Gbb9Gvuuuuueu9Gduueu9Gluuuueu9Gvuuuuub9Gouuuuuub9Gluuuub9GiuuueuiKLdilevlevlooroowwvwbDDbelve9Weiiviebeoweuec:W;kekr;RiOo9TW9T9VV95dbH9F9F939H79T9F9J9H229F9Jt9VV7bb8A9TW79O9V9Wt9FW9U9J9V9KW9wWVtW949c919M9MWVbe8F9TW79O9V9Wt9FW9U9J9V9KW9wWVtW949c919M9MWV9c9V919U9KbdE9TW79O9V9Wt9FW9U9J9V9KW9wWVtW949wWV79P9V9UbiY9TW79O9V9Wt9FW9U9J9V9KW69U9KW949c919M9MWVbl8E9TW79O9V9Wt9FW9U9J9V9KW69U9KW949c919M9MWV9c9V919U9Kbv8A9TW79O9V9Wt9FW9U9J9V9KW69U9KW949wWV79P9V9UboE9TW79O9V9Wt9FW9U9J9V9KW69U9KW949tWG91W9U9JWbra9TW79O9V9Wt9FW9U9J9V9KW69U9KW949tWG91W9U9JW9c9V919U9KbwL9TW79O9V9Wt9FW9U9J9V9KWS9P2tWV9p9JtbDK9TW79O9V9Wt9FW9U9J9V9KWS9P2tWV9r919HtbqL9TW79O9V9Wt9FW9U9J9V9KWS9P2tWVT949WbkE9TW79O9V9Wt9F9V9Wt9P9T9P96W9wWVtW94J9H9J9OWbPa9TW79O9V9Wt9F9V9Wt9P9T9P96W9wWVtW94J9H9J9OW9ttV9P9Wbsa9TW79O9V9Wt9F9V9Wt9P9T9P96W9wWVtW94SWt9J9O9sW9T9H9WbzK9TW79O9V9Wt9F79W9Ht9P9H29t9VVt9sW9T9H9WbHl79IV9RbODwebcekdQXq:g9sLdbk;3keYu8Jjjjjbcjo9Rgv8Kjjjjbcbhodnalcefae0mbabcbRb:S:kjjbc:GeV86bbavcjdfcbcjdzNjjjb8AdnaiTmbavcjdfadalz:tjjjb8Akabaefhrabcefhwavalfcbcbcjdal9RalcFe0EzNjjjb8Aavavcjdfalz:tjjjbhDcj;abal9UhodndndndndnalTmbaoc;WFbGgecjdaecjd6Ehqcbhkdninakai9pmiaDcjlfcbcjdzNjjjb8Aaqaiak9Rakaqfai6Egxcsfgecl4cifcd4hmadakal2fhPdndndndndnaec9WGgsTmbcbhzcehHaPhOawhAxekdnaxTmbcbhAcehHaPhCinaDaAfRbbhXaDcjlfheaChoaxhQinaeaoRbbgLaX9RgXcetaX;acr4786bbaoalfhoaecefheaLhXaQcufgQmbkaraw9Ram6miawcbamzNjjjbgeTmiaCcefhCaeamfhwaAcefgAal6hHaAal9hmbxvkkaraw9Ram6mvawcbamzNjjjb8AceheinawgXamfhwalaegoSmldnaraw9Ram6mbaocefheawcbamzNjjjb8AaXmekkaoal6hHxekindnaxTmbaDazfRbbhXaDcjlfheaOhoaxhQinaeaoRbbgLaX9RgXcetaX;acr4786bbaoalfhoaecefheaLhXaQcufgQmbkkaraA9Ram6mearaAcbamzNjjjbgKamfgw9RcK6mdcbhYaDcjlfhAinaDcjlfaYfh8AcwhCczhLcehQindndnaQce9hmbcuhoa8ARbbmecbhodninaogecsSmeaecefhoaAaefcefRbbTmbkkcucbaecs6EhoxekaQcetc;:FFFeGhocuaQtcu7cFeGhXcbheinaoaXaAaefRbb9nfhoaecefgecz9hmbkkaoaLaoaL6geEhLaQaCaeEhCaQcetgQcw6mbkdndndndnaCcufPdiebkaKaYco4fgeaeRbbcdciaCclSEaYci4coGtV86bbaCcw9hmeawa8A8Pbb83bbawcwfa8Acwf8Pbb83bbawczfhwxdkaKaYco4fgeaeRbbceaYci4coGtV86bbkdncwaC9TgEmbinawcb86bbawcefhwxbkkcuaCtcu7h8Acbh3aAh5ina5heaEhQcbhoinaeRbbgLa8AcFeGgXaLaX6EaoaCtVhoaecefheaQcufgQmbkawao86bba5aEfh5awcefhwa3aEfg3cz6mbkcbheindnaAaefRbbgoaX6mbawao86bbawcefhwkaecefgecz9hmbkkdnaYczfgYas9pmbaAczfhAaraw9RcL0mekkaYas6meawTmeaOcefhOazcefgzal6hHawhAazalSmixbkkcbhwaHceGTmexikcbhwaHceGmdkaDaPaxcufal2falz:tjjjb8AaxakfhkawmbkcbhoxokcbhoxvkaiTmekcbhoaraw9Ralcaalca0E6mialc8F9nmexdkcbhoaecufca6mdkawcbcaal9RgezNjjjbaefhwkawaDcjdfalz:tjjjbalfab9Rhokavcjof8Kjjjjbaok9heeuaecaaeca0Eabcj;abae9Uc;WFbGgdcjdadcjd6Egdfcufad9Uae2adcl4cifcd4adV2fcefkmbcbabBd:S:kjjbk;rse3u8Jjjjjbc;ae9Rgl8Kjjjjbcbhvdnaici9UgocHfae0mbabcbyd:C:kjjbgrc;GeV86bbalc;abfcFecjezNjjjb8AalcUfgw9cu83ibalc8WfgD9cu83ibalcyfgq9cu83ibalcafgk9cu83ibalcKfgx9cu83ibalczfgm9cu83ibal9cu83iwal9cu83ibabaefc9WfhPabcefgsaofhednaiTmbcmcsarcb9kgzEhHcbhOcbhAcbhCcbhXcbhQindnaeaP9nmbcbhvxikaQcufhvadaCcdtfgoydbhLaocwfydbhKaoclfydbhYcbh8Adndninalc;abfavcsGcitfgoydlhEdndndnaoydbgoaL9hmbaEaYSmekdnaoaY9hmbaEaK9hmba8Acefh8AxekaoaK9hmeaEaL9hmea8Acdfh8Aka8Ac870mdaXcufhvada8AciGcx2goc:y1jjbfydbaCfcdtfydbhEadaocN1jjbfydbaCfcdtfydbhKadaoc:q1jjbfydbaCfcdtfydbhLcbhodnindnalavcsGcdtfydbaE9hmbaohYxdkcuhYavcufhvaocefgocz9hmbkkaEaOSgvaYce9iaYaH9oVgoGh3dndndndndncbcsavEaYaoEgvcs9hmbarce9imbaEaEaAaEcefaASgvEgAcefSmecmcsavEhvkasava8Acdtc;WeGV86bbavcs9hmeaEaA9Rgvcetavc8F917hvinaeavcFb0crtavcFbGV86bbaecefheavcje6hoavcr4hvaoTmbkaEhAxdkcPhvasa8AcdtcPV86bbaEhAkavTmbavaH9imekalaXcdtfaEBdbaXcefcsGhXkaOa3fhOalc;abfaQcitfgvaKBdlavaEBdbalc;abfaQcefcsGgvcitfgoaEBdlaoaLBdbavcefhoxikavcufhva8Aclfg8Ac;ab9hmbkkdnadceaKaOScetaYaOSEcx2gvc:q1jjbfydbaCfcdtfydbgLTadavcN1jjbfydbaCfcdtfydbg8AceSGadavc:y1jjbfydbaCfcdtfydbgYcdSGaOcb9hGazGg5ce9hmbaw9cu83ibaD9cu83ibaq9cu83ibak9cu83ibax9cu83ibam9cu83ibal9cu83iwal9cu83ibcbhOkcbhEaXcufgvhodnindnalaocsGcdtfydba8A9hmbaEhKxdkcuhKaocufhoaEcefgEcz9hmbkkcbhodnindnalavcsGcdtfydbaY9hmbaohExdkcuhEavcufhvaocefgocz9hmbkkaOaLaOSg8Efh3dndnaKcm0mbaKcefhKxekcbcsa8Aa3SgvEhKa3avfh3kdndnaEcm0mbaEcefhExekcbcsaYa3SgvEhEa3avfh3kc9:cua8EEh8FaEaKcltVhocbhvdndndninavcj1jjbfRbbaocFeGSmeavcefgvcz9hmbxdkka5aLaO9havcm0VVmbasavc;WeV86bbxekasa8F86bbaeao86bbaecefhekdna8EmbaLaA9Rgvcetavc8F917hvinaeavcFb0gocrtavcFbGV86bbavcr4hvaecefheaombkaLhAkdnaKcs9hmba8AaA9Rgvcetavc8F917hvinaeavcFb0gocrtavcFbGV86bbavcr4hvaecefheaombka8AhAkdnaEcs9hmbaYaA9Rgvcetavc8F917hvinaeavcFb0gocrtavcFbGV86bbavcr4hvaecefheaombkaYhAkalaXcdtfaLBdbaXcefcsGhvdndnaKPzbeeeeeeeeeeeeeebekalavcdtfa8ABdbaXcdfcsGhvkdndnaEPzbeeeeeeeeeeeeeebekalavcdtfaYBdbavcefcsGhvkalc;abfaQcitfgoaLBdlaoa8ABdbalc;abfaQcefcsGcitfgoa8ABdlaoaYBdbalc;abfaQcdfcsGcitfgoaYBdlaoaLBdbaQcifhoavhXa3hOkascefhsaocsGhQaCcifgCai6mbkkcbhvaeaP0mbcbhvinaeavfavcj1jjbfRbb86bbavcefgvcz9hmbkaeab9Ravfhvkalc;aef8KjjjjbavkZeeucbhddninadcefgdc8F0meceadtae6mbkkadcrfcFeGcr9Uci2cdfabci9U2cHfkmbcbabBd:C:kjjbk:ydewu8Jjjjjbcz9Rhlcbhvdnaicvfae0mbcbhvabcbRb:C:kjjbc;qeV86bbal9cb83iwabcefhoabaefc98fhrdnaiTmbcbhwcbhDindnaoar6mbcbskadaDcdtfydbgqalcwfawaqav9Rgvavc8F91gv7av9Rc507gwcdtfgkydb9Rgvc8E91c9:Gavcdt7awVhvinaoavcFb0gecrtavcFbGV86bbavcr4hvaocefhoaembkakaqBdbaqhvaDcefgDai9hmbkkcbhvaoar0mbaocbBbbaoab9RclfhvkavkBeeucbhddninadcefgdc8F0meceadtae6mbkkadcwfcFeGcr9Uab2cvfk:dvli99dui99ludnaeTmbcuadcetcuftcu7:Yhvdndncuaicuftcu7:YgoJbbbZMgr:lJbbb9p9DTmbar:Ohwxekcjjjj94hwkcbhicbhDinalclfIdbgrJbbbbJbbjZalIdbgq:lar:lMalcwfIdbgk:lMgr:varJbbbb9BEgrNhxaqarNhralcxfIdbhqdndnakJbbbb9GTmbaxhkxekJbbjZar:l:tgkak:maxJbbbb9GEhkJbbjZax:l:tgxax:marJbbbb9GEhrkdndnaqJbbj:;aqJbbj:;9GEgxJbbjZaxJbbjZ9FEavNJbbbZJbbb:;aqJbbbb9GEMgq:lJbbb9p9DTmbaq:Ohmxekcjjjj94hmkdndnakJbbj:;akJbbj:;9GEgqJbbjZaqJbbjZ9FEaoNJbbbZJbbb:;akJbbbb9GEMgq:lJbbb9p9DTmbaq:OhPxekcjjjj94hPkdndnarJbbj:;arJbbj:;9GEgqJbbjZaqJbbjZ9FEaoNJbbbZJbbb:;arJbbbb9GEMgr:lJbbb9p9DTmbar:Ohsxekcjjjj94hskdndnadcl9hmbabaifgzas86bbazcifam86bbazcdfaw86bbazcefaP86bbxekabaDfgzas87ebazcofam87ebazclfaw87ebazcdfaP87ebkalczfhlaiclfhiaDcwfhDaecufgembkkk;klld99eud99eudnaeTmbdndncuaicuftcu7:YgvJbbbZMgo:lJbbb9p9DTmbao:Ohixekcjjjj94hikaic;8FiGhrinabcofcicdalclfIdb:lalIdb:l9EgialcwfIdb:lalaicdtfIdb:l9EEgialcxfIdb:lalaicdtfIdb:l9EEgiarV87ebdndnalaicefciGcdtfIdbJ;Zl:1ZNJbbj:;JbbjZalaicdtfIdbJbbbb9DEgoNgwJbbj:;awJbbj:;9GEgDJbbjZaDJbbjZ9FEavNJbbbZJbbb:;awJbbbb9GEMgw:lJbbb9p9DTmbaw:Ohqxekcjjjj94hqkabaq87ebdndnaoalaicdfciGcdtfIdbJ;Zl:1ZNNgwJbbj:;awJbbj:;9GEgDJbbjZaDJbbjZ9FEavNJbbbZJbbb:;awJbbbb9GEMgw:lJbbb9p9DTmbaw:Ohqxekcjjjj94hqkabcdfaq87ebdndnaoalaicufciGcdtfIdbJ;Zl:1ZNNgoJbbj:;aoJbbj:;9GEgwJbbjZawJbbjZ9FEavNJbbbZJbbb:;aoJbbbb9GEMgo:lJbbb9p9DTmbao:Ohixekcjjjj94hikabclfai87ebabcwfhbalczfhlaecufgembkkk:Hvdxue998Jjjjjbcjd9Rgo8Kjjjjbadcd4hrdndndndnavcd9hmbadcl6mearcearce0EhwaohDinaDc:CuBdbaDclfhDawcufgwmbkaeTmiadcl6mdarcearce0EhqarcdthkalhxcbhminaohDaxhwaqhPinaDaDydbgsawydbgzcL4cFeGc:cufcbazEgzasaz9kEBdbawclfhwaDclfhDaPcufgPmbkaxakfhxamcefgmae9hmbkkaeTmdxekaeTmekavcb9hadcl6gqVhHarcearce0Ehkarcdthrceai9Rhmcbhdindndndnavce9hmbaqmdc:CuhwalhDakhPinawaDydbgscL4cFeGc:cufcbasEgsawas9kEhwaDclfhDaPcufgPmbxdkkc:CuhwaHmbaohDalhPakhsinaDaPydbgzcL4cFeGgxc8Aaxc8A9kEc:cufcbazEBdbaPclfhPaDclfhDascufgsmbkkaqmbcbhDakhsinawhPdnavceSmbaoaDfydbhPkdndnalaDfIdbgOcjjj;8iamaPfgPcLt9R::NJbbbZJbbb:;aOJbbbb9GEMgO:lJbbb9p9DTmbaO:Ohzxekcjjjj94hzkabaDfazcFFFrGaPcKtVBdbaDclfhDascufgsmbkkabarfhbalarfhladcefgdae9hmbkkaocjdf8KjjjjbkFkdCui998Jjjjjbc:Gd9Rgv8Kjjjjbavc:4efcbc;KbzNjjjb8AcbhodnadTmbcbhoaiTmbdnabae9hmbavcuadcdtgoadcFFFFi0Ecbyd:K:kjjbHjjjjbbgeBd:4eavceBd:ydaeabaoz:tjjjb8Akavc:OefcwfcbBdbav9cb83i:Oeavc:Oefaeadaiavc:4efz:njjjbcuaicdtgraicFFFFi0Egwcbyd:K:kjjbHjjjjbbhoavc:4efavyd:ydgDcdtfaoBdbavaDcefgqBd:ydaoavyd:Oegkarz:tjjjbhxavc:4efaqcdtfadci9Ugmcbyd:K:kjjbHjjjjbbgoBdbavaDcdfgrBd:ydaocbamzNjjjbhPavc:4efarcdtfawcbyd:K:kjjbHjjjjbbgsBdbavaDcifgqBd:ydaxhoashrinaralIdbalaoydbgwcwawcw6Ecdtfc;ebfIdbMUdbaoclfhoarclfhraicufgimbkavc:4efaqcdtfcuamcdtadcFFFF970Ecbyd:K:kjjbHjjjjbbgqBdbavaDclfBd:yddnadci6mbamceamce0EhiaehoaqhrinarasaoydbcdtfIdbasaoclfydbcdtfIdbMasaocwfydbcdtfIdbMUdbaocxfhoarclfhraicufgimbkkavc;qbfhzavhoavyd:SehHavyd:WehOcbhwcbhrcbhAcehCinaohXcihQaearci2gLcdtfgocwfydbhdaoydbhDabaAcx2fgiclfaoclfydbgKBdbaiaDBdbaicwfadBdbaParfce86bbazadBdwazaKBdlazaDBdbaqarcdtfcbBdbdnawTmbcihQaXhiinazaQcdtfaiydbgoBdbaQaoaD9haoaK9hGaoad9hGfhQaiclfhiawcufgwmbkkaAcefhAaxaDcdtfgoaoydbcufBdbaxaKcdtfgoaoydbcufBdbaxadcdtfgoaoydbcufBdbcbhwinaOaHaeawaLfcdtfydbcdtgifydbcdtfgKhoakaifgDydbgdhidnadTmbdninaoydbarSmeaoclfhoaicufgiTmdxbkkaoadcdtaKfc98fydbBdbaDaDydbcufBdbkawcefgwci9hmbkdndndnaQTmbcuhrJbbbbhYcbhDavyd:SehKavyd:WehLindndnakazaDcdtfydbcdtgofydbgimbaDcefhDxekaDcs0hwasaofgdIdbh8AadalcbaDcefgDawEcdtfIdbalaxaofydbgwcwawcw6Ecdtfc;ebfIdbMgEUdbaEa8A:thEaicdthiaLaKaofydbcdtfhoinaqaoydbgwcdtfgdaEadIdbMg8AUdba8AaYaYa8A9DgdEhYawaradEhraoclfhoaic98fgimbkkaDaQ9hmbkarcu9hmekaCam9pmeindnaPaCfRbbmbaChrxdkamaCcefgC9hmbxdkkaQczaQcz6EhwazhoaXhzarcu9hmekkavyd:ydhokaocdtavc:4effc98fhrdninaoTmearydbcbyd:G:kjjbH:bjjjbbarc98fhraocufhoxbkkavc:Gdf8Kjjjjbk;UlevucuaicdtgvaicFFFFi0Egocbyd:K:kjjbHjjjjbbhralalyd9GgwcdtfarBdbalawcefBd9GabarBdbaocbyd:K:kjjbHjjjjbbhralalyd9GgocdtfarBdbalaocefBd9GabarBdlcuadcdtadcFFFFi0Ecbyd:K:kjjbHjjjjbbhralalyd9GgocdtfarBdbalaocefBd9GabarBdwabydbcbavzNjjjb8Aadci9UhwdnadTmbabydbhoaehladhrinaoalydbcdtfgvavydbcefBdbalclfhlarcufgrmbkkdnaiTmbabydbhlabydlhrcbhvaihoinaravBdbarclfhralydbavfhvalclfhlaocufgombkkdnadci6mbawceawce0EhDabydlhrabydwhvcbhlinaecwfydbhoaeclfydbhdaraeydbcdtfgwawydbgwcefBdbavawcdtfalBdbaradcdtfgdadydbgdcefBdbavadcdtfalBdbaraocdtfgoaoydbgocefBdbavaocdtfalBdbaecxfheaDalcefgl9hmbkkdnaiTmbabydlheabydbhlinaeaeydbalydb9RBdbalclfhlaeclfheaicufgimbkkkQbabaeadaic:01jjbz:mjjjbkQbabaeadaic:C:jjjbz:mjjjbk9DeeuabcFeaicdtzNjjjbhlcbhbdnadTmbindnalaeydbcdtfgiydbcu9hmbaiabBdbabcefhbkaeclfheadcufgdmbkkabk;:kivuo99lu8Jjjjjbcj;Hb9Rgl8Kjjjjbcbhvalc1;Gbfcbc;KbzNjjjb8AalcuadcdtadcFFFFi0Egocbyd:K:kjjbHjjjjbbgrBd19GalceBd;O9Galcwfcbyd:m:kjjbBdbalcb8Pd:e:kjjb83ibalc;W;Gbfcwfcbyd:y:kjjbBdbalcb8Pd:q:kjjb83i;W9Gaicd4hwdndnadmbJFFuFhDJFFuuhqJFFuuhkJFFuFhxJFFuuhmJFFuFhPxekawcdthsaehzincbhiinalaifgHazaifIdbgDaHIdbgxaxaD9EEUdbalc;W;GbfaifgHaDaHIdbgxaxaD9DEUdbaiclfgicx9hmbkazasfhzavcefgvad9hmbkalIdwhqalId;49GhDalIdlhkalId;09GhxalIdbhmalId;W9GhPkdndnadTmbJbbbbJbbjZaPam:tJbbbb:xgPaxak:tgxaxaP9DEgxaDaq:tgDaDax9DEgD:vaDJbbbb9BEhDawcdthsarhHadhzindndnaDaeIdbam:tNJb;au9eNJbbbZMgx:lJbbb9p9DTmbax:Ohixekcjjjj94hikaicztaicwtcj;GiGVaicsGVc:p;G:dKGcH2c;d;H:WKGcv2c;j:KM;jbGhvdndnaDaeclfIdbak:tNJb;au9eNJbbbZMgx:lJbbb9p9DTmbax:Ohixekcjjjj94hikaicztaicwtcj;GiGVaicsGVc:p;G:dKGcH2c;d;H:WKGcq2cM;j:KMeGavVhvdndnaDaecwfIdbaq:tNJb;au9eNJbbbZMgx:lJbbb9p9DTmbax:Ohixekcjjjj94hikaHavaicztaicwtcj;GiGVaicsGVc:p;G:dKGcH2c;d;H:WKGcC2c:KM;j:KdGVBdbaeasfheaHclfhHazcufgzmbkalcbcj;GbzNjjjbhiarhHadheinaiaHydbgzcFrGcx2fgvavydbcefBdbaiazcq4cFrGcx2fgvavydlcefBdlaiazcC4cFrGcx2fgzazydwcefBdwaHclfhHaecufgembxdkkalcbcj;GbzNjjjb8AkcbhHcbhzcbhecbhvinalaHfgiydbhsaiazBdbaicwfgwydbhOawavBdbaiclfgiydbhwaiaeBdbasazfhzaOavfhvawaefheaHcxfgHcj;Gb9hmbkcbhialaocbyd:K:kjjbHjjjjbbgzBd:m9GdnadTmbabhHinaHaiBdbaHclfhHadaicefgi9hmbkadTmbabhiadhHinalaraiydbgecdtfydbcFrGcx2fgvavydbgvcefBdbazavcdtfaeBdbaiclfhiaHcufgHmbkazhiadhHinalaraiydbgecdtfydbcq4cFrGcx2fgvavydlgvcefBdlabavcdtfaeBdbaiclfhiaHcufgHmbkabhiadhHinalaraiydbgecdtfydbcC4cFrGcx2fgvavydwgvcefBdwazavcdtfaeBdbaiclfhiaHcufgHmbkadTmbcbhiinabazydbcdtfaiBdbazclfhzadaicefgi9hmbkkclhidninaic98Smealc1;Gbfaifydbcbyd:G:kjjbH:bjjjbbaic98fhixbkkalcj;Hbf8Kjjjjbk9teiucbcbyd:O:kjjbgeabcifc98GfgbBd:O:kjjbdndnabZbcztgd9nmbcuhiabad9RcFFifcz4nbcuSmekaehikaik;LeeeudndnaeabVciGTmbabhixekdndnadcz9pmbabhixekabhiinaiaeydbBdbaiclfaeclfydbBdbaicwfaecwfydbBdbaicxfaecxfydbBdbaeczfheaiczfhiadc9Wfgdcs0mbkkadcl6mbinaiaeydbBdbaeclfheaiclfhiadc98fgdci0mbkkdnadTmbinaiaeRbb86bbaicefhiaecefheadcufgdmbkkabk;aeedudndnabciGTmbabhixekaecFeGc:b:c:ew2hldndnadcz9pmbabhixekabhiinaialBdbaicxfalBdbaicwfalBdbaiclfalBdbaiczfhiadc9Wfgdcs0mbkkadcl6mbinaialBdbaiclfhiadc98fgdci0mbkkdnadTmbinaiae86bbaicefhiadcufgdmbkkabk9teiucbcbyd:O:kjjbgeabcrfc94GfgbBd:O:kjjbdndnabZbcztgd9nmbcuhiabad9RcFFifcz4nbcuSmekaehikaik9:eiuZbhedndncbyd:O:kjjbgdaecztgi9nmbcuheadai9RcFFifcz4nbcuSmekadhekcbabae9Rcifc98Gcbyd:O:kjjbfgdBd:O:kjjbdnadZbcztge9nmbadae9RcFFifcz4nb8Akkk:6ddbcjwk:Cdb4:h9w9N94:P:gW:j9O:ye9Pbbbbbbebbbdbbbebbbdbbbbbbbdbbbbbbbebbbbbbb:l29hZ;69:9kZ;N;76Z;rg97Z;z;o9xZ8J;B85Z;:;u9yZ;b;k9HZ:2;Z9DZ9e:l9mZ59A8KZ:r;T3Z:A:zYZ79OHZ;j4::8::Y:D9V8:bbbb9s:49:Z8R:hBZ9M9M;M8:L;z;o8:;8:PG89q;x:J878R:hQ8::M:B;e87bbbbbbjZbbjZbbjZ:E;V;N8::Y:DsZ9i;H;68:xd;R8:;h0838:;W:NoZbbbb:WV9O8:uf888:9i;H;68:9c9G;L89;n;m9m89;D8Ko8:bbbbf:8tZ9m836ZS:2AZL;zPZZ818EZ9e:lxZ;U98F8:819E;68:FFuuFFuuFFuuFFuFFFuFFFuFbc:Cqkzebbbebbbdbbb8WWbb"),{}).then(function(o){(r=o.instance).exports.__wasm_call_ctors(),r.exports.meshopt_encodeVertexVersion(0),r.exports.meshopt_encodeIndexVersion(1)});function a(o){if(!o)throw new Error("Assertion failed")}function t(o){return new Uint8Array(o.buffer,o.byteOffset,o.byteLength)}function i(o,b,c,h,f){var l=r.exports.sbrk,u=l(b),I=l(h*f),C=new Uint8Array(r.exports.memory.buffer);C.set(t(c),I);var B=o(u,b,I,h,f),m=new Uint8Array(B);return m.set(C.subarray(u,u+B)),l(u-l(0)),m}function s(o){for(var b=0,c=0;c<o.length;++c)var h=o[c];return b}function n(o,b){if(a(b==2||b==4),b==4)return new Uint32Array(o.buffer,o.byteOffset,o.byteLength/4);var c=new Uint16Array(o.buffer,o.byteOffset,o.byteLength/2);return new Uint32Array(c)}function d(o,b,c,h,f,l,u){var I=r.exports.sbrk,C=I(c*h),B=I(c*l),m=new Uint8Array(r.exports.memory.buffer);m.set(t(b),B),o(C,c,h,f,B,u);var E=new Uint8Array(c*h);return E.set(m.subarray(C,C+c*h)),I(C-I(0)),E}})();var DA=function(){var r=new Uint8Array([0,97,115,109,1,0,0,0,1,4,1,96,0,0,3,3,2,0,0,5,3,1,0,1,12,1,0,10,22,2,12,0,65,0,65,0,65,0,252,10,0,0,11,7,0,65,0,253,15,26,11]),e=new Uint8Array([32,0,65,2,1,106,34,33,3,128,11,4,13,64,6,253,10,7,15,116,127,5,8,12,40,16,19,54,20,9,27,255,113,17,42,67,24,23,146,148,18,14,22,45,70,69,56,114,101,21,25,63,75,136,108,28,118,29,73,115]);if(typeof WebAssembly!="object")return{supported:!1};var A,a=WebAssembly.validate(r)?"b9H79TebbbeKl9Gbb9Gvuuuuueu9Giuuub9Geueuikqbbebeedddilve9Weeeviebeoweuec:q;Aekr;leDo9TW9T9VV95dbH9F9F939H79T9F9J9H229F9Jt9VV7bb8A9TW79O9V9Wt9F9KW9J9V9KW9wWVtW949c919M9MWVbdY9TW79O9V9Wt9F9KW9J9V9KW69U9KW949c919M9MWVblE9TW79O9V9Wt9F9KW9J9V9KW69U9KW949tWG91W9U9JWbvL9TW79O9V9Wt9F9KW9J9V9KWS9P2tWV9p9JtboK9TW79O9V9Wt9F9KW9J9V9KWS9P2tWV9r919HtbrL9TW79O9V9Wt9F9KW9J9V9KWS9P2tWVT949Wbwl79IV9RbDq;b9tqlbzik9:evu8Jjjjjbcz9Rhbcbheincbhdcbhiinabcwfadfaicjuaead4ceGglE86bbaialfhiadcefgdcw9hmbkaec:q:yjjbfai86bbaecitc:q1jjbfab8Piw83ibaecefgecjd9hmbkk;e8JlHud97euo978Jjjjjbcj;kb9Rgv8Kjjjjbc9:hodnadcefal0mbcuhoaiRbbc:Ge9hmbavaialfgrad9Rad;8qbbcj;abad9UhoaicefhldnadTmbaoc;WFbGgocjdaocjd6EhwcbhDinaDae9pmeawaeaD9RaDawfae6Egqcsfgoc9WGgkci2hxakcethmaocl4cifcd4hPabaDad2fhscbhzdnincbhHalhOcbhAdninaraO9RaP6miavcj;cbfaAak2fhCaOaPfhlcbhidnakc;ab6mbaral9Rc;Gb6mbcbhoinaCaofhidndndndndnaOaoco4fRbbgXciGPlbedibkaipxbbbbbbbbbbbbbbbbpklbxikaialpbblalpbbbgQclp:meaQpmbzeHdOiAlCvXoQrLgQcdp:meaQpmbzeHdOiAlCvXoQrLpxiiiiiiiiiiiiiiiip9ogLpxiiiiiiiiiiiiiiiip8JgQp5b9cjF;8;4;W;G;ab9:9cU1:NgKcitc:q1jjbfpbibaKc:q:yjjbfpbbbgYaYpmbbbbbbbbbbbbbbbbaQp5e9cjF;8;4;W;G;ab9:9cU1:NgKcitc:q1jjbfpbibp9UpmbedilvorzHOACXQLpPaLaQp9spklbalclfaYpQbfaKc:q:yjjbfRbbfhlxdkaialpbbwalpbbbgQclp:meaQpmbzeHdOiAlCvXoQrLpxssssssssssssssssp9ogLpxssssssssssssssssp8JgQp5b9cjF;8;4;W;G;ab9:9cU1:NgKcitc:q1jjbfpbibaKc:q:yjjbfpbbbgYaYpmbbbbbbbbbbbbbbbbaQp5e9cjF;8;4;W;G;ab9:9cU1:NgKcitc:q1jjbfpbibp9UpmbedilvorzHOACXQLpPaLaQp9spklbalcwfaYpQbfaKc:q:yjjbfRbbfhlxekaialpbbbpklbalczfhlkdndndndndnaXcd4ciGPlbedibkaipxbbbbbbbbbbbbbbbbpklzxikaialpbblalpbbbgQclp:meaQpmbzeHdOiAlCvXoQrLgQcdp:meaQpmbzeHdOiAlCvXoQrLpxiiiiiiiiiiiiiiiip9ogLpxiiiiiiiiiiiiiiiip8JgQp5b9cjF;8;4;W;G;ab9:9cU1:NgKcitc:q1jjbfpbibaKc:q:yjjbfpbbbgYaYpmbbbbbbbbbbbbbbbbaQp5e9cjF;8;4;W;G;ab9:9cU1:NgKcitc:q1jjbfpbibp9UpmbedilvorzHOACXQLpPaLaQp9spklzalclfaYpQbfaKc:q:yjjbfRbbfhlxdkaialpbbwalpbbbgQclp:meaQpmbzeHdOiAlCvXoQrLpxssssssssssssssssp9ogLpxssssssssssssssssp8JgQp5b9cjF;8;4;W;G;ab9:9cU1:NgKcitc:q1jjbfpbibaKc:q:yjjbfpbbbgYaYpmbbbbbbbbbbbbbbbbaQp5e9cjF;8;4;W;G;ab9:9cU1:NgKcitc:q1jjbfpbibp9UpmbedilvorzHOACXQLpPaLaQp9spklzalcwfaYpQbfaKc:q:yjjbfRbbfhlxekaialpbbbpklzalczfhlkdndndndndnaXcl4ciGPlbedibkaipxbbbbbbbbbbbbbbbbpklaxikaialpbblalpbbbgQclp:meaQpmbzeHdOiAlCvXoQrLgQcdp:meaQpmbzeHdOiAlCvXoQrLpxiiiiiiiiiiiiiiiip9ogLpxiiiiiiiiiiiiiiiip8JgQp5b9cjF;8;4;W;G;ab9:9cU1:NgKcitc:q1jjbfpbibaKc:q:yjjbfpbbbgYaYpmbbbbbbbbbbbbbbbbaQp5e9cjF;8;4;W;G;ab9:9cU1:NgKcitc:q1jjbfpbibp9UpmbedilvorzHOACXQLpPaLaQp9spklaalclfaYpQbfaKc:q:yjjbfRbbfhlxdkaialpbbwalpbbbgQclp:meaQpmbzeHdOiAlCvXoQrLpxssssssssssssssssp9ogLpxssssssssssssssssp8JgQp5b9cjF;8;4;W;G;ab9:9cU1:NgKcitc:q1jjbfpbibaKc:q:yjjbfpbbbgYaYpmbbbbbbbbbbbbbbbbaQp5e9cjF;8;4;W;G;ab9:9cU1:NgKcitc:q1jjbfpbibp9UpmbedilvorzHOACXQLpPaLaQp9spklaalcwfaYpQbfaKc:q:yjjbfRbbfhlxekaialpbbbpklaalczfhlkdndndndndnaXco4Plbedibkaipxbbbbbbbbbbbbbbbbpkl8WxikaialpbblalpbbbgQclp:meaQpmbzeHdOiAlCvXoQrLgQcdp:meaQpmbzeHdOiAlCvXoQrLpxiiiiiiiiiiiiiiiip9ogLpxiiiiiiiiiiiiiiiip8JgQp5b9cjF;8;4;W;G;ab9:9cU1:NgXcitc:q1jjbfpbibaXc:q:yjjbfpbbbgYaYpmbbbbbbbbbbbbbbbbaQp5e9cjF;8;4;W;G;ab9:9cU1:NgXcitc:q1jjbfpbibp9UpmbedilvorzHOACXQLpPaLaQp9spkl8WalclfaYpQbfaXc:q:yjjbfRbbfhlxdkaialpbbwalpbbbgQclp:meaQpmbzeHdOiAlCvXoQrLpxssssssssssssssssp9ogLpxssssssssssssssssp8JgQp5b9cjF;8;4;W;G;ab9:9cU1:NgXcitc:q1jjbfpbibaXc:q:yjjbfpbbbgYaYpmbbbbbbbbbbbbbbbbaQp5e9cjF;8;4;W;G;ab9:9cU1:NgXcitc:q1jjbfpbibp9UpmbedilvorzHOACXQLpPaLaQp9spkl8WalcwfaYpQbfaXc:q:yjjbfRbbfhlxekaialpbbbpkl8Walczfhlkaoc;abfhiaocjefak0meaihoaral9Rc;Fb0mbkkdndnaiak9pmbaici4hoinaral9RcK6mdaCaifhXdndndndndnaOaico4fRbbaocoG4ciGPlbedibkaXpxbbbbbbbbbbbbbbbbpklbxikaXalpbblalpbbbgQclp:meaQpmbzeHdOiAlCvXoQrLgQcdp:meaQpmbzeHdOiAlCvXoQrLpxiiiiiiiiiiiiiiiip9ogLpxiiiiiiiiiiiiiiiip8JgQp5b9cjF;8;4;W;G;ab9:9cU1:NgKcitc:q1jjbfpbibaKc:q:yjjbfpbbbgYaYpmbbbbbbbbbbbbbbbbaQp5e9cjF;8;4;W;G;ab9:9cU1:NgKcitc:q1jjbfpbibp9UpmbedilvorzHOACXQLpPaLaQp9spklbalclfaYpQbfaKc:q:yjjbfRbbfhlxdkaXalpbbwalpbbbgQclp:meaQpmbzeHdOiAlCvXoQrLpxssssssssssssssssp9ogLpxssssssssssssssssp8JgQp5b9cjF;8;4;W;G;ab9:9cU1:NgKcitc:q1jjbfpbibaKc:q:yjjbfpbbbgYaYpmbbbbbbbbbbbbbbbbaQp5e9cjF;8;4;W;G;ab9:9cU1:NgKcitc:q1jjbfpbibp9UpmbedilvorzHOACXQLpPaLaQp9spklbalcwfaYpQbfaKc:q:yjjbfRbbfhlxekaXalpbbbpklbalczfhlkaocdfhoaiczfgiak6mbkkalTmbaAcd0hHalhOaAcefgAclSmdxekkcbhlaHceGTmdkdnakTmbavcjdfazfhiavazfpbdbhYcbhXinaiavcj;cbfaXfgopblbgLcep9TaLpxeeeeeeeeeeeeeeeegQp9op9Hp9rgLaoakfpblbg8Acep9Ta8AaQp9op9Hp9rg8ApmbzeHdOiAlCvXoQrLgEaoamfpblbg3cep9Ta3aQp9op9Hp9rg3aoaxfpblbg5cep9Ta5aQp9op9Hp9rg5pmbzeHdOiAlCvXoQrLg8EpmbezHdiOAlvCXorQLgQaQpmbedibedibedibediaYp9UgYp9AdbbaiadfgoaYaQaQpmlvorlvorlvorlvorp9UgYp9AdbbaoadfgoaYaQaQpmwDqkwDqkwDqkwDqkp9UgYp9AdbbaoadfgoaYaQaQpmxmPsxmPsxmPsxmPsp9UgYp9AdbbaoadfgoaYaEa8EpmwDKYqk8AExm35Ps8E8FgQaQpmbedibedibedibedip9UgYp9AdbbaoadfgoaYaQaQpmlvorlvorlvorlvorp9UgYp9AdbbaoadfgoaYaQaQpmwDqkwDqkwDqkwDqkp9UgYp9AdbbaoadfgoaYaQaQpmxmPsxmPsxmPsxmPsp9UgYp9AdbbaoadfgoaYaLa8ApmwKDYq8AkEx3m5P8Es8FgLa3a5pmwKDYq8AkEx3m5P8Es8Fg8ApmbezHdiOAlvCXorQLgQaQpmbedibedibedibedip9UgYp9AdbbaoadfgoaYaQaQpmlvorlvorlvorlvorp9UgYp9AdbbaoadfgoaYaQaQpmwDqkwDqkwDqkwDqkp9UgYp9AdbbaoadfgoaYaQaQpmxmPsxmPsxmPsxmPsp9UgYp9AdbbaoadfgoaYaLa8ApmwDKYqk8AExm35Ps8E8FgQaQpmbedibedibedibedip9UgYp9AdbbaoadfgoaYaQaQpmlvorlvorlvorlvorp9UgYp9AdbbaoadfgoaYaQaQpmwDqkwDqkwDqkwDqkp9UgYp9AdbbaoadfgoaYaQaQpmxmPsxmPsxmPsxmPsp9UgYp9AdbbaoadfhiaXczfgXak6mbkkazclfgzad6mbkasavcjdfaqad2;8qbbavavcjdfaqcufad2fad;8qbbaqaDfhDc9:hoalmexikkc9:hoxekcbc99aral9Radcaadca0ESEhokavcj;kbf8Kjjjjbaokwbz:bjjjbk;tzeHu8Jjjjjbc;ae9Rgv8Kjjjjbc9:hodnaeci9UgrcHfal0mbcuhoaiRbbgwc;WeGc;Ge9hmbawcsGgDce0mbavc;abfcFecje;8kbavcUf9cu83ibavc8Wf9cu83ibavcyf9cu83ibavcaf9cu83ibavcKf9cu83ibavczf9cu83ibav9cu83iwav9cu83ibaialfc9WfhqaicefgwarfhodnaeTmbcmcsaDceSEhkcbhxcbhmcbhrcbhicbhlindnaoaq9nmbc9:hoxikdndnawRbbgDc;Ve0mbavc;abfalaDcu7gPcl4fcsGcitfgsydlhzasydbhHdnaDcsGgDak9pmbavaiaPfcsGcdtfydbaxaDEhsaDThDdndnadcd9hmbabarcetfgPaH87ebaPcdfaz87ebaPclfas87ebxekabarcdtfgPaHBdbaPclfazBdbaPcwfasBdbkaxaDfhxavc;abfalcitfgPasBdbaPazBdlavaicdtfasBdbavc;abfalcefcsGglcitfgPaHBdbaPasBdlaiaDfhialcefhlxdkdndnaDcsSmbamaDfaDc987fcefhmxekaocefhDao8SbbgscFeGhPdndnascu9mmbaDhoxekaocvfhoaPcFbGhPcrhsdninaD8SbbgOcFbGastaPVhPaOcu9kmeaDcefhDascrfgsc8J9hmbxdkkaDcefhokaPce4cbaPceG9R7amfhmkdndnadcd9hmbabarcetfgDaH87ebaDcdfaz87ebaDclfam87ebxekabarcdtfgDaHBdbaDclfazBdbaDcwfamBdbkavc;abfalcitfgDamBdbaDazBdlavaicdtfamBdbavc;abfalcefcsGglcitfgDaHBdbaDamBdlaicefhialcefhlxekdnaDcpe0mbaxcefgOavaiaqaDcsGfRbbgscl49RcsGcdtfydbascz6gPEhDavaias9RcsGcdtfydbaOaPfgzascsGgOEhsaOThOdndnadcd9hmbabarcetfgHax87ebaHcdfaD87ebaHclfas87ebxekabarcdtfgHaxBdbaHclfaDBdbaHcwfasBdbkavaicdtfaxBdbavc;abfalcitfgHaDBdbaHaxBdlavaicefgicsGcdtfaDBdbavc;abfalcefcsGcitfgHasBdbaHaDBdlavaiaPfcsGgicdtfasBdbavc;abfalcdfcsGglcitfgDaxBdbaDasBdlalcefhlaiaOfhiazaOfhxxekaxcbaoRbbgHEgAaDc;:eSgDfhzaHcsGhCaHcl4hXdndnaHcs0mbazcefhOxekazhOavaiaX9RcsGcdtfydbhzkdndnaCmbaOcefhxxekaOhxavaiaH9RcsGcdtfydbhOkdndnaDTmbaocefhDxekaocdfhDao8SbegPcFeGhsdnaPcu9kmbaocofhAascFbGhscrhodninaD8SbbgPcFbGaotasVhsaPcu9kmeaDcefhDaocrfgoc8J9hmbkaAhDxekaDcefhDkasce4cbasceG9R7amfgmhAkdndnaXcsSmbaDhsxekaDcefhsaD8SbbgocFeGhPdnaocu9kmbaDcvfhzaPcFbGhPcrhodninas8SbbgDcFbGaotaPVhPaDcu9kmeascefhsaocrfgoc8J9hmbkazhsxekascefhskaPce4cbaPceG9R7amfgmhzkdndnaCcsSmbashoxekascefhoas8SbbgDcFeGhPdnaDcu9kmbascvfhOaPcFbGhPcrhDdninao8SbbgscFbGaDtaPVhPascu9kmeaocefhoaDcrfgDc8J9hmbkaOhoxekaocefhokaPce4cbaPceG9R7amfgmhOkdndnadcd9hmbabarcetfgDaA87ebaDcdfaz87ebaDclfaO87ebxekabarcdtfgDaABdbaDclfazBdbaDcwfaOBdbkavc;abfalcitfgDazBdbaDaABdlavaicdtfaABdbavc;abfalcefcsGcitfgDaOBdbaDazBdlavaicefgicsGcdtfazBdbavc;abfalcdfcsGcitfgDaABdbaDaOBdlavaiaHcz6aXcsSVfgicsGcdtfaOBdbaiaCTaCcsSVfhialcifhlkawcefhwalcsGhlaicsGhiarcifgrae6mbkkcbc99aoaqSEhokavc;aef8Kjjjjbaok:flevu8Jjjjjbcz9Rhvc9:hodnaecvfal0mbcuhoaiRbbc;:eGc;qe9hmbav9cb83iwaicefhraialfc98fhwdnaeTmbdnadcdSmbcbhDindnaraw6mbc9:skarcefhoar8SbbglcFeGhidndnalcu9mmbaohrxekarcvfhraicFbGhicrhldninao8SbbgdcFbGaltaiVhiadcu9kmeaocefhoalcrfglc8J9hmbxdkkaocefhrkabaDcdtfaic8Etc8F91aicd47avcwfaiceGcdtVgoydbfglBdbaoalBdbaDcefgDae9hmbxdkkcbhDindnaraw6mbc9:skarcefhoar8SbbglcFeGhidndnalcu9mmbaohrxekarcvfhraicFbGhicrhldninao8SbbgdcFbGaltaiVhiadcu9kmeaocefhoalcrfglc8J9hmbxdkkaocefhrkabaDcetfaic8Etc8F91aicd47avcwfaiceGcdtVgoydbfgl87ebaoalBdbaDcefgDae9hmbkkcbc99arawSEhokaok:wPliuo97eue978Jjjjjbca9Rhiaec98Ghldndnadcl9hmbdnalTmbcbhvabhdinadadpbbbgocKp:RecKp:Sep;6egraocwp:RecKp:Sep;6earp;Geaoczp:RecKp:Sep;6egwp;Gep;Kep;LegDpxbbbbbbbbbbbbbbbbp:2egqarpxbbbjbbbjbbbjbbbjgkp9op9rp;Kegrpxbb;:9cbb;:9cbb;:9cbb;:9cararp;MeaDaDp;Meawaqawakp9op9rp;Kegrarp;Mep;Kep;Kep;Jep;Negwp;Mepxbbn0bbn0bbn0bbn0gqp;KepxFbbbFbbbFbbbFbbbp9oaopxbbbFbbbFbbbFbbbFp9op9qarawp;Meaqp;Kecwp:RepxbFbbbFbbbFbbbFbbp9op9qaDawp;Meaqp;Keczp:RepxbbFbbbFbbbFbbbFbp9op9qpkbbadczfhdavclfgval6mbkkalae9pmeaipxbbbbbbbbbbbbbbbbgqpklbaiabalcdtfgdaeciGglcdtgv;8qbbdnalTmbaiaipblbgocKp:RecKp:Sep;6egraocwp:RecKp:Sep;6earp;Geaoczp:RecKp:Sep;6egwp;Gep;Kep;LegDaqp:2egqarpxbbbjbbbjbbbjbbbjgkp9op9rp;Kegrpxbb;:9cbb;:9cbb;:9cbb;:9cararp;MeaDaDp;Meawaqawakp9op9rp;Kegrarp;Mep;Kep;Kep;Jep;Negwp;Mepxbbn0bbn0bbn0bbn0gqp;KepxFbbbFbbbFbbbFbbbp9oaopxbbbFbbbFbbbFbbbFp9op9qarawp;Meaqp;Kecwp:RepxbFbbbFbbbFbbbFbbp9op9qaDawp;Meaqp;Keczp:RepxbbFbbbFbbbFbbbFbp9op9qpklbkadaiav;8qbbskdnalTmbcbhvabhdinadczfgxaxpbbbgopxbbbbbbFFbbbbbbFFgkp9oadpbbbgDaopmlvorxmPsCXQL358E8FpxFubbFubbFubbFubbp9op;6eaDaopmbediwDqkzHOAKY8AEgoczp:Sep;6egrp;Geaoczp:Reczp:Sep;6egwp;Gep;Kep;Legopxb;:FSb;:FSb;:FSb;:FSawaopxbbbbbbbbbbbbbbbbp:2egqawpxbbbjbbbjbbbjbbbjgmp9op9rp;Kegwawp;Meaoaop;Mearaqaramp9op9rp;Kegoaop;Mep;Kep;Kep;Jep;Negrp;Mepxbbn0bbn0bbn0bbn0gqp;Keczp:Reawarp;Meaqp;KepxFFbbFFbbFFbbFFbbp9op9qgwaoarp;Meaqp;KepxFFbbFFbbFFbbFFbbp9ogopmwDKYqk8AExm35Ps8E8Fp9qpkbbadaDakp9oawaopmbezHdiOAlvCXorQLp9qpkbbadcafhdavclfgval6mbkkalae9pmbaiaeciGgvcitgdfcbcaad9R;8kbaiabalcitfglad;8qbbdnavTmbaiaipblzgopxbbbbbbFFbbbbbbFFgkp9oaipblbgDaopmlvorxmPsCXQL358E8FpxFubbFubbFubbFubbp9op;6eaDaopmbediwDqkzHOAKY8AEgoczp:Sep;6egrp;Geaoczp:Reczp:Sep;6egwp;Gep;Kep;Legopxb;:FSb;:FSb;:FSb;:FSawaopxbbbbbbbbbbbbbbbbp:2egqawpxbbbjbbbjbbbjbbbjgmp9op9rp;Kegwawp;Meaoaop;Mearaqaramp9op9rp;Kegoaop;Mep;Kep;Kep;Jep;Negrp;Mepxbbn0bbn0bbn0bbn0gqp;Keczp:Reawarp;Meaqp;KepxFFbbFFbbFFbbFFbbp9op9qgwaoarp;Meaqp;KepxFFbbFFbbFFbbFFbbp9ogopmwDKYqk8AExm35Ps8E8Fp9qpklzaiaDakp9oawaopmbezHdiOAlvCXorQLp9qpklbkalaiad;8qbbkk;4wllue97euv978Jjjjjbc8W9Rhidnaec98GglTmbcbhvabhoinaiaopbbbgraoczfgwpbbbgDpmlvorxmPsCXQL358E8Fgqczp:Segkclp:RepklbaopxbbjZbbjZbbjZbbjZpx;Zl81Z;Zl81Z;Zl81Z;Zl81Zakpxibbbibbbibbbibbbp9qp;6ep;NegkaraDpmbediwDqkzHOAKY8AEgrczp:Reczp:Sep;6ep;MegDaDp;Meakarczp:Sep;6ep;Megxaxp;Meakaqczp:Reczp:Sep;6ep;Megqaqp;Mep;Kep;Kep;Lepxbbbbbbbbbbbbbbbbp:4ep;Jepxb;:FSb;:FSb;:FSb;:FSgkp;Mepxbbn0bbn0bbn0bbn0grp;KepxFFbbFFbbFFbbFFbbgmp9oaxakp;Mearp;Keczp:Rep9qgxaqakp;Mearp;Keczp:ReaDakp;Mearp;Keamp9op9qgkpmbezHdiOAlvCXorQLgrp5baipblbpEb:T:j83ibaocwfarp5eaipblbpEe:T:j83ibawaxakpmwDKYqk8AExm35Ps8E8Fgkp5baipblbpEd:T:j83ibaocKfakp5eaipblbpEi:T:j83ibaocafhoavclfgval6mbkkdnalae9pmbaiaeciGgvcitgofcbcaao9R;8kbaiabalcitfgwao;8qbbdnavTmbaiaipblbgraipblzgDpmlvorxmPsCXQL358E8Fgqczp:Segkclp:RepklaaipxbbjZbbjZbbjZbbjZpx;Zl81Z;Zl81Z;Zl81Z;Zl81Zakpxibbbibbbibbbibbbp9qp;6ep;NegkaraDpmbediwDqkzHOAKY8AEgrczp:Reczp:Sep;6ep;MegDaDp;Meakarczp:Sep;6ep;Megxaxp;Meakaqczp:Reczp:Sep;6ep;Megqaqp;Mep;Kep;Kep;Lepxbbbbbbbbbbbbbbbbp:4ep;Jepxb;:FSb;:FSb;:FSb;:FSgkp;Mepxbbn0bbn0bbn0bbn0grp;KepxFFbbFFbbFFbbFFbbgmp9oaxakp;Mearp;Keczp:Rep9qgxaqakp;Mearp;Keczp:ReaDakp;Mearp;Keamp9op9qgkpmbezHdiOAlvCXorQLgrp5baipblapEb:T:j83ibaiarp5eaipblapEe:T:j83iwaiaxakpmwDKYqk8AExm35Ps8E8Fgkp5baipblapEd:T:j83izaiakp5eaipblapEi:T:j83iKkawaiao;8qbbkk:Pddiue978Jjjjjbc;ab9Rhidnadcd4ae2glc98GgvTmbcbheabhdinadadpbbbgocwp:Recwp:Sep;6eaocep:SepxbbjFbbjFbbjFbbjFp9opxbbjZbbjZbbjZbbjZp:Uep;Mepkbbadczfhdaeclfgeav6mbkkdnaval9pmbaialciGgecdtgdVcbc;abad9R;8kbaiabavcdtfgvad;8qbbdnaeTmbaiaipblbgocwp:Recwp:Sep;6eaocep:SepxbbjFbbjFbbjFbbjFp9opxbbjZbbjZbbjZbbjZp:Uep;Mepklbkavaiad;8qbbkk9teiucbcbydj1jjbgeabcifc98GfgbBdj1jjbdndnabZbcztgd9nmbcuhiabad9RcFFifcz4nbcuSmekaehikaikkkebcjwklz9Tbb":"b9H79Tebbbe8Fv9Gbb9Gvuuuuueu9Giuuub9Geueu9Giuuueuikqbeeedddillviebeoweuec:q;iekr;leDo9TW9T9VV95dbH9F9F939H79T9F9J9H229F9Jt9VV7bb8A9TW79O9V9Wt9F9KW9J9V9KW9wWVtW949c919M9MWVbeY9TW79O9V9Wt9F9KW9J9V9KW69U9KW949c919M9MWVbdE9TW79O9V9Wt9F9KW9J9V9KW69U9KW949tWG91W9U9JWbiL9TW79O9V9Wt9F9KW9J9V9KWS9P2tWV9p9JtblK9TW79O9V9Wt9F9KW9J9V9KWS9P2tWV9r919HtbvL9TW79O9V9Wt9F9KW9J9V9KWS9P2tWVT949Wbol79IV9Rbrq;d8Yqdbk:yzeHu8Jjjjjbcj;eb9Rgv8Kjjjjbc9:hodnadcefal0mbcuhoaiRbbc:Ge9hmbavaialfgrad9Radz1jjjbhwcj;abad9UhlaicefhodnadTmbalc;WFbGglcjdalcjd6EhDcbhqinaqae9pmeaDaeaq9RaqaDfae6Egkcsfglcl4cifcd4hxdndndndnalc9WGgmTmbcbhPcehsawcjdfhzaohHinaraH9Rax6midnaraHaxfgo9RcK6mbczhlcbhOinalgic9WfgAawcj;cbffhldndndndndnaHaAco4fRbbaOcoG4ciGPlbedibkal9cb83ibalcwf9cb83ibxikalaoRblaoRbbgAco4gCaCciSgCE86bbawcj;cbfaifglcGfaoclfaCfgCRbbaAcl4ciGgXaXciSgXE86bbalcVfaCaXfgCRbbaAcd4ciGgXaXciSgXE86bbalc7faCaXfgCRbbaAciGgAaAciSgAE86bbalctfaCaAfgCRbbaoRbegAco4gXaXciSgXE86bbalc91faCaXfgCRbbaAcl4ciGgXaXciSgXE86bbalc4faCaXfgCRbbaAcd4ciGgXaXciSgXE86bbalc93faCaXfgCRbbaAciGgAaAciSgAE86bbalc94faCaAfgCRbbaoRbdgAco4gXaXciSgXE86bbalc95faCaXfgCRbbaAcl4ciGgXaXciSgXE86bbalc96faCaXfgCRbbaAcd4ciGgXaXciSgXE86bbalc97faCaXfgCRbbaAciGgAaAciSgAE86bbalc98faCaAfgARbbaoRbigoco4gCaCciSgCE86bbalc99faAaCfgARbbaocl4ciGgCaCciSgCE86bbalc9:faAaCfgARbbaocd4ciGgCaCciSgCE86bbalcufaAaCfglRbbaociGgoaociSgoE86bbalaofhoxdkalaoRbwaoRbbgAcl4gCaCcsSgCE86bbawcj;cbfaifglcGfaocwfaCfgCRbbaAcsGgAaAcsSgAE86bbalcVfaCaAfgARbbaoRbegCcl4gXaXcsSgXE86bbalc7faAaXfgARbbaCcsGgCaCcsSgCE86bbalctfaAaCfgARbbaoRbdgCcl4gXaXcsSgXE86bbalc91faAaXfgARbbaCcsGgCaCcsSgCE86bbalc4faAaCfgARbbaoRbigCcl4gXaXcsSgXE86bbalc93faAaXfgARbbaCcsGgCaCcsSgCE86bbalc94faAaCfgARbbaoRblgCcl4gXaXcsSgXE86bbalc95faAaXfgARbbaCcsGgCaCcsSgCE86bbalc96faAaCfgARbbaoRbvgCcl4gXaXcsSgXE86bbalc97faAaXfgARbbaCcsGgCaCcsSgCE86bbalc98faAaCfgARbbaoRbogCcl4gXaXcsSgXE86bbalc99faAaXfgARbbaCcsGgCaCcsSgCE86bbalc9:faAaCfgARbbaoRbrgocl4gCaCcsSgCE86bbalcufaAaCfglRbbaocsGgoaocsSgoE86bbalaofhoxekalao8Pbb83bbalcwfaocwf8Pbb83bbaoczfhokdnaiam9pmbaOcdfhOaiczfhlarao9RcL0mekkaiam6miaoTmidnakTmbawaPfRbbhOawcj;cbfhlazhiakhAinaialRbbgHce4cbaHceG9R7aOfgO86bbaiadfhialcefhlaAcufgAmbkkazcefhzaPcefgPad6hsaohHaPad9hmexvkkcbhoasceGmdxikaoaxad2fhXdnakTmbcbhmcehsawcjdfhCinarao9Rax6miaoTmdaoaxfhoawamfRbbhOawcj;cbfhlaChiakhAinaialRbbgHce4cbaHceG9R7aOfgO86bbaiadfhialcefhlaAcufgAmbkaCcefhCamcefgmad6hsamad9hmbkaXhoxikcbhlcehsinarao9Rax6mdaoTmeaoaxfhoalcefglad6hsadal9hmbkaXhoxdkcbhoasceGTmekc9:hoxikabaqad2fawcjdfakad2z1jjjb8Aawawcjdfakcufad2fadz1jjjb8Aakaqfhqaombkc9:hoxekcbc99arao9Radcaadca0ESEhokavcj;ebf8Kjjjjbaok;xzeHu8Jjjjjbc;ae9Rgv8Kjjjjbc9:hodnaeci9UgrcHfal0mbcuhoaiRbbgwc;WeGc;Ge9hmbawcsGgDce0mbavc;abfcFecjez:jjjjb8AavcUf9cu83ibavc8Wf9cu83ibavcyf9cu83ibavcaf9cu83ibavcKf9cu83ibavczf9cu83ibav9cu83iwav9cu83ibaialfc9WfhqaicefgwarfhodnaeTmbcmcsaDceSEhkcbhxcbhmcbhrcbhicbhlindnaoaq9nmbc9:hoxikdndnawRbbgDc;Ve0mbavc;abfalaDcu7gPcl4fcsGcitfgsydlhzasydbhHdnaDcsGgDak9pmbavaiaPfcsGcdtfydbaxaDEhsaDThDdndnadcd9hmbabarcetfgPaH87ebaPcdfaz87ebaPclfas87ebxekabarcdtfgPaHBdbaPclfazBdbaPcwfasBdbkaxaDfhxavc;abfalcitfgPasBdbaPazBdlavaicdtfasBdbavc;abfalcefcsGglcitfgPaHBdbaPasBdlaiaDfhialcefhlxdkdndnaDcsSmbamaDfaDc987fcefhmxekaocefhDao8SbbgscFeGhPdndnascu9mmbaDhoxekaocvfhoaPcFbGhPcrhsdninaD8SbbgOcFbGastaPVhPaOcu9kmeaDcefhDascrfgsc8J9hmbxdkkaDcefhokaPce4cbaPceG9R7amfhmkdndnadcd9hmbabarcetfgDaH87ebaDcdfaz87ebaDclfam87ebxekabarcdtfgDaHBdbaDclfazBdbaDcwfamBdbkavc;abfalcitfgDamBdbaDazBdlavaicdtfamBdbavc;abfalcefcsGglcitfgDaHBdbaDamBdlaicefhialcefhlxekdnaDcpe0mbaxcefgOavaiaqaDcsGfRbbgscl49RcsGcdtfydbascz6gPEhDavaias9RcsGcdtfydbaOaPfgzascsGgOEhsaOThOdndnadcd9hmbabarcetfgHax87ebaHcdfaD87ebaHclfas87ebxekabarcdtfgHaxBdbaHclfaDBdbaHcwfasBdbkavaicdtfaxBdbavc;abfalcitfgHaDBdbaHaxBdlavaicefgicsGcdtfaDBdbavc;abfalcefcsGcitfgHasBdbaHaDBdlavaiaPfcsGgicdtfasBdbavc;abfalcdfcsGglcitfgDaxBdbaDasBdlalcefhlaiaOfhiazaOfhxxekaxcbaoRbbgHEgAaDc;:eSgDfhzaHcsGhCaHcl4hXdndnaHcs0mbazcefhOxekazhOavaiaX9RcsGcdtfydbhzkdndnaCmbaOcefhxxekaOhxavaiaH9RcsGcdtfydbhOkdndnaDTmbaocefhDxekaocdfhDao8SbegPcFeGhsdnaPcu9kmbaocofhAascFbGhscrhodninaD8SbbgPcFbGaotasVhsaPcu9kmeaDcefhDaocrfgoc8J9hmbkaAhDxekaDcefhDkasce4cbasceG9R7amfgmhAkdndnaXcsSmbaDhsxekaDcefhsaD8SbbgocFeGhPdnaocu9kmbaDcvfhzaPcFbGhPcrhodninas8SbbgDcFbGaotaPVhPaDcu9kmeascefhsaocrfgoc8J9hmbkazhsxekascefhskaPce4cbaPceG9R7amfgmhzkdndnaCcsSmbashoxekascefhoas8SbbgDcFeGhPdnaDcu9kmbascvfhOaPcFbGhPcrhDdninao8SbbgscFbGaDtaPVhPascu9kmeaocefhoaDcrfgDc8J9hmbkaOhoxekaocefhokaPce4cbaPceG9R7amfgmhOkdndnadcd9hmbabarcetfgDaA87ebaDcdfaz87ebaDclfaO87ebxekabarcdtfgDaABdbaDclfazBdbaDcwfaOBdbkavc;abfalcitfgDazBdbaDaABdlavaicdtfaABdbavc;abfalcefcsGcitfgDaOBdbaDazBdlavaicefgicsGcdtfazBdbavc;abfalcdfcsGcitfgDaABdbaDaOBdlavaiaHcz6aXcsSVfgicsGcdtfaOBdbaiaCTaCcsSVfhialcifhlkawcefhwalcsGhlaicsGhiarcifgrae6mbkkcbc99aoaqSEhokavc;aef8Kjjjjbaok:flevu8Jjjjjbcz9Rhvc9:hodnaecvfal0mbcuhoaiRbbc;:eGc;qe9hmbav9cb83iwaicefhraialfc98fhwdnaeTmbdnadcdSmbcbhDindnaraw6mbc9:skarcefhoar8SbbglcFeGhidndnalcu9mmbaohrxekarcvfhraicFbGhicrhldninao8SbbgdcFbGaltaiVhiadcu9kmeaocefhoalcrfglc8J9hmbxdkkaocefhrkabaDcdtfaic8Etc8F91aicd47avcwfaiceGcdtVgoydbfglBdbaoalBdbaDcefgDae9hmbxdkkcbhDindnaraw6mbc9:skarcefhoar8SbbglcFeGhidndnalcu9mmbaohrxekarcvfhraicFbGhicrhldninao8SbbgdcFbGaltaiVhiadcu9kmeaocefhoalcrfglc8J9hmbxdkkaocefhrkabaDcetfaic8Etc8F91aicd47avcwfaiceGcdtVgoydbfgl87ebaoalBdbaDcefgDae9hmbkkcbc99arawSEhokaok:Lvoeue99dud99eud99dndnadcl9hmbaeTmeindndnabcdfgd8Sbb:Yab8Sbbgi:Ygl:l:tabcefgv8Sbbgo:Ygr:l:tgwJbb;:9cawawNJbbbbawawJbbbb9GgDEgq:mgkaqaicb9iEalMgwawNakaqaocb9iEarMgqaqNMM:r:vglNJbbbZJbbb:;aDEMgr:lJbbb9p9DTmbar:Ohixekcjjjj94hikadai86bbdndnaqalNJbbbZJbbb:;aqJbbbb9GEMgq:lJbbb9p9DTmbaq:Ohdxekcjjjj94hdkavad86bbdndnawalNJbbbZJbbb:;awJbbbb9GEMgw:lJbbb9p9DTmbaw:Ohdxekcjjjj94hdkabad86bbabclfhbaecufgembxdkkaeTmbindndnabclfgd8Ueb:Yab8Uebgi:Ygl:l:tabcdfgv8Uebgo:Ygr:l:tgwJb;:FSawawNJbbbbawawJbbbb9GgDEgq:mgkaqaicb9iEalMgwawNakaqaocb9iEarMgqaqNMM:r:vglNJbbbZJbbb:;aDEMgr:lJbbb9p9DTmbar:Ohixekcjjjj94hikadai87ebdndnaqalNJbbbZJbbb:;aqJbbbb9GEMgq:lJbbb9p9DTmbaq:Ohdxekcjjjj94hdkavad87ebdndnawalNJbbbZJbbb:;awJbbbb9GEMgw:lJbbb9p9DTmbaw:Ohdxekcjjjj94hdkabad87ebabcwfhbaecufgembkkk;siliui99iue99dnaeTmbcbhiabhlindndnJ;Zl81Zalcof8UebgvciV:Y:vgoal8Ueb:YNgrJb;:FSNJbbbZJbbb:;arJbbbb9GEMgw:lJbbb9p9DTmbaw:OhDxekcjjjj94hDkalclf8Uebhqalcdf8UebhkabaiavcefciGfcetfaD87ebdndnaoak:YNgwJb;:FSNJbbbZJbbb:;awJbbbb9GEMgx:lJbbb9p9DTmbax:Ohkxekcjjjj94hkkabaiavcdfciGfcetfak87ebdndnaoaq:YNgoJb;:FSNJbbbZJbbb:;aoJbbbb9GEMgx:lJbbb9p9DTmbax:Ohqxekcjjjj94hqkabaiavcufciGfcetfaq87ebdndnJbbjZararN:tawawN:taoaoN:tgrJbbbbarJbbbb9GE:rJb;:FSNJbbbZMgr:lJbbb9p9DTmbar:Ohqxekcjjjj94hqkabaiavciGfcetfaq87ebalcwfhlaiclfhiaecufgembkkk9mbdnadcd4ae2gdTmbinababydbgecwtcw91:Yaece91cjjj98Gcjjj;8if::NUdbabclfhbadcufgdmbkkk9teiucbcbydj1jjbgeabcifc98GfgbBdj1jjbdndnabZbcztgd9nmbcuhiabad9RcFFifcz4nbcuSmekaehikaik;LeeeudndnaeabVciGTmbabhixekdndnadcz9pmbabhixekabhiinaiaeydbBdbaiclfaeclfydbBdbaicwfaecwfydbBdbaicxfaecxfydbBdbaeczfheaiczfhiadc9Wfgdcs0mbkkadcl6mbinaiaeydbBdbaeclfheaiclfhiadc98fgdci0mbkkdnadTmbinaiaeRbb86bbaicefhiaecefheadcufgdmbkkabk;aeedudndnabciGTmbabhixekaecFeGc:b:c:ew2hldndnadcz9pmbabhixekabhiinaialBdbaicxfalBdbaicwfalBdbaiclfalBdbaiczfhiadc9Wfgdcs0mbkkadcl6mbinaialBdbaiclfhiadc98fgdci0mbkkdnadTmbinaiae86bbaicefhiadcufgdmbkkabkkkebcjwklz9Kbb",t=WebAssembly.instantiate(i(a),{}).then(function(f){(A=f.instance).exports.__wasm_call_ctors()});function i(f){for(var l=new Uint8Array(f.length),u=0;u<f.length;++u){var I=f.charCodeAt(u);l[u]=I>96?I-97:I>64?I-39:I+4}var C=0;for(u=0;u<f.length;++u)l[C++]=l[u]<60?e[l[u]]:64*(l[u]-60)+l[++u];return l.buffer.slice(0,C)}function s(f,l,u,I,C,B,m){var E=f.exports.sbrk,j=I+3&-4,k=E(j*C),w=E(B.length),p=new Uint8Array(f.exports.memory.buffer);p.set(B,w);var y=l(k,I,C,w,B.length);if(y==0&&m&&m(k,j,C),u.set(p.subarray(k,k+I*C)),E(k-E(0)),y!=0)throw new Error("Malformed buffer data: "+y)}var n={NONE:"",OCTAHEDRAL:"meshopt_decodeFilterOct",QUATERNION:"meshopt_decodeFilterQuat",EXPONENTIAL:"meshopt_decodeFilterExp"},d={ATTRIBUTES:"meshopt_decodeVertexBuffer",TRIANGLES:"meshopt_decodeIndexBuffer",INDICES:"meshopt_decodeIndexSequence"},o=[],b=0;function c(f){var l={object:new Worker(f),pending:0,requests:{}};return l.object.onmessage=function(u){var I=u.data;l.pending-=I.count,l.requests[I.id][I.action](I.value),delete l.requests[I.id]},l}function h(f){var l=f.data;if(!l.id)return self.close();self.ready.then(function(u){try{var I=new Uint8Array(l.count*l.size);s(u,u.exports[l.mode],I,l.count,l.size,l.source,u.exports[l.filter]),self.postMessage({id:l.id,count:l.count,action:"resolve",value:I},[I.buffer])}catch(C){self.postMessage({id:l.id,count:l.count,action:"reject",value:C})}})}return{ready:t,supported:!0,useWorkers:function(f){(function(l){for(var u="self.ready = WebAssembly.instantiate(new Uint8Array(["+new Uint8Array(i(a))+"]), {}).then(function(result) { result.instance.exports.__wasm_call_ctors(); return result.instance; });self.onmessage = "+h.name+";"+s.toString()+h.toString(),I=new Blob([u],{type:"text/javascript"}),C=URL.createObjectURL(I),B=o.length;B<l;++B)o[B]=c(C);for(B=l;B<o.length;++B)o[B].object.postMessage({});o.length=l,URL.revokeObjectURL(C)})(f)},decodeVertexBuffer:function(f,l,u,I,C){s(A,A.exports.meshopt_decodeVertexBuffer,f,l,u,I,A.exports[n[C]])},decodeIndexBuffer:function(f,l,u,I){s(A,A.exports.meshopt_decodeIndexBuffer,f,l,u,I)},decodeIndexSequence:function(f,l,u,I){s(A,A.exports.meshopt_decodeIndexSequence,f,l,u,I)},decodeGltfBuffer:function(f,l,u,I,C,B){s(A,A.exports[d[C]],f,l,u,I,A.exports[n[B]])},decodeGltfBufferAsync:function(f,l,u,I,C){return o.length>0?function(B,m,E,j,k){for(var w=o[0],p=1;p<o.length;++p)o[p].pending<w.pending&&(w=o[p]);return new Promise(function(y,x){var D=new Uint8Array(E),F=++b;w.pending+=B,w.requests[F]={resolve:y,reject:x},w.object.postMessage({id:F,count:B,size:m,source:D,mode:j,filter:k},[D.buffer])})}(f,l,u,d[I],n[C]):t.then(function(){var B=new Uint8Array(f*l);return s(A,A.exports[d[I]],B,f,l,u,A.exports[n[C]]),B})}}}();(function(){var r,e=new Uint8Array([32,0,65,2,1,106,34,33,3,128,11,4,13,64,6,253,10,7,15,116,127,5,8,12,40,16,19,54,20,9,27,255,113,17,42,67,24,23,146,148,18,14,22,45,70,69,56,114,101,21,25,63,75,136,108,28,118,29,73,115]);if(typeof WebAssembly!="object")return{supported:!1};var A=WebAssembly.instantiate(function(n){for(var d=new Uint8Array(n.length),o=0;o<n.length;++o){var b=n.charCodeAt(o);d[o]=b>96?b-97:b>64?b-39:b+4}var c=0;for(o=0;o<n.length;++o)d[c++]=d[o]<60?e[d[o]]:64*(d[o]-60)+d[++o];return d.buffer.slice(0,c)}("b9H79Tebbbe9Ek9Geueu9Geub9Gbb9GPuuuuuuuuuuu99uueu9Gvuuuuub9Gluuuub9Gquuuuuuu99uueu9Gwuuuuuu99ueu9Giuuue999Gluuuueu9GiuuueuizsdilvoirwDbqqbeqlve9Weiiviebeoweuec:G;jekr:Tewo9TW9T9VV95dbH9F9F939H79T9F9J9H229F9Jt9VV7bbz9TW79O9V9Wt9F79P9T9W29P9M95bl8E9TW79O9V9Wt9F79P9T9W29P9M959x9Pt9OcttV9P9I91tW7bvQ9TW79O9V9Wt9F79P9T9W29P9M959q9V9P9Ut7boX9TW79O9V9Wt9F79P9T9W29P9M959t9J9H2Wbra9TW79O9V9Wt9F9V9Wt9P9T9P96W9wWVtW94SWt9J9O9sW9T9H9Wbwl79IV9RbDDwebcekdxmq::9Usdbk;i6iKuY99Ou8Jjjjjbc;W;ab9RgP8KjjjjbaPcwfcbc;Kbz:ljjjb8AaPcualcefgscdtascFFFFi0Ecbyd1:jjjbHjjjjbbgzBdwaPceBd9OaPazBdbaPcuadcitadcFFFFe0Ecbyd1:jjjbHjjjjbbgHBdxaPcdBd9OaPaHBdlaPaeadalcbz:cjjjbaPcualcdtgOalcFFFFi0EgAcbyd1:jjjbHjjjjbbgCBdzaPciBd9OaPaAcbyd1:jjjbHjjjjbbgXBdCaPclBd9Oalcd4alfhQcehLinaLgscethLasaQ6mbkcbhKaPcuascdtgLascFFFFi0Ecbyd1:jjjbHjjjjbbgQBdKaPcvBd9OaQcFeaLz:ljjjbhYdnalTmbavcd4h8AascufhEinaiaKa8A2cdtfg3ydlgscH4as7c:F:b:DD2a3ydbgscH4as7c;D;O:B8J27a3ydwgscH4as7c:3F;N8N27hQcbhsdndninaYaQaEGgQcdtfg5ydbgLcuSmeaiaLa8A2cdtfa3cxz:ojjjbTmdascefgsaQfhQasaE9nmbxdkka5aKBdbaKhLkaCaKcdtfaLBdbaKcefgKal9hmbkcbhsaXhLinaLasBdbaLclfhLalascefgs9hmbkcbhsaChLaXhQindnasaLydbgESmbaQaXaEcdtfgEydbBdbaEasBdbkaLclfhLaQclfhQalascefgs9hmbkkcbh8EaYcbyd:m:jjjbH:bjjjbbaPclBd9OaPalcbyd1:jjjbHjjjjbbgEBdKaPcvBd9OaPaAcbyd1:jjjbHjjjjbbgsBd3aPcoBd9OaPaAcbyd1:jjjbHjjjjbbgLBdaaPcrBd9OascFeaOz:ljjjbh8FaLcFeaOz:ljjjbhadnalTmbaHcwfhhindnaza8EgQcefg8Ecdtfydbg3azaQcdtgsfydbgLSmba3aL9RhOaHaLcitfhgaaasfh8Ja8FasfhKcbh8Aindndnaga8Acitfydbg5aQ9hmbaKaQBdba8JaQBdbxekdnaza5cdtg8KfgsclfydbgLasydbgsSmbaHascitg3fydbaQSmeaLas9Rh8Lascu7aLfhYaha3fhLcbhsinaYasSmeascefhsaLydbh3aLcwfhLa3aQ9hmbkasa8L6mekaaa8KfgsaQa5asydbcuSEBdbaKa5aQaKydbcuSEBdbka8Acefg8AaO9hmbkka8Eal9hmbkaChLaXhQaah3a8Fh8AcbhsindndnasaLydbg59hmbdnasaQydbg59hmba8Aydbh5dna3ydbgYcu9hmba5cu9hmbaEasfcb86bbxikaEasfhKdnasaYSmbasa5SmbaKce86bbxikaKcl86bbxdkdnasaXa5cdtgYfydb9hmbdna3ydbgKcuSmbasaKSmba8AydbgOcuSmbasaOSmbaaaYfydbggcuSmbaga5Smba8FaYfydbgYcuSmbaYa5SmbdnaCaKcdtfydbaCaYcdtfydb9hmbaCaOcdtfydbaCagcdtfydb9hmbaEasfcd86bbxlkaEasfcl86bbxikaEasfcl86bbxdkaEasfcl86bbxekaEasfaEa5fRbb86bbkaLclfhLaQclfhQa3clfh3a8Aclfh8Aalascefgs9hmbkaxceGTmbaEhsalhLindnasRbbce9hmbascl86bbkascefhsaLcufgLmbkkcualcx2alc;v:Q;v:Qe0Ecbyd1:jjjbHjjjjbbh8JaPcwfaPyd9Ogscdtfa8JBdbaPascefgOBd9Oa8Jaialavz:djjjbdndnaDmbcbhvxekcbh5aPcwfaOcdtfcuaDal2gLcdtaLcFFFFi0Ecbyd1:jjjbHjjjjbbgvBdbaPascdfgOBd9OalTmbarcd4cdthYaDcdthKavh8AinaohsawhLa8AhQaDh3inaQasIdbaLIdbNUdbasclfhsaLclfhLaQclfhQa3cufg3mbkaoaYfhoa8AaKfh8Aa5cefg5al9hmbkkaPcwfaOcdtfcualc8S2gsalc;D;O;f8U0EgQcbyd1:jjjbHjjjjbbgLBdbaPaOcefg3Bd9OaLcbasz:ljjjbh8EdndndnaDTmbaPcwfa3cdtfaQcbyd1:jjjbHjjjjbbgoBdbaPaOcdfgLBd9Oaocbasz:ljjjb8AaPcwfaLcdtfcuaDal2gscltgLascFFFFb0Ecbyd1:jjjbHjjjjbbgwBdbaPaOcifBd9OawcbaLz:ljjjb8AadmexdkcbhocbhwadTmekcbh8AaehLindna8JaLclfydbg5cx2fgsIdba8JaLydbgYcx2fgQIdbg8M:tg8Na8JaLcwfydbgKcx2fg3IdlaQIdlgy:tg8PNa3Idba8M:tgIasIdlay:tg8RN:tg8Sa8SNa8Ra3IdwaQIdwgR:tg8UNa8PasIdwaR:tg8RN:tg8Pa8PNa8RaINa8Ua8NN:tg8Na8NNMM:rgIJbbbb9ETmba8SaI:vh8Sa8NaI:vh8Na8PaI:vh8Pka8EaCaYcdtfydbc8S2fgsa8PaI:rgIa8PNNg8RasIdbMUdbasa8NaIa8NNg8VNg8UasIdlMUdlasa8SaIa8SNg8WNg8XasIdwMUdwasa8Va8PNg8VasIdxMUdxasa8Wa8PNg8YasIdzMUdzasa8Wa8NNg8WasIdCMUdCasa8PaIa8SaRNa8Pa8MNaya8NNMM:mgyNg8MNg8PasIdKMUdKasa8Na8MNg8NasId3MUd3asa8Sa8MNg8SasIdaMUdaasa8MayNg8MasId8KMUd8KasaIasIdyMUdya8EaCa5cdtfydbc8S2fgsa8RasIdbMUdbasa8UasIdlMUdlasa8XasIdwMUdwasa8VasIdxMUdxasa8YasIdzMUdzasa8WasIdCMUdCasa8PasIdKMUdKasa8NasId3MUd3asa8SasIdaMUdaasa8MasId8KMUd8KasaIasIdyMUdya8EaCaKcdtfydbc8S2fgsa8RasIdbMUdbasa8UasIdlMUdlasa8XasIdwMUdwasa8VasIdxMUdxasa8YasIdzMUdzasa8WasIdCMUdCasa8PasIdKMUdKasa8NasId3MUd3asa8SasIdaMUdaasa8MasId8KMUd8KasaIasIdyMUdyaLcxfhLa8Acifg8Aad6mbkcbh5aehYincbhLinaEaeaLc:G1jjbfydba5fcdtfydbgQfRbbhsdndnaEaYaLfydbg3fRbbg8Ac99fcFeGcpe0mbasceSmbascd9hmekdna8AcufcFeGce0mba8Fa3cdtfydbaQ9hmekdnascufcFeGce0mbaaaQcdtfydba39hmekdna8Acv2asfc:W1jjbfRbbTmbaCaQcdtfydbaCa3cdtfydb0mekJbbacJbbjZasceSEhIa8AceShOa8JaeaLc:K1jjbfydba5fcdtfydbcx2fhsdna8JaQcx2fg8AIdwa8Ja3cx2fgKIdwgy:tg8Pa8PNa8AIdbaKIdbgR:tg8Na8NNa8AIdlaKIdlg8R:tg8Sa8SNMM:rg8MJbbbb9ETmba8Pa8M:vh8Pa8Sa8M:vh8Sa8Na8M:vh8NkJbbacaIaOEh8WdnasIdway:tgIa8PaIa8PNasIdbaR:tg8Xa8NNa8SasIdla8R:tg8VNMMg8UN:tgIaINa8Xa8Na8UN:tg8Pa8PNa8Va8Sa8UN:tg8Na8NNMM:rg8SJbbbb9ETmbaIa8S:vhIa8Na8S:vh8Na8Pa8S:vh8Pka8EaCa3cdtfydbc8S2fgsa8Pa8Wa8MNg8Sa8PNNg8UasIdbMUdbasa8Na8Sa8NNg8WNg8XasIdlMUdlasaIa8SaINg8MNg8VasIdwMUdwasa8Wa8PNg8WasIdxMUdxasa8Ma8PNg8YasIdzMUdzasa8Ma8NNg8ZasIdCMUdCasa8Pa8SaIayNa8PaRNa8Ra8NNMM:mgyNg8MNg8PasIdKMUdKasa8Na8MNg8NasId3MUd3asaIa8MNgIasIdaMUdaasa8MayNg8MasId8KMUd8Kasa8SasIdyMUdya8EaCaQcdtfydbc8S2fgsa8UasIdbMUdbasa8XasIdlMUdlasa8VasIdwMUdwasa8WasIdxMUdxasa8YasIdzMUdzasa8ZasIdCMUdCasa8PasIdKMUdKasa8NasId3MUd3asaIasIdaMUdaasa8MasId8KMUd8Kasa8SasIdyMUdykaLclfgLcx9hmbkaYcxfhYa5cifg5ad6mbkaDTmbcbhYinJbbbbhRa8JaeaYcdtfgsclfydbgKcx2fgLIdwa8JasydbgOcx2fgQIdwg8V:tg8Na8NNaLIdbaQIdbg8Y:tgIaINaLIdlaQIdlg8Z:tg8Sa8SNMMg8Wa8Jascwfydbggcx2fgsIdwa8V:tg8MNa8Na8Na8MNaIasIdba8Y:tgyNa8SasIdla8Z:tg8RNMMg8PN:tJbbbbJbbjZa8Wa8Ma8MNayayNa8Ra8RNMMg8XNa8Pa8PN:tg8U:va8UJbbbb9BEg8UNh80a8Xa8NNa8Ma8PN:ta8UNh81a8Wa8RNa8Sa8PN:ta8UNhBa8Xa8SNa8Ra8PN:ta8UNh83a8WayNaIa8PN:ta8UNhUa8XaINaya8PN:ta8UNh85aIa8RNaya8SN:tg8Pa8PNa8Sa8MNa8Ra8NN:tg8Pa8PNa8NayNa8MaIN:tg8Pa8PNMM:r:rh8PavaOaD2cdtfhLavagaD2cdtfhQavaKaD2cdtfh3a8V:mh86a8Z:mh87a8Y:mh88cbh8AaDh5Jbbbbh8RJbbbbh8UJbbbbh8WJbbbbh8XJbbbbh8VJbbbbh8YJbbbbh8ZJbbbbh89Jbbbbh8:inaPc;Wbfa8Afgscwfa8Pa81a3IdbaLIdbg8M:tg8SNa80aQIdba8M:tgyNMg8NNUdbasclfa8Pa83a8SNaBayNMgINUdbasa8Pa85a8SNaUayNMg8SNUdbascxfa8Pa86a8NNa87aINa8Ma88a8SNMMMg8MNUdba8Pa8NaINNa8XMh8Xa8Pa8Na8SNNa8VMh8Va8PaIa8SNNa8YMh8Ya8Pa8Ma8MNNaRMhRa8Pa8Na8MNNa8RMh8Ra8PaIa8MNNa8UMh8Ua8Pa8Sa8MNNa8WMh8Wa8Pa8Na8NNNa8ZMh8Za8PaIaINNa89Mh89a8Pa8Sa8SNNa8:Mh8:aLclfhLa3clfh3aQclfhQa8Aczfh8Aa5cufg5mbkaoaCaOcdtfydbgLc8S2fgsa8:asIdbMUdbasa89asIdlMUdlasa8ZasIdwMUdwasa8YasIdxMUdxasa8VasIdzMUdzasa8XasIdCMUdCasa8WasIdKMUdKasa8UasId3MUd3asa8RasIdaMUdaasaRasId8KMUd8Kasa8PasIdyMUdyaoaCaKcdtfydbgKc8S2fgsa8:asIdbMUdbasa89asIdlMUdlasa8ZasIdwMUdwasa8YasIdxMUdxasa8VasIdzMUdzasa8XasIdCMUdCasa8WasIdKMUdKasa8UasId3MUd3asa8RasIdaMUdaasaRasId8KMUd8Kasa8PasIdyMUdyaoaCagcdtfydbgOc8S2fgsa8:asIdbMUdbasa89asIdlMUdlasa8ZasIdwMUdwasa8YasIdxMUdxasa8VasIdzMUdzasa8XasIdCMUdCasa8WasIdKMUdKasa8UasId3MUd3asa8RasIdaMUdaasaRasId8KMUd8Kasa8PasIdyMUdyawaLaD2cltfh5cbhLaDh3ina5aLfgsaPc;WbfaLfgQIdbasIdbMUdbasclfg8AaQclfIdba8AIdbMUdbascwfg8AaQcwfIdba8AIdbMUdbascxfgsaQcxfIdbasIdbMUdbaLczfhLa3cufg3mbkawaKaD2cltfh5cbhLaDh3ina5aLfgsaPc;WbfaLfgQIdbasIdbMUdbasclfg8AaQclfIdba8AIdbMUdbascwfg8AaQcwfIdba8AIdbMUdbascxfgsaQcxfIdbasIdbMUdbaLczfhLa3cufg3mbkawaOaD2cltfh5cbhLaDh3ina5aLfgsaPc;WbfaLfgQIdbasIdbMUdbasclfg8AaQclfIdba8AIdbMUdbascwfg8AaQcwfIdba8AIdbMUdbascxfgsaQcxfIdbasIdbMUdbaLczfhLa3cufg3mbkaYcifgYad6mbkkdnabaeSmbabaeadcdtz:kjjjb8AkaPydbhZcbhsdnalTmbaZclfhsaZydbh3aEhLalh8AcbhQincbasydbg5a39RaLRbbcpeGEaQfhQaLcefhLasclfhsa5h3a8Acufg8AmbkaQce4hskcuadas9Rcifgrcx2arc;v:Q;v:Qe0Ecbyd1:jjjbHjjjjbbh8LaPcwfaPyd9Ogscdtfa8LBdbaPascefgLBd9OaPcwfaLcdtfcuarcdtarcFFFFi0Ecbyd1:jjjbHjjjjbbgxBdbaPascdfgLBd9OaPcwfaLcdtfaAcbyd1:jjjbHjjjjbbgHBdbaPascifgLBd9OaPcwfaLcdtfalcbyd1:jjjbHjjjjbbgnBdbaPasclfBd9OJbbbbh8Ydnadaq9nmbdnarci6mbakakNh8VaDclthca8Lcwfh9cJbbbbh8YinaPabadghalaCz:cjjjbabhOcbhzcbhKincbhsindnaCaOasfydbgQcdtgYfydbg8AaCabasc;m1jjbfydbaKfcdtfydbgLcdtfydbg5SmbaEaLfRbbgecv2aEaQfRbbg3fc;G1jjbfRbbg8Ka3cv2aefggc;G1jjbfRbbgiVcFeGTmbdnagc:W1jjbfRbbTmba5a8A0mekdna3ae9hmba3cufcFeGce0mba8FaYfydbaL9hmeka8Lazcx2fg3aLaQaicFeGg8AEBdla3aQaLa8AEBdba3a8Aa8KGcb9hBdwazcefhzkasclfgscx9hmbkdnaKcifgKah9pmbaOcxfhOazcifar9nmekkdnazmbahhdxikcbheinJbbbbJbbjZa8EaCa8Laecx2fg3ydlg8Aa3ydbg5a3ydwgLEgKcdtfydbg8Kc8S2gifgsIdyg8P:va8PJbbbb9BEasIdwa8Ja5a8AaLEgYcx2fgLIdwg8SNasIdzaLIdbg8MNasIdaMg8Pa8PMMa8SNasIdlaLIdlgyNasIdCa8SNasId3Mg8Pa8PMMayNasIdba8MNasIdxayNasIdKMg8Pa8PMMa8MNasId8KMMM:lNh8WJbbbbJbbjZa8EaCa5cdtfydbgdc8S2gQfgsIdyg8P:va8PJbbbb9BEasIdwa8Ja8Acx2fgLIdwgINasIdzaLIdbgRNasIdaMg8Pa8PMMaINasIdlaLIdlg8RNasIdCaINasId3Mg8Pa8PMMa8RNasIdbaRNasIdxa8RNasIdKMg8Pa8PMMaRNasId8KMMM:lNh8Xa3cwfhOa3clfhgdnaDTmbaoaQfgQIdwaINaQIdzaRNaQIdaMg8Pa8PMMaINaQIdla8RNaQIdCaINaQId3Mg8Pa8PMMa8RNaQIdbaRNaQIdxa8RNaQIdKMg8Pa8PMMaRNaQId8KMMMh8Nava8AaD2cdtfhLawadaD2cltfhsaQIdyh8UaDhQinaLIdbg8PJbbb;aNascxfIdbaIascwfIdbNaRasIdbNa8RasclfIdbNMMMNa8Pa8PNa8UNa8NMMh8NaLclfhLasczfhsaQcufgQmbkaoaifgQIdwa8SNaQIdza8MNaQIdaMg8Pa8PMMa8SNaQIdlayNaQIdCa8SNaQId3Mg8Pa8PMMayNaQIdba8MNaQIdxayNaQIdKMg8Pa8PMMa8MNaQId8KMMMhIavaYaD2cdtfhLawa8KaD2cltfhsaQIdyhRaDhQinaLIdbg8PJbbb;aNascxfIdba8SascwfIdbNa8MasIdbNayasclfIdbNMMMNa8Pa8PNaRNaIMMhIaLclfhLasczfhsaQcufgQmbka8WaI:lMh8Wa8Xa8N:lMh8Xkaga8AaYa8Xa8W9FgsEBdba3a5aKasEBdbaOa8Xa8WasEUdbaecefgeaz9hmbkaPc;Wbfcbcj;abz:ljjjb8Aa9chsazhLinaPc;WbfasydbcO4c;8ZGfgQaQydbcefBdbascxfhsaLcufgLmbkcbhscbhLinaPc;WbfasfgQydbh3aQaLBdba3aLfhLasclfgscj;ab9hmbkcbhsa9chLinaPc;WbfaLydbcO4c;8ZGfgQaQydbgQcefBdbaxaQcdtfasBdbaLcxfhLazascefgs9hmbkahaq9RgQci9UhJdnalTmbcbhsaHhLinaLasBdbaLclfhLalascefgs9hmbkkcbh9eancbalz:ljjjbhTaQcO9UhSaJce4h9haPydlh9icbhicbhgdnina8Laxagcdtfydbcx2fgOIdwg8Na8V9EmeaiaJ9pmeJFFuuh8Pdna9haz9pmba8Laxa9hcdtfydbcx2fIdwJbb;aZNh8Pkdna8Na8P9ETmbaiaS0mdkdnaTaCaOydlg6cdtg9kfydbg3fg0RbbaTaCaOydbgKcdtg9mfydbg9nfg9oRbbVmbdnaZa9ncdtfgsclfydbgLasydbgsSmbaLas9Rh5a9iascitfhsa8Ja3cx2fgYcwfhdaYclfhAa8Ja9ncx2fg8Kcwfh9pa8Kclfh9qcbhLcehednindnaHasydbcdtfydbgQa3SmbaHasclfydbcdtfydbg8Aa3SmbaQa8ASmba8Ja8Acx2fg8AIdba8JaQcx2fgQIdbgI:tg8Pa9qIdbaQIdlg8S:tg8MNa8KIdbaI:tgya8AIdla8S:tg8NN:ta8PaAIdba8S:tgRNaYIdbaI:tg8Ra8NN:tNa8Na9pIdbaQIdwg8S:tg8UNa8Ma8AIdwa8S:tgIN:ta8NadIdba8S:tg8SNaRaIN:tNaIayNa8Ua8PN:taIa8RNa8Sa8PN:tNMMJbbbb9FmdkascwfhsaLcefgLa56hea5aL9hmbkkaeceGTmba9hcefh9hxeka8Ea3c8S2gQfgsa8Ea9nc8S2g8AfgLIdbasIdbMUdbasaLIdlasIdlMUdlasaLIdwasIdwMUdwasaLIdxasIdxMUdxasaLIdzasIdzMUdzasaLIdCasIdCMUdCasaLIdKasIdKMUdKasaLId3asId3MUd3asaLIdaasIdaMUdaasaLId8KasId8KMUd8KasaLIdyasIdyMUdydnaDTmbaoaQfgsaoa8AfgLIdbasIdbMUdbasaLIdlasIdlMUdlasaLIdwasIdwMUdwasaLIdxasIdxMUdxasaLIdzasIdzMUdzasaLIdCasIdCMUdCasaLIdKasIdKMUdKasaLId3asId3MUd3asaLIdaasIdaMUdaasaLId8KasId8KMUd8KasaLIdyasIdyMUdyaca9n2heaca32hYawhLaDh8AinaLaYfgsaLaefgQIdbasIdbMUdbasclfg5aQclfIdba5IdbMUdbascwfg5aQcwfIdba5IdbMUdbascxfgsaQcxfIdbasIdbMUdbaLczfhLa8Acufg8AmbkkaOcwfhLdndndndnaEaKfgQRbbc9:fPdebdkaKhsinaHascdtgsfa3BdbaXasfydbgsaK9hmbxikkaXa9kfydbhsaXa9mfydbhKaHa9mfa6Bdbash6kaHaKcdtfa6Bdbka9oce86bba0ce86bbaLIdbg8Pa8Ya8Ya8P9DEh8Ya9ecefh9ececdaQRbbceSEaifhikagcefggaz9hmbkkdna9embahhdxikdnalTmbcbhLa8FhsindnasydbgQcuSmbdnaLaHaQcdtg3fydbgQ9hmba8Fa3fydbhQkasaQBdbkasclfhsalaLcefgL9hmbkcbhLaahsindnasydbgQcuSmbdnaLaHaQcdtg3fydbgQ9hmbaaa3fydbhQkasaQBdbkasclfhsalaLcefgL9hmbkkcbhdabhscbh8AindnaHasydbcdtfydbgLaHasclfydbcdtfydbgQSmbaLaHascwfydbcdtfydbg3SmbaQa3Smbabadcdtfg5aLBdba5clfaQBdba5cwfa3Bdbadcifhdkascxfhsa8Acifg8Aah6mbkadaq9nmdxbkkaPabadalaCz:cjjjbkdnamTmbama8Y:rUdbkaPyd9OgscdtaPcwffc98fhCdninasTmeaCydbcbyd:m:jjjbH:bjjjbbaCc98fhCascufhsxbkkaPc;W;abf8Kjjjjbadk;:ieouabydlhvabydbclfcbaicdtz:ljjjbhoadci9UhrdnadTmbdnalTmbaehwadhDinaoalawydbcdtfydbcdtfgqaqydbcefBdbawclfhwaDcufgDmbxdkkaehwadhDinaoawydbcdtfgqaqydbcefBdbawclfhwaDcufgDmbkkdnaiTmbcbhDaohwinawydbhqawaDBdbawclfhwaqaDfhDaicufgimbkkdnadci6mbarcearce0EhdinaecwfydbhwaeclfydbhDaeydbhidnalTmbalawcdtfydbhwalaDcdtfydbhDalaicdtfydbhikavaoaicdtfgqydbcitfaDBdbavaqydbcitfawBdlaqaqydbcefBdbavaoaDcdtfgqydbcitfawBdbavaqydbcitfaiBdlaqaqydbcefBdbavaoawcdtfgwydbcitfaiBdbavawydbcitfaDBdlawawydbcefBdbaecxfheadcufgdmbkkabydbcbBdbk:Zldouv998Jjjjjbca9Rglczfcwfcbyd11jjbBdbalcb8Pdj1jjb83izalcwfcbydN1jjbBdbalcb8Pd:m1jjb83ibdnadTmbaicd4hvdnabTmbavcdthocbhraehwinabarcx2fgiaearav2cdtfgDIdbUdbaiaDIdlUdlaiaDIdwUdwcbhiinalczfaifgDawaifIdbgqaDIdbgkakaq9EEUdbalaifgDaqaDIdbgkakaq9DEUdbaiclfgicx9hmbkawaofhwarcefgrad9hmbxdkkavcdthrcbhwincbhiinalczfaifgDaeaifIdbgqaDIdbgkakaq9EEUdbalaifgDaqaDIdbgkakaq9DEUdbaiclfgicx9hmbkaearfheawcefgwad9hmbkkdnabTmbadTmbJbbbbJbbjZalIdbalIdzgk:tJbbbb:xgqalIdlalIdCgx:tgmamaq9DEgqalIdwalIdKgm:tgPaPaq9DEgq:vaqJbbbb9BEhqinabaqabIdbak:tNUdbabclfgiaqaiIdbax:tNUdbabcwfgiaqaiIdbam:tNUdbabcxfhbadcufgdmbkkk8KbabaeadaialavcbcbcbcbaoarawaDz:bjjjbk8KbabaeadaialavaoarawaDaqakaxamz:bjjjbk;lOowud99wue99iul998Jjjjjbc;Wb9Rgw8KjjjjbdndnarmbcbhDxekawcwfcbc;Kbz:ljjjb8Aawcuadcx2adc;v:Q;v:Qe0Ecbyd1:jjjbHjjjjbbgqBdwawceBd9Oaqaeadaiz:djjjbawcuadcdtadcFFFFi0Egkcbyd1:jjjbHjjjjbbgxBdxawcdBd9Oadcd4adfhmceheinaegicetheaiam6mbkcbhmawcuaicdtgPaicFFFFi0Ecbyd1:jjjbHjjjjbbgsBdzawciBd9Odndnar:Zgz:rJbbbZMgH:lJbbb9p9DTmbaH:Ohexekcjjjj94hekaicufhOc:bwhAcbhCcbhXadhQinaChLaeaAgKcufaeaK9iEamgDcefaeaD9kEhYdndnadTmbaYcuf:YhHaqhiaxheadhmindndnaiIdbaHNJbbbZMg8A:lJbbb9p9DTmba8A:OhAxekcjjjj94hAkaAcCthAdndnaiclfIdbaHNJbbbZMg8A:lJbbb9p9DTmba8A:OhCxekcjjjj94hCkaCcqtaAVhAdndnaicwfIdbaHNJbbbZMg8A:lJbbb9p9DTmba8A:OhCxekcjjjj94hCkaeaAaCVBdbaicxfhiaeclfheamcufgmmbkascFeaPz:ljjjbhEcbh3cbh5indnaEaxa5cdtfydbgAcm4aA7c:v;t;h;Ev2gics4ai7aOGgmcdtfgCydbgecuSmbaeaASmbcehiinaEamaifaOGgmcdtfgCydbgecuSmeaicefhiaeaA9hmbkkaCaABdba3aecuSfh3a5cefg5ad9hmbxdkkascFeaPz:ljjjb8Acbh3kaDaYa3ar0giEhmaLa3aiEhCdna3arSmbaYaKaiEgAam9Rcd9imbdndnaXcl0mbdnaQ:ZgHaL:Zg8A:taY:Yg8EaD:Y:tg8Fa8EaK:Y:tgaa3:Zghaz:tNNNaHaz:taaNa8Aah:tNa8Aaz:ta8FNahaH:tNM:va8EMJbbbZMgH:lJbbb9p9DTmbaH:Ohexdkcjjjj94hexekamaAfcd9Theka3aQaiEhQaXcefgXcs9hmekkdndnaCmbcihicbhDxekcbhiawakcbyd1:jjjbHjjjjbbg5BdCawclBd9OdndnadTmbamcuf:YhHaqhiaxheadhmindndnaiIdbaHNJbbbZMg8A:lJbbb9p9DTmba8A:OhAxekcjjjj94hAkaAcCthAdndnaiclfIdbaHNJbbbZMg8A:lJbbb9p9DTmba8A:OhCxekcjjjj94hCkaCcqtaAVhAdndnaicwfIdbaHNJbbbZMg8A:lJbbb9p9DTmba8A:OhCxekcjjjj94hCkaeaAaCVBdbaicxfhiaeclfheamcufgmmbkascFeaPz:ljjjbhEcbhDcbh3inaxa3cdtgYfydbgAcm4aA7c:v;t;h;Ev2gics4ai7hecbhidndninaEaeaOGgmcdtfgCydbgecuSmednaxaecdtgCfydbaASmbaicefgiamfheaiaO9nmekka5aCfydbhixekaCa3BdbaDhiaDcefhDka5aYfaiBdba3cefg3ad9hmbkcuaDc32giaDc;j:KM;jb0EhexekascFeaPz:ljjjb8AcbhDcbhekawaecbyd1:jjjbHjjjjbbgeBdKawcvBd9Oaecbaiz:ljjjbhOavcd4hxdnadTmbaxcdth3a5hmalhAaqheadhEinaOamydbc32fgiaeIdbaiIdbMUdbaiaeclfIdbaiIdlMUdlaiaecwfIdbaiIdwMUdwaiaAc;81jjbalEgCIdbaiIdxMUdxaiaCIdlaiIdzMUdzaiaCIdwaiIdCMUdCaiaiIdKJbbjZMUdKamclfhmaAa3fhAaecxfheaEcufgEmbkkdnaDTmbaOcxfhiaDheinaictfgmamIdbJbbbbJbbjZaicxfIdbgH:vaHJbbbb9BEgHNUdbaic94fgmaHamIdbNUdbaic98fgmaHamIdbNUdbaiaHaiIdbNUdbaiclfgmaHamIdbNUdbaicwfgmaHamIdbNUdbaic3fhiaecufgembkkcbhAawcuaDcdtgYaDcFFFFi0Egicbyd1:jjjbHjjjjbbgeBd3awcoBd9Oawaicbyd1:jjjbHjjjjbbgEBdaaecFeaYz:ljjjbh3dnadTmbaoaoNh8Aaxcdthxalheina8Aaec;81jjbalEgmIdwaOa5ydbgCc32fgiIdC:tgHaHNamIdbaiIdx:tgHaHNamIdlaiIdz:tgHaHNMMNaqcwfIdbaiIdw:tgHaHNaqIdbaiIdb:tgHaHNaqclfIdbaiIdl:tgHaHNMMMhHdndna3aCcdtgifgmydbcuSmbaEaifIdbaH9ETmekamaABdbaEaifaHUdbka5clfh5aeaxfheaqcxfhqadaAcefgA9hmbkkaba3aYz:kjjjb8AcrhikaicdthiinaiTmeaic98fgiawcwffydbcbyd:m:jjjbH:bjjjbbxbkkawc;Wbf8KjjjjbaDk:Qdidui99ducbhi8Jjjjjbca9Rglczfcwfcbyd11jjbBdbalcb8Pdj1jjb83izalcwfcbydN1jjbBdbalcb8Pd:m1jjb83ibdndnaembJbbjFhvJbbjFhoJbbjFhrxekadcd4cdthwincbhdinalczfadfgDabadfIdbgoaDIdbgrarao9EEUdbaladfgDaoaDIdbgrarao9DEUdbadclfgdcx9hmbkabawfhbaicefgiae9hmbkalIdwalIdK:thralIdlalIdC:thoalIdbalIdz:thvkavJbbbb:xgvaoaoav9DEgoararao9DEk9DeeuabcFeaicdtz:ljjjbhlcbhbdnadTmbindnalaeydbcdtfgiydbcu9hmbaiabBdbabcefhbkaeclfheadcufgdmbkkabk9teiucbcbyd:q:jjjbgeabcifc98GfgbBd:q:jjjbdndnabZbcztgd9nmbcuhiabad9RcFFifcz4nbcuSmekaehikaik;LeeeudndnaeabVciGTmbabhixekdndnadcz9pmbabhixekabhiinaiaeydbBdbaiclfaeclfydbBdbaicwfaecwfydbBdbaicxfaecxfydbBdbaeczfheaiczfhiadc9Wfgdcs0mbkkadcl6mbinaiaeydbBdbaeclfheaiclfhiadc98fgdci0mbkkdnadTmbinaiaeRbb86bbaicefhiaecefheadcufgdmbkkabk;aeedudndnabciGTmbabhixekaecFeGc:b:c:ew2hldndnadcz9pmbabhixekabhiinaialBdbaicxfalBdbaicwfalBdbaiclfalBdbaiczfhiadc9Wfgdcs0mbkkadcl6mbinaialBdbaiclfhiadc98fgdci0mbkkdnadTmbinaiae86bbaicefhiadcufgdmbkkabk9teiucbcbyd:q:jjjbgeabcrfc94GfgbBd:q:jjjbdndnabZbcztgd9nmbcuhiabad9RcFFifcz4nbcuSmekaehikaik9:eiuZbhedndncbyd:q:jjjbgdaecztgi9nmbcuheadai9RcFFifcz4nbcuSmekadhekcbabae9Rcifc98Gcbyd:q:jjjbfgdBd:q:jjjbdnadZbcztge9nmbadae9RcFFifcz4nb8Akk6eiucbhidnadTmbdninabRbbglaeRbbgv9hmeaecefheabcefhbadcufgdmbxdkkalav9Rhikaikk:Iedbcjwk1eFFuuFFuuFFuuFFuFFFuFFFuFbbbbbbbbebbbdbbbbbbbebbbeeebeebebbeeebebbbbbebebbbbbebbbdbbbbbbbbbbbbbbbeeeeebebbbbbebbbbbeebbbbbbbbbbbbbbbbbbbbbc1Dkxebbbdbbb:G9Kbb"),{}).then(function(n){(r=n.instance).exports.__wasm_call_ctors()});function a(n){if(!n)throw new Error("Assertion failed")}function t(n){return new Uint8Array(n.buffer,n.byteOffset,n.byteLength)}function i(n,d,o,b,c,h,f,l){var u=r.exports.sbrk,I=u(4*l),C=u(o*b),B=u(o*h),m=new Uint8Array(r.exports.memory.buffer);m.set(t(d),C),c&&m.set(t(c),B);var E=n(I,C,o,b,B,h,f,l);new Uint8Array(r.exports.memory.buffer);var j=new Uint32Array(E);return t(j).set(m.subarray(I,I+4*E)),u(I-u(0)),j}var s={LockBorder:1}})();let te=0;class jA{constructor(e){if(this.zUpToYUpMatrix=new Q.Matrix4,this.zUpToYUpMatrix.set(1,0,0,0,0,0,-1,0,0,1,0,0,0,0,0,1),this.maxCachedItems=100,this.proxy=e.proxy,e&&(this.meshCallback=e.meshCallback,this.pointsCallback=e.pointsCallback,e.maxCachedItems&&(this.maxCachedItems=e.maxCachedItems)),this.gltfLoader=new eA,e&&e.dracoLoader)this.gltfLoader.setDRACOLoader(e.dracoLoader),this.hasDracoLoader=!0;else{const A=new rA;A.setDecoderPath("https://storage.googleapis.com/ogc-3d-tiles/draco/"),this.gltfLoader.setDRACOLoader(A),this.gltfLoader.hasDracoLoader=!0}if(e&&e.ktx2Loader)this.gltfLoader.setKTX2Loader(e.ktx2Loader),this.hasKTX2Loader=!0;else if(e&&e.renderer){const A=new N;A.setTranscoderPath("https://storage.googleapis.com/ogc-3d-tiles/basis/").detectSupport(e.renderer),this.gltfLoader.setKTX2Loader(A),this.gltfLoader.hasKTX2Loader=!0}this.gltfLoader.setMeshoptDecoder(DA),this.hasMeshOptDecoder=!0,this.b3dmDecoder=new $e(this.gltfLoader),this.cache=new Ye.LinkedHashMap,this.register={},this.ready=[],this.downloads=[],this.nextReady=[],this.nextDownloads=[]}update(){const e=this;te<8&&e._download(),e._loadBatch()}_scheduleDownload(e){this.downloads.unshift(e)}_download(){if(this.nextDownloads.length!=0||(this._getNextDownloads(),this.nextDownloads.length!=0))for(;this.nextDownloads.length>0;){const e=this.nextDownloads.shift();e&&e.shouldDoDownload()&&e.doDownload()}}_meshReceived(e,A,a,t,i,s,n){this.ready.unshift([e,A,a,t,i,s,n])}_loadBatch(){for(this.nextReady.length==0&&this._getNextReady();this.nextReady.length>0;){const e=this.nextReady.shift();if(!e)return;const A=e[0],a=e[1],t=e[2],i=A.get(t);i&&a[t]&&Object.keys(a[t]).forEach(s=>{const n=a[t][s];n&&(n(i),a[t][s]=null)}),this.nextReady.length==0&&this._getNextReady()}}_getNextDownloads(){let e=Number.POSITIVE_INFINITY,A=-1;for(let a=this.downloads.length-1;a>=0;a--)this.downloads[a].distanceFunction||this.nextDownloads.push(this.downloads.splice(a,1)[0]);if(!(this.nextDownloads.length>0)){for(let a=this.downloads.length-1;a>=0;a--){const t=this.downloads[a].distanceFunction();t<=e&&(e=t,A=a)}if(A>=0){const a=this.downloads.splice(A,1).pop();this.nextDownloads.push(a);const t=a.getSiblings();for(let i=this.downloads.length-1;i>=0;i--)t.map(s=>s.uuid).includes(this.downloads[i].uuid)&&this.nextDownloads.push(this.downloads.splice(i,1).pop())}}}_getNextReady(){let e=Number.POSITIVE_INFINITY,A=-1;for(let a=this.ready.length-1;a>=0;a--)this.ready[a][3]||this.nextReady.push(this.ready.splice(a,1)[0]);if(!(this.nextReady.length>0)){for(let a=this.ready.length-1;a>=0;a--){const t=this.ready[a][3]()*this.ready[a][5];t<=e&&(e=t,A=a)}if(A>=0){const a=this.ready.splice(A,1).pop();this.nextReady.push(a);const t=a[4]();for(let i=this.ready.length-1;i>=0;i--)t.map(s=>s.uuid).includes(this.ready[i][6])&&this.nextReady.push(this.ready.splice(i,1).pop())}}}get(e,A,a,t,i,s,n,d,o,b){const c=this,h=MA(a),f=new AbortController;if(e.signal.addEventListener("abort",()=>{c.register[h]&&Object.keys(c.register[h]).length!=0||f.abort("user abort")}),!(a.includes(".b3dm")||a.includes(".json")||a.includes(".gltf")||a.includes(".glb")))return void console.error("the 3DTiles cache can only be used to load B3DM, gltf and json data");if(c.register[h]||(c.register[h]={}),c.register[h][A]&&console.error(" a tile should only be loaded once"),c.register[h][A]=t,c.cache.get(h))this._meshReceived(c.cache,c.register,h,i,s,n,A);else if(Object.keys(c.register[h]).length==1){let l;a.includes(".b3dm")?l=()=>{var u;u=c.proxy?()=>fetch(c.proxy,{method:"POST",body:a,signal:f.signal}):()=>fetch(a,{signal:f.signal}),te++,u().then(I=>{if(!I.ok)throw console.error("could not load tile with path : "+a),new Error(`couldn't load "${a}". Request failed with status ${I.status} : ${I.statusText}`);return I.arrayBuffer()}).then(I=>this.b3dmDecoder.parseB3DM(I,C=>{c.meshCallback(C,b)},d,o)).then(I=>{c.cache.put(h,I),c._checkSize(),this._meshReceived(c.cache,c.register,h,i,s,n,A)}).catch(I=>{console.error(I)}).finally(()=>{te--})}:a.includes(".glb")||a.includes(".gltf")?l=()=>{var u;u=c.proxy?()=>fetch(c.proxy,{method:"POST",body:a,signal:f.signal}):()=>fetch(a,{signal:f.signal}),te++,u().then(I=>{if(!I.ok)throw console.error("could not load tile with path : "+a),new Error(`couldn't load "${a}". Request failed with status ${I.status} : ${I.statusText}`);return I.arrayBuffer()}).then(async I=>{await async function(C){return new Promise(B=>{const m=setInterval(()=>{C.hasDracoLoader&&!C.dracoLoader||C.hasKTX2Loader&&!C.ktx2Loader||(clearInterval(m),B())},10)})}(this.gltfLoader),this.gltfLoader.parse(I,null,C=>{C.scene.asset=C.asset,d&&C.scene.applyMatrix4(this.zUpToYUpMatrix),C.scene.traverse(B=>{B.isMesh&&(o&&B.applyMatrix4(this.zUpToYUpMatrix),c.meshCallback&&c.meshCallback(B,b)),B.isPoints&&c.pointsCallback&&c.pointsCallback(B,b)}),c.cache.put(h,C.scene),c._checkSize(),c._meshReceived(c.cache,c.register,h,i,s,n,A)})}).catch(I=>{I!=="user abort"&&I.code!==20&&console.error(I)}).finally(()=>{te--})}:a.includes(".json")&&(l=()=>{var u;u=c.proxy?()=>fetch(c.proxy,{method:"POST",body:a,signal:f.signal}):()=>fetch(a,{signal:f.signal}),te++,u().then(I=>{if(!I.ok)throw console.error("could not load tile with path : "+a),new Error(`couldn't load "${a}". Request failed with status ${I.status} : ${I.statusText}`);return I.json()}).then(I=>Ne(I,a)).then(I=>{c.cache.put(h,I),c._checkSize(),c._meshReceived(c.cache,c.register,h)}).catch(I=>{console.error(I)}).finally(()=>{te--})}),this._scheduleDownload({shouldDoDownload:()=>!e.signal.aborted&&!!c.register[h]&&Object.keys(c.register[h]).length>0,doDownload:l,distanceFunction:i,getSiblings:s,level:n,uuid:A})}}clear(){const e=this.maxCachedItems;this.maxCachedItems=0,this._checkSize(),this.maxCachedItems=e}invalidate(e,A){const a=MA(e);this.register[a]&&delete this.register[a][A]}_checkSize(){const e=this;let A=0;for(;e.cache.size()>e.maxCachedItems&&A<e.cache.size();){A++;const a=e.cache.head(),t=e.register[a.key];t&&(Object.keys(t).length>0?(e.cache.remove(a.key),e.cache.put(a.key,a.value)):(e.cache.remove(a.key),delete e.register[a.key],a.value.traverse(i=>{if(i.material)if(i.material.length)for(let s=0;s<i.material.length;++s)i.material[s].dispose();else i.material.dispose();i.geometry&&i.geometry.dispose()})))}}}function MA(r){for(var e=r.split("/"),A=[],a=0,t=0;t<e.length;t++){var i=e[t];i!=="."&&i!==""&&i!==".."?A[a++]=i:i===".."&&a>0&&a--}if(a===0)return"/";var s="";for(t=0;t<a;t++)s+="/"+A[t];return s}var _e,Ma=new Uint8Array(16);function Ra(){if(!_e&&!(_e=typeof crypto<"u"&&crypto.getRandomValues&&crypto.getRandomValues.bind(crypto)||typeof msCrypto<"u"&&typeof msCrypto.getRandomValues=="function"&&msCrypto.getRandomValues.bind(msCrypto)))throw new Error("crypto.getRandomValues() not supported. See https://github.com/uuidjs/uuid#getrandomvalues-not-supported");return _e(Ma)}const Fa=/^(?:[0-9a-f]{8}-[0-9a-f]{4}-[1-5][0-9a-f]{3}-[89ab][0-9a-f]{3}-[0-9a-f]{12}|00000000-0000-0000-0000-000000000000)$/i;for(var T=[],Pe=0;Pe<256;++Pe)T.push((Pe+256).toString(16).substr(1));function Sa(r){var e=arguments.length>1&&arguments[1]!==void 0?arguments[1]:0,A=(T[r[e+0]]+T[r[e+1]]+T[r[e+2]]+T[r[e+3]]+"-"+T[r[e+4]]+T[r[e+5]]+"-"+T[r[e+6]]+T[r[e+7]]+"-"+T[r[e+8]]+T[r[e+9]]+"-"+T[r[e+10]]+T[r[e+11]]+T[r[e+12]]+T[r[e+13]]+T[r[e+14]]+T[r[e+15]]).toLowerCase();if(!function(a){return typeof a=="string"&&Fa.test(a)}(A))throw TypeError("Stringified UUID is invalid");return A}function RA(r,e,A){var a=(r=r||{}).random||(r.rng||Ra)();return a[6]=15&a[6]|64,a[8]=63&a[8]|128,Sa(a)}function O(r){if(typeof r!="string")throw new TypeError("Path must be a string. Received "+JSON.stringify(r))}function FA(r,e){for(var A,a="",t=0,i=-1,s=0,n=0;n<=r.length;++n){if(n<r.length)A=r.charCodeAt(n);else{if(A===47)break;A=47}if(A===47){if(!(i===n-1||s===1))if(i!==n-1&&s===2){if(a.length<2||t!==2||a.charCodeAt(a.length-1)!==46||a.charCodeAt(a.length-2)!==46){if(a.length>2){var d=a.lastIndexOf("/");if(d!==a.length-1){d===-1?(a="",t=0):t=(a=a.slice(0,d)).length-1-a.lastIndexOf("/"),i=n,s=0;continue}}else if(a.length===2||a.length===1){a="",t=0,i=n,s=0;continue}}e&&(a.length>0?a+="/..":a="..",t=2)}else a.length>0?a+="/"+r.slice(i+1,n):a=r.slice(i+1,n),t=n-i-1;i=n,s=0}else A===46&&s!==-1?++s:s=-1}return a}var ne={resolve:function(){for(var r,e="",A=!1,a=arguments.length-1;a>=-1&&!A;a--){var t;a>=0?t=arguments[a]:(r===void 0&&(r=process.cwd()),t=r),O(t),t.length!==0&&(e=t+"/"+e,A=t.charCodeAt(0)===47)}return e=FA(e,!A),A?e.length>0?"/"+e:"/":e.length>0?e:"."},normalize:function(r){if(O(r),r.length===0)return".";var e=r.charCodeAt(0)===47,A=r.charCodeAt(r.length-1)===47;return(r=FA(r,!e)).length!==0||e||(r="."),r.length>0&&A&&(r+="/"),e?"/"+r:r},isAbsolute:function(r){return O(r),r.length>0&&r.charCodeAt(0)===47},join:function(){if(arguments.length===0)return".";for(var r,e=0;e<arguments.length;++e){var A=arguments[e];O(A),A.length>0&&(r===void 0?r=A:r+="/"+A)}return r===void 0?".":ne.normalize(r)},relative:function(r,e){if(O(r),O(e),r===e||(r=ne.resolve(r))===(e=ne.resolve(e)))return"";for(var A=1;A<r.length&&r.charCodeAt(A)===47;++A);for(var a=r.length,t=a-A,i=1;i<e.length&&e.charCodeAt(i)===47;++i);for(var s=e.length-i,n=t<s?t:s,d=-1,o=0;o<=n;++o){if(o===n){if(s>n){if(e.charCodeAt(i+o)===47)return e.slice(i+o+1);if(o===0)return e.slice(i+o)}else t>n&&(r.charCodeAt(A+o)===47?d=o:o===0&&(d=0));break}var b=r.charCodeAt(A+o);if(b!==e.charCodeAt(i+o))break;b===47&&(d=o)}var c="";for(o=A+d+1;o<=a;++o)o!==a&&r.charCodeAt(o)!==47||(c.length===0?c+="..":c+="/..");return c.length>0?c+e.slice(i+d):(i+=d,e.charCodeAt(i)===47&&++i,e.slice(i))},_makeLong:function(r){return r},dirname:function(r){if(O(r),r.length===0)return".";for(var e=r.charCodeAt(0),A=e===47,a=-1,t=!0,i=r.length-1;i>=1;--i)if((e=r.charCodeAt(i))===47){if(!t){a=i;break}}else t=!1;return a===-1?A?"/":".":A&&a===1?"//":r.slice(0,a)},basename:function(r,e){if(e!==void 0&&typeof e!="string")throw new TypeError('"ext" argument must be a string');O(r);var A,a=0,t=-1,i=!0;if(e!==void 0&&e.length>0&&e.length<=r.length){if(e.length===r.length&&e===r)return"";var s=e.length-1,n=-1;for(A=r.length-1;A>=0;--A){var d=r.charCodeAt(A);if(d===47){if(!i){a=A+1;break}}else n===-1&&(i=!1,n=A+1),s>=0&&(d===e.charCodeAt(s)?--s==-1&&(t=A):(s=-1,t=n))}return a===t?t=n:t===-1&&(t=r.length),r.slice(a,t)}for(A=r.length-1;A>=0;--A)if(r.charCodeAt(A)===47){if(!i){a=A+1;break}}else t===-1&&(i=!1,t=A+1);return t===-1?"":r.slice(a,t)},extname:function(r){O(r);for(var e=-1,A=0,a=-1,t=!0,i=0,s=r.length-1;s>=0;--s){var n=r.charCodeAt(s);if(n!==47)a===-1&&(t=!1,a=s+1),n===46?e===-1?e=s:i!==1&&(i=1):e!==-1&&(i=-1);else if(!t){A=s+1;break}}return e===-1||a===-1||i===0||i===1&&e===a-1&&e===A+1?"":r.slice(e,a)},format:function(r){if(r===null||typeof r!="object")throw new TypeError('The "pathObject" argument must be of type Object. Received type '+typeof r);return function(e,A){var a=A.dir||A.root,t=A.base||(A.name||"")+(A.ext||"");return a?a===A.root?a+t:a+e+t:t}("/",r)},parse:function(r){O(r);var e={root:"",dir:"",base:"",ext:"",name:""};if(r.length===0)return e;var A,a=r.charCodeAt(0),t=a===47;t?(e.root="/",A=1):A=0;for(var i=-1,s=0,n=-1,d=!0,o=r.length-1,b=0;o>=A;--o)if((a=r.charCodeAt(o))!==47)n===-1&&(d=!1,n=o+1),a===46?i===-1?i=o:b!==1&&(b=1):i!==-1&&(b=-1);else if(!d){s=o+1;break}return i===-1||n===-1||b===0||b===1&&i===n-1&&i===s+1?n!==-1&&(e.base=e.name=s===0&&t?r.slice(1,n):r.slice(s,n)):(s===0&&t?(e.name=r.slice(1,i),e.base=r.slice(1,n)):(e.name=r.slice(s,i),e.base=r.slice(s,n)),e.ext=r.slice(i,n)),s>0?e.dir=r.slice(0,s-1):t&&(e.dir="/"),e},sep:"/",delimiter:":",win32:null,posix:null};ne.posix=ne;var J,$=ne;const L=new Q.Sphere(new Q.Vector3(0,0,0),1);new Q.Box3;const ee=new Q.Vector3(0,0,0),He=new Q.Vector3(0,0,0),Ta=new Q.Vector3(0,1,0),SA=new Q.Quaternion,K={};function TA(){var r=[];for(let e in K)K.hasOwnProperty(e)&&K[e]>0&&r.push(e);return r}class qe extends Q.Object3D{constructor(e){super();const A=this;if(this.contentURL=[],e.domWidth&&e.domHeight?this.rendererSize=new Q.Vector2(e.domWidth,e.domHeight):this.rendererSize=new Q.Vector2(1e3,1e3),this.loadingStrategy=e.loadingStrategy?e.loadingStrategy.toUpperCase():"INCREMENTAL",this.distanceBias=Math.max(1e-4,e.distanceBias?e.distanceBias:1),this.proxy=e.proxy,this.drawBoundingVolume=!!e.drawBoundingVolume&&e.drawBoundingVolume,this.displayErrors=e.displayErrors,this.displayCopyright=e.displayCopyright,e.queryParams&&(this.queryParams={...e.queryParams}),this.uuid=RA(),e.tileLoader)this.tileLoader=e.tileLoader;else{const i={};i.meshCallback=e.meshCallback?e.meshCallback:(s,n)=>{s.material.wireframe=!1,s.material.side=Q.DoubleSide},i.pointsCallback=e.pointsCallback?e.pointsCallback:(s,n)=>{s.material.size=Math.pow(n,.33),s.material.sizeAttenuation=!0},i.proxy=this.proxy,i.renderer=e.renderer,i.dracoLoader=e.dracoLoader,i.ktx2Loader=e.ktx2Loader,this.tileLoader=new jA(i),this.update=s=>{this.update(s),this.tileLoader.update()}}if(this.displayCopyright=!!e.displayCopyright,this.geometricErrorMultiplier=e.geometricErrorMultiplier?e.geometricErrorMultiplier:1,this.renderer=e.renderer,this.meshCallback=e.meshCallback,this.loadOutsideView=e.loadOutsideView,this.cameraOnLoad=e.cameraOnLoad,this.parentTile=e.parentTile,this.occlusionCullingService=e.occlusionCullingService,this.static=e.static,this.occlusionCullingService&&(this.color=new Q.Color,this.color.setHex(16777215*Math.random()),this.colorID=Q.MathUtils.clamp(255*A.color.r,0,255)<<16^Q.MathUtils.clamp(255*A.color.g,0,255)<<8^Q.MathUtils.clamp(255*A.color.b,0,255)),this.static&&(this.matrixAutoUpdate=!1,this.matrixWorldAutoUpdate=!1),this.childrenTiles=[],this.meshContent=[],this.tileContent,this.refine,this.rootPath,this.geometricError,this.boundingVolume,this.json,this.materialVisibility=!1,this.level=e.level?e.level:0,this.hasMeshContent=0,this.hasUnloadedJSONContent=0,this.centerModel=e.centerModel,this.abortController=new AbortController,this.onLoadCallback=e.onLoadCallback,e.json)A._setup(e);else if(e.url){var a=e.url;if(A.queryParams){var t="";for(let i in A.queryParams)A.queryParams.hasOwnProperty(i)&&(t+="&"+i+"="+A.queryParams[i]);a.includes("?")?a+=t:a+="?"+t.substring(1)}(A.proxy?()=>fetch(A.proxy,{method:"POST",body:a,signal:A.abortController.signal}):()=>fetch(a,{signal:A.abortController.signal}))().then(i=>{if(!i.ok)throw new Error(`couldn't load "${e.url}". Request failed with status ${i.status} : ${i.statusText}`);i.json().then(s=>Ne(s,a)).then(s=>{A._setup({rootPath:$.dirname(e.url),json:s})})}).catch(i=>{A.displayErrors&&LA(i)})}}updateMatrices(){this.updateMatrix(),this.static&&this.traverse(e=>{e.isObject3D&&(e.matrixWorldAutoUpdate=!0)}),this.updateMatrixWorld(!0),this.static&&this.traverse(e=>{e.isObject3D&&(e.matrixWorldAutoUpdate=!1)})}setCanvasSize(e,A){this.rendererSize.set(e,A)}async _setup(e){const A=this;if(e.json.root?(A.json=e.json.root,A.json.refine||(A.json.refine=e.json.refine),A.json.geometricError||(A.json.geometricError=e.json.geometricError),A.json.transform||(A.json.transform=e.json.transform),A.json.boundingVolume||(A.json.boundingVolume=e.json.boundingVolume)):A.json=e.json,A.json.children||(A.json.getChildren?A.json.children=await A.json.getChildren():A.json.children=[]),A.rootPath=e.json.rootPath?e.json.rootPath:e.rootPath,A.json.refine?A.refine=A.json.refine:A.refine=e.parentRefine,A.json.geometricError?A.geometricError=A.json.geometricError:A.geometricError=e.parentGeometricError,A.json.transform){let t=new Q.Matrix4;t.elements=A.json.transform,A.applyMatrix4(t)}if(A.json.boundingVolume)if(A.json.boundingVolume.box)A.boundingVolume=new X(A.json.boundingVolume.box);else if(A.json.boundingVolume.region){const t=A.json.boundingVolume.region;A._transformWGS84ToCartesian(t[0],t[1],t[4],ee),A._transformWGS84ToCartesian(t[2],t[3],t[5],He),ee.lerp(He,.5),A.boundingVolume=new Q.Sphere(new Q.Vector3(ee.x,ee.y,ee.z),ee.distanceTo(He))}else if(A.json.boundingVolume.sphere){const t=A.json.boundingVolume.sphere;A.boundingVolume=new Q.Sphere(new Q.Vector3(t[0],t[1],t[2]),t[3])}else A.boundingVolume=e.parentBoundingVolume;else A.boundingVolume=e.parentBoundingVolume;function a(t){t.uri&&t.uri.includes("json")||t.url&&t.url.includes("json")?A.hasUnloadedJSONContent++:A.hasMeshContent++}if(A.json.content?(a(A.json.content),A.hasMeshContent==0&&(A.level=Math.max(0,A.parentTile?A.parentTile.level+.01:0)),A.loadingStrategy==="IMMEDIATE"?A._load(!0,!1):A._load()):A.json.contents&&(A.json.contents.forEach(t=>a(t)),A.hasMeshContent==0&&(A.level=Math.max(0,A.parentTile?A.parentTile.level+.01:0)),A.loadingStrategy==="IMMEDIATE"?A._load(!0,!1):A._load()),A.centerModel){const t=new Q.Sphere;A.boundingVolume instanceof X?t.copy(A.boundingVolume.sphere):A.boundingVolume instanceof Q.Sphere&&t.copy(A.boundingVolume),this.json.boundingVolume.region&&(this._transformWGS84ToCartesian(.5*(this.json.boundingVolume.region[0]+this.json.boundingVolume.region[2]),.5*(this.json.boundingVolume.region[1]+this.json.boundingVolume.region[3]),.5*(this.json.boundingVolume.region[4]+this.json.boundingVolume.region[5]),ee),SA.setFromUnitVectors(ee.normalize(),Ta.normalize()),A.applyQuaternion(SA)),t.center.applyMatrix4(A.matrix),A.position.sub(t.center),A.updateMatrices()}if(e.onLoadCallback&&A.onLoadCallback(A),A.isSetup=!0,A.level>0&&A.drawBoundingVolume&&(A.bbox&&console.log("double setup"),this.boundingVolume.aabb)){let t=this.boundingVolume.aabb.clone();t.applyMatrix4(this.matrixWorld),A.bbox=new Q.Box3Helper(t,16776960),A.add(A.bbox),A.bbox.material.visible=!1}}_assembleURL(e,A){e.endsWith("/")||(e+="/");const a=new URL(e);let t=a.pathname.split("/").filter(s=>s!==""),i=A.split("/").filter(s=>s!=="");for(let s=1;s<=t.length&&!(s>=i.length);s++)if(t.slice(t.length-s,t.length).join("/")===i.slice(0,s).join("/")){for(let n=0;n<s;n++)t.pop();break}for(;i.length>0&&i[0]==="..";)t.pop(),i.shift();return`${a.protocol}//${a.host}/${[...t,...i].join("/")}`}_extractQueryParams(e,A){const a=new URL(e);for(let[t,i]of a.searchParams)A[t]=i;return a.search="",a.toString()}async _load(e=!0,A=!0){var a=this;if(!a.deleted){if(a.json.content)await t(a.json.content,null,e,A);else if(a.json.contents){let i=a.json.contents.map((s,n)=>t(s,n,e,A));Promise.all(i)}}async function t(i,s,n,d){let o;i.uri?o=i.uri:i.url&&(o=i.url);const b=/^(?:http|https|ftp|tcp|udp):\/\/\S+/;if(b.test(a.rootPath)?b.test(o)||(o=a._assembleURL(a.rootPath,o)):$.isAbsolute(a.rootPath)&&(o=a.rootPath+$.sep+o),o=a._extractQueryParams(o,a.queryParams),a.queryParams){var c="";for(let h in a.queryParams)a.queryParams.hasOwnProperty(h)&&(c+="&"+h+"="+a.queryParams[h]);o.includes("?")?o+=c:o+="?"+c.substring(1)}if(o)if(d&&(o.includes(".b3dm")||o.includes(".glb")||o.includes(".gltf"))){a.contentURL.push(o);try{a.tileLoader.get(a.abortController,a.uuid,o,h=>{a.deleted||(h.asset&&h.asset.copyright&&(h.asset.copyright.split(";").forEach(f=>{K[f]?K[f]++:K[f]=1}),a.displayCopyright&&Oe()),h.traverse(f=>{if((f.isMesh||f.isPoints)&&f.layers.disable(0),f.isMesh&&a.occlusionCullingService){const l=f.geometry.attributes.position,u=[];for(let I=0;I<l.count;I++)u.push(a.color.r,a.color.g,a.color.b);f.geometry.setAttribute("color",new Q.Float32BufferAttribute(u,3))}}),a.add(h),a.updateMatrices(),a.meshContent.push(h))},a.cameraOnLoad?()=>{let h=1;return(a.metric&&a.metric<0||a.deleted)&&(h=2),a.parentTile?a.parentTile._calculateDistanceToCamera(a.cameraOnLoad)*h*a.level:a._calculateDistanceToCamera(a.cameraOnLoad)*h*a.level}:()=>0,()=>a._getSiblings(),a.level,!a.json.boundingVolume.region,!!a.json.boundingVolume.region,a.geometricError)}catch(h){a.displayErrors&&LA(h)}}else n&&o.includes(".json")&&(a.jsonRequested=o,a.tileLoader.get(a.abortController,a.uuid,o,async h=>{a.deleted||(h.rootPath=$.dirname(o),a.json.children.push(h),s==null?delete a.json.content:a.json.contents.splice(s,1),a.hasUnloadedJSONContent--)}))}}dispose(){const e=this;e.meshContent.forEach(A=>{A&&A.asset&&A.asset.copyright&&(A.asset.copyright.split(";").forEach(a=>{K[a]&&K[a]--}),e.displayCopyright&&Oe())}),e.bbox&&e.bbox.dispose(),e.childrenTiles.forEach(A=>A.dispose()),e.deleted=!0,e.contentURL&&(e.contentURL.forEach(A=>{e.tileLoader.invalidate(A,e.uuid)}),e.contentURL=[]),e.abortController&&e.abortController.abort("tile not needed"),this.parent=null,this.parentTile=null,this.dispatchEvent({type:"removed"})}_disposeMeshContent(){const e=this;if(!e.deleted){e.deleted=!0,e.abortController&&(e.abortController.abort("tile not needed"),e.abortController=new AbortController);for(let A=e.meshContent.length-1;A>=0;A--){const a=e.meshContent[A];a&&a.asset&&a.asset.copyright&&(a.asset.copyright.split(";").forEach(t=>{K[t]&&K[t]--}),e.displayCopyright&&Oe()),e.remove(a)}e.meshContent=[],e.contentURL.forEach(A=>{e.tileLoader.invalidate(A,e.uuid)}),e.contentURL=[]}}_disposeChildren(){var e=this;e.childrenTiles.forEach(A=>{A.dispose(),e.remove(A)}),e.childrenTiles=[]}update(e){const A=new Q.Frustum;A.setFromProjectionMatrix(new Q.Matrix4().multiplyMatrices(e.projectionMatrix,e.matrixWorldInverse));let a=[0],t=[0],i=[0],s=[0];return this.refine=="REPLACE"?this.loadingStrategy==="IMMEDIATE"?(this._updateImmediate(e,A),this._statsImmediate(i,a,s,t)):(this._update(e,A),this._stats(i,a,s,t)):(this._update(e,A),this._stats(i,a,s,t)),a>0&&(s[0]/=a[0]),{numTilesLoaded:a[0],numTilesRendered:t[0],maxLOD:i[0],percentageLoaded:s[0]}}_updateImmediate(e,A){this._computeMetricRecursive(e,A),this._updateNodeVisibilityImmediate(),this._expandTreeImmediate(e),this.shouldBeVisible=this.metric>0||!!this.loadOutsideView,this._shouldBeVisibleUpdateImmediate(),this._trimTreeImmediate(),this._loadMeshImmediate()}_statsImmediate(e,A,a,t){e[0]=Math.max(e[0],this.level),(this.shouldBeVisible||this.materialVisibility)&&(A[0]++,this.materialVisibility&&a[0]++),this.materialVisibility&&t[0]++,this.childrenTiles.forEach(i=>{i._statsImmediate(e,A,a,t)})}_stats(e,A,a,t){e[0]=Math.max(e[0],this.level),this.hasMeshContent&&(A[0]++,this.meshContent.length==this.hasMeshContent&&a[0]++,this.materialVisibility&&t[0]++),this.childrenTiles.forEach(i=>{i._stats(e,A,a,t)})}_trimTreeImmediate(){this.metric!=null&&(this.hasMeshContent&&this.shouldBeVisible&&this.materialVisibility?this._disposeChildren():this.childrenTiles.forEach(e=>{e._trimTreeImmediate()}))}_updateNodeVisibilityImmediate(e=!1){const A=this;if(A.hasMeshContent)if(A.shouldBeVisible)A.meshContent.length==A.hasMeshContent?A.materialVisibility?A.childrenTiles.forEach(a=>{a._updateNodeVisibilityImmediate(!0)}):(A._changeContentVisibility(!0),A.childrenTiles.forEach(a=>{a._updateNodeVisibilityImmediate(e)})):A.childrenTiles.forEach(a=>{a._updateNodeVisibilityImmediate(e)});else{if(!A.loadOutsideView&&A.metric<0)return A._changeContentVisibility(!1),A.meshContent.length>0&&A._disposeMeshContent(),void A.childrenTiles.forEach(a=>{a._updateNodeVisibilityImmediate(!0)});if(A.materialVisibility)if(e)A._changeContentVisibility(!1),A.meshContent.length>0&&A._disposeMeshContent(),A.childrenTiles.forEach(a=>{a._updateNodeVisibilityImmediate(e)});else{let a=!0;A.childrenTiles.every(t=>!!t._isReadyImmediate()||(a=!1,!1)),a&&A.childrenTiles.length>0?(A._changeContentVisibility(!1),A.meshContent.length>0&&A._disposeMeshContent(),A.childrenTiles.forEach(t=>{t._updateNodeVisibilityImmediate(e)})):A.childrenTiles.forEach(t=>{t._updateNodeVisibilityImmediate(!0)})}else A.childrenTiles.forEach(a=>{a._updateNodeVisibilityImmediate(e)})}else A.childrenTiles.forEach(a=>{a._updateNodeVisibilityImmediate(e)})}_shouldBeVisibleUpdateImmediate(){const e=this;e.hasMeshContent?e.metric==null?e.shouldBeVisible=!1:e.metric<0?(e.shouldBeVisible=!!e.loadOutsideView,e.childrenTiles.forEach(A=>{A._setShouldNotBeVisibleRecursive()})):e.metric<e.geometricErrorMultiplier*e.geometricError?e.hasUnloadedJSONContent||(e.json&&e.json.children&&e.json.children.length>0?(e.shouldBeVisible=!1,e.childrenTiles.forEach(A=>{A.shouldBeVisible=!0,A._shouldBeVisibleUpdateImmediate()})):e.shouldBeVisible=!0):e.childrenTiles.forEach(A=>{A._setShouldNotBeVisibleRecursive()}):(e.childrenTiles.forEach(A=>{A.shouldBeVisible=!0,A._shouldBeVisibleUpdateImmediate()}),e.shouldBeVisible=!1)}_setShouldNotBeVisibleRecursive(){this.shouldBeVisible=!1,this.childrenTiles.forEach(e=>{e._setShouldNotBeVisibleRecursive()})}_loadMeshImmediate(){const e=this;e.hasMeshContent&&e.shouldBeVisible?e.meshContent.length<e.hasMeshContent&&e.contentURL.length==0&&(e.deleted=!1,e._load(!1,!0)):e.childrenTiles.forEach(A=>{A._loadMeshImmediate()})}_computeMetricRecursive(e,A){const a=this;a.metric=-1,a.isSetup&&(a.boundingVolume&&a.geometricError&&(a.metric=a._calculateUpdateMetric(e,A)),a.childrenTiles.forEach(t=>t._computeMetricRecursive(e,A)))}_expandTreeImmediate(e){const A=this;A.hasUnloadedJSONContent||(A.hasMeshContent?A.occlusionCullingService&&A.hasMeshContent&&!A.occlusionCullingService.hasID(A.colorID)||A.metric>=0&&A.metric<A.geometricErrorMultiplier*A.geometricError&&A.json&&A.json.children&&A.childrenTiles.length<A.json.children.length&&A._loadJsonChildren(e):A.json&&A.json.children&&A.childrenTiles.length<A.json.children.length&&A._loadJsonChildren(e)),A.childrenTiles.forEach(a=>a._expandTreeImmediate(e))}_update(e,A){const a=this;if(!a.isSetup)return;const t=a.materialVisibility;a.boundingVolume&&a.geometricError&&(a.metric=a._calculateUpdateMetric(e,A)),a.childrenTiles.forEach(i=>i._update(e,A)),function(i){if(a.hasMeshContent&&!(a.meshContent.length<a.hasMeshContent)){if(i<0)return a.inFrustum=!1,void a._changeContentVisibility(!!a.loadOutsideView);if(a.inFrustum=!0,a.childrenTiles.length==0)return void a._changeContentVisibility(!0);if(i>=a.geometricErrorMultiplier*a.geometricError)a._changeContentVisibility(!0);else if(i<a.geometricErrorMultiplier*a.geometricError&&a.refine=="REPLACE"){let s=!0;a.childrenTiles.every(n=>!!n._isReady()||(s=!1,!1)),s?a._changeContentVisibility(!1):a._changeContentVisibility(!0)}}}(a.metric),function(i){i<0&&a.hasMeshContent||a.occlusionCullingService&&a.hasMeshContent&&!a.occlusionCullingService.hasID(a.colorID)||(!a.hasMeshContent||i<=a.geometricErrorMultiplier*a.geometricError&&a.meshContent.length>0)&&a.json&&a.json.children&&a.childrenTiles.length!=a.json.children.length&&a._loadJsonChildren(e)}(a.metric),function(i,s){if(a.hasMeshContent){if(!a.inFrustum||a.occlusionCullingService&&!s&&a.hasMeshContent&&a.meshContent.length>0&&a.materialVisibility&&a._areAllChildrenLoadedAndHidden())return void a._disposeChildren();i>=a.geometricErrorMultiplier*a.geometricError&&a._disposeChildren()}}(a.metric,t)}_loadJsonChildren(e){const A=this;for(let a=A.json.children.length-1;a>=0;a--)A.json.children[a].root||A.json.children[a].children||A.json.children[a].getChildren||A.json.children[a].content||A.json.children[a].contents||A.json.children.splice(a,1);A.json.children.forEach(a=>{let t=new qe({parentTile:A,queryParams:A.queryParams,parentGeometricError:A.geometricError,parentBoundingVolume:A.boundingVolume,parentRefine:A.refine,json:a,rootPath:A.rootPath,geometricErrorMultiplier:A.geometricErrorMultiplier,loadOutsideView:A.loadOutsideView,level:Math.floor(A.level)+1,tileLoader:A.tileLoader,cameraOnLoad:e,occlusionCullingService:A.occlusionCullingService,renderer:A.renderer,static:A.static,centerModel:!1,displayErrors:A.displayErrors,displayCopyright:A.displayCopyright,distanceBias:A.distanceBias,loadingStrategy:A.loadingStrategy,drawBoundingVolume:A.drawBoundingVolume});A.childrenTiles.push(t),A.add(t)}),A.updateMatrices(!0)}_areAllChildrenLoadedAndHidden(){let e=!0;const A=this;return this.childrenTiles.every(a=>{if(a.hasMeshContent){if(a.childrenTiles.length>0)return e=!1,!1;if(!a.metric<0)return!0;if(a.materialVisibility||A.occlusionCullingService.hasID(a.colorID))return e=!1,!1}else if(!a._areAllChildrenLoadedAndHidden())return e=!1,!1;return!0}),e}_isReady(){if(this.metric==null)return!1;if(this.metric<0)return!0;if(this.hasUnloadedJSONContent)return!1;if(!this.hasMeshContent&&this.json.children.length==0&&!this.hasUnloadedJSONContent)return!0;if(!this.hasMeshContent||this.meshContent.length==0||!this.materialVisibility){if(this.children.length>0){var e=!0;return this.childrenTiles.every(A=>!!A._isReady()||(e=!1,!1)),e}return!1}return!this.hasMeshContent||!(this.meshContent.length<this.hasMeshContent)&&!!this.materialVisibility}_isReadyImmediate(){if(this.materialVisibility||!this.loadOutsideView&&this.metric<0)return!0;if(this.childrenTiles.length>0){var e=!0;return this.childrenTiles.every(A=>!!A._isReadyImmediate()||(e=!1,!1)),e}return!1}_changeContentVisibility(e){const A=this;A.bbox&&(A.bbox.material.visible=e),A.hasMeshContent&&A.meshContent.length>0&&(e?A.meshContent.forEach(a=>{a.traverse(t=>{(t.isMesh||t.isPoints)&&t.layers.enable(0)})}):A.meshContent.forEach(a=>{a.traverse(t=>{(t.isMesh||t.isPoints)&&t.layers.disable(0)})})),A.materialVisibility!=e&&(A.materialVisibility=e)}_calculateUpdateMetric(e,A){let a=0;if(this.boundingVolume instanceof X){if(L.copy(this.boundingVolume.sphere),L.applyMatrix4(this.matrixWorld),!A.intersectsSphere(L))return-1;a=Math.max(0,e.position.distanceTo(L.center)-L.radius-e.near)}else{if(!(this.boundingVolume instanceof Q.Sphere))return console.error("unsupported shape"),-1;if(L.copy(this.boundingVolume),L.applyMatrix4(this.matrixWorld),!A.intersectsSphere(L))return-1;a=Math.max(0,e.position.distanceTo(L.center)-L.radius-e.near)}if(a=Math.pow(a,this.distanceBias),a==0)return 0;const t=this.matrixWorld.getMaxScaleOnAxis();this.renderer&&this.renderer.getDrawingBufferSize(this.rendererSize);let i=this.rendererSize.y,s=e.fov;e.aspect<1&&(s*=e.aspect,i=this.rendererSize.x);let n=2*Math.tan(.5*s*.017453292519943295)*a;return 16*window.devicePixelRatio*n/(i*t)}_getSiblings(){const e=this,A=[];if(!e.parentTile)return A;let a=e.parentTile;for(;!a.hasMeshContent&&a.parentTile;)a=a.parentTile;return a.childrenTiles.forEach(t=>{if(t&&t!=e){for(;!t.hasMeshContent&&t.childrenTiles[0];)t=t.childrenTiles[0];A.push(t)}}),A}_calculateDistanceToCamera(e){return this.boundingVolume instanceof X?(L.copy(this.boundingVolume.sphere),L.applyMatrix4(this.matrixWorld)):this.boundingVolume instanceof Q.Sphere?(L.copy(this.boundingVolume),L.applyMatrix4(this.matrixWorld)):console.error("unsupported shape"),Math.max(0,e.position.distanceTo(L.center)-L.radius)}setGeometricErrorMultiplier(e){this.geometricErrorMultiplier=e,this.childrenTiles.forEach(A=>A.setGeometricErrorMultiplier(e))}setDistanceBias(e){this.distanceBias=e,this.childrenTiles.forEach(A=>A.setDistanceBias(e))}_transformWGS84ToCartesian(e,A,a,t){const i=6378137/Math.sqrt(1-.006694384442042*Math.pow(Math.sin(A),2)),s=Math.cos(A),n=Math.cos(e),d=Math.sin(A),o=i+a,b=o*s*n,c=o*s*Math.sin(e),h=(.993305615557957*i+a)*d;t.set(b,c,h)}}function LA(r){var e=document.createElement("div");e.textContent=r,e.style.position="fixed",e.style.top="10px",e.style.left="50%",e.style.transform="translateX(-50%)",e.style.padding="10px",e.style.backgroundColor="#ff8800",e.style.color="#ffffff",e.style.zIndex="9999",document.body.appendChild(e),setTimeout(function(){e.remove()},8e3)}function Oe(){J||((J=document.createElement("div")).style.position="fixed",J.style.bottom="20px",J.style.left="20px",J.style.color="white",J.style.textShadow="2px 2px 0 #000, -1px -1px 0 #000, 1px -1px 0 #000, -1px 1px 0 #000, 1px 1px 0 #000",J.style.padding="10px",J.style.backgroundColor="rgba(0, 0, 0, 0.1)",document.body.appendChild(J));const r=TA();let e="";r.forEach(A=>{e+=A+", "}),e=e.slice(0,-2),J.textContent=e}const U=new Q.Sphere(new Q.Vector3(0,0,0),1),Ae=new Q.Vector3(0,0,0),Je=new Q.Vector3(0,0,0),La=new Q.Vector3(0,1,0),Ke=new Q.Vector2,GA=new Q.Quaternion,vA=new Q.Matrix4;class Ve extends Q.Object3D{constructor(e){super();const A=this;if(e.queryParams&&(this.queryParams={...e.queryParams}),this.uuid=RA(),e.tileLoader?this.tileLoader=e.tileLoader:console.error("an instanced tileset must be provided an InstancedTilesetLoader"),this.master=e.master,this.loadOutsideView=e.loadOutsideView,this.cameraOnLoad=e.cameraOnLoad,this.parentTile=e.parentTile,this.distanceBias=Math.max(1e-4,e.distanceBias?e.distanceBias:1),this.childrenTiles=[],this.jsonChildren=[],this.meshContent=new Set,this.static=e.static,this.static&&(this.matrixAutoUpdate=!1,this.matrixWorldAutoUpdate=!1),this.tileContent,this.refinement,this.rootPath,this.geometricError,this.boundingVolume,this.json,this.materialVisibility=!1,this.inFrustum=!0,this.level=e.level?e.level:0,this.hasMeshContent=0,this.hasUnloadedJSONContent=0,this.centerModel=e.centerModel,this.deleted=!1,this.abortController=new AbortController,e.json)this.rootPath=e.json.rootPath?e.json.rootPath:e.rootPath,e.json.children&&(this.jsonChildren=e.json.children),A.setup(e);else if(e.url){this.loadJson=(i,s)=>{const n=$.dirname(s);A.setup({rootPath:n,json:i,onLoadCallback:e.onLoadCallback})};var a=e.url;if(A.queryParams){var t="";for(let i in A.queryParams)A.queryParams.hasOwnProperty(i)&&(t+="&"+i+"="+A.queryParams[i]);a.includes("?")?a+=t:a+="?"+t.substring(1)}A.tileLoader.get(A.abortController,a,A.uuid,A)}}async setup(e){const A=this;e.json.root?(A.json=e.json.root,!A.json.children&&A.json.getChildren&&(A.json.children=await A.json.getChildren()),A.jsonChildren=A.json.children,A.json.refinement||(A.json.refinement=e.json.refinement),A.json.geometricError||(A.json.geometricError=e.json.geometricError),A.json.transform||(A.json.transform=e.json.transform),A.json.boundingVolume||(A.json.boundingVolume=e.json.boundingVolume)):(A.json=e.json,!A.json.children&&A.json.getChildren&&(A.json.children=await A.json.getChildren(),A.jsonChildren=A.json.children)),A.rootPath=e.json.rootPath?e.json.rootPath:e.rootPath,A.json.refinement?A.refinement=A.json.refinement:A.refinement=e.parentRefinement,A.json.geometricError?A.geometricError=A.json.geometricError:A.geometricError=e.parentGeometricError;let a=new Q.Matrix4;if(A.json.transform&&!A.centerModel&&(a.elements=A.json.transform),A.applyMatrix4(a),A.parentTile&&A.parentTile.matrix&&(A.matrix.premultiply(A.parentTile.matrix),A.matrix.decompose(A.position,A.quaternion,A.scale)),A.matrixWorldNeedsUpdate=!0,A.updateWorldMatrix(!0,!0),A.json.boundingVolume)if(A.json.boundingVolume.box)A.boundingVolume=new X(A.json.boundingVolume.box);else if(A.json.boundingVolume.region){const i=A.json.boundingVolume.region;A.transformWGS84ToCartesian(i[0],i[1],i[4],Ae),A.transformWGS84ToCartesian(i[2],i[3],i[5],Je),Ae.lerp(Je,.5),A.boundingVolume=new Q.Sphere(new Q.Vector3(Ae.x,Ae.y,Ae.z),Ae.distanceTo(Je))}else if(A.json.boundingVolume.sphere){const i=A.json.boundingVolume.sphere;A.boundingVolume=new Q.Sphere(new Q.Vector3(i[0],i[1],i[2]),i[3])}else A.boundingVolume=e.parentBoundingVolume;else A.boundingVolume=e.parentBoundingVolume;function t(i){i.uri&&i.uri.includes("json")||i.url&&i.url.includes("json")?A.hasUnloadedJSONContent++:A.hasMeshContent++}if(A.json.content?(t(A.json.content),A.load()):A.json.contents&&(A.json.contents.forEach(i=>t(i)),A.load()),A.centerModel){const i=new Q.Sphere;A.boundingVolume instanceof X?i.copy(A.boundingVolume.sphere):A.boundingVolume instanceof Q.Sphere&&i.copy(A.boundingVolume),this.json.boundingVolume.region&&(A.transformWGS84ToCartesian(.5*(A.json.boundingVolume.region[0]+A.json.boundingVolume.region[2]),.5*(A.json.boundingVolume.region[1]+A.json.boundingVolume.region[3]),.5*(A.json.boundingVolume.region[4]+A.json.boundingVolume.region[5]),Ae),GA.setFromUnitVectors(Ae.normalize(),La.normalize()),A.master.applyQuaternion(GA),A.master.updateWorldMatrix(!1,!1)),vA.makeTranslation(-i.center.x*A.scale.x,-i.center.y*A.scale.y,-i.center.z*A.scale.z),A.master.matrix.multiply(vA),A.master.matrix.decompose(A.master.position,A.master.quaternion,A.master.scale)}A.isSetup=!0,e.onLoadCallback&&e.onLoadCallback(A)}isAbsolutePathOrURL(e){const A=/^(?:http|https|ftp|tcp|udp):\/\/\S+/.test(e),a=e.startsWith("/")&&!e.startsWith("//");return A||a}assembleURL(e,A){e.endsWith("/")||(e+="/");const a=new URL(e);let t=a.pathname.split("/").filter(s=>s!==""),i=A.split("/").filter(s=>s!=="");for(let s=1;s<=t.length&&!(s>=i.length);s++)if(t.slice(t.length-s,t.length).join("/")===i.slice(0,s).join("/")){for(let n=0;n<s;n++)t.pop();break}for(;i.length>0&&i[0]==="..";)t.pop(),i.shift();return`${a.protocol}//${a.host}/${[...t,...i].join("/")}`}extractQueryParams(e,A){const a=new URL(e);for(let[t,i]of a.searchParams)A[t]=i;return a.search="",a.toString()}load(){var e=this;function A(a){let t;a.uri?t=a.uri:a.url&&(t=a.url);const i=/^(?:http|https|ftp|tcp|udp):\/\/\S+/;if(i.test(e.rootPath)?i.test(t)||(t=e.assembleURL(e.rootPath,t)):$.isAbsolute(e.rootPath)&&(t=e.rootPath+$.sep+t),t=e.extractQueryParams(t,e.queryParams),e.queryParams){var s="";for(let n in e.queryParams)e.queryParams.hasOwnProperty(n)&&(s+="&"+n+"="+e.queryParams[n]);t.includes("?")?t+=s:t+="?"+s.substring(1)}t&&(t.includes(".b3dm")||t.includes(".glb")||t.includes(".gltf")?(e.contentURL=t,e.tileLoader.get(e.abortController,t,e.uuid,e,e.cameraOnLoad?()=>e.calculateDistanceToCamera(e.cameraOnLoad):()=>0,()=>e.getSiblings(),e.level,!e.json.boundingVolume.region,!!e.json.boundingVolume.region,e.geometricError)):t.includes(".json")&&e.tileLoader.get(e.abortController,t,e.uuid,e))}e.deleted||(e.json.content?A(e.json.content):e.json.contents&&e.json.contents.forEach(a=>A(a)))}loadMesh(e){this.deleted||this.meshContent.add(e)}loadJson(e,A){this.deleted||(this.json.children&&(this.jsonChildren=this.json.children),e.rootPath=$.dirname(A),this.jsonChildren.push(e),this.hasUnloadedJSONContent--)}dispose(){const e=this;e.childrenTiles.forEach(A=>A.dispose()),e.deleted=!0,e.abortController&&e.abortController.abort(),this.parent=null,this.parentTile=null,this.dispatchEvent({type:"removed"})}disposeChildren(){this.childrenTiles.forEach(e=>e.dispose()),this.childrenTiles=[]}_update(e,A){const a=this;function t(i){if(a.hasMeshContent&&!(a.meshContent.size<a.hasMeshContent)){if(i<0)return a.inFrustum=!1,void a.changeContentVisibility(!!a.loadOutsideView);if(a.inFrustum=!0,a.childrenTiles.length!=0){if(i>=a.master.geometricErrorMultiplier*a.geometricError)a.changeContentVisibility(!0);else if(i<a.master.geometricErrorMultiplier*a.geometricError){let s=!0;a.childrenTiles.every(n=>!!n.isReady()||(s=!1,!1)),s&&a.changeContentVisibility(!1)}}else a.changeContentVisibility(!0)}}a.isSetup&&(a.materialVisibility,a.boundingVolume&&a.geometricError&&(a.metric=a.calculateUpdateMetric(e,A)),a.childrenTiles.forEach(i=>i._update(e,A)),t(a.metric),function(i){i<0&&a.hasMeshContent||(!a.hasMeshContent&&a.rootPath||i<a.master.geometricErrorMultiplier*a.geometricError&&a.meshContent.size>0)&&a.json&&a.jsonChildren&&a.childrenTiles.length!=a.jsonChildren.length&&a.jsonChildren.forEach(s=>{if(!(s.root||s.children||s.getChildren||s.content||s.contents))return;let n=new Ve({parentTile:a,queryParams:a.queryParams,parentGeometricError:a.geometricError,parentBoundingVolume:a.boundingVolume,parentRefinement:a.refinement,json:s,rootPath:a.rootPath,loadOutsideView:a.loadOutsideView,level:a.level+1,tileLoader:a.tileLoader,cameraOnLoad:e,master:a.master,centerModel:!1});a.childrenTiles.push(n)})}(a.metric),function(i){if(a.hasMeshContent){if(!a.inFrustum)return a.disposeChildren(),void t(i);i>=a.master.geometricErrorMultiplier*a.geometricError&&(a.disposeChildren(),t(i))}}(a.metric))}areAllChildrenLoadedAndHidden(){let e=!0;return this.childrenTiles.every(A=>{if(A.hasMeshContent){if(A.childrenTiles.length>0)return e=!1,!1;if(!A.inFrustum)return!0;if(!A.materialVisibility||A.meshesToDisplay!=A.meshesDisplayed)return e=!1,!1}else if(!A.areAllChildrenLoadedAndHidden())return e=!1,!1;return!0}),e}isReady(){if(!this.inFrustum)return!0;if(this.hasUnloadedJSONContent)return!1;if(!this.hasMeshContent||this.meshContent.size==0||!this.materialVisibility){if(this.childrenTiles.length>0){var e=!0;return this.childrenTiles.every(A=>!!A.isReady()||(e=!1,!1)),e}return!1}return!this.hasMeshContent||!(this.meshContent.size<this.hasMeshContent)&&!!this.materialVisibility}changeContentVisibility(e){this.materialVisibility=e}calculateUpdateMetric(e,A){if(this.boundingVolume instanceof X){if(U.copy(this.boundingVolume.sphere),U.applyMatrix4(this.matrixWorld),!A.intersectsSphere(U))return-1}else{if(!(this.boundingVolume instanceof Q.Sphere))return console.error("unsupported shape"),-1;if(U.copy(this.boundingVolume),U.applyMatrix4(this.matrixWorld),!A.intersectsSphere(U))return-1}let a=Math.max(0,e.position.distanceTo(U.center)-U.radius);if(a=Math.pow(a,this.distanceBias),a==0)return 0;const t=this.matrixWorld.getMaxScaleOnAxis();this.master._renderSize(Ke);let i=Ke.y,s=e.fov;e.aspect<1&&(s*=e.aspect,i=Ke.x);let n=2*Math.tan(.5*s*.017453292519943295)*a;return 16*window.devicePixelRatio*n/(i*t)}getSiblings(){const e=this,A=[];if(!e.parentTile)return A;let a=e.parentTile;for(;!a.hasMeshContent&&a.parentTile;)a=a.parentTile;return a.childrenTiles.forEach(t=>{if(t&&t!=e){for(;!t.hasMeshContent&&t.childrenTiles[0];)t=t.childrenTiles[0];A.push(t)}}),A}calculateDistanceToCamera(e){return this.boundingVolume instanceof X?(U.copy(this.boundingVolume.sphere),U.applyMatrix4(this.matrixWorld)):this.boundingVolume instanceof Q.Sphere?(U.copy(this.boundingVolume),U.applyMatrix4(this.matrixWorld)):console.error("unsupported shape"),Math.max(0,e.position.distanceTo(U.center)-U.radius)}getWorldMatrix(){return this.matrixWorld}transformWGS84ToCartesian(e,A,a,t){const i=6378137/Math.sqrt(1-.006694384442042*Math.pow(Math.sin(A),2)),s=Math.cos(A),n=Math.cos(e),d=Math.sin(A),o=i+a,b=o*s*n,c=o*s*Math.sin(e),h=(.993305615557957*i+a)*d;t.set(b,c,h)}}class Ga extends Q.Object3D{constructor(e){super(),e.master=this,e.domWidth&&e.domHeight?this.rendererSize=new Q.Vector2(e.domWidth,e.domHeight):this.rendererSize=new Q.Vector2(1e3,1e3),this.renderer=e.renderer,this.distanceBias=Math.max(1e-4,e.distanceBias?e.distanceBias:1),this.geometricErrorMultiplier=e.geometricErrorMultiplier?e.geometricErrorMultiplier:1,this.tileset=new Ve(e),e.static&&(this.matrixAutoUpdate=!1),this.tileLoader=e.tileLoader}_renderSize(e){this.renderer?this.renderer.getDrawingBufferSize(e):e.copy(this.rendererSize)}setCanvasSize(e,A){this.rendererSize.set(e,A)}update(e,A){if(A)this.tileset._update(e,A);else{const a=new Q.Frustum;a.setFromProjectionMatrix(new Q.Matrix4().multiplyMatrices(e.projectionMatrix,e.matrixWorldInverse)),this.tileset._update(e,a)}}setGeometricErrorMultiplier(e){this.geometricErrorMultiplier=e||1}}class va{constructor(e){const A=this;A.scene=e,A.instancedTiles=[],A.instancedMesh,A.reuseableMatrix=new Q.Matrix4}addInstance(e){const A=this;e.added=!0,e.listOMesh=A.instancedTiles,A.instancedTiles.push(e),A.instancedMesh&&e.loadMesh(A.instancedMesh)}addToScene(){const e=this;e.instancedMesh.setMatrixAt(0,new Q.Matrix4),e.instancedMesh.instanceMatrix.needsUpdate=!0,e.instancedMesh.count=1,e.scene.add(e.instancedMesh),e.instancedMesh.onAfterRender=()=>{delete e.instancedMesh.onAfterRender,e.instancedMesh.displayedOnce=!0}}setObject(e){const A=this;A.instancedMesh=e,A.instancedMesh.matrixAutoUpdate=!1,A.instancedMesh.matrixWorldAutoUpdate=!1,A.scene.children.includes(e)||this.addToScene();for(let a=0;a<A.instancedTiles.length;a++)A.instancedTiles[a].loadMesh(A.instancedMesh)}update(){const e=this;for(let A=e.instancedTiles.length-1;A>=0;A--)e.instancedTiles[A].deleted&&e.instancedTiles.splice(A,1);if(e.instancedMesh){e.instancedMesh.count=0,e.instancedMesh.instancedTiles=[];for(let A=0;A<e.instancedTiles.length;A++)e.instancedTiles[A].meshContent.add(e.instancedMesh),e.instancedTiles[A].materialVisibility&&(e.instancedMesh.count++,e.reuseableMatrix.set(1,0,0,0,0,1,0,0,0,0,1,0,0,0,0,1),e.reuseableMatrix.multiply(e.instancedTiles[A].matrixWorld),e.reuseableMatrix.multiply(e.instancedMesh.baseMatrix),e.instancedMesh.setMatrixAt(e.instancedMesh.count-1,e.reuseableMatrix),e.instancedMesh.instancedTiles.push(e.instancedTiles[A]));e.instancedMesh.instanceMatrix.needsUpdate=!0,e.instancedMesh.needsUpdate=!0,e.instancedMesh.computeBoundingSphere()}}getCount(){return this.instancedTiles.length}dispose(){const e=this;return!(e.instancedTiles.length>0)&&!!e.instancedMesh&&(e.scene.remove(e.instancedMesh),e.instancedMesh.traverse(A=>{if(A.dispose&&A.dispose(),A.material)if(A.material.length)for(let a=0;a<A.material.length;++a)A.material[a].dispose();else A.material.dispose();A.geometry&&A.geometry.dispose()}),e.instancedMesh.dispose(),!0)}}class Ua{constructor(){const e=this;e.count=0,e.json,e.instancedTiles=[]}addInstance(e){this.instancedTiles.push(e),this.json&&e.loadJson(this.json,this.url)}setObject(e,A){const a=this;a.json=e,a.url=A;for(let t=0;t<a.instancedTiles.length;t++)a.instancedTiles[t].loadJson(a.json,a.url)}getCount(){return this.instancedTiles.length}update(){const e=this;for(let A=e.instancedTiles.length-1;A>=0;A--)e.instancedTiles[A].deleted&&e.instancedTiles.splice(A,1)}dispose(){return!(!this.json||this.instancedTiles.length!=0)}}let ie=0;async function Na(r){return new Promise(e=>{const A=setInterval(()=>{r.hasDracoLoader&&!r.dracoLoader||r.hasKTX2Loader&&!r.ktx2Loader||(clearInterval(A),e())},10)})}S.InstancedOGC3DTile=Ga,S.InstancedTileLoader=class{constructor(r,e){if(this.zUpToYUpMatrix=new Q.Matrix4,this.zUpToYUpMatrix.set(1,0,0,0,0,0,-1,0,0,1,0,0,0,0,0,1),this.maxCachedItems=100,this.maxInstances=1,this.proxy=e.proxy,e&&(this.meshCallback=e.meshCallback,this.pointsCallback=e.pointsCallback,e.maxCachedItems&&(this.maxCachedItems=e.maxCachedItems),e.maxInstances&&(this.maxInstances=e.maxInstances)),this.gltfLoader=new eA,e&&e.dracoLoader)this.gltfLoader.setDRACOLoader(e.dracoLoader),this.hasDracoLoader=!0;else{const A=new rA;A.setDecoderPath("https://www.gstatic.com/draco/versioned/decoders/1.4.3/"),this.gltfLoader.setDRACOLoader(A),this.gltfLoader.hasDracoLoader=!0}if(e&&e.ktx2Loader)this.gltfLoader.setKTX2Loader(e.ktx2Loader),this.hasKTX2Loader=!0;else if(e&&e.renderer){const A=new N;A.setTranscoderPath("https://storage.googleapis.com/ogc-3d-tiles/basis/").detectSupport(e.renderer),this.gltfLoader.setKTX2Loader(A),this.gltfLoader.hasKTX2Loader=!0}this.gltfLoader.setMeshoptDecoder(DA),this.hasMeshOptDecoder=!0,this.b3dmDecoder=new $e(this.gltfLoader),this.cache=new Ye.LinkedHashMap,this.scene=r,this.ready=[],this.downloads=[],this.nextReady=[],this.nextDownloads=[]}update(){const r=this;r._checkSize(),r.cache._data.forEach(e=>{e.update()}),ie<8&&r._download(),r._loadBatch()}_download(){const r=this;if(r.nextDownloads.length!=0||(r._getNextDownloads(),r.nextDownloads.length!=0))for(;r.nextDownloads.length>0;){const A=r.nextDownloads.shift();if(A){if(A.path.includes(".b3dm")&&(e=r.proxy?()=>fetch(r.proxy,{method:"POST",body:A.path}):()=>fetch(A.path),ie++,e().then(a=>{if(!a.ok)throw console.error("could not load tile with path : "+A.path),new Error(`couldn't load "${A.path}". Request failed with status ${a.status} : ${a.statusText}`);return a.arrayBuffer()}).then(a=>this.b3dmDecoder.parseB3DMInstanced(a,t=>{r.meshCallback(t,A.geometricError)},r.maxInstances,A.sceneZupToYup,A.meshZupToYup)).then(a=>{a.frustumCulled=!1,A.tile.setObject(a),r.ready.unshift(A)}).catch(a=>console.error(a)).finally(()=>{ie--})),A.path.includes(".glb")||A.path.includes(".gltf"))e=r.proxy?()=>fetch(r.proxy,{method:"POST",body:A.path}):()=>fetch(A.path),ie++,e().then(a=>{if(!a.ok)throw new Error("missing content");return a.arrayBuffer()}).then(async a=>{await Na(this.gltfLoader),this.gltfLoader.parse(a,null,t=>{let i;t.scene.asset=t.asset,A.sceneZupToYup&&t.scene.applyMatrix4(this.zUpToYUpMatrix),t.scene.traverse(s=>{s.geometricError=A.geometricError,s.isMesh&&(A.meshZupToYup&&s.applyMatrix4(this.zUpToYUpMatrix),r.meshCallback&&r.meshCallback(s,s.geometricError)),s.isPoints&&console.error("instanced point cloud is not supported")}),t.scene.updateWorldMatrix(!1,!0),t.scene.traverse(s=>{s.isMesh&&(i=new Q.InstancedMesh(s.geometry,s.material,r.maxInstances),i.baseMatrix=s.matrixWorld)}),r.ready.unshift(A),i?(i.frustumCulled=!1,A.tile.setObject(i)):t.scene.traverse(s=>{s.dispose&&s.dispose(),s.material&&s.material.dispose()})})},a=>{console.error("could not load tile : "+A.path)}).finally(()=>{ie--});else if(A.path.includes(".json")){var e;e=r.proxy?()=>fetch(r.proxy,{method:"POST",body:A.path}):()=>fetch(A.path),ie++,e().then(a=>{if(!a.ok)throw console.error("could not load tile with path : "+A.path),new Error(`couldn't load "${A.path}". Request failed with status ${a.status} : ${a.statusText}`);return a.json()}).then(a=>Ne(a,A.path)).then(a=>{A.tile.setObject(a,A.path),r.ready.unshift(A)}).catch(a=>console.error(a)).finally(()=>{ie--})}}}}_loadBatch(){return this.nextReady.length==0&&(this._getNextReady(),this.nextReady.length==0)?0:this.nextReady.shift()?1:0}_getNextReady(){let r=Number.MAX_VALUE,e=-1;for(let A=this.ready.length-1;A>=0;A--)this.ready[A].distanceFunction||this.nextReady.push(this.ready.splice(A,1)[0]);if(!(this.nextReady.length>0)){for(let A=this.ready.length-1;A>=0;A--){const a=this.ready[A].distanceFunction()*this.ready[A].level;a<r&&(r=a,e=A)}if(e>=0){const A=this.ready.splice(e,1).pop();this.nextReady.push(A);const a=A.getSiblings();for(let t=this.ready.length-1;t>=0;t--)a.includes(this.ready[t].uuid)&&this.nextready.push(this.ready.splice(t,1).pop())}}}get(r,e,A,a,t,i,s,n,d,o){const b=this,c=function(f){for(var l=f.split("/"),u=[],I=0,C=0;C<l.length;C++){var B=l[C];B!=="."&&B!==""&&B!==".."?u[I++]=B:B===".."&&I>0&&I--}if(I===0)return"/";var m="";for(C=0;C<I;C++)m+="/"+u[C];return m}(e);if(!(e.includes(".b3dm")||e.includes(".json")||e.includes(".glb")||e.includes(".gltf")))return void console.error("the 3DTiles cache can only be used to load B3DM, gltf and json data");const h=b.cache.get(c);if(h)h.addInstance(a);else if(e.includes(".b3dm")||e.includes(".glb")||e.includes(".gltf")){const f=new va(b.scene);f.addInstance(a),b.cache.put(c,f);const l=new AbortController;r.signal.addEventListener("abort",()=>{f.getCount()==0&&l.abort()}),this.downloads.push({abortController:l,tile:f,key:c,path:e,distanceFunction:t,getSiblings:i,level:s,uuid:A,sceneZupToYup:n,meshZupToYup:d,geometricError:o,shouldDoDownload:()=>!0})}else if(e.includes(".json")){const f=new Ua;f.addInstance(a),b.cache.put(c,f);const l=new AbortController;r.signal.addEventListener("abort",()=>{f.getCount()==0&&l.abort()}),this.downloads.push({abortController:l,tile:f,key:c,path:e,distanceFunction:t,getSiblings:i,level:s,shouldDoDownload:()=>!0})}}_getNextDownloads(){let r=Number.MAX_VALUE,e=-1;for(let A=this.downloads.length-1;A>=0;A--){const a=this.downloads[A];a.shouldDoDownload()?a.distanceFunction||this.nextDownloads.push(this.downloads.splice(A,1)[0]):this.downloads.splice(A,1)}if(!(this.nextDownloads.length>0)){for(let A=this.downloads.length-1;A>=0;A--){const a=this.downloads[A],t=a.distanceFunction()*a.level;t<r&&(r=t,e=A)}if(e>=0){const A=this.downloads.splice(e,1).pop();this.nextDownloads.push(A);const a=A.getSiblings();for(let t=this.downloads.length-1;t>=0;t--)a.includes(this.downloads[t].uuid)&&this.nextDownloads.push(this.downloads.splice(t,1).pop())}}}_checkSize(){const r=this;let e=0;for(;r.cache.size()>r.maxCachedItems&&e<r.cache.size();){e++;const A=r.cache.head();r.cache.remove(A.key),A.value.dispose()||r.cache.put(A.key,A.value)}}},S.OGC3DTile=qe,S.OcclusionCullingService=class{constructor(){this.cullMap=[],this.cullMaterial=new Q.MeshBasicMaterial({vertexColors:!0}),this.cullMaterial.side=Q.FrontSide,this.cullTarget=this._createCullTarget(),this.cullPixels=new Uint8Array(4*this.cullTarget.width*this.cullTarget.height)}setSide(r){this.cullMaterial.side=r}_createCullTarget(){const r=new Q.WebGLRenderTarget(Math.floor(.05*window.innerWidth),Math.floor(.05*window.innerHeight));return r.texture.format=Q.RGBAFormat,r.texture.colorSpace=Q.LinearSRGBColorSpace,r.texture.minFilter=Q.NearestFilter,r.texture.magFilter=Q.NearestFilter,r.texture.generateMipmaps=!1,r.stencilBuffer=!1,r.depthBuffer=!0,r.depthTexture=new Q.DepthTexture,r.depthTexture.format=Q.DepthFormat,r.depthTexture.type=Q.UnsignedShortType,r}update(r,e,A){let a=e.getRenderTarget(),t=r.overrideMaterial;r.overrideMaterial=this.cullMaterial,e.setRenderTarget(this.cullTarget),e.render(r,A),r.overrideMaterial=t,e.setRenderTarget(a),e.readRenderTargetPixels(this.cullTarget,0,0,this.cullTarget.width,this.cullTarget.height,this.cullPixels),this.cullMap=[];for(let i=0;i<this.cullPixels.length;i+=4){const s=Q.MathUtils.clamp(this.cullPixels[i],0,255)<<16^Q.MathUtils.clamp(this.cullPixels[i+1],0,255)<<8^Q.MathUtils.clamp(this.cullPixels[i+2],0,255);this.cullMap[s]=!0}}hasID(r){return this.cullMap[r]}},S.TileLoader=jA,S.getOGC3DTilesCopyrightInfo=TA,Object.defineProperty(S,Symbol.toStringTag,{value:"Module"})});
21
+ //# sourceMappingURL=threedtiles.umd.js.map