@ifc-lite/viewer 1.21.0 → 1.22.1

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.
Files changed (598) hide show
  1. package/.turbo/turbo-build.log +91 -57
  2. package/CHANGELOG.md +33 -0
  3. package/dist/assets/__vite-browser-external-B1O5LaIO.js +1 -0
  4. package/dist/assets/arrow-CXWhTnNT.js +20 -0
  5. package/dist/assets/ascii-points-source-bTjLVmUX.js +1 -0
  6. package/dist/assets/{basketViewActivator-Bzw51jhm.js → basketViewActivator--cFpU2Q9.js} +14 -15
  7. package/dist/assets/bcf-Ba2CjHib.js +281 -0
  8. package/dist/assets/browser-DXS29_v9.js +695 -0
  9. package/dist/assets/cesium-BoVuJvTC.js +17850 -0
  10. package/dist/assets/decode-worker-CgM1iNSK.js +172 -0
  11. package/dist/assets/deflate-DCLbV4UE.js +1 -0
  12. package/dist/assets/{drawing-2d-Bjy8YPrg.js → drawing-2d-C71b8Ugx.js} +1 -1
  13. package/dist/assets/e57-source-CQHxE8n3.js +1 -0
  14. package/dist/assets/emscripten-module-B1g2L2eS.wasm +0 -0
  15. package/dist/assets/emscripten-module-DHbYPfAp.wasm +0 -0
  16. package/dist/assets/emscripten-module-ZrHFMo7O.wasm +0 -0
  17. package/dist/assets/emscripten-module-uFzwHH0Y.wasm +0 -0
  18. package/dist/assets/emscripten-module.browser-BLJD5hhE.js +1 -0
  19. package/dist/assets/{esbuild-Cpd5nU_H.wasm → esbuild-CzsZLPr0.wasm} +0 -0
  20. package/dist/assets/esbuild-FgU11_Eg.js +1 -0
  21. package/dist/assets/event-B0kAzHa-.js +1 -0
  22. package/dist/assets/exporters-Bf6PTtdW.js +5723 -0
  23. package/dist/assets/ffi-Boa1QuFa.js +1 -0
  24. package/dist/assets/geometry-controller.worker-CEr00X3X.js +7 -0
  25. package/dist/assets/geometry.worker-B4VPDkmL.js +1 -0
  26. package/dist/assets/geotiff-BN4J8Vt9.js +3354 -0
  27. package/dist/assets/{ids-B7AXEv7h.js → ids-XwxE1tK3.js} +7 -7
  28. package/dist/assets/ifc-lite-DNzkEkIb.js +7 -0
  29. package/dist/assets/ifc-lite_bg-1IiJN0Zg.wasm +0 -0
  30. package/dist/assets/ifc-lite_bg-B_eUD1Wy.wasm +0 -0
  31. package/dist/assets/index-DMho-JA0.js +6 -0
  32. package/dist/assets/index-DS_xJQfP.css +1 -0
  33. package/dist/assets/{index-DVNSvEMh.js → index-j2x5R7fb.js} +86695 -74779
  34. package/dist/assets/inline-worker-BpBzlmd6.js +1 -0
  35. package/dist/assets/jpeg-BUTmr0Bp.js +1 -0
  36. package/dist/assets/las-BW6LIc_j.js +1 -0
  37. package/dist/assets/las-source-C_IGrgRq.js +1 -0
  38. package/dist/assets/{laz-perf-DnSyzVYH.wasm → laz-perf-CFJp03W6.wasm} +0 -0
  39. package/dist/assets/laz-perf-DgUOSLeU.js +1 -0
  40. package/dist/assets/laz-source-BWjza0Iw.js +125 -0
  41. package/dist/assets/{lens-CSASnhAL.js → lens-CpjUdqpw.js} +1 -1
  42. package/dist/assets/lerc-DmzRHXn3.js +1 -0
  43. package/dist/assets/lzw-CgyIIzii.js +1 -0
  44. package/dist/assets/maplibre-gl-Do6O5tDc.js +800 -0
  45. package/dist/assets/{native-bridge-BiD01jI9.js → native-bridge-Q5ACp4QY.js} +6 -9
  46. package/dist/assets/packbits-C1r4AzHj.js +1 -0
  47. package/dist/assets/pako.esm-Cram60i4.js +1 -0
  48. package/dist/assets/parquet_wasm_bg-DcKVfvto.wasm +0 -0
  49. package/dist/assets/{parser.worker-Bnbrl6gy.js → parser.worker-Cl6XQcXA.js} +2 -2
  50. package/dist/assets/pcd-source-Ck0UnVDn.js +3 -0
  51. package/dist/assets/ply-source-C8jjyzxE.js +4 -0
  52. package/dist/assets/raw-ZqLh7kVQ.js +1 -0
  53. package/dist/assets/{exporters-u0sz2Upj.js → sandbox-Bju6ZKJK.js} +11869 -7414
  54. package/dist/assets/{server-client-DP8fMPY9.js → server-client-B8wi3CGx.js} +4 -4
  55. package/dist/assets/three-CQBzFWY2.js +4104 -0
  56. package/dist/assets/wasm-bridge-X-mWRA9Z.js +1 -0
  57. package/dist/assets/webimage-D0MbRMkU.js +1 -0
  58. package/dist/assets/{workerHelpers-CBbWSJmd.js → workerHelpers-DnNedVRr.js} +1 -1
  59. package/dist/assets/zip-BJqVbRkU.js +2 -0
  60. package/dist/assets/zstd-DA4VQ-ji.js +1 -0
  61. package/dist/cesium/{Workers/chunk-V7QEYVP3.js → node_modules/.pnpm/cesium@1.141.0/node_modules/cesium/Build/Cesium/Workers/chunk-236YIEYT.js} +2 -2
  62. package/dist/cesium/{Workers/chunk-5TJMAQVL.js → node_modules/.pnpm/cesium@1.141.0/node_modules/cesium/Build/Cesium/Workers/chunk-2ZYB3DYT.js} +2 -2
  63. package/dist/cesium/{Workers/chunk-UBOGZS7F.js → node_modules/.pnpm/cesium@1.141.0/node_modules/cesium/Build/Cesium/Workers/chunk-4M56RRIL.js} +2 -2
  64. package/dist/cesium/{Workers/chunk-OCWJRAXS.js → node_modules/.pnpm/cesium@1.141.0/node_modules/cesium/Build/Cesium/Workers/chunk-5BC2Q3QW.js} +2 -2
  65. package/dist/cesium/node_modules/.pnpm/cesium@1.141.0/node_modules/cesium/Build/Cesium/Workers/chunk-5XHUDY37.js +26 -0
  66. package/dist/cesium/{Workers/chunk-Z3QF2EHT.js → node_modules/.pnpm/cesium@1.141.0/node_modules/cesium/Build/Cesium/Workers/chunk-6WMLAJJP.js} +2 -2
  67. package/dist/cesium/node_modules/.pnpm/cesium@1.141.0/node_modules/cesium/Build/Cesium/Workers/chunk-72KUXMWU.js +26 -0
  68. package/dist/cesium/{Workers/chunk-EQ4YRVWL.js → node_modules/.pnpm/cesium@1.141.0/node_modules/cesium/Build/Cesium/Workers/chunk-7NQYTTAU.js} +2 -2
  69. package/dist/cesium/node_modules/.pnpm/cesium@1.141.0/node_modules/cesium/Build/Cesium/Workers/chunk-A35GG5WJ.js +26 -0
  70. package/dist/cesium/{Workers/chunk-FC4ZZ65J.js → node_modules/.pnpm/cesium@1.141.0/node_modules/cesium/Build/Cesium/Workers/chunk-AXNBHUAG.js} +2 -2
  71. package/dist/cesium/{Workers/chunk-BTSYJ5XU.js → node_modules/.pnpm/cesium@1.141.0/node_modules/cesium/Build/Cesium/Workers/chunk-DC3K7YTH.js} +2 -2
  72. package/dist/cesium/{Workers/chunk-SLT4J352.js → node_modules/.pnpm/cesium@1.141.0/node_modules/cesium/Build/Cesium/Workers/chunk-DRBPXGI7.js} +2 -2
  73. package/dist/cesium/{Workers/chunk-2MJIIVP4.js → node_modules/.pnpm/cesium@1.141.0/node_modules/cesium/Build/Cesium/Workers/chunk-EARRZPMO.js} +2 -2
  74. package/dist/cesium/node_modules/.pnpm/cesium@1.141.0/node_modules/cesium/Build/Cesium/Workers/chunk-EHC3BDVP.js +26 -0
  75. package/dist/cesium/node_modules/.pnpm/cesium@1.141.0/node_modules/cesium/Build/Cesium/Workers/chunk-EYZUSGKM.js +26 -0
  76. package/dist/cesium/node_modules/.pnpm/cesium@1.141.0/node_modules/cesium/Build/Cesium/Workers/chunk-EZSKHVA2.js +26 -0
  77. package/dist/cesium/{Workers/chunk-ICALLYLG.js → node_modules/.pnpm/cesium@1.141.0/node_modules/cesium/Build/Cesium/Workers/chunk-F3WJIFOO.js} +2 -2
  78. package/dist/cesium/{Workers/chunk-LSLE2RL4.js → node_modules/.pnpm/cesium@1.141.0/node_modules/cesium/Build/Cesium/Workers/chunk-FB7UV5BI.js} +2 -2
  79. package/dist/cesium/{Workers/chunk-CUUSNIVQ.js → node_modules/.pnpm/cesium@1.141.0/node_modules/cesium/Build/Cesium/Workers/chunk-FC6IYMYF.js} +2 -2
  80. package/dist/cesium/{Workers/chunk-TNSUQXWK.js → node_modules/.pnpm/cesium@1.141.0/node_modules/cesium/Build/Cesium/Workers/chunk-GF67PEXE.js} +2 -2
  81. package/dist/cesium/node_modules/.pnpm/cesium@1.141.0/node_modules/cesium/Build/Cesium/Workers/chunk-GXEQRH2R.js +26 -0
  82. package/dist/cesium/{Workers/chunk-M4HLDBCG.js → node_modules/.pnpm/cesium@1.141.0/node_modules/cesium/Build/Cesium/Workers/chunk-I5NKQIWE.js} +2 -2
  83. package/dist/cesium/node_modules/.pnpm/cesium@1.141.0/node_modules/cesium/Build/Cesium/Workers/chunk-IH7GXIUB.js +26 -0
  84. package/dist/cesium/{Workers/chunk-OIT7J4IC.js → node_modules/.pnpm/cesium@1.141.0/node_modules/cesium/Build/Cesium/Workers/chunk-IPP3UFGH.js} +2 -2
  85. package/dist/cesium/{Workers/chunk-WWWZVEEH.js → node_modules/.pnpm/cesium@1.141.0/node_modules/cesium/Build/Cesium/Workers/chunk-IYRGNBSH.js} +2 -2
  86. package/dist/cesium/{Workers/chunk-WPMZLB3Y.js → node_modules/.pnpm/cesium@1.141.0/node_modules/cesium/Build/Cesium/Workers/chunk-J6BM74AD.js} +2 -2
  87. package/dist/cesium/{Workers/chunk-QFM5DCMQ.js → node_modules/.pnpm/cesium@1.141.0/node_modules/cesium/Build/Cesium/Workers/chunk-KG2GJUJT.js} +1 -1
  88. package/dist/cesium/{Workers/chunk-XQHLGIO7.js → node_modules/.pnpm/cesium@1.141.0/node_modules/cesium/Build/Cesium/Workers/chunk-L7UE5MMF.js} +2 -2
  89. package/dist/cesium/{Workers/chunk-EFBN7QNX.js → node_modules/.pnpm/cesium@1.141.0/node_modules/cesium/Build/Cesium/Workers/chunk-LBZ34MHQ.js} +2 -2
  90. package/dist/cesium/{Workers/chunk-YP7I5QBZ.js → node_modules/.pnpm/cesium@1.141.0/node_modules/cesium/Build/Cesium/Workers/chunk-LOQDTQMX.js} +2 -2
  91. package/dist/cesium/node_modules/.pnpm/cesium@1.141.0/node_modules/cesium/Build/Cesium/Workers/chunk-LYLRYC4L.js +29 -0
  92. package/dist/cesium/node_modules/.pnpm/cesium@1.141.0/node_modules/cesium/Build/Cesium/Workers/chunk-MGPRMLLW.js +26 -0
  93. package/dist/cesium/{Workers/chunk-LI2ZSORM.js → node_modules/.pnpm/cesium@1.141.0/node_modules/cesium/Build/Cesium/Workers/chunk-NP26LKQA.js} +2 -2
  94. package/dist/cesium/node_modules/.pnpm/cesium@1.141.0/node_modules/cesium/Build/Cesium/Workers/chunk-OMUAZ3NM.js +26 -0
  95. package/dist/cesium/{Workers/chunk-S44JILQT.js → node_modules/.pnpm/cesium@1.141.0/node_modules/cesium/Build/Cesium/Workers/chunk-PPFUDJN4.js} +2 -2
  96. package/dist/cesium/{Workers/chunk-EDVBB7SS.js → node_modules/.pnpm/cesium@1.141.0/node_modules/cesium/Build/Cesium/Workers/chunk-PQ3V63XF.js} +2 -2
  97. package/dist/cesium/{Workers/chunk-Q5BPHJQF.js → node_modules/.pnpm/cesium@1.141.0/node_modules/cesium/Build/Cesium/Workers/chunk-PWBQN4GK.js} +2 -2
  98. package/dist/cesium/{Workers/chunk-E7KYDCM5.js → node_modules/.pnpm/cesium@1.141.0/node_modules/cesium/Build/Cesium/Workers/chunk-QOTMLO2T.js} +2 -2
  99. package/dist/cesium/{Workers/chunk-XUSCFAVF.js → node_modules/.pnpm/cesium@1.141.0/node_modules/cesium/Build/Cesium/Workers/chunk-SP35IT73.js} +2 -2
  100. package/dist/cesium/{Workers/chunk-6BD4U3VO.js → node_modules/.pnpm/cesium@1.141.0/node_modules/cesium/Build/Cesium/Workers/chunk-T3ZGSZKA.js} +2 -2
  101. package/dist/cesium/node_modules/.pnpm/cesium@1.141.0/node_modules/cesium/Build/Cesium/Workers/chunk-TM6SYYHO.js +28 -0
  102. package/dist/cesium/{Workers/chunk-VUKYSU4H.js → node_modules/.pnpm/cesium@1.141.0/node_modules/cesium/Build/Cesium/Workers/chunk-TSGIJVWH.js} +2 -2
  103. package/dist/cesium/node_modules/.pnpm/cesium@1.141.0/node_modules/cesium/Build/Cesium/Workers/chunk-U3YGOX3C.js +63 -0
  104. package/dist/cesium/{Workers/chunk-7TVGLKQF.js → node_modules/.pnpm/cesium@1.141.0/node_modules/cesium/Build/Cesium/Workers/chunk-VBYOXOSM.js} +2 -2
  105. package/dist/cesium/node_modules/.pnpm/cesium@1.141.0/node_modules/cesium/Build/Cesium/Workers/chunk-VCOHJNKB.js +26 -0
  106. package/dist/cesium/{Workers/chunk-WBOV35NL.js → node_modules/.pnpm/cesium@1.141.0/node_modules/cesium/Build/Cesium/Workers/chunk-VXAZXMUX.js} +2 -2
  107. package/dist/cesium/{Workers/chunk-IX4VMHEV.js → node_modules/.pnpm/cesium@1.141.0/node_modules/cesium/Build/Cesium/Workers/chunk-VXCJOT4W.js} +2 -2
  108. package/dist/cesium/node_modules/.pnpm/cesium@1.141.0/node_modules/cesium/Build/Cesium/Workers/chunk-WPD3MB6X.js +26 -0
  109. package/dist/cesium/{Workers/chunk-V3OSTMM6.js → node_modules/.pnpm/cesium@1.141.0/node_modules/cesium/Build/Cesium/Workers/chunk-X4D5KUN5.js} +2 -2
  110. package/dist/cesium/node_modules/.pnpm/cesium@1.141.0/node_modules/cesium/Build/Cesium/Workers/chunk-XEC656IT.js +26 -0
  111. package/dist/cesium/{Workers/chunk-MJHHSGEH.js → node_modules/.pnpm/cesium@1.141.0/node_modules/cesium/Build/Cesium/Workers/chunk-XR53QRQS.js} +2 -2
  112. package/dist/cesium/{Workers/chunk-XFIQ5DEQ.js → node_modules/.pnpm/cesium@1.141.0/node_modules/cesium/Build/Cesium/Workers/chunk-XR7MN4PJ.js} +2 -2
  113. package/dist/cesium/node_modules/.pnpm/cesium@1.141.0/node_modules/cesium/Build/Cesium/Workers/chunk-XU6O4MRS.js +26 -0
  114. package/dist/cesium/node_modules/.pnpm/cesium@1.141.0/node_modules/cesium/Build/Cesium/Workers/chunk-XZBHEBLF.js +29 -0
  115. package/dist/cesium/{Workers/chunk-OLZ3FYUM.js → node_modules/.pnpm/cesium@1.141.0/node_modules/cesium/Build/Cesium/Workers/chunk-Z2M4BF4E.js} +2 -2
  116. package/dist/cesium/{Workers/chunk-2ZBHLJST.js → node_modules/.pnpm/cesium@1.141.0/node_modules/cesium/Build/Cesium/Workers/chunk-Z4ERBZFB.js} +2 -2
  117. package/dist/cesium/{Workers/chunk-W37FE5GR.js → node_modules/.pnpm/cesium@1.141.0/node_modules/cesium/Build/Cesium/Workers/chunk-ZY2KCIWI.js} +2 -2
  118. package/dist/cesium/{Workers → node_modules/.pnpm/cesium@1.141.0/node_modules/cesium/Build/Cesium/Workers}/combineGeometry.js +2 -2
  119. package/dist/cesium/{Workers → node_modules/.pnpm/cesium@1.141.0/node_modules/cesium/Build/Cesium/Workers}/createBoxGeometry.js +2 -2
  120. package/dist/cesium/{Workers → node_modules/.pnpm/cesium@1.141.0/node_modules/cesium/Build/Cesium/Workers}/createBoxOutlineGeometry.js +2 -2
  121. package/dist/cesium/{Workers → node_modules/.pnpm/cesium@1.141.0/node_modules/cesium/Build/Cesium/Workers}/createCircleGeometry.js +2 -2
  122. package/dist/cesium/{Workers → node_modules/.pnpm/cesium@1.141.0/node_modules/cesium/Build/Cesium/Workers}/createCircleOutlineGeometry.js +2 -2
  123. package/dist/cesium/{Workers → node_modules/.pnpm/cesium@1.141.0/node_modules/cesium/Build/Cesium/Workers}/createCoplanarPolygonGeometry.js +2 -2
  124. package/dist/cesium/node_modules/.pnpm/cesium@1.141.0/node_modules/cesium/Build/Cesium/Workers/createCoplanarPolygonOutlineGeometry.js +26 -0
  125. package/dist/cesium/{Workers → node_modules/.pnpm/cesium@1.141.0/node_modules/cesium/Build/Cesium/Workers}/createCorridorGeometry.js +2 -2
  126. package/dist/cesium/{Workers → node_modules/.pnpm/cesium@1.141.0/node_modules/cesium/Build/Cesium/Workers}/createCorridorOutlineGeometry.js +2 -2
  127. package/dist/cesium/{Workers → node_modules/.pnpm/cesium@1.141.0/node_modules/cesium/Build/Cesium/Workers}/createCylinderGeometry.js +2 -2
  128. package/dist/cesium/{Workers → node_modules/.pnpm/cesium@1.141.0/node_modules/cesium/Build/Cesium/Workers}/createCylinderOutlineGeometry.js +2 -2
  129. package/dist/cesium/{Workers → node_modules/.pnpm/cesium@1.141.0/node_modules/cesium/Build/Cesium/Workers}/createEllipseGeometry.js +2 -2
  130. package/dist/cesium/{Workers → node_modules/.pnpm/cesium@1.141.0/node_modules/cesium/Build/Cesium/Workers}/createEllipseOutlineGeometry.js +2 -2
  131. package/dist/cesium/{Workers → node_modules/.pnpm/cesium@1.141.0/node_modules/cesium/Build/Cesium/Workers}/createEllipsoidGeometry.js +2 -2
  132. package/dist/cesium/{Workers → node_modules/.pnpm/cesium@1.141.0/node_modules/cesium/Build/Cesium/Workers}/createEllipsoidOutlineGeometry.js +2 -2
  133. package/dist/cesium/{Workers → node_modules/.pnpm/cesium@1.141.0/node_modules/cesium/Build/Cesium/Workers}/createFrustumGeometry.js +2 -2
  134. package/dist/cesium/{Workers → node_modules/.pnpm/cesium@1.141.0/node_modules/cesium/Build/Cesium/Workers}/createFrustumOutlineGeometry.js +2 -2
  135. package/dist/cesium/{Workers → node_modules/.pnpm/cesium@1.141.0/node_modules/cesium/Build/Cesium/Workers}/createGeometry.js +2 -2
  136. package/dist/cesium/node_modules/.pnpm/cesium@1.141.0/node_modules/cesium/Build/Cesium/Workers/createGroundPolylineGeometry.js +26 -0
  137. package/dist/cesium/{Workers → node_modules/.pnpm/cesium@1.141.0/node_modules/cesium/Build/Cesium/Workers}/createPlaneGeometry.js +2 -2
  138. package/dist/cesium/{Workers → node_modules/.pnpm/cesium@1.141.0/node_modules/cesium/Build/Cesium/Workers}/createPlaneOutlineGeometry.js +2 -2
  139. package/dist/cesium/{Workers → node_modules/.pnpm/cesium@1.141.0/node_modules/cesium/Build/Cesium/Workers}/createPolygonGeometry.js +2 -2
  140. package/dist/cesium/{Workers → node_modules/.pnpm/cesium@1.141.0/node_modules/cesium/Build/Cesium/Workers}/createPolygonOutlineGeometry.js +2 -2
  141. package/dist/cesium/{Workers → node_modules/.pnpm/cesium@1.141.0/node_modules/cesium/Build/Cesium/Workers}/createPolylineGeometry.js +2 -2
  142. package/dist/cesium/{Workers → node_modules/.pnpm/cesium@1.141.0/node_modules/cesium/Build/Cesium/Workers}/createPolylineVolumeGeometry.js +2 -2
  143. package/dist/cesium/{Workers → node_modules/.pnpm/cesium@1.141.0/node_modules/cesium/Build/Cesium/Workers}/createPolylineVolumeOutlineGeometry.js +2 -2
  144. package/dist/cesium/{Workers → node_modules/.pnpm/cesium@1.141.0/node_modules/cesium/Build/Cesium/Workers}/createRectangleGeometry.js +2 -2
  145. package/dist/cesium/{Workers → node_modules/.pnpm/cesium@1.141.0/node_modules/cesium/Build/Cesium/Workers}/createRectangleOutlineGeometry.js +2 -2
  146. package/dist/cesium/{Workers → node_modules/.pnpm/cesium@1.141.0/node_modules/cesium/Build/Cesium/Workers}/createSimplePolylineGeometry.js +2 -2
  147. package/dist/cesium/{Workers → node_modules/.pnpm/cesium@1.141.0/node_modules/cesium/Build/Cesium/Workers}/createSphereGeometry.js +2 -2
  148. package/dist/cesium/{Workers → node_modules/.pnpm/cesium@1.141.0/node_modules/cesium/Build/Cesium/Workers}/createSphereOutlineGeometry.js +2 -2
  149. package/dist/cesium/{Workers → node_modules/.pnpm/cesium@1.141.0/node_modules/cesium/Build/Cesium/Workers}/createTaskProcessorWorker.js +2 -2
  150. package/dist/cesium/{Workers → node_modules/.pnpm/cesium@1.141.0/node_modules/cesium/Build/Cesium/Workers}/createVectorTileClampedPolylines.js +2 -2
  151. package/dist/cesium/{Workers → node_modules/.pnpm/cesium@1.141.0/node_modules/cesium/Build/Cesium/Workers}/createVectorTileGeometries.js +2 -2
  152. package/dist/cesium/{Workers → node_modules/.pnpm/cesium@1.141.0/node_modules/cesium/Build/Cesium/Workers}/createVectorTilePoints.js +2 -2
  153. package/dist/cesium/{Workers → node_modules/.pnpm/cesium@1.141.0/node_modules/cesium/Build/Cesium/Workers}/createVectorTilePolygons.js +2 -2
  154. package/dist/cesium/{Workers → node_modules/.pnpm/cesium@1.141.0/node_modules/cesium/Build/Cesium/Workers}/createVectorTilePolylines.js +2 -2
  155. package/dist/cesium/{Workers → node_modules/.pnpm/cesium@1.141.0/node_modules/cesium/Build/Cesium/Workers}/createVerticesFromCesium3DTilesTerrain.js +2 -2
  156. package/dist/cesium/{Workers → node_modules/.pnpm/cesium@1.141.0/node_modules/cesium/Build/Cesium/Workers}/createVerticesFromGoogleEarthEnterpriseBuffer.js +2 -2
  157. package/dist/cesium/{Workers → node_modules/.pnpm/cesium@1.141.0/node_modules/cesium/Build/Cesium/Workers}/createVerticesFromHeightmap.js +2 -2
  158. package/dist/cesium/{Workers → node_modules/.pnpm/cesium@1.141.0/node_modules/cesium/Build/Cesium/Workers}/createVerticesFromQuantizedTerrainMesh.js +2 -2
  159. package/dist/cesium/{Workers → node_modules/.pnpm/cesium@1.141.0/node_modules/cesium/Build/Cesium/Workers}/createWallGeometry.js +2 -2
  160. package/dist/cesium/{Workers → node_modules/.pnpm/cesium@1.141.0/node_modules/cesium/Build/Cesium/Workers}/createWallOutlineGeometry.js +2 -2
  161. package/dist/cesium/{Workers → node_modules/.pnpm/cesium@1.141.0/node_modules/cesium/Build/Cesium/Workers}/decodeDraco.js +2 -2
  162. package/dist/cesium/{Workers → node_modules/.pnpm/cesium@1.141.0/node_modules/cesium/Build/Cesium/Workers}/decodeGoogleEarthEnterprisePacket.js +2 -2
  163. package/dist/cesium/{Workers → node_modules/.pnpm/cesium@1.141.0/node_modules/cesium/Build/Cesium/Workers}/decodeI3S.js +2 -2
  164. package/dist/cesium/{Workers → node_modules/.pnpm/cesium@1.141.0/node_modules/cesium/Build/Cesium/Workers}/gaussianSplatSorter.js +2 -2
  165. package/dist/cesium/{Workers → node_modules/.pnpm/cesium@1.141.0/node_modules/cesium/Build/Cesium/Workers}/gaussianSplatTextureGenerator.js +2 -2
  166. package/dist/cesium/{Workers → node_modules/.pnpm/cesium@1.141.0/node_modules/cesium/Build/Cesium/Workers}/incrementallyBuildTerrainPicker.js +2 -2
  167. package/dist/cesium/node_modules/.pnpm/cesium@1.141.0/node_modules/cesium/Build/Cesium/Workers/transcodeKTX2.js +56 -0
  168. package/dist/cesium/{Workers → node_modules/.pnpm/cesium@1.141.0/node_modules/cesium/Build/Cesium/Workers}/transferTypedArrayTest.js +1 -1
  169. package/dist/cesium/node_modules/.pnpm/cesium@1.141.0/node_modules/cesium/Build/Cesium/Workers/upsampleQuantizedTerrainMesh.js +26 -0
  170. package/dist/cesium/{Workers → node_modules/.pnpm/cesium@1.141.0/node_modules/cesium/Build/Cesium/Workers}/upsampleVerticesFromCesium3DTilesTerrain.js +2 -2
  171. package/dist/index.html +12 -14
  172. package/package.json +52 -45
  173. package/src/components/mcp/McpLanding.tsx +1 -1
  174. package/src/components/mcp/McpPlayground.tsx +1 -1
  175. package/src/components/mcp/PlaygroundChat.tsx +90 -52
  176. package/src/components/viewer/AddElementPanel.tsx +2 -2
  177. package/src/components/viewer/BasepointOverlay.tsx +239 -0
  178. package/src/components/viewer/CesiumOverlay.tsx +130 -115
  179. package/src/components/viewer/CesiumPlacementEditor.tsx +1024 -0
  180. package/src/components/viewer/ChatPanel.tsx +76 -93
  181. package/src/components/viewer/CommandPalette.tsx +25 -0
  182. package/src/components/viewer/EntityContextMenu.tsx +68 -10
  183. package/src/components/viewer/GeometryAxisRow.tsx +54 -0
  184. package/src/components/viewer/GeometryEditCard.tsx +392 -0
  185. package/src/components/viewer/HierarchyPanel.tsx +2 -2
  186. package/src/components/viewer/IDSAuditSummary.tsx +2 -2
  187. package/src/components/viewer/KeyboardShortcutsDialog.tsx +58 -4
  188. package/src/components/viewer/MainToolbar.tsx +308 -7
  189. package/src/components/viewer/PropertiesPanel.tsx +28 -31
  190. package/src/components/viewer/StatusBar.tsx +12 -0
  191. package/src/components/viewer/ToolOverlays.tsx +36 -0
  192. package/src/components/viewer/ViewerLayout.tsx +27 -0
  193. package/src/components/viewer/Viewport.tsx +49 -4
  194. package/src/components/viewer/ViewportContainer.tsx +158 -33
  195. package/src/components/viewer/ViewportOverlays.tsx +49 -106
  196. package/src/components/viewer/chat/ByokKeyModal.tsx +338 -0
  197. package/src/components/viewer/chat/ByokStreamingPill.tsx +62 -0
  198. package/src/components/viewer/chat/ByokTrustDiagram.tsx +192 -0
  199. package/src/components/viewer/properties/FederationAlignmentControls.tsx +180 -0
  200. package/src/components/viewer/properties/GeoreferencingPanel.tsx +55 -52
  201. package/src/components/viewer/properties/ModelMetadataPanel.tsx +55 -44
  202. package/src/components/viewer/properties/PrecisionGridBadge.tsx +125 -0
  203. package/src/components/viewer/properties/raw-step-format.ts +5 -3
  204. package/src/components/viewer/selectionHandlers.ts +308 -11
  205. package/src/components/viewer/tools/GizmoOverlay.tsx +322 -0
  206. package/src/components/viewer/tools/SplitNumericInput.tsx +225 -0
  207. package/src/components/viewer/tools/SplitOverlay.tsx +242 -0
  208. package/src/components/viewer/tools/WallEndpointOverlay.tsx +252 -0
  209. package/src/components/viewer/useGeometryStreaming.ts +100 -1
  210. package/src/components/viewer/useMouseControls.ts +8 -1
  211. package/src/hooks/useBCF.ts +6 -6
  212. package/src/hooks/useCameraTickSubscription.ts +62 -0
  213. package/src/hooks/useIfc.ts +4 -0
  214. package/src/hooks/useIfcFederation.ts +368 -20
  215. package/src/hooks/useKeyboardShortcuts.ts +86 -0
  216. package/src/hooks/useLevelDisplayEffect.ts +160 -0
  217. package/src/hooks/useViewerSelectors.ts +8 -0
  218. package/src/lib/__test__/stubs.ts +110 -0
  219. package/src/lib/geo/cesium-bridge.ts +86 -50
  220. package/src/lib/geo/cesium-placement.test.ts +260 -0
  221. package/src/lib/geo/cesium-placement.ts +237 -0
  222. package/src/lib/geo/effective-georef.test.ts +97 -8
  223. package/src/lib/geo/effective-georef.ts +40 -93
  224. package/src/lib/geo/geo-scale.ts +160 -0
  225. package/src/lib/geo/ifc-origin.test.ts +176 -0
  226. package/src/lib/geo/ifc-origin.ts +144 -0
  227. package/src/lib/geo/precision-grids.ts +444 -0
  228. package/src/lib/geo/reproject.test.ts +218 -0
  229. package/src/lib/geo/reproject.ts +199 -42
  230. package/src/lib/geo/terrain-elevation.ts +198 -89
  231. package/src/lib/lens/adapter.ts +52 -6
  232. package/src/lib/level-offsets.test.ts +153 -0
  233. package/src/lib/level-offsets.ts +140 -0
  234. package/src/lib/linear-element-edit.test.ts +220 -0
  235. package/src/lib/linear-element-edit.ts +327 -0
  236. package/src/lib/llm/clipboard-detect.test.ts +150 -0
  237. package/src/lib/llm/clipboard-detect.ts +90 -0
  238. package/src/lib/llm/models.ts +28 -0
  239. package/src/lib/llm/stream-direct.ts +16 -4
  240. package/src/lib/llm/types.ts +8 -0
  241. package/src/lib/metadata-clone.test.ts +173 -0
  242. package/src/lib/metadata-clone.ts +124 -0
  243. package/src/lib/placement-core.ts +340 -0
  244. package/src/lib/placement-edit.boot.ts +21 -0
  245. package/src/lib/placement-edit.test.ts +464 -0
  246. package/src/lib/placement-edit.ts +47 -0
  247. package/src/lib/polygon-clip.test.ts +193 -0
  248. package/src/lib/polygon-clip.ts +199 -0
  249. package/src/lib/slab-edit.test.ts +169 -0
  250. package/src/lib/slab-edit.ts +312 -0
  251. package/src/lib/wall-edit.ts +342 -0
  252. package/src/lib/wall-opening-reassign.test.ts +291 -0
  253. package/src/lib/wall-opening-reassign.ts +241 -0
  254. package/src/main.tsx +4 -0
  255. package/src/services/playground-model.ts +55 -0
  256. package/src/store/index.ts +11 -5
  257. package/src/store/slices/cesiumSlice.ts +154 -20
  258. package/src/store/slices/dataSlice.ts +80 -0
  259. package/src/store/slices/levelDisplaySlice.ts +105 -0
  260. package/src/store/slices/modelSlice.test.ts +19 -0
  261. package/src/store/slices/mutationSlice.ts +1138 -1
  262. package/src/store/slices/splitToolSlice.ts +165 -0
  263. package/src/store/slices/uiSlice.edit-mode.test.ts +210 -0
  264. package/src/store/slices/uiSlice.ts +78 -1
  265. package/src/store/types.ts +57 -2
  266. package/src/store.ts +3 -0
  267. package/src/utils/createBlankIfc.ts +37 -0
  268. package/tsconfig.json +1 -0
  269. package/.turbo/turbo-typecheck.log +0 -4
  270. package/dist/assets/arrow-CZ5kQ26f.js +0 -20
  271. package/dist/assets/arrow2_bg-BoXCojjR.wasm +0 -0
  272. package/dist/assets/bcf-4K724hw0.js +0 -281
  273. package/dist/assets/browser-C5TFR7sH.js +0 -694
  274. package/dist/assets/cesium-DUOzBlqv.js +0 -17817
  275. package/dist/assets/decode-worker-t2EGKAxO.js +0 -1708
  276. package/dist/assets/emscripten-module-BTRCZGcB.wasm +0 -0
  277. package/dist/assets/emscripten-module-CGIn_cMh.wasm +0 -0
  278. package/dist/assets/emscripten-module-DYvzWiHh.wasm +0 -0
  279. package/dist/assets/emscripten-module-NWak2PoB.wasm +0 -0
  280. package/dist/assets/emscripten-module.browser-CY5t0Vfq.js +0 -1
  281. package/dist/assets/esbuild-COv63sf-.js +0 -1
  282. package/dist/assets/event-DIOks52T.js +0 -1
  283. package/dist/assets/ffi-DlhRHxHv.js +0 -1
  284. package/dist/assets/geometry-controller.worker-NH8pZmrU.js +0 -7
  285. package/dist/assets/geometry.worker-Bp4rW_R1.js +0 -1
  286. package/dist/assets/ifc-lite-DfZHk36-.js +0 -7
  287. package/dist/assets/ifc-lite_bg-DlKs5-yM.wasm +0 -0
  288. package/dist/assets/ifc-lite_bg-PqmRe3Ph.wasm +0 -0
  289. package/dist/assets/index-CSWgTe1s.css +0 -1
  290. package/dist/assets/index-XwKzDuw6.js +0 -22
  291. package/dist/assets/laz-perf-Cvr_Lepg.js +0 -1
  292. package/dist/assets/maplibre-gl-CGLcoNXc.js +0 -811
  293. package/dist/assets/sandbox-DPD1ROr0.js +0 -9700
  294. package/dist/assets/three-CDRZThFA.js +0 -4057
  295. package/dist/assets/wasm-bridge-CErti6zX.js +0 -1
  296. package/dist/assets/zip-DBEtpeu6.js +0 -12
  297. package/dist/cesium/Workers/chunk-23ZQ2IVV.js +0 -29
  298. package/dist/cesium/Workers/chunk-2EQO3Q56.js +0 -26
  299. package/dist/cesium/Workers/chunk-2TE5NTVD.js +0 -26
  300. package/dist/cesium/Workers/chunk-BXMEEOCS.js +0 -63
  301. package/dist/cesium/Workers/chunk-BYLCY7GP.js +0 -29
  302. package/dist/cesium/Workers/chunk-CTHM3W6I.js +0 -26
  303. package/dist/cesium/Workers/chunk-E3JOOS3S.js +0 -26
  304. package/dist/cesium/Workers/chunk-F6PRE7D6.js +0 -26
  305. package/dist/cesium/Workers/chunk-FFBVWF2L.js +0 -26
  306. package/dist/cesium/Workers/chunk-GBAA6GVX.js +0 -26
  307. package/dist/cesium/Workers/chunk-ILRYTWTP.js +0 -26
  308. package/dist/cesium/Workers/chunk-IRNLBSEJ.js +0 -26
  309. package/dist/cesium/Workers/chunk-L6QHHACZ.js +0 -26
  310. package/dist/cesium/Workers/chunk-NMVKML6W.js +0 -26
  311. package/dist/cesium/Workers/chunk-OIRKANTH.js +0 -26
  312. package/dist/cesium/Workers/chunk-QKUIYMGC.js +0 -28
  313. package/dist/cesium/Workers/chunk-SQMIIXB7.js +0 -26
  314. package/dist/cesium/Workers/chunk-TJ4XLGBQ.js +0 -26
  315. package/dist/cesium/Workers/createCoplanarPolygonOutlineGeometry.js +0 -26
  316. package/dist/cesium/Workers/createGroundPolylineGeometry.js +0 -26
  317. package/dist/cesium/Workers/transcodeKTX2.js +0 -56
  318. package/dist/cesium/Workers/upsampleQuantizedTerrainMesh.js +0 -26
  319. package/src/components/viewer/CesiumSettingsDialog.tsx +0 -100
  320. /package/dist/cesium/{Assets → node_modules/.pnpm/cesium@1.141.0/node_modules/cesium/Build/Cesium/Assets}/IAU2006_XYS/IAU2006_XYS_0.json +0 -0
  321. /package/dist/cesium/{Assets → node_modules/.pnpm/cesium@1.141.0/node_modules/cesium/Build/Cesium/Assets}/IAU2006_XYS/IAU2006_XYS_1.json +0 -0
  322. /package/dist/cesium/{Assets → node_modules/.pnpm/cesium@1.141.0/node_modules/cesium/Build/Cesium/Assets}/IAU2006_XYS/IAU2006_XYS_10.json +0 -0
  323. /package/dist/cesium/{Assets → node_modules/.pnpm/cesium@1.141.0/node_modules/cesium/Build/Cesium/Assets}/IAU2006_XYS/IAU2006_XYS_11.json +0 -0
  324. /package/dist/cesium/{Assets → node_modules/.pnpm/cesium@1.141.0/node_modules/cesium/Build/Cesium/Assets}/IAU2006_XYS/IAU2006_XYS_12.json +0 -0
  325. /package/dist/cesium/{Assets → node_modules/.pnpm/cesium@1.141.0/node_modules/cesium/Build/Cesium/Assets}/IAU2006_XYS/IAU2006_XYS_13.json +0 -0
  326. /package/dist/cesium/{Assets → node_modules/.pnpm/cesium@1.141.0/node_modules/cesium/Build/Cesium/Assets}/IAU2006_XYS/IAU2006_XYS_14.json +0 -0
  327. /package/dist/cesium/{Assets → node_modules/.pnpm/cesium@1.141.0/node_modules/cesium/Build/Cesium/Assets}/IAU2006_XYS/IAU2006_XYS_15.json +0 -0
  328. /package/dist/cesium/{Assets → node_modules/.pnpm/cesium@1.141.0/node_modules/cesium/Build/Cesium/Assets}/IAU2006_XYS/IAU2006_XYS_16.json +0 -0
  329. /package/dist/cesium/{Assets → node_modules/.pnpm/cesium@1.141.0/node_modules/cesium/Build/Cesium/Assets}/IAU2006_XYS/IAU2006_XYS_17.json +0 -0
  330. /package/dist/cesium/{Assets → node_modules/.pnpm/cesium@1.141.0/node_modules/cesium/Build/Cesium/Assets}/IAU2006_XYS/IAU2006_XYS_18.json +0 -0
  331. /package/dist/cesium/{Assets → node_modules/.pnpm/cesium@1.141.0/node_modules/cesium/Build/Cesium/Assets}/IAU2006_XYS/IAU2006_XYS_19.json +0 -0
  332. /package/dist/cesium/{Assets → node_modules/.pnpm/cesium@1.141.0/node_modules/cesium/Build/Cesium/Assets}/IAU2006_XYS/IAU2006_XYS_2.json +0 -0
  333. /package/dist/cesium/{Assets → node_modules/.pnpm/cesium@1.141.0/node_modules/cesium/Build/Cesium/Assets}/IAU2006_XYS/IAU2006_XYS_20.json +0 -0
  334. /package/dist/cesium/{Assets → node_modules/.pnpm/cesium@1.141.0/node_modules/cesium/Build/Cesium/Assets}/IAU2006_XYS/IAU2006_XYS_21.json +0 -0
  335. /package/dist/cesium/{Assets → node_modules/.pnpm/cesium@1.141.0/node_modules/cesium/Build/Cesium/Assets}/IAU2006_XYS/IAU2006_XYS_22.json +0 -0
  336. /package/dist/cesium/{Assets → node_modules/.pnpm/cesium@1.141.0/node_modules/cesium/Build/Cesium/Assets}/IAU2006_XYS/IAU2006_XYS_23.json +0 -0
  337. /package/dist/cesium/{Assets → node_modules/.pnpm/cesium@1.141.0/node_modules/cesium/Build/Cesium/Assets}/IAU2006_XYS/IAU2006_XYS_24.json +0 -0
  338. /package/dist/cesium/{Assets → node_modules/.pnpm/cesium@1.141.0/node_modules/cesium/Build/Cesium/Assets}/IAU2006_XYS/IAU2006_XYS_25.json +0 -0
  339. /package/dist/cesium/{Assets → node_modules/.pnpm/cesium@1.141.0/node_modules/cesium/Build/Cesium/Assets}/IAU2006_XYS/IAU2006_XYS_26.json +0 -0
  340. /package/dist/cesium/{Assets → node_modules/.pnpm/cesium@1.141.0/node_modules/cesium/Build/Cesium/Assets}/IAU2006_XYS/IAU2006_XYS_27.json +0 -0
  341. /package/dist/cesium/{Assets → node_modules/.pnpm/cesium@1.141.0/node_modules/cesium/Build/Cesium/Assets}/IAU2006_XYS/IAU2006_XYS_3.json +0 -0
  342. /package/dist/cesium/{Assets → node_modules/.pnpm/cesium@1.141.0/node_modules/cesium/Build/Cesium/Assets}/IAU2006_XYS/IAU2006_XYS_4.json +0 -0
  343. /package/dist/cesium/{Assets → node_modules/.pnpm/cesium@1.141.0/node_modules/cesium/Build/Cesium/Assets}/IAU2006_XYS/IAU2006_XYS_5.json +0 -0
  344. /package/dist/cesium/{Assets → node_modules/.pnpm/cesium@1.141.0/node_modules/cesium/Build/Cesium/Assets}/IAU2006_XYS/IAU2006_XYS_6.json +0 -0
  345. /package/dist/cesium/{Assets → node_modules/.pnpm/cesium@1.141.0/node_modules/cesium/Build/Cesium/Assets}/IAU2006_XYS/IAU2006_XYS_7.json +0 -0
  346. /package/dist/cesium/{Assets → node_modules/.pnpm/cesium@1.141.0/node_modules/cesium/Build/Cesium/Assets}/IAU2006_XYS/IAU2006_XYS_8.json +0 -0
  347. /package/dist/cesium/{Assets → node_modules/.pnpm/cesium@1.141.0/node_modules/cesium/Build/Cesium/Assets}/IAU2006_XYS/IAU2006_XYS_9.json +0 -0
  348. /package/dist/cesium/{Assets → node_modules/.pnpm/cesium@1.141.0/node_modules/cesium/Build/Cesium/Assets}/Images/bing_maps_credit.png +0 -0
  349. /package/dist/cesium/{Assets → node_modules/.pnpm/cesium@1.141.0/node_modules/cesium/Build/Cesium/Assets}/Images/cesium_credit.png +0 -0
  350. /package/dist/cesium/{Assets → node_modules/.pnpm/cesium@1.141.0/node_modules/cesium/Build/Cesium/Assets}/Images/google_earth_credit.png +0 -0
  351. /package/dist/cesium/{Assets → node_modules/.pnpm/cesium@1.141.0/node_modules/cesium/Build/Cesium/Assets}/Images/ion-credit.png +0 -0
  352. /package/dist/cesium/{Assets → node_modules/.pnpm/cesium@1.141.0/node_modules/cesium/Build/Cesium/Assets}/Textures/LensFlare/DirtMask.jpg +0 -0
  353. /package/dist/cesium/{Assets → node_modules/.pnpm/cesium@1.141.0/node_modules/cesium/Build/Cesium/Assets}/Textures/LensFlare/StarBurst.jpg +0 -0
  354. /package/dist/cesium/{Assets → node_modules/.pnpm/cesium@1.141.0/node_modules/cesium/Build/Cesium/Assets}/Textures/NaturalEarthII/0/0/0.jpg +0 -0
  355. /package/dist/cesium/{Assets → node_modules/.pnpm/cesium@1.141.0/node_modules/cesium/Build/Cesium/Assets}/Textures/NaturalEarthII/0/1/0.jpg +0 -0
  356. /package/dist/cesium/{Assets → node_modules/.pnpm/cesium@1.141.0/node_modules/cesium/Build/Cesium/Assets}/Textures/NaturalEarthII/1/0/0.jpg +0 -0
  357. /package/dist/cesium/{Assets → node_modules/.pnpm/cesium@1.141.0/node_modules/cesium/Build/Cesium/Assets}/Textures/NaturalEarthII/1/0/1.jpg +0 -0
  358. /package/dist/cesium/{Assets → node_modules/.pnpm/cesium@1.141.0/node_modules/cesium/Build/Cesium/Assets}/Textures/NaturalEarthII/1/1/0.jpg +0 -0
  359. /package/dist/cesium/{Assets → node_modules/.pnpm/cesium@1.141.0/node_modules/cesium/Build/Cesium/Assets}/Textures/NaturalEarthII/1/1/1.jpg +0 -0
  360. /package/dist/cesium/{Assets → node_modules/.pnpm/cesium@1.141.0/node_modules/cesium/Build/Cesium/Assets}/Textures/NaturalEarthII/1/2/0.jpg +0 -0
  361. /package/dist/cesium/{Assets → node_modules/.pnpm/cesium@1.141.0/node_modules/cesium/Build/Cesium/Assets}/Textures/NaturalEarthII/1/2/1.jpg +0 -0
  362. /package/dist/cesium/{Assets → node_modules/.pnpm/cesium@1.141.0/node_modules/cesium/Build/Cesium/Assets}/Textures/NaturalEarthII/1/3/0.jpg +0 -0
  363. /package/dist/cesium/{Assets → node_modules/.pnpm/cesium@1.141.0/node_modules/cesium/Build/Cesium/Assets}/Textures/NaturalEarthII/1/3/1.jpg +0 -0
  364. /package/dist/cesium/{Assets → node_modules/.pnpm/cesium@1.141.0/node_modules/cesium/Build/Cesium/Assets}/Textures/NaturalEarthII/2/0/0.jpg +0 -0
  365. /package/dist/cesium/{Assets → node_modules/.pnpm/cesium@1.141.0/node_modules/cesium/Build/Cesium/Assets}/Textures/NaturalEarthII/2/0/1.jpg +0 -0
  366. /package/dist/cesium/{Assets → node_modules/.pnpm/cesium@1.141.0/node_modules/cesium/Build/Cesium/Assets}/Textures/NaturalEarthII/2/0/2.jpg +0 -0
  367. /package/dist/cesium/{Assets → node_modules/.pnpm/cesium@1.141.0/node_modules/cesium/Build/Cesium/Assets}/Textures/NaturalEarthII/2/0/3.jpg +0 -0
  368. /package/dist/cesium/{Assets → node_modules/.pnpm/cesium@1.141.0/node_modules/cesium/Build/Cesium/Assets}/Textures/NaturalEarthII/2/1/0.jpg +0 -0
  369. /package/dist/cesium/{Assets → node_modules/.pnpm/cesium@1.141.0/node_modules/cesium/Build/Cesium/Assets}/Textures/NaturalEarthII/2/1/1.jpg +0 -0
  370. /package/dist/cesium/{Assets → node_modules/.pnpm/cesium@1.141.0/node_modules/cesium/Build/Cesium/Assets}/Textures/NaturalEarthII/2/1/2.jpg +0 -0
  371. /package/dist/cesium/{Assets → node_modules/.pnpm/cesium@1.141.0/node_modules/cesium/Build/Cesium/Assets}/Textures/NaturalEarthII/2/1/3.jpg +0 -0
  372. /package/dist/cesium/{Assets → node_modules/.pnpm/cesium@1.141.0/node_modules/cesium/Build/Cesium/Assets}/Textures/NaturalEarthII/2/2/0.jpg +0 -0
  373. /package/dist/cesium/{Assets → node_modules/.pnpm/cesium@1.141.0/node_modules/cesium/Build/Cesium/Assets}/Textures/NaturalEarthII/2/2/1.jpg +0 -0
  374. /package/dist/cesium/{Assets → node_modules/.pnpm/cesium@1.141.0/node_modules/cesium/Build/Cesium/Assets}/Textures/NaturalEarthII/2/2/2.jpg +0 -0
  375. /package/dist/cesium/{Assets → node_modules/.pnpm/cesium@1.141.0/node_modules/cesium/Build/Cesium/Assets}/Textures/NaturalEarthII/2/2/3.jpg +0 -0
  376. /package/dist/cesium/{Assets → node_modules/.pnpm/cesium@1.141.0/node_modules/cesium/Build/Cesium/Assets}/Textures/NaturalEarthII/2/3/0.jpg +0 -0
  377. /package/dist/cesium/{Assets → node_modules/.pnpm/cesium@1.141.0/node_modules/cesium/Build/Cesium/Assets}/Textures/NaturalEarthII/2/3/1.jpg +0 -0
  378. /package/dist/cesium/{Assets → node_modules/.pnpm/cesium@1.141.0/node_modules/cesium/Build/Cesium/Assets}/Textures/NaturalEarthII/2/3/2.jpg +0 -0
  379. /package/dist/cesium/{Assets → node_modules/.pnpm/cesium@1.141.0/node_modules/cesium/Build/Cesium/Assets}/Textures/NaturalEarthII/2/3/3.jpg +0 -0
  380. /package/dist/cesium/{Assets → node_modules/.pnpm/cesium@1.141.0/node_modules/cesium/Build/Cesium/Assets}/Textures/NaturalEarthII/2/4/0.jpg +0 -0
  381. /package/dist/cesium/{Assets → node_modules/.pnpm/cesium@1.141.0/node_modules/cesium/Build/Cesium/Assets}/Textures/NaturalEarthII/2/4/1.jpg +0 -0
  382. /package/dist/cesium/{Assets → node_modules/.pnpm/cesium@1.141.0/node_modules/cesium/Build/Cesium/Assets}/Textures/NaturalEarthII/2/4/2.jpg +0 -0
  383. /package/dist/cesium/{Assets → node_modules/.pnpm/cesium@1.141.0/node_modules/cesium/Build/Cesium/Assets}/Textures/NaturalEarthII/2/4/3.jpg +0 -0
  384. /package/dist/cesium/{Assets → node_modules/.pnpm/cesium@1.141.0/node_modules/cesium/Build/Cesium/Assets}/Textures/NaturalEarthII/2/5/0.jpg +0 -0
  385. /package/dist/cesium/{Assets → node_modules/.pnpm/cesium@1.141.0/node_modules/cesium/Build/Cesium/Assets}/Textures/NaturalEarthII/2/5/1.jpg +0 -0
  386. /package/dist/cesium/{Assets → node_modules/.pnpm/cesium@1.141.0/node_modules/cesium/Build/Cesium/Assets}/Textures/NaturalEarthII/2/5/2.jpg +0 -0
  387. /package/dist/cesium/{Assets → node_modules/.pnpm/cesium@1.141.0/node_modules/cesium/Build/Cesium/Assets}/Textures/NaturalEarthII/2/5/3.jpg +0 -0
  388. /package/dist/cesium/{Assets → node_modules/.pnpm/cesium@1.141.0/node_modules/cesium/Build/Cesium/Assets}/Textures/NaturalEarthII/2/6/0.jpg +0 -0
  389. /package/dist/cesium/{Assets → node_modules/.pnpm/cesium@1.141.0/node_modules/cesium/Build/Cesium/Assets}/Textures/NaturalEarthII/2/6/1.jpg +0 -0
  390. /package/dist/cesium/{Assets → node_modules/.pnpm/cesium@1.141.0/node_modules/cesium/Build/Cesium/Assets}/Textures/NaturalEarthII/2/6/2.jpg +0 -0
  391. /package/dist/cesium/{Assets → node_modules/.pnpm/cesium@1.141.0/node_modules/cesium/Build/Cesium/Assets}/Textures/NaturalEarthII/2/6/3.jpg +0 -0
  392. /package/dist/cesium/{Assets → node_modules/.pnpm/cesium@1.141.0/node_modules/cesium/Build/Cesium/Assets}/Textures/NaturalEarthII/2/7/0.jpg +0 -0
  393. /package/dist/cesium/{Assets → node_modules/.pnpm/cesium@1.141.0/node_modules/cesium/Build/Cesium/Assets}/Textures/NaturalEarthII/2/7/1.jpg +0 -0
  394. /package/dist/cesium/{Assets → node_modules/.pnpm/cesium@1.141.0/node_modules/cesium/Build/Cesium/Assets}/Textures/NaturalEarthII/2/7/2.jpg +0 -0
  395. /package/dist/cesium/{Assets → node_modules/.pnpm/cesium@1.141.0/node_modules/cesium/Build/Cesium/Assets}/Textures/NaturalEarthII/2/7/3.jpg +0 -0
  396. /package/dist/cesium/{Assets → node_modules/.pnpm/cesium@1.141.0/node_modules/cesium/Build/Cesium/Assets}/Textures/NaturalEarthII/tilemapresource.xml +0 -0
  397. /package/dist/cesium/{Assets → node_modules/.pnpm/cesium@1.141.0/node_modules/cesium/Build/Cesium/Assets}/Textures/SkyBox/tycho2t3_80_mx.jpg +0 -0
  398. /package/dist/cesium/{Assets → node_modules/.pnpm/cesium@1.141.0/node_modules/cesium/Build/Cesium/Assets}/Textures/SkyBox/tycho2t3_80_my.jpg +0 -0
  399. /package/dist/cesium/{Assets → node_modules/.pnpm/cesium@1.141.0/node_modules/cesium/Build/Cesium/Assets}/Textures/SkyBox/tycho2t3_80_mz.jpg +0 -0
  400. /package/dist/cesium/{Assets → node_modules/.pnpm/cesium@1.141.0/node_modules/cesium/Build/Cesium/Assets}/Textures/SkyBox/tycho2t3_80_px.jpg +0 -0
  401. /package/dist/cesium/{Assets → node_modules/.pnpm/cesium@1.141.0/node_modules/cesium/Build/Cesium/Assets}/Textures/SkyBox/tycho2t3_80_py.jpg +0 -0
  402. /package/dist/cesium/{Assets → node_modules/.pnpm/cesium@1.141.0/node_modules/cesium/Build/Cesium/Assets}/Textures/SkyBox/tycho2t3_80_pz.jpg +0 -0
  403. /package/dist/cesium/{Assets → node_modules/.pnpm/cesium@1.141.0/node_modules/cesium/Build/Cesium/Assets}/Textures/maki/airfield.png +0 -0
  404. /package/dist/cesium/{Assets → node_modules/.pnpm/cesium@1.141.0/node_modules/cesium/Build/Cesium/Assets}/Textures/maki/airport.png +0 -0
  405. /package/dist/cesium/{Assets → node_modules/.pnpm/cesium@1.141.0/node_modules/cesium/Build/Cesium/Assets}/Textures/maki/alcohol-shop.png +0 -0
  406. /package/dist/cesium/{Assets → node_modules/.pnpm/cesium@1.141.0/node_modules/cesium/Build/Cesium/Assets}/Textures/maki/america-football.png +0 -0
  407. /package/dist/cesium/{Assets → node_modules/.pnpm/cesium@1.141.0/node_modules/cesium/Build/Cesium/Assets}/Textures/maki/art-gallery.png +0 -0
  408. /package/dist/cesium/{Assets → node_modules/.pnpm/cesium@1.141.0/node_modules/cesium/Build/Cesium/Assets}/Textures/maki/bakery.png +0 -0
  409. /package/dist/cesium/{Assets → node_modules/.pnpm/cesium@1.141.0/node_modules/cesium/Build/Cesium/Assets}/Textures/maki/bank.png +0 -0
  410. /package/dist/cesium/{Assets → node_modules/.pnpm/cesium@1.141.0/node_modules/cesium/Build/Cesium/Assets}/Textures/maki/bar.png +0 -0
  411. /package/dist/cesium/{Assets → node_modules/.pnpm/cesium@1.141.0/node_modules/cesium/Build/Cesium/Assets}/Textures/maki/baseball.png +0 -0
  412. /package/dist/cesium/{Assets → node_modules/.pnpm/cesium@1.141.0/node_modules/cesium/Build/Cesium/Assets}/Textures/maki/basketball.png +0 -0
  413. /package/dist/cesium/{Assets → node_modules/.pnpm/cesium@1.141.0/node_modules/cesium/Build/Cesium/Assets}/Textures/maki/beer.png +0 -0
  414. /package/dist/cesium/{Assets → node_modules/.pnpm/cesium@1.141.0/node_modules/cesium/Build/Cesium/Assets}/Textures/maki/bicycle.png +0 -0
  415. /package/dist/cesium/{Assets → node_modules/.pnpm/cesium@1.141.0/node_modules/cesium/Build/Cesium/Assets}/Textures/maki/building.png +0 -0
  416. /package/dist/cesium/{Assets → node_modules/.pnpm/cesium@1.141.0/node_modules/cesium/Build/Cesium/Assets}/Textures/maki/bus.png +0 -0
  417. /package/dist/cesium/{Assets → node_modules/.pnpm/cesium@1.141.0/node_modules/cesium/Build/Cesium/Assets}/Textures/maki/cafe.png +0 -0
  418. /package/dist/cesium/{Assets → node_modules/.pnpm/cesium@1.141.0/node_modules/cesium/Build/Cesium/Assets}/Textures/maki/camera.png +0 -0
  419. /package/dist/cesium/{Assets → node_modules/.pnpm/cesium@1.141.0/node_modules/cesium/Build/Cesium/Assets}/Textures/maki/campsite.png +0 -0
  420. /package/dist/cesium/{Assets → node_modules/.pnpm/cesium@1.141.0/node_modules/cesium/Build/Cesium/Assets}/Textures/maki/car.png +0 -0
  421. /package/dist/cesium/{Assets → node_modules/.pnpm/cesium@1.141.0/node_modules/cesium/Build/Cesium/Assets}/Textures/maki/cemetery.png +0 -0
  422. /package/dist/cesium/{Assets → node_modules/.pnpm/cesium@1.141.0/node_modules/cesium/Build/Cesium/Assets}/Textures/maki/cesium.png +0 -0
  423. /package/dist/cesium/{Assets → node_modules/.pnpm/cesium@1.141.0/node_modules/cesium/Build/Cesium/Assets}/Textures/maki/chemist.png +0 -0
  424. /package/dist/cesium/{Assets → node_modules/.pnpm/cesium@1.141.0/node_modules/cesium/Build/Cesium/Assets}/Textures/maki/cinema.png +0 -0
  425. /package/dist/cesium/{Assets → node_modules/.pnpm/cesium@1.141.0/node_modules/cesium/Build/Cesium/Assets}/Textures/maki/circle-stroked.png +0 -0
  426. /package/dist/cesium/{Assets → node_modules/.pnpm/cesium@1.141.0/node_modules/cesium/Build/Cesium/Assets}/Textures/maki/circle.png +0 -0
  427. /package/dist/cesium/{Assets → node_modules/.pnpm/cesium@1.141.0/node_modules/cesium/Build/Cesium/Assets}/Textures/maki/city.png +0 -0
  428. /package/dist/cesium/{Assets → node_modules/.pnpm/cesium@1.141.0/node_modules/cesium/Build/Cesium/Assets}/Textures/maki/clothing-store.png +0 -0
  429. /package/dist/cesium/{Assets → node_modules/.pnpm/cesium@1.141.0/node_modules/cesium/Build/Cesium/Assets}/Textures/maki/college.png +0 -0
  430. /package/dist/cesium/{Assets → node_modules/.pnpm/cesium@1.141.0/node_modules/cesium/Build/Cesium/Assets}/Textures/maki/commercial.png +0 -0
  431. /package/dist/cesium/{Assets → node_modules/.pnpm/cesium@1.141.0/node_modules/cesium/Build/Cesium/Assets}/Textures/maki/cricket.png +0 -0
  432. /package/dist/cesium/{Assets → node_modules/.pnpm/cesium@1.141.0/node_modules/cesium/Build/Cesium/Assets}/Textures/maki/cross.png +0 -0
  433. /package/dist/cesium/{Assets → node_modules/.pnpm/cesium@1.141.0/node_modules/cesium/Build/Cesium/Assets}/Textures/maki/dam.png +0 -0
  434. /package/dist/cesium/{Assets → node_modules/.pnpm/cesium@1.141.0/node_modules/cesium/Build/Cesium/Assets}/Textures/maki/danger.png +0 -0
  435. /package/dist/cesium/{Assets → node_modules/.pnpm/cesium@1.141.0/node_modules/cesium/Build/Cesium/Assets}/Textures/maki/disability.png +0 -0
  436. /package/dist/cesium/{Assets → node_modules/.pnpm/cesium@1.141.0/node_modules/cesium/Build/Cesium/Assets}/Textures/maki/dog-park.png +0 -0
  437. /package/dist/cesium/{Assets → node_modules/.pnpm/cesium@1.141.0/node_modules/cesium/Build/Cesium/Assets}/Textures/maki/embassy.png +0 -0
  438. /package/dist/cesium/{Assets → node_modules/.pnpm/cesium@1.141.0/node_modules/cesium/Build/Cesium/Assets}/Textures/maki/emergency-telephone.png +0 -0
  439. /package/dist/cesium/{Assets → node_modules/.pnpm/cesium@1.141.0/node_modules/cesium/Build/Cesium/Assets}/Textures/maki/entrance.png +0 -0
  440. /package/dist/cesium/{Assets → node_modules/.pnpm/cesium@1.141.0/node_modules/cesium/Build/Cesium/Assets}/Textures/maki/farm.png +0 -0
  441. /package/dist/cesium/{Assets → node_modules/.pnpm/cesium@1.141.0/node_modules/cesium/Build/Cesium/Assets}/Textures/maki/fast-food.png +0 -0
  442. /package/dist/cesium/{Assets → node_modules/.pnpm/cesium@1.141.0/node_modules/cesium/Build/Cesium/Assets}/Textures/maki/ferry.png +0 -0
  443. /package/dist/cesium/{Assets → node_modules/.pnpm/cesium@1.141.0/node_modules/cesium/Build/Cesium/Assets}/Textures/maki/fire-station.png +0 -0
  444. /package/dist/cesium/{Assets → node_modules/.pnpm/cesium@1.141.0/node_modules/cesium/Build/Cesium/Assets}/Textures/maki/fuel.png +0 -0
  445. /package/dist/cesium/{Assets → node_modules/.pnpm/cesium@1.141.0/node_modules/cesium/Build/Cesium/Assets}/Textures/maki/garden.png +0 -0
  446. /package/dist/cesium/{Assets → node_modules/.pnpm/cesium@1.141.0/node_modules/cesium/Build/Cesium/Assets}/Textures/maki/gift.png +0 -0
  447. /package/dist/cesium/{Assets → node_modules/.pnpm/cesium@1.141.0/node_modules/cesium/Build/Cesium/Assets}/Textures/maki/golf.png +0 -0
  448. /package/dist/cesium/{Assets → node_modules/.pnpm/cesium@1.141.0/node_modules/cesium/Build/Cesium/Assets}/Textures/maki/grocery.png +0 -0
  449. /package/dist/cesium/{Assets → node_modules/.pnpm/cesium@1.141.0/node_modules/cesium/Build/Cesium/Assets}/Textures/maki/hairdresser.png +0 -0
  450. /package/dist/cesium/{Assets → node_modules/.pnpm/cesium@1.141.0/node_modules/cesium/Build/Cesium/Assets}/Textures/maki/harbor.png +0 -0
  451. /package/dist/cesium/{Assets → node_modules/.pnpm/cesium@1.141.0/node_modules/cesium/Build/Cesium/Assets}/Textures/maki/heart.png +0 -0
  452. /package/dist/cesium/{Assets → node_modules/.pnpm/cesium@1.141.0/node_modules/cesium/Build/Cesium/Assets}/Textures/maki/heliport.png +0 -0
  453. /package/dist/cesium/{Assets → node_modules/.pnpm/cesium@1.141.0/node_modules/cesium/Build/Cesium/Assets}/Textures/maki/hospital.png +0 -0
  454. /package/dist/cesium/{Assets → node_modules/.pnpm/cesium@1.141.0/node_modules/cesium/Build/Cesium/Assets}/Textures/maki/ice-cream.png +0 -0
  455. /package/dist/cesium/{Assets → node_modules/.pnpm/cesium@1.141.0/node_modules/cesium/Build/Cesium/Assets}/Textures/maki/industrial.png +0 -0
  456. /package/dist/cesium/{Assets → node_modules/.pnpm/cesium@1.141.0/node_modules/cesium/Build/Cesium/Assets}/Textures/maki/land-use.png +0 -0
  457. /package/dist/cesium/{Assets → node_modules/.pnpm/cesium@1.141.0/node_modules/cesium/Build/Cesium/Assets}/Textures/maki/laundry.png +0 -0
  458. /package/dist/cesium/{Assets → node_modules/.pnpm/cesium@1.141.0/node_modules/cesium/Build/Cesium/Assets}/Textures/maki/library.png +0 -0
  459. /package/dist/cesium/{Assets → node_modules/.pnpm/cesium@1.141.0/node_modules/cesium/Build/Cesium/Assets}/Textures/maki/lighthouse.png +0 -0
  460. /package/dist/cesium/{Assets → node_modules/.pnpm/cesium@1.141.0/node_modules/cesium/Build/Cesium/Assets}/Textures/maki/lodging.png +0 -0
  461. /package/dist/cesium/{Assets → node_modules/.pnpm/cesium@1.141.0/node_modules/cesium/Build/Cesium/Assets}/Textures/maki/logging.png +0 -0
  462. /package/dist/cesium/{Assets → node_modules/.pnpm/cesium@1.141.0/node_modules/cesium/Build/Cesium/Assets}/Textures/maki/london-underground.png +0 -0
  463. /package/dist/cesium/{Assets → node_modules/.pnpm/cesium@1.141.0/node_modules/cesium/Build/Cesium/Assets}/Textures/maki/marker-stroked.png +0 -0
  464. /package/dist/cesium/{Assets → node_modules/.pnpm/cesium@1.141.0/node_modules/cesium/Build/Cesium/Assets}/Textures/maki/marker.png +0 -0
  465. /package/dist/cesium/{Assets → node_modules/.pnpm/cesium@1.141.0/node_modules/cesium/Build/Cesium/Assets}/Textures/maki/minefield.png +0 -0
  466. /package/dist/cesium/{Assets → node_modules/.pnpm/cesium@1.141.0/node_modules/cesium/Build/Cesium/Assets}/Textures/maki/mobilephone.png +0 -0
  467. /package/dist/cesium/{Assets → node_modules/.pnpm/cesium@1.141.0/node_modules/cesium/Build/Cesium/Assets}/Textures/maki/monument.png +0 -0
  468. /package/dist/cesium/{Assets → node_modules/.pnpm/cesium@1.141.0/node_modules/cesium/Build/Cesium/Assets}/Textures/maki/museum.png +0 -0
  469. /package/dist/cesium/{Assets → node_modules/.pnpm/cesium@1.141.0/node_modules/cesium/Build/Cesium/Assets}/Textures/maki/music.png +0 -0
  470. /package/dist/cesium/{Assets → node_modules/.pnpm/cesium@1.141.0/node_modules/cesium/Build/Cesium/Assets}/Textures/maki/oil-well.png +0 -0
  471. /package/dist/cesium/{Assets → node_modules/.pnpm/cesium@1.141.0/node_modules/cesium/Build/Cesium/Assets}/Textures/maki/park.png +0 -0
  472. /package/dist/cesium/{Assets → node_modules/.pnpm/cesium@1.141.0/node_modules/cesium/Build/Cesium/Assets}/Textures/maki/park2.png +0 -0
  473. /package/dist/cesium/{Assets → node_modules/.pnpm/cesium@1.141.0/node_modules/cesium/Build/Cesium/Assets}/Textures/maki/parking-garage.png +0 -0
  474. /package/dist/cesium/{Assets → node_modules/.pnpm/cesium@1.141.0/node_modules/cesium/Build/Cesium/Assets}/Textures/maki/parking.png +0 -0
  475. /package/dist/cesium/{Assets → node_modules/.pnpm/cesium@1.141.0/node_modules/cesium/Build/Cesium/Assets}/Textures/maki/pharmacy.png +0 -0
  476. /package/dist/cesium/{Assets → node_modules/.pnpm/cesium@1.141.0/node_modules/cesium/Build/Cesium/Assets}/Textures/maki/pitch.png +0 -0
  477. /package/dist/cesium/{Assets → node_modules/.pnpm/cesium@1.141.0/node_modules/cesium/Build/Cesium/Assets}/Textures/maki/place-of-worship.png +0 -0
  478. /package/dist/cesium/{Assets → node_modules/.pnpm/cesium@1.141.0/node_modules/cesium/Build/Cesium/Assets}/Textures/maki/playground.png +0 -0
  479. /package/dist/cesium/{Assets → node_modules/.pnpm/cesium@1.141.0/node_modules/cesium/Build/Cesium/Assets}/Textures/maki/police.png +0 -0
  480. /package/dist/cesium/{Assets → node_modules/.pnpm/cesium@1.141.0/node_modules/cesium/Build/Cesium/Assets}/Textures/maki/polling-place.png +0 -0
  481. /package/dist/cesium/{Assets → node_modules/.pnpm/cesium@1.141.0/node_modules/cesium/Build/Cesium/Assets}/Textures/maki/post.png +0 -0
  482. /package/dist/cesium/{Assets → node_modules/.pnpm/cesium@1.141.0/node_modules/cesium/Build/Cesium/Assets}/Textures/maki/prison.png +0 -0
  483. /package/dist/cesium/{Assets → node_modules/.pnpm/cesium@1.141.0/node_modules/cesium/Build/Cesium/Assets}/Textures/maki/rail-above.png +0 -0
  484. /package/dist/cesium/{Assets → node_modules/.pnpm/cesium@1.141.0/node_modules/cesium/Build/Cesium/Assets}/Textures/maki/rail-light.png +0 -0
  485. /package/dist/cesium/{Assets → node_modules/.pnpm/cesium@1.141.0/node_modules/cesium/Build/Cesium/Assets}/Textures/maki/rail-metro.png +0 -0
  486. /package/dist/cesium/{Assets → node_modules/.pnpm/cesium@1.141.0/node_modules/cesium/Build/Cesium/Assets}/Textures/maki/rail-underground.png +0 -0
  487. /package/dist/cesium/{Assets → node_modules/.pnpm/cesium@1.141.0/node_modules/cesium/Build/Cesium/Assets}/Textures/maki/rail.png +0 -0
  488. /package/dist/cesium/{Assets → node_modules/.pnpm/cesium@1.141.0/node_modules/cesium/Build/Cesium/Assets}/Textures/maki/religious-christian.png +0 -0
  489. /package/dist/cesium/{Assets → node_modules/.pnpm/cesium@1.141.0/node_modules/cesium/Build/Cesium/Assets}/Textures/maki/religious-jewish.png +0 -0
  490. /package/dist/cesium/{Assets → node_modules/.pnpm/cesium@1.141.0/node_modules/cesium/Build/Cesium/Assets}/Textures/maki/religious-muslim.png +0 -0
  491. /package/dist/cesium/{Assets → node_modules/.pnpm/cesium@1.141.0/node_modules/cesium/Build/Cesium/Assets}/Textures/maki/restaurant.png +0 -0
  492. /package/dist/cesium/{Assets → node_modules/.pnpm/cesium@1.141.0/node_modules/cesium/Build/Cesium/Assets}/Textures/maki/roadblock.png +0 -0
  493. /package/dist/cesium/{Assets → node_modules/.pnpm/cesium@1.141.0/node_modules/cesium/Build/Cesium/Assets}/Textures/maki/rocket.png +0 -0
  494. /package/dist/cesium/{Assets → node_modules/.pnpm/cesium@1.141.0/node_modules/cesium/Build/Cesium/Assets}/Textures/maki/school.png +0 -0
  495. /package/dist/cesium/{Assets → node_modules/.pnpm/cesium@1.141.0/node_modules/cesium/Build/Cesium/Assets}/Textures/maki/scooter.png +0 -0
  496. /package/dist/cesium/{Assets → node_modules/.pnpm/cesium@1.141.0/node_modules/cesium/Build/Cesium/Assets}/Textures/maki/shop.png +0 -0
  497. /package/dist/cesium/{Assets → node_modules/.pnpm/cesium@1.141.0/node_modules/cesium/Build/Cesium/Assets}/Textures/maki/skiing.png +0 -0
  498. /package/dist/cesium/{Assets → node_modules/.pnpm/cesium@1.141.0/node_modules/cesium/Build/Cesium/Assets}/Textures/maki/slaughterhouse.png +0 -0
  499. /package/dist/cesium/{Assets → node_modules/.pnpm/cesium@1.141.0/node_modules/cesium/Build/Cesium/Assets}/Textures/maki/soccer.png +0 -0
  500. /package/dist/cesium/{Assets → node_modules/.pnpm/cesium@1.141.0/node_modules/cesium/Build/Cesium/Assets}/Textures/maki/square-stroked.png +0 -0
  501. /package/dist/cesium/{Assets → node_modules/.pnpm/cesium@1.141.0/node_modules/cesium/Build/Cesium/Assets}/Textures/maki/square.png +0 -0
  502. /package/dist/cesium/{Assets → node_modules/.pnpm/cesium@1.141.0/node_modules/cesium/Build/Cesium/Assets}/Textures/maki/star-stroked.png +0 -0
  503. /package/dist/cesium/{Assets → node_modules/.pnpm/cesium@1.141.0/node_modules/cesium/Build/Cesium/Assets}/Textures/maki/star.png +0 -0
  504. /package/dist/cesium/{Assets → node_modules/.pnpm/cesium@1.141.0/node_modules/cesium/Build/Cesium/Assets}/Textures/maki/suitcase.png +0 -0
  505. /package/dist/cesium/{Assets → node_modules/.pnpm/cesium@1.141.0/node_modules/cesium/Build/Cesium/Assets}/Textures/maki/swimming.png +0 -0
  506. /package/dist/cesium/{Assets → node_modules/.pnpm/cesium@1.141.0/node_modules/cesium/Build/Cesium/Assets}/Textures/maki/telephone.png +0 -0
  507. /package/dist/cesium/{Assets → node_modules/.pnpm/cesium@1.141.0/node_modules/cesium/Build/Cesium/Assets}/Textures/maki/tennis.png +0 -0
  508. /package/dist/cesium/{Assets → node_modules/.pnpm/cesium@1.141.0/node_modules/cesium/Build/Cesium/Assets}/Textures/maki/theatre.png +0 -0
  509. /package/dist/cesium/{Assets → node_modules/.pnpm/cesium@1.141.0/node_modules/cesium/Build/Cesium/Assets}/Textures/maki/toilets.png +0 -0
  510. /package/dist/cesium/{Assets → node_modules/.pnpm/cesium@1.141.0/node_modules/cesium/Build/Cesium/Assets}/Textures/maki/town-hall.png +0 -0
  511. /package/dist/cesium/{Assets → node_modules/.pnpm/cesium@1.141.0/node_modules/cesium/Build/Cesium/Assets}/Textures/maki/town.png +0 -0
  512. /package/dist/cesium/{Assets → node_modules/.pnpm/cesium@1.141.0/node_modules/cesium/Build/Cesium/Assets}/Textures/maki/triangle-stroked.png +0 -0
  513. /package/dist/cesium/{Assets → node_modules/.pnpm/cesium@1.141.0/node_modules/cesium/Build/Cesium/Assets}/Textures/maki/triangle.png +0 -0
  514. /package/dist/cesium/{Assets → node_modules/.pnpm/cesium@1.141.0/node_modules/cesium/Build/Cesium/Assets}/Textures/maki/village.png +0 -0
  515. /package/dist/cesium/{Assets → node_modules/.pnpm/cesium@1.141.0/node_modules/cesium/Build/Cesium/Assets}/Textures/maki/warehouse.png +0 -0
  516. /package/dist/cesium/{Assets → node_modules/.pnpm/cesium@1.141.0/node_modules/cesium/Build/Cesium/Assets}/Textures/maki/waste-basket.png +0 -0
  517. /package/dist/cesium/{Assets → node_modules/.pnpm/cesium@1.141.0/node_modules/cesium/Build/Cesium/Assets}/Textures/maki/water.png +0 -0
  518. /package/dist/cesium/{Assets → node_modules/.pnpm/cesium@1.141.0/node_modules/cesium/Build/Cesium/Assets}/Textures/maki/wetland.png +0 -0
  519. /package/dist/cesium/{Assets → node_modules/.pnpm/cesium@1.141.0/node_modules/cesium/Build/Cesium/Assets}/Textures/maki/zoo.png +0 -0
  520. /package/dist/cesium/{Assets → node_modules/.pnpm/cesium@1.141.0/node_modules/cesium/Build/Cesium/Assets}/Textures/moonSmall.jpg +0 -0
  521. /package/dist/cesium/{Assets → node_modules/.pnpm/cesium@1.141.0/node_modules/cesium/Build/Cesium/Assets}/Textures/pin.svg +0 -0
  522. /package/dist/cesium/{Assets → node_modules/.pnpm/cesium@1.141.0/node_modules/cesium/Build/Cesium/Assets}/Textures/waterNormals.jpg +0 -0
  523. /package/dist/cesium/{Assets → node_modules/.pnpm/cesium@1.141.0/node_modules/cesium/Build/Cesium/Assets}/Textures/waterNormalsSmall.jpg +0 -0
  524. /package/dist/cesium/{Assets → node_modules/.pnpm/cesium@1.141.0/node_modules/cesium/Build/Cesium/Assets}/approximateTerrainHeights.json +0 -0
  525. /package/dist/cesium/{ThirdParty → node_modules/.pnpm/cesium@1.141.0/node_modules/cesium/Build/Cesium/ThirdParty}/Workers/package.json +0 -0
  526. /package/dist/cesium/{ThirdParty → node_modules/.pnpm/cesium@1.141.0/node_modules/cesium/Build/Cesium/ThirdParty}/Workers/zip-web-worker.js +0 -0
  527. /package/dist/cesium/{ThirdParty → node_modules/.pnpm/cesium@1.141.0/node_modules/cesium/Build/Cesium/ThirdParty}/basis_transcoder.wasm +0 -0
  528. /package/dist/cesium/{ThirdParty → node_modules/.pnpm/cesium@1.141.0/node_modules/cesium/Build/Cesium/ThirdParty}/draco_decoder.wasm +0 -0
  529. /package/dist/cesium/{ThirdParty → node_modules/.pnpm/cesium@1.141.0/node_modules/cesium/Build/Cesium/ThirdParty}/google-earth-dbroot-parser.js +0 -0
  530. /package/dist/cesium/{ThirdParty → node_modules/.pnpm/cesium@1.141.0/node_modules/cesium/Build/Cesium/ThirdParty}/wasm_splats_bg.wasm +0 -0
  531. /package/dist/cesium/{ThirdParty → node_modules/.pnpm/cesium@1.141.0/node_modules/cesium/Build/Cesium/ThirdParty}/zip-module.wasm +0 -0
  532. /package/dist/cesium/{Widgets → node_modules/.pnpm/cesium@1.141.0/node_modules/cesium/Build/Cesium/Widgets}/Animation/Animation.css +0 -0
  533. /package/dist/cesium/{Widgets → node_modules/.pnpm/cesium@1.141.0/node_modules/cesium/Build/Cesium/Widgets}/Animation/lighter.css +0 -0
  534. /package/dist/cesium/{Widgets → node_modules/.pnpm/cesium@1.141.0/node_modules/cesium/Build/Cesium/Widgets}/BaseLayerPicker/BaseLayerPicker.css +0 -0
  535. /package/dist/cesium/{Widgets → node_modules/.pnpm/cesium@1.141.0/node_modules/cesium/Build/Cesium/Widgets}/BaseLayerPicker/lighter.css +0 -0
  536. /package/dist/cesium/{Widgets → node_modules/.pnpm/cesium@1.141.0/node_modules/cesium/Build/Cesium/Widgets}/Cesium3DTilesInspector/Cesium3DTilesInspector.css +0 -0
  537. /package/dist/cesium/{Widgets → node_modules/.pnpm/cesium@1.141.0/node_modules/cesium/Build/Cesium/Widgets}/CesiumInspector/CesiumInspector.css +0 -0
  538. /package/dist/cesium/{Widgets → node_modules/.pnpm/cesium@1.141.0/node_modules/cesium/Build/Cesium/Widgets}/CesiumWidget/CesiumWidget.css +0 -0
  539. /package/dist/cesium/{Widgets → node_modules/.pnpm/cesium@1.141.0/node_modules/cesium/Build/Cesium/Widgets}/CesiumWidget/lighter.css +0 -0
  540. /package/dist/cesium/{Widgets → node_modules/.pnpm/cesium@1.141.0/node_modules/cesium/Build/Cesium/Widgets}/FullscreenButton/FullscreenButton.css +0 -0
  541. /package/dist/cesium/{Widgets → node_modules/.pnpm/cesium@1.141.0/node_modules/cesium/Build/Cesium/Widgets}/Geocoder/Geocoder.css +0 -0
  542. /package/dist/cesium/{Widgets → node_modules/.pnpm/cesium@1.141.0/node_modules/cesium/Build/Cesium/Widgets}/Geocoder/lighter.css +0 -0
  543. /package/dist/cesium/{Widgets → node_modules/.pnpm/cesium@1.141.0/node_modules/cesium/Build/Cesium/Widgets}/I3SBuildingSceneLayerExplorer/I3SBuildingSceneLayerExplorer.css +0 -0
  544. /package/dist/cesium/{Widgets → node_modules/.pnpm/cesium@1.141.0/node_modules/cesium/Build/Cesium/Widgets}/Images/ImageryProviders/ArcGisMapServiceWorldHillshade.png +0 -0
  545. /package/dist/cesium/{Widgets → node_modules/.pnpm/cesium@1.141.0/node_modules/cesium/Build/Cesium/Widgets}/Images/ImageryProviders/ArcGisMapServiceWorldImagery.png +0 -0
  546. /package/dist/cesium/{Widgets → node_modules/.pnpm/cesium@1.141.0/node_modules/cesium/Build/Cesium/Widgets}/Images/ImageryProviders/ArcGisMapServiceWorldOcean.png +0 -0
  547. /package/dist/cesium/{Widgets → node_modules/.pnpm/cesium@1.141.0/node_modules/cesium/Build/Cesium/Widgets}/Images/ImageryProviders/azureAerial.png +0 -0
  548. /package/dist/cesium/{Widgets → node_modules/.pnpm/cesium@1.141.0/node_modules/cesium/Build/Cesium/Widgets}/Images/ImageryProviders/azureRoads.png +0 -0
  549. /package/dist/cesium/{Widgets → node_modules/.pnpm/cesium@1.141.0/node_modules/cesium/Build/Cesium/Widgets}/Images/ImageryProviders/bingAerial.png +0 -0
  550. /package/dist/cesium/{Widgets → node_modules/.pnpm/cesium@1.141.0/node_modules/cesium/Build/Cesium/Widgets}/Images/ImageryProviders/bingAerialLabels.png +0 -0
  551. /package/dist/cesium/{Widgets → node_modules/.pnpm/cesium@1.141.0/node_modules/cesium/Build/Cesium/Widgets}/Images/ImageryProviders/bingRoads.png +0 -0
  552. /package/dist/cesium/{Widgets → node_modules/.pnpm/cesium@1.141.0/node_modules/cesium/Build/Cesium/Widgets}/Images/ImageryProviders/blueMarble.png +0 -0
  553. /package/dist/cesium/{Widgets → node_modules/.pnpm/cesium@1.141.0/node_modules/cesium/Build/Cesium/Widgets}/Images/ImageryProviders/earthAtNight.png +0 -0
  554. /package/dist/cesium/{Widgets → node_modules/.pnpm/cesium@1.141.0/node_modules/cesium/Build/Cesium/Widgets}/Images/ImageryProviders/googleContour.png +0 -0
  555. /package/dist/cesium/{Widgets → node_modules/.pnpm/cesium@1.141.0/node_modules/cesium/Build/Cesium/Widgets}/Images/ImageryProviders/googleRoadmap.png +0 -0
  556. /package/dist/cesium/{Widgets → node_modules/.pnpm/cesium@1.141.0/node_modules/cesium/Build/Cesium/Widgets}/Images/ImageryProviders/googleSatellite.png +0 -0
  557. /package/dist/cesium/{Widgets → node_modules/.pnpm/cesium@1.141.0/node_modules/cesium/Build/Cesium/Widgets}/Images/ImageryProviders/googleSatelliteLabels.png +0 -0
  558. /package/dist/cesium/{Widgets → node_modules/.pnpm/cesium@1.141.0/node_modules/cesium/Build/Cesium/Widgets}/Images/ImageryProviders/mapQuestOpenStreetMap.png +0 -0
  559. /package/dist/cesium/{Widgets → node_modules/.pnpm/cesium@1.141.0/node_modules/cesium/Build/Cesium/Widgets}/Images/ImageryProviders/mapboxSatellite.png +0 -0
  560. /package/dist/cesium/{Widgets → node_modules/.pnpm/cesium@1.141.0/node_modules/cesium/Build/Cesium/Widgets}/Images/ImageryProviders/mapboxStreets.png +0 -0
  561. /package/dist/cesium/{Widgets → node_modules/.pnpm/cesium@1.141.0/node_modules/cesium/Build/Cesium/Widgets}/Images/ImageryProviders/mapboxTerrain.png +0 -0
  562. /package/dist/cesium/{Widgets → node_modules/.pnpm/cesium@1.141.0/node_modules/cesium/Build/Cesium/Widgets}/Images/ImageryProviders/naturalEarthII.png +0 -0
  563. /package/dist/cesium/{Widgets → node_modules/.pnpm/cesium@1.141.0/node_modules/cesium/Build/Cesium/Widgets}/Images/ImageryProviders/openStreetMap.png +0 -0
  564. /package/dist/cesium/{Widgets → node_modules/.pnpm/cesium@1.141.0/node_modules/cesium/Build/Cesium/Widgets}/Images/ImageryProviders/sentinel-2.png +0 -0
  565. /package/dist/cesium/{Widgets → node_modules/.pnpm/cesium@1.141.0/node_modules/cesium/Build/Cesium/Widgets}/Images/ImageryProviders/stadiaAlidadeSmooth.png +0 -0
  566. /package/dist/cesium/{Widgets → node_modules/.pnpm/cesium@1.141.0/node_modules/cesium/Build/Cesium/Widgets}/Images/ImageryProviders/stadiaAlidadeSmoothDark.png +0 -0
  567. /package/dist/cesium/{Widgets → node_modules/.pnpm/cesium@1.141.0/node_modules/cesium/Build/Cesium/Widgets}/Images/ImageryProviders/stamenToner.png +0 -0
  568. /package/dist/cesium/{Widgets → node_modules/.pnpm/cesium@1.141.0/node_modules/cesium/Build/Cesium/Widgets}/Images/ImageryProviders/stamenWatercolor.png +0 -0
  569. /package/dist/cesium/{Widgets → node_modules/.pnpm/cesium@1.141.0/node_modules/cesium/Build/Cesium/Widgets}/Images/NavigationHelp/Mouse.svg +0 -0
  570. /package/dist/cesium/{Widgets → node_modules/.pnpm/cesium@1.141.0/node_modules/cesium/Build/Cesium/Widgets}/Images/NavigationHelp/MouseLeft.svg +0 -0
  571. /package/dist/cesium/{Widgets → node_modules/.pnpm/cesium@1.141.0/node_modules/cesium/Build/Cesium/Widgets}/Images/NavigationHelp/MouseMiddle.svg +0 -0
  572. /package/dist/cesium/{Widgets → node_modules/.pnpm/cesium@1.141.0/node_modules/cesium/Build/Cesium/Widgets}/Images/NavigationHelp/MouseRight.svg +0 -0
  573. /package/dist/cesium/{Widgets → node_modules/.pnpm/cesium@1.141.0/node_modules/cesium/Build/Cesium/Widgets}/Images/NavigationHelp/Touch.svg +0 -0
  574. /package/dist/cesium/{Widgets → node_modules/.pnpm/cesium@1.141.0/node_modules/cesium/Build/Cesium/Widgets}/Images/NavigationHelp/TouchDrag.svg +0 -0
  575. /package/dist/cesium/{Widgets → node_modules/.pnpm/cesium@1.141.0/node_modules/cesium/Build/Cesium/Widgets}/Images/NavigationHelp/TouchRotate.svg +0 -0
  576. /package/dist/cesium/{Widgets → node_modules/.pnpm/cesium@1.141.0/node_modules/cesium/Build/Cesium/Widgets}/Images/NavigationHelp/TouchTilt.svg +0 -0
  577. /package/dist/cesium/{Widgets → node_modules/.pnpm/cesium@1.141.0/node_modules/cesium/Build/Cesium/Widgets}/Images/NavigationHelp/TouchZoom.svg +0 -0
  578. /package/dist/cesium/{Widgets → node_modules/.pnpm/cesium@1.141.0/node_modules/cesium/Build/Cesium/Widgets}/Images/TerrainProviders/CesiumWorldTerrain.png +0 -0
  579. /package/dist/cesium/{Widgets → node_modules/.pnpm/cesium@1.141.0/node_modules/cesium/Build/Cesium/Widgets}/Images/TerrainProviders/Ellipsoid.png +0 -0
  580. /package/dist/cesium/{Widgets → node_modules/.pnpm/cesium@1.141.0/node_modules/cesium/Build/Cesium/Widgets}/Images/TimelineIcons.png +0 -0
  581. /package/dist/cesium/{Widgets → node_modules/.pnpm/cesium@1.141.0/node_modules/cesium/Build/Cesium/Widgets}/Images/info-loading.gif +0 -0
  582. /package/dist/cesium/{Widgets → node_modules/.pnpm/cesium@1.141.0/node_modules/cesium/Build/Cesium/Widgets}/InfoBox/InfoBox.css +0 -0
  583. /package/dist/cesium/{Widgets → node_modules/.pnpm/cesium@1.141.0/node_modules/cesium/Build/Cesium/Widgets}/InfoBox/InfoBoxDescription.css +0 -0
  584. /package/dist/cesium/{Widgets → node_modules/.pnpm/cesium@1.141.0/node_modules/cesium/Build/Cesium/Widgets}/NavigationHelpButton/NavigationHelpButton.css +0 -0
  585. /package/dist/cesium/{Widgets → node_modules/.pnpm/cesium@1.141.0/node_modules/cesium/Build/Cesium/Widgets}/NavigationHelpButton/lighter.css +0 -0
  586. /package/dist/cesium/{Widgets → node_modules/.pnpm/cesium@1.141.0/node_modules/cesium/Build/Cesium/Widgets}/PerformanceWatchdog/PerformanceWatchdog.css +0 -0
  587. /package/dist/cesium/{Widgets → node_modules/.pnpm/cesium@1.141.0/node_modules/cesium/Build/Cesium/Widgets}/ProjectionPicker/ProjectionPicker.css +0 -0
  588. /package/dist/cesium/{Widgets → node_modules/.pnpm/cesium@1.141.0/node_modules/cesium/Build/Cesium/Widgets}/SceneModePicker/SceneModePicker.css +0 -0
  589. /package/dist/cesium/{Widgets → node_modules/.pnpm/cesium@1.141.0/node_modules/cesium/Build/Cesium/Widgets}/SelectionIndicator/SelectionIndicator.css +0 -0
  590. /package/dist/cesium/{Widgets → node_modules/.pnpm/cesium@1.141.0/node_modules/cesium/Build/Cesium/Widgets}/Timeline/Timeline.css +0 -0
  591. /package/dist/cesium/{Widgets → node_modules/.pnpm/cesium@1.141.0/node_modules/cesium/Build/Cesium/Widgets}/Timeline/lighter.css +0 -0
  592. /package/dist/cesium/{Widgets → node_modules/.pnpm/cesium@1.141.0/node_modules/cesium/Build/Cesium/Widgets}/VRButton/VRButton.css +0 -0
  593. /package/dist/cesium/{Widgets → node_modules/.pnpm/cesium@1.141.0/node_modules/cesium/Build/Cesium/Widgets}/Viewer/Viewer.css +0 -0
  594. /package/dist/cesium/{Widgets → node_modules/.pnpm/cesium@1.141.0/node_modules/cesium/Build/Cesium/Widgets}/VoxelInspector/VoxelInspector.css +0 -0
  595. /package/dist/cesium/{Widgets → node_modules/.pnpm/cesium@1.141.0/node_modules/cesium/Build/Cesium/Widgets}/lighter.css +0 -0
  596. /package/dist/cesium/{Widgets → node_modules/.pnpm/cesium@1.141.0/node_modules/cesium/Build/Cesium/Widgets}/lighterShared.css +0 -0
  597. /package/dist/cesium/{Widgets → node_modules/.pnpm/cesium@1.141.0/node_modules/cesium/Build/Cesium/Widgets}/shared.css +0 -0
  598. /package/dist/cesium/{Widgets → node_modules/.pnpm/cesium@1.141.0/node_modules/cesium/Build/Cesium/Widgets}/widgets.css +0 -0
@@ -48,6 +48,7 @@ export function useKeyboardShortcuts(options: KeyboardShortcutsOptions = {}) {
48
48
  const hideEntities = useViewerStore((s) => s.hideEntities);
49
49
  const toggleTheme = useViewerStore((s) => s.toggleTheme);
50
50
  const toggleBasketPresentationVisible = useViewerStore((s) => s.toggleBasketPresentationVisible);
51
+ const toggleEditEnabled = useViewerStore((s) => s.toggleEditEnabled);
51
52
 
52
53
  // Measure tool specific actions
53
54
  const activeMeasurement = useViewerStore((s) => s.activeMeasurement);
@@ -71,6 +72,19 @@ export function useKeyboardShortcuts(options: KeyboardShortcutsOptions = {}) {
71
72
  const shift = e.shiftKey;
72
73
  const key = e.key.toLowerCase();
73
74
 
75
+ // Undo / Redo — Ctrl/Cmd+Z and Ctrl/Cmd+Shift+Z, scoped to the
76
+ // active model's mutation stack. Always available regardless
77
+ // of edit mode so the user can recover from any change.
78
+ if (key === 'z' && ctrl) {
79
+ e.preventDefault();
80
+ const state = useViewerStore.getState();
81
+ const activeModelId = state.activeModelId;
82
+ if (!activeModelId) return;
83
+ if (shift) state.redo(activeModelId);
84
+ else state.undo(activeModelId);
85
+ return;
86
+ }
87
+
74
88
  // Navigation tools
75
89
  if (key === 'v' && !ctrl && !shift) {
76
90
  e.preventDefault();
@@ -93,6 +107,60 @@ export function useKeyboardShortcuts(options: KeyboardShortcutsOptions = {}) {
93
107
  setActiveTool('annotate');
94
108
  }
95
109
 
110
+ // Global edit-mode pill — unlocks inline property/attribute
111
+ // editors, add-element draw tools, georeference placement, and
112
+ // future geometry manipulators. Toggle from anywhere outside an
113
+ // input field.
114
+ if (key === 'e' && !ctrl && !shift) {
115
+ e.preventDefault();
116
+ toggleEditEnabled();
117
+ }
118
+
119
+ // K = knife / Split. Operates only on the currently selected
120
+ // entity — there's no free-roam "hover anything and split" mode
121
+ // any more. If there's no selection, the keypress is a no-op
122
+ // (a toast would be noisy; the user can see no entity is
123
+ // selected). The action also pre-arms the splitTarget so the
124
+ // overlay knows what to draw the moment Split engages.
125
+ if (key === 'k' && !ctrl && !shift) {
126
+ e.preventDefault();
127
+ const state = useViewerStore.getState();
128
+ if (state.activeTool === 'split') {
129
+ state.clearSplitHover();
130
+ state.setActiveTool('select');
131
+ return;
132
+ }
133
+ const sel = state.selectedEntity;
134
+ if (!sel) return;
135
+ state.setSplitTarget(sel.modelId, sel.expressId);
136
+ state.setActiveTool('split');
137
+ }
138
+
139
+ // R / Shift+R = rotate selected entity ±15° about the storey-up
140
+ // Z axis. Only fires while edit mode is on and a single entity
141
+ // is selected. The rotateEntity action handles the placement
142
+ // chain walk + undo registration.
143
+ if (key === 'r' && !ctrl) {
144
+ const state = useViewerStore.getState();
145
+ if (state.editEnabled && state.selectedEntity) {
146
+ e.preventDefault();
147
+ const deltaDeg = shift ? -15 : 15;
148
+ const result = state.rotateEntity(
149
+ state.selectedEntity.modelId,
150
+ state.selectedEntity.expressId,
151
+ (deltaDeg * Math.PI) / 180,
152
+ );
153
+ if (!result.ok) {
154
+ // Surface the reason via the existing toast helper rather
155
+ // than a console warning — the user just pressed a key and
156
+ // deserves immediate feedback.
157
+ void import('@/components/ui/toast').then((m) => {
158
+ m.toast.error(`Couldn't rotate: ${result.reason}`);
159
+ });
160
+ }
161
+ }
162
+ }
163
+
96
164
  // Basket controls (automatic context source)
97
165
  // I = Isolate from current context
98
166
  if (key === 'i' && !ctrl && !shift) {
@@ -154,6 +222,18 @@ export function useKeyboardShortcuts(options: KeyboardShortcutsOptions = {}) {
154
222
  resetVisibilityForHomeFromStore();
155
223
  }
156
224
 
225
+ // Split tool — Esc exits Split and returns to Select. We catch
226
+ // it here before the global Esc handler so the user gets a
227
+ // gentle exit (clear hover, swap tool) rather than the global
228
+ // "clear all selection + visibility" cascade.
229
+ if (activeTool === 'split' && key === 'escape') {
230
+ e.preventDefault();
231
+ const state = useViewerStore.getState();
232
+ state.clearSplitHover();
233
+ state.setActiveTool('select');
234
+ return;
235
+ }
236
+
157
237
  // Add-element tool shortcuts — Enter commits an in-progress slab
158
238
  // polygon; Esc clears any pending points before falling through to
159
239
  // the global Esc handler (which exits the tool).
@@ -250,6 +330,7 @@ export function useKeyboardShortcuts(options: KeyboardShortcutsOptions = {}) {
250
330
  cancelMeasurement,
251
331
  clearMeasurements,
252
332
  toggleSnap,
333
+ toggleEditEnabled,
253
334
  ]);
254
335
 
255
336
  useEffect(() => {
@@ -264,11 +345,16 @@ export function useKeyboardShortcuts(options: KeyboardShortcutsOptions = {}) {
264
345
 
265
346
  // Export shortcut definitions for UI display
266
347
  export const KEYBOARD_SHORTCUTS = [
348
+ { key: 'Ctrl+Z / Cmd+Z', description: 'Undo last authoring change for the active model', category: 'Editing' },
349
+ { key: 'Ctrl+Shift+Z / Cmd+Shift+Z', description: 'Redo last undone change', category: 'Editing' },
267
350
  { key: 'V', description: 'Select tool', category: 'Tools' },
268
351
  { key: 'C', description: 'Walk mode', category: 'Tools' },
269
352
  { key: 'M', description: 'Measure tool', category: 'Tools' },
270
353
  { key: 'P', description: 'Annotate tool — drop a pin with a note', category: 'Tools' },
271
354
  { key: 'X', description: 'Section tool', category: 'Tools' },
355
+ { key: 'E', description: 'Toggle edit mode (unlocks property + geometry edits)', category: 'Tools' },
356
+ { key: 'K', description: 'Split the selected entity (requires a selection)', category: 'Tools' },
357
+ { key: 'R / Shift+R', description: 'Rotate selected entity ±15° about Z (requires edit mode)', category: 'Tools' },
272
358
  { key: 'S', description: 'Toggle snapping (Measure tool)', category: 'Tools' },
273
359
  { key: 'Esc', description: 'Cancel measurement (Measure tool)', category: 'Tools' },
274
360
  { key: 'Ctrl+C', description: 'Clear measurements (Measure tool)', category: 'Tools' },
@@ -0,0 +1,160 @@
1
+ /* This Source Code Form is subject to the terms of the Mozilla Public
2
+ * License, v. 2.0. If a copy of the MPL was not distributed with this
3
+ * file, You can obtain one at https://mozilla.org/MPL/2.0/. */
4
+
5
+ /**
6
+ * Drive Exploded / Solo level display modes from the slice state.
7
+ *
8
+ * Stacked:
9
+ * - Subtract any previously-applied Exploded offsets so the
10
+ * renderer's mesh positions revert to their loaded values.
11
+ * - Clear isolation if we're coming out of Solo.
12
+ *
13
+ * Exploded:
14
+ * - Compute per-storey offsets via `computeStoreyOffsets` for
15
+ * each loaded model.
16
+ * - Diff against the per-model `appliedStoreyOffsets` and push
17
+ * the deltas into `pendingMeshTranslations` so the renderer
18
+ * applies them on the next frame.
19
+ * - Stash the new applied offsets on the slice so the next
20
+ * toggle / gap change knows what to subtract.
21
+ *
22
+ * Solo:
23
+ * - Use the existing `setIsolatedEntities` channel to gate
24
+ * visibility to the chosen storey's entities (resolved to
25
+ * federation global ids).
26
+ *
27
+ * The hook reads from a slim selector (`useViewerStore`) and only
28
+ * runs its work when `levelDisplayMode`, `explodedGap`, or the
29
+ * set of loaded models changes. No per-frame work.
30
+ */
31
+
32
+ import { useEffect, useRef } from 'react';
33
+ import { useViewerStore } from '@/store';
34
+ import { toGlobalIdFromModels } from '@/store/globalId';
35
+ import {
36
+ computeStoreyOffsets,
37
+ diffStoreyOffsets,
38
+ buildEntityTranslations,
39
+ entitiesInStorey,
40
+ type StoreyOffsets,
41
+ } from '@/lib/level-offsets';
42
+
43
+ export function useLevelDisplayEffect(): void {
44
+ const levelDisplayMode = useViewerStore((s) => s.levelDisplayMode);
45
+ const explodedGap = useViewerStore((s) => s.explodedGap);
46
+ const soloStorey = useViewerStore((s) => s.soloStorey);
47
+ const models = useViewerStore((s) => s.models);
48
+ const activeModelId = useViewerStore((s) => s.activeModelId);
49
+ const appliedStoreyOffsets = useViewerStore((s) => s.appliedStoreyOffsets);
50
+ const setAppliedStoreyOffsets = useViewerStore((s) => s.setAppliedStoreyOffsets);
51
+ const setPendingMeshTranslations = useViewerStore((s) => s.setPendingMeshTranslations);
52
+ const setIsolatedEntities = useViewerStore((s) => s.setIsolatedEntities);
53
+
54
+ // Track the last-applied mode so the cleanup logic can tell
55
+ // "user is exiting Exploded" from "user is changing gap inside
56
+ // Exploded". Without this, the diff math handles both, but
57
+ // having a discrete flag makes it cheap to skip Solo→Solo
58
+ // re-entry without touching translations.
59
+ const lastModeRef = useRef(levelDisplayMode);
60
+
61
+ useEffect(() => {
62
+ // Compute the target Exploded offsets per model. `target` is
63
+ // empty when Exploded isn't active — diff against the
64
+ // previously-applied offsets will revert any lifts.
65
+ const target: typeof appliedStoreyOffsets = new Map();
66
+ if (levelDisplayMode === 'exploded') {
67
+ for (const [modelId, model] of models) {
68
+ if (!model.ifcDataStore) continue;
69
+ const offsets = computeStoreyOffsets(model.ifcDataStore, explodedGap);
70
+ if (offsets.size > 0) target.set(modelId, offsets);
71
+ }
72
+ }
73
+
74
+ // Build the renderer-frame translation map by diffing the
75
+ // target against the slice's applied snapshot, per model. Sum
76
+ // into a single Map<globalId, [dx,dy,dz]> so one push covers
77
+ // the whole scene.
78
+ const aggregated = new Map<number, [number, number, number]>();
79
+ const modelIds = new Set<string>([
80
+ ...models.keys(),
81
+ ...appliedStoreyOffsets.keys(),
82
+ ]);
83
+ for (const modelId of modelIds) {
84
+ const targetMap: StoreyOffsets = target.get(modelId) ?? new Map();
85
+ const previousMap: StoreyOffsets = appliedStoreyOffsets.get(modelId) ?? new Map();
86
+ const diff = diffStoreyOffsets(targetMap, previousMap);
87
+ if (diff.size === 0) continue;
88
+ const dataStore = models.get(modelId)?.ifcDataStore;
89
+ if (!dataStore) continue;
90
+ const toGlobalId = (localExpressId: number): number =>
91
+ toGlobalIdFromModels(models, modelId, localExpressId);
92
+ const perEntity = buildEntityTranslations(dataStore, diff, toGlobalId);
93
+ for (const [id, delta] of perEntity) {
94
+ const existing = aggregated.get(id);
95
+ if (existing) {
96
+ aggregated.set(id, [existing[0] + delta[0], existing[1] + delta[1], existing[2] + delta[2]]);
97
+ } else {
98
+ aggregated.set(id, [delta[0], delta[1], delta[2]]);
99
+ }
100
+ }
101
+ }
102
+ if (aggregated.size > 0) {
103
+ setPendingMeshTranslations(aggregated);
104
+ }
105
+ setAppliedStoreyOffsets(target);
106
+
107
+ // Solo isolation. Resolve against the (modelId, expressId)
108
+ // pair the slice stores so federated scenes with overlapping
109
+ // storey express-ids isolate the right one. Slice default is
110
+ // null → pick the lowest-elevation storey of the active model.
111
+ if (levelDisplayMode === 'solo') {
112
+ let targetModelId: string | null = soloStorey?.modelId ?? null;
113
+ let storeyId: number | null = soloStorey?.expressId ?? null;
114
+ if (targetModelId === null || storeyId === null) {
115
+ // Cold-start default — fall back to the active model's
116
+ // lowest storey ONLY when the slice has no explicit pick.
117
+ const fallbackModelId = activeModelId ?? models.keys().next().value ?? null;
118
+ const fallbackStore = fallbackModelId ? models.get(fallbackModelId)?.ifcDataStore : undefined;
119
+ if (fallbackModelId && fallbackStore) {
120
+ const elevations = fallbackStore.spatialHierarchy?.storeyElevations;
121
+ if (elevations && elevations.size > 0) {
122
+ const lowest = [...elevations.entries()].sort((a, b) => a[1] - b[1])[0][0];
123
+ targetModelId = fallbackModelId;
124
+ storeyId = lowest;
125
+ }
126
+ }
127
+ }
128
+ const targetStore = targetModelId ? models.get(targetModelId)?.ifcDataStore : undefined;
129
+ if (targetModelId !== null && storeyId !== null && targetStore) {
130
+ const resolvedModelId = targetModelId;
131
+ const toGlobalId = (localExpressId: number): number =>
132
+ toGlobalIdFromModels(models, resolvedModelId, localExpressId);
133
+ const ids = entitiesInStorey(targetStore, storeyId, toGlobalId);
134
+ setIsolatedEntities(new Set(ids));
135
+ } else {
136
+ setIsolatedEntities(null);
137
+ }
138
+ } else if (lastModeRef.current === 'solo') {
139
+ // Leaving Solo → drop isolation. (User may have manually
140
+ // re-isolated via the basket; we still clear because the
141
+ // Solo cleanup should be predictable. Tradeoff documented.)
142
+ setIsolatedEntities(null);
143
+ }
144
+
145
+ lastModeRef.current = levelDisplayMode;
146
+ // appliedStoreyOffsets is intentionally NOT a dep — we write
147
+ // to it as a side effect; depending on it would loop. The
148
+ // ref-based last-mode check covers the Solo→other case.
149
+ // eslint-disable-next-line react-hooks/exhaustive-deps
150
+ }, [
151
+ levelDisplayMode,
152
+ explodedGap,
153
+ soloStorey,
154
+ models,
155
+ activeModelId,
156
+ setPendingMeshTranslations,
157
+ setIsolatedEntities,
158
+ setAppliedStoreyOffsets,
159
+ ]);
160
+ }
@@ -212,14 +212,22 @@ export function useContextMenuState() {
212
212
  export function useColorUpdateState() {
213
213
  const pendingColorUpdates = useViewerStore((state) => state.pendingColorUpdates);
214
214
  const pendingMeshColorUpdates = useViewerStore((state) => state.pendingMeshColorUpdates);
215
+ const pendingMeshRemovals = useViewerStore((state) => state.pendingMeshRemovals);
216
+ const pendingMeshTranslations = useViewerStore((state) => state.pendingMeshTranslations);
215
217
  const clearPendingColorUpdates = useViewerStore((state) => state.clearPendingColorUpdates);
216
218
  const clearPendingMeshColorUpdates = useViewerStore((state) => state.clearPendingMeshColorUpdates);
219
+ const clearPendingMeshRemovals = useViewerStore((state) => state.clearPendingMeshRemovals);
220
+ const clearPendingMeshTranslations = useViewerStore((state) => state.clearPendingMeshTranslations);
217
221
 
218
222
  return {
219
223
  pendingColorUpdates,
220
224
  pendingMeshColorUpdates,
225
+ pendingMeshRemovals,
226
+ pendingMeshTranslations,
221
227
  clearPendingColorUpdates,
222
228
  clearPendingMeshColorUpdates,
229
+ clearPendingMeshRemovals,
230
+ clearPendingMeshTranslations,
223
231
  };
224
232
  }
225
233
 
@@ -0,0 +1,110 @@
1
+ /* This Source Code Form is subject to the terms of the Mozilla Public
2
+ * License, v. 2.0. If a copy of the MPL was not distributed with this
3
+ * file, You can obtain one at https://mozilla.org/MPL/2.0/. */
4
+
5
+ /**
6
+ * Test stubs shared across the lib/ helper test suites. Each
7
+ * helper that walks the IFC attribute graph
8
+ * (placement-core / wall-edit / slab-edit / linear-element-edit /
9
+ * metadata-clone / wall-opening-reassign) wants the same minimal
10
+ * mocks: an in-memory `StoreEditor` that returns overlay entities
11
+ * + records positional writes, a `MutablePropertyView` whose
12
+ * `getPositionalMutationsForEntity` is a no-op, and an
13
+ * `IfcDataStore` shim with a `entityIndex.byType` map for the
14
+ * helpers that scan by type. Centralising them here removes the
15
+ * five-way duplication and keeps the harness consistent when one
16
+ * helper's contract evolves.
17
+ *
18
+ * Production code never imports from this module — the lib/
19
+ * helpers take their dependencies via constructor / parameter so
20
+ * the real `@ifc-lite/mutations` + `@ifc-lite/parser` types slot
21
+ * in at runtime.
22
+ */
23
+
24
+ import type { reassignWallOpenings } from '../wall-opening-reassign.js';
25
+
26
+ export interface OverlayEntity {
27
+ expressId: number;
28
+ type: string;
29
+ attributes: unknown[];
30
+ }
31
+
32
+ /**
33
+ * Minimal `StoreEditor` stand-in. Records positional writes by
34
+ * mutating the matching overlay entity's `attributes` array (same
35
+ * effect the real editor has via the property view). `addEntity`
36
+ * mirrors the real editor for tests that exercise creation paths
37
+ * (rotation IfcDirection materialise, etc.).
38
+ */
39
+ export class StubStoreEditor {
40
+ private overlay = new Map<number, OverlayEntity>();
41
+ private positional = new Map<number, Map<number, unknown>>();
42
+ private nextId: number;
43
+
44
+ constructor(initial: OverlayEntity[]) {
45
+ for (const e of initial) this.overlay.set(e.expressId, e);
46
+ this.nextId = Math.max(0, ...initial.map((e) => e.expressId)) + 1;
47
+ }
48
+
49
+ getNewEntity(id: number): OverlayEntity | null {
50
+ return this.overlay.get(id) ?? null;
51
+ }
52
+
53
+ setPositionalAttribute(id: number, index: number, value: unknown): void {
54
+ let entry = this.positional.get(id);
55
+ if (!entry) {
56
+ entry = new Map();
57
+ this.positional.set(id, entry);
58
+ }
59
+ entry.set(index, value);
60
+ const ent = this.overlay.get(id);
61
+ if (ent) ent.attributes[index] = value;
62
+ }
63
+
64
+ addEntity(type: string, attributes: unknown[]): { expressId: number } {
65
+ const id = this.nextId++;
66
+ this.overlay.set(id, { expressId: id, type, attributes: attributes.slice() });
67
+ return { expressId: id };
68
+ }
69
+ }
70
+
71
+ /**
72
+ * Minimal `MutablePropertyView` stand-in. Returns no positional
73
+ * overrides by default. Tests that need pre-mutation state can
74
+ * call `setPositionalForTest` to seed an override; the helper
75
+ * then reads it back via `getPositionalMutationsForEntity`.
76
+ */
77
+ export class StubView {
78
+ private positional = new Map<number, Map<number, unknown>>();
79
+
80
+ getPositionalMutationsForEntity(id: number): Map<number, unknown> | null {
81
+ return this.positional.get(id) ?? null;
82
+ }
83
+
84
+ setPositionalForTest(id: number, index: number, value: unknown): void {
85
+ let entry = this.positional.get(id);
86
+ if (!entry) {
87
+ entry = new Map();
88
+ this.positional.set(id, entry);
89
+ }
90
+ entry.set(index, value);
91
+ }
92
+ }
93
+
94
+ /**
95
+ * Stub `IfcDataStore` — only the `entityIndex.byType` map is
96
+ * meaningfully populated. `source` is an empty buffer; `byId` is
97
+ * an empty map so the parser-backed source reader (registered via
98
+ * `setSourceAttrsReader` in production) never matches anything,
99
+ * which is correct for overlay-only test fixtures.
100
+ *
101
+ * Pass `byType: new Map([['IFCRELDEFINESBYPROPERTIES', [50]]])`
102
+ * to expose rels for `cloneElementMetadata` /
103
+ * `reassignWallOpenings` style tests.
104
+ */
105
+ export function makeStubDataStore(byType: Map<string, number[]> = new Map()): Parameters<typeof reassignWallOpenings>[0] {
106
+ return {
107
+ source: new Uint8Array(),
108
+ entityIndex: { byId: new Map(), byType },
109
+ } as unknown as Parameters<typeof reassignWallOpenings>[0];
110
+ }
@@ -28,9 +28,13 @@
28
28
  import proj4 from 'proj4';
29
29
  import type { MapConversion, ProjectedCRS } from '@ifc-lite/parser';
30
30
  import type { CoordinateInfo } from '@ifc-lite/geometry';
31
- import { resolveProjection } from './reproject';
32
- import { resolveTerrainElevation } from './terrain-elevation';
33
- import { getEffectiveHorizontalScale } from './effective-georef';
31
+ import { computeModelCenterInIfcMeters, resolveProjection } from './reproject';
32
+ import {
33
+ resolveTerrainElevationDetailed,
34
+ type ResolveTerrainElevationOptions,
35
+ type TerrainElevationSample,
36
+ } from './terrain-elevation';
37
+ import { getEffectiveHorizontalScale, resolveMapUnitToMetreScale } from './geo-scale';
34
38
 
35
39
  export interface GeodesicPosition {
36
40
  longitude: number;
@@ -61,11 +65,65 @@ export interface CesiumBridge {
61
65
  queryTerrainHeight(
62
66
  Cesium: typeof import('cesium'),
63
67
  viewer: InstanceType<typeof import('cesium').Viewer>,
64
- ): Promise<number | null>;
68
+ options?: ResolveTerrainElevationOptions,
69
+ ): Promise<TerrainElevationSample | null>;
65
70
 
66
71
  viewerToGeodetic(vx: number, vy: number, vz: number): GeodesicPosition | null;
67
72
  }
68
73
 
74
+ export interface CesiumModelOriginInfo extends GeodesicPosition {
75
+ longitude: number;
76
+ latitude: number;
77
+ height: number;
78
+ ifcOriginHeight: number;
79
+ easting: number;
80
+ northing: number;
81
+ horizontalScale: number;
82
+ }
83
+
84
+ export async function computeCesiumModelOrigin(
85
+ mapConversion: MapConversion,
86
+ projectedCRS: ProjectedCRS,
87
+ coordinateInfo?: CoordinateInfo,
88
+ lengthUnitScale = 1,
89
+ placementHeightOverride?: number,
90
+ ): Promise<CesiumModelOriginInfo | null> {
91
+ const projDef = await resolveProjection(projectedCRS);
92
+ if (!projDef) return null;
93
+
94
+ const absc = mapConversion.xAxisAbscissa ?? 1.0;
95
+ const ordi = mapConversion.xAxisOrdinate ?? 0.0;
96
+ const center = computeModelCenterInIfcMeters(coordinateInfo);
97
+ const mapScale = resolveMapUnitToMetreScale(projectedCRS.mapUnitScale, lengthUnitScale);
98
+ const horizontalScale = getEffectiveHorizontalScale(
99
+ mapConversion.scale,
100
+ mapScale,
101
+ lengthUnitScale,
102
+ );
103
+ const easting = mapConversion.eastings * mapScale
104
+ + horizontalScale * (absc * center.ifcX - ordi * center.ifcY);
105
+ const northing = mapConversion.northings * mapScale
106
+ + horizontalScale * (ordi * center.ifcX + absc * center.ifcY);
107
+ const ifcOriginHeight = mapConversion.orthogonalHeight * mapScale + center.ifcZ;
108
+ const height = placementHeightOverride ?? ifcOriginHeight;
109
+
110
+ try {
111
+ const [lon, lat] = proj4(projDef, 'WGS84', [easting, northing]);
112
+ if (!Number.isFinite(lat) || !Number.isFinite(lon)) return null;
113
+ return {
114
+ longitude: lon,
115
+ latitude: lat,
116
+ height,
117
+ ifcOriginHeight,
118
+ easting,
119
+ northing,
120
+ horizontalScale,
121
+ };
122
+ } catch {
123
+ return null;
124
+ }
125
+ }
126
+
69
127
  export async function createCesiumBridge(
70
128
  mapConversion: MapConversion,
71
129
  projectedCRS: ProjectedCRS,
@@ -87,57 +145,34 @@ export async function createCesiumBridge(
87
145
  const ordi = mapConversion.xAxisOrdinate ?? 0.0;
88
146
  const rotAngle = Math.atan2(ordi, absc);
89
147
 
90
- const shift = coordinateInfo?.originShift ?? { x: 0, y: 0, z: 0 };
91
- const rtc = coordinateInfo?.wasmRtcOffset;
92
- const rtcYup = rtc
93
- ? { x: rtc.x, y: rtc.z, z: -rtc.y }
94
- : { x: 0, y: 0, z: 0 };
95
-
96
148
  const bounds = coordinateInfo?.originalBounds;
97
149
  const modelVX = bounds ? (bounds.min.x + bounds.max.x) / 2 : 0;
98
150
  const modelVY = bounds ? (bounds.min.y + bounds.max.y) / 2 : 0;
99
151
  const modelVZ = bounds ? (bounds.min.z + bounds.max.z) / 2 : 0;
100
152
 
101
- // ── Compute model origin in WGS84 ──
102
- const owx = modelVX + shift.x + rtcYup.x;
103
- const owy = modelVY + shift.y + rtcYup.y;
104
- const owz = modelVZ + shift.z + rtcYup.z;
105
- // Viewer Y-up IFC Z-up
106
- const oIfcX = owx;
107
- const oIfcY = -owz;
108
- const oIfcZ = owy;
109
- // Geometry coordinates (oIfcX/Y/Z) are already in metres (the geometry engine
110
- // converts from the IFC file's native unit during extraction). MapConversion
111
- // values use the unit from IfcProjectedCRS.MapUnit; fall back to project unit.
112
- const mapScale = projectedCRS.mapUnitScale ?? lengthUnitScale;
113
- // IfcMapConversion.Scale bridges project length unit → map unit (e.g. 0.001
114
- // for mm→m). Geometry is already in metres, so the effective horizontal
115
- // scale is (Scale * mapUnitScale) / lengthUnitScale — see issue #595.
116
- const hScale = getEffectiveHorizontalScale(mapConversion.scale, mapScale, lengthUnitScale);
117
- const oEasting = mapConversion.eastings * mapScale + hScale * (absc * oIfcX - ordi * oIfcY);
118
- const oNorthing = mapConversion.northings * mapScale + hScale * (ordi * oIfcX + absc * oIfcY);
119
- const ifcOHeight = mapConversion.orthogonalHeight * mapScale + oIfcZ;
120
- // The actual altitude used for the enuToEcef origin. When the caller
121
- // pre-computes a terrain-clamped placement, we honour it so the bridge,
122
- // model matrix, and camera frame are all built around the SAME altitude
123
- // from the start — no post-load shifting required.
124
- const oHeight = placementHeightOverride ?? ifcOHeight;
125
-
126
- let originLon: number, originLat: number;
127
- try {
128
- const [lon, lat] = proj4(projDef, 'WGS84', [oEasting, oNorthing]);
129
- if (!Number.isFinite(lat) || !Number.isFinite(lon)) return null;
130
- originLon = lon;
131
- originLat = lat;
132
- } catch {
133
- return null;
134
- }
135
-
153
+ const shift = coordinateInfo?.originShift ?? { x: 0, y: 0, z: 0 };
154
+ const rtc = coordinateInfo?.wasmRtcOffset;
155
+ const rtcYup = rtc
156
+ ? { x: rtc.x, y: rtc.z, z: -rtc.y }
157
+ : { x: 0, y: 0, z: 0 };
158
+ const origin = await computeCesiumModelOrigin(
159
+ mapConversion,
160
+ projectedCRS,
161
+ coordinateInfo,
162
+ lengthUnitScale,
163
+ placementHeightOverride,
164
+ );
165
+ if (!origin) return null;
136
166
  const modelOrigin: GeodesicPosition = {
137
- longitude: originLon,
138
- latitude: originLat,
139
- height: oHeight,
167
+ longitude: origin.longitude,
168
+ latitude: origin.latitude,
169
+ height: origin.height,
140
170
  };
171
+ const hScale = origin.horizontalScale;
172
+ const mapScale = resolveMapUnitToMetreScale(projectedCRS.mapUnitScale, lengthUnitScale);
173
+ const oHeight = origin.height;
174
+ const originLon = origin.longitude;
175
+ const originLat = origin.latitude;
141
176
 
142
177
  // ── Build the viewer→ENU 3x3 rotation matrix ──
143
178
  // This converts a DELTA vector from viewer space to ENU.
@@ -301,8 +336,9 @@ export async function createCesiumBridge(
301
336
  function queryTerrainHeight(
302
337
  Cesium: typeof import('cesium'),
303
338
  viewer: InstanceType<typeof import('cesium').Viewer>,
304
- ): Promise<number | null> {
305
- return resolveTerrainElevation(Cesium, viewer, originLat, originLon);
339
+ options: ResolveTerrainElevationOptions = {},
340
+ ): Promise<TerrainElevationSample | null> {
341
+ return resolveTerrainElevationDetailed(Cesium, viewer, originLat, originLon, options);
306
342
  }
307
343
 
308
344
  function viewerToGeodetic(vx: number, vy: number, vz: number): GeodesicPosition | null {