UNPKG

cve-connector

Version:
956 lines 1.27 MB
var Vg = Object.defineProperty; var VA = Object.getOwnPropertySymbols; var qg = Object.prototype.hasOwnProperty, Rg = Object.prototype.propertyIsEnumerable; var qA = (A, g, e) => g in A ? Vg(A, g, { enumerable: !0, configurable: !0, writable: !0, value: e }) : A[g] = e, I = (A, g) => { for (var e in g || (g = {})) qg.call(g, e) && qA(A, e, g[e]); if (VA) for (var e of VA(g)) Rg.call(g, e) && qA(A, e, g[e]); return A; }; var E = (A, g, e) => new Promise((n, C) => { var w = (l) => { try { o(e.next(l)); } catch (M) { C(M); } }, D = (l) => { try { o(e.throw(l)); } catch (M) { C(M); } }, o = (l) => l.done ? n(l.value) : Promise.resolve(l.value).then(w, D); o((e = e.apply(A, g)).next()); }); import { Logger as h, Config as hg, PixelStreaming as og } from "@epicgames-ps/lib-pixelstreamingfrontend-ue5.3"; import { PixelStreamingApplicationStyle as _g, Application as $g } from "@epicgames-ps/lib-pixelstreamingfrontend-ui-ue5.3"; const AB = [ "featureselect", "featurehover", "measurefinished", "sequencepause", "sequenceplay", "sequencestop", "timechange" ], gB = /^(\d+)\.(\d+)\.(\d+)-(\d+)\.(\d+)\.(\d+)$/, BB = "$1-$2-$3T$4:$5:$6"; let c = document.getElementById("app"); function jA(A, g) { const e = eB(A); if (!e) { H("message", { Action: A, Data: g }); return; } e === "timechange" ? g = g.replace( gB, BB ) : e === "yaw" && (g = Number(g)); const n = new CustomEvent(e, { detail: g }); c == null || c.dispatchEvent(n); } function H(A, g) { const e = new CustomEvent(A, { detail: g }); c == null || c.dispatchEvent(e); } function NA(A) { const g = new ErrorEvent("error", { message: A }); c == null || c.dispatchEvent(g); } function _(A, g) { c == null || c.addEventListener(A, g); } function eB(A) { if (AB.includes(A)) return A; switch (A) { case "MouseClick": return "mouseclick"; case "ViewDirectionChanged": return "yaw"; case "WalkthroughPathPlayTime": return "roam"; default: return null; } } function $(A, g) { c == null || c.removeEventListener(A, g); } function nB(A) { c = A; } const fB = `/* Container */\r cve-player {\r cursor: pointer;\r display: block;\r height: 100%;\r position: relative;\r width: 100%;\r z-index: 0;\r }\r \r /* Medias */\r .cve-media-wrapper {\r position: relative;\r }\r .cve-media-wrapper video {\r height: 100%;\r width: 100%;\r }\r `; let nA = null; const CB = (A, g = 62.5, e = !1) => (...n) => { nA && clearTimeout(nA), e && A(...n), nA = setTimeout(() => { e || A(...n), nA = null; }, g); }, lg = CB((...A) => E(null, null, function* () { if (!(v != null && v.isConnected)) return; const [g, e] = A, n = (g != null ? g : v.matchMakerURL).replace(/\/$/, ""), C = e != null ? e : v.applicationName; if (!n || !C) return; if (/,/.test(n)) { const l = n.split(",").map((K) => ZA(K, C, !0)), M = yield Promise.any(l); M && v.setAttribute("signaling-url", M); return; } const w = `${n}/GetPixelStreamingInstance?ApplicationName=${C}`, D = v.getAttribute("data-source"); if (w === D) { oA(); return; } v.setAttribute("data-source", w); const o = yield ZA(n, C).catch(NA); o && v.setAttribute("signaling-url", o); })); function ZA(A, g, e = !1) { return E(this, null, function* () { if (A = A.replace(/\/$/, ""), !g || !A) throw new Error("Invalid Match Maker Origin Or Appilication Name"); try { const n = `${A}/GetPixelStreamingInstance?ApplicationName=${g}`, w = yield (yield fetch(n)).json(); if (w.Code === "1" || w.Code === "2") { if (e) throw new Error("No Avaliable Instance!"); return PB(A, g); } if (!w.Data) throw new Error("Get Pixel Streaming Instance Failed!"); if (w.Code === "3") throw new Error(w.Data); return w.Data; } catch (n) { throw n; } }); } function PB(A, g) { return new Promise((e) => { setTimeout(() => { ZA(A, g).then(e); }, 1e3); }); } const wB = `cve-player {\r align-items: center;\r display: flex;\r justify-content: center;\r }\r \r .cve-media-wrapper {\r aspect-ratio: 16 / 9;\r }\r \r @media screen and (max-aspect-ratio: 16 / 9) {\r .cve-media-wrapper {\r width: 100%;\r }\r }\r @media screen and (min-aspect-ratio: 16 / 9) {\r .cve-media-wrapper {\r height: 100%;\r }\r }\r `; let AA = null; function zg() { const A = v == null ? void 0 : v.aspectRatio; return typeof A == "string" ? A.replace(/\s/g, "").split("/").length > 1 : !1; } function vB(A) { AA = A; } function RA() { if (!AA) return; const A = v == null ? void 0 : v.aspectRatio; if (typeof A == "string") { const g = A.replace(/\s/g, "").split("/"), e = zg(); if (u == null || u.classList.toggle("fixed-size", e), e) { const n = Number(g[0]), C = Number(g[1]); QB(n, C); return; } } AA.textContent = ` .cve-media-wrapper { height: 100%; width: 100%; } `; } function QB(A = 16, g = 9) { if (!AA) return; const e = /aspect-ratio: (\d+) \/ (\d+)/g, n = `aspect-ratio: ${A} / ${g}`; AA.textContent = wB.replace(e, n); } let DA, v; class DB extends HTMLElement { constructor() { super(), rB(), v = this, nB(this), DA == null || DA(this); } get applicationName() { var g; return (g = this.getAttribute("application-name")) != null ? g : ""; } set applicationName(g) { this.setAttribute("application-name", g); } get aspectRatio() { var g; return (g = this.getAttribute("aspect-ratio")) != null ? g : "auto"; } set aspectRatio(g) { this.setAttribute("aspect-ratio", g); } attributeChangedCallback(g, e, n) { switch (g) { case "application-name": case "matchmaker-url": { lg(); break; } case "signaling-url": { oA(); break; } case "aspect-ratio": { RA(); break; } case "oncommand": case "onfeaturehover": case "onfeatureselect": case "onmessage": case "onmouseclick": case "onroam": case "onsequencepause": case "onsequenceplay": case "onsequencestop": case "onstart": case "onstop": case "ontimechange": case "onyaw": { const C = g.replace(/^on/, ""); typeof n == "function" ? this.addEventListener(C, n) : typeof e == "function" && this.removeEventListener(C, e); break; } case "volume": { f("SetVolume", n); break; } } } connectedCallback() { const g = document.createElement("style"); g.id = "cve-common-style", g.textContent = fB; const e = document.createElement("style"); e.id = "cve-specific-style", e.textContent = ` .cve-media-wrapper { height: 100%; width: 100%; } `, this.append(g, e), vB(e), oA(), RA(); } disconnectedCallback() { iA(); } get height() { return Number(this.getAttribute("height")); } set height(g) { this.setAttribute("height", g.toFixed(0)); } get matchMakerURL() { var g; return (g = this.getAttribute("matchmaker-url")) != null ? g : ""; } set matchMakerURL(g) { this.setAttribute("matchmaker-url", g); } static get observedAttributes() { return [ "application-name", "aspect-ratio", "matchmaker-url", "oncommand", "onfeaturehover", "onfeatureselect", "onmessage", "onmouseclick", "onroam", "onsequencepause", "onsequenceplay", "onsequencestop", "onstart", "onstop", "onyaw", "signaling-url", "volume" ]; } set oncommand(g) { this.addEventListener("command", g); } set onfeaturehover(g) { this.addEventListener("featurehover", g); } set onfeatureselect(g) { this.addEventListener("featureselect", g); } set onmessage(g) { this.addEventListener("message", g); } set onmouseclick(g) { this.addEventListener("mouseclick", g); } set onroam(g) { this.addEventListener("roam", g); } set onsequencepause(g) { this.addEventListener("sequencepause", g); } set onsequenceplay(g) { this.addEventListener("sequenceplay", g); } set onsequencestop(g) { this.addEventListener("sequencestop", g); } set onstart(g) { this.addEventListener("start", g); } set onstop(g) { this.addEventListener("stop", g); } set ontimechange(g) { this.addEventListener("timechange", g); } set onyaw(g) { this.addEventListener("yaw", g); } get ready() { return this.hasAttribute("ready"); } set ready(g) { this.toggleAttribute("ready", g); } get signalingURL() { var g; return (g = this.getAttribute("signaling-url")) != null ? g : ""; } set signalingURL(g) { this.setAttribute("signaling-url", g); } get volume() { const g = this.getAttribute("volume"); return Number(typeof g != "string" ? 0.3 : g); } set volume(g) { this.setAttribute("volume", g.toFixed(1)); } get width() { return Number(this.getAttribute("width")); } set width(g) { this.setAttribute("width", g.toFixed(0)); } } function vf(A) { const g = "cve-player"; DA = A, customElements.get(g) || customElements.define(g, DB); } const tB = ["MouseClick", "timechange", "ViewDirectionChanged", "Walk", "WalkthroughPathPlayTime"]; h.SetLoggerVerbosity(-1); const V = new hg({ initialSettings: { AutoPlayVideo: !1, AutoConnect: !1, HoveringMouse: !0, MatchViewportRes: !0, MouseInput: !0, StartVideoMuted: !0, SuppressBrowserKeys: !1, WaitForStreamer: !0, PreferredCodec: "H264 level-asymmetry-allowed=1;packetization-mode=1;profile-level-id=42001f" }, useUrlParams: !1 }); let t = null, W = null, cg = sB, u = null; function rB() { t == null || t.disconnect(), t = null, W = null, u = null; } function oA(A) { var w; if (iA(), !(v != null && v.isConnected)) return; const g = A != null ? A : v.signalingURL, e = g !== "", n = e ? g.replace(/^http/, "ws") : void 0; if (V.setSettings({ AutoPlayVideo: e, AutoConnect: e, ss: n }), h.Warning("Signaling URL", n || "undefined"), t) { t.reconnect(); return; } const C = cg(V); u = C.videoElementParent, W = document.createElement("div"), W.className = "cve-media-wrapper", W.appendChild(u), v.appendChild(W), t = C.pixelStreaming, u == null || u.classList.toggle("fixed-size", zg()), (w = C == null ? void 0 : C.callback) == null || w.call(C), lB(); } function sB(A) { const g = document.createElement("div"); return { pixelStreaming: new og(A, { videoElementParent: g }), videoElementParent: g }; } function iA() { v && (t == null || t.disconnect(), v.ready = !1); } function YA(A) { const g = JSON.parse(A), e = /^(\{|\[)|(\]|\})$/; return typeof g.Data == "string" && e.test(g.Data) && (g.Data = JSON.parse(g.Data)), g; } function aB() { t == null || t.reconnect(); } function oB(A, g) { const e = A.UID; t == null || t.addResponseEventListener(e, (n) => { const C = YA(n); (C == null ? void 0 : C.UID) === e && (g(C), t == null || t.removeResponseEventListener(e)); }), h.Warning("CVE Command", JSON.stringify(A)), t == null || t.emitUIInteraction(A); } function lB() { t && (t.addEventListener("playStream", () => { H("start", Date.now()); }), t.addEventListener("playStreamError", () => { NA("Play Stream Error"); }), t.addEventListener("playStreamRejected", () => { H("stop", "Play Stream Rejected"); }), t.addEventListener("streamerListMessage", (A) => { const g = A.data.messageStreamerList.ids, e = V.getSettingOption("PreferredCodec"); if (g.length > 1 && V.setOptionSettingValue("StreamerId", g[0]), e.options.length > 1) { const n = e.options.length - 1; V.setOptionSettingValue("PreferredCodec", e.options[n]); } }), t.addEventListener("webRtcConnected", () => { v && (v.ready = !0); }), t.addResponseEventListener("message", (A) => { const g = YA(A); g.Action ? (jA(g.Action, g.Data), tB.includes(g.Action) ? h.Info(g.Action, JSON.stringify(g.Data), 0) : h.Warning(g.Action, JSON.stringify(g.Data))) : H("message", g); })); } function Qf(A) { cg = A; } const SA = /* @__PURE__ */ new Map(); let L = null; function zB(A) { const g = YA(A.data); if (g.Action) { jA(g.Action, g.Data); return; } if (H("message", g), !g.UID) return; const e = SA.get(g.UID); e && (e(g), SA.delete(g.UID)); } function cB(A, g) { !(A.Command || A.Console) || !A.UID || (SA.set(A.UID, g), L == null || L.send(JSON.stringify(A))); } function Df(A) { window.uews = L = new WebSocket(A), L.onmessage = zB, L.onerror = () => { NA("Web Socket Error"); }, L.onclose = () => { H("stop", "Web Socket Closed"); }, L.onopen = () => { H("start", Date.now()); }; } const OA = /* @__PURE__ */ new Map(); function IB(A) { const g = /^(\{|\[)|(\]|\})$/; if (typeof A.Data == "string" && g.test(A.Data) && (A.Data = JSON.parse(A.Data)), A.Action) { jA(A.Action, A.Data); return; } if (H("message", A), !A.UID) return; const e = OA.get(A.UID); e && (e(A), OA.delete(A.UID)); } function MB(A, g) { window.ue && (!A.UID || !(A.Command || A.Console) || (OA.set(A.UID, g), window.ue.interface.web2ue(JSON.stringify(A)))); } function tf() { window.ue && (window.ue.interface.ue2web = IB); } function x(A, g) { return Mg({ Console: g ? A + " " + g : A, UID: Ig() }); } function Ig() { let g = 16; const e = "0123456789ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz".split(""), n = []; g = g || e.length; for (let C = 0; C < 8; C++) n[C] = e[0 | Math.random() * g]; return n.join(""); } function f(A, g) { return Mg({ Command: A, Data: { Parameters: g }, UID: Ig() }); } function Mg(A) { return new Promise( (g, e) => { H("command", A), window.ue ? MB(A, g) : window.uews ? cB(A, g) : t ? oB(A, g) : e({ Result: "[Error] Failed to get UE host!" }); } ); } const xA = { addDecal: (A, g, e) => f("AddDecal", { Tag: A, URL: g, XMax: e[2], XMin: e[0], YMax: e[3], YMin: e[1] }), delete: (A, g = !1) => f("DeleteActorByTag", { IncludeChildren: g, Tag: A }), hide: (A, g = !1) => f("HideActorByTag", { IncludeChildren: g, Tag: A }), show: (A, g = !1) => f("ShowActorByTag", { IncludeChildren: g, Tag: A }) }, i = { addMultiView: (A) => f("AddMultiView", A), deleteSightline: (A) => f("DeleteIntervisibilityAnalysis", A), deleteSkyline: () => f("StopSkylineAnalysis"), deleteViewshed: (A) => f("DeleteViewshedAnalysis", A), drawSightline: () => f("StartIntervisibilityAnalysis"), drawSkyline: () => f("StartSkylineAnalysis"), drawViewshed: () => f("StartViewshedAnalysis"), refreshMultiView: () => f("RefreshMultiView"), removeMultiView: (A) => f("RemoveMultiView", A), startMultiView: (A) => f("StartMultiViewAnalysis", { Tags: A }), stopMultiView: () => f("StopMultiViewAnalysis") }, y = { addArcgisLayer: (A) => f("AddArcGISWmtsLayer", A), addCustomLayer: ({ EPSG: A = "3857", Format: g = "image/jpeg", Id: e, GroupId: n, Index: C, Layer: w = "", RequestHeaders: D, Style: o = "default", Subdomains: l, TileMatrixSetId: M = "", TileMatrixSetLabelPrefix: K = "", Url: mA }) => f("AddWmtsLayer", { EPSG: A, Format: g, Id: e, GroupId: n, Index: C, Layer: w, RequestHeaders: D, Style: o, Subdomains: l, TileMatrixSetId: M, TileMatrixSetLabelPrefix: K, Url: mA }), addMapboxLayer: (A) => f("AddMapboxWmtsLayer", A), addTiandituLayer: (A) => f("AddTianDiTuWmtsLayer", A), config: ({ GeographicEPSG: A = "4326", IsBigScene: g = !1, IsOriginLocationInProjectedCRS: e, OriginCenter: n, ProjectedEPSG: C = "4549" }) => f("SetGeoReferencingParameters", { IsBigScene: g, GeographicEPSG: A, IsOriginLocationInProjectedCRS: e, OriginCenter: n, ProjectedEPSG: C }), create3dTiles: (A, g, e = 16) => f("Create3DTiles", { Id: A, Url: g, MaximumScreenSpaceError: e }), delete3dTiles: (A) => f("Delete3Dtiles", { Id: A }), deleteAll: () => f("DeleteAllWmtsLayer"), deleteLayer: (A) => f("DeleteWmtsLayer", A), deleteLayerGroup: (A) => f("DeleteWmtsLayerByGroupId", A), hide3dTiles: (A) => f("Hide3Dtiles", { Id: A }), hideAll: () => f("HideAllWmtsLayer"), hideLayer: (A) => f("HideWmtsLayer", A), hideLayerGroup: (A) => f("HideWmtsLayerByGroupId", A), hideOsgb: (A) => f("HideOsgb", { Id: A }), loadOsgb: (A, g, e = 1.5, n = [0, 0, 0]) => f("LoadOsgb", { Id: A, OsgbDirectoryName: g, LodScale: e, Offset: n }), setCesiumTerrainLayer: (A) => f("SetTerrainLayerByCesiumIon", A), setCustomLayer: (A) => f("ChangeWmtsLayer", A), setHeaders: (A, g) => f("ChangeRequestHeaders", { Id: A, RequestHeaders: g }), setLayerIndex: (A, g) => f("ChangeWmtsLayerIndex", { Id: A, Index: g }), setTerrainLayer: (A) => f("SetTerrainLayerByUrl", A), show3dTiles: (A) => f("Show3Dtiles", { Id: A }), showAll: () => f("ShowAllWmtsLayer"), showLayer: (A) => f("ShowWmtsLayer", A), showLayerGroup: (A) => f("ShowWmtsLayerByGroupId", A), showOsgb: (A) => f("ShowOsgb", { Id: A }), toggleDebug: (A, g) => f("ChangeDebugMessages", { Id: A, ShowDebugMessage: g }), unloadOsgb: (A) => f("UnloadOsgb", { Id: A }) }, cA = { loadStreamLevels: (A, g = !0, e = !0, n = !1) => f("LoadStreamLevels", { LevelNames: A, UnloadOtherStreamLevels: g, MakeVisibleAfterLoad: e, ShouldBlockOnLoad: n }), openLevel: (A, g) => f("OpenLevel", { MainLevelName: A, StreamLevelNames: g }), restartLevel: () => x("RestartLevel", ""), unloadStreamLevels: (A, g = !1) => f("UnloadStreamLevels", { LevelNames: A, ShouldBlockOnLoad: g }) }, BA = { focus: (A) => f("FocusById", { Id: A }), load: (A, g, e) => f("Load", { GroupId: e, Id: g, Path: A }), unload: (A) => f("UnloadById", { Id: A }), unloadAll: () => f("UnloadAll"), unloadByGroup: (A) => f("UnloadByGroupId", { GroupId: A }) }, IA = { addTag: (A, g, e) => f("AddPointTag", I({ Key: g, Value: e }, A)), create: (A) => f("CreatePoint", A), delete: (A) => f("DeletePoint", A), hide: (A) => f("HidePoint", A), removeTag: (A, g) => f("RemovePointTag", I({ Key: g }, A)), removeAllTags: (A) => f("RemovePointAllTags", A), select: (A) => f("SelectPoint", A), show: (A) => f("ShowPoint", A), unselect: () => f("UnselectPoint"), update: (A) => f("UpdatePoint", A) }, MA = { addTag: (A, g, e) => f("AddPolygonTag", I({ Key: g, Value: e }, A)), create: (A) => f("CreatePolygon", A), delete: (A) => f("DeletePolygon", A), hide: (A) => f("HidePolygon", A), removeTag: (A, g) => f("RemovePolygonTag", I({ Key: g }, A)), removeAllTags: (A) => f("RemovePolygonAllTags", A), select: (A) => f("SelectPolygon", A), show: (A) => f("ShowPolygon", A), unselect: () => f("UnselectPolygon"), update: (A) => f("UpdatePolygon", A) }, U = { addTag: (A, g, e) => f("AddPolylineTag", I({ Key: g, Value: e }, A)), create: (A) => f("CreatePolyline", A), delete: (A) => f("DeletePolyline", A), hide: (A) => f("HidePolyline", A), hideWithAnimateAndDuration: (A, g, e) => f("HidePolyline", I({ Animate: g, AnimateDuration: e }, A)), hideWithAnimateAndSpeed: (A, g, e) => f("HidePolyline", I({ Animate: g, AnimateSpeed: e }, A)), removeTag: (A, g) => f("RemovePolylineTag", I({ Key: g }, A)), removeAllTags: (A) => f("RemovePolylineAllTags", A), select: (A) => f("SelectPolyline", A), show: (A) => f("ShowPolyline", A), showWithAnimateAndDuration: (A, g, e) => f("ShowPolyline", I({ Animate: g, AnimateDuration: e }, A)), showWithAnimateAndSpeed: (A, g, e) => f("ShowPolyline", I({ Animate: g, AnimateSpeed: e }, A)), unselect: () => f("UnselectPolyline"), update: (A) => f("UpdatePolyline", A) }, EA = { addTag: (A, g, e) => f("AddPolymeshTag", I({ Key: g, Value: e }, A)), create: (A) => f("CreatePolymesh", A), delete: (A) => f("DeletePolymesh", A), hide: (A) => f("HidePolymesh", A), removeTag: (A, g) => f("RemovePolymeshTag", I({ Key: g }, A)), removeAllTags: (A) => f("RemovePolymeshAllTags", A), select: (A) => f("SelectPolymesh", A), show: (A) => f("ShowPolymesh", A), unselect: () => f("UnselectPolymesh"), update: (A) => f("UpdatePolymesh", A) }, JA = { jumpTo: (A) => f("JumpToSeconds", A), pause: (A = !1) => f("PauseSequence", A), play: (A) => f("PlaySequence", A), stop: () => f("StopSequence") }, XA = { mute: () => f("Mute"), setVolume: (A) => f("SetVolume", A), unmute: () => f("Unmute") }, EB = /^(\d)(\d)(\d)(\d)-(0?)(\d+)-(0?)(\d+)T(0?)(\d+):(0?)(\d+):(0?)(\d+)\.(0?)(\d+)Z$/, JB = { dd: "$7$8", d: "$8", hh: "$9$10", h: "$10", MM: "$5$6", M: "$6", mm: "$11$12", m: "$12", ss: "$13$14", s: "$14", S: "$16", yyyy: "$1$2$3$4", yyy: "$2$3$4", yy: "$3$4", y: "$4" }; function Eg(A, g) { return Object.entries(JB).forEach(([e, n]) => { g = g.replace(new RegExp(e), n); }), A.toJSON().replace(EB, g); } const lA = { disableRealtime: () => f("DisableRealtime"), enableRealtime: () => f("EnableRealtime"), setDateTime: (A) => f("SetDateTime", Eg(A, "yyyy-MM-dd hh:mm:ss")) }; var O = /* @__PURE__ */ ((A) => (A[A.SpringArm = 0] = "SpringArm", A[A.GIS = 1] = "GIS", A[A.Free = 2] = "Free", A[A.Editor = 3] = "Editor", A))(O || {}); const m = { addPath: ({ Delays: A, Durations: g, Positions: e }) => f("MakeWalkthroughPath", { Position: e.map(({ Location: n, Rotation: C }) => ({ Location: `(X=${n[0]},Y=${n[1]},Z=${n[2]})`, Rotation: `(P=${C[1]},Y=${C[2]},R=${C[0]})` })), StayDurations: A, WalkthroughTimes: g }), changeViewMode: (A) => f("ChangeViewMode", A), deletePath: (A) => f("DeleteWalkthroughPath", A), flyTo: ({ Location: A, Distance: g, UseCurrentDistance: e, UseCurrentRotation: n, Rotation: C = [] }, w) => f("FlyTo", { Distance: g, Duration: w, Location: `(X=${A[0]},Y=${A[1]},Z=${A[2]})`, Rotation: `(P=${C[1]},Y=${C[2]},R=${C[0]})`, UseCurrentDistance: e, UseCurrentRotation: n }), flyToBookmark: (A, g) => f("FlyToBookmark", { Bookmark: A, Duration: g }), getView: () => E(null, null, function* () { const A = yield f("GetView"), g = A.Data, [e, n, C] = g.Location.replace(/(X|Y|Z)=/g, "").split(" "), [w, D, o] = g.Rotation.replace(/(P|Y|R)=/g, "").split(" "); return { Type: "Command", UID: A.UID, Command: "GetView", Data: { Location: [Number(e), Number(n), Number(C)], Rotation: [Number(o), Number(w), Number(D)], Distance: g.ArmLength }, Result: !0 }; }), playPath: (A) => f("PlayWalkthroughPath", A), replayPath: (A) => f("ReplayWalkthroughPath", A), resetView: (A) => f("ResetView", A), seekPath: (A, g) => f("SeekWalkthroughPath", { Time: g, PathId: A }), stopPath: (A) => f("StopWalkthroughPath", A) }, Jg = { changeByPreset: (A, g = 0) => f("ChangeWeatherByPreset", { Duration: g, Preset: A }), changeBySettings: (A, g = 0) => f("ChangeWeatherBySettings", I({ Duration: g }, A)) }; function rf(A, g) { return { Coordinates: g, Style: A }; } function sf(A, g) { return { Coordinates: g, Style: A }; } function af(A, g) { return { Coordinates: g, Style: A }; } function of(A, g, e) { return { Coordinates: g, Height: e, Style: A }; } function lf(A) { return x( "PixelStreaming.WebRTC.DegradationPreference", A ); } function zf(A) { return x("r.DynamicRes.OperationMode", A ? "2" : A === void 0 ? "1" : "0"); } function cf(A, g) { const e = `${A}x${g}f`; return x("r.setRes", e); } function If(A) { A < 1 && (A = window.devicePixelRatio * 100); const g = A.toFixed(); return x("r.ScreenPercentage", g); } const kB = { "&": "amp", "<": "lt", ">": "gt", '"': "quot", "'": "#39", "/": "#x2F" }, yB = (A) => String(A).replace(/[&<>"'\/\\]/g, (g) => `&${kB[g]};`), mB = (A) => ({ tabIndex: "tabindex", className: "class", readOnly: "readonly" })[A] || A; function B(A, g, ...e) { g = g || {}; const n = [...e]; if (typeof A == "function") return g.children = n, A(g); const C = ["svg", "g", "path"].includes(A) ? document.createElementNS("http://www.w3.org/2000/svg", A) : document.createElement(A); for (let [w, D] of Object.entries(g)) w = yB(mB(w)), w.startsWith("on") && w.toLowerCase() in window ? C.addEventListener(w.toLowerCase().substring(2), D) : w === "ref" ? D(C) : w === "style" ? Object.assign(C.style, D) : D === !0 ? C.setAttribute(w, w) : D !== !1 && D != null ? C.setAttribute(w, D) : D === !1 && C.removeAttribute(w); for (; n.length; ) { const w = n.shift(); Array.isArray(w) ? n.push(...w) : C.appendChild( w.nodeType == null ? document.createTextNode(w.toString()) : w ); } return C; } const J = (A) => { const g = document.createElement("slot"); return g.append(...A.children), g; }, hA = {}, uB = { set: TB }; new Proxy({}, uB); const dB = {}, HB = {}; function TB(A, g, e, n) { return dB[g].forEach((C) => LB(C, e)), Reflect.set(A, g, e, n); } function LB(A, g) { const [e, n] = A.split("@"), C = hA[e]; if (!C.dataset.signal) { delete hA[e]; return; } const w = (HB[A] || "${self}").replace(/\$\{self\}/g, g); if (n === "text") { C.textContent = w; return; } if (n === "value" && C.tagName === "INPUT") { C.value = g; return; } C.setAttribute(n, w); } function z(A) { let g = null; return /* @__PURE__ */ B( "section", { className: "debug-rows" + (A.opened || window.uews || window.ue ? "" : " collapsed"), ref: (e) => { g = e; } }, /* @__PURE__ */ B( "div", { className: "debug-header", onclick: () => { g == null || g.classList.toggle("collapsed"); } }, A.desc ), A.slot ); } const ZB = [120.01168722430221, 30.249110392135236, 120.0139057862743, 30.251019653237694], SB = "