@aibee/crc-bmap 0.0.113 → 0.0.114
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/lib/bmap.cjs.min.js +1 -1
- package/lib/bmap.cjs.min.js.map +3 -3
- package/lib/bmap.esm.js +7 -2
- package/lib/bmap.esm.js.map +2 -2
- package/lib/bmap.esm.min.js +1 -1
- package/lib/bmap.esm.min.js.map +3 -3
- package/lib/bmap.min.js +1 -1
- package/lib/bmap.min.js.map +3 -3
- package/package.json +1 -1
package/lib/bmap.esm.min.js
CHANGED
|
@@ -1,4 +1,4 @@
|
|
|
1
|
-
var gn=Object.create;var Jt=Object.defineProperty;var mn=Object.getOwnPropertyDescriptor;var yn=Object.getOwnPropertyNames;var _n=Object.getPrototypeOf,vn=Object.prototype.hasOwnProperty;var z=(o,n)=>()=>(n||o((n={exports:{}}).exports,n),n.exports);var xn=(o,n,t,e)=>{if(n&&typeof n=="object"||typeof n=="function")for(let r of yn(n))!vn.call(o,r)&&r!==t&&Jt(o,r,{get:()=>n[r],enumerable:!(e=mn(n,r))||e.enumerable});return o};var Qt=(o,n,t)=>(t=o!=null?gn(_n(o)):{},xn(n||!o||!o.__esModule?Jt(t,"default",{value:o,enumerable:!0}):t,o));var ve=z((ho,_e)=>{_e.exports=function(n,t){return n[0]=t[0],n[1]=t[1],n}});var be=z((co,Ee)=>{var xe=ve();Ee.exports=function(o,n){Array.isArray(n)||(n=[]),o.length>0&&n.push(xe([0,0],o[0]));for(var t=0;t<o.length-1;t++){var e=o[t],r=o[t+1],i=e[0],s=e[1],l=r[0],u=r[1],a=[.75*i+.25*l,.75*s+.25*u],h=[.25*i+.75*l,.25*s+.75*u];n.push(a),n.push(h)}return o.length>1&&n.push(xe([0,0],o[o.length-1])),n}});var Ae=z((yo,Pe)=>{var Wt=class{constructor(){this.keys=new Set,this.queue=[]}sort(){this.queue.sort((n,t)=>n.priority-t.priority)}set(n,t){let e=Number(t);if(isNaN(e))throw new TypeError('"priority" must be a number');return this.keys.has(n)?this.queue.map(r=>(r.key===n&&Object.assign(r,{priority:e}),r)):(this.keys.add(n),this.queue.push({key:n,priority:e})),this.sort(),this.queue.length}next(){let n=this.queue.shift();return this.keys.delete(n.key),n}isEmpty(){return this.queue.length===0}has(n){return this.keys.has(n)}get(n){return this.queue.find(t=>t.key===n)}};Pe.exports=Wt});var Ie=z((_o,Le)=>{function Re(o,n){let t=new Map;for(let[e,r]of o)e!==n&&r instanceof Map?t.set(e,Re(r,n)):e!==n&&t.set(e,r);return t}Le.exports=Re});var De=z((vo,Oe)=>{function qn(o){let n=Number(o);return!(isNaN(n)||n<=0)}function Ne(o){let n=new Map;return Object.keys(o).forEach(e=>{let r=o[e];if(r!==null&&typeof r=="object"&&!Array.isArray(r))return n.set(e,Ne(r));if(!qn(r))throw new Error(`Could not add node at key "${e}", make sure it's a valid node`,r);return n.set(e,Number(r))}),n}Oe.exports=Ne});var Be=z((xo,Ue)=>{function Fe(o){if(!(o instanceof Map))throw new Error(`Invalid graph: Expected Map instead found ${typeof o}`);o.forEach((n,t)=>{if(typeof n=="object"&&n instanceof Map){Fe(n);return}if(typeof n!="number"||n<=0)throw new Error(`Values must be numbers greater than 0. Found value ${n} at ${t}`)})}Ue.exports=Fe});var Ve=z((Eo,ke)=>{var jn=Ae(),Yn=Ie(),Ge=De(),ze=Be(),Xt=class{constructor(n){n instanceof Map?(ze(n),this.graph=n):n?this.graph=Ge(n):this.graph=new Map}addNode(n,t){let e;return t instanceof Map?(ze(t),e=t):e=Ge(t),this.graph.set(n,e),this}addVertex(n,t){return this.addNode(n,t)}removeNode(n){return this.graph=Yn(this.graph,n),this}path(n,t,e={}){if(!this.graph.size)return e.cost?{path:null,cost:0}:null;let r=new Set,i=new jn,s=new Map,l=[],u=0,a=[];if(e.avoid&&(a=[].concat(e.avoid)),a.includes(n))throw new Error(`Starting node (${n}) cannot be avoided`);if(a.includes(t))throw new Error(`Ending node (${t}) cannot be avoided`);for(i.set(n,0);!i.isEmpty();){let h=i.next();if(h.key===t){u=h.priority;let f=h.key;for(;s.has(f);)l.push(f),f=s.get(f);break}r.add(h.key),(this.graph.get(h.key)||new Map).forEach((f,d)=>{if(r.has(d)||a.includes(d))return null;if(!i.has(d))return s.set(d,h.key),i.set(d,h.priority+f);let p=i.get(d).priority,m=h.priority+f;return m<p?(s.set(d,h.key),i.set(d,m)):null})}return l.length?(e.trim?l.shift():l=l.concat([n]),e.reverse||(l=l.reverse()),e.cost?{path:l,cost:u}:l):e.cost?{path:null,cost:0}:null}shortestPath(...n){return this.path(...n)}};ke.exports=Xt});import{EventDispatcher as ii,Vector3 as oi}from"three";var L=class{tasks={requestAnimation:new Set,timeout:new Set,interval:new Set};requestAnimationFrame(n){let t=window.requestAnimationFrame(()=>{this.tasks.requestAnimation.delete(t),n()});return this.tasks.requestAnimation.add(t),t}cancelAnimationFrame(n){this.tasks.requestAnimation.delete(n),window.cancelAnimationFrame(n)}setTimeout(n,t){let e=window.setTimeout(()=>{this.tasks.timeout.delete(e),n()},t);return this.tasks.timeout.add(e),e}clearTimeout(n){this.tasks.timeout.delete(n),window.clearTimeout(n)}setInterval(n,t){let e=window.setInterval(()=>{this.tasks.interval.delete(e),n()},t);return this.tasks.interval.add(e),e}clearInterval(n){this.tasks.interval.delete(n),window.clearInterval(n)}dispose(){this.tasks.requestAnimation.forEach(n=>{window.cancelAnimationFrame(n)}),this.tasks.requestAnimation.clear(),this.tasks.timeout.forEach(n=>{window.clearTimeout(n)}),this.tasks.timeout.clear(),this.tasks.interval.forEach(n=>{window.clearInterval(n)}),this.tasks.interval.clear()}};import{Scene as En,WebGLRenderer as bn,OrthographicCamera as Mn,Shape as Sn,PCFSoftShadowMap as wn,Group as Tn,Color as Cn,DirectionalLight as Pn,AmbientLight as An,Path as Rn,Vector2 as te}from"three";import{MapControls as Ln}from"three/examples/jsm/controls/MapControls";function ee(){let o=new En;return o.background=new Cn(16777215),o}function ne(){let o=new bn({antialias:!0});return o.autoClear=!0,o.setClearAlpha(1),o.setClearColor(16777215),o.setPixelRatio(window.devicePixelRatio),o.shadowMap.enabled=!0,o.shadowMap.autoUpdate=!0,o.shadowMap.type=wn,o}function re(o,n){let t=new Mn(-o/2,o/2,n/2,-n/2,-1e3,5e3);return t.up.set(0,0,1),t.position.set(0,0,100),t.lookAt(0,0,0),t}function ie(){let o=new Tn,n=new An(16777215,2.6);return o.add(n),o}function oe(o,n){let t=new Ln(o,n);return t.enableDamping=!1,t.zoomSpeed=2,t}function se(o,n=[]){let t=new Sn(o.map(e=>new te(...e)));return n.length&&n.forEach(e=>{var r=new Rn(e.map(i=>new te(...i)));t.holes.push(r)}),t}function ae(o=16777215,n=1){let t=new Pn(o,n);return t.castShadow=!0,t.shadow.radius=8,t.shadow.bias=-.001,t.shadow.mapSize.set(256,256),t.shadow.camera.left=-200,t.shadow.camera.right=200,t.shadow.camera.top=200,t.shadow.camera.bottom=-200,t}function O(o,n){if(n&&o.children&&o.children.length&&o.children.forEach(t=>{O(t,n)}),o.isMesh){let t=o;t.geometry&&t.geometry.dispose(),t.material&&(Array.isArray(t.material)?t.material.forEach(e=>{e.dispose()}):t.material.dispose())}o.isLight&&o.dispose?.()}function le(o){return/[\u4E00-\u9FA5]+/g.test(o)}import{DataTexture as In,RGBAFormat as Nn,LinearFilter as ue}from"three";var it=new Map;function On(){let o=document.createElement("canvas");o.width=1024,o.height=64;let n=o.getContext("2d",{willReadFrequently:!0});return n.font="54px sans-serif",n.textBaseline="hanging",n.lineWidth=12,n.fillStyle="rgba(0,0,0,1)",n.strokeStyle="white",{canvas:o,ctx:n}}var Gt,k;function Dn(){if(!Gt){let{canvas:o,ctx:n}=On();Gt=o,k=n}}function Ui(o){if(it.has(o))return it.get(o);Dn(),k.clearRect(0,0,1024,64);let n=le(o)?4:8;k.strokeText(o,2,n),k.fillText(o,2,n);let t=Math.ceil(k.measureText(o).width);t=t%2===0?t:t+1,t+=2;let e=k.getImageData(0,0,t,64),r=new In(Uint8Array.from(e.data),t,64,Nn);return r.flipY=!0,r.minFilter=ue,r.magFilter=ue,it.set(o,r),r}function he(){it.clear()}function ce(){k=null,Gt=null}import{Vector3 as zt,Vector2 as ot}from"three";import{point as Fn,featureCollection as Un,center as Bn}from"@turf/turf";function y(o,n,t,e){let r=o.clone().project(n),i=t/2,s=e/2,l=Math.round(r.x*i+i),u=Math.round(-r.y*s+s);return{x:l,y:u}}function kt(o){let n=Un(o.map(e=>Fn(e)));return Bn(n).geometry.coordinates}function st(o,n,t){return o.x>=n.x&&o.x<=t.x&&o.y>=n.y&&o.y<=t.y}function Vi(o){let n=0,t=new zt;for(let e=1;e<o.length;e++){let r=new zt(o[e-1][0],o[e-1][1],0),i=new zt(o[e][0],o[e][1],0),s=i.distanceTo(r);s>n&&(n=s,t=i.clone().sub(r).normalize())}return t}function M(o,n){return Math.sqrt((n[0]-o[0])**2+(n[1]-o[1])**2)}function at(o){let n=0;for(let t=0;t<o.length-1;t++)n+=M(o[t],o[t+1]);return n}function pe(o,n,t){let e=new ot(n[0]-o[0],n[1]-o[1]),r=new ot(n[0]-t[0],n[1]-t[1]),s=e.angleTo(r)*180/Math.PI,l=new ot(n[0]-o[0],n[1]-o[1]);return new ot(t[0]-o[0],t[1]-o[1]).cross(l)>0?s:-s}function X(o,n){return new Proxy(o,{get:(t,e,r)=>Reflect.get(t,e,r),set:(t,e,r,i)=>{let s=Reflect.get(t,e,i),l=Reflect.set(t,e,r,i);return s!==r&&n.dispatchEvent({type:`change-${e}`,value:r}),l}})}function V(o,n){return Promise.race([o,new Promise((t,e)=>{setTimeout(()=>e(new Error("Promise timeout")),n)})])}function lt(o){return document.createElementNS("http://www.w3.org/2000/svg",o)}function fe(o,n){let t=lt("svg");return t.setAttribute("width",o),t.setAttribute("height",n),t.style.cssText="position: absolute; left: 0; top: 0; pointer-events: none;",t}function K(o="2",n){let t=lt("circle");return t.setAttribute("r",o),t.setAttribute("fill",n),t}function ut(o){let n=lt("line");return n.setAttribute("stroke",o),n}function q(o,n){let t=lt("rect");return t.setAttribute("stroke",o),t.setAttribute("fill",n),t}function H(o,n,t){o.setAttribute("cx",`${n}`),o.setAttribute("cy",`${t}`)}function C(o,n,t){n&&(o.setAttribute("x1",`${n.x}`),o.setAttribute("y1",`${n.y}`)),t&&(o.setAttribute("x2",`${t.x}`),o.setAttribute("y2",`${t.y}`))}function P(o,n,t,e,r){o.setAttribute("x",`${n}`),o.setAttribute("y",`${t}`),o.setAttribute("width",`${e}`),o.setAttribute("height",`${r}`)}function de(){return Promise.resolve()}function ji(){return new Promise(o=>{requestAnimationFrame(o)})}function Zi(o){return parseInt(o.replace("#","0x"),16)}function Ki(o,n){let t=parseInt(o.substring(1,3),16),e=parseInt(o.substring(3,5),16),r=parseInt(o.substring(5,7),16),i=Math.round(t*n),s=Math.round(e*n),l=Math.round(r*n);return`#${(1<<24|i<<16|s<<8|l).toString(16).slice(1)}`}function ht(o,n=.85){let t,e,r;if(o.startsWith("#"))t=parseInt(o.substring(1,3),16),e=parseInt(o.substring(3,5),16),r=parseInt(o.substring(5,7),16);else{let s=o.slice(4,-1).split(",");t=parseInt(s[0].trim()),e=parseInt(s[1].trim()),r=parseInt(s[2].trim())}return t=Math.min(Math.floor(t*n),255),e=Math.min(Math.floor(e*n),255),r=Math.min(Math.floor(r*n),255),"#"+((1<<24)+(t<<16)+(e<<8)+r).toString(16).slice(1)}import{GLTFLoader as Gn}from"three/examples/jsm/loaders/GLTFLoader";function zn(){return new Gn}var ct=null,pt=new Map;function ge(o){if(pt.has(o)){let t=pt.get(o).then(e=>(e.scene=e.scene.clone(),e))}ct||(ct=zn());let n=new Promise((t,e)=>{ct.load(o,r=>{t(r)},void 0,e)});return pt.set(o,n),n.then(t=>(t.scene=t.scene.clone(),t))}function me(){ct=null,pt.clear()}var ft=navigator.userAgent.toUpperCase().indexOf("MAC")>=0;function Vt(o){return ft?o==="Meta":o==="Control"}var Ht="__once__",ye=class{events=new Map;on(n,t){if(typeof t!="function")return;let e=this.events.get(n);return e?e.add(t):this.events.set(n,new Set([t]))}once(n,t){if(typeof t!="function")return;let e=`${Ht}${n}`,r=this.events.get(e);return r?r.add(t):this.events.set(e,new Set([t]))}off(n,t){let e=this.events.get(n),r=this.events.get(`${Ht}${n}`);!e&&!r||(t===void 0&&(e?.clear(),r?.clear()),e?.has(t)&&e.delete(t),r?.has(t)&&r.delete(t))}offAll(){this.events.clear()}emit(n,...t){let e=this.events.get(n),r=this.events.get(`${Ht}${n}`);!e&&!r||(e?.forEach(i=>{typeof i=="function"&&i(...t)}),r?.forEach(i=>{typeof i=="function"&&i(...t)}),r?.clear())}};var $=(t=>(t.SWITCH_FLOOR_BEFORE="switch_floor_before",t.SWITCH_FLOOR_AFTER="switch_floor_after",t))($||{});function A(o){return Object.keys(o).sort().map(n=>`${n}=${o[n]}`).join("&")}function ao(o,n){return new Promise((t,e)=>{let r=new XMLHttpRequest;r.open("GET",o,!0),Object.keys(n.headers||{}).forEach(i=>{r.setRequestHeader(i,n.headers[i])}),n.responseType&&(r.responseType=n.responseType),r.onload=()=>{if(r.status>=200&&r.status<300)if(n.responseType==="arraybuffer")t(r.response);else try{let i=JSON.parse(r.responseText);t(i)}catch(i){e(i)}else e(r.statusText)},r.onerror=()=>{e(r.statusText)},r.send()})}var j=class o{keySet=new Set;static createKey(){return Math.random().toString(36).substring(2,15)+Math.random().toString(36).substring(2,15)}genUniqueKey(){let n=o.createKey();for(;this.keySet.has(n);)n=o.createKey();return n}removeKey(n){this.keySet.delete(n)}dispose(){this.keySet.clear()}};var Me=Qt(be(),1);import{Vector2 as J}from"three";function kn(o,n){let t=o.clone().normalize(),e=n.clone().normalize();return Math.acos(t.dot(e))}function Vn(o){let n=0;return o.reduce(([t,e],[r,i])=>(n+=Math.sqrt((r-t)**2+(i-e)**2),[r,i])),n/o.length}function Se(o,n=.25){if(Vn(o)<n)return o;let t=(0,Me.default)(o);return Se(t,n)}function we(o,n=!1,t=!0,e=5,r=150,i=3){let s=[],l=!n;if(s.push(o[0]),o.length<2)return s;for(let a=0;a<o.length-2;a+=1){let h=o[a],c=o[a+1],f=o[a+2],d=new J(h[0]-c[0],h[1]-c[1]),p=new J(f[0]-c[0],f[1]-c[1]),m=kn(d,p)/Math.PI*180,g=d.length()+p.length();(!l||m<r&&g>.01||g>e)&&(s.push(o[a+1]),l=!0)}if(s.push(o[o.length-1]),!t)return s;let u=[];u.push(s[0]);for(let a=0;a<s.length-2;a+=1){let h=new J(s[a][0],s[a][1]),c=new J(s[a+1][0],s[a+1][1]),f=new J(s[a+2][0],s[a+2][1]),d=h.distanceTo(c)/2,p=f.distanceTo(c)/2,m=c.clone(),g=c.clone();m.add(h.clone().sub(c).normalize().multiplyScalar(d>i?i/2:d)),g.add(f.clone().sub(c).normalize().multiplyScalar(p>i?i/2:p));let x=[[m.x,m.y],[c.x,c.y],[g.x,g.y]];u.push(...Se(x,i/25))}return u.push(s[s.length-1]),Hn(u)}function Hn(o){if(o.length<=1)return o;let n=[],t;return o.forEach(([e,r])=>{t?e===t[0]&&r===t[1]||(t=[e,r],n.push([e,r])):(t=[e,r],n.push([e,r]))}),n}function Te(o,n,t){let e=Math.sqrt((t[0]-n[0])**2+(t[1]-n[1])**2);if(e===0)return{distance:Math.sqrt((o[0]-n[0])**2+(o[1]-n[1])**2),closestPoint:n.slice(0)};let r=Math.max(0,Math.min(1,((o[0]-n[0])*(t[0]-n[0])+(o[1]-n[1])*(t[1]-n[1]))/e**2)),i=[n[0]+r*(t[0]-n[0]),n[1]+r*(t[1]-n[1])];return{distance:Math.sqrt((o[0]-i[0])**2+(o[1]-i[1])**2),closestPoint:i}}function Ce(o,n,t){let[e,r]=o,[i,s]=n,l=Math.sqrt(Math.pow(i-e,2)+Math.pow(s-r,2)),u=t/l,a=e+(i-e)*u,h=r+(s-r)*u;return[a,h]}var Wn=(a=>(a.START="start",a.END="end",a.FRONT="front",a.RIGHT="right",a.LEFT="left",a.RIGHT_FRONT="right_front",a.LEFT_FRONT="left_front",a.RIGHT_BACK="right_back",a.LEFT_BACK="left_back",a))(Wn||{});function Xn(o,n,t){let e=pe(o,n,t);return 180-Math.abs(e)<15?"front":e>135?"right_front":e<-135?"left_front":e<=135&&e>=60?"right":e>=-135&&e<=-60?"left":e<60&&e>0?"right_back":e>-60&&e<0?"left_back":"front"}function go(o){let n=[{direction:"start",distance:M(o[0],o[1]),points:[o[0],o[1]]}];for(let t=2;t<o.length;t++){let e=Xn(o[t-2],o[t-1],o[t]);if(e==="front"){let r=n[n.length-1],i=M(o[t-1],o[t]);r.distance+=i,t!==2&&r.points.push(o[t-1])}else n.push({direction:e,distance:M(o[t-1],o[t]),points:[o[t-1],o[t]]})}return n.push({direction:"end",distance:0,points:[o[o.length-1]]}),n}var I=Qt(Ve(),1);var He=class{constructor(n=3){this.lift_priority=n}roadInfo=[];pointMap=new Map;nodeMap=new Map;facilityMap=new Map;straightLadderMap=new Map;escalatorMap=new Map;staircaseMap=new Map;lineMap=new Map;baseRoute=new I.default;escalatorRoute=new I.default;straightLadderRoute=new I.default;initRoute(n){this.clear(),this.roadInfo=n,n.length&&(n.forEach(t=>{t.points.forEach(e=>{let r=`${t.floor}-${e.id}`;if(this.pointMap.set(r,e),this.nodeMap.set(`${e.floor}-${e.nodeId}`,r),e.type==="straightLadder"){let i=this.straightLadderMap.get(e.name)||[];i.push({...e}),this.straightLadderMap.set(e.name,i)}if(e.type==="staircase"){let i=this.staircaseMap.get(e.name)||[];i.push({...e}),this.staircaseMap.set(e.name,i)}if(e.type==="escalator"){let i=this.escalatorMap.get(e.name)||{};e.escalatorDirection==="exit"?i.end={floor:e.floor,id:e.id}:i.start={floor:e.floor,id:e.id},this.escalatorMap.set(e.name,i)}if(e.type==="facility"){let i=this.facilityMap.get(e.targetId)||[];i.push({...e}),this.facilityMap.set(e.targetId,i)}}),t.lines.filter(e=>e.direction!=="no").forEach(e=>{let r=`${t.floor}-${e.from}`,i=`${t.floor}-${e.to}`,s=this.pointMap.get(r)?.cds,l=this.pointMap.get(i)?.cds;if(s?.length&&l?.length){let u=M(s,l);this.addLineItem(r,i,u),e.direction==="double"&&this.addLineItem(i,r,u)}})}),this.initBaseRoute(),this.initEscalatorRoute(),this.initStraightLadderRoute())}addLineItem(n,t,e,r=this.lineMap){let i=r.get(n)||new Map;i.set(t,e),r.set(n,i)}addFacilityToLineMap(n,t,e,r){[...this.straightLadderMap,...this.staircaseMap].forEach(([i,s])=>{if(!(s.length<2))for(let l=0;l<s.length;l++){let u=`${s[l].floor}-${s[l].id}`;for(let a=0;a<s.length;a++)if(l!==a){let h=`${s[a].floor}-${s[a].id}`,c=this.pointMap.get(u)?.cds,f=this.pointMap.get(h)?.cds;if(c?.length&&f?.length)if(s[l].type==="straightLadder"){let d=t;this.addLineItem(u,h,d,r)}else{let d=e;this.addLineItem(u,h,d,r)}}}}),this.escalatorMap.forEach((i,s)=>{if(i.start&&i.end){let l=`${i.start.floor}-${i.start.id}`,u=`${i.end.floor}-${i.end.id}`,a=this.pointMap.get(l)?.cds,h=this.pointMap.get(u)?.cds;if(a?.length&&h?.length){let c=n;this.addLineItem(l,u,c,r)}}})}initBaseRoute(){let n=new Map([...this.lineMap]);this.addFacilityToLineMap(1,this.lift_priority,3e4,n),this.baseRoute=new I.default(n)}initEscalatorRoute(){let n=new Map([...this.lineMap]),t=1e4;this.addFacilityToLineMap(1*t,this.lift_priority*t,3e4*t,n),this.escalatorRoute=new I.default(n)}initStraightLadderRoute(){let n=new Map([...this.lineMap]),t=1e4;this.addFacilityToLineMap(3*t,1*t,3e4*t,n),this.straightLadderRoute=new I.default(n)}checkStart(n){return!(!n.floor||!n.nodeId&&(!n.coord||n.coord.length<2))}checkEnd(n){return n.facility?!0:this.checkStart(n)}transformStart(n){if(n.nodeId){let t=this.nodeMap.get(`${n.floor}-${n.nodeId}`);if(t){let[e,r]=t.split("-");return{floor:e,id:r}}}if(n.coord?.length){let t=this.roadInfo.find(r=>r.floor===n.floor);if(!t)return null;let e=t.points.reduce((r,i)=>{let s=M(n.coord,i.cds);return s<r.min&&(r.min=s,r.point=i),r},{min:1/0,point:t.points[0]});return{floor:e.point.floor,id:e.point.id}}return null}transformEnd(n){if(n.floor){let t=this.transformStart(n);if(t)return t}return n.facility&&this.facilityMap.get(n.facility)?.length?{floor:n.floor,facility:n.facility}:null}getPath(n,t,e=""){if(!this.checkStart(n))return"start-error";if(!this.checkEnd(t))return"end-error";let r=this.transformStart(n);if(!r)return"no-start";let i=this.transformEnd(t);if(!i)return"no-end";let s=this.getBasePath.bind(this);switch(e){case"escalator":s=this.getEscalatorPath.bind(this);case"straightLadder":s=this.getStraightLadderPath.bind(this);default:s=this.getBasePath.bind(this)}if(i.id)return s(r,i);if(i.facility){let l=this.facilityMap.get(i.facility).filter(a=>i.floor?a.floor===i.floor:!0);if(!l.length)return null;let u=l.map(a=>s(r,{floor:a.floor,id:a.id})).filter(a=>!!a);return u.reduce((a,h)=>{let c=h.reduce((f,d)=>f+at(d.points),0);return c<a.distance&&(a.distance=c,a.path=h),a},{distance:1/0,path:u[0]}).path}}getRoutePath(n,t,e){let r=`${n.floor}-${n.id}`,i=`${t.floor}-${t.id}`,s=e.path(r,i);if(!s)return null;let l=[];return s.map(u=>{let a=this.pointMap.get(u);if(a){let{floor:h}=a;if(l[l.length-1]?.floor===h){let c=l[l.length-1];c.points.push(a.cds),c.endType=a.type,c.destId=a.nodeId}else l.push({floor:h,points:[a.cds],endType:a.type,destId:a.nodeId})}}),l}getBasePath(n,t){return this.getRoutePath(n,t,this.baseRoute)}getEscalatorPath(n,t){return this.getRoutePath(n,t,this.escalatorRoute)}getStraightLadderPath(n,t){return this.getRoutePath(n,t,this.straightLadderRoute)}clear(){this.roadInfo=[],this.pointMap.clear(),this.nodeMap.clear(),this.facilityMap.clear(),this.straightLadderMap.clear(),this.escalatorMap.clear(),this.staircaseMap.clear(),this.lineMap.clear(),this.baseRoute=new I.default,this.escalatorRoute=new I.default,this.straightLadderRoute=new I.default}};function We(o){return o.replace(/[A-Z]/g,n=>"_"+n.toLowerCase()).replace(/^_/,"")}var Xe=new j;function Q(o,n,t){return new Promise((e,r)=>{let i=Xe.genUniqueKey(),s=({data:l})=>{l.type===`${n}_result`&&l.key===i&&(Xe.removeKey(i),self.removeEventListener("message",s),l.error?r(l.error):e(l.data))};o.addEventListener("message",s),o.postMessage({type:n,key:i,data:t})})}function Co(o){let n={};for(let e in o)e.startsWith("on")&&(n[We(e.slice(2))]=o[e]);let t=async({data:e})=>{if(n[e.type])try{let r=await n[e.type](e.data);self.postMessage({type:`${e.type}_result`,key:e.key,data:r})}catch(r){self.postMessage({type:`${e.type}_result`,key:e.key,error:r})}else self.postMessage({type:`${e.type}_result`,key:e.key,error:"no_event"})};return self.addEventListener("message",t),()=>{self.removeEventListener("message",t)}}import{EventDispatcher as Zr,Box2 as Kr,Vector3 as F,Vector2 as Z,Raycaster as $r,Box3 as Jr,Color as Qr,AmbientLight as ti}from"three";import{Group as ei,Tween as Dt}from"@tweenjs/tween.js";import{EventDispatcher as kr}from"three";import{Object3D as Zn,ExtrudeGeometry as Kn,Mesh as $n,Box3 as dt,Vector3 as R,BufferGeometry as Jn,LineSegments as Qn,Ray as qe}from"three";var tr={id:"",height:.1,airHeight:0,area:0,group:"",fillColor:"#EFF4FB",strokeColor:"#ffffff",fillOpacity:1,strokeOpacity:1,strokeWidth:1,doors:[],locked:!1,visible:!0,geometry:{type:"polygon",cds:[],coords:[],curveCpt:[],curveIndex:[]},layerType:"",zIndex:0,stroke:!0,deltaHeight:0,userData:{},gradualColor:[],renderType:"single",colorFactor:.9},S=class extends Zn{constructor(t,e){super();this.context=t;if(this.options=X({...tr,...e},this),this.options.geometry.type==="point"){let[r,i]=this.options.geometry.coords;return this.position.set(r,i,this.options.height+this.options.airHeight),this}this.init(),this.visible=this.options.visible,this.addEventListener("change-fillColor",({value:r})=>{this.initMaterial(),this.initMesh()}),this.addEventListener("change-fillOpacity",({value:r})=>{this.initMaterial(),this.initMesh()}),this.addEventListener("change-height",({value:r})=>{this.dispose(),this.init()}),this.addEventListener("change-strokeColor",({value:r})=>{this.options.stroke&&(this.initLineMaterial(),this.createBorder())}),this.addEventListener("change-strokeOpacity",({value:r})=>{this.options.stroke&&(this.initLineMaterial(),this.createBorder())}),this.addEventListener("change-airHeight",({value:r})=>{this.position.z=r}),this.addEventListener("change-visible",({value:r})=>{this.visible=r}),this.addEventListener("change-stroke",({value:r})=>{if(r){if(this.line)return;this.initLineGeometry(),this.initLineMaterial(),this.createBorder()}else this.line&&(this.remove(this.line),this.lineGeometry?.dispose())}),this.addEventListener("change-renderType",()=>{this.initMaterial(),this.initMesh()}),this.addEventListener("change-gradualColor",()=>{this.initMaterial(),this.initMesh()})}geometry;material;mesh;line;lineMaterial;lineGeometry;options;getCenter(){if(this.options.geometry.type==="point")return this.position.clone();let t=new R,e=new dt;return e.setFromObject(this),e.getCenter(t),t}getSize(){if(this.options.geometry.type==="point")return new R(0,0,0);let t=new dt,e=new R;return t.setFromObject(this),t.getSize(e),e}getPosition(){let t=this.getCenter();return t.setZ(t.z+this.options.height/2),t}init(){this.geometry=this.initGeometry(),this.initMaterial(),this.initMesh(),this.mesh.position.z=this.options.airHeight+this.options.deltaHeight,this.options.stroke&&(this.initLineMaterial(),this.initLineGeometry(),this.createBorder())}initGeometry(){let t=se(this.options.geometry.coords[0],this.options.geometry.coords.slice(1));return new Kn(t,{steps:1,bevelEnabled:!1,depth:this.options.height,curveSegments:4})}initSingleMaterial(){let t=this.context.materialFactory.createMeshBasicMaterial({color:this.options.fillColor,opacity:this.options.fillOpacity});if(this.options.height<=.1)return this.material=t,t;let e=this.context.materialFactory.createMeshBasicMaterial({color:ht(this.options.fillColor),opacity:this.options.fillOpacity});return this.material=[t,e],[t,e]}getMaxAndMin(t,e){let r=new dt().setFromObject(this),i=t.clone().add(e.clone().multiplyScalar(1e3)),s=new qe(i,e.clone().multiplyScalar(-1)),l=new R;s.intersectBox(r,l);let u=t.clone().add(e.clone().multiplyScalar(-1e3)),a=new qe(u,e.clone()),h=new R;return a.intersectBox(r,h),{max:h,min:l}}initGradualMaterial(){let{max:t,min:e}=new dt().setFromObject(this),r=t.clone().sub(e),i=Math.max(r.x,r.y,r.z)/2,s=this.getPosition(),l=new R(-1,.2,0).normalize(),{max:u,min:a}=this.getMaxAndMin(s,l),h=this.context.materialFactory.createShaderMaterial({gradualColor:this.options.gradualColor,center:this.getPosition(),maxValue:i,opacity:this.options.fillOpacity,direction:new R(-1,.2,0),max:u,min:a});if(this.options.height<=.1)return this.material=h,h;let c=this.getCenter(),f=new R(-1,.2,1).normalize(),{max:d,min:p}=this.getMaxAndMin(c,f),m=this.context.materialFactory.createShaderMaterial({gradualColor:[ht(this.options.gradualColor[0],this.options.colorFactor),ht(this.options.gradualColor[1],this.options.colorFactor)],center:this.getCenter(),maxValue:i,opacity:this.options.fillOpacity,direction:new R(-1,.2,1),max:d,min:p});return this.material=[h,m],[h,m]}initMaterial(){return this.options.renderType==="gradual"?this.initGradualMaterial():this.initSingleMaterial()}initLineMaterial(){let t=this.context.materialFactory.createLineMaterial({color:this.options.strokeColor,opacity:this.options.strokeOpacity});return this.lineMaterial=t,t}initMesh(){this.mesh&&this.remove(this.mesh),this.mesh=new $n(this.geometry,this.material),this.add(this.mesh)}getBorderPoints(){let t=[],e=this.options.height+this.options.deltaHeight,{coords:r}=this.options.geometry;for(let i=0;i<r.length;i++){let s=r[i];for(let l=0;l<s.length;l++){let u=s[l],a=l+1===s.length?s[0]:s[l+1];t.push(new R(u[0],u[1],e)),t.push(new R(a[0],a[1],e))}}return t}initLineGeometry(){this.lineGeometry&&this.lineGeometry.dispose();let t=this.getBorderPoints(),e=new Jn().setFromPoints(t);this.lineGeometry=e}createBorder(){this.line&&this.remove(this.line);let t=new Qn(this.lineGeometry,this.lineMaterial);return t.position.z=this.options.airHeight+.01,this.line=t,this.add(t),t}raycast(t){if(!this.visible||this.options.geometry.type==="point")return!1;this.mesh.updateMatrixWorld(!0);let e=t.intersectObject(this.mesh);if(e[0]){let{point:r,distance:i}=e[0];return{position:r,distance:i}}return!1}dispose(){this.geometry.dispose(),this.line?.geometry.dispose(),this.clear()}};import{Object3D as er,PlaneGeometry as nr,Mesh as rr,ShadowMaterial as ir,Color as or,DoubleSide as sr}from"three";var gt=class extends er{directionalLight;plane;basicOpacity=.07;constructor(){super(),this.directionalLight=this.initLight(),this.initPlane()}initLight(){let n=ae(16777215,.5);return n.position.set(0,0,100),this.add(n),n}changeLightCamera(n){let t=n.x,e=n.y;this.directionalLight.shadow.camera.left=-t,this.directionalLight.shadow.camera.right=t,this.directionalLight.shadow.camera.top=e,this.directionalLight.shadow.camera.bottom=-e,this.directionalLight.shadow.camera.near=.5,this.directionalLight.shadow.camera.far=Math.max(t,e)}changeLightColor(n){this.directionalLight.color=new or(n)}setPosition(n){this.position.copy(n),this.directionalLight.position.set(-n.x/2,-n.y/2,100)}initPlane(n=1e3,t=1e3){let e=new nr(n,t),r=new ir({transparent:!0,opacity:0,side:sr}),i=new rr(e,r);return i.receiveShadow=!0,i.position.z=-10,this.add(i),this.plane=i,i}setTarget(n){this.directionalLight.target=n}transformOpacity(n){return n*this.basicOpacity}setOpacity(n){this.plane.material.opacity=this.transformOpacity(n)}dispose(){O(this,!0)}};import{EventDispatcher as hr,Vector3 as cr}from"three";import{Box3 as je,EventDispatcher as ar,Vector3 as _}from"three";import{debounce as lr}from"lodash";var ur={autoUpdate:!0,appendToBody:!1,autoChangePlacement:!1},mt=class extends ar{constructor(t,e={}){super();this.context=t;this.options={...ur,...e},this.registryEvent(),this.div=this.initDiv(),this.options.appendToBody?document.body.appendChild(this.div):this.context.container.appendChild(this.div)}div;element;position=new _;clientPos={x:0,y:0};visible=!0;options;placement="top";observer=null;initObserver(){let t=new MutationObserver(lr(()=>{this.div&&this.usePlacement()},100));t.observe(this.div,{childList:!0,subtree:!0,attributes:!0}),this.observer=t}getPlacementPosition(){if(this.element instanceof S&&this.element.options.geometry.type==="polygon"){let{max:i,min:s}=new je().setFromObject(this.element),l=(i.x+s.x)/2,u=(i.y+s.y)/2;return{left:new _(s.x,u,i.z),leftTop:new _(s.x,i.y,i.z),top:new _(l,i.y,i.z),rightTop:new _(i.x,i.y,i.z),right:new _(i.x,u,i.z),rightBottom:new _(i.x,s.y,i.z),bottom:new _(l,s.y,i.z),leftBottom:new _(s.x,s.y,i.z),center:new _(l,u,i.z)}}let{x:t,y:e,z:r}=this.element?.getPosition?.()||this.position;return{left:new _(t,e,r),leftTop:new _(t,e,r),top:new _(t,e,r),rightTop:new _(t,e,r),right:new _(t,e,r),rightBottom:new _(t,e,r),bottom:new _(t,e,r),leftBottom:new _(t,e,r),center:new _(t,e,r)}}getPlacementScreenPosition(){let{width:t,height:e}=this.context.clientSize,r=this.getPlacementPosition();return Object.keys(r).reduce((i,s)=>{let{x:l,y:u}=y(r[s],this.context.camera,t,e);return i[s]={x:l,y:u},i},{})}checkOverflow(t,e){let{width:r,height:i}=this.context.clientSize;return e.x>0&&t.x<r&&e.y<i&&t.y>0}getPlacement(){let{clientWidth:t,clientHeight:e}=this.div,r=this.getPlacementScreenPosition(),i=t/2,s=e/2,l=[{type:"center",getBox(u,a){return{max:{x:i+u,y:a-e},min:{x:u-i,y:a}}}},{type:"left",getBox(u,a){return{max:{x:u,y:a-s},min:{x:u-t,y:a+s}}}},{type:"leftTop",getBox(u,a){return{max:{x:u,y:a-e},min:{x:u-t,y:a}}}},{type:"top",getBox(u,a){return{max:{x:u+i,y:a-e},min:{x:u-i,y:a}}}},{type:"rightTop",getBox(u,a){return{max:{x:u+t,y:a-e},min:{x:u,y:a}}}},{type:"right",getBox(u,a){return{max:{x:u+t,y:a-s},min:{x:u,y:a+s}}}},{type:"rightBottom",getBox(u,a){return{max:{x:u+t,y:a},min:{x:u,y:a+e}}}},{type:"bottom",getBox(u,a){return{max:{x:u+i,y:a},min:{x:u-i,y:a+e}}}},{type:"leftBottom",getBox(u,a){return{max:{x:u,y:a},min:{x:u-t,y:a+s}}}}];for(let u=0;u<l.length;u++){let a=l[u],h=r[a.type],{max:c,min:f}=a.getBox(h.x,h.y);if(this.checkOverflow(c,f))return{type:a.type,position:h}}return{type:"center",position:r.center}}initDiv(){let t=document.createElement("div");return t.style.position="absolute",t}usePlacement(){let t=this.getPlacement();this.div.className=`overlay_${t.type}`,this._updatePosition(t.position.x,t.position.y)}bindElement(t){this.element=t,this.options.autoChangePlacement&&this.initObserver(),this.onUpdate()}unBindElement(){this.element=void 0}setVisible(t,e="block"){t!==this.visible&&(this.div.style.display=t?e:"none",this.visible=t)}setOpacity(t){this.div.style.opacity=`${t}`}getPosition(){return this.element?typeof this.element.getPosition=="function"?this.element.getPosition():new je().setFromObject(this.element).getCenter(new _):this.position}get withinDisplayRange(){let{x:t,y:e}=this.clientPos,{width:r,height:i}=this.context.clientSize;return t>=0&&t<=r&&e>=0&&e<=i}_updatePosition(t,e){this.clientPos={x:t,y:e};let{width:r,height:i,x:s,y:l}=this.context.clientSize;this.options.appendToBody&&(this.div.style.left=`${s}px`,this.div.style.top=`${l+i}px`),this.options.autoUpdate?this.div.style.transform=`translate3d(${t}px, ${-i+e}px, 0)`:this.dispatchEvent({type:"update-position",x:t,y:e,width:r,height:i})}updatePosition(t=!1){let e=this.getPosition(),{width:r,height:i}=this.context.clientSize,{x:s,y:l}=y(e,this.context.camera,r,i);this.clientPos.x===s&&this.clientPos.y===l&&!t||this._updatePosition(s,l)}onUpdate=()=>{this.options.autoChangePlacement?this.usePlacement():this.updatePosition()};registryEvent(){this.context.addEventListener("update",this.onUpdate)}unRegistryEvent(){this.context.removeEventListener("update",this.onUpdate)}dispose(){this.unRegistryEvent(),this.unBindElement(),this.observer?.disconnect(),this.div?.remove(),this.div=null}};var pr={texts:[{text:""}],level:1,icon_position:"bottom",collision_enable:!0,opacity:1,id:"",position:{x:0,y:0,z:0},icon_opacity:1,icon_border:{color:"#586EE0",width:0},background:"",collision_hide_icon:!0,built_in:!1,box_only_icon:!1},tt=class extends hr{constructor(t,e){super();this.context=t;this.options=X({...pr,...e},this),this.position.set(e.position?.x||0,e.position?.y||0,e.position?.z||0),this.overlay=new mt(this.context,{autoUpdate:!1}),this.overlay.addEventListener("update-position",({x:r,y:i,height:s})=>{this.overlay.div.style.transform=`translate3d(calc(${r}px - 50%), calc(${-s+i}px - ${this.options.icon&&this.options.icon_position!=="center"?"100%":"50%"}), 0)`}),this.overlay.bindElement(this),this.registryEvent(),this.initDiv(),this.addEventListener("change-icon",({value:r})=>{r?this.img?this.img.setAttribute("src",r):(this.addIcon(),this._changePosition()):(this.img&&this.div.removeChild(this.img),this.img=void 0,this._changePosition(),this.resetSize())}),this.addEventListener("change-texts",({value:r})=>{this.div.removeChild(this.textDiv),this.addText(),this.resetSize()}),this.addEventListener("change-opacity",({value:r})=>{this.overlay.setOpacity(r)}),this.addEventListener("change-icon_size",({value:r})=>{this.img&&(this.img.style.width=`${r?.[0]||32}px`,this.img.style.height=`${r?.[1]||32}px`,this.resetSize())}),this.addEventListener("change-icon_opacity",({value:r})=>{this.img&&(this.img.style.opacity=`${r}`)}),this.addEventListener("change-icon_border",({value:r})=>{this.img&&(this.img.style.border=`${r.width}px solid ${r.color}`)}),this.addEventListener("change-background",({value:r})=>{this.div.style.background=r})}div;textDiv;img;overlay;options;visible=!0;size={width:0,height:0};position=new cr;userData={};showTextStatus=!0;disposed=!1;get withinDisplayRange(){return this.overlay.withinDisplayRange}async resetSize(){if(await de(),!this.disposed)if(this.options.box_only_icon){if(!this.img)return;let{width:t,height:e}=this.img.getBoundingClientRect();this.size={width:t+2,height:e+2}}else{let{width:t,height:e}=this.div.getBoundingClientRect();this.size={width:t+2,height:e+2}}}renderHelperBox(){}get clientPos(){return this.overlay.clientPos}initDiv(){let t=document.createElement("div");return this.div=t,this.addText(),this.options.icon&&this.addIcon(),t.style.fontSize="12px",t.style.textShadow="#fff 1px 0 0, #fff 0 1px 0, #fff -1px 0 0, #fff 0 -1px 0",t.style.display="flex",t.style.flexDirection="column",t.style.justifyContent="center",t.style.alignItems="center",t.style.padding="4px",this.overlay.setOpacity(this.options.opacity),this.overlay.div.style.pointerEvents="none",this.overlay.div.style.userSelect="none",this.overlay.div.appendChild(t),this.resetSize(),t}addIcon(){if(!this.img){let t=this.initIcon();this.options.icon_position==="top"?this.div.firstChild?this.div.insertBefore(t,this.div.firstChild):this.div.appendChild(t):this.div.appendChild(t)}}addText(){let t=this.initText();this.options.icon_position==="top"?this.div.appendChild(t):this.div.firstChild?this.div.insertBefore(t,this.div.firstChild):this.div.appendChild(t)}getPosition(){return this.position}initText(){let t=document.createElement("div");return t.appendChild(this.createTextFragment()),t.style.textAlign="center",this.textDiv=t,t}createTextFragment(){let t=document.createDocumentFragment();return this.options.texts.forEach(e=>{let r=document.createElement("div");if(r.style.whiteSpace="nowrap",e.styles)for(let[i,s]of Object.entries(e.styles))r.style[i]=s;r.textContent=e.text,t.appendChild(r)}),t}initIcon(){let t=document.createElement("img");return t.setAttribute("src",this.options.icon),t.style.width=`${this.options.icon_size?.[0]||32}px`,t.style.height=`${this.options.icon_size?.[1]||32}px`,t.style.opacity=`${this.options.icon_opacity}px`,t.style.borderRadius="50%",this.options.icon_border.width&&(t.style.border=`${this.options.icon_border.width}px solid ${this.options.icon_border.color}`),t.onload=()=>{this.resetSize()},this.img=t,t}_changePosition=()=>{this.overlay.updatePosition(!0)};registryEvent(){}unRegistryEvent(){}setVisible(t){t!==this.visible&&(this.visible=t,this.changeOverlayVisible(t))}changeOverlayVisible(t){if(!(t===this.overlay.visible&&this.options.collision_hide_icon))if(this.options.collision_hide_icon)this.overlay.visible=t,this.overlay.div.style.visibility=t?"visible":"hidden";else{if(this.showTextStatus===t)return;this.textDiv.style.visibility=t?"visible":"hidden",this.showTextStatus=t}}parentSetVisible(t){this.visible&&this.changeOverlayVisible(t)}getBox(t=this.context.config.poi.boxScale){let{width:e,height:r}=this.size,i=e*t,s=r*t,{x:l,y:u}=this.overlay.clientPos;return{left:l-i/2,right:l+i/2,top:this.options.icon?u-s:u-s/2,bottom:this.options.icon?u:u+s/2}}getOriginBox(){return this.getBox(1)}isContain(t,e){if(!this.overlay.visible||!this.visible)return!1;let r=this.getOriginBox();return t>=r.left&&t<=r.right&&e>=r.top&&e<=r.bottom}dispose(){this.unRegistryEvent(),this.div=null,this.textDiv=null,this.img=void 0,this.overlay.dispose(),this.disposed=!0}};import{Box3 as bt,Group as Fr,Object3D as qt,Vector3 as Mt}from"three";import{Box3 as dr,Vector3 as gr}from"three";import{Object3D as fr}from"three";var Y=class extends fr{constructor(t){super();this.context=t}dispose(){O(this),this.clear()}};var yt=class extends Y{graphicMap=new Map;constructor(n){super(n)}getCenter(){return new dr().setFromObject(this).getCenter(new gr)}createGraphic(n){let t=new S(this.context,n);return this.add(t),this.graphicMap.set(n.id,t),t}removeGraphic(n){this.remove(n),this.graphicMap.delete(n.options.id),n.dispose()}removeGraphicById(n){this.graphicMap.has(n)&&this.removeGraphic(this.graphicMap.get(n))}getGraphicByNodeId(n){return this.graphicMap.get(n)||null}getGraphicByRaycaster(n){let t={distance:1e4,graphic:null,position:null},e=this.children.reduce((r,i)=>{if(i instanceof S){let s=i.raycast(n);if(s){let{distance:l}=s;if(l<r.distance)return{distance:s.distance,position:s.position,graphic:i}}return r}else return r},t);return e===t?{graphics:[],position:null}:{graphics:[e.graphic],position:e.position}}};import{debounce as mr}from"lodash";var _t=class extends Y{pois=[];debounceCollisionDetection;timer=new L;constructor(n){super(n),this.registryEvent(),this.debounceCollisionDetection=mr(this.collisionDetection,10)}clear(n=!1){return this.pois.forEach(t=>{t.options.built_in&&!n||t.dispose()}),this.pois=n?[]:this.pois.filter(t=>t.options.built_in),this}createPoi(n){let t=new tt(this.context,n);return this.pushPoi(t),t.addEventListener("change-level",()=>this.changePoiLevelOrCollisionEnable(t)),t.addEventListener("change-collision_enable",()=>this.changePoiLevelOrCollisionEnable(t)),Promise.resolve().then(()=>{this.debounceCollisionDetection()}),t}changePoiLevelOrCollisionEnable(n){let t=this.pois.findIndex(e=>e===n);t!==-1&&(this.pois.splice(t,1),this.pushPoi(n))}removePoi(n){let t=this.pois.findIndex(e=>e===n);t!==-1&&(this.pois.splice(t,1),n.dispose())}removePoiById(n){let t=this.pois.find(e=>e.options.id===n);t&&this.removePoi(t)}getPoiById(n){return this.pois.find(e=>e.options.id===n)||null}pushPoi(n){if(!n.options.collision_enable){this.pois.unshift(n);return}if(n.options.level===0){this.pois.push(n);return}for(let t=0;t<this.pois.length;t++){let e=this.pois[t];if(e.options.collision_enable&&e.options.level<=n.options.level){this.pois.splice(t,0,n);return}}this.pois.push(n)}getPoiByDeviceXy(n,t){return this.pois.filter(r=>r instanceof tt&&r.isContain(n,t))}onUpdate=()=>{this.timer.requestAnimationFrame(()=>{this.collisionDetection()})};collisionDetection(){let n=[];this.pois.filter(e=>e.visible&&e.withinDisplayRange).forEach((e,r)=>{let{left:i,right:s,top:l,bottom:u}=e.getBox();if(r===0||!e.options.collision_enable){n.push({left:i,right:s,top:l,bottom:u}),e.parentSetVisible(!0);return}let a=n.some(h=>h.left<s&&h.right>i&&h.top<u&&h.bottom>l);e.parentSetVisible(!a),a||n.push({left:i,right:s,top:l,bottom:u})})}registryEvent(){this.context.addEventListener("update",this.onUpdate)}unRegistryEvent(){this.context.removeEventListener("update",this.onUpdate)}dispose(){this.timer.dispose(),this.pois.forEach(n=>n.dispose()),this.pois.length=0,this.debounceCollisionDetection=()=>{},super.dispose(),this.unRegistryEvent()}};import{MeshBasicMaterial as yr,Object3D as _r,PlaneGeometry as vr,Texture as xr,DoubleSide as Er,Mesh as br,Matrix3 as Ye,Vector2 as Mr}from"three";import{create as Sr}from"@mars3d/heatmap.js";import{featureCollection as wr,point as Tr,bbox as Cr,center as Pr}from"@turf/turf";var vt=class extends _r{constructor(t){super();this.context=t;this.div=document.createElement("div")}heatmap;div;plane;clearHeatmap(){this.div.firstChild&&this.div.removeChild(this.div.firstChild),this.heatmap=void 0}loadData(t){this.clearHeatmap();let{width:e,height:r,leftTop:i,center:s}=this.getBox(t);this.heatmap=Sr({width:e,height:r,container:this.div,...this.context.config.heatMap}),this.heatmap.setData(this.transformData(t,i)),this.initPlane(e,r),this.position.set(s[0],s[1],this.position.z)}initPlane(t,e){this.plane&&this.remove(this.plane);let r=new vr(t,e),i=new xr(this.div.firstChild);i.needsUpdate=!0;let s=new yr({transparent:!0,side:Er,map:i});s.needsUpdate=!0,this.plane=new br(r,s),this.add(this.plane)}getTransMatrix({x:t,y:e}){return new Ye().makeScale(1,-1).multiply(new Ye().makeTranslation(0-t,0-e))}transformData(t,e){let r=this.getTransMatrix(e);return{data:t.data.map(s=>{let l=new Mr(s.x,s.y).applyMatrix3(r);return{x:l.x,y:l.y,value:s.value}}),max:t.max,min:t.min}}getBox(t){let e=wr(t.data.map(a=>Tr([a.x,a.y]))),r=Cr(e),i=r[2]-r[0],s=r[3]-r[1],l={x:r[0],y:r[3]},u=Pr(e);return{width:i,height:s,leftTop:l,center:u.geometry.coordinates}}dispose(){this.div=null,this.heatmap=void 0}};import{Box3 as Ar,Object3D as Rr,Vector3 as Ze}from"three";var xt=class extends Rr{constructor(t,e){super();this.context=t;this.options=e;this.position.copy(e.position||new Ze(0,0,0)),this.loadModel()}poi=null;model=null;async loadModel(){let t=await ge(this.options.modelUrl);t.scene.rotation.set(Math.PI/2,Math.PI/2,0),this.add(t.scene),this.model=t,this.initPoi()}initPoi(){if(!this.options.icon)return;let t=this.context.currentFloor?.addPoi({icon:this.options.icon,icon_size:this.options.icon_size,built_in:!0,level:0});this.poi=t||null,this.model&&t&&(t.position=new Ar().setFromObject(this).getCenter(new Ze))}dispose(){O(this),this.model=null,this.poi&&(this.context.currentFloor?.poiLayer.removePoi(this.poi),this.poi=null)}};import{Euler as Lr,Mesh as Ir,Object3D as Nr,PlaneGeometry as Or}from"three";var Dr={uuid:"",url:"",name:"",angleX:0,angleY:0,angleZ:0,width:0,height:0,center:[0,0],opacity:1,visible:!0},Et=class extends Nr{constructor(t,e){super();this.context=t;this.options=X({...Dr,...e},this),this.init()}options;mesh;async init(){let{width:t,height:e,center:r,url:i,opacity:s,angleX:l,angleY:u,angleZ:a}=this.options,h=new Or(t,e),c=await this.context.materialFactory.createGroundTextureMaterial({url:i,opacity:s}),f=new Ir(h,c);this.mesh=f,this.mesh.position.set(r[0],r[1],0),f.setRotationFromEuler(new Lr(l,u,a)),this.add(f)}dispose(){this.mesh?.geometry.dispose(),this.clear()}};var St=class extends qt{constructor(t){super();this.context=t;this.graphicLayer=new yt(this.context),this.poiLayer=new _t(this.context),this.groundUpper.add(this.graphicLayer),this.groundUpper.add(this.poiLayer),this.groundUpper.add(this.groundTextures),this.add(this.groundUpper),this.add(this.models)}graphicLayer;poiLayer;grounds=new Set;shadow=new gt;heatmap;groundUpper=new qt;models=new qt;modelMap=new Map;groundTextures=new Fr;groundMaxHeight=0;name="";key="";getPosition(){return new bt().setFromObject(this.groundUpper).getCenter(new Mt)}createGround(t){let e=new S(this.context,t);this.addGrounds([e])}addGrounds(t){t.forEach(e=>{this.grounds.has(e)||(e.mesh.castShadow=!0,this.grounds.add(e),this.groundUpper.add(e))}),this.changeGroundMaxHeight()}changeGroundMaxHeight(){let t=Array.from(this.grounds);this.groundMaxHeight=this.grounds.size>0?Math.max(...t.map(e=>e.options.height+e.options.airHeight+e.options.deltaHeight)):0,this.graphicLayer.position.z=this.groundMaxHeight,this.models.position.z=this.groundMaxHeight}get hasElement(){return!!(this.grounds.size||this.graphicLayer.children.length)}getCenter(){return new bt().setFromObject(this.groundUpper).getCenter(new Mt)}addModel(t){let e=new xt(this.context,t);return this.models.add(e),this.modelMap.set(t.id,e),e}addShadow(){let t=new bt().setFromObject(this.groundUpper),e=t.getCenter(new Mt),r=t.getSize(new Mt);this.shadow.setPosition(e),this.shadow.changeLightCamera(r)}addGraphic(t){return this.graphicLayer.createGraphic(t)}addPoi(t){return this.poiLayer.createPoi(t)}addGroundTexture(t){let e=new Et(this.context,t);this.groundTextures.add(e)}addHeatmap(t){this.heatmap||(this.heatmap=new vt(this.context),this.add(this.heatmap)),this.heatmap.loadData(t);let e=new bt().setFromObject(this.graphicLayer);return this.heatmap.position.setZ(e.max.z),this.heatmap}removeHeatMap(){this.heatmap&&(this.remove(this.heatmap),this.heatmap.dispose(),this.heatmap=void 0)}setShadowOpacity(t){this.shadow.setOpacity(t)}setShadowVisible(t){this.shadow.visible=t}dispose(){this.shadow.dispose(),this.graphicLayer.dispose(),this.poiLayer.dispose(),this.grounds.forEach(t=>t.dispose()),this.groundTextures.children.forEach(t=>t.dispose()),this.groundTextures.clear(),this.heatmap?.dispose(),this.groundUpper.clear(),this.models.children.forEach(t=>t.dispose()),this.models.clear(),this.modelMap.clear(),this.clear()}};import{EventDispatcher as Ur,Vector3 as Br}from"three";var N=class extends Ur{constructor(t){super();this.context=t;this.svg=fe(`${t.container.clientWidth}`,`${t.container.clientHeight}`),t.container.appendChild(this.svg),this._registryEvent()}points=[];svg;enable=!0;_onResize=({width:t,height:e})=>{this.svg&&(this.svg.setAttribute("width",`${t}`),this.svg.setAttribute("height",`${e}`))};_registryEvent(){this.context.addEventListener("resize",this._onResize)}_unRegistryEvent(){this.context.removeEventListener("resize",this._onResize)}setEnable(t){this.enable=t,t?this.svg.style.display="block":this.svg.style.display="none"}getIntersectByPointerEvent(t){let{camera:e,renderer:r}=this.context,{offsetX:i,offsetY:s}=t,{clientWidth:l,clientHeight:u}=r.domElement,a=i/l*2-1,h=1-s/u*2;return new Br(a,h,0).unproject(e)}getSvgCoordinate(t){let{camera:e,container:r}=this.context;return y(t,e,r.clientWidth,r.clientHeight)}dispose(){this._unRegistryEvent(),this.context.container.removeChild(this.svg),this.svg=null}};var wt=class extends N{constructor(t){super(t);this.context=t;let{config:{svg:{circle:e,line:r}}}=t;this.circles=[K(e.radius,e.fill),K(e.radius,e.fill)],this.line=ut(r.stroke),this.svg.appendChild(this.circles[0]),this.svg.appendChild(this.circles[1]),this.svg.appendChild(this.line),this.registryEvent()}circles;line;setEnable(t){super.setEnable(t),t?this.registryEvent():this.unRegistryEvent()}registryEvent(){this.context.container.addEventListener("pointerenter",this.onPointermove),this.context.container.addEventListener("pointermove",this.onPointermove),this.context.container.addEventListener("pointerleave",this.onPointerleave),this.context.container.addEventListener("pointerdown",this.onPointerdown),this.context.addEventListener("update",this.onUpdate)}unRegistryEvent(){this.context.container.removeEventListener("pointerenter",this.onPointermove),this.context.container.removeEventListener("pointermove",this.onPointermove),this.context.container.removeEventListener("pointerleave",this.onPointerleave),this.context.container.removeEventListener("pointerdown",this.onPointerdown),this.context.removeEventListener("update",this.onUpdate)}onUpdate=()=>{if(this.points[0]){let t=this.getSvgCoordinate(this.points[0]);H(this.circles[0],t.x,t.y),C(this.line,t)}if(this.points[1]){let t=this.getSvgCoordinate(this.points[1]);H(this.circles[1],t.x,t.y),C(this.line,void 0,t)}};onPointermove=t=>{this.points.length===1&&(this.line.style.display="block",C(this.line,void 0,{x:t.offsetX,y:t.offsetY}))};onPointerleave=()=>{this.points[1]||(this.line.style.display="none")};onPointerdown=t=>{if(this.points[1])return;let e=this.getIntersectByPointerEvent(t);if(e){let{offsetX:r,offsetY:i}=t,s=this.circles[this.points.length];H(s,r,i),this.points.length||C(this.line,{x:r,y:i},{x:r,y:i}),this.addPoint(e)}};addPoint(t){if(this.points.push(t),this.points.length>=2){let e=this.calculatedDistance();this.dispatchEvent({type:"distance",distance:e})}}calculatedDistance(){let[{x:t,y:e},{x:r,y:i}]=this.points;return Math.sqrt((r-t)**2+(i-e)**2)}dispose(){super.dispose(),this.unRegistryEvent(),this.line=null,this.circles=[]}};var Tt=class extends N{circles=[];lines=[];isClose=!1;constructor(n){super(n),this.registryEvent()}setEnable(n){super.setEnable(n),n?this.registryEvent():this.unRegistryEvent()}get lastLine(){return this.lines.slice(-1)[0]}addCircle(n){this.circles.push(n),this.svg.appendChild(n)}addLine(n){this.lines.push(n),this.svg.appendChild(n)}registryEvent(){this.context.container.addEventListener("pointerenter",this.onPointermove),this.context.container.addEventListener("pointermove",this.onPointermove),this.context.container.addEventListener("pointerleave",this.onPointerleave),this.context.container.addEventListener("pointerdown",this.onPointerdown),this.context.addEventListener("update",this.onUpdate)}unRegistryEvent(){this.context.container.removeEventListener("pointerenter",this.onPointermove),this.context.container.removeEventListener("pointermove",this.onPointermove),this.context.container.removeEventListener("pointerleave",this.onPointerleave),this.context.container.removeEventListener("pointerdown",this.onPointerdown),this.context.removeEventListener("update",this.onUpdate)}onUpdate=()=>{this.points.length&&this.points.forEach((n,t)=>{let e=this.getSvgCoordinate(n);this.circles[t]&&H(this.circles[t],e.x,e.y),t!==0&&C(this.lines[t-1],void 0,e),this.lines[t]&&C(this.lines[t],e)})};onPointermove=n=>{!this.lastLine||this.isClose||(this.lastLine.style.display="block",C(this.lastLine,void 0,{x:n.offsetX,y:n.offsetY}))};onPointerleave=()=>{this.isClose||(this.lastLine.style.display="none")};onPointerdown=n=>{if(this.isClose)return;let t=this.getIntersectByPointerEvent(n);if(t){let{offsetX:e,offsetY:r}=n;this.checkAdsorb(e,r)?(this.isClose=!0,this.addPoint(this.points[0])):this.addPoint(t);let{circle:{fill:i,radius:s},line:{stroke:l}}=this.context.config.svg;if(!this.isClose){let u=K(s,i);H(u,e,r),this.addCircle(u)}if(this.lines.length&&C(this.lastLine,void 0,{x:e,y:r}),!this.isClose){let u=ut(l);C(u,{x:e,y:r},{x:e,y:r}),this.addLine(u)}}};checkAdsorb(n,t){if(this.points.length<3)return!1;let e=this.circles[0],r=+e.getAttribute("cx"),i=+e.getAttribute("cy");return Math.sqrt((n-r)**2+(t-i)**2)<=5}addPoint(n){if(this.points.push(n),this.isClose){let t=this.calculatedArea();this.dispatchEvent({type:"area",area:t})}}calculatedArea(){let n=this.points.map(r=>[r.x,r.y]),t=0,e=n.length;for(let r=0;r<e;r++){let i=(r+1)%e;t+=n[r][0]*n[i][1]-n[i][0]*n[r][1]}return Math.abs(t/2)}dispose(){super.dispose(),this.unRegistryEvent(),this.lines=[],this.circles=[]}};import{Box3 as Gr}from"three";var Ke=class extends N{constructor(t){super(t);this.context=t;let{config:{svg:{line:e}}}=t;this.rect=q(e.stroke,"transparent"),this.svg.appendChild(this.rect);for(let r=0;r<4;r++)this.cornerRect[r]=q(e.stroke,"#ffffff"),this.centerRect[r]=q(e.stroke,"#ffffff"),this.svg.appendChild(this.cornerRect[r]),this.svg.appendChild(this.centerRect[r]);this.registryEvent()}rect;cornerRect=[];centerRect=[];graphic;setEnable(t){super.setEnable(t),t?this.registryEvent():this.unRegistryEvent()}registryEvent(){this.context.addEventListener("update",this.onUpdate)}unRegistryEvent(){this.context.removeEventListener("update",this.onUpdate)}onUpdate=()=>{if(this.graphic){let t=new Gr().setFromObject(this.graphic),{camera:e,container:{clientWidth:r,clientHeight:i}}=this.context,{min:s,max:l}=t,u=y(s,e,r,i),a=y(l,e,r,i);P(this.rect,u.x,a.y,Math.abs(a.x-u.x),Math.abs(a.y-u.y));let{x:h,y:c}=u,{x:f,y:d}=a,p=5,m=[{x:h-p,y:d-p},{x:f-p,y:d-p},{x:h-p,y:c-p},{x:f-p,y:c-p}];for(let v=0;v<m.length;v++)P(this.cornerRect[v],m[v].x,m[v].y,p*2,p*2);let g=4,x=(h+f)/2,E=(c+d)/2,b=[{x:x-g,y:d-g},{x:h-g,y:E-g},{x:f-g,y:E-g},{x:x-g,y:c-g}];for(let v=0;v<b.length;v++)P(this.centerRect[v],b[v].x,b[v].y,g*2,g*2)}else{P(this.rect,0,0,0,0);for(let t=0;t<this.cornerRect.length;t++)P(this.cornerRect[t],0,0,0,0),P(this.centerRect[t],0,0,0,0)}};selectGraphic(t){this.graphic=t}dispose(){super.dispose(),this.unRegistryEvent(),this.rect=null,this.cornerRect=[],this.centerRect=[]}};import{Frustum as zr}from"three";var Ct=class extends N{startPoint;endPoint;rect;frustum=new zr;constructor(n){super(n);let{config:{selectBox:{fill:t,stroke:e}}}=n;this.rect=q(e,t),this.svg.appendChild(this.rect),this.registryEvent()}setEnable(n){super.setEnable(n),P(this.rect,0,0,0,0),n?this.registryEvent():(this.startPoint=void 0,this.unRegistryEvent())}onPointerDown=n=>{if(!this.enable)return;let t=this.getIntersectByPointerEvent(n);t&&(this.startPoint=t),this.endPoint=void 0};onPointerMove=n=>{if(!this.enable||!this.startPoint)return;let t=this.getIntersectByPointerEvent(n);t&&(this.endPoint=t)};onPointerUp=n=>{if(!this.enable)return;let t=this.getIntersectByPointerEvent(n);t&&(this.endPoint=t),this.doSelect(),this.startPoint=void 0};onUpdate=()=>{if(this.startPoint){let n=this.getSvgCoordinate(this.startPoint),t={...n};this.endPoint&&(t=this.getSvgCoordinate(this.endPoint));let e={x:Math.min(n.x,t.x),y:Math.min(n.y,t.y)},r=Math.abs(t.x-n.x),i=Math.abs(t.y-n.y);P(this.rect,e.x,e.y,r,i)}else P(this.rect,0,0,0,0)};registryEvent(){this.context.container.addEventListener("pointerdown",this.onPointerDown),this.context.container.addEventListener("pointermove",this.onPointerMove),this.context.container.addEventListener("pointerup",this.onPointerUp),this.context.addEventListener("update",this.onUpdate)}unRegistryEvent(){this.context.container.removeEventListener("pointerdown",this.onPointerDown),this.context.container.removeEventListener("pointermove",this.onPointerMove),this.context.container.removeEventListener("pointerup",this.onPointerUp),this.context.removeEventListener("update",this.onUpdate)}doSelect(){if(this.startPoint&&this.endPoint){if(this.startPoint.distanceTo(this.endPoint)<.1)return;let{context:{camera:t,container:{clientWidth:e,clientHeight:r}}}=this,i=y(this.startPoint,t,e,r),s=y(this.endPoint,t,e,r),l={x:Math.min(i.x,s.x),y:Math.min(i.y,s.y)},u={x:Math.max(i.x,s.x),y:Math.max(i.y,s.y)},a=this.searchMapInFrustum(l,u);this.dispatchEvent({type:"selected",list:a})}}searchMapInFrustum(n,t){let{context:e}=this;return e.currentFloor?.graphicLayer.children.filter(r=>r instanceof S&&this.searchChildInFrustum(r,n,t))||[]}searchChildInFrustum(n,t,e){let{context:{camera:r,container:{clientWidth:i,clientHeight:s}}}=this;if(!n)return!1;if(!n.mesh){let f=n.getPosition();if(f){let d=y(f,r,i,s);return st(d,t,e)}return!1}n.mesh.geometry.boundingBox||n.mesh.geometry.computeBoundingBox();let l=n.mesh.geometry.boundingBox;if(!l)return!1;let{min:u,max:a}=l,h=y(u,r,i,s),c=y(a,r,i,s);return!(!st(h,t,e)||!st(c,t,e))}dispose(){this.unRegistryEvent()}};var Pt=class extends kr{constructor(t){super();this.context=t;this.boxSelection=new Ct(t),this.boxSelection.setEnable(!1),this.registryEvent()}_list=new Set;boxSelection;prevPanStatus;prevRotateStatus;downPoint=null;isMultipleSelect=!1;get list(){return this._list}enableBoxSelection(){this.isMultipleSelect||(this.isMultipleSelect=!0,this.boxSelection.setEnable(!0),this.prevPanStatus=this.context.control.enablePan,this.prevRotateStatus=this.context.control.enableRotate,this.context.control.enablePan=!1,this.context.control.enableRotate=!1)}disableBoxSelection(){this.isMultipleSelect&&(this.isMultipleSelect=!1,this.boxSelection.setEnable(!1),this.context.control.enablePan=!!this.prevPanStatus,this.context.control.enableRotate=!!this.prevRotateStatus)}onPointerDown=t=>{this.downPoint={x:t.offsetX,y:t.offsetY}};onPointerUp=t=>{if(!this.downPoint)return;let{offsetX:e,offsetY:r}=t,{x:i,y:s}=this.downPoint;if(Math.sqrt((i-e)**2+(s-r)**2)>3)return;let{graphics:l}=this.context.getGraphicsByDeviceXy(e,r),u=new Set(l.map(h=>h.options.id));this.context.getPoisByDeviceXy(e,r).forEach(h=>{if(!u.has(h.options.id)){let c=this.context.currentFloor?.graphicLayer.graphicMap.get(h.options.id)||null;c&&c.options.geometry.type==="point"&&(l.push(c),u.add(h.options.id))}}),(ft?t.metaKey:t.ctrlKey)||this._list.clear(),l.forEach(h=>this._list.add(h)),this.selectEnd(),this.downPoint=null};onPointerOut=t=>{this.disableBoxSelection()};onKeyDown=t=>{Vt(t.key)&&this.enableBoxSelection()};onKeyUp=t=>{Vt(t.key)&&this.disableBoxSelection()};onBoxSelected=({list:t})=>{this._list.clear(),t.forEach(e=>{this._list.add(e)}),this.selectEnd()};selectEnd(){this.dispatchEvent({type:"select",graphics:[...this._list],isMultipleSelect:this.isMultipleSelect})}registryEvent(){this.context.container.addEventListener("pointerdown",this.onPointerDown),this.context.container.addEventListener("pointerup",this.onPointerUp),this.context.container.addEventListener("pointerout",this.onPointerOut),this.context.container.addEventListener("pointercancel",this.onPointerOut),window.addEventListener("keydown",this.onKeyDown),window.addEventListener("keyup",this.onKeyUp),this.boxSelection.addEventListener("selected",this.onBoxSelected)}unRegistryEvent(){this.context.container.removeEventListener("pointerdown",this.onPointerDown),this.context.container.removeEventListener("pointerup",this.onPointerUp),this.context.container.removeEventListener("pointerout",this.onPointerOut),this.context.container.removeEventListener("pointercancel",this.onPointerOut),window.removeEventListener("keydown",this.onKeyDown),window.removeEventListener("keyup",this.onKeyUp),this.boxSelection.removeEventListener("selected",this.onBoxSelected)}clear(){this._list.clear()}remove(t){this._list.delete(t)}dispose(){this.unRegistryEvent()}};import{EventDispatcher as Vr}from"three";var At=class extends Vr{constructor(t){super();this.context=t;this.registryEvent()}curGraphics=new Set;timer=new L;graphicTimerMap=new Map;onPointerMove=({graphics:t,pois:e,e:r})=>{let i=e.map(a=>this.context.currentFloor?.graphicLayer.graphicMap.get(a.options.id)).filter(a=>a&&a.options.geometry.type==="point");if(!t.length&&!i.length&&this.curGraphics.size){this.curGraphics.clear(),this.handleHoverGraphicsChange();return}let{time:s}=this.context.config.hover,l=new Set;if(i.length){let a,h=1e4;i.forEach(c=>{let f=e.find(g=>g.options.id===c.options.id),{x:d,y:p}=f.clientPos,m=Math.sqrt((d-r.offsetX)**2+(p-r.offsetY)**2);m<h&&(h=m,a=c)}),l.add(a)}l.size||t.forEach(a=>l.add(a)),l.forEach(a=>{if(this.graphicTimerMap.get(a)||this.curGraphics.has(a))return;let h=this.timer.setTimeout(()=>{this.curGraphics.add(a),this.graphicTimerMap.delete(a),this.timer.clearTimeout(h),this.handleHoverGraphicsChange()},s);this.graphicTimerMap.set(a,h)}),this.graphicTimerMap.forEach((a,h)=>{l.has(h)||(this.timer.clearTimeout(a),this.graphicTimerMap.delete(h))});let u=this.curGraphics.size;this.curGraphics.forEach(a=>{l.has(a)||this.curGraphics.delete(a)}),u!==this.curGraphics.size&&this.handleHoverGraphicsChange()};onPointerLevel=()=>{this.curGraphics.clear(),this.handleHoverGraphicsChange()};onBodyPointerMove=t=>{if(this.curGraphics.size){let e=this.context.container.getBoundingClientRect();(t.clientX<e.left||t.clientX>e.right||t.clientY<e.top||t.clientY>e.bottom)&&this.onPointerLevel()}};handleHoverGraphicsChange(t=this.curGraphics){this.dispatchEvent({type:"hover-change",graphics:Array.from(t)})}registryEvent(){this.context.addEventListener("pointer-over",this.onPointerMove),this.context.addEventListener("pointer-move",this.onPointerMove),this.context.addEventListener("pointer-level",this.onPointerLevel),document.body.addEventListener("pointermove",this.onBodyPointerMove)}unRegistryEvent(){this.context.removeEventListener("pointer-over",this.onPointerMove),this.context.removeEventListener("pointer-move",this.onPointerMove),this.context.removeEventListener("pointer-level",this.onPointerLevel),document.body.removeEventListener("pointermove",this.onBodyPointerMove)}dispose(){this.unRegistryEvent(),this.timer.dispose()}};import{Color as Rt,LineBasicMaterial as Hr,MeshStandardMaterial as Wr,MeshBasicMaterial as $e,ShaderMaterial as Xr,DoubleSide as qr}from"three";function Je(o){return`${o.x}-${o.y}-${o.z}`}var Lt=class{constructor(n){this.context=n}lineMaterialMap=new Map;meshStandardMaterialMap=new Map;meshBasicMaterialMap=new Map;shaderMaterialMap=new Map;groundTextureMaterialMap=new Map;generateLineMaterialKey({color:n,opacity:t}){return`${n}-${t}`}createLineMaterial({color:n,opacity:t}){let e=this.generateLineMaterialKey({color:n,opacity:t});if(this.lineMaterialMap.has(e))return this.lineMaterialMap.get(e);let r=new Hr({color:new Rt(n).convertLinearToSRGB(),transparent:!0,opacity:t});return this.lineMaterialMap.set(e,r),r}createMeshStandardMaterial({color:n,opacity:t}){let e=`${n}-${t}`;if(this.meshStandardMaterialMap.has(e))return this.meshStandardMaterialMap.get(e);let r=new Wr({color:new Rt(n).convertLinearToSRGB(),roughness:1,transparent:!0,opacity:t,depthWrite:!0});return this.meshStandardMaterialMap.set(e,r),r}createMeshBasicMaterial({color:n,opacity:t}){let e=`${n}-${t}`;if(this.meshBasicMaterialMap.has(e))return this.meshBasicMaterialMap.get(e);let r=new $e({color:n,transparent:!0,opacity:t,depthWrite:!0});return this.meshBasicMaterialMap.set(e,r),r}createShaderMaterial({gradualColor:n,center:t,maxValue:e,opacity:r,direction:i,max:s,min:l}){let u=`${n.toString()}-${Je(t)}-${e}-${r}-${Je(i)}`;if(this.shaderMaterialMap.has(u))return this.shaderMaterialMap.get(u);let a=`
|
|
1
|
+
var gn=Object.create;var Jt=Object.defineProperty;var mn=Object.getOwnPropertyDescriptor;var yn=Object.getOwnPropertyNames;var _n=Object.getPrototypeOf,vn=Object.prototype.hasOwnProperty;var z=(o,n)=>()=>(n||o((n={exports:{}}).exports,n),n.exports);var xn=(o,n,t,e)=>{if(n&&typeof n=="object"||typeof n=="function")for(let r of yn(n))!vn.call(o,r)&&r!==t&&Jt(o,r,{get:()=>n[r],enumerable:!(e=mn(n,r))||e.enumerable});return o};var Qt=(o,n,t)=>(t=o!=null?gn(_n(o)):{},xn(n||!o||!o.__esModule?Jt(t,"default",{value:o,enumerable:!0}):t,o));var ve=z((ho,_e)=>{_e.exports=function(n,t){return n[0]=t[0],n[1]=t[1],n}});var be=z((co,Ee)=>{var xe=ve();Ee.exports=function(o,n){Array.isArray(n)||(n=[]),o.length>0&&n.push(xe([0,0],o[0]));for(var t=0;t<o.length-1;t++){var e=o[t],r=o[t+1],i=e[0],s=e[1],l=r[0],u=r[1],a=[.75*i+.25*l,.75*s+.25*u],h=[.25*i+.75*l,.25*s+.75*u];n.push(a),n.push(h)}return o.length>1&&n.push(xe([0,0],o[o.length-1])),n}});var Ae=z((yo,Pe)=>{var Wt=class{constructor(){this.keys=new Set,this.queue=[]}sort(){this.queue.sort((n,t)=>n.priority-t.priority)}set(n,t){let e=Number(t);if(isNaN(e))throw new TypeError('"priority" must be a number');return this.keys.has(n)?this.queue.map(r=>(r.key===n&&Object.assign(r,{priority:e}),r)):(this.keys.add(n),this.queue.push({key:n,priority:e})),this.sort(),this.queue.length}next(){let n=this.queue.shift();return this.keys.delete(n.key),n}isEmpty(){return this.queue.length===0}has(n){return this.keys.has(n)}get(n){return this.queue.find(t=>t.key===n)}};Pe.exports=Wt});var Ie=z((_o,Le)=>{function Re(o,n){let t=new Map;for(let[e,r]of o)e!==n&&r instanceof Map?t.set(e,Re(r,n)):e!==n&&t.set(e,r);return t}Le.exports=Re});var De=z((vo,Oe)=>{function qn(o){let n=Number(o);return!(isNaN(n)||n<=0)}function Ne(o){let n=new Map;return Object.keys(o).forEach(e=>{let r=o[e];if(r!==null&&typeof r=="object"&&!Array.isArray(r))return n.set(e,Ne(r));if(!qn(r))throw new Error(`Could not add node at key "${e}", make sure it's a valid node`,r);return n.set(e,Number(r))}),n}Oe.exports=Ne});var Be=z((xo,Ue)=>{function Fe(o){if(!(o instanceof Map))throw new Error(`Invalid graph: Expected Map instead found ${typeof o}`);o.forEach((n,t)=>{if(typeof n=="object"&&n instanceof Map){Fe(n);return}if(typeof n!="number"||n<=0)throw new Error(`Values must be numbers greater than 0. Found value ${n} at ${t}`)})}Ue.exports=Fe});var Ve=z((Eo,ke)=>{var jn=Ae(),Yn=Ie(),Ge=De(),ze=Be(),Xt=class{constructor(n){n instanceof Map?(ze(n),this.graph=n):n?this.graph=Ge(n):this.graph=new Map}addNode(n,t){let e;return t instanceof Map?(ze(t),e=t):e=Ge(t),this.graph.set(n,e),this}addVertex(n,t){return this.addNode(n,t)}removeNode(n){return this.graph=Yn(this.graph,n),this}path(n,t,e={}){if(!this.graph.size)return e.cost?{path:null,cost:0}:null;let r=new Set,i=new jn,s=new Map,l=[],u=0,a=[];if(e.avoid&&(a=[].concat(e.avoid)),a.includes(n))throw new Error(`Starting node (${n}) cannot be avoided`);if(a.includes(t))throw new Error(`Ending node (${t}) cannot be avoided`);for(i.set(n,0);!i.isEmpty();){let h=i.next();if(h.key===t){u=h.priority;let f=h.key;for(;s.has(f);)l.push(f),f=s.get(f);break}r.add(h.key),(this.graph.get(h.key)||new Map).forEach((f,d)=>{if(r.has(d)||a.includes(d))return null;if(!i.has(d))return s.set(d,h.key),i.set(d,h.priority+f);let p=i.get(d).priority,m=h.priority+f;return m<p?(s.set(d,h.key),i.set(d,m)):null})}return l.length?(e.trim?l.shift():l=l.concat([n]),e.reverse||(l=l.reverse()),e.cost?{path:l,cost:u}:l):e.cost?{path:null,cost:0}:null}shortestPath(...n){return this.path(...n)}};ke.exports=Xt});import{EventDispatcher as ii,Vector3 as oi}from"three";var L=class{tasks={requestAnimation:new Set,timeout:new Set,interval:new Set};requestAnimationFrame(n){let t=window.requestAnimationFrame(()=>{this.tasks.requestAnimation.delete(t),n()});return this.tasks.requestAnimation.add(t),t}cancelAnimationFrame(n){this.tasks.requestAnimation.delete(n),window.cancelAnimationFrame(n)}setTimeout(n,t){let e=window.setTimeout(()=>{this.tasks.timeout.delete(e),n()},t);return this.tasks.timeout.add(e),e}clearTimeout(n){this.tasks.timeout.delete(n),window.clearTimeout(n)}setInterval(n,t){let e=window.setInterval(()=>{this.tasks.interval.delete(e),n()},t);return this.tasks.interval.add(e),e}clearInterval(n){this.tasks.interval.delete(n),window.clearInterval(n)}dispose(){this.tasks.requestAnimation.forEach(n=>{window.cancelAnimationFrame(n)}),this.tasks.requestAnimation.clear(),this.tasks.timeout.forEach(n=>{window.clearTimeout(n)}),this.tasks.timeout.clear(),this.tasks.interval.forEach(n=>{window.clearInterval(n)}),this.tasks.interval.clear()}};import{Scene as En,WebGLRenderer as bn,OrthographicCamera as Mn,Shape as Sn,PCFSoftShadowMap as wn,Group as Tn,Color as Cn,DirectionalLight as Pn,AmbientLight as An,Path as Rn,Vector2 as te}from"three";import{MapControls as Ln}from"three/examples/jsm/controls/MapControls";function ee(){let o=new En;return o.background=new Cn(16777215),o}function ne(){let o=new bn({antialias:!0});return o.autoClear=!0,o.setClearAlpha(1),o.setClearColor(16777215),o.setPixelRatio(window.devicePixelRatio),o.shadowMap.enabled=!0,o.shadowMap.autoUpdate=!0,o.shadowMap.type=wn,o}function re(o,n){let t=new Mn(-o/2,o/2,n/2,-n/2,-1e3,5e3);return t.up.set(0,0,1),t.position.set(0,0,100),t.lookAt(0,0,0),t}function ie(){let o=new Tn,n=new An(16777215,2.6);return o.add(n),o}function oe(o,n){let t=new Ln(o,n);return t.enableDamping=!1,t.zoomSpeed=2,t}function se(o,n=[]){let t=new Sn(o.map(e=>new te(...e)));return n.length&&n.forEach(e=>{var r=new Rn(e.map(i=>new te(...i)));t.holes.push(r)}),t}function ae(o=16777215,n=1){let t=new Pn(o,n);return t.castShadow=!0,t.shadow.radius=8,t.shadow.bias=-.001,t.shadow.mapSize.set(256,256),t.shadow.camera.left=-200,t.shadow.camera.right=200,t.shadow.camera.top=200,t.shadow.camera.bottom=-200,t}function O(o,n){if(n&&o.children&&o.children.length&&o.children.forEach(t=>{O(t,n)}),o.isMesh){let t=o;t.geometry&&t.geometry.dispose(),t.material&&(Array.isArray(t.material)?t.material.forEach(e=>{e.dispose()}):t.material.dispose())}o.isLight&&o.dispose?.()}function le(o){return/[\u4E00-\u9FA5]+/g.test(o)}import{DataTexture as In,RGBAFormat as Nn,LinearFilter as ue}from"three";var it=new Map;function On(){let o=document.createElement("canvas");o.width=1024,o.height=64;let n=o.getContext("2d",{willReadFrequently:!0});return n.font="54px sans-serif",n.textBaseline="hanging",n.lineWidth=12,n.fillStyle="rgba(0,0,0,1)",n.strokeStyle="white",{canvas:o,ctx:n}}var Gt,k;function Dn(){if(!Gt){let{canvas:o,ctx:n}=On();Gt=o,k=n}}function Ui(o){if(it.has(o))return it.get(o);Dn(),k.clearRect(0,0,1024,64);let n=le(o)?4:8;k.strokeText(o,2,n),k.fillText(o,2,n);let t=Math.ceil(k.measureText(o).width);t=t%2===0?t:t+1,t+=2;let e=k.getImageData(0,0,t,64),r=new In(Uint8Array.from(e.data),t,64,Nn);return r.flipY=!0,r.minFilter=ue,r.magFilter=ue,it.set(o,r),r}function he(){it.clear()}function ce(){k=null,Gt=null}import{Vector3 as zt,Vector2 as ot}from"three";import{point as Fn,featureCollection as Un,center as Bn}from"@turf/turf";function y(o,n,t,e){let r=o.clone().project(n),i=t/2,s=e/2,l=Math.round(r.x*i+i),u=Math.round(-r.y*s+s);return{x:l,y:u}}function kt(o){let n=Un(o.map(e=>Fn(e)));return Bn(n).geometry.coordinates}function st(o,n,t){return o.x>=n.x&&o.x<=t.x&&o.y>=n.y&&o.y<=t.y}function Vi(o){let n=0,t=new zt;for(let e=1;e<o.length;e++){let r=new zt(o[e-1][0],o[e-1][1],0),i=new zt(o[e][0],o[e][1],0),s=i.distanceTo(r);s>n&&(n=s,t=i.clone().sub(r).normalize())}return t}function M(o,n){return Math.sqrt((n[0]-o[0])**2+(n[1]-o[1])**2)}function at(o){let n=0;for(let t=0;t<o.length-1;t++)n+=M(o[t],o[t+1]);return n}function pe(o,n,t){let e=new ot(n[0]-o[0],n[1]-o[1]),r=new ot(n[0]-t[0],n[1]-t[1]),s=e.angleTo(r)*180/Math.PI,l=new ot(n[0]-o[0],n[1]-o[1]);return new ot(t[0]-o[0],t[1]-o[1]).cross(l)>0?s:-s}function X(o,n){return new Proxy(o,{get:(t,e,r)=>Reflect.get(t,e,r),set:(t,e,r,i)=>{let s=Reflect.get(t,e,i),l=Reflect.set(t,e,r,i);return s!==r&&n.dispatchEvent({type:`change-${e}`,value:r}),l}})}function V(o,n){return Promise.race([o,new Promise((t,e)=>{setTimeout(()=>e(new Error("Promise timeout")),n)})])}function lt(o){return document.createElementNS("http://www.w3.org/2000/svg",o)}function fe(o,n){let t=lt("svg");return t.setAttribute("width",o),t.setAttribute("height",n),t.style.cssText="position: absolute; left: 0; top: 0; pointer-events: none;",t}function K(o="2",n){let t=lt("circle");return t.setAttribute("r",o),t.setAttribute("fill",n),t}function ut(o){let n=lt("line");return n.setAttribute("stroke",o),n}function q(o,n){let t=lt("rect");return t.setAttribute("stroke",o),t.setAttribute("fill",n),t}function H(o,n,t){o.setAttribute("cx",`${n}`),o.setAttribute("cy",`${t}`)}function C(o,n,t){n&&(o.setAttribute("x1",`${n.x}`),o.setAttribute("y1",`${n.y}`)),t&&(o.setAttribute("x2",`${t.x}`),o.setAttribute("y2",`${t.y}`))}function P(o,n,t,e,r){o.setAttribute("x",`${n}`),o.setAttribute("y",`${t}`),o.setAttribute("width",`${e}`),o.setAttribute("height",`${r}`)}function de(){return Promise.resolve()}function ji(){return new Promise(o=>{requestAnimationFrame(o)})}function Zi(o){return parseInt(o.replace("#","0x"),16)}function Ki(o,n){let t=parseInt(o.substring(1,3),16),e=parseInt(o.substring(3,5),16),r=parseInt(o.substring(5,7),16),i=Math.round(t*n),s=Math.round(e*n),l=Math.round(r*n);return`#${(1<<24|i<<16|s<<8|l).toString(16).slice(1)}`}function ht(o,n=.85){let t,e,r;if(o.startsWith("#"))t=parseInt(o.substring(1,3),16),e=parseInt(o.substring(3,5),16),r=parseInt(o.substring(5,7),16);else{let s=o.slice(4,-1).split(",");t=parseInt(s[0].trim()),e=parseInt(s[1].trim()),r=parseInt(s[2].trim())}return t=Math.min(Math.floor(t*n),255),e=Math.min(Math.floor(e*n),255),r=Math.min(Math.floor(r*n),255),"#"+((1<<24)+(t<<16)+(e<<8)+r).toString(16).slice(1)}import{GLTFLoader as Gn}from"three/examples/jsm/loaders/GLTFLoader";function zn(){return new Gn}var ct=null,pt=new Map;function ge(o){if(pt.has(o)){let t=pt.get(o).then(e=>(e.scene=e.scene.clone(),e))}ct||(ct=zn());let n=new Promise((t,e)=>{ct.load(o,r=>{t(r)},void 0,e)});return pt.set(o,n),n.then(t=>(t.scene=t.scene.clone(),t))}function me(){ct=null,pt.clear()}var ft=navigator.userAgent.toUpperCase().indexOf("MAC")>=0;function Vt(o){return ft?o==="Meta":o==="Control"}var Ht="__once__",ye=class{events=new Map;on(n,t){if(typeof t!="function")return;let e=this.events.get(n);return e?e.add(t):this.events.set(n,new Set([t]))}once(n,t){if(typeof t!="function")return;let e=`${Ht}${n}`,r=this.events.get(e);return r?r.add(t):this.events.set(e,new Set([t]))}off(n,t){let e=this.events.get(n),r=this.events.get(`${Ht}${n}`);!e&&!r||(t===void 0&&(e?.clear(),r?.clear()),e?.has(t)&&e.delete(t),r?.has(t)&&r.delete(t))}offAll(){this.events.clear()}emit(n,...t){let e=this.events.get(n),r=this.events.get(`${Ht}${n}`);!e&&!r||(e?.forEach(i=>{typeof i=="function"&&i(...t)}),r?.forEach(i=>{typeof i=="function"&&i(...t)}),r?.clear())}};var $=(t=>(t.SWITCH_FLOOR_BEFORE="switch_floor_before",t.SWITCH_FLOOR_AFTER="switch_floor_after",t))($||{});function A(o){return Object.keys(o).sort().map(n=>`${n}=${o[n]}`).join("&")}function ao(o,n){return new Promise((t,e)=>{let r=new XMLHttpRequest;r.open("GET",o,!0),Object.keys(n.headers||{}).forEach(i=>{r.setRequestHeader(i,n.headers[i])}),n.responseType&&(r.responseType=n.responseType),r.onload=()=>{if(r.status>=200&&r.status<300)if(n.responseType==="arraybuffer")t(r.response);else try{let i=JSON.parse(r.responseText);t(i)}catch(i){e(i)}else e(r.statusText)},r.onerror=()=>{e(r.statusText)},r.send()})}var j=class o{keySet=new Set;static createKey(){return Math.random().toString(36).substring(2,15)+Math.random().toString(36).substring(2,15)}genUniqueKey(){let n=o.createKey();for(;this.keySet.has(n);)n=o.createKey();return n}removeKey(n){this.keySet.delete(n)}dispose(){this.keySet.clear()}};var Me=Qt(be(),1);import{Vector2 as J}from"three";function kn(o,n){let t=o.clone().normalize(),e=n.clone().normalize();return Math.acos(t.dot(e))}function Vn(o){let n=0;return o.reduce(([t,e],[r,i])=>(n+=Math.sqrt((r-t)**2+(i-e)**2),[r,i])),n/o.length}function Se(o,n=.25){if(Vn(o)<n)return o;let t=(0,Me.default)(o);return Se(t,n)}function we(o,n=!1,t=!0,e=5,r=150,i=3){let s=[],l=!n;if(s.push(o[0]),o.length<2)return s;for(let a=0;a<o.length-2;a+=1){let h=o[a],c=o[a+1],f=o[a+2],d=new J(h[0]-c[0],h[1]-c[1]),p=new J(f[0]-c[0],f[1]-c[1]),m=kn(d,p)/Math.PI*180,g=d.length()+p.length();(!l||m<r&&g>.01||g>e)&&(s.push(o[a+1]),l=!0)}if(s.push(o[o.length-1]),!t)return s;let u=[];u.push(s[0]);for(let a=0;a<s.length-2;a+=1){let h=new J(s[a][0],s[a][1]),c=new J(s[a+1][0],s[a+1][1]),f=new J(s[a+2][0],s[a+2][1]),d=h.distanceTo(c)/2,p=f.distanceTo(c)/2,m=c.clone(),g=c.clone();m.add(h.clone().sub(c).normalize().multiplyScalar(d>i?i/2:d)),g.add(f.clone().sub(c).normalize().multiplyScalar(p>i?i/2:p));let x=[[m.x,m.y],[c.x,c.y],[g.x,g.y]];u.push(...Se(x,i/25))}return u.push(s[s.length-1]),Hn(u)}function Hn(o){if(o.length<=1)return o;let n=[],t;return o.forEach(([e,r])=>{t?e===t[0]&&r===t[1]||(t=[e,r],n.push([e,r])):(t=[e,r],n.push([e,r]))}),n}function Te(o,n,t){let e=Math.sqrt((t[0]-n[0])**2+(t[1]-n[1])**2);if(e===0)return{distance:Math.sqrt((o[0]-n[0])**2+(o[1]-n[1])**2),closestPoint:n.slice(0)};let r=Math.max(0,Math.min(1,((o[0]-n[0])*(t[0]-n[0])+(o[1]-n[1])*(t[1]-n[1]))/e**2)),i=[n[0]+r*(t[0]-n[0]),n[1]+r*(t[1]-n[1])];return{distance:Math.sqrt((o[0]-i[0])**2+(o[1]-i[1])**2),closestPoint:i}}function Ce(o,n,t){let[e,r]=o,[i,s]=n,l=Math.sqrt(Math.pow(i-e,2)+Math.pow(s-r,2)),u=t/l,a=e+(i-e)*u,h=r+(s-r)*u;return[a,h]}var Wn=(a=>(a.START="start",a.END="end",a.FRONT="front",a.RIGHT="right",a.LEFT="left",a.RIGHT_FRONT="right_front",a.LEFT_FRONT="left_front",a.RIGHT_BACK="right_back",a.LEFT_BACK="left_back",a))(Wn||{});function Xn(o,n,t){let e=pe(o,n,t);return 180-Math.abs(e)<15?"front":e>135?"right_front":e<-135?"left_front":e<=135&&e>=60?"right":e>=-135&&e<=-60?"left":e<60&&e>0?"right_back":e>-60&&e<0?"left_back":"front"}function go(o){let n=[{direction:"start",distance:M(o[0],o[1]),points:[o[0],o[1]]}];for(let t=2;t<o.length;t++){let e=Xn(o[t-2],o[t-1],o[t]);if(e==="front"){let r=n[n.length-1],i=M(o[t-1],o[t]);r.distance+=i,t!==2&&r.points.push(o[t-1])}else n.push({direction:e,distance:M(o[t-1],o[t]),points:[o[t-1],o[t]]})}return n.push({direction:"end",distance:0,points:[o[o.length-1]]}),n}var I=Qt(Ve(),1);var He=class{constructor(n=3){this.lift_priority=n}roadInfo=[];pointMap=new Map;nodeMap=new Map;facilityMap=new Map;straightLadderMap=new Map;escalatorMap=new Map;staircaseMap=new Map;lineMap=new Map;baseRoute=new I.default;escalatorRoute=new I.default;straightLadderRoute=new I.default;initRoute(n){this.clear(),this.roadInfo=n,n.length&&(n.forEach(t=>{t.points.forEach(e=>{let r=`${t.floor}-${e.id}`;if(this.pointMap.set(r,e),this.nodeMap.set(`${e.floor}-${e.nodeId}`,r),e.type==="straightLadder"){let i=this.straightLadderMap.get(e.name)||[];i.push({...e}),this.straightLadderMap.set(e.name,i)}if(e.type==="staircase"){let i=this.staircaseMap.get(e.name)||[];i.push({...e}),this.staircaseMap.set(e.name,i)}if(e.type==="escalator"){let i=this.escalatorMap.get(e.name)||{};e.escalatorDirection==="exit"?i.end={floor:e.floor,id:e.id}:i.start={floor:e.floor,id:e.id},this.escalatorMap.set(e.name,i)}if(e.type==="facility"){let i=this.facilityMap.get(e.targetId)||[];i.push({...e}),this.facilityMap.set(e.targetId,i)}}),t.lines.filter(e=>e.direction!=="no").forEach(e=>{let r=`${t.floor}-${e.from}`,i=`${t.floor}-${e.to}`,s=this.pointMap.get(r)?.cds,l=this.pointMap.get(i)?.cds;if(s?.length&&l?.length){let u=M(s,l);this.addLineItem(r,i,u),e.direction==="double"&&this.addLineItem(i,r,u)}})}),this.initBaseRoute(),this.initEscalatorRoute(),this.initStraightLadderRoute())}addLineItem(n,t,e,r=this.lineMap){let i=r.get(n)||new Map;i.set(t,e),r.set(n,i)}addFacilityToLineMap(n,t,e,r){[...this.straightLadderMap,...this.staircaseMap].forEach(([i,s])=>{if(!(s.length<2))for(let l=0;l<s.length;l++){let u=`${s[l].floor}-${s[l].id}`;for(let a=0;a<s.length;a++)if(l!==a){let h=`${s[a].floor}-${s[a].id}`,c=this.pointMap.get(u)?.cds,f=this.pointMap.get(h)?.cds;if(c?.length&&f?.length)if(s[l].type==="straightLadder"){let d=t;this.addLineItem(u,h,d,r)}else{let d=e;this.addLineItem(u,h,d,r)}}}}),this.escalatorMap.forEach((i,s)=>{if(i.start&&i.end){let l=`${i.start.floor}-${i.start.id}`,u=`${i.end.floor}-${i.end.id}`,a=this.pointMap.get(l)?.cds,h=this.pointMap.get(u)?.cds;if(a?.length&&h?.length){let c=n;this.addLineItem(l,u,c,r)}}})}initBaseRoute(){let n=new Map([...this.lineMap]);this.addFacilityToLineMap(1,this.lift_priority,3e4,n),this.baseRoute=new I.default(n)}initEscalatorRoute(){let n=new Map([...this.lineMap]),t=1e4;this.addFacilityToLineMap(1*t,this.lift_priority*t,3e4*t,n),this.escalatorRoute=new I.default(n)}initStraightLadderRoute(){let n=new Map([...this.lineMap]),t=1e4;this.addFacilityToLineMap(3*t,1*t,3e4*t,n),this.straightLadderRoute=new I.default(n)}checkStart(n){return!(!n.floor||!n.nodeId&&(!n.coord||n.coord.length<2))}checkEnd(n){return n.facility?!0:this.checkStart(n)}transformStart(n){if(n.nodeId){let t=this.nodeMap.get(`${n.floor}-${n.nodeId}`);if(t){let[e,r]=t.split("-");return{floor:e,id:r}}}if(n.coord?.length){let t=this.roadInfo.find(r=>r.floor===n.floor);if(!t)return null;let e=t.points.reduce((r,i)=>{let s=M(n.coord,i.cds);return s<r.min&&(r.min=s,r.point=i),r},{min:1/0,point:t.points[0]});return{floor:e.point.floor,id:e.point.id}}return null}transformEnd(n){if(n.floor){let t=this.transformStart(n);if(t)return t}return n.facility&&this.facilityMap.get(n.facility)?.length?{floor:n.floor,facility:n.facility}:null}getPath(n,t,e=""){if(!this.checkStart(n))return"start-error";if(!this.checkEnd(t))return"end-error";let r=this.transformStart(n);if(!r)return"no-start";let i=this.transformEnd(t);if(!i)return"no-end";let s=this.getBasePath.bind(this);switch(e){case"escalator":s=this.getEscalatorPath.bind(this);case"straightLadder":s=this.getStraightLadderPath.bind(this);default:s=this.getBasePath.bind(this)}if(i.id)return s(r,i);if(i.facility){let l=this.facilityMap.get(i.facility).filter(a=>i.floor?a.floor===i.floor:!0);if(!l.length)return null;let u=l.map(a=>s(r,{floor:a.floor,id:a.id})).filter(a=>!!a);return u.reduce((a,h)=>{let c=h.reduce((f,d)=>f+at(d.points),0);return c<a.distance&&(a.distance=c,a.path=h),a},{distance:1/0,path:u[0]}).path}}getRoutePath(n,t,e){let r=`${n.floor}-${n.id}`,i=`${t.floor}-${t.id}`,s=e.path(r,i);if(!s)return null;let l=[];return s.map(u=>{let a=this.pointMap.get(u);if(a){let{floor:h}=a;if(l[l.length-1]?.floor===h){let c=l[l.length-1];c.points.push(a.cds),c.endType=a.type,c.destId=a.nodeId}else l.push({floor:h,points:[a.cds],endType:a.type,destId:a.nodeId})}}),l}getBasePath(n,t){return this.getRoutePath(n,t,this.baseRoute)}getEscalatorPath(n,t){return this.getRoutePath(n,t,this.escalatorRoute)}getStraightLadderPath(n,t){return this.getRoutePath(n,t,this.straightLadderRoute)}clear(){this.roadInfo=[],this.pointMap.clear(),this.nodeMap.clear(),this.facilityMap.clear(),this.straightLadderMap.clear(),this.escalatorMap.clear(),this.staircaseMap.clear(),this.lineMap.clear(),this.baseRoute=new I.default,this.escalatorRoute=new I.default,this.straightLadderRoute=new I.default}};function We(o){return o.replace(/[A-Z]/g,n=>"_"+n.toLowerCase()).replace(/^_/,"")}var Xe=new j;function Q(o,n,t){return new Promise((e,r)=>{let i=Xe.genUniqueKey(),s=({data:l})=>{l.type===`${n}_result`&&l.key===i&&(Xe.removeKey(i),self.removeEventListener("message",s),l.error?r(l.error):e(l.data))};o.addEventListener("message",s),o.postMessage({type:n,key:i,data:t})})}function Co(o){let n={};for(let e in o)e.startsWith("on")&&(n[We(e.slice(2))]=o[e]);let t=async({data:e})=>{if(n[e.type])try{let r=await n[e.type](e.data);self.postMessage({type:`${e.type}_result`,key:e.key,data:r})}catch(r){self.postMessage({type:`${e.type}_result`,key:e.key,error:r})}else self.postMessage({type:`${e.type}_result`,key:e.key,error:"no_event"})};return self.addEventListener("message",t),()=>{self.removeEventListener("message",t)}}import{EventDispatcher as Zr,Box2 as Kr,Vector3 as F,Vector2 as Z,Raycaster as $r,Box3 as Jr,Color as Qr,AmbientLight as ti}from"three";import{Group as ei,Tween as Dt}from"@tweenjs/tween.js";import{EventDispatcher as kr}from"three";import{Object3D as Zn,ExtrudeGeometry as Kn,Mesh as $n,Box3 as dt,Vector3 as R,BufferGeometry as Jn,LineSegments as Qn,Ray as qe}from"three";var tr={id:"",height:.1,airHeight:0,area:0,group:"",fillColor:"#EFF4FB",strokeColor:"#ffffff",fillOpacity:1,strokeOpacity:1,strokeWidth:1,doors:[],locked:!1,visible:!0,geometry:{type:"polygon",cds:[],coords:[],curveCpt:[],curveIndex:[]},layerType:"",zIndex:0,stroke:!0,deltaHeight:0,userData:{},gradualColor:[],renderType:"single",colorFactor:.9},S=class extends Zn{constructor(t,e){super();this.context=t;if(this.options=X({...tr,...e},this),this.options.geometry.type==="point"){let[r,i]=this.options.geometry.coords;return this.position.set(r,i,this.options.height+this.options.airHeight),this}this.init(),this.visible=this.options.visible,this.addEventListener("change-fillColor",({value:r})=>{this.initMaterial(),this.initMesh()}),this.addEventListener("change-fillOpacity",({value:r})=>{this.initMaterial(),this.initMesh()}),this.addEventListener("change-height",({value:r})=>{this.dispose(),this.init()}),this.addEventListener("change-strokeColor",({value:r})=>{this.options.stroke&&(this.initLineMaterial(),this.createBorder())}),this.addEventListener("change-strokeOpacity",({value:r})=>{this.options.stroke&&(this.initLineMaterial(),this.createBorder())}),this.addEventListener("change-airHeight",({value:r})=>{this.position.z=r}),this.addEventListener("change-visible",({value:r})=>{this.visible=r}),this.addEventListener("change-stroke",({value:r})=>{if(r){if(this.line)return;this.initLineGeometry(),this.initLineMaterial(),this.createBorder()}else this.line&&(this.remove(this.line),this.lineGeometry?.dispose())}),this.addEventListener("change-renderType",()=>{this.initMaterial(),this.initMesh()}),this.addEventListener("change-gradualColor",()=>{this.initMaterial(),this.initMesh()})}geometry;material;mesh;line;lineMaterial;lineGeometry;options;getCenter(){if(this.options.geometry.type==="point")return this.position.clone();let t=new R,e=new dt;return e.setFromObject(this),e.getCenter(t),t}getSize(){if(this.options.geometry.type==="point")return new R(0,0,0);let t=new dt,e=new R;return t.setFromObject(this),t.getSize(e),e}getPosition(){let t=this.getCenter();return t.setZ(t.z+this.options.height/2),t}init(){this.geometry=this.initGeometry(),this.initMaterial(),this.initMesh(),this.mesh.position.z=this.options.airHeight+this.options.deltaHeight,this.options.stroke&&(this.initLineMaterial(),this.initLineGeometry(),this.createBorder())}initGeometry(){let t=se(this.options.geometry.coords[0],this.options.geometry.coords.slice(1));return new Kn(t,{steps:1,bevelEnabled:!1,depth:this.options.height,curveSegments:4})}initSingleMaterial(){let t=this.context.materialFactory.createMeshBasicMaterial({color:this.options.fillColor,opacity:this.options.fillOpacity});if(this.options.height<=.1)return this.material=t,t;let e=this.context.materialFactory.createMeshBasicMaterial({color:ht(this.options.fillColor),opacity:this.options.fillOpacity});return this.material=[t,e],[t,e]}getMaxAndMin(t,e){let r=new dt().setFromObject(this),i=t.clone().add(e.clone().multiplyScalar(1e3)),s=new qe(i,e.clone().multiplyScalar(-1)),l=new R;s.intersectBox(r,l);let u=t.clone().add(e.clone().multiplyScalar(-1e3)),a=new qe(u,e.clone()),h=new R;return a.intersectBox(r,h),{max:h,min:l}}initGradualMaterial(){let{max:t,min:e}=new dt().setFromObject(this),r=t.clone().sub(e),i=Math.max(r.x,r.y,r.z)/2,s=this.getPosition(),l=new R(-1,.2,0).normalize(),{max:u,min:a}=this.getMaxAndMin(s,l),h=this.context.materialFactory.createShaderMaterial({gradualColor:this.options.gradualColor,center:this.getPosition(),maxValue:i,opacity:this.options.fillOpacity,direction:new R(-1,.2,0),max:u,min:a});if(this.options.height<=.1)return this.material=h,h;let c=this.getCenter(),f=new R(-1,.2,1).normalize(),{max:d,min:p}=this.getMaxAndMin(c,f),m=this.context.materialFactory.createShaderMaterial({gradualColor:[ht(this.options.gradualColor[0],this.options.colorFactor),ht(this.options.gradualColor[1],this.options.colorFactor)],center:this.getCenter(),maxValue:i,opacity:this.options.fillOpacity,direction:new R(-1,.2,1),max:d,min:p});return this.material=[h,m],[h,m]}initMaterial(){return this.options.renderType==="gradual"?this.initGradualMaterial():this.initSingleMaterial()}initLineMaterial(){let t=this.context.materialFactory.createLineMaterial({color:this.options.strokeColor,opacity:this.options.strokeOpacity});return this.lineMaterial=t,t}initMesh(){this.mesh&&this.remove(this.mesh),this.mesh=new $n(this.geometry,this.material),this.add(this.mesh)}getBorderPoints(){let t=[],e=this.options.height+this.options.deltaHeight,{coords:r}=this.options.geometry;for(let i=0;i<r.length;i++){let s=r[i];for(let l=0;l<s.length;l++){let u=s[l],a=l+1===s.length?s[0]:s[l+1];t.push(new R(u[0],u[1],e)),t.push(new R(a[0],a[1],e))}}return t}initLineGeometry(){this.lineGeometry&&this.lineGeometry.dispose();let t=this.getBorderPoints(),e=new Jn().setFromPoints(t);this.lineGeometry=e}createBorder(){this.line&&this.remove(this.line);let t=new Qn(this.lineGeometry,this.lineMaterial);return t.position.z=this.options.airHeight+.01,this.line=t,this.add(t),t}raycast(t){if(!this.visible||this.options.geometry.type==="point")return!1;this.mesh.updateMatrixWorld(!0);let e=t.intersectObject(this.mesh);if(e[0]){let{point:r,distance:i}=e[0];return{position:r,distance:i}}return!1}dispose(){this.geometry.dispose(),this.line?.geometry.dispose(),this.clear()}};import{Object3D as er,PlaneGeometry as nr,Mesh as rr,ShadowMaterial as ir,Color as or,DoubleSide as sr}from"three";var gt=class extends er{directionalLight;plane;basicOpacity=.07;constructor(){super(),this.directionalLight=this.initLight(),this.initPlane()}initLight(){let n=ae(16777215,.5);return n.position.set(0,0,100),this.add(n),n}changeLightCamera(n){let t=n.x,e=n.y;this.directionalLight.shadow.camera.left=-t,this.directionalLight.shadow.camera.right=t,this.directionalLight.shadow.camera.top=e,this.directionalLight.shadow.camera.bottom=-e,this.directionalLight.shadow.camera.near=.5,this.directionalLight.shadow.camera.far=Math.max(t,e)}changeLightColor(n){this.directionalLight.color=new or(n)}setPosition(n){this.position.copy(n),this.directionalLight.position.set(-n.x/2,-n.y/2,100)}initPlane(n=1e3,t=1e3){let e=new nr(n,t),r=new ir({transparent:!0,opacity:0,side:sr}),i=new rr(e,r);return i.receiveShadow=!0,i.position.z=-10,this.add(i),this.plane=i,i}setTarget(n){this.directionalLight.target=n}transformOpacity(n){return n*this.basicOpacity}setOpacity(n){this.plane.material.opacity=this.transformOpacity(n)}dispose(){O(this,!0)}};import{EventDispatcher as hr,Vector3 as cr}from"three";import{Box3 as je,EventDispatcher as ar,Vector3 as _}from"three";import{debounce as lr}from"lodash";var ur={autoUpdate:!0,appendToBody:!1,autoChangePlacement:!1},mt=class extends ar{constructor(t,e={}){super();this.context=t;this.options={...ur,...e},this.registryEvent(),this.div=this.initDiv(),this.options.appendToBody?document.body.appendChild(this.div):this.context.container.appendChild(this.div)}div;element;position=new _;clientPos={x:0,y:0};visible=!0;options;placement="top";observer=null;initObserver(){let t=new MutationObserver(lr(()=>{this.div&&this.usePlacement()},100));t.observe(this.div,{childList:!0,subtree:!0,attributes:!0}),this.observer=t}getPlacementPosition(){if(this.element instanceof S&&this.element.options.geometry.type==="polygon"){let{max:i,min:s}=new je().setFromObject(this.element),l=(i.x+s.x)/2,u=(i.y+s.y)/2;return{left:new _(s.x,u,i.z),leftTop:new _(s.x,i.y,i.z),top:new _(l,i.y,i.z),rightTop:new _(i.x,i.y,i.z),right:new _(i.x,u,i.z),rightBottom:new _(i.x,s.y,i.z),bottom:new _(l,s.y,i.z),leftBottom:new _(s.x,s.y,i.z),center:new _(l,u,i.z)}}let{x:t,y:e,z:r}=this.element?.getPosition?.()||this.position;return{left:new _(t,e,r),leftTop:new _(t,e,r),top:new _(t,e,r),rightTop:new _(t,e,r),right:new _(t,e,r),rightBottom:new _(t,e,r),bottom:new _(t,e,r),leftBottom:new _(t,e,r),center:new _(t,e,r)}}getPlacementScreenPosition(){let{width:t,height:e}=this.context.clientSize,r=this.getPlacementPosition();return Object.keys(r).reduce((i,s)=>{let{x:l,y:u}=y(r[s],this.context.camera,t,e);return i[s]={x:l,y:u},i},{})}checkOverflow(t,e){let{width:r,height:i}=this.context.clientSize;return e.x>0&&t.x<r&&e.y<i&&t.y>0}getPlacement(){let{clientWidth:t,clientHeight:e}=this.div,r=this.getPlacementScreenPosition(),i=t/2,s=e/2,l=[{type:"center",getBox(u,a){return{max:{x:i+u,y:a-e},min:{x:u-i,y:a}}}},{type:"left",getBox(u,a){return{max:{x:u,y:a-s},min:{x:u-t,y:a+s}}}},{type:"leftTop",getBox(u,a){return{max:{x:u,y:a-e},min:{x:u-t,y:a}}}},{type:"top",getBox(u,a){return{max:{x:u+i,y:a-e},min:{x:u-i,y:a}}}},{type:"rightTop",getBox(u,a){return{max:{x:u+t,y:a-e},min:{x:u,y:a}}}},{type:"right",getBox(u,a){return{max:{x:u+t,y:a-s},min:{x:u,y:a+s}}}},{type:"rightBottom",getBox(u,a){return{max:{x:u+t,y:a},min:{x:u,y:a+e}}}},{type:"bottom",getBox(u,a){return{max:{x:u+i,y:a},min:{x:u-i,y:a+e}}}},{type:"leftBottom",getBox(u,a){return{max:{x:u,y:a},min:{x:u-t,y:a+s}}}}];for(let u=0;u<l.length;u++){let a=l[u],h=r[a.type],{max:c,min:f}=a.getBox(h.x,h.y);if(this.checkOverflow(c,f))return{type:a.type,position:h}}return{type:"center",position:r.center}}initDiv(){let t=document.createElement("div");return t.style.position="absolute",t}usePlacement(){let t=this.getPlacement();this.div.className=`overlay_${t.type}`,this._updatePosition(t.position.x,t.position.y)}bindElement(t){this.element=t,this.options.autoChangePlacement&&this.initObserver(),this.onUpdate()}unBindElement(){this.element=void 0}setVisible(t,e="block"){t!==this.visible&&(this.div.style.display=t?e:"none",this.visible=t)}setOpacity(t){this.div.style.opacity=`${t}`}getPosition(){return this.element?typeof this.element.getPosition=="function"?this.element.getPosition():new je().setFromObject(this.element).getCenter(new _):this.position}get withinDisplayRange(){let{x:t,y:e}=this.clientPos,{width:r,height:i}=this.context.clientSize;return t>=0&&t<=r&&e>=0&&e<=i}_updatePosition(t,e){this.clientPos={x:t,y:e};let{width:r,height:i,x:s,y:l}=this.context.clientSize;this.options.appendToBody&&(this.div.style.left=`${s}px`,this.div.style.top=`${l+i}px`),this.options.autoUpdate?this.div.style.transform=`translate3d(${t}px, ${-i+e}px, 0)`:this.dispatchEvent({type:"update-position",x:t,y:e,width:r,height:i})}updatePosition(t=!1){let e=this.getPosition(),{width:r,height:i}=this.context.clientSize,{x:s,y:l}=y(e,this.context.camera,r,i);this.clientPos.x===s&&this.clientPos.y===l&&!t||this._updatePosition(s,l)}onUpdate=()=>{this.options.autoChangePlacement?this.usePlacement():this.updatePosition()};registryEvent(){this.context.addEventListener("update",this.onUpdate)}unRegistryEvent(){this.context.removeEventListener("update",this.onUpdate)}dispose(){this.unRegistryEvent(),this.unBindElement(),this.observer?.disconnect(),this.div?.remove(),this.div=null}};var pr={texts:[{text:""}],level:1,icon_position:"bottom",collision_enable:!0,opacity:1,id:"",position:{x:0,y:0,z:0},icon_opacity:1,icon_border:{color:"#586EE0",width:0},background:"",collision_hide_icon:!0,built_in:!1,box_only_icon:!1},tt=class extends hr{constructor(t,e){super();this.context=t;this.options=X({...pr,...e},this),this.position.set(e.position?.x||0,e.position?.y||0,e.position?.z||0),this.overlay=new mt(this.context,{autoUpdate:!1}),this.overlay.addEventListener("update-position",({x:r,y:i,height:s})=>{this.overlay.div.style.transform=`translate3d(calc(${r}px - 50%), calc(${-s+i}px - ${this.options.icon&&this.options.icon_position!=="center"?"100%":"50%"}), 0)`}),this.overlay.bindElement(this),this.registryEvent(),this.initDiv(),this.addEventListener("change-icon",({value:r})=>{r?this.img?this.img.setAttribute("src",r):(this.addIcon(),this._changePosition()):(this.img&&this.div.removeChild(this.img),this.img=void 0,this._changePosition(),this.resetSize())}),this.addEventListener("change-texts",({value:r})=>{let i=this.textDiv;if(i){let s=this.initText();this.div.replaceChild(s,i)}else this.addText();this.resetSize()}),this.addEventListener("change-opacity",({value:r})=>{this.overlay.setOpacity(r)}),this.addEventListener("change-icon_size",({value:r})=>{this.img&&(this.img.style.width=`${r?.[0]||32}px`,this.img.style.height=`${r?.[1]||32}px`,this.resetSize())}),this.addEventListener("change-icon_opacity",({value:r})=>{this.img&&(this.img.style.opacity=`${r}`)}),this.addEventListener("change-icon_border",({value:r})=>{this.img&&(this.img.style.border=`${r.width}px solid ${r.color}`)}),this.addEventListener("change-background",({value:r})=>{this.div.style.background=r})}div;textDiv;img;overlay;options;visible=!0;size={width:0,height:0};position=new cr;userData={};showTextStatus=!0;disposed=!1;get withinDisplayRange(){return this.overlay.withinDisplayRange}async resetSize(){if(await de(),!this.disposed)if(this.options.box_only_icon){if(!this.img)return;let{width:t,height:e}=this.img.getBoundingClientRect();this.size={width:t+2,height:e+2}}else{let{width:t,height:e}=this.div.getBoundingClientRect();this.size={width:t+2,height:e+2}}}renderHelperBox(){}get clientPos(){return this.overlay.clientPos}initDiv(){let t=document.createElement("div");return this.div=t,this.addText(),this.options.icon&&this.addIcon(),t.style.fontSize="12px",t.style.textShadow="#fff 1px 0 0, #fff 0 1px 0, #fff -1px 0 0, #fff 0 -1px 0",t.style.display="flex",t.style.flexDirection="column",t.style.justifyContent="center",t.style.alignItems="center",t.style.padding="4px",this.overlay.setOpacity(this.options.opacity),this.overlay.div.style.pointerEvents="none",this.overlay.div.style.userSelect="none",this.overlay.div.appendChild(t),this.resetSize(),t}addIcon(){if(!this.img){let t=this.initIcon();this.options.icon_position==="top"?this.div.firstChild?this.div.insertBefore(t,this.div.firstChild):this.div.appendChild(t):this.div.appendChild(t)}}addText(){let t=this.initText();this.options.icon_position==="top"?this.div.appendChild(t):this.div.firstChild?this.div.insertBefore(t,this.div.firstChild):this.div.appendChild(t)}getPosition(){return this.position}initText(){let t=document.createElement("div");return t.appendChild(this.createTextFragment()),t.style.textAlign="center",this.textDiv=t,t}createTextFragment(){let t=document.createDocumentFragment();return this.options.texts.forEach(e=>{let r=document.createElement("div");if(r.style.whiteSpace="nowrap",e.styles)for(let[i,s]of Object.entries(e.styles))r.style[i]=s;r.textContent=e.text,t.appendChild(r)}),t}initIcon(){let t=document.createElement("img");return t.setAttribute("src",this.options.icon),t.style.width=`${this.options.icon_size?.[0]||32}px`,t.style.height=`${this.options.icon_size?.[1]||32}px`,t.style.opacity=`${this.options.icon_opacity}px`,t.style.borderRadius="50%",this.options.icon_border.width&&(t.style.border=`${this.options.icon_border.width}px solid ${this.options.icon_border.color}`),t.onload=()=>{this.resetSize()},this.img=t,t}_changePosition=()=>{this.overlay.updatePosition(!0)};registryEvent(){}unRegistryEvent(){}setVisible(t){t!==this.visible&&(this.visible=t,this.changeOverlayVisible(t))}changeOverlayVisible(t){if(!(t===this.overlay.visible&&this.options.collision_hide_icon))if(this.options.collision_hide_icon)this.overlay.visible=t,this.overlay.div.style.visibility=t?"visible":"hidden";else{if(this.showTextStatus===t)return;this.textDiv.style.visibility=t?"visible":"hidden",this.showTextStatus=t}}parentSetVisible(t){this.visible&&this.changeOverlayVisible(t)}getBox(t=this.context.config.poi.boxScale){let{width:e,height:r}=this.size,i=e*t,s=r*t,{x:l,y:u}=this.overlay.clientPos;return{left:l-i/2,right:l+i/2,top:this.options.icon?u-s:u-s/2,bottom:this.options.icon?u:u+s/2}}getOriginBox(){return this.getBox(1)}isContain(t,e){if(!this.overlay.visible||!this.visible)return!1;let r=this.getOriginBox();return t>=r.left&&t<=r.right&&e>=r.top&&e<=r.bottom}dispose(){this.unRegistryEvent(),this.div=null,this.textDiv=null,this.img=void 0,this.overlay.dispose(),this.disposed=!0}};import{Box3 as bt,Group as Fr,Object3D as qt,Vector3 as Mt}from"three";import{Box3 as dr,Vector3 as gr}from"three";import{Object3D as fr}from"three";var Y=class extends fr{constructor(t){super();this.context=t}dispose(){O(this),this.clear()}};var yt=class extends Y{graphicMap=new Map;constructor(n){super(n)}getCenter(){return new dr().setFromObject(this).getCenter(new gr)}createGraphic(n){let t=new S(this.context,n);return this.add(t),this.graphicMap.set(n.id,t),t}removeGraphic(n){this.remove(n),this.graphicMap.delete(n.options.id),n.dispose()}removeGraphicById(n){this.graphicMap.has(n)&&this.removeGraphic(this.graphicMap.get(n))}getGraphicByNodeId(n){return this.graphicMap.get(n)||null}getGraphicByRaycaster(n){let t={distance:1e4,graphic:null,position:null},e=this.children.reduce((r,i)=>{if(i instanceof S){let s=i.raycast(n);if(s){let{distance:l}=s;if(l<r.distance)return{distance:s.distance,position:s.position,graphic:i}}return r}else return r},t);return e===t?{graphics:[],position:null}:{graphics:[e.graphic],position:e.position}}};import{debounce as mr}from"lodash";var _t=class extends Y{pois=[];debounceCollisionDetection;timer=new L;constructor(n){super(n),this.registryEvent(),this.debounceCollisionDetection=mr(this.collisionDetection,10)}clear(n=!1){return this.pois.forEach(t=>{t.options.built_in&&!n||t.dispose()}),this.pois=n?[]:this.pois.filter(t=>t.options.built_in),this}createPoi(n){let t=new tt(this.context,n);return this.pushPoi(t),t.addEventListener("change-level",()=>this.changePoiLevelOrCollisionEnable(t)),t.addEventListener("change-collision_enable",()=>this.changePoiLevelOrCollisionEnable(t)),Promise.resolve().then(()=>{this.debounceCollisionDetection()}),t}changePoiLevelOrCollisionEnable(n){let t=this.pois.findIndex(e=>e===n);t!==-1&&(this.pois.splice(t,1),this.pushPoi(n))}removePoi(n){let t=this.pois.findIndex(e=>e===n);t!==-1&&(this.pois.splice(t,1),n.dispose())}removePoiById(n){let t=this.pois.find(e=>e.options.id===n);t&&this.removePoi(t)}getPoiById(n){return this.pois.find(e=>e.options.id===n)||null}pushPoi(n){if(!n.options.collision_enable){this.pois.unshift(n);return}if(n.options.level===0){this.pois.push(n);return}for(let t=0;t<this.pois.length;t++){let e=this.pois[t];if(e.options.collision_enable&&e.options.level<=n.options.level){this.pois.splice(t,0,n);return}}this.pois.push(n)}getPoiByDeviceXy(n,t){return this.pois.filter(r=>r instanceof tt&&r.isContain(n,t))}onUpdate=()=>{this.timer.requestAnimationFrame(()=>{this.collisionDetection()})};collisionDetection(){let n=[];this.pois.filter(e=>e.visible&&e.withinDisplayRange).forEach((e,r)=>{let{left:i,right:s,top:l,bottom:u}=e.getBox();if(r===0||!e.options.collision_enable){n.push({left:i,right:s,top:l,bottom:u}),e.parentSetVisible(!0);return}let a=n.some(h=>h.left<s&&h.right>i&&h.top<u&&h.bottom>l);e.parentSetVisible(!a),a||n.push({left:i,right:s,top:l,bottom:u})})}registryEvent(){this.context.addEventListener("update",this.onUpdate)}unRegistryEvent(){this.context.removeEventListener("update",this.onUpdate)}dispose(){this.timer.dispose(),this.pois.forEach(n=>n.dispose()),this.pois.length=0,this.debounceCollisionDetection=()=>{},super.dispose(),this.unRegistryEvent()}};import{MeshBasicMaterial as yr,Object3D as _r,PlaneGeometry as vr,Texture as xr,DoubleSide as Er,Mesh as br,Matrix3 as Ye,Vector2 as Mr}from"three";import{create as Sr}from"@mars3d/heatmap.js";import{featureCollection as wr,point as Tr,bbox as Cr,center as Pr}from"@turf/turf";var vt=class extends _r{constructor(t){super();this.context=t;this.div=document.createElement("div")}heatmap;div;plane;clearHeatmap(){this.div.firstChild&&this.div.removeChild(this.div.firstChild),this.heatmap=void 0}loadData(t){this.clearHeatmap();let{width:e,height:r,leftTop:i,center:s}=this.getBox(t);this.heatmap=Sr({width:e,height:r,container:this.div,...this.context.config.heatMap}),this.heatmap.setData(this.transformData(t,i)),this.initPlane(e,r),this.position.set(s[0],s[1],this.position.z)}initPlane(t,e){this.plane&&this.remove(this.plane);let r=new vr(t,e),i=new xr(this.div.firstChild);i.needsUpdate=!0;let s=new yr({transparent:!0,side:Er,map:i});s.needsUpdate=!0,this.plane=new br(r,s),this.add(this.plane)}getTransMatrix({x:t,y:e}){return new Ye().makeScale(1,-1).multiply(new Ye().makeTranslation(0-t,0-e))}transformData(t,e){let r=this.getTransMatrix(e);return{data:t.data.map(s=>{let l=new Mr(s.x,s.y).applyMatrix3(r);return{x:l.x,y:l.y,value:s.value}}),max:t.max,min:t.min}}getBox(t){let e=wr(t.data.map(a=>Tr([a.x,a.y]))),r=Cr(e),i=r[2]-r[0],s=r[3]-r[1],l={x:r[0],y:r[3]},u=Pr(e);return{width:i,height:s,leftTop:l,center:u.geometry.coordinates}}dispose(){this.div=null,this.heatmap=void 0}};import{Box3 as Ar,Object3D as Rr,Vector3 as Ze}from"three";var xt=class extends Rr{constructor(t,e){super();this.context=t;this.options=e;this.position.copy(e.position||new Ze(0,0,0)),this.loadModel()}poi=null;model=null;async loadModel(){let t=await ge(this.options.modelUrl);t.scene.rotation.set(Math.PI/2,Math.PI/2,0),this.add(t.scene),this.model=t,this.initPoi()}initPoi(){if(!this.options.icon)return;let t=this.context.currentFloor?.addPoi({icon:this.options.icon,icon_size:this.options.icon_size,built_in:!0,level:0});this.poi=t||null,this.model&&t&&(t.position=new Ar().setFromObject(this).getCenter(new Ze))}dispose(){O(this),this.model=null,this.poi&&(this.context.currentFloor?.poiLayer.removePoi(this.poi),this.poi=null)}};import{Euler as Lr,Mesh as Ir,Object3D as Nr,PlaneGeometry as Or}from"three";var Dr={uuid:"",url:"",name:"",angleX:0,angleY:0,angleZ:0,width:0,height:0,center:[0,0],opacity:1,visible:!0},Et=class extends Nr{constructor(t,e){super();this.context=t;this.options=X({...Dr,...e},this),this.init()}options;mesh;async init(){let{width:t,height:e,center:r,url:i,opacity:s,angleX:l,angleY:u,angleZ:a}=this.options,h=new Or(t,e),c=await this.context.materialFactory.createGroundTextureMaterial({url:i,opacity:s}),f=new Ir(h,c);this.mesh=f,this.mesh.position.set(r[0],r[1],0),f.setRotationFromEuler(new Lr(l,u,a)),this.add(f)}dispose(){this.mesh?.geometry.dispose(),this.clear()}};var St=class extends qt{constructor(t){super();this.context=t;this.graphicLayer=new yt(this.context),this.poiLayer=new _t(this.context),this.groundUpper.add(this.graphicLayer),this.groundUpper.add(this.poiLayer),this.groundUpper.add(this.groundTextures),this.add(this.groundUpper),this.add(this.models)}graphicLayer;poiLayer;grounds=new Set;shadow=new gt;heatmap;groundUpper=new qt;models=new qt;modelMap=new Map;groundTextures=new Fr;groundMaxHeight=0;name="";key="";getPosition(){return new bt().setFromObject(this.groundUpper).getCenter(new Mt)}createGround(t){let e=new S(this.context,t);this.addGrounds([e])}addGrounds(t){t.forEach(e=>{this.grounds.has(e)||(e.mesh.castShadow=!0,this.grounds.add(e),this.groundUpper.add(e))}),this.changeGroundMaxHeight()}changeGroundMaxHeight(){let t=Array.from(this.grounds);this.groundMaxHeight=this.grounds.size>0?Math.max(...t.map(e=>e.options.height+e.options.airHeight+e.options.deltaHeight)):0,this.graphicLayer.position.z=this.groundMaxHeight,this.models.position.z=this.groundMaxHeight}get hasElement(){return!!(this.grounds.size||this.graphicLayer.children.length)}getCenter(){return new bt().setFromObject(this.groundUpper).getCenter(new Mt)}addModel(t){let e=new xt(this.context,t);return this.models.add(e),this.modelMap.set(t.id,e),e}addShadow(){let t=new bt().setFromObject(this.groundUpper),e=t.getCenter(new Mt),r=t.getSize(new Mt);this.shadow.setPosition(e),this.shadow.changeLightCamera(r)}addGraphic(t){return this.graphicLayer.createGraphic(t)}addPoi(t){return this.poiLayer.createPoi(t)}addGroundTexture(t){let e=new Et(this.context,t);this.groundTextures.add(e)}addHeatmap(t){this.heatmap||(this.heatmap=new vt(this.context),this.add(this.heatmap)),this.heatmap.loadData(t);let e=new bt().setFromObject(this.graphicLayer);return this.heatmap.position.setZ(e.max.z),this.heatmap}removeHeatMap(){this.heatmap&&(this.remove(this.heatmap),this.heatmap.dispose(),this.heatmap=void 0)}setShadowOpacity(t){this.shadow.setOpacity(t)}setShadowVisible(t){this.shadow.visible=t}dispose(){this.shadow.dispose(),this.graphicLayer.dispose(),this.poiLayer.dispose(),this.grounds.forEach(t=>t.dispose()),this.groundTextures.children.forEach(t=>t.dispose()),this.groundTextures.clear(),this.heatmap?.dispose(),this.groundUpper.clear(),this.models.children.forEach(t=>t.dispose()),this.models.clear(),this.modelMap.clear(),this.clear()}};import{EventDispatcher as Ur,Vector3 as Br}from"three";var N=class extends Ur{constructor(t){super();this.context=t;this.svg=fe(`${t.container.clientWidth}`,`${t.container.clientHeight}`),t.container.appendChild(this.svg),this._registryEvent()}points=[];svg;enable=!0;_onResize=({width:t,height:e})=>{this.svg&&(this.svg.setAttribute("width",`${t}`),this.svg.setAttribute("height",`${e}`))};_registryEvent(){this.context.addEventListener("resize",this._onResize)}_unRegistryEvent(){this.context.removeEventListener("resize",this._onResize)}setEnable(t){this.enable=t,t?this.svg.style.display="block":this.svg.style.display="none"}getIntersectByPointerEvent(t){let{camera:e,renderer:r}=this.context,{offsetX:i,offsetY:s}=t,{clientWidth:l,clientHeight:u}=r.domElement,a=i/l*2-1,h=1-s/u*2;return new Br(a,h,0).unproject(e)}getSvgCoordinate(t){let{camera:e,container:r}=this.context;return y(t,e,r.clientWidth,r.clientHeight)}dispose(){this._unRegistryEvent(),this.context.container.removeChild(this.svg),this.svg=null}};var wt=class extends N{constructor(t){super(t);this.context=t;let{config:{svg:{circle:e,line:r}}}=t;this.circles=[K(e.radius,e.fill),K(e.radius,e.fill)],this.line=ut(r.stroke),this.svg.appendChild(this.circles[0]),this.svg.appendChild(this.circles[1]),this.svg.appendChild(this.line),this.registryEvent()}circles;line;setEnable(t){super.setEnable(t),t?this.registryEvent():this.unRegistryEvent()}registryEvent(){this.context.container.addEventListener("pointerenter",this.onPointermove),this.context.container.addEventListener("pointermove",this.onPointermove),this.context.container.addEventListener("pointerleave",this.onPointerleave),this.context.container.addEventListener("pointerdown",this.onPointerdown),this.context.addEventListener("update",this.onUpdate)}unRegistryEvent(){this.context.container.removeEventListener("pointerenter",this.onPointermove),this.context.container.removeEventListener("pointermove",this.onPointermove),this.context.container.removeEventListener("pointerleave",this.onPointerleave),this.context.container.removeEventListener("pointerdown",this.onPointerdown),this.context.removeEventListener("update",this.onUpdate)}onUpdate=()=>{if(this.points[0]){let t=this.getSvgCoordinate(this.points[0]);H(this.circles[0],t.x,t.y),C(this.line,t)}if(this.points[1]){let t=this.getSvgCoordinate(this.points[1]);H(this.circles[1],t.x,t.y),C(this.line,void 0,t)}};onPointermove=t=>{this.points.length===1&&(this.line.style.display="block",C(this.line,void 0,{x:t.offsetX,y:t.offsetY}))};onPointerleave=()=>{this.points[1]||(this.line.style.display="none")};onPointerdown=t=>{if(this.points[1])return;let e=this.getIntersectByPointerEvent(t);if(e){let{offsetX:r,offsetY:i}=t,s=this.circles[this.points.length];H(s,r,i),this.points.length||C(this.line,{x:r,y:i},{x:r,y:i}),this.addPoint(e)}};addPoint(t){if(this.points.push(t),this.points.length>=2){let e=this.calculatedDistance();this.dispatchEvent({type:"distance",distance:e})}}calculatedDistance(){let[{x:t,y:e},{x:r,y:i}]=this.points;return Math.sqrt((r-t)**2+(i-e)**2)}dispose(){super.dispose(),this.unRegistryEvent(),this.line=null,this.circles=[]}};var Tt=class extends N{circles=[];lines=[];isClose=!1;constructor(n){super(n),this.registryEvent()}setEnable(n){super.setEnable(n),n?this.registryEvent():this.unRegistryEvent()}get lastLine(){return this.lines.slice(-1)[0]}addCircle(n){this.circles.push(n),this.svg.appendChild(n)}addLine(n){this.lines.push(n),this.svg.appendChild(n)}registryEvent(){this.context.container.addEventListener("pointerenter",this.onPointermove),this.context.container.addEventListener("pointermove",this.onPointermove),this.context.container.addEventListener("pointerleave",this.onPointerleave),this.context.container.addEventListener("pointerdown",this.onPointerdown),this.context.addEventListener("update",this.onUpdate)}unRegistryEvent(){this.context.container.removeEventListener("pointerenter",this.onPointermove),this.context.container.removeEventListener("pointermove",this.onPointermove),this.context.container.removeEventListener("pointerleave",this.onPointerleave),this.context.container.removeEventListener("pointerdown",this.onPointerdown),this.context.removeEventListener("update",this.onUpdate)}onUpdate=()=>{this.points.length&&this.points.forEach((n,t)=>{let e=this.getSvgCoordinate(n);this.circles[t]&&H(this.circles[t],e.x,e.y),t!==0&&C(this.lines[t-1],void 0,e),this.lines[t]&&C(this.lines[t],e)})};onPointermove=n=>{!this.lastLine||this.isClose||(this.lastLine.style.display="block",C(this.lastLine,void 0,{x:n.offsetX,y:n.offsetY}))};onPointerleave=()=>{this.isClose||(this.lastLine.style.display="none")};onPointerdown=n=>{if(this.isClose)return;let t=this.getIntersectByPointerEvent(n);if(t){let{offsetX:e,offsetY:r}=n;this.checkAdsorb(e,r)?(this.isClose=!0,this.addPoint(this.points[0])):this.addPoint(t);let{circle:{fill:i,radius:s},line:{stroke:l}}=this.context.config.svg;if(!this.isClose){let u=K(s,i);H(u,e,r),this.addCircle(u)}if(this.lines.length&&C(this.lastLine,void 0,{x:e,y:r}),!this.isClose){let u=ut(l);C(u,{x:e,y:r},{x:e,y:r}),this.addLine(u)}}};checkAdsorb(n,t){if(this.points.length<3)return!1;let e=this.circles[0],r=+e.getAttribute("cx"),i=+e.getAttribute("cy");return Math.sqrt((n-r)**2+(t-i)**2)<=5}addPoint(n){if(this.points.push(n),this.isClose){let t=this.calculatedArea();this.dispatchEvent({type:"area",area:t})}}calculatedArea(){let n=this.points.map(r=>[r.x,r.y]),t=0,e=n.length;for(let r=0;r<e;r++){let i=(r+1)%e;t+=n[r][0]*n[i][1]-n[i][0]*n[r][1]}return Math.abs(t/2)}dispose(){super.dispose(),this.unRegistryEvent(),this.lines=[],this.circles=[]}};import{Box3 as Gr}from"three";var Ke=class extends N{constructor(t){super(t);this.context=t;let{config:{svg:{line:e}}}=t;this.rect=q(e.stroke,"transparent"),this.svg.appendChild(this.rect);for(let r=0;r<4;r++)this.cornerRect[r]=q(e.stroke,"#ffffff"),this.centerRect[r]=q(e.stroke,"#ffffff"),this.svg.appendChild(this.cornerRect[r]),this.svg.appendChild(this.centerRect[r]);this.registryEvent()}rect;cornerRect=[];centerRect=[];graphic;setEnable(t){super.setEnable(t),t?this.registryEvent():this.unRegistryEvent()}registryEvent(){this.context.addEventListener("update",this.onUpdate)}unRegistryEvent(){this.context.removeEventListener("update",this.onUpdate)}onUpdate=()=>{if(this.graphic){let t=new Gr().setFromObject(this.graphic),{camera:e,container:{clientWidth:r,clientHeight:i}}=this.context,{min:s,max:l}=t,u=y(s,e,r,i),a=y(l,e,r,i);P(this.rect,u.x,a.y,Math.abs(a.x-u.x),Math.abs(a.y-u.y));let{x:h,y:c}=u,{x:f,y:d}=a,p=5,m=[{x:h-p,y:d-p},{x:f-p,y:d-p},{x:h-p,y:c-p},{x:f-p,y:c-p}];for(let v=0;v<m.length;v++)P(this.cornerRect[v],m[v].x,m[v].y,p*2,p*2);let g=4,x=(h+f)/2,E=(c+d)/2,b=[{x:x-g,y:d-g},{x:h-g,y:E-g},{x:f-g,y:E-g},{x:x-g,y:c-g}];for(let v=0;v<b.length;v++)P(this.centerRect[v],b[v].x,b[v].y,g*2,g*2)}else{P(this.rect,0,0,0,0);for(let t=0;t<this.cornerRect.length;t++)P(this.cornerRect[t],0,0,0,0),P(this.centerRect[t],0,0,0,0)}};selectGraphic(t){this.graphic=t}dispose(){super.dispose(),this.unRegistryEvent(),this.rect=null,this.cornerRect=[],this.centerRect=[]}};import{Frustum as zr}from"three";var Ct=class extends N{startPoint;endPoint;rect;frustum=new zr;constructor(n){super(n);let{config:{selectBox:{fill:t,stroke:e}}}=n;this.rect=q(e,t),this.svg.appendChild(this.rect),this.registryEvent()}setEnable(n){super.setEnable(n),P(this.rect,0,0,0,0),n?this.registryEvent():(this.startPoint=void 0,this.unRegistryEvent())}onPointerDown=n=>{if(!this.enable)return;let t=this.getIntersectByPointerEvent(n);t&&(this.startPoint=t),this.endPoint=void 0};onPointerMove=n=>{if(!this.enable||!this.startPoint)return;let t=this.getIntersectByPointerEvent(n);t&&(this.endPoint=t)};onPointerUp=n=>{if(!this.enable)return;let t=this.getIntersectByPointerEvent(n);t&&(this.endPoint=t),this.doSelect(),this.startPoint=void 0};onUpdate=()=>{if(this.startPoint){let n=this.getSvgCoordinate(this.startPoint),t={...n};this.endPoint&&(t=this.getSvgCoordinate(this.endPoint));let e={x:Math.min(n.x,t.x),y:Math.min(n.y,t.y)},r=Math.abs(t.x-n.x),i=Math.abs(t.y-n.y);P(this.rect,e.x,e.y,r,i)}else P(this.rect,0,0,0,0)};registryEvent(){this.context.container.addEventListener("pointerdown",this.onPointerDown),this.context.container.addEventListener("pointermove",this.onPointerMove),this.context.container.addEventListener("pointerup",this.onPointerUp),this.context.addEventListener("update",this.onUpdate)}unRegistryEvent(){this.context.container.removeEventListener("pointerdown",this.onPointerDown),this.context.container.removeEventListener("pointermove",this.onPointerMove),this.context.container.removeEventListener("pointerup",this.onPointerUp),this.context.removeEventListener("update",this.onUpdate)}doSelect(){if(this.startPoint&&this.endPoint){if(this.startPoint.distanceTo(this.endPoint)<.1)return;let{context:{camera:t,container:{clientWidth:e,clientHeight:r}}}=this,i=y(this.startPoint,t,e,r),s=y(this.endPoint,t,e,r),l={x:Math.min(i.x,s.x),y:Math.min(i.y,s.y)},u={x:Math.max(i.x,s.x),y:Math.max(i.y,s.y)},a=this.searchMapInFrustum(l,u);this.dispatchEvent({type:"selected",list:a})}}searchMapInFrustum(n,t){let{context:e}=this;return e.currentFloor?.graphicLayer.children.filter(r=>r instanceof S&&this.searchChildInFrustum(r,n,t))||[]}searchChildInFrustum(n,t,e){let{context:{camera:r,container:{clientWidth:i,clientHeight:s}}}=this;if(!n)return!1;if(!n.mesh){let f=n.getPosition();if(f){let d=y(f,r,i,s);return st(d,t,e)}return!1}n.mesh.geometry.boundingBox||n.mesh.geometry.computeBoundingBox();let l=n.mesh.geometry.boundingBox;if(!l)return!1;let{min:u,max:a}=l,h=y(u,r,i,s),c=y(a,r,i,s);return!(!st(h,t,e)||!st(c,t,e))}dispose(){this.unRegistryEvent()}};var Pt=class extends kr{constructor(t){super();this.context=t;this.boxSelection=new Ct(t),this.boxSelection.setEnable(!1),this.registryEvent()}_list=new Set;boxSelection;prevPanStatus;prevRotateStatus;downPoint=null;isMultipleSelect=!1;get list(){return this._list}enableBoxSelection(){this.isMultipleSelect||(this.isMultipleSelect=!0,this.boxSelection.setEnable(!0),this.prevPanStatus=this.context.control.enablePan,this.prevRotateStatus=this.context.control.enableRotate,this.context.control.enablePan=!1,this.context.control.enableRotate=!1)}disableBoxSelection(){this.isMultipleSelect&&(this.isMultipleSelect=!1,this.boxSelection.setEnable(!1),this.context.control.enablePan=!!this.prevPanStatus,this.context.control.enableRotate=!!this.prevRotateStatus)}onPointerDown=t=>{this.downPoint={x:t.offsetX,y:t.offsetY}};onPointerUp=t=>{if(!this.downPoint)return;let{offsetX:e,offsetY:r}=t,{x:i,y:s}=this.downPoint;if(Math.sqrt((i-e)**2+(s-r)**2)>3)return;let{graphics:l}=this.context.getGraphicsByDeviceXy(e,r),u=new Set(l.map(h=>h.options.id));this.context.getPoisByDeviceXy(e,r).forEach(h=>{if(!u.has(h.options.id)){let c=this.context.currentFloor?.graphicLayer.graphicMap.get(h.options.id)||null;c&&c.options.geometry.type==="point"&&(l.push(c),u.add(h.options.id))}}),(ft?t.metaKey:t.ctrlKey)||this._list.clear(),l.forEach(h=>this._list.add(h)),this.selectEnd(),this.downPoint=null};onPointerOut=t=>{this.disableBoxSelection()};onKeyDown=t=>{Vt(t.key)&&this.enableBoxSelection()};onKeyUp=t=>{Vt(t.key)&&this.disableBoxSelection()};onBoxSelected=({list:t})=>{this._list.clear(),t.forEach(e=>{this._list.add(e)}),this.selectEnd()};selectEnd(){this.dispatchEvent({type:"select",graphics:[...this._list],isMultipleSelect:this.isMultipleSelect})}registryEvent(){this.context.container.addEventListener("pointerdown",this.onPointerDown),this.context.container.addEventListener("pointerup",this.onPointerUp),this.context.container.addEventListener("pointerout",this.onPointerOut),this.context.container.addEventListener("pointercancel",this.onPointerOut),window.addEventListener("keydown",this.onKeyDown),window.addEventListener("keyup",this.onKeyUp),this.boxSelection.addEventListener("selected",this.onBoxSelected)}unRegistryEvent(){this.context.container.removeEventListener("pointerdown",this.onPointerDown),this.context.container.removeEventListener("pointerup",this.onPointerUp),this.context.container.removeEventListener("pointerout",this.onPointerOut),this.context.container.removeEventListener("pointercancel",this.onPointerOut),window.removeEventListener("keydown",this.onKeyDown),window.removeEventListener("keyup",this.onKeyUp),this.boxSelection.removeEventListener("selected",this.onBoxSelected)}clear(){this._list.clear()}remove(t){this._list.delete(t)}dispose(){this.unRegistryEvent()}};import{EventDispatcher as Vr}from"three";var At=class extends Vr{constructor(t){super();this.context=t;this.registryEvent()}curGraphics=new Set;timer=new L;graphicTimerMap=new Map;onPointerMove=({graphics:t,pois:e,e:r})=>{let i=e.map(a=>this.context.currentFloor?.graphicLayer.graphicMap.get(a.options.id)).filter(a=>a&&a.options.geometry.type==="point");if(!t.length&&!i.length&&this.curGraphics.size){this.curGraphics.clear(),this.handleHoverGraphicsChange();return}let{time:s}=this.context.config.hover,l=new Set;if(i.length){let a,h=1e4;i.forEach(c=>{let f=e.find(g=>g.options.id===c.options.id),{x:d,y:p}=f.clientPos,m=Math.sqrt((d-r.offsetX)**2+(p-r.offsetY)**2);m<h&&(h=m,a=c)}),l.add(a)}l.size||t.forEach(a=>l.add(a)),l.forEach(a=>{if(this.graphicTimerMap.get(a)||this.curGraphics.has(a))return;let h=this.timer.setTimeout(()=>{this.curGraphics.add(a),this.graphicTimerMap.delete(a),this.timer.clearTimeout(h),this.handleHoverGraphicsChange()},s);this.graphicTimerMap.set(a,h)}),this.graphicTimerMap.forEach((a,h)=>{l.has(h)||(this.timer.clearTimeout(a),this.graphicTimerMap.delete(h))});let u=this.curGraphics.size;this.curGraphics.forEach(a=>{l.has(a)||this.curGraphics.delete(a)}),u!==this.curGraphics.size&&this.handleHoverGraphicsChange()};onPointerLevel=()=>{this.curGraphics.clear(),this.handleHoverGraphicsChange()};onBodyPointerMove=t=>{if(this.curGraphics.size){let e=this.context.container.getBoundingClientRect();(t.clientX<e.left||t.clientX>e.right||t.clientY<e.top||t.clientY>e.bottom)&&this.onPointerLevel()}};handleHoverGraphicsChange(t=this.curGraphics){this.dispatchEvent({type:"hover-change",graphics:Array.from(t)})}registryEvent(){this.context.addEventListener("pointer-over",this.onPointerMove),this.context.addEventListener("pointer-move",this.onPointerMove),this.context.addEventListener("pointer-level",this.onPointerLevel),document.body.addEventListener("pointermove",this.onBodyPointerMove)}unRegistryEvent(){this.context.removeEventListener("pointer-over",this.onPointerMove),this.context.removeEventListener("pointer-move",this.onPointerMove),this.context.removeEventListener("pointer-level",this.onPointerLevel),document.body.removeEventListener("pointermove",this.onBodyPointerMove)}dispose(){this.unRegistryEvent(),this.timer.dispose()}};import{Color as Rt,LineBasicMaterial as Hr,MeshStandardMaterial as Wr,MeshBasicMaterial as $e,ShaderMaterial as Xr,DoubleSide as qr}from"three";function Je(o){return`${o.x}-${o.y}-${o.z}`}var Lt=class{constructor(n){this.context=n}lineMaterialMap=new Map;meshStandardMaterialMap=new Map;meshBasicMaterialMap=new Map;shaderMaterialMap=new Map;groundTextureMaterialMap=new Map;generateLineMaterialKey({color:n,opacity:t}){return`${n}-${t}`}createLineMaterial({color:n,opacity:t}){let e=this.generateLineMaterialKey({color:n,opacity:t});if(this.lineMaterialMap.has(e))return this.lineMaterialMap.get(e);let r=new Hr({color:new Rt(n).convertLinearToSRGB(),transparent:!0,opacity:t});return this.lineMaterialMap.set(e,r),r}createMeshStandardMaterial({color:n,opacity:t}){let e=`${n}-${t}`;if(this.meshStandardMaterialMap.has(e))return this.meshStandardMaterialMap.get(e);let r=new Wr({color:new Rt(n).convertLinearToSRGB(),roughness:1,transparent:!0,opacity:t,depthWrite:!0});return this.meshStandardMaterialMap.set(e,r),r}createMeshBasicMaterial({color:n,opacity:t}){let e=`${n}-${t}`;if(this.meshBasicMaterialMap.has(e))return this.meshBasicMaterialMap.get(e);let r=new $e({color:n,transparent:!0,opacity:t,depthWrite:!0});return this.meshBasicMaterialMap.set(e,r),r}createShaderMaterial({gradualColor:n,center:t,maxValue:e,opacity:r,direction:i,max:s,min:l}){let u=`${n.toString()}-${Je(t)}-${e}-${r}-${Je(i)}`;if(this.shaderMaterialMap.has(u))return this.shaderMaterialMap.get(u);let a=`
|
|
2
2
|
uniform vec3 uColor;
|
|
3
3
|
uniform vec3 uGradualColor;
|
|
4
4
|
uniform vec3 center;
|