@giro3d/piero 1.0.0-beta.2 → 1.0.0-beta.3

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
@@ -1,3 +1,3 @@
1
- "use strict";var W=Object.defineProperty;var X=(c,t,e)=>t in c?W(c,t,{enumerable:!0,configurable:!0,writable:!0,value:e}):c[t]=e;var y=(c,t,e)=>X(c,typeof t!="symbol"?t+"":t,e);Object.defineProperty(exports,Symbol.toStringTag,{value:"Module"});const p=require("./Components.cjs.js"),r=require("vue"),U=require("pinia"),Z=require("@giro3d/giro3d/core/geographic/Coordinates"),R=require("@giro3d/giro3d/entities/Entity3D"),Q=require("@giro3d/giro3d/gui/EntityPanel"),T=require("openbim-components"),J=require("@giro3d/giro3d/gui/EntityInspector"),K=require("@giro3d/giro3d/entities/PointCloud"),ee=require("@giro3d/giro3d/sources/PotreeSource"),F=require("shepherd.js"),Y=U.defineStore("crossSection",()=>{const c=r.ref(0),t=r.ref(new p.Vector3(0,0,0)),e=r.ref(!1);function o(n){e.value=n}function s(n){c.value=n}function i(n){t.value=n}return{center:t,enable:e,orientation:c,setCenter:i,setEnabled:o,setOrientation:s}}),te={class:"input-group mb-3"},ne={class:"input-group mb-3"},oe=["value"],se={class:"input-group mb-3"},ie=["value"],re={class:"input-group"},ae={class:"input-group"},le=["value"],ce=["value"],ue=r.defineComponent({__name:"CrossSection",setup(c){const t=Y();function e(i){t.setOrientation(i)}function o(i){const n=t.center.clone();n.setX(i),t.setCenter(n)}function s(i){const n=t.center.clone();n.setY(i),t.setCenter(n)}return(i,n)=>(r.openBlock(),r.createElementBlock("div",null,[r.createElementVNode("div",te,[r.createVNode(p._sfc_main,{"model-value":r.unref(t).enable,"onUpdate:modelValue":n[0]||(n[0]=l=>r.unref(t).setEnabled(l)),id:"cross-section-enable",title:"foo"},null,8,["model-value"]),n[5]||(n[5]=r.createElementVNode("label",{for:"cross-section-enable",class:"form-label"},"Enable cross section",-1))]),r.createElementVNode("div",ne,[n[6]||(n[6]=r.createElementVNode("label",{for:"plane-orientation-range",class:"form-label"},"Plane orientation (0-360°)",-1)),r.createElementVNode("input",{id:"plane-orientation-range",title:"Altitude",type:"range",class:"form-range",min:"0",step:"0.1",max:"360",value:r.unref(t).orientation,onInput:n[1]||(n[1]=l=>e(Number.parseFloat(l.target.value)))},null,40,oe)]),r.createElementVNode("div",se,[r.createElementVNode("input",{type:"number",class:"form-control",id:"plane-orientation-number",step:"0.1",value:r.unref(t).orientation,onInput:n[2]||(n[2]=l=>e(Number.parseFloat(l.target.value)))},null,40,ie)]),n[8]||(n[8]=r.createElementVNode("hr",null,null,-1)),r.createElementVNode("div",re,[n[7]||(n[7]=r.createElementVNode("label",{class:"form-label"},"Center (x, y)",-1)),r.createElementVNode("div",ae,[r.createElementVNode("input",{type:"number",class:"form-control",id:"plane-center-x",value:r.unref(t).center.x,onInput:n[3]||(n[3]=l=>o(Number.parseFloat(l.target.value)))},null,40,le),r.createElementVNode("input",{type:"number",class:"form-control",id:"plane-center-y",value:r.unref(t).center.y,onInput:n[4]||(n[4]=l=>s(Number.parseFloat(l.target.value)))},null,40,ce)])])]))}});class de{constructor(t){y(this,"_store",Y());this.context=t,t.events.addEventListener("ready",()=>{const e=t.configuration.default_crs,o=t.configuration.analysis.cross_section;this._store.setOrientation(o.orientation);const s=o.pivot,i=new Z(s.crs??e,s.x,s.y,0).as(e);this._store.setCenter(i.toVector3()),this._store.$onAction(({after:n,name:l})=>{n(()=>{switch(l){case"setCenter":case"setEnabled":case"setOrientation":this.updateCrossSection();break}})}),this.updateCrossSection()})}dispose(){}updateCrossSection(){const t=[];if(this._store.enable){const o=p.MathUtils.DEG2RAD*this._store.orientation,s=Math.cos(o),i=Math.sin(o),n=new p.Vector3(s,i,0),l=new p.Plane(n,0).distanceToPoint(this._store.center),b=new p.Plane(n,-l);t.push(b)}const e=this.context.view.getInstance();e.renderer.clippingPlanes=t;for(const o of this.context.view.getInstance().getEntities())R.isEntity3D(o)&&o.dispatchEvent({clippingPlanes:t,type:"clippingPlanes-property-changed"});e.notifyChange()}}class pe{constructor(){y(this,"id","builtin-cross-section-analysis");y(this,"name","Cross section");y(this,"_manager",null)}initialize(t){t.analysis.registerTool({component:ue,icon:"bi-circle-half",name:"Cross section"}),this._manager=new de(t)}}function z(c){if("url"in c.config&&typeof c.config.url=="string")return c.config.url;if("source"in c.config&&typeof c.config.source=="object"&&"url"in c.config.source&&typeof c.config.source.url=="string")return c.config.source.url}function he(c){return z(c)!=null}class fe{constructor(){y(this,"id","builtin-download-dataset");y(this,"name","Download dataset");y(this,"_context",null)}initialize(t){this._context=t,t.datasets.registerDatasetAction({action:this.download.bind(this),icon:"bi-download",predicate:he,title:"Download dataset"})}download(t){const e=z(t);if(e==null){console.warn("invalid");return}const o=this._context,s=new URL(e).pathname.split("/"),i=s[s.length-1];console.info(`download ${z(t)}`),p.Fetcher.fetch(e).then(n=>{if(!n.ok)throw new Error(`${n.status} ${n.statusText}`);return n.blob()}).then(n=>{p.Download.downloadBlob(n,i),o.notifications.pushNotification({level:"success",text:i,title:"Download successful"})}).catch(n=>{console.error(n);const l=n instanceof Error?n.message:"Download failed";o.notifications.pushNotification({level:"error",text:l,title:t.name})})}}const $=U.defineStore("floodingPlane",()=>{const c=r.ref(0),t=r.ref(!1);function e(){return c.value}function o(i){c.value=i}function s(i){t.value=i}return{enable:t,getHeight:e,setEnabled:s,setHeight:o}}),me={class:"input-group mb-3"},ge={class:"input-group mb-3"},ye=["value"],be={class:"input-group mb-3"},_e=["value"],we=r.defineComponent({__name:"FloodingPlane",setup(c){const t=$();function e(o){t.setHeight(o)}return(o,s)=>(r.openBlock(),r.createElementBlock(r.Fragment,null,[r.createElementVNode("div",me,[r.createVNode(p._sfc_main,{"model-value":r.unref(t).enable,"onUpdate:modelValue":s[0]||(s[0]=i=>r.unref(t).setEnabled(i)),id:"flooding-plane-enable",title:"foo"},null,8,["model-value"]),s[3]||(s[3]=r.createElementVNode("label",{for:"flooding-plane-enable",class:"form-label"},"Enable flooding plane",-1))]),r.createElementVNode("div",ge,[s[5]||(s[5]=r.createElementVNode("label",{for:"flooding-altitude-range",class:"form-label"},"Altitude",-1)),r.createElementVNode("input",{id:"flooding-altitude-range",title:"Altitude",type:"range",class:"form-range",min:"0",step:"0.1",max:"500",value:r.unref(t).getHeight(),onInput:s[1]||(s[1]=i=>e(Number.parseFloat(i.target.value)))},null,40,ye),r.createElementVNode("div",be,[r.createElementVNode("input",{type:"number",class:"form-control",id:"flooding-altitude-number",step:"0.1",value:r.unref(t).getHeight(),onInput:s[2]||(s[2]=i=>e(Number.parseFloat(i.target.value)))},null,40,_e),s[4]||(s[4]=r.createElementVNode("span",{class:"input-group-text"},"m",-1))])])],64))}});class ve{constructor(){y(this,"geometry");y(this,"material");y(this,"object3D");y(this,"_height");this.geometry=new p.PlaneGeometry(1,1,1,1),this.material=new p.MeshBasicMaterial({color:43690,opacity:.5,transparent:!0}),this.object3D=new p.Mesh(this.geometry,this.material),this.object3D.renderOrder=2,this.visible=!1,this._height=0}set height(t){this._height=t}get height(){return this._height}set visible(t){this.object3D.visible=t}get visible(){return this.object3D.visible}dispose(){this.object3D.removeFromParent(),this.geometry.dispose(),this.material.dispose()}setPosition(t,e,o,s,i){this.object3D.scale.set(s,i,1),this.object3D.position.set(t,e,o),this.object3D.updateMatrixWorld()}}class xe{constructor(t){y(this,"_context");y(this,"_plane");y(this,"_store",$());this._context=t,this._plane=null,t.events.addEventListener("ready",()=>{this._store.$onAction(({after:e,name:o})=>{e(()=>{switch(o){case"setEnabled":this.updatePlane();break;case"setHeight":this.updatePlane();break}})})})}dispose(){this._plane&&(this._context.view.getInstance().remove(this._plane.object3D),this._plane.dispose())}async updatePlane(){this._plane||(this._plane=new ve,await this._context.view.getInstance().add(this._plane.object3D));const t=this._context.view.getBoundingBox(),e=t.getCenter(new p.Vector3),o=t.getSize(new p.Vector3);this._plane.visible=this._store.enable,this._plane.setPosition(e.x,e.y,this._store.getHeight(),o.x,o.y),this._context.view.getInstance().notifyChange()}}class Ce{constructor(){y(this,"id","builtin-flooding-plane-analysis");y(this,"name","Flooding plane");y(this,"_manager",null)}initialize(t){t.analysis.registerTool({component:we,icon:"bi-layers-half",name:"Flooding plane"}),this._manager=new xe(t)}}const D=new p.Matrix4,Ie={bbox:new p.MeshBasicMaterial({color:"#FFFF00",depthTest:!0,opacity:.2,transparent:!0}),selection:new p.MeshBasicMaterial({color:"#FF0000",depthTest:!1,opacity:.6,transparent:!0})},Pe=4186316022,Se=781010003,Ee=2655215786,Te=3242617779,Be=919958153,Ne=1307041759,G=1451395588,q=1883228015,Fe=[G,q],ke=[Pe,Se,Ee,Te,Be,Ne],H=c=>p.isObject(c)&&c.isIFCPickResult,A=class A extends R{constructor(e){super(new p.Group);y(this,"isIfcEntity",!0);y(this,"isPickableFeatures",!0);y(this,"type","IfcEntity");y(this,"_classificationCache");y(this,"_components");y(this,"_fragmentBoundingBox");y(this,"_fragmentClassifier");y(this,"_fragmentManager");y(this,"_ifcSelection");y(this,"_indexMap");y(this,"_model");y(this,"_source");this._source=e,this._components=new T.Components,this._components.ui.enabled=!1,this._components.scene=new T.SimpleScene(this._components),this._components.renderer=new T.SimpleRenderer(this._components,document.createElement("div")),this._components.camera=new T.SimpleCamera(this._components),this._components.raycaster=new T.SimpleRaycaster(this._components),this._components.init(),this._ifcSelection={bbox:{},selection:{}},this._indexMap={},this._classificationCache=null,this._fragmentBoundingBox=null}clearHighlight(e="selection"){for(const o of Object.keys(this._ifcSelection[e])){const s=this._fragmentManager.list[o],i=s==null?void 0:s.fragments[e];i!=null&&i.mesh.removeFromParent()}this.notifyChange(this),this._ifcSelection[e]={}}getBoundingBoxById(e){this.clearHighlight("bbox"),this.highlightById(e,"bbox");const o=this._fragmentBoundingBox;if(o===null)throw new Error("Must call initClassification before getBoundingBoxById");const s=this._fragmentManager;o.reset();const i=this._ifcSelection.bbox;if(!Object.keys(i).length)return;for(const g of Object.keys(i)){const S=s.list[g].fragments.bbox;o.addMesh(S.mesh)}const n=o.get(),{y:l,z:b}=n.min,{y:x,z:d}=n.max;return n.min.y=-d,n.max.y=-b,n.min.z=l,n.max.z=x,n.translate(this._model.position),this.clearHighlight("bbox"),n}getClassification(){if(this._classificationCache===null)throw new Error("Must call initClassification before getClassification");return this._classificationCache}getProperties(e){const o=[],s=this._model.properties;if(!s)return[];for(const i of this._indexMap[e]){const n=s[i];if(n==null)continue;const{name:l}=T.IfcPropertiesUtils.getEntityName(s,i);if(l!==null){if(n.type===G){const b=T.IfcPropertiesUtils.getPsetProps(s,i);if(b!==null)for(const x of b){if(s[x]==null)continue;const g=this.getProperty(x);g!==null&&o.push({parentName:l,...g})}}else if(n.type===q){const b=T.IfcPropertiesUtils.getQsetQuantities(s,i);if(b!==null)for(const x of b){const{key:d}=T.IfcPropertiesUtils.getQuantityValue(s,x);if(d===null)continue;const g=this.getProperty(x);g!==null&&o.push({parentName:l,...g})}}}}return o}getProperty(e){const o=this._model.properties;if(o===void 0)return null;const{name:s}=T.IfcPropertiesUtils.getEntityName(o,e);if(s===null)return null;const{value:i}=T.IfcPropertiesUtils.getQuantityValue(o,e);return{name:s,value:i}}highlight(e,o,s){this._ifcSelection[e][o.uuid]=new Set;const i=parseInt(s,10);this._ifcSelection[e][o.uuid].add(s),this.addComposites(e,o,i),this.regenerate(e,o.uuid);const n=o.fragment.group;if(n){const l=n.data[i][0];for(let b=0;b<l.length;b++){const x=l[b],d=n.keyFragments[x],g=this._fragmentManager.list[d];d in this._ifcSelection[e]||(this._ifcSelection[e][d]=new Set),this._ifcSelection[e][d].add(s),this.addComposites(e,g.mesh,i),this.regenerate(e,d)}}this.notifyChange(this)}highlightById(e,o="selection"){for(const s of Object.keys(e)){s in this._ifcSelection[o]||(this._ifcSelection[o][s]=new Set);const i=this._fragmentManager.list[s],n=new Set;for(const l of e[s])this._ifcSelection[o][s].add(l),n.add(parseInt(l,10));for(const l of n)this.addComposites(o,i.mesh,l);this.regenerate(o,s)}this.notifyChange(this)}pick(e,o){return super.pick(e,o).map(s=>({...s,entity:this,features:s.features,isIFCPickResult:!0,object:s.object}))}pickFeaturesFrom(e){var s,i,n;const o=e.object;if(o.fragment!=null&&e.instanceId!=null&&e.face){const l=o.fragment.getVertexBlockID(o.geometry,e.face.a),b=(s=o.fragment.getItemID(e.instanceId,l))==null?void 0:s.replace(/\..*/,"");if(b&&((n=(i=o.fragment.group)==null?void 0:i.properties)==null?void 0:n[b])!=null){const d=o.fragment.group.properties[b],I=[{ifcProperties:this.getProperties(b),itemProperties:d}];return e.features=I,I}}return[]}async initClassification(){this._classificationCache=await this.regenerateClassification(["storeys","entities"]),this._classificationCache.length===0&&(this._classificationCache=await this.regenerateClassification(["entities"])),this._fragmentBoundingBox=await this._components.tools.get(T.FragmentBoundingBox)}async preprocess(){const e=await p.Fetcher.fetchArrayBuffer(this._source.url);this._fragmentManager=await this._components.tools.get(T.FragmentManager),this._fragmentClassifier=await this._components.tools.get(T.FragmentClassifier);const o=new T.FragmentIfcLoader(this._components);o.settings.webIfc.COORDINATE_TO_ORIGIN=!0,o.settings.webIfc.OPTIMIZE_PROFILES=!0;const s=new Uint8Array(e);this._model=await o.load(s,this._source.name),this._model.rotateX(Math.PI/2);const i=new p.Vector3;if(this._source.at)this._source.at.toVector3(i),this._model.position.copy(i);else{const l=this._model.coordinationMatrix.clone().invert();i.applyMatrix4(l),this._model.position.set(i.x,-i.z,i.y)}this._model.updateWorldMatrix(!0,!0),this._model.updateMatrix(),this._model.updateMatrixWorld(!0),this.initializeEntityIndexes(),this._fragmentClassifier.byStorey(this._model),this._fragmentClassifier.byEntity(this._model),await this.initClassification(),this.object3d.add(this._model),this.onObjectCreated(this._model);const n=p.Fetcher.getContext(this._source.url);p.fillObject3DUserData(this,{filename:n.filename}),this.notifyChange(this.object3d)}addComposites(e,o,s){this.addHighlightToFragment(e,o.fragment);const i=o.fragment.composites[s];if(i)for(let n=1;n<i;n++){const l=T.toCompositeID(s,n);this._ifcSelection[e][o.uuid].add(l)}}addHighlightToFragment(e,o){if(!(e in o.fragments)){const s=o.addFragment(e,[Ie[e]]);o.blocks.count>1&&(s.setInstance(0,{ids:Array.from(o.ids),transform:D}),s.blocks.setVisibility(!1)),this._model.add(s.mesh),s.mesh.renderOrder=30,s.mesh.frustumCulled=!1,s.mesh.name=e,s.mesh.updateMatrixWorld(!0)}}initializeEntityIndexes(){this._indexMap={};const e=this._model.properties;if(e!==void 0)for(const o of ke)T.IfcPropertiesUtils.getRelationMap(e,o,(s,i)=>{const n=e[s];Fe.includes(n.type)||this.setEntityIndex(s);for(const l of i)this.setEntityIndex(l).add(s)})}regenerate(e,o){this.updateFragmentFill(e,o)}async regenerateClassification(e,o={}){const s=this._fragmentClassifier.get(),i=[],n=e[0],l=s[n];if(n==null||l==null)return i;for(const b of Object.keys(l)){const x={...o,[n]:[b]},d=await this._fragmentClassifier.find(x);if(Object.keys(d).length>0){const S=n[0].toUpperCase()+n.slice(1),P=await this.regenerateClassification(e.slice(1),x);i.push({children:P,fragments:d,name:b,treeItemName:S})}}return i}setEntityIndex(e){return e in this._indexMap||(this._indexMap[e]=new Set),this._indexMap[e]}updateFragmentFill(e,o){const s=this._ifcSelection[e][o],i=this._fragmentManager.list[o];if(i==null)return;const n=i.fragments[e];if(n==null)return;const l=i.mesh.parent;if(l==null)return;if(l.add(n.mesh),n.blocks.count>1)i.getInstance(0,D),n.setInstance(0,{ids:Array.from(i.ids),transform:D}),n.blocks.setVisibility(!0,s,!0);else{let x=0;for(const d of s){n.mesh.count=x+1;const{instanceID:g}=i.getInstanceAndBlockID(d);i.getInstance(g,D),n.setInstance(x,{ids:[d],transform:D}),x++}}}};y(A,"isIFCEntity",e=>p.isObject(e)&&e.isIfcEntity),y(A,"isIFCPickResult",e=>p.isObject(e)&&A.isIFCEntity(e.entity));let j=A;class Me extends J{constructor(t,e,o){super(t,e,o,{visibility:!0})}}const De={class:"d-flex"},Ae=["title"],Ve=["id"],Le={class:"list-unstyled border-start"},Oe=r.defineComponent({__name:"IfcSubtree",props:{classificationElement:{},ifcEntity:{}},setup(c){const t=c,e=p.MathUtils.generateUUID(),o=`#${e}`,s=r.ref(!1),i=p.useCameraStore(),l=p.useModuleStore().getModule(p.moduleId);function b(){if(l==null){console.warn("Cannot clip IFC element, ClippingBoxAnalysis module is not present");return}const g=t.ifcEntity.getBoundingBoxById(t.classificationElement.fragments);g&&!g.isEmpty()&&l.setClippingBox(g)}function x(){s.value=!0,t.ifcEntity.clearHighlight(),t.ifcEntity.highlightById(t.classificationElement.fragments),setTimeout(()=>s.value=!1,2e3)}function d(){const g=t.ifcEntity.getBoundingBoxById(t.classificationElement.fragments);g&&!g.isEmpty()&&i.lookTopDownAt(g)}return(g,I)=>{const S=r.resolveComponent("IfcSubtree",!0);return r.openBlock(),r.createElementBlock("div",null,[r.createElementVNode("div",De,[r.createElementVNode("span",{class:r.normalizeClass(["border rounded px-1 py-0 fw-normal",s.value?"text-danger border-danger":"text-secondary border-secondary"]),title:g.classificationElement.treeItemName},r.toDisplayString(g.classificationElement.treeItemName),11,Ae),g.classificationElement.children.length>0?(r.openBlock(),r.createBlock(p.IconList,{key:0},{default:r.withCtx(()=>[r.createVNode(p.IconListButton,{title:"Expand group",icon:"bi-chevron-down","data-bs-toggle":"collapse","data-bs-target":o,"aria-controls":r.unref(e),"aria-expanded":"true"},null,8,["aria-controls"])]),_:1})):r.createCommentVNode("",!0),r.createVNode(p._sfc_main$3,{class:r.normalizeClass(["label",s.value?"text-danger-emphasis":"text-muted"]),text:g.classificationElement.name,title:`Zoom to ${g.classificationElement.name}`,onClick:d},null,8,["class","text","title"]),r.createVNode(p.IconList,{class:"ms-1"},{default:r.withCtx(()=>[r.createVNode(p.IconListButton,{title:"Highlight",icon:"bi-highlighter",onClick:x}),r.unref(l)!=null?(r.openBlock(),r.createBlock(p.IconListButton,{key:0,title:"Clip to",icon:"bi-bounding-box",onClick:b})):r.createCommentVNode("",!0)]),_:1})]),g.classificationElement.children.length>0?(r.openBlock(),r.createElementBlock("div",{key:0,id:r.unref(e),class:"collapse show"},[r.createElementVNode("ul",Le,[(r.openBlock(!0),r.createElementBlock(r.Fragment,null,r.renderList(g.classificationElement.children,(P,B)=>(r.openBlock(),r.createElementBlock("li",{key:B},[r.createVNode(S,{"ifc-entity":t.ifcEntity,"classification-element":P},null,8,["ifc-entity","classification-element"])]))),128))])],8,Ve)):r.createCommentVNode("",!0)])}}}),ze=p._export_sfc(Oe,[["__scopeId","data-v-804ca598"]]),je={key:0},Re=r.defineComponent({__name:"IfcPropertyView",props:{dataset:{}},setup(c){const t=p.useDatasetStore(),e=c,o=p.refAndWatch(e.dataset,"isPreloaded");function s(){const n=i();return n==null?null:n.getClassification()}function i(){const n=t.getEntity(e.dataset);return n??null}return(n,l)=>r.unref(o)?(r.openBlock(),r.createElementBlock("div",je,[r.createElementVNode("ul",null,[(r.openBlock(!0),r.createElementBlock(r.Fragment,null,r.renderList(s(),(b,x)=>(r.openBlock(),r.createElementBlock("li",{key:x},[r.createVNode(ze,{"ifc-entity":i(),"classification-element":b},null,8,["ifc-entity","classification-element"])]))),128))])])):r.createCommentVNode("",!0)}}),Ue=p._export_sfc(Re,[["__scopeId","data-v-d2d82ae7"]]),Ye=c=>{if(H(c)){const t=c.object;if(t.fragment!=null&&c.face&&c.instanceId!=null){const e=t.fragment.getVertexBlockID(t.geometry,c.face.a),o=t.fragment.getItemID(c.instanceId,e).replace(/\..*/,"");return c.entity.highlight("selection",t,o),()=>c.entity.clearHighlight()}}return null},$e=c=>({name:c.filename,source:{url:c.file},type:"ifc",visible:!0}),Ge=(c,t)=>{var b,x,d,g,I,S,P,B,a;if(!H(c))return;const e=(b=c.features)==null?void 0:b.at(0);if(!e)return;t.has("IFC")||t.set("IFC",[]);const o=t.get("IFC"),{ifcProperties:s,itemProperties:i}=e,n="NULL",l=((x=i.Name)==null?void 0:x.value)??n;o.push({key:"Site",value:((g=(d=c.entity.object3d.userData)==null?void 0:d.dataset)==null?void 0:g.name)??n}),o.push({key:"IFCType",value:T.IfcCategoryMap[i.type]??n}),o.push({key:"Name",value:l}),o.push({key:"ID",value:i.expressID}),o.push({key:"GlobalId",value:((I=i.GlobalId)==null?void 0:I.value)??n}),((S=i.Description)==null?void 0:S.value)!=null&&o.push({key:"Description",value:i.Description.value}),((P=i.PredefinedType)==null?void 0:P.value)!=null&&o.push({key:"PredefinedType",value:i.PredefinedType.value}),((B=i.ObjectType)==null?void 0:B.value)!=null&&o.push({key:"ObjectType",value:i.ObjectType.value});for(const{name:f,parentName:h,value:u}of s)t.has(h)||t.set(h,[]),(a=t.get(h))==null||a.push({key:f,value:u})},qe=c=>{const t=c.dataset,e=t.config,o=p.getCoordinates(e.source.position??t.get("position")),s=new j({...e.source,at:o,name:t.name});return Promise.resolve(s)};class He{constructor(){y(this,"id","builtin-ifc-loader");y(this,"name","IFC")}async initialize(t){t.datasets.registerDatasetType("ifc",{attributeExtractor:Ge,entityBuilder:qe,fileExtensions:["ifc"],highlight:Ye,icon:"bi-building",loader:$e,name:"IFC",propertyView:Ue}),Q.registerInspector("IfcEntity",Me),await p.Fetcher.fetch("web-ifc.wasm").catch(e=>{console.warn("Could not load web-ifc.wasm",e)})}}const k=new p.Color;let We=class extends p.Loader{constructor(t){super(t),this.propertyNameMapping={},this.customPropertyMapping={}}load(t,e,o,s){const i=this,n=new p.FileLoader(this.manager);n.setPath(this.path),n.setResponseType("arraybuffer"),n.setRequestHeader(this.requestHeader),n.setWithCredentials(this.withCredentials),n.load(t,function(l){try{e(i.parse(l))}catch(b){s?s(b):console.error(b),i.manager.itemError(t)}},o,s)}setPropertyNameMapping(t){this.propertyNameMapping=t}setCustomPropertyNameMapping(t){this.customPropertyMapping=t}parse(t){function e(a,f=0){const h=/^ply([\s\S]*)end_header(\r\n|\r|\n)/;let u="";const m=h.exec(a);m!==null&&(u=m[1]);const _={comments:[],elements:[],headerLength:f,objInfo:""},v=u.split(/\r\n|\r|\n/);let w;function M(E,N){const C={type:E[0]};return C.type==="list"?(C.name=E[3],C.countType=E[1],C.itemType=E[2]):C.name=E[1],C.name in N&&(C.name=N[C.name]),C}for(let E=0;E<v.length;E++){let N=v[E];if(N=N.trim(),N==="")continue;const C=N.split(/\s+/),L=C.shift();switch(N=C.join(" "),L){case"format":_.format=C[0],_.version=C[1];break;case"comment":_.comments.push(N);break;case"element":w!==void 0&&_.elements.push(w),w={},w.name=C[0],w.count=parseInt(C[1]),w.properties=[];break;case"property":w.properties.push(M(C,B.propertyNameMapping));break;case"obj_info":_.objInfo=N;break;default:console.log("unhandled",L,C)}}return w!==void 0&&_.elements.push(w),_}function o(a,f){switch(f){case"char":case"uchar":case"short":case"ushort":case"int":case"uint":case"int8":case"uint8":case"int16":case"uint16":case"int32":case"uint32":return parseInt(a);case"float":case"double":case"float32":case"float64":return parseFloat(a)}}function s(a,f){const h={};for(let u=0;u<a.length;u++){if(f.empty())return null;if(a[u].type==="list"){const m=[],_=o(f.next(),a[u].countType);for(let v=0;v<_;v++){if(f.empty())return null;m.push(o(f.next(),a[u].itemType))}h[a[u].name]=m}else h[a[u].name]=o(f.next(),a[u].type)}return h}function i(){const a={indices:[],vertices:[],normals:[],uvs:[],faceVertexUvs:[],colors:[],faceVertexColors:[]};for(const f of Object.keys(B.customPropertyMapping))a[f]=[];return a}function n(a){const f=a.map(u=>u.name);function h(u){for(let m=0,_=u.length;m<_;m++){const v=u[m];if(f.includes(v))return v}return null}return{attrX:h(["x","px","posx"])||"x",attrY:h(["y","py","posy"])||"y",attrZ:h(["z","pz","posz"])||"z",attrNX:h(["nx","normalx"]),attrNY:h(["ny","normaly"]),attrNZ:h(["nz","normalz"]),attrS:h(["s","u","texture_u","tx"]),attrT:h(["t","v","texture_v","ty"]),attrR:h(["red","diffuse_red","r","diffuse_r"]),attrG:h(["green","diffuse_green","g","diffuse_g"]),attrB:h(["blue","diffuse_blue","b","diffuse_b"])}}function l(a,f){const h=i(),u=/end_header\s+(\S[\s\S]*\S|\S)\s*$/;let m,_;(_=u.exec(a))!==null?m=_[1].split(/\s+/):m=[];const v=new Xe(m);e:for(let w=0;w<f.elements.length;w++){const M=f.elements[w],E=n(M.properties);for(let N=0;N<M.count;N++){const C=s(M.properties,v);if(!C)break e;x(h,M.name,C,E)}}return b(h)}function b(a){let f=new p.BufferGeometry;a.indices.length>0&&f.setIndex(a.indices),f.setAttribute("position",new p.Float32BufferAttribute(a.vertices,3)),a.normals.length>0&&f.setAttribute("normal",new p.Float32BufferAttribute(a.normals,3)),a.uvs.length>0&&f.setAttribute("uv",new p.Float32BufferAttribute(a.uvs,2)),a.colors.length>0&&f.setAttribute("color",new p.Float32BufferAttribute(a.colors,3)),(a.faceVertexUvs.length>0||a.faceVertexColors.length>0)&&(f=f.toNonIndexed(),a.faceVertexUvs.length>0&&f.setAttribute("uv",new p.Float32BufferAttribute(a.faceVertexUvs,2)),a.faceVertexColors.length>0&&f.setAttribute("color",new p.Float32BufferAttribute(a.faceVertexColors,3)));for(const h of Object.keys(B.customPropertyMapping))a[h].length>0&&f.setAttribute(h,new p.Float32BufferAttribute(a[h],B.customPropertyMapping[h].length));return f.computeBoundingSphere(),f}function x(a,f,h,u){if(f==="vertex"){a.vertices.push(h[u.attrX],h[u.attrY],h[u.attrZ]),u.attrNX!==null&&u.attrNY!==null&&u.attrNZ!==null&&a.normals.push(h[u.attrNX],h[u.attrNY],h[u.attrNZ]),u.attrS!==null&&u.attrT!==null&&a.uvs.push(h[u.attrS],h[u.attrT]),u.attrR!==null&&u.attrG!==null&&u.attrB!==null&&(k.setRGB(h[u.attrR]/255,h[u.attrG]/255,h[u.attrB]/255,p.SRGBColorSpace),a.colors.push(k.r,k.g,k.b));for(const m of Object.keys(B.customPropertyMapping))for(const _ of B.customPropertyMapping[m])a[m].push(h[_])}else if(f==="face"){const m=h.vertex_indices||h.vertex_index,_=h.texcoord;m.length===3?(a.indices.push(m[0],m[1],m[2]),_&&_.length===6&&(a.faceVertexUvs.push(_[0],_[1]),a.faceVertexUvs.push(_[2],_[3]),a.faceVertexUvs.push(_[4],_[5]))):m.length===4&&(a.indices.push(m[0],m[1],m[3]),a.indices.push(m[1],m[2],m[3])),u.attrR!==null&&u.attrG!==null&&u.attrB!==null&&(k.setRGB(h[u.attrR]/255,h[u.attrG]/255,h[u.attrB]/255,p.SRGBColorSpace),a.faceVertexColors.push(k.r,k.g,k.b),a.faceVertexColors.push(k.r,k.g,k.b),a.faceVertexColors.push(k.r,k.g,k.b))}}function d(a,f){const h={};let u=0;for(let m=0;m<f.length;m++){const _=f[m],v=_.valueReader;if(_.type==="list"){const w=[],M=_.countReader.read(a+u);u+=_.countReader.size;for(let E=0;E<M;E++)w.push(v.read(a+u)),u+=v.size;h[_.name]=w}else h[_.name]=v.read(a+u),u+=v.size}return[h,u]}function g(a,f,h){function u(m,_,v){switch(_){case"int8":case"char":return{read:w=>m.getInt8(w),size:1};case"uint8":case"uchar":return{read:w=>m.getUint8(w),size:1};case"int16":case"short":return{read:w=>m.getInt16(w,v),size:2};case"uint16":case"ushort":return{read:w=>m.getUint16(w,v),size:2};case"int32":case"int":return{read:w=>m.getInt32(w,v),size:4};case"uint32":case"uint":return{read:w=>m.getUint32(w,v),size:4};case"float32":case"float":return{read:w=>m.getFloat32(w,v),size:4};case"float64":case"double":return{read:w=>m.getFloat64(w,v),size:8}}}for(let m=0,_=a.length;m<_;m++){const v=a[m];v.type==="list"?(v.countReader=u(f,v.countType,h),v.valueReader=u(f,v.itemType,h)):v.valueReader=u(f,v.type,h)}}function I(a,f){const h=i(),u=f.format==="binary_little_endian",m=new DataView(a,f.headerLength);let _,v=0;for(let w=0;w<f.elements.length;w++){const M=f.elements[w],E=M.properties,N=n(E);g(E,m,u);for(let C=0;C<M.count;C++){_=d(v,E),v+=_[1];const L=_[0];x(h,M.name,L,N)}}return b(h)}function S(a){let f=0,h=!0,u="";const m=[],_=new TextDecoder().decode(a.subarray(0,5)),v=/^ply\r\n/.test(_);do{const w=String.fromCharCode(a[f++]);w!==`
2
- `&&w!=="\r"?u+=w:(u==="end_header"&&(h=!1),u!==""&&(m.push(u),u=""))}while(h&&f<a.length);return v===!0&&f++,{headerText:m.join("\r")+"\r",headerLength:f}}let P;const B=this;if(t instanceof ArrayBuffer){const a=new Uint8Array(t),{headerText:f,headerLength:h}=S(a),u=e(f,h);if(u.format==="ascii"){const m=new TextDecoder().decode(a);P=l(m,u)}else P=I(t,u)}else P=l(t,e(t));return P}};class Xe{constructor(t){this.arr=t,this.i=0}empty(){return this.i>=this.arr.length}next(){return this.arr[this.i++]}}const V=class V extends p.Mesh{constructor(){super(...arguments);y(this,"isPickableFeatures",!0);y(this,"isPlyMesh",!0)}pickFeaturesFrom(e){if(this.geometry.hasAttribute("color")&&e.face){const o=this.geometry.getAttribute("color").array,s=e.face,n=[{color:new p.Color(o[s.a*3],o[s.a*3+1],o[s.a*3+2])}];return e.features=n,n}return[]}};y(V,"isPlyMesh",e=>p.isObject(e)&&e.isPlyMesh),y(V,"isPlyPickResult",e=>p.isObject(e)&&V.isPlyMesh(e==null?void 0:e.object));let O=V;class Ze extends R{constructor(e){super(new p.Group);y(this,"isPlyEntity",!0);y(this,"source");this.source=e}async preprocess(){const e=await p.Fetcher.fetchArrayBuffer(this.source.url),o=this.source.at.as(this.source.featureProjection).toVector3(),i=new We().parse(e),n=new p.MeshLambertMaterial({side:p.DoubleSide});i.hasAttribute("color")&&(n.vertexColors=!0),i.computeVertexNormals();const l=new O(i,n);l.name="plyModel",i.computeBoundingBox(),l.position.copy(o),l.updateWorldMatrix(!0,!0),this.object3d.add(l),this.onObjectCreated(l);const b=p.Fetcher.getContext(this.source.url);p.fillObject3DUserData(this,{filename:b.filename}),this.notifyChange(this.object3d)}}const Qe=c=>{const{dataset:t,instance:e}=c,o=t.config,s=p.getCoordinates(o.source.position??t.get("position")),i=new Ze({...o.source,at:s,featureProjection:e.referenceCrs});return Promise.resolve(i)},Je=(c,t)=>{var s;if(!O.isPlyPickResult(c))return;const e=(s=c.features)==null?void 0:s.at(0);if(!e)return;t.has("PLY")||t.set("PLY",[]),t.get("PLY").push({key:"Color",value:e.color})};class Ke{constructor(){y(this,"id","builtin-ply-loader");y(this,"name","PLY")}initialize(t){t.datasets.registerDatasetType("ply",{attributeExtractor:Je,entityBuilder:Qe,icon:"bi-file-earmark-binary",name:"PLY"})}}const et=c=>{const t=c.dataset.config,e=new K({source:new ee({url:`${t.source.url}/${t.source.filename}`})});return p.fillObject3DUserData(e,{filename:t.source.url}),Promise.resolve(e)};class tt{constructor(){y(this,"id","builtin-potree-loader");y(this,"name","Potree")}initialize(t){t.datasets.registerDatasetType("potree",{entityBuilder:et,icon:"fg-multipoint",name:"Potree Point Cloud"})}}class nt{constructor(){y(this,"id","builtin-tour");y(this,"name","Tour");y(this,"_camera",null);y(this,"_cameraCallback",null);y(this,"_context",null);y(this,"_tours",null)}initialize(t){this._context=t,t.events.addEventListener("ready",this.start.bind(this))}buildTours(){const t=this._camera,e=new F.Tour({tourName:"main",useModalOverlay:!0}),o=new F.Tour({tourName:"navigating",useModalOverlay:!0}),s=new F.Tour({tourName:"analyzing",useModalOverlay:!0}),i=[{action:()=>{var d;return(d=F.activeTour)==null?void 0:d.next()},text:"Next"},{action:()=>{var d;return(d=F.activeTour)==null?void 0:d.cancel()},secondary:!0,text:"Exit"}],n=()=>{var a,f;const d=(a=F.activeTour)==null?void 0:a.getCurrentStep(),g=d==null?void 0:d.getElement(),I=g==null?void 0:g.querySelector(".shepherd-text"),S=(f=F.activeTour)==null?void 0:f.steps;if(d==null||g==null||I==null||S==null)return;const P=document.createElement("div");P.className="progress mt-3",P.setAttribute("role","progressbar"),P.style.height="2px";const B=document.createElement("div");B.className="progress-bar bg-success",B.style.width=`${100*(S.indexOf(d)/S.length)}%`,P.appendChild(B),I.appendChild(P)},l=async(d,g)=>new Promise(I=>{const S=document.getElementById(d);if(S&&!S.classList.contains("active")&&S.click(),document.querySelector(g))return I(document.querySelector(g));const P=new MutationObserver(()=>{document.querySelector(g)&&(P.disconnect(),I(document.querySelector(g)))});P.observe(document.body,{childList:!0,subtree:!0})});e.addStep({buttons:[{action:()=>{var d;(d=F.activeTour)==null||d.complete(),o.show(0)},text:"Navigating"},{action:()=>{var d;(d=F.activeTour)==null||d.complete(),s.show(0)},text:"Analyzing data"},{action:()=>{var d;return(d=F.activeTour)==null?void 0:d.cancel()},secondary:!0,text:"Exit"}],cancelIcon:{enabled:!0,label:"Exit tutorial"},id:"example-step",text:"<p>Welcome to <strong>Piero</strong>, the Giro3D application.<br/>We can guide you through the different features.</p>",title:"Welcome!",when:{show:n}}),o.addStep({attachTo:{element:"#main-view",on:"bottom"},buttons:i,id:"view",text:"<p>This is the <b>main view</b>.</p><p>Giro3D natively supports a broad range of data sources, from 2D raster and vector data, to 3D point clouds and tilesets.</p><p>Piero adds support for CityJSON and IFC files.</p>",when:{show:n}}),o.addStep({attachTo:{element:"#main-view",on:"bottom"},buttons:i,id:"navigate",text:'<p>This application integrates <a href="https://github.com/yomotsu/camera-controls">camera-controls</a>, a camera control for three.js.</p><p><b>Click</b> to move the camera. <b>Right-click</b> to rotate around a point. <b>Scroll</b> to zoom in or out.</p>',when:{hide:()=>{this._cameraCallback&&t.removeEventListener("interaction-end",this._cameraCallback),this._cameraCallback=null},show:()=>{let d=0;this._cameraCallback=()=>{var g;d+=1,d>2&&((g=F.activeTour)==null||g.next())},t.addEventListener("interaction-end",this._cameraCallback),n()}}}),o.addStep({attachTo:{element:"#toolbar",on:"right"},beforeShowPromise:()=>l("toolbar-datasets","#datasets-drop-zone"),buttons:i,id:"toolbar-layers",text:"<p>Giro3D supports multiple datasets.</p><p>You can toggle datasets as you wish with the <b>Datasets</b> panel.</p>",when:{show:n}}),o.addStep({attachTo:{element:"#basemap-list",on:"right"},beforeShowPromise:()=>l("toolbar-datasets","#datasets-drop-zone"),buttons:i,id:"basemaps",text:"<p><b>Basemaps</b> are color and elevation layers that make the basic shape and aspect of the <b>Map</b>.</p>",when:{show:n}}),o.addStep({attachTo:{element:"#overlay-list",on:"right"},beforeShowPromise:()=>l("toolbar-datasets","#datasets-drop-zone"),buttons:i,id:"overlays",text:"<p><b>Overlays</b> are vector layers in various formats (WFS, GML, GeoJSON...).</p>",when:{show:n}}),o.addStep({attachTo:{element:"#dataset-list",on:"right"},beforeShowPromise:()=>l("toolbar-datasets","#datasets-drop-zone"),buttons:i,id:"layers",text:"<p>The <b>Datasets</b> panel contains all 3D objects in the scene.</><p>You can toggle their visibility and delete them.<p><p>Most objects leverage Giro3D's adaptive resolution to optimize their display.</p>",when:{show:n}}),o.addStep({attachTo:{element:"#datasets-drop-zone",on:"right"},beforeShowPromise:()=>l("toolbar-datasets","#datasets-drop-zone"),buttons:i,id:"adddata",text:"<p>You can add your own data from your computer by <b>dragging the file</b> into this page.</p><p>While you won't benefit from Giro3D's tiling mechanism, this can be a great way to quickly visualize datasets up to 100MB.</p><p>This application supports CityJSONs, IFCs, LAS/LAZs, CSV pointclouds, and simple GeoJSON features.</p>",when:{show:n}}),o.addStep({attachTo:{element:"#main-view",on:"bottom"},buttons:i,id:"attributes",text:"<p>By clicking on any feature on the map, you can see its <strong>Attribute table</strong>. Clickable features display a cursor when hovered.</p>",when:{show:n}}),o.addStep({attachTo:{element:"#search-place-autocomplete",on:"bottom"},buttons:[{action:()=>{var d;(d=F.activeTour)==null||d.complete(),s.show(0)},text:"Analyzing data"},{action:()=>{var d;return(d=F.activeTour)==null?void 0:d.complete()},secondary:!0,text:"Exit"}],id:"widgets",text:"Giro3D is highly extensible. Here we added a widget to search and navigate to locations based on the French address database.",when:{show:n}}),s.addStep({attachTo:{element:"#annotations-fieldset",on:"right"},beforeShowPromise:()=>l("toolbar-annotations","#annotations-fieldset"),buttons:i,id:"annotation",text:"<p>You can <strong>annotate</strong> any data displayed using Giro3D native tools.<br>Select the <strong>geometry</strong> of your annotation, and <strong>click</strong> on the scene to add points. <strong>Right-click</strong> to end the shape.</p>",when:{show:n}}),s.addStep({attachTo:{element:"#annotations-fieldset",on:"right"},beforeShowPromise:()=>l("toolbar-annotations","#annotations-fieldset"),buttons:i,id:"annotations",text:"You can download your annotations as GeoJSON files. You can also upload your own by dragging them into this panel.",when:{show:n}}),p.hasExperimentalFeature("measurements")&&s.addStep({attachTo:{element:"#panel-container",on:"right"},beforeShowPromise:()=>l("toolbar-measures","#measures-fieldset"),buttons:i,id:"measurements",text:"You can add <strong>measurements</strong> to easily get distances betwween objects.<br>Once started, moving the mouse will display the measure. <strong>Click</strong> to save the measurement. <strong>Right-click</strong> to end.",when:{show:n}}),s.addStep({attachTo:{element:"#panel-container",on:"right"},beforeShowPromise:()=>l("toolbar-analysis","#panel-container .card"),buttons:[{action:()=>{var d;return(d=F.activeTour)==null?void 0:d.complete()},text:"Done!"}],id:"analysis",text:"In the <strong>Analysis</strong> panel you'll find some advanced analysis tools.",when:{show:n}});const b=()=>{const d=new URL(document.URL);d.searchParams.delete("tourStep"),d.searchParams.set("tour","none"),window.history.replaceState({},"",d.toString())},x=d=>{const g=new URL(document.URL);let I="main";d.tour.id.startsWith("navigating")?I="navigating":d.tour.id.startsWith("analyzing")&&(I="analyzing"),g.searchParams.set("tour",I),g.searchParams.set("tourStep",d.step.id),window.history.replaceState({},"",g.toString())};return e.on("cancel",b),e.on("complete",b),e.on("show",x),o.on("cancel",b),o.on("complete",b),o.on("show",x),s.on("cancel",b),s.on("complete",b),s.on("show",x),{analyzingTour:s,mainTour:e,navigatingTour:o}}getTours(){return this._tours||(this._tours=this.buildTours()),this._tours}restart(){const{mainTour:t}=this.getTours();t.show(0)}start(){if(!this._context)throw new Error("module is not initialized");const{analyzingTour:t,mainTour:e,navigatingTour:o}=this.getTours();this._camera=this._context.view.getCameraController();const s=new URL(document.URL),i=s.searchParams.get("tour")??"main";if(i!=="none"){const n=s.searchParams.get("tourStep")??0;i==="navigating"?o.show(n):i==="analyzing"?t.show(n):e.show(n)}}}exports.ClippingBoxAnalysis=p.ClippingBoxAnalysis;exports.CrossSectionAnalysis=pe;exports.DownloadDataset=fe;exports.FloodingPlaneAnalysis=Ce;exports.IFCLoader=He;exports.PLYLoader=Ke;exports.PotreeLoader=tt;exports.Tour=nt;
1
+ "use strict";var J=Object.defineProperty;var Q=(a,t,e)=>t in a?J(a,t,{enumerable:!0,configurable:!0,writable:!0,value:e}):a[t]=e;var h=(a,t,e)=>Q(a,typeof t!="symbol"?t+"":t,e);Object.defineProperty(exports,Symbol.toStringTag,{value:"Module"});const d=require("./Components.cjs.js"),r=require("vue"),q=require("pinia"),O=require("@giro3d/giro3d/core/geographic/Coordinates"),j=require("@giro3d/giro3d/entities/Entity3D"),K=require("@giro3d/giro3d/utils/Fetcher"),ee=require("@giro3d/giro3d/gui/EntityPanel"),B=require("openbim-components"),te=require("@giro3d/giro3d/gui/EntityInspector"),$=require("ol"),ne=require("ol/layer/Tile"),G=require("ol/proj"),se=require("ol/source"),oe=require("@giro3d/giro3d/entities/PointCloud"),ie=require("@giro3d/giro3d/sources/PotreeSource"),N=require("shepherd.js"),Y=q.defineStore("crossSection",()=>{const a=r.ref(0),t=r.ref(new d.Vector3(0,0,0)),e=r.ref(!1);function n(s){e.value=s}function o(s){a.value=s}function i(s){t.value=s}return{center:t,enable:e,orientation:a,setCenter:i,setEnabled:n,setOrientation:o}}),re={class:"input-group mb-3"},ae={class:"input-group mb-3"},le=["value"],ce={class:"input-group mb-3"},ue=["value"],de={class:"input-group"},pe={class:"input-group"},me=["value"],he=["value"],fe=r.defineComponent({__name:"CrossSection",setup(a){const t=Y();function e(i){t.setOrientation(i)}function n(i){const s=t.center.clone();s.setX(i),t.setCenter(s)}function o(i){const s=t.center.clone();s.setY(i),t.setCenter(s)}return(i,s)=>(r.openBlock(),r.createElementBlock("div",null,[r.createElementVNode("div",re,[r.createVNode(d._sfc_main,{"model-value":r.unref(t).enable,"onUpdate:modelValue":s[0]||(s[0]=c=>r.unref(t).setEnabled(c)),id:"cross-section-enable",title:"foo"},null,8,["model-value"]),s[5]||(s[5]=r.createElementVNode("label",{for:"cross-section-enable",class:"form-label"},"Enable cross section",-1))]),r.createElementVNode("div",ae,[s[6]||(s[6]=r.createElementVNode("label",{for:"plane-orientation-range",class:"form-label"},"Plane orientation (0-360°)",-1)),r.createElementVNode("input",{id:"plane-orientation-range",title:"Altitude",type:"range",class:"form-range",min:"0",step:"0.1",max:"360",value:r.unref(t).orientation,onInput:s[1]||(s[1]=c=>e(Number.parseFloat(c.target.value)))},null,40,le)]),r.createElementVNode("div",ce,[r.createElementVNode("input",{type:"number",class:"form-control",id:"plane-orientation-number",step:"0.1",value:r.unref(t).orientation,onInput:s[2]||(s[2]=c=>e(Number.parseFloat(c.target.value)))},null,40,ue)]),s[8]||(s[8]=r.createElementVNode("hr",null,null,-1)),r.createElementVNode("div",de,[s[7]||(s[7]=r.createElementVNode("label",{class:"form-label"},"Center (x, y)",-1)),r.createElementVNode("div",pe,[r.createElementVNode("input",{type:"number",class:"form-control",id:"plane-center-x",value:r.unref(t).center.x,onInput:s[3]||(s[3]=c=>n(Number.parseFloat(c.target.value)))},null,40,me),r.createElementVNode("input",{type:"number",class:"form-control",id:"plane-center-y",value:r.unref(t).center.y,onInput:s[4]||(s[4]=c=>o(Number.parseFloat(c.target.value)))},null,40,he)])])]))}});class ge{constructor(t){h(this,"_store",Y());this.context=t,t.events.addEventListener("ready",()=>{const e=t.configuration.default_crs,n=t.configuration.analysis.cross_section;this._store.setOrientation(n.orientation);const o=n.pivot,i=new O(o.crs??e,o.x,o.y,0).as(e);this._store.setCenter(i.toVector3()),this._store.$onAction(({after:s,name:c})=>{s(()=>{switch(c){case"setCenter":case"setEnabled":case"setOrientation":this.updateCrossSection();break}})}),this.updateCrossSection()})}dispose(){}updateCrossSection(){const t=[];if(this._store.enable){const n=d.MathUtils.DEG2RAD*this._store.orientation,o=Math.cos(n),i=Math.sin(n),s=new d.Vector3(o,i,0),c=new d.Plane(s,0).distanceToPoint(this._store.center),y=new d.Plane(s,-c);t.push(y)}const e=this.context.view.getInstance();e.renderer.clippingPlanes=t;for(const n of this.context.view.getInstance().getEntities())j.isEntity3D(n)&&n.dispatchEvent({clippingPlanes:t,type:"clippingPlanes-property-changed"});e.notifyChange()}}class ye{constructor(){h(this,"id","builtin-cross-section-analysis");h(this,"name","Cross section");h(this,"_manager",null)}initialize(t){t.analysis.registerTool({component:fe,icon:"bi-circle-half",name:"Cross section"}),this._manager=new ge(t)}}function R(a){if("url"in a.config&&typeof a.config.url=="string")return a.config.url;if("source"in a.config&&typeof a.config.source=="object"&&"url"in a.config.source&&typeof a.config.source.url=="string")return a.config.source.url}function be(a){return R(a)!=null}class ve{constructor(){h(this,"id","builtin-download-dataset");h(this,"name","Download dataset");h(this,"_context",null)}initialize(t){this._context=t,t.datasets.registerDatasetAction({action:this.download.bind(this),icon:"bi-download",predicate:be,title:"Download dataset"})}download(t){const e=R(t);if(e==null){console.warn("invalid");return}const n=this._context,o=new URL(e).pathname.split("/"),i=o[o.length-1];console.info(`download ${R(t)}`),d.Fetcher.fetch(e).then(s=>{if(!s.ok)throw new Error(`${s.status} ${s.statusText}`);return s.blob()}).then(s=>{d.Download.downloadBlob(s,i),n.notifications.pushNotification({level:"success",text:i,title:"Download successful"})}).catch(s=>{console.error(s);const c=s instanceof Error?s.message:"Download failed";n.notifications.pushNotification({level:"error",text:c,title:t.name})})}}const H=q.defineStore("floodingPlane",()=>{const a=r.ref(0),t=r.ref(!1);function e(){return a.value}function n(i){a.value=i}function o(i){t.value=i}return{enable:t,getHeight:e,setEnabled:o,setHeight:n}}),_e={class:"input-group mb-3"},we={class:"input-group mb-3"},xe=["value"],Ce={class:"input-group mb-3"},Pe=["value"],Ie=r.defineComponent({__name:"FloodingPlane",setup(a){const t=H();function e(n){t.setHeight(n)}return(n,o)=>(r.openBlock(),r.createElementBlock(r.Fragment,null,[r.createElementVNode("div",_e,[r.createVNode(d._sfc_main,{"model-value":r.unref(t).enable,"onUpdate:modelValue":o[0]||(o[0]=i=>r.unref(t).setEnabled(i)),id:"flooding-plane-enable",title:"foo"},null,8,["model-value"]),o[3]||(o[3]=r.createElementVNode("label",{for:"flooding-plane-enable",class:"form-label"},"Enable flooding plane",-1))]),r.createElementVNode("div",we,[o[5]||(o[5]=r.createElementVNode("label",{for:"flooding-altitude-range",class:"form-label"},"Altitude",-1)),r.createElementVNode("input",{id:"flooding-altitude-range",title:"Altitude",type:"range",class:"form-range",min:"0",step:"0.1",max:"500",value:r.unref(t).getHeight(),onInput:o[1]||(o[1]=i=>e(Number.parseFloat(i.target.value)))},null,40,xe),r.createElementVNode("div",Ce,[r.createElementVNode("input",{type:"number",class:"form-control",id:"flooding-altitude-number",step:"0.1",value:r.unref(t).getHeight(),onInput:o[2]||(o[2]=i=>e(Number.parseFloat(i.target.value)))},null,40,Pe),o[4]||(o[4]=r.createElementVNode("span",{class:"input-group-text"},"m",-1))])])],64))}});class Se{constructor(){h(this,"geometry");h(this,"material");h(this,"object3D");h(this,"_height");this.geometry=new d.PlaneGeometry(1,1,1,1),this.material=new d.MeshBasicMaterial({color:43690,opacity:.5,transparent:!0}),this.object3D=new d.Mesh(this.geometry,this.material),this.object3D.renderOrder=2,this.visible=!1,this._height=0}set height(t){this._height=t}get height(){return this._height}set visible(t){this.object3D.visible=t}get visible(){return this.object3D.visible}dispose(){this.object3D.removeFromParent(),this.geometry.dispose(),this.material.dispose()}setPosition(t,e,n,o,i){this.object3D.scale.set(o,i,1),this.object3D.position.set(t,e,n),this.object3D.updateMatrixWorld()}}class Ee{constructor(t){h(this,"_context");h(this,"_plane");h(this,"_store",H());this._context=t,this._plane=null,t.events.addEventListener("ready",()=>{this._store.$onAction(({after:e,name:n})=>{e(()=>{switch(n){case"setEnabled":this.updatePlane();break;case"setHeight":this.updatePlane();break}})})})}dispose(){this._plane&&(this._context.view.getInstance().remove(this._plane.object3D),this._plane.dispose())}async updatePlane(){this._plane||(this._plane=new Se,await this._context.view.getInstance().add(this._plane.object3D));const t=this._context.view.getBoundingBox(),e=t.getCenter(new d.Vector3),n=t.getSize(new d.Vector3);this._plane.visible=this._store.enable,this._plane.setPosition(e.x,e.y,this._store.getHeight(),n.x,n.y),this._context.view.getInstance().notifyChange()}}class Be{constructor(){h(this,"id","builtin-flooding-plane-analysis");h(this,"name","Flooding plane");h(this,"_manager",null)}initialize(t){t.analysis.registerTool({component:Ie,icon:"bi-layers-half",name:"Flooding plane"}),this._manager=new Ee(t)}}const Te=/^(\d+\.\d+)\s*,\s*(\d+\.\d+)$/;class Fe{constructor(){h(this,"name","Go to coordinates")}search(t){const e=Te.exec(t);if(e){const n=Number.parseFloat(e[1]),o=Number.parseFloat(e[2]),s={coordinates:O.WGS84(n,o),label:`${n.toFixed(6)}, ${o.toFixed(6)}`,provider:this};return Promise.resolve([s])}else return Promise.resolve([])}}class Ne{constructor(){h(this,"id","builtin-coordinates-search");h(this,"name","Coordinates search")}initialize(t){t.search.registerProvider(new Fe)}}const ke=/[a-z]{3}/;class Le{constructor(){h(this,"name","Base adresse nationale (BAN)")}async search(t){if(!ke.test(t))return[];try{const n=(await d.Fetcher.fetchJson(`https://api-adresse.data.gouv.fr/search/?q=${t}`)).features.map(o=>{const i=o.properties,s=o.geometry,[c,y]=s.coordinates;return{coordinates:new O("EPSG:4326",c,y,0),label:i.label,provider:this}});return await Me(n.map(o=>o.coordinates)),n}catch(e){if(e instanceof K.HttpError)return[];throw e}}}async function Me(a){const t=new URL("https://data.geopf.fr/altimetrie/1.0/calcul/alti/rest/elevation.json");t.searchParams.append("lon",a.map(n=>n.longitude).join("|")),t.searchParams.append("lat",a.map(n=>n.latitude).join("|")),t.searchParams.append("zonly","true"),t.searchParams.append("resource","ign_rge_alti_wld"),t.searchParams.append("delimiter","|"),t.searchParams.append("indent","false");const e=await d.Fetcher.fetchJson(t.toString());for(let n=0;n<a.length;n++)a[n].setAltitude(e.elevations[n]);return e}class De{constructor(){h(this,"id","builtin-geocoding-ban");h(this,"name","Base adresse nationale")}initialize(t){t.search.registerProvider(new Le)}}const M=new d.Matrix4,Ve={bbox:new d.MeshBasicMaterial({color:"#FFFF00",depthTest:!0,opacity:.2,transparent:!0}),selection:new d.MeshBasicMaterial({color:"#FF0000",depthTest:!1,opacity:.6,transparent:!0})},Ae=4186316022,ze=781010003,Oe=2655215786,je=3242617779,Re=919958153,Ue=1307041759,W=1451395588,Z=1883228015,$e=[W,Z],Ge=[Ae,ze,Oe,je,Re,Ue],X=a=>d.isObject(a)&&a.isIFCPickResult,D=class D extends j{constructor(e){super(new d.Group);h(this,"isIfcEntity",!0);h(this,"isPickableFeatures",!0);h(this,"type","IfcEntity");h(this,"_classificationCache");h(this,"_components");h(this,"_fragmentBoundingBox");h(this,"_fragmentClassifier");h(this,"_fragmentManager");h(this,"_ifcSelection");h(this,"_indexMap");h(this,"_model");h(this,"_source");this._source=e,this._components=new B.Components,this._components.ui.enabled=!1,this._components.scene=new B.SimpleScene(this._components),this._components.renderer=new B.SimpleRenderer(this._components,document.createElement("div")),this._components.camera=new B.SimpleCamera(this._components),this._components.raycaster=new B.SimpleRaycaster(this._components),this._components.init(),this._ifcSelection={bbox:{},selection:{}},this._indexMap={},this._classificationCache=null,this._fragmentBoundingBox=null}clearHighlight(e="selection"){for(const n of Object.keys(this._ifcSelection[e])){const o=this._fragmentManager.list[n],i=o==null?void 0:o.fragments[e];i!=null&&i.mesh.removeFromParent()}this.notifyChange(this),this._ifcSelection[e]={}}getBoundingBoxById(e){this.clearHighlight("bbox"),this.highlightById(e,"bbox");const n=this._fragmentBoundingBox;if(n===null)throw new Error("Must call initClassification before getBoundingBoxById");const o=this._fragmentManager;n.reset();const i=this._ifcSelection.bbox;if(!Object.keys(i).length)return;for(const f of Object.keys(i)){const S=o.list[f].fragments.bbox;n.addMesh(S.mesh)}const s=n.get(),{y:c,z:y}=s.min,{y:w,z:u}=s.max;return s.min.y=-u,s.max.y=-y,s.min.z=c,s.max.z=w,s.translate(this._model.position),this.clearHighlight("bbox"),s}getClassification(){if(this._classificationCache===null)throw new Error("Must call initClassification before getClassification");return this._classificationCache}getProperties(e){const n=[],o=this._model.properties;if(!o)return[];for(const i of this._indexMap[e]){const s=o[i];if(s==null)continue;const{name:c}=B.IfcPropertiesUtils.getEntityName(o,i);if(c!==null){if(s.type===W){const y=B.IfcPropertiesUtils.getPsetProps(o,i);if(y!==null)for(const w of y){if(o[w]==null)continue;const f=this.getProperty(w);f!==null&&n.push({parentName:c,...f})}}else if(s.type===Z){const y=B.IfcPropertiesUtils.getQsetQuantities(o,i);if(y!==null)for(const w of y){const{key:u}=B.IfcPropertiesUtils.getQuantityValue(o,w);if(u===null)continue;const f=this.getProperty(w);f!==null&&n.push({parentName:c,...f})}}}}return n}getProperty(e){const n=this._model.properties;if(n===void 0)return null;const{name:o}=B.IfcPropertiesUtils.getEntityName(n,e);if(o===null)return null;const{value:i}=B.IfcPropertiesUtils.getQuantityValue(n,e);return{name:o,value:i}}highlight(e,n,o){this._ifcSelection[e][n.uuid]=new Set;const i=parseInt(o,10);this._ifcSelection[e][n.uuid].add(o),this.addComposites(e,n,i),this.regenerate(e,n.uuid);const s=n.fragment.group;if(s){const c=s.data[i][0];for(let y=0;y<c.length;y++){const w=c[y],u=s.keyFragments[w],f=this._fragmentManager.list[u];u in this._ifcSelection[e]||(this._ifcSelection[e][u]=new Set),this._ifcSelection[e][u].add(o),this.addComposites(e,f.mesh,i),this.regenerate(e,u)}}this.notifyChange(this)}highlightById(e,n="selection"){for(const o of Object.keys(e)){o in this._ifcSelection[n]||(this._ifcSelection[n][o]=new Set);const i=this._fragmentManager.list[o],s=new Set;for(const c of e[o])this._ifcSelection[n][o].add(c),s.add(parseInt(c,10));for(const c of s)this.addComposites(n,i.mesh,c);this.regenerate(n,o)}this.notifyChange(this)}pick(e,n){return super.pick(e,n).map(o=>({...o,entity:this,features:o.features,isIFCPickResult:!0,object:o.object}))}pickFeaturesFrom(e){var o,i,s;const n=e.object;if(n.fragment!=null&&e.instanceId!=null&&e.face){const c=n.fragment.getVertexBlockID(n.geometry,e.face.a),y=(o=n.fragment.getItemID(e.instanceId,c))==null?void 0:o.replace(/\..*/,"");if(y&&((s=(i=n.fragment.group)==null?void 0:i.properties)==null?void 0:s[y])!=null){const u=n.fragment.group.properties[y],C=[{ifcProperties:this.getProperties(y),itemProperties:u}];return e.features=C,C}}return[]}async initClassification(){this._classificationCache=await this.regenerateClassification(["storeys","entities"]),this._classificationCache.length===0&&(this._classificationCache=await this.regenerateClassification(["entities"])),this._fragmentBoundingBox=await this._components.tools.get(B.FragmentBoundingBox)}async preprocess(){const e=await d.Fetcher.fetchArrayBuffer(this._source.url);this._fragmentManager=await this._components.tools.get(B.FragmentManager),this._fragmentClassifier=await this._components.tools.get(B.FragmentClassifier);const n=new B.FragmentIfcLoader(this._components);n.settings.webIfc.COORDINATE_TO_ORIGIN=!0,n.settings.webIfc.OPTIMIZE_PROFILES=!0;const o=new Uint8Array(e);this._model=await n.load(o,this._source.name),this._model.rotateX(Math.PI/2);const i=new d.Vector3;if(this._source.at)this._source.at.toVector3(i),this._model.position.copy(i);else{const c=this._model.coordinationMatrix.clone().invert();i.applyMatrix4(c),this._model.position.set(i.x,-i.z,i.y)}this._model.updateWorldMatrix(!0,!0),this._model.updateMatrix(),this._model.updateMatrixWorld(!0),this.initializeEntityIndexes(),this._fragmentClassifier.byStorey(this._model),this._fragmentClassifier.byEntity(this._model),await this.initClassification(),this.object3d.add(this._model),this.onObjectCreated(this._model);const s=d.Fetcher.getContext(this._source.url);d.fillObject3DUserData(this,{filename:s.filename}),this.notifyChange(this.object3d)}addComposites(e,n,o){this.addHighlightToFragment(e,n.fragment);const i=n.fragment.composites[o];if(i)for(let s=1;s<i;s++){const c=B.toCompositeID(o,s);this._ifcSelection[e][n.uuid].add(c)}}addHighlightToFragment(e,n){if(!(e in n.fragments)){const o=n.addFragment(e,[Ve[e]]);n.blocks.count>1&&(o.setInstance(0,{ids:Array.from(n.ids),transform:M}),o.blocks.setVisibility(!1)),this._model.add(o.mesh),o.mesh.renderOrder=30,o.mesh.frustumCulled=!1,o.mesh.name=e,o.mesh.updateMatrixWorld(!0)}}initializeEntityIndexes(){this._indexMap={};const e=this._model.properties;if(e!==void 0)for(const n of Ge)B.IfcPropertiesUtils.getRelationMap(e,n,(o,i)=>{const s=e[o];$e.includes(s.type)||this.setEntityIndex(o);for(const c of i)this.setEntityIndex(c).add(o)})}regenerate(e,n){this.updateFragmentFill(e,n)}async regenerateClassification(e,n={}){const o=this._fragmentClassifier.get(),i=[],s=e[0],c=o[s];if(s==null||c==null)return i;for(const y of Object.keys(c)){const w={...n,[s]:[y]},u=await this._fragmentClassifier.find(w);if(Object.keys(u).length>0){const S=s[0].toUpperCase()+s.slice(1),I=await this.regenerateClassification(e.slice(1),w);i.push({children:I,fragments:u,name:y,treeItemName:S})}}return i}setEntityIndex(e){return e in this._indexMap||(this._indexMap[e]=new Set),this._indexMap[e]}updateFragmentFill(e,n){const o=this._ifcSelection[e][n],i=this._fragmentManager.list[n];if(i==null)return;const s=i.fragments[e];if(s==null)return;const c=i.mesh.parent;if(c==null)return;if(c.add(s.mesh),s.blocks.count>1)i.getInstance(0,M),s.setInstance(0,{ids:Array.from(i.ids),transform:M}),s.blocks.setVisibility(!0,o,!0);else{let w=0;for(const u of o){s.mesh.count=w+1;const{instanceID:f}=i.getInstanceAndBlockID(u);i.getInstance(f,M),s.setInstance(w,{ids:[u],transform:M}),w++}}}};h(D,"isIFCEntity",e=>d.isObject(e)&&e.isIfcEntity),h(D,"isIFCPickResult",e=>d.isObject(e)&&D.isIFCEntity(e.entity));let U=D;class qe extends te{constructor(t,e,n){super(t,e,n,{visibility:!0})}}const Ye={class:"d-flex"},He=["title"],We=["id"],Ze={class:"list-unstyled border-start"},Xe=r.defineComponent({__name:"IfcSubtree",props:{classificationElement:{},ifcEntity:{}},setup(a){const t=a,e=d.MathUtils.generateUUID(),n=`#${e}`,o=r.ref(!1),i=d.useCameraStore(),c=d.useModuleStore().getModule(d.moduleId);function y(){if(c==null){console.warn("Cannot clip IFC element, ClippingBoxAnalysis module is not present");return}const f=t.ifcEntity.getBoundingBoxById(t.classificationElement.fragments);f&&!f.isEmpty()&&c.setClippingBox(f)}function w(){o.value=!0,t.ifcEntity.clearHighlight(),t.ifcEntity.highlightById(t.classificationElement.fragments),setTimeout(()=>o.value=!1,2e3)}function u(){const f=t.ifcEntity.getBoundingBoxById(t.classificationElement.fragments);f&&!f.isEmpty()&&i.lookTopDownAt(f)}return(f,C)=>{const S=r.resolveComponent("IfcSubtree",!0);return r.openBlock(),r.createElementBlock("div",null,[r.createElementVNode("div",Ye,[r.createElementVNode("span",{class:r.normalizeClass(["border rounded px-1 py-0 fw-normal",o.value?"text-danger border-danger":"text-secondary border-secondary"]),title:f.classificationElement.treeItemName},r.toDisplayString(f.classificationElement.treeItemName),11,He),f.classificationElement.children.length>0?(r.openBlock(),r.createBlock(d.IconList,{key:0},{default:r.withCtx(()=>[r.createVNode(d.IconListButton,{title:"Expand group",icon:"bi-chevron-down","data-bs-toggle":"collapse","data-bs-target":n,"aria-controls":r.unref(e),"aria-expanded":"true"},null,8,["aria-controls"])]),_:1})):r.createCommentVNode("",!0),r.createVNode(d._sfc_main$3,{class:r.normalizeClass(["label",o.value?"text-danger-emphasis":"text-muted"]),text:f.classificationElement.name,title:`Zoom to ${f.classificationElement.name}`,onClick:u},null,8,["class","text","title"]),r.createVNode(d.IconList,{class:"ms-1"},{default:r.withCtx(()=>[r.createVNode(d.IconListButton,{title:"Highlight",icon:"bi-highlighter",onClick:w}),r.unref(c)!=null?(r.openBlock(),r.createBlock(d.IconListButton,{key:0,title:"Clip to",icon:"bi-bounding-box",onClick:y})):r.createCommentVNode("",!0)]),_:1})]),f.classificationElement.children.length>0?(r.openBlock(),r.createElementBlock("div",{key:0,id:r.unref(e),class:"collapse show"},[r.createElementVNode("ul",Ze,[(r.openBlock(!0),r.createElementBlock(r.Fragment,null,r.renderList(f.classificationElement.children,(I,T)=>(r.openBlock(),r.createElementBlock("li",{key:T},[r.createVNode(S,{"ifc-entity":t.ifcEntity,"classification-element":I},null,8,["ifc-entity","classification-element"])]))),128))])],8,We)):r.createCommentVNode("",!0)])}}}),Je=d._export_sfc(Xe,[["__scopeId","data-v-804ca598"]]),Qe={key:0},Ke=r.defineComponent({__name:"IfcPropertyView",props:{dataset:{}},setup(a){const t=d.useDatasetStore(),e=a,n=d.refAndWatch(e.dataset,"isPreloaded");function o(){const s=i();return s==null?null:s.getClassification()}function i(){const s=t.getEntity(e.dataset);return s??null}return(s,c)=>r.unref(n)?(r.openBlock(),r.createElementBlock("div",Qe,[r.createElementVNode("ul",null,[(r.openBlock(!0),r.createElementBlock(r.Fragment,null,r.renderList(o(),(y,w)=>(r.openBlock(),r.createElementBlock("li",{key:w},[r.createVNode(Je,{"ifc-entity":i(),"classification-element":y},null,8,["ifc-entity","classification-element"])]))),128))])])):r.createCommentVNode("",!0)}}),et=d._export_sfc(Ke,[["__scopeId","data-v-d2d82ae7"]]),tt=a=>{if(X(a)){const t=a.object;if(t.fragment!=null&&a.face&&a.instanceId!=null){const e=t.fragment.getVertexBlockID(t.geometry,a.face.a),n=t.fragment.getItemID(a.instanceId,e).replace(/\..*/,"");return a.entity.highlight("selection",t,n),()=>a.entity.clearHighlight()}}return null},nt=a=>({name:a.filename,source:{url:a.file},type:"ifc",visible:!0}),st=(a,t)=>{var y,w,u,f,C,S,I,T,l;if(!X(a))return;const e=(y=a.features)==null?void 0:y.at(0);if(!e)return;t.has("IFC")||t.set("IFC",[]);const n=t.get("IFC"),{ifcProperties:o,itemProperties:i}=e,s="NULL",c=((w=i.Name)==null?void 0:w.value)??s;n.push({key:"Site",value:((f=(u=a.entity.object3d.userData)==null?void 0:u.dataset)==null?void 0:f.name)??s}),n.push({key:"IFCType",value:B.IfcCategoryMap[i.type]??s}),n.push({key:"Name",value:c}),n.push({key:"ID",value:i.expressID}),n.push({key:"GlobalId",value:((C=i.GlobalId)==null?void 0:C.value)??s}),((S=i.Description)==null?void 0:S.value)!=null&&n.push({key:"Description",value:i.Description.value}),((I=i.PredefinedType)==null?void 0:I.value)!=null&&n.push({key:"PredefinedType",value:i.PredefinedType.value}),((T=i.ObjectType)==null?void 0:T.value)!=null&&n.push({key:"ObjectType",value:i.ObjectType.value});for(const{name:g,parentName:m,value:p}of o)t.has(m)||t.set(m,[]),(l=t.get(m))==null||l.push({key:g,value:p})},ot=a=>{const t=a.dataset,e=t.config,n=d.getCoordinates(e.source.position??t.get("position")),o=new U({...e.source,at:n,name:t.name});return Promise.resolve(o)};class it{constructor(){h(this,"id","builtin-ifc-loader");h(this,"name","IFC")}async initialize(t){t.datasets.registerDatasetType("ifc",{attributeExtractor:st,entityBuilder:ot,fileExtensions:["ifc"],highlight:tt,icon:"bi-building",loader:nt,name:"IFC",propertyView:et}),ee.registerInspector("IfcEntity",qe),await d.Fetcher.fetch("web-ifc.wasm").catch(e=>{console.warn("Could not load web-ifc.wasm",e)})}}const rt=r.defineComponent({__name:"OpenLayersMinimapComponent",props:{context:{}},setup(a){const t=r.ref(),e=r.shallowRef(),n=a,o=[[3e4,12],[5e4,10],[1e5,8],[4e5,6],[8e5,4]];function i(s){for(const[c,y]of o)if(s<c)return y;return o[o.length-1][1]}return r.onMounted(()=>{e.value=new $.Map({controls:[],layers:[new ne({source:new se.OSM})],target:t.value,view:new $.View({center:G.fromLonLat([4,44]),projection:"EPSG:3857",zoom:5})});let s=new d.Vector3;const c=()=>{var S;const w=n.context.view.getInstance(),f=n.context.view.getCameraController().getCameraPosition(),C=f.camera.z;if(!f.camera.equals(s)){s=f.camera.clone();const I=new O(w.referenceCrs,s.x,s.y).as("EPSG:4326"),T=i(C),l=(S=e.value)==null?void 0:S.getView();l==null||l.setCenter(G.fromLonLat([I.longitude,I.latitude])),l==null||l.setZoom(T)}};n.context.events.addEventListener("updated",c);let y=!1;t.value&&(t.value.onclick=()=>{var w,u,f,C;y=!y,y?((w=t.value)==null||w.classList.add("collapsed"),(u=t.value)==null||u.classList.remove("expanded")):((f=t.value)==null||f.classList.remove("collapsed"),(C=t.value)==null||C.classList.add("expanded"))})}),r.onUnmounted(()=>{var s;(s=e.value)==null||s.dispose(),e.value=void 0}),(s,c)=>(r.openBlock(),r.createElementBlock("div",{ref_key:"target",ref:t,title:"Toggle minimap",class:"minimap expanded"},null,512))}}),at=d._export_sfc(rt,[["__scopeId","data-v-38ee3c04"]]);class lt{constructor(){h(this,"id","builtin-minimap-openlayers");h(this,"name","Minimap")}initialize(t){t.widgets.addWidget({component:at,id:"minimap-ol"})}}const k=new d.Color;let ct=class extends d.Loader{constructor(t){super(t),this.propertyNameMapping={},this.customPropertyMapping={}}load(t,e,n,o){const i=this,s=new d.FileLoader(this.manager);s.setPath(this.path),s.setResponseType("arraybuffer"),s.setRequestHeader(this.requestHeader),s.setWithCredentials(this.withCredentials),s.load(t,function(c){try{e(i.parse(c))}catch(y){o?o(y):console.error(y),i.manager.itemError(t)}},n,o)}setPropertyNameMapping(t){this.propertyNameMapping=t}setCustomPropertyNameMapping(t){this.customPropertyMapping=t}parse(t){function e(l,g=0){const m=/^ply([\s\S]*)end_header(\r\n|\r|\n)/;let p="";const b=m.exec(l);b!==null&&(p=b[1]);const v={comments:[],elements:[],headerLength:g,objInfo:""},x=p.split(/\r\n|\r|\n/);let _;function L(E,F){const P={type:E[0]};return P.type==="list"?(P.name=E[3],P.countType=E[1],P.itemType=E[2]):P.name=E[1],P.name in F&&(P.name=F[P.name]),P}for(let E=0;E<x.length;E++){let F=x[E];if(F=F.trim(),F==="")continue;const P=F.split(/\s+/),A=P.shift();switch(F=P.join(" "),A){case"format":v.format=P[0],v.version=P[1];break;case"comment":v.comments.push(F);break;case"element":_!==void 0&&v.elements.push(_),_={},_.name=P[0],_.count=parseInt(P[1]),_.properties=[];break;case"property":_.properties.push(L(P,T.propertyNameMapping));break;case"obj_info":v.objInfo=F;break;default:console.log("unhandled",A,P)}}return _!==void 0&&v.elements.push(_),v}function n(l,g){switch(g){case"char":case"uchar":case"short":case"ushort":case"int":case"uint":case"int8":case"uint8":case"int16":case"uint16":case"int32":case"uint32":return parseInt(l);case"float":case"double":case"float32":case"float64":return parseFloat(l)}}function o(l,g){const m={};for(let p=0;p<l.length;p++){if(g.empty())return null;if(l[p].type==="list"){const b=[],v=n(g.next(),l[p].countType);for(let x=0;x<v;x++){if(g.empty())return null;b.push(n(g.next(),l[p].itemType))}m[l[p].name]=b}else m[l[p].name]=n(g.next(),l[p].type)}return m}function i(){const l={indices:[],vertices:[],normals:[],uvs:[],faceVertexUvs:[],colors:[],faceVertexColors:[]};for(const g of Object.keys(T.customPropertyMapping))l[g]=[];return l}function s(l){const g=l.map(p=>p.name);function m(p){for(let b=0,v=p.length;b<v;b++){const x=p[b];if(g.includes(x))return x}return null}return{attrX:m(["x","px","posx"])||"x",attrY:m(["y","py","posy"])||"y",attrZ:m(["z","pz","posz"])||"z",attrNX:m(["nx","normalx"]),attrNY:m(["ny","normaly"]),attrNZ:m(["nz","normalz"]),attrS:m(["s","u","texture_u","tx"]),attrT:m(["t","v","texture_v","ty"]),attrR:m(["red","diffuse_red","r","diffuse_r"]),attrG:m(["green","diffuse_green","g","diffuse_g"]),attrB:m(["blue","diffuse_blue","b","diffuse_b"])}}function c(l,g){const m=i(),p=/end_header\s+(\S[\s\S]*\S|\S)\s*$/;let b,v;(v=p.exec(l))!==null?b=v[1].split(/\s+/):b=[];const x=new ut(b);e:for(let _=0;_<g.elements.length;_++){const L=g.elements[_],E=s(L.properties);for(let F=0;F<L.count;F++){const P=o(L.properties,x);if(!P)break e;w(m,L.name,P,E)}}return y(m)}function y(l){let g=new d.BufferGeometry;l.indices.length>0&&g.setIndex(l.indices),g.setAttribute("position",new d.Float32BufferAttribute(l.vertices,3)),l.normals.length>0&&g.setAttribute("normal",new d.Float32BufferAttribute(l.normals,3)),l.uvs.length>0&&g.setAttribute("uv",new d.Float32BufferAttribute(l.uvs,2)),l.colors.length>0&&g.setAttribute("color",new d.Float32BufferAttribute(l.colors,3)),(l.faceVertexUvs.length>0||l.faceVertexColors.length>0)&&(g=g.toNonIndexed(),l.faceVertexUvs.length>0&&g.setAttribute("uv",new d.Float32BufferAttribute(l.faceVertexUvs,2)),l.faceVertexColors.length>0&&g.setAttribute("color",new d.Float32BufferAttribute(l.faceVertexColors,3)));for(const m of Object.keys(T.customPropertyMapping))l[m].length>0&&g.setAttribute(m,new d.Float32BufferAttribute(l[m],T.customPropertyMapping[m].length));return g.computeBoundingSphere(),g}function w(l,g,m,p){if(g==="vertex"){l.vertices.push(m[p.attrX],m[p.attrY],m[p.attrZ]),p.attrNX!==null&&p.attrNY!==null&&p.attrNZ!==null&&l.normals.push(m[p.attrNX],m[p.attrNY],m[p.attrNZ]),p.attrS!==null&&p.attrT!==null&&l.uvs.push(m[p.attrS],m[p.attrT]),p.attrR!==null&&p.attrG!==null&&p.attrB!==null&&(k.setRGB(m[p.attrR]/255,m[p.attrG]/255,m[p.attrB]/255,d.SRGBColorSpace),l.colors.push(k.r,k.g,k.b));for(const b of Object.keys(T.customPropertyMapping))for(const v of T.customPropertyMapping[b])l[b].push(m[v])}else if(g==="face"){const b=m.vertex_indices||m.vertex_index,v=m.texcoord;b.length===3?(l.indices.push(b[0],b[1],b[2]),v&&v.length===6&&(l.faceVertexUvs.push(v[0],v[1]),l.faceVertexUvs.push(v[2],v[3]),l.faceVertexUvs.push(v[4],v[5]))):b.length===4&&(l.indices.push(b[0],b[1],b[3]),l.indices.push(b[1],b[2],b[3])),p.attrR!==null&&p.attrG!==null&&p.attrB!==null&&(k.setRGB(m[p.attrR]/255,m[p.attrG]/255,m[p.attrB]/255,d.SRGBColorSpace),l.faceVertexColors.push(k.r,k.g,k.b),l.faceVertexColors.push(k.r,k.g,k.b),l.faceVertexColors.push(k.r,k.g,k.b))}}function u(l,g){const m={};let p=0;for(let b=0;b<g.length;b++){const v=g[b],x=v.valueReader;if(v.type==="list"){const _=[],L=v.countReader.read(l+p);p+=v.countReader.size;for(let E=0;E<L;E++)_.push(x.read(l+p)),p+=x.size;m[v.name]=_}else m[v.name]=x.read(l+p),p+=x.size}return[m,p]}function f(l,g,m){function p(b,v,x){switch(v){case"int8":case"char":return{read:_=>b.getInt8(_),size:1};case"uint8":case"uchar":return{read:_=>b.getUint8(_),size:1};case"int16":case"short":return{read:_=>b.getInt16(_,x),size:2};case"uint16":case"ushort":return{read:_=>b.getUint16(_,x),size:2};case"int32":case"int":return{read:_=>b.getInt32(_,x),size:4};case"uint32":case"uint":return{read:_=>b.getUint32(_,x),size:4};case"float32":case"float":return{read:_=>b.getFloat32(_,x),size:4};case"float64":case"double":return{read:_=>b.getFloat64(_,x),size:8}}}for(let b=0,v=l.length;b<v;b++){const x=l[b];x.type==="list"?(x.countReader=p(g,x.countType,m),x.valueReader=p(g,x.itemType,m)):x.valueReader=p(g,x.type,m)}}function C(l,g){const m=i(),p=g.format==="binary_little_endian",b=new DataView(l,g.headerLength);let v,x=0;for(let _=0;_<g.elements.length;_++){const L=g.elements[_],E=L.properties,F=s(E);f(E,b,p);for(let P=0;P<L.count;P++){v=u(x,E),x+=v[1];const A=v[0];w(m,L.name,A,F)}}return y(m)}function S(l){let g=0,m=!0,p="";const b=[],v=new TextDecoder().decode(l.subarray(0,5)),x=/^ply\r\n/.test(v);do{const _=String.fromCharCode(l[g++]);_!==`
2
+ `&&_!=="\r"?p+=_:(p==="end_header"&&(m=!1),p!==""&&(b.push(p),p=""))}while(m&&g<l.length);return x===!0&&g++,{headerText:b.join("\r")+"\r",headerLength:g}}let I;const T=this;if(t instanceof ArrayBuffer){const l=new Uint8Array(t),{headerText:g,headerLength:m}=S(l),p=e(g,m);if(p.format==="ascii"){const b=new TextDecoder().decode(l);I=c(b,p)}else I=C(t,p)}else I=c(t,e(t));return I}};class ut{constructor(t){this.arr=t,this.i=0}empty(){return this.i>=this.arr.length}next(){return this.arr[this.i++]}}const V=class V extends d.Mesh{constructor(){super(...arguments);h(this,"isPickableFeatures",!0);h(this,"isPlyMesh",!0)}pickFeaturesFrom(e){if(this.geometry.hasAttribute("color")&&e.face){const n=this.geometry.getAttribute("color").array,o=e.face,s=[{color:new d.Color(n[o.a*3],n[o.a*3+1],n[o.a*3+2])}];return e.features=s,s}return[]}};h(V,"isPlyMesh",e=>d.isObject(e)&&e.isPlyMesh),h(V,"isPlyPickResult",e=>d.isObject(e)&&V.isPlyMesh(e==null?void 0:e.object));let z=V;class dt extends j{constructor(e){super(new d.Group);h(this,"isPlyEntity",!0);h(this,"source");this.source=e}async preprocess(){const e=await d.Fetcher.fetchArrayBuffer(this.source.url),n=this.source.at.as(this.source.featureProjection).toVector3(),i=new ct().parse(e),s=new d.MeshLambertMaterial({side:d.DoubleSide});i.hasAttribute("color")&&(s.vertexColors=!0),i.computeVertexNormals();const c=new z(i,s);c.name="plyModel",i.computeBoundingBox(),c.position.copy(n),c.updateWorldMatrix(!0,!0),this.object3d.add(c),this.onObjectCreated(c);const y=d.Fetcher.getContext(this.source.url);d.fillObject3DUserData(this,{filename:y.filename}),this.notifyChange(this.object3d)}}const pt=a=>{const{dataset:t,instance:e}=a,n=t.config,o=d.getCoordinates(n.source.position??t.get("position")),i=new dt({...n.source,at:o,featureProjection:e.referenceCrs});return Promise.resolve(i)},mt=(a,t)=>{var o;if(!z.isPlyPickResult(a))return;const e=(o=a.features)==null?void 0:o.at(0);if(!e)return;t.has("PLY")||t.set("PLY",[]),t.get("PLY").push({key:"Color",value:e.color})};class ht{constructor(){h(this,"id","builtin-ply-loader");h(this,"name","PLY")}initialize(t){t.datasets.registerDatasetType("ply",{attributeExtractor:mt,entityBuilder:pt,icon:"bi-file-earmark-binary",name:"PLY"})}}const ft=a=>{a.addEventListener("object-created",t=>{t.obj.traverse(n=>{var o;((o=n.userData)==null?void 0:o.class)==="IfcSpace"&&(n.visible=!1)})})};class gt{constructor(){h(this,"id","builtin-post-process-entities");h(this,"name","Post-process 3D Tiles");h(this,"_alreadyProcessedEntities",new Set);h(this,"_processings",[ft])}initialize(t){t.events.addEventListener("ready",()=>{const e=t.view.getInstance();e.addEventListener("entity-added",()=>this.processEntities(e)),this.processEntities(e)})}processEntities(t){for(const e of t.getEntities())this._alreadyProcessedEntities.has(e.id)||(j.isEntity3D(e)&&this.processEntity(e,t),this._alreadyProcessedEntities.add(e.id))}processEntity(t,e){const n={instance:e};for(const o of this._processings)o(t,n)}}const yt=a=>{const t=a.dataset.config,e=new oe({source:new ie({url:`${t.source.url}/${t.source.filename}`})});return d.fillObject3DUserData(e,{filename:t.source.url}),Promise.resolve(e)};class bt{constructor(){h(this,"id","builtin-potree-loader");h(this,"name","Potree")}initialize(t){t.datasets.registerDatasetType("potree",{entityBuilder:yt,icon:"fg-multipoint",name:"Potree Point Cloud"})}}class vt{constructor(){h(this,"id","builtin-tour");h(this,"name","Tour");h(this,"_camera",null);h(this,"_cameraCallback",null);h(this,"_context",null);h(this,"_tours",null)}initialize(t){this._context=t,t.events.addEventListener("ready",this.start.bind(this))}buildTours(){const t=this._camera,e=new N.Tour({tourName:"main",useModalOverlay:!0}),n=new N.Tour({tourName:"navigating",useModalOverlay:!0}),o=new N.Tour({tourName:"analyzing",useModalOverlay:!0}),i=[{action:()=>{var u;return(u=N.activeTour)==null?void 0:u.next()},text:"Next"},{action:()=>{var u;return(u=N.activeTour)==null?void 0:u.cancel()},secondary:!0,text:"Exit"}],s=()=>{var l,g;const u=(l=N.activeTour)==null?void 0:l.getCurrentStep(),f=u==null?void 0:u.getElement(),C=f==null?void 0:f.querySelector(".shepherd-text"),S=(g=N.activeTour)==null?void 0:g.steps;if(u==null||f==null||C==null||S==null)return;const I=document.createElement("div");I.className="progress mt-3",I.setAttribute("role","progressbar"),I.style.height="2px";const T=document.createElement("div");T.className="progress-bar bg-success",T.style.width=`${100*(S.indexOf(u)/S.length)}%`,I.appendChild(T),C.appendChild(I)},c=async(u,f)=>new Promise(C=>{const S=document.getElementById(u);if(S&&!S.classList.contains("active")&&S.click(),document.querySelector(f))return C(document.querySelector(f));const I=new MutationObserver(()=>{document.querySelector(f)&&(I.disconnect(),C(document.querySelector(f)))});I.observe(document.body,{childList:!0,subtree:!0})});e.addStep({buttons:[{action:()=>{var u;(u=N.activeTour)==null||u.complete(),n.show(0)},text:"Navigating"},{action:()=>{var u;(u=N.activeTour)==null||u.complete(),o.show(0)},text:"Analyzing data"},{action:()=>{var u;return(u=N.activeTour)==null?void 0:u.cancel()},secondary:!0,text:"Exit"}],cancelIcon:{enabled:!0,label:"Exit tutorial"},id:"example-step",text:"<p>Welcome to <strong>Piero</strong>, the Giro3D application.<br/>We can guide you through the different features.</p>",title:"Welcome!",when:{show:s}}),n.addStep({attachTo:{element:"#main-view",on:"bottom"},buttons:i,id:"view",text:"<p>This is the <b>main view</b>.</p><p>Giro3D natively supports a broad range of data sources, from 2D raster and vector data, to 3D point clouds and tilesets.</p><p>Piero adds support for CityJSON and IFC files.</p>",when:{show:s}}),n.addStep({attachTo:{element:"#main-view",on:"bottom"},buttons:i,id:"navigate",text:'<p>This application integrates <a href="https://github.com/yomotsu/camera-controls">camera-controls</a>, a camera control for three.js.</p><p><b>Click</b> to move the camera. <b>Right-click</b> to rotate around a point. <b>Scroll</b> to zoom in or out.</p>',when:{hide:()=>{this._cameraCallback&&t.removeEventListener("interaction-end",this._cameraCallback),this._cameraCallback=null},show:()=>{let u=0;this._cameraCallback=()=>{var f;u+=1,u>2&&((f=N.activeTour)==null||f.next())},t.addEventListener("interaction-end",this._cameraCallback),s()}}}),n.addStep({attachTo:{element:"#toolbar",on:"right"},beforeShowPromise:()=>c("toolbar-datasets","#datasets-drop-zone"),buttons:i,id:"toolbar-layers",text:"<p>Giro3D supports multiple datasets.</p><p>You can toggle datasets as you wish with the <b>Datasets</b> panel.</p>",when:{show:s}}),n.addStep({attachTo:{element:"#basemap-list",on:"right"},beforeShowPromise:()=>c("toolbar-datasets","#datasets-drop-zone"),buttons:i,id:"basemaps",text:"<p><b>Basemaps</b> are color and elevation layers that make the basic shape and aspect of the <b>Map</b>.</p>",when:{show:s}}),n.addStep({attachTo:{element:"#overlay-list",on:"right"},beforeShowPromise:()=>c("toolbar-datasets","#datasets-drop-zone"),buttons:i,id:"overlays",text:"<p><b>Overlays</b> are vector layers in various formats (WFS, GML, GeoJSON...).</p>",when:{show:s}}),n.addStep({attachTo:{element:"#dataset-list",on:"right"},beforeShowPromise:()=>c("toolbar-datasets","#datasets-drop-zone"),buttons:i,id:"layers",text:"<p>The <b>Datasets</b> panel contains all 3D objects in the scene.</><p>You can toggle their visibility and delete them.<p><p>Most objects leverage Giro3D's adaptive resolution to optimize their display.</p>",when:{show:s}}),n.addStep({attachTo:{element:"#datasets-drop-zone",on:"right"},beforeShowPromise:()=>c("toolbar-datasets","#datasets-drop-zone"),buttons:i,id:"adddata",text:"<p>You can add your own data from your computer by <b>dragging the file</b> into this page.</p><p>While you won't benefit from Giro3D's tiling mechanism, this can be a great way to quickly visualize datasets up to 100MB.</p><p>This application supports CityJSONs, IFCs, LAS/LAZs, CSV pointclouds, and simple GeoJSON features.</p>",when:{show:s}}),n.addStep({attachTo:{element:"#main-view",on:"bottom"},buttons:i,id:"attributes",text:"<p>By clicking on any feature on the map, you can see its <strong>Attribute table</strong>. Clickable features display a cursor when hovered.</p>",when:{show:s}}),n.addStep({attachTo:{element:"#search-place-autocomplete",on:"bottom"},buttons:[{action:()=>{var u;(u=N.activeTour)==null||u.complete(),o.show(0)},text:"Analyzing data"},{action:()=>{var u;return(u=N.activeTour)==null?void 0:u.complete()},secondary:!0,text:"Exit"}],id:"widgets",text:"Giro3D is highly extensible. Here we added a widget to search and navigate to locations based on the French address database.",when:{show:s}}),o.addStep({attachTo:{element:"#annotations-fieldset",on:"right"},beforeShowPromise:()=>c("toolbar-annotations","#annotations-fieldset"),buttons:i,id:"annotation",text:"<p>You can <strong>annotate</strong> any data displayed using Giro3D native tools.<br>Select the <strong>geometry</strong> of your annotation, and <strong>click</strong> on the scene to add points. <strong>Right-click</strong> to end the shape.</p>",when:{show:s}}),o.addStep({attachTo:{element:"#annotations-fieldset",on:"right"},beforeShowPromise:()=>c("toolbar-annotations","#annotations-fieldset"),buttons:i,id:"annotations",text:"You can download your annotations as GeoJSON files. You can also upload your own by dragging them into this panel.",when:{show:s}}),d.hasExperimentalFeature("measurements")&&o.addStep({attachTo:{element:"#panel-container",on:"right"},beforeShowPromise:()=>c("toolbar-measures","#measures-fieldset"),buttons:i,id:"measurements",text:"You can add <strong>measurements</strong> to easily get distances betwween objects.<br>Once started, moving the mouse will display the measure. <strong>Click</strong> to save the measurement. <strong>Right-click</strong> to end.",when:{show:s}}),o.addStep({attachTo:{element:"#panel-container",on:"right"},beforeShowPromise:()=>c("toolbar-analysis","#panel-container .card"),buttons:[{action:()=>{var u;return(u=N.activeTour)==null?void 0:u.complete()},text:"Done!"}],id:"analysis",text:"In the <strong>Analysis</strong> panel you'll find some advanced analysis tools.",when:{show:s}});const y=()=>{const u=new URL(document.URL);u.searchParams.delete("tourStep"),u.searchParams.set("tour","none"),window.history.replaceState({},"",u.toString())},w=u=>{const f=new URL(document.URL);let C="main";u.tour.id.startsWith("navigating")?C="navigating":u.tour.id.startsWith("analyzing")&&(C="analyzing"),f.searchParams.set("tour",C),f.searchParams.set("tourStep",u.step.id),window.history.replaceState({},"",f.toString())};return e.on("cancel",y),e.on("complete",y),e.on("show",w),n.on("cancel",y),n.on("complete",y),n.on("show",w),o.on("cancel",y),o.on("complete",y),o.on("show",w),{analyzingTour:o,mainTour:e,navigatingTour:n}}getTours(){return this._tours||(this._tours=this.buildTours()),this._tours}restart(){const{mainTour:t}=this.getTours();t.show(0)}start(){if(!this._context)throw new Error("module is not initialized");const{analyzingTour:t,mainTour:e,navigatingTour:n}=this.getTours();this._camera=this._context.view.getCameraController();const o=new URL(document.URL),i=o.searchParams.get("tour")??"main";if(i!=="none"){const s=o.searchParams.get("tourStep")??0;i==="navigating"?n.show(s):i==="analyzing"?t.show(s):e.show(s)}}}exports.ClippingBoxAnalysis=d.ClippingBoxAnalysis;exports.CoordinatesSearch=Ne;exports.CrossSectionAnalysis=ye;exports.DownloadDataset=ve;exports.FloodingPlaneAnalysis=Be;exports.FrenchBanGeocoder=De;exports.IFCLoader=it;exports.OpenLayersMinimap=lt;exports.PLYLoader=ht;exports.PostProcessEntities=gt;exports.PotreeLoader=bt;exports.Tour=vt;
3
3
  //# sourceMappingURL=modules.cjs.js.map