import { AnnotationService } from "./chunk-NO2C2JJZ.js"; import { defineStore, mapState, mapStores } from "./chunk-EZG7MI55.js"; import { hn, wn } from "./chunk-4PXRF7LI.js"; import { $7, M7, V7, z7 } from "./chunk-VSHHOTB7.js"; import "./chunk-GQENOT3W.js"; import { Comment, Fragment, Teleport, Text, Transition, cloneVNode, computed, createApp, createBaseVNode, createBlock, createCommentVNode, createElementBlock, createSlots, createTextVNode, createVNode, defineComponent, getCurrentInstance, getCurrentScope, h, inject, isRef, isVNode, markRaw, mergeProps, nextTick, normalizeClass, normalizeStyle, onActivated, onBeforeMount, onBeforeUnmount, onDeactivated, onMounted, onScopeDispose, onUnmounted, onUpdated, openBlock, provide, reactive, readonly, ref, renderList, renderSlot, resolveComponent, resolveDirective, resolveDynamicComponent, shallowRef, toDisplayString, toHandlerKey, toHandlers, toRaw, toRef, toRefs, unref, useAttrs, useSlots, vModelRadio, vModelText, vShow, warn, watch, watchEffect, withCtx, withDirectives, withKeys, withModifiers } from "./chunk-HM42ZP2D.js"; import "./chunk-EWTE5DHJ.js"; // node_modules/@abi-software/scaffoldvuer/dist/scaffoldvuer.js var Yi = (n, e, { checkForDefaultPrevented: t = true } = {}) => (r) => { const s = n == null ? void 0 : n(r); if (t === false || !s) return e == null ? void 0 : e(r); }; var aw = Object.defineProperty; var lw = Object.defineProperties; var cw = Object.getOwnPropertyDescriptors; var bp = Object.getOwnPropertySymbols; var uw = Object.prototype.hasOwnProperty; var hw = Object.prototype.propertyIsEnumerable; var xp = (n, e, t) => e in n ? aw(n, e, { enumerable: true, configurable: true, writable: true, value: t }) : n[e] = t; var dw = (n, e) => { for (var t in e || (e = {})) uw.call(e, t) && xp(n, t, e[t]); if (bp) for (var t of bp(e)) hw.call(e, t) && xp(n, t, e[t]); return n; }; var fw = (n, e) => lw(n, cw(e)); function Mp(n, e) { var t; const i = shallowRef(); return watchEffect(() => { i.value = n(); }, fw(dw({}, e), { flush: (t = void 0) != null ? t : "sync" })), readonly(i); } var wp; var en = typeof window < "u"; var pw = (n) => typeof n == "string"; var Hv = () => { }; var zh = en && ((wp = window == null ? void 0 : window.navigator) == null ? void 0 : wp.userAgent) && /iP(ad|hone|od)/.test(window.navigator.userAgent); function Wv(n) { return typeof n == "function" ? n() : unref(n); } function mw(n) { return n; } function Yc(n) { return getCurrentScope() ? (onScopeDispose(n), true) : false; } function gw(n, e = true) { getCurrentInstance() ? onMounted(n) : e ? n() : nextTick(n); } function Qi(n) { var e; const t = Wv(n); return (e = t == null ? void 0 : t.$el) != null ? e : t; } var tl = en ? window : void 0; var vw = en ? window.document : void 0; function un(...n) { let e, t, i, r; if (pw(n[0]) || Array.isArray(n[0]) ? ([t, i, r] = n, e = tl) : [e, t, i, r] = n, !e) return Hv; Array.isArray(t) || (t = [t]), Array.isArray(i) || (i = [i]); const s = [], o = () => { s.forEach((d) => d()), s.length = 0; }, a = (d, h6, f, g) => (d.addEventListener(h6, f, g), () => d.removeEventListener(h6, f, g)), c = watch(() => [Qi(e), Wv(r)], ([d, h6]) => { o(), d && s.push(...t.flatMap((f) => i.map((g) => a(d, f, g, h6)))); }, { immediate: true, flush: "post" }), l = () => { c(), o(); }; return Yc(l), l; } var Ap = false; function yw(n, e, t = {}) { const { window: i = tl, ignore: r = [], capture: s = true, detectIframe: o = false } = t; if (!i) return; zh && !Ap && (Ap = true, Array.from(i.document.body.children).forEach((f) => f.addEventListener("click", Hv))); let a = true; const c = (f) => r.some((g) => { if (typeof g == "string") return Array.from(i.document.querySelectorAll(g)).some((p) => p === f.target || f.composedPath().includes(p)); { const p = Qi(g); return p && (f.target === p || f.composedPath().includes(p)); } }), d = [ un(i, "click", (f) => { const g = Qi(n); if (!(!g || g === f.target || f.composedPath().includes(g))) { if (f.detail === 0 && (a = !c(f)), !a) { a = true; return; } e(f); } }, { passive: true, capture: s }), un(i, "pointerdown", (f) => { const g = Qi(n); g && (a = !f.composedPath().includes(g) && !c(f)); }, { passive: true }), o && un(i, "blur", (f) => { var g; const p = Qi(n); ((g = i.document.activeElement) == null ? void 0 : g.tagName) === "IFRAME" && !(p != null && p.contains(i.document.activeElement)) && e(f); }) ].filter(Boolean); return () => d.forEach((f) => f()); } function jv(n, e = false) { const t = ref(), i = () => t.value = !!n(); return i(), gw(i, e), t; } var Sp = typeof globalThis < "u" ? globalThis : typeof window < "u" ? window : typeof global < "u" ? global : typeof self < "u" ? self : {}; var _p = "__vueuse_ssr_handlers__"; Sp[_p] = Sp[_p] || {}; function bw({ document: n = vw } = {}) { if (!n) return ref("visible"); const e = ref(n.visibilityState); return un(n, "visibilitychange", () => { e.value = n.visibilityState; }), e; } var Tp = Object.getOwnPropertySymbols; var xw = Object.prototype.hasOwnProperty; var Mw = Object.prototype.propertyIsEnumerable; var ww = (n, e) => { var t = {}; for (var i in n) xw.call(n, i) && e.indexOf(i) < 0 && (t[i] = n[i]); if (n != null && Tp) for (var i of Tp(n)) e.indexOf(i) < 0 && Mw.call(n, i) && (t[i] = n[i]); return t; }; function Yn(n, e, t = {}) { const i = t, { window: r = tl } = i, s = ww(i, ["window"]); let o; const a = jv(() => r && "ResizeObserver" in r), c = () => { o && (o.disconnect(), o = void 0); }, l = watch(() => Qi(n), (h6) => { c(), a.value && r && h6 && (o = new ResizeObserver(e), o.observe(h6, s)); }, { immediate: true, flush: "post" }), d = () => { c(), l(); }; return Yc(d), { isSupported: a, stop: d }; } var Ep = Object.getOwnPropertySymbols; var Aw = Object.prototype.hasOwnProperty; var Sw = Object.prototype.propertyIsEnumerable; var _w = (n, e) => { var t = {}; for (var i in n) Aw.call(n, i) && e.indexOf(i) < 0 && (t[i] = n[i]); if (n != null && Ep) for (var i of Ep(n)) e.indexOf(i) < 0 && Sw.call(n, i) && (t[i] = n[i]); return t; }; function Tw(n, e, t = {}) { const i = t, { window: r = tl } = i, s = _w(i, ["window"]); let o; const a = jv(() => r && "MutationObserver" in r), c = () => { o && (o.disconnect(), o = void 0); }, l = watch(() => Qi(n), (h6) => { c(), a.value && r && h6 && (o = new MutationObserver(e), o.observe(h6, s)); }, { immediate: true }), d = () => { c(), l(); }; return Yc(d), { isSupported: a, stop: d }; } var Cp; (function(n) { n.UP = "UP", n.RIGHT = "RIGHT", n.DOWN = "DOWN", n.LEFT = "LEFT", n.NONE = "NONE"; })(Cp || (Cp = {})); var Ew = Object.defineProperty; var Lp = Object.getOwnPropertySymbols; var Cw = Object.prototype.hasOwnProperty; var Lw = Object.prototype.propertyIsEnumerable; var Rp = (n, e, t) => e in n ? Ew(n, e, { enumerable: true, configurable: true, writable: true, value: t }) : n[e] = t; var Rw = (n, e) => { for (var t in e || (e = {})) Cw.call(e, t) && Rp(n, t, e[t]); if (Lp) for (var t of Lp(e)) Lw.call(e, t) && Rp(n, t, e[t]); return n; }; var Fw = { easeInSine: [0.12, 0, 0.39, 0], easeOutSine: [0.61, 1, 0.88, 1], easeInOutSine: [0.37, 0, 0.63, 1], easeInQuad: [0.11, 0, 0.5, 0], easeOutQuad: [0.5, 1, 0.89, 1], easeInOutQuad: [0.45, 0, 0.55, 1], easeInCubic: [0.32, 0, 0.67, 0], easeOutCubic: [0.33, 1, 0.68, 1], easeInOutCubic: [0.65, 0, 0.35, 1], easeInQuart: [0.5, 0, 0.75, 0], easeOutQuart: [0.25, 1, 0.5, 1], easeInOutQuart: [0.76, 0, 0.24, 1], easeInQuint: [0.64, 0, 0.78, 0], easeOutQuint: [0.22, 1, 0.36, 1], easeInOutQuint: [0.83, 0, 0.17, 1], easeInExpo: [0.7, 0, 0.84, 0], easeOutExpo: [0.16, 1, 0.3, 1], easeInOutExpo: [0.87, 0, 0.13, 1], easeInCirc: [0.55, 0, 1, 0.45], easeOutCirc: [0, 0.55, 0.45, 1], easeInOutCirc: [0.85, 0, 0.15, 1], easeInBack: [0.36, 0, 0.66, -0.56], easeOutBack: [0.34, 1.56, 0.64, 1], easeInOutBack: [0.68, -0.6, 0.32, 1.6] }; Rw({ linear: mw }, Fw); function Pw({ window: n = tl } = {}) { if (!n) return ref(false); const e = ref(n.document.hasFocus()); return un(n, "blur", () => { e.value = false; }), un(n, "focus", () => { e.value = true; }), e; } var Iw = () => en && /firefox/i.test(window.navigator.userAgent); Object.freeze({}); Object.freeze([]); var Oa = () => { }; var Ow = Object.prototype.hasOwnProperty; var Fp = (n, e) => Ow.call(n, e); var Pn = Array.isArray; var Sn = (n) => typeof n == "function"; var vn = (n) => typeof n == "string"; var Tn = (n) => n !== null && typeof n == "object"; var Dw = Object.prototype.toString; var Nw = (n) => Dw.call(n); var Pu = (n) => Nw(n).slice(8, -1); var Vd = (n) => { const e = /* @__PURE__ */ Object.create(null); return (t) => e[t] || (e[t] = n(t)); }; var Bw = /-(\w)/g; var Uw = Vd( (n) => n.replace(Bw, (e, t) => t ? t.toUpperCase() : "") ); var zw = /\B([A-Z])/g; var Vw = Vd( (n) => n.replace(zw, "-$1").toLowerCase() ); var kw = Vd((n) => n.charAt(0).toUpperCase() + n.slice(1)); var $v = typeof global == "object" && global && global.Object === Object && global; var Gw = typeof self == "object" && self && self.Object === Object && self; var Bi = $v || Gw || Function("return this")(); var Pi = Bi.Symbol; var Zv = Object.prototype; var Hw = Zv.hasOwnProperty; var Ww = Zv.toString; var la = Pi ? Pi.toStringTag : void 0; function jw(n) { var e = Hw.call(n, la), t = n[la]; try { n[la] = void 0; var i = true; } catch { } var r = Ww.call(n); return i && (e ? n[la] = t : delete n[la]), r; } var $w = Object.prototype; var Zw = $w.toString; function Xw(n) { return Zw.call(n); } var Yw = "[object Null]"; var Jw = "[object Undefined]"; var Pp = Pi ? Pi.toStringTag : void 0; function Zo(n) { return n == null ? n === void 0 ? Jw : Yw : Pp && Pp in Object(n) ? jw(n) : Xw(n); } function Mo(n) { return n != null && typeof n == "object"; } var Kw = "[object Symbol]"; function Jc(n) { return typeof n == "symbol" || Mo(n) && Zo(n) == Kw; } function qw(n, e) { for (var t = -1, i = n == null ? 0 : n.length, r = Array(i); ++t < i; ) r[t] = e(n[t], t, n); return r; } var pi = Array.isArray; var Qw = 1 / 0; var Ip = Pi ? Pi.prototype : void 0; var Op = Ip ? Ip.toString : void 0; function Xv(n) { if (typeof n == "string") return n; if (pi(n)) return qw(n, Xv) + ""; if (Jc(n)) return Op ? Op.call(n) : ""; var e = n + ""; return e == "0" && 1 / n == -Qw ? "-0" : e; } var e1 = /\s/; function t1(n) { for (var e = n.length; e-- && e1.test(n.charAt(e)); ) ; return e; } var n1 = /^\s+/; function i1(n) { return n && n.slice(0, t1(n) + 1).replace(n1, ""); } function Ur(n) { var e = typeof n; return n != null && (e == "object" || e == "function"); } var Dp = NaN; var r1 = /^[-+]0x[0-9a-f]+$/i; var s1 = /^0b[01]+$/i; var o1 = /^0o[0-7]+$/i; var a1 = parseInt; function Np(n) { if (typeof n == "number") return n; if (Jc(n)) return Dp; if (Ur(n)) { var e = typeof n.valueOf == "function" ? n.valueOf() : n; n = Ur(e) ? e + "" : e; } if (typeof n != "string") return n === 0 ? n : +n; n = i1(n); var t = s1.test(n); return t || o1.test(n) ? a1(n.slice(2), t ? 2 : 8) : r1.test(n) ? Dp : +n; } function Yv(n) { return n; } var l1 = "[object AsyncFunction]"; var c1 = "[object Function]"; var u1 = "[object GeneratorFunction]"; var h1 = "[object Proxy]"; function Jv(n) { if (!Ur(n)) return false; var e = Zo(n); return e == c1 || e == u1 || e == l1 || e == h1; } var Iu = Bi["__core-js_shared__"]; var Bp = function() { var n = /[^.]+$/.exec(Iu && Iu.keys && Iu.keys.IE_PROTO || ""); return n ? "Symbol(src)_1." + n : ""; }(); function d1(n) { return !!Bp && Bp in n; } var f1 = Function.prototype; var p1 = f1.toString; function Os(n) { if (n != null) { try { return p1.call(n); } catch { } try { return n + ""; } catch { } } return ""; } var m1 = /[\\^$.*+?()[\]{}|]/g; var g1 = /^\[object .+?Constructor\]$/; var v1 = Function.prototype; var y1 = Object.prototype; var b1 = v1.toString; var x1 = y1.hasOwnProperty; var M1 = RegExp( "^" + b1.call(x1).replace(m1, "\\$&").replace(/hasOwnProperty|(function).*?(?=\\\()| for .+?(?=\\\])/g, "$1.*?") + "$" ); function w1(n) { if (!Ur(n) || d1(n)) return false; var e = Jv(n) ? M1 : g1; return e.test(Os(n)); } function A1(n, e) { return n == null ? void 0 : n[e]; } function Ds(n, e) { var t = A1(n, e); return w1(t) ? t : void 0; } var Vh = Ds(Bi, "WeakMap"); function S1(n, e, t) { switch (t.length) { case 0: return n.call(e); case 1: return n.call(e, t[0]); case 2: return n.call(e, t[0], t[1]); case 3: return n.call(e, t[0], t[1], t[2]); } return n.apply(e, t); } var _1 = 800; var T1 = 16; var E1 = Date.now; function C1(n) { var e = 0, t = 0; return function() { var i = E1(), r = T1 - (i - t); if (t = i, r > 0) { if (++e >= _1) return arguments[0]; } else e = 0; return n.apply(void 0, arguments); }; } function L1(n) { return function() { return n; }; } var Fc = function() { try { var n = Ds(Object, "defineProperty"); return n({}, "", {}), n; } catch { } }(); var R1 = Fc ? function(n, e) { return Fc(n, "toString", { configurable: true, enumerable: false, value: L1(e), writable: true }); } : Yv; var F1 = C1(R1); function P1(n, e, t, i) { n.length; for (var r = t + 1; r--; ) if (e(n[r], r, n)) return r; return -1; } var I1 = 9007199254740991; var O1 = /^(?:0|[1-9]\d*)$/; function kd(n, e) { var t = typeof n; return e = e ?? I1, !!e && (t == "number" || t != "symbol" && O1.test(n)) && n > -1 && n % 1 == 0 && n < e; } function D1(n, e, t) { e == "__proto__" && Fc ? Fc(n, e, { configurable: true, enumerable: true, value: t, writable: true }) : n[e] = t; } function Gd(n, e) { return n === e || n !== n && e !== e; } var N1 = Object.prototype; var B1 = N1.hasOwnProperty; function U1(n, e, t) { var i = n[e]; (!(B1.call(n, e) && Gd(i, t)) || t === void 0 && !(e in n)) && D1(n, e, t); } var Up = Math.max; function z1(n, e, t) { return e = Up(e === void 0 ? n.length - 1 : e, 0), function() { for (var i = arguments, r = -1, s = Up(i.length - e, 0), o = Array(s); ++r < s; ) o[r] = i[e + r]; r = -1; for (var a = Array(e + 1); ++r < e; ) a[r] = i[r]; return a[e] = t(o), S1(n, this, a); }; } var V1 = 9007199254740991; function Hd(n) { return typeof n == "number" && n > -1 && n % 1 == 0 && n <= V1; } function k1(n) { return n != null && Hd(n.length) && !Jv(n); } var G1 = Object.prototype; function H1(n) { var e = n && n.constructor, t = typeof e == "function" && e.prototype || G1; return n === t; } function W1(n, e) { for (var t = -1, i = Array(n); ++t < n; ) i[t] = e(t); return i; } var j1 = "[object Arguments]"; function zp(n) { return Mo(n) && Zo(n) == j1; } var Kv = Object.prototype; var $1 = Kv.hasOwnProperty; var Z1 = Kv.propertyIsEnumerable; var Wd = zp(/* @__PURE__ */ function() { return arguments; }()) ? zp : function(n) { return Mo(n) && $1.call(n, "callee") && !Z1.call(n, "callee"); }; function X1() { return false; } var qv = typeof exports == "object" && exports && !exports.nodeType && exports; var Vp = qv && typeof module == "object" && module && !module.nodeType && module; var Y1 = Vp && Vp.exports === qv; var kp = Y1 ? Bi.Buffer : void 0; var J1 = kp ? kp.isBuffer : void 0; var kh = J1 || X1; var K1 = "[object Arguments]"; var q1 = "[object Array]"; var Q1 = "[object Boolean]"; var eA = "[object Date]"; var tA = "[object Error]"; var nA = "[object Function]"; var iA = "[object Map]"; var rA = "[object Number]"; var sA = "[object Object]"; var oA = "[object RegExp]"; var aA = "[object Set]"; var lA = "[object String]"; var cA = "[object WeakMap]"; var uA = "[object ArrayBuffer]"; var hA = "[object DataView]"; var dA = "[object Float32Array]"; var fA = "[object Float64Array]"; var pA = "[object Int8Array]"; var mA = "[object Int16Array]"; var gA = "[object Int32Array]"; var vA = "[object Uint8Array]"; var yA = "[object Uint8ClampedArray]"; var bA = "[object Uint16Array]"; var xA = "[object Uint32Array]"; var Et = {}; Et[dA] = Et[fA] = Et[pA] = Et[mA] = Et[gA] = Et[vA] = Et[yA] = Et[bA] = Et[xA] = true; Et[K1] = Et[q1] = Et[uA] = Et[Q1] = Et[hA] = Et[eA] = Et[tA] = Et[nA] = Et[iA] = Et[rA] = Et[sA] = Et[oA] = Et[aA] = Et[lA] = Et[cA] = false; function MA(n) { return Mo(n) && Hd(n.length) && !!Et[Zo(n)]; } function wA(n) { return function(e) { return n(e); }; } var Qv = typeof exports == "object" && exports && !exports.nodeType && exports; var Ea = Qv && typeof module == "object" && module && !module.nodeType && module; var AA = Ea && Ea.exports === Qv; var Ou = AA && $v.process; var Gp = function() { try { var n = Ea && Ea.require && Ea.require("util").types; return n || Ou && Ou.binding && Ou.binding("util"); } catch { } }(); var Hp = Gp && Gp.isTypedArray; var e0 = Hp ? wA(Hp) : MA; var SA = Object.prototype; var _A = SA.hasOwnProperty; function TA(n, e) { var t = pi(n), i = !t && Wd(n), r = !t && !i && kh(n), s = !t && !i && !r && e0(n), o = t || i || r || s, a = o ? W1(n.length, String) : [], c = a.length; for (var l in n) _A.call(n, l) && !(o && // Safari 9 has enumerable `arguments.length` in strict mode. (l == "length" || // Node.js 0.10 has enumerable non-index properties on buffers. r && (l == "offset" || l == "parent") || // PhantomJS 2 has enumerable non-index properties on typed arrays. s && (l == "buffer" || l == "byteLength" || l == "byteOffset") || // Skip index properties. kd(l, c))) && a.push(l); return a; } function EA(n, e) { return function(t) { return n(e(t)); }; } var CA = EA(Object.keys, Object); var LA = Object.prototype; var RA = LA.hasOwnProperty; function FA(n) { if (!H1(n)) return CA(n); var e = []; for (var t in Object(n)) RA.call(n, t) && t != "constructor" && e.push(t); return e; } function t0(n) { return k1(n) ? TA(n) : FA(n); } var PA = /\.|\[(?:[^[\]]*|(["'])(?:(?!\1)[^\\]|\\.)*?\1)\]/; var IA = /^\w*$/; function jd(n, e) { if (pi(n)) return false; var t = typeof n; return t == "number" || t == "symbol" || t == "boolean" || n == null || Jc(n) ? true : IA.test(n) || !PA.test(n) || e != null && n in Object(e); } var Da = Ds(Object, "create"); function OA() { this.__data__ = Da ? Da(null) : {}, this.size = 0; } function DA(n) { var e = this.has(n) && delete this.__data__[n]; return this.size -= e ? 1 : 0, e; } var NA = "__lodash_hash_undefined__"; var BA = Object.prototype; var UA = BA.hasOwnProperty; function zA(n) { var e = this.__data__; if (Da) { var t = e[n]; return t === NA ? void 0 : t; } return UA.call(e, n) ? e[n] : void 0; } var VA = Object.prototype; var kA = VA.hasOwnProperty; function GA(n) { var e = this.__data__; return Da ? e[n] !== void 0 : kA.call(e, n); } var HA = "__lodash_hash_undefined__"; function WA(n, e) { var t = this.__data__; return this.size += this.has(n) ? 0 : 1, t[n] = Da && e === void 0 ? HA : e, this; } function _s(n) { var e = -1, t = n == null ? 0 : n.length; for (this.clear(); ++e < t; ) { var i = n[e]; this.set(i[0], i[1]); } } _s.prototype.clear = OA; _s.prototype.delete = DA; _s.prototype.get = zA; _s.prototype.has = GA; _s.prototype.set = WA; function jA() { this.__data__ = [], this.size = 0; } function Kc(n, e) { for (var t = n.length; t--; ) if (Gd(n[t][0], e)) return t; return -1; } var $A = Array.prototype; var ZA = $A.splice; function XA(n) { var e = this.__data__, t = Kc(e, n); if (t < 0) return false; var i = e.length - 1; return t == i ? e.pop() : ZA.call(e, t, 1), --this.size, true; } function YA(n) { var e = this.__data__, t = Kc(e, n); return t < 0 ? void 0 : e[t][1]; } function JA(n) { return Kc(this.__data__, n) > -1; } function KA(n, e) { var t = this.__data__, i = Kc(t, n); return i < 0 ? (++this.size, t.push([n, e])) : t[i][1] = e, this; } function lr(n) { var e = -1, t = n == null ? 0 : n.length; for (this.clear(); ++e < t; ) { var i = n[e]; this.set(i[0], i[1]); } } lr.prototype.clear = jA; lr.prototype.delete = XA; lr.prototype.get = YA; lr.prototype.has = JA; lr.prototype.set = KA; var Na = Ds(Bi, "Map"); function qA() { this.size = 0, this.__data__ = { hash: new _s(), map: new (Na || lr)(), string: new _s() }; } function QA(n) { var e = typeof n; return e == "string" || e == "number" || e == "symbol" || e == "boolean" ? n !== "__proto__" : n === null; } function qc(n, e) { var t = n.__data__; return QA(e) ? t[typeof e == "string" ? "string" : "hash"] : t.map; } function eS(n) { var e = qc(this, n).delete(n); return this.size -= e ? 1 : 0, e; } function tS(n) { return qc(this, n).get(n); } function nS(n) { return qc(this, n).has(n); } function iS(n, e) { var t = qc(this, n), i = t.size; return t.set(n, e), this.size += t.size == i ? 0 : 1, this; } function cr(n) { var e = -1, t = n == null ? 0 : n.length; for (this.clear(); ++e < t; ) { var i = n[e]; this.set(i[0], i[1]); } } cr.prototype.clear = qA; cr.prototype.delete = eS; cr.prototype.get = tS; cr.prototype.has = nS; cr.prototype.set = iS; var rS = "Expected a function"; function $d(n, e) { if (typeof n != "function" || e != null && typeof e != "function") throw new TypeError(rS); var t = function() { var i = arguments, r = e ? e.apply(this, i) : i[0], s = t.cache; if (s.has(r)) return s.get(r); var o = n.apply(this, i); return t.cache = s.set(r, o) || s, o; }; return t.cache = new ($d.Cache || cr)(), t; } $d.Cache = cr; var sS = 500; function oS(n) { var e = $d(n, function(i) { return t.size === sS && t.clear(), i; }), t = e.cache; return e; } var aS = /[^.[\]]+|\[(?:(-?\d+(?:\.\d+)?)|(["'])((?:(?!\2)[^\\]|\\.)*?)\2)\]|(?=(?:\.|\[\])(?:\.|\[\]|$))/g; var lS = /\\(\\)?/g; var cS = oS(function(n) { var e = []; return n.charCodeAt(0) === 46 && e.push(""), n.replace(aS, function(t, i, r, s) { e.push(r ? s.replace(lS, "$1") : i || t); }), e; }); function uS(n) { return n == null ? "" : Xv(n); } function Qc(n, e) { return pi(n) ? n : jd(n, e) ? [n] : cS(uS(n)); } var hS = 1 / 0; function nl(n) { if (typeof n == "string" || Jc(n)) return n; var e = n + ""; return e == "0" && 1 / n == -hS ? "-0" : e; } function Zd(n, e) { e = Qc(e, n); for (var t = 0, i = e.length; n != null && t < i; ) n = n[nl(e[t++])]; return t && t == i ? n : void 0; } function Ji(n, e, t) { var i = n == null ? void 0 : Zd(n, e); return i === void 0 ? t : i; } function n0(n, e) { for (var t = -1, i = e.length, r = n.length; ++t < i; ) n[r + t] = e[t]; return n; } var Wp = Pi ? Pi.isConcatSpreadable : void 0; function dS(n) { return pi(n) || Wd(n) || !!(Wp && n && n[Wp]); } function fS(n, e, t, i, r) { var s = -1, o = n.length; for (t || (t = dS), r || (r = []); ++s < o; ) { var a = n[s]; t(a) ? n0(r, a) : r[r.length] = a; } return r; } function pS(n) { var e = n == null ? 0 : n.length; return e ? fS(n) : []; } function mS(n) { return F1(z1(n, void 0, pS), n + ""); } function Si() { if (!arguments.length) return []; var n = arguments[0]; return pi(n) ? n : [n]; } function gS() { this.__data__ = new lr(), this.size = 0; } function vS(n) { var e = this.__data__, t = e.delete(n); return this.size = e.size, t; } function yS(n) { return this.__data__.get(n); } function bS(n) { return this.__data__.has(n); } var xS = 200; function MS(n, e) { var t = this.__data__; if (t instanceof lr) { var i = t.__data__; if (!Na || i.length < xS - 1) return i.push([n, e]), this.size = ++t.size, this; t = this.__data__ = new cr(i); } return t.set(n, e), this.size = t.size, this; } function er(n) { var e = this.__data__ = new lr(n); this.size = e.size; } er.prototype.clear = gS; er.prototype.delete = vS; er.prototype.get = yS; er.prototype.has = bS; er.prototype.set = MS; function wS(n, e) { for (var t = -1, i = n == null ? 0 : n.length, r = 0, s = []; ++t < i; ) { var o = n[t]; e(o, t, n) && (s[r++] = o); } return s; } function AS() { return []; } var SS = Object.prototype; var _S = SS.propertyIsEnumerable; var jp = Object.getOwnPropertySymbols; var TS = jp ? function(n) { return n == null ? [] : (n = Object(n), wS(jp(n), function(e) { return _S.call(n, e); })); } : AS; function ES(n, e, t) { var i = e(n); return pi(n) ? i : n0(i, t(n)); } function $p(n) { return ES(n, t0, TS); } var Gh = Ds(Bi, "DataView"); var Hh = Ds(Bi, "Promise"); var Wh = Ds(Bi, "Set"); var Zp = "[object Map]"; var CS = "[object Object]"; var Xp = "[object Promise]"; var Yp = "[object Set]"; var Jp = "[object WeakMap]"; var Kp = "[object DataView]"; var LS = Os(Gh); var RS = Os(Na); var FS = Os(Hh); var PS = Os(Wh); var IS = Os(Vh); var Cr = Zo; (Gh && Cr(new Gh(new ArrayBuffer(1))) != Kp || Na && Cr(new Na()) != Zp || Hh && Cr(Hh.resolve()) != Xp || Wh && Cr(new Wh()) != Yp || Vh && Cr(new Vh()) != Jp) && (Cr = function(n) { var e = Zo(n), t = e == CS ? n.constructor : void 0, i = t ? Os(t) : ""; if (i) switch (i) { case LS: return Kp; case RS: return Zp; case FS: return Xp; case PS: return Yp; case IS: return Jp; } return e; }); var qp = Bi.Uint8Array; var OS = "__lodash_hash_undefined__"; function DS(n) { return this.__data__.set(n, OS), this; } function NS(n) { return this.__data__.has(n); } function Pc(n) { var e = -1, t = n == null ? 0 : n.length; for (this.__data__ = new cr(); ++e < t; ) this.add(n[e]); } Pc.prototype.add = Pc.prototype.push = DS; Pc.prototype.has = NS; function BS(n, e) { for (var t = -1, i = n == null ? 0 : n.length; ++t < i; ) if (e(n[t], t, n)) return true; return false; } function US(n, e) { return n.has(e); } var zS = 1; var VS = 2; function i0(n, e, t, i, r, s) { var o = t & zS, a = n.length, c = e.length; if (a != c && !(o && c > a)) return false; var l = s.get(n), d = s.get(e); if (l && d) return l == e && d == n; var h6 = -1, f = true, g = t & VS ? new Pc() : void 0; for (s.set(n, e), s.set(e, n); ++h6 < a; ) { var p = n[h6], u = e[h6]; if (i) var y = o ? i(u, p, h6, e, n, s) : i(p, u, h6, n, e, s); if (y !== void 0) { if (y) continue; f = false; break; } if (g) { if (!BS(e, function(v, m) { if (!US(g, m) && (p === v || r(p, v, t, i, s))) return g.push(m); })) { f = false; break; } } else if (!(p === u || r(p, u, t, i, s))) { f = false; break; } } return s.delete(n), s.delete(e), f; } function kS(n) { var e = -1, t = Array(n.size); return n.forEach(function(i, r) { t[++e] = [r, i]; }), t; } function GS(n) { var e = -1, t = Array(n.size); return n.forEach(function(i) { t[++e] = i; }), t; } var HS = 1; var WS = 2; var jS = "[object Boolean]"; var $S = "[object Date]"; var ZS = "[object Error]"; var XS = "[object Map]"; var YS = "[object Number]"; var JS = "[object RegExp]"; var KS = "[object Set]"; var qS = "[object String]"; var QS = "[object Symbol]"; var e_ = "[object ArrayBuffer]"; var t_ = "[object DataView]"; var Qp = Pi ? Pi.prototype : void 0; var Du = Qp ? Qp.valueOf : void 0; function n_(n, e, t, i, r, s, o) { switch (t) { case t_: if (n.byteLength != e.byteLength || n.byteOffset != e.byteOffset) return false; n = n.buffer, e = e.buffer; case e_: return !(n.byteLength != e.byteLength || !s(new qp(n), new qp(e))); case jS: case $S: case YS: return Gd(+n, +e); case ZS: return n.name == e.name && n.message == e.message; case JS: case qS: return n == e + ""; case XS: var a = kS; case KS: var c = i & HS; if (a || (a = GS), n.size != e.size && !c) return false; var l = o.get(n); if (l) return l == e; i |= WS, o.set(n, e); var d = i0(a(n), a(e), i, r, s, o); return o.delete(n), d; case QS: if (Du) return Du.call(n) == Du.call(e); } return false; } var i_ = 1; var r_ = Object.prototype; var s_ = r_.hasOwnProperty; function o_(n, e, t, i, r, s) { var o = t & i_, a = $p(n), c = a.length, l = $p(e), d = l.length; if (c != d && !o) return false; for (var h6 = c; h6--; ) { var f = a[h6]; if (!(o ? f in e : s_.call(e, f))) return false; } var g = s.get(n), p = s.get(e); if (g && p) return g == e && p == n; var u = true; s.set(n, e), s.set(e, n); for (var y = o; ++h6 < c; ) { f = a[h6]; var v = n[f], m = e[f]; if (i) var x = o ? i(m, v, f, e, n, s) : i(v, m, f, n, e, s); if (!(x === void 0 ? v === m || r(v, m, t, i, s) : x)) { u = false; break; } y || (y = f == "constructor"); } if (u && !y) { var w = n.constructor, A = e.constructor; w != A && "constructor" in n && "constructor" in e && !(typeof w == "function" && w instanceof w && typeof A == "function" && A instanceof A) && (u = false); } return s.delete(n), s.delete(e), u; } var a_ = 1; var em = "[object Arguments]"; var tm = "[object Array]"; var _l = "[object Object]"; var l_ = Object.prototype; var nm = l_.hasOwnProperty; function c_(n, e, t, i, r, s) { var o = pi(n), a = pi(e), c = o ? tm : Cr(n), l = a ? tm : Cr(e); c = c == em ? _l : c, l = l == em ? _l : l; var d = c == _l, h6 = l == _l, f = c == l; if (f && kh(n)) { if (!kh(e)) return false; o = true, d = false; } if (f && !d) return s || (s = new er()), o || e0(n) ? i0(n, e, t, i, r, s) : n_(n, e, c, t, i, r, s); if (!(t & a_)) { var g = d && nm.call(n, "__wrapped__"), p = h6 && nm.call(e, "__wrapped__"); if (g || p) { var u = g ? n.value() : n, y = p ? e.value() : e; return s || (s = new er()), r(u, y, t, i, s); } } return f ? (s || (s = new er()), o_(n, e, t, i, r, s)) : false; } function eu(n, e, t, i, r) { return n === e ? true : n == null || e == null || !Mo(n) && !Mo(e) ? n !== n && e !== e : c_(n, e, t, i, eu, r); } var u_ = 1; var h_ = 2; function d_(n, e, t, i) { var r = t.length, s = r; if (n == null) return !s; for (n = Object(n); r--; ) { var o = t[r]; if (o[2] ? o[1] !== n[o[0]] : !(o[0] in n)) return false; } for (; ++r < s; ) { o = t[r]; var a = o[0], c = n[a], l = o[1]; if (o[2]) { if (c === void 0 && !(a in n)) return false; } else { var d = new er(), h6; if (!(h6 === void 0 ? eu(l, c, u_ | h_, i, d) : h6)) return false; } } return true; } function r0(n) { return n === n && !Ur(n); } function f_(n) { for (var e = t0(n), t = e.length; t--; ) { var i = e[t], r = n[i]; e[t] = [i, r, r0(r)]; } return e; } function s0(n, e) { return function(t) { return t == null ? false : t[n] === e && (e !== void 0 || n in Object(t)); }; } function p_(n) { var e = f_(n); return e.length == 1 && e[0][2] ? s0(e[0][0], e[0][1]) : function(t) { return t === n || d_(t, n, e); }; } function m_(n, e) { return n != null && e in Object(n); } function g_(n, e, t) { e = Qc(e, n); for (var i = -1, r = e.length, s = false; ++i < r; ) { var o = nl(e[i]); if (!(s = n != null && t(n, o))) break; n = n[o]; } return s || ++i != r ? s : (r = n == null ? 0 : n.length, !!r && Hd(r) && kd(o, r) && (pi(n) || Wd(n))); } function o0(n, e) { return n != null && g_(n, e, m_); } var v_ = 1; var y_ = 2; function b_(n, e) { return jd(n) && r0(e) ? s0(nl(n), e) : function(t) { var i = Ji(t, n); return i === void 0 && i === e ? o0(t, n) : eu(e, i, v_ | y_); }; } function x_(n) { return function(e) { return e == null ? void 0 : e[n]; }; } function M_(n) { return function(e) { return Zd(e, n); }; } function w_(n) { return jd(n) ? x_(nl(n)) : M_(n); } function A_(n) { return typeof n == "function" ? n : n == null ? Yv : typeof n == "object" ? pi(n) ? b_(n[0], n[1]) : p_(n) : w_(n); } var Nu = function() { return Bi.Date.now(); }; var S_ = "Expected a function"; var __ = Math.max; var T_ = Math.min; function jh(n, e, t) { var i, r, s, o, a, c, l = 0, d = false, h6 = false, f = true; if (typeof n != "function") throw new TypeError(S_); e = Np(e) || 0, Ur(t) && (d = !!t.leading, h6 = "maxWait" in t, s = h6 ? __(Np(t.maxWait) || 0, e) : s, f = "trailing" in t ? !!t.trailing : f); function g(M) { var R = i, L = r; return i = r = void 0, l = M, o = n.apply(L, R), o; } function p(M) { return l = M, a = setTimeout(v, e), d ? g(M) : o; } function u(M) { var R = M - c, L = M - l, S = e - R; return h6 ? T_(S, s - L) : S; } function y(M) { var R = M - c, L = M - l; return c === void 0 || R >= e || R < 0 || h6 && L >= s; } function v() { var M = Nu(); if (y(M)) return m(M); a = setTimeout(v, u(M)); } function m(M) { return a = void 0, f && i ? g(M) : (i = r = void 0, o); } function x() { a !== void 0 && clearTimeout(a), l = 0, i = c = r = a = void 0; } function w() { return a === void 0 ? o : m(Nu()); } function A() { var M = Nu(), R = y(M); if (i = arguments, r = this, c = M, R) { if (a === void 0) return p(c); if (h6) return clearTimeout(a), a = setTimeout(v, e), g(c); } return a === void 0 && (a = setTimeout(v, e)), o; } return A.cancel = x, A.flush = w, A; } function E_(n, e, t) { var i = n == null ? 0 : n.length; if (!i) return -1; var r = i - 1; return P1(n, A_(e), r); } function Ic(n) { for (var e = -1, t = n == null ? 0 : n.length, i = {}; ++e < t; ) { var r = n[e]; i[r[0]] = r[1]; } return i; } function $h(n, e) { return eu(n, e); } function Ci(n) { return n == null; } function C_(n) { return n === void 0; } function L_(n, e, t, i) { if (!Ur(n)) return n; e = Qc(e, n); for (var r = -1, s = e.length, o = s - 1, a = n; a != null && ++r < s; ) { var c = nl(e[r]), l = t; if (c === "__proto__" || c === "constructor" || c === "prototype") return n; if (r != o) { var d = a[c]; l = void 0, l === void 0 && (l = Ur(d) ? d : kd(e[r + 1]) ? [] : {}); } U1(a, c, l), a = a[c]; } return n; } function R_(n, e, t) { for (var i = -1, r = e.length, s = {}; ++i < r; ) { var o = e[i], a = Zd(n, o); t(a, o) && L_(s, Qc(o, n), a); } return s; } function F_(n, e) { return R_(n, e, function(t, i) { return o0(n, i); }); } var P_ = mS(function(n, e) { return n == null ? {} : F_(n, e); }); var di = (n) => n === void 0; var Ba = (n) => typeof n == "boolean"; var yt = (n) => typeof n == "number"; var ys = (n) => typeof Element > "u" ? false : n instanceof Element; var im = (n) => Ci(n); var I_ = (n) => vn(n) ? !Number.isNaN(Number(n)) : false; var O_ = (n = "") => n.replace(/[|\\{}()[\]^$+*?.]/g, "\\$&").replace(/-/g, "\\x2d"); var Rr = (n) => kw(n); var rm = (n) => Object.keys(n); var a0 = class extends Error { constructor(e) { super(e), this.name = "ElementPlusError"; } }; function Xo(n, e) { throw new a0(`[${n}] ${e}`); } function Vt(n, e) { if (true) { const t = vn(n) ? new a0(`[${n}] ${e}`) : n; console.warn(t); } } var D_ = "utils/dom/style"; var l0 = (n = "") => n.split(" ").filter((e) => !!e.trim()); var sm = (n, e) => { !n || !e.trim() || n.classList.add(...l0(e)); }; var Oc = (n, e) => { !n || !e.trim() || n.classList.remove(...l0(e)); }; var ca = (n, e) => { var t; if (!en || !n || !e) return ""; let i = Uw(e); i === "float" && (i = "cssFloat"); try { const r = n.style[i]; if (r) return r; const s = (t = document.defaultView) == null ? void 0 : t.getComputedStyle(n, ""); return s ? s[i] : ""; } catch { return n.style[i]; } }; function Dc(n, e = "px") { if (!n) return ""; if (yt(n) || I_(n)) return `${n}${e}`; if (vn(n)) return n; Vt(D_, "binding value must be a string or number"); } function N_(n, e) { if (!en) return; if (!e) { n.scrollTop = 0; return; } const t = []; let i = e.offsetParent; for (; i !== null && n !== i && n.contains(i); ) t.push(i), i = i.offsetParent; const r = e.offsetTop + t.reduce((c, l) => c + l.offsetTop, 0), s = r + e.offsetHeight, o = n.scrollTop, a = o + n.clientHeight; r < o ? n.scrollTop = r : s > a && (n.scrollTop = s - n.clientHeight); } var B_ = defineComponent({ name: "ArrowDown", __name: "arrow-down", setup(n) { return (e, t) => (openBlock(), createElementBlock("svg", { xmlns: "http://www.w3.org/2000/svg", viewBox: "0 0 1024 1024" }, [ createBaseVNode("path", { fill: "currentColor", d: "M831.872 340.864 512 652.672 192.128 340.864a30.592 30.592 0 0 0-42.752 0 29.12 29.12 0 0 0 0 41.6L489.664 714.24a32 32 0 0 0 44.672 0l340.288-331.712a29.12 29.12 0 0 0 0-41.728 30.592 30.592 0 0 0-42.752 0z" }) ])); } }); var Xd = B_; var U_ = defineComponent({ name: "ArrowLeft", __name: "arrow-left", setup(n) { return (e, t) => (openBlock(), createElementBlock("svg", { xmlns: "http://www.w3.org/2000/svg", viewBox: "0 0 1024 1024" }, [ createBaseVNode("path", { fill: "currentColor", d: "M609.408 149.376 277.76 489.6a32 32 0 0 0 0 44.672l331.648 340.352a29.12 29.12 0 0 0 41.728 0 30.592 30.592 0 0 0 0-42.752L339.264 511.936l311.872-319.872a30.592 30.592 0 0 0 0-42.688 29.12 29.12 0 0 0-41.728 0z" }) ])); } }); var zr = U_; var z_ = defineComponent({ name: "ArrowRight", __name: "arrow-right", setup(n) { return (e, t) => (openBlock(), createElementBlock("svg", { xmlns: "http://www.w3.org/2000/svg", viewBox: "0 0 1024 1024" }, [ createBaseVNode("path", { fill: "currentColor", d: "M340.864 149.312a30.592 30.592 0 0 0 0 42.752L652.736 512 340.864 831.872a30.592 30.592 0 0 0 0 42.752 29.12 29.12 0 0 0 41.728 0L714.24 534.336a32 32 0 0 0 0-44.672L382.592 149.376a29.12 29.12 0 0 0-41.728 0z" }) ])); } }); var Vr = z_; var V_ = defineComponent({ name: "ArrowUp", __name: "arrow-up", setup(n) { return (e, t) => (openBlock(), createElementBlock("svg", { xmlns: "http://www.w3.org/2000/svg", viewBox: "0 0 1024 1024" }, [ createBaseVNode("path", { fill: "currentColor", d: "m488.832 344.32-339.84 356.672a32 32 0 0 0 0 44.16l.384.384a29.44 29.44 0 0 0 42.688 0l320-335.872 319.872 335.872a29.44 29.44 0 0 0 42.688 0l.384-.384a32 32 0 0 0 0-44.16L535.168 344.32a32 32 0 0 0-46.336 0" }) ])); } }); var k_ = V_; var G_ = defineComponent({ name: "CircleCheck", __name: "circle-check", setup(n) { return (e, t) => (openBlock(), createElementBlock("svg", { xmlns: "http://www.w3.org/2000/svg", viewBox: "0 0 1024 1024" }, [ createBaseVNode("path", { fill: "currentColor", d: "M512 896a384 384 0 1 0 0-768 384 384 0 0 0 0 768m0 64a448 448 0 1 1 0-896 448 448 0 0 1 0 896" }), createBaseVNode("path", { fill: "currentColor", d: "M745.344 361.344a32 32 0 0 1 45.312 45.312l-288 288a32 32 0 0 1-45.312 0l-160-160a32 32 0 1 1 45.312-45.312L480 626.752l265.344-265.408z" }) ])); } }); var H_ = G_; var W_ = defineComponent({ name: "CircleClose", __name: "circle-close", setup(n) { return (e, t) => (openBlock(), createElementBlock("svg", { xmlns: "http://www.w3.org/2000/svg", viewBox: "0 0 1024 1024" }, [ createBaseVNode("path", { fill: "currentColor", d: "m466.752 512-90.496-90.496a32 32 0 0 1 45.248-45.248L512 466.752l90.496-90.496a32 32 0 1 1 45.248 45.248L557.248 512l90.496 90.496a32 32 0 1 1-45.248 45.248L512 557.248l-90.496 90.496a32 32 0 0 1-45.248-45.248z" }), createBaseVNode("path", { fill: "currentColor", d: "M512 896a384 384 0 1 0 0-768 384 384 0 0 0 0 768m0 64a448 448 0 1 1 0-896 448 448 0 0 1 0 896" }) ])); } }); var Yd = W_; var j_ = defineComponent({ name: "Close", __name: "close", setup(n) { return (e, t) => (openBlock(), createElementBlock("svg", { xmlns: "http://www.w3.org/2000/svg", viewBox: "0 0 1024 1024" }, [ createBaseVNode("path", { fill: "currentColor", d: "M764.288 214.592 512 466.88 259.712 214.592a31.936 31.936 0 0 0-45.12 45.12L466.752 512 214.528 764.224a31.936 31.936 0 1 0 45.12 45.184L512 557.184l252.288 252.288a31.936 31.936 0 0 0 45.12-45.12L557.12 512.064l252.288-252.352a31.936 31.936 0 1 0-45.12-45.184z" }) ])); } }); var Zh = j_; var $_ = defineComponent({ name: "Delete", __name: "delete", setup(n) { return (e, t) => (openBlock(), createElementBlock("svg", { xmlns: "http://www.w3.org/2000/svg", viewBox: "0 0 1024 1024" }, [ createBaseVNode("path", { fill: "currentColor", d: "M160 256H96a32 32 0 0 1 0-64h256V95.936a32 32 0 0 1 32-32h256a32 32 0 0 1 32 32V192h256a32 32 0 1 1 0 64h-64v672a32 32 0 0 1-32 32H192a32 32 0 0 1-32-32zm448-64v-64H416v64zM224 896h576V256H224zm192-128a32 32 0 0 1-32-32V416a32 32 0 0 1 64 0v320a32 32 0 0 1-32 32m192 0a32 32 0 0 1-32-32V416a32 32 0 0 1 64 0v320a32 32 0 0 1-32 32" }) ])); } }); var Nc = $_; var Z_ = defineComponent({ name: "Hide", __name: "hide", setup(n) { return (e, t) => (openBlock(), createElementBlock("svg", { xmlns: "http://www.w3.org/2000/svg", viewBox: "0 0 1024 1024" }, [ createBaseVNode("path", { fill: "currentColor", d: "M876.8 156.8c0-9.6-3.2-16-9.6-22.4-6.4-6.4-12.8-9.6-22.4-9.6-9.6 0-16 3.2-22.4 9.6L736 220.8c-64-32-137.6-51.2-224-60.8-160 16-288 73.6-377.6 176C44.8 438.4 0 496 0 512s48 73.6 134.4 176c22.4 25.6 44.8 48 73.6 67.2l-86.4 89.6c-6.4 6.4-9.6 12.8-9.6 22.4 0 9.6 3.2 16 9.6 22.4 6.4 6.4 12.8 9.6 22.4 9.6 9.6 0 16-3.2 22.4-9.6l704-710.4c3.2-6.4 6.4-12.8 6.4-22.4Zm-646.4 528c-76.8-70.4-128-128-153.6-172.8 28.8-48 80-105.6 153.6-172.8C304 272 400 230.4 512 224c64 3.2 124.8 19.2 176 44.8l-54.4 54.4C598.4 300.8 560 288 512 288c-64 0-115.2 22.4-160 64s-64 96-64 160c0 48 12.8 89.6 35.2 124.8L256 707.2c-9.6-6.4-19.2-16-25.6-22.4Zm140.8-96c-12.8-22.4-19.2-48-19.2-76.8 0-44.8 16-83.2 48-112 32-28.8 67.2-48 112-48 28.8 0 54.4 6.4 73.6 19.2zM889.599 336c-12.8-16-28.8-28.8-41.6-41.6l-48 48c73.6 67.2 124.8 124.8 150.4 169.6-28.8 48-80 105.6-153.6 172.8-73.6 67.2-172.8 108.8-284.8 115.2-51.2-3.2-99.2-12.8-140.8-28.8l-48 48c57.6 22.4 118.4 38.4 188.8 44.8 160-16 288-73.6 377.6-176C979.199 585.6 1024 528 1024 512s-48.001-73.6-134.401-176Z" }), createBaseVNode("path", { fill: "currentColor", d: "M511.998 672c-12.8 0-25.6-3.2-38.4-6.4l-51.2 51.2c28.8 12.8 57.6 19.2 89.6 19.2 64 0 115.2-22.4 160-64 41.6-41.6 64-96 64-160 0-32-6.4-64-19.2-89.6l-51.2 51.2c3.2 12.8 6.4 25.6 6.4 38.4 0 44.8-16 83.2-48 112-32 28.8-67.2 48-112 48Z" }) ])); } }); var X_ = Z_; var Y_ = defineComponent({ name: "Loading", __name: "loading", setup(n) { return (e, t) => (openBlock(), createElementBlock("svg", { xmlns: "http://www.w3.org/2000/svg", viewBox: "0 0 1024 1024" }, [ createBaseVNode("path", { fill: "currentColor", d: "M512 64a32 32 0 0 1 32 32v192a32 32 0 0 1-64 0V96a32 32 0 0 1 32-32m0 640a32 32 0 0 1 32 32v192a32 32 0 1 1-64 0V736a32 32 0 0 1 32-32m448-192a32 32 0 0 1-32 32H736a32 32 0 1 1 0-64h192a32 32 0 0 1 32 32m-640 0a32 32 0 0 1-32 32H96a32 32 0 0 1 0-64h192a32 32 0 0 1 32 32M195.2 195.2a32 32 0 0 1 45.248 0L376.32 331.008a32 32 0 0 1-45.248 45.248L195.2 240.448a32 32 0 0 1 0-45.248zm452.544 452.544a32 32 0 0 1 45.248 0L828.8 783.552a32 32 0 0 1-45.248 45.248L647.744 692.992a32 32 0 0 1 0-45.248zM828.8 195.264a32 32 0 0 1 0 45.184L692.992 376.32a32 32 0 0 1-45.248-45.248l135.808-135.808a32 32 0 0 1 45.248 0m-452.544 452.48a32 32 0 0 1 0 45.248L240.448 828.8a32 32 0 0 1-45.248-45.248l135.808-135.808a32 32 0 0 1 45.248 0z" }) ])); } }); var c0 = Y_; var J_ = defineComponent({ name: "Minus", __name: "minus", setup(n) { return (e, t) => (openBlock(), createElementBlock("svg", { xmlns: "http://www.w3.org/2000/svg", viewBox: "0 0 1024 1024" }, [ createBaseVNode("path", { fill: "currentColor", d: "M128 544h768a32 32 0 1 0 0-64H128a32 32 0 0 0 0 64" }) ])); } }); var K_ = J_; var q_ = defineComponent({ name: "Plus", __name: "plus", setup(n) { return (e, t) => (openBlock(), createElementBlock("svg", { xmlns: "http://www.w3.org/2000/svg", viewBox: "0 0 1024 1024" }, [ createBaseVNode("path", { fill: "currentColor", d: "M480 480V128a32 32 0 0 1 64 0v352h352a32 32 0 1 1 0 64H544v352a32 32 0 1 1-64 0V544H128a32 32 0 0 1 0-64z" }) ])); } }); var tu = q_; var Q_ = defineComponent({ name: "View", __name: "view", setup(n) { return (e, t) => (openBlock(), createElementBlock("svg", { xmlns: "http://www.w3.org/2000/svg", viewBox: "0 0 1024 1024" }, [ createBaseVNode("path", { fill: "currentColor", d: "M512 160c320 0 512 352 512 352S832 864 512 864 0 512 0 512s192-352 512-352m0 64c-225.28 0-384.128 208.064-436.8 288 52.608 79.872 211.456 288 436.8 288 225.28 0 384.128-208.064 436.8-288-52.608-79.872-211.456-288-436.8-288zm0 64a224 224 0 1 1 0 448 224 224 0 0 1 0-448m0 64a160.192 160.192 0 0 0-160 160c0 88.192 71.744 160 160 160s160-71.808 160-160-71.744-160-160-160" }) ])); } }); var eT = Q_; var tT = defineComponent({ name: "WarningFilled", __name: "warning-filled", setup(n) { return (e, t) => (openBlock(), createElementBlock("svg", { xmlns: "http://www.w3.org/2000/svg", viewBox: "0 0 1024 1024" }, [ createBaseVNode("path", { fill: "currentColor", d: "M512 64a448 448 0 1 1 0 896 448 448 0 0 1 0-896m0 192a58.432 58.432 0 0 0-58.24 63.744l23.36 256.384a35.072 35.072 0 0 0 69.76 0l23.296-256.384A58.432 58.432 0 0 0 512 256m0 512a51.2 51.2 0 1 0 0-102.4 51.2 51.2 0 0 0 0 102.4" }) ])); } }); var u0 = tT; var h0 = "__epPropKey"; var Je = (n) => n; var nT = (n) => Tn(n) && !!n[h0]; var nu = (n, e) => { if (!Tn(n) || nT(n)) return n; const { values: t, required: i, default: r, type: s, validator: o } = n, c = { type: s, required: !!i, validator: t || o ? (l) => { let d = false, h6 = []; if (t && (h6 = Array.from(t), Fp(n, "default") && h6.push(r), d || (d = h6.includes(l))), o && (d || (d = o(l))), !d && h6.length > 0) { const f = [...new Set(h6)].map((g) => JSON.stringify(g)).join(", "); warn(`Invalid prop: validation failed${e ? ` for prop "${e}"` : ""}. Expected one of [${f}], got value ${JSON.stringify(l)}.`); } return d; } : void 0, [h0]: true }; return Fp(n, "default") && (c.default = r), c; }; var at = (n) => Ic(Object.entries(n).map(([e, t]) => [ e, nu(t, e) ])); var kr = Je([ String, Object, Function ]); var d0 = { validating: c0, success: H_, error: Yd }; var on = (n, e) => { if (n.install = (t) => { for (const i of [n, ...Object.values(e ?? {})]) t.component(i.name, i); }, e) for (const [t, i] of Object.entries(e)) n[t] = i; return n; }; var iT = (n, e) => (n.install = (t) => { t.directive(e, n); }, n); var vi = (n) => (n.install = Oa, n); var Li = { tab: "Tab", enter: "Enter", space: "Space", left: "ArrowLeft", up: "ArrowUp", right: "ArrowRight", down: "ArrowDown", esc: "Escape", delete: "Delete", backspace: "Backspace", numpadEnter: "NumpadEnter", pageUp: "PageUp", pageDown: "PageDown", home: "Home", end: "End" }; var At = "update:modelValue"; var ur = "change"; var bs = "input"; var f0 = ["", "default", "small", "large"]; var Sc = (n) => { const e = Pn(n) ? n : [n], t = []; return e.forEach((i) => { var r; Pn(i) ? t.push(...Sc(i)) : isVNode(i) && Pn(i.children) ? t.push(...Sc(i.children)) : (t.push(i), isVNode(i) && ((r = i.component) != null && r.subTree) && t.push(...Sc(i.component.subTree))); }), t; }; var rT = (n) => /([\uAC00-\uD7AF\u3130-\u318F])+/gi.test(n); var Ki = (n) => n; var sT = ["class", "style"]; var oT = /^on[A-Z]/; var aT = (n = {}) => { const { excludeListeners: e = false, excludeKeys: t } = n, i = computed(() => ((t == null ? void 0 : t.value) || []).concat(sT)), r = getCurrentInstance(); return r ? computed(() => { var s; return Ic(Object.entries((s = r.proxy) == null ? void 0 : s.$attrs).filter(([o]) => !i.value.includes(o) && !(e && oT.test(o)))); }) : (Vt("use-attrs", "getCurrentInstance() returned null. useAttrs() must be called at the top of a setup function"), computed(() => ({}))); }; var p0 = ({ from: n, replacement: e, scope: t, version: i, ref: r, type: s = "API" }, o) => { watch(() => unref(o), (a) => { a && Vt(t, `[${s}] ${n} is about to be deprecated in version ${i}, please use ${e} instead. For more detail, please visit: ${r} `); }, { immediate: true }); }; var lT = { name: "en", el: { breadcrumb: { label: "Breadcrumb" }, colorpicker: { confirm: "OK", clear: "Clear", defaultLabel: "color picker", description: "current color is {color}. press enter to select a new color.", alphaLabel: "pick alpha value" }, datepicker: { now: "Now", today: "Today", cancel: "Cancel", clear: "Clear", confirm: "OK", dateTablePrompt: "Use the arrow keys and enter to select the day of the month", monthTablePrompt: "Use the arrow keys and enter to select the month", yearTablePrompt: "Use the arrow keys and enter to select the year", selectedDate: "Selected date", selectDate: "Select date", selectTime: "Select time", startDate: "Start Date", startTime: "Start Time", endDate: "End Date", endTime: "End Time", prevYear: "Previous Year", nextYear: "Next Year", prevMonth: "Previous Month", nextMonth: "Next Month", year: "", month1: "January", month2: "February", month3: "March", month4: "April", month5: "May", month6: "June", month7: "July", month8: "August", month9: "September", month10: "October", month11: "November", month12: "December", week: "week", weeks: { sun: "Sun", mon: "Mon", tue: "Tue", wed: "Wed", thu: "Thu", fri: "Fri", sat: "Sat" }, weeksFull: { sun: "Sunday", mon: "Monday", tue: "Tuesday", wed: "Wednesday", thu: "Thursday", fri: "Friday", sat: "Saturday" }, months: { jan: "Jan", feb: "Feb", mar: "Mar", apr: "Apr", may: "May", jun: "Jun", jul: "Jul", aug: "Aug", sep: "Sep", oct: "Oct", nov: "Nov", dec: "Dec" } }, inputNumber: { decrease: "decrease number", increase: "increase number" }, select: { loading: "Loading", noMatch: "No matching data", noData: "No data", placeholder: "Select" }, mention: { loading: "Loading" }, dropdown: { toggleDropdown: "Toggle Dropdown" }, cascader: { noMatch: "No matching data", loading: "Loading", placeholder: "Select", noData: "No data" }, pagination: { goto: "Go to", pagesize: "/page", total: "Total {total}", pageClassifier: "", page: "Page", prev: "Go to previous page", next: "Go to next page", currentPage: "page {pager}", prevPages: "Previous {pager} pages", nextPages: "Next {pager} pages", deprecationWarning: "Deprecated usages detected, please refer to the el-pagination documentation for more details" }, dialog: { close: "Close this dialog" }, drawer: { close: "Close this dialog" }, messagebox: { title: "Message", confirm: "OK", cancel: "Cancel", error: "Illegal input", close: "Close this dialog" }, upload: { deleteTip: "press delete to remove", delete: "Delete", preview: "Preview", continue: "Continue" }, slider: { defaultLabel: "slider between {min} and {max}", defaultRangeStartLabel: "pick start value", defaultRangeEndLabel: "pick end value" }, table: { emptyText: "No Data", confirmFilter: "Confirm", resetFilter: "Reset", clearFilter: "All", sumText: "Sum" }, tour: { next: "Next", previous: "Previous", finish: "Finish" }, tree: { emptyText: "No Data" }, transfer: { noMatch: "No matching data", noData: "No data", titles: ["List 1", "List 2"], filterPlaceholder: "Enter keyword", noCheckedFormat: "{total} items", hasCheckedFormat: "{checked}/{total} checked" }, image: { error: "FAILED" }, pageHeader: { title: "Back" }, popconfirm: { confirmButtonText: "Yes", cancelButtonText: "No" }, carousel: { leftArrow: "Carousel arrow left", rightArrow: "Carousel arrow right", indicator: "Carousel switch to index {index}" } } }; var cT = (n) => (e, t) => uT(e, t, unref(n)); var uT = (n, e, t) => Ji(t, n, n).replace(/\{(\w+)\}/g, (i, r) => { var s; return `${(s = e == null ? void 0 : e[r]) != null ? s : `{${r}}`}`; }); var hT = (n) => { const e = computed(() => unref(n).name), t = isRef(n) ? n : ref(n); return { lang: e, locale: t, t: cT(n) }; }; var m0 = Symbol("localeContextKey"); var iu = (n) => { const e = n || inject(m0, ref()); return hT(computed(() => e.value || lT)); }; var _c = "el"; var dT = "is-"; var rs = (n, e, t, i, r) => { let s = `${n}-${e}`; return t && (s += `-${t}`), i && (s += `__${i}`), r && (s += `--${r}`), s; }; var g0 = Symbol("namespaceContextKey"); var Jd = (n) => { const e = n || (getCurrentInstance() ? inject(g0, ref(_c)) : ref(_c)); return computed(() => unref(e) || _c); }; var nt = (n, e) => { const t = Jd(e); return { namespace: t, b: (u = "") => rs(t.value, n, u, "", ""), e: (u) => u ? rs(t.value, n, "", u, "") : "", m: (u) => u ? rs(t.value, n, "", "", u) : "", be: (u, y) => u && y ? rs(t.value, n, u, y, "") : "", em: (u, y) => u && y ? rs(t.value, n, "", u, y) : "", bm: (u, y) => u && y ? rs(t.value, n, u, "", y) : "", bem: (u, y, v) => u && y && v ? rs(t.value, n, u, y, v) : "", is: (u, ...y) => { const v = y.length >= 1 ? y[0] : true; return u && v ? `${dT}${u}` : ""; }, cssVar: (u) => { const y = {}; for (const v in u) u[v] && (y[`--${t.value}-${v}`] = u[v]); return y; }, cssVarName: (u) => `--${t.value}-${u}`, cssVarBlock: (u) => { const y = {}; for (const v in u) u[v] && (y[`--${t.value}-${n}-${v}`] = u[v]); return y; }, cssVarBlockName: (u) => `--${t.value}-${n}-${u}` }; }; var fT = nu({ type: Je(Boolean), default: null }); var pT = nu({ type: Je(Function) }); var mT = (n) => { const e = `update:${n}`, t = `onUpdate:${n}`, i = [e], r = { [n]: fT, [t]: pT }; return { useModelToggle: ({ indicator: o, toggleReason: a, shouldHideWhenRouteChanges: c, shouldProceed: l, onShow: d, onHide: h6 }) => { const f = getCurrentInstance(), { emit: g } = f, p = f.props, u = computed(() => Sn(p[t])), y = computed(() => p[n] === null), v = (R) => { o.value !== true && (o.value = true, a && (a.value = R), Sn(d) && d(R)); }, m = (R) => { o.value !== false && (o.value = false, a && (a.value = R), Sn(h6) && h6(R)); }, x = (R) => { if (p.disabled === true || Sn(l) && !l()) return; const L = u.value && en; L && g(e, true), (y.value || !L) && v(R); }, w = (R) => { if (p.disabled === true || !en) return; const L = u.value && en; L && g(e, false), (y.value || !L) && m(R); }, A = (R) => { Ba(R) && (p.disabled && R ? u.value && g(e, false) : o.value !== R && (R ? v() : m())); }, M = () => { o.value ? w() : x(); }; return watch(() => p[n], A), c && f.appContext.config.globalProperties.$route !== void 0 && watch(() => ({ ...f.proxy.$route }), () => { c.value && o.value && w(); }), onMounted(() => { A(p[n]); }), { hide: w, show: x, toggle: M, hasUpdateHandler: u }; }, useModelToggleProps: r, useModelToggleEmits: i }; }; var v0 = (n) => { const e = getCurrentInstance(); return computed(() => { var t, i; return (i = (t = e == null ? void 0 : e.proxy) == null ? void 0 : t.$props) == null ? void 0 : i[n]; }); }; var On = "top"; var qn = "bottom"; var Qn = "right"; var Dn = "left"; var Kd = "auto"; var il = [On, qn, Qn, Dn]; var wo = "start"; var Ua = "end"; var gT = "clippingParents"; var y0 = "viewport"; var ua = "popper"; var vT = "reference"; var om = il.reduce(function(n, e) { return n.concat([e + "-" + wo, e + "-" + Ua]); }, []); var Yo = [].concat(il, [Kd]).reduce(function(n, e) { return n.concat([e, e + "-" + wo, e + "-" + Ua]); }, []); var yT = "beforeRead"; var bT = "read"; var xT = "afterRead"; var MT = "beforeMain"; var wT = "main"; var AT = "afterMain"; var ST = "beforeWrite"; var _T = "write"; var TT = "afterWrite"; var ET = [yT, bT, xT, MT, wT, AT, ST, _T, TT]; function Ii(n) { return n ? (n.nodeName || "").toLowerCase() : null; } function yi(n) { if (n == null) return window; if (n.toString() !== "[object Window]") { var e = n.ownerDocument; return e && e.defaultView || window; } return n; } function Ao(n) { var e = yi(n).Element; return n instanceof e || n instanceof Element; } function Kn(n) { var e = yi(n).HTMLElement; return n instanceof e || n instanceof HTMLElement; } function qd(n) { if (typeof ShadowRoot > "u") return false; var e = yi(n).ShadowRoot; return n instanceof e || n instanceof ShadowRoot; } function CT(n) { var e = n.state; Object.keys(e.elements).forEach(function(t) { var i = e.styles[t] || {}, r = e.attributes[t] || {}, s = e.elements[t]; !Kn(s) || !Ii(s) || (Object.assign(s.style, i), Object.keys(r).forEach(function(o) { var a = r[o]; a === false ? s.removeAttribute(o) : s.setAttribute(o, a === true ? "" : a); })); }); } function LT(n) { var e = n.state, t = { popper: { position: e.options.strategy, left: "0", top: "0", margin: "0" }, arrow: { position: "absolute" }, reference: {} }; return Object.assign(e.elements.popper.style, t.popper), e.styles = t, e.elements.arrow && Object.assign(e.elements.arrow.style, t.arrow), function() { Object.keys(e.elements).forEach(function(i) { var r = e.elements[i], s = e.attributes[i] || {}, o = Object.keys(e.styles.hasOwnProperty(i) ? e.styles[i] : t[i]), a = o.reduce(function(c, l) { return c[l] = "", c; }, {}); !Kn(r) || !Ii(r) || (Object.assign(r.style, a), Object.keys(s).forEach(function(c) { r.removeAttribute(c); })); }); }; } var b0 = { name: "applyStyles", enabled: true, phase: "write", fn: CT, effect: LT, requires: ["computeStyles"] }; function Ri(n) { return n.split("-")[0]; } var xs = Math.max; var Bc = Math.min; var So = Math.round; function _o(n, e) { e === void 0 && (e = false); var t = n.getBoundingClientRect(), i = 1, r = 1; if (Kn(n) && e) { var s = n.offsetHeight, o = n.offsetWidth; o > 0 && (i = So(t.width) / o || 1), s > 0 && (r = So(t.height) / s || 1); } return { width: t.width / i, height: t.height / r, top: t.top / r, right: t.right / i, bottom: t.bottom / r, left: t.left / i, x: t.left / i, y: t.top / r }; } function Qd(n) { var e = _o(n), t = n.offsetWidth, i = n.offsetHeight; return Math.abs(e.width - t) <= 1 && (t = e.width), Math.abs(e.height - i) <= 1 && (i = e.height), { x: n.offsetLeft, y: n.offsetTop, width: t, height: i }; } function x0(n, e) { var t = e.getRootNode && e.getRootNode(); if (n.contains(e)) return true; if (t && qd(t)) { var i = e; do { if (i && n.isSameNode(i)) return true; i = i.parentNode || i.host; } while (i); } return false; } function rr(n) { return yi(n).getComputedStyle(n); } function RT(n) { return ["table", "td", "th"].indexOf(Ii(n)) >= 0; } function Xr(n) { return ((Ao(n) ? n.ownerDocument : n.document) || window.document).documentElement; } function ru(n) { return Ii(n) === "html" ? n : n.assignedSlot || n.parentNode || (qd(n) ? n.host : null) || Xr(n); } function am(n) { return !Kn(n) || rr(n).position === "fixed" ? null : n.offsetParent; } function FT(n) { var e = navigator.userAgent.toLowerCase().indexOf("firefox") !== -1, t = navigator.userAgent.indexOf("Trident") !== -1; if (t && Kn(n)) { var i = rr(n); if (i.position === "fixed") return null; } var r = ru(n); for (qd(r) && (r = r.host); Kn(r) && ["html", "body"].indexOf(Ii(r)) < 0; ) { var s = rr(r); if (s.transform !== "none" || s.perspective !== "none" || s.contain === "paint" || ["transform", "perspective"].indexOf(s.willChange) !== -1 || e && s.willChange === "filter" || e && s.filter && s.filter !== "none") return r; r = r.parentNode; } return null; } function rl(n) { for (var e = yi(n), t = am(n); t && RT(t) && rr(t).position === "static"; ) t = am(t); return t && (Ii(t) === "html" || Ii(t) === "body" && rr(t).position === "static") ? e : t || FT(n) || e; } function ef(n) { return ["top", "bottom"].indexOf(n) >= 0 ? "x" : "y"; } function Ca(n, e, t) { return xs(n, Bc(e, t)); } function PT(n, e, t) { var i = Ca(n, e, t); return i > t ? t : i; } function M0() { return { top: 0, right: 0, bottom: 0, left: 0 }; } function w0(n) { return Object.assign({}, M0(), n); } function A0(n, e) { return e.reduce(function(t, i) { return t[i] = n, t; }, {}); } var IT = function(n, e) { return n = typeof n == "function" ? n(Object.assign({}, e.rects, { placement: e.placement })) : n, w0(typeof n != "number" ? n : A0(n, il)); }; function OT(n) { var e, t = n.state, i = n.name, r = n.options, s = t.elements.arrow, o = t.modifiersData.popperOffsets, a = Ri(t.placement), c = ef(a), l = [Dn, Qn].indexOf(a) >= 0, d = l ? "height" : "width"; if (!(!s || !o)) { var h6 = IT(r.padding, t), f = Qd(s), g = c === "y" ? On : Dn, p = c === "y" ? qn : Qn, u = t.rects.reference[d] + t.rects.reference[c] - o[c] - t.rects.popper[d], y = o[c] - t.rects.reference[c], v = rl(s), m = v ? c === "y" ? v.clientHeight || 0 : v.clientWidth || 0 : 0, x = u / 2 - y / 2, w = h6[g], A = m - f[d] - h6[p], M = m / 2 - f[d] / 2 + x, R = Ca(w, M, A), L = c; t.modifiersData[i] = (e = {}, e[L] = R, e.centerOffset = R - M, e); } } function DT(n) { var e = n.state, t = n.options, i = t.element, r = i === void 0 ? "[data-popper-arrow]" : i; r != null && (typeof r == "string" && (r = e.elements.popper.querySelector(r), !r) || !x0(e.elements.popper, r) || (e.elements.arrow = r)); } var NT = { name: "arrow", enabled: true, phase: "main", fn: OT, effect: DT, requires: ["popperOffsets"], requiresIfExists: ["preventOverflow"] }; function To(n) { return n.split("-")[1]; } var BT = { top: "auto", right: "auto", bottom: "auto", left: "auto" }; function UT(n) { var e = n.x, t = n.y, i = window, r = i.devicePixelRatio || 1; return { x: So(e * r) / r || 0, y: So(t * r) / r || 0 }; } function lm(n) { var e, t = n.popper, i = n.popperRect, r = n.placement, s = n.variation, o = n.offsets, a = n.position, c = n.gpuAcceleration, l = n.adaptive, d = n.roundOffsets, h6 = n.isFixed, f = o.x, g = f === void 0 ? 0 : f, p = o.y, u = p === void 0 ? 0 : p, y = typeof d == "function" ? d({ x: g, y: u }) : { x: g, y: u }; g = y.x, u = y.y; var v = o.hasOwnProperty("x"), m = o.hasOwnProperty("y"), x = Dn, w = On, A = window; if (l) { var M = rl(t), R = "clientHeight", L = "clientWidth"; if (M === yi(t) && (M = Xr(t), rr(M).position !== "static" && a === "absolute" && (R = "scrollHeight", L = "scrollWidth")), M = M, r === On || (r === Dn || r === Qn) && s === Ua) { w = qn; var S = h6 && M === A && A.visualViewport ? A.visualViewport.height : M[R]; u -= S - i.height, u *= c ? 1 : -1; } if (r === Dn || (r === On || r === qn) && s === Ua) { x = Qn; var I = h6 && M === A && A.visualViewport ? A.visualViewport.width : M[L]; g -= I - i.width, g *= c ? 1 : -1; } } var T = Object.assign({ position: a }, l && BT), _ = d === true ? UT({ x: g, y: u }) : { x: g, y: u }; if (g = _.x, u = _.y, c) { var E; return Object.assign({}, T, (E = {}, E[w] = m ? "0" : "", E[x] = v ? "0" : "", E.transform = (A.devicePixelRatio || 1) <= 1 ? "translate(" + g + "px, " + u + "px)" : "translate3d(" + g + "px, " + u + "px, 0)", E)); } return Object.assign({}, T, (e = {}, e[w] = m ? u + "px" : "", e[x] = v ? g + "px" : "", e.transform = "", e)); } function zT(n) { var e = n.state, t = n.options, i = t.gpuAcceleration, r = i === void 0 ? true : i, s = t.adaptive, o = s === void 0 ? true : s, a = t.roundOffsets, c = a === void 0 ? true : a, l = { placement: Ri(e.placement), variation: To(e.placement), popper: e.elements.popper, popperRect: e.rects.popper, gpuAcceleration: r, isFixed: e.options.strategy === "fixed" }; e.modifiersData.popperOffsets != null && (e.styles.popper = Object.assign({}, e.styles.popper, lm(Object.assign({}, l, { offsets: e.modifiersData.popperOffsets, position: e.options.strategy, adaptive: o, roundOffsets: c })))), e.modifiersData.arrow != null && (e.styles.arrow = Object.assign({}, e.styles.arrow, lm(Object.assign({}, l, { offsets: e.modifiersData.arrow, position: "absolute", adaptive: false, roundOffsets: c })))), e.attributes.popper = Object.assign({}, e.attributes.popper, { "data-popper-placement": e.placement }); } var S0 = { name: "computeStyles", enabled: true, phase: "beforeWrite", fn: zT, data: {} }; var Tl = { passive: true }; function VT(n) { var e = n.state, t = n.instance, i = n.options, r = i.scroll, s = r === void 0 ? true : r, o = i.resize, a = o === void 0 ? true : o, c = yi(e.elements.popper), l = [].concat(e.scrollParents.reference, e.scrollParents.popper); return s && l.forEach(function(d) { d.addEventListener("scroll", t.update, Tl); }), a && c.addEventListener("resize", t.update, Tl), function() { s && l.forEach(function(d) { d.removeEventListener("scroll", t.update, Tl); }), a && c.removeEventListener("resize", t.update, Tl); }; } var _0 = { name: "eventListeners", enabled: true, phase: "write", fn: function() { }, effect: VT, data: {} }; var kT = { left: "right", right: "left", bottom: "top", top: "bottom" }; function Tc(n) { return n.replace(/left|right|bottom|top/g, function(e) { return kT[e]; }); } var GT = { start: "end", end: "start" }; function cm(n) { return n.replace(/start|end/g, function(e) { return GT[e]; }); } function tf(n) { var e = yi(n), t = e.pageXOffset, i = e.pageYOffset; return { scrollLeft: t, scrollTop: i }; } function nf(n) { return _o(Xr(n)).left + tf(n).scrollLeft; } function HT(n) { var e = yi(n), t = Xr(n), i = e.visualViewport, r = t.clientWidth, s = t.clientHeight, o = 0, a = 0; return i && (r = i.width, s = i.height, /^((?!chrome|android).)*safari/i.test(navigator.userAgent) || (o = i.offsetLeft, a = i.offsetTop)), { width: r, height: s, x: o + nf(n), y: a }; } function WT(n) { var e, t = Xr(n), i = tf(n), r = (e = n.ownerDocument) == null ? void 0 : e.body, s = xs(t.scrollWidth, t.clientWidth, r ? r.scrollWidth : 0, r ? r.clientWidth : 0), o = xs(t.scrollHeight, t.clientHeight, r ? r.scrollHeight : 0, r ? r.clientHeight : 0), a = -i.scrollLeft + nf(n), c = -i.scrollTop; return rr(r || t).direction === "rtl" && (a += xs(t.clientWidth, r ? r.clientWidth : 0) - s), { width: s, height: o, x: a, y: c }; } function rf(n) { var e = rr(n), t = e.overflow, i = e.overflowX, r = e.overflowY; return /auto|scroll|overlay|hidden/.test(t + r + i); } function T0(n) { return ["html", "body", "#document"].indexOf(Ii(n)) >= 0 ? n.ownerDocument.body : Kn(n) && rf(n) ? n : T0(ru(n)); } function La(n, e) { var t; e === void 0 && (e = []); var i = T0(n), r = i === ((t = n.ownerDocument) == null ? void 0 : t.body), s = yi(i), o = r ? [s].concat(s.visualViewport || [], rf(i) ? i : []) : i, a = e.concat(o); return r ? a : a.concat(La(ru(o))); } function Xh(n) { return Object.assign({}, n, { left: n.x, top: n.y, right: n.x + n.width, bottom: n.y + n.height }); } function jT(n) { var e = _o(n); return e.top = e.top + n.clientTop, e.left = e.left + n.clientLeft, e.bottom = e.top + n.clientHeight, e.right = e.left + n.clientWidth, e.width = n.clientWidth, e.height = n.clientHeight, e.x = e.left, e.y = e.top, e; } function um(n, e) { return e === y0 ? Xh(HT(n)) : Ao(e) ? jT(e) : Xh(WT(Xr(n))); } function $T(n) { var e = La(ru(n)), t = ["absolute", "fixed"].indexOf(rr(n).position) >= 0, i = t && Kn(n) ? rl(n) : n; return Ao(i) ? e.filter(function(r) { return Ao(r) && x0(r, i) && Ii(r) !== "body"; }) : []; } function ZT(n, e, t) { var i = e === "clippingParents" ? $T(n) : [].concat(e), r = [].concat(i, [t]), s = r[0], o = r.reduce(function(a, c) { var l = um(n, c); return a.top = xs(l.top, a.top), a.right = Bc(l.right, a.right), a.bottom = Bc(l.bottom, a.bottom), a.left = xs(l.left, a.left), a; }, um(n, s)); return o.width = o.right - o.left, o.height = o.bottom - o.top, o.x = o.left, o.y = o.top, o; } function E0(n) { var e = n.reference, t = n.element, i = n.placement, r = i ? Ri(i) : null, s = i ? To(i) : null, o = e.x + e.width / 2 - t.width / 2, a = e.y + e.height / 2 - t.height / 2, c; switch (r) { case On: c = { x: o, y: e.y - t.height }; break; case qn: c = { x: o, y: e.y + e.height }; break; case Qn: c = { x: e.x + e.width, y: a }; break; case Dn: c = { x: e.x - t.width, y: a }; break; default: c = { x: e.x, y: e.y }; } var l = r ? ef(r) : null; if (l != null) { var d = l === "y" ? "height" : "width"; switch (s) { case wo: c[l] = c[l] - (e[d] / 2 - t[d] / 2); break; case Ua: c[l] = c[l] + (e[d] / 2 - t[d] / 2); break; } } return c; } function za(n, e) { e === void 0 && (e = {}); var t = e, i = t.placement, r = i === void 0 ? n.placement : i, s = t.boundary, o = s === void 0 ? gT : s, a = t.rootBoundary, c = a === void 0 ? y0 : a, l = t.elementContext, d = l === void 0 ? ua : l, h6 = t.altBoundary, f = h6 === void 0 ? false : h6, g = t.padding, p = g === void 0 ? 0 : g, u = w0(typeof p != "number" ? p : A0(p, il)), y = d === ua ? vT : ua, v = n.rects.popper, m = n.elements[f ? y : d], x = ZT(Ao(m) ? m : m.contextElement || Xr(n.elements.popper), o, c), w = _o(n.elements.reference), A = E0({ reference: w, element: v, strategy: "absolute", placement: r }), M = Xh(Object.assign({}, v, A)), R = d === ua ? M : w, L = { top: x.top - R.top + u.top, bottom: R.bottom - x.bottom + u.bottom, left: x.left - R.left + u.left, right: R.right - x.right + u.right }, S = n.modifiersData.offset; if (d === ua && S) { var I = S[r]; Object.keys(L).forEach(function(T) { var _ = [Qn, qn].indexOf(T) >= 0 ? 1 : -1, E = [On, qn].indexOf(T) >= 0 ? "y" : "x"; L[T] += I[E] * _; }); } return L; } function XT(n, e) { e === void 0 && (e = {}); var t = e, i = t.placement, r = t.boundary, s = t.rootBoundary, o = t.padding, a = t.flipVariations, c = t.allowedAutoPlacements, l = c === void 0 ? Yo : c, d = To(i), h6 = d ? a ? om : om.filter(function(p) { return To(p) === d; }) : il, f = h6.filter(function(p) { return l.indexOf(p) >= 0; }); f.length === 0 && (f = h6); var g = f.reduce(function(p, u) { return p[u] = za(n, { placement: u, boundary: r, rootBoundary: s, padding: o })[Ri(u)], p; }, {}); return Object.keys(g).sort(function(p, u) { return g[p] - g[u]; }); } function YT(n) { if (Ri(n) === Kd) return []; var e = Tc(n); return [cm(n), e, cm(e)]; } function JT(n) { var e = n.state, t = n.options, i = n.name; if (!e.modifiersData[i]._skip) { for (var r = t.mainAxis, s = r === void 0 ? true : r, o = t.altAxis, a = o === void 0 ? true : o, c = t.fallbackPlacements, l = t.padding, d = t.boundary, h6 = t.rootBoundary, f = t.altBoundary, g = t.flipVariations, p = g === void 0 ? true : g, u = t.allowedAutoPlacements, y = e.options.placement, v = Ri(y), m = v === y, x = c || (m || !p ? [Tc(y)] : YT(y)), w = [y].concat(x).reduce(function(te, ae) { return te.concat(Ri(ae) === Kd ? XT(e, { placement: ae, boundary: d, rootBoundary: h6, padding: l, flipVariations: p, allowedAutoPlacements: u }) : ae); }, []), A = e.rects.reference, M = e.rects.popper, R = /* @__PURE__ */ new Map(), L = true, S = w[0], I = 0; I < w.length; I++) { var T = w[I], _ = Ri(T), E = To(T) === wo, C = [On, qn].indexOf(_) >= 0, P = C ? "width" : "height", b = za(e, { placement: T, boundary: d, rootBoundary: h6, altBoundary: f, padding: l }), F = C ? E ? Qn : Dn : E ? qn : On; A[P] > M[P] && (F = Tc(F)); var D = Tc(F), N = []; if (s && N.push(b[_] <= 0), a && N.push(b[F] <= 0, b[D] <= 0), N.every(function(te) { return te; })) { S = T, L = false; break; } R.set(T, N); } if (L) for (var B = p ? 3 : 1, U = function(te) { var ae = w.find(function(ie) { var le = R.get(ie); if (le) return le.slice(0, te).every(function(W) { return W; }); }); if (ae) return S = ae, "break"; }, G = B; G > 0; G--) { var Y = U(G); if (Y === "break") break; } e.placement !== S && (e.modifiersData[i]._skip = true, e.placement = S, e.reset = true); } } var KT = { name: "flip", enabled: true, phase: "main", fn: JT, requiresIfExists: ["offset"], data: { _skip: false } }; function hm(n, e, t) { return t === void 0 && (t = { x: 0, y: 0 }), { top: n.top - e.height - t.y, right: n.right - e.width + t.x, bottom: n.bottom - e.height + t.y, left: n.left - e.width - t.x }; } function dm(n) { return [On, Qn, qn, Dn].some(function(e) { return n[e] >= 0; }); } function qT(n) { var e = n.state, t = n.name, i = e.rects.reference, r = e.rects.popper, s = e.modifiersData.preventOverflow, o = za(e, { elementContext: "reference" }), a = za(e, { altBoundary: true }), c = hm(o, i), l = hm(a, r, s), d = dm(c), h6 = dm(l); e.modifiersData[t] = { referenceClippingOffsets: c, popperEscapeOffsets: l, isReferenceHidden: d, hasPopperEscaped: h6 }, e.attributes.popper = Object.assign({}, e.attributes.popper, { "data-popper-reference-hidden": d, "data-popper-escaped": h6 }); } var QT = { name: "hide", enabled: true, phase: "main", requiresIfExists: ["preventOverflow"], fn: qT }; function eE(n, e, t) { var i = Ri(n), r = [Dn, On].indexOf(i) >= 0 ? -1 : 1, s = typeof t == "function" ? t(Object.assign({}, e, { placement: n })) : t, o = s[0], a = s[1]; return o = o || 0, a = (a || 0) * r, [Dn, Qn].indexOf(i) >= 0 ? { x: a, y: o } : { x: o, y: a }; } function tE(n) { var e = n.state, t = n.options, i = n.name, r = t.offset, s = r === void 0 ? [0, 0] : r, o = Yo.reduce(function(d, h6) { return d[h6] = eE(h6, e.rects, s), d; }, {}), a = o[e.placement], c = a.x, l = a.y; e.modifiersData.popperOffsets != null && (e.modifiersData.popperOffsets.x += c, e.modifiersData.popperOffsets.y += l), e.modifiersData[i] = o; } var nE = { name: "offset", enabled: true, phase: "main", requires: ["popperOffsets"], fn: tE }; function iE(n) { var e = n.state, t = n.name; e.modifiersData[t] = E0({ reference: e.rects.reference, element: e.rects.popper, strategy: "absolute", placement: e.placement }); } var C0 = { name: "popperOffsets", enabled: true, phase: "read", fn: iE, data: {} }; function rE(n) { return n === "x" ? "y" : "x"; } function sE(n) { var e = n.state, t = n.options, i = n.name, r = t.mainAxis, s = r === void 0 ? true : r, o = t.altAxis, a = o === void 0 ? false : o, c = t.boundary, l = t.rootBoundary, d = t.altBoundary, h6 = t.padding, f = t.tether, g = f === void 0 ? true : f, p = t.tetherOffset, u = p === void 0 ? 0 : p, y = za(e, { boundary: c, rootBoundary: l, padding: h6, altBoundary: d }), v = Ri(e.placement), m = To(e.placement), x = !m, w = ef(v), A = rE(w), M = e.modifiersData.popperOffsets, R = e.rects.reference, L = e.rects.popper, S = typeof u == "function" ? u(Object.assign({}, e.rects, { placement: e.placement })) : u, I = typeof S == "number" ? { mainAxis: S, altAxis: S } : Object.assign({ mainAxis: 0, altAxis: 0 }, S), T = e.modifiersData.offset ? e.modifiersData.offset[e.placement] : null, _ = { x: 0, y: 0 }; if (M) { if (s) { var E, C = w === "y" ? On : Dn, P = w === "y" ? qn : Qn, b = w === "y" ? "height" : "width", F = M[w], D = F + y[C], N = F - y[P], B = g ? -L[b] / 2 : 0, U = m === wo ? R[b] : L[b], G = m === wo ? -L[b] : -R[b], Y = e.elements.arrow, te = g && Y ? Qd(Y) : { width: 0, height: 0 }, ae = e.modifiersData["arrow#persistent"] ? e.modifiersData["arrow#persistent"].padding : M0(), ie = ae[C], le = ae[P], W = Ca(0, R[b], te[b]), $ = x ? R[b] / 2 - B - W - ie - I.mainAxis : U - W - ie - I.mainAxis, j = x ? -R[b] / 2 + B + W + le + I.mainAxis : G + W + le + I.mainAxis, re = e.elements.arrow && rl(e.elements.arrow), V = re ? w === "y" ? re.clientTop || 0 : re.clientLeft || 0 : 0, H = (E = T == null ? void 0 : T[w]) != null ? E : 0, K = F + $ - H - V, ce = F + j - H, se = Ca(g ? Bc(D, K) : D, F, g ? xs(N, ce) : N); M[w] = se, _[w] = se - F; } if (a) { var k, O = w === "x" ? On : Dn, Z = w === "x" ? qn : Qn, X = M[A], ee = A === "y" ? "height" : "width", fe = X + y[O], be = X - y[Z], Ae = [On, Dn].indexOf(v) !== -1, he = (k = T == null ? void 0 : T[A]) != null ? k : 0, xe = Ae ? fe : X - R[ee] - L[ee] - he + I.altAxis, ne = Ae ? X + R[ee] + L[ee] - he - I.altAxis : be, me = g && Ae ? PT(xe, X, ne) : Ca(g ? xe : fe, X, g ? ne : be); M[A] = me, _[A] = me - X; } e.modifiersData[i] = _; } } var oE = { name: "preventOverflow", enabled: true, phase: "main", fn: sE, requiresIfExists: ["offset"] }; function aE(n) { return { scrollLeft: n.scrollLeft, scrollTop: n.scrollTop }; } function lE(n) { return n === yi(n) || !Kn(n) ? tf(n) : aE(n); } function cE(n) { var e = n.getBoundingClientRect(), t = So(e.width) / n.offsetWidth || 1, i = So(e.height) / n.offsetHeight || 1; return t !== 1 || i !== 1; } function uE(n, e, t) { t === void 0 && (t = false); var i = Kn(e), r = Kn(e) && cE(e), s = Xr(e), o = _o(n, r), a = { scrollLeft: 0, scrollTop: 0 }, c = { x: 0, y: 0 }; return (i || !i && !t) && ((Ii(e) !== "body" || rf(s)) && (a = lE(e)), Kn(e) ? (c = _o(e, true), c.x += e.clientLeft, c.y += e.clientTop) : s && (c.x = nf(s))), { x: o.left + a.scrollLeft - c.x, y: o.top + a.scrollTop - c.y, width: o.width, height: o.height }; } function hE(n) { var e = /* @__PURE__ */ new Map(), t = /* @__PURE__ */ new Set(), i = []; n.forEach(function(s) { e.set(s.name, s); }); function r(s) { t.add(s.name); var o = [].concat(s.requires || [], s.requiresIfExists || []); o.forEach(function(a) { if (!t.has(a)) { var c = e.get(a); c && r(c); } }), i.push(s); } return n.forEach(function(s) { t.has(s.name) || r(s); }), i; } function dE(n) { var e = hE(n); return ET.reduce(function(t, i) { return t.concat(e.filter(function(r) { return r.phase === i; })); }, []); } function fE(n) { var e; return function() { return e || (e = new Promise(function(t) { Promise.resolve().then(function() { e = void 0, t(n()); }); })), e; }; } function pE(n) { var e = n.reduce(function(t, i) { var r = t[i.name]; return t[i.name] = r ? Object.assign({}, r, i, { options: Object.assign({}, r.options, i.options), data: Object.assign({}, r.data, i.data) }) : i, t; }, {}); return Object.keys(e).map(function(t) { return e[t]; }); } var fm = { placement: "bottom", modifiers: [], strategy: "absolute" }; function pm() { for (var n = arguments.length, e = new Array(n), t = 0; t < n; t++) e[t] = arguments[t]; return !e.some(function(i) { return !(i && typeof i.getBoundingClientRect == "function"); }); } function sf(n) { n === void 0 && (n = {}); var e = n, t = e.defaultModifiers, i = t === void 0 ? [] : t, r = e.defaultOptions, s = r === void 0 ? fm : r; return function(o, a, c) { c === void 0 && (c = s); var l = { placement: "bottom", orderedModifiers: [], options: Object.assign({}, fm, s), modifiersData: {}, elements: { reference: o, popper: a }, attributes: {}, styles: {} }, d = [], h6 = false, f = { state: l, setOptions: function(u) { var y = typeof u == "function" ? u(l.options) : u; p(), l.options = Object.assign({}, s, l.options, y), l.scrollParents = { reference: Ao(o) ? La(o) : o.contextElement ? La(o.contextElement) : [], popper: La(a) }; var v = dE(pE([].concat(i, l.options.modifiers))); return l.orderedModifiers = v.filter(function(m) { return m.enabled; }), g(), f.update(); }, forceUpdate: function() { if (!h6) { var u = l.elements, y = u.reference, v = u.popper; if (pm(y, v)) { l.rects = { reference: uE(y, rl(v), l.options.strategy === "fixed"), popper: Qd(v) }, l.reset = false, l.placement = l.options.placement, l.orderedModifiers.forEach(function(L) { return l.modifiersData[L.name] = Object.assign({}, L.data); }); for (var m = 0; m < l.orderedModifiers.length; m++) { if (l.reset === true) { l.reset = false, m = -1; continue; } var x = l.orderedModifiers[m], w = x.fn, A = x.options, M = A === void 0 ? {} : A, R = x.name; typeof w == "function" && (l = w({ state: l, options: M, name: R, instance: f }) || l); } } } }, update: fE(function() { return new Promise(function(u) { f.forceUpdate(), u(l); }); }), destroy: function() { p(), h6 = true; } }; if (!pm(o, a)) return f; f.setOptions(c).then(function(u) { !h6 && c.onFirstUpdate && c.onFirstUpdate(u); }); function g() { l.orderedModifiers.forEach(function(u) { var y = u.name, v = u.options, m = v === void 0 ? {} : v, x = u.effect; if (typeof x == "function") { var w = x({ state: l, name: y, instance: f, options: m }), A = function() { }; d.push(w || A); } }); } function p() { d.forEach(function(u) { return u(); }), d = []; } return f; }; } sf(); var mE = [_0, C0, S0, b0]; sf({ defaultModifiers: mE }); var gE = [_0, C0, S0, b0, nE, KT, oE, NT, QT]; var vE = sf({ defaultModifiers: gE }); var yE = (n, e, t = {}) => { const i = { name: "updateState", enabled: true, phase: "write", fn: ({ state: c }) => { const l = bE(c); Object.assign(o.value, l); }, requires: ["computeStyles"] }, r = computed(() => { const { onFirstUpdate: c, placement: l, strategy: d, modifiers: h6 } = unref(t); return { onFirstUpdate: c, placement: l || "bottom", strategy: d || "absolute", modifiers: [ ...h6 || [], i, { name: "applyStyles", enabled: false } ] }; }), s = shallowRef(), o = ref({ styles: { popper: { position: unref(r).strategy, left: "0", top: "0" }, arrow: { position: "absolute" } }, attributes: {} }), a = () => { s.value && (s.value.destroy(), s.value = void 0); }; return watch(r, (c) => { const l = unref(s); l && l.setOptions(c); }, { deep: true }), watch([n, e], ([c, l]) => { a(), !(!c || !l) && (s.value = vE(c, l, unref(r))); }), onBeforeUnmount(() => { a(); }), { state: computed(() => { var c; return { ...((c = unref(s)) == null ? void 0 : c.state) || {} }; }), styles: computed(() => unref(o).styles), attributes: computed(() => unref(o).attributes), update: () => { var c; return (c = unref(s)) == null ? void 0 : c.update(); }, forceUpdate: () => { var c; return (c = unref(s)) == null ? void 0 : c.forceUpdate(); }, instanceRef: computed(() => unref(s)) }; }; function bE(n) { const e = Object.keys(n.elements), t = Ic(e.map((r) => [r, n.styles[r] || {}])), i = Ic(e.map((r) => [r, n.attributes[r]])); return { styles: t, attributes: i }; } function mm() { let n; const e = (i, r) => { t(), n = window.setTimeout(i, r); }, t = () => window.clearTimeout(n); return Yc(() => t()), { registerTimeout: e, cancelTimeout: t }; } var Yh = { prefix: Math.floor(Math.random() * 1e4), current: 0 }; var xE = Symbol("elIdInjection"); var of = () => getCurrentInstance() ? inject(xE, Yh) : Yh; var sl = (n) => { const e = of(); !en && e === Yh && Vt("IdInjection", `Looks like you are using server rendering, you must provide a id provider to ensure the hydration process to be succeed usage: app.provide(ID_INJECTION_KEY, { prefix: number, current: number, })`); const t = Jd(); return computed(() => unref(n) || `${t.value}-id-${e.prefix}-${e.current++}`); }; var fo = []; var gm = (n) => { const e = n; e.key === Li.esc && fo.forEach((t) => t(e)); }; var ME = (n) => { onMounted(() => { fo.length === 0 && document.addEventListener("keydown", gm), en && fo.push(n); }), onBeforeUnmount(() => { fo = fo.filter((e) => e !== n), fo.length === 0 && en && document.removeEventListener("keydown", gm); }); }; var vm; var L0 = () => { const n = Jd(), e = of(), t = computed(() => `${n.value}-popper-container-${e.prefix}`), i = computed(() => `#${t.value}`); return { id: t, selector: i }; }; var wE = (n) => { const e = document.createElement("div"); return e.id = n, document.body.appendChild(e), e; }; var AE = () => { const { id: n, selector: e } = L0(); return onBeforeMount(() => { en && (!vm || !document.body.querySelector(e.value)) && (vm = wE(n.value)); }), { id: n, selector: e }; }; var SE = at({ showAfter: { type: Number, default: 0 }, hideAfter: { type: Number, default: 200 }, autoClose: { type: Number, default: 0 } }); var _E = ({ showAfter: n, hideAfter: e, autoClose: t, open: i, close: r }) => { const { registerTimeout: s } = mm(), { registerTimeout: o, cancelTimeout: a } = mm(); return { onOpen: (d) => { s(() => { i(d); const h6 = unref(t); yt(h6) && h6 > 0 && o(() => { r(d); }, h6); }, unref(n)); }, onClose: (d) => { a(), s(() => { r(d); }, unref(e)); } }; }; var R0 = Symbol("elForwardRef"); var TE = (n) => { provide(R0, { setForwardRef: (t) => { n.value = t; } }); }; var EE = (n) => ({ mounted(e) { n(e); }, updated(e) { n(e); }, unmounted() { n(null); } }); var ym = { current: 0 }; var bm = ref(0); var F0 = 2e3; var xm = Symbol("elZIndexContextKey"); var P0 = Symbol("zIndexContextKey"); var I0 = (n) => { const e = getCurrentInstance() ? inject(xm, ym) : ym, t = n || (getCurrentInstance() ? inject(P0, void 0) : void 0), i = computed(() => { const o = unref(t); return yt(o) ? o : F0; }), r = computed(() => i.value + bm.value), s = () => (e.current++, bm.value = e.current, r.value); return !en && !inject(xm) && Vt("ZIndexInjection", `Looks like you are using server rendering, you must provide a z-index provider to ensure the hydration process to be succeed usage: app.provide(ZINDEX_INJECTION_KEY, { current: 0 })`), { initialZIndex: i, currentZIndex: r, nextZIndex: s }; }; function CE(n) { let e; function t() { if (n.value == null) return; const { selectionStart: r, selectionEnd: s, value: o } = n.value; if (r == null || s == null) return; const a = o.slice(0, Math.max(0, r)), c = o.slice(Math.max(0, s)); e = { selectionStart: r, selectionEnd: s, value: o, beforeTxt: a, afterTxt: c }; } function i() { if (n.value == null || e == null) return; const { value: r } = n.value, { beforeTxt: s, afterTxt: o, selectionStart: a } = e; if (s == null || o == null || a == null) return; let c = r.length; if (r.endsWith(o)) c = r.length - o.length; else if (r.startsWith(s)) c = s.length; else { const l = s[a - 1], d = r.indexOf(l, a - 1); d !== -1 && (c = d + 1); } n.value.setSelectionRange(c, c); } return [t, i]; } var LE = (n, e, t) => Sc(n.subTree).filter((s) => { var o; return isVNode(s) && ((o = s.type) == null ? void 0 : o.name) === e && !!s.component; }).map((s) => s.component.uid).map((s) => t[s]).filter((s) => !!s); var RE = (n, e) => { const t = {}, i = shallowRef([]); return { children: i, addChild: (o) => { t[o.uid] = o, i.value = LE(n, e, t); }, removeChild: (o) => { delete t[o], i.value = i.value.filter((a) => a.uid !== o); } }; }; var Gr = nu({ type: String, values: f0, required: false }); var O0 = Symbol("size"); var FE = () => { const n = inject(O0, {}); return computed(() => unref(n.size) || ""); }; function D0(n, { beforeFocus: e, afterFocus: t, beforeBlur: i, afterBlur: r } = {}) { const s = getCurrentInstance(), { emit: o } = s, a = shallowRef(), c = ref(false), l = (f) => { Sn(e) && e(f) || c.value || (c.value = true, o("focus", f), t == null || t()); }, d = (f) => { var g; Sn(i) && i(f) || f.relatedTarget && ((g = a.value) != null && g.contains(f.relatedTarget)) || (c.value = false, o("blur", f), r == null || r()); }, h6 = () => { var f, g; (f = a.value) != null && f.contains(document.activeElement) && a.value !== document.activeElement || (g = n.value) == null || g.focus(); }; return watch(a, (f) => { f && f.setAttribute("tabindex", "-1"); }), un(a, "focus", l, true), un(a, "blur", d, true), un(a, "click", h6, true), false, { isFocused: c, wrapperRef: a, handleFocus: l, handleBlur: d }; } function N0({ afterComposition: n, emit: e }) { const t = ref(false), i = (a) => { e == null || e("compositionstart", a), t.value = true; }, r = (a) => { var c; e == null || e("compositionupdate", a); const l = (c = a.target) == null ? void 0 : c.value, d = l[l.length - 1] || ""; t.value = !rT(d); }, s = (a) => { e == null || e("compositionend", a), t.value && (t.value = false, nextTick(() => n(a))); }; return { isComposing: t, handleComposition: (a) => { a.type === "compositionend" ? s(a) : r(a); }, handleCompositionStart: i, handleCompositionUpdate: r, handleCompositionEnd: s }; } var B0 = Symbol("emptyValuesContextKey"); var PE = "use-empty-values"; var IE = ["", void 0, null]; var OE = void 0; var DE = at({ emptyValues: Array, valueOnClear: { type: [String, Number, Boolean, Function], default: void 0, validator: (n) => Sn(n) ? !n() : !n } }); var NE = (n, e) => { const t = getCurrentInstance() ? inject(B0, ref({})) : ref({}), i = computed(() => n.emptyValues || t.value.emptyValues || IE), r = computed(() => Sn(n.valueOnClear) ? n.valueOnClear() : n.valueOnClear !== void 0 ? n.valueOnClear : Sn(t.value.valueOnClear) ? t.value.valueOnClear() : t.value.valueOnClear !== void 0 ? t.value.valueOnClear : OE), s = (o) => i.value.includes(o); return i.value.includes(r.value) || Vt(PE, "value-on-clear should be a value of empty-values"), { emptyValues: i, valueOnClear: r, isEmptyValue: s }; }; var BE = at({ ariaLabel: String, ariaOrientation: { type: String, values: ["horizontal", "vertical", "undefined"] }, ariaControls: String }); var Yr = (n) => P_(BE, n); var U0 = Symbol(); var Uc = ref(); function af(n, e = void 0) { const t = getCurrentInstance() ? inject(U0, Uc) : Uc; return n ? computed(() => { var i, r; return (r = (i = t.value) == null ? void 0 : i[n]) != null ? r : e; }) : t; } function UE(n, e) { const t = af(), i = nt(n, computed(() => { var a; return ((a = t.value) == null ? void 0 : a.namespace) || _c; })), r = iu(computed(() => { var a; return (a = t.value) == null ? void 0 : a.locale; })), s = I0(computed(() => { var a; return ((a = t.value) == null ? void 0 : a.zIndex) || F0; })), o = computed(() => { var a; return unref(e) || ((a = t.value) == null ? void 0 : a.size) || ""; }); return zE(computed(() => unref(t) || {})), { ns: i, locale: r, zIndex: s, size: o }; } var zE = (n, e, t = false) => { var i; const r = !!getCurrentInstance(), s = r ? af() : void 0, o = (i = void 0) != null ? i : r ? provide : void 0; if (!o) { Vt("provideGlobalConfig", "provideGlobalConfig() can only be used inside setup()."); return; } const a = computed(() => { const c = unref(n); return s != null && s.value ? VE(s.value, c) : c; }); return o(U0, a), o(m0, computed(() => a.value.locale)), o(g0, computed(() => a.value.namespace)), o(P0, computed(() => a.value.zIndex)), o(O0, { size: computed(() => a.value.size || "") }), o(B0, computed(() => ({ emptyValues: a.value.emptyValues, valueOnClear: a.value.valueOnClear }))), (t || !Uc.value) && (Uc.value = a.value), a; }; var VE = (n, e) => { const t = [.../* @__PURE__ */ new Set([...rm(n), ...rm(e)])], i = {}; for (const r of t) i[r] = e[r] !== void 0 ? e[r] : n[r]; return i; }; var st = (n, e) => { const t = n.__vccOpts || n; for (const [i, r] of e) t[i] = r; return t; }; var kE = at({ size: { type: Je([Number, String]) }, color: { type: String } }); var GE = defineComponent({ name: "ElIcon", inheritAttrs: false }); var HE = defineComponent({ ...GE, props: kE, setup(n) { const e = n, t = nt("icon"), i = computed(() => { const { size: r, color: s } = e; return !r && !s ? {} : { fontSize: di(r) ? void 0 : Dc(r), "--color": s }; }); return (r, s) => (openBlock(), createElementBlock("i", mergeProps({ class: unref(t).b(), style: unref(i) }, r.$attrs), [ renderSlot(r.$slots, "default") ], 16)); } }); var WE = st(HE, [["__file", "icon.vue"]]); var It = on(WE); var lf = Symbol("formContextKey"); var zc = Symbol("formItemContextKey"); var Ns = (n, e = {}) => { const t = ref(void 0), i = e.prop ? t : v0("size"), r = e.global ? t : FE(), s = e.form ? { size: void 0 } : inject(lf, void 0), o = e.formItem ? { size: void 0 } : inject(zc, void 0); return computed(() => i.value || unref(n) || (o == null ? void 0 : o.size) || (s == null ? void 0 : s.size) || r.value || ""); }; var ol = (n) => { const e = v0("disabled"), t = inject(lf, void 0); return computed(() => e.value || unref(n) || (t == null ? void 0 : t.disabled) || false); }; var Jo = () => { const n = inject(lf, void 0), e = inject(zc, void 0); return { form: n, formItem: e }; }; var su = (n, { formItemContext: e, disableIdGeneration: t, disableIdManagement: i }) => { t || (t = ref(false)), i || (i = ref(false)); const r = ref(); let s; const o = computed(() => { var a; return !!(!(n.label || n.ariaLabel) && e && e.inputIds && ((a = e.inputIds) == null ? void 0 : a.length) <= 1); }); return onMounted(() => { s = watch([toRef(n, "id"), t], ([a, c]) => { const l = a ?? (c ? void 0 : sl().value); l !== r.value && (e != null && e.removeInputId && (r.value && e.removeInputId(r.value), !(i != null && i.value) && !c && l && e.addInputId(l)), r.value = l); }, { immediate: true }); }), onUnmounted(() => { s && s(), e != null && e.removeInputId && r.value && e.removeInputId(r.value); }), { isLabeledByFormItem: o, inputId: r }; }; var ii; var jE = ` height:0 !important; visibility:hidden !important; ${Iw() ? "" : "overflow:hidden !important;"} position:absolute !important; z-index:-1000 !important; top:0 !important; right:0 !important; `; var $E = [ "letter-spacing", "line-height", "padding-top", "padding-bottom", "font-family", "font-weight", "font-size", "text-rendering", "text-transform", "width", "text-indent", "padding-left", "padding-right", "border-width", "box-sizing" ]; function ZE(n) { const e = window.getComputedStyle(n), t = e.getPropertyValue("box-sizing"), i = Number.parseFloat(e.getPropertyValue("padding-bottom")) + Number.parseFloat(e.getPropertyValue("padding-top")), r = Number.parseFloat(e.getPropertyValue("border-bottom-width")) + Number.parseFloat(e.getPropertyValue("border-top-width")); return { contextStyle: $E.map((o) => `${o}:${e.getPropertyValue(o)}`).join(";"), paddingSize: i, borderSize: r, boxSizing: t }; } function Mm(n, e = 1, t) { var i; ii || (ii = document.createElement("textarea"), document.body.appendChild(ii)); const { paddingSize: r, borderSize: s, boxSizing: o, contextStyle: a } = ZE(n); ii.setAttribute("style", `${a};${jE}`), ii.value = n.value || n.placeholder || ""; let c = ii.scrollHeight; const l = {}; o === "border-box" ? c = c + s : o === "content-box" && (c = c - r), ii.value = ""; const d = ii.scrollHeight - r; if (yt(e)) { let h6 = d * e; o === "border-box" && (h6 = h6 + r + s), c = Math.max(h6, c), l.minHeight = `${h6}px`; } if (yt(t)) { let h6 = d * t; o === "border-box" && (h6 = h6 + r + s), c = Math.min(h6, c); } return l.height = `${c}px`, (i = ii.parentNode) == null || i.removeChild(ii), ii = void 0, l; } var XE = at({ id: { type: String, default: void 0 }, size: Gr, disabled: Boolean, modelValue: { type: Je([ String, Number, Object ]), default: "" }, maxlength: { type: [String, Number] }, minlength: { type: [String, Number] }, type: { type: String, default: "text" }, resize: { type: String, values: ["none", "both", "horizontal", "vertical"] }, autosize: { type: Je([Boolean, Object]), default: false }, autocomplete: { type: String, default: "off" }, formatter: { type: Function }, parser: { type: Function }, placeholder: { type: String }, form: { type: String }, readonly: Boolean, clearable: Boolean, showPassword: Boolean, showWordLimit: Boolean, suffixIcon: { type: kr }, prefixIcon: { type: kr }, containerRole: { type: String, default: void 0 }, tabindex: { type: [String, Number], default: 0 }, validateEvent: { type: Boolean, default: true }, inputStyle: { type: Je([Object, Array, String]), default: () => Ki({}) }, autofocus: Boolean, rows: { type: Number, default: 2 }, ...Yr(["ariaLabel"]) }); var YE = { [At]: (n) => vn(n), input: (n) => vn(n), change: (n) => vn(n), focus: (n) => n instanceof FocusEvent, blur: (n) => n instanceof FocusEvent, clear: () => true, mouseleave: (n) => n instanceof MouseEvent, mouseenter: (n) => n instanceof MouseEvent, keydown: (n) => n instanceof Event, compositionstart: (n) => n instanceof CompositionEvent, compositionupdate: (n) => n instanceof CompositionEvent, compositionend: (n) => n instanceof CompositionEvent }; var JE = defineComponent({ name: "ElInput", inheritAttrs: false }); var KE = defineComponent({ ...JE, props: XE, emits: YE, setup(n, { expose: e, emit: t }) { const i = n, r = useAttrs(), s = useSlots(), o = computed(() => { const he = {}; return i.containerRole === "combobox" && (he["aria-haspopup"] = r["aria-haspopup"], he["aria-owns"] = r["aria-owns"], he["aria-expanded"] = r["aria-expanded"]), he; }), a = computed(() => [ i.type === "textarea" ? y.b() : u.b(), u.m(g.value), u.is("disabled", p.value), u.is("exceed", Y.value), { [u.b("group")]: s.prepend || s.append, [u.m("prefix")]: s.prefix || i.prefixIcon, [u.m("suffix")]: s.suffix || i.suffixIcon || i.clearable || i.showPassword, [u.bm("suffix", "password-clear")]: N.value && B.value, [u.b("hidden")]: i.type === "hidden" }, r.class ]), c = computed(() => [ u.e("wrapper"), u.is("focus", S.value) ]), l = aT({ excludeKeys: computed(() => Object.keys(o.value)) }), { form: d, formItem: h6 } = Jo(), { inputId: f } = su(i, { formItemContext: h6 }), g = Ns(), p = ol(), u = nt("input"), y = nt("textarea"), v = shallowRef(), m = shallowRef(), x = ref(false), w = ref(false), A = ref(), M = shallowRef(i.inputStyle), R = computed(() => v.value || m.value), { wrapperRef: L, isFocused: S, handleFocus: I, handleBlur: T } = D0(R, { beforeFocus() { return p.value; }, afterBlur() { var he; i.validateEvent && ((he = h6 == null ? void 0 : h6.validate) == null || he.call(h6, "blur").catch((xe) => Vt(xe))); } }), _ = computed(() => { var he; return (he = d == null ? void 0 : d.statusIcon) != null ? he : false; }), E = computed(() => (h6 == null ? void 0 : h6.validateState) || ""), C = computed(() => E.value && d0[E.value]), P = computed(() => w.value ? eT : X_), b = computed(() => [ r.style ]), F = computed(() => [ i.inputStyle, M.value, { resize: i.resize } ]), D = computed(() => Ci(i.modelValue) ? "" : String(i.modelValue)), N = computed(() => i.clearable && !p.value && !i.readonly && !!D.value && (S.value || x.value)), B = computed(() => i.showPassword && !p.value && !i.readonly && !!D.value && (!!D.value || S.value)), U = computed(() => i.showWordLimit && !!i.maxlength && (i.type === "text" || i.type === "textarea") && !p.value && !i.readonly && !i.showPassword), G = computed(() => D.value.length), Y = computed(() => !!U.value && G.value > Number(i.maxlength)), te = computed(() => !!s.suffix || !!i.suffixIcon || N.value || i.showPassword || U.value || !!E.value && _.value), [ae, ie] = CE(v); Yn(m, (he) => { if ($(), !U.value || i.resize !== "both") return; const xe = he[0], { width: ne } = xe.contentRect; A.value = { right: `calc(100% - ${ne + 15 + 6}px)` }; }); const le = () => { const { type: he, autosize: xe } = i; if (!(!en || he !== "textarea" || !m.value)) if (xe) { const ne = Tn(xe) ? xe.minRows : void 0, me = Tn(xe) ? xe.maxRows : void 0, Me = Mm(m.value, ne, me); M.value = { overflowY: "hidden", ...Me }, nextTick(() => { m.value.offsetHeight, M.value = Me; }); } else M.value = { minHeight: Mm(m.value).minHeight }; }, $ = /* @__PURE__ */ ((he) => { let xe = false; return () => { var ne; if (xe || !i.autosize) return; ((ne = m.value) == null ? void 0 : ne.offsetParent) === null || (he(), xe = true); }; })(le), j = () => { const he = R.value, xe = i.formatter ? i.formatter(D.value) : D.value; !he || he.value === xe || (he.value = xe); }, re = async (he) => { ae(); let { value: xe } = he.target; if (i.formatter && (xe = i.parser ? i.parser(xe) : xe), !H.value) { if (xe === D.value) { j(); return; } t(At, xe), t("input", xe), await nextTick(), j(), ie(); } }, V = (he) => { t("change", he.target.value); }, { isComposing: H, handleCompositionStart: K, handleCompositionUpdate: ce, handleCompositionEnd: se } = N0({ emit: t, afterComposition: re }), k = () => { w.value = !w.value, O(); }, O = async () => { var he; await nextTick(), (he = R.value) == null || he.focus(); }, Z = () => { var he; return (he = R.value) == null ? void 0 : he.blur(); }, X = (he) => { x.value = false, t("mouseleave", he); }, ee = (he) => { x.value = true, t("mouseenter", he); }, fe = (he) => { t("keydown", he); }, be = () => { var he; (he = R.value) == null || he.select(); }, Ae = () => { t(At, ""), t("change", ""), t("clear"), t("input", ""); }; return watch(() => i.modelValue, () => { var he; nextTick(() => le()), i.validateEvent && ((he = h6 == null ? void 0 : h6.validate) == null || he.call(h6, "change").catch((xe) => Vt(xe))); }), watch(D, () => j()), watch(() => i.type, async () => { await nextTick(), j(), le(); }), onMounted(() => { !i.formatter && i.parser && Vt("ElInput", "If you set the parser, you also need to set the formatter."), j(), nextTick(le); }), e({ input: v, textarea: m, ref: R, textareaStyle: F, autosize: toRef(i, "autosize"), isComposing: H, focus: O, blur: Z, select: be, clear: Ae, resizeTextarea: le }), (he, xe) => (openBlock(), createElementBlock("div", mergeProps(unref(o), { class: [ unref(a), { [unref(u).bm("group", "append")]: he.$slots.append, [unref(u).bm("group", "prepend")]: he.$slots.prepend } ], style: unref(b), role: he.containerRole, onMouseenter: ee, onMouseleave: X }), [ createCommentVNode(" input "), he.type !== "textarea" ? (openBlock(), createElementBlock(Fragment, { key: 0 }, [ createCommentVNode(" prepend slot "), he.$slots.prepend ? (openBlock(), createElementBlock("div", { key: 0, class: normalizeClass(unref(u).be("group", "prepend")) }, [ renderSlot(he.$slots, "prepend") ], 2)) : createCommentVNode("v-if", true), createBaseVNode("div", { ref_key: "wrapperRef", ref: L, class: normalizeClass(unref(c)) }, [ createCommentVNode(" prefix slot "), he.$slots.prefix || he.prefixIcon ? (openBlock(), createElementBlock("span", { key: 0, class: normalizeClass(unref(u).e("prefix")) }, [ createBaseVNode("span", { class: normalizeClass(unref(u).e("prefix-inner")) }, [ renderSlot(he.$slots, "prefix"), he.prefixIcon ? (openBlock(), createBlock(unref(It), { key: 0, class: normalizeClass(unref(u).e("icon")) }, { default: withCtx(() => [ (openBlock(), createBlock(resolveDynamicComponent(he.prefixIcon))) ]), _: 1 }, 8, ["class"])) : createCommentVNode("v-if", true) ], 2) ], 2)) : createCommentVNode("v-if", true), createBaseVNode("input", mergeProps({ id: unref(f), ref_key: "input", ref: v, class: unref(u).e("inner") }, unref(l), { minlength: he.minlength, maxlength: he.maxlength, type: he.showPassword ? w.value ? "text" : "password" : he.type, disabled: unref(p), readonly: he.readonly, autocomplete: he.autocomplete, tabindex: he.tabindex, "aria-label": he.ariaLabel, placeholder: he.placeholder, style: he.inputStyle, form: he.form, autofocus: he.autofocus, onCompositionstart: unref(K), onCompositionupdate: unref(ce), onCompositionend: unref(se), onInput: re, onChange: V, onKeydown: fe }), null, 16, ["id", "minlength", "maxlength", "type", "disabled", "readonly", "autocomplete", "tabindex", "aria-label", "placeholder", "form", "autofocus", "onCompositionstart", "onCompositionupdate", "onCompositionend"]), createCommentVNode(" suffix slot "), unref(te) ? (openBlock(), createElementBlock("span", { key: 1, class: normalizeClass(unref(u).e("suffix")) }, [ createBaseVNode("span", { class: normalizeClass(unref(u).e("suffix-inner")) }, [ !unref(N) || !unref(B) || !unref(U) ? (openBlock(), createElementBlock(Fragment, { key: 0 }, [ renderSlot(he.$slots, "suffix"), he.suffixIcon ? (openBlock(), createBlock(unref(It), { key: 0, class: normalizeClass(unref(u).e("icon")) }, { default: withCtx(() => [ (openBlock(), createBlock(resolveDynamicComponent(he.suffixIcon))) ]), _: 1 }, 8, ["class"])) : createCommentVNode("v-if", true) ], 64)) : createCommentVNode("v-if", true), unref(N) ? (openBlock(), createBlock(unref(It), { key: 1, class: normalizeClass([unref(u).e("icon"), unref(u).e("clear")]), onMousedown: withModifiers(unref(Oa), ["prevent"]), onClick: Ae }, { default: withCtx(() => [ createVNode(unref(Yd)) ]), _: 1 }, 8, ["class", "onMousedown"])) : createCommentVNode("v-if", true), unref(B) ? (openBlock(), createBlock(unref(It), { key: 2, class: normalizeClass([unref(u).e("icon"), unref(u).e("password")]), onClick: k }, { default: withCtx(() => [ (openBlock(), createBlock(resolveDynamicComponent(unref(P)))) ]), _: 1 }, 8, ["class"])) : createCommentVNode("v-if", true), unref(U) ? (openBlock(), createElementBlock("span", { key: 3, class: normalizeClass(unref(u).e("count")) }, [ createBaseVNode("span", { class: normalizeClass(unref(u).e("count-inner")) }, toDisplayString(unref(G)) + " / " + toDisplayString(he.maxlength), 3) ], 2)) : createCommentVNode("v-if", true), unref(E) && unref(C) && unref(_) ? (openBlock(), createBlock(unref(It), { key: 4, class: normalizeClass([ unref(u).e("icon"), unref(u).e("validateIcon"), unref(u).is("loading", unref(E) === "validating") ]) }, { default: withCtx(() => [ (openBlock(), createBlock(resolveDynamicComponent(unref(C)))) ]), _: 1 }, 8, ["class"])) : createCommentVNode("v-if", true) ], 2) ], 2)) : createCommentVNode("v-if", true) ], 2), createCommentVNode(" append slot "), he.$slots.append ? (openBlock(), createElementBlock("div", { key: 1, class: normalizeClass(unref(u).be("group", "append")) }, [ renderSlot(he.$slots, "append") ], 2)) : createCommentVNode("v-if", true) ], 64)) : (openBlock(), createElementBlock(Fragment, { key: 1 }, [ createCommentVNode(" textarea "), createBaseVNode("textarea", mergeProps({ id: unref(f), ref_key: "textarea", ref: m, class: [unref(y).e("inner"), unref(u).is("focus", unref(S))] }, unref(l), { minlength: he.minlength, maxlength: he.maxlength, tabindex: he.tabindex, disabled: unref(p), readonly: he.readonly, autocomplete: he.autocomplete, style: unref(F), "aria-label": he.ariaLabel, placeholder: he.placeholder, form: he.form, autofocus: he.autofocus, rows: he.rows, onCompositionstart: unref(K), onCompositionupdate: unref(ce), onCompositionend: unref(se), onInput: re, onFocus: unref(I), onBlur: unref(T), onChange: V, onKeydown: fe }), null, 16, ["id", "minlength", "maxlength", "tabindex", "disabled", "readonly", "autocomplete", "aria-label", "placeholder", "form", "autofocus", "rows", "onCompositionstart", "onCompositionupdate", "onCompositionend", "onFocus", "onBlur"]), unref(U) ? (openBlock(), createElementBlock("span", { key: 0, style: normalizeStyle(A.value), class: normalizeClass(unref(u).e("count")) }, toDisplayString(unref(G)) + " / " + toDisplayString(he.maxlength), 7)) : createCommentVNode("v-if", true) ], 64)) ], 16, ["role"])); } }); var qE = st(KE, [["__file", "input.vue"]]); var QE = on(qE); var Hs = 4; var e2 = { vertical: { offset: "offsetHeight", scroll: "scrollTop", scrollSize: "scrollHeight", size: "height", key: "vertical", axis: "Y", client: "clientY", direction: "top" }, horizontal: { offset: "offsetWidth", scroll: "scrollLeft", scrollSize: "scrollWidth", size: "width", key: "horizontal", axis: "X", client: "clientX", direction: "left" } }; var t2 = ({ move: n, size: e, bar: t }) => ({ [t.size]: e, transform: `translate${t.axis}(${n}%)` }); var cf = Symbol("scrollbarContextKey"); var n2 = at({ vertical: Boolean, size: String, move: Number, ratio: { type: Number, required: true }, always: Boolean }); var i2 = "Thumb"; var r2 = defineComponent({ __name: "thumb", props: n2, setup(n) { const e = n, t = inject(cf), i = nt("scrollbar"); t || Xo(i2, "can not inject scrollbar context"); const r = ref(), s = ref(), o = ref({}), a = ref(false); let c = false, l = false, d = en ? document.onselectstart : null; const h6 = computed(() => e2[e.vertical ? "vertical" : "horizontal"]), f = computed(() => t2({ size: e.size, move: e.move, bar: h6.value })), g = computed(() => r.value[h6.value.offset] ** 2 / t.wrapElement[h6.value.scrollSize] / e.ratio / s.value[h6.value.offset]), p = (M) => { var R; if (M.stopPropagation(), M.ctrlKey || [1, 2].includes(M.button)) return; (R = window.getSelection()) == null || R.removeAllRanges(), y(M); const L = M.currentTarget; L && (o.value[h6.value.axis] = L[h6.value.offset] - (M[h6.value.client] - L.getBoundingClientRect()[h6.value.direction])); }, u = (M) => { if (!s.value || !r.value || !t.wrapElement) return; const R = Math.abs(M.target.getBoundingClientRect()[h6.value.direction] - M[h6.value.client]), L = s.value[h6.value.offset] / 2, S = (R - L) * 100 * g.value / r.value[h6.value.offset]; t.wrapElement[h6.value.scroll] = S * t.wrapElement[h6.value.scrollSize] / 100; }, y = (M) => { M.stopImmediatePropagation(), c = true, document.addEventListener("mousemove", v), document.addEventListener("mouseup", m), d = document.onselectstart, document.onselectstart = () => false; }, v = (M) => { if (!r.value || !s.value || c === false) return; const R = o.value[h6.value.axis]; if (!R) return; const L = (r.value.getBoundingClientRect()[h6.value.direction] - M[h6.value.client]) * -1, S = s.value[h6.value.offset] - R, I = (L - S) * 100 * g.value / r.value[h6.value.offset]; t.wrapElement[h6.value.scroll] = I * t.wrapElement[h6.value.scrollSize] / 100; }, m = () => { c = false, o.value[h6.value.axis] = 0, document.removeEventListener("mousemove", v), document.removeEventListener("mouseup", m), A(), l && (a.value = false); }, x = () => { l = false, a.value = !!e.size; }, w = () => { l = true, a.value = c; }; onBeforeUnmount(() => { A(), document.removeEventListener("mouseup", m); }); const A = () => { document.onselectstart !== d && (document.onselectstart = d); }; return un(toRef(t, "scrollbarElement"), "mousemove", x), un(toRef(t, "scrollbarElement"), "mouseleave", w), (M, R) => (openBlock(), createBlock(Transition, { name: unref(i).b("fade"), persisted: "" }, { default: withCtx(() => [ withDirectives(createBaseVNode("div", { ref_key: "instance", ref: r, class: normalizeClass([unref(i).e("bar"), unref(i).is(unref(h6).key)]), onMousedown: u }, [ createBaseVNode("div", { ref_key: "thumb", ref: s, class: normalizeClass(unref(i).e("thumb")), style: normalizeStyle(unref(f)), onMousedown: p }, null, 38) ], 34), [ [vShow, M.always || a.value] ]) ]), _: 1 }, 8, ["name"])); } }); var wm = st(r2, [["__file", "thumb.vue"]]); var s2 = at({ always: { type: Boolean, default: true }, minSize: { type: Number, required: true } }); var o2 = defineComponent({ __name: "bar", props: s2, setup(n, { expose: e }) { const t = n, i = inject(cf), r = ref(0), s = ref(0), o = ref(""), a = ref(""), c = ref(1), l = ref(1); return e({ handleScroll: (f) => { if (f) { const g = f.offsetHeight - Hs, p = f.offsetWidth - Hs; s.value = f.scrollTop * 100 / g * c.value, r.value = f.scrollLeft * 100 / p * l.value; } }, update: () => { const f = i == null ? void 0 : i.wrapElement; if (!f) return; const g = f.offsetHeight - Hs, p = f.offsetWidth - Hs, u = g ** 2 / f.scrollHeight, y = p ** 2 / f.scrollWidth, v = Math.max(u, t.minSize), m = Math.max(y, t.minSize); c.value = u / (g - u) / (v / (g - v)), l.value = y / (p - y) / (m / (p - m)), a.value = v + Hs < g ? `${v}px` : "", o.value = m + Hs < p ? `${m}px` : ""; } }), (f, g) => (openBlock(), createElementBlock(Fragment, null, [ createVNode(wm, { move: r.value, ratio: l.value, size: o.value, always: f.always }, null, 8, ["move", "ratio", "size", "always"]), createVNode(wm, { move: s.value, ratio: c.value, size: a.value, vertical: "", always: f.always }, null, 8, ["move", "ratio", "size", "always"]) ], 64)); } }); var a2 = st(o2, [["__file", "bar.vue"]]); var l2 = at({ height: { type: [String, Number], default: "" }, maxHeight: { type: [String, Number], default: "" }, native: { type: Boolean, default: false }, wrapStyle: { type: Je([String, Object, Array]), default: "" }, wrapClass: { type: [String, Array], default: "" }, viewClass: { type: [String, Array], default: "" }, viewStyle: { type: [String, Array, Object], default: "" }, noresize: Boolean, tag: { type: String, default: "div" }, always: Boolean, minSize: { type: Number, default: 20 }, tabindex: { type: [String, Number], default: void 0 }, id: String, role: String, ...Yr(["ariaLabel", "ariaOrientation"]) }); var c2 = { scroll: ({ scrollTop: n, scrollLeft: e }) => [n, e].every(yt) }; var Jh = "ElScrollbar"; var u2 = defineComponent({ name: Jh }); var h2 = defineComponent({ ...u2, props: l2, emits: c2, setup(n, { expose: e, emit: t }) { const i = n, r = nt("scrollbar"); let s, o, a = 0, c = 0; const l = ref(), d = ref(), h6 = ref(), f = ref(), g = computed(() => { const A = {}; return i.height && (A.height = Dc(i.height)), i.maxHeight && (A.maxHeight = Dc(i.maxHeight)), [i.wrapStyle, A]; }), p = computed(() => [ i.wrapClass, r.e("wrap"), { [r.em("wrap", "hidden-default")]: !i.native } ]), u = computed(() => [r.e("view"), i.viewClass]), y = () => { var A; d.value && ((A = f.value) == null || A.handleScroll(d.value), a = d.value.scrollTop, c = d.value.scrollLeft, t("scroll", { scrollTop: d.value.scrollTop, scrollLeft: d.value.scrollLeft })); }; function v(A, M) { Tn(A) ? d.value.scrollTo(A) : yt(A) && yt(M) && d.value.scrollTo(A, M); } const m = (A) => { if (!yt(A)) { Vt(Jh, "value must be a number"); return; } d.value.scrollTop = A; }, x = (A) => { if (!yt(A)) { Vt(Jh, "value must be a number"); return; } d.value.scrollLeft = A; }, w = () => { var A; (A = f.value) == null || A.update(); }; return watch(() => i.noresize, (A) => { A ? (s == null || s(), o == null || o()) : ({ stop: s } = Yn(h6, w), o = un("resize", w)); }, { immediate: true }), watch(() => [i.maxHeight, i.height], () => { i.native || nextTick(() => { var A; w(), d.value && ((A = f.value) == null || A.handleScroll(d.value)); }); }), provide(cf, reactive({ scrollbarElement: l, wrapElement: d })), onActivated(() => { d.value && (d.value.scrollTop = a, d.value.scrollLeft = c); }), onMounted(() => { i.native || nextTick(() => { w(); }); }), onUpdated(() => w()), e({ wrapRef: d, update: w, scrollTo: v, setScrollTop: m, setScrollLeft: x, handleScroll: y }), (A, M) => (openBlock(), createElementBlock("div", { ref_key: "scrollbarRef", ref: l, class: normalizeClass(unref(r).b()) }, [ createBaseVNode("div", { ref_key: "wrapRef", ref: d, class: normalizeClass(unref(p)), style: normalizeStyle(unref(g)), tabindex: A.tabindex, onScroll: y }, [ (openBlock(), createBlock(resolveDynamicComponent(A.tag), { id: A.id, ref_key: "resizeRef", ref: h6, class: normalizeClass(unref(u)), style: normalizeStyle(A.viewStyle), role: A.role, "aria-label": A.ariaLabel, "aria-orientation": A.ariaOrientation }, { default: withCtx(() => [ renderSlot(A.$slots, "default") ]), _: 3 }, 8, ["id", "class", "style", "role", "aria-label", "aria-orientation"])) ], 46, ["tabindex"]), A.native ? createCommentVNode("v-if", true) : (openBlock(), createBlock(a2, { key: 0, ref_key: "barRef", ref: f, always: A.always, "min-size": A.minSize }, null, 8, ["always", "min-size"])) ], 2)); } }); var d2 = st(h2, [["__file", "scrollbar.vue"]]); var f2 = on(d2); var uf = Symbol("popper"); var z0 = Symbol("popperContent"); var p2 = [ "dialog", "grid", "group", "listbox", "menu", "navigation", "tooltip", "tree" ]; var V0 = at({ role: { type: String, values: p2, default: "tooltip" } }); var m2 = defineComponent({ name: "ElPopper", inheritAttrs: false }); var g2 = defineComponent({ ...m2, props: V0, setup(n, { expose: e }) { const t = n, i = ref(), r = ref(), s = ref(), o = ref(), a = computed(() => t.role), c = { triggerRef: i, popperInstanceRef: r, contentRef: s, referenceRef: o, role: a }; return e(c), provide(uf, c), (l, d) => renderSlot(l.$slots, "default"); } }); var v2 = st(g2, [["__file", "popper.vue"]]); var k0 = at({ arrowOffset: { type: Number, default: 5 } }); var y2 = defineComponent({ name: "ElPopperArrow", inheritAttrs: false }); var b2 = defineComponent({ ...y2, props: k0, setup(n, { expose: e }) { const t = n, i = nt("popper"), { arrowOffset: r, arrowRef: s, arrowStyle: o } = inject(z0, void 0); return watch(() => t.arrowOffset, (a) => { r.value = a; }), onBeforeUnmount(() => { s.value = void 0; }), e({ arrowRef: s }), (a, c) => (openBlock(), createElementBlock("span", { ref_key: "arrowRef", ref: s, class: normalizeClass(unref(i).e("arrow")), style: normalizeStyle(unref(o)), "data-popper-arrow": "" }, null, 6)); } }); var x2 = st(b2, [["__file", "arrow.vue"]]); var Bu = "ElOnlyChild"; var M2 = defineComponent({ name: Bu, setup(n, { slots: e, attrs: t }) { var i; const r = inject(R0), s = EE((i = r == null ? void 0 : r.setForwardRef) != null ? i : Oa); return () => { var o; const a = (o = e.default) == null ? void 0 : o.call(e, t); if (!a) return null; if (a.length > 1) return Vt(Bu, "requires exact only one valid child."), null; const c = G0(a); return c ? withDirectives(cloneVNode(c, t), [[s]]) : (Vt(Bu, "no valid child node found"), null); }; } }); function G0(n) { if (!n) return null; const e = n; for (const t of e) { if (Tn(t)) switch (t.type) { case Comment: continue; case Text: case "svg": return Am(t); case Fragment: return G0(t.children); default: return t; } return Am(t); } return null; } function Am(n) { const e = nt("only-child"); return createVNode("span", { class: e.e("content") }, [n]); } var H0 = at({ virtualRef: { type: Je(Object) }, virtualTriggering: Boolean, onMouseenter: { type: Je(Function) }, onMouseleave: { type: Je(Function) }, onClick: { type: Je(Function) }, onKeydown: { type: Je(Function) }, onFocus: { type: Je(Function) }, onBlur: { type: Je(Function) }, onContextmenu: { type: Je(Function) }, id: String, open: Boolean }); var w2 = defineComponent({ name: "ElPopperTrigger", inheritAttrs: false }); var A2 = defineComponent({ ...w2, props: H0, setup(n, { expose: e }) { const t = n, { role: i, triggerRef: r } = inject(uf, void 0); TE(r); const s = computed(() => a.value ? t.id : void 0), o = computed(() => { if (i && i.value === "tooltip") return t.open && t.id ? t.id : void 0; }), a = computed(() => { if (i && i.value !== "tooltip") return i.value; }), c = computed(() => a.value ? `${t.open}` : void 0); let l; const d = [ "onMouseenter", "onMouseleave", "onClick", "onKeydown", "onFocus", "onBlur", "onContextmenu" ]; return onMounted(() => { watch(() => t.virtualRef, (h6) => { h6 && (r.value = Qi(h6)); }, { immediate: true }), watch(r, (h6, f) => { l == null || l(), l = void 0, ys(h6) && (d.forEach((g) => { var p; const u = t[g]; u && (h6.addEventListener(g.slice(2).toLowerCase(), u), (p = f == null ? void 0 : f.removeEventListener) == null || p.call(f, g.slice(2).toLowerCase(), u)); }), l = watch([s, o, a, c], (g) => { [ "aria-controls", "aria-describedby", "aria-haspopup", "aria-expanded" ].forEach((p, u) => { Ci(g[u]) ? h6.removeAttribute(p) : h6.setAttribute(p, g[u]); }); }, { immediate: true })), ys(f) && [ "aria-controls", "aria-describedby", "aria-haspopup", "aria-expanded" ].forEach((g) => f.removeAttribute(g)); }, { immediate: true }); }), onBeforeUnmount(() => { if (l == null || l(), l = void 0, r.value && ys(r.value)) { const h6 = r.value; d.forEach((f) => { const g = t[f]; g && h6.removeEventListener(f.slice(2).toLowerCase(), g); }), r.value = void 0; } }), e({ triggerRef: r }), (h6, f) => h6.virtualTriggering ? createCommentVNode("v-if", true) : (openBlock(), createBlock(unref(M2), mergeProps({ key: 0 }, h6.$attrs, { "aria-controls": unref(s), "aria-describedby": unref(o), "aria-expanded": unref(c), "aria-haspopup": unref(a) }), { default: withCtx(() => [ renderSlot(h6.$slots, "default") ]), _: 3 }, 16, ["aria-controls", "aria-describedby", "aria-expanded", "aria-haspopup"])); } }); var S2 = st(A2, [["__file", "trigger.vue"]]); var Uu = "focus-trap.focus-after-trapped"; var zu = "focus-trap.focus-after-released"; var _2 = "focus-trap.focusout-prevented"; var Sm = { cancelable: true, bubbles: false }; var T2 = { cancelable: true, bubbles: false }; var _m = "focusAfterTrapped"; var Tm = "focusAfterReleased"; var E2 = Symbol("elFocusTrap"); var hf = ref(); var ou = ref(0); var df = ref(0); var El = 0; var W0 = (n) => { const e = [], t = document.createTreeWalker(n, NodeFilter.SHOW_ELEMENT, { acceptNode: (i) => { const r = i.tagName === "INPUT" && i.type === "hidden"; return i.disabled || i.hidden || r ? NodeFilter.FILTER_SKIP : i.tabIndex >= 0 || i === document.activeElement ? NodeFilter.FILTER_ACCEPT : NodeFilter.FILTER_SKIP; } }); for (; t.nextNode(); ) e.push(t.currentNode); return e; }; var Em = (n, e) => { for (const t of n) if (!C2(t, e)) return t; }; var C2 = (n, e) => { if (false) return false; if (getComputedStyle(n).visibility === "hidden") return true; for (; n; ) { if (e && n === e) return false; if (getComputedStyle(n).display === "none") return true; n = n.parentElement; } return false; }; var L2 = (n) => { const e = W0(n), t = Em(e, n), i = Em(e.reverse(), n); return [t, i]; }; var R2 = (n) => n instanceof HTMLInputElement && "select" in n; var Tr = (n, e) => { if (n && n.focus) { const t = document.activeElement; n.focus({ preventScroll: true }), df.value = window.performance.now(), n !== t && R2(n) && e && n.select(); } }; function Cm(n, e) { const t = [...n], i = n.indexOf(e); return i !== -1 && t.splice(i, 1), t; } var F2 = () => { let n = []; return { push: (i) => { const r = n[0]; r && i !== r && r.pause(), n = Cm(n, i), n.unshift(i); }, remove: (i) => { var r, s; n = Cm(n, i), (s = (r = n[0]) == null ? void 0 : r.resume) == null || s.call(r); } }; }; var P2 = (n, e = false) => { const t = document.activeElement; for (const i of n) if (Tr(i, e), document.activeElement !== t) return; }; var Lm = F2(); var I2 = () => ou.value > df.value; var Cl = () => { hf.value = "pointer", ou.value = window.performance.now(); }; var Rm = () => { hf.value = "keyboard", ou.value = window.performance.now(); }; var O2 = () => (onMounted(() => { El === 0 && (document.addEventListener("mousedown", Cl), document.addEventListener("touchstart", Cl), document.addEventListener("keydown", Rm)), El++; }), onBeforeUnmount(() => { El--, El <= 0 && (document.removeEventListener("mousedown", Cl), document.removeEventListener("touchstart", Cl), document.removeEventListener("keydown", Rm)); }), { focusReason: hf, lastUserFocusTimestamp: ou, lastAutomatedFocusTimestamp: df }); var Ll = (n) => new CustomEvent(_2, { ...T2, detail: n }); var D2 = defineComponent({ name: "ElFocusTrap", inheritAttrs: false, props: { loop: Boolean, trapped: Boolean, focusTrapEl: Object, focusStartEl: { type: [Object, String], default: "first" } }, emits: [ _m, Tm, "focusin", "focusout", "focusout-prevented", "release-requested" ], setup(n, { emit: e }) { const t = ref(); let i, r; const { focusReason: s } = O2(); ME((p) => { n.trapped && !o.paused && e("release-requested", p); }); const o = { paused: false, pause() { this.paused = true; }, resume() { this.paused = false; } }, a = (p) => { if (!n.loop && !n.trapped || o.paused) return; const { key: u, altKey: y, ctrlKey: v, metaKey: m, currentTarget: x, shiftKey: w } = p, { loop: A } = n, M = u === Li.tab && !y && !v && !m, R = document.activeElement; if (M && R) { const L = x, [S, I] = L2(L); if (S && I) { if (!w && R === I) { const _ = Ll({ focusReason: s.value }); e("focusout-prevented", _), _.defaultPrevented || (p.preventDefault(), A && Tr(S, true)); } else if (w && [S, L].includes(R)) { const _ = Ll({ focusReason: s.value }); e("focusout-prevented", _), _.defaultPrevented || (p.preventDefault(), A && Tr(I, true)); } } else if (R === L) { const _ = Ll({ focusReason: s.value }); e("focusout-prevented", _), _.defaultPrevented || p.preventDefault(); } } }; provide(E2, { focusTrapRef: t, onKeydown: a }), watch(() => n.focusTrapEl, (p) => { p && (t.value = p); }, { immediate: true }), watch([t], ([p], [u]) => { p && (p.addEventListener("keydown", a), p.addEventListener("focusin", d), p.addEventListener("focusout", h6)), u && (u.removeEventListener("keydown", a), u.removeEventListener("focusin", d), u.removeEventListener("focusout", h6)); }); const c = (p) => { e(_m, p); }, l = (p) => e(Tm, p), d = (p) => { const u = unref(t); if (!u) return; const y = p.target, v = p.relatedTarget, m = y && u.contains(y); n.trapped || v && u.contains(v) || (i = v), m && e("focusin", p), !o.paused && n.trapped && (m ? r = y : Tr(r, true)); }, h6 = (p) => { const u = unref(t); if (!(o.paused || !u)) if (n.trapped) { const y = p.relatedTarget; !Ci(y) && !u.contains(y) && setTimeout(() => { if (!o.paused && n.trapped) { const v = Ll({ focusReason: s.value }); e("focusout-prevented", v), v.defaultPrevented || Tr(r, true); } }, 0); } else { const y = p.target; y && u.contains(y) || e("focusout", p); } }; async function f() { await nextTick(); const p = unref(t); if (p) { Lm.push(o); const u = p.contains(document.activeElement) ? i : document.activeElement; if (i = u, !p.contains(u)) { const v = new Event(Uu, Sm); p.addEventListener(Uu, c), p.dispatchEvent(v), v.defaultPrevented || nextTick(() => { let m = n.focusStartEl; vn(m) || (Tr(m), document.activeElement !== m && (m = "first")), m === "first" && P2(W0(p), true), (document.activeElement === u || m === "container") && Tr(p); }); } } } function g() { const p = unref(t); if (p) { p.removeEventListener(Uu, c); const u = new CustomEvent(zu, { ...Sm, detail: { focusReason: s.value } }); p.addEventListener(zu, l), p.dispatchEvent(u), !u.defaultPrevented && (s.value == "keyboard" || !I2() || p.contains(document.activeElement)) && Tr(i ?? document.body), p.removeEventListener(zu, l), Lm.remove(o); } } return onMounted(() => { n.trapped && f(), watch(() => n.trapped, (p) => { p ? f() : g(); }); }), onBeforeUnmount(() => { n.trapped && g(), t.value && (t.value.removeEventListener("keydown", a), t.value.removeEventListener("focusin", d), t.value.removeEventListener("focusout", h6), t.value = void 0); }), { onKeydown: a }; } }); function N2(n, e, t, i, r, s) { return renderSlot(n.$slots, "default", { handleKeydown: n.onKeydown }); } var B2 = st(D2, [["render", N2], ["__file", "focus-trap.vue"]]); var U2 = ["fixed", "absolute"]; var z2 = at({ boundariesPadding: { type: Number, default: 0 }, fallbackPlacements: { type: Je(Array), default: void 0 }, gpuAcceleration: { type: Boolean, default: true }, offset: { type: Number, default: 12 }, placement: { type: String, values: Yo, default: "bottom" }, popperOptions: { type: Je(Object), default: () => ({}) }, strategy: { type: String, values: U2, default: "absolute" } }); var j0 = at({ ...z2, id: String, style: { type: Je([String, Array, Object]) }, className: { type: Je([String, Array, Object]) }, effect: { type: Je(String), default: "dark" }, visible: Boolean, enterable: { type: Boolean, default: true }, pure: Boolean, focusOnShow: { type: Boolean, default: false }, trapping: { type: Boolean, default: false }, popperClass: { type: Je([String, Array, Object]) }, popperStyle: { type: Je([String, Array, Object]) }, referenceEl: { type: Je(Object) }, triggerTargetEl: { type: Je(Object) }, stopPopperMouseEvent: { type: Boolean, default: true }, virtualTriggering: Boolean, zIndex: Number, ...Yr(["ariaLabel"]) }); var V2 = { mouseenter: (n) => n instanceof MouseEvent, mouseleave: (n) => n instanceof MouseEvent, focus: () => true, blur: () => true, close: () => true }; var k2 = (n, e = []) => { const { placement: t, strategy: i, popperOptions: r } = n, s = { placement: t, strategy: i, ...r, modifiers: [...H2(n), ...e] }; return W2(s, r == null ? void 0 : r.modifiers), s; }; var G2 = (n) => { if (en) return Qi(n); }; function H2(n) { const { offset: e, gpuAcceleration: t, fallbackPlacements: i } = n; return [ { name: "offset", options: { offset: [0, e ?? 12] } }, { name: "preventOverflow", options: { padding: { top: 2, bottom: 2, left: 5, right: 5 } } }, { name: "flip", options: { padding: 5, fallbackPlacements: i } }, { name: "computeStyles", options: { gpuAcceleration: t } } ]; } function W2(n, e) { e && (n.modifiers = [...n.modifiers, ...e ?? []]); } var j2 = 0; var $2 = (n) => { const { popperInstanceRef: e, contentRef: t, triggerRef: i, role: r } = inject(uf, void 0), s = ref(), o = ref(), a = computed(() => ({ name: "eventListeners", enabled: !!n.visible })), c = computed(() => { var v; const m = unref(s), x = (v = unref(o)) != null ? v : j2; return { name: "arrow", enabled: !C_(m), options: { element: m, padding: x } }; }), l = computed(() => ({ onFirstUpdate: () => { p(); }, ...k2(n, [ unref(c), unref(a) ]) })), d = computed(() => G2(n.referenceEl) || unref(i)), { attributes: h6, state: f, styles: g, update: p, forceUpdate: u, instanceRef: y } = yE(d, t, l); return watch(y, (v) => e.value = v), onMounted(() => { watch(() => { var v; return (v = unref(d)) == null ? void 0 : v.getBoundingClientRect(); }, () => { p(); }); }), { attributes: h6, arrowRef: s, contentRef: t, instanceRef: y, state: f, styles: g, role: r, forceUpdate: u, update: p }; }; var Z2 = (n, { attributes: e, styles: t, role: i }) => { const { nextZIndex: r } = I0(), s = nt("popper"), o = computed(() => unref(e).popper), a = ref(yt(n.zIndex) ? n.zIndex : r()), c = computed(() => [ s.b(), s.is("pure", n.pure), s.is(n.effect), n.popperClass ]), l = computed(() => [ { zIndex: unref(a) }, unref(t).popper, n.popperStyle || {} ]), d = computed(() => i.value === "dialog" ? "false" : void 0), h6 = computed(() => unref(t).arrow || {}); return { ariaModal: d, arrowStyle: h6, contentAttrs: o, contentClass: c, contentStyle: l, contentZIndex: a, updateZIndex: () => { a.value = yt(n.zIndex) ? n.zIndex : r(); } }; }; var X2 = (n, e) => { const t = ref(false), i = ref(); return { focusStartRef: i, trapped: t, onFocusAfterReleased: (l) => { var d; ((d = l.detail) == null ? void 0 : d.focusReason) !== "pointer" && (i.value = "first", e("blur")); }, onFocusAfterTrapped: () => { e("focus"); }, onFocusInTrap: (l) => { n.visible && !t.value && (l.target && (i.value = l.target), t.value = true); }, onFocusoutPrevented: (l) => { n.trapping || (l.detail.focusReason === "pointer" && l.preventDefault(), t.value = false); }, onReleaseRequested: () => { t.value = false, e("close"); } }; }; var Y2 = defineComponent({ name: "ElPopperContent" }); var J2 = defineComponent({ ...Y2, props: j0, emits: V2, setup(n, { expose: e, emit: t }) { const i = n, { focusStartRef: r, trapped: s, onFocusAfterReleased: o, onFocusAfterTrapped: a, onFocusInTrap: c, onFocusoutPrevented: l, onReleaseRequested: d } = X2(i, t), { attributes: h6, arrowRef: f, contentRef: g, styles: p, instanceRef: u, role: y, update: v } = $2(i), { ariaModal: m, arrowStyle: x, contentAttrs: w, contentClass: A, contentStyle: M, updateZIndex: R } = Z2(i, { styles: p, attributes: h6, role: y }), L = inject(zc, void 0), S = ref(); provide(z0, { arrowStyle: x, arrowRef: f, arrowOffset: S }), L && provide(zc, { ...L, addInputId: Oa, removeInputId: Oa }); let I; const T = (E = true) => { v(), E && R(); }, _ = () => { T(false), i.visible && i.focusOnShow ? s.value = true : i.visible === false && (s.value = false); }; return onMounted(() => { watch(() => i.triggerTargetEl, (E, C) => { I == null || I(), I = void 0; const P = unref(E || g.value), b = unref(C || g.value); ys(P) && (I = watch([y, () => i.ariaLabel, m, () => i.id], (F) => { ["role", "aria-label", "aria-modal", "id"].forEach((D, N) => { Ci(F[N]) ? P.removeAttribute(D) : P.setAttribute(D, F[N]); }); }, { immediate: true })), b !== P && ys(b) && ["role", "aria-label", "aria-modal", "id"].forEach((F) => { b.removeAttribute(F); }); }, { immediate: true }), watch(() => i.visible, _, { immediate: true }); }), onBeforeUnmount(() => { I == null || I(), I = void 0; }), e({ popperContentRef: g, popperInstanceRef: u, updatePopper: T, contentStyle: M }), (E, C) => (openBlock(), createElementBlock("div", mergeProps({ ref_key: "contentRef", ref: g }, unref(w), { style: unref(M), class: unref(A), tabindex: "-1", onMouseenter: (P) => E.$emit("mouseenter", P), onMouseleave: (P) => E.$emit("mouseleave", P) }), [ createVNode(unref(B2), { trapped: unref(s), "trap-on-focus-in": true, "focus-trap-el": unref(g), "focus-start-el": unref(r), onFocusAfterTrapped: unref(a), onFocusAfterReleased: unref(o), onFocusin: unref(c), onFocusoutPrevented: unref(l), onReleaseRequested: unref(d) }, { default: withCtx(() => [ renderSlot(E.$slots, "default") ]), _: 3 }, 8, ["trapped", "focus-trap-el", "focus-start-el", "onFocusAfterTrapped", "onFocusAfterReleased", "onFocusin", "onFocusoutPrevented", "onReleaseRequested"]) ], 16, ["onMouseenter", "onMouseleave"])); } }); var K2 = st(J2, [["__file", "content.vue"]]); var q2 = on(v2); var ff = Symbol("elTooltip"); var Vn = at({ ...SE, ...j0, appendTo: { type: Je([String, Object]) }, content: { type: String, default: "" }, rawContent: Boolean, persistent: Boolean, visible: { type: Je(Boolean), default: null }, transition: String, teleported: { type: Boolean, default: true }, disabled: Boolean, ...Yr(["ariaLabel"]) }); var Va = at({ ...H0, disabled: Boolean, trigger: { type: Je([String, Array]), default: "hover" }, triggerKeys: { type: Je(Array), default: () => [Li.enter, Li.space] } }); var { useModelToggleProps: Q2, useModelToggleEmits: eC, useModelToggle: tC } = mT("visible"); var nC = at({ ...V0, ...Q2, ...Vn, ...Va, ...k0, showArrow: { type: Boolean, default: true } }); var iC = [ ...eC, "before-show", "before-hide", "show", "hide", "open", "close" ]; var rC = (n, e) => Pn(n) ? n.includes(e) : n === e; var Ws = (n, e, t) => (i) => { rC(unref(n), e) && t(i); }; var sC = defineComponent({ name: "ElTooltipTrigger" }); var oC = defineComponent({ ...sC, props: Va, setup(n, { expose: e }) { const t = n, i = nt("tooltip"), { controlled: r, id: s, open: o, onOpen: a, onClose: c, onToggle: l } = inject(ff, void 0), d = ref(null), h6 = () => { if (unref(r) || t.disabled) return true; }, f = toRef(t, "trigger"), g = Yi(h6, Ws(f, "hover", a)), p = Yi(h6, Ws(f, "hover", c)), u = Yi(h6, Ws(f, "click", (w) => { w.button === 0 && l(w); })), y = Yi(h6, Ws(f, "focus", a)), v = Yi(h6, Ws(f, "focus", c)), m = Yi(h6, Ws(f, "contextmenu", (w) => { w.preventDefault(), l(w); })), x = Yi(h6, (w) => { const { code: A } = w; t.triggerKeys.includes(A) && (w.preventDefault(), l(w)); }); return e({ triggerRef: d }), (w, A) => (openBlock(), createBlock(unref(S2), { id: unref(s), "virtual-ref": w.virtualRef, open: unref(o), "virtual-triggering": w.virtualTriggering, class: normalizeClass(unref(i).e("trigger")), onBlur: unref(v), onClick: unref(u), onContextmenu: unref(m), onFocus: unref(y), onMouseenter: unref(g), onMouseleave: unref(p), onKeydown: unref(x) }, { default: withCtx(() => [ renderSlot(w.$slots, "default") ]), _: 3 }, 8, ["id", "virtual-ref", "open", "virtual-triggering", "class", "onBlur", "onClick", "onContextmenu", "onFocus", "onMouseenter", "onMouseleave", "onKeydown"])); } }); var aC = st(oC, [["__file", "trigger.vue"]]); var lC = at({ to: { type: Je([String, Object]), required: true }, disabled: Boolean }); var cC = defineComponent({ __name: "teleport", props: lC, setup(n) { return (e, t) => e.disabled ? renderSlot(e.$slots, "default", { key: 0 }) : (openBlock(), createBlock(Teleport, { key: 1, to: e.to }, [ renderSlot(e.$slots, "default") ], 8, ["to"])); } }); var uC = st(cC, [["__file", "teleport.vue"]]); var hC = on(uC); var dC = defineComponent({ name: "ElTooltipContent", inheritAttrs: false }); var fC = defineComponent({ ...dC, props: Vn, setup(n, { expose: e }) { const t = n, { selector: i } = L0(), r = nt("tooltip"), s = ref(null); let o; const { controlled: a, id: c, open: l, trigger: d, onClose: h6, onOpen: f, onShow: g, onHide: p, onBeforeShow: u, onBeforeHide: y } = inject(ff, void 0), v = computed(() => t.transition || `${r.namespace.value}-fade-in-linear`), m = computed(() => false ? true : t.persistent); onBeforeUnmount(() => { o == null || o(); }); const x = computed(() => unref(m) ? true : unref(l)), w = computed(() => t.disabled ? false : unref(l)), A = computed(() => t.appendTo || i.value), M = computed(() => { var b; return (b = t.style) != null ? b : {}; }), R = ref(true), L = () => { p(), R.value = true; }, S = () => { if (unref(a)) return true; }, I = Yi(S, () => { t.enterable && unref(d) === "hover" && f(); }), T = Yi(S, () => { unref(d) === "hover" && h6(); }), _ = () => { var b, F; (F = (b = s.value) == null ? void 0 : b.updatePopper) == null || F.call(b), u == null || u(); }, E = () => { y == null || y(); }, C = () => { g(), o = yw(computed(() => { var b; return (b = s.value) == null ? void 0 : b.popperContentRef; }), () => { if (unref(a)) return; unref(d) !== "hover" && h6(); }); }, P = () => { t.virtualTriggering || h6(); }; return watch(() => unref(l), (b) => { b ? R.value = false : o == null || o(); }, { flush: "post" }), watch(() => t.content, () => { var b, F; (F = (b = s.value) == null ? void 0 : b.updatePopper) == null || F.call(b); }), e({ contentRef: s }), (b, F) => (openBlock(), createBlock(unref(hC), { disabled: !b.teleported, to: unref(A) }, { default: withCtx(() => [ createVNode(Transition, { name: unref(v), onAfterLeave: L, onBeforeEnter: _, onAfterEnter: C, onBeforeLeave: E }, { default: withCtx(() => [ unref(x) ? withDirectives((openBlock(), createBlock(unref(K2), mergeProps({ key: 0, id: unref(c), ref_key: "contentRef", ref: s }, b.$attrs, { "aria-label": b.ariaLabel, "aria-hidden": R.value, "boundaries-padding": b.boundariesPadding, "fallback-placements": b.fallbackPlacements, "gpu-acceleration": b.gpuAcceleration, offset: b.offset, placement: b.placement, "popper-options": b.popperOptions, strategy: b.strategy, effect: b.effect, enterable: b.enterable, pure: b.pure, "popper-class": b.popperClass, "popper-style": [b.popperStyle, unref(M)], "reference-el": b.referenceEl, "trigger-target-el": b.triggerTargetEl, visible: unref(w), "z-index": b.zIndex, onMouseenter: unref(I), onMouseleave: unref(T), onBlur: P, onClose: unref(h6) }), { default: withCtx(() => [ renderSlot(b.$slots, "default") ]), _: 3 }, 16, ["id", "aria-label", "aria-hidden", "boundaries-padding", "fallback-placements", "gpu-acceleration", "offset", "placement", "popper-options", "strategy", "effect", "enterable", "pure", "popper-class", "popper-style", "reference-el", "trigger-target-el", "visible", "z-index", "onMouseenter", "onMouseleave", "onClose"])), [ [vShow, unref(w)] ]) : createCommentVNode("v-if", true) ]), _: 3 }, 8, ["name"]) ]), _: 3 }, 8, ["disabled", "to"])); } }); var pC = st(fC, [["__file", "content.vue"]]); var mC = defineComponent({ name: "ElTooltip" }); var gC = defineComponent({ ...mC, props: nC, emits: iC, setup(n, { expose: e, emit: t }) { const i = n; AE(); const r = sl(), s = ref(), o = ref(), a = () => { var v; const m = unref(s); m && ((v = m.popperInstanceRef) == null || v.update()); }, c = ref(false), l = ref(), { show: d, hide: h6, hasUpdateHandler: f } = tC({ indicator: c, toggleReason: l }), { onOpen: g, onClose: p } = _E({ showAfter: toRef(i, "showAfter"), hideAfter: toRef(i, "hideAfter"), autoClose: toRef(i, "autoClose"), open: d, close: h6 }), u = computed(() => Ba(i.visible) && !f.value); provide(ff, { controlled: u, id: r, open: readonly(c), trigger: toRef(i, "trigger"), onOpen: (v) => { g(v); }, onClose: (v) => { p(v); }, onToggle: (v) => { unref(c) ? p(v) : g(v); }, onShow: () => { t("show", l.value); }, onHide: () => { t("hide", l.value); }, onBeforeShow: () => { t("before-show", l.value); }, onBeforeHide: () => { t("before-hide", l.value); }, updatePopper: a }), watch(() => i.disabled, (v) => { v && c.value && (c.value = false); }); const y = (v) => { var m, x; const w = (x = (m = o.value) == null ? void 0 : m.contentRef) == null ? void 0 : x.popperContentRef, A = (v == null ? void 0 : v.relatedTarget) || document.activeElement; return w && w.contains(A); }; return onDeactivated(() => c.value && h6()), e({ popperRef: s, contentRef: o, isFocusInsideContent: y, updatePopper: a, onOpen: g, onClose: p, hide: h6 }), (v, m) => (openBlock(), createBlock(unref(q2), { ref_key: "popperRef", ref: s, role: v.role }, { default: withCtx(() => [ createVNode(aC, { disabled: v.disabled, trigger: v.trigger, "trigger-keys": v.triggerKeys, "virtual-ref": v.virtualRef, "virtual-triggering": v.virtualTriggering }, { default: withCtx(() => [ v.$slots.default ? renderSlot(v.$slots, "default", { key: 0 }) : createCommentVNode("v-if", true) ]), _: 3 }, 8, ["disabled", "trigger", "trigger-keys", "virtual-ref", "virtual-triggering"]), createVNode(pC, { ref_key: "contentRef", ref: o, "aria-label": v.ariaLabel, "boundaries-padding": v.boundariesPadding, content: v.content, disabled: v.disabled, effect: v.effect, enterable: v.enterable, "fallback-placements": v.fallbackPlacements, "hide-after": v.hideAfter, "gpu-acceleration": v.gpuAcceleration, offset: v.offset, persistent: v.persistent, "popper-class": v.popperClass, "popper-style": v.popperStyle, placement: v.placement, "popper-options": v.popperOptions, pure: v.pure, "raw-content": v.rawContent, "reference-el": v.referenceEl, "trigger-target-el": v.triggerTargetEl, "show-after": v.showAfter, strategy: v.strategy, teleported: v.teleported, transition: v.transition, "virtual-triggering": v.virtualTriggering, "z-index": v.zIndex, "append-to": v.appendTo }, { default: withCtx(() => [ renderSlot(v.$slots, "content", {}, () => [ v.rawContent ? (openBlock(), createElementBlock("span", { key: 0, innerHTML: v.content }, null, 8, ["innerHTML"])) : (openBlock(), createElementBlock("span", { key: 1 }, toDisplayString(v.content), 1)) ]), v.showArrow ? (openBlock(), createBlock(unref(x2), { key: 0, "arrow-offset": v.arrowOffset }, null, 8, ["arrow-offset"])) : createCommentVNode("v-if", true) ]), _: 3 }, 8, ["aria-label", "boundaries-padding", "content", "disabled", "effect", "enterable", "fallback-placements", "hide-after", "gpu-acceleration", "offset", "persistent", "popper-class", "popper-style", "placement", "popper-options", "pure", "raw-content", "reference-el", "trigger-target-el", "show-after", "strategy", "teleported", "transition", "virtual-triggering", "z-index", "append-to"]) ]), _: 3 }, 8, ["role"])); } }); var vC = st(gC, [["__file", "tooltip.vue"]]); var pf = on(vC); var $0 = Symbol("buttonGroupContextKey"); var yC = (n, e) => { p0({ from: "type.text", replacement: "link", version: "3.0.0", scope: "props", ref: "https://element-plus.org/en-US/component/button.html#button-attributes" }, computed(() => n.type === "text")); const t = inject($0, void 0), i = af("button"), { form: r } = Jo(), s = Ns(computed(() => t == null ? void 0 : t.size)), o = ol(), a = ref(), c = useSlots(), l = computed(() => n.type || (t == null ? void 0 : t.type) || ""), d = computed(() => { var p, u, y; return (y = (u = n.autoInsertSpace) != null ? u : (p = i.value) == null ? void 0 : p.autoInsertSpace) != null ? y : false; }), h6 = computed(() => n.tag === "button" ? { ariaDisabled: o.value || n.loading, disabled: o.value || n.loading, autofocus: n.autofocus, type: n.nativeType } : {}), f = computed(() => { var p; const u = (p = c.default) == null ? void 0 : p.call(c); if (d.value && (u == null ? void 0 : u.length) === 1) { const y = u[0]; if ((y == null ? void 0 : y.type) === Text) { const v = y.children; return new RegExp("^\\p{Unified_Ideograph}{2}$", "u").test(v.trim()); } } return false; }); return { _disabled: o, _size: s, _type: l, _ref: a, _props: h6, shouldAddSpace: f, handleClick: (p) => { if (o.value || n.loading) { p.stopPropagation(); return; } n.nativeType === "reset" && (r == null || r.resetFields()), e("click", p); } }; }; var bC = [ "default", "primary", "success", "warning", "info", "danger", "text", "" ]; var xC = ["button", "submit", "reset"]; var Kh = at({ size: Gr, disabled: Boolean, type: { type: String, values: bC, default: "" }, icon: { type: kr }, nativeType: { type: String, values: xC, default: "button" }, loading: Boolean, loadingIcon: { type: kr, default: () => c0 }, plain: Boolean, text: Boolean, link: Boolean, bg: Boolean, autofocus: Boolean, round: Boolean, circle: Boolean, color: String, dark: Boolean, autoInsertSpace: { type: Boolean, default: void 0 }, tag: { type: Je([String, Object]), default: "button" } }); var MC = { click: (n) => n instanceof MouseEvent }; function yn(n, e) { wC(n) && (n = "100%"); var t = AC(n); return n = e === 360 ? n : Math.min(e, Math.max(0, parseFloat(n))), t && (n = parseInt(String(n * e), 10) / 100), Math.abs(n - e) < 1e-6 ? 1 : (e === 360 ? n = (n < 0 ? n % e + e : n % e) / parseFloat(String(e)) : n = n % e / parseFloat(String(e)), n); } function Rl(n) { return Math.min(1, Math.max(0, n)); } function wC(n) { return typeof n == "string" && n.indexOf(".") !== -1 && parseFloat(n) === 1; } function AC(n) { return typeof n == "string" && n.indexOf("%") !== -1; } function Z0(n) { return n = parseFloat(n), (isNaN(n) || n < 0 || n > 1) && (n = 1), n; } function Fl(n) { return n <= 1 ? "".concat(Number(n) * 100, "%") : n; } function ms(n) { return n.length === 1 ? "0" + n : String(n); } function SC(n, e, t) { return { r: yn(n, 255) * 255, g: yn(e, 255) * 255, b: yn(t, 255) * 255 }; } function Fm(n, e, t) { n = yn(n, 255), e = yn(e, 255), t = yn(t, 255); var i = Math.max(n, e, t), r = Math.min(n, e, t), s = 0, o = 0, a = (i + r) / 2; if (i === r) o = 0, s = 0; else { var c = i - r; switch (o = a > 0.5 ? c / (2 - i - r) : c / (i + r), i) { case n: s = (e - t) / c + (e < t ? 6 : 0); break; case e: s = (t - n) / c + 2; break; case t: s = (n - e) / c + 4; break; } s /= 6; } return { h: s, s: o, l: a }; } function Vu(n, e, t) { return t < 0 && (t += 1), t > 1 && (t -= 1), t < 1 / 6 ? n + (e - n) * (6 * t) : t < 1 / 2 ? e : t < 2 / 3 ? n + (e - n) * (2 / 3 - t) * 6 : n; } function _C(n, e, t) { var i, r, s; if (n = yn(n, 360), e = yn(e, 100), t = yn(t, 100), e === 0) r = t, s = t, i = t; else { var o = t < 0.5 ? t * (1 + e) : t + e - t * e, a = 2 * t - o; i = Vu(a, o, n + 1 / 3), r = Vu(a, o, n), s = Vu(a, o, n - 1 / 3); } return { r: i * 255, g: r * 255, b: s * 255 }; } function Pm(n, e, t) { n = yn(n, 255), e = yn(e, 255), t = yn(t, 255); var i = Math.max(n, e, t), r = Math.min(n, e, t), s = 0, o = i, a = i - r, c = i === 0 ? 0 : a / i; if (i === r) s = 0; else { switch (i) { case n: s = (e - t) / a + (e < t ? 6 : 0); break; case e: s = (t - n) / a + 2; break; case t: s = (n - e) / a + 4; break; } s /= 6; } return { h: s, s: c, v: o }; } function TC(n, e, t) { n = yn(n, 360) * 6, e = yn(e, 100), t = yn(t, 100); var i = Math.floor(n), r = n - i, s = t * (1 - e), o = t * (1 - r * e), a = t * (1 - (1 - r) * e), c = i % 6, l = [t, o, s, s, a, t][c], d = [a, t, t, o, s, s][c], h6 = [s, s, a, t, t, o][c]; return { r: l * 255, g: d * 255, b: h6 * 255 }; } function Im(n, e, t, i) { var r = [ ms(Math.round(n).toString(16)), ms(Math.round(e).toString(16)), ms(Math.round(t).toString(16)) ]; return i && r[0].startsWith(r[0].charAt(1)) && r[1].startsWith(r[1].charAt(1)) && r[2].startsWith(r[2].charAt(1)) ? r[0].charAt(0) + r[1].charAt(0) + r[2].charAt(0) : r.join(""); } function EC(n, e, t, i, r) { var s = [ ms(Math.round(n).toString(16)), ms(Math.round(e).toString(16)), ms(Math.round(t).toString(16)), ms(CC(i)) ]; return r && s[0].startsWith(s[0].charAt(1)) && s[1].startsWith(s[1].charAt(1)) && s[2].startsWith(s[2].charAt(1)) && s[3].startsWith(s[3].charAt(1)) ? s[0].charAt(0) + s[1].charAt(0) + s[2].charAt(0) + s[3].charAt(0) : s.join(""); } function CC(n) { return Math.round(parseFloat(n) * 255).toString(16); } function Om(n) { return zn(n) / 255; } function zn(n) { return parseInt(n, 16); } function LC(n) { return { r: n >> 16, g: (n & 65280) >> 8, b: n & 255 }; } var qh = { aliceblue: "#f0f8ff", antiquewhite: "#faebd7", aqua: "#00ffff", aquamarine: "#7fffd4", azure: "#f0ffff", beige: "#f5f5dc", bisque: "#ffe4c4", black: "#000000", blanchedalmond: "#ffebcd", blue: "#0000ff", blueviolet: "#8a2be2", brown: "#a52a2a", burlywood: "#deb887", cadetblue: "#5f9ea0", chartreuse: "#7fff00", chocolate: "#d2691e", coral: "#ff7f50", cornflowerblue: "#6495ed", cornsilk: "#fff8dc", crimson: "#dc143c", cyan: "#00ffff", darkblue: "#00008b", darkcyan: "#008b8b", darkgoldenrod: "#b8860b", darkgray: "#a9a9a9", darkgreen: "#006400", darkgrey: "#a9a9a9", darkkhaki: "#bdb76b", darkmagenta: "#8b008b", darkolivegreen: "#556b2f", darkorange: "#ff8c00", darkorchid: "#9932cc", darkred: "#8b0000", darksalmon: "#e9967a", darkseagreen: "#8fbc8f", darkslateblue: "#483d8b", darkslategray: "#2f4f4f", darkslategrey: "#2f4f4f", darkturquoise: "#00ced1", darkviolet: "#9400d3", deeppink: "#ff1493", deepskyblue: "#00bfff", dimgray: "#696969", dimgrey: "#696969", dodgerblue: "#1e90ff", firebrick: "#b22222", floralwhite: "#fffaf0", forestgreen: "#228b22", fuchsia: "#ff00ff", gainsboro: "#dcdcdc", ghostwhite: "#f8f8ff", goldenrod: "#daa520", gold: "#ffd700", gray: "#808080", green: "#008000", greenyellow: "#adff2f", grey: "#808080", honeydew: "#f0fff0", hotpink: "#ff69b4", indianred: "#cd5c5c", indigo: "#4b0082", ivory: "#fffff0", khaki: "#f0e68c", lavenderblush: "#fff0f5", lavender: "#e6e6fa", lawngreen: "#7cfc00", lemonchiffon: "#fffacd", lightblue: "#add8e6", lightcoral: "#f08080", lightcyan: "#e0ffff", lightgoldenrodyellow: "#fafad2", lightgray: "#d3d3d3", lightgreen: "#90ee90", lightgrey: "#d3d3d3", lightpink: "#ffb6c1", lightsalmon: "#ffa07a", lightseagreen: "#20b2aa", lightskyblue: "#87cefa", lightslategray: "#778899", lightslategrey: "#778899", lightsteelblue: "#b0c4de", lightyellow: "#ffffe0", lime: "#00ff00", limegreen: "#32cd32", linen: "#faf0e6", magenta: "#ff00ff", maroon: "#800000", mediumaquamarine: "#66cdaa", mediumblue: "#0000cd", mediumorchid: "#ba55d3", mediumpurple: "#9370db", mediumseagreen: "#3cb371", mediumslateblue: "#7b68ee", mediumspringgreen: "#00fa9a", mediumturquoise: "#48d1cc", mediumvioletred: "#c71585", midnightblue: "#191970", mintcream: "#f5fffa", mistyrose: "#ffe4e1", moccasin: "#ffe4b5", navajowhite: "#ffdead", navy: "#000080", oldlace: "#fdf5e6", olive: "#808000", olivedrab: "#6b8e23", orange: "#ffa500", orangered: "#ff4500", orchid: "#da70d6", palegoldenrod: "#eee8aa", palegreen: "#98fb98", paleturquoise: "#afeeee", palevioletred: "#db7093", papayawhip: "#ffefd5", peachpuff: "#ffdab9", peru: "#cd853f", pink: "#ffc0cb", plum: "#dda0dd", powderblue: "#b0e0e6", purple: "#800080", rebeccapurple: "#663399", red: "#ff0000", rosybrown: "#bc8f8f", royalblue: "#4169e1", saddlebrown: "#8b4513", salmon: "#fa8072", sandybrown: "#f4a460", seagreen: "#2e8b57", seashell: "#fff5ee", sienna: "#a0522d", silver: "#c0c0c0", skyblue: "#87ceeb", slateblue: "#6a5acd", slategray: "#708090", slategrey: "#708090", snow: "#fffafa", springgreen: "#00ff7f", steelblue: "#4682b4", tan: "#d2b48c", teal: "#008080", thistle: "#d8bfd8", tomato: "#ff6347", turquoise: "#40e0d0", violet: "#ee82ee", wheat: "#f5deb3", white: "#ffffff", whitesmoke: "#f5f5f5", yellow: "#ffff00", yellowgreen: "#9acd32" }; function RC(n) { var e = { r: 0, g: 0, b: 0 }, t = 1, i = null, r = null, s = null, o = false, a = false; return typeof n == "string" && (n = IC(n)), typeof n == "object" && (Gi(n.r) && Gi(n.g) && Gi(n.b) ? (e = SC(n.r, n.g, n.b), o = true, a = String(n.r).substr(-1) === "%" ? "prgb" : "rgb") : Gi(n.h) && Gi(n.s) && Gi(n.v) ? (i = Fl(n.s), r = Fl(n.v), e = TC(n.h, i, r), o = true, a = "hsv") : Gi(n.h) && Gi(n.s) && Gi(n.l) && (i = Fl(n.s), s = Fl(n.l), e = _C(n.h, i, s), o = true, a = "hsl"), Object.prototype.hasOwnProperty.call(n, "a") && (t = n.a)), t = Z0(t), { ok: o, format: n.format || a, r: Math.min(255, Math.max(e.r, 0)), g: Math.min(255, Math.max(e.g, 0)), b: Math.min(255, Math.max(e.b, 0)), a: t }; } var FC = "[-\\+]?\\d+%?"; var PC = "[-\\+]?\\d*\\.\\d+%?"; var Fr = "(?:".concat(PC, ")|(?:").concat(FC, ")"); var ku = "[\\s|\\(]+(".concat(Fr, ")[,|\\s]+(").concat(Fr, ")[,|\\s]+(").concat(Fr, ")\\s*\\)?"); var Gu = "[\\s|\\(]+(".concat(Fr, ")[,|\\s]+(").concat(Fr, ")[,|\\s]+(").concat(Fr, ")[,|\\s]+(").concat(Fr, ")\\s*\\)?"); var li = { CSS_UNIT: new RegExp(Fr), rgb: new RegExp("rgb" + ku), rgba: new RegExp("rgba" + Gu), hsl: new RegExp("hsl" + ku), hsla: new RegExp("hsla" + Gu), hsv: new RegExp("hsv" + ku), hsva: new RegExp("hsva" + Gu), hex3: /^#?([0-9a-fA-F]{1})([0-9a-fA-F]{1})([0-9a-fA-F]{1})$/, hex6: /^#?([0-9a-fA-F]{2})([0-9a-fA-F]{2})([0-9a-fA-F]{2})$/, hex4: /^#?([0-9a-fA-F]{1})([0-9a-fA-F]{1})([0-9a-fA-F]{1})([0-9a-fA-F]{1})$/, hex8: /^#?([0-9a-fA-F]{2})([0-9a-fA-F]{2})([0-9a-fA-F]{2})([0-9a-fA-F]{2})$/ }; function IC(n) { if (n = n.trim().toLowerCase(), n.length === 0) return false; var e = false; if (qh[n]) n = qh[n], e = true; else if (n === "transparent") return { r: 0, g: 0, b: 0, a: 0, format: "name" }; var t = li.rgb.exec(n); return t ? { r: t[1], g: t[2], b: t[3] } : (t = li.rgba.exec(n), t ? { r: t[1], g: t[2], b: t[3], a: t[4] } : (t = li.hsl.exec(n), t ? { h: t[1], s: t[2], l: t[3] } : (t = li.hsla.exec(n), t ? { h: t[1], s: t[2], l: t[3], a: t[4] } : (t = li.hsv.exec(n), t ? { h: t[1], s: t[2], v: t[3] } : (t = li.hsva.exec(n), t ? { h: t[1], s: t[2], v: t[3], a: t[4] } : (t = li.hex8.exec(n), t ? { r: zn(t[1]), g: zn(t[2]), b: zn(t[3]), a: Om(t[4]), format: e ? "name" : "hex8" } : (t = li.hex6.exec(n), t ? { r: zn(t[1]), g: zn(t[2]), b: zn(t[3]), format: e ? "name" : "hex" } : (t = li.hex4.exec(n), t ? { r: zn(t[1] + t[1]), g: zn(t[2] + t[2]), b: zn(t[3] + t[3]), a: Om(t[4] + t[4]), format: e ? "name" : "hex8" } : (t = li.hex3.exec(n), t ? { r: zn(t[1] + t[1]), g: zn(t[2] + t[2]), b: zn(t[3] + t[3]), format: e ? "name" : "hex" } : false))))))))); } function Gi(n) { return !!li.CSS_UNIT.exec(String(n)); } var OC = ( /** @class */ function() { function n(e, t) { e === void 0 && (e = ""), t === void 0 && (t = {}); var i; if (e instanceof n) return e; typeof e == "number" && (e = LC(e)), this.originalInput = e; var r = RC(e); this.originalInput = e, this.r = r.r, this.g = r.g, this.b = r.b, this.a = r.a, this.roundA = Math.round(100 * this.a) / 100, this.format = (i = t.format) !== null && i !== void 0 ? i : r.format, this.gradientType = t.gradientType, this.r < 1 && (this.r = Math.round(this.r)), this.g < 1 && (this.g = Math.round(this.g)), this.b < 1 && (this.b = Math.round(this.b)), this.isValid = r.ok; } return n.prototype.isDark = function() { return this.getBrightness() < 128; }, n.prototype.isLight = function() { return !this.isDark(); }, n.prototype.getBrightness = function() { var e = this.toRgb(); return (e.r * 299 + e.g * 587 + e.b * 114) / 1e3; }, n.prototype.getLuminance = function() { var e = this.toRgb(), t, i, r, s = e.r / 255, o = e.g / 255, a = e.b / 255; return s <= 0.03928 ? t = s / 12.92 : t = Math.pow((s + 0.055) / 1.055, 2.4), o <= 0.03928 ? i = o / 12.92 : i = Math.pow((o + 0.055) / 1.055, 2.4), a <= 0.03928 ? r = a / 12.92 : r = Math.pow((a + 0.055) / 1.055, 2.4), 0.2126 * t + 0.7152 * i + 0.0722 * r; }, n.prototype.getAlpha = function() { return this.a; }, n.prototype.setAlpha = function(e) { return this.a = Z0(e), this.roundA = Math.round(100 * this.a) / 100, this; }, n.prototype.isMonochrome = function() { var e = this.toHsl().s; return e === 0; }, n.prototype.toHsv = function() { var e = Pm(this.r, this.g, this.b); return { h: e.h * 360, s: e.s, v: e.v, a: this.a }; }, n.prototype.toHsvString = function() { var e = Pm(this.r, this.g, this.b), t = Math.round(e.h * 360), i = Math.round(e.s * 100), r = Math.round(e.v * 100); return this.a === 1 ? "hsv(".concat(t, ", ").concat(i, "%, ").concat(r, "%)") : "hsva(".concat(t, ", ").concat(i, "%, ").concat(r, "%, ").concat(this.roundA, ")"); }, n.prototype.toHsl = function() { var e = Fm(this.r, this.g, this.b); return { h: e.h * 360, s: e.s, l: e.l, a: this.a }; }, n.prototype.toHslString = function() { var e = Fm(this.r, this.g, this.b), t = Math.round(e.h * 360), i = Math.round(e.s * 100), r = Math.round(e.l * 100); return this.a === 1 ? "hsl(".concat(t, ", ").concat(i, "%, ").concat(r, "%)") : "hsla(".concat(t, ", ").concat(i, "%, ").concat(r, "%, ").concat(this.roundA, ")"); }, n.prototype.toHex = function(e) { return e === void 0 && (e = false), Im(this.r, this.g, this.b, e); }, n.prototype.toHexString = function(e) { return e === void 0 && (e = false), "#" + this.toHex(e); }, n.prototype.toHex8 = function(e) { return e === void 0 && (e = false), EC(this.r, this.g, this.b, this.a, e); }, n.prototype.toHex8String = function(e) { return e === void 0 && (e = false), "#" + this.toHex8(e); }, n.prototype.toHexShortString = function(e) { return e === void 0 && (e = false), this.a === 1 ? this.toHexString(e) : this.toHex8String(e); }, n.prototype.toRgb = function() { return { r: Math.round(this.r), g: Math.round(this.g), b: Math.round(this.b), a: this.a }; }, n.prototype.toRgbString = function() { var e = Math.round(this.r), t = Math.round(this.g), i = Math.round(this.b); return this.a === 1 ? "rgb(".concat(e, ", ").concat(t, ", ").concat(i, ")") : "rgba(".concat(e, ", ").concat(t, ", ").concat(i, ", ").concat(this.roundA, ")"); }, n.prototype.toPercentageRgb = function() { var e = function(t) { return "".concat(Math.round(yn(t, 255) * 100), "%"); }; return { r: e(this.r), g: e(this.g), b: e(this.b), a: this.a }; }, n.prototype.toPercentageRgbString = function() { var e = function(t) { return Math.round(yn(t, 255) * 100); }; return this.a === 1 ? "rgb(".concat(e(this.r), "%, ").concat(e(this.g), "%, ").concat(e(this.b), "%)") : "rgba(".concat(e(this.r), "%, ").concat(e(this.g), "%, ").concat(e(this.b), "%, ").concat(this.roundA, ")"); }, n.prototype.toName = function() { if (this.a === 0) return "transparent"; if (this.a < 1) return false; for (var e = "#" + Im(this.r, this.g, this.b, false), t = 0, i = Object.entries(qh); t < i.length; t++) { var r = i[t], s = r[0], o = r[1]; if (e === o) return s; } return false; }, n.prototype.toString = function(e) { var t = !!e; e = e ?? this.format; var i = false, r = this.a < 1 && this.a >= 0, s = !t && r && (e.startsWith("hex") || e === "name"); return s ? e === "name" && this.a === 0 ? this.toName() : this.toRgbString() : (e === "rgb" && (i = this.toRgbString()), e === "prgb" && (i = this.toPercentageRgbString()), (e === "hex" || e === "hex6") && (i = this.toHexString()), e === "hex3" && (i = this.toHexString(true)), e === "hex4" && (i = this.toHex8String(true)), e === "hex8" && (i = this.toHex8String()), e === "name" && (i = this.toName()), e === "hsl" && (i = this.toHslString()), e === "hsv" && (i = this.toHsvString()), i || this.toHexString()); }, n.prototype.toNumber = function() { return (Math.round(this.r) << 16) + (Math.round(this.g) << 8) + Math.round(this.b); }, n.prototype.clone = function() { return new n(this.toString()); }, n.prototype.lighten = function(e) { e === void 0 && (e = 10); var t = this.toHsl(); return t.l += e / 100, t.l = Rl(t.l), new n(t); }, n.prototype.brighten = function(e) { e === void 0 && (e = 10); var t = this.toRgb(); return t.r = Math.max(0, Math.min(255, t.r - Math.round(255 * -(e / 100)))), t.g = Math.max(0, Math.min(255, t.g - Math.round(255 * -(e / 100)))), t.b = Math.max(0, Math.min(255, t.b - Math.round(255 * -(e / 100)))), new n(t); }, n.prototype.darken = function(e) { e === void 0 && (e = 10); var t = this.toHsl(); return t.l -= e / 100, t.l = Rl(t.l), new n(t); }, n.prototype.tint = function(e) { return e === void 0 && (e = 10), this.mix("white", e); }, n.prototype.shade = function(e) { return e === void 0 && (e = 10), this.mix("black", e); }, n.prototype.desaturate = function(e) { e === void 0 && (e = 10); var t = this.toHsl(); return t.s -= e / 100, t.s = Rl(t.s), new n(t); }, n.prototype.saturate = function(e) { e === void 0 && (e = 10); var t = this.toHsl(); return t.s += e / 100, t.s = Rl(t.s), new n(t); }, n.prototype.greyscale = function() { return this.desaturate(100); }, n.prototype.spin = function(e) { var t = this.toHsl(), i = (t.h + e) % 360; return t.h = i < 0 ? 360 + i : i, new n(t); }, n.prototype.mix = function(e, t) { t === void 0 && (t = 50); var i = this.toRgb(), r = new n(e).toRgb(), s = t / 100, o = { r: (r.r - i.r) * s + i.r, g: (r.g - i.g) * s + i.g, b: (r.b - i.b) * s + i.b, a: (r.a - i.a) * s + i.a }; return new n(o); }, n.prototype.analogous = function(e, t) { e === void 0 && (e = 6), t === void 0 && (t = 30); var i = this.toHsl(), r = 360 / t, s = [this]; for (i.h = (i.h - (r * e >> 1) + 720) % 360; --e; ) i.h = (i.h + r) % 360, s.push(new n(i)); return s; }, n.prototype.complement = function() { var e = this.toHsl(); return e.h = (e.h + 180) % 360, new n(e); }, n.prototype.monochromatic = function(e) { e === void 0 && (e = 6); for (var t = this.toHsv(), i = t.h, r = t.s, s = t.v, o = [], a = 1 / e; e--; ) o.push(new n({ h: i, s: r, v: s })), s = (s + a) % 1; return o; }, n.prototype.splitcomplement = function() { var e = this.toHsl(), t = e.h; return [ this, new n({ h: (t + 72) % 360, s: e.s, l: e.l }), new n({ h: (t + 216) % 360, s: e.s, l: e.l }) ]; }, n.prototype.onBackground = function(e) { var t = this.toRgb(), i = new n(e).toRgb(), r = t.a + i.a * (1 - t.a); return new n({ r: (t.r * t.a + i.r * i.a * (1 - t.a)) / r, g: (t.g * t.a + i.g * i.a * (1 - t.a)) / r, b: (t.b * t.a + i.b * i.a * (1 - t.a)) / r, a: r }); }, n.prototype.triad = function() { return this.polyad(3); }, n.prototype.tetrad = function() { return this.polyad(4); }, n.prototype.polyad = function(e) { for (var t = this.toHsl(), i = t.h, r = [this], s = 360 / e, o = 1; o < e; o++) r.push(new n({ h: (i + o * s) % 360, s: t.s, l: t.l })); return r; }, n.prototype.equals = function(e) { return this.toRgbString() === new n(e).toRgbString(); }, n; }() ); function gr(n, e = 20) { return n.mix("#141414", e).toString(); } function DC(n) { const e = ol(), t = nt("button"); return computed(() => { let i = {}, r = n.color; if (r) { const s = r.match(/var\((.*?)\)/); s && (r = window.getComputedStyle(window.document.documentElement).getPropertyValue(s[1])); const o = new OC(r), a = n.dark ? o.tint(20).toString() : gr(o, 20); if (n.plain) i = t.cssVarBlock({ "bg-color": n.dark ? gr(o, 90) : o.tint(90).toString(), "text-color": r, "border-color": n.dark ? gr(o, 50) : o.tint(50).toString(), "hover-text-color": `var(${t.cssVarName("color-white")})`, "hover-bg-color": r, "hover-border-color": r, "active-bg-color": a, "active-text-color": `var(${t.cssVarName("color-white")})`, "active-border-color": a }), e.value && (i[t.cssVarBlockName("disabled-bg-color")] = n.dark ? gr(o, 90) : o.tint(90).toString(), i[t.cssVarBlockName("disabled-text-color")] = n.dark ? gr(o, 50) : o.tint(50).toString(), i[t.cssVarBlockName("disabled-border-color")] = n.dark ? gr(o, 80) : o.tint(80).toString()); else { const c = n.dark ? gr(o, 30) : o.tint(30).toString(), l = o.isDark() ? `var(${t.cssVarName("color-white")})` : `var(${t.cssVarName("color-black")})`; if (i = t.cssVarBlock({ "bg-color": r, "text-color": l, "border-color": r, "hover-bg-color": c, "hover-text-color": l, "hover-border-color": c, "active-bg-color": a, "active-border-color": a }), e.value) { const d = n.dark ? gr(o, 50) : o.tint(50).toString(); i[t.cssVarBlockName("disabled-bg-color")] = d, i[t.cssVarBlockName("disabled-text-color")] = n.dark ? "rgba(255, 255, 255, 0.5)" : `var(${t.cssVarName("color-white")})`, i[t.cssVarBlockName("disabled-border-color")] = d; } } } return i; }); } var NC = defineComponent({ name: "ElButton" }); var BC = defineComponent({ ...NC, props: Kh, emits: MC, setup(n, { expose: e, emit: t }) { const i = n, r = DC(i), s = nt("button"), { _ref: o, _size: a, _type: c, _disabled: l, _props: d, shouldAddSpace: h6, handleClick: f } = yC(i, t), g = computed(() => [ s.b(), s.m(c.value), s.m(a.value), s.is("disabled", l.value), s.is("loading", i.loading), s.is("plain", i.plain), s.is("round", i.round), s.is("circle", i.circle), s.is("text", i.text), s.is("link", i.link), s.is("has-bg", i.bg) ]); return e({ ref: o, size: a, type: c, disabled: l, shouldAddSpace: h6 }), (p, u) => (openBlock(), createBlock(resolveDynamicComponent(p.tag), mergeProps({ ref_key: "_ref", ref: o }, unref(d), { class: unref(g), style: unref(r), onClick: unref(f) }), { default: withCtx(() => [ p.loading ? (openBlock(), createElementBlock(Fragment, { key: 0 }, [ p.$slots.loading ? renderSlot(p.$slots, "loading", { key: 0 }) : (openBlock(), createBlock(unref(It), { key: 1, class: normalizeClass(unref(s).is("loading")) }, { default: withCtx(() => [ (openBlock(), createBlock(resolveDynamicComponent(p.loadingIcon))) ]), _: 1 }, 8, ["class"])) ], 64)) : p.icon || p.$slots.icon ? (openBlock(), createBlock(unref(It), { key: 1 }, { default: withCtx(() => [ p.icon ? (openBlock(), createBlock(resolveDynamicComponent(p.icon), { key: 0 })) : renderSlot(p.$slots, "icon", { key: 1 }) ]), _: 3 })) : createCommentVNode("v-if", true), p.$slots.default ? (openBlock(), createElementBlock("span", { key: 2, class: normalizeClass({ [unref(s).em("text", "expand")]: unref(h6) }) }, [ renderSlot(p.$slots, "default") ], 2)) : createCommentVNode("v-if", true) ]), _: 3 }, 16, ["class", "style", "onClick"])); } }); var UC = st(BC, [["__file", "button.vue"]]); var zC = { size: Kh.size, type: Kh.type }; var VC = defineComponent({ name: "ElButtonGroup" }); var kC = defineComponent({ ...VC, props: zC, setup(n) { const e = n; provide($0, reactive({ size: toRef(e, "size"), type: toRef(e, "type") })); const t = nt("button"); return (i, r) => (openBlock(), createElementBlock("div", { class: normalizeClass(unref(t).b("group")) }, [ renderSlot(i.$slots, "default") ], 2)); } }); var X0 = st(kC, [["__file", "button-group.vue"]]); var Ko = on(UC, { ButtonGroup: X0 }); vi(X0); var Lr = typeof globalThis < "u" ? globalThis : typeof window < "u" ? window : typeof global < "u" ? global : typeof self < "u" ? self : {}; function GC(n) { return n && n.__esModule && Object.prototype.hasOwnProperty.call(n, "default") ? n.default : n; } function au(n) { if (n.__esModule) return n; var e = n.default; if (typeof e == "function") { var t = function i() { return this instanceof i ? Reflect.construct(e, arguments, this.constructor) : e.apply(this, arguments); }; t.prototype = e.prototype; } else t = {}; return Object.defineProperty(t, "__esModule", { value: true }), Object.keys(n).forEach(function(i) { var r = Object.getOwnPropertyDescriptor(n, i); Object.defineProperty(t, i, r.get ? r : { enumerable: true, get: function() { return n[i]; } }); }), t; } var Er = /* @__PURE__ */ new Map(); if (en) { let n; document.addEventListener("mousedown", (e) => n = e), document.addEventListener("mouseup", (e) => { if (n) { for (const t of Er.values()) for (const { documentHandler: i } of t) i(e, n); n = void 0; } }); } function Dm(n, e) { let t = []; return Array.isArray(e.arg) ? t = e.arg : ys(e.arg) && t.push(e.arg), function(i, r) { const s = e.instance.popperRef, o = i.target, a = r == null ? void 0 : r.target, c = !e || !e.instance, l = !o || !a, d = n.contains(o) || n.contains(a), h6 = n === o, f = t.length && t.some((p) => p == null ? void 0 : p.contains(o)) || t.length && t.includes(a), g = s && (s.contains(o) || s.contains(a)); c || l || d || h6 || f || g || e.value(i, r); }; } var HC = { beforeMount(n, e) { Er.has(n) || Er.set(n, []), Er.get(n).push({ documentHandler: Dm(n, e), bindingFn: e.value }); }, updated(n, e) { Er.has(n) || Er.set(n, []); const t = Er.get(n), i = t.findIndex((s) => s.bindingFn === e.oldValue), r = { documentHandler: Dm(n, e), bindingFn: e.value }; i >= 0 ? t.splice(i, 1, r) : t.push(r); }, unmounted(n) { Er.delete(n); } }; var WC = 100; var jC = 600; var Nm = { beforeMount(n, e) { const t = e.value, { interval: i = WC, delay: r = jC } = Sn(t) ? {} : t; let s, o; const a = () => Sn(t) ? t() : t.handler(), c = () => { o && (clearTimeout(o), o = void 0), s && (clearInterval(s), s = void 0); }; n.addEventListener("mousedown", (l) => { l.button === 0 && (c(), a(), document.addEventListener("mouseup", () => c(), { once: true }), o = setTimeout(() => { s = setInterval(() => { a(); }, i); }, r)); }); } }; var Y0 = at({ modelValue: { type: [String, Number, Boolean], default: void 0 }, size: Gr, disabled: Boolean, label: { type: [String, Number, Boolean], default: void 0 }, value: { type: [String, Number, Boolean], default: void 0 }, name: { type: String, default: void 0 } }); var $C = at({ ...Y0, border: Boolean }); var J0 = { [At]: (n) => vn(n) || yt(n) || Ba(n), [ur]: (n) => vn(n) || yt(n) || Ba(n) }; var K0 = Symbol("radioGroupKey"); var q0 = (n, e) => { const t = ref(), i = inject(K0, void 0), r = computed(() => !!i), s = computed(() => im(n.value) ? n.label : n.value), o = computed({ get() { return r.value ? i.modelValue : n.modelValue; }, set(h6) { r.value ? i.changeEvent(h6) : e && e(At, h6), t.value.checked = n.modelValue === s.value; } }), a = Ns(computed(() => i == null ? void 0 : i.size)), c = ol(computed(() => i == null ? void 0 : i.disabled)), l = ref(false), d = computed(() => c.value || r.value && o.value !== s.value ? -1 : 0); return p0({ from: "label act as value", replacement: "value", version: "3.0.0", scope: "el-radio", ref: "https://element-plus.org/en-US/component/radio.html" }, computed(() => r.value && im(n.value))), { radioRef: t, isGroup: r, radioGroup: i, focus: l, size: a, disabled: c, tabIndex: d, modelValue: o, actualValue: s }; }; var ZC = defineComponent({ name: "ElRadio" }); var XC = defineComponent({ ...ZC, props: $C, emits: J0, setup(n, { emit: e }) { const t = n, i = nt("radio"), { radioRef: r, radioGroup: s, focus: o, size: a, disabled: c, modelValue: l, actualValue: d } = q0(t, e); function h6() { nextTick(() => e("change", l.value)); } return (f, g) => { var p; return openBlock(), createElementBlock("label", { class: normalizeClass([ unref(i).b(), unref(i).is("disabled", unref(c)), unref(i).is("focus", unref(o)), unref(i).is("bordered", f.border), unref(i).is("checked", unref(l) === unref(d)), unref(i).m(unref(a)) ]) }, [ createBaseVNode("span", { class: normalizeClass([ unref(i).e("input"), unref(i).is("disabled", unref(c)), unref(i).is("checked", unref(l) === unref(d)) ]) }, [ withDirectives(createBaseVNode("input", { ref_key: "radioRef", ref: r, "onUpdate:modelValue": (u) => isRef(l) ? l.value = u : null, class: normalizeClass(unref(i).e("original")), value: unref(d), name: f.name || ((p = unref(s)) == null ? void 0 : p.name), disabled: unref(c), checked: unref(l) === unref(d), type: "radio", onFocus: (u) => o.value = true, onBlur: (u) => o.value = false, onChange: h6, onClick: withModifiers(() => { }, ["stop"]) }, null, 42, ["onUpdate:modelValue", "value", "name", "disabled", "checked", "onFocus", "onBlur", "onClick"]), [ [vModelRadio, unref(l)] ]), createBaseVNode("span", { class: normalizeClass(unref(i).e("inner")) }, null, 2) ], 2), createBaseVNode("span", { class: normalizeClass(unref(i).e("label")), onKeydown: withModifiers(() => { }, ["stop"]) }, [ renderSlot(f.$slots, "default", {}, () => [ createTextVNode(toDisplayString(f.label), 1) ]) ], 42, ["onKeydown"]) ], 2); }; } }); var YC = st(XC, [["__file", "radio.vue"]]); var JC = at({ ...Y0 }); var KC = defineComponent({ name: "ElRadioButton" }); var qC = defineComponent({ ...KC, props: JC, setup(n) { const e = n, t = nt("radio"), { radioRef: i, focus: r, size: s, disabled: o, modelValue: a, radioGroup: c, actualValue: l } = q0(e), d = computed(() => ({ backgroundColor: (c == null ? void 0 : c.fill) || "", borderColor: (c == null ? void 0 : c.fill) || "", boxShadow: c != null && c.fill ? `-1px 0 0 0 ${c.fill}` : "", color: (c == null ? void 0 : c.textColor) || "" })); return (h6, f) => { var g; return openBlock(), createElementBlock("label", { class: normalizeClass([ unref(t).b("button"), unref(t).is("active", unref(a) === unref(l)), unref(t).is("disabled", unref(o)), unref(t).is("focus", unref(r)), unref(t).bm("button", unref(s)) ]) }, [ withDirectives(createBaseVNode("input", { ref_key: "radioRef", ref: i, "onUpdate:modelValue": (p) => isRef(a) ? a.value = p : null, class: normalizeClass(unref(t).be("button", "original-radio")), value: unref(l), type: "radio", name: h6.name || ((g = unref(c)) == null ? void 0 : g.name), disabled: unref(o), onFocus: (p) => r.value = true, onBlur: (p) => r.value = false, onClick: withModifiers(() => { }, ["stop"]) }, null, 42, ["onUpdate:modelValue", "value", "name", "disabled", "onFocus", "onBlur", "onClick"]), [ [vModelRadio, unref(a)] ]), createBaseVNode("span", { class: normalizeClass(unref(t).be("button", "inner")), style: normalizeStyle(unref(a) === unref(l) ? unref(d) : {}), onKeydown: withModifiers(() => { }, ["stop"]) }, [ renderSlot(h6.$slots, "default", {}, () => [ createTextVNode(toDisplayString(h6.label), 1) ]) ], 46, ["onKeydown"]) ], 2); }; } }); var Q0 = st(qC, [["__file", "radio-button.vue"]]); var QC = at({ id: { type: String, default: void 0 }, size: Gr, disabled: Boolean, modelValue: { type: [String, Number, Boolean], default: void 0 }, fill: { type: String, default: "" }, textColor: { type: String, default: "" }, name: { type: String, default: void 0 }, validateEvent: { type: Boolean, default: true }, ...Yr(["ariaLabel"]) }); var eL = J0; var tL = defineComponent({ name: "ElRadioGroup" }); var nL = defineComponent({ ...tL, props: QC, emits: eL, setup(n, { emit: e }) { const t = n, i = nt("radio"), r = sl(), s = ref(), { formItem: o } = Jo(), { inputId: a, isLabeledByFormItem: c } = su(t, { formItemContext: o }), l = (h6) => { e(At, h6), nextTick(() => e("change", h6)); }; onMounted(() => { const h6 = s.value.querySelectorAll("[type=radio]"), f = h6[0]; !Array.from(h6).some((g) => g.checked) && f && (f.tabIndex = 0); }); const d = computed(() => t.name || r.value); return provide(K0, reactive({ ...toRefs(t), changeEvent: l, name: d })), watch(() => t.modelValue, () => { t.validateEvent && (o == null || o.validate("change").catch((h6) => Vt(h6))); }), (h6, f) => (openBlock(), createElementBlock("div", { id: unref(a), ref_key: "radioGroupRef", ref: s, class: normalizeClass(unref(i).b("group")), role: "radiogroup", "aria-label": unref(c) ? void 0 : h6.ariaLabel || "radio-group", "aria-labelledby": unref(c) ? unref(o).labelId : void 0 }, [ renderSlot(h6.$slots, "default") ], 10, ["id", "aria-label", "aria-labelledby"])); } }); var ey = st(nL, [["__file", "radio-group.vue"]]); var ty = on(YC, { RadioButton: Q0, RadioGroup: ey }); var ny = vi(ey); vi(Q0); var Qh = at({ type: { type: String, values: ["primary", "success", "info", "warning", "danger"], default: "primary" }, closable: Boolean, disableTransitions: Boolean, hit: Boolean, color: String, size: { type: String, values: f0 }, effect: { type: String, values: ["dark", "light", "plain"], default: "light" }, round: Boolean }); var iL = { close: (n) => n instanceof MouseEvent, click: (n) => n instanceof MouseEvent }; var rL = defineComponent({ name: "ElTag" }); var sL = defineComponent({ ...rL, props: Qh, emits: iL, setup(n, { emit: e }) { const t = n, i = Ns(), r = nt("tag"), s = computed(() => { const { type: l, hit: d, effect: h6, closable: f, round: g } = t; return [ r.b(), r.is("closable", f), r.m(l || "primary"), r.m(i.value), r.m(h6), r.is("hit", d), r.is("round", g) ]; }), o = (l) => { e("close", l); }, a = (l) => { e("click", l); }, c = (l) => { l.component.subTree.component.bum = null; }; return (l, d) => l.disableTransitions ? (openBlock(), createElementBlock("span", { key: 0, class: normalizeClass(unref(s)), style: normalizeStyle({ backgroundColor: l.color }), onClick: a }, [ createBaseVNode("span", { class: normalizeClass(unref(r).e("content")) }, [ renderSlot(l.$slots, "default") ], 2), l.closable ? (openBlock(), createBlock(unref(It), { key: 0, class: normalizeClass(unref(r).e("close")), onClick: withModifiers(o, ["stop"]) }, { default: withCtx(() => [ createVNode(unref(Zh)) ]), _: 1 }, 8, ["class", "onClick"])) : createCommentVNode("v-if", true) ], 6)) : (openBlock(), createBlock(Transition, { key: 1, name: `${unref(r).namespace.value}-zoom-in-center`, appear: "", onVnodeMounted: c }, { default: withCtx(() => [ createBaseVNode("span", { class: normalizeClass(unref(s)), style: normalizeStyle({ backgroundColor: l.color }), onClick: a }, [ createBaseVNode("span", { class: normalizeClass(unref(r).e("content")) }, [ renderSlot(l.$slots, "default") ], 2), l.closable ? (openBlock(), createBlock(unref(It), { key: 0, class: normalizeClass(unref(r).e("close")), onClick: withModifiers(o, ["stop"]) }, { default: withCtx(() => [ createVNode(unref(Zh)) ]), _: 1 }, 8, ["class", "onClick"])) : createCommentVNode("v-if", true) ], 6) ]), _: 3 }, 8, ["name"])); } }); var oL = st(sL, [["__file", "tag.vue"]]); var aL = on(oL); var iy = Symbol("rowContextKey"); var lL = [ "start", "center", "end", "space-around", "space-between", "space-evenly" ]; var cL = ["top", "middle", "bottom"]; var uL = at({ tag: { type: String, default: "div" }, gutter: { type: Number, default: 0 }, justify: { type: String, values: lL, default: "start" }, align: { type: String, values: cL } }); var hL = defineComponent({ name: "ElRow" }); var dL = defineComponent({ ...hL, props: uL, setup(n) { const e = n, t = nt("row"), i = computed(() => e.gutter); provide(iy, { gutter: i }); const r = computed(() => { const o = {}; return e.gutter && (o.marginRight = o.marginLeft = `-${e.gutter / 2}px`), o; }), s = computed(() => [ t.b(), t.is(`justify-${e.justify}`, e.justify !== "start"), t.is(`align-${e.align}`, !!e.align) ]); return (o, a) => (openBlock(), createBlock(resolveDynamicComponent(o.tag), { class: normalizeClass(unref(s)), style: normalizeStyle(unref(r)) }, { default: withCtx(() => [ renderSlot(o.$slots, "default") ]), _: 3 }, 8, ["class", "style"])); } }); var fL = st(dL, [["__file", "row.vue"]]); var Ui = on(fL); var pL = at({ tag: { type: String, default: "div" }, span: { type: Number, default: 24 }, offset: { type: Number, default: 0 }, pull: { type: Number, default: 0 }, push: { type: Number, default: 0 }, xs: { type: Je([Number, Object]), default: () => Ki({}) }, sm: { type: Je([Number, Object]), default: () => Ki({}) }, md: { type: Je([Number, Object]), default: () => Ki({}) }, lg: { type: Je([Number, Object]), default: () => Ki({}) }, xl: { type: Je([Number, Object]), default: () => Ki({}) } }); var mL = defineComponent({ name: "ElCol" }); var gL = defineComponent({ ...mL, props: pL, setup(n) { const e = n, { gutter: t } = inject(iy, { gutter: computed(() => 0) }), i = nt("col"), r = computed(() => { const o = {}; return t.value && (o.paddingLeft = o.paddingRight = `${t.value / 2}px`), o; }), s = computed(() => { const o = []; return ["span", "offset", "pull", "push"].forEach((l) => { const d = e[l]; yt(d) && (l === "span" ? o.push(i.b(`${e[l]}`)) : d > 0 && o.push(i.b(`${l}-${e[l]}`))); }), ["xs", "sm", "md", "lg", "xl"].forEach((l) => { yt(e[l]) ? o.push(i.b(`${l}-${e[l]}`)) : Tn(e[l]) && Object.entries(e[l]).forEach(([d, h6]) => { o.push(d !== "span" ? i.b(`${l}-${d}-${h6}`) : i.b(`${l}-${h6}`)); }); }), t.value && o.push(i.is("guttered")), [i.b(), o]; }); return (o, a) => (openBlock(), createBlock(resolveDynamicComponent(o.tag), { class: normalizeClass(unref(s)), style: normalizeStyle(unref(r)) }, { default: withCtx(() => [ renderSlot(o.$slots, "default") ]), _: 3 }, 8, ["class", "style"])); } }); var vL = st(gL, [["__file", "col.vue"]]); var bi = on(vL); var Bm = (n) => yt(n) || vn(n) || Pn(n); var yL = at({ accordion: Boolean, modelValue: { type: Je([Array, String, Number]), default: () => Ki([]) } }); var bL = { [At]: Bm, [ur]: Bm }; var ry = Symbol("collapseContextKey"); var xL = (n, e) => { const t = ref(Si(n.modelValue)), i = (s) => { t.value = s; const o = n.accordion ? t.value[0] : t.value; e(At, o), e(ur, o); }, r = (s) => { if (n.accordion) i([t.value[0] === s ? "" : s]); else { const o = [...t.value], a = o.indexOf(s); a > -1 ? o.splice(a, 1) : o.push(s), i(o); } }; return watch(() => n.modelValue, () => t.value = Si(n.modelValue), { deep: true }), provide(ry, { activeNames: t, handleItemClick: r }), { activeNames: t, setActiveNames: i }; }; var ML = () => { const n = nt("collapse"); return { rootKls: computed(() => n.b()) }; }; var wL = defineComponent({ name: "ElCollapse" }); var AL = defineComponent({ ...wL, props: yL, emits: bL, setup(n, { expose: e, emit: t }) { const i = n, { activeNames: r, setActiveNames: s } = xL(i, t), { rootKls: o } = ML(); return e({ activeNames: r, setActiveNames: s }), (a, c) => (openBlock(), createElementBlock("div", { class: normalizeClass(unref(o)) }, [ renderSlot(a.$slots, "default") ], 2)); } }); var SL = st(AL, [["__file", "collapse.vue"]]); var _L = defineComponent({ name: "ElCollapseTransition" }); var TL = defineComponent({ ..._L, setup(n) { const e = nt("collapse-transition"), t = (r) => { r.style.maxHeight = "", r.style.overflow = r.dataset.oldOverflow, r.style.paddingTop = r.dataset.oldPaddingTop, r.style.paddingBottom = r.dataset.oldPaddingBottom; }, i = { beforeEnter(r) { r.dataset || (r.dataset = {}), r.dataset.oldPaddingTop = r.style.paddingTop, r.dataset.oldPaddingBottom = r.style.paddingBottom, r.style.height && (r.dataset.elExistsHeight = r.style.height), r.style.maxHeight = 0, r.style.paddingTop = 0, r.style.paddingBottom = 0; }, enter(r) { requestAnimationFrame(() => { r.dataset.oldOverflow = r.style.overflow, r.dataset.elExistsHeight ? r.style.maxHeight = r.dataset.elExistsHeight : r.scrollHeight !== 0 ? r.style.maxHeight = `${r.scrollHeight}px` : r.style.maxHeight = 0, r.style.paddingTop = r.dataset.oldPaddingTop, r.style.paddingBottom = r.dataset.oldPaddingBottom, r.style.overflow = "hidden"; }); }, afterEnter(r) { r.style.maxHeight = "", r.style.overflow = r.dataset.oldOverflow; }, enterCancelled(r) { t(r); }, beforeLeave(r) { r.dataset || (r.dataset = {}), r.dataset.oldPaddingTop = r.style.paddingTop, r.dataset.oldPaddingBottom = r.style.paddingBottom, r.dataset.oldOverflow = r.style.overflow, r.style.maxHeight = `${r.scrollHeight}px`, r.style.overflow = "hidden"; }, leave(r) { r.scrollHeight !== 0 && (r.style.maxHeight = 0, r.style.paddingTop = 0, r.style.paddingBottom = 0); }, afterLeave(r) { t(r); }, leaveCancelled(r) { t(r); } }; return (r, s) => (openBlock(), createBlock(Transition, mergeProps({ name: unref(e).b() }, toHandlers(i)), { default: withCtx(() => [ renderSlot(r.$slots, "default") ]), _: 3 }, 16, ["name"])); } }); var EL = st(TL, [["__file", "collapse-transition.vue"]]); var CL = on(EL); var LL = at({ title: { type: String, default: "" }, name: { type: Je([String, Number]), default: void 0 }, icon: { type: kr, default: Vr }, disabled: Boolean }); var RL = (n) => { const e = inject(ry), { namespace: t } = nt("collapse"), i = ref(false), r = ref(false), s = of(), o = computed(() => s.current++), a = computed(() => { var f; return (f = n.name) != null ? f : `${t.value}-id-${s.prefix}-${unref(o)}`; }), c = computed(() => e == null ? void 0 : e.activeNames.value.includes(unref(a))); return { focusing: i, id: o, isActive: c, handleFocus: () => { setTimeout(() => { r.value ? r.value = false : i.value = true; }, 50); }, handleHeaderClick: () => { n.disabled || (e == null || e.handleItemClick(unref(a)), i.value = false, r.value = true); }, handleEnterClick: () => { e == null || e.handleItemClick(unref(a)); } }; }; var FL = (n, { focusing: e, isActive: t, id: i }) => { const r = nt("collapse"), s = computed(() => [ r.b("item"), r.is("active", unref(t)), r.is("disabled", n.disabled) ]), o = computed(() => [ r.be("item", "header"), r.is("active", unref(t)), { focusing: unref(e) && !n.disabled } ]), a = computed(() => [ r.be("item", "arrow"), r.is("active", unref(t)) ]), c = computed(() => r.be("item", "wrap")), l = computed(() => r.be("item", "content")), d = computed(() => r.b(`content-${unref(i)}`)), h6 = computed(() => r.b(`head-${unref(i)}`)); return { arrowKls: a, headKls: o, rootKls: s, itemWrapperKls: c, itemContentKls: l, scopedContentId: d, scopedHeadId: h6 }; }; var PL = defineComponent({ name: "ElCollapseItem" }); var IL = defineComponent({ ...PL, props: LL, setup(n, { expose: e }) { const t = n, { focusing: i, id: r, isActive: s, handleFocus: o, handleHeaderClick: a, handleEnterClick: c } = RL(t), { arrowKls: l, headKls: d, rootKls: h6, itemWrapperKls: f, itemContentKls: g, scopedContentId: p, scopedHeadId: u } = FL(t, { focusing: i, isActive: s, id: r }); return e({ isActive: s }), (y, v) => (openBlock(), createElementBlock("div", { class: normalizeClass(unref(h6)) }, [ createBaseVNode("button", { id: unref(u), class: normalizeClass(unref(d)), "aria-expanded": unref(s), "aria-controls": unref(p), "aria-describedby": unref(p), tabindex: y.disabled ? -1 : 0, type: "button", onClick: unref(a), onKeydown: withKeys(withModifiers(unref(c), ["stop", "prevent"]), ["space", "enter"]), onFocus: unref(o), onBlur: (m) => i.value = false }, [ renderSlot(y.$slots, "title", {}, () => [ createTextVNode(toDisplayString(y.title), 1) ]), renderSlot(y.$slots, "icon", { isActive: unref(s) }, () => [ createVNode(unref(It), { class: normalizeClass(unref(l)) }, { default: withCtx(() => [ (openBlock(), createBlock(resolveDynamicComponent(y.icon))) ]), _: 1 }, 8, ["class"]) ]) ], 42, ["id", "aria-expanded", "aria-controls", "aria-describedby", "tabindex", "onClick", "onKeydown", "onFocus", "onBlur"]), createVNode(unref(CL), null, { default: withCtx(() => [ withDirectives(createBaseVNode("div", { id: unref(p), role: "region", class: normalizeClass(unref(f)), "aria-hidden": !unref(s), "aria-labelledby": unref(u) }, [ createBaseVNode("div", { class: normalizeClass(unref(g)) }, [ renderSlot(y.$slots, "default") ], 2) ], 10, ["id", "aria-hidden", "aria-labelledby"]), [ [vShow, unref(s)] ]) ]), _: 3 }) ], 2)); } }); var sy = st(IL, [["__file", "collapse-item.vue"]]); var oy = on(SL, { CollapseItem: sy }); var ay = vi(sy); var OL = defineComponent({ name: "ElContainer" }); var DL = defineComponent({ ...OL, props: { direction: { type: String } }, setup(n) { const e = n, t = useSlots(), i = nt("container"), r = computed(() => e.direction === "vertical" ? true : e.direction === "horizontal" ? false : t && t.default ? t.default().some((o) => { const a = o.type.name; return a === "ElHeader" || a === "ElFooter"; }) : false); return (s, o) => (openBlock(), createElementBlock("section", { class: normalizeClass([unref(i).b(), unref(i).is("vertical", unref(r))]) }, [ renderSlot(s.$slots, "default") ], 2)); } }); var NL = st(DL, [["__file", "container.vue"]]); var BL = defineComponent({ name: "ElAside" }); var UL = defineComponent({ ...BL, props: { width: { type: String, default: null } }, setup(n) { const e = n, t = nt("aside"), i = computed(() => e.width ? t.cssVarBlock({ width: e.width }) : {}); return (r, s) => (openBlock(), createElementBlock("aside", { class: normalizeClass(unref(t).b()), style: normalizeStyle(unref(i)) }, [ renderSlot(r.$slots, "default") ], 6)); } }); var ly = st(UL, [["__file", "aside.vue"]]); var zL = defineComponent({ name: "ElFooter" }); var VL = defineComponent({ ...zL, props: { height: { type: String, default: null } }, setup(n) { const e = n, t = nt("footer"), i = computed(() => e.height ? t.cssVarBlock({ height: e.height }) : {}); return (r, s) => (openBlock(), createElementBlock("footer", { class: normalizeClass(unref(t).b()), style: normalizeStyle(unref(i)) }, [ renderSlot(r.$slots, "default") ], 6)); } }); var cy = st(VL, [["__file", "footer.vue"]]); var kL = defineComponent({ name: "ElHeader" }); var GL = defineComponent({ ...kL, props: { height: { type: String, default: null } }, setup(n) { const e = n, t = nt("header"), i = computed(() => e.height ? t.cssVarBlock({ height: e.height }) : {}); return (r, s) => (openBlock(), createElementBlock("header", { class: normalizeClass(unref(t).b()), style: normalizeStyle(unref(i)) }, [ renderSlot(r.$slots, "default") ], 6)); } }); var uy = st(GL, [["__file", "header.vue"]]); var HL = defineComponent({ name: "ElMain" }); var WL = defineComponent({ ...HL, setup(n) { const e = nt("main"); return (t, i) => (openBlock(), createElementBlock("main", { class: normalizeClass(unref(e).b()) }, [ renderSlot(t.$slots, "default") ], 2)); } }); var hy = st(WL, [["__file", "main.vue"]]); var zi = on(NL, { Aside: ly, Footer: cy, Header: uy, Main: hy }); vi(ly); var dy = vi(cy); var jL = vi(uy); var hr = vi(hy); var $L = defineComponent({ inheritAttrs: false }); function ZL(n, e, t, i, r, s) { return renderSlot(n.$slots, "default"); } var XL = st($L, [["render", ZL], ["__file", "collection.vue"]]); var YL = defineComponent({ name: "ElCollectionItem", inheritAttrs: false }); function JL(n, e, t, i, r, s) { return renderSlot(n.$slots, "default"); } var KL = st(YL, [["render", JL], ["__file", "collection-item.vue"]]); var qL = "data-el-collection-item"; var QL = (n) => { const e = `El${n}Collection`, t = `${e}Item`, i = Symbol(e), r = Symbol(t), s = { ...XL, name: e, setup() { const a = ref(null), c = /* @__PURE__ */ new Map(); provide(i, { itemMap: c, getItems: () => { const d = unref(a); if (!d) return []; const h6 = Array.from(d.querySelectorAll(`[${qL}]`)); return [...c.values()].sort((g, p) => h6.indexOf(g.ref) - h6.indexOf(p.ref)); }, collectionRef: a }); } }, o = { ...KL, name: t, setup(a, { attrs: c }) { const l = ref(null), d = inject(i, void 0); provide(r, { collectionItemRef: l }), onMounted(() => { const h6 = unref(l); h6 && d.itemMap.set(h6, { ref: h6, ...c }); }), onBeforeUnmount(() => { const h6 = unref(l); d.itemMap.delete(h6); }); } }; return { COLLECTION_INJECTION_KEY: i, COLLECTION_ITEM_INJECTION_KEY: r, ElCollection: s, ElCollectionItem: o }; }; var Hu = at({ trigger: Va.trigger, effect: { ...Vn.effect, default: "light" }, type: { type: Je(String) }, placement: { type: Je(String), default: "bottom" }, popperOptions: { type: Je(Object), default: () => ({}) }, id: String, size: { type: String, default: "" }, splitButton: Boolean, hideOnClick: { type: Boolean, default: true }, loop: { type: Boolean, default: true }, showTimeout: { type: Number, default: 150 }, hideTimeout: { type: Number, default: 150 }, tabindex: { type: Je([Number, String]), default: 0 }, maxHeight: { type: Je([Number, String]), default: "" }, popperClass: { type: String, default: "" }, disabled: Boolean, role: { type: String, default: "menu" }, buttonProps: { type: Je(Object) }, teleported: Vn.teleported }); at({ command: { type: [Object, String, Number], default: () => ({}) }, disabled: Boolean, divided: Boolean, textValue: String, icon: { type: kr } }); at({ onKeydown: { type: Je(Function) } }); QL("Dropdown"); var eR = at({ id: { type: String, default: void 0 }, step: { type: Number, default: 1 }, stepStrictly: Boolean, max: { type: Number, default: Number.POSITIVE_INFINITY }, min: { type: Number, default: Number.NEGATIVE_INFINITY }, modelValue: Number, readonly: Boolean, disabled: Boolean, size: Gr, controls: { type: Boolean, default: true }, controlsPosition: { type: String, default: "", values: ["", "right"] }, valueOnClear: { type: [String, Number, null], validator: (n) => n === null || yt(n) || ["min", "max"].includes(n), default: null }, name: String, placeholder: String, precision: { type: Number, validator: (n) => n >= 0 && n === Number.parseInt(`${n}`, 10) }, validateEvent: { type: Boolean, default: true }, ...Yr(["ariaLabel"]) }); var tR = { [ur]: (n, e) => e !== n, blur: (n) => n instanceof FocusEvent, focus: (n) => n instanceof FocusEvent, [bs]: (n) => yt(n) || Ci(n), [At]: (n) => yt(n) || Ci(n) }; var nR = defineComponent({ name: "ElInputNumber" }); var iR = defineComponent({ ...nR, props: eR, emits: tR, setup(n, { expose: e, emit: t }) { const i = n, { t: r } = iu(), s = nt("input-number"), o = ref(), a = reactive({ currentValue: i.modelValue, userInput: null }), { formItem: c } = Jo(), l = computed(() => yt(i.modelValue) && i.modelValue <= i.min), d = computed(() => yt(i.modelValue) && i.modelValue >= i.max), h6 = computed(() => { const P = v(i.step); return di(i.precision) ? Math.max(v(i.modelValue), P) : (P > i.precision && Vt("InputNumber", "precision should not be less than the decimal places of step"), i.precision); }), f = computed(() => i.controls && i.controlsPosition === "right"), g = Ns(), p = ol(), u = computed(() => { if (a.userInput !== null) return a.userInput; let P = a.currentValue; if (Ci(P)) return ""; if (yt(P)) { if (Number.isNaN(P)) return ""; di(i.precision) || (P = P.toFixed(i.precision)); } return P; }), y = (P, b) => { if (di(b) && (b = h6.value), b === 0) return Math.round(P); let F = String(P); const D = F.indexOf("."); if (D === -1 || !F.replace(".", "").split("")[D + b]) return P; const U = F.length; return F.charAt(U - 1) === "5" && (F = `${F.slice(0, Math.max(0, U - 1))}6`), Number.parseFloat(Number(F).toFixed(b)); }, v = (P) => { if (Ci(P)) return 0; const b = P.toString(), F = b.indexOf("."); let D = 0; return F !== -1 && (D = b.length - F - 1), D; }, m = (P, b = 1) => yt(P) ? y(P + i.step * b) : a.currentValue, x = () => { if (i.readonly || p.value || d.value) return; const P = Number(u.value) || 0, b = m(P); M(b), t(bs, a.currentValue), E(); }, w = () => { if (i.readonly || p.value || l.value) return; const P = Number(u.value) || 0, b = m(P, -1); M(b), t(bs, a.currentValue), E(); }, A = (P, b) => { const { max: F, min: D, step: N, precision: B, stepStrictly: U, valueOnClear: G } = i; F < D && Xo("InputNumber", "min should not be greater than max."); let Y = Number(P); if (Ci(P) || Number.isNaN(Y)) return null; if (P === "") { if (G === null) return null; Y = vn(G) ? { min: D, max: F }[G] : G; } return U && (Y = y(Math.round(Y / N) * N, B), Y !== P && b && t(At, Y)), di(B) || (Y = y(Y, B)), (Y > F || Y < D) && (Y = Y > F ? F : D, b && t(At, Y)), Y; }, M = (P, b = true) => { var F; const D = a.currentValue, N = A(P); if (!b) { t(At, N); return; } D === N && P || (a.userInput = null, t(At, N), D !== N && t(ur, N, D), i.validateEvent && ((F = c == null ? void 0 : c.validate) == null || F.call(c, "change").catch((B) => Vt(B))), a.currentValue = N); }, R = (P) => { a.userInput = P; const b = P === "" ? null : Number(P); t(bs, b), M(b, false); }, L = (P) => { const b = P !== "" ? Number(P) : ""; (yt(b) && !Number.isNaN(b) || P === "") && M(b), E(), a.userInput = null; }, S = () => { var P, b; (b = (P = o.value) == null ? void 0 : P.focus) == null || b.call(P); }, I = () => { var P, b; (b = (P = o.value) == null ? void 0 : P.blur) == null || b.call(P); }, T = (P) => { t("focus", P); }, _ = (P) => { var b; a.userInput = null, t("blur", P), i.validateEvent && ((b = c == null ? void 0 : c.validate) == null || b.call(c, "blur").catch((F) => Vt(F))); }, E = () => { a.currentValue !== i.modelValue && (a.currentValue = i.modelValue); }, C = (P) => { document.activeElement === P.target && P.preventDefault(); }; return watch(() => i.modelValue, (P, b) => { const F = A(P, true); a.userInput === null && F !== b && (a.currentValue = F); }, { immediate: true }), onMounted(() => { var P; const { min: b, max: F, modelValue: D } = i, N = (P = o.value) == null ? void 0 : P.input; if (N.setAttribute("role", "spinbutton"), Number.isFinite(F) ? N.setAttribute("aria-valuemax", String(F)) : N.removeAttribute("aria-valuemax"), Number.isFinite(b) ? N.setAttribute("aria-valuemin", String(b)) : N.removeAttribute("aria-valuemin"), N.setAttribute("aria-valuenow", a.currentValue || a.currentValue === 0 ? String(a.currentValue) : ""), N.setAttribute("aria-disabled", String(p.value)), !yt(D) && D != null) { let B = Number(D); Number.isNaN(B) && (B = null), t(At, B); } N.addEventListener("wheel", C, { passive: false }); }), onUpdated(() => { var P, b; const F = (P = o.value) == null ? void 0 : P.input; F == null || F.setAttribute("aria-valuenow", `${(b = a.currentValue) != null ? b : ""}`); }), e({ focus: S, blur: I }), (P, b) => (openBlock(), createElementBlock("div", { class: normalizeClass([ unref(s).b(), unref(s).m(unref(g)), unref(s).is("disabled", unref(p)), unref(s).is("without-controls", !P.controls), unref(s).is("controls-right", unref(f)) ]), onDragstart: withModifiers(() => { }, ["prevent"]) }, [ P.controls ? withDirectives((openBlock(), createElementBlock("span", { key: 0, role: "button", "aria-label": unref(r)("el.inputNumber.decrease"), class: normalizeClass([unref(s).e("decrease"), unref(s).is("disabled", unref(l))]), onKeydown: withKeys(w, ["enter"]) }, [ renderSlot(P.$slots, "decrease-icon", {}, () => [ createVNode(unref(It), null, { default: withCtx(() => [ unref(f) ? (openBlock(), createBlock(unref(Xd), { key: 0 })) : (openBlock(), createBlock(unref(K_), { key: 1 })) ]), _: 1 }) ]) ], 42, ["aria-label", "onKeydown"])), [ [unref(Nm), w] ]) : createCommentVNode("v-if", true), P.controls ? withDirectives((openBlock(), createElementBlock("span", { key: 1, role: "button", "aria-label": unref(r)("el.inputNumber.increase"), class: normalizeClass([unref(s).e("increase"), unref(s).is("disabled", unref(d))]), onKeydown: withKeys(x, ["enter"]) }, [ renderSlot(P.$slots, "increase-icon", {}, () => [ createVNode(unref(It), null, { default: withCtx(() => [ unref(f) ? (openBlock(), createBlock(unref(k_), { key: 0 })) : (openBlock(), createBlock(unref(tu), { key: 1 })) ]), _: 1 }) ]) ], 42, ["aria-label", "onKeydown"])), [ [unref(Nm), x] ]) : createCommentVNode("v-if", true), createVNode(unref(QE), { id: P.id, ref_key: "input", ref: o, type: "number", step: P.step, "model-value": unref(u), placeholder: P.placeholder, readonly: P.readonly, disabled: unref(p), size: unref(g), max: P.max, min: P.min, name: P.name, "aria-label": P.ariaLabel, "validate-event": false, onKeydown: [ withKeys(withModifiers(x, ["prevent"]), ["up"]), withKeys(withModifiers(w, ["prevent"]), ["down"]) ], onBlur: _, onFocus: T, onInput: R, onChange: L }, createSlots({ _: 2 }, [ P.$slots.prefix ? { name: "prefix", fn: withCtx(() => [ renderSlot(P.$slots, "prefix") ]) } : void 0, P.$slots.suffix ? { name: "suffix", fn: withCtx(() => [ renderSlot(P.$slots, "suffix") ]) } : void 0 ]), 1032, ["id", "step", "model-value", "placeholder", "readonly", "disabled", "size", "max", "min", "name", "aria-label", "onKeydown"]) ], 42, ["onDragstart"])); } }); var rR = st(iR, [["__file", "input-number.vue"]]); var dr = on(rR); var fy = Symbol("ElSelectGroup"); var lu = Symbol("ElSelect"); function sR(n, e) { const t = inject(lu), i = inject(fy, { disabled: false }), r = computed(() => d(Si(t.props.modelValue), n.value)), s = computed(() => { var g; if (t.props.multiple) { const p = Si((g = t.props.modelValue) != null ? g : []); return !r.value && p.length >= t.props.multipleLimit && t.props.multipleLimit > 0; } else return false; }), o = computed(() => n.label || (Tn(n.value) ? "" : n.value)), a = computed(() => n.value || n.label || ""), c = computed(() => n.disabled || e.groupDisabled || s.value), l = getCurrentInstance(), d = (g = [], p) => { if (Tn(n.value)) { const u = t.props.valueKey; return g && g.some((y) => toRaw(Ji(y, u)) === Ji(p, u)); } else return g && g.includes(p); }, h6 = () => { !n.disabled && !i.disabled && (t.states.hoveringIndex = t.optionsArray.indexOf(l.proxy)); }, f = (g) => { const p = new RegExp(O_(g), "i"); e.visible = p.test(o.value) || n.created; }; return watch(() => o.value, () => { !n.created && !t.props.remote && t.setSelected(); }), watch(() => n.value, (g, p) => { const { remote: u, valueKey: y } = t.props; if (g !== p && (t.onOptionDestroy(p, l.proxy), t.onOptionCreate(l.proxy)), !n.created && !u) { if (y && Tn(g) && Tn(p) && g[y] === p[y]) return; t.setSelected(); } }), watch(() => i.disabled, () => { e.groupDisabled = i.disabled; }, { immediate: true }), { select: t, currentLabel: o, currentValue: a, itemSelected: r, isDisabled: c, hoverItem: h6, updateOption: f }; } var oR = defineComponent({ name: "ElOption", componentName: "ElOption", props: { value: { required: true, type: [String, Number, Boolean, Object] }, label: [String, Number], created: Boolean, disabled: Boolean }, setup(n) { const e = nt("select"), t = sl(), i = computed(() => [ e.be("dropdown", "item"), e.is("disabled", unref(a)), e.is("selected", unref(o)), e.is("hovering", unref(f)) ]), r = reactive({ index: -1, groupDisabled: false, visible: true, hover: false }), { currentLabel: s, itemSelected: o, isDisabled: a, select: c, hoverItem: l, updateOption: d } = sR(n, r), { visible: h6, hover: f } = toRefs(r), g = getCurrentInstance().proxy; c.onOptionCreate(g), onBeforeUnmount(() => { const u = g.value, { selected: y } = c.states, m = (c.props.multiple ? y : [y]).some((x) => x.value === g.value); nextTick(() => { c.states.cachedOptions.get(u) === g && !m && c.states.cachedOptions.delete(u); }), c.onOptionDestroy(u, g); }); function p() { a.value || c.handleOptionSelect(g); } return { ns: e, id: t, containerKls: i, currentLabel: s, itemSelected: o, isDisabled: a, select: c, hoverItem: l, updateOption: d, visible: h6, hover: f, selectOptionClick: p, states: r }; } }); function aR(n, e, t, i, r, s) { return withDirectives((openBlock(), createElementBlock("li", { id: n.id, class: normalizeClass(n.containerKls), role: "option", "aria-disabled": n.isDisabled || void 0, "aria-selected": n.itemSelected, onMouseenter: n.hoverItem, onClick: withModifiers(n.selectOptionClick, ["stop"]) }, [ renderSlot(n.$slots, "default", {}, () => [ createBaseVNode("span", null, toDisplayString(n.currentLabel), 1) ]) ], 42, ["id", "aria-disabled", "aria-selected", "onMouseenter", "onClick"])), [ [vShow, n.visible] ]); } var mf = st(oR, [["render", aR], ["__file", "option.vue"]]); var lR = defineComponent({ name: "ElSelectDropdown", componentName: "ElSelectDropdown", setup() { const n = inject(lu), e = nt("select"), t = computed(() => n.props.popperClass), i = computed(() => n.props.multiple), r = computed(() => n.props.fitInputWidth), s = ref(""); function o() { var a; s.value = `${(a = n.selectRef) == null ? void 0 : a.offsetWidth}px`; } return onMounted(() => { o(), Yn(n.selectRef, o); }), { ns: e, minWidth: s, popperClass: t, isMultiple: i, isFitInputWidth: r }; } }); function cR(n, e, t, i, r, s) { return openBlock(), createElementBlock("div", { class: normalizeClass([n.ns.b("dropdown"), n.ns.is("multiple", n.isMultiple), n.popperClass]), style: normalizeStyle({ [n.isFitInputWidth ? "width" : "minWidth"]: n.minWidth }) }, [ n.$slots.header ? (openBlock(), createElementBlock("div", { key: 0, class: normalizeClass(n.ns.be("dropdown", "header")) }, [ renderSlot(n.$slots, "header") ], 2)) : createCommentVNode("v-if", true), renderSlot(n.$slots, "default"), n.$slots.footer ? (openBlock(), createElementBlock("div", { key: 1, class: normalizeClass(n.ns.be("dropdown", "footer")) }, [ renderSlot(n.$slots, "footer") ], 2)) : createCommentVNode("v-if", true) ], 6); } var uR = st(lR, [["render", cR], ["__file", "select-dropdown.vue"]]); var hR = 11; var dR = (n, e) => { const { t } = iu(), i = sl(), r = nt("select"), s = nt("input"), o = reactive({ inputValue: "", options: /* @__PURE__ */ new Map(), cachedOptions: /* @__PURE__ */ new Map(), disabledOptions: /* @__PURE__ */ new Map(), optionValues: [], selected: [], selectionWidth: 0, calculatorWidth: 0, collapseItemWidth: 0, selectedLabel: "", hoveringIndex: -1, previousQuery: null, inputHovering: false, menuVisibleOnFocus: false, isBeforeHide: false }), a = ref(null), c = ref(null), l = ref(null), d = ref(null), h6 = ref(null), f = ref(null), g = ref(null), p = ref(null), u = ref(null), y = ref(null), v = ref(null), m = ref(null), { isComposing: x, handleCompositionStart: w, handleCompositionUpdate: A, handleCompositionEnd: M } = N0({ afterComposition: (ge) => ne(ge) }), { wrapperRef: R, isFocused: L } = D0(h6, { beforeFocus() { return b.value; }, afterFocus() { n.automaticDropdown && !S.value && (S.value = true, o.menuVisibleOnFocus = true); }, beforeBlur(ge) { var Se, Fe; return ((Se = l.value) == null ? void 0 : Se.isFocusInsideContent(ge)) || ((Fe = d.value) == null ? void 0 : Fe.isFocusInsideContent(ge)); }, afterBlur() { S.value = false, o.menuVisibleOnFocus = false; } }), S = ref(false), I = ref(), { form: T, formItem: _ } = Jo(), { inputId: E } = su(n, { formItemContext: _ }), { valueOnClear: C, isEmptyValue: P } = NE(n), b = computed(() => n.disabled || (T == null ? void 0 : T.disabled)), F = computed(() => Pn(n.modelValue) ? n.modelValue.length > 0 : !P(n.modelValue)), D = computed(() => n.clearable && !b.value && o.inputHovering && F.value), N = computed(() => n.remote && n.filterable && !n.remoteShowSuffix ? "" : n.suffixIcon), B = computed(() => r.is("reverse", N.value && S.value)), U = computed(() => (_ == null ? void 0 : _.validateState) || ""), G = computed(() => d0[U.value]), Y = computed(() => n.remote ? 300 : 0), te = computed(() => n.loading ? n.loadingText || t("el.select.loading") : n.remote && !o.inputValue && o.options.size === 0 ? false : n.filterable && o.inputValue && o.options.size > 0 && ae.value === 0 ? n.noMatchText || t("el.select.noMatch") : o.options.size === 0 ? n.noDataText || t("el.select.noData") : null), ae = computed(() => ie.value.filter((ge) => ge.visible).length), ie = computed(() => { const ge = Array.from(o.options.values()), Se = []; return o.optionValues.forEach((Fe) => { const Ge = ge.findIndex((We) => We.value === Fe); Ge > -1 && Se.push(ge[Ge]); }), Se.length >= ge.length ? Se : ge; }), le = computed(() => Array.from(o.cachedOptions.values())), W = computed(() => { const ge = ie.value.filter((Se) => !Se.created).some((Se) => Se.currentLabel === o.inputValue); return n.filterable && n.allowCreate && o.inputValue !== "" && !ge; }), $ = () => { n.filterable && Sn(n.filterMethod) || n.filterable && n.remote && Sn(n.remoteMethod) || ie.value.forEach((ge) => { var Se; (Se = ge.updateOption) == null || Se.call(ge, o.inputValue); }); }, j = Ns(), re = computed(() => ["small"].includes(j.value) ? "small" : "default"), V = computed({ get() { return S.value && te.value !== false; }, set(ge) { S.value = ge; } }), H = computed(() => { if (n.multiple && !di(n.modelValue)) return Si(n.modelValue).length === 0 && !o.inputValue; const ge = Pn(n.modelValue) ? n.modelValue[0] : n.modelValue; return n.filterable || di(ge) ? !o.inputValue : true; }), K = computed(() => { var ge; const Se = (ge = n.placeholder) != null ? ge : t("el.select.placeholder"); return n.multiple || !F.value ? Se : o.selectedLabel; }), ce = computed(() => zh ? null : "mouseenter"); watch(() => n.modelValue, (ge, Se) => { n.multiple && n.filterable && !n.reserveKeyword && (o.inputValue = "", se("")), O(), !$h(ge, Se) && n.validateEvent && (_ == null || _.validate("change").catch((Fe) => Vt(Fe))); }, { flush: "post", deep: true }), watch(() => S.value, (ge) => { ge ? se(o.inputValue) : (o.inputValue = "", o.previousQuery = null, o.isBeforeHide = true), e("visible-change", ge); }), watch(() => o.options.entries(), () => { var ge; if (!en) return; const Se = ((ge = a.value) == null ? void 0 : ge.querySelectorAll("input")) || []; (!n.filterable && !n.defaultFirstOption && !di(n.modelValue) || !Array.from(Se).includes(document.activeElement)) && O(), n.defaultFirstOption && (n.filterable || n.remote) && ae.value && k(); }, { flush: "post" }), watch(() => o.hoveringIndex, (ge) => { yt(ge) && ge > -1 ? I.value = ie.value[ge] || {} : I.value = {}, ie.value.forEach((Se) => { Se.hover = I.value === Se; }); }), watchEffect(() => { o.isBeforeHide || $(); }); const se = (ge) => { o.previousQuery === ge || x.value || (o.previousQuery = ge, n.filterable && Sn(n.filterMethod) ? n.filterMethod(ge) : n.filterable && n.remote && Sn(n.remoteMethod) && n.remoteMethod(ge), n.defaultFirstOption && (n.filterable || n.remote) && ae.value ? nextTick(k) : nextTick(X)); }, k = () => { const ge = ie.value.filter((Ge) => Ge.visible && !Ge.disabled && !Ge.states.groupDisabled), Se = ge.find((Ge) => Ge.created), Fe = ge[0]; o.hoveringIndex = Mt(ie.value, Se || Fe); }, O = () => { if (n.multiple) o.selectedLabel = ""; else { const Se = Pn(n.modelValue) ? n.modelValue[0] : n.modelValue, Fe = Z(Se); o.selectedLabel = Fe.currentLabel, o.selected = [Fe]; return; } const ge = []; di(n.modelValue) || Si(n.modelValue).forEach((Se) => { ge.push(Z(Se)); }), o.selected = ge; }, Z = (ge) => { let Se; const Fe = Pu(ge).toLowerCase() === "object", Ge = Pu(ge).toLowerCase() === "null", We = Pu(ge).toLowerCase() === "undefined"; for (let ft = o.cachedOptions.size - 1; ft >= 0; ft--) { const kt = le.value[ft]; if (Fe ? Ji(kt.value, n.valueKey) === Ji(ge, n.valueKey) : kt.value === ge) { Se = { value: ge, currentLabel: kt.currentLabel, get isDisabled() { return kt.isDisabled; } }; break; } } if (Se) return Se; const et = Fe ? ge.label : !Ge && !We ? ge : ""; return { value: ge, currentLabel: et }; }, X = () => { o.hoveringIndex = ie.value.findIndex((ge) => o.selected.some((Se) => _e(Se) === _e(ge))); }, ee = () => { o.selectionWidth = c.value.getBoundingClientRect().width; }, fe = () => { o.calculatorWidth = f.value.getBoundingClientRect().width; }, be = () => { o.collapseItemWidth = v.value.getBoundingClientRect().width; }, Ae = () => { var ge, Se; (Se = (ge = l.value) == null ? void 0 : ge.updatePopper) == null || Se.call(ge); }, he = () => { var ge, Se; (Se = (ge = d.value) == null ? void 0 : ge.updatePopper) == null || Se.call(ge); }, xe = () => { o.inputValue.length > 0 && !S.value && (S.value = true), se(o.inputValue); }, ne = (ge) => { if (o.inputValue = ge.target.value, n.remote) me(); else return xe(); }, me = jh(() => { xe(); }, Y.value), Me = (ge) => { $h(n.modelValue, ge) || e(ur, ge); }, De = (ge) => E_(ge, (Se) => !o.disabledOptions.has(Se)), Ie = (ge) => { if (n.multiple && ge.code !== Li.delete && ge.target.value.length <= 0) { const Se = Si(n.modelValue).slice(), Fe = De(Se); if (Fe < 0) return; const Ge = Se[Fe]; Se.splice(Fe, 1), e(At, Se), Me(Se), e("remove-tag", Ge); } }, $e = (ge, Se) => { const Fe = o.selected.indexOf(Se); if (Fe > -1 && !b.value) { const Ge = Si(n.modelValue).slice(); Ge.splice(Fe, 1), e(At, Ge), Me(Ge), e("remove-tag", Se.value); } ge.stopPropagation(), Ft(); }, lt = (ge) => { ge.stopPropagation(); const Se = n.multiple ? [] : C.value; if (n.multiple) for (const Fe of o.selected) Fe.isDisabled && Se.push(Fe.value); e(At, Se), Me(Se), o.hoveringIndex = -1, S.value = false, e("clear"), Ft(); }, qe = (ge) => { var Se; if (n.multiple) { const Fe = Si((Se = n.modelValue) != null ? Se : []).slice(), Ge = Mt(Fe, ge.value); Ge > -1 ? Fe.splice(Ge, 1) : (n.multipleLimit <= 0 || Fe.length < n.multipleLimit) && Fe.push(ge.value), e(At, Fe), Me(Fe), ge.created && se(""), n.filterable && !n.reserveKeyword && (o.inputValue = ""); } else e(At, ge.value), Me(ge.value), S.value = false; Ft(), !S.value && nextTick(() => { Be(ge); }); }, Mt = (ge = [], Se) => { if (!Tn(Se)) return ge.indexOf(Se); const Fe = n.valueKey; let Ge = -1; return ge.some((We, et) => toRaw(Ji(We, Fe)) === Ji(Se, Fe) ? (Ge = et, true) : false), Ge; }, Be = (ge) => { var Se, Fe, Ge, We, et; const Ye = Pn(ge) ? ge[0] : ge; let ft = null; if (Ye != null && Ye.value) { const kt = ie.value.filter((ln) => ln.value === Ye.value); kt.length > 0 && (ft = kt[0].$el); } if (l.value && ft) { const kt = (We = (Ge = (Fe = (Se = l.value) == null ? void 0 : Se.popperRef) == null ? void 0 : Fe.contentRef) == null ? void 0 : Ge.querySelector) == null ? void 0 : We.call(Ge, `.${r.be("dropdown", "wrap")}`); kt && N_(kt, ft); } (et = m.value) == null || et.handleScroll(); }, it = (ge) => { o.options.set(ge.value, ge), o.cachedOptions.set(ge.value, ge), ge.disabled && o.disabledOptions.set(ge.value, ge); }, tt = (ge, Se) => { o.options.get(ge) === Se && o.options.delete(ge); }, qt = computed(() => { var ge, Se; return (Se = (ge = l.value) == null ? void 0 : ge.popperRef) == null ? void 0 : Se.contentRef; }), Qt = () => { o.isBeforeHide = false, nextTick(() => Be(o.selected)); }, Ft = () => { var ge; (ge = h6.value) == null || ge.focus(); }, Nt = () => { var ge; (ge = h6.value) == null || ge.blur(); }, Vi = (ge) => { lt(ge); }, ki = () => { S.value = false, L.value && Nt(); }, ni = () => { o.inputValue.length > 0 ? o.inputValue = "" : S.value = false; }, ts = () => { b.value || (zh && (o.inputHovering = true), o.menuVisibleOnFocus ? o.menuVisibleOnFocus = false : S.value = !S.value); }, Q = () => { S.value ? ie.value[o.hoveringIndex] && qe(ie.value[o.hoveringIndex]) : ts(); }, _e = (ge) => Tn(ge.value) ? Ji(ge.value, n.valueKey) : ge.value, Oe = computed(() => ie.value.filter((ge) => ge.visible).every((ge) => ge.disabled)), Ze = computed(() => n.multiple ? n.collapseTags ? o.selected.slice(0, n.maxCollapseTags) : o.selected : []), ht = computed(() => n.multiple ? n.collapseTags ? o.selected.slice(n.maxCollapseTags) : [] : []), J = (ge) => { if (!S.value) { S.value = true; return; } if (!(o.options.size === 0 || o.filteredOptionsCount === 0 || x.value) && !Oe.value) { ge === "next" ? (o.hoveringIndex++, o.hoveringIndex === o.options.size && (o.hoveringIndex = 0)) : ge === "prev" && (o.hoveringIndex--, o.hoveringIndex < 0 && (o.hoveringIndex = o.options.size - 1)); const Se = ie.value[o.hoveringIndex]; (Se.disabled === true || Se.states.groupDisabled === true || !Se.visible) && J(ge), nextTick(() => Be(I.value)); } }, ye = () => { if (!c.value) return 0; const ge = window.getComputedStyle(c.value); return Number.parseFloat(ge.gap || "6px"); }, pe = computed(() => { const ge = ye(); return { maxWidth: `${v.value && n.maxCollapseTags === 1 ? o.selectionWidth - o.collapseItemWidth - ge : o.selectionWidth}px` }; }), we = computed(() => ({ maxWidth: `${o.selectionWidth}px` })), Ce = computed(() => ({ width: `${Math.max(o.calculatorWidth, hR)}px` })); return Yn(c, ee), Yn(f, fe), Yn(u, Ae), Yn(R, Ae), Yn(y, he), Yn(v, be), onMounted(() => { O(); }), { inputId: E, contentId: i, nsSelect: r, nsInput: s, states: o, isFocused: L, expanded: S, optionsArray: ie, hoverOption: I, selectSize: j, filteredOptionsCount: ae, resetCalculatorWidth: fe, updateTooltip: Ae, updateTagTooltip: he, debouncedOnInputChange: me, onInput: ne, deletePrevTag: Ie, deleteTag: $e, deleteSelected: lt, handleOptionSelect: qe, scrollToOption: Be, hasModelValue: F, shouldShowPlaceholder: H, currentPlaceholder: K, mouseEnterEventName: ce, showClose: D, iconComponent: N, iconReverse: B, validateState: U, validateIcon: G, showNewOption: W, updateOptions: $, collapseTagSize: re, setSelected: O, selectDisabled: b, emptyText: te, handleCompositionStart: w, handleCompositionUpdate: A, handleCompositionEnd: M, onOptionCreate: it, onOptionDestroy: tt, handleMenuEnter: Qt, focus: Ft, blur: Nt, handleClearClick: Vi, handleClickOutside: ki, handleEsc: ni, toggleMenu: ts, selectOption: Q, getValueKey: _e, navigateOptions: J, dropdownMenuVisible: V, showTagList: Ze, collapseTagList: ht, tagStyle: pe, collapseTagStyle: we, inputStyle: Ce, popperRef: qt, inputRef: h6, tooltipRef: l, tagTooltipRef: d, calculatorRef: f, prefixRef: g, suffixRef: p, selectRef: a, wrapperRef: R, selectionRef: c, scrollbarRef: m, menuRef: u, tagMenuRef: y, collapseItemRef: v }; }; var fR = defineComponent({ name: "ElOptions", setup(n, { slots: e }) { const t = inject(lu); let i = []; return () => { var r, s; const o = (r = e.default) == null ? void 0 : r.call(e), a = []; function c(l) { Pn(l) && l.forEach((d) => { var h6, f, g, p; const u = (h6 = (d == null ? void 0 : d.type) || {}) == null ? void 0 : h6.name; u === "ElOptionGroup" ? c(!vn(d.children) && !Pn(d.children) && Sn((f = d.children) == null ? void 0 : f.default) ? (g = d.children) == null ? void 0 : g.default() : d.children) : u === "ElOption" ? a.push((p = d.props) == null ? void 0 : p.value) : Pn(d.children) && c(d.children); }); } return o.length && c((s = o[0]) == null ? void 0 : s.children), $h(a, i) || (i = a, t && (t.states.optionValues = a)), o; }; } }); var pR = at({ name: String, id: String, modelValue: { type: [Array, String, Number, Boolean, Object], default: void 0 }, autocomplete: { type: String, default: "off" }, automaticDropdown: Boolean, size: Gr, effect: { type: Je(String), default: "light" }, disabled: Boolean, clearable: Boolean, filterable: Boolean, allowCreate: Boolean, loading: Boolean, popperClass: { type: String, default: "" }, popperOptions: { type: Je(Object), default: () => ({}) }, remote: Boolean, loadingText: String, noMatchText: String, noDataText: String, remoteMethod: Function, filterMethod: Function, multiple: Boolean, multipleLimit: { type: Number, default: 0 }, placeholder: { type: String }, defaultFirstOption: Boolean, reserveKeyword: { type: Boolean, default: true }, valueKey: { type: String, default: "value" }, collapseTags: Boolean, collapseTagsTooltip: Boolean, maxCollapseTags: { type: Number, default: 1 }, teleported: Vn.teleported, persistent: { type: Boolean, default: true }, clearIcon: { type: kr, default: Yd }, fitInputWidth: Boolean, suffixIcon: { type: kr, default: Xd }, tagType: { ...Qh.type, default: "info" }, tagEffect: { ...Qh.effect, default: "light" }, validateEvent: { type: Boolean, default: true }, remoteShowSuffix: Boolean, placement: { type: Je(String), values: Yo, default: "bottom-start" }, fallbackPlacements: { type: Je(Array), default: ["bottom-start", "top-start", "right", "left"] }, appendTo: String, ...DE, ...Yr(["ariaLabel"]) }); var Um = "ElSelect"; var mR = defineComponent({ name: Um, componentName: Um, components: { ElSelectMenu: uR, ElOption: mf, ElOptions: fR, ElTag: aL, ElScrollbar: f2, ElTooltip: pf, ElIcon: It }, directives: { ClickOutside: HC }, props: pR, emits: [ At, ur, "remove-tag", "clear", "visible-change", "focus", "blur" ], setup(n, { emit: e }) { const t = computed(() => { const { modelValue: s, multiple: o } = n, a = o ? [] : void 0; return Pn(s) ? o ? s : a : o ? a : s; }), i = reactive({ ...toRefs(n), modelValue: t }), r = dR(i, e); return provide(lu, reactive({ props: i, states: r.states, optionsArray: r.optionsArray, handleOptionSelect: r.handleOptionSelect, onOptionCreate: r.onOptionCreate, onOptionDestroy: r.onOptionDestroy, selectRef: r.selectRef, setSelected: r.setSelected })), { ...r, modelValue: t }; } }); function gR(n, e, t, i, r, s) { const o = resolveComponent("el-tag"), a = resolveComponent("el-tooltip"), c = resolveComponent("el-icon"), l = resolveComponent("el-option"), d = resolveComponent("el-options"), h6 = resolveComponent("el-scrollbar"), f = resolveComponent("el-select-menu"), g = resolveDirective("click-outside"); return withDirectives((openBlock(), createElementBlock("div", { ref: "selectRef", class: normalizeClass([n.nsSelect.b(), n.nsSelect.m(n.selectSize)]), [toHandlerKey(n.mouseEnterEventName)]: (p) => n.states.inputHovering = true, onMouseleave: (p) => n.states.inputHovering = false }, [ createVNode(a, { ref: "tooltipRef", visible: n.dropdownMenuVisible, placement: n.placement, teleported: n.teleported, "popper-class": [n.nsSelect.e("popper"), n.popperClass], "popper-options": n.popperOptions, "fallback-placements": n.fallbackPlacements, effect: n.effect, pure: "", trigger: "click", transition: `${n.nsSelect.namespace.value}-zoom-in-top`, "stop-popper-mouse-event": false, "gpu-acceleration": false, persistent: n.persistent, "append-to": n.appendTo, onBeforeShow: n.handleMenuEnter, onHide: (p) => n.states.isBeforeHide = false }, { default: withCtx(() => { var p; return [ createBaseVNode("div", { ref: "wrapperRef", class: normalizeClass([ n.nsSelect.e("wrapper"), n.nsSelect.is("focused", n.isFocused), n.nsSelect.is("hovering", n.states.inputHovering), n.nsSelect.is("filterable", n.filterable), n.nsSelect.is("disabled", n.selectDisabled) ]), onClick: withModifiers(n.toggleMenu, ["prevent"]) }, [ n.$slots.prefix ? (openBlock(), createElementBlock("div", { key: 0, ref: "prefixRef", class: normalizeClass(n.nsSelect.e("prefix")) }, [ renderSlot(n.$slots, "prefix") ], 2)) : createCommentVNode("v-if", true), createBaseVNode("div", { ref: "selectionRef", class: normalizeClass([ n.nsSelect.e("selection"), n.nsSelect.is("near", n.multiple && !n.$slots.prefix && !!n.states.selected.length) ]) }, [ n.multiple ? renderSlot(n.$slots, "tag", { key: 0 }, () => [ (openBlock(true), createElementBlock(Fragment, null, renderList(n.showTagList, (u) => (openBlock(), createElementBlock("div", { key: n.getValueKey(u), class: normalizeClass(n.nsSelect.e("selected-item")) }, [ createVNode(o, { closable: !n.selectDisabled && !u.isDisabled, size: n.collapseTagSize, type: n.tagType, effect: n.tagEffect, "disable-transitions": "", style: normalizeStyle(n.tagStyle), onClose: (y) => n.deleteTag(y, u) }, { default: withCtx(() => [ createBaseVNode("span", { class: normalizeClass(n.nsSelect.e("tags-text")) }, [ renderSlot(n.$slots, "label", { label: u.currentLabel, value: u.value }, () => [ createTextVNode(toDisplayString(u.currentLabel), 1) ]) ], 2) ]), _: 2 }, 1032, ["closable", "size", "type", "effect", "style", "onClose"]) ], 2))), 128)), n.collapseTags && n.states.selected.length > n.maxCollapseTags ? (openBlock(), createBlock(a, { key: 0, ref: "tagTooltipRef", disabled: n.dropdownMenuVisible || !n.collapseTagsTooltip, "fallback-placements": ["bottom", "top", "right", "left"], effect: n.effect, placement: "bottom", teleported: n.teleported }, { default: withCtx(() => [ createBaseVNode("div", { ref: "collapseItemRef", class: normalizeClass(n.nsSelect.e("selected-item")) }, [ createVNode(o, { closable: false, size: n.collapseTagSize, type: n.tagType, effect: n.tagEffect, "disable-transitions": "", style: normalizeStyle(n.collapseTagStyle) }, { default: withCtx(() => [ createBaseVNode("span", { class: normalizeClass(n.nsSelect.e("tags-text")) }, " + " + toDisplayString(n.states.selected.length - n.maxCollapseTags), 3) ]), _: 1 }, 8, ["size", "type", "effect", "style"]) ], 2) ]), content: withCtx(() => [ createBaseVNode("div", { ref: "tagMenuRef", class: normalizeClass(n.nsSelect.e("selection")) }, [ (openBlock(true), createElementBlock(Fragment, null, renderList(n.collapseTagList, (u) => (openBlock(), createElementBlock("div", { key: n.getValueKey(u), class: normalizeClass(n.nsSelect.e("selected-item")) }, [ createVNode(o, { class: "in-tooltip", closable: !n.selectDisabled && !u.isDisabled, size: n.collapseTagSize, type: n.tagType, effect: n.tagEffect, "disable-transitions": "", onClose: (y) => n.deleteTag(y, u) }, { default: withCtx(() => [ createBaseVNode("span", { class: normalizeClass(n.nsSelect.e("tags-text")) }, [ renderSlot(n.$slots, "label", { label: u.currentLabel, value: u.value }, () => [ createTextVNode(toDisplayString(u.currentLabel), 1) ]) ], 2) ]), _: 2 }, 1032, ["closable", "size", "type", "effect", "onClose"]) ], 2))), 128)) ], 2) ]), _: 3 }, 8, ["disabled", "effect", "teleported"])) : createCommentVNode("v-if", true) ]) : createCommentVNode("v-if", true), n.selectDisabled ? createCommentVNode("v-if", true) : (openBlock(), createElementBlock("div", { key: 1, class: normalizeClass([ n.nsSelect.e("selected-item"), n.nsSelect.e("input-wrapper"), n.nsSelect.is("hidden", !n.filterable) ]) }, [ withDirectives(createBaseVNode("input", { id: n.inputId, ref: "inputRef", "onUpdate:modelValue": (u) => n.states.inputValue = u, type: "text", name: n.name, class: normalizeClass([n.nsSelect.e("input"), n.nsSelect.is(n.selectSize)]), disabled: n.selectDisabled, autocomplete: n.autocomplete, style: normalizeStyle(n.inputStyle), role: "combobox", readonly: !n.filterable, spellcheck: "false", "aria-activedescendant": ((p = n.hoverOption) == null ? void 0 : p.id) || "", "aria-controls": n.contentId, "aria-expanded": n.dropdownMenuVisible, "aria-label": n.ariaLabel, "aria-autocomplete": "none", "aria-haspopup": "listbox", onKeydown: [ withKeys(withModifiers((u) => n.navigateOptions("next"), ["stop", "prevent"]), ["down"]), withKeys(withModifiers((u) => n.navigateOptions("prev"), ["stop", "prevent"]), ["up"]), withKeys(withModifiers(n.handleEsc, ["stop", "prevent"]), ["esc"]), withKeys(withModifiers(n.selectOption, ["stop", "prevent"]), ["enter"]), withKeys(withModifiers(n.deletePrevTag, ["stop"]), ["delete"]) ], onCompositionstart: n.handleCompositionStart, onCompositionupdate: n.handleCompositionUpdate, onCompositionend: n.handleCompositionEnd, onInput: n.onInput, onClick: withModifiers(n.toggleMenu, ["stop"]) }, null, 46, ["id", "onUpdate:modelValue", "name", "disabled", "autocomplete", "readonly", "aria-activedescendant", "aria-controls", "aria-expanded", "aria-label", "onKeydown", "onCompositionstart", "onCompositionupdate", "onCompositionend", "onInput", "onClick"]), [ [vModelText, n.states.inputValue] ]), n.filterable ? (openBlock(), createElementBlock("span", { key: 0, ref: "calculatorRef", "aria-hidden": "true", class: normalizeClass(n.nsSelect.e("input-calculator")), textContent: toDisplayString(n.states.inputValue) }, null, 10, ["textContent"])) : createCommentVNode("v-if", true) ], 2)), n.shouldShowPlaceholder ? (openBlock(), createElementBlock("div", { key: 2, class: normalizeClass([ n.nsSelect.e("selected-item"), n.nsSelect.e("placeholder"), n.nsSelect.is("transparent", !n.hasModelValue || n.expanded && !n.states.inputValue) ]) }, [ n.hasModelValue ? renderSlot(n.$slots, "label", { key: 0, label: n.currentPlaceholder, value: n.modelValue }, () => [ createBaseVNode("span", null, toDisplayString(n.currentPlaceholder), 1) ]) : (openBlock(), createElementBlock("span", { key: 1 }, toDisplayString(n.currentPlaceholder), 1)) ], 2)) : createCommentVNode("v-if", true) ], 2), createBaseVNode("div", { ref: "suffixRef", class: normalizeClass(n.nsSelect.e("suffix")) }, [ n.iconComponent && !n.showClose ? (openBlock(), createBlock(c, { key: 0, class: normalizeClass([n.nsSelect.e("caret"), n.nsSelect.e("icon"), n.iconReverse]) }, { default: withCtx(() => [ (openBlock(), createBlock(resolveDynamicComponent(n.iconComponent))) ]), _: 1 }, 8, ["class"])) : createCommentVNode("v-if", true), n.showClose && n.clearIcon ? (openBlock(), createBlock(c, { key: 1, class: normalizeClass([ n.nsSelect.e("caret"), n.nsSelect.e("icon"), n.nsSelect.e("clear") ]), onClick: n.handleClearClick }, { default: withCtx(() => [ (openBlock(), createBlock(resolveDynamicComponent(n.clearIcon))) ]), _: 1 }, 8, ["class", "onClick"])) : createCommentVNode("v-if", true), n.validateState && n.validateIcon ? (openBlock(), createBlock(c, { key: 2, class: normalizeClass([n.nsInput.e("icon"), n.nsInput.e("validateIcon")]) }, { default: withCtx(() => [ (openBlock(), createBlock(resolveDynamicComponent(n.validateIcon))) ]), _: 1 }, 8, ["class"])) : createCommentVNode("v-if", true) ], 2) ], 10, ["onClick"]) ]; }), content: withCtx(() => [ createVNode(f, { ref: "menuRef" }, { default: withCtx(() => [ n.$slots.header ? (openBlock(), createElementBlock("div", { key: 0, class: normalizeClass(n.nsSelect.be("dropdown", "header")), onClick: withModifiers(() => { }, ["stop"]) }, [ renderSlot(n.$slots, "header") ], 10, ["onClick"])) : createCommentVNode("v-if", true), withDirectives(createVNode(h6, { id: n.contentId, ref: "scrollbarRef", tag: "ul", "wrap-class": n.nsSelect.be("dropdown", "wrap"), "view-class": n.nsSelect.be("dropdown", "list"), class: normalizeClass([n.nsSelect.is("empty", n.filteredOptionsCount === 0)]), role: "listbox", "aria-label": n.ariaLabel, "aria-orientation": "vertical" }, { default: withCtx(() => [ n.showNewOption ? (openBlock(), createBlock(l, { key: 0, value: n.states.inputValue, created: true }, null, 8, ["value"])) : createCommentVNode("v-if", true), createVNode(d, null, { default: withCtx(() => [ renderSlot(n.$slots, "default") ]), _: 3 }) ]), _: 3 }, 8, ["id", "wrap-class", "view-class", "class", "aria-label"]), [ [vShow, n.states.options.size > 0 && !n.loading] ]), n.$slots.loading && n.loading ? (openBlock(), createElementBlock("div", { key: 1, class: normalizeClass(n.nsSelect.be("dropdown", "loading")) }, [ renderSlot(n.$slots, "loading") ], 2)) : n.loading || n.filteredOptionsCount === 0 ? (openBlock(), createElementBlock("div", { key: 2, class: normalizeClass(n.nsSelect.be("dropdown", "empty")) }, [ renderSlot(n.$slots, "empty", {}, () => [ createBaseVNode("span", null, toDisplayString(n.emptyText), 1) ]) ], 2)) : createCommentVNode("v-if", true), n.$slots.footer ? (openBlock(), createElementBlock("div", { key: 3, class: normalizeClass(n.nsSelect.be("dropdown", "footer")), onClick: withModifiers(() => { }, ["stop"]) }, [ renderSlot(n.$slots, "footer") ], 10, ["onClick"])) : createCommentVNode("v-if", true) ]), _: 3 }, 512) ]), _: 3 }, 8, ["visible", "placement", "teleported", "popper-class", "popper-options", "fallback-placements", "effect", "transition", "persistent", "append-to", "onBeforeShow", "onHide"]) ], 16, ["onMouseleave"])), [ [g, n.handleClickOutside, n.popperRef] ]); } var vR = st(mR, [["render", gR], ["__file", "select.vue"]]); var yR = defineComponent({ name: "ElOptionGroup", componentName: "ElOptionGroup", props: { label: String, disabled: Boolean }, setup(n) { const e = nt("select"), t = ref(null), i = getCurrentInstance(), r = ref([]); provide(fy, reactive({ ...toRefs(n) })); const s = computed(() => r.value.some((l) => l.visible === true)), o = (l) => { var d, h6; return ((d = l.type) == null ? void 0 : d.name) === "ElOption" && !!((h6 = l.component) != null && h6.proxy); }, a = (l) => { const d = Si(l), h6 = []; return d.forEach((f) => { var g, p; o(f) ? h6.push(f.component.proxy) : (g = f.children) != null && g.length ? h6.push(...a(f.children)) : (p = f.component) != null && p.subTree && h6.push(...a(f.component.subTree)); }), h6; }, c = () => { r.value = a(i.subTree); }; return onMounted(() => { c(); }), Tw(t, c, { attributes: true, subtree: true, childList: true }), { groupRef: t, visible: s, ns: e }; } }); function bR(n, e, t, i, r, s) { return withDirectives((openBlock(), createElementBlock("ul", { ref: "groupRef", class: normalizeClass(n.ns.be("group", "wrap")) }, [ createBaseVNode("li", { class: normalizeClass(n.ns.be("group", "title")) }, toDisplayString(n.label), 3), createBaseVNode("li", null, [ createBaseVNode("ul", { class: normalizeClass(n.ns.b("group")) }, [ renderSlot(n.$slots, "default") ], 2) ]) ], 2)), [ [vShow, n.visible] ]); } var py = st(yR, [["render", bR], ["__file", "option-group.vue"]]); var qo = on(vR, { Option: mf, OptionGroup: py }); var Qo = vi(mf); vi(py); var xR = at({ trigger: Va.trigger, placement: Hu.placement, disabled: Va.disabled, visible: Vn.visible, transition: Vn.transition, popperOptions: Hu.popperOptions, tabindex: Hu.tabindex, content: Vn.content, popperStyle: Vn.popperStyle, popperClass: Vn.popperClass, enterable: { ...Vn.enterable, default: true }, effect: { ...Vn.effect, default: "light" }, teleported: Vn.teleported, title: String, width: { type: [String, Number], default: 150 }, offset: { type: Number, default: void 0 }, showAfter: { type: Number, default: 0 }, hideAfter: { type: Number, default: 200 }, autoClose: { type: Number, default: 0 }, showArrow: { type: Boolean, default: true }, persistent: { type: Boolean, default: true }, "onUpdate:visible": { type: Function } }); var MR = { "update:visible": (n) => Ba(n), "before-enter": () => true, "before-leave": () => true, "after-enter": () => true, "after-leave": () => true }; var wR = "onUpdate:visible"; var AR = defineComponent({ name: "ElPopover" }); var SR = defineComponent({ ...AR, props: xR, emits: MR, setup(n, { expose: e, emit: t }) { const i = n, r = computed(() => i[wR]), s = nt("popover"), o = ref(), a = computed(() => { var y; return (y = unref(o)) == null ? void 0 : y.popperRef; }), c = computed(() => [ { width: Dc(i.width) }, i.popperStyle ]), l = computed(() => [s.b(), i.popperClass, { [s.m("plain")]: !!i.content }]), d = computed(() => i.transition === `${s.namespace.value}-fade-in-linear`), h6 = () => { var y; (y = o.value) == null || y.hide(); }, f = () => { t("before-enter"); }, g = () => { t("before-leave"); }, p = () => { t("after-enter"); }, u = () => { t("update:visible", false), t("after-leave"); }; return e({ popperRef: a, hide: h6 }), (y, v) => (openBlock(), createBlock(unref(pf), mergeProps({ ref_key: "tooltipRef", ref: o }, y.$attrs, { trigger: y.trigger, placement: y.placement, disabled: y.disabled, visible: y.visible, transition: y.transition, "popper-options": y.popperOptions, tabindex: y.tabindex, content: y.content, offset: y.offset, "show-after": y.showAfter, "hide-after": y.hideAfter, "auto-close": y.autoClose, "show-arrow": y.showArrow, "aria-label": y.title, effect: y.effect, enterable: y.enterable, "popper-class": unref(l), "popper-style": unref(c), teleported: y.teleported, persistent: y.persistent, "gpu-acceleration": unref(d), "onUpdate:visible": unref(r), onBeforeShow: f, onBeforeHide: g, onShow: p, onHide: u }), { content: withCtx(() => [ y.title ? (openBlock(), createElementBlock("div", { key: 0, class: normalizeClass(unref(s).e("title")), role: "title" }, toDisplayString(y.title), 3)) : createCommentVNode("v-if", true), renderSlot(y.$slots, "default", {}, () => [ createTextVNode(toDisplayString(y.content), 1) ]) ]), default: withCtx(() => [ y.$slots.reference ? renderSlot(y.$slots, "reference", { key: 0 }) : createCommentVNode("v-if", true) ]), _: 3 }, 16, ["trigger", "placement", "disabled", "visible", "transition", "popper-options", "tabindex", "content", "offset", "show-after", "hide-after", "auto-close", "show-arrow", "aria-label", "effect", "enterable", "popper-class", "popper-style", "teleported", "persistent", "gpu-acceleration", "onUpdate:visible"])); } }); var _R = st(SR, [["__file", "popover.vue"]]); var zm = (n, e) => { const t = e.arg || e.value, i = t == null ? void 0 : t.popperRef; i && (i.triggerRef = n); }; var TR = { mounted(n, e) { zm(n, e); }, updated(n, e) { zm(n, e); } }; var ER = "popover"; var CR = iT(TR, ER); var cu = on(_R, { directive: CR }); var my = Symbol("sliderContextKey"); var LR = at({ modelValue: { type: Je([Number, Array]), default: 0 }, id: { type: String, default: void 0 }, min: { type: Number, default: 0 }, max: { type: Number, default: 100 }, step: { type: Number, default: 1 }, showInput: Boolean, showInputControls: { type: Boolean, default: true }, size: Gr, inputSize: Gr, showStops: Boolean, showTooltip: { type: Boolean, default: true }, formatTooltip: { type: Je(Function), default: void 0 }, disabled: Boolean, range: Boolean, vertical: Boolean, height: String, debounce: { type: Number, default: 300 }, rangeStartLabel: { type: String, default: void 0 }, rangeEndLabel: { type: String, default: void 0 }, formatValueText: { type: Je(Function), default: void 0 }, tooltipClass: { type: String, default: void 0 }, placement: { type: String, values: Yo, default: "top" }, marks: { type: Je(Object) }, validateEvent: { type: Boolean, default: true }, ...Yr(["ariaLabel"]) }); var Wu = (n) => yt(n) || Pn(n) && n.every(yt); var RR = { [At]: Wu, [bs]: Wu, [ur]: Wu }; var FR = (n, e, t) => { const i = ref(); return onMounted(async () => { n.range ? (Array.isArray(n.modelValue) ? (e.firstValue = Math.max(n.min, n.modelValue[0]), e.secondValue = Math.min(n.max, n.modelValue[1])) : (e.firstValue = n.min, e.secondValue = n.max), e.oldValue = [e.firstValue, e.secondValue]) : (typeof n.modelValue != "number" || Number.isNaN(n.modelValue) ? e.firstValue = n.min : e.firstValue = Math.min(n.max, Math.max(n.min, n.modelValue)), e.oldValue = e.firstValue), un(window, "resize", t), await nextTick(), t(); }), { sliderWrapper: i }; }; var PR = (n) => computed(() => n.marks ? Object.keys(n.marks).map(Number.parseFloat).sort((t, i) => t - i).filter((t) => t <= n.max && t >= n.min).map((t) => ({ point: t, position: (t - n.min) * 100 / (n.max - n.min), mark: n.marks[t] })) : []); var IR = (n, e, t) => { const { form: i, formItem: r } = Jo(), s = shallowRef(), o = ref(), a = ref(), c = { firstButton: o, secondButton: a }, l = computed(() => n.disabled || (i == null ? void 0 : i.disabled) || false), d = computed(() => Math.min(e.firstValue, e.secondValue)), h6 = computed(() => Math.max(e.firstValue, e.secondValue)), f = computed(() => n.range ? `${100 * (h6.value - d.value) / (n.max - n.min)}%` : `${100 * (e.firstValue - n.min) / (n.max - n.min)}%`), g = computed(() => n.range ? `${100 * (d.value - n.min) / (n.max - n.min)}%` : "0%"), p = computed(() => n.vertical ? { height: n.height } : {}), u = computed(() => n.vertical ? { height: f.value, bottom: g.value } : { width: f.value, left: g.value }), y = () => { s.value && (e.sliderSize = s.value[`client${n.vertical ? "Height" : "Width"}`]); }, v = (_) => { const E = n.min + _ * (n.max - n.min) / 100; if (!n.range) return o; let C; return Math.abs(d.value - E) < Math.abs(h6.value - E) ? C = e.firstValue < e.secondValue ? "firstButton" : "secondButton" : C = e.firstValue > e.secondValue ? "firstButton" : "secondButton", c[C]; }, m = (_) => { const E = v(_); return E.value.setPosition(_), E; }, x = (_) => { e.firstValue = _ ?? n.min, A(n.range ? [d.value, h6.value] : _ ?? n.min); }, w = (_) => { e.secondValue = _, n.range && A([d.value, h6.value]); }, A = (_) => { t(At, _), t(bs, _); }, M = async () => { await nextTick(), t(ur, n.range ? [d.value, h6.value] : n.modelValue); }, R = (_) => { var E, C, P, b, F, D; if (l.value || e.dragging) return; y(); let N = 0; if (n.vertical) { const B = (P = (C = (E = _.touches) == null ? void 0 : E.item(0)) == null ? void 0 : C.clientY) != null ? P : _.clientY; N = (s.value.getBoundingClientRect().bottom - B) / e.sliderSize * 100; } else { const B = (D = (F = (b = _.touches) == null ? void 0 : b.item(0)) == null ? void 0 : F.clientX) != null ? D : _.clientX, U = s.value.getBoundingClientRect().left; N = (B - U) / e.sliderSize * 100; } if (!(N < 0 || N > 100)) return m(N); }; return { elFormItem: r, slider: s, firstButton: o, secondButton: a, sliderDisabled: l, minValue: d, maxValue: h6, runwayStyle: p, barStyle: u, resetSize: y, setPosition: m, emitChange: M, onSliderWrapperPrevent: (_) => { var E, C; ((E = c.firstButton.value) != null && E.dragging || (C = c.secondButton.value) != null && C.dragging) && _.preventDefault(); }, onSliderClick: (_) => { R(_) && M(); }, onSliderDown: async (_) => { const E = R(_); E && (await nextTick(), E.value.onButtonDown(_)); }, onSliderMarkerDown: (_) => { l.value || e.dragging || m(_); }, setFirstValue: x, setSecondValue: w }; }; var { left: OR, down: DR, right: NR, up: BR, home: UR, end: zR, pageUp: VR, pageDown: kR } = Li; var GR = (n, e, t) => { const i = ref(), r = ref(false), s = computed(() => e.value instanceof Function), o = computed(() => s.value && e.value(n.modelValue) || n.modelValue), a = jh(() => { t.value && (r.value = true); }, 50), c = jh(() => { t.value && (r.value = false); }, 50); return { tooltip: i, tooltipVisible: r, formatValue: o, displayTooltip: a, hideTooltip: c }; }; var HR = (n, e, t) => { const { disabled: i, min: r, max: s, step: o, showTooltip: a, precision: c, sliderSize: l, formatTooltip: d, emitChange: h6, resetSize: f, updateDragging: g } = inject(my), { tooltip: p, tooltipVisible: u, formatValue: y, displayTooltip: v, hideTooltip: m } = GR(n, d, a), x = ref(), w = computed(() => `${(n.modelValue - r.value) / (s.value - r.value) * 100}%`), A = computed(() => n.vertical ? { bottom: w.value } : { left: w.value }), M = () => { e.hovering = true, v(); }, R = () => { e.hovering = false, e.dragging || m(); }, L = (G) => { i.value || (G.preventDefault(), D(G), window.addEventListener("mousemove", N), window.addEventListener("touchmove", N), window.addEventListener("mouseup", B), window.addEventListener("touchend", B), window.addEventListener("contextmenu", B), x.value.focus()); }, S = (G) => { i.value || (e.newPosition = Number.parseFloat(w.value) + G / (s.value - r.value) * 100, U(e.newPosition), h6()); }, I = () => { S(-o.value); }, T = () => { S(o.value); }, _ = () => { S(-o.value * 4); }, E = () => { S(o.value * 4); }, C = () => { i.value || (U(0), h6()); }, P = () => { i.value || (U(100), h6()); }, b = (G) => { let Y = true; [OR, DR].includes(G.key) ? I() : [NR, BR].includes(G.key) ? T() : G.key === UR ? C() : G.key === zR ? P() : G.key === kR ? _() : G.key === VR ? E() : Y = false, Y && G.preventDefault(); }, F = (G) => { let Y, te; return G.type.startsWith("touch") ? (te = G.touches[0].clientY, Y = G.touches[0].clientX) : (te = G.clientY, Y = G.clientX), { clientX: Y, clientY: te }; }, D = (G) => { e.dragging = true, e.isClick = true; const { clientX: Y, clientY: te } = F(G); n.vertical ? e.startY = te : e.startX = Y, e.startPosition = Number.parseFloat(w.value), e.newPosition = e.startPosition; }, N = (G) => { if (e.dragging) { e.isClick = false, v(), f(); let Y; const { clientX: te, clientY: ae } = F(G); n.vertical ? (e.currentY = ae, Y = (e.startY - e.currentY) / l.value * 100) : (e.currentX = te, Y = (e.currentX - e.startX) / l.value * 100), e.newPosition = e.startPosition + Y, U(e.newPosition); } }, B = () => { e.dragging && (setTimeout(() => { e.dragging = false, e.hovering || m(), e.isClick || U(e.newPosition), h6(); }, 0), window.removeEventListener("mousemove", N), window.removeEventListener("touchmove", N), window.removeEventListener("mouseup", B), window.removeEventListener("touchend", B), window.removeEventListener("contextmenu", B)); }, U = async (G) => { if (G === null || Number.isNaN(+G)) return; G < 0 ? G = 0 : G > 100 && (G = 100); const Y = 100 / ((s.value - r.value) / o.value); let ae = Math.round(G / Y) * Y * (s.value - r.value) * 0.01 + r.value; ae = Number.parseFloat(ae.toFixed(c.value)), ae !== n.modelValue && t(At, ae), !e.dragging && n.modelValue !== e.oldValue && (e.oldValue = n.modelValue), await nextTick(), e.dragging && v(), p.value.updatePopper(); }; return watch(() => e.dragging, (G) => { g(G); }), un(x, "touchstart", L, { passive: false }), { disabled: i, button: x, tooltip: p, tooltipVisible: u, showTooltip: a, wrapperStyle: A, formatValue: y, handleMouseEnter: M, handleMouseLeave: R, onButtonDown: L, onKeyDown: b, setPosition: U }; }; var WR = (n, e, t, i) => ({ stops: computed(() => { if (!n.showStops || n.min > n.max) return []; if (n.step === 0) return Vt("ElSlider", "step should not be 0."), []; const o = (n.max - n.min) / n.step, a = 100 * n.step / (n.max - n.min), c = Array.from({ length: o - 1 }).map((l, d) => (d + 1) * a); return n.range ? c.filter((l) => l < 100 * (t.value - n.min) / (n.max - n.min) || l > 100 * (i.value - n.min) / (n.max - n.min)) : c.filter((l) => l > 100 * (e.firstValue - n.min) / (n.max - n.min)); }), getStopStyle: (o) => n.vertical ? { bottom: `${o}%` } : { left: `${o}%` } }); var jR = (n, e, t, i, r, s) => { const o = (l) => { r(At, l), r(bs, l); }, a = () => n.range ? ![t.value, i.value].every((l, d) => l === e.oldValue[d]) : n.modelValue !== e.oldValue, c = () => { var l, d; n.min > n.max && Xo("Slider", "min should not be greater than max."); const h6 = n.modelValue; n.range && Array.isArray(h6) ? h6[1] < n.min ? o([n.min, n.min]) : h6[0] > n.max ? o([n.max, n.max]) : h6[0] < n.min ? o([n.min, h6[1]]) : h6[1] > n.max ? o([h6[0], n.max]) : (e.firstValue = h6[0], e.secondValue = h6[1], a() && (n.validateEvent && ((l = s == null ? void 0 : s.validate) == null || l.call(s, "change").catch((f) => Vt(f))), e.oldValue = h6.slice())) : !n.range && typeof h6 == "number" && !Number.isNaN(h6) && (h6 < n.min ? o(n.min) : h6 > n.max ? o(n.max) : (e.firstValue = h6, a() && (n.validateEvent && ((d = s == null ? void 0 : s.validate) == null || d.call(s, "change").catch((f) => Vt(f))), e.oldValue = h6))); }; c(), watch(() => e.dragging, (l) => { l || c(); }), watch(() => n.modelValue, (l, d) => { e.dragging || Array.isArray(l) && Array.isArray(d) && l.every((h6, f) => h6 === d[f]) && e.firstValue === l[0] && e.secondValue === l[1] || c(); }, { deep: true }), watch(() => [n.min, n.max], () => { c(); }); }; var $R = at({ modelValue: { type: Number, default: 0 }, vertical: Boolean, tooltipClass: String, placement: { type: String, values: Yo, default: "top" } }); var ZR = { [At]: (n) => yt(n) }; var XR = defineComponent({ name: "ElSliderButton" }); var YR = defineComponent({ ...XR, props: $R, emits: ZR, setup(n, { expose: e, emit: t }) { const i = n, r = nt("slider"), s = reactive({ hovering: false, dragging: false, isClick: false, startX: 0, currentX: 0, startY: 0, currentY: 0, startPosition: 0, newPosition: 0, oldValue: i.modelValue }), { disabled: o, button: a, tooltip: c, showTooltip: l, tooltipVisible: d, wrapperStyle: h6, formatValue: f, handleMouseEnter: g, handleMouseLeave: p, onButtonDown: u, onKeyDown: y, setPosition: v } = HR(i, s, t), { hovering: m, dragging: x } = toRefs(s); return e({ onButtonDown: u, onKeyDown: y, setPosition: v, hovering: m, dragging: x }), (w, A) => (openBlock(), createElementBlock("div", { ref_key: "button", ref: a, class: normalizeClass([unref(r).e("button-wrapper"), { hover: unref(m), dragging: unref(x) }]), style: normalizeStyle(unref(h6)), tabindex: unref(o) ? -1 : 0, onMouseenter: unref(g), onMouseleave: unref(p), onMousedown: unref(u), onFocus: unref(g), onBlur: unref(p), onKeydown: unref(y) }, [ createVNode(unref(pf), { ref_key: "tooltip", ref: c, visible: unref(d), placement: w.placement, "fallback-placements": ["top", "bottom", "right", "left"], "stop-popper-mouse-event": false, "popper-class": w.tooltipClass, disabled: !unref(l), persistent: "" }, { content: withCtx(() => [ createBaseVNode("span", null, toDisplayString(unref(f)), 1) ]), default: withCtx(() => [ createBaseVNode("div", { class: normalizeClass([unref(r).e("button"), { hover: unref(m), dragging: unref(x) }]) }, null, 2) ]), _: 1 }, 8, ["visible", "placement", "popper-class", "disabled"]) ], 46, ["tabindex", "onMouseenter", "onMouseleave", "onMousedown", "onFocus", "onBlur", "onKeydown"])); } }); var Vm = st(YR, [["__file", "button.vue"]]); var JR = at({ mark: { type: Je([String, Object]), default: void 0 } }); var KR = defineComponent({ name: "ElSliderMarker", props: JR, setup(n) { const e = nt("slider"), t = computed(() => vn(n.mark) ? n.mark : n.mark.label), i = computed(() => vn(n.mark) ? void 0 : n.mark.style); return () => h("div", { class: e.e("marks-text"), style: i.value }, t.value); } }); var qR = defineComponent({ name: "ElSlider" }); var QR = defineComponent({ ...qR, props: LR, emits: RR, setup(n, { expose: e, emit: t }) { const i = n, r = nt("slider"), { t: s } = iu(), o = reactive({ firstValue: 0, secondValue: 0, oldValue: 0, dragging: false, sliderSize: 1 }), { elFormItem: a, slider: c, firstButton: l, secondButton: d, sliderDisabled: h6, minValue: f, maxValue: g, runwayStyle: p, barStyle: u, resetSize: y, emitChange: v, onSliderWrapperPrevent: m, onSliderClick: x, onSliderDown: w, onSliderMarkerDown: A, setFirstValue: M, setSecondValue: R } = IR(i, o, t), { stops: L, getStopStyle: S } = WR(i, o, f, g), { inputId: I, isLabeledByFormItem: T } = su(i, { formItemContext: a }), _ = Ns(), E = computed(() => i.inputSize || _.value), C = computed(() => i.ariaLabel || s("el.slider.defaultLabel", { min: i.min, max: i.max })), P = computed(() => i.range ? i.rangeStartLabel || s("el.slider.defaultRangeStartLabel") : C.value), b = computed(() => i.formatValueText ? i.formatValueText(Y.value) : `${Y.value}`), F = computed(() => i.rangeEndLabel || s("el.slider.defaultRangeEndLabel")), D = computed(() => i.formatValueText ? i.formatValueText(te.value) : `${te.value}`), N = computed(() => [ r.b(), r.m(_.value), r.is("vertical", i.vertical), { [r.m("with-input")]: i.showInput } ]), B = PR(i); jR(i, o, f, g, t, a); const U = computed(() => { const le = [i.min, i.max, i.step].map((W) => { const $ = `${W}`.split(".")[1]; return $ ? $.length : 0; }); return Math.max.apply(null, le); }), { sliderWrapper: G } = FR(i, o, y), { firstValue: Y, secondValue: te, sliderSize: ae } = toRefs(o), ie = (le) => { o.dragging = le; }; return un(G, "touchstart", m, { passive: false }), un(G, "touchmove", m, { passive: false }), provide(my, { ...toRefs(i), sliderSize: ae, disabled: h6, precision: U, emitChange: v, resetSize: y, updateDragging: ie }), e({ onSliderClick: x }), (le, W) => { var $, j; return openBlock(), createElementBlock("div", { id: le.range ? unref(I) : void 0, ref_key: "sliderWrapper", ref: G, class: normalizeClass(unref(N)), role: le.range ? "group" : void 0, "aria-label": le.range && !unref(T) ? unref(C) : void 0, "aria-labelledby": le.range && unref(T) ? ($ = unref(a)) == null ? void 0 : $.labelId : void 0 }, [ createBaseVNode("div", { ref_key: "slider", ref: c, class: normalizeClass([ unref(r).e("runway"), { "show-input": le.showInput && !le.range }, unref(r).is("disabled", unref(h6)) ]), style: normalizeStyle(unref(p)), onMousedown: unref(w), onTouchstartPassive: unref(w) }, [ createBaseVNode("div", { class: normalizeClass(unref(r).e("bar")), style: normalizeStyle(unref(u)) }, null, 6), createVNode(Vm, { id: le.range ? void 0 : unref(I), ref_key: "firstButton", ref: l, "model-value": unref(Y), vertical: le.vertical, "tooltip-class": le.tooltipClass, placement: le.placement, role: "slider", "aria-label": le.range || !unref(T) ? unref(P) : void 0, "aria-labelledby": !le.range && unref(T) ? (j = unref(a)) == null ? void 0 : j.labelId : void 0, "aria-valuemin": le.min, "aria-valuemax": le.range ? unref(te) : le.max, "aria-valuenow": unref(Y), "aria-valuetext": unref(b), "aria-orientation": le.vertical ? "vertical" : "horizontal", "aria-disabled": unref(h6), "onUpdate:modelValue": unref(M) }, null, 8, ["id", "model-value", "vertical", "tooltip-class", "placement", "aria-label", "aria-labelledby", "aria-valuemin", "aria-valuemax", "aria-valuenow", "aria-valuetext", "aria-orientation", "aria-disabled", "onUpdate:modelValue"]), le.range ? (openBlock(), createBlock(Vm, { key: 0, ref_key: "secondButton", ref: d, "model-value": unref(te), vertical: le.vertical, "tooltip-class": le.tooltipClass, placement: le.placement, role: "slider", "aria-label": unref(F), "aria-valuemin": unref(Y), "aria-valuemax": le.max, "aria-valuenow": unref(te), "aria-valuetext": unref(D), "aria-orientation": le.vertical ? "vertical" : "horizontal", "aria-disabled": unref(h6), "onUpdate:modelValue": unref(R) }, null, 8, ["model-value", "vertical", "tooltip-class", "placement", "aria-label", "aria-valuemin", "aria-valuemax", "aria-valuenow", "aria-valuetext", "aria-orientation", "aria-disabled", "onUpdate:modelValue"])) : createCommentVNode("v-if", true), le.showStops ? (openBlock(), createElementBlock("div", { key: 1 }, [ (openBlock(true), createElementBlock(Fragment, null, renderList(unref(L), (re, V) => (openBlock(), createElementBlock("div", { key: V, class: normalizeClass(unref(r).e("stop")), style: normalizeStyle(unref(S)(re)) }, null, 6))), 128)) ])) : createCommentVNode("v-if", true), unref(B).length > 0 ? (openBlock(), createElementBlock(Fragment, { key: 2 }, [ createBaseVNode("div", null, [ (openBlock(true), createElementBlock(Fragment, null, renderList(unref(B), (re, V) => (openBlock(), createElementBlock("div", { key: V, style: normalizeStyle(unref(S)(re.position)), class: normalizeClass([unref(r).e("stop"), unref(r).e("marks-stop")]) }, null, 6))), 128)) ]), createBaseVNode("div", { class: normalizeClass(unref(r).e("marks")) }, [ (openBlock(true), createElementBlock(Fragment, null, renderList(unref(B), (re, V) => (openBlock(), createBlock(unref(KR), { key: V, mark: re.mark, style: normalizeStyle(unref(S)(re.position)), onMousedown: withModifiers((H) => unref(A)(re.position), ["stop"]) }, null, 8, ["mark", "style", "onMousedown"]))), 128)) ], 2) ], 64)) : createCommentVNode("v-if", true) ], 46, ["onMousedown", "onTouchstartPassive"]), le.showInput && !le.range ? (openBlock(), createBlock(unref(dr), { key: 0, ref: "input", "model-value": unref(Y), class: normalizeClass(unref(r).e("input")), step: le.step, disabled: unref(h6), controls: le.showInputControls, min: le.min, max: le.max, precision: unref(U), debounce: le.debounce, size: unref(E), "onUpdate:modelValue": unref(M), onChange: unref(v) }, null, 8, ["model-value", "class", "step", "disabled", "controls", "min", "max", "precision", "debounce", "size", "onUpdate:modelValue", "onChange"])) : createCommentVNode("v-if", true) ], 10, ["id", "role", "aria-label", "aria-labelledby"]); }; } }); var e3 = st(QR, [["__file", "slider.vue"]]); var ti = on(e3); var uu = Symbol("tabsRootContextKey"); var t3 = at({ tabs: { type: Je(Array), default: () => Ki([]) } }); var gy = "ElTabBar"; var n3 = defineComponent({ name: gy }); var i3 = defineComponent({ ...n3, props: t3, setup(n, { expose: e }) { const t = n, i = getCurrentInstance(), r = inject(uu); r || Xo(gy, ""); const s = nt("tabs"), o = ref(), a = ref(), c = () => { let g = 0, p = 0; const u = ["top", "bottom"].includes(r.props.tabPosition) ? "width" : "height", y = u === "width" ? "x" : "y", v = y === "x" ? "left" : "top"; return t.tabs.every((m) => { var x, w; const A = (w = (x = i.parent) == null ? void 0 : x.refs) == null ? void 0 : w[`tab-${m.uid}`]; if (!A) return false; if (!m.active) return true; g = A[`offset${Rr(v)}`], p = A[`client${Rr(u)}`]; const M = window.getComputedStyle(A); return u === "width" && (p -= Number.parseFloat(M.paddingLeft) + Number.parseFloat(M.paddingRight), g += Number.parseFloat(M.paddingLeft)), false; }), { [u]: `${p}px`, transform: `translate${Rr(y)}(${g}px)` }; }, l = () => a.value = c(), d = [], h6 = () => { var g; d.forEach((u) => u.stop()), d.length = 0; const p = (g = i.parent) == null ? void 0 : g.refs; if (p) { for (const u in p) if (u.startsWith("tab-")) { const y = p[u]; y && d.push(Yn(y, l)); } } }; watch(() => t.tabs, async () => { await nextTick(), l(), h6(); }, { immediate: true }); const f = Yn(o, () => l()); return onBeforeUnmount(() => { d.forEach((g) => g.stop()), d.length = 0, f.stop(); }), e({ ref: o, update: l }), (g, p) => (openBlock(), createElementBlock("div", { ref_key: "barRef", ref: o, class: normalizeClass([unref(s).e("active-bar"), unref(s).is(unref(r).props.tabPosition)]), style: normalizeStyle(a.value) }, null, 6)); } }); var r3 = st(i3, [["__file", "tab-bar.vue"]]); var s3 = at({ panes: { type: Je(Array), default: () => Ki([]) }, currentName: { type: [String, Number], default: "" }, editable: Boolean, type: { type: String, values: ["card", "border-card", ""], default: "" }, stretch: Boolean }); var o3 = { tabClick: (n, e, t) => t instanceof Event, tabRemove: (n, e) => e instanceof Event }; var km = "ElTabNav"; var a3 = defineComponent({ name: km, props: s3, emits: o3, setup(n, { expose: e, emit: t }) { const i = inject(uu); i || Xo(km, ""); const r = nt("tabs"), s = bw(), o = Pw(), a = ref(), c = ref(), l = ref(), d = ref(), h6 = ref(false), f = ref(0), g = ref(false), p = ref(true), u = computed(() => ["top", "bottom"].includes(i.props.tabPosition) ? "width" : "height"), y = computed(() => ({ transform: `translate${u.value === "width" ? "X" : "Y"}(-${f.value}px)` })), v = () => { if (!a.value) return; const L = a.value[`offset${Rr(u.value)}`], S = f.value; if (!S) return; const I = S > L ? S - L : 0; f.value = I; }, m = () => { if (!a.value || !c.value) return; const L = c.value[`offset${Rr(u.value)}`], S = a.value[`offset${Rr(u.value)}`], I = f.value; if (L - I <= S) return; const T = L - I > S * 2 ? I + S : L - S; f.value = T; }, x = async () => { const L = c.value; if (!h6.value || !l.value || !a.value || !L) return; await nextTick(); const S = l.value.querySelector(".is-active"); if (!S) return; const I = a.value, T = ["top", "bottom"].includes(i.props.tabPosition), _ = S.getBoundingClientRect(), E = I.getBoundingClientRect(), C = T ? L.offsetWidth - E.width : L.offsetHeight - E.height, P = f.value; let b = P; T ? (_.left < E.left && (b = P - (E.left - _.left)), _.right > E.right && (b = P + _.right - E.right)) : (_.top < E.top && (b = P - (E.top - _.top)), _.bottom > E.bottom && (b = P + (_.bottom - E.bottom))), b = Math.max(b, 0), f.value = Math.min(b, C); }, w = () => { var L; if (!c.value || !a.value) return; n.stretch && ((L = d.value) == null || L.update()); const S = c.value[`offset${Rr(u.value)}`], I = a.value[`offset${Rr(u.value)}`], T = f.value; I < S ? (h6.value = h6.value || {}, h6.value.prev = T, h6.value.next = T + I < S, S - T < I && (f.value = S - I)) : (h6.value = false, T > 0 && (f.value = 0)); }, A = (L) => { const S = L.code, { up: I, down: T, left: _, right: E } = Li; if (![I, T, _, E].includes(S)) return; const C = Array.from(L.currentTarget.querySelectorAll("[role=tab]:not(.is-disabled)")), P = C.indexOf(L.target); let b; S === _ || S === I ? P === 0 ? b = C.length - 1 : b = P - 1 : P < C.length - 1 ? b = P + 1 : b = 0, C[b].focus({ preventScroll: true }), C[b].click(), M(); }, M = () => { p.value && (g.value = true); }, R = () => g.value = false; return watch(s, (L) => { L === "hidden" ? p.value = false : L === "visible" && setTimeout(() => p.value = true, 50); }), watch(o, (L) => { L ? setTimeout(() => p.value = true, 50) : p.value = false; }), Yn(l, w), onMounted(() => setTimeout(() => x(), 0)), onUpdated(() => w()), e({ scrollToActiveTab: x, removeFocus: R }), () => { const L = h6.value ? [createVNode("span", { class: [r.e("nav-prev"), r.is("disabled", !h6.value.prev)], onClick: v }, [createVNode(It, null, { default: () => [createVNode(zr, null, null)] })]), createVNode("span", { class: [r.e("nav-next"), r.is("disabled", !h6.value.next)], onClick: m }, [createVNode(It, null, { default: () => [createVNode(Vr, null, null)] })])] : null, S = n.panes.map((I, T) => { var _, E, C, P; const b = I.uid, F = I.props.disabled, D = (E = (_ = I.props.name) != null ? _ : I.index) != null ? E : `${T}`, N = !F && (I.isClosable || n.editable); I.index = `${T}`; const B = N ? createVNode(It, { class: "is-icon-close", onClick: (Y) => t("tabRemove", I, Y) }, { default: () => [createVNode(Zh, null, null)] }) : null, U = ((P = (C = I.slots).label) == null ? void 0 : P.call(C)) || I.props.label, G = !F && I.active ? 0 : -1; return createVNode("div", { ref: `tab-${b}`, class: [r.e("item"), r.is(i.props.tabPosition), r.is("active", I.active), r.is("disabled", F), r.is("closable", N), r.is("focus", g.value)], id: `tab-${D}`, key: `tab-${b}`, "aria-controls": `pane-${D}`, role: "tab", "aria-selected": I.active, tabindex: G, onFocus: () => M(), onBlur: () => R(), onClick: (Y) => { R(), t("tabClick", I, D, Y); }, onKeydown: (Y) => { N && (Y.code === Li.delete || Y.code === Li.backspace) && t("tabRemove", I, Y); } }, [U, B]); }); return createVNode("div", { ref: l, class: [r.e("nav-wrap"), r.is("scrollable", !!h6.value), r.is(i.props.tabPosition)] }, [L, createVNode("div", { class: r.e("nav-scroll"), ref: a }, [createVNode("div", { class: [r.e("nav"), r.is(i.props.tabPosition), r.is("stretch", n.stretch && ["top", "bottom"].includes(i.props.tabPosition))], ref: c, style: y.value, role: "tablist", onKeydown: A }, [n.type ? null : createVNode(r3, { ref: d, tabs: [...n.panes] }, null), S])])]); }; } }); var l3 = at({ type: { type: String, values: ["card", "border-card", ""], default: "" }, closable: Boolean, addable: Boolean, modelValue: { type: [String, Number] }, editable: Boolean, tabPosition: { type: String, values: ["top", "right", "bottom", "left"], default: "top" }, beforeLeave: { type: Je(Function), default: () => true }, stretch: Boolean }); var ju = (n) => vn(n) || yt(n); var c3 = { [At]: (n) => ju(n), tabClick: (n, e) => e instanceof Event, tabChange: (n) => ju(n), edit: (n, e) => ["remove", "add"].includes(e), tabRemove: (n) => ju(n), tabAdd: () => true }; var u3 = defineComponent({ name: "ElTabs", props: l3, emits: c3, setup(n, { emit: e, slots: t, expose: i }) { var r; const s = nt("tabs"), o = computed(() => ["left", "right"].includes(n.tabPosition)), { children: a, addChild: c, removeChild: l } = RE(getCurrentInstance(), "ElTabPane"), d = ref(), h6 = ref((r = n.modelValue) != null ? r : "0"), f = async (v, m = false) => { var x, w, A; if (!(h6.value === v || di(v))) try { await ((x = n.beforeLeave) == null ? void 0 : x.call(n, v, h6.value)) !== false && (h6.value = v, m && (e(At, v), e("tabChange", v)), (A = (w = d.value) == null ? void 0 : w.removeFocus) == null || A.call(w)); } catch { } }, g = (v, m, x) => { v.props.disabled || (f(m, true), e("tabClick", v, x)); }, p = (v, m) => { v.props.disabled || di(v.props.name) || (m.stopPropagation(), e("edit", v.props.name, "remove"), e("tabRemove", v.props.name)); }, u = () => { e("edit", void 0, "add"), e("tabAdd"); }; watch(() => n.modelValue, (v) => f(v)), watch(h6, async () => { var v; await nextTick(), (v = d.value) == null || v.scrollToActiveTab(); }), provide(uu, { props: n, currentName: h6, registerPane: (v) => { a.value.push(v); }, sortPane: c, unregisterPane: l }), i({ currentName: h6 }); const y = ({ render: v }) => v(); return () => { const v = t["add-icon"], m = n.editable || n.addable ? createVNode("div", { class: [s.e("new-tab"), o.value && s.e("new-tab-vertical")], tabindex: "0", onClick: u, onKeydown: (A) => { A.code === Li.enter && u(); } }, [v ? renderSlot(t, "add-icon") : createVNode(It, { class: s.is("icon-plus") }, { default: () => [createVNode(tu, null, null)] })]) : null, x = createVNode("div", { class: [s.e("header"), o.value && s.e("header-vertical"), s.is(n.tabPosition)] }, [createVNode(y, { render: () => { const A = a.value.some((M) => M.slots.label); return createVNode(a3, { ref: d, currentName: h6.value, editable: n.editable, type: n.type, panes: a.value, stretch: n.stretch, onTabClick: g, onTabRemove: p }, { $stable: !A }); } }, null), m]), w = createVNode("div", { class: s.e("content") }, [renderSlot(t, "default")]); return createVNode("div", { class: [s.b(), s.m(n.tabPosition), { [s.m("card")]: n.type === "card", [s.m("border-card")]: n.type === "border-card" }] }, [w, x]); }; } }); var h3 = at({ label: { type: String, default: "" }, name: { type: [String, Number] }, closable: Boolean, disabled: Boolean, lazy: Boolean }); var vy = "ElTabPane"; var d3 = defineComponent({ name: vy }); var f3 = defineComponent({ ...d3, props: h3, setup(n) { const e = n, t = getCurrentInstance(), i = useSlots(), r = inject(uu); r || Xo(vy, "usage: "); const s = nt("tab-pane"), o = ref(), a = computed(() => e.closable || r.props.closable), c = Mp(() => { var g; return r.currentName.value === ((g = e.name) != null ? g : o.value); }), l = ref(c.value), d = computed(() => { var g; return (g = e.name) != null ? g : o.value; }), h6 = Mp(() => !e.lazy || l.value || c.value); watch(c, (g) => { g && (l.value = true); }); const f = reactive({ uid: t.uid, slots: i, props: e, paneName: d, active: c, index: o, isClosable: a }); return r.registerPane(f), onMounted(() => { r.sortPane(f); }), onUnmounted(() => { r.unregisterPane(f.uid); }), (g, p) => unref(h6) ? withDirectives((openBlock(), createElementBlock("div", { key: 0, id: `pane-${unref(d)}`, class: normalizeClass(unref(s).b()), role: "tabpanel", "aria-hidden": !unref(c), "aria-labelledby": `tab-${unref(d)}` }, [ renderSlot(g.$slots, "default") ], 10, ["id", "aria-hidden", "aria-labelledby"])), [ [vShow, unref(c)] ]) : createCommentVNode("v-if", true); } }); var yy = st(f3, [["__file", "tab-pane.vue"]]); var by = on(u3, { TabPane: yy }); var xy = vi(yy); function p3(n) { let e; const t = ref(false), i = reactive({ ...n, originalPosition: "", originalOverflow: "", visible: false }); function r(f) { i.text = f; } function s() { const f = i.parent, g = h6.ns; if (!f.vLoadingAddClassList) { let p = f.getAttribute("loading-number"); p = Number.parseInt(p) - 1, p ? f.setAttribute("loading-number", p.toString()) : (Oc(f, g.bm("parent", "relative")), f.removeAttribute("loading-number")), Oc(f, g.bm("parent", "hidden")); } o(), d.unmount(); } function o() { var f, g; (g = (f = h6.$el) == null ? void 0 : f.parentNode) == null || g.removeChild(h6.$el); } function a() { var f; n.beforeClose && !n.beforeClose() || (t.value = true, clearTimeout(e), e = setTimeout(c, 400), i.visible = false, (f = n.closed) == null || f.call(n)); } function c() { if (!t.value) return; const f = i.parent; t.value = false, f.vLoadingAddClassList = void 0, s(); } const l = defineComponent({ name: "ElLoading", setup(f, { expose: g }) { const { ns: p, zIndex: u } = UE("loading"); return g({ ns: p, zIndex: u }), () => { const y = i.spinner || i.svg, v = h("svg", { class: "circular", viewBox: i.svgViewBox ? i.svgViewBox : "0 0 50 50", ...y ? { innerHTML: y } : {} }, [ h("circle", { class: "path", cx: "25", cy: "25", r: "20", fill: "none" }) ]), m = i.text ? h("p", { class: p.b("text") }, [i.text]) : void 0; return h(Transition, { name: p.b("fade"), onAfterLeave: c }, { default: withCtx(() => [ withDirectives(createVNode("div", { style: { backgroundColor: i.background || "" }, class: [ p.b("mask"), i.customClass, i.fullscreen ? "is-fullscreen" : "" ] }, [ h("div", { class: p.b("spinner") }, [v, m]) ]), [[vShow, i.visible]]) ]) }); }; } }), d = createApp(l), h6 = d.mount(document.createElement("div")); return { ...toRefs(i), setText: r, removeElLoadingChild: o, close: a, handleAfterLeave: c, vm: h6, get $el() { return h6.$el; } }; } var Pl; var ed = function(n = {}) { if (!en) return; const e = m3(n); if (e.fullscreen && Pl) return Pl; const t = p3({ ...e, closed: () => { var r; (r = e.closed) == null || r.call(e), e.fullscreen && (Pl = void 0); } }); g3(e, e.parent, t), Gm(e, e.parent, t), e.parent.vLoadingAddClassList = () => Gm(e, e.parent, t); let i = e.parent.getAttribute("loading-number"); return i ? i = `${Number.parseInt(i) + 1}` : i = "1", e.parent.setAttribute("loading-number", i), e.parent.appendChild(t.$el), nextTick(() => t.visible.value = e.visible), e.fullscreen && (Pl = t), t; }; var m3 = (n) => { var e, t, i, r; let s; return vn(n.target) ? s = (e = document.querySelector(n.target)) != null ? e : document.body : s = n.target || document.body, { parent: s === document.body || n.body ? document.body : s, background: n.background || "", svg: n.svg || "", svgViewBox: n.svgViewBox || "", spinner: n.spinner || false, text: n.text || "", fullscreen: s === document.body && ((t = n.fullscreen) != null ? t : true), lock: (i = n.lock) != null ? i : false, customClass: n.customClass || "", visible: (r = n.visible) != null ? r : true, beforeClose: n.beforeClose, closed: n.closed, target: s }; }; var g3 = async (n, e, t) => { const { nextZIndex: i } = t.vm.zIndex || t.vm._.exposed.zIndex, r = {}; if (n.fullscreen) t.originalPosition.value = ca(document.body, "position"), t.originalOverflow.value = ca(document.body, "overflow"), r.zIndex = i(); else if (n.parent === document.body) { t.originalPosition.value = ca(document.body, "position"), await nextTick(); for (const s of ["top", "left"]) { const o = s === "top" ? "scrollTop" : "scrollLeft"; r[s] = `${n.target.getBoundingClientRect()[s] + document.body[o] + document.documentElement[o] - Number.parseInt(ca(document.body, `margin-${s}`), 10)}px`; } for (const s of ["height", "width"]) r[s] = `${n.target.getBoundingClientRect()[s]}px`; } else t.originalPosition.value = ca(e, "position"); for (const [s, o] of Object.entries(r)) t.$el.style[s] = o; }; var Gm = (n, e, t) => { const i = t.vm.ns || t.vm._.exposed.ns; ["absolute", "fixed", "sticky"].includes(t.originalPosition.value) ? Oc(e, i.bm("parent", "relative")) : sm(e, i.bm("parent", "relative")), n.fullscreen && n.lock ? sm(e, i.bm("parent", "hidden")) : Oc(e, i.bm("parent", "hidden")); }; var Ec = Symbol("ElLoading"); var Hm = (n, e) => { var t, i, r, s; const o = e.instance, a = (f) => Tn(e.value) ? e.value[f] : void 0, c = (f) => { const g = vn(f) && (o == null ? void 0 : o[f]) || f; return g && ref(g); }, l = (f) => c(a(f) || n.getAttribute(`element-loading-${Vw(f)}`)), d = (t = a("fullscreen")) != null ? t : e.modifiers.fullscreen, h6 = { text: l("text"), svg: l("svg"), svgViewBox: l("svgViewBox"), spinner: l("spinner"), background: l("background"), customClass: l("customClass"), fullscreen: d, target: (i = a("target")) != null ? i : d ? void 0 : n, body: (r = a("body")) != null ? r : e.modifiers.body, lock: (s = a("lock")) != null ? s : e.modifiers.lock }; n[Ec] = { options: h6, instance: ed(h6) }; }; var v3 = (n, e) => { for (const t of Object.keys(e)) isRef(e[t]) && (e[t].value = n[t]); }; var td = { mounted(n, e) { e.value && Hm(n, e); }, updated(n, e) { const t = n[Ec]; e.oldValue !== e.value && (e.value && !e.oldValue ? Hm(n, e) : e.value && e.oldValue ? Tn(e.value) && v3(e.value, t.options) : t == null || t.instance.close()); }, unmounted(n) { var e; (e = n[Ec]) == null || e.instance.close(), n[Ec] = null; } }; var y3 = { install(n) { n.directive("loading", td), n.config.globalProperties.$loading = ed; }, directive: td, service: ed }; var My = { exports: {} }; var Wm = {}; var jm; function b3() { return jm || (jm = 1, function(n) { var e = function() { try { return !!Symbol.iterator; } catch { return false; } }, t = e(), i = function(l) { var d = { next: function() { var h6 = l.shift(); return { done: h6 === void 0, value: h6 }; } }; return t && (d[Symbol.iterator] = function() { return d; }), d; }, r = function(l) { return encodeURIComponent(l).replace(/%20/g, "+"); }, s = function(l) { return decodeURIComponent(String(l).replace(/\+/g, " ")); }, o = function() { var l = function(h6) { Object.defineProperty(this, "_entries", { writable: true, value: {} }); var f = typeof h6; if (f !== "undefined") if (f === "string") h6 !== "" && this._fromString(h6); else if (h6 instanceof l) { var g = this; h6.forEach(function(v, m) { g.append(m, v); }); } else if (h6 !== null && f === "object") if (Object.prototype.toString.call(h6) === "[object Array]") for (var p = 0; p < h6.length; p++) { var u = h6[p]; if (Object.prototype.toString.call(u) === "[object Array]" || u.length !== 2) this.append(u[0], u[1]); else throw new TypeError("Expected [string, any] as entry at index " + p + " of URLSearchParams's input"); } else for (var y in h6) h6.hasOwnProperty(y) && this.append(y, h6[y]); else throw new TypeError("Unsupported input's type for URLSearchParams"); }, d = l.prototype; d.append = function(h6, f) { h6 in this._entries ? this._entries[h6].push(String(f)) : this._entries[h6] = [String(f)]; }, d.delete = function(h6) { delete this._entries[h6]; }, d.get = function(h6) { return h6 in this._entries ? this._entries[h6][0] : null; }, d.getAll = function(h6) { return h6 in this._entries ? this._entries[h6].slice(0) : []; }, d.has = function(h6) { return h6 in this._entries; }, d.set = function(h6, f) { this._entries[h6] = [String(f)]; }, d.forEach = function(h6, f) { var g; for (var p in this._entries) if (this._entries.hasOwnProperty(p)) { g = this._entries[p]; for (var u = 0; u < g.length; u++) h6.call(f, g[u], p, this); } }, d.keys = function() { var h6 = []; return this.forEach(function(f, g) { h6.push(g); }), i(h6); }, d.values = function() { var h6 = []; return this.forEach(function(f) { h6.push(f); }), i(h6); }, d.entries = function() { var h6 = []; return this.forEach(function(f, g) { h6.push([g, f]); }), i(h6); }, t && (d[Symbol.iterator] = d.entries), d.toString = function() { var h6 = []; return this.forEach(function(f, g) { h6.push(r(g) + "=" + r(f)); }), h6.join("&"); }, n.URLSearchParams = l; }, a = function() { try { var l = n.URLSearchParams; return new l("?a=1").toString() === "a=1" && typeof l.prototype.set == "function" && typeof l.prototype.entries == "function"; } catch { return false; } }; a() || o(); var c = n.URLSearchParams.prototype; typeof c.sort != "function" && (c.sort = function() { var l = this, d = []; this.forEach(function(f, g) { d.push([g, f]), l._entries || l.delete(g); }), d.sort(function(f, g) { return f[0] < g[0] ? -1 : f[0] > g[0] ? 1 : 0; }), l._entries && (l._entries = {}); for (var h6 = 0; h6 < d.length; h6++) this.append(d[h6][0], d[h6][1]); }), typeof c._fromString != "function" && Object.defineProperty(c, "_fromString", { enumerable: false, configurable: false, writable: false, value: function(l) { if (this._entries) this._entries = {}; else { var d = []; this.forEach(function(p, u) { d.push(u); }); for (var h6 = 0; h6 < d.length; h6++) this.delete(d[h6]); } l = l.replace(/^\?/, ""); for (var f = l.split("&"), g, h6 = 0; h6 < f.length; h6++) g = f[h6].split("="), this.append( s(g[0]), g.length > 1 ? s(g[1]) : "" ); } }); }( typeof Lr < "u" ? Lr : typeof window < "u" ? window : typeof self < "u" ? self : Lr ), function(n) { var e = function() { try { var r = new n.URL("b", "http://a"); return r.pathname = "c d", r.href === "http://a/c%20d" && r.searchParams; } catch { return false; } }, t = function() { var r = n.URL, s = function(c, l) { typeof c != "string" && (c = String(c)), l && typeof l != "string" && (l = String(l)); var d = document, h6; if (l && (n.location === void 0 || l !== n.location.href)) { l = l.toLowerCase(), d = document.implementation.createHTMLDocument(""), h6 = d.createElement("base"), h6.href = l, d.head.appendChild(h6); try { if (h6.href.indexOf(l) !== 0) throw new Error(h6.href); } catch (x) { throw new Error("URL unable to set base " + l + " due to " + x); } } var f = d.createElement("a"); f.href = c, h6 && (d.body.appendChild(f), f.href = f.href); var g = d.createElement("input"); if (g.type = "url", g.value = c, f.protocol === ":" || !/:/.test(f.href) || !g.checkValidity() && !l) throw new TypeError("Invalid URL"); Object.defineProperty(this, "_anchorElement", { value: f }); var p = new n.URLSearchParams(this.search), u = true, y = true, v = this; ["append", "delete", "set"].forEach(function(x) { var w = p[x]; p[x] = function() { w.apply(p, arguments), u && (y = false, v.search = p.toString(), y = true); }; }), Object.defineProperty(this, "searchParams", { value: p, enumerable: true }); var m = void 0; Object.defineProperty(this, "_updateSearchParams", { enumerable: false, configurable: false, writable: false, value: function() { this.search !== m && (m = this.search, y && (u = false, this.searchParams._fromString(this.search), u = true)); } }); }, o = s.prototype, a = function(c) { Object.defineProperty(o, c, { get: function() { return this._anchorElement[c]; }, set: function(l) { this._anchorElement[c] = l; }, enumerable: true }); }; ["hash", "host", "hostname", "port", "protocol"].forEach(function(c) { a(c); }), Object.defineProperty(o, "search", { get: function() { return this._anchorElement.search; }, set: function(c) { this._anchorElement.search = c, this._updateSearchParams(); }, enumerable: true }), Object.defineProperties(o, { toString: { get: function() { var c = this; return function() { return c.href; }; } }, href: { get: function() { return this._anchorElement.href.replace(/\?$/, ""); }, set: function(c) { this._anchorElement.href = c, this._updateSearchParams(); }, enumerable: true }, pathname: { get: function() { return this._anchorElement.pathname.replace(/(^\/?)/, "/"); }, set: function(c) { this._anchorElement.pathname = c; }, enumerable: true }, origin: { get: function() { var c = { "http:": 80, "https:": 443, "ftp:": 21 }[this._anchorElement.protocol], l = this._anchorElement.port != c && this._anchorElement.port !== ""; return this._anchorElement.protocol + "//" + this._anchorElement.hostname + (l ? ":" + this._anchorElement.port : ""); }, enumerable: true }, password: { // TODO get: function() { return ""; }, set: function(c) { }, enumerable: true }, username: { // TODO get: function() { return ""; }, set: function(c) { }, enumerable: true } }), s.createObjectURL = function(c) { return r.createObjectURL.apply(r, arguments); }, s.revokeObjectURL = function(c) { return r.revokeObjectURL.apply(r, arguments); }, n.URL = s; }; if (e() || t(), n.location !== void 0 && !("origin" in n.location)) { var i = function() { return n.location.protocol + "//" + n.location.hostname + (n.location.port ? ":" + n.location.port : ""); }; try { Object.defineProperty(n.location, "origin", { get: i, enumerable: true }); } catch { setInterval(function() { n.location.origin = i(); }, 100); } } }( typeof Lr < "u" ? Lr : typeof window < "u" ? window : typeof self < "u" ? self : Lr )), Wm; } var gf = "130"; var x3 = { LEFT: 0, MIDDLE: 1, RIGHT: 2, ROTATE: 0, DOLLY: 1, PAN: 2 }; var M3 = { ROTATE: 0, PAN: 1, DOLLY_PAN: 2, DOLLY_ROTATE: 3 }; var wy = 0; var nd = 1; var Ay = 2; var w3 = 3; var A3 = 0; var vf = 1; var Sy = 2; var po = 3; var Hr = 0; var jt = 1; var Wr = 2; var yf = 1; var S3 = 2; var tr = 0; var vo = 1; var id = 2; var rd = 3; var sd = 4; var _y = 5; var ps = 100; var Ty = 101; var Ey = 102; var od = 103; var ad = 104; var Cy = 200; var Ly = 201; var Ry = 202; var Fy = 203; var bf = 204; var xf = 205; var Py = 206; var Iy = 207; var Oy = 208; var Dy = 209; var Ny = 210; var By = 0; var Uy = 1; var zy = 2; var Vc = 3; var Vy = 4; var ky = 5; var Gy = 6; var Hy = 7; var al = 0; var Wy = 1; var jy = 2; var Ir = 0; var $y = 1; var Zy = 2; var Xy = 3; var Yy = 4; var Jy = 5; var hu = 300; var ll = 301; var cl = 302; var kc = 303; var Gc = 304; var ea = 306; var ul = 307; var jr = 1e3; var hn2 = 1001; var Eo = 1002; var $t = 1003; var ka = 1004; var _3 = 1004; var Ga = 1005; var T3 = 1005; var zt = 1006; var du = 1007; var E3 = 1007; var fr = 1008; var C3 = 1008; var Ts = 1009; var Ky = 1010; var qy = 1011; var Ha = 1012; var Qy = 1013; var Ra = 1014; var qi = 1015; var Ms = 1016; var eb = 1017; var tb = 1018; var nb = 1019; var yo = 1020; var ib = 1021; var nr = 1022; var Gn = 1023; var rb = 1024; var sb = 1025; var ob = Gn; var ws = 1026; var Co = 1027; var ab = 1028; var lb = 1029; var cb = 1030; var ub = 1031; var hb = 1032; var db = 1033; var ld = 33776; var cd = 33777; var ud = 33778; var hd = 33779; var dd = 35840; var fd = 35841; var pd = 35842; var md = 35843; var fb = 36196; var gd = 37492; var vd = 37496; var pb = 37808; var mb = 37809; var gb = 37810; var vb = 37811; var yb = 37812; var bb = 37813; var xb = 37814; var Mb = 37815; var wb = 37816; var Ab = 37817; var Sb = 37818; var _b = 37819; var Tb = 37820; var Eb = 37821; var Cb = 36492; var Lb = 37840; var Rb = 37841; var Fb = 37842; var Pb = 37843; var Ib = 37844; var Ob = 37845; var Db = 37846; var Nb = 37847; var Bb = 37848; var Ub = 37849; var zb = 37850; var Vb = 37851; var kb = 37852; var Gb = 37853; var Hb = 2200; var Wb = 2201; var jb = 2202; var Lo = 2300; var Es = 2301; var Cc = 2302; var gs = 2400; var vs = 2401; var Wa = 2402; var fu = 2500; var Mf = 2501; var $b = 0; var Zb = 1; var wf = 2; var Cn = 3e3; var Cs = 3001; var pu = 3007; var mu = 3002; var Xb = 3003; var Af = 3004; var Sf = 3005; var _f = 3006; var Yb = 3200; var Jb = 3201; var Jr = 0; var Kb = 1; var L3 = 0; var Lc = 7680; var R3 = 7681; var F3 = 7682; var P3 = 7683; var I3 = 34055; var O3 = 34056; var D3 = 5386; var N3 = 512; var B3 = 513; var U3 = 514; var z3 = 515; var V3 = 516; var k3 = 517; var G3 = 518; var qb = 519; var Ro = 35044; var Fo = 35048; var H3 = 35040; var W3 = 35045; var j3 = 35049; var $3 = 35041; var Z3 = 35046; var X3 = 35050; var Y3 = 35042; var J3 = "100"; var yd = "300 es"; var Kr = class { addEventListener(e, t) { this._listeners === void 0 && (this._listeners = {}); const i = this._listeners; i[e] === void 0 && (i[e] = []), i[e].indexOf(t) === -1 && i[e].push(t); } hasEventListener(e, t) { if (this._listeners === void 0) return false; const i = this._listeners; return i[e] !== void 0 && i[e].indexOf(t) !== -1; } removeEventListener(e, t) { if (this._listeners === void 0) return; const r = this._listeners[e]; if (r !== void 0) { const s = r.indexOf(t); s !== -1 && r.splice(s, 1); } } dispatchEvent(e) { if (this._listeners === void 0) return; const i = this._listeners[e.type]; if (i !== void 0) { e.target = this; const r = i.slice(0); for (let s = 0, o = r.length; s < o; s++) r[s].call(this, e); e.target = null; } } }; var fn = []; for (let n = 0; n < 256; n++) fn[n] = (n < 16 ? "0" : "") + n.toString(16); var Il = 1234567; var As = Math.PI / 180; var ja = 180 / Math.PI; function Hn() { const n = Math.random() * 4294967295 | 0, e = Math.random() * 4294967295 | 0, t = Math.random() * 4294967295 | 0, i = Math.random() * 4294967295 | 0; return (fn[n & 255] + fn[n >> 8 & 255] + fn[n >> 16 & 255] + fn[n >> 24 & 255] + "-" + fn[e & 255] + fn[e >> 8 & 255] + "-" + fn[e >> 16 & 15 | 64] + fn[e >> 24 & 255] + "-" + fn[t & 63 | 128] + fn[t >> 8 & 255] + "-" + fn[t >> 16 & 255] + fn[t >> 24 & 255] + fn[i & 255] + fn[i >> 8 & 255] + fn[i >> 16 & 255] + fn[i >> 24 & 255]).toUpperCase(); } function gn(n, e, t) { return Math.max(e, Math.min(t, n)); } function Tf(n, e) { return (n % e + e) % e; } function K3(n, e, t, i, r) { return i + (n - e) * (r - i) / (t - e); } function q3(n, e, t) { return n !== e ? (t - n) / (e - n) : 0; } function Fa(n, e, t) { return (1 - t) * n + t * e; } function Q3(n, e, t, i) { return Fa(n, e, 1 - Math.exp(-t * i)); } function eF(n, e = 1) { return e - Math.abs(Tf(n, e * 2) - e); } function tF(n, e, t) { return n <= e ? 0 : n >= t ? 1 : (n = (n - e) / (t - e), n * n * (3 - 2 * n)); } function nF(n, e, t) { return n <= e ? 0 : n >= t ? 1 : (n = (n - e) / (t - e), n * n * n * (n * (n * 6 - 15) + 10)); } function iF(n, e) { return n + Math.floor(Math.random() * (e - n + 1)); } function rF(n, e) { return n + Math.random() * (e - n); } function sF(n) { return n * (0.5 - Math.random()); } function oF(n) { return n !== void 0 && (Il = n % 2147483647), Il = Il * 16807 % 2147483647, (Il - 1) / 2147483646; } function aF(n) { return n * As; } function lF(n) { return n * ja; } function bd(n) { return (n & n - 1) === 0 && n !== 0; } function Qb(n) { return Math.pow(2, Math.ceil(Math.log(n) / Math.LN2)); } function ex(n) { return Math.pow(2, Math.floor(Math.log(n) / Math.LN2)); } function cF(n, e, t, i, r) { const s = Math.cos, o = Math.sin, a = s(t / 2), c = o(t / 2), l = s((e + i) / 2), d = o((e + i) / 2), h6 = s((e - i) / 2), f = o((e - i) / 2), g = s((i - e) / 2), p = o((i - e) / 2); switch (r) { case "XYX": n.set(a * d, c * h6, c * f, a * l); break; case "YZY": n.set(c * f, a * d, c * h6, a * l); break; case "ZXZ": n.set(c * h6, c * f, a * d, a * l); break; case "XZX": n.set(a * d, c * p, c * g, a * l); break; case "YXY": n.set(c * g, a * d, c * p, a * l); break; case "ZYZ": n.set(c * p, c * g, a * d, a * l); break; default: console.warn("THREE.MathUtils: .setQuaternionFromProperEuler() encountered an unknown order: " + r); } } var xd = Object.freeze({ __proto__: null, DEG2RAD: As, RAD2DEG: ja, generateUUID: Hn, clamp: gn, euclideanModulo: Tf, mapLinear: K3, inverseLerp: q3, lerp: Fa, damp: Q3, pingpong: eF, smoothstep: tF, smootherstep: nF, randInt: iF, randFloat: rF, randFloatSpread: sF, seededRandom: oF, degToRad: aF, radToDeg: lF, isPowerOfTwo: bd, ceilPowerOfTwo: Qb, floorPowerOfTwo: ex, setQuaternionFromProperEuler: cF }); var Re = class { constructor(e = 0, t = 0) { this.x = e, this.y = t; } get width() { return this.x; } set width(e) { this.x = e; } get height() { return this.y; } set height(e) { this.y = e; } set(e, t) { return this.x = e, this.y = t, this; } setScalar(e) { return this.x = e, this.y = e, this; } setX(e) { return this.x = e, this; } setY(e) { return this.y = e, this; } setComponent(e, t) { switch (e) { case 0: this.x = t; break; case 1: this.y = t; break; default: throw new Error("index is out of range: " + e); } return this; } getComponent(e) { switch (e) { case 0: return this.x; case 1: return this.y; default: throw new Error("index is out of range: " + e); } } clone() { return new this.constructor(this.x, this.y); } copy(e) { return this.x = e.x, this.y = e.y, this; } add(e, t) { return t !== void 0 ? (console.warn("THREE.Vector2: .add() now only accepts one argument. Use .addVectors( a, b ) instead."), this.addVectors(e, t)) : (this.x += e.x, this.y += e.y, this); } addScalar(e) { return this.x += e, this.y += e, this; } addVectors(e, t) { return this.x = e.x + t.x, this.y = e.y + t.y, this; } addScaledVector(e, t) { return this.x += e.x * t, this.y += e.y * t, this; } sub(e, t) { return t !== void 0 ? (console.warn("THREE.Vector2: .sub() now only accepts one argument. Use .subVectors( a, b ) instead."), this.subVectors(e, t)) : (this.x -= e.x, this.y -= e.y, this); } subScalar(e) { return this.x -= e, this.y -= e, this; } subVectors(e, t) { return this.x = e.x - t.x, this.y = e.y - t.y, this; } multiply(e) { return this.x *= e.x, this.y *= e.y, this; } multiplyScalar(e) { return this.x *= e, this.y *= e, this; } divide(e) { return this.x /= e.x, this.y /= e.y, this; } divideScalar(e) { return this.multiplyScalar(1 / e); } applyMatrix3(e) { const t = this.x, i = this.y, r = e.elements; return this.x = r[0] * t + r[3] * i + r[6], this.y = r[1] * t + r[4] * i + r[7], this; } min(e) { return this.x = Math.min(this.x, e.x), this.y = Math.min(this.y, e.y), this; } max(e) { return this.x = Math.max(this.x, e.x), this.y = Math.max(this.y, e.y), this; } clamp(e, t) { return this.x = Math.max(e.x, Math.min(t.x, this.x)), this.y = Math.max(e.y, Math.min(t.y, this.y)), this; } clampScalar(e, t) { return this.x = Math.max(e, Math.min(t, this.x)), this.y = Math.max(e, Math.min(t, this.y)), this; } clampLength(e, t) { const i = this.length(); return this.divideScalar(i || 1).multiplyScalar(Math.max(e, Math.min(t, i))); } floor() { return this.x = Math.floor(this.x), this.y = Math.floor(this.y), this; } ceil() { return this.x = Math.ceil(this.x), this.y = Math.ceil(this.y), this; } round() { return this.x = Math.round(this.x), this.y = Math.round(this.y), this; } roundToZero() { return this.x = this.x < 0 ? Math.ceil(this.x) : Math.floor(this.x), this.y = this.y < 0 ? Math.ceil(this.y) : Math.floor(this.y), this; } negate() { return this.x = -this.x, this.y = -this.y, this; } dot(e) { return this.x * e.x + this.y * e.y; } cross(e) { return this.x * e.y - this.y * e.x; } lengthSq() { return this.x * this.x + this.y * this.y; } length() { return Math.sqrt(this.x * this.x + this.y * this.y); } manhattanLength() { return Math.abs(this.x) + Math.abs(this.y); } normalize() { return this.divideScalar(this.length() || 1); } angle() { return Math.atan2(-this.y, -this.x) + Math.PI; } distanceTo(e) { return Math.sqrt(this.distanceToSquared(e)); } distanceToSquared(e) { const t = this.x - e.x, i = this.y - e.y; return t * t + i * i; } manhattanDistanceTo(e) { return Math.abs(this.x - e.x) + Math.abs(this.y - e.y); } setLength(e) { return this.normalize().multiplyScalar(e); } lerp(e, t) { return this.x += (e.x - this.x) * t, this.y += (e.y - this.y) * t, this; } lerpVectors(e, t, i) { return this.x = e.x + (t.x - e.x) * i, this.y = e.y + (t.y - e.y) * i, this; } equals(e) { return e.x === this.x && e.y === this.y; } fromArray(e, t = 0) { return this.x = e[t], this.y = e[t + 1], this; } toArray(e = [], t = 0) { return e[t] = this.x, e[t + 1] = this.y, e; } fromBufferAttribute(e, t, i) { return i !== void 0 && console.warn("THREE.Vector2: offset has been removed from .fromBufferAttribute()."), this.x = e.getX(t), this.y = e.getY(t), this; } rotateAround(e, t) { const i = Math.cos(t), r = Math.sin(t), s = this.x - e.x, o = this.y - e.y; return this.x = s * i - o * r + e.x, this.y = s * r + o * i + e.y, this; } random() { return this.x = Math.random(), this.y = Math.random(), this; } }; Re.prototype.isVector2 = true; var rn = class { constructor() { this.elements = [ 1, 0, 0, 0, 1, 0, 0, 0, 1 ], arguments.length > 0 && console.error("THREE.Matrix3: the constructor no longer reads arguments. use .set() instead."); } set(e, t, i, r, s, o, a, c, l) { const d = this.elements; return d[0] = e, d[1] = r, d[2] = a, d[3] = t, d[4] = s, d[5] = c, d[6] = i, d[7] = o, d[8] = l, this; } identity() { return this.set( 1, 0, 0, 0, 1, 0, 0, 0, 1 ), this; } copy(e) { const t = this.elements, i = e.elements; return t[0] = i[0], t[1] = i[1], t[2] = i[2], t[3] = i[3], t[4] = i[4], t[5] = i[5], t[6] = i[6], t[7] = i[7], t[8] = i[8], this; } extractBasis(e, t, i) { return e.setFromMatrix3Column(this, 0), t.setFromMatrix3Column(this, 1), i.setFromMatrix3Column(this, 2), this; } setFromMatrix4(e) { const t = e.elements; return this.set( t[0], t[4], t[8], t[1], t[5], t[9], t[2], t[6], t[10] ), this; } multiply(e) { return this.multiplyMatrices(this, e); } premultiply(e) { return this.multiplyMatrices(e, this); } multiplyMatrices(e, t) { const i = e.elements, r = t.elements, s = this.elements, o = i[0], a = i[3], c = i[6], l = i[1], d = i[4], h6 = i[7], f = i[2], g = i[5], p = i[8], u = r[0], y = r[3], v = r[6], m = r[1], x = r[4], w = r[7], A = r[2], M = r[5], R = r[8]; return s[0] = o * u + a * m + c * A, s[3] = o * y + a * x + c * M, s[6] = o * v + a * w + c * R, s[1] = l * u + d * m + h6 * A, s[4] = l * y + d * x + h6 * M, s[7] = l * v + d * w + h6 * R, s[2] = f * u + g * m + p * A, s[5] = f * y + g * x + p * M, s[8] = f * v + g * w + p * R, this; } multiplyScalar(e) { const t = this.elements; return t[0] *= e, t[3] *= e, t[6] *= e, t[1] *= e, t[4] *= e, t[7] *= e, t[2] *= e, t[5] *= e, t[8] *= e, this; } determinant() { const e = this.elements, t = e[0], i = e[1], r = e[2], s = e[3], o = e[4], a = e[5], c = e[6], l = e[7], d = e[8]; return t * o * d - t * a * l - i * s * d + i * a * c + r * s * l - r * o * c; } invert() { const e = this.elements, t = e[0], i = e[1], r = e[2], s = e[3], o = e[4], a = e[5], c = e[6], l = e[7], d = e[8], h6 = d * o - a * l, f = a * c - d * s, g = l * s - o * c, p = t * h6 + i * f + r * g; if (p === 0) return this.set(0, 0, 0, 0, 0, 0, 0, 0, 0); const u = 1 / p; return e[0] = h6 * u, e[1] = (r * l - d * i) * u, e[2] = (a * i - r * o) * u, e[3] = f * u, e[4] = (d * t - r * c) * u, e[5] = (r * s - a * t) * u, e[6] = g * u, e[7] = (i * c - l * t) * u, e[8] = (o * t - i * s) * u, this; } transpose() { let e; const t = this.elements; return e = t[1], t[1] = t[3], t[3] = e, e = t[2], t[2] = t[6], t[6] = e, e = t[5], t[5] = t[7], t[7] = e, this; } getNormalMatrix(e) { return this.setFromMatrix4(e).invert().transpose(); } transposeIntoArray(e) { const t = this.elements; return e[0] = t[0], e[1] = t[3], e[2] = t[6], e[3] = t[1], e[4] = t[4], e[5] = t[7], e[6] = t[2], e[7] = t[5], e[8] = t[8], this; } setUvTransform(e, t, i, r, s, o, a) { const c = Math.cos(s), l = Math.sin(s); return this.set( i * c, i * l, -i * (c * o + l * a) + o + e, -r * l, r * c, -r * (-l * o + c * a) + a + t, 0, 0, 1 ), this; } scale(e, t) { const i = this.elements; return i[0] *= e, i[3] *= e, i[6] *= e, i[1] *= t, i[4] *= t, i[7] *= t, this; } rotate(e) { const t = Math.cos(e), i = Math.sin(e), r = this.elements, s = r[0], o = r[3], a = r[6], c = r[1], l = r[4], d = r[7]; return r[0] = t * s + i * c, r[3] = t * o + i * l, r[6] = t * a + i * d, r[1] = -i * s + t * c, r[4] = -i * o + t * l, r[7] = -i * a + t * d, this; } translate(e, t) { const i = this.elements; return i[0] += e * i[2], i[3] += e * i[5], i[6] += e * i[8], i[1] += t * i[2], i[4] += t * i[5], i[7] += t * i[8], this; } equals(e) { const t = this.elements, i = e.elements; for (let r = 0; r < 9; r++) if (t[r] !== i[r]) return false; return true; } fromArray(e, t = 0) { for (let i = 0; i < 9; i++) this.elements[i] = e[i + t]; return this; } toArray(e = [], t = 0) { const i = this.elements; return e[t] = i[0], e[t + 1] = i[1], e[t + 2] = i[2], e[t + 3] = i[3], e[t + 4] = i[4], e[t + 5] = i[5], e[t + 6] = i[6], e[t + 7] = i[7], e[t + 8] = i[8], e; } clone() { return new this.constructor().fromArray(this.elements); } }; rn.prototype.isMatrix3 = true; var js; var Bs = class { static getDataURL(e) { if (/^data:/i.test(e.src) || typeof HTMLCanvasElement > "u") return e.src; let t; if (e instanceof HTMLCanvasElement) t = e; else { js === void 0 && (js = document.createElementNS("http://www.w3.org/1999/xhtml", "canvas")), js.width = e.width, js.height = e.height; const i = js.getContext("2d"); e instanceof ImageData ? i.putImageData(e, 0, 0) : i.drawImage(e, 0, 0, e.width, e.height), t = js; } return t.width > 2048 || t.height > 2048 ? (console.warn("THREE.ImageUtils.getDataURL: Image converted to jpg for performance reasons", e), t.toDataURL("image/jpeg", 0.6)) : t.toDataURL("image/png"); } }; var uF = 0; var Yt = class _Yt extends Kr { constructor(e = _Yt.DEFAULT_IMAGE, t = _Yt.DEFAULT_MAPPING, i = hn2, r = hn2, s = zt, o = fr, a = Gn, c = Ts, l = 1, d = Cn) { super(), Object.defineProperty(this, "id", { value: uF++ }), this.uuid = Hn(), this.name = "", this.image = e, this.mipmaps = [], this.mapping = t, this.wrapS = i, this.wrapT = r, this.magFilter = s, this.minFilter = o, this.anisotropy = l, this.format = a, this.internalFormat = null, this.type = c, this.offset = new Re(0, 0), this.repeat = new Re(1, 1), this.center = new Re(0, 0), this.rotation = 0, this.matrixAutoUpdate = true, this.matrix = new rn(), this.generateMipmaps = true, this.premultiplyAlpha = false, this.flipY = true, this.unpackAlignment = 4, this.encoding = d, this.version = 0, this.onUpdate = null; } updateMatrix() { this.matrix.setUvTransform(this.offset.x, this.offset.y, this.repeat.x, this.repeat.y, this.rotation, this.center.x, this.center.y); } clone() { return new this.constructor().copy(this); } copy(e) { return this.name = e.name, this.image = e.image, this.mipmaps = e.mipmaps.slice(0), this.mapping = e.mapping, this.wrapS = e.wrapS, this.wrapT = e.wrapT, this.magFilter = e.magFilter, this.minFilter = e.minFilter, this.anisotropy = e.anisotropy, this.format = e.format, this.internalFormat = e.internalFormat, this.type = e.type, this.offset.copy(e.offset), this.repeat.copy(e.repeat), this.center.copy(e.center), this.rotation = e.rotation, this.matrixAutoUpdate = e.matrixAutoUpdate, this.matrix.copy(e.matrix), this.generateMipmaps = e.generateMipmaps, this.premultiplyAlpha = e.premultiplyAlpha, this.flipY = e.flipY, this.unpackAlignment = e.unpackAlignment, this.encoding = e.encoding, this; } toJSON(e) { const t = e === void 0 || typeof e == "string"; if (!t && e.textures[this.uuid] !== void 0) return e.textures[this.uuid]; const i = { metadata: { version: 4.5, type: "Texture", generator: "Texture.toJSON" }, uuid: this.uuid, name: this.name, mapping: this.mapping, repeat: [this.repeat.x, this.repeat.y], offset: [this.offset.x, this.offset.y], center: [this.center.x, this.center.y], rotation: this.rotation, wrap: [this.wrapS, this.wrapT], format: this.format, type: this.type, encoding: this.encoding, minFilter: this.minFilter, magFilter: this.magFilter, anisotropy: this.anisotropy, flipY: this.flipY, premultiplyAlpha: this.premultiplyAlpha, unpackAlignment: this.unpackAlignment }; if (this.image !== void 0) { const r = this.image; if (r.uuid === void 0 && (r.uuid = Hn()), !t && e.images[r.uuid] === void 0) { let s; if (Array.isArray(r)) { s = []; for (let o = 0, a = r.length; o < a; o++) r[o].isDataTexture ? s.push($u(r[o].image)) : s.push($u(r[o])); } else s = $u(r); e.images[r.uuid] = { uuid: r.uuid, url: s }; } i.image = r.uuid; } return t || (e.textures[this.uuid] = i), i; } dispose() { this.dispatchEvent({ type: "dispose" }); } transformUv(e) { if (this.mapping !== hu) return e; if (e.applyMatrix3(this.matrix), e.x < 0 || e.x > 1) switch (this.wrapS) { case jr: e.x = e.x - Math.floor(e.x); break; case hn2: e.x = e.x < 0 ? 0 : 1; break; case Eo: Math.abs(Math.floor(e.x) % 2) === 1 ? e.x = Math.ceil(e.x) - e.x : e.x = e.x - Math.floor(e.x); break; } if (e.y < 0 || e.y > 1) switch (this.wrapT) { case jr: e.y = e.y - Math.floor(e.y); break; case hn2: e.y = e.y < 0 ? 0 : 1; break; case Eo: Math.abs(Math.floor(e.y) % 2) === 1 ? e.y = Math.ceil(e.y) - e.y : e.y = e.y - Math.floor(e.y); break; } return this.flipY && (e.y = 1 - e.y), e; } set needsUpdate(e) { e === true && this.version++; } }; Yt.DEFAULT_IMAGE = void 0; Yt.DEFAULT_MAPPING = hu; Yt.prototype.isTexture = true; function $u(n) { return typeof HTMLImageElement < "u" && n instanceof HTMLImageElement || typeof HTMLCanvasElement < "u" && n instanceof HTMLCanvasElement || typeof ImageBitmap < "u" && n instanceof ImageBitmap ? Bs.getDataURL(n) : n.data ? { data: Array.prototype.slice.call(n.data), width: n.width, height: n.height, type: n.data.constructor.name } : (console.warn("THREE.Texture: Unable to serialize Texture."), {}); } var xt = class { constructor(e = 0, t = 0, i = 0, r = 1) { this.x = e, this.y = t, this.z = i, this.w = r; } get width() { return this.z; } set width(e) { this.z = e; } get height() { return this.w; } set height(e) { this.w = e; } set(e, t, i, r) { return this.x = e, this.y = t, this.z = i, this.w = r, this; } setScalar(e) { return this.x = e, this.y = e, this.z = e, this.w = e, this; } setX(e) { return this.x = e, this; } setY(e) { return this.y = e, this; } setZ(e) { return this.z = e, this; } setW(e) { return this.w = e, this; } setComponent(e, t) { switch (e) { case 0: this.x = t; break; case 1: this.y = t; break; case 2: this.z = t; break; case 3: this.w = t; break; default: throw new Error("index is out of range: " + e); } return this; } getComponent(e) { switch (e) { case 0: return this.x; case 1: return this.y; case 2: return this.z; case 3: return this.w; default: throw new Error("index is out of range: " + e); } } clone() { return new this.constructor(this.x, this.y, this.z, this.w); } copy(e) { return this.x = e.x, this.y = e.y, this.z = e.z, this.w = e.w !== void 0 ? e.w : 1, this; } add(e, t) { return t !== void 0 ? (console.warn("THREE.Vector4: .add() now only accepts one argument. Use .addVectors( a, b ) instead."), this.addVectors(e, t)) : (this.x += e.x, this.y += e.y, this.z += e.z, this.w += e.w, this); } addScalar(e) { return this.x += e, this.y += e, this.z += e, this.w += e, this; } addVectors(e, t) { return this.x = e.x + t.x, this.y = e.y + t.y, this.z = e.z + t.z, this.w = e.w + t.w, this; } addScaledVector(e, t) { return this.x += e.x * t, this.y += e.y * t, this.z += e.z * t, this.w += e.w * t, this; } sub(e, t) { return t !== void 0 ? (console.warn("THREE.Vector4: .sub() now only accepts one argument. Use .subVectors( a, b ) instead."), this.subVectors(e, t)) : (this.x -= e.x, this.y -= e.y, this.z -= e.z, this.w -= e.w, this); } subScalar(e) { return this.x -= e, this.y -= e, this.z -= e, this.w -= e, this; } subVectors(e, t) { return this.x = e.x - t.x, this.y = e.y - t.y, this.z = e.z - t.z, this.w = e.w - t.w, this; } multiply(e) { return this.x *= e.x, this.y *= e.y, this.z *= e.z, this.w *= e.w, this; } multiplyScalar(e) { return this.x *= e, this.y *= e, this.z *= e, this.w *= e, this; } applyMatrix4(e) { const t = this.x, i = this.y, r = this.z, s = this.w, o = e.elements; return this.x = o[0] * t + o[4] * i + o[8] * r + o[12] * s, this.y = o[1] * t + o[5] * i + o[9] * r + o[13] * s, this.z = o[2] * t + o[6] * i + o[10] * r + o[14] * s, this.w = o[3] * t + o[7] * i + o[11] * r + o[15] * s, this; } divideScalar(e) { return this.multiplyScalar(1 / e); } setAxisAngleFromQuaternion(e) { this.w = 2 * Math.acos(e.w); const t = Math.sqrt(1 - e.w * e.w); return t < 1e-4 ? (this.x = 1, this.y = 0, this.z = 0) : (this.x = e.x / t, this.y = e.y / t, this.z = e.z / t), this; } setAxisAngleFromRotationMatrix(e) { let t, i, r, s; const c = e.elements, l = c[0], d = c[4], h6 = c[8], f = c[1], g = c[5], p = c[9], u = c[2], y = c[6], v = c[10]; if (Math.abs(d - f) < 0.01 && Math.abs(h6 - u) < 0.01 && Math.abs(p - y) < 0.01) { if (Math.abs(d + f) < 0.1 && Math.abs(h6 + u) < 0.1 && Math.abs(p + y) < 0.1 && Math.abs(l + g + v - 3) < 0.1) return this.set(1, 0, 0, 0), this; t = Math.PI; const x = (l + 1) / 2, w = (g + 1) / 2, A = (v + 1) / 2, M = (d + f) / 4, R = (h6 + u) / 4, L = (p + y) / 4; return x > w && x > A ? x < 0.01 ? (i = 0, r = 0.707106781, s = 0.707106781) : (i = Math.sqrt(x), r = M / i, s = R / i) : w > A ? w < 0.01 ? (i = 0.707106781, r = 0, s = 0.707106781) : (r = Math.sqrt(w), i = M / r, s = L / r) : A < 0.01 ? (i = 0.707106781, r = 0.707106781, s = 0) : (s = Math.sqrt(A), i = R / s, r = L / s), this.set(i, r, s, t), this; } let m = Math.sqrt((y - p) * (y - p) + (h6 - u) * (h6 - u) + (f - d) * (f - d)); return Math.abs(m) < 1e-3 && (m = 1), this.x = (y - p) / m, this.y = (h6 - u) / m, this.z = (f - d) / m, this.w = Math.acos((l + g + v - 1) / 2), this; } min(e) { return this.x = Math.min(this.x, e.x), this.y = Math.min(this.y, e.y), this.z = Math.min(this.z, e.z), this.w = Math.min(this.w, e.w), this; } max(e) { return this.x = Math.max(this.x, e.x), this.y = Math.max(this.y, e.y), this.z = Math.max(this.z, e.z), this.w = Math.max(this.w, e.w), this; } clamp(e, t) { return this.x = Math.max(e.x, Math.min(t.x, this.x)), this.y = Math.max(e.y, Math.min(t.y, this.y)), this.z = Math.max(e.z, Math.min(t.z, this.z)), this.w = Math.max(e.w, Math.min(t.w, this.w)), this; } clampScalar(e, t) { return this.x = Math.max(e, Math.min(t, this.x)), this.y = Math.max(e, Math.min(t, this.y)), this.z = Math.max(e, Math.min(t, this.z)), this.w = Math.max(e, Math.min(t, this.w)), this; } clampLength(e, t) { const i = this.length(); return this.divideScalar(i || 1).multiplyScalar(Math.max(e, Math.min(t, i))); } floor() { return this.x = Math.floor(this.x), this.y = Math.floor(this.y), this.z = Math.floor(this.z), this.w = Math.floor(this.w), this; } ceil() { return this.x = Math.ceil(this.x), this.y = Math.ceil(this.y), this.z = Math.ceil(this.z), this.w = Math.ceil(this.w), this; } round() { return this.x = Math.round(this.x), this.y = Math.round(this.y), this.z = Math.round(this.z), this.w = Math.round(this.w), this; } roundToZero() { return this.x = this.x < 0 ? Math.ceil(this.x) : Math.floor(this.x), this.y = this.y < 0 ? Math.ceil(this.y) : Math.floor(this.y), this.z = this.z < 0 ? Math.ceil(this.z) : Math.floor(this.z), this.w = this.w < 0 ? Math.ceil(this.w) : Math.floor(this.w), this; } negate() { return this.x = -this.x, this.y = -this.y, this.z = -this.z, this.w = -this.w, this; } dot(e) { return this.x * e.x + this.y * e.y + this.z * e.z + this.w * e.w; } lengthSq() { return this.x * this.x + this.y * this.y + this.z * this.z + this.w * this.w; } length() { return Math.sqrt(this.x * this.x + this.y * this.y + this.z * this.z + this.w * this.w); } manhattanLength() { return Math.abs(this.x) + Math.abs(this.y) + Math.abs(this.z) + Math.abs(this.w); } normalize() { return this.divideScalar(this.length() || 1); } setLength(e) { return this.normalize().multiplyScalar(e); } lerp(e, t) { return this.x += (e.x - this.x) * t, this.y += (e.y - this.y) * t, this.z += (e.z - this.z) * t, this.w += (e.w - this.w) * t, this; } lerpVectors(e, t, i) { return this.x = e.x + (t.x - e.x) * i, this.y = e.y + (t.y - e.y) * i, this.z = e.z + (t.z - e.z) * i, this.w = e.w + (t.w - e.w) * i, this; } equals(e) { return e.x === this.x && e.y === this.y && e.z === this.z && e.w === this.w; } fromArray(e, t = 0) { return this.x = e[t], this.y = e[t + 1], this.z = e[t + 2], this.w = e[t + 3], this; } toArray(e = [], t = 0) { return e[t] = this.x, e[t + 1] = this.y, e[t + 2] = this.z, e[t + 3] = this.w, e; } fromBufferAttribute(e, t, i) { return i !== void 0 && console.warn("THREE.Vector4: offset has been removed from .fromBufferAttribute()."), this.x = e.getX(t), this.y = e.getY(t), this.z = e.getZ(t), this.w = e.getW(t), this; } random() { return this.x = Math.random(), this.y = Math.random(), this.z = Math.random(), this.w = Math.random(), this; } }; xt.prototype.isVector4 = true; var fi = class extends Kr { constructor(e, t, i = {}) { super(), this.width = e, this.height = t, this.depth = 1, this.scissor = new xt(0, 0, e, t), this.scissorTest = false, this.viewport = new xt(0, 0, e, t), this.texture = new Yt(void 0, i.mapping, i.wrapS, i.wrapT, i.magFilter, i.minFilter, i.format, i.type, i.anisotropy, i.encoding), this.texture.image = { width: e, height: t, depth: 1 }, this.texture.generateMipmaps = i.generateMipmaps !== void 0 ? i.generateMipmaps : false, this.texture.minFilter = i.minFilter !== void 0 ? i.minFilter : zt, this.depthBuffer = i.depthBuffer !== void 0 ? i.depthBuffer : true, this.stencilBuffer = i.stencilBuffer !== void 0 ? i.stencilBuffer : false, this.depthTexture = i.depthTexture !== void 0 ? i.depthTexture : null; } setTexture(e) { e.image = { width: this.width, height: this.height, depth: this.depth }, this.texture = e; } setSize(e, t, i = 1) { (this.width !== e || this.height !== t || this.depth !== i) && (this.width = e, this.height = t, this.depth = i, this.texture.image.width = e, this.texture.image.height = t, this.texture.image.depth = i, this.dispose()), this.viewport.set(0, 0, e, t), this.scissor.set(0, 0, e, t); } clone() { return new this.constructor().copy(this); } copy(e) { return this.width = e.width, this.height = e.height, this.depth = e.depth, this.viewport.copy(e.viewport), this.texture = e.texture.clone(), this.texture.image = { ...this.texture.image }, this.depthBuffer = e.depthBuffer, this.stencilBuffer = e.stencilBuffer, this.depthTexture = e.depthTexture, this; } dispose() { this.dispatchEvent({ type: "dispose" }); } }; fi.prototype.isWebGLRenderTarget = true; var tx = class extends fi { constructor(e, t, i) { super(e, t); const r = this.texture; this.texture = []; for (let s = 0; s < i; s++) this.texture[s] = r.clone(); } setSize(e, t, i = 1) { if (this.width !== e || this.height !== t || this.depth !== i) { this.width = e, this.height = t, this.depth = i; for (let r = 0, s = this.texture.length; r < s; r++) this.texture[r].image.width = e, this.texture[r].image.height = t, this.texture[r].image.depth = i; this.dispose(); } return this.viewport.set(0, 0, e, t), this.scissor.set(0, 0, e, t), this; } copy(e) { this.dispose(), this.width = e.width, this.height = e.height, this.depth = e.depth, this.viewport.set(0, 0, this.width, this.height), this.scissor.set(0, 0, this.width, this.height), this.depthBuffer = e.depthBuffer, this.stencilBuffer = e.stencilBuffer, this.depthTexture = e.depthTexture, this.texture.length = 0; for (let t = 0, i = e.texture.length; t < i; t++) this.texture[t] = e.texture[t].clone(); return this; } }; tx.prototype.isWebGLMultipleRenderTargets = true; var Ef = class extends fi { constructor(e, t, i) { super(e, t, i), this.samples = 4; } copy(e) { return super.copy.call(this, e), this.samples = e.samples, this; } }; Ef.prototype.isWebGLMultisampleRenderTarget = true; var bn = class { constructor(e = 0, t = 0, i = 0, r = 1) { this._x = e, this._y = t, this._z = i, this._w = r; } static slerp(e, t, i, r) { return console.warn("THREE.Quaternion: Static .slerp() has been deprecated. Use qm.slerpQuaternions( qa, qb, t ) instead."), i.slerpQuaternions(e, t, r); } static slerpFlat(e, t, i, r, s, o, a) { let c = i[r + 0], l = i[r + 1], d = i[r + 2], h6 = i[r + 3]; const f = s[o + 0], g = s[o + 1], p = s[o + 2], u = s[o + 3]; if (a === 0) { e[t + 0] = c, e[t + 1] = l, e[t + 2] = d, e[t + 3] = h6; return; } if (a === 1) { e[t + 0] = f, e[t + 1] = g, e[t + 2] = p, e[t + 3] = u; return; } if (h6 !== u || c !== f || l !== g || d !== p) { let y = 1 - a; const v = c * f + l * g + d * p + h6 * u, m = v >= 0 ? 1 : -1, x = 1 - v * v; if (x > Number.EPSILON) { const A = Math.sqrt(x), M = Math.atan2(A, v * m); y = Math.sin(y * M) / A, a = Math.sin(a * M) / A; } const w = a * m; if (c = c * y + f * w, l = l * y + g * w, d = d * y + p * w, h6 = h6 * y + u * w, y === 1 - a) { const A = 1 / Math.sqrt(c * c + l * l + d * d + h6 * h6); c *= A, l *= A, d *= A, h6 *= A; } } e[t] = c, e[t + 1] = l, e[t + 2] = d, e[t + 3] = h6; } static multiplyQuaternionsFlat(e, t, i, r, s, o) { const a = i[r], c = i[r + 1], l = i[r + 2], d = i[r + 3], h6 = s[o], f = s[o + 1], g = s[o + 2], p = s[o + 3]; return e[t] = a * p + d * h6 + c * g - l * f, e[t + 1] = c * p + d * f + l * h6 - a * g, e[t + 2] = l * p + d * g + a * f - c * h6, e[t + 3] = d * p - a * h6 - c * f - l * g, e; } get x() { return this._x; } set x(e) { this._x = e, this._onChangeCallback(); } get y() { return this._y; } set y(e) { this._y = e, this._onChangeCallback(); } get z() { return this._z; } set z(e) { this._z = e, this._onChangeCallback(); } get w() { return this._w; } set w(e) { this._w = e, this._onChangeCallback(); } set(e, t, i, r) { return this._x = e, this._y = t, this._z = i, this._w = r, this._onChangeCallback(), this; } clone() { return new this.constructor(this._x, this._y, this._z, this._w); } copy(e) { return this._x = e.x, this._y = e.y, this._z = e.z, this._w = e.w, this._onChangeCallback(), this; } setFromEuler(e, t) { if (!(e && e.isEuler)) throw new Error("THREE.Quaternion: .setFromEuler() now expects an Euler rotation rather than a Vector3 and order."); const i = e._x, r = e._y, s = e._z, o = e._order, a = Math.cos, c = Math.sin, l = a(i / 2), d = a(r / 2), h6 = a(s / 2), f = c(i / 2), g = c(r / 2), p = c(s / 2); switch (o) { case "XYZ": this._x = f * d * h6 + l * g * p, this._y = l * g * h6 - f * d * p, this._z = l * d * p + f * g * h6, this._w = l * d * h6 - f * g * p; break; case "YXZ": this._x = f * d * h6 + l * g * p, this._y = l * g * h6 - f * d * p, this._z = l * d * p - f * g * h6, this._w = l * d * h6 + f * g * p; break; case "ZXY": this._x = f * d * h6 - l * g * p, this._y = l * g * h6 + f * d * p, this._z = l * d * p + f * g * h6, this._w = l * d * h6 - f * g * p; break; case "ZYX": this._x = f * d * h6 - l * g * p, this._y = l * g * h6 + f * d * p, this._z = l * d * p - f * g * h6, this._w = l * d * h6 + f * g * p; break; case "YZX": this._x = f * d * h6 + l * g * p, this._y = l * g * h6 + f * d * p, this._z = l * d * p - f * g * h6, this._w = l * d * h6 - f * g * p; break; case "XZY": this._x = f * d * h6 - l * g * p, this._y = l * g * h6 - f * d * p, this._z = l * d * p + f * g * h6, this._w = l * d * h6 + f * g * p; break; default: console.warn("THREE.Quaternion: .setFromEuler() encountered an unknown order: " + o); } return t !== false && this._onChangeCallback(), this; } setFromAxisAngle(e, t) { const i = t / 2, r = Math.sin(i); return this._x = e.x * r, this._y = e.y * r, this._z = e.z * r, this._w = Math.cos(i), this._onChangeCallback(), this; } setFromRotationMatrix(e) { const t = e.elements, i = t[0], r = t[4], s = t[8], o = t[1], a = t[5], c = t[9], l = t[2], d = t[6], h6 = t[10], f = i + a + h6; if (f > 0) { const g = 0.5 / Math.sqrt(f + 1); this._w = 0.25 / g, this._x = (d - c) * g, this._y = (s - l) * g, this._z = (o - r) * g; } else if (i > a && i > h6) { const g = 2 * Math.sqrt(1 + i - a - h6); this._w = (d - c) / g, this._x = 0.25 * g, this._y = (r + o) / g, this._z = (s + l) / g; } else if (a > h6) { const g = 2 * Math.sqrt(1 + a - i - h6); this._w = (s - l) / g, this._x = (r + o) / g, this._y = 0.25 * g, this._z = (c + d) / g; } else { const g = 2 * Math.sqrt(1 + h6 - i - a); this._w = (o - r) / g, this._x = (s + l) / g, this._y = (c + d) / g, this._z = 0.25 * g; } return this._onChangeCallback(), this; } setFromUnitVectors(e, t) { let i = e.dot(t) + 1; return i < Number.EPSILON ? (i = 0, Math.abs(e.x) > Math.abs(e.z) ? (this._x = -e.y, this._y = e.x, this._z = 0, this._w = i) : (this._x = 0, this._y = -e.z, this._z = e.y, this._w = i)) : (this._x = e.y * t.z - e.z * t.y, this._y = e.z * t.x - e.x * t.z, this._z = e.x * t.y - e.y * t.x, this._w = i), this.normalize(); } angleTo(e) { return 2 * Math.acos(Math.abs(gn(this.dot(e), -1, 1))); } rotateTowards(e, t) { const i = this.angleTo(e); if (i === 0) return this; const r = Math.min(1, t / i); return this.slerp(e, r), this; } identity() { return this.set(0, 0, 0, 1); } invert() { return this.conjugate(); } conjugate() { return this._x *= -1, this._y *= -1, this._z *= -1, this._onChangeCallback(), this; } dot(e) { return this._x * e._x + this._y * e._y + this._z * e._z + this._w * e._w; } lengthSq() { return this._x * this._x + this._y * this._y + this._z * this._z + this._w * this._w; } length() { return Math.sqrt(this._x * this._x + this._y * this._y + this._z * this._z + this._w * this._w); } normalize() { let e = this.length(); return e === 0 ? (this._x = 0, this._y = 0, this._z = 0, this._w = 1) : (e = 1 / e, this._x = this._x * e, this._y = this._y * e, this._z = this._z * e, this._w = this._w * e), this._onChangeCallback(), this; } multiply(e, t) { return t !== void 0 ? (console.warn("THREE.Quaternion: .multiply() now only accepts one argument. Use .multiplyQuaternions( a, b ) instead."), this.multiplyQuaternions(e, t)) : this.multiplyQuaternions(this, e); } premultiply(e) { return this.multiplyQuaternions(e, this); } multiplyQuaternions(e, t) { const i = e._x, r = e._y, s = e._z, o = e._w, a = t._x, c = t._y, l = t._z, d = t._w; return this._x = i * d + o * a + r * l - s * c, this._y = r * d + o * c + s * a - i * l, this._z = s * d + o * l + i * c - r * a, this._w = o * d - i * a - r * c - s * l, this._onChangeCallback(), this; } slerp(e, t) { if (t === 0) return this; if (t === 1) return this.copy(e); const i = this._x, r = this._y, s = this._z, o = this._w; let a = o * e._w + i * e._x + r * e._y + s * e._z; if (a < 0 ? (this._w = -e._w, this._x = -e._x, this._y = -e._y, this._z = -e._z, a = -a) : this.copy(e), a >= 1) return this._w = o, this._x = i, this._y = r, this._z = s, this; const c = 1 - a * a; if (c <= Number.EPSILON) { const g = 1 - t; return this._w = g * o + t * this._w, this._x = g * i + t * this._x, this._y = g * r + t * this._y, this._z = g * s + t * this._z, this.normalize(), this._onChangeCallback(), this; } const l = Math.sqrt(c), d = Math.atan2(l, a), h6 = Math.sin((1 - t) * d) / l, f = Math.sin(t * d) / l; return this._w = o * h6 + this._w * f, this._x = i * h6 + this._x * f, this._y = r * h6 + this._y * f, this._z = s * h6 + this._z * f, this._onChangeCallback(), this; } slerpQuaternions(e, t, i) { this.copy(e).slerp(t, i); } equals(e) { return e._x === this._x && e._y === this._y && e._z === this._z && e._w === this._w; } fromArray(e, t = 0) { return this._x = e[t], this._y = e[t + 1], this._z = e[t + 2], this._w = e[t + 3], this._onChangeCallback(), this; } toArray(e = [], t = 0) { return e[t] = this._x, e[t + 1] = this._y, e[t + 2] = this._z, e[t + 3] = this._w, e; } fromBufferAttribute(e, t) { return this._x = e.getX(t), this._y = e.getY(t), this._z = e.getZ(t), this._w = e.getW(t), this; } _onChange(e) { return this._onChangeCallback = e, this; } _onChangeCallback() { } }; bn.prototype.isQuaternion = true; var q = class { constructor(e = 0, t = 0, i = 0) { this.x = e, this.y = t, this.z = i; } set(e, t, i) { return i === void 0 && (i = this.z), this.x = e, this.y = t, this.z = i, this; } setScalar(e) { return this.x = e, this.y = e, this.z = e, this; } setX(e) { return this.x = e, this; } setY(e) { return this.y = e, this; } setZ(e) { return this.z = e, this; } setComponent(e, t) { switch (e) { case 0: this.x = t; break; case 1: this.y = t; break; case 2: this.z = t; break; default: throw new Error("index is out of range: " + e); } return this; } getComponent(e) { switch (e) { case 0: return this.x; case 1: return this.y; case 2: return this.z; default: throw new Error("index is out of range: " + e); } } clone() { return new this.constructor(this.x, this.y, this.z); } copy(e) { return this.x = e.x, this.y = e.y, this.z = e.z, this; } add(e, t) { return t !== void 0 ? (console.warn("THREE.Vector3: .add() now only accepts one argument. Use .addVectors( a, b ) instead."), this.addVectors(e, t)) : (this.x += e.x, this.y += e.y, this.z += e.z, this); } addScalar(e) { return this.x += e, this.y += e, this.z += e, this; } addVectors(e, t) { return this.x = e.x + t.x, this.y = e.y + t.y, this.z = e.z + t.z, this; } addScaledVector(e, t) { return this.x += e.x * t, this.y += e.y * t, this.z += e.z * t, this; } sub(e, t) { return t !== void 0 ? (console.warn("THREE.Vector3: .sub() now only accepts one argument. Use .subVectors( a, b ) instead."), this.subVectors(e, t)) : (this.x -= e.x, this.y -= e.y, this.z -= e.z, this); } subScalar(e) { return this.x -= e, this.y -= e, this.z -= e, this; } subVectors(e, t) { return this.x = e.x - t.x, this.y = e.y - t.y, this.z = e.z - t.z, this; } multiply(e, t) { return t !== void 0 ? (console.warn("THREE.Vector3: .multiply() now only accepts one argument. Use .multiplyVectors( a, b ) instead."), this.multiplyVectors(e, t)) : (this.x *= e.x, this.y *= e.y, this.z *= e.z, this); } multiplyScalar(e) { return this.x *= e, this.y *= e, this.z *= e, this; } multiplyVectors(e, t) { return this.x = e.x * t.x, this.y = e.y * t.y, this.z = e.z * t.z, this; } applyEuler(e) { return e && e.isEuler || console.error("THREE.Vector3: .applyEuler() now expects an Euler rotation rather than a Vector3 and order."), this.applyQuaternion($m.setFromEuler(e)); } applyAxisAngle(e, t) { return this.applyQuaternion($m.setFromAxisAngle(e, t)); } applyMatrix3(e) { const t = this.x, i = this.y, r = this.z, s = e.elements; return this.x = s[0] * t + s[3] * i + s[6] * r, this.y = s[1] * t + s[4] * i + s[7] * r, this.z = s[2] * t + s[5] * i + s[8] * r, this; } applyNormalMatrix(e) { return this.applyMatrix3(e).normalize(); } applyMatrix4(e) { const t = this.x, i = this.y, r = this.z, s = e.elements, o = 1 / (s[3] * t + s[7] * i + s[11] * r + s[15]); return this.x = (s[0] * t + s[4] * i + s[8] * r + s[12]) * o, this.y = (s[1] * t + s[5] * i + s[9] * r + s[13]) * o, this.z = (s[2] * t + s[6] * i + s[10] * r + s[14]) * o, this; } applyQuaternion(e) { const t = this.x, i = this.y, r = this.z, s = e.x, o = e.y, a = e.z, c = e.w, l = c * t + o * r - a * i, d = c * i + a * t - s * r, h6 = c * r + s * i - o * t, f = -s * t - o * i - a * r; return this.x = l * c + f * -s + d * -a - h6 * -o, this.y = d * c + f * -o + h6 * -s - l * -a, this.z = h6 * c + f * -a + l * -o - d * -s, this; } project(e) { return this.applyMatrix4(e.matrixWorldInverse).applyMatrix4(e.projectionMatrix); } unproject(e) { return this.applyMatrix4(e.projectionMatrixInverse).applyMatrix4(e.matrixWorld); } transformDirection(e) { const t = this.x, i = this.y, r = this.z, s = e.elements; return this.x = s[0] * t + s[4] * i + s[8] * r, this.y = s[1] * t + s[5] * i + s[9] * r, this.z = s[2] * t + s[6] * i + s[10] * r, this.normalize(); } divide(e) { return this.x /= e.x, this.y /= e.y, this.z /= e.z, this; } divideScalar(e) { return this.multiplyScalar(1 / e); } min(e) { return this.x = Math.min(this.x, e.x), this.y = Math.min(this.y, e.y), this.z = Math.min(this.z, e.z), this; } max(e) { return this.x = Math.max(this.x, e.x), this.y = Math.max(this.y, e.y), this.z = Math.max(this.z, e.z), this; } clamp(e, t) { return this.x = Math.max(e.x, Math.min(t.x, this.x)), this.y = Math.max(e.y, Math.min(t.y, this.y)), this.z = Math.max(e.z, Math.min(t.z, this.z)), this; } clampScalar(e, t) { return this.x = Math.max(e, Math.min(t, this.x)), this.y = Math.max(e, Math.min(t, this.y)), this.z = Math.max(e, Math.min(t, this.z)), this; } clampLength(e, t) { const i = this.length(); return this.divideScalar(i || 1).multiplyScalar(Math.max(e, Math.min(t, i))); } floor() { return this.x = Math.floor(this.x), this.y = Math.floor(this.y), this.z = Math.floor(this.z), this; } ceil() { return this.x = Math.ceil(this.x), this.y = Math.ceil(this.y), this.z = Math.ceil(this.z), this; } round() { return this.x = Math.round(this.x), this.y = Math.round(this.y), this.z = Math.round(this.z), this; } roundToZero() { return this.x = this.x < 0 ? Math.ceil(this.x) : Math.floor(this.x), this.y = this.y < 0 ? Math.ceil(this.y) : Math.floor(this.y), this.z = this.z < 0 ? Math.ceil(this.z) : Math.floor(this.z), this; } negate() { return this.x = -this.x, this.y = -this.y, this.z = -this.z, this; } dot(e) { return this.x * e.x + this.y * e.y + this.z * e.z; } // TODO lengthSquared? lengthSq() { return this.x * this.x + this.y * this.y + this.z * this.z; } length() { return Math.sqrt(this.x * this.x + this.y * this.y + this.z * this.z); } manhattanLength() { return Math.abs(this.x) + Math.abs(this.y) + Math.abs(this.z); } normalize() { return this.divideScalar(this.length() || 1); } setLength(e) { return this.normalize().multiplyScalar(e); } lerp(e, t) { return this.x += (e.x - this.x) * t, this.y += (e.y - this.y) * t, this.z += (e.z - this.z) * t, this; } lerpVectors(e, t, i) { return this.x = e.x + (t.x - e.x) * i, this.y = e.y + (t.y - e.y) * i, this.z = e.z + (t.z - e.z) * i, this; } cross(e, t) { return t !== void 0 ? (console.warn("THREE.Vector3: .cross() now only accepts one argument. Use .crossVectors( a, b ) instead."), this.crossVectors(e, t)) : this.crossVectors(this, e); } crossVectors(e, t) { const i = e.x, r = e.y, s = e.z, o = t.x, a = t.y, c = t.z; return this.x = r * c - s * a, this.y = s * o - i * c, this.z = i * a - r * o, this; } projectOnVector(e) { const t = e.lengthSq(); if (t === 0) return this.set(0, 0, 0); const i = e.dot(this) / t; return this.copy(e).multiplyScalar(i); } projectOnPlane(e) { return Zu.copy(this).projectOnVector(e), this.sub(Zu); } reflect(e) { return this.sub(Zu.copy(e).multiplyScalar(2 * this.dot(e))); } angleTo(e) { const t = Math.sqrt(this.lengthSq() * e.lengthSq()); if (t === 0) return Math.PI / 2; const i = this.dot(e) / t; return Math.acos(gn(i, -1, 1)); } distanceTo(e) { return Math.sqrt(this.distanceToSquared(e)); } distanceToSquared(e) { const t = this.x - e.x, i = this.y - e.y, r = this.z - e.z; return t * t + i * i + r * r; } manhattanDistanceTo(e) { return Math.abs(this.x - e.x) + Math.abs(this.y - e.y) + Math.abs(this.z - e.z); } setFromSpherical(e) { return this.setFromSphericalCoords(e.radius, e.phi, e.theta); } setFromSphericalCoords(e, t, i) { const r = Math.sin(t) * e; return this.x = r * Math.sin(i), this.y = Math.cos(t) * e, this.z = r * Math.cos(i), this; } setFromCylindrical(e) { return this.setFromCylindricalCoords(e.radius, e.theta, e.y); } setFromCylindricalCoords(e, t, i) { return this.x = e * Math.sin(t), this.y = i, this.z = e * Math.cos(t), this; } setFromMatrixPosition(e) { const t = e.elements; return this.x = t[12], this.y = t[13], this.z = t[14], this; } setFromMatrixScale(e) { const t = this.setFromMatrixColumn(e, 0).length(), i = this.setFromMatrixColumn(e, 1).length(), r = this.setFromMatrixColumn(e, 2).length(); return this.x = t, this.y = i, this.z = r, this; } setFromMatrixColumn(e, t) { return this.fromArray(e.elements, t * 4); } setFromMatrix3Column(e, t) { return this.fromArray(e.elements, t * 3); } equals(e) { return e.x === this.x && e.y === this.y && e.z === this.z; } fromArray(e, t = 0) { return this.x = e[t], this.y = e[t + 1], this.z = e[t + 2], this; } toArray(e = [], t = 0) { return e[t] = this.x, e[t + 1] = this.y, e[t + 2] = this.z, e; } fromBufferAttribute(e, t, i) { return i !== void 0 && console.warn("THREE.Vector3: offset has been removed from .fromBufferAttribute()."), this.x = e.getX(t), this.y = e.getY(t), this.z = e.getZ(t), this; } random() { return this.x = Math.random(), this.y = Math.random(), this.z = Math.random(), this; } }; q.prototype.isVector3 = true; var Zu = new q(); var $m = new bn(); var Nn = class { constructor(e = new q(1 / 0, 1 / 0, 1 / 0), t = new q(-1 / 0, -1 / 0, -1 / 0)) { this.min = e, this.max = t; } set(e, t) { return this.min.copy(e), this.max.copy(t), this; } setFromArray(e) { let t = 1 / 0, i = 1 / 0, r = 1 / 0, s = -1 / 0, o = -1 / 0, a = -1 / 0; for (let c = 0, l = e.length; c < l; c += 3) { const d = e[c], h6 = e[c + 1], f = e[c + 2]; d < t && (t = d), h6 < i && (i = h6), f < r && (r = f), d > s && (s = d), h6 > o && (o = h6), f > a && (a = f); } return this.min.set(t, i, r), this.max.set(s, o, a), this; } setFromBufferAttribute(e) { let t = 1 / 0, i = 1 / 0, r = 1 / 0, s = -1 / 0, o = -1 / 0, a = -1 / 0; for (let c = 0, l = e.count; c < l; c++) { const d = e.getX(c), h6 = e.getY(c), f = e.getZ(c); d < t && (t = d), h6 < i && (i = h6), f < r && (r = f), d > s && (s = d), h6 > o && (o = h6), f > a && (a = f); } return this.min.set(t, i, r), this.max.set(s, o, a), this; } setFromPoints(e) { this.makeEmpty(); for (let t = 0, i = e.length; t < i; t++) this.expandByPoint(e[t]); return this; } setFromCenterAndSize(e, t) { const i = ha.copy(t).multiplyScalar(0.5); return this.min.copy(e).sub(i), this.max.copy(e).add(i), this; } setFromObject(e) { return this.makeEmpty(), this.expandByObject(e); } clone() { return new this.constructor().copy(this); } copy(e) { return this.min.copy(e.min), this.max.copy(e.max), this; } makeEmpty() { return this.min.x = this.min.y = this.min.z = 1 / 0, this.max.x = this.max.y = this.max.z = -1 / 0, this; } isEmpty() { return this.max.x < this.min.x || this.max.y < this.min.y || this.max.z < this.min.z; } getCenter(e) { return this.isEmpty() ? e.set(0, 0, 0) : e.addVectors(this.min, this.max).multiplyScalar(0.5); } getSize(e) { return this.isEmpty() ? e.set(0, 0, 0) : e.subVectors(this.max, this.min); } expandByPoint(e) { return this.min.min(e), this.max.max(e), this; } expandByVector(e) { return this.min.sub(e), this.max.add(e), this; } expandByScalar(e) { return this.min.addScalar(-e), this.max.addScalar(e), this; } expandByObject(e) { e.updateWorldMatrix(false, false); const t = e.geometry; t !== void 0 && (t.boundingBox === null && t.computeBoundingBox(), Xu.copy(t.boundingBox), Xu.applyMatrix4(e.matrixWorld), this.union(Xu)); const i = e.children; for (let r = 0, s = i.length; r < s; r++) this.expandByObject(i[r]); return this; } containsPoint(e) { return !(e.x < this.min.x || e.x > this.max.x || e.y < this.min.y || e.y > this.max.y || e.z < this.min.z || e.z > this.max.z); } containsBox(e) { return this.min.x <= e.min.x && e.max.x <= this.max.x && this.min.y <= e.min.y && e.max.y <= this.max.y && this.min.z <= e.min.z && e.max.z <= this.max.z; } getParameter(e, t) { return t.set( (e.x - this.min.x) / (this.max.x - this.min.x), (e.y - this.min.y) / (this.max.y - this.min.y), (e.z - this.min.z) / (this.max.z - this.min.z) ); } intersectsBox(e) { return !(e.max.x < this.min.x || e.min.x > this.max.x || e.max.y < this.min.y || e.min.y > this.max.y || e.max.z < this.min.z || e.min.z > this.max.z); } intersectsSphere(e) { return this.clampPoint(e.center, ha), ha.distanceToSquared(e.center) <= e.radius * e.radius; } intersectsPlane(e) { let t, i; return e.normal.x > 0 ? (t = e.normal.x * this.min.x, i = e.normal.x * this.max.x) : (t = e.normal.x * this.max.x, i = e.normal.x * this.min.x), e.normal.y > 0 ? (t += e.normal.y * this.min.y, i += e.normal.y * this.max.y) : (t += e.normal.y * this.max.y, i += e.normal.y * this.min.y), e.normal.z > 0 ? (t += e.normal.z * this.min.z, i += e.normal.z * this.max.z) : (t += e.normal.z * this.max.z, i += e.normal.z * this.min.z), t <= -e.constant && i >= -e.constant; } intersectsTriangle(e) { if (this.isEmpty()) return false; this.getCenter(da), Ol.subVectors(this.max, da), $s.subVectors(e.a, da), Zs.subVectors(e.b, da), Xs.subVectors(e.c, da), vr.subVectors(Zs, $s), yr.subVectors(Xs, Zs), ss.subVectors($s, Xs); let t = [ 0, -vr.z, vr.y, 0, -yr.z, yr.y, 0, -ss.z, ss.y, vr.z, 0, -vr.x, yr.z, 0, -yr.x, ss.z, 0, -ss.x, -vr.y, vr.x, 0, -yr.y, yr.x, 0, -ss.y, ss.x, 0 ]; return !Yu(t, $s, Zs, Xs, Ol) || (t = [1, 0, 0, 0, 1, 0, 0, 0, 1], !Yu(t, $s, Zs, Xs, Ol)) ? false : (Dl.crossVectors(vr, yr), t = [Dl.x, Dl.y, Dl.z], Yu(t, $s, Zs, Xs, Ol)); } clampPoint(e, t) { return t.copy(e).clamp(this.min, this.max); } distanceToPoint(e) { return ha.copy(e).clamp(this.min, this.max).sub(e).length(); } getBoundingSphere(e) { return this.getCenter(e.center), e.radius = this.getSize(ha).length() * 0.5, e; } intersect(e) { return this.min.max(e.min), this.max.min(e.max), this.isEmpty() && this.makeEmpty(), this; } union(e) { return this.min.min(e.min), this.max.max(e.max), this; } applyMatrix4(e) { return this.isEmpty() ? this : (Hi[0].set(this.min.x, this.min.y, this.min.z).applyMatrix4(e), Hi[1].set(this.min.x, this.min.y, this.max.z).applyMatrix4(e), Hi[2].set(this.min.x, this.max.y, this.min.z).applyMatrix4(e), Hi[3].set(this.min.x, this.max.y, this.max.z).applyMatrix4(e), Hi[4].set(this.max.x, this.min.y, this.min.z).applyMatrix4(e), Hi[5].set(this.max.x, this.min.y, this.max.z).applyMatrix4(e), Hi[6].set(this.max.x, this.max.y, this.min.z).applyMatrix4(e), Hi[7].set(this.max.x, this.max.y, this.max.z).applyMatrix4(e), this.setFromPoints(Hi), this); } translate(e) { return this.min.add(e), this.max.add(e), this; } equals(e) { return e.min.equals(this.min) && e.max.equals(this.max); } }; Nn.prototype.isBox3 = true; var Hi = [ new q(), new q(), new q(), new q(), new q(), new q(), new q(), new q() ]; var ha = new q(); var Xu = new Nn(); var $s = new q(); var Zs = new q(); var Xs = new q(); var vr = new q(); var yr = new q(); var ss = new q(); var da = new q(); var Ol = new q(); var Dl = new q(); var os = new q(); function Yu(n, e, t, i, r) { for (let s = 0, o = n.length - 3; s <= o; s += 3) { os.fromArray(n, s); const a = r.x * Math.abs(os.x) + r.y * Math.abs(os.y) + r.z * Math.abs(os.z), c = e.dot(os), l = t.dot(os), d = i.dot(os); if (Math.max(-Math.max(c, l, d), Math.min(c, l, d)) > a) return false; } return true; } var hF = new Nn(); var Zm = new q(); var Ju = new q(); var Ku = new q(); var pr = class { constructor(e = new q(), t = -1) { this.center = e, this.radius = t; } set(e, t) { return this.center.copy(e), this.radius = t, this; } setFromPoints(e, t) { const i = this.center; t !== void 0 ? i.copy(t) : hF.setFromPoints(e).getCenter(i); let r = 0; for (let s = 0, o = e.length; s < o; s++) r = Math.max(r, i.distanceToSquared(e[s])); return this.radius = Math.sqrt(r), this; } copy(e) { return this.center.copy(e.center), this.radius = e.radius, this; } isEmpty() { return this.radius < 0; } makeEmpty() { return this.center.set(0, 0, 0), this.radius = -1, this; } containsPoint(e) { return e.distanceToSquared(this.center) <= this.radius * this.radius; } distanceToPoint(e) { return e.distanceTo(this.center) - this.radius; } intersectsSphere(e) { const t = this.radius + e.radius; return e.center.distanceToSquared(this.center) <= t * t; } intersectsBox(e) { return e.intersectsSphere(this); } intersectsPlane(e) { return Math.abs(e.distanceToPoint(this.center)) <= this.radius; } clampPoint(e, t) { const i = this.center.distanceToSquared(e); return t.copy(e), i > this.radius * this.radius && (t.sub(this.center).normalize(), t.multiplyScalar(this.radius).add(this.center)), t; } getBoundingBox(e) { return this.isEmpty() ? (e.makeEmpty(), e) : (e.set(this.center, this.center), e.expandByScalar(this.radius), e); } applyMatrix4(e) { return this.center.applyMatrix4(e), this.radius = this.radius * e.getMaxScaleOnAxis(), this; } translate(e) { return this.center.add(e), this; } expandByPoint(e) { Ku.subVectors(e, this.center); const t = Ku.lengthSq(); if (t > this.radius * this.radius) { const i = Math.sqrt(t), r = (i - this.radius) * 0.5; this.center.add(Ku.multiplyScalar(r / i)), this.radius += r; } return this; } union(e) { return Ju.subVectors(e.center, this.center).normalize().multiplyScalar(e.radius), this.expandByPoint(Zm.copy(e.center).add(Ju)), this.expandByPoint(Zm.copy(e.center).sub(Ju)), this; } equals(e) { return e.center.equals(this.center) && e.radius === this.radius; } clone() { return new this.constructor().copy(this); } }; var Wi = new q(); var qu = new q(); var Nl = new q(); var br = new q(); var Qu = new q(); var Bl = new q(); var eh = new q(); var qr = class { constructor(e = new q(), t = new q(0, 0, -1)) { this.origin = e, this.direction = t; } set(e, t) { return this.origin.copy(e), this.direction.copy(t), this; } copy(e) { return this.origin.copy(e.origin), this.direction.copy(e.direction), this; } at(e, t) { return t.copy(this.direction).multiplyScalar(e).add(this.origin); } lookAt(e) { return this.direction.copy(e).sub(this.origin).normalize(), this; } recast(e) { return this.origin.copy(this.at(e, Wi)), this; } closestPointToPoint(e, t) { t.subVectors(e, this.origin); const i = t.dot(this.direction); return i < 0 ? t.copy(this.origin) : t.copy(this.direction).multiplyScalar(i).add(this.origin); } distanceToPoint(e) { return Math.sqrt(this.distanceSqToPoint(e)); } distanceSqToPoint(e) { const t = Wi.subVectors(e, this.origin).dot(this.direction); return t < 0 ? this.origin.distanceToSquared(e) : (Wi.copy(this.direction).multiplyScalar(t).add(this.origin), Wi.distanceToSquared(e)); } distanceSqToSegment(e, t, i, r) { qu.copy(e).add(t).multiplyScalar(0.5), Nl.copy(t).sub(e).normalize(), br.copy(this.origin).sub(qu); const s = e.distanceTo(t) * 0.5, o = -this.direction.dot(Nl), a = br.dot(this.direction), c = -br.dot(Nl), l = br.lengthSq(), d = Math.abs(1 - o * o); let h6, f, g, p; if (d > 0) if (h6 = o * c - a, f = o * a - c, p = s * d, h6 >= 0) if (f >= -p) if (f <= p) { const u = 1 / d; h6 *= u, f *= u, g = h6 * (h6 + o * f + 2 * a) + f * (o * h6 + f + 2 * c) + l; } else f = s, h6 = Math.max(0, -(o * f + a)), g = -h6 * h6 + f * (f + 2 * c) + l; else f = -s, h6 = Math.max(0, -(o * f + a)), g = -h6 * h6 + f * (f + 2 * c) + l; else f <= -p ? (h6 = Math.max(0, -(-o * s + a)), f = h6 > 0 ? -s : Math.min(Math.max(-s, -c), s), g = -h6 * h6 + f * (f + 2 * c) + l) : f <= p ? (h6 = 0, f = Math.min(Math.max(-s, -c), s), g = f * (f + 2 * c) + l) : (h6 = Math.max(0, -(o * s + a)), f = h6 > 0 ? s : Math.min(Math.max(-s, -c), s), g = -h6 * h6 + f * (f + 2 * c) + l); else f = o > 0 ? -s : s, h6 = Math.max(0, -(o * f + a)), g = -h6 * h6 + f * (f + 2 * c) + l; return i && i.copy(this.direction).multiplyScalar(h6).add(this.origin), r && r.copy(Nl).multiplyScalar(f).add(qu), g; } intersectSphere(e, t) { Wi.subVectors(e.center, this.origin); const i = Wi.dot(this.direction), r = Wi.dot(Wi) - i * i, s = e.radius * e.radius; if (r > s) return null; const o = Math.sqrt(s - r), a = i - o, c = i + o; return a < 0 && c < 0 ? null : a < 0 ? this.at(c, t) : this.at(a, t); } intersectsSphere(e) { return this.distanceSqToPoint(e.center) <= e.radius * e.radius; } distanceToPlane(e) { const t = e.normal.dot(this.direction); if (t === 0) return e.distanceToPoint(this.origin) === 0 ? 0 : null; const i = -(this.origin.dot(e.normal) + e.constant) / t; return i >= 0 ? i : null; } intersectPlane(e, t) { const i = this.distanceToPlane(e); return i === null ? null : this.at(i, t); } intersectsPlane(e) { const t = e.distanceToPoint(this.origin); return t === 0 || e.normal.dot(this.direction) * t < 0; } intersectBox(e, t) { let i, r, s, o, a, c; const l = 1 / this.direction.x, d = 1 / this.direction.y, h6 = 1 / this.direction.z, f = this.origin; return l >= 0 ? (i = (e.min.x - f.x) * l, r = (e.max.x - f.x) * l) : (i = (e.max.x - f.x) * l, r = (e.min.x - f.x) * l), d >= 0 ? (s = (e.min.y - f.y) * d, o = (e.max.y - f.y) * d) : (s = (e.max.y - f.y) * d, o = (e.min.y - f.y) * d), i > o || s > r || ((s > i || i !== i) && (i = s), (o < r || r !== r) && (r = o), h6 >= 0 ? (a = (e.min.z - f.z) * h6, c = (e.max.z - f.z) * h6) : (a = (e.max.z - f.z) * h6, c = (e.min.z - f.z) * h6), i > c || a > r) || ((a > i || i !== i) && (i = a), (c < r || r !== r) && (r = c), r < 0) ? null : this.at(i >= 0 ? i : r, t); } intersectsBox(e) { return this.intersectBox(e, Wi) !== null; } intersectTriangle(e, t, i, r, s) { Qu.subVectors(t, e), Bl.subVectors(i, e), eh.crossVectors(Qu, Bl); let o = this.direction.dot(eh), a; if (o > 0) { if (r) return null; a = 1; } else if (o < 0) a = -1, o = -o; else return null; br.subVectors(this.origin, e); const c = a * this.direction.dot(Bl.crossVectors(br, Bl)); if (c < 0) return null; const l = a * this.direction.dot(Qu.cross(br)); if (l < 0 || c + l > o) return null; const d = -a * br.dot(eh); return d < 0 ? null : this.at(d / o, s); } applyMatrix4(e) { return this.origin.applyMatrix4(e), this.direction.transformDirection(e), this; } equals(e) { return e.origin.equals(this.origin) && e.direction.equals(this.direction); } clone() { return new this.constructor().copy(this); } }; var Xe = class _Xe { constructor() { this.elements = [ 1, 0, 0, 0, 0, 1, 0, 0, 0, 0, 1, 0, 0, 0, 0, 1 ], arguments.length > 0 && console.error("THREE.Matrix4: the constructor no longer reads arguments. use .set() instead."); } set(e, t, i, r, s, o, a, c, l, d, h6, f, g, p, u, y) { const v = this.elements; return v[0] = e, v[4] = t, v[8] = i, v[12] = r, v[1] = s, v[5] = o, v[9] = a, v[13] = c, v[2] = l, v[6] = d, v[10] = h6, v[14] = f, v[3] = g, v[7] = p, v[11] = u, v[15] = y, this; } identity() { return this.set( 1, 0, 0, 0, 0, 1, 0, 0, 0, 0, 1, 0, 0, 0, 0, 1 ), this; } clone() { return new _Xe().fromArray(this.elements); } copy(e) { const t = this.elements, i = e.elements; return t[0] = i[0], t[1] = i[1], t[2] = i[2], t[3] = i[3], t[4] = i[4], t[5] = i[5], t[6] = i[6], t[7] = i[7], t[8] = i[8], t[9] = i[9], t[10] = i[10], t[11] = i[11], t[12] = i[12], t[13] = i[13], t[14] = i[14], t[15] = i[15], this; } copyPosition(e) { const t = this.elements, i = e.elements; return t[12] = i[12], t[13] = i[13], t[14] = i[14], this; } setFromMatrix3(e) { const t = e.elements; return this.set( t[0], t[3], t[6], 0, t[1], t[4], t[7], 0, t[2], t[5], t[8], 0, 0, 0, 0, 1 ), this; } extractBasis(e, t, i) { return e.setFromMatrixColumn(this, 0), t.setFromMatrixColumn(this, 1), i.setFromMatrixColumn(this, 2), this; } makeBasis(e, t, i) { return this.set( e.x, t.x, i.x, 0, e.y, t.y, i.y, 0, e.z, t.z, i.z, 0, 0, 0, 0, 1 ), this; } extractRotation(e) { const t = this.elements, i = e.elements, r = 1 / Ys.setFromMatrixColumn(e, 0).length(), s = 1 / Ys.setFromMatrixColumn(e, 1).length(), o = 1 / Ys.setFromMatrixColumn(e, 2).length(); return t[0] = i[0] * r, t[1] = i[1] * r, t[2] = i[2] * r, t[3] = 0, t[4] = i[4] * s, t[5] = i[5] * s, t[6] = i[6] * s, t[7] = 0, t[8] = i[8] * o, t[9] = i[9] * o, t[10] = i[10] * o, t[11] = 0, t[12] = 0, t[13] = 0, t[14] = 0, t[15] = 1, this; } makeRotationFromEuler(e) { e && e.isEuler || console.error("THREE.Matrix4: .makeRotationFromEuler() now expects a Euler rotation rather than a Vector3 and order."); const t = this.elements, i = e.x, r = e.y, s = e.z, o = Math.cos(i), a = Math.sin(i), c = Math.cos(r), l = Math.sin(r), d = Math.cos(s), h6 = Math.sin(s); if (e.order === "XYZ") { const f = o * d, g = o * h6, p = a * d, u = a * h6; t[0] = c * d, t[4] = -c * h6, t[8] = l, t[1] = g + p * l, t[5] = f - u * l, t[9] = -a * c, t[2] = u - f * l, t[6] = p + g * l, t[10] = o * c; } else if (e.order === "YXZ") { const f = c * d, g = c * h6, p = l * d, u = l * h6; t[0] = f + u * a, t[4] = p * a - g, t[8] = o * l, t[1] = o * h6, t[5] = o * d, t[9] = -a, t[2] = g * a - p, t[6] = u + f * a, t[10] = o * c; } else if (e.order === "ZXY") { const f = c * d, g = c * h6, p = l * d, u = l * h6; t[0] = f - u * a, t[4] = -o * h6, t[8] = p + g * a, t[1] = g + p * a, t[5] = o * d, t[9] = u - f * a, t[2] = -o * l, t[6] = a, t[10] = o * c; } else if (e.order === "ZYX") { const f = o * d, g = o * h6, p = a * d, u = a * h6; t[0] = c * d, t[4] = p * l - g, t[8] = f * l + u, t[1] = c * h6, t[5] = u * l + f, t[9] = g * l - p, t[2] = -l, t[6] = a * c, t[10] = o * c; } else if (e.order === "YZX") { const f = o * c, g = o * l, p = a * c, u = a * l; t[0] = c * d, t[4] = u - f * h6, t[8] = p * h6 + g, t[1] = h6, t[5] = o * d, t[9] = -a * d, t[2] = -l * d, t[6] = g * h6 + p, t[10] = f - u * h6; } else if (e.order === "XZY") { const f = o * c, g = o * l, p = a * c, u = a * l; t[0] = c * d, t[4] = -h6, t[8] = l * d, t[1] = f * h6 + u, t[5] = o * d, t[9] = g * h6 - p, t[2] = p * h6 - g, t[6] = a * d, t[10] = u * h6 + f; } return t[3] = 0, t[7] = 0, t[11] = 0, t[12] = 0, t[13] = 0, t[14] = 0, t[15] = 1, this; } makeRotationFromQuaternion(e) { return this.compose(dF, e, fF); } lookAt(e, t, i) { const r = this.elements; return Bn.subVectors(e, t), Bn.lengthSq() === 0 && (Bn.z = 1), Bn.normalize(), xr.crossVectors(i, Bn), xr.lengthSq() === 0 && (Math.abs(i.z) === 1 ? Bn.x += 1e-4 : Bn.z += 1e-4, Bn.normalize(), xr.crossVectors(i, Bn)), xr.normalize(), Ul.crossVectors(Bn, xr), r[0] = xr.x, r[4] = Ul.x, r[8] = Bn.x, r[1] = xr.y, r[5] = Ul.y, r[9] = Bn.y, r[2] = xr.z, r[6] = Ul.z, r[10] = Bn.z, this; } multiply(e, t) { return t !== void 0 ? (console.warn("THREE.Matrix4: .multiply() now only accepts one argument. Use .multiplyMatrices( a, b ) instead."), this.multiplyMatrices(e, t)) : this.multiplyMatrices(this, e); } premultiply(e) { return this.multiplyMatrices(e, this); } multiplyMatrices(e, t) { const i = e.elements, r = t.elements, s = this.elements, o = i[0], a = i[4], c = i[8], l = i[12], d = i[1], h6 = i[5], f = i[9], g = i[13], p = i[2], u = i[6], y = i[10], v = i[14], m = i[3], x = i[7], w = i[11], A = i[15], M = r[0], R = r[4], L = r[8], S = r[12], I = r[1], T = r[5], _ = r[9], E = r[13], C = r[2], P = r[6], b = r[10], F = r[14], D = r[3], N = r[7], B = r[11], U = r[15]; return s[0] = o * M + a * I + c * C + l * D, s[4] = o * R + a * T + c * P + l * N, s[8] = o * L + a * _ + c * b + l * B, s[12] = o * S + a * E + c * F + l * U, s[1] = d * M + h6 * I + f * C + g * D, s[5] = d * R + h6 * T + f * P + g * N, s[9] = d * L + h6 * _ + f * b + g * B, s[13] = d * S + h6 * E + f * F + g * U, s[2] = p * M + u * I + y * C + v * D, s[6] = p * R + u * T + y * P + v * N, s[10] = p * L + u * _ + y * b + v * B, s[14] = p * S + u * E + y * F + v * U, s[3] = m * M + x * I + w * C + A * D, s[7] = m * R + x * T + w * P + A * N, s[11] = m * L + x * _ + w * b + A * B, s[15] = m * S + x * E + w * F + A * U, this; } multiplyScalar(e) { const t = this.elements; return t[0] *= e, t[4] *= e, t[8] *= e, t[12] *= e, t[1] *= e, t[5] *= e, t[9] *= e, t[13] *= e, t[2] *= e, t[6] *= e, t[10] *= e, t[14] *= e, t[3] *= e, t[7] *= e, t[11] *= e, t[15] *= e, this; } determinant() { const e = this.elements, t = e[0], i = e[4], r = e[8], s = e[12], o = e[1], a = e[5], c = e[9], l = e[13], d = e[2], h6 = e[6], f = e[10], g = e[14], p = e[3], u = e[7], y = e[11], v = e[15]; return p * (+s * c * h6 - r * l * h6 - s * a * f + i * l * f + r * a * g - i * c * g) + u * (+t * c * g - t * l * f + s * o * f - r * o * g + r * l * d - s * c * d) + y * (+t * l * h6 - t * a * g - s * o * h6 + i * o * g + s * a * d - i * l * d) + v * (-r * a * d - t * c * h6 + t * a * f + r * o * h6 - i * o * f + i * c * d); } transpose() { const e = this.elements; let t; return t = e[1], e[1] = e[4], e[4] = t, t = e[2], e[2] = e[8], e[8] = t, t = e[6], e[6] = e[9], e[9] = t, t = e[3], e[3] = e[12], e[12] = t, t = e[7], e[7] = e[13], e[13] = t, t = e[11], e[11] = e[14], e[14] = t, this; } setPosition(e, t, i) { const r = this.elements; return e.isVector3 ? (r[12] = e.x, r[13] = e.y, r[14] = e.z) : (r[12] = e, r[13] = t, r[14] = i), this; } invert() { const e = this.elements, t = e[0], i = e[1], r = e[2], s = e[3], o = e[4], a = e[5], c = e[6], l = e[7], d = e[8], h6 = e[9], f = e[10], g = e[11], p = e[12], u = e[13], y = e[14], v = e[15], m = h6 * y * l - u * f * l + u * c * g - a * y * g - h6 * c * v + a * f * v, x = p * f * l - d * y * l - p * c * g + o * y * g + d * c * v - o * f * v, w = d * u * l - p * h6 * l + p * a * g - o * u * g - d * a * v + o * h6 * v, A = p * h6 * c - d * u * c - p * a * f + o * u * f + d * a * y - o * h6 * y, M = t * m + i * x + r * w + s * A; if (M === 0) return this.set(0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0); const R = 1 / M; return e[0] = m * R, e[1] = (u * f * s - h6 * y * s - u * r * g + i * y * g + h6 * r * v - i * f * v) * R, e[2] = (a * y * s - u * c * s + u * r * l - i * y * l - a * r * v + i * c * v) * R, e[3] = (h6 * c * s - a * f * s - h6 * r * l + i * f * l + a * r * g - i * c * g) * R, e[4] = x * R, e[5] = (d * y * s - p * f * s + p * r * g - t * y * g - d * r * v + t * f * v) * R, e[6] = (p * c * s - o * y * s - p * r * l + t * y * l + o * r * v - t * c * v) * R, e[7] = (o * f * s - d * c * s + d * r * l - t * f * l - o * r * g + t * c * g) * R, e[8] = w * R, e[9] = (p * h6 * s - d * u * s - p * i * g + t * u * g + d * i * v - t * h6 * v) * R, e[10] = (o * u * s - p * a * s + p * i * l - t * u * l - o * i * v + t * a * v) * R, e[11] = (d * a * s - o * h6 * s - d * i * l + t * h6 * l + o * i * g - t * a * g) * R, e[12] = A * R, e[13] = (d * u * r - p * h6 * r + p * i * f - t * u * f - d * i * y + t * h6 * y) * R, e[14] = (p * a * r - o * u * r - p * i * c + t * u * c + o * i * y - t * a * y) * R, e[15] = (o * h6 * r - d * a * r + d * i * c - t * h6 * c - o * i * f + t * a * f) * R, this; } scale(e) { const t = this.elements, i = e.x, r = e.y, s = e.z; return t[0] *= i, t[4] *= r, t[8] *= s, t[1] *= i, t[5] *= r, t[9] *= s, t[2] *= i, t[6] *= r, t[10] *= s, t[3] *= i, t[7] *= r, t[11] *= s, this; } getMaxScaleOnAxis() { const e = this.elements, t = e[0] * e[0] + e[1] * e[1] + e[2] * e[2], i = e[4] * e[4] + e[5] * e[5] + e[6] * e[6], r = e[8] * e[8] + e[9] * e[9] + e[10] * e[10]; return Math.sqrt(Math.max(t, i, r)); } makeTranslation(e, t, i) { return this.set( 1, 0, 0, e, 0, 1, 0, t, 0, 0, 1, i, 0, 0, 0, 1 ), this; } makeRotationX(e) { const t = Math.cos(e), i = Math.sin(e); return this.set( 1, 0, 0, 0, 0, t, -i, 0, 0, i, t, 0, 0, 0, 0, 1 ), this; } makeRotationY(e) { const t = Math.cos(e), i = Math.sin(e); return this.set( t, 0, i, 0, 0, 1, 0, 0, -i, 0, t, 0, 0, 0, 0, 1 ), this; } makeRotationZ(e) { const t = Math.cos(e), i = Math.sin(e); return this.set( t, -i, 0, 0, i, t, 0, 0, 0, 0, 1, 0, 0, 0, 0, 1 ), this; } makeRotationAxis(e, t) { const i = Math.cos(t), r = Math.sin(t), s = 1 - i, o = e.x, a = e.y, c = e.z, l = s * o, d = s * a; return this.set( l * o + i, l * a - r * c, l * c + r * a, 0, l * a + r * c, d * a + i, d * c - r * o, 0, l * c - r * a, d * c + r * o, s * c * c + i, 0, 0, 0, 0, 1 ), this; } makeScale(e, t, i) { return this.set( e, 0, 0, 0, 0, t, 0, 0, 0, 0, i, 0, 0, 0, 0, 1 ), this; } makeShear(e, t, i, r, s, o) { return this.set( 1, i, s, 0, e, 1, o, 0, t, r, 1, 0, 0, 0, 0, 1 ), this; } compose(e, t, i) { const r = this.elements, s = t._x, o = t._y, a = t._z, c = t._w, l = s + s, d = o + o, h6 = a + a, f = s * l, g = s * d, p = s * h6, u = o * d, y = o * h6, v = a * h6, m = c * l, x = c * d, w = c * h6, A = i.x, M = i.y, R = i.z; return r[0] = (1 - (u + v)) * A, r[1] = (g + w) * A, r[2] = (p - x) * A, r[3] = 0, r[4] = (g - w) * M, r[5] = (1 - (f + v)) * M, r[6] = (y + m) * M, r[7] = 0, r[8] = (p + x) * R, r[9] = (y - m) * R, r[10] = (1 - (f + u)) * R, r[11] = 0, r[12] = e.x, r[13] = e.y, r[14] = e.z, r[15] = 1, this; } decompose(e, t, i) { const r = this.elements; let s = Ys.set(r[0], r[1], r[2]).length(); const o = Ys.set(r[4], r[5], r[6]).length(), a = Ys.set(r[8], r[9], r[10]).length(); this.determinant() < 0 && (s = -s), e.x = r[12], e.y = r[13], e.z = r[14], ri.copy(this); const l = 1 / s, d = 1 / o, h6 = 1 / a; return ri.elements[0] *= l, ri.elements[1] *= l, ri.elements[2] *= l, ri.elements[4] *= d, ri.elements[5] *= d, ri.elements[6] *= d, ri.elements[8] *= h6, ri.elements[9] *= h6, ri.elements[10] *= h6, t.setFromRotationMatrix(ri), i.x = s, i.y = o, i.z = a, this; } makePerspective(e, t, i, r, s, o) { o === void 0 && console.warn("THREE.Matrix4: .makePerspective() has been redefined and has a new signature. Please check the docs."); const a = this.elements, c = 2 * s / (t - e), l = 2 * s / (i - r), d = (t + e) / (t - e), h6 = (i + r) / (i - r), f = -(o + s) / (o - s), g = -2 * o * s / (o - s); return a[0] = c, a[4] = 0, a[8] = d, a[12] = 0, a[1] = 0, a[5] = l, a[9] = h6, a[13] = 0, a[2] = 0, a[6] = 0, a[10] = f, a[14] = g, a[3] = 0, a[7] = 0, a[11] = -1, a[15] = 0, this; } makeOrthographic(e, t, i, r, s, o) { const a = this.elements, c = 1 / (t - e), l = 1 / (i - r), d = 1 / (o - s), h6 = (t + e) * c, f = (i + r) * l, g = (o + s) * d; return a[0] = 2 * c, a[4] = 0, a[8] = 0, a[12] = -h6, a[1] = 0, a[5] = 2 * l, a[9] = 0, a[13] = -f, a[2] = 0, a[6] = 0, a[10] = -2 * d, a[14] = -g, a[3] = 0, a[7] = 0, a[11] = 0, a[15] = 1, this; } equals(e) { const t = this.elements, i = e.elements; for (let r = 0; r < 16; r++) if (t[r] !== i[r]) return false; return true; } fromArray(e, t = 0) { for (let i = 0; i < 16; i++) this.elements[i] = e[i + t]; return this; } toArray(e = [], t = 0) { const i = this.elements; return e[t] = i[0], e[t + 1] = i[1], e[t + 2] = i[2], e[t + 3] = i[3], e[t + 4] = i[4], e[t + 5] = i[5], e[t + 6] = i[6], e[t + 7] = i[7], e[t + 8] = i[8], e[t + 9] = i[9], e[t + 10] = i[10], e[t + 11] = i[11], e[t + 12] = i[12], e[t + 13] = i[13], e[t + 14] = i[14], e[t + 15] = i[15], e; } }; Xe.prototype.isMatrix4 = true; var Ys = new q(); var ri = new Xe(); var dF = new q(0, 0, 0); var fF = new q(1, 1, 1); var xr = new q(); var Ul = new q(); var Bn = new q(); var Xm = new Xe(); var Ym = new bn(); var Us = class _Us { constructor(e = 0, t = 0, i = 0, r = _Us.DefaultOrder) { this._x = e, this._y = t, this._z = i, this._order = r; } get x() { return this._x; } set x(e) { this._x = e, this._onChangeCallback(); } get y() { return this._y; } set y(e) { this._y = e, this._onChangeCallback(); } get z() { return this._z; } set z(e) { this._z = e, this._onChangeCallback(); } get order() { return this._order; } set order(e) { this._order = e, this._onChangeCallback(); } set(e, t, i, r = this._order) { return this._x = e, this._y = t, this._z = i, this._order = r, this._onChangeCallback(), this; } clone() { return new this.constructor(this._x, this._y, this._z, this._order); } copy(e) { return this._x = e._x, this._y = e._y, this._z = e._z, this._order = e._order, this._onChangeCallback(), this; } setFromRotationMatrix(e, t = this._order, i = true) { const r = e.elements, s = r[0], o = r[4], a = r[8], c = r[1], l = r[5], d = r[9], h6 = r[2], f = r[6], g = r[10]; switch (t) { case "XYZ": this._y = Math.asin(gn(a, -1, 1)), Math.abs(a) < 0.9999999 ? (this._x = Math.atan2(-d, g), this._z = Math.atan2(-o, s)) : (this._x = Math.atan2(f, l), this._z = 0); break; case "YXZ": this._x = Math.asin(-gn(d, -1, 1)), Math.abs(d) < 0.9999999 ? (this._y = Math.atan2(a, g), this._z = Math.atan2(c, l)) : (this._y = Math.atan2(-h6, s), this._z = 0); break; case "ZXY": this._x = Math.asin(gn(f, -1, 1)), Math.abs(f) < 0.9999999 ? (this._y = Math.atan2(-h6, g), this._z = Math.atan2(-o, l)) : (this._y = 0, this._z = Math.atan2(c, s)); break; case "ZYX": this._y = Math.asin(-gn(h6, -1, 1)), Math.abs(h6) < 0.9999999 ? (this._x = Math.atan2(f, g), this._z = Math.atan2(c, s)) : (this._x = 0, this._z = Math.atan2(-o, l)); break; case "YZX": this._z = Math.asin(gn(c, -1, 1)), Math.abs(c) < 0.9999999 ? (this._x = Math.atan2(-d, l), this._y = Math.atan2(-h6, s)) : (this._x = 0, this._y = Math.atan2(a, g)); break; case "XZY": this._z = Math.asin(-gn(o, -1, 1)), Math.abs(o) < 0.9999999 ? (this._x = Math.atan2(f, l), this._y = Math.atan2(a, s)) : (this._x = Math.atan2(-d, g), this._y = 0); break; default: console.warn("THREE.Euler: .setFromRotationMatrix() encountered an unknown order: " + t); } return this._order = t, i === true && this._onChangeCallback(), this; } setFromQuaternion(e, t, i) { return Xm.makeRotationFromQuaternion(e), this.setFromRotationMatrix(Xm, t, i); } setFromVector3(e, t = this._order) { return this.set(e.x, e.y, e.z, t); } reorder(e) { return Ym.setFromEuler(this), this.setFromQuaternion(Ym, e); } equals(e) { return e._x === this._x && e._y === this._y && e._z === this._z && e._order === this._order; } fromArray(e) { return this._x = e[0], this._y = e[1], this._z = e[2], e[3] !== void 0 && (this._order = e[3]), this._onChangeCallback(), this; } toArray(e = [], t = 0) { return e[t] = this._x, e[t + 1] = this._y, e[t + 2] = this._z, e[t + 3] = this._order, e; } toVector3(e) { return e ? e.set(this._x, this._y, this._z) : new q(this._x, this._y, this._z); } _onChange(e) { return this._onChangeCallback = e, this; } _onChangeCallback() { } }; Us.prototype.isEuler = true; Us.DefaultOrder = "XYZ"; Us.RotationOrders = ["XYZ", "YZX", "ZXY", "XZY", "YXZ", "ZYX"]; var Cf = class { constructor() { this.mask = 1; } set(e) { this.mask = 1 << e | 0; } enable(e) { this.mask |= 1 << e | 0; } enableAll() { this.mask = -1; } toggle(e) { this.mask ^= 1 << e | 0; } disable(e) { this.mask &= ~(1 << e | 0); } disableAll() { this.mask = 0; } test(e) { return (this.mask & e.mask) !== 0; } }; var pF = 0; var Jm = new q(); var Js = new bn(); var ji = new Xe(); var zl = new q(); var fa = new q(); var mF = new q(); var gF = new bn(); var Km = new q(1, 0, 0); var qm = new q(0, 1, 0); var Qm = new q(0, 0, 1); var vF = { type: "added" }; var eg = { type: "removed" }; var ut = class _ut extends Kr { constructor() { super(), Object.defineProperty(this, "id", { value: pF++ }), this.uuid = Hn(), this.name = "", this.type = "Object3D", this.parent = null, this.children = [], this.up = _ut.DefaultUp.clone(); const e = new q(), t = new Us(), i = new bn(), r = new q(1, 1, 1); function s() { i.setFromEuler(t, false); } function o() { t.setFromQuaternion(i, void 0, false); } t._onChange(s), i._onChange(o), Object.defineProperties(this, { position: { configurable: true, enumerable: true, value: e }, rotation: { configurable: true, enumerable: true, value: t }, quaternion: { configurable: true, enumerable: true, value: i }, scale: { configurable: true, enumerable: true, value: r }, modelViewMatrix: { value: new Xe() }, normalMatrix: { value: new rn() } }), this.matrix = new Xe(), this.matrixWorld = new Xe(), this.matrixAutoUpdate = _ut.DefaultMatrixAutoUpdate, this.matrixWorldNeedsUpdate = false, this.layers = new Cf(), this.visible = true, this.castShadow = false, this.receiveShadow = false, this.frustumCulled = true, this.renderOrder = 0, this.animations = [], this.userData = {}; } onBeforeRender() { } onAfterRender() { } applyMatrix4(e) { this.matrixAutoUpdate && this.updateMatrix(), this.matrix.premultiply(e), this.matrix.decompose(this.position, this.quaternion, this.scale); } applyQuaternion(e) { return this.quaternion.premultiply(e), this; } setRotationFromAxisAngle(e, t) { this.quaternion.setFromAxisAngle(e, t); } setRotationFromEuler(e) { this.quaternion.setFromEuler(e, true); } setRotationFromMatrix(e) { this.quaternion.setFromRotationMatrix(e); } setRotationFromQuaternion(e) { this.quaternion.copy(e); } rotateOnAxis(e, t) { return Js.setFromAxisAngle(e, t), this.quaternion.multiply(Js), this; } rotateOnWorldAxis(e, t) { return Js.setFromAxisAngle(e, t), this.quaternion.premultiply(Js), this; } rotateX(e) { return this.rotateOnAxis(Km, e); } rotateY(e) { return this.rotateOnAxis(qm, e); } rotateZ(e) { return this.rotateOnAxis(Qm, e); } translateOnAxis(e, t) { return Jm.copy(e).applyQuaternion(this.quaternion), this.position.add(Jm.multiplyScalar(t)), this; } translateX(e) { return this.translateOnAxis(Km, e); } translateY(e) { return this.translateOnAxis(qm, e); } translateZ(e) { return this.translateOnAxis(Qm, e); } localToWorld(e) { return e.applyMatrix4(this.matrixWorld); } worldToLocal(e) { return e.applyMatrix4(ji.copy(this.matrixWorld).invert()); } lookAt(e, t, i) { e.isVector3 ? zl.copy(e) : zl.set(e, t, i); const r = this.parent; this.updateWorldMatrix(true, false), fa.setFromMatrixPosition(this.matrixWorld), this.isCamera || this.isLight ? ji.lookAt(fa, zl, this.up) : ji.lookAt(zl, fa, this.up), this.quaternion.setFromRotationMatrix(ji), r && (ji.extractRotation(r.matrixWorld), Js.setFromRotationMatrix(ji), this.quaternion.premultiply(Js.invert())); } add(e) { if (arguments.length > 1) { for (let t = 0; t < arguments.length; t++) this.add(arguments[t]); return this; } return e === this ? (console.error("THREE.Object3D.add: object can't be added as a child of itself.", e), this) : (e && e.isObject3D ? (e.parent !== null && e.parent.remove(e), e.parent = this, this.children.push(e), e.dispatchEvent(vF)) : console.error("THREE.Object3D.add: object not an instance of THREE.Object3D.", e), this); } remove(e) { if (arguments.length > 1) { for (let i = 0; i < arguments.length; i++) this.remove(arguments[i]); return this; } const t = this.children.indexOf(e); return t !== -1 && (e.parent = null, this.children.splice(t, 1), e.dispatchEvent(eg)), this; } removeFromParent() { const e = this.parent; return e !== null && e.remove(this), this; } clear() { for (let e = 0; e < this.children.length; e++) { const t = this.children[e]; t.parent = null, t.dispatchEvent(eg); } return this.children.length = 0, this; } attach(e) { return this.updateWorldMatrix(true, false), ji.copy(this.matrixWorld).invert(), e.parent !== null && (e.parent.updateWorldMatrix(true, false), ji.multiply(e.parent.matrixWorld)), e.applyMatrix4(ji), this.add(e), e.updateWorldMatrix(false, true), this; } getObjectById(e) { return this.getObjectByProperty("id", e); } getObjectByName(e) { return this.getObjectByProperty("name", e); } getObjectByProperty(e, t) { if (this[e] === t) return this; for (let i = 0, r = this.children.length; i < r; i++) { const o = this.children[i].getObjectByProperty(e, t); if (o !== void 0) return o; } } getWorldPosition(e) { return this.updateWorldMatrix(true, false), e.setFromMatrixPosition(this.matrixWorld); } getWorldQuaternion(e) { return this.updateWorldMatrix(true, false), this.matrixWorld.decompose(fa, e, mF), e; } getWorldScale(e) { return this.updateWorldMatrix(true, false), this.matrixWorld.decompose(fa, gF, e), e; } getWorldDirection(e) { this.updateWorldMatrix(true, false); const t = this.matrixWorld.elements; return e.set(t[8], t[9], t[10]).normalize(); } raycast() { } traverse(e) { e(this); const t = this.children; for (let i = 0, r = t.length; i < r; i++) t[i].traverse(e); } traverseVisible(e) { if (this.visible === false) return; e(this); const t = this.children; for (let i = 0, r = t.length; i < r; i++) t[i].traverseVisible(e); } traverseAncestors(e) { const t = this.parent; t !== null && (e(t), t.traverseAncestors(e)); } updateMatrix() { this.matrix.compose(this.position, this.quaternion, this.scale), this.matrixWorldNeedsUpdate = true; } updateMatrixWorld(e) { this.matrixAutoUpdate && this.updateMatrix(), (this.matrixWorldNeedsUpdate || e) && (this.parent === null ? this.matrixWorld.copy(this.matrix) : this.matrixWorld.multiplyMatrices(this.parent.matrixWorld, this.matrix), this.matrixWorldNeedsUpdate = false, e = true); const t = this.children; for (let i = 0, r = t.length; i < r; i++) t[i].updateMatrixWorld(e); } updateWorldMatrix(e, t) { const i = this.parent; if (e === true && i !== null && i.updateWorldMatrix(true, false), this.matrixAutoUpdate && this.updateMatrix(), this.parent === null ? this.matrixWorld.copy(this.matrix) : this.matrixWorld.multiplyMatrices(this.parent.matrixWorld, this.matrix), t === true) { const r = this.children; for (let s = 0, o = r.length; s < o; s++) r[s].updateWorldMatrix(false, true); } } toJSON(e) { const t = e === void 0 || typeof e == "string", i = {}; t && (e = { geometries: {}, materials: {}, textures: {}, images: {}, shapes: {}, skeletons: {}, animations: {} }, i.metadata = { version: 4.5, type: "Object", generator: "Object3D.toJSON" }); const r = {}; r.uuid = this.uuid, r.type = this.type, this.name !== "" && (r.name = this.name), this.castShadow === true && (r.castShadow = true), this.receiveShadow === true && (r.receiveShadow = true), this.visible === false && (r.visible = false), this.frustumCulled === false && (r.frustumCulled = false), this.renderOrder !== 0 && (r.renderOrder = this.renderOrder), JSON.stringify(this.userData) !== "{}" && (r.userData = this.userData), r.layers = this.layers.mask, r.matrix = this.matrix.toArray(), this.matrixAutoUpdate === false && (r.matrixAutoUpdate = false), this.isInstancedMesh && (r.type = "InstancedMesh", r.count = this.count, r.instanceMatrix = this.instanceMatrix.toJSON(), this.instanceColor !== null && (r.instanceColor = this.instanceColor.toJSON())); function s(a, c) { return a[c.uuid] === void 0 && (a[c.uuid] = c.toJSON(e)), c.uuid; } if (this.isScene) this.background && (this.background.isColor ? r.background = this.background.toJSON() : this.background.isTexture && (r.background = this.background.toJSON(e).uuid)), this.environment && this.environment.isTexture && (r.environment = this.environment.toJSON(e).uuid); else if (this.isMesh || this.isLine || this.isPoints) { r.geometry = s(e.geometries, this.geometry); const a = this.geometry.parameters; if (a !== void 0 && a.shapes !== void 0) { const c = a.shapes; if (Array.isArray(c)) for (let l = 0, d = c.length; l < d; l++) { const h6 = c[l]; s(e.shapes, h6); } else s(e.shapes, c); } } if (this.isSkinnedMesh && (r.bindMode = this.bindMode, r.bindMatrix = this.bindMatrix.toArray(), this.skeleton !== void 0 && (s(e.skeletons, this.skeleton), r.skeleton = this.skeleton.uuid)), this.material !== void 0) if (Array.isArray(this.material)) { const a = []; for (let c = 0, l = this.material.length; c < l; c++) a.push(s(e.materials, this.material[c])); r.material = a; } else r.material = s(e.materials, this.material); if (this.children.length > 0) { r.children = []; for (let a = 0; a < this.children.length; a++) r.children.push(this.children[a].toJSON(e).object); } if (this.animations.length > 0) { r.animations = []; for (let a = 0; a < this.animations.length; a++) { const c = this.animations[a]; r.animations.push(s(e.animations, c)); } } if (t) { const a = o(e.geometries), c = o(e.materials), l = o(e.textures), d = o(e.images), h6 = o(e.shapes), f = o(e.skeletons), g = o(e.animations); a.length > 0 && (i.geometries = a), c.length > 0 && (i.materials = c), l.length > 0 && (i.textures = l), d.length > 0 && (i.images = d), h6.length > 0 && (i.shapes = h6), f.length > 0 && (i.skeletons = f), g.length > 0 && (i.animations = g); } return i.object = r, i; function o(a) { const c = []; for (const l in a) { const d = a[l]; delete d.metadata, c.push(d); } return c; } } clone(e) { return new this.constructor().copy(this, e); } copy(e, t = true) { if (this.name = e.name, this.up.copy(e.up), this.position.copy(e.position), this.rotation.order = e.rotation.order, this.quaternion.copy(e.quaternion), this.scale.copy(e.scale), this.matrix.copy(e.matrix), this.matrixWorld.copy(e.matrixWorld), this.matrixAutoUpdate = e.matrixAutoUpdate, this.matrixWorldNeedsUpdate = e.matrixWorldNeedsUpdate, this.layers.mask = e.layers.mask, this.visible = e.visible, this.castShadow = e.castShadow, this.receiveShadow = e.receiveShadow, this.frustumCulled = e.frustumCulled, this.renderOrder = e.renderOrder, this.userData = JSON.parse(JSON.stringify(e.userData)), t === true) for (let i = 0; i < e.children.length; i++) { const r = e.children[i]; this.add(r.clone()); } return this; } }; ut.DefaultUp = new q(0, 1, 0); ut.DefaultMatrixAutoUpdate = true; ut.prototype.isObject3D = true; var si = new q(); var $i = new q(); var th = new q(); var Zi = new q(); var Ks = new q(); var qs = new q(); var tg = new q(); var nh = new q(); var ih = new q(); var rh = new q(); var Zt = class _Zt { constructor(e = new q(), t = new q(), i = new q()) { this.a = e, this.b = t, this.c = i; } static getNormal(e, t, i, r) { r.subVectors(i, t), si.subVectors(e, t), r.cross(si); const s = r.lengthSq(); return s > 0 ? r.multiplyScalar(1 / Math.sqrt(s)) : r.set(0, 0, 0); } // static/instance method to calculate barycentric coordinates // based on: http://www.blackpawn.com/texts/pointinpoly/default.html static getBarycoord(e, t, i, r, s) { si.subVectors(r, t), $i.subVectors(i, t), th.subVectors(e, t); const o = si.dot(si), a = si.dot($i), c = si.dot(th), l = $i.dot($i), d = $i.dot(th), h6 = o * l - a * a; if (h6 === 0) return s.set(-2, -1, -1); const f = 1 / h6, g = (l * c - a * d) * f, p = (o * d - a * c) * f; return s.set(1 - g - p, p, g); } static containsPoint(e, t, i, r) { return this.getBarycoord(e, t, i, r, Zi), Zi.x >= 0 && Zi.y >= 0 && Zi.x + Zi.y <= 1; } static getUV(e, t, i, r, s, o, a, c) { return this.getBarycoord(e, t, i, r, Zi), c.set(0, 0), c.addScaledVector(s, Zi.x), c.addScaledVector(o, Zi.y), c.addScaledVector(a, Zi.z), c; } static isFrontFacing(e, t, i, r) { return si.subVectors(i, t), $i.subVectors(e, t), si.cross($i).dot(r) < 0; } set(e, t, i) { return this.a.copy(e), this.b.copy(t), this.c.copy(i), this; } setFromPointsAndIndices(e, t, i, r) { return this.a.copy(e[t]), this.b.copy(e[i]), this.c.copy(e[r]), this; } clone() { return new this.constructor().copy(this); } copy(e) { return this.a.copy(e.a), this.b.copy(e.b), this.c.copy(e.c), this; } getArea() { return si.subVectors(this.c, this.b), $i.subVectors(this.a, this.b), si.cross($i).length() * 0.5; } getMidpoint(e) { return e.addVectors(this.a, this.b).add(this.c).multiplyScalar(1 / 3); } getNormal(e) { return _Zt.getNormal(this.a, this.b, this.c, e); } getPlane(e) { return e.setFromCoplanarPoints(this.a, this.b, this.c); } getBarycoord(e, t) { return _Zt.getBarycoord(e, this.a, this.b, this.c, t); } getUV(e, t, i, r, s) { return _Zt.getUV(e, this.a, this.b, this.c, t, i, r, s); } containsPoint(e) { return _Zt.containsPoint(e, this.a, this.b, this.c); } isFrontFacing(e) { return _Zt.isFrontFacing(this.a, this.b, this.c, e); } intersectsBox(e) { return e.intersectsTriangle(this); } closestPointToPoint(e, t) { const i = this.a, r = this.b, s = this.c; let o, a; Ks.subVectors(r, i), qs.subVectors(s, i), nh.subVectors(e, i); const c = Ks.dot(nh), l = qs.dot(nh); if (c <= 0 && l <= 0) return t.copy(i); ih.subVectors(e, r); const d = Ks.dot(ih), h6 = qs.dot(ih); if (d >= 0 && h6 <= d) return t.copy(r); const f = c * h6 - d * l; if (f <= 0 && c >= 0 && d <= 0) return o = c / (c - d), t.copy(i).addScaledVector(Ks, o); rh.subVectors(e, s); const g = Ks.dot(rh), p = qs.dot(rh); if (p >= 0 && g <= p) return t.copy(s); const u = g * l - c * p; if (u <= 0 && l >= 0 && p <= 0) return a = l / (l - p), t.copy(i).addScaledVector(qs, a); const y = d * p - g * h6; if (y <= 0 && h6 - d >= 0 && g - p >= 0) return tg.subVectors(s, r), a = (h6 - d) / (h6 - d + (g - p)), t.copy(r).addScaledVector(tg, a); const v = 1 / (y + u + f); return o = u * v, a = f * v, t.copy(i).addScaledVector(Ks, o).addScaledVector(qs, a); } equals(e) { return e.a.equals(this.a) && e.b.equals(this.b) && e.c.equals(this.c); } }; var yF = 0; var tn = class extends Kr { constructor() { super(), Object.defineProperty(this, "id", { value: yF++ }), this.uuid = Hn(), this.name = "", this.type = "Material", this.fog = true, this.blending = vo, this.side = Hr, this.vertexColors = false, this.opacity = 1, this.transparent = false, this.blendSrc = bf, this.blendDst = xf, this.blendEquation = ps, this.blendSrcAlpha = null, this.blendDstAlpha = null, this.blendEquationAlpha = null, this.depthFunc = Vc, this.depthTest = true, this.depthWrite = true, this.stencilWriteMask = 255, this.stencilFunc = qb, this.stencilRef = 0, this.stencilFuncMask = 255, this.stencilFail = Lc, this.stencilZFail = Lc, this.stencilZPass = Lc, this.stencilWrite = false, this.clippingPlanes = null, this.clipIntersection = false, this.clipShadows = false, this.shadowSide = null, this.colorWrite = true, this.precision = null, this.polygonOffset = false, this.polygonOffsetFactor = 0, this.polygonOffsetUnits = 0, this.dithering = false, this.alphaTest = 0, this.alphaToCoverage = false, this.premultipliedAlpha = false, this.visible = true, this.toneMapped = true, this.userData = {}, this.version = 0; } onBuild() { } onBeforeCompile() { } customProgramCacheKey() { return this.onBeforeCompile.toString(); } setValues(e) { if (e !== void 0) for (const t in e) { const i = e[t]; if (i === void 0) { console.warn("THREE.Material: '" + t + "' parameter is undefined."); continue; } if (t === "shading") { console.warn("THREE." + this.type + ": .shading has been removed. Use the boolean .flatShading instead."), this.flatShading = i === yf; continue; } const r = this[t]; if (r === void 0) { console.warn("THREE." + this.type + ": '" + t + "' is not a property of this material."); continue; } r && r.isColor ? r.set(i) : r && r.isVector3 && i && i.isVector3 ? r.copy(i) : this[t] = i; } } toJSON(e) { const t = e === void 0 || typeof e == "string"; t && (e = { textures: {}, images: {} }); const i = { metadata: { version: 4.5, type: "Material", generator: "Material.toJSON" } }; i.uuid = this.uuid, i.type = this.type, this.name !== "" && (i.name = this.name), this.color && this.color.isColor && (i.color = this.color.getHex()), this.roughness !== void 0 && (i.roughness = this.roughness), this.metalness !== void 0 && (i.metalness = this.metalness), this.sheen && this.sheen.isColor && (i.sheen = this.sheen.getHex()), this.emissive && this.emissive.isColor && (i.emissive = this.emissive.getHex()), this.emissiveIntensity && this.emissiveIntensity !== 1 && (i.emissiveIntensity = this.emissiveIntensity), this.specular && this.specular.isColor && (i.specular = this.specular.getHex()), this.shininess !== void 0 && (i.shininess = this.shininess), this.clearcoat !== void 0 && (i.clearcoat = this.clearcoat), this.clearcoatRoughness !== void 0 && (i.clearcoatRoughness = this.clearcoatRoughness), this.clearcoatMap && this.clearcoatMap.isTexture && (i.clearcoatMap = this.clearcoatMap.toJSON(e).uuid), this.clearcoatRoughnessMap && this.clearcoatRoughnessMap.isTexture && (i.clearcoatRoughnessMap = this.clearcoatRoughnessMap.toJSON(e).uuid), this.clearcoatNormalMap && this.clearcoatNormalMap.isTexture && (i.clearcoatNormalMap = this.clearcoatNormalMap.toJSON(e).uuid, i.clearcoatNormalScale = this.clearcoatNormalScale.toArray()), this.map && this.map.isTexture && (i.map = this.map.toJSON(e).uuid), this.matcap && this.matcap.isTexture && (i.matcap = this.matcap.toJSON(e).uuid), this.alphaMap && this.alphaMap.isTexture && (i.alphaMap = this.alphaMap.toJSON(e).uuid), this.lightMap && this.lightMap.isTexture && (i.lightMap = this.lightMap.toJSON(e).uuid, i.lightMapIntensity = this.lightMapIntensity), this.aoMap && this.aoMap.isTexture && (i.aoMap = this.aoMap.toJSON(e).uuid, i.aoMapIntensity = this.aoMapIntensity), this.bumpMap && this.bumpMap.isTexture && (i.bumpMap = this.bumpMap.toJSON(e).uuid, i.bumpScale = this.bumpScale), this.normalMap && this.normalMap.isTexture && (i.normalMap = this.normalMap.toJSON(e).uuid, i.normalMapType = this.normalMapType, i.normalScale = this.normalScale.toArray()), this.displacementMap && this.displacementMap.isTexture && (i.displacementMap = this.displacementMap.toJSON(e).uuid, i.displacementScale = this.displacementScale, i.displacementBias = this.displacementBias), this.roughnessMap && this.roughnessMap.isTexture && (i.roughnessMap = this.roughnessMap.toJSON(e).uuid), this.metalnessMap && this.metalnessMap.isTexture && (i.metalnessMap = this.metalnessMap.toJSON(e).uuid), this.emissiveMap && this.emissiveMap.isTexture && (i.emissiveMap = this.emissiveMap.toJSON(e).uuid), this.specularMap && this.specularMap.isTexture && (i.specularMap = this.specularMap.toJSON(e).uuid), this.envMap && this.envMap.isTexture && (i.envMap = this.envMap.toJSON(e).uuid, this.combine !== void 0 && (i.combine = this.combine)), this.envMapIntensity !== void 0 && (i.envMapIntensity = this.envMapIntensity), this.reflectivity !== void 0 && (i.reflectivity = this.reflectivity), this.refractionRatio !== void 0 && (i.refractionRatio = this.refractionRatio), this.gradientMap && this.gradientMap.isTexture && (i.gradientMap = this.gradientMap.toJSON(e).uuid), this.transmission !== void 0 && (i.transmission = this.transmission), this.transmissionMap && this.transmissionMap.isTexture && (i.transmissionMap = this.transmissionMap.toJSON(e).uuid), this.thickness !== void 0 && (i.thickness = this.thickness), this.thicknessMap && this.thicknessMap.isTexture && (i.thicknessMap = this.thicknessMap.toJSON(e).uuid), this.attenuationDistance !== void 0 && (i.attenuationDistance = this.attenuationDistance), this.attenuationColor !== void 0 && (i.attenuationColor = this.attenuationColor.getHex()), this.size !== void 0 && (i.size = this.size), this.shadowSide !== null && (i.shadowSide = this.shadowSide), this.sizeAttenuation !== void 0 && (i.sizeAttenuation = this.sizeAttenuation), this.blending !== vo && (i.blending = this.blending), this.side !== Hr && (i.side = this.side), this.vertexColors && (i.vertexColors = true), this.opacity < 1 && (i.opacity = this.opacity), this.transparent === true && (i.transparent = this.transparent), i.depthFunc = this.depthFunc, i.depthTest = this.depthTest, i.depthWrite = this.depthWrite, i.colorWrite = this.colorWrite, i.stencilWrite = this.stencilWrite, i.stencilWriteMask = this.stencilWriteMask, i.stencilFunc = this.stencilFunc, i.stencilRef = this.stencilRef, i.stencilFuncMask = this.stencilFuncMask, i.stencilFail = this.stencilFail, i.stencilZFail = this.stencilZFail, i.stencilZPass = this.stencilZPass, this.rotation && this.rotation !== 0 && (i.rotation = this.rotation), this.polygonOffset === true && (i.polygonOffset = true), this.polygonOffsetFactor !== 0 && (i.polygonOffsetFactor = this.polygonOffsetFactor), this.polygonOffsetUnits !== 0 && (i.polygonOffsetUnits = this.polygonOffsetUnits), this.linewidth && this.linewidth !== 1 && (i.linewidth = this.linewidth), this.dashSize !== void 0 && (i.dashSize = this.dashSize), this.gapSize !== void 0 && (i.gapSize = this.gapSize), this.scale !== void 0 && (i.scale = this.scale), this.dithering === true && (i.dithering = true), this.alphaTest > 0 && (i.alphaTest = this.alphaTest), this.alphaToCoverage === true && (i.alphaToCoverage = this.alphaToCoverage), this.premultipliedAlpha === true && (i.premultipliedAlpha = this.premultipliedAlpha), this.wireframe === true && (i.wireframe = this.wireframe), this.wireframeLinewidth > 1 && (i.wireframeLinewidth = this.wireframeLinewidth), this.wireframeLinecap !== "round" && (i.wireframeLinecap = this.wireframeLinecap), this.wireframeLinejoin !== "round" && (i.wireframeLinejoin = this.wireframeLinejoin), this.morphTargets === true && (i.morphTargets = true), this.morphNormals === true && (i.morphNormals = true), this.flatShading === true && (i.flatShading = this.flatShading), this.visible === false && (i.visible = false), this.toneMapped === false && (i.toneMapped = false), JSON.stringify(this.userData) !== "{}" && (i.userData = this.userData); function r(s) { const o = []; for (const a in s) { const c = s[a]; delete c.metadata, o.push(c); } return o; } if (t) { const s = r(e.textures), o = r(e.images); s.length > 0 && (i.textures = s), o.length > 0 && (i.images = o); } return i; } clone() { return new this.constructor().copy(this); } copy(e) { this.name = e.name, this.fog = e.fog, this.blending = e.blending, this.side = e.side, this.vertexColors = e.vertexColors, this.opacity = e.opacity, this.transparent = e.transparent, this.blendSrc = e.blendSrc, this.blendDst = e.blendDst, this.blendEquation = e.blendEquation, this.blendSrcAlpha = e.blendSrcAlpha, this.blendDstAlpha = e.blendDstAlpha, this.blendEquationAlpha = e.blendEquationAlpha, this.depthFunc = e.depthFunc, this.depthTest = e.depthTest, this.depthWrite = e.depthWrite, this.stencilWriteMask = e.stencilWriteMask, this.stencilFunc = e.stencilFunc, this.stencilRef = e.stencilRef, this.stencilFuncMask = e.stencilFuncMask, this.stencilFail = e.stencilFail, this.stencilZFail = e.stencilZFail, this.stencilZPass = e.stencilZPass, this.stencilWrite = e.stencilWrite; const t = e.clippingPlanes; let i = null; if (t !== null) { const r = t.length; i = new Array(r); for (let s = 0; s !== r; ++s) i[s] = t[s].clone(); } return this.clippingPlanes = i, this.clipIntersection = e.clipIntersection, this.clipShadows = e.clipShadows, this.shadowSide = e.shadowSide, this.colorWrite = e.colorWrite, this.precision = e.precision, this.polygonOffset = e.polygonOffset, this.polygonOffsetFactor = e.polygonOffsetFactor, this.polygonOffsetUnits = e.polygonOffsetUnits, this.dithering = e.dithering, this.alphaTest = e.alphaTest, this.alphaToCoverage = e.alphaToCoverage, this.premultipliedAlpha = e.premultipliedAlpha, this.visible = e.visible, this.toneMapped = e.toneMapped, this.userData = JSON.parse(JSON.stringify(e.userData)), this; } dispose() { this.dispatchEvent({ type: "dispose" }); } set needsUpdate(e) { e === true && this.version++; } }; tn.prototype.isMaterial = true; var nx = { aliceblue: 15792383, antiquewhite: 16444375, aqua: 65535, aquamarine: 8388564, azure: 15794175, beige: 16119260, bisque: 16770244, black: 0, blanchedalmond: 16772045, blue: 255, blueviolet: 9055202, brown: 10824234, burlywood: 14596231, cadetblue: 6266528, chartreuse: 8388352, chocolate: 13789470, coral: 16744272, cornflowerblue: 6591981, cornsilk: 16775388, crimson: 14423100, cyan: 65535, darkblue: 139, darkcyan: 35723, darkgoldenrod: 12092939, darkgray: 11119017, darkgreen: 25600, darkgrey: 11119017, darkkhaki: 12433259, darkmagenta: 9109643, darkolivegreen: 5597999, darkorange: 16747520, darkorchid: 10040012, darkred: 9109504, darksalmon: 15308410, darkseagreen: 9419919, darkslateblue: 4734347, darkslategray: 3100495, darkslategrey: 3100495, darkturquoise: 52945, darkviolet: 9699539, deeppink: 16716947, deepskyblue: 49151, dimgray: 6908265, dimgrey: 6908265, dodgerblue: 2003199, firebrick: 11674146, floralwhite: 16775920, forestgreen: 2263842, fuchsia: 16711935, gainsboro: 14474460, ghostwhite: 16316671, gold: 16766720, goldenrod: 14329120, gray: 8421504, green: 32768, greenyellow: 11403055, grey: 8421504, honeydew: 15794160, hotpink: 16738740, indianred: 13458524, indigo: 4915330, ivory: 16777200, khaki: 15787660, lavender: 15132410, lavenderblush: 16773365, lawngreen: 8190976, lemonchiffon: 16775885, lightblue: 11393254, lightcoral: 15761536, lightcyan: 14745599, lightgoldenrodyellow: 16448210, lightgray: 13882323, lightgreen: 9498256, lightgrey: 13882323, lightpink: 16758465, lightsalmon: 16752762, lightseagreen: 2142890, lightskyblue: 8900346, lightslategray: 7833753, lightslategrey: 7833753, lightsteelblue: 11584734, lightyellow: 16777184, lime: 65280, limegreen: 3329330, linen: 16445670, magenta: 16711935, maroon: 8388608, mediumaquamarine: 6737322, mediumblue: 205, mediumorchid: 12211667, mediumpurple: 9662683, mediumseagreen: 3978097, mediumslateblue: 8087790, mediumspringgreen: 64154, mediumturquoise: 4772300, mediumvioletred: 13047173, midnightblue: 1644912, mintcream: 16121850, mistyrose: 16770273, moccasin: 16770229, navajowhite: 16768685, navy: 128, oldlace: 16643558, olive: 8421376, olivedrab: 7048739, orange: 16753920, orangered: 16729344, orchid: 14315734, palegoldenrod: 15657130, palegreen: 10025880, paleturquoise: 11529966, palevioletred: 14381203, papayawhip: 16773077, peachpuff: 16767673, peru: 13468991, pink: 16761035, plum: 14524637, powderblue: 11591910, purple: 8388736, rebeccapurple: 6697881, red: 16711680, rosybrown: 12357519, royalblue: 4286945, saddlebrown: 9127187, salmon: 16416882, sandybrown: 16032864, seagreen: 3050327, seashell: 16774638, sienna: 10506797, silver: 12632256, skyblue: 8900331, slateblue: 6970061, slategray: 7372944, slategrey: 7372944, snow: 16775930, springgreen: 65407, steelblue: 4620980, tan: 13808780, teal: 32896, thistle: 14204888, tomato: 16737095, turquoise: 4251856, violet: 15631086, wheat: 16113331, white: 16777215, whitesmoke: 16119285, yellow: 16776960, yellowgreen: 10145074 }; var oi = { h: 0, s: 0, l: 0 }; var Vl = { h: 0, s: 0, l: 0 }; function sh(n, e, t) { return t < 0 && (t += 1), t > 1 && (t -= 1), t < 1 / 6 ? n + (e - n) * 6 * t : t < 1 / 2 ? e : t < 2 / 3 ? n + (e - n) * 6 * (2 / 3 - t) : n; } function oh(n) { return n < 0.04045 ? n * 0.0773993808 : Math.pow(n * 0.9478672986 + 0.0521327014, 2.4); } function ah(n) { return n < 31308e-7 ? n * 12.92 : 1.055 * Math.pow(n, 0.41666) - 0.055; } var Ue = class { constructor(e, t, i) { return t === void 0 && i === void 0 ? this.set(e) : this.setRGB(e, t, i); } set(e) { return e && e.isColor ? this.copy(e) : typeof e == "number" ? this.setHex(e) : typeof e == "string" && this.setStyle(e), this; } setScalar(e) { return this.r = e, this.g = e, this.b = e, this; } setHex(e) { return e = Math.floor(e), this.r = (e >> 16 & 255) / 255, this.g = (e >> 8 & 255) / 255, this.b = (e & 255) / 255, this; } setRGB(e, t, i) { return this.r = e, this.g = t, this.b = i, this; } setHSL(e, t, i) { if (e = Tf(e, 1), t = gn(t, 0, 1), i = gn(i, 0, 1), t === 0) this.r = this.g = this.b = i; else { const r = i <= 0.5 ? i * (1 + t) : i + t - i * t, s = 2 * i - r; this.r = sh(s, r, e + 1 / 3), this.g = sh(s, r, e), this.b = sh(s, r, e - 1 / 3); } return this; } setStyle(e) { function t(r) { r !== void 0 && parseFloat(r) < 1 && console.warn("THREE.Color: Alpha component of " + e + " will be ignored."); } let i; if (i = /^((?:rgb|hsl)a?)\(([^\)]*)\)/.exec(e)) { let r; const s = i[1], o = i[2]; switch (s) { case "rgb": case "rgba": if (r = /^\s*(\d+)\s*,\s*(\d+)\s*,\s*(\d+)\s*(?:,\s*(\d*\.?\d+)\s*)?$/.exec(o)) return this.r = Math.min(255, parseInt(r[1], 10)) / 255, this.g = Math.min(255, parseInt(r[2], 10)) / 255, this.b = Math.min(255, parseInt(r[3], 10)) / 255, t(r[4]), this; if (r = /^\s*(\d+)\%\s*,\s*(\d+)\%\s*,\s*(\d+)\%\s*(?:,\s*(\d*\.?\d+)\s*)?$/.exec(o)) return this.r = Math.min(100, parseInt(r[1], 10)) / 100, this.g = Math.min(100, parseInt(r[2], 10)) / 100, this.b = Math.min(100, parseInt(r[3], 10)) / 100, t(r[4]), this; break; case "hsl": case "hsla": if (r = /^\s*(\d*\.?\d+)\s*,\s*(\d+)\%\s*,\s*(\d+)\%\s*(?:,\s*(\d*\.?\d+)\s*)?$/.exec(o)) { const a = parseFloat(r[1]) / 360, c = parseInt(r[2], 10) / 100, l = parseInt(r[3], 10) / 100; return t(r[4]), this.setHSL(a, c, l); } break; } } else if (i = /^\#([A-Fa-f\d]+)$/.exec(e)) { const r = i[1], s = r.length; if (s === 3) return this.r = parseInt(r.charAt(0) + r.charAt(0), 16) / 255, this.g = parseInt(r.charAt(1) + r.charAt(1), 16) / 255, this.b = parseInt(r.charAt(2) + r.charAt(2), 16) / 255, this; if (s === 6) return this.r = parseInt(r.charAt(0) + r.charAt(1), 16) / 255, this.g = parseInt(r.charAt(2) + r.charAt(3), 16) / 255, this.b = parseInt(r.charAt(4) + r.charAt(5), 16) / 255, this; } return e && e.length > 0 ? this.setColorName(e) : this; } setColorName(e) { const t = nx[e.toLowerCase()]; return t !== void 0 ? this.setHex(t) : console.warn("THREE.Color: Unknown color " + e), this; } clone() { return new this.constructor(this.r, this.g, this.b); } copy(e) { return this.r = e.r, this.g = e.g, this.b = e.b, this; } copyGammaToLinear(e, t = 2) { return this.r = Math.pow(e.r, t), this.g = Math.pow(e.g, t), this.b = Math.pow(e.b, t), this; } copyLinearToGamma(e, t = 2) { const i = t > 0 ? 1 / t : 1; return this.r = Math.pow(e.r, i), this.g = Math.pow(e.g, i), this.b = Math.pow(e.b, i), this; } convertGammaToLinear(e) { return this.copyGammaToLinear(this, e), this; } convertLinearToGamma(e) { return this.copyLinearToGamma(this, e), this; } copySRGBToLinear(e) { return this.r = oh(e.r), this.g = oh(e.g), this.b = oh(e.b), this; } copyLinearToSRGB(e) { return this.r = ah(e.r), this.g = ah(e.g), this.b = ah(e.b), this; } convertSRGBToLinear() { return this.copySRGBToLinear(this), this; } convertLinearToSRGB() { return this.copyLinearToSRGB(this), this; } getHex() { return this.r * 255 << 16 ^ this.g * 255 << 8 ^ this.b * 255 << 0; } getHexString() { return ("000000" + this.getHex().toString(16)).slice(-6); } getHSL(e) { const t = this.r, i = this.g, r = this.b, s = Math.max(t, i, r), o = Math.min(t, i, r); let a, c; const l = (o + s) / 2; if (o === s) a = 0, c = 0; else { const d = s - o; switch (c = l <= 0.5 ? d / (s + o) : d / (2 - s - o), s) { case t: a = (i - r) / d + (i < r ? 6 : 0); break; case i: a = (r - t) / d + 2; break; case r: a = (t - i) / d + 4; break; } a /= 6; } return e.h = a, e.s = c, e.l = l, e; } getStyle() { return "rgb(" + (this.r * 255 | 0) + "," + (this.g * 255 | 0) + "," + (this.b * 255 | 0) + ")"; } offsetHSL(e, t, i) { return this.getHSL(oi), oi.h += e, oi.s += t, oi.l += i, this.setHSL(oi.h, oi.s, oi.l), this; } add(e) { return this.r += e.r, this.g += e.g, this.b += e.b, this; } addColors(e, t) { return this.r = e.r + t.r, this.g = e.g + t.g, this.b = e.b + t.b, this; } addScalar(e) { return this.r += e, this.g += e, this.b += e, this; } sub(e) { return this.r = Math.max(0, this.r - e.r), this.g = Math.max(0, this.g - e.g), this.b = Math.max(0, this.b - e.b), this; } multiply(e) { return this.r *= e.r, this.g *= e.g, this.b *= e.b, this; } multiplyScalar(e) { return this.r *= e, this.g *= e, this.b *= e, this; } lerp(e, t) { return this.r += (e.r - this.r) * t, this.g += (e.g - this.g) * t, this.b += (e.b - this.b) * t, this; } lerpColors(e, t, i) { return this.r = e.r + (t.r - e.r) * i, this.g = e.g + (t.g - e.g) * i, this.b = e.b + (t.b - e.b) * i, this; } lerpHSL(e, t) { this.getHSL(oi), e.getHSL(Vl); const i = Fa(oi.h, Vl.h, t), r = Fa(oi.s, Vl.s, t), s = Fa(oi.l, Vl.l, t); return this.setHSL(i, r, s), this; } equals(e) { return e.r === this.r && e.g === this.g && e.b === this.b; } fromArray(e, t = 0) { return this.r = e[t], this.g = e[t + 1], this.b = e[t + 2], this; } toArray(e = [], t = 0) { return e[t] = this.r, e[t + 1] = this.g, e[t + 2] = this.b, e; } fromBufferAttribute(e, t) { return this.r = e.getX(t), this.g = e.getY(t), this.b = e.getZ(t), e.normalized === true && (this.r /= 255, this.g /= 255, this.b /= 255), this; } toJSON() { return this.getHex(); } }; Ue.NAMES = nx; Ue.prototype.isColor = true; Ue.prototype.r = 1; Ue.prototype.g = 1; Ue.prototype.b = 1; var In = class extends tn { constructor(e) { super(), this.type = "MeshBasicMaterial", this.color = new Ue(16777215), this.map = null, this.lightMap = null, this.lightMapIntensity = 1, this.aoMap = null, this.aoMapIntensity = 1, this.specularMap = null, this.alphaMap = null, this.envMap = null, this.combine = al, this.reflectivity = 1, this.refractionRatio = 0.98, this.wireframe = false, this.wireframeLinewidth = 1, this.wireframeLinecap = "round", this.wireframeLinejoin = "round", this.morphTargets = false, this.setValues(e); } copy(e) { return super.copy(e), this.color.copy(e.color), this.map = e.map, this.lightMap = e.lightMap, this.lightMapIntensity = e.lightMapIntensity, this.aoMap = e.aoMap, this.aoMapIntensity = e.aoMapIntensity, this.specularMap = e.specularMap, this.alphaMap = e.alphaMap, this.envMap = e.envMap, this.combine = e.combine, this.reflectivity = e.reflectivity, this.refractionRatio = e.refractionRatio, this.wireframe = e.wireframe, this.wireframeLinewidth = e.wireframeLinewidth, this.wireframeLinecap = e.wireframeLinecap, this.wireframeLinejoin = e.wireframeLinejoin, this.morphTargets = e.morphTargets, this; } }; In.prototype.isMeshBasicMaterial = true; var St = new q(); var kl = new Re(); var ot = class { constructor(e, t, i) { if (Array.isArray(e)) throw new TypeError("THREE.BufferAttribute: array should be a Typed Array."); this.name = "", this.array = e, this.itemSize = t, this.count = e !== void 0 ? e.length / t : 0, this.normalized = i === true, this.usage = Ro, this.updateRange = { offset: 0, count: -1 }, this.version = 0; } onUploadCallback() { } set needsUpdate(e) { e === true && this.version++; } setUsage(e) { return this.usage = e, this; } copy(e) { return this.name = e.name, this.array = new e.array.constructor(e.array), this.itemSize = e.itemSize, this.count = e.count, this.normalized = e.normalized, this.usage = e.usage, this; } copyAt(e, t, i) { e *= this.itemSize, i *= t.itemSize; for (let r = 0, s = this.itemSize; r < s; r++) this.array[e + r] = t.array[i + r]; return this; } copyArray(e) { return this.array.set(e), this; } copyColorsArray(e) { const t = this.array; let i = 0; for (let r = 0, s = e.length; r < s; r++) { let o = e[r]; o === void 0 && (console.warn("THREE.BufferAttribute.copyColorsArray(): color is undefined", r), o = new Ue()), t[i++] = o.r, t[i++] = o.g, t[i++] = o.b; } return this; } copyVector2sArray(e) { const t = this.array; let i = 0; for (let r = 0, s = e.length; r < s; r++) { let o = e[r]; o === void 0 && (console.warn("THREE.BufferAttribute.copyVector2sArray(): vector is undefined", r), o = new Re()), t[i++] = o.x, t[i++] = o.y; } return this; } copyVector3sArray(e) { const t = this.array; let i = 0; for (let r = 0, s = e.length; r < s; r++) { let o = e[r]; o === void 0 && (console.warn("THREE.BufferAttribute.copyVector3sArray(): vector is undefined", r), o = new q()), t[i++] = o.x, t[i++] = o.y, t[i++] = o.z; } return this; } copyVector4sArray(e) { const t = this.array; let i = 0; for (let r = 0, s = e.length; r < s; r++) { let o = e[r]; o === void 0 && (console.warn("THREE.BufferAttribute.copyVector4sArray(): vector is undefined", r), o = new xt()), t[i++] = o.x, t[i++] = o.y, t[i++] = o.z, t[i++] = o.w; } return this; } applyMatrix3(e) { if (this.itemSize === 2) for (let t = 0, i = this.count; t < i; t++) kl.fromBufferAttribute(this, t), kl.applyMatrix3(e), this.setXY(t, kl.x, kl.y); else if (this.itemSize === 3) for (let t = 0, i = this.count; t < i; t++) St.fromBufferAttribute(this, t), St.applyMatrix3(e), this.setXYZ(t, St.x, St.y, St.z); return this; } applyMatrix4(e) { for (let t = 0, i = this.count; t < i; t++) St.x = this.getX(t), St.y = this.getY(t), St.z = this.getZ(t), St.applyMatrix4(e), this.setXYZ(t, St.x, St.y, St.z); return this; } applyNormalMatrix(e) { for (let t = 0, i = this.count; t < i; t++) St.x = this.getX(t), St.y = this.getY(t), St.z = this.getZ(t), St.applyNormalMatrix(e), this.setXYZ(t, St.x, St.y, St.z); return this; } transformDirection(e) { for (let t = 0, i = this.count; t < i; t++) St.x = this.getX(t), St.y = this.getY(t), St.z = this.getZ(t), St.transformDirection(e), this.setXYZ(t, St.x, St.y, St.z); return this; } set(e, t = 0) { return this.array.set(e, t), this; } getX(e) { return this.array[e * this.itemSize]; } setX(e, t) { return this.array[e * this.itemSize] = t, this; } getY(e) { return this.array[e * this.itemSize + 1]; } setY(e, t) { return this.array[e * this.itemSize + 1] = t, this; } getZ(e) { return this.array[e * this.itemSize + 2]; } setZ(e, t) { return this.array[e * this.itemSize + 2] = t, this; } getW(e) { return this.array[e * this.itemSize + 3]; } setW(e, t) { return this.array[e * this.itemSize + 3] = t, this; } setXY(e, t, i) { return e *= this.itemSize, this.array[e + 0] = t, this.array[e + 1] = i, this; } setXYZ(e, t, i, r) { return e *= this.itemSize, this.array[e + 0] = t, this.array[e + 1] = i, this.array[e + 2] = r, this; } setXYZW(e, t, i, r, s) { return e *= this.itemSize, this.array[e + 0] = t, this.array[e + 1] = i, this.array[e + 2] = r, this.array[e + 3] = s, this; } onUpload(e) { return this.onUploadCallback = e, this; } clone() { return new this.constructor(this.array, this.itemSize).copy(this); } toJSON() { const e = { itemSize: this.itemSize, type: this.array.constructor.name, array: Array.prototype.slice.call(this.array), normalized: this.normalized }; return this.name !== "" && (e.name = this.name), this.usage !== Ro && (e.usage = this.usage), (this.updateRange.offset !== 0 || this.updateRange.count !== -1) && (e.updateRange = this.updateRange), e; } }; ot.prototype.isBufferAttribute = true; var ix = class extends ot { constructor(e, t, i) { super(new Int8Array(e), t, i); } }; var rx = class extends ot { constructor(e, t, i) { super(new Uint8Array(e), t, i); } }; var sx = class extends ot { constructor(e, t, i) { super(new Uint8ClampedArray(e), t, i); } }; var ox = class extends ot { constructor(e, t, i) { super(new Int16Array(e), t, i); } }; var gu = class extends ot { constructor(e, t, i) { super(new Uint16Array(e), t, i); } }; var ax = class extends ot { constructor(e, t, i) { super(new Int32Array(e), t, i); } }; var vu = class extends ot { constructor(e, t, i) { super(new Uint32Array(e), t, i); } }; var lx = class extends ot { constructor(e, t, i) { super(new Uint16Array(e), t, i); } }; lx.prototype.isFloat16BufferAttribute = true; var He = class extends ot { constructor(e, t, i) { super(new Float32Array(e), t, i); } }; var cx = class extends ot { constructor(e, t, i) { super(new Float64Array(e), t, i); } }; function ux(n) { if (n.length === 0) return -1 / 0; let e = n[0]; for (let t = 1, i = n.length; t < i; ++t) n[t] > e && (e = n[t]); return e; } var bF = { Int8Array, Uint8Array, Uint8ClampedArray, Int16Array, Uint16Array, Int32Array, Uint32Array, Float32Array, Float64Array }; function mo(n, e) { return new bF[n](e); } var xF = 0; var Xn = new Xe(); var lh = new ut(); var Qs = new q(); var Un = new Nn(); var pa = new Nn(); var cn = new q(); var Ke = class _Ke extends Kr { constructor() { super(), Object.defineProperty(this, "id", { value: xF++ }), this.uuid = Hn(), this.name = "", this.type = "BufferGeometry", this.index = null, this.attributes = {}, this.morphAttributes = {}, this.morphTargetsRelative = false, this.groups = [], this.boundingBox = null, this.boundingSphere = null, this.drawRange = { start: 0, count: 1 / 0 }, this.userData = {}; } getIndex() { return this.index; } setIndex(e) { return Array.isArray(e) ? this.index = new (ux(e) > 65535 ? vu : gu)(e, 1) : this.index = e, this; } getAttribute(e) { return this.attributes[e]; } setAttribute(e, t) { return this.attributes[e] = t, this; } deleteAttribute(e) { return delete this.attributes[e], this; } hasAttribute(e) { return this.attributes[e] !== void 0; } addGroup(e, t, i = 0) { this.groups.push({ start: e, count: t, materialIndex: i }); } clearGroups() { this.groups = []; } setDrawRange(e, t) { this.drawRange.start = e, this.drawRange.count = t; } applyMatrix4(e) { const t = this.attributes.position; t !== void 0 && (t.applyMatrix4(e), t.needsUpdate = true); const i = this.attributes.normal; if (i !== void 0) { const s = new rn().getNormalMatrix(e); i.applyNormalMatrix(s), i.needsUpdate = true; } const r = this.attributes.tangent; return r !== void 0 && (r.transformDirection(e), r.needsUpdate = true), this.boundingBox !== null && this.computeBoundingBox(), this.boundingSphere !== null && this.computeBoundingSphere(), this; } applyQuaternion(e) { return Xn.makeRotationFromQuaternion(e), this.applyMatrix4(Xn), this; } rotateX(e) { return Xn.makeRotationX(e), this.applyMatrix4(Xn), this; } rotateY(e) { return Xn.makeRotationY(e), this.applyMatrix4(Xn), this; } rotateZ(e) { return Xn.makeRotationZ(e), this.applyMatrix4(Xn), this; } translate(e, t, i) { return Xn.makeTranslation(e, t, i), this.applyMatrix4(Xn), this; } scale(e, t, i) { return Xn.makeScale(e, t, i), this.applyMatrix4(Xn), this; } lookAt(e) { return lh.lookAt(e), lh.updateMatrix(), this.applyMatrix4(lh.matrix), this; } center() { return this.computeBoundingBox(), this.boundingBox.getCenter(Qs).negate(), this.translate(Qs.x, Qs.y, Qs.z), this; } setFromPoints(e) { const t = []; for (let i = 0, r = e.length; i < r; i++) { const s = e[i]; t.push(s.x, s.y, s.z || 0); } return this.setAttribute("position", new He(t, 3)), this; } computeBoundingBox() { this.boundingBox === null && (this.boundingBox = new Nn()); const e = this.attributes.position, t = this.morphAttributes.position; if (e && e.isGLBufferAttribute) { console.error('THREE.BufferGeometry.computeBoundingBox(): GLBufferAttribute requires a manual bounding box. Alternatively set "mesh.frustumCulled" to "false".', this), this.boundingBox.set( new q(-1 / 0, -1 / 0, -1 / 0), new q(1 / 0, 1 / 0, 1 / 0) ); return; } if (e !== void 0) { if (this.boundingBox.setFromBufferAttribute(e), t) for (let i = 0, r = t.length; i < r; i++) { const s = t[i]; Un.setFromBufferAttribute(s), this.morphTargetsRelative ? (cn.addVectors(this.boundingBox.min, Un.min), this.boundingBox.expandByPoint(cn), cn.addVectors(this.boundingBox.max, Un.max), this.boundingBox.expandByPoint(cn)) : (this.boundingBox.expandByPoint(Un.min), this.boundingBox.expandByPoint(Un.max)); } } else this.boundingBox.makeEmpty(); (isNaN(this.boundingBox.min.x) || isNaN(this.boundingBox.min.y) || isNaN(this.boundingBox.min.z)) && console.error('THREE.BufferGeometry.computeBoundingBox(): Computed min/max have NaN values. The "position" attribute is likely to have NaN values.', this); } computeBoundingSphere() { this.boundingSphere === null && (this.boundingSphere = new pr()); const e = this.attributes.position, t = this.morphAttributes.position; if (e && e.isGLBufferAttribute) { console.error('THREE.BufferGeometry.computeBoundingSphere(): GLBufferAttribute requires a manual bounding sphere. Alternatively set "mesh.frustumCulled" to "false".', this), this.boundingSphere.set(new q(), 1 / 0); return; } if (e) { const i = this.boundingSphere.center; if (Un.setFromBufferAttribute(e), t) for (let s = 0, o = t.length; s < o; s++) { const a = t[s]; pa.setFromBufferAttribute(a), this.morphTargetsRelative ? (cn.addVectors(Un.min, pa.min), Un.expandByPoint(cn), cn.addVectors(Un.max, pa.max), Un.expandByPoint(cn)) : (Un.expandByPoint(pa.min), Un.expandByPoint(pa.max)); } Un.getCenter(i); let r = 0; for (let s = 0, o = e.count; s < o; s++) cn.fromBufferAttribute(e, s), r = Math.max(r, i.distanceToSquared(cn)); if (t) for (let s = 0, o = t.length; s < o; s++) { const a = t[s], c = this.morphTargetsRelative; for (let l = 0, d = a.count; l < d; l++) cn.fromBufferAttribute(a, l), c && (Qs.fromBufferAttribute(e, l), cn.add(Qs)), r = Math.max(r, i.distanceToSquared(cn)); } this.boundingSphere.radius = Math.sqrt(r), isNaN(this.boundingSphere.radius) && console.error('THREE.BufferGeometry.computeBoundingSphere(): Computed radius is NaN. The "position" attribute is likely to have NaN values.', this); } } computeFaceNormals() { } computeTangents() { const e = this.index, t = this.attributes; if (e === null || t.position === void 0 || t.normal === void 0 || t.uv === void 0) { console.error("THREE.BufferGeometry: .computeTangents() failed. Missing required attributes (index, position, normal or uv)"); return; } const i = e.array, r = t.position.array, s = t.normal.array, o = t.uv.array, a = r.length / 3; t.tangent === void 0 && this.setAttribute("tangent", new ot(new Float32Array(4 * a), 4)); const c = t.tangent.array, l = [], d = []; for (let I = 0; I < a; I++) l[I] = new q(), d[I] = new q(); const h6 = new q(), f = new q(), g = new q(), p = new Re(), u = new Re(), y = new Re(), v = new q(), m = new q(); function x(I, T, _) { h6.fromArray(r, I * 3), f.fromArray(r, T * 3), g.fromArray(r, _ * 3), p.fromArray(o, I * 2), u.fromArray(o, T * 2), y.fromArray(o, _ * 2), f.sub(h6), g.sub(h6), u.sub(p), y.sub(p); const E = 1 / (u.x * y.y - y.x * u.y); isFinite(E) && (v.copy(f).multiplyScalar(y.y).addScaledVector(g, -u.y).multiplyScalar(E), m.copy(g).multiplyScalar(u.x).addScaledVector(f, -y.x).multiplyScalar(E), l[I].add(v), l[T].add(v), l[_].add(v), d[I].add(m), d[T].add(m), d[_].add(m)); } let w = this.groups; w.length === 0 && (w = [{ start: 0, count: i.length }]); for (let I = 0, T = w.length; I < T; ++I) { const _ = w[I], E = _.start, C = _.count; for (let P = E, b = E + C; P < b; P += 3) x( i[P + 0], i[P + 1], i[P + 2] ); } const A = new q(), M = new q(), R = new q(), L = new q(); function S(I) { R.fromArray(s, I * 3), L.copy(R); const T = l[I]; A.copy(T), A.sub(R.multiplyScalar(R.dot(T))).normalize(), M.crossVectors(L, T); const E = M.dot(d[I]) < 0 ? -1 : 1; c[I * 4] = A.x, c[I * 4 + 1] = A.y, c[I * 4 + 2] = A.z, c[I * 4 + 3] = E; } for (let I = 0, T = w.length; I < T; ++I) { const _ = w[I], E = _.start, C = _.count; for (let P = E, b = E + C; P < b; P += 3) S(i[P + 0]), S(i[P + 1]), S(i[P + 2]); } } computeVertexNormals() { const e = this.index, t = this.getAttribute("position"); if (t !== void 0) { let i = this.getAttribute("normal"); if (i === void 0) i = new ot(new Float32Array(t.count * 3), 3), this.setAttribute("normal", i); else for (let f = 0, g = i.count; f < g; f++) i.setXYZ(f, 0, 0, 0); const r = new q(), s = new q(), o = new q(), a = new q(), c = new q(), l = new q(), d = new q(), h6 = new q(); if (e) for (let f = 0, g = e.count; f < g; f += 3) { const p = e.getX(f + 0), u = e.getX(f + 1), y = e.getX(f + 2); r.fromBufferAttribute(t, p), s.fromBufferAttribute(t, u), o.fromBufferAttribute(t, y), d.subVectors(o, s), h6.subVectors(r, s), d.cross(h6), a.fromBufferAttribute(i, p), c.fromBufferAttribute(i, u), l.fromBufferAttribute(i, y), a.add(d), c.add(d), l.add(d), i.setXYZ(p, a.x, a.y, a.z), i.setXYZ(u, c.x, c.y, c.z), i.setXYZ(y, l.x, l.y, l.z); } else for (let f = 0, g = t.count; f < g; f += 3) r.fromBufferAttribute(t, f + 0), s.fromBufferAttribute(t, f + 1), o.fromBufferAttribute(t, f + 2), d.subVectors(o, s), h6.subVectors(r, s), d.cross(h6), i.setXYZ(f + 0, d.x, d.y, d.z), i.setXYZ(f + 1, d.x, d.y, d.z), i.setXYZ(f + 2, d.x, d.y, d.z); this.normalizeNormals(), i.needsUpdate = true; } } merge(e, t) { if (!(e && e.isBufferGeometry)) { console.error("THREE.BufferGeometry.merge(): geometry not an instance of THREE.BufferGeometry.", e); return; } t === void 0 && (t = 0, console.warn( "THREE.BufferGeometry.merge(): Overwriting original geometry, starting at offset=0. Use BufferGeometryUtils.mergeBufferGeometries() for lossless merge." )); const i = this.attributes; for (const r in i) { if (e.attributes[r] === void 0) continue; const o = i[r].array, a = e.attributes[r], c = a.array, l = a.itemSize * t, d = Math.min(c.length, o.length - l); for (let h6 = 0, f = l; h6 < d; h6++, f++) o[f] = c[h6]; } return this; } normalizeNormals() { const e = this.attributes.normal; for (let t = 0, i = e.count; t < i; t++) cn.fromBufferAttribute(e, t), cn.normalize(), e.setXYZ(t, cn.x, cn.y, cn.z); } toNonIndexed() { function e(a, c) { const l = a.array, d = a.itemSize, h6 = a.normalized, f = new l.constructor(c.length * d); let g = 0, p = 0; for (let u = 0, y = c.length; u < y; u++) { a.isInterleavedBufferAttribute ? g = c[u] * a.data.stride + a.offset : g = c[u] * d; for (let v = 0; v < d; v++) f[p++] = l[g++]; } return new ot(f, d, h6); } if (this.index === null) return console.warn("THREE.BufferGeometry.toNonIndexed(): BufferGeometry is already non-indexed."), this; const t = new _Ke(), i = this.index.array, r = this.attributes; for (const a in r) { const c = r[a], l = e(c, i); t.setAttribute(a, l); } const s = this.morphAttributes; for (const a in s) { const c = [], l = s[a]; for (let d = 0, h6 = l.length; d < h6; d++) { const f = l[d], g = e(f, i); c.push(g); } t.morphAttributes[a] = c; } t.morphTargetsRelative = this.morphTargetsRelative; const o = this.groups; for (let a = 0, c = o.length; a < c; a++) { const l = o[a]; t.addGroup(l.start, l.count, l.materialIndex); } return t; } toJSON() { const e = { metadata: { version: 4.5, type: "BufferGeometry", generator: "BufferGeometry.toJSON" } }; if (e.uuid = this.uuid, e.type = this.type, this.name !== "" && (e.name = this.name), Object.keys(this.userData).length > 0 && (e.userData = this.userData), this.parameters !== void 0) { const c = this.parameters; for (const l in c) c[l] !== void 0 && (e[l] = c[l]); return e; } e.data = { attributes: {} }; const t = this.index; t !== null && (e.data.index = { type: t.array.constructor.name, array: Array.prototype.slice.call(t.array) }); const i = this.attributes; for (const c in i) { const l = i[c]; e.data.attributes[c] = l.toJSON(e.data); } const r = {}; let s = false; for (const c in this.morphAttributes) { const l = this.morphAttributes[c], d = []; for (let h6 = 0, f = l.length; h6 < f; h6++) { const g = l[h6]; d.push(g.toJSON(e.data)); } d.length > 0 && (r[c] = d, s = true); } s && (e.data.morphAttributes = r, e.data.morphTargetsRelative = this.morphTargetsRelative); const o = this.groups; o.length > 0 && (e.data.groups = JSON.parse(JSON.stringify(o))); const a = this.boundingSphere; return a !== null && (e.data.boundingSphere = { center: a.center.toArray(), radius: a.radius }), e; } clone() { return new _Ke().copy(this); } copy(e) { this.index = null, this.attributes = {}, this.morphAttributes = {}, this.groups = [], this.boundingBox = null, this.boundingSphere = null; const t = {}; this.name = e.name; const i = e.index; i !== null && this.setIndex(i.clone(t)); const r = e.attributes; for (const l in r) { const d = r[l]; this.setAttribute(l, d.clone(t)); } const s = e.morphAttributes; for (const l in s) { const d = [], h6 = s[l]; for (let f = 0, g = h6.length; f < g; f++) d.push(h6[f].clone(t)); this.morphAttributes[l] = d; } this.morphTargetsRelative = e.morphTargetsRelative; const o = e.groups; for (let l = 0, d = o.length; l < d; l++) { const h6 = o[l]; this.addGroup(h6.start, h6.count, h6.materialIndex); } const a = e.boundingBox; a !== null && (this.boundingBox = a.clone()); const c = e.boundingSphere; return c !== null && (this.boundingSphere = c.clone()), this.drawRange.start = e.drawRange.start, this.drawRange.count = e.drawRange.count, this.userData = e.userData, this; } dispose() { this.dispatchEvent({ type: "dispose" }); } }; Ke.prototype.isBufferGeometry = true; var ng = new Xe(); var eo = new qr(); var ch = new pr(); var Mr = new q(); var wr = new q(); var Ar = new q(); var uh = new q(); var hh = new q(); var dh = new q(); var Gl = new q(); var Hl = new q(); var Wl = new q(); var jl = new Re(); var $l = new Re(); var Zl = new Re(); var fh = new q(); var Xl = new q(); var Xt = class extends ut { constructor(e = new Ke(), t = new In()) { super(), this.type = "Mesh", this.geometry = e, this.material = t, this.updateMorphTargets(); } copy(e) { return super.copy(e), e.morphTargetInfluences !== void 0 && (this.morphTargetInfluences = e.morphTargetInfluences.slice()), e.morphTargetDictionary !== void 0 && (this.morphTargetDictionary = Object.assign({}, e.morphTargetDictionary)), this.material = e.material, this.geometry = e.geometry, this; } updateMorphTargets() { const e = this.geometry; if (e.isBufferGeometry) { const t = e.morphAttributes, i = Object.keys(t); if (i.length > 0) { const r = t[i[0]]; if (r !== void 0) { this.morphTargetInfluences = [], this.morphTargetDictionary = {}; for (let s = 0, o = r.length; s < o; s++) { const a = r[s].name || String(s); this.morphTargetInfluences.push(0), this.morphTargetDictionary[a] = s; } } } } else { const t = e.morphTargets; t !== void 0 && t.length > 0 && console.error("THREE.Mesh.updateMorphTargets() no longer supports THREE.Geometry. Use THREE.BufferGeometry instead."); } } raycast(e, t) { const i = this.geometry, r = this.material, s = this.matrixWorld; if (r === void 0 || (i.boundingSphere === null && i.computeBoundingSphere(), ch.copy(i.boundingSphere), ch.applyMatrix4(s), e.ray.intersectsSphere(ch) === false) || (ng.copy(s).invert(), eo.copy(e.ray).applyMatrix4(ng), i.boundingBox !== null && eo.intersectsBox(i.boundingBox) === false)) return; let o; if (i.isBufferGeometry) { const a = i.index, c = i.attributes.position, l = i.morphAttributes.position, d = i.morphTargetsRelative, h6 = i.attributes.uv, f = i.attributes.uv2, g = i.groups, p = i.drawRange; if (a !== null) if (Array.isArray(r)) for (let u = 0, y = g.length; u < y; u++) { const v = g[u], m = r[v.materialIndex], x = Math.max(v.start, p.start), w = Math.min(v.start + v.count, p.start + p.count); for (let A = x, M = w; A < M; A += 3) { const R = a.getX(A), L = a.getX(A + 1), S = a.getX(A + 2); o = Yl(this, m, e, eo, c, l, d, h6, f, R, L, S), o && (o.faceIndex = Math.floor(A / 3), o.face.materialIndex = v.materialIndex, t.push(o)); } } else { const u = Math.max(0, p.start), y = Math.min(a.count, p.start + p.count); for (let v = u, m = y; v < m; v += 3) { const x = a.getX(v), w = a.getX(v + 1), A = a.getX(v + 2); o = Yl(this, r, e, eo, c, l, d, h6, f, x, w, A), o && (o.faceIndex = Math.floor(v / 3), t.push(o)); } } else if (c !== void 0) if (Array.isArray(r)) for (let u = 0, y = g.length; u < y; u++) { const v = g[u], m = r[v.materialIndex], x = Math.max(v.start, p.start), w = Math.min(v.start + v.count, p.start + p.count); for (let A = x, M = w; A < M; A += 3) { const R = A, L = A + 1, S = A + 2; o = Yl(this, m, e, eo, c, l, d, h6, f, R, L, S), o && (o.faceIndex = Math.floor(A / 3), o.face.materialIndex = v.materialIndex, t.push(o)); } } else { const u = Math.max(0, p.start), y = Math.min(c.count, p.start + p.count); for (let v = u, m = y; v < m; v += 3) { const x = v, w = v + 1, A = v + 2; o = Yl(this, r, e, eo, c, l, d, h6, f, x, w, A), o && (o.faceIndex = Math.floor(v / 3), t.push(o)); } } } else i.isGeometry && console.error("THREE.Mesh.raycast() no longer supports THREE.Geometry. Use THREE.BufferGeometry instead."); } }; Xt.prototype.isMesh = true; function MF(n, e, t, i, r, s, o, a) { let c; if (e.side === jt ? c = i.intersectTriangle(o, s, r, true, a) : c = i.intersectTriangle(r, s, o, e.side !== Wr, a), c === null) return null; Xl.copy(a), Xl.applyMatrix4(n.matrixWorld); const l = t.ray.origin.distanceTo(Xl); return l < t.near || l > t.far ? null : { distance: l, point: Xl.clone(), object: n }; } function Yl(n, e, t, i, r, s, o, a, c, l, d, h6) { Mr.fromBufferAttribute(r, l), wr.fromBufferAttribute(r, d), Ar.fromBufferAttribute(r, h6); const f = n.morphTargetInfluences; if (e.morphTargets && s && f) { Gl.set(0, 0, 0), Hl.set(0, 0, 0), Wl.set(0, 0, 0); for (let p = 0, u = s.length; p < u; p++) { const y = f[p], v = s[p]; y !== 0 && (uh.fromBufferAttribute(v, l), hh.fromBufferAttribute(v, d), dh.fromBufferAttribute(v, h6), o ? (Gl.addScaledVector(uh, y), Hl.addScaledVector(hh, y), Wl.addScaledVector(dh, y)) : (Gl.addScaledVector(uh.sub(Mr), y), Hl.addScaledVector(hh.sub(wr), y), Wl.addScaledVector(dh.sub(Ar), y))); } Mr.add(Gl), wr.add(Hl), Ar.add(Wl); } n.isSkinnedMesh && (n.boneTransform(l, Mr), n.boneTransform(d, wr), n.boneTransform(h6, Ar)); const g = MF(n, e, t, i, Mr, wr, Ar, fh); if (g) { a && (jl.fromBufferAttribute(a, l), $l.fromBufferAttribute(a, d), Zl.fromBufferAttribute(a, h6), g.uv = Zt.getUV(fh, Mr, wr, Ar, jl, $l, Zl, new Re())), c && (jl.fromBufferAttribute(c, l), $l.fromBufferAttribute(c, d), Zl.fromBufferAttribute(c, h6), g.uv2 = Zt.getUV(fh, Mr, wr, Ar, jl, $l, Zl, new Re())); const p = { a: l, b: d, c: h6, normal: new q(), materialIndex: 0 }; Zt.getNormal(Mr, wr, Ar, p.normal), g.face = p; } return g; } var sr = class _sr extends Ke { constructor(e = 1, t = 1, i = 1, r = 1, s = 1, o = 1) { super(), this.type = "BoxGeometry", this.parameters = { width: e, height: t, depth: i, widthSegments: r, heightSegments: s, depthSegments: o }; const a = this; r = Math.floor(r), s = Math.floor(s), o = Math.floor(o); const c = [], l = [], d = [], h6 = []; let f = 0, g = 0; p("z", "y", "x", -1, -1, i, t, e, o, s, 0), p("z", "y", "x", 1, -1, i, t, -e, o, s, 1), p("x", "z", "y", 1, 1, e, i, t, r, o, 2), p("x", "z", "y", 1, -1, e, i, -t, r, o, 3), p("x", "y", "z", 1, -1, e, t, i, r, s, 4), p("x", "y", "z", -1, -1, e, t, -i, r, s, 5), this.setIndex(c), this.setAttribute("position", new He(l, 3)), this.setAttribute("normal", new He(d, 3)), this.setAttribute("uv", new He(h6, 2)); function p(u, y, v, m, x, w, A, M, R, L, S) { const I = w / R, T = A / L, _ = w / 2, E = A / 2, C = M / 2, P = R + 1, b = L + 1; let F = 0, D = 0; const N = new q(); for (let B = 0; B < b; B++) { const U = B * T - E; for (let G = 0; G < P; G++) { const Y = G * I - _; N[u] = Y * m, N[y] = U * x, N[v] = C, l.push(N.x, N.y, N.z), N[u] = 0, N[y] = 0, N[v] = M > 0 ? 1 : -1, d.push(N.x, N.y, N.z), h6.push(G / R), h6.push(1 - B / L), F += 1; } } for (let B = 0; B < L; B++) for (let U = 0; U < R; U++) { const G = f + U + P * B, Y = f + U + P * (B + 1), te = f + (U + 1) + P * (B + 1), ae = f + (U + 1) + P * B; c.push(G, Y, ae), c.push(Y, te, ae), D += 6; } a.addGroup(g, D, S), g += D, f += F; } } static fromJSON(e) { return new _sr(e.width, e.height, e.depth, e.widthSegments, e.heightSegments, e.depthSegments); } }; function Po(n) { const e = {}; for (const t in n) { e[t] = {}; for (const i in n[t]) { const r = n[t][i]; r && (r.isColor || r.isMatrix3 || r.isMatrix4 || r.isVector2 || r.isVector3 || r.isVector4 || r.isTexture || r.isQuaternion) ? e[t][i] = r.clone() : Array.isArray(r) ? e[t][i] = r.slice() : e[t][i] = r; } } return e; } function wn2(n) { const e = {}; for (let t = 0; t < n.length; t++) { const i = Po(n[t]); for (const r in i) e[r] = i[r]; } return e; } var hx = { clone: Po, merge: wn2 }; var wF = `void main() { gl_Position = projectionMatrix * modelViewMatrix * vec4( position, 1.0 ); }`; var AF = `void main() { gl_FragColor = vec4( 1.0, 0.0, 0.0, 1.0 ); }`; var or = class extends tn { constructor(e) { super(), this.type = "ShaderMaterial", this.defines = {}, this.uniforms = {}, this.vertexShader = wF, this.fragmentShader = AF, this.linewidth = 1, this.wireframe = false, this.wireframeLinewidth = 1, this.fog = false, this.lights = false, this.clipping = false, this.morphTargets = false, this.morphNormals = false, this.extensions = { derivatives: false, // set to use derivatives fragDepth: false, // set to use fragment depth values drawBuffers: false, // set to use draw buffers shaderTextureLOD: false // set to use shader texture LOD }, this.defaultAttributeValues = { color: [1, 1, 1], uv: [0, 0], uv2: [0, 0] }, this.index0AttributeName = void 0, this.uniformsNeedUpdate = false, this.glslVersion = null, e !== void 0 && (e.attributes !== void 0 && console.error("THREE.ShaderMaterial: attributes should now be defined in THREE.BufferGeometry instead."), this.setValues(e)); } copy(e) { return super.copy(e), this.fragmentShader = e.fragmentShader, this.vertexShader = e.vertexShader, this.uniforms = Po(e.uniforms), this.defines = Object.assign({}, e.defines), this.wireframe = e.wireframe, this.wireframeLinewidth = e.wireframeLinewidth, this.lights = e.lights, this.clipping = e.clipping, this.morphTargets = e.morphTargets, this.morphNormals = e.morphNormals, this.extensions = Object.assign({}, e.extensions), this.glslVersion = e.glslVersion, this; } toJSON(e) { const t = super.toJSON(e); t.glslVersion = this.glslVersion, t.uniforms = {}; for (const r in this.uniforms) { const o = this.uniforms[r].value; o && o.isTexture ? t.uniforms[r] = { type: "t", value: o.toJSON(e).uuid } : o && o.isColor ? t.uniforms[r] = { type: "c", value: o.getHex() } : o && o.isVector2 ? t.uniforms[r] = { type: "v2", value: o.toArray() } : o && o.isVector3 ? t.uniforms[r] = { type: "v3", value: o.toArray() } : o && o.isVector4 ? t.uniforms[r] = { type: "v4", value: o.toArray() } : o && o.isMatrix3 ? t.uniforms[r] = { type: "m3", value: o.toArray() } : o && o.isMatrix4 ? t.uniforms[r] = { type: "m4", value: o.toArray() } : t.uniforms[r] = { value: o }; } Object.keys(this.defines).length > 0 && (t.defines = this.defines), t.vertexShader = this.vertexShader, t.fragmentShader = this.fragmentShader; const i = {}; for (const r in this.extensions) this.extensions[r] === true && (i[r] = true); return Object.keys(i).length > 0 && (t.extensions = i), t; } }; or.prototype.isShaderMaterial = true; var hl = class extends ut { constructor() { super(), this.type = "Camera", this.matrixWorldInverse = new Xe(), this.projectionMatrix = new Xe(), this.projectionMatrixInverse = new Xe(); } copy(e, t) { return super.copy(e, t), this.matrixWorldInverse.copy(e.matrixWorldInverse), this.projectionMatrix.copy(e.projectionMatrix), this.projectionMatrixInverse.copy(e.projectionMatrixInverse), this; } getWorldDirection(e) { this.updateWorldMatrix(true, false); const t = this.matrixWorld.elements; return e.set(-t[8], -t[9], -t[10]).normalize(); } updateMatrixWorld(e) { super.updateMatrixWorld(e), this.matrixWorldInverse.copy(this.matrixWorld).invert(); } updateWorldMatrix(e, t) { super.updateWorldMatrix(e, t), this.matrixWorldInverse.copy(this.matrixWorld).invert(); } clone() { return new this.constructor().copy(this); } }; hl.prototype.isCamera = true; var nn = class extends hl { constructor(e = 50, t = 1, i = 0.1, r = 2e3) { super(), this.type = "PerspectiveCamera", this.fov = e, this.zoom = 1, this.near = i, this.far = r, this.focus = 10, this.aspect = t, this.view = null, this.filmGauge = 35, this.filmOffset = 0, this.updateProjectionMatrix(); } copy(e, t) { return super.copy(e, t), this.fov = e.fov, this.zoom = e.zoom, this.near = e.near, this.far = e.far, this.focus = e.focus, this.aspect = e.aspect, this.view = e.view === null ? null : Object.assign({}, e.view), this.filmGauge = e.filmGauge, this.filmOffset = e.filmOffset, this; } /** * Sets the FOV by focal length in respect to the current .filmGauge. * * The default film gauge is 35, so that the focal length can be specified for * a 35mm (full frame) camera. * * Values for focal length and film gauge must have the same unit. */ setFocalLength(e) { const t = 0.5 * this.getFilmHeight() / e; this.fov = ja * 2 * Math.atan(t), this.updateProjectionMatrix(); } /** * Calculates the focal length from the current .fov and .filmGauge. */ getFocalLength() { const e = Math.tan(As * 0.5 * this.fov); return 0.5 * this.getFilmHeight() / e; } getEffectiveFOV() { return ja * 2 * Math.atan( Math.tan(As * 0.5 * this.fov) / this.zoom ); } getFilmWidth() { return this.filmGauge * Math.min(this.aspect, 1); } getFilmHeight() { return this.filmGauge / Math.max(this.aspect, 1); } /** * Sets an offset in a larger frustum. This is useful for multi-window or * multi-monitor/multi-machine setups. * * For example, if you have 3x2 monitors and each monitor is 1920x1080 and * the monitors are in grid like this * * +---+---+---+ * | A | B | C | * +---+---+---+ * | D | E | F | * +---+---+---+ * * then for each monitor you would call it like this * * const w = 1920; * const h = 1080; * const fullWidth = w * 3; * const fullHeight = h * 2; * * --A-- * camera.setViewOffset( fullWidth, fullHeight, w * 0, h * 0, w, h ); * --B-- * camera.setViewOffset( fullWidth, fullHeight, w * 1, h * 0, w, h ); * --C-- * camera.setViewOffset( fullWidth, fullHeight, w * 2, h * 0, w, h ); * --D-- * camera.setViewOffset( fullWidth, fullHeight, w * 0, h * 1, w, h ); * --E-- * camera.setViewOffset( fullWidth, fullHeight, w * 1, h * 1, w, h ); * --F-- * camera.setViewOffset( fullWidth, fullHeight, w * 2, h * 1, w, h ); * * Note there is no reason monitors have to be the same size or in a grid. */ setViewOffset(e, t, i, r, s, o) { this.aspect = e / t, this.view === null && (this.view = { enabled: true, fullWidth: 1, fullHeight: 1, offsetX: 0, offsetY: 0, width: 1, height: 1 }), this.view.enabled = true, this.view.fullWidth = e, this.view.fullHeight = t, this.view.offsetX = i, this.view.offsetY = r, this.view.width = s, this.view.height = o, this.updateProjectionMatrix(); } clearViewOffset() { this.view !== null && (this.view.enabled = false), this.updateProjectionMatrix(); } updateProjectionMatrix() { const e = this.near; let t = e * Math.tan(As * 0.5 * this.fov) / this.zoom, i = 2 * t, r = this.aspect * i, s = -0.5 * r; const o = this.view; if (this.view !== null && this.view.enabled) { const c = o.fullWidth, l = o.fullHeight; s += o.offsetX * r / c, t -= o.offsetY * i / l, r *= o.width / c, i *= o.height / l; } const a = this.filmOffset; a !== 0 && (s += e * a / this.getFilmWidth()), this.projectionMatrix.makePerspective(s, s + r, t, t - i, e, this.far), this.projectionMatrixInverse.copy(this.projectionMatrix).invert(); } toJSON(e) { const t = super.toJSON(e); return t.object.fov = this.fov, t.object.zoom = this.zoom, t.object.near = this.near, t.object.far = this.far, t.object.focus = this.focus, t.object.aspect = this.aspect, this.view !== null && (t.object.view = Object.assign({}, this.view)), t.object.filmGauge = this.filmGauge, t.object.filmOffset = this.filmOffset, t; } }; nn.prototype.isPerspectiveCamera = true; var to = 90; var no = 1; var yu = class extends ut { constructor(e, t, i) { if (super(), this.type = "CubeCamera", i.isWebGLCubeRenderTarget !== true) { console.error("THREE.CubeCamera: The constructor now expects an instance of WebGLCubeRenderTarget as third parameter."); return; } this.renderTarget = i; const r = new nn(to, no, e, t); r.layers = this.layers, r.up.set(0, -1, 0), r.lookAt(new q(1, 0, 0)), this.add(r); const s = new nn(to, no, e, t); s.layers = this.layers, s.up.set(0, -1, 0), s.lookAt(new q(-1, 0, 0)), this.add(s); const o = new nn(to, no, e, t); o.layers = this.layers, o.up.set(0, 0, 1), o.lookAt(new q(0, 1, 0)), this.add(o); const a = new nn(to, no, e, t); a.layers = this.layers, a.up.set(0, 0, -1), a.lookAt(new q(0, -1, 0)), this.add(a); const c = new nn(to, no, e, t); c.layers = this.layers, c.up.set(0, -1, 0), c.lookAt(new q(0, 0, 1)), this.add(c); const l = new nn(to, no, e, t); l.layers = this.layers, l.up.set(0, -1, 0), l.lookAt(new q(0, 0, -1)), this.add(l); } update(e, t) { this.parent === null && this.updateMatrixWorld(); const i = this.renderTarget, [r, s, o, a, c, l] = this.children, d = e.xr.enabled, h6 = e.getRenderTarget(); e.xr.enabled = false; const f = i.texture.generateMipmaps; i.texture.generateMipmaps = false, e.setRenderTarget(i, 0), e.render(t, r), e.setRenderTarget(i, 1), e.render(t, s), e.setRenderTarget(i, 2), e.render(t, o), e.setRenderTarget(i, 3), e.render(t, a), e.setRenderTarget(i, 4), e.render(t, c), i.texture.generateMipmaps = f, e.setRenderTarget(i, 5), e.render(t, l), e.setRenderTarget(h6), e.xr.enabled = d; } }; var ta = class extends Yt { constructor(e, t, i, r, s, o, a, c, l, d) { e = e !== void 0 ? e : [], t = t !== void 0 ? t : ll, a = a !== void 0 ? a : nr, super(e, t, i, r, s, o, a, c, l, d), this._needsFlipEnvMap = true, this.flipY = false; } get images() { return this.image; } set images(e) { this.image = e; } }; ta.prototype.isCubeTexture = true; var bu = class extends fi { constructor(e, t, i) { Number.isInteger(t) && (console.warn("THREE.WebGLCubeRenderTarget: constructor signature is now WebGLCubeRenderTarget( size, options )"), t = i), super(e, e, t), t = t || {}, this.texture = new ta(void 0, t.mapping, t.wrapS, t.wrapT, t.magFilter, t.minFilter, t.format, t.type, t.anisotropy, t.encoding), this.texture.generateMipmaps = t.generateMipmaps !== void 0 ? t.generateMipmaps : false, this.texture.minFilter = t.minFilter !== void 0 ? t.minFilter : zt, this.texture._needsFlipEnvMap = false; } fromEquirectangularTexture(e, t) { this.texture.type = t.type, this.texture.format = Gn, this.texture.encoding = t.encoding, this.texture.generateMipmaps = t.generateMipmaps, this.texture.minFilter = t.minFilter, this.texture.magFilter = t.magFilter; const i = { uniforms: { tEquirect: { value: null } }, vertexShader: ( /* glsl */ ` varying vec3 vWorldDirection; vec3 transformDirection( in vec3 dir, in mat4 matrix ) { return normalize( ( matrix * vec4( dir, 0.0 ) ).xyz ); } void main() { vWorldDirection = transformDirection( position, modelMatrix ); #include #include } ` ), fragmentShader: ( /* glsl */ ` uniform sampler2D tEquirect; varying vec3 vWorldDirection; #include void main() { vec3 direction = normalize( vWorldDirection ); vec2 sampleUV = equirectUv( direction ); gl_FragColor = texture2D( tEquirect, sampleUV ); } ` ) }, r = new sr(5, 5, 5), s = new or({ name: "CubemapFromEquirect", uniforms: Po(i.uniforms), vertexShader: i.vertexShader, fragmentShader: i.fragmentShader, side: jt, blending: tr }); s.uniforms.tEquirect.value = t; const o = new Xt(r, s), a = t.minFilter; return t.minFilter === fr && (t.minFilter = zt), new yu(1, 10, this).update(e, o), t.minFilter = a, o.geometry.dispose(), o.material.dispose(), this; } clear(e, t, i, r) { const s = e.getRenderTarget(); for (let o = 0; o < 6; o++) e.setRenderTarget(this, o), e.clear(t, i, r); e.setRenderTarget(s); } }; bu.prototype.isWebGLCubeRenderTarget = true; var ph = new q(); var SF = new q(); var _F = new rn(); var wi = class { constructor(e = new q(1, 0, 0), t = 0) { this.normal = e, this.constant = t; } set(e, t) { return this.normal.copy(e), this.constant = t, this; } setComponents(e, t, i, r) { return this.normal.set(e, t, i), this.constant = r, this; } setFromNormalAndCoplanarPoint(e, t) { return this.normal.copy(e), this.constant = -t.dot(this.normal), this; } setFromCoplanarPoints(e, t, i) { const r = ph.subVectors(i, t).cross(SF.subVectors(e, t)).normalize(); return this.setFromNormalAndCoplanarPoint(r, e), this; } copy(e) { return this.normal.copy(e.normal), this.constant = e.constant, this; } normalize() { const e = 1 / this.normal.length(); return this.normal.multiplyScalar(e), this.constant *= e, this; } negate() { return this.constant *= -1, this.normal.negate(), this; } distanceToPoint(e) { return this.normal.dot(e) + this.constant; } distanceToSphere(e) { return this.distanceToPoint(e.center) - e.radius; } projectPoint(e, t) { return t.copy(this.normal).multiplyScalar(-this.distanceToPoint(e)).add(e); } intersectLine(e, t) { const i = e.delta(ph), r = this.normal.dot(i); if (r === 0) return this.distanceToPoint(e.start) === 0 ? t.copy(e.start) : null; const s = -(e.start.dot(this.normal) + this.constant) / r; return s < 0 || s > 1 ? null : t.copy(i).multiplyScalar(s).add(e.start); } intersectsLine(e) { const t = this.distanceToPoint(e.start), i = this.distanceToPoint(e.end); return t < 0 && i > 0 || i < 0 && t > 0; } intersectsBox(e) { return e.intersectsPlane(this); } intersectsSphere(e) { return e.intersectsPlane(this); } coplanarPoint(e) { return e.copy(this.normal).multiplyScalar(-this.constant); } applyMatrix4(e, t) { const i = t || _F.getNormalMatrix(e), r = this.coplanarPoint(ph).applyMatrix4(e), s = this.normal.applyMatrix3(i).normalize(); return this.constant = -r.dot(s), this; } translate(e) { return this.constant -= e.dot(this.normal), this; } equals(e) { return e.normal.equals(this.normal) && e.constant === this.constant; } clone() { return new this.constructor().copy(this); } }; wi.prototype.isPlane = true; var io = new pr(); var Jl = new q(); var dl = class { constructor(e = new wi(), t = new wi(), i = new wi(), r = new wi(), s = new wi(), o = new wi()) { this.planes = [e, t, i, r, s, o]; } set(e, t, i, r, s, o) { const a = this.planes; return a[0].copy(e), a[1].copy(t), a[2].copy(i), a[3].copy(r), a[4].copy(s), a[5].copy(o), this; } copy(e) { const t = this.planes; for (let i = 0; i < 6; i++) t[i].copy(e.planes[i]); return this; } setFromProjectionMatrix(e) { const t = this.planes, i = e.elements, r = i[0], s = i[1], o = i[2], a = i[3], c = i[4], l = i[5], d = i[6], h6 = i[7], f = i[8], g = i[9], p = i[10], u = i[11], y = i[12], v = i[13], m = i[14], x = i[15]; return t[0].setComponents(a - r, h6 - c, u - f, x - y).normalize(), t[1].setComponents(a + r, h6 + c, u + f, x + y).normalize(), t[2].setComponents(a + s, h6 + l, u + g, x + v).normalize(), t[3].setComponents(a - s, h6 - l, u - g, x - v).normalize(), t[4].setComponents(a - o, h6 - d, u - p, x - m).normalize(), t[5].setComponents(a + o, h6 + d, u + p, x + m).normalize(), this; } intersectsObject(e) { const t = e.geometry; return t.boundingSphere === null && t.computeBoundingSphere(), io.copy(t.boundingSphere).applyMatrix4(e.matrixWorld), this.intersectsSphere(io); } intersectsSprite(e) { return io.center.set(0, 0, 0), io.radius = 0.7071067811865476, io.applyMatrix4(e.matrixWorld), this.intersectsSphere(io); } intersectsSphere(e) { const t = this.planes, i = e.center, r = -e.radius; for (let s = 0; s < 6; s++) if (t[s].distanceToPoint(i) < r) return false; return true; } intersectsBox(e) { const t = this.planes; for (let i = 0; i < 6; i++) { const r = t[i]; if (Jl.x = r.normal.x > 0 ? e.max.x : e.min.x, Jl.y = r.normal.y > 0 ? e.max.y : e.min.y, Jl.z = r.normal.z > 0 ? e.max.z : e.min.z, r.distanceToPoint(Jl) < 0) return false; } return true; } containsPoint(e) { const t = this.planes; for (let i = 0; i < 6; i++) if (t[i].distanceToPoint(e) < 0) return false; return true; } clone() { return new this.constructor().copy(this); } }; function dx() { let n = null, e = false, t = null, i = null; function r(s, o) { t(s, o), i = n.requestAnimationFrame(r); } return { start: function() { e !== true && t !== null && (i = n.requestAnimationFrame(r), e = true); }, stop: function() { n.cancelAnimationFrame(i), e = false; }, setAnimationLoop: function(s) { t = s; }, setContext: function(s) { n = s; } }; } function TF(n, e) { const t = e.isWebGL2, i = /* @__PURE__ */ new WeakMap(); function r(l, d) { const h6 = l.array, f = l.usage, g = n.createBuffer(); n.bindBuffer(d, g), n.bufferData(d, h6, f), l.onUploadCallback(); let p = 5126; return h6 instanceof Float32Array ? p = 5126 : h6 instanceof Float64Array ? console.warn("THREE.WebGLAttributes: Unsupported data buffer format: Float64Array.") : h6 instanceof Uint16Array ? l.isFloat16BufferAttribute ? t ? p = 5131 : console.warn("THREE.WebGLAttributes: Usage of Float16BufferAttribute requires WebGL2.") : p = 5123 : h6 instanceof Int16Array ? p = 5122 : h6 instanceof Uint32Array ? p = 5125 : h6 instanceof Int32Array ? p = 5124 : h6 instanceof Int8Array ? p = 5120 : (h6 instanceof Uint8Array || h6 instanceof Uint8ClampedArray) && (p = 5121), { buffer: g, type: p, bytesPerElement: h6.BYTES_PER_ELEMENT, version: l.version }; } function s(l, d, h6) { const f = d.array, g = d.updateRange; n.bindBuffer(h6, l), g.count === -1 ? n.bufferSubData(h6, 0, f) : (t ? n.bufferSubData( h6, g.offset * f.BYTES_PER_ELEMENT, f, g.offset, g.count ) : n.bufferSubData( h6, g.offset * f.BYTES_PER_ELEMENT, f.subarray(g.offset, g.offset + g.count) ), g.count = -1); } function o(l) { return l.isInterleavedBufferAttribute && (l = l.data), i.get(l); } function a(l) { l.isInterleavedBufferAttribute && (l = l.data); const d = i.get(l); d && (n.deleteBuffer(d.buffer), i.delete(l)); } function c(l, d) { if (l.isGLBufferAttribute) { const f = i.get(l); (!f || f.version < l.version) && i.set(l, { buffer: l.buffer, type: l.type, bytesPerElement: l.elementSize, version: l.version }); return; } l.isInterleavedBufferAttribute && (l = l.data); const h6 = i.get(l); h6 === void 0 ? i.set(l, r(l, d)) : h6.version < l.version && (s(h6.buffer, l, d), h6.version = l.version); } return { get: o, remove: a, update: c }; } var Ls = class _Ls extends Ke { constructor(e = 1, t = 1, i = 1, r = 1) { super(), this.type = "PlaneGeometry", this.parameters = { width: e, height: t, widthSegments: i, heightSegments: r }; const s = e / 2, o = t / 2, a = Math.floor(i), c = Math.floor(r), l = a + 1, d = c + 1, h6 = e / a, f = t / c, g = [], p = [], u = [], y = []; for (let v = 0; v < d; v++) { const m = v * f - o; for (let x = 0; x < l; x++) { const w = x * h6 - s; p.push(w, -m, 0), u.push(0, 0, 1), y.push(x / a), y.push(1 - v / c); } } for (let v = 0; v < c; v++) for (let m = 0; m < a; m++) { const x = m + l * v, w = m + l * (v + 1), A = m + 1 + l * (v + 1), M = m + 1 + l * v; g.push(x, w, M), g.push(w, A, M); } this.setIndex(g), this.setAttribute("position", new He(p, 3)), this.setAttribute("normal", new He(u, 3)), this.setAttribute("uv", new He(y, 2)); } static fromJSON(e) { return new _Ls(e.width, e.height, e.widthSegments, e.heightSegments); } }; var EF = `#ifdef USE_ALPHAMAP diffuseColor.a *= texture2D( alphaMap, vUv ).g; #endif`; var CF = `#ifdef USE_ALPHAMAP uniform sampler2D alphaMap; #endif`; var LF = `#ifdef ALPHATEST if ( diffuseColor.a < ALPHATEST ) discard; #endif`; var RF = `#ifdef USE_AOMAP float ambientOcclusion = ( texture2D( aoMap, vUv2 ).r - 1.0 ) * aoMapIntensity + 1.0; reflectedLight.indirectDiffuse *= ambientOcclusion; #if defined( USE_ENVMAP ) && defined( STANDARD ) float dotNV = saturate( dot( geometry.normal, geometry.viewDir ) ); reflectedLight.indirectSpecular *= computeSpecularOcclusion( dotNV, ambientOcclusion, material.specularRoughness ); #endif #endif`; var FF = `#ifdef USE_AOMAP uniform sampler2D aoMap; uniform float aoMapIntensity; #endif`; var PF = "vec3 transformed = vec3( position );"; var IF = `vec3 objectNormal = vec3( normal ); #ifdef USE_TANGENT vec3 objectTangent = vec3( tangent.xyz ); #endif`; var OF = `vec2 integrateSpecularBRDF( const in float dotNV, const in float roughness ) { const vec4 c0 = vec4( - 1, - 0.0275, - 0.572, 0.022 ); const vec4 c1 = vec4( 1, 0.0425, 1.04, - 0.04 ); vec4 r = roughness * c0 + c1; float a004 = min( r.x * r.x, exp2( - 9.28 * dotNV ) ) * r.x + r.y; return vec2( -1.04, 1.04 ) * a004 + r.zw; } float punctualLightIntensityToIrradianceFactor( const in float lightDistance, const in float cutoffDistance, const in float decayExponent ) { #if defined ( PHYSICALLY_CORRECT_LIGHTS ) float distanceFalloff = 1.0 / max( pow( lightDistance, decayExponent ), 0.01 ); if( cutoffDistance > 0.0 ) { distanceFalloff *= pow2( saturate( 1.0 - pow4( lightDistance / cutoffDistance ) ) ); } return distanceFalloff; #else if( cutoffDistance > 0.0 && decayExponent > 0.0 ) { return pow( saturate( -lightDistance / cutoffDistance + 1.0 ), decayExponent ); } return 1.0; #endif } vec3 BRDF_Diffuse_Lambert( const in vec3 diffuseColor ) { return RECIPROCAL_PI * diffuseColor; } vec3 F_Schlick( const in vec3 specularColor, const in float dotVH ) { float fresnel = exp2( ( -5.55473 * dotVH - 6.98316 ) * dotVH ); return ( 1.0 - specularColor ) * fresnel + specularColor; } vec3 F_Schlick_RoughnessDependent( const in vec3 F0, const in float dotNV, const in float roughness ) { float fresnel = exp2( ( -5.55473 * dotNV - 6.98316 ) * dotNV ); vec3 Fr = max( vec3( 1.0 - roughness ), F0 ) - F0; return Fr * fresnel + F0; } float G_GGX_Smith( const in float alpha, const in float dotNL, const in float dotNV ) { float a2 = pow2( alpha ); float gl = dotNL + sqrt( a2 + ( 1.0 - a2 ) * pow2( dotNL ) ); float gv = dotNV + sqrt( a2 + ( 1.0 - a2 ) * pow2( dotNV ) ); return 1.0 / ( gl * gv ); } float G_GGX_SmithCorrelated( const in float alpha, const in float dotNL, const in float dotNV ) { float a2 = pow2( alpha ); float gv = dotNL * sqrt( a2 + ( 1.0 - a2 ) * pow2( dotNV ) ); float gl = dotNV * sqrt( a2 + ( 1.0 - a2 ) * pow2( dotNL ) ); return 0.5 / max( gv + gl, EPSILON ); } float D_GGX( const in float alpha, const in float dotNH ) { float a2 = pow2( alpha ); float denom = pow2( dotNH ) * ( a2 - 1.0 ) + 1.0; return RECIPROCAL_PI * a2 / pow2( denom ); } vec3 BRDF_Specular_GGX( const in IncidentLight incidentLight, const in vec3 viewDir, const in vec3 normal, const in vec3 specularColor, const in float roughness ) { float alpha = pow2( roughness ); vec3 halfDir = normalize( incidentLight.direction + viewDir ); float dotNL = saturate( dot( normal, incidentLight.direction ) ); float dotNV = saturate( dot( normal, viewDir ) ); float dotNH = saturate( dot( normal, halfDir ) ); float dotLH = saturate( dot( incidentLight.direction, halfDir ) ); vec3 F = F_Schlick( specularColor, dotLH ); float G = G_GGX_SmithCorrelated( alpha, dotNL, dotNV ); float D = D_GGX( alpha, dotNH ); return F * ( G * D ); } vec2 LTC_Uv( const in vec3 N, const in vec3 V, const in float roughness ) { const float LUT_SIZE = 64.0; const float LUT_SCALE = ( LUT_SIZE - 1.0 ) / LUT_SIZE; const float LUT_BIAS = 0.5 / LUT_SIZE; float dotNV = saturate( dot( N, V ) ); vec2 uv = vec2( roughness, sqrt( 1.0 - dotNV ) ); uv = uv * LUT_SCALE + LUT_BIAS; return uv; } float LTC_ClippedSphereFormFactor( const in vec3 f ) { float l = length( f ); return max( ( l * l + f.z ) / ( l + 1.0 ), 0.0 ); } vec3 LTC_EdgeVectorFormFactor( const in vec3 v1, const in vec3 v2 ) { float x = dot( v1, v2 ); float y = abs( x ); float a = 0.8543985 + ( 0.4965155 + 0.0145206 * y ) * y; float b = 3.4175940 + ( 4.1616724 + y ) * y; float v = a / b; float theta_sintheta = ( x > 0.0 ) ? v : 0.5 * inversesqrt( max( 1.0 - x * x, 1e-7 ) ) - v; return cross( v1, v2 ) * theta_sintheta; } vec3 LTC_Evaluate( const in vec3 N, const in vec3 V, const in vec3 P, const in mat3 mInv, const in vec3 rectCoords[ 4 ] ) { vec3 v1 = rectCoords[ 1 ] - rectCoords[ 0 ]; vec3 v2 = rectCoords[ 3 ] - rectCoords[ 0 ]; vec3 lightNormal = cross( v1, v2 ); if( dot( lightNormal, P - rectCoords[ 0 ] ) < 0.0 ) return vec3( 0.0 ); vec3 T1, T2; T1 = normalize( V - N * dot( V, N ) ); T2 = - cross( N, T1 ); mat3 mat = mInv * transposeMat3( mat3( T1, T2, N ) ); vec3 coords[ 4 ]; coords[ 0 ] = mat * ( rectCoords[ 0 ] - P ); coords[ 1 ] = mat * ( rectCoords[ 1 ] - P ); coords[ 2 ] = mat * ( rectCoords[ 2 ] - P ); coords[ 3 ] = mat * ( rectCoords[ 3 ] - P ); coords[ 0 ] = normalize( coords[ 0 ] ); coords[ 1 ] = normalize( coords[ 1 ] ); coords[ 2 ] = normalize( coords[ 2 ] ); coords[ 3 ] = normalize( coords[ 3 ] ); vec3 vectorFormFactor = vec3( 0.0 ); vectorFormFactor += LTC_EdgeVectorFormFactor( coords[ 0 ], coords[ 1 ] ); vectorFormFactor += LTC_EdgeVectorFormFactor( coords[ 1 ], coords[ 2 ] ); vectorFormFactor += LTC_EdgeVectorFormFactor( coords[ 2 ], coords[ 3 ] ); vectorFormFactor += LTC_EdgeVectorFormFactor( coords[ 3 ], coords[ 0 ] ); float result = LTC_ClippedSphereFormFactor( vectorFormFactor ); return vec3( result ); } vec3 BRDF_Specular_GGX_Environment( const in vec3 viewDir, const in vec3 normal, const in vec3 specularColor, const in float roughness ) { float dotNV = saturate( dot( normal, viewDir ) ); vec2 brdf = integrateSpecularBRDF( dotNV, roughness ); return specularColor * brdf.x + brdf.y; } void BRDF_Specular_Multiscattering_Environment( const in GeometricContext geometry, const in vec3 specularColor, const in float roughness, inout vec3 singleScatter, inout vec3 multiScatter ) { float dotNV = saturate( dot( geometry.normal, geometry.viewDir ) ); vec3 F = F_Schlick_RoughnessDependent( specularColor, dotNV, roughness ); vec2 brdf = integrateSpecularBRDF( dotNV, roughness ); vec3 FssEss = F * brdf.x + brdf.y; float Ess = brdf.x + brdf.y; float Ems = 1.0 - Ess; vec3 Favg = specularColor + ( 1.0 - specularColor ) * 0.047619; vec3 Fms = FssEss * Favg / ( 1.0 - Ems * Favg ); singleScatter += FssEss; multiScatter += Fms * Ems; } float G_BlinnPhong_Implicit( ) { return 0.25; } float D_BlinnPhong( const in float shininess, const in float dotNH ) { return RECIPROCAL_PI * ( shininess * 0.5 + 1.0 ) * pow( dotNH, shininess ); } vec3 BRDF_Specular_BlinnPhong( const in IncidentLight incidentLight, const in GeometricContext geometry, const in vec3 specularColor, const in float shininess ) { vec3 halfDir = normalize( incidentLight.direction + geometry.viewDir ); float dotNH = saturate( dot( geometry.normal, halfDir ) ); float dotLH = saturate( dot( incidentLight.direction, halfDir ) ); vec3 F = F_Schlick( specularColor, dotLH ); float G = G_BlinnPhong_Implicit( ); float D = D_BlinnPhong( shininess, dotNH ); return F * ( G * D ); } float GGXRoughnessToBlinnExponent( const in float ggxRoughness ) { return ( 2.0 / pow2( ggxRoughness + 0.0001 ) - 2.0 ); } float BlinnExponentToGGXRoughness( const in float blinnExponent ) { return sqrt( 2.0 / ( blinnExponent + 2.0 ) ); } #if defined( USE_SHEEN ) float D_Charlie(float roughness, float NoH) { float invAlpha = 1.0 / roughness; float cos2h = NoH * NoH; float sin2h = max(1.0 - cos2h, 0.0078125); return (2.0 + invAlpha) * pow(sin2h, invAlpha * 0.5) / (2.0 * PI); } float V_Neubelt(float NoV, float NoL) { return saturate(1.0 / (4.0 * (NoL + NoV - NoL * NoV))); } vec3 BRDF_Specular_Sheen( const in float roughness, const in vec3 L, const in GeometricContext geometry, vec3 specularColor ) { vec3 N = geometry.normal; vec3 V = geometry.viewDir; vec3 H = normalize( V + L ); float dotNH = saturate( dot( N, H ) ); return specularColor * D_Charlie( roughness, dotNH ) * V_Neubelt( dot(N, V), dot(N, L) ); } #endif`; var DF = `#ifdef USE_BUMPMAP uniform sampler2D bumpMap; uniform float bumpScale; vec2 dHdxy_fwd() { vec2 dSTdx = dFdx( vUv ); vec2 dSTdy = dFdy( vUv ); float Hll = bumpScale * texture2D( bumpMap, vUv ).x; float dBx = bumpScale * texture2D( bumpMap, vUv + dSTdx ).x - Hll; float dBy = bumpScale * texture2D( bumpMap, vUv + dSTdy ).x - Hll; return vec2( dBx, dBy ); } vec3 perturbNormalArb( vec3 surf_pos, vec3 surf_norm, vec2 dHdxy, float faceDirection ) { vec3 vSigmaX = vec3( dFdx( surf_pos.x ), dFdx( surf_pos.y ), dFdx( surf_pos.z ) ); vec3 vSigmaY = vec3( dFdy( surf_pos.x ), dFdy( surf_pos.y ), dFdy( surf_pos.z ) ); vec3 vN = surf_norm; vec3 R1 = cross( vSigmaY, vN ); vec3 R2 = cross( vN, vSigmaX ); float fDet = dot( vSigmaX, R1 ) * faceDirection; vec3 vGrad = sign( fDet ) * ( dHdxy.x * R1 + dHdxy.y * R2 ); return normalize( abs( fDet ) * surf_norm - vGrad ); } #endif`; var NF = `#if NUM_CLIPPING_PLANES > 0 vec4 plane; #pragma unroll_loop_start for ( int i = 0; i < UNION_CLIPPING_PLANES; i ++ ) { plane = clippingPlanes[ i ]; if ( dot( vClipPosition, plane.xyz ) > plane.w ) discard; } #pragma unroll_loop_end #if UNION_CLIPPING_PLANES < NUM_CLIPPING_PLANES bool clipped = true; #pragma unroll_loop_start for ( int i = UNION_CLIPPING_PLANES; i < NUM_CLIPPING_PLANES; i ++ ) { plane = clippingPlanes[ i ]; clipped = ( dot( vClipPosition, plane.xyz ) > plane.w ) && clipped; } #pragma unroll_loop_end if ( clipped ) discard; #endif #endif`; var BF = `#if NUM_CLIPPING_PLANES > 0 varying vec3 vClipPosition; uniform vec4 clippingPlanes[ NUM_CLIPPING_PLANES ]; #endif`; var UF = `#if NUM_CLIPPING_PLANES > 0 varying vec3 vClipPosition; #endif`; var zF = `#if NUM_CLIPPING_PLANES > 0 vClipPosition = - mvPosition.xyz; #endif`; var VF = `#if defined( USE_COLOR_ALPHA ) diffuseColor *= vColor; #elif defined( USE_COLOR ) diffuseColor.rgb *= vColor; #endif`; var kF = `#if defined( USE_COLOR_ALPHA ) varying vec4 vColor; #elif defined( USE_COLOR ) varying vec3 vColor; #endif`; var GF = `#if defined( USE_COLOR_ALPHA ) varying vec4 vColor; #elif defined( USE_COLOR ) || defined( USE_INSTANCING_COLOR ) varying vec3 vColor; #endif`; var HF = `#if defined( USE_COLOR_ALPHA ) vColor = vec4( 1.0 ); #elif defined( USE_COLOR ) || defined( USE_INSTANCING_COLOR ) vColor = vec3( 1.0 ); #endif #ifdef USE_COLOR vColor *= color; #endif #ifdef USE_INSTANCING_COLOR vColor.xyz *= instanceColor.xyz; #endif`; var WF = `#define PI 3.141592653589793 #define PI2 6.283185307179586 #define PI_HALF 1.5707963267948966 #define RECIPROCAL_PI 0.3183098861837907 #define RECIPROCAL_PI2 0.15915494309189535 #define EPSILON 1e-6 #ifndef saturate #define saturate(a) clamp( a, 0.0, 1.0 ) #endif #define whiteComplement(a) ( 1.0 - saturate( a ) ) float pow2( const in float x ) { return x*x; } float pow3( const in float x ) { return x*x*x; } float pow4( const in float x ) { float x2 = x*x; return x2*x2; } float average( const in vec3 color ) { return dot( color, vec3( 0.3333 ) ); } highp float rand( const in vec2 uv ) { const highp float a = 12.9898, b = 78.233, c = 43758.5453; highp float dt = dot( uv.xy, vec2( a,b ) ), sn = mod( dt, PI ); return fract(sin(sn) * c); } #ifdef HIGH_PRECISION float precisionSafeLength( vec3 v ) { return length( v ); } #else float max3( vec3 v ) { return max( max( v.x, v.y ), v.z ); } float precisionSafeLength( vec3 v ) { float maxComponent = max3( abs( v ) ); return length( v / maxComponent ) * maxComponent; } #endif struct IncidentLight { vec3 color; vec3 direction; bool visible; }; struct ReflectedLight { vec3 directDiffuse; vec3 directSpecular; vec3 indirectDiffuse; vec3 indirectSpecular; }; struct GeometricContext { vec3 position; vec3 normal; vec3 viewDir; #ifdef CLEARCOAT vec3 clearcoatNormal; #endif }; vec3 transformDirection( in vec3 dir, in mat4 matrix ) { return normalize( ( matrix * vec4( dir, 0.0 ) ).xyz ); } vec3 inverseTransformDirection( in vec3 dir, in mat4 matrix ) { return normalize( ( vec4( dir, 0.0 ) * matrix ).xyz ); } vec3 projectOnPlane(in vec3 point, in vec3 pointOnPlane, in vec3 planeNormal ) { float distance = dot( planeNormal, point - pointOnPlane ); return - distance * planeNormal + point; } float sideOfPlane( in vec3 point, in vec3 pointOnPlane, in vec3 planeNormal ) { return sign( dot( point - pointOnPlane, planeNormal ) ); } vec3 linePlaneIntersect( in vec3 pointOnLine, in vec3 lineDirection, in vec3 pointOnPlane, in vec3 planeNormal ) { return lineDirection * ( dot( planeNormal, pointOnPlane - pointOnLine ) / dot( planeNormal, lineDirection ) ) + pointOnLine; } mat3 transposeMat3( const in mat3 m ) { mat3 tmp; tmp[ 0 ] = vec3( m[ 0 ].x, m[ 1 ].x, m[ 2 ].x ); tmp[ 1 ] = vec3( m[ 0 ].y, m[ 1 ].y, m[ 2 ].y ); tmp[ 2 ] = vec3( m[ 0 ].z, m[ 1 ].z, m[ 2 ].z ); return tmp; } float linearToRelativeLuminance( const in vec3 color ) { vec3 weights = vec3( 0.2126, 0.7152, 0.0722 ); return dot( weights, color.rgb ); } bool isPerspectiveMatrix( mat4 m ) { return m[ 2 ][ 3 ] == - 1.0; } vec2 equirectUv( in vec3 dir ) { float u = atan( dir.z, dir.x ) * RECIPROCAL_PI2 + 0.5; float v = asin( clamp( dir.y, - 1.0, 1.0 ) ) * RECIPROCAL_PI + 0.5; return vec2( u, v ); }`; var jF = `#ifdef ENVMAP_TYPE_CUBE_UV #define cubeUV_maxMipLevel 8.0 #define cubeUV_minMipLevel 4.0 #define cubeUV_maxTileSize 256.0 #define cubeUV_minTileSize 16.0 float getFace( vec3 direction ) { vec3 absDirection = abs( direction ); float face = - 1.0; if ( absDirection.x > absDirection.z ) { if ( absDirection.x > absDirection.y ) face = direction.x > 0.0 ? 0.0 : 3.0; else face = direction.y > 0.0 ? 1.0 : 4.0; } else { if ( absDirection.z > absDirection.y ) face = direction.z > 0.0 ? 2.0 : 5.0; else face = direction.y > 0.0 ? 1.0 : 4.0; } return face; } vec2 getUV( vec3 direction, float face ) { vec2 uv; if ( face == 0.0 ) { uv = vec2( direction.z, direction.y ) / abs( direction.x ); } else if ( face == 1.0 ) { uv = vec2( - direction.x, - direction.z ) / abs( direction.y ); } else if ( face == 2.0 ) { uv = vec2( - direction.x, direction.y ) / abs( direction.z ); } else if ( face == 3.0 ) { uv = vec2( - direction.z, direction.y ) / abs( direction.x ); } else if ( face == 4.0 ) { uv = vec2( - direction.x, direction.z ) / abs( direction.y ); } else { uv = vec2( direction.x, direction.y ) / abs( direction.z ); } return 0.5 * ( uv + 1.0 ); } vec3 bilinearCubeUV( sampler2D envMap, vec3 direction, float mipInt ) { float face = getFace( direction ); float filterInt = max( cubeUV_minMipLevel - mipInt, 0.0 ); mipInt = max( mipInt, cubeUV_minMipLevel ); float faceSize = exp2( mipInt ); float texelSize = 1.0 / ( 3.0 * cubeUV_maxTileSize ); vec2 uv = getUV( direction, face ) * ( faceSize - 1.0 ); vec2 f = fract( uv ); uv += 0.5 - f; if ( face > 2.0 ) { uv.y += faceSize; face -= 3.0; } uv.x += face * faceSize; if ( mipInt < cubeUV_maxMipLevel ) { uv.y += 2.0 * cubeUV_maxTileSize; } uv.y += filterInt * 2.0 * cubeUV_minTileSize; uv.x += 3.0 * max( 0.0, cubeUV_maxTileSize - 2.0 * faceSize ); uv *= texelSize; vec3 tl = envMapTexelToLinear( texture2D( envMap, uv ) ).rgb; uv.x += texelSize; vec3 tr = envMapTexelToLinear( texture2D( envMap, uv ) ).rgb; uv.y += texelSize; vec3 br = envMapTexelToLinear( texture2D( envMap, uv ) ).rgb; uv.x -= texelSize; vec3 bl = envMapTexelToLinear( texture2D( envMap, uv ) ).rgb; vec3 tm = mix( tl, tr, f.x ); vec3 bm = mix( bl, br, f.x ); return mix( tm, bm, f.y ); } #define r0 1.0 #define v0 0.339 #define m0 - 2.0 #define r1 0.8 #define v1 0.276 #define m1 - 1.0 #define r4 0.4 #define v4 0.046 #define m4 2.0 #define r5 0.305 #define v5 0.016 #define m5 3.0 #define r6 0.21 #define v6 0.0038 #define m6 4.0 float roughnessToMip( float roughness ) { float mip = 0.0; if ( roughness >= r1 ) { mip = ( r0 - roughness ) * ( m1 - m0 ) / ( r0 - r1 ) + m0; } else if ( roughness >= r4 ) { mip = ( r1 - roughness ) * ( m4 - m1 ) / ( r1 - r4 ) + m1; } else if ( roughness >= r5 ) { mip = ( r4 - roughness ) * ( m5 - m4 ) / ( r4 - r5 ) + m4; } else if ( roughness >= r6 ) { mip = ( r5 - roughness ) * ( m6 - m5 ) / ( r5 - r6 ) + m5; } else { mip = - 2.0 * log2( 1.16 * roughness ); } return mip; } vec4 textureCubeUV( sampler2D envMap, vec3 sampleDir, float roughness ) { float mip = clamp( roughnessToMip( roughness ), m0, cubeUV_maxMipLevel ); float mipF = fract( mip ); float mipInt = floor( mip ); vec3 color0 = bilinearCubeUV( envMap, sampleDir, mipInt ); if ( mipF == 0.0 ) { return vec4( color0, 1.0 ); } else { vec3 color1 = bilinearCubeUV( envMap, sampleDir, mipInt + 1.0 ); return vec4( mix( color0, color1, mipF ), 1.0 ); } } #endif`; var $F = `vec3 transformedNormal = objectNormal; #ifdef USE_INSTANCING mat3 m = mat3( instanceMatrix ); transformedNormal /= vec3( dot( m[ 0 ], m[ 0 ] ), dot( m[ 1 ], m[ 1 ] ), dot( m[ 2 ], m[ 2 ] ) ); transformedNormal = m * transformedNormal; #endif transformedNormal = normalMatrix * transformedNormal; #ifdef FLIP_SIDED transformedNormal = - transformedNormal; #endif #ifdef USE_TANGENT vec3 transformedTangent = ( modelViewMatrix * vec4( objectTangent, 0.0 ) ).xyz; #ifdef FLIP_SIDED transformedTangent = - transformedTangent; #endif #endif`; var ZF = `#ifdef USE_DISPLACEMENTMAP uniform sampler2D displacementMap; uniform float displacementScale; uniform float displacementBias; #endif`; var XF = `#ifdef USE_DISPLACEMENTMAP transformed += normalize( objectNormal ) * ( texture2D( displacementMap, vUv ).x * displacementScale + displacementBias ); #endif`; var YF = `#ifdef USE_EMISSIVEMAP vec4 emissiveColor = texture2D( emissiveMap, vUv ); emissiveColor.rgb = emissiveMapTexelToLinear( emissiveColor ).rgb; totalEmissiveRadiance *= emissiveColor.rgb; #endif`; var JF = `#ifdef USE_EMISSIVEMAP uniform sampler2D emissiveMap; #endif`; var KF = "gl_FragColor = linearToOutputTexel( gl_FragColor );"; var qF = ` vec4 LinearToLinear( in vec4 value ) { return value; } vec4 GammaToLinear( in vec4 value, in float gammaFactor ) { return vec4( pow( value.rgb, vec3( gammaFactor ) ), value.a ); } vec4 LinearToGamma( in vec4 value, in float gammaFactor ) { return vec4( pow( value.rgb, vec3( 1.0 / gammaFactor ) ), value.a ); } vec4 sRGBToLinear( in vec4 value ) { return vec4( mix( pow( value.rgb * 0.9478672986 + vec3( 0.0521327014 ), vec3( 2.4 ) ), value.rgb * 0.0773993808, vec3( lessThanEqual( value.rgb, vec3( 0.04045 ) ) ) ), value.a ); } vec4 LinearTosRGB( in vec4 value ) { return vec4( mix( pow( value.rgb, vec3( 0.41666 ) ) * 1.055 - vec3( 0.055 ), value.rgb * 12.92, vec3( lessThanEqual( value.rgb, vec3( 0.0031308 ) ) ) ), value.a ); } vec4 RGBEToLinear( in vec4 value ) { return vec4( value.rgb * exp2( value.a * 255.0 - 128.0 ), 1.0 ); } vec4 LinearToRGBE( in vec4 value ) { float maxComponent = max( max( value.r, value.g ), value.b ); float fExp = clamp( ceil( log2( maxComponent ) ), -128.0, 127.0 ); return vec4( value.rgb / exp2( fExp ), ( fExp + 128.0 ) / 255.0 ); } vec4 RGBMToLinear( in vec4 value, in float maxRange ) { return vec4( value.rgb * value.a * maxRange, 1.0 ); } vec4 LinearToRGBM( in vec4 value, in float maxRange ) { float maxRGB = max( value.r, max( value.g, value.b ) ); float M = clamp( maxRGB / maxRange, 0.0, 1.0 ); M = ceil( M * 255.0 ) / 255.0; return vec4( value.rgb / ( M * maxRange ), M ); } vec4 RGBDToLinear( in vec4 value, in float maxRange ) { return vec4( value.rgb * ( ( maxRange / 255.0 ) / value.a ), 1.0 ); } vec4 LinearToRGBD( in vec4 value, in float maxRange ) { float maxRGB = max( value.r, max( value.g, value.b ) ); float D = max( maxRange / maxRGB, 1.0 ); D = clamp( floor( D ) / 255.0, 0.0, 1.0 ); return vec4( value.rgb * ( D * ( 255.0 / maxRange ) ), D ); } const mat3 cLogLuvM = mat3( 0.2209, 0.3390, 0.4184, 0.1138, 0.6780, 0.7319, 0.0102, 0.1130, 0.2969 ); vec4 LinearToLogLuv( in vec4 value ) { vec3 Xp_Y_XYZp = cLogLuvM * value.rgb; Xp_Y_XYZp = max( Xp_Y_XYZp, vec3( 1e-6, 1e-6, 1e-6 ) ); vec4 vResult; vResult.xy = Xp_Y_XYZp.xy / Xp_Y_XYZp.z; float Le = 2.0 * log2(Xp_Y_XYZp.y) + 127.0; vResult.w = fract( Le ); vResult.z = ( Le - ( floor( vResult.w * 255.0 ) ) / 255.0 ) / 255.0; return vResult; } const mat3 cLogLuvInverseM = mat3( 6.0014, -2.7008, -1.7996, -1.3320, 3.1029, -5.7721, 0.3008, -1.0882, 5.6268 ); vec4 LogLuvToLinear( in vec4 value ) { float Le = value.z * 255.0 + value.w; vec3 Xp_Y_XYZp; Xp_Y_XYZp.y = exp2( ( Le - 127.0 ) / 2.0 ); Xp_Y_XYZp.z = Xp_Y_XYZp.y / value.y; Xp_Y_XYZp.x = value.x * Xp_Y_XYZp.z; vec3 vRGB = cLogLuvInverseM * Xp_Y_XYZp.rgb; return vec4( max( vRGB, 0.0 ), 1.0 ); }`; var QF = `#ifdef USE_ENVMAP #ifdef ENV_WORLDPOS vec3 cameraToFrag; if ( isOrthographic ) { cameraToFrag = normalize( vec3( - viewMatrix[ 0 ][ 2 ], - viewMatrix[ 1 ][ 2 ], - viewMatrix[ 2 ][ 2 ] ) ); } else { cameraToFrag = normalize( vWorldPosition - cameraPosition ); } vec3 worldNormal = inverseTransformDirection( normal, viewMatrix ); #ifdef ENVMAP_MODE_REFLECTION vec3 reflectVec = reflect( cameraToFrag, worldNormal ); #else vec3 reflectVec = refract( cameraToFrag, worldNormal, refractionRatio ); #endif #else vec3 reflectVec = vReflect; #endif #ifdef ENVMAP_TYPE_CUBE vec4 envColor = textureCube( envMap, vec3( flipEnvMap * reflectVec.x, reflectVec.yz ) ); #elif defined( ENVMAP_TYPE_CUBE_UV ) vec4 envColor = textureCubeUV( envMap, reflectVec, 0.0 ); #else vec4 envColor = vec4( 0.0 ); #endif #ifndef ENVMAP_TYPE_CUBE_UV envColor = envMapTexelToLinear( envColor ); #endif #ifdef ENVMAP_BLENDING_MULTIPLY outgoingLight = mix( outgoingLight, outgoingLight * envColor.xyz, specularStrength * reflectivity ); #elif defined( ENVMAP_BLENDING_MIX ) outgoingLight = mix( outgoingLight, envColor.xyz, specularStrength * reflectivity ); #elif defined( ENVMAP_BLENDING_ADD ) outgoingLight += envColor.xyz * specularStrength * reflectivity; #endif #endif`; var eP = `#ifdef USE_ENVMAP uniform float envMapIntensity; uniform float flipEnvMap; uniform int maxMipLevel; #ifdef ENVMAP_TYPE_CUBE uniform samplerCube envMap; #else uniform sampler2D envMap; #endif #endif`; var tP = `#ifdef USE_ENVMAP uniform float reflectivity; #if defined( USE_BUMPMAP ) || defined( USE_NORMALMAP ) || defined( PHONG ) #define ENV_WORLDPOS #endif #ifdef ENV_WORLDPOS varying vec3 vWorldPosition; uniform float refractionRatio; #else varying vec3 vReflect; #endif #endif`; var nP = `#ifdef USE_ENVMAP #if defined( USE_BUMPMAP ) || defined( USE_NORMALMAP ) ||defined( PHONG ) #define ENV_WORLDPOS #endif #ifdef ENV_WORLDPOS varying vec3 vWorldPosition; #else varying vec3 vReflect; uniform float refractionRatio; #endif #endif`; var iP = `#ifdef USE_ENVMAP #ifdef ENV_WORLDPOS vWorldPosition = worldPosition.xyz; #else vec3 cameraToVertex; if ( isOrthographic ) { cameraToVertex = normalize( vec3( - viewMatrix[ 0 ][ 2 ], - viewMatrix[ 1 ][ 2 ], - viewMatrix[ 2 ][ 2 ] ) ); } else { cameraToVertex = normalize( worldPosition.xyz - cameraPosition ); } vec3 worldNormal = inverseTransformDirection( transformedNormal, viewMatrix ); #ifdef ENVMAP_MODE_REFLECTION vReflect = reflect( cameraToVertex, worldNormal ); #else vReflect = refract( cameraToVertex, worldNormal, refractionRatio ); #endif #endif #endif`; var rP = `#ifdef USE_FOG fogDepth = - mvPosition.z; #endif`; var sP = `#ifdef USE_FOG varying float fogDepth; #endif`; var oP = `#ifdef USE_FOG #ifdef FOG_EXP2 float fogFactor = 1.0 - exp( - fogDensity * fogDensity * fogDepth * fogDepth ); #else float fogFactor = smoothstep( fogNear, fogFar, fogDepth ); #endif gl_FragColor.rgb = mix( gl_FragColor.rgb, fogColor, fogFactor ); #endif`; var aP = `#ifdef USE_FOG uniform vec3 fogColor; varying float fogDepth; #ifdef FOG_EXP2 uniform float fogDensity; #else uniform float fogNear; uniform float fogFar; #endif #endif`; var lP = `#ifdef USE_GRADIENTMAP uniform sampler2D gradientMap; #endif vec3 getGradientIrradiance( vec3 normal, vec3 lightDirection ) { float dotNL = dot( normal, lightDirection ); vec2 coord = vec2( dotNL * 0.5 + 0.5, 0.0 ); #ifdef USE_GRADIENTMAP return texture2D( gradientMap, coord ).rgb; #else return ( coord.x < 0.7 ) ? vec3( 0.7 ) : vec3( 1.0 ); #endif }`; var cP = `#ifdef USE_LIGHTMAP vec4 lightMapTexel= texture2D( lightMap, vUv2 ); reflectedLight.indirectDiffuse += PI * lightMapTexelToLinear( lightMapTexel ).rgb * lightMapIntensity; #endif`; var uP = `#ifdef USE_LIGHTMAP uniform sampler2D lightMap; uniform float lightMapIntensity; #endif`; var hP = `vec3 diffuse = vec3( 1.0 ); GeometricContext geometry; geometry.position = mvPosition.xyz; geometry.normal = normalize( transformedNormal ); geometry.viewDir = ( isOrthographic ) ? vec3( 0, 0, 1 ) : normalize( -mvPosition.xyz ); GeometricContext backGeometry; backGeometry.position = geometry.position; backGeometry.normal = -geometry.normal; backGeometry.viewDir = geometry.viewDir; vLightFront = vec3( 0.0 ); vIndirectFront = vec3( 0.0 ); #ifdef DOUBLE_SIDED vLightBack = vec3( 0.0 ); vIndirectBack = vec3( 0.0 ); #endif IncidentLight directLight; float dotNL; vec3 directLightColor_Diffuse; vIndirectFront += getAmbientLightIrradiance( ambientLightColor ); vIndirectFront += getLightProbeIrradiance( lightProbe, geometry ); #ifdef DOUBLE_SIDED vIndirectBack += getAmbientLightIrradiance( ambientLightColor ); vIndirectBack += getLightProbeIrradiance( lightProbe, backGeometry ); #endif #if NUM_POINT_LIGHTS > 0 #pragma unroll_loop_start for ( int i = 0; i < NUM_POINT_LIGHTS; i ++ ) { getPointDirectLightIrradiance( pointLights[ i ], geometry, directLight ); dotNL = dot( geometry.normal, directLight.direction ); directLightColor_Diffuse = PI * directLight.color; vLightFront += saturate( dotNL ) * directLightColor_Diffuse; #ifdef DOUBLE_SIDED vLightBack += saturate( -dotNL ) * directLightColor_Diffuse; #endif } #pragma unroll_loop_end #endif #if NUM_SPOT_LIGHTS > 0 #pragma unroll_loop_start for ( int i = 0; i < NUM_SPOT_LIGHTS; i ++ ) { getSpotDirectLightIrradiance( spotLights[ i ], geometry, directLight ); dotNL = dot( geometry.normal, directLight.direction ); directLightColor_Diffuse = PI * directLight.color; vLightFront += saturate( dotNL ) * directLightColor_Diffuse; #ifdef DOUBLE_SIDED vLightBack += saturate( -dotNL ) * directLightColor_Diffuse; #endif } #pragma unroll_loop_end #endif #if NUM_DIR_LIGHTS > 0 #pragma unroll_loop_start for ( int i = 0; i < NUM_DIR_LIGHTS; i ++ ) { getDirectionalDirectLightIrradiance( directionalLights[ i ], geometry, directLight ); dotNL = dot( geometry.normal, directLight.direction ); directLightColor_Diffuse = PI * directLight.color; vLightFront += saturate( dotNL ) * directLightColor_Diffuse; #ifdef DOUBLE_SIDED vLightBack += saturate( -dotNL ) * directLightColor_Diffuse; #endif } #pragma unroll_loop_end #endif #if NUM_HEMI_LIGHTS > 0 #pragma unroll_loop_start for ( int i = 0; i < NUM_HEMI_LIGHTS; i ++ ) { vIndirectFront += getHemisphereLightIrradiance( hemisphereLights[ i ], geometry ); #ifdef DOUBLE_SIDED vIndirectBack += getHemisphereLightIrradiance( hemisphereLights[ i ], backGeometry ); #endif } #pragma unroll_loop_end #endif`; var dP = `uniform bool receiveShadow; uniform vec3 ambientLightColor; uniform vec3 lightProbe[ 9 ]; vec3 shGetIrradianceAt( in vec3 normal, in vec3 shCoefficients[ 9 ] ) { float x = normal.x, y = normal.y, z = normal.z; vec3 result = shCoefficients[ 0 ] * 0.886227; result += shCoefficients[ 1 ] * 2.0 * 0.511664 * y; result += shCoefficients[ 2 ] * 2.0 * 0.511664 * z; result += shCoefficients[ 3 ] * 2.0 * 0.511664 * x; result += shCoefficients[ 4 ] * 2.0 * 0.429043 * x * y; result += shCoefficients[ 5 ] * 2.0 * 0.429043 * y * z; result += shCoefficients[ 6 ] * ( 0.743125 * z * z - 0.247708 ); result += shCoefficients[ 7 ] * 2.0 * 0.429043 * x * z; result += shCoefficients[ 8 ] * 0.429043 * ( x * x - y * y ); return result; } vec3 getLightProbeIrradiance( const in vec3 lightProbe[ 9 ], const in GeometricContext geometry ) { vec3 worldNormal = inverseTransformDirection( geometry.normal, viewMatrix ); vec3 irradiance = shGetIrradianceAt( worldNormal, lightProbe ); return irradiance; } vec3 getAmbientLightIrradiance( const in vec3 ambientLightColor ) { vec3 irradiance = ambientLightColor; #ifndef PHYSICALLY_CORRECT_LIGHTS irradiance *= PI; #endif return irradiance; } #if NUM_DIR_LIGHTS > 0 struct DirectionalLight { vec3 direction; vec3 color; }; uniform DirectionalLight directionalLights[ NUM_DIR_LIGHTS ]; void getDirectionalDirectLightIrradiance( const in DirectionalLight directionalLight, const in GeometricContext geometry, out IncidentLight directLight ) { directLight.color = directionalLight.color; directLight.direction = directionalLight.direction; directLight.visible = true; } #endif #if NUM_POINT_LIGHTS > 0 struct PointLight { vec3 position; vec3 color; float distance; float decay; }; uniform PointLight pointLights[ NUM_POINT_LIGHTS ]; void getPointDirectLightIrradiance( const in PointLight pointLight, const in GeometricContext geometry, out IncidentLight directLight ) { vec3 lVector = pointLight.position - geometry.position; directLight.direction = normalize( lVector ); float lightDistance = length( lVector ); directLight.color = pointLight.color; directLight.color *= punctualLightIntensityToIrradianceFactor( lightDistance, pointLight.distance, pointLight.decay ); directLight.visible = ( directLight.color != vec3( 0.0 ) ); } #endif #if NUM_SPOT_LIGHTS > 0 struct SpotLight { vec3 position; vec3 direction; vec3 color; float distance; float decay; float coneCos; float penumbraCos; }; uniform SpotLight spotLights[ NUM_SPOT_LIGHTS ]; void getSpotDirectLightIrradiance( const in SpotLight spotLight, const in GeometricContext geometry, out IncidentLight directLight ) { vec3 lVector = spotLight.position - geometry.position; directLight.direction = normalize( lVector ); float lightDistance = length( lVector ); float angleCos = dot( directLight.direction, spotLight.direction ); if ( angleCos > spotLight.coneCos ) { float spotEffect = smoothstep( spotLight.coneCos, spotLight.penumbraCos, angleCos ); directLight.color = spotLight.color; directLight.color *= spotEffect * punctualLightIntensityToIrradianceFactor( lightDistance, spotLight.distance, spotLight.decay ); directLight.visible = true; } else { directLight.color = vec3( 0.0 ); directLight.visible = false; } } #endif #if NUM_RECT_AREA_LIGHTS > 0 struct RectAreaLight { vec3 color; vec3 position; vec3 halfWidth; vec3 halfHeight; }; uniform sampler2D ltc_1; uniform sampler2D ltc_2; uniform RectAreaLight rectAreaLights[ NUM_RECT_AREA_LIGHTS ]; #endif #if NUM_HEMI_LIGHTS > 0 struct HemisphereLight { vec3 direction; vec3 skyColor; vec3 groundColor; }; uniform HemisphereLight hemisphereLights[ NUM_HEMI_LIGHTS ]; vec3 getHemisphereLightIrradiance( const in HemisphereLight hemiLight, const in GeometricContext geometry ) { float dotNL = dot( geometry.normal, hemiLight.direction ); float hemiDiffuseWeight = 0.5 * dotNL + 0.5; vec3 irradiance = mix( hemiLight.groundColor, hemiLight.skyColor, hemiDiffuseWeight ); #ifndef PHYSICALLY_CORRECT_LIGHTS irradiance *= PI; #endif return irradiance; } #endif`; var fP = `#if defined( USE_ENVMAP ) #ifdef ENVMAP_MODE_REFRACTION uniform float refractionRatio; #endif vec3 getLightProbeIndirectIrradiance( const in GeometricContext geometry, const in int maxMIPLevel ) { vec3 worldNormal = inverseTransformDirection( geometry.normal, viewMatrix ); #ifdef ENVMAP_TYPE_CUBE vec3 queryVec = vec3( flipEnvMap * worldNormal.x, worldNormal.yz ); #ifdef TEXTURE_LOD_EXT vec4 envMapColor = textureCubeLodEXT( envMap, queryVec, float( maxMIPLevel ) ); #else vec4 envMapColor = textureCube( envMap, queryVec, float( maxMIPLevel ) ); #endif envMapColor.rgb = envMapTexelToLinear( envMapColor ).rgb; #elif defined( ENVMAP_TYPE_CUBE_UV ) vec4 envMapColor = textureCubeUV( envMap, worldNormal, 1.0 ); #else vec4 envMapColor = vec4( 0.0 ); #endif return PI * envMapColor.rgb * envMapIntensity; } float getSpecularMIPLevel( const in float roughness, const in int maxMIPLevel ) { float maxMIPLevelScalar = float( maxMIPLevel ); float sigma = PI * roughness * roughness / ( 1.0 + roughness ); float desiredMIPLevel = maxMIPLevelScalar + log2( sigma ); return clamp( desiredMIPLevel, 0.0, maxMIPLevelScalar ); } vec3 getLightProbeIndirectRadiance( const in vec3 viewDir, const in vec3 normal, const in float roughness, const in int maxMIPLevel ) { #ifdef ENVMAP_MODE_REFLECTION vec3 reflectVec = reflect( -viewDir, normal ); reflectVec = normalize( mix( reflectVec, normal, roughness * roughness) ); #else vec3 reflectVec = refract( -viewDir, normal, refractionRatio ); #endif reflectVec = inverseTransformDirection( reflectVec, viewMatrix ); float specularMIPLevel = getSpecularMIPLevel( roughness, maxMIPLevel ); #ifdef ENVMAP_TYPE_CUBE vec3 queryReflectVec = vec3( flipEnvMap * reflectVec.x, reflectVec.yz ); #ifdef TEXTURE_LOD_EXT vec4 envMapColor = textureCubeLodEXT( envMap, queryReflectVec, specularMIPLevel ); #else vec4 envMapColor = textureCube( envMap, queryReflectVec, specularMIPLevel ); #endif envMapColor.rgb = envMapTexelToLinear( envMapColor ).rgb; #elif defined( ENVMAP_TYPE_CUBE_UV ) vec4 envMapColor = textureCubeUV( envMap, reflectVec, roughness ); #endif return envMapColor.rgb * envMapIntensity; } #endif`; var pP = `ToonMaterial material; material.diffuseColor = diffuseColor.rgb;`; var mP = `varying vec3 vViewPosition; #ifndef FLAT_SHADED varying vec3 vNormal; #endif struct ToonMaterial { vec3 diffuseColor; }; void RE_Direct_Toon( const in IncidentLight directLight, const in GeometricContext geometry, const in ToonMaterial material, inout ReflectedLight reflectedLight ) { vec3 irradiance = getGradientIrradiance( geometry.normal, directLight.direction ) * directLight.color; #ifndef PHYSICALLY_CORRECT_LIGHTS irradiance *= PI; #endif reflectedLight.directDiffuse += irradiance * BRDF_Diffuse_Lambert( material.diffuseColor ); } void RE_IndirectDiffuse_Toon( const in vec3 irradiance, const in GeometricContext geometry, const in ToonMaterial material, inout ReflectedLight reflectedLight ) { reflectedLight.indirectDiffuse += irradiance * BRDF_Diffuse_Lambert( material.diffuseColor ); } #define RE_Direct RE_Direct_Toon #define RE_IndirectDiffuse RE_IndirectDiffuse_Toon #define Material_LightProbeLOD( material ) (0)`; var gP = `BlinnPhongMaterial material; material.diffuseColor = diffuseColor.rgb; material.specularColor = specular; material.specularShininess = shininess; material.specularStrength = specularStrength;`; var vP = `varying vec3 vViewPosition; #ifndef FLAT_SHADED varying vec3 vNormal; #endif struct BlinnPhongMaterial { vec3 diffuseColor; vec3 specularColor; float specularShininess; float specularStrength; }; void RE_Direct_BlinnPhong( const in IncidentLight directLight, const in GeometricContext geometry, const in BlinnPhongMaterial material, inout ReflectedLight reflectedLight ) { float dotNL = saturate( dot( geometry.normal, directLight.direction ) ); vec3 irradiance = dotNL * directLight.color; #ifndef PHYSICALLY_CORRECT_LIGHTS irradiance *= PI; #endif reflectedLight.directDiffuse += irradiance * BRDF_Diffuse_Lambert( material.diffuseColor ); reflectedLight.directSpecular += irradiance * BRDF_Specular_BlinnPhong( directLight, geometry, material.specularColor, material.specularShininess ) * material.specularStrength; } void RE_IndirectDiffuse_BlinnPhong( const in vec3 irradiance, const in GeometricContext geometry, const in BlinnPhongMaterial material, inout ReflectedLight reflectedLight ) { reflectedLight.indirectDiffuse += irradiance * BRDF_Diffuse_Lambert( material.diffuseColor ); } #define RE_Direct RE_Direct_BlinnPhong #define RE_IndirectDiffuse RE_IndirectDiffuse_BlinnPhong #define Material_LightProbeLOD( material ) (0)`; var yP = `PhysicalMaterial material; material.diffuseColor = diffuseColor.rgb * ( 1.0 - metalnessFactor ); vec3 dxy = max( abs( dFdx( geometryNormal ) ), abs( dFdy( geometryNormal ) ) ); float geometryRoughness = max( max( dxy.x, dxy.y ), dxy.z ); material.specularRoughness = max( roughnessFactor, 0.0525 );material.specularRoughness += geometryRoughness; material.specularRoughness = min( material.specularRoughness, 1.0 ); #ifdef REFLECTIVITY material.specularColor = mix( vec3( MAXIMUM_SPECULAR_COEFFICIENT * pow2( reflectivity ) ), diffuseColor.rgb, metalnessFactor ); #else material.specularColor = mix( vec3( DEFAULT_SPECULAR_COEFFICIENT ), diffuseColor.rgb, metalnessFactor ); #endif #ifdef CLEARCOAT material.clearcoat = clearcoat; material.clearcoatRoughness = clearcoatRoughness; #ifdef USE_CLEARCOATMAP material.clearcoat *= texture2D( clearcoatMap, vUv ).x; #endif #ifdef USE_CLEARCOAT_ROUGHNESSMAP material.clearcoatRoughness *= texture2D( clearcoatRoughnessMap, vUv ).y; #endif material.clearcoat = saturate( material.clearcoat ); material.clearcoatRoughness = max( material.clearcoatRoughness, 0.0525 ); material.clearcoatRoughness += geometryRoughness; material.clearcoatRoughness = min( material.clearcoatRoughness, 1.0 ); #endif #ifdef USE_SHEEN material.sheenColor = sheen; #endif`; var bP = `struct PhysicalMaterial { vec3 diffuseColor; float specularRoughness; vec3 specularColor; #ifdef CLEARCOAT float clearcoat; float clearcoatRoughness; #endif #ifdef USE_SHEEN vec3 sheenColor; #endif }; #define MAXIMUM_SPECULAR_COEFFICIENT 0.16 #define DEFAULT_SPECULAR_COEFFICIENT 0.04 float clearcoatDHRApprox( const in float roughness, const in float dotNL ) { return DEFAULT_SPECULAR_COEFFICIENT + ( 1.0 - DEFAULT_SPECULAR_COEFFICIENT ) * ( pow( 1.0 - dotNL, 5.0 ) * pow( 1.0 - roughness, 2.0 ) ); } #if NUM_RECT_AREA_LIGHTS > 0 void RE_Direct_RectArea_Physical( const in RectAreaLight rectAreaLight, const in GeometricContext geometry, const in PhysicalMaterial material, inout ReflectedLight reflectedLight ) { vec3 normal = geometry.normal; vec3 viewDir = geometry.viewDir; vec3 position = geometry.position; vec3 lightPos = rectAreaLight.position; vec3 halfWidth = rectAreaLight.halfWidth; vec3 halfHeight = rectAreaLight.halfHeight; vec3 lightColor = rectAreaLight.color; float roughness = material.specularRoughness; vec3 rectCoords[ 4 ]; rectCoords[ 0 ] = lightPos + halfWidth - halfHeight; rectCoords[ 1 ] = lightPos - halfWidth - halfHeight; rectCoords[ 2 ] = lightPos - halfWidth + halfHeight; rectCoords[ 3 ] = lightPos + halfWidth + halfHeight; vec2 uv = LTC_Uv( normal, viewDir, roughness ); vec4 t1 = texture2D( ltc_1, uv ); vec4 t2 = texture2D( ltc_2, uv ); mat3 mInv = mat3( vec3( t1.x, 0, t1.y ), vec3( 0, 1, 0 ), vec3( t1.z, 0, t1.w ) ); vec3 fresnel = ( material.specularColor * t2.x + ( vec3( 1.0 ) - material.specularColor ) * t2.y ); reflectedLight.directSpecular += lightColor * fresnel * LTC_Evaluate( normal, viewDir, position, mInv, rectCoords ); reflectedLight.directDiffuse += lightColor * material.diffuseColor * LTC_Evaluate( normal, viewDir, position, mat3( 1.0 ), rectCoords ); } #endif void RE_Direct_Physical( const in IncidentLight directLight, const in GeometricContext geometry, const in PhysicalMaterial material, inout ReflectedLight reflectedLight ) { float dotNL = saturate( dot( geometry.normal, directLight.direction ) ); vec3 irradiance = dotNL * directLight.color; #ifndef PHYSICALLY_CORRECT_LIGHTS irradiance *= PI; #endif #ifdef CLEARCOAT float ccDotNL = saturate( dot( geometry.clearcoatNormal, directLight.direction ) ); vec3 ccIrradiance = ccDotNL * directLight.color; #ifndef PHYSICALLY_CORRECT_LIGHTS ccIrradiance *= PI; #endif float clearcoatDHR = material.clearcoat * clearcoatDHRApprox( material.clearcoatRoughness, ccDotNL ); reflectedLight.directSpecular += ccIrradiance * material.clearcoat * BRDF_Specular_GGX( directLight, geometry.viewDir, geometry.clearcoatNormal, vec3( DEFAULT_SPECULAR_COEFFICIENT ), material.clearcoatRoughness ); #else float clearcoatDHR = 0.0; #endif #ifdef USE_SHEEN reflectedLight.directSpecular += ( 1.0 - clearcoatDHR ) * irradiance * BRDF_Specular_Sheen( material.specularRoughness, directLight.direction, geometry, material.sheenColor ); #else reflectedLight.directSpecular += ( 1.0 - clearcoatDHR ) * irradiance * BRDF_Specular_GGX( directLight, geometry.viewDir, geometry.normal, material.specularColor, material.specularRoughness); #endif reflectedLight.directDiffuse += ( 1.0 - clearcoatDHR ) * irradiance * BRDF_Diffuse_Lambert( material.diffuseColor ); } void RE_IndirectDiffuse_Physical( const in vec3 irradiance, const in GeometricContext geometry, const in PhysicalMaterial material, inout ReflectedLight reflectedLight ) { reflectedLight.indirectDiffuse += irradiance * BRDF_Diffuse_Lambert( material.diffuseColor ); } void RE_IndirectSpecular_Physical( const in vec3 radiance, const in vec3 irradiance, const in vec3 clearcoatRadiance, const in GeometricContext geometry, const in PhysicalMaterial material, inout ReflectedLight reflectedLight) { #ifdef CLEARCOAT float ccDotNV = saturate( dot( geometry.clearcoatNormal, geometry.viewDir ) ); reflectedLight.indirectSpecular += clearcoatRadiance * material.clearcoat * BRDF_Specular_GGX_Environment( geometry.viewDir, geometry.clearcoatNormal, vec3( DEFAULT_SPECULAR_COEFFICIENT ), material.clearcoatRoughness ); float ccDotNL = ccDotNV; float clearcoatDHR = material.clearcoat * clearcoatDHRApprox( material.clearcoatRoughness, ccDotNL ); #else float clearcoatDHR = 0.0; #endif float clearcoatInv = 1.0 - clearcoatDHR; vec3 singleScattering = vec3( 0.0 ); vec3 multiScattering = vec3( 0.0 ); vec3 cosineWeightedIrradiance = irradiance * RECIPROCAL_PI; BRDF_Specular_Multiscattering_Environment( geometry, material.specularColor, material.specularRoughness, singleScattering, multiScattering ); vec3 diffuse = material.diffuseColor * ( 1.0 - ( singleScattering + multiScattering ) ); reflectedLight.indirectSpecular += clearcoatInv * radiance * singleScattering; reflectedLight.indirectSpecular += multiScattering * cosineWeightedIrradiance; reflectedLight.indirectDiffuse += diffuse * cosineWeightedIrradiance; } #define RE_Direct RE_Direct_Physical #define RE_Direct_RectArea RE_Direct_RectArea_Physical #define RE_IndirectDiffuse RE_IndirectDiffuse_Physical #define RE_IndirectSpecular RE_IndirectSpecular_Physical float computeSpecularOcclusion( const in float dotNV, const in float ambientOcclusion, const in float roughness ) { return saturate( pow( dotNV + ambientOcclusion, exp2( - 16.0 * roughness - 1.0 ) ) - 1.0 + ambientOcclusion ); }`; var xP = ` GeometricContext geometry; geometry.position = - vViewPosition; geometry.normal = normal; geometry.viewDir = ( isOrthographic ) ? vec3( 0, 0, 1 ) : normalize( vViewPosition ); #ifdef CLEARCOAT geometry.clearcoatNormal = clearcoatNormal; #endif IncidentLight directLight; #if ( NUM_POINT_LIGHTS > 0 ) && defined( RE_Direct ) PointLight pointLight; #if defined( USE_SHADOWMAP ) && NUM_POINT_LIGHT_SHADOWS > 0 PointLightShadow pointLightShadow; #endif #pragma unroll_loop_start for ( int i = 0; i < NUM_POINT_LIGHTS; i ++ ) { pointLight = pointLights[ i ]; getPointDirectLightIrradiance( pointLight, geometry, directLight ); #if defined( USE_SHADOWMAP ) && ( UNROLLED_LOOP_INDEX < NUM_POINT_LIGHT_SHADOWS ) pointLightShadow = pointLightShadows[ i ]; directLight.color *= all( bvec2( directLight.visible, receiveShadow ) ) ? getPointShadow( pointShadowMap[ i ], pointLightShadow.shadowMapSize, pointLightShadow.shadowBias, pointLightShadow.shadowRadius, vPointShadowCoord[ i ], pointLightShadow.shadowCameraNear, pointLightShadow.shadowCameraFar ) : 1.0; #endif RE_Direct( directLight, geometry, material, reflectedLight ); } #pragma unroll_loop_end #endif #if ( NUM_SPOT_LIGHTS > 0 ) && defined( RE_Direct ) SpotLight spotLight; #if defined( USE_SHADOWMAP ) && NUM_SPOT_LIGHT_SHADOWS > 0 SpotLightShadow spotLightShadow; #endif #pragma unroll_loop_start for ( int i = 0; i < NUM_SPOT_LIGHTS; i ++ ) { spotLight = spotLights[ i ]; getSpotDirectLightIrradiance( spotLight, geometry, directLight ); #if defined( USE_SHADOWMAP ) && ( UNROLLED_LOOP_INDEX < NUM_SPOT_LIGHT_SHADOWS ) spotLightShadow = spotLightShadows[ i ]; directLight.color *= all( bvec2( directLight.visible, receiveShadow ) ) ? getShadow( spotShadowMap[ i ], spotLightShadow.shadowMapSize, spotLightShadow.shadowBias, spotLightShadow.shadowRadius, vSpotShadowCoord[ i ] ) : 1.0; #endif RE_Direct( directLight, geometry, material, reflectedLight ); } #pragma unroll_loop_end #endif #if ( NUM_DIR_LIGHTS > 0 ) && defined( RE_Direct ) DirectionalLight directionalLight; #if defined( USE_SHADOWMAP ) && NUM_DIR_LIGHT_SHADOWS > 0 DirectionalLightShadow directionalLightShadow; #endif #pragma unroll_loop_start for ( int i = 0; i < NUM_DIR_LIGHTS; i ++ ) { directionalLight = directionalLights[ i ]; getDirectionalDirectLightIrradiance( directionalLight, geometry, directLight ); #if defined( USE_SHADOWMAP ) && ( UNROLLED_LOOP_INDEX < NUM_DIR_LIGHT_SHADOWS ) directionalLightShadow = directionalLightShadows[ i ]; directLight.color *= all( bvec2( directLight.visible, receiveShadow ) ) ? getShadow( directionalShadowMap[ i ], directionalLightShadow.shadowMapSize, directionalLightShadow.shadowBias, directionalLightShadow.shadowRadius, vDirectionalShadowCoord[ i ] ) : 1.0; #endif RE_Direct( directLight, geometry, material, reflectedLight ); } #pragma unroll_loop_end #endif #if ( NUM_RECT_AREA_LIGHTS > 0 ) && defined( RE_Direct_RectArea ) RectAreaLight rectAreaLight; #pragma unroll_loop_start for ( int i = 0; i < NUM_RECT_AREA_LIGHTS; i ++ ) { rectAreaLight = rectAreaLights[ i ]; RE_Direct_RectArea( rectAreaLight, geometry, material, reflectedLight ); } #pragma unroll_loop_end #endif #if defined( RE_IndirectDiffuse ) vec3 iblIrradiance = vec3( 0.0 ); vec3 irradiance = getAmbientLightIrradiance( ambientLightColor ); irradiance += getLightProbeIrradiance( lightProbe, geometry ); #if ( NUM_HEMI_LIGHTS > 0 ) #pragma unroll_loop_start for ( int i = 0; i < NUM_HEMI_LIGHTS; i ++ ) { irradiance += getHemisphereLightIrradiance( hemisphereLights[ i ], geometry ); } #pragma unroll_loop_end #endif #endif #if defined( RE_IndirectSpecular ) vec3 radiance = vec3( 0.0 ); vec3 clearcoatRadiance = vec3( 0.0 ); #endif`; var MP = `#if defined( RE_IndirectDiffuse ) #ifdef USE_LIGHTMAP vec4 lightMapTexel= texture2D( lightMap, vUv2 ); vec3 lightMapIrradiance = lightMapTexelToLinear( lightMapTexel ).rgb * lightMapIntensity; #ifndef PHYSICALLY_CORRECT_LIGHTS lightMapIrradiance *= PI; #endif irradiance += lightMapIrradiance; #endif #if defined( USE_ENVMAP ) && defined( STANDARD ) && defined( ENVMAP_TYPE_CUBE_UV ) iblIrradiance += getLightProbeIndirectIrradiance( geometry, maxMipLevel ); #endif #endif #if defined( USE_ENVMAP ) && defined( RE_IndirectSpecular ) radiance += getLightProbeIndirectRadiance( geometry.viewDir, geometry.normal, material.specularRoughness, maxMipLevel ); #ifdef CLEARCOAT clearcoatRadiance += getLightProbeIndirectRadiance( geometry.viewDir, geometry.clearcoatNormal, material.clearcoatRoughness, maxMipLevel ); #endif #endif`; var wP = `#if defined( RE_IndirectDiffuse ) RE_IndirectDiffuse( irradiance, geometry, material, reflectedLight ); #endif #if defined( RE_IndirectSpecular ) RE_IndirectSpecular( radiance, iblIrradiance, clearcoatRadiance, geometry, material, reflectedLight ); #endif`; var AP = `#if defined( USE_LOGDEPTHBUF ) && defined( USE_LOGDEPTHBUF_EXT ) gl_FragDepthEXT = vIsPerspective == 0.0 ? gl_FragCoord.z : log2( vFragDepth ) * logDepthBufFC * 0.5; #endif`; var SP = `#if defined( USE_LOGDEPTHBUF ) && defined( USE_LOGDEPTHBUF_EXT ) uniform float logDepthBufFC; varying float vFragDepth; varying float vIsPerspective; #endif`; var _P = `#ifdef USE_LOGDEPTHBUF #ifdef USE_LOGDEPTHBUF_EXT varying float vFragDepth; varying float vIsPerspective; #else uniform float logDepthBufFC; #endif #endif`; var TP = `#ifdef USE_LOGDEPTHBUF #ifdef USE_LOGDEPTHBUF_EXT vFragDepth = 1.0 + gl_Position.w; vIsPerspective = float( isPerspectiveMatrix( projectionMatrix ) ); #else if ( isPerspectiveMatrix( projectionMatrix ) ) { gl_Position.z = log2( max( EPSILON, gl_Position.w + 1.0 ) ) * logDepthBufFC - 1.0; gl_Position.z *= gl_Position.w; } #endif #endif`; var EP = `#ifdef USE_MAP vec4 texelColor = texture2D( map, vUv ); texelColor = mapTexelToLinear( texelColor ); diffuseColor *= texelColor; #endif`; var CP = `#ifdef USE_MAP uniform sampler2D map; #endif`; var LP = `#if defined( USE_MAP ) || defined( USE_ALPHAMAP ) vec2 uv = ( uvTransform * vec3( gl_PointCoord.x, 1.0 - gl_PointCoord.y, 1 ) ).xy; #endif #ifdef USE_MAP vec4 mapTexel = texture2D( map, uv ); diffuseColor *= mapTexelToLinear( mapTexel ); #endif #ifdef USE_ALPHAMAP diffuseColor.a *= texture2D( alphaMap, uv ).g; #endif`; var RP = `#if defined( USE_MAP ) || defined( USE_ALPHAMAP ) uniform mat3 uvTransform; #endif #ifdef USE_MAP uniform sampler2D map; #endif #ifdef USE_ALPHAMAP uniform sampler2D alphaMap; #endif`; var FP = `float metalnessFactor = metalness; #ifdef USE_METALNESSMAP vec4 texelMetalness = texture2D( metalnessMap, vUv ); metalnessFactor *= texelMetalness.b; #endif`; var PP = `#ifdef USE_METALNESSMAP uniform sampler2D metalnessMap; #endif`; var IP = `#ifdef USE_MORPHNORMALS objectNormal *= morphTargetBaseInfluence; objectNormal += morphNormal0 * morphTargetInfluences[ 0 ]; objectNormal += morphNormal1 * morphTargetInfluences[ 1 ]; objectNormal += morphNormal2 * morphTargetInfluences[ 2 ]; objectNormal += morphNormal3 * morphTargetInfluences[ 3 ]; #endif`; var OP = `#ifdef USE_MORPHTARGETS uniform float morphTargetBaseInfluence; #ifndef USE_MORPHNORMALS uniform float morphTargetInfluences[ 8 ]; #else uniform float morphTargetInfluences[ 4 ]; #endif #endif`; var DP = `#ifdef USE_MORPHTARGETS transformed *= morphTargetBaseInfluence; transformed += morphTarget0 * morphTargetInfluences[ 0 ]; transformed += morphTarget1 * morphTargetInfluences[ 1 ]; transformed += morphTarget2 * morphTargetInfluences[ 2 ]; transformed += morphTarget3 * morphTargetInfluences[ 3 ]; #ifndef USE_MORPHNORMALS transformed += morphTarget4 * morphTargetInfluences[ 4 ]; transformed += morphTarget5 * morphTargetInfluences[ 5 ]; transformed += morphTarget6 * morphTargetInfluences[ 6 ]; transformed += morphTarget7 * morphTargetInfluences[ 7 ]; #endif #endif`; var NP = `float faceDirection = gl_FrontFacing ? 1.0 : - 1.0; #ifdef FLAT_SHADED vec3 fdx = vec3( dFdx( vViewPosition.x ), dFdx( vViewPosition.y ), dFdx( vViewPosition.z ) ); vec3 fdy = vec3( dFdy( vViewPosition.x ), dFdy( vViewPosition.y ), dFdy( vViewPosition.z ) ); vec3 normal = normalize( cross( fdx, fdy ) ); #else vec3 normal = normalize( vNormal ); #ifdef DOUBLE_SIDED normal = normal * faceDirection; #endif #ifdef USE_TANGENT vec3 tangent = normalize( vTangent ); vec3 bitangent = normalize( vBitangent ); #ifdef DOUBLE_SIDED tangent = tangent * faceDirection; bitangent = bitangent * faceDirection; #endif #if defined( TANGENTSPACE_NORMALMAP ) || defined( USE_CLEARCOAT_NORMALMAP ) mat3 vTBN = mat3( tangent, bitangent, normal ); #endif #endif #endif vec3 geometryNormal = normal;`; var BP = `#ifdef OBJECTSPACE_NORMALMAP normal = texture2D( normalMap, vUv ).xyz * 2.0 - 1.0; #ifdef FLIP_SIDED normal = - normal; #endif #ifdef DOUBLE_SIDED normal = normal * faceDirection; #endif normal = normalize( normalMatrix * normal ); #elif defined( TANGENTSPACE_NORMALMAP ) vec3 mapN = texture2D( normalMap, vUv ).xyz * 2.0 - 1.0; mapN.xy *= normalScale; #ifdef USE_TANGENT normal = normalize( vTBN * mapN ); #else normal = perturbNormal2Arb( -vViewPosition, normal, mapN, faceDirection ); #endif #elif defined( USE_BUMPMAP ) normal = perturbNormalArb( -vViewPosition, normal, dHdxy_fwd(), faceDirection ); #endif`; var UP = `#ifdef USE_NORMALMAP uniform sampler2D normalMap; uniform vec2 normalScale; #endif #ifdef OBJECTSPACE_NORMALMAP uniform mat3 normalMatrix; #endif #if ! defined ( USE_TANGENT ) && ( defined ( TANGENTSPACE_NORMALMAP ) || defined ( USE_CLEARCOAT_NORMALMAP ) ) vec3 perturbNormal2Arb( vec3 eye_pos, vec3 surf_norm, vec3 mapN, float faceDirection ) { vec3 q0 = vec3( dFdx( eye_pos.x ), dFdx( eye_pos.y ), dFdx( eye_pos.z ) ); vec3 q1 = vec3( dFdy( eye_pos.x ), dFdy( eye_pos.y ), dFdy( eye_pos.z ) ); vec2 st0 = dFdx( vUv.st ); vec2 st1 = dFdy( vUv.st ); vec3 N = surf_norm; vec3 q1perp = cross( q1, N ); vec3 q0perp = cross( N, q0 ); vec3 T = q1perp * st0.x + q0perp * st1.x; vec3 B = q1perp * st0.y + q0perp * st1.y; float det = max( dot( T, T ), dot( B, B ) ); float scale = ( det == 0.0 ) ? 0.0 : faceDirection * inversesqrt( det ); return normalize( T * ( mapN.x * scale ) + B * ( mapN.y * scale ) + N * mapN.z ); } #endif`; var zP = `#ifdef CLEARCOAT vec3 clearcoatNormal = geometryNormal; #endif`; var VP = `#ifdef USE_CLEARCOAT_NORMALMAP vec3 clearcoatMapN = texture2D( clearcoatNormalMap, vUv ).xyz * 2.0 - 1.0; clearcoatMapN.xy *= clearcoatNormalScale; #ifdef USE_TANGENT clearcoatNormal = normalize( vTBN * clearcoatMapN ); #else clearcoatNormal = perturbNormal2Arb( - vViewPosition, clearcoatNormal, clearcoatMapN, faceDirection ); #endif #endif`; var kP = `#ifdef USE_CLEARCOATMAP uniform sampler2D clearcoatMap; #endif #ifdef USE_CLEARCOAT_ROUGHNESSMAP uniform sampler2D clearcoatRoughnessMap; #endif #ifdef USE_CLEARCOAT_NORMALMAP uniform sampler2D clearcoatNormalMap; uniform vec2 clearcoatNormalScale; #endif`; var GP = `vec3 packNormalToRGB( const in vec3 normal ) { return normalize( normal ) * 0.5 + 0.5; } vec3 unpackRGBToNormal( const in vec3 rgb ) { return 2.0 * rgb.xyz - 1.0; } const float PackUpscale = 256. / 255.;const float UnpackDownscale = 255. / 256.; const vec3 PackFactors = vec3( 256. * 256. * 256., 256. * 256., 256. ); const vec4 UnpackFactors = UnpackDownscale / vec4( PackFactors, 1. ); const float ShiftRight8 = 1. / 256.; vec4 packDepthToRGBA( const in float v ) { vec4 r = vec4( fract( v * PackFactors ), v ); r.yzw -= r.xyz * ShiftRight8; return r * PackUpscale; } float unpackRGBAToDepth( const in vec4 v ) { return dot( v, UnpackFactors ); } vec4 pack2HalfToRGBA( vec2 v ) { vec4 r = vec4( v.x, fract( v.x * 255.0 ), v.y, fract( v.y * 255.0 )); return vec4( r.x - r.y / 255.0, r.y, r.z - r.w / 255.0, r.w); } vec2 unpackRGBATo2Half( vec4 v ) { return vec2( v.x + ( v.y / 255.0 ), v.z + ( v.w / 255.0 ) ); } float viewZToOrthographicDepth( const in float viewZ, const in float near, const in float far ) { return ( viewZ + near ) / ( near - far ); } float orthographicDepthToViewZ( const in float linearClipZ, const in float near, const in float far ) { return linearClipZ * ( near - far ) - near; } float viewZToPerspectiveDepth( const in float viewZ, const in float near, const in float far ) { return (( near + viewZ ) * far ) / (( far - near ) * viewZ ); } float perspectiveDepthToViewZ( const in float invClipZ, const in float near, const in float far ) { return ( near * far ) / ( ( far - near ) * invClipZ - far ); }`; var HP = `#ifdef PREMULTIPLIED_ALPHA gl_FragColor.rgb *= gl_FragColor.a; #endif`; var WP = `vec4 mvPosition = vec4( transformed, 1.0 ); #ifdef USE_INSTANCING mvPosition = instanceMatrix * mvPosition; #endif mvPosition = modelViewMatrix * mvPosition; gl_Position = projectionMatrix * mvPosition;`; var jP = `#ifdef DITHERING gl_FragColor.rgb = dithering( gl_FragColor.rgb ); #endif`; var $P = `#ifdef DITHERING vec3 dithering( vec3 color ) { float grid_position = rand( gl_FragCoord.xy ); vec3 dither_shift_RGB = vec3( 0.25 / 255.0, -0.25 / 255.0, 0.25 / 255.0 ); dither_shift_RGB = mix( 2.0 * dither_shift_RGB, -2.0 * dither_shift_RGB, grid_position ); return color + dither_shift_RGB; } #endif`; var ZP = `float roughnessFactor = roughness; #ifdef USE_ROUGHNESSMAP vec4 texelRoughness = texture2D( roughnessMap, vUv ); roughnessFactor *= texelRoughness.g; #endif`; var XP = `#ifdef USE_ROUGHNESSMAP uniform sampler2D roughnessMap; #endif`; var YP = `#ifdef USE_SHADOWMAP #if NUM_DIR_LIGHT_SHADOWS > 0 uniform sampler2D directionalShadowMap[ NUM_DIR_LIGHT_SHADOWS ]; varying vec4 vDirectionalShadowCoord[ NUM_DIR_LIGHT_SHADOWS ]; struct DirectionalLightShadow { float shadowBias; float shadowNormalBias; float shadowRadius; vec2 shadowMapSize; }; uniform DirectionalLightShadow directionalLightShadows[ NUM_DIR_LIGHT_SHADOWS ]; #endif #if NUM_SPOT_LIGHT_SHADOWS > 0 uniform sampler2D spotShadowMap[ NUM_SPOT_LIGHT_SHADOWS ]; varying vec4 vSpotShadowCoord[ NUM_SPOT_LIGHT_SHADOWS ]; struct SpotLightShadow { float shadowBias; float shadowNormalBias; float shadowRadius; vec2 shadowMapSize; }; uniform SpotLightShadow spotLightShadows[ NUM_SPOT_LIGHT_SHADOWS ]; #endif #if NUM_POINT_LIGHT_SHADOWS > 0 uniform sampler2D pointShadowMap[ NUM_POINT_LIGHT_SHADOWS ]; varying vec4 vPointShadowCoord[ NUM_POINT_LIGHT_SHADOWS ]; struct PointLightShadow { float shadowBias; float shadowNormalBias; float shadowRadius; vec2 shadowMapSize; float shadowCameraNear; float shadowCameraFar; }; uniform PointLightShadow pointLightShadows[ NUM_POINT_LIGHT_SHADOWS ]; #endif float texture2DCompare( sampler2D depths, vec2 uv, float compare ) { return step( compare, unpackRGBAToDepth( texture2D( depths, uv ) ) ); } vec2 texture2DDistribution( sampler2D shadow, vec2 uv ) { return unpackRGBATo2Half( texture2D( shadow, uv ) ); } float VSMShadow (sampler2D shadow, vec2 uv, float compare ){ float occlusion = 1.0; vec2 distribution = texture2DDistribution( shadow, uv ); float hard_shadow = step( compare , distribution.x ); if (hard_shadow != 1.0 ) { float distance = compare - distribution.x ; float variance = max( 0.00000, distribution.y * distribution.y ); float softness_probability = variance / (variance + distance * distance ); softness_probability = clamp( ( softness_probability - 0.3 ) / ( 0.95 - 0.3 ), 0.0, 1.0 ); occlusion = clamp( max( hard_shadow, softness_probability ), 0.0, 1.0 ); } return occlusion; } float getShadow( sampler2D shadowMap, vec2 shadowMapSize, float shadowBias, float shadowRadius, vec4 shadowCoord ) { float shadow = 1.0; shadowCoord.xyz /= shadowCoord.w; shadowCoord.z += shadowBias; bvec4 inFrustumVec = bvec4 ( shadowCoord.x >= 0.0, shadowCoord.x <= 1.0, shadowCoord.y >= 0.0, shadowCoord.y <= 1.0 ); bool inFrustum = all( inFrustumVec ); bvec2 frustumTestVec = bvec2( inFrustum, shadowCoord.z <= 1.0 ); bool frustumTest = all( frustumTestVec ); if ( frustumTest ) { #if defined( SHADOWMAP_TYPE_PCF ) vec2 texelSize = vec2( 1.0 ) / shadowMapSize; float dx0 = - texelSize.x * shadowRadius; float dy0 = - texelSize.y * shadowRadius; float dx1 = + texelSize.x * shadowRadius; float dy1 = + texelSize.y * shadowRadius; float dx2 = dx0 / 2.0; float dy2 = dy0 / 2.0; float dx3 = dx1 / 2.0; float dy3 = dy1 / 2.0; shadow = ( texture2DCompare( shadowMap, shadowCoord.xy + vec2( dx0, dy0 ), shadowCoord.z ) + texture2DCompare( shadowMap, shadowCoord.xy + vec2( 0.0, dy0 ), shadowCoord.z ) + texture2DCompare( shadowMap, shadowCoord.xy + vec2( dx1, dy0 ), shadowCoord.z ) + texture2DCompare( shadowMap, shadowCoord.xy + vec2( dx2, dy2 ), shadowCoord.z ) + texture2DCompare( shadowMap, shadowCoord.xy + vec2( 0.0, dy2 ), shadowCoord.z ) + texture2DCompare( shadowMap, shadowCoord.xy + vec2( dx3, dy2 ), shadowCoord.z ) + texture2DCompare( shadowMap, shadowCoord.xy + vec2( dx0, 0.0 ), shadowCoord.z ) + texture2DCompare( shadowMap, shadowCoord.xy + vec2( dx2, 0.0 ), shadowCoord.z ) + texture2DCompare( shadowMap, shadowCoord.xy, shadowCoord.z ) + texture2DCompare( shadowMap, shadowCoord.xy + vec2( dx3, 0.0 ), shadowCoord.z ) + texture2DCompare( shadowMap, shadowCoord.xy + vec2( dx1, 0.0 ), shadowCoord.z ) + texture2DCompare( shadowMap, shadowCoord.xy + vec2( dx2, dy3 ), shadowCoord.z ) + texture2DCompare( shadowMap, shadowCoord.xy + vec2( 0.0, dy3 ), shadowCoord.z ) + texture2DCompare( shadowMap, shadowCoord.xy + vec2( dx3, dy3 ), shadowCoord.z ) + texture2DCompare( shadowMap, shadowCoord.xy + vec2( dx0, dy1 ), shadowCoord.z ) + texture2DCompare( shadowMap, shadowCoord.xy + vec2( 0.0, dy1 ), shadowCoord.z ) + texture2DCompare( shadowMap, shadowCoord.xy + vec2( dx1, dy1 ), shadowCoord.z ) ) * ( 1.0 / 17.0 ); #elif defined( SHADOWMAP_TYPE_PCF_SOFT ) vec2 texelSize = vec2( 1.0 ) / shadowMapSize; float dx = texelSize.x; float dy = texelSize.y; vec2 uv = shadowCoord.xy; vec2 f = fract( uv * shadowMapSize + 0.5 ); uv -= f * texelSize; shadow = ( texture2DCompare( shadowMap, uv, shadowCoord.z ) + texture2DCompare( shadowMap, uv + vec2( dx, 0.0 ), shadowCoord.z ) + texture2DCompare( shadowMap, uv + vec2( 0.0, dy ), shadowCoord.z ) + texture2DCompare( shadowMap, uv + texelSize, shadowCoord.z ) + mix( texture2DCompare( shadowMap, uv + vec2( -dx, 0.0 ), shadowCoord.z ), texture2DCompare( shadowMap, uv + vec2( 2.0 * dx, 0.0 ), shadowCoord.z ), f.x ) + mix( texture2DCompare( shadowMap, uv + vec2( -dx, dy ), shadowCoord.z ), texture2DCompare( shadowMap, uv + vec2( 2.0 * dx, dy ), shadowCoord.z ), f.x ) + mix( texture2DCompare( shadowMap, uv + vec2( 0.0, -dy ), shadowCoord.z ), texture2DCompare( shadowMap, uv + vec2( 0.0, 2.0 * dy ), shadowCoord.z ), f.y ) + mix( texture2DCompare( shadowMap, uv + vec2( dx, -dy ), shadowCoord.z ), texture2DCompare( shadowMap, uv + vec2( dx, 2.0 * dy ), shadowCoord.z ), f.y ) + mix( mix( texture2DCompare( shadowMap, uv + vec2( -dx, -dy ), shadowCoord.z ), texture2DCompare( shadowMap, uv + vec2( 2.0 * dx, -dy ), shadowCoord.z ), f.x ), mix( texture2DCompare( shadowMap, uv + vec2( -dx, 2.0 * dy ), shadowCoord.z ), texture2DCompare( shadowMap, uv + vec2( 2.0 * dx, 2.0 * dy ), shadowCoord.z ), f.x ), f.y ) ) * ( 1.0 / 9.0 ); #elif defined( SHADOWMAP_TYPE_VSM ) shadow = VSMShadow( shadowMap, shadowCoord.xy, shadowCoord.z ); #else shadow = texture2DCompare( shadowMap, shadowCoord.xy, shadowCoord.z ); #endif } return shadow; } vec2 cubeToUV( vec3 v, float texelSizeY ) { vec3 absV = abs( v ); float scaleToCube = 1.0 / max( absV.x, max( absV.y, absV.z ) ); absV *= scaleToCube; v *= scaleToCube * ( 1.0 - 2.0 * texelSizeY ); vec2 planar = v.xy; float almostATexel = 1.5 * texelSizeY; float almostOne = 1.0 - almostATexel; if ( absV.z >= almostOne ) { if ( v.z > 0.0 ) planar.x = 4.0 - v.x; } else if ( absV.x >= almostOne ) { float signX = sign( v.x ); planar.x = v.z * signX + 2.0 * signX; } else if ( absV.y >= almostOne ) { float signY = sign( v.y ); planar.x = v.x + 2.0 * signY + 2.0; planar.y = v.z * signY - 2.0; } return vec2( 0.125, 0.25 ) * planar + vec2( 0.375, 0.75 ); } float getPointShadow( sampler2D shadowMap, vec2 shadowMapSize, float shadowBias, float shadowRadius, vec4 shadowCoord, float shadowCameraNear, float shadowCameraFar ) { vec2 texelSize = vec2( 1.0 ) / ( shadowMapSize * vec2( 4.0, 2.0 ) ); vec3 lightToPosition = shadowCoord.xyz; float dp = ( length( lightToPosition ) - shadowCameraNear ) / ( shadowCameraFar - shadowCameraNear ); dp += shadowBias; vec3 bd3D = normalize( lightToPosition ); #if defined( SHADOWMAP_TYPE_PCF ) || defined( SHADOWMAP_TYPE_PCF_SOFT ) || defined( SHADOWMAP_TYPE_VSM ) vec2 offset = vec2( - 1, 1 ) * shadowRadius * texelSize.y; return ( texture2DCompare( shadowMap, cubeToUV( bd3D + offset.xyy, texelSize.y ), dp ) + texture2DCompare( shadowMap, cubeToUV( bd3D + offset.yyy, texelSize.y ), dp ) + texture2DCompare( shadowMap, cubeToUV( bd3D + offset.xyx, texelSize.y ), dp ) + texture2DCompare( shadowMap, cubeToUV( bd3D + offset.yyx, texelSize.y ), dp ) + texture2DCompare( shadowMap, cubeToUV( bd3D, texelSize.y ), dp ) + texture2DCompare( shadowMap, cubeToUV( bd3D + offset.xxy, texelSize.y ), dp ) + texture2DCompare( shadowMap, cubeToUV( bd3D + offset.yxy, texelSize.y ), dp ) + texture2DCompare( shadowMap, cubeToUV( bd3D + offset.xxx, texelSize.y ), dp ) + texture2DCompare( shadowMap, cubeToUV( bd3D + offset.yxx, texelSize.y ), dp ) ) * ( 1.0 / 9.0 ); #else return texture2DCompare( shadowMap, cubeToUV( bd3D, texelSize.y ), dp ); #endif } #endif`; var JP = `#ifdef USE_SHADOWMAP #if NUM_DIR_LIGHT_SHADOWS > 0 uniform mat4 directionalShadowMatrix[ NUM_DIR_LIGHT_SHADOWS ]; varying vec4 vDirectionalShadowCoord[ NUM_DIR_LIGHT_SHADOWS ]; struct DirectionalLightShadow { float shadowBias; float shadowNormalBias; float shadowRadius; vec2 shadowMapSize; }; uniform DirectionalLightShadow directionalLightShadows[ NUM_DIR_LIGHT_SHADOWS ]; #endif #if NUM_SPOT_LIGHT_SHADOWS > 0 uniform mat4 spotShadowMatrix[ NUM_SPOT_LIGHT_SHADOWS ]; varying vec4 vSpotShadowCoord[ NUM_SPOT_LIGHT_SHADOWS ]; struct SpotLightShadow { float shadowBias; float shadowNormalBias; float shadowRadius; vec2 shadowMapSize; }; uniform SpotLightShadow spotLightShadows[ NUM_SPOT_LIGHT_SHADOWS ]; #endif #if NUM_POINT_LIGHT_SHADOWS > 0 uniform mat4 pointShadowMatrix[ NUM_POINT_LIGHT_SHADOWS ]; varying vec4 vPointShadowCoord[ NUM_POINT_LIGHT_SHADOWS ]; struct PointLightShadow { float shadowBias; float shadowNormalBias; float shadowRadius; vec2 shadowMapSize; float shadowCameraNear; float shadowCameraFar; }; uniform PointLightShadow pointLightShadows[ NUM_POINT_LIGHT_SHADOWS ]; #endif #endif`; var KP = `#ifdef USE_SHADOWMAP #if NUM_DIR_LIGHT_SHADOWS > 0 || NUM_SPOT_LIGHT_SHADOWS > 0 || NUM_POINT_LIGHT_SHADOWS > 0 vec3 shadowWorldNormal = inverseTransformDirection( transformedNormal, viewMatrix ); vec4 shadowWorldPosition; #endif #if NUM_DIR_LIGHT_SHADOWS > 0 #pragma unroll_loop_start for ( int i = 0; i < NUM_DIR_LIGHT_SHADOWS; i ++ ) { shadowWorldPosition = worldPosition + vec4( shadowWorldNormal * directionalLightShadows[ i ].shadowNormalBias, 0 ); vDirectionalShadowCoord[ i ] = directionalShadowMatrix[ i ] * shadowWorldPosition; } #pragma unroll_loop_end #endif #if NUM_SPOT_LIGHT_SHADOWS > 0 #pragma unroll_loop_start for ( int i = 0; i < NUM_SPOT_LIGHT_SHADOWS; i ++ ) { shadowWorldPosition = worldPosition + vec4( shadowWorldNormal * spotLightShadows[ i ].shadowNormalBias, 0 ); vSpotShadowCoord[ i ] = spotShadowMatrix[ i ] * shadowWorldPosition; } #pragma unroll_loop_end #endif #if NUM_POINT_LIGHT_SHADOWS > 0 #pragma unroll_loop_start for ( int i = 0; i < NUM_POINT_LIGHT_SHADOWS; i ++ ) { shadowWorldPosition = worldPosition + vec4( shadowWorldNormal * pointLightShadows[ i ].shadowNormalBias, 0 ); vPointShadowCoord[ i ] = pointShadowMatrix[ i ] * shadowWorldPosition; } #pragma unroll_loop_end #endif #endif`; var qP = `float getShadowMask() { float shadow = 1.0; #ifdef USE_SHADOWMAP #if NUM_DIR_LIGHT_SHADOWS > 0 DirectionalLightShadow directionalLight; #pragma unroll_loop_start for ( int i = 0; i < NUM_DIR_LIGHT_SHADOWS; i ++ ) { directionalLight = directionalLightShadows[ i ]; shadow *= receiveShadow ? getShadow( directionalShadowMap[ i ], directionalLight.shadowMapSize, directionalLight.shadowBias, directionalLight.shadowRadius, vDirectionalShadowCoord[ i ] ) : 1.0; } #pragma unroll_loop_end #endif #if NUM_SPOT_LIGHT_SHADOWS > 0 SpotLightShadow spotLight; #pragma unroll_loop_start for ( int i = 0; i < NUM_SPOT_LIGHT_SHADOWS; i ++ ) { spotLight = spotLightShadows[ i ]; shadow *= receiveShadow ? getShadow( spotShadowMap[ i ], spotLight.shadowMapSize, spotLight.shadowBias, spotLight.shadowRadius, vSpotShadowCoord[ i ] ) : 1.0; } #pragma unroll_loop_end #endif #if NUM_POINT_LIGHT_SHADOWS > 0 PointLightShadow pointLight; #pragma unroll_loop_start for ( int i = 0; i < NUM_POINT_LIGHT_SHADOWS; i ++ ) { pointLight = pointLightShadows[ i ]; shadow *= receiveShadow ? getPointShadow( pointShadowMap[ i ], pointLight.shadowMapSize, pointLight.shadowBias, pointLight.shadowRadius, vPointShadowCoord[ i ], pointLight.shadowCameraNear, pointLight.shadowCameraFar ) : 1.0; } #pragma unroll_loop_end #endif #endif return shadow; }`; var QP = `#ifdef USE_SKINNING mat4 boneMatX = getBoneMatrix( skinIndex.x ); mat4 boneMatY = getBoneMatrix( skinIndex.y ); mat4 boneMatZ = getBoneMatrix( skinIndex.z ); mat4 boneMatW = getBoneMatrix( skinIndex.w ); #endif`; var eI = `#ifdef USE_SKINNING uniform mat4 bindMatrix; uniform mat4 bindMatrixInverse; #ifdef BONE_TEXTURE uniform highp sampler2D boneTexture; uniform int boneTextureSize; mat4 getBoneMatrix( const in float i ) { float j = i * 4.0; float x = mod( j, float( boneTextureSize ) ); float y = floor( j / float( boneTextureSize ) ); float dx = 1.0 / float( boneTextureSize ); float dy = 1.0 / float( boneTextureSize ); y = dy * ( y + 0.5 ); vec4 v1 = texture2D( boneTexture, vec2( dx * ( x + 0.5 ), y ) ); vec4 v2 = texture2D( boneTexture, vec2( dx * ( x + 1.5 ), y ) ); vec4 v3 = texture2D( boneTexture, vec2( dx * ( x + 2.5 ), y ) ); vec4 v4 = texture2D( boneTexture, vec2( dx * ( x + 3.5 ), y ) ); mat4 bone = mat4( v1, v2, v3, v4 ); return bone; } #else uniform mat4 boneMatrices[ MAX_BONES ]; mat4 getBoneMatrix( const in float i ) { mat4 bone = boneMatrices[ int(i) ]; return bone; } #endif #endif`; var tI = `#ifdef USE_SKINNING vec4 skinVertex = bindMatrix * vec4( transformed, 1.0 ); vec4 skinned = vec4( 0.0 ); skinned += boneMatX * skinVertex * skinWeight.x; skinned += boneMatY * skinVertex * skinWeight.y; skinned += boneMatZ * skinVertex * skinWeight.z; skinned += boneMatW * skinVertex * skinWeight.w; transformed = ( bindMatrixInverse * skinned ).xyz; #endif`; var nI = `#ifdef USE_SKINNING mat4 skinMatrix = mat4( 0.0 ); skinMatrix += skinWeight.x * boneMatX; skinMatrix += skinWeight.y * boneMatY; skinMatrix += skinWeight.z * boneMatZ; skinMatrix += skinWeight.w * boneMatW; skinMatrix = bindMatrixInverse * skinMatrix * bindMatrix; objectNormal = vec4( skinMatrix * vec4( objectNormal, 0.0 ) ).xyz; #ifdef USE_TANGENT objectTangent = vec4( skinMatrix * vec4( objectTangent, 0.0 ) ).xyz; #endif #endif`; var iI = `float specularStrength; #ifdef USE_SPECULARMAP vec4 texelSpecular = texture2D( specularMap, vUv ); specularStrength = texelSpecular.r; #else specularStrength = 1.0; #endif`; var rI = `#ifdef USE_SPECULARMAP uniform sampler2D specularMap; #endif`; var sI = `#if defined( TONE_MAPPING ) gl_FragColor.rgb = toneMapping( gl_FragColor.rgb ); #endif`; var oI = `#ifndef saturate #define saturate(a) clamp( a, 0.0, 1.0 ) #endif uniform float toneMappingExposure; vec3 LinearToneMapping( vec3 color ) { return toneMappingExposure * color; } vec3 ReinhardToneMapping( vec3 color ) { color *= toneMappingExposure; return saturate( color / ( vec3( 1.0 ) + color ) ); } vec3 OptimizedCineonToneMapping( vec3 color ) { color *= toneMappingExposure; color = max( vec3( 0.0 ), color - 0.004 ); return pow( ( color * ( 6.2 * color + 0.5 ) ) / ( color * ( 6.2 * color + 1.7 ) + 0.06 ), vec3( 2.2 ) ); } vec3 RRTAndODTFit( vec3 v ) { vec3 a = v * ( v + 0.0245786 ) - 0.000090537; vec3 b = v * ( 0.983729 * v + 0.4329510 ) + 0.238081; return a / b; } vec3 ACESFilmicToneMapping( vec3 color ) { const mat3 ACESInputMat = mat3( vec3( 0.59719, 0.07600, 0.02840 ), vec3( 0.35458, 0.90834, 0.13383 ), vec3( 0.04823, 0.01566, 0.83777 ) ); const mat3 ACESOutputMat = mat3( vec3( 1.60475, -0.10208, -0.00327 ), vec3( -0.53108, 1.10813, -0.07276 ), vec3( -0.07367, -0.00605, 1.07602 ) ); color *= toneMappingExposure / 0.6; color = ACESInputMat * color; color = RRTAndODTFit( color ); color = ACESOutputMat * color; return saturate( color ); } vec3 CustomToneMapping( vec3 color ) { return color; }`; var aI = `#ifdef USE_TRANSMISSION float transmissionFactor = transmission; float thicknessFactor = thickness; #ifdef USE_TRANSMISSIONMAP transmissionFactor *= texture2D( transmissionMap, vUv ).r; #endif #ifdef USE_THICKNESSNMAP thicknessFactor *= texture2D( thicknessMap, vUv ).g; #endif vec3 pos = vWorldPosition.xyz / vWorldPosition.w; vec3 v = normalize( cameraPosition - pos ); float ior = ( 1.0 + 0.4 * reflectivity ) / ( 1.0 - 0.4 * reflectivity ); vec3 transmission = transmissionFactor * getIBLVolumeRefraction( normal, v, roughnessFactor, material.diffuseColor, totalSpecular, pos, modelMatrix, viewMatrix, projectionMatrix, ior, thicknessFactor, attenuationColor, attenuationDistance ); totalDiffuse = mix( totalDiffuse, transmission, transmissionFactor ); #endif`; var lI = `#ifdef USE_TRANSMISSION #ifdef USE_TRANSMISSIONMAP uniform sampler2D transmissionMap; #endif #ifdef USE_THICKNESSMAP uniform sampler2D thicknessMap; #endif uniform vec2 transmissionSamplerSize; uniform sampler2D transmissionSamplerMap; uniform mat4 modelMatrix; uniform mat4 projectionMatrix; varying vec4 vWorldPosition; vec3 getVolumeTransmissionRay(vec3 n, vec3 v, float thickness, float ior, mat4 modelMatrix) { vec3 refractionVector = refract(-v, normalize(n), 1.0 / ior); vec3 modelScale; modelScale.x = length(vec3(modelMatrix[0].xyz)); modelScale.y = length(vec3(modelMatrix[1].xyz)); modelScale.z = length(vec3(modelMatrix[2].xyz)); return normalize(refractionVector) * thickness * modelScale; } float applyIorToRoughness(float roughness, float ior) { return roughness * clamp(ior * 2.0 - 2.0, 0.0, 1.0); } vec3 getTransmissionSample(vec2 fragCoord, float roughness, float ior) { float framebufferLod = log2(transmissionSamplerSize.x) * applyIorToRoughness(roughness, ior); return texture2DLodEXT(transmissionSamplerMap, fragCoord.xy, framebufferLod).rgb; } vec3 applyVolumeAttenuation(vec3 radiance, float transmissionDistance, vec3 attenuationColor, float attenuationDistance) { if (attenuationDistance == 0.0) { return radiance; } else { vec3 attenuationCoefficient = -log(attenuationColor) / attenuationDistance; vec3 transmittance = exp(-attenuationCoefficient * transmissionDistance); return transmittance * radiance; } } vec3 getIBLVolumeRefraction(vec3 n, vec3 v, float perceptualRoughness, vec3 baseColor, vec3 specularColor, vec3 position, mat4 modelMatrix, mat4 viewMatrix, mat4 projMatrix, float ior, float thickness, vec3 attenuationColor, float attenuationDistance) { vec3 transmissionRay = getVolumeTransmissionRay(n, v, thickness, ior, modelMatrix); vec3 refractedRayExit = position + transmissionRay; vec4 ndcPos = projMatrix * viewMatrix * vec4(refractedRayExit, 1.0); vec2 refractionCoords = ndcPos.xy / ndcPos.w; refractionCoords += 1.0; refractionCoords /= 2.0; vec3 transmittedLight = getTransmissionSample(refractionCoords, perceptualRoughness, ior); vec3 attenuatedColor = applyVolumeAttenuation(transmittedLight, length(transmissionRay), attenuationColor, attenuationDistance); return (1.0 - specularColor) * attenuatedColor * baseColor; } #endif`; var cI = `#if ( defined( USE_UV ) && ! defined( UVS_VERTEX_ONLY ) ) varying vec2 vUv; #endif`; var uI = `#ifdef USE_UV #ifdef UVS_VERTEX_ONLY vec2 vUv; #else varying vec2 vUv; #endif uniform mat3 uvTransform; #endif`; var hI = `#ifdef USE_UV vUv = ( uvTransform * vec3( uv, 1 ) ).xy; #endif`; var dI = `#if defined( USE_LIGHTMAP ) || defined( USE_AOMAP ) varying vec2 vUv2; #endif`; var fI = `#if defined( USE_LIGHTMAP ) || defined( USE_AOMAP ) attribute vec2 uv2; varying vec2 vUv2; uniform mat3 uv2Transform; #endif`; var pI = `#if defined( USE_LIGHTMAP ) || defined( USE_AOMAP ) vUv2 = ( uv2Transform * vec3( uv2, 1 ) ).xy; #endif`; var mI = `#if defined( USE_ENVMAP ) || defined( DISTANCE ) || defined ( USE_SHADOWMAP ) || defined ( USE_TRANSMISSION ) vec4 worldPosition = vec4( transformed, 1.0 ); #ifdef USE_INSTANCING worldPosition = instanceMatrix * worldPosition; #endif worldPosition = modelMatrix * worldPosition; #endif`; var gI = `uniform sampler2D t2D; varying vec2 vUv; void main() { vec4 texColor = texture2D( t2D, vUv ); gl_FragColor = mapTexelToLinear( texColor ); #include #include }`; var vI = `varying vec2 vUv; uniform mat3 uvTransform; void main() { vUv = ( uvTransform * vec3( uv, 1 ) ).xy; gl_Position = vec4( position.xy, 1.0, 1.0 ); }`; var yI = `#include uniform float opacity; varying vec3 vWorldDirection; #include void main() { vec3 vReflect = vWorldDirection; #include gl_FragColor = envColor; gl_FragColor.a *= opacity; #include #include }`; var bI = `varying vec3 vWorldDirection; #include void main() { vWorldDirection = transformDirection( position, modelMatrix ); #include #include gl_Position.z = gl_Position.w; }`; var xI = `#if DEPTH_PACKING == 3200 uniform float opacity; #endif #include #include #include #include #include #include #include varying vec2 vHighPrecisionZW; void main() { #include vec4 diffuseColor = vec4( 1.0 ); #if DEPTH_PACKING == 3200 diffuseColor.a = opacity; #endif #include #include #include #include float fragCoordZ = 0.5 * vHighPrecisionZW[0] / vHighPrecisionZW[1] + 0.5; #if DEPTH_PACKING == 3200 gl_FragColor = vec4( vec3( 1.0 - fragCoordZ ), opacity ); #elif DEPTH_PACKING == 3201 gl_FragColor = packDepthToRGBA( fragCoordZ ); #endif }`; var MI = `#include #include #include #include #include #include #include varying vec2 vHighPrecisionZW; void main() { #include #include #ifdef USE_DISPLACEMENTMAP #include #include #include #endif #include #include #include #include #include #include #include vHighPrecisionZW = gl_Position.zw; }`; var wI = `#define DISTANCE uniform vec3 referencePosition; uniform float nearDistance; uniform float farDistance; varying vec3 vWorldPosition; #include #include #include #include #include #include void main () { #include vec4 diffuseColor = vec4( 1.0 ); #include #include #include float dist = length( vWorldPosition - referencePosition ); dist = ( dist - nearDistance ) / ( farDistance - nearDistance ); dist = saturate( dist ); gl_FragColor = packDepthToRGBA( dist ); }`; var AI = `#define DISTANCE varying vec3 vWorldPosition; #include #include #include #include #include #include void main() { #include #include #ifdef USE_DISPLACEMENTMAP #include #include #include #endif #include #include #include #include #include #include #include vWorldPosition = worldPosition.xyz; }`; var SI = `uniform sampler2D tEquirect; varying vec3 vWorldDirection; #include void main() { vec3 direction = normalize( vWorldDirection ); vec2 sampleUV = equirectUv( direction ); vec4 texColor = texture2D( tEquirect, sampleUV ); gl_FragColor = mapTexelToLinear( texColor ); #include #include }`; var _I = `varying vec3 vWorldDirection; #include void main() { vWorldDirection = transformDirection( position, modelMatrix ); #include #include }`; var TI = `uniform vec3 diffuse; uniform float opacity; uniform float dashSize; uniform float totalSize; varying float vLineDistance; #include #include #include #include #include void main() { #include if ( mod( vLineDistance, totalSize ) > dashSize ) { discard; } vec3 outgoingLight = vec3( 0.0 ); vec4 diffuseColor = vec4( diffuse, opacity ); #include #include outgoingLight = diffuseColor.rgb; gl_FragColor = vec4( outgoingLight, diffuseColor.a ); #include #include #include #include }`; var EI = `uniform float scale; attribute float lineDistance; varying float vLineDistance; #include #include #include #include #include #include void main() { vLineDistance = scale * lineDistance; #include #include #include #include #include #include #include }`; var CI = `uniform vec3 diffuse; uniform float opacity; #ifndef FLAT_SHADED varying vec3 vNormal; #endif #include #include #include #include #include #include #include #include #include #include #include #include #include #include #include #include void main() { #include vec4 diffuseColor = vec4( diffuse, opacity ); #include #include #include #include #include #include ReflectedLight reflectedLight = ReflectedLight( vec3( 0.0 ), vec3( 0.0 ), vec3( 0.0 ), vec3( 0.0 ) ); #ifdef USE_LIGHTMAP vec4 lightMapTexel= texture2D( lightMap, vUv2 ); reflectedLight.indirectDiffuse += lightMapTexelToLinear( lightMapTexel ).rgb * lightMapIntensity; #else reflectedLight.indirectDiffuse += vec3( 1.0 ); #endif #include reflectedLight.indirectDiffuse *= diffuseColor.rgb; vec3 outgoingLight = reflectedLight.indirectDiffuse; #include gl_FragColor = vec4( outgoingLight, diffuseColor.a ); #include #include #include #include #include }`; var LI = `#include #include #include #include #include #include #include #include #include #include void main() { #include #include #include #include #ifdef USE_ENVMAP #include #include #include #include #endif #include #include #include #include #include #include #include #include #include }`; var RI = `uniform vec3 diffuse; uniform vec3 emissive; uniform float opacity; varying vec3 vLightFront; varying vec3 vIndirectFront; #ifdef DOUBLE_SIDED varying vec3 vLightBack; varying vec3 vIndirectBack; #endif #include #include #include #include #include #include #include #include #include #include #include #include #include #include #include #include #include #include #include #include #include #include void main() { #include vec4 diffuseColor = vec4( diffuse, opacity ); ReflectedLight reflectedLight = ReflectedLight( vec3( 0.0 ), vec3( 0.0 ), vec3( 0.0 ), vec3( 0.0 ) ); vec3 totalEmissiveRadiance = emissive; #include #include #include #include #include #include #include #ifdef DOUBLE_SIDED reflectedLight.indirectDiffuse += ( gl_FrontFacing ) ? vIndirectFront : vIndirectBack; #else reflectedLight.indirectDiffuse += vIndirectFront; #endif #include reflectedLight.indirectDiffuse *= BRDF_Diffuse_Lambert( diffuseColor.rgb ); #ifdef DOUBLE_SIDED reflectedLight.directDiffuse = ( gl_FrontFacing ) ? vLightFront : vLightBack; #else reflectedLight.directDiffuse = vLightFront; #endif reflectedLight.directDiffuse *= BRDF_Diffuse_Lambert( diffuseColor.rgb ) * getShadowMask(); #include vec3 outgoingLight = reflectedLight.directDiffuse + reflectedLight.indirectDiffuse + totalEmissiveRadiance; #include gl_FragColor = vec4( outgoingLight, diffuseColor.a ); #include #include #include #include #include }`; var FI = `#define LAMBERT varying vec3 vLightFront; varying vec3 vIndirectFront; #ifdef DOUBLE_SIDED varying vec3 vLightBack; varying vec3 vIndirectBack; #endif #include #include #include #include #include #include #include #include #include #include #include #include #include void main() { #include #include #include #include #include #include #include #include #include #include #include #include #include #include #include #include #include #include #include }`; var PI = `#define MATCAP uniform vec3 diffuse; uniform float opacity; uniform sampler2D matcap; varying vec3 vViewPosition; #ifndef FLAT_SHADED varying vec3 vNormal; #endif #include #include #include #include #include #include #include #include #include #include #include void main() { #include vec4 diffuseColor = vec4( diffuse, opacity ); #include #include #include #include #include #include #include vec3 viewDir = normalize( vViewPosition ); vec3 x = normalize( vec3( viewDir.z, 0.0, - viewDir.x ) ); vec3 y = cross( viewDir, x ); vec2 uv = vec2( dot( x, normal ), dot( y, normal ) ) * 0.495 + 0.5; #ifdef USE_MATCAP vec4 matcapColor = texture2D( matcap, uv ); matcapColor = matcapTexelToLinear( matcapColor ); #else vec4 matcapColor = vec4( 1.0 ); #endif vec3 outgoingLight = diffuseColor.rgb * matcapColor.rgb; gl_FragColor = vec4( outgoingLight, diffuseColor.a ); #include #include #include #include #include }`; var II = `#define MATCAP varying vec3 vViewPosition; #ifndef FLAT_SHADED varying vec3 vNormal; #endif #include #include #include #include #include #include #include #include #include void main() { #include #include #include #include #include #include #include #ifndef FLAT_SHADED vNormal = normalize( transformedNormal ); #endif #include #include #include #include #include #include #include #include vViewPosition = - mvPosition.xyz; }`; var OI = `#define TOON uniform vec3 diffuse; uniform vec3 emissive; uniform float opacity; #include #include #include #include #include #include #include #include #include #include #include #include #include #include #include #include #include #include #include #include #include void main() { #include vec4 diffuseColor = vec4( diffuse, opacity ); ReflectedLight reflectedLight = ReflectedLight( vec3( 0.0 ), vec3( 0.0 ), vec3( 0.0 ), vec3( 0.0 ) ); vec3 totalEmissiveRadiance = emissive; #include #include #include #include #include #include #include #include #include #include #include #include #include vec3 outgoingLight = reflectedLight.directDiffuse + reflectedLight.indirectDiffuse + totalEmissiveRadiance; gl_FragColor = vec4( outgoingLight, diffuseColor.a ); #include #include #include #include #include }`; var DI = `#define TOON varying vec3 vViewPosition; #ifndef FLAT_SHADED varying vec3 vNormal; #endif #include #include #include #include #include #include #include #include #include #include #include void main() { #include #include #include #include #include #include #include #include #ifndef FLAT_SHADED vNormal = normalize( transformedNormal ); #endif #include #include #include #include #include #include #include vViewPosition = - mvPosition.xyz; #include #include #include }`; var NI = `#define PHONG uniform vec3 diffuse; uniform vec3 emissive; uniform vec3 specular; uniform float shininess; uniform float opacity; #include #include #include #include #include #include #include #include #include #include #include #include #include #include #include #include #include #include #include #include #include #include #include #include void main() { #include vec4 diffuseColor = vec4( diffuse, opacity ); ReflectedLight reflectedLight = ReflectedLight( vec3( 0.0 ), vec3( 0.0 ), vec3( 0.0 ), vec3( 0.0 ) ); vec3 totalEmissiveRadiance = emissive; #include #include #include #include #include #include #include #include #include #include #include #include #include #include vec3 outgoingLight = reflectedLight.directDiffuse + reflectedLight.indirectDiffuse + reflectedLight.directSpecular + reflectedLight.indirectSpecular + totalEmissiveRadiance; #include gl_FragColor = vec4( outgoingLight, diffuseColor.a ); #include #include #include #include #include }`; var BI = `#define PHONG varying vec3 vViewPosition; #ifndef FLAT_SHADED varying vec3 vNormal; #endif #include #include #include #include #include #include #include #include #include #include #include #include void main() { #include #include #include #include #include #include #include #include #ifndef FLAT_SHADED vNormal = normalize( transformedNormal ); #endif #include #include #include #include #include #include #include vViewPosition = - mvPosition.xyz; #include #include #include #include }`; var UI = `#define STANDARD #ifdef PHYSICAL #define REFLECTIVITY #define CLEARCOAT #endif uniform vec3 diffuse; uniform vec3 emissive; uniform float roughness; uniform float metalness; uniform float opacity; #ifdef USE_TRANSMISSION uniform float transmission; uniform float thickness; uniform vec3 attenuationColor; uniform float attenuationDistance; #endif #ifdef REFLECTIVITY uniform float reflectivity; #endif #ifdef CLEARCOAT uniform float clearcoat; uniform float clearcoatRoughness; #endif #ifdef USE_SHEEN uniform vec3 sheen; #endif varying vec3 vViewPosition; #ifndef FLAT_SHADED varying vec3 vNormal; #ifdef USE_TANGENT varying vec3 vTangent; varying vec3 vBitangent; #endif #endif #include #include #include #include #include #include #include #include #include #include #include #include #include #include #include #include #include #include #include #include #include #include #include #include #include #include #include void main() { #include vec4 diffuseColor = vec4( diffuse, opacity ); ReflectedLight reflectedLight = ReflectedLight( vec3( 0.0 ), vec3( 0.0 ), vec3( 0.0 ), vec3( 0.0 ) ); vec3 totalEmissiveRadiance = emissive; #include #include #include #include #include #include #include #include #include #include #include #include #include #include #include #include #include vec3 totalDiffuse = reflectedLight.directDiffuse + reflectedLight.indirectDiffuse; vec3 totalSpecular = reflectedLight.directSpecular + reflectedLight.indirectSpecular; #include vec3 outgoingLight = totalDiffuse + totalSpecular + totalEmissiveRadiance; gl_FragColor = vec4( outgoingLight, diffuseColor.a ); #include #include #include #include #include }`; var zI = `#define STANDARD varying vec3 vViewPosition; #ifndef FLAT_SHADED varying vec3 vNormal; #ifdef USE_TANGENT varying vec3 vTangent; varying vec3 vBitangent; #endif #endif #ifdef USE_TRANSMISSION varying vec4 vWorldPosition; #endif #include #include #include #include #include #include #include #include #include #include #include void main() { #include #include #include #include #include #include #include #include #ifndef FLAT_SHADED vNormal = normalize( transformedNormal ); #ifdef USE_TANGENT vTangent = normalize( transformedTangent ); vBitangent = normalize( cross( vNormal, vTangent ) * tangent.w ); #endif #endif #include #include #include #include #include #include #include vViewPosition = - mvPosition.xyz; #include #include #include #ifdef USE_TRANSMISSION vWorldPosition = worldPosition; #endif }`; var VI = `#define NORMAL uniform float opacity; #if defined( FLAT_SHADED ) || defined( USE_BUMPMAP ) || defined( TANGENTSPACE_NORMALMAP ) varying vec3 vViewPosition; #endif #ifndef FLAT_SHADED varying vec3 vNormal; #ifdef USE_TANGENT varying vec3 vTangent; varying vec3 vBitangent; #endif #endif #include #include #include #include #include #include void main() { #include #include #include #include gl_FragColor = vec4( packNormalToRGB( normal ), opacity ); }`; var kI = `#define NORMAL #if defined( FLAT_SHADED ) || defined( USE_BUMPMAP ) || defined( TANGENTSPACE_NORMALMAP ) varying vec3 vViewPosition; #endif #ifndef FLAT_SHADED varying vec3 vNormal; #ifdef USE_TANGENT varying vec3 vTangent; varying vec3 vBitangent; #endif #endif #include #include #include #include #include #include #include void main() { #include #include #include #include #include #include #ifndef FLAT_SHADED vNormal = normalize( transformedNormal ); #ifdef USE_TANGENT vTangent = normalize( transformedTangent ); vBitangent = normalize( cross( vNormal, vTangent ) * tangent.w ); #endif #endif #include #include #include #include #include #include #include #if defined( FLAT_SHADED ) || defined( USE_BUMPMAP ) || defined( TANGENTSPACE_NORMALMAP ) vViewPosition = - mvPosition.xyz; #endif }`; var GI = `uniform vec3 diffuse; uniform float opacity; #include #include #include #include #include #include void main() { #include vec3 outgoingLight = vec3( 0.0 ); vec4 diffuseColor = vec4( diffuse, opacity ); #include #include #include #include outgoingLight = diffuseColor.rgb; gl_FragColor = vec4( outgoingLight, diffuseColor.a ); #include #include #include #include }`; var HI = `uniform float size; uniform float scale; #include #include #include #include #include #include void main() { #include #include #include #include gl_PointSize = size; #ifdef USE_SIZEATTENUATION bool isPerspective = isPerspectiveMatrix( projectionMatrix ); if ( isPerspective ) gl_PointSize *= ( scale / - mvPosition.z ); #endif #include #include #include #include }`; var WI = `uniform vec3 color; uniform float opacity; #include #include #include #include #include #include #include void main() { gl_FragColor = vec4( color, opacity * ( 1.0 - getShadowMask() ) ); #include #include #include }`; var jI = `#include #include #include void main() { #include #include #include #include #include #include #include #include #include #include }`; var $I = `uniform vec3 diffuse; uniform float opacity; #include #include #include #include #include #include #include void main() { #include vec3 outgoingLight = vec3( 0.0 ); vec4 diffuseColor = vec4( diffuse, opacity ); #include #include #include #include outgoingLight = diffuseColor.rgb; gl_FragColor = vec4( outgoingLight, diffuseColor.a ); #include #include #include }`; var ZI = `uniform float rotation; uniform vec2 center; #include #include #include #include #include void main() { #include vec4 mvPosition = modelViewMatrix * vec4( 0.0, 0.0, 0.0, 1.0 ); vec2 scale; scale.x = length( vec3( modelMatrix[ 0 ].x, modelMatrix[ 0 ].y, modelMatrix[ 0 ].z ) ); scale.y = length( vec3( modelMatrix[ 1 ].x, modelMatrix[ 1 ].y, modelMatrix[ 1 ].z ) ); #ifndef USE_SIZEATTENUATION bool isPerspective = isPerspectiveMatrix( projectionMatrix ); if ( isPerspective ) scale *= - mvPosition.z; #endif vec2 alignedPosition = ( position.xy - ( center - vec2( 0.5 ) ) ) * scale; vec2 rotatedPosition; rotatedPosition.x = cos( rotation ) * alignedPosition.x - sin( rotation ) * alignedPosition.y; rotatedPosition.y = sin( rotation ) * alignedPosition.x + cos( rotation ) * alignedPosition.y; mvPosition.xy += rotatedPosition; gl_Position = projectionMatrix * mvPosition; #include #include #include }`; var dt = { alphamap_fragment: EF, alphamap_pars_fragment: CF, alphatest_fragment: LF, aomap_fragment: RF, aomap_pars_fragment: FF, begin_vertex: PF, beginnormal_vertex: IF, bsdfs: OF, bumpmap_pars_fragment: DF, clipping_planes_fragment: NF, clipping_planes_pars_fragment: BF, clipping_planes_pars_vertex: UF, clipping_planes_vertex: zF, color_fragment: VF, color_pars_fragment: kF, color_pars_vertex: GF, color_vertex: HF, common: WF, cube_uv_reflection_fragment: jF, defaultnormal_vertex: $F, displacementmap_pars_vertex: ZF, displacementmap_vertex: XF, emissivemap_fragment: YF, emissivemap_pars_fragment: JF, encodings_fragment: KF, encodings_pars_fragment: qF, envmap_fragment: QF, envmap_common_pars_fragment: eP, envmap_pars_fragment: tP, envmap_pars_vertex: nP, envmap_physical_pars_fragment: fP, envmap_vertex: iP, fog_vertex: rP, fog_pars_vertex: sP, fog_fragment: oP, fog_pars_fragment: aP, gradientmap_pars_fragment: lP, lightmap_fragment: cP, lightmap_pars_fragment: uP, lights_lambert_vertex: hP, lights_pars_begin: dP, lights_toon_fragment: pP, lights_toon_pars_fragment: mP, lights_phong_fragment: gP, lights_phong_pars_fragment: vP, lights_physical_fragment: yP, lights_physical_pars_fragment: bP, lights_fragment_begin: xP, lights_fragment_maps: MP, lights_fragment_end: wP, logdepthbuf_fragment: AP, logdepthbuf_pars_fragment: SP, logdepthbuf_pars_vertex: _P, logdepthbuf_vertex: TP, map_fragment: EP, map_pars_fragment: CP, map_particle_fragment: LP, map_particle_pars_fragment: RP, metalnessmap_fragment: FP, metalnessmap_pars_fragment: PP, morphnormal_vertex: IP, morphtarget_pars_vertex: OP, morphtarget_vertex: DP, normal_fragment_begin: NP, normal_fragment_maps: BP, normalmap_pars_fragment: UP, clearcoat_normal_fragment_begin: zP, clearcoat_normal_fragment_maps: VP, clearcoat_pars_fragment: kP, packing: GP, premultiplied_alpha_fragment: HP, project_vertex: WP, dithering_fragment: jP, dithering_pars_fragment: $P, roughnessmap_fragment: ZP, roughnessmap_pars_fragment: XP, shadowmap_pars_fragment: YP, shadowmap_pars_vertex: JP, shadowmap_vertex: KP, shadowmask_pars_fragment: qP, skinbase_vertex: QP, skinning_pars_vertex: eI, skinning_vertex: tI, skinnormal_vertex: nI, specularmap_fragment: iI, specularmap_pars_fragment: rI, tonemapping_fragment: sI, tonemapping_pars_fragment: oI, transmission_fragment: aI, transmission_pars_fragment: lI, uv_pars_fragment: cI, uv_pars_vertex: uI, uv_vertex: hI, uv2_pars_fragment: dI, uv2_pars_vertex: fI, uv2_vertex: pI, worldpos_vertex: mI, background_frag: gI, background_vert: vI, cube_frag: yI, cube_vert: bI, depth_frag: xI, depth_vert: MI, distanceRGBA_frag: wI, distanceRGBA_vert: AI, equirect_frag: SI, equirect_vert: _I, linedashed_frag: TI, linedashed_vert: EI, meshbasic_frag: CI, meshbasic_vert: LI, meshlambert_frag: RI, meshlambert_vert: FI, meshmatcap_frag: PI, meshmatcap_vert: II, meshtoon_frag: OI, meshtoon_vert: DI, meshphong_frag: NI, meshphong_vert: BI, meshphysical_frag: UI, meshphysical_vert: zI, normal_frag: VI, normal_vert: kI, points_frag: GI, points_vert: HI, shadow_frag: WI, shadow_vert: jI, sprite_frag: $I, sprite_vert: ZI }; var ze = { common: { diffuse: { value: new Ue(16777215) }, opacity: { value: 1 }, map: { value: null }, uvTransform: { value: new rn() }, uv2Transform: { value: new rn() }, alphaMap: { value: null } }, specularmap: { specularMap: { value: null } }, envmap: { envMap: { value: null }, flipEnvMap: { value: -1 }, reflectivity: { value: 1 }, refractionRatio: { value: 0.98 }, maxMipLevel: { value: 0 } }, aomap: { aoMap: { value: null }, aoMapIntensity: { value: 1 } }, lightmap: { lightMap: { value: null }, lightMapIntensity: { value: 1 } }, emissivemap: { emissiveMap: { value: null } }, bumpmap: { bumpMap: { value: null }, bumpScale: { value: 1 } }, normalmap: { normalMap: { value: null }, normalScale: { value: new Re(1, 1) } }, displacementmap: { displacementMap: { value: null }, displacementScale: { value: 1 }, displacementBias: { value: 0 } }, roughnessmap: { roughnessMap: { value: null } }, metalnessmap: { metalnessMap: { value: null } }, gradientmap: { gradientMap: { value: null } }, fog: { fogDensity: { value: 25e-5 }, fogNear: { value: 1 }, fogFar: { value: 2e3 }, fogColor: { value: new Ue(16777215) } }, lights: { ambientLightColor: { value: [] }, lightProbe: { value: [] }, directionalLights: { value: [], properties: { direction: {}, color: {} } }, directionalLightShadows: { value: [], properties: { shadowBias: {}, shadowNormalBias: {}, shadowRadius: {}, shadowMapSize: {} } }, directionalShadowMap: { value: [] }, directionalShadowMatrix: { value: [] }, spotLights: { value: [], properties: { color: {}, position: {}, direction: {}, distance: {}, coneCos: {}, penumbraCos: {}, decay: {} } }, spotLightShadows: { value: [], properties: { shadowBias: {}, shadowNormalBias: {}, shadowRadius: {}, shadowMapSize: {} } }, spotShadowMap: { value: [] }, spotShadowMatrix: { value: [] }, pointLights: { value: [], properties: { color: {}, position: {}, decay: {}, distance: {} } }, pointLightShadows: { value: [], properties: { shadowBias: {}, shadowNormalBias: {}, shadowRadius: {}, shadowMapSize: {}, shadowCameraNear: {}, shadowCameraFar: {} } }, pointShadowMap: { value: [] }, pointShadowMatrix: { value: [] }, hemisphereLights: { value: [], properties: { direction: {}, skyColor: {}, groundColor: {} } }, // TODO (abelnation): RectAreaLight BRDF data needs to be moved from example to main src rectAreaLights: { value: [], properties: { color: {}, position: {}, width: {}, height: {} } }, ltc_1: { value: null }, ltc_2: { value: null } }, points: { diffuse: { value: new Ue(16777215) }, opacity: { value: 1 }, size: { value: 1 }, scale: { value: 1 }, map: { value: null }, alphaMap: { value: null }, uvTransform: { value: new rn() } }, sprite: { diffuse: { value: new Ue(16777215) }, opacity: { value: 1 }, center: { value: new Re(0.5, 0.5) }, rotation: { value: 0 }, map: { value: null }, alphaMap: { value: null }, uvTransform: { value: new rn() } } }; var ci = { basic: { uniforms: wn2([ ze.common, ze.specularmap, ze.envmap, ze.aomap, ze.lightmap, ze.fog ]), vertexShader: dt.meshbasic_vert, fragmentShader: dt.meshbasic_frag }, lambert: { uniforms: wn2([ ze.common, ze.specularmap, ze.envmap, ze.aomap, ze.lightmap, ze.emissivemap, ze.fog, ze.lights, { emissive: { value: new Ue(0) } } ]), vertexShader: dt.meshlambert_vert, fragmentShader: dt.meshlambert_frag }, phong: { uniforms: wn2([ ze.common, ze.specularmap, ze.envmap, ze.aomap, ze.lightmap, ze.emissivemap, ze.bumpmap, ze.normalmap, ze.displacementmap, ze.fog, ze.lights, { emissive: { value: new Ue(0) }, specular: { value: new Ue(1118481) }, shininess: { value: 30 } } ]), vertexShader: dt.meshphong_vert, fragmentShader: dt.meshphong_frag }, standard: { uniforms: wn2([ ze.common, ze.envmap, ze.aomap, ze.lightmap, ze.emissivemap, ze.bumpmap, ze.normalmap, ze.displacementmap, ze.roughnessmap, ze.metalnessmap, ze.fog, ze.lights, { emissive: { value: new Ue(0) }, roughness: { value: 1 }, metalness: { value: 0 }, envMapIntensity: { value: 1 } // temporary } ]), vertexShader: dt.meshphysical_vert, fragmentShader: dt.meshphysical_frag }, toon: { uniforms: wn2([ ze.common, ze.aomap, ze.lightmap, ze.emissivemap, ze.bumpmap, ze.normalmap, ze.displacementmap, ze.gradientmap, ze.fog, ze.lights, { emissive: { value: new Ue(0) } } ]), vertexShader: dt.meshtoon_vert, fragmentShader: dt.meshtoon_frag }, matcap: { uniforms: wn2([ ze.common, ze.bumpmap, ze.normalmap, ze.displacementmap, ze.fog, { matcap: { value: null } } ]), vertexShader: dt.meshmatcap_vert, fragmentShader: dt.meshmatcap_frag }, points: { uniforms: wn2([ ze.points, ze.fog ]), vertexShader: dt.points_vert, fragmentShader: dt.points_frag }, dashed: { uniforms: wn2([ ze.common, ze.fog, { scale: { value: 1 }, dashSize: { value: 1 }, totalSize: { value: 2 } } ]), vertexShader: dt.linedashed_vert, fragmentShader: dt.linedashed_frag }, depth: { uniforms: wn2([ ze.common, ze.displacementmap ]), vertexShader: dt.depth_vert, fragmentShader: dt.depth_frag }, normal: { uniforms: wn2([ ze.common, ze.bumpmap, ze.normalmap, ze.displacementmap, { opacity: { value: 1 } } ]), vertexShader: dt.normal_vert, fragmentShader: dt.normal_frag }, sprite: { uniforms: wn2([ ze.sprite, ze.fog ]), vertexShader: dt.sprite_vert, fragmentShader: dt.sprite_frag }, background: { uniforms: { uvTransform: { value: new rn() }, t2D: { value: null } }, vertexShader: dt.background_vert, fragmentShader: dt.background_frag }, /* ------------------------------------------------------------------------- // Cube map shader ------------------------------------------------------------------------- */ cube: { uniforms: wn2([ ze.envmap, { opacity: { value: 1 } } ]), vertexShader: dt.cube_vert, fragmentShader: dt.cube_frag }, equirect: { uniforms: { tEquirect: { value: null } }, vertexShader: dt.equirect_vert, fragmentShader: dt.equirect_frag }, distanceRGBA: { uniforms: wn2([ ze.common, ze.displacementmap, { referencePosition: { value: new q() }, nearDistance: { value: 1 }, farDistance: { value: 1e3 } } ]), vertexShader: dt.distanceRGBA_vert, fragmentShader: dt.distanceRGBA_frag }, shadow: { uniforms: wn2([ ze.lights, ze.fog, { color: { value: new Ue(0) }, opacity: { value: 1 } } ]), vertexShader: dt.shadow_vert, fragmentShader: dt.shadow_frag } }; ci.physical = { uniforms: wn2([ ci.standard.uniforms, { clearcoat: { value: 0 }, clearcoatMap: { value: null }, clearcoatRoughness: { value: 0 }, clearcoatRoughnessMap: { value: null }, clearcoatNormalScale: { value: new Re(1, 1) }, clearcoatNormalMap: { value: null }, sheen: { value: new Ue(0) }, transmission: { value: 0 }, transmissionMap: { value: null }, transmissionSamplerSize: { value: new Re() }, transmissionSamplerMap: { value: null }, thickness: { value: 0 }, thicknessMap: { value: null }, attenuationDistance: { value: 0 }, attenuationColor: { value: new Ue(0) } } ]), vertexShader: dt.meshphysical_vert, fragmentShader: dt.meshphysical_frag }; function XI(n, e, t, i, r) { const s = new Ue(0); let o = 0, a, c, l = null, d = 0, h6 = null; function f(p, u) { let y = false, v = u.isScene === true ? u.background : null; v && v.isTexture && (v = e.get(v)); const m = n.xr, x = m.getSession && m.getSession(); x && x.environmentBlendMode === "additive" && (v = null), v === null ? g(s, o) : v && v.isColor && (g(v, 1), y = true), (n.autoClear || y) && n.clear(n.autoClearColor, n.autoClearDepth, n.autoClearStencil), v && (v.isCubeTexture || v.mapping === ea) ? (c === void 0 && (c = new Xt( new sr(1, 1, 1), new or({ name: "BackgroundCubeMaterial", uniforms: Po(ci.cube.uniforms), vertexShader: ci.cube.vertexShader, fragmentShader: ci.cube.fragmentShader, side: jt, depthTest: false, depthWrite: false, fog: false }) ), c.geometry.deleteAttribute("normal"), c.geometry.deleteAttribute("uv"), c.onBeforeRender = function(w, A, M) { this.matrixWorld.copyPosition(M.matrixWorld); }, Object.defineProperty(c.material, "envMap", { get: function() { return this.uniforms.envMap.value; } }), i.update(c)), c.material.uniforms.envMap.value = v, c.material.uniforms.flipEnvMap.value = v.isCubeTexture && v._needsFlipEnvMap ? -1 : 1, (l !== v || d !== v.version || h6 !== n.toneMapping) && (c.material.needsUpdate = true, l = v, d = v.version, h6 = n.toneMapping), p.unshift(c, c.geometry, c.material, 0, 0, null)) : v && v.isTexture && (a === void 0 && (a = new Xt( new Ls(2, 2), new or({ name: "BackgroundMaterial", uniforms: Po(ci.background.uniforms), vertexShader: ci.background.vertexShader, fragmentShader: ci.background.fragmentShader, side: Hr, depthTest: false, depthWrite: false, fog: false }) ), a.geometry.deleteAttribute("normal"), Object.defineProperty(a.material, "map", { get: function() { return this.uniforms.t2D.value; } }), i.update(a)), a.material.uniforms.t2D.value = v, v.matrixAutoUpdate === true && v.updateMatrix(), a.material.uniforms.uvTransform.value.copy(v.matrix), (l !== v || d !== v.version || h6 !== n.toneMapping) && (a.material.needsUpdate = true, l = v, d = v.version, h6 = n.toneMapping), p.unshift(a, a.geometry, a.material, 0, 0, null)); } function g(p, u) { t.buffers.color.setClear(p.r, p.g, p.b, u, r); } return { getClearColor: function() { return s; }, setClearColor: function(p, u = 1) { s.set(p), o = u, g(s, o); }, getClearAlpha: function() { return o; }, setClearAlpha: function(p) { o = p, g(s, o); }, render: f }; } function YI(n, e, t, i) { const r = n.getParameter(34921), s = i.isWebGL2 ? null : e.get("OES_vertex_array_object"), o = i.isWebGL2 || s !== null, a = {}, c = u(null); let l = c; function d(E, C, P, b, F) { let D = false; if (o) { const N = p(b, P, C); l !== N && (l = N, f(l.object)), D = y(b, F), D && v(b, F); } else { const N = C.wireframe === true; (l.geometry !== b.id || l.program !== P.id || l.wireframe !== N) && (l.geometry = b.id, l.program = P.id, l.wireframe = N, D = true); } E.isInstancedMesh === true && (D = true), F !== null && t.update(F, 34963), D && (R(E, C, P, b), F !== null && n.bindBuffer(34963, t.get(F).buffer)); } function h6() { return i.isWebGL2 ? n.createVertexArray() : s.createVertexArrayOES(); } function f(E) { return i.isWebGL2 ? n.bindVertexArray(E) : s.bindVertexArrayOES(E); } function g(E) { return i.isWebGL2 ? n.deleteVertexArray(E) : s.deleteVertexArrayOES(E); } function p(E, C, P) { const b = P.wireframe === true; let F = a[E.id]; F === void 0 && (F = {}, a[E.id] = F); let D = F[C.id]; D === void 0 && (D = {}, F[C.id] = D); let N = D[b]; return N === void 0 && (N = u(h6()), D[b] = N), N; } function u(E) { const C = [], P = [], b = []; for (let F = 0; F < r; F++) C[F] = 0, P[F] = 0, b[F] = 0; return { // for backward compatibility on non-VAO support browser geometry: null, program: null, wireframe: false, newAttributes: C, enabledAttributes: P, attributeDivisors: b, object: E, attributes: {}, index: null }; } function y(E, C) { const P = l.attributes, b = E.attributes; let F = 0; for (const D in b) { const N = P[D], B = b[D]; if (N === void 0 || N.attribute !== B || N.data !== B.data) return true; F++; } return l.attributesNum !== F || l.index !== C; } function v(E, C) { const P = {}, b = E.attributes; let F = 0; for (const D in b) { const N = b[D], B = {}; B.attribute = N, N.data && (B.data = N.data), P[D] = B, F++; } l.attributes = P, l.attributesNum = F, l.index = C; } function m() { const E = l.newAttributes; for (let C = 0, P = E.length; C < P; C++) E[C] = 0; } function x(E) { w(E, 0); } function w(E, C) { const P = l.newAttributes, b = l.enabledAttributes, F = l.attributeDivisors; P[E] = 1, b[E] === 0 && (n.enableVertexAttribArray(E), b[E] = 1), F[E] !== C && ((i.isWebGL2 ? n : e.get("ANGLE_instanced_arrays"))[i.isWebGL2 ? "vertexAttribDivisor" : "vertexAttribDivisorANGLE"](E, C), F[E] = C); } function A() { const E = l.newAttributes, C = l.enabledAttributes; for (let P = 0, b = C.length; P < b; P++) C[P] !== E[P] && (n.disableVertexAttribArray(P), C[P] = 0); } function M(E, C, P, b, F, D) { i.isWebGL2 === true && (P === 5124 || P === 5125) ? n.vertexAttribIPointer(E, C, P, F, D) : n.vertexAttribPointer(E, C, P, b, F, D); } function R(E, C, P, b) { if (i.isWebGL2 === false && (E.isInstancedMesh || b.isInstancedBufferGeometry) && e.get("ANGLE_instanced_arrays") === null) return; m(); const F = b.attributes, D = P.getAttributes(), N = C.defaultAttributeValues; for (const B in D) { const U = D[B]; if (U >= 0) { const G = F[B]; if (G !== void 0) { const Y = G.normalized, te = G.itemSize, ae = t.get(G); if (ae === void 0) continue; const ie = ae.buffer, le = ae.type, W = ae.bytesPerElement; if (G.isInterleavedBufferAttribute) { const $ = G.data, j = $.stride, re = G.offset; $ && $.isInstancedInterleavedBuffer ? (w(U, $.meshPerAttribute), b._maxInstanceCount === void 0 && (b._maxInstanceCount = $.meshPerAttribute * $.count)) : x(U), n.bindBuffer(34962, ie), M(U, te, le, Y, j * W, re * W); } else G.isInstancedBufferAttribute ? (w(U, G.meshPerAttribute), b._maxInstanceCount === void 0 && (b._maxInstanceCount = G.meshPerAttribute * G.count)) : x(U), n.bindBuffer(34962, ie), M(U, te, le, Y, 0, 0); } else if (B === "instanceMatrix") { const Y = t.get(E.instanceMatrix); if (Y === void 0) continue; const te = Y.buffer, ae = Y.type; w(U + 0, 1), w(U + 1, 1), w(U + 2, 1), w(U + 3, 1), n.bindBuffer(34962, te), n.vertexAttribPointer(U + 0, 4, ae, false, 64, 0), n.vertexAttribPointer(U + 1, 4, ae, false, 64, 16), n.vertexAttribPointer(U + 2, 4, ae, false, 64, 32), n.vertexAttribPointer(U + 3, 4, ae, false, 64, 48); } else if (B === "instanceColor") { const Y = t.get(E.instanceColor); if (Y === void 0) continue; const te = Y.buffer, ae = Y.type; w(U, 1), n.bindBuffer(34962, te), n.vertexAttribPointer(U, 3, ae, false, 12, 0); } else if (N !== void 0) { const Y = N[B]; if (Y !== void 0) switch (Y.length) { case 2: n.vertexAttrib2fv(U, Y); break; case 3: n.vertexAttrib3fv(U, Y); break; case 4: n.vertexAttrib4fv(U, Y); break; default: n.vertexAttrib1fv(U, Y); } } } } A(); } function L() { T(); for (const E in a) { const C = a[E]; for (const P in C) { const b = C[P]; for (const F in b) g(b[F].object), delete b[F]; delete C[P]; } delete a[E]; } } function S(E) { if (a[E.id] === void 0) return; const C = a[E.id]; for (const P in C) { const b = C[P]; for (const F in b) g(b[F].object), delete b[F]; delete C[P]; } delete a[E.id]; } function I(E) { for (const C in a) { const P = a[C]; if (P[E.id] === void 0) continue; const b = P[E.id]; for (const F in b) g(b[F].object), delete b[F]; delete P[E.id]; } } function T() { _(), l !== c && (l = c, f(l.object)); } function _() { c.geometry = null, c.program = null, c.wireframe = false; } return { setup: d, reset: T, resetDefaultState: _, dispose: L, releaseStatesOfGeometry: S, releaseStatesOfProgram: I, initAttributes: m, enableAttribute: x, disableUnusedAttributes: A }; } function JI(n, e, t, i) { const r = i.isWebGL2; let s; function o(l) { s = l; } function a(l, d) { n.drawArrays(s, l, d), t.update(d, s, 1); } function c(l, d, h6) { if (h6 === 0) return; let f, g; if (r) f = n, g = "drawArraysInstanced"; else if (f = e.get("ANGLE_instanced_arrays"), g = "drawArraysInstancedANGLE", f === null) { console.error("THREE.WebGLBufferRenderer: using THREE.InstancedBufferGeometry but hardware does not support extension ANGLE_instanced_arrays."); return; } f[g](s, l, d, h6), t.update(d, s, h6); } this.setMode = o, this.render = a, this.renderInstances = c; } function KI(n, e, t) { let i; function r() { if (i !== void 0) return i; if (e.has("EXT_texture_filter_anisotropic") === true) { const R = e.get("EXT_texture_filter_anisotropic"); i = n.getParameter(R.MAX_TEXTURE_MAX_ANISOTROPY_EXT); } else i = 0; return i; } function s(R) { if (R === "highp") { if (n.getShaderPrecisionFormat(35633, 36338).precision > 0 && n.getShaderPrecisionFormat(35632, 36338).precision > 0) return "highp"; R = "mediump"; } return R === "mediump" && n.getShaderPrecisionFormat(35633, 36337).precision > 0 && n.getShaderPrecisionFormat(35632, 36337).precision > 0 ? "mediump" : "lowp"; } const o = typeof WebGL2RenderingContext < "u" && n instanceof WebGL2RenderingContext || typeof WebGL2ComputeRenderingContext < "u" && n instanceof WebGL2ComputeRenderingContext; let a = t.precision !== void 0 ? t.precision : "highp"; const c = s(a); c !== a && (console.warn("THREE.WebGLRenderer:", a, "not supported, using", c, "instead."), a = c); const l = o || e.has("WEBGL_draw_buffers"), d = t.logarithmicDepthBuffer === true, h6 = n.getParameter(34930), f = n.getParameter(35660), g = n.getParameter(3379), p = n.getParameter(34076), u = n.getParameter(34921), y = n.getParameter(36347), v = n.getParameter(36348), m = n.getParameter(36349), x = f > 0, w = o || e.has("OES_texture_float"), A = x && w, M = o ? n.getParameter(36183) : 0; return { isWebGL2: o, drawBuffers: l, getMaxAnisotropy: r, getMaxPrecision: s, precision: a, logarithmicDepthBuffer: d, maxTextures: h6, maxVertexTextures: f, maxTextureSize: g, maxCubemapSize: p, maxAttributes: u, maxVertexUniforms: y, maxVaryings: v, maxFragmentUniforms: m, vertexTextures: x, floatFragmentTextures: w, floatVertexTextures: A, maxSamples: M }; } function qI(n) { const e = this; let t = null, i = 0, r = false, s = false; const o = new wi(), a = new rn(), c = { value: null, needsUpdate: false }; this.uniform = c, this.numPlanes = 0, this.numIntersection = 0, this.init = function(h6, f, g) { const p = h6.length !== 0 || f || // enable state of previous frame - the clipping code has to // run another frame in order to reset the state: i !== 0 || r; return r = f, t = d(h6, g, 0), i = h6.length, p; }, this.beginShadows = function() { s = true, d(null); }, this.endShadows = function() { s = false, l(); }, this.setState = function(h6, f, g) { const p = h6.clippingPlanes, u = h6.clipIntersection, y = h6.clipShadows, v = n.get(h6); if (!r || p === null || p.length === 0 || s && !y) s ? d(null) : l(); else { const m = s ? 0 : i, x = m * 4; let w = v.clippingState || null; c.value = w, w = d(p, f, x, g); for (let A = 0; A !== x; ++A) w[A] = t[A]; v.clippingState = w, this.numIntersection = u ? this.numPlanes : 0, this.numPlanes += m; } }; function l() { c.value !== t && (c.value = t, c.needsUpdate = i > 0), e.numPlanes = i, e.numIntersection = 0; } function d(h6, f, g, p) { const u = h6 !== null ? h6.length : 0; let y = null; if (u !== 0) { if (y = c.value, p !== true || y === null) { const v = g + u * 4, m = f.matrixWorldInverse; a.getNormalMatrix(m), (y === null || y.length < v) && (y = new Float32Array(v)); for (let x = 0, w = g; x !== u; ++x, w += 4) o.copy(h6[x]).applyMatrix4(m, a), o.normal.toArray(y, w), y[w + 3] = o.constant; } c.value = y, c.needsUpdate = true; } return e.numPlanes = u, e.numIntersection = 0, y; } } function QI(n) { let e = /* @__PURE__ */ new WeakMap(); function t(o, a) { return a === kc ? o.mapping = ll : a === Gc && (o.mapping = cl), o; } function i(o) { if (o && o.isTexture) { const a = o.mapping; if (a === kc || a === Gc) if (e.has(o)) { const c = e.get(o).texture; return t(c, o.mapping); } else { const c = o.image; if (c && c.height > 0) { const l = n.getRenderTarget(), d = new bu(c.height / 2); return d.fromEquirectangularTexture(n, o), e.set(o, d), n.setRenderTarget(l), o.addEventListener("dispose", r), t(d.texture, o.mapping); } else return null; } } return o; } function r(o) { const a = o.target; a.removeEventListener("dispose", r); const c = e.get(a); c !== void 0 && (e.delete(a), c.dispose()); } function s() { e = /* @__PURE__ */ new WeakMap(); } return { get: i, dispose: s }; } function eO(n) { const e = {}; function t(i) { if (e[i] !== void 0) return e[i]; let r; switch (i) { case "WEBGL_depth_texture": r = n.getExtension("WEBGL_depth_texture") || n.getExtension("MOZ_WEBGL_depth_texture") || n.getExtension("WEBKIT_WEBGL_depth_texture"); break; case "EXT_texture_filter_anisotropic": r = n.getExtension("EXT_texture_filter_anisotropic") || n.getExtension("MOZ_EXT_texture_filter_anisotropic") || n.getExtension("WEBKIT_EXT_texture_filter_anisotropic"); break; case "WEBGL_compressed_texture_s3tc": r = n.getExtension("WEBGL_compressed_texture_s3tc") || n.getExtension("MOZ_WEBGL_compressed_texture_s3tc") || n.getExtension("WEBKIT_WEBGL_compressed_texture_s3tc"); break; case "WEBGL_compressed_texture_pvrtc": r = n.getExtension("WEBGL_compressed_texture_pvrtc") || n.getExtension("WEBKIT_WEBGL_compressed_texture_pvrtc"); break; default: r = n.getExtension(i); } return e[i] = r, r; } return { has: function(i) { return t(i) !== null; }, init: function(i) { i.isWebGL2 ? t("EXT_color_buffer_float") : (t("WEBGL_depth_texture"), t("OES_texture_float"), t("OES_texture_half_float"), t("OES_texture_half_float_linear"), t("OES_standard_derivatives"), t("OES_element_index_uint"), t("OES_vertex_array_object"), t("ANGLE_instanced_arrays")), t("OES_texture_float_linear"), t("EXT_color_buffer_half_float"); }, get: function(i) { const r = t(i); return r === null && console.warn("THREE.WebGLRenderer: " + i + " extension not supported."), r; } }; } function tO(n, e, t, i) { const r = {}, s = /* @__PURE__ */ new WeakMap(); function o(h6) { const f = h6.target; f.index !== null && e.remove(f.index); for (const p in f.attributes) e.remove(f.attributes[p]); f.removeEventListener("dispose", o), delete r[f.id]; const g = s.get(f); g && (e.remove(g), s.delete(f)), i.releaseStatesOfGeometry(f), f.isInstancedBufferGeometry === true && delete f._maxInstanceCount, t.memory.geometries--; } function a(h6, f) { return r[f.id] === true || (f.addEventListener("dispose", o), r[f.id] = true, t.memory.geometries++), f; } function c(h6) { const f = h6.attributes; for (const p in f) e.update(f[p], 34962); const g = h6.morphAttributes; for (const p in g) { const u = g[p]; for (let y = 0, v = u.length; y < v; y++) e.update(u[y], 34962); } } function l(h6) { const f = [], g = h6.index, p = h6.attributes.position; let u = 0; if (g !== null) { const m = g.array; u = g.version; for (let x = 0, w = m.length; x < w; x += 3) { const A = m[x + 0], M = m[x + 1], R = m[x + 2]; f.push(A, M, M, R, R, A); } } else { const m = p.array; u = p.version; for (let x = 0, w = m.length / 3 - 1; x < w; x += 3) { const A = x + 0, M = x + 1, R = x + 2; f.push(A, M, M, R, R, A); } } const y = new (ux(f) > 65535 ? vu : gu)(f, 1); y.version = u; const v = s.get(h6); v && e.remove(v), s.set(h6, y); } function d(h6) { const f = s.get(h6); if (f) { const g = h6.index; g !== null && f.version < g.version && l(h6); } else l(h6); return s.get(h6); } return { get: a, update: c, getWireframeAttribute: d }; } function nO(n, e, t, i) { const r = i.isWebGL2; let s; function o(f) { s = f; } let a, c; function l(f) { a = f.type, c = f.bytesPerElement; } function d(f, g) { n.drawElements(s, g, a, f * c), t.update(g, s, 1); } function h6(f, g, p) { if (p === 0) return; let u, y; if (r) u = n, y = "drawElementsInstanced"; else if (u = e.get("ANGLE_instanced_arrays"), y = "drawElementsInstancedANGLE", u === null) { console.error("THREE.WebGLIndexedBufferRenderer: using THREE.InstancedBufferGeometry but hardware does not support extension ANGLE_instanced_arrays."); return; } u[y](s, g, a, f * c, p), t.update(g, s, p); } this.setMode = o, this.setIndex = l, this.render = d, this.renderInstances = h6; } function iO(n) { const e = { geometries: 0, textures: 0 }, t = { frame: 0, calls: 0, triangles: 0, points: 0, lines: 0 }; function i(s, o, a) { switch (t.calls++, o) { case 4: t.triangles += a * (s / 3); break; case 1: t.lines += a * (s / 2); break; case 3: t.lines += a * (s - 1); break; case 2: t.lines += a * s; break; case 0: t.points += a * s; break; default: console.error("THREE.WebGLInfo: Unknown draw mode:", o); break; } } function r() { t.frame++, t.calls = 0, t.triangles = 0, t.points = 0, t.lines = 0; } return { memory: e, render: t, programs: null, autoReset: true, reset: r, update: i }; } function rO(n, e) { return n[0] - e[0]; } function sO(n, e) { return Math.abs(e[1]) - Math.abs(n[1]); } function oO(n) { const e = {}, t = new Float32Array(8), i = []; for (let s = 0; s < 8; s++) i[s] = [s, 0]; function r(s, o, a, c) { const l = s.morphTargetInfluences, d = l === void 0 ? 0 : l.length; let h6 = e[o.id]; if (h6 === void 0 || h6.length !== d) { h6 = []; for (let y = 0; y < d; y++) h6[y] = [y, 0]; e[o.id] = h6; } for (let y = 0; y < d; y++) { const v = h6[y]; v[0] = y, v[1] = l[y]; } h6.sort(sO); for (let y = 0; y < 8; y++) y < d && h6[y][1] ? (i[y][0] = h6[y][0], i[y][1] = h6[y][1]) : (i[y][0] = Number.MAX_SAFE_INTEGER, i[y][1] = 0); i.sort(rO); const f = a.morphTargets && o.morphAttributes.position, g = a.morphNormals && o.morphAttributes.normal; let p = 0; for (let y = 0; y < 8; y++) { const v = i[y], m = v[0], x = v[1]; m !== Number.MAX_SAFE_INTEGER && x ? (f && o.getAttribute("morphTarget" + y) !== f[m] && o.setAttribute("morphTarget" + y, f[m]), g && o.getAttribute("morphNormal" + y) !== g[m] && o.setAttribute("morphNormal" + y, g[m]), t[y] = x, p += x) : (f && o.hasAttribute("morphTarget" + y) === true && o.deleteAttribute("morphTarget" + y), g && o.hasAttribute("morphNormal" + y) === true && o.deleteAttribute("morphNormal" + y), t[y] = 0); } const u = o.morphTargetsRelative ? 1 : 1 - p; c.getUniforms().setValue(n, "morphTargetBaseInfluence", u), c.getUniforms().setValue(n, "morphTargetInfluences", t); } return { update: r }; } function aO(n, e, t, i) { let r = /* @__PURE__ */ new WeakMap(); function s(c) { const l = i.render.frame, d = c.geometry, h6 = e.get(c, d); return r.get(h6) !== l && (e.update(h6), r.set(h6, l)), c.isInstancedMesh && (c.hasEventListener("dispose", a) === false && c.addEventListener("dispose", a), t.update(c.instanceMatrix, 34962), c.instanceColor !== null && t.update(c.instanceColor, 34962)), h6; } function o() { r = /* @__PURE__ */ new WeakMap(); } function a(c) { const l = c.target; l.removeEventListener("dispose", a), t.remove(l.instanceMatrix), l.instanceColor !== null && t.remove(l.instanceColor); } return { update: s, dispose: o }; } var Lf = class extends Yt { constructor(e = null, t = 1, i = 1, r = 1) { super(null), this.image = { data: e, width: t, height: i, depth: r }, this.magFilter = $t, this.minFilter = $t, this.wrapR = hn2, this.generateMipmaps = false, this.flipY = false, this.unpackAlignment = 1, this.needsUpdate = true; } }; Lf.prototype.isDataTexture2DArray = true; var Rf = class extends Yt { constructor(e = null, t = 1, i = 1, r = 1) { super(null), this.image = { data: e, width: t, height: i, depth: r }, this.magFilter = $t, this.minFilter = $t, this.wrapR = hn2, this.generateMipmaps = false, this.flipY = false, this.unpackAlignment = 1, this.needsUpdate = true; } }; Rf.prototype.isDataTexture3D = true; var fx = new Yt(); var lO = new Lf(); var cO = new Rf(); var px = new ta(); var ig = []; var rg = []; var sg = new Float32Array(16); var og = new Float32Array(9); var ag = new Float32Array(4); function na(n, e, t) { const i = n[0]; if (i <= 0 || i > 0) return n; const r = e * t; let s = ig[r]; if (s === void 0 && (s = new Float32Array(r), ig[r] = s), e !== 0) { i.toArray(s, 0); for (let o = 1, a = 0; o !== e; ++o) a += t, n[o].toArray(s, a); } return s; } function Ln(n, e) { if (n.length !== e.length) return false; for (let t = 0, i = n.length; t < i; t++) if (n[t] !== e[t]) return false; return true; } function _n(n, e) { for (let t = 0, i = e.length; t < i; t++) n[t] = e[t]; } function mx(n, e) { let t = rg[e]; t === void 0 && (t = new Int32Array(e), rg[e] = t); for (let i = 0; i !== e; ++i) t[i] = n.allocateTextureUnit(); return t; } function uO(n, e) { const t = this.cache; t[0] !== e && (n.uniform1f(this.addr, e), t[0] = e); } function hO(n, e) { const t = this.cache; if (e.x !== void 0) (t[0] !== e.x || t[1] !== e.y) && (n.uniform2f(this.addr, e.x, e.y), t[0] = e.x, t[1] = e.y); else { if (Ln(t, e)) return; n.uniform2fv(this.addr, e), _n(t, e); } } function dO(n, e) { const t = this.cache; if (e.x !== void 0) (t[0] !== e.x || t[1] !== e.y || t[2] !== e.z) && (n.uniform3f(this.addr, e.x, e.y, e.z), t[0] = e.x, t[1] = e.y, t[2] = e.z); else if (e.r !== void 0) (t[0] !== e.r || t[1] !== e.g || t[2] !== e.b) && (n.uniform3f(this.addr, e.r, e.g, e.b), t[0] = e.r, t[1] = e.g, t[2] = e.b); else { if (Ln(t, e)) return; n.uniform3fv(this.addr, e), _n(t, e); } } function fO(n, e) { const t = this.cache; if (e.x !== void 0) (t[0] !== e.x || t[1] !== e.y || t[2] !== e.z || t[3] !== e.w) && (n.uniform4f(this.addr, e.x, e.y, e.z, e.w), t[0] = e.x, t[1] = e.y, t[2] = e.z, t[3] = e.w); else { if (Ln(t, e)) return; n.uniform4fv(this.addr, e), _n(t, e); } } function pO(n, e) { const t = this.cache, i = e.elements; if (i === void 0) { if (Ln(t, e)) return; n.uniformMatrix2fv(this.addr, false, e), _n(t, e); } else { if (Ln(t, i)) return; ag.set(i), n.uniformMatrix2fv(this.addr, false, ag), _n(t, i); } } function mO(n, e) { const t = this.cache, i = e.elements; if (i === void 0) { if (Ln(t, e)) return; n.uniformMatrix3fv(this.addr, false, e), _n(t, e); } else { if (Ln(t, i)) return; og.set(i), n.uniformMatrix3fv(this.addr, false, og), _n(t, i); } } function gO(n, e) { const t = this.cache, i = e.elements; if (i === void 0) { if (Ln(t, e)) return; n.uniformMatrix4fv(this.addr, false, e), _n(t, e); } else { if (Ln(t, i)) return; sg.set(i), n.uniformMatrix4fv(this.addr, false, sg), _n(t, i); } } function vO(n, e) { const t = this.cache; t[0] !== e && (n.uniform1i(this.addr, e), t[0] = e); } function yO(n, e) { const t = this.cache; Ln(t, e) || (n.uniform2iv(this.addr, e), _n(t, e)); } function bO(n, e) { const t = this.cache; Ln(t, e) || (n.uniform3iv(this.addr, e), _n(t, e)); } function xO(n, e) { const t = this.cache; Ln(t, e) || (n.uniform4iv(this.addr, e), _n(t, e)); } function MO(n, e) { const t = this.cache; t[0] !== e && (n.uniform1ui(this.addr, e), t[0] = e); } function wO(n, e) { const t = this.cache; Ln(t, e) || (n.uniform2uiv(this.addr, e), _n(t, e)); } function AO(n, e) { const t = this.cache; Ln(t, e) || (n.uniform3uiv(this.addr, e), _n(t, e)); } function SO(n, e) { const t = this.cache; Ln(t, e) || (n.uniform4uiv(this.addr, e), _n(t, e)); } function _O(n, e, t) { const i = this.cache, r = t.allocateTextureUnit(); i[0] !== r && (n.uniform1i(this.addr, r), i[0] = r), t.safeSetTexture2D(e || fx, r); } function TO(n, e, t) { const i = this.cache, r = t.allocateTextureUnit(); i[0] !== r && (n.uniform1i(this.addr, r), i[0] = r), t.setTexture3D(e || cO, r); } function EO(n, e, t) { const i = this.cache, r = t.allocateTextureUnit(); i[0] !== r && (n.uniform1i(this.addr, r), i[0] = r), t.safeSetTextureCube(e || px, r); } function CO(n, e, t) { const i = this.cache, r = t.allocateTextureUnit(); i[0] !== r && (n.uniform1i(this.addr, r), i[0] = r), t.setTexture2DArray(e || lO, r); } function LO(n) { switch (n) { case 5126: return uO; case 35664: return hO; case 35665: return dO; case 35666: return fO; case 35674: return pO; case 35675: return mO; case 35676: return gO; case 5124: case 35670: return vO; case 35667: case 35671: return yO; case 35668: case 35672: return bO; case 35669: case 35673: return xO; case 5125: return MO; case 36294: return wO; case 36295: return AO; case 36296: return SO; case 35678: case 36198: case 36298: case 36306: case 35682: return _O; case 35679: case 36299: case 36307: return TO; case 35680: case 36300: case 36308: case 36293: return EO; case 36289: case 36303: case 36311: case 36292: return CO; } } function RO(n, e) { n.uniform1fv(this.addr, e); } function FO(n, e) { const t = na(e, this.size, 2); n.uniform2fv(this.addr, t); } function PO(n, e) { const t = na(e, this.size, 3); n.uniform3fv(this.addr, t); } function IO(n, e) { const t = na(e, this.size, 4); n.uniform4fv(this.addr, t); } function OO(n, e) { const t = na(e, this.size, 4); n.uniformMatrix2fv(this.addr, false, t); } function DO(n, e) { const t = na(e, this.size, 9); n.uniformMatrix3fv(this.addr, false, t); } function NO(n, e) { const t = na(e, this.size, 16); n.uniformMatrix4fv(this.addr, false, t); } function BO(n, e) { n.uniform1iv(this.addr, e); } function UO(n, e) { n.uniform2iv(this.addr, e); } function zO(n, e) { n.uniform3iv(this.addr, e); } function VO(n, e) { n.uniform4iv(this.addr, e); } function kO(n, e) { n.uniform1uiv(this.addr, e); } function GO(n, e) { n.uniform2uiv(this.addr, e); } function HO(n, e) { n.uniform3uiv(this.addr, e); } function WO(n, e) { n.uniform4uiv(this.addr, e); } function jO(n, e, t) { const i = e.length, r = mx(t, i); n.uniform1iv(this.addr, r); for (let s = 0; s !== i; ++s) t.safeSetTexture2D(e[s] || fx, r[s]); } function $O(n, e, t) { const i = e.length, r = mx(t, i); n.uniform1iv(this.addr, r); for (let s = 0; s !== i; ++s) t.safeSetTextureCube(e[s] || px, r[s]); } function ZO(n) { switch (n) { case 5126: return RO; case 35664: return FO; case 35665: return PO; case 35666: return IO; case 35674: return OO; case 35675: return DO; case 35676: return NO; case 5124: case 35670: return BO; case 35667: case 35671: return UO; case 35668: case 35672: return zO; case 35669: case 35673: return VO; case 5125: return kO; case 36294: return GO; case 36295: return HO; case 36296: return WO; case 35678: case 36198: case 36298: case 36306: case 35682: return jO; case 35680: case 36300: case 36308: case 36293: return $O; } } function XO(n, e, t) { this.id = n, this.addr = t, this.cache = [], this.setValue = LO(e.type); } function gx(n, e, t) { this.id = n, this.addr = t, this.cache = [], this.size = e.size, this.setValue = ZO(e.type); } gx.prototype.updateCache = function(n) { const e = this.cache; n instanceof Float32Array && e.length !== n.length && (this.cache = new Float32Array(n.length)), _n(e, n); }; function vx(n) { this.id = n, this.seq = [], this.map = {}; } vx.prototype.setValue = function(n, e, t) { const i = this.seq; for (let r = 0, s = i.length; r !== s; ++r) { const o = i[r]; o.setValue(n, e[o.id], t); } }; var mh = /(\w+)(\])?(\[|\.)?/g; function lg(n, e) { n.seq.push(e), n.map[e.id] = e; } function YO(n, e, t) { const i = n.name, r = i.length; for (mh.lastIndex = 0; ; ) { const s = mh.exec(i), o = mh.lastIndex; let a = s[1]; const c = s[2] === "]", l = s[3]; if (c && (a = a | 0), l === void 0 || l === "[" && o + 2 === r) { lg(t, l === void 0 ? new XO(a, n, e) : new gx(a, n, e)); break; } else { let h6 = t.map[a]; h6 === void 0 && (h6 = new vx(a), lg(t, h6)), t = h6; } } } function Or(n, e) { this.seq = [], this.map = {}; const t = n.getProgramParameter(e, 35718); for (let i = 0; i < t; ++i) { const r = n.getActiveUniform(e, i), s = n.getUniformLocation(e, r.name); YO(r, s, this); } } Or.prototype.setValue = function(n, e, t, i) { const r = this.map[e]; r !== void 0 && r.setValue(n, t, i); }; Or.prototype.setOptional = function(n, e, t) { const i = e[t]; i !== void 0 && this.setValue(n, t, i); }; Or.upload = function(n, e, t, i) { for (let r = 0, s = e.length; r !== s; ++r) { const o = e[r], a = t[o.id]; a.needsUpdate !== false && o.setValue(n, a.value, i); } }; Or.seqWithValue = function(n, e) { const t = []; for (let i = 0, r = n.length; i !== r; ++i) { const s = n[i]; s.id in e && t.push(s); } return t; }; function cg(n, e, t) { const i = n.createShader(e); return n.shaderSource(i, t), n.compileShader(i), i; } var JO = 0; function KO(n) { const e = n.split(` `); for (let t = 0; t < e.length; t++) e[t] = t + 1 + ": " + e[t]; return e.join(` `); } function yx(n) { switch (n) { case Cn: return ["Linear", "( value )"]; case Cs: return ["sRGB", "( value )"]; case mu: return ["RGBE", "( value )"]; case Af: return ["RGBM", "( value, 7.0 )"]; case Sf: return ["RGBM", "( value, 16.0 )"]; case _f: return ["RGBD", "( value, 256.0 )"]; case pu: return ["Gamma", "( value, float( GAMMA_FACTOR ) )"]; case Xb: return ["LogLuv", "( value )"]; default: return console.warn("THREE.WebGLProgram: Unsupported encoding:", n), ["Linear", "( value )"]; } } function ug(n, e, t) { const i = n.getShaderParameter(e, 35713), r = n.getShaderInfoLog(e).trim(); if (i && r === "") return ""; const s = n.getShaderSource(e); return "THREE.WebGLShader: gl.getShaderInfoLog() " + t + ` ` + r + KO(s); } function ma(n, e) { const t = yx(e); return "vec4 " + n + "( vec4 value ) { return " + t[0] + "ToLinear" + t[1] + "; }"; } function qO(n, e) { const t = yx(e); return "vec4 " + n + "( vec4 value ) { return LinearTo" + t[0] + t[1] + "; }"; } function QO(n, e) { let t; switch (e) { case $y: t = "Linear"; break; case Zy: t = "Reinhard"; break; case Xy: t = "OptimizedCineon"; break; case Yy: t = "ACESFilmic"; break; case Jy: t = "Custom"; break; default: console.warn("THREE.WebGLProgram: Unsupported toneMapping:", e), t = "Linear"; } return "vec3 " + n + "( vec3 color ) { return " + t + "ToneMapping( color ); }"; } function eD(n) { return [ n.extensionDerivatives || n.envMapCubeUV || n.bumpMap || n.tangentSpaceNormalMap || n.clearcoatNormalMap || n.flatShading || n.shaderID === "physical" ? "#extension GL_OES_standard_derivatives : enable" : "", (n.extensionFragDepth || n.logarithmicDepthBuffer) && n.rendererExtensionFragDepth ? "#extension GL_EXT_frag_depth : enable" : "", n.extensionDrawBuffers && n.rendererExtensionDrawBuffers ? "#extension GL_EXT_draw_buffers : require" : "", (n.extensionShaderTextureLOD || n.envMap || n.transmission > 0) && n.rendererExtensionShaderTextureLod ? "#extension GL_EXT_shader_texture_lod : enable" : "" ].filter(Ta).join(` `); } function tD(n) { const e = []; for (const t in n) { const i = n[t]; i !== false && e.push("#define " + t + " " + i); } return e.join(` `); } function nD(n, e) { const t = {}, i = n.getProgramParameter(e, 35721); for (let r = 0; r < i; r++) { const o = n.getActiveAttrib(e, r).name; t[o] = n.getAttribLocation(e, o); } return t; } function Ta(n) { return n !== ""; } function hg(n, e) { return n.replace(/NUM_DIR_LIGHTS/g, e.numDirLights).replace(/NUM_SPOT_LIGHTS/g, e.numSpotLights).replace(/NUM_RECT_AREA_LIGHTS/g, e.numRectAreaLights).replace(/NUM_POINT_LIGHTS/g, e.numPointLights).replace(/NUM_HEMI_LIGHTS/g, e.numHemiLights).replace(/NUM_DIR_LIGHT_SHADOWS/g, e.numDirLightShadows).replace(/NUM_SPOT_LIGHT_SHADOWS/g, e.numSpotLightShadows).replace(/NUM_POINT_LIGHT_SHADOWS/g, e.numPointLightShadows); } function dg(n, e) { return n.replace(/NUM_CLIPPING_PLANES/g, e.numClippingPlanes).replace(/UNION_CLIPPING_PLANES/g, e.numClippingPlanes - e.numClipIntersection); } var iD = /^[ \t]*#include +<([\w\d./]+)>/gm; function Md(n) { return n.replace(iD, rD); } function rD(n, e) { const t = dt[e]; if (t === void 0) throw new Error("Can not resolve #include <" + e + ">"); return Md(t); } var sD = /#pragma unroll_loop[\s]+?for \( int i \= (\d+)\; i < (\d+)\; i \+\+ \) \{([\s\S]+?)(?=\})\}/g; var oD = /#pragma unroll_loop_start\s+for\s*\(\s*int\s+i\s*=\s*(\d+)\s*;\s*i\s*<\s*(\d+)\s*;\s*i\s*\+\+\s*\)\s*{([\s\S]+?)}\s+#pragma unroll_loop_end/g; function fg(n) { return n.replace(oD, bx).replace(sD, aD); } function aD(n, e, t, i) { return console.warn("WebGLProgram: #pragma unroll_loop shader syntax is deprecated. Please use #pragma unroll_loop_start syntax instead."), bx(n, e, t, i); } function bx(n, e, t, i) { let r = ""; for (let s = parseInt(e); s < parseInt(t); s++) r += i.replace(/\[\s*i\s*\]/g, "[ " + s + " ]").replace(/UNROLLED_LOOP_INDEX/g, s); return r; } function pg(n) { let e = "precision " + n.precision + ` float; precision ` + n.precision + " int;"; return n.precision === "highp" ? e += ` #define HIGH_PRECISION` : n.precision === "mediump" ? e += ` #define MEDIUM_PRECISION` : n.precision === "lowp" && (e += ` #define LOW_PRECISION`), e; } function lD(n) { let e = "SHADOWMAP_TYPE_BASIC"; return n.shadowMapType === vf ? e = "SHADOWMAP_TYPE_PCF" : n.shadowMapType === Sy ? e = "SHADOWMAP_TYPE_PCF_SOFT" : n.shadowMapType === po && (e = "SHADOWMAP_TYPE_VSM"), e; } function cD(n) { let e = "ENVMAP_TYPE_CUBE"; if (n.envMap) switch (n.envMapMode) { case ll: case cl: e = "ENVMAP_TYPE_CUBE"; break; case ea: case ul: e = "ENVMAP_TYPE_CUBE_UV"; break; } return e; } function uD(n) { let e = "ENVMAP_MODE_REFLECTION"; if (n.envMap) switch (n.envMapMode) { case cl: case ul: e = "ENVMAP_MODE_REFRACTION"; break; } return e; } function hD(n) { let e = "ENVMAP_BLENDING_NONE"; if (n.envMap) switch (n.combine) { case al: e = "ENVMAP_BLENDING_MULTIPLY"; break; case Wy: e = "ENVMAP_BLENDING_MIX"; break; case jy: e = "ENVMAP_BLENDING_ADD"; break; } return e; } function dD(n, e, t, i) { const r = n.getContext(), s = t.defines; let o = t.vertexShader, a = t.fragmentShader; const c = lD(t), l = cD(t), d = uD(t), h6 = hD(t), f = n.gammaFactor > 0 ? n.gammaFactor : 1, g = t.isWebGL2 ? "" : eD(t), p = tD(s), u = r.createProgram(); let y, v, m = t.glslVersion ? "#version " + t.glslVersion + ` ` : ""; t.isRawShaderMaterial ? (y = [ p ].filter(Ta).join(` `), y.length > 0 && (y += ` `), v = [ g, p ].filter(Ta).join(` `), v.length > 0 && (v += ` `)) : (y = [ pg(t), "#define SHADER_NAME " + t.shaderName, p, t.instancing ? "#define USE_INSTANCING" : "", t.instancingColor ? "#define USE_INSTANCING_COLOR" : "", t.supportsVertexTextures ? "#define VERTEX_TEXTURES" : "", "#define GAMMA_FACTOR " + f, "#define MAX_BONES " + t.maxBones, t.useFog && t.fog ? "#define USE_FOG" : "", t.useFog && t.fogExp2 ? "#define FOG_EXP2" : "", t.map ? "#define USE_MAP" : "", t.envMap ? "#define USE_ENVMAP" : "", t.envMap ? "#define " + d : "", t.lightMap ? "#define USE_LIGHTMAP" : "", t.aoMap ? "#define USE_AOMAP" : "", t.emissiveMap ? "#define USE_EMISSIVEMAP" : "", t.bumpMap ? "#define USE_BUMPMAP" : "", t.normalMap ? "#define USE_NORMALMAP" : "", t.normalMap && t.objectSpaceNormalMap ? "#define OBJECTSPACE_NORMALMAP" : "", t.normalMap && t.tangentSpaceNormalMap ? "#define TANGENTSPACE_NORMALMAP" : "", t.clearcoatMap ? "#define USE_CLEARCOATMAP" : "", t.clearcoatRoughnessMap ? "#define USE_CLEARCOAT_ROUGHNESSMAP" : "", t.clearcoatNormalMap ? "#define USE_CLEARCOAT_NORMALMAP" : "", t.displacementMap && t.supportsVertexTextures ? "#define USE_DISPLACEMENTMAP" : "", t.specularMap ? "#define USE_SPECULARMAP" : "", t.roughnessMap ? "#define USE_ROUGHNESSMAP" : "", t.metalnessMap ? "#define USE_METALNESSMAP" : "", t.alphaMap ? "#define USE_ALPHAMAP" : "", t.transmission ? "#define USE_TRANSMISSION" : "", t.transmissionMap ? "#define USE_TRANSMISSIONMAP" : "", t.thicknessMap ? "#define USE_THICKNESSMAP" : "", t.vertexTangents ? "#define USE_TANGENT" : "", t.vertexColors ? "#define USE_COLOR" : "", t.vertexAlphas ? "#define USE_COLOR_ALPHA" : "", t.vertexUvs ? "#define USE_UV" : "", t.uvsVertexOnly ? "#define UVS_VERTEX_ONLY" : "", t.flatShading ? "#define FLAT_SHADED" : "", t.skinning ? "#define USE_SKINNING" : "", t.useVertexTexture ? "#define BONE_TEXTURE" : "", t.morphTargets ? "#define USE_MORPHTARGETS" : "", t.morphNormals && t.flatShading === false ? "#define USE_MORPHNORMALS" : "", t.doubleSided ? "#define DOUBLE_SIDED" : "", t.flipSided ? "#define FLIP_SIDED" : "", t.shadowMapEnabled ? "#define USE_SHADOWMAP" : "", t.shadowMapEnabled ? "#define " + c : "", t.sizeAttenuation ? "#define USE_SIZEATTENUATION" : "", t.logarithmicDepthBuffer ? "#define USE_LOGDEPTHBUF" : "", t.logarithmicDepthBuffer && t.rendererExtensionFragDepth ? "#define USE_LOGDEPTHBUF_EXT" : "", "uniform mat4 modelMatrix;", "uniform mat4 modelViewMatrix;", "uniform mat4 projectionMatrix;", "uniform mat4 viewMatrix;", "uniform mat3 normalMatrix;", "uniform vec3 cameraPosition;", "uniform bool isOrthographic;", "#ifdef USE_INSTANCING", " attribute mat4 instanceMatrix;", "#endif", "#ifdef USE_INSTANCING_COLOR", " attribute vec3 instanceColor;", "#endif", "attribute vec3 position;", "attribute vec3 normal;", "attribute vec2 uv;", "#ifdef USE_TANGENT", " attribute vec4 tangent;", "#endif", "#if defined( USE_COLOR_ALPHA )", " attribute vec4 color;", "#elif defined( USE_COLOR )", " attribute vec3 color;", "#endif", "#ifdef USE_MORPHTARGETS", " attribute vec3 morphTarget0;", " attribute vec3 morphTarget1;", " attribute vec3 morphTarget2;", " attribute vec3 morphTarget3;", " #ifdef USE_MORPHNORMALS", " attribute vec3 morphNormal0;", " attribute vec3 morphNormal1;", " attribute vec3 morphNormal2;", " attribute vec3 morphNormal3;", " #else", " attribute vec3 morphTarget4;", " attribute vec3 morphTarget5;", " attribute vec3 morphTarget6;", " attribute vec3 morphTarget7;", " #endif", "#endif", "#ifdef USE_SKINNING", " attribute vec4 skinIndex;", " attribute vec4 skinWeight;", "#endif", ` ` ].filter(Ta).join(` `), v = [ g, pg(t), "#define SHADER_NAME " + t.shaderName, p, t.alphaTest ? "#define ALPHATEST " + t.alphaTest + (t.alphaTest % 1 ? "" : ".0") : "", // add '.0' if integer "#define GAMMA_FACTOR " + f, t.useFog && t.fog ? "#define USE_FOG" : "", t.useFog && t.fogExp2 ? "#define FOG_EXP2" : "", t.map ? "#define USE_MAP" : "", t.matcap ? "#define USE_MATCAP" : "", t.envMap ? "#define USE_ENVMAP" : "", t.envMap ? "#define " + l : "", t.envMap ? "#define " + d : "", t.envMap ? "#define " + h6 : "", t.lightMap ? "#define USE_LIGHTMAP" : "", t.aoMap ? "#define USE_AOMAP" : "", t.emissiveMap ? "#define USE_EMISSIVEMAP" : "", t.bumpMap ? "#define USE_BUMPMAP" : "", t.normalMap ? "#define USE_NORMALMAP" : "", t.normalMap && t.objectSpaceNormalMap ? "#define OBJECTSPACE_NORMALMAP" : "", t.normalMap && t.tangentSpaceNormalMap ? "#define TANGENTSPACE_NORMALMAP" : "", t.clearcoatMap ? "#define USE_CLEARCOATMAP" : "", t.clearcoatRoughnessMap ? "#define USE_CLEARCOAT_ROUGHNESSMAP" : "", t.clearcoatNormalMap ? "#define USE_CLEARCOAT_NORMALMAP" : "", t.specularMap ? "#define USE_SPECULARMAP" : "", t.roughnessMap ? "#define USE_ROUGHNESSMAP" : "", t.metalnessMap ? "#define USE_METALNESSMAP" : "", t.alphaMap ? "#define USE_ALPHAMAP" : "", t.sheen ? "#define USE_SHEEN" : "", t.transmission ? "#define USE_TRANSMISSION" : "", t.transmissionMap ? "#define USE_TRANSMISSIONMAP" : "", t.thicknessMap ? "#define USE_THICKNESSMAP" : "", t.vertexTangents ? "#define USE_TANGENT" : "", t.vertexColors || t.instancingColor ? "#define USE_COLOR" : "", t.vertexAlphas ? "#define USE_COLOR_ALPHA" : "", t.vertexUvs ? "#define USE_UV" : "", t.uvsVertexOnly ? "#define UVS_VERTEX_ONLY" : "", t.gradientMap ? "#define USE_GRADIENTMAP" : "", t.flatShading ? "#define FLAT_SHADED" : "", t.doubleSided ? "#define DOUBLE_SIDED" : "", t.flipSided ? "#define FLIP_SIDED" : "", t.shadowMapEnabled ? "#define USE_SHADOWMAP" : "", t.shadowMapEnabled ? "#define " + c : "", t.premultipliedAlpha ? "#define PREMULTIPLIED_ALPHA" : "", t.physicallyCorrectLights ? "#define PHYSICALLY_CORRECT_LIGHTS" : "", t.logarithmicDepthBuffer ? "#define USE_LOGDEPTHBUF" : "", t.logarithmicDepthBuffer && t.rendererExtensionFragDepth ? "#define USE_LOGDEPTHBUF_EXT" : "", (t.extensionShaderTextureLOD || t.envMap) && t.rendererExtensionShaderTextureLod ? "#define TEXTURE_LOD_EXT" : "", "uniform mat4 viewMatrix;", "uniform vec3 cameraPosition;", "uniform bool isOrthographic;", t.toneMapping !== Ir ? "#define TONE_MAPPING" : "", t.toneMapping !== Ir ? dt.tonemapping_pars_fragment : "", // this code is required here because it is used by the toneMapping() function defined below t.toneMapping !== Ir ? QO("toneMapping", t.toneMapping) : "", t.dithering ? "#define DITHERING" : "", dt.encodings_pars_fragment, // this code is required here because it is used by the various encoding/decoding function defined below t.map ? ma("mapTexelToLinear", t.mapEncoding) : "", t.matcap ? ma("matcapTexelToLinear", t.matcapEncoding) : "", t.envMap ? ma("envMapTexelToLinear", t.envMapEncoding) : "", t.emissiveMap ? ma("emissiveMapTexelToLinear", t.emissiveMapEncoding) : "", t.lightMap ? ma("lightMapTexelToLinear", t.lightMapEncoding) : "", qO("linearToOutputTexel", t.outputEncoding), t.depthPacking ? "#define DEPTH_PACKING " + t.depthPacking : "", ` ` ].filter(Ta).join(` `)), o = Md(o), o = hg(o, t), o = dg(o, t), a = Md(a), a = hg(a, t), a = dg(a, t), o = fg(o), a = fg(a), t.isWebGL2 && t.isRawShaderMaterial !== true && (m = `#version 300 es `, y = [ "#define attribute in", "#define varying out", "#define texture2D texture" ].join(` `) + ` ` + y, v = [ "#define varying in", t.glslVersion === yd ? "" : "out highp vec4 pc_fragColor;", t.glslVersion === yd ? "" : "#define gl_FragColor pc_fragColor", "#define gl_FragDepthEXT gl_FragDepth", "#define texture2D texture", "#define textureCube texture", "#define texture2DProj textureProj", "#define texture2DLodEXT textureLod", "#define texture2DProjLodEXT textureProjLod", "#define textureCubeLodEXT textureLod", "#define texture2DGradEXT textureGrad", "#define texture2DProjGradEXT textureProjGrad", "#define textureCubeGradEXT textureGrad" ].join(` `) + ` ` + v); const x = m + y + o, w = m + v + a, A = cg(r, 35633, x), M = cg(r, 35632, w); if (r.attachShader(u, A), r.attachShader(u, M), t.index0AttributeName !== void 0 ? r.bindAttribLocation(u, 0, t.index0AttributeName) : t.morphTargets === true && r.bindAttribLocation(u, 0, "position"), r.linkProgram(u), n.debug.checkShaderErrors) { const S = r.getProgramInfoLog(u).trim(), I = r.getShaderInfoLog(A).trim(), T = r.getShaderInfoLog(M).trim(); let _ = true, E = true; if (r.getProgramParameter(u, 35714) === false) { _ = false; const C = ug(r, A, "vertex"), P = ug(r, M, "fragment"); console.error("THREE.WebGLProgram: shader error: ", r.getError(), "35715", r.getProgramParameter(u, 35715), "gl.getProgramInfoLog", S, C, P); } else S !== "" ? console.warn("THREE.WebGLProgram: gl.getProgramInfoLog()", S) : (I === "" || T === "") && (E = false); E && (this.diagnostics = { runnable: _, programLog: S, vertexShader: { log: I, prefix: y }, fragmentShader: { log: T, prefix: v } }); } r.deleteShader(A), r.deleteShader(M); let R; this.getUniforms = function() { return R === void 0 && (R = new Or(r, u)), R; }; let L; return this.getAttributes = function() { return L === void 0 && (L = nD(r, u)), L; }, this.destroy = function() { i.releaseStatesOfProgram(this), r.deleteProgram(u), this.program = void 0; }, this.name = t.shaderName, this.id = JO++, this.cacheKey = e, this.usedTimes = 1, this.program = u, this.vertexShader = A, this.fragmentShader = M, this; } function fD(n, e, t, i, r, s) { const o = [], a = i.isWebGL2, c = i.logarithmicDepthBuffer, l = i.floatVertexTextures, d = i.maxVertexUniforms, h6 = i.vertexTextures; let f = i.precision; const g = { MeshDepthMaterial: "depth", MeshDistanceMaterial: "distanceRGBA", MeshNormalMaterial: "normal", MeshBasicMaterial: "basic", MeshLambertMaterial: "lambert", MeshPhongMaterial: "phong", MeshToonMaterial: "toon", MeshStandardMaterial: "physical", MeshPhysicalMaterial: "physical", MeshMatcapMaterial: "matcap", LineBasicMaterial: "basic", LineDashedMaterial: "dashed", PointsMaterial: "points", ShadowMaterial: "shadow", SpriteMaterial: "sprite" }, p = [ "precision", "isWebGL2", "supportsVertexTextures", "outputEncoding", "instancing", "instancingColor", "map", "mapEncoding", "matcap", "matcapEncoding", "envMap", "envMapMode", "envMapEncoding", "envMapCubeUV", "lightMap", "lightMapEncoding", "aoMap", "emissiveMap", "emissiveMapEncoding", "bumpMap", "normalMap", "objectSpaceNormalMap", "tangentSpaceNormalMap", "clearcoatMap", "clearcoatRoughnessMap", "clearcoatNormalMap", "displacementMap", "specularMap", "roughnessMap", "metalnessMap", "gradientMap", "alphaMap", "combine", "vertexColors", "vertexAlphas", "vertexTangents", "vertexUvs", "uvsVertexOnly", "fog", "useFog", "fogExp2", "flatShading", "sizeAttenuation", "logarithmicDepthBuffer", "skinning", "maxBones", "useVertexTexture", "morphTargets", "morphNormals", "premultipliedAlpha", "numDirLights", "numPointLights", "numSpotLights", "numHemiLights", "numRectAreaLights", "numDirLightShadows", "numPointLightShadows", "numSpotLightShadows", "shadowMapEnabled", "shadowMapType", "toneMapping", "physicallyCorrectLights", "alphaTest", "doubleSided", "flipSided", "numClippingPlanes", "numClipIntersection", "depthPacking", "dithering", "sheen", "transmission", "transmissionMap", "thicknessMap" ]; function u(M) { const L = M.skeleton.bones; if (l) return 1024; { const I = Math.floor((d - 20) / 4), T = Math.min(I, L.length); return T < L.length ? (console.warn("THREE.WebGLRenderer: Skeleton has " + L.length + " bones. This GPU supports " + T + "."), 0) : T; } } function y(M) { let R; return M && M.isTexture ? R = M.encoding : M && M.isWebGLRenderTarget ? (console.warn("THREE.WebGLPrograms.getTextureEncodingFromMap: don't use render targets as textures. Use their .texture property instead."), R = M.texture.encoding) : R = Cn, R; } function v(M, R, L, S, I) { const T = S.fog, _ = M.isMeshStandardMaterial ? S.environment : null, E = e.get(M.envMap || _), C = g[M.type], P = I.isSkinnedMesh ? u(I) : 0; M.precision !== null && (f = i.getMaxPrecision(M.precision), f !== M.precision && console.warn("THREE.WebGLProgram.getParameters:", M.precision, "not supported, using", f, "instead.")); let b, F; if (C) { const B = ci[C]; b = B.vertexShader, F = B.fragmentShader; } else b = M.vertexShader, F = M.fragmentShader; const D = n.getRenderTarget(); return { isWebGL2: a, shaderID: C, shaderName: M.type, vertexShader: b, fragmentShader: F, defines: M.defines, isRawShaderMaterial: M.isRawShaderMaterial === true, glslVersion: M.glslVersion, precision: f, instancing: I.isInstancedMesh === true, instancingColor: I.isInstancedMesh === true && I.instanceColor !== null, supportsVertexTextures: h6, outputEncoding: D !== null ? y(D.texture) : n.outputEncoding, map: !!M.map, mapEncoding: y(M.map), matcap: !!M.matcap, matcapEncoding: y(M.matcap), envMap: !!E, envMapMode: E && E.mapping, envMapEncoding: y(E), envMapCubeUV: !!E && (E.mapping === ea || E.mapping === ul), lightMap: !!M.lightMap, lightMapEncoding: y(M.lightMap), aoMap: !!M.aoMap, emissiveMap: !!M.emissiveMap, emissiveMapEncoding: y(M.emissiveMap), bumpMap: !!M.bumpMap, normalMap: !!M.normalMap, objectSpaceNormalMap: M.normalMapType === Kb, tangentSpaceNormalMap: M.normalMapType === Jr, clearcoatMap: !!M.clearcoatMap, clearcoatRoughnessMap: !!M.clearcoatRoughnessMap, clearcoatNormalMap: !!M.clearcoatNormalMap, displacementMap: !!M.displacementMap, roughnessMap: !!M.roughnessMap, metalnessMap: !!M.metalnessMap, specularMap: !!M.specularMap, alphaMap: !!M.alphaMap, gradientMap: !!M.gradientMap, sheen: !!M.sheen, transmission: !!M.transmission, transmissionMap: !!M.transmissionMap, thicknessMap: !!M.thicknessMap, combine: M.combine, vertexTangents: M.normalMap && M.vertexTangents, vertexColors: M.vertexColors, vertexAlphas: M.vertexColors === true && I.geometry && I.geometry.attributes.color && I.geometry.attributes.color.itemSize === 4, vertexUvs: !!M.map || !!M.bumpMap || !!M.normalMap || !!M.specularMap || !!M.alphaMap || !!M.emissiveMap || !!M.roughnessMap || !!M.metalnessMap || !!M.clearcoatMap || !!M.clearcoatRoughnessMap || !!M.clearcoatNormalMap || !!M.displacementMap || !!M.transmissionMap || !!M.thicknessMap, uvsVertexOnly: !(M.map || M.bumpMap || M.normalMap || M.specularMap || M.alphaMap || M.emissiveMap || M.roughnessMap || M.metalnessMap || M.clearcoatNormalMap || M.transmission || M.transmissionMap || M.thicknessMap) && !!M.displacementMap, fog: !!T, useFog: M.fog, fogExp2: T && T.isFogExp2, flatShading: !!M.flatShading, sizeAttenuation: M.sizeAttenuation, logarithmicDepthBuffer: c, skinning: I.isSkinnedMesh === true && P > 0, maxBones: P, useVertexTexture: l, morphTargets: M.morphTargets, morphNormals: M.morphNormals, numDirLights: R.directional.length, numPointLights: R.point.length, numSpotLights: R.spot.length, numRectAreaLights: R.rectArea.length, numHemiLights: R.hemi.length, numDirLightShadows: R.directionalShadowMap.length, numPointLightShadows: R.pointShadowMap.length, numSpotLightShadows: R.spotShadowMap.length, numClippingPlanes: s.numPlanes, numClipIntersection: s.numIntersection, dithering: M.dithering, shadowMapEnabled: n.shadowMap.enabled && L.length > 0, shadowMapType: n.shadowMap.type, toneMapping: M.toneMapped ? n.toneMapping : Ir, physicallyCorrectLights: n.physicallyCorrectLights, premultipliedAlpha: M.premultipliedAlpha, alphaTest: M.alphaTest, doubleSided: M.side === Wr, flipSided: M.side === jt, depthPacking: M.depthPacking !== void 0 ? M.depthPacking : false, index0AttributeName: M.index0AttributeName, extensionDerivatives: M.extensions && M.extensions.derivatives, extensionFragDepth: M.extensions && M.extensions.fragDepth, extensionDrawBuffers: M.extensions && M.extensions.drawBuffers, extensionShaderTextureLOD: M.extensions && M.extensions.shaderTextureLOD, rendererExtensionFragDepth: a || t.has("EXT_frag_depth"), rendererExtensionDrawBuffers: a || t.has("WEBGL_draw_buffers"), rendererExtensionShaderTextureLod: a || t.has("EXT_shader_texture_lod"), customProgramCacheKey: M.customProgramCacheKey() }; } function m(M) { const R = []; if (M.shaderID ? R.push(M.shaderID) : (R.push(M.fragmentShader), R.push(M.vertexShader)), M.defines !== void 0) for (const L in M.defines) R.push(L), R.push(M.defines[L]); if (M.isRawShaderMaterial === false) { for (let L = 0; L < p.length; L++) R.push(M[p[L]]); R.push(n.outputEncoding), R.push(n.gammaFactor); } return R.push(M.customProgramCacheKey), R.join(); } function x(M) { const R = g[M.type]; let L; if (R) { const S = ci[R]; L = hx.clone(S.uniforms); } else L = M.uniforms; return L; } function w(M, R) { let L; for (let S = 0, I = o.length; S < I; S++) { const T = o[S]; if (T.cacheKey === R) { L = T, ++L.usedTimes; break; } } return L === void 0 && (L = new dD(n, R, M, r), o.push(L)), L; } function A(M) { if (--M.usedTimes === 0) { const R = o.indexOf(M); o[R] = o[o.length - 1], o.pop(), M.destroy(); } } return { getParameters: v, getProgramCacheKey: m, getUniforms: x, acquireProgram: w, releaseProgram: A, // Exposed for resource monitoring & error feedback via renderer.info: programs: o }; } function pD() { let n = /* @__PURE__ */ new WeakMap(); function e(s) { let o = n.get(s); return o === void 0 && (o = {}, n.set(s, o)), o; } function t(s) { n.delete(s); } function i(s, o, a) { n.get(s)[o] = a; } function r() { n = /* @__PURE__ */ new WeakMap(); } return { get: e, remove: t, update: i, dispose: r }; } function mD(n, e) { return n.groupOrder !== e.groupOrder ? n.groupOrder - e.groupOrder : n.renderOrder !== e.renderOrder ? n.renderOrder - e.renderOrder : n.program !== e.program ? n.program.id - e.program.id : n.material.id !== e.material.id ? n.material.id - e.material.id : n.z !== e.z ? n.z - e.z : n.id - e.id; } function mg(n, e) { return n.groupOrder !== e.groupOrder ? n.groupOrder - e.groupOrder : n.renderOrder !== e.renderOrder ? n.renderOrder - e.renderOrder : n.z !== e.z ? e.z - n.z : n.id - e.id; } function gg(n) { const e = []; let t = 0; const i = [], r = [], s = [], o = { id: -1 }; function a() { t = 0, i.length = 0, r.length = 0, s.length = 0; } function c(g, p, u, y, v, m) { let x = e[t]; const w = n.get(u); return x === void 0 ? (x = { id: g.id, object: g, geometry: p, material: u, program: w.program || o, groupOrder: y, renderOrder: g.renderOrder, z: v, group: m }, e[t] = x) : (x.id = g.id, x.object = g, x.geometry = p, x.material = u, x.program = w.program || o, x.groupOrder = y, x.renderOrder = g.renderOrder, x.z = v, x.group = m), t++, x; } function l(g, p, u, y, v, m) { const x = c(g, p, u, y, v, m); u.transmission > 0 ? r.push(x) : u.transparent === true ? s.push(x) : i.push(x); } function d(g, p, u, y, v, m) { const x = c(g, p, u, y, v, m); u.transmission > 0 ? r.unshift(x) : u.transparent === true ? s.unshift(x) : i.unshift(x); } function h6(g, p) { i.length > 1 && i.sort(g || mD), r.length > 1 && r.sort(p || mg), s.length > 1 && s.sort(p || mg); } function f() { for (let g = t, p = e.length; g < p; g++) { const u = e[g]; if (u.id === null) break; u.id = null, u.object = null, u.geometry = null, u.material = null, u.program = null, u.group = null; } } return { opaque: i, transmissive: r, transparent: s, init: a, push: l, unshift: d, finish: f, sort: h6 }; } function gD(n) { let e = /* @__PURE__ */ new WeakMap(); function t(r, s) { let o; return e.has(r) === false ? (o = new gg(n), e.set(r, [o])) : s >= e.get(r).length ? (o = new gg(n), e.get(r).push(o)) : o = e.get(r)[s], o; } function i() { e = /* @__PURE__ */ new WeakMap(); } return { get: t, dispose: i }; } function vD() { const n = {}; return { get: function(e) { if (n[e.id] !== void 0) return n[e.id]; let t; switch (e.type) { case "DirectionalLight": t = { direction: new q(), color: new Ue() }; break; case "SpotLight": t = { position: new q(), direction: new q(), color: new Ue(), distance: 0, coneCos: 0, penumbraCos: 0, decay: 0 }; break; case "PointLight": t = { position: new q(), color: new Ue(), distance: 0, decay: 0 }; break; case "HemisphereLight": t = { direction: new q(), skyColor: new Ue(), groundColor: new Ue() }; break; case "RectAreaLight": t = { color: new Ue(), position: new q(), halfWidth: new q(), halfHeight: new q() }; break; } return n[e.id] = t, t; } }; } function yD() { const n = {}; return { get: function(e) { if (n[e.id] !== void 0) return n[e.id]; let t; switch (e.type) { case "DirectionalLight": t = { shadowBias: 0, shadowNormalBias: 0, shadowRadius: 1, shadowMapSize: new Re() }; break; case "SpotLight": t = { shadowBias: 0, shadowNormalBias: 0, shadowRadius: 1, shadowMapSize: new Re() }; break; case "PointLight": t = { shadowBias: 0, shadowNormalBias: 0, shadowRadius: 1, shadowMapSize: new Re(), shadowCameraNear: 1, shadowCameraFar: 1e3 }; break; } return n[e.id] = t, t; } }; } var bD = 0; function xD(n, e) { return (e.castShadow ? 1 : 0) - (n.castShadow ? 1 : 0); } function MD(n, e) { const t = new vD(), i = yD(), r = { version: 0, hash: { directionalLength: -1, pointLength: -1, spotLength: -1, rectAreaLength: -1, hemiLength: -1, numDirectionalShadows: -1, numPointShadows: -1, numSpotShadows: -1 }, ambient: [0, 0, 0], probe: [], directional: [], directionalShadow: [], directionalShadowMap: [], directionalShadowMatrix: [], spot: [], spotShadow: [], spotShadowMap: [], spotShadowMatrix: [], rectArea: [], rectAreaLTC1: null, rectAreaLTC2: null, point: [], pointShadow: [], pointShadowMap: [], pointShadowMatrix: [], hemi: [] }; for (let d = 0; d < 9; d++) r.probe.push(new q()); const s = new q(), o = new Xe(), a = new Xe(); function c(d) { let h6 = 0, f = 0, g = 0; for (let R = 0; R < 9; R++) r.probe[R].set(0, 0, 0); let p = 0, u = 0, y = 0, v = 0, m = 0, x = 0, w = 0, A = 0; d.sort(xD); for (let R = 0, L = d.length; R < L; R++) { const S = d[R], I = S.color, T = S.intensity, _ = S.distance, E = S.shadow && S.shadow.map ? S.shadow.map.texture : null; if (S.isAmbientLight) h6 += I.r * T, f += I.g * T, g += I.b * T; else if (S.isLightProbe) for (let C = 0; C < 9; C++) r.probe[C].addScaledVector(S.sh.coefficients[C], T); else if (S.isDirectionalLight) { const C = t.get(S); if (C.color.copy(S.color).multiplyScalar(S.intensity), S.castShadow) { const P = S.shadow, b = i.get(S); b.shadowBias = P.bias, b.shadowNormalBias = P.normalBias, b.shadowRadius = P.radius, b.shadowMapSize = P.mapSize, r.directionalShadow[p] = b, r.directionalShadowMap[p] = E, r.directionalShadowMatrix[p] = S.shadow.matrix, x++; } r.directional[p] = C, p++; } else if (S.isSpotLight) { const C = t.get(S); if (C.position.setFromMatrixPosition(S.matrixWorld), C.color.copy(I).multiplyScalar(T), C.distance = _, C.coneCos = Math.cos(S.angle), C.penumbraCos = Math.cos(S.angle * (1 - S.penumbra)), C.decay = S.decay, S.castShadow) { const P = S.shadow, b = i.get(S); b.shadowBias = P.bias, b.shadowNormalBias = P.normalBias, b.shadowRadius = P.radius, b.shadowMapSize = P.mapSize, r.spotShadow[y] = b, r.spotShadowMap[y] = E, r.spotShadowMatrix[y] = S.shadow.matrix, A++; } r.spot[y] = C, y++; } else if (S.isRectAreaLight) { const C = t.get(S); C.color.copy(I).multiplyScalar(T), C.halfWidth.set(S.width * 0.5, 0, 0), C.halfHeight.set(0, S.height * 0.5, 0), r.rectArea[v] = C, v++; } else if (S.isPointLight) { const C = t.get(S); if (C.color.copy(S.color).multiplyScalar(S.intensity), C.distance = S.distance, C.decay = S.decay, S.castShadow) { const P = S.shadow, b = i.get(S); b.shadowBias = P.bias, b.shadowNormalBias = P.normalBias, b.shadowRadius = P.radius, b.shadowMapSize = P.mapSize, b.shadowCameraNear = P.camera.near, b.shadowCameraFar = P.camera.far, r.pointShadow[u] = b, r.pointShadowMap[u] = E, r.pointShadowMatrix[u] = S.shadow.matrix, w++; } r.point[u] = C, u++; } else if (S.isHemisphereLight) { const C = t.get(S); C.skyColor.copy(S.color).multiplyScalar(T), C.groundColor.copy(S.groundColor).multiplyScalar(T), r.hemi[m] = C, m++; } } v > 0 && (e.isWebGL2 || n.has("OES_texture_float_linear") === true ? (r.rectAreaLTC1 = ze.LTC_FLOAT_1, r.rectAreaLTC2 = ze.LTC_FLOAT_2) : n.has("OES_texture_half_float_linear") === true ? (r.rectAreaLTC1 = ze.LTC_HALF_1, r.rectAreaLTC2 = ze.LTC_HALF_2) : console.error("THREE.WebGLRenderer: Unable to use RectAreaLight. Missing WebGL extensions.")), r.ambient[0] = h6, r.ambient[1] = f, r.ambient[2] = g; const M = r.hash; (M.directionalLength !== p || M.pointLength !== u || M.spotLength !== y || M.rectAreaLength !== v || M.hemiLength !== m || M.numDirectionalShadows !== x || M.numPointShadows !== w || M.numSpotShadows !== A) && (r.directional.length = p, r.spot.length = y, r.rectArea.length = v, r.point.length = u, r.hemi.length = m, r.directionalShadow.length = x, r.directionalShadowMap.length = x, r.pointShadow.length = w, r.pointShadowMap.length = w, r.spotShadow.length = A, r.spotShadowMap.length = A, r.directionalShadowMatrix.length = x, r.pointShadowMatrix.length = w, r.spotShadowMatrix.length = A, M.directionalLength = p, M.pointLength = u, M.spotLength = y, M.rectAreaLength = v, M.hemiLength = m, M.numDirectionalShadows = x, M.numPointShadows = w, M.numSpotShadows = A, r.version = bD++); } function l(d, h6) { let f = 0, g = 0, p = 0, u = 0, y = 0; const v = h6.matrixWorldInverse; for (let m = 0, x = d.length; m < x; m++) { const w = d[m]; if (w.isDirectionalLight) { const A = r.directional[f]; A.direction.setFromMatrixPosition(w.matrixWorld), s.setFromMatrixPosition(w.target.matrixWorld), A.direction.sub(s), A.direction.transformDirection(v), f++; } else if (w.isSpotLight) { const A = r.spot[p]; A.position.setFromMatrixPosition(w.matrixWorld), A.position.applyMatrix4(v), A.direction.setFromMatrixPosition(w.matrixWorld), s.setFromMatrixPosition(w.target.matrixWorld), A.direction.sub(s), A.direction.transformDirection(v), p++; } else if (w.isRectAreaLight) { const A = r.rectArea[u]; A.position.setFromMatrixPosition(w.matrixWorld), A.position.applyMatrix4(v), a.identity(), o.copy(w.matrixWorld), o.premultiply(v), a.extractRotation(o), A.halfWidth.set(w.width * 0.5, 0, 0), A.halfHeight.set(0, w.height * 0.5, 0), A.halfWidth.applyMatrix4(a), A.halfHeight.applyMatrix4(a), u++; } else if (w.isPointLight) { const A = r.point[g]; A.position.setFromMatrixPosition(w.matrixWorld), A.position.applyMatrix4(v), g++; } else if (w.isHemisphereLight) { const A = r.hemi[y]; A.direction.setFromMatrixPosition(w.matrixWorld), A.direction.transformDirection(v), A.direction.normalize(), y++; } } } return { setup: c, setupView: l, state: r }; } function vg(n, e) { const t = new MD(n, e), i = [], r = []; function s() { i.length = 0, r.length = 0; } function o(h6) { i.push(h6); } function a(h6) { r.push(h6); } function c() { t.setup(i); } function l(h6) { t.setupView(i, h6); } return { init: s, state: { lightsArray: i, shadowsArray: r, lights: t }, setupLights: c, setupLightsView: l, pushLight: o, pushShadow: a }; } function wD(n, e) { let t = /* @__PURE__ */ new WeakMap(); function i(s, o = 0) { let a; return t.has(s) === false ? (a = new vg(n, e), t.set(s, [a])) : o >= t.get(s).length ? (a = new vg(n, e), t.get(s).push(a)) : a = t.get(s)[o], a; } function r() { t = /* @__PURE__ */ new WeakMap(); } return { get: i, dispose: r }; } var xu = class extends tn { constructor(e) { super(), this.type = "MeshDepthMaterial", this.depthPacking = Yb, this.morphTargets = false, this.map = null, this.alphaMap = null, this.displacementMap = null, this.displacementScale = 1, this.displacementBias = 0, this.wireframe = false, this.wireframeLinewidth = 1, this.fog = false, this.setValues(e); } copy(e) { return super.copy(e), this.depthPacking = e.depthPacking, this.morphTargets = e.morphTargets, this.map = e.map, this.alphaMap = e.alphaMap, this.displacementMap = e.displacementMap, this.displacementScale = e.displacementScale, this.displacementBias = e.displacementBias, this.wireframe = e.wireframe, this.wireframeLinewidth = e.wireframeLinewidth, this; } }; xu.prototype.isMeshDepthMaterial = true; var Mu = class extends tn { constructor(e) { super(), this.type = "MeshDistanceMaterial", this.referencePosition = new q(), this.nearDistance = 1, this.farDistance = 1e3, this.morphTargets = false, this.map = null, this.alphaMap = null, this.displacementMap = null, this.displacementScale = 1, this.displacementBias = 0, this.fog = false, this.setValues(e); } copy(e) { return super.copy(e), this.referencePosition.copy(e.referencePosition), this.nearDistance = e.nearDistance, this.farDistance = e.farDistance, this.morphTargets = e.morphTargets, this.map = e.map, this.alphaMap = e.alphaMap, this.displacementMap = e.displacementMap, this.displacementScale = e.displacementScale, this.displacementBias = e.displacementBias, this; } }; Mu.prototype.isMeshDistanceMaterial = true; var AD = `uniform sampler2D shadow_pass; uniform vec2 resolution; uniform float radius; #include void main() { float mean = 0.0; float squared_mean = 0.0; float depth = unpackRGBAToDepth( texture2D( shadow_pass, ( gl_FragCoord.xy ) / resolution ) ); for ( float i = -1.0; i < 1.0 ; i += SAMPLE_RATE) { #ifdef HORIZONTAL_PASS vec2 distribution = unpackRGBATo2Half( texture2D( shadow_pass, ( gl_FragCoord.xy + vec2( i, 0.0 ) * radius ) / resolution ) ); mean += distribution.x; squared_mean += distribution.y * distribution.y + distribution.x * distribution.x; #else float depth = unpackRGBAToDepth( texture2D( shadow_pass, ( gl_FragCoord.xy + vec2( 0.0, i ) * radius ) / resolution ) ); mean += depth; squared_mean += depth * depth; #endif } mean = mean * HALF_SAMPLE_RATE; squared_mean = squared_mean * HALF_SAMPLE_RATE; float std_dev = sqrt( squared_mean - mean * mean ); gl_FragColor = pack2HalfToRGBA( vec2( mean, std_dev ) ); }`; var SD = `void main() { gl_Position = vec4( position, 1.0 ); }`; function xx(n, e, t) { let i = new dl(); const r = new Re(), s = new Re(), o = new xt(), a = [], c = [], l = {}, d = t.maxTextureSize, h6 = { 0: jt, 1: Hr, 2: Wr }, f = new or({ defines: { SAMPLE_RATE: 2 / 8, HALF_SAMPLE_RATE: 1 / 8 }, uniforms: { shadow_pass: { value: null }, resolution: { value: new Re() }, radius: { value: 4 } }, vertexShader: SD, fragmentShader: AD }), g = f.clone(); g.defines.HORIZONTAL_PASS = 1; const p = new Ke(); p.setAttribute( "position", new ot( new Float32Array([-1, -1, 0.5, 3, -1, 0.5, -1, 3, 0.5]), 3 ) ); const u = new Xt(p, f), y = this; this.enabled = false, this.autoUpdate = true, this.needsUpdate = false, this.type = vf, this.render = function(M, R, L) { if (y.enabled === false || y.autoUpdate === false && y.needsUpdate === false || M.length === 0) return; const S = n.getRenderTarget(), I = n.getActiveCubeFace(), T = n.getActiveMipmapLevel(), _ = n.state; _.setBlending(tr), _.buffers.color.setClear(1, 1, 1, 1), _.buffers.depth.setTest(true), _.setScissorTest(false); for (let E = 0, C = M.length; E < C; E++) { const P = M[E], b = P.shadow; if (b === void 0) { console.warn("THREE.WebGLShadowMap:", P, "has no shadow."); continue; } if (b.autoUpdate === false && b.needsUpdate === false) continue; r.copy(b.mapSize); const F = b.getFrameExtents(); if (r.multiply(F), s.copy(b.mapSize), (r.x > d || r.y > d) && (r.x > d && (s.x = Math.floor(d / F.x), r.x = s.x * F.x, b.mapSize.x = s.x), r.y > d && (s.y = Math.floor(d / F.y), r.y = s.y * F.y, b.mapSize.y = s.y)), b.map === null && !b.isPointLightShadow && this.type === po) { const N = { minFilter: zt, magFilter: zt, format: Gn }; b.map = new fi(r.x, r.y, N), b.map.texture.name = P.name + ".shadowMap", b.mapPass = new fi(r.x, r.y, N), b.camera.updateProjectionMatrix(); } if (b.map === null) { const N = { minFilter: $t, magFilter: $t, format: Gn }; b.map = new fi(r.x, r.y, N), b.map.texture.name = P.name + ".shadowMap", b.camera.updateProjectionMatrix(); } n.setRenderTarget(b.map), n.clear(); const D = b.getViewportCount(); for (let N = 0; N < D; N++) { const B = b.getViewport(N); o.set( s.x * B.x, s.y * B.y, s.x * B.z, s.y * B.w ), _.viewport(o), b.updateMatrices(P, N), i = b.getFrustum(), A(R, L, b.camera, P, this.type); } !b.isPointLightShadow && this.type === po && v(b, L), b.needsUpdate = false; } y.needsUpdate = false, n.setRenderTarget(S, I, T); }; function v(M, R) { const L = e.update(u); f.uniforms.shadow_pass.value = M.map.texture, f.uniforms.resolution.value = M.mapSize, f.uniforms.radius.value = M.radius, n.setRenderTarget(M.mapPass), n.clear(), n.renderBufferDirect(R, null, L, f, u, null), g.uniforms.shadow_pass.value = M.mapPass.texture, g.uniforms.resolution.value = M.mapSize, g.uniforms.radius.value = M.radius, n.setRenderTarget(M.map), n.clear(), n.renderBufferDirect(R, null, L, g, u, null); } function m(M) { const R = M << 0; let L = a[R]; return L === void 0 && (L = new xu({ depthPacking: Jb, morphTargets: M }), a[R] = L), L; } function x(M) { const R = M << 0; let L = c[R]; return L === void 0 && (L = new Mu({ morphTargets: M }), c[R] = L), L; } function w(M, R, L, S, I, T, _) { let E = null, C = m, P = M.customDepthMaterial; if (S.isPointLight === true && (C = x, P = M.customDistanceMaterial), P === void 0) { let b = false; L.morphTargets === true && (b = R.morphAttributes && R.morphAttributes.position && R.morphAttributes.position.length > 0), E = C(b); } else E = P; if (n.localClippingEnabled && L.clipShadows === true && L.clippingPlanes.length !== 0) { const b = E.uuid, F = L.uuid; let D = l[b]; D === void 0 && (D = {}, l[b] = D); let N = D[F]; N === void 0 && (N = E.clone(), D[F] = N), E = N; } return E.visible = L.visible, E.wireframe = L.wireframe, _ === po ? E.side = L.shadowSide !== null ? L.shadowSide : L.side : E.side = L.shadowSide !== null ? L.shadowSide : h6[L.side], E.clipShadows = L.clipShadows, E.clippingPlanes = L.clippingPlanes, E.clipIntersection = L.clipIntersection, E.wireframeLinewidth = L.wireframeLinewidth, E.linewidth = L.linewidth, S.isPointLight === true && E.isMeshDistanceMaterial === true && (E.referencePosition.setFromMatrixPosition(S.matrixWorld), E.nearDistance = I, E.farDistance = T), E; } function A(M, R, L, S, I) { if (M.visible === false) return; if (M.layers.test(R.layers) && (M.isMesh || M.isLine || M.isPoints) && (M.castShadow || M.receiveShadow && I === po) && (!M.frustumCulled || i.intersectsObject(M))) { M.modelViewMatrix.multiplyMatrices(L.matrixWorldInverse, M.matrixWorld); const E = e.update(M), C = M.material; if (Array.isArray(C)) { const P = E.groups; for (let b = 0, F = P.length; b < F; b++) { const D = P[b], N = C[D.materialIndex]; if (N && N.visible) { const B = w(M, E, N, S, L.near, L.far, I); n.renderBufferDirect(L, null, E, B, M, D); } } } else if (C.visible) { const P = w(M, E, C, S, L.near, L.far, I); n.renderBufferDirect(L, null, E, P, M, null); } } const _ = M.children; for (let E = 0, C = _.length; E < C; E++) A(_[E], R, L, S, I); } } function _D(n, e, t) { const i = t.isWebGL2; function r() { let ne = false; const me = new xt(); let Me = null; const De = new xt(0, 0, 0, 0); return { setMask: function(Ie) { Me !== Ie && !ne && (n.colorMask(Ie, Ie, Ie, Ie), Me = Ie); }, setLocked: function(Ie) { ne = Ie; }, setClear: function(Ie, $e, lt, qe, Mt) { Mt === true && (Ie *= qe, $e *= qe, lt *= qe), me.set(Ie, $e, lt, qe), De.equals(me) === false && (n.clearColor(Ie, $e, lt, qe), De.copy(me)); }, reset: function() { ne = false, Me = null, De.set(-1, 0, 0, 0); } }; } function s() { let ne = false, me = null, Me = null, De = null; return { setTest: function(Ie) { Ie ? te(2929) : ae(2929); }, setMask: function(Ie) { me !== Ie && !ne && (n.depthMask(Ie), me = Ie); }, setFunc: function(Ie) { if (Me !== Ie) { if (Ie) switch (Ie) { case By: n.depthFunc(512); break; case Uy: n.depthFunc(519); break; case zy: n.depthFunc(513); break; case Vc: n.depthFunc(515); break; case Vy: n.depthFunc(514); break; case ky: n.depthFunc(518); break; case Gy: n.depthFunc(516); break; case Hy: n.depthFunc(517); break; default: n.depthFunc(515); } else n.depthFunc(515); Me = Ie; } }, setLocked: function(Ie) { ne = Ie; }, setClear: function(Ie) { De !== Ie && (n.clearDepth(Ie), De = Ie); }, reset: function() { ne = false, me = null, Me = null, De = null; } }; } function o() { let ne = false, me = null, Me = null, De = null, Ie = null, $e = null, lt = null, qe = null, Mt = null; return { setTest: function(Be) { ne || (Be ? te(2960) : ae(2960)); }, setMask: function(Be) { me !== Be && !ne && (n.stencilMask(Be), me = Be); }, setFunc: function(Be, it, tt) { (Me !== Be || De !== it || Ie !== tt) && (n.stencilFunc(Be, it, tt), Me = Be, De = it, Ie = tt); }, setOp: function(Be, it, tt) { ($e !== Be || lt !== it || qe !== tt) && (n.stencilOp(Be, it, tt), $e = Be, lt = it, qe = tt); }, setLocked: function(Be) { ne = Be; }, setClear: function(Be) { Mt !== Be && (n.clearStencil(Be), Mt = Be); }, reset: function() { ne = false, me = null, Me = null, De = null, Ie = null, $e = null, lt = null, qe = null, Mt = null; } }; } const a = new r(), c = new s(), l = new o(); let d = {}, h6 = null, f = {}, g = null, p = false, u = null, y = null, v = null, m = null, x = null, w = null, A = null, M = false, R = null, L = null, S = null, I = null, T = null; const _ = n.getParameter(35661); let E = false, C = 0; const P = n.getParameter(7938); P.indexOf("WebGL") !== -1 ? (C = parseFloat(/^WebGL (\d)/.exec(P)[1]), E = C >= 1) : P.indexOf("OpenGL ES") !== -1 && (C = parseFloat(/^OpenGL ES (\d)/.exec(P)[1]), E = C >= 2); let b = null, F = {}; const D = n.getParameter(3088), N = n.getParameter(2978), B = new xt().fromArray(D), U = new xt().fromArray(N); function G(ne, me, Me) { const De = new Uint8Array(4), Ie = n.createTexture(); n.bindTexture(ne, Ie), n.texParameteri(ne, 10241, 9728), n.texParameteri(ne, 10240, 9728); for (let $e = 0; $e < Me; $e++) n.texImage2D(me + $e, 0, 6408, 1, 1, 0, 6408, 5121, De); return Ie; } const Y = {}; Y[3553] = G(3553, 3553, 1), Y[34067] = G(34067, 34069, 6), a.setClear(0, 0, 0, 1), c.setClear(1), l.setClear(0), te(2929), c.setFunc(Vc), H(false), K(nd), te(2884), re(tr); function te(ne) { d[ne] !== true && (n.enable(ne), d[ne] = true); } function ae(ne) { d[ne] !== false && (n.disable(ne), d[ne] = false); } function ie(ne) { ne !== h6 && (n.bindFramebuffer(36160, ne), h6 = ne); } function le(ne, me) { return me === null && h6 !== null && (me = h6), f[ne] !== me ? (n.bindFramebuffer(ne, me), f[ne] = me, i && (ne === 36009 && (f[36160] = me), ne === 36160 && (f[36009] = me)), true) : false; } function W(ne) { return g !== ne ? (n.useProgram(ne), g = ne, true) : false; } const $ = { [ps]: 32774, [Ty]: 32778, [Ey]: 32779 }; if (i) $[od] = 32775, $[ad] = 32776; else { const ne = e.get("EXT_blend_minmax"); ne !== null && ($[od] = ne.MIN_EXT, $[ad] = ne.MAX_EXT); } const j = { [Cy]: 0, [Ly]: 1, [Ry]: 768, [bf]: 770, [Ny]: 776, [Oy]: 774, [Py]: 772, [Fy]: 769, [xf]: 771, [Dy]: 775, [Iy]: 773 }; function re(ne, me, Me, De, Ie, $e, lt, qe) { if (ne === tr) { p === true && (ae(3042), p = false); return; } if (p === false && (te(3042), p = true), ne !== _y) { if (ne !== u || qe !== M) { if ((y !== ps || x !== ps) && (n.blendEquation(32774), y = ps, x = ps), qe) switch (ne) { case vo: n.blendFuncSeparate(1, 771, 1, 771); break; case id: n.blendFunc(1, 1); break; case rd: n.blendFuncSeparate(0, 0, 769, 771); break; case sd: n.blendFuncSeparate(0, 768, 0, 770); break; default: console.error("THREE.WebGLState: Invalid blending: ", ne); break; } else switch (ne) { case vo: n.blendFuncSeparate(770, 771, 1, 771); break; case id: n.blendFunc(770, 1); break; case rd: n.blendFunc(0, 769); break; case sd: n.blendFunc(0, 768); break; default: console.error("THREE.WebGLState: Invalid blending: ", ne); break; } v = null, m = null, w = null, A = null, u = ne, M = qe; } return; } Ie = Ie || me, $e = $e || Me, lt = lt || De, (me !== y || Ie !== x) && (n.blendEquationSeparate($[me], $[Ie]), y = me, x = Ie), (Me !== v || De !== m || $e !== w || lt !== A) && (n.blendFuncSeparate(j[Me], j[De], j[$e], j[lt]), v = Me, m = De, w = $e, A = lt), u = ne, M = null; } function V(ne, me) { ne.side === Wr ? ae(2884) : te(2884); let Me = ne.side === jt; me && (Me = !Me), H(Me), ne.blending === vo && ne.transparent === false ? re(tr) : re(ne.blending, ne.blendEquation, ne.blendSrc, ne.blendDst, ne.blendEquationAlpha, ne.blendSrcAlpha, ne.blendDstAlpha, ne.premultipliedAlpha), c.setFunc(ne.depthFunc), c.setTest(ne.depthTest), c.setMask(ne.depthWrite), a.setMask(ne.colorWrite); const De = ne.stencilWrite; l.setTest(De), De && (l.setMask(ne.stencilWriteMask), l.setFunc(ne.stencilFunc, ne.stencilRef, ne.stencilFuncMask), l.setOp(ne.stencilFail, ne.stencilZFail, ne.stencilZPass)), se(ne.polygonOffset, ne.polygonOffsetFactor, ne.polygonOffsetUnits), ne.alphaToCoverage === true ? te(32926) : ae(32926); } function H(ne) { R !== ne && (ne ? n.frontFace(2304) : n.frontFace(2305), R = ne); } function K(ne) { ne !== wy ? (te(2884), ne !== L && (ne === nd ? n.cullFace(1029) : ne === Ay ? n.cullFace(1028) : n.cullFace(1032))) : ae(2884), L = ne; } function ce(ne) { ne !== S && (E && n.lineWidth(ne), S = ne); } function se(ne, me, Me) { ne ? (te(32823), (I !== me || T !== Me) && (n.polygonOffset(me, Me), I = me, T = Me)) : ae(32823); } function k(ne) { ne ? te(3089) : ae(3089); } function O(ne) { ne === void 0 && (ne = 33984 + _ - 1), b !== ne && (n.activeTexture(ne), b = ne); } function Z(ne, me) { b === null && O(); let Me = F[b]; Me === void 0 && (Me = { type: void 0, texture: void 0 }, F[b] = Me), (Me.type !== ne || Me.texture !== me) && (n.bindTexture(ne, me || Y[ne]), Me.type = ne, Me.texture = me); } function X() { const ne = F[b]; ne !== void 0 && ne.type !== void 0 && (n.bindTexture(ne.type, null), ne.type = void 0, ne.texture = void 0); } function ee() { try { n.compressedTexImage2D.apply(n, arguments); } catch (ne) { console.error("THREE.WebGLState:", ne); } } function fe() { try { n.texImage2D.apply(n, arguments); } catch (ne) { console.error("THREE.WebGLState:", ne); } } function be() { try { n.texImage3D.apply(n, arguments); } catch (ne) { console.error("THREE.WebGLState:", ne); } } function Ae(ne) { B.equals(ne) === false && (n.scissor(ne.x, ne.y, ne.z, ne.w), B.copy(ne)); } function he(ne) { U.equals(ne) === false && (n.viewport(ne.x, ne.y, ne.z, ne.w), U.copy(ne)); } function xe() { n.disable(3042), n.disable(2884), n.disable(2929), n.disable(32823), n.disable(3089), n.disable(2960), n.disable(32926), n.blendEquation(32774), n.blendFunc(1, 0), n.blendFuncSeparate(1, 0, 1, 0), n.colorMask(true, true, true, true), n.clearColor(0, 0, 0, 0), n.depthMask(true), n.depthFunc(513), n.clearDepth(1), n.stencilMask(4294967295), n.stencilFunc(519, 0, 4294967295), n.stencilOp(7680, 7680, 7680), n.clearStencil(0), n.cullFace(1029), n.frontFace(2305), n.polygonOffset(0, 0), n.activeTexture(33984), n.bindFramebuffer(36160, null), i === true && (n.bindFramebuffer(36009, null), n.bindFramebuffer(36008, null)), n.useProgram(null), n.lineWidth(1), n.scissor(0, 0, n.canvas.width, n.canvas.height), n.viewport(0, 0, n.canvas.width, n.canvas.height), d = {}, b = null, F = {}, h6 = null, f = {}, g = null, p = false, u = null, y = null, v = null, m = null, x = null, w = null, A = null, M = false, R = null, L = null, S = null, I = null, T = null, B.set(0, 0, n.canvas.width, n.canvas.height), U.set(0, 0, n.canvas.width, n.canvas.height), a.reset(), c.reset(), l.reset(); } return { buffers: { color: a, depth: c, stencil: l }, enable: te, disable: ae, bindFramebuffer: le, bindXRFramebuffer: ie, useProgram: W, setBlending: re, setMaterial: V, setFlipSided: H, setCullFace: K, setLineWidth: ce, setPolygonOffset: se, setScissorTest: k, activeTexture: O, bindTexture: Z, unbindTexture: X, compressedTexImage2D: ee, texImage2D: fe, texImage3D: be, scissor: Ae, viewport: he, reset: xe }; } function TD(n, e, t, i, r, s, o) { const a = r.isWebGL2, c = r.maxTextures, l = r.maxCubemapSize, d = r.maxTextureSize, h6 = r.maxSamples, f = /* @__PURE__ */ new WeakMap(); let g, p = false; try { p = typeof OffscreenCanvas < "u" && new OffscreenCanvas(1, 1).getContext("2d") !== null; } catch { } function u(k, O) { return p ? new OffscreenCanvas(k, O) : document.createElementNS("http://www.w3.org/1999/xhtml", "canvas"); } function y(k, O, Z, X) { let ee = 1; if ((k.width > X || k.height > X) && (ee = X / Math.max(k.width, k.height)), ee < 1 || O === true) if (typeof HTMLImageElement < "u" && k instanceof HTMLImageElement || typeof HTMLCanvasElement < "u" && k instanceof HTMLCanvasElement || typeof ImageBitmap < "u" && k instanceof ImageBitmap) { const fe = O ? ex : Math.floor, be = fe(ee * k.width), Ae = fe(ee * k.height); g === void 0 && (g = u(be, Ae)); const he = Z ? u(be, Ae) : g; return he.width = be, he.height = Ae, he.getContext("2d").drawImage(k, 0, 0, be, Ae), console.warn("THREE.WebGLRenderer: Texture has been resized from (" + k.width + "x" + k.height + ") to (" + be + "x" + Ae + ")."), he; } else return "data" in k && console.warn("THREE.WebGLRenderer: Image in DataTexture is too big (" + k.width + "x" + k.height + ")."), k; return k; } function v(k) { return bd(k.width) && bd(k.height); } function m(k) { return a ? false : k.wrapS !== hn2 || k.wrapT !== hn2 || k.minFilter !== $t && k.minFilter !== zt; } function x(k, O) { return k.generateMipmaps && O && k.minFilter !== $t && k.minFilter !== zt; } function w(k, O, Z, X, ee = 1) { n.generateMipmap(k); const fe = i.get(O); fe.__maxMipLevel = Math.log2(Math.max(Z, X, ee)); } function A(k, O, Z) { if (a === false) return O; if (k !== null) { if (n[k] !== void 0) return n[k]; console.warn("THREE.WebGLRenderer: Attempt to use non-existing WebGL internal format '" + k + "'"); } let X = O; return O === 6403 && (Z === 5126 && (X = 33326), Z === 5131 && (X = 33325), Z === 5121 && (X = 33321)), O === 6407 && (Z === 5126 && (X = 34837), Z === 5131 && (X = 34843), Z === 5121 && (X = 32849)), O === 6408 && (Z === 5126 && (X = 34836), Z === 5131 && (X = 34842), Z === 5121 && (X = 32856)), (X === 33325 || X === 33326 || X === 34842 || X === 34836) && e.get("EXT_color_buffer_float"), X; } function M(k) { return k === $t || k === ka || k === Ga ? 9728 : 9729; } function R(k) { const O = k.target; O.removeEventListener("dispose", R), S(O), O.isVideoTexture && f.delete(O), o.memory.textures--; } function L(k) { const O = k.target; O.removeEventListener("dispose", L), I(O); } function S(k) { const O = i.get(k); O.__webglInit !== void 0 && (n.deleteTexture(O.__webglTexture), i.remove(k)); } function I(k) { const O = k.texture, Z = i.get(k), X = i.get(O); if (k) { if (X.__webglTexture !== void 0 && (n.deleteTexture(X.__webglTexture), o.memory.textures--), k.depthTexture && k.depthTexture.dispose(), k.isWebGLCubeRenderTarget) for (let ee = 0; ee < 6; ee++) n.deleteFramebuffer(Z.__webglFramebuffer[ee]), Z.__webglDepthbuffer && n.deleteRenderbuffer(Z.__webglDepthbuffer[ee]); else n.deleteFramebuffer(Z.__webglFramebuffer), Z.__webglDepthbuffer && n.deleteRenderbuffer(Z.__webglDepthbuffer), Z.__webglMultisampledFramebuffer && n.deleteFramebuffer(Z.__webglMultisampledFramebuffer), Z.__webglColorRenderbuffer && n.deleteRenderbuffer(Z.__webglColorRenderbuffer), Z.__webglDepthRenderbuffer && n.deleteRenderbuffer(Z.__webglDepthRenderbuffer); if (k.isWebGLMultipleRenderTargets) for (let ee = 0, fe = O.length; ee < fe; ee++) { const be = i.get(O[ee]); be.__webglTexture && (n.deleteTexture(be.__webglTexture), o.memory.textures--), i.remove(O[ee]); } i.remove(O), i.remove(k); } } let T = 0; function _() { T = 0; } function E() { const k = T; return k >= c && console.warn("THREE.WebGLTextures: Trying to use " + k + " texture units while this GPU supports only " + c), T += 1, k; } function C(k, O) { const Z = i.get(k); if (k.isVideoTexture && V(k), k.version > 0 && Z.__version !== k.version) { const X = k.image; if (X === void 0) console.warn("THREE.WebGLRenderer: Texture marked for update but image is undefined"); else if (X.complete === false) console.warn("THREE.WebGLRenderer: Texture marked for update but image is incomplete"); else { G(Z, k, O); return; } } t.activeTexture(33984 + O), t.bindTexture(3553, Z.__webglTexture); } function P(k, O) { const Z = i.get(k); if (k.version > 0 && Z.__version !== k.version) { G(Z, k, O); return; } t.activeTexture(33984 + O), t.bindTexture(35866, Z.__webglTexture); } function b(k, O) { const Z = i.get(k); if (k.version > 0 && Z.__version !== k.version) { G(Z, k, O); return; } t.activeTexture(33984 + O), t.bindTexture(32879, Z.__webglTexture); } function F(k, O) { const Z = i.get(k); if (k.version > 0 && Z.__version !== k.version) { Y(Z, k, O); return; } t.activeTexture(33984 + O), t.bindTexture(34067, Z.__webglTexture); } const D = { [jr]: 10497, [hn2]: 33071, [Eo]: 33648 }, N = { [$t]: 9728, [ka]: 9984, [Ga]: 9986, [zt]: 9729, [du]: 9985, [fr]: 9987 }; function B(k, O, Z) { if (Z ? (n.texParameteri(k, 10242, D[O.wrapS]), n.texParameteri(k, 10243, D[O.wrapT]), (k === 32879 || k === 35866) && n.texParameteri(k, 32882, D[O.wrapR]), n.texParameteri(k, 10240, N[O.magFilter]), n.texParameteri(k, 10241, N[O.minFilter])) : (n.texParameteri(k, 10242, 33071), n.texParameteri(k, 10243, 33071), (k === 32879 || k === 35866) && n.texParameteri(k, 32882, 33071), (O.wrapS !== hn2 || O.wrapT !== hn2) && console.warn("THREE.WebGLRenderer: Texture is not power of two. Texture.wrapS and Texture.wrapT should be set to THREE.ClampToEdgeWrapping."), n.texParameteri(k, 10240, M(O.magFilter)), n.texParameteri(k, 10241, M(O.minFilter)), O.minFilter !== $t && O.minFilter !== zt && console.warn("THREE.WebGLRenderer: Texture is not power of two. Texture.minFilter should be set to THREE.NearestFilter or THREE.LinearFilter.")), e.has("EXT_texture_filter_anisotropic") === true) { const X = e.get("EXT_texture_filter_anisotropic"); if (O.type === qi && e.has("OES_texture_float_linear") === false || a === false && O.type === Ms && e.has("OES_texture_half_float_linear") === false) return; (O.anisotropy > 1 || i.get(O).__currentAnisotropy) && (n.texParameterf(k, X.TEXTURE_MAX_ANISOTROPY_EXT, Math.min(O.anisotropy, r.getMaxAnisotropy())), i.get(O).__currentAnisotropy = O.anisotropy); } } function U(k, O) { k.__webglInit === void 0 && (k.__webglInit = true, O.addEventListener("dispose", R), k.__webglTexture = n.createTexture(), o.memory.textures++); } function G(k, O, Z) { let X = 3553; O.isDataTexture2DArray && (X = 35866), O.isDataTexture3D && (X = 32879), U(k, O), t.activeTexture(33984 + Z), t.bindTexture(X, k.__webglTexture), n.pixelStorei(37440, O.flipY), n.pixelStorei(37441, O.premultiplyAlpha), n.pixelStorei(3317, O.unpackAlignment), n.pixelStorei(37443, 0); const ee = m(O) && v(O.image) === false, fe = y(O.image, ee, false, d), be = v(fe) || a, Ae = s.convert(O.format); let he = s.convert(O.type), xe = A(O.internalFormat, Ae, he); B(X, O, be); let ne; const me = O.mipmaps; if (O.isDepthTexture) xe = 6402, a ? O.type === qi ? xe = 36012 : O.type === Ra ? xe = 33190 : O.type === yo ? xe = 35056 : xe = 33189 : O.type === qi && console.error("WebGLRenderer: Floating point depth texture requires WebGL2."), O.format === ws && xe === 6402 && O.type !== Ha && O.type !== Ra && (console.warn("THREE.WebGLRenderer: Use UnsignedShortType or UnsignedIntType for DepthFormat DepthTexture."), O.type = Ha, he = s.convert(O.type)), O.format === Co && xe === 6402 && (xe = 34041, O.type !== yo && (console.warn("THREE.WebGLRenderer: Use UnsignedInt248Type for DepthStencilFormat DepthTexture."), O.type = yo, he = s.convert(O.type))), t.texImage2D(3553, 0, xe, fe.width, fe.height, 0, Ae, he, null); else if (O.isDataTexture) if (me.length > 0 && be) { for (let Me = 0, De = me.length; Me < De; Me++) ne = me[Me], t.texImage2D(3553, Me, xe, ne.width, ne.height, 0, Ae, he, ne.data); O.generateMipmaps = false, k.__maxMipLevel = me.length - 1; } else t.texImage2D(3553, 0, xe, fe.width, fe.height, 0, Ae, he, fe.data), k.__maxMipLevel = 0; else if (O.isCompressedTexture) { for (let Me = 0, De = me.length; Me < De; Me++) ne = me[Me], O.format !== Gn && O.format !== nr ? Ae !== null ? t.compressedTexImage2D(3553, Me, xe, ne.width, ne.height, 0, ne.data) : console.warn("THREE.WebGLRenderer: Attempt to load unsupported compressed texture format in .uploadTexture()") : t.texImage2D(3553, Me, xe, ne.width, ne.height, 0, Ae, he, ne.data); k.__maxMipLevel = me.length - 1; } else if (O.isDataTexture2DArray) t.texImage3D(35866, 0, xe, fe.width, fe.height, fe.depth, 0, Ae, he, fe.data), k.__maxMipLevel = 0; else if (O.isDataTexture3D) t.texImage3D(32879, 0, xe, fe.width, fe.height, fe.depth, 0, Ae, he, fe.data), k.__maxMipLevel = 0; else if (me.length > 0 && be) { for (let Me = 0, De = me.length; Me < De; Me++) ne = me[Me], t.texImage2D(3553, Me, xe, Ae, he, ne); O.generateMipmaps = false, k.__maxMipLevel = me.length - 1; } else t.texImage2D(3553, 0, xe, Ae, he, fe), k.__maxMipLevel = 0; x(O, be) && w(X, O, fe.width, fe.height), k.__version = O.version, O.onUpdate && O.onUpdate(O); } function Y(k, O, Z) { if (O.image.length !== 6) return; U(k, O), t.activeTexture(33984 + Z), t.bindTexture(34067, k.__webglTexture), n.pixelStorei(37440, O.flipY), n.pixelStorei(37441, O.premultiplyAlpha), n.pixelStorei(3317, O.unpackAlignment), n.pixelStorei(37443, 0); const X = O && (O.isCompressedTexture || O.image[0].isCompressedTexture), ee = O.image[0] && O.image[0].isDataTexture, fe = []; for (let Me = 0; Me < 6; Me++) !X && !ee ? fe[Me] = y(O.image[Me], false, true, l) : fe[Me] = ee ? O.image[Me].image : O.image[Me]; const be = fe[0], Ae = v(be) || a, he = s.convert(O.format), xe = s.convert(O.type), ne = A(O.internalFormat, he, xe); B(34067, O, Ae); let me; if (X) { for (let Me = 0; Me < 6; Me++) { me = fe[Me].mipmaps; for (let De = 0; De < me.length; De++) { const Ie = me[De]; O.format !== Gn && O.format !== nr ? he !== null ? t.compressedTexImage2D(34069 + Me, De, ne, Ie.width, Ie.height, 0, Ie.data) : console.warn("THREE.WebGLRenderer: Attempt to load unsupported compressed texture format in .setTextureCube()") : t.texImage2D(34069 + Me, De, ne, Ie.width, Ie.height, 0, he, xe, Ie.data); } } k.__maxMipLevel = me.length - 1; } else { me = O.mipmaps; for (let Me = 0; Me < 6; Me++) if (ee) { t.texImage2D(34069 + Me, 0, ne, fe[Me].width, fe[Me].height, 0, he, xe, fe[Me].data); for (let De = 0; De < me.length; De++) { const $e = me[De].image[Me].image; t.texImage2D(34069 + Me, De + 1, ne, $e.width, $e.height, 0, he, xe, $e.data); } } else { t.texImage2D(34069 + Me, 0, ne, he, xe, fe[Me]); for (let De = 0; De < me.length; De++) { const Ie = me[De]; t.texImage2D(34069 + Me, De + 1, ne, he, xe, Ie.image[Me]); } } k.__maxMipLevel = me.length; } x(O, Ae) && w(34067, O, be.width, be.height), k.__version = O.version, O.onUpdate && O.onUpdate(O); } function te(k, O, Z, X, ee) { const fe = s.convert(Z.format), be = s.convert(Z.type), Ae = A(Z.internalFormat, fe, be); ee === 32879 || ee === 35866 ? t.texImage3D(ee, 0, Ae, O.width, O.height, O.depth, 0, fe, be, null) : t.texImage2D(ee, 0, Ae, O.width, O.height, 0, fe, be, null), t.bindFramebuffer(36160, k), n.framebufferTexture2D(36160, X, ee, i.get(Z).__webglTexture, 0), t.bindFramebuffer(36160, null); } function ae(k, O, Z) { if (n.bindRenderbuffer(36161, k), O.depthBuffer && !O.stencilBuffer) { let X = 33189; if (Z) { const ee = O.depthTexture; ee && ee.isDepthTexture && (ee.type === qi ? X = 36012 : ee.type === Ra && (X = 33190)); const fe = re(O); n.renderbufferStorageMultisample(36161, fe, X, O.width, O.height); } else n.renderbufferStorage(36161, X, O.width, O.height); n.framebufferRenderbuffer(36160, 36096, 36161, k); } else if (O.depthBuffer && O.stencilBuffer) { if (Z) { const X = re(O); n.renderbufferStorageMultisample(36161, X, 35056, O.width, O.height); } else n.renderbufferStorage(36161, 34041, O.width, O.height); n.framebufferRenderbuffer(36160, 33306, 36161, k); } else { const X = O.isWebGLMultipleRenderTargets === true ? O.texture[0] : O.texture, ee = s.convert(X.format), fe = s.convert(X.type), be = A(X.internalFormat, ee, fe); if (Z) { const Ae = re(O); n.renderbufferStorageMultisample(36161, Ae, be, O.width, O.height); } else n.renderbufferStorage(36161, be, O.width, O.height); } n.bindRenderbuffer(36161, null); } function ie(k, O) { if (O && O.isWebGLCubeRenderTarget) throw new Error("Depth Texture with cube render targets is not supported"); if (t.bindFramebuffer(36160, k), !(O.depthTexture && O.depthTexture.isDepthTexture)) throw new Error("renderTarget.depthTexture must be an instance of THREE.DepthTexture"); (!i.get(O.depthTexture).__webglTexture || O.depthTexture.image.width !== O.width || O.depthTexture.image.height !== O.height) && (O.depthTexture.image.width = O.width, O.depthTexture.image.height = O.height, O.depthTexture.needsUpdate = true), C(O.depthTexture, 0); const X = i.get(O.depthTexture).__webglTexture; if (O.depthTexture.format === ws) n.framebufferTexture2D(36160, 36096, 3553, X, 0); else if (O.depthTexture.format === Co) n.framebufferTexture2D(36160, 33306, 3553, X, 0); else throw new Error("Unknown depthTexture format"); } function le(k) { const O = i.get(k), Z = k.isWebGLCubeRenderTarget === true; if (k.depthTexture) { if (Z) throw new Error("target.depthTexture not supported in Cube render targets"); ie(O.__webglFramebuffer, k); } else if (Z) { O.__webglDepthbuffer = []; for (let X = 0; X < 6; X++) t.bindFramebuffer(36160, O.__webglFramebuffer[X]), O.__webglDepthbuffer[X] = n.createRenderbuffer(), ae(O.__webglDepthbuffer[X], k, false); } else t.bindFramebuffer(36160, O.__webglFramebuffer), O.__webglDepthbuffer = n.createRenderbuffer(), ae(O.__webglDepthbuffer, k, false); t.bindFramebuffer(36160, null); } function W(k) { const O = k.texture, Z = i.get(k), X = i.get(O); k.addEventListener("dispose", L), k.isWebGLMultipleRenderTargets !== true && (X.__webglTexture = n.createTexture(), X.__version = O.version, o.memory.textures++); const ee = k.isWebGLCubeRenderTarget === true, fe = k.isWebGLMultipleRenderTargets === true, be = k.isWebGLMultisampleRenderTarget === true, Ae = O.isDataTexture3D || O.isDataTexture2DArray, he = v(k) || a; if (a && O.format === nr && (O.type === qi || O.type === Ms) && (O.format = Gn, console.warn("THREE.WebGLRenderer: Rendering to textures with RGB format is not supported. Using RGBA format instead.")), ee) { Z.__webglFramebuffer = []; for (let xe = 0; xe < 6; xe++) Z.__webglFramebuffer[xe] = n.createFramebuffer(); } else if (Z.__webglFramebuffer = n.createFramebuffer(), fe) if (r.drawBuffers) { const xe = k.texture; for (let ne = 0, me = xe.length; ne < me; ne++) { const Me = i.get(xe[ne]); Me.__webglTexture === void 0 && (Me.__webglTexture = n.createTexture(), o.memory.textures++); } } else console.warn("THREE.WebGLRenderer: WebGLMultipleRenderTargets can only be used with WebGL2 or WEBGL_draw_buffers extension."); else if (be) if (a) { Z.__webglMultisampledFramebuffer = n.createFramebuffer(), Z.__webglColorRenderbuffer = n.createRenderbuffer(), n.bindRenderbuffer(36161, Z.__webglColorRenderbuffer); const xe = s.convert(O.format), ne = s.convert(O.type), me = A(O.internalFormat, xe, ne), Me = re(k); n.renderbufferStorageMultisample(36161, Me, me, k.width, k.height), t.bindFramebuffer(36160, Z.__webglMultisampledFramebuffer), n.framebufferRenderbuffer(36160, 36064, 36161, Z.__webglColorRenderbuffer), n.bindRenderbuffer(36161, null), k.depthBuffer && (Z.__webglDepthRenderbuffer = n.createRenderbuffer(), ae(Z.__webglDepthRenderbuffer, k, true)), t.bindFramebuffer(36160, null); } else console.warn("THREE.WebGLRenderer: WebGLMultisampleRenderTarget can only be used with WebGL2."); if (ee) { t.bindTexture(34067, X.__webglTexture), B(34067, O, he); for (let xe = 0; xe < 6; xe++) te(Z.__webglFramebuffer[xe], k, O, 36064, 34069 + xe); x(O, he) && w(34067, O, k.width, k.height), t.bindTexture(34067, null); } else if (fe) { const xe = k.texture; for (let ne = 0, me = xe.length; ne < me; ne++) { const Me = xe[ne], De = i.get(Me); t.bindTexture(3553, De.__webglTexture), B(3553, Me, he), te(Z.__webglFramebuffer, k, Me, 36064 + ne, 3553), x(Me, he) && w(3553, Me, k.width, k.height); } t.bindTexture(3553, null); } else { let xe = 3553; Ae && (a ? xe = O.isDataTexture3D ? 32879 : 35866 : console.warn("THREE.DataTexture3D and THREE.DataTexture2DArray only supported with WebGL2.")), t.bindTexture(xe, X.__webglTexture), B(xe, O, he), te(Z.__webglFramebuffer, k, O, 36064, xe), x(O, he) && w(xe, O, k.width, k.height, k.depth), t.bindTexture(xe, null); } k.depthBuffer && le(k); } function $(k) { const O = v(k) || a, Z = k.isWebGLMultipleRenderTargets === true ? k.texture : [k.texture]; for (let X = 0, ee = Z.length; X < ee; X++) { const fe = Z[X]; if (x(fe, O)) { const be = k.isWebGLCubeRenderTarget ? 34067 : 3553, Ae = i.get(fe).__webglTexture; t.bindTexture(be, Ae), w(be, fe, k.width, k.height), t.bindTexture(be, null); } } } function j(k) { if (k.isWebGLMultisampleRenderTarget) if (a) { const O = k.width, Z = k.height; let X = 16384; k.depthBuffer && (X |= 256), k.stencilBuffer && (X |= 1024); const ee = i.get(k); t.bindFramebuffer(36008, ee.__webglMultisampledFramebuffer), t.bindFramebuffer(36009, ee.__webglFramebuffer), n.blitFramebuffer(0, 0, O, Z, 0, 0, O, Z, X, 9728), t.bindFramebuffer(36008, null), t.bindFramebuffer(36009, ee.__webglMultisampledFramebuffer); } else console.warn("THREE.WebGLRenderer: WebGLMultisampleRenderTarget can only be used with WebGL2."); } function re(k) { return a && k.isWebGLMultisampleRenderTarget ? Math.min(h6, k.samples) : 0; } function V(k) { const O = o.render.frame; f.get(k) !== O && (f.set(k, O), k.update()); } let H = false, K = false; function ce(k, O) { k && k.isWebGLRenderTarget && (H === false && (console.warn("THREE.WebGLTextures.safeSetTexture2D: don't use render targets as textures. Use their .texture property instead."), H = true), k = k.texture), C(k, O); } function se(k, O) { k && k.isWebGLCubeRenderTarget && (K === false && (console.warn("THREE.WebGLTextures.safeSetTextureCube: don't use cube render targets as textures. Use their .texture property instead."), K = true), k = k.texture), F(k, O); } this.allocateTextureUnit = E, this.resetTextureUnits = _, this.setTexture2D = C, this.setTexture2DArray = P, this.setTexture3D = b, this.setTextureCube = F, this.setupRenderTarget = W, this.updateRenderTargetMipmap = $, this.updateMultisampleRenderTarget = j, this.safeSetTexture2D = ce, this.safeSetTextureCube = se; } function Mx(n, e, t) { const i = t.isWebGL2; function r(s) { let o; if (s === Ts) return 5121; if (s === eb) return 32819; if (s === tb) return 32820; if (s === nb) return 33635; if (s === Ky) return 5120; if (s === qy) return 5122; if (s === Ha) return 5123; if (s === Qy) return 5124; if (s === Ra) return 5125; if (s === qi) return 5126; if (s === Ms) return i ? 5131 : (o = e.get("OES_texture_half_float"), o !== null ? o.HALF_FLOAT_OES : null); if (s === ib) return 6406; if (s === nr) return 6407; if (s === Gn) return 6408; if (s === rb) return 6409; if (s === sb) return 6410; if (s === ws) return 6402; if (s === Co) return 34041; if (s === ab) return 6403; if (s === lb) return 36244; if (s === cb) return 33319; if (s === ub) return 33320; if (s === hb) return 36248; if (s === db) return 36249; if (s === ld || s === cd || s === ud || s === hd) if (o = e.get("WEBGL_compressed_texture_s3tc"), o !== null) { if (s === ld) return o.COMPRESSED_RGB_S3TC_DXT1_EXT; if (s === cd) return o.COMPRESSED_RGBA_S3TC_DXT1_EXT; if (s === ud) return o.COMPRESSED_RGBA_S3TC_DXT3_EXT; if (s === hd) return o.COMPRESSED_RGBA_S3TC_DXT5_EXT; } else return null; if (s === dd || s === fd || s === pd || s === md) if (o = e.get("WEBGL_compressed_texture_pvrtc"), o !== null) { if (s === dd) return o.COMPRESSED_RGB_PVRTC_4BPPV1_IMG; if (s === fd) return o.COMPRESSED_RGB_PVRTC_2BPPV1_IMG; if (s === pd) return o.COMPRESSED_RGBA_PVRTC_4BPPV1_IMG; if (s === md) return o.COMPRESSED_RGBA_PVRTC_2BPPV1_IMG; } else return null; if (s === fb) return o = e.get("WEBGL_compressed_texture_etc1"), o !== null ? o.COMPRESSED_RGB_ETC1_WEBGL : null; if ((s === gd || s === vd) && (o = e.get("WEBGL_compressed_texture_etc"), o !== null)) { if (s === gd) return o.COMPRESSED_RGB8_ETC2; if (s === vd) return o.COMPRESSED_RGBA8_ETC2_EAC; } if (s === pb || s === mb || s === gb || s === vb || s === yb || s === bb || s === xb || s === Mb || s === wb || s === Ab || s === Sb || s === _b || s === Tb || s === Eb || s === Lb || s === Rb || s === Fb || s === Pb || s === Ib || s === Ob || s === Db || s === Nb || s === Bb || s === Ub || s === zb || s === Vb || s === kb || s === Gb) return o = e.get("WEBGL_compressed_texture_astc"), o !== null ? s : null; if (s === Cb) return o = e.get("EXT_texture_compression_bptc"), o !== null ? s : null; if (s === yo) return i ? 34042 : (o = e.get("WEBGL_depth_texture"), o !== null ? o.UNSIGNED_INT_24_8_WEBGL : null); } return { convert: r }; } var Ff = class extends nn { constructor(e = []) { super(), this.cameras = e; } }; Ff.prototype.isArrayCamera = true; var _i = class extends ut { constructor() { super(), this.type = "Group"; } }; _i.prototype.isGroup = true; var ED = { type: "move" }; var gh = class { constructor() { this._targetRay = null, this._grip = null, this._hand = null; } getHandSpace() { return this._hand === null && (this._hand = new _i(), this._hand.matrixAutoUpdate = false, this._hand.visible = false, this._hand.joints = {}, this._hand.inputState = { pinching: false }), this._hand; } getTargetRaySpace() { return this._targetRay === null && (this._targetRay = new _i(), this._targetRay.matrixAutoUpdate = false, this._targetRay.visible = false, this._targetRay.hasLinearVelocity = false, this._targetRay.linearVelocity = new q(), this._targetRay.hasAngularVelocity = false, this._targetRay.angularVelocity = new q()), this._targetRay; } getGripSpace() { return this._grip === null && (this._grip = new _i(), this._grip.matrixAutoUpdate = false, this._grip.visible = false, this._grip.hasLinearVelocity = false, this._grip.linearVelocity = new q(), this._grip.hasAngularVelocity = false, this._grip.angularVelocity = new q()), this._grip; } dispatchEvent(e) { return this._targetRay !== null && this._targetRay.dispatchEvent(e), this._grip !== null && this._grip.dispatchEvent(e), this._hand !== null && this._hand.dispatchEvent(e), this; } disconnect(e) { return this.dispatchEvent({ type: "disconnected", data: e }), this._targetRay !== null && (this._targetRay.visible = false), this._grip !== null && (this._grip.visible = false), this._hand !== null && (this._hand.visible = false), this; } update(e, t, i) { let r = null, s = null, o = null; const a = this._targetRay, c = this._grip, l = this._hand; if (e && t.session.visibilityState !== "visible-blurred") if (a !== null && (r = t.getPose(e.targetRaySpace, i), r !== null && (a.matrix.fromArray(r.transform.matrix), a.matrix.decompose(a.position, a.rotation, a.scale), r.linearVelocity ? (a.hasLinearVelocity = true, a.linearVelocity.copy(r.linearVelocity)) : a.hasLinearVelocity = false, r.angularVelocity ? (a.hasAngularVelocity = true, a.angularVelocity.copy(r.angularVelocity)) : a.hasAngularVelocity = false, this.dispatchEvent(ED))), l && e.hand) { o = true; for (const u of e.hand.values()) { const y = t.getJointPose(u, i); if (l.joints[u.jointName] === void 0) { const m = new _i(); m.matrixAutoUpdate = false, m.visible = false, l.joints[u.jointName] = m, l.add(m); } const v = l.joints[u.jointName]; y !== null && (v.matrix.fromArray(y.transform.matrix), v.matrix.decompose(v.position, v.rotation, v.scale), v.jointRadius = y.radius), v.visible = y !== null; } const d = l.joints["index-finger-tip"], h6 = l.joints["thumb-tip"], f = d.position.distanceTo(h6.position), g = 0.02, p = 5e-3; l.inputState.pinching && f > g + p ? (l.inputState.pinching = false, this.dispatchEvent({ type: "pinchend", handedness: e.handedness, target: this })) : !l.inputState.pinching && f <= g - p && (l.inputState.pinching = true, this.dispatchEvent({ type: "pinchstart", handedness: e.handedness, target: this })); } else c !== null && e.gripSpace && (s = t.getPose(e.gripSpace, i), s !== null && (c.matrix.fromArray(s.transform.matrix), c.matrix.decompose(c.position, c.rotation, c.scale), s.linearVelocity ? (c.hasLinearVelocity = true, c.linearVelocity.copy(s.linearVelocity)) : c.hasLinearVelocity = false, s.angularVelocity ? (c.hasAngularVelocity = true, c.angularVelocity.copy(s.angularVelocity)) : c.hasAngularVelocity = false)); return a !== null && (a.visible = r !== null), c !== null && (c.visible = s !== null), l !== null && (l.visible = o !== null), this; } }; var CD = class extends Kr { constructor(e, t) { super(); const i = this, r = e.state; let s = null, o = 1, a = null, c = "local-floor", l = null, d = null, h6 = null, f = null; const g = [], p = /* @__PURE__ */ new Map(), u = new nn(); u.layers.enable(1), u.viewport = new xt(); const y = new nn(); y.layers.enable(2), y.viewport = new xt(); const v = [u, y], m = new Ff(); m.layers.enable(1), m.layers.enable(2); let x = null, w = null; this.cameraAutoUpdate = true, this.enabled = false, this.isPresenting = false, this.getController = function(P) { let b = g[P]; return b === void 0 && (b = new gh(), g[P] = b), b.getTargetRaySpace(); }, this.getControllerGrip = function(P) { let b = g[P]; return b === void 0 && (b = new gh(), g[P] = b), b.getGripSpace(); }, this.getHand = function(P) { let b = g[P]; return b === void 0 && (b = new gh(), g[P] = b), b.getHandSpace(); }; function A(P) { const b = p.get(P.inputSource); b && b.dispatchEvent({ type: P.type, data: P.inputSource }); } function M() { p.forEach(function(P, b) { P.disconnect(b); }), p.clear(), x = null, w = null, r.bindXRFramebuffer(null), e.setRenderTarget(e.getRenderTarget()), C.stop(), i.isPresenting = false, i.dispatchEvent({ type: "sessionend" }); } this.setFramebufferScaleFactor = function(P) { o = P, i.isPresenting === true && console.warn("THREE.WebXRManager: Cannot change framebuffer scale while presenting."); }, this.setReferenceSpaceType = function(P) { c = P, i.isPresenting === true && console.warn("THREE.WebXRManager: Cannot change reference space type while presenting."); }, this.getReferenceSpace = function() { return a; }, this.getSession = function() { return s; }, this.setSession = async function(P) { if (s = P, s !== null) { s.addEventListener("select", A), s.addEventListener("selectstart", A), s.addEventListener("selectend", A), s.addEventListener("squeeze", A), s.addEventListener("squeezestart", A), s.addEventListener("squeezeend", A), s.addEventListener("end", M), s.addEventListener("inputsourceschange", R); const b = t.getContextAttributes(); if (b.xrCompatible !== true && await t.makeXRCompatible(), s.renderState.layers === void 0) { const F = { antialias: b.antialias, alpha: b.alpha, depth: b.depth, stencil: b.stencil, framebufferScaleFactor: o }, D = new XRWebGLLayer(s, t, F); s.updateRenderState({ baseLayer: D }); } else { let F = 0; b.depth && (F = b.stencil ? 34041 : 6402); const D = { colorFormat: b.alpha ? 6408 : 6407, depthFormat: F, scaleFactor: o }; d = new XRWebGLBinding(s, t), f = d.createProjectionLayer(D), h6 = t.createFramebuffer(), s.updateRenderState({ layers: [f] }); } a = await s.requestReferenceSpace(c), C.setContext(s), C.start(), i.isPresenting = true, i.dispatchEvent({ type: "sessionstart" }); } }; function R(P) { const b = s.inputSources; for (let F = 0; F < g.length; F++) p.set(b[F], g[F]); for (let F = 0; F < P.removed.length; F++) { const D = P.removed[F], N = p.get(D); N && (N.dispatchEvent({ type: "disconnected", data: D }), p.delete(D)); } for (let F = 0; F < P.added.length; F++) { const D = P.added[F], N = p.get(D); N && N.dispatchEvent({ type: "connected", data: D }); } } const L = new q(), S = new q(); function I(P, b, F) { L.setFromMatrixPosition(b.matrixWorld), S.setFromMatrixPosition(F.matrixWorld); const D = L.distanceTo(S), N = b.projectionMatrix.elements, B = F.projectionMatrix.elements, U = N[14] / (N[10] - 1), G = N[14] / (N[10] + 1), Y = (N[9] + 1) / N[5], te = (N[9] - 1) / N[5], ae = (N[8] - 1) / N[0], ie = (B[8] + 1) / B[0], le = U * ae, W = U * ie, $ = D / (-ae + ie), j = $ * -ae; b.matrixWorld.decompose(P.position, P.quaternion, P.scale), P.translateX(j), P.translateZ($), P.matrixWorld.compose(P.position, P.quaternion, P.scale), P.matrixWorldInverse.copy(P.matrixWorld).invert(); const re = U + $, V = G + $, H = le - j, K = W + (D - j), ce = Y * G / V * re, se = te * G / V * re; P.projectionMatrix.makePerspective(H, K, ce, se, re, V); } function T(P, b) { b === null ? P.matrixWorld.copy(P.matrix) : P.matrixWorld.multiplyMatrices(b.matrixWorld, P.matrix), P.matrixWorldInverse.copy(P.matrixWorld).invert(); } this.updateCamera = function(P) { if (s === null) return; m.near = y.near = u.near = P.near, m.far = y.far = u.far = P.far, (x !== m.near || w !== m.far) && (s.updateRenderState({ depthNear: m.near, depthFar: m.far }), x = m.near, w = m.far); const b = P.parent, F = m.cameras; T(m, b); for (let N = 0; N < F.length; N++) T(F[N], b); m.matrixWorld.decompose(m.position, m.quaternion, m.scale), P.position.copy(m.position), P.quaternion.copy(m.quaternion), P.scale.copy(m.scale), P.matrix.copy(m.matrix), P.matrixWorld.copy(m.matrixWorld); const D = P.children; for (let N = 0, B = D.length; N < B; N++) D[N].updateMatrixWorld(true); F.length === 2 ? I(m, u, y) : m.projectionMatrix.copy(u.projectionMatrix); }, this.getCamera = function() { return m; }; let _ = null; function E(P, b) { if (l = b.getViewerPose(a), l !== null) { const D = l.views, N = s.renderState.baseLayer; s.renderState.layers === void 0 && r.bindXRFramebuffer(N.framebuffer); let B = false; D.length !== m.cameras.length && (m.cameras.length = 0, B = true); for (let U = 0; U < D.length; U++) { const G = D[U]; let Y = null; if (s.renderState.layers === void 0) Y = N.getViewport(G); else { const ae = d.getViewSubImage(f, G); r.bindXRFramebuffer(h6), t.framebufferTexture2D(36160, 36064, 3553, ae.colorTexture, 0), ae.depthStencilTexture !== void 0 && t.framebufferTexture2D(36160, 36096, 3553, ae.depthStencilTexture, 0), Y = ae.viewport; } const te = v[U]; te.matrix.fromArray(G.transform.matrix), te.projectionMatrix.fromArray(G.projectionMatrix), te.viewport.set(Y.x, Y.y, Y.width, Y.height), U === 0 && m.matrix.copy(te.matrix), B === true && m.cameras.push(te); } } const F = s.inputSources; for (let D = 0; D < g.length; D++) { const N = g[D], B = F[D]; N.update(B, b, a); } _ && _(P, b); } const C = new dx(); C.setAnimationLoop(E), this.setAnimationLoop = function(P) { _ = P; }, this.dispose = function() { }; } }; function LD(n) { function e(v, m) { v.fogColor.value.copy(m.color), m.isFog ? (v.fogNear.value = m.near, v.fogFar.value = m.far) : m.isFogExp2 && (v.fogDensity.value = m.density); } function t(v, m, x, w, A) { m.isMeshBasicMaterial ? i(v, m) : m.isMeshLambertMaterial ? (i(v, m), c(v, m)) : m.isMeshToonMaterial ? (i(v, m), d(v, m)) : m.isMeshPhongMaterial ? (i(v, m), l(v, m)) : m.isMeshStandardMaterial ? (i(v, m), m.isMeshPhysicalMaterial ? f(v, m, A) : h6(v, m)) : m.isMeshMatcapMaterial ? (i(v, m), g(v, m)) : m.isMeshDepthMaterial ? (i(v, m), p(v, m)) : m.isMeshDistanceMaterial ? (i(v, m), u(v, m)) : m.isMeshNormalMaterial ? (i(v, m), y(v, m)) : m.isLineBasicMaterial ? (r(v, m), m.isLineDashedMaterial && s(v, m)) : m.isPointsMaterial ? o(v, m, x, w) : m.isSpriteMaterial ? a(v, m) : m.isShadowMaterial ? (v.color.value.copy(m.color), v.opacity.value = m.opacity) : m.isShaderMaterial && (m.uniformsNeedUpdate = false); } function i(v, m) { v.opacity.value = m.opacity, m.color && v.diffuse.value.copy(m.color), m.emissive && v.emissive.value.copy(m.emissive).multiplyScalar(m.emissiveIntensity), m.map && (v.map.value = m.map), m.alphaMap && (v.alphaMap.value = m.alphaMap), m.specularMap && (v.specularMap.value = m.specularMap); const x = n.get(m).envMap; if (x) { v.envMap.value = x, v.flipEnvMap.value = x.isCubeTexture && x._needsFlipEnvMap ? -1 : 1, v.reflectivity.value = m.reflectivity, v.refractionRatio.value = m.refractionRatio; const M = n.get(x).__maxMipLevel; M !== void 0 && (v.maxMipLevel.value = M); } m.lightMap && (v.lightMap.value = m.lightMap, v.lightMapIntensity.value = m.lightMapIntensity), m.aoMap && (v.aoMap.value = m.aoMap, v.aoMapIntensity.value = m.aoMapIntensity); let w; m.map ? w = m.map : m.specularMap ? w = m.specularMap : m.displacementMap ? w = m.displacementMap : m.normalMap ? w = m.normalMap : m.bumpMap ? w = m.bumpMap : m.roughnessMap ? w = m.roughnessMap : m.metalnessMap ? w = m.metalnessMap : m.alphaMap ? w = m.alphaMap : m.emissiveMap ? w = m.emissiveMap : m.clearcoatMap ? w = m.clearcoatMap : m.clearcoatNormalMap ? w = m.clearcoatNormalMap : m.clearcoatRoughnessMap && (w = m.clearcoatRoughnessMap), w !== void 0 && (w.isWebGLRenderTarget && (w = w.texture), w.matrixAutoUpdate === true && w.updateMatrix(), v.uvTransform.value.copy(w.matrix)); let A; m.aoMap ? A = m.aoMap : m.lightMap && (A = m.lightMap), A !== void 0 && (A.isWebGLRenderTarget && (A = A.texture), A.matrixAutoUpdate === true && A.updateMatrix(), v.uv2Transform.value.copy(A.matrix)); } function r(v, m) { v.diffuse.value.copy(m.color), v.opacity.value = m.opacity; } function s(v, m) { v.dashSize.value = m.dashSize, v.totalSize.value = m.dashSize + m.gapSize, v.scale.value = m.scale; } function o(v, m, x, w) { v.diffuse.value.copy(m.color), v.opacity.value = m.opacity, v.size.value = m.size * x, v.scale.value = w * 0.5, m.map && (v.map.value = m.map), m.alphaMap && (v.alphaMap.value = m.alphaMap); let A; m.map ? A = m.map : m.alphaMap && (A = m.alphaMap), A !== void 0 && (A.matrixAutoUpdate === true && A.updateMatrix(), v.uvTransform.value.copy(A.matrix)); } function a(v, m) { v.diffuse.value.copy(m.color), v.opacity.value = m.opacity, v.rotation.value = m.rotation, m.map && (v.map.value = m.map), m.alphaMap && (v.alphaMap.value = m.alphaMap); let x; m.map ? x = m.map : m.alphaMap && (x = m.alphaMap), x !== void 0 && (x.matrixAutoUpdate === true && x.updateMatrix(), v.uvTransform.value.copy(x.matrix)); } function c(v, m) { m.emissiveMap && (v.emissiveMap.value = m.emissiveMap); } function l(v, m) { v.specular.value.copy(m.specular), v.shininess.value = Math.max(m.shininess, 1e-4), m.emissiveMap && (v.emissiveMap.value = m.emissiveMap), m.bumpMap && (v.bumpMap.value = m.bumpMap, v.bumpScale.value = m.bumpScale, m.side === jt && (v.bumpScale.value *= -1)), m.normalMap && (v.normalMap.value = m.normalMap, v.normalScale.value.copy(m.normalScale), m.side === jt && v.normalScale.value.negate()), m.displacementMap && (v.displacementMap.value = m.displacementMap, v.displacementScale.value = m.displacementScale, v.displacementBias.value = m.displacementBias); } function d(v, m) { m.gradientMap && (v.gradientMap.value = m.gradientMap), m.emissiveMap && (v.emissiveMap.value = m.emissiveMap), m.bumpMap && (v.bumpMap.value = m.bumpMap, v.bumpScale.value = m.bumpScale, m.side === jt && (v.bumpScale.value *= -1)), m.normalMap && (v.normalMap.value = m.normalMap, v.normalScale.value.copy(m.normalScale), m.side === jt && v.normalScale.value.negate()), m.displacementMap && (v.displacementMap.value = m.displacementMap, v.displacementScale.value = m.displacementScale, v.displacementBias.value = m.displacementBias); } function h6(v, m) { v.roughness.value = m.roughness, v.metalness.value = m.metalness, m.roughnessMap && (v.roughnessMap.value = m.roughnessMap), m.metalnessMap && (v.metalnessMap.value = m.metalnessMap), m.emissiveMap && (v.emissiveMap.value = m.emissiveMap), m.bumpMap && (v.bumpMap.value = m.bumpMap, v.bumpScale.value = m.bumpScale, m.side === jt && (v.bumpScale.value *= -1)), m.normalMap && (v.normalMap.value = m.normalMap, v.normalScale.value.copy(m.normalScale), m.side === jt && v.normalScale.value.negate()), m.displacementMap && (v.displacementMap.value = m.displacementMap, v.displacementScale.value = m.displacementScale, v.displacementBias.value = m.displacementBias), n.get(m).envMap && (v.envMapIntensity.value = m.envMapIntensity); } function f(v, m, x) { h6(v, m), v.reflectivity.value = m.reflectivity, v.clearcoat.value = m.clearcoat, v.clearcoatRoughness.value = m.clearcoatRoughness, m.sheen && v.sheen.value.copy(m.sheen), m.clearcoatMap && (v.clearcoatMap.value = m.clearcoatMap), m.clearcoatRoughnessMap && (v.clearcoatRoughnessMap.value = m.clearcoatRoughnessMap), m.clearcoatNormalMap && (v.clearcoatNormalScale.value.copy(m.clearcoatNormalScale), v.clearcoatNormalMap.value = m.clearcoatNormalMap, m.side === jt && v.clearcoatNormalScale.value.negate()), v.transmission.value = m.transmission, m.transmissionMap && (v.transmissionMap.value = m.transmissionMap), m.transmission > 0 && (v.transmissionSamplerMap.value = x.texture, v.transmissionSamplerSize.value.set(x.width, x.height)), v.thickness.value = m.thickness, m.thicknessMap && (v.thicknessMap.value = m.thicknessMap), v.attenuationDistance.value = m.attenuationDistance, v.attenuationColor.value.copy(m.attenuationColor); } function g(v, m) { m.matcap && (v.matcap.value = m.matcap), m.bumpMap && (v.bumpMap.value = m.bumpMap, v.bumpScale.value = m.bumpScale, m.side === jt && (v.bumpScale.value *= -1)), m.normalMap && (v.normalMap.value = m.normalMap, v.normalScale.value.copy(m.normalScale), m.side === jt && v.normalScale.value.negate()), m.displacementMap && (v.displacementMap.value = m.displacementMap, v.displacementScale.value = m.displacementScale, v.displacementBias.value = m.displacementBias); } function p(v, m) { m.displacementMap && (v.displacementMap.value = m.displacementMap, v.displacementScale.value = m.displacementScale, v.displacementBias.value = m.displacementBias); } function u(v, m) { m.displacementMap && (v.displacementMap.value = m.displacementMap, v.displacementScale.value = m.displacementScale, v.displacementBias.value = m.displacementBias), v.referencePosition.value.copy(m.referencePosition), v.nearDistance.value = m.nearDistance, v.farDistance.value = m.farDistance; } function y(v, m) { m.bumpMap && (v.bumpMap.value = m.bumpMap, v.bumpScale.value = m.bumpScale, m.side === jt && (v.bumpScale.value *= -1)), m.normalMap && (v.normalMap.value = m.normalMap, v.normalScale.value.copy(m.normalScale), m.side === jt && v.normalScale.value.negate()), m.displacementMap && (v.displacementMap.value = m.displacementMap, v.displacementScale.value = m.displacementScale, v.displacementBias.value = m.displacementBias); } return { refreshFogUniforms: e, refreshMaterialUniforms: t }; } function RD() { const n = document.createElementNS("http://www.w3.org/1999/xhtml", "canvas"); return n.style.display = "block", n; } function wt(n = {}) { const e = n.canvas !== void 0 ? n.canvas : RD(), t = n.context !== void 0 ? n.context : null, i = n.alpha !== void 0 ? n.alpha : false, r = n.depth !== void 0 ? n.depth : true, s = n.stencil !== void 0 ? n.stencil : true, o = n.antialias !== void 0 ? n.antialias : false, a = n.premultipliedAlpha !== void 0 ? n.premultipliedAlpha : true, c = n.preserveDrawingBuffer !== void 0 ? n.preserveDrawingBuffer : false, l = n.powerPreference !== void 0 ? n.powerPreference : "default", d = n.failIfMajorPerformanceCaveat !== void 0 ? n.failIfMajorPerformanceCaveat : false; let h6 = null, f = null; const g = [], p = []; this.domElement = e, this.debug = { /** * Enables error checking and reporting when shader programs are being compiled * @type {boolean} */ checkShaderErrors: true }, this.autoClear = true, this.autoClearColor = true, this.autoClearDepth = true, this.autoClearStencil = true, this.sortObjects = true, this.clippingPlanes = [], this.localClippingEnabled = false, this.gammaFactor = 2, this.outputEncoding = Cn, this.physicallyCorrectLights = false, this.toneMapping = Ir, this.toneMappingExposure = 1; const u = this; let y = false, v = 0, m = 0, x = null, w = -1, A = null; const M = new xt(), R = new xt(); let L = null, S = e.width, I = e.height, T = 1, _ = null, E = null; const C = new xt(0, 0, S, I), P = new xt(0, 0, S, I); let b = false; const F = [], D = new dl(); let N = false, B = false, U = null; const G = new Xe(), Y = new q(), te = { background: null, fog: null, environment: null, overrideMaterial: null, isScene: true }; function ae() { return x === null ? T : 1; } let ie = t; function le(J, ye) { for (let pe = 0; pe < J.length; pe++) { const we = J[pe], Ce = e.getContext(we, ye); if (Ce !== null) return Ce; } return null; } try { const J = { alpha: i, depth: r, stencil: s, antialias: o, premultipliedAlpha: a, preserveDrawingBuffer: c, powerPreference: l, failIfMajorPerformanceCaveat: d }; if (e.addEventListener("webglcontextlost", $e, false), e.addEventListener("webglcontextrestored", lt, false), ie === null) { const ye = ["webgl2", "webgl", "experimental-webgl"]; if (u.isWebGL1Renderer === true && ye.shift(), ie = le(ye, J), ie === null) throw le(ye) ? new Error("Error creating WebGL context with your selected attributes.") : new Error("Error creating WebGL context."); } ie.getShaderPrecisionFormat === void 0 && (ie.getShaderPrecisionFormat = function() { return { rangeMin: 1, rangeMax: 1, precision: 1 }; }); } catch (J) { throw console.error("THREE.WebGLRenderer: " + J.message), J; } let W, $, j, re, V, H, K, ce, se, k, O, Z, X, ee, fe, be, Ae, he, xe, ne, me, Me; function De() { W = new eO(ie), $ = new KI(ie, W, n), W.init($), me = new Mx(ie, W, $), j = new _D(ie, W, $), F[0] = 1029, re = new iO(), V = new pD(), H = new TD(ie, W, j, V, $, me, re), K = new QI(u), ce = new TF(ie, $), Me = new YI(ie, W, ce, $), se = new tO(ie, ce, re, Me), k = new aO(ie, se, ce, re), he = new oO(ie), fe = new qI(V), O = new fD(u, K, W, $, Me, fe), Z = new LD(V), X = new gD(V), ee = new wD(W, $), Ae = new XI(u, K, j, k, a), be = new xx(u, k, $), xe = new JI(ie, W, re, $), ne = new nO(ie, W, re, $), re.programs = O.programs, u.capabilities = $, u.extensions = W, u.properties = V, u.renderLists = X, u.shadowMap = be, u.state = j, u.info = re; } De(); const Ie = new CD(u, ie); this.xr = Ie, this.getContext = function() { return ie; }, this.getContextAttributes = function() { return ie.getContextAttributes(); }, this.forceContextLoss = function() { const J = W.get("WEBGL_lose_context"); J && J.loseContext(); }, this.forceContextRestore = function() { const J = W.get("WEBGL_lose_context"); J && J.restoreContext(); }, this.getPixelRatio = function() { return T; }, this.setPixelRatio = function(J) { J !== void 0 && (T = J, this.setSize(S, I, false)); }, this.getSize = function(J) { return J.set(S, I); }, this.setSize = function(J, ye, pe) { if (Ie.isPresenting) { console.warn("THREE.WebGLRenderer: Can't change size while VR device is presenting."); return; } S = J, I = ye, e.width = Math.floor(J * T), e.height = Math.floor(ye * T), pe !== false && (e.style.width = J + "px", e.style.height = ye + "px"), this.setViewport(0, 0, J, ye); }, this.getDrawingBufferSize = function(J) { return J.set(S * T, I * T).floor(); }, this.setDrawingBufferSize = function(J, ye, pe) { S = J, I = ye, T = pe, e.width = Math.floor(J * pe), e.height = Math.floor(ye * pe), this.setViewport(0, 0, J, ye); }, this.getCurrentViewport = function(J) { return J.copy(M); }, this.getViewport = function(J) { return J.copy(C); }, this.setViewport = function(J, ye, pe, we) { J.isVector4 ? C.set(J.x, J.y, J.z, J.w) : C.set(J, ye, pe, we), j.viewport(M.copy(C).multiplyScalar(T).floor()); }, this.getScissor = function(J) { return J.copy(P); }, this.setScissor = function(J, ye, pe, we) { J.isVector4 ? P.set(J.x, J.y, J.z, J.w) : P.set(J, ye, pe, we), j.scissor(R.copy(P).multiplyScalar(T).floor()); }, this.getScissorTest = function() { return b; }, this.setScissorTest = function(J) { j.setScissorTest(b = J); }, this.setOpaqueSort = function(J) { _ = J; }, this.setTransparentSort = function(J) { E = J; }, this.getClearColor = function(J) { return J.copy(Ae.getClearColor()); }, this.setClearColor = function() { Ae.setClearColor.apply(Ae, arguments); }, this.getClearAlpha = function() { return Ae.getClearAlpha(); }, this.setClearAlpha = function() { Ae.setClearAlpha.apply(Ae, arguments); }, this.clear = function(J, ye, pe) { let we = 0; (J === void 0 || J) && (we |= 16384), (ye === void 0 || ye) && (we |= 256), (pe === void 0 || pe) && (we |= 1024), ie.clear(we); }, this.clearColor = function() { this.clear(true, false, false); }, this.clearDepth = function() { this.clear(false, true, false); }, this.clearStencil = function() { this.clear(false, false, true); }, this.dispose = function() { e.removeEventListener("webglcontextlost", $e, false), e.removeEventListener("webglcontextrestored", lt, false), X.dispose(), ee.dispose(), V.dispose(), K.dispose(), k.dispose(), Me.dispose(), Ie.dispose(), Ie.removeEventListener("sessionstart", Qt), Ie.removeEventListener("sessionend", Ft), U && (U.dispose(), U = null), Nt.stop(); }; function $e(J) { J.preventDefault(), console.log("THREE.WebGLRenderer: Context Lost."), y = true; } function lt() { console.log("THREE.WebGLRenderer: Context Restored."), y = false; const J = re.autoReset, ye = be.enabled, pe = be.autoUpdate, we = be.needsUpdate, Ce = be.type; De(), re.autoReset = J, be.enabled = ye, be.autoUpdate = pe, be.needsUpdate = we, be.type = Ce; } function qe(J) { const ye = J.target; ye.removeEventListener("dispose", qe), Mt(ye); } function Mt(J) { Be(J), V.remove(J); } function Be(J) { const ye = V.get(J).programs; ye !== void 0 && ye.forEach(function(pe) { O.releaseProgram(pe); }); } function it(J, ye) { J.render(function(pe) { u.renderBufferImmediate(pe, ye); }); } this.renderBufferImmediate = function(J, ye) { Me.initAttributes(); const pe = V.get(J); J.hasPositions && !pe.position && (pe.position = ie.createBuffer()), J.hasNormals && !pe.normal && (pe.normal = ie.createBuffer()), J.hasUvs && !pe.uv && (pe.uv = ie.createBuffer()), J.hasColors && !pe.color && (pe.color = ie.createBuffer()); const we = ye.getAttributes(); J.hasPositions && (ie.bindBuffer(34962, pe.position), ie.bufferData(34962, J.positionArray, 35048), Me.enableAttribute(we.position), ie.vertexAttribPointer(we.position, 3, 5126, false, 0, 0)), J.hasNormals && (ie.bindBuffer(34962, pe.normal), ie.bufferData(34962, J.normalArray, 35048), Me.enableAttribute(we.normal), ie.vertexAttribPointer(we.normal, 3, 5126, false, 0, 0)), J.hasUvs && (ie.bindBuffer(34962, pe.uv), ie.bufferData(34962, J.uvArray, 35048), Me.enableAttribute(we.uv), ie.vertexAttribPointer(we.uv, 2, 5126, false, 0, 0)), J.hasColors && (ie.bindBuffer(34962, pe.color), ie.bufferData(34962, J.colorArray, 35048), Me.enableAttribute(we.color), ie.vertexAttribPointer(we.color, 3, 5126, false, 0, 0)), Me.disableUnusedAttributes(), ie.drawArrays(4, 0, J.count), J.count = 0; }, this.renderBufferDirect = function(J, ye, pe, we, Ce, ge) { ye === null && (ye = te); const Se = Ce.isMesh && Ce.matrixWorld.determinant() < 0, Fe = Oe(J, ye, we, Ce); j.setMaterial(we, Se); let Ge = pe.index; const We = pe.attributes.position; if (Ge === null) { if (We === void 0 || We.count === 0) return; } else if (Ge.count === 0) return; let et = 1; we.wireframe === true && (Ge = se.getWireframeAttribute(pe), et = 2), (we.morphTargets || we.morphNormals) && he.update(Ce, pe, we, Fe), Me.setup(Ce, we, Fe, pe, Ge); let Ye, ft = xe; Ge !== null && (Ye = ce.get(Ge), ft = ne, ft.setIndex(Ye)); const kt = Ge !== null ? Ge.count : We.count, ln = pe.drawRange.start * et, ns = pe.drawRange.count * et, Tt = ge !== null ? ge.start * et : 0, is = ge !== null ? ge.count * et : 1 / 0, Mn = Math.max(ln, Tt), DM = Math.min(kt, ln + ns, Tt + is) - 1, Sl = Math.max(0, DM - Mn + 1); if (Sl !== 0) { if (Ce.isMesh) we.wireframe === true ? (j.setLineWidth(we.wireframeLinewidth * ae()), ft.setMode(1)) : ft.setMode(4); else if (Ce.isLine) { let aa = we.linewidth; aa === void 0 && (aa = 1), j.setLineWidth(aa * ae()), Ce.isLineSegments ? ft.setMode(1) : Ce.isLineLoop ? ft.setMode(2) : ft.setMode(3); } else Ce.isPoints ? ft.setMode(0) : Ce.isSprite && ft.setMode(4); if (Ce.isInstancedMesh) ft.renderInstances(Mn, Sl, Ce.count); else if (pe.isInstancedBufferGeometry) { const aa = Math.min(pe.instanceCount, pe._maxInstanceCount); ft.renderInstances(Mn, Sl, aa); } else ft.render(Mn, Sl); } }, this.compile = function(J, ye) { f = ee.get(J), f.init(), J.traverseVisible(function(pe) { pe.isLight && pe.layers.test(ye.layers) && (f.pushLight(pe), pe.castShadow && f.pushShadow(pe)); }), f.setupLights(), J.traverse(function(pe) { const we = pe.material; if (we) if (Array.isArray(we)) for (let Ce = 0; Ce < we.length; Ce++) { const ge = we[Ce]; Q(ge, J, pe); } else Q(we, J, pe); }); }; let tt = null; function qt(J) { tt && tt(J); } function Qt() { Nt.stop(); } function Ft() { Nt.start(); } const Nt = new dx(); Nt.setAnimationLoop(qt), typeof window < "u" && Nt.setContext(window), this.setAnimationLoop = function(J) { tt = J, Ie.setAnimationLoop(J), J === null ? Nt.stop() : Nt.start(); }, Ie.addEventListener("sessionstart", Qt), Ie.addEventListener("sessionend", Ft), this.render = function(J, ye) { if (ye !== void 0 && ye.isCamera !== true) { console.error("THREE.WebGLRenderer.render: camera is not an instance of THREE.Camera."); return; } if (y === true) return; J.autoUpdate === true && J.updateMatrixWorld(), ye.parent === null && ye.updateMatrixWorld(), Ie.enabled === true && Ie.isPresenting === true && (Ie.cameraAutoUpdate === true && Ie.updateCamera(ye), ye = Ie.getCamera()), J.isScene === true && J.onBeforeRender(u, J, ye, x), f = ee.get(J, p.length), f.init(), p.push(f), G.multiplyMatrices(ye.projectionMatrix, ye.matrixWorldInverse), D.setFromProjectionMatrix(G), B = this.localClippingEnabled, N = fe.init(this.clippingPlanes, B, ye), h6 = X.get(J, g.length), h6.init(), g.push(h6), Vi(J, ye, 0, u.sortObjects), h6.finish(), u.sortObjects === true && h6.sort(_, E), N === true && fe.beginShadows(); const pe = f.state.shadowsArray; be.render(pe, J, ye), f.setupLights(), f.setupLightsView(ye), N === true && fe.endShadows(), this.info.autoReset === true && this.info.reset(), Ae.render(h6, J); const we = h6.opaque, Ce = h6.transmissive, ge = h6.transparent; we.length > 0 && ni(we, J, ye), Ce.length > 0 && ki(we, Ce, J, ye), ge.length > 0 && ni(ge, J, ye), x !== null && (H.updateMultisampleRenderTarget(x), H.updateRenderTargetMipmap(x)), J.isScene === true && J.onAfterRender(u, J, ye), j.buffers.depth.setTest(true), j.buffers.depth.setMask(true), j.buffers.color.setMask(true), j.setPolygonOffset(false), Me.resetDefaultState(), w = -1, A = null, p.pop(), p.length > 0 ? f = p[p.length - 1] : f = null, g.pop(), g.length > 0 ? h6 = g[g.length - 1] : h6 = null; }; function Vi(J, ye, pe, we) { if (J.visible === false) return; if (J.layers.test(ye.layers)) { if (J.isGroup) pe = J.renderOrder; else if (J.isLOD) J.autoUpdate === true && J.update(ye); else if (J.isLight) f.pushLight(J), J.castShadow && f.pushShadow(J); else if (J.isSprite) { if (!J.frustumCulled || D.intersectsSprite(J)) { we && Y.setFromMatrixPosition(J.matrixWorld).applyMatrix4(G); const Se = k.update(J), Fe = J.material; Fe.visible && h6.push(J, Se, Fe, pe, Y.z, null); } } else if (J.isImmediateRenderObject) we && Y.setFromMatrixPosition(J.matrixWorld).applyMatrix4(G), h6.push(J, null, J.material, pe, Y.z, null); else if ((J.isMesh || J.isLine || J.isPoints) && (J.isSkinnedMesh && J.skeleton.frame !== re.render.frame && (J.skeleton.update(), J.skeleton.frame = re.render.frame), !J.frustumCulled || D.intersectsObject(J))) { we && Y.setFromMatrixPosition(J.matrixWorld).applyMatrix4(G); const Se = k.update(J), Fe = J.material; if (Array.isArray(Fe)) { const Ge = Se.groups; for (let We = 0, et = Ge.length; We < et; We++) { const Ye = Ge[We], ft = Fe[Ye.materialIndex]; ft && ft.visible && h6.push(J, Se, ft, pe, Y.z, Ye); } } else Fe.visible && h6.push(J, Se, Fe, pe, Y.z, null); } } const ge = J.children; for (let Se = 0, Fe = ge.length; Se < Fe; Se++) Vi(ge[Se], ye, pe, we); } function ki(J, ye, pe, we) { if (U === null) { const Fe = o === true && $.isWebGL2 === true ? Ef : fi; U = new Fe(1024, 1024, { generateMipmaps: true, type: me.convert(Ms) !== null ? Ms : Ts, minFilter: fr, magFilter: $t, wrapS: hn2, wrapT: hn2 }); } const Ce = u.getRenderTarget(); u.setRenderTarget(U), u.clear(); const ge = u.toneMapping; u.toneMapping = Ir, ni(J, pe, we), u.toneMapping = ge, H.updateMultisampleRenderTarget(U), H.updateRenderTargetMipmap(U), u.setRenderTarget(Ce), ni(ye, pe, we); } function ni(J, ye, pe) { const we = ye.isScene === true ? ye.overrideMaterial : null; for (let Ce = 0, ge = J.length; Ce < ge; Ce++) { const Se = J[Ce], Fe = Se.object, Ge = Se.geometry, We = we === null ? Se.material : we, et = Se.group; if (pe.isArrayCamera) { const Ye = pe.cameras; for (let ft = 0, kt = Ye.length; ft < kt; ft++) { const ln = Ye[ft]; Fe.layers.test(ln.layers) && (j.viewport(M.copy(ln.viewport)), f.setupLightsView(ln), ts(Fe, ye, ln, Ge, We, et)); } } else ts(Fe, ye, pe, Ge, We, et); } } function ts(J, ye, pe, we, Ce, ge) { if (J.onBeforeRender(u, ye, pe, we, Ce, ge), J.modelViewMatrix.multiplyMatrices(pe.matrixWorldInverse, J.matrixWorld), J.normalMatrix.getNormalMatrix(J.modelViewMatrix), J.isImmediateRenderObject) { const Se = Oe(pe, ye, Ce, J); j.setMaterial(Ce), Me.reset(), it(J, Se); } else Ce.transparent === true && Ce.side === Wr ? (Ce.side = jt, Ce.needsUpdate = true, u.renderBufferDirect(pe, ye, we, Ce, J, ge), Ce.side = Hr, Ce.needsUpdate = true, u.renderBufferDirect(pe, ye, we, Ce, J, ge), Ce.side = Wr) : u.renderBufferDirect(pe, ye, we, Ce, J, ge); J.onAfterRender(u, ye, pe, we, Ce, ge); } function Q(J, ye, pe) { ye.isScene !== true && (ye = te); const we = V.get(J), Ce = f.state.lights, ge = f.state.shadowsArray, Se = Ce.state.version, Fe = O.getParameters(J, Ce.state, ge, ye, pe), Ge = O.getProgramCacheKey(Fe); let We = we.programs; we.environment = J.isMeshStandardMaterial ? ye.environment : null, we.fog = ye.fog, we.envMap = K.get(J.envMap || we.environment), We === void 0 && (J.addEventListener("dispose", qe), We = /* @__PURE__ */ new Map(), we.programs = We); let et = We.get(Ge); if (et !== void 0) { if (we.currentProgram === et && we.lightsStateVersion === Se) return _e(J, Fe), et; } else Fe.uniforms = O.getUniforms(J), J.onBuild(Fe, u), J.onBeforeCompile(Fe, u), et = O.acquireProgram(Fe, Ge), We.set(Ge, et), we.uniforms = Fe.uniforms; const Ye = we.uniforms; (!J.isShaderMaterial && !J.isRawShaderMaterial || J.clipping === true) && (Ye.clippingPlanes = fe.uniform), _e(J, Fe), we.needsLights = ht(J), we.lightsStateVersion = Se, we.needsLights && (Ye.ambientLightColor.value = Ce.state.ambient, Ye.lightProbe.value = Ce.state.probe, Ye.directionalLights.value = Ce.state.directional, Ye.directionalLightShadows.value = Ce.state.directionalShadow, Ye.spotLights.value = Ce.state.spot, Ye.spotLightShadows.value = Ce.state.spotShadow, Ye.rectAreaLights.value = Ce.state.rectArea, Ye.ltc_1.value = Ce.state.rectAreaLTC1, Ye.ltc_2.value = Ce.state.rectAreaLTC2, Ye.pointLights.value = Ce.state.point, Ye.pointLightShadows.value = Ce.state.pointShadow, Ye.hemisphereLights.value = Ce.state.hemi, Ye.directionalShadowMap.value = Ce.state.directionalShadowMap, Ye.directionalShadowMatrix.value = Ce.state.directionalShadowMatrix, Ye.spotShadowMap.value = Ce.state.spotShadowMap, Ye.spotShadowMatrix.value = Ce.state.spotShadowMatrix, Ye.pointShadowMap.value = Ce.state.pointShadowMap, Ye.pointShadowMatrix.value = Ce.state.pointShadowMatrix); const ft = et.getUniforms(), kt = Or.seqWithValue(ft.seq, Ye); return we.currentProgram = et, we.uniformsList = kt, et; } function _e(J, ye) { const pe = V.get(J); pe.outputEncoding = ye.outputEncoding, pe.instancing = ye.instancing, pe.skinning = ye.skinning, pe.numClippingPlanes = ye.numClippingPlanes, pe.numIntersection = ye.numClipIntersection, pe.vertexAlphas = ye.vertexAlphas; } function Oe(J, ye, pe, we) { ye.isScene !== true && (ye = te), H.resetTextureUnits(); const Ce = ye.fog, ge = pe.isMeshStandardMaterial ? ye.environment : null, Se = x === null ? u.outputEncoding : x.texture.encoding, Fe = K.get(pe.envMap || ge), Ge = pe.vertexColors === true && we.geometry && we.geometry.attributes.color && we.geometry.attributes.color.itemSize === 4, We = V.get(pe), et = f.state.lights; if (N === true && (B === true || J !== A)) { const Mn = J === A && pe.id === w; fe.setState(pe, J, Mn); } let Ye = false; pe.version === We.__version ? (We.needsLights && We.lightsStateVersion !== et.state.version || We.outputEncoding !== Se || we.isInstancedMesh && We.instancing === false || !we.isInstancedMesh && We.instancing === true || we.isSkinnedMesh && We.skinning === false || !we.isSkinnedMesh && We.skinning === true || We.envMap !== Fe || pe.fog && We.fog !== Ce || We.numClippingPlanes !== void 0 && (We.numClippingPlanes !== fe.numPlanes || We.numIntersection !== fe.numIntersection) || We.vertexAlphas !== Ge) && (Ye = true) : (Ye = true, We.__version = pe.version); let ft = We.currentProgram; Ye === true && (ft = Q(pe, ye, we)); let kt = false, ln = false, ns = false; const Tt = ft.getUniforms(), is = We.uniforms; if (j.useProgram(ft.program) && (kt = true, ln = true, ns = true), pe.id !== w && (w = pe.id, ln = true), kt || A !== J) { if (Tt.setValue(ie, "projectionMatrix", J.projectionMatrix), $.logarithmicDepthBuffer && Tt.setValue( ie, "logDepthBufFC", 2 / (Math.log(J.far + 1) / Math.LN2) ), A !== J && (A = J, ln = true, ns = true), pe.isShaderMaterial || pe.isMeshPhongMaterial || pe.isMeshToonMaterial || pe.isMeshStandardMaterial || pe.envMap) { const Mn = Tt.map.cameraPosition; Mn !== void 0 && Mn.setValue( ie, Y.setFromMatrixPosition(J.matrixWorld) ); } (pe.isMeshPhongMaterial || pe.isMeshToonMaterial || pe.isMeshLambertMaterial || pe.isMeshBasicMaterial || pe.isMeshStandardMaterial || pe.isShaderMaterial) && Tt.setValue(ie, "isOrthographic", J.isOrthographicCamera === true), (pe.isMeshPhongMaterial || pe.isMeshToonMaterial || pe.isMeshLambertMaterial || pe.isMeshBasicMaterial || pe.isMeshStandardMaterial || pe.isShaderMaterial || pe.isShadowMaterial || we.isSkinnedMesh) && Tt.setValue(ie, "viewMatrix", J.matrixWorldInverse); } if (we.isSkinnedMesh) { Tt.setOptional(ie, we, "bindMatrix"), Tt.setOptional(ie, we, "bindMatrixInverse"); const Mn = we.skeleton; Mn && ($.floatVertexTextures ? (Mn.boneTexture === null && Mn.computeBoneTexture(), Tt.setValue(ie, "boneTexture", Mn.boneTexture, H), Tt.setValue(ie, "boneTextureSize", Mn.boneTextureSize)) : Tt.setOptional(ie, Mn, "boneMatrices")); } return (ln || We.receiveShadow !== we.receiveShadow) && (We.receiveShadow = we.receiveShadow, Tt.setValue(ie, "receiveShadow", we.receiveShadow)), ln && (Tt.setValue(ie, "toneMappingExposure", u.toneMappingExposure), We.needsLights && Ze(is, ns), Ce && pe.fog && Z.refreshFogUniforms(is, Ce), Z.refreshMaterialUniforms(is, pe, T, I, U), Or.upload(ie, We.uniformsList, is, H)), pe.isShaderMaterial && pe.uniformsNeedUpdate === true && (Or.upload(ie, We.uniformsList, is, H), pe.uniformsNeedUpdate = false), pe.isSpriteMaterial && Tt.setValue(ie, "center", we.center), Tt.setValue(ie, "modelViewMatrix", we.modelViewMatrix), Tt.setValue(ie, "normalMatrix", we.normalMatrix), Tt.setValue(ie, "modelMatrix", we.matrixWorld), ft; } function Ze(J, ye) { J.ambientLightColor.needsUpdate = ye, J.lightProbe.needsUpdate = ye, J.directionalLights.needsUpdate = ye, J.directionalLightShadows.needsUpdate = ye, J.pointLights.needsUpdate = ye, J.pointLightShadows.needsUpdate = ye, J.spotLights.needsUpdate = ye, J.spotLightShadows.needsUpdate = ye, J.rectAreaLights.needsUpdate = ye, J.hemisphereLights.needsUpdate = ye; } function ht(J) { return J.isMeshLambertMaterial || J.isMeshToonMaterial || J.isMeshPhongMaterial || J.isMeshStandardMaterial || J.isShadowMaterial || J.isShaderMaterial && J.lights === true; } this.getActiveCubeFace = function() { return v; }, this.getActiveMipmapLevel = function() { return m; }, this.getRenderTarget = function() { return x; }, this.setRenderTarget = function(J, ye = 0, pe = 0) { x = J, v = ye, m = pe, J && V.get(J).__webglFramebuffer === void 0 && H.setupRenderTarget(J); let we = null, Ce = false, ge = false; if (J) { const Fe = J.texture; (Fe.isDataTexture3D || Fe.isDataTexture2DArray) && (ge = true); const Ge = V.get(J).__webglFramebuffer; J.isWebGLCubeRenderTarget ? (we = Ge[ye], Ce = true) : J.isWebGLMultisampleRenderTarget ? we = V.get(J).__webglMultisampledFramebuffer : we = Ge, M.copy(J.viewport), R.copy(J.scissor), L = J.scissorTest; } else M.copy(C).multiplyScalar(T).floor(), R.copy(P).multiplyScalar(T).floor(), L = b; if (j.bindFramebuffer(36160, we) && $.drawBuffers) { let Fe = false; if (J) if (J.isWebGLMultipleRenderTargets) { const Ge = J.texture; if (F.length !== Ge.length || F[0] !== 36064) { for (let We = 0, et = Ge.length; We < et; We++) F[We] = 36064 + We; F.length = Ge.length, Fe = true; } } else (F.length !== 1 || F[0] !== 36064) && (F[0] = 36064, F.length = 1, Fe = true); else (F.length !== 1 || F[0] !== 1029) && (F[0] = 1029, F.length = 1, Fe = true); Fe && ($.isWebGL2 ? ie.drawBuffers(F) : W.get("WEBGL_draw_buffers").drawBuffersWEBGL(F)); } if (j.viewport(M), j.scissor(R), j.setScissorTest(L), Ce) { const Fe = V.get(J.texture); ie.framebufferTexture2D(36160, 36064, 34069 + ye, Fe.__webglTexture, pe); } else if (ge) { const Fe = V.get(J.texture), Ge = ye || 0; ie.framebufferTextureLayer(36160, 36064, Fe.__webglTexture, pe || 0, Ge); } }, this.readRenderTargetPixels = function(J, ye, pe, we, Ce, ge, Se) { if (!(J && J.isWebGLRenderTarget)) { console.error("THREE.WebGLRenderer.readRenderTargetPixels: renderTarget is not THREE.WebGLRenderTarget."); return; } let Fe = V.get(J).__webglFramebuffer; if (J.isWebGLCubeRenderTarget && Se !== void 0 && (Fe = Fe[Se]), Fe) { j.bindFramebuffer(36160, Fe); try { const Ge = J.texture, We = Ge.format, et = Ge.type; if (We !== Gn && me.convert(We) !== ie.getParameter(35739)) { console.error("THREE.WebGLRenderer.readRenderTargetPixels: renderTarget is not in RGBA or implementation defined format."); return; } const Ye = et === Ms && (W.has("EXT_color_buffer_half_float") || $.isWebGL2 && W.has("EXT_color_buffer_float")); if (et !== Ts && me.convert(et) !== ie.getParameter(35738) && // Edge and Chrome Mac < 52 (#9513) !(et === qi && ($.isWebGL2 || W.has("OES_texture_float") || W.has("WEBGL_color_buffer_float"))) && // Chrome Mac >= 52 and Firefox !Ye) { console.error("THREE.WebGLRenderer.readRenderTargetPixels: renderTarget is not in UnsignedByteType or implementation defined type."); return; } ie.checkFramebufferStatus(36160) === 36053 ? ye >= 0 && ye <= J.width - we && pe >= 0 && pe <= J.height - Ce && ie.readPixels(ye, pe, we, Ce, me.convert(We), me.convert(et), ge) : console.error("THREE.WebGLRenderer.readRenderTargetPixels: readPixels from renderTarget failed. Framebuffer not complete."); } finally { const Ge = x !== null ? V.get(x).__webglFramebuffer : null; j.bindFramebuffer(36160, Ge); } } }, this.copyFramebufferToTexture = function(J, ye, pe = 0) { const we = Math.pow(2, -pe), Ce = Math.floor(ye.image.width * we), ge = Math.floor(ye.image.height * we); let Se = me.convert(ye.format); $.isWebGL2 && (Se === 6407 && (Se = 32849), Se === 6408 && (Se = 32856)), H.setTexture2D(ye, 0), ie.copyTexImage2D(3553, pe, Se, J.x, J.y, Ce, ge, 0), j.unbindTexture(); }, this.copyTextureToTexture = function(J, ye, pe, we = 0) { const Ce = ye.image.width, ge = ye.image.height, Se = me.convert(pe.format), Fe = me.convert(pe.type); H.setTexture2D(pe, 0), ie.pixelStorei(37440, pe.flipY), ie.pixelStorei(37441, pe.premultiplyAlpha), ie.pixelStorei(3317, pe.unpackAlignment), ye.isDataTexture ? ie.texSubImage2D(3553, we, J.x, J.y, Ce, ge, Se, Fe, ye.image.data) : ye.isCompressedTexture ? ie.compressedTexSubImage2D(3553, we, J.x, J.y, ye.mipmaps[0].width, ye.mipmaps[0].height, Se, ye.mipmaps[0].data) : ie.texSubImage2D(3553, we, J.x, J.y, Se, Fe, ye.image), we === 0 && pe.generateMipmaps && ie.generateMipmap(3553), j.unbindTexture(); }, this.copyTextureToTexture3D = function(J, ye, pe, we, Ce = 0) { if (u.isWebGL1Renderer) { console.warn("THREE.WebGLRenderer.copyTextureToTexture3D: can only be used with WebGL2."); return; } const ge = J.max.x - J.min.x + 1, Se = J.max.y - J.min.y + 1, Fe = J.max.z - J.min.z + 1, Ge = me.convert(we.format), We = me.convert(we.type); let et; if (we.isDataTexture3D) H.setTexture3D(we, 0), et = 32879; else if (we.isDataTexture2DArray) H.setTexture2DArray(we, 0), et = 35866; else { console.warn("THREE.WebGLRenderer.copyTextureToTexture3D: only supports THREE.DataTexture3D and THREE.DataTexture2DArray."); return; } ie.pixelStorei(37440, we.flipY), ie.pixelStorei(37441, we.premultiplyAlpha), ie.pixelStorei(3317, we.unpackAlignment); const Ye = ie.getParameter(3314), ft = ie.getParameter(32878), kt = ie.getParameter(3316), ln = ie.getParameter(3315), ns = ie.getParameter(32877), Tt = pe.isCompressedTexture ? pe.mipmaps[0] : pe.image; ie.pixelStorei(3314, Tt.width), ie.pixelStorei(32878, Tt.height), ie.pixelStorei(3316, J.min.x), ie.pixelStorei(3315, J.min.y), ie.pixelStorei(32877, J.min.z), pe.isDataTexture || pe.isDataTexture3D ? ie.texSubImage3D(et, Ce, ye.x, ye.y, ye.z, ge, Se, Fe, Ge, We, Tt.data) : pe.isCompressedTexture ? (console.warn("THREE.WebGLRenderer.copyTextureToTexture3D: untested support for compressed srcTexture."), ie.compressedTexSubImage3D(et, Ce, ye.x, ye.y, ye.z, ge, Se, Fe, Ge, Tt.data)) : ie.texSubImage3D(et, Ce, ye.x, ye.y, ye.z, ge, Se, Fe, Ge, We, Tt), ie.pixelStorei(3314, Ye), ie.pixelStorei(32878, ft), ie.pixelStorei(3316, kt), ie.pixelStorei(3315, ln), ie.pixelStorei(32877, ns), Ce === 0 && we.generateMipmaps && ie.generateMipmap(et), j.unbindTexture(); }, this.initTexture = function(J) { H.setTexture2D(J, 0), j.unbindTexture(); }, this.resetState = function() { v = 0, m = 0, x = null, j.reset(), Me.reset(); }, typeof __THREE_DEVTOOLS__ < "u" && __THREE_DEVTOOLS__.dispatchEvent(new CustomEvent("observe", { detail: this })); } var wx = class extends wt { }; wx.prototype.isWebGL1Renderer = true; var fl = class _fl { constructor(e, t = 25e-5) { this.name = "", this.color = new Ue(e), this.density = t; } clone() { return new _fl(this.color, this.density); } toJSON() { return { type: "FogExp2", color: this.color.getHex(), density: this.density }; } }; fl.prototype.isFogExp2 = true; var pl = class _pl { constructor(e, t = 1, i = 1e3) { this.name = "", this.color = new Ue(e), this.near = t, this.far = i; } clone() { return new _pl(this.color, this.near, this.far); } toJSON() { return { type: "Fog", color: this.color.getHex(), near: this.near, far: this.far }; } }; pl.prototype.isFog = true; var wu = class extends ut { constructor() { super(), this.type = "Scene", this.background = null, this.environment = null, this.fog = null, this.overrideMaterial = null, this.autoUpdate = true, typeof __THREE_DEVTOOLS__ < "u" && __THREE_DEVTOOLS__.dispatchEvent(new CustomEvent("observe", { detail: this })); } copy(e, t) { return super.copy(e, t), e.background !== null && (this.background = e.background.clone()), e.environment !== null && (this.environment = e.environment.clone()), e.fog !== null && (this.fog = e.fog.clone()), e.overrideMaterial !== null && (this.overrideMaterial = e.overrideMaterial.clone()), this.autoUpdate = e.autoUpdate, this.matrixAutoUpdate = e.matrixAutoUpdate, this; } toJSON(e) { const t = super.toJSON(e); return this.fog !== null && (t.object.fog = this.fog.toJSON()), t; } }; wu.prototype.isScene = true; var Qr = class { constructor(e, t) { this.array = e, this.stride = t, this.count = e !== void 0 ? e.length / t : 0, this.usage = Ro, this.updateRange = { offset: 0, count: -1 }, this.version = 0, this.uuid = Hn(); } onUploadCallback() { } set needsUpdate(e) { e === true && this.version++; } setUsage(e) { return this.usage = e, this; } copy(e) { return this.array = new e.array.constructor(e.array), this.count = e.count, this.stride = e.stride, this.usage = e.usage, this; } copyAt(e, t, i) { e *= this.stride, i *= t.stride; for (let r = 0, s = this.stride; r < s; r++) this.array[e + r] = t.array[i + r]; return this; } set(e, t = 0) { return this.array.set(e, t), this; } clone(e) { e.arrayBuffers === void 0 && (e.arrayBuffers = {}), this.array.buffer._uuid === void 0 && (this.array.buffer._uuid = Hn()), e.arrayBuffers[this.array.buffer._uuid] === void 0 && (e.arrayBuffers[this.array.buffer._uuid] = this.array.slice(0).buffer); const t = new this.array.constructor(e.arrayBuffers[this.array.buffer._uuid]), i = new this.constructor(t, this.stride); return i.setUsage(this.usage), i; } onUpload(e) { return this.onUploadCallback = e, this; } toJSON(e) { return e.arrayBuffers === void 0 && (e.arrayBuffers = {}), this.array.buffer._uuid === void 0 && (this.array.buffer._uuid = Hn()), e.arrayBuffers[this.array.buffer._uuid] === void 0 && (e.arrayBuffers[this.array.buffer._uuid] = Array.prototype.slice.call(new Uint32Array(this.array.buffer))), { uuid: this.uuid, buffer: this.array.buffer._uuid, type: this.array.constructor.name, stride: this.stride }; } }; Qr.prototype.isInterleavedBuffer = true; var Gt = new q(); var ar = class _ar { constructor(e, t, i, r = false) { this.name = "", this.data = e, this.itemSize = t, this.offset = i, this.normalized = r === true; } get count() { return this.data.count; } get array() { return this.data.array; } set needsUpdate(e) { this.data.needsUpdate = e; } applyMatrix4(e) { for (let t = 0, i = this.data.count; t < i; t++) Gt.x = this.getX(t), Gt.y = this.getY(t), Gt.z = this.getZ(t), Gt.applyMatrix4(e), this.setXYZ(t, Gt.x, Gt.y, Gt.z); return this; } applyNormalMatrix(e) { for (let t = 0, i = this.count; t < i; t++) Gt.x = this.getX(t), Gt.y = this.getY(t), Gt.z = this.getZ(t), Gt.applyNormalMatrix(e), this.setXYZ(t, Gt.x, Gt.y, Gt.z); return this; } transformDirection(e) { for (let t = 0, i = this.count; t < i; t++) Gt.x = this.getX(t), Gt.y = this.getY(t), Gt.z = this.getZ(t), Gt.transformDirection(e), this.setXYZ(t, Gt.x, Gt.y, Gt.z); return this; } setX(e, t) { return this.data.array[e * this.data.stride + this.offset] = t, this; } setY(e, t) { return this.data.array[e * this.data.stride + this.offset + 1] = t, this; } setZ(e, t) { return this.data.array[e * this.data.stride + this.offset + 2] = t, this; } setW(e, t) { return this.data.array[e * this.data.stride + this.offset + 3] = t, this; } getX(e) { return this.data.array[e * this.data.stride + this.offset]; } getY(e) { return this.data.array[e * this.data.stride + this.offset + 1]; } getZ(e) { return this.data.array[e * this.data.stride + this.offset + 2]; } getW(e) { return this.data.array[e * this.data.stride + this.offset + 3]; } setXY(e, t, i) { return e = e * this.data.stride + this.offset, this.data.array[e + 0] = t, this.data.array[e + 1] = i, this; } setXYZ(e, t, i, r) { return e = e * this.data.stride + this.offset, this.data.array[e + 0] = t, this.data.array[e + 1] = i, this.data.array[e + 2] = r, this; } setXYZW(e, t, i, r, s) { return e = e * this.data.stride + this.offset, this.data.array[e + 0] = t, this.data.array[e + 1] = i, this.data.array[e + 2] = r, this.data.array[e + 3] = s, this; } clone(e) { if (e === void 0) { console.log("THREE.InterleavedBufferAttribute.clone(): Cloning an interlaved buffer attribute will deinterleave buffer data."); const t = []; for (let i = 0; i < this.count; i++) { const r = i * this.data.stride + this.offset; for (let s = 0; s < this.itemSize; s++) t.push(this.data.array[r + s]); } return new ot(new this.array.constructor(t), this.itemSize, this.normalized); } else return e.interleavedBuffers === void 0 && (e.interleavedBuffers = {}), e.interleavedBuffers[this.data.uuid] === void 0 && (e.interleavedBuffers[this.data.uuid] = this.data.clone(e)), new _ar(e.interleavedBuffers[this.data.uuid], this.itemSize, this.offset, this.normalized); } toJSON(e) { if (e === void 0) { console.log("THREE.InterleavedBufferAttribute.toJSON(): Serializing an interlaved buffer attribute will deinterleave buffer data."); const t = []; for (let i = 0; i < this.count; i++) { const r = i * this.data.stride + this.offset; for (let s = 0; s < this.itemSize; s++) t.push(this.data.array[r + s]); } return { itemSize: this.itemSize, type: this.array.constructor.name, array: t, normalized: this.normalized }; } else return e.interleavedBuffers === void 0 && (e.interleavedBuffers = {}), e.interleavedBuffers[this.data.uuid] === void 0 && (e.interleavedBuffers[this.data.uuid] = this.data.toJSON(e)), { isInterleavedBufferAttribute: true, itemSize: this.itemSize, data: this.data.uuid, offset: this.offset, normalized: this.normalized }; } }; ar.prototype.isInterleavedBufferAttribute = true; var ml = class extends tn { constructor(e) { super(), this.type = "SpriteMaterial", this.color = new Ue(16777215), this.map = null, this.alphaMap = null, this.rotation = 0, this.sizeAttenuation = true, this.transparent = true, this.setValues(e); } copy(e) { return super.copy(e), this.color.copy(e.color), this.map = e.map, this.alphaMap = e.alphaMap, this.rotation = e.rotation, this.sizeAttenuation = e.sizeAttenuation, this; } }; ml.prototype.isSpriteMaterial = true; var ro; var ga = new q(); var so = new q(); var oo = new q(); var ao = new Re(); var va = new Re(); var Ax = new Xe(); var Kl = new q(); var ya = new q(); var ql = new q(); var yg = new Re(); var vh = new Re(); var bg = new Re(); var gl = class extends ut { constructor(e) { if (super(), this.type = "Sprite", ro === void 0) { ro = new Ke(); const t = new Float32Array([ -0.5, -0.5, 0, 0, 0, 0.5, -0.5, 0, 1, 0, 0.5, 0.5, 0, 1, 1, -0.5, 0.5, 0, 0, 1 ]), i = new Qr(t, 5); ro.setIndex([0, 1, 2, 0, 2, 3]), ro.setAttribute("position", new ar(i, 3, 0, false)), ro.setAttribute("uv", new ar(i, 2, 3, false)); } this.geometry = ro, this.material = e !== void 0 ? e : new ml(), this.center = new Re(0.5, 0.5); } raycast(e, t) { e.camera === null && console.error('THREE.Sprite: "Raycaster.camera" needs to be set in order to raycast against sprites.'), so.setFromMatrixScale(this.matrixWorld), Ax.copy(e.camera.matrixWorld), this.modelViewMatrix.multiplyMatrices(e.camera.matrixWorldInverse, this.matrixWorld), oo.setFromMatrixPosition(this.modelViewMatrix), e.camera.isPerspectiveCamera && this.material.sizeAttenuation === false && so.multiplyScalar(-oo.z); const i = this.material.rotation; let r, s; i !== 0 && (s = Math.cos(i), r = Math.sin(i)); const o = this.center; Ql(Kl.set(-0.5, -0.5, 0), oo, o, so, r, s), Ql(ya.set(0.5, -0.5, 0), oo, o, so, r, s), Ql(ql.set(0.5, 0.5, 0), oo, o, so, r, s), yg.set(0, 0), vh.set(1, 0), bg.set(1, 1); let a = e.ray.intersectTriangle(Kl, ya, ql, false, ga); if (a === null && (Ql(ya.set(-0.5, 0.5, 0), oo, o, so, r, s), vh.set(0, 1), a = e.ray.intersectTriangle(Kl, ql, ya, false, ga), a === null)) return; const c = e.ray.origin.distanceTo(ga); c < e.near || c > e.far || t.push({ distance: c, point: ga.clone(), uv: Zt.getUV(ga, Kl, ya, ql, yg, vh, bg, new Re()), face: null, object: this }); } copy(e) { return super.copy(e), e.center !== void 0 && this.center.copy(e.center), this.material = e.material, this; } }; gl.prototype.isSprite = true; function Ql(n, e, t, i, r, s) { ao.subVectors(n, t).addScalar(0.5).multiply(i), r !== void 0 ? (va.x = s * ao.x - r * ao.y, va.y = r * ao.x + s * ao.y) : va.copy(ao), n.copy(e), n.x += va.x, n.y += va.y, n.applyMatrix4(Ax); } var ec = new q(); var xg = new q(); var Sx = class extends ut { constructor() { super(), this._currentLevel = 0, this.type = "LOD", Object.defineProperties(this, { levels: { enumerable: true, value: [] }, isLOD: { value: true } }), this.autoUpdate = true; } copy(e) { super.copy(e, false); const t = e.levels; for (let i = 0, r = t.length; i < r; i++) { const s = t[i]; this.addLevel(s.object.clone(), s.distance); } return this.autoUpdate = e.autoUpdate, this; } addLevel(e, t = 0) { t = Math.abs(t); const i = this.levels; let r; for (r = 0; r < i.length && !(t < i[r].distance); r++) ; return i.splice(r, 0, { distance: t, object: e }), this.add(e), this; } getCurrentLevel() { return this._currentLevel; } getObjectForDistance(e) { const t = this.levels; if (t.length > 0) { let i, r; for (i = 1, r = t.length; i < r && !(e < t[i].distance); i++) ; return t[i - 1].object; } return null; } raycast(e, t) { if (this.levels.length > 0) { ec.setFromMatrixPosition(this.matrixWorld); const r = e.ray.origin.distanceTo(ec); this.getObjectForDistance(r).raycast(e, t); } } update(e) { const t = this.levels; if (t.length > 1) { ec.setFromMatrixPosition(e.matrixWorld), xg.setFromMatrixPosition(this.matrixWorld); const i = ec.distanceTo(xg) / e.zoom; t[0].object.visible = true; let r, s; for (r = 1, s = t.length; r < s && i >= t[r].distance; r++) t[r - 1].object.visible = false, t[r].object.visible = true; for (this._currentLevel = r - 1; r < s; r++) t[r].object.visible = false; } } toJSON(e) { const t = super.toJSON(e); this.autoUpdate === false && (t.object.autoUpdate = false), t.object.levels = []; const i = this.levels; for (let r = 0, s = i.length; r < s; r++) { const o = i[r]; t.object.levels.push({ object: o.object.uuid, distance: o.distance }); } return t; } }; var Mg = new q(); var wg = new xt(); var Ag = new xt(); var FD = new q(); var Sg = new Xe(); var vl = class extends Xt { constructor(e, t) { super(e, t), this.type = "SkinnedMesh", this.bindMode = "attached", this.bindMatrix = new Xe(), this.bindMatrixInverse = new Xe(); } copy(e) { return super.copy(e), this.bindMode = e.bindMode, this.bindMatrix.copy(e.bindMatrix), this.bindMatrixInverse.copy(e.bindMatrixInverse), this.skeleton = e.skeleton, this; } bind(e, t) { this.skeleton = e, t === void 0 && (this.updateMatrixWorld(true), this.skeleton.calculateInverses(), t = this.matrixWorld), this.bindMatrix.copy(t), this.bindMatrixInverse.copy(t).invert(); } pose() { this.skeleton.pose(); } normalizeSkinWeights() { const e = new xt(), t = this.geometry.attributes.skinWeight; for (let i = 0, r = t.count; i < r; i++) { e.x = t.getX(i), e.y = t.getY(i), e.z = t.getZ(i), e.w = t.getW(i); const s = 1 / e.manhattanLength(); s !== 1 / 0 ? e.multiplyScalar(s) : e.set(1, 0, 0, 0), t.setXYZW(i, e.x, e.y, e.z, e.w); } } updateMatrixWorld(e) { super.updateMatrixWorld(e), this.bindMode === "attached" ? this.bindMatrixInverse.copy(this.matrixWorld).invert() : this.bindMode === "detached" ? this.bindMatrixInverse.copy(this.bindMatrix).invert() : console.warn("THREE.SkinnedMesh: Unrecognized bindMode: " + this.bindMode); } boneTransform(e, t) { const i = this.skeleton, r = this.geometry; wg.fromBufferAttribute(r.attributes.skinIndex, e), Ag.fromBufferAttribute(r.attributes.skinWeight, e), Mg.fromBufferAttribute(r.attributes.position, e).applyMatrix4(this.bindMatrix), t.set(0, 0, 0); for (let s = 0; s < 4; s++) { const o = Ag.getComponent(s); if (o !== 0) { const a = wg.getComponent(s); Sg.multiplyMatrices(i.bones[a].matrixWorld, i.boneInverses[a]), t.addScaledVector(FD.copy(Mg).applyMatrix4(Sg), o); } } return t.applyMatrix4(this.bindMatrixInverse); } }; vl.prototype.isSkinnedMesh = true; var yl = class extends ut { constructor() { super(), this.type = "Bone"; } }; yl.prototype.isBone = true; var Ss = class extends Yt { constructor(e = null, t = 1, i = 1, r, s, o, a, c, l = $t, d = $t, h6, f) { super(null, o, a, c, l, d, r, s, h6, f), this.image = { data: e, width: t, height: i }, this.magFilter = l, this.minFilter = d, this.generateMipmaps = false, this.flipY = false, this.unpackAlignment = 1, this.needsUpdate = true; } }; Ss.prototype.isDataTexture = true; var _g = new Xe(); var PD = new Xe(); var bl = class _bl { constructor(e = [], t = []) { this.uuid = Hn(), this.bones = e.slice(0), this.boneInverses = t, this.boneMatrices = null, this.boneTexture = null, this.boneTextureSize = 0, this.frame = -1, this.init(); } init() { const e = this.bones, t = this.boneInverses; if (this.boneMatrices = new Float32Array(e.length * 16), t.length === 0) this.calculateInverses(); else if (e.length !== t.length) { console.warn("THREE.Skeleton: Number of inverse bone matrices does not match amount of bones."), this.boneInverses = []; for (let i = 0, r = this.bones.length; i < r; i++) this.boneInverses.push(new Xe()); } } calculateInverses() { this.boneInverses.length = 0; for (let e = 0, t = this.bones.length; e < t; e++) { const i = new Xe(); this.bones[e] && i.copy(this.bones[e].matrixWorld).invert(), this.boneInverses.push(i); } } pose() { for (let e = 0, t = this.bones.length; e < t; e++) { const i = this.bones[e]; i && i.matrixWorld.copy(this.boneInverses[e]).invert(); } for (let e = 0, t = this.bones.length; e < t; e++) { const i = this.bones[e]; i && (i.parent && i.parent.isBone ? (i.matrix.copy(i.parent.matrixWorld).invert(), i.matrix.multiply(i.matrixWorld)) : i.matrix.copy(i.matrixWorld), i.matrix.decompose(i.position, i.quaternion, i.scale)); } } update() { const e = this.bones, t = this.boneInverses, i = this.boneMatrices, r = this.boneTexture; for (let s = 0, o = e.length; s < o; s++) { const a = e[s] ? e[s].matrixWorld : PD; _g.multiplyMatrices(a, t[s]), _g.toArray(i, s * 16); } r !== null && (r.needsUpdate = true); } clone() { return new _bl(this.bones, this.boneInverses); } computeBoneTexture() { let e = Math.sqrt(this.bones.length * 4); e = Qb(e), e = Math.max(e, 4); const t = new Float32Array(e * e * 4); t.set(this.boneMatrices); const i = new Ss(t, e, e, Gn, qi); return this.boneMatrices = t, this.boneTexture = i, this.boneTextureSize = e, this; } getBoneByName(e) { for (let t = 0, i = this.bones.length; t < i; t++) { const r = this.bones[t]; if (r.name === e) return r; } } dispose() { this.boneTexture !== null && (this.boneTexture.dispose(), this.boneTexture = null); } fromJSON(e, t) { this.uuid = e.uuid; for (let i = 0, r = e.bones.length; i < r; i++) { const s = e.bones[i]; let o = t[s]; o === void 0 && (console.warn("THREE.Skeleton: No bone found with UUID:", s), o = new yl()), this.bones.push(o), this.boneInverses.push(new Xe().fromArray(e.boneInverses[i])); } return this.init(), this; } toJSON() { const e = { metadata: { version: 4.5, type: "Skeleton", generator: "Skeleton.toJSON" }, bones: [], boneInverses: [] }; e.uuid = this.uuid; const t = this.bones, i = this.boneInverses; for (let r = 0, s = t.length; r < s; r++) { const o = t[r]; e.bones.push(o.uuid); const a = i[r]; e.boneInverses.push(a.toArray()); } return e; } }; var Tg = new Xe(); var Eg = new Xe(); var tc = []; var ba = new Xt(); var Pf = class extends Xt { constructor(e, t, i) { super(e, t), this.instanceMatrix = new ot(new Float32Array(i * 16), 16), this.instanceColor = null, this.count = i, this.frustumCulled = false; } copy(e) { return super.copy(e), this.instanceMatrix.copy(e.instanceMatrix), e.instanceColor !== null && (this.instanceColor = e.instanceColor.clone()), this.count = e.count, this; } getColorAt(e, t) { t.fromArray(this.instanceColor.array, e * 3); } getMatrixAt(e, t) { t.fromArray(this.instanceMatrix.array, e * 16); } raycast(e, t) { const i = this.matrixWorld, r = this.count; if (ba.geometry = this.geometry, ba.material = this.material, ba.material !== void 0) for (let s = 0; s < r; s++) { this.getMatrixAt(s, Tg), Eg.multiplyMatrices(i, Tg), ba.matrixWorld = Eg, ba.raycast(e, tc); for (let o = 0, a = tc.length; o < a; o++) { const c = tc[o]; c.instanceId = s, c.object = this, t.push(c); } tc.length = 0; } } setColorAt(e, t) { this.instanceColor === null && (this.instanceColor = new ot(new Float32Array(this.count * 3), 3)), t.toArray(this.instanceColor.array, e * 3); } setMatrixAt(e, t) { t.toArray(this.instanceMatrix.array, e * 16); } updateMorphTargets() { } dispose() { this.dispatchEvent({ type: "dispose" }); } }; Pf.prototype.isInstancedMesh = true; var an = class extends tn { constructor(e) { super(), this.type = "LineBasicMaterial", this.color = new Ue(16777215), this.linewidth = 1, this.linecap = "round", this.linejoin = "round", this.morphTargets = false, this.setValues(e); } copy(e) { return super.copy(e), this.color.copy(e.color), this.linewidth = e.linewidth, this.linecap = e.linecap, this.linejoin = e.linejoin, this.morphTargets = e.morphTargets, this; } }; an.prototype.isLineBasicMaterial = true; var Cg = new q(); var Lg = new q(); var Rg = new Xe(); var yh = new qr(); var nc = new pr(); var Oi = class extends ut { constructor(e = new Ke(), t = new an()) { super(), this.type = "Line", this.geometry = e, this.material = t, this.updateMorphTargets(); } copy(e) { return super.copy(e), this.material = e.material, this.geometry = e.geometry, this; } computeLineDistances() { const e = this.geometry; if (e.isBufferGeometry) if (e.index === null) { const t = e.attributes.position, i = [0]; for (let r = 1, s = t.count; r < s; r++) Cg.fromBufferAttribute(t, r - 1), Lg.fromBufferAttribute(t, r), i[r] = i[r - 1], i[r] += Cg.distanceTo(Lg); e.setAttribute("lineDistance", new He(i, 1)); } else console.warn("THREE.Line.computeLineDistances(): Computation only possible with non-indexed BufferGeometry."); else e.isGeometry && console.error("THREE.Line.computeLineDistances() no longer supports THREE.Geometry. Use THREE.BufferGeometry instead."); return this; } raycast(e, t) { const i = this.geometry, r = this.matrixWorld, s = e.params.Line.threshold, o = i.drawRange; if (i.boundingSphere === null && i.computeBoundingSphere(), nc.copy(i.boundingSphere), nc.applyMatrix4(r), nc.radius += s, e.ray.intersectsSphere(nc) === false) return; Rg.copy(r).invert(), yh.copy(e.ray).applyMatrix4(Rg); const a = s / ((this.scale.x + this.scale.y + this.scale.z) / 3), c = a * a, l = new q(), d = new q(), h6 = new q(), f = new q(), g = this.isLineSegments ? 2 : 1; if (i.isBufferGeometry) { const p = i.index, y = i.attributes.position; if (p !== null) { const v = Math.max(0, o.start), m = Math.min(p.count, o.start + o.count); for (let x = v, w = m - 1; x < w; x += g) { const A = p.getX(x), M = p.getX(x + 1); if (l.fromBufferAttribute(y, A), d.fromBufferAttribute(y, M), yh.distanceSqToSegment(l, d, f, h6) > c) continue; f.applyMatrix4(this.matrixWorld); const L = e.ray.origin.distanceTo(f); L < e.near || L > e.far || t.push({ distance: L, // What do we want? intersection point on the ray or on the segment?? // point: raycaster.ray.at( distance ), point: h6.clone().applyMatrix4(this.matrixWorld), index: x, face: null, faceIndex: null, object: this }); } } else { const v = Math.max(0, o.start), m = Math.min(y.count, o.start + o.count); for (let x = v, w = m - 1; x < w; x += g) { if (l.fromBufferAttribute(y, x), d.fromBufferAttribute(y, x + 1), yh.distanceSqToSegment(l, d, f, h6) > c) continue; f.applyMatrix4(this.matrixWorld); const M = e.ray.origin.distanceTo(f); M < e.near || M > e.far || t.push({ distance: M, // What do we want? intersection point on the ray or on the segment?? // point: raycaster.ray.at( distance ), point: h6.clone().applyMatrix4(this.matrixWorld), index: x, face: null, faceIndex: null, object: this }); } } } else i.isGeometry && console.error("THREE.Line.raycast() no longer supports THREE.Geometry. Use THREE.BufferGeometry instead."); } updateMorphTargets() { const e = this.geometry; if (e.isBufferGeometry) { const t = e.morphAttributes, i = Object.keys(t); if (i.length > 0) { const r = t[i[0]]; if (r !== void 0) { this.morphTargetInfluences = [], this.morphTargetDictionary = {}; for (let s = 0, o = r.length; s < o; s++) { const a = r[s].name || String(s); this.morphTargetInfluences.push(0), this.morphTargetDictionary[a] = s; } } } } else { const t = e.morphTargets; t !== void 0 && t.length > 0 && console.error("THREE.Line.updateMorphTargets() does not support THREE.Geometry. Use THREE.BufferGeometry instead."); } } }; Oi.prototype.isLine = true; var Fg = new q(); var Pg = new q(); var Rn = class extends Oi { constructor(e, t) { super(e, t), this.type = "LineSegments"; } computeLineDistances() { const e = this.geometry; if (e.isBufferGeometry) if (e.index === null) { const t = e.attributes.position, i = []; for (let r = 0, s = t.count; r < s; r += 2) Fg.fromBufferAttribute(t, r), Pg.fromBufferAttribute(t, r + 1), i[r] = r === 0 ? 0 : i[r - 1], i[r + 1] = i[r] + Fg.distanceTo(Pg); e.setAttribute("lineDistance", new He(i, 1)); } else console.warn("THREE.LineSegments.computeLineDistances(): Computation only possible with non-indexed BufferGeometry."); else e.isGeometry && console.error("THREE.LineSegments.computeLineDistances() no longer supports THREE.Geometry. Use THREE.BufferGeometry instead."); return this; } }; Rn.prototype.isLineSegments = true; var Au = class extends Oi { constructor(e, t) { super(e, t), this.type = "LineLoop"; } }; Au.prototype.isLineLoop = true; var es = class extends tn { constructor(e) { super(), this.type = "PointsMaterial", this.color = new Ue(16777215), this.map = null, this.alphaMap = null, this.size = 1, this.sizeAttenuation = true, this.morphTargets = false, this.setValues(e); } copy(e) { return super.copy(e), this.color.copy(e.color), this.map = e.map, this.alphaMap = e.alphaMap, this.size = e.size, this.sizeAttenuation = e.sizeAttenuation, this.morphTargets = e.morphTargets, this; } }; es.prototype.isPointsMaterial = true; var Ig = new Xe(); var wd = new qr(); var ic = new pr(); var rc = new q(); var ia = class extends ut { constructor(e = new Ke(), t = new es()) { super(), this.type = "Points", this.geometry = e, this.material = t, this.updateMorphTargets(); } copy(e) { return super.copy(e), this.material = e.material, this.geometry = e.geometry, this; } raycast(e, t) { const i = this.geometry, r = this.matrixWorld, s = e.params.Points.threshold, o = i.drawRange; if (i.boundingSphere === null && i.computeBoundingSphere(), ic.copy(i.boundingSphere), ic.applyMatrix4(r), ic.radius += s, e.ray.intersectsSphere(ic) === false) return; Ig.copy(r).invert(), wd.copy(e.ray).applyMatrix4(Ig); const a = s / ((this.scale.x + this.scale.y + this.scale.z) / 3), c = a * a; if (i.isBufferGeometry) { const l = i.index, h6 = i.attributes.position; if (l !== null) { const f = Math.max(0, o.start), g = Math.min(l.count, o.start + o.count); for (let p = f, u = g; p < u; p++) { const y = l.getX(p); rc.fromBufferAttribute(h6, y), Og(rc, y, c, r, e, t, this); } } else { const f = Math.max(0, o.start), g = Math.min(h6.count, o.start + o.count); for (let p = f, u = g; p < u; p++) rc.fromBufferAttribute(h6, p), Og(rc, p, c, r, e, t, this); } } else console.error("THREE.Points.raycast() no longer supports THREE.Geometry. Use THREE.BufferGeometry instead."); } updateMorphTargets() { const e = this.geometry; if (e.isBufferGeometry) { const t = e.morphAttributes, i = Object.keys(t); if (i.length > 0) { const r = t[i[0]]; if (r !== void 0) { this.morphTargetInfluences = [], this.morphTargetDictionary = {}; for (let s = 0, o = r.length; s < o; s++) { const a = r[s].name || String(s); this.morphTargetInfluences.push(0), this.morphTargetDictionary[a] = s; } } } } else { const t = e.morphTargets; t !== void 0 && t.length > 0 && console.error("THREE.Points.updateMorphTargets() does not support THREE.Geometry. Use THREE.BufferGeometry instead."); } } }; ia.prototype.isPoints = true; function Og(n, e, t, i, r, s, o) { const a = wd.distanceSqToPoint(n); if (a < t) { const c = new q(); wd.closestPointToPoint(n, c), c.applyMatrix4(i); const l = r.ray.origin.distanceTo(c); if (l < r.near || l > r.far) return; s.push({ distance: l, distanceToRay: Math.sqrt(a), point: c, index: e, face: null, object: o }); } } var _x = class extends Yt { constructor(e, t, i, r, s, o, a, c, l) { super(e, t, i, r, s, o, a, c, l), this.format = a !== void 0 ? a : nr, this.minFilter = o !== void 0 ? o : zt, this.magFilter = s !== void 0 ? s : zt, this.generateMipmaps = false; const d = this; function h6() { d.needsUpdate = true, e.requestVideoFrameCallback(h6); } "requestVideoFrameCallback" in e && e.requestVideoFrameCallback(h6); } clone() { return new this.constructor(this.image).copy(this); } update() { const e = this.image; "requestVideoFrameCallback" in e === false && e.readyState >= e.HAVE_CURRENT_DATA && (this.needsUpdate = true); } }; _x.prototype.isVideoTexture = true; var If = class extends Yt { constructor(e, t, i, r, s, o, a, c, l, d, h6, f) { super(null, o, a, c, l, d, r, s, h6, f), this.image = { width: t, height: i }, this.mipmaps = e, this.flipY = false, this.generateMipmaps = false; } }; If.prototype.isCompressedTexture = true; var Tx = class extends Yt { constructor(e, t, i, r, s, o, a, c, l) { super(e, t, i, r, s, o, a, c, l), this.needsUpdate = true; } }; Tx.prototype.isCanvasTexture = true; var Ex = class extends Yt { constructor(e, t, i, r, s, o, a, c, l, d) { if (d = d !== void 0 ? d : ws, d !== ws && d !== Co) throw new Error("DepthTexture format must be either THREE.DepthFormat or THREE.DepthStencilFormat"); i === void 0 && d === ws && (i = Ha), i === void 0 && d === Co && (i = yo), super(null, r, s, o, a, c, d, i, l), this.image = { width: e, height: t }, this.magFilter = a !== void 0 ? a : $t, this.minFilter = c !== void 0 ? c : $t, this.flipY = false, this.generateMipmaps = false; } }; Ex.prototype.isDepthTexture = true; var Io = class _Io extends Ke { constructor(e = 1, t = 8, i = 0, r = Math.PI * 2) { super(), this.type = "CircleGeometry", this.parameters = { radius: e, segments: t, thetaStart: i, thetaLength: r }, t = Math.max(3, t); const s = [], o = [], a = [], c = [], l = new q(), d = new Re(); o.push(0, 0, 0), a.push(0, 0, 1), c.push(0.5, 0.5); for (let h6 = 0, f = 3; h6 <= t; h6++, f += 3) { const g = i + h6 / t * r; l.x = e * Math.cos(g), l.y = e * Math.sin(g), o.push(l.x, l.y, l.z), a.push(0, 0, 1), d.x = (o[f] / e + 1) / 2, d.y = (o[f + 1] / e + 1) / 2, c.push(d.x, d.y); } for (let h6 = 1; h6 <= t; h6++) s.push(h6, h6 + 1, 0); this.setIndex(s), this.setAttribute("position", new He(o, 3)), this.setAttribute("normal", new He(a, 3)), this.setAttribute("uv", new He(c, 2)); } static fromJSON(e) { return new _Io(e.radius, e.segments, e.thetaStart, e.thetaLength); } }; var $r = class _$r extends Ke { constructor(e = 1, t = 1, i = 1, r = 8, s = 1, o = false, a = 0, c = Math.PI * 2) { super(), this.type = "CylinderGeometry", this.parameters = { radiusTop: e, radiusBottom: t, height: i, radialSegments: r, heightSegments: s, openEnded: o, thetaStart: a, thetaLength: c }; const l = this; r = Math.floor(r), s = Math.floor(s); const d = [], h6 = [], f = [], g = []; let p = 0; const u = [], y = i / 2; let v = 0; m(), o === false && (e > 0 && x(true), t > 0 && x(false)), this.setIndex(d), this.setAttribute("position", new He(h6, 3)), this.setAttribute("normal", new He(f, 3)), this.setAttribute("uv", new He(g, 2)); function m() { const w = new q(), A = new q(); let M = 0; const R = (t - e) / i; for (let L = 0; L <= s; L++) { const S = [], I = L / s, T = I * (t - e) + e; for (let _ = 0; _ <= r; _++) { const E = _ / r, C = E * c + a, P = Math.sin(C), b = Math.cos(C); A.x = T * P, A.y = -I * i + y, A.z = T * b, h6.push(A.x, A.y, A.z), w.set(P, R, b).normalize(), f.push(w.x, w.y, w.z), g.push(E, 1 - I), S.push(p++); } u.push(S); } for (let L = 0; L < r; L++) for (let S = 0; S < s; S++) { const I = u[S][L], T = u[S + 1][L], _ = u[S + 1][L + 1], E = u[S][L + 1]; d.push(I, T, E), d.push(T, _, E), M += 6; } l.addGroup(v, M, 0), v += M; } function x(w) { const A = p, M = new Re(), R = new q(); let L = 0; const S = w === true ? e : t, I = w === true ? 1 : -1; for (let _ = 1; _ <= r; _++) h6.push(0, y * I, 0), f.push(0, I, 0), g.push(0.5, 0.5), p++; const T = p; for (let _ = 0; _ <= r; _++) { const C = _ / r * c + a, P = Math.cos(C), b = Math.sin(C); R.x = S * b, R.y = y * I, R.z = S * P, h6.push(R.x, R.y, R.z), f.push(0, I, 0), M.x = P * 0.5 + 0.5, M.y = b * 0.5 * I + 0.5, g.push(M.x, M.y), p++; } for (let _ = 0; _ < r; _++) { const E = A + _, C = T + _; w === true ? d.push(C, C + 1, E) : d.push(C + 1, C, E), L += 3; } l.addGroup(v, L, w === true ? 1 : 2), v += L; } } static fromJSON(e) { return new _$r(e.radiusTop, e.radiusBottom, e.height, e.radialSegments, e.heightSegments, e.openEnded, e.thetaStart, e.thetaLength); } }; var Oo = class _Oo extends $r { constructor(e = 1, t = 1, i = 8, r = 1, s = false, o = 0, a = Math.PI * 2) { super(0, e, t, i, r, s, o, a), this.type = "ConeGeometry", this.parameters = { radius: e, height: t, radialSegments: i, heightSegments: r, openEnded: s, thetaStart: o, thetaLength: a }; } static fromJSON(e) { return new _Oo(e.radius, e.height, e.radialSegments, e.heightSegments, e.openEnded, e.thetaStart, e.thetaLength); } }; var Di = class _Di extends Ke { constructor(e, t, i = 1, r = 0) { super(), this.type = "PolyhedronGeometry", this.parameters = { vertices: e, indices: t, radius: i, detail: r }; const s = [], o = []; a(r), l(i), d(), this.setAttribute("position", new He(s, 3)), this.setAttribute("normal", new He(s.slice(), 3)), this.setAttribute("uv", new He(o, 2)), r === 0 ? this.computeVertexNormals() : this.normalizeNormals(); function a(m) { const x = new q(), w = new q(), A = new q(); for (let M = 0; M < t.length; M += 3) g(t[M + 0], x), g(t[M + 1], w), g(t[M + 2], A), c(x, w, A, m); } function c(m, x, w, A) { const M = A + 1, R = []; for (let L = 0; L <= M; L++) { R[L] = []; const S = m.clone().lerp(w, L / M), I = x.clone().lerp(w, L / M), T = M - L; for (let _ = 0; _ <= T; _++) _ === 0 && L === M ? R[L][_] = S : R[L][_] = S.clone().lerp(I, _ / T); } for (let L = 0; L < M; L++) for (let S = 0; S < 2 * (M - L) - 1; S++) { const I = Math.floor(S / 2); S % 2 === 0 ? (f(R[L][I + 1]), f(R[L + 1][I]), f(R[L][I])) : (f(R[L][I + 1]), f(R[L + 1][I + 1]), f(R[L + 1][I])); } } function l(m) { const x = new q(); for (let w = 0; w < s.length; w += 3) x.x = s[w + 0], x.y = s[w + 1], x.z = s[w + 2], x.normalize().multiplyScalar(m), s[w + 0] = x.x, s[w + 1] = x.y, s[w + 2] = x.z; } function d() { const m = new q(); for (let x = 0; x < s.length; x += 3) { m.x = s[x + 0], m.y = s[x + 1], m.z = s[x + 2]; const w = y(m) / 2 / Math.PI + 0.5, A = v(m) / Math.PI + 0.5; o.push(w, 1 - A); } p(), h6(); } function h6() { for (let m = 0; m < o.length; m += 6) { const x = o[m + 0], w = o[m + 2], A = o[m + 4], M = Math.max(x, w, A), R = Math.min(x, w, A); M > 0.9 && R < 0.1 && (x < 0.2 && (o[m + 0] += 1), w < 0.2 && (o[m + 2] += 1), A < 0.2 && (o[m + 4] += 1)); } } function f(m) { s.push(m.x, m.y, m.z); } function g(m, x) { const w = m * 3; x.x = e[w + 0], x.y = e[w + 1], x.z = e[w + 2]; } function p() { const m = new q(), x = new q(), w = new q(), A = new q(), M = new Re(), R = new Re(), L = new Re(); for (let S = 0, I = 0; S < s.length; S += 9, I += 6) { m.set(s[S + 0], s[S + 1], s[S + 2]), x.set(s[S + 3], s[S + 4], s[S + 5]), w.set(s[S + 6], s[S + 7], s[S + 8]), M.set(o[I + 0], o[I + 1]), R.set(o[I + 2], o[I + 3]), L.set(o[I + 4], o[I + 5]), A.copy(m).add(x).add(w).divideScalar(3); const T = y(A); u(M, I + 0, m, T), u(R, I + 2, x, T), u(L, I + 4, w, T); } } function u(m, x, w, A) { A < 0 && m.x === 1 && (o[x] = m.x - 1), w.x === 0 && w.z === 0 && (o[x] = A / 2 / Math.PI + 0.5); } function y(m) { return Math.atan2(m.z, -m.x); } function v(m) { return Math.atan2(-m.y, Math.sqrt(m.x * m.x + m.z * m.z)); } } static fromJSON(e) { return new _Di(e.vertices, e.indices, e.radius, e.details); } }; var Do = class _Do extends Di { constructor(e = 1, t = 0) { const i = (1 + Math.sqrt(5)) / 2, r = 1 / i, s = [ // (±1, ±1, ±1) -1, -1, -1, -1, -1, 1, -1, 1, -1, -1, 1, 1, 1, -1, -1, 1, -1, 1, 1, 1, -1, 1, 1, 1, // (0, ±1/φ, ±φ) 0, -r, -i, 0, -r, i, 0, r, -i, 0, r, i, // (±1/φ, ±φ, 0) -r, -i, 0, -r, i, 0, r, -i, 0, r, i, 0, // (±φ, 0, ±1/φ) -i, 0, -r, i, 0, -r, -i, 0, r, i, 0, r ], o = [ 3, 11, 7, 3, 7, 15, 3, 15, 13, 7, 19, 17, 7, 17, 6, 7, 6, 15, 17, 4, 8, 17, 8, 10, 17, 10, 6, 8, 0, 16, 8, 16, 2, 8, 2, 10, 0, 12, 1, 0, 1, 18, 0, 18, 16, 6, 10, 2, 6, 2, 13, 6, 13, 15, 2, 16, 18, 2, 18, 3, 2, 3, 13, 18, 1, 9, 18, 9, 11, 18, 11, 3, 4, 14, 12, 4, 12, 0, 4, 0, 8, 11, 9, 5, 11, 5, 19, 11, 19, 7, 19, 5, 14, 19, 14, 4, 19, 4, 17, 1, 12, 14, 1, 14, 5, 1, 5, 9 ]; super(s, o, e, t), this.type = "DodecahedronGeometry", this.parameters = { radius: e, detail: t }; } static fromJSON(e) { return new _Do(e.radius, e.detail); } }; var sc = new q(); var oc = new q(); var bh = new q(); var ac = new Zt(); var Of = class extends Ke { constructor(e, t) { if (super(), this.type = "EdgesGeometry", this.parameters = { thresholdAngle: t }, t = t !== void 0 ? t : 1, e.isGeometry === true) { console.error("THREE.EdgesGeometry no longer supports THREE.Geometry. Use THREE.BufferGeometry instead."); return; } const r = Math.pow(10, 4), s = Math.cos(As * t), o = e.getIndex(), a = e.getAttribute("position"), c = o ? o.count : a.count, l = [0, 0, 0], d = ["a", "b", "c"], h6 = new Array(3), f = {}, g = []; for (let p = 0; p < c; p += 3) { o ? (l[0] = o.getX(p), l[1] = o.getX(p + 1), l[2] = o.getX(p + 2)) : (l[0] = p, l[1] = p + 1, l[2] = p + 2); const { a: u, b: y, c: v } = ac; if (u.fromBufferAttribute(a, l[0]), y.fromBufferAttribute(a, l[1]), v.fromBufferAttribute(a, l[2]), ac.getNormal(bh), h6[0] = `${Math.round(u.x * r)},${Math.round(u.y * r)},${Math.round(u.z * r)}`, h6[1] = `${Math.round(y.x * r)},${Math.round(y.y * r)},${Math.round(y.z * r)}`, h6[2] = `${Math.round(v.x * r)},${Math.round(v.y * r)},${Math.round(v.z * r)}`, !(h6[0] === h6[1] || h6[1] === h6[2] || h6[2] === h6[0])) for (let m = 0; m < 3; m++) { const x = (m + 1) % 3, w = h6[m], A = h6[x], M = ac[d[m]], R = ac[d[x]], L = `${w}_${A}`, S = `${A}_${w}`; S in f && f[S] ? (bh.dot(f[S].normal) <= s && (g.push(M.x, M.y, M.z), g.push(R.x, R.y, R.z)), f[S] = null) : L in f || (f[L] = { index0: l[m], index1: l[x], normal: bh.clone() }); } } for (const p in f) if (f[p]) { const { index0: u, index1: y } = f[p]; sc.fromBufferAttribute(a, u), oc.fromBufferAttribute(a, y), g.push(sc.x, sc.y, sc.z), g.push(oc.x, oc.y, oc.z); } this.setAttribute("position", new He(g, 3)); } }; var jn = class { constructor() { this.type = "Curve", this.arcLengthDivisions = 200; } // Virtual base class method to overwrite and implement in subclasses // - t [0 .. 1] getPoint() { return console.warn("THREE.Curve: .getPoint() not implemented."), null; } // Get point at relative position in curve according to arc length // - u [0 .. 1] getPointAt(e, t) { const i = this.getUtoTmapping(e); return this.getPoint(i, t); } // Get sequence of points using getPoint( t ) getPoints(e = 5) { const t = []; for (let i = 0; i <= e; i++) t.push(this.getPoint(i / e)); return t; } // Get sequence of points using getPointAt( u ) getSpacedPoints(e = 5) { const t = []; for (let i = 0; i <= e; i++) t.push(this.getPointAt(i / e)); return t; } // Get total curve arc length getLength() { const e = this.getLengths(); return e[e.length - 1]; } // Get list of cumulative segment lengths getLengths(e = this.arcLengthDivisions) { if (this.cacheArcLengths && this.cacheArcLengths.length === e + 1 && !this.needsUpdate) return this.cacheArcLengths; this.needsUpdate = false; const t = []; let i, r = this.getPoint(0), s = 0; t.push(0); for (let o = 1; o <= e; o++) i = this.getPoint(o / e), s += i.distanceTo(r), t.push(s), r = i; return this.cacheArcLengths = t, t; } updateArcLengths() { this.needsUpdate = true, this.getLengths(); } // Given u ( 0 .. 1 ), get a t to find p. This gives you points which are equidistant getUtoTmapping(e, t) { const i = this.getLengths(); let r = 0; const s = i.length; let o; t ? o = t : o = e * i[s - 1]; let a = 0, c = s - 1, l; for (; a <= c; ) if (r = Math.floor(a + (c - a) / 2), l = i[r] - o, l < 0) a = r + 1; else if (l > 0) c = r - 1; else { c = r; break; } if (r = c, i[r] === o) return r / (s - 1); const d = i[r], f = i[r + 1] - d, g = (o - d) / f; return (r + g) / (s - 1); } // Returns a unit vector tangent at t // In case any sub curve does not implement its tangent derivation, // 2 points a small delta apart will be used to find its gradient // which seems to give a reasonable approximation getTangent(e, t) { let r = e - 1e-4, s = e + 1e-4; r < 0 && (r = 0), s > 1 && (s = 1); const o = this.getPoint(r), a = this.getPoint(s), c = t || (o.isVector2 ? new Re() : new q()); return c.copy(a).sub(o).normalize(), c; } getTangentAt(e, t) { const i = this.getUtoTmapping(e); return this.getTangent(i, t); } computeFrenetFrames(e, t) { const i = new q(), r = [], s = [], o = [], a = new q(), c = new Xe(); for (let g = 0; g <= e; g++) { const p = g / e; r[g] = this.getTangentAt(p, new q()), r[g].normalize(); } s[0] = new q(), o[0] = new q(); let l = Number.MAX_VALUE; const d = Math.abs(r[0].x), h6 = Math.abs(r[0].y), f = Math.abs(r[0].z); d <= l && (l = d, i.set(1, 0, 0)), h6 <= l && (l = h6, i.set(0, 1, 0)), f <= l && i.set(0, 0, 1), a.crossVectors(r[0], i).normalize(), s[0].crossVectors(r[0], a), o[0].crossVectors(r[0], s[0]); for (let g = 1; g <= e; g++) { if (s[g] = s[g - 1].clone(), o[g] = o[g - 1].clone(), a.crossVectors(r[g - 1], r[g]), a.length() > Number.EPSILON) { a.normalize(); const p = Math.acos(gn(r[g - 1].dot(r[g]), -1, 1)); s[g].applyMatrix4(c.makeRotationAxis(a, p)); } o[g].crossVectors(r[g], s[g]); } if (t === true) { let g = Math.acos(gn(s[0].dot(s[e]), -1, 1)); g /= e, r[0].dot(a.crossVectors(s[0], s[e])) > 0 && (g = -g); for (let p = 1; p <= e; p++) s[p].applyMatrix4(c.makeRotationAxis(r[p], g * p)), o[p].crossVectors(r[p], s[p]); } return { tangents: r, normals: s, binormals: o }; } clone() { return new this.constructor().copy(this); } copy(e) { return this.arcLengthDivisions = e.arcLengthDivisions, this; } toJSON() { const e = { metadata: { version: 4.5, type: "Curve", generator: "Curve.toJSON" } }; return e.arcLengthDivisions = this.arcLengthDivisions, e.type = this.type, e; } fromJSON(e) { return this.arcLengthDivisions = e.arcLengthDivisions, this; } }; var xl = class extends jn { constructor(e = 0, t = 0, i = 1, r = 1, s = 0, o = Math.PI * 2, a = false, c = 0) { super(), this.type = "EllipseCurve", this.aX = e, this.aY = t, this.xRadius = i, this.yRadius = r, this.aStartAngle = s, this.aEndAngle = o, this.aClockwise = a, this.aRotation = c; } getPoint(e, t) { const i = t || new Re(), r = Math.PI * 2; let s = this.aEndAngle - this.aStartAngle; const o = Math.abs(s) < Number.EPSILON; for (; s < 0; ) s += r; for (; s > r; ) s -= r; s < Number.EPSILON && (o ? s = 0 : s = r), this.aClockwise === true && !o && (s === r ? s = -r : s = s - r); const a = this.aStartAngle + e * s; let c = this.aX + this.xRadius * Math.cos(a), l = this.aY + this.yRadius * Math.sin(a); if (this.aRotation !== 0) { const d = Math.cos(this.aRotation), h6 = Math.sin(this.aRotation), f = c - this.aX, g = l - this.aY; c = f * d - g * h6 + this.aX, l = f * h6 + g * d + this.aY; } return i.set(c, l); } copy(e) { return super.copy(e), this.aX = e.aX, this.aY = e.aY, this.xRadius = e.xRadius, this.yRadius = e.yRadius, this.aStartAngle = e.aStartAngle, this.aEndAngle = e.aEndAngle, this.aClockwise = e.aClockwise, this.aRotation = e.aRotation, this; } toJSON() { const e = super.toJSON(); return e.aX = this.aX, e.aY = this.aY, e.xRadius = this.xRadius, e.yRadius = this.yRadius, e.aStartAngle = this.aStartAngle, e.aEndAngle = this.aEndAngle, e.aClockwise = this.aClockwise, e.aRotation = this.aRotation, e; } fromJSON(e) { return super.fromJSON(e), this.aX = e.aX, this.aY = e.aY, this.xRadius = e.xRadius, this.yRadius = e.yRadius, this.aStartAngle = e.aStartAngle, this.aEndAngle = e.aEndAngle, this.aClockwise = e.aClockwise, this.aRotation = e.aRotation, this; } }; xl.prototype.isEllipseCurve = true; var Df = class extends xl { constructor(e, t, i, r, s, o) { super(e, t, i, i, r, s, o), this.type = "ArcCurve"; } }; Df.prototype.isArcCurve = true; function Nf() { let n = 0, e = 0, t = 0, i = 0; function r(s, o, a, c) { n = s, e = a, t = -3 * s + 3 * o - 2 * a - c, i = 2 * s - 2 * o + a + c; } return { initCatmullRom: function(s, o, a, c, l) { r(o, a, l * (a - s), l * (c - o)); }, initNonuniformCatmullRom: function(s, o, a, c, l, d, h6) { let f = (o - s) / l - (a - s) / (l + d) + (a - o) / d, g = (a - o) / d - (c - o) / (d + h6) + (c - a) / h6; f *= d, g *= d, r(o, a, f, g); }, calc: function(s) { const o = s * s, a = o * s; return n + e * s + t * o + i * a; } }; } var lc = new q(); var xh = new Nf(); var Mh = new Nf(); var wh = new Nf(); var Bf = class extends jn { constructor(e = [], t = false, i = "centripetal", r = 0.5) { super(), this.type = "CatmullRomCurve3", this.points = e, this.closed = t, this.curveType = i, this.tension = r; } getPoint(e, t = new q()) { const i = t, r = this.points, s = r.length, o = (s - (this.closed ? 0 : 1)) * e; let a = Math.floor(o), c = o - a; this.closed ? a += a > 0 ? 0 : (Math.floor(Math.abs(a) / s) + 1) * s : c === 0 && a === s - 1 && (a = s - 2, c = 1); let l, d; this.closed || a > 0 ? l = r[(a - 1) % s] : (lc.subVectors(r[0], r[1]).add(r[0]), l = lc); const h6 = r[a % s], f = r[(a + 1) % s]; if (this.closed || a + 2 < s ? d = r[(a + 2) % s] : (lc.subVectors(r[s - 1], r[s - 2]).add(r[s - 1]), d = lc), this.curveType === "centripetal" || this.curveType === "chordal") { const g = this.curveType === "chordal" ? 0.5 : 0.25; let p = Math.pow(l.distanceToSquared(h6), g), u = Math.pow(h6.distanceToSquared(f), g), y = Math.pow(f.distanceToSquared(d), g); u < 1e-4 && (u = 1), p < 1e-4 && (p = u), y < 1e-4 && (y = u), xh.initNonuniformCatmullRom(l.x, h6.x, f.x, d.x, p, u, y), Mh.initNonuniformCatmullRom(l.y, h6.y, f.y, d.y, p, u, y), wh.initNonuniformCatmullRom(l.z, h6.z, f.z, d.z, p, u, y); } else this.curveType === "catmullrom" && (xh.initCatmullRom(l.x, h6.x, f.x, d.x, this.tension), Mh.initCatmullRom(l.y, h6.y, f.y, d.y, this.tension), wh.initCatmullRom(l.z, h6.z, f.z, d.z, this.tension)); return i.set( xh.calc(c), Mh.calc(c), wh.calc(c) ), i; } copy(e) { super.copy(e), this.points = []; for (let t = 0, i = e.points.length; t < i; t++) { const r = e.points[t]; this.points.push(r.clone()); } return this.closed = e.closed, this.curveType = e.curveType, this.tension = e.tension, this; } toJSON() { const e = super.toJSON(); e.points = []; for (let t = 0, i = this.points.length; t < i; t++) { const r = this.points[t]; e.points.push(r.toArray()); } return e.closed = this.closed, e.curveType = this.curveType, e.tension = this.tension, e; } fromJSON(e) { super.fromJSON(e), this.points = []; for (let t = 0, i = e.points.length; t < i; t++) { const r = e.points[t]; this.points.push(new q().fromArray(r)); } return this.closed = e.closed, this.curveType = e.curveType, this.tension = e.tension, this; } }; Bf.prototype.isCatmullRomCurve3 = true; function Dg(n, e, t, i, r) { const s = (i - e) * 0.5, o = (r - t) * 0.5, a = n * n, c = n * a; return (2 * t - 2 * i + s + o) * c + (-3 * t + 3 * i - 2 * s - o) * a + s * n + t; } function ID(n, e) { const t = 1 - n; return t * t * e; } function OD(n, e) { return 2 * (1 - n) * n * e; } function DD(n, e) { return n * n * e; } function Pa(n, e, t, i) { return ID(n, e) + OD(n, t) + DD(n, i); } function ND(n, e) { const t = 1 - n; return t * t * t * e; } function BD(n, e) { const t = 1 - n; return 3 * t * t * n * e; } function UD(n, e) { return 3 * (1 - n) * n * n * e; } function zD(n, e) { return n * n * n * e; } function Ia(n, e, t, i, r) { return ND(n, e) + BD(n, t) + UD(n, i) + zD(n, r); } var Su = class extends jn { constructor(e = new Re(), t = new Re(), i = new Re(), r = new Re()) { super(), this.type = "CubicBezierCurve", this.v0 = e, this.v1 = t, this.v2 = i, this.v3 = r; } getPoint(e, t = new Re()) { const i = t, r = this.v0, s = this.v1, o = this.v2, a = this.v3; return i.set( Ia(e, r.x, s.x, o.x, a.x), Ia(e, r.y, s.y, o.y, a.y) ), i; } copy(e) { return super.copy(e), this.v0.copy(e.v0), this.v1.copy(e.v1), this.v2.copy(e.v2), this.v3.copy(e.v3), this; } toJSON() { const e = super.toJSON(); return e.v0 = this.v0.toArray(), e.v1 = this.v1.toArray(), e.v2 = this.v2.toArray(), e.v3 = this.v3.toArray(), e; } fromJSON(e) { return super.fromJSON(e), this.v0.fromArray(e.v0), this.v1.fromArray(e.v1), this.v2.fromArray(e.v2), this.v3.fromArray(e.v3), this; } }; Su.prototype.isCubicBezierCurve = true; var Uf = class extends jn { constructor(e = new q(), t = new q(), i = new q(), r = new q()) { super(), this.type = "CubicBezierCurve3", this.v0 = e, this.v1 = t, this.v2 = i, this.v3 = r; } getPoint(e, t = new q()) { const i = t, r = this.v0, s = this.v1, o = this.v2, a = this.v3; return i.set( Ia(e, r.x, s.x, o.x, a.x), Ia(e, r.y, s.y, o.y, a.y), Ia(e, r.z, s.z, o.z, a.z) ), i; } copy(e) { return super.copy(e), this.v0.copy(e.v0), this.v1.copy(e.v1), this.v2.copy(e.v2), this.v3.copy(e.v3), this; } toJSON() { const e = super.toJSON(); return e.v0 = this.v0.toArray(), e.v1 = this.v1.toArray(), e.v2 = this.v2.toArray(), e.v3 = this.v3.toArray(), e; } fromJSON(e) { return super.fromJSON(e), this.v0.fromArray(e.v0), this.v1.fromArray(e.v1), this.v2.fromArray(e.v2), this.v3.fromArray(e.v3), this; } }; Uf.prototype.isCubicBezierCurve3 = true; var Ml = class extends jn { constructor(e = new Re(), t = new Re()) { super(), this.type = "LineCurve", this.v1 = e, this.v2 = t; } getPoint(e, t = new Re()) { const i = t; return e === 1 ? i.copy(this.v2) : (i.copy(this.v2).sub(this.v1), i.multiplyScalar(e).add(this.v1)), i; } // Line curve is linear, so we can overwrite default getPointAt getPointAt(e, t) { return this.getPoint(e, t); } getTangent(e, t) { const i = t || new Re(); return i.copy(this.v2).sub(this.v1).normalize(), i; } copy(e) { return super.copy(e), this.v1.copy(e.v1), this.v2.copy(e.v2), this; } toJSON() { const e = super.toJSON(); return e.v1 = this.v1.toArray(), e.v2 = this.v2.toArray(), e; } fromJSON(e) { return super.fromJSON(e), this.v1.fromArray(e.v1), this.v2.fromArray(e.v2), this; } }; Ml.prototype.isLineCurve = true; var Cx = class extends jn { constructor(e = new q(), t = new q()) { super(), this.type = "LineCurve3", this.isLineCurve3 = true, this.v1 = e, this.v2 = t; } getPoint(e, t = new q()) { const i = t; return e === 1 ? i.copy(this.v2) : (i.copy(this.v2).sub(this.v1), i.multiplyScalar(e).add(this.v1)), i; } // Line curve is linear, so we can overwrite default getPointAt getPointAt(e, t) { return this.getPoint(e, t); } copy(e) { return super.copy(e), this.v1.copy(e.v1), this.v2.copy(e.v2), this; } toJSON() { const e = super.toJSON(); return e.v1 = this.v1.toArray(), e.v2 = this.v2.toArray(), e; } fromJSON(e) { return super.fromJSON(e), this.v1.fromArray(e.v1), this.v2.fromArray(e.v2), this; } }; var _u = class extends jn { constructor(e = new Re(), t = new Re(), i = new Re()) { super(), this.type = "QuadraticBezierCurve", this.v0 = e, this.v1 = t, this.v2 = i; } getPoint(e, t = new Re()) { const i = t, r = this.v0, s = this.v1, o = this.v2; return i.set( Pa(e, r.x, s.x, o.x), Pa(e, r.y, s.y, o.y) ), i; } copy(e) { return super.copy(e), this.v0.copy(e.v0), this.v1.copy(e.v1), this.v2.copy(e.v2), this; } toJSON() { const e = super.toJSON(); return e.v0 = this.v0.toArray(), e.v1 = this.v1.toArray(), e.v2 = this.v2.toArray(), e; } fromJSON(e) { return super.fromJSON(e), this.v0.fromArray(e.v0), this.v1.fromArray(e.v1), this.v2.fromArray(e.v2), this; } }; _u.prototype.isQuadraticBezierCurve = true; var zf = class extends jn { constructor(e = new q(), t = new q(), i = new q()) { super(), this.type = "QuadraticBezierCurve3", this.v0 = e, this.v1 = t, this.v2 = i; } getPoint(e, t = new q()) { const i = t, r = this.v0, s = this.v1, o = this.v2; return i.set( Pa(e, r.x, s.x, o.x), Pa(e, r.y, s.y, o.y), Pa(e, r.z, s.z, o.z) ), i; } copy(e) { return super.copy(e), this.v0.copy(e.v0), this.v1.copy(e.v1), this.v2.copy(e.v2), this; } toJSON() { const e = super.toJSON(); return e.v0 = this.v0.toArray(), e.v1 = this.v1.toArray(), e.v2 = this.v2.toArray(), e; } fromJSON(e) { return super.fromJSON(e), this.v0.fromArray(e.v0), this.v1.fromArray(e.v1), this.v2.fromArray(e.v2), this; } }; zf.prototype.isQuadraticBezierCurve3 = true; var Tu = class extends jn { constructor(e = []) { super(), this.type = "SplineCurve", this.points = e; } getPoint(e, t = new Re()) { const i = t, r = this.points, s = (r.length - 1) * e, o = Math.floor(s), a = s - o, c = r[o === 0 ? o : o - 1], l = r[o], d = r[o > r.length - 2 ? r.length - 1 : o + 1], h6 = r[o > r.length - 3 ? r.length - 1 : o + 2]; return i.set( Dg(a, c.x, l.x, d.x, h6.x), Dg(a, c.y, l.y, d.y, h6.y) ), i; } copy(e) { super.copy(e), this.points = []; for (let t = 0, i = e.points.length; t < i; t++) { const r = e.points[t]; this.points.push(r.clone()); } return this; } toJSON() { const e = super.toJSON(); e.points = []; for (let t = 0, i = this.points.length; t < i; t++) { const r = this.points[t]; e.points.push(r.toArray()); } return e; } fromJSON(e) { super.fromJSON(e), this.points = []; for (let t = 0, i = e.points.length; t < i; t++) { const r = e.points[t]; this.points.push(new Re().fromArray(r)); } return this; } }; Tu.prototype.isSplineCurve = true; var Vf = Object.freeze({ __proto__: null, ArcCurve: Df, CatmullRomCurve3: Bf, CubicBezierCurve: Su, CubicBezierCurve3: Uf, EllipseCurve: xl, LineCurve: Ml, LineCurve3: Cx, QuadraticBezierCurve: _u, QuadraticBezierCurve3: zf, SplineCurve: Tu }); var VD = { triangulate: function(n, e, t = 2) { const i = e && e.length, r = i ? e[0] * t : n.length; let s = Lx(n, 0, r, t, true); const o = []; if (!s || s.next === s.prev) return o; let a, c, l, d, h6, f, g; if (i && (s = jD(n, e, s, t)), n.length > 80 * t) { a = l = n[0], c = d = n[1]; for (let p = t; p < r; p += t) h6 = n[p], f = n[p + 1], h6 < a && (a = h6), f < c && (c = f), h6 > l && (l = h6), f > d && (d = f); g = Math.max(l - a, d - c), g = g !== 0 ? 1 / g : 0; } return $a(s, o, t, a, c, g), o; } }; function Lx(n, e, t, i, r) { let s, o; if (r === nN(n, e, t, i) > 0) for (s = e; s < t; s += i) o = Ng(s, n[s], n[s + 1], o); else for (s = t - i; s >= e; s -= i) o = Ng(s, n[s], n[s + 1], o); return o && Eu(o, o.next) && (Xa(o), o = o.next), o; } function Zr(n, e) { if (!n) return n; e || (e = n); let t = n, i; do if (i = false, !t.steiner && (Eu(t, t.next) || Ot(t.prev, t, t.next) === 0)) { if (Xa(t), t = e = t.prev, t === t.next) break; i = true; } else t = t.next; while (i || t !== e); return e; } function $a(n, e, t, i, r, s, o) { if (!n) return; !o && s && JD(n, i, r, s); let a = n, c, l; for (; n.prev !== n.next; ) { if (c = n.prev, l = n.next, s ? GD(n, i, r, s) : kD(n)) { e.push(c.i / t), e.push(n.i / t), e.push(l.i / t), Xa(n), n = l.next, a = l.next; continue; } if (n = l, n === a) { o ? o === 1 ? (n = HD(Zr(n), e, t), $a(n, e, t, i, r, s, 2)) : o === 2 && WD(n, e, t, i, r, s) : $a(Zr(n), e, t, i, r, s, 1); break; } } } function kD(n) { const e = n.prev, t = n, i = n.next; if (Ot(e, t, i) >= 0) return false; let r = n.next.next; for (; r !== n.prev; ) { if (go(e.x, e.y, t.x, t.y, i.x, i.y, r.x, r.y) && Ot(r.prev, r, r.next) >= 0) return false; r = r.next; } return true; } function GD(n, e, t, i) { const r = n.prev, s = n, o = n.next; if (Ot(r, s, o) >= 0) return false; const a = r.x < s.x ? r.x < o.x ? r.x : o.x : s.x < o.x ? s.x : o.x, c = r.y < s.y ? r.y < o.y ? r.y : o.y : s.y < o.y ? s.y : o.y, l = r.x > s.x ? r.x > o.x ? r.x : o.x : s.x > o.x ? s.x : o.x, d = r.y > s.y ? r.y > o.y ? r.y : o.y : s.y > o.y ? s.y : o.y, h6 = Ad(a, c, e, t, i), f = Ad(l, d, e, t, i); let g = n.prevZ, p = n.nextZ; for (; g && g.z >= h6 && p && p.z <= f; ) { if (g !== n.prev && g !== n.next && go(r.x, r.y, s.x, s.y, o.x, o.y, g.x, g.y) && Ot(g.prev, g, g.next) >= 0 || (g = g.prevZ, p !== n.prev && p !== n.next && go(r.x, r.y, s.x, s.y, o.x, o.y, p.x, p.y) && Ot(p.prev, p, p.next) >= 0)) return false; p = p.nextZ; } for (; g && g.z >= h6; ) { if (g !== n.prev && g !== n.next && go(r.x, r.y, s.x, s.y, o.x, o.y, g.x, g.y) && Ot(g.prev, g, g.next) >= 0) return false; g = g.prevZ; } for (; p && p.z <= f; ) { if (p !== n.prev && p !== n.next && go(r.x, r.y, s.x, s.y, o.x, o.y, p.x, p.y) && Ot(p.prev, p, p.next) >= 0) return false; p = p.nextZ; } return true; } function HD(n, e, t) { let i = n; do { const r = i.prev, s = i.next.next; !Eu(r, s) && Rx(r, i, i.next, s) && Za(r, s) && Za(s, r) && (e.push(r.i / t), e.push(i.i / t), e.push(s.i / t), Xa(i), Xa(i.next), i = n = s), i = i.next; } while (i !== n); return Zr(i); } function WD(n, e, t, i, r, s) { let o = n; do { let a = o.next.next; for (; a !== o.prev; ) { if (o.i !== a.i && QD(o, a)) { let c = Fx(o, a); o = Zr(o, o.next), c = Zr(c, c.next), $a(o, e, t, i, r, s), $a(c, e, t, i, r, s); return; } a = a.next; } o = o.next; } while (o !== n); } function jD(n, e, t, i) { const r = []; let s, o, a, c, l; for (s = 0, o = e.length; s < o; s++) a = e[s] * i, c = s < o - 1 ? e[s + 1] * i : n.length, l = Lx(n, a, c, i, false), l === l.next && (l.steiner = true), r.push(qD(l)); for (r.sort($D), s = 0; s < r.length; s++) ZD(r[s], t), t = Zr(t, t.next); return t; } function $D(n, e) { return n.x - e.x; } function ZD(n, e) { if (e = XD(n, e), e) { const t = Fx(e, n); Zr(e, e.next), Zr(t, t.next); } } function XD(n, e) { let t = e; const i = n.x, r = n.y; let s = -1 / 0, o; do { if (r <= t.y && r >= t.next.y && t.next.y !== t.y) { const f = t.x + (r - t.y) * (t.next.x - t.x) / (t.next.y - t.y); if (f <= i && f > s) { if (s = f, f === i) { if (r === t.y) return t; if (r === t.next.y) return t.next; } o = t.x < t.next.x ? t : t.next; } } t = t.next; } while (t !== e); if (!o) return null; if (i === s) return o; const a = o, c = o.x, l = o.y; let d = 1 / 0, h6; t = o; do i >= t.x && t.x >= c && i !== t.x && go(r < l ? i : s, r, c, l, r < l ? s : i, r, t.x, t.y) && (h6 = Math.abs(r - t.y) / (i - t.x), Za(t, n) && (h6 < d || h6 === d && (t.x > o.x || t.x === o.x && YD(o, t))) && (o = t, d = h6)), t = t.next; while (t !== a); return o; } function YD(n, e) { return Ot(n.prev, n, e.prev) < 0 && Ot(e.next, n, n.next) < 0; } function JD(n, e, t, i) { let r = n; do r.z === null && (r.z = Ad(r.x, r.y, e, t, i)), r.prevZ = r.prev, r.nextZ = r.next, r = r.next; while (r !== n); r.prevZ.nextZ = null, r.prevZ = null, KD(r); } function KD(n) { let e, t, i, r, s, o, a, c, l = 1; do { for (t = n, n = null, s = null, o = 0; t; ) { for (o++, i = t, a = 0, e = 0; e < l && (a++, i = i.nextZ, !!i); e++) ; for (c = l; a > 0 || c > 0 && i; ) a !== 0 && (c === 0 || !i || t.z <= i.z) ? (r = t, t = t.nextZ, a--) : (r = i, i = i.nextZ, c--), s ? s.nextZ = r : n = r, r.prevZ = s, s = r; t = i; } s.nextZ = null, l *= 2; } while (o > 1); return n; } function Ad(n, e, t, i, r) { return n = 32767 * (n - t) * r, e = 32767 * (e - i) * r, n = (n | n << 8) & 16711935, n = (n | n << 4) & 252645135, n = (n | n << 2) & 858993459, n = (n | n << 1) & 1431655765, e = (e | e << 8) & 16711935, e = (e | e << 4) & 252645135, e = (e | e << 2) & 858993459, e = (e | e << 1) & 1431655765, n | e << 1; } function qD(n) { let e = n, t = n; do (e.x < t.x || e.x === t.x && e.y < t.y) && (t = e), e = e.next; while (e !== n); return t; } function go(n, e, t, i, r, s, o, a) { return (r - o) * (e - a) - (n - o) * (s - a) >= 0 && (n - o) * (i - a) - (t - o) * (e - a) >= 0 && (t - o) * (s - a) - (r - o) * (i - a) >= 0; } function QD(n, e) { return n.next.i !== e.i && n.prev.i !== e.i && !eN(n, e) && // dones't intersect other edges (Za(n, e) && Za(e, n) && tN(n, e) && // locally visible (Ot(n.prev, n, e.prev) || Ot(n, e.prev, e)) || // does not create opposite-facing sectors Eu(n, e) && Ot(n.prev, n, n.next) > 0 && Ot(e.prev, e, e.next) > 0); } function Ot(n, e, t) { return (e.y - n.y) * (t.x - e.x) - (e.x - n.x) * (t.y - e.y); } function Eu(n, e) { return n.x === e.x && n.y === e.y; } function Rx(n, e, t, i) { const r = uc(Ot(n, e, t)), s = uc(Ot(n, e, i)), o = uc(Ot(t, i, n)), a = uc(Ot(t, i, e)); return !!(r !== s && o !== a || r === 0 && cc(n, t, e) || s === 0 && cc(n, i, e) || o === 0 && cc(t, n, i) || a === 0 && cc(t, e, i)); } function cc(n, e, t) { return e.x <= Math.max(n.x, t.x) && e.x >= Math.min(n.x, t.x) && e.y <= Math.max(n.y, t.y) && e.y >= Math.min(n.y, t.y); } function uc(n) { return n > 0 ? 1 : n < 0 ? -1 : 0; } function eN(n, e) { let t = n; do { if (t.i !== n.i && t.next.i !== n.i && t.i !== e.i && t.next.i !== e.i && Rx(t, t.next, n, e)) return true; t = t.next; } while (t !== n); return false; } function Za(n, e) { return Ot(n.prev, n, n.next) < 0 ? Ot(n, e, n.next) >= 0 && Ot(n, n.prev, e) >= 0 : Ot(n, e, n.prev) < 0 || Ot(n, n.next, e) < 0; } function tN(n, e) { let t = n, i = false; const r = (n.x + e.x) / 2, s = (n.y + e.y) / 2; do t.y > s != t.next.y > s && t.next.y !== t.y && r < (t.next.x - t.x) * (s - t.y) / (t.next.y - t.y) + t.x && (i = !i), t = t.next; while (t !== n); return i; } function Fx(n, e) { const t = new Sd(n.i, n.x, n.y), i = new Sd(e.i, e.x, e.y), r = n.next, s = e.prev; return n.next = e, e.prev = n, t.next = r, r.prev = t, i.next = t, t.prev = i, s.next = i, i.prev = s, i; } function Ng(n, e, t, i) { const r = new Sd(n, e, t); return i ? (r.next = i.next, r.prev = i, i.next.prev = r, i.next = r) : (r.prev = r, r.next = r), r; } function Xa(n) { n.next.prev = n.prev, n.prev.next = n.next, n.prevZ && (n.prevZ.nextZ = n.nextZ), n.nextZ && (n.nextZ.prevZ = n.prevZ); } function Sd(n, e, t) { this.i = n, this.x = e, this.y = t, this.prev = null, this.next = null, this.z = null, this.prevZ = null, this.nextZ = null, this.steiner = false; } function nN(n, e, t, i) { let r = 0; for (let s = e, o = t - i; s < t; s += i) r += (n[o] - n[s]) * (n[s + 1] + n[o + 1]), o = s; return r; } var Fi = class _Fi { // calculate area of the contour polygon static area(e) { const t = e.length; let i = 0; for (let r = t - 1, s = 0; s < t; r = s++) i += e[r].x * e[s].y - e[s].x * e[r].y; return i * 0.5; } static isClockWise(e) { return _Fi.area(e) < 0; } static triangulateShape(e, t) { const i = [], r = [], s = []; Bg(e), Ug(i, e); let o = e.length; t.forEach(Bg); for (let c = 0; c < t.length; c++) r.push(o), o += t[c].length, Ug(i, t[c]); const a = VD.triangulate(i, r); for (let c = 0; c < a.length; c += 3) s.push(a.slice(c, c + 3)); return s; } }; function Bg(n) { const e = n.length; e > 2 && n[e - 1].equals(n[0]) && n.pop(); } function Ug(n, e) { for (let t = 0; t < e.length; t++) n.push(e[t].x), n.push(e[t].y); } var mi = class _mi extends Ke { constructor(e, t) { super(), this.type = "ExtrudeGeometry", this.parameters = { shapes: e, options: t }, e = Array.isArray(e) ? e : [e]; const i = this, r = [], s = []; for (let a = 0, c = e.length; a < c; a++) { const l = e[a]; o(l); } this.setAttribute("position", new He(r, 3)), this.setAttribute("uv", new He(s, 2)), this.computeVertexNormals(); function o(a) { const c = [], l = t.curveSegments !== void 0 ? t.curveSegments : 12, d = t.steps !== void 0 ? t.steps : 1; let h6 = t.depth !== void 0 ? t.depth : 100, f = t.bevelEnabled !== void 0 ? t.bevelEnabled : true, g = t.bevelThickness !== void 0 ? t.bevelThickness : 6, p = t.bevelSize !== void 0 ? t.bevelSize : g - 2, u = t.bevelOffset !== void 0 ? t.bevelOffset : 0, y = t.bevelSegments !== void 0 ? t.bevelSegments : 3; const v = t.extrudePath, m = t.UVGenerator !== void 0 ? t.UVGenerator : iN; t.amount !== void 0 && (console.warn("THREE.ExtrudeBufferGeometry: amount has been renamed to depth."), h6 = t.amount); let x, w = false, A, M, R, L; v && (x = v.getSpacedPoints(d), w = true, f = false, A = v.computeFrenetFrames(d, false), M = new q(), R = new q(), L = new q()), f || (y = 0, g = 0, p = 0, u = 0); const S = a.extractPoints(l); let I = S.shape; const T = S.holes; if (!Fi.isClockWise(I)) { I = I.reverse(); for (let V = 0, H = T.length; V < H; V++) { const K = T[V]; Fi.isClockWise(K) && (T[V] = K.reverse()); } } const E = Fi.triangulateShape(I, T), C = I; for (let V = 0, H = T.length; V < H; V++) { const K = T[V]; I = I.concat(K); } function P(V, H, K) { return H || console.error("THREE.ExtrudeGeometry: vec does not exist"), H.clone().multiplyScalar(K).add(V); } const b = I.length, F = E.length; function D(V, H, K) { let ce, se, k; const O = V.x - H.x, Z = V.y - H.y, X = K.x - V.x, ee = K.y - V.y, fe = O * O + Z * Z, be = O * ee - Z * X; if (Math.abs(be) > Number.EPSILON) { const Ae = Math.sqrt(fe), he = Math.sqrt(X * X + ee * ee), xe = H.x - Z / Ae, ne = H.y + O / Ae, me = K.x - ee / he, Me = K.y + X / he, De = ((me - xe) * ee - (Me - ne) * X) / (O * ee - Z * X); ce = xe + O * De - V.x, se = ne + Z * De - V.y; const Ie = ce * ce + se * se; if (Ie <= 2) return new Re(ce, se); k = Math.sqrt(Ie / 2); } else { let Ae = false; O > Number.EPSILON ? X > Number.EPSILON && (Ae = true) : O < -Number.EPSILON ? X < -Number.EPSILON && (Ae = true) : Math.sign(Z) === Math.sign(ee) && (Ae = true), Ae ? (ce = -Z, se = O, k = Math.sqrt(fe)) : (ce = O, se = Z, k = Math.sqrt(fe / 2)); } return new Re(ce / k, se / k); } const N = []; for (let V = 0, H = C.length, K = H - 1, ce = V + 1; V < H; V++, K++, ce++) K === H && (K = 0), ce === H && (ce = 0), N[V] = D(C[V], C[K], C[ce]); const B = []; let U, G = N.concat(); for (let V = 0, H = T.length; V < H; V++) { const K = T[V]; U = []; for (let ce = 0, se = K.length, k = se - 1, O = ce + 1; ce < se; ce++, k++, O++) k === se && (k = 0), O === se && (O = 0), U[ce] = D(K[ce], K[k], K[O]); B.push(U), G = G.concat(U); } for (let V = 0; V < y; V++) { const H = V / y, K = g * Math.cos(H * Math.PI / 2), ce = p * Math.sin(H * Math.PI / 2) + u; for (let se = 0, k = C.length; se < k; se++) { const O = P(C[se], N[se], ce); le(O.x, O.y, -K); } for (let se = 0, k = T.length; se < k; se++) { const O = T[se]; U = B[se]; for (let Z = 0, X = O.length; Z < X; Z++) { const ee = P(O[Z], U[Z], ce); le(ee.x, ee.y, -K); } } } const Y = p + u; for (let V = 0; V < b; V++) { const H = f ? P(I[V], G[V], Y) : I[V]; w ? (R.copy(A.normals[0]).multiplyScalar(H.x), M.copy(A.binormals[0]).multiplyScalar(H.y), L.copy(x[0]).add(R).add(M), le(L.x, L.y, L.z)) : le(H.x, H.y, 0); } for (let V = 1; V <= d; V++) for (let H = 0; H < b; H++) { const K = f ? P(I[H], G[H], Y) : I[H]; w ? (R.copy(A.normals[V]).multiplyScalar(K.x), M.copy(A.binormals[V]).multiplyScalar(K.y), L.copy(x[V]).add(R).add(M), le(L.x, L.y, L.z)) : le(K.x, K.y, h6 / d * V); } for (let V = y - 1; V >= 0; V--) { const H = V / y, K = g * Math.cos(H * Math.PI / 2), ce = p * Math.sin(H * Math.PI / 2) + u; for (let se = 0, k = C.length; se < k; se++) { const O = P(C[se], N[se], ce); le(O.x, O.y, h6 + K); } for (let se = 0, k = T.length; se < k; se++) { const O = T[se]; U = B[se]; for (let Z = 0, X = O.length; Z < X; Z++) { const ee = P(O[Z], U[Z], ce); w ? le(ee.x, ee.y + x[d - 1].y, x[d - 1].x + K) : le(ee.x, ee.y, h6 + K); } } } te(), ae(); function te() { const V = r.length / 3; if (f) { let H = 0, K = b * H; for (let ce = 0; ce < F; ce++) { const se = E[ce]; W(se[2] + K, se[1] + K, se[0] + K); } H = d + y * 2, K = b * H; for (let ce = 0; ce < F; ce++) { const se = E[ce]; W(se[0] + K, se[1] + K, se[2] + K); } } else { for (let H = 0; H < F; H++) { const K = E[H]; W(K[2], K[1], K[0]); } for (let H = 0; H < F; H++) { const K = E[H]; W(K[0] + b * d, K[1] + b * d, K[2] + b * d); } } i.addGroup(V, r.length / 3 - V, 0); } function ae() { const V = r.length / 3; let H = 0; ie(C, H), H += C.length; for (let K = 0, ce = T.length; K < ce; K++) { const se = T[K]; ie(se, H), H += se.length; } i.addGroup(V, r.length / 3 - V, 1); } function ie(V, H) { let K = V.length; for (; --K >= 0; ) { const ce = K; let se = K - 1; se < 0 && (se = V.length - 1); for (let k = 0, O = d + y * 2; k < O; k++) { const Z = b * k, X = b * (k + 1), ee = H + ce + Z, fe = H + se + Z, be = H + se + X, Ae = H + ce + X; $(ee, fe, be, Ae); } } } function le(V, H, K) { c.push(V), c.push(H), c.push(K); } function W(V, H, K) { j(V), j(H), j(K); const ce = r.length / 3, se = m.generateTopUV(i, r, ce - 3, ce - 2, ce - 1); re(se[0]), re(se[1]), re(se[2]); } function $(V, H, K, ce) { j(V), j(H), j(ce), j(H), j(K), j(ce); const se = r.length / 3, k = m.generateSideWallUV(i, r, se - 6, se - 3, se - 2, se - 1); re(k[0]), re(k[1]), re(k[3]), re(k[1]), re(k[2]), re(k[3]); } function j(V) { r.push(c[V * 3 + 0]), r.push(c[V * 3 + 1]), r.push(c[V * 3 + 2]); } function re(V) { s.push(V.x), s.push(V.y); } } } toJSON() { const e = super.toJSON(), t = this.parameters.shapes, i = this.parameters.options; return rN(t, i, e); } static fromJSON(e, t) { const i = []; for (let s = 0, o = e.shapes.length; s < o; s++) { const a = t[e.shapes[s]]; i.push(a); } const r = e.options.extrudePath; return r !== void 0 && (e.options.extrudePath = new Vf[r.type]().fromJSON(r)), new _mi(i, e.options); } }; var iN = { generateTopUV: function(n, e, t, i, r) { const s = e[t * 3], o = e[t * 3 + 1], a = e[i * 3], c = e[i * 3 + 1], l = e[r * 3], d = e[r * 3 + 1]; return [ new Re(s, o), new Re(a, c), new Re(l, d) ]; }, generateSideWallUV: function(n, e, t, i, r, s) { const o = e[t * 3], a = e[t * 3 + 1], c = e[t * 3 + 2], l = e[i * 3], d = e[i * 3 + 1], h6 = e[i * 3 + 2], f = e[r * 3], g = e[r * 3 + 1], p = e[r * 3 + 2], u = e[s * 3], y = e[s * 3 + 1], v = e[s * 3 + 2]; return Math.abs(a - d) < Math.abs(o - l) ? [ new Re(o, 1 - c), new Re(l, 1 - h6), new Re(f, 1 - p), new Re(u, 1 - v) ] : [ new Re(a, 1 - c), new Re(d, 1 - h6), new Re(g, 1 - p), new Re(y, 1 - v) ]; } }; function rN(n, e, t) { if (t.shapes = [], Array.isArray(n)) for (let i = 0, r = n.length; i < r; i++) { const s = n[i]; t.shapes.push(s.uuid); } else t.shapes.push(n.uuid); return e.extrudePath !== void 0 && (t.options.extrudePath = e.extrudePath.toJSON()), t; } var No = class _No extends Di { constructor(e = 1, t = 0) { const i = (1 + Math.sqrt(5)) / 2, r = [ -1, i, 0, 1, i, 0, -1, -i, 0, 1, -i, 0, 0, -1, i, 0, 1, i, 0, -1, -i, 0, 1, -i, i, 0, -1, i, 0, 1, -i, 0, -1, -i, 0, 1 ], s = [ 0, 11, 5, 0, 5, 1, 0, 1, 7, 0, 7, 10, 0, 10, 11, 1, 5, 9, 5, 11, 4, 11, 10, 2, 10, 7, 6, 7, 1, 8, 3, 9, 4, 3, 4, 2, 3, 2, 6, 3, 6, 8, 3, 8, 9, 4, 9, 5, 2, 4, 11, 6, 2, 10, 8, 6, 7, 9, 8, 1 ]; super(r, s, e, t), this.type = "IcosahedronGeometry", this.parameters = { radius: e, detail: t }; } static fromJSON(e) { return new _No(e.radius, e.detail); } }; var Bo = class _Bo extends Ke { constructor(e, t = 12, i = 0, r = Math.PI * 2) { super(), this.type = "LatheGeometry", this.parameters = { points: e, segments: t, phiStart: i, phiLength: r }, t = Math.floor(t), r = gn(r, 0, Math.PI * 2); const s = [], o = [], a = [], c = 1 / t, l = new q(), d = new Re(); for (let h6 = 0; h6 <= t; h6++) { const f = i + h6 * c * r, g = Math.sin(f), p = Math.cos(f); for (let u = 0; u <= e.length - 1; u++) l.x = e[u].x * g, l.y = e[u].y, l.z = e[u].x * p, o.push(l.x, l.y, l.z), d.x = h6 / t, d.y = u / (e.length - 1), a.push(d.x, d.y); } for (let h6 = 0; h6 < t; h6++) for (let f = 0; f < e.length - 1; f++) { const g = f + h6 * e.length, p = g, u = g + e.length, y = g + e.length + 1, v = g + 1; s.push(p, u, v), s.push(u, y, v); } if (this.setIndex(s), this.setAttribute("position", new He(o, 3)), this.setAttribute("uv", new He(a, 2)), this.computeVertexNormals(), r === Math.PI * 2) { const h6 = this.attributes.normal.array, f = new q(), g = new q(), p = new q(), u = t * e.length * 3; for (let y = 0, v = 0; y < e.length; y++, v += 3) f.x = h6[v + 0], f.y = h6[v + 1], f.z = h6[v + 2], g.x = h6[u + v + 0], g.y = h6[u + v + 1], g.z = h6[u + v + 2], p.addVectors(f, g).normalize(), h6[v + 0] = h6[u + v + 0] = p.x, h6[v + 1] = h6[u + v + 1] = p.y, h6[v + 2] = h6[u + v + 2] = p.z; } } static fromJSON(e) { return new _Bo(e.points, e.segments, e.phiStart, e.phiLength); } }; var Rs = class _Rs extends Di { constructor(e = 1, t = 0) { const i = [ 1, 0, 0, -1, 0, 0, 0, 1, 0, 0, -1, 0, 0, 0, 1, 0, 0, -1 ], r = [ 0, 2, 4, 0, 4, 3, 0, 3, 5, 0, 5, 2, 1, 2, 5, 1, 5, 3, 1, 3, 4, 1, 4, 2 ]; super(i, r, e, t), this.type = "OctahedronGeometry", this.parameters = { radius: e, detail: t }; } static fromJSON(e) { return new _Rs(e.radius, e.detail); } }; var Hc = class extends Ke { constructor(e, t, i) { super(), this.type = "ParametricGeometry", this.parameters = { func: e, slices: t, stacks: i }; const r = [], s = [], o = [], a = [], c = 1e-5, l = new q(), d = new q(), h6 = new q(), f = new q(), g = new q(); e.length < 3 && console.error("THREE.ParametricGeometry: Function must now modify a Vector3 as third parameter."); const p = t + 1; for (let u = 0; u <= i; u++) { const y = u / i; for (let v = 0; v <= t; v++) { const m = v / t; e(m, y, d), s.push(d.x, d.y, d.z), m - c >= 0 ? (e(m - c, y, h6), f.subVectors(d, h6)) : (e(m + c, y, h6), f.subVectors(h6, d)), y - c >= 0 ? (e(m, y - c, h6), g.subVectors(d, h6)) : (e(m, y + c, h6), g.subVectors(h6, d)), l.crossVectors(f, g).normalize(), o.push(l.x, l.y, l.z), a.push(m, y); } } for (let u = 0; u < i; u++) for (let y = 0; y < t; y++) { const v = u * p + y, m = u * p + y + 1, x = (u + 1) * p + y + 1, w = (u + 1) * p + y; r.push(v, m, w), r.push(m, x, w); } this.setIndex(r), this.setAttribute("position", new He(s, 3)), this.setAttribute("normal", new He(o, 3)), this.setAttribute("uv", new He(a, 2)); } }; var Uo = class _Uo extends Ke { constructor(e = 0.5, t = 1, i = 8, r = 1, s = 0, o = Math.PI * 2) { super(), this.type = "RingGeometry", this.parameters = { innerRadius: e, outerRadius: t, thetaSegments: i, phiSegments: r, thetaStart: s, thetaLength: o }, i = Math.max(3, i), r = Math.max(1, r); const a = [], c = [], l = [], d = []; let h6 = e; const f = (t - e) / r, g = new q(), p = new Re(); for (let u = 0; u <= r; u++) { for (let y = 0; y <= i; y++) { const v = s + y / i * o; g.x = h6 * Math.cos(v), g.y = h6 * Math.sin(v), c.push(g.x, g.y, g.z), l.push(0, 0, 1), p.x = (g.x / t + 1) / 2, p.y = (g.y / t + 1) / 2, d.push(p.x, p.y); } h6 += f; } for (let u = 0; u < r; u++) { const y = u * (i + 1); for (let v = 0; v < i; v++) { const m = v + y, x = m, w = m + i + 1, A = m + i + 2, M = m + 1; a.push(x, w, M), a.push(w, A, M); } } this.setIndex(a), this.setAttribute("position", new He(c, 3)), this.setAttribute("normal", new He(l, 3)), this.setAttribute("uv", new He(d, 2)); } static fromJSON(e) { return new _Uo(e.innerRadius, e.outerRadius, e.thetaSegments, e.phiSegments, e.thetaStart, e.thetaLength); } }; var Fs = class _Fs extends Ke { constructor(e, t = 12) { super(), this.type = "ShapeGeometry", this.parameters = { shapes: e, curveSegments: t }; const i = [], r = [], s = [], o = []; let a = 0, c = 0; if (Array.isArray(e) === false) l(e); else for (let d = 0; d < e.length; d++) l(e[d]), this.addGroup(a, c, d), a += c, c = 0; this.setIndex(i), this.setAttribute("position", new He(r, 3)), this.setAttribute("normal", new He(s, 3)), this.setAttribute("uv", new He(o, 2)); function l(d) { const h6 = r.length / 3, f = d.extractPoints(t); let g = f.shape; const p = f.holes; Fi.isClockWise(g) === false && (g = g.reverse()); for (let y = 0, v = p.length; y < v; y++) { const m = p[y]; Fi.isClockWise(m) === true && (p[y] = m.reverse()); } const u = Fi.triangulateShape(g, p); for (let y = 0, v = p.length; y < v; y++) { const m = p[y]; g = g.concat(m); } for (let y = 0, v = g.length; y < v; y++) { const m = g[y]; r.push(m.x, m.y, 0), s.push(0, 0, 1), o.push(m.x, m.y); } for (let y = 0, v = u.length; y < v; y++) { const m = u[y], x = m[0] + h6, w = m[1] + h6, A = m[2] + h6; i.push(x, w, A), c += 3; } } } toJSON() { const e = super.toJSON(), t = this.parameters.shapes; return sN(t, e); } static fromJSON(e, t) { const i = []; for (let r = 0, s = e.shapes.length; r < s; r++) { const o = t[e.shapes[r]]; i.push(o); } return new _Fs(i, e.curveSegments); } }; function sN(n, e) { if (e.shapes = [], Array.isArray(n)) for (let t = 0, i = n.length; t < i; t++) { const r = n[t]; e.shapes.push(r.uuid); } else e.shapes.push(n.uuid); return e; } var Ps = class _Ps extends Ke { constructor(e = 1, t = 8, i = 6, r = 0, s = Math.PI * 2, o = 0, a = Math.PI) { super(), this.type = "SphereGeometry", this.parameters = { radius: e, widthSegments: t, heightSegments: i, phiStart: r, phiLength: s, thetaStart: o, thetaLength: a }, t = Math.max(3, Math.floor(t)), i = Math.max(2, Math.floor(i)); const c = Math.min(o + a, Math.PI); let l = 0; const d = [], h6 = new q(), f = new q(), g = [], p = [], u = [], y = []; for (let v = 0; v <= i; v++) { const m = [], x = v / i; let w = 0; v == 0 && o == 0 ? w = 0.5 / t : v == i && c == Math.PI && (w = -0.5 / t); for (let A = 0; A <= t; A++) { const M = A / t; h6.x = -e * Math.cos(r + M * s) * Math.sin(o + x * a), h6.y = e * Math.cos(o + x * a), h6.z = e * Math.sin(r + M * s) * Math.sin(o + x * a), p.push(h6.x, h6.y, h6.z), f.copy(h6).normalize(), u.push(f.x, f.y, f.z), y.push(M + w, 1 - x), m.push(l++); } d.push(m); } for (let v = 0; v < i; v++) for (let m = 0; m < t; m++) { const x = d[v][m + 1], w = d[v][m], A = d[v + 1][m], M = d[v + 1][m + 1]; (v !== 0 || o > 0) && g.push(x, w, M), (v !== i - 1 || c < Math.PI) && g.push(w, A, M); } this.setIndex(g), this.setAttribute("position", new He(p, 3)), this.setAttribute("normal", new He(u, 3)), this.setAttribute("uv", new He(y, 2)); } static fromJSON(e) { return new _Ps(e.radius, e.widthSegments, e.heightSegments, e.phiStart, e.phiLength, e.thetaStart, e.thetaLength); } }; var zo = class _zo extends Di { constructor(e = 1, t = 0) { const i = [ 1, 1, 1, -1, -1, 1, -1, 1, -1, 1, -1, -1 ], r = [ 2, 1, 0, 0, 3, 2, 1, 3, 0, 2, 3, 1 ]; super(i, r, e, t), this.type = "TetrahedronGeometry", this.parameters = { radius: e, detail: t }; } static fromJSON(e) { return new _zo(e.radius, e.detail); } }; var Wc = class extends mi { constructor(e, t = {}) { const i = t.font; if (!(i && i.isFont)) return console.error("THREE.TextGeometry: font parameter is not an instance of THREE.Font."), new Ke(); const r = i.generateShapes(e, t.size); t.depth = t.height !== void 0 ? t.height : 50, t.bevelThickness === void 0 && (t.bevelThickness = 10), t.bevelSize === void 0 && (t.bevelSize = 8), t.bevelEnabled === void 0 && (t.bevelEnabled = false), super(r, t), this.type = "TextGeometry"; } }; var Vo = class _Vo extends Ke { constructor(e = 1, t = 0.4, i = 8, r = 6, s = Math.PI * 2) { super(), this.type = "TorusGeometry", this.parameters = { radius: e, tube: t, radialSegments: i, tubularSegments: r, arc: s }, i = Math.floor(i), r = Math.floor(r); const o = [], a = [], c = [], l = [], d = new q(), h6 = new q(), f = new q(); for (let g = 0; g <= i; g++) for (let p = 0; p <= r; p++) { const u = p / r * s, y = g / i * Math.PI * 2; h6.x = (e + t * Math.cos(y)) * Math.cos(u), h6.y = (e + t * Math.cos(y)) * Math.sin(u), h6.z = t * Math.sin(y), a.push(h6.x, h6.y, h6.z), d.x = e * Math.cos(u), d.y = e * Math.sin(u), f.subVectors(h6, d).normalize(), c.push(f.x, f.y, f.z), l.push(p / r), l.push(g / i); } for (let g = 1; g <= i; g++) for (let p = 1; p <= r; p++) { const u = (r + 1) * g + p - 1, y = (r + 1) * (g - 1) + p - 1, v = (r + 1) * (g - 1) + p, m = (r + 1) * g + p; o.push(u, y, m), o.push(y, v, m); } this.setIndex(o), this.setAttribute("position", new He(a, 3)), this.setAttribute("normal", new He(c, 3)), this.setAttribute("uv", new He(l, 2)); } static fromJSON(e) { return new _Vo(e.radius, e.tube, e.radialSegments, e.tubularSegments, e.arc); } }; var ko = class _ko extends Ke { constructor(e = 1, t = 0.4, i = 64, r = 8, s = 2, o = 3) { super(), this.type = "TorusKnotGeometry", this.parameters = { radius: e, tube: t, tubularSegments: i, radialSegments: r, p: s, q: o }, i = Math.floor(i), r = Math.floor(r); const a = [], c = [], l = [], d = [], h6 = new q(), f = new q(), g = new q(), p = new q(), u = new q(), y = new q(), v = new q(); for (let x = 0; x <= i; ++x) { const w = x / i * s * Math.PI * 2; m(w, s, o, e, g), m(w + 0.01, s, o, e, p), y.subVectors(p, g), v.addVectors(p, g), u.crossVectors(y, v), v.crossVectors(u, y), u.normalize(), v.normalize(); for (let A = 0; A <= r; ++A) { const M = A / r * Math.PI * 2, R = -t * Math.cos(M), L = t * Math.sin(M); h6.x = g.x + (R * v.x + L * u.x), h6.y = g.y + (R * v.y + L * u.y), h6.z = g.z + (R * v.z + L * u.z), c.push(h6.x, h6.y, h6.z), f.subVectors(h6, g).normalize(), l.push(f.x, f.y, f.z), d.push(x / i), d.push(A / r); } } for (let x = 1; x <= i; x++) for (let w = 1; w <= r; w++) { const A = (r + 1) * (x - 1) + (w - 1), M = (r + 1) * x + (w - 1), R = (r + 1) * x + w, L = (r + 1) * (x - 1) + w; a.push(A, M, L), a.push(M, R, L); } this.setIndex(a), this.setAttribute("position", new He(c, 3)), this.setAttribute("normal", new He(l, 3)), this.setAttribute("uv", new He(d, 2)); function m(x, w, A, M, R) { const L = Math.cos(x), S = Math.sin(x), I = A / w * x, T = Math.cos(I); R.x = M * (2 + T) * 0.5 * L, R.y = M * (2 + T) * S * 0.5, R.z = M * Math.sin(I) * 0.5; } } static fromJSON(e) { return new _ko(e.radius, e.tube, e.tubularSegments, e.radialSegments, e.p, e.q); } }; var Go = class _Go extends Ke { constructor(e, t = 64, i = 1, r = 8, s = false) { super(), this.type = "TubeGeometry", this.parameters = { path: e, tubularSegments: t, radius: i, radialSegments: r, closed: s }; const o = e.computeFrenetFrames(t, s); this.tangents = o.tangents, this.normals = o.normals, this.binormals = o.binormals; const a = new q(), c = new q(), l = new Re(); let d = new q(); const h6 = [], f = [], g = [], p = []; u(), this.setIndex(p), this.setAttribute("position", new He(h6, 3)), this.setAttribute("normal", new He(f, 3)), this.setAttribute("uv", new He(g, 2)); function u() { for (let x = 0; x < t; x++) y(x); y(s === false ? t : 0), m(), v(); } function y(x) { d = e.getPointAt(x / t, d); const w = o.normals[x], A = o.binormals[x]; for (let M = 0; M <= r; M++) { const R = M / r * Math.PI * 2, L = Math.sin(R), S = -Math.cos(R); c.x = S * w.x + L * A.x, c.y = S * w.y + L * A.y, c.z = S * w.z + L * A.z, c.normalize(), f.push(c.x, c.y, c.z), a.x = d.x + i * c.x, a.y = d.y + i * c.y, a.z = d.z + i * c.z, h6.push(a.x, a.y, a.z); } } function v() { for (let x = 1; x <= t; x++) for (let w = 1; w <= r; w++) { const A = (r + 1) * (x - 1) + (w - 1), M = (r + 1) * x + (w - 1), R = (r + 1) * x + w, L = (r + 1) * (x - 1) + w; p.push(A, M, L), p.push(M, R, L); } } function m() { for (let x = 0; x <= t; x++) for (let w = 0; w <= r; w++) l.x = x / t, l.y = w / r, g.push(l.x, l.y); } } toJSON() { const e = super.toJSON(); return e.path = this.parameters.path.toJSON(), e; } static fromJSON(e) { return new _Go( new Vf[e.path.type]().fromJSON(e.path), e.tubularSegments, e.radius, e.radialSegments, e.closed ); } }; var kf = class extends Ke { constructor(e) { if (super(), this.type = "WireframeGeometry", e.isGeometry === true) { console.error("THREE.WireframeGeometry no longer supports THREE.Geometry. Use THREE.BufferGeometry instead."); return; } const t = [], i = [0, 0], r = {}, s = new q(); if (e.index !== null) { const o = e.attributes.position, a = e.index; let c = e.groups; c.length === 0 && (c = [{ start: 0, count: a.count, materialIndex: 0 }]); for (let l = 0, d = c.length; l < d; ++l) { const h6 = c[l], f = h6.start, g = h6.count; for (let p = f, u = f + g; p < u; p += 3) for (let y = 0; y < 3; y++) { const v = a.getX(p + y), m = a.getX(p + (y + 1) % 3); i[0] = Math.min(v, m), i[1] = Math.max(v, m); const x = i[0] + "," + i[1]; r[x] === void 0 && (r[x] = { index1: i[0], index2: i[1] }); } } for (const l in r) { const d = r[l]; s.fromBufferAttribute(o, d.index1), t.push(s.x, s.y, s.z), s.fromBufferAttribute(o, d.index2), t.push(s.x, s.y, s.z); } } else { const o = e.attributes.position; for (let a = 0, c = o.count / 3; a < c; a++) for (let l = 0; l < 3; l++) { const d = 3 * a + l; s.fromBufferAttribute(o, d), t.push(s.x, s.y, s.z); const h6 = 3 * a + (l + 1) % 3; s.fromBufferAttribute(o, h6), t.push(s.x, s.y, s.z); } } this.setAttribute("position", new He(t, 3)); } }; var zg = Object.freeze({ __proto__: null, BoxGeometry: sr, BoxBufferGeometry: sr, CircleGeometry: Io, CircleBufferGeometry: Io, ConeGeometry: Oo, ConeBufferGeometry: Oo, CylinderGeometry: $r, CylinderBufferGeometry: $r, DodecahedronGeometry: Do, DodecahedronBufferGeometry: Do, EdgesGeometry: Of, ExtrudeGeometry: mi, ExtrudeBufferGeometry: mi, IcosahedronGeometry: No, IcosahedronBufferGeometry: No, LatheGeometry: Bo, LatheBufferGeometry: Bo, OctahedronGeometry: Rs, OctahedronBufferGeometry: Rs, ParametricGeometry: Hc, ParametricBufferGeometry: Hc, PlaneGeometry: Ls, PlaneBufferGeometry: Ls, PolyhedronGeometry: Di, PolyhedronBufferGeometry: Di, RingGeometry: Uo, RingBufferGeometry: Uo, ShapeGeometry: Fs, ShapeBufferGeometry: Fs, SphereGeometry: Ps, SphereBufferGeometry: Ps, TetrahedronGeometry: zo, TetrahedronBufferGeometry: zo, TextGeometry: Wc, TextBufferGeometry: Wc, TorusGeometry: Vo, TorusBufferGeometry: Vo, TorusKnotGeometry: ko, TorusKnotBufferGeometry: ko, TubeGeometry: Go, TubeBufferGeometry: Go, WireframeGeometry: kf }); var Gf = class extends tn { constructor(e) { super(), this.type = "ShadowMaterial", this.color = new Ue(0), this.transparent = true, this.setValues(e); } copy(e) { return super.copy(e), this.color.copy(e.color), this; } }; Gf.prototype.isShadowMaterial = true; var ra = class extends or { constructor(e) { super(e), this.type = "RawShaderMaterial"; } }; ra.prototype.isRawShaderMaterial = true; var zs = class extends tn { constructor(e) { super(), this.defines = { STANDARD: "" }, this.type = "MeshStandardMaterial", this.color = new Ue(16777215), this.roughness = 1, this.metalness = 0, this.map = null, this.lightMap = null, this.lightMapIntensity = 1, this.aoMap = null, this.aoMapIntensity = 1, this.emissive = new Ue(0), this.emissiveIntensity = 1, this.emissiveMap = null, this.bumpMap = null, this.bumpScale = 1, this.normalMap = null, this.normalMapType = Jr, this.normalScale = new Re(1, 1), this.displacementMap = null, this.displacementScale = 1, this.displacementBias = 0, this.roughnessMap = null, this.metalnessMap = null, this.alphaMap = null, this.envMap = null, this.envMapIntensity = 1, this.refractionRatio = 0.98, this.wireframe = false, this.wireframeLinewidth = 1, this.wireframeLinecap = "round", this.wireframeLinejoin = "round", this.morphTargets = false, this.morphNormals = false, this.flatShading = false, this.vertexTangents = false, this.setValues(e); } copy(e) { return super.copy(e), this.defines = { STANDARD: "" }, this.color.copy(e.color), this.roughness = e.roughness, this.metalness = e.metalness, this.map = e.map, this.lightMap = e.lightMap, this.lightMapIntensity = e.lightMapIntensity, this.aoMap = e.aoMap, this.aoMapIntensity = e.aoMapIntensity, this.emissive.copy(e.emissive), this.emissiveMap = e.emissiveMap, this.emissiveIntensity = e.emissiveIntensity, this.bumpMap = e.bumpMap, this.bumpScale = e.bumpScale, this.normalMap = e.normalMap, this.normalMapType = e.normalMapType, this.normalScale.copy(e.normalScale), this.displacementMap = e.displacementMap, this.displacementScale = e.displacementScale, this.displacementBias = e.displacementBias, this.roughnessMap = e.roughnessMap, this.metalnessMap = e.metalnessMap, this.alphaMap = e.alphaMap, this.envMap = e.envMap, this.envMapIntensity = e.envMapIntensity, this.refractionRatio = e.refractionRatio, this.wireframe = e.wireframe, this.wireframeLinewidth = e.wireframeLinewidth, this.wireframeLinecap = e.wireframeLinecap, this.wireframeLinejoin = e.wireframeLinejoin, this.morphTargets = e.morphTargets, this.morphNormals = e.morphNormals, this.flatShading = e.flatShading, this.vertexTangents = e.vertexTangents, this; } }; zs.prototype.isMeshStandardMaterial = true; var wl = class extends zs { constructor(e) { super(), this.defines = { STANDARD: "", PHYSICAL: "" }, this.type = "MeshPhysicalMaterial", this.clearcoat = 0, this.clearcoatMap = null, this.clearcoatRoughness = 0, this.clearcoatRoughnessMap = null, this.clearcoatNormalScale = new Re(1, 1), this.clearcoatNormalMap = null, this.reflectivity = 0.5, Object.defineProperty(this, "ior", { get: function() { return (1 + 0.4 * this.reflectivity) / (1 - 0.4 * this.reflectivity); }, set: function(t) { this.reflectivity = gn(2.5 * (t - 1) / (t + 1), 0, 1); } }), this.sheen = null, this.transmission = 0, this.transmissionMap = null, this.thickness = 0.01, this.thicknessMap = null, this.attenuationDistance = 0, this.attenuationColor = new Ue(1, 1, 1), this.setValues(e); } copy(e) { return super.copy(e), this.defines = { STANDARD: "", PHYSICAL: "" }, this.clearcoat = e.clearcoat, this.clearcoatMap = e.clearcoatMap, this.clearcoatRoughness = e.clearcoatRoughness, this.clearcoatRoughnessMap = e.clearcoatRoughnessMap, this.clearcoatNormalMap = e.clearcoatNormalMap, this.clearcoatNormalScale.copy(e.clearcoatNormalScale), this.reflectivity = e.reflectivity, e.sheen ? this.sheen = (this.sheen || new Ue()).copy(e.sheen) : this.sheen = null, this.transmission = e.transmission, this.transmissionMap = e.transmissionMap, this.thickness = e.thickness, this.thicknessMap = e.thicknessMap, this.attenuationDistance = e.attenuationDistance, this.attenuationColor.copy(e.attenuationColor), this; } }; wl.prototype.isMeshPhysicalMaterial = true; var Hf = class extends tn { constructor(e) { super(), this.type = "MeshPhongMaterial", this.color = new Ue(16777215), this.specular = new Ue(1118481), this.shininess = 30, this.map = null, this.lightMap = null, this.lightMapIntensity = 1, this.aoMap = null, this.aoMapIntensity = 1, this.emissive = new Ue(0), this.emissiveIntensity = 1, this.emissiveMap = null, this.bumpMap = null, this.bumpScale = 1, this.normalMap = null, this.normalMapType = Jr, this.normalScale = new Re(1, 1), this.displacementMap = null, this.displacementScale = 1, this.displacementBias = 0, this.specularMap = null, this.alphaMap = null, this.envMap = null, this.combine = al, this.reflectivity = 1, this.refractionRatio = 0.98, this.wireframe = false, this.wireframeLinewidth = 1, this.wireframeLinecap = "round", this.wireframeLinejoin = "round", this.morphTargets = false, this.morphNormals = false, this.flatShading = false, this.setValues(e); } copy(e) { return super.copy(e), this.color.copy(e.color), this.specular.copy(e.specular), this.shininess = e.shininess, this.map = e.map, this.lightMap = e.lightMap, this.lightMapIntensity = e.lightMapIntensity, this.aoMap = e.aoMap, this.aoMapIntensity = e.aoMapIntensity, this.emissive.copy(e.emissive), this.emissiveMap = e.emissiveMap, this.emissiveIntensity = e.emissiveIntensity, this.bumpMap = e.bumpMap, this.bumpScale = e.bumpScale, this.normalMap = e.normalMap, this.normalMapType = e.normalMapType, this.normalScale.copy(e.normalScale), this.displacementMap = e.displacementMap, this.displacementScale = e.displacementScale, this.displacementBias = e.displacementBias, this.specularMap = e.specularMap, this.alphaMap = e.alphaMap, this.envMap = e.envMap, this.combine = e.combine, this.reflectivity = e.reflectivity, this.refractionRatio = e.refractionRatio, this.wireframe = e.wireframe, this.wireframeLinewidth = e.wireframeLinewidth, this.wireframeLinecap = e.wireframeLinecap, this.wireframeLinejoin = e.wireframeLinejoin, this.morphTargets = e.morphTargets, this.morphNormals = e.morphNormals, this.flatShading = e.flatShading, this; } }; Hf.prototype.isMeshPhongMaterial = true; var Wf = class extends tn { constructor(e) { super(), this.defines = { TOON: "" }, this.type = "MeshToonMaterial", this.color = new Ue(16777215), this.map = null, this.gradientMap = null, this.lightMap = null, this.lightMapIntensity = 1, this.aoMap = null, this.aoMapIntensity = 1, this.emissive = new Ue(0), this.emissiveIntensity = 1, this.emissiveMap = null, this.bumpMap = null, this.bumpScale = 1, this.normalMap = null, this.normalMapType = Jr, this.normalScale = new Re(1, 1), this.displacementMap = null, this.displacementScale = 1, this.displacementBias = 0, this.alphaMap = null, this.wireframe = false, this.wireframeLinewidth = 1, this.wireframeLinecap = "round", this.wireframeLinejoin = "round", this.morphTargets = false, this.morphNormals = false, this.setValues(e); } copy(e) { return super.copy(e), this.color.copy(e.color), this.map = e.map, this.gradientMap = e.gradientMap, this.lightMap = e.lightMap, this.lightMapIntensity = e.lightMapIntensity, this.aoMap = e.aoMap, this.aoMapIntensity = e.aoMapIntensity, this.emissive.copy(e.emissive), this.emissiveMap = e.emissiveMap, this.emissiveIntensity = e.emissiveIntensity, this.bumpMap = e.bumpMap, this.bumpScale = e.bumpScale, this.normalMap = e.normalMap, this.normalMapType = e.normalMapType, this.normalScale.copy(e.normalScale), this.displacementMap = e.displacementMap, this.displacementScale = e.displacementScale, this.displacementBias = e.displacementBias, this.alphaMap = e.alphaMap, this.wireframe = e.wireframe, this.wireframeLinewidth = e.wireframeLinewidth, this.wireframeLinecap = e.wireframeLinecap, this.wireframeLinejoin = e.wireframeLinejoin, this.morphTargets = e.morphTargets, this.morphNormals = e.morphNormals, this; } }; Wf.prototype.isMeshToonMaterial = true; var jf = class extends tn { constructor(e) { super(), this.type = "MeshNormalMaterial", this.bumpMap = null, this.bumpScale = 1, this.normalMap = null, this.normalMapType = Jr, this.normalScale = new Re(1, 1), this.displacementMap = null, this.displacementScale = 1, this.displacementBias = 0, this.wireframe = false, this.wireframeLinewidth = 1, this.fog = false, this.morphTargets = false, this.morphNormals = false, this.flatShading = false, this.setValues(e); } copy(e) { return super.copy(e), this.bumpMap = e.bumpMap, this.bumpScale = e.bumpScale, this.normalMap = e.normalMap, this.normalMapType = e.normalMapType, this.normalScale.copy(e.normalScale), this.displacementMap = e.displacementMap, this.displacementScale = e.displacementScale, this.displacementBias = e.displacementBias, this.wireframe = e.wireframe, this.wireframeLinewidth = e.wireframeLinewidth, this.morphTargets = e.morphTargets, this.morphNormals = e.morphNormals, this.flatShading = e.flatShading, this; } }; jf.prototype.isMeshNormalMaterial = true; var $f = class extends tn { constructor(e) { super(), this.type = "MeshLambertMaterial", this.color = new Ue(16777215), this.map = null, this.lightMap = null, this.lightMapIntensity = 1, this.aoMap = null, this.aoMapIntensity = 1, this.emissive = new Ue(0), this.emissiveIntensity = 1, this.emissiveMap = null, this.specularMap = null, this.alphaMap = null, this.envMap = null, this.combine = al, this.reflectivity = 1, this.refractionRatio = 0.98, this.wireframe = false, this.wireframeLinewidth = 1, this.wireframeLinecap = "round", this.wireframeLinejoin = "round", this.morphTargets = false, this.morphNormals = false, this.setValues(e); } copy(e) { return super.copy(e), this.color.copy(e.color), this.map = e.map, this.lightMap = e.lightMap, this.lightMapIntensity = e.lightMapIntensity, this.aoMap = e.aoMap, this.aoMapIntensity = e.aoMapIntensity, this.emissive.copy(e.emissive), this.emissiveMap = e.emissiveMap, this.emissiveIntensity = e.emissiveIntensity, this.specularMap = e.specularMap, this.alphaMap = e.alphaMap, this.envMap = e.envMap, this.combine = e.combine, this.reflectivity = e.reflectivity, this.refractionRatio = e.refractionRatio, this.wireframe = e.wireframe, this.wireframeLinewidth = e.wireframeLinewidth, this.wireframeLinecap = e.wireframeLinecap, this.wireframeLinejoin = e.wireframeLinejoin, this.morphTargets = e.morphTargets, this.morphNormals = e.morphNormals, this; } }; $f.prototype.isMeshLambertMaterial = true; var Zf = class extends tn { constructor(e) { super(), this.defines = { MATCAP: "" }, this.type = "MeshMatcapMaterial", this.color = new Ue(16777215), this.matcap = null, this.map = null, this.bumpMap = null, this.bumpScale = 1, this.normalMap = null, this.normalMapType = Jr, this.normalScale = new Re(1, 1), this.displacementMap = null, this.displacementScale = 1, this.displacementBias = 0, this.alphaMap = null, this.morphTargets = false, this.morphNormals = false, this.flatShading = false, this.setValues(e); } copy(e) { return super.copy(e), this.defines = { MATCAP: "" }, this.color.copy(e.color), this.matcap = e.matcap, this.map = e.map, this.bumpMap = e.bumpMap, this.bumpScale = e.bumpScale, this.normalMap = e.normalMap, this.normalMapType = e.normalMapType, this.normalScale.copy(e.normalScale), this.displacementMap = e.displacementMap, this.displacementScale = e.displacementScale, this.displacementBias = e.displacementBias, this.alphaMap = e.alphaMap, this.morphTargets = e.morphTargets, this.morphNormals = e.morphNormals, this.flatShading = e.flatShading, this; } }; Zf.prototype.isMeshMatcapMaterial = true; var Xf = class extends an { constructor(e) { super(), this.type = "LineDashedMaterial", this.scale = 1, this.dashSize = 3, this.gapSize = 1, this.setValues(e); } copy(e) { return super.copy(e), this.scale = e.scale, this.dashSize = e.dashSize, this.gapSize = e.gapSize, this; } }; Xf.prototype.isLineDashedMaterial = true; var oN = Object.freeze({ __proto__: null, ShadowMaterial: Gf, SpriteMaterial: ml, RawShaderMaterial: ra, ShaderMaterial: or, PointsMaterial: es, MeshPhysicalMaterial: wl, MeshStandardMaterial: zs, MeshPhongMaterial: Hf, MeshToonMaterial: Wf, MeshNormalMaterial: jf, MeshLambertMaterial: $f, MeshDepthMaterial: xu, MeshDistanceMaterial: Mu, MeshBasicMaterial: In, MeshMatcapMaterial: Zf, LineDashedMaterial: Xf, LineBasicMaterial: an, Material: tn }); var Ct = { // same as Array.prototype.slice, but also works on typed arrays arraySlice: function(n, e, t) { return Ct.isTypedArray(n) ? new n.constructor(n.subarray(e, t !== void 0 ? t : n.length)) : n.slice(e, t); }, // converts an array to a specific type convertArray: function(n, e, t) { return !n || // let 'undefined' and 'null' pass !t && n.constructor === e ? n : typeof e.BYTES_PER_ELEMENT == "number" ? new e(n) : Array.prototype.slice.call(n); }, isTypedArray: function(n) { return ArrayBuffer.isView(n) && !(n instanceof DataView); }, // returns an array by which times and values can be sorted getKeyframeOrder: function(n) { function e(r, s) { return n[r] - n[s]; } const t = n.length, i = new Array(t); for (let r = 0; r !== t; ++r) i[r] = r; return i.sort(e), i; }, // uses the array previously returned by 'getKeyframeOrder' to sort data sortedArray: function(n, e, t) { const i = n.length, r = new n.constructor(i); for (let s = 0, o = 0; o !== i; ++s) { const a = t[s] * e; for (let c = 0; c !== e; ++c) r[o++] = n[a + c]; } return r; }, // function for parsing AOS keyframe formats flattenJSON: function(n, e, t, i) { let r = 1, s = n[0]; for (; s !== void 0 && s[i] === void 0; ) s = n[r++]; if (s === void 0) return; let o = s[i]; if (o !== void 0) if (Array.isArray(o)) do o = s[i], o !== void 0 && (e.push(s.time), t.push.apply(t, o)), s = n[r++]; while (s !== void 0); else if (o.toArray !== void 0) do o = s[i], o !== void 0 && (e.push(s.time), o.toArray(t, t.length)), s = n[r++]; while (s !== void 0); else do o = s[i], o !== void 0 && (e.push(s.time), t.push(o)), s = n[r++]; while (s !== void 0); }, subclip: function(n, e, t, i, r = 30) { const s = n.clone(); s.name = e; const o = []; for (let c = 0; c < s.tracks.length; ++c) { const l = s.tracks[c], d = l.getValueSize(), h6 = [], f = []; for (let g = 0; g < l.times.length; ++g) { const p = l.times[g] * r; if (!(p < t || p >= i)) { h6.push(l.times[g]); for (let u = 0; u < d; ++u) f.push(l.values[g * d + u]); } } h6.length !== 0 && (l.times = Ct.convertArray(h6, l.times.constructor), l.values = Ct.convertArray(f, l.values.constructor), o.push(l)); } s.tracks = o; let a = 1 / 0; for (let c = 0; c < s.tracks.length; ++c) a > s.tracks[c].times[0] && (a = s.tracks[c].times[0]); for (let c = 0; c < s.tracks.length; ++c) s.tracks[c].shift(-1 * a); return s.resetDuration(), s; }, makeClipAdditive: function(n, e = 0, t = n, i = 30) { i <= 0 && (i = 30); const r = t.tracks.length, s = e / i; for (let o = 0; o < r; ++o) { const a = t.tracks[o], c = a.ValueTypeName; if (c === "bool" || c === "string") continue; const l = n.tracks.find(function(v) { return v.name === a.name && v.ValueTypeName === c; }); if (l === void 0) continue; let d = 0; const h6 = a.getValueSize(); a.createInterpolant.isInterpolantFactoryMethodGLTFCubicSpline && (d = h6 / 3); let f = 0; const g = l.getValueSize(); l.createInterpolant.isInterpolantFactoryMethodGLTFCubicSpline && (f = g / 3); const p = a.times.length - 1; let u; if (s <= a.times[0]) { const v = d, m = h6 - d; u = Ct.arraySlice(a.values, v, m); } else if (s >= a.times[p]) { const v = p * h6 + d, m = v + h6 - d; u = Ct.arraySlice(a.values, v, m); } else { const v = a.createInterpolant(), m = d, x = h6 - d; v.evaluate(s), u = Ct.arraySlice(v.resultBuffer, m, x); } c === "quaternion" && new bn().fromArray(u).normalize().conjugate().toArray(u); const y = l.times.length; for (let v = 0; v < y; ++v) { const m = v * g + f; if (c === "quaternion") bn.multiplyQuaternionsFlat( l.values, m, u, 0, l.values, m ); else { const x = g - f * 2; for (let w = 0; w < x; ++w) l.values[m + w] -= u[w]; } } } return n.blendMode = Mf, n; } }; var Ni = class { constructor(e, t, i, r) { this.parameterPositions = e, this._cachedIndex = 0, this.resultBuffer = r !== void 0 ? r : new t.constructor(i), this.sampleValues = t, this.valueSize = i, this.settings = null, this.DefaultSettings_ = {}; } evaluate(e) { const t = this.parameterPositions; let i = this._cachedIndex, r = t[i], s = t[i - 1]; e: { t: { let o; n: { i: if (!(e < r)) { for (let a = i + 2; ; ) { if (r === void 0) { if (e < s) break i; return i = t.length, this._cachedIndex = i, this.afterEnd_(i - 1, e, s); } if (i === a) break; if (s = r, r = t[++i], e < r) break t; } o = t.length; break n; } if (!(e >= s)) { const a = t[1]; e < a && (i = 2, s = a); for (let c = i - 2; ; ) { if (s === void 0) return this._cachedIndex = 0, this.beforeStart_(0, e, r); if (i === c) break; if (r = s, s = t[--i - 1], e >= s) break t; } o = i, i = 0; break n; } break e; } for (; i < o; ) { const a = i + o >>> 1; e < t[a] ? o = a : i = a + 1; } if (r = t[i], s = t[i - 1], s === void 0) return this._cachedIndex = 0, this.beforeStart_(0, e, r); if (r === void 0) return i = t.length, this._cachedIndex = i, this.afterEnd_(i - 1, s, e); } this._cachedIndex = i, this.intervalChanged_(i, s, r); } return this.interpolate_(i, s, e, r); } getSettings_() { return this.settings || this.DefaultSettings_; } copySampleValue_(e) { const t = this.resultBuffer, i = this.sampleValues, r = this.valueSize, s = e * r; for (let o = 0; o !== r; ++o) t[o] = i[s + o]; return t; } // Template methods for derived classes: interpolate_() { throw new Error("call to abstract method"); } intervalChanged_() { } }; Ni.prototype.beforeStart_ = Ni.prototype.copySampleValue_; Ni.prototype.afterEnd_ = Ni.prototype.copySampleValue_; var Px = class extends Ni { constructor(e, t, i, r) { super(e, t, i, r), this._weightPrev = -0, this._offsetPrev = -0, this._weightNext = -0, this._offsetNext = -0, this.DefaultSettings_ = { endingStart: gs, endingEnd: gs }; } intervalChanged_(e, t, i) { const r = this.parameterPositions; let s = e - 2, o = e + 1, a = r[s], c = r[o]; if (a === void 0) switch (this.getSettings_().endingStart) { case vs: s = e, a = 2 * t - i; break; case Wa: s = r.length - 2, a = t + r[s] - r[s + 1]; break; default: s = e, a = i; } if (c === void 0) switch (this.getSettings_().endingEnd) { case vs: o = e, c = 2 * i - t; break; case Wa: o = 1, c = i + r[1] - r[0]; break; default: o = e - 1, c = t; } const l = (i - t) * 0.5, d = this.valueSize; this._weightPrev = l / (t - a), this._weightNext = l / (c - i), this._offsetPrev = s * d, this._offsetNext = o * d; } interpolate_(e, t, i, r) { const s = this.resultBuffer, o = this.sampleValues, a = this.valueSize, c = e * a, l = c - a, d = this._offsetPrev, h6 = this._offsetNext, f = this._weightPrev, g = this._weightNext, p = (i - t) / (r - t), u = p * p, y = u * p, v = -f * y + 2 * f * u - f * p, m = (1 + f) * y + (-1.5 - 2 * f) * u + (-0.5 + f) * p + 1, x = (-1 - g) * y + (1.5 + g) * u + 0.5 * p, w = g * y - g * u; for (let A = 0; A !== a; ++A) s[A] = v * o[d + A] + m * o[l + A] + x * o[c + A] + w * o[h6 + A]; return s; } }; var Yf = class extends Ni { constructor(e, t, i, r) { super(e, t, i, r); } interpolate_(e, t, i, r) { const s = this.resultBuffer, o = this.sampleValues, a = this.valueSize, c = e * a, l = c - a, d = (i - t) / (r - t), h6 = 1 - d; for (let f = 0; f !== a; ++f) s[f] = o[l + f] * h6 + o[c + f] * d; return s; } }; var Ix = class extends Ni { constructor(e, t, i, r) { super(e, t, i, r); } interpolate_(e) { return this.copySampleValue_(e - 1); } }; var xi = class { constructor(e, t, i, r) { if (e === void 0) throw new Error("THREE.KeyframeTrack: track name is undefined"); if (t === void 0 || t.length === 0) throw new Error("THREE.KeyframeTrack: no keyframes in track named " + e); this.name = e, this.times = Ct.convertArray(t, this.TimeBufferType), this.values = Ct.convertArray(i, this.ValueBufferType), this.setInterpolation(r || this.DefaultInterpolation); } // Serialization (in static context, because of constructor invocation // and automatic invocation of .toJSON): static toJSON(e) { const t = e.constructor; let i; if (t.toJSON !== this.toJSON) i = t.toJSON(e); else { i = { name: e.name, times: Ct.convertArray(e.times, Array), values: Ct.convertArray(e.values, Array) }; const r = e.getInterpolation(); r !== e.DefaultInterpolation && (i.interpolation = r); } return i.type = e.ValueTypeName, i; } InterpolantFactoryMethodDiscrete(e) { return new Ix(this.times, this.values, this.getValueSize(), e); } InterpolantFactoryMethodLinear(e) { return new Yf(this.times, this.values, this.getValueSize(), e); } InterpolantFactoryMethodSmooth(e) { return new Px(this.times, this.values, this.getValueSize(), e); } setInterpolation(e) { let t; switch (e) { case Lo: t = this.InterpolantFactoryMethodDiscrete; break; case Es: t = this.InterpolantFactoryMethodLinear; break; case Cc: t = this.InterpolantFactoryMethodSmooth; break; } if (t === void 0) { const i = "unsupported interpolation for " + this.ValueTypeName + " keyframe track named " + this.name; if (this.createInterpolant === void 0) if (e !== this.DefaultInterpolation) this.setInterpolation(this.DefaultInterpolation); else throw new Error(i); return console.warn("THREE.KeyframeTrack:", i), this; } return this.createInterpolant = t, this; } getInterpolation() { switch (this.createInterpolant) { case this.InterpolantFactoryMethodDiscrete: return Lo; case this.InterpolantFactoryMethodLinear: return Es; case this.InterpolantFactoryMethodSmooth: return Cc; } } getValueSize() { return this.values.length / this.times.length; } // move all keyframes either forwards or backwards in time shift(e) { if (e !== 0) { const t = this.times; for (let i = 0, r = t.length; i !== r; ++i) t[i] += e; } return this; } // scale all keyframe times by a factor (useful for frame <-> seconds conversions) scale(e) { if (e !== 1) { const t = this.times; for (let i = 0, r = t.length; i !== r; ++i) t[i] *= e; } return this; } // removes keyframes before and after animation without changing any values within the range [startTime, endTime]. // IMPORTANT: We do not shift around keys to the start of the track time, because for interpolated keys this will change their values trim(e, t) { const i = this.times, r = i.length; let s = 0, o = r - 1; for (; s !== r && i[s] < e; ) ++s; for (; o !== -1 && i[o] > t; ) --o; if (++o, s !== 0 || o !== r) { s >= o && (o = Math.max(o, 1), s = o - 1); const a = this.getValueSize(); this.times = Ct.arraySlice(i, s, o), this.values = Ct.arraySlice(this.values, s * a, o * a); } return this; } // ensure we do not get a GarbageInGarbageOut situation, make sure tracks are at least minimally viable validate() { let e = true; const t = this.getValueSize(); t - Math.floor(t) !== 0 && (console.error("THREE.KeyframeTrack: Invalid value size in track.", this), e = false); const i = this.times, r = this.values, s = i.length; s === 0 && (console.error("THREE.KeyframeTrack: Track is empty.", this), e = false); let o = null; for (let a = 0; a !== s; a++) { const c = i[a]; if (typeof c == "number" && isNaN(c)) { console.error("THREE.KeyframeTrack: Time is not a valid number.", this, a, c), e = false; break; } if (o !== null && o > c) { console.error("THREE.KeyframeTrack: Out of order keys.", this, a, c, o), e = false; break; } o = c; } if (r !== void 0 && Ct.isTypedArray(r)) for (let a = 0, c = r.length; a !== c; ++a) { const l = r[a]; if (isNaN(l)) { console.error("THREE.KeyframeTrack: Value is not a valid number.", this, a, l), e = false; break; } } return e; } // removes equivalent sequential keys as common in morph target sequences // (0,0,0,0,1,1,1,0,0,0,0,0,0,0) --> (0,0,1,1,0,0) optimize() { const e = Ct.arraySlice(this.times), t = Ct.arraySlice(this.values), i = this.getValueSize(), r = this.getInterpolation() === Cc, s = e.length - 1; let o = 1; for (let a = 1; a < s; ++a) { let c = false; const l = e[a], d = e[a + 1]; if (l !== d && (a !== 1 || l !== e[0])) if (r) c = true; else { const h6 = a * i, f = h6 - i, g = h6 + i; for (let p = 0; p !== i; ++p) { const u = t[h6 + p]; if (u !== t[f + p] || u !== t[g + p]) { c = true; break; } } } if (c) { if (a !== o) { e[o] = e[a]; const h6 = a * i, f = o * i; for (let g = 0; g !== i; ++g) t[f + g] = t[h6 + g]; } ++o; } } if (s > 0) { e[o] = e[s]; for (let a = s * i, c = o * i, l = 0; l !== i; ++l) t[c + l] = t[a + l]; ++o; } return o !== e.length ? (this.times = Ct.arraySlice(e, 0, o), this.values = Ct.arraySlice(t, 0, o * i)) : (this.times = e, this.values = t), this; } clone() { const e = Ct.arraySlice(this.times, 0), t = Ct.arraySlice(this.values, 0), i = this.constructor, r = new i(this.name, e, t); return r.createInterpolant = this.createInterpolant, r; } }; xi.prototype.TimeBufferType = Float32Array; xi.prototype.ValueBufferType = Float32Array; xi.prototype.DefaultInterpolation = Es; var Vs = class extends xi { }; Vs.prototype.ValueTypeName = "bool"; Vs.prototype.ValueBufferType = Array; Vs.prototype.DefaultInterpolation = Lo; Vs.prototype.InterpolantFactoryMethodLinear = void 0; Vs.prototype.InterpolantFactoryMethodSmooth = void 0; var Jf = class extends xi { }; Jf.prototype.ValueTypeName = "color"; var Ho = class extends xi { }; Ho.prototype.ValueTypeName = "number"; var Ox = class extends Ni { constructor(e, t, i, r) { super(e, t, i, r); } interpolate_(e, t, i, r) { const s = this.resultBuffer, o = this.sampleValues, a = this.valueSize, c = (i - t) / (r - t); let l = e * a; for (let d = l + a; l !== d; l += 4) bn.slerpFlat(s, 0, o, l - a, o, l, c); return s; } }; var ks = class extends xi { InterpolantFactoryMethodLinear(e) { return new Ox(this.times, this.values, this.getValueSize(), e); } }; ks.prototype.ValueTypeName = "quaternion"; ks.prototype.DefaultInterpolation = Es; ks.prototype.InterpolantFactoryMethodSmooth = void 0; var Gs = class extends xi { }; Gs.prototype.ValueTypeName = "string"; Gs.prototype.ValueBufferType = Array; Gs.prototype.DefaultInterpolation = Lo; Gs.prototype.InterpolantFactoryMethodLinear = void 0; Gs.prototype.InterpolantFactoryMethodSmooth = void 0; var Wo = class extends xi { }; Wo.prototype.ValueTypeName = "vector"; var jo = class { constructor(e, t = -1, i, r = fu) { this.name = e, this.tracks = i, this.duration = t, this.blendMode = r, this.uuid = Hn(), this.duration < 0 && this.resetDuration(); } static parse(e) { const t = [], i = e.tracks, r = 1 / (e.fps || 1); for (let o = 0, a = i.length; o !== a; ++o) t.push(lN(i[o]).scale(r)); const s = new this(e.name, e.duration, t, e.blendMode); return s.uuid = e.uuid, s; } static toJSON(e) { const t = [], i = e.tracks, r = { name: e.name, duration: e.duration, tracks: t, uuid: e.uuid, blendMode: e.blendMode }; for (let s = 0, o = i.length; s !== o; ++s) t.push(xi.toJSON(i[s])); return r; } static CreateFromMorphTargetSequence(e, t, i, r) { const s = t.length, o = []; for (let a = 0; a < s; a++) { let c = [], l = []; c.push( (a + s - 1) % s, a, (a + 1) % s ), l.push(0, 1, 0); const d = Ct.getKeyframeOrder(c); c = Ct.sortedArray(c, 1, d), l = Ct.sortedArray(l, 1, d), !r && c[0] === 0 && (c.push(s), l.push(l[0])), o.push( new Ho( ".morphTargetInfluences[" + t[a].name + "]", c, l ).scale(1 / i) ); } return new this(e, -1, o); } static findByName(e, t) { let i = e; if (!Array.isArray(e)) { const r = e; i = r.geometry && r.geometry.animations || r.animations; } for (let r = 0; r < i.length; r++) if (i[r].name === t) return i[r]; return null; } static CreateClipsFromMorphTargetSequences(e, t, i) { const r = {}, s = /^([\w-]*?)([\d]+)$/; for (let a = 0, c = e.length; a < c; a++) { const l = e[a], d = l.name.match(s); if (d && d.length > 1) { const h6 = d[1]; let f = r[h6]; f || (r[h6] = f = []), f.push(l); } } const o = []; for (const a in r) o.push(this.CreateFromMorphTargetSequence(a, r[a], t, i)); return o; } // parse the animation.hierarchy format static parseAnimation(e, t) { if (!e) return console.error("THREE.AnimationClip: No animation in JSONLoader data."), null; const i = function(h6, f, g, p, u) { if (g.length !== 0) { const y = [], v = []; Ct.flattenJSON(g, y, v, p), y.length !== 0 && u.push(new h6(f, y, v)); } }, r = [], s = e.name || "default", o = e.fps || 30, a = e.blendMode; let c = e.length || -1; const l = e.hierarchy || []; for (let h6 = 0; h6 < l.length; h6++) { const f = l[h6].keys; if (!(!f || f.length === 0)) if (f[0].morphTargets) { const g = {}; let p; for (p = 0; p < f.length; p++) if (f[p].morphTargets) for (let u = 0; u < f[p].morphTargets.length; u++) g[f[p].morphTargets[u]] = -1; for (const u in g) { const y = [], v = []; for (let m = 0; m !== f[p].morphTargets.length; ++m) { const x = f[p]; y.push(x.time), v.push(x.morphTarget === u ? 1 : 0); } r.push(new Ho(".morphTargetInfluence[" + u + "]", y, v)); } c = g.length * (o || 1); } else { const g = ".bones[" + t[h6].name + "]"; i( Wo, g + ".position", f, "pos", r ), i( ks, g + ".quaternion", f, "rot", r ), i( Wo, g + ".scale", f, "scl", r ); } } return r.length === 0 ? null : new this(s, c, r, a); } resetDuration() { const e = this.tracks; let t = 0; for (let i = 0, r = e.length; i !== r; ++i) { const s = this.tracks[i]; t = Math.max(t, s.times[s.times.length - 1]); } return this.duration = t, this; } trim() { for (let e = 0; e < this.tracks.length; e++) this.tracks[e].trim(0, this.duration); return this; } validate() { let e = true; for (let t = 0; t < this.tracks.length; t++) e = e && this.tracks[t].validate(); return e; } optimize() { for (let e = 0; e < this.tracks.length; e++) this.tracks[e].optimize(); return this; } clone() { const e = []; for (let t = 0; t < this.tracks.length; t++) e.push(this.tracks[t].clone()); return new this.constructor(this.name, this.duration, e, this.blendMode); } toJSON() { return this.constructor.toJSON(this); } }; function aN(n) { switch (n.toLowerCase()) { case "scalar": case "double": case "float": case "number": case "integer": return Ho; case "vector": case "vector2": case "vector3": case "vector4": return Wo; case "color": return Jf; case "quaternion": return ks; case "bool": case "boolean": return Vs; case "string": return Gs; } throw new Error("THREE.KeyframeTrack: Unsupported typeName: " + n); } function lN(n) { if (n.type === void 0) throw new Error("THREE.KeyframeTrack: track type undefined, can not parse"); const e = aN(n.type); if (n.times === void 0) { const t = [], i = []; Ct.flattenJSON(n.keys, t, i, "value"), n.times = t, n.values = i; } return e.parse !== void 0 ? e.parse(n) : new e(n.name, n.times, n.values, n.interpolation); } var Is = { enabled: false, files: {}, add: function(n, e) { this.enabled !== false && (this.files[n] = e); }, get: function(n) { if (this.enabled !== false) return this.files[n]; }, remove: function(n) { delete this.files[n]; }, clear: function() { this.files = {}; } }; var Kf = class { constructor(e, t, i) { const r = this; let s = false, o = 0, a = 0, c; const l = []; this.onStart = void 0, this.onLoad = e, this.onProgress = t, this.onError = i, this.itemStart = function(d) { a++, s === false && r.onStart !== void 0 && r.onStart(d, o, a), s = true; }, this.itemEnd = function(d) { o++, r.onProgress !== void 0 && r.onProgress(d, o, a), o === a && (s = false, r.onLoad !== void 0 && r.onLoad()); }, this.itemError = function(d) { r.onError !== void 0 && r.onError(d); }, this.resolveURL = function(d) { return c ? c(d) : d; }, this.setURLModifier = function(d) { return c = d, this; }, this.addHandler = function(d, h6) { return l.push(d, h6), this; }, this.removeHandler = function(d) { const h6 = l.indexOf(d); return h6 !== -1 && l.splice(h6, 2), this; }, this.getHandler = function(d) { for (let h6 = 0, f = l.length; h6 < f; h6 += 2) { const g = l[h6], p = l[h6 + 1]; if (g.global && (g.lastIndex = 0), g.test(d)) return p; } return null; }; } }; var Dx = new Kf(); var xn = class { constructor(e) { this.manager = e !== void 0 ? e : Dx, this.crossOrigin = "anonymous", this.withCredentials = false, this.path = "", this.resourcePath = "", this.requestHeader = {}; } load() { } loadAsync(e, t) { const i = this; return new Promise(function(r, s) { i.load(e, r, t, s); }); } parse() { } setCrossOrigin(e) { return this.crossOrigin = e, this; } setWithCredentials(e) { return this.withCredentials = e, this; } setPath(e) { return this.path = e, this; } setResourcePath(e) { return this.resourcePath = e, this; } setRequestHeader(e) { return this.requestHeader = e, this; } }; var ai = {}; var $n = class extends xn { constructor(e) { super(e); } load(e, t, i, r) { e === void 0 && (e = ""), this.path !== void 0 && (e = this.path + e), e = this.manager.resolveURL(e); const s = this, o = Is.get(e); if (o !== void 0) return s.manager.itemStart(e), setTimeout(function() { t && t(o), s.manager.itemEnd(e); }, 0), o; if (ai[e] !== void 0) { ai[e].push({ onLoad: t, onProgress: i, onError: r }); return; } const a = /^data:(.*?)(;base64)?,(.*)$/, c = e.match(a); let l; if (c) { const d = c[1], h6 = !!c[2]; let f = c[3]; f = decodeURIComponent(f), h6 && (f = atob(f)); try { let g; const p = (this.responseType || "").toLowerCase(); switch (p) { case "arraybuffer": case "blob": const u = new Uint8Array(f.length); for (let v = 0; v < f.length; v++) u[v] = f.charCodeAt(v); p === "blob" ? g = new Blob([u.buffer], { type: d }) : g = u.buffer; break; case "document": g = new DOMParser().parseFromString(f, d); break; case "json": g = JSON.parse(f); break; default: g = f; break; } setTimeout(function() { t && t(g), s.manager.itemEnd(e); }, 0); } catch (g) { setTimeout(function() { r && r(g), s.manager.itemError(e), s.manager.itemEnd(e); }, 0); } } else { ai[e] = [], ai[e].push({ onLoad: t, onProgress: i, onError: r }), l = new XMLHttpRequest(), l.open("GET", e, true), l.addEventListener("load", function(d) { const h6 = this.response, f = ai[e]; if (delete ai[e], this.status === 200 || this.status === 0) { this.status === 0 && console.warn("THREE.FileLoader: HTTP Status 0 received."), Is.add(e, h6); for (let g = 0, p = f.length; g < p; g++) { const u = f[g]; u.onLoad && u.onLoad(h6); } s.manager.itemEnd(e); } else { for (let g = 0, p = f.length; g < p; g++) { const u = f[g]; u.onError && u.onError(d); } s.manager.itemError(e), s.manager.itemEnd(e); } }, false), l.addEventListener("progress", function(d) { const h6 = ai[e]; for (let f = 0, g = h6.length; f < g; f++) { const p = h6[f]; p.onProgress && p.onProgress(d); } }, false), l.addEventListener("error", function(d) { const h6 = ai[e]; delete ai[e]; for (let f = 0, g = h6.length; f < g; f++) { const p = h6[f]; p.onError && p.onError(d); } s.manager.itemError(e), s.manager.itemEnd(e); }, false), l.addEventListener("abort", function(d) { const h6 = ai[e]; delete ai[e]; for (let f = 0, g = h6.length; f < g; f++) { const p = h6[f]; p.onError && p.onError(d); } s.manager.itemError(e), s.manager.itemEnd(e); }, false), this.responseType !== void 0 && (l.responseType = this.responseType), this.withCredentials !== void 0 && (l.withCredentials = this.withCredentials), l.overrideMimeType && l.overrideMimeType(this.mimeType !== void 0 ? this.mimeType : "text/plain"); for (const d in this.requestHeader) l.setRequestHeader(d, this.requestHeader[d]); l.send(null); } return s.manager.itemStart(e), l; } setResponseType(e) { return this.responseType = e, this; } setMimeType(e) { return this.mimeType = e, this; } }; var cN = class extends xn { constructor(e) { super(e); } load(e, t, i, r) { const s = this, o = new $n(this.manager); o.setPath(this.path), o.setRequestHeader(this.requestHeader), o.setWithCredentials(this.withCredentials), o.load(e, function(a) { try { t(s.parse(JSON.parse(a))); } catch (c) { r ? r(c) : console.error(c), s.manager.itemError(e); } }, i, r); } parse(e) { const t = []; for (let i = 0; i < e.length; i++) { const r = jo.parse(e[i]); t.push(r); } return t; } }; var uN = class extends xn { constructor(e) { super(e); } load(e, t, i, r) { const s = this, o = [], a = new If(), c = new $n(this.manager); c.setPath(this.path), c.setResponseType("arraybuffer"), c.setRequestHeader(this.requestHeader), c.setWithCredentials(s.withCredentials); let l = 0; function d(h6) { c.load(e[h6], function(f) { const g = s.parse(f, true); o[h6] = { width: g.width, height: g.height, format: g.format, mipmaps: g.mipmaps }, l += 1, l === 6 && (g.mipmapCount === 1 && (a.minFilter = zt), a.image = o, a.format = g.format, a.needsUpdate = true, t && t(a)); }, i, r); } if (Array.isArray(e)) for (let h6 = 0, f = e.length; h6 < f; ++h6) d(h6); else c.load(e, function(h6) { const f = s.parse(h6, true); if (f.isCubemap) { const g = f.mipmaps.length / f.mipmapCount; for (let p = 0; p < g; p++) { o[p] = { mipmaps: [] }; for (let u = 0; u < f.mipmapCount; u++) o[p].mipmaps.push(f.mipmaps[p * f.mipmapCount + u]), o[p].format = f.format, o[p].width = f.width, o[p].height = f.height; } a.image = o; } else a.image.width = f.width, a.image.height = f.height, a.mipmaps = f.mipmaps; f.mipmapCount === 1 && (a.minFilter = zt), a.format = f.format, a.needsUpdate = true, t && t(a); }, i, r); return a; } }; var Ya = class extends xn { constructor(e) { super(e); } load(e, t, i, r) { this.path !== void 0 && (e = this.path + e), e = this.manager.resolveURL(e); const s = this, o = Is.get(e); if (o !== void 0) return s.manager.itemStart(e), setTimeout(function() { t && t(o), s.manager.itemEnd(e); }, 0), o; const a = document.createElementNS("http://www.w3.org/1999/xhtml", "img"); function c() { a.removeEventListener("load", c, false), a.removeEventListener("error", l, false), Is.add(e, this), t && t(this), s.manager.itemEnd(e); } function l(d) { a.removeEventListener("load", c, false), a.removeEventListener("error", l, false), r && r(d), s.manager.itemError(e), s.manager.itemEnd(e); } return a.addEventListener("load", c, false), a.addEventListener("error", l, false), e.substr(0, 5) !== "data:" && this.crossOrigin !== void 0 && (a.crossOrigin = this.crossOrigin), s.manager.itemStart(e), a.src = e, a; } }; var Nx = class extends xn { constructor(e) { super(e); } load(e, t, i, r) { const s = new ta(), o = new Ya(this.manager); o.setCrossOrigin(this.crossOrigin), o.setPath(this.path); let a = 0; function c(l) { o.load(e[l], function(d) { s.images[l] = d, a++, a === 6 && (s.needsUpdate = true, t && t(s)); }, void 0, r); } for (let l = 0; l < e.length; ++l) c(l); return s; } }; var Bx = class extends xn { constructor(e) { super(e); } load(e, t, i, r) { const s = this, o = new Ss(), a = new $n(this.manager); return a.setResponseType("arraybuffer"), a.setRequestHeader(this.requestHeader), a.setPath(this.path), a.setWithCredentials(s.withCredentials), a.load(e, function(c) { const l = s.parse(c); l && (l.image !== void 0 ? o.image = l.image : l.data !== void 0 && (o.image.width = l.width, o.image.height = l.height, o.image.data = l.data), o.wrapS = l.wrapS !== void 0 ? l.wrapS : hn2, o.wrapT = l.wrapT !== void 0 ? l.wrapT : hn2, o.magFilter = l.magFilter !== void 0 ? l.magFilter : zt, o.minFilter = l.minFilter !== void 0 ? l.minFilter : zt, o.anisotropy = l.anisotropy !== void 0 ? l.anisotropy : 1, l.encoding !== void 0 && (o.encoding = l.encoding), l.flipY !== void 0 && (o.flipY = l.flipY), l.format !== void 0 && (o.format = l.format), l.type !== void 0 && (o.type = l.type), l.mipmaps !== void 0 && (o.mipmaps = l.mipmaps, o.minFilter = fr), l.mipmapCount === 1 && (o.minFilter = zt), l.generateMipmaps !== void 0 && (o.generateMipmaps = l.generateMipmaps), o.needsUpdate = true, t && t(o, l)); }, i, r), o; } }; var qf = class extends xn { constructor(e) { super(e); } load(e, t, i, r) { const s = new Yt(), o = new Ya(this.manager); return o.setCrossOrigin(this.crossOrigin), o.setPath(this.path), o.load(e, function(a) { s.image = a; const c = e.search(/\.jpe?g($|\?)/i) > 0 || e.search(/^data\:image\/jpeg/) === 0; s.format = c ? nr : Gn, s.needsUpdate = true, t !== void 0 && t(s); }, i, r), s; } }; var Ux = class extends jn { constructor() { super(), this.type = "CurvePath", this.curves = [], this.autoClose = false; } add(e) { this.curves.push(e); } closePath() { const e = this.curves[0].getPoint(0), t = this.curves[this.curves.length - 1].getPoint(1); e.equals(t) || this.curves.push(new Ml(t, e)); } // To get accurate point with reference to // entire path distance at time t, // following has to be done: // 1. Length of each sub path have to be known // 2. Locate and identify type of curve // 3. Get t for the curve // 4. Return curve.getPointAt(t') getPoint(e) { const t = e * this.getLength(), i = this.getCurveLengths(); let r = 0; for (; r < i.length; ) { if (i[r] >= t) { const s = i[r] - t, o = this.curves[r], a = o.getLength(), c = a === 0 ? 0 : 1 - s / a; return o.getPointAt(c); } r++; } return null; } // We cannot use the default THREE.Curve getPoint() with getLength() because in // THREE.Curve, getLength() depends on getPoint() but in THREE.CurvePath // getPoint() depends on getLength getLength() { const e = this.getCurveLengths(); return e[e.length - 1]; } // cacheLengths must be recalculated. updateArcLengths() { this.needsUpdate = true, this.cacheLengths = null, this.getCurveLengths(); } // Compute lengths and cache them // We cannot overwrite getLengths() because UtoT mapping uses it. getCurveLengths() { if (this.cacheLengths && this.cacheLengths.length === this.curves.length) return this.cacheLengths; const e = []; let t = 0; for (let i = 0, r = this.curves.length; i < r; i++) t += this.curves[i].getLength(), e.push(t); return this.cacheLengths = e, e; } getSpacedPoints(e = 40) { const t = []; for (let i = 0; i <= e; i++) t.push(this.getPoint(i / e)); return this.autoClose && t.push(t[0]), t; } getPoints(e = 12) { const t = []; let i; for (let r = 0, s = this.curves; r < s.length; r++) { const o = s[r], a = o && o.isEllipseCurve ? e * 2 : o && (o.isLineCurve || o.isLineCurve3) ? 1 : o && o.isSplineCurve ? e * o.points.length : e, c = o.getPoints(a); for (let l = 0; l < c.length; l++) { const d = c[l]; i && i.equals(d) || (t.push(d), i = d); } } return this.autoClose && t.length > 1 && !t[t.length - 1].equals(t[0]) && t.push(t[0]), t; } copy(e) { super.copy(e), this.curves = []; for (let t = 0, i = e.curves.length; t < i; t++) { const r = e.curves[t]; this.curves.push(r.clone()); } return this.autoClose = e.autoClose, this; } toJSON() { const e = super.toJSON(); e.autoClose = this.autoClose, e.curves = []; for (let t = 0, i = this.curves.length; t < i; t++) { const r = this.curves[t]; e.curves.push(r.toJSON()); } return e; } fromJSON(e) { super.fromJSON(e), this.autoClose = e.autoClose, this.curves = []; for (let t = 0, i = e.curves.length; t < i; t++) { const r = e.curves[t]; this.curves.push(new Vf[r.type]().fromJSON(r)); } return this; } }; var Ja = class extends Ux { constructor(e) { super(), this.type = "Path", this.currentPoint = new Re(), e && this.setFromPoints(e); } setFromPoints(e) { this.moveTo(e[0].x, e[0].y); for (let t = 1, i = e.length; t < i; t++) this.lineTo(e[t].x, e[t].y); return this; } moveTo(e, t) { return this.currentPoint.set(e, t), this; } lineTo(e, t) { const i = new Ml(this.currentPoint.clone(), new Re(e, t)); return this.curves.push(i), this.currentPoint.set(e, t), this; } quadraticCurveTo(e, t, i, r) { const s = new _u( this.currentPoint.clone(), new Re(e, t), new Re(i, r) ); return this.curves.push(s), this.currentPoint.set(i, r), this; } bezierCurveTo(e, t, i, r, s, o) { const a = new Su( this.currentPoint.clone(), new Re(e, t), new Re(i, r), new Re(s, o) ); return this.curves.push(a), this.currentPoint.set(s, o), this; } splineThru(e) { const t = [this.currentPoint.clone()].concat(e), i = new Tu(t); return this.curves.push(i), this.currentPoint.copy(e[e.length - 1]), this; } arc(e, t, i, r, s, o) { const a = this.currentPoint.x, c = this.currentPoint.y; return this.absarc( e + a, t + c, i, r, s, o ), this; } absarc(e, t, i, r, s, o) { return this.absellipse(e, t, i, i, r, s, o), this; } ellipse(e, t, i, r, s, o, a, c) { const l = this.currentPoint.x, d = this.currentPoint.y; return this.absellipse(e + l, t + d, i, r, s, o, a, c), this; } absellipse(e, t, i, r, s, o, a, c) { const l = new xl(e, t, i, r, s, o, a, c); if (this.curves.length > 0) { const h6 = l.getPoint(0); h6.equals(this.currentPoint) || this.lineTo(h6.x, h6.y); } this.curves.push(l); const d = l.getPoint(1); return this.currentPoint.copy(d), this; } copy(e) { return super.copy(e), this.currentPoint.copy(e.currentPoint), this; } toJSON() { const e = super.toJSON(); return e.currentPoint = this.currentPoint.toArray(), e; } fromJSON(e) { return super.fromJSON(e), this.currentPoint.fromArray(e.currentPoint), this; } }; var Dr = class extends Ja { constructor(e) { super(e), this.uuid = Hn(), this.type = "Shape", this.holes = []; } getPointsHoles(e) { const t = []; for (let i = 0, r = this.holes.length; i < r; i++) t[i] = this.holes[i].getPoints(e); return t; } // get points of shape and holes (keypoints based on segments parameter) extractPoints(e) { return { shape: this.getPoints(e), holes: this.getPointsHoles(e) }; } copy(e) { super.copy(e), this.holes = []; for (let t = 0, i = e.holes.length; t < i; t++) { const r = e.holes[t]; this.holes.push(r.clone()); } return this; } toJSON() { const e = super.toJSON(); e.uuid = this.uuid, e.holes = []; for (let t = 0, i = this.holes.length; t < i; t++) { const r = this.holes[t]; e.holes.push(r.toJSON()); } return e; } fromJSON(e) { super.fromJSON(e), this.uuid = e.uuid, this.holes = []; for (let t = 0, i = e.holes.length; t < i; t++) { const r = e.holes[t]; this.holes.push(new Ja().fromJSON(r)); } return this; } }; var gi = class extends ut { constructor(e, t = 1) { super(), this.type = "Light", this.color = new Ue(e), this.intensity = t; } dispose() { } copy(e) { return super.copy(e), this.color.copy(e.color), this.intensity = e.intensity, this; } toJSON(e) { const t = super.toJSON(e); return t.object.color = this.color.getHex(), t.object.intensity = this.intensity, this.groundColor !== void 0 && (t.object.groundColor = this.groundColor.getHex()), this.distance !== void 0 && (t.object.distance = this.distance), this.angle !== void 0 && (t.object.angle = this.angle), this.decay !== void 0 && (t.object.decay = this.decay), this.penumbra !== void 0 && (t.object.penumbra = this.penumbra), this.shadow !== void 0 && (t.object.shadow = this.shadow.toJSON()), t; } }; gi.prototype.isLight = true; var Qf = class extends gi { constructor(e, t, i) { super(e, i), this.type = "HemisphereLight", this.position.copy(ut.DefaultUp), this.updateMatrix(), this.groundColor = new Ue(t); } copy(e) { return gi.prototype.copy.call(this, e), this.groundColor.copy(e.groundColor), this; } }; Qf.prototype.isHemisphereLight = true; var Vg = new Xe(); var kg = new q(); var Gg = new q(); var ep = class { constructor(e) { this.camera = e, this.bias = 0, this.normalBias = 0, this.radius = 1, this.mapSize = new Re(512, 512), this.map = null, this.mapPass = null, this.matrix = new Xe(), this.autoUpdate = true, this.needsUpdate = false, this._frustum = new dl(), this._frameExtents = new Re(1, 1), this._viewportCount = 1, this._viewports = [ new xt(0, 0, 1, 1) ]; } getViewportCount() { return this._viewportCount; } getFrustum() { return this._frustum; } updateMatrices(e) { const t = this.camera, i = this.matrix; kg.setFromMatrixPosition(e.matrixWorld), t.position.copy(kg), Gg.setFromMatrixPosition(e.target.matrixWorld), t.lookAt(Gg), t.updateMatrixWorld(), Vg.multiplyMatrices(t.projectionMatrix, t.matrixWorldInverse), this._frustum.setFromProjectionMatrix(Vg), i.set( 0.5, 0, 0, 0.5, 0, 0.5, 0, 0.5, 0, 0, 0.5, 0.5, 0, 0, 0, 1 ), i.multiply(t.projectionMatrix), i.multiply(t.matrixWorldInverse); } getViewport(e) { return this._viewports[e]; } getFrameExtents() { return this._frameExtents; } dispose() { this.map && this.map.dispose(), this.mapPass && this.mapPass.dispose(); } copy(e) { return this.camera = e.camera.clone(), this.bias = e.bias, this.radius = e.radius, this.mapSize.copy(e.mapSize), this; } clone() { return new this.constructor().copy(this); } toJSON() { const e = {}; return this.bias !== 0 && (e.bias = this.bias), this.normalBias !== 0 && (e.normalBias = this.normalBias), this.radius !== 1 && (e.radius = this.radius), (this.mapSize.x !== 512 || this.mapSize.y !== 512) && (e.mapSize = this.mapSize.toArray()), e.camera = this.camera.toJSON(false).object, delete e.camera.matrix, e; } }; var zx = class extends ep { constructor() { super(new nn(50, 1, 0.5, 500)), this.focus = 1; } updateMatrices(e) { const t = this.camera, i = ja * 2 * e.angle * this.focus, r = this.mapSize.width / this.mapSize.height, s = e.distance || t.far; (i !== t.fov || r !== t.aspect || s !== t.far) && (t.fov = i, t.aspect = r, t.far = s, t.updateProjectionMatrix()), super.updateMatrices(e); } copy(e) { return super.copy(e), this.focus = e.focus, this; } }; zx.prototype.isSpotLightShadow = true; var Cu = class extends gi { constructor(e, t, i = 0, r = Math.PI / 3, s = 0, o = 1) { super(e, t), this.type = "SpotLight", this.position.copy(ut.DefaultUp), this.updateMatrix(), this.target = new ut(), this.distance = i, this.angle = r, this.penumbra = s, this.decay = o, this.shadow = new zx(); } get power() { return this.intensity * Math.PI; } set power(e) { this.intensity = e / Math.PI; } dispose() { this.shadow.dispose(); } copy(e) { return super.copy(e), this.distance = e.distance, this.angle = e.angle, this.penumbra = e.penumbra, this.decay = e.decay, this.target = e.target.clone(), this.shadow = e.shadow.clone(), this; } }; Cu.prototype.isSpotLight = true; var Hg = new Xe(); var xa = new q(); var Ah = new q(); var Vx = class extends ep { constructor() { super(new nn(90, 1, 0.5, 500)), this._frameExtents = new Re(4, 2), this._viewportCount = 6, this._viewports = [ // These viewports map a cube-map onto a 2D texture with the // following orientation: // // xzXZ // y Y // // X - Positive x direction // x - Negative x direction // Y - Positive y direction // y - Negative y direction // Z - Positive z direction // z - Negative z direction // positive X new xt(2, 1, 1, 1), // negative X new xt(0, 1, 1, 1), // positive Z new xt(3, 1, 1, 1), // negative Z new xt(1, 1, 1, 1), // positive Y new xt(3, 0, 1, 1), // negative Y new xt(1, 0, 1, 1) ], this._cubeDirections = [ new q(1, 0, 0), new q(-1, 0, 0), new q(0, 0, 1), new q(0, 0, -1), new q(0, 1, 0), new q(0, -1, 0) ], this._cubeUps = [ new q(0, 1, 0), new q(0, 1, 0), new q(0, 1, 0), new q(0, 1, 0), new q(0, 0, 1), new q(0, 0, -1) ]; } updateMatrices(e, t = 0) { const i = this.camera, r = this.matrix, s = e.distance || i.far; s !== i.far && (i.far = s, i.updateProjectionMatrix()), xa.setFromMatrixPosition(e.matrixWorld), i.position.copy(xa), Ah.copy(i.position), Ah.add(this._cubeDirections[t]), i.up.copy(this._cubeUps[t]), i.lookAt(Ah), i.updateMatrixWorld(), r.makeTranslation(-xa.x, -xa.y, -xa.z), Hg.multiplyMatrices(i.projectionMatrix, i.matrixWorldInverse), this._frustum.setFromProjectionMatrix(Hg); } }; Vx.prototype.isPointLightShadow = true; var Lu = class extends gi { constructor(e, t, i = 0, r = 1) { super(e, t), this.type = "PointLight", this.distance = i, this.decay = r, this.shadow = new Vx(); } get power() { return this.intensity * 4 * Math.PI; } set power(e) { this.intensity = e / (4 * Math.PI); } dispose() { this.shadow.dispose(); } copy(e) { return super.copy(e), this.distance = e.distance, this.decay = e.decay, this.shadow = e.shadow.clone(), this; } }; Lu.prototype.isPointLight = true; var sa = class extends hl { constructor(e = -1, t = 1, i = 1, r = -1, s = 0.1, o = 2e3) { super(), this.type = "OrthographicCamera", this.zoom = 1, this.view = null, this.left = e, this.right = t, this.top = i, this.bottom = r, this.near = s, this.far = o, this.updateProjectionMatrix(); } copy(e, t) { return super.copy(e, t), this.left = e.left, this.right = e.right, this.top = e.top, this.bottom = e.bottom, this.near = e.near, this.far = e.far, this.zoom = e.zoom, this.view = e.view === null ? null : Object.assign({}, e.view), this; } setViewOffset(e, t, i, r, s, o) { this.view === null && (this.view = { enabled: true, fullWidth: 1, fullHeight: 1, offsetX: 0, offsetY: 0, width: 1, height: 1 }), this.view.enabled = true, this.view.fullWidth = e, this.view.fullHeight = t, this.view.offsetX = i, this.view.offsetY = r, this.view.width = s, this.view.height = o, this.updateProjectionMatrix(); } clearViewOffset() { this.view !== null && (this.view.enabled = false), this.updateProjectionMatrix(); } updateProjectionMatrix() { const e = (this.right - this.left) / (2 * this.zoom), t = (this.top - this.bottom) / (2 * this.zoom), i = (this.right + this.left) / 2, r = (this.top + this.bottom) / 2; let s = i - e, o = i + e, a = r + t, c = r - t; if (this.view !== null && this.view.enabled) { const l = (this.right - this.left) / this.view.fullWidth / this.zoom, d = (this.top - this.bottom) / this.view.fullHeight / this.zoom; s += l * this.view.offsetX, o = s + l * this.view.width, a -= d * this.view.offsetY, c = a - d * this.view.height; } this.projectionMatrix.makeOrthographic(s, o, a, c, this.near, this.far), this.projectionMatrixInverse.copy(this.projectionMatrix).invert(); } toJSON(e) { const t = super.toJSON(e); return t.object.zoom = this.zoom, t.object.left = this.left, t.object.right = this.right, t.object.top = this.top, t.object.bottom = this.bottom, t.object.near = this.near, t.object.far = this.far, this.view !== null && (t.object.view = Object.assign({}, this.view)), t; } }; sa.prototype.isOrthographicCamera = true; var kx = class extends ep { constructor() { super(new sa(-5, 5, 5, -5, 0.5, 500)); } }; kx.prototype.isDirectionalLightShadow = true; var Ru = class extends gi { constructor(e, t) { super(e, t), this.type = "DirectionalLight", this.position.copy(ut.DefaultUp), this.updateMatrix(), this.target = new ut(), this.shadow = new kx(); } dispose() { this.shadow.dispose(); } copy(e) { return super.copy(e), this.target = e.target.clone(), this.shadow = e.shadow.clone(), this; } }; Ru.prototype.isDirectionalLight = true; var tp = class extends gi { constructor(e, t) { super(e, t), this.type = "AmbientLight"; } }; tp.prototype.isAmbientLight = true; var np = class extends gi { constructor(e, t, i = 10, r = 10) { super(e, t), this.type = "RectAreaLight", this.width = i, this.height = r; } copy(e) { return super.copy(e), this.width = e.width, this.height = e.height, this; } toJSON(e) { const t = super.toJSON(e); return t.object.width = this.width, t.object.height = this.height, t; } }; np.prototype.isRectAreaLight = true; var ip = class { constructor() { this.coefficients = []; for (let e = 0; e < 9; e++) this.coefficients.push(new q()); } set(e) { for (let t = 0; t < 9; t++) this.coefficients[t].copy(e[t]); return this; } zero() { for (let e = 0; e < 9; e++) this.coefficients[e].set(0, 0, 0); return this; } // get the radiance in the direction of the normal // target is a Vector3 getAt(e, t) { const i = e.x, r = e.y, s = e.z, o = this.coefficients; return t.copy(o[0]).multiplyScalar(0.282095), t.addScaledVector(o[1], 0.488603 * r), t.addScaledVector(o[2], 0.488603 * s), t.addScaledVector(o[3], 0.488603 * i), t.addScaledVector(o[4], 1.092548 * (i * r)), t.addScaledVector(o[5], 1.092548 * (r * s)), t.addScaledVector(o[6], 0.315392 * (3 * s * s - 1)), t.addScaledVector(o[7], 1.092548 * (i * s)), t.addScaledVector(o[8], 0.546274 * (i * i - r * r)), t; } // get the irradiance (radiance convolved with cosine lobe) in the direction of the normal // target is a Vector3 // https://graphics.stanford.edu/papers/envmap/envmap.pdf getIrradianceAt(e, t) { const i = e.x, r = e.y, s = e.z, o = this.coefficients; return t.copy(o[0]).multiplyScalar(0.886227), t.addScaledVector(o[1], 2 * 0.511664 * r), t.addScaledVector(o[2], 2 * 0.511664 * s), t.addScaledVector(o[3], 2 * 0.511664 * i), t.addScaledVector(o[4], 2 * 0.429043 * i * r), t.addScaledVector(o[5], 2 * 0.429043 * r * s), t.addScaledVector(o[6], 0.743125 * s * s - 0.247708), t.addScaledVector(o[7], 2 * 0.429043 * i * s), t.addScaledVector(o[8], 0.429043 * (i * i - r * r)), t; } add(e) { for (let t = 0; t < 9; t++) this.coefficients[t].add(e.coefficients[t]); return this; } addScaledSH(e, t) { for (let i = 0; i < 9; i++) this.coefficients[i].addScaledVector(e.coefficients[i], t); return this; } scale(e) { for (let t = 0; t < 9; t++) this.coefficients[t].multiplyScalar(e); return this; } lerp(e, t) { for (let i = 0; i < 9; i++) this.coefficients[i].lerp(e.coefficients[i], t); return this; } equals(e) { for (let t = 0; t < 9; t++) if (!this.coefficients[t].equals(e.coefficients[t])) return false; return true; } copy(e) { return this.set(e.coefficients); } clone() { return new this.constructor().copy(this); } fromArray(e, t = 0) { const i = this.coefficients; for (let r = 0; r < 9; r++) i[r].fromArray(e, t + r * 3); return this; } toArray(e = [], t = 0) { const i = this.coefficients; for (let r = 0; r < 9; r++) i[r].toArray(e, t + r * 3); return e; } // evaluate the basis functions // shBasis is an Array[ 9 ] static getBasisAt(e, t) { const i = e.x, r = e.y, s = e.z; t[0] = 0.282095, t[1] = 0.488603 * r, t[2] = 0.488603 * s, t[3] = 0.488603 * i, t[4] = 1.092548 * i * r, t[5] = 1.092548 * r * s, t[6] = 0.315392 * (3 * s * s - 1), t[7] = 1.092548 * i * s, t[8] = 0.546274 * (i * i - r * r); } }; ip.prototype.isSphericalHarmonics3 = true; var Al = class extends gi { constructor(e = new ip(), t = 1) { super(void 0, t), this.sh = e; } copy(e) { return super.copy(e), this.sh.copy(e.sh), this; } fromJSON(e) { return this.intensity = e.intensity, this.sh.fromArray(e.sh), this; } toJSON(e) { const t = super.toJSON(e); return t.object.sh = this.sh.toArray(), t; } }; Al.prototype.isLightProbe = true; var Gx = class extends xn { constructor(e) { super(e), this.textures = {}; } load(e, t, i, r) { const s = this, o = new $n(s.manager); o.setPath(s.path), o.setRequestHeader(s.requestHeader), o.setWithCredentials(s.withCredentials), o.load(e, function(a) { try { t(s.parse(JSON.parse(a))); } catch (c) { r ? r(c) : console.error(c), s.manager.itemError(e); } }, i, r); } parse(e) { const t = this.textures; function i(s) { return t[s] === void 0 && console.warn("THREE.MaterialLoader: Undefined texture", s), t[s]; } const r = new oN[e.type](); if (e.uuid !== void 0 && (r.uuid = e.uuid), e.name !== void 0 && (r.name = e.name), e.color !== void 0 && r.color !== void 0 && r.color.setHex(e.color), e.roughness !== void 0 && (r.roughness = e.roughness), e.metalness !== void 0 && (r.metalness = e.metalness), e.sheen !== void 0 && (r.sheen = new Ue().setHex(e.sheen)), e.emissive !== void 0 && r.emissive !== void 0 && r.emissive.setHex(e.emissive), e.specular !== void 0 && r.specular !== void 0 && r.specular.setHex(e.specular), e.shininess !== void 0 && (r.shininess = e.shininess), e.clearcoat !== void 0 && (r.clearcoat = e.clearcoat), e.clearcoatRoughness !== void 0 && (r.clearcoatRoughness = e.clearcoatRoughness), e.transmission !== void 0 && (r.transmission = e.transmission), e.thickness !== void 0 && (r.thickness = e.thickness), e.attenuationDistance !== void 0 && (r.attenuationDistance = e.attenuationDistance), e.attenuationColor !== void 0 && r.attenuationColor !== void 0 && r.attenuationColor.setHex(e.attenuationColor), e.fog !== void 0 && (r.fog = e.fog), e.flatShading !== void 0 && (r.flatShading = e.flatShading), e.blending !== void 0 && (r.blending = e.blending), e.combine !== void 0 && (r.combine = e.combine), e.side !== void 0 && (r.side = e.side), e.shadowSide !== void 0 && (r.shadowSide = e.shadowSide), e.opacity !== void 0 && (r.opacity = e.opacity), e.transparent !== void 0 && (r.transparent = e.transparent), e.alphaTest !== void 0 && (r.alphaTest = e.alphaTest), e.depthTest !== void 0 && (r.depthTest = e.depthTest), e.depthWrite !== void 0 && (r.depthWrite = e.depthWrite), e.colorWrite !== void 0 && (r.colorWrite = e.colorWrite), e.stencilWrite !== void 0 && (r.stencilWrite = e.stencilWrite), e.stencilWriteMask !== void 0 && (r.stencilWriteMask = e.stencilWriteMask), e.stencilFunc !== void 0 && (r.stencilFunc = e.stencilFunc), e.stencilRef !== void 0 && (r.stencilRef = e.stencilRef), e.stencilFuncMask !== void 0 && (r.stencilFuncMask = e.stencilFuncMask), e.stencilFail !== void 0 && (r.stencilFail = e.stencilFail), e.stencilZFail !== void 0 && (r.stencilZFail = e.stencilZFail), e.stencilZPass !== void 0 && (r.stencilZPass = e.stencilZPass), e.wireframe !== void 0 && (r.wireframe = e.wireframe), e.wireframeLinewidth !== void 0 && (r.wireframeLinewidth = e.wireframeLinewidth), e.wireframeLinecap !== void 0 && (r.wireframeLinecap = e.wireframeLinecap), e.wireframeLinejoin !== void 0 && (r.wireframeLinejoin = e.wireframeLinejoin), e.rotation !== void 0 && (r.rotation = e.rotation), e.linewidth !== 1 && (r.linewidth = e.linewidth), e.dashSize !== void 0 && (r.dashSize = e.dashSize), e.gapSize !== void 0 && (r.gapSize = e.gapSize), e.scale !== void 0 && (r.scale = e.scale), e.polygonOffset !== void 0 && (r.polygonOffset = e.polygonOffset), e.polygonOffsetFactor !== void 0 && (r.polygonOffsetFactor = e.polygonOffsetFactor), e.polygonOffsetUnits !== void 0 && (r.polygonOffsetUnits = e.polygonOffsetUnits), e.morphTargets !== void 0 && (r.morphTargets = e.morphTargets), e.morphNormals !== void 0 && (r.morphNormals = e.morphNormals), e.dithering !== void 0 && (r.dithering = e.dithering), e.alphaToCoverage !== void 0 && (r.alphaToCoverage = e.alphaToCoverage), e.premultipliedAlpha !== void 0 && (r.premultipliedAlpha = e.premultipliedAlpha), e.vertexTangents !== void 0 && (r.vertexTangents = e.vertexTangents), e.visible !== void 0 && (r.visible = e.visible), e.toneMapped !== void 0 && (r.toneMapped = e.toneMapped), e.userData !== void 0 && (r.userData = e.userData), e.vertexColors !== void 0 && (typeof e.vertexColors == "number" ? r.vertexColors = e.vertexColors > 0 : r.vertexColors = e.vertexColors), e.uniforms !== void 0) for (const s in e.uniforms) { const o = e.uniforms[s]; switch (r.uniforms[s] = {}, o.type) { case "t": r.uniforms[s].value = i(o.value); break; case "c": r.uniforms[s].value = new Ue().setHex(o.value); break; case "v2": r.uniforms[s].value = new Re().fromArray(o.value); break; case "v3": r.uniforms[s].value = new q().fromArray(o.value); break; case "v4": r.uniforms[s].value = new xt().fromArray(o.value); break; case "m3": r.uniforms[s].value = new rn().fromArray(o.value); break; case "m4": r.uniforms[s].value = new Xe().fromArray(o.value); break; default: r.uniforms[s].value = o.value; } } if (e.defines !== void 0 && (r.defines = e.defines), e.vertexShader !== void 0 && (r.vertexShader = e.vertexShader), e.fragmentShader !== void 0 && (r.fragmentShader = e.fragmentShader), e.extensions !== void 0) for (const s in e.extensions) r.extensions[s] = e.extensions[s]; if (e.shading !== void 0 && (r.flatShading = e.shading === 1), e.size !== void 0 && (r.size = e.size), e.sizeAttenuation !== void 0 && (r.sizeAttenuation = e.sizeAttenuation), e.map !== void 0 && (r.map = i(e.map)), e.matcap !== void 0 && (r.matcap = i(e.matcap)), e.alphaMap !== void 0 && (r.alphaMap = i(e.alphaMap)), e.bumpMap !== void 0 && (r.bumpMap = i(e.bumpMap)), e.bumpScale !== void 0 && (r.bumpScale = e.bumpScale), e.normalMap !== void 0 && (r.normalMap = i(e.normalMap)), e.normalMapType !== void 0 && (r.normalMapType = e.normalMapType), e.normalScale !== void 0) { let s = e.normalScale; Array.isArray(s) === false && (s = [s, s]), r.normalScale = new Re().fromArray(s); } return e.displacementMap !== void 0 && (r.displacementMap = i(e.displacementMap)), e.displacementScale !== void 0 && (r.displacementScale = e.displacementScale), e.displacementBias !== void 0 && (r.displacementBias = e.displacementBias), e.roughnessMap !== void 0 && (r.roughnessMap = i(e.roughnessMap)), e.metalnessMap !== void 0 && (r.metalnessMap = i(e.metalnessMap)), e.emissiveMap !== void 0 && (r.emissiveMap = i(e.emissiveMap)), e.emissiveIntensity !== void 0 && (r.emissiveIntensity = e.emissiveIntensity), e.specularMap !== void 0 && (r.specularMap = i(e.specularMap)), e.envMap !== void 0 && (r.envMap = i(e.envMap)), e.envMapIntensity !== void 0 && (r.envMapIntensity = e.envMapIntensity), e.reflectivity !== void 0 && (r.reflectivity = e.reflectivity), e.refractionRatio !== void 0 && (r.refractionRatio = e.refractionRatio), e.lightMap !== void 0 && (r.lightMap = i(e.lightMap)), e.lightMapIntensity !== void 0 && (r.lightMapIntensity = e.lightMapIntensity), e.aoMap !== void 0 && (r.aoMap = i(e.aoMap)), e.aoMapIntensity !== void 0 && (r.aoMapIntensity = e.aoMapIntensity), e.gradientMap !== void 0 && (r.gradientMap = i(e.gradientMap)), e.clearcoatMap !== void 0 && (r.clearcoatMap = i(e.clearcoatMap)), e.clearcoatRoughnessMap !== void 0 && (r.clearcoatRoughnessMap = i(e.clearcoatRoughnessMap)), e.clearcoatNormalMap !== void 0 && (r.clearcoatNormalMap = i(e.clearcoatNormalMap)), e.clearcoatNormalScale !== void 0 && (r.clearcoatNormalScale = new Re().fromArray(e.clearcoatNormalScale)), e.transmissionMap !== void 0 && (r.transmissionMap = i(e.transmissionMap)), e.thicknessMap !== void 0 && (r.thicknessMap = i(e.thicknessMap)), r; } setTextures(e) { return this.textures = e, this; } }; var ir = class { static decodeText(e) { if (typeof TextDecoder < "u") return new TextDecoder().decode(e); let t = ""; for (let i = 0, r = e.length; i < r; i++) t += String.fromCharCode(e[i]); try { return decodeURIComponent(escape(t)); } catch { return t; } } static extractUrlBase(e) { const t = e.lastIndexOf("/"); return t === -1 ? "./" : e.substr(0, t + 1); } }; var rp = class extends Ke { constructor() { super(), this.type = "InstancedBufferGeometry", this.instanceCount = 1 / 0; } copy(e) { return super.copy(e), this.instanceCount = e.instanceCount, this; } clone() { return new this.constructor().copy(this); } toJSON() { const e = super.toJSON(this); return e.instanceCount = this.instanceCount, e.isInstancedBufferGeometry = true, e; } }; rp.prototype.isInstancedBufferGeometry = true; var sp = class extends ot { constructor(e, t, i, r = 1) { typeof i == "number" && (r = i, i = false, console.error("THREE.InstancedBufferAttribute: The constructor now expects normalized as the third argument.")), super(e, t, i), this.meshPerAttribute = r; } copy(e) { return super.copy(e), this.meshPerAttribute = e.meshPerAttribute, this; } toJSON() { const e = super.toJSON(); return e.meshPerAttribute = this.meshPerAttribute, e.isInstancedBufferAttribute = true, e; } }; sp.prototype.isInstancedBufferAttribute = true; var Hx = class extends xn { constructor(e) { super(e); } load(e, t, i, r) { const s = this, o = new $n(s.manager); o.setPath(s.path), o.setRequestHeader(s.requestHeader), o.setWithCredentials(s.withCredentials), o.load(e, function(a) { try { t(s.parse(JSON.parse(a))); } catch (c) { r ? r(c) : console.error(c), s.manager.itemError(e); } }, i, r); } parse(e) { const t = {}, i = {}; function r(g, p) { if (t[p] !== void 0) return t[p]; const y = g.interleavedBuffers[p], v = s(g, y.buffer), m = mo(y.type, v), x = new Qr(m, y.stride); return x.uuid = y.uuid, t[p] = x, x; } function s(g, p) { if (i[p] !== void 0) return i[p]; const y = g.arrayBuffers[p], v = new Uint32Array(y).buffer; return i[p] = v, v; } const o = e.isInstancedBufferGeometry ? new rp() : new Ke(), a = e.data.index; if (a !== void 0) { const g = mo(a.type, a.array); o.setIndex(new ot(g, 1)); } const c = e.data.attributes; for (const g in c) { const p = c[g]; let u; if (p.isInterleavedBufferAttribute) { const y = r(e.data, p.data); u = new ar(y, p.itemSize, p.offset, p.normalized); } else { const y = mo(p.type, p.array), v = p.isInstancedBufferAttribute ? sp : ot; u = new v(y, p.itemSize, p.normalized); } p.name !== void 0 && (u.name = p.name), p.usage !== void 0 && u.setUsage(p.usage), p.updateRange !== void 0 && (u.updateRange.offset = p.updateRange.offset, u.updateRange.count = p.updateRange.count), o.setAttribute(g, u); } const l = e.data.morphAttributes; if (l) for (const g in l) { const p = l[g], u = []; for (let y = 0, v = p.length; y < v; y++) { const m = p[y]; let x; if (m.isInterleavedBufferAttribute) { const w = r(e.data, m.data); x = new ar(w, m.itemSize, m.offset, m.normalized); } else { const w = mo(m.type, m.array); x = new ot(w, m.itemSize, m.normalized); } m.name !== void 0 && (x.name = m.name), u.push(x); } o.morphAttributes[g] = u; } e.data.morphTargetsRelative && (o.morphTargetsRelative = true); const h6 = e.data.groups || e.data.drawcalls || e.data.offsets; if (h6 !== void 0) for (let g = 0, p = h6.length; g !== p; ++g) { const u = h6[g]; o.addGroup(u.start, u.count, u.materialIndex); } const f = e.data.boundingSphere; if (f !== void 0) { const g = new q(); f.center !== void 0 && g.fromArray(f.center), o.boundingSphere = new pr(g, f.radius); } return e.name && (o.name = e.name), e.userData && (o.userData = e.userData), o; } }; var hN = class extends xn { constructor(e) { super(e); } load(e, t, i, r) { const s = this, o = this.path === "" ? ir.extractUrlBase(e) : this.path; this.resourcePath = this.resourcePath || o; const a = new $n(this.manager); a.setPath(this.path), a.setRequestHeader(this.requestHeader), a.setWithCredentials(this.withCredentials), a.load(e, function(c) { let l = null; try { l = JSON.parse(c); } catch (h6) { r !== void 0 && r(h6), console.error("THREE:ObjectLoader: Can't parse " + e + ".", h6.message); return; } const d = l.metadata; if (d === void 0 || d.type === void 0 || d.type.toLowerCase() === "geometry") { console.error("THREE.ObjectLoader: Can't load " + e); return; } s.parse(l, t); }, i, r); } async loadAsync(e, t) { const i = this, r = this.path === "" ? ir.extractUrlBase(e) : this.path; this.resourcePath = this.resourcePath || r; const s = new $n(this.manager); s.setPath(this.path), s.setRequestHeader(this.requestHeader), s.setWithCredentials(this.withCredentials); const o = await s.loadAsync(e, t), a = JSON.parse(o), c = a.metadata; if (c === void 0 || c.type === void 0 || c.type.toLowerCase() === "geometry") throw new Error("THREE.ObjectLoader: Can't load " + e); return await i.parseAsync(a); } parse(e, t) { const i = this.parseAnimations(e.animations), r = this.parseShapes(e.shapes), s = this.parseGeometries(e.geometries, r), o = this.parseImages(e.images, function() { t !== void 0 && t(l); }), a = this.parseTextures(e.textures, o), c = this.parseMaterials(e.materials, a), l = this.parseObject(e.object, s, c, a, i), d = this.parseSkeletons(e.skeletons, l); if (this.bindSkeletons(l, d), t !== void 0) { let h6 = false; for (const f in o) if (o[f] instanceof HTMLImageElement) { h6 = true; break; } h6 === false && t(l); } return l; } async parseAsync(e) { const t = this.parseAnimations(e.animations), i = this.parseShapes(e.shapes), r = this.parseGeometries(e.geometries, i), s = await this.parseImagesAsync(e.images), o = this.parseTextures(e.textures, s), a = this.parseMaterials(e.materials, o), c = this.parseObject(e.object, r, a, o, t), l = this.parseSkeletons(e.skeletons, c); return this.bindSkeletons(c, l), c; } parseShapes(e) { const t = {}; if (e !== void 0) for (let i = 0, r = e.length; i < r; i++) { const s = new Dr().fromJSON(e[i]); t[s.uuid] = s; } return t; } parseSkeletons(e, t) { const i = {}, r = {}; if (t.traverse(function(s) { s.isBone && (r[s.uuid] = s); }), e !== void 0) for (let s = 0, o = e.length; s < o; s++) { const a = new bl().fromJSON(e[s], r); i[a.uuid] = a; } return i; } parseGeometries(e, t) { const i = {}; if (e !== void 0) { const r = new Hx(); for (let s = 0, o = e.length; s < o; s++) { let a; const c = e[s]; switch (c.type) { case "BufferGeometry": case "InstancedBufferGeometry": a = r.parse(c); break; case "Geometry": console.error("THREE.ObjectLoader: The legacy Geometry type is no longer supported."); break; default: c.type in zg ? a = zg[c.type].fromJSON(c, t) : console.warn(`THREE.ObjectLoader: Unsupported geometry type "${c.type}"`); } a.uuid = c.uuid, c.name !== void 0 && (a.name = c.name), a.isBufferGeometry === true && c.userData !== void 0 && (a.userData = c.userData), i[c.uuid] = a; } } return i; } parseMaterials(e, t) { const i = {}, r = {}; if (e !== void 0) { const s = new Gx(); s.setTextures(t); for (let o = 0, a = e.length; o < a; o++) { const c = e[o]; if (c.type === "MultiMaterial") { const l = []; for (let d = 0; d < c.materials.length; d++) { const h6 = c.materials[d]; i[h6.uuid] === void 0 && (i[h6.uuid] = s.parse(h6)), l.push(i[h6.uuid]); } r[c.uuid] = l; } else i[c.uuid] === void 0 && (i[c.uuid] = s.parse(c)), r[c.uuid] = i[c.uuid]; } } return r; } parseAnimations(e) { const t = {}; if (e !== void 0) for (let i = 0; i < e.length; i++) { const r = e[i], s = jo.parse(r); t[s.uuid] = s; } return t; } parseImages(e, t) { const i = this, r = {}; let s; function o(c) { return i.manager.itemStart(c), s.load(c, function() { i.manager.itemEnd(c); }, void 0, function() { i.manager.itemError(c), i.manager.itemEnd(c); }); } function a(c) { if (typeof c == "string") { const l = c, d = /^(\/\/)|([a-z]+:(\/\/)?)/i.test(l) ? l : i.resourcePath + l; return o(d); } else return c.data ? { data: mo(c.type, c.data), width: c.width, height: c.height } : null; } if (e !== void 0 && e.length > 0) { const c = new Kf(t); s = new Ya(c), s.setCrossOrigin(this.crossOrigin); for (let l = 0, d = e.length; l < d; l++) { const h6 = e[l], f = h6.url; if (Array.isArray(f)) { r[h6.uuid] = []; for (let g = 0, p = f.length; g < p; g++) { const u = f[g], y = a(u); y !== null && (y instanceof HTMLImageElement ? r[h6.uuid].push(y) : r[h6.uuid].push(new Ss(y.data, y.width, y.height))); } } else { const g = a(h6.url); g !== null && (r[h6.uuid] = g); } } } return r; } async parseImagesAsync(e) { const t = this, i = {}; let r; async function s(o) { if (typeof o == "string") { const a = o, c = /^(\/\/)|([a-z]+:(\/\/)?)/i.test(a) ? a : t.resourcePath + a; return await r.loadAsync(c); } else return o.data ? { data: mo(o.type, o.data), width: o.width, height: o.height } : null; } if (e !== void 0 && e.length > 0) { r = new Ya(this.manager), r.setCrossOrigin(this.crossOrigin); for (let o = 0, a = e.length; o < a; o++) { const c = e[o], l = c.url; if (Array.isArray(l)) { i[c.uuid] = []; for (let d = 0, h6 = l.length; d < h6; d++) { const f = l[d], g = await s(f); g !== null && (g instanceof HTMLImageElement ? i[c.uuid].push(g) : i[c.uuid].push(new Ss(g.data, g.width, g.height))); } } else { const d = await s(c.url); d !== null && (i[c.uuid] = d); } } } return i; } parseTextures(e, t) { function i(s, o) { return typeof s == "number" ? s : (console.warn("THREE.ObjectLoader.parseTexture: Constant should be in numeric form.", s), o[s]); } const r = {}; if (e !== void 0) for (let s = 0, o = e.length; s < o; s++) { const a = e[s]; a.image === void 0 && console.warn('THREE.ObjectLoader: No "image" specified for', a.uuid), t[a.image] === void 0 && console.warn("THREE.ObjectLoader: Undefined image", a.image); let c; const l = t[a.image]; Array.isArray(l) ? (c = new ta(l), l.length === 6 && (c.needsUpdate = true)) : (l && l.data ? c = new Ss(l.data, l.width, l.height) : c = new Yt(l), l && (c.needsUpdate = true)), c.uuid = a.uuid, a.name !== void 0 && (c.name = a.name), a.mapping !== void 0 && (c.mapping = i(a.mapping, dN)), a.offset !== void 0 && c.offset.fromArray(a.offset), a.repeat !== void 0 && c.repeat.fromArray(a.repeat), a.center !== void 0 && c.center.fromArray(a.center), a.rotation !== void 0 && (c.rotation = a.rotation), a.wrap !== void 0 && (c.wrapS = i(a.wrap[0], Wg), c.wrapT = i(a.wrap[1], Wg)), a.format !== void 0 && (c.format = a.format), a.type !== void 0 && (c.type = a.type), a.encoding !== void 0 && (c.encoding = a.encoding), a.minFilter !== void 0 && (c.minFilter = i(a.minFilter, jg)), a.magFilter !== void 0 && (c.magFilter = i(a.magFilter, jg)), a.anisotropy !== void 0 && (c.anisotropy = a.anisotropy), a.flipY !== void 0 && (c.flipY = a.flipY), a.premultiplyAlpha !== void 0 && (c.premultiplyAlpha = a.premultiplyAlpha), a.unpackAlignment !== void 0 && (c.unpackAlignment = a.unpackAlignment), r[a.uuid] = c; } return r; } parseObject(e, t, i, r, s) { let o; function a(f) { return t[f] === void 0 && console.warn("THREE.ObjectLoader: Undefined geometry", f), t[f]; } function c(f) { if (f !== void 0) { if (Array.isArray(f)) { const g = []; for (let p = 0, u = f.length; p < u; p++) { const y = f[p]; i[y] === void 0 && console.warn("THREE.ObjectLoader: Undefined material", y), g.push(i[y]); } return g; } return i[f] === void 0 && console.warn("THREE.ObjectLoader: Undefined material", f), i[f]; } } function l(f) { return r[f] === void 0 && console.warn("THREE.ObjectLoader: Undefined texture", f), r[f]; } let d, h6; switch (e.type) { case "Scene": o = new wu(), e.background !== void 0 && (Number.isInteger(e.background) ? o.background = new Ue(e.background) : o.background = l(e.background)), e.environment !== void 0 && (o.environment = l(e.environment)), e.fog !== void 0 && (e.fog.type === "Fog" ? o.fog = new pl(e.fog.color, e.fog.near, e.fog.far) : e.fog.type === "FogExp2" && (o.fog = new fl(e.fog.color, e.fog.density))); break; case "PerspectiveCamera": o = new nn(e.fov, e.aspect, e.near, e.far), e.focus !== void 0 && (o.focus = e.focus), e.zoom !== void 0 && (o.zoom = e.zoom), e.filmGauge !== void 0 && (o.filmGauge = e.filmGauge), e.filmOffset !== void 0 && (o.filmOffset = e.filmOffset), e.view !== void 0 && (o.view = Object.assign({}, e.view)); break; case "OrthographicCamera": o = new sa(e.left, e.right, e.top, e.bottom, e.near, e.far), e.zoom !== void 0 && (o.zoom = e.zoom), e.view !== void 0 && (o.view = Object.assign({}, e.view)); break; case "AmbientLight": o = new tp(e.color, e.intensity); break; case "DirectionalLight": o = new Ru(e.color, e.intensity); break; case "PointLight": o = new Lu(e.color, e.intensity, e.distance, e.decay); break; case "RectAreaLight": o = new np(e.color, e.intensity, e.width, e.height); break; case "SpotLight": o = new Cu(e.color, e.intensity, e.distance, e.angle, e.penumbra, e.decay); break; case "HemisphereLight": o = new Qf(e.color, e.groundColor, e.intensity); break; case "LightProbe": o = new Al().fromJSON(e); break; case "SkinnedMesh": d = a(e.geometry), h6 = c(e.material), o = new vl(d, h6), e.bindMode !== void 0 && (o.bindMode = e.bindMode), e.bindMatrix !== void 0 && o.bindMatrix.fromArray(e.bindMatrix), e.skeleton !== void 0 && (o.skeleton = e.skeleton); break; case "Mesh": d = a(e.geometry), h6 = c(e.material), o = new Xt(d, h6); break; case "InstancedMesh": d = a(e.geometry), h6 = c(e.material); const f = e.count, g = e.instanceMatrix, p = e.instanceColor; o = new Pf(d, h6, f), o.instanceMatrix = new ot(new Float32Array(g.array), 16), p !== void 0 && (o.instanceColor = new ot(new Float32Array(p.array), p.itemSize)); break; case "LOD": o = new Sx(); break; case "Line": o = new Oi(a(e.geometry), c(e.material)); break; case "LineLoop": o = new Au(a(e.geometry), c(e.material)); break; case "LineSegments": o = new Rn(a(e.geometry), c(e.material)); break; case "PointCloud": case "Points": o = new ia(a(e.geometry), c(e.material)); break; case "Sprite": o = new gl(c(e.material)); break; case "Group": o = new _i(); break; case "Bone": o = new yl(); break; default: o = new ut(); } if (o.uuid = e.uuid, e.name !== void 0 && (o.name = e.name), e.matrix !== void 0 ? (o.matrix.fromArray(e.matrix), e.matrixAutoUpdate !== void 0 && (o.matrixAutoUpdate = e.matrixAutoUpdate), o.matrixAutoUpdate && o.matrix.decompose(o.position, o.quaternion, o.scale)) : (e.position !== void 0 && o.position.fromArray(e.position), e.rotation !== void 0 && o.rotation.fromArray(e.rotation), e.quaternion !== void 0 && o.quaternion.fromArray(e.quaternion), e.scale !== void 0 && o.scale.fromArray(e.scale)), e.castShadow !== void 0 && (o.castShadow = e.castShadow), e.receiveShadow !== void 0 && (o.receiveShadow = e.receiveShadow), e.shadow && (e.shadow.bias !== void 0 && (o.shadow.bias = e.shadow.bias), e.shadow.normalBias !== void 0 && (o.shadow.normalBias = e.shadow.normalBias), e.shadow.radius !== void 0 && (o.shadow.radius = e.shadow.radius), e.shadow.mapSize !== void 0 && o.shadow.mapSize.fromArray(e.shadow.mapSize), e.shadow.camera !== void 0 && (o.shadow.camera = this.parseObject(e.shadow.camera))), e.visible !== void 0 && (o.visible = e.visible), e.frustumCulled !== void 0 && (o.frustumCulled = e.frustumCulled), e.renderOrder !== void 0 && (o.renderOrder = e.renderOrder), e.userData !== void 0 && (o.userData = e.userData), e.layers !== void 0 && (o.layers.mask = e.layers), e.children !== void 0) { const f = e.children; for (let g = 0; g < f.length; g++) o.add(this.parseObject(f[g], t, i, r, s)); } if (e.animations !== void 0) { const f = e.animations; for (let g = 0; g < f.length; g++) { const p = f[g]; o.animations.push(s[p]); } } if (e.type === "LOD") { e.autoUpdate !== void 0 && (o.autoUpdate = e.autoUpdate); const f = e.levels; for (let g = 0; g < f.length; g++) { const p = f[g], u = o.getObjectByProperty("uuid", p.object); u !== void 0 && o.addLevel(u, p.distance); } } return o; } bindSkeletons(e, t) { Object.keys(t).length !== 0 && e.traverse(function(i) { if (i.isSkinnedMesh === true && i.skeleton !== void 0) { const r = t[i.skeleton]; r === void 0 ? console.warn("THREE.ObjectLoader: No skeleton found with UUID:", i.skeleton) : i.bind(r, i.bindMatrix); } }); } /* DEPRECATED */ setTexturePath(e) { return console.warn("THREE.ObjectLoader: .setTexturePath() has been renamed to .setResourcePath()."), this.setResourcePath(e); } }; var dN = { UVMapping: hu, CubeReflectionMapping: ll, CubeRefractionMapping: cl, EquirectangularReflectionMapping: kc, EquirectangularRefractionMapping: Gc, CubeUVReflectionMapping: ea, CubeUVRefractionMapping: ul }; var Wg = { RepeatWrapping: jr, ClampToEdgeWrapping: hn2, MirroredRepeatWrapping: Eo }; var jg = { NearestFilter: $t, NearestMipmapNearestFilter: ka, NearestMipmapLinearFilter: Ga, LinearFilter: zt, LinearMipmapNearestFilter: du, LinearMipmapLinearFilter: fr }; var op = class extends xn { constructor(e) { super(e), typeof createImageBitmap > "u" && console.warn("THREE.ImageBitmapLoader: createImageBitmap() not supported."), typeof fetch > "u" && console.warn("THREE.ImageBitmapLoader: fetch() not supported."), this.options = { premultiplyAlpha: "none" }; } setOptions(e) { return this.options = e, this; } load(e, t, i, r) { e === void 0 && (e = ""), this.path !== void 0 && (e = this.path + e), e = this.manager.resolveURL(e); const s = this, o = Is.get(e); if (o !== void 0) return s.manager.itemStart(e), setTimeout(function() { t && t(o), s.manager.itemEnd(e); }, 0), o; const a = {}; a.credentials = this.crossOrigin === "anonymous" ? "same-origin" : "include", a.headers = this.requestHeader, fetch(e, a).then(function(c) { return c.blob(); }).then(function(c) { return createImageBitmap(c, Object.assign(s.options, { colorSpaceConversion: "none" })); }).then(function(c) { Is.add(e, c), t && t(c), s.manager.itemEnd(e); }).catch(function(c) { r && r(c), s.manager.itemError(e), s.manager.itemEnd(e); }), s.manager.itemStart(e); } }; op.prototype.isImageBitmapLoader = true; var Wx = class { constructor() { this.type = "ShapePath", this.color = new Ue(), this.subPaths = [], this.currentPath = null; } moveTo(e, t) { return this.currentPath = new Ja(), this.subPaths.push(this.currentPath), this.currentPath.moveTo(e, t), this; } lineTo(e, t) { return this.currentPath.lineTo(e, t), this; } quadraticCurveTo(e, t, i, r) { return this.currentPath.quadraticCurveTo(e, t, i, r), this; } bezierCurveTo(e, t, i, r, s, o) { return this.currentPath.bezierCurveTo(e, t, i, r, s, o), this; } splineThru(e) { return this.currentPath.splineThru(e), this; } toShapes(e, t) { function i(m) { const x = []; for (let w = 0, A = m.length; w < A; w++) { const M = m[w], R = new Dr(); R.curves = M.curves, x.push(R); } return x; } function r(m, x) { const w = x.length; let A = false; for (let M = w - 1, R = 0; R < w; M = R++) { let L = x[M], S = x[R], I = S.x - L.x, T = S.y - L.y; if (Math.abs(T) > Number.EPSILON) { if (T < 0 && (L = x[R], I = -I, S = x[M], T = -T), m.y < L.y || m.y > S.y) continue; if (m.y === L.y) { if (m.x === L.x) return true; } else { const _ = T * (m.x - L.x) - I * (m.y - L.y); if (_ === 0) return true; if (_ < 0) continue; A = !A; } } else { if (m.y !== L.y) continue; if (S.x <= m.x && m.x <= L.x || L.x <= m.x && m.x <= S.x) return true; } } return A; } const s = Fi.isClockWise, o = this.subPaths; if (o.length === 0) return []; if (t === true) return i(o); let a, c, l; const d = []; if (o.length === 1) return c = o[0], l = new Dr(), l.curves = c.curves, d.push(l), d; let h6 = !s(o[0].getPoints()); h6 = e ? !h6 : h6; const f = [], g = []; let p = [], u = 0, y; g[u] = void 0, p[u] = []; for (let m = 0, x = o.length; m < x; m++) c = o[m], y = c.getPoints(), a = s(y), a = e ? !a : a, a ? (!h6 && g[u] && u++, g[u] = { s: new Dr(), p: y }, g[u].s.curves = c.curves, h6 && u++, p[u] = []) : p[u].push({ h: c, p: y[0] }); if (!g[0]) return i(o); if (g.length > 1) { let m = false; const x = []; for (let w = 0, A = g.length; w < A; w++) f[w] = []; for (let w = 0, A = g.length; w < A; w++) { const M = p[w]; for (let R = 0; R < M.length; R++) { const L = M[R]; let S = true; for (let I = 0; I < g.length; I++) r(L.p, g[I].p) && (w !== I && x.push({ froms: w, tos: I, hole: R }), S ? (S = false, f[I].push(L)) : m = true); S && f[w].push(L); } } x.length > 0 && (m || (p = f)); } let v; for (let m = 0, x = g.length; m < x; m++) { l = g[m].s, d.push(l), v = p[m]; for (let w = 0, A = v.length; w < A; w++) l.holes.push(v[w].h); } return d; } }; var ap = class { constructor(e) { this.type = "Font", this.data = e; } generateShapes(e, t = 100) { const i = [], r = fN(e, t, this.data); for (let s = 0, o = r.length; s < o; s++) Array.prototype.push.apply(i, r[s].toShapes()); return i; } }; function fN(n, e, t) { const i = Array.from(n), r = e / t.resolution, s = (t.boundingBox.yMax - t.boundingBox.yMin + t.underlineThickness) * r, o = []; let a = 0, c = 0; for (let l = 0; l < i.length; l++) { const d = i[l]; if (d === ` `) a = 0, c -= s; else { const h6 = pN(d, r, a, c, t); a += h6.offsetX, o.push(h6.path); } } return o; } function pN(n, e, t, i, r) { const s = r.glyphs[n] || r.glyphs["?"]; if (!s) { console.error('THREE.Font: character "' + n + '" does not exists in font family ' + r.familyName + "."); return; } const o = new Wx(); let a, c, l, d, h6, f, g, p; if (s.o) { const u = s._cachedOutline || (s._cachedOutline = s.o.split(" ")); for (let y = 0, v = u.length; y < v; ) switch (u[y++]) { case "m": a = u[y++] * e + t, c = u[y++] * e + i, o.moveTo(a, c); break; case "l": a = u[y++] * e + t, c = u[y++] * e + i, o.lineTo(a, c); break; case "q": l = u[y++] * e + t, d = u[y++] * e + i, h6 = u[y++] * e + t, f = u[y++] * e + i, o.quadraticCurveTo(h6, f, l, d); break; case "b": l = u[y++] * e + t, d = u[y++] * e + i, h6 = u[y++] * e + t, f = u[y++] * e + i, g = u[y++] * e + t, p = u[y++] * e + i, o.bezierCurveTo(h6, f, g, p, l, d); break; } } return { offsetX: s.ha * e, path: o }; } ap.prototype.isFont = true; var mN = class extends xn { constructor(e) { super(e); } load(e, t, i, r) { const s = this, o = new $n(this.manager); o.setPath(this.path), o.setRequestHeader(this.requestHeader), o.setWithCredentials(s.withCredentials), o.load(e, function(a) { let c; try { c = JSON.parse(a); } catch { console.warn("THREE.FontLoader: typeface.js support is being deprecated. Use typeface.json instead."), c = JSON.parse(a.substring(65, a.length - 2)); } const l = s.parse(c); t && t(l); }, i, r); } parse(e) { return new ap(e); } }; var hc; var lp = { getContext: function() { return hc === void 0 && (hc = new (window.AudioContext || window.webkitAudioContext)()), hc; }, setContext: function(n) { hc = n; } }; var jx = class extends xn { constructor(e) { super(e); } load(e, t, i, r) { const s = this, o = new $n(this.manager); o.setResponseType("arraybuffer"), o.setPath(this.path), o.setRequestHeader(this.requestHeader), o.setWithCredentials(this.withCredentials), o.load(e, function(a) { try { const c = a.slice(0); lp.getContext().decodeAudioData(c, function(d) { t(d); }); } catch (c) { r ? r(c) : console.error(c), s.manager.itemError(e); } }, i, r); } }; var $x = class extends Al { constructor(e, t, i = 1) { super(void 0, i); const r = new Ue().set(e), s = new Ue().set(t), o = new q(r.r, r.g, r.b), a = new q(s.r, s.g, s.b), c = Math.sqrt(Math.PI), l = c * Math.sqrt(0.75); this.sh.coefficients[0].copy(o).add(a).multiplyScalar(c), this.sh.coefficients[1].copy(o).sub(a).multiplyScalar(l); } }; $x.prototype.isHemisphereLightProbe = true; var Zx = class extends Al { constructor(e, t = 1) { super(void 0, t); const i = new Ue().set(e); this.sh.coefficients[0].set(i.r, i.g, i.b).multiplyScalar(2 * Math.sqrt(Math.PI)); } }; Zx.prototype.isAmbientLightProbe = true; var $g = new Xe(); var Zg = new Xe(); var gN = class { constructor() { this.type = "StereoCamera", this.aspect = 1, this.eyeSep = 0.064, this.cameraL = new nn(), this.cameraL.layers.enable(1), this.cameraL.matrixAutoUpdate = false, this.cameraR = new nn(), this.cameraR.layers.enable(2), this.cameraR.matrixAutoUpdate = false, this._cache = { focus: null, fov: null, aspect: null, near: null, far: null, zoom: null, eyeSep: null }; } update(e) { const t = this._cache; if (t.focus !== e.focus || t.fov !== e.fov || t.aspect !== e.aspect * this.aspect || t.near !== e.near || t.far !== e.far || t.zoom !== e.zoom || t.eyeSep !== this.eyeSep) { t.focus = e.focus, t.fov = e.fov, t.aspect = e.aspect * this.aspect, t.near = e.near, t.far = e.far, t.zoom = e.zoom, t.eyeSep = this.eyeSep; const r = e.projectionMatrix.clone(), s = t.eyeSep / 2, o = s * t.near / t.focus, a = t.near * Math.tan(As * t.fov * 0.5) / t.zoom; let c, l; Zg.elements[12] = -s, $g.elements[12] = s, c = -a * t.aspect + o, l = a * t.aspect + o, r.elements[0] = 2 * t.near / (l - c), r.elements[8] = (l + c) / (l - c), this.cameraL.projectionMatrix.copy(r), c = -a * t.aspect - o, l = a * t.aspect - o, r.elements[0] = 2 * t.near / (l - c), r.elements[8] = (l + c) / (l - c), this.cameraR.projectionMatrix.copy(r); } this.cameraL.matrixWorld.copy(e.matrixWorld).multiply(Zg), this.cameraR.matrixWorld.copy(e.matrixWorld).multiply($g); } }; var Xx = class { constructor(e = true) { this.autoStart = e, this.startTime = 0, this.oldTime = 0, this.elapsedTime = 0, this.running = false; } start() { this.startTime = Xg(), this.oldTime = this.startTime, this.elapsedTime = 0, this.running = true; } stop() { this.getElapsedTime(), this.running = false, this.autoStart = false; } getElapsedTime() { return this.getDelta(), this.elapsedTime; } getDelta() { let e = 0; if (this.autoStart && !this.running) return this.start(), 0; if (this.running) { const t = Xg(); e = (t - this.oldTime) / 1e3, this.oldTime = t, this.elapsedTime += e; } return e; } }; function Xg() { return (typeof performance > "u" ? Date : performance).now(); } var as = new q(); var Yg = new bn(); var vN = new q(); var ls = new q(); var yN = class extends ut { constructor() { super(), this.type = "AudioListener", this.context = lp.getContext(), this.gain = this.context.createGain(), this.gain.connect(this.context.destination), this.filter = null, this.timeDelta = 0, this._clock = new Xx(); } getInput() { return this.gain; } removeFilter() { return this.filter !== null && (this.gain.disconnect(this.filter), this.filter.disconnect(this.context.destination), this.gain.connect(this.context.destination), this.filter = null), this; } getFilter() { return this.filter; } setFilter(e) { return this.filter !== null ? (this.gain.disconnect(this.filter), this.filter.disconnect(this.context.destination)) : this.gain.disconnect(this.context.destination), this.filter = e, this.gain.connect(this.filter), this.filter.connect(this.context.destination), this; } getMasterVolume() { return this.gain.gain.value; } setMasterVolume(e) { return this.gain.gain.setTargetAtTime(e, this.context.currentTime, 0.01), this; } updateMatrixWorld(e) { super.updateMatrixWorld(e); const t = this.context.listener, i = this.up; if (this.timeDelta = this._clock.getDelta(), this.matrixWorld.decompose(as, Yg, vN), ls.set(0, 0, -1).applyQuaternion(Yg), t.positionX) { const r = this.context.currentTime + this.timeDelta; t.positionX.linearRampToValueAtTime(as.x, r), t.positionY.linearRampToValueAtTime(as.y, r), t.positionZ.linearRampToValueAtTime(as.z, r), t.forwardX.linearRampToValueAtTime(ls.x, r), t.forwardY.linearRampToValueAtTime(ls.y, r), t.forwardZ.linearRampToValueAtTime(ls.z, r), t.upX.linearRampToValueAtTime(i.x, r), t.upY.linearRampToValueAtTime(i.y, r), t.upZ.linearRampToValueAtTime(i.z, r); } else t.setPosition(as.x, as.y, as.z), t.setOrientation(ls.x, ls.y, ls.z, i.x, i.y, i.z); } }; var cp = class extends ut { constructor(e) { super(), this.type = "Audio", this.listener = e, this.context = e.context, this.gain = this.context.createGain(), this.gain.connect(e.getInput()), this.autoplay = false, this.buffer = null, this.detune = 0, this.loop = false, this.loopStart = 0, this.loopEnd = 0, this.offset = 0, this.duration = void 0, this.playbackRate = 1, this.isPlaying = false, this.hasPlaybackControl = true, this.source = null, this.sourceType = "empty", this._startedAt = 0, this._progress = 0, this._connected = false, this.filters = []; } getOutput() { return this.gain; } setNodeSource(e) { return this.hasPlaybackControl = false, this.sourceType = "audioNode", this.source = e, this.connect(), this; } setMediaElementSource(e) { return this.hasPlaybackControl = false, this.sourceType = "mediaNode", this.source = this.context.createMediaElementSource(e), this.connect(), this; } setMediaStreamSource(e) { return this.hasPlaybackControl = false, this.sourceType = "mediaStreamNode", this.source = this.context.createMediaStreamSource(e), this.connect(), this; } setBuffer(e) { return this.buffer = e, this.sourceType = "buffer", this.autoplay && this.play(), this; } play(e = 0) { if (this.isPlaying === true) { console.warn("THREE.Audio: Audio is already playing."); return; } if (this.hasPlaybackControl === false) { console.warn("THREE.Audio: this Audio has no playback control."); return; } this._startedAt = this.context.currentTime + e; const t = this.context.createBufferSource(); return t.buffer = this.buffer, t.loop = this.loop, t.loopStart = this.loopStart, t.loopEnd = this.loopEnd, t.onended = this.onEnded.bind(this), t.start(this._startedAt, this._progress + this.offset, this.duration), this.isPlaying = true, this.source = t, this.setDetune(this.detune), this.setPlaybackRate(this.playbackRate), this.connect(); } pause() { if (this.hasPlaybackControl === false) { console.warn("THREE.Audio: this Audio has no playback control."); return; } return this.isPlaying === true && (this._progress += Math.max(this.context.currentTime - this._startedAt, 0) * this.playbackRate, this.loop === true && (this._progress = this._progress % (this.duration || this.buffer.duration)), this.source.stop(), this.source.onended = null, this.isPlaying = false), this; } stop() { if (this.hasPlaybackControl === false) { console.warn("THREE.Audio: this Audio has no playback control."); return; } return this._progress = 0, this.source.stop(), this.source.onended = null, this.isPlaying = false, this; } connect() { if (this.filters.length > 0) { this.source.connect(this.filters[0]); for (let e = 1, t = this.filters.length; e < t; e++) this.filters[e - 1].connect(this.filters[e]); this.filters[this.filters.length - 1].connect(this.getOutput()); } else this.source.connect(this.getOutput()); return this._connected = true, this; } disconnect() { if (this.filters.length > 0) { this.source.disconnect(this.filters[0]); for (let e = 1, t = this.filters.length; e < t; e++) this.filters[e - 1].disconnect(this.filters[e]); this.filters[this.filters.length - 1].disconnect(this.getOutput()); } else this.source.disconnect(this.getOutput()); return this._connected = false, this; } getFilters() { return this.filters; } setFilters(e) { return e || (e = []), this._connected === true ? (this.disconnect(), this.filters = e.slice(), this.connect()) : this.filters = e.slice(), this; } setDetune(e) { if (this.detune = e, this.source.detune !== void 0) return this.isPlaying === true && this.source.detune.setTargetAtTime(this.detune, this.context.currentTime, 0.01), this; } getDetune() { return this.detune; } getFilter() { return this.getFilters()[0]; } setFilter(e) { return this.setFilters(e ? [e] : []); } setPlaybackRate(e) { if (this.hasPlaybackControl === false) { console.warn("THREE.Audio: this Audio has no playback control."); return; } return this.playbackRate = e, this.isPlaying === true && this.source.playbackRate.setTargetAtTime(this.playbackRate, this.context.currentTime, 0.01), this; } getPlaybackRate() { return this.playbackRate; } onEnded() { this.isPlaying = false; } getLoop() { return this.hasPlaybackControl === false ? (console.warn("THREE.Audio: this Audio has no playback control."), false) : this.loop; } setLoop(e) { if (this.hasPlaybackControl === false) { console.warn("THREE.Audio: this Audio has no playback control."); return; } return this.loop = e, this.isPlaying === true && (this.source.loop = this.loop), this; } setLoopStart(e) { return this.loopStart = e, this; } setLoopEnd(e) { return this.loopEnd = e, this; } getVolume() { return this.gain.gain.value; } setVolume(e) { return this.gain.gain.setTargetAtTime(e, this.context.currentTime, 0.01), this; } }; var cs = new q(); var Jg = new bn(); var bN = new q(); var us = new q(); var xN = class extends cp { constructor(e) { super(e), this.panner = this.context.createPanner(), this.panner.panningModel = "HRTF", this.panner.connect(this.gain); } getOutput() { return this.panner; } getRefDistance() { return this.panner.refDistance; } setRefDistance(e) { return this.panner.refDistance = e, this; } getRolloffFactor() { return this.panner.rolloffFactor; } setRolloffFactor(e) { return this.panner.rolloffFactor = e, this; } getDistanceModel() { return this.panner.distanceModel; } setDistanceModel(e) { return this.panner.distanceModel = e, this; } getMaxDistance() { return this.panner.maxDistance; } setMaxDistance(e) { return this.panner.maxDistance = e, this; } setDirectionalCone(e, t, i) { return this.panner.coneInnerAngle = e, this.panner.coneOuterAngle = t, this.panner.coneOuterGain = i, this; } updateMatrixWorld(e) { if (super.updateMatrixWorld(e), this.hasPlaybackControl === true && this.isPlaying === false) return; this.matrixWorld.decompose(cs, Jg, bN), us.set(0, 0, 1).applyQuaternion(Jg); const t = this.panner; if (t.positionX) { const i = this.context.currentTime + this.listener.timeDelta; t.positionX.linearRampToValueAtTime(cs.x, i), t.positionY.linearRampToValueAtTime(cs.y, i), t.positionZ.linearRampToValueAtTime(cs.z, i), t.orientationX.linearRampToValueAtTime(us.x, i), t.orientationY.linearRampToValueAtTime(us.y, i), t.orientationZ.linearRampToValueAtTime(us.z, i); } else t.setPosition(cs.x, cs.y, cs.z), t.setOrientation(us.x, us.y, us.z); } }; var Yx = class { constructor(e, t = 2048) { this.analyser = e.context.createAnalyser(), this.analyser.fftSize = t, this.data = new Uint8Array(this.analyser.frequencyBinCount), e.getOutput().connect(this.analyser); } getFrequencyData() { return this.analyser.getByteFrequencyData(this.data), this.data; } getAverageFrequency() { let e = 0; const t = this.getFrequencyData(); for (let i = 0; i < t.length; i++) e += t[i]; return e / t.length; } }; var Jx = class { constructor(e, t, i) { this.binding = e, this.valueSize = i; let r, s, o; switch (t) { case "quaternion": r = this._slerp, s = this._slerpAdditive, o = this._setAdditiveIdentityQuaternion, this.buffer = new Float64Array(i * 6), this._workIndex = 5; break; case "string": case "bool": r = this._select, s = this._select, o = this._setAdditiveIdentityOther, this.buffer = new Array(i * 5); break; default: r = this._lerp, s = this._lerpAdditive, o = this._setAdditiveIdentityNumeric, this.buffer = new Float64Array(i * 5); } this._mixBufferRegion = r, this._mixBufferRegionAdditive = s, this._setIdentity = o, this._origIndex = 3, this._addIndex = 4, this.cumulativeWeight = 0, this.cumulativeWeightAdditive = 0, this.useCount = 0, this.referenceCount = 0; } // accumulate data in the 'incoming' region into 'accu' accumulate(e, t) { const i = this.buffer, r = this.valueSize, s = e * r + r; let o = this.cumulativeWeight; if (o === 0) { for (let a = 0; a !== r; ++a) i[s + a] = i[a]; o = t; } else { o += t; const a = t / o; this._mixBufferRegion(i, s, 0, a, r); } this.cumulativeWeight = o; } // accumulate data in the 'incoming' region into 'add' accumulateAdditive(e) { const t = this.buffer, i = this.valueSize, r = i * this._addIndex; this.cumulativeWeightAdditive === 0 && this._setIdentity(), this._mixBufferRegionAdditive(t, r, 0, e, i), this.cumulativeWeightAdditive += e; } // apply the state of 'accu' to the binding when accus differ apply(e) { const t = this.valueSize, i = this.buffer, r = e * t + t, s = this.cumulativeWeight, o = this.cumulativeWeightAdditive, a = this.binding; if (this.cumulativeWeight = 0, this.cumulativeWeightAdditive = 0, s < 1) { const c = t * this._origIndex; this._mixBufferRegion( i, r, c, 1 - s, t ); } o > 0 && this._mixBufferRegionAdditive(i, r, this._addIndex * t, 1, t); for (let c = t, l = t + t; c !== l; ++c) if (i[c] !== i[c + t]) { a.setValue(i, r); break; } } // remember the state of the bound property and copy it to both accus saveOriginalState() { const e = this.binding, t = this.buffer, i = this.valueSize, r = i * this._origIndex; e.getValue(t, r); for (let s = i, o = r; s !== o; ++s) t[s] = t[r + s % i]; this._setIdentity(), this.cumulativeWeight = 0, this.cumulativeWeightAdditive = 0; } // apply the state previously taken via 'saveOriginalState' to the binding restoreOriginalState() { const e = this.valueSize * 3; this.binding.setValue(this.buffer, e); } _setAdditiveIdentityNumeric() { const e = this._addIndex * this.valueSize, t = e + this.valueSize; for (let i = e; i < t; i++) this.buffer[i] = 0; } _setAdditiveIdentityQuaternion() { this._setAdditiveIdentityNumeric(), this.buffer[this._addIndex * this.valueSize + 3] = 1; } _setAdditiveIdentityOther() { const e = this._origIndex * this.valueSize, t = this._addIndex * this.valueSize; for (let i = 0; i < this.valueSize; i++) this.buffer[t + i] = this.buffer[e + i]; } // mix functions _select(e, t, i, r, s) { if (r >= 0.5) for (let o = 0; o !== s; ++o) e[t + o] = e[i + o]; } _slerp(e, t, i, r) { bn.slerpFlat(e, t, e, t, e, i, r); } _slerpAdditive(e, t, i, r, s) { const o = this._workIndex * s; bn.multiplyQuaternionsFlat(e, o, e, t, e, i), bn.slerpFlat(e, t, e, t, e, o, r); } _lerp(e, t, i, r, s) { const o = 1 - r; for (let a = 0; a !== s; ++a) { const c = t + a; e[c] = e[c] * o + e[i + a] * r; } } _lerpAdditive(e, t, i, r, s) { for (let o = 0; o !== s; ++o) { const a = t + o; e[a] = e[a] + e[i + o] * r; } } }; var up = "\\[\\]\\.:\\/"; var MN = new RegExp("[" + up + "]", "g"); var hp = "[^" + up + "]"; var wN = "[^" + up.replace("\\.", "") + "]"; var AN = /((?:WC+[\/:])*)/.source.replace("WC", hp); var SN = /(WCOD+)?/.source.replace("WCOD", wN); var _N = /(?:\.(WC+)(?:\[(.+)\])?)?/.source.replace("WC", hp); var TN = /\.(WC+)(?:\[(.+)\])?/.source.replace("WC", hp); var EN = new RegExp( "^" + AN + SN + _N + TN + "$" ); var CN = ["material", "materials", "bones"]; var LN = class { constructor(e, t, i) { const r = i || mt.parseTrackName(t); this._targetGroup = e, this._bindings = e.subscribe_(t, r); } getValue(e, t) { this.bind(); const i = this._targetGroup.nCachedObjects_, r = this._bindings[i]; r !== void 0 && r.getValue(e, t); } setValue(e, t) { const i = this._bindings; for (let r = this._targetGroup.nCachedObjects_, s = i.length; r !== s; ++r) i[r].setValue(e, t); } bind() { const e = this._bindings; for (let t = this._targetGroup.nCachedObjects_, i = e.length; t !== i; ++t) e[t].bind(); } unbind() { const e = this._bindings; for (let t = this._targetGroup.nCachedObjects_, i = e.length; t !== i; ++t) e[t].unbind(); } }; var mt = class _mt { constructor(e, t, i) { this.path = t, this.parsedPath = i || _mt.parseTrackName(t), this.node = _mt.findNode(e, this.parsedPath.nodeName) || e, this.rootNode = e, this.getValue = this._getValue_unbound, this.setValue = this._setValue_unbound; } static create(e, t, i) { return e && e.isAnimationObjectGroup ? new _mt.Composite(e, t, i) : new _mt(e, t, i); } /** * Replaces spaces with underscores and removes unsupported characters from * node names, to ensure compatibility with parseTrackName(). * * @param {string} name Node name to be sanitized. * @return {string} */ static sanitizeNodeName(e) { return e.replace(/\s/g, "_").replace(MN, ""); } static parseTrackName(e) { const t = EN.exec(e); if (!t) throw new Error("PropertyBinding: Cannot parse trackName: " + e); const i = { // directoryName: matches[ 1 ], // (tschw) currently unused nodeName: t[2], objectName: t[3], objectIndex: t[4], propertyName: t[5], // required propertyIndex: t[6] }, r = i.nodeName && i.nodeName.lastIndexOf("."); if (r !== void 0 && r !== -1) { const s = i.nodeName.substring(r + 1); CN.indexOf(s) !== -1 && (i.nodeName = i.nodeName.substring(0, r), i.objectName = s); } if (i.propertyName === null || i.propertyName.length === 0) throw new Error("PropertyBinding: can not parse propertyName from trackName: " + e); return i; } static findNode(e, t) { if (!t || t === "" || t === "." || t === -1 || t === e.name || t === e.uuid) return e; if (e.skeleton) { const i = e.skeleton.getBoneByName(t); if (i !== void 0) return i; } if (e.children) { const i = function(s) { for (let o = 0; o < s.length; o++) { const a = s[o]; if (a.name === t || a.uuid === t) return a; const c = i(a.children); if (c) return c; } return null; }, r = i(e.children); if (r) return r; } return null; } // these are used to "bind" a nonexistent property _getValue_unavailable() { } _setValue_unavailable() { } // Getters _getValue_direct(e, t) { e[t] = this.node[this.propertyName]; } _getValue_array(e, t) { const i = this.resolvedProperty; for (let r = 0, s = i.length; r !== s; ++r) e[t++] = i[r]; } _getValue_arrayElement(e, t) { e[t] = this.resolvedProperty[this.propertyIndex]; } _getValue_toArray(e, t) { this.resolvedProperty.toArray(e, t); } // Direct _setValue_direct(e, t) { this.targetObject[this.propertyName] = e[t]; } _setValue_direct_setNeedsUpdate(e, t) { this.targetObject[this.propertyName] = e[t], this.targetObject.needsUpdate = true; } _setValue_direct_setMatrixWorldNeedsUpdate(e, t) { this.targetObject[this.propertyName] = e[t], this.targetObject.matrixWorldNeedsUpdate = true; } // EntireArray _setValue_array(e, t) { const i = this.resolvedProperty; for (let r = 0, s = i.length; r !== s; ++r) i[r] = e[t++]; } _setValue_array_setNeedsUpdate(e, t) { const i = this.resolvedProperty; for (let r = 0, s = i.length; r !== s; ++r) i[r] = e[t++]; this.targetObject.needsUpdate = true; } _setValue_array_setMatrixWorldNeedsUpdate(e, t) { const i = this.resolvedProperty; for (let r = 0, s = i.length; r !== s; ++r) i[r] = e[t++]; this.targetObject.matrixWorldNeedsUpdate = true; } // ArrayElement _setValue_arrayElement(e, t) { this.resolvedProperty[this.propertyIndex] = e[t]; } _setValue_arrayElement_setNeedsUpdate(e, t) { this.resolvedProperty[this.propertyIndex] = e[t], this.targetObject.needsUpdate = true; } _setValue_arrayElement_setMatrixWorldNeedsUpdate(e, t) { this.resolvedProperty[this.propertyIndex] = e[t], this.targetObject.matrixWorldNeedsUpdate = true; } // HasToFromArray _setValue_fromArray(e, t) { this.resolvedProperty.fromArray(e, t); } _setValue_fromArray_setNeedsUpdate(e, t) { this.resolvedProperty.fromArray(e, t), this.targetObject.needsUpdate = true; } _setValue_fromArray_setMatrixWorldNeedsUpdate(e, t) { this.resolvedProperty.fromArray(e, t), this.targetObject.matrixWorldNeedsUpdate = true; } _getValue_unbound(e, t) { this.bind(), this.getValue(e, t); } _setValue_unbound(e, t) { this.bind(), this.setValue(e, t); } // create getter / setter pair for a property in the scene graph bind() { let e = this.node; const t = this.parsedPath, i = t.objectName, r = t.propertyName; let s = t.propertyIndex; if (e || (e = _mt.findNode(this.rootNode, t.nodeName) || this.rootNode, this.node = e), this.getValue = this._getValue_unavailable, this.setValue = this._setValue_unavailable, !e) { console.error("THREE.PropertyBinding: Trying to update node for track: " + this.path + " but it wasn't found."); return; } if (i) { let l = t.objectIndex; switch (i) { case "materials": if (!e.material) { console.error("THREE.PropertyBinding: Can not bind to material as node does not have a material.", this); return; } if (!e.material.materials) { console.error("THREE.PropertyBinding: Can not bind to material.materials as node.material does not have a materials array.", this); return; } e = e.material.materials; break; case "bones": if (!e.skeleton) { console.error("THREE.PropertyBinding: Can not bind to bones as node does not have a skeleton.", this); return; } e = e.skeleton.bones; for (let d = 0; d < e.length; d++) if (e[d].name === l) { l = d; break; } break; default: if (e[i] === void 0) { console.error("THREE.PropertyBinding: Can not bind to objectName of node undefined.", this); return; } e = e[i]; } if (l !== void 0) { if (e[l] === void 0) { console.error("THREE.PropertyBinding: Trying to bind to objectIndex of objectName, but is undefined.", this, e); return; } e = e[l]; } } const o = e[r]; if (o === void 0) { const l = t.nodeName; console.error("THREE.PropertyBinding: Trying to update property for track: " + l + "." + r + " but it wasn't found.", e); return; } let a = this.Versioning.None; this.targetObject = e, e.needsUpdate !== void 0 ? a = this.Versioning.NeedsUpdate : e.matrixWorldNeedsUpdate !== void 0 && (a = this.Versioning.MatrixWorldNeedsUpdate); let c = this.BindingType.Direct; if (s !== void 0) { if (r === "morphTargetInfluences") { if (!e.geometry) { console.error("THREE.PropertyBinding: Can not bind to morphTargetInfluences because node does not have a geometry.", this); return; } if (e.geometry.isBufferGeometry) { if (!e.geometry.morphAttributes) { console.error("THREE.PropertyBinding: Can not bind to morphTargetInfluences because node does not have a geometry.morphAttributes.", this); return; } e.morphTargetDictionary[s] !== void 0 && (s = e.morphTargetDictionary[s]); } else { console.error("THREE.PropertyBinding: Can not bind to morphTargetInfluences on THREE.Geometry. Use THREE.BufferGeometry instead.", this); return; } } c = this.BindingType.ArrayElement, this.resolvedProperty = o, this.propertyIndex = s; } else o.fromArray !== void 0 && o.toArray !== void 0 ? (c = this.BindingType.HasFromToArray, this.resolvedProperty = o) : Array.isArray(o) ? (c = this.BindingType.EntireArray, this.resolvedProperty = o) : this.propertyName = r; this.getValue = this.GetterByBindingType[c], this.setValue = this.SetterByBindingTypeAndVersioning[c][a]; } unbind() { this.node = null, this.getValue = this._getValue_unbound, this.setValue = this._setValue_unbound; } }; mt.Composite = LN; mt.prototype.BindingType = { Direct: 0, EntireArray: 1, ArrayElement: 2, HasFromToArray: 3 }; mt.prototype.Versioning = { None: 0, NeedsUpdate: 1, MatrixWorldNeedsUpdate: 2 }; mt.prototype.GetterByBindingType = [ mt.prototype._getValue_direct, mt.prototype._getValue_array, mt.prototype._getValue_arrayElement, mt.prototype._getValue_toArray ]; mt.prototype.SetterByBindingTypeAndVersioning = [ [ // Direct mt.prototype._setValue_direct, mt.prototype._setValue_direct_setNeedsUpdate, mt.prototype._setValue_direct_setMatrixWorldNeedsUpdate ], [ // EntireArray mt.prototype._setValue_array, mt.prototype._setValue_array_setNeedsUpdate, mt.prototype._setValue_array_setMatrixWorldNeedsUpdate ], [ // ArrayElement mt.prototype._setValue_arrayElement, mt.prototype._setValue_arrayElement_setNeedsUpdate, mt.prototype._setValue_arrayElement_setMatrixWorldNeedsUpdate ], [ // HasToFromArray mt.prototype._setValue_fromArray, mt.prototype._setValue_fromArray_setNeedsUpdate, mt.prototype._setValue_fromArray_setMatrixWorldNeedsUpdate ] ]; var Kx = class { constructor() { this.uuid = Hn(), this._objects = Array.prototype.slice.call(arguments), this.nCachedObjects_ = 0; const e = {}; this._indicesByUUID = e; for (let i = 0, r = arguments.length; i !== r; ++i) e[arguments[i].uuid] = i; this._paths = [], this._parsedPaths = [], this._bindings = [], this._bindingsIndicesByPath = {}; const t = this; this.stats = { objects: { get total() { return t._objects.length; }, get inUse() { return this.total - t.nCachedObjects_; } }, get bindingsPerObject() { return t._bindings.length; } }; } add() { const e = this._objects, t = this._indicesByUUID, i = this._paths, r = this._parsedPaths, s = this._bindings, o = s.length; let a, c = e.length, l = this.nCachedObjects_; for (let d = 0, h6 = arguments.length; d !== h6; ++d) { const f = arguments[d], g = f.uuid; let p = t[g]; if (p === void 0) { p = c++, t[g] = p, e.push(f); for (let u = 0, y = o; u !== y; ++u) s[u].push(new mt(f, i[u], r[u])); } else if (p < l) { a = e[p]; const u = --l, y = e[u]; t[y.uuid] = p, e[p] = y, t[g] = u, e[u] = f; for (let v = 0, m = o; v !== m; ++v) { const x = s[v], w = x[u]; let A = x[p]; x[p] = w, A === void 0 && (A = new mt(f, i[v], r[v])), x[u] = A; } } else e[p] !== a && console.error("THREE.AnimationObjectGroup: Different objects with the same UUID detected. Clean the caches or recreate your infrastructure when reloading scenes."); } this.nCachedObjects_ = l; } remove() { const e = this._objects, t = this._indicesByUUID, i = this._bindings, r = i.length; let s = this.nCachedObjects_; for (let o = 0, a = arguments.length; o !== a; ++o) { const c = arguments[o], l = c.uuid, d = t[l]; if (d !== void 0 && d >= s) { const h6 = s++, f = e[h6]; t[f.uuid] = d, e[d] = f, t[l] = h6, e[h6] = c; for (let g = 0, p = r; g !== p; ++g) { const u = i[g], y = u[h6], v = u[d]; u[d] = y, u[h6] = v; } } } this.nCachedObjects_ = s; } // remove & forget uncache() { const e = this._objects, t = this._indicesByUUID, i = this._bindings, r = i.length; let s = this.nCachedObjects_, o = e.length; for (let a = 0, c = arguments.length; a !== c; ++a) { const l = arguments[a], d = l.uuid, h6 = t[d]; if (h6 !== void 0) if (delete t[d], h6 < s) { const f = --s, g = e[f], p = --o, u = e[p]; t[g.uuid] = h6, e[h6] = g, t[u.uuid] = f, e[f] = u, e.pop(); for (let y = 0, v = r; y !== v; ++y) { const m = i[y], x = m[f], w = m[p]; m[h6] = x, m[f] = w, m.pop(); } } else { const f = --o, g = e[f]; f > 0 && (t[g.uuid] = h6), e[h6] = g, e.pop(); for (let p = 0, u = r; p !== u; ++p) { const y = i[p]; y[h6] = y[f], y.pop(); } } } this.nCachedObjects_ = s; } // Internal interface used by befriended PropertyBinding.Composite: subscribe_(e, t) { const i = this._bindingsIndicesByPath; let r = i[e]; const s = this._bindings; if (r !== void 0) return s[r]; const o = this._paths, a = this._parsedPaths, c = this._objects, l = c.length, d = this.nCachedObjects_, h6 = new Array(l); r = s.length, i[e] = r, o.push(e), a.push(t), s.push(h6); for (let f = d, g = c.length; f !== g; ++f) { const p = c[f]; h6[f] = new mt(p, e, t); } return h6; } unsubscribe_(e) { const t = this._bindingsIndicesByPath, i = t[e]; if (i !== void 0) { const r = this._paths, s = this._parsedPaths, o = this._bindings, a = o.length - 1, c = o[a], l = e[a]; t[l] = i, o[i] = c, o.pop(), s[i] = s[a], s.pop(), r[i] = r[a], r.pop(); } } }; Kx.prototype.isAnimationObjectGroup = true; var RN = class { constructor(e, t, i = null, r = t.blendMode) { this._mixer = e, this._clip = t, this._localRoot = i, this.blendMode = r; const s = t.tracks, o = s.length, a = new Array(o), c = { endingStart: gs, endingEnd: gs }; for (let l = 0; l !== o; ++l) { const d = s[l].createInterpolant(null); a[l] = d, d.settings = c; } this._interpolantSettings = c, this._interpolants = a, this._propertyBindings = new Array(o), this._cacheIndex = null, this._byClipCacheIndex = null, this._timeScaleInterpolant = null, this._weightInterpolant = null, this.loop = Wb, this._loopCount = -1, this._startTime = null, this.time = 0, this.timeScale = 1, this._effectiveTimeScale = 1, this.weight = 1, this._effectiveWeight = 1, this.repetitions = 1 / 0, this.paused = false, this.enabled = true, this.clampWhenFinished = false, this.zeroSlopeAtStart = true, this.zeroSlopeAtEnd = true; } // State & Scheduling play() { return this._mixer._activateAction(this), this; } stop() { return this._mixer._deactivateAction(this), this.reset(); } reset() { return this.paused = false, this.enabled = true, this.time = 0, this._loopCount = -1, this._startTime = null, this.stopFading().stopWarping(); } isRunning() { return this.enabled && !this.paused && this.timeScale !== 0 && this._startTime === null && this._mixer._isActiveAction(this); } // return true when play has been called isScheduled() { return this._mixer._isActiveAction(this); } startAt(e) { return this._startTime = e, this; } setLoop(e, t) { return this.loop = e, this.repetitions = t, this; } // Weight // set the weight stopping any scheduled fading // although .enabled = false yields an effective weight of zero, this // method does *not* change .enabled, because it would be confusing setEffectiveWeight(e) { return this.weight = e, this._effectiveWeight = this.enabled ? e : 0, this.stopFading(); } // return the weight considering fading and .enabled getEffectiveWeight() { return this._effectiveWeight; } fadeIn(e) { return this._scheduleFading(e, 0, 1); } fadeOut(e) { return this._scheduleFading(e, 1, 0); } crossFadeFrom(e, t, i) { if (e.fadeOut(t), this.fadeIn(t), i) { const r = this._clip.duration, s = e._clip.duration, o = s / r, a = r / s; e.warp(1, o, t), this.warp(a, 1, t); } return this; } crossFadeTo(e, t, i) { return e.crossFadeFrom(this, t, i); } stopFading() { const e = this._weightInterpolant; return e !== null && (this._weightInterpolant = null, this._mixer._takeBackControlInterpolant(e)), this; } // Time Scale Control // set the time scale stopping any scheduled warping // although .paused = true yields an effective time scale of zero, this // method does *not* change .paused, because it would be confusing setEffectiveTimeScale(e) { return this.timeScale = e, this._effectiveTimeScale = this.paused ? 0 : e, this.stopWarping(); } // return the time scale considering warping and .paused getEffectiveTimeScale() { return this._effectiveTimeScale; } setDuration(e) { return this.timeScale = this._clip.duration / e, this.stopWarping(); } syncWith(e) { return this.time = e.time, this.timeScale = e.timeScale, this.stopWarping(); } halt(e) { return this.warp(this._effectiveTimeScale, 0, e); } warp(e, t, i) { const r = this._mixer, s = r.time, o = this.timeScale; let a = this._timeScaleInterpolant; a === null && (a = r._lendControlInterpolant(), this._timeScaleInterpolant = a); const c = a.parameterPositions, l = a.sampleValues; return c[0] = s, c[1] = s + i, l[0] = e / o, l[1] = t / o, this; } stopWarping() { const e = this._timeScaleInterpolant; return e !== null && (this._timeScaleInterpolant = null, this._mixer._takeBackControlInterpolant(e)), this; } // Object Accessors getMixer() { return this._mixer; } getClip() { return this._clip; } getRoot() { return this._localRoot || this._mixer._root; } // Interna _update(e, t, i, r) { if (!this.enabled) { this._updateWeight(e); return; } const s = this._startTime; if (s !== null) { const c = (e - s) * i; if (c < 0 || i === 0) return; this._startTime = null, t = i * c; } t *= this._updateTimeScale(e); const o = this._updateTime(t), a = this._updateWeight(e); if (a > 0) { const c = this._interpolants, l = this._propertyBindings; switch (this.blendMode) { case Mf: for (let d = 0, h6 = c.length; d !== h6; ++d) c[d].evaluate(o), l[d].accumulateAdditive(a); break; case fu: default: for (let d = 0, h6 = c.length; d !== h6; ++d) c[d].evaluate(o), l[d].accumulate(r, a); } } } _updateWeight(e) { let t = 0; if (this.enabled) { t = this.weight; const i = this._weightInterpolant; if (i !== null) { const r = i.evaluate(e)[0]; t *= r, e > i.parameterPositions[1] && (this.stopFading(), r === 0 && (this.enabled = false)); } } return this._effectiveWeight = t, t; } _updateTimeScale(e) { let t = 0; if (!this.paused) { t = this.timeScale; const i = this._timeScaleInterpolant; if (i !== null) { const r = i.evaluate(e)[0]; t *= r, e > i.parameterPositions[1] && (this.stopWarping(), t === 0 ? this.paused = true : this.timeScale = t); } } return this._effectiveTimeScale = t, t; } _updateTime(e) { const t = this._clip.duration, i = this.loop; let r = this.time + e, s = this._loopCount; const o = i === jb; if (e === 0) return s === -1 ? r : o && (s & 1) === 1 ? t - r : r; if (i === Hb) { s === -1 && (this._loopCount = 0, this._setEndings(true, true, false)); e: { if (r >= t) r = t; else if (r < 0) r = 0; else { this.time = r; break e; } this.clampWhenFinished ? this.paused = true : this.enabled = false, this.time = r, this._mixer.dispatchEvent({ type: "finished", action: this, direction: e < 0 ? -1 : 1 }); } } else { if (s === -1 && (e >= 0 ? (s = 0, this._setEndings(true, this.repetitions === 0, o)) : this._setEndings(this.repetitions === 0, true, o)), r >= t || r < 0) { const a = Math.floor(r / t); r -= t * a, s += Math.abs(a); const c = this.repetitions - s; if (c <= 0) this.clampWhenFinished ? this.paused = true : this.enabled = false, r = e > 0 ? t : 0, this.time = r, this._mixer.dispatchEvent({ type: "finished", action: this, direction: e > 0 ? 1 : -1 }); else { if (c === 1) { const l = e < 0; this._setEndings(l, !l, o); } else this._setEndings(false, false, o); this._loopCount = s, this.time = r, this._mixer.dispatchEvent({ type: "loop", action: this, loopDelta: a }); } } else this.time = r; if (o && (s & 1) === 1) return t - r; } return r; } _setEndings(e, t, i) { const r = this._interpolantSettings; i ? (r.endingStart = vs, r.endingEnd = vs) : (e ? r.endingStart = this.zeroSlopeAtStart ? vs : gs : r.endingStart = Wa, t ? r.endingEnd = this.zeroSlopeAtEnd ? vs : gs : r.endingEnd = Wa); } _scheduleFading(e, t, i) { const r = this._mixer, s = r.time; let o = this._weightInterpolant; o === null && (o = r._lendControlInterpolant(), this._weightInterpolant = o); const a = o.parameterPositions, c = o.sampleValues; return a[0] = s, c[0] = t, a[1] = s + e, c[1] = i, this; } }; var qx = class extends Kr { constructor(e) { super(), this._root = e, this._initMemoryManager(), this._accuIndex = 0, this.time = 0, this.timeScale = 1; } _bindAction(e, t) { const i = e._localRoot || this._root, r = e._clip.tracks, s = r.length, o = e._propertyBindings, a = e._interpolants, c = i.uuid, l = this._bindingsByRootAndName; let d = l[c]; d === void 0 && (d = {}, l[c] = d); for (let h6 = 0; h6 !== s; ++h6) { const f = r[h6], g = f.name; let p = d[g]; if (p !== void 0) o[h6] = p; else { if (p = o[h6], p !== void 0) { p._cacheIndex === null && (++p.referenceCount, this._addInactiveBinding(p, c, g)); continue; } const u = t && t._propertyBindings[h6].binding.parsedPath; p = new Jx( mt.create(i, g, u), f.ValueTypeName, f.getValueSize() ), ++p.referenceCount, this._addInactiveBinding(p, c, g), o[h6] = p; } a[h6].resultBuffer = p.buffer; } } _activateAction(e) { if (!this._isActiveAction(e)) { if (e._cacheIndex === null) { const i = (e._localRoot || this._root).uuid, r = e._clip.uuid, s = this._actionsByClip[r]; this._bindAction( e, s && s.knownActions[0] ), this._addInactiveAction(e, r, i); } const t = e._propertyBindings; for (let i = 0, r = t.length; i !== r; ++i) { const s = t[i]; s.useCount++ === 0 && (this._lendBinding(s), s.saveOriginalState()); } this._lendAction(e); } } _deactivateAction(e) { if (this._isActiveAction(e)) { const t = e._propertyBindings; for (let i = 0, r = t.length; i !== r; ++i) { const s = t[i]; --s.useCount === 0 && (s.restoreOriginalState(), this._takeBackBinding(s)); } this._takeBackAction(e); } } // Memory manager _initMemoryManager() { this._actions = [], this._nActiveActions = 0, this._actionsByClip = {}, this._bindings = [], this._nActiveBindings = 0, this._bindingsByRootAndName = {}, this._controlInterpolants = [], this._nActiveControlInterpolants = 0; const e = this; this.stats = { actions: { get total() { return e._actions.length; }, get inUse() { return e._nActiveActions; } }, bindings: { get total() { return e._bindings.length; }, get inUse() { return e._nActiveBindings; } }, controlInterpolants: { get total() { return e._controlInterpolants.length; }, get inUse() { return e._nActiveControlInterpolants; } } }; } // Memory management for AnimationAction objects _isActiveAction(e) { const t = e._cacheIndex; return t !== null && t < this._nActiveActions; } _addInactiveAction(e, t, i) { const r = this._actions, s = this._actionsByClip; let o = s[t]; if (o === void 0) o = { knownActions: [e], actionByRoot: {} }, e._byClipCacheIndex = 0, s[t] = o; else { const a = o.knownActions; e._byClipCacheIndex = a.length, a.push(e); } e._cacheIndex = r.length, r.push(e), o.actionByRoot[i] = e; } _removeInactiveAction(e) { const t = this._actions, i = t[t.length - 1], r = e._cacheIndex; i._cacheIndex = r, t[r] = i, t.pop(), e._cacheIndex = null; const s = e._clip.uuid, o = this._actionsByClip, a = o[s], c = a.knownActions, l = c[c.length - 1], d = e._byClipCacheIndex; l._byClipCacheIndex = d, c[d] = l, c.pop(), e._byClipCacheIndex = null; const h6 = a.actionByRoot, f = (e._localRoot || this._root).uuid; delete h6[f], c.length === 0 && delete o[s], this._removeInactiveBindingsForAction(e); } _removeInactiveBindingsForAction(e) { const t = e._propertyBindings; for (let i = 0, r = t.length; i !== r; ++i) { const s = t[i]; --s.referenceCount === 0 && this._removeInactiveBinding(s); } } _lendAction(e) { const t = this._actions, i = e._cacheIndex, r = this._nActiveActions++, s = t[r]; e._cacheIndex = r, t[r] = e, s._cacheIndex = i, t[i] = s; } _takeBackAction(e) { const t = this._actions, i = e._cacheIndex, r = --this._nActiveActions, s = t[r]; e._cacheIndex = r, t[r] = e, s._cacheIndex = i, t[i] = s; } // Memory management for PropertyMixer objects _addInactiveBinding(e, t, i) { const r = this._bindingsByRootAndName, s = this._bindings; let o = r[t]; o === void 0 && (o = {}, r[t] = o), o[i] = e, e._cacheIndex = s.length, s.push(e); } _removeInactiveBinding(e) { const t = this._bindings, i = e.binding, r = i.rootNode.uuid, s = i.path, o = this._bindingsByRootAndName, a = o[r], c = t[t.length - 1], l = e._cacheIndex; c._cacheIndex = l, t[l] = c, t.pop(), delete a[s], Object.keys(a).length === 0 && delete o[r]; } _lendBinding(e) { const t = this._bindings, i = e._cacheIndex, r = this._nActiveBindings++, s = t[r]; e._cacheIndex = r, t[r] = e, s._cacheIndex = i, t[i] = s; } _takeBackBinding(e) { const t = this._bindings, i = e._cacheIndex, r = --this._nActiveBindings, s = t[r]; e._cacheIndex = r, t[r] = e, s._cacheIndex = i, t[i] = s; } // Memory management of Interpolants for weight and time scale _lendControlInterpolant() { const e = this._controlInterpolants, t = this._nActiveControlInterpolants++; let i = e[t]; return i === void 0 && (i = new Yf( new Float32Array(2), new Float32Array(2), 1, this._controlInterpolantsResultBuffer ), i.__cacheIndex = t, e[t] = i), i; } _takeBackControlInterpolant(e) { const t = this._controlInterpolants, i = e.__cacheIndex, r = --this._nActiveControlInterpolants, s = t[r]; e.__cacheIndex = r, t[r] = e, s.__cacheIndex = i, t[i] = s; } // return an action for a clip optionally using a custom root target // object (this method allocates a lot of dynamic memory in case a // previously unknown clip/root combination is specified) clipAction(e, t, i) { const r = t || this._root, s = r.uuid; let o = typeof e == "string" ? jo.findByName(r, e) : e; const a = o !== null ? o.uuid : e, c = this._actionsByClip[a]; let l = null; if (i === void 0 && (o !== null ? i = o.blendMode : i = fu), c !== void 0) { const h6 = c.actionByRoot[s]; if (h6 !== void 0 && h6.blendMode === i) return h6; l = c.knownActions[0], o === null && (o = l._clip); } if (o === null) return null; const d = new RN(this, o, t, i); return this._bindAction(d, l), this._addInactiveAction(d, a, s), d; } // get an existing action existingAction(e, t) { const i = t || this._root, r = i.uuid, s = typeof e == "string" ? jo.findByName(i, e) : e, o = s ? s.uuid : e, a = this._actionsByClip[o]; return a !== void 0 && a.actionByRoot[r] || null; } // deactivates all previously scheduled actions stopAllAction() { const e = this._actions, t = this._nActiveActions; for (let i = t - 1; i >= 0; --i) e[i].stop(); return this; } // advance the time and update apply the animation update(e) { e *= this.timeScale; const t = this._actions, i = this._nActiveActions, r = this.time += e, s = Math.sign(e), o = this._accuIndex ^= 1; for (let l = 0; l !== i; ++l) t[l]._update(r, e, s, o); const a = this._bindings, c = this._nActiveBindings; for (let l = 0; l !== c; ++l) a[l].apply(o); return this; } // Allows you to seek to a specific time in an animation. setTime(e) { this.time = 0; for (let t = 0; t < this._actions.length; t++) this._actions[t].time = 0; return this.update(e); } // return this mixer's root target object getRoot() { return this._root; } // free all resources specific to a particular clip uncacheClip(e) { const t = this._actions, i = e.uuid, r = this._actionsByClip, s = r[i]; if (s !== void 0) { const o = s.knownActions; for (let a = 0, c = o.length; a !== c; ++a) { const l = o[a]; this._deactivateAction(l); const d = l._cacheIndex, h6 = t[t.length - 1]; l._cacheIndex = null, l._byClipCacheIndex = null, h6._cacheIndex = d, t[d] = h6, t.pop(), this._removeInactiveBindingsForAction(l); } delete r[i]; } } // free all resources specific to a particular root target object uncacheRoot(e) { const t = e.uuid, i = this._actionsByClip; for (const o in i) { const a = i[o].actionByRoot, c = a[t]; c !== void 0 && (this._deactivateAction(c), this._removeInactiveAction(c)); } const r = this._bindingsByRootAndName, s = r[t]; if (s !== void 0) for (const o in s) { const a = s[o]; a.restoreOriginalState(), this._removeInactiveBinding(a); } } // remove a targeted clip from the cache uncacheAction(e, t) { const i = this.existingAction(e, t); i !== null && (this._deactivateAction(i), this._removeInactiveAction(i)); } }; qx.prototype._controlInterpolantsResultBuffer = new Float32Array(1); var Fu = class _Fu { constructor(e) { typeof e == "string" && (console.warn("THREE.Uniform: Type parameter is no longer needed."), e = arguments[1]), this.value = e; } clone() { return new _Fu(this.value.clone === void 0 ? this.value : this.value.clone()); } }; var Qx = class extends Qr { constructor(e, t, i = 1) { super(e, t), this.meshPerAttribute = i; } copy(e) { return super.copy(e), this.meshPerAttribute = e.meshPerAttribute, this; } clone(e) { const t = super.clone(e); return t.meshPerAttribute = this.meshPerAttribute, t; } toJSON(e) { const t = super.toJSON(e); return t.isInstancedInterleavedBuffer = true, t.meshPerAttribute = this.meshPerAttribute, t; } }; Qx.prototype.isInstancedInterleavedBuffer = true; var eM = class { constructor(e, t, i, r, s) { this.buffer = e, this.type = t, this.itemSize = i, this.elementSize = r, this.count = s, this.version = 0; } set needsUpdate(e) { e === true && this.version++; } setBuffer(e) { return this.buffer = e, this; } setType(e, t) { return this.type = e, this.elementSize = t, this; } setItemSize(e) { return this.itemSize = e, this; } setCount(e) { return this.count = e, this; } }; eM.prototype.isGLBufferAttribute = true; var FN = class { constructor(e, t, i = 0, r = 1 / 0) { this.ray = new qr(e, t), this.near = i, this.far = r, this.camera = null, this.layers = new Cf(), this.params = { Mesh: {}, Line: { threshold: 1 }, LOD: {}, Points: { threshold: 1 }, Sprite: {} }; } set(e, t) { this.ray.set(e, t); } setFromCamera(e, t) { t && t.isPerspectiveCamera ? (this.ray.origin.setFromMatrixPosition(t.matrixWorld), this.ray.direction.set(e.x, e.y, 0.5).unproject(t).sub(this.ray.origin).normalize(), this.camera = t) : t && t.isOrthographicCamera ? (this.ray.origin.set(e.x, e.y, (t.near + t.far) / (t.near - t.far)).unproject(t), this.ray.direction.set(0, 0, -1).transformDirection(t.matrixWorld), this.camera = t) : console.error("THREE.Raycaster: Unsupported camera type: " + t.type); } intersectObject(e, t = false, i = []) { return _d(e, this, i, t), i.sort(Kg), i; } intersectObjects(e, t = false, i = []) { for (let r = 0, s = e.length; r < s; r++) _d(e[r], this, i, t); return i.sort(Kg), i; } }; function Kg(n, e) { return n.distance - e.distance; } function _d(n, e, t, i) { if (n.layers.test(e.layers) && n.raycast(e, t), i === true) { const r = n.children; for (let s = 0, o = r.length; s < o; s++) _d(r[s], e, t, true); } } var PN = class { constructor(e = 1, t = 0, i = 0) { return this.radius = e, this.phi = t, this.theta = i, this; } set(e, t, i) { return this.radius = e, this.phi = t, this.theta = i, this; } copy(e) { return this.radius = e.radius, this.phi = e.phi, this.theta = e.theta, this; } // restrict phi to be betwee EPS and PI-EPS makeSafe() { return this.phi = Math.max(1e-6, Math.min(Math.PI - 1e-6, this.phi)), this; } setFromVector3(e) { return this.setFromCartesianCoords(e.x, e.y, e.z); } setFromCartesianCoords(e, t, i) { return this.radius = Math.sqrt(e * e + t * t + i * i), this.radius === 0 ? (this.theta = 0, this.phi = 0) : (this.theta = Math.atan2(e, i), this.phi = Math.acos(gn(t / this.radius, -1, 1))), this; } clone() { return new this.constructor().copy(this); } }; var IN = class { constructor(e = 1, t = 0, i = 0) { return this.radius = e, this.theta = t, this.y = i, this; } set(e, t, i) { return this.radius = e, this.theta = t, this.y = i, this; } copy(e) { return this.radius = e.radius, this.theta = e.theta, this.y = e.y, this; } setFromVector3(e) { return this.setFromCartesianCoords(e.x, e.y, e.z); } setFromCartesianCoords(e, t, i) { return this.radius = Math.sqrt(e * e + i * i), this.theta = Math.atan2(e, i), this.y = t, this; } clone() { return new this.constructor().copy(this); } }; var qg = new Re(); var oa = class { constructor(e = new Re(1 / 0, 1 / 0), t = new Re(-1 / 0, -1 / 0)) { this.min = e, this.max = t; } set(e, t) { return this.min.copy(e), this.max.copy(t), this; } setFromPoints(e) { this.makeEmpty(); for (let t = 0, i = e.length; t < i; t++) this.expandByPoint(e[t]); return this; } setFromCenterAndSize(e, t) { const i = qg.copy(t).multiplyScalar(0.5); return this.min.copy(e).sub(i), this.max.copy(e).add(i), this; } clone() { return new this.constructor().copy(this); } copy(e) { return this.min.copy(e.min), this.max.copy(e.max), this; } makeEmpty() { return this.min.x = this.min.y = 1 / 0, this.max.x = this.max.y = -1 / 0, this; } isEmpty() { return this.max.x < this.min.x || this.max.y < this.min.y; } getCenter(e) { return this.isEmpty() ? e.set(0, 0) : e.addVectors(this.min, this.max).multiplyScalar(0.5); } getSize(e) { return this.isEmpty() ? e.set(0, 0) : e.subVectors(this.max, this.min); } expandByPoint(e) { return this.min.min(e), this.max.max(e), this; } expandByVector(e) { return this.min.sub(e), this.max.add(e), this; } expandByScalar(e) { return this.min.addScalar(-e), this.max.addScalar(e), this; } containsPoint(e) { return !(e.x < this.min.x || e.x > this.max.x || e.y < this.min.y || e.y > this.max.y); } containsBox(e) { return this.min.x <= e.min.x && e.max.x <= this.max.x && this.min.y <= e.min.y && e.max.y <= this.max.y; } getParameter(e, t) { return t.set( (e.x - this.min.x) / (this.max.x - this.min.x), (e.y - this.min.y) / (this.max.y - this.min.y) ); } intersectsBox(e) { return !(e.max.x < this.min.x || e.min.x > this.max.x || e.max.y < this.min.y || e.min.y > this.max.y); } clampPoint(e, t) { return t.copy(e).clamp(this.min, this.max); } distanceToPoint(e) { return qg.copy(e).clamp(this.min, this.max).sub(e).length(); } intersect(e) { return this.min.max(e.min), this.max.min(e.max), this; } union(e) { return this.min.min(e.min), this.max.max(e.max), this; } translate(e) { return this.min.add(e), this.max.add(e), this; } equals(e) { return e.min.equals(this.min) && e.max.equals(this.max); } }; oa.prototype.isBox2 = true; var Qg = new q(); var dc = new q(); var tM = class { constructor(e = new q(), t = new q()) { this.start = e, this.end = t; } set(e, t) { return this.start.copy(e), this.end.copy(t), this; } copy(e) { return this.start.copy(e.start), this.end.copy(e.end), this; } getCenter(e) { return e.addVectors(this.start, this.end).multiplyScalar(0.5); } delta(e) { return e.subVectors(this.end, this.start); } distanceSq() { return this.start.distanceToSquared(this.end); } distance() { return this.start.distanceTo(this.end); } at(e, t) { return this.delta(t).multiplyScalar(e).add(this.start); } closestPointToPointParameter(e, t) { Qg.subVectors(e, this.start), dc.subVectors(this.end, this.start); const i = dc.dot(dc); let s = dc.dot(Qg) / i; return t && (s = gn(s, 0, 1)), s; } closestPointToPoint(e, t, i) { const r = this.closestPointToPointParameter(e, t); return this.delta(i).multiplyScalar(r).add(this.start); } applyMatrix4(e) { return this.start.applyMatrix4(e), this.end.applyMatrix4(e), this; } equals(e) { return e.start.equals(this.start) && e.end.equals(this.end); } clone() { return new this.constructor().copy(this); } }; var nM = class extends ut { constructor(e) { super(), this.material = e, this.render = function() { }, this.hasPositions = false, this.hasNormals = false, this.hasColors = false, this.hasUvs = false, this.positionArray = null, this.normalArray = null, this.colorArray = null, this.uvArray = null, this.count = 0; } }; nM.prototype.isImmediateRenderObject = true; var ev = new q(); var ON = class extends ut { constructor(e, t) { super(), this.light = e, this.light.updateMatrixWorld(), this.matrix = e.matrixWorld, this.matrixAutoUpdate = false, this.color = t; const i = new Ke(), r = [ 0, 0, 0, 0, 0, 1, 0, 0, 0, 1, 0, 1, 0, 0, 0, -1, 0, 1, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, -1, 1 ]; for (let o = 0, a = 1, c = 32; o < c; o++, a++) { const l = o / c * Math.PI * 2, d = a / c * Math.PI * 2; r.push( Math.cos(l), Math.sin(l), 1, Math.cos(d), Math.sin(d), 1 ); } i.setAttribute("position", new He(r, 3)); const s = new an({ fog: false, toneMapped: false }); this.cone = new Rn(i, s), this.add(this.cone), this.update(); } dispose() { this.cone.geometry.dispose(), this.cone.material.dispose(); } update() { this.light.updateMatrixWorld(); const e = this.light.distance ? this.light.distance : 1e3, t = e * Math.tan(this.light.angle); this.cone.scale.set(t, t, e), ev.setFromMatrixPosition(this.light.target.matrixWorld), this.cone.lookAt(ev), this.color !== void 0 ? this.cone.material.color.set(this.color) : this.cone.material.color.copy(this.light.color); } }; var Sr = new q(); var fc = new Xe(); var Sh = new Xe(); var iM = class extends Rn { constructor(e) { const t = rM(e), i = new Ke(), r = [], s = [], o = new Ue(0, 0, 1), a = new Ue(0, 1, 0); for (let l = 0; l < t.length; l++) { const d = t[l]; d.parent && d.parent.isBone && (r.push(0, 0, 0), r.push(0, 0, 0), s.push(o.r, o.g, o.b), s.push(a.r, a.g, a.b)); } i.setAttribute("position", new He(r, 3)), i.setAttribute("color", new He(s, 3)); const c = new an({ vertexColors: true, depthTest: false, depthWrite: false, toneMapped: false, transparent: true }); super(i, c), this.type = "SkeletonHelper", this.isSkeletonHelper = true, this.root = e, this.bones = t, this.matrix = e.matrixWorld, this.matrixAutoUpdate = false; } updateMatrixWorld(e) { const t = this.bones, i = this.geometry, r = i.getAttribute("position"); Sh.copy(this.root.matrixWorld).invert(); for (let s = 0, o = 0; s < t.length; s++) { const a = t[s]; a.parent && a.parent.isBone && (fc.multiplyMatrices(Sh, a.matrixWorld), Sr.setFromMatrixPosition(fc), r.setXYZ(o, Sr.x, Sr.y, Sr.z), fc.multiplyMatrices(Sh, a.parent.matrixWorld), Sr.setFromMatrixPosition(fc), r.setXYZ(o + 1, Sr.x, Sr.y, Sr.z), o += 2); } i.getAttribute("position").needsUpdate = true, super.updateMatrixWorld(e); } }; function rM(n) { const e = []; n && n.isBone && e.push(n); for (let t = 0; t < n.children.length; t++) e.push.apply(e, rM(n.children[t])); return e; } var DN = class extends Xt { constructor(e, t, i) { const r = new Ps(t, 4, 2), s = new In({ wireframe: true, fog: false, toneMapped: false }); super(r, s), this.light = e, this.light.updateMatrixWorld(), this.color = i, this.type = "PointLightHelper", this.matrix = this.light.matrixWorld, this.matrixAutoUpdate = false, this.update(); } dispose() { this.geometry.dispose(), this.material.dispose(); } update() { this.color !== void 0 ? this.material.color.set(this.color) : this.material.color.copy(this.light.color); } }; var NN = new q(); var tv = new Ue(); var nv = new Ue(); var BN = class extends ut { constructor(e, t, i) { super(), this.light = e, this.light.updateMatrixWorld(), this.matrix = e.matrixWorld, this.matrixAutoUpdate = false, this.color = i; const r = new Rs(t); r.rotateY(Math.PI * 0.5), this.material = new In({ wireframe: true, fog: false, toneMapped: false }), this.color === void 0 && (this.material.vertexColors = true); const s = r.getAttribute("position"), o = new Float32Array(s.count * 3); r.setAttribute("color", new ot(o, 3)), this.add(new Xt(r, this.material)), this.update(); } dispose() { this.children[0].geometry.dispose(), this.children[0].material.dispose(); } update() { const e = this.children[0]; if (this.color !== void 0) this.material.color.set(this.color); else { const t = e.geometry.getAttribute("color"); tv.copy(this.light.color), nv.copy(this.light.groundColor); for (let i = 0, r = t.count; i < r; i++) { const s = i < r / 2 ? tv : nv; t.setXYZ(i, s.r, s.g, s.b); } t.needsUpdate = true; } e.lookAt(NN.setFromMatrixPosition(this.light.matrixWorld).negate()); } }; var sM = class extends Rn { constructor(e = 10, t = 10, i = 4473924, r = 8947848) { i = new Ue(i), r = new Ue(r); const s = t / 2, o = e / t, a = e / 2, c = [], l = []; for (let f = 0, g = 0, p = -a; f <= t; f++, p += o) { c.push(-a, 0, p, a, 0, p), c.push(p, 0, -a, p, 0, a); const u = f === s ? i : r; u.toArray(l, g), g += 3, u.toArray(l, g), g += 3, u.toArray(l, g), g += 3, u.toArray(l, g), g += 3; } const d = new Ke(); d.setAttribute("position", new He(c, 3)), d.setAttribute("color", new He(l, 3)); const h6 = new an({ vertexColors: true, toneMapped: false }); super(d, h6), this.type = "GridHelper"; } }; var UN = class extends Rn { constructor(e = 10, t = 16, i = 8, r = 64, s = 4473924, o = 8947848) { s = new Ue(s), o = new Ue(o); const a = [], c = []; for (let h6 = 0; h6 <= t; h6++) { const f = h6 / t * (Math.PI * 2), g = Math.sin(f) * e, p = Math.cos(f) * e; a.push(0, 0, 0), a.push(g, 0, p); const u = h6 & 1 ? s : o; c.push(u.r, u.g, u.b), c.push(u.r, u.g, u.b); } for (let h6 = 0; h6 <= i; h6++) { const f = h6 & 1 ? s : o, g = e - e / i * h6; for (let p = 0; p < r; p++) { let u = p / r * (Math.PI * 2), y = Math.sin(u) * g, v = Math.cos(u) * g; a.push(y, 0, v), c.push(f.r, f.g, f.b), u = (p + 1) / r * (Math.PI * 2), y = Math.sin(u) * g, v = Math.cos(u) * g, a.push(y, 0, v), c.push(f.r, f.g, f.b); } } const l = new Ke(); l.setAttribute("position", new He(a, 3)), l.setAttribute("color", new He(c, 3)); const d = new an({ vertexColors: true, toneMapped: false }); super(l, d), this.type = "PolarGridHelper"; } }; var iv = new q(); var pc = new q(); var rv = new q(); var zN = class extends ut { constructor(e, t, i) { super(), this.light = e, this.light.updateMatrixWorld(), this.matrix = e.matrixWorld, this.matrixAutoUpdate = false, this.color = i, t === void 0 && (t = 1); let r = new Ke(); r.setAttribute("position", new He([ -t, t, 0, t, t, 0, t, -t, 0, -t, -t, 0, -t, t, 0 ], 3)); const s = new an({ fog: false, toneMapped: false }); this.lightPlane = new Oi(r, s), this.add(this.lightPlane), r = new Ke(), r.setAttribute("position", new He([0, 0, 0, 0, 0, 1], 3)), this.targetLine = new Oi(r, s), this.add(this.targetLine), this.update(); } dispose() { this.lightPlane.geometry.dispose(), this.lightPlane.material.dispose(), this.targetLine.geometry.dispose(), this.targetLine.material.dispose(); } update() { iv.setFromMatrixPosition(this.light.matrixWorld), pc.setFromMatrixPosition(this.light.target.matrixWorld), rv.subVectors(pc, iv), this.lightPlane.lookAt(pc), this.color !== void 0 ? (this.lightPlane.material.color.set(this.color), this.targetLine.material.color.set(this.color)) : (this.lightPlane.material.color.copy(this.light.color), this.targetLine.material.color.copy(this.light.color)), this.targetLine.lookAt(pc), this.targetLine.scale.z = rv.length(); } }; var mc = new q(); var Bt = new hl(); var VN = class extends Rn { constructor(e) { const t = new Ke(), i = new an({ color: 16777215, vertexColors: true, toneMapped: false }), r = [], s = [], o = {}, a = new Ue(16755200), c = new Ue(16711680), l = new Ue(43775), d = new Ue(16777215), h6 = new Ue(3355443); f("n1", "n2", a), f("n2", "n4", a), f("n4", "n3", a), f("n3", "n1", a), f("f1", "f2", a), f("f2", "f4", a), f("f4", "f3", a), f("f3", "f1", a), f("n1", "f1", a), f("n2", "f2", a), f("n3", "f3", a), f("n4", "f4", a), f("p", "n1", c), f("p", "n2", c), f("p", "n3", c), f("p", "n4", c), f("u1", "u2", l), f("u2", "u3", l), f("u3", "u1", l), f("c", "t", d), f("p", "c", h6), f("cn1", "cn2", h6), f("cn3", "cn4", h6), f("cf1", "cf2", h6), f("cf3", "cf4", h6); function f(p, u, y) { g(p, y), g(u, y); } function g(p, u) { r.push(0, 0, 0), s.push(u.r, u.g, u.b), o[p] === void 0 && (o[p] = []), o[p].push(r.length / 3 - 1); } t.setAttribute("position", new He(r, 3)), t.setAttribute("color", new He(s, 3)), super(t, i), this.type = "CameraHelper", this.camera = e, this.camera.updateProjectionMatrix && this.camera.updateProjectionMatrix(), this.matrix = e.matrixWorld, this.matrixAutoUpdate = false, this.pointMap = o, this.update(); } update() { const e = this.geometry, t = this.pointMap, i = 1, r = 1; Bt.projectionMatrixInverse.copy(this.camera.projectionMatrixInverse), Ht("c", t, e, Bt, 0, 0, -1), Ht("t", t, e, Bt, 0, 0, 1), Ht("n1", t, e, Bt, -i, -r, -1), Ht("n2", t, e, Bt, i, -r, -1), Ht("n3", t, e, Bt, -i, r, -1), Ht("n4", t, e, Bt, i, r, -1), Ht("f1", t, e, Bt, -i, -r, 1), Ht("f2", t, e, Bt, i, -r, 1), Ht("f3", t, e, Bt, -i, r, 1), Ht("f4", t, e, Bt, i, r, 1), Ht("u1", t, e, Bt, i * 0.7, r * 1.1, -1), Ht("u2", t, e, Bt, -i * 0.7, r * 1.1, -1), Ht("u3", t, e, Bt, 0, r * 2, -1), Ht("cf1", t, e, Bt, -i, 0, 1), Ht("cf2", t, e, Bt, i, 0, 1), Ht("cf3", t, e, Bt, 0, -r, 1), Ht("cf4", t, e, Bt, 0, r, 1), Ht("cn1", t, e, Bt, -i, 0, -1), Ht("cn2", t, e, Bt, i, 0, -1), Ht("cn3", t, e, Bt, 0, -r, -1), Ht("cn4", t, e, Bt, 0, r, -1), e.getAttribute("position").needsUpdate = true; } dispose() { this.geometry.dispose(), this.material.dispose(); } }; function Ht(n, e, t, i, r, s, o) { mc.set(r, s, o).unproject(i); const a = e[n]; if (a !== void 0) { const c = t.getAttribute("position"); for (let l = 0, d = a.length; l < d; l++) c.setXYZ(a[l], mc.x, mc.y, mc.z); } } var gc = new Nn(); var oM = class extends Rn { constructor(e, t = 16776960) { const i = new Uint16Array([0, 1, 1, 2, 2, 3, 3, 0, 4, 5, 5, 6, 6, 7, 7, 4, 0, 4, 1, 5, 2, 6, 3, 7]), r = new Float32Array(8 * 3), s = new Ke(); s.setIndex(new ot(i, 1)), s.setAttribute("position", new ot(r, 3)), super(s, new an({ color: t, toneMapped: false })), this.object = e, this.type = "BoxHelper", this.matrixAutoUpdate = false, this.update(); } update(e) { if (e !== void 0 && console.warn("THREE.BoxHelper: .update() has no longer arguments."), this.object !== void 0 && gc.setFromObject(this.object), gc.isEmpty()) return; const t = gc.min, i = gc.max, r = this.geometry.attributes.position, s = r.array; s[0] = i.x, s[1] = i.y, s[2] = i.z, s[3] = t.x, s[4] = i.y, s[5] = i.z, s[6] = t.x, s[7] = t.y, s[8] = i.z, s[9] = i.x, s[10] = t.y, s[11] = i.z, s[12] = i.x, s[13] = i.y, s[14] = t.z, s[15] = t.x, s[16] = i.y, s[17] = t.z, s[18] = t.x, s[19] = t.y, s[20] = t.z, s[21] = i.x, s[22] = t.y, s[23] = t.z, r.needsUpdate = true, this.geometry.computeBoundingSphere(); } setFromObject(e) { return this.object = e, this.update(), this; } copy(e) { return Rn.prototype.copy.call(this, e), this.object = e.object, this; } }; var kN = class extends Rn { constructor(e, t = 16776960) { const i = new Uint16Array([0, 1, 1, 2, 2, 3, 3, 0, 4, 5, 5, 6, 6, 7, 7, 4, 0, 4, 1, 5, 2, 6, 3, 7]), r = [1, 1, 1, -1, 1, 1, -1, -1, 1, 1, -1, 1, 1, 1, -1, -1, 1, -1, -1, -1, -1, 1, -1, -1], s = new Ke(); s.setIndex(new ot(i, 1)), s.setAttribute("position", new He(r, 3)), super(s, new an({ color: t, toneMapped: false })), this.box = e, this.type = "Box3Helper", this.geometry.computeBoundingSphere(); } updateMatrixWorld(e) { const t = this.box; t.isEmpty() || (t.getCenter(this.position), t.getSize(this.scale), this.scale.multiplyScalar(0.5), super.updateMatrixWorld(e)); } }; var GN = class extends Oi { constructor(e, t = 1, i = 16776960) { const r = i, s = [1, -1, 1, -1, 1, 1, -1, -1, 1, 1, 1, 1, -1, 1, 1, -1, -1, 1, 1, -1, 1, 1, 1, 1, 0, 0, 1, 0, 0, 0], o = new Ke(); o.setAttribute("position", new He(s, 3)), o.computeBoundingSphere(), super(o, new an({ color: r, toneMapped: false })), this.type = "PlaneHelper", this.plane = e, this.size = t; const a = [1, 1, 1, -1, 1, 1, -1, -1, 1, 1, 1, 1, -1, -1, 1, 1, -1, 1], c = new Ke(); c.setAttribute("position", new He(a, 3)), c.computeBoundingSphere(), this.add(new Xt(c, new In({ color: r, opacity: 0.2, transparent: true, depthWrite: false, toneMapped: false }))); } updateMatrixWorld(e) { let t = -this.plane.constant; Math.abs(t) < 1e-8 && (t = 1e-8), this.scale.set(0.5 * this.size, 0.5 * this.size, t), this.children[0].material.side = t < 0 ? jt : Hr, this.lookAt(this.plane.normal), super.updateMatrixWorld(e); } }; var sv = new q(); var vc; var _h; var HN = class extends ut { // dir is assumed to be normalized constructor(e = new q(0, 0, 1), t = new q(0, 0, 0), i = 1, r = 16776960, s = i * 0.2, o = s * 0.2) { super(), this.type = "ArrowHelper", vc === void 0 && (vc = new Ke(), vc.setAttribute("position", new He([0, 0, 0, 0, 1, 0], 3)), _h = new $r(0, 0.5, 1, 5, 1), _h.translate(0, -0.5, 0)), this.position.copy(t), this.line = new Oi(vc, new an({ color: r, toneMapped: false })), this.line.matrixAutoUpdate = false, this.add(this.line), this.cone = new Xt(_h, new In({ color: r, toneMapped: false })), this.cone.matrixAutoUpdate = false, this.add(this.cone), this.setDirection(e), this.setLength(i, s, o); } setDirection(e) { if (e.y > 0.99999) this.quaternion.set(0, 0, 0, 1); else if (e.y < -0.99999) this.quaternion.set(1, 0, 0, 0); else { sv.set(e.z, 0, -e.x).normalize(); const t = Math.acos(e.y); this.quaternion.setFromAxisAngle(sv, t); } } setLength(e, t = e * 0.2, i = t * 0.2) { this.line.scale.set(1, Math.max(1e-4, e - t), 1), this.line.updateMatrix(), this.cone.scale.set(i, t, i), this.cone.position.y = e, this.cone.updateMatrix(); } setColor(e) { this.line.material.color.set(e), this.cone.material.color.set(e); } copy(e) { return super.copy(e, false), this.line.copy(e.line), this.cone.copy(e.cone), this; } }; var aM = class extends Rn { constructor(e = 1) { const t = [ 0, 0, 0, e, 0, 0, 0, 0, 0, 0, e, 0, 0, 0, 0, 0, 0, e ], i = [ 1, 0, 0, 1, 0.6, 0, 0, 1, 0, 0.6, 1, 0, 0, 0, 1, 0, 0.6, 1 ], r = new Ke(); r.setAttribute("position", new He(t, 3)), r.setAttribute("color", new He(i, 3)); const s = new an({ vertexColors: true, toneMapped: false }); super(r, s), this.type = "AxesHelper"; } setColors(e, t, i) { const r = new Ue(), s = this.geometry.attributes.color.array; return r.set(e), r.toArray(s, 0), r.toArray(s, 3), r.set(t), r.toArray(s, 6), r.toArray(s, 9), r.set(i), r.toArray(s, 12), r.toArray(s, 15), this.geometry.attributes.color.needsUpdate = true, this; } dispose() { this.geometry.dispose(), this.material.dispose(); } }; var lM = new Float32Array(1); var WN = new Int32Array(lM.buffer); var jN = class { // Converts float32 to float16 (stored as uint16 value). static toHalfFloat(e) { lM[0] = e; const t = WN[0]; let i = t >> 16 & 32768, r = t >> 12 & 2047; const s = t >> 23 & 255; return s < 103 ? i : s > 142 ? (i |= 31744, i |= (s == 255 ? 0 : 1) && t & 8388607, i) : s < 113 ? (r |= 2048, i |= (r >> 114 - s) + (r >> 113 - s & 1), i) : (i |= s - 112 << 10 | r >> 1, i += r & 1, i); } }; var bo = 4; var Nr = 8; var Mi = Math.pow(2, Nr); var cM = [0.125, 0.215, 0.35, 0.446, 0.526, 0.582]; var uM = Nr - bo + 1 + cM.length; var lo = 20; var Ti = { [Cn]: 0, [Cs]: 1, [mu]: 2, [Af]: 3, [Sf]: 4, [_f]: 5, [pu]: 6 }; var hs = new In({ side: jt, depthWrite: false, depthTest: false }); var $N = new Xt(new sr(), hs); var Th = new sa(); var { _lodPlanes: Ma, _sizeLods: ov, _sigmas: yc } = YN(); var av = new Ue(); var Eh = null; var ds = (1 + Math.sqrt(5)) / 2; var co = 1 / ds; var lv = [ new q(1, 1, 1), new q(-1, 1, 1), new q(1, 1, -1), new q(-1, 1, -1), new q(0, ds, co), new q(0, ds, -co), new q(co, 0, ds), new q(-co, 0, ds), new q(ds, co, 0), new q(-ds, co, 0) ]; function cv(n) { const e = Math.max(n.r, n.g, n.b), t = Math.min(Math.max(Math.ceil(Math.log2(e)), -128), 127); return n.multiplyScalar(Math.pow(2, -t)), (t + 128) / 255; } var ZN = class { constructor(e) { this._renderer = e, this._pingPongRenderTarget = null, this._blurMaterial = JN(lo), this._equirectShader = null, this._cubemapShader = null, this._compileMaterial(this._blurMaterial); } /** * Generates a PMREM from a supplied Scene, which can be faster than using an * image if networking bandwidth is low. Optional sigma specifies a blur radius * in radians to be applied to the scene before PMREM generation. Optional near * and far planes ensure the scene is rendered in its entirety (the cubeCamera * is placed at the origin). */ fromScene(e, t = 0, i = 0.1, r = 100) { Eh = this._renderer.getRenderTarget(); const s = this._allocateTargets(); return this._sceneToCubeUV(e, i, r, s), t > 0 && this._blur(s, 0, 0, t), this._applyPMREM(s), this._cleanup(s), s; } /** * Generates a PMREM from an equirectangular texture, which can be either LDR * (RGBFormat) or HDR (RGBEFormat). The ideal input image size is 1k (1024 x 512), * as this matches best with the 256 x 256 cubemap output. */ fromEquirectangular(e) { return this._fromTexture(e); } /** * Generates a PMREM from an cubemap texture, which can be either LDR * (RGBFormat) or HDR (RGBEFormat). The ideal input cube size is 256 x 256, * as this matches best with the 256 x 256 cubemap output. */ fromCubemap(e) { return this._fromTexture(e); } /** * Pre-compiles the cubemap shader. You can get faster start-up by invoking this method during * your texture's network fetch for increased concurrency. */ compileCubemapShader() { this._cubemapShader === null && (this._cubemapShader = dv(), this._compileMaterial(this._cubemapShader)); } /** * Pre-compiles the equirectangular shader. You can get faster start-up by invoking this method during * your texture's network fetch for increased concurrency. */ compileEquirectangularShader() { this._equirectShader === null && (this._equirectShader = hv(), this._compileMaterial(this._equirectShader)); } /** * Disposes of the PMREMGenerator's internal memory. Note that PMREMGenerator is a static class, * so you should not need more than one PMREMGenerator object. If you do, calling dispose() on * one of them will cause any others to also become unusable. */ dispose() { this._blurMaterial.dispose(), this._cubemapShader !== null && this._cubemapShader.dispose(), this._equirectShader !== null && this._equirectShader.dispose(); for (let e = 0; e < Ma.length; e++) Ma[e].dispose(); } // private interface _cleanup(e) { this._pingPongRenderTarget.dispose(), this._renderer.setRenderTarget(Eh), e.scissorTest = false, bc(e, 0, 0, e.width, e.height); } _fromTexture(e) { Eh = this._renderer.getRenderTarget(); const t = this._allocateTargets(e); return this._textureToCubeUV(e, t), this._applyPMREM(t), this._cleanup(t), t; } _allocateTargets(e) { const t = { magFilter: $t, minFilter: $t, generateMipmaps: false, type: Ts, format: ob, encoding: XN(e) ? e.encoding : mu, depthBuffer: false }, i = uv(t); return i.depthBuffer = !e, this._pingPongRenderTarget = uv(t), i; } _compileMaterial(e) { const t = new Xt(Ma[0], e); this._renderer.compile(t, Th); } _sceneToCubeUV(e, t, i, r) { const a = new nn(90, 1, t, i), c = [1, -1, 1, 1, 1, 1], l = [1, 1, 1, -1, -1, -1], d = this._renderer, h6 = d.autoClear, f = d.outputEncoding, g = d.toneMapping; d.getClearColor(av), d.toneMapping = Ir, d.outputEncoding = Cn, d.autoClear = false; let p = false; const u = e.background; if (u) { if (u.isColor) { hs.color.copy(u).convertSRGBToLinear(), e.background = null; const y = cv(hs.color); hs.opacity = y, p = true; } } else { hs.color.copy(av).convertSRGBToLinear(); const y = cv(hs.color); hs.opacity = y, p = true; } for (let y = 0; y < 6; y++) { const v = y % 3; v == 0 ? (a.up.set(0, c[y], 0), a.lookAt(l[y], 0, 0)) : v == 1 ? (a.up.set(0, 0, c[y]), a.lookAt(0, l[y], 0)) : (a.up.set(0, c[y], 0), a.lookAt(0, 0, l[y])), bc( r, v * Mi, y > 2 ? Mi : 0, Mi, Mi ), d.setRenderTarget(r), p && d.render($N, a), d.render(e, a); } d.toneMapping = g, d.outputEncoding = f, d.autoClear = h6; } _textureToCubeUV(e, t) { const i = this._renderer; e.isCubeTexture ? this._cubemapShader == null && (this._cubemapShader = dv()) : this._equirectShader == null && (this._equirectShader = hv()); const r = e.isCubeTexture ? this._cubemapShader : this._equirectShader, s = new Xt(Ma[0], r), o = r.uniforms; o.envMap.value = e, e.isCubeTexture || o.texelSize.value.set(1 / e.image.width, 1 / e.image.height), o.inputEncoding.value = Ti[e.encoding], o.outputEncoding.value = Ti[t.texture.encoding], bc(t, 0, 0, 3 * Mi, 2 * Mi), i.setRenderTarget(t), i.render(s, Th); } _applyPMREM(e) { const t = this._renderer, i = t.autoClear; t.autoClear = false; for (let r = 1; r < uM; r++) { const s = Math.sqrt(yc[r] * yc[r] - yc[r - 1] * yc[r - 1]), o = lv[(r - 1) % lv.length]; this._blur(e, r - 1, r, s, o); } t.autoClear = i; } /** * This is a two-pass Gaussian blur for a cubemap. Normally this is done * vertically and horizontally, but this breaks down on a cube. Here we apply * the blur latitudinally (around the poles), and then longitudinally (towards * the poles) to approximate the orthogonally-separable blur. It is least * accurate at the poles, but still does a decent job. */ _blur(e, t, i, r, s) { const o = this._pingPongRenderTarget; this._halfBlur( e, o, t, i, r, "latitudinal", s ), this._halfBlur( o, e, i, i, r, "longitudinal", s ); } _halfBlur(e, t, i, r, s, o, a) { const c = this._renderer, l = this._blurMaterial; o !== "latitudinal" && o !== "longitudinal" && console.error( "blur direction must be either latitudinal or longitudinal!" ); const d = 3, h6 = new Xt(Ma[r], l), f = l.uniforms, g = ov[i] - 1, p = isFinite(s) ? Math.PI / (2 * g) : 2 * Math.PI / (2 * lo - 1), u = s / p, y = isFinite(s) ? 1 + Math.floor(d * u) : lo; y > lo && console.warn(`sigmaRadians, ${s}, is too large and will clip, as it requested ${y} samples when the maximum is set to ${lo}`); const v = []; let m = 0; for (let M = 0; M < lo; ++M) { const R = M / u, L = Math.exp(-R * R / 2); v.push(L), M == 0 ? m += L : M < y && (m += 2 * L); } for (let M = 0; M < v.length; M++) v[M] = v[M] / m; f.envMap.value = e.texture, f.samples.value = y, f.weights.value = v, f.latitudinal.value = o === "latitudinal", a && (f.poleAxis.value = a), f.dTheta.value = p, f.mipInt.value = Nr - i, f.inputEncoding.value = Ti[e.texture.encoding], f.outputEncoding.value = Ti[e.texture.encoding]; const x = ov[r], w = 3 * Math.max(0, Mi - 2 * x), A = (r === 0 ? 0 : 2 * Mi) + 2 * x * (r > Nr - bo ? r - Nr + bo : 0); bc(t, w, A, 3 * x, 2 * x), c.setRenderTarget(t), c.render(h6, Th); } }; function XN(n) { return n === void 0 || n.type !== Ts ? false : n.encoding === Cn || n.encoding === Cs || n.encoding === pu; } function YN() { const n = [], e = [], t = []; let i = Nr; for (let r = 0; r < uM; r++) { const s = Math.pow(2, i); e.push(s); let o = 1 / s; r > Nr - bo ? o = cM[r - Nr + bo - 1] : r == 0 && (o = 0), t.push(o); const a = 1 / (s - 1), c = -a / 2, l = 1 + a / 2, d = [c, c, l, c, l, l, c, c, l, l, c, l], h6 = 6, f = 6, g = 3, p = 2, u = 1, y = new Float32Array(g * f * h6), v = new Float32Array(p * f * h6), m = new Float32Array(u * f * h6); for (let w = 0; w < h6; w++) { const A = w % 3 * 2 / 3 - 1, M = w > 2 ? 0 : -1, R = [ A, M, 0, A + 2 / 3, M, 0, A + 2 / 3, M + 1, 0, A, M, 0, A + 2 / 3, M + 1, 0, A, M + 1, 0 ]; y.set(R, g * f * w), v.set(d, p * f * w); const L = [w, w, w, w, w, w]; m.set(L, u * f * w); } const x = new Ke(); x.setAttribute("position", new ot(y, g)), x.setAttribute("uv", new ot(v, p)), x.setAttribute("faceIndex", new ot(m, u)), n.push(x), i > bo && i--; } return { _lodPlanes: n, _sizeLods: e, _sigmas: t }; } function uv(n) { const e = new fi(3 * Mi, 3 * Mi, n); return e.texture.mapping = ea, e.texture.name = "PMREM.cubeUv", e.scissorTest = true, e; } function bc(n, e, t, i, r) { n.viewport.set(e, t, i, r), n.scissor.set(e, t, i, r); } function JN(n) { const e = new Float32Array(n), t = new q(0, 1, 0); return new ra({ name: "SphericalGaussianBlur", defines: { n }, uniforms: { envMap: { value: null }, samples: { value: 1 }, weights: { value: e }, latitudinal: { value: false }, dTheta: { value: 0 }, mipInt: { value: 0 }, poleAxis: { value: t }, inputEncoding: { value: Ti[Cn] }, outputEncoding: { value: Ti[Cn] } }, vertexShader: dp(), fragmentShader: ( /* glsl */ ` precision mediump float; precision mediump int; varying vec3 vOutputDirection; uniform sampler2D envMap; uniform int samples; uniform float weights[ n ]; uniform bool latitudinal; uniform float dTheta; uniform float mipInt; uniform vec3 poleAxis; ${fp()} #define ENVMAP_TYPE_CUBE_UV #include vec3 getSample( float theta, vec3 axis ) { float cosTheta = cos( theta ); // Rodrigues' axis-angle rotation vec3 sampleDirection = vOutputDirection * cosTheta + cross( axis, vOutputDirection ) * sin( theta ) + axis * dot( axis, vOutputDirection ) * ( 1.0 - cosTheta ); return bilinearCubeUV( envMap, sampleDirection, mipInt ); } void main() { vec3 axis = latitudinal ? poleAxis : cross( poleAxis, vOutputDirection ); if ( all( equal( axis, vec3( 0.0 ) ) ) ) { axis = vec3( vOutputDirection.z, 0.0, - vOutputDirection.x ); } axis = normalize( axis ); gl_FragColor = vec4( 0.0, 0.0, 0.0, 1.0 ); gl_FragColor.rgb += weights[ 0 ] * getSample( 0.0, axis ); for ( int i = 1; i < n; i++ ) { if ( i >= samples ) { break; } float theta = dTheta * float( i ); gl_FragColor.rgb += weights[ i ] * getSample( -1.0 * theta, axis ); gl_FragColor.rgb += weights[ i ] * getSample( theta, axis ); } gl_FragColor = linearToOutputTexel( gl_FragColor ); } ` ), blending: tr, depthTest: false, depthWrite: false }); } function hv() { const n = new Re(1, 1); return new ra({ name: "EquirectangularToCubeUV", uniforms: { envMap: { value: null }, texelSize: { value: n }, inputEncoding: { value: Ti[Cn] }, outputEncoding: { value: Ti[Cn] } }, vertexShader: dp(), fragmentShader: ( /* glsl */ ` precision mediump float; precision mediump int; varying vec3 vOutputDirection; uniform sampler2D envMap; uniform vec2 texelSize; ${fp()} #include void main() { gl_FragColor = vec4( 0.0, 0.0, 0.0, 1.0 ); vec3 outputDirection = normalize( vOutputDirection ); vec2 uv = equirectUv( outputDirection ); vec2 f = fract( uv / texelSize - 0.5 ); uv -= f * texelSize; vec3 tl = envMapTexelToLinear( texture2D ( envMap, uv ) ).rgb; uv.x += texelSize.x; vec3 tr = envMapTexelToLinear( texture2D ( envMap, uv ) ).rgb; uv.y += texelSize.y; vec3 br = envMapTexelToLinear( texture2D ( envMap, uv ) ).rgb; uv.x -= texelSize.x; vec3 bl = envMapTexelToLinear( texture2D ( envMap, uv ) ).rgb; vec3 tm = mix( tl, tr, f.x ); vec3 bm = mix( bl, br, f.x ); gl_FragColor.rgb = mix( tm, bm, f.y ); gl_FragColor = linearToOutputTexel( gl_FragColor ); } ` ), blending: tr, depthTest: false, depthWrite: false }); } function dv() { return new ra({ name: "CubemapToCubeUV", uniforms: { envMap: { value: null }, inputEncoding: { value: Ti[Cn] }, outputEncoding: { value: Ti[Cn] } }, vertexShader: dp(), fragmentShader: ( /* glsl */ ` precision mediump float; precision mediump int; varying vec3 vOutputDirection; uniform samplerCube envMap; ${fp()} void main() { gl_FragColor = vec4( 0.0, 0.0, 0.0, 1.0 ); gl_FragColor.rgb = envMapTexelToLinear( textureCube( envMap, vec3( - vOutputDirection.x, vOutputDirection.yz ) ) ).rgb; gl_FragColor = linearToOutputTexel( gl_FragColor ); } ` ), blending: tr, depthTest: false, depthWrite: false }); } function dp() { return ( /* glsl */ ` precision mediump float; precision mediump int; attribute vec3 position; attribute vec2 uv; attribute float faceIndex; varying vec3 vOutputDirection; // RH coordinate system; PMREM face-indexing convention vec3 getDirection( vec2 uv, float face ) { uv = 2.0 * uv - 1.0; vec3 direction = vec3( uv, 1.0 ); if ( face == 0.0 ) { direction = direction.zyx; // ( 1, v, u ) pos x } else if ( face == 1.0 ) { direction = direction.xzy; direction.xz *= -1.0; // ( -u, 1, -v ) pos y } else if ( face == 2.0 ) { direction.x *= -1.0; // ( -u, v, 1 ) pos z } else if ( face == 3.0 ) { direction = direction.zyx; direction.xz *= -1.0; // ( -1, v, -u ) neg x } else if ( face == 4.0 ) { direction = direction.xzy; direction.xy *= -1.0; // ( -u, -1, v ) neg y } else if ( face == 5.0 ) { direction.z *= -1.0; // ( u, v, -1 ) neg z } return direction; } void main() { vOutputDirection = getDirection( uv, faceIndex ); gl_Position = vec4( position, 1.0 ); } ` ); } function fp() { return ( /* glsl */ ` uniform int inputEncoding; uniform int outputEncoding; #include vec4 inputTexelToLinear( vec4 value ) { if ( inputEncoding == 0 ) { return value; } else if ( inputEncoding == 1 ) { return sRGBToLinear( value ); } else if ( inputEncoding == 2 ) { return RGBEToLinear( value ); } else if ( inputEncoding == 3 ) { return RGBMToLinear( value, 7.0 ); } else if ( inputEncoding == 4 ) { return RGBMToLinear( value, 16.0 ); } else if ( inputEncoding == 5 ) { return RGBDToLinear( value, 256.0 ); } else { return GammaToLinear( value, 2.2 ); } } vec4 linearToOutputTexel( vec4 value ) { if ( outputEncoding == 0 ) { return value; } else if ( outputEncoding == 1 ) { return LinearTosRGB( value ); } else if ( outputEncoding == 2 ) { return LinearToRGBE( value ); } else if ( outputEncoding == 3 ) { return LinearToRGBM( value, 7.0 ); } else if ( outputEncoding == 4 ) { return LinearToRGBM( value, 16.0 ); } else if ( outputEncoding == 5 ) { return LinearToRGBD( value, 256.0 ); } else { return LinearToGamma( value, 2.2 ); } } vec4 envMapTexelToLinear( vec4 color ) { return inputTexelToLinear( color ); } ` ); } var KN = 0; var qN = 1; var QN = 0; var eB = 1; var tB = 2; function nB(n) { return console.warn("THREE.MeshFaceMaterial has been removed. Use an Array instead."), n; } function iB(n = []) { return console.warn("THREE.MultiMaterial has been removed. Use an Array instead."), n.isMultiMaterial = true, n.materials = n, n.clone = function() { return n.slice(); }, n; } function rB(n, e) { return console.warn("THREE.PointCloud has been renamed to THREE.Points."), new ia(n, e); } function sB(n) { return console.warn("THREE.Particle has been renamed to THREE.Sprite."), new gl(n); } function oB(n, e) { return console.warn("THREE.ParticleSystem has been renamed to THREE.Points."), new ia(n, e); } function aB(n) { return console.warn("THREE.PointCloudMaterial has been renamed to THREE.PointsMaterial."), new es(n); } function lB(n) { return console.warn("THREE.ParticleBasicMaterial has been renamed to THREE.PointsMaterial."), new es(n); } function cB(n) { return console.warn("THREE.ParticleSystemMaterial has been renamed to THREE.PointsMaterial."), new es(n); } function uB(n, e, t) { return console.warn("THREE.Vertex has been removed. Use THREE.Vector3 instead."), new q(n, e, t); } function hB(n, e) { return console.warn("THREE.DynamicBufferAttribute has been removed. Use new THREE.BufferAttribute().setUsage( THREE.DynamicDrawUsage ) instead."), new ot(n, e).setUsage(Fo); } function dB(n, e) { return console.warn("THREE.Int8Attribute has been removed. Use new THREE.Int8BufferAttribute() instead."), new ix(n, e); } function fB(n, e) { return console.warn("THREE.Uint8Attribute has been removed. Use new THREE.Uint8BufferAttribute() instead."), new rx(n, e); } function pB(n, e) { return console.warn("THREE.Uint8ClampedAttribute has been removed. Use new THREE.Uint8ClampedBufferAttribute() instead."), new sx(n, e); } function mB(n, e) { return console.warn("THREE.Int16Attribute has been removed. Use new THREE.Int16BufferAttribute() instead."), new ox(n, e); } function gB(n, e) { return console.warn("THREE.Uint16Attribute has been removed. Use new THREE.Uint16BufferAttribute() instead."), new gu(n, e); } function vB(n, e) { return console.warn("THREE.Int32Attribute has been removed. Use new THREE.Int32BufferAttribute() instead."), new ax(n, e); } function yB(n, e) { return console.warn("THREE.Uint32Attribute has been removed. Use new THREE.Uint32BufferAttribute() instead."), new vu(n, e); } function bB(n, e) { return console.warn("THREE.Float32Attribute has been removed. Use new THREE.Float32BufferAttribute() instead."), new He(n, e); } function xB(n, e) { return console.warn("THREE.Float64Attribute has been removed. Use new THREE.Float64BufferAttribute() instead."), new cx(n, e); } jn.create = function(n, e) { return console.log("THREE.Curve.create() has been deprecated"), n.prototype = Object.create(jn.prototype), n.prototype.constructor = n, n.prototype.getPoint = e, n; }; Ja.prototype.fromPoints = function(n) { return console.warn("THREE.Path: .fromPoints() has been renamed to .setFromPoints()."), this.setFromPoints(n); }; function MB(n) { return console.warn("THREE.AxisHelper has been renamed to THREE.AxesHelper."), new aM(n); } function wB(n, e) { return console.warn("THREE.BoundingBoxHelper has been deprecated. Creating a THREE.BoxHelper instead."), new oM(n, e); } function AB(n, e) { return console.warn("THREE.EdgesHelper has been removed. Use THREE.EdgesGeometry instead."), new Rn(new Of(n.geometry), new an({ color: e !== void 0 ? e : 16777215 })); } sM.prototype.setColors = function() { console.error("THREE.GridHelper: setColors() has been deprecated, pass them in the constructor instead."); }; iM.prototype.update = function() { console.error("THREE.SkeletonHelper: update() no longer needs to be called."); }; function SB(n, e) { return console.warn("THREE.WireframeHelper has been removed. Use THREE.WireframeGeometry instead."), new Rn(new kf(n.geometry), new an({ color: e !== void 0 ? e : 16777215 })); } xn.prototype.extractUrlBase = function(n) { return console.warn("THREE.Loader: .extractUrlBase() has been deprecated. Use THREE.LoaderUtils.extractUrlBase() instead."), ir.extractUrlBase(n); }; xn.Handlers = { add: function() { console.error("THREE.Loader: Handlers.add() has been removed. Use LoadingManager.addHandler() instead."); }, get: function() { console.error("THREE.Loader: Handlers.get() has been removed. Use LoadingManager.getHandler() instead."); } }; function _B(n) { return console.warn("THREE.XHRLoader has been renamed to THREE.FileLoader."), new $n(n); } function TB(n) { return console.warn("THREE.BinaryTextureLoader has been renamed to THREE.DataTextureLoader."), new Bx(n); } oa.prototype.center = function(n) { return console.warn("THREE.Box2: .center() has been renamed to .getCenter()."), this.getCenter(n); }; oa.prototype.empty = function() { return console.warn("THREE.Box2: .empty() has been renamed to .isEmpty()."), this.isEmpty(); }; oa.prototype.isIntersectionBox = function(n) { return console.warn("THREE.Box2: .isIntersectionBox() has been renamed to .intersectsBox()."), this.intersectsBox(n); }; oa.prototype.size = function(n) { return console.warn("THREE.Box2: .size() has been renamed to .getSize()."), this.getSize(n); }; Nn.prototype.center = function(n) { return console.warn("THREE.Box3: .center() has been renamed to .getCenter()."), this.getCenter(n); }; Nn.prototype.empty = function() { return console.warn("THREE.Box3: .empty() has been renamed to .isEmpty()."), this.isEmpty(); }; Nn.prototype.isIntersectionBox = function(n) { return console.warn("THREE.Box3: .isIntersectionBox() has been renamed to .intersectsBox()."), this.intersectsBox(n); }; Nn.prototype.isIntersectionSphere = function(n) { return console.warn("THREE.Box3: .isIntersectionSphere() has been renamed to .intersectsSphere()."), this.intersectsSphere(n); }; Nn.prototype.size = function(n) { return console.warn("THREE.Box3: .size() has been renamed to .getSize()."), this.getSize(n); }; pr.prototype.empty = function() { return console.warn("THREE.Sphere: .empty() has been renamed to .isEmpty()."), this.isEmpty(); }; dl.prototype.setFromMatrix = function(n) { return console.warn("THREE.Frustum: .setFromMatrix() has been renamed to .setFromProjectionMatrix()."), this.setFromProjectionMatrix(n); }; tM.prototype.center = function(n) { return console.warn("THREE.Line3: .center() has been renamed to .getCenter()."), this.getCenter(n); }; rn.prototype.flattenToArrayOffset = function(n, e) { return console.warn("THREE.Matrix3: .flattenToArrayOffset() has been deprecated. Use .toArray() instead."), this.toArray(n, e); }; rn.prototype.multiplyVector3 = function(n) { return console.warn("THREE.Matrix3: .multiplyVector3() has been removed. Use vector.applyMatrix3( matrix ) instead."), n.applyMatrix3(this); }; rn.prototype.multiplyVector3Array = function() { console.error("THREE.Matrix3: .multiplyVector3Array() has been removed."); }; rn.prototype.applyToBufferAttribute = function(n) { return console.warn("THREE.Matrix3: .applyToBufferAttribute() has been removed. Use attribute.applyMatrix3( matrix ) instead."), n.applyMatrix3(this); }; rn.prototype.applyToVector3Array = function() { console.error("THREE.Matrix3: .applyToVector3Array() has been removed."); }; rn.prototype.getInverse = function(n) { return console.warn("THREE.Matrix3: .getInverse() has been removed. Use matrixInv.copy( matrix ).invert(); instead."), this.copy(n).invert(); }; Xe.prototype.extractPosition = function(n) { return console.warn("THREE.Matrix4: .extractPosition() has been renamed to .copyPosition()."), this.copyPosition(n); }; Xe.prototype.flattenToArrayOffset = function(n, e) { return console.warn("THREE.Matrix4: .flattenToArrayOffset() has been deprecated. Use .toArray() instead."), this.toArray(n, e); }; Xe.prototype.getPosition = function() { return console.warn("THREE.Matrix4: .getPosition() has been removed. Use Vector3.setFromMatrixPosition( matrix ) instead."), new q().setFromMatrixColumn(this, 3); }; Xe.prototype.setRotationFromQuaternion = function(n) { return console.warn("THREE.Matrix4: .setRotationFromQuaternion() has been renamed to .makeRotationFromQuaternion()."), this.makeRotationFromQuaternion(n); }; Xe.prototype.multiplyToArray = function() { console.warn("THREE.Matrix4: .multiplyToArray() has been removed."); }; Xe.prototype.multiplyVector3 = function(n) { return console.warn("THREE.Matrix4: .multiplyVector3() has been removed. Use vector.applyMatrix4( matrix ) instead."), n.applyMatrix4(this); }; Xe.prototype.multiplyVector4 = function(n) { return console.warn("THREE.Matrix4: .multiplyVector4() has been removed. Use vector.applyMatrix4( matrix ) instead."), n.applyMatrix4(this); }; Xe.prototype.multiplyVector3Array = function() { console.error("THREE.Matrix4: .multiplyVector3Array() has been removed."); }; Xe.prototype.rotateAxis = function(n) { console.warn("THREE.Matrix4: .rotateAxis() has been removed. Use Vector3.transformDirection( matrix ) instead."), n.transformDirection(this); }; Xe.prototype.crossVector = function(n) { return console.warn("THREE.Matrix4: .crossVector() has been removed. Use vector.applyMatrix4( matrix ) instead."), n.applyMatrix4(this); }; Xe.prototype.translate = function() { console.error("THREE.Matrix4: .translate() has been removed."); }; Xe.prototype.rotateX = function() { console.error("THREE.Matrix4: .rotateX() has been removed."); }; Xe.prototype.rotateY = function() { console.error("THREE.Matrix4: .rotateY() has been removed."); }; Xe.prototype.rotateZ = function() { console.error("THREE.Matrix4: .rotateZ() has been removed."); }; Xe.prototype.rotateByAxis = function() { console.error("THREE.Matrix4: .rotateByAxis() has been removed."); }; Xe.prototype.applyToBufferAttribute = function(n) { return console.warn("THREE.Matrix4: .applyToBufferAttribute() has been removed. Use attribute.applyMatrix4( matrix ) instead."), n.applyMatrix4(this); }; Xe.prototype.applyToVector3Array = function() { console.error("THREE.Matrix4: .applyToVector3Array() has been removed."); }; Xe.prototype.makeFrustum = function(n, e, t, i, r, s) { return console.warn("THREE.Matrix4: .makeFrustum() has been removed. Use .makePerspective( left, right, top, bottom, near, far ) instead."), this.makePerspective(n, e, i, t, r, s); }; Xe.prototype.getInverse = function(n) { return console.warn("THREE.Matrix4: .getInverse() has been removed. Use matrixInv.copy( matrix ).invert(); instead."), this.copy(n).invert(); }; wi.prototype.isIntersectionLine = function(n) { return console.warn("THREE.Plane: .isIntersectionLine() has been renamed to .intersectsLine()."), this.intersectsLine(n); }; bn.prototype.multiplyVector3 = function(n) { return console.warn("THREE.Quaternion: .multiplyVector3() has been removed. Use is now vector.applyQuaternion( quaternion ) instead."), n.applyQuaternion(this); }; bn.prototype.inverse = function() { return console.warn("THREE.Quaternion: .inverse() has been renamed to invert()."), this.invert(); }; qr.prototype.isIntersectionBox = function(n) { return console.warn("THREE.Ray: .isIntersectionBox() has been renamed to .intersectsBox()."), this.intersectsBox(n); }; qr.prototype.isIntersectionPlane = function(n) { return console.warn("THREE.Ray: .isIntersectionPlane() has been renamed to .intersectsPlane()."), this.intersectsPlane(n); }; qr.prototype.isIntersectionSphere = function(n) { return console.warn("THREE.Ray: .isIntersectionSphere() has been renamed to .intersectsSphere()."), this.intersectsSphere(n); }; Zt.prototype.area = function() { return console.warn("THREE.Triangle: .area() has been renamed to .getArea()."), this.getArea(); }; Zt.prototype.barycoordFromPoint = function(n, e) { return console.warn("THREE.Triangle: .barycoordFromPoint() has been renamed to .getBarycoord()."), this.getBarycoord(n, e); }; Zt.prototype.midpoint = function(n) { return console.warn("THREE.Triangle: .midpoint() has been renamed to .getMidpoint()."), this.getMidpoint(n); }; Zt.prototypenormal = function(n) { return console.warn("THREE.Triangle: .normal() has been renamed to .getNormal()."), this.getNormal(n); }; Zt.prototype.plane = function(n) { return console.warn("THREE.Triangle: .plane() has been renamed to .getPlane()."), this.getPlane(n); }; Zt.barycoordFromPoint = function(n, e, t, i, r) { return console.warn("THREE.Triangle: .barycoordFromPoint() has been renamed to .getBarycoord()."), Zt.getBarycoord(n, e, t, i, r); }; Zt.normal = function(n, e, t, i) { return console.warn("THREE.Triangle: .normal() has been renamed to .getNormal()."), Zt.getNormal(n, e, t, i); }; Dr.prototype.extractAllPoints = function(n) { return console.warn("THREE.Shape: .extractAllPoints() has been removed. Use .extractPoints() instead."), this.extractPoints(n); }; Dr.prototype.extrude = function(n) { return console.warn("THREE.Shape: .extrude() has been removed. Use ExtrudeGeometry() instead."), new mi(this, n); }; Dr.prototype.makeGeometry = function(n) { return console.warn("THREE.Shape: .makeGeometry() has been removed. Use ShapeGeometry() instead."), new Fs(this, n); }; Re.prototype.fromAttribute = function(n, e, t) { return console.warn("THREE.Vector2: .fromAttribute() has been renamed to .fromBufferAttribute()."), this.fromBufferAttribute(n, e, t); }; Re.prototype.distanceToManhattan = function(n) { return console.warn("THREE.Vector2: .distanceToManhattan() has been renamed to .manhattanDistanceTo()."), this.manhattanDistanceTo(n); }; Re.prototype.lengthManhattan = function() { return console.warn("THREE.Vector2: .lengthManhattan() has been renamed to .manhattanLength()."), this.manhattanLength(); }; q.prototype.setEulerFromRotationMatrix = function() { console.error("THREE.Vector3: .setEulerFromRotationMatrix() has been removed. Use Euler.setFromRotationMatrix() instead."); }; q.prototype.setEulerFromQuaternion = function() { console.error("THREE.Vector3: .setEulerFromQuaternion() has been removed. Use Euler.setFromQuaternion() instead."); }; q.prototype.getPositionFromMatrix = function(n) { return console.warn("THREE.Vector3: .getPositionFromMatrix() has been renamed to .setFromMatrixPosition()."), this.setFromMatrixPosition(n); }; q.prototype.getScaleFromMatrix = function(n) { return console.warn("THREE.Vector3: .getScaleFromMatrix() has been renamed to .setFromMatrixScale()."), this.setFromMatrixScale(n); }; q.prototype.getColumnFromMatrix = function(n, e) { return console.warn("THREE.Vector3: .getColumnFromMatrix() has been renamed to .setFromMatrixColumn()."), this.setFromMatrixColumn(e, n); }; q.prototype.applyProjection = function(n) { return console.warn("THREE.Vector3: .applyProjection() has been removed. Use .applyMatrix4( m ) instead."), this.applyMatrix4(n); }; q.prototype.fromAttribute = function(n, e, t) { return console.warn("THREE.Vector3: .fromAttribute() has been renamed to .fromBufferAttribute()."), this.fromBufferAttribute(n, e, t); }; q.prototype.distanceToManhattan = function(n) { return console.warn("THREE.Vector3: .distanceToManhattan() has been renamed to .manhattanDistanceTo()."), this.manhattanDistanceTo(n); }; q.prototype.lengthManhattan = function() { return console.warn("THREE.Vector3: .lengthManhattan() has been renamed to .manhattanLength()."), this.manhattanLength(); }; xt.prototype.fromAttribute = function(n, e, t) { return console.warn("THREE.Vector4: .fromAttribute() has been renamed to .fromBufferAttribute()."), this.fromBufferAttribute(n, e, t); }; xt.prototype.lengthManhattan = function() { return console.warn("THREE.Vector4: .lengthManhattan() has been renamed to .manhattanLength()."), this.manhattanLength(); }; ut.prototype.getChildByName = function(n) { return console.warn("THREE.Object3D: .getChildByName() has been renamed to .getObjectByName()."), this.getObjectByName(n); }; ut.prototype.renderDepth = function() { console.warn("THREE.Object3D: .renderDepth has been removed. Use .renderOrder, instead."); }; ut.prototype.translate = function(n, e) { return console.warn("THREE.Object3D: .translate() has been removed. Use .translateOnAxis( axis, distance ) instead."), this.translateOnAxis(e, n); }; ut.prototype.getWorldRotation = function() { console.error("THREE.Object3D: .getWorldRotation() has been removed. Use THREE.Object3D.getWorldQuaternion( target ) instead."); }; ut.prototype.applyMatrix = function(n) { return console.warn("THREE.Object3D: .applyMatrix() has been renamed to .applyMatrix4()."), this.applyMatrix4(n); }; Object.defineProperties(ut.prototype, { eulerOrder: { get: function() { return console.warn("THREE.Object3D: .eulerOrder is now .rotation.order."), this.rotation.order; }, set: function(n) { console.warn("THREE.Object3D: .eulerOrder is now .rotation.order."), this.rotation.order = n; } }, useQuaternion: { get: function() { console.warn("THREE.Object3D: .useQuaternion has been removed. The library now uses quaternions by default."); }, set: function() { console.warn("THREE.Object3D: .useQuaternion has been removed. The library now uses quaternions by default."); } } }); Xt.prototype.setDrawMode = function() { console.error("THREE.Mesh: .setDrawMode() has been removed. The renderer now always assumes THREE.TrianglesDrawMode. Transform your geometry via BufferGeometryUtils.toTrianglesDrawMode() if necessary."); }; Object.defineProperties(Xt.prototype, { drawMode: { get: function() { return console.error("THREE.Mesh: .drawMode has been removed. The renderer now always assumes THREE.TrianglesDrawMode."), $b; }, set: function() { console.error("THREE.Mesh: .drawMode has been removed. The renderer now always assumes THREE.TrianglesDrawMode. Transform your geometry via BufferGeometryUtils.toTrianglesDrawMode() if necessary."); } } }); vl.prototype.initBones = function() { console.error("THREE.SkinnedMesh: initBones() has been removed."); }; nn.prototype.setLens = function(n, e) { console.warn("THREE.PerspectiveCamera.setLens is deprecated. Use .setFocalLength and .filmGauge for a photographic setup."), e !== void 0 && (this.filmGauge = e), this.setFocalLength(n); }; Object.defineProperties(gi.prototype, { onlyShadow: { set: function() { console.warn("THREE.Light: .onlyShadow has been removed."); } }, shadowCameraFov: { set: function(n) { console.warn("THREE.Light: .shadowCameraFov is now .shadow.camera.fov."), this.shadow.camera.fov = n; } }, shadowCameraLeft: { set: function(n) { console.warn("THREE.Light: .shadowCameraLeft is now .shadow.camera.left."), this.shadow.camera.left = n; } }, shadowCameraRight: { set: function(n) { console.warn("THREE.Light: .shadowCameraRight is now .shadow.camera.right."), this.shadow.camera.right = n; } }, shadowCameraTop: { set: function(n) { console.warn("THREE.Light: .shadowCameraTop is now .shadow.camera.top."), this.shadow.camera.top = n; } }, shadowCameraBottom: { set: function(n) { console.warn("THREE.Light: .shadowCameraBottom is now .shadow.camera.bottom."), this.shadow.camera.bottom = n; } }, shadowCameraNear: { set: function(n) { console.warn("THREE.Light: .shadowCameraNear is now .shadow.camera.near."), this.shadow.camera.near = n; } }, shadowCameraFar: { set: function(n) { console.warn("THREE.Light: .shadowCameraFar is now .shadow.camera.far."), this.shadow.camera.far = n; } }, shadowCameraVisible: { set: function() { console.warn("THREE.Light: .shadowCameraVisible has been removed. Use new THREE.CameraHelper( light.shadow.camera ) instead."); } }, shadowBias: { set: function(n) { console.warn("THREE.Light: .shadowBias is now .shadow.bias."), this.shadow.bias = n; } }, shadowDarkness: { set: function() { console.warn("THREE.Light: .shadowDarkness has been removed."); } }, shadowMapWidth: { set: function(n) { console.warn("THREE.Light: .shadowMapWidth is now .shadow.mapSize.width."), this.shadow.mapSize.width = n; } }, shadowMapHeight: { set: function(n) { console.warn("THREE.Light: .shadowMapHeight is now .shadow.mapSize.height."), this.shadow.mapSize.height = n; } } }); Object.defineProperties(ot.prototype, { length: { get: function() { return console.warn("THREE.BufferAttribute: .length has been deprecated. Use .count instead."), this.array.length; } }, dynamic: { get: function() { return console.warn("THREE.BufferAttribute: .dynamic has been deprecated. Use .usage instead."), this.usage === Fo; }, set: function() { console.warn("THREE.BufferAttribute: .dynamic has been deprecated. Use .usage instead."), this.setUsage(Fo); } } }); ot.prototype.setDynamic = function(n) { return console.warn("THREE.BufferAttribute: .setDynamic() has been deprecated. Use .setUsage() instead."), this.setUsage(n === true ? Fo : Ro), this; }; ot.prototype.copyIndicesArray = function() { console.error("THREE.BufferAttribute: .copyIndicesArray() has been removed."); }, ot.prototype.setArray = function() { console.error("THREE.BufferAttribute: .setArray has been removed. Use BufferGeometry .setAttribute to replace/resize attribute buffers"); }; Ke.prototype.addIndex = function(n) { console.warn("THREE.BufferGeometry: .addIndex() has been renamed to .setIndex()."), this.setIndex(n); }; Ke.prototype.addAttribute = function(n, e) { return console.warn("THREE.BufferGeometry: .addAttribute() has been renamed to .setAttribute()."), !(e && e.isBufferAttribute) && !(e && e.isInterleavedBufferAttribute) ? (console.warn("THREE.BufferGeometry: .addAttribute() now expects ( name, attribute )."), this.setAttribute(n, new ot(arguments[1], arguments[2]))) : n === "index" ? (console.warn("THREE.BufferGeometry.addAttribute: Use .setIndex() for index attribute."), this.setIndex(e), this) : this.setAttribute(n, e); }; Ke.prototype.addDrawCall = function(n, e, t) { t !== void 0 && console.warn("THREE.BufferGeometry: .addDrawCall() no longer supports indexOffset."), console.warn("THREE.BufferGeometry: .addDrawCall() is now .addGroup()."), this.addGroup(n, e); }; Ke.prototype.clearDrawCalls = function() { console.warn("THREE.BufferGeometry: .clearDrawCalls() is now .clearGroups()."), this.clearGroups(); }; Ke.prototype.computeOffsets = function() { console.warn("THREE.BufferGeometry: .computeOffsets() has been removed."); }; Ke.prototype.removeAttribute = function(n) { return console.warn("THREE.BufferGeometry: .removeAttribute() has been renamed to .deleteAttribute()."), this.deleteAttribute(n); }; Ke.prototype.applyMatrix = function(n) { return console.warn("THREE.BufferGeometry: .applyMatrix() has been renamed to .applyMatrix4()."), this.applyMatrix4(n); }; Object.defineProperties(Ke.prototype, { drawcalls: { get: function() { return console.error("THREE.BufferGeometry: .drawcalls has been renamed to .groups."), this.groups; } }, offsets: { get: function() { return console.warn("THREE.BufferGeometry: .offsets has been renamed to .groups."), this.groups; } } }); Qr.prototype.setDynamic = function(n) { return console.warn("THREE.InterleavedBuffer: .setDynamic() has been deprecated. Use .setUsage() instead."), this.setUsage(n === true ? Fo : Ro), this; }; Qr.prototype.setArray = function() { console.error("THREE.InterleavedBuffer: .setArray has been removed. Use BufferGeometry .setAttribute to replace/resize attribute buffers"); }; mi.prototype.getArrays = function() { console.error("THREE.ExtrudeGeometry: .getArrays() has been removed."); }; mi.prototype.addShapeList = function() { console.error("THREE.ExtrudeGeometry: .addShapeList() has been removed."); }; mi.prototype.addShape = function() { console.error("THREE.ExtrudeGeometry: .addShape() has been removed."); }; wu.prototype.dispose = function() { console.error("THREE.Scene: .dispose() has been removed."); }; Fu.prototype.onUpdate = function() { return console.warn("THREE.Uniform: .onUpdate() has been removed. Use object.onBeforeRender() instead."), this; }; Object.defineProperties(tn.prototype, { wrapAround: { get: function() { console.warn("THREE.Material: .wrapAround has been removed."); }, set: function() { console.warn("THREE.Material: .wrapAround has been removed."); } }, overdraw: { get: function() { console.warn("THREE.Material: .overdraw has been removed."); }, set: function() { console.warn("THREE.Material: .overdraw has been removed."); } }, wrapRGB: { get: function() { return console.warn("THREE.Material: .wrapRGB has been removed."), new Ue(); } }, shading: { get: function() { console.error("THREE." + this.type + ": .shading has been removed. Use the boolean .flatShading instead."); }, set: function(n) { console.warn("THREE." + this.type + ": .shading has been removed. Use the boolean .flatShading instead."), this.flatShading = n === yf; } }, stencilMask: { get: function() { return console.warn("THREE." + this.type + ": .stencilMask has been removed. Use .stencilFuncMask instead."), this.stencilFuncMask; }, set: function(n) { console.warn("THREE." + this.type + ": .stencilMask has been removed. Use .stencilFuncMask instead."), this.stencilFuncMask = n; } } }); Object.defineProperties(or.prototype, { derivatives: { get: function() { return console.warn("THREE.ShaderMaterial: .derivatives has been moved to .extensions.derivatives."), this.extensions.derivatives; }, set: function(n) { console.warn("THREE. ShaderMaterial: .derivatives has been moved to .extensions.derivatives."), this.extensions.derivatives = n; } } }); wt.prototype.clearTarget = function(n, e, t, i) { console.warn("THREE.WebGLRenderer: .clearTarget() has been deprecated. Use .setRenderTarget() and .clear() instead."), this.setRenderTarget(n), this.clear(e, t, i); }; wt.prototype.animate = function(n) { console.warn("THREE.WebGLRenderer: .animate() is now .setAnimationLoop()."), this.setAnimationLoop(n); }; wt.prototype.getCurrentRenderTarget = function() { return console.warn("THREE.WebGLRenderer: .getCurrentRenderTarget() is now .getRenderTarget()."), this.getRenderTarget(); }; wt.prototype.getMaxAnisotropy = function() { return console.warn("THREE.WebGLRenderer: .getMaxAnisotropy() is now .capabilities.getMaxAnisotropy()."), this.capabilities.getMaxAnisotropy(); }; wt.prototype.getPrecision = function() { return console.warn("THREE.WebGLRenderer: .getPrecision() is now .capabilities.precision."), this.capabilities.precision; }; wt.prototype.resetGLState = function() { return console.warn("THREE.WebGLRenderer: .resetGLState() is now .state.reset()."), this.state.reset(); }; wt.prototype.supportsFloatTextures = function() { return console.warn("THREE.WebGLRenderer: .supportsFloatTextures() is now .extensions.get( 'OES_texture_float' )."), this.extensions.get("OES_texture_float"); }; wt.prototype.supportsHalfFloatTextures = function() { return console.warn("THREE.WebGLRenderer: .supportsHalfFloatTextures() is now .extensions.get( 'OES_texture_half_float' )."), this.extensions.get("OES_texture_half_float"); }; wt.prototype.supportsStandardDerivatives = function() { return console.warn("THREE.WebGLRenderer: .supportsStandardDerivatives() is now .extensions.get( 'OES_standard_derivatives' )."), this.extensions.get("OES_standard_derivatives"); }; wt.prototype.supportsCompressedTextureS3TC = function() { return console.warn("THREE.WebGLRenderer: .supportsCompressedTextureS3TC() is now .extensions.get( 'WEBGL_compressed_texture_s3tc' )."), this.extensions.get("WEBGL_compressed_texture_s3tc"); }; wt.prototype.supportsCompressedTexturePVRTC = function() { return console.warn("THREE.WebGLRenderer: .supportsCompressedTexturePVRTC() is now .extensions.get( 'WEBGL_compressed_texture_pvrtc' )."), this.extensions.get("WEBGL_compressed_texture_pvrtc"); }; wt.prototype.supportsBlendMinMax = function() { return console.warn("THREE.WebGLRenderer: .supportsBlendMinMax() is now .extensions.get( 'EXT_blend_minmax' )."), this.extensions.get("EXT_blend_minmax"); }; wt.prototype.supportsVertexTextures = function() { return console.warn("THREE.WebGLRenderer: .supportsVertexTextures() is now .capabilities.vertexTextures."), this.capabilities.vertexTextures; }; wt.prototype.supportsInstancedArrays = function() { return console.warn("THREE.WebGLRenderer: .supportsInstancedArrays() is now .extensions.get( 'ANGLE_instanced_arrays' )."), this.extensions.get("ANGLE_instanced_arrays"); }; wt.prototype.enableScissorTest = function(n) { console.warn("THREE.WebGLRenderer: .enableScissorTest() is now .setScissorTest()."), this.setScissorTest(n); }; wt.prototype.initMaterial = function() { console.warn("THREE.WebGLRenderer: .initMaterial() has been removed."); }; wt.prototype.addPrePlugin = function() { console.warn("THREE.WebGLRenderer: .addPrePlugin() has been removed."); }; wt.prototype.addPostPlugin = function() { console.warn("THREE.WebGLRenderer: .addPostPlugin() has been removed."); }; wt.prototype.updateShadowMap = function() { console.warn("THREE.WebGLRenderer: .updateShadowMap() has been removed."); }; wt.prototype.setFaceCulling = function() { console.warn("THREE.WebGLRenderer: .setFaceCulling() has been removed."); }; wt.prototype.allocTextureUnit = function() { console.warn("THREE.WebGLRenderer: .allocTextureUnit() has been removed."); }; wt.prototype.setTexture = function() { console.warn("THREE.WebGLRenderer: .setTexture() has been removed."); }; wt.prototype.setTexture2D = function() { console.warn("THREE.WebGLRenderer: .setTexture2D() has been removed."); }; wt.prototype.setTextureCube = function() { console.warn("THREE.WebGLRenderer: .setTextureCube() has been removed."); }; wt.prototype.getActiveMipMapLevel = function() { return console.warn("THREE.WebGLRenderer: .getActiveMipMapLevel() is now .getActiveMipmapLevel()."), this.getActiveMipmapLevel(); }; Object.defineProperties(wt.prototype, { shadowMapEnabled: { get: function() { return this.shadowMap.enabled; }, set: function(n) { console.warn("THREE.WebGLRenderer: .shadowMapEnabled is now .shadowMap.enabled."), this.shadowMap.enabled = n; } }, shadowMapType: { get: function() { return this.shadowMap.type; }, set: function(n) { console.warn("THREE.WebGLRenderer: .shadowMapType is now .shadowMap.type."), this.shadowMap.type = n; } }, shadowMapCullFace: { get: function() { console.warn("THREE.WebGLRenderer: .shadowMapCullFace has been removed. Set Material.shadowSide instead."); }, set: function() { console.warn("THREE.WebGLRenderer: .shadowMapCullFace has been removed. Set Material.shadowSide instead."); } }, context: { get: function() { return console.warn("THREE.WebGLRenderer: .context has been removed. Use .getContext() instead."), this.getContext(); } }, vr: { get: function() { return console.warn("THREE.WebGLRenderer: .vr has been renamed to .xr"), this.xr; } }, gammaInput: { get: function() { return console.warn("THREE.WebGLRenderer: .gammaInput has been removed. Set the encoding for textures via Texture.encoding instead."), false; }, set: function() { console.warn("THREE.WebGLRenderer: .gammaInput has been removed. Set the encoding for textures via Texture.encoding instead."); } }, gammaOutput: { get: function() { return console.warn("THREE.WebGLRenderer: .gammaOutput has been removed. Set WebGLRenderer.outputEncoding instead."), false; }, set: function(n) { console.warn("THREE.WebGLRenderer: .gammaOutput has been removed. Set WebGLRenderer.outputEncoding instead."), this.outputEncoding = n === true ? Cs : Cn; } }, toneMappingWhitePoint: { get: function() { return console.warn("THREE.WebGLRenderer: .toneMappingWhitePoint has been removed."), 1; }, set: function() { console.warn("THREE.WebGLRenderer: .toneMappingWhitePoint has been removed."); } } }); Object.defineProperties(xx.prototype, { cullFace: { get: function() { console.warn("THREE.WebGLRenderer: .shadowMap.cullFace has been removed. Set Material.shadowSide instead."); }, set: function() { console.warn("THREE.WebGLRenderer: .shadowMap.cullFace has been removed. Set Material.shadowSide instead."); } }, renderReverseSided: { get: function() { console.warn("THREE.WebGLRenderer: .shadowMap.renderReverseSided has been removed. Set Material.shadowSide instead."); }, set: function() { console.warn("THREE.WebGLRenderer: .shadowMap.renderReverseSided has been removed. Set Material.shadowSide instead."); } }, renderSingleSided: { get: function() { console.warn("THREE.WebGLRenderer: .shadowMap.renderSingleSided has been removed. Set Material.shadowSide instead."); }, set: function() { console.warn("THREE.WebGLRenderer: .shadowMap.renderSingleSided has been removed. Set Material.shadowSide instead."); } } }); function EB(n, e, t) { return console.warn("THREE.WebGLRenderTargetCube( width, height, options ) is now WebGLCubeRenderTarget( size, options )."), new bu(n, t); } Object.defineProperties(fi.prototype, { wrapS: { get: function() { return console.warn("THREE.WebGLRenderTarget: .wrapS is now .texture.wrapS."), this.texture.wrapS; }, set: function(n) { console.warn("THREE.WebGLRenderTarget: .wrapS is now .texture.wrapS."), this.texture.wrapS = n; } }, wrapT: { get: function() { return console.warn("THREE.WebGLRenderTarget: .wrapT is now .texture.wrapT."), this.texture.wrapT; }, set: function(n) { console.warn("THREE.WebGLRenderTarget: .wrapT is now .texture.wrapT."), this.texture.wrapT = n; } }, magFilter: { get: function() { return console.warn("THREE.WebGLRenderTarget: .magFilter is now .texture.magFilter."), this.texture.magFilter; }, set: function(n) { console.warn("THREE.WebGLRenderTarget: .magFilter is now .texture.magFilter."), this.texture.magFilter = n; } }, minFilter: { get: function() { return console.warn("THREE.WebGLRenderTarget: .minFilter is now .texture.minFilter."), this.texture.minFilter; }, set: function(n) { console.warn("THREE.WebGLRenderTarget: .minFilter is now .texture.minFilter."), this.texture.minFilter = n; } }, anisotropy: { get: function() { return console.warn("THREE.WebGLRenderTarget: .anisotropy is now .texture.anisotropy."), this.texture.anisotropy; }, set: function(n) { console.warn("THREE.WebGLRenderTarget: .anisotropy is now .texture.anisotropy."), this.texture.anisotropy = n; } }, offset: { get: function() { return console.warn("THREE.WebGLRenderTarget: .offset is now .texture.offset."), this.texture.offset; }, set: function(n) { console.warn("THREE.WebGLRenderTarget: .offset is now .texture.offset."), this.texture.offset = n; } }, repeat: { get: function() { return console.warn("THREE.WebGLRenderTarget: .repeat is now .texture.repeat."), this.texture.repeat; }, set: function(n) { console.warn("THREE.WebGLRenderTarget: .repeat is now .texture.repeat."), this.texture.repeat = n; } }, format: { get: function() { return console.warn("THREE.WebGLRenderTarget: .format is now .texture.format."), this.texture.format; }, set: function(n) { console.warn("THREE.WebGLRenderTarget: .format is now .texture.format."), this.texture.format = n; } }, type: { get: function() { return console.warn("THREE.WebGLRenderTarget: .type is now .texture.type."), this.texture.type; }, set: function(n) { console.warn("THREE.WebGLRenderTarget: .type is now .texture.type."), this.texture.type = n; } }, generateMipmaps: { get: function() { return console.warn("THREE.WebGLRenderTarget: .generateMipmaps is now .texture.generateMipmaps."), this.texture.generateMipmaps; }, set: function(n) { console.warn("THREE.WebGLRenderTarget: .generateMipmaps is now .texture.generateMipmaps."), this.texture.generateMipmaps = n; } } }); cp.prototype.load = function(n) { console.warn("THREE.Audio: .load has been deprecated. Use THREE.AudioLoader instead."); const e = this; return new jx().load(n, function(i) { e.setBuffer(i); }), this; }; Yx.prototype.getData = function() { return console.warn("THREE.AudioAnalyser: .getData() is now .getFrequencyData()."), this.getFrequencyData(); }; yu.prototype.updateCubeMap = function(n, e) { return console.warn("THREE.CubeCamera: .updateCubeMap() is now .update()."), this.update(n, e); }; yu.prototype.clear = function(n, e, t, i) { return console.warn("THREE.CubeCamera: .clear() is now .renderTarget.clear()."), this.renderTarget.clear(n, e, t, i); }; Bs.crossOrigin = void 0; Bs.loadTexture = function(n, e, t, i) { console.warn("THREE.ImageUtils.loadTexture has been deprecated. Use THREE.TextureLoader() instead."); const r = new qf(); r.setCrossOrigin(this.crossOrigin); const s = r.load(n, t, void 0, i); return e && (s.mapping = e), s; }; Bs.loadTextureCube = function(n, e, t, i) { console.warn("THREE.ImageUtils.loadTextureCube has been deprecated. Use THREE.CubeTextureLoader() instead."); const r = new Nx(); r.setCrossOrigin(this.crossOrigin); const s = r.load(n, t, void 0, i); return e && (s.mapping = e), s; }; Bs.loadCompressedTexture = function() { console.error("THREE.ImageUtils.loadCompressedTexture has been removed. Use THREE.DDSLoader instead."); }; Bs.loadCompressedTextureCube = function() { console.error("THREE.ImageUtils.loadCompressedTextureCube has been removed. Use THREE.DDSLoader instead."); }; function CB() { console.error("THREE.CanvasRenderer has been removed"); } function LB() { console.error("THREE.JSONLoader has been removed."); } var RB = { createMultiMaterialObject: function() { console.error("THREE.SceneUtils has been moved to /examples/jsm/utils/SceneUtils.js"); }, detach: function() { console.error("THREE.SceneUtils has been moved to /examples/jsm/utils/SceneUtils.js"); }, attach: function() { console.error("THREE.SceneUtils has been moved to /examples/jsm/utils/SceneUtils.js"); } }; function FB() { console.error("THREE.LensFlare has been moved to /examples/jsm/objects/Lensflare.js"); } typeof __THREE_DEVTOOLS__ < "u" && __THREE_DEVTOOLS__.dispatchEvent(new CustomEvent("register", { detail: { revision: gf } })); typeof window < "u" && (window.__THREE__ ? console.warn("WARNING: Multiple instances of Three.js being imported.") : window.__THREE__ = gf); var PB = Object.freeze(Object.defineProperty({ __proto__: null, ACESFilmicToneMapping: Yy, AddEquation: ps, AddOperation: jy, AdditiveAnimationBlendMode: Mf, AdditiveBlending: id, AlphaFormat: ib, AlwaysDepth: Uy, AlwaysStencilFunc: qb, AmbientLight: tp, AmbientLightProbe: Zx, AnimationClip: jo, AnimationLoader: cN, AnimationMixer: qx, AnimationObjectGroup: Kx, AnimationUtils: Ct, ArcCurve: Df, ArrayCamera: Ff, ArrowHelper: HN, Audio: cp, AudioAnalyser: Yx, AudioContext: lp, AudioListener: yN, AudioLoader: jx, AxesHelper: aM, AxisHelper: MB, BackSide: jt, BasicDepthPacking: Yb, BasicShadowMap: A3, BinaryTextureLoader: TB, Bone: yl, BooleanKeyframeTrack: Vs, BoundingBoxHelper: wB, Box2: oa, Box3: Nn, Box3Helper: kN, BoxBufferGeometry: sr, BoxGeometry: sr, BoxHelper: oM, BufferAttribute: ot, BufferGeometry: Ke, BufferGeometryLoader: Hx, ByteType: Ky, Cache: Is, Camera: hl, CameraHelper: VN, CanvasRenderer: CB, CanvasTexture: Tx, CatmullRomCurve3: Bf, CineonToneMapping: Xy, CircleBufferGeometry: Io, CircleGeometry: Io, ClampToEdgeWrapping: hn2, Clock: Xx, Color: Ue, ColorKeyframeTrack: Jf, CompressedTexture: If, CompressedTextureLoader: uN, ConeBufferGeometry: Oo, ConeGeometry: Oo, CubeCamera: yu, CubeReflectionMapping: ll, CubeRefractionMapping: cl, CubeTexture: ta, CubeTextureLoader: Nx, CubeUVReflectionMapping: ea, CubeUVRefractionMapping: ul, CubicBezierCurve: Su, CubicBezierCurve3: Uf, CubicInterpolant: Px, CullFaceBack: nd, CullFaceFront: Ay, CullFaceFrontBack: w3, CullFaceNone: wy, Curve: jn, CurvePath: Ux, CustomBlending: _y, CustomToneMapping: Jy, CylinderBufferGeometry: $r, CylinderGeometry: $r, Cylindrical: IN, DataTexture: Ss, DataTexture2DArray: Lf, DataTexture3D: Rf, DataTextureLoader: Bx, DataUtils: jN, DecrementStencilOp: P3, DecrementWrapStencilOp: O3, DefaultLoadingManager: Dx, DepthFormat: ws, DepthStencilFormat: Co, DepthTexture: Ex, DirectionalLight: Ru, DirectionalLightHelper: zN, DiscreteInterpolant: Ix, DodecahedronBufferGeometry: Do, DodecahedronGeometry: Do, DoubleSide: Wr, DstAlphaFactor: Py, DstColorFactor: Oy, DynamicBufferAttribute: hB, DynamicCopyUsage: X3, DynamicDrawUsage: Fo, DynamicReadUsage: j3, EdgesGeometry: Of, EdgesHelper: AB, EllipseCurve: xl, EqualDepth: Vy, EqualStencilFunc: U3, EquirectangularReflectionMapping: kc, EquirectangularRefractionMapping: Gc, Euler: Us, EventDispatcher: Kr, ExtrudeBufferGeometry: mi, ExtrudeGeometry: mi, FaceColors: eB, FileLoader: $n, FlatShading: yf, Float16BufferAttribute: lx, Float32Attribute: bB, Float32BufferAttribute: He, Float64Attribute: xB, Float64BufferAttribute: cx, FloatType: qi, Fog: pl, FogExp2: fl, Font: ap, FontLoader: mN, FrontSide: Hr, Frustum: dl, GLBufferAttribute: eM, GLSL1: J3, GLSL3: yd, GammaEncoding: pu, GreaterDepth: Gy, GreaterEqualDepth: ky, GreaterEqualStencilFunc: G3, GreaterStencilFunc: V3, GridHelper: sM, Group: _i, HalfFloatType: Ms, HemisphereLight: Qf, HemisphereLightHelper: BN, HemisphereLightProbe: $x, IcosahedronBufferGeometry: No, IcosahedronGeometry: No, ImageBitmapLoader: op, ImageLoader: Ya, ImageUtils: Bs, ImmediateRenderObject: nM, IncrementStencilOp: F3, IncrementWrapStencilOp: I3, InstancedBufferAttribute: sp, InstancedBufferGeometry: rp, InstancedInterleavedBuffer: Qx, InstancedMesh: Pf, Int16Attribute: mB, Int16BufferAttribute: ox, Int32Attribute: vB, Int32BufferAttribute: ax, Int8Attribute: dB, Int8BufferAttribute: ix, IntType: Qy, InterleavedBuffer: Qr, InterleavedBufferAttribute: ar, Interpolant: Ni, InterpolateDiscrete: Lo, InterpolateLinear: Es, InterpolateSmooth: Cc, InvertStencilOp: D3, JSONLoader: LB, KeepStencilOp: Lc, KeyframeTrack: xi, LOD: Sx, LatheBufferGeometry: Bo, LatheGeometry: Bo, Layers: Cf, LensFlare: FB, LessDepth: zy, LessEqualDepth: Vc, LessEqualStencilFunc: z3, LessStencilFunc: B3, Light: gi, LightProbe: Al, Line: Oi, Line3: tM, LineBasicMaterial: an, LineCurve: Ml, LineCurve3: Cx, LineDashedMaterial: Xf, LineLoop: Au, LinePieces: qN, LineSegments: Rn, LineStrip: KN, LinearEncoding: Cn, LinearFilter: zt, LinearInterpolant: Yf, LinearMipMapLinearFilter: C3, LinearMipMapNearestFilter: E3, LinearMipmapLinearFilter: fr, LinearMipmapNearestFilter: du, LinearToneMapping: $y, Loader: xn, LoaderUtils: ir, LoadingManager: Kf, LogLuvEncoding: Xb, LoopOnce: Hb, LoopPingPong: jb, LoopRepeat: Wb, LuminanceAlphaFormat: sb, LuminanceFormat: rb, MOUSE: x3, Material: tn, MaterialLoader: Gx, Math: xd, MathUtils: xd, Matrix3: rn, Matrix4: Xe, MaxEquation: ad, Mesh: Xt, MeshBasicMaterial: In, MeshDepthMaterial: xu, MeshDistanceMaterial: Mu, MeshFaceMaterial: nB, MeshLambertMaterial: $f, MeshMatcapMaterial: Zf, MeshNormalMaterial: jf, MeshPhongMaterial: Hf, MeshPhysicalMaterial: wl, MeshStandardMaterial: zs, MeshToonMaterial: Wf, MinEquation: od, MirroredRepeatWrapping: Eo, MixOperation: Wy, MultiMaterial: iB, MultiplyBlending: sd, MultiplyOperation: al, NearestFilter: $t, NearestMipMapLinearFilter: T3, NearestMipMapNearestFilter: _3, NearestMipmapLinearFilter: Ga, NearestMipmapNearestFilter: ka, NeverDepth: By, NeverStencilFunc: N3, NoBlending: tr, NoColors: QN, NoToneMapping: Ir, NormalAnimationBlendMode: fu, NormalBlending: vo, NotEqualDepth: Hy, NotEqualStencilFunc: k3, NumberKeyframeTrack: Ho, Object3D: ut, ObjectLoader: hN, ObjectSpaceNormalMap: Kb, OctahedronBufferGeometry: Rs, OctahedronGeometry: Rs, OneFactor: Ly, OneMinusDstAlphaFactor: Iy, OneMinusDstColorFactor: Dy, OneMinusSrcAlphaFactor: xf, OneMinusSrcColorFactor: Fy, OrthographicCamera: sa, PCFShadowMap: vf, PCFSoftShadowMap: Sy, PMREMGenerator: ZN, ParametricBufferGeometry: Hc, ParametricGeometry: Hc, Particle: sB, ParticleBasicMaterial: lB, ParticleSystem: oB, ParticleSystemMaterial: cB, Path: Ja, PerspectiveCamera: nn, Plane: wi, PlaneBufferGeometry: Ls, PlaneGeometry: Ls, PlaneHelper: GN, PointCloud: rB, PointCloudMaterial: aB, PointLight: Lu, PointLightHelper: DN, Points: ia, PointsMaterial: es, PolarGridHelper: UN, PolyhedronBufferGeometry: Di, PolyhedronGeometry: Di, PositionalAudio: xN, PropertyBinding: mt, PropertyMixer: Jx, QuadraticBezierCurve: _u, QuadraticBezierCurve3: zf, Quaternion: bn, QuaternionKeyframeTrack: ks, QuaternionLinearInterpolant: Ox, REVISION: gf, RGBADepthPacking: Jb, RGBAFormat: Gn, RGBAIntegerFormat: db, RGBA_ASTC_10x10_Format: _b, RGBA_ASTC_10x5_Format: wb, RGBA_ASTC_10x6_Format: Ab, RGBA_ASTC_10x8_Format: Sb, RGBA_ASTC_12x10_Format: Tb, RGBA_ASTC_12x12_Format: Eb, RGBA_ASTC_4x4_Format: pb, RGBA_ASTC_5x4_Format: mb, RGBA_ASTC_5x5_Format: gb, RGBA_ASTC_6x5_Format: vb, RGBA_ASTC_6x6_Format: yb, RGBA_ASTC_8x5_Format: bb, RGBA_ASTC_8x6_Format: xb, RGBA_ASTC_8x8_Format: Mb, RGBA_BPTC_Format: Cb, RGBA_ETC2_EAC_Format: vd, RGBA_PVRTC_2BPPV1_Format: md, RGBA_PVRTC_4BPPV1_Format: pd, RGBA_S3TC_DXT1_Format: cd, RGBA_S3TC_DXT3_Format: ud, RGBA_S3TC_DXT5_Format: hd, RGBDEncoding: _f, RGBEEncoding: mu, RGBEFormat: ob, RGBFormat: nr, RGBIntegerFormat: hb, RGBM16Encoding: Sf, RGBM7Encoding: Af, RGB_ETC1_Format: fb, RGB_ETC2_Format: gd, RGB_PVRTC_2BPPV1_Format: fd, RGB_PVRTC_4BPPV1_Format: dd, RGB_S3TC_DXT1_Format: ld, RGFormat: cb, RGIntegerFormat: ub, RawShaderMaterial: ra, Ray: qr, Raycaster: FN, RectAreaLight: np, RedFormat: ab, RedIntegerFormat: lb, ReinhardToneMapping: Zy, RepeatWrapping: jr, ReplaceStencilOp: R3, ReverseSubtractEquation: Ey, RingBufferGeometry: Uo, RingGeometry: Uo, SRGB8_ALPHA8_ASTC_10x10_Format: Vb, SRGB8_ALPHA8_ASTC_10x5_Format: Bb, SRGB8_ALPHA8_ASTC_10x6_Format: Ub, SRGB8_ALPHA8_ASTC_10x8_Format: zb, SRGB8_ALPHA8_ASTC_12x10_Format: kb, SRGB8_ALPHA8_ASTC_12x12_Format: Gb, SRGB8_ALPHA8_ASTC_4x4_Format: Lb, SRGB8_ALPHA8_ASTC_5x4_Format: Rb, SRGB8_ALPHA8_ASTC_5x5_Format: Fb, SRGB8_ALPHA8_ASTC_6x5_Format: Pb, SRGB8_ALPHA8_ASTC_6x6_Format: Ib, SRGB8_ALPHA8_ASTC_8x5_Format: Ob, SRGB8_ALPHA8_ASTC_8x6_Format: Db, SRGB8_ALPHA8_ASTC_8x8_Format: Nb, Scene: wu, SceneUtils: RB, ShaderChunk: dt, ShaderLib: ci, ShaderMaterial: or, ShadowMaterial: Gf, Shape: Dr, ShapeBufferGeometry: Fs, ShapeGeometry: Fs, ShapePath: Wx, ShapeUtils: Fi, ShortType: qy, Skeleton: bl, SkeletonHelper: iM, SkinnedMesh: vl, SmoothShading: S3, Sphere: pr, SphereBufferGeometry: Ps, SphereGeometry: Ps, Spherical: PN, SphericalHarmonics3: ip, SplineCurve: Tu, SpotLight: Cu, SpotLightHelper: ON, Sprite: gl, SpriteMaterial: ml, SrcAlphaFactor: bf, SrcAlphaSaturateFactor: Ny, SrcColorFactor: Ry, StaticCopyUsage: Z3, StaticDrawUsage: Ro, StaticReadUsage: W3, StereoCamera: gN, StreamCopyUsage: Y3, StreamDrawUsage: H3, StreamReadUsage: $3, StringKeyframeTrack: Gs, SubtractEquation: Ty, SubtractiveBlending: rd, TOUCH: M3, TangentSpaceNormalMap: Jr, TetrahedronBufferGeometry: zo, TetrahedronGeometry: zo, TextBufferGeometry: Wc, TextGeometry: Wc, Texture: Yt, TextureLoader: qf, TorusBufferGeometry: Vo, TorusGeometry: Vo, TorusKnotBufferGeometry: ko, TorusKnotGeometry: ko, Triangle: Zt, TriangleFanDrawMode: wf, TriangleStripDrawMode: Zb, TrianglesDrawMode: $b, TubeBufferGeometry: Go, TubeGeometry: Go, UVMapping: hu, Uint16Attribute: gB, Uint16BufferAttribute: gu, Uint32Attribute: yB, Uint32BufferAttribute: vu, Uint8Attribute: fB, Uint8BufferAttribute: rx, Uint8ClampedAttribute: pB, Uint8ClampedBufferAttribute: sx, Uniform: Fu, UniformsLib: ze, UniformsUtils: hx, UnsignedByteType: Ts, UnsignedInt248Type: yo, UnsignedIntType: Ra, UnsignedShort4444Type: eb, UnsignedShort5551Type: tb, UnsignedShort565Type: nb, UnsignedShortType: Ha, VSMShadowMap: po, Vector2: Re, Vector3: q, Vector4: xt, VectorKeyframeTrack: Wo, Vertex: uB, VertexColors: tB, VideoTexture: _x, WebGL1Renderer: wx, WebGLCubeRenderTarget: bu, WebGLMultipleRenderTargets: tx, WebGLMultisampleRenderTarget: Ef, WebGLRenderTarget: fi, WebGLRenderTargetCube: EB, WebGLRenderer: wt, WebGLUtils: Mx, WireframeGeometry: kf, WireframeHelper: SB, WrapAroundEnding: Wa, XHRLoader: _B, ZeroCurvatureEnding: gs, ZeroFactor: Cy, ZeroSlopeEnding: vs, ZeroStencilOp: L3, sRGBEncoding: Cs }, Symbol.toStringTag, { value: "Module" })); var IB = au(PB); function OB(n, e) { if (!(n instanceof e)) throw new TypeError("Cannot call a class as a function"); } function DB(n, e) { for (var t = 0; t < e.length; t++) { var i = e[t]; i.enumerable = i.enumerable || false, i.configurable = true, "value" in i && (i.writable = true), Object.defineProperty(n, i.key, i); } } function NB(n, e, t) { return e && DB(n.prototype, e), n; } function BB(n, e) { if (typeof e != "function" && e !== null) throw new TypeError("Super expression must either be null or a function"); n.prototype = Object.create(e && e.prototype, { constructor: { value: n, writable: true, configurable: true } }), e && Td(n, e); } function jc(n) { return jc = Object.setPrototypeOf ? Object.getPrototypeOf : function(t) { return t.__proto__ || Object.getPrototypeOf(t); }, jc(n); } function Td(n, e) { return Td = Object.setPrototypeOf || function(i, r) { return i.__proto__ = r, i; }, Td(n, e); } function UB() { if (typeof Reflect > "u" || !Reflect.construct || Reflect.construct.sham) return false; if (typeof Proxy == "function") return true; try { return Boolean.prototype.valueOf.call(Reflect.construct(Boolean, [], function() { })), true; } catch { return false; } } function zB(n) { if (n === void 0) throw new ReferenceError("this hasn't been initialised - super() hasn't been called"); return n; } function VB(n, e) { return e && (typeof e == "object" || typeof e == "function") ? e : zB(n); } function kB(n) { var e = UB(); return function() { var i = jc(n), r; if (e) { var s = jc(this).constructor; r = Reflect.construct(i, arguments, s); } else r = i.apply(this, arguments); return VB(this, r); }; } function fv(n, e) { return HB(n) || jB(n, e) || hM(n, e) || ZB(); } function xc(n) { return GB(n) || WB(n) || hM(n) || $B(); } function GB(n) { if (Array.isArray(n)) return Ed(n); } function HB(n) { if (Array.isArray(n)) return n; } function WB(n) { if (typeof Symbol < "u" && n[Symbol.iterator] != null || n["@@iterator"] != null) return Array.from(n); } function jB(n, e) { var t = n && (typeof Symbol < "u" && n[Symbol.iterator] || n["@@iterator"]); if (t != null) { var i = [], r = true, s = false, o, a; try { for (t = t.call(n); !(r = (o = t.next()).done) && (i.push(o.value), !(e && i.length === e)); r = true) ; } catch (c) { s = true, a = c; } finally { try { !r && t.return != null && t.return(); } finally { if (s) throw a; } } return i; } } function hM(n, e) { if (n) { if (typeof n == "string") return Ed(n, e); var t = Object.prototype.toString.call(n).slice(8, -1); if (t === "Object" && n.constructor && (t = n.constructor.name), t === "Map" || t === "Set") return Array.from(n); if (t === "Arguments" || /^(?:Ui|I)nt(?:8|16|32)(?:Clamped)?Array$/.test(t)) return Ed(n, e); } } function Ed(n, e) { (e == null || e > n.length) && (e = n.length); for (var t = 0, i = new Array(e); t < e; t++) i[t] = n[t]; return i; } function $B() { throw new TypeError(`Invalid attempt to spread non-iterable instance. In order to be iterable, non-array objects must have a [Symbol.iterator]() method.`); } function ZB() { throw new TypeError(`Invalid attempt to destructure non-iterable instance. In order to be iterable, non-array objects must have a [Symbol.iterator]() method.`); } var wa = typeof window < "u" && window.THREE ? window.THREE : { LinearFilter: zt, Sprite: gl, SpriteMaterial: ml, Texture: Yt }; var XB = function(n) { BB(t, n); var e = kB(t); function t() { var i, r = arguments.length > 0 && arguments[0] !== void 0 ? arguments[0] : "", s = arguments.length > 1 && arguments[1] !== void 0 ? arguments[1] : 10, o = arguments.length > 2 && arguments[2] !== void 0 ? arguments[2] : "rgba(255, 255, 255, 1)"; return OB(this, t), i = e.call(this, new wa.SpriteMaterial({ map: new wa.Texture() })), i._text = "".concat(r), i._textHeight = s, i._color = o, i._backgroundColor = false, i._padding = 0, i._borderWidth = 0, i._borderRadius = 0, i._borderColor = "white", i._strokeWidth = 0, i._strokeColor = "white", i._fontFace = "Arial", i._fontSize = 90, i._fontWeight = "normal", i._canvas = document.createElement("canvas"), i._texture = i.material.map, i._texture.minFilter = wa.LinearFilter, i._genCanvas(), i; } return NB(t, [{ key: "text", get: function() { return this._text; }, set: function(r) { this._text = r, this._genCanvas(); } }, { key: "textHeight", get: function() { return this._textHeight; }, set: function(r) { this._textHeight = r, this._genCanvas(); } }, { key: "color", get: function() { return this._color; }, set: function(r) { this._color = r, this._genCanvas(); } }, { key: "backgroundColor", get: function() { return this._backgroundColor; }, set: function(r) { this._backgroundColor = r, this._genCanvas(); } }, { key: "padding", get: function() { return this._padding; }, set: function(r) { this._padding = r, this._genCanvas(); } }, { key: "borderWidth", get: function() { return this._borderWidth; }, set: function(r) { this._borderWidth = r, this._genCanvas(); } }, { key: "borderRadius", get: function() { return this._borderRadius; }, set: function(r) { this._borderRadius = r, this._genCanvas(); } }, { key: "borderColor", get: function() { return this._borderColor; }, set: function(r) { this._borderColor = r, this._genCanvas(); } }, { key: "fontFace", get: function() { return this._fontFace; }, set: function(r) { this._fontFace = r, this._genCanvas(); } }, { key: "fontSize", get: function() { return this._fontSize; }, set: function(r) { this._fontSize = r, this._genCanvas(); } }, { key: "fontWeight", get: function() { return this._fontWeight; }, set: function(r) { this._fontWeight = r, this._genCanvas(); } }, { key: "strokeWidth", get: function() { return this._strokeWidth; }, set: function(r) { this._strokeWidth = r, this._genCanvas(); } }, { key: "strokeColor", get: function() { return this._strokeColor; }, set: function(r) { this._strokeColor = r, this._genCanvas(); } }, { key: "_genCanvas", value: function() { var r = this, s = this._canvas, o = s.getContext("2d"), a = Array.isArray(this.borderWidth) ? this.borderWidth : [this.borderWidth, this.borderWidth], c = a.map(function(R) { return R * r.fontSize * 0.1; }), l = Array.isArray(this.borderRadius) ? this.borderRadius : [this.borderRadius, this.borderRadius, this.borderRadius, this.borderRadius], d = l.map(function(R) { return R * r.fontSize * 0.1; }), h6 = Array.isArray(this.padding) ? this.padding : [this.padding, this.padding], f = h6.map(function(R) { return R * r.fontSize * 0.1; }), g = this.text.split(` `), p = "".concat(this.fontWeight, " ").concat(this.fontSize, "px ").concat(this.fontFace); o.font = p; var u = Math.max.apply(Math, xc(g.map(function(R) { return o.measureText(R).width; }))), y = this.fontSize * g.length; if (s.width = u + c[0] * 2 + f[0] * 2, s.height = y + c[1] * 2 + f[1] * 2, this.borderWidth) { if (o.strokeStyle = this.borderColor, c[0]) { var v = c[0] / 2; o.lineWidth = c[0], o.beginPath(), o.moveTo(v, d[0]), o.lineTo(v, s.height - d[3]), o.moveTo(s.width - v, d[1]), o.lineTo(s.width - v, s.height - d[2]), o.stroke(); } if (c[1]) { var m = c[1] / 2; o.lineWidth = c[1], o.beginPath(), o.moveTo(Math.max(c[0], d[0]), m), o.lineTo(s.width - Math.max(c[0], d[1]), m), o.moveTo(Math.max(c[0], d[3]), s.height - m), o.lineTo(s.width - Math.max(c[0], d[2]), s.height - m), o.stroke(); } if (this.borderRadius) { var x = Math.max.apply(Math, xc(c)), w = x / 2; o.lineWidth = x, o.beginPath(), [!!d[0] && [d[0], w, w, d[0]], !!d[1] && [s.width - d[1], s.width - w, w, d[1]], !!d[2] && [s.width - d[2], s.width - w, s.height - w, s.height - d[2]], !!d[3] && [d[3], w, s.height - w, s.height - d[3]]].filter(function(R) { return R; }).forEach(function(R) { var L = fv(R, 4), S = L[0], I = L[1], T = L[2], _ = L[3]; o.moveTo(S, T), o.quadraticCurveTo(I, T, I, _); }), o.stroke(); } } this.backgroundColor && (o.fillStyle = this.backgroundColor, this.borderRadius ? (o.beginPath(), o.moveTo(c[0], d[0]), [ [c[0], d[0], s.width - d[1], c[1], c[1], c[1]], // t [s.width - c[0], s.width - c[0], s.width - c[0], c[1], d[1], s.height - d[2]], // r [s.width - c[0], s.width - d[2], d[3], s.height - c[1], s.height - c[1], s.height - c[1]], // b [c[0], c[0], c[0], s.height - c[1], s.height - d[3], d[0]] // t ].forEach(function(R) { var L = fv(R, 6), S = L[0], I = L[1], T = L[2], _ = L[3], E = L[4], C = L[5]; o.quadraticCurveTo(S, _, I, E), o.lineTo(T, C); }), o.closePath(), o.fill()) : o.fillRect(c[0], c[1], s.width - c[0] * 2, s.height - c[1] * 2)), o.translate.apply(o, xc(c)), o.translate.apply(o, xc(f)), o.font = p, o.fillStyle = this.color, o.textBaseline = "bottom"; var A = this.strokeWidth > 0; A && (o.lineWidth = this.strokeWidth * this.fontSize / 10, o.strokeStyle = this.strokeColor), g.forEach(function(R, L) { var S = (u - o.measureText(R).width) / 2, I = (L + 1) * r.fontSize; A && o.strokeText(R, S, I), o.fillText(R, S, I); }), this._texture.image = s, this._texture.needsUpdate = true; var M = this.textHeight * g.length + a[1] * 2 + h6[1] * 2; this.scale.set(M * s.width / s.height, M, 0); } }, { key: "clone", value: function() { return new this.constructor(this.text, this.textHeight, this.color).copy(this); } }, { key: "copy", value: function(r) { return wa.Sprite.prototype.copy.call(this, r), this.color = r.color, this.backgroundColor = r.backgroundColor, this.padding = r.padding, this.borderWidth = r.borderWidth, this.borderColor = r.borderColor, this.fontFace = r.fontFace, this.fontSize = r.fontSize, this.fontWeight = r.fontWeight, this.strokeWidth = r.strokeWidth, this.strokeColor = r.strokeColor, this; } }]), t; }(wa.Sprite); var YB = Object.freeze(Object.defineProperty({ __proto__: null, default: XB }, Symbol.toStringTag, { value: "Module" })); var JB = au(YB); var Ch = { exports: {} }; var pv; function KB() { return pv || (pv = 1, function(n, e) { (function(t, i) { n.exports = i(); })(typeof window < "u" ? window : Lr, function() { if (typeof window > "u") return null; var t = typeof window < "u" && window.Math == Math ? window : typeof self < "u" && self.Math == Math ? self : Function("return this")(), i = t.requestAnimationFrame || t.mozRequestAnimationFrame || t.webkitRequestAnimationFrame || function(d) { return t.setTimeout(d, 20); }, r = t.cancelAnimationFrame || t.mozCancelAnimationFrame || t.webkitCancelAnimationFrame || function(d) { t.clearTimeout(d); }; function s(d, h6) { var f = Object.prototype.toString.call(d), g = f === "[object Array]" || f === "[object NodeList]" || f === "[object HTMLCollection]" || f === "[object Object]" || typeof jQuery < "u" && d instanceof jQuery || typeof Elements < "u" && d instanceof Elements, p = 0, u = d.length; if (g) for (; p < u; p++) h6(d[p]); else h6(d); } function o(d) { if (!d.getBoundingClientRect) return { width: d.offsetWidth, height: d.offsetHeight }; var h6 = d.getBoundingClientRect(); return { width: Math.round(h6.width), height: Math.round(h6.height) }; } function a(d, h6) { Object.keys(h6).forEach(function(f) { d.style[f] = h6[f]; }); } var c = function(d, h6) { var f = 0; function g() { var u = []; this.add = function(m) { u.push(m); }; var y, v; this.call = function(m) { for (y = 0, v = u.length; y < v; y++) u[y].call(this, m); }, this.remove = function(m) { var x = []; for (y = 0, v = u.length; y < v; y++) u[y] !== m && x.push(u[y]); u = x; }, this.length = function() { return u.length; }; } function p(u, y) { if (u) { if (u.resizedAttached) { u.resizedAttached.add(y); return; } u.resizedAttached = new g(), u.resizedAttached.add(y), u.resizeSensor = document.createElement("div"), u.resizeSensor.dir = "ltr", u.resizeSensor.className = "resize-sensor"; var v = { pointerEvents: "none", position: "absolute", left: "0px", top: "0px", right: "0px", bottom: "0px", overflow: "hidden", zIndex: "-1", visibility: "hidden", maxWidth: "100%" }, m = { position: "absolute", left: "0px", top: "0px", transition: "0s" }; a(u.resizeSensor, v); var x = document.createElement("div"); x.className = "resize-sensor-expand", a(x, v); var w = document.createElement("div"); a(w, m), x.appendChild(w); var A = document.createElement("div"); A.className = "resize-sensor-shrink", a(A, v); var M = document.createElement("div"); a(M, m), a(M, { width: "200%", height: "200%" }), A.appendChild(M), u.resizeSensor.appendChild(x), u.resizeSensor.appendChild(A), u.appendChild(u.resizeSensor); var R = window.getComputedStyle(u), L = R ? R.getPropertyValue("position") : null; L !== "absolute" && L !== "relative" && L !== "fixed" && L !== "sticky" && (u.style.position = "relative"); var S = false, I = 0, T = o(u), _ = 0, E = 0, C = true; f = 0; var P = function() { var B = u.offsetWidth, U = u.offsetHeight; w.style.width = B + 10 + "px", w.style.height = U + 10 + "px", x.scrollLeft = B + 10, x.scrollTop = U + 10, A.scrollLeft = B + 10, A.scrollTop = U + 10; }, b = function() { if (C) { var B = u.offsetWidth === 0 && u.offsetHeight === 0; if (B) { f || (f = i(function() { f = 0, b(); })); return; } else C = false; } P(); }; u.resizeSensor.resetSensor = b; var F = function() { I = 0, S && (_ = T.width, E = T.height, u.resizedAttached && u.resizedAttached.call(T)); }, D = function() { T = o(u), S = T.width !== _ || T.height !== E, S && !I && (I = i(F)), b(); }, N = function(B, U, G) { B.attachEvent ? B.attachEvent("on" + U, G) : B.addEventListener(U, G); }; N(x, "scroll", D), N(A, "scroll", D), f = i(function() { f = 0, b(); }); } } s(d, function(u) { p(u, h6); }), this.detach = function(u) { f || (r(f), f = 0), c.detach(d, u); }, this.reset = function() { d.resizeSensor.resetSensor(); }; }; if (c.reset = function(d) { s(d, function(h6) { h6.resizeSensor.resetSensor(); }); }, c.detach = function(d, h6) { s(d, function(f) { f && (f.resizedAttached && typeof h6 == "function" && (f.resizedAttached.remove(h6), f.resizedAttached.length()) || f.resizeSensor && (f.contains(f.resizeSensor) && f.removeChild(f.resizeSensor), delete f.resizeSensor, delete f.resizedAttached)); }); }, typeof MutationObserver < "u") { var l = new MutationObserver(function(d) { for (var h6 in d) if (d.hasOwnProperty(h6)) for (var f = d[h6].addedNodes, g = 0; g < f.length; g++) f[g].resizeSensor && c.reset(f[g]); }); document.addEventListener("DOMContentLoaded", function(d) { l.observe(document.body, { childList: true, subtree: true }); }); } return c; }); }(Ch)), Ch.exports; } var qB = class extends xn { constructor(e) { super(e), this.dracoLoader = null, this.ktx2Loader = null, this.meshoptDecoder = null, this.pluginCallbacks = [], this.register(function(t) { return new n4(t); }), this.register(function(t) { return new r4(t); }), this.register(function(t) { return new s4(t); }), this.register(function(t) { return new i4(t); }), this.register(function(t) { return new e4(t); }), this.register(function(t) { return new o4(t); }); } load(e, t, i, r) { const s = this; let o; this.resourcePath !== "" ? o = this.resourcePath : this.path !== "" ? o = this.path : o = ir.extractUrlBase(e), this.manager.itemStart(e); const a = function(l) { r ? r(l) : console.error(l), s.manager.itemError(e), s.manager.itemEnd(e); }, c = new $n(this.manager); c.setPath(this.path), c.setResponseType("arraybuffer"), c.setRequestHeader(this.requestHeader), c.setWithCredentials(this.withCredentials), c.load(e, function(l) { try { s.parse(l, o, function(d) { t(d), s.manager.itemEnd(e); }, a); } catch (d) { a(d); } }, i, a); } setDRACOLoader(e) { return this.dracoLoader = e, this; } setDDSLoader() { throw new Error( 'THREE.GLTFLoader: "MSFT_texture_dds" no longer supported. Please update to "KHR_texture_basisu".' ); } setKTX2Loader(e) { return this.ktx2Loader = e, this; } setMeshoptDecoder(e) { return this.meshoptDecoder = e, this; } register(e) { return this.pluginCallbacks.indexOf(e) === -1 && this.pluginCallbacks.push(e), this; } unregister(e) { return this.pluginCallbacks.indexOf(e) !== -1 && this.pluginCallbacks.splice(this.pluginCallbacks.indexOf(e), 1), this; } parse(e, t, i, r) { let s; const o = {}, a = {}; if (typeof e == "string") s = e; else if (ir.decodeText(new Uint8Array(e, 0, 4)) === dM) { try { o[gt.KHR_BINARY_GLTF] = new a4(e); } catch (h6) { r && r(h6); return; } s = o[gt.KHR_BINARY_GLTF].content; } else s = ir.decodeText(new Uint8Array(e)); const c = JSON.parse(s); if (c.asset === void 0 || c.asset.version[0] < 2) { r && r(new Error("THREE.GLTFLoader: Unsupported asset. glTF versions >=2.0 are supported.")); return; } const l = new v4(c, { path: t || this.resourcePath || "", crossOrigin: this.crossOrigin, requestHeader: this.requestHeader, manager: this.manager, ktx2Loader: this.ktx2Loader, meshoptDecoder: this.meshoptDecoder }); l.fileLoader.setRequestHeader(this.requestHeader); for (let d = 0; d < this.pluginCallbacks.length; d++) { const h6 = this.pluginCallbacks[d](l); a[h6.name] = h6, o[h6.name] = true; } if (c.extensionsUsed) for (let d = 0; d < c.extensionsUsed.length; ++d) { const h6 = c.extensionsUsed[d], f = c.extensionsRequired || []; switch (h6) { case gt.KHR_MATERIALS_UNLIT: o[h6] = new t4(); break; case gt.KHR_MATERIALS_PBR_SPECULAR_GLOSSINESS: o[h6] = new u4(); break; case gt.KHR_DRACO_MESH_COMPRESSION: o[h6] = new l4(c, this.dracoLoader); break; case gt.KHR_TEXTURE_TRANSFORM: o[h6] = new c4(); break; case gt.KHR_MESH_QUANTIZATION: o[h6] = new h4(); break; default: f.indexOf(h6) >= 0 && a[h6] === void 0 && console.warn('THREE.GLTFLoader: Unknown extension "' + h6 + '".'); } } l.setExtensions(o), l.setPlugins(a), l.parse(i, r); } }; function QB() { let n = {}; return { get: function(e) { return n[e]; }, add: function(e, t) { n[e] = t; }, remove: function(e) { delete n[e]; }, removeAll: function() { n = {}; } }; } var gt = { KHR_BINARY_GLTF: "KHR_binary_glTF", KHR_DRACO_MESH_COMPRESSION: "KHR_draco_mesh_compression", KHR_LIGHTS_PUNCTUAL: "KHR_lights_punctual", KHR_MATERIALS_CLEARCOAT: "KHR_materials_clearcoat", KHR_MATERIALS_PBR_SPECULAR_GLOSSINESS: "KHR_materials_pbrSpecularGlossiness", KHR_MATERIALS_TRANSMISSION: "KHR_materials_transmission", KHR_MATERIALS_UNLIT: "KHR_materials_unlit", KHR_TEXTURE_BASISU: "KHR_texture_basisu", KHR_TEXTURE_TRANSFORM: "KHR_texture_transform", KHR_MESH_QUANTIZATION: "KHR_mesh_quantization", EXT_TEXTURE_WEBP: "EXT_texture_webp", EXT_MESHOPT_COMPRESSION: "EXT_meshopt_compression" }; var e4 = class { constructor(e) { this.parser = e, this.name = gt.KHR_LIGHTS_PUNCTUAL, this.cache = { refs: {}, uses: {} }; } _markDefs() { const e = this.parser, t = this.parser.json.nodes || []; for (let i = 0, r = t.length; i < r; i++) { const s = t[i]; s.extensions && s.extensions[this.name] && s.extensions[this.name].light !== void 0 && e._addNodeRef(this.cache, s.extensions[this.name].light); } } _loadLight(e) { const t = this.parser, i = "light:" + e; let r = t.cache.get(i); if (r) return r; const s = t.json, c = ((s.extensions && s.extensions[this.name] || {}).lights || [])[e]; let l; const d = new Ue(16777215); c.color !== void 0 && d.fromArray(c.color); const h6 = c.range !== void 0 ? c.range : 0; switch (c.type) { case "directional": l = new Ru(d), l.target.position.set(0, 0, -1), l.add(l.target); break; case "point": l = new Lu(d), l.distance = h6; break; case "spot": l = new Cu(d), l.distance = h6, c.spot = c.spot || {}, c.spot.innerConeAngle = c.spot.innerConeAngle !== void 0 ? c.spot.innerConeAngle : 0, c.spot.outerConeAngle = c.spot.outerConeAngle !== void 0 ? c.spot.outerConeAngle : Math.PI / 4, l.angle = c.spot.outerConeAngle, l.penumbra = 1 - c.spot.innerConeAngle / c.spot.outerConeAngle, l.target.position.set(0, 0, -1), l.add(l.target); break; default: throw new Error("THREE.GLTFLoader: Unexpected light type: " + c.type); } return l.position.set(0, 0, 0), l.decay = 2, c.intensity !== void 0 && (l.intensity = c.intensity), l.name = t.createUniqueName(c.name || "light_" + e), r = Promise.resolve(l), t.cache.add(i, r), r; } createNodeAttachment(e) { const t = this, i = this.parser, s = i.json.nodes[e], a = (s.extensions && s.extensions[this.name] || {}).light; return a === void 0 ? null : this._loadLight(a).then(function(c) { return i._getNodeRef(t.cache, a, c); }); } }; var t4 = class { constructor() { this.name = gt.KHR_MATERIALS_UNLIT; } getMaterialType() { return In; } extendParams(e, t, i) { const r = []; e.color = new Ue(1, 1, 1), e.opacity = 1; const s = t.pbrMetallicRoughness; if (s) { if (Array.isArray(s.baseColorFactor)) { const o = s.baseColorFactor; e.color.fromArray(o), e.opacity = o[3]; } s.baseColorTexture !== void 0 && r.push(i.assignTexture(e, "map", s.baseColorTexture)); } return Promise.all(r); } }; var n4 = class { constructor(e) { this.parser = e, this.name = gt.KHR_MATERIALS_CLEARCOAT; } getMaterialType(e) { const i = this.parser.json.materials[e]; return !i.extensions || !i.extensions[this.name] ? null : wl; } extendMaterialParams(e, t) { const i = this.parser, r = i.json.materials[e]; if (!r.extensions || !r.extensions[this.name]) return Promise.resolve(); const s = [], o = r.extensions[this.name]; if (o.clearcoatFactor !== void 0 && (t.clearcoat = o.clearcoatFactor), o.clearcoatTexture !== void 0 && s.push(i.assignTexture(t, "clearcoatMap", o.clearcoatTexture)), o.clearcoatRoughnessFactor !== void 0 && (t.clearcoatRoughness = o.clearcoatRoughnessFactor), o.clearcoatRoughnessTexture !== void 0 && s.push(i.assignTexture(t, "clearcoatRoughnessMap", o.clearcoatRoughnessTexture)), o.clearcoatNormalTexture !== void 0 && (s.push(i.assignTexture(t, "clearcoatNormalMap", o.clearcoatNormalTexture)), o.clearcoatNormalTexture.scale !== void 0)) { const a = o.clearcoatNormalTexture.scale; t.clearcoatNormalScale = new Re(a, -a); } return Promise.all(s); } }; var i4 = class { constructor(e) { this.parser = e, this.name = gt.KHR_MATERIALS_TRANSMISSION; } getMaterialType(e) { const i = this.parser.json.materials[e]; return !i.extensions || !i.extensions[this.name] ? null : wl; } extendMaterialParams(e, t) { const i = this.parser, r = i.json.materials[e]; if (!r.extensions || !r.extensions[this.name]) return Promise.resolve(); const s = [], o = r.extensions[this.name]; return o.transmissionFactor !== void 0 && (t.transmission = o.transmissionFactor), o.transmissionTexture !== void 0 && s.push(i.assignTexture(t, "transmissionMap", o.transmissionTexture)), Promise.all(s); } }; var r4 = class { constructor(e) { this.parser = e, this.name = gt.KHR_TEXTURE_BASISU; } loadTexture(e) { const t = this.parser, i = t.json, r = i.textures[e]; if (!r.extensions || !r.extensions[this.name]) return null; const s = r.extensions[this.name], o = i.images[s.source], a = t.options.ktx2Loader; if (!a) { if (i.extensionsRequired && i.extensionsRequired.indexOf(this.name) >= 0) throw new Error("THREE.GLTFLoader: setKTX2Loader must be called before loading KTX2 textures"); return null; } return t.loadTextureImage(e, o, a); } }; var s4 = class { constructor(e) { this.parser = e, this.name = gt.EXT_TEXTURE_WEBP, this.isSupported = null; } loadTexture(e) { const t = this.name, i = this.parser, r = i.json, s = r.textures[e]; if (!s.extensions || !s.extensions[t]) return null; const o = s.extensions[t], a = r.images[o.source]; let c = i.textureLoader; if (a.uri) { const l = i.options.manager.getHandler(a.uri); l !== null && (c = l); } return this.detectSupport().then(function(l) { if (l) return i.loadTextureImage(e, a, c); if (r.extensionsRequired && r.extensionsRequired.indexOf(t) >= 0) throw new Error("THREE.GLTFLoader: WebP required by asset but unsupported."); return i.loadTexture(e); }); } detectSupport() { return this.isSupported || (this.isSupported = new Promise(function(e) { const t = new Image(); t.src = "", t.onload = t.onerror = function() { e(t.height === 1); }; })), this.isSupported; } }; var o4 = class { constructor(e) { this.name = gt.EXT_MESHOPT_COMPRESSION, this.parser = e; } loadBufferView(e) { const t = this.parser.json, i = t.bufferViews[e]; if (i.extensions && i.extensions[this.name]) { const r = i.extensions[this.name], s = this.parser.getDependency("buffer", r.buffer), o = this.parser.options.meshoptDecoder; if (!o || !o.supported) { if (t.extensionsRequired && t.extensionsRequired.indexOf(this.name) >= 0) throw new Error("THREE.GLTFLoader: setMeshoptDecoder must be called before loading compressed files"); return null; } return Promise.all([s, o.ready]).then(function(a) { const c = r.byteOffset || 0, l = r.byteLength || 0, d = r.count, h6 = r.byteStride, f = new ArrayBuffer(d * h6), g = new Uint8Array(a[0], c, l); return o.decodeGltfBuffer(new Uint8Array(f), d, h6, g, r.mode, r.filter), f; }); } else return null; } }; var dM = "glTF"; var Aa = 12; var mv = { JSON: 1313821514, BIN: 5130562 }; var a4 = class { constructor(e) { this.name = gt.KHR_BINARY_GLTF, this.content = null, this.body = null; const t = new DataView(e, 0, Aa); if (this.header = { magic: ir.decodeText(new Uint8Array(e.slice(0, 4))), version: t.getUint32(4, true), length: t.getUint32(8, true) }, this.header.magic !== dM) throw new Error("THREE.GLTFLoader: Unsupported glTF-Binary header."); if (this.header.version < 2) throw new Error("THREE.GLTFLoader: Legacy binary file detected."); const i = this.header.length - Aa, r = new DataView(e, Aa); let s = 0; for (; s < i; ) { const o = r.getUint32(s, true); s += 4; const a = r.getUint32(s, true); if (s += 4, a === mv.JSON) { const c = new Uint8Array(e, Aa + s, o); this.content = ir.decodeText(c); } else if (a === mv.BIN) { const c = Aa + s; this.body = e.slice(c, c + o); } s += o; } if (this.content === null) throw new Error("THREE.GLTFLoader: JSON content not found."); } }; var l4 = class { constructor(e, t) { if (!t) throw new Error("THREE.GLTFLoader: No DRACOLoader instance provided."); this.name = gt.KHR_DRACO_MESH_COMPRESSION, this.json = e, this.dracoLoader = t, this.dracoLoader.preload(); } decodePrimitive(e, t) { const i = this.json, r = this.dracoLoader, s = e.extensions[this.name].bufferView, o = e.extensions[this.name].attributes, a = {}, c = {}, l = {}; for (const d in o) { const h6 = Ld[d] || d.toLowerCase(); a[h6] = o[d]; } for (const d in e.attributes) { const h6 = Ld[d] || d.toLowerCase(); if (o[d] !== void 0) { const f = i.accessors[e.attributes[d]], g = Ka[f.componentType]; l[h6] = g, c[h6] = f.normalized === true; } } return t.getDependency("bufferView", s).then(function(d) { return new Promise(function(h6) { r.decodeDracoFile(d, function(f) { for (const g in f.attributes) { const p = f.attributes[g], u = c[g]; u !== void 0 && (p.normalized = u); } h6(f); }, a, l); }); }); } }; var c4 = class { constructor() { this.name = gt.KHR_TEXTURE_TRANSFORM; } extendTexture(e, t) { return t.texCoord !== void 0 && console.warn('THREE.GLTFLoader: Custom UV sets in "' + this.name + '" extension not yet supported.'), t.offset === void 0 && t.rotation === void 0 && t.scale === void 0 || (e = e.clone(), t.offset !== void 0 && e.offset.fromArray(t.offset), t.rotation !== void 0 && (e.rotation = t.rotation), t.scale !== void 0 && e.repeat.fromArray(t.scale), e.needsUpdate = true), e; } }; var Cd = class extends zs { constructor(e) { super(), this.isGLTFSpecularGlossinessMaterial = true; const t = [ "#ifdef USE_SPECULARMAP", " uniform sampler2D specularMap;", "#endif" ].join(` `), i = [ "#ifdef USE_GLOSSINESSMAP", " uniform sampler2D glossinessMap;", "#endif" ].join(` `), r = [ "vec3 specularFactor = specular;", "#ifdef USE_SPECULARMAP", " vec4 texelSpecular = texture2D( specularMap, vUv );", " texelSpecular = sRGBToLinear( texelSpecular );", " // reads channel RGB, compatible with a glTF Specular-Glossiness (RGBA) texture", " specularFactor *= texelSpecular.rgb;", "#endif" ].join(` `), s = [ "float glossinessFactor = glossiness;", "#ifdef USE_GLOSSINESSMAP", " vec4 texelGlossiness = texture2D( glossinessMap, vUv );", " // reads channel A, compatible with a glTF Specular-Glossiness (RGBA) texture", " glossinessFactor *= texelGlossiness.a;", "#endif" ].join(` `), o = [ "PhysicalMaterial material;", "material.diffuseColor = diffuseColor.rgb * ( 1. - max( specularFactor.r, max( specularFactor.g, specularFactor.b ) ) );", "vec3 dxy = max( abs( dFdx( geometryNormal ) ), abs( dFdy( geometryNormal ) ) );", "float geometryRoughness = max( max( dxy.x, dxy.y ), dxy.z );", "material.specularRoughness = max( 1.0 - glossinessFactor, 0.0525 ); // 0.0525 corresponds to the base mip of a 256 cubemap.", "material.specularRoughness += geometryRoughness;", "material.specularRoughness = min( material.specularRoughness, 1.0 );", "material.specularColor = specularFactor;" ].join(` `), a = { specular: { value: new Ue().setHex(16777215) }, glossiness: { value: 1 }, specularMap: { value: null }, glossinessMap: { value: null } }; this._extraUniforms = a, this.onBeforeCompile = function(c) { for (const l in a) c.uniforms[l] = a[l]; c.fragmentShader = c.fragmentShader.replace("uniform float roughness;", "uniform vec3 specular;").replace("uniform float metalness;", "uniform float glossiness;").replace("#include ", t).replace("#include ", i).replace("#include ", r).replace("#include ", s).replace("#include ", o); }, Object.defineProperties(this, { specular: { get: function() { return a.specular.value; }, set: function(c) { a.specular.value = c; } }, specularMap: { get: function() { return a.specularMap.value; }, set: function(c) { a.specularMap.value = c, c ? this.defines.USE_SPECULARMAP = "" : delete this.defines.USE_SPECULARMAP; } }, glossiness: { get: function() { return a.glossiness.value; }, set: function(c) { a.glossiness.value = c; } }, glossinessMap: { get: function() { return a.glossinessMap.value; }, set: function(c) { a.glossinessMap.value = c, c ? (this.defines.USE_GLOSSINESSMAP = "", this.defines.USE_UV = "") : (delete this.defines.USE_GLOSSINESSMAP, delete this.defines.USE_UV); } } }), delete this.metalness, delete this.roughness, delete this.metalnessMap, delete this.roughnessMap, this.setValues(e); } copy(e) { return super.copy(e), this.specularMap = e.specularMap, this.specular.copy(e.specular), this.glossinessMap = e.glossinessMap, this.glossiness = e.glossiness, delete this.metalness, delete this.roughness, delete this.metalnessMap, delete this.roughnessMap, this; } }; var u4 = class { constructor() { this.name = gt.KHR_MATERIALS_PBR_SPECULAR_GLOSSINESS, this.specularGlossinessParams = [ "color", "map", "lightMap", "lightMapIntensity", "aoMap", "aoMapIntensity", "emissive", "emissiveIntensity", "emissiveMap", "bumpMap", "bumpScale", "normalMap", "normalMapType", "displacementMap", "displacementScale", "displacementBias", "specularMap", "specular", "glossinessMap", "glossiness", "alphaMap", "envMap", "envMapIntensity", "refractionRatio" ]; } getMaterialType() { return Cd; } extendParams(e, t, i) { const r = t.extensions[this.name]; e.color = new Ue(1, 1, 1), e.opacity = 1; const s = []; if (Array.isArray(r.diffuseFactor)) { const o = r.diffuseFactor; e.color.fromArray(o), e.opacity = o[3]; } if (r.diffuseTexture !== void 0 && s.push(i.assignTexture(e, "map", r.diffuseTexture)), e.emissive = new Ue(0, 0, 0), e.glossiness = r.glossinessFactor !== void 0 ? r.glossinessFactor : 1, e.specular = new Ue(1, 1, 1), Array.isArray(r.specularFactor) && e.specular.fromArray(r.specularFactor), r.specularGlossinessTexture !== void 0) { const o = r.specularGlossinessTexture; s.push(i.assignTexture(e, "glossinessMap", o)), s.push(i.assignTexture(e, "specularMap", o)); } return Promise.all(s); } createMaterial(e) { const t = new Cd(e); return t.fog = true, t.color = e.color, t.map = e.map === void 0 ? null : e.map, t.lightMap = null, t.lightMapIntensity = 1, t.aoMap = e.aoMap === void 0 ? null : e.aoMap, t.aoMapIntensity = 1, t.emissive = e.emissive, t.emissiveIntensity = 1, t.emissiveMap = e.emissiveMap === void 0 ? null : e.emissiveMap, t.bumpMap = e.bumpMap === void 0 ? null : e.bumpMap, t.bumpScale = 1, t.normalMap = e.normalMap === void 0 ? null : e.normalMap, t.normalMapType = Jr, e.normalScale && (t.normalScale = e.normalScale), t.displacementMap = null, t.displacementScale = 1, t.displacementBias = 0, t.specularMap = e.specularMap === void 0 ? null : e.specularMap, t.specular = e.specular, t.glossinessMap = e.glossinessMap === void 0 ? null : e.glossinessMap, t.glossiness = e.glossiness, t.alphaMap = null, t.envMap = e.envMap === void 0 ? null : e.envMap, t.envMapIntensity = 1, t.refractionRatio = 0.98, t; } }; var h4 = class { constructor() { this.name = gt.KHR_MESH_QUANTIZATION; } }; var $o = class extends Ni { constructor(e, t, i, r) { super(e, t, i, r); } copySampleValue_(e) { const t = this.resultBuffer, i = this.sampleValues, r = this.valueSize, s = e * r * 3 + r; for (let o = 0; o !== r; o++) t[o] = i[s + o]; return t; } }; $o.prototype.beforeStart_ = $o.prototype.copySampleValue_; $o.prototype.afterEnd_ = $o.prototype.copySampleValue_; $o.prototype.interpolate_ = function(n, e, t, i) { const r = this.resultBuffer, s = this.sampleValues, o = this.valueSize, a = o * 2, c = o * 3, l = i - e, d = (t - e) / l, h6 = d * d, f = h6 * d, g = n * c, p = g - c, u = -2 * f + 3 * h6, y = f - h6, v = 1 - u, m = y - h6 + d; for (let x = 0; x !== o; x++) { const w = s[p + x + o], A = s[p + x + a] * l, M = s[g + x + o], R = s[g + x] * l; r[x] = v * w + m * A + u * M + y * R; } return r; }; var Xi = { FLOAT: 5126, //FLOAT_MAT2: 35674, FLOAT_MAT3: 35675, FLOAT_MAT4: 35676, FLOAT_VEC2: 35664, FLOAT_VEC3: 35665, FLOAT_VEC4: 35666, LINEAR: 9729, REPEAT: 10497, SAMPLER_2D: 35678, POINTS: 0, LINES: 1, LINE_LOOP: 2, LINE_STRIP: 3, TRIANGLES: 4, TRIANGLE_STRIP: 5, TRIANGLE_FAN: 6, UNSIGNED_BYTE: 5121, UNSIGNED_SHORT: 5123 }; var Ka = { 5120: Int8Array, 5121: Uint8Array, 5122: Int16Array, 5123: Uint16Array, 5125: Uint32Array, 5126: Float32Array }; var gv = { 9728: $t, 9729: zt, 9984: ka, 9985: du, 9986: Ga, 9987: fr }; var vv = { 33071: hn2, 33648: Eo, 10497: jr }; var yv = { SCALAR: 1, VEC2: 2, VEC3: 3, VEC4: 4, MAT2: 4, MAT3: 9, MAT4: 16 }; var Ld = { POSITION: "position", NORMAL: "normal", TANGENT: "tangent", TEXCOORD_0: "uv", TEXCOORD_1: "uv2", COLOR_0: "color", WEIGHTS_0: "skinWeight", JOINTS_0: "skinIndex" }; var _r = { scale: "scale", translation: "position", rotation: "quaternion", weights: "morphTargetInfluences" }; var d4 = { CUBICSPLINE: void 0, // We use a custom interpolant (GLTFCubicSplineInterpolation) for CUBICSPLINE tracks. Each // keyframe track will be initialized with a default interpolation type, then modified. LINEAR: Es, STEP: Lo }; var Lh = { OPAQUE: "OPAQUE", MASK: "MASK", BLEND: "BLEND" }; function bv(n, e) { return typeof n != "string" || n === "" ? "" : (/^https?:\/\//i.test(e) && /^\//.test(n) && (e = e.replace(/(^https?:\/\/[^\/]+).*/i, "$1")), /^(https?:)?\/\//i.test(n) || /^data:.*,.*$/i.test(n) || /^blob:.*$/i.test(n) ? n : e + n); } function f4(n) { return n.DefaultMaterial === void 0 && (n.DefaultMaterial = new zs({ color: 16777215, emissive: 0, metalness: 1, roughness: 1, transparent: false, depthTest: true, side: Hr })), n.DefaultMaterial; } function Sa(n, e, t) { for (const i in t.extensions) n[i] === void 0 && (e.userData.gltfExtensions = e.userData.gltfExtensions || {}, e.userData.gltfExtensions[i] = t.extensions[i]); } function fs(n, e) { e.extras !== void 0 && (typeof e.extras == "object" ? Object.assign(n.userData, e.extras) : console.warn("THREE.GLTFLoader: Ignoring primitive type .extras, " + e.extras)); } function p4(n, e, t) { let i = false, r = false; for (let a = 0, c = e.length; a < c; a++) { const l = e[a]; if (l.POSITION !== void 0 && (i = true), l.NORMAL !== void 0 && (r = true), i && r) break; } if (!i && !r) return Promise.resolve(n); const s = [], o = []; for (let a = 0, c = e.length; a < c; a++) { const l = e[a]; if (i) { const d = l.POSITION !== void 0 ? t.getDependency("accessor", l.POSITION) : n.attributes.position; s.push(d); } if (r) { const d = l.NORMAL !== void 0 ? t.getDependency("accessor", l.NORMAL) : n.attributes.normal; o.push(d); } } return Promise.all([ Promise.all(s), Promise.all(o) ]).then(function(a) { const c = a[0], l = a[1]; return i && (n.morphAttributes.position = c), r && (n.morphAttributes.normal = l), n.morphTargetsRelative = true, n; }); } function m4(n, e) { if (n.updateMorphTargets(), e.weights !== void 0) for (let t = 0, i = e.weights.length; t < i; t++) n.morphTargetInfluences[t] = e.weights[t]; if (e.extras && Array.isArray(e.extras.targetNames)) { const t = e.extras.targetNames; if (n.morphTargetInfluences.length === t.length) { n.morphTargetDictionary = {}; for (let i = 0, r = t.length; i < r; i++) n.morphTargetDictionary[t[i]] = i; } else console.warn("THREE.GLTFLoader: Invalid extras.targetNames length. Ignoring names."); } } function g4(n) { const e = n.extensions && n.extensions[gt.KHR_DRACO_MESH_COMPRESSION]; let t; return e ? t = "draco:" + e.bufferView + ":" + e.indices + ":" + xv(e.attributes) : t = n.indices + ":" + xv(n.attributes) + ":" + n.mode, t; } function xv(n) { let e = ""; const t = Object.keys(n).sort(); for (let i = 0, r = t.length; i < r; i++) e += t[i] + ":" + n[t[i]] + ";"; return e; } function Rd(n) { switch (n) { case Int8Array: return 1 / 127; case Uint8Array: return 1 / 255; case Int16Array: return 1 / 32767; case Uint16Array: return 1 / 65535; default: throw new Error("THREE.GLTFLoader: Unsupported normalized accessor component type."); } } var v4 = class { constructor(e = {}, t = {}) { this.json = e, this.extensions = {}, this.plugins = {}, this.options = t, this.cache = new QB(), this.associations = /* @__PURE__ */ new Map(), this.primitiveCache = {}, this.meshCache = { refs: {}, uses: {} }, this.cameraCache = { refs: {}, uses: {} }, this.lightCache = { refs: {}, uses: {} }, this.textureCache = {}, this.nodeNamesUsed = {}, typeof createImageBitmap < "u" && /Firefox/.test(navigator.userAgent) === false ? this.textureLoader = new op(this.options.manager) : this.textureLoader = new qf(this.options.manager), this.textureLoader.setCrossOrigin(this.options.crossOrigin), this.textureLoader.setRequestHeader(this.options.requestHeader), this.fileLoader = new $n(this.options.manager), this.fileLoader.setResponseType("arraybuffer"), this.options.crossOrigin === "use-credentials" && this.fileLoader.setWithCredentials(true); } setExtensions(e) { this.extensions = e; } setPlugins(e) { this.plugins = e; } parse(e, t) { const i = this, r = this.json, s = this.extensions; this.cache.removeAll(), this._invokeAll(function(o) { return o._markDefs && o._markDefs(); }), Promise.all(this._invokeAll(function(o) { return o.beforeRoot && o.beforeRoot(); })).then(function() { return Promise.all([ i.getDependencies("scene"), i.getDependencies("animation"), i.getDependencies("camera") ]); }).then(function(o) { const a = { scene: o[0][r.scene || 0], scenes: o[0], animations: o[1], cameras: o[2], asset: r.asset, parser: i, userData: {} }; Sa(s, a, r), fs(a, r), Promise.all(i._invokeAll(function(c) { return c.afterRoot && c.afterRoot(a); })).then(function() { e(a); }); }).catch(t); } /** * Marks the special nodes/meshes in json for efficient parse. */ _markDefs() { const e = this.json.nodes || [], t = this.json.skins || [], i = this.json.meshes || []; for (let r = 0, s = t.length; r < s; r++) { const o = t[r].joints; for (let a = 0, c = o.length; a < c; a++) e[o[a]].isBone = true; } for (let r = 0, s = e.length; r < s; r++) { const o = e[r]; o.mesh !== void 0 && (this._addNodeRef(this.meshCache, o.mesh), o.skin !== void 0 && (i[o.mesh].isSkinnedMesh = true)), o.camera !== void 0 && this._addNodeRef(this.cameraCache, o.camera); } } /** * Counts references to shared node / Object3D resources. These resources * can be reused, or "instantiated", at multiple nodes in the scene * hierarchy. Mesh, Camera, and Light instances are instantiated and must * be marked. Non-scenegraph resources (like Materials, Geometries, and * Textures) can be reused directly and are not marked here. * * Example: CesiumMilkTruck sample model reuses "Wheel" meshes. */ _addNodeRef(e, t) { t !== void 0 && (e.refs[t] === void 0 && (e.refs[t] = e.uses[t] = 0), e.refs[t]++); } /** Returns a reference to a shared resource, cloning it if necessary. */ _getNodeRef(e, t, i) { if (e.refs[t] <= 1) return i; const r = i.clone(); return r.name += "_instance_" + e.uses[t]++, r; } _invokeOne(e) { const t = Object.values(this.plugins); t.push(this); for (let i = 0; i < t.length; i++) { const r = e(t[i]); if (r) return r; } return null; } _invokeAll(e) { const t = Object.values(this.plugins); t.unshift(this); const i = []; for (let r = 0; r < t.length; r++) { const s = e(t[r]); s && i.push(s); } return i; } /** * Requests the specified dependency asynchronously, with caching. * @param {string} type * @param {number} index * @return {Promise} */ getDependency(e, t) { const i = e + ":" + t; let r = this.cache.get(i); if (!r) { switch (e) { case "scene": r = this.loadScene(t); break; case "node": r = this.loadNode(t); break; case "mesh": r = this._invokeOne(function(s) { return s.loadMesh && s.loadMesh(t); }); break; case "accessor": r = this.loadAccessor(t); break; case "bufferView": r = this._invokeOne(function(s) { return s.loadBufferView && s.loadBufferView(t); }); break; case "buffer": r = this.loadBuffer(t); break; case "material": r = this._invokeOne(function(s) { return s.loadMaterial && s.loadMaterial(t); }); break; case "texture": r = this._invokeOne(function(s) { return s.loadTexture && s.loadTexture(t); }); break; case "skin": r = this.loadSkin(t); break; case "animation": r = this.loadAnimation(t); break; case "camera": r = this.loadCamera(t); break; default: throw new Error("Unknown type: " + e); } this.cache.add(i, r); } return r; } /** * Requests all dependencies of the specified type asynchronously, with caching. * @param {string} type * @return {Promise>} */ getDependencies(e) { let t = this.cache.get(e); if (!t) { const i = this, r = this.json[e + (e === "mesh" ? "es" : "s")] || []; t = Promise.all(r.map(function(s, o) { return i.getDependency(e, o); })), this.cache.add(e, t); } return t; } /** * Specification: https://github.com/KhronosGroup/glTF/blob/master/specification/2.0/README.md#buffers-and-buffer-views * @param {number} bufferIndex * @return {Promise} */ loadBuffer(e) { const t = this.json.buffers[e], i = this.fileLoader; if (t.type && t.type !== "arraybuffer") throw new Error("THREE.GLTFLoader: " + t.type + " buffer type is not supported."); if (t.uri === void 0 && e === 0) return Promise.resolve(this.extensions[gt.KHR_BINARY_GLTF].body); const r = this.options; return new Promise(function(s, o) { i.load(bv(t.uri, r.path), s, void 0, function() { o(new Error('THREE.GLTFLoader: Failed to load buffer "' + t.uri + '".')); }); }); } /** * Specification: https://github.com/KhronosGroup/glTF/blob/master/specification/2.0/README.md#buffers-and-buffer-views * @param {number} bufferViewIndex * @return {Promise} */ loadBufferView(e) { const t = this.json.bufferViews[e]; return this.getDependency("buffer", t.buffer).then(function(i) { const r = t.byteLength || 0, s = t.byteOffset || 0; return i.slice(s, s + r); }); } /** * Specification: https://github.com/KhronosGroup/glTF/blob/master/specification/2.0/README.md#accessors * @param {number} accessorIndex * @return {Promise} */ loadAccessor(e) { const t = this, i = this.json, r = this.json.accessors[e]; if (r.bufferView === void 0 && r.sparse === void 0) return Promise.resolve(null); const s = []; return r.bufferView !== void 0 ? s.push(this.getDependency("bufferView", r.bufferView)) : s.push(null), r.sparse !== void 0 && (s.push(this.getDependency("bufferView", r.sparse.indices.bufferView)), s.push(this.getDependency("bufferView", r.sparse.values.bufferView))), Promise.all(s).then(function(o) { const a = o[0], c = yv[r.type], l = Ka[r.componentType], d = l.BYTES_PER_ELEMENT, h6 = d * c, f = r.byteOffset || 0, g = r.bufferView !== void 0 ? i.bufferViews[r.bufferView].byteStride : void 0, p = r.normalized === true; let u, y; if (g && g !== h6) { const v = Math.floor(f / g), m = "InterleavedBuffer:" + r.bufferView + ":" + r.componentType + ":" + v + ":" + r.count; let x = t.cache.get(m); x || (u = new l(a, v * g, r.count * g / d), x = new Qr(u, g / d), t.cache.add(m, x)), y = new ar(x, c, f % g / d, p); } else a === null ? u = new l(r.count * c) : u = new l(a, f, r.count * c), y = new ot(u, c, p); if (r.sparse !== void 0) { const v = yv.SCALAR, m = Ka[r.sparse.indices.componentType], x = r.sparse.indices.byteOffset || 0, w = r.sparse.values.byteOffset || 0, A = new m(o[1], x, r.sparse.count * v), M = new l(o[2], w, r.sparse.count * c); a !== null && (y = new ot(y.array.slice(), y.itemSize, y.normalized)); for (let R = 0, L = A.length; R < L; R++) { const S = A[R]; if (y.setX(S, M[R * c]), c >= 2 && y.setY(S, M[R * c + 1]), c >= 3 && y.setZ(S, M[R * c + 2]), c >= 4 && y.setW(S, M[R * c + 3]), c >= 5) throw new Error("THREE.GLTFLoader: Unsupported itemSize in sparse BufferAttribute."); } } return y; }); } /** * Specification: https://github.com/KhronosGroup/glTF/tree/master/specification/2.0#textures * @param {number} textureIndex * @return {Promise} */ loadTexture(e) { const t = this.json, i = this.options, r = t.textures[e], s = t.images[r.source]; let o = this.textureLoader; if (s.uri) { const a = i.manager.getHandler(s.uri); a !== null && (o = a); } return this.loadTextureImage(e, s, o); } loadTextureImage(e, t, i) { const r = this, s = this.json, o = this.options, a = s.textures[e], c = (t.uri || t.bufferView) + ":" + a.sampler; if (this.textureCache[c]) return this.textureCache[c]; const l = self.URL || self.webkitURL; let d = t.uri || "", h6 = false, f = true; const g = d.search(/\.jpe?g($|\?)/i) > 0 || d.search(/^data\:image\/jpeg/) === 0; if ((t.mimeType === "image/jpeg" || g) && (f = false), t.bufferView !== void 0) d = r.getDependency("bufferView", t.bufferView).then(function(u) { if (t.mimeType === "image/png") { const v = new DataView(u, 25, 1).getUint8(0, false); f = v === 6 || v === 4 || v === 3; } h6 = true; const y = new Blob([u], { type: t.mimeType }); return d = l.createObjectURL(y), d; }); else if (t.uri === void 0) throw new Error("THREE.GLTFLoader: Image " + e + " is missing URI and bufferView"); const p = Promise.resolve(d).then(function(u) { return new Promise(function(y, v) { let m = y; i.isImageBitmapLoader === true && (m = function(x) { const w = new Yt(x); w.needsUpdate = true, y(w); }), i.load(bv(u, o.path), m, void 0, v); }); }).then(function(u) { h6 === true && l.revokeObjectURL(d), u.flipY = false, a.name && (u.name = a.name), f || (u.format = nr); const v = (s.samplers || {})[a.sampler] || {}; return u.magFilter = gv[v.magFilter] || zt, u.minFilter = gv[v.minFilter] || fr, u.wrapS = vv[v.wrapS] || jr, u.wrapT = vv[v.wrapT] || jr, r.associations.set(u, { type: "textures", index: e }), u; }).catch(function() { return console.error("THREE.GLTFLoader: Couldn't load texture", d), null; }); return this.textureCache[c] = p, p; } /** * Asynchronously assigns a texture to the given material parameters. * @param {Object} materialParams * @param {string} mapName * @param {Object} mapDef * @return {Promise} */ assignTexture(e, t, i) { const r = this; return this.getDependency("texture", i.index).then(function(s) { if (i.texCoord !== void 0 && i.texCoord != 0 && !(t === "aoMap" && i.texCoord == 1) && console.warn("THREE.GLTFLoader: Custom UV set " + i.texCoord + " for texture " + t + " not yet supported."), r.extensions[gt.KHR_TEXTURE_TRANSFORM]) { const o = i.extensions !== void 0 ? i.extensions[gt.KHR_TEXTURE_TRANSFORM] : void 0; if (o) { const a = r.associations.get(s); s = r.extensions[gt.KHR_TEXTURE_TRANSFORM].extendTexture(s, o), r.associations.set(s, a); } } e[t] = s; }); } /** * Assigns final material to a Mesh, Line, or Points instance. The instance * already has a material (generated from the glTF material options alone) * but reuse of the same glTF material may require multiple threejs materials * to accommodate different primitive types, defines, etc. New materials will * be created if necessary, and reused from a cache. * @param {Object3D} mesh Mesh, Line, or Points instance. */ assignFinalMaterial(e) { const t = e.geometry; let i = e.material; const r = t.attributes.tangent !== void 0, s = t.attributes.color !== void 0, o = t.attributes.normal === void 0, a = Object.keys(t.morphAttributes).length > 0, c = a && t.morphAttributes.normal !== void 0; if (e.isPoints) { const l = "PointsMaterial:" + i.uuid; let d = this.cache.get(l); d || (d = new es(), tn.prototype.copy.call(d, i), d.color.copy(i.color), d.map = i.map, d.sizeAttenuation = false, this.cache.add(l, d)), i = d; } else if (e.isLine) { const l = "LineBasicMaterial:" + i.uuid; let d = this.cache.get(l); d || (d = new an(), tn.prototype.copy.call(d, i), d.color.copy(i.color), this.cache.add(l, d)), i = d; } if (r || s || o || a) { let l = "ClonedMaterial:" + i.uuid + ":"; i.isGLTFSpecularGlossinessMaterial && (l += "specular-glossiness:"), r && (l += "vertex-tangents:"), s && (l += "vertex-colors:"), o && (l += "flat-shading:"), a && (l += "morph-targets:"), c && (l += "morph-normals:"); let d = this.cache.get(l); d || (d = i.clone(), s && (d.vertexColors = true), o && (d.flatShading = true), a && (d.morphTargets = true), c && (d.morphNormals = true), r && (d.vertexTangents = true, d.normalScale && (d.normalScale.y *= -1), d.clearcoatNormalScale && (d.clearcoatNormalScale.y *= -1)), this.cache.add(l, d), this.associations.set(d, this.associations.get(i))), i = d; } i.aoMap && t.attributes.uv2 === void 0 && t.attributes.uv !== void 0 && t.setAttribute("uv2", t.attributes.uv), e.material = i; } getMaterialType() { return zs; } /** * Specification: https://github.com/KhronosGroup/glTF/blob/master/specification/2.0/README.md#materials * @param {number} materialIndex * @return {Promise} */ loadMaterial(e) { const t = this, i = this.json, r = this.extensions, s = i.materials[e]; let o; const a = {}, c = s.extensions || {}, l = []; if (c[gt.KHR_MATERIALS_PBR_SPECULAR_GLOSSINESS]) { const h6 = r[gt.KHR_MATERIALS_PBR_SPECULAR_GLOSSINESS]; o = h6.getMaterialType(), l.push(h6.extendParams(a, s, t)); } else if (c[gt.KHR_MATERIALS_UNLIT]) { const h6 = r[gt.KHR_MATERIALS_UNLIT]; o = h6.getMaterialType(), l.push(h6.extendParams(a, s, t)); } else { const h6 = s.pbrMetallicRoughness || {}; if (a.color = new Ue(1, 1, 1), a.opacity = 1, Array.isArray(h6.baseColorFactor)) { const f = h6.baseColorFactor; a.color.fromArray(f), a.opacity = f[3]; } h6.baseColorTexture !== void 0 && l.push(t.assignTexture(a, "map", h6.baseColorTexture)), a.metalness = h6.metallicFactor !== void 0 ? h6.metallicFactor : 1, a.roughness = h6.roughnessFactor !== void 0 ? h6.roughnessFactor : 1, h6.metallicRoughnessTexture !== void 0 && (l.push(t.assignTexture(a, "metalnessMap", h6.metallicRoughnessTexture)), l.push(t.assignTexture(a, "roughnessMap", h6.metallicRoughnessTexture))), o = this._invokeOne(function(f) { return f.getMaterialType && f.getMaterialType(e); }), l.push(Promise.all(this._invokeAll(function(f) { return f.extendMaterialParams && f.extendMaterialParams(e, a); }))); } s.doubleSided === true && (a.side = Wr); const d = s.alphaMode || Lh.OPAQUE; return d === Lh.BLEND ? (a.transparent = true, a.depthWrite = false) : (a.transparent = false, d === Lh.MASK && (a.alphaTest = s.alphaCutoff !== void 0 ? s.alphaCutoff : 0.5)), s.normalTexture !== void 0 && o !== In && (l.push(t.assignTexture(a, "normalMap", s.normalTexture)), a.normalScale = new Re(1, -1), s.normalTexture.scale !== void 0 && a.normalScale.set(s.normalTexture.scale, -s.normalTexture.scale)), s.occlusionTexture !== void 0 && o !== In && (l.push(t.assignTexture(a, "aoMap", s.occlusionTexture)), s.occlusionTexture.strength !== void 0 && (a.aoMapIntensity = s.occlusionTexture.strength)), s.emissiveFactor !== void 0 && o !== In && (a.emissive = new Ue().fromArray(s.emissiveFactor)), s.emissiveTexture !== void 0 && o !== In && l.push(t.assignTexture(a, "emissiveMap", s.emissiveTexture)), Promise.all(l).then(function() { let h6; return o === Cd ? h6 = r[gt.KHR_MATERIALS_PBR_SPECULAR_GLOSSINESS].createMaterial(a) : h6 = new o(a), s.name && (h6.name = s.name), h6.map && (h6.map.encoding = Cs), h6.emissiveMap && (h6.emissiveMap.encoding = Cs), fs(h6, s), t.associations.set(h6, { type: "materials", index: e }), s.extensions && Sa(r, h6, s), h6; }); } /** When Object3D instances are targeted by animation, they need unique names. */ createUniqueName(e) { const t = mt.sanitizeNodeName(e || ""); let i = t; for (let r = 1; this.nodeNamesUsed[i]; ++r) i = t + "_" + r; return this.nodeNamesUsed[i] = true, i; } /** * Specification: https://github.com/KhronosGroup/glTF/blob/master/specification/2.0/README.md#geometry * * Creates BufferGeometries from primitives. * * @param {Array} primitives * @return {Promise>} */ loadGeometries(e) { const t = this, i = this.extensions, r = this.primitiveCache; function s(a) { return i[gt.KHR_DRACO_MESH_COMPRESSION].decodePrimitive(a, t).then(function(c) { return Mv(c, a, t); }); } const o = []; for (let a = 0, c = e.length; a < c; a++) { const l = e[a], d = g4(l), h6 = r[d]; if (h6) o.push(h6.promise); else { let f; l.extensions && l.extensions[gt.KHR_DRACO_MESH_COMPRESSION] ? f = s(l) : f = Mv(new Ke(), l, t), r[d] = { primitive: l, promise: f }, o.push(f); } } return Promise.all(o); } /** * Specification: https://github.com/KhronosGroup/glTF/blob/master/specification/2.0/README.md#meshes * @param {number} meshIndex * @return {Promise} */ loadMesh(e) { const t = this, i = this.json, r = this.extensions, s = i.meshes[e], o = s.primitives, a = []; for (let c = 0, l = o.length; c < l; c++) { const d = o[c].material === void 0 ? f4(this.cache) : this.getDependency("material", o[c].material); a.push(d); } return a.push(t.loadGeometries(o)), Promise.all(a).then(function(c) { const l = c.slice(0, c.length - 1), d = c[c.length - 1], h6 = []; for (let g = 0, p = d.length; g < p; g++) { const u = d[g], y = o[g]; let v; const m = l[g]; if (y.mode === Xi.TRIANGLES || y.mode === Xi.TRIANGLE_STRIP || y.mode === Xi.TRIANGLE_FAN || y.mode === void 0) v = s.isSkinnedMesh === true ? new vl(u, m) : new Xt(u, m), v.isSkinnedMesh === true && !v.geometry.attributes.skinWeight.normalized && v.normalizeSkinWeights(), y.mode === Xi.TRIANGLE_STRIP ? v.geometry = wv(v.geometry, Zb) : y.mode === Xi.TRIANGLE_FAN && (v.geometry = wv(v.geometry, wf)); else if (y.mode === Xi.LINES) v = new Rn(u, m); else if (y.mode === Xi.LINE_STRIP) v = new Oi(u, m); else if (y.mode === Xi.LINE_LOOP) v = new Au(u, m); else if (y.mode === Xi.POINTS) v = new ia(u, m); else throw new Error("THREE.GLTFLoader: Primitive mode unsupported: " + y.mode); Object.keys(v.geometry.morphAttributes).length > 0 && m4(v, s), v.name = t.createUniqueName(s.name || "mesh_" + e), fs(v, s), y.extensions && Sa(r, v, y), t.assignFinalMaterial(v), h6.push(v); } if (h6.length === 1) return h6[0]; const f = new _i(); for (let g = 0, p = h6.length; g < p; g++) f.add(h6[g]); return f; }); } /** * Specification: https://github.com/KhronosGroup/glTF/tree/master/specification/2.0#cameras * @param {number} cameraIndex * @return {Promise} */ loadCamera(e) { let t; const i = this.json.cameras[e], r = i[i.type]; if (!r) { console.warn("THREE.GLTFLoader: Missing camera parameters."); return; } return i.type === "perspective" ? t = new nn(xd.radToDeg(r.yfov), r.aspectRatio || 1, r.znear || 1, r.zfar || 2e6) : i.type === "orthographic" && (t = new sa(-r.xmag, r.xmag, r.ymag, -r.ymag, r.znear, r.zfar)), i.name && (t.name = this.createUniqueName(i.name)), fs(t, i), Promise.resolve(t); } /** * Specification: https://github.com/KhronosGroup/glTF/tree/master/specification/2.0#skins * @param {number} skinIndex * @return {Promise} */ loadSkin(e) { const t = this.json.skins[e], i = { joints: t.joints }; return t.inverseBindMatrices === void 0 ? Promise.resolve(i) : this.getDependency("accessor", t.inverseBindMatrices).then(function(r) { return i.inverseBindMatrices = r, i; }); } /** * Specification: https://github.com/KhronosGroup/glTF/tree/master/specification/2.0#animations * @param {number} animationIndex * @return {Promise} */ loadAnimation(e) { const i = this.json.animations[e], r = [], s = [], o = [], a = [], c = []; for (let l = 0, d = i.channels.length; l < d; l++) { const h6 = i.channels[l], f = i.samplers[h6.sampler], g = h6.target, p = g.node !== void 0 ? g.node : g.id, u = i.parameters !== void 0 ? i.parameters[f.input] : f.input, y = i.parameters !== void 0 ? i.parameters[f.output] : f.output; r.push(this.getDependency("node", p)), s.push(this.getDependency("accessor", u)), o.push(this.getDependency("accessor", y)), a.push(f), c.push(g); } return Promise.all([ Promise.all(r), Promise.all(s), Promise.all(o), Promise.all(a), Promise.all(c) ]).then(function(l) { const d = l[0], h6 = l[1], f = l[2], g = l[3], p = l[4], u = []; for (let v = 0, m = d.length; v < m; v++) { const x = d[v], w = h6[v], A = f[v], M = g[v], R = p[v]; if (x === void 0) continue; x.updateMatrix(), x.matrixAutoUpdate = true; let L; switch (_r[R.path]) { case _r.weights: L = Ho; break; case _r.rotation: L = ks; break; case _r.position: case _r.scale: default: L = Wo; break; } const S = x.name ? x.name : x.uuid, I = M.interpolation !== void 0 ? d4[M.interpolation] : Es, T = []; _r[R.path] === _r.weights ? x.traverse(function(E) { E.isMesh === true && E.morphTargetInfluences && T.push(E.name ? E.name : E.uuid); }) : T.push(S); let _ = A.array; if (A.normalized) { const E = Rd(_.constructor), C = new Float32Array(_.length); for (let P = 0, b = _.length; P < b; P++) C[P] = _[P] * E; _ = C; } for (let E = 0, C = T.length; E < C; E++) { const P = new L( T[E] + "." + _r[R.path], w.array, _, I ); M.interpolation === "CUBICSPLINE" && (P.createInterpolant = function(F) { return new $o(this.times, this.values, this.getValueSize() / 3, F); }, P.createInterpolant.isInterpolantFactoryMethodGLTFCubicSpline = true), u.push(P); } } const y = i.name ? i.name : "animation_" + e; return new jo(y, void 0, u); }); } createNodeMesh(e) { const t = this.json, i = this, r = t.nodes[e]; return r.mesh === void 0 ? null : i.getDependency("mesh", r.mesh).then(function(s) { const o = i._getNodeRef(i.meshCache, r.mesh, s); return r.weights !== void 0 && o.traverse(function(a) { if (a.isMesh) for (let c = 0, l = r.weights.length; c < l; c++) a.morphTargetInfluences[c] = r.weights[c]; }), o; }); } /** * Specification: https://github.com/KhronosGroup/glTF/tree/master/specification/2.0#nodes-and-hierarchy * @param {number} nodeIndex * @return {Promise} */ loadNode(e) { const t = this.json, i = this.extensions, r = this, s = t.nodes[e], o = s.name ? r.createUniqueName(s.name) : ""; return function() { const a = [], c = r._invokeOne(function(l) { return l.createNodeMesh && l.createNodeMesh(e); }); return c && a.push(c), s.camera !== void 0 && a.push(r.getDependency("camera", s.camera).then(function(l) { return r._getNodeRef(r.cameraCache, s.camera, l); })), r._invokeAll(function(l) { return l.createNodeAttachment && l.createNodeAttachment(e); }).forEach(function(l) { a.push(l); }), Promise.all(a); }().then(function(a) { let c; if (s.isBone === true ? c = new yl() : a.length > 1 ? c = new _i() : a.length === 1 ? c = a[0] : c = new ut(), c !== a[0]) for (let l = 0, d = a.length; l < d; l++) c.add(a[l]); if (s.name && (c.userData.name = s.name, c.name = o), fs(c, s), s.extensions && Sa(i, c, s), s.matrix !== void 0) { const l = new Xe(); l.fromArray(s.matrix), c.applyMatrix4(l); } else s.translation !== void 0 && c.position.fromArray(s.translation), s.rotation !== void 0 && c.quaternion.fromArray(s.rotation), s.scale !== void 0 && c.scale.fromArray(s.scale); return r.associations.set(c, { type: "nodes", index: e }), c; }); } /** * Specification: https://github.com/KhronosGroup/glTF/tree/master/specification/2.0#scenes * @param {number} sceneIndex * @return {Promise} */ loadScene(e) { const t = this.json, i = this.extensions, r = this.json.scenes[e], s = this, o = new _i(); r.name && (o.name = s.createUniqueName(r.name)), fs(o, r), r.extensions && Sa(i, o, r); const a = r.nodes || [], c = []; for (let l = 0, d = a.length; l < d; l++) c.push(fM(a[l], o, t, s)); return Promise.all(c).then(function() { return o; }); } }; function fM(n, e, t, i) { const r = t.nodes[n]; return i.getDependency("node", n).then(function(s) { if (r.skin === void 0) return s; let o; return i.getDependency("skin", r.skin).then(function(a) { o = a; const c = []; for (let l = 0, d = o.joints.length; l < d; l++) c.push(i.getDependency("node", o.joints[l])); return Promise.all(c); }).then(function(a) { return s.traverse(function(c) { if (!c.isMesh) return; const l = [], d = []; for (let h6 = 0, f = a.length; h6 < f; h6++) { const g = a[h6]; if (g) { l.push(g); const p = new Xe(); o.inverseBindMatrices !== void 0 && p.fromArray(o.inverseBindMatrices.array, h6 * 16), d.push(p); } else console.warn('THREE.GLTFLoader: Joint "%s" could not be found.', o.joints[h6]); } c.bind(new bl(l, d), c.matrixWorld); }), s; }); }).then(function(s) { e.add(s); const o = []; if (r.children) { const a = r.children; for (let c = 0, l = a.length; c < l; c++) { const d = a[c]; o.push(fM(d, s, t, i)); } } return Promise.all(o); }); } function y4(n, e, t) { const i = e.attributes, r = new Nn(); if (i.POSITION !== void 0) { const a = t.json.accessors[i.POSITION], c = a.min, l = a.max; if (c !== void 0 && l !== void 0) { if (r.set( new q(c[0], c[1], c[2]), new q(l[0], l[1], l[2]) ), a.normalized) { const d = Rd(Ka[a.componentType]); r.min.multiplyScalar(d), r.max.multiplyScalar(d); } } else { console.warn("THREE.GLTFLoader: Missing min/max properties for accessor POSITION."); return; } } else return; const s = e.targets; if (s !== void 0) { const a = new q(), c = new q(); for (let l = 0, d = s.length; l < d; l++) { const h6 = s[l]; if (h6.POSITION !== void 0) { const f = t.json.accessors[h6.POSITION], g = f.min, p = f.max; if (g !== void 0 && p !== void 0) { if (c.setX(Math.max(Math.abs(g[0]), Math.abs(p[0]))), c.setY(Math.max(Math.abs(g[1]), Math.abs(p[1]))), c.setZ(Math.max(Math.abs(g[2]), Math.abs(p[2]))), f.normalized) { const u = Rd(Ka[f.componentType]); c.multiplyScalar(u); } a.max(c); } else console.warn("THREE.GLTFLoader: Missing min/max properties for accessor POSITION."); } } r.expandByVector(a); } n.boundingBox = r; const o = new pr(); r.getCenter(o.center), o.radius = r.min.distanceTo(r.max) / 2, n.boundingSphere = o; } function Mv(n, e, t) { const i = e.attributes, r = []; function s(o, a) { return t.getDependency("accessor", o).then(function(c) { n.setAttribute(a, c); }); } for (const o in i) { const a = Ld[o] || o.toLowerCase(); a in n.attributes || r.push(s(i[o], a)); } if (e.indices !== void 0 && !n.index) { const o = t.getDependency("accessor", e.indices).then(function(a) { n.setIndex(a); }); r.push(o); } return fs(n, e), y4(n, e, t), Promise.all(r).then(function() { return e.targets !== void 0 ? p4(n, e.targets, t) : n; }); } function wv(n, e) { let t = n.getIndex(); if (t === null) { const o = [], a = n.getAttribute("position"); if (a !== void 0) { for (let c = 0; c < a.count; c++) o.push(c); n.setIndex(o), t = n.getIndex(); } else return console.error("THREE.GLTFLoader.toTrianglesDrawMode(): Undefined position attribute. Processing not possible."), n; } const i = t.count - 2, r = []; if (e === wf) for (let o = 1; o <= i; o++) r.push(t.getX(0)), r.push(t.getX(o)), r.push(t.getX(o + 1)); else for (let o = 0; o < i; o++) o % 2 === 0 ? (r.push(t.getX(o)), r.push(t.getX(o + 1)), r.push(t.getX(o + 2))) : (r.push(t.getX(o + 2)), r.push(t.getX(o + 1)), r.push(t.getX(o))); r.length / 3 !== i && console.error("THREE.GLTFLoader.toTrianglesDrawMode(): Unable to generate correct amount of triangles."); const s = n.clone(); return s.setIndex(r), s; } var b4 = Object.freeze(Object.defineProperty({ __proto__: null, GLTFLoader: qB }, Symbol.toStringTag, { value: "Module" })); var x4 = au(b4); var Rh = { exports: {} }; var Av; function M4() { return Av || (Av = 1, function(n) { function e(l) { var d = {}; function h6(g) { if (d[g]) return d[g].exports; var p = d[g] = { /******/ i: g, /******/ l: false, /******/ exports: {} /******/ }; return l[g].call(p.exports, p, p.exports, h6), p.l = true, p.exports; } h6.m = l, h6.c = d, h6.i = function(g) { return g; }, h6.d = function(g, p, u) { h6.o(g, p) || Object.defineProperty(g, p, { /******/ configurable: false, /******/ enumerable: true, /******/ get: u /******/ }); }, h6.r = function(g) { Object.defineProperty(g, "__esModule", { value: true }); }, h6.n = function(g) { var p = g && g.__esModule ? ( /******/ function() { return g.default; } ) : ( /******/ function() { return g; } ); return h6.d(p, "a", p), p; }, h6.o = function(g, p) { return Object.prototype.hasOwnProperty.call(g, p); }, h6.p = "/", h6.oe = function(g) { throw console.error(g), g; }; var f = h6(h6.s = ENTRY_MODULE); return f.default || f; } var t = "[\\.|\\-|\\+|\\w|/|@]+", i = "\\(\\s*(/\\*.*?\\*/)?\\s*.*?(" + t + ").*?\\)"; function r(l) { return (l + "").replace(/[.?*+^$[\]\\(){}|-]/g, "\\$&"); } function s(l) { return !isNaN(1 * l); } function o(l, d, h6) { var f = {}; f[h6] = []; var g = d.toString(), p = g.match(/^function\s?\w*\(\w+,\s*\w+,\s*(\w+)\)/); if (!p) return f; for (var u = p[1], y = new RegExp("(\\\\n|\\W)" + r(u) + i, "g"), v; v = y.exec(g); ) v[3] !== "dll-reference" && f[h6].push(v[3]); for (y = new RegExp("\\(" + r(u) + '\\("(dll-reference\\s(' + t + '))"\\)\\)' + i, "g"); v = y.exec(g); ) l[v[2]] || (f[h6].push(v[1]), l[v[2]] = __webpack_require__(v[1]).m), f[v[2]] = f[v[2]] || [], f[v[2]].push(v[4]); for (var m = Object.keys(f), x = 0; x < m.length; x++) for (var w = 0; w < f[m[x]].length; w++) s(f[m[x]][w]) && (f[m[x]][w] = 1 * f[m[x]][w]); return f; } function a(l) { var d = Object.keys(l); return d.reduce(function(h6, f) { return h6 || l[f].length > 0; }, false); } function c(l, d) { for (var h6 = { main: [d] }, f = { main: [] }, g = { main: {} }; a(h6); ) for (var p = Object.keys(h6), u = 0; u < p.length; u++) { var y = p[u], v = h6[y], m = v.pop(); if (g[y] = g[y] || {}, !(g[y][m] || !l[y][m])) { g[y][m] = true, f[y] = f[y] || [], f[y].push(m); for (var x = o(l, l[y][m], y), w = Object.keys(x), A = 0; A < w.length; A++) h6[w[A]] = h6[w[A]] || [], h6[w[A]] = h6[w[A]].concat(x[w[A]]); } } return f; } n.exports = function(l, d) { d = d || {}; var h6 = { main: __webpack_modules__ }, f = d.all ? { main: Object.keys(h6.main) } : c(h6, l), g = ""; Object.keys(f).filter(function(m) { return m !== "main"; }).forEach(function(m) { for (var x = 0; f[m][x]; ) x++; f[m].push(x), h6[m][x] = "(function(module, exports, __webpack_require__) { module.exports = __webpack_require__; })", g = g + "var " + m + " = (" + e.toString().replace("ENTRY_MODULE", JSON.stringify(x)) + ")({" + f[m].map(function(w) { return "" + JSON.stringify(w) + ": " + h6[m][w].toString(); }).join(",") + `}); `; }), g = g + "new ((" + e.toString().replace("ENTRY_MODULE", JSON.stringify(l)) + ")({" + f.main.map(function(m) { return "" + JSON.stringify(m) + ": " + h6.main[m].toString(); }).join(",") + "}))(self);"; var p = new window.Blob([g], { type: "text/javascript" }); if (d.bare) return p; var u = window.URL || window.webkitURL || window.mozURL || window.msURL, y = u.createObjectURL(p), v = new window.Worker(y); return v.objectURL = y, v; }; }(Rh)), Rh.exports; } function w4(n) { var e = this.constructor; return this.then( function(t) { return e.resolve(n()).then(function() { return t; }); }, function(t) { return e.resolve(n()).then(function() { return e.reject(t); }); } ); } function A4(n) { var e = this; return new e(function(t, i) { if (!(n && typeof n.length < "u")) return i( new TypeError( typeof n + " " + n + " is not iterable(cannot read property Symbol(Symbol.iterator))" ) ); var r = Array.prototype.slice.call(n); if (r.length === 0) return t([]); var s = r.length; function o(c, l) { if (l && (typeof l == "object" || typeof l == "function")) { var d = l.then; if (typeof d == "function") { d.call( l, function(h6) { o(c, h6); }, function(h6) { r[c] = { status: "rejected", reason: h6 }, --s === 0 && t(r); } ); return; } } r[c] = { status: "fulfilled", value: l }, --s === 0 && t(r); } for (var a = 0; a < r.length; a++) o(a, r[a]); }); } function pM(n, e) { this.name = "AggregateError", this.errors = n, this.message = e || ""; } pM.prototype = Error.prototype; function S4(n) { var e = this; return new e(function(t, i) { if (!(n && typeof n.length < "u")) return i(new TypeError("Promise.any accepts an array")); var r = Array.prototype.slice.call(n); if (r.length === 0) return i(); for (var s = [], o = 0; o < r.length; o++) try { e.resolve(r[o]).then(t).catch(function(a) { s.push(a), s.length === r.length && i( new pM( s, "All promises were rejected" ) ); }); } catch (a) { i(a); } }); } var _4 = setTimeout; function mM(n) { return !!(n && typeof n.length < "u"); } function T4() { } function E4(n, e) { return function() { n.apply(e, arguments); }; } function Dt(n) { if (!(this instanceof Dt)) throw new TypeError("Promises must be constructed via new"); if (typeof n != "function") throw new TypeError("not a function"); this._state = 0, this._handled = false, this._value = void 0, this._deferreds = [], vM(n, this); } function gM(n, e) { for (; n._state === 3; ) n = n._value; if (n._state === 0) { n._deferreds.push(e); return; } n._handled = true, Dt._immediateFn(function() { var t = n._state === 1 ? e.onFulfilled : e.onRejected; if (t === null) { (n._state === 1 ? Fd : qa)(e.promise, n._value); return; } var i; try { i = t(n._value); } catch (r) { qa(e.promise, r); return; } Fd(e.promise, i); }); } function Fd(n, e) { try { if (e === n) throw new TypeError("A promise cannot be resolved with itself."); if (e && (typeof e == "object" || typeof e == "function")) { var t = e.then; if (e instanceof Dt) { n._state = 3, n._value = e, Pd(n); return; } else if (typeof t == "function") { vM(E4(t, e), n); return; } } n._state = 1, n._value = e, Pd(n); } catch (i) { qa(n, i); } } function qa(n, e) { n._state = 2, n._value = e, Pd(n); } function Pd(n) { n._state === 2 && n._deferreds.length === 0 && Dt._immediateFn(function() { n._handled || Dt._unhandledRejectionFn(n._value); }); for (var e = 0, t = n._deferreds.length; e < t; e++) gM(n, n._deferreds[e]); n._deferreds = null; } function C4(n, e, t) { this.onFulfilled = typeof n == "function" ? n : null, this.onRejected = typeof e == "function" ? e : null, this.promise = t; } function vM(n, e) { var t = false; try { n( function(i) { t || (t = true, Fd(e, i)); }, function(i) { t || (t = true, qa(e, i)); } ); } catch (i) { if (t) return; t = true, qa(e, i); } } Dt.prototype.catch = function(n) { return this.then(null, n); }; Dt.prototype.then = function(n, e) { var t = new this.constructor(T4); return gM(this, new C4(n, e, t)), t; }; Dt.prototype.finally = w4; Dt.all = function(n) { return new Dt(function(e, t) { if (!mM(n)) return t(new TypeError("Promise.all accepts an array")); var i = Array.prototype.slice.call(n); if (i.length === 0) return e([]); var r = i.length; function s(a, c) { try { if (c && (typeof c == "object" || typeof c == "function")) { var l = c.then; if (typeof l == "function") { l.call( c, function(d) { s(a, d); }, t ); return; } } i[a] = c, --r === 0 && e(i); } catch (d) { t(d); } } for (var o = 0; o < i.length; o++) s(o, i[o]); }); }; Dt.any = S4; Dt.allSettled = A4; Dt.resolve = function(n) { return n && typeof n == "object" && n.constructor === Dt ? n : new Dt(function(e) { e(n); }); }; Dt.reject = function(n) { return new Dt(function(e, t) { t(n); }); }; Dt.race = function(n) { return new Dt(function(e, t) { if (!mM(n)) return t(new TypeError("Promise.race accepts an array")); for (var i = 0, r = n.length; i < r; i++) Dt.resolve(n[i]).then(e, t); }); }; Dt._immediateFn = // @ts-ignore typeof setImmediate == "function" && function(n) { setImmediate(n); } || function(n) { _4(n, 0); }; Dt._unhandledRejectionFn = function(e) { typeof console < "u" && console && console.warn("Possible Unhandled Promise Rejection:", e); }; var L4 = Object.freeze(Object.defineProperty({ __proto__: null, default: Dt }, Symbol.toStringTag, { value: "Module" })); var R4 = au(L4); (function(n, e) { (function(i, r) { n.exports = r(); })(Lr, () => ( /******/ (() => { var t = [ /* 0 */ /***/ (o, a, c) => { c(1); var l = c(2), d = l.version, h6 = function() { this.Revision = d, this.defaultMaterialColor = 16777215, this.defaultOpacity = 1, this.modelPrefix = void 0, this.Geometry = c(3).Geometry, this.Glyph = c(16).Glyph, this.Glyphset = c(18).Glyphset, this.Pointset = c(22).Pointset, this.Label = c(17).Label, this.Lines = c(24).Lines, this.TextureArray = c(25).TextureArray, this.TextureSlides = c(27).TextureSlides, this.Renderer = c(30).Renderer, this.Scene = c(32).Scene, this.GeometryCSG = c(51).GeometryCSG, this.GlyphsetCSG = c(57).GlyphsetCSG, this.Viewport = c(44).Viewport, this.CameraControls = c(44).CameraControls, this.SmoothCameraTransition = c(44).SmoothCameraTransition, this.RayCaster = c(44).RayCaster, this.CameraAutoTumble = c(44).CameraAutoTumble, this.StereoEffect = c(44).StereoEffect, this.loadExternalFile = c(5).loadExternalFile, this.loadExternalFiles = c(5).loadExternalFiles, this.THREE = c(4); }; o.exports = new h6(); }, /* 1 */ /***/ (o) => { o.exports = b3(); }, /* 2 */ /***/ (o) => { o.exports = JSON.parse('{"name":"zincjs","version":"1.15.1","description":"ZincJS (Web-based-Zinc-Visualisation)","main":"build/zinc.js","directories":{"doc":"docs"},"files":["package.json","LICENSE","README.md","src/*","build/zinc.js","build/zinc.frontend.js","build/zinc.js.map","webpack.config.js"],"scripts":{"build-bundle":"webpack --config webpack.frontend.js; webpack --config webpack.backend.js","build-backend":"webpack --config webpack.backend.js","test":"npm --prefix ./test install && npm --prefix ./test run test-ci","changelog":"auto-changelog -p --output CHANGELOG.md --template keepachangelog","jsdoc":"jsdoc -c jsdoc_conf.json","version":"npm run build-bundle;npm run jsdoc;npm run changelog; git add CHANGELOG.md docs","release:beta":"npm version prerelease --preid=beta; npm publish --tag beta","release:minor":"npm version minor; npm publish","release:patch":"npm version patch; npm publish"},"repository":{"type":"git","url":"git+https://github.com/alan-wu/ZincJS.git"},"keywords":["library","webgl","3d","zincjs"],"author":"Alan Wu ","license":"MIT","bugs":{"url":"https://github.com/alan-wu/ZincJS/issues"},"homepage":"http://alan-wu.github.io/ZincJS/","devDependencies":{"@babel/core":"^7.23.9","@babel/preset-env":"^7.23.9","auto-changelog":"^2.4.0","babel-loader":"^9.1.3","babel-preset-minify":"^0.5.1","file-loader":"^6.2.0","jsdoc":"^4.0.2","raw-loader":"^4.0.2","webpack":"^5.90.3","webpack-cli":"^5.1.4","webpack-node-externals":"^3.0.0"},"dependencies":{"css-element-queries":"^1.2.2","lodash":"^4.17.19","promise-polyfill":"^8.1.3","three":"^0.130.1","three-spritetext":"1.6.2","url-loader":"^4.1.1","url-polyfill":"^1.1.7","webworkify-webpack":"^2.1.5"}}'); }, /* 3 */ /***/ function(o, a, c) { var l = c(4), d = c(5).toBufferGeometry, h6 = (g, p, u) => { var y = d(g, u), v = false; 1 > u.opacity && (v = true); var m; if (y._video === void 0) { var x = u.localTimeEnabled || u.localMorphColour; p ? (m = p, m.morphTargets = x, m.morphNormals = u.localTimeEnabled) : y instanceof l.BufferGeometry && y.attributes.color === void 0 ? m = new l.MeshPhongMaterial({ color: u.colour, morphTargets: x, morphNormals: u.localTimeEnabled, transparent: v, opacity: u.opacity, side: l.DoubleSide }) : m = new l.MeshPhongMaterial({ color: u.colour, morphTargets: x, morphNormals: u.localTimeEnabled, vertexColors: l.VertexColors, transparent: v, opacity: u.opacity, side: l.DoubleSide }), u.localMorphColour && y.morphAttributes.color && (m.onBeforeCompile = c(9).augmentMorphColor()); } else { var w = y._video.createCanvasVideoTexture(); m = new l.MeshBasicMaterial({ morphTargets: u.localTimeEnabled, color: new l.Color(1, 1, 1), transparent: v, opacity: u.opacity, map: w, side: l.DoubleSide }), this.videoHandler = y._video; } return new l.Mesh(y, m); }, f = function() { c(10).ZincObject.call(this), this.videoHandler = void 0, this.isGeometry = true, this.createMesh = (g, p, u) => { if (!(this.morph && this.morph.geometry && g != null)) { var y = h6(g, p, u); this.setMesh(y, u.localTimeEnabled, u.localMorphColour); } }, this.calculateUVs = () => { this.geometry.computeBoundingBox(); var g = this.geometry.boundingBox.max, p = this.geometry.boundingBox.min, u = new l.Vector2(0 - p.x, 0 - p.y), y = new l.Vector2(g.x - p.x, g.y - p.y); this.geometry.faceVertexUvs[0] = []; for (var v = 0; v < this.geometry.faces.length; v++) { var m = this.geometry.vertices[this.geometry.faces[v].a], x = this.geometry.vertices[this.geometry.faces[v].b], w = this.geometry.vertices[this.geometry.faces[v].c]; geometry.faceVertexUvs[0].push([new l.Vector2((m.x + u.x) / y.x, (m.y + u.y) / y.y), new l.Vector2((x.x + u.x) / y.x, (x.y + u.y) / y.y), new l.Vector2((w.x + u.x) / y.x, (w.y + u.y) / y.y)]); } geometry.uvsNeedUpdate = true; }, this.checkTransparentMesh = function() { this._lod.checkTransparentMesh(); }, this.setWireframe = (g) => { this.morph.material.wireframe = g; }, this.editVertices = function(g, p) { if (g && g.length) { var u = this.getMorph(), y = u.geometry.getAttribute("position"); if (!u || 0 > p) return; var v = 3 * p; g.forEach((m) => { y.array[v++] = m[0], y.array[v++] = m[1], y.array[v++] = m[2]; }), y.needsUpdate = true, u.geometry.computeBoundingBox(), u.geometry.computeBoundingSphere(), this.boundingBoxUpdateRequired = true; } }; }; f.prototype = Object.create(c(10).ZincObject.prototype), a.Geometry = f; }, /* 4 */ /***/ (o) => { o.exports = IB; }, /* 5 */ /***/ (o, a, c) => { function l(S) { throw new TypeError('"' + S + '" is read-only'); } var d = c(4), h6 = c(6).Geometry, f = c(7).default; function g(S) { var I = S, T = c(0).modelPrefix; return T && (T[T.length - 1] != "/" && l("prefix"), /^(?:[a-z]+:)?\/\//i.test(S) || (I = T + S)), I; } function p(S, I) { var T = (E, C) => { try { var P = new URL(E, C).href; if (E && 2 > E.split("?").length) { var b = C.split("?"); b.length === 2 && (P = P + "?" + b[1]); } return P; } catch { console.error("There is an issue creating the url link with: ".concat(E, ".")); } }; if (!Array.isArray(S)) return T(S, I); var _ = []; return S.forEach((E) => { _.push(T(E, I)); }), _; } function u(S, I, T, _, E) { var C = S.morphTargetInfluences, P = void 0; S.geometry && (P = S.geometry.morphAttributes); var b = false; if (C && P && P.position) { _.set(0, 0, 0), E.set(0, 0, 0); for (var F = 0; F < C.length; F++) 0 < C[F] && (b = true, T.setFromArray(P.position[F].array), _.add(T.min.multiplyScalar(C[F])), E.add(T.max.multiplyScalar(C[F]))); b && I.set(_, E); } b || I.setFromBufferAttribute(S.geometry.attributes.position), S.updateWorldMatrix(true, true), I.applyMatrix4(S.matrixWorld); } function y(S, I, T, _) { var E = new XMLHttpRequest(); E.open("GET", g(S), true), E.onreadystatechange = () => { E.readyState == 4 && (E.status == 200 ? T(E.responseText, I) : _(S)); }, E.send(null); } function v(S, I, T) { function _(F, D) { P[D] = F, C++, C == E && I(P); } for (var E = S.length, C = 0, P = [], b = 0; b < E; b++) y(S[b], b, _, T); } a.getColorsRGB = (S, I) => { var T = Math.floor(I / 3), _ = I % 3, E = 0; _ == 0 ? E = S[T].r : _ == 1 ? E = S[T].g : _ == 2 && (E = S[T].b); var C = new d.Color(E); return [C.r, C.g, C.b]; }, a.updateMorphColorAttribute = function(S, I) { if (I && S && S.morphAttributes && S.morphAttributes.color) { var T = S.morphAttributes.color, _ = I.morphTargetInfluences, E = _.length; S.deleteAttribute("morphColor0"), S.deleteAttribute("morphColor1"); for (var C = 0, P = [], b = 0; 1 > C || b < E; b++) 0 < _[b] && (C++, P.push([b, _[b]])); P.length == 2 ? (S.setAttribute("morphColor0", T[P[0][0]]), S.setAttribute("morphColor1", T[P[1][0]])) : P.length == 1 && (S.setAttribute("morphColor0", T[P[0][0]]), S.setAttribute("morphColor1", T[P[0][0]])); } }, a.toBufferGeometry = (S, I) => { var T; return S instanceof h6 ? (I.localTimeEnabled && !S.morphNormalsReady && (S.morphNormals == null || S.morphNormals.length == 0) && S.computeMorphNormals(), T = S.toIndexedBufferGeometry(), I.localMorphColour && m(S, T)) : S instanceof d.BufferGeometry && (T = S.clone()), T.colorsNeedUpdate = true, T.computeBoundingBox(), T.computeBoundingSphere(), S._video && (T._video = S._video), T; }, a.copyMorphColorsToBufferGeometry = (S, I) => { if (S && S.morphColors && 0 < S.morphColors.length) { for (var T = [], _ = S.morphColors, E = c(5).getColorsRGB, C = 0, P = _.length; C < P; C++) { for (var b = _[C], F = [], D = 0; D < S.faces.length; D++) { var N = S.faces[D], B = E(b.colors, N.a); F.push(B[0], B[1], B[2]), B = E(b.colors, N.b), F.push(B[0], B[1], B[2]), B = E(b.colors, N.c), F.push(B[0], B[1], B[2]); } var U = new d.Float32BufferAttribute(3 * (3 * S.faces.length), 3); U.name = b.name, T.push(U.copyArray(F)); } I.morphAttributes.color = T; } }; var m = (S, I) => { if (S && S.morphColors && 0 < S.morphColors.length) { for (var T = [], _ = S.morphColors, E = c(5).getColorsRGB, C = 0, P = _.length; C < P; C++) { for (var b, F = _[C], D = [], N = 0; N < 3 * F.colors.length; N++) b = E(F.colors, N), D.push(b[0], b[1], b[2]); var B = new d.Float32BufferAttribute(D, 3); B.name = F.name, T.push(B); } I.morphAttributes.color = T; } }; function x(S) { for (var I, T, _, E, C = -1, P = 0, b = 0; b < S.length; ++b) { if (E = S[b], I === void 0 && (I = E.array.constructor), I !== E.array.constructor) return console.error("THREE.BufferGeometryUtils: .mergeAttributes() failed. BufferAttribute.array must be of consistent array types across matching attributes."), null; if (T === void 0 && (T = E.itemSize), T !== E.itemSize) return console.error("THREE.BufferGeometryUtils: .mergeAttributes() failed. BufferAttribute.itemSize must be consistent across matching attributes."), null; if (_ === void 0 && (_ = E.normalized), _ !== E.normalized) return console.error("THREE.BufferGeometryUtils: .mergeAttributes() failed. BufferAttribute.normalized must be consistent across matching attributes."), null; if (C === -1 && (C = E.gpuType), C !== E.gpuType) return console.error("THREE.BufferGeometryUtils: .mergeAttributes() failed. BufferAttribute.gpuType must be consistent across matching attributes."), null; P += E.count * T; } for (var F, D = new I(P), N = new d.BufferAttribute(D, T, _), B = 0, U = 0; U < S.length; ++U) { if (F = S[U], F.isInterleavedBufferAttribute) for (var G = B / T, Y = 0, te = F.count; Y < te; Y++) for (var ae, ie = 0; ie < T; ie++) ae = F.getComponent(Y, ie), N.setComponent(Y + G, ie, ae); else D.set(F.array, B); B += F.count * T; } return C !== void 0 && (N.gpuType = C), N; } a.mergeGeometries = function(S) { for (var I = 1 < arguments.length && arguments[1] !== void 0 && arguments[1], T = S[0].index !== null, _ = new Set(Object.keys(S[0].attributes)), E = new Set(Object.keys(S[0].morphAttributes)), C = {}, P = {}, b = S[0].morphTargetsRelative, F = new d.BufferGeometry(), D = 0, N = 0; N < S.length; ++N) { var B = S[N], U = 0; if (T !== (B.index !== null)) return console.error("THREE.BufferGeometryUtils: .mergeGeometries() failed with geometry at index " + N + ". All geometries must have compatible attributes; make sure index attribute exists among all geometries, or in none of them."), null; for (var G in B.attributes) { if (!_.has(G)) return console.error("THREE.BufferGeometryUtils: .mergeGeometries() failed with geometry at index " + N + '. All geometries must have compatible attributes; make sure "' + G + '" attribute exists among all geometries, or in none of them.'), null; C[G] === void 0 && (C[G] = []), C[G].push(B.attributes[G]), U++; } if (U !== _.size) return console.error("THREE.BufferGeometryUtils: .mergeGeometries() failed with geometry at index " + N + ". Make sure all geometries have the same number of attributes."), null; if (b !== B.morphTargetsRelative) return console.error("THREE.BufferGeometryUtils: .mergeGeometries() failed with geometry at index " + N + ". .morphTargetsRelative must be consistent throughout all geometries."), null; for (var Y in B.morphAttributes) { if (!E.has(Y)) return console.error("THREE.BufferGeometryUtils: .mergeGeometries() failed with geometry at index " + N + ". .morphAttributes must be consistent throughout all geometries."), null; P[Y] === void 0 && (P[Y] = []), P[Y].push(B.morphAttributes[Y]); } if (I) { var te = void 0; if (T) te = B.index.count; else if (B.attributes.position !== void 0) te = B.attributes.position.count; else return console.error("THREE.BufferGeometryUtils: .mergeGeometries() failed with geometry at index " + N + ". The geometry must have either an index or a position attribute"), null; F.addGroup(D, te, N), D += te; } } if (T) { for (var ae, ie = 0, le = [], W = 0; W < S.length; ++W) { ae = S[W].index; for (var $ = 0; $ < ae.count; ++$) le.push(ae.getX($) + ie); ie += S[W].attributes.position.count; } F.setIndex(le); } for (var j in C) { var re = x(C[j]); if (!re) return console.error("THREE.BufferGeometryUtils: .mergeGeometries() failed while trying to merge the " + j + " attribute."), null; F.setAttribute(j, re); } for (var V in P) { var H = P[V][0].length; if (H === 0) break; F.morphAttributes = F.morphAttributes || {}, F.morphAttributes[V] = []; for (var K, ce = 0; ce < H; ++ce) { K = []; for (var se = 0; se < P[V].length; ++se) K.push(P[V][se][ce]); var k = x(K); if (!k) return console.error("THREE.BufferGeometryUtils: .mergeGeometries() failed while trying to merge the " + V + " morphAttribute."), null; F.morphAttributes[V].push(k); } } return F; }, a.mergeVertices = function(S) { var I = 1 < arguments.length && arguments[1] !== void 0 ? arguments[1] : 1e-4; I = Math.max(I, Number.EPSILON); for (var T, _ = {}, E = S.getIndex(), C = S.getAttribute("position"), P = E ? E.count : C.count, b = 0, F = Object.keys(S.attributes), D = {}, N = {}, be = [], B = ["getX", "getY", "getZ", "getW"], U = 0, G = F.length; U < G; U++) { T = F[U], D[T] = []; var Y = S.morphAttributes[T]; Y && (N[T] = Array(Y.length).fill().map(() => [])); } for (var te = Math.log10(1 / I), ae = Math.pow(10, te), U = 0; U < P; U++) { for (var ie = E ? E.getX(U) : U, le = "", W = 0, G = F.length; W < G; W++) for (var T = F[W], $ = S.getAttribute(T), j = $.itemSize, re = 0; re < j; re++) le += "".concat(~~($[B[re]](ie) * ae), ","); if (le in _) be.push(_[le]); else { for (var W = 0, G = F.length; W < G; W++) for (var V, T = F[W], $ = S.getAttribute(T), Y = S.morphAttributes[T], j = $.itemSize, H = D[T], K = N[T], re = 0; re < j; re++) if (V = B[re], H.push($[V](ie)), Y) for (var ce = 0, se = Y.length; ce < se; ce++) K[ce].push(Y[ce][V](ie)); _[le] = b, be.push(b), b++; } } for (var k = S.clone(), U = 0, G = F.length; U < G; U++) { var $, T = F[U], O = S.getAttribute(T), Z = new O.array.constructor(D[T]); if (O.isInterleavedBufferAttribute ? $ = new d.BufferAttribute(Z, O.itemSize, O.itemSize) : ($ = S.getAttribute(T).clone(), $.setArray(Z)), k.setAttribute(T, $), T in N) for (var X, W = 0; W < N[T].length; W++) X = S.morphAttributes[T][W].clone(), X.setArray(new X.array.constructor(N[T][W])), k.morphAttributes[T][W] = X; } var ee = Uint8Array; be.length >= Math.pow(2, 8) && (ee = Uint16Array), be.length >= Math.pow(2, 16) && (ee = Uint32Array); var fe = new ee(be), be = null; return E === null ? be = new d.BufferAttribute(fe, 1) : (be = S.getIndex().clone(), be.setArray(fe)), k.setIndex(be), k; }; function w(S) { if (S.isMeshPhongMaterial) { var I = new d.MeshToonMaterial({ color: S.color.clone(), morphTargets: S.morphTargets, morphNormals: S.morphNormals, vertexColors: S.vertexColors, transparent: S.transparent, opacity: S.opacity, side: S.side }); return S.map && (I.map = S.map), I; } return S; } function A(S, I) { if (I && S >= I.length) { var T = new d.BufferGeometry(), _ = new Float32Array(3 * S), E = 0; return I.forEach((C) => { _[E++] = C[0], _[E++] = C[1], _[E++] = C[2]; }), T.setAttribute("position", new d.BufferAttribute(_, 3)), T.setDrawRange(0, I.length), T; } } function M() { var S = new Image(); S.src = c(8); var I = new d.Texture(); return I.image = S, I.needsUpdate = true, I; } function R(S, I, T, _, E, C) { var P = new f(S, I, T, _, E, C); return P.fontFace = _, P.fontSize = E, P.fontWeight = C, P.material.map.generateMipmaps = false, P.material.map.anisotropy = 4, P.material.sizeAttenuation = false, P.material.alphaTest = 0.5, P.material.transparent = true, P.material.depthWrite = false, P.material.depthTest = false, P.center.set(0.5, -1.2), P.renderOrder = 1e4, P; } function L(S, I, T) { if (T) { var _ = S || "", E = I || "", C = T.lastIndexOf("/"); if (-1 < C) { var P = void 0, b = void 0; if (P = T.substring(0, C), b = T.substring(C + 1), (P === "*" || P === "**" || P.toLowerCase() === _.toLowerCase()) && (b === "*" || b === "**" || b.toLowerCase() === E.toLowerCase())) return true; } else if (_.toLowerCase() === T.toLowerCase() || E.toLowerCase() === T.toLowerCase()) return true; } return false; } a.getBoundingBox = u, a.createNewURL = p, a.createBufferGeometry = A, a.getCircularTexture = M, a.resolveURL = g, a.loadExternalFile = y, a.loadExternalFiles = v, a.PhongToToon = w, a.createNewSpriteText = R, a.isRegionGroup = L; }, /* 6 */ /***/ (o, a, c) => { c.r(a), c.d(a, { /* harmony export */ Face3: () => ( /* binding */ y ), /* harmony export */ Geometry: () => ( /* binding */ p ) /* harmony export */ }); var l = c(4), d = new l.Matrix4(), h6 = new l.Object3D(), f = new l.Vector3(), g = new l.Vector3(); function p() { this.uuid = l.MathUtils.generateUUID(), this.name = "", this.type = "Geometry", this.vertices = [], this.colors = [], this.faces = [], this.faceVertexUvs = [[]], this.normals = [], this.uvs = [], this.morphTargets = [], this.morphNormals = [], this.skinWeights = [], this.skinIndices = [], this.lineDistances = [], this.boundingBox = null, this.boundingSphere = null, this.elementsNeedUpdate = false, this.verticesNeedUpdate = false, this.uvsNeedUpdate = false, this.normalsNeedUpdate = false, this.colorsNeedUpdate = false, this.lineDistancesNeedUpdate = false, this.groupsNeedUpdate = false, this.morphNormalsReady = false; } p.prototype = Object.assign(Object.create(l.EventDispatcher.prototype), { constructor: p, isGeometry: true, applyMatrix4: function(m) { for (var x, w = new l.Matrix3().getNormalMatrix(m), A = 0, M = this.vertices.length; A < M; A++) x = this.vertices[A], x.applyMatrix4(m); for (var R, L = 0, S = this.faces.length; L < S; L++) { R = this.faces[L], R.normal.applyMatrix3(w).normalize(); for (var I = 0, T = R.vertexNormals.length; I < T; I++) R.vertexNormals[I].applyMatrix3(w).normalize(); } return this.boundingBox !== null && this.computeBoundingBox(), this.boundingSphere !== null && this.computeBoundingSphere(), this.verticesNeedUpdate = true, this.normalsNeedUpdate = true, this; }, rotateX: function(m) { return d.makeRotationX(m), this.applyMatrix4(d), this; }, rotateY: function(m) { return d.makeRotationY(m), this.applyMatrix4(d), this; }, rotateZ: function(m) { return d.makeRotationZ(m), this.applyMatrix4(d), this; }, translate: function(m, x, w) { return d.makeTranslation(m, x, w), this.applyMatrix4(d), this; }, scale: function(m, x, w) { return d.makeScale(m, x, w), this.applyMatrix4(d), this; }, lookAt: function(m) { return h6.lookAt(m), h6.updateMatrix(), this.applyMatrix4(h6.matrix), this; }, fromBufferGeometry: function(m) { function x(G, Y, te, ae) { var ie = S === void 0 ? [] : [w.colors[G].clone(), w.colors[Y].clone(), w.colors[te].clone()], le = L === void 0 ? [] : [new l.Vector3().fromBufferAttribute(L, G), new l.Vector3().fromBufferAttribute(L, Y), new l.Vector3().fromBufferAttribute(L, te)], W = new y(G, Y, te, le, ie, ae); w.faces.push(W), I !== void 0 && w.faceVertexUvs[0].push([new l.Vector2().fromBufferAttribute(I, G), new l.Vector2().fromBufferAttribute(I, Y), new l.Vector2().fromBufferAttribute(I, te)]), T !== void 0 && w.faceVertexUvs[1].push([new l.Vector2().fromBufferAttribute(T, G), new l.Vector2().fromBufferAttribute(T, Y), new l.Vector2().fromBufferAttribute(T, te)]); } var w = this, A = m.index === null ? void 0 : m.index, M = m.attributes; if (M.position === void 0) return console.error("THREE.Geometry.fromBufferGeometry(): Position attribute required for conversion."), this; var R = M.position, L = M.normal, S = M.color, I = M.uv, T = M.uv2; T !== void 0 && (this.faceVertexUvs[1] = []); for (var _ = 0; _ < R.count; _++) w.vertices.push(new l.Vector3().fromBufferAttribute(R, _)), S !== void 0 && w.colors.push(new l.Color().fromBufferAttribute(S, _)); var E = m.groups; if (0 < E.length) for (var C = 0; C < E.length; C++) for (var P = E[C], b = P.start, F = P.count, D = b, N = b + F; D < N; D += 3) A === void 0 ? x(D, D + 1, D + 2, P.materialIndex) : x(A.getX(D), A.getX(D + 1), A.getX(D + 2), P.materialIndex); else if (A !== void 0) for (var B = 0; B < A.count; B += 3) x(A.getX(B), A.getX(B + 1), A.getX(B + 2)); else for (var U = 0; U < R.count; U += 3) x(U, U + 1, U + 2); return this.computeFaceNormals(), m.boundingBox !== null && (this.boundingBox = m.boundingBox.clone()), m.boundingSphere !== null && (this.boundingSphere = m.boundingSphere.clone()), this; }, center: function() { return this.computeBoundingBox(), this.boundingBox.getCenter(f).negate(), this.translate(f.x, f.y, f.z), this; }, normalize: function() { this.computeBoundingSphere(); var m = this.boundingSphere.center, x = this.boundingSphere.radius, w = x === 0 ? 1 : 1 / x, A = new l.Matrix4(); return A.set(w, 0, 0, -w * m.x, 0, w, 0, -w * m.y, 0, 0, w, -w * m.z, 0, 0, 0, 1), this.applyMatrix4(A), this; }, computeFaceNormals: function() { for (var m = new l.Vector3(), x = new l.Vector3(), w = 0, A = this.faces.length; w < A; w++) { var M = this.faces[w], R = this.vertices[M.a], L = this.vertices[M.b], S = this.vertices[M.c]; m.subVectors(S, L), x.subVectors(R, L), m.cross(x), m.normalize(), M.normal.copy(m); } }, computeVertexNormals: function() { for (var m = !(0 < arguments.length && arguments[0] !== void 0) || arguments[0], x = Array(this.vertices.length), w = 0, A = this.vertices.length; w < A; w++) x[w] = new l.Vector3(); if (m) for (var M = new l.Vector3(), R = new l.Vector3(), L = 0, S = this.faces.length; L < S; L++) { var I = this.faces[L], T = this.vertices[I.a], _ = this.vertices[I.b], E = this.vertices[I.c]; M.subVectors(E, _), R.subVectors(T, _), M.cross(R), x[I.a].add(M), x[I.b].add(M), x[I.c].add(M); } else { this.computeFaceNormals(); for (var C, P = 0, b = this.faces.length; P < b; P++) C = this.faces[P], x[C.a].add(C.normal), x[C.b].add(C.normal), x[C.c].add(C.normal); } for (var F = 0, D = this.vertices.length; F < D; F++) x[F].normalize(); for (var N = 0, B = this.faces.length; N < B; N++) { var U = this.faces[N], G = U.vertexNormals; G.length === 3 ? (G[0].copy(x[U.a]), G[1].copy(x[U.b]), G[2].copy(x[U.c])) : (G[0] = x[U.a].clone(), G[1] = x[U.b].clone(), G[2] = x[U.c].clone()); } return 0 < this.faces.length && (this.normalsNeedUpdate = true), x; }, computeFlatVertexNormals: function() { this.computeFaceNormals(); for (var m = 0, x = this.faces.length; m < x; m++) { var w = this.faces[m], A = w.vertexNormals; A.length === 3 ? (A[0].copy(w.normal), A[1].copy(w.normal), A[2].copy(w.normal)) : (A[0] = w.normal.clone(), A[1] = w.normal.clone(), A[2] = w.normal.clone()); } 0 < this.faces.length && (this.normalsNeedUpdate = true); }, computeMorphNormals: function() { for (var m, x = 0, w = this.faces.length; x < w; x++) { m = this.faces[x], m.__originalFaceNormal ? m.__originalFaceNormal.copy(m.normal) : m.__originalFaceNormal = m.normal.clone(), m.__originalVertexNormals || (m.__originalVertexNormals = []); for (var A = 0, M = m.vertexNormals.length; A < M; A++) m.__originalVertexNormals[A] ? m.__originalVertexNormals[A].copy(m.vertexNormals[A]) : m.__originalVertexNormals[A] = m.vertexNormals[A].clone(); } var R = new p(); R.faces = this.faces; for (var L = 0, S = this.morphTargets.length; L < S; L++) { if (!this.morphNormals[L]) { this.morphNormals[L] = {}, this.morphNormals[L].faceNormals = [], this.morphNormals[L].vertexNormals = []; for (var I = this.morphNormals[L].faceNormals, T = this.morphNormals[L].vertexNormals, _ = 0, E = this.faces.length; _ < E; _++) { var C = new l.Vector3(), P = { a: new l.Vector3(), b: new l.Vector3(), c: new l.Vector3() }; I.push(C), T.push(P); } } var b = this.morphNormals[L]; R.vertices = this.morphTargets[L].vertices, R.computeFaceNormals(); var F = R.computeVertexNormals(); if (F && 0 < F.length) { this.morphTargets[L].normals = Array(this.vertices.length); for (var D = 0; D < F.length; D++) this.morphTargets[L].normals[D] = F[D].clone(); } for (var N = 0, B = this.faces.length; N < B; N++) { var U = this.faces[N], G = b.faceNormals[N], Y = b.vertexNormals[N]; G.copy(U.normal), Y.a.copy(U.vertexNormals[0]), Y.b.copy(U.vertexNormals[1]), Y.c.copy(U.vertexNormals[2]); } } for (var te, ae = 0, ie = this.faces.length; ae < ie; ae++) te = this.faces[ae], te.normal = te.__originalFaceNormal, te.vertexNormals = te.__originalVertexNormals; this.morphNormalsReady = true; }, computeBoundingBox: function() { this.boundingBox === null && (this.boundingBox = new l.Box3()), this.boundingBox.setFromPoints(this.vertices); }, computeBoundingSphere: function() { this.boundingSphere === null && (this.boundingSphere = new l.Sphere()), this.boundingSphere.setFromPoints(this.vertices); }, mergeMorph: function(m, x) { var w = this.morphTargets.length, A = this.morphTargets, M = m.morphTargets, R = this.morphColors.length, L = this.morphColors, S = m.morphColors; if (0 < w && w == M.length) for (var I = 0, T = A.length; I < T; I++) { for (var _ = A[I], E = M[I], C = 0, P = E.vertices.length; C < P; C++) { var b = E.vertices[C], F = b.clone(); x !== void 0 && F.applyMatrix4(x), _.vertices.push(F); } if (_.normals && E.normals) for (var D = 0; D < E.normals.length; D += 3) g.set(E.normals2[D], E.normals2[D + 1], E.normals2[D + 2]), x !== void 0 && g.applyMatrix4(x), _.normals.push(g.x, g.y, g.z); } if (0 < R && R == S.length) for (var N = 0, B = L.length; N < B; N++) for (var U = L[N], G = S[N], Y = 0, te = G.colors; Y < te; Y++) U.colors.push(G.colors[Y].clone()); }, merge: function(m, x) { var w = 2 < arguments.length && arguments[2] !== void 0 ? arguments[2] : 0; if (!(m && m.isGeometry)) return void console.error("THREE.Geometry.merge(): geometry not an instance of THREE.Geometry.", m); var A, M = this.vertices.length, R = this.vertices, L = m.vertices, S = m.normals, I = this.faces, T = m.faces, _ = this.colors, E = m.colors; x !== void 0 && (A = new l.Matrix3().getNormalMatrix(x)); for (var C = 0, P = L.length; C < P; C++) { var b = L[C], F = b.clone(); x !== void 0 && F.applyMatrix4(x), R.push(F); } for (var D = 0; D < S.length; D += 3) g.set(S[D], S[D + 1], S[D + 2]), x !== void 0 && g.applyMatrix4(x), this.normals.push(g.x, g.y, g.z); for (var N = 0, B = E.length; N < B; N++) typeof E[N] == "number" ? _.push(E[N]) : _.push(E[N].clone()); for (var U = 0, G = T.length; U < G; U++) { var Y = T[U], te = void 0, ae = void 0, ie = Y.vertexNormals, le = Y.vertexColors, W = new y(Y.a + M, Y.b + M, Y.c + M); W.normal.copy(Y.normal), A !== void 0 && W.normal.applyMatrix3(A).normalize(); for (var $ = 0, j = ie.length; $ < j; $++) te = ie[$].clone(), A !== void 0 && te.applyMatrix3(A).normalize(), W.vertexNormals.push(te); W.color.copy(Y.color); for (var re = 0, V = le.length; re < V; re++) ae = le[re], W.vertexColors.push(ae.clone()); W.materialIndex = Y.materialIndex + w, I.push(W); } for (var H, K = 0, ce = m.faceVertexUvs.length; K < ce; K++) { H = m.faceVertexUvs[K], this.faceVertexUvs[K] === void 0 && (this.faceVertexUvs[K] = []); for (var se = 0, k = H.length; se < k; se++) { for (var O = H[se], Z = [], X = 0, ee = O.length; X < ee; X++) Z.push(O[X].clone()); this.faceVertexUvs[K].push(Z); } } this.mergeMorph(m, x); }, mergeMesh: function(m) { return m && m.isMesh ? (m.matrixAutoUpdate && m.updateMatrix(), void this.merge(m.geometry, m.matrix)) : void console.error("THREE.Geometry.mergeMesh(): mesh not an instance of THREE.Mesh.", m); }, /* * Checks for duplicate vertices with hashmap. * Duplicated vertices are removed * and faces' vertices are updated. */ mergeVertices: function() { for (var m = 0 < arguments.length && arguments[0] !== void 0 ? arguments[0] : 4, x = {}, w = [], A = [], M = Math.pow(10, m), R = 0, L = this.vertices.length; R < L; R++) { var S = this.vertices[R], I = Math.round(S.x * M) + "_" + Math.round(S.y * M) + "_" + Math.round(S.z * M); x[I] === void 0 ? (x[I] = R, w.push(this.vertices[R]), A[R] = w.length - 1) : A[R] = A[x[I]]; } for (var T, _ = [], E = 0, C = this.faces.length; E < C; E++) { T = this.faces[E], T.a = A[T.a], T.b = A[T.b], T.c = A[T.c]; for (var P = [T.a, T.b, T.c], b = 0; 3 > b; b++) if (P[b] === P[(b + 1) % 3]) { _.push(E); break; } } for (var F, D = _.length - 1; 0 <= D; D--) { F = _[D], this.faces.splice(F, 1); for (var N = 0, B = this.faceVertexUvs.length; N < B; N++) this.faceVertexUvs[N].splice(F, 1); } var U = this.vertices.length - w.length; return this.vertices = w, U; }, setFromPoints: function(m) { this.vertices = []; for (var x, w = 0, A = m.length; w < A; w++) x = m[w], this.vertices.push(new l.Vector3(x.x, x.y, x.z || 0)); return this; }, sortFacesByMaterialIndex: function() { for (var m = this.faces, x = m.length, w = 0; w < x; w++) m[w]._id = w; m.sort(function(T, _) { return T.materialIndex - _.materialIndex; }); var A, M, R = this.faceVertexUvs[0], L = this.faceVertexUvs[1]; R && R.length === x && (A = []), L && L.length === x && (M = []); for (var S, I = 0; I < x; I++) S = m[I]._id, A && A.push(R[S]), M && M.push(L[S]); A && (this.faceVertexUvs[0] = A), M && (this.faceVertexUvs[1] = M); }, toJSON: function() { function m(V, H, K) { return K ? V | 1 << H : V & ~(1 << H); } function x(V) { var H = V.x.toString() + V.y.toString() + V.z.toString(); return C[H] === void 0 && (C[H] = E.length / 3, E.push(V.x, V.y, V.z)), C[H]; } function w(V) { var H = V.r.toString() + V.g.toString() + V.b.toString(); return b[H] === void 0 && (b[H] = P.length, P.push(V.getHex())), b[H]; } function A(V) { var H = V.x.toString() + V.y.toString(); return D[H] === void 0 && (D[H] = F.length / 2, F.push(V.x, V.y)), D[H]; } var M = { metadata: { version: 4.5, type: "Geometry", generator: "Geometry.toJSON" } }; if (M.uuid = this.uuid, M.type = this.type, this.name !== "" && (M.name = this.name), this.parameters !== void 0) { var R = this.parameters; for (var L in R) R[L] !== void 0 && (M[L] = R[L]); return M; } for (var S, I = [], T = 0; T < this.vertices.length; T++) S = this.vertices[T], I.push(S.x, S.y, S.z); for (var _ = [], E = [], C = {}, P = [], b = {}, F = [], D = {}, N = 0; N < this.faces.length; N++) { var B = this.faces[N], U = true, G = false, Y = this.faceVertexUvs[0][N] !== void 0, te = 0 < B.normal.length(), ae = 0 < B.vertexNormals.length, ie = B.color.r !== 1 || B.color.g !== 1 || B.color.b !== 1, le = 0 < B.vertexColors.length, W = 0; if (W = m(W, 0, 0), W = m(W, 1, U), W = m(W, 2, G), W = m(W, 3, Y), W = m(W, 4, te), W = m(W, 5, ae), W = m(W, 6, ie), W = m(W, 7, le), _.push(W), _.push(B.a, B.b, B.c), _.push(B.materialIndex), Y) { var $ = this.faceVertexUvs[0][N]; _.push(A($[0]), A($[1]), A($[2])); } if (te && _.push(x(B.normal)), ae) { var j = B.vertexNormals; _.push(x(j[0]), x(j[1]), x(j[2])); } if (ie && _.push(w(B.color)), le) { var re = B.vertexColors; _.push(w(re[0]), w(re[1]), w(re[2])); } } return M.data = {}, M.data.vertices = I, M.data.normals = E, 0 < P.length && (M.data.colors = P), 0 < F.length && (M.data.uvs = [F]), M.data.faces = _, M; }, clone: function() { return new p().copy(this); }, copy: function(m) { this.vertices = [], this.colors = [], this.faces = [], this.faceVertexUvs = [[]], this.morphTargets = [], this.morphNormals = [], this.skinWeights = [], this.skinIndices = [], this.lineDistances = [], this.boundingBox = null, this.boundingSphere = null, this.name = m.name; for (var x = m.vertices, w = 0, A = x.length; w < A; w++) this.vertices.push(x[w].clone()); for (var M = m.colors, R = 0, L = M.length; R < L; R++) this.colors.push(M[R].clone()); for (var S = m.faces, I = 0, T = S.length; I < T; I++) this.faces.push(S[I].clone()); for (var _, E = 0, C = m.faceVertexUvs.length; E < C; E++) { _ = m.faceVertexUvs[E], this.faceVertexUvs[E] === void 0 && (this.faceVertexUvs[E] = []); for (var P = 0, b = _.length; P < b; P++) { for (var F, D = _[P], N = [], B = 0, U = D.length; B < U; B++) F = D[B], N.push(F.clone()); this.faceVertexUvs[E].push(N); } } for (var G, Y = m.morphTargets, te = 0, ae = Y.length; te < ae; te++) { if (G = {}, G.name = Y[te].name, Y[te].vertices !== void 0) { G.vertices = []; for (var ie = 0, le = Y[te].vertices.length; ie < le; ie++) G.vertices.push(Y[te].vertices[ie].clone()); } if (Y[te].normals !== void 0) { G.normals = []; for (var W = 0, $ = Y[te].normals.length; W < $; W++) G.normals.push(Y[te].normals[W].clone()); } this.morphTargets.push(G); } for (var j, re = m.morphNormals, V = 0, H = re.length; V < H; V++) { if (j = {}, re[V].vertexNormals !== void 0) { j.vertexNormals = []; for (var K = 0, ce = re[V].vertexNormals.length; K < ce; K++) { var se = re[V].vertexNormals[K], k = {}; k.a = se.a.clone(), k.b = se.b.clone(), k.c = se.c.clone(), j.vertexNormals.push(k); } } if (re[V].faceNormals !== void 0) { j.faceNormals = []; for (var O = 0, Z = re[V].faceNormals.length; O < Z; O++) j.faceNormals.push(re[V].faceNormals[O].clone()); } this.morphNormals.push(j); } for (var X = m.skinWeights, ee = 0, fe = X.length; ee < fe; ee++) this.skinWeights.push(X[ee].clone()); for (var be = m.skinIndices, Ae = 0, he = be.length; Ae < he; Ae++) this.skinIndices.push(be[Ae].clone()); for (var xe = m.lineDistances, ne = 0, me = xe.length; ne < me; ne++) this.lineDistances.push(xe[ne]); var Me = m.boundingBox; Me !== null && (this.boundingBox = Me.clone()); var De = m.boundingSphere; return De !== null && (this.boundingSphere = De.clone()), this.elementsNeedUpdate = m.elementsNeedUpdate, this.verticesNeedUpdate = m.verticesNeedUpdate, this.uvsNeedUpdate = m.uvsNeedUpdate, this.normalsNeedUpdate = m.normalsNeedUpdate, this.colorsNeedUpdate = m.colorsNeedUpdate, this.lineDistancesNeedUpdate = m.lineDistancesNeedUpdate, this.groupsNeedUpdate = m.groupsNeedUpdate, this; }, computeGroups() { var v, m, x = [], w = void 0, A = this.faces; for (m = 0; m < A.length; m++) { var M = A[m]; M.materialIndex !== w && (w = M.materialIndex, v !== void 0 && (v.count = 3 * m - v.start, x.push(v)), v = { start: 3 * m, materialIndex: w }); } return v !== void 0 && (v.count = 3 * m - v.start, x.push(v)), x; }, toBufferGeometry: function() { var m = new u().fromGeometry(this), x = new l.BufferGeometry(), w = new Float32Array(3 * m.vertices.length); if (x.setAttribute("position", new l.BufferAttribute(w, 3).copyVector3sArray(m.vertices)), 0 < m.normals.length) { var A = new Float32Array(3 * m.normals.length); x.setAttribute("normal", new l.BufferAttribute(A, 3).copyVector3sArray(m.normals)); } if (0 < m.colors.length) { var M = new Float32Array(3 * m.colors.length); x.setAttribute("color", new l.BufferAttribute(M, 3).copyColorsArray(m.colors)); } if (0 < m.uvs.length) { var R = new Float32Array(2 * m.uvs.length); x.setAttribute("uv", new l.BufferAttribute(R, 2).copyVector2sArray(m.uvs)); } if (0 < m.uvs2.length) { var L = new Float32Array(2 * m.uvs2.length); x.setAttribute("uv2", new l.BufferAttribute(L, 2).copyVector2sArray(m.uvs2)); } for (var S in x.groups = m.groups, m.morphTargets) { for (var I = [], T = m.morphTargets[S], _ = 0, E = T.length; _ < E; _++) { var C = T[_], P = new l.Float32BufferAttribute(3 * C.data.length, 3); P.name = C.name, I.push(P.copyVector3sArray(C.data)); } x.morphAttributes[S] = I; } if (0 < m.skinIndices.length) { var b = new l.Float32BufferAttribute(4 * m.skinIndices.length, 4); x.setAttribute("skinIndex", b.copyVector4sArray(m.skinIndices)); } if (0 < m.skinWeights.length) { var F = new l.Float32BufferAttribute(4 * m.skinWeights.length, 4); x.setAttribute("skinWeight", F.copyVector4sArray(m.skinWeights)); } return m.boundingSphere !== null && (x.boundingSphere = m.boundingSphere.clone()), m.boundingBox !== null && (x.boundingBox = m.boundingBox.clone()), x; }, toIndexedBufferGeometry: function() { var m = new l.BufferGeometry(), x = new Float32Array(3 * this.vertices.length); if (m.setAttribute("position", new l.BufferAttribute(x, 3).copyVector3sArray(this.vertices)), 0 < this.normals.length) { var w = new Float32Array(this.normals.length), A = new l.BufferAttribute(w, 3).copyArray(this.normals); m.setAttribute("normal", A); } if (0 < this.uvs.length && 0 < this.uvs[0].length) { var M = new Float32Array(2 * this.uvs[0].length); m.setAttribute("uv", new l.BufferAttribute(M, 2).copyArray(this.uvs[0])); } if (1 < this.uvs.length && 0 < this.uvs[1].length) { var R = new Float32Array(2 * this.uvs[1].length); m.setAttribute("uv2", new l.BufferAttribute(R, 2).copyArray(this.uvs[1])); } if (0 < this.colors.length) { for (var L = [], S = 0; S < this.colors.length; S++) L.push(new l.Color(this.colors[S])); var I = new Float32Array(3 * L.length); m.setAttribute("color", new l.BufferAttribute(I, 3).copyColorsArray(L)); } else { for (var T = new Float32Array(3 * this.vertices.length), _ = 0; _ < 3 * this.vertices.length; _++) T[_] = 1; m.setAttribute("color", new l.BufferAttribute(T, 3)); } if (0 < this.faces.length) { for (var E = [], C = [], P = 0; P < this.faces.length; P++) { C.push(this.faces[P].a, this.faces[P].b, this.faces[P].c); var b = this.faces[P].vertexColors; if (b.length === 3) E.push(b[0], b[1], b[2]); else { var F = this.faces[P].color; E.push(F, F, F); } } m.setIndex(C), m.groups = this.computeGroups(); } if (0 < this.morphTargets.length) { for (var D = [], N = [], B = 0, U = this.morphTargets.length; B < U; B++) { var G = this.morphTargets[B], Y = new l.Float32BufferAttribute(3 * G.vertices.length, 3); if (Y.name = G.name, D.push(Y.copyVector3sArray(G.vertices)), G.normals) { var te = new l.Float32BufferAttribute(3 * G.normals.length, 3); te.name = G.name, N.push(te.copyVector3sArray(G.normals)); } } m.morphAttributes.position = D, m.morphAttributes.normal = N; } if (0 < this.skinIndices.length) { var ae = new l.Float32BufferAttribute(4 * this.skinIndices.length, 4); m.setAttribute("skinIndex", ae.copyVector4sArray(this.skinIndices)); } if (0 < this.skinWeights.length) { var ie = new l.Float32BufferAttribute(4 * this.skinWeights.length, 4); m.setAttribute("skinWeight", ie.copyVector4sArray(this.skinWeights)); } return this.boundingSphere !== null && (m.boundingSphere = this.boundingSphere.clone()), this.boundingBox !== null && (m.boundingBox = this.boundingBox.clone()), m; }, computeTangents: function() { console.error("THREE.Geometry: .computeTangents() has been removed."); }, computeLineDistances: function() { console.error("THREE.Geometry: .computeLineDistances() has been removed. Use THREE.Line.computeLineDistances() instead."); }, applyMatrix: function(m) { return console.warn("THREE.Geometry: .applyMatrix() has been renamed to .applyMatrix4()."), this.applyMatrix4(m); }, dispose: function() { this.dispatchEvent({ type: "dispose" }); } }), p.createBufferGeometryFromObject = function(v) { var m = new l.BufferGeometry(), x = v.geometry; if (v.isPoints || v.isLine) { var w = new l.Float32BufferAttribute(3 * x.vertices.length, 3), A = new l.Float32BufferAttribute(3 * x.colors.length, 3); if (m.setAttribute("position", w.copyVector3sArray(x.vertices)), m.setAttribute("color", A.copyColorsArray(x.colors)), x.lineDistances && x.lineDistances.length === x.vertices.length) { var M = new l.Float32BufferAttribute(x.lineDistances.length, 1); m.setAttribute("lineDistance", M.copyArray(x.lineDistances)); } x.boundingSphere !== null && (m.boundingSphere = x.boundingSphere.clone()), x.boundingBox !== null && (m.boundingBox = x.boundingBox.clone()); } else v.isMesh && (m = x.toBufferGeometry()); return m; }; class u { constructor() { this.vertices = [], this.normals = [], this.colors = [], this.uvs = [], this.uvs2 = [], this.groups = [], this.morphTargets = {}, this.skinWeights = [], this.skinIndices = [], this.boundingBox = null, this.boundingSphere = null, this.verticesNeedUpdate = false, this.normalsNeedUpdate = false, this.colorsNeedUpdate = false, this.uvsNeedUpdate = false, this.groupsNeedUpdate = false; } computeGroups(m) { var x, w, A = [], M = void 0, R = m.faces; for (w = 0; w < R.length; w++) { var L = R[w]; L.materialIndex !== M && (M = L.materialIndex, x !== void 0 && (x.count = 3 * w - x.start, A.push(x)), x = { start: 3 * w, materialIndex: M }); } x !== void 0 && (x.count = 3 * w - x.start, A.push(x)), this.groups = A; } fromGeometry(m) { var x, w = m.faces, A = m.vertices, M = m.faceVertexUvs, R = M[0] && 0 < M[0].length, L = M[1] && 0 < M[1].length, S = m.morphTargets, I = S.length; if (0 < I) { x = []; for (var T = 0; T < I; T++) x[T] = { name: S[T].name, data: [] }; this.morphTargets.position = x; } var _, E = m.morphNormals, C = E.length; if (0 < C) { _ = []; for (var P = 0; P < C; P++) _[P] = { name: E[P].name, data: [] }; this.morphTargets.normal = _; } var b = m.skinIndices, F = m.skinWeights, D = b.length === A.length, N = F.length === A.length; 0 < A.length && w.length === 0 && console.error("THREE.DirectGeometry: Faceless geometries are not supported."); for (var B, U = 0; U < w.length; U++) { B = w[U], this.vertices.push(A[B.a], A[B.b], A[B.c]); var G = B.vertexNormals; if (G.length === 3) this.normals.push(G[0], G[1], G[2]); else { var Y = B.normal; this.normals.push(Y, Y, Y); } var te = B.vertexColors; if (te.length === 3) this.colors.push(te[0], te[1], te[2]); else { var ae = B.color; this.colors.push(ae, ae, ae); } if (R === true) { var ie = M[0][U]; ie === void 0 ? (console.warn("THREE.DirectGeometry.fromGeometry(): Undefined vertexUv ", U), this.uvs.push(new l.Vector2(), new l.Vector2(), new l.Vector2())) : this.uvs.push(ie[0], ie[1], ie[2]); } if (L === true) { var le = M[1][U]; le === void 0 ? (console.warn("THREE.DirectGeometry.fromGeometry(): Undefined vertexUv2 ", U), this.uvs2.push(new l.Vector2(), new l.Vector2(), new l.Vector2())) : this.uvs2.push(le[0], le[1], le[2]); } for (var W, $ = 0; $ < I; $++) W = S[$].vertices, x[$].data.push(W[B.a], W[B.b], W[B.c]); for (var j, re = 0; re < C; re++) j = E[re].vertexNormals[U], _[re].data.push(j.a, j.b, j.c); D && this.skinIndices.push(b[B.a], b[B.b], b[B.c]), N && this.skinWeights.push(F[B.a], F[B.b], F[B.c]); } return this.computeGroups(m), this.verticesNeedUpdate = m.verticesNeedUpdate, this.normalsNeedUpdate = m.normalsNeedUpdate, this.colorsNeedUpdate = m.colorsNeedUpdate, this.uvsNeedUpdate = m.uvsNeedUpdate, this.groupsNeedUpdate = m.groupsNeedUpdate, m.boundingSphere !== null && (this.boundingSphere = m.boundingSphere.clone()), m.boundingBox !== null && (this.boundingBox = m.boundingBox.clone()), this; } } class y { constructor(m, x, w, A, M) { var R = 5 < arguments.length && arguments[5] !== void 0 ? arguments[5] : 0; this.a = m, this.b = x, this.c = w, this.normal = A && A.isVector3 ? A : new l.Vector3(), this.vertexNormals = Array.isArray(A) ? A : [], this.color = M && M.isColor ? M : new l.Color(), this.vertexColors = Array.isArray(M) ? M : [], this.materialIndex = R; } clone() { return new this.constructor().copy(this); } copy(m) { this.a = m.a, this.b = m.b, this.c = m.c, this.normal.copy(m.normal), this.color.copy(m.color), this.materialIndex = m.materialIndex; for (var x = 0, w = m.vertexNormals.length; x < w; x++) this.vertexNormals[x] = m.vertexNormals[x].clone(); for (var A = 0, M = m.vertexColors.length; A < M; A++) this.vertexColors[A] = m.vertexColors[A].clone(); return this; } } }, /* 7 */ /***/ (o) => { o.exports = JB; }, /* 8 */ /***/ (o) => { o.exports = ""; }, /* 9 */ /***/ (o, a) => { a.augmentMorphColor = function() { return function(c) { c.vertexShader = c.vertexShader.replace("#include ", ["varying vec3 vColor;", "attribute vec3 morphColor0;", "attribute vec3 morphColor1;"].join(` `)), c.vertexShader = c.vertexShader.replace("#include ", ["vColor.xyz = color.xyz;", "#ifdef USE_MORPHTARGETS", "vColor = morphColor0 * morphTargetInfluences[ 0 ];", "vColor += morphColor1 * morphTargetInfluences[ 1 ];", "#endif"].join(` `)); }; }; }, /* 10 */ /***/ (o, a, c) => { var l = c(4), d = c(5).createBufferGeometry, h6 = c(5).resolveURL, f = 0, g = function() { return "pr" + f++; }, p = function() { this.isZincObject = true, this.geometry = void 0, this.morph = void 0, this.group = new l.Group(), this._lod = new (c(11)).LOD(this), this.groupName = void 0, this.timeEnabled = false, this.morphColour = false, this.inbuildTime = 0, this.mixer = void 0, this.animationGroup = void 0, this.duration = 6e3, this.clipAction = void 0, this.userData = {}, this.videoHandler = void 0, this.marker = void 0, this.markerNumber = void 0, this.markerUpdateRequired = true, this.closestVertexIndex = -1, this.boundingBoxUpdateRequired = true, this.cachedBoundingBox = new l.Box3(), this.anatomicalId = void 0, this.region = void 0, this.animationClip = void 0, this.markerMode = "inherited", this.uuid = g(), this._v1 = new l.Vector3(), this._v2 = new l.Vector3(), this._b1 = new l.Box3(), this.center = new l.Vector3(), this.radius = 0, this.visible = true, this.drawRange = -1, this.origColour = void 0, this.origVertexColors = false, this.isPickable = true; }; p.prototype.setDuration = function(u) { this.duration = u, this.clipAction && this.clipAction.setDuration(this.duration); }, p.prototype.getDuration = function() { return this.duration; }, p.prototype.setRegion = function(u) { this.region = u; }, p.prototype.getRegion = function() { return this.region; }, p.prototype.getMorph = function() { var u = this._lod.getCurrentMorph(); return u || this.morph; }, p.prototype.getGroup = function() { return this.group; }, p.prototype.setMorph = function(u) { this.morph = u, this.group.add(this.morph); var y = this._lod.calculateDistance("far"); this._lod.addLevel(u, y), this._lod.setMaterial(u.material); }, p.prototype.checkTransparentMesh = function() { }, p.prototype.setMesh = function(u, y, v) { this.animationGroup = new l.AnimationObjectGroup(u), this.mixer = new l.AnimationMixer(this.animationGroup); var m = u.geometry; if (this.geometry = u.geometry, this.clipAction = void 0, m && m.morphAttributes) { var x = m.morphAttributes.position; x || (x = m.morphAttributes.color ? m.morphAttributes.color : m.morphAttributes.normal), x && (this.animationClip = l.AnimationClip.CreateClipsFromMorphTargetSequences(x, 10, true), this.animationClip && this.animationClip[0] != null && (this.clipAction = this.mixer.clipAction(this.animationClip[0]).setDuration(this.duration), this.clipAction.loop = l.loopOnce, this.clipAction.clampWhenFinished = true, this.clipAction.play())); } this.timeEnabled = y, this.morphColour = v, u.userData = this, u.matrixAutoUpdate = false, this.setMorph(u), this.checkTransparentMesh(), this.timeEnabled ? this.setFrustumCulled(false) : this.morphColour && (m.setAttribute("morphTarget0", m.getAttribute("position")), m.setAttribute("morphTarget1", m.getAttribute("position"))), this.boundingBoxUpdateRequired = true; }, p.prototype.setIsPickable = function(u) { this.isPickable !== u && (this.isPickable = u, this.region && (this.region.pickableUpdateRequired = true)); }, p.prototype.setAnatomicalId = function(u) { this.anatomicalId = u; }, p.prototype.setName = function(u) { this.groupName = u, this._lod.setName(u); }, p.prototype.getCurrentTime = function() { if (this.clipAction) { var u = this.clipAction.time / this.clipAction._clip.duration; return this.duration * u; } return this.inbuildTime; }, p.prototype.setMorphTime = function(u) { var y = false; if (this.clipAction) { var v = u / this.duration, m = this.clipAction._clip.duration, x = v * m; x != this.clipAction.time && (this.clipAction.time = x, y = true), y && this.isTimeVarying() && this.mixer.update(0); } else { var w = u; w = u > this.duration ? this.duration : 0 > u ? 0 : u, w != this.inbuildTime && (this.inbuildTime = w, y = true); } y && (this.boundingBoxUpdateRequired = true, this._lod.updateMorphColorAttribute(true), this.timeEnabled && (this.markerUpdateRequired = true)); }, p.prototype.isTimeVarying = function() { return !!(this.timeEnabled || this.morphColour); }, p.prototype.getVisibility = function() { return this.visible; }, p.prototype.setVisibility = function(u) { u !== this.visible && (this.visible = u, this.group.visible = u, this.region && (this.region.pickableUpdateRequired = true)); }, p.prototype.setAlpha = function(u) { var y = this._lod._material, v = false; 1 > u && (v = true), y.opacity = u, y.transparent = v, this.checkTransparentMesh(); }, p.prototype.setFrustumCulled = function(u) { this._lod.setFrustumCulled(u); }, p.prototype.setVertexColors = function(u) { this._lod.setVertexColors(u); }, p.prototype.getColour = function() { return this._lod._material ? this._lod._material.color : void 0; }, p.prototype.setColour = function(u) { this._lod.setColour(u); }, p.prototype.setGreyScale = function(u) { if (u) { if (!this.origColour && this._lod._material) return this.origColour = this._lod._material.color, this.origVertexColors = this._lod._material.vertexColors, this._lod.setVertexColors(false), this._lod.setColour(new l.Color().setHex(12303291)), true; } else if (this.origColour) return this._lod.setColour(this.origColour), this._lod.setVertexColors(this.origVertexColors), this.origColour = void 0, true; return false; }, p.prototype.getColourHex = function() { return !this.morphColour && this._lod._material && this._lod._material.color ? this._lod._material.color.getHexString() : void 0; }, p.prototype.setColourHex = function(u) { this._lod._material.color.setHex(u), this._lod._secondaryMaterial && this._lod._secondaryMaterial.color.setHex(u); }, p.prototype.setEmissiveRGB = function(u) { this._lod._material && this._lod._material.emissive && this._lod._material.emissive.setRGB(...u), this._lod._secondaryMaterial && this._lod._secondaryMaterial.emissive.setRGB(...u); }, p.prototype.setMaterial = function(u) { this._lod.setMaterial(u); }, p.prototype.getClosestVertexIndex = function() { var u = -1, y = this.getMorph(); if (y && y.geoemtry) { var v = y.geometry.attributes.position; if (this._b1.setFromBufferAttribute(v), this._b1.getCenter(this._v1), v) for (var m = -1, x = 0, w = 0; w < v.count; w++) this._v2.fromArray(v.array, 3 * w), x = this._v2.distanceTo(this._v1), m == -1 ? m = x : m > x && (m = x, u = w); } return u; }, p.prototype.getClosestVertex = function(u) { var y = new l.Vector3(); this.closestVertexIndex == -1 && (this.closestVertexIndex = this.getClosestVertexIndex()); var v = this.getMorph(); if (v && v.geometry && 0 <= this.closestVertexIndex) { var m = v.morphTargetInfluences, x = v.geometry.morphAttributes; if (m && x && x.position) { for (var w = false, A = 0; A < m.length; A++) 0 < m[A] && (w = true, this._v1.fromArray(x.position[A].array, 3 * this.closestVertexIndex), y.add(this._v1.multiplyScalar(m[A]))); if (w) return u ? y.applyMatrix4(v.matrixWorld) : y; } else return y.fromArray(v.geometry.attributes.position.array, 3 * this.closestVertexIndex), u ? y.applyMatrix4(v.matrixWorld) : y; } return this.getBoundingBox(), y.copy(this.center), u ? y.applyMatrix4(this.morph.matrixWorld) : y; }, p.prototype.getBoundingBox = function() { if (this.visible) { var u = this._lod.getCurrentMorph(); if (u && u.visible) return this.boundingBoxUpdateRequired && (c(5).getBoundingBox(u, this.cachedBoundingBox, this._b1, this._v1, this._v2), this.cachedBoundingBox.getCenter(this.center), this.radius = this.center.distanceTo(this.cachedBoundingBox.max), this.boundingBoxUpdateRequired = false), this.cachedBoundingBox; } }, p.prototype.dispose = function() { this._lod.dispose(), this.animationGroup = void 0, this.mixer = void 0, this.morph = void 0, this.group = void 0, this.clipAction = void 0, this.groupName = void 0; }, p.prototype.markerIsRequired = function(u) { return !!(this.visible && (this.markerMode === "on" || u && u.displayMarkers && this.markerMode === "inherited")); }, p.prototype.updateMarker = function(u, y) { if (u == false && this.markerIsRequired(y)) { var v = y.ndcToBeUpdated; if (this.groupName) { if (this.marker || (this.marker = new (c(14)).Marker(this), this.markerUpdateRequired = true), this.markerUpdateRequired) { var m = this.getClosestVertex(false); m && (this.marker.setPosition(m.x, m.y, m.z), this.markerUpdateRequired = false); } this.marker.isEnabled() || (y.markersList && !(this.marker.uuid in y.markersList) && (v = true, y.markersList[this.marker.uuid] = this.marker), this.marker.enable(), this.group.add(this.marker.morph)), this.marker.setNumber(this.markerNumber), this.markerImgURL ? this.marker.loadUserSprite(this.markerImgURL) : this.marker.setDefaultSprite(), y && y.camera && (v || y.markerCluster.markerUpdateRequired) && (this.marker.updateNDC(y.camera.cameraObject), y.markerCluster.markerUpdateRequired = true); } } else this.marker && this.marker.isEnabled() && (this.marker.disable(), this.group.remove(this.marker.morph), y.markersList && this.marker.uuid in y.markersList && (y.markerCluster.markerUpdateRequired = true, delete y.markersList[this.marker.uuid])), this.markerUpdateRequired = true; }, p.prototype.processMarkerVisual = function(u, y) { this.marker && this.marker.isEnabled() && this.marker.updateVisual(u, y); }, p.prototype.initiateMorphColor = function() { this.morphColour == 1 && this._lod.updateMorphColorAttribute(false); }, p.prototype.setRenderOrder = function(u) { this._lod.setRenderOrder(u); }, p.prototype.getClosestVertexDOMElementCoords = function(u) { if (u && u.camera) { var y = true, v = this.getClosestVertex(true); return v.project(u.camera), v.z = Math.min(Math.max(v.z, 0), 1), (1 < v.x || -1 > v.x || 1 < v.y || -1 > v.y) && (y = false), u.getZincCameraControls().getRelativeCoordsFromNDC(v.x, v.y, v), { position: v, inView: y }; } }, p.prototype.setMarkerMode = function(u, y) { u !== this.markerMode && (this.markerMode = u === "on" || u === "off" ? u : "inherited", this.region && (this.region.pickableUpdateRequired = true)), y && (this.markerNumber = y.number, this.markerImgURL = y.imgURL); }, p.prototype.render = function(u, y, v, m) { if (this.visible && !(this.timeEnabled && y) && this._lod.update(v, this.center), y == true) { if (this.clipAction && this.isTimeVarying()) this.mixer.update(u); else { var x = this.inbuildTime + u; x > this.duration && (x -= this.duration), this.inbuildTime = x; } this.visible && u != 0 && (this.boundingBoxUpdateRequired = true, this.morphColour == 1 && this._lod.updateMorphColorAttribute(true)); } this.updateMarker(y, m); }, p.prototype.addLOD = function(u, y, v, m, x) { this._lod.addLevelFromURL(u, y, v, m, x); }, p.prototype.addVertices = function(u) { var y = this.getMorph(), v = void 0; if (!y) v = d(500, u), this.drawRange = u.length; else if (-1 < this.drawRange) { var m = y.geometry.getAttribute("position"); u.forEach((x) => { m.setXYZ(this.drawRange, x[0], x[1], x[2]), ++this.drawRange; }), m.needsUpdate = true, y.geometry.setDrawRange(0, this.drawRange), y.geometry.computeBoundingBox(), y.geometry.computeBoundingSphere(), v = y.geoemtry, this.boundingBoxUpdateRequired = true; } return v; }, p.prototype.setPosition = function(u, y, v) { var m = this.getGroup(); m && (m.position.set(u, y, v), m.updateMatrix(), this.boundingBoxUpdateRequired = true); }, p.prototype.loadAdditionalSources = function(u) { u.load(h6(filename), meshloader(region, colour, opacity, localTimeEnabled, localMorphColour, void 0, void 0, void 0, void 0, finishCallback), this.onProgress(filename), this.onError(finishCallback)); }, p.prototype.setScaleAll = function(u) { var y = this.getGroup(); y && (y.scale.set(u, u, u), y.updateMatrix(), this.boundingBoxUpdateRequired = true); }, a.ZincObject = p; }, /* 11 */ /***/ (o, a, c) => { var l = c(4), d = c(5).updateMorphColorAttribute, h6 = c(5).toBufferGeometry, f = function(g) { this.levels = [], this._currentLevel = 0, this._renderOrder = 1, this._material = void 0, this._secondaryMaterial = void 0, this._loader = void 0, this._parent = g, this.addLevel = (u, y) => { if (u) { var v, m = Math.abs(y); for (v = 0; v < this.levels.length && !(m < this.levels[v].distance); v++) ; this.levels.splice(v, 0, { distance: m, morph: u, loaded: true, loading: false, url: "" }), u.renderOrder = this._renderOrder; } }, this.levelLoaded = (u, y) => { if (u) { for (var v = Math.abs(y), m = 0; m < this.levels.length; m++) if (v === this.levels[m].distance) { this._parent.group.add(u), this.levels[m].morph = u, this.levels[m].loaded = true, this.levels[m].loading = false; break; } this.checkTransparentMesh(); } }, this.addLevelFromURL = (u, y, v, m, x) => { this._loader = u; var w, A = this.calculateDistance(y); for (w = 0; w < this.levels.length && !(A < this.levels[w].distance); w++) ; this.levels.splice(w, 0, { distance: A, morph: void 0, loaded: false, loading: false, url: v, index: m }), x && this.loadLevel(w); }, this.loadLevel = (u) => { var y = this.levels[u]; return y.morph || y.loaded || y.loading || (y.loading = true, this._loader.load(y.url, this.lodLoader(y.distance), void 0, void 0, { index: y.index })), y.morph === void 0; }, this.calculateDistance = function(u) { this._parent.getBoundingBox(); var y = this._parent.radius, v = 0; return u === "far" ? v = 4.5 * y : u === "medium" ? v = 2.5 * y : u == "close" && (v = 0), v; }, this.containsLevels = () => !!(this.levels && 1 < this.levels.length), this.checkTransparentMesh = () => { var u = this.levels[this._currentLevel]; this._material && (this._material.transparent ? (!this._secondaryMaterial && (this._secondaryMaterial = this._material.clone(), this._secondaryMaterial.side = l.FrontSide), this._secondaryMaterial.opacity = this._material.opacity, this._secondaryMaterial.emissive && this._secondaryMaterial.emissive.copy(this._material.emissive), this._secondaryMaterial.needsUpdate = true, !u.secondaryMesh && (u.secondaryMesh = new l.Mesh(u.morph.geometry, this._secondaryMaterial), u.secondaryMesh.renderOrder = u.morph.renderOrder + 1, u.secondaryMesh.userData = u.morph.userData, u.secondaryMesh.name = u.morph.name), this._material.side = l.BackSide, this._material.needsUpdate = true, !u.secondaryMesh.parent && (u.morph.add(u.secondaryMesh), this._parent.animationGroup && this._parent.animationGroup.add(u.secondaryMesh))) : (u.secondaryMesh && (u.morph.remove(u.secondaryMesh), this._parent.animationGroup && (this._parent.animationGroup.uncache(u.secondaryMesh), this._parent.animationGroup.remove(u.secondaryMesh))), this._material.side = l.DoubleSide, this._material.needsUpdate = true)); }, this.dispose = () => { this.levels.forEach((u) => { u.morph && u.morph.geometry && u.morph.geometry.dispose(); }), this._material && this._material.dispose(), this._secondaryMaterial && this._secondaryMaterial.dispose(); }, this.getCurrentLevel = () => this._currentLevel, this.getCurrentMorph = () => { var u = this.levels[this._currentLevel]; return u && u.morph ? u.morph : this._parent.morph; }, this.lodLoader = function(u) { return (y) => { var v = this._material, m = { localTimeEnabled: this._parent.timeEnabled, localMorphColour: this._parent.morphColour }, x = h6(y, m), w = void 0; this._parent.isGeometry ? w = new l.Mesh(x, v) : this._parent.isLines && (w = new (c(12)).LineSegments(x, v)), w.userData = this._parent, w.renderOrder = this._renderOrder, y.dispose(), this.levelLoaded(w, u); }; }, this.updateMorphColorAttribute = (u) => { if (this._material && (this._material.vertexColors == l.VertexColors || this._material.vertexColors == true)) if (u) { var y = this.getCurrentMorph(); d(y.geometry, y); } else this.levels.forEach((v) => { v.morph && v.morph.geometry && d(v.morph.geometry, v.morph); }); }, this.setColour = (u) => { this._material.color = u, this._secondaryMaterial && (this._secondaryMaterial.color = u), p(); }, this.setFrustumCulled = (u) => { this.levels.forEach((y) => { y.morph && (y.morph.frustumCulled = u), y.secondaryMesh && (y.secondaryMesh.frustumCulled = u); }); }, this.setMaterial = (u) => { u && (!this._material || this._material.id !== u.id) && (this._material = u, this._secondaryMaterial && this._secondaryMaterial.dispose(), this._secondaryMaterial = u.clone(), this._secondaryMaterial.side = l.FrontSide, this._secondaryMaterial.transparent = true, this.levels.forEach((y) => { y.morph && (y.morph.material = this._material, y.morph.geometry && (y.morph.geometry.colorsNeedUpdate = true)), y.secondaryMesh && (y.secondaryMesh.material = this._secondaryMaterial); })); }, this.setName = (u) => { this.levels.forEach((y) => { y.morph && (y.morph.name = u), y.secondaryMesh && (y.secondaryMesh.name = u); }); }, this.setRenderOrder = (u) => { this._renderOrder = u, this.levels.forEach((y) => { y.morph && (y.morph.renderOrder = u), y.secondaryMesh && (y.secondaryMesh.renderOrder = u); }); }, this.setVertexColors = (u) => { this._material.vertexColors = u, p(), this._secondaryMaterial && (this._secondaryMaterial.vertexColors = u); }, this.update = (u, y) => { var v = this.levels; if (1 < v.length) { var m, x, w = u.cameraObject.position.distanceTo(y), A = -1, M = -1; for (m = 0, x = v.length; m < x && w >= v[m].distance; m++) v[m].morph ? (-1 < A && v[A].morph && (v[A].morph.visible = false), A = m, v[m].morph.visible = true, M = -1) : M = m; for (-1 < M && this.loadLevel(M); m < x; m++) v[m].morph && (-1 < A ? v[m].morph.visible = false : (v[m].morph.visible = true, A = m)); this._currentLevel != A && (this._currentLevel = A, this.checkTransparentMesh()); } }, this.toggleMarker = (u, y) => { this.levels.forEach((v) => { v.morph && (y ? v.morph.add(u) : v.morph.remove(u)); }); }; var p = () => { this.levels.forEach((u) => { u.morph && u.morph.geometry && (u.morph.geometry.colorsNeedUpdate = true); }); }; }; a.LOD = f; }, /* 12 */ /***/ (o, a, c) => { c.r(a), c.d(a, { /* harmony export */ LineSegments: () => ( /* binding */ g ) /* harmony export */ }); var l = c(13), d = c(4), h6 = new d.Vector3(), f = new d.Vector3(); class g extends l.Line { constructor(u, y) { super(u, y), this.type = "LineSegments"; } computeLineDistances() { var u = this.geometry; if (!u.isBufferGeometry) u.isGeometry && console.error("THREE.LineSegments.computeLineDistances() no longer supports THREE.Geometry. Use THREE.BufferGeometry instead."); else if (u.index === null) { for (var y = u.attributes.position, v = [], m = 0, x = y.count; m < x; m += 2) h6.fromBufferAttribute(y, m), f.fromBufferAttribute(y, m + 1), v[m] = m == 0 ? 0 : v[m - 1], v[m + 1] = v[m] + h6.distanceTo(f); u.setAttribute("lineDistance", new d.Float32BufferAttribute(v, 1)); } else console.warn("THREE.LineSegments.computeLineDistances(): Computation only possible with non-indexed BufferGeometry."); return this; } } g.prototype.isLineSegments = true; }, /* 13 */ /***/ (o, a, c) => { c.r(a), c.d(a, { /* harmony export */ Line: () => ( /* binding */ x ) /* harmony export */ }); var l = c(4), d = new l.Vector3(), h6 = new l.Vector3(), f = new l.Matrix4(), g = new l.Ray(), p = new l.Sphere(), u = new l.Vector3(), y = new l.Vector3(), v = new l.Vector3(), m = new l.Vector3(); class x extends l.Object3D { constructor() { var M = 0 < arguments.length && arguments[0] !== void 0 ? arguments[0] : new l.BufferGeometry(), R = 1 < arguments.length && arguments[1] !== void 0 ? arguments[1] : new l.LineBasicMaterial(); super(), this.type = "Line", this.geometry = M, this.material = R, this.updateMorphTargets(); } copy(M) { return super.copy(M), this.material = M.material, this.geometry = M.geometry, this; } computeLineDistances() { var M = this.geometry; if (!M.isBufferGeometry) M.isGeometry && console.error("THREE.Line.computeLineDistances() no longer supports THREE.Geometry. Use THREE.BufferGeometry instead."); else if (M.index === null) { for (var R = M.attributes.position, L = [0], S = 1, I = R.count; S < I; S++) d.fromBufferAttribute(R, S - 1), h6.fromBufferAttribute(R, S), L[S] = L[S - 1], L[S] += d.distanceTo(h6); M.setAttribute("lineDistance", new l.Float32BufferAttribute(L, 1)); } else console.warn("THREE.Line.computeLineDistances(): Computation only possible with non-indexed BufferGeometry."); return this; } raycast(M, R) { var L = this.geometry, S = this.matrixWorld, I = M.params.Line.threshold, T = L.drawRange, _ = L.morphAttributes.position; if (L.boundingSphere === null && L.computeBoundingSphere(), p.copy(L.boundingSphere), p.applyMatrix4(S), p.radius += I, M.ray.intersectsSphere(p) !== false) { f.copy(S).invert(), g.copy(M.ray).applyMatrix4(f); var E = I / ((this.scale.x + this.scale.y + this.scale.z) / 3), C = E * E, P = new l.Vector3(), b = new l.Vector3(), F = new l.Vector3(), D = new l.Vector3(), N = this.isLineSegments ? 2 : 1; if (L.isBufferGeometry) { var B = L.index, U = L.attributes, G = U.position; if (B !== null) for (var Y = Math.max(0, T.start), te = Math.min(B.count, T.start + T.count), ae = Y; ae < te - 1; ae += N) { var ie = B.getX(ae), le = B.getX(ae + 1); w(P, b, this, G, _, ie, le); var W = g.distanceSqToSegment(P, b, D, F); if (!(W > C)) { D.applyMatrix4(this.matrixWorld); var $ = M.ray.origin.distanceTo(D); $ < M.near || $ > M.far || R.push({ distance: $, // What do we want? intersection point on the ray or on the segment?? // point: raycaster.ray.at( distance ), point: F.clone().applyMatrix4(this.matrixWorld), index: ae, face: null, faceIndex: null, object: this }); } } else for (var j = Math.max(0, T.start), re = Math.min(G.count, T.start + T.count), V = j; V < re - 1; V += N) { w(P, b, this, G, _, V, V + 1); var H = g.distanceSqToSegment(P, b, D, F); if (!(H > C)) { D.applyMatrix4(this.matrixWorld); var K = M.ray.origin.distanceTo(D); K < M.near || K > M.far || R.push({ distance: K, // What do we want? intersection point on the ray or on the segment?? // point: raycaster.ray.at( distance ), point: F.clone().applyMatrix4(this.matrixWorld), index: V, face: null, faceIndex: null, object: this }); } } } else L.isGeometry && console.error("THREE.Line.raycast() no longer supports THREE.Geometry. Use THREE.BufferGeometry instead."); } } updateMorphTargets() { var M = this.geometry; if (M.isBufferGeometry) { var R = M.morphAttributes, L = Object.keys(R); if (0 < L.length) { var S = R[L[0]]; if (S !== void 0) { this.morphTargetInfluences = [], this.morphTargetDictionary = {}; for (var I, T = 0, _ = S.length; T < _; T++) I = S[T].name || T + "", this.morphTargetInfluences.push(0), this.morphTargetDictionary[I] = T; } } } else { var E = M.morphTargets; E !== void 0 && 0 < E.length && console.error("THREE.Line.updateMorphTargets() does not support THREE.Geometry. Use THREE.BufferGeometry instead."); } } } function w(A, M, R, L, S, I, T) { A.fromBufferAttribute(L, I), M.fromBufferAttribute(L, T); var _ = R.morphTargetInfluences; if (R.material.morphTargets && S && _) { u.set(0, 0, 0), y.set(0, 0, 0); for (var E = 0, C = S.length; E < C; E++) { var P = _[E], b = S[E]; P !== 0 && (v.fromBufferAttribute(b, I), m.fromBufferAttribute(b, T), u.addScaledVector(v.sub(A), P), y.addScaledVector(m.sub(M), P)); } A.add(u), M.add(y); } } x.prototype.isLine = true; }, /* 14 */ /***/ (o, a, c) => { var l = c(4), d = new Image(128, 128); d.src = c(15); var h6 = new l.Texture(); h6.image = d, h6.needsUpdate = true; var f = [0.02, 0.03, 1], g = new l.SpriteMaterial({ map: h6, alphaTest: 0.5, transparent: true, depthTest: false, depthWrite: false, sizeAttenuation: false }), p = c(5).createNewSpriteText, u = function(y) { c(10).ZincObject.call(this), this.texture = h6; var v = void 0, m = void 0, x = void 0, w = void 0, A = void 0, M = true; this.morph = new l.Group(), this.group = this.morph, this.parent = y, this.isMarker = true; var R = false; this.ndc = new l.Vector3(); var L = void 0, S = void 0, I = () => { v = new l.Sprite(g), v.center.set(0.5, 0), this.morph.add(v), this.morph.position.set(0, 0, 0), this.morph.renderOrder = 1e4, v.scale.set(f[0], f[1], f[2]), v.userData = this; }; this.updateVisual = (T, _) => { var E = 1, C = 0; T !== _ && (C = 1 - (this.ndc.z - T) / (_ - T), E = 0.6 + 0.4 * C), this.setSpriteSize(E); }, this.updateNDC = (T) => (this.ndc.copy(this.morph.position), this.ndc.project(T), this.ndc.z = Math.min(Math.max(this.ndc.z, 0), 1), this.ndc), this.setPosition = (T, _, E) => { this.morph.position.set(T, _, E); }, this.setSpriteSize = (T) => { v.scale.set(0.015, 0.02, 1), v.scale.multiplyScalar(T); }, this.setUserSprite = () => { w && (this.morph.add(w), M && (this.morph.remove(v), S && this.morph.remove(S), M = false)); }, this.setImageForUserSprite = (T, _) => { w && (this.morph.remove(w), w = void 0), m && m.dispose(), x && x.dispose(), m = new l.Texture(), m.image = T, m.needsUpdate = true, x = new l.SpriteMaterial({ map: m, alphaTest: 0.5, transparent: true, depthTest: false, depthWrite: false, sizeAttenuation: false }), _ || (_ = [0.05, 0.05, 1]), w = new l.Sprite(x), w.center.set(0.5, 0), w.scale.set(_[0], _[1], _[2]), w.userData = this, this.setUserSprite(); }, this.setDefaultSprite = () => { M || (M = true, this.morph.add(v), w && this.morph.remove(w), S && this.morph.add(S)); }, this.loadUserSprite = (T, _) => { if (T) if (T !== A) { A = T; var E = new Image(128, 128); E.crossOrigin = "anonymous", E.onload = () => { this.setImageForUserSprite(E, _); }, E.src = T; } else this.setUserSprite(); }, this.dispose = () => { this.morph && this.morph.clear(), v && (v.clear(), v = void 0), S && (S.material.map.dispose(), S.material.dispose(), S = void 0); }, this.isEnabled = () => R, this.setNumber = (T) => { (!T || L != T) && S && (this.morph.remove(S), S.material.map.dispose(), S.material.dispose(), S = void 0), !S && T && (S = p(T, 0.012, "black", "Asap", 120, 700), this.morph.add(S)), L = T; }, this.getNumber = () => L || 1, this.setVisibility = function(T) { T !== this.visible && (this.visible = T, this.group.visible = T, this.parent.region && (this.parent.region.pickableUpdateRequired = true)); }, this.enable = () => { R = true, this.morph.visible = true, this.visible = true; }, this.disable = () => { R = false, this.morph.visible = false, this.visible = false; }, I(); }; u.prototype = Object.create(c(10).ZincObject.prototype), a.Marker = u; }, /* 15 */ /***/ (o) => { o.exports = ""; }, /* 16 */ /***/ (o, a, c) => { var l = c(4), d = function(h6, f, g, p) { c(10).ZincObject.call(this); var u; f && (u = f.clone(), u.vertexColors = l.FaceColors), this.id = g; var y = void 0, v = void 0; this.isGlyph = true; var m = [0, 0, 0]; this.fromMesh = (x) => !!(x && x.isMesh) && (this.morph = x.clone(), this.morph.userData = this, this.group.add(this.morph), true), h6 && u && this.fromMesh(new l.Mesh(h6, u)), this.getGlyphset = function() { return p; }, this.setLabel = (x) => { x && (typeof x == "string" || x instanceof String) && (v = x, this.morph && (this.morph.name = x)); }, this.showLabel = (x) => { y && (m = y.getPosition(), this.group.remove(y.getSprite()), y.dispose(), y = void 0), v && (typeof v == "string" || v instanceof String) && (y = new (c(17)).Label(v, x), y.setPosition(m[0], m[1], m[2]), this.group.add(y.getSprite())); }, this.hideLabel = () => { y && (m = y.getPosition(), this.group.remove(y.getSprite()), y.dispose(), y = void 0); }, this.getLabel = () => v, this.getMesh = () => this.morph, this.setTransformation = (x, w, A, M) => { this.morph && (this.morph.matrix.elements[0] = w[0], this.morph.matrix.elements[1] = w[1], this.morph.matrix.elements[2] = w[2], this.morph.matrix.elements[3] = 0, this.morph.matrix.elements[4] = A[0], this.morph.matrix.elements[5] = A[1], this.morph.matrix.elements[6] = A[2], this.morph.matrix.elements[7] = 0, this.morph.matrix.elements[8] = M[0], this.morph.matrix.elements[9] = M[1], this.morph.matrix.elements[10] = M[2], this.morph.matrix.elements[11] = 0, this.morph.matrix.elements[12] = x[0], this.morph.matrix.elements[13] = x[1], this.morph.matrix.elements[14] = x[2], this.morph.matrix.elements[15] = 1, this.morph.matrixAutoUpdate = false), m = [...x], y && y.setPosition(x[0], x[1], x[2]); }, this.setColour = (x) => { y && y.setColour(x), this.secondaryMesh && this.secondaryMesh.material && (this.secondaryMesh.material.color = colour), this.geometry && (this.geometry.colorsNeedUpdate = true); }, this.dispose = () => { this.material && this.material.dispose(), this.morph = void 0; }; }; d.prototype = Object.create(c(10).ZincObject.prototype), a.Glyph = d; }, /* 17 */ /***/ (o, a, c) => { var l = c(7).default; a.Label = function(d, h6) { var f = d, g = void 0; g = h6 ? new l(f, 0.015, h6.getStyle()) : new l(f, 0.015), g.fontFace = "Asap", g.fontWeight = 700, g.material.map.generateMipmaps = false, g.material.sizeAttenuation = false, g.center.x = -0.05, g.center.y = 0, this.getPosition = () => g ? [g.position.x, g.position.y, g.position.z] : [0, 0, 0], this.setPosition = (p, u, y) => { g && g.position.set(p, u, y); }, this.setColour = (p) => { g.color = p.getStyle(); }, this.setScale = (p) => { g && 0 < p && g.scale.set(p, p, 1); }, this.dispose = () => { }, this.getSprite = () => g, this.getString = () => f; }; }, /* 18 */ /***/ (o, a, c) => { var l = c(4), d = c(19).JSONLoader, h6 = function() { c(10).ZincObject.call(this); var f = [], g = void 0, p = void 0, u = void 0, y = void 0, v = void 0, m = void 0, x = void 0, w = 0, A = 0, M = [0, 0, 0], R = [0, 0, 0], L = [0, 0, 0], S = "NONE"; this.ready = false; var I = false, T = false; this.isGlyphset = true; var _ = new l.Matrix4(), E = new l.Color(), C = new l.Color(), P = new l.Box3(), b = new l.Box3(), F = new l.Box3(), D = [], N = [], B = [], U = [], G = [], Y = [], te = []; this.globalScale = 1; for (var ae = 0; 8 > ae; ae++) new l.Vector3(); this.load = (V, H, K, ce, se) => { g = V.axis1, p = V.axis2, u = V.axis3, y = V.positions, v = V.scale, m = V.colors, x = V.label, I = V.metadata.MorphColours, T = V.metadata.MorphVertices, w = V.metadata.number_of_time_steps, S = V.metadata.repeat_mode, A = V.metadata.number_of_vertices, S == "AXES_2D" || S == "MIRROR" ? A *= 2 : S == "AXES_3D" && (A *= 3), M = V.metadata.base_size, R = V.metadata.offset, L = V.metadata.scale_factors; var k = new d(); this.geometry = new l.BufferGeometry(); var O = new l.InstancedMesh(this.geometry, void 0, A); if (this.setMorph(O), ce) { var Z = k.parse(H); re(K, se)(Z.geometry, Z.materials), Z.geometry.dispose(); } else k.crossOrigin = "Anonymous", k.load(H, re(K, se)); }; var ie = (V, H, K, ce, se, k) => { if (S == "NONE" || S == "MIRROR") { for (var O, Z = [0, 0, 0], X = [0, 0, 0], ee = [0, 0, 0], fe = [0, 0, 0], be = [0, 0, 0], Ae = [0, 0, 0], he = [0, 0, 0], xe = [0, 0, 0], ne = [0, 0, 0], me = 0; 3 > me; me++) O = 0 > se[me] ? -1 : 1, Z[me] = (O * M[me] + se[me] * L[me]) * this.globalScale; for (var me = 0; 3 > me; me++) X[me] = H[me] * Z[0], ee[me] = K[me] * Z[1], fe[me] = ce[me] * Z[2], be[me] = V[me] + R[0] * X[me] + R[1] * ee[me] + R[2] * fe[me], S == "MIRROR" && (Ae[me] = -X[me], he[me] = -ee[me], xe[me] = -fe[me], ne[me] = be[me], 0 > se[0] && (be[me] -= X[me], ne[me] -= Ae[me])); 0 > fe[0] * (X[1] * ee[2] - X[2] * ee[1]) + fe[1] * (X[2] * ee[0] - X[0] * ee[2]) + fe[2] * (X[0] * ee[1] - X[1] * ee[0]) && (fe[0] = -fe[0], fe[1] = -fe[1], fe[2] = -fe[2]), k[0] = [be, X, ee, fe], S == "MIRROR" && (0 > xe[0] * (Ae[1] * he[2] - Ae[2] * he[1]) + xe[1] * (Ae[2] * he[0] - Ae[0] * he[2]) + xe[2] * (Ae[0] * he[1] - Ae[1] * he[0]) && (xe[0] = -xe[0], xe[1] = -xe[1], xe[2] = -xe[2]), k[1] = [ne, Ae, he, xe]); } else if (S == "AXES_2D" || S == "AXES_3D") { for (var O, Me = [0, 0, 0], De = [0, 0, 0], me = 0; 3 > me; me++) O = 0 > se[me] ? -1 : 1, Me[me] = (O * M[0] + se[me] * L[0]) * this.globalScale; for (var me = 0; 3 > me; me++) De[me] = V[me] + R[0] * Me[0] * H[me] + R[1] * Me[1] * K[me] + R[2] * Me[2] * ce[me]; for (var Ie = glyph_repeat_mode == "AXES_2D" ? 2 : 3, $e = 0; $e < Ie; $e++) { var lt = void 0, qe = void 0, Mt = se[$e], Be = [0, 0, 0], it = [0, 0, 0], tt = [0, 0, 0]; $e == 0 ? (lt = H, qe = K) : $e == 1 ? (lt = K, qe = glyph_repeat_mode == "AXES_2D" ? H : ce) : (lt = ce, qe = H); var qt = (M[0] + Mt * L[0]) * this.globalScale; Be[0] = lt[0] * qt, Be[1] = lt[1] * qt, Be[2] = lt[2] * qt, tt[0] = Be[1] * qe[2] - qe[1] * Be[2], tt[1] = Be[2] * qe[0] - qe[2] * Be[0], tt[2] = Be[0] * qe[1] - Be[1] * qe[0]; var Qt = Math.sqrt(tt[0] * tt[0] + tt[1] * tt[1] + tt[2] * tt[2]); if (0 < Qt) { var Ft = (M[2] + Mt * L[2]) * this.globalScale / Qt; S == "AXES_2D" && 0 < $e && (Ft *= -1), tt[0] *= Ft, tt[1] *= Ft, tt[2] *= Ft; } if (it[0] = tt[1] * Be[2] - Be[1] * tt[2], it[1] = tt[2] * Be[0] - Be[2] * tt[0], it[2] = tt[0] * Be[1] - tt[1] * Be[0], Qt = Math.sqrt(it[0] * it[0] + it[1] * it[1] + it[2] * it[2]), 0 < Qt) { var Nt = (M[1] + Mt * L[1]) * this.globalScale / Qt; it[0] *= Nt, it[1] *= Nt, it[2] *= Nt; } k[$e] = [De, Be, it, tt]; } } return k; }, le = (V, H, K, ce, se) => { var k = 1; S == "AXES_2D" || S == "MIRROR" ? k = 2 : S == "AXES_3D" && (k = 3); var O = V.length / 3, Z = 0; te.length = k; for (var X = 0; X < O; X++) { var ee = 3 * X, fe = [V[ee], V[ee + 1], V[ee + 2]], be = [H[ee], H[ee + 1], H[ee + 2]], Ae = [K[ee], K[ee + 1], K[ee + 2]], he = [ce[ee], ce[ee + 1], ce[ee + 2]], xe = [se[ee], se[ee + 1], se[ee + 2]], ne = ie(fe, be, Ae, he, xe, te); if (ne.length == k) for (var me = 0; me < k; me++) { _.elements[0] = ne[me][1][0], _.elements[1] = ne[me][1][1], _.elements[2] = ne[me][1][2], _.elements[3] = 0, _.elements[4] = ne[me][2][0], _.elements[5] = ne[me][2][1], _.elements[6] = ne[me][2][2], _.elements[7] = 0, _.elements[8] = ne[me][3][0], _.elements[9] = ne[me][3][1], _.elements[10] = ne[me][3][2], _.elements[11] = 0, _.elements[12] = ne[me][0][0], _.elements[13] = ne[me][0][1], _.elements[14] = ne[me][0][2], _.elements[15] = 1, this.morph.setMatrixAt(Z, _); var Me = f[Z]; Me && Me.setTransformation(ne[me][0], ne[me][1], ne[me][2], ne[me][3]), Z++; } } this.morph.instanceMatrix.needsUpdate = true; }, W = (V) => { var H = 1; S == "AXES_2D" || S == "MIRROR" ? H = 2 : S == "AXES_3D" && (H = 3); for (var K, ce = V.length, se = 0, k = 0; k < ce; k++) { K = V[k]; for (var O = 0; O < H; O++) { E.setHex(K), this.morph.setColorAt(se, E); var Z = f[se]; Z && Z.setColour(E), se++; } } this.morph.instanceColor.needsUpdate = true; }, $ = () => { var V = D, H = N, K = B, ce = U, se = G, k = Y, O = this.inbuildTime / this.duration * (w - 1), Z = Math.floor(O), X = 1 - (O - Z), ee = Math.ceil(O); if (T) { var fe = y[Z.toString()], be = y[ee.toString()], Ae = g[Z.toString()], he = g[ee.toString()], xe = p[Z.toString()], ne = p[ee.toString()], me = u[Z.toString()], Me = u[ee.toString()], De = v[Z.toString()], Ie = v[ee.toString()]; D.length = fe.length, N.length = fe.length, B.length = fe.length, U.length = fe.length, G.length = fe.length; for (var $e = 0; $e < fe.length; $e++) V[$e] = X * fe[$e] + (1 - X) * be[$e], H[$e] = X * Ae[$e] + (1 - X) * he[$e], K[$e] = X * xe[$e] + (1 - X) * ne[$e], ce[$e] = X * me[$e] + (1 - X) * Me[$e], se[$e] = X * De[$e] + (1 - X) * Ie[$e]; } else V = y[0], H = g[0], K = p[0], ce = u[0], se = v[0]; if (le(V, H, K, ce, se), this.boundingBoxUpdateRequired = true, m != null) { if (I) { var lt = m[Z.toString()], qe = m[ee.toString()]; k.length = lt.length; for (var Mt = 0; Mt < lt.length; Mt++) E.setHex(lt[Mt]), C.setHex(qe[Mt]), E.setRGB(E.r * X + C.r * (1 - X), E.g * X + C.g * (1 - X), E.b * X + C.b * (1 - X)), k[Mt] = E.getHex(); } else k = m[0]; W(k); } }; this.showLabel = () => { for (var V = 0; V < f.length; V++) f[V].showLabel(this.morph.material ? this.morph.material.color : void 0); }, this.hideLabel = () => { for (var V = 0; V < f.length; V++) f[V].hideLabel(); }; var j = (V) => { for (var H = 0; H < A; H++) { var K = new (c(16)).Glyph(void 0, void 0, H, this), ce = x ? x[H] : void 0; ce = ce || this.groupName, ce && K.setLabel(ce), 0 < w && K.setFrustumCulled(false), f[H] = K, this.morph.add(K.getGroup()); } V && this.showLabel(), le(y[0], g[0], p[0], u[0], v[0]), m != null && W(m[0]), this.ready = true, this.boundingBoxUpdateRequired = true; }; this.addCustomGlyph = (V) => { V.isGlyph && f.push(V), this.ready = true, this.boundingBoxUpdateRequired = true; }, this.addMeshAsGlyph = (V, H) => { if (V.isMesh) { var K = new (c(16)).Glyph(void 0, void 0, H, this); return K.fromMesh(V), f.push(K), this.morph.add(K.getGroup()), this.ready = true, this.boundingBoxUpdateRequired = true, K; } }, this.forEachGlyph = (V) => { for (var H = 0; H < f.length; H++) V(f[H]); }; var re = (V, H) => (K, ce) => { var se = K.toBufferGeometry(); this.geometry.copy(se), this.geometry.computeBoundingSphere(), this.geometry.computeBoundingBox(), se.dispose(), ce && ce[0] && (this.morph.material = ce[0]), j(H), this.morph.name = this.groupName, this.morph.userData = this, this.setMorph(this.morph), K.dispose(), V != null && typeof V == "function" && V(this); }; this.getClosestVertexIndex = function() { var V = -1; if (this.morph && this.ready) { this.getBoundingBox().getCenter(this._v1); for (var H, K = y[0], ce = K.length / 3, se = -1, k = 0, O = 0; O < ce; O++) H = 3 * O, this._v2.set(K[H], K[H + 1], K[H + 2]), k = this._v1.distanceTo(this._v2), (se == -1 || se > k) && (se = k, V = O); } return V; }, this.getClosestVertex = function() { if (this.closestVertexIndex == -1 && (this.closestVertexIndex = this.getClosestVertexIndex()), 0 <= this.closestVertexIndex && this.morph) { var V = new l.Vector3(); return this.morph.getMatrixAt(this.closestVertexIndex, _), V.setFromMatrixPosition(_), V; } }, this.getBoundingBox = () => { if (this.morph && this.ready && this.morph.visible) { if (this.boundingBoxUpdateRequired) { P.setFromBufferAttribute(this.morph.geometry.attributes.position); for (var V = 0; V < A; V++) this.morph.getMatrixAt(V, _), b.copy(P).applyMatrix4(_), V == 0 ? F.copy(b) : F.union(b); if (F) this.cachedBoundingBox.copy(F), this.morph.updateWorldMatrix(true, true), this.cachedBoundingBox.applyMatrix4(this.morph.matrixWorld), this.boundingBoxUpdateRequired = false; else return; } return this.cachedBoundingBox; } }, this.setMorphTime = (V) => { this.inbuildTime = V > this.duration ? this.duration : 0 > V ? 0 : V, (I || T) && ($(), T && (this.markerUpdateRequired = true)); }, this.isTimeVarying = () => !!((this.ready === false || 0 < w) && (I || T)), this.getCurrentTime = () => this.inbuildTime, this.setScaleAll = function(V) { this.globalScale = V, $(); }, this.dispose = () => { for (var V = f.length - 1; 0 <= V; V--) f[V].dispose(); this.geometry && this.geometry.dispose(), this.morph && this.morph.material.dispose(), g = void 0, p = void 0, u = void 0, y = void 0, v = void 0, m = void 0, this.ready = false, this.groupName = void 0; }, this.render = (V, H, K) => { if (H == true) { var ce = this.inbuildTime + V; ce > this.duration && (ce -= this.duration), this.inbuildTime = ce, (I || T) && $(); } this.updateMarker(H, K); }; }; h6.prototype = Object.create(c(10).ZincObject.prototype), a.Glyphset = h6; }, /* 19 */ /***/ (o, a, c) => { c.r(a), c.d(a, { /* harmony export */ JSONLoader: () => ( /* binding */ M ) /* harmony export */ }); var l = c(4), d = c(20).Loader, h6 = l.LoaderUtils, f = l.AnimationClip, g = l.Vector3, p = l.Vector4, u = l.Color, y = l.Vector2, v = c(6).Face3, m = c(6).Geometry, x = l.FileLoader, w = l.DefaultLoadingManager, A = c(21).VideoHandler; function M(R) { typeof R == "boolean" && (console.warn("THREE.JSONLoader: showStatus parameter has been removed from constructor."), R = void 0), this.manager = R === void 0 ? w : R, this.withCredentials = false, this.paramsString = ""; } Object.assign(M.prototype, { load: function(L, S, I, T) { var _ = this, E = this.texturePath && typeof this.texturePath == "string" ? this.texturePath : h6.extractUrlBase(L), C = new x(this.manager); L.split("?"), this.paramsString = L.length === 2 ? paramsStrings[1] : "", C.setWithCredentials(this.withCredentials), C.load(L, function(P) { var b; try { b = JSON.parse(P); } catch { if (console.error("The loader has encountered an error while parsing the content of a resource."), T) return void T({ responseURL: L }); } var F = b.metadata; if (F !== void 0) { var D = F.type; if (D !== void 0 && D.toLowerCase() === "object") return void console.error("THREE.JSONLoader: " + L + " should be loaded with THREE.ObjectLoader instead."); } if (_ && _.parse) try { var N = _.parse(b, E); S(N.geometry, N.materials); } catch (B) { if (console.error("The loader has encountered aon loading the geometry"), console.error(B), T) return void T({ responseURL: L }); } }, I, T); }, setTexturePath: function(L) { this.texturePath = L; }, parse: /* @__PURE__ */ function() { function R(T, _) { function E(me, Me) { return me & 1 << Me; } var C, P, b, F, D, N, B, U, G, Y, te, ae, ie, le, W, $, j, re, V, H, K, ce, se, k, O, Z, X, ee = T.faces, fe = T.vertices, be = T.normals, Ae = T.colors, he = T.scale, xe = 0; if (T.uvs !== void 0) { for (C = 0; C < T.uvs.length; C++) T.uvs[C].length && xe++; for (C = 0; C < xe; C++) _.faceVertexUvs[C] = []; } for (F = 0, D = fe.length; F < D; ) re = new g(), re.x = fe[F++] * he, re.y = fe[F++] * he, re.z = fe[F++] * he, _.vertices.push(re); if (F = 0, D = ee.length, T.uvs) for (C = 0; C < T.uvs.length; C++) { _.uvs[C] = []; for (var ne = 0; ne < T.uvs[C].length; ne++) _.uvs[C][ne] = T.uvs[C][ne]; } if (be) for (C = 0; C < be.length; C++) _.normals[C] = be[C]; if (Ae) for (C = 0; C < Ae.length; C++) _.colors[C] = Ae[C]; for (; F < D; ) if (Y = ee[F++], te = E(Y, 0), ae = E(Y, 1), ie = E(Y, 3), le = E(Y, 4), W = E(Y, 5), $ = E(Y, 6), j = E(Y, 7), te) { if (H = new v(), H.a = ee[F], H.b = ee[F + 1], H.c = ee[F + 3], K = new v(), K.a = ee[F + 1], K.b = ee[F + 2], K.c = ee[F + 3], F += 4, ae && (G = ee[F++], H.materialIndex = G, K.materialIndex = G), b = _.faces.length, ie) for (C = 0; C < xe; C++) for (k = T.uvs[C], _.faceVertexUvs[C][b] = [], _.faceVertexUvs[C][b + 1] = [], P = 0; 4 > P; P++) U = ee[F++], Z = k[2 * U], X = k[2 * U + 1], O = new y(Z, X), P !== 2 && _.faceVertexUvs[C][b].push(O), P !== 0 && _.faceVertexUvs[C][b + 1].push(O); if (le && (B = 3 * ee[F++], H.normal.set(be[B++], be[B++], be[B]), K.normal.copy(H.normal)), W) for (C = 0; 4 > C; C++) B = 3 * ee[F++], se = new g(be[B++], be[B++], be[B]), C !== 2 && H.vertexNormals.push(se), C !== 0 && K.vertexNormals.push(se); if ($ && (N = ee[F++], ce = Ae[N], H.color.setHex(ce), K.color.setHex(ce)), j) for (C = 0; 4 > C; C++) N = ee[F++], ce = Ae[N], C !== 2 && H.vertexColors.push(new u(ce)), C !== 0 && K.vertexColors.push(new u(ce)); _.faces.push(H), _.faces.push(K); } else { if (V = new v(), V.a = ee[F++], V.b = ee[F++], V.c = ee[F++], ae && (G = ee[F++], V.materialIndex = G), b = _.faces.length, ie) for (C = 0; C < xe; C++) for (k = T.uvs[C], _.faceVertexUvs[C][b] = [], P = 0; 3 > P; P++) U = ee[F++], Z = k[2 * U], X = k[2 * U + 1], O = new y(Z, X), _.faceVertexUvs[C][b].push(O); if (le && (B = 3 * ee[F++], V.normal.set(be[B++], be[B++], be[B])), W) for (C = 0; 3 > C; C++) B = 3 * ee[F++], se = new g(be[B++], be[B++], be[B]), V.vertexNormals.push(se); if ($ && (N = ee[F++], V.color.setHex(Ae[N])), j) for (C = 0; 3 > C; C++) N = ee[F++], V.vertexColors.push(new u(Ae[N])); _.faces.push(V); } } function L(T, _) { var E = T.influencesPerVertex === void 0 ? 2 : T.influencesPerVertex; if (T.skinWeights) for (var C = 0, P = T.skinWeights.length; C < P; C += E) { var b = T.skinWeights[C], F = 1 < E ? T.skinWeights[C + 1] : 0, D = 2 < E ? T.skinWeights[C + 2] : 0, N = 3 < E ? T.skinWeights[C + 3] : 0; _.skinWeights.push(new p(b, F, D, N)); } if (T.skinIndices) for (var C = 0, P = T.skinIndices.length; C < P; C += E) { var B = T.skinIndices[C], U = 1 < E ? T.skinIndices[C + 1] : 0, G = 2 < E ? T.skinIndices[C + 2] : 0, Y = 3 < E ? T.skinIndices[C + 3] : 0; _.skinIndices.push(new p(B, U, G, Y)); } _.bones = T.bones, _.bones && 0 < _.bones.length && (_.skinWeights.length !== _.skinIndices.length || _.skinIndices.length !== _.vertices.length) && console.warn("When skinning, number of vertices (" + _.vertices.length + "), skinIndices (" + _.skinIndices.length + "), and skinWeights (" + _.skinWeights.length + ") should match."); } function S(T, _) { var E = T.scale; if (T.morphTargets !== void 0) for (var C = 0, P = T.morphTargets.length; C < P; C++) { _.morphTargets[C] = {}, _.morphTargets[C].name = T.morphTargets[C].name, _.morphTargets[C].vertices = []; for (var b, F = _.morphTargets[C].vertices, D = T.morphTargets[C].vertices, N = 0, B = D.length; N < B; N += 3) b = new g(), b.x = D[N] * E, b.y = D[N + 1] * E, b.z = D[N + 2] * E, F.push(b); } if (T.morphNormals !== void 0) { for (var C = 0, P = T.morphNormals.length; C < P; C++) if (_.morphTargets[C]) { _.morphTargets[C].normals = []; for (var U, G = _.morphTargets[C].normals, Y = T.morphNormals[C].normals, N = 0, B = Y.length; N < B; N += 3) U = new g(), U.x = Y[N], U.y = Y[N + 1], U.z = Y[N + 2], G.push(U); _.morphNormalsReady = true; } } if (T.morphColors !== void 0) { var C, P, te, ae, ie, le, W; for (C = 0, P = T.morphColors.length; C < P; C++) for (_.morphColors[C] = {}, _.morphColors[C].name = T.morphColors[C].name, _.morphColors[C].colors = [], ie = _.morphColors[C].colors, le = T.morphColors[C].colors, te = 0, ae = le.length; te < ae; te += 3) W = new l.Color(16755200), W.setRGB(le[te], le[te + 1], le[te + 2]), ie.push(W); } } function I(T, _) { var E = [], C = []; T.animation !== void 0 && C.push(T.animation), T.animations !== void 0 && (T.animations.length ? C = C.concat(T.animations) : C.push(T.animations)); for (var P, b = 0; b < C.length; b++) P = f.parseAnimation(C[b], _.bones), P && E.push(P); if (_.morphTargets) { var F = f.CreateClipsFromMorphTargetSequences(_.morphTargets, 10); E = E.concat(F); } 0 < E.length && (_.animations = E); } return function(T, _) { T.data !== void 0 && (T = T.data), T.scale = T.scale === void 0 ? 1 : 1 / T.scale; var E = new m(); if (E.morphColors = [], R(T, E), L(T, E), S(T, E), I(T, E), E.computeFaceNormals(), E.computeBoundingSphere(), T.materials === void 0 || T.materials.length === 0) return { geometry: E }; var C = d.prototype.initMaterials(T.materials, _, "Anonymous"); if (T.materials[0].video) { var P = _ + T.materials[0].video; this.paramsString && (P += "?".concat(this.paramsString)); var b = new A(P); E._video = b; } return C && 0 < C.length && (C[0].side = T.materials[0].singleSided ? l.FrontSide : T.materials[0].flipSided ? l.BackSide : l.DoubleSide, T.materials[0].specularCoef && (C[0].shininess = Math.floor(T.materials[0].specularCoef / 3))), { geometry: E, materials: C }; }; }() }); }, /* 20 */ /***/ (o, a, c) => { c.r(a), c.d(a, { /* harmony export */ Loader: () => ( /* binding */ d ) /* harmony export */ }); var l = c(4); c(4); function d() { } d.Handlers = { handlers: [], add: function(f, g) { this.handlers.push(f, g); }, get: function(f) { for (var g = this.handlers, p = 0, u = g.length; p < u; p += 2) { var y = g[p], v = g[p + 1]; if (y.test(f)) return v; } return null; } }, Object.assign(d.prototype, { crossOrigin: "anonymous", onLoadStart: function() { }, onLoadProgress: function() { }, onLoadComplete: function() { }, initMaterials: function(f, g, p) { for (var u = [], y = 0; y < f.length; ++y) u[y] = this.createMaterial(f[y], g, p); return u; }, createMaterial: function() { var h6 = { NoBlending: l.NoBlending, NormalBlending: l.NormalBlending, AdditiveBlending: l.AdditiveBlending, SubtractiveBlending: l.SubtractiveBlending, MultiplyBlending: l.MultiplyBlending, CustomBlending: l.CustomBlending }, f = new l.Color(), g = new l.TextureLoader(), p = new l.MaterialLoader(); return function(u, y, v) { function m(R, L, S, I, T) { var _, E = y + R, C = d.Handlers.get(E); C === null ? (g.setCrossOrigin(v), _ = g.load(E)) : _ = C.load(E), L !== void 0 && (_.repeat.fromArray(L), L[0] !== 1 && (_.wrapS = l.RepeatWrapping), L[1] !== 1 && (_.wrapT = l.RepeatWrapping)), S !== void 0 && _.offset.fromArray(S), I !== void 0 && (I[0] === "repeat" && (_.wrapS = l.RepeatWrapping), I[0] === "mirror" && (_.wrapS = l.MirroredRepeatWrapping), I[1] === "repeat" && (_.wrapT = l.RepeatWrapping), I[1] === "mirror" && (_.wrapT = l.MirroredRepeatWrapping)), T !== void 0 && (_.anisotropy = T); var P = l.MathUtils.generateUUID(); return x[P] = _, P; } var x = {}, w = { uuid: l.MathUtils.generateUUID(), type: "MeshLambertMaterial" }; for (var A in u) { var M = u[A]; switch (A) { case "DbgColor": case "DbgIndex": case "opticalDensity": case "illumination": break; case "DbgName": w.name = M; break; case "blending": w.blending = h6[M]; break; case "colorAmbient": case "mapAmbient": console.warn("THREE.Loader.createMaterial:", A, "is no longer supported."); break; case "colorDiffuse": w.color = f.fromArray(M).getHex(); break; case "colorSpecular": w.specular = f.fromArray(M).getHex(); break; case "colorEmissive": w.emissive = f.fromArray(M).getHex(); break; case "specularCoef": w.shininess = M; break; case "shading": M.toLowerCase() === "basic" && (w.type = "MeshBasicMaterial"), M.toLowerCase() === "phong" && (w.type = "MeshPhongMaterial"), M.toLowerCase() === "standard" && (w.type = "MeshStandardMaterial"); break; case "mapDiffuse": w.map = m(M, u.mapDiffuseRepeat, u.mapDiffuseOffset, u.mapDiffuseWrap, u.mapDiffuseAnisotropy); break; case "mapDiffuseRepeat": case "mapDiffuseOffset": case "mapDiffuseWrap": case "mapDiffuseAnisotropy": break; case "mapEmissive": w.emissiveMap = m(M, u.mapEmissiveRepeat, u.mapEmissiveOffset, u.mapEmissiveWrap, u.mapEmissiveAnisotropy); break; case "mapEmissiveRepeat": case "mapEmissiveOffset": case "mapEmissiveWrap": case "mapEmissiveAnisotropy": break; case "mapLight": w.lightMap = m(M, u.mapLightRepeat, u.mapLightOffset, u.mapLightWrap, u.mapLightAnisotropy); break; case "mapLightRepeat": case "mapLightOffset": case "mapLightWrap": case "mapLightAnisotropy": break; case "mapAO": w.aoMap = m(M, u.mapAORepeat, u.mapAOOffset, u.mapAOWrap, u.mapAOAnisotropy); break; case "mapAORepeat": case "mapAOOffset": case "mapAOWrap": case "mapAOAnisotropy": break; case "mapBump": w.bumpMap = m(M, u.mapBumpRepeat, u.mapBumpOffset, u.mapBumpWrap, u.mapBumpAnisotropy); break; case "mapBumpScale": w.bumpScale = M; break; case "mapBumpRepeat": case "mapBumpOffset": case "mapBumpWrap": case "mapBumpAnisotropy": break; case "mapNormal": w.normalMap = m(M, u.mapNormalRepeat, u.mapNormalOffset, u.mapNormalWrap, u.mapNormalAnisotropy); break; case "mapNormalFactor": w.normalScale = M; break; case "mapNormalRepeat": case "mapNormalOffset": case "mapNormalWrap": case "mapNormalAnisotropy": break; case "mapSpecular": w.specularMap = m(M, u.mapSpecularRepeat, u.mapSpecularOffset, u.mapSpecularWrap, u.mapSpecularAnisotropy); break; case "mapSpecularRepeat": case "mapSpecularOffset": case "mapSpecularWrap": case "mapSpecularAnisotropy": break; case "mapMetalness": w.metalnessMap = m(M, u.mapMetalnessRepeat, u.mapMetalnessOffset, u.mapMetalnessWrap, u.mapMetalnessAnisotropy); break; case "mapMetalnessRepeat": case "mapMetalnessOffset": case "mapMetalnessWrap": case "mapMetalnessAnisotropy": break; case "mapRoughness": w.roughnessMap = m(M, u.mapRoughnessRepeat, u.mapRoughnessOffset, u.mapRoughnessWrap, u.mapRoughnessAnisotropy); break; case "mapRoughnessRepeat": case "mapRoughnessOffset": case "mapRoughnessWrap": case "mapRoughnessAnisotropy": break; case "mapAlpha": w.alphaMap = m(M, u.mapAlphaRepeat, u.mapAlphaOffset, u.mapAlphaWrap, u.mapAlphaAnisotropy); break; case "mapAlphaRepeat": case "mapAlphaOffset": case "mapAlphaWrap": case "mapAlphaAnisotropy": break; case "flipSided": w.side = l.BackSide; break; case "doubleSided": w.side = l.DoubleSide; break; case "transparency": console.warn("THREE.Loader.createMaterial: transparency has been renamed to opacity"), w.opacity = M; break; case "depthTest": case "depthWrite": case "colorWrite": case "opacity": case "reflectivity": case "transparent": case "visible": case "wireframe": w[A] = M; break; case "vertexColors": M === true && (w.vertexColors = l.VertexColors), M === "face" && (w.vertexColors = l.FaceColors); break; default: console.error("THREE.Loader.createMaterial: Unsupported", A, M); } } return w.type === "MeshBasicMaterial" && delete w.emissive, w.type !== "MeshPhongMaterial" && delete w.specular, 1 > w.opacity && (w.transparent = true), p.setTextures(x), p.parse(w); }; }() }); }, /* 21 */ /***/ (o, a, c) => { var l = c(4); a.VideoHandler = function(d) { var h6 = this; this.video = void 0, this.videoTexture = void 0, this.setMorphTime = function(f, g) { var p = f / g * h6.video.duration; h6.video.currentTime = p; }, this.getVideoDuration = function() { return h6.video.duration; }, this.createCanvasVideoTexture = function() { return h6.videoTexture = new l.VideoTexture(h6.video), h6.videoTexture.minFilter = l.LinearFilter, h6.videoTexture.magFilter = l.LinearFilter, h6.videoTexture.format = l.RGBFormat, h6.video.currentTime = 0, h6.videoTexture; }, this.getCurrentTime = function(f) { return h6.video ? f * (h6.video.currentTime / h6.video.duration) : 0; }, this.isReadyToPlay = function() { return !!(h6.video && 3 <= h6.video.readyState); }, function() { document && (h6.video = document.createElement("video"), h6.video.crossOrigin = "anonymous", h6.video.src = d, h6.video.load(), h6.video.loop = true); }(); }; }, /* 22 */ /***/ (o, a, c) => { var l = c(4), d = c(23).Points, h6 = c(5).toBufferGeometry, f = c(5).getCircularTexture, g = c(17).Label, p = function() { c(10).ZincObject.call(this), this.isPointset = true; var u = []; this.createMesh = (v, m, x) => { if (v && m) { var w = h6(v, x), A = f(); m.map = A; var M = new d(w, m); this.setMesh(M, x.localTimeEnabled, x.localMorphColour); } }; var y = (v, m, x, w) => { if (x) { var A = new l.Color(w), M = new g(x, A); M.setPosition(m[0], m[1], m[2]); var R = M.getSprite(); R.material.sizeAttenuation = false, R.material.alphaTest = 0.5, R.material.transparent = true, R.material.depthWrite = false, R.material.depthTest = false, this.group.add(R), u[v] = M; } }; this.addPoints = (v, m, x) => { if (v && 0 < v.length) { var w = this.drawRange - 1, A = this.addVertices(v), M = this.getMorph(); if (!M) { var R = new l.PointsMaterial({ alphaTest: 0.5, size: 10, color: x, sizeAttenuation: false }); A.colorsNeedUpdate = true, this.createMesh(A, R, { localTimeEnabled: false, localMorphColour: false }); } var L = w + v.length, S = 0; if (Array.isArray(m) && m.length === v.length || typeof m == "string") for (w; w + S < L; ) { var I = typeof m == "string" ? m : m[S]; y(S, v[S], I, x), S++; } this.region && (this.region.pickableUpdateRequired = true); } }, this.setSize = (v) => { this.morph && this.morph.material && (this.morph.material.size = v, this.morph.material.needsUpdate = true); }, this.setSizeAttenuation = (v) => { this.morph && this.morph.material && (this.morph.material.sizeAttenuation = v, this.morph.material.needsUpdate = true); }, this.getVerticesByIndex = function(v) { if (0 <= v && this.drawRange > v) { var m = this.getMorph().geometry.getAttribute("position"); return [m.getX(v), m.getY(v), m.getZ(v)]; } }, this.editVertices = function(v, m) { if (v && v.length) { var x = this.getMorph(), w = m + v.length - 1; if (!x || 0 > m || w >= this.drawRange) return; var A = x.geometry.getAttribute("position"), M = m; v.forEach((R) => { var L = u[M]; L && L.setPosition(R[0], R[1], R[2]), A.setXYZ(M++, R[0], R[1], R[2]); }), A.needsUpdate = true, this.boundingBoxUpdateRequired = true; } }, this.render = (v, m, x, w) => { this.morph && x && (this.morph.sizePerPixel = x.pixelHeight), p.prototype.render.call(this, v, m, x, w); }; }; p.prototype = Object.create(c(10).ZincObject.prototype), a.Pointset = p; }, /* 23 */ /***/ (o, a, c) => { c.r(a), c.d(a, { /* harmony export */ Points: () => ( /* binding */ y ) /* harmony export */ }); var l = c(4), d = new l.Matrix4(), h6 = new l.Ray(), f = new l.Sphere(), g = new l.Vector3(), p = new l.Vector3(), u = new l.Vector3(); class y extends l.Object3D { constructor() { var w = 0 < arguments.length && arguments[0] !== void 0 ? arguments[0] : new l.BufferGeometry(), A = 1 < arguments.length && arguments[1] !== void 0 ? arguments[1] : new l.PointsMaterial(); super(), this.type = "Points", this.geometry = w, this.material = A, this.sizePerPixel = 1, this.updateMorphTargets(); } copy(w) { return super.copy(w), this.material = w.material, this.geometry = w.geometry, this; } raycast(w, A) { var M = this.geometry, R = this.matrixWorld, L = w.params.Points.threshold, S = M.drawRange; if (M.boundingSphere === null && M.computeBoundingSphere(), f.copy(M.boundingSphere), f.applyMatrix4(R), f.radius += L, w.ray.intersectsSphere(f) !== false) { d.copy(R).invert(), h6.copy(w.ray).applyMatrix4(d); var I = L / ((this.scale.x + this.scale.y + this.scale.z) / 3) * this.material.size * this.sizePerPixel, T = I * I; if (M.isBufferGeometry) { var _ = M.index, E = M.attributes, C = E.position, P = M.morphAttributes.position; if (_ !== null) for (var b, F = Math.max(0, S.start), D = Math.min(_.count, S.start + S.count), N = F; N < D; N++) b = _.getX(N), m(this, C, P, b), v(g, b, T, R, w, A, this); else for (var B = Math.max(0, S.start), U = Math.min(C.count, S.start + S.count), G = B; G < U; G++) m(this, C, P, G), v(g, G, T, R, w, A, this); } else console.error("THREE.Points.raycast() no longer supports THREE.Geometry. Use THREE.BufferGeometry instead."); } } updateMorphTargets() { var w = this.geometry; if (w.isBufferGeometry) { var A = w.morphAttributes, M = Object.keys(A); if (0 < M.length) { var R = A[M[0]]; if (R !== void 0) { this.morphTargetInfluences = [], this.morphTargetDictionary = {}; for (var L, S = 0, I = R.length; S < I; S++) L = R[S].name || S + "", this.morphTargetInfluences.push(0), this.morphTargetDictionary[L] = S; } } } else { var T = w.morphTargets; T !== void 0 && 0 < T.length && console.error("THREE.Points.updateMorphTargets() does not support THREE.Geometry. Use THREE.BufferGeometry instead."); } } } y.prototype.isPoints = true; function v(x, w, A, M, R, L, S) { var I = h6.distanceSqToPoint(x); if (I < A) { var T = new l.Vector3(); h6.closestPointToPoint(x, T), T.applyMatrix4(M); var _ = R.ray.origin.distanceTo(T); if (_ < R.near || _ > R.far) return; L.push({ distance: _, distanceToRay: Math.sqrt(I), point: T, index: w, face: null, object: S }); } } function m(x, w, A, M) { g.fromBufferAttribute(w, M); var R = x.morphTargetInfluences; if (x.material.morphTargets && A && R) { p.set(0, 0, 0); for (var L = 0, S = A.length; L < S; L++) { var I = R[L], T = A[L]; I !== 0 && (u.fromBufferAttribute(T, M), p.addScaledVector(u.sub(g), I)); } g.add(p); } } }, /* 24 */ /***/ (o, a, c) => { var l = c(4), d = c(5).toBufferGeometry, h6 = function() { c(10).ZincObject.call(this), this.isLines = true, this.createLineSegment = (f, g, p) => { if (f && g) { var u = d(f, p); p.localMorphColour && u.morphAttributes.color && (g.onBeforeCompile = c(9).augmentMorphColor()); var y = new (c(12)).LineSegments(u, g); this.setMesh(y, p.localTimeEnabled, p.localMorphColour); } }, this.setWidth = (f) => { this.morph && this.morph.material && (this.morph.material.linewidth = f, this.morph.material.needsUpdate = true); }, this.addLines = (f, g) => { if (f && 0 < f.length) { var p = this.addVertices(f), u = this.getMorph(); if (!u) { var y = new l.LineBasicMaterial({ color: g }); p.colorsNeedUpdate = true, this.createLineSegment(p, y, { localTimeEnabled: false, localMorphColour: false }); } this.region && (this.region.pickableUpdateRequired = true); } }; }; h6.prototype = Object.create(c(10).ZincObject.prototype), a.Lines = h6; }, /* 25 */ /***/ (o, a, c) => { function l(g, p, u, y, v, m, x) { try { var w = g[m](x), A = w.value; } catch (M) { return void u(M); } w.done ? p(A) : Promise.resolve(A).then(y, v); } function d(g) { return function() { var p = this, u = arguments; return new Promise(function(y, v) { function m(A) { l(w, y, v, m, x, "next", A); } function x(A) { l(w, y, v, m, x, "throw", A); } var w = g.apply(p, u); m(void 0); }); }; } var h6 = c(4), f = function() { var g = this; c(26).Texture.call(this), this.isTextureArray = true, this.loadFromImages = function() { var p = d(function* (u) { var y = 1, v = 1, m = 0; if (u && u.length) { g.isLoading = true; var x = new Image(); x.crossOrigin = "Anonymous"; for (var w, A = document.createElement("canvas"), M = 0, R = Array(u.length), L = 0; L < u.length; L++) w = yield g.imageToUint8Array(g, x, u[L], A), w && w.array && (y = w.width, v = w.height, R[m] = w.array, M += R[m].length, m++); var S = new Uint8Array(M); M = 0, R.forEach((I) => { S.set(I, M), M += I.length; }), g.impl = new h6.DataTexture2DArray(S, y, v, m), g.size = { width: y, height: v, depth: m }, g.isLoading = false, g.impl.needsUpdate = true; } }); return function() { return p.apply(this, arguments); }; }(), this.getMaterial = (p) => { if (this.impl) { var u; if (!p) u = new h6.MeshBasicMaterial({ color: new h6.Color(1, 1, 1), transparent: false, opacity: 1, map: this.impl, side: h6.DoubleSide }); else if (p.vs && p.fs) { var y = true; "transparent" in p && (y = p.transparent); var v = h6.FrontSide; p.side && (v = p.side), u = new h6.ShaderMaterial({ transparent: y, uniforms: p.uniforms, vertexShader: p.vs, fragmentShader: p.fs, side: v }), p.glslVersion && (u.glslVersion = p.glslVersion); } if (u) return u.needsUpdate = true, u; } }; }; f.prototype = Object.create(c(26).Texture.prototype), a.TextureArray = f; }, /* 26 */ /***/ (o, a, c) => { function l(g, p, u, y, v, m, x) { try { var w = g[m](x), A = w.value; } catch (M) { return void u(M); } w.done ? p(A) : Promise.resolve(A).then(y, v); } function d(g) { return function() { var p = this, u = arguments; return new Promise(function(y, v) { function m(A) { l(w, y, v, m, x, "next", A); } function x(A) { l(w, y, v, m, x, "throw", A); } var w = g.apply(p, u); m(void 0); }); }; } var h6 = c(4), f = function() { this.isTexture = true, this.impl = void 0, this.isLoading = false, this.size = { width: 1, height: 1, depth: 0 }; }; f.prototype.loadImage = function(g, p) { return new Promise((u, y) => { g.onload = () => u(g), g.onerror = y, g.src = p; }); }, f.prototype.imageToUint8Array = function() { var g = d(function* (p, u, y, v) { yield p.loadImage(u, y), v.width = u.width, v.height = u.height; var m = v.getContext("2d"); return m.drawImage(u, 0, 0), { array: new Uint8Array(m.getImageData(0, 0, v.width, v.height).data.buffer), width: v.width, height: v.height }; }); return function() { return g.apply(this, arguments); }; }(), f.prototype.loadFromImages = function() { var g = d(function* () { }); return function() { return g.apply(this, arguments); }; }(), f.prototype.isReady = function() { return !(!this.impl || this.isLoading); }, f.prototype.getMaterial = function() { if (this.impl) return new h6.MeshBasicMaterial({ color: new h6.Color(1, 1, 1), transparent: false, opacity: 1, map: this.impl, side: h6.DoubleSide }); }, a.Texture = f; }, /* 27 */ /***/ (o, a, c) => { function l(v, m) { var x = Object.keys(v); if (Object.getOwnPropertySymbols) { var w = Object.getOwnPropertySymbols(v); m && (w = w.filter(function(A) { return Object.getOwnPropertyDescriptor(v, A).enumerable; })), x.push.apply(x, w); } return x; } function d(v) { for (var m, x = 1; x < arguments.length; x++) m = arguments[x] == null ? {} : arguments[x], x % 2 ? l(Object(m), true).forEach(function(w) { h6(v, w, m[w]); }) : Object.getOwnPropertyDescriptors ? Object.defineProperties(v, Object.getOwnPropertyDescriptors(m)) : l(Object(m)).forEach(function(w) { Object.defineProperty(v, w, Object.getOwnPropertyDescriptor(m, w)); }); return v; } function h6(v, m, x) { return (m = f(m)) in v ? Object.defineProperty(v, m, { value: x, enumerable: true, configurable: true, writable: true }) : v[m] = x, v; } function f(v) { var m = g(v, "string"); return typeof m == "symbol" ? m : m + ""; } function g(v, m) { if (typeof v != "object" || !v) return v; var x = v[Symbol.toPrimitive]; if (x !== void 0) { var w = x.call(v, m || "default"); if (typeof w != "object") return w; throw new TypeError("@@toPrimitive must return a primitive value."); } return (m === "string" ? String : Number)(v); } var p = c(4), u = c(28), y = function(v) { c(29).TexturePrimitive.call(this, v), this.isTextureSlides = true; var m = [], x = {}; this.morph = new p.Group(), this.group = this.morph, this.morph.userData = this; var w = void 0, A = true; this.createSlides = (L) => { L.forEach((S) => this.createSlide(S)); }; var M = (L, S) => { var I = L.material, T = I.uniforms; switch (L.rotation.x = 0, L.rotation.y = 0, L.rotation.z = 0, L.position.x = 0, L.position.y = 0, L.position.z = 0, S.direction) { case "x": var _ = -Math.PI / 2; L.rotation.y = _, T.direction.value = 1, T.slide.value.set(S.value, 0, 0), L.position.x = S.value; break; case "y": L.rotation.x = Math.PI / 2, T.direction.value = 2, T.slide.value.set(0, S.value, 0), L.position.y = S.value; break; case "z": T.direction.value = 3, T.slide.value.set(0, 0, S.value), L.position.z = S.value; break; } I.needsUpdate = true, this.boundingBoxUpdateRequired = true; }; this.modifySlideSettings = (L) => { L && L.id && L.id in x && x[L.id] && M(x[L.id], L); }, this.createSlide = (L) => { if (this.texture && this.texture.isTextureArray && this.texture.isReady() && L && L.direction && L.value !== void 0) { var S = new p.PlaneGeometry(1, 1); S.translate(0.5, 0.5, 0); var I = u.getUniforms(); I.diffuse.value = this.texture.impl, I.depth.value = this.texture.size.depth, I.flipY.value = A; var T = { fs: u.fs, vs: u.vs, uniforms: I, glslVersion: u.glslVersion, side: p.DoubleSide, transparent: false }, _ = this.texture.getMaterial(T); _.needsUpdate = true; var E = new p.Mesh(S, _); E.name = this.groupName, E.userData = this; var C = { value: L.value, direction: L.direction, id: E.id }; return m.push(C), M(E, C), x[E.id] = E, this.morph.add(E), this.boundingBoxUpdateRequired = true, C; } }, this.getTextureSettings = () => [...m], this.getTextureSettingsWithId = (L) => { for (var S = 0; S < m.length; S++) if (L === m[S].id) return d({}, m[S]); }, this.getSlides = () => this.morph ? [...this.morph.children] : [], this.removeSlide = (L) => { L && this.removeSlideWithId(L.id); }, this.removeSlideWithId = (L) => { if (this.morph && L in x && x[L]) { if (this.morph.getObjectById(L)) { var S = x[L]; this.morph.remove(S), S.clear(), S.geometry && S.geometry.dispose(), S.material && S.material.dispose(), this.boundingBoxUpdateRequired = true; } var I = m.findIndex((T) => T.id === L); -1 < I && m.splice(I, 1); } }, this.dispose = () => { this.morph.children.forEach((L) => { L.geometry && L.geometry.dispose(), L.material && L.material.dispose(); }), c(29).TexturePrimitive.prototype.dispose.call(this), this.boundingBoxUpdateRequired = true; }; var R = (L, S, I) => { if (S) switch (S.direction.value) { case 1: I.copy(S.slide.value), L.expandByPoint(I), I.setY(1), I.setZ(1), L.expandByPoint(I); break; case 2: I.copy(S.slide.value), L.expandByPoint(I), I.setX(1), I.setZ(1), L.expandByPoint(I); break; case 3: I.copy(S.slide.value), L.expandByPoint(I), I.setX(1), I.setY(1), L.expandByPoint(I); break; } }; this.getBoundingBox = () => { if (this.morph && this.morph.children && this.morph.visible && this.boundingBoxUpdateRequired) { this.cachedBoundingBox.makeEmpty(); var L = new p.Vector3(0, 0, 0); this.morph.children.forEach((S) => { R(this.cachedBoundingBox, S.material.uniforms, L); }), this.morph.updateMatrixWorld(true, true), this.cachedBoundingBox.applyMatrix4(this.morph.matrixWorld), this.boundingBoxUpdateRequired = false; } return this.cachedBoundingBox; }, this.applyTransformation = (L, S, I) => { var T = new p.Matrix4(); T.set(L[0], L[1], L[2], 0, L[3], L[4], L[5], 0, L[6], L[7], L[8], 0, 0, 0, 0, 0); var _ = new p.Quaternion().setFromRotationMatrix(T); this.morph.position.set(...S), this.morph.quaternion.copy(_), this.morph.scale.set(...I), this.morph.updateMatrix(), this.boundingBoxUpdateRequired = true; }, this.setRenderOrder = (L) => { this.morph.renderOrder = L; }, this.initialise = (L, S) => { if (L) { var I = L.locations; I && 0 < I.length && (this.applyTransformation(I[0].orientation, I[0].position, I[0].scale), "flipY" in I[0] && (A = I[0].flipY)), this.createSlides(L.settings.slides), S != null && typeof S == "function" && S(this); } }, this.showEdges = (L) => { if (w) w.material.color = L; else { var S = new p.BoxGeometry(1, 1, 1); S.translate(0.5, 0.5, 0.5); var I = new p.EdgesGeometry(S); w = new p.LineSegments(I, new p.LineBasicMaterial({ color: L })), this.group.add(w); } w.visible = true; }, this.hideEdges = () => { w && (w.visible = false); }; }; y.prototype = Object.create(c(29).TexturePrimitive.prototype), y.prototype.constructor = y, a.TextureSlides = y; }, /* 28 */ /***/ (o, a, c) => { var l = c(4), d = l.GLSL3, h6 = ` precision highp float; precision highp int; precision highp sampler2DArray; uniform sampler2DArray diffuse; uniform bool discardAlpha; in vec3 vUw; out vec4 outColor; void main() { vec4 color = texture( diffuse, vUw ); // lighten a bit if (discardAlpha && color.a == 0.0) discard; outColor = vec4( color.rgba ); } `, f = ` out vec3 vUw; uniform float depth; uniform vec3 slide; uniform int direction; uniform bool flipY; void main() { vec3 slidePos = position.xyz; gl_Position = projectionMatrix * modelViewMatrix * vec4( position.xyz, 1.0 ); if (direction == 1) slidePos = vec3(slide.x, position.y, position.x); if (direction == 2) slidePos = vec3(position.x, slide.y, position.y); if (direction == 3) slidePos = vec3(position.x, position.y, slide.z); if (flipY) slidePos.y = 1.0 - slidePos.y; vUw.xyz = vec3(slidePos.x, slidePos.y, slidePos.z * depth); } `, g = function() { return { diffuse: { value: void 0 }, depth: { value: 1 }, slide: { value: new l.Vector3(0, 0, 1) }, direction: { value: 1 }, flipY: { value: true }, discardAlpha: { value: true } }; }; a.fs = h6, a.vs = f, a.glslVersion = d, a.getUniforms = g; }, /* 29 */ /***/ (o, a, c) => { c(4); var l = c(5).resolveURL, d = function(h6) { c(10).ZincObject.call(this), this.isTexturePrimitive = true, this.texture = h6, this.load = (f, g) => { if (f && f.images && f.images.source) { var p = new (c(25)).TextureArray(), u = []; f.images.source.forEach((v) => { u.push(l(v)); }); var y = this; p.loadFromImages(u).then(() => { y.texture = p, y.initialise(f, g); }); } }, this.initialise = (f, g) => { g != null && typeof g == "function" && g(this); }; }; d.prototype = Object.create(c(10).ZincObject.prototype), d.prototype.constructor = d, a.TexturePrimitive = d; }, /* 30 */ /***/ (o, a, c) => { var l = c(4), d = c(31); a.Renderer = function(h6) { var f = h6, g = void 0, p = void 0, u = new l.Clock(false); this.playAnimation = true; var y = 1e3, v = [], m = 0, x = [], w = 0, A = void 0, M = void 0, R = void 0, L = void 0, S = [], I = [], T = new l.Group(), _ = void 0, E = void 0, C = false; this.getDrawingWidth = () => f ? f.clientWidth : _ ? typeof _.clientWidth > "u" ? Math.round(_.width) : Math.round(_.clientWidth) : 0, this.getDrawingHeight = () => f ? f.clientHeight : _ ? typeof _.clientHeight > "u" ? Math.round(_.height) : Math.round(_.clientHeight) : 0, this.onWindowResize = () => { p.onWindowResize(); var F = this.getDrawingWidth(), D = this.getDrawingHeight(); if (g != null) { var N; f ? (N = f.getBoundingClientRect(), g.setSize(F, D)) : _ && (typeof _.getBoundingClientRect > "u" || (N = _.getBoundingClientRect(), _.width = F, _.height = D), g.setSize(F, D, false)), N && (N.left, N.top); var B = new l.Vector2(); g.getSize(B), B.x, B.y; } }, this.initialiseVisualisation = (F) => { if (F = F || {}, F.antialias === void 0) { var D = false; try { /Android|webOS|iPhone|iPad|iPod|BlackBerry|IEMobile|Opera Mini/i.test(navigator.userAgent) && (D = true); } catch { D = false; } F.antialias = !D; } F.canvas && (f = void 0, _ = F.canvas), g = new l.WebGLRenderer(F), f !== void 0 && f.appendChild(g.domElement), g.setClearColor(16777215, 1), _ && _.style && (_.style.height = "100%", _.style.width = "100%"), g.autoClear = false; var N = this.createScene("default"); this.setCurrentScene(N); }, this.getCurrentScene = () => p, this.setCurrentScene = (F) => { if (F) { this.removeActiveScene(F); var D = p; p = F, D && D.setInteractiveControlEnable(false), p.setInteractiveControlEnable(true), p.setAdditionalScenesGroup(T), this.onWindowResize(); } }, this.getSceneByName = (F) => S[F], this.createScene = (F) => { if (S[F] == null) { var D; return D = _ ? new (c(32)).Scene(_, g) : new (c(32)).Scene(f, g), S[F] = D, D.sceneName = F, D; } }, this.resetView = () => { p.resetView(); }, this.viewAll = () => { if (p) { var F = p.getBoundingBox(); if (F) { for (var D, N = 0; N < I.length; N++) D = I[N].getBoundingBox(), D && F.union(D); p.viewAllWithBoundingBox(F); } } }, this.loadModelsURL = (F, D, N, B, U, G) => { p.loadModelsURL(F, D, N, B, U, G); }, this.loadViewURL = (F) => { p.loadViewURL(F); }, this.loadFromViewURL = (F, D) => { p.loadFromViewURL(F, D); }, this.updateDirectionalLight = () => { p.updateDirectionalLight(); }; var P = () => { C ? (A = requestAnimationFrame(P), this.render()) : (cancelAnimationFrame(A), A = void 0); }; this.stopAnimate = () => { C && (u.stop(), C = false); }, this.animate = () => { C || (u.start(), C = true, P()); }, this.addPreRenderCallbackFunction = (F) => (++m, v[m] = F, m), this.removePreRenderCallbackFunction = (F) => { F in v && delete v[F]; }, this.addPostRenderCallbackFunction = (F) => (++w, x[w] = F, w), this.removePostRenderCallbackFunction = (F) => { F in x && delete x[F]; }, this.getPlayRate = () => y, this.setPlayRate = (F) => { y = F; }, this.getCurrentTime = () => p.getCurrentTime(), this.setMorphsTime = (F) => { p.setMorphsTime(F); }, this.getZincGeometryByID = (F) => p.getZincGeometryByID(F), this.addToScene = (F) => { p.addObject(F); }, this.addToOrthoScene = (F) => { if (R == null && (R = new l.Scene()), M == null) { var D = this.getDrawingWidth(), N = this.getDrawingHeight(); M = new l.OrthographicCamera(-D / 2, D / 2, N / 2, -N / 2, 1, 10), M.position.z = 10; } R.add(F); }; var b = (F) => (D) => { D.needsUpdate = true; var N = new l.SpriteMaterial({ map: D }), B = N.map.image.width, U = N.map.image.height; F.material = N, F.scale.set(B, U, 1); var G = this.getDrawingWidth(), Y = this.getDrawingHeight(); F.position.set((G - B) / 2, (-Y + U) / 2, 1), this.addToOrthoScene(F); }; this.addLogo = () => { L = new l.Sprite(), l.ImageUtils.loadTexture("images/abi_big_logo_transparent_small.png", void 0, b(L)); }, this.render = () => { E || (f ? 0 < f.clientWidth && 0 < f.clientHeight && (E = new d(f, this.onWindowResize)) : _ && 0 < _.width && 0 < _.height && (E = new d(_, this.onWindowResize))); var F = u.getDelta(); p.renderGeometries(y, F, this.playAnimation); for (var D, N = 0; N < I.length; N++) D = I[N], D.renderGeometries(y, F, this.playAnimation); for (var B in M != null && R != null && (g.clearDepth(), g.render(R, M)), v) v.hasOwnProperty(B) && v[B].call(); for (var U in p.render(g), x) x.hasOwnProperty(U) && x[U].call(); }, this.getThreeJSRenderer = () => g, this.isSceneActive = (F) => { if (p === F) return true; for (var D, N = 0; N < I.length; N++) if (D = I[N], D === F) return true; return false; }, this.addActiveScene = (F) => { this.isSceneActive(F) || (I.push(F), T.add(F.getThreeJSScene())); }, this.removeActiveScene = (F) => { for (var D, N = 0; N < I.length; N++) if (D = I[N], D === F) return I.splice(N, 1), void T.remove(F.getThreeJSScene()); }, this.clearAllActiveScene = () => { for (var F = 0; F < I.length; F++) T.remove(I[F].getThreeJSScene()); I.splice(0, I.length); }, this.dispose = () => { for (var F in C && cancelAnimationFrame(A), S) S.hasOwnProperty(F) && S[F].clearAll(); S = [], I = [], T = new l.Group(), this.stopAnimate(), v = [], m = 0, M = void 0, R = void 0, L = void 0; var D = this.createScene("default"); this.setCurrentScene(D), E = void 0; }, this.transitionScene = (F, D) => { if (p) { var N = p.getZincCameraControls(), B = F.getBoundingBox(); if (B) { var U = B.min.distanceTo(B.max) / 2, G = (B.min.x + B.max.x) / 2, Y = (B.min.y + B.max.y) / 2, te = (B.min.z + B.max.z) / 2, ae = N.getViewportFromCentreAndRadius(G, Y, te, U, 40, U * 4), ie = N.getCurrentViewport(); N.cameraTransition(ie, ae, D), N.enableCameraTransition(); } } }, this.isWebGL2 = () => !!g && g.capabilities.isWebGL2; }; }, /* 31 */ /***/ (o) => { o.exports = KB(); }, /* 32 */ /***/ (o, a, c) => { var l = c(4), d = c(33).MarkerCluster, h6 = c(35).SceneLoader, f = c(42).SceneExporter, g = c(44).Viewport, p = c(5).createBufferGeometry, u = c(5).getCircularTexture, y = c(5).createNewSpriteText, v = 0, m = function() { return "sc" + v++; }, x = function() { return { Duration: "6 secs", OriginalDuration: "-", TimeStamps: {} }; }, w = 6e3; a.Scene = function(A, M) { var R = this, L = A, S = void 0, I = new h6(this), T = void 0, _ = {}, E = 0, C = {}, P = 0, b = new l.Scene(), F = new l.Scene(), D = new (c(45)).Region(void 0, this); b.add(D.getGroup()); var N = new l.Group(); b.add(N), this.directionalLight = void 0, this.ambient = void 0, this.camera = void 0; var B = 6e3, U = void 0; this.sceneName = void 0; var G = false, Y = void 0; this.autoClearFlag = true, this.displayMarkers = false, this.displayMinimap = false, this.displayMiniAxes = false, this.minimapScissor = { x_offset: 16, y_offset: 16, width: 128, height: 128, align: "top-right", updateRequired: true }; var te = { x: 0, y: 0 }, ae = x(), ie = new l.Vector2(), le = []; this.forcePickableObjectsUpdate = false, this.uuid = m(); var W = new d(this); W.disable(), b.add(W.group); var $ = { main: [], mini: [] }, j = new l.Vector3(0, 0, 0), re = () => L ? typeof L.clientWidth > "u" ? L.width : L.clientWidth : 0, V = () => L ? typeof L.clientHeight > "u" ? L.height : L.clientHeight : 0; this.getDownloadProgress = () => I.getDownloadProgress(), this.onWindowResize = () => { var O = V(); this.camera.aspect = re() / O, this.camera.updateProjectionMatrix(), this.minimapScissor.updateRequired = true, U.onResize(), U.calculateHeightPerPixelAtZeroDepth(O); }, this.resetView = () => { this.onWindowResize(), U.resetView(); }, this.changeZoomByScrollRateUnit = (O) => { U.changeZoomByScrollRateUnit(O); }; var H = () => { this.camera = new l.PerspectiveCamera(40, re() / V(), 0, 10), this.ambient = new l.AmbientLight(16777215, 0.2), b.add(this.ambient), this.directionalLight = new l.DirectionalLight(16777215, 0.8), b.add(this.directionalLight), U = new (c(44)).CameraControls(this.camera, M.domElement, M, this), U.setDirectionalLight(this.directionalLight), U.resetView(), T = new (c(50)).Minimap(this); }; H(), this.loadView = (O) => { var Z = new g(); return Z.setFromObject(O), U.setCurrentCameraSettings(Z), true; }, this.setupMultipleViews = (O, Z) => { for (var [X, ee] of Object.entries(Z)) { var fe = new g(); fe.setFromObject(ee), U.addViewport(X, fe); } U.setDefaultViewport(O); }, this.getBoundingBox = () => D.getBoundingBox(true), this.viewAllWithBoundingBox = (O) => { if (O) { var Z = U.getViewportFromBoundingBox(O, 1); U.setCurrentCameraSettings(Z), U.calculateHeightPerPixelAtZeroDepth(V()), W.markerUpdateRequired = true; } }, this.viewAll = () => { var O = this.getBoundingBox(); this.viewAllWithBoundingBox(O), W.markerUpdateRequired = true; }, this.forEachGeometry = (O) => { D.forEachGeometry(O, true); }, this.forEachGlyphset = (O) => { D.forEachGlyphset(O, true); }, this.forEachPointset = (O) => { D.forEachPointset(O, true); }, this.forEachLine = (O) => { D.forEachLine(O, true); }, this.findGeometriesWithGroupName = (O) => D.findGeometriesWithGroupName(O, true), this.findPointsetsWithGroupName = (O) => D.findPointsetsWithGroupName(O, true), this.findGlyphsetsWithGroupName = (O) => D.findGlyphsetsWithGroupName(O, true), this.findLinesWithGroupName = (O) => D.findLinesWithGroupName(O, true), this.findObjectsWithGroupName = (O) => D.findObjectsWithGroupName(O, true), this.findObjectsWithAnatomicalId = (O) => D.findObjectsWithAnatomicalId(O, true), this.getBoundingBoxOfZincObjects = (O) => { for (var Z, X = void 0, ee = 0; ee < O.length; ee++) Z = O[ee].getBoundingBox(), Z && (X ? X.union(Z) : X = Z); return X; }, this.vectorToScreenXY = (O) => { O.project(this.camera); var Z = re(), X = V(), ee = Z / 2, fe = X / 2; return O.x = O.x * ee + ee, O.y = -(O.y * fe) + fe, O; }, this.getObjectsScreenXY = (O) => { if (O && 0 < O.length) { var Z = this.getBoundingBoxOfZincObjects(O), X = new l.Vector3(); return Z.getCenter(X), this.vectorToScreenXY(X); } }, this.getNamedObjectsScreenXY = (O) => { var Z = this.findObjectsWithGroupName(O); return this.getObjectsScreenXY(Z); }, this.addZincObject = (O) => { O && (D.addZincObject(O), U && U.calculateMaxAllowedDistance(this)); }, this.loadGlyphsetURL = (O, Z, X, ee) => { I.loadGlyphsetURL(D, O, Z, X, ee); }, this.loadPointsetURL = (O, Z, X, ee, fe) => { I.loadPointsetURL(D, O, Z, X, ee, fe); }, this.loadLinesURL = (O, Z, X, ee, fe) => { I.loadLinesURL(D, O, Z, X, ee, fe); }, this.loadSTL = (O, Z, X) => { I.loadSTL(D, O, Z, X); }, this.loadOBJ = (O, Z, X) => { I.loadOBJ(D, O, Z, X); }, this.loadMetadataURL = (O, Z, X, ee) => { I.loadMetadataURL(D, O, Z, X, ee); }, this.loadModelsURL = (O, Z, X, ee, fe, be) => { I.loadModelsURL(D.urls, Z, X, ee, fe, be); }, this.loadViewURL = (O) => { I.loadViewURL(O); }, this.loadFromViewURL = (O, Z) => { I.loadFromViewURL(O, Z); }, this.loadGLTF = (O, Z, X, ee) => { I.loadGLTF(D, O, Z, X, ee); }, this.updateDirectionalLight = () => { U.updateDirectionalLight(); }, this.addObject = (O) => { b.add(O); }, this.removeObject = (O) => { b.remove(O); }, this.getCurrentTime = () => { if (S != null) return S.getCurrentTime(B); var O = D.getCurrentTime(); return O === -1 ? 0 : O; }, this.setMorphsTime = (O) => { S != null && S.setMorphTime(O, B), D.setMorphTime(O, true); }, this.isTimeVarying = () => !!(S && S.video && !S.video.error) || D.isTimeVarying(), this.renderGeometries = (O, Z, X) => { var ee = {}; if (ee.camera = U, ee.displayMarkers = this.displayMarkers, ee.markerCluster = W, ee.markersList = W.markers, ee.ndcToBeUpdated = false, X && (ee.markerCluster.markerUpdateRequired = true), !S) I.toBeDownloaded == 0 ? (ee.ndcToBeUpdated = U.update(Z), ee.ndcToBeUpdated && U.calculateHeightPerPixelAtZeroDepth(V()), D.renderGeometries(O, Z, X, U, ee, true)) : U.update(0); else if (S.isReadyToPlay()) { X ? S.video.play() : S.video.pause(); var fe = S.video.currentTime / S.getVideoDuration() * B; I.toBeDownloaded == 0 ? (U.setTime(fe), ee.ndcToBeUpdated = U.update(0), ee.ndcToBeUpdated && U.calculateHeightPerPixelAtZeroDepth(V()), D.setMorphTime(fe, true), D.renderGeometries(0, 0, X, U, ee, true)) : U.update(0); } else myPlayRate = 0; }, this.getThreeJSScene = () => b, this.setVideoHandler = (O) => { S || (S = O); }, this.setAdditionalScenesGroup = (O) => { b.add(O); }; var K = (O, Z, X, ee, fe, be, Ae) => { var he = 0, xe = 0; return xe = O.includes("top") ? Ae - fe - X : O.includes("bottom") ? X : Math.floor((Ae - fe) / 2), he = O.includes("left") ? Z : O.includes("right") ? be - Z - ee : Math.floor((be - ee) / 2), { x: he, y: xe }; }, ce = (O) => { (this.displayMinimap || this.displayMiniAxes) && (O.setScissorTest(true), O.getSize(ie), this.minimapScissor.updateRequired && (te = K(this.minimapScissor.align, this.minimapScissor.x_offset, this.minimapScissor.y_offset, this.minimapScissor.width, this.minimapScissor.height, ie.x, ie.y), this.minimapScissor.updateRequired = false), O.setScissor(te.x, te.y, this.minimapScissor.width, this.minimapScissor.height), O.setViewport(te.x, te.y, this.minimapScissor.width, this.minimapScissor.height), T.updateCamera(), this.displayMiniAxes ? O.render(F, T.camera) : (b.add(T.mask), O.render(b, T.camera), b.remove(T.mask)), O.setScissorTest(false), O.setViewport(0, 0, ie.x, ie.y)); }; this.render = (O) => { this.autoClearFlag && O.clear(), G && Y ? Y.render(b, this.camera) : (O.render(b, this.camera), ce(O)); }, this.setInteractiveControlEnable = (O) => { O == true ? U.enable() : U.disable(); }, this.getZincCameraControls = () => U, this.getThreeJSScene = () => b, this.setDuration = (O) => { D.setDuration(O), B = O, U.setPathDuration(O), I.duration = O; }, this.getDuration = () => B, this.setStereoEffectEnable = (O) => { O != true || Y || (Y = new c(44).StereoEffect(M)), M.setSize(re(), V()), this.camera.updateProjectionMatrix(), G = O; }, this.objectIsInScene = (O) => D.objectIsInRegion(O, true), this.alignBoundingBoxToCameraView = (O, Z) => { if (O) { O.getCenter(j); var X = this.getZincCameraControls().getCurrentViewport(), ee = new l.Vector3(X.targetPosition[0], X.targetPosition[1], X.targetPosition[2]), fe = new l.Vector3(X.eyePosition[0], X.eyePosition[1], X.eyePosition[2]), be = new l.Vector3(), Ae = new l.Vector3(); be.subVectors(ee, fe).normalize(), Ae.subVectors(ee, j).normalize(); var he = new l.Vector3(); he.crossVectors(be, Ae); var xe = be.angleTo(Ae); 0 < Z ? (this.getZincCameraControls().rotateCameraTransition(he, xe, Z), this.getZincCameraControls().enableCameraTransition()) : this.getZincCameraControls().rotateAboutLookAtpoint(he, xe), W.markerUpdateRequired = true; } }, this.translateBoundingBoxToCameraView = (O, Z, X) => { if (O) { var ee = this.getZincCameraControls().getCurrentViewport(), fe = this.getZincCameraControls().getViewportFromBoundingBox(O, Z); 0 < X && (this.getZincCameraControls().cameraTransition(ee, fe, X), this.getZincCameraControls().enableCameraTransition()), W.markerUpdateRequired = true; } }, this.alignObjectToCameraView = (O, Z) => { if (this.objectIsInScene(O)) { var X = O.getBoundingBox(); this.alignBoundingBoxToCameraView(X, Z); } }, this.setCameraTargetToObject = (O) => { if (this.objectIsInScene(O)) { var Z = O.getBoundingBox(), X = this.getZincCameraControls().getCurrentViewport(); Z.getCenter(j); var ee = new l.Vector3(X.targetPosition[0], X.targetPosition[1], X.targetPosition[2]), fe = new l.Vector3(X.eyePosition[0], X.eyePosition[1], X.eyePosition[2]), be = new l.Vector3(), Ae = new l.Vector3(); be.subVectors(fe, ee), Ae.addVectors(j, be), X.eyePosition[0] = Ae.x, X.eyePosition[1] = Ae.y, X.eyePosition[2] = Ae.z, X.targetPosition[0] = j.x, X.targetPosition[1] = j.y, X.targetPosition[2] = j.z, this.getZincCameraControls().setCurrentCameraSettings(X), W.markerUpdateRequired = true; } }, this.isStereoEffectEnable = () => G, this.removeZincObject = (O) => { D.removeZincObject(O), U && U.calculateMaxAllowedDistance(this), W.markerUpdateRequired = true; }, this.updatePickableThreeJSObjects = () => { le.length = 0, W.isEnabled && le.push(W.group), D.getPickableThreeJSObjects(le, true), this.forcePickableObjectsUpdate = false; }, this.getPickableThreeJSObjects = () => ((this.forcePickableObjectsUpdate || D.checkPickableUpdateRequred(true)) && this.updatePickableThreeJSObjects(), le), this.getNormalisedMinimapCoordinates = (O, Z) => { if (this.displayMinimap) { var X = new l.Vector2(); O.getSize(X); var ee = X.y - Z.clientY; if (te.x + this.minimapScissor.width > Z.clientX && Z.clientX > te.x && te.y + this.minimapScissor.height > ee && ee > te.y) { var fe = 2 * ((Z.clientX - te.x) / this.minimapScissor.width) - 1, be = 2 * ((ee - te.y) / this.minimapScissor.height) - 1; return { x: fe, y: be }; } } }, this.getMinimapDiffFromNormalised = (O, Z) => T ? T.getDiffFromNormalised(O, Z) : void 0, this.isWebGL2 = () => M.isWebGL2(), this.clearAll = () => { W.clear(), D.clear(true), this.clearZincObjectAddedCallbacks(), this.clearZincObjectRemovedCallbacks(), I.toBeDwonloaded = 0, U && U.calculateMaxAllowedDistance(this), W.markerUpdateRequired = true; }, this.addMetadataTimeStamp = (O, Z) => { ae.TimeStamps[O] = k(Z); }, this.getMetadataTag = (O) => ae[O], this.getMetadata = () => ae, this.setMetadataTag = (O, Z) => { ae[O] = Z; }, this.removeMetadataTag = (O) => { delete ae[O]; }, this.resetMetadata = () => { ae = x(); }, this.resetDuration = () => { this.setDuration(w); }; var se = (O) => [...O.years ? ["".concat(O.years, "years")] : [], ...O.months ? ["".concat(O.months, "months")] : [], ...O.weeks ? ["".concat(O.weeks, "weeks")] : [], ...O.days ? ["".concat(O.days, "days")] : [], ...O.hours ? ["".concat(O.hours, "hours")] : [], ...O.mins ? ["".concat(O.mins, "mins")] : [], ...O.secs ? ["".concat(O.secs, "secs")] : []].join(" "), k = (O) => O.years ? 31536e6 * O.years : 0 + O.months ? 2592e6 * O.months : 0 + O.weeks ? 6048e5 * O.weeks : 0 + O.days ? 864e5 * O.days : 0 + O.hours ? 36e5 * O.hours : 0 + O.mins ? 6e4 * O.mins : 0 + O.secs ? 1e3 * O.secs : 0; this.setDurationFromObject = (O) => { var Z = se(O), X = k(O); this.setMetadataTag("Duration", Z), this.setDuration(X); }, this.setOriginalDurationFromObject = (O) => { var Z = se(O); this.setMetadataTag("OriginalDuration", Z); }, this.exportGLTF = (O) => { var Z = new f(this); return Z.exportGLTF(O); }, this.getRootRegion = () => D, this.createLines = (O, Z, X, ee) => { var fe = D.findChildFromPath(O); return fe === void 0 && (fe = D.createChildFromPath(O)), fe.createLines(Z, X, ee); }, this.createPoints = (O, Z, X, ee, fe) => { var be = D.findChildFromPath(O); return be === void 0 && (be = D.createChildFromPath(O)), be.createPoints(Z, X, ee, fe); }, this.addZincObjectAddedCallbacks = (O) => (++E, _[E] = O, E), this.addZincObjectRemovedCallbacks = (O) => (++P, C[P] = O, P), this.removeZincObjectAddedCallbacks = (O) => { O in E && delete _[O]; }, this.removeZincObjectRemovedCallbacks = (O) => { O in P && delete C[O]; }, this.clearZincObjectAddedCallbacks = () => { _ = {}, E = 0; }, this.clearZincObjectRemovedCallbacks = () => { C = {}, P = 0; }, this.triggerObjectAddedCallback = (O) => { for (var Z in _) _.hasOwnProperty(Z) && _[Z](O); }, this.triggerObjectRemovedCallback = (O) => { for (var Z in C) C.hasOwnProperty(Z) && C[Z](O); }, this.addTemporaryPoints = (O, Z) => { var X = p(O.length, O), ee = new l.PointsMaterial({ alphaTest: 0.5, size: 15, color: Z, sizeAttenuation: false }), fe = u(); ee.map = fe; var be = new (c(23)).Points(X, ee); return N.add(be), be; }, this.addTemporaryLines = (O, Z) => { var X = p(O.length, O), ee = new l.LineBasicMaterial({ color: Z }), fe = new (c(12)).LineSegments(X, ee); return N.add(fe), fe; }, this.removeTemporaryPrimitive = (O) => { N.remove(O), O.geometry.dispose(), O.material.dispose(); }, this.clearTemporaryPrimitives = () => { var O = 0, Z = N.children; return Z.forEach((X) => { X.geometry.dispose(), X.material.dispose(), O++; }), N.clear(), O; }, this.addBoundingBoxPrimitive = function(O, Z, X, ee, fe) { var be = 5 < arguments.length && arguments[5] !== void 0 ? arguments[5] : void 0, Ae = D.findChildFromPath(O); Ae === void 0 && (Ae = D.createChildFromPath(O)); var he = be || R.getBoundingBox(); j.set(0, 0, 0); var xe = j.subVectors(he.max, he.min), ne = new l.BoxGeometry(xe.x, xe.y, xe.z), me = Ae.createGeometryFromThreeJSGeometry(Z, ne, X, ee, fe, 1e4); return xe.addVectors(he.min, he.max).multiplyScalar(0.5), me.setPosition(xe.x, xe.y, xe.z), me; }, this.addSlicesPrimitive = function(O, Z, X, ee, fe) { var be = 5 < arguments.length && arguments[5] !== void 0 ? arguments[5] : void 0; if (Z && 3 <= Z.length && X && 3 <= X.length) { var Ae = D.findChildFromPath(O); Ae === void 0 && (Ae = D.createChildFromPath(O)); var he = be || R.getBoundingBox(); j.set(0, 0, 0); var xe = j.subVectors(he.max, he.min), ne = [], me = 0; return ["x", "y", "z"].forEach((Me) => { var De; switch (Me) { case "x": De = new l.PlaneGeometry(xe.z, xe.y), De.rotateY(Math.PI / 2); break; case "y": De = new l.PlaneGeometry(xe.x, xe.z), De.rotateX(Math.PI / 2); break; case "z": De = new l.PlaneGeometry(xe.x, xe.y); break; } var Ie = Ae.createGeometryFromThreeJSGeometry(Z[me], De, X[me], ee, fe, 10001); ne.push(Ie), me++; }), xe.addVectors(he.min, he.max).multiplyScalar(0.5), ne.forEach((Me) => { Me.setPosition(xe.x, xe.y, xe.z); }), ne; } }, this.enableMarkerCluster = (O) => { O ? (W.markerUpdateRequired = true, W.enable()) : (W.markerUpdateRequired = false, W.disable()), this.forcePickableObjectsUpdate = true; }, this.destroyAxisDisplay = () => { this.displayMiniAxes = false, $.main && (this.enableAxisDisplay(false, false), $.main.forEach((O) => { O.dispose && O.dispose(); })), $.mini && (this.enableAxisDisplay(false, true), $.mini.forEach((O) => { O.dispose && O.dispose(); })), $ = { main: [], mini: [] }; }, this.createAxisDisplay = function() { var O = 0 < arguments.length && arguments[0] !== void 0 && arguments[0]; R.destroyAxisDisplay(); var Z = [{ name: "x", dir: new l.Vector3(1, 0, 0), colour: "red", hex: 16733525 }, { name: "y", dir: new l.Vector3(0, 1, 0), colour: "green", hex: 5635925 }, { name: "z", dir: new l.Vector3(0, 0, 1), colour: "blue", hex: 5592575 }], X = R.getBoundingBox(), ee = X.min.distanceTo(X.max), fe = new l.Vector3(0, 0, 0); O && fe.copy(X.min), Z.forEach((be) => { var Ae = new l.ArrowHelper(be.dir, fe, ee, be.hex); $.main.push(Ae); var he = new l.ArrowHelper(be.dir, X.getCenter(j), ee / 2, be.hex); $.mini.push(he); var xe = y(be.name, 0.036, be.colour, "Asap", 120, 700), ne = be.dir.clone().multiplyScalar(ee).add(fe); xe.position.set(ne.x, ne.y, ne.z), $.main.push(xe); }); }, this.enableAxisDisplay = function(O) { var Z, X = 1 < arguments.length && arguments[1] !== void 0 && arguments[1]; X && (Z = $) !== null && Z !== void 0 && (Z = Z.mini) !== null && Z !== void 0 && Z.length ? (R.displayMiniAxes = O, $.mini.forEach((ee) => { O ? F.add(ee) : F.remove(ee); })) : !X && $.main && $.main.forEach((ee) => { O ? b.add(ee) : b.remove(ee); }); }; }; }, /* 33 */ /***/ (o, a, c) => { function l(A, M) { var R = Object.keys(A); if (Object.getOwnPropertySymbols) { var L = Object.getOwnPropertySymbols(A); M && (L = L.filter(function(S) { return Object.getOwnPropertyDescriptor(A, S).enumerable; })), R.push.apply(R, L); } return R; } function d(A) { for (var M, R = 1; R < arguments.length; R++) M = arguments[R] == null ? {} : arguments[R], R % 2 ? l(Object(M), true).forEach(function(L) { h6(A, L, M[L]); }) : Object.getOwnPropertyDescriptors ? Object.defineProperties(A, Object.getOwnPropertyDescriptors(M)) : l(Object(M)).forEach(function(L) { Object.defineProperty(A, L, Object.getOwnPropertyDescriptor(M, L)); }); return A; } function h6(A, M, R) { return (M = f(M)) in A ? Object.defineProperty(A, M, { value: R, enumerable: true, configurable: true, writable: true }) : A[M] = R, A; } function f(A) { var M = g(A, "string"); return typeof M == "symbol" ? M : M + ""; } function g(A, M) { if (typeof A != "object" || !A) return A; var R = A[Symbol.toPrimitive]; if (R !== void 0) { var L = R.call(A, M || "default"); if (typeof L != "object") return L; throw new TypeError("@@toPrimitive must return a primitive value."); } return (M === "string" ? String : Number)(A); } var p = c(4), u = new Image(128, 128); u.src = c(34); var y = new p.Texture(); y.image = u, y.needsUpdate = true; var v = [0.02, 0.03, 1], m = new p.SpriteMaterial({ map: y, alphaTest: 0.5, transparent: true, depthTest: false, depthWrite: false, sizeAttenuation: false }), x = c(5).createNewSpriteText, w = function(A) { c(10).ZincObject.call(this), this.texture = y; var M = void 0; this.morph = new p.Group(), this.group = this.morph, this.isMarkerCluster = true; var R = true, L = []; this.markers = {}; var S = new p.Vector2(), I = new p.Vector2(), T = Date.now(); this.setSpriteSize = (b) => { M.scale.set(0.015, 0.02, 1), M.scale.multiplyScalar(b); }, this.clear = () => { this.group.clear(), this.markers = {}; }, this.dispose = () => { this.clear(), this.morph && this.morph.clear(); }; var _ = (b) => { var F = new p.Group(), D = new p.Sprite(m); return D.clusterIndex = b, D.center.set(0.5, 0), D.position.set(0, 0, 0), D.renderOrder = 1e4, D.scale.set(v[0], v[1], v[2]), D.userData = this, F.add(D), this.group.add(F), { group: F, marker: D, label: void 0, number: 0, min: [0, 0, 0], max: [1, 1, 1] }; }, E = (b, F, D) => { b.group.visible = true, b.group.position.set(F.coords[0], F.coords[1], F.coords[2]), (b.label === void 0 || D !== b.number) && (b.label && (b.group.remove(b.label), b.label.material.map.dispose(), b.label.material.dispose()), b.label = x(D, 0.012, "black", "Asap", 120, 700), b.number = D, b.group.add(b.label)), b.min = F.min, b.max = F.max; }, C = (b) => { var F = 0; for (b.forEach((D) => { var N = D.members.length, B = 0; N === 1 ? D.members[0].setVisibility(true) : (D.members.forEach((U) => { B += U.getNumber(), U.setVisibility(false); }), !L[F] && L.push(_(F)), E(L[F], D, B), F++); }), F; F < L.length; F++) L[F].group.visible = false; }, P = (b, F) => { var D = true, N = { members: [], coords: [0, 0, 0], min: [0, 0, 0], max: [1, 1, 1] }, B = 0; for (var U in b) D ? (S.set(b[U].ndc.x, b[U].ndc.y), this._b1.setFromPoints([b[U].morph.position]), D = false, N.members.push(b[U]), N.coords = [b[U].morph.position.x, b[U].morph.position.y, b[U].morph.position.z], F.push(N), delete b[U]) : (I.set(b[U].ndc.x, b[U].ndc.y), B = S.distanceTo(I), 0.1 > B && (N.members.push(b[U]), this._b1.expandByPoint(b[U].morph.position), delete b[U])); N.min = [this._b1.min.x, this._b1.min.y, this._b1.min.z], N.max = [this._b1.max.x, this._b1.max.y, this._b1.max.z], D != true && P(b, F); }; this.calculate = () => { if (R) { var b = Date.now(); if (500 < b - T) { var F = []; P(d({}, this.markers), F), C(F), T = Date.now(), this.markerUpdateRequired = false; } } }, this.isEnabled = () => R, this.enable = () => { R = true, this.morph.visible = true; }, this.disable = () => { for (var b in R = false, this.morph.visible = false, this.markers) { var F; (F = this.markers[b]) !== null && F !== void 0 && F.isMarker && this.markers[b].isEnabled() && this.markers[b].setVisibility(true); } }, this.zoomToCluster = (b) => !!(b !== void 0 && -1 < b && (this._v1.set(...L[b].min), this._v2.set(...L[b].max), Math.abs(0 < this._v1.distanceTo(this._v2)))) && (this._b1.set(this._v1, this._v2), A.translateBoundingBoxToCameraView(this._b1, 3, 300), this.markerUpdateRequired = true, true), this.clusterIsVisible = (b) => { if (b !== void 0 && -1 < b && L[b]) { var F; return (F = L[b].group) === null || F === void 0 ? void 0 : F.visible; } return false; }; }; w.prototype = Object.create(c(10).ZincObject.prototype), a.MarkerCluster = w; }, /* 34 */ /***/ (o) => { o.exports = ""; }, /* 35 */ /***/ (o, a, c) => { var l = c(4), d = c(5).resolveURL, h6 = c(5).createNewURL, f = c(5).isRegionGroup, g = c(36).STLLoader, p = c(37).OBJLoader, u = c(38).PrimitivesLoader; a.SceneLoader = function(y) { var v = y; this.toBeDownloaded = 0, this.progressMap = {}; var m = false, x = false, w = new u(); this.getDownloadProgress = () => { var W = 0, $ = 0, j = false; for (var re in this.progressMap) { var V = this.progressMap[re]; W += V[1], $ += V[0], V[1] == 0 && (j = true); } return j && (W = 0), [W, $, x]; }, this.onProgress = (W) => ($) => { this.progressMap[W] = [$.loaded, $.total]; }, this.onError = (W) => ($) => { --this.toBeDownloaded, x = true, console.error("There is an issue with external resource ".concat($ != null && $.responseURL ? ": " + ($ == null ? void 0 : $.responseURL) : "", ".")), W && W({ type: "Error", xhr: $ }); }; var A = (W, $) => { var j = $.Default; if ($.Inline) v.setupMultipleViews(j, $.Entries); else { var re = [], V = function(se) { W && (newURL = h6(K, W), re.push(new Promise((k, O) => { fetch(newURL).then((Z) => Z.json()).then((Z) => k({ key: se, data: Z })).catch((Z) => O(Z)); }))); }; for (var [H, K] of Object.entries($.Entries)) V(H); Promise.all(re).then((ce) => { var se = {}; ce.forEach((O) => { se[O.key] = O.data; }), v.setupMultipleViews(j, se); var k = v.getZincCameraControls(); k && k.setCurrentViewport(j), m = true; }); } }; this.loadViewURL = (W, $) => { this.toBeDownloaded += 1; var j = new XMLHttpRequest(); j.onreadystatechange = () => { if (j.readyState == 4) if (j.status == 200) { var V = JSON.parse(j.responseText); v.setupMultipleViews("default", { default: V }), v.resetView(), m = true, --this.toBeDownloaded, $ != null && typeof $ == "function" && $(); } else this.onError($)({ responseURL: W }); }; var re = d(W); j.open("GET", re, true), j.send(); }, this.loadModelsURL = (W, $, j, re, V, H, K) => { var ce = $.length; this.toBeDownloaded += ce; for (var se = 0; se < ce; se++) { var k = $[se], O = c(0).defaultMaterialColor, Z = c(0).defaultOpacity; j != null && j[se] != null && (O = !!j[se]), re != null && re[se] != null && (Z = re[se]); var X = 0; V != null && V[se] != null && (X = !!V[se]); var ee = 0; H != null && H[se] != null && (ee = !!H[se]), w.load(d(k), P(W, O, Z, X, ee, void 0, void 0, void 0, void 0, K), this.onProgress(k), this.onError(K)); } }, this.loadFromViewURL = (W, $, j) => { var re = new XMLHttpRequest(); re.onreadystatechange = () => { if (re.readyState == 4 && re.status == 200) { var H = JSON.parse(re.responseText); v.loadView(H); for (var K, ce = [], se = $ + "_", k = 0; k < H.numberOfResources; k++) K = se + (k + 1) + ".json", ce.push(K); this.loadModelsURL(W, ce, H.colour, H.opacity, H.timeEnabled, H.morphColour, j); } }; var V = d($ + "_view.json"); re.open("GET", V, true), re.send(); }; var M = (W, $, j, re, V, H, K, ce, se) => (k, O) => { var Z = ce ? new (c(39)).TubeLines() : new (c(24)).Lines(), X = void 0; O && O[0] && (X = new l.LineBasicMaterial({ color: O[0].color.clone() }), 1 > O[0].opacity && (X.transparent = true), X.opacity = O[0].opacity, X.morphTargets = $, X.vertexColors = O[0].vertexColors); var ee = { localTimeEnabled: $, localMorphColour: j }; if (Z && (Z.createLineSegment(k, X, ee), Z.setName(re), Z.setAnatomicalId(V), Z.setRenderOrder(H), W.addZincObject(Z), Z.setDuration(v.getDuration()), K && K.levels)) for (var [fe, be] of Object.entries(K.levels)) Z.addLOD(w, fe, be.URL, be.Index, K.preload); --this.toBeDownloaded, k.dispose(), se != null && typeof se == "function" && se(Z); }; this.loadLinesURL = (W, $, j, re, V, H, K) => { var ce = 0; this.toBeDownloaded += 1; var se = !!(K != null && K.isInline) && K.isInline, k = K != null && K.anatomicalId ? K.anatomicalId : void 0, O = K != null && K.renderOrder ? K.renderOrder : void 0; j != null && (ce = !!j); var Z = 0; re != null && (Z = !!re); var X = K.tubeLines && !ce && !Z; if (se) { var ee = w.parse($); M(W, ce, Z, V, k, O, K.lod, X, H)(ee.geometry, ee.materials); } else w.load($, M(W, ce, Z, V, k, O, K.lod, X, H), this.onProgress($), this.onError(H), K.loaderOptions); }; var R = (W, $, j, re, V, H) => { var K = H && H.isInline ? H.isInline : void 0, ce = H && H.anatomicalId ? H.anatomicalId : void 0, se = H && H.displayLabels ? H.displayLabels : void 0, k = H && H.renderOrder ? H.renderOrder : void 0, O = new (c(18)).Glyphset(); O.setDuration(v.getDuration()), O.groupName = re; var Z = () => { --this.toBeDownloaded, V != null && typeof V == "function" && V(O); }; ++this.toBeDownloaded, K ? O.load($, j, Z, K, se) : O.load($, d(j), Z, K, se), O.setAnatomicalId(ce), O.setRenderOrder(k), W.addZincObject(O); }, L = (W, $, j, re, V, H) => () => { if ($.readyState == 4 && $.status == 200) { var K = JSON.parse($.responseText); R(W, K, j, re, V, H); } }, S = (W, $, j, re, V, H, K) => (ce, se) => { var k = new (c(22)).Pointset(), O = new l.PointsMaterial({ alphaTest: 0.5, size: 10, sizeAttenuation: false }); se && se[0] && (1 > se[0].opacity && (O.transparent = true), O.opacity = se[0].opacity, O.color = se[0].color, O.morphTargets = $, O.vertexColors = se[0].vertexColors); var Z = {}; Z.localTimeEnabled = $, Z.localMorphColour = j, k && (k.createMesh(ce, O, Z), k.setName(re), k.setAnatomicalId(V), W.addZincObject(k), k.setDuration(v.getDuration()), k.setRenderOrder(H)), ce.dispose(), --this.toBeDownloaded, K != null && typeof K == "function" && K(k); }; this.loadSTL = (W, $, j, re) => { this.toBeDownloaded += 1; var V = c(0).defaultMaterialColor, H = c(0).defaultOpacity, K = new g(); K.crossOrigin = "Anonymous", K.load(d($), P(W, V, H, false, false, j, void 0, void 0, void 0, re)); }, this.loadOBJ = (W, $, j, re) => { this.toBeDownloaded += 1; var V = c(0).defaultMaterialColor, H = c(0).defaultOpacity, K = new p(); K.crossOrigin = "Anonymous", K.load(d($), P(W, V, H, false, false, j, void 0, void 0, void 0, re)); }; var I = (W, $, j, re, V, H, K) => { this.toBeDownloaded += 1; var ce = c(0).defaultMaterialColor, se = c(0).defaultOpacity, k = 0, O = !!(K && K.isInline) && K.isInline, Z = K && K.fileFormat ? K.fileFormat : void 0, X = K && K.anatomicalId ? K.anatomicalId : void 0, ee = K && K.renderOrder ? K.renderOrder : void 0; j != null && (k = !!j); var fe = 0; re != null && (fe = !!re); var be = w; if (Z !== void 0) { if (Z == "STL") be = new g(); else if (Z == "OBJ") return be = new p(), be.crossOrigin = "Anonymous", void be.load($, objloader(W, ce, se, k, fe, V, X, H), this.onProgress($), this.onError, K.loaderOptions); } if (O) { var Ae = w.parse($); P(W, ce, se, k, fe, V, X, ee, K, H)(Ae.geometry, Ae.materials); } else be.crossOrigin = "Anonymous", w.load($, P(W, ce, se, k, fe, V, X, ee, K, H), this.onProgress($), this.onError(H), K.loaderOptions); }, T = function($, j, re) { var V = 0; return (H) => { if (++V, H && j != null && typeof j == "function" && j(H), V == $ && (m == false && v.viewAll(), re != null && typeof re == "function")) { re(); var K = v.getZincCameraControls(); K && K.calculateMaxAllowedDistance(v); } }; }; this.loadPointsetURL = (W, $, j, re, V, H, K) => { var ce = 0; this.toBeDownloaded += 1, j != null && (ce = !!j); var se = 0; re != null && (se = !!re); var k = !!(K && K.isInline) && K.isInline, O = K && K.anatomicalId ? K.anatomicalId : void 0, Z = K && K.renderOrder ? K.renderOrder : void 0; if (k) { var X = w.parse($); S(W, ce, se, V, O, Z, H)(X.geometry, X.materials); } else w.load($, S(W, ce, se, V, O, Z, H), this.onProgress($), this.onError(H), K.loaderOptions); }; var _ = (W, $, j, re, V, H) => { var K = H && H.isInline ? H.isInline : void 0, ce = H && H.anatomicalId ? H.anatomicalId : void 0, se = H && H.renderOrder ? H.renderOrder : void 0, k = void 0; if (j) { if ($ && j.images && j.images.source) for (var O, Z = j.images.source, X = 0; X < Z.length; X++) O = h6(Z[X], $), j.images.source[X] = O; if (j.type === "slides" && (k = new (c(27)).TextureSlides()), k) { k.groupName = re; var ee = () => { --this.toBeDownloaded, V != null && typeof V == "function" && V(k); }; ++this.toBeDownloaded, k.load(j, ee, K), k.setAnatomicalId(ce), k.setRenderOrder(se), W.addZincObject(k); } } }, E = (W, $, j, re, V) => () => { if ($.readyState == 4 && $.status == 200) { var H = JSON.parse($.responseText); _(W, $.responseURL, H, j, re, V); } }; this.loadTextureURL = (W, $, j, re, V) => { var H = !!(V && V.isInline) && V.isInline; if (H) _(W, void 0, $, j, re, V); else { var K = new XMLHttpRequest(); K.onreadystatechange = E(W, K, j, re, V), K.open("GET", d($), true), K.send(); } }, this.loadGlyphsetURL = (W, $, j, re, V, H) => { var K = !!(H && H.isInline) && H.isInline; if (K) R(W, $, j, re, V, H); else { var ce = new XMLHttpRequest(); ce.onreadystatechange = L(W, ce, j, re, V, H), ce.open("GET", d($), true), ce.send(); } }; var C = (W, $, j, re, V, H, K, ce, se, k, O) => { var Z = { colour: j, opacity: re, localTimeEnabled: V, localMorphColour: H }, X = new (c(3)).Geometry(); return X.createMesh($, ce, Z), X.getMorph() ? (X.setName(se), X.setRenderOrder(k), X.setAnatomicalId(O), W && W.addZincObject(X), X.setDuration(v.getDuration()), X.videoHandler && v.setVideoHandler(X.videoHandler), X) : void 0; }, P = (W, $, j, re, V, H, K, ce, se, k) => (O, Z) => { var X; Z && Z[0] && (X = Z[0]); var ee = C(W, O, $, j, re, V, void 0, X, H, ce, K); if (se.lod && se.lod.levels) for (var [fe, be] of Object.entries(se.lod.levels)) ee.addLOD(w, fe, be.URL, be.Index, se.lod.preload); --this.toBeDownloaded, O.dispose(), k != null && typeof k == "function" && k(ee); }, b = (W) => { var $ = /P(?:(\d+)Y)?(?:(\d+)M)?(?:(\d+)W)?(?:(\d+)D)?(?:T(?:(\d+)H)?(?:(\d+)M)?(?:(\d+)S)?)?$/, [, j, re, V, H, K, ce, se] = W.match($); return { years: j, months: re, weeks: V, days: H, hours: K, mins: ce, secs: se }; }; this.loadSettings = (W) => { if (W) { if (W.Duration) { var $ = b(W.Duration); v.setDurationFromObject($); } if (W.OriginalDuration) { var j = b(W.OriginalDuration); v.setOriginalDurationFromObject(j); } if (W.TimeStamps) for (var re in W.TimeStamps) { var V = b(W.TimeStamps[re]); v.addMetadataTimeStamp(re, V); } } }; var F = (W, $, j, re, V) => { if (j) { var H = void 0, K = false; j.URL ? (H = j.URL, $ && (H = h6(H, $))) : j.Inline && (H = j.Inline.URL, K = true); var ce = {}; if (j.LOD && j.LOD.Levels) { ce.preload = !!j.LOD.Preload, ce.levels = {}; for (var [se, k] of Object.entries(j.LOD.Levels)) ce.levels[se] = {}, ce.levels[se].URL = h6(k.URL, $), ce.levels[se].Index = k.Index; } var O = j.GroupName; (O === void 0 || O === "") && (O = "_Unnamed"); var Z = { loaderOptions: { index: j.Index }, isInline: K, fileFormat: j.FileFormat, anatomicalId: j.AnatomicalId, compression: j.compression, tubeLines: j.tubeLines, lod: ce, renderOrder: re }; switch (j.Type) { case "Surfaces": I(W, H, j.MorphVertices, j.MorphColours, O, V, Z); break; case "Glyph": var X; K ? X = j.Inline.GlyphGeometriesURL : (X = j.GlyphGeometriesURL, X = h6(j.GlyphGeometriesURL, $)), j.DisplayLabels && (Z.displayLabels = true), this.loadGlyphsetURL(W, H, X, O, V, Z); break; case "Points": this.loadPointsetURL(W, H, j.MorphVertices, j.MorphColours, O, V, Z); break; case "Lines": this.loadLinesURL(W, H, j.MorphVertices, j.MorphColours, O, V, Z); break; case "Texture": this.loadTextureURL(W, H, O, V, Z); break; } } }, D = (W, $, j) => { if ($) { var re = void 0, V = false; switch ($.URL ? (re = $.URL, W && (re = h6($.URL, W))) : $.Inline && (re = $.Inline.URL, V = true), $.Type) { case "View": V ? (v.setupMultipleViews("default", { default: re }), m = true, j != null && typeof j == "function" && j()) : this.loadViewURL(re, j); break; case "Settings": this.loadSettings($); break; } } }; this.loadGLTF = (W, $, j, re, V) => { var H = new (c(40)).GLTFToZincJSLoader(); H.load(v, W, $, j, re, V); }; var N = (W, $, j, re) => { if (j.Primitives && j.Primitives.forEach((ce) => { var se = 1; ce.Order && (se = ce.Order), F(W, $, ce, se, re); }), j.Transformation && W.setTransformation(j.Transformation), j.Children) for (var [V, H] of Object.entries(j.Children)) { var K = W.findOrCreateChildFromPath(V); K && N(K, $, H, re); } }, B = (W, $) => { var j, re, V = W, H = $ == null || (j = $.enabled) === null || j === void 0 ? void 0 : j.include, K = $ == null || (re = $.enabled) === null || re === void 0 ? void 0 : re.exclude, ce = $ == null ? void 0 : $.tubeLines; return (H != null && H.length || K != null && K.length) && (H && (V = W.filter((se) => { if (se.Type === "View") return true; for (var k = 0; k < H.length; k++) if (f(se.RegionPath, se.GroupName, H[k])) return true; return false; })), K && (V = V.filter((se) => { if (se.Type === "View") return true; for (var k = 0; k < K.length; k++) if (f(se.RegionPath, se.GroupName, K[k])) return false; return true; }))), ce && V.forEach((se) => { se.Type === "Lines" && (se.tubeLines = true); }), V; }, U = (W, $) => Array.isArray(W) ? B(W, $) : W, G = (W, $) => { if (Array.isArray(W)) { for (var j = 0, re = 0; re < W.length; re++) W[re].Type && ($ && W[re].Type === "View" || W[re].Type === "Surfaces" || W[re].Type === "Glyph" || W[re].Type === "Points" || W[re].Type === "Lines" || W[re].Type === "Texture") && j++; return j; } return 0; }, Y = (W) => { var $ = W.Primitives ? G(W.Primitives, false) : 0; return W.Children && Object.values(W.Children).forEach((j) => { $ += Y(j); }), $; }, te = (W) => Array.isArray(W) ? G(W, true) : typeof W == "object" && W !== null && W.Version === "2.0" ? Y(W.Regions) : void 0, ae = (W, $, j, re, V) => { var H = W; j.RegionPath && j.RegionPath !== "" && (H = W.findOrCreateChildFromPath(j.RegionPath)), F(H, $, j, 2 * re, V); }, ie = (W, $, j, re, V, H) => { for (var K = U($, H), ce = te(K), se = new T(ce, re, V), k = 0; k < $.length; k++) D(j, K[k], se); for (var O = 0; O < $.length; O++) ae(W, j, K[O], O, se); }, le = (W, $, j, re, V) => { var H = te($), K = new T(H, re, V); $.Settings && this.loadSettings($.Settings), $.Views && A(j, $.Views), $.Regions && N(W, j, $.Regions, K); }; this.loadMetadataURL = (W, $, j, re, V) => { var H = new XMLHttpRequest(), K = d($); H.onreadystatechange = () => { if (H.readyState == 4 && H.status == 200) { v.resetMetadata(), v.resetDuration(), m = false; var ce = H.responseURL; ce === void 0 && (ce = new URL(K).href); var se = JSON.parse(H.responseText); Array.isArray(se) ? ie(W, se, ce, j, re, V) : typeof se == "object" && se !== null && se.Version == "2.0" && le(W, se, ce, j, re); } }, H.open("GET", K, true), H.send(); }; }; }, /* 36 */ /***/ (o, a, c) => { c.r(a), c.d(a, { /* harmony export */ STLLoader: () => ( /* binding */ d ) /* harmony export */ }); var l = c(4); class d extends l.Loader { constructor(f) { super(f); } load(f, g, p, u) { var y = this, v = new l.FileLoader(this.manager); v.setPath(this.path), v.setResponseType("arraybuffer"), v.setRequestHeader(this.requestHeader), v.setWithCredentials(this.withCredentials), v.load(f, function(m) { try { g(y.parse(m)); } catch (x) { u ? u(x) : console.error(x), y.manager.itemError(f); } }, p, u); } parse(f) { function g(u, y, v) { for (var m = 0, x = u.length; m < x; m++) if (u[m] !== y.getUint8(v + m, false)) return false; return true; } var p = function(u) { if (typeof u == "string") { for (var y = new Uint8Array(u.length), v = 0; v < u.length; v++) y[v] = 255 & u.charCodeAt(v); return y.buffer || y; } return u; }(f); return function(u) { var y = new DataView(u), v = y.getUint32(80, true); if (84 + v * 50 === y.byteLength) return true; for (var m = [115, 111, 108, 105, 100], x = 0; 5 > x; x++) if (g(m, y, x)) return false; return true; }(p) ? function(u) { for (var y, v, m, x, w, A, M, R, L = new DataView(u), S = L.getUint32(80, true), I = false, T = 0; T < 70; T++) L.getUint32(T, false) == 1129270351 && L.getUint8(T + 4) == 82 && L.getUint8(T + 5) == 61 && (I = true, x = new Float32Array(3 * (3 * S)), w = L.getUint8(T + 6) / 255, A = L.getUint8(T + 7) / 255, M = L.getUint8(T + 8) / 255, R = L.getUint8(T + 9) / 255); for (var _ = new l.BufferGeometry(), E = new Float32Array(3 * (3 * S)), C = new Float32Array(3 * (3 * S)), P = 0; P < S; P++) { var b = 84 + P * 50, F = L.getFloat32(b, true), D = L.getFloat32(b + 4, true), N = L.getFloat32(b + 8, true); if (I) { var B = L.getUint16(b + 48, true); 32768 & B ? (y = w, v = A, m = M) : (y = (31 & B) / 31, v = (31 & B >> 5) / 31, m = (31 & B >> 10) / 31); } for (var U = 1; 3 >= U; U++) { var G = b + 12 * U, Y = 3 * (3 * P) + 3 * (U - 1); E[Y] = L.getFloat32(G, true), E[Y + 1] = L.getFloat32(G + 4, true), E[Y + 2] = L.getFloat32(G + 8, true), C[Y] = F, C[Y + 1] = D, C[Y + 2] = N, I && (x[Y] = y, x[Y + 1] = v, x[Y + 2] = m); } } return _.setAttribute("position", new l.BufferAttribute(E, 3)), _.setAttribute("normal", new l.BufferAttribute(C, 3)), I && (_.setAttribute("color", new l.BufferAttribute(x, 3)), _.hasColors = true, _.alpha = R), _; }(p) : function(u) { for (var y, v = new l.BufferGeometry(), m = /solid([\s\S]*?)endsolid/g, x = /facet([\s\S]*?)endfacet/g, w = 0, A = /[\s]+([+-]?(?:\d*)(?:\.\d*)?(?:[eE][+-]?\d+)?)/.source, M = new RegExp("vertex" + A + A + A, "g"), R = new RegExp("normal" + A + A + A, "g"), L = [], S = [], I = new l.Vector3(), T = 0, _ = 0, E = 0; (y = m.exec(u)) !== null; ) { _ = E; for (var C = y[0]; (y = x.exec(C)) !== null; ) { for (var P = 0, b = 0, F = y[0]; (y = R.exec(F)) !== null; ) I.x = parseFloat(y[1]), I.y = parseFloat(y[2]), I.z = parseFloat(y[3]), b++; for (; (y = M.exec(F)) !== null; ) L.push(parseFloat(y[1]), parseFloat(y[2]), parseFloat(y[3])), S.push(I.x, I.y, I.z), P++, E++; b !== 1 && console.error("THREE.STLLoader: Something isn't right with the normal of face number " + w), P !== 3 && console.error("THREE.STLLoader: Something isn't right with the vertices of face number " + w), w++; } var D = _, N = E - _; v.addGroup(D, N, T), T++; } return v.setAttribute("position", new l.Float32BufferAttribute(L, 3)), v.setAttribute("normal", new l.Float32BufferAttribute(S, 3)), v; }(function(u) { return typeof u == "string" ? u : l.LoaderUtils.decodeText(new Uint8Array(u)); }(f)); } } }, /* 37 */ /***/ (o, a, c) => { c.r(a), c.d(a, { /* harmony export */ OBJLoader: () => ( /* binding */ w ) /* harmony export */ }); var l = c(4), d = /^[og]\s*(.+)?/, h6 = /^mtllib /, f = /^usemtl /, g = /^usemap /, p = new l.Vector3(), u = new l.Vector3(), y = new l.Vector3(), v = new l.Vector3(), m = new l.Vector3(); function x() { var A = { objects: [], object: {}, vertices: [], normals: [], colors: [], uvs: [], materials: {}, materialLibraries: [], startObject: function(R, L) { if (this.object && this.object.fromDeclaration === false) return this.object.name = R, void (this.object.fromDeclaration = L !== false); var S = this.object && typeof this.object.currentMaterial == "function" ? this.object.currentMaterial() : void 0; if (this.object && typeof this.object._finalize == "function" && this.object._finalize(true), this.object = { name: R || "", fromDeclaration: L !== false, geometry: { vertices: [], normals: [], colors: [], uvs: [], hasUVIndices: false }, materials: [], smooth: true, startMaterial: function(_, E) { var C = this._finalize(false); C && (C.inherited || 0 >= C.groupCount) && this.materials.splice(C.index, 1); var P = { index: this.materials.length, name: _ || "", mtllib: Array.isArray(E) && 0 < E.length ? E[E.length - 1] : "", smooth: C === void 0 ? this.smooth : C.smooth, groupStart: C === void 0 ? 0 : C.groupEnd, groupEnd: -1, groupCount: -1, inherited: false, clone: function(F) { var D = { index: typeof F == "number" ? F : this.index, name: this.name, mtllib: this.mtllib, smooth: this.smooth, groupStart: 0, groupEnd: -1, groupCount: -1, inherited: false }; return D.clone = this.clone.bind(D), D; } }; return this.materials.push(P), P; }, currentMaterial: function() { return 0 < this.materials.length ? this.materials[this.materials.length - 1] : void 0; }, _finalize: function(_) { var E = this.currentMaterial(); if (E && E.groupEnd === -1 && (E.groupEnd = this.geometry.vertices.length / 3, E.groupCount = E.groupEnd - E.groupStart, E.inherited = false), _ && 1 < this.materials.length) for (var C = this.materials.length - 1; 0 <= C; C--) 0 >= this.materials[C].groupCount && this.materials.splice(C, 1); return _ && this.materials.length === 0 && this.materials.push({ name: "", smooth: this.smooth }), E; } }, S && S.name && typeof S.clone == "function") { var I = S.clone(0); I.inherited = true, this.object.materials.push(I); } this.objects.push(this.object); }, finalize: function() { this.object && typeof this.object._finalize == "function" && this.object._finalize(true); }, parseVertexIndex: function(R, L) { var S = parseInt(R, 10); return 3 * (0 <= S ? S - 1 : S + L / 3); }, parseNormalIndex: function(R, L) { var S = parseInt(R, 10); return 3 * (0 <= S ? S - 1 : S + L / 3); }, parseUVIndex: function(R, L) { var S = parseInt(R, 10); return 2 * (0 <= S ? S - 1 : S + L / 2); }, addVertex: function(R, L, S) { var I = this.vertices, T = this.object.geometry.vertices; T.push(I[R + 0], I[R + 1], I[R + 2]), T.push(I[L + 0], I[L + 1], I[L + 2]), T.push(I[S + 0], I[S + 1], I[S + 2]); }, addVertexPoint: function(R) { var L = this.vertices, S = this.object.geometry.vertices; S.push(L[R + 0], L[R + 1], L[R + 2]); }, addVertexLine: function(R) { var L = this.vertices, S = this.object.geometry.vertices; S.push(L[R + 0], L[R + 1], L[R + 2]); }, addNormal: function(R, L, S) { var I = this.normals, T = this.object.geometry.normals; T.push(I[R + 0], I[R + 1], I[R + 2]), T.push(I[L + 0], I[L + 1], I[L + 2]), T.push(I[S + 0], I[S + 1], I[S + 2]); }, addFaceNormal: function(R, L, S) { var I = this.vertices, T = this.object.geometry.normals; p.fromArray(I, R), u.fromArray(I, L), y.fromArray(I, S), m.subVectors(y, u), v.subVectors(p, u), m.cross(v), m.normalize(), T.push(m.x, m.y, m.z), T.push(m.x, m.y, m.z), T.push(m.x, m.y, m.z); }, addColor: function(R, L, S) { var I = this.colors, T = this.object.geometry.colors; I[R] !== void 0 && T.push(I[R + 0], I[R + 1], I[R + 2]), I[L] !== void 0 && T.push(I[L + 0], I[L + 1], I[L + 2]), I[S] !== void 0 && T.push(I[S + 0], I[S + 1], I[S + 2]); }, addUV: function(R, L, S) { var I = this.uvs, T = this.object.geometry.uvs; T.push(I[R + 0], I[R + 1]), T.push(I[L + 0], I[L + 1]), T.push(I[S + 0], I[S + 1]); }, addDefaultUV: function() { var R = this.object.geometry.uvs; R.push(0, 0), R.push(0, 0), R.push(0, 0); }, addUVLine: function(R) { var L = this.uvs, S = this.object.geometry.uvs; S.push(L[R + 0], L[R + 1]); }, addFace: function(R, L, S, I, T, _, E, C, P) { var b = this.vertices.length, F = this.parseVertexIndex(R, b), D = this.parseVertexIndex(L, b), N = this.parseVertexIndex(S, b); if (this.addVertex(F, D, N), this.addColor(F, D, N), E !== void 0 && E !== "") { var B = this.normals.length; F = this.parseNormalIndex(E, B), D = this.parseNormalIndex(C, B), N = this.parseNormalIndex(P, B), this.addNormal(F, D, N); } else this.addFaceNormal(F, D, N); if (I !== void 0 && I !== "") { var U = this.uvs.length; F = this.parseUVIndex(I, U), D = this.parseUVIndex(T, U), N = this.parseUVIndex(_, U), this.addUV(F, D, N), this.object.geometry.hasUVIndices = true; } else this.addDefaultUV(); }, addPointGeometry: function(R) { this.object.geometry.type = "Points"; for (var L, S = this.vertices.length, I = 0, T = R.length; I < T; I++) L = this.parseVertexIndex(R[I], S), this.addVertexPoint(L), this.addColor(L); }, addLineGeometry: function(R, L) { this.object.geometry.type = "Line"; for (var S = this.vertices.length, I = this.uvs.length, T = 0, _ = R.length; T < _; T++) this.addVertexLine(this.parseVertexIndex(R[T], S)); for (var E = 0, C = L.length; E < C; E++) this.addUVLine(this.parseUVIndex(L[E], I)); } }; return A.startObject("", false), A; } class w extends l.Loader { constructor(M) { super(M), this.materials = null; } load(M, R, L, S) { var I = this, T = new l.FileLoader(this.manager); T.setPath(this.path), T.setRequestHeader(this.requestHeader), T.setWithCredentials(this.withCredentials), T.load(M, function(_) { try { R(I.parse(_)); } catch (E) { S ? S(E) : console.error(E), I.manager.itemError(M); } }, L, S); } setMaterials(M) { return this.materials = M, this; } parse(M) { var R = new x(); M.indexOf(`\r `) !== -1 && (M = M.replace(/\r\n/g, ` `)), M.indexOf(`\\ `) !== -1 && (M = M.replace(/\\\n/g, "")); for (var L = M.split(` `), S = "", I = "", T = 0, _ = [], E = typeof "".trimLeft == "function", C = 0, P = L.length; C < P; C++) if (S = L[C], S = E ? S.trimLeft() : S.trim(), T = S.length, T !== 0 && (I = S.charAt(0), I !== "#")) if (I === "v") { var b = S.split(/\s+/); switch (b[0]) { case "v": R.vertices.push(parseFloat(b[1]), parseFloat(b[2]), parseFloat(b[3])), 7 <= b.length ? R.colors.push(parseFloat(b[4]), parseFloat(b[5]), parseFloat(b[6])) : R.colors.push(void 0, void 0, void 0); break; case "vn": R.normals.push(parseFloat(b[1]), parseFloat(b[2]), parseFloat(b[3])); break; case "vt": R.uvs.push(parseFloat(b[1]), parseFloat(b[2])); } } else if (I === "f") { for (var F, D = S.substr(1).trim(), N = D.split(/\s+/), B = [], U = 0, G = N.length; U < G; U++) if (F = N[U], 0 < F.length) { var Y = F.split("/"); B.push(Y); } for (var te = B[0], ae = 1, ie = B.length - 1; ae < ie; ae++) { var le = B[ae], W = B[ae + 1]; R.addFace(te[0], le[0], W[0], te[1], le[1], W[1], te[2], le[2], W[2]); } } else if (I === "l") { var $ = S.substring(1).trim().split(" "), j = [], re = []; if (S.indexOf("/") === -1) j = $; else for (var V, H = 0, K = $.length; H < K; H++) V = $[H].split("/"), V[0] !== "" && j.push(V[0]), V[1] !== "" && re.push(V[1]); R.addLineGeometry(j, re); } else if (I === "p") { var ce = S.substr(1).trim(), se = ce.split(" "); R.addPointGeometry(se); } else if ((_ = d.exec(S)) !== null) { var k = (" " + _[0].substr(1).trim()).substr(1); R.startObject(k); } else if (f.test(S)) R.object.startMaterial(S.substring(7).trim(), R.materialLibraries); else if (h6.test(S)) R.materialLibraries.push(S.substring(7).trim()); else if (g.test(S)) console.warn('THREE.OBJLoader: Rendering identifier "usemap" not supported. Textures must be defined in MTL files.'); else if (I === "s") { if (_ = S.split(" "), 1 < _.length) { var O = _[1].trim().toLowerCase(); R.object.smooth = O !== "0" && O !== "off"; } else R.object.smooth = true; var Z = R.object.currentMaterial(); Z && (Z.smooth = R.object.smooth); } else { if (S === "\0") continue; console.warn('THREE.OBJLoader: Unexpected line: "' + S + '"'); } R.finalize(); var X = new l.Group(); X.materialLibraries = [].concat(R.materialLibraries); var ee = R.objects.length !== 1 || R.objects[0].geometry.vertices.length !== 0; if (ee == true) for (var fe = 0, be = R.objects.length; fe < be; fe++) { var Ae = R.objects[fe], he = Ae.geometry, xe = Ae.materials, ne = he.type === "Line", me = he.type === "Points", Me = false; if (he.vertices.length !== 0) { var De = new l.BufferGeometry(); De.setAttribute("position", new l.Float32BufferAttribute(he.vertices, 3)), 0 < he.normals.length && De.setAttribute("normal", new l.Float32BufferAttribute(he.normals, 3)), 0 < he.colors.length && (Me = true, De.setAttribute("color", new l.Float32BufferAttribute(he.colors, 3))), he.hasUVIndices === true && De.setAttribute("uv", new l.Float32BufferAttribute(he.uvs, 2)); for (var Ie = [], $e = 0, lt = xe.length; $e < lt; $e++) { var qe = xe[$e], Mt = qe.name + "_" + qe.smooth + "_" + Me, Be = R.materials[Mt]; if (this.materials !== null) { if (Be = this.materials.create(qe.name), ne && Be && !(Be instanceof l.LineBasicMaterial)) { var it = new l.LineBasicMaterial(); l.Material.prototype.copy.call(it, Be), it.color.copy(Be.color), Be = it; } else if (me && Be && !(Be instanceof l.PointsMaterial)) { var tt = new l.PointsMaterial({ size: 10, sizeAttenuation: false }); l.Material.prototype.copy.call(tt, Be), tt.color.copy(Be.color), tt.map = Be.map, Be = tt; } } Be === void 0 && (Be = ne ? new l.LineBasicMaterial() : me ? new l.PointsMaterial({ size: 1, sizeAttenuation: false }) : new l.MeshPhongMaterial(), Be.name = qe.name, Be.flatShading = !qe.smooth, Be.vertexColors = Me, R.materials[Mt] = Be), Ie.push(Be); } var qt = void 0; if (1 < Ie.length) { for (var Qt, Ft = 0, Nt = xe.length; Ft < Nt; Ft++) Qt = xe[Ft], De.addGroup(Qt.groupStart, Qt.groupCount, Ft); qt = ne ? new l.LineSegments(De, Ie) : me ? new l.Points(De, Ie) : new l.Mesh(De, Ie); } else qt = ne ? new l.LineSegments(De, Ie[0]) : me ? new l.Points(De, Ie[0]) : new l.Mesh(De, Ie[0]); qt.name = Ae.name, X.add(qt); } } else if (0 < R.vertices.length) { var Vi = new l.PointsMaterial({ size: 1, sizeAttenuation: false }), ki = new l.BufferGeometry(); ki.setAttribute("position", new l.Float32BufferAttribute(R.vertices, 3)), 0 < R.colors.length && R.colors[0] !== void 0 && (ki.setAttribute("color", new l.Float32BufferAttribute(R.colors, 3)), Vi.vertexColors = true); var ni = new l.Points(ki, Vi); X.add(ni); } return X; } } }, /* 38 */ /***/ (o, a, c) => { function l(w, A) { var M = Object.keys(w); if (Object.getOwnPropertySymbols) { var R = Object.getOwnPropertySymbols(w); A && (R = R.filter(function(L) { return Object.getOwnPropertyDescriptor(w, L).enumerable; })), M.push.apply(M, R); } return M; } function d(w) { for (var A, M = 1; M < arguments.length; M++) A = arguments[M] == null ? {} : arguments[M], M % 2 ? l(Object(A), true).forEach(function(R) { h6(w, R, A[R]); }) : Object.getOwnPropertyDescriptors ? Object.defineProperties(w, Object.getOwnPropertyDescriptors(A)) : l(Object(A)).forEach(function(R) { Object.defineProperty(w, R, Object.getOwnPropertyDescriptor(A, R)); }); return w; } function h6(w, A, M) { return (A = f(A)) in w ? Object.defineProperty(w, A, { value: M, enumerable: true, configurable: true, writable: true }) : w[A] = M, w; } function f(w) { var A = g(w, "string"); return typeof A == "symbol" ? A : A + ""; } function g(w, A) { if (typeof w != "object" || !w) return w; var M = w[Symbol.toPrimitive]; if (M !== void 0) { var R = M.call(w, A || "default"); if (typeof R != "object") return R; throw new TypeError("@@toPrimitive must return a primitive value."); } return (A === "string" ? String : Number)(w); } var p = c(19).JSONLoader, u = c(4), y = u.FileLoader, v = (w) => { var A = (R, L) => { R.merge(L); }; if (w && 0 < w.length) { for (; 1 < w.length; ) { var M = w.splice(1, 1); A(w[0], M[0]); } return w[0]; } }, m = function(A, M, R) { var L = new y(), S = new p(); L.crossOrigin = M; var I = A, T = R, _ = void 0, E = false, C = false, P = void 0, b = [], F = (U) => { var G = _[U.index]; if (G) { var Y = S.parse(G); U.onLoad(Y.geometry, Y.materials); } else D(U); }, D = (U) => { U.onError && (!P && (P = { responseURL: I }), U.onError(P)); }; this.downloadCompleted = (U) => { try { _ = JSON.parse(U[0]), E = false, C = true, Array.isArray(_) ? b.forEach((G) => F(G)) : b.forEach((G) => D(G)); } catch { b.forEach((Y) => D(Y)); } }; var N = () => (U) => { P = U, C = true, E = false, b.forEach((G) => { D(G); }); }, B = () => (U) => { b.forEach((G) => { G.onProgress && G.onProgress(U); }); }; this.load = (U, G, Y, te) => { var ae = { index: U, onLoad: G, onProgress: Y, onError: te }; C ? _ ? F(ae) : D(P) : E ? b.push(ae) : (b.push(ae), E = true, L.load(I, T, B, N)); }; }, x = function(A, M) { var R = [], L = A, S = M, I = 0; this.itemDownloaded = (T, _) => { if (R[T] = _, I++, I == L) { for (var E = R[0][1], C = R.map((F) => F[0]), P = v(C), b = 1; b < L; b++) R[T][0].dispose(), R[T][1].forEach((F) => F.dispose()); S(P, E); } }; }; a.PrimitivesLoader = function() { var w = 0, A = 20; this.crossOrigin = "Anonymous"; var M = new p(), R = [], L = {}, S = (E, C, P, b, F) => { var D = E.length, N = new x(D, C), B = 0; E.forEach((U) => { var G = F ? d({}, F) : {}; G.msHandler = N, G.order = B, B++, T(U, C, P, b, G); }); }, I = (E, C, P, b, F) => { var D = F ? d({}, F) : {}, N = L[E]; if (!N) if (A > w) { var B = new _(void 0, this, D); ++w, N = new m(E, this.crossOrigin, B), L[E] = N; } else R.push({ url: E, onLoad: C, onProgress: P, onError: b, options: F }); N && (D.isHandler = N, N.load(F.index, C, P, b)); }, T = (E, C, P, b, F) => { if (F && F.index !== void 0) I(E, C, P, b, F); else if (A > w) { ++w; var D = new _(C, this, F), N = new _(b, this, F); M.crossOrigin = this.crossOrigin, M.load(E, D, P, N); } else R.push({ url: E, onLoad: C, onProgress: P, onError: b, options: F }); }; this.load = (E, C, P, b, F) => { Array.isArray(E) ? S(E, C, P, b, F) : T(E, C, P, b, F); }, this.loadFromWaitingList = () => { for (; A > w; ) { var E = R.shift(); if (E) this.load(E.url, E.onLoad, E.onProgress, E.onError, E.options); else return; } }, this.itemRemainingCheck = () => { if (R.length === 0 && w == 0) for (var E in L) L.hasOwnProperty(E) && delete L[E]; }; var _ = function(C, P, b) { return function() { --w; for (var F = arguments.length, D = Array(F), N = 0; N < F; N++) D[N] = arguments[N]; b != null && b.msHandler ? b.msHandler.itemDownloaded(b.order, D) : b != null && b.isHandler ? b.isHandler.downloadCompleted(D) : C && C(...D), P.loadFromWaitingList(), P.itemRemainingCheck(); }; }; this.parse = (E) => M.parse(E); }; }, /* 39 */ /***/ (o, a, c) => { var l = c(4), d = c(5).mergeGeometries, h6 = function() { c(10).ZincObject.call(this), this.isTubeLines = true; var f = {}, g = { radius: 1, radialSegments: 8, smooth: false }; this.createLineSegment = (u, y, v) => { if (u && y) { f = { geometryIn: u, materialIn: y, options: v }; var m = p(u.vertices), x = new l.MeshStandardMaterial({ color: y.color }), w = new l.Mesh(m, x); this.setMesh(w, v.localTimeEnabled, v.localMorphColour); } }, this.setWidth = (u) => { this.morph && this.morph.material && (this.morph.material.linewidth = u, this.morph.material.needsUpdate = true); }, this.setAlpha = function(u) { var y = this.getMorph(); y.material.opacity = u, y.material.transparent = 1 > u, y.material.depthWrite = 0.5 < u; }, this.setWireframe = (u) => { var y = this.getMorph(); y.material.wireframe = u; }, this.setTubeLines = (u, y) => { if (u && y) { var { geometryIn: v } = f, m = this.getMorph(); m.geometry.dispose(), g = Object.assign(g, { radius: u, radialSegments: y }), m.geometry = p(v.vertices); } }; var p = (u) => { var y, { radius: v, radialSegments: m, smooth: x } = g; if (x) { var w = new l.CatmullRomCurve3(u); y = new l.TubeGeometry(w, u.length, v, m, false); } else { for (var A = [], M = 0; M + 1 < u.length; M += 2) { var R = new l.LineCurve3(u[M], u[M + 1]), L = new l.TubeGeometry(R, 1, v, m, false); A.push(L); } y = d(A, true), A.forEach((S) => S.dispose()); } return y; }; }; h6.prototype = Object.create(c(10).ZincObject.prototype), a.TubeLines = h6; }, /* 40 */ /***/ (o, a, c) => { c(4); var l = c(41).GLTFLoader, d = function() { var h6 = this; this.parseGLTFObjects = (f, g, p, u) => { var y = g; if (p !== 0) { if (f.type !== "Object3D") { var v; if (f.type === "Mesh" ? v = new (c(3)).Geometry() : f.type === "LineSegments" ? v = new (c(24)).Lines() : f.type === "Points" && (v = new (c(22)).Pointset()), v) { var m = false, x = false; f.geometry && f.geometry.morphAttributes && (m = !!f.geometry.morphAttributes.position, x = !!f.geometry.morphAttributes.color), v.setMesh(f.clone(), m, x); var w = v.getMorph(); v.groupName = w.name, w.matrixAutoUpdate = true, g.addZincObject(v), u != null && typeof u == "function" && u(v); } } else if (f.name !== "" && (g && (y = g.findOrCreateChildFromPath(f.name)), y)) { var A = y.getGroup(); A.position.copy(f.position), A.rotation.copy(f.rotation), A.quaternion.copy(f.quaternion), A.matrixAutoUpdate = true; } } p++, f.children.forEach((M) => { h6.parseGLTFObjects(M, y, p, u); }); }, this.setCamera = (f) => { f.viewAll(); var g = f.getZincCameraControls(), p = g.getCurrentViewport(); g.addViewport("default", p), g.setDefaultViewport("default"); }, this.load = (f, g, p, u, y) => { var v = p.substring(0, p.lastIndexOf("/") + 1), m = p.substring(p.lastIndexOf("/") + 1, p.length), x = new l().setPath(v); x.load(m, function(w) { console.log(w), h6.parseGLTFObjects(w.scene, g, 0, u), h6.setCamera(f), y != null && typeof y == "function" && y(); }); }; }; a.GLTFToZincJSLoader = d; }, /* 41 */ /***/ (o) => { o.exports = x4; }, /* 42 */ /***/ (o, a, c) => { var l = c(43).GLTFExporter, d = function(h6) { var f = h6; this.exportGLTF = (g) => { var p = f.getRootRegion(), u = p.getAllObjects(true), y = []; u.forEach((x) => { x.animationClip && y.push({ clip: x.animationClip[0], mesh: x.getMorph() }); }); var v = new l(), m = { binary: g, animations: y }; return new Promise((x) => { v.parse(f.getThreeJSScene(), function(w) { x(w); }, m); }); }; }; a.SceneExporter = d; }, /* 43 */ /***/ (o, a, c) => { c.r(a), c.d(a, { /* harmony export */ GLTFExporter: () => ( /* binding */ d ) /* harmony export */ }); var l = c(4); class d { constructor() { this.pluginCallbacks = [], this.register(function(b) { return new _(b); }), this.register(function(b) { return new E(b); }), this.register(function(b) { return new C(b); }); } register(b) { return this.pluginCallbacks.indexOf(b) === -1 && this.pluginCallbacks.push(b), this; } unregister(b) { return this.pluginCallbacks.indexOf(b) !== -1 && this.pluginCallbacks.splice(this.pluginCallbacks.indexOf(b), 1), this; } /** * Parse scenes and generate GLTF output * @param {Scene or [THREE.Scenes]} input Scene or Array of THREE.Scenes * @param {Function} onDone Callback on completed * @param {Object} options options */ parse(b, F, D) { for (var N = new T(), B = [], U = 0, G = this.pluginCallbacks.length; U < G; U++) B.push(this.pluginCallbacks[U](N)); N.setPlugins(B), N.write(b, F, D); } } var h6 = { POINTS: 0, LINES: 1, LINE_LOOP: 2, LINE_STRIP: 3, TRIANGLES: 4, TRIANGLE_STRIP: 5, TRIANGLE_FAN: 6, UNSIGNED_BYTE: 5121, UNSIGNED_SHORT: 5123, FLOAT: 5126, UNSIGNED_INT: 5125, ARRAY_BUFFER: 34962, ELEMENT_ARRAY_BUFFER: 34963, NEAREST: 9728, LINEAR: 9729, NEAREST_MIPMAP_NEAREST: 9984, LINEAR_MIPMAP_NEAREST: 9985, NEAREST_MIPMAP_LINEAR: 9986, LINEAR_MIPMAP_LINEAR: 9987, CLAMP_TO_EDGE: 33071, MIRRORED_REPEAT: 33648, REPEAT: 10497 }, f = {}; f[l.NearestFilter] = h6.NEAREST, f[l.NearestMipmapNearestFilter] = h6.NEAREST_MIPMAP_NEAREST, f[l.NearestMipmapLinearFilter] = h6.NEAREST_MIPMAP_LINEAR, f[l.LinearFilter] = h6.LINEAR, f[l.LinearMipmapNearestFilter] = h6.LINEAR_MIPMAP_NEAREST, f[l.LinearMipmapLinearFilter] = h6.LINEAR_MIPMAP_LINEAR, f[l.ClampToEdgeWrapping] = h6.CLAMP_TO_EDGE, f[l.RepeatWrapping] = h6.REPEAT, f[l.MirroredRepeatWrapping] = h6.MIRRORED_REPEAT; var g = { scale: "scale", position: "translation", quaternion: "rotation", morphTargetInfluences: "weights" }, p = 12, u = 1179937895, y = 2, v = 8, m = 1313821514, x = 5130562; function w(P, b) { return P.length === b.length && P.every(function(F, D) { return F === b[D]; }); } function A(P) { if (window.TextEncoder !== void 0) return new TextEncoder().encode(P).buffer; for (var b, F = new Uint8Array(new ArrayBuffer(P.length)), D = 0, N = P.length; D < N; D++) b = P.charCodeAt(D), F[D] = 255 < b ? 32 : b; return F.buffer; } function M(P) { return w(P.elements, [1, 0, 0, 0, 0, 1, 0, 0, 0, 0, 1, 0, 0, 0, 0, 1]); } function R(P, b, F) { for (var D = { min: Array(P.itemSize).fill(Number.POSITIVE_INFINITY), max: Array(P.itemSize).fill(Number.NEGATIVE_INFINITY) }, N = b; N < b + F; N++) for (var B, U = 0; U < P.itemSize; U++) B = void 0, 4 < P.itemSize ? B = P.array[N * P.itemSize + U] : U === 0 ? B = P.getX(N) : U === 1 ? B = P.getY(N) : U === 2 ? B = P.getZ(N) : U == 3 && (B = P.getW(N)), D.min[U] = Math.min(D.min[U], B), D.max[U] = Math.max(D.max[U], B); return D; } function L(P) { return 4 * Math.ceil(P / 4); } function S(P) { var b = 1 < arguments.length && arguments[1] !== void 0 ? arguments[1] : 0, F = L(P.byteLength); if (F !== P.byteLength) { var D = new Uint8Array(F); if (D.set(new Uint8Array(P)), b !== 0) for (var N = P.byteLength; N < F; N++) D[N] = b; return D.buffer; } return P; } var I = null; class T { constructor() { this.plugins = [], this.options = {}, this.pending = [], this.buffers = [], this.byteOffset = 0, this.buffers = [], this.nodeMap = /* @__PURE__ */ new Map(), this.skins = [], this.extensionsUsed = {}, this.uids = /* @__PURE__ */ new Map(), this.uid = 0, this.json = { asset: { version: "2.0", generator: "THREE.GLTFExporter" } }, this.cache = { meshes: /* @__PURE__ */ new Map(), attributes: /* @__PURE__ */ new Map(), attributesNormalized: /* @__PURE__ */ new Map(), materials: /* @__PURE__ */ new Map(), textures: /* @__PURE__ */ new Map(), images: /* @__PURE__ */ new Map() }; } setPlugins(b) { this.plugins = b; } /** * Parse scenes and generate GLTF output * @param {Scene or [THREE.Scenes]} input Scene or Array of THREE.Scenes * @param {Function} onDone Callback on completed * @param {Object} options options */ write(b, F, D) { this.options = Object.assign({}, { // default options binary: false, trs: false, onlyVisible: true, truncateDrawRange: true, embedImages: true, maxTextureSize: 1 / 0, animations: [], includeCustomExtensions: false }, D), 0 < this.options.animations.length && (this.options.trs = true), this.processInput(b); var N = this; Promise.all(this.pending).then(function() { var B = N.buffers, U = N.json, G = N.options, Y = N.extensionsUsed, te = new Blob(B, { type: "application/octet-stream" }), ae = Object.keys(Y); if (0 < ae.length && (U.extensionsUsed = ae), U.buffers && 0 < U.buffers.length && (U.buffers[0].byteLength = te.size), G.binary === true) { var ie = new window.FileReader(); ie.readAsArrayBuffer(te), ie.onloadend = function() { var W = S(ie.result), $ = new DataView(new ArrayBuffer(v)); $.setUint32(0, W.byteLength, true), $.setUint32(4, x, true); var j = S(A(JSON.stringify(U)), 32), re = new DataView(new ArrayBuffer(v)); re.setUint32(0, j.byteLength, true), re.setUint32(4, m, true); var V = new ArrayBuffer(p), H = new DataView(V); H.setUint32(0, u, true), H.setUint32(4, y, true); var K = p + re.byteLength + j.byteLength + $.byteLength + W.byteLength; H.setUint32(8, K, true); var ce = new Blob([V, re, j, $, W], { type: "application/octet-stream" }), se = new window.FileReader(); se.readAsArrayBuffer(ce), se.onloadend = function() { F(se.result); }; }; } else if (U.buffers && 0 < U.buffers.length) { var le = new window.FileReader(); le.readAsDataURL(te), le.onloadend = function() { var W = le.result; U.buffers[0].uri = W, F(U); }; } else F(U); }); } /** * Serializes a userData. * * @param {THREE.Object3D|THREE.Material} object * @param {Object} objectDef */ serializeUserData(b, F) { if (!(b.userData && b.userData.isZincObject) && Object.keys(b.userData).length !== 0) { var D = this.options, N = this.extensionsUsed; try { var B = JSON.parse(JSON.stringify(b.userData)); if (D.includeCustomExtensions && B.gltfExtensions) { for (var U in F.extensions === void 0 && (F.extensions = {}), B.gltfExtensions) F.extensions[U] = B.gltfExtensions[U], N[U] = true; delete B.gltfExtensions; } 0 < Object.keys(B).length && (F.extras = B); } catch (G) { console.warn("THREE.GLTFExporter: userData of '" + b.name + "' won't be serialized because of JSON.stringify error - " + G.message); } } } /** * Assign and return a temporal unique id for an object * especially which doesn't have .uuid * @param {Object} object * @return {Integer} */ getUID(b) { return this.uids.has(b) || this.uids.set(b, this.uid++), this.uids.get(b); } /** * Checks if normal attribute values are normalized. * * @param {BufferAttribute} normal * @returns {Boolean} */ isNormalizedNormalAttribute(b) { var F = this.cache; if (F.attributesNormalized.has(b)) return false; for (var D = new l.Vector3(), N = 0, B = b.count; N < B; N++) if (5e-4 < Math.abs(D.fromBufferAttribute(b, N).length() - 1)) return false; return true; } /** * Creates normalized normal buffer attribute. * * @param {BufferAttribute} normal * @returns {BufferAttribute} * */ createNormalizedNormalAttribute(b) { var F = this.cache; if (F.attributesNormalized.has(b)) return F.attributesNormalized.get(b); for (var D = b.clone(), N = new l.Vector3(), B = 0, U = D.count; B < U; B++) N.fromBufferAttribute(D, B), N.x === 0 && N.y === 0 && N.z === 0 ? N.setX(1) : N.normalize(), D.setXYZ(B, N.x, N.y, N.z); return F.attributesNormalized.set(b, D), D; } /** * Applies a texture transform, if present, to the map definition. Requires * the KHR_texture_transform extension. * * @param {Object} mapDef * @param {THREE.Texture} texture */ applyTextureTransform(b, F) { var D = false, N = {}; (F.offset.x !== 0 || F.offset.y !== 0) && (N.offset = F.offset.toArray(), D = true), F.rotation !== 0 && (N.rotation = F.rotation, D = true), (F.repeat.x !== 1 || F.repeat.y !== 1) && (N.scale = F.repeat.toArray(), D = true), D && (b.extensions = b.extensions || {}, b.extensions.KHR_texture_transform = N, this.extensionsUsed.KHR_texture_transform = true); } /** * Process a buffer to append to the default one. * @param {ArrayBuffer} buffer * @return {Integer} */ processBuffer(b) { var F = this.json, D = this.buffers; return F.buffers || (F.buffers = [{ byteLength: 0 }]), D.push(b), 0; } /** * Process and generate a BufferView * @param {BufferAttribute} attribute * @param {number} componentType * @param {number} start * @param {number} count * @param {number} target (Optional) Target usage of the BufferView * @return {Object} */ processBufferView(b, F, D, N, B) { var U = this.json; U.bufferViews || (U.bufferViews = []); for (var G = F === h6.UNSIGNED_BYTE ? 1 : F === h6.UNSIGNED_SHORT ? 2 : 4, Y = L(N * b.itemSize * G), te = new DataView(new ArrayBuffer(Y)), ae = 0, ie = D; ie < D + N; ie++) for (var le, W = 0; W < b.itemSize; W++) le = void 0, 4 < b.itemSize ? le = b.array[ie * b.itemSize + W] : W === 0 ? le = b.getX(ie) : W === 1 ? le = b.getY(ie) : W === 2 ? le = b.getZ(ie) : W == 3 && (le = b.getW(ie)), F === h6.FLOAT ? te.setFloat32(ae, le, true) : F === h6.UNSIGNED_INT ? te.setUint32(ae, le, true) : F === h6.UNSIGNED_SHORT ? te.setUint16(ae, le, true) : F === h6.UNSIGNED_BYTE && te.setUint8(ae, le), ae += G; var $ = { buffer: this.processBuffer(te.buffer), byteOffset: this.byteOffset, byteLength: Y }; B !== void 0 && ($.target = B), B === h6.ARRAY_BUFFER && ($.byteStride = b.itemSize * G), this.byteOffset += Y, U.bufferViews.push($); var j = { id: U.bufferViews.length - 1, byteLength: 0 }; return j; } /** * Process and generate a BufferView from an image Blob. * @param {Blob} blob * @return {Promise} */ processBufferViewImage(b) { var F = this, D = F.json; return D.bufferViews || (D.bufferViews = []), new Promise(function(N) { var B = new window.FileReader(); B.readAsArrayBuffer(b), B.onloadend = function() { var U = S(B.result), G = { buffer: F.processBuffer(U), byteOffset: F.byteOffset, byteLength: U.byteLength }; F.byteOffset += U.byteLength, N(D.bufferViews.push(G) - 1); }; }); } /** * Process attribute to generate an accessor * @param {BufferAttribute} attribute Attribute to process * @param {THREE.BufferGeometry} geometry (Optional) Geometry used for truncated draw range * @param {Integer} start (Optional) * @param {Integer} count (Optional) * @return {Integer|null} Index of the processed accessor on the "accessors" array */ processAccessor(b, F, D, N) { var B, U = this.options, G = this.json; if (b.array.constructor === Float32Array) B = h6.FLOAT; else if (b.array.constructor === Uint32Array) B = h6.UNSIGNED_INT; else if (b.array.constructor === Uint16Array) B = h6.UNSIGNED_SHORT; else if (b.array.constructor === Uint8Array) B = h6.UNSIGNED_BYTE; else throw new Error("THREE.GLTFExporter: Unsupported bufferAttribute component type."); if (D === void 0 && (D = 0), N === void 0 && (N = b.count), U.truncateDrawRange && F !== void 0 && F.index === null) { var Y = D + N, te = F.drawRange.count === 1 / 0 ? b.count : F.drawRange.start + F.drawRange.count; D = Math.max(D, F.drawRange.start), N = Math.min(Y, te) - D, 0 > N && (N = 0); } if (N === 0) return null; var ae, ie = R(b, D, N); F !== void 0 && (ae = b === F.index ? h6.ELEMENT_ARRAY_BUFFER : h6.ARRAY_BUFFER); var le = this.processBufferView(b, B, D, N, ae), W = { bufferView: le.id, byteOffset: le.byteOffset, componentType: B, count: N, max: ie.max, min: ie.min, type: { 1: "SCALAR", 2: "VEC2", 3: "VEC3", 4: "VEC4", 16: "MAT4" }[b.itemSize] }; return b.normalized === true && (W.normalized = true), G.accessors || (G.accessors = []), G.accessors.push(W) - 1; } /** * Process image * @param {Image} image to process * @param {Integer} format of the image (e.g. RGBFormat, RGBAFormat etc) * @param {Boolean} flipY before writing out the image * @return {Integer} Index of the processed texture in the "images" array */ processImage(b, F, D) { var N = this, B = N.cache, U = N.json, G = N.options, Y = N.pending; B.images.has(b) || B.images.set(b, {}); var te = B.images.get(b), ae = F === l.RGBAFormat ? "image/png" : "image/jpeg", ie = ae + ":flipY/" + D.toString(); if (te[ie] !== void 0) return te[ie]; U.images || (U.images = []); var le = { mimeType: ae }; if (G.embedImages) { var W = I = I || document.createElement("canvas"); W.width = Math.min(b.width, G.maxTextureSize), W.height = Math.min(b.height, G.maxTextureSize); var $ = W.getContext("2d"); if (D === true && ($.translate(0, W.height), $.scale(1, -1)), typeof HTMLImageElement < "u" && b instanceof HTMLImageElement || typeof HTMLCanvasElement < "u" && b instanceof HTMLCanvasElement || typeof OffscreenCanvas < "u" && b instanceof OffscreenCanvas || typeof ImageBitmap < "u" && b instanceof ImageBitmap) $.drawImage(b, 0, 0, W.width, W.height); else { F !== l.RGBAFormat && F !== l.RGBFormat && console.error("GLTFExporter: Only RGB and RGBA formats are supported."), (b.width > G.maxTextureSize || b.height > G.maxTextureSize) && console.warn("GLTFExporter: Image size is bigger than maxTextureSize", b); var j = new Uint8ClampedArray(4 * (b.height * b.width)); if (F === l.RGBAFormat) for (var re = 0; re < j.length; re += 4) j[re + 0] = b.data[re + 0], j[re + 1] = b.data[re + 1], j[re + 2] = b.data[re + 2], j[re + 3] = b.data[re + 3]; else for (var V = 0, H = 0; V < j.length; V += 4, H += 3) j[V + 0] = b.data[H + 0], j[V + 1] = b.data[H + 1], j[V + 2] = b.data[H + 2], j[V + 3] = 255; $.putImageData(new ImageData(j, b.width, b.height), 0, 0); } G.binary === true ? Y.push(new Promise(function(ce) { W.toBlob(function(se) { N.processBufferViewImage(se).then(function(k) { le.bufferView = k, ce(); }); }, ae); })) : le.uri = W.toDataURL(ae); } else le.uri = b.src; var K = U.images.push(le) - 1; return te[ie] = K, K; } /** * Process sampler * @param {Texture} map Texture to process * @return {Integer} Index of the processed texture in the "samplers" array */ processSampler(b) { var F = this.json; F.samplers || (F.samplers = []); var D = { magFilter: f[b.magFilter], minFilter: f[b.minFilter], wrapS: f[b.wrapS], wrapT: f[b.wrapT] }; return F.samplers.push(D) - 1; } /** * Process texture * @param {Texture} map Map to process * @return {Integer} Index of the processed texture in the "textures" array */ processTexture(b) { var F = this.cache, D = this.json; if (F.textures.has(b)) return F.textures.get(b); D.textures || (D.textures = []); var N = { sampler: this.processSampler(b), source: this.processImage(b.image, b.format, b.flipY) }; b.name && (N.name = b.name), this._invokeAll(function(U) { U.writeTexture && U.writeTexture(b, N); }); var B = D.textures.push(N) - 1; return F.textures.set(b, B), B; } /** * Process material * @param {THREE.Material} material Material to process * @return {Integer|null} Index of the processed material in the "materials" array */ processMaterial(b) { var F = this.cache, D = this.json; if (F.materials.has(b)) return F.materials.get(b); if (b.isShaderMaterial) return console.warn("GLTFExporter: THREE.ShaderMaterial not supported."), null; D.materials || (D.materials = []); var N = { pbrMetallicRoughness: {} }; b.isMeshStandardMaterial !== true && b.isMeshBasicMaterial !== true && console.warn("GLTFExporter: Use MeshStandardMaterial or MeshBasicMaterial for best results."); var B = b.color.toArray().concat([b.opacity]); if (w(B, [1, 1, 1, 1]) || (N.pbrMetallicRoughness.baseColorFactor = B), b.isMeshStandardMaterial ? (N.pbrMetallicRoughness.metallicFactor = b.metalness, N.pbrMetallicRoughness.roughnessFactor = b.roughness) : (N.pbrMetallicRoughness.metallicFactor = 0.5, N.pbrMetallicRoughness.roughnessFactor = 0.5), b.metalnessMap || b.roughnessMap) if (b.metalnessMap === b.roughnessMap) { var U = { index: this.processTexture(b.metalnessMap) }; this.applyTextureTransform(U, b.metalnessMap), N.pbrMetallicRoughness.metallicRoughnessTexture = U; } else console.warn("THREE.GLTFExporter: Ignoring metalnessMap and roughnessMap because they are not the same Texture."); if (b.map) { var G = { index: this.processTexture(b.map) }; this.applyTextureTransform(G, b.map), N.pbrMetallicRoughness.baseColorTexture = G; } if (b.emissive) { var Y = b.emissive.clone().multiplyScalar(b.emissiveIntensity), te = Math.max(Y.r, Y.g, Y.b); if (1 < te && (Y.multiplyScalar(1 / te), console.warn("THREE.GLTFExporter: Some emissive components exceed 1; emissive has been limited")), 0 < te && (N.emissiveFactor = Y.toArray()), b.emissiveMap) { var ae = { index: this.processTexture(b.emissiveMap) }; this.applyTextureTransform(ae, b.emissiveMap), N.emissiveTexture = ae; } } if (b.normalMap) { var ie = { index: this.processTexture(b.normalMap) }; b.normalScale && b.normalScale.x !== -1 && (b.normalScale.x !== b.normalScale.y && console.warn("THREE.GLTFExporter: Normal scale components are different, ignoring Y and exporting X."), ie.scale = b.normalScale.x), this.applyTextureTransform(ie, b.normalMap), N.normalTexture = ie; } if (b.aoMap) { var le = { index: this.processTexture(b.aoMap), texCoord: 1 }; b.aoMapIntensity !== 1 && (le.strength = b.aoMapIntensity), this.applyTextureTransform(le, b.aoMap), N.occlusionTexture = le; } b.transparent ? N.alphaMode = "BLEND" : 0 < b.alphaTest && (N.alphaMode = "MASK", N.alphaCutoff = b.alphaTest), b.side === l.DoubleSide && (N.doubleSided = true), b.name !== "" && (N.name = b.name), this.serializeUserData(b, N), this._invokeAll(function($) { $.writeMaterial && $.writeMaterial(b, N); }); var W = D.materials.push(N) - 1; return F.materials.set(b, W), W; } /** * Process mesh * @param {THREE.Mesh} mesh Mesh to process * @return {Integer|null} Index of the processed mesh in the "meshes" array */ processMesh(b) { var F = this.cache, D = this.json, N = [b.geometry.uuid]; if (Array.isArray(b.material)) for (var B = 0, U = b.material.length; B < U; B++) N.push(b.material[B].uuid); else N.push(b.material.uuid); var G = N.join(":"); if (F.meshes.has(G)) return F.meshes.get(G); var Y, te = b.geometry; if (Y = b.isLineSegments ? h6.LINES : b.isLineLoop ? h6.LINE_LOOP : b.isLine ? h6.LINE_STRIP : b.isPoints ? h6.POINTS : b.material.wireframe ? h6.LINES : h6.TRIANGLES, te.isBufferGeometry !== true) throw new Error("THREE.GLTFExporter: Geometry is not of type THREE.BufferGeometry."); var ae = {}, ie = {}, le = [], W = [], $ = { uv: "TEXCOORD_0", uv2: "TEXCOORD_1", color: "COLOR_0", skinWeight: "WEIGHTS_0", skinIndex: "JOINTS_0" }, j = te.getAttribute("normal"); j === void 0 || this.isNormalizedNormalAttribute(j) || (console.warn("THREE.GLTFExporter: Creating normalized normal attribute from the non-normalized one."), te.setAttribute("normal", this.createNormalizedNormalAttribute(j))); var re = null; for (var V in te.attributes) if (V.substr(0, 5) !== "morph") { var H = te.attributes[V]; V = $[V] || V.toUpperCase(); var K = /^(POSITION|NORMAL|TANGENT|TEXCOORD_\d+|COLOR_\d+|JOINTS_\d+|WEIGHTS_\d+)$/; if (K.test(V) || (V = "_" + V), F.attributes.has(this.getUID(H))) { ie[V] = F.attributes.get(this.getUID(H)); continue; } re = null; var ce = H.array; V !== "JOINTS_0" || ce instanceof Uint16Array || ce instanceof Uint8Array || (console.warn('GLTFExporter: Attribute "skinIndex" converted to type UNSIGNED_SHORT.'), re = new l.BufferAttribute(new Uint16Array(ce), H.itemSize, H.normalized)); var se = this.processAccessor(re || H, te); se !== null && (ie[V] = se, F.attributes.set(this.getUID(H), se)); } if (j !== void 0 && te.setAttribute("normal", j), Object.keys(ie).length === 0) return null; if (b.morphTargetInfluences !== void 0 && 0 < b.morphTargetInfluences.length) { var k = [], O = [], Z = {}; if (b.morphTargetDictionary !== void 0) for (var X in b.morphTargetDictionary) Z[b.morphTargetDictionary[X]] = X; for (var ee = 0; ee < b.morphTargetInfluences.length; ++ee) { var fe = {}, be = false; for (var Ae in te.morphAttributes) { if (Ae != "position" && Ae !== "normal" && Ae !== "color") { be || (console.warn("GLTFExporter: Only POSITION and NORMAL morph are supported."), be = true); continue; } var he = te.morphAttributes[Ae][ee], xe = Ae.toUpperCase(); $[Ae] && (xe = $[Ae]); var ne = te.attributes[Ae]; if (F.attributes.has(this.getUID(he))) { fe[xe] = F.attributes.get(this.getUID(he)); continue; } var me = ne.clone(); if (!te.morphTargetsRelative) if (ne) for (var Me = 0, De = he.count; Me < De; Me++) ne.count > Me && me.setXYZ(Me, he.getX(Me) - ne.getX(Me), he.getY(Me) - ne.getY(Me), he.getZ(Me) - ne.getZ(Me)); else for (var Ie = 0, $e = he.count; Ie < $e; Ie++) me.setXYZ(Ie, 0, 0, 0); fe[xe] = this.processAccessor(me, te), F.attributes.set(this.getUID(ne), fe[xe]); } W.push(fe), k.push(b.morphTargetInfluences[ee]), b.morphTargetDictionary !== void 0 && O.push(Z[ee]); } ae.weights = k, 0 < O.length && (ae.extras = {}, ae.extras.targetNames = O); } var lt = Array.isArray(b.material); if (lt && te.groups.length === 0) return null; for (var qe, Mt = lt ? b.material : [b.material], Be = lt ? te.groups : [{ materialIndex: 0, start: void 0, count: void 0 }], it = 0, tt = Be.length; it < tt; it++) { if (qe = { mode: Y, attributes: ie }, this.serializeUserData(te, qe), 0 < W.length && (qe.targets = W), te.index !== null) { var qt = this.getUID(te.index); (Be[it].start !== void 0 || Be[it].count !== void 0) && (qt += ":" + Be[it].start + ":" + Be[it].count), F.attributes.has(qt) ? qe.indices = F.attributes.get(qt) : (qe.indices = this.processAccessor(te.index, te, Be[it].start, Be[it].count), F.attributes.set(qt, qe.indices)), qe.indices === null && delete qe.indices; } var Qt = this.processMaterial(Mt[Be[it].materialIndex]); Qt !== null && (qe.material = Qt), le.push(qe); } ae.primitives = le, D.meshes || (D.meshes = []), this._invokeAll(function(Nt) { Nt.writeMesh && Nt.writeMesh(b, ae); }); var Ft = D.meshes.push(ae) - 1; return F.meshes.set(G, Ft), Ft; } /** * Process camera * @param {THREE.Camera} camera Camera to process * @return {Integer} Index of the processed mesh in the "camera" array */ processCamera(b) { var F = this.json; F.cameras || (F.cameras = []); var D = b.isOrthographicCamera, N = { type: D ? "orthographic" : "perspective" }; return D ? N.orthographic = { xmag: 2 * b.right, ymag: 2 * b.top, zfar: 0 >= b.far ? 1e-3 : b.far, znear: 0 > b.near ? 0 : b.near } : N.perspective = { aspectRatio: b.aspect, yfov: l.MathUtils.degToRad(b.fov), zfar: 0 >= b.far ? 1e-3 : b.far, znear: 0 > b.near ? 0 : b.near }, b.name !== "" && (N.name = b.type), F.cameras.push(N) - 1; } /** * Creates glTF animation entry from AnimationClip object. * * Status: * - Only properties listed in PATH_PROPERTIES may be animated. * * @param {THREE.AnimationClip} clip * @param {THREE.Object3D} root * @return {number|null} */ processAnimation(b, F) { var D = this.json, N = this.nodeMap; D.animations || (D.animations = []), b = d.Utils.mergeMorphTargetTracks(b.clone(), F); for (var B = b.tracks, U = [], G = [], Y = 0; Y < B.length; ++Y) { var te = B[Y], ae = l.PropertyBinding.parseTrackName(te.name), ie = l.PropertyBinding.findNode(F, ae.nodeName), le = g[ae.propertyName]; if (ae.objectName === "bones" && (ie.isSkinnedMesh === true ? ie = ie.skeleton.getBoneByName(ae.objectIndex) : ie = void 0), !ie || !le) return console.warn('THREE.GLTFExporter: Could not export animation track "%s".', te.name), null; var W = 1, $ = te.values.length / te.times.length; le === g.morphTargetInfluences && ($ /= ie.morphTargetInfluences.length); var j = void 0; te.createInterpolant.isInterpolantFactoryMethodGLTFCubicSpline === true ? (j = "CUBICSPLINE", $ /= 3) : te.getInterpolation() === l.InterpolateDiscrete ? j = "STEP" : j = "LINEAR", G.push({ input: this.processAccessor(new l.BufferAttribute(te.times, W)), output: this.processAccessor(new l.BufferAttribute(te.values, $)), interpolation: j }), U.push({ sampler: G.length - 1, target: { node: N.get(ie), path: le } }); } return D.animations.push({ name: b.name || "clip_" + D.animations.length, samplers: G, channels: U }), D.animations.length - 1; } /** * @param {THREE.Object3D} object * @return {number|null} */ processSkin(b) { var F = this.json, D = this.nodeMap, N = F.nodes[D.get(b)], B = b.skeleton; if (B === void 0) return null; var U = b.skeleton.bones[0]; if (U === void 0) return null; for (var G = [], Y = new Float32Array(16 * B.bones.length), te = new l.Matrix4(), ae = 0; ae < B.bones.length; ++ae) G.push(D.get(B.bones[ae])), te.copy(B.boneInverses[ae]), te.multiply(b.bindMatrix).toArray(Y, 16 * ae); F.skins === void 0 && (F.skins = []), F.skins.push({ inverseBindMatrices: this.processAccessor(new l.BufferAttribute(Y, 16)), joints: G, skeleton: D.get(U) }); var ie = N.skin = F.skins.length - 1; return ie; } /** * Process Object3D node * @param {THREE.Object3D} node Object3D to processNode * @return {Integer} Index of the node in the nodes list */ processNode(b) { var F = this.json, D = this.options, N = this.nodeMap; F.nodes || (F.nodes = []); var B = {}; if (D.trs) { var U = b.quaternion.toArray(), G = b.position.toArray(), Y = b.scale.toArray(); w(U, [0, 0, 0, 1]) || (B.rotation = U), w(G, [0, 0, 0]) || (B.translation = G), w(Y, [1, 1, 1]) || (B.scale = Y); } else b.matrixAutoUpdate && b.updateMatrix(), M(b.matrix) === false && (B.matrix = b.matrix.elements); if (b.name !== "" && (B.name = b.name + ""), this.serializeUserData(b, B), b.isMesh || b.isLine || b.isPoints) { var te = this.processMesh(b); te !== null && (B.mesh = te); } else b.isCamera && (B.camera = this.processCamera(b)); if (b.isSkinnedMesh && this.skins.push(b), 0 < b.children.length) { for (var ae, ie = [], le = 0, W = b.children.length; le < W; le++) if (ae = b.children[le], ae.visible || D.onlyVisible === false) { var $ = this.processNode(ae); $ !== null && ie.push($); } 0 < ie.length && (B.children = ie); } this._invokeAll(function(re) { re.writeNode && re.writeNode(b, B); }); var j = F.nodes.push(B) - 1; return N.set(b, j), j; } /** * Process Scene * @param {Scene} node Scene to process */ processScene(b) { var F = this.json, D = this.options; F.scenes || (F.scenes = [], F.scene = 0); var N = {}; b.name !== "" && (N.name = b.name), F.scenes.push(N); for (var B, U = [], G = 0, Y = b.children.length; G < Y; G++) if (B = b.children[G], B.visible || D.onlyVisible === false) { var te = this.processNode(B); te !== null && U.push(te); } 0 < U.length && (N.nodes = U), this.serializeUserData(b, N); } /** * Creates a Scene to hold a list of objects and parse it * @param {Array} objects List of objects to process */ processObjects(b) { var F = new l.Scene(); F.name = "AuxScene"; for (var D = 0; D < b.length; D++) F.children.push(b[D]); this.processScene(F); } /** * @param {THREE.Object3D|Array} input */ processInput(b) { var F = this.options; b = b instanceof Array ? b : [b], this._invokeAll(function(G) { G.beforeParse && G.beforeParse(b); }); for (var D = [], N = 0; N < b.length; N++) b[N] instanceof l.Scene ? this.processScene(b[N]) : D.push(b[N]); 0 < D.length && this.processObjects(D); for (var B = 0; B < this.skins.length; ++B) this.processSkin(this.skins[B]); for (var U = 0; U < F.animations.length; ++U) this.processAnimation(F.animations[U].clip, F.animations[U].mesh); this._invokeAll(function(G) { G.afterParse && G.afterParse(b); }); } _invokeAll(b) { for (var F = 0, D = this.plugins.length; F < D; F++) b(this.plugins[F]); } } class _ { constructor(b) { this.writer = b, this.name = "KHR_lights_punctual"; } writeNode(b, F) { if (b.isLight) { if (!b.isDirectionalLight && !b.isPointLight && !b.isSpotLight) return void console.warn("THREE.GLTFExporter: Only directional, point, and spot lights are supported.", b); var D = this.writer, N = D.json, B = D.extensionsUsed, U = {}; b.name && (U.name = b.name), U.color = b.color.toArray(), U.intensity = b.intensity, b.isDirectionalLight ? U.type = "directional" : b.isPointLight ? (U.type = "point", 0 < b.distance && (U.range = b.distance)) : b.isSpotLight && (U.type = "spot", 0 < b.distance && (U.range = b.distance), U.spot = {}, U.spot.innerConeAngle = -1 * ((b.penumbra - 1) * b.angle), U.spot.outerConeAngle = b.angle), b.decay !== void 0 && b.decay !== 2 && console.warn("THREE.GLTFExporter: Light decay may be lost. glTF is physically-based, and expects light.decay=2."), b.target && (b.target.parent !== b || b.target.position.x !== 0 || b.target.position.y !== 0 || b.target.position.z !== -1) && console.warn("THREE.GLTFExporter: Light direction may be lost. For best results, make light.target a child of the light with position 0,0,-1."), B[this.name] || (N.extensions = N.extensions || {}, N.extensions[this.name] = { lights: [] }, B[this.name] = true); var G = N.extensions[this.name].lights; G.push(U), F.extensions = F.extensions || {}, F.extensions[this.name] = { light: G.length - 1 }; } } } class E { constructor(b) { this.writer = b, this.name = "KHR_materials_unlit"; } writeMaterial(b, F) { if (b.isMeshBasicMaterial) { var D = this.writer, N = D.extensionsUsed; F.extensions = F.extensions || {}, F.extensions[this.name] = {}, N[this.name] = true, F.pbrMetallicRoughness.metallicFactor = 0, F.pbrMetallicRoughness.roughnessFactor = 0.9; } } } class C { constructor(b) { this.writer = b, this.name = "KHR_materials_pbrSpecularGlossiness"; } writeMaterial(b, F) { if (b.isGLTFSpecularGlossinessMaterial) { var D = this.writer, N = D.extensionsUsed, B = {}; F.pbrMetallicRoughness.baseColorFactor && (B.diffuseFactor = F.pbrMetallicRoughness.baseColorFactor); var U = [1, 1, 1]; if (b.specular.toArray(U, 0), B.specularFactor = U, B.glossinessFactor = b.glossiness, F.pbrMetallicRoughness.baseColorTexture && (B.diffuseTexture = F.pbrMetallicRoughness.baseColorTexture), b.specularMap) { var G = { index: D.processTexture(b.specularMap) }; D.applyTextureTransform(G, b.specularMap), B.specularGlossinessTexture = G; } F.extensions = F.extensions || {}, F.extensions[this.name] = B, N[this.name] = true; } } } d.Utils = { insertKeyframe: function(b, F) { var D, N = 1e-3, B = b.getValueSize(), U = new b.TimeBufferType(b.times.length + 1), G = new b.ValueBufferType(b.values.length + B), Y = b.createInterpolant(new b.ValueBufferType(B)); if (b.times.length === 0) { U[0] = F; for (var te = 0; te < B; te++) G[te] = 0; D = 0; } else if (F < b.times[0]) { if (Math.abs(b.times[0] - F) < N) return 0; U[0] = F, U.set(b.times, 1), G.set(Y.evaluate(F), 0), G.set(b.values, B), D = 0; } else if (F > b.times[b.times.length - 1]) { if (Math.abs(b.times[b.times.length - 1] - F) < N) return b.times.length - 1; U[U.length - 1] = F, U.set(b.times, 0), G.set(b.values, 0), G.set(Y.evaluate(F), b.values.length), D = U.length - 1; } else for (var ae = 0; ae < b.times.length; ae++) { if (Math.abs(b.times[ae] - F) < N) return ae; if (b.times[ae] < F && b.times[ae + 1] > F) { U.set(b.times.slice(0, ae + 1), 0), U[ae + 1] = F, U.set(b.times.slice(ae + 1), ae + 2), G.set(b.values.slice(0, (ae + 1) * B), 0), G.set(Y.evaluate(F), (ae + 1) * B), G.set(b.values.slice((ae + 1) * B), (ae + 2) * B), D = ae + 1; break; } } return b.times = U, b.values = G, D; }, mergeMorphTargetTracks: function(b, F) { for (var D = [], N = {}, B = b.tracks, U = 0; U < B.length; ++U) { var G = B[U], Y = l.PropertyBinding.parseTrackName(G.name), te = l.PropertyBinding.findNode(F, Y.nodeName); if (Y.propertyName !== "morphTargetInfluences" || Y.propertyIndex === void 0) { D.push(G); continue; } if (G.createInterpolant !== G.InterpolantFactoryMethodDiscrete && G.createInterpolant !== G.InterpolantFactoryMethodLinear) { if (G.createInterpolant.isInterpolantFactoryMethodGLTFCubicSpline) throw new Error("THREE.GLTFExporter: Cannot merge tracks with glTF CUBICSPLINE interpolation."); console.warn("THREE.GLTFExporter: Morph target interpolation mode not yet supported. Using LINEAR instead."), G = G.clone(), G.setInterpolation(l.InterpolateLinear); } var ae = te.morphTargetInfluences.length, ie = te.morphTargetDictionary[Y.propertyIndex]; if (ie === void 0) throw new Error("THREE.GLTFExporter: Morph target name not found: " + Y.propertyIndex); var le = void 0; if (N[te.uuid] === void 0) { le = G.clone(); for (var W = new le.ValueBufferType(ae * le.times.length), $ = 0; $ < le.times.length; $++) W[$ * ae + ie] = le.values[$]; le.name = (Y.nodeName || "") + ".morphTargetInfluences", le.values = W, N[te.uuid] = le, D.push(le); continue; } var j = G.createInterpolant(new G.ValueBufferType(1)); le = N[te.uuid]; for (var re = 0; re < le.times.length; re++) le.values[re * ae + ie] = j.evaluate(le.times[re]); for (var V, H = 0; H < G.times.length; H++) V = this.insertKeyframe(le, G.times[H]), le.values[V * ae + ie] = G.values[H]; } return b.tracks = D, b; } }; }, /* 44 */ /***/ (o, a, c) => { var l = c(4), d = c(5).resolveURL, h6 = function() { this.nearPlane = 0.168248, this.farPlane = 6.82906, this.eyePosition = [0.5, -2.86496, 0.5], this.targetPosition = [0.5, 0.5, 0.5], this.upVector = [0, 0, 1]; var A = this; this.setFromObject = (M) => { var { nearPlane: R, farPlane: L, eyePosition: S, targetPosition: I, upVector: T } = M; A.nearPlane = R, A.farPlane = L, A.eyePosition = S, A.targetPosition = I, A.upVector = T; }; }, f = function(A, M, R, L) { var S = { NONE: -1, DEFAULT: 0, PATH: 1, SMOOTH_CAMERA_TRANSITION: 2, AUTO_TUMBLE: 3, ROTATE_TRANSITION: 4, MINIMAP: 5, SYNC_CONTROL: 6 }, I = { NONE: -1, ROTATE: 0, ZOOM: 1, PAN: 2, TOUCH_ROTATE: 3, TOUCH_ZOOM: 4, TOUCH_PAN: 5, SCROLL: 6, KEYBOARD_ZOOM: 7, KEYBOARD_ROTATE: 8, KEYBOARD_PAN: 9 }, T = { NONE: -1, FREE: 1, HORIZONTAL: 2, VERTICAL: 3 }, _ = { ARROWLEFT: 37, ARROWUP: 38, ARROWRIGHT: 39, ARROWDOWN: 40, NUMPADADD: 107, NUMPADSUBTRACT: 109, EQUAL: 187, MINUS: 189 }, E = {}; E.MAIN = I.ROTATE, E.AUXILIARY = I.ZOOM, E.SECONDARY = I.PAN, this.cameraObject = A, this.domElement = M === void 0 ? document : M, this.renderer = R, this.scene = L, this.tumble_rate = 1.5, this.pointer_x = 0, this.pointer_y = 0, this.pointer_x_start = 0, this.pointer_y_start = 0, this.previous_pointer_x = 0, this.previous_pointer_y = 0, this.near_plane_fly_debt = 0, this.touchZoomDistanceStart = 0, this.touchZoomDistanceEnd = 0, this.directionalLight = 0, this.zoomRate = 50, this.rotateRate = 50, this.panRate = 100, this.pixelHeight = 1; var C = 6e3, P = true, b = 0, F = void 0, D = void 0, N = false, B = 500, U = void 0, G = "default", Y = S.DEFAULT, te = void 0, ae = void 0, ie = void 0, le = 0, W = T.FREE; this._state = I.NONE; var $; this.targetTouchId = -1; var j = void 0, re = new l.Vector3(), V = new l.Vector3(), H = new l.Vector3(), K = new l.Vector3(), ce = new l.Vector3(), se = new l.Vector3(), k = new l.Vector3(), O = new l.Vector3(), Z = new l.Sphere(), X = new l.Vector3(), ee = false, fe = void 0, be = 0, Ae = { default: new h6() }; Ae.default.nearPlane = 0.1, Ae.default.farPlane = 2e3, Ae.default.eyePosition = [0, 0, 0], Ae.default.targetPosition = [0, 0, -1], Ae.default.upVector = [0, 1, 0], this.cameraObject.target === void 0 && (this.cameraObject.target = new l.Vector3(...Ae.default.targetPosition)), this.calculateMaxAllowedDistance = (Q) => { var _e = Q.getBoundingBox(); if (_e) { _e.getBoundingSphere(Z), be = 6 * Z.radius; var Oe = 0; this.cameraObject && (Oe = this.cameraObject.position.distanceTo(Z.center)), be = Oe > be ? 1.5 * Oe : be; } else be = 0; }, this.addViewport = (Q, _e) => { Q && _e && (Ae[Q] = _e); }, this.setDefaultViewport = (Q) => !!(Q && Q in Ae) && (G = Q, true), this.getDefaultViewport = () => G, this.getViewportOfName = (Q) => Ae[Q], this.setCurrentViewport = (Q) => Q in Ae && (this.setCurrentCameraSettings(Ae[Q]), true), this.setRotationMode = (Q) => { switch (Q) { case "none": W = T.NONE; break; case "horizontal": W = T.HORIZONTAL; break; case "vertical": W = T.VERTICAL; break; case "free": default: W = T.FREE; } }, this.onResize = () => { j && (j = void 0), fe && fe.setCurrentCameraSettings(this.cameraObject, Ae[G]); }, this.getVisibleHeightAtZDepth = (Q) => { var _e = this.cameraObject.position.distanceTo(this.cameraObject.target); Q < _e ? Q -= _e : Q += _e; var Oe = this.cameraObject.fov * Math.PI / 180; return 2 * Math.tan(Oe / 2) * Math.abs(Q); }, this.calculateHeightPerPixelAtZeroDepth = (Q) => { var _e = this.getVisibleHeightAtZDepth(0); return this.pixelHeight = _e / Q, this.pixelHeight; }, this.getNDCFromDocumentCoords = (Q, _e, Oe) => { Be(false); var Ze = Oe || new l.Vector2(), ht = 2 * ((Q - j.left) / j.width) - 1, J = 2 * -((_e - j.top) / j.height) + 1; return Ze.set(ht, J); }, this.getRelativeCoordsFromNDC = (Q, _e, Oe) => { Be(false); var Ze = Oe || new l.Vector2(); return Ze.x = (Q + 1) * j.width / 2, Ze.y = (1 - _e) * j.height / 2, Ze; }, this.setMouseButtonAction = (Q, _e) => { E[Q] = I[_e]; }; var he = (Q, _e) => { Q instanceof HTMLCanvasElement && (Q.tabIndex = _e); }, xe = () => { if (0 < be) { var Q = X.distanceTo(Z.center); return be > Q || this.cameraObject.position.distanceTo(Z.center) > Q; } return true; }, ne = (Q) => { X.copy(this.cameraObject.position).add(Q), xe() && (this.cameraObject.target.add(Q), this.cameraObject.position.add(Q), this.updateDirectionalLight()); }, me = (Q) => { Be(false); var _e; if (Y === S.DEFAULT && (_e = this.scene.getNormalisedMinimapCoordinates(this.renderer, Q)), !_e) Q.button == 0 ? Q.ctrlKey ? this._state = E.AUXILIARY : Q.shiftKey ? this._state = E.SECONDARY : this._state = E.MAIN : Q.button == 1 ? (Q.preventDefault(), this._state = E.AUXILIARY) : Q.button == 2 && (this._state = E.SECONDARY), this.pointer_x = Q.clientX - j.left, this.pointer_y = Q.clientY - j.top, this.pointer_x_start = this.pointer_x, this.pointer_y_start = this.pointer_y, this.previous_pointer_x = this.pointer_x, this.previous_pointer_y = this.pointer_y; else { Y = S.MINIMAP; var Oe = this.scene.getMinimapDiffFromNormalised(_e.x, _e.y); ne(Oe); } }, Me = (Q) => { if (Be(false), j) if (this.pointer_x = Q.clientX - j.left, this.pointer_y = Q.clientY - j.top, Y === S.MINIMAP) { var _e = this.scene.getNormalisedMinimapCoordinates(this.renderer, Q); if (_e) { var Oe = this.scene.getMinimapDiffFromNormalised(_e.x, _e.y); ne(Oe); } } else this._state === I.NONE && $ !== void 0 && $.move(this, Q.clientX, Q.clientY, this.renderer); }, De = (Q) => { this._state = I.NONE, Y == S.MINIMAP && (Y = S.DEFAULT), $ !== void 0 && this.pointer_x_start == Q.clientX - j.left && this.pointer_y_start == Q.clientY - j.top && $.pick(this, Q.clientX, Q.clientY, this.renderer); }, Ie = (Q) => { this._state = I.NONE; }, $e = (Q) => { Be(false); var _e = Q.touches.length; if (_e == 1) { var Oe, Ze; this._state = I.TOUCH_ROTATE, this.pointer_x = Q.touches[0].clientX - ((Oe = j) === null || Oe === void 0 ? void 0 : Oe.left), this.pointer_y = Q.touches[0].clientY - ((Ze = j) === null || Ze === void 0 ? void 0 : Ze.top), this.pointer_x_start = this.pointer_x, this.pointer_y_start = this.pointer_y, this.previous_pointer_x = this.pointer_x, this.previous_pointer_y = this.pointer_y; } else if (_e == 2) { this._state = I.TOUCH_ZOOM; var ht = Q.touches[0].clientX - Q.touches[1].clientX, J = Q.touches[0].clientY - Q.touches[1].clientY; this.touchZoomDistanceEnd = this.touchZoomDistanceStart = Math.sqrt(ht * ht + J * J); } else if (_e == 3) { var ye, pe; this._state = I.TOUCH_PAN, this.targetTouchId = Q.touches[0].identifier, this.pointer_x = Q.touches[0].clientX - ((ye = j) === null || ye === void 0 ? void 0 : ye.left), this.pointer_y = Q.touches[0].clientY - ((pe = j) === null || pe === void 0 ? void 0 : pe.top), this.previous_pointer_x = this.pointer_x, this.previous_pointer_y = this.pointer_y; } }, lt = (Q) => { Q.preventDefault(), Q.stopPropagation(); var _e = Q.touches.length; if (_e == 1) this.pointer_x = Q.touches[0].clientX - j.left, this.pointer_y = Q.touches[0].clientY - j.top; else if (_e == 2) { if (this._state === I.TOUCH_ZOOM) { var Oe = Q.touches[0].clientX - Q.touches[1].clientX, Ze = Q.touches[0].clientY - Q.touches[1].clientY; this.touchZoomDistanceEnd = Math.sqrt(Oe * Oe + Ze * Ze); } } else if (_e == 3 && this._state === I.TOUCH_PAN) for (var ht = 0; 3 > ht; ht++) Q.touches[ht].identifier == this.targetTouchId && (this.pointer_x = Q.touches[0].clientX - j.left, this.pointer_y = Q.touches[0].clientY - j.top); }, qe = (Q) => { var _e = Q.touches.length; this.touchZoomDistanceStart = this.touchZoomDistanceEnd = 0, this.targetTouchId = -1, this._state = I.NONE, _e == 1 && $ !== void 0 && this.pointer_x_start == Q.touches[0].clientX - j.left && this.pointer_y_start == Q.touches[0].clientY - j.top && $.pick(this.cameraObject, Q.touches[0].clientX, Q.touches[0].clientY, this.renderer); }, Mt = () => { Be(true); }, Be = (Q) => { if (Q || j === void 0) { var _e = new IntersectionObserver((Oe) => { for (var Ze of Oe) j = Ze.boundingClientRect; _e.disconnect(); }); _e.observe(this.domElement); } }, it = (Q) => { Be(false), this._state = I.SCROLL; var _e = 0; 0 < Q.deltaY ? _e = this.zoomRate : 0 > Q.deltaY && (_e = -1 * this.zoomRate), le += _e, Q.preventDefault(), Q.stopImmediatePropagation(); }, tt = (Q) => { Be(false); var _e = 0; if (Q.keyCode === _.EQUAL || Q.keyCode === _.MINUS || Q.keyCode === _.NUMPADADD || Q.keyCode === _.NUMPADSUBTRACT) { this._state = I.KEYBOARD_ZOOM; var Oe = 1; Q.shiftKey && (Oe *= 2), Q.keyCode === _.EQUAL || Q.keyCode === _.NUMPADADD ? _e = -1 * (this.zoomRate * Oe) : (Q.keyCode === _.MINUS || Q.keyCode === _.NUMPADSUBTRACT) && (_e = this.zoomRate * Oe), le += _e; } else (Q.keyCode === _.ARROWLEFT || Q.keyCode === _.ARROWUP || Q.keyCode === _.ARROWRIGHT || Q.keyCode === _.ARROWDOWN) && (Q.shiftKey ? (this._state = I.KEYBOARD_ROTATE, this.pointer_x_start = this.pointer_x, this.pointer_y_start = this.pointer_y, _e = this.rotateRate) : (this._state = I.KEYBOARD_PAN, _e = this.panRate), this.previous_pointer_x = this.pointer_x, this.previous_pointer_y = this.pointer_y, Q.keyCode === _.ARROWLEFT ? this.pointer_x -= _e : Q.keyCode === _.ARROWUP ? this.pointer_y -= _e : Q.keyCode === _.ARROWRIGHT ? this.pointer_x += _e : Q.keyCode === _.ARROWDOWN && (this.pointer_y += _e)); Object.values(_).includes(Q.keyCode) && Q.preventDefault(); }, qt = (Q) => { this._state = I.NONE; }, Qt = () => { if (typeof this.cameraObject < "u") { var Q = j.height, _e = this.cameraObject.position.distanceTo(this.cameraObject.target), Oe = 0; this.cameraObject.far > this.cameraObject.near && _e >= this.cameraObject.near && _e <= this.cameraObject.far && (Oe = (_e - this.cameraObject.near) / (this.cameraObject.far - this.cameraObject.near)), V.set(this.previous_pointer_x, Q - this.previous_pointer_y, 0), H.set(this.previous_pointer_x, Q - this.previous_pointer_y, 1), K.set(this.pointer_x, Q - this.pointer_y, 0), ce.set(this.pointer_x, Q - this.pointer_y, 1), V.unproject(this.cameraObject), H.unproject(this.cameraObject), K.unproject(this.cameraObject), ce.unproject(this.cameraObject); var Ze = -2e-3; K.sub(V).multiplyScalar(1 - Oe), ce.sub(H).multiplyScalar(Oe), K.add(ce).multiplyScalar(Ze), ne(K); } this.previous_pointer_x = this.pointer_x, this.previous_pointer_y = this.pointer_y; }; this.getVectorsFromRotateAboutLookAtPoints = (Q, _e) => { Q.normalize(), k.copy(this.cameraObject.position).sub(this.cameraObject.target), O.copy(k), k.normalize(), 0.8 < Math.abs(k.dot(Q)) && k.copy(this.cameraObject.up), V.crossVectors(Q, k).normalize(), H.crossVectors(Q, V); var Oe = Q.dot(O), Ze = V.dot(O), ht = H.dot(O), J = Q.dot(this.cameraObject.up), ye = V.dot(this.cameraObject.up), pe = H.dot(this.cameraObject.up), we = Math.cos(_e), Ce = Math.sin(_e); return K.set(we * V.x + Ce * H.x, we * V.y + Ce * H.y, we * V.z + Ce * H.z), ce.set(we * H.x - Ce * V.x, we * H.y - Ce * V.y, we * H.z - Ce * V.z), k.copy(this.cameraObject.target), k.x = k.x + Q.x * Oe + K.x * Ze + ce.x * ht, k.y = k.y + Q.y * Oe + K.y * Ze + ce.y * ht, k.z = k.z + Q.z * Oe + K.z * Ze + ce.z * ht, re.set(Q.x * J + K.x * ye + ce.x * pe, Q.y * J + K.y * ye + ce.y * pe, Q.z * J + K.z * ye + ce.z * pe), { position: k, up: re }; }, this.rotateAboutLookAtpoint = (Q, _e) => { var Oe = this.getVectorsFromRotateAboutLookAtPoints(Q, _e); this.cameraObject.position.copy(Oe.position), this.updateDirectionalLight(), this.cameraObject.up.copy(Oe.up); }; var Ft = () => { if (typeof this.cameraObject < "u") { var Q, _e, Oe = (Q = j) === null || Q === void 0 ? void 0 : Q.width, Ze = (_e = j) === null || _e === void 0 ? void 0 : _e.height; if (0 < Oe && 0 < Ze) { var ht = 0.25 * (Oe + Ze), J = 0, ye = 0; (W === T.FREE || W === T.HORIZONTAL) && (J = this.pointer_x - this.previous_pointer_x), (W === T.FREE || W === T.VERTICAL) && (ye = this.previous_pointer_y - this.pointer_y); var pe = Math.sqrt(J * J + ye * ye); if (0 < pe) { var we = 1 * -ye / pe, Ce = 1 * J / pe, ge = 0; W === T.FREE && we * (this.pointer_x - 0.5 * (Oe - 1)) + Ce * (0.5 * (Ze - 1) - this.pointer_y); var Se = Math.acos(ge / ht) - 0.5 * Math.PI, Fe = this.tumble_rate * pe / ht; re.copy(this.cameraObject.position).sub(this.cameraObject.target).normalize(), V.copy(this.cameraObject.up).normalize(), H.copy(V).cross(re).normalize().multiplyScalar(we), V.multiplyScalar(Ce), se.addVectors(H, V).multiplyScalar(Math.cos(Se)), re.multiplyScalar(Math.sin(Se)), se.add(re), this.rotateAboutLookAtpoint(se, -Fe); } } } this.previous_pointer_x = this.pointer_x, this.previous_pointer_y = this.pointer_y; }, Nt = () => { var Q = 0; return this._state === I.ZOOM ? Q = this.previous_pointer_y - this.pointer_y : this._state === I.SCROLL || this._state === I.KEYBOARD_ZOOM ? Q = le : (Q = -1 * (this.touchZoomDistanceEnd - this.touchZoomDistanceStart), this.touchZoomDistanceStart = this.touchZoomDistanceEnd), Q; }; this.changeZoomByScrollRateUnit = (Q) => { var _e = Q * this.zoomRate; this.changeZoomByValue(_e); }, this.changeZoomByValue = (Q) => { if (typeof this.cameraObject < "u") { var _e = j.height, Oe = this.cameraObject.position.clone(); Oe.sub(this.cameraObject.target); var Ze = Oe.length(), ht = 1.5 * Q / _e; if (0.01 < Ze + ht * Ze && (Oe.normalize(), X.copy(this.cameraObject.position), X.x += Oe.x * ht * Ze, X.y += Oe.y * ht * Ze, X.z += Oe.z * ht * Ze, xe())) { this.cameraObject.position.copy(X), this.updateDirectionalLight(); var J = 1e-5; if (J * this.cameraObject.far < this.cameraObject.near + ht * Ze + this.near_plane_fly_debt) this.near_plane_fly_debt != 0 && (this.near_plane_fly_debt += ht * Ze, 0 < this.near_plane_fly_debt ? (this.cameraObject.near += this.near_plane_fly_debt, this.cameraObject.far += this.near_plane_fly_debt, this.near_plane_fly_debt = 0) : (this.cameraObject.near += ht * Ze, this.cameraObject.far += ht * Ze)); else { if (this.near_plane_fly_debt == 0) { var ye = this.cameraObject.near - J * this.cameraObject.far; this.cameraObject.near = J * this.cameraObject.far, this.cameraObject.far -= ye, this.near_plane_fly_debt -= J * this.cameraObject.far; } this.near_plane_fly_debt += ht * Ze; } ee = true; } } }; var Vi = () => { var Q = Nt(); this.changeZoomByValue(Q), this._state === I.ZOOM && (this.previous_pointer_x = this.pointer_x, this.previous_pointer_y = this.pointer_y), (this._state === I.SCROLL || this._state === I.KEYBOARD_ZOOM) && (le = 0, this._state = I.NONE); }; this.setDirectionalLight = (Q) => { this.directionalLight = Q; }, this.updateDirectionalLight = () => { this.directionalLight != 0 && this.directionalLight.position.set(this.cameraObject.position.x, this.cameraObject.position.y, this.cameraObject.position.z); }, this.enable = function() { P = true, this.domElement && this.domElement.addEventListener && (he(this.domElement, 0), this.domElement.addEventListener("mousedown", me, false), this.domElement.addEventListener("mousemove", Me, false), this.domElement.addEventListener("mouseup", De, false), this.domElement.addEventListener("mouseleave", Ie, false), this.domElement.addEventListener("touchstart", $e, false), this.domElement.addEventListener("touchmove", lt, false), this.domElement.addEventListener("touchend", qe, false), this.domElement.addEventListener("wheel", it, false), this.domElement.addEventListener("mouseenter", Mt, false), this.domElement.addEventListener("contextmenu", (Q) => { Q.preventDefault(); }, false), this.domElement.addEventListener("keydown", tt, false), this.domElement.addEventListener("keyup", qt, false)); }, this.disable = function() { P = false, this.domElement && this.domElement.removeEventListener && (this.domElement.removeEventListener("mousedown", me, false), this.domElement.removeEventListener("mousemove", Me, false), this.domElement.removeEventListener("mouseup", De, false), this.domElement.removeEventListener("mouseleave", Ie, false), this.domElement.removeEventListener("touchstart", $e, false), this.domElement.removeEventListener("touchmove", lt, false), this.domElement.removeEventListener("touchend", qe, false), this.domElement.removeEventListener("wheel", it, false), this.domElement.removeEventListener("mouseenter", Mt, false), this.domElement.removeEventListener("contextmenu", (Q) => { Q.preventDefault(); }, false), this.domElement.removeEventListener("keydown", tt, false), this.domElement.removeEventListener("keyup", qt, false), he(this.domElement, -1)); }, this.loadPath = (Q) => { F = Q.CameraPath, D = Q.NumberOfPoints; }, this.loadPathURL = (Q, _e) => { var Oe = new XMLHttpRequest(); Oe.onreadystatechange = () => { if (Oe.readyState == 4 && Oe.status == 200) { var ht = JSON.parse(Oe.responseText); this.loadPath(ht), _e != null && typeof _e == "function" && _e(); } }; var Ze = d(Q); Oe.open("GET", Ze, true), Oe.send(); }, this.setPathDuration = (Q) => { C = Q, te && te.setDuration(C), ae && ae.setDuration(C); }, this.getPlayRate = () => B, this.setPlayRate = (Q) => { B = Q; }; var ki = (Q) => { var _e = b + Q; _e > C && (_e -= C), b = _e; }; this.getTime = () => b, this.setTime = (Q) => { b = Q > C ? C : 0 > Q ? 0 : Q; }, this.getNumberOfTimeFrame = () => D, this.getCurrentTimeFrame = () => { if (2 < D) { var Q = b / C * (D - 1), _e = Math.floor(Q), Oe = 1 - (Q - _e), Ze = Math.ceil(Q); return _e == Ze ? _e == D - 1 ? [_e - 1, Ze, 0] : [_e, Ze + 1, 1] : [_e, Ze, Oe]; } return D == 1 ? [0, 0, 0] : void 0; }, this.setCurrentTimeFrame = (Q) => { 2 < D && (b = C * Q / (D - 1), 0 > b && (b = 0), b > C && (b = C)); }; var ni = (Q) => { if (Y === S.PATH && (ki(Q), F)) { for (var _e = this.getCurrentTimeFrame(), Oe = _e[0], Ze = _e[1], ht = _e[2], J = [F[3 * Oe], F[3 * Oe + 1], F[3 * Oe + 2]], ye = [F[3 * Ze], F[3 * Ze + 1], F[3 * Ze + 2]], pe = [], we = 0; we < J.length; we++) pe.push(ht * J[we] + (1 - ht) * ye[we]); this.cameraObject.position.set(pe[0], pe[1], pe[2]), this.cameraObject.target.set(ye[0], ye[1], ye[2]), U && this.cameraObject.lookAt(this.cameraObject.target), N && (this.directionalLight.position.set(pe[0], pe[1], pe[2]), this.directionalLight.target.position.set(ye[0], ye[1], ye[2])); } }; this.calculatePathNow = () => { ni(0); }; var ts = () => { this._state === I.ROTATE || this._state === I.TOUCH_ROTATE || this._state === I.KEYBOARD_ROTATE ? Ft() : this._state === I.PAN || this._state === I.TOUCH_PAN || this._state === I.KEYBOARD_PAN ? (Qt(), fe.triggerCallback()) : (this._state === I.ZOOM || this._state === I.TOUCH_ZOOM || this._state === I.SCROLL || this._state === I.KEYBOARD_ZOOM) && (fe.zoom(Nt()), this.previous_pointer_x = this.pointer_x, this.previous_pointer_y = this.pointer_y, (this._state === I.SCROLL || this._state === I.KEYBOARD_ZOOM) && (this._state = I.NONE), le = 0, fe.triggerCallback()); }; this.update = (Q) => { var _e = Q * B, Oe = P, Ze = true; return Y === S.PATH ? ni(_e) : Y === S.SMOOTH_CAMERA_TRANSITION && te ? (te.update(_e), te.isTransitionCompleted() && (Y = S.DEFAULT), Oe = false) : Y === S.ROTATE_CAMERA_TRANSITION && ae ? (ae.update(_e), ae.isTransitionCompleted() && (Y = S.DEFAULT), Oe = false) : Y === S.AUTO_TUMBLE && ie ? ie.update(_e) : Y === S.SYNC_CONTROL && fe ? (ts(), Oe = false) : Ze = false, Oe && (this._state !== I.NONE && (Ze = true), this._state === I.ROTATE || this._state === I.TOUCH_ROTATE || this._state === I.KEYBOARD_ROTATE ? Ft() : this._state === I.PAN || this._state === I.TOUCH_PAN || this._state === I.KEYBOARD_PAN ? Qt() : (this._state === I.ZOOM || this._state === I.TOUCH_ZOOM || this._state === I.SCROLL || this._state === I.KEYBOARD_ZOOM) && Vi(), this._state !== I.NONE && Y === S.AUTO_TUMBLE && ie && ie.stopOnCameraInput, this._state === I.SCROLL && (this._state = I.NONE)), U ? (Ze = true, U.update()) : this.cameraObject.lookAt(this.cameraObject.target), Ze = Ze || ee, ee = false, Ze; }, this.playPath = () => { Y = S.PATH; }, this.stopPath = () => { Y = S.DEFAULT; }, this.isPlayingPath = () => Y === S.PATH, this.enableDirectionalLightUpdateWithPath = (Q) => { N = Q; }, this.enableDeviceOrientation = () => { U || (U = new x(this.cameraObject)); }, this.disableDeviceOrientation = () => { U && (U.dispose(), U = void 0); }, this.isDeviceOrientationEnabled = () => !!U, this.resetView = () => { var Q = Ae[G]; this.cameraObject.near = Q.nearPlane, this.cameraObject.far = Q.farPlane, this.cameraObject.position.set(Q.eyePosition[0], Q.eyePosition[1], Q.eyePosition[2]), this.cameraObject.target.set(Q.targetPosition[0], Q.targetPosition[1], Q.targetPosition[2]), this.cameraObject.up.set(Q.upVector[0], Q.upVector[1], Q.upVector[2]), this.cameraObject.updateProjectionMatrix(), this.updateDirectionalLight(); }, this.setCurrentCameraSettings = (Q) => { Q.nearPlane && (this.cameraObject.near = Q.nearPlane), Q.farPlane && (this.cameraObject.far = Q.farPlane), Q.eyePosition && this.cameraObject.position.set(Q.eyePosition[0], Q.eyePosition[1], Q.eyePosition[2]), Q.targetPosition && this.cameraObject.target.set(Q.targetPosition[0], Q.targetPosition[1], Q.targetPosition[2]), Q.upVector && this.cameraObject.up.set(Q.upVector[0], Q.upVector[1], Q.upVector[2]), this.cameraObject.updateProjectionMatrix(), this.updateDirectionalLight(), ee = true; }, this.getViewportFromCentreAndRadius = (Q, _e, Oe, Ze, ht, J) => { var ye = this.cameraObject.position.x - this.cameraObject.target.x, pe = this.cameraObject.position.y - this.cameraObject.target.y, we = this.cameraObject.position.z - this.cameraObject.target.z, Ce = 1 / Math.sqrt(ye * ye + pe * pe + we * we); ye *= Ce, pe *= Ce, we *= Ce; var ge = [Q, _e, Oe], Se = Ze / Math.tan(ht * Math.PI / 360), Fe = [Q + ye * Se, _e + pe * Se, Oe + we * Se], Ge = Se + J, We = 0, et = 0.95; We = J > et * Se ? (1 - et) * Se : Se - J; var Ye = new h6(); return Ye.nearPlane = We, Ye.farPlane = Ge, Ye.eyePosition = Fe, Ye.targetPosition = ge, Ye.upVector = [this.cameraObject.up.x, this.cameraObject.up.y, this.cameraObject.up.z], Ye; }, this.getViewportFromBoundingBox = (Q, _e) => { var Oe = Q.min.distanceTo(Q.max) / 2 * _e, Ze = (Q.min.x + Q.max.x) / 2, ht = (Q.min.y + Q.max.y) / 2, J = (Q.min.z + Q.max.z) / 2, ye = 4, pe = this.getViewportFromCentreAndRadius(Ze, ht, J, Oe, 40, Oe * ye); return pe; }, this.getCurrentViewport = () => { var Q = new h6(); return Q.nearPlane = this.cameraObject.near, Q.farPlane = this.cameraObject.far, Q.eyePosition[0] = this.cameraObject.position.x, Q.eyePosition[1] = this.cameraObject.position.y, Q.eyePosition[2] = this.cameraObject.position.z, Q.targetPosition[0] = this.cameraObject.target.x, Q.targetPosition[1] = this.cameraObject.target.y, Q.targetPosition[2] = this.cameraObject.target.z, Q.upVector[0] = this.cameraObject.up.x, Q.upVector[1] = this.cameraObject.up.y, Q.upVector[2] = this.cameraObject.up.z, Q; }, this.getDefaultEyePosition = () => eyePosition, this.getDefaultTargetPosition = () => targetPosition, this.cameraTransition = (Q, _e, Oe) => { ae == null && (te = new g(Q, _e, this, Oe)); }, this.rotateCameraTransition = (Q, _e, Oe) => { te == null && (ae = new p(Q, _e, this, Oe)); }, this.enableCameraTransition = () => { te && (Y = S.SMOOTH_CAMERA_TRANSITION), ae && (Y = S.ROTATE_CAMERA_TRANSITION); }, this.pauseCameraTransition = () => { Y = S.DEFAULT; }, this.stopCameraTransition = () => { Y = S.DEFAULT, te = void 0, ae = void 0; }, this.isTransitioningCamera = () => Y === S.SMOOTH_CAMERA_TRANSITION || Y === S.ROTATE_CAMERA_TRANSITION, this.autoTumble = (Q, _e, Oe) => { ie = new y(Q, _e, Oe, this); }, this.enableAutoTumble = () => { Y = S.AUTO_TUMBLE; }, this.stopAutoTumble = () => { Y = S.DEFAULT, ie = void 0; }, this.updateAutoTumble = () => { ie && (ie.requireUpdate = true); }, this.isAutoTumble = () => Y === S.AUTO_TUMBLE, this.enableRaycaster = (Q, _e, Oe) => { $ == null && ($ = new u(Q, this.scene, _e, Oe, this.renderer)); }, this.disableRaycaster = () => { $.disable(), $ = void 0; }, this.isSyncControl = () => currentMpde === S.SYNC_CONTROL, this.enableSyncControl = () => (Y = S.SYNC_CONTROL, fe || (fe = new w()), fe.setCurrentCameraSettings(this.cameraObject, Ae[G]), fe), this.disableSyncControl = () => { Y = S.DEFAULT, this.cameraObject.zoom = 1, this.cameraObject.updateProjectionMatrix(); }, this.enable(); }, g = function(M, R, L, S) { var I = M.eyePosition, T = M.targetPosition, _ = M.upVector, E = R.eyePosition, C = R.targetPosition, P = R.upVector, b = L, F = S, D = 0, N = false; b.near = Math.min(M.nearPlane, R.nearPlane), b.far = Math.max(M.farPlane, R.farPlane), b.cameraObject.up.set(R.upVector[0], R.upVector[1], R.upVector[2]), this.setDuration = (G) => { F = G; }; var B = (G) => { var Y = D + G; Y > F && (Y = F), D = Y; }, U = () => { var G = D / F, Y = [I[0] * (1 - G) + E[0] * G, I[1] * (1 - G) + E[1] * G, I[2] * (1 - G) + E[2] * G], te = [T[0] * (1 - G) + C[0] * G, T[1] * (1 - G) + C[1] * G, T[2] * (1 - G) + C[2] * G]; _[0] * (1 - G) + P[0] * G, _[1] * (1 - G) + P[1] * G, _[2] * (1 - G) + P[2] * G, b.cameraObject.position.set(Y[0], Y[1], Y[2]), b.cameraObject.target.set(te[0], te[1], te[2]); }; this.update = (G) => { this.enabled === false || (B(G), U(), D == F && (N = true)); }, this.isTransitionCompleted = () => N; }, p = function(M, R, L, S) { var I = M, T = R, _ = L, E = S, C = 0, P = false; this.setDuration = (F) => { E = F; }; var b = (F) => { var D = C, N = C + F; N > E && (N = E), C = N; var B = C - D, U = B / E, G = U * T; _.rotateAboutLookAtpoint(I, G); }; this.update = (F) => { this.enabled === false || (b(F), C == E && (P = true)); }, this.isTransitionCompleted = () => P; }, u = function(M, R, L, S, I) { var T = M, _ = R, E = I, C = L, P = S, b = new l.Raycaster(); b.params.Line.threshold = 0.1, b.params.Points.threshold = 1; var F = new l.Vector2(), D = false, N = /* @__PURE__ */ new Date(), B = false, U = 0, G = [], Y = { zincCamera: void 0, x: -1, y: -1 }, te = void 0; this.enable = () => { enable = true; }, this.disable = () => { enable = false; }, this.getIntersectsObject = (le) => { if (_ !== T) { var W = T.getThreeJSScene(); E.render(W, le.cameraObject); } var $ = te || T.getPickableThreeJSObjects(); return G.length = 0, b.intersectObjects($, true, G); }, this.setPickableObjects = (le) => { le === void 0 ? te = void 0 : (te = [], le.forEach((W) => { W.getGroup() && W.getGroup().visible && te.push(W.getGroup()); })); }, this.getIntersectsObjectWithOrigin = (le, W, $) => (b.set(W, $), this.getIntersectsObject(le)), this.getIntersectsObjectWithCamera = (le, W, $) => (le.getNDCFromDocumentCoords(W, $, F), b.setFromCamera(F, le.cameraObject), this.getIntersectsObject(le)), this.pick = (le, W, $) => { if (E && T && le && C) { this.getIntersectsObjectWithCamera(le, W, $); for (var j, re = G.length, V = 0; V < re; V++) if (j = G[V].object ? G[V].object.userData : void 0, j && j.isMarkerCluster && j.visible && j.clusterIsVisible(G[V].object.clusterIndex) && j.zoomToCluster(G[V].object.clusterIndex)) return; C(G, W, $); } }; var ae = (le, W, $) => { if (E && T && le && P) { if (this.getIntersectsObjectWithCamera(le, W, $), N.setTime(Date.now()), G.length === 0) { if (B) return; B = true; } else B = false; P(G, W, $); } }; this.move = (le, W, $) => { E && T && le && P && (T.displayMarkers ? ae(le, W, $) : (Y.zincCamera = le, Y.x = W, Y.y = $, !D && (U = N ? Date.now() - N.getTime() : 250, 250 <= U ? ae(le, W, $) : (D = true, setTimeout(ie(Y), U))))); }; var ie = (le) => function() { D = false, ae(le.zincCamera, le.x, le.y); }; }, y = function(M, R, L, S) { var I = new l.Vector3(), T = -R, _ = S, E = M; this.stopOnCameraInput = L, this.requireUpdate = true; var C = new l.Vector3(), P = new l.Vector3(), b = (F) => { var D = Math.sqrt(F[0] * F[0] + F[1] * F[1]), N = 4 * Math.abs(F[0]), B = 4 * Math.abs(F[1]), U = 0.25 * (N + B), G = -F[1] / D, Y = F[0] / D, te = G * F[0] + Y * -F[1]; te > U ? te = U : te < -U && (te = -U); var ae = Math.acos(te / U) - 0.5 * Math.PI; I.copy(_.cameraObject.position).sub(_.cameraObject.target).normalize(), C.copy(_.cameraObject.up).normalize(), P.crossVectors(C, I).normalize().multiplyScalar(G), C.multiplyScalar(Y), C.add(P).multiplyScalar(Math.cos(ae)), I.multiplyScalar(Math.sin(ae)).add(C); }; this.update = (F) => { this.enabled === false || (this.requireUpdate && (b(E), this.requireUpdate = false), _.rotateAboutLookAtpoint(I, T * F / 1e3)); }; }, v = function() { this.type = "StereoCamera", this.aspect = 1, this.cameraL = new l.PerspectiveCamera(), this.cameraL.layers.enable(1), this.cameraL.matrixAutoUpdate = false, this.cameraR = new l.PerspectiveCamera(), this.cameraR.layers.enable(2), this.cameraR.matrixAutoUpdate = false; }; Object.assign(v.prototype, { update: (() => { var A, M, R, L, S, I, T = new l.Matrix4(), _ = new l.Matrix4(); return function(C) { var P = A !== C.focus || M !== C.fov || R !== C.aspect * this.aspect || L !== C.near || S !== C.far || I !== C.zoom; if (P) { A = C.focus, M = C.fov, R = C.aspect * this.aspect, L = C.near, S = C.far, I = C.zoom; var b, F, D = C.projectionMatrix.clone(), N = 0.064 / 2, B = N * L / A, U = L * Math.tan(0.5 * (l.Math.DEG2RAD * M)) / C.zoom; _.elements[12] = -N, T.elements[12] = N, b = -U * R + B, F = U * R + B, D.elements[0] = 2 * L / (F - b), D.elements[8] = (F + b) / (F - b), this.cameraL.projectionMatrix.copy(D), b = -U * R - B, F = U * R - B, D.elements[0] = 2 * L / (F - b), D.elements[8] = (F + b) / (F - b), this.cameraR.projectionMatrix.copy(D); } this.cameraL.matrixWorld.copy(C.matrixWorld).multiply(_), this.cameraR.matrixWorld.copy(C.matrixWorld).multiply(T); }; })() }); var m = function(M) { var R = new v(); R.aspect = 0.5, this.setSize = (L, S) => { M.setSize(L, S); }, this.render = (L, S) => { L.updateMatrixWorld(), S.parent === null && S.updateMatrixWorld(), R.update(S); var I = M.getSize(); M.setScissorTest(true), M.clear(), M.setScissor(0, 0, I.width / 2, I.height), M.setViewport(0, 0, I.width / 2, I.height), M.render(L, R.cameraL), M.setScissor(I.width / 2, 0, I.width / 2, I.height), M.setViewport(I.width / 2, 0, I.width / 2, I.height), M.render(L, R.cameraR), M.setScissorTest(false); }; }, x = function(M) { var R = this; this.object = M, this.object.rotation.reorder("YXZ"), this.enabled = true, this.deviceOrientation = {}, this.screenOrientation = 0; var L = (T) => { R.deviceOrientation = T; }, S = () => { typeof window < "u" && (R.screenOrientation = window.orientation || 0); }, I = (() => { var T = new l.Vector3(0, 0, 1), _ = new l.Euler(), E = new l.Quaternion(), C = new l.Quaternion(-Math.sqrt(0.5), 0, 0, Math.sqrt(0.5)); return (P, b, F, D, N) => { var B = new l.Vector3(0, 0, 1); B.subVectors(P.target, P.position), _.set(F, b, -D, "YXZ"); var U = new l.Quaternion(); U.setFromEuler(_), U.multiply(C), U.multiply(E.setFromAxisAngle(T, -N)), B.applyQuaternion(U), B.addVectors(P.position, B), P.lookAt(B); }; })(); this.connect = () => { S(), typeof window < "u" && (window.addEventListener("orientationchange", S, false), window.addEventListener("deviceorientation", L, false)), R.enabled = true; }, this.disconnect = () => { typeof window < "u" && (window.removeEventListener("orientationchange", S, false), window.removeEventListener("deviceorientation", L, false)), R.enabled = false; }, this.update = () => { if (R.enabled !== false) { var T = R.deviceOrientation.alpha ? l.Math.degToRad(R.deviceOrientation.alpha) : 0, _ = R.deviceOrientation.beta ? l.Math.degToRad(R.deviceOrientation.beta) : 0, E = R.deviceOrientation.gamma ? l.Math.degToRad(R.deviceOrientation.gamma) : 0, C = R.screenOrientation ? l.Math.degToRad(R.screenOrientation) : 0; I(R.object, T, _, E, C); } }, this.dispose = function() { this.disconnect(); }, this.connect(); }, w = function() { var M = void 0, R = void 0, L = void 0, S = new l.Vector3(), I = new l.Vector3(), T = new l.Vector3(), _ = new l.Vector3(), E = void 0; this.setCurrentCameraSettings = (C, P) => { M = C.clone(), R = C, L = P, M.near = L.nearPlane, L.farPlane && (M.far = L.farPlane), L.eyePosition && M.position.set(L.eyePosition[0], L.eyePosition[1], L.eyePosition[2]), L.upVector && M.up.set(L.upVector[0], L.upVector[1], L.upVector[2]), L.targetPosition && (M.target = new l.Vector3(L.targetPosition[0], L.targetPosition[1], L.targetPosition[2]), M.lookAt(M.target)), M.updateProjectionMatrix(), S.copy(M.position).project(M), I.copy(M.target).project(M); }, this.getCurrentPosition = () => (I.copy(R.target).project(M), [I.x, I.y]), this.zoom = (C) => { var P = 2e-3 * C, b = Math.max(R.zoom - P, 1); R.zoom = b, R.updateProjectionMatrix(); }, this.zoomToBox = (C, P) => { C.getCenter(T), T.project(M), this.setCenterZoom([T.x, T.y], P); }, this.getPanZoom = () => ({ target: this.getCurrentPosition(), zoom: R.zoom }), this.setCenterZoom = (C, P) => { T.set(C[0], C[1], I.z).unproject(M), _.copy(T).sub(R.target), R.target.copy(T), R.lookAt(R.target), R.position.add(_), R.zoom = P, R.updateProjectionMatrix(); }, this.setEventCallback = (C) => { (C === void 0 || typeof C == "function") && (E = C); }, this.triggerCallback = () => { E !== void 0 && typeof E == "function" && E(); }; }; a.Viewport = h6, a.CameraControls = f, a.SmoothCameraTransition = g, a.RotateCameraTransition = p, a.RayCaster = u, a.CameraAutoTumble = y, a.StereoEffect = m, a.NDCCameraControl = w; }, /* 45 */ /***/ (o, a, c) => { var { Group: l, Matrix4: d } = c(4), h6 = c(22).Pointset; c(24).Lines; var f = c(46).Lines2, g = c(3).Geometry, p = c(4), u = 0, y = function() { return "re" + u++; }, v = function(m, x) { var w = m, A = new l(); A.matrixAutoUpdate = false, A.userData = this; var M = [], R = "", L = [], S = x, I = new d(), T = 3e3; I.set(1, 0, 0, 0, 0, 1, 0, 0, 0, 0, 1, 0, 0, 0, 0, 1), this.pickableUpdateRequired = true, this.isRegion = true, this.uuid = y(), this.hideAllPrimitives = () => { M.forEach((_) => _.hideAllPrimitives()), L.forEach((_) => _.setVisibility(false)); }, this.showAllPrimitives = () => { M.forEach((_) => _.showAllPrimitives()), L.forEach((_) => _.setVisibility(true)); }, this.setVisibility = (_) => { _ != A.visible && (A.visible = _, this.pickableUpdateRequired = true); }, this.getVisibility = () => A.visible, this.getGroup = () => A, this.setTransformation = (_) => { I.set(..._), A.matrix.copy(I), A.updateMatrixWorld(); }, this.setName = (_) => { _ && _ !== "" && (R = _); }, this.getName = () => R, this.getParent = () => w, this.getFullSeparatedPath = () => { var _ = []; if (R !== "") { _.push(R); for (var E, C = w; C !== void 0; ) E = C.getName(), E !== "" && _.unshift(E), C = C.getParent(); } return _; }, this.getFullPath = () => { var _ = this.getFullSeparatedPath(); if (0 < _.length) { var E = _.shift(); return _.forEach((C) => { E = E.concat("/", C); }), E; } return ""; }, this.createChild = (_) => { var E = new v(this, S); return E.setName(_), M.push(E), A.add(E.getGroup()), E; }, this.getChildWithName = (_) => { if (_) { for (var E = _.toLowerCase(), C = 0; C < M.length; C++) if (M[C].getName().toLowerCase() === E) return M[C]; } }, this.findChildFromSeparatedPath = (_) => { if (_ && 0 < _.length && _[0] === "" && _.shift(), _ && 0 < _.length) { var E = this.getChildWithName(_[0]); return E ? (_.shift(), E.findChildFromSeparatedPath(_)) : void 0; } return this; }, this.findChildFromPath = (_) => { var E = _.split("/"); return this.findChildFromSeparatedPath(E); }, this.createChildFromSeparatedPath = (_) => { if (0 < _.length && _[0] === "" && _.shift(), 0 < _.length) { var E = this.getChildWithName(_[0]); return E || (E = this.createChild(_[0])), _.shift(), E.createChildFromSeparatedPath(_); } return this; }, this.createChildFromPath = (_) => { var E = _.split("/"); return this.createChildFromSeparatedPath(E); }, this.findOrCreateChildFromPath = (_) => { var E = this.findChildFromPath(_); return E || (E = this.createChildFromPath(_)), E; }, this.addZincObject = (_) => { _ && (_.setRegion(this), A.add(_.getGroup()), L.push(_), this.pickableUpdateRequired = true, S && S.triggerObjectAddedCallback(_)); }, this.removeZincObject = (_) => { for (var E = 0; E < L.length; E++) if (_ === L[E]) return A.remove(_.getGroup()), L.splice(E, 1), S && S.triggerObjectRemovedCallback(_), _.dispose(), void (this.pickableUpdateRequired = true); }, this.checkPickableUpdateRequred = (_) => { if (this.pickableUpdateRequired) return true; if (_) { for (var E = false, C = 0; C < M.length; C++) if (E = M[C].checkPickableUpdateRequred(_), E) return true; } return false; }, this.getPickableThreeJSObjects = (_, E) => (A.visible && (L.forEach((C) => { if (C.isPickable && C.getGroup() && C.getGroup().visible) { var P = C.marker; P && P.isEnabled() && _.push(P.getMorph()), _.push(C.getGroup()); } }), E && M.forEach((C) => { C.getPickableThreeJSObjects(_, E); }), this.pickableUpdateRequired = false), _), this.setDuration = (_) => { T = _, L.forEach((E) => E.setDuration(_)), M.forEach((E) => E.setDuration(_)); }, this.getDuration = () => T, this.getBoundingBox = (_) => { var E, C; return L.forEach((P) => { C = P.getBoundingBox(), C && (E == null ? E = C.clone() : E.union(C)); }), _ && M.forEach((P) => { C = P.getBoundingBox(_), C && (E == null ? E = C.clone() : E.union(C)); }), E; }, this.clear = (_) => { _ && M.forEach((E) => E.clear(_)), L.forEach((E) => { A.remove(E.getGroup()), E.dispose(); }), M = [], L = []; }, this.objectIsInRegion = (_, E) => { for (var C = 0; C < L.length; C++) if (_ === L[C]) return true; if (E) { for (var P = 0; P < M.length; P++) if (M[P].objectIsInRegion(_, E)) return true; } return false; }, this.forEachGeometry = (_, E) => { L.forEach((C) => { C.isGeometry && _(C); }), E && M.forEach((C) => C.forEachGeometry(_, E)); }, this.forEachGlyphset = (_, E) => { L.forEach((C) => { C.isGlyphset && _(C); }), E && M.forEach((C) => C.forEachGlyphset(_, E)); }, this.forEachPointset = (_, E) => { L.forEach((C) => { C.isPointset && _(C); }), E && M.forEach((C) => C.forEachPointset(_, E)); }, this.forEachLine = (_, E) => { L.forEach((C) => { C.isLines && _(C); }), E && M.forEach((C) => C.forEachLine(_, E)); }, this.findObjectsWithAnatomicalId = (_, E) => { var C = []; return L.forEach((P) => { P.anatomicalId === _ && C.push(P); }), E && M.forEach((P) => { var b = P.findObjectsWithAnatomicalId(_, E); C.push(...b); }), C; }, this.findObjectsWithGroupName = (_, E) => { var C = []; return L.forEach((P) => { var b = P.groupName ? P.groupName.toLowerCase() : P.groupName, F = _ && _.toLowerCase(); b === F && C.push(P); }), E && M.forEach((P) => { var b = P.findObjectsWithGroupName(_, E); C.push(...b); }), C; }, this.findGeometriesWithGroupName = (_, E) => { var C = this.findObjectsWithGroupName(_, E), P = C.filter((b) => b.isGeometry); return P; }, this.findPointsetsWithGroupName = (_, E) => { var C = this.findObjectsWithGroupName(_, E), P = C.filter((b) => b.isPointset); return P; }, this.findGlyphsetsWithGroupName = (_, E) => { var C = this.findObjectsWithGroupName(_, E), P = C.filter((b) => b.isGlyphset); return P; }, this.findLinesWithGroupName = (_, E) => { var C = this.findObjectsWithGroupName(_, E), P = C.filter((b) => b.isLines); return P; }, this.getAllObjects = (_) => { var E = [...L]; return _ && M.forEach((C) => { var P = C.getAllObjects(_); E.push(...P); }), E; }, this.getChildRegions = (_) => { var E = [...M]; return _ && M.forEach((C) => { var P = C.getChildRegions(_); E.push(...P); }), E; }, this.getCurrentTime = () => { if (L[0] != null) return L[0].getCurrentTime(); for (var _, E = 0; E < M.length; E++) if (_ = M[E].getCurrentTime(), _ !== -1) return _; return -1; }, this.setMorphTime = (_, E) => { L.forEach((C) => { C.setMorphTime(_); }), E && M.forEach((C) => { C.setMorphTime(_); }); }, this.isTimeVarying = () => { for (var _ = 0; _ < L.length; _++) if (L[_].isTimeVarying()) return true; for (var E = 0; E < M.length; E++) if (M[E].isTimeVarying()) return true; return false; }, this.renderGeometries = (_, E, C, P, b, F) => { var D, N = this.getAllObjects(F); N.forEach((B) => { B.render(_ * E, C, P, b); }), b && C === false && (D = b.markerCluster) !== null && D !== void 0 && D.markerUpdateRequired && b.markerCluster.calculate(); }, this.createPoints = (_, E, C, P) => { var b = false, F = this.findObjectsWithGroupName(_, false), D = F.findIndex((B) => B.isPointset), N = -1 < D ? F[D] : new h6(); return N.addPoints(E, C, P), D === -1 ? (N.setName(_), this.addZincObject(N), b = true) : this.pickableUpdateRequired = true, { zincObject: N, isNew: b }; }, this.createLines = (_, E, C) => { var P = false, b = this.findObjectsWithGroupName(_, false), F = b.findIndex((N) => N.isLines), D = -1 < F ? b[F] : new f(); return D.addLines(E, C), F === -1 ? (D.setName(_), this.addZincObject(D), P = true) : this.pickableUpdateRequired = true, { zincObject: D, isNew: P }; }, this.createGeometryFromThreeJSGeometry = (_, E, C, P, b, F) => { var D = new g(), N = new p.MeshPhongMaterial({ color: C, morphTargets: false, morphNormals: false, transparent: true, opacity: P, side: p.DoubleSide }); return D.createMesh(E, N, { localTimeEnabled: false, localMorphColour: false }), D.getMorph() ? (D.setVisibility(false), D.setName(_), D.setRenderOrder(F), this.addZincObject(D), D) : void 0; }; }; a.Region = v; }, /* 46 */ /***/ (o, a, c) => { c(4), c(5).toBufferGeometry; var l = c(47).LineSegments2, d = c(49).LineMaterial, h6 = c(48).LineSegmentsGeometry, f = function() { c(24).Lines.call(this), this.isLines2 = true; var g = Array(300); this.createLineSegment = (p, u, y) => { if (p && u) { var v = new h6(); v.setPositions(p), v.colorsNeedUpdate = true; var m = new l(v, u); m.scale.set(1, 1, 1), m.computeLineDistances(), this.setMesh(m, y.localTimeEnabled, y.localMorphColour); } }, this.setWidth = (p) => { this.morph && this.morph.material && (this.morph.material.linewidth = p, this.morph.material.needsUpdate = true); }, this.addVertices = function(p) { if (p && p.length) { var u = this.getMorph(); u || (this.drawRange = 0); var y = 3 * this.drawRange; if (p.forEach((v) => { g[y++] = v[0], g[y++] = v[1], g[y++] = v[2], this.drawRange++; }), !u) for (; 300 > y; ) g[y++] = p[0][0], g[y++] = p[0][1], g[y++] = p[0][2]; u && (u.geometry.setPositions(g), u.computeLineDistances(), this.boundingBoxUpdateRequired = true); } return g; }, this.getVerticesByFaceIndex = function(p) { var u = 3 * (2 * p), y = this.getMorph(); if (y && 3 * this.drawRange > u) { var v = y.geometry.getAttribute("instanceStart"); return [[v.data.array[u], v.data.array[++u], v.data.array[++u]], [v.data.array[++u], v.data.array[++u], v.data.array[++u]]]; } return []; }, this.editVertices = function(p, u) { if (p && p.length) { var y = this.getMorph(), v = u + p.length - 1; if (!y || 0 > u || v >= this.drawRange) return; var m = 3 * u; for (p.forEach((x) => { g[m++] = x[0], g[m++] = x[1], g[m++] = x[2]; }), m = 3 * this.drawRange; 300 > m; ) g[m++] = p[0][0], g[m++] = p[0][1], g[m++] = p[0][2]; y.geometry.setPositions(g), y.computeLineDistances(), this.boundingBoxUpdateRequired = true; } return g; }, this.addLines = (p, u) => { if (p && 0 < p.length) { this.addVertices(p); var y = this.getMorph(); if (!y) { var v = new d({ color: u, linewidth: 1, vertexColors: false, worldUnits: false }); v.resolution.set(window.innerWidth, window.innerHeight), this.createLineSegment(g, v, { localTimeEnabled: false, localMorphColour: false }); } this.region && (this.region.pickableUpdateRequired = true); } }, this.render = () => { var p = this.getMorph().material; p.resolution.set(window.innerWidth, window.innerHeight); }; }; f.prototype = Object.create(c(24).Lines.prototype), f.prototype.constructor = f, a.Lines2 = f; }, /* 47 */ /***/ (o, a, c) => { c.r(a), c.d(a, { /* harmony export */ LineSegments2: () => ( /* binding */ L ) /* harmony export */ }); var l = c(4), d = c(48), h6 = c(49), f = new l.Vector3(), g = new l.Vector3(), p = new l.Vector4(), u = new l.Vector4(), y = new l.Vector4(), v = new l.Vector3(), m = new l.Matrix4(), x = new l.Line3(), w = new l.Vector3(), A = new l.Box3(), M = new l.Sphere(), R = new l.Vector4(); class L extends l.Mesh { constructor() { var I = 0 < arguments.length && arguments[0] !== void 0 ? arguments[0] : new d.LineSegmentsGeometry(), T = 1 < arguments.length && arguments[1] !== void 0 ? arguments[1] : new h6.LineMaterial({ color: 16777215 * Math.random() }); super(I, T), this.type = "LineSegments2"; } // for backwards-compatability, but could be a method of LineSegmentsGeometry... computeLineDistances() { for (var I = this.geometry, T = I.attributes.instanceStart, _ = I.attributes.instanceEnd, E = new Float32Array(2 * T.count), C = 0, P = 0, b = T.count; C < b; C++, P += 2) f.fromBufferAttribute(T, C), g.fromBufferAttribute(_, C), E[P] = P == 0 ? 0 : E[P - 1], E[P + 1] = E[P] + f.distanceTo(g); var F = new l.InstancedInterleavedBuffer(E, 2, 1); return I.setAttribute("instanceDistanceStart", new l.InterleavedBufferAttribute(F, 1, 0)), I.setAttribute("instanceDistanceEnd", new l.InterleavedBufferAttribute(F, 1, 1)), this; } raycast(I, T) { I.camera === null && console.error('LineSegments2: "Raycaster.camera" needs to be set in order to raycast against LineSegments2.'); var _ = I.params.Line2 === void 0 ? 0 : I.params.Line2.threshold || 0, E = I.ray, C = I.camera, P = C.projectionMatrix, b = this.matrixWorld, F = this.geometry, D = this.material, N = D.resolution, B = D.linewidth + _, U = F.attributes.instanceStart, G = F.attributes.instanceEnd, Y = -C.near, te = 2 * Math.max(B / N.width, B / N.height); F.boundingSphere === null && F.computeBoundingSphere(), M.copy(F.boundingSphere).applyMatrix4(b); var ae = Math.max(C.near, M.distanceToPoint(E.origin)); R.set(0, 0, -ae, 1).applyMatrix4(C.projectionMatrix), R.multiplyScalar(1 / R.w), R.applyMatrix4(C.projectionMatrixInverse); var ie = 0.5 * Math.abs(te / R.w); if (M.radius += ie, I.ray.intersectsSphere(M) !== false) { F.boundingBox === null && F.computeBoundingBox(), A.copy(F.boundingBox).applyMatrix4(b); var le = Math.max(C.near, A.distanceToPoint(E.origin)); R.set(0, 0, -le, 1).applyMatrix4(C.projectionMatrix), R.multiplyScalar(1 / R.w), R.applyMatrix4(C.projectionMatrixInverse); var W = 0.5 * Math.abs(te / R.w); if (A.max.x += W, A.max.y += W, A.max.z += W, A.min.x -= W, A.min.y -= W, A.min.z -= W, I.ray.intersectsBox(A) !== false) { E.at(1, y), y.w = 1, y.applyMatrix4(C.matrixWorldInverse), y.applyMatrix4(P), y.multiplyScalar(1 / y.w), y.x *= N.x / 2, y.y *= N.y / 2, y.z = 0, v.copy(y), m.multiplyMatrices(C.matrixWorldInverse, b); for (var $ = 0, j = U.count; $ < j; $++) { p.fromBufferAttribute(U, $), u.fromBufferAttribute(G, $), p.w = 1, u.w = 1, p.applyMatrix4(m), u.applyMatrix4(m); var re = p.z > Y && u.z > Y; if (!re) { if (p.z > Y) { var V = p.z - u.z, H = (p.z - Y) / V; p.lerp(u, H); } else if (u.z > Y) { var K = u.z - p.z, ce = (u.z - Y) / K; u.lerp(p, ce); } p.applyMatrix4(P), u.applyMatrix4(P), p.multiplyScalar(1 / p.w), u.multiplyScalar(1 / u.w), p.x *= N.x / 2, p.y *= N.y / 2, u.x *= N.x / 2, u.y *= N.y / 2, x.start.copy(p), x.start.z = 0, x.end.copy(u), x.end.z = 0; var se = x.closestPointToPointParameter(v, true); x.at(se, w); var k = l.MathUtils.lerp(p.z, u.z, se), O = -1 <= k && 1 >= k, Z = v.distanceTo(w) < 0.5 * B; if (O && Z) { x.start.fromBufferAttribute(U, $), x.end.fromBufferAttribute(G, $), x.start.applyMatrix4(b), x.end.applyMatrix4(b); var X = new l.Vector3(), ee = new l.Vector3(); E.distanceSqToSegment(x.start, x.end, ee, X), T.push({ point: ee, pointOnLine: X, distance: E.origin.distanceTo(ee), object: this, face: null, faceIndex: $, uv: null, uv2: null }); } } } } } } } L.prototype.LineSegments2 = true; }, /* 48 */ /***/ (o, a, c) => { c.r(a), c.d(a, { /* harmony export */ LineSegmentsGeometry: () => ( /* binding */ f ) /* harmony export */ }); var l = c(4), d = new l.Box3(), h6 = new l.Vector3(); class f extends l.InstancedBufferGeometry { constructor() { super(), this.type = "LineSegmentsGeometry", this.setIndex([0, 2, 1, 2, 3, 1, 2, 4, 3, 4, 5, 3, 4, 6, 5, 6, 7, 5]), this.setAttribute("position", new l.Float32BufferAttribute([-1, 2, 0, 1, 2, 0, -1, 1, 0, 1, 1, 0, -1, 0, 0, 1, 0, 0, -1, -1, 0, 1, -1, 0], 3)), this.setAttribute("uv", new l.Float32BufferAttribute([-1, 2, 1, 2, -1, 1, 1, 1, -1, -1, 1, -1, -1, -2, 1, -2], 2)); } applyMatrix4(p) { var u = this.attributes.instanceStart, y = this.attributes.instanceEnd; return u !== void 0 && (u.applyMatrix4(p), y.applyMatrix4(p), u.needsUpdate = true), this.boundingBox !== null && this.computeBoundingBox(), this.boundingSphere !== null && this.computeBoundingSphere(), this; } setPositions(p) { var u; p instanceof Float32Array ? u = p : Array.isArray(p) && (u = new Float32Array(p)); var y = new l.InstancedInterleavedBuffer(u, 6, 1); return this.setAttribute("instanceStart", new l.InterleavedBufferAttribute(y, 3, 0)), this.setAttribute("instanceEnd", new l.InterleavedBufferAttribute(y, 3, 3)), this.computeBoundingBox(), this.computeBoundingSphere(), this; } setColors(p) { var u; p instanceof Float32Array ? u = p : Array.isArray(p) && (u = new Float32Array(p)); var y = new l.InstancedInterleavedBuffer(u, 6, 1); return this.setAttribute("instanceColorStart", new l.InterleavedBufferAttribute(y, 3, 0)), this.setAttribute("instanceColorEnd", new l.InterleavedBufferAttribute(y, 3, 3)), this; } fromWireframeGeometry(p) { return this.setPositions(p.attributes.position.array), this; } fromEdgesGeometry(p) { return this.setPositions(p.attributes.position.array), this; } fromMesh(p) { return this.fromWireframeGeometry(new l.WireframeGeometry(p.geometry)), this; } fromLineSegments(p) { var u = p.geometry; return u.isGeometry ? void console.error("THREE.LineSegmentsGeometry no longer supports Geometry. Use THREE.BufferGeometry instead.") : (u.isBufferGeometry && this.setPositions(u.attributes.position.array), this); } computeBoundingBox() { this.boundingBox === null && (this.boundingBox = new l.Box3()); var p = this.attributes.instanceStart, u = this.attributes.instanceEnd; p !== void 0 && u !== void 0 && (this.boundingBox.setFromBufferAttribute(p), d.setFromBufferAttribute(u), this.boundingBox.union(d)); } computeBoundingSphere() { this.boundingSphere === null && (this.boundingSphere = new l.Sphere()), this.boundingBox === null && this.computeBoundingBox(); var p = this.attributes.instanceStart, u = this.attributes.instanceEnd; if (p !== void 0 && u !== void 0) { var y = this.boundingSphere.center; this.boundingBox.getCenter(y); for (var v = 0, m = 0, x = p.count; m < x; m++) h6.fromBufferAttribute(p, m), v = Math.max(v, y.distanceToSquared(h6)), h6.fromBufferAttribute(u, m), v = Math.max(v, y.distanceToSquared(h6)); this.boundingSphere.radius = Math.sqrt(v), isNaN(this.boundingSphere.radius) && console.error("THREE.LineSegmentsGeometry.computeBoundingSphere(): Computed radius is NaN. The instanced position data is likely to have NaN values.", this); } } toJSON() { } applyMatrix(p) { return console.warn("THREE.LineSegmentsGeometry: applyMatrix() has been renamed to applyMatrix4()."), this.applyMatrix4(p); } } f.prototype.isLineSegmentsGeometry = true; }, /* 49 */ /***/ (o, a, c) => { c.r(a), c.d(a, { /* harmony export */ LineMaterial: () => ( /* binding */ d ) /* harmony export */ }); var l = c(4); l.UniformsLib.line = { linewidth: { value: 1 }, resolution: { value: new l.Vector2(1, 1) }, dashScale: { value: 1 }, dashSize: { value: 1 }, dashOffset: { value: 0 }, gapSize: { value: 1 }, // todo FIX - maybe change to totalSize opacity: { value: 1 } }, l.ShaderLib.line = { uniforms: l.UniformsUtils.merge([l.UniformsLib.common, l.UniformsLib.fog, l.UniformsLib.line]), vertexShader: ( /* glsl */ ` #include #include #include #include #include uniform float linewidth; uniform vec2 resolution; attribute vec3 instanceStart; attribute vec3 instanceEnd; attribute vec3 instanceColorStart; attribute vec3 instanceColorEnd; varying vec2 vUv; #ifdef USE_DASH uniform float dashScale; attribute float instanceDistanceStart; attribute float instanceDistanceEnd; varying float vLineDistance; #endif void trimSegment( const in vec4 start, inout vec4 end ) { // trim end segment so it terminates between the camera plane and the near plane // conservative estimate of the near plane float a = projectionMatrix[ 2 ][ 2 ]; // 3nd entry in 3th column float b = projectionMatrix[ 3 ][ 2 ]; // 3nd entry in 4th column float nearEstimate = - 0.5 * b / a; float alpha = ( nearEstimate - start.z ) / ( end.z - start.z ); end.xyz = mix( start.xyz, end.xyz, alpha ); } void main() { #ifdef USE_COLOR vColor.xyz = ( position.y < 0.5 ) ? instanceColorStart : instanceColorEnd; #endif #ifdef USE_DASH vLineDistance = ( position.y < 0.5 ) ? dashScale * instanceDistanceStart : dashScale * instanceDistanceEnd; #endif float aspect = resolution.x / resolution.y; vUv = uv; // camera space vec4 start = modelViewMatrix * vec4( instanceStart, 1.0 ); vec4 end = modelViewMatrix * vec4( instanceEnd, 1.0 ); // special case for perspective projection, and segments that terminate either in, or behind, the camera plane // clearly the gpu firmware has a way of addressing this issue when projecting into ndc space // but we need to perform ndc-space calculations in the shader, so we must address this issue directly // perhaps there is a more elegant solution -- WestLangley bool perspective = ( projectionMatrix[ 2 ][ 3 ] == - 1.0 ); // 4th entry in the 3rd column if ( perspective ) { if ( start.z < 0.0 && end.z >= 0.0 ) { trimSegment( start, end ); } else if ( end.z < 0.0 && start.z >= 0.0 ) { trimSegment( end, start ); } } // clip space vec4 clipStart = projectionMatrix * start; vec4 clipEnd = projectionMatrix * end; // ndc space vec2 ndcStart = clipStart.xy / clipStart.w; vec2 ndcEnd = clipEnd.xy / clipEnd.w; // direction vec2 dir = ndcEnd - ndcStart; // account for clip-space aspect ratio dir.x *= aspect; dir = normalize( dir ); // perpendicular to dir vec2 offset = vec2( dir.y, - dir.x ); // undo aspect ratio adjustment dir.x /= aspect; offset.x /= aspect; // sign flip if ( position.x < 0.0 ) offset *= - 1.0; // endcaps if ( position.y < 0.0 ) { offset += - dir; } else if ( position.y > 1.0 ) { offset += dir; } // adjust for linewidth offset *= linewidth; // adjust for clip-space to screen-space conversion // maybe resolution should be based on viewport ... offset /= resolution.y; // select end vec4 clip = ( position.y < 0.5 ) ? clipStart : clipEnd; // back to clip space offset *= clip.w; clip.xy += offset; gl_Position = clip; vec4 mvPosition = ( position.y < 0.5 ) ? start : end; // this is an approximation #include #include #include }` ), fragmentShader: ( /* glsl */ ` uniform vec3 diffuse; uniform float opacity; #ifdef USE_DASH uniform float dashSize; uniform float dashOffset; uniform float gapSize; #endif varying float vLineDistance; #include #include #include #include #include varying vec2 vUv; void main() { #include #ifdef USE_DASH if ( vUv.y < - 1.0 || vUv.y > 1.0 ) discard; // discard endcaps if ( mod( vLineDistance + dashOffset, dashSize + gapSize ) > dashSize ) discard; // todo - FIX #endif float alpha = opacity; #ifdef ALPHA_TO_COVERAGE // artifacts appear on some hardware if a derivative is taken within a conditional float a = vUv.x; float b = ( vUv.y > 0.0 ) ? vUv.y - 1.0 : vUv.y + 1.0; float len2 = a * a + b * b; float dlen = fwidth( len2 ); if ( abs( vUv.y ) > 1.0 ) { alpha = 1.0 - smoothstep( 1.0 - dlen, 1.0 + dlen, len2 ); } #else if ( abs( vUv.y ) > 1.0 ) { float a = vUv.x; float b = ( vUv.y > 0.0 ) ? vUv.y - 1.0 : vUv.y + 1.0; float len2 = a * a + b * b; if ( len2 > 1.0 ) discard; } #endif vec4 diffuseColor = vec4( diffuse, alpha ); #include #include gl_FragColor = vec4( diffuseColor.rgb, alpha ); #include #include #include #include }` ) }; class d extends l.ShaderMaterial { constructor(f) { super({ type: "LineMaterial", uniforms: l.UniformsUtils.clone(l.ShaderLib.line.uniforms), vertexShader: l.ShaderLib.line.vertexShader, fragmentShader: l.ShaderLib.line.fragmentShader, clipping: true // required for clipping support }), Object.defineProperties(this, { color: { enumerable: true, get: function() { return this.uniforms.diffuse.value; }, set: function(p) { this.uniforms.diffuse.value = p; } }, linewidth: { enumerable: true, get: function() { return this.uniforms.linewidth.value; }, set: function(p) { this.uniforms.linewidth.value = p; } }, dashed: { enumerable: true, get: function() { return "USE_DASH" in this.defines; }, set(g) { !!g != "USE_DASH" in this.defines && (this.needsUpdate = true), g === true ? this.defines.USE_DASH = "" : delete this.defines.USE_DASH; } }, dashScale: { enumerable: true, get: function() { return this.uniforms.dashScale.value; }, set: function(p) { this.uniforms.dashScale.value = p; } }, dashSize: { enumerable: true, get: function() { return this.uniforms.dashSize.value; }, set: function(p) { this.uniforms.dashSize.value = p; } }, dashOffset: { enumerable: true, get: function() { return this.uniforms.dashOffset.value; }, set: function(p) { this.uniforms.dashOffset.value = p; } }, gapSize: { enumerable: true, get: function() { return this.uniforms.gapSize.value; }, set: function(p) { this.uniforms.gapSize.value = p; } }, opacity: { enumerable: true, get: function() { return this.uniforms.opacity.value; }, set: function(p) { this.uniforms.opacity.value = p; } }, resolution: { enumerable: true, get: function() { return this.uniforms.resolution.value; }, set: function(p) { this.uniforms.resolution.value.copy(p); } }, alphaToCoverage: { enumerable: true, get: function() { return "ALPHA_TO_COVERAGE" in this.defines; }, set: function(p) { !!p != "ALPHA_TO_COVERAGE" in this.defines && (this.needsUpdate = true), p === true ? (this.defines.ALPHA_TO_COVERAGE = "", this.extensions.derivatives = true) : (delete this.defines.ALPHA_TO_COVERAGE, this.extensions.derivatives = false); } } }), this.setValues(f); } } d.prototype.isLineMaterial = true; }, /* 50 */ /***/ (o, a, c) => { var l = c(4); a.Minimap = function(d) { var h6 = d; this.camera = new l.OrthographicCamera(-0.5, 0.5, 0.5, -0.5, 0.01, 10), this.helper = void 0; var f = new l.BufferGeometry(), g = new Float32Array([-1, -1, 1, 1, -1, 1, 1, 1, 1, 1, 1, 1, -1, 1, 1, -1, -1, 1]), p = new l.BufferAttribute(g, 3); f.setAttribute("position", p); var u = new l.MeshBasicMaterial({ color: 3355443, depthTest: false, depthWrite: false, opacity: 0.5, transparent: true }); this.mask = new l.Mesh(f, u); var y = new l.Box3(), v = new l.Vector3(); this.getDiffFromNormalised = (x, w) => { y.setFromBufferAttribute(p).getCenter(v); var A = v.clone().project(this.camera), M = new l.Vector3(x, w, A.z).unproject(this.camera); return M.sub(v); }; var m = (x, w) => { h6.camera.near && (this.camera.near = h6.camera.near), w.farPlane && (this.camera.far = w.farPlane), w.eyePosition && this.camera.position.set(w.eyePosition[0], w.eyePosition[1], w.eyePosition[2]), w.upVector && this.camera.up.set(w.upVector[0], w.upVector[1], w.upVector[2]), w.targetPosition && this.camera.lookAt(new l.Vector3(w.targetPosition[0], w.targetPosition[1], w.targetPosition[2])), this.camera.zoom = 1 / x, this.camera.updateProjectionMatrix(); }; this.getBoundary = () => { var x = new l.Vector3().copy(h6.camera.target).project(h6.camera), w = new l.Vector3(-1, -1, x.z).unproject(h6.camera), A = new l.Vector3(1, -1, x.z).unproject(h6.camera), M = new l.Vector3(1, 1, x.z).unproject(h6.camera), R = new l.Vector3(-1, 1, x.z).unproject(h6.camera); p.copyVector3sArray([w, A, M, M, R, w]), p.needsUpdate = true; }, this.updateCamera = () => { this.getBoundary(); var x = h6.getZincCameraControls(), w = h6.getBoundingBox(); if (w) { var A = w.min.distanceTo(w.max), M = A / 2, R = (w.min.x + w.max.x) / 2, L = (w.min.y + w.max.y) / 2, S = (w.min.z + w.max.z) / 2, I = x.getViewportFromCentreAndRadius(R, L, S, M, 40, M * 4); m(A, I); } }; }; }, /* 51 */ /***/ (o, a, c) => { var l = c(4), d = c(52)(l), h6 = c(3).Geometry, f = c(53), g = c(54).default, p = l.BufferGeometryLoader, u = function(y) { var v; y && y.isGeometry && (v = y); var m = void 0, x = void 0, w = false, A = void 0, M = (T) => { var _ = v.getMorph().material.clone(); _.morphTargets = false; var E = new h6(), C = new p(), P = C.parse(T), b = new l.Mesh(P.geometry, _); return E.geometry = b.geometry, b.userData = E, E.setMorph(b), E; }, R = (T) => { switch (T.data.action) { case "message": console.log(T.data.message); break; case "result": var _ = new u(M(T.data.object)); A && A(_), A = void 0, w = false; break; default: throw "Cannot handle specified action."; } }, L = (T) => { if (f !== void 0 && (x = f( /*require.resolve*/ 55 )), !x) m = new (c(56)).GeometryCSGInternal(T); else if (T && T.isGeometry) { var _ = T.getMorph(), E = _.geometry.clone().applyMatrix(_.matrix).toJSON(); x.addEventListener("message", function(C) { R(C); }), x.postMessage({ action: "initialise", object: E }); } }; this.getHostGeometry = () => { var T = new d(v.getMorph()); return new S(T); }, this.getGeometry = () => v; var S = (T) => { var _ = v.getMorph().material.clone(); _.morphTargets = false; var E = T.toMesh(_), C = new h6(); return C.geometry = E.geometry, E.userData = C, C.setMorph(E), C; }; this.setCSG = (T) => { m.setCSG(T); }; var I = (T, _, E, C) => { if (w) C("On progress"); else { var P = T.getMorph(), b = P.geometry.clone().applyMatrix(P.matrix).toJSON(); A = E, w = true, x.postMessage({ action: _, object: b }); } }; this.intersect = (T) => new g((_, E) => { if (x) I(T, "intersect", _, E); else { var C = m.intersect(T), P = new u(S(C)); P.setCSG(C), _(P); } }), this.subtract = (T) => new g((_, E) => { if (x) I(T, "intersect", _, E); else { var C = m.subtract(T), P = new u(S(C)); P.setCSG(C), _(P); } }), this.union = (T) => new g((_, E) => { if (x) I(T, "intersect", _, E); else { var C = m.union(T), P = new u(S(C)); P.setCSG(C), _(P); } }), this.terminateWorker = () => { x && x.terminate(); }, L(y); }; a.GeometryCSG = u; }, /* 52 */ /***/ (o) => { var a = 1e-5, c = 0, l = 1, d = 2, h6 = 3; o.exports = function(f) { var g = function(p) { var u, y, v, m, x, w, A, M = []; if (p.isBufferGeometry && (p = new f.Geometry().fromBufferGeometry(p)), p instanceof f.Geometry) this.matrix = new f.Matrix4(); else if (p.isMesh) p.updateMatrix(), this.matrix = p.matrix.clone(), p = p.geometry, p.isBufferGeometry && (p = new f.Geometry().fromBufferGeometry(p)), p.mergeVertices(), p.computeVertexNormals(false); else { if (p instanceof g.Node) return this.tree = p, this.matrix = new f.Matrix4(), this; throw "ThreeBSP: Given geometry is unsupported"; } for (u = 0, y = p.faces.length; u < y; u++) v = p.faces[u], x = p.faceVertexUvs[0][u], A = new g.Polygon(), v instanceof f.Face3 ? (m = p.vertices[v.a], w = x ? new f.Vector2(x[0].x, x[0].y) : null, m = new g.Vertex(m.x, m.y, m.z, v.vertexNormals[0], w), m.applyMatrix4(this.matrix), A.vertices.push(m), m = p.vertices[v.b], w = x ? new f.Vector2(x[1].x, x[1].y) : null, m = new g.Vertex(m.x, m.y, m.z, v.vertexNormals[2], w), m.applyMatrix4(this.matrix), A.vertices.push(m), m = p.vertices[v.c], w = x ? new f.Vector2(x[2].x, x[2].y) : null, m = new g.Vertex(m.x, m.y, m.z, v.vertexNormals[2], w), m.applyMatrix4(this.matrix), A.vertices.push(m)) : (f.Face4, m = p.vertices[v.a], w = x ? new f.Vector2(x[0].x, x[0].y) : null, m = new g.Vertex(m.x, m.y, m.z, v.vertexNormals[0], w), m.applyMatrix4(this.matrix), A.vertices.push(m), m = p.vertices[v.b], w = x ? new f.Vector2(x[1].x, x[1].y) : null, m = new g.Vertex(m.x, m.y, m.z, v.vertexNormals[1], w), m.applyMatrix4(this.matrix), A.vertices.push(m), m = p.vertices[v.c], w = x ? new f.Vector2(x[2].x, x[2].y) : null, m = new g.Vertex(m.x, m.y, m.z, v.vertexNormals[2], w), m.applyMatrix4(this.matrix), A.vertices.push(m), m = p.vertices[v.d], w = x ? new f.Vector2(x[3].x, x[3].y) : null, m = new g.Vertex(m.x, m.y, m.z, v.vertexNormals[3], w), m.applyMatrix4(this.matrix), A.vertices.push(m)), A.calculateProperties(), M.push(A); this.tree = new g.Node(M); }; return g.prototype.subtract = function(p) { var u = this.tree.clone(), y = p.tree.clone(); return u.invert(), u.clipTo(y), y.clipTo(u), y.invert(), y.clipTo(u), y.invert(), u.build(y.allPolygons()), u.invert(), u = new g(u), u.matrix = this.matrix, u; }, g.prototype.union = function(p) { var u = this.tree.clone(), y = p.tree.clone(); return u.clipTo(y), y.clipTo(u), y.invert(), y.clipTo(u), y.invert(), u.build(y.allPolygons()), u = new g(u), u.matrix = this.matrix, u; }, g.prototype.intersect = function(p) { var u = this.tree.clone(), y = p.tree.clone(); return u.invert(), y.clipTo(u), y.invert(), u.clipTo(y), y.clipTo(u), u.build(y.allPolygons()), u.invert(), u = new g(u), u.matrix = this.matrix, u; }, g.prototype.toGeometry = function() { var p, u, y, v, m, x, w, A, M, R, L = new f.Matrix4().getInverse(this.matrix), S = new f.Geometry(), I = this.tree.allPolygons(), T = I.length, _ = {}; for (p = 0; p < T; p++) for (y = I[p], v = y.vertices.length, u = 2; u < v; u++) R = [], A = y.vertices[0], R.push(new f.Vector2(A.uv.x, A.uv.y)), A = new f.Vector3(A.x, A.y, A.z), A.applyMatrix4(L), typeof _[A.x + "," + A.y + "," + A.z] > "u" ? (S.vertices.push(A), m = _[A.x + "," + A.y + "," + A.z] = S.vertices.length - 1) : m = _[A.x + "," + A.y + "," + A.z], A = y.vertices[u - 1], R.push(new f.Vector2(A.uv.x, A.uv.y)), A = new f.Vector3(A.x, A.y, A.z), A.applyMatrix4(L), typeof _[A.x + "," + A.y + "," + A.z] > "u" ? (S.vertices.push(A), x = _[A.x + "," + A.y + "," + A.z] = S.vertices.length - 1) : x = _[A.x + "," + A.y + "," + A.z], A = y.vertices[u], R.push(new f.Vector2(A.uv.x, A.uv.y)), A = new f.Vector3(A.x, A.y, A.z), A.applyMatrix4(L), typeof _[A.x + "," + A.y + "," + A.z] > "u" ? (S.vertices.push(A), w = _[A.x + "," + A.y + "," + A.z] = S.vertices.length - 1) : w = _[A.x + "," + A.y + "," + A.z], M = new f.Face3(m, x, w, new f.Vector3(y.normal.x, y.normal.y, y.normal.z)), S.faces.push(M), S.faceVertexUvs[0].push(R); return S; }, g.prototype.toBufferGeometry = function() { var p = this.toGeometry(), u = new f.BufferGeometry().fromGeometry(p); return u; }, g.prototype.toMesh = function(p) { var u = this.toBufferGeometry(), y = new f.Mesh(u, p); return y.position.setFromMatrixPosition(this.matrix), y.rotation.setFromRotationMatrix(this.matrix), y; }, g.Polygon = function(p) { p instanceof Array || (p = []), this.vertices = p, 0 < p.length ? this.calculateProperties() : this.normal = this.w = void 0; }, g.Polygon.prototype.calculateProperties = function() { var p = this.vertices[0], u = this.vertices[1], y = this.vertices[2]; return this.normal = u.clone().subtract(p).cross(y.clone().subtract(p)).normalize(), this.w = this.normal.clone().dot(p), this; }, g.Polygon.prototype.clone = function() { var p, u, y = new g.Polygon(); for (p = 0, u = this.vertices.length; p < u; p++) y.vertices.push(this.vertices[p].clone()); return y.calculateProperties(), y; }, g.Polygon.prototype.flip = function() { var p, u = []; for (this.normal.multiplyScalar(-1), this.w *= -1, p = this.vertices.length - 1; 0 <= p; p--) u.push(this.vertices[p]); return this.vertices = u, this; }, g.Polygon.prototype.classifyVertex = function(p) { var u = this.normal.dot(p) - this.w; return u < -a ? d : u > a ? l : c; }, g.Polygon.prototype.classifySide = function(p) { var u, y, v, m = 0, x = 0, w = p.vertices.length; for (u = 0; u < w; u++) y = p.vertices[u], v = this.classifyVertex(y), v === l ? m++ : v === d && x++; return 0 < m && x === 0 ? l : m === 0 && 0 < x ? d : m === 0 && x === 0 ? c : h6; }, g.Polygon.prototype.splitPolygon = function(p, u, y, v, m) { var x = this.classifySide(p); if (x === c) (0 < this.normal.dot(p.normal) ? u : y).push(p); else if (x === l) v.push(p); else if (x === d) m.push(p); else { var w, A, M, R, L, S, I, T, _, E = [], C = []; for (A = 0, w = p.vertices.length; A < w; A++) M = (A + 1) % w, S = p.vertices[A], I = p.vertices[M], R = this.classifyVertex(S), L = this.classifyVertex(I), R != d && E.push(S), R != l && C.push(S), (R | L) == h6 && (T = (this.w - this.normal.dot(S)) / this.normal.dot(I.clone().subtract(S)), _ = S.interpolate(I, T), E.push(_), C.push(_)); 3 <= E.length && v.push(new g.Polygon(E).calculateProperties()), 3 <= C.length && m.push(new g.Polygon(C).calculateProperties()); } }, g.Vertex = function(p, u, y, v, m) { this.x = p, this.y = u, this.z = y, this.normal = v || new f.Vector3(), this.uv = m || new f.Vector2(); }, g.Vertex.prototype.clone = function() { return new g.Vertex(this.x, this.y, this.z, this.normal.clone(), this.uv.clone()); }, g.Vertex.prototype.add = function(p) { return this.x += p.x, this.y += p.y, this.z += p.z, this; }, g.Vertex.prototype.subtract = function(p) { return this.x -= p.x, this.y -= p.y, this.z -= p.z, this; }, g.Vertex.prototype.multiplyScalar = function(p) { return this.x *= p, this.y *= p, this.z *= p, this; }, g.Vertex.prototype.cross = function(p) { var u = this.x, y = this.y, v = this.z; return this.x = y * p.z - v * p.y, this.y = v * p.x - u * p.z, this.z = u * p.y - y * p.x, this; }, g.Vertex.prototype.normalize = function() { var p = Math.sqrt(this.x * this.x + this.y * this.y + this.z * this.z); return this.x /= p, this.y /= p, this.z /= p, this; }, g.Vertex.prototype.dot = function(p) { return this.x * p.x + this.y * p.y + this.z * p.z; }, g.Vertex.prototype.lerp = function(p, u) { return this.add(p.clone().subtract(this).multiplyScalar(u)), this.normal.add(p.normal.clone().sub(this.normal).multiplyScalar(u)), this.uv.add(p.uv.clone().sub(this.uv).multiplyScalar(u)), this; }, g.Vertex.prototype.interpolate = function(p, u) { return this.clone().lerp(p, u); }, g.Vertex.prototype.applyMatrix4 = function(p) { var u = this.x, y = this.y, v = this.z, m = p.elements; return this.x = m[0] * u + m[4] * y + m[8] * v + m[12], this.y = m[1] * u + m[5] * y + m[9] * v + m[13], this.z = m[2] * u + m[6] * y + m[10] * v + m[14], this; }, g.Node = function(p) { var u, y, v = [], m = []; if (this.polygons = [], this.front = this.back = void 0, p instanceof Array && p.length !== 0) { for (this.divider = p[0].clone(), u = 0, y = p.length; u < y; u++) this.divider.splitPolygon(p[u], this.polygons, this.polygons, v, m); 0 < v.length && (this.front = new g.Node(v)), 0 < m.length && (this.back = new g.Node(m)); } }, g.Node.isConvex = function(p) { var u, y; for (u = 0; u < p.length; u++) for (y = 0; y < p.length; y++) if (u !== y && p[u].classifySide(p[y]) !== d) return false; return true; }, g.Node.prototype.build = function(p) { var u, y, v = [], m = []; for (this.divider || (this.divider = p[0].clone()), u = 0, y = p.length; u < y; u++) this.divider.splitPolygon(p[u], this.polygons, this.polygons, v, m); 0 < v.length && (!this.front && (this.front = new g.Node()), this.front.build(v)), 0 < m.length && (!this.back && (this.back = new g.Node()), this.back.build(m)); }, g.Node.prototype.allPolygons = function() { var p = this.polygons.slice(); return this.front && (p = p.concat(this.front.allPolygons())), this.back && (p = p.concat(this.back.allPolygons())), p; }, g.Node.prototype.clone = function() { var p = new g.Node(); return p.divider = this.divider.clone(), p.polygons = this.polygons.map(function(u) { return u.clone(); }), p.front = this.front && this.front.clone(), p.back = this.back && this.back.clone(), p; }, g.Node.prototype.invert = function() { var p, u, y; for (p = 0, u = this.polygons.length; p < u; p++) this.polygons[p].flip(); return this.divider.flip(), this.front && this.front.invert(), this.back && this.back.invert(), y = this.front, this.front = this.back, this.back = y, this; }, g.Node.prototype.clipPolygons = function(p) { var u, y, v, m; if (!this.divider) return p.slice(); for (v = [], m = [], u = 0, y = p.length; u < y; u++) this.divider.splitPolygon(p[u], v, m, v, m); return this.front && (v = this.front.clipPolygons(v)), m = this.back ? this.back.clipPolygons(m) : [], v.concat(m); }, g.Node.prototype.clipTo = function(p) { this.polygons = p.clipPolygons(this.polygons), this.front && this.front.clipTo(p), this.back && this.back.clipTo(p); }, g; }; }, /* 53 */ /***/ (o) => { o.exports = M4(); }, /* 54 */ /***/ (o) => { o.exports = R4; }, /* 55 */ /***/ (o, a, c) => { var l = c(3).Geometry, d = c(4), h6 = d.BufferGeometryLoader; o.exports = function(f) { var g = void 0, p = function(w) { var A = new h6(), M = A.parse(w), R = new d.MeshPhongMaterial(), L = new d.Mesh(M.geometry, R), S = new l(); return S.setMorph(L), S; }, u = function(w) { var A = p(w); g = new (c(56)).GeometryCSGInternal(A), f.postMessage({ action: "message", message: "Initialised" }); }, y = function(w) { if (g) { var A = p(w), M = g.intersect(A), R = M.toBufferGeometry().toJSON(); f.postMessage({ action: "result", object: R }); } }, v = function(w) { if (g) { var A = p(w), M = g.subtract(A), R = M.toBufferGeometry().toJSON(); f.postMessage({ action: "result", object: R }); } }, m = function(w) { if (g) { var A = p(w), M = g.union(A), R = M.toBufferGeometry().toJSON(); f.postMessage({ action: "result", object: R }); } }; f.addEventListener("message", function(x) { switch (x.data.action) { case "initialise": u(x.data.object); break; case "intersect": y(x.data.object); break; case "subtract": v(x.data.object); break; case "union": m(x.data.object); break; default: throw "Cannot handle specified action."; } }); }; }, /* 56 */ /***/ (o, a, c) => { var l = c(4), d = c(52)(l); c(3).Geometry, c(51).GeometryCSG; var h6 = function(f) { var g; f && f.isGeometry && (g = f); var p; this.setGeometry = (y) => { y && y.isGeometry && (g = y), p = void 0; }, this.setCSG = (y) => { p = y; }; var u = (y) => { if (g && g.morph && y && y.morph) { p === void 0 && (p = new d(g.morph)); var v = new d(y.morph); return v; } }; this.intersect = (y) => { var v = u(y); return p && v ? p.intersect(v) : void 0; }, this.subtract = (y) => { var v = u(y); return p && v ? p.subtract(v) : void 0; }, this.union = (y) => { var v = u(y); return p && v ? p.union(v) : void 0; }; }; a.GeometryCSGInternal = h6; }, /* 57 */ /***/ (o, a, c) => { var l = c(4), d = c(52)(l); c(18).Glyphset; var h6 = function(f) { var g; f && f.isGlyphset && (g = f); var p = []; this.setGlyphset = (v) => { v && v.isGlyphset && (g = v), hostCSG = void 0; }, this.getGlyphset = () => g; var u = () => (v) => { var m = v.getMesh(), x = v.getLabel(); if (m) { var w = new d(m.geometry.clone().applyMatrix(m.matrix)), A = []; A.csg = w, A.label = x, m.material && (A.material = m.material.clone()), p.push(A); } }, y = (v) => { if (g && v && v.getMorph()) { p.length == 0 && g.forEachGlyph(u()); var m = new d(v.getMorph()); return m; } }; this.intersect = (v) => { var m = y(v); if (0 < p.length && m) { for (var x = new (c(18)).Glyphset(), w = 0; w < p.length; w++) { var A = p[w], M = A.csg.intersect(m), R = M.toMesh(); if (R && R.geometry && 0 < R.geometry.vertices.length) { A.material && (R.material = A.material, R.material.side = l.DoubleSide, R.material.clippingPlanes = null); var L = x.addMeshAsGlyph(R, w + 1); L.setLabel(A.label); } } var S = new h6(x); return S; } }; }; a.GlyphsetCSG = h6; } /******/ ], i = {}; function r(o) { var a = i[o]; if (a !== void 0) return a.exports; var c = i[o] = { /******/ // no module.id needed /******/ // no module.loaded needed /******/ exports: {} /******/ }; return t[o].call(c.exports, c, c.exports, r), c.exports; } r.n = (o) => { var a = o && o.__esModule ? ( /******/ () => o.default ) : ( /******/ () => o ); return r.d(a, { a }), a; }, r.d = (o, a) => { for (var c in a) r.o(a, c) && !r.o(o, c) && Object.defineProperty(o, c, { enumerable: true, get: a[c] }); }, r.o = (o, a) => Object.prototype.hasOwnProperty.call(o, a), r.r = (o) => { typeof Symbol < "u" && Symbol.toStringTag && Object.defineProperty(o, Symbol.toStringTag, { value: "Module" }), Object.defineProperty(o, "__esModule", { value: true }); }; var s = r(0); return s; })() )); })(My); var Pr = My.exports; var Rc = GC(Pr); var Ai = { SELECTED_COLOUR: "#00ff00", HIGHLIGHTED_COLOUR: "#ff0000", DEFAULT_RADIUS: 1, DEFAULT_RADIAL_SEGMENTS: 8, ZOOM_RADIUS: 5, ZOOM_RADIAL_SEGMENTS: 12 }; var Sv = (n, e) => { if (n) { let t = ""; n.forEach((i) => { t = i.uuid, i.region && (t = i.region.uuid + "/" + t), i && i.getVisibility() && e.push(t); }); } return e; }; var Id = (n, e) => { const t = n[0] - e[0], i = n[1] - e[1], r = n[2] - e[2]; return Math.sqrt(t * t + i * i + r * r); }; var F4 = (n) => { const e = n.zincObjects; if (e.length > 0 && e[0]) { const t = e[0]; if (t.isEditable && t.isLines2) { const i = n.identifiers[0].extraData.intersected; if (i && i.faceIndex > -1) { const r = t.getVerticesByFaceIndex(i.faceIndex), s = n.identifiers[0].extraData.intersected.pointOnLine; if (r.length > 1) { const o = Id(r[0], [s.x, s.y, s.z]), a = Id(r[1], [s.x, s.y, s.z]); return o > a ? { zincObject: t, faceIndex: i.faceIndex, vertexIndex: i.faceIndex * 2 + 1, point: r[0] } : { zincObject: t, faceIndex: i.faceIndex, vertexIndex: i.faceIndex * 2, point: r[1] }; } } } } }; var P4 = (n) => { const e = n.zincObjects; if (e.length > 0 && e[0]) return e[0]; }; var I4 = (n) => { const e = n.zincObjects; if (e.length > 0 && e[0]) { const t = e[0]; if (t.isEditable) return t; } }; var O4 = (n, e, t) => { if (n != null && n.isEditable && (n != null && n.isPointset)) { let i = false; for (let r = 0; r < 3 && !i; r++) t[r] !== 0 && (i = true); if (i && e > -1) { const r = n.getVerticesByIndex(e); return r && (r[0] = r[0] + t[0], r[1] = r[1] + t[1], r[2] = r[2] + t[2]), n.editVertices([r], e), n.boundingBoxUpdateRequired = true, true; } } return false; }; var Mc = (n, e) => { if (n != null && n.isEditable && (n != null && n.isLines2) && e > -1) { const t = n.getVerticesByFaceIndex(e); if (t && t.length > 1) return Id(t[1], t[0]); } return 0; }; var Fh = (n, e, t, i) => { if (n && t !== 0 && n.isEditable && n.isLines2 && e > -1) { const r = n.getVerticesByFaceIndex(e); let s = [r[1][0] - r[0][0], r[1][1] - r[0][1], r[1][2] - r[0][2]]; const o = Math.sqrt(s[0] * s[0] + s[1] * s[1] + s[2] * s[2]); for (let a = 0; a < 3; a++) s[a] = s[a] / o * t, i ? r[1][a] = r[0][a] + s[a] : (r[0][a] = r[0][a] + s[a], r[1][a] = r[1][a] + s[a]); return n.editVertices(r, e * 2), n.boundingBoxUpdateRequired = true, true; } return false; }; var D4 = (n, e) => { const t = e.getBoundingBox(), i = new Pr.THREE.Vector3().subVectors(t.max, t.min), r = new Pr.THREE.BoxGeometry(i.x, i.y, i.z); i.addVectors(t.min, t.max).multiplyScalar(0.5); const s = r.getAttribute("position"), o = s.count, a = []; for (let c = 0; c < o; c++) a[c] = [ s.array[c * 3], s.array[c * 3 + 1], s.array[c * 3 + 2] ]; n.editVertices(a, 0), n.setPosition(i.x, i.y, i.z), r.dispose(); }; var yM = (n, e) => { let t = ""; n.isRegion && (t = `__r${n.regionPath}`), n.isPrimitives && (t = `${n.regionPath}/${n.label}`), e.push(t), n.children && n.children.forEach((i) => yM(i, e)); }; var xo = (n, e, t, i) => { let r = n; const s = []; if (t && (r = n.findChildFromPath(t)), r) { const o = Array.isArray(e); let a = e; o || (a = [a]), a.forEach((c) => { const l = r.findObjectsWithGroupName(c, i); s.push(...l); }); } return s; }; var Od = (n, e, t) => { const i = n.findIndex((s) => s.uuid === e); let r; return i > -1 && (r = n[i], t && n.splice(i, 1)), r; }; var N4 = (n, e) => { const t = []; if (n && e && e.length > 0) { const i = {}, r = {}, s = [n, ...n.getChildRegions(true)]; let o, a, c; e.forEach((l) => { const d = l.split("/"); c = d[0], o = Od(s, c, false), o && (r[c] || (r[c] = o.getFullPath()), d[1] ? (i[c] || (i[c] = o.getAllObjects(false)), a = Od(i[c], d[1], true), a && t.push(`${r[c]}/${a.groupName}`)) : t.push(`__r/${r[c]}`)); }); } return t; }; var B4 = (n) => { if (n) { const e = []; return n.forEach((i) => { i.isZincObject ? e.push(i) : i.isRegion && e.push(...i.getAllObjects(true)); }), Object.values( e.reduce((i, r) => ({ ...i, [r.uuid]: r }), {}) ); } return []; }; var _v = (n, e) => { const t = { label: "Multiple selections", regionPath: "", objects: [] }; if (e && n) { const i = {}, r = n.getRootRegion(); e.length > 0 && (t.regionPath = e[0].data.region, t.label = e[0].data.group), e.forEach((s) => { s.data.region.includes(t.regionPath) || (t.regionPath = ""), t.label !== s.data.group && (t.label = "Multiple selections"); const o = r.findChildFromPath(s.data.region); i[o.uuid] || (i[o.uuid] = o.getAllObjects(false)); const a = Od(i[o.uuid], s.data.uuid); a && t.objects.push(a); }); } return t; }; var U4 = (n) => { const e = n.getMorph(); let t = "position"; n.isLines2 && (t = "instanceStart"); const i = []; let r = 0; const s = e.geometry.getAttribute(t); for (let o = 0; o < n.drawRange; o++) i.push([ s.array[r++], s.array[r++], s.array[r++] ]); return i; }; var bM = (n, e, t, i, r) => { let s; n.isPointset ? s = "MultiPoint" : n.isLines2 ? s = "MultiLineString" : s = "Feature"; const o = s !== "Feature", a = s === "Feature" ? "Feature annotation" : "Drawn annotation"; if (s) { const c = U4(n); let l = e.slice(-1) === "/" ? e : e + "/"; l = l + t; const d = l, h6 = { resource: i, item: { id: d }, body: { evidence: [], comment: r }, feature: { id: d, properties: { drawn: o, label: a }, geometry: { coordinates: c, type: s } } }; return r === "Deleted" && (h6.feature = void 0), h6; } }; var Tv = (n, e, t, i, r, s, o) => { const a = bM(t, i, r, s, o); if (a) return n && n.currentUser && (a.creator = { ...n.currentUser }, a.creator.orcid || (a.creator.orcid = "0000-0000-0000-0000"), n.addAnnotation(e, a).then((c) => { c.annotationId || console.log("There is a problem with the submission, please try again later"); }).catch(() => { console.log("There is a problem with the submission, please try again later"); })), a; }; var Ev = async (n, e, t) => { const i = t; return await n.drawnFeatures(e, i); }; var Cv = (n, e) => { n && e.forEach((t) => { const i = t.geometry, r = decodeURIComponent(t.id), s = r.lastIndexOf("/"), o = r.substring(0, s), a = r.substring(s + 1); let c; i.type === "MultiPoint" ? c = n.createPoints( o, a, i.coordinates, a, 8942 ) : i.type === "MultiLineString" && (c = n.createLines( o, a, i.coordinates, 60962 )), c && (c.zincObject.isEditable = true); }); }; var pp = function(n) { const e = []; for (let t = 0; t < n.length; t++) { let i = n[t].userData; if (i) if (i.isGlyph || i.isGlyphset) { let r = i; i.isGlyph && (r = i.getGlyphset()), e.push(r); } else e.push(i); } return e; }; var mr = (n, e) => { const t = n.__vccOpts || n; for (const [i, r] of e) t[i] = r; return t; }; var z4 = { name: "LinesControls", components: { Button: Ko, Col: bi, Container: zi, InputNumber: dr, Main: hr, Slider: ti, ElIconArrowLeft: zr, ElIconArrowRight: Vr }, props: { createData: { type: Object }, usageConfig: { type: Object } }, data: function() { return { adjust: 0, pAdjust: 0, lengthScale: 0, distance: 0, newDistance: 0, width: 1, radius: Ai.DEFAULT_RADIUS, radialSegments: Ai.DEFAULT_RADIAL_SEGMENTS, currentIndex: 0, ElIconArrowLeft: shallowRef(zr), ElIconArrowRight: shallowRef(Vr), edited: false, zincObject: void 0, isTubeLines: false }; }, computed: { showTubeLinesControls() { return this.usageConfig.showTubeLinesControls; } }, watch: { "createData.faceIndex": { handler: function(n) { var e; (e = this.zincObject) != null && e.isLines2 && (this.currentIndex = n, this.distance = Mc(this.zincObject, this.currentIndex)); }, immediate: true } }, methods: { changeIndex: function(n) { n ? Mc(this.zincObject, this.currentIndex + 1) > 0 && (this.currentIndex++, this.reset()) : (this.currentIndex--, this.reset()); }, onLengthInput: function() { this.newDistance !== 0 ? (this.distance = this.newDistance, this.edited = Fh( this.zincObject, this.currentIndex, this.newDistance, true ) || this.edited) : this.newDistance = this.distance; }, onLengthSliding: function() { this.newDistance = Math.pow(10, this.lengthScale) * this.distance, this.edited = Fh( this.zincObject, this.currentIndex, this.newDistance, true ) || this.edited; }, onMoveSliding: function() { const n = (this.adjust - this.pAdjust) * this.distance; this.edited = Fh( this.zincObject, this.currentIndex, n, false ) || this.edited, this.pAdjust = this.adjust; }, reset: function() { this.adjust = 0, this.pAdjust = 0, this.lengthScale = 0, this.distance = Mc(this.zincObject, this.currentIndex), this.newDistance = this.distance, this.edited && (this.$emit("primitivesUpdated", this.zincObject), this.edited = false); }, setObject: function(n) { var e; this.currentIndex = -1, this.distance = 0, n.isLines2 || n.isTubeLines ? (this.zincObject = markRaw(n), this.width = this.zincObject.getMorph().material.linewidth, this.isTubeLines = n.isTubeLines, n.isEditable ? (this.currentIndex = 0, this.distance = Mc(n, this.currentIndex)) : (e = n.userData) != null && e.isNerves && (this.radius = Ai.ZOOM_RADIUS, this.radialSegments = Ai.ZOOM_RADIAL_SEGMENTS)) : (this.zincObject = void 0, this.width = 10); }, modifyWidth: function() { this.zincObject.setWidth(this.width); }, modifyTubeLines: function() { this.zincObject.setTubeLines(this.radius, this.radius * this.radialSegments); } } }; function V4(n, e, t, i, r, s) { const o = bi, a = ti, c = dr, l = Ui, d = Ko, h6 = hr, f = zi; return openBlock(), createBlock(f, { class: "lines-container" }, { default: withCtx(() => [ createVNode(h6, { class: "slides-block" }, { default: withCtx(() => [ n.isTubeLines && s.showTubeLinesControls ? (openBlock(), createElementBlock(Fragment, { key: 0 }, [ createVNode(l, null, { default: withCtx(() => [ createVNode(o, { offset: 0, span: 6 }, { default: withCtx(() => e[15] || (e[15] = [ createTextVNode(" Radius: ") ])), _: 1 }), createVNode(o, { offset: 0, span: 12 }, { default: withCtx(() => [ createVNode(a, { modelValue: n.radius, "onUpdate:modelValue": e[0] || (e[0] = (g) => n.radius = g), class: "my-slider", step: 1, min: 1, max: 32, "show-tooltip": false, onInput: s.modifyTubeLines }, null, 8, ["modelValue", "onInput"]) ]), _: 1 }), createVNode(o, { offset: 0, span: 4 }, { default: withCtx(() => [ createVNode(c, { modelValue: n.radius, "onUpdate:modelValue": e[1] || (e[1] = (g) => n.radius = g), step: 1, min: 1, max: 32, controls: false, onChange: s.modifyTubeLines, class: "input-box number-input" }, null, 8, ["modelValue", "onChange"]) ]), _: 1 }) ]), _: 1 }), createVNode(l, null, { default: withCtx(() => [ createVNode(o, { offset: 0, span: 6 }, { default: withCtx(() => e[16] || (e[16] = [ createTextVNode(" Radial Segments: ") ])), _: 1 }), createVNode(o, { offset: 0, span: 12 }, { default: withCtx(() => [ createVNode(a, { modelValue: n.radialSegments, "onUpdate:modelValue": e[2] || (e[2] = (g) => n.radialSegments = g), class: "my-slider", step: 1, min: 8, max: 32, "show-tooltip": false, onInput: s.modifyTubeLines }, null, 8, ["modelValue", "onInput"]) ]), _: 1 }), createVNode(o, { offset: 0, span: 4 }, { default: withCtx(() => [ createVNode(c, { modelValue: n.radialSegments, "onUpdate:modelValue": e[3] || (e[3] = (g) => n.radialSegments = g), step: 1, min: 8, max: 32, controls: false, onChange: s.modifyTubeLines, class: "input-box number-input" }, null, 8, ["modelValue", "onChange"]) ]), _: 1 }) ]), _: 1 }) ], 64)) : n.isTubeLines ? createCommentVNode("", true) : (openBlock(), createBlock(l, { key: 1 }, { default: withCtx(() => [ createVNode(o, { offset: 0, span: 6 }, { default: withCtx(() => e[17] || (e[17] = [ createTextVNode(" Width: ") ])), _: 1 }), createVNode(o, { offset: 0, span: 12 }, { default: withCtx(() => [ createVNode(a, { modelValue: n.width, "onUpdate:modelValue": e[4] || (e[4] = (g) => n.width = g), class: "my-slider", step: 1, min: 1, max: 100, "show-tooltip": false, onInput: s.modifyWidth }, null, 8, ["modelValue", "onInput"]) ]), _: 1 }), createVNode(o, { offset: 0, span: 4 }, { default: withCtx(() => [ createVNode(c, { modelValue: n.width, "onUpdate:modelValue": e[5] || (e[5] = (g) => n.width = g), step: 1, min: 1, max: 100, controls: false, class: "input-box number-input" }, null, 8, ["modelValue"]) ]), _: 1 }) ]), _: 1 })), n.currentIndex > -1 && n.distance > 0 ? (openBlock(), createElementBlock(Fragment, { key: 2 }, [ createVNode(l, null, { default: withCtx(() => [ createVNode(o, { offset: 0, span: 4 }, { default: withCtx(() => [ createVNode(d, { size: "small", disabled: n.currentIndex === 0, icon: n.ElIconArrowLeft, onClick: e[6] || (e[6] = (g) => s.changeIndex(false)) }, null, 8, ["disabled", "icon"]) ]), _: 1 }), createVNode(o, { offset: 4, span: 9 }, { default: withCtx(() => [ createTextVNode(" Editing Line " + toDisplayString(n.currentIndex + 1), 1) ]), _: 1 }), createVNode(o, { offset: 2, span: 2 }, { default: withCtx(() => [ createVNode(d, { size: "small", icon: n.ElIconArrowRight, onClick: e[7] || (e[7] = (g) => s.changeIndex(true)) }, null, 8, ["icon"]) ]), _: 1 }) ]), _: 1 }), createVNode(l, null, { default: withCtx(() => [ createVNode(o, { offset: 0, span: 6 }, { default: withCtx(() => e[18] || (e[18] = [ createTextVNode(" Move: ") ])), _: 1 }), createVNode(o, { offset: 0, span: 16 }, { default: withCtx(() => [ createVNode(a, { modelValue: n.adjust, "onUpdate:modelValue": e[8] || (e[8] = (g) => n.adjust = g), step: 0.01, min: -3, max: 3, "show-tooltip": false, onInput: e[9] || (e[9] = (g) => s.onMoveSliding()), onChange: e[10] || (e[10] = (g) => s.reset()) }, null, 8, ["modelValue"]) ]), _: 1 }) ]), _: 1 }), createVNode(l, null, { default: withCtx(() => [ createVNode(o, { offset: 0, span: 6 }, { default: withCtx(() => e[19] || (e[19] = [ createTextVNode(" Length: ") ])), _: 1 }), createVNode(o, { offset: 0, span: 10 }, { default: withCtx(() => [ createVNode(a, { modelValue: n.lengthScale, "onUpdate:modelValue": e[11] || (e[11] = (g) => n.lengthScale = g), step: 0.01, min: -1, max: 1, "show-tooltip": false, onInput: e[12] || (e[12] = (g) => s.onLengthSliding()), onChange: e[13] || (e[13] = (g) => s.reset()) }, null, 8, ["modelValue"]) ]), _: 1 }), createVNode(o, { offset: 0, span: 6 }, { default: withCtx(() => [ createVNode(c, { modelValue: n.newDistance, "onUpdate:modelValue": e[14] || (e[14] = (g) => n.newDistance = g), controls: false, class: "input-box number-input", onChange: s.onLengthInput }, null, 8, ["modelValue", "onChange"]) ]), _: 1 }) ]), _: 1 }) ], 64)) : createCommentVNode("", true) ]), _: 1 }) ]), _: 1 }); } var xM = mr(z4, [["render", V4], ["__scopeId", "data-v-0deb177d"]]); var k4 = { name: "PointsControls", components: { Col: bi, Container: zi, InputNumber: dr, Main: hr, Select: qo, Slider: ti, Row: Ui, Option: Qo, ElIconArrowLeft: zr, ElIconArrowRight: Vr }, inject: ["boundingDims"], data: function() { return { attenuation: false, size: 10, choices: [ { value: true, label: "On" }, { value: false, label: "off" } ], min: [0, 0, 0], max: [1, 1, 1], translation: [0, 0, 0], pTranslation: [0, 0, 0], currentIndex: -1, ElIconArrowLeft: shallowRef(zr), ElIconArrowRight: shallowRef(Vr), edited: false, zincObject: void 0 }; }, watch: { boundingDims: { handler: function(n) { const e = n.size; this.min = [ -e[0] / 2, -e[1] / 2, -e[2] / 2 ], this.max = [ e[0] / 2, e[1] / 2, e[2] / 2 ]; }, immediate: true, deep: true } }, methods: { changeIndex: function(n) { n ? this.zincObject.drawRange > this.currentIndex + 1 && (this.currentIndex++, this.reset()) : (this.currentIndex--, this.reset()); }, onMoveSliding: function() { const n = [ this.translation[0] - this.pTranslation[0], this.translation[1] - this.pTranslation[1], this.translation[2] - this.pTranslation[2] ]; this.edited = O4(this.zincObject, this.currentIndex, n) || this.edited; for (let e = 0; e < 3; e++) this.pTranslation[e] = this.translation[e]; }, reset: function() { this.translation = [0, 0, 0], this.pTranslation = [0, 0, 0], this.edited && (this.$emit("primitivesUpdated", this.zincObject), this.edited = false); }, setObject: function(n) { this.currentIndex = -1, n.isPointset ? (this.zincObject = markRaw(n), this.size = this.zincObject.morph.material.size, this.attenuation = this.zincObject.morph.material.sizeAttenuation, n.isEditable && this.zincObject.drawRange > 0 && (this.currentIndex = 0)) : (this.zincObject = void 0, this.size = 10, this.attenuation = false); }, modifyAttenuation: function(n) { this.attenuation = n, this.zincObject.setSizeAttenuation(n); }, modifySize: function() { this.zincObject.setSize(this.size); } } }; function G4(n, e, t, i, r, s) { const o = bi, a = ti, c = dr, l = Ui, d = Qo, h6 = qo, f = Ko, g = hr, p = zi; return openBlock(), createBlock(p, { class: "pointset-container" }, { default: withCtx(() => [ createVNode(g, { class: "slides-block" }, { default: withCtx(() => [ createVNode(l, null, { default: withCtx(() => [ createVNode(o, { offset: 0, span: 6 }, { default: withCtx(() => e[15] || (e[15] = [ createTextVNode(" Size: ") ])), _: 1 }), createVNode(o, { offset: 0, span: 10 }, { default: withCtx(() => [ createVNode(a, { modelValue: n.size, "onUpdate:modelValue": e[0] || (e[0] = (u) => n.size = u), class: "my-slider", step: 1, min: 0, max: 100, "show-tooltip": false, onInput: e[1] || (e[1] = (u) => s.modifySize()) }, null, 8, ["modelValue"]) ]), _: 1 }), createVNode(o, { offset: 0, span: 6 }, { default: withCtx(() => [ createVNode(c, { modelValue: n.size, "onUpdate:modelValue": e[2] || (e[2] = (u) => n.size = u), step: 1, min: 0, max: 100, controls: false, class: "input-box number-input" }, null, 8, ["modelValue"]) ]), _: 1 }) ]), _: 1 }), createVNode(l, null, { default: withCtx(() => [ createVNode(o, { offset: 0, span: 16 }, { default: withCtx(() => e[16] || (e[16] = [ createTextVNode(" Size attenuation: ") ])), _: 1 }), createVNode(o, { offset: 0, span: 5 }, { default: withCtx(() => [ createVNode(h6, { teleported: false, "model-value": n.attenuation, placeholder: "Select", class: "input-box", "popper-class": "viewer_dropdown", onChange: e[3] || (e[3] = (u) => s.modifyAttenuation(u, n.slide)) }, { default: withCtx(() => [ (openBlock(true), createElementBlock(Fragment, null, renderList(n.choices, (u) => (openBlock(), createBlock(d, { key: u.value, label: u.label, value: u.value }, null, 8, ["label", "value"]))), 128)) ]), _: 1 }, 8, ["model-value"]) ]), _: 1 }) ]), _: 1 }), n.currentIndex > -1 ? (openBlock(), createElementBlock(Fragment, { key: 0 }, [ createVNode(l, null, { default: withCtx(() => [ createVNode(o, { offset: 0, span: 4 }, { default: withCtx(() => [ createVNode(f, { size: "small", disabled: n.currentIndex === 0, icon: n.ElIconArrowLeft, onClick: e[4] || (e[4] = (u) => s.changeIndex(false)) }, null, 8, ["disabled", "icon"]) ]), _: 1 }), createVNode(o, { offset: 4, span: 9 }, { default: withCtx(() => [ createTextVNode(" Editing Point " + toDisplayString(n.currentIndex + 1), 1) ]), _: 1 }), createVNode(o, { offset: 2, span: 2 }, { default: withCtx(() => [ createVNode(f, { size: "small", icon: n.ElIconArrowRight, onClick: e[5] || (e[5] = (u) => s.changeIndex(true)) }, null, 8, ["icon"]) ]), _: 1 }) ]), _: 1 }), createVNode(l, null, { default: withCtx(() => [ createVNode(o, { offset: 0, span: 6 }, { default: withCtx(() => e[17] || (e[17] = [ createTextVNode(" x: ") ])), _: 1 }), createVNode(o, { offset: 0, span: 16 }, { default: withCtx(() => [ createVNode(a, { modelValue: n.translation[0], "onUpdate:modelValue": e[6] || (e[6] = (u) => n.translation[0] = u), step: 0.01, min: n.min[0], max: n.max[0], "show-tooltip": false, onInput: e[7] || (e[7] = (u) => s.onMoveSliding()), onChange: e[8] || (e[8] = (u) => s.reset()) }, null, 8, ["modelValue", "min", "max"]) ]), _: 1 }) ]), _: 1 }), createVNode(l, null, { default: withCtx(() => [ createVNode(o, { offset: 0, span: 6 }, { default: withCtx(() => e[18] || (e[18] = [ createTextVNode(" y: ") ])), _: 1 }), createVNode(o, { offset: 0, span: 16 }, { default: withCtx(() => [ createVNode(a, { modelValue: n.translation[1], "onUpdate:modelValue": e[9] || (e[9] = (u) => n.translation[1] = u), step: 0.01, min: n.min[1], max: n.max[1], "show-tooltip": false, onInput: e[10] || (e[10] = (u) => s.onMoveSliding()), onChange: e[11] || (e[11] = (u) => s.reset()) }, null, 8, ["modelValue", "min", "max"]) ]), _: 1 }) ]), _: 1 }), createVNode(l, null, { default: withCtx(() => [ createVNode(o, { offset: 0, span: 6 }, { default: withCtx(() => e[19] || (e[19] = [ createTextVNode(" z: ") ])), _: 1 }), createVNode(o, { offset: 0, span: 16 }, { default: withCtx(() => [ createVNode(a, { modelValue: n.translation[2], "onUpdate:modelValue": e[12] || (e[12] = (u) => n.translation[2] = u), step: 0.01, min: n.min[2], max: n.max[2], "show-tooltip": false, onInput: e[13] || (e[13] = (u) => s.onMoveSliding()), onChange: e[14] || (e[14] = (u) => s.reset()) }, null, 8, ["modelValue", "min", "max"]) ]), _: 1 }) ]), _: 1 }) ], 64)) : createCommentVNode("", true) ]), _: 1 }) ]), _: 1 }); } var MM = mr(k4, [["render", G4], ["__scopeId", "data-v-d1de9c65"]]); var H4 = { name: "TextureSlidesControls", components: { Col: bi, Container: zi, Footer: dy, Icon: It, InputNumber: dr, Main: hr, Row: Ui, Select: qo, Slider: ti, Option: Qo, ElIconDelete: Nc, ElIconPlus: tu }, data: function() { return { settings: [], directions: [ { value: "x", label: "x" }, { value: "y", label: "y" }, { value: "z", label: "z" } ], zincObject: void 0 }; }, methods: { setObject: function(n) { n.isTextureSlides ? (this.zincObject = markRaw(n), this.settings = this.zincObject.getTextureSettings()) : (this.zincObject = void 0, this.settings = []); }, addNewSlide: function() { const n = { direction: "x", value: 0 }, e = this.zincObject.createSlide(n); this.settings.push(e); }, modifyDirection: function(n, e) { e && (e.direction = n, this.zincObject.modifySlideSettings(e)); }, modifySlide: function(n) { n && this.zincObject.modifySlideSettings(n); }, removeSlide: function(n, e) { this.zincObject.removeSlideWithId(e.id), this.settings.splice(n, 1); } } }; function W4(n, e, t, i, r, s) { const o = Qo, a = qo, c = bi, l = ti, d = dr, h6 = Nc, f = It, g = Ui, p = hr, u = tu, y = dy, v = zi; return openBlock(), createBlock(v, { class: "t-slides-container" }, { default: withCtx(() => [ createVNode(p, { class: "slides-block" }, { default: withCtx(() => [ (openBlock(true), createElementBlock(Fragment, null, renderList(n.settings, (m, x) => (openBlock(), createBlock(g, { key: m.id, class: "slide-row" }, { default: withCtx(() => [ createVNode(c, { offset: 0, span: 6 }, { default: withCtx(() => [ createVNode(a, { teleported: false, "model-value": m.direction, placeholder: "Select", class: "input-box", "popper-class": "viewer_dropdown", onChange: (w) => s.modifyDirection(w, m) }, { default: withCtx(() => [ (openBlock(true), createElementBlock(Fragment, null, renderList(n.directions, (w) => (openBlock(), createBlock(o, { key: w.value, label: w.label, value: w.value }, null, 8, ["label", "value"]))), 128)) ]), _: 2 }, 1032, ["model-value", "onChange"]) ]), _: 2 }, 1024), createVNode(c, { offset: 0, span: 10 }, { default: withCtx(() => [ createVNode(l, { modelValue: m.value, "onUpdate:modelValue": (w) => m.value = w, class: "my-slider", step: 0.01, min: 0, max: 1, "show-tooltip": false, onInput: (w) => s.modifySlide(m) }, null, 8, ["modelValue", "onUpdate:modelValue", "onInput"]) ]), _: 2 }, 1024), createVNode(c, { offset: 0, span: 6 }, { default: withCtx(() => [ createVNode(d, { modelValue: m.value, "onUpdate:modelValue": (w) => m.value = w, step: 0.01, min: 0, max: 1, controls: false, class: "input-box number-input" }, null, 8, ["modelValue", "onUpdate:modelValue"]) ]), _: 2 }, 1024), createVNode(c, { offset: 0, span: 2 }, { default: withCtx(() => [ createVNode(f, { class: "delete-icon", onClick: (w) => s.removeSlide(x, m) }, { default: withCtx(() => [ createVNode(h6) ]), _: 2 }, 1032, ["onClick"]) ]), _: 2 }, 1024) ]), _: 2 }, 1024))), 128)) ]), _: 1 }), createVNode(y, { height: "30px", class: "add-slides-text", onClick: s.addNewSlide }, { default: withCtx(() => [ createVNode(g, null, { default: withCtx(() => [ createVNode(c, { span: 2 }, { default: withCtx(() => [ createVNode(f, null, { default: withCtx(() => [ createVNode(u) ]), _: 1 }) ]), _: 1 }), createVNode(c, { span: 20 }, { default: withCtx(() => e[0] || (e[0] = [ createTextVNode(" Add a new slide ") ])), _: 1 }) ]), _: 1 }) ]), _: 1 }, 8, ["onClick"]) ]), _: 1 }); } var wM = mr(H4, [["render", W4], ["__scopeId", "data-v-12185b7f"]]); var j4 = { name: "TransformationControls", components: { Col: bi, Container: zi, InputNumber: dr, Main: hr, Slider: ti }, inject: ["boundingDims"], data: function() { return { x: 0, y: 0, z: 0, scale: 1, min: [0, 0, 0], max: [1, 1, 1], zincObject: void 0, enableScaling: true }; }, watch: { boundingDims: { handler: function(n) { const e = n.centre, t = n.size; this.min = [ e[0] - t[0], e[1] - t[1], e[2] - t[2] ], this.max = [ e[0] + t[0], e[1] + t[1], e[2] + t[2] ]; }, immediate: true, deep: true } }, methods: { setObject: function(n) { if (n.isZincObject) { this.zincObject = markRaw(n); const e = this.zincObject.getGroup(), t = this.zincObject.userData.originalPos; e && e.position && (this.x = e.position.x, this.y = e.position.y, this.z = e.position.z, this.zincObject.isGlyphset ? this.scale = this.zincObject.globalScale : this.scale = e.scale.x, this.enableScaling = !this.zincObject.isTextureSlides, t && this.boundingDims && (this.min = [ t[0] - this.boundingDims.size[0], t[1] - this.boundingDims.size[1], t[2] - this.boundingDims.size[2] ], this.max = [ t[0] + this.boundingDims.size[0], t[1] + this.boundingDims.size[1], t[2] + this.boundingDims.size[2] ])); } else this.zincObject = void 0, this.x = 0, this.y = 0, this.z = 0, this.scale = 1; }, modifyPosition: function() { this.zincObject && this.zincObject.setPosition(this.x, this.y, this.z); }, modifyScale: function() { this.zincObject.setScaleAll(this.scale); } } }; function $4(n, e, t, i, r, s) { const o = bi, a = ti, c = dr, l = Ui, d = hr, h6 = zi; return openBlock(), createBlock(h6, { class: "transformation-container" }, { default: withCtx(() => [ createVNode(d, { class: "slides-block" }, { default: withCtx(() => [ createVNode(l, { class: "tool-row" }, { default: withCtx(() => [ createVNode(o, { offset: 0, span: 6 }, { default: withCtx(() => e[16] || (e[16] = [ createTextVNode(" x: ") ])), _: 1 }), createVNode(o, { offset: 0, span: 10 }, { default: withCtx(() => [ createVNode(a, { modelValue: n.x, "onUpdate:modelValue": e[0] || (e[0] = (f) => n.x = f), step: 0.01, min: n.min[0], max: n.max[0], "show-tooltip": false, onInput: e[1] || (e[1] = (f) => s.modifyPosition()) }, null, 8, ["modelValue", "min", "max"]) ]), _: 1 }), createVNode(o, { offset: 0, span: 6 }, { default: withCtx(() => [ createVNode(c, { modelValue: n.x, "onUpdate:modelValue": e[2] || (e[2] = (f) => n.x = f), step: 0.01, min: n.min[0], max: n.max[0], controls: false, class: "input-box number-input", onChange: e[3] || (e[3] = (f) => s.modifyPosition()) }, null, 8, ["modelValue", "min", "max"]) ]), _: 1 }) ]), _: 1 }), createVNode(l, { class: "tool-row" }, { default: withCtx(() => [ createVNode(o, { offset: 0, span: 6 }, { default: withCtx(() => e[17] || (e[17] = [ createTextVNode(" y: ") ])), _: 1 }), createVNode(o, { offset: 0, span: 10 }, { default: withCtx(() => [ createVNode(a, { modelValue: n.y, "onUpdate:modelValue": e[4] || (e[4] = (f) => n.y = f), step: 0.01, min: n.min[1], max: n.max[1], "show-tooltip": false, onInput: e[5] || (e[5] = (f) => s.modifyPosition()) }, null, 8, ["modelValue", "min", "max"]) ]), _: 1 }), createVNode(o, { offset: 0, span: 6 }, { default: withCtx(() => [ createVNode(c, { modelValue: n.y, "onUpdate:modelValue": e[6] || (e[6] = (f) => n.y = f), step: 0.01, min: n.min[1], max: n.max[1], controls: false, class: "input-box number-input", onChange: e[7] || (e[7] = (f) => s.modifyPosition()) }, null, 8, ["modelValue", "min", "max"]) ]), _: 1 }) ]), _: 1 }), createVNode(l, { class: "tool-row" }, { default: withCtx(() => [ createVNode(o, { offset: 0, span: 6 }, { default: withCtx(() => e[18] || (e[18] = [ createTextVNode(" z: ") ])), _: 1 }), createVNode(o, { offset: 0, span: 10 }, { default: withCtx(() => [ createVNode(a, { modelValue: n.z, "onUpdate:modelValue": e[8] || (e[8] = (f) => n.z = f), step: 0.01, min: n.min[2], max: n.max[2], "show-tooltip": false, onInput: e[9] || (e[9] = (f) => s.modifyPosition()) }, null, 8, ["modelValue", "min", "max"]) ]), _: 1 }), createVNode(o, { offset: 0, span: 6 }, { default: withCtx(() => [ createVNode(c, { modelValue: n.z, "onUpdate:modelValue": e[10] || (e[10] = (f) => n.z = f), step: 0.01, min: n.min[2], max: n.max[2], controls: false, class: "input-box number-input", onChange: e[11] || (e[11] = (f) => s.modifyPosition()) }, null, 8, ["modelValue", "min", "max"]) ]), _: 1 }) ]), _: 1 }), n.enableScaling ? (openBlock(), createBlock(l, { key: 0, class: "tool-row" }, { default: withCtx(() => [ createVNode(o, { offset: 0, span: 6 }, { default: withCtx(() => e[19] || (e[19] = [ createTextVNode(" Scale: ") ])), _: 1 }), createVNode(o, { offset: 0, span: 10 }, { default: withCtx(() => [ createVNode(a, { modelValue: n.scale, "onUpdate:modelValue": e[12] || (e[12] = (f) => n.scale = f), step: 0.01, min: 0, max: 5, "show-tooltip": false, onInput: e[13] || (e[13] = (f) => s.modifyScale()) }, null, 8, ["modelValue"]) ]), _: 1 }), createVNode(o, { offset: 0, span: 6 }, { default: withCtx(() => [ createVNode(c, { modelValue: n.scale, "onUpdate:modelValue": e[14] || (e[14] = (f) => n.scale = f), step: 0.01, min: 0, max: 5, controls: false, class: "input-box number-input", onChange: e[15] || (e[15] = (f) => s.modifyScale()) }, null, 8, ["modelValue"]) ]), _: 1 }) ]), _: 1 })) : createCommentVNode("", true) ]), _: 1 }) ]), _: 1 }); } var AM = mr(j4, [["render", $4], ["__scopeId", "data-v-cd88ead8"]]); var Z4 = { name: "OpacityControls", components: { Container: zi, Header: jL, Main: hr, Slider: ti }, props: { material: void 0, zincObject: void 0 }, data: function() { return { displayString: "100%" }; }, watch: { "material.opacity": function() { this.material && this.zincObject && this.zincObject.setAlpha(this.material.opacity); } }, methods: { formatTooltip(n) { return this.displayString = Math.floor(100 * n + 0.5) + "%", this.displayString; } } }; var X4 = { class: "block" }; var Y4 = { class: "display" }; function J4(n, e, t, i, r, s) { const o = ti, a = zi; return t.material ? (openBlock(), createBlock(a, { key: 0, class: "opacity-container" }, { default: withCtx(() => [ createBaseVNode("div", X4, [ createBaseVNode("span", Y4, toDisplayString(n.displayString), 1), createVNode(o, { modelValue: t.material.opacity, "onUpdate:modelValue": e[0] || (e[0] = (c) => t.material.opacity = c), class: "my-slider", step: 0.01, min: 0, max: 1, "format-tooltip": s.formatTooltip, "show-tooltip": false }, null, 8, ["modelValue", "format-tooltip"]) ]) ]), _: 1 })) : createCommentVNode("", true); } var SM = mr(Z4, [["render", J4], ["__scopeId", "data-v-cbfc46a5"]]); var K4 = { name: "PrimitiveControls", components: { Collapse: oy, CollapseItem: ay, LinesControls: xM, OpacityControls: SM, PointsControls: MM, TextureSlidesControls: wM, TransformationControls: AM, ElIconArrowRight: Vr }, props: { createData: { type: Object }, viewingMode: { type: String, default: "Exploration" }, usageConfig: { type: Object } }, data: function() { return { activeName: "oControls", material: void 0, isTextureSlides: false, isPointset: false, isLines: false, drawerOpen: true, zincObject: void 0, isEditable: false, displayString: "100%" }; }, computed: { hasValidPrimitive: function() { return this.viewingMode === "Exploration" || this.viewingMode === "Annotation" ? this.material !== void 0 || this.isTextureSlides === true : false; } }, methods: { formatTooltip: function(n) { return this.displayString = Math.floor(100 * n + 0.5) + "%", this.displayString; }, toggleDrawer: function() { this.drawerOpen = !this.drawerOpen; }, setObject: function(n) { var e, t; n ? this.zincObject = markRaw(n) : this.zincObject = void 0, this.isEditable = !!((e = this.zincObject) != null && e.isEditable), this.isPointset = false, this.isTextureSlides = false, this.isLines = false, this.activeName = "trControls", n && (n.isTextureSlides ? (this.isTextureSlides = true, this.$refs.tSlidesControls.setObject(n), this.activeName = "tsControls") : n.isPointset ? (this.isPointset = true, this.$refs.pointsetControls.setObject(n), this.activeName = "pControls") : (n.isLines2 || n.isTubeLines && ((t = this.usageConfig) != null && t.showTubeLinesControls)) && (this.isLines = true, this.$refs.linesControls.setObject(n), this.activeName = "lControls"), this.$refs.transformationControls.setObject(n)), n && n.getMorph() ? this.material = n.getMorph().material : this.material = void 0; } } }; function q4(n, e, t, i, r, s) { const o = SM, a = ay, c = AM, l = wM, d = MM, h6 = xM, f = oy, g = Vr, p = It; return withDirectives((openBlock(), createElementBlock("div", { class: normalizeClass(["primitive-controls", { open: n.drawerOpen, close: !n.drawerOpen }]) }, [ createBaseVNode("div", { class: normalizeClass(["my-drawer", { open: n.drawerOpen, close: !n.drawerOpen }]) }, [ createVNode(f, { class: "collapse", modelValue: n.activeName, "onUpdate:modelValue": e[2] || (e[2] = (u) => n.activeName = u), accordion: "" }, { default: withCtx(() => [ withDirectives(createVNode(a, { title: "Opacity", name: "oControls" }, { default: withCtx(() => [ createVNode(o, { material: n.material, zincObject: n.zincObject, ref: "opacityControls" }, null, 8, ["material", "zincObject"]) ]), _: 1 }, 512), [ [vShow, !n.isTextureSlides] ]), withDirectives(createVNode(a, { title: "Transformation", name: "trControls" }, { default: withCtx(() => [ createVNode(c, { class: "transformation-controls", ref: "transformationControls" }, null, 512) ]), _: 1 }, 512), [ [vShow, !n.isEditable] ]), withDirectives(createVNode(a, { title: "Texture Slides", name: "tsControls" }, { default: withCtx(() => [ createVNode(l, { class: "texture-controls", ref: "tSlidesControls" }, null, 512) ]), _: 1 }, 512), [ [vShow, n.isTextureSlides] ]), withDirectives(createVNode(a, { title: "Points", name: "pControls" }, { default: withCtx(() => [ createVNode(d, { class: "pointset-controls", ref: "pointsetControls", onPrimitivesUpdated: e[0] || (e[0] = (u) => n.$emit("primitivesUpdated", u)) }, null, 512) ]), _: 1 }, 512), [ [vShow, n.isPointset] ]), withDirectives(createVNode(a, { title: "Lines", name: "lControls" }, { default: withCtx(() => [ createVNode(h6, { class: "lines-controls", ref: "linesControls", createData: t.createData, usageConfig: t.usageConfig, onPrimitivesUpdated: e[1] || (e[1] = (u) => n.$emit("primitivesUpdated", u)) }, null, 8, ["createData", "usageConfig"]) ]), _: 1 }, 512), [ [vShow, n.isLines] ]) ]), _: 1 }, 8, ["modelValue"]) ], 2), createBaseVNode("div", { class: normalizeClass(["drawer-button", { open: n.drawerOpen, close: !n.drawerOpen }]), onClick: e[3] || (e[3] = (...u) => s.toggleDrawer && s.toggleDrawer(...u)) }, [ createVNode(p, null, { default: withCtx(() => [ createVNode(g) ]), _: 1 }) ], 2) ], 2)), [ [vShow, s.hasValidPrimitive] ]); } var _M = mr(K4, [["render", q4], ["__scopeId", "data-v-83d11562"]]); var Q4 = (n, e) => { const t = n.label.toUpperCase(), i = e.label.toUpperCase(); return t < i ? -1 : t > i ? 1 : 0; }; var e5 = { name: "ScaffoldTreeControls", components: { ElIconArrowLeft: zr, TreeControls: V7 }, props: { /** * Enable/disable colour picker */ showColourPicker: Boolean, isReady: Boolean }, data: function() { return { treeData: [ { label: "Root", regionPath: "", id: void 0, children: [] } ], active: [], hover: [], drawerOpen: true, nodeNumbers: 0, module: void 0 //checkedRegions: [], }; }, computed: { treeDataEntry: function() { return this.treeData[0].children; } }, watch: { treeDataEntry: { deep: true, handler: function(n) { this.isReady && this.setColourField(n); } } /* checkedRegions: { deep: true, handler: function (data) { if (this.isReady) { this.$emit('checked-regions', data); } }, }, */ }, methods: { addTreeItem: function(n, e, t) { n.some((i) => i.label === e.label) || (Object.assign(e, { activeColour: this.getColour(e) }), n.push(e), n.sort((i, r) => Q4(i, r)), this.nodeNumbers++, this.$nextTick(() => { !this.$refs.treeControls.$refs.regionTree.getCheckedKeys().includes(e.id) && t.getVisibility() && this.$refs.treeControls.$refs.regionTree.setChecked(e.id, true); })); }, // find or create new region, region id is always prefixed with // '__r/' findOrCreateRegion: function(n, e, t) { if (this.module && this.module.scene && (this.treeData[0].id = this.module.scene.getRootRegion().uuid, this.treeData[0].isRegion = true), e.length > 0) { const i = [...e]; let r = n.children.find( (a) => a.label == i[0] ); const s = t + "/" + e[0], o = this.module.scene.getRootRegion().findChildFromPath(s); return r || (r = { label: i[0], id: o.uuid, children: [], regionPath: s, isRegion: true }, this.addTreeItem(n.children, r, o), s === "/_helper" && this.$nextTick(() => { this.$refs.treeControls.$refs.regionTree.setChecked(r.id, false); })), i.shift(), this.findOrCreateRegion(r, i, s); } else return n; }, removeRegion: function(n) { if (this.treeData[0].children) { for (let e = 0; e < this.treeData[0].children.length; e++) if (this.treeData[0].children[e].label === n) { this.treeData[0].children.splice(e, 1), this.nodeNumbers--; return; } } }, /** * This is called when a new zinc object is read into the scene. */ zincObjectAdded: function(n) { const e = n.region; if (e) { const t = e.getFullSeparatedPath(), i = this.findOrCreateRegion(this.treeData[0], t, ""); if (n.groupName && i) { i.children || (i.children = []); const r = { disabled: false, label: n.groupName, id: e.uuid + "/" + n.uuid, isPrimitives: true, regionPath: n.region.getFullPath(), isTextureSlides: !!n.isTextureSlides }; this.addTreeItem(i.children, r, n); } } }, zincObjectRemoved: function(n) { const e = n.groupName; if (n.region.findObjectsWithGroupName(e, false).length === 0) { const i = n.region.getFullSeparatedPath(), r = this.findOrCreateRegion(this.treeData[0], i, ""); if (r.children) { for (let s = 0; s < r.children.length; s++) if (r.children[s].label === e) { r.children.splice(s, 1), this.nodeNumbers--; return; } } } }, checkChanged: function(n, e) { const t = n.isRegion, i = n.isPrimitives, r = e.checkedKeys.includes(n.id), s = this.module.scene.getRootRegion().findChildFromPath(n.regionPath); t && (r ? s.showAllPrimitives() : s.hideAllPrimitives()), i && s.findObjectsWithGroupName(n.label).forEach((a) => { const c = r && !n.disabled; a.setVisibility(c); }); }, updateActiveUI: function(n) { this.active.length = 0, Sv(n, this.active); }, changeActiveByPrimitives: function(n, e) { n && n.length > 0 ? (this.updateActiveUI(n), this.$emit("object-selected", n, e)) : this.removeActive(e), this.removeHover(e); }, updateHoverUI: function(n) { this.hover.length = 0, Sv(n, this.hover); }, changeHoverByPrimitives: function(n, e) { n && n.length > 0 ? (this.updateHoverUI(n), this.$emit("object-hovered", n, e)) : this.removeHover(e); }, /** * Select a region by its name. */ changeActiveByNames: function(n, e, t) { const i = this.module.scene.getRootRegion(), r = xo( i, n, e, true ); this.changeActiveByPrimitives(r, t); }, /** * Hover a region by its name. */ changeHoverByNames: function(n, e, t) { const i = this.module.scene.getRootRegion(), r = xo( i, n, e, true ); this.changeHoverByPrimitives(r, t); }, changeActiveByNode: function(n, e) { if (n.isPrimitives || n.isRegion) { const t = !!n.isRegion, i = this.getZincObjectsFromNode(n, t); this.changeActiveByPrimitives(i, e); } }, changeHoverByNode: function(n, e) { if (n.isPrimitives) { const t = this.getZincObjectsFromNode(n, false); this.changeHoverByPrimitives(t, e); } }, /** * Unselect the current selected region. */ removeActive: function(n) { this.active = [], this.$emit("object-selected", [], n); }, /** * Unselect the current hover region. */ removeHover: function(n) { this.hover = [], this.$emit("object-hovered", [], n); }, /** * Reset the controls. */ clear: function() { this.active.length = 0, this.hover.length = 0, this.nodeNumbers = 0, this.$refs.treeControls.$refs.regionTree.updateKeyChildren( this.treeData[0].id, [] ), this.treeData[0].children.length = 0, this.treeData[0].id = void 0, this.$emit("object-selected", []); }, forEachChildInNode: function(n, e, t, i, r) { if (n.isRegion) { if (n.children) { const s = t === "" || e.includes(n.id); n.children.forEach( (o) => this.forEachChildInNode( o, e, n.regionPath, i && s, r ) ); } } else n.isPrimitives && r(n, t, i); }, getColour: function(n) { if (n) { let t = this.getZincObjectsFromNode(n, false)[0]; if (t) { let i = t.getColourHex(); if (i) return "#" + i; } } return "#FFFFFF"; }, getNodeDataByRegionAndGroup: function(n, e) { for (const t of this.treeDataEntry) if (t.isRegion && t.label === n) { const i = t.children; for (const r of i) if (r.isPrimitives && r.label === e) return r; } }, getZincObjectsFromNode: function(n, e) { const t = this.module.scene.getRootRegion(); if (n.isPrimitives) return xo( t, n.label, n.regionPath, e ); if (n.isRegion && n.regionPath) { let i = t.findChildFromPath(n.regionPath); if (i) return i.getAllObjects(e); } return []; }, //Set this right at the beginning. setModule: function(n) { this.module = markRaw(n), this.nodeNumbers = 0, this.module.scene.getRootRegion().getAllObjects(true).forEach((t) => { this.zincObjectAdded(t); }), this.module.addOrganPartAddedCallback(this.zincObjectAdded), this.module.addOrganPartRemovedCallback(this.zincObjectRemoved); }, setColourField: function(n, e = void 0) { n.filter((t) => e && !t.children ? t.id === e.id : true).map((t) => { if (t.children) this.setColourField(t.children, e); else { const i = this.getColour(t); t.defaultColour || (t.defaultColour = i), t.activeColour = i; } }); }, setColour: function(n, e) { n && n.isPrimitives && this.getZincObjectsFromNode(n, false).forEach((i) => { let s = (e || n.defaultColour).replace("#", "0x"); i.setColourHex(s), this.setColourField(this.treeData[0].children, n); }); }, updateAllNodeColours: function() { const n = this.$refs.treeControls.$refs.regionTree.getCheckedKeys(); this.forEachChildInNode( this.treeData[0], n, "", true, (e, t, i) => { e.isPrimitives && (e.activeColour = this.getColour(e)); } ); }, setOutlines: function(n) { const e = this.$refs.treeControls.$refs.regionTree.getCheckedKeys(); this.forEachChildInNode( this.treeData[0], e, "", true, (t, i, r) => { const o = this.module.scene.getRootRegion().findChildFromPath(i).findObjectsWithGroupName(t.label); n ? o.forEach((a) => { a.isLines && (e.includes(t.id) && r && a.setVisibility(true), t.disabled = false); }) : t.isPrimitives && o.forEach((a) => { a.isLines && (a.setVisibility(false), t.disabled = true); }); } ); }, visibilityToggle: function(n, e) { this.module.changeOrganPartsVisibility(n, e), e == false && (this.activeRegion === n && this.removeActive(true), this.hoverRegion === n && this.removeHover(true)); }, toggleDrawer: function() { this.drawerOpen = !this.drawerOpen, this.$emit("drawer-toggled", this.drawerOpen); }, //Set visibility using full paths and add found id to the ids list //and remove item from list if remove is set to true. setTreeVisibilityWithFullPaths: function(n, e, t, i) { let r = false, s = ""; n.isRegion && (s = `__r${n.regionPath}`), n.isPrimitives && (s = `${n.regionPath}/${n.label}`); const o = e.indexOf(s); o > -1 && (r = true, e.splice(o, 1), t.push(n.id)); const a = this.module.scene.getRootRegion().findChildFromPath(n.regionPath); s && s !== "__r" && n.isPrimitives && a.findObjectsWithGroupName(n.label).forEach((l) => l.setVisibility(r)), n.children && n.children.forEach((c) => { this.setTreeVisibilityWithFullPaths(c, e, t, true); }); }, setCheckedKeys: function(n, e) { this.$nextTick(() => { e && this.$refs.treeControls.$refs.regionTree.setCheckedKeys([]), n.forEach((t) => { this.$refs.treeControls.$refs.regionTree.setChecked(t, true, true); }); }); }, checkAllKeys: function(n = []) { const e = [], t = []; yM(this.treeData[0], e); const i = e.filter((r) => !n.some((s) => r.includes(s))); this.setTreeVisibilityWithFullPaths( this.treeData[0], i, t, true ), this.$refs.treeControls.$refs.regionTree.setCheckedKeys(t); }, getState: function() { let n = this.$refs.treeControls.$refs.regionTree.getCheckedKeys(); return n.length === this.nodeNumbers ? { checkAll: true, version: "2.0" } : { checkedItems: N4( this.module.scene.getRootRegion(), n ), version: "2.0" }; }, setState: function(n) { if (n) { if (n.checkAll) this.checkAllKeys(); else if (n.checkedItems) { let e = []; n.version !== "2.0" ? (e = n.checkedItems.map((i) => "/" + i), e.shift("__r/")) : e.push(...n.checkedItems); const t = []; this.setTreeVisibilityWithFullPaths( this.treeData[0], e, t, true ), this.$refs.treeControls.$refs.regionTree.setCheckedKeys(t); } } } } }; var t5 = { class: "traditional-container" }; function n5(n, e, t, i, r, s) { const o = resolveComponent("TreeControls"), a = zr, c = It; return openBlock(), createElementBlock("div", { class: normalizeClass(["tree-controls", { open: n.drawerOpen, close: !n.drawerOpen }]) }, [ createBaseVNode("div", t5, [ createVNode(o, { mapType: "scaffold", title: "Regions", isReady: t.isReady, treeData: s.treeDataEntry, active: n.active, hover: n.hover, showColourPicker: t.showColourPicker, onSetColour: s.setColour, onCheckChanged: s.checkChanged, onChangeActive: s.changeActiveByNode, onChangeHover: s.changeHoverByNode, ref: "treeControls", onMouseleave: e[0] || (e[0] = (l) => s.removeHover(true)) }, null, 8, ["isReady", "treeData", "active", "hover", "showColourPicker", "onSetColour", "onCheckChanged", "onChangeActive", "onChangeHover"]) ]), createBaseVNode("div", { class: normalizeClass(["drawer-button", { open: n.drawerOpen, close: !n.drawerOpen }]), onClick: e[1] || (e[1] = (...l) => s.toggleDrawer && s.toggleDrawer(...l)) }, [ createVNode(c, null, { default: withCtx(() => [ createVNode(a) ]), _: 1 }) ], 2) ], 2); } var TM = mr(e5, [["render", n5], ["__scopeId", "data-v-5394b615"]]); var Dd = defineStore("main", { state: () => ({ userProfile: { token: "" } }), getters: { userToken(n) { return n.userProfile.token; } }, actions: { setUserToken(n) { this.userProfile.token = n; } } }); var i5 = { name: "ScaffoldTooltip", components: { Col: bi, CreateTooltipContent: M7, ElIconDelete: Nc, Icon: It, Popover: cu, Row: Ui, Tooltip: z7 }, props: { createData: { type: Object, default: { toBeConfirmed: false, points: [], shape: "", x: 0, y: 0 } }, label: { type: String, default: "" }, annotationDisplay: { type: Boolean, default: false }, annotationFeature: { type: Object, default: {} }, offlineAnnotationEnabled: { type: Boolean, default: false }, region: { type: String, default: "" }, visible: { type: Boolean, default: false }, x: { type: Number, default: 200 }, y: { type: Number, default: 200 } }, inject: ["scaffoldUrl"], provide() { return { userApiKey: this.userToken }; }, data: function() { return { display: false, annotationEntry: [], ElIconDelete: shallowRef(Nc) }; }, computed: { ...mapState(Dd, ["userToken"]), position: function() { let n = 40; return this.region && (n = 55), { left: this.x - 40 + "px", top: this.y - n + "px" }; } }, methods: { checkForDisplay: function() { if (this.visible && this.label && this.label !== "") { if (this.display = true, this.annotationDisplay) { const n = this.region ? this.region + "/" : ""; this.annotationEntry = [{ featureId: n + this.label, resourceId: this.scaffoldUrl, resource: this.scaffoldUrl, feature: this.annotationFeature, offline: this.offlineAnnotationEnabled }]; } } else this.display = false, this.annotationEntry = []; }, hideTriggered: function() { this.$emit("tooltip-hide"); } }, watch: { label: { handler: function() { this.checkForDisplay(); }, immediate: true }, visible: { handler: function() { this.checkForDisplay(); }, immediate: true }, annotationDisplay: { handler: function() { this.checkForDisplay(); }, immediate: true } } }; var r5 = { class: "tooltip-text" }; var s5 = { key: 0, class: "tooltip-text" }; var o5 = { key: 1, class: "delete-container" }; function a5(n, e, t, i, r, s) { const o = resolveComponent("CreateTooltipContent"), a = resolveComponent("Tooltip"), c = bi, l = Ko, d = Ui, h6 = cu; return openBlock(), createElementBlock("div", { style: normalizeStyle(s.position), class: "region-tooltip" }, [ createVNode(h6, { ref: "tooltip", visible: t.visible, placement: "top", "show-arrow": false, teleported: false, trigger: "manual", "popper-class": "tooltip-popper non-selectable", "virtual-triggering": "", onHide: s.hideTriggered }, { default: withCtx(() => [ createBaseVNode("div", r5, toDisplayString(t.label), 1), t.region ? (openBlock(), createElementBlock("div", s5, "Region: " + toDisplayString(t.region), 1)) : createCommentVNode("", true), withDirectives(createVNode(o, { createData: t.createData, onConfirmCreate: e[0] || (e[0] = (f) => n.$emit("confirm-create", f)), onCancelCreate: e[1] || (e[1] = (f) => n.$emit("cancel-create")) }, null, 8, ["createData"]), [ [vShow, t.createData.toBeConfirmed] ]), withDirectives(createVNode(a, { class: "p-tooltip", ref: "annotationTooltip", annotationDisplay: true, annotationEntry: n.annotationEntry, onAnnotation: e[2] || (e[2] = (f) => n.$emit("confirm-comment", f)) }, null, 8, ["annotationEntry"]), [ [vShow, t.annotationDisplay && !t.createData.toBeConfirmed] ]), t.createData.toBeDeleted ? (openBlock(), createElementBlock("div", o5, [ createVNode(d, null, { default: withCtx(() => [ createVNode(c, { span: 10 }, { default: withCtx(() => e[5] || (e[5] = [ createTextVNode("Delete this feature?") ])), _: 1 }), createVNode(c, { span: 7 }, { default: withCtx(() => [ createVNode(l, { class: "delete-button", icon: n.ElIconDelete, onClick: e[3] || (e[3] = (f) => n.$emit("confirm-delete")) }, { default: withCtx(() => e[6] || (e[6] = [ createTextVNode(" Delete ") ])), _: 1 }, 8, ["icon"]) ]), _: 1 }), createVNode(c, { span: 6 }, { default: withCtx(() => [ createVNode(l, { class: "delete-button", onClick: e[4] || (e[4] = (f) => n.$emit("cancel-create")) }, { default: withCtx(() => e[7] || (e[7] = [ createTextVNode(" Dismiss ") ])), _: 1 }) ]), _: 1 }) ]), _: 1 }) ])) : createCommentVNode("", true) ]), _: 1 }, 8, ["visible", "onHide"]) ], 4); } var EM = mr(i5, [["render", a5], ["__scopeId", "data-v-d3f76b72"]]); var Qa = { ALL: 0, SELECTED: 1, HIGHLIGHTED: 2, MOVE: 3 }; var l5 = function(n, e, t) { this.eventType = n, this.identifiers = e, this.zincObjects = t; }; var c5 = function(n, e, t) { this.targetedID = []; const i = n, r = e; this.targetEventType = t; const s = this; t === void 0 && (this.targetEventType = Qa.ALL), this.getEventType = function() { return t; }, this.notify = function(o, a, c, l) { if (o !== i && (s.targetEventType === Qa.ALL || s.targetEventType === a)) { const d = new l5(a, c, l); r(d); } }; }; var u5 = function() { const n = []; this.publish = function(e, t, i, r) { for (let s = 0; s < n.length; s++) n[s].notify(e, t, i, r); }, this.subscribe = function(e, t, i) { if (typeof t == "function") { const r = new c5(e, t, i); return n.push(r), r; } }, this.unsubscribe = function(e) { for (let t = 0; t < n.length; t++) if (e === n[t]) { n.splice(t, 1); return; } }; }; var Lv = { isWebGLAvailable: function() { try { var n = document.createElement("canvas"); return !!(window.WebGLRenderingContext && (n.getContext("webgl") || n.getContext("experimental-webgl"))); } catch { return false; } }, isWebGL2Available: function() { try { var n = document.createElement("canvas"); return !!(window.WebGL2RenderingContext && n.getContext("webgl2")); } catch { return false; } }, getWebGLErrorMessage: function() { return this.getErrorMessage(1); }, getWebGL2ErrorMessage: function() { return this.getErrorMessage(2); }, getErrorMessage: function(n) { var e = { 1: "WebGL", 2: "WebGL 2" }, t = { 1: window.WebGLRenderingContext, 2: window.WebGL2RenderingContext }, i = 'This module requires $1 support but your $0 does not seem to support it.', r = document.createElement("div"); return r.id = "webglmessage", r.style.fontFamily = "monospace", r.style.fontSize = "20px", r.style.fontWeight = "normal", r.style.textAlign = "center", r.style.background = "#fff", r.style.color = "#000", r.style.padding = "1.5em", r.style.width = "400px", r.style.margin = "5em auto 0", t[n] ? i = i.replace("$0", "graphics card") : i = i.replace("$0", "browser"), i = i.replace("$1", e[n]), r.innerHTML = i, r; } }; var mp = { ALL: 0, DESTROYED: 1, NAME_CHANGED: 2, SETTINGS_CHANGED: 3 }; var Zn = function() { this.typeName = "Base Module", this.instanceName = "default", this.onChangedCallbacks = [], this.eventNotifiers = []; }; Zn.prototype.setName = function(n) { if (n && this.instanceName !== n) { this.instanceName = n; const e = this.onChangedCallbacks.slice(); for (let t = 0; t < e.length; t++) e[t](this, mp.NAME_CHANGED); } }; Zn.prototype.settingsChanged = function() { const n = this.onChangedCallbacks.slice(); for (let e = 0; e < n.length; e++) n[e](this, mp.SETTINGS_CHANGED); }; Zn.prototype.exportSettings = function() { const n = {}; return n.dialog = this.typeName, n.name = this.instanceName, n; }; Zn.prototype.importSettings = function(n) { return n.dialog == this.typeName ? (this.setName(n.name), true) : false; }; Zn.prototype.publishChanges = function(n, e, t) { for (let i = 0; i < this.eventNotifiers.length; i++) this.eventNotifiers[i].publish(this, e, n, t); }; Zn.prototype.getName = function() { return this.instanceName; }; Zn.prototype.destroy = function() { const n = this.onChangedCallbacks.slice(); for (let e = 0; e < n.length; e++) n[e](this, mp.DESTROYED); delete this; }; Zn.prototype.addChangedCallback = function(n) { this.onChangedCallbacks.includes(n) == false && this.onChangedCallbacks.push(n); }; Zn.prototype.removeChangedCallback = function(n) { const e = this.onChangedCallbacks.indexOf(n); e > -1 && this.onChangedCallbacks.splice(e, 1); }; Zn.prototype.addNotifier = function(n) { this.eventNotifiers.push(n); }; var wc = (n, e, t) => { for (let i = 0; i < n.length; i++) if (n[i] && n[i].material && n[i].material.emissive) { let r = n[i].userData; r && r.isZincObject ? r.setEmissiveRGB(e) : n[i].material && n[i].material.emissive && n[i].material.emissive.setRGB(...e), t && n[i].material.depthFunc && (n[i].material.depthFunc = Pr.THREE.LessEqualDepth), n[i].children.forEach((s) => { const o = s.userData; o && o.isZincObject && s.material && s.material.emissive && s.material.emissive.setRGB(...e); }); } }; var h5 = function() { let n = [], e = []; this.highlightColour = [1, 0, 0], this.selectColour = [0, 1, 0], this.originalColour = [0, 0, 0]; const t = [], i = [], r = this, s = function(c, l) { if (c.length == 0 && l.length == 0) return false; for (let d = 0; d < c.length; d++) { let h6 = false; for (let f = 0; f < l.length; f++) c[d] === l[f] && (h6 = true); if (!h6) return true; } for (let d = 0; d < l.length; d++) { let h6 = false; for (let f = 0; f < c.length; f++) l[d] === c[f] && (h6 = true); if (!h6) return true; } return false; }, o = function(c, l) { if (t.length = 0, l.length == 0) return c; for (let d = 0; d < c.length; d++) { let h6 = false; for (let f = 0; f < l.length; f++) c[d] === l[f] && (h6 = true); h6 || t.push(c[d]); } return t; }; this.setHighlighted = function(c) { const l = [...n]; this.setNervesStyle(l), r.resetHighlighted(); const d = o(c, e), h6 = a(d); return this.setNervesStyle(d, Ai.HIGHLIGHTED_COLOUR), wc(h6, r.highlightColour, false), n = d, s(n, l); }, this.setSelected = function(c) { const l = [...e]; this.setNervesStyle(l), r.resetHighlighted(), r.resetSelected(); const d = a(c); return this.setNervesStyle(c, Ai.SELECTED_COLOUR), wc(d, r.selectColour, false), e = c, s(e, l); }; const a = function(c) { i.length = 0; for (let l = 0; l < c.length; l++) c[l].material && i.push(c[l]); return i; }; this.setNervesStyle = function(c, l) { const d = pp(c); if (d && d.length) { const h6 = l ? Ai.ZOOM_RADIUS : Ai.DEFAULT_RADIUS, f = l ? Ai.ZOOM_RADIAL_SEGMENTS : Ai.DEFAULT_RADIAL_SEGMENTS; d.forEach((g) => { var p, u, y; if (g.isTubeLines && ((p = g.userData) != null && p.isNerves) && !((u = g.userData) != null && u.isGreyScale)) { g.setTubeLines(h6, f); let v = l || ((y = g.userData) == null ? void 0 : y.defaultColour); v = v.replace("#", "0x"), g.setColourHex(v); } }); } }, this.resetHighlighted = function() { const c = a(n); this.setNervesStyle(n), wc(c, r.originalColour, true), n = []; }, this.resetSelected = function() { const c = a(e); this.setNervesStyle(n), wc(c, r.originalColour, true), e = []; }, this.getSelected = function() { return e; }, this.reset = function() { r.resetSelected(), r.resetHighlighted(); }; }; var gp = Rc.THREE; var d5 = function() { const n = document.createElement("div"); let e; if (n.style.height = "100%", Lv.isWebGLAvailable()) e = new Rc.Renderer(n, window), Rc.defaultMaterialColor = 16777116, e.initialiseVisualisation(), e.playAnimation = false; else { const t = Lv.getWebGLErrorMessage(); n.appendChild(t); } return { Zinc: Rc, renderer: e, container: n }; }; var Kt = function() { Zn.call(this), this.scene = void 0, this.rendererContainer = void 0, this.displayArea = void 0, this.graphicsHighlight = new h5(), this.selectObjectOnPick = true, this.zincRenderer = null, this.selectedScreenCoordinates = new gp.Vector3(), this.selectedCenter = void 0, this.liveUpdatesObjects = void 0, this.ignorePreviousSelected = false; }; Kt.prototype = Object.create(Zn.prototype); Kt.prototype.getIntersectedObject = function(n) { if (n) { const e = n.map((i) => { if (i && i.object && i.object.userData) { if (i.object.userData.isMarker) return 1; if (i.object.name && i.object.userData.isZincObject) return i.object.name === "_Unnamed" ? 3 : 2; } return 0; }); let t = e.indexOf(1); return t > -1 || (t = e.indexOf(2), t = t > -1 ? t : e.indexOf(3)), n[t]; } }; Kt.prototype.getAnnotationsFromObjects = function(n) { const e = []; for (var t = 0; t < n.length; t++) { const i = n[t].userData; let r; if (i) { if (i.isGlyph || i.isGlyphset) { let s = i; i.isGlyph && (s = i.getGlyphset()), r = s.userData ? s.userData.annotation : void 0, r && r.data && (n[t].name && n[t].name != "" ? r.data.id = n[t].name : r.data.id = s.groupName); } else r = i.userData ? i.userData.annotation : void 0, r && r.data && (r.data.id = n[t].name); r && (r.data.anatomicalId = i.anatomicalId, r.data.isNerves = i.userData.isNerves, r.data.zincObject = i); } r && e.push(r); } return e; }; Kt.prototype.setHighlightedByObjects = function(n, e, t, i) { const r = pp(n), s = this.graphicsHighlight.setHighlighted(n); if (i) { let o = Qa.MOVE; s && (o = Qa.HIGHLIGHTED); const a = this.getAnnotationsFromObjects(n); a.length > 0 && (a[0].coords = e, a[0].extraData = t), this.publishChanges(a, o, r); } return s; }; Kt.prototype.setHighlightedByZincObjects = function(n, e, t, i) { let r = []; return n && n.forEach((s) => { s && s.getMorph() && r.push(s.getMorph()); }), this.setHighlightedByObjects(r, e, t, i); }; Kt.prototype.setupLiveCoordinates = function(n) { if (this.liveUpdatesObjects = n, n && n.length > 0) { const e = this.scene.getBoundingBoxOfZincObjects(n); let t = new gp.Vector3(); e ? (e.getCenter(t), this.selectedCenter == null ? this.selectedCenter = t : this.selectedCenter.copy(t)) : this.selectedCenter = void 0; } else this.selectedCenter = void 0; }; Kt.prototype.setSelectedByObjects = function(n, e, t, i) { let r = false; if (this.selectObjectOnPick ? r = this.graphicsHighlight.setSelected(n) : r = true, r || this.ignorePreviousSelected) { const s = pp(n); if (this.selectObjectOnPick && this.setupLiveCoordinates(s), i) { const o = Qa.SELECTED, a = this.getAnnotationsFromObjects(n); a.length > 0 && (a[0].coords = e, a[0].extraData = t), this.publishChanges(a, o, s); } } return r; }; Kt.prototype.setSelectedByZincObjects = function(n, e, t, i) { let r = []; return n && n.forEach((s) => { if (s) { const o = s.getMorph(); o && r.push(o); } }), this.setSelectedByObjects(r, e, t, i); }; Kt.prototype.findObjectsByGroupName = function(n) { return this.scene.findObjectsWithGroupName(n); }; Kt.prototype.setHighlightedByGroupName = function(n, e) { const t = this.findObjectsByGroupName(n); return this.setHighlightedByObjects(t, void 0, {}, e); }; Kt.prototype.setSelectedByGroupName = function(n, e) { const t = this.findObjectsByGroupName(n); return this.setSelectedByObjects(t, void 0, {}, e); }; Kt.prototype.changeBackgroundColour = function(n) { const e = new gp.Color(n); this.zincRenderer && this.zincRenderer.getThreeJSRenderer().setClearColor(e, 1); }; Kt.prototype.resetView = function() { this.zincRenderer && this.zincRenderer.resetView(); }; Kt.prototype.viewAll = function() { this.zincRenderer && this.zincRenderer.viewAll(); }; Kt.prototype.playAnimation = function(n) { this.zincRenderer && (this.zincRenderer.playAnimation = n); }; Kt.prototype.setPlayRate = function(n) { this.zincRenderer && this.zincRenderer.setPlayRate(n); }; Kt.prototype.getPlayRate = function(n) { return this.zincRenderer ? this.zincRenderer.getPlayRate() : 0; }; Kt.prototype.initialiseRenderer = function(n) { if (this.zincRenderer === void 0 || this.rendererContainer === void 0) { let e = d5(); this.Zinc = e.Zinc, this.zincRenderer = e.renderer, this.rendererContainer = e.container; } n && (this.displayArea = n, this.displayArea.appendChild(this.rendererContainer), this.zincRenderer && this.zincRenderer.animate()); }; Kt.prototype.destroy = function() { this.zincRenderer && (this.zincRenderer.dispose(), this.zincRenderer.getThreeJSRenderer().dispose(), this.zincRenderer = void 0), Zn.prototype.destroy.call(this); }; var f5 = function() { this.type = "anatomical", this.data = void 0, this.isAnnotation = true; }; var p5 = function() { this.currentName = "", this.currentSystem = "", this.currentPart = "", this.currentSpecies = "", this.metaURL = "", this.viewURL = "", this.timeVarying = false, this.currentTime = 0; }; var CM = function(n) { Kt.call(this); const e = this; let t; this.sceneData = new p5(); const i = new Array(), r = new Array(), s = new Array(), o = new Array(); let a, c; const l = n; this.NDCCameraControl = void 0, e.typeName = "Organ Viewer"; let d = false; this.isIgnorePicking = function() { return d; }, this.setIgnorePicking = function(T) { d = T; }, this.getSceneData = function() { return e.sceneData; }, this.updateTime = function(T) { let _ = 6e3; e.scene && (_ = e.scene.getDuration()); const E = T / 100 * _; e.sceneData.nerveMapIsActive || e.scene && e.scene.setMorphsTime(E), e.sceneData.currentTime = T; }; const h6 = function() { let T = 3e3; e.scene && (T = e.scene.getDuration()); const _ = e.zincRenderer.getCurrentTime(); for (let E = 0; E < i.length; E++) i[E](_); !e.sceneData.nerveMapIsActive && t && t.setMorphsTime(_), e.sceneData.nerveMap && e.sceneData.nerveMap.additionalReader && e.sceneData.nerveMap.additionalReader.setTime(_ / T), e.sceneData.currentTime = _ / T * 100; }; this.getCurrentTime = function() { return e.sceneData.currentTime; }, this.toggleSyncControl = (T, _) => { let E = this.scene.getZincCameraControls(); T ? (E.resetView(), this.NDCCameraControl = E.enableSyncControl(), E.setRotationMode(_)) : (E.disableSyncControl(), this.NDCCameraControl = void 0, E.setRotationMode("free")); }, this.isSyncControl = () => this.NDCCameraControl !== void 0, this.setSyncControlZoomToBox = (T) => { this.NDCCameraControl && this.NDCCameraControl.zoomToBox(T, 2); }, this.setSyncControlCallback = (T) => { this.NDCCameraControl && this.NDCCameraControl.setEventCallback(T); }, this.setSyncControlCenterZoom = (T, _) => { this.NDCCameraControl && this.NDCCameraControl.setCenterZoom(T, _); }; const f = function() { if (e.zincRenderer.playAnimation && e.liveUpdatesObjects && e.setupLiveCoordinates(e.liveUpdatesObjects), e.selectedCenter) { const T = new Pr.THREE.Vector3(); T.copy(e.selectedCenter); const _ = e.scene.vectorToScreenXY(T); e.selectedScreenCoordinates.x = _.x, e.selectedScreenCoordinates.y = _.y; } }, g = function() { return function() { h6(); }; }, p = function() { return function() { f(); }; }; this.addTimeChangedCallback = function(T) { i.push(T); }, this.setTexturePos = function(T) { e.sceneData.nerveMap && e.sceneData.nerveMap.additionalReader && e.sceneData.nerveMap.additionalReader.setSliderPos(T); }, this.addSceneChangedCallback = function(T) { r.push(T); }, this.addOrganPartAddedCallback = function(T) { s.push(T); }, this.addOrganPartRemovedCallback = function(T) { o.push(T); }, this.setFinishDownloadCallback = function(T) { a = T; }, this.unsetFinishDownloadCallback = function() { a = void 0; }, this.setDownloadErrorCallback = function(T) { c = T; }, this.unsetDownloadErrorCallback = function() { c = void 0; }, this.getNamedObjectsToScreenCoordinates = function(T, _) { const E = new Pr.THREE.Vector3(); E.setFromMatrixPosition(obj.matrixWorld); const C = width / 2, P = height / 2; return E.project(_), E.x = E.x * C + C, E.y = -(E.y * P) + P, E; }; const u = function(T) { let _, E; if (T !== void 0) { let C = false; T.object.userData && T.object.userData.isMarker ? (C = true, E = T.object.userData.parent.getMorph()) : E = T.object; try { E.userData.userData.annotation.data.lastActionOnMarker = C; } finally { } if (E) if (E.name) _ = E.name; else { const P = e.getAnnotationsFromObjects( [E] ); P && P[0] && (_ = P[0].data.group); } } return { id: _, object: E }; }, y = function() { return function(T, _, E) { var D; const C = e.getIntersectedObject(T), P = u(C), b = { worldCoords: [ C ? C.point.x : 0, C ? C.point.y : 0, C ? C.point.z : 0 ], intersected: C, intersects: T }, F = { x: _, y: E }; if (P.id) { b.threeID = (D = P.object) == null ? void 0 : D.id, P.object.userData.isGlyph ? P.object.name ? e.setSelectedByObjects( [P.object], F, b, true ) : e.setSelectedByZincObjects( P.object.userData.getGlyphset(), F, b, true ) : e.setSelectedByObjects([P.object], F, b, true); return; } else { if (d) return; e.setSelectedByObjects([], F, b, true); } }; }, v = function() { return function(T, _, E) { var D; const C = e.getIntersectedObject(T), P = u(C), b = { worldCoords: [ C ? C.point.x : 0, C ? C.point.y : 0, C ? C.point.z : 0 ] }, F = { x: _, y: E }; if (P.id) { b.threeID = (D = P.object) == null ? void 0 : D.id, e.displayArea.style.cursor = "pointer", e.setHighlightedByObjects([P.object], F, b, true); return; } else e.displayArea.style.cursor = "auto", e.setHighlightedByObjects([], F, b, true); }; }, m = function(T, _, E, C) { if (C == "all" || C == "geometries") { const P = T.findGeometriesWithGroupName(_); for (let b = 0; b < P.length; b++) P[b].setVisibility(E); } if (C == "all" || C == "glyphsets") { const P = T.findGlyphsetsWithGroupName(_); for (let b = 0; b < P.length; b++) P[b].setVisibility(E); } if (C == "all" || C == "pointsets") { const P = T.findPointsetsWithGroupName(_); for (let b = 0; b < P.length; b++) P[b].setVisibility(E); } if (C == "all" || C == "lines") { const P = T.findLinesWithGroupName(_); for (let b = 0; b < P.length; b++) P[b].setVisibility(E); } }; this.changeGeometriesVisibility = function(T, _) { m(e.scene, T, _, "geometries"); }, this.changeGlyphsetsVisibility = function(T, _) { m(e.scene, T, _, "glyphsets"); }, this.changeLinesVisibility = function(T, _) { m(e.scene, T, _, "lines"); }, this.changePointsetsVisibility = function(T, _) { m(e.scene, T, _, "pointsets"); }, this.changeOrganPartsVisibility = function(T, _, E) { let C = "all"; E !== void 0 && (C = E), m(e.scene, T, _, C); }, this.changeOrganPartsVisibilityCallback = function(T) { return function(_) { e.changeOrganPartsVisibility(T, _); }; }, this.changeBackgroundColour = function(T) { const _ = new Pr.THREE.Color(T); e.zincRenderer && e.zincRenderer.getThreeJSRenderer().setClearColor(_, 1); }; const x = function(T, _, E, C) { for (let F = 0; F < s.length; F++) s[F](C, e.scene.isTimeVarying()); const P = new f5(), b = C.region.getFullPath(); P.data = { species: e.sceneData.currentSpecies, system: T, part: _, group: C.groupName, region: b, uuid: C.uuid, lastActionOnMarker: false }, C.userData.annotation = P; }, w = function(T, _, E, C) { for (let P = 0; P < o.length; P++) o[P](C); }, A = function(T, _, E) { return function(C) { x(T, _, E, C); }; }, M = function(T, _, E) { return function(C) { w(T, _, E, C); }; }, R = function() { return function() { e.settingsChanged(), e.sceneData.timeVarying = e.scene.isTimeVarying(), a && a(); }; }, L = function() { return function(T) { if ((T == null ? void 0 : T.type) === "Error" && c) { const _ = { xhr: T.xhr, type: "download-error" }; c(_); } }; }; this.updateFieldvisibility = function(T, _) { for (let E = 0; E < T.length; E++) if (_ != E) { const C = T[E].PartName; e.changeOrganPartsVisibility(C, false); } if (_ > -1) { const E = T[_].PartName; if (e.scene.findGeometriesWithGroupName(E).length > 0 || e.scene.findGlyphsetsWithGroupName(E).length > 0) e.changeOrganPartsVisibility(E, true); else { const C = getOrganDetails(T[_].SystemName, E); C != null && e.scene.loadMetadataURL(l.getOrgansDirectoryPrefix() + "/" + C.meta); } } }, this.getAvailableSpecies = function(T, _, E) { const C = new Array(); C.push("none"); const P = Object.keys(organsFileMap); for (index in P) { const b = P[index]; b != T && organsFileMap[b].hasOwnProperty(_) && organsFileMap[b][_].hasOwnProperty(E) && C.push(b); } return C; }, this.getCentreAndSize = function() { const T = new Pr.THREE.Vector3(), _ = this.scene.getBoundingBox(); _.getCenter(T); const E = [T.x, T.y, T.z]; _.getSize(T); const C = [T.x, T.y, T.z]; return { centre: E, size: C }; }; const S = function(T, _, E, C) { e.sceneData.nerveMapIsActive = false, e.sceneData.nerveMap = void 0, e.sceneData.metaURL = "", e.sceneData.viewURL = "", e.sceneData.currentSpecies = T, e.sceneData.currentSystem = _, e.sceneData.currentPart = E, e.sceneData.currentTime = 0, e.sceneData.timeVarying = false; let P = ""; T && (P = T + "/"), _ && (P = _ + "/"), E && (P = E), e.sceneData.currentName = P; }; this.loadOrgansFromURL = function(T, _, E, C, P, b, F) { if (e.zincRenderer && C && e.sceneData.metaURL !== T) { S(_, E, C); const D = e.sceneData.currentName; let N = e.zincRenderer.getSceneByName(D); N ? b && N.clearAll() : N = e.zincRenderer.createScene(D), e.selectObjectOnPick = true; for (let U = 0; U < r.length; U++) r[U](e.sceneData); P && P != "" ? (e.sceneData.viewURL = P, N.loadViewURL(e.sceneData.viewURL)) : e.sceneData.viewURL = void 0, e.sceneData.metaURL = T, N.addZincObjectAddedCallbacks(A(E, C, false)), N.addZincObjectRemovedCallbacks(M(void 0, C, false)), N.loadMetadataURL(T, L(), R(), F), e.scene = N, e.zincRenderer.setCurrentScene(N), e.graphicsHighlight.reset(); const B = N.getZincCameraControls(); B.enableRaycaster(N, y(), v()), B.setMouseButtonAction("AUXILIARY", "ZOOM"), B.setMouseButtonAction("SECONDARY", "PAN"); } }, this.loadGLTFFromURL = function(T, _, E) { if (e.zincRenderer && _ && e.sceneData.metaURL !== T) { S(void 0, void 0, _); const C = e.sceneData.currentName; let P = e.zincRenderer.getSceneByName(C); P ? E && P.clearAll() : P = e.zincRenderer.createScene(C); for (let F = 0; F < r.length; F++) r[F](e.sceneData); e.sceneData.viewURL = void 0, e.sceneData.metaURL = T, P.addZincObjectAddedCallbacks(A(void 0, _, false)), P.addZincObjectRemovedCallbacks(M(void 0, _, false)), P.loadGLTF(T, void 0, R()), e.scene = P, e.zincRenderer.setCurrentScene(P), e.graphicsHighlight.reset(); const b = P.getZincCameraControls(); b.enableRaycaster(P, y(), v()), b.setMouseButtonAction("AUXILIARY", "ZOOM"), b.setMouseButtonAction("SECONDARY", "PAN"); } }, this.alignCameraWithSelectedObject = function(T) { const _ = e.graphicsHighlight.getSelected(); _ && _[0] && _[0].userData && e.scene.alignObjectToCameraView(_[0].userData, T); }, this.exportSettings = function() { const T = {}; return T.name = e.instanceName, e.sceneData.currentSystem && (T.system = e.sceneData.currentSystem), e.sceneData.currentSpecies && (T.species = e.sceneData.currentSpecies), e.sceneData.currentPart && (T.part = e.sceneData.currentPart), T.metaURL = e.sceneData.metaURL, e.sceneData.viewURL && (T.viewURL = e.sceneData.viewURL), T.dialog = "Organ Viewer", T; }, this.importSettings = function(T) { return T && T.dialog == this.typeName ? (e.setName(T.name), T.metaURL !== void 0 && T.metaURL != "" ? e.loadOrgansFromURL( T.metaURL, T.species, T.system, T.part, T.viewURL, true ) : e.loadOrgans(T.species, T.system, T.part), true) : false; }, function() { e.initialiseRenderer(void 0), e.zincRenderer && (e.zincRenderer.addPreRenderCallbackFunction(g()), e.zincRenderer.addPostRenderCallbackFunction(p())); }(); }; CM.prototype = Object.create(Kt.prototype); var _t = function() { return _t = Object.assign || function(e) { for (var t, i = 1, r = arguments.length; i < r; i++) { t = arguments[i]; for (var s in t) Object.prototype.hasOwnProperty.call(t, s) && (e[s] = t[s]); } return e; }, _t.apply(this, arguments); }; function m5(n, e, t, i) { function r(s) { return s instanceof t ? s : new t(function(o) { o(s); }); } return new (t || (t = Promise))(function(s, o) { function a(d) { try { l(i.next(d)); } catch (h6) { o(h6); } } function c(d) { try { l(i.throw(d)); } catch (h6) { o(h6); } } function l(d) { d.done ? s(d.value) : r(d.value).then(a, c); } l((i = i.apply(n, [])).next()); }); } function g5(n, e) { var t = { label: 0, sent: function() { if (s[0] & 1) throw s[1]; return s[1]; }, trys: [], ops: [] }, i, r, s, o; return o = { next: a(0), throw: a(1), return: a(2) }, typeof Symbol == "function" && (o[Symbol.iterator] = function() { return this; }), o; function a(l) { return function(d) { return c([l, d]); }; } function c(l) { if (i) throw new TypeError("Generator is already executing."); for (; o && (o = 0, l[0] && (t = 0)), t; ) try { if (i = 1, r && (s = l[0] & 2 ? r.return : l[0] ? r.throw || ((s = r.return) && s.call(r), 0) : r.next) && !(s = s.call(r, l[1])).done) return s; switch (r = 0, s && (l = [l[0] & 2, s.value]), l[0]) { case 0: case 1: s = l; break; case 4: return t.label++, { value: l[1], done: false }; case 5: t.label++, r = l[1], l = [0]; continue; case 7: l = t.ops.pop(), t.trys.pop(); continue; default: if (s = t.trys, !(s = s.length > 0 && s[s.length - 1]) && (l[0] === 6 || l[0] === 2)) { t = 0; continue; } if (l[0] === 3 && (!s || l[1] > s[0] && l[1] < s[3])) { t.label = l[1]; break; } if (l[0] === 6 && t.label < s[1]) { t.label = s[1], s = l; break; } if (s && t.label < s[2]) { t.label = s[2], t.ops.push(l); break; } s[2] && t.ops.pop(), t.trys.pop(); continue; } l = e.call(n, t); } catch (d) { l = [6, d], r = 0; } finally { i = s = 0; } if (l[0] & 5) throw l[1]; return { value: l[0] ? l[1] : void 0, done: true }; } } function ct(n) { var e = typeof Symbol == "function" && Symbol.iterator, t = e && n[e], i = 0; if (t) return t.call(n); if (n && typeof n.length == "number") return { next: function() { return n && i >= n.length && (n = void 0), { value: n && n[i++], done: !n }; } }; throw new TypeError(e ? "Object is not iterable." : "Symbol.iterator is not defined."); } function Wt(n, e) { var t = typeof Symbol == "function" && n[Symbol.iterator]; if (!t) return n; var i = t.call(n), r, s = [], o; try { for (; (e === void 0 || e-- > 0) && !(r = i.next()).done; ) s.push(r.value); } catch (a) { o = { error: a }; } finally { try { r && !r.done && (t = i.return) && t.call(i); } finally { if (o) throw o.error; } } return s; } var v5 = "ENTRIES"; var LM = "KEYS"; var RM = "VALUES"; var pn = ""; var Ph = ( /** @class */ function() { function n(e, t) { var i = e._tree, r = Array.from(i.keys()); this.set = e, this._type = t, this._path = r.length > 0 ? [{ node: i, keys: r }] : []; } return n.prototype.next = function() { var e = this.dive(); return this.backtrack(), e; }, n.prototype.dive = function() { if (this._path.length === 0) return { done: true, value: void 0 }; var e = uo(this._path), t = e.node, i = e.keys; if (uo(i) === pn) return { done: false, value: this.result() }; var r = t.get(uo(i)); return this._path.push({ node: r, keys: Array.from(r.keys()) }), this.dive(); }, n.prototype.backtrack = function() { if (this._path.length !== 0) { var e = uo(this._path).keys; e.pop(), !(e.length > 0) && (this._path.pop(), this.backtrack()); } }, n.prototype.key = function() { return this.set._prefix + this._path.map(function(e) { var t = e.keys; return uo(t); }).filter(function(e) { return e !== pn; }).join(""); }, n.prototype.value = function() { return uo(this._path).node.get(pn); }, n.prototype.result = function() { switch (this._type) { case RM: return this.value(); case LM: return this.key(); default: return [this.key(), this.value()]; } }, n.prototype[Symbol.iterator] = function() { return this; }, n; }() ); var uo = function(n) { return n[n.length - 1]; }; var y5 = function(n, e, t) { var i = /* @__PURE__ */ new Map(); if (e === void 0) return i; for (var r = e.length + 1, s = r + t, o = new Uint8Array(s * r).fill(t + 1), a = 0; a < r; ++a) o[a] = a; for (var c = 1; c < s; ++c) o[c * r] = c; return FM(n, e, t, i, o, 1, r, ""), i; }; var FM = function(n, e, t, i, r, s, o, a) { var c, l, d = s * o; try { e: for (var h6 = ct(n.keys()), f = h6.next(); !f.done; f = h6.next()) { var g = f.value; if (g === pn) { var p = r[d - 1]; p <= t && i.set(a, [n.get(g), p]); } else { for (var u = s, y = 0; y < g.length; ++y, ++u) { for (var v = g[y], m = o * u, x = m - o, w = r[m], A = Math.max(0, u - t - 1), M = Math.min(o - 1, u + t), R = A; R < M; ++R) { var L = v !== e[R], S = r[x + R] + +L, I = r[x + R + 1] + 1, T = r[m + R] + 1, _ = r[m + R + 1] = Math.min(S, I, T); _ < w && (w = _); } if (w > t) continue e; } FM(n.get(g), e, t, i, r, u, o, a + g); } } } catch (E) { c = { error: E }; } finally { try { f && !f.done && (l = h6.return) && l.call(h6); } finally { if (c) throw c.error; } } }; var Ih = ( /** @class */ function() { function n(e, t) { e === void 0 && (e = /* @__PURE__ */ new Map()), t === void 0 && (t = ""), this._size = void 0, this._tree = e, this._prefix = t; } return n.prototype.atPrefix = function(e) { var t, i; if (!e.startsWith(this._prefix)) throw new Error("Mismatched prefix"); var r = Wt($c(this._tree, e.slice(this._prefix.length)), 2), s = r[0], o = r[1]; if (s === void 0) { var a = Wt(vp(o), 2), c = a[0], l = a[1]; try { for (var d = ct(c.keys()), h6 = d.next(); !h6.done; h6 = d.next()) { var f = h6.value; if (f !== pn && f.startsWith(l)) { var g = /* @__PURE__ */ new Map(); return g.set(f.slice(l.length), c.get(f)), new n(g, e); } } } catch (p) { t = { error: p }; } finally { try { h6 && !h6.done && (i = d.return) && i.call(d); } finally { if (t) throw t.error; } } } return new n(s, e); }, n.prototype.clear = function() { this._size = void 0, this._tree.clear(); }, n.prototype.delete = function(e) { return this._size = void 0, b5(this._tree, e); }, n.prototype.entries = function() { return new Ph(this, v5); }, n.prototype.forEach = function(e) { var t, i; try { for (var r = ct(this), s = r.next(); !s.done; s = r.next()) { var o = Wt(s.value, 2), a = o[0], c = o[1]; e(a, c, this); } } catch (l) { t = { error: l }; } finally { try { s && !s.done && (i = r.return) && i.call(r); } finally { if (t) throw t.error; } } }, n.prototype.fuzzyGet = function(e, t) { return y5(this._tree, e, t); }, n.prototype.get = function(e) { var t = Nd(this._tree, e); return t !== void 0 ? t.get(pn) : void 0; }, n.prototype.has = function(e) { var t = Nd(this._tree, e); return t !== void 0 && t.has(pn); }, n.prototype.keys = function() { return new Ph(this, LM); }, n.prototype.set = function(e, t) { if (typeof e != "string") throw new Error("key must be a string"); this._size = void 0; var i = Oh(this._tree, e); return i.set(pn, t), this; }, Object.defineProperty(n.prototype, "size", { /** * @see https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Global_Objects/Map/size */ get: function() { if (this._size) return this._size; this._size = 0; for (var e = this.entries(); !e.next().done; ) this._size += 1; return this._size; }, enumerable: false, configurable: true }), n.prototype.update = function(e, t) { if (typeof e != "string") throw new Error("key must be a string"); this._size = void 0; var i = Oh(this._tree, e); return i.set(pn, t(i.get(pn))), this; }, n.prototype.fetch = function(e, t) { if (typeof e != "string") throw new Error("key must be a string"); this._size = void 0; var i = Oh(this._tree, e), r = i.get(pn); return r === void 0 && i.set(pn, r = t()), r; }, n.prototype.values = function() { return new Ph(this, RM); }, n.prototype[Symbol.iterator] = function() { return this.entries(); }, n.from = function(e) { var t, i, r = new n(); try { for (var s = ct(e), o = s.next(); !o.done; o = s.next()) { var a = Wt(o.value, 2), c = a[0], l = a[1]; r.set(c, l); } } catch (d) { t = { error: d }; } finally { try { o && !o.done && (i = s.return) && i.call(s); } finally { if (t) throw t.error; } } return r; }, n.fromObject = function(e) { return n.from(Object.entries(e)); }, n; }() ); var $c = function(n, e, t) { var i, r; if (t === void 0 && (t = []), e.length === 0 || n == null) return [n, t]; try { for (var s = ct(n.keys()), o = s.next(); !o.done; o = s.next()) { var a = o.value; if (a !== pn && e.startsWith(a)) return t.push([n, a]), $c(n.get(a), e.slice(a.length), t); } } catch (c) { i = { error: c }; } finally { try { o && !o.done && (r = s.return) && r.call(s); } finally { if (i) throw i.error; } } return t.push([n, e]), $c(void 0, "", t); }; var Nd = function(n, e) { var t, i; if (e.length === 0 || n == null) return n; try { for (var r = ct(n.keys()), s = r.next(); !s.done; s = r.next()) { var o = s.value; if (o !== pn && e.startsWith(o)) return Nd(n.get(o), e.slice(o.length)); } } catch (a) { t = { error: a }; } finally { try { s && !s.done && (i = r.return) && i.call(r); } finally { if (t) throw t.error; } } }; var Oh = function(n, e) { var t, i, r = e.length; e: for (var s = 0; n && s < r; ) { try { for (var o = (t = void 0, ct(n.keys())), a = o.next(); !a.done; a = o.next()) { var c = a.value; if (c !== pn && e[s] === c[0]) { for (var l = Math.min(r - s, c.length), d = 1; d < l && e[s + d] === c[d]; ) ++d; var h6 = n.get(c); if (d === c.length) n = h6; else { var f = /* @__PURE__ */ new Map(); f.set(c.slice(d), h6), n.set(e.slice(s, s + d), f), n.delete(c), n = f; } s += d; continue e; } } } catch (p) { t = { error: p }; } finally { try { a && !a.done && (i = o.return) && i.call(o); } finally { if (t) throw t.error; } } var g = /* @__PURE__ */ new Map(); return n.set(e.slice(s), g), g; } return n; }; var b5 = function(n, e) { var t = Wt($c(n, e), 2), i = t[0], r = t[1]; if (i !== void 0) { if (i.delete(pn), i.size === 0) PM(r); else if (i.size === 1) { var s = Wt(i.entries().next().value, 2), o = s[0], a = s[1]; IM(r, o, a); } } }; var PM = function(n) { if (n.length !== 0) { var e = Wt(vp(n), 2), t = e[0], i = e[1]; if (t.delete(i), t.size === 0) PM(n.slice(0, -1)); else if (t.size === 1) { var r = Wt(t.entries().next().value, 2), s = r[0], o = r[1]; s !== pn && IM(n.slice(0, -1), s, o); } } }; var IM = function(n, e, t) { if (n.length !== 0) { var i = Wt(vp(n), 2), r = i[0], s = i[1]; r.set(s + e, t), r.delete(s); } }; var vp = function(n) { return n[n.length - 1]; }; var _a; var yp = "or"; var OM = "and"; var x5 = "and_not"; var M5 = ( /** @class */ function() { function n(e) { if ((e == null ? void 0 : e.fields) == null) throw new Error('MiniSearch: option "fields" must be provided'); var t = e.autoVacuum == null || e.autoVacuum === true ? Bh : e.autoVacuum; this._options = _t(_t(_t({}, Nh), e), { autoVacuum: t, searchOptions: _t(_t({}, Rv), e.searchOptions || {}), autoSuggestOptions: _t(_t({}, T5), e.autoSuggestOptions || {}) }), this._index = new Ih(), this._documentCount = 0, this._documentIds = /* @__PURE__ */ new Map(), this._idToShortId = /* @__PURE__ */ new Map(), this._fieldIds = {}, this._fieldLength = /* @__PURE__ */ new Map(), this._avgFieldLength = [], this._nextId = 0, this._storedFields = /* @__PURE__ */ new Map(), this._dirtCount = 0, this._currentVacuum = null, this._enqueuedVacuum = null, this._enqueuedVacuumConditions = Ud, this.addFields(this._options.fields); } return n.prototype.add = function(e) { var t, i, r, s, o, a, c = this._options, l = c.extractField, d = c.tokenize, h6 = c.processTerm, f = c.fields, g = c.idField, p = l(e, g); if (p == null) throw new Error('MiniSearch: document does not have ID field "'.concat(g, '"')); if (this._idToShortId.has(p)) throw new Error("MiniSearch: duplicate ID ".concat(p)); var u = this.addDocumentId(p); this.saveStoredFields(u, e); try { for (var y = ct(f), v = y.next(); !v.done; v = y.next()) { var m = v.value, x = l(e, m); if (x != null) { var w = d(x.toString(), m), A = this._fieldIds[m], M = new Set(w).size; this.addFieldLength(u, A, this._documentCount - 1, M); try { for (var R = (r = void 0, ct(w)), L = R.next(); !L.done; L = R.next()) { var S = L.value, I = h6(S, m); if (Array.isArray(I)) try { for (var T = (o = void 0, ct(I)), _ = T.next(); !_.done; _ = T.next()) { var E = _.value; this.addTerm(A, u, E); } } catch (C) { o = { error: C }; } finally { try { _ && !_.done && (a = T.return) && a.call(T); } finally { if (o) throw o.error; } } else I && this.addTerm(A, u, I); } } catch (C) { r = { error: C }; } finally { try { L && !L.done && (s = R.return) && s.call(R); } finally { if (r) throw r.error; } } } } } catch (C) { t = { error: C }; } finally { try { v && !v.done && (i = y.return) && i.call(y); } finally { if (t) throw t.error; } } }, n.prototype.addAll = function(e) { var t, i; try { for (var r = ct(e), s = r.next(); !s.done; s = r.next()) { var o = s.value; this.add(o); } } catch (a) { t = { error: a }; } finally { try { s && !s.done && (i = r.return) && i.call(r); } finally { if (t) throw t.error; } } }, n.prototype.addAllAsync = function(e, t) { var i = this; t === void 0 && (t = {}); var r = t.chunkSize, s = r === void 0 ? 10 : r, o = { chunk: [], promise: Promise.resolve() }, a = e.reduce(function(d, h6, f) { var g = d.chunk, p = d.promise; return g.push(h6), (f + 1) % s === 0 ? { chunk: [], promise: p.then(function() { return new Promise(function(u) { return setTimeout(u, 0); }); }).then(function() { return i.addAll(g); }) } : { chunk: g, promise: p }; }, o), c = a.chunk, l = a.promise; return l.then(function() { return i.addAll(c); }); }, n.prototype.remove = function(e) { var t, i, r, s, o, a, c = this._options, l = c.tokenize, d = c.processTerm, h6 = c.extractField, f = c.fields, g = c.idField, p = h6(e, g); if (p == null) throw new Error('MiniSearch: document does not have ID field "'.concat(g, '"')); var u = this._idToShortId.get(p); if (u == null) throw new Error("MiniSearch: cannot remove document with ID ".concat(p, ": it is not in the index")); try { for (var y = ct(f), v = y.next(); !v.done; v = y.next()) { var m = v.value, x = h6(e, m); if (x != null) { var w = l(x.toString(), m), A = this._fieldIds[m], M = new Set(w).size; this.removeFieldLength(u, A, this._documentCount, M); try { for (var R = (r = void 0, ct(w)), L = R.next(); !L.done; L = R.next()) { var S = L.value, I = d(S, m); if (Array.isArray(I)) try { for (var T = (o = void 0, ct(I)), _ = T.next(); !_.done; _ = T.next()) { var E = _.value; this.removeTerm(A, u, E); } } catch (C) { o = { error: C }; } finally { try { _ && !_.done && (a = T.return) && a.call(T); } finally { if (o) throw o.error; } } else I && this.removeTerm(A, u, I); } } catch (C) { r = { error: C }; } finally { try { L && !L.done && (s = R.return) && s.call(R); } finally { if (r) throw r.error; } } } } } catch (C) { t = { error: C }; } finally { try { v && !v.done && (i = y.return) && i.call(y); } finally { if (t) throw t.error; } } this._storedFields.delete(u), this._documentIds.delete(u), this._idToShortId.delete(p), this._fieldLength.delete(u), this._documentCount -= 1; }, n.prototype.removeAll = function(e) { var t, i; if (e) try { for (var r = ct(e), s = r.next(); !s.done; s = r.next()) { var o = s.value; this.remove(o); } } catch (a) { t = { error: a }; } finally { try { s && !s.done && (i = r.return) && i.call(r); } finally { if (t) throw t.error; } } else { if (arguments.length > 0) throw new Error("Expected documents to be present. Omit the argument to remove all documents."); this._index = new Ih(), this._documentCount = 0, this._documentIds = /* @__PURE__ */ new Map(), this._idToShortId = /* @__PURE__ */ new Map(), this._fieldLength = /* @__PURE__ */ new Map(), this._avgFieldLength = [], this._storedFields = /* @__PURE__ */ new Map(), this._nextId = 0; } }, n.prototype.discard = function(e) { var t = this, i = this._idToShortId.get(e); if (i == null) throw new Error("MiniSearch: cannot discard document with ID ".concat(e, ": it is not in the index")); this._idToShortId.delete(e), this._documentIds.delete(i), this._storedFields.delete(i), (this._fieldLength.get(i) || []).forEach(function(r, s) { t.removeFieldLength(i, s, t._documentCount, r); }), this._fieldLength.delete(i), this._documentCount -= 1, this._dirtCount += 1, this.maybeAutoVacuum(); }, n.prototype.maybeAutoVacuum = function() { if (this._options.autoVacuum !== false) { var e = this._options.autoVacuum, t = e.minDirtFactor, i = e.minDirtCount, r = e.batchSize, s = e.batchWait; this.conditionalVacuum({ batchSize: r, batchWait: s }, { minDirtCount: i, minDirtFactor: t }); } }, n.prototype.discardAll = function(e) { var t, i, r = this._options.autoVacuum; try { this._options.autoVacuum = false; try { for (var s = ct(e), o = s.next(); !o.done; o = s.next()) { var a = o.value; this.discard(a); } } catch (c) { t = { error: c }; } finally { try { o && !o.done && (i = s.return) && i.call(s); } finally { if (t) throw t.error; } } } finally { this._options.autoVacuum = r; } this.maybeAutoVacuum(); }, n.prototype.replace = function(e) { var t = this._options, i = t.idField, r = t.extractField, s = r(e, i); this.discard(s), this.add(e); }, n.prototype.vacuum = function(e) { return e === void 0 && (e = {}), this.conditionalVacuum(e); }, n.prototype.conditionalVacuum = function(e, t) { var i = this; return this._currentVacuum ? (this._enqueuedVacuumConditions = this._enqueuedVacuumConditions && t, this._enqueuedVacuum != null ? this._enqueuedVacuum : (this._enqueuedVacuum = this._currentVacuum.then(function() { var r = i._enqueuedVacuumConditions; return i._enqueuedVacuumConditions = Ud, i.performVacuuming(e, r); }), this._enqueuedVacuum)) : this.vacuumConditionsMet(t) === false ? Promise.resolve() : (this._currentVacuum = this.performVacuuming(e), this._currentVacuum); }, n.prototype.performVacuuming = function(e, t) { return m5(this, void 0, void 0, function() { var i, r, s, o, a, c, l, d, h6, f, g, p, u, y, v, m, x, w, A, M, R, L, S, I, T; return g5(this, function(_) { switch (_.label) { case 0: if (i = this._dirtCount, !this.vacuumConditionsMet(t)) return [3, 10]; r = e.batchSize || Bd.batchSize, s = e.batchWait || Bd.batchWait, o = 1, _.label = 1; case 1: _.trys.push([1, 7, 8, 9]), a = ct(this._index), c = a.next(), _.label = 2; case 2: if (c.done) return [3, 6]; l = Wt(c.value, 2), d = l[0], h6 = l[1]; try { for (f = (L = void 0, ct(h6)), g = f.next(); !g.done; g = f.next()) { p = Wt(g.value, 2), u = p[0], y = p[1]; try { for (v = (I = void 0, ct(y)), m = v.next(); !m.done; m = v.next()) x = Wt(m.value, 1), w = x[0], !this._documentIds.has(w) && (y.size <= 1 ? h6.delete(u) : y.delete(w)); } catch (E) { I = { error: E }; } finally { try { m && !m.done && (T = v.return) && T.call(v); } finally { if (I) throw I.error; } } } } catch (E) { L = { error: E }; } finally { try { g && !g.done && (S = f.return) && S.call(f); } finally { if (L) throw L.error; } } return this._index.get(d).size === 0 && this._index.delete(d), o % r !== 0 ? [3, 4] : [4, new Promise(function(E) { return setTimeout(E, s); })]; case 3: _.sent(), _.label = 4; case 4: o += 1, _.label = 5; case 5: return c = a.next(), [3, 2]; case 6: return [3, 9]; case 7: return A = _.sent(), M = { error: A }, [3, 9]; case 8: try { c && !c.done && (R = a.return) && R.call(a); } finally { if (M) throw M.error; } return [ 7 /*endfinally*/ ]; case 9: this._dirtCount -= i, _.label = 10; case 10: return [4, null]; case 11: return _.sent(), this._currentVacuum = this._enqueuedVacuum, this._enqueuedVacuum = null, [ 2 /*return*/ ]; } }); }); }, n.prototype.vacuumConditionsMet = function(e) { if (e == null) return true; var t = e.minDirtCount, i = e.minDirtFactor; return t = t || Bh.minDirtCount, i = i || Bh.minDirtFactor, this.dirtCount >= t && this.dirtFactor >= i; }, Object.defineProperty(n.prototype, "isVacuuming", { /** * Is `true` if a vacuuming operation is ongoing, `false` otherwise */ get: function() { return this._currentVacuum != null; }, enumerable: false, configurable: true }), Object.defineProperty(n.prototype, "dirtCount", { /** * The number of documents discarded since the most recent vacuuming */ get: function() { return this._dirtCount; }, enumerable: false, configurable: true }), Object.defineProperty(n.prototype, "dirtFactor", { /** * A number between 0 and 1 giving an indication about the proportion of * documents that are discarded, and can therefore be cleaned up by vacuuming. * A value close to 0 means that the index is relatively clean, while a higher * value means that the index is relatively dirty, and vacuuming could release * memory. */ get: function() { return this._dirtCount / (1 + this._documentCount + this._dirtCount); }, enumerable: false, configurable: true }), n.prototype.has = function(e) { return this._idToShortId.has(e); }, n.prototype.getStoredFields = function(e) { var t = this._idToShortId.get(e); if (t != null) return this._storedFields.get(t); }, n.prototype.search = function(e, t) { var i, r; t === void 0 && (t = {}); var s = this.executeQuery(e, t), o = []; try { for (var a = ct(s), c = a.next(); !c.done; c = a.next()) { var l = Wt(c.value, 2), d = l[0], h6 = l[1], f = h6.score, g = h6.terms, p = h6.match, u = g.length || 1, y = { id: this._documentIds.get(d), score: f * u, terms: Object.keys(p), queryTerms: g, match: p }; Object.assign(y, this._storedFields.get(d)), (t.filter == null || t.filter(y)) && o.push(y); } } catch (v) { i = { error: v }; } finally { try { c && !c.done && (r = a.return) && r.call(a); } finally { if (i) throw i.error; } } return e === n.wildcard && t.boostDocument == null && this._options.searchOptions.boostDocument == null || o.sort(Pv), o; }, n.prototype.autoSuggest = function(e, t) { var i, r, s, o; t === void 0 && (t = {}), t = _t(_t({}, this._options.autoSuggestOptions), t); var a = /* @__PURE__ */ new Map(); try { for (var c = ct(this.search(e, t)), l = c.next(); !l.done; l = c.next()) { var d = l.value, h6 = d.score, f = d.terms, g = f.join(" "), p = a.get(g); p != null ? (p.score += h6, p.count += 1) : a.set(g, { score: h6, terms: f, count: 1 }); } } catch (A) { i = { error: A }; } finally { try { l && !l.done && (r = c.return) && r.call(c); } finally { if (i) throw i.error; } } var u = []; try { for (var y = ct(a), v = y.next(); !v.done; v = y.next()) { var m = Wt(v.value, 2), p = m[0], x = m[1], h6 = x.score, f = x.terms, w = x.count; u.push({ suggestion: p, terms: f, score: h6 / w }); } } catch (A) { s = { error: A }; } finally { try { v && !v.done && (o = y.return) && o.call(y); } finally { if (s) throw s.error; } } return u.sort(Pv), u; }, Object.defineProperty(n.prototype, "documentCount", { /** * Total number of documents available to search */ get: function() { return this._documentCount; }, enumerable: false, configurable: true }), Object.defineProperty(n.prototype, "termCount", { /** * Number of terms in the index */ get: function() { return this._index.size; }, enumerable: false, configurable: true }), n.loadJSON = function(e, t) { if (t == null) throw new Error("MiniSearch: loadJSON should be given the same options used when serializing the index"); return this.loadJS(JSON.parse(e), t); }, n.getDefault = function(e) { if (Nh.hasOwnProperty(e)) return Dh(Nh, e); throw new Error('MiniSearch: unknown option "'.concat(e, '"')); }, n.loadJS = function(e, t) { var i, r, s, o, a, c, l = e.index, d = e.documentCount, h6 = e.nextId, f = e.documentIds, g = e.fieldIds, p = e.fieldLength, u = e.averageFieldLength, y = e.storedFields, v = e.dirtCount, m = e.serializationVersion; if (m !== 1 && m !== 2) throw new Error("MiniSearch: cannot deserialize an index created with an incompatible version"); var x = new n(t); x._documentCount = d, x._nextId = h6, x._documentIds = Ac(f), x._idToShortId = /* @__PURE__ */ new Map(), x._fieldIds = g, x._fieldLength = Ac(p), x._avgFieldLength = u, x._storedFields = Ac(y), x._dirtCount = v || 0, x._index = new Ih(); try { for (var w = ct(x._documentIds), A = w.next(); !A.done; A = w.next()) { var M = Wt(A.value, 2), R = M[0], L = M[1]; x._idToShortId.set(L, R); } } catch (N) { i = { error: N }; } finally { try { A && !A.done && (r = w.return) && r.call(w); } finally { if (i) throw i.error; } } try { for (var S = ct(l), I = S.next(); !I.done; I = S.next()) { var T = Wt(I.value, 2), _ = T[0], E = T[1], C = /* @__PURE__ */ new Map(); try { for (var P = (a = void 0, ct(Object.keys(E))), b = P.next(); !b.done; b = P.next()) { var F = b.value, D = E[F]; m === 1 && (D = D.ds), C.set(parseInt(F, 10), Ac(D)); } } catch (N) { a = { error: N }; } finally { try { b && !b.done && (c = P.return) && c.call(P); } finally { if (a) throw a.error; } } x._index.set(_, C); } } catch (N) { s = { error: N }; } finally { try { I && !I.done && (o = S.return) && o.call(S); } finally { if (s) throw s.error; } } return x; }, n.prototype.executeQuery = function(e, t) { var i = this; if (t === void 0 && (t = {}), e === n.wildcard) return this.executeWildcardQuery(t); if (typeof e != "string") { var r = _t(_t(_t({}, t), e), { queries: void 0 }), s = e.queries.map(function(y) { return i.executeQuery(y, r); }); return this.combineResults(s, r.combineWith); } var o = this._options, a = o.tokenize, c = o.processTerm, l = o.searchOptions, d = _t(_t({ tokenize: a, processTerm: c }, l), t), h6 = d.tokenize, f = d.processTerm, g = h6(e).flatMap(function(y) { return f(y); }).filter(function(y) { return !!y; }), p = g.map(_5(d)), u = p.map(function(y) { return i.executeQuerySpec(y, d); }); return this.combineResults(u, d.combineWith); }, n.prototype.executeQuerySpec = function(e, t) { var i, r, s, o, a = _t(_t({}, this._options.searchOptions), t), c = (a.fields || this._options.fields).reduce(function(F, D) { var N; return _t(_t({}, F), (N = {}, N[D] = Dh(a.boost, D) || 1, N)); }, {}), l = a.boostDocument, d = a.weights, h6 = a.maxFuzzy, f = a.bm25, g = _t(_t({}, Rv.weights), d), p = g.fuzzy, u = g.prefix, y = this._index.get(e.term), v = this.termResults(e.term, e.term, 1, y, c, l, f), m, x; if (e.prefix && (m = this._index.atPrefix(e.term)), e.fuzzy) { var w = e.fuzzy === true ? 0.2 : e.fuzzy, A = w < 1 ? Math.min(h6, Math.round(e.term.length * w)) : w; A && (x = this._index.fuzzyGet(e.term, A)); } if (m) try { for (var M = ct(m), R = M.next(); !R.done; R = M.next()) { var L = Wt(R.value, 2), S = L[0], I = L[1], T = S.length - e.term.length; if (T) { x == null || x.delete(S); var _ = u * S.length / (S.length + 0.3 * T); this.termResults(e.term, S, _, I, c, l, f, v); } } } catch (F) { i = { error: F }; } finally { try { R && !R.done && (r = M.return) && r.call(M); } finally { if (i) throw i.error; } } if (x) try { for (var E = ct(x.keys()), C = E.next(); !C.done; C = E.next()) { var S = C.value, P = Wt(x.get(S), 2), b = P[0], T = P[1]; if (T) { var _ = p * S.length / (S.length + T); this.termResults(e.term, S, _, b, c, l, f, v); } } } catch (F) { s = { error: F }; } finally { try { C && !C.done && (o = E.return) && o.call(E); } finally { if (s) throw s.error; } } return v; }, n.prototype.executeWildcardQuery = function(e) { var t, i, r = /* @__PURE__ */ new Map(), s = _t(_t({}, this._options.searchOptions), e); try { for (var o = ct(this._documentIds), a = o.next(); !a.done; a = o.next()) { var c = Wt(a.value, 2), l = c[0], d = c[1], h6 = s.boostDocument ? s.boostDocument(d, "", this._storedFields.get(l)) : 1; r.set(l, { score: h6, terms: [], match: {} }); } } catch (f) { t = { error: f }; } finally { try { a && !a.done && (i = o.return) && i.call(o); } finally { if (t) throw t.error; } } return r; }, n.prototype.combineResults = function(e, t) { if (t === void 0 && (t = yp), e.length === 0) return /* @__PURE__ */ new Map(); var i = t.toLowerCase(); return e.reduce(w5[i]) || /* @__PURE__ */ new Map(); }, n.prototype.toJSON = function() { var e, t, i, r, s = []; try { for (var o = ct(this._index), a = o.next(); !a.done; a = o.next()) { var c = Wt(a.value, 2), l = c[0], d = c[1], h6 = {}; try { for (var f = (i = void 0, ct(d)), g = f.next(); !g.done; g = f.next()) { var p = Wt(g.value, 2), u = p[0], y = p[1]; h6[u] = Object.fromEntries(y); } } catch (v) { i = { error: v }; } finally { try { g && !g.done && (r = f.return) && r.call(f); } finally { if (i) throw i.error; } } s.push([l, h6]); } } catch (v) { e = { error: v }; } finally { try { a && !a.done && (t = o.return) && t.call(o); } finally { if (e) throw e.error; } } return { documentCount: this._documentCount, nextId: this._nextId, documentIds: Object.fromEntries(this._documentIds), fieldIds: this._fieldIds, fieldLength: Object.fromEntries(this._fieldLength), averageFieldLength: this._avgFieldLength, storedFields: Object.fromEntries(this._storedFields), dirtCount: this._dirtCount, index: s, serializationVersion: 2 }; }, n.prototype.termResults = function(e, t, i, r, s, o, a, c) { var l, d, h6, f, g; if (c === void 0 && (c = /* @__PURE__ */ new Map()), r == null) return c; try { for (var p = ct(Object.keys(s)), u = p.next(); !u.done; u = p.next()) { var y = u.value, v = s[y], m = this._fieldIds[y], x = r.get(m); if (x != null) { var w = x.size, A = this._avgFieldLength[m]; try { for (var M = (h6 = void 0, ct(x.keys())), R = M.next(); !R.done; R = M.next()) { var L = R.value; if (!this._documentIds.has(L)) { this.removeTerm(m, L, t), w -= 1; continue; } var S = o ? o(this._documentIds.get(L), t, this._storedFields.get(L)) : 1; if (S) { var I = x.get(L), T = this._fieldLength.get(L)[m], _ = S5(I, w, this._documentCount, T, A, a), E = i * v * S * _, C = c.get(L); if (C) { C.score += E, E5(C.terms, e); var P = Dh(C.match, t); P ? P.push(y) : C.match[t] = [y]; } else c.set(L, { score: E, terms: [e], match: (g = {}, g[t] = [y], g) }); } } } catch (b) { h6 = { error: b }; } finally { try { R && !R.done && (f = M.return) && f.call(M); } finally { if (h6) throw h6.error; } } } } } catch (b) { l = { error: b }; } finally { try { u && !u.done && (d = p.return) && d.call(p); } finally { if (l) throw l.error; } } return c; }, n.prototype.addTerm = function(e, t, i) { var r = this._index.fetch(i, Iv), s = r.get(e); if (s == null) s = /* @__PURE__ */ new Map(), s.set(t, 1), r.set(e, s); else { var o = s.get(t); s.set(t, (o || 0) + 1); } }, n.prototype.removeTerm = function(e, t, i) { if (!this._index.has(i)) { this.warnDocumentChanged(t, e, i); return; } var r = this._index.fetch(i, Iv), s = r.get(e); s == null || s.get(t) == null ? this.warnDocumentChanged(t, e, i) : s.get(t) <= 1 ? s.size <= 1 ? r.delete(e) : s.delete(t) : s.set(t, s.get(t) - 1), this._index.get(i).size === 0 && this._index.delete(i); }, n.prototype.warnDocumentChanged = function(e, t, i) { var r, s; try { for (var o = ct(Object.keys(this._fieldIds)), a = o.next(); !a.done; a = o.next()) { var c = a.value; if (this._fieldIds[c] === t) { this._options.logger("warn", "MiniSearch: document with ID ".concat(this._documentIds.get(e), ' has changed before removal: term "').concat(i, '" was not present in field "').concat(c, '". Removing a document after it has changed can corrupt the index!'), "version_conflict"); return; } } } catch (l) { r = { error: l }; } finally { try { a && !a.done && (s = o.return) && s.call(o); } finally { if (r) throw r.error; } } }, n.prototype.addDocumentId = function(e) { var t = this._nextId; return this._idToShortId.set(e, t), this._documentIds.set(t, e), this._documentCount += 1, this._nextId += 1, t; }, n.prototype.addFields = function(e) { for (var t = 0; t < e.length; t++) this._fieldIds[e[t]] = t; }, n.prototype.addFieldLength = function(e, t, i, r) { var s = this._fieldLength.get(e); s == null && this._fieldLength.set(e, s = []), s[t] = r; var o = this._avgFieldLength[t] || 0, a = o * i + r; this._avgFieldLength[t] = a / (i + 1); }, n.prototype.removeFieldLength = function(e, t, i, r) { if (i === 1) { this._avgFieldLength[t] = 0; return; } var s = this._avgFieldLength[t] * i - r; this._avgFieldLength[t] = s / (i - 1); }, n.prototype.saveStoredFields = function(e, t) { var i, r, s = this._options, o = s.storeFields, a = s.extractField; if (!(o == null || o.length === 0)) { var c = this._storedFields.get(e); c == null && this._storedFields.set(e, c = {}); try { for (var l = ct(o), d = l.next(); !d.done; d = l.next()) { var h6 = d.value, f = a(t, h6); f !== void 0 && (c[h6] = f); } } catch (g) { i = { error: g }; } finally { try { d && !d.done && (r = l.return) && r.call(l); } finally { if (i) throw i.error; } } } }, n.wildcard = Symbol("*"), n; }() ); var Dh = function(n, e) { return Object.prototype.hasOwnProperty.call(n, e) ? n[e] : void 0; }; var w5 = (_a = {}, _a[yp] = function(n, e) { var t, i; try { for (var r = ct(e.keys()), s = r.next(); !s.done; s = r.next()) { var o = s.value, a = n.get(o); if (a == null) n.set(o, e.get(o)); else { var c = e.get(o), l = c.score, d = c.terms, h6 = c.match; a.score = a.score + l, a.match = Object.assign(a.match, h6), Fv(a.terms, d); } } } catch (f) { t = { error: f }; } finally { try { s && !s.done && (i = r.return) && i.call(r); } finally { if (t) throw t.error; } } return n; }, _a[OM] = function(n, e) { var t, i, r = /* @__PURE__ */ new Map(); try { for (var s = ct(e.keys()), o = s.next(); !o.done; o = s.next()) { var a = o.value, c = n.get(a); if (c != null) { var l = e.get(a), d = l.score, h6 = l.terms, f = l.match; Fv(c.terms, h6), r.set(a, { score: c.score + d, terms: c.terms, match: Object.assign(c.match, f) }); } } } catch (g) { t = { error: g }; } finally { try { o && !o.done && (i = s.return) && i.call(s); } finally { if (t) throw t.error; } } return r; }, _a[x5] = function(n, e) { var t, i; try { for (var r = ct(e.keys()), s = r.next(); !s.done; s = r.next()) { var o = s.value; n.delete(o); } } catch (a) { t = { error: a }; } finally { try { s && !s.done && (i = r.return) && i.call(r); } finally { if (t) throw t.error; } } return n; }, _a); var A5 = { k: 1.2, b: 0.7, d: 0.5 }; var S5 = function(n, e, t, i, r, s) { var o = s.k, a = s.b, c = s.d, l = Math.log(1 + (t - e + 0.5) / (e + 0.5)); return l * (c + n * (o + 1) / (n + o * (1 - a + a * i / r))); }; var _5 = function(n) { return function(e, t, i) { var r = typeof n.fuzzy == "function" ? n.fuzzy(e, t, i) : n.fuzzy || false, s = typeof n.prefix == "function" ? n.prefix(e, t, i) : n.prefix === true; return { term: e, fuzzy: r, prefix: s }; }; }; var Nh = { idField: "id", extractField: function(n, e) { return n[e]; }, tokenize: function(n) { return n.split(C5); }, processTerm: function(n) { return n.toLowerCase(); }, fields: void 0, searchOptions: void 0, storeFields: [], logger: function(n, e) { typeof (console == null ? void 0 : console[n]) == "function" && console[n](e); }, autoVacuum: true }; var Rv = { combineWith: yp, prefix: false, fuzzy: false, maxFuzzy: 6, boost: {}, weights: { fuzzy: 0.45, prefix: 0.375 }, bm25: A5 }; var T5 = { combineWith: OM, prefix: function(n, e, t) { return e === t.length - 1; } }; var Bd = { batchSize: 1e3, batchWait: 10 }; var Ud = { minDirtFactor: 0.1, minDirtCount: 20 }; var Bh = _t(_t({}, Bd), Ud); var E5 = function(n, e) { n.includes(e) || n.push(e); }; var Fv = function(n, e) { var t, i; try { for (var r = ct(e), s = r.next(); !s.done; s = r.next()) { var o = s.value; n.includes(o) || n.push(o); } } catch (a) { t = { error: a }; } finally { try { s && !s.done && (i = r.return) && i.call(r); } finally { if (t) throw t.error; } } }; var Pv = function(n, e) { var t = n.score, i = e.score; return i - t; }; var Iv = function() { return /* @__PURE__ */ new Map(); }; var Ac = function(n) { var e, t, i = /* @__PURE__ */ new Map(); try { for (var r = ct(Object.keys(n)), s = r.next(); !s.done; s = r.next()) { var o = s.value; i.set(parseInt(o, 10), n[o]); } } catch (a) { e = { error: a }; } finally { try { s && !s.done && (t = r.return) && t.call(r); } finally { if (e) throw e.error; } } return i; }; var C5 = /[\n\r -#%-*,-/:;?@[-\]_{}\u00A0\u00A1\u00A7\u00AB\u00B6\u00B7\u00BB\u00BF\u037E\u0387\u055A-\u055F\u0589\u058A\u05BE\u05C0\u05C3\u05C6\u05F3\u05F4\u0609\u060A\u060C\u060D\u061B\u061E\u061F\u066A-\u066D\u06D4\u0700-\u070D\u07F7-\u07F9\u0830-\u083E\u085E\u0964\u0965\u0970\u09FD\u0A76\u0AF0\u0C77\u0C84\u0DF4\u0E4F\u0E5A\u0E5B\u0F04-\u0F12\u0F14\u0F3A-\u0F3D\u0F85\u0FD0-\u0FD4\u0FD9\u0FDA\u104A-\u104F\u10FB\u1360-\u1368\u1400\u166E\u1680\u169B\u169C\u16EB-\u16ED\u1735\u1736\u17D4-\u17D6\u17D8-\u17DA\u1800-\u180A\u1944\u1945\u1A1E\u1A1F\u1AA0-\u1AA6\u1AA8-\u1AAD\u1B5A-\u1B60\u1BFC-\u1BFF\u1C3B-\u1C3F\u1C7E\u1C7F\u1CC0-\u1CC7\u1CD3\u2000-\u200A\u2010-\u2029\u202F-\u2043\u2045-\u2051\u2053-\u205F\u207D\u207E\u208D\u208E\u2308-\u230B\u2329\u232A\u2768-\u2775\u27C5\u27C6\u27E6-\u27EF\u2983-\u2998\u29D8-\u29DB\u29FC\u29FD\u2CF9-\u2CFC\u2CFE\u2CFF\u2D70\u2E00-\u2E2E\u2E30-\u2E4F\u3000-\u3003\u3008-\u3011\u3014-\u301F\u3030\u303D\u30A0\u30FB\uA4FE\uA4FF\uA60D-\uA60F\uA673\uA67E\uA6F2-\uA6F7\uA874-\uA877\uA8CE\uA8CF\uA8F8-\uA8FA\uA8FC\uA92E\uA92F\uA95F\uA9C1-\uA9CD\uA9DE\uA9DF\uAA5C-\uAA5F\uAADE\uAADF\uAAF0\uAAF1\uABEB\uFD3E\uFD3F\uFE10-\uFE19\uFE30-\uFE52\uFE54-\uFE61\uFE63\uFE68\uFE6A\uFE6B\uFF01-\uFF03\uFF05-\uFF0A\uFF0C-\uFF0F\uFF1A\uFF1B\uFF1F\uFF20\uFF3B-\uFF3D\uFF3F\uFF5B\uFF5D\uFF5F-\uFF65]+/u; var L5 = class { constructor() { this._searchEngine = new M5({ fields: ["path", "name"], storeFields: ["path"], tokenize: (e, t) => e.split(/[\s/]+/) // indexing tokenizer }), this.idMaps = {}; } addZincObject(e, t) { const i = e.getRegion().getFullPath(); let r = e.groupName, s = i ? `${i}/${e.groupName}` : e.groupName; r = r.replaceAll('"', ""), s = s.replaceAll('"', ""); const o = { path: s, name: r, id: t }; this._searchEngine.add(o), this.idMaps[t] = { path: s, zincObject: e }; } removeZincObject(e, t) { const i = e.getRegion().getFullPath(); let r = e.groupName, s = i ? `${i}/${e.groupName}` : e.groupName; r = r.replaceAll('"', ""), s = s.replaceAll('"', ""); const o = { path: s, name: r, id: t }; this._searchEngine.remove(o), delete this.idMaps[t]; } addRegion(e, t) { let i = e.getFullPath(), r = e.getName(); i = i.replaceAll('"', ""), r = r.replaceAll('"', ""); const s = { path: i, name: r, id: t }; this._searchEngine.add(s), this.idMaps[t] = { path: i, zincObject: e }; } clearResults() { this._; } removeAll() { this._searchEngine.removeAll(), this.idMaps = {}; } auto_suggest(e) { let t = []; e.length > 2 && ["'", '"'].includes(e.slice(0, 1)) ? (e = e.replaceAll(e.slice(0, 1), ""), t = this._searchEngine.search(e, { prefix: true, combineWith: "AND" })) : e.length > 1 && (t = this._searchEngine.search(e, { prefix: true })); const i = []; t.forEach((o) => { o.id in this.idMaps && i.push(this.idMaps[o.id].path); }); const r = [...new Set(i)], s = []; return r.forEach((o) => s.push({ suggestion: '"' + o + '"' })), s; } processResults(e, t) { const i = { regionPath: void 0, label: 'Search Results for "' }; return Array.isArray(t) ? i.label += ",".join(t) : i.label += t, i.label += '"', e.length === 1 && (e[0].isRegion ? i.regionPath = e[0].getFullPath() : e[0].isZincObject && (i.regionPath = e[0].getRegion().getFullPath(), i.label = e[0].groupName)), i.zincObjects = B4(e), i; } search(e) { let t; e.length > 2 && ["'", '"'].includes(e.slice(0, 1)) ? (e = e.replaceAll(e.slice(0, 1), ""), t = this._searchEngine.search(e, { prefix: true, combineWith: "AND" })) : e.length > 1 && (t = this._searchEngine.search(e, { prefix: true })); const i = []; return t.forEach((r) => { r.id in this.idMaps && i.push(this.idMaps[r.id].zincObject); }), i; } searchTerms(e) { let t = []; return e.forEach((i) => { const r = this.search(i); t.push(...r); }), t; } searchAndProcessResult(e) { let t = []; return Array.isArray(e) ? t = this.searchTerms(e) : t = this.search(e), this.processResults(t, e); } }; var R5 = [ { id: 0, nerve_id: "ILX:0793723", label: "Auriculotemporal nerve", "FMA subclasses (in human nerves)": ["FMA:53002", "FMA:53001"], "subclass labels": ["Left auriculotemporal nerve", "Right auriculotemporal nerve"] }, { id: 1, nerve_id: "ILX:0792409", label: "gray communicating ramus of tenth thoracic nerve", "FMA subclasses (in human nerves)": ["FMA:6895", "FMA:6894"], "subclass labels": ["Left T10 grey ramus communicans", "Right T10 grey ramus communicans"] }, { id: 2, nerve_id: "UBERON:0011326", label: "superior laryngeal nerve", "FMA subclasses (in human nerves)": ["FMA:53530", "FMA:53536"], "subclass labels": ["Right superior laryngeal nerve", "Left superior laryngeal nerve"] }, { id: 3, nerve_id: "ILX:0793220", label: "white communicating ramus of first lumbar spinal nerve", "FMA subclasses (in human nerves)": [], "subclass labels": [] }, { id: 4, nerve_id: "ILX:0787082", label: "gray communicating ramus of the first thoracic nerve", "FMA subclasses (in human nerves)": ["FMA:6082", "FMA:6084"], "subclass labels": ["Right T1 grey ramus communicans", "Left T1 grey ramus communicans"] }, { id: 5, nerve_id: "ILX:0793809", label: "Clitoral cavernous nerve", "FMA subclasses (in human nerves)": [], "subclass labels": [] }, { id: 6, nerve_id: "UBERON:0011096", label: "lacrimal nerve", "FMA subclasses (in human nerves)": ["FMA:52630", "FMA:52629"], "subclass labels": ["Left lacrimal nerve", "Right lacrimal nerve"] }, { id: 7, nerve_id: "ILX:0793215", label: "white communicating ramus of ninth thoracic spinal nerve", "FMA subclasses (in human nerves)": [], "subclass labels": [] }, { id: 8, nerve_id: "ILX:0795005", label: "Posterior cutaneous nerve of arm", "FMA subclasses (in human nerves)": [], "subclass labels": [] }, { id: 9, nerve_id: "UBERON:0001649", label: "glossopharyngeal nerve", "FMA subclasses (in human nerves)": ["FMA:50894", "FMA:50892"], "subclass labels": [] }, { id: 10, nerve_id: "UBERON:0022302", label: "short ciliary nerve", "FMA subclasses (in human nerves)": [], "subclass labels": [] }, { id: 11, nerve_id: "ILX:0785932", label: "gray communicating ramus of third lumbar nerve", "FMA subclasses (in human nerves)": ["FMA:65920", "FMA:65919"], "subclass labels": ["Left L3 grey ramus communicans", "Right L3 grey ramus communicans"] }, { id: 12, nerve_id: "ILX:0738293", label: "Ganglioglomerular nerve", "FMA subclasses (in human nerves)": [], "subclass labels": [] }, { id: 13, nerve_id: "ILX:0739298", label: "gray communicating ramus of twelfth thoracic nerve", "FMA subclasses (in human nerves)": [], "subclass labels": [] }, { id: 14, nerve_id: "UBERON:0001492", label: "radial nerve", "FMA subclasses (in human nerves)": ["FMA:37070", "FMA:37071"], "subclass labels": ["Right radial nerve", "Left radial nerve"] }, { id: 15, nerve_id: "ILX:0793214", label: "white communicating ramus of eighth thoracic spinal nerve", "FMA subclasses (in human nerves)": [], "subclass labels": [] }, { id: 16, nerve_id: "UBERON:0018681", label: "lesser splanchnic nerve", "FMA subclasses (in human nerves)": ["FMA:6957", "FMA:6958"], "subclass labels": ["Right lesser splanchnic nerve", "Left lesser splanchnic nerve"] }, { id: 17, nerve_id: "ILX:0794476", label: "abdominal branch of vagus nerve", "FMA subclasses (in human nerves)": [], "subclass labels": [] }, { id: 18, nerve_id: "ILX:0791105", label: "gray communicating ramus of the second thoracic nerve", "FMA subclasses (in human nerves)": ["FMA:6122", "FMA:6757"], "subclass labels": ["Right T2 grey ramus communicans", "Left T2 grey ramus communicans"] }, { id: 19, nerve_id: "ILX:0794853", label: "esophageal vagus trunk", "FMA subclasses (in human nerves)": [], "subclass labels": [] }, { id: 20, nerve_id: "ILX:0793210", label: "white communicating ramus of fourth thoracic spinal nerve", "FMA subclasses (in human nerves)": [], "subclass labels": [] }, { id: 21, nerve_id: "UBERON:0001759", label: "vagus nerve", "FMA subclasses (in human nerves)": [], "subclass labels": [] }, { id: 22, nerve_id: "UBERON:0009675", label: "chorda tympani branch of facial nerve", "FMA subclasses (in human nerves)": [], "subclass labels": [] }, { id: 23, nerve_id: "ILX:0794949", label: "recurrent branch of the median nerve", "FMA subclasses (in human nerves)": [], "subclass labels": [] }, { id: 24, nerve_id: "ILX:0789339", label: "Pharyngeal branch of glossopharyngeal nerve", "FMA subclasses (in human nerves)": ["FMA:53495", "FMA:53494"], "subclass labels": ["Pharyngeal branch of left glossopharyngeal nerve", "Pharyngeal branch of right glossopharyngeal nerve"] }, { id: 25, nerve_id: "ILX:0793712", label: "Zygomatic nerve", "FMA subclasses (in human nerves)": ["FMA:52968", "FMA:52969"], "subclass labels": ["Right zygomatic nerve", "Left zygomatic nerve"] }, { id: 26, nerve_id: "ILX:0788536", label: "gray communicating ramus of fourth lumbar nerve", "FMA subclasses (in human nerves)": ["FMA:65917", "FMA:65918"], "subclass labels": ["Right L4 grey ramus communicans", "Left L4 grey ramus communicans"] }, { id: 27, nerve_id: "UBERON:0018680", label: "greater splanchnic nerve", "FMA subclasses (in human nerves)": ["FMA:6956", "FMA:6955"], "subclass labels": ["Right greater splanchnic nerve", "Left greater splanchnic nerve"] }, { id: 28, nerve_id: "UBERON:0001322", label: "sciatic nerve", "FMA subclasses (in human nerves)": ["FMA:22111", "FMA:22112"], "subclass labels": ["Right sciatic nerve", "Left sciatic nerve"] }, { id: 29, nerve_id: "ILX:0793209", label: "white communicating ramus of third thoracic spinal nerve", "FMA subclasses (in human nerves)": [], "subclass labels": [] }, { id: 30, nerve_id: "UBERON:0011391", label: "perineal nerve", "FMA subclasses (in human nerves)": ["FMA:21874", "FMA:21873"], "subclass labels": ["Left perineal nerve", "Right perineal nerve"] }, { id: 31, nerve_id: "ILX:0788945", label: "gray communicating ramus of the fourth thoracic nerve", "FMA subclasses (in human nerves)": ["FMA:6759", "FMA:6758"], "subclass labels": ["Right T4 grey ramus communicans", "Left T4 grey ramus communicans"] }, { id: 32, nerve_id: "ILX:0790497", label: "Gray communicating ramus of cervicothoracic ganglion to first thoracic spinal nerve", "FMA subclasses (in human nerves)": [], "subclass labels": [] }, { id: 33, nerve_id: "UBERON:0001323", label: "tibial nerve", "FMA subclasses (in human nerves)": ["FMA:22109", "FMA:22110"], "subclass labels": ["Right tibial nerve", "Left tibial nerve"] }, { id: 34, nerve_id: "ILX:0794969", label: "deep branch of ulnar nerve", "FMA subclasses (in human nerves)": [], "subclass labels": [] }, { id: 35, nerve_id: "ILX:0793227", label: "gray communicating ramus of thirteenth thoracic nerve", "FMA subclasses (in human nerves)": [], "subclass labels": [] }, { id: 36, nerve_id: "ILX:0793228", label: "gray communicating ramus of first sacral nerve", "FMA subclasses (in human nerves)": ["FMA:65992", "FMA:65991"], "subclass labels": ["Left S1 grey ramus communicans", "Right S1 grey ramus communicans"] }, { id: 37, nerve_id: "UBERON:0035111", label: "medial plantar nerve", "FMA subclasses (in human nerves)": ["FMA:45435", "FMA:45434"], "subclass labels": ["Left medial plantar nerve", "Right medial plantar nerve"] }, { id: 38, nerve_id: "UBERON:0001780", label: "spinal nerve", "FMA subclasses (in human nerves)": ["FMA:6117", "FMA:6435", "FMA:6295", "FMA:6422", "FMA:6417", "FMA:6421", "FMA:6038", "FMA:6292", "FMA:6439", "FMA:6313", "FMA:6410", "FMA:6412", "FMA:6088", "FMA:6298", "FMA:6433", "FMA:6411", "FMA:6438", "FMA:6314", "FMA:6291", "FMA:6420", "FMA:6116", "FMA:6413", "FMA:6310", "FMA:6432", "FMA:6305", "FMA:6182", "FMA:6297", "FMA:6436", "FMA:6418", "FMA:6039", "FMA:6089", "FMA:6301", "FMA:6294", "FMA:6303", "FMA:6183", "FMA:6434", "FMA:6429", "FMA:6308", "FMA:6300", "FMA:6430", "FMA:6428", "FMA:6419", "FMA:6437", "FMA:6307", "FMA:6311", "FMA:6431"], "subclass labels": ["Left T3 spinal nerve", "Left S4 spinal nerve", "Left T5 spinal nerve", "Left L5 spinal nerve", "Right L3 spinal nerve", "Right L5 spinal nerve", "Right T1 spinal nerve", "Left T4 spinal nerve", "Left coccygeal spinal nerve", "Right T11 spinal nerve", "Right L1 spinal nerve", "Right L2 spinal nerve", "Right T2 spinal nerve", "Left T6 spinal nerve", "Left S3 spinal nerve", "Left L1 spinal nerve", "Right coccygeal spinal nerve", "Left T11 spinal nerve", "Right T4 spinal nerve", "Left L4 spinal nerve", "Right T3 spinal nerve", "Left L2 spinal nerve", "Right T10 spinal nerve", "Right S3 spinal nerve", "Left T8 spinal nerve", "Right T12 spinal nerve", "Right T6 spinal nerve", "Right S5 spinal nerve", "Left L3 spinal nerve", "Left T1 spinal nerve", "Left T2 spinal nerve", "Left T7 spinal nerve", "Right T5 spinal nerve", "Right T8 spinal nerve", "Left T12 spinal nerve", "Right S4 spinal nerve", "Left S1 spinal nerve", "Left T9 spinal nerve", "Right T7 spinal nerve", "Right S2 spinal nerve", "Right S1 spinal nerve", "Right L4 spinal nerve", "Left S5 spinal nerve", "Right T9 spinal nerve", "Left T10 spinal nerve", "Left S2 spinal nerve"] }, { id: 39, nerve_id: "UBERON:0018683", label: "lumbar splanchnic nerve", "FMA subclasses (in human nerves)": ["FMA:6924", "FMA:6928", "FMA:6929", "FMA:6931", "FMA:6925", "FMA:6930", "FMA:6927", "FMA:6926"], "subclass labels": ["Right first lumbar splanchnic nerve", "Right third lumbar splanchnic nerve", "Left third lumbar splanchnic nerve", "Left fourth lumbar splanchnic nerve", "Left first lumbar splanchnic nerve", "Right fourth lumbar splanchnic nerve", "Left second lumbar splanchnic nerve", "Right second lumbar splanchnic nerve"] }, { id: 40, nerve_id: "UBERON:0001643", label: "oculomotor nerve", "FMA subclasses (in human nerves)": ["FMA:50880", "FMA:50879"], "subclass labels": ["Left oculomotor nerve", "Right oculomotor nerve"] }, { id: 41, nerve_id: "ILX:0793212", label: "white communicating ramus of sixth thoracic spinal nerve", "FMA subclasses (in human nerves)": [], "subclass labels": [] }, { id: 42, nerve_id: "UBERON:0003724", label: "musculocutaneous nerve", "FMA subclasses (in human nerves)": ["FMA:37066", "FMA:37065"], "subclass labels": ["Left musculocutaneous nerve", "Right musculocutaneous nerve"] }, { id: 43, nerve_id: "ILX:0738372", label: "white communicating ramus of first thoracic spinal nerve", "FMA subclasses (in human nerves)": [], "subclass labels": [] }, { id: 44, nerve_id: "ILX:0793563", label: "splenic nerve", "FMA subclasses (in human nerves)": [], "subclass labels": [] }, { id: 45, nerve_id: "UBERON:0035526", label: "superficial fibular nerve", "FMA subclasses (in human nerves)": ["FMA:45363", "FMA:45364"], "subclass labels": ["Right superficial fibular nerve", "Left superficial fibular nerve"] }, { id: 46, nerve_id: "ILX:0791560", label: "gray communicating ramus of eighth thoracic nerve", "FMA subclasses (in human nerves)": ["FMA:6891", "FMA:6890"], "subclass labels": ["Left T8 grey ramus communicans", "Right T8 grey ramus communicans"] }, { id: 47, nerve_id: "ILX:0793827", label: "posterior abdominal vagal trunk", "FMA subclasses (in human nerves)": [], "subclass labels": [] }, { id: 48, nerve_id: "ILX:0794141", label: "right cervical vagus nerve", "FMA subclasses (in human nerves)": [], "subclass labels": [] }, { id: 49, nerve_id: "ILX:0793714", label: "Mesenteric nerve", "FMA subclasses (in human nerves)": [], "subclass labels": [] }, { id: 50, nerve_id: "UBERON:0001964", label: "least splanchnic nerve", "FMA subclasses (in human nerves)": ["FMA:6960", "FMA:6959"], "subclass labels": ["Left least splanchnic nerve", "Right least splanchnic nerve"] }, { id: 51, nerve_id: "UBERON:0001267", label: "femoral nerve", "FMA subclasses (in human nerves)": ["FMA:16499", "FMA:16500"], "subclass labels": ["Right femoral nerve", "Left femoral nerve"] }, { id: 52, nerve_id: "UBERON:0034984", label: "nerve to quadratus femoris", "FMA subclasses (in human nerves)": [], "subclass labels": [] }, { id: 53, nerve_id: "UBERON:0003721", label: "lingual nerve", "FMA subclasses (in human nerves)": ["FMA:53219", "FMA:53220"], "subclass labels": ["Right lingual nerve", "Left lingual nerve"] }, { id: 54, nerve_id: "UBERON:0036216", label: "tympanic nerve", "FMA subclasses (in human nerves)": ["FMA:53481", "FMA:53482"], "subclass labels": ["Right tympanic nerve", "Left tympanic nerve"] }, { id: 55, nerve_id: "ILX:0793216", label: "white communicating ramus of tenth thoracic spinal nerve", "FMA subclasses (in human nerves)": [], "subclass labels": [] }, { id: 56, nerve_id: "ILX:0793362", label: "White communicating ramus of fourth lumbar anterior ramus", "FMA subclasses (in human nerves)": [], "subclass labels": [] }, { id: 57, nerve_id: "ILX:0793561", label: "Internal branch of superior laryngeal nerve", "FMA subclasses (in human nerves)": ["FMA:53539", "FMA:53540"], "subclass labels": ["Right internal laryngeal nerve", "Left internal laryngeal nerve"] }, { id: 58, nerve_id: "ILX:0738312", label: "Aortic arch depressor nerve", "FMA subclasses (in human nerves)": [], "subclass labels": [] }, { id: 59, nerve_id: "ILX:0793218", label: "white communicating ramus of twelfth thoracic spinal nerve", "FMA subclasses (in human nerves)": [], "subclass labels": [] }, { id: 60, nerve_id: "ILX:0738308", label: "External branch of inferior laryngeal nerve", "FMA subclasses (in human nerves)": [], "subclass labels": [] }, { id: 61, nerve_id: "ILX:0739299", label: "gray communicating ramus of sixth lumbar nerve", "FMA subclasses (in human nerves)": [], "subclass labels": [] }, { id: 62, nerve_id: "ILX:0793559", label: "bladder nerve", "FMA subclasses (in human nerves)": [], "subclass labels": [] }, { id: 63, nerve_id: "ILX:0793822", label: "Superior ovarian nerve", "FMA subclasses (in human nerves)": [], "subclass labels": [] }, { id: 64, nerve_id: "ILX:0793807", label: "Penile cavernous nerve", "FMA subclasses (in human nerves)": [], "subclass labels": [] }, { id: 65, nerve_id: "UBERON:0011390", label: "pudendal nerve", "FMA subclasses (in human nerves)": ["FMA:21863", "FMA:21864"], "subclass labels": ["Right pudendal nerve", "Left pudendal nerve"] }, { id: 66, nerve_id: "UBERON:0008810", label: "nasopalatine nerve", "FMA subclasses (in human nerves)": ["FMA:52799", "FMA:52798"], "subclass labels": ["Left nasopalatine nerve", "Right nasopalatine nerve"] }, { id: 67, nerve_id: "ILX:0793219", label: "white communicating ramus of thirteenth thoracic spinal nerve", "FMA subclasses (in human nerves)": [], "subclass labels": [] }, { id: 68, nerve_id: "ILX:0793632", label: "lumbar colonic nerve", "FMA subclasses (in human nerves)": [], "subclass labels": [] }, { id: 69, nerve_id: "ILX:0784439", label: "gray communicating ramus of the fifth thoracic nerve", "FMA subclasses (in human nerves)": ["FMA:6760", "FMA:6761"], "subclass labels": ["Left T5 grey ramus communicans", "Right T5 grey ramus communicans"] }, { id: 70, nerve_id: "ILX:0794977", label: "deep branch of radial nerve", "FMA subclasses (in human nerves)": [], "subclass labels": [] }, { id: 71, nerve_id: "UBERON:0001884", label: "phrenic nerve", "FMA subclasses (in human nerves)": ["FMA:6193", "FMA:6192"], "subclass labels": ["Left phrenic nerve", "Right phrenic nerve"] }, { id: 72, nerve_id: "UBERON:0035110", label: "lateral plantar nerve", "FMA subclasses (in human nerves)": ["FMA:45450", "FMA:45451"], "subclass labels": ["Right lateral plantar nerve", "Left lateral plantar nerve"] }, { id: 73, nerve_id: "ILX:0793711", label: "Communicating branch of zygomatic nerve", "FMA subclasses (in human nerves)": [], "subclass labels": [] }, { id: 74, nerve_id: "ILX:0793560", label: "External branch of superior laryngeal nerve", "FMA subclasses (in human nerves)": ["FMA:53537", "FMA:53538"], "subclass labels": ["Right external laryngeal nerve", "Left external laryngeal nerve"] }, { id: 75, nerve_id: "ILX:0738309", label: "Internal branch of inferior laryngeal nerve", "FMA subclasses (in human nerves)": [], "subclass labels": [] }, { id: 76, nerve_id: "UBERON:0001021", label: "nerve", "FMA subclasses (in human nerves)": ["FMA:6775", "FMA:6894", "FMA:6784", "FMA:6728", "FMA:65325", "FMA:21873", "FMA:45429", "FMA:6844", "FMA:53609", "FMA:7116", "FMA:44770", "FMA:8916", "FMA:52995", "FMA:6071", "FMA:45309", "FMA:6122", "FMA:6892", "FMA:6767", "FMA:16405", "FMA:53560", "FMA:6092", "FMA:65343", "FMA:37066", "FMA:8894", "FMA:8868", "FMA:65341", "FMA:53559", "FMA:8897", "FMA:82956", "FMA:20633", "FMA:6763", "FMA:65339", "FMA:8829", "FMA:16493", "FMA:8817", "FMA:8821", "FMA:11757", "FMA:45456", "FMA:45422", "FMA:11261", "FMA:65388", "FMA:6192", "FMA:65347", "FMA:37068", "FMA:65995", "FMA:6764", "FMA:39081", "FMA:45338", "FMA:53402", "FMA:11210", "FMA:52644", "FMA:37067", "FMA:65313", "FMA:11153", "FMA:6155", "FMA:8797", "FMA:53302", "FMA:8883", "FMA:53067", "FMA:52939", "FMA:53301", "FMA:292889", "FMA:45423", "FMA:8791", "FMA:45380", "FMA:11759", "FMA:7305", "FMA:8830", "FMA:78650", "FMA:65389", "FMA:45387", "FMA:8827", "FMA:8912", "FMA:52941", "FMA:6743", "FMA:7126", "FMA:53485", "FMA:16492", "FMA:53399", "FMA:65337", "FMA:11209", "FMA:6772", "FMA:52726", "FMA:6121", "FMA:52627", "FMA:52974", "FMA:53571", "FMA:6729", "FMA:8729", "FMA:53606", "FMA:80025", "FMA:53481", "FMA:53575", "FMA:45451", "FMA:11218", "FMA:22109", "FMA:6852", "FMA:8909", "FMA:11751", "FMA:65991", "FMA:8836", "FMA:65350", "FMA:53423", "FMA:65569", "FMA:65314", "FMA:82957", "FMA:65438", "FMA:39146", "FMA:8911", "FMA:22111", "FMA:65916", "FMA:65739", "FMA:65917", "FMA:6779", "FMA:8889", "FMA:65924", "FMA:65316", "FMA:53002", "FMA:16887", "FMA:53366", "FMA:6890", "FMA:8790", "FMA:6730", "FMA:45358", "FMA:52716", "FMA:53494", "FMA:7115", "FMA:53561", "FMA:78655", "FMA:45366", "FMA:11219", "FMA:11555", "FMA:7092", "FMA:53220", "FMA:45428", "FMA:6193", "FMA:20604", "FMA:45433", "FMA:21874", "FMA:21875", "FMA:53244", "FMA:45432", "FMA:6770", "FMA:52640", "FMA:11249", "FMA:20630", "FMA:53308", "FMA:11216", "FMA:65399", "FMA:78649", "FMA:11084", "FMA:6897", "FMA:53633", "FMA:6085", "FMA:6851", "FMA:45457", "FMA:6757", "FMA:8732", "FMA:8824", "FMA:20632", "FMA:6137", "FMA:52730", "FMA:7301", "FMA:52699", "FMA:53607", "FMA:7300", "FMA:53576", "FMA:44904", "FMA:65342", "FMA:7127", "FMA:6737", "FMA:52669", "FMA:21876", "FMA:45425", "FMA:65999", "FMA:8728", "FMA:21871", "FMA:55172", "FMA:6149", "FMA:45453", "FMA:44932", "FMA:292832", "FMA:6744", "FMA:6781", "FMA:44769", "FMA:45326", "FMA:6760", "FMA:53634", "FMA:53605", "FMA:53530", "FMA:6821", "FMA:52968", "FMA:53001", "FMA:11552", "FMA:45264", "FMA:8835", "FMA:6888", "FMA:55160", "FMA:44899", "FMA:52979", "FMA:45333", "FMA:45310", "FMA:6084", "FMA:11781", "FMA:82962", "FMA:53280", "FMA:52715", "FMA:53311", "FMA:16491", "FMA:21880", "FMA:44952", "FMA:11687", "FMA:11212", "FMA:65335", "FMA:52940", "FMA:6774", "FMA:8823", "FMA:45388", "FMA:6666", "FMA:6072", "FMA:16886", "FMA:53312", "FMA:65915", "FMA:45357", "FMA:11262", "FMA:65921", "FMA:0328826", "FMA:81290", "FMA:53279", "FMA:11551", "FMA:7293", "FMA:6677", "FMA:11756", "FMA:53598", "FMA:52732", "FMA:44902", "FMA:53545", "FMA:6740", "FMA:53502", "FMA:53562", "FMA:52700", "FMA:7122", "FMA:6118", "FMA:65918", "FMA:8814", "FMA:16403", "FMA:65346", "FMA:6667", "FMA:52630", "FMA:52629", "FMA:8871", "FMA:16500", "FMA:52725", "FMA:6108", "FMA:45363", "FMA:65340", "FMA:8872", "FMA:11760", "FMA:53604", "FMA:11214", "FMA:52777", "FMA:21864", "FMA:53503", "FMA:6738", "FMA:66000", "FMA:6776", "FMA:6777", "FMA:6765", "FMA:6111", "FMA:8890", "FMA:20607", "FMA:52643", "FMA:8908", "FMA:65437", "FMA:6762", "FMA:11154", "FMA:65344", "FMA:52937", "FMA:8919", "FMA:45354", "FMA:6766", "FMA:53424", "FMA:6145", "FMA:65568", "FMA:20634", "FMA:6732", "FMA:8893", "FMA:11758", "FMA:6889", "FMA:11554", "FMA:65922", "FMA:7118", "FMA:16884", "FMA:45308", "FMA:7290", "FMA:6758", "FMA:65743", "FMA:11063", "FMA:16885", "FMA:8882", "FMA:65286", "FMA:291238", "FMA:53482", "FMA:52976", "FMA:11308", "FMA:53432", "FMA:53540", "FMA:45379", "FMA:44871", "FMA:6714", "FMA:82955", "FMA:65993", "FMA:45452", "FMA:52626", "FMA:6083", "FMA:53582", "FMA:65919", "FMA:52936", "FMA:53506", "FMA:8918", "FMA:44901", "FMA:6073", "FMA:65315", "FMA:53219", "FMA:11194", "FMA:6792", "FMA:7119", "FMA:52785", "FMA:7296", "FMA:53068", "FMA:6845", "FMA:52677", "FMA:53504", "FMA:53548", "FMA:52698", "FMA:53570", "FMA:6771", "FMA:7078", "FMA:65997", "FMA:65338", "FMA:52969", "FMA:16401", "FMA:65416", "FMA:6835", "FMA:39082", "FMA:8726", "FMA:45254", "FMA:8879", "FMA:11250", "FMA:53049", "FMA:45382", "FMA:8795", "FMA:53495", "FMA:45434", "FMA:82963", "FMA:0328827", "FMA:52656", "FMA:82961", "FMA:11753", "FMA:39147", "FMA:45339", "FMA:20605", "FMA:20631", "FMA:8898", "FMA:6070", "FMA:44892", "FMA:16404", "FMA:52942", "FMA:6082", "FMA:8861", "FMA:82953", "FMA:8808", "FMA:8805", "FMA:52994", "FMA:65348", "FMA:55173", "FMA:7129", "FMA:52674", "FMA:44894", "FMA:55159", "FMA:65327", "FMA:37320", "FMA:6761", "FMA:65349", "FMA:11253", "FMA:53507", "FMA:11213", "FMA:7307", "FMA:6769", "FMA:6759", "FMA:55155", "FMA:53675", "FMA:53599", "FMA:65282", "FMA:53251", "FMA:6731", "FMA:11111", "FMA:16497", "FMA:8878", "FMA:11211", "FMA:65740", "FMA:45367", "FMA:53588", "FMA:45365", "UBERON:0011766", "FMA:16502", "FMA:6891", "FMA:6091", "FMA:11018", "FMA:6090", "FMA:292887", "FMA:65401", "FMA:65326", "FMA:11215", "FMA:44735", "FMA:8735", "FMA:53538", "FMA:6849", "FMA:53608", "FMA:11217", "FMA:8860", "FMA:6134", "FMA:6893", "FMA:53534", "FMA:45361", "FMA:37321", "FMA:82734", "FMA:22112", "FMA:7294", "FMA:52987", "FMA:65247", "FMA:53535", "FMA:6895", "FMA:52787", "FMA:53635", "FMA:65920", "FMA:55156", "FMA:16498", "FMA:53569", "FMA:6739", "FMA:8807", "FMA:22110", "FMA:81294", "FMA:45450", "FMA:8922", "FMA:8725", "FMA:20608", "FMA:7308", "FMA:65281", "FMA:39084", "FMA:78656", "FMA:6133", "FMA:53581", "FMA:16494", "FMA:53252", "FMA:11789", "FMA:45364", "FMA:65345", "FMA:44870", "FMA:39083", "FMA:45355", "FMA:11193", "FMA:16400", "FMA:81287", "FMA:52776", "FMA:65747", "FMA:8900", "UBERON:0011767", "FMA:45424", "FMA:292830", "FMA:44734", "FMA:45381", "FMA:82960", "FMA:0328831", "FMA:6689", "FMA:7077", "FMA:291236", "FMA:8886", "FMA:276381", "FMA:6124", "FMA:65336", "FMA:65328", "FMA:52670", "FMA:53537", "FMA:53636", "FMA:6896", "FMA:21879", "FMA:8798", "FMA:81288", "FMA:53542", "FMA:45368", "FMA:53547", "FMA:55157", "FMA:65415", "FMA:53309", "FMA:65744", "FMA:53367", "FMA:53590", "FMA:65923", "FMA:53048", "FMA:16499", "FMA:53610", "FMA:44951", "FMA:44953", "FMA:8832", "FMA:45426", "FMA:6114", "FMA:52799", "FMA:11039", "FMA:53546", "FMA:53589", "FMA:8901", "FMA:11681", "FMA:52639", "FMA:8905", "FMA:52733", "FMA:65992", "FMA:52807", "FMA:45435", "FMA:53484", "FMA:52975", "FMA:7289", "FMA:44905", "FMA:37071", "FMA:7130", "FMA:65996", "FMA:6132", "FMA:8826", "FMA:6741", "FMA:11252", "FMA:8917", "FMA:82954", "FMA:6832", "FMA:37073", "FMA:37074", "FMA:44893", "FMA:82959", "FMA:20635", "FMA:6093", "FMA:65248", "FMA:45362", "FMA:52622", "FMA:53508", "FMA:11755", "FMA:82958", "FMA:52997", "FMA:16501", "FMA:65402", "FMA:45427", "FMA:52803", "FMA:16402", "FMA:8734", "FMA:52784", "FMA:45454", "FMA:6736", "FMA:7304", "FMA:6742", "FMA:52998", "FMA:52804", "FMA:11788", "FMA:6713", "FMA:52623", "FMA:53536", "FMA:11780", "FMA:45334", "FMA:52701", "FMA:65998", "FMA:11092", "FMA:6684", "FMA:52779", "FMA:52778", "FMA:78652", "FMA:0328830", "FMA:6733", "FMA:44950", "FMA:78653", "FMA:45455", "FMA:8864", "FMA:8833", "FMA:8876", "FMA:8867", "FMA:11752", "FMA:53541", "FMA:53611", "FMA:8904", "FMA:6745", "FMA:21863", "FMA:7297", "FMA:52676", "FMA:52798", "FMA:8818", "FMA:82735", "FMA:52657", "FMA:52786", "FMA:6773", "FMA:45253", "FMA:6127", "FMA:45263", "FMA:8875", "FMA:81295", "FMA:11754", "FMA:8812", "FMA:45311", "FMA:53568", "FMA:276379", "FMA:6842", "FMA:8794", "FMA:8820", "FMA:53572", "FMA:53409", "FMA:37070", "FMA:6119", "FMA:53433", "FMA:7123", "FMA:8811", "FMA:65444", "FMA:52806", "FMA:53245", "FMA:65285", "FMA:6768", "FMA:8731", "FMA:11220", "FMA:6778", "FMA:53509", "FMA:55158", "FMA:53567", "FMA:65994", "FMA:53539", "FMA:45327", "FMA:8865", "FMA:44898", "FMA:52673", "FMA:80026", "FMA:52980", "FMA:53505", "FMA:82952", "FMA:21872", "FMA:37065", "FMA:52988", "FMA:8815", "FMA:53398", "FMA:52729", "FMA:81289", "FMA:65398", "FMA:52977", "FMA:8887"], "subclass labels": ["Left T9 white ramus communicans", "Right T10 grey ramus communicans", "Right T4 spinal nerve posterior ramus", "Right fourth intercostal nerve", "Right anterior interosseous nerve", "Right perineal nerve", "Left lateral calcaneal branch A of left sural nerve", "Right C3 spinal nerve posterior ramus medial branch", "Oesophageal branch of left recurrent laryngeal nerve", "Anterior branch of lateral cutaneous branch of left third intercostal nerve", "Left common plantar digital nerve F", "Anterior cutaneous branch of right subcostal nerve", "Left superior labial branch of infraorbital nerve", "Left T1 spinal nerve posterior ramus", "Anterior branch of left obturator nerve", "Right T2 grey ramus communicans", "Right T9 grey ramus communicans", "Left T5 white ramus communicans", "Left L3 spinal nerve posterior ramus lateral branch", "Communicating branch of left vagus nerve with left glossopharyngeal nerve", "Right second intercostal nerve", "Right proper palmar digital nerve G", "Left musculocutaneous nerve", "Anterior cutaneous branch of left ninth intercostal nerve", "Posterior branch of lateral cutaneous branch of left sixth intercostal nerve", "Right proper palmar digital nerve H", "Communicating branch of right vagus nerve with right glossopharyngeal nerve", "Anterior branch of lateral cutaneous branch of right ninth intercostal nerve", "Right proper plantar digital nerve C", "Left genital branch of genitofemoral nerve", "Left T6 grey ramus communicans", "Right proper palmar digital nerve I", "Right T12 spinal nerve posterior ramus", "Right ilioinguinal nerve", "Right T8 spinal nerve posterior ramus", "Left T9 spinal nerve posterior ramus", "Right T11 spinal nerve posterior ramus lateral branch", "Right proper plantar digital nerve J", "Right medial sural cutaneous nerve", "Right T6 spinal nerve posterior ramus medial branch", "Right lesser occipital nerve", "Right phrenic nerve", "Right proper palmar digital nerve E", "Left median nerve", "Right S3 grey ramus communicans", "Right T4 white ramus communicans", "Right medial cutaneous nerve of forearm", "Right posterior femoral cutaneous nerve", "Right vestibular nerve", "Lateral cutaneous branch of left sixth intercostal nerve", "Left supratrochlear nerve", "Right median nerve", "Anterior branch of right medial cutaneous nerve of forearm", "Right T5 spinal nerve posterior ramus medial branch", "Anterior cutaneous branch of right third intercostal nerve", "Right C6 spinal nerve posterior ramus", "Temporal branch of left facial nerve", "Anterior cutaneous branch of left eighth intercostal nerve", "Right buccal nerve", "Right middle superior alveolar nerve", "Temporal branch of right facial nerve", "Left superficial branch of radial nerve", "Left medial sural cutaneous nerve", "Left C4 spinal nerve posterior ramus", "Left lateral dorsal digital nerve of the third toe", "Right T12 spinal nerve posterior ramus lateral branch", "Anterior branch of lateral cutaneous branch of left eleventh intercostal nerve", "Left T12 spinal nerve posterior ramus", "Left anterior supraclavicular nerve", "Left lesser occipital nerve", "Right deep fibular nerve", "Left T11 spinal nerve posterior ramus", "Posterior branch of lateral cutaneous branch of left tenth intercostal nerve", "Right anterior superior alveolar nerve", "Left tenth intercostal nerve", "Anterior branch of lateral cutaneous branch of right fourth intercostal nerve", "Communicating branch of left glossopharyngeal nerve with auricular branch of left vagus nerve", "Left iliohypogastric nerve", "Cervical branch of left facial nerve", "Right proper palmar digital nerve J", "Lateral cutaneous branch of right sixth intercostal nerve", "Right T8 white ramus communicans", "Left maxillary nerve", "Left intercostobrachial nerve", "Left tentorial nerve", "Right zygomaticotemporal nerve", "Communicating branch of right internal laryngeal nerve with right recurrent laryngeal nerve", "Left fourth intercostal nerve", "Brachial plexus left C7 root", "Vagal branch to right carotid body", "Right proper plantar digital nerve G", "Right tympanic nerve", "Left lateral plantar nerve", "Lateral cutaneous branch of left tenth intercostal nerve", "Right tibial nerve", "Left third occipital nerve", "Anterior branch of lateral cutaneous branch of left tenth intercostal nerve", "Right T8 spinal nerve posterior ramus lateral branch", "Right S1 grey ramus communicans", "Left L3 spinal nerve posterior ramus", "Palmar cutaneous branch of left ulnar nerve", "Right greater petrosal nerve", "Left subcostal nerve", "Anterior branch of left medial cutaneous nerve of forearm", "Left proper plantar digital nerve C", "Left C3 spinal nerve branch to left supraclavicular nerve", "Right posterior cutaneous nerve of forearm", "Posterior branch of lateral cutaneous branch of right tenth intercostal nerve", "Right sciatic nerve", "Left L5 grey ramus communicans", "Right C4 spinal nerve posterior ramus medial branch", "Right L4 grey ramus communicans", "Left T11 white ramus communicans", "Posterior branch of lateral cutaneous branch of right eighth intercostal nerve", "Left L1 grey ramus communicans", "Posterior branch of left medial cutaneous nerve of forearm", "Left auriculotemporal nerve", "Left L2 white ramus communicans", "Marginal mandibular branch of right facial nerve", "Right T8 grey ramus communicans", "Right C4 spinal nerve posterior ramus", "Right fifth intercostal nerve", "Left common fibular nerve", "Left posterior ethmoidal nerve", "Pharyngeal branch of right glossopharyngeal nerve", "Anterior branch of lateral cutaneous branch of right third intercostal nerve", "Communicating branch of right external laryngeal nerve with right superior cardiac nerve", "Right posterior supraclavicular nerve", "Left medial dorsal cutaneous nerve", "Lateral cutaneous branch of right eleventh intercostal nerve", "Posterior branch of lateral cutaneous branch of left subcostal nerve", "Anterior cutaneous branch of left second intercostal nerve", "Left lingual nerve", "Right lateral calcaneal branch A of right sural nerve", "Left phrenic nerve", "Right hypogastric nerve", "Medial calcaneal branch A of left tibial nerve", "Left perineal nerve", "Right posterior scrotal nerve", "Right inferior alveolar nerve", "Medial calcaneal branch A of right tibial nerve", "Right T7 white ramus communicans", "Left frontal nerve", "Right T1 spinal nerve posterior ramus medial branch", "Right genitofemoral nerve", "Zygomatic branch of right facial nerve", "Lateral cutaneous branch of left ninth intercostal nerve", "Left C2 spinal nerve branch to left great auricular nerve", "Right anterior supraclavicular nerve", "Lateral cutaneous branch of right fourth intercostal nerve", "Left T11 grey ramus communicans", "Lingual branch of right vagus nerve", "Left T1 white ramus communicans", "Left C3 spinal nerve posterior ramus medial branch", "Left proper plantar digital nerve J", "Left T2 grey ramus communicans", "Brachial plexus left C6 root", "Left T10 spinal nerve posterior ramus", "Right genital branch of genitofemoral nerve", "Anterior cutaneous branch of right first intercostal nerve", "Left middle meningeal nerve", "Anterior cutaneous branch of left eleventh intercostal nerve", "Left infratrochlear nerve", "Vagal branch to left carotid body", "Anterior cutaneous branch of right eleventh intercostal nerve", "Right proper palmar digital nerve B", "Left proper palmar digital nerve H", "Anterior branch of lateral cutaneous branch of left fourth intercostal nerve", "Left seventh intercostal nerve", "Right nasociliary nerve", "Left posterior scrotal nerve", "Left sural nerve", "Right S5 grey ramus communicans", "Brachial plexus right C7 root", "Right inferior rectal nerve", "Right transverse cervical nerve", "Anterior cutaneous branch of left third intercostal nerve", "Left proper plantar digital nerve H", "Superficial branch of left ulnar nerve", "Dorsal branch of left ulnar nerve", "Right eleventh intercostal nerve", "Right T2 white ramus communicans", "Right common plantar digital nerve F", "Infrapatellar branch of right saphenous nerve", "Left T5 grey ramus communicans", "Lingual branch of left vagus nerve", "Thoracic cardiac branch of left vagus nerve", "Right superior laryngeal nerve", "Right C2 spinal nerve posterior ramus", "Right zygomatic nerve", "Right auriculotemporal nerve", "Anterior branch of lateral cutaneous branch of left subcostal nerve", "Left saphenous nerve", "Right L3 spinal nerve posterior ramus", "Right T7 grey ramus communicans", "Left great auricular nerve posterior branch", "Left proper palmar digital nerve A", "Right infraorbital nerve", "Cutaneous branch of right obturator nerve", "Posterior branch of right obturator nerve", "Left T1 grey ramus communicans", "Right T12 white ramus communicans", "Right proper plantar digital nerve F", "Left posterior auricular nerve", "Right posterior ethmoidal nerve", "Buccal branch of right facial nerve", "Right iliohypogastric nerve", "Left dorsal nerve of penis", "Right inferior lateral cutaneous nerve of arm", "Left T7 spinal nerve posterior ramus lateral branch", "Lateral cutaneous branch of left seventh intercostal nerve", "Right posterior interosseous nerve", "Left middle superior alveolar nerve", "Right T9 white ramus communicans", "Right T10 spinal nerve posterior ramus", "Left deep fibular nerve", "Hepatic branch of anterior vagal trunk", "Left first intercostal nerve", "Right L2 white ramus communicans", "Buccal branch of left facial nerve", "Right L5 grey ramus communicans", "Right common fibular nerve", "Left T6 spinal nerve posterior ramus medial branch", "Right L2 grey ramus communicans", "Right deep petrosal nerve", "Left axillary nerve posterior branch", "Right posterior auricular nerve", "Anterior branch of lateral cutaneous branch of right subcostal nerve", "Anterior branch of lateral cutaneous branch of right fifth intercostal nerve", "Pyloric branch of greater posterior gastric nerve", "Left T10 spinal nerve posterior ramus lateral branch", "Superior cervical cardiac branch of right vagus nerve", "Ganglionic branch of right maxillary nerve to pterygopalatine ganglion", "Left proper palmar digital nerve C", "Right superior cervical cardiac nerve", "Right ninth intercostal nerve", "Right lesser petrosal nerve", "Communicating branch of left external laryngeal nerve with left superior cardiac nerve", "Right long ciliary nerve B", "Anterior cutaneous branch of right fourth intercostal nerve", "Right third intercostal nerve", "Left L4 grey ramus communicans", "Right T7 spinal nerve posterior ramus", "Left L2 spinal nerve posterior ramus lateral branch", "Left proper palmar digital nerve F", "Coeliac branch of posterior vagal trunk", "Left lacrimal nerve", "Right lacrimal nerve", "Anterior cutaneous branch of right seventh intercostal nerve", "Left femoral nerve", "Right maxillary nerve", "Lateral cutaneous branch of right third intercostal nerve", "Right superficial fibular nerve", "Left proper palmar digital nerve I", "Anterior cutaneous branch of left seventh intercostal nerve", "Left T12 spinal nerve posterior ramus lateral branch", "Thoracic cardiac branch of right vagus nerve", "Lateral cutaneous branch of left eighth intercostal nerve", "Orbital branch of left maxillary nerve to left ethmoidal sinus", "Left pudendal nerve", "Left lesser petrosal nerve", "Right eighth intercostal nerve", "Left S5 grey ramus communicans", "Right T10 white ramus communicans", "Left T10 white ramus communicans", "Left T4 white ramus communicans", "Lateral cutaneous branch of left third intercostal nerve", "Posterior branch of lateral cutaneous branch of left eighth intercostal nerve", "Lateral cutaneous branch of right iliohypogastric nerve", "Right supratrochlear nerve", "Anterior branch of lateral cutaneous branch of right tenth intercostal nerve", "Right C3 spinal nerve branch to right supraclavicular nerve", "Right T6 grey ramus communicans", "Left T5 spinal nerve posterior ramus medial branch", "Left proper palmar digital nerve G", "Left posterior superior alveolar nerve", "Lateral cutaneous branch of left subcostal nerve", "Gluteal branch A of right posterior femoral cutaneous nerve", "Right T5 white ramus communicans", "Left greater petrosal nerve", "Left T3 spinal nerve posterior ramus", "Right subcostal nerve", "Right femoral branch of genitofemoral nerve", "Right sixth intercostal nerve", "Anterior cutaneous branch of right ninth intercostal nerve", "Left T11 spinal nerve posterior ramus lateral branch", "Left T7 grey ramus communicans", "Posterior branch of lateral cutaneous branch of right subcostal nerve", "Left L2 grey ramus communicans", "Posterior branch of lateral cutaneous branch of right third intercostal nerve", "Right L1 white ramus communicans", "Anterior branch of right obturator nerve", "Anterior cutaneous branch of left fifth intercostal nerve", "Left T4 grey ramus communicans", "Right C5 spinal nerve posterior ramus medial branch", "Right T4 spinal nerve posterior ramus medial branch", "Left L1 white ramus communicans", "Anterior cutaneous branch of right eighth intercostal nerve", "Left subclavian nerve", "Pericardial branch of left phrenic nerve", "Left tympanic nerve", "Right zygomaticofacial nerve", "Right intercostobrachial nerve", "Right cochlear nerve", "Left internal laryngeal nerve", "Right lateral dorsal digital nerve of the third toe", "Left proper palmar digital nerve D", "Inferior cervical cardiac branch of left vagus nerve", "Left proper plantar digital nerve B", "Right S2 grey ramus communicans", "Right proper plantar digital nerve H", "Right tentorial nerve", "Right T1 white ramus communicans", "Inferior ramus of left internal laryngeal nerve", "Right L3 grey ramus communicans", "Right posterior superior alveolar nerve", "Tonsillar branch of right glossopharyngeal nerve", "Lateral cutaneous branch of right subcostal nerve", "Right proper palmar digital nerve C", "Right first intercostal nerve", "Posterior branch of right medial cutaneous nerve of forearm", "Right lingual nerve", "Lateral cutaneous branch of right fifth intercostal nerve", "Left T4 spinal nerve posterior ramus", "Posterior branch of lateral cutaneous branch of left third intercostal nerve", "Right posterior superior lateral nasal branch of maxillary nerve", "Posterior branch of lateral cutaneous branch of right fifth intercostal nerve", "Left buccal nerve", "Right third occipital nerve", "Left anterior ethmoidal nerve", "Right lingual branch of glossopharyngeal nerve", "Left laryngopharyngeal branch of superior cervical ganglion", "Right infratrochlear nerve", "Left external laryngeal nerve branch to pharyngeal plexus", "Left T7 white ramus communicans", "Left L1 spinal nerve posterior ramus", "Right S4 grey ramus communicans", "Left proper palmar digital nerve J", "Left zygomatic nerve", "Left L1 spinal nerve posterior ramus lateral branch", "Left greater occipital nerve", "Left medial cutaneous nerve of forearm", "Brachial plexus left C8 root", "Left anterior femoral cutaneous branch A", "Posterior branch of lateral cutaneous branch of left seventh intercostal nerve", "Left T1 spinal nerve posterior ramus medial branch", "Left meningeal branch of mandibular nerve", "Left medial dorsal digital nerve of the fourth toe", "Left C5 spinal nerve posterior ramus", "Pharyngeal branch of left glossopharyngeal nerve", "Right medial plantar nerve", "Left proper plantar digital nerve F", "Left deep petrosal nerve", "Right supraorbital nerve", "Left proper plantar digital nerve E", "Right T9 spinal nerve posterior ramus lateral branch", "Left posterior cutaneous nerve of forearm", "Left posterior femoral cutaneous nerve", "Left hypogastric nerve", "Left genitofemoral nerve", "Anterior branch of lateral cutaneous branch of left ninth intercostal nerve", "Right T1 spinal nerve posterior ramus", "Right common palmar digital nerve A", "Right L3 spinal nerve posterior ramus lateral branch", "Left anterior superior alveolar nerve", "Right T1 grey ramus communicans", "Anterior cutaneous branch of left sixth intercostal nerve", "Left proper plantar digital nerve A", "Left T5 spinal nerve posterior ramus", "Right T3 spinal nerve posterior ramus", "Right superior labial branch of infraorbital nerve", "Left proper palmar digital nerve E", "Left transverse cervical nerve", "Posterior branch of lateral cutaneous branch of right fourth intercostal nerve", "Left communicating branch of nasociliary nerve with ciliary ganglion", "Superficial branch of right ulnar nerve", "Right great auricular nerve posterior branch", "Palmar branch of right median nerve", "Right ulnar nerve", "Right T5 grey ramus communicans", "Palmar cutaneous branch of right ulnar nerve", "Left T2 spinal nerve posterior ramus medial branch", "Tonsillar branch of left glossopharyngeal nerve", "Lateral cutaneous branch of right eighth intercostal nerve", "Posterior branch of lateral cutaneous branch of right eleventh intercostal nerve", "Left T6 white ramus communicans", "Right T4 grey ramus communicans", "Branch of right vagus nerve to oesophageal nerve plexus", "Superior cervical cardiac branch of left vagus nerve", "Left long thoracic nerve", "Right mental nerve", "Left fifth intercostal nerve", "Lateral cutaneous branch of left fourth intercostal nerve", "Right lateral femoral cutaneous nerve", "Posterior branch of lateral cutaneous branch of right seventh intercostal nerve", "Lateral cutaneous branch of right seventh intercostal nerve", "Left C4 spinal nerve posterior ramus medial branch", "Right intermediate dorsal cutaneous nerve", "Right medial dorsal cutaneous nerve", "Left recurrent laryngeal nerve", "Left obturator nerve", "Left T8 grey ramus communicans", "Right T2 spinal nerve posterior ramus", "Right T3 spinal nerve posterior ramus medial branch", "Left T2 spinal nerve posterior ramus", "Right superficial branch of radial nerve", "Right C3 spinal nerve branch to right great auricular nerve", "Left anterior interosseous nerve", "Lateral cutaneous branch of right ninth intercostal nerve", "Left common plantar digital nerve E", "Brachial plexus left C5 root", "Left external laryngeal nerve", "Left C3 spinal nerve posterior ramus", "Oesophageal branch of right recurrent laryngeal nerve", "Lateral cutaneous branch of right tenth intercostal nerve", "Anterior cutaneous branch of right sixth intercostal nerve", "Right T3 white ramus communicans", "Left T9 grey ramus communicans", "Auricular branch of right vagus nerve", "Right lateral sural cutaneous nerve", "Left ulnar nerve", "Right long ciliary nerve A", "Left sciatic nerve", "Anterior branch of lateral cutaneous branch of left fifth intercostal nerve", "Right inferior palpebral branch of infraorbital nerve", "Right medial cutaneous nerve of arm", "Auricular branch of left vagus nerve", "Left T10 grey ramus communicans", "Left medial posterior superior nasal nerve", "Pharyngeal branch of right vagus nerve to pharyngeal nerve plexus", "Left L3 grey ramus communicans", "Left lateral femoral cutaneous nerve", "Right external laryngeal nerve branch to pharyngeal plexus", "Left eighth intercostal nerve", "Right T5 spinal nerve posterior ramus", "Left tibial nerve", "Right superior lateral cutaneous nerve of arm", "Right lateral plantar nerve", "Anterior cutaneous branch of left first intercostal nerve", "Brachial plexus right C8 root", "Lateral cutaneous branch of left iliohypogastric nerve", "Posterior branch of lateral cutaneous branch of left eleventh intercostal nerve", "Right long thoracic nerve", "Left lateral cutaneous nerve of forearm", "Left posterior supraclavicular nerve", "Left T3 grey ramus communicans", "Left ilioinguinal nerve", "Left mental nerve", "Left T12 white ramus communicans", "Left superficial fibular nerve", "Right proper palmar digital nerve F", "Right proper palmar digital nerve D", "Right lateral cutaneous nerve of forearm", "Gluteal branch A of left posterior femoral cutaneous nerve", "Lateral cutaneous branch of left fifth intercostal nerve", "Right L1 spinal nerve posterior ramus lateral branch", "Right axillary nerve anterior branch", "Orbital branch of right maxillary nerve to right ethmoidal sinus", "Right C6 spinal nerve posterior ramus medial branch", "Posterior branch of lateral cutaneous branch of right ninth intercostal nerve", "Right recurrent laryngeal nerve", "Right sural nerve", "Dorsal branch of right ulnar nerve", "Right common plantar digital nerve E", "Right medial dorsal digital nerve of the fourth toe", "Right proper plantar digital nerve E", "Left caroticotympanic nerve", "Greater posterior gastric nerve", "Right L1 spinal nerve posterior ramus", "Pericardial branch of right phrenic nerve", "Anterior branch of lateral cutaneous branch of right eighth intercostal nerve", "Left incisive branch of inferior alveolar nerve", "Right T3 grey ramus communicans", "Left posterior interosseous nerve", "Palmar branch of left median nerve", "Left nasociliary nerve", "Right external laryngeal nerve", "Pharyngeal branch of left vagus nerve to pharyngeal nerve plexus", "Right T11 grey ramus communicans", "Right dorsal nerve of penis", "Left C6 spinal nerve posterior ramus", "Left axillary nerve anterior branch", "Meningeal branch of left vagus nerve", "Left intermediate dorsal cutaneous nerve", "Right laryngopharyngeal branch of superior cervical ganglion", "Right great auricular nerve anterior branch", "Zygomatic branch of left facial nerve", "Left C5 spinal nerve posterior ramus medial branch", "Marginal mandibular branch of left facial nerve", "Right L1 grey ramus communicans", "Right meningeal branch of mandibular nerve", "Right femoral nerve", "Tracheal branch of right recurrent laryngeal nerve", "Left posterior cutaneous nerve of arm", "Left inferior lateral cutaneous nerve of arm", "Right L2 spinal nerve posterior ramus", "Right lateral dorsal cutaneous nerve", "Anterior cutaneous branch of right second intercostal nerve", "Left nasopalatine nerve", "Left T3 spinal nerve posterior ramus medial branch", "Left superior cervical cardiac nerve", "Posterior branch of lateral cutaneous branch of left ninth intercostal nerve", "Right T7 spinal nerve posterior ramus lateral branch", "Right frontal nerve", "Anterior cutaneous branch of left tenth intercostal nerve", "Ganglionic branch of left maxillary nerve to pterygopalatine ganglion", "Left S1 grey ramus communicans", "Left lesser palatine nerve", "Left medial plantar nerve", "Communicating branch of right glossopharyngeal nerve with auricular branch of right vagus nerve", "Left zygomaticotemporal nerve", "Anterior cutaneous branch of right fifth intercostal nerve", "Left proper palmar digital nerve B", "Left radial nerve", "Posterior branch of lateral cutaneous branch of left fourth intercostal nerve", "Left S3 grey ramus communicans", "Left T3 white ramus communicans", "Right T11 spinal nerve posterior ramus", "Left ninth intercostal nerve", "Right T2 spinal nerve posterior ramus medial branch", "Anterior cutaneous branch of left subcostal nerve", "Right proper plantar digital nerve B", "Left C2 spinal nerve posterior ramus", "Right axillary nerve", "Left axillary nerve", "Left common palmar digital nerve A", "Left proper plantar digital nerve D", "Left femoral branch of genitofemoral nerve", "Left second intercostal nerve", "Left medial cutaneous nerve of arm", "Left lateral sural cutaneous nerve", "Right ophthalmic nerve", "Right carotid sinus nerve", "Right T10 spinal nerve posterior ramus lateral branch", "Right proper plantar digital nerve D", "Right mandibular nerve", "Right obturator nerve", "Left C3 spinal nerve branch to left great auricular nerve", "Left lateral dorsal cutaneous nerve", "Right greater palatine nerve", "Right L2 spinal nerve posterior ramus lateral branch", "Brachial plexus right C5 root", "Left posterior superior lateral nasal branch of maxillary nerve", "Right proper plantar digital nerve I", "Right seventh intercostal nerve", "Anterior branch of lateral cutaneous branch of right eleventh intercostal nerve", "Right tenth intercostal nerve", "Left mandibular nerve", "Left greater palatine nerve", "Left T12 grey ramus communicans", "Inferior cervical cardiac branch of right vagus nerve", "Left ophthalmic nerve", "Left superior laryngeal nerve", "Right T12 grey ramus communicans", "Cutaneous branch of left obturator nerve", "Left long ciliary nerve B", "Left S4 grey ramus communicans", "Left T4 spinal nerve posterior ramus medial branch", "Greater anterior gastric nerve", "Orbital branch of left maxillary nerve to left sphenoidal sinus", "Orbital branch of right maxillary nerve to right sphenoidal sinus", "Right middle supraclavicular nerve", "Right caroticotympanic nerve", "Left sixth intercostal nerve", "Right posterior cutaneous nerve of arm", "Left middle supraclavicular nerve", "Left proper plantar digital nerve I", "Anterior branch of lateral cutaneous branch of right sixth intercostal nerve", "Left L2 spinal nerve posterior ramus", "Anterior branch of lateral cutaneous branch of left seventh intercostal nerve", "Posterior branch of lateral cutaneous branch of right sixth intercostal nerve", "Left T8 spinal nerve posterior ramus lateral branch", "Meningeal branch of right vagus nerve", "Tracheal branch of left recurrent laryngeal nerve", "Anterior cutaneous branch of right tenth intercostal nerve", "Left eleventh intercostal nerve", "Right pudendal nerve", "Posterior branch of lateral cutaneous branch of left fifth intercostal nerve", "Right anterior ethmoidal nerve", "Right nasopalatine nerve", "Left T8 spinal nerve posterior ramus", "Left long ciliary nerve A", "Left supraorbital nerve", "Right medial posterior superior nasal nerve", "Left T8 white ramus communicans", "Right anterior femoral cutaneous branch A", "Left T2 white ramus communicans", "Right saphenous nerve", "Anterior branch of lateral cutaneous branch of right seventh intercostal nerve", "Left superior lateral cutaneous nerve of arm", "Left T9 spinal nerve posterior ramus lateral branch", "Left T6 spinal nerve posterior ramus", "Posterior branch of left obturator nerve", "Left external laryngeal nerve branch to inferior pharyngeal constrictor", "Right incisive branch of inferior alveolar nerve", "Right C3 spinal nerve posterior ramus", "Right C5 spinal nerve posterior ramus", "Right T9 spinal nerve posterior ramus", "Communicating branch of left internal laryngeal nerve with left recurrent laryngeal nerve", "Left vestibular nerve", "Right radial nerve", "Left third intercostal nerve", "Left cochlear nerve", "Anterior cutaneous branch of left fourth intercostal nerve", "Right T6 spinal nerve posterior ramus", "Right greater occipital nerve", "Right lesser palatine nerve", "Left inferior alveolar nerve", "Right subclavian nerve", "Right T6 white ramus communicans", "Brachial plexus right C6 root", "Lateral cutaneous branch of left eleventh intercostal nerve", "Right T11 white ramus communicans", "Left carotid sinus nerve", "Left great auricular nerve anterior branch", "Right external laryngeal nerve branch to inferior pharyngeal constrictor", "Left S2 grey ramus communicans", "Right internal laryngeal nerve", "Infrapatellar branch of left saphenous nerve", "Anterior branch of lateral cutaneous branch of left sixth intercostal nerve", "Right proper palmar digital nerve A", "Right communicating branch of nasociliary nerve with ciliary ganglion", "Left proper plantar digital nerve G", "Left infraorbital nerve", "Left lingual branch of glossopharyngeal nerve", "Right proper plantar digital nerve A", "Left inferior rectal nerve", "Right musculocutaneous nerve", "Left inferior palpebral branch of infraorbital nerve", "Left T7 spinal nerve posterior ramus", "Cervical branch of right facial nerve", "Right middle meningeal nerve", "Right axillary nerve posterior branch", "Right C2 spinal nerve branch to right great auricular nerve", "Left zygomaticofacial nerve", "Anterior branch of lateral cutaneous branch of left eighth intercostal nerve"] }, { id: 77, nerve_id: "UBERON:0001647", label: "facial nerve", "FMA subclasses (in human nerves)": ["FMA:50888", "FMA:50889"], "subclass labels": ["Right facial nerve", "Left facial nerve"] }, { id: 78, nerve_id: "UBERON:0001148", label: "median nerve", "FMA subclasses (in human nerves)": ["FMA:37067", "FMA:37068"], "subclass labels": ["Right median nerve", "Left median nerve"] }, { id: 79, nerve_id: "UBERON:0009009", label: "carotid sinus nerve", "FMA subclasses (in human nerves)": ["FMA:53508", "FMA:53509"], "subclass labels": ["Right carotid sinus nerve", "Left carotid sinus nerve"] }, { id: 80, nerve_id: "UBERON:0003715", label: "splanchnic nerve", "FMA subclasses (in human nerves)": ["FMA:6924", "FMA:6928", "FMA:6929", "FMA:6931", "FMA:6930", "FMA:6960", "FMA:6958", "FMA:6959", "FMA:6925", "FMA:6956", "FMA:6927", "FMA:6955", "FMA:6926", "FMA:6957"], "subclass labels": ["Right first lumbar splanchnic nerve", "Right third lumbar splanchnic nerve", "Left third lumbar splanchnic nerve", "Left fourth lumbar splanchnic nerve", "Right fourth lumbar splanchnic nerve", "Left least splanchnic nerve", "Left lesser splanchnic nerve", "Right least splanchnic nerve", "Left first lumbar splanchnic nerve", "Right greater splanchnic nerve", "Left second lumbar splanchnic nerve", "Left greater splanchnic nerve", "Right second lumbar splanchnic nerve", "Right lesser splanchnic nerve"] }, { id: 81, nerve_id: "ILX:0793826", label: "anterior abdominal vagal trunk", "FMA subclasses (in human nerves)": [], "subclass labels": [] }, { id: 82, nerve_id: "UBERON:0001650", label: "hypoglossal nerve", "FMA subclasses (in human nerves)": [], "subclass labels": [] }, { id: 83, nerve_id: "ILX:0794967", label: "posterior interosseous nerve", "FMA subclasses (in human nerves)": [], "subclass labels": [] }, { id: 84, nerve_id: "ILX:0793713", label: "Deep petrosal nerve", "FMA subclasses (in human nerves)": ["FMA:0328827", "FMA:0328826"], "subclass labels": ["Left deep petrosal nerve", "Right deep petrosal nerve"] }, { id: 85, nerve_id: "ILX:0793361", label: "white communicating ramus of third lumbar spinal nerve", "FMA subclasses (in human nerves)": [], "subclass labels": [] }, { id: 86, nerve_id: "ILX:0787562", label: "gray communicating ramus of the third thoracic nerve", "FMA subclasses (in human nerves)": ["FMA:6133", "FMA:6124"], "subclass labels": ["Left T3 grey ramus communicans", "Right T3 grey ramus communicans"] }, { id: 87, nerve_id: "ILX:0793211", label: "white communicating ramus of fifth thoracic spinal nerve", "FMA subclasses (in human nerves)": [], "subclass labels": [] }, { id: 88, nerve_id: "UBERON:0018679", label: "thoracic splanchnic nerve", "FMA subclasses (in human nerves)": ["FMA:6958", "FMA:6960", "FMA:6955", "FMA:6959", "FMA:6957", "FMA:6956"], "subclass labels": ["Left lesser splanchnic nerve", "Left least splanchnic nerve", "Left greater splanchnic nerve", "Right least splanchnic nerve", "Right lesser splanchnic nerve", "Right greater splanchnic nerve"] }, { id: 89, nerve_id: "ILX:0731969", label: "least splanchnic nerve", "FMA subclasses (in human nerves)": ["FMA:6960", "FMA:6959"], "subclass labels": ["Left least splanchnic nerve", "Right least splanchnic nerve"] }, { id: 90, nerve_id: "ILX:0788771", label: "gray communicating ramus of seventh thoracic nerve", "FMA subclasses (in human nerves)": ["FMA:6888", "FMA:6889"], "subclass labels": ["Right T7 grey ramus communicans", "Left T7 grey ramus communicans"] }, { id: 91, nerve_id: "UBERON:0022301", label: "long ciliary nerve", "FMA subclasses (in human nerves)": ["FMA:52701", "FMA:52700", "FMA:82734", "FMA:82735"], "subclass labels": ["Left long ciliary nerve B", "Right long ciliary nerve B", "Right long ciliary nerve A", "Left long ciliary nerve A"] }, { id: 92, nerve_id: "ILX:0793221", label: "white communicating ramus of second lumbar spinal nerve", "FMA subclasses (in human nerves)": [], "subclass labels": [] }, { id: 93, nerve_id: "ILX:0785825", label: "gray communicating ramus of first lumbar nerve", "FMA subclasses (in human nerves)": ["FMA:65924", "FMA:65923"], "subclass labels": ["Left L1 grey ramus communicans", "Right L1 grey ramus communicans"] }, { id: 94, nerve_id: "ILX:0793208", label: "white communicating ramus of second thoracic spinal nerve", "FMA subclasses (in human nerves)": [], "subclass labels": [] }, { id: 95, nerve_id: "UBERON:0018412", label: "vidian nerve", "FMA subclasses (in human nerves)": [], "subclass labels": [] }, { id: 96, nerve_id: "ILX:0739303", label: "gray communicating ramus of second thoracic nerve", "FMA subclasses (in human nerves)": [], "subclass labels": [] }, { id: 97, nerve_id: "ILX:0795006", label: "Suboccipital nerve", "FMA subclasses (in human nerves)": [], "subclass labels": [] }, { id: 98, nerve_id: "ILX:0785733", label: "gray communicating ramus of second lumbar nerve", "FMA subclasses (in human nerves)": ["FMA:65921", "FMA:65922"], "subclass labels": ["Right L2 grey ramus communicans", "Left L2 grey ramus communicans"] }, { id: 99, nerve_id: "UBERON:0035207", label: "deep fibular nerve", "FMA subclasses (in human nerves)": ["FMA:45387", "FMA:45388"], "subclass labels": ["Right deep fibular nerve", "Left deep fibular nerve"] }, { id: 100, nerve_id: "ILX:0739304", label: "gray communicating ramus of third thoracic nerve", "FMA subclasses (in human nerves)": [], "subclass labels": [] }, { id: 101, nerve_id: "UBERON:0002019", label: "accessory XI nerve", "FMA subclasses (in human nerves)": ["FMA:50899", "FMA:50897"], "subclass labels": ["Left accessory nerve", "Right accessory nerve"] }, { id: 102, nerve_id: "ILX:0793217", label: "white communicating ramus of eleventh thoracic spinal nerve", "FMA subclasses (in human nerves)": [], "subclass labels": [] }, { id: 103, nerve_id: "ILX:0793722", label: "Lesser petrosal nerve", "FMA subclasses (in human nerves)": ["FMA:53503", "FMA:53502"], "subclass labels": ["Left lesser petrosal nerve", "Right lesser petrosal nerve"] }, { id: 104, nerve_id: "UBERON:0018675", label: "pelvic splanchnic nerve", "FMA subclasses (in human nerves)": [], "subclass labels": [] }, { id: 105, nerve_id: "ILX:0793702", label: "Greater petrosal nerve", "FMA subclasses (in human nerves)": ["FMA:53423", "FMA:53424"], "subclass labels": ["Right greater petrosal nerve", "Left greater petrosal nerve"] }, { id: 106, nerve_id: "ILX:0794916", label: "white ramus communicans", "FMA subclasses (in human nerves)": [], "subclass labels": [] }, { id: 107, nerve_id: "UBERON:0003716", label: "Recurrent Laryngeal Nerve", "FMA subclasses (in human nerves)": ["UBERON:0011766", "UBERON:0011767"], "subclass labels": ["Left recurrent laryngeal nerve", "Right recurrent laryngeal nerve"] }, { id: 108, nerve_id: "UBERON:0005465", label: "obturator nerve", "FMA subclasses (in human nerves)": ["FMA:16501", "FMA:16502"], "subclass labels": ["Right obturator nerve", "Left obturator nerve"] }, { id: 109, nerve_id: "ILX:0793213", label: "white communicating ramus of seventh thoracic spinal nerve", "FMA subclasses (in human nerves)": [], "subclass labels": [] }, { id: 110, nerve_id: "ILX:0785067", label: "gray communicating ramus of eleventh thoracic nerve", "FMA subclasses (in human nerves)": ["FMA:6897", "FMA:6896"], "subclass labels": ["Left T11 grey ramus communicans", "Right T11 grey ramus communicans"] }, { id: 111, nerve_id: "UBERON:0001494", label: "ulnar nerve", "FMA subclasses (in human nerves)": ["FMA:37320", "FMA:37321"], "subclass labels": ["Right ulnar nerve", "Left ulnar nerve"] }, { id: 112, nerve_id: "ILX:0794959", label: "posterior rami lower cervical nerves", "FMA subclasses (in human nerves)": [], "subclass labels": [] }, { id: 113, nerve_id: "UBERON:0001493", label: "axillary nerve", "FMA subclasses (in human nerves)": ["FMA:37074", "FMA:37073"], "subclass labels": ["Left axillary nerve", "Right axillary nerve"] }, { id: 114, nerve_id: "ILX:0787946", label: "gray communicating ramus of sixth thoracic nerve", "FMA subclasses (in human nerves)": ["FMA:6762", "FMA:6763"], "subclass labels": ["Right T6 grey ramus communicans", "Left T6 grey ramus communicans"] }, { id: 115, nerve_id: "ILX:0785542", label: "gray communicating ramus of ninth thoracic nerve", "FMA subclasses (in human nerves)": ["FMA:6892", "FMA:6893"], "subclass labels": ["Right T9 grey ramus communicans", "Left T9 grey ramus communicans"] } ]; var F5 = () => { const n = {}; return R5.forEach((e) => { e.nerve_id && e.label !== "nerve" && e["subclass labels"].forEach((t) => { t in n || (n[t.toLowerCase()] = e.nerve_id); }); }), n; }; var P5 = [ { label: "urinary bladder", anatomicalId: "UBERON:0001255" }, { label: "brainstem", anatomicalId: "UBERON:0002298" }, { label: "caecum", anatomicalId: "UBERON:0001153" }, { label: "colon", anatomicalId: "UBERON:0001155" }, { label: "esophagus", anatomicalId: "UBERON:0001043" }, { label: "small intestine", anatomicalId: "UBERON:0002108" }, { label: "stomach", anatomicalId: "UBERON:0000945" }, { label: "heart", anatomicalId: "UBERON:0000948" }, { label: "lung", anatomicalId: "UBERON:0002048" } ]; var I5 = () => { const n = {}; return P5.forEach((e) => { const t = e.label.toLowerCase(); t in n || (n[t.toLowerCase()] = e.anatomicalId); }), n; }; var Ov = F5(); var Dv = I5(); var O5 = { name: "ScaffoldVuer", components: { Button: Ko, Col: bi, Loading: y3, Option: Qo, Popover: cu, Radio: ty, RadioGroup: ny, Row: Ui, Select: qo, Slider: ti, TabPane: xy, Tabs: by, MapSvgIcon: wn, MapSvgSpriteColor: hn, PrimitiveControls: _M, ScaffoldTooltip: EM, ElIconWarningFilled: u0, ElIconArrowDown: Xd, ElIconArrowLeft: zr, DrawToolbar: $7, ScaffoldTreeControls: TM }, setup(n) { let e = inject("$annotator"); return e || (e = markRaw(new AnnotationService(`${n.flatmapAPI}annotator`)), provide("$annotator", e)), { annotator: e }; }, props: { /** * The option to show annotation information in sidebar */ annotationSidebar: { type: Boolean, default: false }, /** * URL of the zincjs metadata. This value will be ignored if a valid * state prop is also provided. * If the url needs to be updated with state present, please use * the setURL method. */ url: { type: String, default: "" }, /** * Show the colour control of set to true. */ showColourPicker: { type: Boolean, default: false }, /** * Flag to show/hide the UI. */ displayUI: { type: Boolean, default: true }, /** * Display all graphics at start. * * This setting only works when traditional is set to false. */ displayAtStartUp: { type: Boolean, default: true }, /** * Use for toggling the help tooltips. */ helpMode: { type: Boolean, default: false }, /** * The active item index of help mode. */ helpModeActiveItem: { type: Number, default: 0 }, /** * The option to use helpModeDialog. * On default, `false`, clicking help will show all tooltips. * If `true`, clicking help will show the help-mode-dialog. */ helpModeDialog: { type: Boolean, default: false }, /** * The last item of help mode. */ helpModeLastItem: { type: Boolean, default: false }, /** * The initial index number for help mode tooltips. * Set negative (e.g. -1) if there are other tooltips outside of `hoverVisibilities`. */ helpModeInitialIndex: { type: Number, default: 0 }, /** * Use for show/display beta warning icon. */ displayWarning: { type: Boolean, default: true }, /** * Warning message for the hovered over text * on the warning icon. */ warningMessage: { type: String, default: "Beta feature - under active development" }, displayLatestChanges: { type: Boolean, default: false }, latestChangesMessage: { type: String, default: "New feature - Local search is now available" }, /** * Show/hide pickable markers for regions. */ displayMarkers: { type: Boolean, default: false }, /** * Display adjacent markers with a cluster marker. */ markerCluster: { type: Boolean, default: false }, /** * GroupName to value pair. * The value can be a single number or and object in the following * form: * * { * number: Number, * imgURL: String * } * * When imgURL is specified, scaffoldvuer will attempt to render * the image in imgURL as marker instead. * */ markerLabels: { type: Object, default: function() { return {}; } }, /** * Show/hide minimap. */ displayMinimap: { type: Boolean, default: false }, /** * Format of the input URL */ format: { type: String, default: "metadata" }, /** * Settings for minimap position, size and alignment. */ minimapSettings: { type: Object, default: function() { return { x_offset: 16, y_offset: 16, width: 128, height: 128, align: "top-right" }; } }, /** * Flag to determine rather the open map UI icon and popup * should be shown or not. */ enableOpenMapUI: { type: Boolean, default: false }, /** * Define what is considered as nerves. */ isNerves: { type: Object, default: function() { return { regions: ["nerves"] }; } }, /** * This array populate the the openMapOptions popup. * Each entry contains a pair of display and key. */ openMapOptions: { type: Array, default: function() { return [ { display: "Open AC Map", key: "AC" }, { display: "Open FC Map", key: "FC" }, { display: "Open 3D Human Map", key: "3D" } ]; } }, /** * State containing state of the scaffold. */ state: { type: Object, default: void 0 }, /** * Optional prop for the name of the region to focus on, * this option is ignored if state or viewURL is also provided. */ region: { type: String, default: "" }, /** * Optional prop for an URL of containing information of a viewport. * This option is ignored if state is also provided. * It will use the provided URL as base if a relative parth is provided. */ viewURL: { type: String, default: "" }, /** * Settings for turning on/off rendering */ render: { type: Boolean, default: true }, /** * Specify the endpoint of the flatmap server. * This is used by annotation service included in * third party flatmapvuer library. */ flatmapAPI: { type: String, default: "https://mapcore-demo.org/current/flatmap/v3/" }, /** * The option to show local settings UI * (background colour, viewing mode, etc.) */ showLocalSettings: { type: Boolean, default: true }, /** * The option to show open new map button */ showOpenMapButton: { type: Boolean, default: true }, /** * Manage the settings when used in standalone or as child component. */ usageConfig: { type: Object, default: function() { return { showTubeLinesControls: true, tubeLines: false }; } } }, provide() { return { flatmapAPI: this.flatmapAPI, scaffoldUrl: this.url, boundingDims: this.boundingDims }; }, data: function() { return { annotator: void 0, colourRadio: true, createData: { drawingBox: false, toBeConfirmed: false, points: [], shape: "", x: 0, y: 0, editingIndex: -1, faceIndex: -1, toBeDeleted: false }, currentTime: 0, timeVarying: false, isPlaying: false, isReady: false, /** * This is set when scene is transitioning. */ isTransitioning: false, tooltipAppendToBody: false, hoverVisibilities: [ { value: false, ref: "zoomInPopover" }, // 0 { value: false, ref: "zoomOutPopover" }, // 1 { value: false, ref: "zoomFitPopover" }, // 2 { value: false, ref: "openMapPopover" }, // 3 { value: false, ref: "settingsPopover" }, // 4 { value: false, ref: "sliderPopover" }, // 5 { value: false, ref: "regionVisibilityPopover" }, // 6 { value: false, ref: "warningPopover" }, // 7 { value: false, ref: "whatsNewPopover" }, // 8 { value: false, refs: "toolbarPopover", ref: "editPopover" }, // 9 { value: false, refs: "toolbarPopover", ref: "pointPopover" }, // 10 { value: false, refs: "toolbarPopover", ref: "lineStringPopover" }, // 11 { value: false, refs: "toolbarPopover", ref: "deletePopover" } // 11 ], inHelp: false, helpModeActiveIndex: this.helpModeInitialIndex, loading: false, duration: 3e3, drawerOpen: true, currentBackground: "white", availableBackground: ["white", "lightskyblue", "black"], minimisedSlider: false, sliderPosition: "", timeMax: 100, orginalDuration: "", animateDuration: "6secs", playSpeed: [ { value: 0.1, label: "0.1x" }, { value: 0.5, label: "0.5x" }, { value: 1, label: "1x" }, { value: 2, label: "2x" }, { value: 5, label: "5x" }, { value: 10, label: "10x" } ], currentSpeed: 1, timeStamps: {}, defaultCheckedKeys: [], outlinesRadio: true, tData: { label: "", region: "", visible: false, x: 200, y: 200, active: false }, fileFormat: "metadata", previousMarkerLabels: markRaw({}), viewingMode: "Exploration", viewingModes: { Exploration: "View and explore detailed visualization of 3D scaffolds", "Neuron Connection": "Discover nerve connections by selecting a nerve and viewing its associated connections", Annotation: ["View feature annotations", "Add, comment on and view feature annotations"] }, openMapRef: void 0, backgroundIconRef: void 0, annotationFeature: {}, offlineAnnotationEnabled: false, offlineAnnotations: markRaw([]), authorisedUser: void 0, toolbarOptions: [ "Delete", "Edit", "Point", "LineString" ], existDrawnFeatures: markRaw([]), // Store all exist drawn features activeDrawTool: void 0, activeDrawMode: void 0, boundingDims: { centre: [0, 0, 0], size: [1, 1, 1] }, lastSelected: markRaw({ region: "", group: "", isSearch: false }) //checkedRegions: [] }; }, watch: { format: { handler: function(n) { this.fileFormat = n; }, immediate: true }, url: { handler: function(n) { (this.state === void 0 || this.state.url === void 0) && this.setURL(n); }, immediate: true }, region: { handler: function(n) { this.state || this.viewURL || this.setFocusedRegion(n); }, immediate: true }, state: { handler: function(n) { this.setState(n); }, immediate: true, deep: true }, viewURL: { handler: function(n) { this.updateViewURL(n); }, immediate: true }, helpMode: function(n, e) { n !== e && this.setHelpMode(n); }, helpModeActiveItem: function() { this.helpMode && (this.helpModeActiveIndex += 1, this.setHelpMode(this.helpMode)); }, displayMarkers: function(n) { this.$module.scene.displayMarkers = n, this.$module.scene.forcePickableObjectsUpdate = true; }, displayMinimap: function(n) { this.$module.scene.displayMinimap = n; }, currentTime: { handler: function() { this.$emit("timeChanged", this.currentTime); } }, duration: function() { this.$module.scene.setDuration(this.duration); }, minimapSettings: { deep: true, handler: "updateMinimapScissor" }, render: function(n) { this.toggleRendering(n); }, markerCluster: { handler: function(n) { this.$module.scene.enableMarkerCluster(n); }, immediate: true }, markerLabels: function(n) { for (const [e, t] of Object.entries(this.previousMarkerLabels)) this.setMarkerModeForObjectsWithName(e, t, "off"); for (const [e, t] of Object.entries(n)) this.setMarkerModeForObjectsWithName(e, t, "on"); this.previousMarkerLabels = markRaw({ ...n }); } }, beforeCreate: function() { this.$module = new CM(), this.selectedObjects = [], this.hoveredObjects = [], this.currentBackground = "white", this._currentURL = void 0, this.availableBackground = ["white", "black", "lightskyblue"], this.$_searchIndex = new L5(); }, mounted: function() { this.openMapRef = shallowRef(this.$refs.openMapRef), this.backgroundIconRef = shallowRef(this.$refs.backgroundIconRef), this.$refs.scaffoldTreeControls.setModule(this.$module); let n = new u5(); n.subscribe(this, this.eventNotifierCallback), this.$module.addNotifier(n), this.$module.addOrganPartAddedCallback(this.zincObjectAdded), this.$module.addOrganPartRemovedCallback(this.zincObjectRemoved), this.$module.initialiseRenderer(this.$refs.display), this.toggleRendering(this.render), this.ro = new ResizeObserver(this.adjustLayout).observe( this.$refs.scaffoldContainer ), this.helpTextWait = [], this.helpTextWait.length = this.hoverVisibilities.length, this.defaultRate = this.$module.getPlayRate(), this.$module.zincRenderer.addPreRenderCallbackFunction(() => { this.currentTime = this.$module.getCurrentTime(); }); }, beforeUnmount: function() { this.ro && this.ro.disconnect(), this.$module.destroy(), this.$module = void 0; }, computed: { ...mapStores(Dd), ...mapState(Dd, ["userToken"]), annotationDisplay: function() { return this.viewingMode === "Annotation" && this.tData.active === true && this.activeDrawMode !== "Point" && this.activeDrawMode !== "LineString"; }, enableColourPicker: function() { return this.showColourPicker && this.colourRadio; }, modeDescription: function() { let n = this.viewingModes[this.viewingMode]; return this.viewingMode === "Annotation" ? this.authorisedUser ? n[1] : n[0] : n; } }, methods: { /* setCheckedRegions: function (data) { this.checkedRegions = data; }, */ /** * * @param nerves array of nerve names, show all nerves if empty * @param processed boolean, whether unselect all checkboxes */ zoomToNerves: function(n, e = false) { if (this.$module.scene) { this.$module.setIgnorePicking(e); const t = []; this.$module.scene.getRootRegion().getChildRegions().forEach((r) => { r.getName() === "Nerves" && e && n.forEach((o) => { const a = this.findObjectsWithGroupName(o); t.push(...a); }); }), this.$module.setSelectedByZincObjects(t, void 0, {}, true), this.$module.scene.viewAll(); } }, enableAxisDisplay: function(n, e) { this.$module.scene && this.$module.scene.enableAxisDisplay(n, e); }, createAxisDisplay: function(n) { this.$module.scene && this.$module.scene.createAxisDisplay(n); }, /** * @public * Call this to manually add a zinc object into the current scene. * This will subsequently trigger a zincObjectAdded * @arg {Object} "ZincObject object to be added" */ addZincObject: function(n) { this.$module.scene && this.$module.scene.addZincObject(n); }, /** * Internal only. * This is called when a new zinc object is read into the scene. */ zincObjectAdded: function(n) { var r; this.loading = false, this.$_searchIndex.addZincObject(n, n.uuid), this.timeVarying === false && n.isTimeVarying() && (this.timeVarying = true); const e = n.groupName.toLowerCase(); e in Dv && n.setAnatomicalId(Dv[e]); const t = n.getGroup(); t && t.position ? n.userData.originalPos = [ t.position.x, t.position.y, t.position.z ] : n.userData.originalPos = [0, 0, 0]; const i = (r = this.isNerves) == null ? void 0 : r.regions; if (i) { const s = n.getRegion().getFullPath().toLowerCase(); for (let o = 0; o < i.length; o++) s.includes(i[o].toLowerCase()) ? (n.userData.isNerves = true, n.userData.defaultColour = `#${n.getColourHex()}`, n.userData.isGreyScale = false, e in Ov && n.setAnatomicalId(Ov[e])) : n.userData.isNerves = false; } this.$emit("zinc-object-added", n); }, /** * Internal only. * Remove an entry matching region and group from * local annotation list. */ removeFromOfflineAnnotation: function(n, e) { for (let t = 0; t < this.offlineAnnotations.length; t++) { const i = this.offlineAnnotations[t]; if (i.region === n && i.group === e) { this.offlineAnnotations.splice(t, 1); return; } } }, /** * Internal only. * This is called when a zinc object is removed. */ zincObjectRemoved: function(n) { if (this.$module.scene) { const e = n.groupName; n.region.findObjectsWithGroupName(e, false).length === 0 && this.$_searchIndex.removeZincObject(n, n.uuid); } }, /** * Internal only. * Add regions to search index. */ addRegionsToSearchIndex: function() { this.$module.scene.getRootRegion().getChildRegions(true).forEach((t) => { this.$_searchIndex.addRegion(t, t.uuid); }); }, /** * Internal only. * This is called when Change backgspeedround colour button * is pressed an causes the backgrouColornd colour to be changed * to one of the three preset colour: white, black and * lightskyblue. */ backgroundChangeCallback: function(n) { this.currentBackground = n, this.$module.zincRenderer.getThreeJSRenderer().setClearColor(this.currentBackground, 1); }, /** * Internal only. * This is called by captueeScreenshot and after the last render * loop, it download a screenshot of the current scene with no UI. */ captureScreenshotCallback: function() { this.$module.zincRenderer.removePostRenderCallbackFunction( this.captureID ); let n = this.$module.zincRenderer.getThreeJSRenderer().domElement.toDataURL("image/png"), e = document.createElement("a"); document.body.append(e), this.captureFilename ? e.download = this.captureFilename : e.download = "screenshot.png", e.href = n, e.click(), e.remove(); }, /** * @public * Function for capturing a screenshot of the current rendering. * * @arg {String} "filename given to the screenshot." */ captureScreenshot: function(n) { this.captureFilename = n, this.captureID = this.$module.zincRenderer.addPostRenderCallbackFunction( this.captureScreenshotCallback ); }, /** * @public * Function to clear current scene, the tree controls and the search index. */ clearScene: function() { this.$refs.scaffoldTreeControls && this.$refs.scaffoldTreeControls.clear(), this.$_searchIndex && this.$_searchIndex.removeAll(), this.$module.scene && this.$module.scene.clearAll(); }, /** * @public * Add and edit local annotations * @arg `region`, * @arg `group`, * @arg `zincObject`, * @arg `comment` */ addAndEditAnnotations: function(n, e, t, i) { const r = Tv( this.annotator, this.userToken, t, n, e, this.url, i ); if (this.existDrawnFeatures = markRaw(this.existDrawnFeatures.filter((s) => s.id !== r.item.id)), this.existDrawnFeatures.push(r.feature), this.offlineAnnotationEnabled) { r.group = e; let s = n; s.slice(-1) === "/" && (s = s.slice(0, -1)), r.region = s, this.offlineAnnotations = JSON.parse(sessionStorage.getItem("anonymous-annotation")) || [], this.offlineAnnotations.push(r), sessionStorage.setItem("anonymous-annotation", JSON.stringify(this.offlineAnnotations)); } this.$emit("userPrimitivesUpdated", { region: n, group: e, zincObject: t }); }, /** * @public * Callback for when primitives have been update using primitive controls. * This is only called from callback. * @arg `object` */ primitivesUpdated: function(n) { if (n.isZincObject && n.isEditable) { const e = n.groupName, t = n.region.getFullPath(); this.addAndEditAnnotations(t, e, n, "Position Updated"); } }, /** * @public * Confirm creation of new primitive. This is only called from callback. * @arg `payload` */ confirmCreate: function(n) { if (n) { let e; if (n.shape === "Point") e = this.$module.scene.createPoints( n.region, n.group, this.createData.points, n.group, 8942 ); else if (n.shape === "LineString") e = this.$module.scene.createLines( n.region, n.group, [this.createData.points[0], this.createData.points[1]], 60962 ); else if (n.editingIndex > -1 && this._editingZincObject) { this._editingZincObject.editVertices( [this.createData.points[1]], n.editingIndex ); const t = this._editingZincObject.region.getFullPath() + "/", i = this._editingZincObject.groupName; this.addAndEditAnnotations(t, i, this._editingZincObject, "Position Updated"); } e && (this.addAndEditAnnotations(n.region, n.group, e.zincObject, "Create"), e.zincObject.isEditable = true, this.tData.region = n.region, this.tData.label = n.group, this.changeActiveByName([n.group], n.region, false)); } this.cancelCreate(); }, /** * Internal only. * Cancel create workflows. Reset all relevant UIs and data. */ cancelCreate: function() { this.createData.points.length = 0, this.createData.toBeConfirmed = false, this._editingZincObject = void 0, this.createData.editingIndex = -1, this.createData.faceIndex = -1, this.tData.visible = false, this.createData.toBeDeleted = false, this._tempLine && (this.$module.scene.removeTemporaryPrimitive(this._tempLine), this._tempLine = void 0), this._tempPoint && (this.$module.scene.removeTemporaryPrimitive(this._tempPoint), this._tempPoint = void 0), this.annotationSidebar && this.$emit("annotation-close"); }, /** * Internal only. * Confirm delete of user created primitive. * This is only called from callback. */ confirmComment: function(n) { if (this._editingZincObject) { let e = n; this._editingZincObject.isEditable && (this.existDrawnFeatures = markRaw(this.existDrawnFeatures.filter((t) => t.id !== e.item.id)), this.existDrawnFeatures.push(n.feature)), this.offlineAnnotationEnabled && (e.group = this._editingZincObject.groupName, e.region = this._editingZincObject.region.getFullPath(), this.offlineAnnotations = JSON.parse(sessionStorage.getItem("anonymous-annotation")) || [], this.offlineAnnotations.push(e), sessionStorage.setItem("anonymous-annotation", JSON.stringify(this.offlineAnnotations))); } }, /** * Internal only. * Confirm delete of user created primitive. * This is only called from callback. */ confirmDelete: function() { var n; if ((n = this._editingZincObject) != null && n.isEditable) { const e = this._editingZincObject.region.getFullPath() + "/", t = this._editingZincObject.groupName, i = Tv( this.annotator, this.userToken, this._editingZincObject, e, t, this.url, "Deleted" ); i && (this.existDrawnFeatures = markRaw(this.existDrawnFeatures.filter((s) => s.id !== i.item.id)), this.$module.scene.getRootRegion().findChildFromPath(e).removeZincObject(this._editingZincObject), this.offlineAnnotationEnabled && (this.offlineAnnotations = JSON.parse(sessionStorage.getItem("anonymous-annotation")) || [], this.offlineAnnotations = this.offlineAnnotations.filter((s) => s.item.id !== i.item.id), sessionStorage.setItem("anonymous-annotation", JSON.stringify(this.offlineAnnotations)))); } this.cancelCreate(); }, /** * Internal only. * This is triggered when tooltip is hidden */ onTooltipHide: function() { this.createData.toBeConfirmed && !this.annotationSidebar && this.cancelCreate(); }, formatTooltip(n) { if (this.timeMax >= 1e3 && n) { let e = (n % 6e4 / 1e3).toFixed(2) + "s"; return (n > 6e4 ? (n / 6e4).toFixed(0) + "m " : "") + e; } return n ? n.toFixed(2) + " ms" : "0 ms"; }, /** * @public * Function to reset the view to default. * Also called when the associated button is pressed. */ fitWindow: function() { if (this.$module.scene) { let n = false; this._boundingBoxGeo && (n = this._boundingBoxGeo.getVisibility(), this._boundingBoxGeo.setVisibility(false)), this.$module.scene.viewAll(), this._boundingBoxGeo && (D4(this._boundingBoxGeo, this.$module.scene), this._boundingBoxGeo.setVisibility(n)); } }, /** * @public * Function to zoom in. * Also called when the associated button is pressed. */ zoomIn: function() { this.$module.scene && this.$module.scene.changeZoomByScrollRateUnit(-1); }, /** * Function to zoom out. * Also called when the associated button is pressed. * * @public */ zoomOut: function() { this.$module.scene && this.$module.scene.changeZoomByScrollRateUnit(1); }, /** * Function to change the current play speed. * * @public * @arg `speed` */ speedChanged: function(n) { this.currentSpeed = n, this.$module.setPlayRate(this.defaultRate * this.currentSpeed); }, /** * Function used to stop the free spin * * @public */ stopFreeSpin: function() { this.$module.scene.getZincCameraControls().stopAutoTumble(), this.isTransitioning = false; }, /** * Return a list of obejcts with the provided name. * @arg "Group name to search." * * @public */ findObjectsWithGroupName: function(n) { let e = []; return n && n != "" && this.$module.scene && (e = this.$module.scene.findObjectsWithGroupName(n)), e; }, /** * @public * Switch active drawing type * @arg {String} `type` * @arg {String} `icon` */ toggleDrawing: function(n, e) { this.createData.toBeDeleted = false, n === "mode" ? (this.cancelCreate(), this.activeDrawMode = e, this.createData.shape = "", this.$module.selectObjectOnPick = true) : n === "tool" && (this.activeDrawTool = e, this.createData.shape = this.activeDrawTool ? this.activeDrawTool : "", this.$module.selectObjectOnPick = false); }, /** * Toggle the drawing box which aid the drawing * * @public */ toggleDrawingBox: function() { this.createData.drawingBox = !this.createData.drawingBox; }, /** * Find and and zoom into objects with the provided list of names. * @arg "List of names" * * @public */ viewRegion: function(n) { const e = this.$module.scene.getRootRegion(), t = Array.isArray(n) ? n : [n], i = xo(e, t, "", true); let r = this.$module.scene.getBoundingBoxOfZincObjects(i); if (r) { if (this.$module.isSyncControl()) this.$module.setSyncControlZoomToBox(r); else { const s = this.$module.scene.camera.far - this.$module.scene.camera.near; this.$module.scene.viewAllWithBoundingBox(r), this.$module.scene.camera.far = this.$module.scene.camera.near + s, this.$module.scene.camera.updateProjectionMatrix(); } return true; } return false; }, setFocusedRegion: function(n) { n && (this.isReady ? this.viewRegion(n) : this.$module.setFinishDownloadCallback( this.setURLFinishCallback({ region: n }) )); }, updateViewURL: function(n) { if (n) if (this.isReady) { const e = new URL(n, this.url); this.$module.scene.loadViewURL(e); } else this.$module.setFinishDownloadCallback( this.setURLFinishCallback({ viewURL: n }) ); }, createEditTemporaryLines: function(n) { const e = n[0].extraData.worldCoords; if (e && (this.createData.shape === "LineString" || this.createData.editingIndex > -1) && this.createData.points.length === 1) if (this.showRegionTooltipWithAnnotations(n, true, false), this.tData.x = 50, this.tData.y = 200, this._tempLine) { const t = this._tempLine.geometry.getAttribute("position"); t.setXYZ(1, e[0], e[1], e[2]), t.needsUpdate = true; } else this._tempLine = this.$module.scene.addTemporaryLines( [this.createData.points[0], e], 65535 ); }, draw: function(n) { n && n.length > 0 && n[0].data.group && n[0].extraData.worldCoords && (this.createData.shape === "Point" ? this.drawPoint(n[0].extraData.worldCoords, n) : (this.createData.shape === "LineString" || this.createData.editingIndex > -1) && this.drawLine(n[0].extraData.worldCoords, n)); }, drawPoint: function(n, e) { this.createData.toBeConfirmed === false && (this.createData.points.length = 0, this.createData.points.push(n), this.createData.toBeConfirmed = true, this.showRegionTooltipWithAnnotations(e, true, false), this.tData.x = 50, this.tData.y = 200, this._tempPoint = this.$module.scene.addTemporaryPoints([n], 16776960)); }, drawLine: function(n, e) { this.createData.toBeConfirmed === false && (this.createData.points.length === 1 ? (this.createData.points.push(n), this.createData.toBeConfirmed = true, this.showRegionTooltipWithAnnotations(e, true, false), this.tData.x = 50, this.tData.y = 200) : (this._tempPoint = this.$module.scene.addTemporaryPoints([n], 16776960), this.createData.points.push(n))); }, /** * Return renderer information * * @public */ getRendererInfo: function() { if (this.$module.zincRenderer) return this.$module.zincRenderer.getThreeJSRenderer().info; }, /** * Function used to rotate the scene. * Also called when the associated button is pressed. * * @public */ freeSpin: function() { if (this.$module.scene) { let n = this.$module.scene.getZincCameraControls(); this.isTransitioning = true, n.enableAutoTumble(), n.autoTumble([1, 0], Math.PI, true), setTimeout(this.stopFreeSpin, 4e3); } }, activateAnnotationMode: function(n, e) { if (this.authorisedUser || this.offlineAnnotationEnabled) if (this.createData.toBeDeleted = false, this.createData.shape !== "" || this.createData.editingIndex > -1) n.length > 0 && e.identifiers[0].coords && (this.createData.x = e.identifiers[0].coords.x, this.createData.y = e.identifiers[0].coords.y, this.draw(e.identifiers)); else { if (this.activeDrawMode === "Edit") { const t = F4(e); t && this.activateEditingMode( t.zincObject, t.faceIndex, t.vertexIndex, t.point ); } else if (this.activeDrawMode === "Delete") { const t = I4(e); t && (this.createData.toBeDeleted = true, this._editingZincObject = t); } this.activeDrawMode !== "Point" && this.activeDrawMode !== "LineString" ? this.showRegionTooltipWithAnnotations(e.identifiers, true, false) : this.showRegionTooltipWithAnnotations(e.identifiers, true, true); } else this.showRegionTooltipWithAnnotations(e.identifiers, true, true); }, activateEditingMode: function(n, e, t, i) { this._editingZincObject = n, this.createData.faceIndex = e, this.createData.editingIndex = t, this.drawLine(i, void 0); }, /** * Callback when a region is selected/highlighted. * It will also update other controls. * */ eventNotifierCallback: function(n) { if (!(this.createData.toBeConfirmed || this.createData.toBeDeleted)) { const e = []; let t = []; (n.eventType == 1 || n.eventType == 2) && (n.identifiers.forEach((s) => { if (s) { let o = s.data.id ? s.data.id : s.data.group; e.push(o); } }), t = n.zincObjects); let i, r; if (n.identifiers.length > 0 && n.identifiers[0] && (i = n.identifiers[0].data.id ? n.identifiers[0].data.id : n.identifiers[0].data.group, n.identifiers[0].data.region && (r = n.identifiers[0].data.region)), n.eventType == 1) if (this.viewingMode === "Annotation") { this.tData.label = i, this.tData.region = r; const s = P4(n); if (this._editingZincObject = s, s) { const o = this._editingZincObject.region.getFullPath() + "/", a = this._editingZincObject.groupName; this.annotationFeature = bM( this._editingZincObject, o, a, this.url, "" ).feature; } this.activateAnnotationMode(e, n); } else this.$refs.scaffoldTreeControls && (e.length > 0 ? (this.$refs.scaffoldTreeControls.updateActiveUI(t), this.updatePrimitiveControls(t)) : (this.hideRegionTooltip(), this.$refs.scaffoldTreeControls.removeActive(false))), n.identifiers.length === 1 ? this.lastSelected = { isSearch: false, region: r, group: n.identifiers[0].data.group } : n.identifiers.length === 0 && (this.lastSelected = { isSearch: false, region: "", group: "" }), this.$emit("scaffold-selected", n.identifiers); else if (n.eventType == 2) this.selectedObjects.length === 0 && (this.hideRegionTooltip(), this.$refs.scaffoldTreeControls && (e.length > 0 ? this.$refs.scaffoldTreeControls.updateHoverUI(t) : this.$refs.scaffoldTreeControls.removeHover(true)), n.identifiers.length > 0 && n.identifiers[0] && n.identifiers[0].coords && (this.tData.active = false, (this.viewingMode !== "Annotation" || !this.annotationSidebar) && (this.tData.visible = true), this.tData.label = i, this.tData.region = r, this.tData.x = n.identifiers[0].coords.x, this.tData.y = n.identifiers[0].coords.y, this.createEditTemporaryLines(n.identifiers)), this.$emit("scaffold-highlighted", n.identifiers)); else if (n.eventType == 3 && n.identifiers.length > 0 && n.identifiers[0]) { if (n.identifiers[0].coords) { const s = this.$refs.scaffoldContainer.getBoundingClientRect(); this.tData.x = n.identifiers[0].coords.x - s.left, this.tData.y = n.identifiers[0].coords.y - s.top; } this.createEditTemporaryLines(n.identifiers); } } }, /** * Get the coordinates of the current selected region. * * @public */ getCoordinatesOfSelected: function() { if (this.selectedObjects && this.selectedObjects.length > 0) return this.$module.scene.getObjectsScreenXY(this.selectedObjects); }, /** * Return an object containing the window coordinates of the * current selected region which will be updated after each render * loop. * * @public */ getDynamicSelectedCoordinates: function() { return this.$module.selectedScreenCoordinates; }, /** * Callback when time is changed through the UI. */ timeChange: function(n) { let e = n / this.timeMax * 100; e != this.currentTime && this.$module.updateTime(e); }, /** * Update primitive controls UI with the specified objects * * @arg objects objects to be set for the selected */ updatePrimitiveControls: function(n) { (this.viewingMode === "Exploration" || this.viewingMode === "Annotation") && (this.selectedObjects = n, this.selectedObjects && this.selectedObjects.length > 0 ? this.$refs.primitiveControls.setObject(this.selectedObjects[0]) : this.$refs.primitiveControls.setObject(void 0)); }, /** * A callback used by children components. Set the selected zinc object * * @arg Selected zinc objects * @arg Flag to determine if callback should be triggered when new selection * is made */ objectSelected: function(n, e) { this.$module.isIgnorePicking() || (this.updatePrimitiveControls(n), this.$module.setSelectedByZincObjects(n, void 0, {}, e)); }, /** * A callback used by children components. Set the highlighted zinc object * * @arg Hovered zinc objects * @arg Flag to determine if callback should be triggered when new selection * is made */ objectHovered: function(n, e) { this.hoveredObjects = n, this.$module.setHighlightedByZincObjects(n, void 0, {}, e); }, /** * Set the selected by name. * * @param {} name Name of the group */ changeActiveByName: function(n, e, t) { const i = Array.isArray(n); if (n === void 0 || i && n.length === 0) this.$refs.scaffoldTreeControls.removeActive(t); else { let r = n; i || (r = [r]), this.$refs.scaffoldTreeControls.changeActiveByNames(r, e, t); } }, /** * Set the highlighted by name. * * @param {name} name Name of the group */ changeHighlightedByName: function(n, e, t) { const i = Array.isArray(n); if (n === void 0 || i && n.length === 0) this.$refs.scaffoldTreeControls.removeHover(t); else { let r = n; i || (r = [r]), this.$refs.scaffoldTreeControls.changeHoverByNames(r, e, t); } }, /** * @public * Start the animation. * * @arg "flag to turn the animation on/off" */ play: function(n) { this.$module.playAnimation(n), this.isPlaying = n; }, /** * @public * Function to toggle on/off overlay help. */ setHelpMode: function(n) { const e = this.hoverVisibilities.length, t = e - 1, i = this.hoverVisibilities[this.helpModeActiveIndex]; if (i) { const r = i == null ? void 0 : i.refs, s = i == null ? void 0 : i.ref; this.$refs[r || s] || (this.helpModeActiveIndex += 1); } n || (this.helpModeActiveIndex = this.helpModeInitialIndex), n && this.helpModeActiveIndex >= t && this.$emit("help-mode-last-item", true), n && !this.helpModeDialog ? (this.inHelp = true, this.hoverVisibilities.forEach((r) => { r.value = true; })) : n && this.helpModeDialog && e > this.helpModeActiveIndex ? this.helpModeActiveIndex > -1 && setTimeout(() => { this.inHelp = false, this.hoverVisibilities.forEach((r) => { r.value = false; }), this.showHelpText(this.helpModeActiveIndex, 200); }, 300) : (this.inHelp = false, this.hoverVisibilities.forEach((r) => { r.value = false; })); }, /** * Callback function used by showRegionTooltip in the case when the tooltip * is out of view. */ displayTooltipOfObjectsCallback: function(n, e, t, i, r) { const s = this; return function() { s.$module.zincRenderer.removePostRenderCallbackFunction( s.$_regionTooltipCallback ), s.$_regionTooltipCallback = void 0, s.displayTooltipOfObjects(n, e, t, i, r); }; }, liveUpdateTooltipPosition: function() { this.$module.selectedCenter && (this.tData.x = this.$module.selectedScreenCoordinates.x, this.tData.y = this.$module.selectedScreenCoordinates.y); }, displayTooltipOfObjects: function(n, e, t, i, r) { if (e.length > 0) { let s = e[0].getClosestVertexDOMElementCoords( this.$module.scene ); if (s) return s.inView ? (n.includes("Search Results for") ? this.tData.active = false : this.tData.active = true, this.tData.visible = true, this.tData.label = n, this.tData.x = s.position.x, this.tData.y = s.position.y, this.tData.region = t, this.$_liveCoordinatesUpdated && this.$module.zincRenderer.removePostRenderCallbackFunction( this.$_liveCoordinatesUpdated ), r && (this.$module.setupLiveCoordinates(e), this.$_liveCoordinatesUpdated = this.$module.zincRenderer.addPostRenderCallbackFunction( this.liveUpdateTooltipPosition ))) : (this.hideRegionTooltip(), i && (this.$module.scene.viewAll(), this.$_regionTooltipCallback && this.$module.zincRenderer.removePostRenderCallbackFunction( this.$_regionTooltipCallback ), this.$_regionTooltipCallback = this.$module.zincRenderer.addPostRenderCallbackFunction( this.displayTooltipOfObjectsCallback( n, e, t, i, r ) ))), true; } return this.hideRegionTooltip(), false; }, /** * Display the tooltip used for displaying search result. * When resetView is set to true, it will * reset view if the tooltip is not in view. * Setting liveUpdates to true will update the tooltip location * at every rendering loop. */ showRegionTooltipWithObjects: function(n, e, t, i, r) { return n && e && e.length > 0 && this.$module.scene ? this.displayTooltipOfObjects( n, e, t, i, r ) : (this.hideRegionTooltip(), false); }, /** * Display the tooltip. When resetView is set to true, it will * reset view if the tooltip is not in view. * Setting liveUpdates to true will update the tooltip location * at every rendering loop. */ showRegionTooltip: function(n, e, t) { if (n && this.$module.scene) { const i = this.$module.scene.getRootRegion(), s = xo(i, [n], "", true); let o; return s && s.length > 0 && (o = s[0].getRegion().getFullPath()), this.showRegionTooltipWithObjects( n, s, o, e, t ); } return this.hideRegionTooltip(), false; }, /** * Display the tooltip using the list of annotations. * When resetView is set to true, it will * reset view if the tooltip is not in view. * Setting liveUpdates to true will update the tooltip location * at every rendering loop. */ showRegionTooltipWithAnnotations: function(n, e, t) { if (this.$module.scene) { const i = _v(this.$module.scene, n); if (i && i.objects.length > 0) if (this.annotationSidebar) { const s = [{ featureId: (this.tData.region ? this.tData.region + "/" : "") + this.tData.label, resourceId: this.url, resource: this.url, feature: this.annotationFeature, offline: this.offlineAnnotationEnabled }]; this.$emit("annotation-open", { annotationEntry: s, createData: this.createData, confirmCreate: this.confirmCreate, cancelCreate: this.cancelCreate, confirmDelete: this.confirmDelete, confirmComment: this.confirmComment }); return; } else return this.showRegionTooltipWithObjects( i.label, i.objects, i.regionPath, e, t ); } return this.hideRegionTooltip(), false; }, clearAnnotationFeature: function() { const n = this.getOfflineAnnotations(); this.existDrawnFeatures.map((t) => decodeURIComponent(t.id).split("/").pop()).forEach((t) => { const i = this.$module.scene.findObjectsWithGroupName(t, false); if (i && i.length) { const r = i[0].region.getFullPath() + "/"; this.$module.scene.getRootRegion().findChildFromPath(r).removeZincObject(i[0]); } }), this.$refs.scaffoldTreeControls.removeRegion("__annotation"), this.offlineAnnotations = n; }, addAnnotationFeature: async function() { let n; if (this.offlineAnnotationEnabled) this.offlineAnnotations = JSON.parse(sessionStorage.getItem("anonymous-annotation")) || [], n = this.offlineAnnotations.filter((e) => e.resource === this.url && e.feature.properties.drawn).map((e) => e.feature); else { n = []; const e = await Ev(this.annotator, this.userToken, this.url); e && e.features && (n = [...e.features]); const t = await Ev(this.annotator, this.userToken, encodeURIComponent(this.url)); t && t.features && (n = [...n, ...t.features]); } this.existDrawnFeatures = markRaw(n), Cv(this.$module.scene, n); }, /** * Callback on viewing mode change * Optional, can be used to update the view mode. */ changeViewingMode: function(n) { let e = true; this.$module && (n && (this.viewingMode = n), this.clearAnnotationFeature(), this.viewingMode === "Annotation" ? (this.loading = true, this.annotator.authenticate(this.userToken).then((t) => { t.name && t.email && t.canUpdate ? (this.authorisedUser = t, this.offlineAnnotationEnabled = false) : (this.authorisedUser = void 0, this.offlineAnnotationEnabled = true), this.emitOfflineAnnotationUpdate(), this.addAnnotationFeature(), this.loading = false; })) : this.viewingMode === "Exploration" ? (this.activeDrawTool = void 0, this.activeDrawMode = void 0, this.createData.shape = "") : this.viewingMode === "Neuron Connection" && (e = false), this.viewingMode === "Exploration" || this.viewingMode === "Neuron Connection" || this.viewingMode === "Annotation" && this.createData.shape === "" ? this.$module.selectObjectOnPick = true : this.$module.selectObjectOnPick = false, this.cancelCreate(), n && this.setObjectIsPickable(e)); }, /** * Function to emit offline annotation enabled status */ emitOfflineAnnotationUpdate: function() { this.$emit("update-offline-annotation-enabled", this.offlineAnnotationEnabled); }, /** * @public * Hide the tooltip */ hideRegionTooltip: function() { this.$_liveCoordinatesUpdated && (this.$module.zincRenderer.removePostRenderCallbackFunction( this.$_liveCoordinatesUpdated ), this.$module.setupLiveCoordinates(void 0)), this.tData.active = false, this.tData.visible = false, this.tData.region = void 0; }, /** * Currently will apply to non-nerve object and object without anatomical id * @param flag boolean to control whether objects pickable */ setObjectIsPickable: function(n) { this.$module.scene.getRootRegion().getAllObjects(true).forEach((t) => { var i; !((i = t.userData) != null && i.isNerves) && !t.anatomicalId && t.setIsPickable(n); }); }, /** * Update objects to greyscale or colour. * This will update all objects except those with the provided nerves labels. * @param flag boolean * @param labels array of nerve names that exclude from greyscale */ setGreyScale: function(n, e = []) { this.$module.scene.getRootRegion().getAllObjects(true).forEach((i) => { var a; const r = i.groupName.toLowerCase(), s = (a = i.userData) == null ? void 0 : a.isNerves; (e.length > 0 && s && !e.includes(r) || e.length === 0 && !s) && (i.setGreyScale(n), i.userData.isGreyScale = n); }), this.$refs.scaffoldTreeControls.updateAllNodeColours(); }, /** * @public * Function to toggle colour/greyscale of primitives. * The parameter ``flag`` is a boolean, ``true`` (colour) and ``false`` (greyscale). * @arg {Boolean} `flag` */ setColour: function(n, e = false) { this.isReady && this.$module.scene && typeof n == "boolean" && (e || n !== this.colourRadio) && (this.loading = true, setTimeout(() => { this.setGreyScale(!n), this.loading = false, this.colourRadio = n; }, 100)); }, /** * @public * Function to toggle lines graphics. * The parameter ``flag`` is a boolean, ``true`` to show lines, ``false`` to hide them. * @arg {Boolean} `flag` */ setOutlines: function(n, e = false) { this.isReady && this.$module.scene && typeof n == "boolean" && (e || n !== this.outlinesRadio) && (this.outlinesRadio = n, this.$nextTick(() => this.$refs.scaffoldTreeControls.setOutlines(n))); }, /** * Set the marker modes for objects with the provided name, mode can * be "on", "off" or "inherited". * Value can either be number or an object containing number and * imgURL. */ setMarkerModeForObjectsWithName: function(n, e, t) { if (n && this.$module.scene) { let i = e; typeof e == "number" && (i = { number: e, imgURL: void 0 }); const r = this.$module.scene.getRootRegion(); xo(r, [n], "", true).forEach((a) => a.setMarkerMode(t, i)); } }, /** * @public * Set the marker modes for objects specified by the list of annotations * @arg `annotations` * @arg `mode` */ setMarkerModeWithAnnotations: function(n, e) { if (this.$module.scene) { const t = _v(this.$module.scene, n); t && t.objects.length > 0 && t.objects.forEach((i) => i.setMarkerMode(e)); } }, /** * This is called when mouse cursor enters supported elements * with help tootltips. */ showHelpText: function(n, e = 500) { this.inHelp || (clearTimeout(this.helpTextWait[n]), this.helpTextWait[n] = setTimeout(() => { this.hoverVisibilities[n].value = true, this.$emit("shown-tooltip"); }, e)); }, /** * This is called when mouse cursor exits supported element.. */ hideHelpText: function(n, e = 500) { this.inHelp || (clearTimeout(this.helpTextWait[n]), this.helpTextWait[n] = setTimeout(() => { this.hoverVisibilities[n].value = false; }, e)); }, /** * @public * * Search a object and display the tooltip * @arg "text to search across" * @arg "toggle the tooltip if this is set" */ search: function(n, e) { if (this.$_searchIndex) { if (n === void 0 || n === "" || Array.isArray(n) && n.length === 0) return this.lastSelected = { region: "", group: "", isSearch: true }, this.objectSelected([], true), false; { this.lastSelected = { region: "", group: n, isSearch: true }; const t = this.$_searchIndex.searchAndProcessResult(n), i = t.zincObjects; if (i.length > 0) { if (this.objectSelected(i, true), e) for (let r = 0; r < i.length; r++) i[r] && i[r].groupName && this.showRegionTooltipWithObjects( t.label, i, t.regionPath, true, true ); return true; } else this.objectSelected([], true); } } return false; }, /** * @public * * Get the list of suggested terms based on the provided term. * This can be used for autocomplete. * @arg `term` */ fetchSuggestions: function(n) { return this.$_searchIndex === void 0 ? [] : this.$_searchIndex.auto_suggest(n); }, /** * Called when minimap settings has changed. Pass the * parameters to ZincJS and marked it for update. */ updateMinimapScissor: function() { Object.keys(this.minimapSettings).forEach((n) => { this.$module.scene.minimapScissor[n] = this.minimapSettings[n]; }), this.$module.scene.minimapScissor.updateRequired = true; }, updateSettingsfromScene: function() { this.currentSpeed = 1, this.$module.setPlayRate(this.defaultRate), this.orginalDuration = this.$module.scene.getMetadataTag("OriginalDuration"), this.animateDuration = this.$module.scene.getMetadataTag("Duration"); let n = this.$module.scene.getMetadataTag("TimeStamps"); this.timeStamps = {}; for (const e in n) this.timeStamps[n[e]] = e; this.timeMax = this.$module.scene.getDuration(); }, restoreSettings: function(n) { if (n) { if (n.viewport) this.$module.scene.getZincCameraControls().setCurrentCameraSettings(n.viewport); else if (n.viewURL && n.viewURL !== "") { const t = new URL(n.viewURL, this.url); this.$module.scene.loadViewURL(t); } else n.region && n.region !== "" && this.viewRegion(n.region); n.visibility && this.$nextTick(() => { this.$refs.scaffoldTreeControls.setState(n.visibility); }), n.background && this.backgroundChangeCallback(n.background), "colour" in n && this.setColour(n.colour), n.offlineAnnotations && sessionStorage.setItem("anonymous-annotation", n.offlineAnnotations), "outlines" in n && this.setOutlines(n.outlines), n.viewingMode && this.changeViewingMode(n.viewingMode); const e = n.search; e && e.group && (e.isSearch ? this.search(e.group, true) : this.changeActiveByName(e.group, e.region, true)); } }, downloadErrorCallback: function() { return (n) => { this.$emit("on-error", n); }; }, setURLFinishCallback: function(n) { return () => { this.offlineAnnotations.length = 0, this.updateSettingsfromScene(), this.$module.updateTime(0.01), this.$module.updateTime(0), this.$module.unsetFinishDownloadCallback(), this.addRegionsToSearchIndex(), this.setMarkers(), this._boundingBoxGeo = this.$module.scene.addBoundingBoxPrimitive( "_helper", "boundingBox", 4251856, 0.15 ), this._slides = this.$module.scene.addSlicesPrimitive( "_helper", ["x-plane", "y-plane", "z-plane"], [16733525, 5635925, 5592575], 0.5 ); const { centre: e, size: t } = this.$module.getCentreAndSize(); this.boundingDims.centre = e, this.boundingDims.size = t, this.isReady = true, this.$nextTick(() => { this.restoreSettings(n), this.$emit("on-ready"); }); }; }, /** * Function used for getting the current states of the scene. This exported states * can be imported using the importStates method. * * @public */ getState: function() { let n = { format: this.fileFormat, url: this._currentURL, viewport: void 0, visibility: void 0, background: this.currentBackground, colour: this.colourRadio, outlines: this.outlinesRadio, viewingMode: this.viewingMode, usageConfig: this.usageConfig }; if (this.$refs.scaffoldTreeControls && (n.visibility = this.$refs.scaffoldTreeControls.getState()), this.$module.scene) { let e = this.$module.scene.getZincCameraControls(); n.viewport = e.getCurrentViewport(); } return this.lastSelected && this.lastSelected.group && (n.search = { ...this.lastSelected }), this.offlineAnnotationEnabled && (n.offlineAnnotations = sessionStorage.getItem("anonymous-annotation")), n; }, /** * Function used for importing the states of the scene. This exported states * can be imported using the read states method. * * @public * @arg `state` */ setState: function(n) { n && (n.url && n.url !== this._currentURL ? this.setURLAndState(n.url, { fileFormat: n.fileFormat, viewport: n.viewport, visibility: n.visibility, background: n.background, colour: n.colour, outlines: n.outlines, viewingMode: n.viewingMode, search: n.search, offlineAnnotations: n.offlineAnnotations }) : (n.background || n.colour || n.search || n.outlines || n.viewport || n.viewingMode || n.visibility) && (this.isReady && this.$module.scene ? this.restoreSettings(n) : this.$module.setFinishDownloadCallback( this.setURLFinishCallback({ background: n.background, colour: n.colour, search: n.search, offlineAnnotations: n.offlineAnnotations, outlines: n.outlines, viewingMode: n.viewingMode, viewport: n.viewport, visibility: n.visibility }) ))); }, /** * export current scene in GLTF. * @arg "Return in binary form when set to true" * * @public */ exportGLTF: function(n) { return this.$module.scene.exportGLTF(n); }, /** * Return a copy of the local annotations list. * This list is used for storing user created annotation * when offlineAnnotationEnabled is set to true. * * @public */ getOfflineAnnotations: function() { return [...this.offlineAnnotations]; }, /** * Import local annotations. The annotations will only * be imported when offlineAnnotationEnabled is set to * true; * * @public * @arg {Array} `annotationsList` */ importOfflineAnnotations: function(n) { if (this.offlineAnnotationEnabled) { n.forEach((t) => { const i = t.group, r = t.region; let s = r.slice(-1) === "/" ? r : r + "/"; const o = s.slice(0, -1); t.region = o, s = s + i; const a = s; t.item.id = a, t.feature.id = a; }); const e = n.map((t) => t.feature); Cv(this.$module.scene, e), n.forEach((t) => { this.offlineAnnotations.push({ ...t }); }), sessionStorage.setItem("anonymous-annotation", JSON.stringify(this.offlineAnnotations)); } }, /** * Function used for reading in new scaffold metadata and a custom * viewport. This function will ignore the state prop and * read in the new url. * * @public * @arg `newValue` * @arg `state` */ setURLAndState: function(n, e) { var t, i; if (n != this._currentURL) { const r = {}; e != null && e.format && (this.fileFormat = e.format), this._currentURL = n, this.$refs.scaffoldTreeControls && this.$refs.scaffoldTreeControls.clear(), this.loading = true, this.timeVarying = false, this.isReady = false, this.$_searchIndex.removeAll(), this.hideRegionTooltip(), this.$module.setDownloadErrorCallback( this.downloadErrorCallback() ), this.$module.setFinishDownloadCallback( this.setURLFinishCallback({ background: e == null ? void 0 : e.background, colour: e == null ? void 0 : e.colour, outlines: e == null ? void 0 : e.outlines, region: this.region, search: e == null ? void 0 : e.search, viewingMode: e == null ? void 0 : e.viewingMode, viewURL: this.viewURL, viewport: e == null ? void 0 : e.viewport, visibility: e == null ? void 0 : e.visibility, offlineAnnotations: e == null ? void 0 : e.offlineAnnotations }) ), this.fileFormat === "gltf" ? this.$module.loadGLTFFromURL(n, "scene", true) : (((t = this == null ? void 0 : this.usageConfig) != null && t.tubeLines || (i = e == null ? void 0 : e.usageConfig) != null && i.tubeLines) && (r.tubeLines = true), this.$module.loadOrgansFromURL( n, void 0, void 0, "scene", void 0, true, r )), this.$module && this.$module.scene && (this.$module.scene.displayMarkers = this.displayMarkers, this.$module.scene.forcePickableObjectsUpdate = true, this.$module.scene.displayMinimap = this.displayMinimap, this.updateMinimapScissor()); } }, /** * Function used for reading in new scaffold metadata. This function will ignore * the state prop and read in the new url. * * @public * @arg `newValue` */ setURL: function(n) { this.setURLAndState(n, void 0); }, /** * Callback when drawer is toggled. */ drawerToggled: function(n) { this.drawerOpen = n, this.adjustLayout(); }, /** * Callback using ResizeObserver. */ adjustLayout: function() { if (this.$refs.scaffoldContainer) { let n = this.$refs.scaffoldContainer.clientWidth; this.minimisedSlider = n < 812, this.minimisedSlider ? this.sliderPosition = this.drawerOpen ? "right" : "left" : this.sliderPosition = ""; } }, toggleRendering: function(n) { this.$module.zincRenderer && (n ? this.$module.zincRenderer.animate() : this.$module.zincRenderer.stopAnimate()); }, /** * @public * * Force the renderer to resize */ forceResize: function() { this.$module.zincRenderer && this.$module.zincRenderer.onWindowResize(); }, syncControlCallback: function() { const n = this.$module.NDCCameraControl.getPanZoom(); this.tData.visible && this.showRegionTooltip(this.tData.label, true, true), this.$emit("scaffold-navigated", n); }, /** * Rotate mode - "none", "horizontal", "vertical", "free" but * it will be ignored if flag is set to false. */ toggleSyncControl: function(n, e) { this.$module.toggleSyncControl(n, e), this.$module.setSyncControlCallback(this.syncControlCallback); }, /** * Set the markers for the scene. */ setMarkers: function() { for (const [n, e] of Object.entries(this.markerLabels)) this.setMarkerModeForObjectsWithName(n, e, "on"); } } }; var D5 = { ref: "scaffoldContainer", class: "scaffold-container", "element-loading-text": "Loading...", "element-loading-background": "rgba(0, 0, 0, 0.3)" }; var N5 = { class: "primitive-controls-box" }; var B5 = { class: "animation-data" }; var U5 = { class: "purple" }; var z5 = { class: "animation-data" }; var V5 = { class: "purple" }; var k5 = { class: "animation-data" }; var G5 = { class: "bottom-right-control" }; var H5 = { style: { "margin-bottom": "2px" } }; var W5 = { key: 0, class: "viewing-mode-title" }; var j5 = ["onClick"]; var $5 = ["onClick"]; function Z5(n, e, t, i, r, s) { const o = resolveComponent("map-svg-sprite-color"), a = EM, c = resolveComponent("DrawToolbar"), l = u0, d = It, h6 = cu, f = TM, g = _M, p = resolveComponent("map-svg-icon"), u = ti, y = Ui, v = xy, m = Qo, x = qo, w = by, A = Ko, M = ty, R = ny, L = td; return withDirectives((openBlock(), createElementBlock("div", D5, [ createVNode(o), createVNode(a, { createData: n.createData, label: n.tData.label, region: n.tData.region, visible: n.tData.visible, x: n.tData.x, y: n.tData.y, annotationDisplay: s.annotationDisplay, annotationFeature: n.annotationFeature, offlineAnnotationEnabled: n.offlineAnnotationEnabled, onConfirmCreate: e[0] || (e[0] = (S) => s.confirmCreate(S)), onCancelCreate: e[1] || (e[1] = (S) => s.cancelCreate()), onConfirmComment: e[2] || (e[2] = (S) => s.confirmComment(S)), onConfirmDelete: e[3] || (e[3] = (S) => s.confirmDelete()), onTooltipHide: e[4] || (e[4] = (S) => s.onTooltipHide()) }, null, 8, ["createData", "label", "region", "visible", "x", "y", "annotationDisplay", "annotationFeature", "offlineAnnotationEnabled"]), createBaseVNode("div", { id: "organsDisplayArea", ref: "display", tabindex: "-1", style: { height: "100%", width: "100%" }, onKeydown: e[5] || (e[5] = withKeys((...S) => s.backgroundChangeCallback && s.backgroundChangeCallback(...S), ["66"])) }, null, 544), withDirectives(createBaseVNode("div", null, [ n.viewingMode === "Annotation" && (n.authorisedUser || n.offlineAnnotationEnabled) ? (openBlock(), createBlock(c, { key: 0, toolbarOptions: n.toolbarOptions, activeDrawTool: n.activeDrawTool, activeDrawMode: n.activeDrawMode, hoverVisibilities: n.hoverVisibilities, onClickToolbar: s.toggleDrawing, onShowTooltip: s.showHelpText, onHideTooltip: s.hideHelpText, ref: "toolbarPopover" }, null, 8, ["toolbarOptions", "activeDrawTool", "activeDrawMode", "hoverVisibilities", "onClickToolbar", "onShowTooltip", "onHideTooltip"])) : createCommentVNode("", true), t.displayWarning ? (openBlock(), createBlock(h6, { key: 1, ref: "warningPopover", visible: n.hoverVisibilities[7].value, content: t.warningMessage, placement: "right", width: "max-content", teleported: false, "popper-class": "scaffold-popper message-popper right-popper non-selectable" }, { reference: withCtx(() => [ t.displayWarning ? (openBlock(), createElementBlock("div", { key: 0, class: "message-icon warning-icon", onMouseover: e[6] || (e[6] = (S) => s.showHelpText(7)), onMouseout: e[7] || (e[7] = (S) => s.hideHelpText(7)) }, [ createVNode(d, null, { default: withCtx(() => [ createVNode(l) ]), _: 1 }), e[31] || (e[31] = createBaseVNode("span", { class: "message-text" }, "Beta", -1)) ], 32)) : createCommentVNode("", true) ]), _: 1 }, 8, ["visible", "content"])) : createCommentVNode("", true), t.displayLatestChanges ? (openBlock(), createBlock(h6, { key: 2, visible: n.hoverVisibilities[8].value, content: t.latestChangesMessage, placement: "right", teleported: false, trigger: "manual", "popper-class": "scaffold-popper message-popper right-popper non-selectable", ref: "whatsNewPopover" }, { reference: withCtx(() => [ t.displayLatestChanges && t.latestChangesMessage ? (openBlock(), createElementBlock("div", { key: 0, class: "el-icon-warning message-icon latest-changesicon", onMouseover: e[8] || (e[8] = (S) => s.showHelpText(8)), onMouseout: e[9] || (e[9] = (S) => s.hideHelpText(8)) }, [ createVNode(d, null, { default: withCtx(() => [ createVNode(l) ]), _: 1 }), e[32] || (e[32] = createBaseVNode("span", { class: "message-text" }, "What's new?", -1)) ], 32)) : createCommentVNode("", true) ]), _: 1 }, 8, ["visible", "content"])) : createCommentVNode("", true), createVNode(h6, { visible: n.hoverVisibilities[6].value, content: "Change region visibility", placement: "right", width: "max-content", teleported: false, trigger: "manual", "popper-class": "scaffold-popper right-popper non-selectable", ref: "regionVisibilityPopover" }, { reference: withCtx(() => [ createVNode(f, { ref: "scaffoldTreeControls", isReady: n.isReady, "show-colour-picker": s.enableColourPicker, onObjectSelected: s.objectSelected, onObjectHovered: s.objectHovered, onDrawerToggled: s.drawerToggled }, null, 8, ["isReady", "show-colour-picker", "onObjectSelected", "onObjectHovered", "onDrawerToggled"]) ]), _: 1 }, 8, ["visible"]), createBaseVNode("div", N5, [ createVNode(g, { ref: "primitiveControls", createData: n.createData, viewingMode: n.viewingMode, usageConfig: t.usageConfig, onPrimitivesUpdated: s.primitivesUpdated }, null, 8, ["createData", "viewingMode", "usageConfig", "onPrimitivesUpdated"]) ]), n.timeVarying ? (openBlock(), createBlock(h6, { key: 3, ref: "sliderPopover", width: "max-content", visible: n.hoverVisibilities[5].value, content: "Move the slider to animate the region", placement: "top", teleported: false, trigger: "manual", "popper-class": "scaffold-popper top-popper non-selectable" }, { reference: withCtx(() => [ n.timeVarying ? (openBlock(), createElementBlock("div", { key: 0, class: normalizeClass(["time-slider-container", [n.minimisedSlider ? "minimised" : "", n.sliderPosition]]) }, [ createVNode(w, { type: "card" }, { default: withCtx(() => [ createVNode(v, { label: "Animate scaffold" }, { default: withCtx(() => [ createVNode(y, { class: "tab-content" }, { default: withCtx(() => [ n.isPlaying ? (openBlock(), createBlock(p, { key: 0, icon: "pause", class: "icon-button video-button", onClick: e[10] || (e[10] = (S) => s.play(false)) })) : (openBlock(), createBlock(p, { key: 1, icon: "play", class: "video-button icon-button", onClick: e[11] || (e[11] = (S) => s.play(true)) })), createVNode(u, { min: 0, max: n.timeMax, "model-value": n.currentTime / 100 * n.timeMax, step: 0.1, "tooltip-class": "time-slider-tooltip", class: "slider", "format-tooltip": s.formatTooltip, marks: n.timeStamps, onInput: e[12] || (e[12] = (S) => s.timeChange(S)) }, null, 8, ["max", "model-value", "format-tooltip", "marks"]) ]), _: 1 }) ]), _: 1 }), createVNode(v, { label: "Animation data" }, { default: withCtx(() => [ createVNode(y, { class: "tab-content" }, { default: withCtx(() => [ createBaseVNode("div", B5, [ e[33] || (e[33] = createTextVNode(" Original duration: ")), createBaseVNode("div", U5, toDisplayString(n.orginalDuration), 1) ]), createBaseVNode("div", z5, [ e[34] || (e[34] = createTextVNode(" Animation duration: ")), createBaseVNode("div", V5, toDisplayString(n.animateDuration), 1) ]), createBaseVNode("div", k5, [ e[35] || (e[35] = createTextVNode(" Playback speed ")), createVNode(x, { teleported: true, "model-value": n.currentSpeed, placeholder: "Select", class: "scaffold-select-box speed", "popper-class": "scaffold_viewer_dropdown", onChange: e[13] || (e[13] = (S) => s.speedChanged(S)) }, { default: withCtx(() => [ (openBlock(true), createElementBlock(Fragment, null, renderList(n.playSpeed, (S) => (openBlock(), createBlock(m, { key: S.value, label: S.label, value: S.value }, null, 8, ["label", "value"]))), 128)) ]), _: 1 }, 8, ["model-value"]) ]) ]), _: 1 }) ]), _: 1 }) ]), _: 1 }) ], 2)) : createCommentVNode("", true) ]), _: 1 }, 8, ["visible"])) : createCommentVNode("", true), createBaseVNode("div", G5, [ createVNode(h6, { visible: n.hoverVisibilities[0].value, content: "Zoom in", width: "max-content", placement: "left", teleported: false, trigger: "manual", "popper-class": "scaffold-popper left-popper non-selectable", ref: "zoomInPopover" }, { reference: withCtx(() => [ createVNode(p, { icon: "zoomIn", class: "icon-button zoomIn", onClick: e[14] || (e[14] = (S) => s.zoomIn()), onMouseover: e[15] || (e[15] = (S) => s.showHelpText(0)), onMouseout: e[16] || (e[16] = (S) => s.hideHelpText(0)) }) ]), _: 1 }, 8, ["visible"]), createVNode(h6, { visible: n.hoverVisibilities[1].value, content: "Zoom out", placement: "top-end", width: "max-content", teleported: false, trigger: "manual", "popper-class": "scaffold-popper popper-zoomout non-selectable", ref: "zoomOutPopover" }, { reference: withCtx(() => [ createVNode(p, { icon: "zoomOut", class: "icon-button zoomOut", onClick: e[17] || (e[17] = (S) => s.zoomOut()), onMouseover: e[18] || (e[18] = (S) => s.showHelpText(1)), onMouseout: e[19] || (e[19] = (S) => s.hideHelpText(1)) }) ]), _: 1 }, 8, ["visible"]), createVNode(h6, { visible: n.hoverVisibilities[2].value, placement: "top", teleported: false, trigger: "manual", width: "max-content", "popper-class": "scaffold-popper non-selectable", ref: "zoomFitPopover" }, { reference: withCtx(() => [ createVNode(p, { icon: "fitWindow", class: "icon-button fitWindow", onClick: e[20] || (e[20] = (S) => s.fitWindow()), onMouseover: e[21] || (e[21] = (S) => s.showHelpText(2)), onMouseout: e[22] || (e[22] = (S) => s.hideHelpText(2)) }) ]), default: withCtx(() => [ e[36] || (e[36] = createBaseVNode("div", null, [ createTextVNode(" Fit to "), createBaseVNode("br"), createTextVNode(" window ") ], -1)) ]), _: 1 }, 8, ["visible"]) ]), n.openMapRef ? (openBlock(), createBlock(h6, { key: 4, ref: "open-map-popover", "virtual-ref": n.openMapRef, placement: "top-start", width: "128", teleported: false, trigger: "click", "popper-class": "open-map-popper", "virtual-triggering": "" }, { default: withCtx(() => [ (openBlock(true), createElementBlock(Fragment, null, renderList(t.openMapOptions, (S) => (openBlock(), createBlock(y, { key: S.key }, { default: withCtx(() => [ createVNode(A, { type: "primary", plain: "", onClick: (I) => n.$emit("open-map", S.key) }, { default: withCtx(() => [ createTextVNode(toDisplayString(S.display), 1) ]), _: 2 }, 1032, ["onClick"]) ]), _: 2 }, 1024))), 128)) ]), _: 1 }, 8, ["virtual-ref"])) : createCommentVNode("", true), createVNode(h6, { ref: "backgroundPopover", "virtual-ref": n.backgroundIconRef, placement: "top-start", width: "320", teleported: false, trigger: "click", "popper-class": "background-popper non-selectable h-auto", "virtual-triggering": "" }, { default: withCtx(() => [ createBaseVNode("div", null, [ createVNode(y, { class: "backgroundText" }, { default: withCtx(() => e[37] || (e[37] = [ createTextVNode("Viewing Mode") ])), _: 1 }), createVNode(y, { class: "backgroundControl" }, { default: withCtx(() => [ createBaseVNode("div", H5, [ (openBlock(true), createElementBlock(Fragment, null, renderList(n.viewingModes, (S, I, T) => (openBlock(), createElementBlock(Fragment, { key: I }, [ I === n.viewingMode ? (openBlock(), createElementBlock("span", W5, [ createBaseVNode("b", null, toDisplayString(I), 1) ])) : (openBlock(), createElementBlock("span", { key: 1, class: "viewing-mode-unselected", onClick: (_) => s.changeViewingMode(I) }, toDisplayString(I), 9, j5)) ], 64))), 128)) ]), createVNode(y, { class: "viewing-mode-description" }, { default: withCtx(() => [ createTextVNode(toDisplayString(s.modeDescription), 1) ]), _: 1 }), n.viewingMode === "Annotation" && n.offlineAnnotationEnabled ? (openBlock(), createBlock(y, { key: 0, class: "viewing-mode-description" }, { default: withCtx(() => e[38] || (e[38] = [ createTextVNode(" (Anonymous annotate) ") ])), _: 1 })) : createCommentVNode("", true) ]), _: 1 }), createVNode(y, { class: "backgroundSpacer" }), createVNode(y, { class: "backgroundText" }, { default: withCtx(() => e[39] || (e[39] = [ createTextVNode("Organs display") ])), _: 1 }), createVNode(y, { class: "backgroundControl" }, { default: withCtx(() => [ createVNode(R, { modelValue: n.colourRadio, "onUpdate:modelValue": e[23] || (e[23] = (S) => n.colourRadio = S), class: "scaffold-radio", onChange: e[24] || (e[24] = (S) => s.setColour(n.colourRadio, true)) }, { default: withCtx(() => [ createVNode(M, { value: true }, { default: withCtx(() => e[40] || (e[40] = [ createTextVNode("Colour") ])), _: 1 }), createVNode(M, { value: false }, { default: withCtx(() => e[41] || (e[41] = [ createTextVNode("Greyscale") ])), _: 1 }) ]), _: 1 }, 8, ["modelValue"]) ]), _: 1 }), createVNode(y, { class: "backgroundSpacer" }), createVNode(y, { class: "backgroundText" }, { default: withCtx(() => e[42] || (e[42] = [ createTextVNode("Outlines display") ])), _: 1 }), createVNode(y, { class: "backgroundControl" }, { default: withCtx(() => [ createVNode(R, { modelValue: n.outlinesRadio, "onUpdate:modelValue": e[25] || (e[25] = (S) => n.outlinesRadio = S), class: "scaffold-radio", onChange: e[26] || (e[26] = (S) => s.setOutlines(n.outlinesRadio, true)) }, { default: withCtx(() => [ createVNode(M, { value: true }, { default: withCtx(() => e[43] || (e[43] = [ createTextVNode("Show") ])), _: 1 }), createVNode(M, { value: false }, { default: withCtx(() => e[44] || (e[44] = [ createTextVNode("Hide") ])), _: 1 }) ]), _: 1 }, 8, ["modelValue"]) ]), _: 1 }), createVNode(y, { class: "backgroundSpacer" }), createVNode(y, { class: "backgroundText" }, { default: withCtx(() => e[45] || (e[45] = [ createTextVNode(" Change background ") ])), _: 1 }), createVNode(y, { class: "backgroundChooser" }, { default: withCtx(() => [ (openBlock(true), createElementBlock(Fragment, null, renderList(n.availableBackground, (S) => (openBlock(), createElementBlock("div", { key: S, class: normalizeClass([ "backgroundChoice", S, S == n.currentBackground ? "active" : "" ]), onClick: (I) => s.backgroundChangeCallback(S) }, null, 10, $5))), 128)) ]), _: 1 }) ]) ]), _: 1 }, 8, ["virtual-ref"]), createBaseVNode("div", { class: normalizeClass(["settings-group", { open: n.drawerOpen, close: !n.drawerOpen }]) }, [ t.showOpenMapButton ? (openBlock(), createBlock(y, { key: 0 }, { default: withCtx(() => [ createVNode(h6, { visible: n.hoverVisibilities[3].value, content: "Open new map", placement: "right", teleported: false, trigger: "manual", width: "max-content", "popper-class": "scaffold-popper right-popper non-selectable", ref: "openMapPopover" }, { reference: withCtx(() => [ t.enableOpenMapUI && t.openMapOptions.length > 0 ? (openBlock(), createBlock(p, { key: 0, ref: "openMapRef", icon: "openMap", class: "icon-button open-map-button", onMouseover: e[27] || (e[27] = (S) => s.showHelpText(3)), onMouseout: e[28] || (e[28] = (S) => s.hideHelpText(3)) }, null, 512)) : createCommentVNode("", true) ]), _: 1 }, 8, ["visible"]) ]), _: 1 })) : createCommentVNode("", true), t.showLocalSettings ? (openBlock(), createBlock(y, { key: 1 }, { default: withCtx(() => [ createVNode(h6, { visible: n.hoverVisibilities[4].value, content: "Change background color", placement: "right", width: "max-content", teleported: false, trigger: "manual", "popper-class": "scaffold-popper right-popper non-selectable", ref: "settingsPopover" }, { reference: withCtx(() => [ createVNode(p, { ref: "backgroundIconRef", icon: "changeBckgd", class: "icon-button", onMouseover: e[29] || (e[29] = (S) => s.showHelpText(4)), onMouseout: e[30] || (e[30] = (S) => s.hideHelpText(4)) }, null, 512) ]), _: 1 }, 8, ["visible"]) ]), _: 1 })) : createCommentVNode("", true) ], 2) ], 512), [ [vShow, t.displayUI && !n.isTransitioning] ]) ])), [ [L, n.loading] ]); } var Q5 = mr(O5, [["render", Z5], ["__scopeId", "data-v-b5c791a7"]]); export { Q5 as ScaffoldVuer }; /*! Bundled license information: @abi-software/scaffoldvuer/dist/scaffoldvuer.js: (** * @vue/shared v3.5.13 * (c) 2018-present Yuxi (Evan) You and Vue contributors * @license MIT **) (*! Element Plus Icons Vue v2.3.1 *) (** * @license * Copyright 2010-2021 Three.js Authors * SPDX-License-Identifier: MIT *) */ //# sourceMappingURL=@abi-software_scaffoldvuer.js.map