@expofp/floorplan 3.3.7 → 3.4.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (249) hide show
  1. package/dist/browser/CookieConsent-BgzFI0o5.js +38 -0
  2. package/dist/browser/{Debug-A2TjoZQK.js → Debug-DwwZ0jVT.js} +9 -9
  3. package/dist/browser/{Demo-iK72mOgP.js → Demo-Bhv7muKd.js} +11 -11
  4. package/dist/browser/{Free-BcbAZA3y.js → Free-EaDzP7U5.js} +12 -12
  5. package/dist/browser/{Gallery-U-ldyITy.js → Gallery-BFio06PY.js} +10 -10
  6. package/dist/browser/{GpsLoader-DqPTky-0.js → GpsLoader-BhYirpWa.js} +46 -47
  7. package/dist/browser/{KioskStore-DIKp1HfX.js → KioskStore-DiTPaFb2.js} +17 -17
  8. package/dist/browser/MaplibreAdapter-BKj3sK8A.js +35131 -0
  9. package/dist/browser/{Modal-BLjdiYfi.js → Modal-DVY124d5.js} +10 -10
  10. package/dist/browser/PermissionNotice-CrAxf_da.js +54 -0
  11. package/dist/browser/{SetKioskMode-CIDQnVVK.js → SetKioskMode-Cj1IbMbn.js} +11 -11
  12. package/dist/browser/ShowKiosk-CqmJT8yJ.js +26 -0
  13. package/dist/browser/{TouchHand-4OAXEmLA.js → TouchHand-BdZWU_I1.js} +4 -4
  14. package/dist/browser/{ViewerMenuPanel-BFEwT9oC.js → ViewerMenuPanel-DbVIwrJO.js} +19 -19
  15. package/dist/browser/{add-debug-secret-listener-B2ugeAcj.js → add-debug-secret-listener-B8gxDWmn.js} +1 -1
  16. package/dist/browser/{boolean-editor-Cc1GCvQj.js → boolean-editor-CIT7g6C5.js} +10 -10
  17. package/dist/browser/{bootIntercom-BVGw_SpO.js → bootIntercom-CcgHFRAw.js} +2 -2
  18. package/dist/browser/{box-CaErtqkj.js → box-CydZk4HJ.js} +5 -5
  19. package/dist/browser/{browser-_paBhqQW.js → browser-DlMYMMvJ.js} +2 -2
  20. package/dist/browser/bundle.json +61 -61
  21. package/dist/browser/{classnames-CVk0A91C.js → classnames-DmdaKMoa.js} +2 -2
  22. package/dist/browser/{client-B70Nbh5h.js → client-8ygU_jvu.js} +4 -4
  23. package/dist/browser/components-BgwIl1Lu.js +6289 -0
  24. package/dist/browser/createWayfinding-D9tuHHx5.js +1889 -0
  25. package/dist/browser/{debug-overlay-CyYqgTdj.js → debug-overlay-Dos3Ate2.js} +11 -11
  26. package/dist/browser/{debug-ui-D9A6yzed.js → debug-ui-BjmKfkgV.js} +6 -6
  27. package/dist/browser/{dist-BUD3zJ9Z.js → dist-B3Y58WKJ.js} +6 -6
  28. package/dist/browser/{dist-BPljQLT7.js → dist-Bm6VKnC2.js} +3 -3
  29. package/dist/browser/{dist-BrWnw-Ri.js → dist-_wJOZ0rm.js} +5 -5
  30. package/dist/browser/{efp-debug-init-CL7ckXKd.js → efp-debug-init-yyCWZRTx.js} +5 -4
  31. package/dist/browser/{enum-editor-Djt6vsG1.js → enum-editor-D8X_uabc.js} +11 -11
  32. package/dist/browser/{event-not-found-CAUywrB2.js → event-not-found-Bm_W5xxA.js} +1 -1
  33. package/dist/browser/{exports-D5aj-cpr.js → exports-DnHrfjiU.js} +1 -1
  34. package/dist/browser/{favicon-B3ilFIzN.js → favicon-Bnz633J6.js} +1 -1
  35. package/dist/browser/{fetch-retry.umd-CC6nRZde.js → fetch-retry.umd-BunUcQza.js} +2 -2
  36. package/dist/browser/{flex-SCSgjwpS.js → flex-DwDJlblp.js} +6 -6
  37. package/dist/browser/{flex.props-DM7y21yG.js → flex.props-BAGkFvkN.js} +2 -2
  38. package/dist/browser/{floorplan.loader-BmVUKCxN.js → floorplan.loader-B3PUqtqn.js} +30 -31
  39. package/dist/browser/{floorplan.ready-da1pQZ1-.js → floorplan.ready-BAnq_GdS.js} +196 -196
  40. package/dist/browser/{fuse-DY6Kjf36.js → fuse-Bhsd7fBU.js} +2 -2
  41. package/dist/browser/{i18n-1-u98ly9.js → i18n-C5BBGKZk.js} +5 -5
  42. package/dist/browser/index.js +13 -13
  43. package/dist/browser/{jsx-runtime-BESB6cP1.js → jsx-runtime-Dk2--jeN.js} +2 -2
  44. package/dist/browser/{lib-BhhCH6-T.js → lib-Brd2BCh_.js} +4 -4
  45. package/dist/browser/locales/ar.json +0 -1
  46. package/dist/browser/locales/de.json +0 -1
  47. package/dist/browser/locales/es.json +0 -1
  48. package/dist/browser/locales/fr.json +0 -1
  49. package/dist/browser/locales/he.json +0 -1
  50. package/dist/browser/locales/it.json +0 -1
  51. package/dist/browser/locales/kk.json +0 -1
  52. package/dist/browser/locales/ko.json +0 -1
  53. package/dist/browser/locales/mn.json +0 -1
  54. package/dist/browser/locales/nl.json +0 -1
  55. package/dist/browser/locales/pl.json +0 -1
  56. package/dist/browser/locales/pt.json +0 -1
  57. package/dist/browser/locales/ru.json +0 -1
  58. package/dist/browser/locales/sv.json +0 -1
  59. package/dist/browser/locales/th.json +0 -1
  60. package/dist/browser/locales/tr.json +0 -1
  61. package/dist/browser/locales/uk.json +0 -1
  62. package/dist/browser/locales/vi.json +0 -1
  63. package/dist/browser/locales/zh.json +0 -1
  64. package/dist/browser/{main-D2NmCv2H.js → main-pIcuVUIg.js} +1 -1
  65. package/dist/browser/{mobx-Cfh5Vfk6.js → mobx-BfCD0EQ-.js} +4 -4
  66. package/dist/browser/{particles.min-B5qlVBuL.js → particles.min-ChGMv-bm.js} +2 -2
  67. package/dist/browser/{prop-types-DZ8VfWUb.js → prop-types-xdXFFTmm.js} +2 -2
  68. package/dist/browser/{react-cXsgFw41.js → react-BbZc5Oeq.js} +2 -2
  69. package/dist/browser/{react-dom-l5Q31Wma.js → react-dom-BBDOhlbP.js} +3 -3
  70. package/dist/browser/{reset-all-settings-B6K1EwXP.js → reset-all-settings-BQC7zljW.js} +7 -7
  71. package/dist/browser/{rolldown-runtime-hPqAdzN2.js → rolldown-runtime-DS4W77DU.js} +1 -1
  72. package/dist/browser/{settings-BZyvLLph.js → settings-CK-qRFM8.js} +2 -2
  73. package/dist/browser/{settings-item-zDeA5cv4.js → settings-item-CUnGC7xO.js} +6 -6
  74. package/dist/browser/{storage-CneO9F9t.js → storage-0QGL3b8S.js} +3 -3
  75. package/dist/browser/{store-CQphSXxk.js → store-Bm4aFC2V.js} +4543 -4998
  76. package/dist/browser/{string-editor-BJn1AFSw.js → string-editor-BNry84Oh.js} +8 -8
  77. package/dist/browser/{theme-DoAOOaRE.js → theme-BIXywNMw.js} +8 -8
  78. package/dist/browser/{ui-DNF4wGZh.js → ui-AzubEvGd.js} +8 -8
  79. package/dist/browser/{useRenderTarget-BYpCY_A9.js → useRenderTarget-Bf7cQRFi.js} +4 -4
  80. package/dist/esm/_misc_to_move/manifest.d.ts +1 -0
  81. package/dist/esm/components/AlertContainer.d.ts +1 -1
  82. package/dist/esm/components/Controls.js +1 -1
  83. package/dist/esm/components/CookieConsent.d.ts +3 -3
  84. package/dist/esm/components/CookieConsent.js +1 -1
  85. package/dist/esm/components/EntityItemContainer.d.ts +1 -1
  86. package/dist/esm/components/Exhibitor.js +1 -1
  87. package/dist/esm/components/HeatmapLegendContainer.d.ts +6 -0
  88. package/dist/esm/components/HeatmapLegendContainer.js +1 -0
  89. package/dist/esm/components/HighlightTextContainer.d.ts +1 -1
  90. package/dist/esm/components/Kiosk/SetKiosk/SetKioskComponent.js +1 -1
  91. package/dist/esm/components/Layout.js +1 -1
  92. package/dist/esm/components/LevelBadgeContainer.d.ts +6 -0
  93. package/dist/esm/components/LevelBadgeContainer.js +1 -0
  94. package/dist/esm/components/LevelSelector.js +1 -1
  95. package/dist/esm/components/LogoOverlay.js +1 -1
  96. package/dist/esm/components/Map/Map.js +1 -1
  97. package/dist/esm/components/Map/drawing/config/config-booth-bg.d.ts +3 -2
  98. package/dist/esm/components/Map/drawing/config/config-booth-bg.js +1 -1
  99. package/dist/esm/components/Map/drawing/config/config-booth-border.js +1 -1
  100. package/dist/esm/components/Map/drawing/config/config-booths.js +1 -1
  101. package/dist/esm/components/Map/drawing/config/config-load-layer.js +1 -1
  102. package/dist/esm/components/Map/traffic/useManageTraffic.js +1 -1
  103. package/dist/esm/components/Maplibre/MaplibreAdapter.d.ts +14 -0
  104. package/dist/esm/components/Maplibre/MaplibreAdapter.js +1 -0
  105. package/dist/esm/components/Maplibre/MaplibreWrapper.d.ts +69 -0
  106. package/dist/esm/components/Maplibre/MaplibreWrapper.js +1 -0
  107. package/dist/esm/components/Maplibre/useCameraReactions.d.ts +10 -0
  108. package/dist/esm/components/Maplibre/useCameraReactions.js +1 -0
  109. package/dist/esm/components/Maplibre/useDimming.d.ts +16 -0
  110. package/dist/esm/components/Maplibre/useDimming.js +1 -0
  111. package/dist/esm/components/Maplibre/useLayerVisibilitySync.d.ts +11 -0
  112. package/dist/esm/components/Maplibre/useLayerVisibilitySync.js +1 -0
  113. package/dist/esm/components/Maplibre/useRendererEvents.d.ts +9 -0
  114. package/dist/esm/components/Maplibre/useRendererEvents.js +1 -0
  115. package/dist/esm/components/Maplibre/useWayfindingAndMarkers.d.ts +8 -0
  116. package/dist/esm/components/Maplibre/useWayfindingAndMarkers.js +1 -0
  117. package/dist/esm/components/Maplibre/utils/geo-config.d.ts +30 -0
  118. package/dist/esm/components/Maplibre/utils/geo-config.js +1 -0
  119. package/dist/esm/components/Maplibre/utils/layer-defs.d.ts +4 -0
  120. package/dist/esm/components/Maplibre/utils/layer-defs.js +1 -0
  121. package/dist/esm/components/Maplibre/utils/map-helpers.d.ts +9 -0
  122. package/dist/esm/components/Maplibre/utils/map-helpers.js +1 -0
  123. package/dist/esm/components/Maplibre/utils/solver.d.ts +24 -0
  124. package/dist/esm/components/Maplibre/utils/solver.js +1 -0
  125. package/dist/esm/components/OverlayContainer.d.ts +1 -1
  126. package/dist/esm/components/OverlayGripContainer.d.ts +4 -0
  127. package/dist/esm/components/OverlayGripContainer.js +1 -0
  128. package/dist/esm/components/ScrollableRowContainer.d.ts +6 -0
  129. package/dist/esm/components/ScrollableRowContainer.js +1 -0
  130. package/dist/esm/components/SearchButtons/SearchButtons.d.ts +1 -1
  131. package/dist/esm/components/SearchButtons/SearchButtons.js +1 -1
  132. package/dist/esm/components/Shortcuts/ShortcutsToolbar.d.ts +1 -1
  133. package/dist/esm/components/Shortcuts/ShortcutsToolbar.js +1 -1
  134. package/dist/esm/components/WayfindingFloorSelectorContainer.d.ts +1 -1
  135. package/dist/esm/components/gps/GpsPermissionRequest.js +1 -1
  136. package/dist/esm/components/index.d.ts +9 -8
  137. package/dist/esm/components/index.js +1 -1
  138. package/dist/esm/data/Flags.d.ts +1 -0
  139. package/dist/esm/data/fpGeo.d.ts +20 -1
  140. package/dist/esm/floorplan.loader.d.ts +1 -0
  141. package/dist/esm/floorplan.loader.js +1 -1
  142. package/dist/esm/floorplan.ready.js +1 -1
  143. package/dist/esm/renderer/RendererService.d.ts +5 -0
  144. package/dist/esm/renderer/RendererService.js +1 -1
  145. package/dist/esm/services/routing.js +1 -1
  146. package/dist/esm/store/HeatmapStore.js +1 -1
  147. package/dist/esm/store/MaplibreStore.d.ts +22 -0
  148. package/dist/esm/store/MaplibreStore.js +1 -0
  149. package/dist/esm/store/RootStore.d.ts +2 -2
  150. package/dist/esm/store/RootStore.js +1 -1
  151. package/dist/esm/store/RouteStore.js +1 -1
  152. package/dist/esm/store/init/init-booths.js +1 -1
  153. package/dist/esm/types.d.ts +9 -0
  154. package/dist/esm/ui/Draggable/Draggable.d.ts +9 -0
  155. package/dist/esm/ui/Draggable/Draggable.js +1 -0
  156. package/dist/esm/ui/Draggable/index.d.ts +3 -0
  157. package/dist/esm/ui/Draggable/index.js +1 -0
  158. package/dist/esm/ui/HeatmapLegend/HeatmapLegend.d.ts +13 -0
  159. package/dist/esm/ui/HeatmapLegend/HeatmapLegend.js +1 -0
  160. package/dist/esm/ui/HeatmapLegend/index.d.ts +3 -0
  161. package/dist/esm/ui/HeatmapLegend/index.js +1 -0
  162. package/dist/esm/ui/LevelBadge/LevelBadge.d.ts +9 -0
  163. package/dist/esm/ui/LevelBadge/LevelBadge.js +1 -0
  164. package/dist/esm/ui/LevelBadge/index.d.ts +3 -0
  165. package/dist/esm/ui/LevelBadge/index.js +1 -0
  166. package/dist/esm/ui/OverlayGrip/OverlayGrip.d.ts +11 -0
  167. package/dist/esm/ui/OverlayGrip/OverlayGrip.js +1 -0
  168. package/dist/esm/ui/OverlayGrip/index.d.ts +3 -0
  169. package/dist/esm/ui/OverlayGrip/index.js +1 -0
  170. package/dist/esm/ui/PermissionNotice/PermissionNotice.d.ts +16 -0
  171. package/dist/esm/ui/PermissionNotice/PermissionNotice.js +1 -0
  172. package/dist/esm/ui/PermissionNotice/index.d.ts +3 -0
  173. package/dist/esm/ui/PermissionNotice/index.js +1 -0
  174. package/dist/esm/{components → ui/ScrollableRow}/ScrollableRow.d.ts +5 -4
  175. package/dist/esm/ui/ScrollableRow/ScrollableRow.js +1 -0
  176. package/dist/esm/ui/ScrollableRow/index.d.ts +3 -0
  177. package/dist/esm/ui/ScrollableRow/index.js +1 -0
  178. package/dist/esm/ui/ToggleSwitch/ToggleSwitch.d.ts +4 -10
  179. package/dist/esm/ui/ToggleSwitch/ToggleSwitch.js +1 -1
  180. package/dist/esm/ui/shared/interactive.d.ts +2 -0
  181. package/dist/esm/ui/shared/interactive.js +1 -0
  182. package/dist/esm/utils/color-gradient.d.ts +2 -0
  183. package/dist/esm/utils/color-gradient.js +1 -0
  184. package/dist/esm/utils/dimming.d.ts +16 -0
  185. package/dist/esm/utils/dimming.js +1 -0
  186. package/dist/esm/wayfinding/core/position/gpsThreshold.d.ts +1 -1
  187. package/package.json +5 -9
  188. package/dist/browser/CookieConsent-DeA-DR4A.js +0 -71
  189. package/dist/browser/Mapbox-ChPNLhVw.js +0 -120
  190. package/dist/browser/ShowKiosk-CprbVv29.js +0 -26
  191. package/dist/browser/ThreeComponent-CtqPjAlQ.js +0 -1494
  192. package/dist/browser/components-XkvqySvZ.js +0 -8143
  193. package/dist/browser/data-DshpY4Eh.js +0 -27967
  194. package/dist/browser/vendor/mapbox/mapbox-gl.css +0 -1
  195. package/dist/esm/components/BookmarkSvg.d.ts +0 -4
  196. package/dist/esm/components/BookmarkSvg.js +0 -1
  197. package/dist/esm/components/Draggable.d.ts +0 -10
  198. package/dist/esm/components/Draggable.js +0 -1
  199. package/dist/esm/components/HeatmapLegend.d.ts +0 -12
  200. package/dist/esm/components/HeatmapLegend.js +0 -1
  201. package/dist/esm/components/LevelBadge.d.ts +0 -8
  202. package/dist/esm/components/LevelBadge.js +0 -1
  203. package/dist/esm/components/Mapbox/Button.d.ts +0 -10
  204. package/dist/esm/components/Mapbox/Button.js +0 -1
  205. package/dist/esm/components/Mapbox/Dot.d.ts +0 -10
  206. package/dist/esm/components/Mapbox/Dot.js +0 -1
  207. package/dist/esm/components/Mapbox/MapLoader.d.ts +0 -4
  208. package/dist/esm/components/Mapbox/MapLoader.js +0 -1
  209. package/dist/esm/components/Mapbox/Mapbox.d.ts +0 -4
  210. package/dist/esm/components/Mapbox/Mapbox.js +0 -1
  211. package/dist/esm/components/Mapbox/utils/data.d.ts +0 -38
  212. package/dist/esm/components/Mapbox/utils/data.js +0 -1
  213. package/dist/esm/components/OverlayGrip.d.ts +0 -5
  214. package/dist/esm/components/OverlayGrip.js +0 -1
  215. package/dist/esm/components/PermissionNotice/PermissionNotice.d.ts +0 -14
  216. package/dist/esm/components/PermissionNotice/PermissionNotice.js +0 -1
  217. package/dist/esm/components/ScrollableRow.js +0 -1
  218. package/dist/esm/components/Threejs/ThreeComponent.d.ts +0 -7
  219. package/dist/esm/components/Threejs/ThreeComponent.js +0 -1
  220. package/dist/esm/components/Threejs/UIManager.d.ts +0 -28
  221. package/dist/esm/components/Threejs/UIManager.js +0 -1
  222. package/dist/esm/components/Threejs/common/BoothMesh.d.ts +0 -20
  223. package/dist/esm/components/Threejs/common/BoothMesh.js +0 -1
  224. package/dist/esm/components/Threejs/common/Scene.d.ts +0 -13
  225. package/dist/esm/components/Threejs/common/Scene.js +0 -1
  226. package/dist/esm/components/Threejs/common/SpriteMesh.d.ts +0 -5
  227. package/dist/esm/components/Threejs/common/SpriteMesh.js +0 -1
  228. package/dist/esm/components/Threejs/common/dataLoader.d.ts +0 -31
  229. package/dist/esm/components/Threejs/common/dataLoader.js +0 -1
  230. package/dist/esm/components/Threejs/common/modelLoader.d.ts +0 -3
  231. package/dist/esm/components/Threejs/common/modelLoader.js +0 -1
  232. package/dist/esm/components/Threejs/common/sceneLoader.d.ts +0 -7
  233. package/dist/esm/components/Threejs/common/sceneLoader.js +0 -1
  234. package/dist/esm/components/Threejs/index.d.ts +0 -4
  235. package/dist/esm/components/Threejs/index.js +0 -1
  236. package/dist/esm/components/Threejs/mapbox/configureWebGLForMapbox.d.ts +0 -2
  237. package/dist/esm/components/Threejs/mapbox/configureWebGLForMapbox.js +0 -1
  238. package/dist/esm/components/Threejs/mapbox/index_mapbox.d.ts +0 -4
  239. package/dist/esm/components/Threejs/mapbox/index_mapbox.js +0 -1
  240. package/dist/esm/components/Threejs/mapbox/init-mapbox.d.ts +0 -3
  241. package/dist/esm/components/Threejs/mapbox/init-mapbox.js +0 -1
  242. package/dist/esm/components/Threejs/utils/canvasFromText.d.ts +0 -2
  243. package/dist/esm/components/Threejs/utils/canvasFromText.js +0 -1
  244. package/dist/esm/components/Threejs/utils/textureMerger.d.ts +0 -60
  245. package/dist/esm/components/Threejs/utils/textureMerger.js +0 -1
  246. package/dist/esm/store/MapboxStore.d.ts +0 -13
  247. package/dist/esm/store/MapboxStore.js +0 -1
  248. package/dist/esm/tools/Color.d.ts +0 -2
  249. package/dist/esm/tools/Color.js +0 -1
@@ -1,1494 +0,0 @@
1
- (function() {
2
- try {
3
- var e = typeof window < "u" ? window : typeof global < "u" ? global : typeof globalThis < "u" ? globalThis : typeof self < "u" ? self : {};
4
- e.SENTRY_RELEASE = { id: "3.3.7" };
5
- var t = new e.Error().stack;
6
- t && (e._sentryDebugIds = e._sentryDebugIds || {}, e._sentryDebugIds[t] = "05ea5011-e159-4b3a-bedf-cbdf26d3a49c", e._sentryDebugIdIdentifier = "sentry-dbid-05ea5011-e159-4b3a-bedf-cbdf26d3a49c");
7
- } catch {}
8
- })();
9
- import { r as e } from "./rolldown-runtime-hPqAdzN2.js";
10
- import { t } from "./react-cXsgFw41.js";
11
- import { t as n } from "./jsx-runtime-BESB6cP1.js";
12
- import { C as r } from "./i18n-1-u98ly9.js";
13
- import { t as i } from "./classnames-CVk0A91C.js";
14
- import { $n as a, $t as o, Bt as s, Cn as c, Dn as l, En as u, Gt as d, Hn as f, Ht as p, Jn as m, Jt as h, Kt as g, Lt as _, On as v, Qn as ee, Qt as y, Rt as te, Sn as b, Tn as x, Ut as S, Vt as C, Wt as w, Xt as ne, Yt as T, Zt as E, _n as re, an as D, bn as ie, cn as ae, dn as oe, en as se, fn as ce, ft as le, gn as ue, gt as de, hn as fe, i as pe, in as O, ln as me, mn as k, nn as he, o as A, on as ge, pn as j, qn as _e, qt as ve, rn as ye, s as M, sn as N, t as P, tn as F, un as be, vn as xe, wn as Se, xn as Ce, yn as I, zt as we } from "./store-CQphSXxk.js";
15
- import { r as L } from "./mobx-Cfh5Vfk6.js";
16
- import { _ as Te, a as R, f as Ee, g as De, i as Oe, n as ke, t as Ae, u as je } from "./data-DshpY4Eh.js";
17
- //#region ../../node_modules/.pnpm/three@0.174.0/node_modules/three/examples/jsm/controls/OrbitControls.js
18
- var Me = /* @__PURE__ */ e(t(), 1), Ne = /* @__PURE__ */ e(i(), 1), z = f(), Pe = { type: "change" }, B = { type: "start" }, Fe = { type: "end" }, V = new ue(), Ie = new oe(), Le = Math.cos(70 * ye.DEG2RAD), H = new l(), U = 2 * Math.PI, W = {
19
- NONE: -1,
20
- ROTATE: 0,
21
- DOLLY: 1,
22
- PAN: 2,
23
- TOUCH_ROTATE: 3,
24
- TOUCH_PAN: 4,
25
- TOUCH_DOLLY_PAN: 5,
26
- TOUCH_DOLLY_ROTATE: 6
27
- }, G = 1e-6, Re = class extends d {
28
- constructor(e, t = null) {
29
- super(e, t), this.state = W.NONE, this.enabled = !0, this.target = new l(), this.cursor = new l(), this.minDistance = 0, this.maxDistance = Infinity, this.minZoom = 0, this.maxZoom = Infinity, this.minTargetRadius = 0, this.maxTargetRadius = Infinity, this.minPolarAngle = 0, this.maxPolarAngle = Math.PI, this.minAzimuthAngle = -Infinity, this.maxAzimuthAngle = Infinity, this.enableDamping = !1, this.dampingFactor = .05, this.enableZoom = !0, this.zoomSpeed = 1, this.enableRotate = !0, this.rotateSpeed = 1, this.keyRotateSpeed = 1, this.enablePan = !0, this.panSpeed = 1, this.screenSpacePanning = !0, this.keyPanSpeed = 7, this.zoomToCursor = !1, this.autoRotate = !1, this.autoRotateSpeed = 2, this.keys = {
30
- LEFT: "ArrowLeft",
31
- UP: "ArrowUp",
32
- RIGHT: "ArrowRight",
33
- BOTTOM: "ArrowDown"
34
- }, this.mouseButtons = {
35
- LEFT: F.ROTATE,
36
- MIDDLE: F.DOLLY,
37
- RIGHT: F.PAN
38
- }, this.touches = {
39
- ONE: c.ROTATE,
40
- TWO: c.DOLLY_PAN
41
- }, this.target0 = this.target.clone(), this.position0 = this.object.position.clone(), this.zoom0 = this.object.zoom, this._domElementKeyEvents = null, this._lastPosition = new l(), this._lastQuaternion = new fe(), this._lastTargetPosition = new l(), this._quat = new fe().setFromUnitVectors(e.up, new l(0, 1, 0)), this._quatInverse = this._quat.clone().invert(), this._spherical = new b(), this._sphericalDelta = new b(), this._scale = 1, this._panOffset = new l(), this._rotateStart = new u(), this._rotateEnd = new u(), this._rotateDelta = new u(), this._panStart = new u(), this._panEnd = new u(), this._panDelta = new u(), this._dollyStart = new u(), this._dollyEnd = new u(), this._dollyDelta = new u(), this._dollyDirection = new l(), this._mouse = new u(), this._performCursorZoom = !1, this._pointers = [], this._pointerPositions = {}, this._controlActive = !1, this._onPointerMove = Be.bind(this), this._onPointerDown = ze.bind(this), this._onPointerUp = Ve.bind(this), this._onContextMenu = Je.bind(this), this._onMouseWheel = We.bind(this), this._onKeyDown = Ge.bind(this), this._onTouchStart = Ke.bind(this), this._onTouchMove = qe.bind(this), this._onMouseDown = He.bind(this), this._onMouseMove = Ue.bind(this), this._interceptControlDown = Ye.bind(this), this._interceptControlUp = Xe.bind(this), this.domElement !== null && this.connect(), this.update();
42
- }
43
- connect() {
44
- this.domElement.addEventListener("pointerdown", this._onPointerDown), this.domElement.addEventListener("pointercancel", this._onPointerUp), this.domElement.addEventListener("contextmenu", this._onContextMenu), this.domElement.addEventListener("wheel", this._onMouseWheel, { passive: !1 }), this.domElement.getRootNode().addEventListener("keydown", this._interceptControlDown, {
45
- passive: !0,
46
- capture: !0
47
- }), this.domElement.style.touchAction = "none";
48
- }
49
- disconnect() {
50
- this.domElement.removeEventListener("pointerdown", this._onPointerDown), this.domElement.removeEventListener("pointermove", this._onPointerMove), this.domElement.removeEventListener("pointerup", this._onPointerUp), this.domElement.removeEventListener("pointercancel", this._onPointerUp), this.domElement.removeEventListener("wheel", this._onMouseWheel), this.domElement.removeEventListener("contextmenu", this._onContextMenu), this.stopListenToKeyEvents(), this.domElement.getRootNode().removeEventListener("keydown", this._interceptControlDown, { capture: !0 }), this.domElement.style.touchAction = "auto";
51
- }
52
- dispose() {
53
- this.disconnect();
54
- }
55
- getPolarAngle() {
56
- return this._spherical.phi;
57
- }
58
- getAzimuthalAngle() {
59
- return this._spherical.theta;
60
- }
61
- getDistance() {
62
- return this.object.position.distanceTo(this.target);
63
- }
64
- listenToKeyEvents(e) {
65
- e.addEventListener("keydown", this._onKeyDown), this._domElementKeyEvents = e;
66
- }
67
- stopListenToKeyEvents() {
68
- this._domElementKeyEvents !== null && (this._domElementKeyEvents.removeEventListener("keydown", this._onKeyDown), this._domElementKeyEvents = null);
69
- }
70
- saveState() {
71
- this.target0.copy(this.target), this.position0.copy(this.object.position), this.zoom0 = this.object.zoom;
72
- }
73
- reset() {
74
- this.target.copy(this.target0), this.object.position.copy(this.position0), this.object.zoom = this.zoom0, this.object.updateProjectionMatrix(), this.dispatchEvent(Pe), this.update(), this.state = W.NONE;
75
- }
76
- update(e = null) {
77
- let t = this.object.position;
78
- H.copy(t).sub(this.target), H.applyQuaternion(this._quat), this._spherical.setFromVector3(H), this.autoRotate && this.state === W.NONE && this._rotateLeft(this._getAutoRotationAngle(e)), this.enableDamping ? (this._spherical.theta += this._sphericalDelta.theta * this.dampingFactor, this._spherical.phi += this._sphericalDelta.phi * this.dampingFactor) : (this._spherical.theta += this._sphericalDelta.theta, this._spherical.phi += this._sphericalDelta.phi);
79
- let n = this.minAzimuthAngle, r = this.maxAzimuthAngle;
80
- isFinite(n) && isFinite(r) && (n < -Math.PI ? n += U : n > Math.PI && (n -= U), r < -Math.PI ? r += U : r > Math.PI && (r -= U), n <= r ? this._spherical.theta = Math.max(n, Math.min(r, this._spherical.theta)) : this._spherical.theta = this._spherical.theta > (n + r) / 2 ? Math.max(n, this._spherical.theta) : Math.min(r, this._spherical.theta)), this._spherical.phi = Math.max(this.minPolarAngle, Math.min(this.maxPolarAngle, this._spherical.phi)), this._spherical.makeSafe(), this.enableDamping === !0 ? this.target.addScaledVector(this._panOffset, this.dampingFactor) : this.target.add(this._panOffset), this.target.sub(this.cursor), this.target.clampLength(this.minTargetRadius, this.maxTargetRadius), this.target.add(this.cursor);
81
- let i = !1;
82
- if (this.zoomToCursor && this._performCursorZoom || this.object.isOrthographicCamera) this._spherical.radius = this._clampDistance(this._spherical.radius);
83
- else {
84
- let e = this._spherical.radius;
85
- this._spherical.radius = this._clampDistance(this._spherical.radius * this._scale), i = e != this._spherical.radius;
86
- }
87
- if (H.setFromSpherical(this._spherical), H.applyQuaternion(this._quatInverse), t.copy(this.target).add(H), this.object.lookAt(this.target), this.enableDamping === !0 ? (this._sphericalDelta.theta *= 1 - this.dampingFactor, this._sphericalDelta.phi *= 1 - this.dampingFactor, this._panOffset.multiplyScalar(1 - this.dampingFactor)) : (this._sphericalDelta.set(0, 0, 0), this._panOffset.set(0, 0, 0)), this.zoomToCursor && this._performCursorZoom) {
88
- let e = null;
89
- if (this.object.isPerspectiveCamera) {
90
- let t = H.length();
91
- e = this._clampDistance(t * this._scale);
92
- let n = t - e;
93
- this.object.position.addScaledVector(this._dollyDirection, n), this.object.updateMatrixWorld(), i = !!n;
94
- } else if (this.object.isOrthographicCamera) {
95
- let t = new l(this._mouse.x, this._mouse.y, 0);
96
- t.unproject(this.object);
97
- let n = this.object.zoom;
98
- this.object.zoom = Math.max(this.minZoom, Math.min(this.maxZoom, this.object.zoom / this._scale)), this.object.updateProjectionMatrix(), i = n !== this.object.zoom;
99
- let r = new l(this._mouse.x, this._mouse.y, 0);
100
- r.unproject(this.object), this.object.position.sub(r).add(t), this.object.updateMatrixWorld(), e = H.length();
101
- } else console.warn("WARNING: OrbitControls.js encountered an unknown camera type - zoom to cursor disabled."), this.zoomToCursor = !1;
102
- e !== null && (this.screenSpacePanning ? this.target.set(0, 0, -1).transformDirection(this.object.matrix).multiplyScalar(e).add(this.object.position) : (V.origin.copy(this.object.position), V.direction.set(0, 0, -1).transformDirection(this.object.matrix), Math.abs(this.object.up.dot(V.direction)) < Le ? this.object.lookAt(this.target) : (Ie.setFromNormalAndCoplanarPoint(this.object.up, this.target), V.intersectPlane(Ie, this.target))));
103
- } else if (this.object.isOrthographicCamera) {
104
- let e = this.object.zoom;
105
- this.object.zoom = Math.max(this.minZoom, Math.min(this.maxZoom, this.object.zoom / this._scale)), e !== this.object.zoom && (this.object.updateProjectionMatrix(), i = !0);
106
- }
107
- return this._scale = 1, this._performCursorZoom = !1, i || this._lastPosition.distanceToSquared(this.object.position) > G || 8 * (1 - this._lastQuaternion.dot(this.object.quaternion)) > G || this._lastTargetPosition.distanceToSquared(this.target) > G ? (this.dispatchEvent(Pe), this._lastPosition.copy(this.object.position), this._lastQuaternion.copy(this.object.quaternion), this._lastTargetPosition.copy(this.target), !0) : !1;
108
- }
109
- _getAutoRotationAngle(e) {
110
- return e === null ? U / 60 / 60 * this.autoRotateSpeed : U / 60 * this.autoRotateSpeed * e;
111
- }
112
- _getZoomScale(e) {
113
- let t = Math.abs(e * .01);
114
- return .95 ** (this.zoomSpeed * t);
115
- }
116
- _rotateLeft(e) {
117
- this._sphericalDelta.theta -= e;
118
- }
119
- _rotateUp(e) {
120
- this._sphericalDelta.phi -= e;
121
- }
122
- _panLeft(e, t) {
123
- H.setFromMatrixColumn(t, 0), H.multiplyScalar(-e), this._panOffset.add(H);
124
- }
125
- _panUp(e, t) {
126
- this.screenSpacePanning === !0 ? H.setFromMatrixColumn(t, 1) : (H.setFromMatrixColumn(t, 0), H.crossVectors(this.object.up, H)), H.multiplyScalar(e), this._panOffset.add(H);
127
- }
128
- _pan(e, t) {
129
- let n = this.domElement;
130
- if (this.object.isPerspectiveCamera) {
131
- let r = this.object.position;
132
- H.copy(r).sub(this.target);
133
- let i = H.length();
134
- i *= Math.tan(this.object.fov / 2 * Math.PI / 180), this._panLeft(2 * e * i / n.clientHeight, this.object.matrix), this._panUp(2 * t * i / n.clientHeight, this.object.matrix);
135
- } else this.object.isOrthographicCamera ? (this._panLeft(e * (this.object.right - this.object.left) / this.object.zoom / n.clientWidth, this.object.matrix), this._panUp(t * (this.object.top - this.object.bottom) / this.object.zoom / n.clientHeight, this.object.matrix)) : (console.warn("WARNING: OrbitControls.js encountered an unknown camera type - pan disabled."), this.enablePan = !1);
136
- }
137
- _dollyOut(e) {
138
- this.object.isPerspectiveCamera || this.object.isOrthographicCamera ? this._scale /= e : (console.warn("WARNING: OrbitControls.js encountered an unknown camera type - dolly/zoom disabled."), this.enableZoom = !1);
139
- }
140
- _dollyIn(e) {
141
- this.object.isPerspectiveCamera || this.object.isOrthographicCamera ? this._scale *= e : (console.warn("WARNING: OrbitControls.js encountered an unknown camera type - dolly/zoom disabled."), this.enableZoom = !1);
142
- }
143
- _updateZoomParameters(e, t) {
144
- if (!this.zoomToCursor) return;
145
- this._performCursorZoom = !0;
146
- let n = this.domElement.getBoundingClientRect(), r = e - n.left, i = t - n.top, a = n.width, o = n.height;
147
- this._mouse.x = r / a * 2 - 1, this._mouse.y = -(i / o) * 2 + 1, this._dollyDirection.set(this._mouse.x, this._mouse.y, 1).unproject(this.object).sub(this.object.position).normalize();
148
- }
149
- _clampDistance(e) {
150
- return Math.max(this.minDistance, Math.min(this.maxDistance, e));
151
- }
152
- _handleMouseDownRotate(e) {
153
- this._rotateStart.set(e.clientX, e.clientY);
154
- }
155
- _handleMouseDownDolly(e) {
156
- this._updateZoomParameters(e.clientX, e.clientX), this._dollyStart.set(e.clientX, e.clientY);
157
- }
158
- _handleMouseDownPan(e) {
159
- this._panStart.set(e.clientX, e.clientY);
160
- }
161
- _handleMouseMoveRotate(e) {
162
- this._rotateEnd.set(e.clientX, e.clientY), this._rotateDelta.subVectors(this._rotateEnd, this._rotateStart).multiplyScalar(this.rotateSpeed);
163
- let t = this.domElement;
164
- this._rotateLeft(U * this._rotateDelta.x / t.clientHeight), this._rotateUp(U * this._rotateDelta.y / t.clientHeight), this._rotateStart.copy(this._rotateEnd), this.update();
165
- }
166
- _handleMouseMoveDolly(e) {
167
- this._dollyEnd.set(e.clientX, e.clientY), this._dollyDelta.subVectors(this._dollyEnd, this._dollyStart), this._dollyDelta.y > 0 ? this._dollyOut(this._getZoomScale(this._dollyDelta.y)) : this._dollyDelta.y < 0 && this._dollyIn(this._getZoomScale(this._dollyDelta.y)), this._dollyStart.copy(this._dollyEnd), this.update();
168
- }
169
- _handleMouseMovePan(e) {
170
- this._panEnd.set(e.clientX, e.clientY), this._panDelta.subVectors(this._panEnd, this._panStart).multiplyScalar(this.panSpeed), this._pan(this._panDelta.x, this._panDelta.y), this._panStart.copy(this._panEnd), this.update();
171
- }
172
- _handleMouseWheel(e) {
173
- this._updateZoomParameters(e.clientX, e.clientY), e.deltaY < 0 ? this._dollyIn(this._getZoomScale(e.deltaY)) : e.deltaY > 0 && this._dollyOut(this._getZoomScale(e.deltaY)), this.update();
174
- }
175
- _handleKeyDown(e) {
176
- let t = !1;
177
- switch (e.code) {
178
- case this.keys.UP:
179
- e.ctrlKey || e.metaKey || e.shiftKey ? this.enableRotate && this._rotateUp(U * this.keyRotateSpeed / this.domElement.clientHeight) : this.enablePan && this._pan(0, this.keyPanSpeed), t = !0;
180
- break;
181
- case this.keys.BOTTOM:
182
- e.ctrlKey || e.metaKey || e.shiftKey ? this.enableRotate && this._rotateUp(-U * this.keyRotateSpeed / this.domElement.clientHeight) : this.enablePan && this._pan(0, -this.keyPanSpeed), t = !0;
183
- break;
184
- case this.keys.LEFT:
185
- e.ctrlKey || e.metaKey || e.shiftKey ? this.enableRotate && this._rotateLeft(U * this.keyRotateSpeed / this.domElement.clientHeight) : this.enablePan && this._pan(this.keyPanSpeed, 0), t = !0;
186
- break;
187
- case this.keys.RIGHT:
188
- e.ctrlKey || e.metaKey || e.shiftKey ? this.enableRotate && this._rotateLeft(-U * this.keyRotateSpeed / this.domElement.clientHeight) : this.enablePan && this._pan(-this.keyPanSpeed, 0), t = !0;
189
- break;
190
- }
191
- t && (e.preventDefault(), this.update());
192
- }
193
- _handleTouchStartRotate(e) {
194
- if (this._pointers.length === 1) this._rotateStart.set(e.pageX, e.pageY);
195
- else {
196
- let t = this._getSecondPointerPosition(e), n = .5 * (e.pageX + t.x), r = .5 * (e.pageY + t.y);
197
- this._rotateStart.set(n, r);
198
- }
199
- }
200
- _handleTouchStartPan(e) {
201
- if (this._pointers.length === 1) this._panStart.set(e.pageX, e.pageY);
202
- else {
203
- let t = this._getSecondPointerPosition(e), n = .5 * (e.pageX + t.x), r = .5 * (e.pageY + t.y);
204
- this._panStart.set(n, r);
205
- }
206
- }
207
- _handleTouchStartDolly(e) {
208
- let t = this._getSecondPointerPosition(e), n = e.pageX - t.x, r = e.pageY - t.y, i = Math.sqrt(n * n + r * r);
209
- this._dollyStart.set(0, i);
210
- }
211
- _handleTouchStartDollyPan(e) {
212
- this.enableZoom && this._handleTouchStartDolly(e), this.enablePan && this._handleTouchStartPan(e);
213
- }
214
- _handleTouchStartDollyRotate(e) {
215
- this.enableZoom && this._handleTouchStartDolly(e), this.enableRotate && this._handleTouchStartRotate(e);
216
- }
217
- _handleTouchMoveRotate(e) {
218
- if (this._pointers.length == 1) this._rotateEnd.set(e.pageX, e.pageY);
219
- else {
220
- let t = this._getSecondPointerPosition(e), n = .5 * (e.pageX + t.x), r = .5 * (e.pageY + t.y);
221
- this._rotateEnd.set(n, r);
222
- }
223
- this._rotateDelta.subVectors(this._rotateEnd, this._rotateStart).multiplyScalar(this.rotateSpeed);
224
- let t = this.domElement;
225
- this._rotateLeft(U * this._rotateDelta.x / t.clientHeight), this._rotateUp(U * this._rotateDelta.y / t.clientHeight), this._rotateStart.copy(this._rotateEnd);
226
- }
227
- _handleTouchMovePan(e) {
228
- if (this._pointers.length === 1) this._panEnd.set(e.pageX, e.pageY);
229
- else {
230
- let t = this._getSecondPointerPosition(e), n = .5 * (e.pageX + t.x), r = .5 * (e.pageY + t.y);
231
- this._panEnd.set(n, r);
232
- }
233
- this._panDelta.subVectors(this._panEnd, this._panStart).multiplyScalar(this.panSpeed), this._pan(this._panDelta.x, this._panDelta.y), this._panStart.copy(this._panEnd);
234
- }
235
- _handleTouchMoveDolly(e) {
236
- let t = this._getSecondPointerPosition(e), n = e.pageX - t.x, r = e.pageY - t.y, i = Math.sqrt(n * n + r * r);
237
- this._dollyEnd.set(0, i), this._dollyDelta.set(0, (this._dollyEnd.y / this._dollyStart.y) ** +this.zoomSpeed), this._dollyOut(this._dollyDelta.y), this._dollyStart.copy(this._dollyEnd);
238
- let a = (e.pageX + t.x) * .5, o = (e.pageY + t.y) * .5;
239
- this._updateZoomParameters(a, o);
240
- }
241
- _handleTouchMoveDollyPan(e) {
242
- this.enableZoom && this._handleTouchMoveDolly(e), this.enablePan && this._handleTouchMovePan(e);
243
- }
244
- _handleTouchMoveDollyRotate(e) {
245
- this.enableZoom && this._handleTouchMoveDolly(e), this.enableRotate && this._handleTouchMoveRotate(e);
246
- }
247
- _addPointer(e) {
248
- this._pointers.push(e.pointerId);
249
- }
250
- _removePointer(e) {
251
- delete this._pointerPositions[e.pointerId];
252
- for (let t = 0; t < this._pointers.length; t++) if (this._pointers[t] == e.pointerId) {
253
- this._pointers.splice(t, 1);
254
- return;
255
- }
256
- }
257
- _isTrackingPointer(e) {
258
- for (let t = 0; t < this._pointers.length; t++) if (this._pointers[t] == e.pointerId) return !0;
259
- return !1;
260
- }
261
- _trackPointer(e) {
262
- let t = this._pointerPositions[e.pointerId];
263
- t === void 0 && (t = new u(), this._pointerPositions[e.pointerId] = t), t.set(e.pageX, e.pageY);
264
- }
265
- _getSecondPointerPosition(e) {
266
- let t = e.pointerId === this._pointers[0] ? this._pointers[1] : this._pointers[0];
267
- return this._pointerPositions[t];
268
- }
269
- _customWheelEvent(e) {
270
- let t = e.deltaMode, n = {
271
- clientX: e.clientX,
272
- clientY: e.clientY,
273
- deltaY: e.deltaY
274
- };
275
- switch (t) {
276
- case 1:
277
- n.deltaY *= 16;
278
- break;
279
- case 2:
280
- n.deltaY *= 100;
281
- break;
282
- }
283
- return e.ctrlKey && !this._controlActive && (n.deltaY *= 10), n;
284
- }
285
- };
286
- function ze(e) {
287
- this.enabled !== !1 && (this._pointers.length === 0 && (this.domElement.setPointerCapture(e.pointerId), this.domElement.addEventListener("pointermove", this._onPointerMove), this.domElement.addEventListener("pointerup", this._onPointerUp)), !this._isTrackingPointer(e) && (this._addPointer(e), e.pointerType === "touch" ? this._onTouchStart(e) : this._onMouseDown(e)));
288
- }
289
- function Be(e) {
290
- this.enabled !== !1 && (e.pointerType === "touch" ? this._onTouchMove(e) : this._onMouseMove(e));
291
- }
292
- function Ve(e) {
293
- switch (this._removePointer(e), this._pointers.length) {
294
- case 0:
295
- this.domElement.releasePointerCapture(e.pointerId), this.domElement.removeEventListener("pointermove", this._onPointerMove), this.domElement.removeEventListener("pointerup", this._onPointerUp), this.dispatchEvent(Fe), this.state = W.NONE;
296
- break;
297
- case 1:
298
- let t = this._pointers[0], n = this._pointerPositions[t];
299
- this._onTouchStart({
300
- pointerId: t,
301
- pageX: n.x,
302
- pageY: n.y
303
- });
304
- break;
305
- }
306
- }
307
- function He(e) {
308
- let t;
309
- switch (e.button) {
310
- case 0:
311
- t = this.mouseButtons.LEFT;
312
- break;
313
- case 1:
314
- t = this.mouseButtons.MIDDLE;
315
- break;
316
- case 2:
317
- t = this.mouseButtons.RIGHT;
318
- break;
319
- default: t = -1;
320
- }
321
- switch (t) {
322
- case F.DOLLY:
323
- if (this.enableZoom === !1) return;
324
- this._handleMouseDownDolly(e), this.state = W.DOLLY;
325
- break;
326
- case F.ROTATE:
327
- if (e.ctrlKey || e.metaKey || e.shiftKey) {
328
- if (this.enablePan === !1) return;
329
- this._handleMouseDownPan(e), this.state = W.PAN;
330
- } else {
331
- if (this.enableRotate === !1) return;
332
- this._handleMouseDownRotate(e), this.state = W.ROTATE;
333
- }
334
- break;
335
- case F.PAN:
336
- if (e.ctrlKey || e.metaKey || e.shiftKey) {
337
- if (this.enableRotate === !1) return;
338
- this._handleMouseDownRotate(e), this.state = W.ROTATE;
339
- } else {
340
- if (this.enablePan === !1) return;
341
- this._handleMouseDownPan(e), this.state = W.PAN;
342
- }
343
- break;
344
- default: this.state = W.NONE;
345
- }
346
- this.state !== W.NONE && this.dispatchEvent(B);
347
- }
348
- function Ue(e) {
349
- switch (this.state) {
350
- case W.ROTATE:
351
- if (this.enableRotate === !1) return;
352
- this._handleMouseMoveRotate(e);
353
- break;
354
- case W.DOLLY:
355
- if (this.enableZoom === !1) return;
356
- this._handleMouseMoveDolly(e);
357
- break;
358
- case W.PAN:
359
- if (this.enablePan === !1) return;
360
- this._handleMouseMovePan(e);
361
- break;
362
- }
363
- }
364
- function We(e) {
365
- this.enabled === !1 || this.enableZoom === !1 || this.state !== W.NONE || (e.preventDefault(), this.dispatchEvent(B), this._handleMouseWheel(this._customWheelEvent(e)), this.dispatchEvent(Fe));
366
- }
367
- function Ge(e) {
368
- this.enabled !== !1 && this._handleKeyDown(e);
369
- }
370
- function Ke(e) {
371
- switch (this._trackPointer(e), this._pointers.length) {
372
- case 1:
373
- switch (this.touches.ONE) {
374
- case c.ROTATE:
375
- if (this.enableRotate === !1) return;
376
- this._handleTouchStartRotate(e), this.state = W.TOUCH_ROTATE;
377
- break;
378
- case c.PAN:
379
- if (this.enablePan === !1) return;
380
- this._handleTouchStartPan(e), this.state = W.TOUCH_PAN;
381
- break;
382
- default: this.state = W.NONE;
383
- }
384
- break;
385
- case 2:
386
- switch (this.touches.TWO) {
387
- case c.DOLLY_PAN:
388
- if (this.enableZoom === !1 && this.enablePan === !1) return;
389
- this._handleTouchStartDollyPan(e), this.state = W.TOUCH_DOLLY_PAN;
390
- break;
391
- case c.DOLLY_ROTATE:
392
- if (this.enableZoom === !1 && this.enableRotate === !1) return;
393
- this._handleTouchStartDollyRotate(e), this.state = W.TOUCH_DOLLY_ROTATE;
394
- break;
395
- default: this.state = W.NONE;
396
- }
397
- break;
398
- default: this.state = W.NONE;
399
- }
400
- this.state !== W.NONE && this.dispatchEvent(B);
401
- }
402
- function qe(e) {
403
- switch (this._trackPointer(e), this.state) {
404
- case W.TOUCH_ROTATE:
405
- if (this.enableRotate === !1) return;
406
- this._handleTouchMoveRotate(e), this.update();
407
- break;
408
- case W.TOUCH_PAN:
409
- if (this.enablePan === !1) return;
410
- this._handleTouchMovePan(e), this.update();
411
- break;
412
- case W.TOUCH_DOLLY_PAN:
413
- if (this.enableZoom === !1 && this.enablePan === !1) return;
414
- this._handleTouchMoveDollyPan(e), this.update();
415
- break;
416
- case W.TOUCH_DOLLY_ROTATE:
417
- if (this.enableZoom === !1 && this.enableRotate === !1) return;
418
- this._handleTouchMoveDollyRotate(e), this.update();
419
- break;
420
- default: this.state = W.NONE;
421
- }
422
- }
423
- function Je(e) {
424
- this.enabled !== !1 && e.preventDefault();
425
- }
426
- function Ye(e) {
427
- e.key === "Control" && (this._controlActive = !0, this.domElement.getRootNode().addEventListener("keyup", this._interceptControlUp, {
428
- passive: !0,
429
- capture: !0
430
- }));
431
- }
432
- function Xe(e) {
433
- e.key === "Control" && (this._controlActive = !1, this.domElement.getRootNode().removeEventListener("keyup", this._interceptControlUp, {
434
- passive: !0,
435
- capture: !0
436
- }));
437
- }
438
- //#endregion
439
- //#region ../../node_modules/.pnpm/three@0.174.0/node_modules/three/examples/jsm/loaders/MTLLoader.js
440
- var Ze = class extends o {
441
- constructor(e) {
442
- super(e);
443
- }
444
- load(e, t, n, r) {
445
- let i = this, a = this.path === "" ? se.extractUrlBase(e) : this.path, o = new ve(this.manager);
446
- o.setPath(this.path), o.setRequestHeader(this.requestHeader), o.setWithCredentials(this.withCredentials), o.load(e, function(n) {
447
- try {
448
- t(i.parse(n, a));
449
- } catch (t) {
450
- r ? r(t) : console.error(t), i.manager.itemError(e);
451
- }
452
- }, n, r);
453
- }
454
- setMaterialOptions(e) {
455
- return this.materialOptions = e, this;
456
- }
457
- parse(e, t) {
458
- let n = e.split("\n"), r = {}, i = /\s+/, a = {};
459
- for (let e = 0; e < n.length; e++) {
460
- let t = n[e];
461
- if (t = t.trim(), t.length === 0 || t.charAt(0) === "#") continue;
462
- let o = t.indexOf(" "), s = o >= 0 ? t.substring(0, o) : t;
463
- s = s.toLowerCase();
464
- let c = o >= 0 ? t.substring(o + 1) : "";
465
- if (c = c.trim(), s === "newmtl") r = { name: c }, a[c] = r;
466
- else if (s === "ka" || s === "kd" || s === "ks" || s === "ke") {
467
- let e = c.split(i, 3);
468
- r[s] = [
469
- parseFloat(e[0]),
470
- parseFloat(e[1]),
471
- parseFloat(e[2])
472
- ];
473
- } else r[s] = c;
474
- }
475
- let o = new Qe(this.resourcePath || t, this.materialOptions);
476
- return o.setCrossOrigin(this.crossOrigin), o.setManager(this.manager), o.setMaterials(a), o;
477
- }
478
- }, Qe = class {
479
- constructor(e = "", t = {}) {
480
- this.baseUrl = e, this.options = t, this.materialsInfo = {}, this.materials = {}, this.materialsArray = [], this.nameLookup = {}, this.crossOrigin = "anonymous", this.side = this.options.side === void 0 ? 0 : this.options.side, this.wrap = this.options.wrap === void 0 ? xe : this.options.wrap;
481
- }
482
- setCrossOrigin(e) {
483
- return this.crossOrigin = e, this;
484
- }
485
- setManager(e) {
486
- this.manager = e;
487
- }
488
- setMaterials(e) {
489
- this.materialsInfo = this.convert(e), this.materials = {}, this.materialsArray = [], this.nameLookup = {};
490
- }
491
- convert(e) {
492
- if (!this.options) return e;
493
- let t = {};
494
- for (let n in e) {
495
- let r = e[n], i = {};
496
- t[n] = i;
497
- for (let e in r) {
498
- let t = !0, n = r[e], a = e.toLowerCase();
499
- switch (a) {
500
- case "kd":
501
- case "ka":
502
- case "ks":
503
- this.options && this.options.normalizeRGB && (n = [
504
- n[0] / 255,
505
- n[1] / 255,
506
- n[2] / 255
507
- ]), this.options && this.options.ignoreZeroRGBs && n[0] === 0 && n[1] === 0 && n[2] === 0 && (t = !1);
508
- break;
509
- default: break;
510
- }
511
- t && (i[a] = n);
512
- }
513
- }
514
- return t;
515
- }
516
- preload() {
517
- for (let e in this.materialsInfo) this.create(e);
518
- }
519
- getIndex(e) {
520
- return this.nameLookup[e];
521
- }
522
- getAsArray() {
523
- let e = 0;
524
- for (let t in this.materialsInfo) this.materialsArray[e] = this.create(t), this.nameLookup[t] = e, e++;
525
- return this.materialsArray;
526
- }
527
- create(e) {
528
- return this.materials[e] === void 0 && this.createMaterial_(e), this.materials[e];
529
- }
530
- createMaterial_(e) {
531
- let t = this, n = this.materialsInfo[e], r = {
532
- name: e,
533
- side: this.side
534
- };
535
- function i(e, t) {
536
- return typeof t != "string" || t === "" ? "" : /^https?:\/\//i.test(t) ? t : e + t;
537
- }
538
- function a(e, n) {
539
- if (r[e]) return;
540
- let a = t.getTextureParams(n, r), o = t.loadTexture(i(t.baseUrl, a.url));
541
- o.repeat.copy(a.scale), o.offset.copy(a.offset), o.wrapS = t.wrap, o.wrapT = t.wrap, (e === "map" || e === "emissiveMap") && (o.colorSpace = I), r[e] = o;
542
- }
543
- for (let e in n) {
544
- let t = n[e], i;
545
- if (t !== "") switch (e.toLowerCase()) {
546
- case "kd":
547
- r.color = S.toWorkingColorSpace(new p().fromArray(t), I);
548
- break;
549
- case "ks":
550
- r.specular = S.toWorkingColorSpace(new p().fromArray(t), I);
551
- break;
552
- case "ke":
553
- r.emissive = S.toWorkingColorSpace(new p().fromArray(t), I);
554
- break;
555
- case "map_kd":
556
- a("map", t);
557
- break;
558
- case "map_ks":
559
- a("specularMap", t);
560
- break;
561
- case "map_ke":
562
- a("emissiveMap", t);
563
- break;
564
- case "norm":
565
- a("normalMap", t);
566
- break;
567
- case "map_bump":
568
- case "bump":
569
- a("bumpMap", t);
570
- break;
571
- case "disp":
572
- a("displacementMap", t);
573
- break;
574
- case "map_d":
575
- a("alphaMap", t), r.transparent = !0;
576
- break;
577
- case "ns":
578
- r.shininess = parseFloat(t);
579
- break;
580
- case "d":
581
- i = parseFloat(t), i < 1 && (r.opacity = i, r.transparent = !0);
582
- break;
583
- case "tr":
584
- i = parseFloat(t), this.options && this.options.invertTrProperty && (i = 1 - i), i > 0 && (r.opacity = 1 - i, r.transparent = !0);
585
- break;
586
- default: break;
587
- }
588
- }
589
- return this.materials[e] = new N(r), this.materials[e];
590
- }
591
- getTextureParams(e, t) {
592
- let n = {
593
- scale: new u(1, 1),
594
- offset: new u(0, 0)
595
- }, r = e.split(/\s+/), i;
596
- return i = r.indexOf("-bm"), i >= 0 && (t.bumpScale = parseFloat(r[i + 1]), r.splice(i, 2)), i = r.indexOf("-mm"), i >= 0 && (t.displacementBias = parseFloat(r[i + 1]), t.displacementScale = parseFloat(r[i + 2]), r.splice(i, 3)), i = r.indexOf("-s"), i >= 0 && (n.scale.set(parseFloat(r[i + 1]), parseFloat(r[i + 2])), r.splice(i, 4)), i = r.indexOf("-o"), i >= 0 && (n.offset.set(parseFloat(r[i + 1]), parseFloat(r[i + 2])), r.splice(i, 4)), n.url = r.join(" ").trim(), n;
597
- }
598
- loadTexture(e, t, n, r, i) {
599
- let a = this.manager === void 0 ? g : this.manager, o = a.getHandler(e);
600
- o === null && (o = new x(a)), o.setCrossOrigin && o.setCrossOrigin(this.crossOrigin);
601
- let s = o.load(e, n, r, i);
602
- return t !== void 0 && (s.mapping = t), s;
603
- }
604
- }, $e = /^[og]\s*(.+)?/, et = /^mtllib /, tt = /^usemtl /, nt = /^usemap /, rt = /\s+/, it = new l(), at = new l(), ot = new l(), st = new l(), K = new l(), q = new p();
605
- function ct() {
606
- let e = {
607
- objects: [],
608
- object: {},
609
- vertices: [],
610
- normals: [],
611
- colors: [],
612
- uvs: [],
613
- materials: {},
614
- materialLibraries: [],
615
- startObject: function(e, t) {
616
- if (this.object && this.object.fromDeclaration === !1) {
617
- this.object.name = e, this.object.fromDeclaration = t !== !1;
618
- return;
619
- }
620
- let n = this.object && typeof this.object.currentMaterial == "function" ? this.object.currentMaterial() : void 0;
621
- if (this.object && typeof this.object._finalize == "function" && this.object._finalize(!0), this.object = {
622
- name: e || "",
623
- fromDeclaration: t !== !1,
624
- geometry: {
625
- vertices: [],
626
- normals: [],
627
- colors: [],
628
- uvs: [],
629
- hasUVIndices: !1
630
- },
631
- materials: [],
632
- smooth: !0,
633
- startMaterial: function(e, t) {
634
- let n = this._finalize(!1);
635
- n && (n.inherited || n.groupCount <= 0) && this.materials.splice(n.index, 1);
636
- let r = {
637
- index: this.materials.length,
638
- name: e || "",
639
- mtllib: Array.isArray(t) && t.length > 0 ? t[t.length - 1] : "",
640
- smooth: n === void 0 ? this.smooth : n.smooth,
641
- groupStart: n === void 0 ? 0 : n.groupEnd,
642
- groupEnd: -1,
643
- groupCount: -1,
644
- inherited: !1,
645
- clone: function(e) {
646
- let t = {
647
- index: typeof e == "number" ? e : this.index,
648
- name: this.name,
649
- mtllib: this.mtllib,
650
- smooth: this.smooth,
651
- groupStart: 0,
652
- groupEnd: -1,
653
- groupCount: -1,
654
- inherited: !1
655
- };
656
- return t.clone = this.clone.bind(t), t;
657
- }
658
- };
659
- return this.materials.push(r), r;
660
- },
661
- currentMaterial: function() {
662
- if (this.materials.length > 0) return this.materials[this.materials.length - 1];
663
- },
664
- _finalize: function(e) {
665
- let t = this.currentMaterial();
666
- if (t && t.groupEnd === -1 && (t.groupEnd = this.geometry.vertices.length / 3, t.groupCount = t.groupEnd - t.groupStart, t.inherited = !1), e && this.materials.length > 1) for (let e = this.materials.length - 1; e >= 0; e--) this.materials[e].groupCount <= 0 && this.materials.splice(e, 1);
667
- return e && this.materials.length === 0 && this.materials.push({
668
- name: "",
669
- smooth: this.smooth
670
- }), t;
671
- }
672
- }, n && n.name && typeof n.clone == "function") {
673
- let e = n.clone(0);
674
- e.inherited = !0, this.object.materials.push(e);
675
- }
676
- this.objects.push(this.object);
677
- },
678
- finalize: function() {
679
- this.object && typeof this.object._finalize == "function" && this.object._finalize(!0);
680
- },
681
- parseVertexIndex: function(e, t) {
682
- let n = parseInt(e, 10);
683
- return (n >= 0 ? n - 1 : n + t / 3) * 3;
684
- },
685
- parseNormalIndex: function(e, t) {
686
- let n = parseInt(e, 10);
687
- return (n >= 0 ? n - 1 : n + t / 3) * 3;
688
- },
689
- parseUVIndex: function(e, t) {
690
- let n = parseInt(e, 10);
691
- return (n >= 0 ? n - 1 : n + t / 2) * 2;
692
- },
693
- addVertex: function(e, t, n) {
694
- let r = this.vertices, i = this.object.geometry.vertices;
695
- i.push(r[e + 0], r[e + 1], r[e + 2]), i.push(r[t + 0], r[t + 1], r[t + 2]), i.push(r[n + 0], r[n + 1], r[n + 2]);
696
- },
697
- addVertexPoint: function(e) {
698
- let t = this.vertices;
699
- this.object.geometry.vertices.push(t[e + 0], t[e + 1], t[e + 2]);
700
- },
701
- addVertexLine: function(e) {
702
- let t = this.vertices;
703
- this.object.geometry.vertices.push(t[e + 0], t[e + 1], t[e + 2]);
704
- },
705
- addNormal: function(e, t, n) {
706
- let r = this.normals, i = this.object.geometry.normals;
707
- i.push(r[e + 0], r[e + 1], r[e + 2]), i.push(r[t + 0], r[t + 1], r[t + 2]), i.push(r[n + 0], r[n + 1], r[n + 2]);
708
- },
709
- addFaceNormal: function(e, t, n) {
710
- let r = this.vertices, i = this.object.geometry.normals;
711
- it.fromArray(r, e), at.fromArray(r, t), ot.fromArray(r, n), K.subVectors(ot, at), st.subVectors(it, at), K.cross(st), K.normalize(), i.push(K.x, K.y, K.z), i.push(K.x, K.y, K.z), i.push(K.x, K.y, K.z);
712
- },
713
- addColor: function(e, t, n) {
714
- let r = this.colors, i = this.object.geometry.colors;
715
- r[e] !== void 0 && i.push(r[e + 0], r[e + 1], r[e + 2]), r[t] !== void 0 && i.push(r[t + 0], r[t + 1], r[t + 2]), r[n] !== void 0 && i.push(r[n + 0], r[n + 1], r[n + 2]);
716
- },
717
- addUV: function(e, t, n) {
718
- let r = this.uvs, i = this.object.geometry.uvs;
719
- i.push(r[e + 0], r[e + 1]), i.push(r[t + 0], r[t + 1]), i.push(r[n + 0], r[n + 1]);
720
- },
721
- addDefaultUV: function() {
722
- let e = this.object.geometry.uvs;
723
- e.push(0, 0), e.push(0, 0), e.push(0, 0);
724
- },
725
- addUVLine: function(e) {
726
- let t = this.uvs;
727
- this.object.geometry.uvs.push(t[e + 0], t[e + 1]);
728
- },
729
- addFace: function(e, t, n, r, i, a, o, s, c) {
730
- let l = this.vertices.length, u = this.parseVertexIndex(e, l), d = this.parseVertexIndex(t, l), f = this.parseVertexIndex(n, l);
731
- if (this.addVertex(u, d, f), this.addColor(u, d, f), o !== void 0 && o !== "") {
732
- let e = this.normals.length;
733
- u = this.parseNormalIndex(o, e), d = this.parseNormalIndex(s, e), f = this.parseNormalIndex(c, e), this.addNormal(u, d, f);
734
- } else this.addFaceNormal(u, d, f);
735
- if (r !== void 0 && r !== "") {
736
- let e = this.uvs.length;
737
- u = this.parseUVIndex(r, e), d = this.parseUVIndex(i, e), f = this.parseUVIndex(a, e), this.addUV(u, d, f), this.object.geometry.hasUVIndices = !0;
738
- } else this.addDefaultUV();
739
- },
740
- addPointGeometry: function(e) {
741
- this.object.geometry.type = "Points";
742
- let t = this.vertices.length;
743
- for (let n = 0, r = e.length; n < r; n++) {
744
- let r = this.parseVertexIndex(e[n], t);
745
- this.addVertexPoint(r), this.addColor(r);
746
- }
747
- },
748
- addLineGeometry: function(e, t) {
749
- this.object.geometry.type = "Line";
750
- let n = this.vertices.length, r = this.uvs.length;
751
- for (let t = 0, r = e.length; t < r; t++) this.addVertexLine(this.parseVertexIndex(e[t], n));
752
- for (let e = 0, n = t.length; e < n; e++) this.addUVLine(this.parseUVIndex(t[e], r));
753
- }
754
- };
755
- return e.startObject("", !1), e;
756
- }
757
- var lt = class extends o {
758
- constructor(e) {
759
- super(e), this.materials = null;
760
- }
761
- load(e, t, n, r) {
762
- let i = this, a = new ve(this.manager);
763
- a.setPath(this.path), a.setRequestHeader(this.requestHeader), a.setWithCredentials(this.withCredentials), a.load(e, function(n) {
764
- try {
765
- t(i.parse(n));
766
- } catch (t) {
767
- r ? r(t) : console.error(t), i.manager.itemError(e);
768
- }
769
- }, n, r);
770
- }
771
- setMaterials(e) {
772
- return this.materials = e, this;
773
- }
774
- parse(e) {
775
- let t = new ct();
776
- e.indexOf("\r\n") !== -1 && (e = e.replace(/\r\n/g, "\n")), e.indexOf("\\\n") !== -1 && (e = e.replace(/\\\n/g, ""));
777
- let n = e.split("\n"), r = [];
778
- for (let e = 0, i = n.length; e < i; e++) {
779
- let i = n[e].trimStart();
780
- if (i.length === 0) continue;
781
- let a = i.charAt(0);
782
- if (a !== "#") if (a === "v") {
783
- let e = i.split(rt);
784
- switch (e[0]) {
785
- case "v":
786
- t.vertices.push(parseFloat(e[1]), parseFloat(e[2]), parseFloat(e[3])), e.length >= 7 ? (q.setRGB(parseFloat(e[4]), parseFloat(e[5]), parseFloat(e[6]), I), t.colors.push(q.r, q.g, q.b)) : t.colors.push(void 0, void 0, void 0);
787
- break;
788
- case "vn":
789
- t.normals.push(parseFloat(e[1]), parseFloat(e[2]), parseFloat(e[3]));
790
- break;
791
- case "vt":
792
- t.uvs.push(parseFloat(e[1]), parseFloat(e[2]));
793
- break;
794
- }
795
- } else if (a === "f") {
796
- let e = i.slice(1).trim().split(rt), n = [];
797
- for (let t = 0, r = e.length; t < r; t++) {
798
- let r = e[t];
799
- if (r.length > 0) {
800
- let e = r.split("/");
801
- n.push(e);
802
- }
803
- }
804
- let r = n[0];
805
- for (let e = 1, i = n.length - 1; e < i; e++) {
806
- let i = n[e], a = n[e + 1];
807
- t.addFace(r[0], i[0], a[0], r[1], i[1], a[1], r[2], i[2], a[2]);
808
- }
809
- } else if (a === "l") {
810
- let e = i.substring(1).trim().split(" "), n = [], r = [];
811
- if (i.indexOf("/") === -1) n = e;
812
- else for (let t = 0, i = e.length; t < i; t++) {
813
- let i = e[t].split("/");
814
- i[0] !== "" && n.push(i[0]), i[1] !== "" && r.push(i[1]);
815
- }
816
- t.addLineGeometry(n, r);
817
- } else if (a === "p") {
818
- let e = i.slice(1).trim().split(" ");
819
- t.addPointGeometry(e);
820
- } else if ((r = $e.exec(i)) !== null) {
821
- let e = (" " + r[0].slice(1).trim()).slice(1);
822
- t.startObject(e);
823
- } else if (tt.test(i)) t.object.startMaterial(i.substring(7).trim(), t.materialLibraries);
824
- else if (et.test(i)) t.materialLibraries.push(i.substring(7).trim());
825
- else if (nt.test(i)) console.warn("THREE.OBJLoader: Rendering identifier \"usemap\" not supported. Textures must be defined in MTL files.");
826
- else if (a === "s") {
827
- if (r = i.split(" "), r.length > 1) {
828
- let e = r[1].trim().toLowerCase();
829
- t.object.smooth = e !== "0" && e !== "off";
830
- } else t.object.smooth = !0;
831
- let e = t.object.currentMaterial();
832
- e && (e.smooth = t.object.smooth);
833
- } else {
834
- if (i === "\0") continue;
835
- console.warn("THREE.OBJLoader: Unexpected line: \"" + i + "\"");
836
- }
837
- }
838
- t.finalize();
839
- let i = new T();
840
- if (i.materialLibraries = [].concat(t.materialLibraries), !(t.objects.length === 1 && t.objects[0].geometry.vertices.length === 0)) for (let e = 0, n = t.objects.length; e < n; e++) {
841
- let n = t.objects[e], r = n.geometry, a = n.materials, o = r.type === "Line", s = r.type === "Points", c = !1;
842
- if (r.vertices.length === 0) continue;
843
- let l = new we();
844
- l.setAttribute("position", new h(r.vertices, 3)), r.normals.length > 0 && l.setAttribute("normal", new h(r.normals, 3)), r.colors.length > 0 && (c = !0, l.setAttribute("color", new h(r.colors, 3))), r.hasUVIndices === !0 && l.setAttribute("uv", new h(r.uvs, 2));
845
- let u = [];
846
- for (let e = 0, n = a.length; e < n; e++) {
847
- let n = a[e], r = n.name + "_" + n.smooth + "_" + c, i = t.materials[r];
848
- if (this.materials !== null) {
849
- if (i = this.materials.create(n.name), o && i && !(i instanceof E)) {
850
- let e = new E();
851
- he.prototype.copy.call(e, i), e.color.copy(i.color), i = e;
852
- } else if (s && i && !(i instanceof k)) {
853
- let e = new k({
854
- size: 10,
855
- sizeAttenuation: !1
856
- });
857
- he.prototype.copy.call(e, i), e.color.copy(i.color), e.map = i.map, i = e;
858
- }
859
- }
860
- i === void 0 && (i = o ? new E() : s ? new k({
861
- size: 1,
862
- sizeAttenuation: !1
863
- }) : new N(), i.name = n.name, i.flatShading = !n.smooth, i.vertexColors = c, t.materials[r] = i), u.push(i);
864
- }
865
- let d;
866
- if (u.length > 1) {
867
- for (let e = 0, t = a.length; e < t; e++) {
868
- let t = a[e];
869
- l.addGroup(t.groupStart, t.groupCount, e);
870
- }
871
- d = o ? new y(l, u) : s ? new j(l, u) : new D(l, u);
872
- } else d = o ? new y(l, u[0]) : s ? new j(l, u[0]) : new D(l, u[0]);
873
- d.name = n.name, i.add(d);
874
- }
875
- else if (t.vertices.length > 0) {
876
- let e = new k({
877
- size: 1,
878
- sizeAttenuation: !1
879
- }), n = new we();
880
- n.setAttribute("position", new h(t.vertices, 3)), t.colors.length > 0 && t.colors[0] !== void 0 && (n.setAttribute("color", new h(t.colors, 3)), e.vertexColors = !0);
881
- let r = new j(n, e);
882
- i.add(r);
883
- }
884
- return i;
885
- }
886
- }, J = class {
887
- constructor(e, t, n, r) {
888
- this.x = void 0, this.y = void 0, this.width = void 0, this.height = void 0, this.finalX = void 0, this.finalY = void 0, this.x = e, this.y = t, this.width = n, this.height = r, this.finalX = e + n, this.finalY = t + r;
889
- }
890
- set(e, t, n, r, i, a) {
891
- return this.x = e, this.y = t, this.finalX = n, this.finalY = r, this.width = i, this.height = a, this;
892
- }
893
- fits(e) {
894
- var t = e.image.width, n = e.image.height;
895
- return t <= this.width && n <= this.height;
896
- }
897
- fitsPerfectly(e) {
898
- var t = e.image.width, n = e.image.height;
899
- return t == this.width && n == this.height;
900
- }
901
- overlaps(e) {
902
- return this.x < e.x + e.width && this.x + this.width > e.x && this.y < e.y + e.height && this.y + this.height > e.y;
903
- }
904
- }, ut = class {
905
- constructor(e, t, n, r) {
906
- this.startU = e, this.endU = t, this.startV = n, this.endV = r;
907
- }
908
- }, Y = class {
909
- constructor(e, t, n, r) {
910
- this.children = e, this.rectangle = t, this.textureName = n, this.upperNode = r;
911
- }
912
- }, dt = class {
913
- constructor(e) {
914
- if (this.MAX_TEXTURE_SIZE = void 0, this.dataURLs = void 0, this.textureCount = void 0, this.maxHeight = void 0, this.maxWidth = void 0, this.canvas = void 0, this.textureCache = void 0, this.node = void 0, this.textureOffsets = void 0, this.allNodes = void 0, this.context = void 0, this.ranges = void 0, this.mergedTexture = void 0, !(!e || !e.size) && (this.MAX_TEXTURE_SIZE = 4096, e)) {
915
- this.dataURLs = /* @__PURE__ */ new Map();
916
- for (var t of e.keys()) {
917
- var n = e.get(t);
918
- if (n instanceof w) throw Error("CompressedTextures are not supported.");
919
- if (n.image.toDataURL === void 0) {
920
- var r = document.createElement("canvas");
921
- r.width = n.image.naturalWidth, r.height = n.image.naturalHeight, r.getContext("2d").drawImage(n.image, 0, 0), this.dataURLs.set(t, r.toDataURL());
922
- } else this.dataURLs.set(t, n.image.toDataURL());
923
- }
924
- this.canvas = document.createElement("canvas"), this.textureCount = 0, this.maxWidth = 0, this.maxHeight = 0;
925
- var i = "";
926
- for (t of e.keys()) {
927
- this.textureCount++;
928
- var a = e.get(t);
929
- a.userData.area = a.image.width * a.image.height, a.image.width > this.maxWidth && (this.maxWidth = a.image.width), a.image.height > this.maxHeight && (this.maxHeight = a.image.height), i += t + ",";
930
- }
931
- i = i.substring(0, i.length - 1), this.textureCache = [], this.node = new Y(), this.node.rectangle = new J(0, 0, this.maxWidth * this.textureCount, this.maxHeight * this.textureCount), this.textureOffsets = /* @__PURE__ */ new Map(), this.allNodes = [], this.insert(this.node, this.findNextTexture(e), e), this.ranges = /* @__PURE__ */ new Map();
932
- var o = this.calculateImageSize(e);
933
- this.canvas.width = o.width, this.canvas.height = o.height;
934
- var c = this.canvas.getContext("2d");
935
- this.context = c;
936
- for (t of this.textureOffsets.keys()) {
937
- for (var a = e.get(t), l = this.textureOffsets.get(t).x, u = this.textureOffsets.get(t).y, d = a.image.width, f = a.image.height, p = u; p < u + f; p += f) for (var m = l; m < l + d; m += d) c.drawImage(a.image, m, p, d, f);
938
- var h = new ut();
939
- h.startU = l / o.width, h.endU = (l + d) / o.width, h.startV = 1 - u / o.height, h.endV = 1 - (u + f) / o.height, this.ranges.set(t, h);
940
- }
941
- this.makeCanvasPowerOfTwo(), this.mergedTexture = new s(this.canvas), this.mergedTexture.wrapS = C, this.mergedTexture.wrapT = C, this.mergedTexture.minFilter = me, this.mergedTexture.magFilter = me, this.mergedTexture.needsUpdate = !0;
942
- }
943
- }
944
- isTextureAlreadyInserted(e, t) {
945
- var n = t.get(e), r = this.dataURLs.get(e);
946
- for (var i of t.keys()) if (i != e) {
947
- var a = t.get(i);
948
- if (r == this.dataURLs.get(i) && a.offset.x == n.offset.x && a.offset.y == n.offset.y && a.repeat.x == n.repeat.x && a.repeat.y == n.repeat.y && a.flipY == n.flipY && a.wrapS == n.wrapS && a.wrapT == n.wrapT && this.textureOffsets.get(i)) return this.textureOffsets.get(i);
949
- }
950
- return null;
951
- }
952
- insert(e, t, n) {
953
- var r = n.get(t), i = this.isTextureAlreadyInserted(t, n);
954
- if (i) {
955
- this.textureOffsets.set(t, i);
956
- var a = this.findNextTexture(n);
957
- a != null && this.insert(e, a, n);
958
- return;
959
- }
960
- var o = r.image.width, s = r.image.height;
961
- if (e.upperNode) {
962
- for (var c = this.maxWidth * this.textureCount + this.maxHeight * this.textureCount, l, u = !1, d = 0; d < this.allNodes.length; d++) {
963
- var f = this.allNodes[d];
964
- if (!f.textureName && f.rectangle.fits(r)) {
965
- this.textureOffsets.set(t, {
966
- x: f.rectangle.x,
967
- y: f.rectangle.y
968
- });
969
- var p = this.calculateImageSize(n), m = p.width + p.height;
970
- if (m < c && p.width <= this.MAX_TEXTURE_SIZE && p.height <= this.MAX_TEXTURE_SIZE) {
971
- var h = !1;
972
- for (var g of this.textureOffsets.keys()) if (g != t) {
973
- var _ = f.rectangle, { x: v, y: ee } = this.textureOffsets.get(g), y = n.get(g).image, te = new J(_.x, _.y, o, s), b = new J(v, ee, y.width, y.height);
974
- te.overlaps(b) && (h = !0);
975
- }
976
- h || (c = m, l = this.allNodes[d], u = !0);
977
- }
978
- this.textureOffsets.delete(t);
979
- }
980
- }
981
- if (u) {
982
- if (this.textureOffsets.set(t, {
983
- x: l.rectangle.x,
984
- y: l.rectangle.y
985
- }), l.textureName = t, !l.children) {
986
- var x = new Y(), S = new Y();
987
- x.upperNode = l, S.upperNode = l, l.children = [x, S];
988
- var C = l.rectangle.x, w = l.rectangle.y, ne = this.maxWidth * this.textureCount, T = this.maxHeight * this.textureCount;
989
- x.rectangle = new J(C + o, w, ne - (C + o), T - w), S.rectangle = new J(C, w + s, ne - C, T - (w + s)), this.allNodes.push(x), this.allNodes.push(S);
990
- }
991
- var a = this.findNextTexture(n);
992
- a != null && this.insert(e, a, n);
993
- } else console.info(o, s, t);
994
- } else {
995
- var E = e.rectangle.width, re = e.rectangle.height;
996
- e.textureName = t;
997
- var x = new Y(), S = new Y();
998
- x.upperNode = e, S.upperNode = e, e.children = [x, S], x.rectangle = new J(o, 0, E - o, s), S.rectangle = new J(0, s, E, re - s), this.textureOffsets.set(t, {
999
- x: e.rectangle.x,
1000
- y: e.rectangle.y
1001
- });
1002
- var D = e.children[0];
1003
- this.allNodes = [
1004
- e,
1005
- x,
1006
- S
1007
- ];
1008
- var a = this.findNextTexture(n);
1009
- a != null && this.insert(D, a, n);
1010
- }
1011
- }
1012
- makeCanvasPowerOfTwo(e) {
1013
- var t = !1;
1014
- e || (e = this.canvas, t = !0);
1015
- var n = e.width, r = e.height, i = 2 ** Math.round(Math.log(n) / Math.log(2)), a = 2 ** Math.round(Math.log(r) / Math.log(2)), o = document.createElement("canvas");
1016
- o.width = i, o.height = a, o.getContext("2d").drawImage(e, 0, 0, i, a), t && (this.canvas = o);
1017
- }
1018
- calculateImageSize(e) {
1019
- var t = 0, n = 0;
1020
- for (var r of this.textureOffsets.keys()) {
1021
- var i = e.get(r), a = i.image.width, o = i.image.height, { x: s, y: c } = this.textureOffsets.get(r);
1022
- s + a > t && (t = s + a), c + o > n && (n = c + o);
1023
- }
1024
- return {
1025
- width: t,
1026
- height: n
1027
- };
1028
- }
1029
- findNextTexture(e) {
1030
- var t = -1, n = "";
1031
- for (var r of e.keys()) {
1032
- var i = e.get(r);
1033
- this.textureCache.indexOf(r) == -1 && i.userData.area > t && (t = i.userData.area, n = r);
1034
- }
1035
- return t == -1 ? null : (this.textureCache.push(n), n);
1036
- }
1037
- rescale(e, t) {
1038
- var n = document.createElement("canvas");
1039
- return n.width = e.width * t, n.height = e.height * t, n.getContext("2d").drawImage(e, 0, 0, e.width, e.height, 0, 0, n.width, n.height), n;
1040
- }
1041
- };
1042
- function ft(e, t) {
1043
- let n = e.geometry.attributes.uv.array;
1044
- for (let e = 0; e < n.length; e += 2) n[e] = n[e] * (t.endU - t.startU) + t.startU, n[e + 1] = n[e + 1] * (t.startV - t.endV) + t.endV;
1045
- e.geometry.attributes.uv.needsUpdate = !0;
1046
- }
1047
- //#endregion
1048
- //#region src/components/Threejs/common/BoothMesh.ts
1049
- new N({
1050
- color: 16711680,
1051
- side: 2,
1052
- name: "selected"
1053
- });
1054
- var pt = new ae({
1055
- metalness: 0,
1056
- roughness: 1,
1057
- clearcoat: .5,
1058
- transparent: !0,
1059
- opacity: .5,
1060
- side: 2,
1061
- depthWrite: !0,
1062
- depthTest: !0
1063
- }), mt = new N({
1064
- color: 16734003,
1065
- side: 2,
1066
- name: "hovered"
1067
- }), ht = class extends T {
1068
- constructor(e, t, n, r, i, a) {
1069
- super(), this.efpBooth = e, this.threeBooth = t, this.boothMesh = n, this.name = r, this.threeLayer = i, this.z = a, this.material = void 0, this.name = r, n.name = r, this.material = n.material, this.children.push(n), this.layers.set(i);
1070
- }
1071
- setText() {
1072
- let e = new _();
1073
- if (e.text = ke(this.efpBooth), !e.text) return;
1074
- e.color = this.efpBooth.labelColor || _e.boothLabelColor, e.anchorX = "center", e.anchorY = "middle", e.textAlign = "center";
1075
- let t = e.text.split(" "), n = Math.max(...t.map((e) => e.length)), { rect: r } = this.threeBooth, i = Math.max(r.width, r.height), a = Math.min(r.width, r.height);
1076
- e.fontSize = a, e.fontSize * e.text.length > i && (e.fontSize *= 1.1 * i / (e.fontSize * e.text.length)), e.fontSize / a < .15 && (e.maxWidth = .1, e.fontSize *= t.length, e.fontSize * t.length > a && (e.fontSize *= .9 * a / (e.fontSize * t.length)), e.fontSize * n > i && (e.fontSize *= i / (e.fontSize * n)));
1077
- let o = e;
1078
- var s = (0, z.lineAngle)(this.threeBooth.rect.p0, this.threeBooth.rect.p1) || 0;
1079
- return 1.5 * r.width < r.height && (s += 90), o.rotateZ(s * Math.PI / 180), o.position.x = r.center.x, o.position.y = r.center.y, o.position.z = this.z + .01, o.scale.y = -1, o.name = this.name, o.layers.set(this.threeLayer), e;
1080
- }
1081
- setLogo(e, t, n) {
1082
- let r = this.threeBooth.rect, i = r.width / r.height, a = 0, o = 0, s = 0;
1083
- if (i > t ? (o = r.height * .9, a = o * t) : (a = r.width * .9, o = a / t), t >= 2 && !this.efpBooth.rotate && r.height >= r.width * 2) {
1084
- let e = r.width * .9, n = e * t;
1085
- for (; n > r.height - .02;) e -= .01, n = e * t;
1086
- o = e, a = n, s = -90;
1087
- } else s = -this.efpBooth.rotate * 180 / Math.PI;
1088
- let c = e.ranges.get(this.efpBooth.slug + "_logo");
1089
- if (!c) return null;
1090
- var l = new D(new ce(a, o), n);
1091
- return l.layers.set(this.threeLayer), ft(l, c), l.rotateZ((s || 0) * Math.PI / 180), l.position.x = r.center.x, l.position.y = r.center.y, l.position.z = this.z + .01 * this.z, l.scale.y = -1, l.material.map = e.mergedTexture, l.name = this.efpBooth.name, l;
1092
- }
1093
- dimmed(e) {
1094
- this.boothMesh.material = e ? pt : this.material, this.boothMesh.userData.dimmed = e;
1095
- }
1096
- hovered(e) {
1097
- e ? this.boothMesh.material = mt : this.boothMesh.userData.dimmed ? this.boothMesh.material = pt : (this.boothMesh.userData.selected, this.boothMesh.material = this.material);
1098
- }
1099
- };
1100
- //#endregion
1101
- //#region src/components/Threejs/common/dataLoader.ts
1102
- async function gt(e) {
1103
- return new Promise(async (t, n) => {
1104
- let i = `https://${e}.expofp.com/data/threejs`;
1105
- t(await (await fetch(r(`${i}/model.json`))).json());
1106
- });
1107
- }
1108
- //#endregion
1109
- //#region src/components/Threejs/common/modelLoader.ts
1110
- async function _t(e, t) {
1111
- return new Promise(async (n, r) => {
1112
- var i = await vt(t);
1113
- i.getAsArray().forEach((e) => {
1114
- e.name.indexOf(".webp") > -1 && (e.alphaTest = .6, e.transparent = !0), e.name === "0xB1C6CE" && (e.alphaTest = .1, e.transparent = !0, e.opacity = .3, e.side = 2, e.depthWrite = !1, e.depthTest = !1);
1115
- });
1116
- let a = new lt();
1117
- a.setMaterials(i), a.load(e, async (e) => {
1118
- e.children.forEach((e) => {
1119
- e.name === "building" ? e.renderOrder = .1 : e.renderOrder = 1;
1120
- }), n(e);
1121
- }, void 0, (e) => r(e));
1122
- });
1123
- }
1124
- async function vt(e) {
1125
- return new Promise((t, n) => {
1126
- let r = new Ze();
1127
- r.setMaterialOptions({ side: 2 }), r.load(e, (e) => {
1128
- t(e);
1129
- }, void 0, (e) => {
1130
- n(e);
1131
- });
1132
- });
1133
- }
1134
- //#endregion
1135
- //#region src/components/Threejs/common/Scene.ts
1136
- var yt = class extends ie {
1137
- constructor() {
1138
- super(), this.camera = void 0, this.raycaster = void 0, this.objLayers = /* @__PURE__ */ new Map(), this.layerCounter = 1, this.onClickCallbacks = [];
1139
- }
1140
- addLayer(e) {
1141
- return this.objLayers.has(e) || (this.objLayers.set(e, this.layerCounter), this.camera.layers.enable(this.layerCounter), this.layerCounter++), this.layerCounter - 1;
1142
- }
1143
- getlayer(e) {
1144
- return this.objLayers.get(e);
1145
- }
1146
- };
1147
- //#endregion
1148
- //#region src/components/Threejs/common/sceneLoader.ts
1149
- async function bt(e, t, n, r, i, a) {
1150
- let o = new re(), s = new yt();
1151
- s.raycaster = o, s.camera = r, r.near = .1, r.far = 1e4, r.aspect = n.clientWidth / n.clientHeight, r.updateProjectionMatrix();
1152
- let c = new ne(16777215, 10, Math.PI);
1153
- c.castShadow = !0, c.position.set(0, 0, 100), s.add(c);
1154
- let l = new te({
1155
- canvas: e || void 0,
1156
- context: t || void 0,
1157
- antialias: !0,
1158
- precision: "highp",
1159
- premultipliedAlpha: !0
1160
- });
1161
- l.outputColorSpace = I, !e && !t && (l.setSize(n.clientWidth, n.clientHeight), n.appendChild(l.domElement)), l.autoClear = !1, n.addEventListener("resize", () => {
1162
- r.aspect = n.clientWidth / n.clientHeight, r.updateProjectionMatrix(), l.setSize(n.clientWidth, n.clientHeight), u();
1163
- }, !1);
1164
- function u() {
1165
- l.resetState(), a(), !e && !t && l.render(s, r);
1166
- }
1167
- function d() {
1168
- requestAnimationFrame(d), u();
1169
- }
1170
- d(), o.layers.enableAll();
1171
- let f = !1;
1172
- n.addEventListener("mousedown", () => {
1173
- f = !0;
1174
- }), n.addEventListener("mousemove", () => {
1175
- f = !1;
1176
- }), n.addEventListener("mouseup", (e) => {
1177
- f && p(e.clientX - n.parentElement.offsetLeft, e.clientY - n.parentElement.offsetTop), f = !1;
1178
- });
1179
- function p(e, t) {
1180
- i(e, t, o);
1181
- let n = o.intersectObjects(s.children).filter((e) => e.object.material.visible).sort((e, t) => e.distance - t.distance);
1182
- s.onClickCallbacks.forEach((e) => e(n));
1183
- }
1184
- return s.scale.x = -1, {
1185
- scene: s,
1186
- renderer: l
1187
- };
1188
- }
1189
- //#endregion
1190
- //#region src/components/Threejs/index.ts
1191
- function xt(e, t) {
1192
- return new Promise(async (n, r) => {
1193
- let i = new be(50, e.clientWidth / e.clientHeight, .1, 1e3);
1194
- var { x: a, y: o } = t.viewbox.center;
1195
- i.position.x = a + t.area.width * .2, i.position.y = o + t.area.height, i.position.z = t.objLayers[t.objLayers.length - 1].z * Math.max(t.area.height, t.area.width) * .15 || Math.min(t.area.height, t.area.width), i.up.set(0, 0, 1);
1196
- let s, l = await bt(null, null, e, i, (t, n, r) => {
1197
- let a = new u();
1198
- a.x = t / e.clientWidth * 2 - 1, a.y = -(n / e.clientHeight) * 2 + 1, r.setFromCamera(a, i);
1199
- }, () => {
1200
- s == null || s.update();
1201
- });
1202
- s = new Re(i, l.renderer.domElement), s.enableRotate = !0, s.enablePan = !0, s.enableZoom = !0, s.enableDamping = !0, s.zoomSpeed = .7, s.rotateSpeed = 1.5, s.panSpeed = .7, s.target.set(a, o, 0), s.mouseButtons = {
1203
- LEFT: F.PAN,
1204
- RIGHT: F.ROTATE,
1205
- MIDDLE: F.DOLLY
1206
- }, s.touches.ONE = c.PAN, s.touches.TWO = c.DOLLY_ROTATE, l.scene.background = new p(12895428), n(l.scene);
1207
- });
1208
- }
1209
- //#endregion
1210
- //#region src/components/Threejs/mapbox/configureWebGLForMapbox.ts
1211
- var X = /* @__PURE__ */ e(Te(), 1);
1212
- function St() {
1213
- if (X.default.Map.prototype._setupPainter.toString().indexOf("webgl2") > -1) {
1214
- let e = X.default.Map.prototype._setupPainter;
1215
- X.default.Map.prototype._setupPainter = function() {
1216
- let t = this._canvas.getContext;
1217
- this._canvas.getContext = function(e, n) {
1218
- return t.apply(this, ["webgl2", n]) || t.apply(this, ["webgl", n]) || t.apply(this, ["experimental-webgl", n]);
1219
- }, e.apply(this), this._canvas.getContext = t;
1220
- };
1221
- }
1222
- }
1223
- //#endregion
1224
- //#region src/components/Threejs/mapbox/init-mapbox.ts
1225
- function Ct(e, t) {
1226
- return new Promise((n, r) => {
1227
- St(), X.default.accessToken = "pk.eyJ1Ijoicm9kaW9ubmlrb2xhZXYiLCJhIjoiY2wwanE5aXB4MDM2NTNibGExd3k4bHhsaiJ9.wdpy8dJ1qktQXGtZYDNH3w";
1228
- let i = new X.default.Map({
1229
- container: e,
1230
- style: "mapbox://styles/mapbox/" + t.replace("v10", "v11"),
1231
- antialias: !0,
1232
- pitch: 30,
1233
- maxPitch: 70,
1234
- minZoom: 14
1235
- });
1236
- i.on("load", () => n(i));
1237
- });
1238
- }
1239
- //#endregion
1240
- //#region src/components/Threejs/mapbox/index_mapbox.ts
1241
- async function wt(e, t) {
1242
- return new Promise(async (n, r) => {
1243
- var { geoConfig: i } = t;
1244
- let a = await Ct(e, i.style);
1245
- je(a);
1246
- let o, s, c, u;
1247
- a.setBearing(i.bearing - 30), a.setCenter(i.center), a.setZoom(16);
1248
- let d = [
1249
- 0,
1250
- 0,
1251
- (180 - i.bearing) * Math.PI / 180
1252
- ], f = X.default.MercatorCoordinate.fromLngLat(i.center, 1), p = {
1253
- translateX: f.x,
1254
- translateY: f.y,
1255
- translateZ: f.z,
1256
- rotateX: d[0],
1257
- rotateY: d[1],
1258
- rotateZ: d[2],
1259
- scale: 10 * f.meterInMercatorCoordinateUnits()
1260
- };
1261
- a.addLayer({
1262
- id: "3d-expofp",
1263
- type: "custom",
1264
- renderingMode: "3d",
1265
- onAdd: async function(t, r) {
1266
- o = new be();
1267
- var i = await bt(t.getCanvas(), r, e, o, (n, r, i) => {
1268
- let a = t.getFreeCameraOptions(), s = new v(a.position.x, a.position.y, a.position.z, 1), c = new v(-1e3, -1e3, 1, 1);
1269
- c.x = n / e.clientWidth * 2 - 1, c.y = -(r / e.clientHeight) * 2 + 1, s.applyMatrix4(u.invert());
1270
- let l = c.clone().applyMatrix4(o.projectionMatrix.clone().invert());
1271
- return l.divideScalar(l.w), i.set(s, l.sub(s).normalize()), i;
1272
- }, () => {});
1273
- s = i.scene, c = i.renderer, n(s);
1274
- },
1275
- render: function(e, t) {
1276
- if (!c) return;
1277
- let n = new O().makeRotationAxis(new l(1, 0, 0), p.rotateX), r = new O().makeRotationAxis(new l(0, 1, 0), p.rotateY), i = new O().makeRotationAxis(new l(0, 0, 1), p.rotateZ), d = new O().fromArray(t);
1278
- u = new O().makeTranslation(p.translateX, p.translateY, p.translateZ).scale(new l(p.scale, -p.scale, p.scale)).multiply(n).multiply(r).multiply(i), o.projectionMatrix = d.multiply(u);
1279
- let f = a.getFreeCameraOptions(), m = new v(f.position.x, f.position.y, f.position.z, 1).applyMatrix4(u.clone().invert());
1280
- o.userData.position = m, c.render(s, o), a.triggerRepaint();
1281
- }
1282
- });
1283
- });
1284
- }
1285
- //#endregion
1286
- //#region src/components/Threejs/common/SpriteMesh.ts
1287
- var Z = class extends D {
1288
- constructor(e, t) {
1289
- let n = new ce(1, 1), r = new ge({
1290
- transparent: !0,
1291
- side: 2,
1292
- alphaTest: .8,
1293
- toneMapped: !0,
1294
- precision: "highp"
1295
- });
1296
- var i = 0;
1297
- new x().load(e, (e) => {
1298
- r.map = e;
1299
- var i = t / e.image.height;
1300
- n.scale(e.image.width * i, e.image.height * i, 1), n.translate(0, e.image.height * i / 2, 0), n.rotateX(Math.PI / 2), r.needsUpdate = !0;
1301
- }), super(n, r), this.onBeforeRender = (e, t, n, r, a, o) => {
1302
- let s = (0, z.round)(((0, z.lineAngle)({
1303
- x: 0,
1304
- y: 0
1305
- }, n.position.x && n.position.y && n.position.z ? n.position : n.userData.position) - 90) * Math.PI / 180, 2);
1306
- this.rotateZ(-1 * (s - i)), i = s;
1307
- };
1308
- }
1309
- };
1310
- //#endregion
1311
- //#region src/components/Threejs/utils/canvasFromText.ts
1312
- function Tt(e) {
1313
- let t = document.createElement("canvas"), n = t.getContext("2d");
1314
- return n.font = "30px Arial", n.fillText(e, 0, 0), t;
1315
- }
1316
- //#endregion
1317
- //#region src/components/Threejs/assets/from.png
1318
- var Et = "data:image/png;base64,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", Dt = "data:image/png;base64,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", Ot = "data:image/png;base64,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", Q = [], kt = new N({ color: 3190763 }), At = new N({ color: 16711680 }), $ = 0, jt = [], Mt = (e) => _e.EXPO == "glf24" ? .1 : 1 * (e.area.width + e.area.height) / 1200, Nt = class {
1319
- constructor(e, t, n) {
1320
- this.expo = void 0, this.isMapbox = void 0, this.scene = void 0, this.data = void 0, this.container = void 0, this.isInit = !1, this.expo = e, this.isMapbox = t, this.container = n, setInterval(() => {
1321
- if (!Q.length) {
1322
- $ = 0;
1323
- return;
1324
- }
1325
- Q[$].material = At, $ > 0 && (Q[$ - 1].material = kt), $ < Q.length - 1 ? $++ : (Q[$ - 1].material = kt, $ = 0);
1326
- }, 50);
1327
- }
1328
- async init() {
1329
- return new Promise(async (e, t) => {
1330
- this.data = await gt(this.expo);
1331
- let n = `https://${this.expo}.expofp.com/data/threejs`, i = await (this.isMapbox ? wt(this.container, this.data) : xt(this.container, this.data)), a = await _t(r(`${n}/model.obj`), r(`${n}/model.mtl`));
1332
- this.isInit = !0, this.scene = i, i.onClickCallbacks.push(this.onClickCallback.bind(this)), i.onBeforeRender = this.onBeforeRender.bind(this), await this.initBooths(i, a), e();
1333
- });
1334
- }
1335
- changeLayerVisibility(e, t) {
1336
- if (!this.isInit) return;
1337
- let n = this.scene.getlayer(e);
1338
- n != null && (t ? (this.scene.camera.layers.enable(n), this.scene.raycaster.layers.enable(n)) : (this.scene.camera.layers.disable(n), this.scene.raycaster.layers.disable(n)));
1339
- }
1340
- hoverBooths(e) {
1341
- jt.forEach((t) => t.hovered(e.length && !!e.find((e) => e.name === t.name)));
1342
- }
1343
- selectBooths(e) {
1344
- jt.forEach((t) => t.dimmed(e.length && !e.find((e) => e.name === t.name)));
1345
- }
1346
- setMarker(e, t, n, r, i = !1, a = 1) {
1347
- let o = `{sprite_${e}}`, s = this.scene.children.find((e) => e.name === o);
1348
- if (t != null && n != null) {
1349
- let c = i ? {
1350
- x: t,
1351
- y: n
1352
- } : this.convertPoint(t, n, 0), l = this.data.objLayers.find((e) => {
1353
- var t;
1354
- return e.name === ((t = A.layerStore.findLayer(r)) == null ? void 0 : t.name);
1355
- }) || this.data.objLayers[0];
1356
- s || (e === "from" ? s = new Z(Et, l.height * a * 2) : e === "to" ? s = new Z(Dt, l.height * a * 2) : e === "yah" ? s = new Z(Ot, l.height * a * 2) : e === "cp" && (s = new Z(Ot, l.height * a)), s.name = o, this.scene.add(s)), s.position.set(c.x, c.y, l.z + (e === "from" || e === "to" ? l.height : 0));
1357
- } else s && this.scene.remove(s);
1358
- }
1359
- interpolateColors(e, t, n) {
1360
- for (var r = 1 / (n - 1), i = [], a = new p(e), o = new p(t), s = 0; s < n; s++) i.push(a.clone().lerp(o, r * s).getHex());
1361
- return i;
1362
- }
1363
- updateRouteLines(e) {
1364
- if (!this.isInit) return;
1365
- var t = e.routeLines.filter((e) => {
1366
- var t, n;
1367
- let r = (t = (n = A.layerStore.layers.find((t) => t.name === e.p0.layer)) == null ? void 0 : n.visible) == null ? !0 : t;
1368
- return !e.virtual && r;
1369
- });
1370
- if (Q.forEach((e) => this.scene.remove(e)), Q.splice(0, Q.length), !t.length) {
1371
- this.setMarker("from", null, null, null), this.setMarker("to", null, null, null);
1372
- return;
1373
- }
1374
- let n = this.linesToPoints(t), { z: r } = this.data.objLayers.find((e) => e.name === (pe.mode === le.Default ? "Default" : t[0].p0.layer)), i = Mt(this.data);
1375
- [].concat(n).reverse().forEach((e, t) => {
1376
- let n = new D(new Ce(i), kt);
1377
- n.position.set(e.x, e.y, r + .02), Q.push(n), this.scene.add(n);
1378
- }), this.setMarker("to", t[0].p0.x, t[0].p0.y, t[0].p0.layer), this.setMarker("from", t[t.length - 1].p1.x, t[t.length - 1].p1.y, t[t.length - 1].p1.layer);
1379
- }
1380
- onBeforeRender(e, t, n, r, i, a) {
1381
- n.userData.position || n.position;
1382
- }
1383
- onClickCallback(e) {
1384
- var t;
1385
- let n = e.filter((e) => e.object.name !== "building")[0], r = n == null || (t = n.object) == null ? void 0 : t.name, i = P.booths.find((e) => e.name === r);
1386
- i ? A.clickBooth(i) : M.details = null;
1387
- }
1388
- async initBooths(e, t) {
1389
- let n = (await de(P.booths)).filter((e) => !!e);
1390
- var r = /* @__PURE__ */ new Map();
1391
- n.forEach((e) => r.set(e.name + "_logo", new Se(e.htmlImage))), A.boothStore.booths.forEach((e) => {
1392
- r.set(e.slug, new Se(Tt(e.name)));
1393
- });
1394
- var i = new dt(r), a = new ge();
1395
- a.side = 2, a.transparent = !0, t.children.forEach((r, o) => {
1396
- var [s, c] = r.name.split(/ (.*)/s);
1397
- let l = e.addLayer(s);
1398
- r.layers.set(l), r.name = c;
1399
- let u = A.boothStore.booths.find((e) => c && c[0] === "b" && e.name === (c == null ? void 0 : c.substring(1)));
1400
- if (u) {
1401
- var d;
1402
- r.material = new N({
1403
- color: Ae(u),
1404
- side: 2,
1405
- name: r.name
1406
- });
1407
- let s = this.data.objLayers.find((e) => {
1408
- var t;
1409
- return e.name === (((t = u.layer) == null ? void 0 : t.name) || "Default");
1410
- }), f = this.data.booths.find((e) => e.name === u.name);
1411
- f.zScale = f.zScale || 1;
1412
- let p = s.z + f.zScale * s.height + (s.z + f.zScale * s.height) * .001, m = new ht(u, f, r, c.substring(1), l, p), h = m.setText();
1413
- if (h && e.add(h), !(u == null || (d = u.exhibitors) == null) && d.find((e) => !!e.logo && e.logoInBooth)) {
1414
- let t = n.find((e) => e.booth.name === c.substring(1)), r = m.setLogo(i, t.htmlImage.width / t.htmlImage.height, a);
1415
- r && e.add(r);
1416
- }
1417
- t.children[o] = m, jt.push(m);
1418
- }
1419
- }), e.add(t);
1420
- }
1421
- convertPoint(e, t, n) {
1422
- var r = this.data.matrix;
1423
- return e += r[0], t += r[1], e *= r[2], t *= r[3], e += r[4], t += r[5], new l(e, t, n);
1424
- }
1425
- linesToPoints(e) {
1426
- let t = [], n = [];
1427
- for (let t = 0; t < e.length; t++) {
1428
- var r, i;
1429
- let a = e[t], o = (r = (i = A.layerStore.layers.find((e) => e.name === a.p0.layer)) == null ? void 0 : i.visible) == null ? !0 : r;
1430
- !a.virtual && o && n.push(a), (a.virtual || !o || t === e.length - 1) && n.length && (n = []);
1431
- }
1432
- return t.map((e) => this.convertPoint(e.x, e.y, e.z));
1433
- }
1434
- }, Pt = n();
1435
- function Ft({ isMapbox: e, expo: t }) {
1436
- let n = (0, Me.useRef)(null), r = null;
1437
- (0, Me.useEffect)(() => {
1438
- r = new Nt(t, e, n.current), r.init().then(() => {
1439
- A.layerStore.layers.forEach((e) => r.changeLayerVisibility(e.name, e.visible)), r.selectBooths([...M.selectedBooths]), r.updateRouteLines(A.routeStore), Ee(!0);
1440
- });
1441
- }, []);
1442
- let i = ee(() => ({
1443
- get initselected() {
1444
- return ![...M.selectedBooths].filter((e) => e.rect);
1445
- },
1446
- get actualCurrentPosition() {
1447
- let e = A.routeStore.currentPosition;
1448
- return !(e != null && e.z) || A.layerStore.visible.indexOf(A.layerStore.findLayer(e.z)) > -1 ? e : null;
1449
- },
1450
- get style() {
1451
- return { left: 0 };
1452
- }
1453
- }));
1454
- return L(() => M.zoomBy, () => {
1455
- if (!M.zoomBy || !A.mapboxStore.showMapbox) return;
1456
- let e = M.zoomBy;
1457
- M.zoomBy = null, De(e > 1);
1458
- }), L(() => [
1459
- A.layerStore.loaded,
1460
- A.layerStore.visible,
1461
- M.selectedRoute
1462
- ], () => {
1463
- A.layerStore.layers.length === A.layerStore.layers.filter((e) => e.loaded).length && A.layerStore.layers.forEach((e) => r.changeLayerVisibility(e.name, e.visible));
1464
- }), L(() => M.hoveredBooths, () => {
1465
- r.hoverBooths([...M.hoveredBooths]);
1466
- }), L(() => [M.selectedBooths, M.listBooths], () => {
1467
- var e = [];
1468
- M.selectedBooths.size ? e = [...M.selectedBooths] : M.listBooths.size && (M.activeListIndex === 0 || M.list.type === "bookmarks" || M.list.type === "category") && (e = [...M.listBooths]), r.selectBooths(e);
1469
- }), L(() => A.mapboxStore.showMapbox, () => {
1470
- Ee(A.mapboxStore.showMapbox);
1471
- }), L(() => M.moveToBooths, () => {
1472
- if (!M.moveToBooths || !A.mapboxStore.showMapbox) return;
1473
- let e = M.moveToBooths.filter((e) => e.rect).map((e) => e.rect), t = m.fromMultiple(e);
1474
- e.length && R(t), M.moveToBooths = null;
1475
- }), L(() => M.moveToRect, () => {
1476
- !M.moveToRect || !A.mapboxStore.showMapbox || (R(M.moveToRect, 15), M.moveToRect = null);
1477
- }), L(() => M.moveToLocation, () => {
1478
- !M.moveToLocation || !A.mapboxStore.showMapbox || Oe();
1479
- }), L(() => M.centerMap, () => {
1480
- !M.centerMap || !A.mapboxStore.showMapbox || (R(m.fromMultiple(P.booths.map((e) => e.rect)), 15), M.centerMap = !1);
1481
- }), L(() => A.routeStore.routeLines, () => r.updateRouteLines(A.routeStore)), L(() => i.actualCurrentPosition, () => {
1482
- var e, t, n;
1483
- return r.setMarker("cp", (e = i.actualCurrentPosition) == null ? void 0 : e.x, (t = i.actualCurrentPosition) == null ? void 0 : t.y, (n = i.actualCurrentPosition) == null ? void 0 : n.z);
1484
- }), a(() => /* @__PURE__ */ (0, Pt.jsx)("div", {
1485
- style: i.style,
1486
- className: (0, Ne.default)("map-container", { hidden: !A.mapboxStore.showMapbox }),
1487
- children: /* @__PURE__ */ (0, Pt.jsx)("div", {
1488
- ref: n,
1489
- className: (0, Ne.default)("map-wrapper", "mapboxgl-map")
1490
- })
1491
- }));
1492
- }
1493
- //#endregion
1494
- export { Ft as default };