@expofp/floorplan 3.0.1 → 3.0.2

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