@kosdev-code/kos-ui-sdk 2.0.25 → 2.0.27
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/core/core/kosCore.d.ts.map +1 -1
- package/core/core/registration/model-registration.d.ts +1 -0
- package/core/core/registration/model-registration.d.ts.map +1 -1
- package/index.cjs +76 -64
- package/index.cjs.map +1 -1
- package/index.d.cts +1 -0
- package/index.d.ts +1 -0
- package/index.d.ts.map +1 -1
- package/index.js +3629 -3013
- package/index.js.map +1 -1
- package/models/index.d.ts +1 -0
- package/models/index.d.ts.map +1 -1
- package/models/models/browser-router/browser-router-model.d.ts.map +1 -1
- package/models/models/canvas-dispatcher/canvas-dispatcher-model.d.ts +25 -0
- package/models/models/canvas-dispatcher/canvas-dispatcher-model.d.ts.map +1 -0
- package/models/models/canvas-dispatcher/canvas-dispatcher-registration.d.ts +89 -0
- package/models/models/canvas-dispatcher/canvas-dispatcher-registration.d.ts.map +1 -0
- package/models/models/canvas-dispatcher/index.d.ts +5 -0
- package/models/models/canvas-dispatcher/index.d.ts.map +1 -0
- package/models/models/canvas-dispatcher/services/canvas-dispatcher-services.d.ts +8 -0
- package/models/models/canvas-dispatcher/services/canvas-dispatcher-services.d.ts.map +1 -0
- package/models/models/canvas-dispatcher/services/index.d.ts +2 -0
- package/models/models/canvas-dispatcher/services/index.d.ts.map +1 -0
- package/models/models/canvas-dispatcher/types/index.d.ts +64 -0
- package/models/models/canvas-dispatcher/utils/encode-frame.d.ts +14 -0
- package/models/models/canvas-dispatcher/utils/encode-frame.d.ts.map +1 -0
- package/models/models/canvas-dispatcher/utils/renderers/base/canvas-2d-renderer.d.ts +37 -0
- package/models/models/canvas-dispatcher/utils/renderers/base/canvas-2d-renderer.d.ts.map +1 -0
- package/models/models/canvas-dispatcher/utils/renderers/base/gradient-base-renderer.d.ts +2 -0
- package/models/models/canvas-dispatcher/utils/renderers/base/gradient-base-renderer.d.ts.map +1 -0
- package/models/models/canvas-dispatcher/utils/renderers/base/video-base-renderer.d.ts +69 -0
- package/models/models/canvas-dispatcher/utils/renderers/base/video-base-renderer.d.ts.map +1 -0
- package/models/models/canvas-dispatcher/utils/renderers/base/webgl-base-renderer.d.ts +51 -0
- package/models/models/canvas-dispatcher/utils/renderers/base/webgl-base-renderer.d.ts.map +1 -0
- package/models/models/canvas-dispatcher/utils/renderers/drop-renderer.d.ts +58 -0
- package/models/models/canvas-dispatcher/utils/renderers/drop-renderer.d.ts.map +1 -0
- package/models/models/canvas-dispatcher/utils/renderers/gradient-renderer.d.ts +17 -0
- package/models/models/canvas-dispatcher/utils/renderers/gradient-renderer.d.ts.map +1 -0
- package/models/models/canvas-dispatcher/utils/renderers/image-renderer.d.ts +13 -0
- package/models/models/canvas-dispatcher/utils/renderers/image-renderer.d.ts.map +1 -0
- package/models/models/canvas-dispatcher/utils/renderers/matrix-renderer.d.ts +36 -0
- package/models/models/canvas-dispatcher/utils/renderers/matrix-renderer.d.ts.map +1 -0
- package/models/models/canvas-dispatcher/utils/renderers/mixins/one-shot-renderer-mixin.d.ts +5 -0
- package/models/models/canvas-dispatcher/utils/renderers/mixins/one-shot-renderer-mixin.d.ts.map +1 -0
- package/models/models/canvas-dispatcher/utils/renderers/renderer-factory.d.ts +25 -0
- package/models/models/canvas-dispatcher/utils/renderers/renderer-factory.d.ts.map +1 -0
- package/models/models/canvas-dispatcher/utils/renderers/solid-color-renderer.d.ts +17 -0
- package/models/models/canvas-dispatcher/utils/renderers/solid-color-renderer.d.ts.map +1 -0
- package/models/models/canvas-dispatcher/utils/renderers/sweep-renderer.d.ts +48 -0
- package/models/models/canvas-dispatcher/utils/renderers/sweep-renderer.d.ts.map +1 -0
- package/models/models/canvas-dispatcher/utils/renderers/swirl-renderer.d.ts +13 -0
- package/models/models/canvas-dispatcher/utils/renderers/swirl-renderer.d.ts.map +1 -0
- package/models/models/canvas-renderer/canvas-renderer-model.d.ts +45 -0
- package/models/models/canvas-renderer/canvas-renderer-model.d.ts.map +1 -0
- package/models/models/canvas-renderer/canvas-renderer-registration.d.ts +87 -0
- package/models/models/canvas-renderer/canvas-renderer-registration.d.ts.map +1 -0
- package/models/models/canvas-renderer/index.d.ts +4 -0
- package/models/models/canvas-renderer/index.d.ts.map +1 -0
- package/models/models/canvas-renderer/types/index.d.ts +8 -0
- package/models/utils/core-registration-manager.d.ts.map +1 -1
- package/models/utils/extension-manager.d.ts +3 -1
- package/models/utils/extension-manager.d.ts.map +1 -1
- package/package.json +2 -2
- package/ui/features/canvas/components/canvas-streamer/canvas-streamer.d.ts +15 -0
- package/ui/features/canvas/components/canvas-streamer/canvas-streamer.d.ts.map +1 -0
- package/ui/features/canvas/components/canvas-streamer/index.d.ts +2 -0
- package/ui/features/canvas/components/canvas-streamer/index.d.ts.map +1 -0
- package/ui/features/canvas/components/index.d.ts +2 -0
- package/ui/features/canvas/components/index.d.ts.map +1 -0
- package/ui/features/canvas/components/rgb-332-visualizer/rgb-332-visualizer.d.ts +5 -0
- package/ui/features/canvas/components/rgb-332-visualizer/rgb-332-visualizer.d.ts.map +1 -0
- package/ui/features/canvas/hooks/canvas-dispatcher/index.d.ts +3 -0
- package/ui/features/canvas/hooks/canvas-dispatcher/index.d.ts.map +1 -0
- package/ui/features/canvas/hooks/canvas-dispatcher/use-canvas-dispatcher.d.ts +14 -0
- package/ui/features/canvas/hooks/canvas-dispatcher/use-canvas-dispatcher.d.ts.map +1 -0
- package/ui/features/canvas/hooks/canvas-dispatcher/with-canvas-dispatcher.d.ts +9 -0
- package/ui/features/canvas/hooks/canvas-dispatcher/with-canvas-dispatcher.d.ts.map +1 -0
- package/ui/features/canvas/hooks/use-gradient-renderer.d.ts +14 -0
- package/ui/features/canvas/hooks/use-gradient-renderer.d.ts.map +1 -0
- package/ui/features/canvas/hooks/use-image-renderer.d.ts +22 -0
- package/ui/features/canvas/hooks/use-image-renderer.d.ts.map +1 -0
- package/ui/features/canvas/hooks/use-solid-color-renderer.d.ts +11 -0
- package/ui/features/canvas/hooks/use-solid-color-renderer.d.ts.map +1 -0
- package/ui/features/canvas/hooks/use-streamable-renderer.d.ts +17 -0
- package/ui/features/canvas/hooks/use-streamable-renderer.d.ts.map +1 -0
- package/ui/features/canvas/hooks/use-sweep-renderer.d.ts +32 -0
- package/ui/features/canvas/hooks/use-sweep-renderer.d.ts.map +1 -0
- package/ui/features/canvas/hooks/use-swirl-renderer.d.ts +22 -0
- package/ui/features/canvas/hooks/use-swirl-renderer.d.ts.map +1 -0
- package/ui/features/canvas/hooks/use-video-renderer.d.ts +24 -0
- package/ui/features/canvas/hooks/use-video-renderer.d.ts.map +1 -0
- package/ui/features/canvas/index.d.ts +2 -0
- package/ui/features/canvas/index.d.ts.map +1 -0
- package/ui/features/canvas/utils/preview-decoder.d.ts +29 -0
- package/ui/features/canvas/utils/preview-decoder.d.ts.map +1 -0
- package/ui/features/index.d.ts +2 -0
- package/ui/features/index.d.ts.map +1 -0
- package/ui/index.d.ts +1 -0
- package/ui/index.d.ts.map +1 -1
package/index.cjs
CHANGED
|
@@ -1,80 +1,80 @@
|
|
|
1
|
-
"use strict";var kl=Object.defineProperty;var Pl=(e,t,s)=>t in e?kl(e,t,{enumerable:!0,configurable:!0,writable:!0,value:s}):e[t]=s;var a=(e,t,s)=>(Pl(e,typeof t!="symbol"?t+"":t,s),s);Object.defineProperty(exports,Symbol.toStringTag,{value:"Module"});const T=require("loglevel"),w=require("mobx"),m=require("robot3"),me=require("date-fns"),M=require("@emotion/react/jsx-runtime"),xl=require("@emotion/styled"),Nl=require("react-dom"),Ie=require("@emotion/react"),h=require("react"),un=require("mobx-react-lite"),Fl=require("@use-gesture/react"),Ls="method",hn="topic",We="url",Ut="request-id",ks="response-id",Do="status",ge="dst-addr",gn="src-addr",ie="type",So="ordered",Ao="tracker",fn="Content-Type",mn="Cache-Control",pn="requestId",yn=process.env.KOS_LOGIN_URL||"http://localhost",bn=process.env.KOS_APP_PORT||"8080",Ul=`${yn}:${bn}`,ds="{MODEL_ID}";var jt=(e=>(e.SEND="/ws/log/msg/send",e.RECEIVED="/ws/log/msg/receive",e))(jt||{}),wn=(e=>(e.MSG_RECEIVE="/mock/msg/receive",e))(wn||{});const Co="/kos/model/ready/";T.info("Initializing event bus");globalThis.kos=globalThis.kos||{};globalThis.kos.subscriptions=globalThis.kos.subscriptions||{};const L=globalThis.kos.subscriptions,jl=()=>Symbol("eventKey");function Ro(e){return L[e]&&Object.getOwnPropertySymbols(L[e]).length>0}function j(e,t){const s=jl();return L[e]||(T.debug(`Initializing subscription for ${e}`),L[e]={}),T.debug(`Subscribing to ${e} with id ${s.toString()}`),L[e][s]=t,{count:L[e]?Object.getOwnPropertySymbols(L[e]).length:0,unsubscribe:()=>(T.debug(`Unsubscribing from ${e} with id ${s.toString()}`),L[e]&&L[e][s]&&delete L[e][s],L[e]&&Object.getOwnPropertySymbols(L[e]).length===0&&delete L[e],{count:L[e]?Object.getOwnPropertySymbols(L[e]).length:0})}}function F(e,t,s={}){if(!L[e]||Object.getOwnPropertySymbols(L[e]).length===0)return T.debug(`No subscriptions for ${e}. Not publishing.`),{eventType:e,subscribers:0};const o=Object.getOwnPropertySymbols(L[e]).length;return Object.getOwnPropertySymbols(L[e]).forEach(r=>{if(s.sync){const n=s.sync;T.debug(`Performing sync publish for ${e} with sync id ${n}`),L[e][r]({body:t,headers:s}).then(i=>{T.debug(`Response recieved for ${n}, publishing back to source.`),F(n,i)})}else T.debug(`Performing async publish for ${e}`),L[e][r]({body:t,headers:s})}),{eventType:e,subscribers:o}}function Bl(){T.warn("Resetting event bus"),Object.keys(L).forEach(e=>delete L[e])}const Kl=Object.freeze(Object.defineProperty({__proto__:null,hasEventSubscriptions:Ro,publish:F,reset:Bl,subscribe:j},Symbol.toStringTag,{value:"Module"})),Gl=(e,t=0)=>{if(!+e)return{value:0,scale:"bytes",toString:()=>"0 bytes"};const s=1024,o=t<0?0:t,r=["bytes","KB","MB","GB","TB"],n=Math.floor(Math.log(e)/Math.log(s)),i=parseFloat((e/Math.pow(s,n)).toFixed(o)),c=r[n];return{value:i,scale:c,toString:()=>`${i} ${c}`}};function Lo(e){let t="pending",s;const o=e.then(n=>{t="success",s=n},n=>{t="error",s=n});return{read:()=>{switch(t){case"pending":throw o;case"error":throw s;default:return s}}}}function Ze(){return"xxxxxxxx-xxxx-4xxx-2xxx-xxxxxxxxxxxx".replace(/[xy]/g,function(e){const t=Math.random()*16|0;return(e=="x"?t:t&3|8).toString(16)})}function Hl(e,t){t.forEach(s=>{Object.getOwnPropertyNames(s.prototype).forEach(o=>{const r=Object.getOwnPropertyDescriptor(s.prototype,o);Object.defineProperty(e.prototype,o,r)})})}function Vl(e,t){const s=e??[],o=t??[];return s.length!==o.length?!1:s.every((r,n)=>r===o[n])}const ko=(e,t)=>{const s=e.map(n=>n.id);return t.map(n=>n.id).filter(n=>!s.includes(n))},Yl=({container:e,onAddItem:t,onRemoveItem:s,idMapper:o=r=>r})=>r=>{const n=r.map(o),c=ko(n,e.data).map(s).filter(Boolean);e.removeAll(c);const l=n.map(t).filter(Boolean);e.addAll(l)},zl=({container:e,onAddItem:t,onRemoveItem:s,idMapper:o=r=>r})=>r=>{const n=r.map(o);ko(n,e.models).forEach(s),n.forEach(t)},ql=({items:e,onAddItem:t,onRemoveItem:s,idMapper:o=r=>r})=>r=>{const n=r.map(o);ko(n,e).forEach(s),n.forEach(t)},Wl=(e,t="parent-")=>{let s=e;return s.startsWith(t)&&(s=s.replace(t,"")),s},Ar=new Intl.RelativeTimeFormat(void 0,{numeric:"auto"}),Cr=[{amount:60,name:"seconds"},{amount:60,name:"minutes"},{amount:24,name:"hours"},{amount:7,name:"days"},{amount:4.34524,name:"weeks"},{amount:12,name:"months"},{amount:Number.POSITIVE_INFINITY,name:"years"}];function vn(e){let t=(e.getTime()-Date.now())/1e3;for(let s=0;s<=Cr.length;s++){const o=Cr[s];if(Math.abs(t)<o.amount)return Ar.format(Math.round(t),o.name);t/=o.amount}return Ar.format(Math.round(t),"years")}const Po=e=>e%4===0&&e%100!==0||e%400===0,xo=(e,t)=>[31,Po(e)?29:28,31,30,31,30,31,31,30,31,30,31][t],Mn=(e,t)=>{const s=new Date(e),o=e.getDate();return s.setDate(1),s.setMonth(s.getMonth()+t),s.setDate(Math.min(o,xo(s.getFullYear(),s.getMonth()))),s},En=(e,t)=>{const s=new Date(e);return s.setDate(s.getDate()+t),s},je="en-US",_n={short:{year:"numeric",month:"2-digit",day:"2-digit"},medium:{year:"numeric",month:"short",day:"2-digit"},long:{year:"numeric",month:"long",day:"numeric"},full:{year:"numeric",month:"long",day:"numeric",weekday:"long"}},In={short:{hour:"2-digit",minute:"2-digit",hour12:!0},medium:{hour:"2-digit",minute:"2-digit",second:"2-digit",hour12:!0},long:{hour:"2-digit",minute:"2-digit",second:"2-digit",hour12:!0,timeZoneName:"short"},full:{hour:"2-digit",minute:"2-digit",hour12:!0,timeZoneName:"long"}},Tn=(e,{dateStyle:t="short",locales:s=je}={dateStyle:"short",locales:je})=>{const o=t==="short"?_n.short:{dateStyle:t};return new Intl.DateTimeFormat(s,o).format(e)},$n=(e,{locales:t=je,timeStyle:s="short"}={locales:je,timeStyle:"short"})=>{const o=In[s];return new Intl.DateTimeFormat(t,o).format(e)},On=(e,{dateStyle:t="short",locales:s=je,timeStyle:o="short"}={dateStyle:"short",locales:je,timeStyle:"short"})=>{const r={...t&&_n[t],...o&&In[o]};return new Intl.DateTimeFormat(s,r).format(e)},Zl=Object.freeze(Object.defineProperty({__proto__:null,addDaysToDate:En,addMonthsToDate:Mn,formatDate:Tn,formatDateSince:vn,formatDateTime:On,formatTime:$n,getDaysInMonth:xo,isLeapYear:Po},Symbol.toStringTag,{value:"Module"}));function Dn(e,t,s=300){let o;return(...r)=>{clearTimeout(o),o=setTimeout(()=>{t.apply(e,r)},s)}}class Sn{constructor(t={}){a(this,"flags",{});this.flags=t}isFeatureEnabled(t){return!!this.flags[t]}enableFeature(t){this.flags[t]=!0}disableFeature(t){this.flags[t]=!1}toggleFeature(t){this.flags[t]=!this.flags[t]}updateFlags(t){this.flags={...this.flags,...t}}}window.KosFeatureFlags=window.KosFeatureFlags??new Sn;const Jl=window.KosFeatureFlags,ae=(e=null)=>(e||window.location.search.replace("?","")).split("&").map(t=>{const[s,o]=t.split("=");return[s,decodeURIComponent(o||"")]}).reduce((t,[s,o])=>(t[s]=o,t),{}),An=(e,t,s)=>{s/=100;const o=t*Math.min(s,1-s)/100,r=n=>{const i=(n+e/30)%12,c=s-o*Math.max(Math.min(i-3,9-i,1),-1);return Math.round(255*c).toString(16).padStart(2,"0")};return`#${r(0)}${r(8)}${r(4)}`},Cn=e=>{const s=new RegExp("hsl\\((\\d+),\\s+(\\d+)\\%,\\s+(\\d+)\\%\\)").exec(e);if(!s)throw Error("Invalid HSL string");return An(parseInt(s[1]),parseInt(s[2]),parseInt(s[3]))},Rn=(e,t)=>getComputedStyle(e).getPropertyValue(t),Ql=(e,t)=>Cn(Rn(e,t)),Ln="studio.tools.preview",Xl="studio.relax.store.validation",kn="studio.log.debug",Pn="studio.log.info",ed={profiles:[Ln]};var dn;const td=((dn=globalThis.getKosConfig)==null?void 0:dn.call(globalThis))||JSON.stringify(ed),xn=JSON.parse(td);globalThis.kosConfig=xn;const No=xn,Nn=()=>No.profiles||[],ao=e=>Nn().includes(e),sd=()=>No.logging||!1,od=(e,t)=>{const s={...e};return s.id&&delete s.id,s},co=(e,t,s=od)=>{const o=s(e,t);w.runInAction(()=>{Object.assign(t,o)})},Zs=new Map,Fn={addToDeletionQueue:(e,t)=>{const s=Zs.get(e)||[];s.push(t),Zs.set(e,s)},cancelDeletion:e=>{const t=Zs.get(e);t&&t.forEach(s=>{clearTimeout(s)})}},rd=()=>{const e=ao(kn),t=ao(Pn);return e?"DEBUG":t?"INFO":void 0},Un=()=>{const e=ae(),t=rd(),o=e.kosLogLevel??t??window.kosLogLevel??process.env.KOS_LOG_LEVEL;return o||"WARN"},jn=()=>window.kosMessageLogging||process.env.KOS_MESSAGE_LOGGING==="true",Bn=()=>window.kosMessageStudioLogging||process.env.KOS_MESSAGE_STUDIO_LOGGING==="true",Kn="ws-log",nd=T.methodFactory,Gn=jn(),id=Bn();T.methodFactory=function(e,t,s){const o=nd(e,t,s);return function(r,n){var l;const i=s?String(s):"",c=i?`[${String(i).substring(i.lastIndexOf(":")+1)}] | `:"[root] | ";o(`${c}${r}`,n||""),(l=globalThis==null?void 0:globalThis.kosConfig)!=null&&l.logging&&globalThis.kosLog&&(s!==Kn||Gn&&id)&&globalThis.kosLog(`UI: ${c}${r}`)}};let Hn=Un();T.setLevel(Hn);window.setKosLogLevel=e=>{Hn=e,T.setLevel(e)};const us=T.getLogger(Kn);window.enableKosMessageLog=()=>{us.setLevel(T.levels.INFO)};window.disableKosMessageLog=()=>{us.setLevel(T.levels.ERROR)};Gn?window.enableKosMessageLog():window.disableKosMessageLog();const ad=["color: black","display: block","background-color: lightgreen","padding: 4px","margin: 0","text-shadow: 0 1px 0 rgba(0, 0, 0, 0.3)","box-shadow: 0 1px 0 rgba(255, 255, 255, 0.4) inset, 0 5px 3px -5px rgba(0, 0, 0, 0.5), 0 -13px 5px -10px rgba(255, 255, 255, 0.4) inset","font-weight: bold"].join(";"),cd=["color: black","display: block","padding: 4px","background-color: yellow","margin: 0","text-shadow: 0 1px 0 rgba(0, 0, 0, 0.3)","box-shadow: 0 1px 0 rgba(255, 255, 255, 0.4) inset, 0 5px 3px -5px rgba(0, 0, 0, 0.5), 0 -13px 5px -10px rgba(255, 255, 255, 0.4) inset","font-weight: bold"].join(";"),qt=e=>t=>{T.getLevel()<=e&&t()},f={...T,ifDebug:qt(T.levels.DEBUG),ifInfo:qt(T.levels.INFO),ifWarn:qt(T.levels.WARN),ifError:qt(T.levels.ERROR),getLogger:e=>T.getLogger(`kos::${e}`),createLogger:({name:e,group:t})=>T.getLogger(`${t?`${t}:`:"kos"}::${e}`),wsSend:(...e)=>{const t=String(e).replace(/\n/g,"\\n");us.info(`%c⬆ ${t}`,ad)},wsReceive:(...e)=>{const t=String(e).replace(/\n/g,"\\n");us.info(`%c⬇ ${t}`,cd)}},ld=f.createLogger({name:"kos-dependency-manager"});class dd{constructor(){a(this,"_usedByCache",new Map);a(this,"_usesCache",new Map)}add(t,s){Fn.cancelDeletion(s);const o=this._usedByCache.get(s)||[];o.includes(t)||o.push(t),this._usedByCache.set(s,o);const r=this._usesCache.get(t)||[];r.includes(s)||r.push(s),this._usesCache.set(t,r)}remove(t,s){const o=this._usedByCache.get(s)||[];this._usedByCache.set(s,o.filter(n=>n!==t));const r=this._usesCache.get(t)||[];this._usesCache.set(t,r.filter(n=>n!==s))}canDestroy(t){const s=this._usedByCache.get(t);return s!=null&&s.length?(ld.info(`Model ${t} is still used by: ${s.join(", ")}`),!1):!0}clear(){this._usedByCache.clear(),this._usesCache.clear()}}var p=(e=>(e.CREATING="creating",e.CREATED="created",e.INITIALIZING="initializing",e.INITIALIZED="initialized",e.LOADING="loading",e.LOADED="loaded",e.ONLINE="online",e.READYING="readying",e.READY="ready",e.READY_FAILED="ready_failed",e.RESETTING="resetting",e.RESET="reset",e.OFFLINE="offline",e.UNLOADING="unloading",e.UNLOADED="unloaded",e.FAILED="failed",e.INACTIVE="inactive",e.ACTIVE="active",e.ACTIVATING="activating",e.DEACTIVATING="deactivating",e))(p||{}),O=(e=>(e.CREATE="create",e.INITIALIZE="init",e.LOAD="load",e.READY="ready",e.GO_ONLINE="go_online",e.GO_OFFLINE="go_offline",e.RESET="go_offline",e.UNLOAD="unload",e.FAILED="failed",e.GO_ACTIVE="go_active",e.GO_INACTIVE="go_inactive",e.TIMEOUT="timeout",e))(O||{});const Rr=f.createLogger({name:"kos-model-cache"});class ud{constructor(t=[]){a(this,"_modelsById",w.observable.map(new Map));a(this,"_toDelete",new Map);a(this,"_preloaded",[]);a(this,"_isPreloaded",!1);this.preloadKeys=t}get models(){return Array.from(this._modelsById.values()).filter(t=>!this._toDelete.has(t.modelId))}getModelById(t){if(t&&!this._toDelete.has(t))return this._modelsById.get(t)}addModel(t){const s=this.getModelById(t.modelId)||t;return this._modelsById.set(s.modelId,s),s}removeModel(t){this._modelsById.delete(t),this._toDelete.delete(t)}hasModel(t){return!!t&&this._modelsById.has(t)&&!this._toDelete.has(t)}restoreFromDeleteCache(t){if(t&&this._toDelete.has(t)){const s=this._toDelete.get(t);this._toDelete.delete(t),this._modelsById.set(t,s)}}markForDeletion(t){this._modelsById.delete(t.modelId),this._toDelete.set(t.modelId,t)}preload(t){return this._isPreloaded?(Rr.debug("Returning cached preloaded models"),this._preloaded):(this._preloaded=this.preloadKeys.map(s=>(Rr.debug(`Preloading model: ${typeof s=="string"?s:s.modelType}`),t(s))).filter(s=>!!s),this._isPreloaded=!0,this._preloaded)}}const Js=new Map,Lr=new Map,Qs=new Map,Xs=new Map,Fo=(e,t)=>{Vn[e]=t},Vn={indexExtension:{registerIndexExtension:(e,t)=>{const s=Xs.get(e)||{};Object.assign(s,t),Xs.set(e,t)},loadIndexExtensions:e=>Xs.get(e)||{}},loader:{registerLoader:(e,t)=>{Lr.set(e,t)},executeLoader:async(e,t)=>{const s=Lr.get(e);if(s)return await s(t)}},propertyMapper:{registerPropertyMapper:(e,t)=>{Qs.set(e,t)},hasMapper:e=>Qs.has(e),executeMapper:(e,t,s)=>{const o=Qs.get(e);return o?o(t,s):""}},dataMapper:{registerDataMapper:(e,t)=>{const s=Js.get(e)||[];s.push(t),Js.set(e,s)},executeMapper:async(e,t,s)=>{const o=Js.get(e);if(!o)return{};const r={};for(const n of o){const i=await n(t,s);Object.assign(r,i)}return r}}},C=Vn;function Yn(e,t){return`${Co}${e}${t?`/${t}`:`/${e}`}`}function zn(e){return`${Co}${e}`}var x=(e=>(e.INIT="init",e.LOAD="load",e.READY="ready",e.ACTIVATE="activate",e.ONLINE="online",e))(x||{});const hd=Object.freeze(Object.defineProperty({__proto__:null,DependencyLifecycle:x},Symbol.toStringTag,{value:"Module"}));function kr(e){const t=[];return new Promise((s,o)=>{for(const{condition:r,onMatch:n}of e){const i=w.when(r,()=>{t.forEach(c=>c());try{n==null||n(),s()}catch(c){o(c)}});t.push(i)}})}const G=Symbol("SubscriptionHandlers"),k=Symbol("DependencyModels"),bt=Symbol("FutureService"),wt=Symbol("ChildModels"),vt=Symbol("ParentModel"),Mt=Symbol("LogConfig"),rs=Symbol("ReferenceConfig"),qn=Symbol("KosModelSymbol"),$e=Symbol("ModelEffects"),ce=(e,t)=>{e[wt]=e[wt]||{},e[wt][t]=!0},Se=e=>`{PROP_${String(e)}}`,gd=e=>`{PROP_${String(e)}}`,fd=Se("kosParentId"),Ps=e=>t=>{t[vt]=t[vt]||{};const s=(e==null?void 0:e.parentId)||fd;t[vt]={parentId:s}},Be=({value:e,modelId:t,modelData:s})=>{let o=e;if(Array.isArray(o))return[...e];if(typeof o!="string"&&typeof o!="object")return o;if(typeof o=="object")o=Object.keys(o).reduce((r,n)=>(r[n]=Be({value:o[n],modelId:t,modelData:s}),r),{});else if(typeof o=="string"){const r=new RegExp(".*({PROP_(.+)})");let n=o!=null&&o.includes(ds)?o.replace(ds,t):o;const i=n.match(r);if(i&&s&&(Object.getOwnPropertyNames(s).includes(i[2])||Object.getOwnPropertyNames(Object.getPrototypeOf(s)).includes(i[2]))){const c=s[i[2]];n=c?n.replace(i[1],c):void 0}return n}else return o;return o},md=f.createLogger({name:"kos-model"});function pd(e,t,s){var n;const o=(n=e[vt])==null?void 0:n.parentId;if(!o)return;const r=Be({value:o,modelData:s,modelId:t});r&&typeof r=="string"&&P.setParentContext(t,r)}function yd(e){const t=e[bt];t&&Object.entries(t).forEach(([s,{handler:o}])=>{e[s]=o})}function bd(e,t){const s=e[k]||{};Object.entries(s).forEach(([o,r])=>{const n=Be({value:r.id||r.modelType,modelData:e,modelId:t}),i=Object.entries((r==null?void 0:r.options)||{}).reduce((c,[l,d])=>(c[l]=Be({value:d,modelData:e,modelId:t}),c),{});if(typeof n=="string"){if(!r.lazy){const c=_.getInstance().modelManager.createModelInstance(r.modelType,n,i);e[o]=c.data}_.getInstance().modelManager.addDependency(t,n)}})}function wd(e){try{return w.makeAutoObservable(e)}catch(t){return md.error("Failed to make observable:",t),e}}const vd={construct(e,t){var c;const[s,o={}]=t,r=P.createContext(s);pd(e,s,o);const n=f.createLogger({name:e.prototype.modelTypeId,group:((c=e[Mt])==null?void 0:c.group)??"kos-model"}),i=new e(s,o,{logger:n,kosContext:r});return yd(i),bd(i,s),wd(i)}};function D(e){return t=>{var o,r;const s=t;return s.prototype.modelTypeId=e,s.prototype[qn]=!0,(o=s.prototype)[G]??(o[G]={}),(r=s.prototype)[k]??(r[k]={}),f.ifDebug(()=>{f.debug(`Registering model with id ${e}`)}),new Proxy(s,vd)}}const Md=({modelType:e})=>t=>{Ps()(t),D(e)(t)};function Ed(e,t,s){const o=s.value;s.value=function(...r){const n=P.getContext(this.id);return r.push(n),o.apply(this,r)}}const _d=({group:e}={group:""})=>t=>{t[Mt]=t[Mt]||{},t[Mt]={group:e}};function Wn(e){return(t,s,o)=>{t[$e]=t[$e]||{},t[$e][s]={dependencies:e==null?void 0:e.dependencies,value:o.value},o.value=function(){throw new Error(`Method ${s} cannot be called directly.`)}}}const Id=e=>(t,s)=>{t[rs]=t[rs]||{},t[rs][s]=e},Bt=({modelType:e,id:t,options:s,lifecycle:o})=>(r,n)=>{r[k]=r[k]||{},r[k][n]={modelType:e,id:t,options:s,lifecycle:o||x.INIT}},Td=({topic:e,handler:t,websocket:s=!1,condition:o=()=>!0})=>r=>{r[G]=r[G]||{},Array.isArray(e)?e.forEach(n=>{r[G][n]={websocket:s,handler:t,condition:o}}):r[G][e]={websocket:s,handler:Dn(r,w.action(t),200),condition:o}};function R({topic:e,condition:t=(d,u)=>!0,transform:s=d=>d,websocket:o=!1,fos:r=!1,bridge:n=!1,skipParse:i=!1,lifecycle:c,destinationAddress:l}){return(d,u,g)=>{d[G]=d[G]||{},Array.isArray(e)?e.forEach(y=>{d[G][y]={websocket:o,fos:r,bridge:n,handler:g.value,condition:t,transform:s,lifecycle:c,skipParse:i,destinationAddress:l}}):d[G][e]={websocket:o,fos:r,bridge:n,handler:g.value,condition:t,transform:s,lifecycle:c,skipParse:i,destinationAddress:l}}}const Zn=5e3;class $d extends Error{constructor(s,o){super(s);a(this,"model");this.model=o}}const Jn=(e,t,s)=>{let o;return{promise:new Promise((i,c)=>{o=setTimeout(()=>{f.error(`Model ${t.modelId} - ${t.modelTypeName} - ${s} timed out after ${e}ms`),c(new $d(`${t.modelId} - ${t.modelTypeName} - ${s}`,t))},e)}),cancel:()=>{o&&clearTimeout(o)}}},Qn=e=>e.fsm.transitionTo(O.GO_ACTIVE,p.ACTIVE),Xn=e=>e.whenReady(),ei=e=>e.fsm.transitionTo(O.LOAD,p.LOADED),Od=e=>e.fsm.transitionTo(O.UNLOAD,p.UNLOADED),ti=e=>e.fsm.transitionTo(O.INITIALIZE,p.INITIALIZED);var Uo=(e=>(e.ACTIVE="active",e.READY="ready",e.LOAD="load",e.UNLOAD="unload",e.INIT="init",e))(Uo||{});const ns={active:Qn,ready:Xn,load:ei,init:ti},si=(e,t)=>{const s=t.id||t.modelType,o=Be({value:s,modelData:e.modelData,modelId:e.modelId});f.debug(`activating dependent model ${t.modelType} with id ${o}`);const r=Object.keys((t==null?void 0:t.options)||{}).reduce((i,c)=>{const l=t.options[c];return i[c]=Be({value:l,modelData:e.modelData,modelId:e.modelId}),i},{});return{dependentModel:_.getInstance().modelManager.createModelInstance(t.modelType,o,r),dataModelId:o}},oi=(e,t=x.READY)=>{var r;const s=((r=e.modelData)==null?void 0:r[k])||{};return Object.keys(s).length===0?(f.debug(`${e.modelId} has no dependencies. Returning`),[]):Object.keys(s).filter(n=>s[n].lifecycle===t).map(n=>{const i=s[n],{dependentModel:c,dataModelId:l}=si(e,i);e.modelData[n]=c.data,f.debug(`waiting for dependent model ${i.modelType} with id ${l} - waiting for WHENREADY`);const d=async(y,v,b)=>{var E;await((E=y.whenReady)==null?void 0:E.call(y)),f.debug(`dependent model ${v} with id ${b} - READY`)},{promise:u,cancel:g}=Jn(Zn,e,e.status);return Promise.race([d(c.model,i.modelType,l).then(()=>{g()}).catch(y=>{console.error(`Error waiting for dependent model ${i.modelType} with id ${l}:`,y),g()}),u])}).filter(n=>!!n)},ri=async(e,t,s,o)=>{if(f.debug(`Execute lifecycle with ${t.length} models`),t.length===0){f.debug(`${e.modelId} has no children. Returning`);return}if(!s){f.error(`${e.modelId} is not transitioning with a valid target ${s}`);return}const r=t.map(c=>{let l;return ns[s]&&c?l=ns[s](c):(c||f.error("model is undefined. This shouldn't happen"),ns[s]||f.error(`There is no promise in the Transition Map for ${s}`)),{promise:l,modelId:c==null?void 0:c.modelId,model:c,type:c==null?void 0:c.modelTypeName,status:c==null?void 0:c.status}}).filter(c=>c.promise?c.model?!0:(f.error(`No model found ${c.modelId}`),!1):(f.error(`No promise found ${c.modelId}`),!1)),i=(await Promise.allSettled(r.map(c=>{var u;const{promise:l,cancel:d}=Jn(Zn,c.model,c.status);return Promise.race([(u=c.promise)==null?void 0:u.then(()=>{d()}).catch(g=>{f.error(`Model ${c.modelId} - ${c.type} failed to transition to ${s}: ${g.message}`),d()}),l])}))).filter(c=>c.status==="rejected");i.length>0&&f.error(`Model ${e.modelId} had ${i.length} failed child models on ${o}`)},ni=async(e,t,s)=>{await ri(e,e.getChildren().filter(o=>!!o),t,s)},it=async(e,t)=>{const o=(await Promise.allSettled(oi(e,t))).filter(r=>r.status==="rejected");o.length&&(f.error(`There were ${o.length} failed dependent models on ${t}`),f.error(o))},Dd=e=>typeof e.toJSON=="function",Et=e=>e[k]!==void 0,jo=e=>e.revision!==void 0&&e.index!==void 0,ii=e=>{if(e){if(Et(e))return e;if(jo(e))return e.data;if(e instanceof Map||e instanceof w.ObservableMap||e instanceof Set)return Array.from(e.values()).filter(Et);if(Array.isArray(e))return e.filter(Et)}};function Sd(e){const t=`KosModel(${e.modelTypeName}:${e.modelId})`;try{Object.defineProperty(e,Symbol.toStringTag,{value:t,configurable:!0})}catch{e.toString=()=>t}try{Object.defineProperty(e.constructor,"name",{value:`KosModel_${e.modelTypeName}`,configurable:!0})}catch{e.constructor.name=`KosModel_${e.modelTypeName}`}const s=["fsm","effectManager","subscriptionManager","onlineLifecycleManager","companionManager","childResolver","_offlineQueue"];for(const o of s)o in e&&Object.defineProperty(e,o,{enumerable:!1});Object.defineProperty(e,"debugState",{enumerable:!1,configurable:!0,get(){var o,r,n;return{id:e.modelId,type:e.modelTypeName,initialized:e.initialized,loaded:e.loaded,status:e.status,onlineStatus:e.onlineStatus,activeStatus:e.activeStatus,companions:(r=(o=e.companionManager)==null?void 0:o.all())==null?void 0:r.map(i=>i.modelTypeName),children:(n=e.getChildren)==null?void 0:n.call(e).map(i=>i.modelId),effects:!!e.effectManager,subs:!!e.subscriptionManager}}}),Ad(e.modelData,e.modelTypeName,e.modelId,e)}function Ad(e,t,s,o){Object.defineProperty(e,Symbol.toStringTag,{value:`KosModelData(${t}:${s})`,configurable:!0});try{Object.defineProperty(e.constructor,"name",{value:`${t}ModelData`,configurable:!0})}catch{e.constructor.name=`${t}ModelData`}Object.defineProperty(e,"debugState",{enumerable:!1,configurable:!0,get(){var c,l,d;const r=((c=o.getChildren)==null?void 0:c.call(o))||[],n=((l=o.companionManager)==null?void 0:l.all())||[],i=o.modelData[k]||{};return{id:s,type:t,companions:{count:n.length,data:n.map(u=>({type:u.modelTypeName,id:u.modelId}))},dependencies:{count:Object.keys(i).length,data:Object.values(i).map(u=>({id:u.id||u.modelType,type:u.modelType,options:u.options,lifecycle:u.lifecycle}))},children:{count:r.length,data:r.map(u=>({id:u.modelId,type:u.modelTypeName}))},data:((d=e.toJSON)==null?void 0:d.call(e))||{},subs:!!o.subscriptionManager}}}),Object.defineProperty(e,"toJSON",{configurable:!0,enumerable:!1,writable:!0,value:()=>{const r={};for(const n of Object.keys(e))if(!(n.startsWith("_")||typeof e[n]=="function"))try{const i=e[n];Et(i)?r[`[KOS Model] ${n}`]=typeof i.toJSON=="function"?i.toJSON():{id:i.id,type:i.constructor.name}:jo(i)?r[`[KOS Container] ${n}`]=typeof i.toJSON=="function"?i.toJSON():["Container"]:Array.isArray(i)?r[n]=`[Array(${i.length})]`:typeof i=="object"&&i!==null?r[n]=JSON.parse(JSON.stringify(i)):r[n]=i}catch{r[n]="[unreadable]"}return r}})}class Cd{constructor(t){this.model=t}resolve(){const t=new Set([...this.getResolvedDecoratedChildren(),...this.getAdditionalChildren(),...this.model.companionModels.all()]),s=Array.from(t).map(o=>this.model.modelManager.getModelById(o.id||"")).filter(o=>o&&o.status!==p.FAILED).filter(o=>!!o);return s.forEach(o=>{try{P.setParentContext(o.modelId,this.model.modelId)}catch(r){console.error(`Failed to set parent context for ${o.modelId} under ${this.model.modelId}`,r)}}),s}getResolvedDecoratedChildren(){var s;const t=((s=this.model.modelData)==null?void 0:s[wt])||{};return Object.keys(t).map(o=>ii(this.model.modelData[o])).filter(o=>!!o).flat()}getAdditionalChildren(){var t,s;return((s=(t=this.model.modelData)==null?void 0:t.getChildren)==null?void 0:s.call(t))||[]}}class Rd{constructor(t){a(this,"companions",new w.ObservableMap);this.hostModel=t}add(t){this.companions.set(t.modelTypeName,t)}clear(){this.companions.clear()}get(t){return this.companions.get(t)}all(){return[...this.companions.values()]}get data(){return this.companions}}class Ld{constructor(t,s,o,r){a(this,"disposers",[]);this.modelTypeName=t,this.modelId=s,this.modelData=o,this.log=r}setup(){var s;const t=((s=this.modelData)==null?void 0:s[$e])||{};for(const o of Object.keys(t)){const{value:r,dependencies:n,options:i}=t[o],c=r.bind(this.modelData),l=()=>{this.log.info(`Running effect ${o} for ${this.modelTypeName} (${this.modelId})`),w.runInAction(()=>c())},d=n?w.reaction(()=>n(this.modelData),l,{fireImmediately:!!(i!=null&&i.fireImmediately)}):w.autorun(l);this.disposers.push(d)}}disposeAll(){for(const t of this.disposers)try{t()}catch(s){this.log.info(`Failed to dispose effect for ${this.modelId}`,s)}this.disposers=[]}}const kd=f.createLogger({name:"model-active-machine"}),Pd=e=>{const t=m.createMachine(p.INACTIVE,{[p.FAILED]:m.state(m.transition(O.GO_ACTIVE,p.ACTIVATING)),[p.INACTIVE]:m.state(m.transition(O.GO_ACTIVE,p.ACTIVATING)),[p.ACTIVATING]:m.invoke(()=>(e.activeStatus=p.ACTIVATING,e.activate()),m.transition("done",p.ACTIVE,m.action(()=>{e.activeStatus=p.ACTIVE})),m.transition("error",p.FAILED,m.action(()=>{e.activeStatus=p.FAILED}))),[p.ACTIVE]:m.state(m.transition(O.GO_INACTIVE,p.DEACTIVATING)),[p.DEACTIVATING]:m.invoke(()=>(e.activeStatus=p.DEACTIVATING,e.deactivate()),m.transition("done",p.INACTIVE,m.action(()=>{e.activeStatus=p.INACTIVE})),m.transition("error",p.FAILED,m.action(()=>{e.activeStatus=p.FAILED})))});return{service:m.interpret(t,o=>kd.debug(o.machine.current)),machine:t}},Pr=f.createLogger({name:"model-online-machine"}),xd=e=>{const t=m.createMachine(p.OFFLINE,{[p.ONLINE]:m.state(m.transition(O.GO_OFFLINE,p.OFFLINE,m.action(async()=>{await e.offline(),e.onlineStatus=p.OFFLINE}))),[p.OFFLINE]:m.state(m.transition(O.GO_ONLINE,p.ONLINE,m.action(async()=>{Pr.debug(`Going online with model ${e.modelId}`),await e.online(),e.onlineStatus=p.ONLINE,await e.fsm.transitionTo(O.INITIALIZE,p.INITIALIZED)})))}),s=m.interpret(t,o=>Pr.debug(o.machine.current));return{machine:t,service:s}},Nd=e=>{var o;const t=Pd(e).service,s=xd(e).service;return m.createMachine(p.CREATING,{[p.CREATING]:m.state(m.transition(O.CREATE,p.CREATED)),[p.CREATED]:m.state(m.immediate(p.INITIALIZING)),[p.INITIALIZING]:m.invoke(()=>(Y(()=>{e.status=p.INITIALIZING}),e.init()),m.transition("done",p.INITIALIZED,m.action(()=>{e.status=p.INITIALIZED})),m.transition("error",p.FAILED,m.action(()=>{f.error(`Model ${e.modelId} - ${e.modelTypeName} failed to initialize. Transitioning to FAILED state.`),e.status=p.FAILED}))),[p.INITIALIZED]:m.state(m.immediate(p.LOADING)),[p.LOADING]:m.invoke(()=>(Y(()=>{e.status=p.LOADING}),e.load()),m.transition("done",p.LOADED,m.action(()=>{e.status=p.LOADED})),m.transition("error",p.FAILED,m.action(()=>{e.status=p.FAILED}))),[p.LOADED]:m.state(m.immediate(p.READYING),m.transition(O.UNLOAD,p.UNLOADING)),[p.RESETTING]:m.invoke(()=>{var r;return Y(()=>{e.status=p.RESETTING}),(r=e.unload)==null||r.call(e),e.load()},m.transition("done",p.LOADED,m.action(()=>{e.status=p.LOADED}))),[p.READYING]:m.invoke(()=>(Y(()=>{e.status=p.READYING}),e.ready()),m.transition("done",p.READY,m.action(()=>{Y(()=>{e.status=p.READY}),s.send(O.GO_ONLINE)})),m.transition("error",p.FAILED,m.action(()=>{e.status=p.FAILED}))),[p.READY]:m.state(m.transition(O.UNLOAD,p.UNLOADED,m.action((o=e.unload)==null?void 0:o.bind(e))),m.transition(O.RESET,p.RESETTING),m.transition(O.GO_ONLINE,p.READY,m.action(()=>{s.send(O.GO_ONLINE)})),m.transition(O.GO_OFFLINE,p.READY,m.action(()=>{s.send(O.GO_OFFLINE)})),m.transition(O.GO_ACTIVE,p.READY,m.action(()=>{t.send(O.GO_ACTIVE)})),m.transition(O.GO_INACTIVE,p.READY,m.action(()=>{t.send(O.GO_INACTIVE)}))),[p.UNLOADED]:m.state(),[p.FAILED]:m.state()})},Fd=f.createLogger({name:"kos-model-lifecycle"}),Ud=e=>({service:m.interpret(Nd(e),s=>Fd.debug(`state machine for model ${e.modelId}: ${s.machine.current});`))});class jd{constructor(t,s){a(this,"disposer");a(this,"service");this.model=t,this.log=s;const o=Ud(t);this.service=o.service,this.service.send(O.CREATE)}get current(){return this.service.machine.current}async transitionTo(t,s,o=p.FAILED){return this.getTransitionStatusFor(s)===s?(this.log.debug(`Model ${this.model.modelId} already in state ${s}, skipping transition`),Promise.resolve()):(this.log.debug(`Transitioning model ${this.model.modelId} with event ${t} toward target ${s}`),new Promise((n,i)=>{var c;(c=this.disposer)==null||c.call(this),this.disposer=w.when(()=>{const l=this.getTransitionStatusFor(s);return l===s||l===o},()=>{this.getTransitionStatusFor(s)===o?(this.log.error(`Model ${this.model.modelId} entered error state ${o} during transition`),i(new Error(`FSM transition failed for model ${this.model.modelId} with event ${t}`))):(this.log.debug(`Model ${this.model.modelId} reached target state ${s}`),n())}),this.service.send(t)}).finally(()=>{var n;(n=this.disposer)==null||n.call(this),this.disposer=void 0}))}getTransitionStatusFor(t){return[p.ACTIVE,p.INACTIVE].includes(t)?this.model.activeStatus:this.model.status}}class Bd{static create({modelId:t,modelTypeName:s,component:o}){const r=[o??"kos",s,t].filter(Boolean).join(".");return f.createLogger({name:r})}}class Kd{constructor(t){a(this,"queue",[]);this.log=t}enqueue(t){this.queue.push(t)}flush(){if(this.queue.length!==0){this.log.warn(`Processing ${this.queue.length} offline message(s)`);for(const t of this.queue)try{t()}catch(s){this.log.error("Error while processing offline message:",s)}this.queue=[],this.log.info("Offline queue flushed")}}clear(){this.queue=[]}get length(){return this.queue.length}get isEmpty(){return this.queue.length===0}}class Gd{constructor(t,s){a(this,"unsubscribers",[]);this.model=t,this.log=s}register(){const t=this.model.modelId,s=j("/kosCore/online",async()=>{this.log.debug(`Online event received for ${t}, waiting for readiness...`),await this.model.whenReady(),this.log.debug(`${t} is ready — sending GO_ONLINE`),await this.model.fsm.transitionTo(O.GO_ONLINE,p.ONLINE)}),o=j("/kosCore/offline",async()=>{this.log.debug(`Offline event received for ${t} — sending GO_OFFLINE`),await this.model.fsm.transitionTo(O.GO_OFFLINE,p.OFFLINE)});this.unsubscribers.push(s.unsubscribe),this.unsubscribers.push(o.unsubscribe)}dispose(){this.unsubscribers.forEach(t=>t()),this.unsubscribers=[]}}var ai=(e=>(e.GET="GET",e.PUT="PUT",e.POST="POST",e.DELETE="DELETE",e))(ai||{});const ci=({path:e,requestId:t,method:s,destinationAddress:o})=>{let r=`${Ls}:${s}
|
|
1
|
+
"use strict";var Qd=Object.defineProperty;var Xd=(e,t,s)=>t in e?Qd(e,t,{enumerable:!0,configurable:!0,writable:!0,value:s}):e[t]=s;var a=(e,t,s)=>(Xd(e,typeof t!="symbol"?t+"":t,s),s);Object.defineProperty(exports,Symbol.toStringTag,{value:"Module"});const T=require("loglevel"),v=require("mobx"),m=require("robot3"),me=require("date-fns"),M=require("@emotion/react/jsx-runtime"),Po=require("@emotion/styled"),En=require("react-dom"),Ie=require("@emotion/react"),g=require("react"),ko=require("mobx-react-lite"),el=require("@use-gesture/react"),xs="method",In="topic",Je="url",Kt="request-id",Fs="response-id",xo="status",fe="dst-addr",Tn="src-addr",de="type",Fo="ordered",No="tracker",$n="Content-Type",On="Cache-Control",Dn="requestId",Sn=process.env.KOS_LOGIN_URL||"http://localhost",An=process.env.KOS_APP_PORT||"8080",tl=`${Sn}:${An}`,hs="{MODEL_ID}";var Gt=(e=>(e.SEND="/ws/log/msg/send",e.RECEIVED="/ws/log/msg/receive",e))(Gt||{}),Cn=(e=>(e.MSG_RECEIVE="/mock/msg/receive",e))(Cn||{});const Uo="/kos/model/ready/";T.info("Initializing event bus");globalThis.kos=globalThis.kos||{};globalThis.kos.subscriptions=globalThis.kos.subscriptions||{};const L=globalThis.kos.subscriptions,sl=()=>Symbol("eventKey");function jo(e){return L[e]&&Object.getOwnPropertySymbols(L[e]).length>0}function j(e,t){const s=sl();return L[e]||(T.debug(`Initializing subscription for ${e}`),L[e]={}),T.debug(`Subscribing to ${e} with id ${s.toString()}`),L[e][s]=t,{count:L[e]?Object.getOwnPropertySymbols(L[e]).length:0,unsubscribe:()=>(T.debug(`Unsubscribing from ${e} with id ${s.toString()}`),L[e]&&L[e][s]&&delete L[e][s],L[e]&&Object.getOwnPropertySymbols(L[e]).length===0&&delete L[e],{count:L[e]?Object.getOwnPropertySymbols(L[e]).length:0})}}function N(e,t,s={}){if(!L[e]||Object.getOwnPropertySymbols(L[e]).length===0)return T.debug(`No subscriptions for ${e}. Not publishing.`),{eventType:e,subscribers:0};const o=Object.getOwnPropertySymbols(L[e]).length;return Object.getOwnPropertySymbols(L[e]).forEach(r=>{if(s.sync){const n=s.sync;T.debug(`Performing sync publish for ${e} with sync id ${n}`),L[e][r]({body:t,headers:s}).then(i=>{T.debug(`Response recieved for ${n}, publishing back to source.`),N(n,i)})}else T.debug(`Performing async publish for ${e}`),L[e][r]({body:t,headers:s})}),{eventType:e,subscribers:o}}function ol(){T.warn("Resetting event bus"),Object.keys(L).forEach(e=>delete L[e])}const rl=Object.freeze(Object.defineProperty({__proto__:null,hasEventSubscriptions:jo,publish:N,reset:ol,subscribe:j},Symbol.toStringTag,{value:"Module"})),nl=(e,t=0)=>{if(!+e)return{value:0,scale:"bytes",toString:()=>"0 bytes"};const s=1024,o=t<0?0:t,r=["bytes","KB","MB","GB","TB"],n=Math.floor(Math.log(e)/Math.log(s)),i=parseFloat((e/Math.pow(s,n)).toFixed(o)),c=r[n];return{value:i,scale:c,toString:()=>`${i} ${c}`}};function Bo(e){let t="pending",s;const o=e.then(n=>{t="success",s=n},n=>{t="error",s=n});return{read:()=>{switch(t){case"pending":throw o;case"error":throw s;default:return s}}}}function Qe(){return"xxxxxxxx-xxxx-4xxx-2xxx-xxxxxxxxxxxx".replace(/[xy]/g,function(e){const t=Math.random()*16|0;return(e=="x"?t:t&3|8).toString(16)})}function il(e,t){t.forEach(s=>{Object.getOwnPropertyNames(s.prototype).forEach(o=>{const r=Object.getOwnPropertyDescriptor(s.prototype,o);Object.defineProperty(e.prototype,o,r)})})}function al(e,t){const s=e??[],o=t??[];return s.length!==o.length?!1:s.every((r,n)=>r===o[n])}const Ko=(e,t)=>{const s=e.map(n=>n.id);return t.map(n=>n.id).filter(n=>!s.includes(n))},cl=({container:e,onAddItem:t,onRemoveItem:s,idMapper:o=r=>r})=>r=>{const n=r.map(o),c=Ko(n,e.data).map(s).filter(Boolean);e.removeAll(c);const d=n.map(t).filter(Boolean);e.addAll(d)},dl=({container:e,onAddItem:t,onRemoveItem:s,idMapper:o=r=>r})=>r=>{const n=r.map(o);Ko(n,e.models).forEach(s),n.forEach(t)},ll=({items:e,onAddItem:t,onRemoveItem:s,idMapper:o=r=>r})=>r=>{const n=r.map(o);Ko(n,e).forEach(s),n.forEach(t)},ul=(e,t="parent-")=>{let s=e;return s.startsWith(t)&&(s=s.replace(t,"")),s},jr=new Intl.RelativeTimeFormat(void 0,{numeric:"auto"}),Br=[{amount:60,name:"seconds"},{amount:60,name:"minutes"},{amount:24,name:"hours"},{amount:7,name:"days"},{amount:4.34524,name:"weeks"},{amount:12,name:"months"},{amount:Number.POSITIVE_INFINITY,name:"years"}];function Rn(e){let t=(e.getTime()-Date.now())/1e3;for(let s=0;s<=Br.length;s++){const o=Br[s];if(Math.abs(t)<o.amount)return jr.format(Math.round(t),o.name);t/=o.amount}return jr.format(Math.round(t),"years")}const Go=e=>e%4===0&&e%100!==0||e%400===0,Ho=(e,t)=>[31,Go(e)?29:28,31,30,31,30,31,31,30,31,30,31][t],Ln=(e,t)=>{const s=new Date(e),o=e.getDate();return s.setDate(1),s.setMonth(s.getMonth()+t),s.setDate(Math.min(o,Ho(s.getFullYear(),s.getMonth()))),s},Pn=(e,t)=>{const s=new Date(e);return s.setDate(s.getDate()+t),s},Be="en-US",kn={short:{year:"numeric",month:"2-digit",day:"2-digit"},medium:{year:"numeric",month:"short",day:"2-digit"},long:{year:"numeric",month:"long",day:"numeric"},full:{year:"numeric",month:"long",day:"numeric",weekday:"long"}},xn={short:{hour:"2-digit",minute:"2-digit",hour12:!0},medium:{hour:"2-digit",minute:"2-digit",second:"2-digit",hour12:!0},long:{hour:"2-digit",minute:"2-digit",second:"2-digit",hour12:!0,timeZoneName:"short"},full:{hour:"2-digit",minute:"2-digit",hour12:!0,timeZoneName:"long"}},Fn=(e,{dateStyle:t="short",locales:s=Be}={dateStyle:"short",locales:Be})=>{const o=t==="short"?kn.short:{dateStyle:t};return new Intl.DateTimeFormat(s,o).format(e)},Nn=(e,{locales:t=Be,timeStyle:s="short"}={locales:Be,timeStyle:"short"})=>{const o=xn[s];return new Intl.DateTimeFormat(t,o).format(e)},Un=(e,{dateStyle:t="short",locales:s=Be,timeStyle:o="short"}={dateStyle:"short",locales:Be,timeStyle:"short"})=>{const r={...t&&kn[t],...o&&xn[o]};return new Intl.DateTimeFormat(s,r).format(e)},hl=Object.freeze(Object.defineProperty({__proto__:null,addDaysToDate:Pn,addMonthsToDate:Ln,formatDate:Fn,formatDateSince:Rn,formatDateTime:Un,formatTime:Nn,getDaysInMonth:Ho,isLeapYear:Go},Symbol.toStringTag,{value:"Module"}));function jn(e,t,s=300){let o;return(...r)=>{clearTimeout(o),o=setTimeout(()=>{t.apply(e,r)},s)}}class Bn{constructor(t={}){a(this,"flags",{});this.flags=t}isFeatureEnabled(t){return!!this.flags[t]}enableFeature(t){this.flags[t]=!0}disableFeature(t){this.flags[t]=!1}toggleFeature(t){this.flags[t]=!this.flags[t]}updateFlags(t){this.flags={...this.flags,...t}}}window.KosFeatureFlags=window.KosFeatureFlags??new Bn;const gl=window.KosFeatureFlags,ee=(e=null)=>(e||window.location.search.replace("?","")).split("&").map(t=>{const[s,o]=t.split("=");return[s,decodeURIComponent(o||"")]}).reduce((t,[s,o])=>(t[s]=o,t),{}),Kn=(e,t,s)=>{s/=100;const o=t*Math.min(s,1-s)/100,r=n=>{const i=(n+e/30)%12,c=s-o*Math.max(Math.min(i-3,9-i,1),-1);return Math.round(255*c).toString(16).padStart(2,"0")};return`#${r(0)}${r(8)}${r(4)}`},Gn=e=>{const s=new RegExp("hsl\\((\\d+),\\s+(\\d+)\\%,\\s+(\\d+)\\%\\)").exec(e);if(!s)throw Error("Invalid HSL string");return Kn(parseInt(s[1]),parseInt(s[2]),parseInt(s[3]))},Hn=(e,t)=>getComputedStyle(e).getPropertyValue(t),fl=(e,t)=>Gn(Hn(e,t)),Vn="studio.tools.preview",pl="studio.relax.store.validation",Yn="studio.log.debug",zn="studio.log.info",ml={profiles:[Vn]};var _n;const yl=((_n=globalThis.getKosConfig)==null?void 0:_n.call(globalThis))||JSON.stringify(ml),qn=JSON.parse(yl);globalThis.kosConfig=qn;const Vo=qn,Wn=()=>Vo.profiles||[],fo=e=>Wn().includes(e),bl=()=>Vo.logging||!1,vl=(e,t)=>{const s={...e};return s.id&&delete s.id,s},po=(e,t,s=vl)=>{const o=s(e,t);v.runInAction(()=>{Object.assign(t,o)})},eo=new Map,Zn={addToDeletionQueue:(e,t)=>{const s=eo.get(e)||[];s.push(t),eo.set(e,s)},cancelDeletion:e=>{const t=eo.get(e);t&&t.forEach(s=>{clearTimeout(s)})}},wl=()=>{const e=fo(Yn),t=fo(zn);return e?"DEBUG":t?"INFO":void 0},Jn=()=>{const e=ee(),t=wl(),o=e.kosLogLevel??t??window.kosLogLevel??process.env.KOS_LOG_LEVEL;return o||"WARN"},Qn=()=>window.kosMessageLogging||process.env.KOS_MESSAGE_LOGGING==="true",Xn=()=>window.kosMessageStudioLogging||process.env.KOS_MESSAGE_STUDIO_LOGGING==="true",ei="ws-log",Ml=T.methodFactory,ti=Qn(),_l=Xn();T.methodFactory=function(e,t,s){const o=Ml(e,t,s);return function(r,n){var d;const i=s?String(s):"",c=i?`[${String(i).substring(i.lastIndexOf(":")+1)}] | `:"[root] | ";o(`${c}${r}`,n||""),(d=globalThis==null?void 0:globalThis.kosConfig)!=null&&d.logging&&globalThis.kosLog&&(s!==ei||ti&&_l)&&globalThis.kosLog(`UI: ${c}${r}`)}};let si=Jn();T.setLevel(si);window.setKosLogLevel=e=>{si=e,T.setLevel(e)};const gs=T.getLogger(ei);window.enableKosMessageLog=()=>{gs.setLevel(T.levels.INFO)};window.disableKosMessageLog=()=>{gs.setLevel(T.levels.ERROR)};ti?window.enableKosMessageLog():window.disableKosMessageLog();const El=["color: black","display: block","background-color: lightgreen","padding: 4px","margin: 0","text-shadow: 0 1px 0 rgba(0, 0, 0, 0.3)","box-shadow: 0 1px 0 rgba(255, 255, 255, 0.4) inset, 0 5px 3px -5px rgba(0, 0, 0, 0.5), 0 -13px 5px -10px rgba(255, 255, 255, 0.4) inset","font-weight: bold"].join(";"),Il=["color: black","display: block","padding: 4px","background-color: yellow","margin: 0","text-shadow: 0 1px 0 rgba(0, 0, 0, 0.3)","box-shadow: 0 1px 0 rgba(255, 255, 255, 0.4) inset, 0 5px 3px -5px rgba(0, 0, 0, 0.5), 0 -13px 5px -10px rgba(255, 255, 255, 0.4) inset","font-weight: bold"].join(";"),Zt=e=>t=>{T.getLevel()<=e&&t()},f={...T,ifDebug:Zt(T.levels.DEBUG),ifInfo:Zt(T.levels.INFO),ifWarn:Zt(T.levels.WARN),ifError:Zt(T.levels.ERROR),getLogger:e=>T.getLogger(`kos::${e}`),createLogger:({name:e,group:t})=>T.getLogger(`${t?`${t}:`:"kos"}::${e}`),wsSend:(...e)=>{const t=String(e).replace(/\n/g,"\\n");gs.info(`%c⬆ ${t}`,El)},wsReceive:(...e)=>{const t=String(e).replace(/\n/g,"\\n");gs.info(`%c⬇ ${t}`,Il)}},Tl=f.createLogger({name:"kos-dependency-manager"});class $l{constructor(){a(this,"_usedByCache",new Map);a(this,"_usesCache",new Map)}add(t,s){Zn.cancelDeletion(s);const o=this._usedByCache.get(s)||[];o.includes(t)||o.push(t),this._usedByCache.set(s,o);const r=this._usesCache.get(t)||[];r.includes(s)||r.push(s),this._usesCache.set(t,r)}remove(t,s){const o=this._usedByCache.get(s)||[];this._usedByCache.set(s,o.filter(n=>n!==t));const r=this._usesCache.get(t)||[];this._usesCache.set(t,r.filter(n=>n!==s))}canDestroy(t){const s=this._usedByCache.get(t);return s!=null&&s.length?(Tl.info(`Model ${t} is still used by: ${s.join(", ")}`),!1):!0}clear(){this._usedByCache.clear(),this._usesCache.clear()}}var y=(e=>(e.CREATING="creating",e.CREATED="created",e.INITIALIZING="initializing",e.INITIALIZED="initialized",e.LOADING="loading",e.LOADED="loaded",e.ONLINE="online",e.READYING="readying",e.READY="ready",e.READY_FAILED="ready_failed",e.RESETTING="resetting",e.RESET="reset",e.OFFLINE="offline",e.UNLOADING="unloading",e.UNLOADED="unloaded",e.FAILED="failed",e.INACTIVE="inactive",e.ACTIVE="active",e.ACTIVATING="activating",e.DEACTIVATING="deactivating",e))(y||{}),D=(e=>(e.CREATE="create",e.INITIALIZE="init",e.LOAD="load",e.READY="ready",e.GO_ONLINE="go_online",e.GO_OFFLINE="go_offline",e.RESET="go_offline",e.UNLOAD="unload",e.FAILED="failed",e.GO_ACTIVE="go_active",e.GO_INACTIVE="go_inactive",e.TIMEOUT="timeout",e))(D||{});const Kr=f.createLogger({name:"kos-model-cache"});class Ol{constructor(t=[]){a(this,"_modelsById",v.observable.map(new Map));a(this,"_toDelete",new Map);a(this,"_preloaded",[]);a(this,"_isPreloaded",!1);this.preloadKeys=t}get models(){return Array.from(this._modelsById.values()).filter(t=>!this._toDelete.has(t.modelId))}getModelById(t){if(t&&!this._toDelete.has(t))return this._modelsById.get(t)}addModel(t){const s=this.getModelById(t.modelId)||t;return this._modelsById.set(s.modelId,s),s}removeModel(t){this._modelsById.delete(t),this._toDelete.delete(t)}hasModel(t){return!!t&&this._modelsById.has(t)&&!this._toDelete.has(t)}restoreFromDeleteCache(t){if(t&&this._toDelete.has(t)){const s=this._toDelete.get(t);this._toDelete.delete(t),this._modelsById.set(t,s)}}markForDeletion(t){this._modelsById.delete(t.modelId),this._toDelete.set(t.modelId,t)}preload(t){return this._isPreloaded?(Kr.debug("Returning cached preloaded models"),this._preloaded):(this._preloaded=this.preloadKeys.map(s=>(Kr.debug(`Preloading model: ${typeof s=="string"?s:s.modelType}`),t(s))).filter(s=>!!s),this._isPreloaded=!0,this._preloaded)}}const to=new Map,Gr=new Map,so=new Map,oo=new Map,Yo=(e,t)=>{oi[e]=t},oi={indexExtension:{registerIndexExtension:(e,t)=>{const s=oo.get(e)||{};Object.assign(s,t),oo.set(e,t)},loadIndexExtensions:e=>oo.get(e)||{}},loader:{registerLoader:(e,t)=>{Gr.set(e,t)},executeLoader:async(e,t)=>{const s=Gr.get(e);if(s)return await s(t)}},propertyMapper:{registerPropertyMapper:(e,t)=>{so.set(e,t)},hasMapper:e=>so.has(e),executeMapper:(e,t,s)=>{const o=so.get(e);return o?o(t,s):""}},dataMapper:{registerDataMapper:(e,t)=>{const s=to.get(e)||[];s.push(t),to.set(e,s)},executeMapper:async(e,t,s)=>{const o=to.get(e);if(!o)return{};const r={};for(const n of o){const i=await n(t,s);Object.assign(r,i)}return r}}},C=oi;function ri(e,t){return`${Uo}${e}${t?`/${t}`:`/${e}`}`}function ni(e){return`${Uo}${e}`}var x=(e=>(e.INIT="init",e.LOAD="load",e.READY="ready",e.ACTIVATE="activate",e.ONLINE="online",e))(x||{});const Dl=Object.freeze(Object.defineProperty({__proto__:null,DependencyLifecycle:x},Symbol.toStringTag,{value:"Module"}));function Hr(e){const t=[];return new Promise((s,o)=>{for(const{condition:r,onMatch:n}of e){const i=v.when(r,()=>{t.forEach(c=>c());try{n==null||n(),s()}catch(c){o(c)}});t.push(i)}})}const G=Symbol("SubscriptionHandlers"),P=Symbol("DependencyModels"),wt=Symbol("FutureService"),Mt=Symbol("ChildModels"),_t=Symbol("ParentModel"),Et=Symbol("LogConfig"),is=Symbol("ReferenceConfig"),ii=Symbol("KosModelSymbol"),$e=Symbol("ModelEffects"),ie=(e,t)=>{e[Mt]=e[Mt]||{},e[Mt][t]=!0},Se=e=>`{PROP_${String(e)}}`,Sl=e=>`{PROP_${String(e)}}`,Al=Se("kosParentId"),Ns=e=>t=>{t[_t]=t[_t]||{};const s=(e==null?void 0:e.parentId)||Al;t[_t]={parentId:s}},Ke=({value:e,modelId:t,modelData:s})=>{let o=e;if(Array.isArray(o))return[...e];if(typeof o!="string"&&typeof o!="object")return o;if(typeof o=="object")o=Object.keys(o).reduce((r,n)=>(r[n]=Ke({value:o[n],modelId:t,modelData:s}),r),{});else if(typeof o=="string"){const r=new RegExp(".*({PROP_(.+)})");let n=o!=null&&o.includes(hs)?o.replace(hs,t):o;const i=n.match(r);if(i&&s&&(Object.getOwnPropertyNames(s).includes(i[2])||Object.getOwnPropertyNames(Object.getPrototypeOf(s)).includes(i[2]))){const c=s[i[2]];n=c?n.replace(i[1],c):void 0}return n}else return o;return o},Cl=f.createLogger({name:"kos-model"});function Rl(e,t,s){var n;const o=(n=e[_t])==null?void 0:n.parentId;if(!o)return;const r=Ke({value:o,modelData:s,modelId:t});r&&typeof r=="string"&&k.setParentContext(t,r)}function Ll(e){const t=e[wt];t&&Object.entries(t).forEach(([s,{handler:o}])=>{e[s]=o})}function Pl(e,t){const s=e[P]||{};Object.entries(s).forEach(([o,r])=>{const n=Ke({value:r.id||r.modelType,modelData:e,modelId:t}),i=Object.entries((r==null?void 0:r.options)||{}).reduce((c,[d,l])=>(c[d]=Ke({value:l,modelData:e,modelId:t}),c),{});if(typeof n=="string"){if(!r.lazy){const c=E.getInstance().modelManager.createModelInstance(r.modelType,n,i);e[o]=c.data}E.getInstance().modelManager.addDependency(t,n)}})}function kl(e){try{return v.makeAutoObservable(e)}catch(t){return Cl.error("Failed to make observable:",t),e}}const xl={construct(e,t){var c;const[s,o={}]=t,r=k.createContext(s);Rl(e,s,o);const n=f.createLogger({name:e.prototype.modelTypeId,group:((c=e[Et])==null?void 0:c.group)??"kos-model"}),i=new e(s,o,{logger:n,kosContext:r});return Ll(i),Pl(i,s),kl(i)}};function O(e){return t=>{var o,r;const s=t;return s.prototype.modelTypeId=e,s.prototype[ii]=!0,(o=s.prototype)[G]??(o[G]={}),(r=s.prototype)[P]??(r[P]={}),f.ifDebug(()=>{f.debug(`Registering model with id ${e}`)}),new Proxy(s,xl)}}const Fl=({modelType:e})=>t=>{Ns()(t),O(e)(t)};function Nl(e,t,s){const o=s.value;s.value=function(...r){const n=k.getContext(this.id);return r.push(n),o.apply(this,r)}}const Ul=({group:e}={group:""})=>t=>{t[Et]=t[Et]||{},t[Et]={group:e}};function ai(e){return(t,s,o)=>{t[$e]=t[$e]||{},t[$e][s]={dependencies:e==null?void 0:e.dependencies,value:o.value},o.value=function(){throw new Error(`Method ${s} cannot be called directly.`)}}}const jl=e=>(t,s)=>{t[is]=t[is]||{},t[is][s]=e},Ae=({modelType:e,id:t,options:s,lifecycle:o})=>(r,n)=>{r[P]=r[P]||{},r[P][n]={modelType:e,id:t,options:s,lifecycle:o||x.INIT}},Bl=({topic:e,handler:t,websocket:s=!1,condition:o=()=>!0})=>r=>{r[G]=r[G]||{},Array.isArray(e)?e.forEach(n=>{r[G][n]={websocket:s,handler:t,condition:o}}):r[G][e]={websocket:s,handler:jn(r,v.action(t),200),condition:o}};function R({topic:e,condition:t=(l,u)=>!0,transform:s=l=>l,websocket:o=!1,fos:r=!1,bridge:n=!1,skipParse:i=!1,lifecycle:c,destinationAddress:d}){return(l,u,h)=>{l[G]=l[G]||{},Array.isArray(e)?e.forEach(p=>{l[G][p]={websocket:o,fos:r,bridge:n,handler:h.value,condition:t,transform:s,lifecycle:c,skipParse:i,destinationAddress:d}}):l[G][e]={websocket:o,fos:r,bridge:n,handler:h.value,condition:t,transform:s,lifecycle:c,skipParse:i,destinationAddress:d}}}const ci=5e3;class Kl extends Error{constructor(s,o){super(s);a(this,"model");this.model=o}}const di=(e,t,s)=>{let o;return{promise:new Promise((i,c)=>{o=setTimeout(()=>{f.error(`Model ${t.modelId} - ${t.modelTypeName} - ${s} timed out after ${e}ms`),c(new Kl(`${t.modelId} - ${t.modelTypeName} - ${s}`,t))},e)}),cancel:()=>{o&&clearTimeout(o)}}},li=e=>e.fsm.transitionTo(D.GO_ACTIVE,y.ACTIVE),ui=e=>e.whenReady(),hi=e=>e.fsm.transitionTo(D.LOAD,y.LOADED),Gl=e=>e.fsm.transitionTo(D.UNLOAD,y.UNLOADED),gi=e=>e.fsm.transitionTo(D.INITIALIZE,y.INITIALIZED);var zo=(e=>(e.ACTIVE="active",e.READY="ready",e.LOAD="load",e.UNLOAD="unload",e.INIT="init",e))(zo||{});const as={active:li,ready:ui,load:hi,init:gi},fi=(e,t)=>{const s=t.id||t.modelType,o=Ke({value:s,modelData:e.modelData,modelId:e.modelId});f.debug(`activating dependent model ${t.modelType} with id ${o}`);const r=Object.keys((t==null?void 0:t.options)||{}).reduce((i,c)=>{const d=t.options[c];return i[c]=Ke({value:d,modelData:e.modelData,modelId:e.modelId}),i},{});return{dependentModel:E.getInstance().modelManager.createModelInstance(t.modelType,o,r),dataModelId:o}},pi=(e,t=x.READY)=>{var r;const s=((r=e.modelData)==null?void 0:r[P])||{};return Object.keys(s).length===0?(f.debug(`${e.modelId} has no dependencies. Returning`),[]):Object.keys(s).filter(n=>s[n].lifecycle===t).map(n=>{const i=s[n],{dependentModel:c,dataModelId:d}=fi(e,i);e.modelData[n]=c.data,f.debug(`waiting for dependent model ${i.modelType} with id ${d} - waiting for WHENREADY`);const l=async(p,w,b)=>{var _;await((_=p.whenReady)==null?void 0:_.call(p)),f.debug(`dependent model ${w} with id ${b} - READY`)},{promise:u,cancel:h}=di(ci,e,e.status);return Promise.race([l(c.model,i.modelType,d).then(()=>{h()}).catch(p=>{console.error(`Error waiting for dependent model ${i.modelType} with id ${d}:`,p),h()}),u])}).filter(n=>!!n)},mi=async(e,t,s,o)=>{if(f.debug(`Execute lifecycle with ${t.length} models`),t.length===0){f.debug(`${e.modelId} has no children. Returning`);return}if(!s){f.error(`${e.modelId} is not transitioning with a valid target ${s}`);return}const r=t.map(c=>{let d;return as[s]&&c?d=as[s](c):(c||f.error("model is undefined. This shouldn't happen"),as[s]||f.error(`There is no promise in the Transition Map for ${s}`)),{promise:d,modelId:c==null?void 0:c.modelId,model:c,type:c==null?void 0:c.modelTypeName,status:c==null?void 0:c.status}}).filter(c=>c.promise?c.model?!0:(f.error(`No model found ${c.modelId}`),!1):(f.error(`No promise found ${c.modelId}`),!1)),i=(await Promise.allSettled(r.map(c=>{var u;const{promise:d,cancel:l}=di(ci,c.model,c.status);return Promise.race([(u=c.promise)==null?void 0:u.then(()=>{l()}).catch(h=>{f.error(`Model ${c.modelId} - ${c.type} failed to transition to ${s}: ${h.message}`),l()}),d])}))).filter(c=>c.status==="rejected");i.length>0&&f.error(`Model ${e.modelId} had ${i.length} failed child models on ${o}`)},yi=async(e,t,s)=>{await mi(e,e.getChildren().filter(o=>!!o),t,s)},ct=async(e,t)=>{const o=(await Promise.allSettled(pi(e,t))).filter(r=>r.status==="rejected");o.length&&(f.error(`There were ${o.length} failed dependent models on ${t}`),f.error(o))},Hl=e=>typeof e.toJSON=="function",It=e=>e[P]!==void 0,qo=e=>e.revision!==void 0&&e.index!==void 0,bi=e=>{if(e){if(It(e))return e;if(qo(e))return e.data;if(e instanceof Map||e instanceof v.ObservableMap||e instanceof Set)return Array.from(e.values()).filter(It);if(Array.isArray(e))return e.filter(It)}};function Vl(e){const t=`KosModel(${e.modelTypeName}:${e.modelId})`;try{Object.defineProperty(e,Symbol.toStringTag,{value:t,configurable:!0})}catch{e.toString=()=>t}try{Object.defineProperty(e.constructor,"name",{value:`KosModel_${e.modelTypeName}`,configurable:!0})}catch{e.constructor.name=`KosModel_${e.modelTypeName}`}const s=["fsm","effectManager","subscriptionManager","onlineLifecycleManager","companionManager","childResolver","_offlineQueue"];for(const o of s)o in e&&Object.defineProperty(e,o,{enumerable:!1});Object.defineProperty(e,"debugState",{enumerable:!1,configurable:!0,get(){var o,r,n;return{id:e.modelId,type:e.modelTypeName,initialized:e.initialized,loaded:e.loaded,status:e.status,onlineStatus:e.onlineStatus,activeStatus:e.activeStatus,companions:(r=(o=e.companionManager)==null?void 0:o.all())==null?void 0:r.map(i=>i.modelTypeName),children:(n=e.getChildren)==null?void 0:n.call(e).map(i=>i.modelId),effects:!!e.effectManager,subs:!!e.subscriptionManager}}}),Yl(e.modelData,e.modelTypeName,e.modelId,e)}function Yl(e,t,s,o){Object.defineProperty(e,Symbol.toStringTag,{value:`KosModelData(${t}:${s})`,configurable:!0});try{Object.defineProperty(e.constructor,"name",{value:`${t}ModelData`,configurable:!0})}catch{e.constructor.name=`${t}ModelData`}Object.defineProperty(e,"debugState",{enumerable:!1,configurable:!0,get(){var c,d,l;const r=((c=o.getChildren)==null?void 0:c.call(o))||[],n=((d=o.companionManager)==null?void 0:d.all())||[],i=o.modelData[P]||{};return{id:s,type:t,companions:{count:n.length,data:n.map(u=>({type:u.modelTypeName,id:u.modelId}))},dependencies:{count:Object.keys(i).length,data:Object.values(i).map(u=>({id:u.id||u.modelType,type:u.modelType,options:u.options,lifecycle:u.lifecycle}))},children:{count:r.length,data:r.map(u=>({id:u.modelId,type:u.modelTypeName}))},data:((l=e.toJSON)==null?void 0:l.call(e))||{},subs:!!o.subscriptionManager}}}),Object.defineProperty(e,"toJSON",{configurable:!0,enumerable:!1,writable:!0,value:()=>{const r={};for(const n of Object.keys(e))if(!(n.startsWith("_")||typeof e[n]=="function"))try{const i=e[n];It(i)?r[`[KOS Model] ${n}`]=typeof i.toJSON=="function"?i.toJSON():{id:i.id,type:i.constructor.name}:qo(i)?r[`[KOS Container] ${n}`]=typeof i.toJSON=="function"?i.toJSON():["Container"]:Array.isArray(i)?r[n]=`[Array(${i.length})]`:typeof i=="object"&&i!==null?r[n]=JSON.parse(JSON.stringify(i)):r[n]=i}catch{r[n]="[unreadable]"}return r}})}class zl{constructor(t){this.model=t}resolve(){const t=new Set([...this.getResolvedDecoratedChildren(),...this.getAdditionalChildren(),...this.model.companionModels.all()]),s=Array.from(t).map(o=>this.model.modelManager.getModelById(o.id||"")).filter(o=>o&&o.status!==y.FAILED).filter(o=>!!o);return s.forEach(o=>{try{k.setParentContext(o.modelId,this.model.modelId)}catch(r){console.error(`Failed to set parent context for ${o.modelId} under ${this.model.modelId}`,r)}}),s}getResolvedDecoratedChildren(){var s;const t=((s=this.model.modelData)==null?void 0:s[Mt])||{};return Object.keys(t).map(o=>bi(this.model.modelData[o])).filter(o=>!!o).flat()}getAdditionalChildren(){var t,s;return((s=(t=this.model.modelData)==null?void 0:t.getChildren)==null?void 0:s.call(t))||[]}}class ql{constructor(t){a(this,"companions",new v.ObservableMap);this.hostModel=t}add(t){this.companions.set(t.modelTypeName,t)}clear(){this.companions.clear()}get(t){return this.companions.get(t)}all(){return[...this.companions.values()]}get data(){return this.companions}}class Wl{constructor(t,s,o,r){a(this,"disposers",[]);this.modelTypeName=t,this.modelId=s,this.modelData=o,this.log=r}setup(){var s;const t=((s=this.modelData)==null?void 0:s[$e])||{};for(const o of Object.keys(t)){const{value:r,dependencies:n,options:i}=t[o],c=r.bind(this.modelData),d=()=>{this.log.info(`Running effect ${o} for ${this.modelTypeName} (${this.modelId})`),v.runInAction(()=>c())},l=n?v.reaction(()=>n(this.modelData),d,{fireImmediately:!!(i!=null&&i.fireImmediately)}):v.autorun(d);this.disposers.push(l)}}disposeAll(){for(const t of this.disposers)try{t()}catch(s){this.log.info(`Failed to dispose effect for ${this.modelId}`,s)}this.disposers=[]}}const Zl=f.createLogger({name:"model-active-machine"}),Jl=e=>{const t=m.createMachine(y.INACTIVE,{[y.FAILED]:m.state(m.transition(D.GO_ACTIVE,y.ACTIVATING)),[y.INACTIVE]:m.state(m.transition(D.GO_ACTIVE,y.ACTIVATING)),[y.ACTIVATING]:m.invoke(()=>(e.activeStatus=y.ACTIVATING,e.activate()),m.transition("done",y.ACTIVE,m.action(()=>{e.activeStatus=y.ACTIVE})),m.transition("error",y.FAILED,m.action(()=>{e.activeStatus=y.FAILED}))),[y.ACTIVE]:m.state(m.transition(D.GO_INACTIVE,y.DEACTIVATING)),[y.DEACTIVATING]:m.invoke(()=>(e.activeStatus=y.DEACTIVATING,e.deactivate()),m.transition("done",y.INACTIVE,m.action(()=>{e.activeStatus=y.INACTIVE})),m.transition("error",y.FAILED,m.action(()=>{e.activeStatus=y.FAILED})))});return{service:m.interpret(t,o=>Zl.debug(o.machine.current)),machine:t}},Vr=f.createLogger({name:"model-online-machine"}),Ql=e=>{const t=m.createMachine(y.OFFLINE,{[y.ONLINE]:m.state(m.transition(D.GO_OFFLINE,y.OFFLINE,m.action(async()=>{await e.offline(),e.onlineStatus=y.OFFLINE}))),[y.OFFLINE]:m.state(m.transition(D.GO_ONLINE,y.ONLINE,m.action(async()=>{Vr.debug(`Going online with model ${e.modelId}`),await e.online(),e.onlineStatus=y.ONLINE,await e.fsm.transitionTo(D.INITIALIZE,y.INITIALIZED)})))}),s=m.interpret(t,o=>Vr.debug(o.machine.current));return{machine:t,service:s}},Xl=e=>{var o;const t=Jl(e).service,s=Ql(e).service;return m.createMachine(y.CREATING,{[y.CREATING]:m.state(m.transition(D.CREATE,y.CREATED)),[y.CREATED]:m.state(m.immediate(y.INITIALIZING)),[y.INITIALIZING]:m.invoke(()=>(Y(()=>{e.status=y.INITIALIZING}),e.init()),m.transition("done",y.INITIALIZED,m.action(()=>{e.status=y.INITIALIZED})),m.transition("error",y.FAILED,m.action(()=>{f.error(`Model ${e.modelId} - ${e.modelTypeName} failed to initialize. Transitioning to FAILED state.`),e.status=y.FAILED}))),[y.INITIALIZED]:m.state(m.immediate(y.LOADING)),[y.LOADING]:m.invoke(()=>(Y(()=>{e.status=y.LOADING}),e.load()),m.transition("done",y.LOADED,m.action(()=>{e.status=y.LOADED})),m.transition("error",y.FAILED,m.action(()=>{e.status=y.FAILED}))),[y.LOADED]:m.state(m.immediate(y.READYING),m.transition(D.UNLOAD,y.UNLOADING)),[y.RESETTING]:m.invoke(()=>{var r;return Y(()=>{e.status=y.RESETTING}),(r=e.unload)==null||r.call(e),e.load()},m.transition("done",y.LOADED,m.action(()=>{e.status=y.LOADED}))),[y.READYING]:m.invoke(()=>(Y(()=>{e.status=y.READYING}),e.ready()),m.transition("done",y.READY,m.action(()=>{Y(()=>{e.status=y.READY}),s.send(D.GO_ONLINE)})),m.transition("error",y.FAILED,m.action(()=>{e.status=y.FAILED}))),[y.READY]:m.state(m.transition(D.UNLOAD,y.UNLOADED,m.action((o=e.unload)==null?void 0:o.bind(e))),m.transition(D.RESET,y.RESETTING),m.transition(D.GO_ONLINE,y.READY,m.action(()=>{s.send(D.GO_ONLINE)})),m.transition(D.GO_OFFLINE,y.READY,m.action(()=>{s.send(D.GO_OFFLINE)})),m.transition(D.GO_ACTIVE,y.READY,m.action(()=>{t.send(D.GO_ACTIVE)})),m.transition(D.GO_INACTIVE,y.READY,m.action(()=>{t.send(D.GO_INACTIVE)}))),[y.UNLOADED]:m.state(),[y.FAILED]:m.state()})},eu=f.createLogger({name:"kos-model-lifecycle"}),tu=e=>({service:m.interpret(Xl(e),s=>eu.debug(`state machine for model ${e.modelId}: ${s.machine.current});`))});class su{constructor(t,s){a(this,"disposer");a(this,"service");this.model=t,this.log=s;const o=tu(t);this.service=o.service,this.service.send(D.CREATE)}get current(){return this.service.machine.current}async transitionTo(t,s,o=y.FAILED){return this.getTransitionStatusFor(s)===s?(this.log.debug(`Model ${this.model.modelId} already in state ${s}, skipping transition`),Promise.resolve()):(this.log.debug(`Transitioning model ${this.model.modelId} with event ${t} toward target ${s}`),new Promise((n,i)=>{var c;(c=this.disposer)==null||c.call(this),this.disposer=v.when(()=>{const d=this.getTransitionStatusFor(s);return d===s||d===o},()=>{this.getTransitionStatusFor(s)===o?(this.log.error(`Model ${this.model.modelId} entered error state ${o} during transition`),i(new Error(`FSM transition failed for model ${this.model.modelId} with event ${t}`))):(this.log.debug(`Model ${this.model.modelId} reached target state ${s}`),n())}),this.service.send(t)}).finally(()=>{var n;(n=this.disposer)==null||n.call(this),this.disposer=void 0}))}getTransitionStatusFor(t){return[y.ACTIVE,y.INACTIVE].includes(t)?this.model.activeStatus:this.model.status}}class ou{static create({modelId:t,modelTypeName:s,component:o}){const r=[o??"kos",s,t].filter(Boolean).join(".");return f.createLogger({name:r})}}class ru{constructor(t){a(this,"queue",[]);this.log=t}enqueue(t){this.queue.push(t)}flush(){if(this.queue.length!==0){this.log.warn(`Processing ${this.queue.length} offline message(s)`);for(const t of this.queue)try{t()}catch(s){this.log.error("Error while processing offline message:",s)}this.queue=[],this.log.info("Offline queue flushed")}}clear(){this.queue=[]}get length(){return this.queue.length}get isEmpty(){return this.queue.length===0}}class nu{constructor(t,s){a(this,"unsubscribers",[]);this.model=t,this.log=s}register(){const t=this.model.modelId,s=j("/kosCore/online",async()=>{this.log.debug(`Online event received for ${t}, waiting for readiness...`),await this.model.whenReady(),this.log.debug(`${t} is ready — sending GO_ONLINE`),await this.model.fsm.transitionTo(D.GO_ONLINE,y.ONLINE)}),o=j("/kosCore/offline",async()=>{this.log.debug(`Offline event received for ${t} — sending GO_OFFLINE`),await this.model.fsm.transitionTo(D.GO_OFFLINE,y.OFFLINE)});this.unsubscribers.push(s.unsubscribe),this.unsubscribers.push(o.unsubscribe)}dispose(){this.unsubscribers.forEach(t=>t()),this.unsubscribers=[]}}var vi=(e=>(e.GET="GET",e.PUT="PUT",e.POST="POST",e.DELETE="DELETE",e))(vi||{});const wi=({path:e,requestId:t,method:s,destinationAddress:o})=>{let r=`${xs}:${s}
|
|
2
2
|
`;return r+=`topic:${e}
|
|
3
|
-
`,r+=`${
|
|
4
|
-
`,r+=`${
|
|
5
|
-
`,o&&(r+=`${
|
|
6
|
-
`),r+=`${
|
|
3
|
+
`,r+=`${Je}:${e}
|
|
4
|
+
`,r+=`${Kt}:${t}
|
|
5
|
+
`,o&&(r+=`${fe}:${o}
|
|
6
|
+
`),r+=`${de}:kos.studio.request
|
|
7
7
|
`,r+=`
|
|
8
|
-
`,r},
|
|
9
|
-
`;return i+=`${
|
|
10
|
-
`,i+=`${
|
|
11
|
-
`,i+=`${
|
|
12
|
-
`,o&&(i+=`${
|
|
13
|
-
`),r&&(i+=`${
|
|
14
|
-
`),n&&(i+=`${
|
|
15
|
-
`),i+=`${
|
|
8
|
+
`,r},Mi=({path:e,requestId:t,method:s,destinationAddress:o,ordered:r,tracker:n})=>{let i=`${In}:/http${e}
|
|
9
|
+
`;return i+=`${xs}:${s}
|
|
10
|
+
`,i+=`${Je}:${e}
|
|
11
|
+
`,i+=`${Dn}:${t}
|
|
12
|
+
`,o&&(i+=`${fe}:${o}
|
|
13
|
+
`),r&&(i+=`${Fo}:true
|
|
14
|
+
`),n&&(i+=`${No}:${n}
|
|
15
|
+
`),i+=`${de}:fos.http.request
|
|
16
16
|
`,i+=`
|
|
17
|
-
`,i},
|
|
18
|
-
`;return
|
|
19
|
-
`,
|
|
20
|
-
`,o&&(
|
|
21
|
-
`),r&&(
|
|
22
|
-
`),n&&(
|
|
23
|
-
`),c&&Object.keys(c).forEach(
|
|
24
|
-
`}),
|
|
25
|
-
`,
|
|
26
|
-
`,
|
|
27
|
-
`;return o+=`${
|
|
28
|
-
`,o+=`${
|
|
29
|
-
`,o+=`${
|
|
30
|
-
`,o+=`${
|
|
17
|
+
`,i},_i=({path:e,requestId:t,method:s,destinationAddress:o,ordered:r,tracker:n,bridge:i,headers:c})=>{let d=`${xs}:${s}
|
|
18
|
+
`;return d+=`${Je}:${e}
|
|
19
|
+
`,d+=`${Kt}:${t}
|
|
20
|
+
`,o&&(d+=`${fe}:${o}
|
|
21
|
+
`),r&&(d+=`${Fo}:true
|
|
22
|
+
`),n&&(d+=`${No}:${n}
|
|
23
|
+
`),c&&Object.keys(c).forEach(l=>{d+=`${l}:${c[l]}
|
|
24
|
+
`}),d+=`${de}:${i?"fos":"kos"}.http.request
|
|
25
|
+
`,d+=`
|
|
26
|
+
`,d},ve=(e,t)=>{let s=e;return t&&(s+=t),s};function mo(e){const t={...e};return{append(s,o){t[s]=o},delete(s){delete t[s]},get(s){return t[s]},forEach(s){Object.keys(t).forEach(o=>s(t[o],o,this))},has(s){return Object.hasOwn(t,s)},set(s,o){t[s]=o},keys(){return Object.keys(t)},values(){return Object.values(t)},entries(){return Object.entries(t)}}}function yo(e){let t=!1;return window.ReadableStream?new ReadableStream({start(o){function r(){return Promise.resolve({done:t,value:e}).then(({done:n,value:i})=>{if(n){o.close();return}o.enqueue(i),t=!0,r()})}r()}}):e}const Ei=({path:e,requestId:t,destinationAddress:s})=>{let o=`topic:${e}
|
|
27
|
+
`;return o+=`${Je}:${e}
|
|
28
|
+
`,o+=`${Kt}:${t}
|
|
29
|
+
`,o+=`${fe}:${s}
|
|
30
|
+
`,o+=`${de}:kos.studio.request
|
|
31
31
|
`,o+=`
|
|
32
|
-
`,o},
|
|
33
|
-
`;return r+=`${
|
|
34
|
-
`,r+=`${
|
|
32
|
+
`,o},Ii=({requestId:e,destinationAddress:t,requestType:s,headers:o})=>{let r=`${Kt}:${e}
|
|
33
|
+
`;return r+=`${fe}:${t}
|
|
34
|
+
`,r+=`${de}:${s}
|
|
35
35
|
`,o&&Object.keys(o).forEach(n=>{r+=`${n}:${o[n]}
|
|
36
36
|
`}),r+=`
|
|
37
|
-
`,r},
|
|
38
|
-
`;return r+=`${
|
|
39
|
-
`,t&&(r+=`${
|
|
40
|
-
`),r+=`${
|
|
41
|
-
`,r+=`${
|
|
42
|
-
`,r+=`${
|
|
37
|
+
`,r},iu=(e,t)=>{const s=e,o=ve(Ii(t),typeof s=="string"?s:JSON.stringify(s)),r=E.getInstance().transport.socket;r?(f.debug("Sending message",o),r.socket.send(o)):f.error("socket transport is not initialized")},Ti=({path:e,responseId:t,status:s,destinationAddress:o})=>{let r=`topic:${e}
|
|
38
|
+
`;return r+=`${Je}:${e}
|
|
39
|
+
`,t&&(r+=`${Fs}:${t}
|
|
40
|
+
`),r+=`${xo}:${s}
|
|
41
|
+
`,r+=`${fe}:${o}
|
|
42
|
+
`,r+=`${de}:kos.studio.response
|
|
43
43
|
`,r+=`
|
|
44
|
-
`,r},
|
|
45
|
-
`;return t+=`${
|
|
44
|
+
`,r},au=(e,t)=>{const s=e,o=ve(Ei(t),JSON.stringify(s)),r=E.getInstance().transport.socket;r?r.socket.send(o):f.error("socket transport is not initialized")},cu=(e,t)=>{const s=t.responseId?{status:t.status,data:e}:e,o=ve(Ti(t),JSON.stringify(s)),r=E.getInstance().transport.socket;r?r.socket.send(o):f.error("socket transport is not initialized")},$i=({topic:e})=>{let t=`topic:${e}
|
|
45
|
+
`;return t+=`${de}:kos.broker.send
|
|
46
46
|
`,t+=`
|
|
47
|
-
`,t},
|
|
48
|
-
`;return n+=`${
|
|
49
|
-
`,n+=`${
|
|
50
|
-
`,n+=`${
|
|
51
|
-
`,n+=`${
|
|
52
|
-
`,n+=`${
|
|
53
|
-
`,n+=`${
|
|
47
|
+
`,t},Oi=({responseId:e,destinationAddress:t,type:s,sourceAddress:o,status:r})=>{let n=`${Fs}:${e}
|
|
48
|
+
`;return n+=`${fe}:${t}
|
|
49
|
+
`,n+=`${Tn}:${o}
|
|
50
|
+
`,n+=`${de}:${s??"kos.message.request"}
|
|
51
|
+
`,n+=`${xo}:${r}
|
|
52
|
+
`,n+=`${$n}:application/json
|
|
53
|
+
`,n+=`${On}:no-cache
|
|
54
54
|
`,n+=`
|
|
55
|
-
`,n},
|
|
56
|
-
`;return t&&(r+=`${
|
|
57
|
-
`),r+=`${
|
|
58
|
-
`,r+=`${
|
|
55
|
+
`,n},Di=({topic:e,responseId:t,destinationAddress:s,type:o})=>{let r=`topic:${e}
|
|
56
|
+
`;return t&&(r+=`${Fs}:${t}
|
|
57
|
+
`),r+=`${fe}:${s}
|
|
58
|
+
`,r+=`${de}:${o??"kos.message.request"}
|
|
59
59
|
`,r+=`
|
|
60
|
-
`,r},
|
|
60
|
+
`,r},du=({msg:e,options:t})=>{const s=e,o=ve($i(t),JSON.stringify(s)),r=E.getInstance().transport.socket;r?r.socket.send(o):f.error("socket transport is not initialized")},Si=({msg:e,options:t})=>{const s=e,o=ve(Di(t),JSON.stringify(s)),r=E.getInstance().transport.socket;r?r.socket.send(o):f.error("socket transport is not initialized")},Ai=({msg:e,options:t})=>{const s=e,o=ve(Oi(t),JSON.stringify(s)),r=E.getInstance().transport.socket;r?r.socket.send(o):f.error("socket transport is not initialized")},bo=(e,t)=>{try{return t?e.body??e:JSON.parse(e.body)}catch{return e.body||e}};class lu extends WebSocket{constructor(t){super(t)}}function Yr(e){const t=`
|
|
61
61
|
|
|
62
62
|
`,s=`
|
|
63
|
-
`,o=/:(.*)/s,[r,n]=e.split(t).map(c=>c.trim());return{headers:r.split(s).reduce((c,
|
|
63
|
+
`,o=/:(.*)/s,[r,n]=e.split(t).map(c=>c.trim());return{headers:r.split(s).reduce((c,d)=>{const[l,u]=d.split(o).map(h=>h.trim());return l&&u&&(c[l]=u),c},{}),body:n}}function uu(e){const t=`
|
|
64
64
|
|
|
65
65
|
`,s=`
|
|
66
|
-
`,o=/:(.*)/s,[,r,n]=e.split(t).map(c=>c.trim());return{headers:r.split(s).reduce((c,
|
|
66
|
+
`,o=/:(.*)/s,[,r,n]=e.split(t).map(c=>c.trim());return{headers:r.split(s).reduce((c,d)=>{const[l,u]=d.split(o).map(h=>h.trim());return l&&u&&(c[l]=u),c},{}),body:n}}class Wo{constructor({host:t,port:s,protocol:o,alias:r,onConnectionEstablished:n,onConnectionLost:i,Transport:c=lu}){a(this,"host");a(this,"port");a(this,"protocol");a(this,"socket");a(this,"connectionEstablished");a(this,"alias");a(this,"onConnectionEstablished");a(this,"onConnectionLost");a(this,"offlineMessages",[]);a(this,"oldSend");this.host=t,this.port=s,this.protocol=o,this.onConnectionEstablished=n,this.onConnectionLost=i,this.alias=r,this.socket=new c(`${this.protocol}${this.host}:${this.port}/events`),this.socket.onmessage=this.onMessage.bind(this),this.socket.onopen=this.onOpen.bind(this),this.socket.onclose=this.onClose.bind(this),this.oldSend=this.socket.send,this.connectionEstablished=!1,j("/mock/msg/receive",d=>{var l,u;if(d!=null&&d.body){f.wsReceive(d==null?void 0:d.body);const h={data:d.body};(u=(l=this.socket)==null?void 0:l.onmessage)==null||u.call(l,h)}}),v.makeObservable(this,{connectionEstablished:v.observable})}addOfflineMessage(t){this.offlineMessages.push({msg:t})}processMessageEvent(t){const{data:s}=t;return Yr(s)}onMessage(t){try{f.debug("webSocketTransport: onMessage received");const{headers:s,body:o}=this.processMessageEvent(t);f.wsReceive(t.data);const r=s.subscription||s[this.RESPONSE_ID_HEADER]||s.topic||s.type;if(r){let n=o,i=s;if(r==="kos.sniffer.msg"){const{headers:c,body:d}=uu(t.data);n=d,i={...s,...c}}N(r,n,i)}}catch(s){f.error("onMessage exception",s.message,s.stack)}}onOpen(t){f.info("websocket connection opened"),this.socket=t.currentTarget,v.runInAction(()=>{var s;this.connectionEstablished=!0,this.alias&&this.socket.send(`type:kos.addr.alias
|
|
67
67
|
alias:${this.alias}
|
|
68
68
|
|
|
69
|
-
`),f.debug(`sending ${this.offlineMessages.length} offline FOS messages`),this.offlineMessages.forEach(o=>{var r;f.debug(`sending offline message ${o.msg}`),(r=this.socket)==null||r.send(o.msg)}),this.offlineMessages=[],(s=this.onConnectionEstablished)==null||s.call(this)})}onClose(){this.socket&&this.socket.close(),
|
|
69
|
+
`),f.debug(`sending ${this.offlineMessages.length} offline FOS messages`),this.offlineMessages.forEach(o=>{var r;f.debug(`sending offline message ${o.msg}`),(r=this.socket)==null||r.send(o.msg)}),this.offlineMessages=[],(s=this.onConnectionEstablished)==null||s.call(this)})}onClose(){this.socket&&this.socket.close(),v.runInAction(()=>{this.connectionEstablished=!1}),f.debug("websocket disconnected. Attempting calling callback"),this.onConnectionLost&&setTimeout(this.onConnectionLost,2500)}send(t){var s,o;if(f.wsSend(t),window.kosLogEvents){const{headers:r,body:n}=Yr(String(t));N(Gt.SEND,{headers:r,body:n})}if(window.kosTopicIntercept&&window.kosEnableMocks){const{handler:r,requestId:n}=window.kosTopicIntercept(t);if(r){t=`mocked:true
|
|
70
70
|
${t}`;const c={data:`mocked:true
|
|
71
|
-
${r(n)}`};(o=(s=this.socket)==null?void 0:s.onmessage)==null||o.call(s,c)}else this.oldSend.call(this.socket,t)}else this.oldSend.call(this.socket,t)}}class
|
|
71
|
+
${r(n)}`};(o=(s=this.socket)==null?void 0:s.onmessage)==null||o.call(s,c)}else this.oldSend.call(this.socket,t)}else this.oldSend.call(this.socket,t)}}class hu{constructor(t){a(this,"addEventListener");a(this,"dispatchEvent");a(this,"removeEventListener");a(this,"_onclose");a(this,"_onerror");a(this,"_onmessage");a(this,"_onopen");a(this,"messageQueue",[]);a(this,"isSending",!1);T.debug(`called Bridge Transport with addr ${t}`);const s=this;globalThis.kosWindowWebsocketRecv=o=>{if(s.onmessage){const r={data:o};s.onmessage(r)}},T.debug("Opening bridge transport"),globalThis.kosWindowWebsocketOpen(),T.debug("Opened bridge transport"),this._onclose=null,this._onerror=null,this._onmessage=null,this._onopen=null,this.addEventListener=()=>T.debug("not implemented"),this.dispatchEvent=()=>T.debug("not implemented"),this.removeEventListener=()=>T.debug("not implemented")}close(){T.debug("closing")}sendNextMessage(){if(this.messageQueue.length>0){const t=this.messageQueue.shift();globalThis.kosWindowWebsocketSend(t),setTimeout(()=>this.sendNextMessage(),1)}else this.isSending=!1}enqueueMessage(t){this.messageQueue.push(t),this.isSending||(this.isSending=!0,this.sendNextMessage())}send(t){globalThis.kosWindowWebsocketSend(t)}get onmessage(){return this._onmessage}set onmessage(t){this._onmessage=t}get onopen(){return this._onopen}set onopen(t){this._onopen=t}get onclose(){return this._onclose}set onclose(t){this._onclose=t}get onerror(){return this._onerror}set onerror(t){this._onopen=t}}class gu extends Wo{constructor({host:s,port:o,alias:r}){super({host:s,port:o,Transport:hu,alias:r,protocol:"kos://"});a(this,"RESPONSE_ID_HEADER");this.RESPONSE_ID_HEADER="response-id"}}class fu extends Wo{constructor({host:s,port:o}){super({host:s,port:o,protocol:"ws://"});a(this,"RESPONSE_ID_HEADER");this.RESPONSE_ID_HEADER="requestId"}}class pu extends Wo{constructor({host:s,port:o,protocol:r,onConnectionEstablished:n,onConnectionLost:i,alias:c}){super({host:s,port:o,onConnectionEstablished:n,onConnectionLost:i,alias:c,protocol:r});a(this,"RESPONSE_ID_HEADER");this.RESPONSE_ID_HEADER="response-id"}}window.kosEnableMocks=process.env.KOS_MOCK_WS==="true";window.kosLogEvents=process.env.KOS_LOG_WS==="true";class vo{static build({host:t,port:s,protocol:o,fos:r,alias:n,onConnectionEstablished:i,onConnectionLost:c}){return f.debug("initializing websocket connection"),f.warn(`kosWindowWebsocketOpen: ${globalThis.kosWindowWebsocketOpen?"true":"false"}`),f.warn(`fos: ${r?"true":"false"}`),window.kosMockWs||globalThis.kosWindowWebsocketOpen&&!r?(f.warn("Using bridged message transport"),new gu({host:t,port:s,protocol:o,onConnectionEstablished:i,onConnectionLost:c,alias:n})):r?new fu({host:t,port:s,protocol:o,alias:n,onConnectionEstablished:i,onConnectionLost:c}):new pu({host:t,port:s,protocol:o,alias:n,onConnectionEstablished:i,onConnectionLost:c})}}const mu=ee();mu.fos&&(window.kosUseFos=!0);const zr=process.env.KOS_FOS_PORT;window.kosUseFos=!!(window.kosUseFos||process.env.KOS_USE_FOS==="true");window.kosFosPort=zr?parseInt(zr):0;const Ee=T.getLogger("web-socket-transport");var Ci=(e=>(e.NOT_INITIALIZED="not_initialized",e.INITIALIZED="initialized",e.OFFLINE="OFFLINE",e.ONLINE="ONLINE",e))(Ci||{}),Tt=(e=>(e.CONNECTED="websocket.connected",e.DISCONNECTED="websocket.disconnected",e.RELOAD="websocket.reload",e))(Tt||{});class Ht{constructor({host:t="localhost",port:s=8080,protocol:o="ws://",token:r,initialize:n,alias:i,fos:c}){a(this,"host");a(this,"port");a(this,"protocol");a(this,"_token");a(this,"webSocketSupported",!!globalThis.WebSocket);a(this,"authorized");a(this,"alias");a(this,"socket");a(this,"fosSocket");a(this,"fosPort");a(this,"useFosTransport");this.host=t,this.port=s,this.protocol=o,this._token=r,this.alias=i,this.authorized=process.env.KOS_ALLOW_ANONYMOUS==="true",this.useFosTransport=!!c,this.fosPort=c==null?void 0:c.port,this.socket=void 0,this.fosSocket=void 0;let d=!1;v.makeObservable(this,{authorized:v.observable,socket:v.observable,fosSocket:v.observable,init:v.action,connectionEstablished:v.computed}),v.reaction(()=>this.connectionEstablished,l=>{l&&(Ee.warn("Connection Established"),N("websocket.connected","websocket.connected"),d&&N("websocket.reload","websocket.reload"),d=!0)}),n&&this.init()}get connectionEstablished(){return!this.webSocketSupported||!this.socket||this.useFosTransport&&!this.fosSocket?!1:this.useFosTransport&&this.fosSocket?this.socket.connectionEstablished&&this.fosSocket.connectionEstablished:!this.useFosTransport&&this.socket?this.socket.connectionEstablished:!1}init(){var t,s;if(f.warn(`Initializing WebSocketTransport on ${this.host}:${this.port}`),this.useFosTransport&&(this.fosSocket=vo.build({host:this.host,port:this.fosPort||9854,protocol:this.protocol,fos:!0})),this.socket=vo.build({host:this.host,port:this.port,protocol:this.protocol,alias:this.alias,onConnectionLost:()=>{Ee.error("Connection Lost"),N("websocket.disconnected","websocket.disconnected"),this.init()}}),globalThis.kosWindowWebsocketOpen){const o={currentTarget:this.socket.socket};(s=(t=this.socket.socket)==null?void 0:t.onopen)==null||s.call(t,o)}return this}_sendSubscriptionMessage(t,s,o=!1,r=!1,n){var p,w,b,_;Ee.debug(`${s} to topic ${t}`);const i=ee(),c=i==null?void 0:i.connId,d=n??c??((p=window==null?void 0:window.kosBridge)==null?void 0:p.call(window,"connId"));Ee.debug(`subscribing with connId ${d}`);const l=d?`dst-addr:${d}
|
|
72
72
|
`:"",u=o?`subscribe:${t}`:r?`type:fos.broker
|
|
73
73
|
cmd:${s}
|
|
74
|
-
${
|
|
75
|
-
`:`${
|
|
74
|
+
${l}topics:${t}
|
|
75
|
+
`:`${l}type:kos.broker.${s}
|
|
76
76
|
|
|
77
|
-
["${t}"]`;if(o?(v=this.fosSocket)==null?void 0:v.connectionEstablished:(b=this.socket)==null?void 0:b.connectionEstablished){const I=o?this.fosSocket:this.socket;(E=I==null?void 0:I.socket)==null||E.send(u)}else{_e.debug("no connection adding to offline messages");const I=o?this.fosSocket:this.socket;I==null||I.addOfflineMessage(u)}}subscribeTopic({topic:t,callback:s,fos:o,bridge:r,destinationAddress:n}){const{unsubscribe:i,count:c}=j(t,s);return _e.debug(`Topic ${t} currently has ${c} subscribers`),this._sendSubscriptionMessage(t,"subscribe",o,r,n),()=>{const{count:l}=i();_e.debug(`Topic ${t} currently has ${l} subscribers`),l===0&&this._sendSubscriptionMessage(t,"unsubscribe",o,r,n)}}async whenReady(){const t=this;return this.webSocketSupported?(await w.when(()=>{var s,o;return!!((s=t.socket)!=null&&s.connectionEstablished)&&(!t.useFosTransport||!!((o=t.fosSocket)!=null&&o.connectionEstablished))&&t.authorized}),{status:"success"}):{status:"not supported"}}get token(){return this._token}set token(t){this._token=t,this.init()}static host(t="localhost"){return this.getInstance().host=t,this}static port(t=8080){return this.getInstance().port=t,this}static alias(t){this.getInstance().alias=t}static getInstance(t=8080,s){if(!this._instance){const o=window.kosUseFos?{port:window.kosFosPort||8081}:void 0;this._instance=new this({port:t,token:s,fos:o})}return this._instance}}a(Kt,"_instance");class tu{constructor(t,s,o,r,n){a(this,"disposers",[]);a(this,"activatableDisposers",[]);this.model=t,this.modelData=s,this.modelId=o,this.offlineQueue=r,this.log=n}registerAll(t){var r;const s=((r=this.modelData)==null?void 0:r[G])||{},o=Object.keys(s);this.log.debug(`Found ${o.length} subscriptions in ${this.modelId} (lifecycle: ${t??"any"})`),o.forEach(n=>{const i=s[n],c=i.lifecycle;if(t&&t!==c)return;const l=this.resolvePropKey(n);this.log.debug(`Resolved topic: ${n} → ${l}`);const d=this.createHandler(l,i);this.subscribe(i,l,d,c===x.ACTIVATE)})}deactivate(){this.log.debug(`Deactivating subscriptions for ${this.modelId}`);for(const t of this.activatableDisposers)try{t()}catch(s){this.log.error("Error during subscription disposal",s)}this.activatableDisposers=[]}disposeAll(){const t=[...this.disposers,...this.activatableDisposers];this.log.debug(`Disposing ${t.length} subscriptions for ${this.modelId}`);for(const s of t)try{s()}catch(o){this.log.error("Error during subscription disposal",o)}this.disposers=[],this.activatableDisposers=[]}subscribe(t,s,o,r){const n=t.destinationAddress?this.resolvePropKey(t.destinationAddress):null;if(t.websocket){this.log.debug(`Subscribing to WebSocket topic: ${s}`);const i=Kt.getInstance().subscribeTopic({topic:s,callback:o,fos:t.fos,bridge:t.bridge,destinationAddress:n});this.disposers.push(i)}else{this.log.debug(`Subscribing to EventBus topic: ${s}`);const{unsubscribe:i}=j(s,o);r?this.activatableDisposers.push(i):this.disposers.push(i)}}createHandler(t,s){return async o=>{var r;try{const n=(r=o==null?void 0:o.headers)==null?void 0:r["src-addr"],i=s.destinationAddress&&this.resolvePropKey(s.destinationAddress),c=i?n===i:!0;if(this.model.isReady()){const l=ho(o,s.skipParse),d=s.transform(l);if(c&&s.condition(d,this.modelData,o))return s.handler.call(this.modelData,d,o,this.modelData)}else{this.log.warn(`Model ${this.modelId} not ready. Queuing message for ${t}`);const l=()=>{const d=ho(o,s.skipParse),u=s.transform(d);if(c&&s.condition(u,this.modelData,o))return s.handler.call(this.modelData,u,o,this.modelData)};this.offlineQueue.enqueue(l)}}catch(n){this.log.error(`Error handling subscription for ${t}`,n)}}}resolvePropKey(t){const s=/.*({PROP_(.+)})/;let o=t.includes("{MODEL_ID}")?t.replace("{MODEL_ID}",this.modelId):t;const r=o.match(s);return r&&r[2]in this.modelData&&(o=o.replace(r[1],this.modelData[r[2]])),o}}function ot(e,t){const s=`[Model:${t}]`;return{debug:(...o)=>e.debug(s,...o),info:(...o)=>e.info(s,...o),warn:(...o)=>e.warn(s,...o),error:(...o)=>e.error(s,...o)}}function su(e){return!!(e!=null&&e[$e])&&Object.keys(e[$e]).length>0}function ou(e){return!!(e!=null&&e[G])&&Object.keys(e[G]).length>0}class ru{static createAll(t){const{modelId:s,modelTypeName:o,modelData:r}=t,n=Bd.create({modelId:s,modelTypeName:o}),i=new jd(t,ot(n,"fsm")),c=new Kd(ot(n,"offline-queue")),l=new Rd(t),d=new Cd(t),u={fsm:i,offlineQueue:c,companionManager:l,childResolver:d};if(su(r)&&(u.effectManager=new Ld(o,s,r,ot(n,"effect"))),ou(r)){const g=ot(n,"subscription");u.subscriptionManager=new tu(t,r,s,c,g),u.onlineLifecycleManager=new Gd(t,ot(n,"online"))}return u}}const S=T.getLogger("kos-model"),Fr="kos.extension.model.loader";class vi{constructor({modelTypeName:t,id:s,modelData:o}){a(this,"_id");a(this,"_status");a(this,"_activeStatus");a(this,"_onlineStatus");a(this,"modelData");a(this,"modelTypeName");a(this,"initialized");a(this,"loaded");a(this,"offlineQueue");a(this,"subscriptionManager");a(this,"effectManager");a(this,"onlineLifecycleManager");a(this,"companionManager");a(this,"childResolver");a(this,"fsm");this._id=typeof s<"u"?`${s}`:t,this.modelTypeName=t,this.initialized=!1,this.loaded=!1,this.modelData=o,this._status=p.CREATED,this._activeStatus=p.INACTIVE,this._onlineStatus=p.OFFLINE;const r=ru.createAll(this);this.fsm=r.fsm,this.offlineQueue=r.offlineQueue,this.companionManager=r.companionManager,this.childResolver=r.childResolver,r.effectManager&&(this.effectManager=r.effectManager),r.subscriptionManager&&(this.subscriptionManager=r.subscriptionManager),r.onlineLifecycleManager&&(this.onlineLifecycleManager=r.onlineLifecycleManager),w.makeAutoObservable(this,{fsm:!1,effectManager:!1,subscriptionManager:!1,onlineLifecycleManager:!1,companionManager:!1,childResolver:!1,offlineQueue:!1}),Sd(this)}get companionModels(){return this.companionManager}set status(t){this._status=t}get status(){return this._status}get modelId(){return this._id}get id(){return this._id}get activeStatus(){return this._activeStatus}set activeStatus(t){this._activeStatus=t}get onlineStatus(){return this._onlineStatus}set onlineStatus(t){this._onlineStatus=t}get modelManager(){return globalThis.kos.modelManager}isActive(){return this._status===p.ACTIVE}isOnline(){return this._onlineStatus===p.ONLINE}isReady(){return this._status===p.READY}async deactivate(){var t,s,o;S.debug(`deactivating model ${this.modelTypeName} with id ${this.modelId}`);try{const r=P.getContext(this.modelId);await((s=(t=this.modelData)==null?void 0:t.deactivate)==null?void 0:s.call(t,r)),S.debug(`Model ${this.modelTypeName} with id ${this.modelId} deactivated`),(o=this.subscriptionManager)==null||o.deactivate()}catch(r){throw S.debug(`Model ${this.modelId} failed to deactivated`),r}}async activate(){var t,s,o;S.debug(`activating model ${this.modelTypeName} with id ${this.modelId}`),await it(this,x.ACTIVATE);try{const r=P.getContext(this.modelId);await((s=(t=this.modelData)==null?void 0:t.activate)==null?void 0:s.call(t,r)),S.debug(`Model ${this.modelTypeName} with id ${this.modelId} subscribing to all topics`),(o=this.subscriptionManager)==null||o.registerAll(x.ACTIVATE),S.debug(`Model ${this.modelTypeName} with id ${this.modelId} activated`)}catch(r){throw S.debug(`Model ${this.modelId} failed to activate`),r}}async whenInitialized(){await kr([{condition:()=>this.status===p.FAILED,onMatch:()=>{throw new Error(`Failed to initialize model ${this.modelId}`)}},{condition:()=>this.initialized,onMatch:()=>{S.debug(`Model ${this.modelId} is initialized`)}}])}async whenReady(){await kr([{condition:()=>this.status===p.FAILED,onMatch:()=>{throw new Error(`Failed to ready model ${this.modelId}`)}},{condition:()=>this.status===p.READY,onMatch:()=>{S.debug(`Model ${this.modelId} is ready`)}}])}async ready(){var t,s,o;if(this.fsm.current===p.READY){S.debug(`already readying model ${this.modelTypeName} with id ${this.modelId} returning`);return}try{S.debug(`readying model ${this.modelTypeName} with id ${this.modelId}`),await it(this,x.READY),await ni(this,Uo.READY,x.READY);const r=P.getContext(this.modelId);await((s=(t=this.modelData)==null?void 0:t.ready)==null?void 0:s.call(t,r)),this.offlineQueue.flush(),(o=this.subscriptionManager)==null||o.registerAll(x.READY),S.debug(`Model ${this.modelId} is ready`);const n={modelId:this.modelId,modelType:this.modelTypeName};F(Yn(this.modelTypeName,this.modelId),n),F(zn(this.modelTypeName),n)}catch(r){throw S.error(r),Error(r)}}async load(){var o,r,n,i;const{modelTypeName:t,modelId:s}=this;if(this.fsm.current===p.LOADED||this.fsm.current===p.LOADING){S.debug(`Model ${t} with id ${s} already loaded or loading`);return}S.debug(`Loading model ${t} with id ${s}`),await it(this,x.LOAD);try{const c=P.getContext(s),l=await C.loader.executeLoader(Fr,{});l&&(S.info(`Setting loaded context for ${s}, type: ${t}`),c==null||c.set(Fr,l)),await((r=(o=this.modelData)==null?void 0:o.load)==null?void 0:r.call(o,c)),this.loaded=!0,S.debug(`Model ${t} with id ${s} successfully loaded`),(n=this.subscriptionManager)==null||n.registerAll(x.LOAD),(i=this.effectManager)==null||i.setup()}catch(c){throw S.error(`Model ${s} failed to load`,c),c}}async unload(){var t,s,o,r,n;S.debug(`unloading model ${this.modelTypeName} with id ${this.modelId}`);try{const i=this.getChildren().map(l=>{var d;return(d=l.unload)==null?void 0:d.call(l)}).filter(l=>!!l);await Promise.allSettled(i);const c=P.getContext(this.modelId);await((s=(t=this.modelData)==null?void 0:t.unload)==null?void 0:s.call(t,c)),this.loaded=!1,(o=this.onlineLifecycleManager)==null||o.dispose(),S.debug(`Model ${this.modelTypeName} with id ${this.modelId} unloaded`),(r=this.effectManager)==null||r.disposeAll(),(n=this.subscriptionManager)==null||n.disposeAll()}catch(i){throw S.debug(`Model ${this.modelId} failed to unload`),i}}async init(){var r,n,i;const{modelId:t,modelTypeName:s}=this,o=P.getContext(t);S.debug(`Initializing model ${s} with id ${t}`),await it(this,x.INIT);try{await((n=(r=this.modelData)==null?void 0:r.init)==null?void 0:n.call(r,o)),this.initialized=!0,S.debug(`Model ${s} with id ${t} initialized`),(i=this.onlineLifecycleManager)==null||i.register(),this.registerSubscribers(x.INIT)}catch(c){throw S.error(`Model ${t} failed to initialize`,c),c}}async registerSubscribers(t){var s;S.debug(`registering subscribers in ${this.modelTypeName} with id ${this.modelId}`),(s=this.subscriptionManager)==null||s.registerAll(t)}async online(){var s,o;S.debug(`online model ${this.modelTypeName} with id ${this.modelId}`),this.registerSubscribers();const t=P.getContext(this.modelId);await((o=(s=this.modelData)==null?void 0:s.online)==null?void 0:o.call(s,t))}async offline(){var s,o,r;S.debug(`offline model ${this.modelTypeName} with id ${this.modelId}`),(s=this.subscriptionManager)==null||s.disposeAll();const t=P.getContext(this.modelId);await((r=(o=this.modelData)==null?void 0:o.offline)==null?void 0:r.call(o,t))}accept(t){t.visit(this)}getChildren(){return this.childResolver.resolve()}addCompanionModel(t){this.companionManager.add(t)}clearCompanionModels(){this.companionManager.clear()}}const Mi=e=>typeof e=="function",Ur=f.createLogger({name:"kos-model-instantiator"});class nu{constructor(t,s){this.registry=t,this.cache=s}createModelInstance(t,s,o={}){const r=this.registry.models[t];if(!r)throw new Error(`No model registered for type ${t}`);const n=r.singleton?t:s;if(this.cache.restoreFromDeleteCache(n),!this.cache.hasModel(n)){Ur.debug(`Creating model instance: ${t} [${n}]`);const c=r.create?r.create({modelTypeId:t,id:n,options:o}):new r.class(n,o),l=new vi({modelTypeName:t,id:n,modelData:c});this.cache.addModel(l),this._createCompanionModels(l,o)}const i=this.cache.getModelById(n);if(!i)throw Ur.error(`Model ${t} [${n}] not found in cache`),new Error(`Model ${t} [${n}] not found in cache`);return{model:i,data:i.modelData}}_createCompanionModels(t,s){var n;const o=t.modelTypeName,r=((n=this.registry.companionModels)==null?void 0:n[o])||[];for(const{type:i}of r){const c=Mi(i)?i(t.modelData,s):i;if(!c)continue;const l=`${c}-${t.modelId}`,d=this.createModelInstance(c,l,{data:s,companionParent:t.modelData,kosParentId:t.modelId});d!=null&&d.model&&t.addCompanionModel(d.model)}}}let iu=class{constructor(t){this._registry=t}get registry(){return this._registry}getModelTypeRegistry(t){const s=this.registry.models[t];if(!s)throw new Error(`No registration for model type ${t}`);return s}registerModel(t){const s=t.type;this.registry.models[s]||(this.registry.models={...this.registry.models,...t.registration})}registerCompanionModel(t,s){var o,r;(o=this.registry).companionModels??(o.companionModels={}),(r=this.registry.companionModels)[t]??(r[t]=[]),this.registry.companionModels[t].some(n=>n.type===s)||this.registry.companionModels[t].push({type:s})}getModelSubscriptions(t){var s;return((s=this.getModelTypeRegistry(t))==null?void 0:s.subscriptions)||{}}getDataModelBuilder(t){var o;const s=(o=this.getModelTypeRegistry(t))==null?void 0:o.builder;if(!s)throw new Error(`No builder found for model type ${t}`);return s}getModelFactory(t){return Qe(t)}};const Ei=10,jr=f.createLogger({name:"kos-model-manager"});class _i{constructor(){a(this,"cache");a(this,"instantiator");a(this,"dependencies");a(this,"_registry");globalThis.kos=globalThis.kos||{},this.dependencies=new dd,globalThis.kos.modelManager=this,globalThis.kos.resolveKosModel=t=>{const s=this.getModelById(t);if(s)return s.modelData||{}},globalThis.kos.kosModelJson=t=>{var o,r;const s=this.getModelById(t);if(s)return((r=(o=s.modelData).toJSON)==null?void 0:r.call(o))||{}},globalThis.kos.kosModelDebug=t=>{var o;const s=this.getModelById(t);if(s)return((o=s.modelData)==null?void 0:o.debugState)||{}},globalThis.kos.kmd=globalThis.kos.kosModelDebug,globalThis.kos.kmj=globalThis.kos.kosModelJson}static create(t,s){const o=this.getInstance(s);return o._registry=new iu(t),o.cache=new ud(t.preloadModels),o.instantiator=new nu(t,o.cache),o}static getInstance(t){var s,o;return(!((s=globalThis.kos)!=null&&s.modelManager)||t)&&(jr.debug("Creating new instance of KosModelManager"),new this),(o=globalThis.kos)==null?void 0:o.modelManager}get registry(){return this._registry.registry}get preloadedModels(){return this.cache.preload(t=>(jr.debug(`preloading ${t}`),typeof t=="string"?this.createModelInstance(t).model:this.createModelInstance(t.modelType,t.modelId,t.options).model))}get models(){return this.cache.models}getModelById(t){return this.cache.getModelById(t)}addModel(t){return this.cache.addModel(t)}removeModel(t){this.cache.removeModel(t.modelId)}hasModel(t){return this.cache.hasModel(t)}getModelsByType(t,s){return Array.from(this.models).filter(o=>o.modelTypeName===t).filter(o=>s?s(o.modelData):!0).map(o=>o.modelData)}getModelSubscriptions(t){return this._registry.getModelSubscriptions(t)}getDataModelBuilder(t){return this._registry.getDataModelBuilder(t)}getModelFactory(t){return Qe(t)}addDependency(t,s){this.cache.restoreFromDeleteCache(s),this.dependencies.add(t,s)}removeDependency(t,s){this.dependencies.remove(t,s)}async reloadModel(t){if(t.id){const s=this.getModelById(t.id);s&&await s.fsm.transitionTo(O.RESET,p.RESETTING)}}async initiateDestroyModel(t){if(!t.id)throw new Error("Model ID is required");if(!this.dependencies.canDestroy(t.id))return;const s=this.getModelById(t.id);s&&(this.cache.markForDeletion(s),Fn.addToDeletionQueue(t.id,setTimeout(()=>this.destroyModel(s),Ei)))}async destroyModel(t){var s;t!=null&&t.modelId&&this.dependencies.canDestroy(t.modelId)&&(await((s=t.unload)==null?void 0:s.call(t)),this.removeModel(t))}createModelInstance(t,s,o={}){return this.instantiator.createModelInstance(t,s,o)}registerCompanionModel(t,s){this._registry.registerCompanionModel(t,s)}registerModel(t){this._registry.registerModel(t)}}const au=async({context:e,extension:t})=>{const s=await C.loader.executeLoader(t,{});return e==null||e.set(t,s),s},cu=async({extension:e,contextData:t,data:s})=>await C.dataMapper.executeMapper(e,s,t),lu=async({extension:e,contextData:t,data:s})=>await C.propertyMapper.executeMapper(e,s,t),du=Object.freeze(Object.defineProperty({__proto__:null,executeDataMapperExtension:cu,executeLoaderExtension:au,executePropertyMapperExtension:lu},Symbol.toStringTag,{value:"Module"})),uu="Extensions";class hu{constructor(){a(this,"extensions");this.extensions={}}register(t,s,o){this.extensions[t]={},this.extensions[t][s]={component:o}}get(t,s){if(!this.extensions[t])throw new Error(`Extension point ${t} not found`);return this.extensions[t][s]}get allExtensions(){return this.extensions}}var is=(e=>(e.CREATING="creating",e.CREATED="created",e.INITIALIZING="initializing",e.INITIALIZED="initialized",e.LOADING="loading",e.LOADED="loaded",e.ONLINE="online",e.READYING="readying",e.READY="ready",e.OFFLINE="offline",e.UNLOADING="unloading",e.UNLOADED="unloaded",e.RELOADING="reloading",e))(is||{}),Ne=(e=>(e.CREATE="create",e.INITIALIZE="init",e.READY="ready",e.GO_ONLINE="go_online",e.GO_OFFLINE="go_offline",e.UNLOAD="unload",e.RELOAD="reload",e))(Ne||{});const gu=e=>{const t=m.createMachine("offline",{online:m.state(m.transition("go_offline","offline",m.action(()=>{e.offline(),w.runInAction(()=>{e.isOnline=!1})}))),offline:m.state(m.transition("go_online","online",m.action(()=>{e.online(),w.runInAction(()=>{e.isOnline=!0})})))}),s=m.interpret(t,n=>T.debug(n.machine.current)),o=m.createMachine({creating:m.state(m.transition("create","created")),created:m.state(m.immediate("initializing")),initializing:m.invoke(()=>e.init(),m.transition("done","initialized")),initialized:m.state(m.immediate("loading")),loading:m.invoke(()=>e.load(),m.transition("done","loaded")),loaded:m.state(m.immediate("readying"),m.transition("unload","unloading")),readying:m.invoke(()=>e.ready(),m.transition("done","ready",m.action(()=>{w.runInAction(()=>{e.status="ready"})}))),reloading:m.invoke(()=>e.reload(),m.transition("done","loading")),ready:m.state(m.transition("reload","reloading"),m.transition("unload","unloaded",m.action(e.unload.bind(e))),m.transition("go_online","ready",m.action(()=>{s.send("go_online")})),m.transition("go_offline","ready",m.action(()=>{s.send("go_offline")}))),unloaded:m.state()});return{service:m.interpret(o,n=>T.debug(n.machine.current)),online:s}},J=async e=>{if(e.id){const t=_.getInstance().modelManager.getModelById(e.id);if(!t)throw new Error(`Model with ID ${e.id} not found`);await(t==null?void 0:t.whenReady())}else throw new Error("Data model must have a valid ID");return e},Oe=async e=>{await _.getInstance().whenReady(),await _.getInstance().modelManager.initiateDestroyModel(e)},fu=async e=>{if(await _.getInstance().whenReady(),!e.id)throw new Error("Model ID is required");const t=_.getInstance().modelManager.getModelById(e.id);t&&await t.fsm.transitionTo(O.UNLOAD,p.UNLOADED)},Ii=async e=>{await _.getInstance().whenReady(),await _.getInstance().modelManager.reloadModel(e),f.debug(`reload model initiated for model ${e.id}, model ready: ${hs(e)} - ${Date.now()} `),await J(e),f.debug(`reload model complete for model ${e.id}, model ready: ${hs(e)} - ${Date.now()} `)},mu=async e=>{if(await _.getInstance().whenReady(),!e)throw new Error("Model ID is required");const t=_.getInstance().modelManager.getModelById(e);return t==null?void 0:t.modelTypeName},Ti=async e=>{if(await _.getInstance().whenReady(),!e)throw new Error("Model ID is required");const t=_.getInstance().modelManager.getModelById(e);return{model:t==null?void 0:t.modelData,type:t==null?void 0:t.modelTypeName}},Je=e=>{if(!e)throw new Error("Model ID is required");const t=_.getInstance().modelManager.getModelById(e);return{model:t==null?void 0:t.modelData,type:t==null?void 0:t.modelTypeName}},$i=(e,t)=>{if(!e)throw new Error("Model type is required");return _.getInstance().modelManager.getModelsByType(e).filter(r=>Object.keys(t).every(n=>r[n]===t[n]))},pu=(e,t)=>$i(e,t)[0],yu=(e,t)=>{if(!e.id)throw new Error("Model ID is required");const s=_.getInstance().modelManager.getModelById(e.id);if(!s)throw new Error("Model not found");const o=s.companionModels.get(t);return o==null?void 0:o.modelData},bu=e=>{if(!e.id)throw new Error("Model ID is required");const t=_.getInstance().modelManager.getModelById(e.id);if(!t)throw new Error("Model not found");return Array.from(t.companionModels.all()).map(o=>o.modelData)},wu=e=>{if(!e)throw new Error("Model ID is required");const t=_.getInstance().modelManager.getModelById(e);if(!t)throw new Error("Model not found");return t.companionModels.data},fo=(e,t)=>{const s=_.getInstance().modelManager.getModelById(e);if(!s){f.info(`Model not found for id ${e}`);return}return Array.from(s.companionModels.all()).find(r=>t(r.modelData))},ee=e=>t=>Object.getPrototypeOf(t).modelTypeId===e,hs=e=>{const t=_.getInstance().modelManager.getModelById(e.id);if(!t)throw new Error("Model not found");return t.isReady()},vu=f.createLogger({name:"kos-model-factory"}),It={byModelType:e=>_.getInstance().modelManager.getModelFactory(e),getModelInstance:(e,t,s)=>{const o=It.byModelType(t);if(!o)throw vu.error(`No registered factory found for model type ${t}. Please register a factory for this model type. `),Error(`No factory found for model type ${t}`);return o.build(e,s)}},H={Factory:{create:e=>t=>(s,o)=>(o&&P.setParentContext(t,o),It.getModelInstance(t,e,s))},Singleton:{create:e=>(t,s)=>(s&&P.setParentContext(e,s),It.getModelInstance(e,e,t))},Model:{instance:e=>t=>It.getModelInstance(t,e)}};window.KosRegistry=window.KosRegistry||{coreModels:new Map,preloadModels:[],companionModels:new Map,models:new Map};const Br=window.KosRegistry.coreModels,eo=window.KosRegistry.preloadModels,to=window.KosRegistry.companionModels,Wt=window.KosRegistry.models,$={model:{registerLegacyModel:e=>(t,s)=>(Br.set(t,s),{preload:$.model.preloadModel(e),model:$.model.register(e),companion:$.companion.register(e),legacy:$.model.registerLegacyModel(e),root:e}),preloadModel:e=>t=>(eo.includes(t)||eo.push(t),{preload:$.model.preloadModel(e),model:$.model.register(e),companion:$.companion.register(e),legacy:$.model.registerLegacyModel(e),root:e}),register:e=>(t,s)=>{const o=so(t)?t.registration():t;return Wt.set(o.type,o),so(t)&&t.relatedModels.forEach(r=>Wt.set(r.type,r.registration())),_.getInstance().isReady&&(_.getInstance().modelManager.registry.models[o.type]||(console.info(`Model with type ${o.type} doesn't exist. Adding new registration`),_.getInstance().modelManager.registry.models[o.type]=o.registration[o.type],so(t)&&t.relatedModels.forEach(r=>_.getInstance().modelManager.registry.models[r.type]=r.registration().registration))),s&&$.model.preloadModel(e)(o.type),{preload:$.model.preloadModel(e),model:$.model.register(e),companion:$.companion.register(e),legacy:$.model.registerLegacyModel(e),root:e}},get:e=>Wt.get(e),getAll:()=>Array.from(Wt.entries()),getPreloadModels:()=>eo,getLegacyModels:()=>Array.from(Br.entries()).reduce((e,[t,s])=>(e[t]=s,e),{})},companion:{register:e=>(t,s)=>{const o=to.get(t)||[];return o.push(s),to.set(t,o),{preload:$.model.preloadModel(e),model:$.model.register(e),companion:$.companion.register(e),legacy:$.model.registerLegacyModel(e),root:e}},getAll:()=>Array.from(to.entries())}},Oi=$.model.registerLegacyModel,Di=$.model.register,Mu=$.companion.register,Eu=$.model.preloadModel,Si=e=>typeof e.updateModel=="function",so=e=>e.registration!==void 0&&typeof e.registration=="function";class Ai{constructor(t){a(this,"singleton");a(this,"type");a(this,"class");a(this,"guard");a(this,"factory");a(this,"relatedModels",[]);this.singleton=t.singleton,this.guard=ee(t.type),this.type=t.type,this.factory=t.factory,this.class=t.class}addRelatedModel(t){this.relatedModels.push(t)}registerRelatedModels(){this.relatedModels.forEach(t=>t.register())}register(){$.model.register({})(this.registration()),this.registerRelatedModels()}}class le extends Ai{constructor(t){super({...t,singleton:!1,factory:H.Factory.create(t.type)})}instance(t){const s=this.factory(t);return{get:()=>{const o=Je(t);if(!o)throw new Error("Model not found with id "+t);if(this.guard(o))return o;throw new Error("Model is not of type "+this.type)},forceUpdate:{options:o=>({build:()=>{const r=s(o);if(this.guard(r)){if(Si(r))r.updateModel(o);else throw new Error(`Model ${this.type} is not updateable. Please implement UpdateAware interface`);return r}else throw new Error("Model is not of type "+this.type)}})},options:o=>({build:()=>{const r=s(o);if(this.guard(r))return r;throw new Error("Model is not of type "+this.type)}})}}registration(){return{type:this.type,predicate:this.guard,registration:{[this.type]:{class:this.class,singleton:!1}},factory:this.factory}}}class we extends Ai{constructor(t){super({...t,singleton:!0,factory:H.Singleton.create(t.type)})}instance(){const t=this.factory;return{get:()=>{const o=Je(this.type);if(!o)throw new Error("Model not found with id "+this.type);if(this.guard(o))return o;throw new Error(`Model is not of type ${this.type}. Received type ${Object.getPrototypeOf(o).modelTypeId}`)},forceUpdate:{options:o=>({build:()=>{const r=t(o);if(this.guard(r)){if(Si(r))r.updateModel(o);else throw new Error(`Model ${this.type} is not updateable. Please implement UpdateAware interface`);return r}else throw new Error(`Model is not of type ${this.type}. Received type ${Object.getPrototypeOf(r).modelTypeId}`)}})},options:o=>({build:()=>{const r=t(o);if(this.guard(r))return r;throw new Error(`Model is not of type ${this.type}. Received type ${Object.getPrototypeOf(r).modelTypeId}`)}})}}registration(){return{type:this.type,predicate:this.guard,registration:{[this.type]:{class:this.class,singleton:!0}},factory:this.factory}}}const U=f.createLogger({name:"kos-core"}),_u=()=>{const e=window.location.protocol,t=ae(),s=t==null?void 0:t.host;let o;try{o=new URL(s).protocol==="https:"?"wss://":"ws://"}catch{}return o||(e==="https:"?"wss://":"ws://")},Iu=()=>{const e=window.location.hostname,t=process.env.KOS_HOST,s=ae(),o=s==null?void 0:s.host;let r;try{r=new URL(o).hostname}catch{}return r??t??e},Tu=()=>{const e=window.location.port,t=process.env.KOS_PORT,s=ae(),o=s==null?void 0:s.host;let r;try{r=new URL(o).port}catch{}return r??t??e},$u=(e,t)=>{let s;return{promise:new Promise((n,i)=>{s=setTimeout(()=>{t?f.error(`Model ${t.modelId} - ${t.modelTypeName} preloading - timed out after ${e}ms`):f.error(`KOS Core preloading timed out after ${e}ms`),i(new Error(`Model ${t==null?void 0:t.modelId} - ${t==null?void 0:t.modelTypeName} - timed out after ${e}ms`))},e)}),cancel:()=>{s&&clearTimeout(s)}}},Kr=e=>typeof e.reload=="function",Ou=e=>typeof e.unload=="function";var Ci=(e=>(e.LOGGED_IN="logged_in",e.LOGGED_OUT="logged_out",e))(Ci||{});class _{constructor(t){a(this,"fsmService");a(this,"status");a(this,"initialized");a(this,"loaded");a(this,"_transport");a(this,"modelManager");a(this,"authState");a(this,"isOnline");a(this,"_reloading");a(this,"_unloading");a(this,"connectionAlias");this.initialized=!1,this.connectionAlias=t,this.loaded=!1,this.isOnline=!1,this.status=is.CREATED,this.authState="logged_out",this._reloading=!1,this._unloading=!1,w.makeAutoObservable(this),j("token",c=>{c&&(this.transport.token=c.body)}),j(_t.CONNECTED,async()=>{await this.whenReady(),this.fsmService.service.send(Ne.GO_ONLINE)}),j(_t.DISCONNECTED,async()=>{this.fsmService.service.send(Ne.GO_OFFLINE)}),j("/studioServer/auth/LOGGED_IN",()=>{this.authState="logged_in",this.transport.authorized=!0}),j("/studioServer/auth/LOGIN_REQUIRED",()=>{this.authState="logged_out",this.transport.authorized=!1}),j(_t.RELOAD,()=>{this.fsmService.service.send(Ne.RELOAD)}),j("/studio/project/reload",()=>{this.fsmService.service.send(Ne.RELOAD)});const s=Kt.getInstance(),o=Iu(),r=Tu(),n=_u();s.host=o,s.port=Number.parseInt(r),s.protocol=n,process.env.KOS_ALLOW_ANONYMOUS==="true"&&(s.authorized=!0);const i=t||process.env.KOS_CONNECTION_ALIAS;i&&(s.alias=i.replace("{{TIMESTAMP}}",Date.now().toString())),this._transport=s.init(),this.fsmService=gu(this),this.fsmService.service.send(Ne.CREATE)}get onlineStatus(){return this.isOnline&&!this._reloading&&!this._unloading}get reloading(){return this._reloading}get unloading(){return this._unloading}async reload(){var r,n,i,c;const t=Date.now();if(this._reloading){U.info("reload already in progress");return}this._reloading=!0,U.warn("reloading KOS Core"),U.warn("reloading preloaded models");const s=this.modelManager;for(const l of s.preloadedModels)Kr(l.modelData)&&(U.info(`reloading model ${l.modelId}`),(r=l.unload)==null||r.call(l),await l.modelData.reload(),(n=l.registerSubscribers)==null||n.call(l),U.info(`reloading model ${l.modelId} complete`));for(const l of s.models)!s.preloadedModels.includes(l)&&Kr(l.modelData)&&((i=l.unload)==null||i.call(l),await l.modelData.reload(),(c=l.registerSubscribers)==null||c.call(l));const o=Date.now()-t;setTimeout(()=>{w.runInAction(()=>{U.warn("reloading KOS Core complete"),this._reloading=!1})},1e3-o)}async online(){U.debug("KOS Core going online"),await this._transport.whenReady(),U.debug("KOS Transport Ready. Calling online() for models"),F("/kosCore/online","/kosCore/online"),console.timeEnd("kosCore:startup")}async offline(){U.debug("KOS Core going offline"),F("/kosCore/offline","/kosCore/offline")}async unload(){var r;U.debug("Unloading KOS Core");const t=Date.now();this._unloading=!0,U.debug("unloading KOS Core");const s=this.modelManager;for(const n of s.models)Ou(n.modelData)&&((r=n.unload)==null||r.call(n));const o=Date.now()-t;setTimeout(()=>{w.runInAction(()=>{this._unloading=!1})},1e3-o)}async whenReady(){await w.when(()=>this.status===is.READY)}async ready(){U.debug("Readying KOS Core"),await this._transport.whenReady();const t=this.modelManager.preloadedModels.map(r=>({modelId:r.modelId,model:r,promise:r.whenReady()})),o=(await Promise.allSettled(t.map(r=>{const{promise:n,cancel:i}=$u(5e3,r.model);Promise.race([r.promise.then(()=>{i()}),n])}))).filter(r=>r.status==="rejected");if(o.length)throw U.error(`There were ${o.length} failed models on model preloading`),Error(`There were ${o.length} failed models on model preloading`);U.debug("leaving kos-core ready() ")}get isReady(){return this.status===is.READY}set transport(t){this._transport=t}get transport(){return this._transport}get coreInitialized(){return this.initialized}get modelsLoaded(){return this.loaded}async init(){U.debug("entering kos-core init()"),console.time("kosCore:startup"),console.time("kosCore:init"),await this._transport.whenReady(),this.initialized=!0,U.debug("initialized - leaving kos-core init()"),console.timeEnd("kosCore:init")}async load(){U.debug("entering kos-core load()"),console.time("kosCore:load"),this.loaded=!0,U.debug("loaded - leaving kos-core load()"),console.timeEnd("kosCore:load")}static create(t,s,o){var i,c,l;const r=this.getInstance({reset:s,connectionAlias:o});(i=t.extensions)!=null&&i.dataMapper&&Object.keys(t.extensions.dataMapper).forEach(d=>{var g,y;const u=(y=(g=t.extensions)==null?void 0:g.dataMapper)==null?void 0:y[d];u&&(Array.isArray(u)?u.forEach(v=>{C.dataMapper.registerDataMapper(d,v)}):C.dataMapper.registerDataMapper(d,u))}),(c=t.extensions)!=null&&c.propertyMapper&&Object.keys(t.extensions.propertyMapper).forEach(d=>{var g,y;const u=(y=(g=t.extensions)==null?void 0:g.propertyMapper)==null?void 0:y[d];u&&C.propertyMapper.registerPropertyMapper(d,u)}),(l=t.extensions)!=null&&l.contextLoader&&Object.keys(t.extensions.contextLoader).forEach(d=>{var g,y;const u=(y=(g=t.extensions)==null?void 0:g.contextLoader)==null?void 0:y[d];u&&C.loader.registerLoader(d,u)}),$.model.getAll().forEach(([,d])=>{t.models={...t.models,...d.registration}}),t.models={...t.models,...$.model.getLegacyModels()},$.companion.getAll().forEach(([d,u])=>{t.companionModels={...t.companionModels},t.companionModels[d]=t.companionModels[d]||[];for(const g of u)t.companionModels[d].push({type:g})}),$.model.getPreloadModels().forEach(d=>{t.preloadModels.includes(d)||t.preloadModels.push(d)});const n=_i.create(t,s);return r.modelManager=n,r}static getInstance(t){return this._instance=window.KosCore,(!this._instance||t!=null&&t.reset)&&(window.KosCore=new this(t==null?void 0:t.connectionAlias),this._instance=window.KosCore),this._instance}}a(_,"_instance");const Gr=f.createLogger({name:"kos-fetch"}),Du=process.env.KOS_WS_TIMEOUT?parseInt(process.env.KOS_WS_TIMEOUT):3e4,Su=()=>new Promise(e=>{setTimeout(()=>{e(!0)},0)}),Au=e=>e!=null&&e.studio?ci:e!=null&&e.fos?li:di,Cu=async(e,t)=>{const s=_.getInstance().transport;await s.whenReady();const o=Ze(),r=new URL(e),n=`${r.pathname}${r.search}`;Gr.debug(`path: ${n}`);const i=(t==null?void 0:t.timeout)||Du,c=Au(t),l=be(c({path:n,requestId:o,method:(t==null?void 0:t.method)||"GET",destinationAddress:(t==null?void 0:t.destinationAddress)||"",ordered:t==null?void 0:t.ordered,tracker:t==null?void 0:t.tracker,bridge:t==null?void 0:t.bridge}),t==null?void 0:t.body);return new Promise(d=>{const u=new AbortController,g=setTimeout(()=>{Gr.error(`Timeout occurred - url: ${e}`),u.abort(),d({headers:lo({}),status:404,ok:!1,json:async()=>null,body:uo(""),redirected:!1,statusText:"",type:"basic",url:"",clone:function(){throw new Error("Function not implemented.")},bodyUsed:!1,arrayBuffer:function(){throw new Error("Function not implemented.")},blob:function(){throw new Error("Function not implemented.")},formData:function(){throw new Error("Function not implemented.")},text:function(){throw new Error("Function not implemented.")}})},i),{unsubscribe:y}=j(o,b=>{var I,A,te;clearTimeout(g);const E={headers:lo((b==null?void 0:b.headers)||{}),status:((I=b==null?void 0:b.headers)==null?void 0:I.status)&&parseInt((A=b==null?void 0:b.headers)==null?void 0:A.status)||200,ok:((te=b==null?void 0:b.headers)==null?void 0:te.status)==="200",json:async()=>{var ve;try{return(ve=b==null?void 0:b.body)!=null&&ve.length?JSON.parse(b.body):null}catch{throw Error("Not a JSON response")}},text:async()=>(b==null?void 0:b.body)||"",body:uo((b==null?void 0:b.body)||""),redirected:!1,statusText:"",type:"basic",url:"",clone:function(){throw new Error("Function not implemented.")},bodyUsed:!1,arrayBuffer:function(){throw new Error("Function not implemented.")},blob:function(){throw new Error("Function not implemented.")},formData:function(){throw new Error("Function not implemented.")}};y(),Su().then(()=>d(E))}),v=t!=null&&t.fos?s.fosSocket:s.socket;if(!v)throw Error(`No web socket transport available: ${t}`);v==null||v.send(l)})};exports.BASE_URL="kos:";exports.kosFetch=Cu;if(process.env.KOS_MOCK_FETCH==="true"){const e=process.env.KOS_PORT||"9999";exports.kosFetch=fetch,exports.BASE_URL=`http://localhost:${e}`}const Ru=f.createLogger({name:"kos-model-visitor",group:"kos-ui-core"});class Lu{constructor(){a(this,"visitedModels",new Set);this.visitedModels=new Set}start(t){var o;if(t.id===void 0)throw new Error("rootModel must have an id");const s=_.getInstance().modelManager.getModelById(t.id);if(!s)throw new Error(`Could not find rootModel with id: ${t.id}`);this.visitedModels.clear(),(o=s.accept)==null||o.call(s,this)}visit(t){var o;if(this.visitedModels.has(t.modelId)){Ru.info(`model ${t.modelId} already visited`);return}const s=!!this.visitModel(t.modelData,this);this.visitedModels.add(t.modelId),!s&&((o=t.getChildren)==null||o.call(t).forEach(r=>{var n;(n=r.accept)==null||n.call(r,this)}))}}const Ri=()=>({isMock:!1,URL:exports.BASE_URL}),ku=f.createLogger({name:"kos-service-request"}),Pu="errUnknown";async function Zt(e,t,s,o,r){const n=o!=null&&o.path?Object.keys(o.path).reduce((g,y)=>String(g).replace(`{${y}}`,o==null?void 0:o.path[y]),String(e)):String(e),i=o!=null&&o.query?Object.keys(o.query).map(g=>`${g}=${o.query[g]}`).join("&"):"",c=`${Ri().URL}${n}${i?`?${encodeURIComponent(i)}`:""}`;ku.debug(`fullUrl: ${c}`);const l={method:String(t).toUpperCase(),body:null,...s};r&&(l.body=JSON.stringify(r));const d=await exports.kosFetch(c,l);return d.status<200||d.status>=400?[`${d.statusText||Pu}`,null]:[null,(await d.json()).data]}function Ko(){return{get:(e,t,s)=>Zt(e,"get",s,t),post:(e,t,s,o)=>Zt(e,"post",o,t,s),put:(e,t,s,o)=>Zt(e,"put",o,t,s),delete:(e,t,s)=>Zt(e,"delete",s,t)}}class Li{constructor(){a(this,"middlewares",[])}use(t){this.middlewares.push(t)}async execute(t){let s=0;const o=async()=>{s++,s<this.middlewares.length&&await this.middlewares[s](t,o)};await this.middlewares[s](t,o)}}const xu=async(e,t)=>{const s=new Li;t.forEach(r=>s.use(r));const o={data:e,result:{}};return await s.execute(o),o.result},Qe=e=>({type:e,build:(t,s)=>_.getInstance().modelManager.createModelInstance(e,t,s).data,buildAsync:async(t,s)=>{const o=_.getInstance().modelManager.createModelInstance(e,t,s);return await o.model.whenInitialized(),o.data}}),Nu=e=>{_.getInstance().modelManager.registerModel(e)},Fu=(e,t)=>{_.getInstance().modelManager.registerCompanionModel(e,t)},ki=Symbol("KosObservableData");class Pi{constructor(){a(this,"map");a(this,"atomMap",new Map);a(this,"proxyHandler",{get:(t,s)=>{var o;return t[s]!==void 0?t[s]:this.atomMap.has(s)&&(o=this.atomMap.get(s))!=null&&o.reportObserved()?this.getValue(s):this.getValue(s)},set:(t,s,o)=>{var r;return this.setValue(s,o),this.atomMap.has(s)||this.atomMap.set(s,w.createAtom(s.toString())),(r=this.atomMap.get(s))==null||r.reportChanged(),!0},ownKeys:()=>Array.from(this.map.keys())});this.map=w.observable.map(new Map)}setValue(t,s){this.map.set(t,s)}getValue(t){return this.map.get(t)}has(t){return this.map.has(t)}get entries(){return Array.from(this.map.entries())}get keys(){return Array.from(this.map.keys())}get values(){return Array.from(this.map.values())}setValues(t){t&&Object.keys(t).forEach(s=>{this.setValue(s,t[s])})}get proxy(){return new Proxy(this,this.proxyHandler)}}Pi.prototype[ki]=!0;function Uu(e,t){return new Proxy(e,{construct:(s,o)=>{const r=new e(...o);return r.setValues(t),r.proxy}})}const pe=e=>{const t=Uu(Pi,e);return new t(e)},Hr="/kos/ui/internal/heartbeat/",ju=({relationshipId:e,destinationAddress:t,onAbort:s,waitTime:o,beatTime:r})=>{const n=_.getInstance().transport,i=new AbortController;let c=performance.now();const l=n.subscribeTopic({topic:`${Hr}${e}`,callback:()=>{c=performance.now()}}),d=o??3e3,u=window.setInterval(()=>{let E=performance.now()-c;E=E/1e3,E>d/1e3&&i.abort()},d),g=r??2e3,y=window.setInterval(()=>{yi({msg:{},options:{topic:`${Hr}${e}`,destinationAddress:t}})},g),v=()=>{window.clearInterval(y),window.clearInterval(u),l()},b=()=>{v(),s&&s(),i.signal.removeEventListener("abort",b)};return i.signal.addEventListener("abort",b),{cleanUpHeartbeat:v}},xi=(...e)=>t=>e.reduce((s,o)=>o(s),t),Bu={maxAttempts:5,baseDelayMs:100,backoffFactor:1.5};async function Ku(e,t){let s=1;const o={...Bu,...t},{maxAttempts:r,baseDelayMs:n,backoffFactor:i}=o;let c=n;for(;s<=r;)try{return await e()}catch(l){if(f.error(`Attempt ${s} failed: ${l}`),s<r)c=n*Math.pow(i,s),await new Promise(d=>setTimeout(d,c)),s++;else throw l}throw new Error("All attempts failed")}const Gu=f.createLogger({name:"kos-service-request"}),q=e=>({isMock:!1,URL:exports.BASE_URL}),Hu=(e,t,s)=>async({id:o,tracker:r,urlOverride:n,ordered:i,studio:c,fos:l,bridge:d,destinationAddress:u})=>{const g={method:"DELETE"};e&&(g.destinationAddress=e),r&&(g.tracker=r),Xe(g,{ordered:i,studio:c,fos:l,bridge:d,destinationAddress:u});const y=await s(n||`${t}/${o}`,g);if(!y.ok)throw Error(`There was a problem deleting the model; returned status ${y.status}`);return await y.json()},Xe=(e,{ordered:t,studio:s,fos:o,destinationAddress:r,bridge:n,timeout:i})=>(i&&(e.timeout=i),t&&(e.ordered=t),s&&(e.studio=s),o&&(e.fos=o),n&&(e.bridge=n),(r||r==="")&&(e.destinationAddress=r),e),Vu=(e,t,s)=>async({urlOverride:o,ordered:r,studio:n,fos:i,bridge:c,timeout:l,destinationAddress:d})=>{const u={method:"GET"};e&&(u.destinationAddress=e),Xe(u,{timeout:l,ordered:r,studio:n,fos:i,bridge:c,destinationAddress:d});const y=await s(o||t,u);if(!y.ok){let b;try{b=await y.json()}catch{}throw new ne(`There was a problem retrieving the model; returned status ${y.status}`,b)}return await y.json()},Yu=(e,t,s)=>async({urlOverride:o,ordered:r,studio:n,fos:i,bridge:c,tracker:l,timeout:d,destinationAddress:u})=>{const g={method:"GET"};e&&(g.destinationAddress=e),l&&(g.tracker=l),Xe(g,{timeout:d,ordered:r,studio:n,fos:i,bridge:c,destinationAddress:u});const y=o||t;Gu.debug(`resolvedUrl: ${y}`);const v=await s(y,g);if(!v.ok){let E;try{E=await v.json()}catch{}throw new ne(`There was a problem retrieving the model; returned status ${v.status}`,E)}return await v.json()},zu=(e,t,s)=>async({urlOverride:o,id:r,ordered:n,studio:i,fos:c,bridge:l,timeout:d,destinationAddress:u})=>{const g={method:"GET"};e&&(g.destinationAddress=e),Xe(g,{timeout:d,ordered:n,studio:i,fos:c,bridge:l,destinationAddress:u});const y=o||`${t}/${r}`,v=await s(y,g);if(!v.ok){let E;try{E=await v.json()}catch{}throw new ne(`There was a problem retrieving the model; returned status ${v.status}`,E)}return await v.json()};class ne extends Error{constructor(s,o){super(s);a(this,"payload");this.name="FetchException",this.payload=o}}const Vr=(e,t,s)=>async({model:o,urlOverride:r,ordered:n,tracker:i,studio:c,fos:l,bridge:d,timeout:u,destinationAddress:g})=>{const y={method:"POST",body:typeof o=="string"?o:JSON.stringify(o)};e&&(y.destinationAddress=e),i&&(y.tracker=i),Xe(y,{timeout:u,ordered:n,studio:c,fos:l,bridge:d,destinationAddress:g});const v=await s(r||t,y);if(!v.ok){let E;try{E=await v.json()}catch{}throw new ne(`There was a problem sending the POST data; returned status ${v.status}`,E)}return await v.json()},Yr=(e="POST",t,s,o)=>async({model:r,id:n,urlOverride:i,ordered:c,studio:l,fos:d,bridge:u,timeout:g,destinationAddress:y})=>{const v={method:e};r&&(v.body=JSON.stringify(r)),t&&(v.destinationAddress=t),Xe(v,{timeout:g,ordered:c,studio:l,fos:d,bridge:u,destinationAddress:y});const b=await o(i||`${s}/${n}`,v);if(!b.ok){let I;try{I=await b.json()}catch{}throw new ne(`There was a problem modifying the model; returned status ${b.status}`,I)}return await b.json()},V={build:({destinationAddress:e="",basePath:t,getAllPath:s,getOnePath:o,deleteModelPath:r,addModelPath:n,modifyModelPath:i,mock:c=!1})=>{const l=c?fetch:exports.kosFetch;return{getAll:Vu(e,s||t,l),getModelById:zu(e,o||t,l),getOne:Yu(e,o||t,l),addModel:Vr(e,n||t,l),deleteModel:Hu(e,r||t,l),modifyModel:Yr("POST",e,i||t,l),putModel:Yr("PUT",e,i||t,l),postModel:Vr(e,n||t,l)}}},qu=Ze(),Ni=()=>`kos-${qu}`,Wu=e=>!!e&&!e.includes("VM_SERVICE")&&e.startsWith(Ni()),Go=async(e,t=6e4)=>new Promise((s,o)=>{const{unsubscribe:r}=j(e,i=>{T.debug(`recieved response for refId ${e}: ${i}`),r(),clearTimeout(n);try{const c=i!=null&&i.body?JSON.parse(i.body):{};s(c)}catch{const c=(i==null?void 0:i.body)||{};s(c)}}),n=setTimeout(()=>{r(),o(Error(`Request with ID ${e} timed out. Cancelling.`))},t)}),Zu=async(e,t,s)=>{const o=Go(s),r=await Promise.allSettled([e(t),o]);if(r[0].status==="fulfilled"){if(r[1].status==="rejected")throw Error(r[1].reason);if(r[0].value){if(r[1].value.error)throw Error(r[1].value.error);return r[0].value.data=r[1].value,r[0].value}}else throw Error(r[0].reason)},Ju=async({topic:e,msg:t,requestId:s})=>{const o=s??Ze(),r=Go(o);F(e,t,{sync:o});const n=await r;if(n.error)throw Error(n.error);return n},de=new Map;class Fi{constructor(t){a(this,"_context");a(this,"_parent");a(this,"_id");this._id=t,this._context=new w.ObservableMap({}),this._parent="",w.makeAutoObservable(this)}setParent(t){Y(()=>{this._parent=t})}get id(){return this._id}get context(){return this._context}get parentModel(){var t;if(this._parent)return(t=Je(this._parent))==null?void 0:t.model}get(t){var s;if(this._context.has(t))return this._context.get(t);if(this._parent)return(s=de.get(this._parent))==null?void 0:s.get(t)}set(t,s){this._context.set(t,s)}remove(t){this._context.delete(t)}clear(){this._context.clear()}}const P={createContext:(e,t)=>{const s=de.get(e)??new Fi(e);if(t){if(!de.has(t))throw new Error(`Parent context ${t} does not exist`);s.setParent(t)}else e!=="root"&&s.setParent("root");return de.set(e,s),s},getContext:e=>de.get(e),deleteContext:e=>{de.delete(e)},setParentContext:(e,t)=>{var s;if(!de.has(t))throw new Error(`Parent context ${t} does not exist`);(s=de.get(e))==null||s.setParent(t)},rootContext:()=>de.get("root")};P.createContext("root");const Qu=e=>P.getContext(e.id);function Xu(e,t){return e.length!==t.length?!1:e.every(s=>t.includes(s))}class Ho{constructor({container:t,key:s}){a(this,"_container");a(this,"_map");a(this,"_key");a(this,"data");this._container=t,this._map=w.observable.map(new Map),this._key=s,this.data=pe(),this.generateIndex(),w.autorun(()=>{this._container.revision&&this.generateIndex()}),w.makeAutoObservable(this)}refresh(){this.generateIndex()}addItemToIndex(t,s,o=this._map,r=this.data){const n=o.get(t)||new Set;n.add(s),o.set(t,n),r[t]=Array.from(n)}resolveIndex(t,s){this.data.keys.filter(r=>!Object.keys(s).includes(r)).forEach(r=>{delete this.data[r],this._map.delete(r)}),Object.keys(s).forEach(r=>{const n=s[r],i=this.data[r]||[];if(Xu(n,i))f.debug(`KosContainerIndex - Index ${r} is the same`);else{this.data[r]=n;const c=t.get(r)||new Set;this._map.set(r,c)}})}generateIndex(){w.runInAction(async()=>{const t=new Map,s={};for(const o of this._container.data){const r=typeof this._key=="function"?await this._key(o):o[this._key];Array.isArray(r)?r.forEach(n=>{this.addItemToIndex(n,o,t,s)}):typeof r=="string"||typeof r=="number"?this.addItemToIndex(String(r),o,t,s):typeof r=="boolean"&&this.addItemToIndex(String(r),o,t,s)}this.resolveIndex(t,s)})}get keys(){return Array.from(this._map.keys())}get index(){return this._map}getByKey(t){const s=this._map.get(t);return s?Array.from(s):[]}}function eh(e,t,s=[]){const o=Object.getOwnPropertyDescriptors(e);return Object.keys(o).filter(i=>w.isComputedProp(e,i)).filter(i=>s.includes(i)).map(i=>w.reaction(()=>e[i],(c,l)=>{t({name:i,newValue:c,oldValue:l})}))}const rt=f.createLogger({name:"kos-container-model"});class fe{constructor(t){a(this,"_data");a(this,"_sortKey");a(this,"_revision");a(this,"_index");a(this,"_optionsMap");a(this,"_disposerMap",new Map);a(this,"_parentId");a(this,"idx");this._data=w.observable.map(new Map),this._sortKey=t==null?void 0:t.sortKey,this._revision=1;const s=t!=null&&t.extensionId?C.indexExtension.loadIndexExtensions(t.extensionId):{},o=(t==null?void 0:t.indexMap)||{};this._optionsMap={...o,...s};const r=t!=null&&t.indexMap?Object.keys(t.indexMap).reduce((n,i)=>(n[i]=void 0,n),{}):{};this._index=w.observable.map(r),this.idx=pe(),this._parentId=t==null?void 0:t.parentId,w.makeAutoObservable(this),this.init()}init(){Object.keys(this._optionsMap).forEach(t=>{const s=this._optionsMap[t],o=new Ho({container:this,key:s});this._index.set(t,o),this.idx[t]=o.data})}[Symbol.iterator](){return this.data[Symbol.iterator]()}get index(){return this._index}get revision(){return this._revision}get indexKeys(){return Array.from(this.index.keys()).reduce((t,s)=>{var o;return t[s]=(o=this.index.get(s))==null?void 0:o.keys,t},{})}sortFn(t,s){const o=this._sortKey;return o?String(t[o]).localeCompare(String(s[o]),void 0,{numeric:!0}):0}get data(){const t=Array.from(this._data.values());return this._sortKey&&t.sort(this.sortFn.bind(this)),t}increment(){w.runInAction(()=>{this._revision=this._revision+1})}addAll(t){w.runInAction(()=>{t.forEach(s=>this.addModel(s,!0))}),this.increment()}removeAll(t){w.runInAction(()=>{t.forEach(s=>this.removeModel(s,!0)),this.increment()})}addModel(t,s){this._data.set(t.id||"",t),t.id&&this._parentId&&P.setParentContext(t.id,this._parentId),s||this.increment();const o=this._disposerMap.get(t.id);o&&(o(),this._disposerMap.delete(t.id));const r=Object.entries(this._optionsMap||{}),n=Object.values(this._optionsMap||{}),i=new Map(r.map(([u,g])=>[g,u])),c=u=>{var y,v;n.includes(u.name)&&((y=this.index.get(i.get(u.name)))==null||y.refresh());const g=r.filter(([,b])=>typeof b=="function");for(const[b]of g)(v=this.index.get(b))==null||v.refresh()},l=eh(t,c,n.filter(u=>typeof u=="string")),d=w.observe(t,c);this._disposerMap.set(t.id||"",()=>[d,...l].forEach(u=>u()))}removeModel(t,s){this._data.delete(t),s||this.increment();const o=this._disposerMap.get(t);o&&(o(),this._disposerMap.delete(t))}updateModel(t){this._data.set(t.id||"",t),this.increment()}getModel(t){return this._data.get(t)}getIndexKeys(t){return this.index.has(t)?this.index.get(t).keys??[]:(rt.info(`index ${t} not found in ${Array.from(this.index.keys())}`),[])}getIndexByKey(t,s){if(this.index.has(t)){const o=this.index.get(t);return o.index.has(s)?o.getByKey(s):(rt.info(`key ${s} not found in ${t} index: ${Array.from(o.index.keys())}`),[])}else return rt.info(`index ${t} not found in ${Array.from(this.index.keys())}`),[]}async clear(){this._data.forEach(t=>{const s=t.id;Oe(t).then(()=>{rt.debug(`${s} destroyed, removing from map`),this.removeModel(s,!0)}).catch(o=>rt.error(o))}),this.increment()}filter(t,s){return this.data.filter(t,s)}sort(t){return this.data.sort(t)}map(t,s){return this.data.map(t,s)}forEach(t,s){this.data.forEach(t,s)}toJSON(){return{indexes:this.indexKeys,data:this.data.map(s=>({id:s.id,type:s.constructor.name}))}}}const oo=f.createLogger({name:"kos-data-container"});class Ui{constructor(t){a(this,"_data");a(this,"_sortKey");a(this,"_revision");a(this,"_index");a(this,"_optionsMap");a(this,"_disposerMap",new Map);a(this,"idx");this._data=w.observable.map(new Map),this._sortKey=t==null?void 0:t.sortKey,this._revision=1,this._optionsMap=(t==null?void 0:t.indexMap)||{};const s=t!=null&&t.indexMap?Object.keys(t.indexMap).reduce((o,r)=>(o[r]=void 0,o),{}):{};this._index=w.observable.map(s),this.idx=pe(),w.makeAutoObservable(this,{}),this.init()}init(){Object.keys(this._optionsMap).forEach(t=>{const s=this._optionsMap[t],o=new Ho({container:this,key:s});this._index.set(t,o),this.idx[t]=o.data})}[Symbol.iterator](){return this.data[Symbol.iterator]()}get index(){return this._index}get indexKeys(){return Array.from(this.index.keys()).reduce((t,s)=>{var o;return t[s]=(o=this.index.get(s))==null?void 0:o.keys,t},{})}get revision(){return this._revision}addAll(t){w.runInAction(()=>{t.forEach(s=>this.addModel(s))})}removeAll(t){w.runInAction(()=>{t.forEach(s=>this.removeModel(s))})}sortFn(t,s){const o=this._sortKey;return o?String(t[o]).localeCompare(String(s[o]),void 0,{numeric:!0}):0}get data(){const t=Array.from(this._data.values());return this._sortKey&&t.sort(this.sortFn.bind(this)),t}increment(){w.runInAction(()=>{this._revision=this._revision+1})}addModel(t,s){const o=w.isObservable(t)?t:w.observable.object(t),r=this._disposerMap.get(t.id);r&&(r(),this._disposerMap.delete(t.id)),this._data.set(o.id||"",o),s||this.increment();const n=w.observe(o,i=>{Object.values(this._optionsMap||{}).includes(i.name)&&this.increment()});this._disposerMap.set(o.id||"",n)}removeModel(t){this._data.delete(t),this.increment();const s=this._disposerMap.get(t);s&&(s(),this._disposerMap.delete(t))}updateModel(t){const s=w.observable.object(t);this._data.set(s.id||"",s),this.increment()}getModel(t){return this._data.get(t)}getIndexKeys(t){return this.index.has(t)?this.index.get(t).keys??[]:(oo.info(`index ${t} not found in ${Array.from(this.index.keys())}`),[])}getIndexByKey(t,s){if(this.index.has(t)){const o=this.index.get(t);return o.index.has(s)?o.getByKey(s):(oo.info(`key ${s} not found in ${t} index: ${Array.from(o.index.keys())}`),[])}else return oo.info(`index ${t} not found in ${Array.from(this.index.keys())}`),[]}async clear(){this._data.clear(),this.increment()}filter(t,s){return this.data.filter(t,s)}sort(t){return this.data.sort(t)}map(t,s){return this.data.map(t,s)}forEach(t,s){this.data.forEach(t,s)}toJSON(){return{indexes:this.indexKeys,data:this.data.map(s=>({id:s.id}))}}}class th{constructor({type:t,model:s,childRegistration:o}){a(this,"type");a(this,"childRegistration");a(this,"model");this.type=t,this.model=s,this.childRegistration=o}get factory(){return H.Factory.create(this.type)}get registration(){return{[this.type]:{class:this.model,singleton:!1,factory:this.factory},...this.childRegistration}}get predicate(){return ee(this.type)}}class sh{constructor({type:t,model:s,childRegistration:o}){a(this,"type");a(this,"model");a(this,"childRegistration");this.type=t,this.model=s,this.childRegistration=o}get factory(){return H.Singleton.create(this.type)}get registration(){return{[this.type]:{class:this.model,singleton:!0,factory:this.factory},...this.childRegistration}}get predicate(){return ee(this.type)}}class ji{constructor(){a(this,"_token");w.makeAutoObservable(this),j("token",t=>{this.token=t==null?void 0:t.body})}get token(){return this._token}set token(t){this._token=t}}class Bi{constructor(){a(this,"routes",[]);a(this,"openApiRoutes",[])}use(t,s,...o){this.routes.push({method:t,path:s,middlewares:o});const r=this.extractOpenApiParams(s);this.openApiRoutes.push({method:t,path:s,parameters:r})}async handle(t,s){var c;const{path:o,query:r,params:n}=this.extractPathParams(t.path),i={...t,params:n,query:r};for(const l of this.routes){const d=this.matchRoute(l.path,o);if(l.method===t.method&&d){i.params=d;let u=0;const g=async()=>{if(u<l.middlewares.length){const y=l.middlewares[u++];await y(i,s,g)}};await g();return}}(c=s.status)==null||c.call(s,404).send({error:"Route not found"})}extractOpenApiParams(t){return t.split("/").filter(s=>s.startsWith(":")).map(s=>({name:s.slice(1),in:"path",required:!0,schema:{type:"string"}}))}generateOpenApiSpec(){const t={};for(const s of this.openApiRoutes)t[s.path]||(t[s.path]={}),t[s.path][s.method.toLowerCase()]={summary:s.description||`Handles ${s.method} ${s.path}`,parameters:s.parameters||[],responses:{200:{description:"Successful response"}}};return{openapi:"3.0.0",info:{title:"Kos Router API",version:"1.0.0",description:"Dynamically generated OpenAPI documentation"},paths:t}}extractPathParams(t){const[s,o]=t.split("?"),r=this.parseQueryParams(o);for(const n of this.routes){const i=this.matchRoute(n.path,s);if(i)return{path:s,query:r,params:i}}return{path:s,query:r,params:{}}}matchRoute(t,s){const o=t.split("/").filter(Boolean),r=s.split("/").filter(Boolean);if(o.length!==r.length)return null;const n={};for(let i=0;i<o.length;i++)if(o[i].startsWith(":"))n[o[i].slice(1)]=decodeURIComponent(r[i]);else if(o[i]!==r[i])return null;return n}parseQueryParams(t){return t?t.split("&").reduce((s,o)=>{const[r,n]=o.split("=").map(decodeURIComponent);return s[r]=n??"",s},{}):{}}}const Ki=f.createLogger({name:"intent-service"}),oh=e=>{Ro(`/kos/intent/${e.type}`)?F(`/kos/intent/${e.type}`,e.options,{"kos.intent.type":e.type}):Ki.info(`No subscribers for intent ${e.type}. Intent not sent.`)},rh=async e=>new Promise(t=>{const{type:s,options:o}=e;if(Ro(`/kos/intent/${e.type}`)){const r=Ze(),{unsubscribe:n}=j(r,c=>{clearTimeout(i),n(),c&&(c.headers=c.headers||{},c.headers["kos.intent.type"]=s,c.headers.responseId=r),t([null,{body:c==null?void 0:c.body,payload:c}])}),i=setTimeout(()=>{n(),t([`Intent ${s} timed out after 1 second`,null]),console.warn(`Intent ${s} timed out after 1 second`)},1e3);F(`/kos/intent/${s}`,o,{"kos.intent.type":s,sync:r})}else Ki.info(`No subscribers for intent ${e.type}. Intent not sent.`),t([null,{body:void 0,payload:void 0}])}),mo=w.when,Vo=w.computed,Y=w.runInAction,N=w.autorun,Gi=w.reaction,Yo=w.observable,zo="Not Assigned",nh="kos.trouble.added",ih="kos.trouble.removed";var oe=(e=>(e.TroubleRank="kos.trouble.rank.mapper",e.TroubleColor="kos.trouble.color.mapper",e.TroubleRole="kos.trouble.role.mapper",e))(oe||{}),Tt=(e=>(e.TIME_CHANGE="/kos/internal/time/time",e.DAY_CHANGE="/kos/internal/time/day",e.TIMEZONE_CHANGE="/kos/internal/time/timezone",e))(Tt||{});const Hi=f.createLogger({name:"config-bean-service",group:"Services"}),qo=exports.BASE_URL,Vi=e=>(e==null?void 0:e.decimals)!==void 0,{postModel:ah,getOne:ch}=V.build({destinationAddress:"",basePath:`${qo}/kos/config/`}),Yi=async(e,t,s="/api/kos/config")=>(Hi.debug(`sending modify request for ConfigBean: ${e}`),ah({model:t,urlOverride:`${qo}${s}/${e}`})),zi=async(e,t="/api/kos/config")=>(Hi.debug(`sending get request for ConfigBean: ${e}`),await ch({urlOverride:`${qo}${t}/details/${e}/15`})),Wo=e=>e.toLowerCase()==="true"||e.toLowerCase()==="false",xs=e=>{try{const t=Number(e);return!isNaN(t)}catch{return!1}};function qi(e=[]){return e.reverse().reduce((t,s)=>{const{overrides:o}=s;return o&&(t={...t,...o}),t},{})}function Wi(e,t="",s={}){for(const o in e)if(Object.prototype.hasOwnProperty.call(e,o)){const r=t?`${t}.${o}`:o;typeof e[o]=="object"&&e[o]!==null&&!Array.isArray(e[o])?Wi(e[o],r,s):s[r]=e[o]}return s}const Zi=(e,t)=>{const s=e.details[0].bean||qi(e.details[0].scopes),o=Wi(s);w.runInAction(()=>{const r={...o};t.props.setValues(r)})},Ji=(e,t)=>{w.runInAction(()=>{e.changes.forEach(s=>{const o=s.attr;let r=s.currentValue,n=s.previousValue;typeof r=="string"&&Wo(r)&&(r=r.toLowerCase()=="true",n=(n==null?void 0:n.toLowerCase())=="true"),typeof r=="string"&&xs(r)&&(r=Number(r),n=Number(n)),t.props[o]=r,t.prevProps[o]=n})})},Qi=e=>Object.fromEntries(e.props.entries),lh=e=>t=>s=>e.build(t,s);var dh=Object.defineProperty,uh=Object.getOwnPropertyDescriptor,Xi=(e,t,s,o)=>{for(var r=o>1?void 0:o?uh(t,s):t,n=e.length-1,i;n>=0;n--)(i=e[n])&&(r=(o?i(t,s,r):i(r))||r);return o&&r&&dh(t,s,r),r};function hh(e,t){for(const s of e)if(new RegExp(`^${s}$`).test(t))return s}const Zo="config-bean-model",Jt=f.getLogger(Zo),gh=Se("path");let gs=class{constructor(e,t){a(this,"_modifyConfigBean");a(this,"_getConfigBean");a(this,"_schema");a(this,"id");a(this,"path");a(this,"props");a(this,"prevProps");a(this,"serviceBasePath");Object.assign(this,t),this.id=e,this.path=t.path,this.serviceBasePath=t.serviceBasePath;const{modifyConfigBean:s=Yi,getConfigBean:o=zi}=t;this._modifyConfigBean=s,this._getConfigBean=o,this.props=pe(),this.prevProps=pe()}get values(){return this.props.values}async ready(){Jt.debug(`readying config bean ${this.path}`),Jt.debug(`complete readying config bean ${this.path}`)}async load(){Jt.debug(`loading config bean ${this.path}`);const e=await this._getConfigBean(this.path,this.serviceBasePath);if(e!=null&&e.data){const t=e.data;Zi(t,this),Jt.debug(this.values);const s=e==null?void 0:e.data.details[0].schema;Y(()=>{s&&(this._schema=s)})}}get schemaKeys(){var e;return Object.keys(((e=this._schema)==null?void 0:e.schema)||{})}getSchemaForProperty(e){var s,o;if(this.schemaKeys.includes(e))return(s=this._schema)==null?void 0:s.schema[e];const t=hh(this.schemaKeys,e);if(t)return(o=this._schema)==null?void 0:o.schema[t]}async updateProperty(e,t){this.props[e]=t,await this.updateConfigBean()}async updateConfigBean(){const e=Qi(this);await this._modifyConfigBean(this.path,e,this.serviceBasePath)}handleConfigBeanUpdated(e){Ji(e,this)}};Xi([R({topic:`/kos/config/${gh}`,websocket:!0})],gs.prototype,"handleConfigBeanUpdated",1);gs=Xi([D(Zo)],gs);const Dt=new le({class:gs,type:Zo}),Ns=({path:e,lazy:t,serviceBasePath:s})=>(o,r)=>{o[k]=o[k]||{},o[k][r]={modelType:Dt.type,id:`${Dt.type}-${e}`,options:{path:e,serviceBasePath:s},lifecycle:x.INIT,lazy:t}},{URL:ea}=q(),{getOne:fh,getAll:mh}=V.build({basePath:`${ea}/api/kos/regions/info`}),ta=async()=>await fh({}),sa=async()=>await mh({urlOverride:`${ea}/api/kos/regions`}),ph=Object.freeze(Object.defineProperty({__proto__:null,getRegionInfo:ta,getRegions:sa},Symbol.toStringTag,{value:"Module"}));var Z=(e=>(e[e.family=0]="family",e[e.scale=1]="scale",e[e.offset=2]="offset",e[e.decimals=3]="decimals",e[e.alias=4]="alias",e[e.system=5]="system",e))(Z||{});const oa={s:["time",1,0,0],second:["time",1,0,0],m:["time",1/60,0,0],minute:["time",1/60,0,0],h:["time",1/3600,0,0],hour:["time",1/3600,0,0],day:["time",1/86400,0,0],week:["time",1/604800,0,0],month:["time",1/2628e3,0,0],year:["time",1/31536e3,0,0],default:["time",1/.001,0,0],ms:["time",1/.001,0,0],millisecond:["time",1/.001,0,0],microsecond:["time",1/1e-6,0,0],nanosecond:["time",1/1e-9,0,0],picosecond:["time",1/1e-12,0,0]};function yh(e,t){const s=t.id,o=t.units.reduce((r,n)=>{const i=[n.measure,n.scale,n.offset,n.decimals,n.alias,s];return r[n.name]=i,n.alias&&(r[n.alias]=i),r},{...oa});return{...e,...o}}function bh(e,t){const s=t.id,o=t.units.reduce((r,n)=>{const i=r[n.measure]||{},c=i[s]||{};i[s]=c;const l=[n.measure,n.scale,n.offset,n.decimals,n.alias,s];return c[n.name]=l,Object.hasOwn(n,"default")&&Object.defineProperty(c,"default",{value:l,writable:!0,enumerable:!0,configurable:!0}),r[n.measure]=i,n.alias&&(r[n.alias]=i),r},{time:{[s]:{...oa}}});return Object.keys(o).forEach(r=>{e[r]={...e[r],...o[r]}}),e}function wh(e,t){const s=t.id,o=t.units.reduce((r,n)=>{const i=r[n.measure]||{};return Object.hasOwn(n,"default")&&(i[s]=n.name),r[n.measure]=i,r},{time:{[s]:"millisecond"}});return Object.keys(o).forEach(r=>{e[r]={...e[r],...o[r]}}),e}var vh=Object.defineProperty,Mh=Object.getOwnPropertyDescriptor,Jo=(e,t,s,o)=>{for(var r=o>1?void 0:o?Mh(t,s):t,n=e.length-1,i;n>=0;n--)(i=e[n])&&(r=(o?i(t,s,r):i(r))||r);return o&&r&&vh(t,s,r),r};const as="region-info-model",nt=f.createLogger({name:"region-info-model"});let St=class{constructor(e){a(this,"id");a(this,"unitSystemMap");a(this,"measureMap");a(this,"defaultMeasureMap");a(this,"regionMap");a(this,"timeFormats");a(this,"dateFormats");a(this,"unitSystems");a(this,"regionSource");a(this,"region");a(this,"regions",[]);a(this,"timeZoneMap",{});this.id=e,this.unitSystems={},this.unitSystemMap={},this.measureMap={},this.defaultMeasureMap={},this.timeFormats={},this.regions=[],this.dateFormats={},this.timeZoneMap={},this.regionMap={}}get availableRegions(){return this.regions}get defaultUnitSystem(){return String(this.regionSource.props.unitSystemId).toLowerCase()||""}get unitSystemId(){return this.defaultUnitSystem}get timeFormatId(){const e=this.regionSource.props.timeFormatId;if(!e)return"";const t=String(e),s=this.timeFormats[t];return s?String(s.id):""}get selectedTimeFormat(){const e=this.timeFormatId;return e?String(this.timeFormats[e].format):"HH:mm:ss"}get is12HourTimeFormat(){const e=this.timeFormatId;return e?this.timeFormats[e].ampm:!0}get dateFormatId(){const e=this.regionSource.props.dateFormatId;if(!e)return"";const t=String(e);return t?this.dateFormats[t].id:""}get selectedDateFormat(){const e=this.dateFormatId;return e?this.dateFormats[e].format:""}get selectedDateOrder(){const e=this.dateFormatId;return e?this.dateFormats[e].order.toLowerCase():"dmy"}get selectedCountry(){return this.regionSource.props.country||"en"}get selectedTimeZone(){return this.regionSource.props.timeZone||""}get timeZones(){return this.regionId?this.timeZoneMap[this.regionId]||[]:[]}get allTimeZones(){return Intl.supportedValuesOf("timeZone")}get regionId(){return this.region.props.regionId||""}get selectedRegion(){return this.regionMap[this.regionId]}get selectedUnitSystem(){return String(this.regionSource.props.unitSystemId)||""}get timeFormatOptions(){return Object.keys(this.timeFormats).map(e=>({id:e,format:this.timeFormats[e].format,ampm:this.timeFormats[e].ampm}))}get dateFormatOptions(){return Object.keys(this.dateFormats).map(e=>({id:e,format:this.dateFormats[e].format,order:this.dateFormats[e].order}))}get unitSystemOptions(){return Object.keys(this.unitSystems).map(e=>({id:e,name:e}))}setSelectedTimeFormat(e){if(!this.timeFormatOptions.find(t=>t.id===e))throw Error(`Invalid time format id. Must be one of ${this.timeFormatOptions.map(t=>t.id).join(", ")}`);this.regionSource.updateProperty("timeFormatId",e)}setSelectedDateFormat(e){if(!this.dateFormatOptions.find(t=>t.id===e))throw Error(`Invalid date format id. Must be one of ${this.dateFormatOptions.map(t=>t.id).join(", ")}`);this.regionSource.updateProperty("dateFormatId",e)}setSelectedUnitSystem(e){if(!this.unitSystemOptions.find(t=>t.id===e))throw Error(`Invalid date format id. Must be one of ${this.unitSystemOptions.map(t=>t.id).join(", ")}`);this.regionSource.updateProperty("unitSystemId",e)}getUnitSystem(e){if(!e)return this.defaultUnitSystem;const t=e==="drt"?"second":e,s=this.unitSystemMap[t];if(!s)throw Error(`No unit found with name: ${t}. Unit should be one of ${Object.keys(this.unitSystemMap).join(", ")}`);return s[Z.system]}getUnitMeasure(e){const t=e==="drt"?"second":e,s=this.unitSystemMap[t];if(!s)throw Error(`No unit found with name: ${t}. Unit should be one of ${Object.keys(this.unitSystemMap).join(", ")}`);return s[Z.family]}getDefaultUnitDecimalPlaces(e,t,s){if(!e||!t)throw Error("Measure and unit system are required");const o=s==="drt"?"second":s,r=this.measureMap[e];if(!r)throw Error(`No unit systems found for measure: ${e}. Measure should come from list of measures: ${Object.keys(this.measureMap).join(", ")}`);const n=r[t.toLowerCase()];if(!n)throw Error(`No unit system found for measure: ${e} and unit system: ${t}. Unit system should come form list of unit systems: ${Object.keys(r).join(", ")}`);const i=n[o||"default"];if(!i)throw Error(`No unit "${o||"default"}" found for measure: ${e} and unit system: ${t}. Unit should come from list of units: ${Object.keys(n).join(", ")}`);return i[Z.decimals]}getDefaultUnitForMeasure(e,t){if(!e||!t)throw Error("Measure and unit system are required");const s=this.defaultMeasureMap[e];if(!s)throw Error(`No unit systems found for measure: ${e}. Measure should come from list of measures: ${Object.keys(this.measureMap).join(", ")}`);const o=s[t.toLowerCase()];if(!o)throw Error(`No unit system found for measure: ${e} and unit system: ${t}. Unit system should come form list of unit systems: ${Object.keys(s).join(", ")}`);return o}convertByUnit(e,t,s){if(t[Z.family]!==s[Z.family])throw new Error(`Cannot convert between units of different families: ${t[Z.family]} and ${s[Z.family]}`);const o=t[Z.offset],r=t[Z.scale],n=s[Z.scale],i=s[Z.offset],c=s[Z.decimals];return((e-o)/(r/n)+i).toFixed(c)}convertByUnitName(e,t,s){const o=this.unitSystemMap[t],r=this.unitSystemMap[s];if(!o||!r)throw new Error(`No unit found with name: ${t} or ${s}. Unit should be one of ${Object.keys(this.unitSystemMap).join(", ")}`);return this.convertByUnit(e,o,r)}convert(e,t,s){var c,l;if(t.unit&&s.unit)return this.convertByUnitName(e,t.unit,s.unit);const o=t.unit||"",r=s.unit||"";let n=this.unitSystemMap[o],i=this.unitSystemMap[r];if(!i&&s.measure&&s.system){const d=this.measureMap[s.measure];if(!d)throw Error(`Could not find measure ${s.measure}. Measure should be one of ${Object.keys(this.measureMap).join(", ")}`);i=(c=d[s.system])==null?void 0:c.default,i||nt.info("Could not find default unit for measure",s.measure)}if(!n&&t.measure&&t.system){const d=this.measureMap[t.measure];if(!d)throw Error(`Could not find measure ${s.measure}. Measure should be one of ${Object.keys(this.measureMap).join(", ")}`);n=(l=d[t.system])==null?void 0:l.default,n||nt.info("Could not find default unit for measure",t.measure)}return!n||!i?(nt.warn("Could not find unit to convert to or from. Return value as is"),String(e)):this.convertByUnit(e,n,i)}async init(){nt.debug("initializing region info")}async load(){nt.debug("loading region info");const e=await sa();e&&(this.regions=e.data.map(s=>s.id),this.timeZoneMap=e.data.reduce((s,o)=>({...s,[o.id]:o.timeZones}),this.timeZoneMap),this.regionMap=e.data.reduce((s,o)=>({...s,[o.id]:o}),{}));const t=await ta();t&&(this.unitSystems=t.data.unitSystems.reduce((s,o)=>{const r={id:o.id,name:o.id};return s[o.id]=r,s},this.unitSystems),this.unitSystemMap=t.data.unitSystems.reduce(yh,{}),this.measureMap=t.data.unitSystems.reduce(bh,{}),this.defaultMeasureMap=t.data.unitSystems.reduce(wh,{}),this.timeFormats=t.data.timeFormats.reduce((s,o)=>({...s,[o.id]:o}),{}),this.dateFormats=t.data.dateFormats.reduce((s,o)=>({...s,[o.id]:o}),{}))}async ready(){var e,t;await((t=(e=this.regionSource).ready)==null?void 0:t.call(e))}};Jo([Ns({path:"kos:service:region:settings"})],St.prototype,"regionSource",2);Jo([Ns({path:"kos:service:region"})],St.prototype,"region",2);St=Jo([D(as)],St);const z={registration:{[as]:{class:St,singleton:!0}},type:as,factory:H.Singleton.create(as)},zr=({source:e,defaultSystem:t="si",defaultMeasure:s})=>{let o={system:t,measure:s};return typeof e=="string"?o={...o,unit:e}:o={...o,...e},o},ra=(e,t,s)=>{const{model:o}=Je(z.type);if(!o)throw new Error("RegionInfo model not found");if(!hs(o))throw new Error("RegionInfo model not ready");const r={system:o.defaultUnitSystem},n=zr({source:t}),i=zr({source:s||r,defaultMeasure:o.getUnitMeasure(n.unit||"")});return o.convert(e,n,i)};function qr({start:e,end:t,count:s,decimals:o=0}){if(typeof e!="number"||typeof t!="number"||typeof s!="number")throw new Error("All input values should be numbers.");if(s<2)throw new Error("Count should be at least 2 for distribution.");if(e>=t)throw new Error("Start should be less than end.");const r=(t-e)/(s-1),n=[];for(let i=0;i<s;i++){const c=Math.round(e+i*r);n.push(c.toFixed(o))}return n}function Wr({start:e,end:t,interval:s,decimals:o=0}){if(typeof e!="number"||typeof t!="number"||typeof s!="number")throw new Error("All input values should be numbers.");if(s<=0)throw new Error("Interval should be a positive number.");if(e>=t)throw new Error("Start should be less than end.");const r=[];let n=e;for(;n<=t;)r.push(n.toFixed(o)),n+=s;return r[r.length-1]!==t.toString()&&r.push(t.toString()),r}const Le=(e,t)=>s=>!e||!t?s:xs(s)?ra(Number(s),e,t):s,Eh=(e,t,s,o)=>{if((e==null?void 0:e.type)==="enum"||!(e!=null&&e.options))return[];if(e.options.type==="rangeCount")return qr(e.options).map(Le(s,o));if(e.options.type==="rangeInterval")return Wr(e.options).map(Le(s,o));if(e.options.type==="list"){const{list:r}=e.options;return r.map(Le(s,o))}else{if(e.options.type==="unitSystemRangeCount"&&t)return qr(e.options.unitSystems[t]).map(Le(s,o));if(e.options.type==="unitSystemRangeInterval"&&t)return Wr(e.options.unitSystems[t]).map(Le(s,o));if(e.options.type==="unitSystemList"&&t){const{list:r}=e.options.unitSystems[t];return r.map(Le(s,o))}}return[]},_h=(e,t)=>{if(!((e==null?void 0:e.type)==="enum"||!(e!=null&&e.options)))return e.options.type==="unitSystemRangeCount"&&t?{type:"rangeCount",...e.options.unitSystems[t]}:e.options.type==="unitSystemRangeInterval"&&t?{type:"rangeInterval",...e.options.unitSystems[t]}:e.options.type==="unitSystemList"&&t?{type:"list",...e.options.unitSystems[t]}:e.options.type==="unitSystemKeypad"&&t?{type:"keypad",...e.options.unitSystems[t]}:e.options};var Ih=Object.defineProperty,Th=Object.getOwnPropertyDescriptor,Qo=(e,t,s,o)=>{for(var r=o>1?void 0:o?Th(t,s):t,n=e.length-1,i;n>=0;n--)(i=e[n])&&(r=(o?i(t,s,r):i(r))||r);return o&&r&&Ih(t,s,r),r};function $h(e){return(e==null?void 0:e.type)==="enum"}function Oh(e){switch(e){case"s":return"second";case"ms":return"millisecond";case"min":return"minute";case"h":return"hour";case"d":return"day";case"w":return"week";case"m":return"month";case"y":return"year";case"ml":return"milliliter";default:return e}}function Dh(e,t){const s=new Date;s.setHours(0,0,0,0);const o=new Date(s.getTime()+e*1e3);return me.format(o,t)}const cs="config-bean-prop-model",ke=f.createLogger({name:"config-bean-prop-model"}),Sh=Se("path"),Ah=Se("serviceBasePath");let At=class{constructor(e,t){a(this,"id");a(this,"path");a(this,"attribute");a(this,"converter");a(this,"formatter");a(this,"optionsExpander");a(this,"serviceBasePath");a(this,"regionInfo");a(this,"bean");this.id=e,this.path=t.path,this.attribute=t.attribute,this.converter=t.converter,this.formatter=t.formatter,this.serviceBasePath=t.serviceBasePath,this.optionsExpander=t.optionsExpander}getDefaultUnitDecimalPlaces(e,t,s){if(!e)throw new Error("measure is required");if(!t)throw new Error("unitSystem is required");return Vi(this.displayOptions)?this.displayOptions.decimals:this.regionInfo.getDefaultUnitDecimalPlaces(e,t,s)}getDefaultUnitForMeasure(e,t){if(!e)throw new Error("measure is required");if(!t)throw new Error("unitSystem is required");return this.regionInfo.getDefaultUnitForMeasure(e,t)}get schemaType(){const e=this.bean.getSchemaForProperty(this.attribute);return e!=null&&e.type?e.type:"String"}get schemaFormat(){const e=this.bean.getSchemaForProperty(this.attribute);return e!=null&&e.format?Oh(e.format):""}get options(){var i;const e=this.regionInfo.defaultUnitSystem,t=this.getConverter(),s=((i=t==null?void 0:t.to)==null?void 0:i.system)??e,o=this.bean.getSchemaForProperty(this.attribute),r=$h(o)?o.values:Eh(o,s,t==null?void 0:t.from,t==null?void 0:t.to),n=r.length>0?r.map(c=>({label:c,value:c})):[];return this.optionsExpander?typeof this.optionsExpander=="function"?this.optionsExpander(s,r):this.optionsExpander:n}convertUnit(e,t,s){const o=(e==null?void 0:e.measure)||s,r=(e==null?void 0:e.system)||t,n=e==null?void 0:e.unit;return{measure:o,system:r,unit:n}}getConverterUnits(){const e=this.regionInfo.defaultUnitSystem,t=this.getConverter();if(!t)throw Error("No converter defined");const s=t.measure,o=this.convertUnit(t.from,"si",s),r=this.convertUnit(t.to,e,s);return{backend:o,display:r}}set value(e){this.updateProperty(e)}get value(){return this.getValue(!0)}get rawValue(){return this.bean.props[this.attribute]}get significantValue(){var r,n;const e=this.value,t=this.regionInfo.defaultUnitSystem,s=this.getConverter(),o=(s==null?void 0:s.measure)||((r=s==null?void 0:s.to)==null?void 0:r.measure);if(!isNaN(e)&&s&&o){const i=this.getDefaultUnitDecimalPlaces(o,t,(n=s==null?void 0:s.to)==null?void 0:n.unit);try{const l=this.getFormatterOptions(s);if(l){let d=String(e);return d=l.formatToParts(Number(e))[0].value,Number(d)}}catch(l){ke.info(`error formatting value ${e}`,l)}return Number(e).toFixed(i)}return e}get previousValue(){return this.getValue(!1)}getValue(e){const t=this.bean[e?"props":"prevProps"][this.attribute];if(typeof t=="boolean")return t;if(this.getConverter()&&!isNaN(t)){const{backend:o,display:r}=this.getConverterUnits();return this.regionInfo.convert(Number(t),o,r)}return t||""}async activate(){ke.debug(`activating config bean ${this.id}`)}get displayValue(){const e=this.value;if(typeof e=="boolean")return String(e);if(this.schemaFormat==="drt"){const s=this.regionInfo.is12HourTimeFormat?"h:mm:ss a":"HH:mm:ss";return Dh(e,s)}if(!isNaN(e))try{const t=this.getConverter(),s=this.getFormatterOptions(t);if(s){let o=String(e);return o=s.format(Number(e)),o}}catch(t){ke.error(`error formatting value ${e}`,t)}return String(e)}get unit(){const e=this.getConverter();if(!isNaN(this.value)){const t=this.getFormatterOptions(e);if(t){const o=t.formatToParts(Number(this.value)).find(r=>r.type==="unit");return(o==null?void 0:o.value)??this.getDefaultUnit(e)}}return this.getDefaultUnit(e)}get displayOptions(){var r;const e=this.bean.getSchemaForProperty(this.attribute),t=this.regionInfo.defaultUnitSystem,s=this.getConverter(),o=((r=s==null?void 0:s.to)==null?void 0:r.system)??t;return _h(e,o)}getMeasureFromFormat(){const e=this.schemaFormat;return e?this.regionInfo.getUnitMeasure(e):""}getConverterFromFormat(){const e=this.getMeasureFromFormat();if(e){const t=this.regionInfo.selectedUnitSystem;return{unit:this.schemaFormat||this.regionInfo.getDefaultUnitForMeasure(e,t),measure:e}}return{}}getDefaultUnit(e){var o,r;const t=this.regionInfo.defaultUnitSystem,s=e==null?void 0:e.measure;return s?((o=e==null?void 0:e.to)==null?void 0:o.unit)||this.getDefaultUnitForMeasure(s,((r=e==null?void 0:e.to)==null?void 0:r.system)||t):this.getConverterFromFormat().unit}getFormatterOptions(e){var n,i,c;const t=this.regionInfo.defaultUnitSystem,s=e==null?void 0:e.measure,o=new Intl.NumberFormat().resolvedOptions().locale;let r=null;if(s||this.formatter){const l=s?{style:"unit",unit:this.getDefaultUnit(e)}:null,d=this.formatter||l;if(d){let u=typeof d=="function"?d(((n=e==null?void 0:e.to)==null?void 0:n.system)||t):d;s&&(u={unit:this.getDefaultUnit(e),...u},u.style==="unit"&&(u.maximumFractionDigits=u.maximumFractionDigits??this.getDefaultUnitDecimalPlaces(s,((i=e==null?void 0:e.to)==null?void 0:i.system)||t,(c=e==null?void 0:e.to)==null?void 0:c.unit)));try{r=new Intl.NumberFormat(o,{...u})}catch(g){ke.error(`error creating formatter ${u}. Returning the raw value`,g)}}else ke.debug(`no formatter found for config bean prop ${this.id}. Returning the raw value`)}return r}getConverter(){var o,r,n,i,c,l,d,u,g,y,v;const{unit:e,measure:t}=this.getConverterFromFormat(),s=e==="drt"?"second":e;if(this.converter){const b=(o=this.converter)==null?void 0:o.measure,E=(n=(r=this.converter)==null?void 0:r.to)==null?void 0:n.measure,I=(c=(i=this.converter)==null?void 0:i.from)==null?void 0:c.measure,A=b||E||I||t,te=((d=(l=this.converter)==null?void 0:l.to)==null?void 0:d.unit)||this.regionInfo.getDefaultUnitForMeasure(A,((g=(u=this.converter)==null?void 0:u.to)==null?void 0:g.system)??this.regionInfo.defaultUnitSystem),ve=((v=(y=this.converter)==null?void 0:y.to)==null?void 0:v.system)??this.regionInfo.getUnitSystem(te),st=this.schemaFormat==="drt"?"second":this.schemaFormat||s;return{...this.converter,from:{unit:st,...this.converter.from},to:{...this.converter.to,unit:te,system:ve},measure:A}}if(s&&t){const b=this.regionInfo.getDefaultUnitForMeasure(t,this.regionInfo.defaultUnitSystem),E=this.regionInfo.getUnitSystem(s),I=this.regionInfo.getUnitSystem(b);return{measure:t,to:{unit:E===I?s:b}}}}async updateProperty(e){ke.debug(`updating property ${this.attribute} with value ${e}`);let t=e;if(this.getConverter()&&!isNaN(t)){const{backend:r,display:n}=this.getConverterUnits();t=this.regionInfo.convert(Number(t),n,r)}const o=Array.isArray(t)?JSON.stringify(t):String(t);await this.bean.updateProperty(this.attribute,o)}};Qo([Bt({modelType:z.type})],At.prototype,"regionInfo",2);Qo([Ns({path:Sh,serviceBasePath:Ah})],At.prototype,"bean",2);At=Qo([D(cs)],At);const Ae={registration:{[cs]:{class:At,singleton:!1}},type:cs,factory:H.Factory.create(cs)};function Ch(e){const{path:t,attribute:s,converter:o,formatter:r,lazy:n,optionsExpander:i,serviceBasePath:c}=e,l=o;return l&&(typeof l!="function"&&typeof l.from=="string"&&(l.from={unit:l.from}),typeof l!="function"&&typeof l.to=="string"&&(l.to={unit:l.to})),(d,u)=>{d[k]=d[k]||{},d[k][u]={modelType:Ae.type,id:`${t}-${s}`,options:{path:t,attribute:s,serviceBasePath:c,converter:l,formatter:r,optionsExpander:i},lifecycle:x.INIT,lazy:n}}}class Rh{constructor(t,s){a(this,"futures");a(this,"defaultContext");a(this,"context");a(this,"disposers",new Map);a(this,"container");this.futures=Yo.map(new Map),this.context="",this.defaultContext=s||"",this.container=t,w.makeAutoObservable(this)}get allFutures(){return Array.from(this.futures.values())}get future(){return this.futures.get(this.defaultContext)}addFuture(t,s){this.futures.set(s||t.id,t),this.context=s||t.id;const o=N(()=>{var r,n;(t.endState||t.progress)&&((n=(r=this.container)==null?void 0:r.onFutureUpdate)==null||n.call(r,t))});this.disposers.set(s||t.id,o)}removeFuture(t){var s;this.futures.delete(t||this.context),(s=this.disposers.get(t||this.context))==null||s(),this.disposers.delete(t||this.context)}getFuture(t){return this.futures.get(t||this.context)}get futureMap(){return this.futures}}class Xo{constructor(t){a(this,"disposer");a(this,"_future");a(this,"container");a(this,"onFutureUpdate");this._future=void 0,this.container=t,w.makeAutoObservable(this)}removeFuture(){var t;this._future=void 0,(t=this.disposer)==null||t.call(this),this.disposer=void 0}get future(){return this._future}getFuture(){return this._future}addFuture(t){this._future=t;const s=N(()=>{var o,r;(t.endState||t.progress)&&((r=(o=this.container)==null?void 0:o.onFutureUpdate)==null||r.call(o,t))});this.disposer=s}get allFutures(){return this._future?[this._future]:[]}get timeRemaining(){var t;return((t=this._future)==null?void 0:t.timeRemaining)||""}get status(){var t;return((t=this._future)==null?void 0:t.status)||"NOT_RESOLVED"}get progress(){var t;return((t=this._future)==null?void 0:t.progress)||-1}async cancel(){if(this._future)try{await this._future.cancelFuture()}catch(t){throw f.error(t),t}}}const na="future-model",et=Qe(na),Fs=f.createLogger({name:"future-service",group:"Services"}),{isMock:Lh,URL:Gt}=q();var Ke=(e=>(e.Success="SUCCESS",e.Fail="FAIL",e.Aborted="ABORT",e.Canceled="CANCEL",e))(Ke||{});const{getAll:kh,modifyModel:Ph,addModel:xh,deleteModel:Nh,postModel:Fh}=V.build({destinationAddress:"",basePath:`${Gt}/api/future`,mock:Lh}),Uh=async()=>await kh({}),ia=async(e,t="/api/kos/future")=>(Fs.info(`sending delete request for Future: ${e}`),await Nh({id:e,urlOverride:`${Gt}${t}/${e}`})),aa=async(e,t="/api/kos/future")=>(Fs.info("sending add request for Future"),await xh({model:e,urlOverride:`${Gt}${t}`})),jh=async(e,t,s="/api/kos/future")=>(Fs.info(`sending modify request for Future: ${e}`),Ph({model:t,id:e,urlOverride:`${Gt}${s}/${e}`})),ca=async(e,t="/api/kos/future")=>(Fs.info(`sending cancel request for Future: ${e}`),Fh({urlOverride:`${Gt}${t}/${e}/cancel`,ordered:!0,model:{}})),er=e=>({id:String(e.id),progress:e.progress,remainingTimeMs:e.remainingTimeMs,endState:e.endState,reason:e.reason,clientData:e.clientData,reasonData:e.reasonData,note:e.note,tracker:e.tracker}),tr=(e,t)=>{f.debug(`future dto ${e.id} end state ${e.endState}`),f.debug(`future model ${t.id} end state ${t.endState}`),t.endState?f.debug(`future model ${t.id} is already complete`):(f.debug(`updating future model ${t.id}`),w.runInAction(()=>{const s=er(e);Y(()=>{Object.keys(s).forEach(o=>{o==="id"?(t.futureId=s.id,s.tracker||(t.id=s.id)):o==="tracker"?t.id=s.tracker:t[o]=s[o]})})}))},la=e=>t=>s=>e.build(String(t),s),sr=e=>t=>xi(er,la(e)(t.tracker||t.id))(t);var Bh=Object.defineProperty,Kh=Object.getOwnPropertyDescriptor,da=(e,t,s,o)=>{for(var r=o>1?void 0:o?Kh(t,s):t,n=e.length-1,i;n>=0;n--)(i=e[n])&&(r=(o?i(t,s,r):i(r))||r);return o&&r&&Bh(t,s,r),r};const ro=f.getLogger(et.type);let fs=class{constructor(e,t,s){a(this,"logger");a(this,"_cancelFuture");a(this,"futureId");Object.assign(this,t),this.logger=s.logger,this.id=e,this.futureId=t.id,this.namespace=t.namespace||"kos",this._cancelFuture=ca,mo(()=>this.status===Ke.Success||this.status===Ke.Fail,()=>{ro.info(`Future ${this.id} has completed with status ${this.status}`),Oe(this)})}async load(){ro.debug(`loading Future ${this.id}`)}unload(){ro.info(`unloading Future ${this.id}`)}async cancelFuture(){const e=this.namespace==="studio"?"/api/future":`/api/${this.namespace}/future`;await mo(()=>this.futureId!==zo),await this._cancelFuture(this.futureId,e)}get status(){return this.endState?this.endState:this.progress>-1?"IN_PROGRESS":"NOT_ACTIVE"}get timeRemaining(){var c,l;const e=this.remainingTimeMs||-1;if(e<0)return"";const t={year:1e3*60*60*24*365,month:1e3*60*60*24*30,day:1e3*60*60*24,hour:1e3*60*60,minute:1e3*60,second:1e3};let s="second",o=0;for(const[d,u]of Object.entries(t))if(Math.abs(e)>=u){s=d,o=Math.round(e/u);break}const n=new Intl.RelativeTimeFormat("en",{numeric:"auto"}).formatToParts(o,s);return n.length===3?`${((c=n[1])==null?void 0:c.value)??0} ${((l=n[2])==null?void 0:l.value)??""}`:"0 seconds"}handleFutureUpdated(e){this.logger.debug(`Future ${this.id} updated. future: ${e.id} endState: ${e.endState} progress: ${e.progress} remainingTimeMs: ${e.remainingTimeMs}`),tr(e,this)}};da([R({topic:`kos.future/${ds}`})],fs.prototype,"handleFutureUpdated",1);fs=da([D(et.type)],fs);const ua=fs,ha=Ko();var Gh=Object.defineProperty,Hh=Object.getOwnPropertyDescriptor,ga=(e,t,s,o)=>{for(var r=o>1?void 0:o?Hh(t,s):t,n=e.length-1,i;n>=0;n--)(i=e[n])&&(r=(o?i(t,s,r):i(r))||r);return o&&r&&Gh(t,s,r),r};const fa="browser-router-model",Vh="kos.http.request",Yh="kos.http.response";let ms=class{constructor(e,t,s){a(this,"_id");a(this,"logger");a(this,"router");this._id=e,this.logger=s.logger,this.router=new Bi}get id(){return this._id}async handleRequest(e,t){const s=t.headers["src-addr"],o=t.headers["dst-addr"],r=t.headers.url,n=t.headers.method,i=t.headers["request-id"],c={id:i,method:n,path:r};let l=200;const d={send:u=>{this.logger.debug(`sending response to ${o}`),this.logger.debug(u),bi({msg:u,options:{responseId:i,destinationAddress:s,type:Yh,sourceAddress:o,status:l}})},status:function(u){return l=u,this}};if(c.path==="/openapi.json"){d.send(this.router.generateOpenApiSpec());return}await this.router.handle(c,d)}use(e,t,...s){this.router.use(e,t,...s)}async init(){this.logger.debug(`initializing browser-router ${this.id}`)}async load(){this.logger.debug(`loading browser-router ${this.id}`)}};ga([R({topic:Vh})],ms.prototype,"handleRequest",1);ms=ga([D(fa)],ms);const ma=new we({class:ms,type:fa}),pa="future-container-model",ye=Qe(pa),ya=e=>sr(et)(e),zh=e=>{const t=ya(e);return ye.build(ye.type,{}).addFutureModel(t),t},qh=e=>ye.build(ye.type,{}).getFuture(String(e)),De={buildFutureModel:ya,initiateFuture:zh,getFuture:qh};var Wh=Object.defineProperty,Zh=Object.getOwnPropertyDescriptor,or=(e,t,s,o)=>{for(var r=o>1?void 0:o?Zh(t,s):t,n=e.length-1,i;n>=0;n--)(i=e[n])&&(r=(o?i(t,s,r):i(r))||r);return o&&r&&Wh(t,s,r),r};const Qt=f.getLogger(ye.type);let Ct=class{constructor(e,t,s){a(this,"id");a(this,"logger");a(this,"_deleteFuture");a(this,"_addFuture");a(this,"_futures");a(this,"createModel");a(this,"deleteModel");const{deleteFuture:o=ia,addFuture:r=aa}=t;this.logger=s.logger,this._deleteFuture=o,this._addFuture=r,this.id=e,this._futures=new fe,this.createModel=this.createFuture,this.deleteModel=this.removeFuture}get futures(){return this._futures.data}get models(){return this.futures}getFuture(e){return this._futures.getModel(e)}addFutureModel(e){this._futures.addModel(e)}removeFutureModel(e){this._futures.removeModel(e)}async removeFuture(e){try{await this._deleteFuture(e)}catch(t){Qt.error("error deleting a Future"),Qt.error(t)}}async createFuture(e){try{const t=await this._addFuture(e),s=t==null?void 0:t.data;if(s){const o=sr(et)(s);return this.addFutureModel(o),o}}catch(t){throw Qt.error("error creating a Future"),Qt.error(t),t}}handleFutureUpdated(e,t){const s=De.buildFutureModel(e);this.addFutureModel(s);const o=`kos.future/${e.tracker||e.id}`;this.logger.debug(`publishing future update to ${o}`),F(o,t.body,t.headers)}};or([ce],Ct.prototype,"_futures",2);or([R({topic:"kos.future"})],Ct.prototype,"handleFutureUpdated",1);Ct=or([D(ye.type)],Ct);const ba=Ct,{URL:Ht}=q(),{getOne:Jh,postModel:Qh,deleteModel:wa}=V.build({basePath:`${Ht}/api/keyVal`}),po=f.createLogger({name:"key-value-service",group:"Services"}),va=async(e,t)=>{await wa({urlOverride:`${Ht}/api/keyVal/${e}/${t}`,id:t})},Ma=async(e,t,s)=>{const o=await Qh({urlOverride:`${Ht}/api/keyVal/${e}/${t}`,model:s.toString()});if((o==null?void 0:o.status)!==200)throw po.error("Failed to update studio-state data",o),new Error(`Failed to update studio-state data for namespace ${e}`);return o.data},Ea=async(e="studio")=>{po.debug("sending GET for studio-state");const t=await Jh({urlOverride:`${Ht}/api/keyVal/${e}`});if((t==null?void 0:t.status)!==200)throw po.error("Failed to retrieve studio-state data",t),new Error(`Failed to retrieve studio-state data for namespace ${e}`);return t.data},Xh=async e=>{await wa({urlOverride:`${Ht}/api/keyVal/${e}}`,id:""})},eg=Object.freeze(Object.defineProperty({__proto__:null,deleteKeyValue:va,deleteKeyValueNamespace:Xh,getKeyValue:Ea,updateKeyValue:Ma},Symbol.toStringTag,{value:"Module"}));var tg=Object.defineProperty,sg=Object.getOwnPropertyDescriptor,rr=(e,t,s,o)=>{for(var r=o>1?void 0:o?sg(t,s):t,n=e.length-1,i;n>=0;n--)(i=e[n])&&(r=(o?i(t,s,r):i(r))||r);return o&&r&&tg(t,s,r),r};const _a="key-value-model";let Rt=class{constructor(e,t,s){a(this,"id");a(this,"logger");a(this,"namespace");a(this,"data");this.id=e,this.logger=s.logger,this.data=pe(),this.namespace=t.namespace||"studio"}async init(){this.logger.debug(`initializing studio-state ${this.id}`)}async updateState(e,t){this.logger.debug(`updating studio-state ${e} with value ${t}`),t!==void 0?(await Ma(this.namespace,e,t),this.data[e]=t):(await va(this.namespace,e),this.data[e]=void 0)}async load(){this.logger.debug(`loading studio-state ${this.id}`);const e=await Ea(this.namespace);this.data.setValues(e)}handleStateUpdate(e){e.namespace===this.namespace&&(this.data[e.key]=e.value)}handleStateDelete(e){e.namespace===this.namespace&&(this.data[e.key]=void 0)}};rr([R({topic:"/keyVal/set"})],Rt.prototype,"handleStateUpdate",1);rr([R({topic:"/keyVal/remove"})],Rt.prototype,"handleStateDelete",1);Rt=rr([D(_a)],Rt);const nr=new le({class:Rt,type:_a}),{URL:Vt}=q(),{postModel:ir,getOne:og}=V.build({basePath:`${Vt}/api/kos-time`});f.createLogger({name:"kos-time-service",group:"Services"});const Ia=async e=>{const t=await ir({model:e,urlOverride:`${Vt}/api/kos/time/time`});if((t==null?void 0:t.status)!==200)throw Error("Failed to set time");return t.data},Ta=async e=>{const t=await ir({model:e,urlOverride:`${Vt}/api/kos/time/date`});if((t==null?void 0:t.status)!==200)throw Error("Failed to set time");return t.data},$a=async e=>{const t=await ir({model:{},urlOverride:`${Vt}/api/kos/time/timezone?tz=${e}`});if((t==null?void 0:t.status)!==200)throw Error("Failed to set timezone");return t.data},Oa=async()=>{const e=await og({urlOverride:`${Vt}/api/kos/time/timezone`});if((e==null?void 0:e.status)!==200)throw Error("Failed to set timezone");return e.data.timeZone},rg=Object.freeze(Object.defineProperty({__proto__:null,getTimezone:Oa,setDate:Ta,setTime:Ia,setTimezone:$a},Symbol.toStringTag,{value:"Module"}));var ng=Object.defineProperty,ig=Object.getOwnPropertyDescriptor,Us=(e,t,s,o)=>{for(var r=o>1?void 0:o?ig(t,s):t,n=e.length-1,i;n>=0;n--)(i=e[n])&&(r=(o?i(t,s,r):i(r))||r);return o&&r&&ng(t,s,r),r};const at="kos-time-model",ag="/kos/time/time",cg="/kos/time/day",lg="/kos/time/timezone";let Ge=class{constructor(e,t,s){a(this,"id");a(this,"logger");a(this,"timezone");this.id=e,this.logger=s.logger,this.timezone=""}async updateSystemTime(e){await Ia(e)}async updateSystemDate(e){await Ta(e)}async updateSystemTimezone(e){await $a(e)}handleTimeChange(){F(Tt.TIME_CHANGE,{})}handleDayChange(){F(Tt.DAY_CHANGE,{})}async handleTimeZoneChange(){await this.retrieveTimezone(),F(Tt.TIMEZONE_CHANGE,{})}async init(){this.logger.debug(`initializing kos-time ${this.id}`)}async retrieveTimezone(){const e=await Oa();this.setTimezone(e)}setTimezone(e){this.timezone=e}async load(){this.logger.debug(`loading kos-time ${this.id}`),this.retrieveTimezone()}};Us([R({topic:ag,websocket:!0})],Ge.prototype,"handleTimeChange",1);Us([R({topic:cg,websocket:!0})],Ge.prototype,"handleDayChange",1);Us([R({topic:lg,websocket:!0})],Ge.prototype,"handleTimeZoneChange",1);Ge=Us([D(at)],Ge);const ps={registration:{[at]:{class:Ge,singleton:!0}},type:at,predicate:ee(at),factory:H.Singleton.create(at)};var dg=Object.defineProperty,ug=Object.getOwnPropertyDescriptor,Da=(e,t,s,o)=>{for(var r=o>1?void 0:o?ug(t,s):t,n=e.length-1,i;n>=0;n--)(i=e[n])&&(r=(o?i(t,s,r):i(r))||r);return o&&r&&dg(t,s,r),r};const Sa="log-block-container-model";let ys=class{constructor(e,t,s){a(this,"id");a(this,"logger");a(this,"_models");this.id=e,this.logger=s.logger,this._models=new fe({parentId:e,sortKey:"blockNum"})}getModel(e){return this._models.getModel(e)}get models(){return this._models}get data(){return this._models.data}addModel(e){this._models.addModel(e)}removeModel(e){this._models.removeModel(e)}async init(){this.logger.debug(`initializing log-block-container container ${this.id}`)}async load(){this.logger.debug(`loading log-block-container container ${this.id}`)}};Da([ce],ys.prototype,"_models",2);ys=Da([D(Sa)],ys);const Ce=Ko(),hg=f.createLogger({name:"log-stream-container-service",group:"Services"}),Aa=()=>{var o;const e=ae(),s=(e==null?void 0:e.connId)||((o=window==null?void 0:window.kosBridge)==null?void 0:o.call(window,"connId"));return f.error(`getKosConnectionId: ${s}`),s},tt=Aa(),gg="/api/kos/logs/node/{nodeId}/streams",Ca=async()=>(hg.debug("sending GET for log-stream-container"),await Ce.get(gg,{path:{nodeId:"primary"}},{destinationAddress:tt})),Ra=async(e,t="primary")=>{await Ce.post("/api/kos/logs/node/{nodeId}/{stream}/subscribe",{path:{nodeId:t,stream:e}},void 0,{destinationAddress:tt})},La=async e=>{await Ce.post("/api/kos/logs/node/{nodeId}/{stream}/unsubscribe",{path:{nodeId:"primary",stream:e}},void 0,{destinationAddress:tt})},fg=async()=>{await Ce.post("/api/kos/logs/overrides",{},{level:"WARN",name:"com.example",nodeType:"java",type:"package"},{destinationAddress:tt})},ka=async e=>await Ce.get("/api/kos/logs/node/{nodeId}/{stream}/blocks",{path:{nodeId:"primary",stream:e}},{destinationAddress:tt}),Pa=async(e,t)=>await Ce.get("/api/kos/logs/node/{nodeId}/{stream}/blocks/{blockId}",{path:{nodeId:"primary",stream:e,blockId:t}},{destinationAddress:tt}),mg=Object.freeze(Object.defineProperty({__proto__:null,createOverride:fg,getKosConnectionId:Aa,getLogStreamBlock:Pa,getLogStreamBlocks:ka,getLogStreams:Ca,subscribeToLogStream:Ra,unsubscribeFromLogStream:La},Symbol.toStringTag,{value:"Module"}));var pg=Object.defineProperty,yg=Object.getOwnPropertyDescriptor,bg=(e,t,s,o)=>{for(var r=o>1?void 0:o?yg(t,s):t,n=e.length-1,i;n>=0;n--)(i=e[n])&&(r=(o?i(t,s,r):i(r))||r);return o&&r&&pg(t,s,r),r};const xa="log-block-model";let yo=class{constructor(e,t,s){a(this,"id");a(this,"logger");a(this,"nodeId");a(this,"stream");a(this,"blockNum");a(this,"startLineNum");a(this,"endLineNum");a(this,"startTime");a(this,"endTime");a(this,"lineCount");a(this,"lines");a(this,"inc");this.id=e,this.logger=s.logger,this.nodeId=t.nodeId,this.stream=t.stream,this.blockNum=t.blockNum,this.startLineNum=t.startLineNum,this.endLineNum=t.endLineNum,this.startTime=t.startTime,this.endTime=t.endTime,this.lineCount=t.lineCount,this.lines=[],this.inc=0}async syncLines(){const[e,t]=await Pa(this.stream,this.blockNum);if(e){this.logger.error(`Failed to get log block ${this.blockNum}`);return}t&&this.addLines(t.lines,!0)}updateModel(e){this.startLineNum=e.startLineNum,this.endLineNum=e.endLineNum,this.startTime=e.startTime,this.endTime=e.endTime,this.lineCount=e.lineCount}addLines(e,t){const s=t?[]:this.lines;this.lines=[...s,...e],this.inc+=1}async init(){this.logger.debug(`initializing log-block ${this.id}`)}async load(){this.logger.debug(`loading log-block ${this.id}`)}};yo=bg([D(xa)],yo);const Lt=new le({class:yo,type:xa}),js=new le({class:ys,type:Sa});js.addRelatedModel(Lt);var wg=Object.defineProperty,vg=Object.getOwnPropertyDescriptor,Na=(e,t,s,o)=>{for(var r=o>1?void 0:o?vg(t,s):t,n=e.length-1,i;n>=0;n--)(i=e[n])&&(r=(o?i(t,s,r):i(r))||r);return o&&r&&wg(t,s,r),r};const Fa="log-stream-model";let bs=class{constructor(e,t,s){a(this,"id");a(this,"logger");a(this,"nodeId");a(this,"_blocks");a(this,"name");a(this,"currentBlockId");a(this,"isResetting");a(this,"generatorInstance");a(this,"shouldStop",!1);this.id=e,this.logger=s.logger,this.currentBlockId="",this.name=t.name,this.nodeId=t.nodeId,this.isResetting=!0,this._blocks=js.instance(`${e}-blocks`).options({}).build()}get firstLineNum(){const e=this.populated[0];return e?e.startLineNum:0}get currentBlock(){const e=this.currentBlockId;return this._blocks.getModel(e)}get populated(){return this._blocks.data.filter(e=>e.lines.length>0)}get blocks(){return this._blocks.data}get totalLineCount(){return this.populated.reduce((e,t)=>e+t.lineCount,0)}accept(e){e.visit(this)}updateBlock(e){var o;let t=this._blocks.models.getModel(`${e.stream}-block-${e.blockNum}`);const s={nodeId:e.nodeId,blockNum:e.blockNum,endLineNum:e.endLineNum,lineCount:e.lineCount,startLineNum:e.startLineNum,stream:this.name,endTime:new Date(e.endTime),startTime:new Date(e.startTime)};t||(t=Lt.instance(`${e.stream}-block-${e.blockNum}`).options(s).build(),this._blocks.addModel(t)),t&&t.updateModel(s),(!this.currentBlock||e.blockNum>=((o=this.currentBlock)==null?void 0:o.blockNum))&&(this.currentBlockId=`${e.stream}-block-${e.blockNum}`)}addBlock(e){var s;const t=Lt.instance(`${e.stream}-block-${e.blockNum}`).options({nodeId:e.nodeId,blockNum:e.blockNum,endLineNum:e.endLineNum,lineCount:e.lineCount,startLineNum:e.startLineNum,stream:this.name,endTime:new Date(e.endTime),startTime:new Date(e.startTime)}).build();this._blocks.addModel(t),(!this.currentBlock||e.blockNum>=((s=this.currentBlock)==null?void 0:s.blockNum))&&(this.currentBlockId=`${e.stream}-block-${e.blockNum}`)}removeBlock(e){this._blocks.models.removeModel(`${this.name}-block-${e}`)}async subscribe(){await Ra(this.name)}async unsubscribe(){await La(this.name)}async reset(){if(this.isResetting=!0,this.populated.length>0)return;this.logger.debug(`resetting log-stream ${this.id}`);for(const t of this._blocks.models.data)t.lines=[];const e=this._blocks.data[this._blocks.data.length-1];e&&await e.syncLines(),this.isResetting=!1}async init(){this.logger.debug(`initializing log-stream ${this.id}`)}async load(){this.logger.debug(`loading log-stream ${this.id}`);const[e,t]=await ka(this.name);if(e){this.logger.error(`Error loading log stream: ${e}`);return}if(t)for(const o of t)this.addBlock(o);const s=this._blocks.data[this._blocks.data.length-1];if(s&&await s.syncLines(),this._blocks.data.length>1){const o=this._blocks.data[this._blocks.data.length-2];o&&await o.syncLines()}}start(){return this.shouldStop=!1,this.generatorInstance=this.streamLogs(),this.generatorInstance}stop(){var e;this.shouldStop=!0,(e=this.generatorInstance)==null||e.next(),console.log("Requested generator stop.")}async*streamLogs(){const e=[];let t=null,s=0,o=this.currentBlockId;const r=Gi(()=>{const n=this.currentBlock;return n?{blockId:this.currentBlockId,lineCount:n.lines.length}:null},n=>{const i=this.currentBlock;if(i)if(o!==(n==null?void 0:n.blockId))o=n==null?void 0:n.blockId,s=0,e.push(...i.lines);else{const c=i.lines.slice(s);e.push(...c),s+=c.length}t&&(t(),t=null)},{fireImmediately:!0});try{for(const n of this.populated.filter(i=>i!==this.currentBlock))for(const i of n.lines)yield i;for(;;)for(e.length===0&&await new Promise(n=>t=n);e.length>0;)yield e.shift()}finally{r()}}};Na([ce],bs.prototype,"_blocks",2);bs=Na([D(Fa)],bs);const $t=new le({class:bs,type:Fa});var Mg=Object.defineProperty,Eg=Object.getOwnPropertyDescriptor,Re=(e,t,s,o)=>{for(var r=o>1?void 0:o?Eg(t,s):t,n=e.length-1,i;n>=0;n--)(i=e[n])&&(r=(o?i(t,s,r):i(r))||r);return o&&r&&Mg(t,s,r),r};const Ua="log-stream-container-model",_g="/kos/logs/subscription/addBlock/*",Ig="/kos/logs/subscription/updateBlock/*",Tg="/kos/logs/subscription/removeBlock/*",$g="/kos/logs/subscription/lines/*",ja="/kos/logs/streams/add/*";let ue=class{constructor(e,t,s){a(this,"id");a(this,"logger");a(this,"selectedStream");a(this,"_models");this.id=e,this.logger=s.logger,this._models=new fe({parentId:e}),this.selectedStream=void 0}getModel(e){return this._models.getModel(e)}get models(){return this._models}get data(){return this._models.data}updateModel(e){}addModel(e){this._models.addModel(e)}removeModel(e){this._models.removeModel(e)}updateSelectedStream(e){this.selectedStream=e}handleStreamAdded(e){this.logger.debug(`Received topic: ${ja}`);const t=e.stream,s=$t.instance(t).options({name:t,nodeId:"primary"}).build();this.addModel(s)}handleAddBlock(e,t){this.logger.debug(`Received topic: ${t.headers.topic}`);const s=e.stream,o=this.models.getModel(s);o&&o.addBlock(e)}handleRemoveBlock(e,t){this.logger.debug(`Received topic: ${t.headers.topic}`);const s=e.stream,o=this.models.getModel(s);o&&o.removeBlock(e.blockNum)}handleUpdateBlock(e,t){this.logger.debug(`Received topic: ${t.headers.topic}`);const s=e.stream,o=this.models.getModel(s);o&&o.updateBlock(e)}handleLogLine(e,t){var r;this.logger.debug(`Received topic: ${t.headers.topic}`);const s=e.stream,o=this.models.getModel(s);o&&((r=o.currentBlock)==null||r.addLines(e.lines))}async init(){this.logger.debug(`initializing log-stream-container container ${this.id}`)}async subscribeToLogStream(e){const t=$t.instance(e).options({name:e,nodeId:"primary"}).build();this.addModel(t),await t.subscribe()}async load(){this.logger.debug(`loading log-stream-container container ${this.id}`);const[e,t]=await Ca();if(e){this.logger.error(`Error loading log-streams: ${e}`);return}t&&t.forEach(s=>{const o=$t.instance(s).options({name:s,nodeId:"primary"}).build();this.addModel(o)})}};Re([ce],ue.prototype,"_models",2);Re([R({topic:[ja],websocket:!0})],ue.prototype,"handleStreamAdded",1);Re([R({topic:[_g],websocket:!0})],ue.prototype,"handleAddBlock",1);Re([R({topic:[Tg],websocket:!0})],ue.prototype,"handleRemoveBlock",1);Re([R({topic:[Ig],websocket:!0})],ue.prototype,"handleUpdateBlock",1);Re([R({topic:[$g],websocket:!0})],ue.prototype,"handleLogLine",1);ue=Re([D(Ua)],ue);const Yt=new we({class:ue,type:Ua});Yt.addRelatedModel($t);Yt.addRelatedModel(js);Yt.addRelatedModel(Lt);const Og=e=>e.rank!==void 0,Dg=e=>e.visibleRole!==void 0,Sg=e=>e.color!==void 0,Ag=e=>{const t=e.info;return Og(t)?t.rank:0},Cg=e=>{const t=e.info;return Sg(t)?t.color:"orange"},Rg=e=>{const t=e.info;return Dg(t)?t.visibleRole:"TECHNICIAN"},{URL:ar}=q(),{getAll:Lg,postModel:Ba}=V.build({basePath:`${ar}/api/kos/troubles`}),Ka=async()=>await Lg({}),Ga=async(e,t)=>{try{const s=await Ba({model:{},urlOverride:`${ar}/api/kos/troubles/resolve/${e}`,tracker:t});return s!=null&&s.data&&De.initiateFuture(s.data),s.data}catch{const o={id:t||"",endState:Ke.Fail,tracker:t,reason:"Failed to resolve trouble"};return De.initiateFuture(o),o}},kg=async(e,t)=>{try{const s=await Ba({model:e,urlOverride:`${ar}/api/kos/troubles/resolve/`,tracker:t});return s!=null&&s.data&&De.initiateFuture(s.data),s.data}catch{const o={id:t||"",endState:Ke.Fail,tracker:t,reason:"Failed to resolve troubles"};return De.initiateFuture(o),o}},Pg=Object.freeze(Object.defineProperty({__proto__:null,bulkResolveTroubles:kg,getTroubles:Ka,resolveTrouble:Ga},Symbol.toStringTag,{value:"Module"})),ws="troubleDataMapper",Xt=new Map;Fo(ws,{register:(e,t)=>{var s;Xt.has(e)||Xt.set(e,[]),(s=Xt.get(e))==null||s.push(t)},execute:async(e,t)=>{const s=Xt.get(e);if(!s)return{...t.data};const o=s.map(i=>i(t));return(await Promise.allSettled(o)).reduce((i,c)=>(c.status==="fulfilled"?i={...i,...c.value}:f.info(`Trouble mapper ${e} failed: ${c.reason}`),i),{...t.data})}});const zt="troubleMapper",es=new Map;Fo(zt,{register:(e,t)=>{var s;es.has(e)||es.set(e,[]),(s=es.get(e))==null||s.push(t)},execute:async(e,t)=>{const s=es.get(e);if(!s)return[];const o=s.map(i=>i(t)),n=(await Promise.allSettled(o)).map(i=>i.status==="fulfilled"?i.value:(f.info(`Trouble mapper ${e} failed: ${i.reason}`),[])).flat();return Array.from(new Set(n))}});C[zt].register("nozzle",async e=>[e.data.nozzlePath]);C[zt].register("path",async e=>[e.data.path]);const xg=async e=>{const t=new Set,s=e.ifaces,o=s==null?void 0:s.map(n=>C[zt].execute(n,e));return(await Promise.allSettled(o)).forEach(n=>{n.status==="fulfilled"&&n.value.forEach(i=>t.add(i))}),Array.from(t)},Ha=async e=>{const t=e.ifaces,s=t==null?void 0:t.map(i=>C[ws].execute(i,e)),o=C[ws].execute(e.type,e);s.push(o);const n=(await Promise.allSettled(s)).reduce((i,c)=>(c.status==="fulfilled"&&(i={...i,...c.value}),i),{});return{...e.data,...n}};class Ng{constructor(){a(this,"type","ResolvableTrouble");a(this,"title","Resolvable Trouble");a(this,"subtitle","Trouble")}}class Fg{constructor(){a(this,"type","BlockPumpTrouble");a(this,"title","Block Pump Trouble");a(this,"subtitle","Trouble")}}class Pe{static getHandler(t){switch(t){case"ResolvableTrouble":return new Ng;case"BlockPumpTrouble":return new Fg;default:return}}}var Ug=Object.defineProperty,jg=Object.getOwnPropertyDescriptor,Va=(e,t,s,o)=>{for(var r=o>1?void 0:o?jg(t,s):t,n=e.length-1,i;n>=0;n--)(i=e[n])&&(r=(o?i(t,s,r):i(r))||r);return o&&r&&Ug(t,s,r),r};const ct="trouble-model";function ts(e){return typeof e.shouldDefer=="boolean"}let vs=class{constructor(e,{resolvable:t,tags:s,info:o,id:r,clientData:n,rank:i,ifaces:c,type:l,group:d,createTime:u,role:g,color:y,...v},b){a(this,"id");a(this,"logger");a(this,"_troubleId");a(this,"_resolvable");a(this,"type");a(this,"futureHandler");a(this,"ifaces");a(this,"clientData");a(this,"info");a(this,"role");a(this,"color");a(this,"tags");a(this,"data");a(this,"rank");a(this,"group");a(this,"createTime");a(this,"_mapped",{});this.id=e,this.logger=b.logger,this.type=l,this._troubleId=r,this._resolvable=!!t,this.ifaces=c,this.rank=i,this.role=g,this.color=y,this.tags=s,this.info=o,this.group=d,this.createTime=u,this.clientData=n,this.data={},Object.assign(this.data,v),this.futureHandler=new Xo(this)}getTitleWithContext(e){var s,o;const t=e?(o=(s=Pe.getHandler(this.type))==null?void 0:s.context)==null?void 0:o[e]:Pe.getHandler(this.type);return(t==null?void 0:t.title)||"Trouble"}getSubtitleWithContext(e){var s,o;const t=e?(o=(s=Pe.getHandler(this.type))==null?void 0:s.context)==null?void 0:o[e]:Pe.getHandler(this.type);return(t==null?void 0:t.subtitle)||"Trouble"}get rawId(){return this._troubleId}get title(){var e;return((e=Pe.getHandler(this.type))==null?void 0:e.title)||"Trouble"}get subtitle(){var e;return((e=Pe.getHandler(this.type))==null?void 0:e.subtitle)||"Trouble"}get troubleId(){return this._troubleId}get resolvable(){return this._resolvable}get future(){return this.futureHandler.future}async resolveMappedData(){return await Ha(this)}get deferredCompanion(){const e=fo(this.id,t=>ts(t));if(e&&ts(e.modelData))return e.modelData}get deferred(){return this.deferredCompanion?this.deferredCompanion.deferred:!1}get shouldDefer(){const e=fo(this.id,t=>ts(t));return e&&ts(e.modelData)?e.modelData.shouldDefer:!1}clearDefer(){var e;(e=this.deferredCompanion)==null||e.clearDefer()}defer(){var e;(e=this.deferredCompanion)==null||e.defer()}getChildren(){return[...this.futureHandler.allFutures]}async resolve(e){var t;if(!this._resolvable)throw this.logger.error(`attempting to resolve an unresolvable trouble with id ${this._troubleId}`),new Error("Trouble is not resolvable");if(this.shouldDefer){(t=this.deferredCompanion)==null||t.defer();return}return await Ga(this._troubleId,e)}};Va([vr()],vs.prototype,"resolve",1);vs=Va([D(ct)],vs);const kt={registration:{[ct]:{class:vs,singleton:!1}},type:ct,predicate:ee(ct),factory:H.Factory.create(ct)};var Bg=Object.defineProperty,Kg=Object.getOwnPropertyDescriptor,Bs=(e,t,s,o)=>{for(var r=o>1?void 0:o?Kg(t,s):t,n=e.length-1,i;n>=0;n--)(i=e[n])&&(r=(o?i(t,s,r):i(r))||r);return o&&r&&Bg(t,s,r),r};const Zr=f.createLogger({name:"trouble-container-model"});function Jr(e){return C.propertyMapper.hasMapper(oe.TroubleRank)?C.propertyMapper.executeMapper(oe.TroubleRank,e):Ag(e)}function Qr(e){return(C.propertyMapper.hasMapper(oe.TroubleColor)?C.propertyMapper.executeMapper(oe.TroubleColor,e):Cg(e)).toLowerCase()}function Xr(e){return(C.propertyMapper.hasMapper(oe.TroubleRole)?C.propertyMapper.executeMapper(oe.TroubleRole,e):Rg(e)).toLowerCase()}const Gg="trouble-container-model";class X{}a(X,"INDEX_TROUBLES_BY_IFACE","byIface"),a(X,"INDEX_TROUBLES_BY_TYPE","byType"),a(X,"INDEX_TROUBLES_BY_GROUP","byGroup"),a(X,"INDEX_TROUBLES_BY_DEFERRED","byDeferred"),a(X,"SORT_KEY_RANK","rank"),a(X,"TROUBLES_DEFERRED","true");let He=class{constructor(e){a(this,"id");a(this,"troubles");this.id=e,this.troubles=new fe({indexMap:{[X.INDEX_TROUBLES_BY_IFACE]:xg,[X.INDEX_TROUBLES_BY_TYPE]:"type",[X.INDEX_TROUBLES_BY_GROUP]:"group",[X.INDEX_TROUBLES_BY_DEFERRED]:"deferred"},sortKey:X.SORT_KEY_RANK,parentId:e})}async load(){Zr.debug("loading trouble container");const e=await Ka();try{e==null||e.data.forEach(t=>{const s={...t,rank:Jr(t),color:Qr(t),role:Xr(t),id:String(t.id)},o=kt.factory(`trouble-${t.id}`)(s);this.troubles.addModel(o)})}catch(t){throw Zr.error(t),t}}handleTroubleRemoved(e){const t=`trouble-${e}`,s=this.troubles.getModel(t);this.troubles.removeModel(t),s&&Oe(s)}handleTroubleAdded(e){const t={...e,rank:Jr(e),color:Qr(e),role:Xr(e),id:String(e.id)};if(t.role==="NONE")return;const s=kt.factory(`trouble-${e.id}`)(t);this.troubles.addModel(s)}};Bs([ce],He.prototype,"troubles",2);Bs([R({topic:"/kos/trouble/remove",websocket:!0,lifecycle:x.INIT})],He.prototype,"handleTroubleRemoved",1);Bs([R({topic:"/kos/trouble/add",websocket:!0})],He.prototype,"handleTroubleAdded",1);He=Bs([D(Gg)],He);const ss="trouble-container-model",Ve={registration:{[ss]:{class:He,singleton:!0}},type:ss,predicate:ee(ss),factory:H.Singleton.create(ss)},{URL:Ya}=q(),{getAll:Hg}=V.build({basePath:`${Ya}/api/kos/ota`}),en=f.createLogger({name:"ota-service",group:"Services"}),Vg=async()=>{en.debug("sending GET request to /api/kos/ota/artifacts");const e=await Hg({urlOverride:`${Ya}/api/kos/ota/artifacts`});return en.debug("getArtifacts - response:",e),e==null?void 0:e.data};var Yg=Object.defineProperty,zg=Object.getOwnPropertyDescriptor,Ks=(e,t,s,o)=>{for(var r=o>1?void 0:o?zg(t,s):t,n=e.length-1,i;n>=0;n--)(i=e[n])&&(r=(o?i(t,s,r):i(r))||r);return o&&r&&Yg(t,s,r),r};const za="ota-model",qg=e=>{let t=null;for(const s in e){const o=e[s],r=o.lastUpdateTime;(!t||t.lastUpdateTime<r)&&(t=o)}return t},no=e=>{const t=e.artifactInfo,s=qg(e.requests),o=(t==null?void 0:t.identifier)||(s==null?void 0:s.kabId);if(!o)return;let r;switch(e.status){case"INSTALLED":r="ready";break;case"INVALID":r="error";break;case"MISSING":r=((s==null?void 0:s.currentSize)||0)>0?"downloading":"idle";break;case"STAGED":r="pending"}const n=t===void 0;return{id:o,manifest:n,label:t==null?void 0:t.version,name:t==null?void 0:t.name,status:r,error:r==="error"?s==null?void 0:s.lastErrorReason:void 0,errorCount:r==="error"?s==null?void 0:s.errorCount:0,progress:r==="downloading"&&s&&!n?s.currentSize/(t==null?void 0:t.size)*100:void 0,size:t==null?void 0:t.size}};let Ye=class{constructor(e,t,s){a(this,"id");a(this,"logger");a(this,"data",new Ui);a(this,"troubleContainer");this.id=e,this.logger=s.logger}get downloadInProgressTrouble(){var t;return(t=this.troubleContainer.troubles.getIndexByKey("byType","OTADownloadInProgressTrouble"))==null?void 0:t[0]}get updatePendingTrouble(){var t;return(t=this.troubleContainer.troubles.getIndexByKey("byType","OTAUpdatePendingTrouble"))==null?void 0:t[0]}get pausedDueToErrorsTrouble(){var t;return(t=this.troubleContainer.troubles.getIndexByKey("byType","OTAPausedDueToErrorsTrouble"))==null?void 0:t[0]}get updates(){return this.data}get status(){return this.pausedDueToErrorsTrouble?"error":this.downloadInProgressTrouble?"downloading":this.updatePendingTrouble?"pending":"idle"}installAndReboot(){var e;this.updatePendingTrouble||this.logger.error("installAndReboot - OTAUpdatePendingTrouble not present"),this.logger.debug("installAndReboot - resolve OTAUpdatePendingTrouble"),(e=this.updatePendingTrouble)==null||e.resolve()}async init(){this.logger.debug(`initializing ota ${this.id}`)}async load(){this.logger.debug(`loading ota ${this.id}`);try{const e=await Vg();e&&e.forEach(t=>{const s=no(t);s&&this.data.addModel(s)})}catch(e){this.logger.error(`loading ota ${this.id} - error:`,e)}}async handleAllArtifacts(e){this.logger.debug("handleAllArtifacts:",e),await this.data.clear();try{e.forEach(t=>{const s=no(t);s&&this.data.addModel(s)})}catch(t){this.logger.error(`handleAllArtifacts ${this.id} - error:`,t)}}handleChangedArtifacts(e){this.logger.debug("handleChangedArtifacts:",e);try{e.forEach(t=>{const s=no(t);s&&this.data.updateModel(s)})}catch(t){this.logger.error(`handleChangedArtifacts ${this.id} - error:`,t)}}};Ks([Bt({modelType:Ve.type})],Ye.prototype,"troubleContainer",2);Ks([R({topic:"/kos/ota/artifacts/all",websocket:!0})],Ye.prototype,"handleAllArtifacts",1);Ks([R({topic:"/kos/ota/artifacts/changed",websocket:!0})],Ye.prototype,"handleChangedArtifacts",1);Ye=Ks([D(za)],Ye);const Ms=new we({class:Ye,type:za}),tn=f.createLogger({name:"software-info-service",group:"Services"}),qa=async()=>{tn.debug("sending GET for software-info");const[e,t]=await ha.get("/api/kos/manifest/info");if(!t)throw tn.error("Failed to fetch software-info",e),new ne("Failed to fetch software-info");return t},Wg=Object.freeze(Object.defineProperty({__proto__:null,getSoftwareInfos:qa},Symbol.toStringTag,{value:"Module"}));var Zg=Object.defineProperty,Jg=Object.getOwnPropertyDescriptor,Qg=(e,t,s,o)=>{for(var r=o>1?void 0:o?Jg(t,s):t,n=e.length-1,i;n>=0;n--)(i=e[n])&&(r=(o?i(t,s,r):i(r))||r);return o&&r&&Zg(t,s,r),r};const lt="software-info-model";let bo=class{constructor(e,t,s){a(this,"id");a(this,"logger");a(this,"nodes");this.id=e,this.logger=s.logger,this.nodes=[]}async init(){this.logger.debug(`initializing software-info ${this.id}`)}groupBy(e,t){return e.reduce((s,o)=>(s[o[t]]=[...s[o[t]]||[],o],s),{})}async load(){this.logger.debug(`loading software-info ${this.id}`);try{const e=await qa(),t=(e==null?void 0:e.nodes)||{};Y(()=>{const o=Object.keys(t).map(r=>t[r][0]).map(r=>({nodeName:r.node,group:this.groupBy(r.artifacts,"group")}));this.nodes=o})}catch(e){e instanceof ne&&this.logger.error("Failed to fetch software-info",e)}}};bo=Qg([D(lt)],bo);const Es={registration:{[lt]:{class:bo,singleton:!1}},type:lt,predicate:ee(lt),factory:H.Factory.create(lt)},{URL:Wa}=q(),{getOne:Xg}=V.build({basePath:`${Wa}/api/kos/state`}),ef=f.createLogger({name:"state-bean-service",group:"Services"}),Za=async({path:e})=>(ef.debug("sending GET for state-bean"),await Xg({urlOverride:`${Wa}/api/kos/state/${e}`})),tf=Object.freeze(Object.defineProperty({__proto__:null,getStateBeanData:Za},Symbol.toStringTag,{value:"Module"}));var sf=Object.defineProperty,of=Object.getOwnPropertyDescriptor,Ja=(e,t,s,o)=>{for(var r=o>1?void 0:o?of(t,s):t,n=e.length-1,i;n>=0;n--)(i=e[n])&&(r=(o?i(t,s,r):i(r))||r);return o&&r&&sf(t,s,r),r};const dt="state-bean-model",rf=Se("path");let _s=class{constructor(e,t,s){a(this,"id");a(this,"path");a(this,"props");a(this,"logger");this.id=e,this.logger=s.logger,this.props=Yo.map(new Map),co(t,this)}updateModel(e){co(e,this)}handleConfigBeanUpdated(e){Object.entries(e).forEach(([t,s])=>{let o=s;typeof o=="string"&&Wo(o)&&(o=o.toLowerCase()=="true"),typeof o=="string"&&xs(o)&&(o=Number(o)),this.props.set(t,o)})}async init(){this.logger.debug(`initializing state-bean ${this.id}`)}updateProps(e){Object.entries(e).forEach(([t,s])=>{this.props.set(t,s)})}async load(){this.logger.debug(`loading state-bean ${this.id}`);const e=await Za({path:this.path});e!=null&&e.data&&this.updateProps(e.data)}};Ja([R({topic:`/kos/state/${rf}`,websocket:!0})],_s.prototype,"handleConfigBeanUpdated",1);_s=Ja([D(dt)],_s);const Pt={registration:{[dt]:{class:_s,singleton:!1}},type:dt,predicate:ee(dt),factory:H.Factory.create(dt)};var nf=Object.defineProperty,af=Object.getOwnPropertyDescriptor,Qa=(e,t,s,o)=>{for(var r=o>1?void 0:o?af(t,s):t,n=e.length-1,i;n>=0;n--)(i=e[n])&&(r=(o?i(t,s,r):i(r))||r);return o&&r&&nf(t,s,r),r};const ut="state-prop-model",sn=Se("path");let Is=class{constructor(e,t,s){a(this,"id");a(this,"path");a(this,"attribute");a(this,"logger");a(this,"stateBean");this.id=e,this.logger=s.logger,this.path=t.path,this.attribute=t.attribute}get value(){return this.stateBean.props.get(this.attribute)}async init(){this.logger.debug(`initializing state-prop ${this.id}`)}async load(){this.logger.debug(`loading state-prop ${this.id}`)}toString(){var e;return((e=this.value)==null?void 0:e.toString())??""}};Qa([Bt({modelType:Pt.type,id:`state-bean-${sn}`,options:{path:sn}})],Is.prototype,"stateBean",2);Is=Qa([D(ut)],Is);const cr={registration:{[ut]:{class:Is,singleton:!1}},type:ut,predicate:ee(ut),factory:H.Factory.create(ut)},{URL:cf}=q(),{getAll:lf}=V.build({basePath:`${cf}/api/state-prop`}),df=f.createLogger({name:"state-prop-service",group:"Services"}),uf=async()=>(df.debug("sending GET for state-prop"),await lf({})),hf=Object.freeze(Object.defineProperty({__proto__:null,getStateProps:uf},Symbol.toStringTag,{value:"Module"})),{URL:lr}=q(),{getOne:Xa}=V.build({basePath:`${lr}/api/translation`}),Ot=f.createLogger({name:"translation-service",group:"Services"}),gf=()=>{const e=window.location.origin,t=ae();return(t==null?void 0:t.host)||e},ec=async(e,t)=>{Ot.debug("sending GET for translation");const s=t??gf();try{const o=await fetch(`${s}${e}`);return o.status!==200?(Ot.warn(`Failed to fetch translations at ${e}: ${o.status}`),{}):await o.json()}catch(o){throw Ot.error("Error fetching translations",o),o}},ff=async()=>{Ot.debug("getting localization descriptor");const e=await Xa({urlOverride:`${lr}/api/system/kos/localization`});if((e==null?void 0:e.status)!==200)throw new Error(`Failed to get tool localization descriptor ${e==null?void 0:e.status}`);return e.data},tc=e=>async()=>{Ot.debug("getting kos localization descriptor");const t=await Xa({urlOverride:`${lr}/api/kos/localization/contexts`});if((t==null?void 0:t.status)!==200)throw new Error(`Failed to get tool localization descriptor ${t==null?void 0:t.status}`);return t.data[e]},sc="langResolver";var mf=Object.defineProperty,pf=Object.getOwnPropertyDescriptor,yf=(e,t,s,o)=>{for(var r=o>1?void 0:o?pf(t,s):t,n=e.length-1,i;n>=0;n--)(i=e[n])&&(r=(o?i(t,s,r):i(r))||r);return o&&r&&mf(t,s,r),r};const ht="translation-model";function bf(e){const t=typeof e=="string",s=t?!1:!!(e!=null&&e.data)&&typeof(e==null?void 0:e.data)!="string",o=t?e:e==null?void 0:e.defaultValue,r=t||e==null?void 0:e.context,n=t?void 0:s?e==null?void 0:e.data:e;return{isBasicOptions:t,defaultValue:o,context:r,data:n}}function oc(e,t=""){return Object.keys(e).reduce((s,o)=>{const r=t?`${t}.${o}`:o;if(typeof e[o]=="object"&&e[o]!==null){const n=oc(e[o],r);return{...s,...n}}else return{...s,[r]:e[o]}},{})}function rc(e,t){const s={...e};for(const o in t)Object.prototype.hasOwnProperty.call(t,o)&&(typeof t[o]=="object"&&t[o]!==null&&typeof e[o]=="object"&&e[o]!==null?s[o]=rc(e[o],t[o]):s[o]=t[o]);return s}const wo=(e,t)=>{const s=/__(.*?)__/g,o=e.replace(s,(r,n)=>Object.prototype.hasOwnProperty.call(t||{},n.trim())?t==null?void 0:t[n.trim()]:r);return o===e?o:s.test(o)?wo(o,t):o},os=(e,t,s)=>{const o=/{{(.*?)}}/g,n=wo(e,t).replace(o,(c,l)=>Object.prototype.hasOwnProperty.call(s||{},l.trim())?s==null?void 0:s[l.trim()]:c);return wo(n,t)},on=(e,t)=>{if(t.includes(":")){const[s,o]=t.split(":");return{namespace:s,key:o}}else return{namespace:e,key:t}};let vo=class{constructor(e,t,s){a(this,"id");a(this,"namespace");a(this,"descriptor");a(this,"defaultLocale");a(this,"currentLocale");a(this,"bundleResolver");a(this,"data");a(this,"logger");a(this,"resolver");a(this,"disposer");a(this,"context");a(this,"rootUrl");this.id=e,this.defaultLocale=t.defaultLocale||"en",this.currentLocale=t.currentLocale||"en",this.namespace=t.namespace,this.descriptor=t.descriptor,this.rootUrl=t.rootUrl,this.data={},this.resolver=t.resolver||s.kosContext.get(sc),this.bundleResolver=t.bundleResolver,this.logger=s.logger,this.context=s.kosContext.parentModel}getTranslationLocales(e){const t=this.descriptor[e];if(!e||!t)return[this.defaultLocale];if(!this.defaultLocale&&!t.fallbacks)return[e];let s=t.fallbacks||[this.defaultLocale];return s.includes(e)||(s=[e,...s]),s}async loadTranslations(){const e=this.getTranslationLocales(this.currentLocale).reverse(),t=e.map(o=>{if(this.bundleResolver){const r=P.getContext(this.id);return this.bundleResolver(this.namespace,o,r)}try{const r=this.resolver(this.namespace,o);return ec(r,this.rootUrl)}catch{return Promise.resolve({})}}),s=await Promise.allSettled(t);Y(()=>{const o=s.reduce((r,n,i)=>(n.status==="fulfilled"?(this.logger.debug(`resolved ${e[i]}`,n.value),n.value&&(r=rc(r,n.value))):this.logger.error(`failed to load translation ${this.id} for ${e[i]}`),r),{});this.data=oc(o)})}async init(){this.logger.debug(`initializing translation ${this.id}`)}exists(e){const{namespace:t,key:s}=on(this.namespace,e);if(t!==this.namespace){const o=this.context.getModel(t);return o?o.exists(s):!1}return!!this.data[s]}resolveKey(e,t){if(!e)return this.logger.debug("key is empty"),"";const{defaultValue:s,context:o,data:r}=bf(t),{namespace:n,key:i}=on(this.namespace,e),c=`${i}_${o}`;if(n!==this.namespace){const l=this.context.getModel(n);return l?l.resolveKey(i,t):i}if(o&&this.data[c]){const l=this.data[c];return Array.isArray(l)?l.map(d=>os(d,this.data,r)):os(this.data[c],this.data,r)}if(this.data[i]){const l=this.data[c];return Array.isArray(l)?l.map(d=>os(d,this.data,r)):os(this.data[i],this.data,r)}return s??i}unload(){this.logger.debug(`unloading translation ${this.id}`),this.disposer&&this.disposer()}async load(){this.logger.debug(`loading translation ${this.id}`),await this.loadTranslations()}async ready(){this.logger.debug(`ready translation ${this.id}`),this.disposer=w.reaction(()=>this.currentLocale,(e,t)=>{this.logger.info(`translation langs for namespace ${this.id} changed from ${t} to ${e}`),this.loadTranslations()})}};vo=yf([Ps(),D(ht)],vo);const Ts={registration:{[ht]:{class:vo,singleton:!1}},type:ht,predicate:ee(ht),factory:H.Factory.create(ht)};var wf=Object.defineProperty,vf=Object.getOwnPropertyDescriptor,nc=(e,t,s,o)=>{for(var r=o>1?void 0:o?vf(t,s):t,n=e.length-1,i;n>=0;n--)(i=e[n])&&(r=(o?i(t,s,r):i(r))||r);return o&&r&&wf(t,s,r),r};const gt="translation-container-model",Mf=(e,t="/")=>e.join(t).replace(new RegExp(t+"{1,}","g"),t);function Ef(e,t){const s=this.descriptor.namespaces[e];if(!s)throw new Error(`namespace ${e} not found in descriptor`);const o=s.basePath,r=s.locales[t].file;return Mf([o,r])}let $s=class{constructor(e,t,s){a(this,"id");a(this,"lang");a(this,"rootUrl");a(this,"descriptor");a(this,"_defaultNamespace");a(this,"resolver");a(this,"logger");a(this,"descriptorUrl");a(this,"namespaces",[]);a(this,"_models");this.id=e,this.lang=t.lang||"en",this.descriptor=t.descriptor,this._defaultNamespace=t.defaultNamespace,this.descriptorUrl=t.descriptorUrl,this.rootUrl=t.rootUrl,this.resolver=t.resolver||Ef.bind(this),s.kosContext.set(sc,this.resolver),this.logger=s.logger,this._models=new fe({parentId:e})}set currentLocale(e){this.lang=e,this.models.data.forEach(t=>{t.currentLocale=e})}get defaultNamespace(){return this._defaultNamespace?this.getModel(`translation-${this._defaultNamespace}`):void 0}getModel(e){return this.logger.debug(`getting model ${e}`),this._models.getModel(`translation-${e}`)}get models(){return this._models}get data(){return this._models.data}async reload(){this._models.clear(),await Ii(this);for(const e of this.namespaces){const t=this.resolveNamespace(e);await J(t)}}resolveNamespace(e){var s;if((s=this.descriptor.namespaces)==null?void 0:s[e]){const o=Object.keys(this.descriptor.namespaces[e].locales)[0],r=this.descriptor.namespaces[e].locales[o].defaultLocale,n=Ts.factory(`translation-${e}`)({kosParentId:this.id,namespace:e,rootUrl:this.rootUrl,currentLocale:this.lang,defaultLocale:r,descriptor:this.descriptor.namespaces[e].locales,resolver:this.resolver});return this.addModel(n),this.namespaces.includes(e)||Y(()=>{this.namespaces.push(e)}),n}else{this.logger.warn(`namespace ${e} not found in descriptor`);const o=Ts.factory(`translation-${e}`)({kosParentId:this.id,namespace:e,rootUrl:this.rootUrl,currentLocale:this.lang,defaultLocale:this.lang,descriptor:{},resolver:this.resolver});return this.addModel(o),o}}addModel(e){this._models.addModel(e)}removeModel(e){this._models.removeModel(e)}async init(){this.logger.debug(`initializing translation-container container ${this.id}`)}async load(){this.logger.debug(`loading translation-container container ${this.id}`)}};nc([ce],$s.prototype,"_models",2);$s=nc([D(gt)],$s);const he={registration:{[gt]:{class:$s,singleton:!0}},type:gt,predicate:ee(gt),factory:H.Singleton.create(gt)},_f={set(e,t){const s=P.getContext(he.type);s&&s.set(e,t)},get(e){const t=P.getContext(he.type);return t==null?void 0:t.get(e)}},ic={async init(e){const t=he.factory(e);return await J(t),{translations:t}}},If=(e,t)=>{const s=t.type;return e[s]||(e[s]=[]),e[s].push(t),e},ac="kos-ws-event",dr=Qe(ac);var Tf=Object.defineProperty,$f=Object.getOwnPropertyDescriptor,ur=(e,t,s,o)=>{for(var r=o>1?void 0:o?$f(t,s):t,n=e.length-1,i;n>=0;n--)(i=e[n])&&(r=(o?i(t,s,r):i(r))||r);return o&&r&&Tf(t,s,r),r};const Of=({headers:e,body:t})=>Object.entries(e).map(([o,r])=>`${o}:${r}`).join("\\n")+"\\n\\n"+t;exports.WsEventModel=class{constructor(t){a(this,"id");a(this,"events");a(this,"_topicMap");this.id=t,this.events=w.observable.map(new Map),this._topicMap=new Map}get websocketEvents(){return Array.from(this.events.values())}handleSendEvent(t,s){this.processEvent(s,!0)}handleReceiveEvent(t,s){this.processEvent(s)}processEvent(t,s=!1){f.debug("kos event received");const{body:o,headers:r}=t.body,n=r["request-id"]||r["response-id"],i=r["request-id"]||r["response-id"]||r.topic||r.type;if(i){let c=i;if(n)c=`${c}-${s?"send":"receive"}`;else{const d=this._topicMap.get(i)||0;c=`${c}-${d+1}`,this._topicMap.set(i,d+1)}const l={msgId:c,content:o,headers:r,timestamp:Date.now(),raw:Of({headers:r,body:o}),direction:s?"send":"receive",mocked:!!r.mocked};this.events.set(c,l),f.debug(`logged ${this.events.size} events`)}}};ur([R({topic:[jt.SEND]})],exports.WsEventModel.prototype,"handleSendEvent",1);ur([R({topic:[jt.RECEIVED]})],exports.WsEventModel.prototype,"handleReceiveEvent",1);exports.WsEventModel=ur([D(dr.type)],exports.WsEventModel);const{URL:hr}=q(),{getOne:cc}=V.build({basePath:`${hr}/api/device`}),Os=f.createLogger({name:"device-service",group:"Services"}),lc=async()=>{Os.debug("sending GET for device serial number");try{const e=await cc({urlOverride:`${hr}/api/kos/device/serialNumber`});return[void 0,e==null?void 0:e.data.serialNumber]}catch(e){if(e instanceof ne)return Os.error(`Error fetching device serial number: ${e.payload.error}`),[e.payload.error,void 0]}return["unknownError",void 0]},dc=async()=>{Os.debug("sending GET for device details");try{const e=await cc({urlOverride:`${hr}/api/kos/device`});return e?[void 0,e.data]:["unknownError",void 0]}catch(e){if(e instanceof ne)return Os.error(`Error fetching device serial number: ${e.payload.error}`),[e.payload.error,void 0]}return["unknownError",void 0]},Df=Object.freeze(Object.defineProperty({__proto__:null,getDeviceDetails:dc,getSerialNumber:lc},Symbol.toStringTag,{value:"Module"}));var Sf=Object.defineProperty,Af=Object.getOwnPropertyDescriptor,uc=(e,t,s,o)=>{for(var r=o>1?void 0:o?Af(t,s):t,n=e.length-1,i;n>=0;n--)(i=e[n])&&(r=(o?i(t,s,r):i(r))||r);return o&&r&&Sf(t,s,r),r};const hc="device-model",Cf="/kos/criticalData/changed",Rf="/kos/criticalData/available";let Ds=class{constructor(e,t,s){a(this,"id");a(this,"logger");a(this,"_serialNumber");a(this,"_name");a(this,"_nodeId");this.id=e,this.logger=s.logger,this._serialNumber="unassigned",this._name="unassigned",this._nodeId="unassigned"}get serialNumber(){return this._serialNumber}get name(){return this._name}get nodeId(){return this._nodeId}get nodeType(){const[e]=this.nodeId.split("-");return e}get nodeName(){const[,e]=this.nodeId.split("-");return e}updateModel(e){this._serialNumber=e.serialNumber??"unassigned",this._name=e.name??"unassigned",this._nodeId=e.nodeId??"unassigned"}async loadDeviceData(){const[e,t]=await dc();if(e){this.logger.error(`Error fetching device serial number: ${e}`);return}if(t){const{name:s,nodeId:o}=t;this.updateModel({name:s,nodeId:o,serialNumber:this.serialNumber})}}async loadSerialNumber(){const[e,t]=await lc();if(e){this.logger.error(`Error fetching device serial number: ${e}`);return}this.updateModel({serialNumber:t,name:this.name,nodeId:this.nodeId})}async handleCriticalDataChanged(){this.logger.debug(`Critical data changed for device ${this.id}`),await this.loadSerialNumber()}async init(){this.logger.debug(`initializing device ${this.id}`)}async load(){this.logger.debug(`loading device ${this.id}`),await this.loadDeviceData(),await this.loadSerialNumber()}};uc([R({topic:[Cf,Rf],websocket:!0})],Ds.prototype,"handleCriticalDataChanged",1);Ds=uc([D(hc)],Ds);const Ss=new we({class:Ds,type:hc});var Lf=Object.defineProperty,kf=Object.getOwnPropertyDescriptor,Pf=(e,t,s,o)=>{for(var r=o>1?void 0:o?kf(t,s):t,n=e.length-1,i;n>=0;n--)(i=e[n])&&(r=(o?i(t,s,r):i(r))||r);return o&&r&&Lf(t,s,r),r};const gc="network-interface-model";let Mo=class{constructor(e,t,s){a(this,"id");a(this,"name");a(this,"type");a(this,"nmdevicestate");a(this,"hwaddress");a(this,"mtu");a(this,"configured");a(this,"wifi");a(this,"ethernet");a(this,"ip4settings");a(this,"category");a(this,"logger");this.id=e,this.logger=s.logger,this.name=t.name,this.type=t.type,this.nmdevicestate=t.nmdevicestate,this.hwaddress=t.hwaddress,this.mtu=t.mtu,this.configured=t.configured,this.wifi=t.wifi,this.ethernet=t.ethernet,this.ip4settings=t.ip4settings,this.category=t.category}updateModel(e){this.name=e.name,this.type=e.type,this.nmdevicestate=e.nmdevicestate,this.hwaddress=e.hwaddress,this.mtu=e.mtu,this.configured=e.configured,this.wifi=e.wifi,this.ethernet=e.ethernet,this.ip4settings=e.ip4settings,this.category=e.category}async init(){this.logger.debug(`initializing network-interface ${this.id}`)}async load(){this.logger.debug(`loading network-interface ${this.id}`)}};Mo=Pf([D(gc)],Mo);const gr=new le({class:Mo,type:gc}),{URL:xf}=q(),{getAll:Nf}=V.build({basePath:`${xf}/api/kos/network/interfaces`}),rn=f.createLogger({name:"network-interface-service",group:"Services"}),fc=async()=>{rn.debug("sending GET for copy-logs");try{const e=await Nf({});return[void 0,e==null?void 0:e.data]}catch(e){if(e instanceof ne)return rn.error(`Error fetching log file size: ${e.payload.error}`),[e.payload.error,void 0]}return["unknownError",void 0]},Ff=Object.freeze(Object.defineProperty({__proto__:null,getNetworkInterfaces:fc},Symbol.toStringTag,{value:"Module"}));var Uf=Object.defineProperty,jf=Object.getOwnPropertyDescriptor,mc=(e,t,s,o)=>{for(var r=o>1?void 0:o?jf(t,s):t,n=e.length-1,i;n>=0;n--)(i=e[n])&&(r=(o?i(t,s,r):i(r))||r);return o&&r&&Uf(t,s,r),r};const pc="network-interface-container-model";let As=class{constructor(e,t,s){a(this,"id");a(this,"logger");a(this,"_models");this.id=e,this.logger=s.logger,this._models=new fe({parentId:e,indexMap:{byCategory:"category"}})}getModel(e){return this._models.getModel(e)}get models(){return this._models}get data(){return this._models.data}addModel(e){this._models.addModel(e)}removeModel(e){this._models.removeModel(e)}async init(){this.logger.debug(`initializing network-interface-container container ${this.id}`)}async refreshInterfaces(){this.logger.debug("refreshing interfaces");const[e,t]=await fc();if(e){this.logger.error(`Error loading network interfaces: ${e}`);return}t&&t.forEach(s=>{const o=gr.instance(s.name).forceUpdate.options(s).build();this.addModel(o)})}async load(){this.logger.debug(`loading network-interface-container container ${this.id}`),this.refreshInterfaces()}};mc([ce],As.prototype,"_models",2);As=mc([D(pc)],As);const xt=new we({class:As,type:pc});xt.addRelatedModel(gr);const{URL:Bf}=q(),{getAll:Kf}=V.build({basePath:`${Bf}/api/kos/storage/devices`}),nn=f.createLogger({name:"storage-device-service",group:"Services"}),yc=async()=>{nn.debug("sending GET for storage-device");const e=await Kf({});return!(e!=null&&e.data)||e.status!==200?(nn.error("Failed to retrieve storage-device data",e),[]):e.data},Gf=Object.freeze(Object.defineProperty({__proto__:null,getStorageDevices:yc},Symbol.toStringTag,{value:"Module"}));var Hf=Object.defineProperty,Vf=Object.getOwnPropertyDescriptor,Yf=(e,t,s,o)=>{for(var r=o>1?void 0:o?Vf(t,s):t,n=e.length-1,i;n>=0;n--)(i=e[n])&&(r=(o?i(t,s,r):i(r))||r);return o&&r&&Hf(t,s,r),r};const bc="storage-device-model";let Eo=class{constructor(e,t,s){a(this,"id");a(this,"mountDir");a(this,"removed");a(this,"vendor");a(this,"runTimeMs");a(this,"model");a(this,"nodeId");a(this,"local");a(this,"label");a(this,"syspath");a(this,"logger");this.id=e,this.logger=s.logger,this.mountDir=t.mountDir,this.removed=t.removed,this.vendor=t.vendor,this.runTimeMs=t.runTimeMs,this.model=t.model,this.nodeId=t.nodeId,this.local=t.local,this.label=t.label,this.syspath=t.syspath}updateModel(e){this.mountDir=e.mountDir,this.removed=e.removed,this.vendor=e.vendor,this.runTimeMs=e.runTimeMs,this.model=e.model,this.nodeId=e.nodeId,this.local=e.local,this.label=e.label,this.syspath=e.syspath}async init(){this.logger.debug(`initializing storage-device ${this.id}`)}async load(){this.logger.debug(`loading storage-device ${this.id}`)}};Eo=Yf([Ps(),D(bc)],Eo);const Cs=new le({class:Eo,type:bc});var zf=Object.defineProperty,qf=Object.getOwnPropertyDescriptor,fr=(e,t,s,o)=>{for(var r=o>1?void 0:o?qf(t,s):t,n=e.length-1,i;n>=0;n--)(i=e[n])&&(r=(o?i(t,s,r):i(r))||r);return o&&r&&zf(t,s,r),r};const wc="storage-device-container-model",Wf="/kos/storage";let Nt=class{constructor(e,t,s){a(this,"id");a(this,"logger");a(this,"_models");this.id=e,this.logger=s.logger,this._models=new fe({parentId:e})}getModel(e){return this._models.getModel(e)}get models(){return this._models}get data(){return this._models.data}addModel(e){this._models.addModel(e)}removeModel(e){this._models.removeModel(e)}async init(){this.logger.debug(`initializing storage-device-container container ${this.id}`)}get isStorageInserted(){return this.data.length>0}get volumes(){return this.data}handleStorageAvailability(e){this._models.data.filter(s=>!e.find(o=>o.id===s.id)).forEach(s=>{this.removeModel(s.id)}),e.forEach(s=>{const o=this.getModel(s.id);if(o){const r={...s,kosParentId:this.id};o.updateModel(r)}else{const r={...s,kosParentId:this.id},n=Cs.instance(s.id).options(r).build();this.addModel(n)}})}async load(){this.logger.debug(`loading storage-device-container container ${this.id}`),(await yc()).forEach(t=>{const s={...t,kosParentId:this.id},o=Cs.instance(t.id).options(s).build();this.addModel(o)})}};fr([ce],Nt.prototype,"_models",2);fr([R({topic:Wf,websocket:!0})],Nt.prototype,"handleStorageAvailability",1);Nt=fr([D(wc)],Nt);const ze=new we({class:Nt,type:wc});ze.addRelatedModel(Cs);const{URL:mr}=q(),{getAll:Zf,postModel:Jf}=V.build({basePath:`${mr}/api/kos/update/available`}),an=f.createLogger({name:"usb-update-service",group:"Services"}),vc=async()=>{an.debug("sending GET for usb-update");const e=await Zf({urlOverride:`${mr}/api/kos/update/available`});return!(e!=null&&e.data)||(e==null?void 0:e.status)!==200?(an.error("Failed to retrieve usb-update data",e),[]):e.data},Mc=async(e,t,s)=>{const o=await Jf({model:{manifestId:e,deviceId:t},tracker:s,urlOverride:`${mr}/api/kos/update/install`});if(!(o!=null&&o.data))throw new Error("No response from server");return o.data},Qf=Object.freeze(Object.defineProperty({__proto__:null,getAvailableUpdates:vc,installUpdate:Mc},Symbol.toStringTag,{value:"Module"}));var Xf=Object.defineProperty,em=Object.getOwnPropertyDescriptor,Ec=(e,t,s,o)=>{for(var r=o>1?void 0:o?em(t,s):t,n=e.length-1,i;n>=0;n--)(i=e[n])&&(r=(o?i(t,s,r):i(r))||r);return o&&r&&Xf(t,s,r),r};const _c="usb-update-model";let Rs=class{constructor(e,t,s){a(this,"id");a(this,"active");a(this,"blocked");a(this,"createTime");a(this,"deviceId");a(this,"manifestId");a(this,"notes");a(this,"futureHandler");a(this,"logger");this.id=e,this.logger=s.logger,this.active=t.active,this.blocked=t.blocked,this.createTime=t.createTime,this.deviceId=t.deviceId,this.manifestId=t.manifestId,this.notes=t.notes,this.futureHandler=new Xo(this)}updateModel(e){this.active=e.active,this.blocked=e.blocked,this.createTime=e.createTime,this.deviceId=e.deviceId,this.manifestId=e.manifestId,this.notes=e.notes}reset(){this.futureHandler.removeFuture()}get future(){return this.futureHandler.future}async install(e){if(!e)throw new Error("No tracker provided");return this.logger.info(`Installing update for manifest ${this.manifestId} from device ${this.deviceId}`),Mc(this.manifestId,this.deviceId,e)}async init(){this.logger.debug(`initializing usb-update ${this.id}`)}async load(){this.logger.debug(`loading usb-update ${this.id}`)}};Ec([vr()],Rs.prototype,"install",1);Rs=Ec([D(_c)],Rs);const pr=new le({class:Rs,type:_c});var tm=Object.defineProperty,sm=Object.getOwnPropertyDescriptor,Gs=(e,t,s,o)=>{for(var r=o>1?void 0:o?sm(t,s):t,n=e.length-1,i;n>=0;n--)(i=e[n])&&(r=(o?i(t,s,r):i(r))||r);return o&&r&&tm(t,s,r),r};const Ic="usb-update-container-model";let qe=class{constructor(e,t,s){a(this,"id");a(this,"disposer");a(this,"storageService");a(this,"_activeUpdate");a(this,"logger");a(this,"_models");this.id=e,this.logger=s.logger,this._models=new fe({parentId:e})}getModel(e){return this._models.getModel(e)}get models(){return this._models}get data(){return this._models.data}addModel(e){this._models.addModel(e)}removeModel(e){this._models.removeModel(e)}get activeUpdate(){return this._activeUpdate}reset(){this.clearActiveUpdate()}clearActiveUpdate(){this._activeUpdate=void 0}updateActiveUpdate(e){this._activeUpdate=e}get isUsbInserted(){return this.storageService.isStorageInserted}get hasAvailableUpdates(){return this._models.data.length>0}async syncAvailableUpdates(){const e=await vc();Y(()=>{const t=e.map(s=>`${s.deviceId}-${s.manifestId}`);this._models.data.filter(s=>!t.includes(s.id)).forEach(s=>this.removeModel(s.id)),e.forEach(s=>{const o=`${s.deviceId}-${s.manifestId}`,r=pr.instance(o).forceUpdate.options({...s,createTime:new Date(s.createTime)}).build();this.addModel(r)}),this.data.length===1?this.updateActiveUpdate(this.data[0]):this.clearActiveUpdate()})}usbInsertedEffect(){this.isUsbInserted?this.syncAvailableUpdates():(this._models.clear(),this.clearActiveUpdate())}async init(){this.logger.debug(`initializing usb-update-container container ${this.id}`)}unload(){var e;(e=this.disposer)==null||e.call(this)}async activate(){this.logger.debug(`activating usb-update-container container ${this.id}`),await this.syncAvailableUpdates()}async load(){this.logger.debug(`loading usb-update-container container ${this.id}`)}};Gs([Bt({modelType:ze.type})],qe.prototype,"storageService",2);Gs([ce],qe.prototype,"_models",2);Gs([Wn({dependencies:e=>[e.isUsbInserted]})],qe.prototype,"usbInsertedEffect",1);qe=Gs([D(Ic)],qe);const Ft=new we({class:qe,type:Ic});Ft.addRelatedModel(pr);const om=()=>({...{[et.type]:{class:ua},[ye.type]:{class:ba,singleton:!0},...z.registration,...Ae.registration,...Ve.registration,...Ts.registration,...he.registration,[dr.type]:{class:exports.WsEventModel,singleton:!0},...Pt.registration,...cr.registration,...ps.registration}}),yr=om(),rm={models:yr,preloadModels:[]},nm=!0,Tc=e=>()=>{const t=yr;return Di(_o)(kt).model(Ve).model(ze).model(Ft).model(Ss).model(Ms).model(Dt).model(Es).model(nr).model(xt).model(ma,nm).model(Yt),Object.keys(t).forEach(s=>{const o=t[s];Oi(_o)(s,o)}),{preload:$.model.preloadModel(e),model:$.model.register(e),companion:$.companion.register(e),legacy:$.model.registerLegacyModel(e)}},re={};re.core={models:Tc(re)};re.preload=$.model.preloadModel(re);re.model=$.model.register(re);re.companion=$.companion.register(re);re.legacy=$.model.registerLegacyModel(re);const _o=re;class im{registerTroubleRankMapper(t){return C.propertyMapper.registerPropertyMapper(oe.TroubleRank,t),this}registerTroubleRoleMapper(t){return C.propertyMapper.registerPropertyMapper(oe.TroubleRole,t),this}registerTroubleColorMapper(t){return C.propertyMapper.registerPropertyMapper(oe.TroubleColor,t),this}}const am=async(e,t)=>{const s=nr.instance(e).options({}).build(),o=t?`${t}-`:"";return await J(s),{getState:r=>s.data[`${o}${r}`],updateState:async(r,n)=>{await s.updateState(`${o}${r}`,n)},clean:async()=>{for(const r of s.data.keys)await s.updateState(`${o}${r}`,void 0)},unsubscribe:()=>{Oe(s)}}},$c="kos:service:region",Oc="regionId",cm=`${$c}-${Oc}`,Dc=async e=>{const t=Ae.factory(cm)({path:$c,attribute:Oc});await J(t),t.updateProperty(e)},br="/kos-timer-event",wr="defaultTimerEnd",ft=f.createLogger({name:"timer-manager"}),lm=e=>e.updateProperty!==void 0;class Sc{constructor(t,s,o){a(this,"name");a(this,"timeout");a(this,"timer");a(this,"state","inactive");a(this,"decrementValue",1);a(this,"remainingTime");a(this,"timeoutActions",new Map);this.name=t;const r=typeof s=="number"?s:s.value||60;this.timeout=r,this.state="inactive",this.remainingTime=r,lm(s)&&N(()=>{f.info(`Updating config value timer ${t} with new timeout value ${s.value}`);const n=s.value||60;this.updateTimeout(n)}),this.addTimeoutAction({name:wr}),o&&o.forEach(n=>{this.addTimeoutAction(n)})}get id(){return this.name}start(){if(this.state==="active"){ft.debug(`Timer ${this.name} already started`);return}(this.state==="inactive"||this.state==="paused")&&(this.state="active",this.timer=setInterval(()=>this.updateTimer(),1e3))}pause(){this.timer&&(ft.debug(`Pausing timer ${this.name}`),this.state="paused",clearInterval(this.timer))}restart(){this.pause(),this.remainingTime=this.timeout,this.start()}reset(){this.pause(),this.remainingTime=this.timeout,this.state="inactive"}updateTimeout(t){this.timeout=t,this.restart()}addTimeoutAction(t){const s=t.remainingTime??0;this.timeoutActions.has(s)||this.timeoutActions.set(s,[]);const o=t.name,r=this.timeoutActions.get(s).find(n=>n.name===o);r?r.action=t.action:this.timeoutActions.get(s).push(t)}removeTimeoutAction(t){for(const[s,o]of this.timeoutActions.entries()){const r=o.filter(n=>n.name!==t);r.length===0?this.timeoutActions.delete(s):this.timeoutActions.set(s,r)}}updateTimer(){if(this.remainingTime=Math.round((this.remainingTime-this.decrementValue)*100)/100,this.remainingTime<=0){this.state==="active"&&this.executeActions(0),this.pause();return}this.state==="active"&&this.executeActions(this.remainingTime)}executeActions(t){this.timeoutActions.has(t)&&this.timeoutActions.get(t).forEach(s=>{var o;ft.debug(`Executing timer action ${s.name} at ${t}`),(o=s.action)==null||o.call(s,s.name,t),this.notifyTimeoutAction(s),s.singleUse&&(ft.info(`${this.name} Removing single-use action ${s.name}`),this.removeTimeoutAction(s.name))})}notifyTimeoutAction(t){F(br,{name:this.name,action:t.name,remainingTime:this.remainingTime})}}const mt=new Map,xe=(e,t)=>{const s=mt.get(e);if(!s){ft.error(`Timer ${e} not found`);return}t(s)},Ac={createRelativeTimer(e,t,s){const o=new Date,r=Math.round((t.getTime()-o.getTime())/1e3);return this.createTimer(e,r,s)},createTimer(e,t=60,s){if(mt.has(e))return mt.get(e);const o=new Sc(e,t,s);return mt.set(e,o),o},getTimer(e){return mt.get(e)},clearTimer(e){xe(e,t=>t.pause())},restartTimer(e){xe(e,t=>t.restart())},resetTimer(e){xe(e,t=>t.reset())},addTimeoutAction(e,t){xe(e,s=>s.addTimeoutAction(t))},removeTimeoutAction(e,t){xe(e,s=>s.removeTimeoutAction(t))},startTimer(e){xe(e,t=>t.start())}},Cc="kos:service:region:settings",Rc="timeZone",dm=`${Cc}-${Rc}`,Io=async e=>{const t=Ae.factory(dm)({path:Cc,attribute:Rc});await J(t),t.updateProperty(e)},um=e=>!e||!e.data;function vr(e={}){const{alias:t,namespace:s}=e;return(o,r,n)=>{o[bt]=o[bt]||{};const i=n.value,c=async function(...l){const d=Ze();f.debug(`Calling future service ${r} with tracker ${d}`);const u=De.initiateFuture({tracker:d,id:zo});s&&(u.namespace=s),f.debug(`waiting for future ${u.id} to be ready`),await J(u),f.debug(`future ${u.id} is ready`),Y(()=>{f.debug(`Adding future ${u.id} to futureHandler`),this.futureHandler.addFuture(u,t)});try{const g=await i.apply(this,[...l,d]);f.debug(`received future response for ${d}`,g);const y=um(g)?g:g==null?void 0:g.data;return y?(y.progress=1,f.debug("mapping future response to future model"),u.endState?f.debug(`future ${u.id} has already completed. Not updating the model`):tr(y,u)):this.futureHandler.removeFuture(t),y}catch(g){throw f.error(g),g}};o[bt][r]={handler:c}}}const hm=({path:e})=>(t,s)=>{t[k]=t[k]||{},t[k][s]={modelType:Pt.type,id:`${Pt.type}-${e}`,options:{path:e},lifecycle:x.INIT}};function gm(e){const{path:t,attribute:s}=e;return(o,r)=>{o[k]=o[k]||{},o[k][r]={modelType:cr.type,id:`${t}-${s}`,options:{path:t,attribute:s},lifecycle:x.INIT}}}const Ue=f.createLogger({name:"services",group:"Services"}),fm=async(e,t)=>Lc(e,t,`${exports.BASE_URL}/api/server/login`),Lc=async(e,t,s=`${exports.BASE_URL}/api/login`)=>{const o=await exports.kosFetch(`${s}`,{method:"POST",destinationAddress:"",body:JSON.stringify({email:e,password:t})});if(!o.ok){const n=await o.json();throw Error(`${n==null?void 0:n.error}`)}return await o.json()},mm=async e=>kc(e,`${exports.BASE_URL}/api/server/startPasswordReset`,""),kc=async(e,t=`${exports.BASE_URL}/api/startPasswordReset`,s="server")=>{const o=await exports.kosFetch(`${t}?email=${e}`,{method:"POST",destinationAddress:s});if(!o.ok)throw Error(`There was a problem reseting config; returned status ${o.status}`);return await o.json()},pm=async(e,t)=>Pc(e,t,`${exports.BASE_URL}/api/server/resetPassword`),Pc=async(e,t,s=`${exports.BASE_URL}/api/resetPassword`)=>{Ue.debug(`resetting password with token ${e} and password ${t.replace(/./g,"*")}`);const o=await exports.kosFetch(`${s}`,{method:"POST",destinationAddress:"",body:JSON.stringify({token:e,password:t})});if(Ue.debug(`password reset returned status ${o.status}`),!o.ok){Ue.error(`password reset failed with message ${o.statusText}`);const n=await o.json();throw Error(`${n==null?void 0:n.error}:There was a problem resetting the password.`)}return await o.json()},ym=async(e,t,s)=>xc(e,t,s,`${exports.BASE_URL}/api/server/acceptInvite`),xc=async(e,t,s,o=`${exports.BASE_URL}/api/server/acceptInvite`)=>{Ue.debug(`accepting invite with token ${e} and password ${t.replace(/./g,"*")}`);const r=await exports.kosFetch(`${o}`,{method:"POST",destinationAddress:"",body:JSON.stringify({token:e,password:t,name:s})});if(Ue.debug(`invitation accept returned status ${r.status}`),!r.ok){Ue.error(`invite failed with message ${r.statusText}`);const i=await r.json();throw Error(`${i==null?void 0:i.error}:There was a problem accepting the invite.`)}return await r.json()},bm=Ie.keyframes`
|
|
77
|
+
["${t}"]`;if(o?(w=this.fosSocket)==null?void 0:w.connectionEstablished:(b=this.socket)==null?void 0:b.connectionEstablished){const I=o?this.fosSocket:this.socket;(_=I==null?void 0:I.socket)==null||_.send(u)}else{Ee.debug("no connection adding to offline messages");const I=o?this.fosSocket:this.socket;I==null||I.addOfflineMessage(u)}}subscribeTopic({topic:t,callback:s,fos:o,bridge:r,destinationAddress:n}){const{unsubscribe:i,count:c}=j(t,s);return Ee.debug(`Topic ${t} currently has ${c} subscribers`),this._sendSubscriptionMessage(t,"subscribe",o,r,n),()=>{const{count:d}=i();Ee.debug(`Topic ${t} currently has ${d} subscribers`),d===0&&this._sendSubscriptionMessage(t,"unsubscribe",o,r,n)}}async whenReady(){const t=this;return this.webSocketSupported?(await v.when(()=>{var s,o;return!!((s=t.socket)!=null&&s.connectionEstablished)&&(!t.useFosTransport||!!((o=t.fosSocket)!=null&&o.connectionEstablished))&&t.authorized}),{status:"success"}):{status:"not supported"}}get token(){return this._token}set token(t){this._token=t,this.init()}static host(t="localhost"){return this.getInstance().host=t,this}static port(t=8080){return this.getInstance().port=t,this}static alias(t){this.getInstance().alias=t}static getInstance(t=8080,s){if(!this._instance){const o=window.kosUseFos?{port:window.kosFosPort||8081}:void 0;this._instance=new this({port:t,token:s,fos:o})}return this._instance}}a(Ht,"_instance");class yu{constructor(t,s,o,r,n){a(this,"disposers",[]);a(this,"activatableDisposers",[]);this.model=t,this.modelData=s,this.modelId=o,this.offlineQueue=r,this.log=n}registerAll(t){var r;const s=((r=this.modelData)==null?void 0:r[G])||{},o=Object.keys(s);this.log.debug(`Found ${o.length} subscriptions in ${this.modelId} (lifecycle: ${t??"any"})`),o.forEach(n=>{const i=s[n],c=i.lifecycle;if(t&&t!==c)return;const d=this.resolvePropKey(n);this.log.debug(`Resolved topic: ${n} → ${d}`);const l=this.createHandler(d,i);this.subscribe(i,d,l,c===x.ACTIVATE)})}deactivate(){this.log.debug(`Deactivating subscriptions for ${this.modelId}`);for(const t of this.activatableDisposers)try{t()}catch(s){this.log.error("Error during subscription disposal",s)}this.activatableDisposers=[]}disposeAll(){const t=[...this.disposers,...this.activatableDisposers];this.log.debug(`Disposing ${t.length} subscriptions for ${this.modelId}`);for(const s of t)try{s()}catch(o){this.log.error("Error during subscription disposal",o)}this.disposers=[],this.activatableDisposers=[]}subscribe(t,s,o,r){const n=t.destinationAddress?this.resolvePropKey(t.destinationAddress):null;if(t.websocket){this.log.debug(`Subscribing to WebSocket topic: ${s}`);const i=Ht.getInstance().subscribeTopic({topic:s,callback:o,fos:t.fos,bridge:t.bridge,destinationAddress:n});this.disposers.push(i)}else{this.log.debug(`Subscribing to EventBus topic: ${s}`);const{unsubscribe:i}=j(s,o);r?this.activatableDisposers.push(i):this.disposers.push(i)}}createHandler(t,s){return async o=>{var r;try{const n=(r=o==null?void 0:o.headers)==null?void 0:r["src-addr"],i=s.destinationAddress&&this.resolvePropKey(s.destinationAddress),c=i?n===i:!0;if(this.model.isReady()){const d=bo(o,s.skipParse),l=s.transform(d);if(c&&s.condition(l,this.modelData,o))return s.handler.call(this.modelData,l,o,this.modelData)}else{this.log.warn(`Model ${this.modelId} not ready. Queuing message for ${t}`);const d=()=>{const l=bo(o,s.skipParse),u=s.transform(l);if(c&&s.condition(u,this.modelData,o))return s.handler.call(this.modelData,u,o,this.modelData)};this.offlineQueue.enqueue(d)}}catch(n){this.log.error(`Error handling subscription for ${t}`,n)}}}resolvePropKey(t){const s=/.*({PROP_(.+)})/;let o=t.includes("{MODEL_ID}")?t.replace("{MODEL_ID}",this.modelId):t;const r=o.match(s);return r&&r[2]in this.modelData&&(o=o.replace(r[1],this.modelData[r[2]])),o}}function nt(e,t){const s=`[Model:${t}]`;return{debug:(...o)=>e.debug(s,...o),info:(...o)=>e.info(s,...o),warn:(...o)=>e.warn(s,...o),error:(...o)=>e.error(s,...o)}}function bu(e){return!!(e!=null&&e[$e])&&Object.keys(e[$e]).length>0}function vu(e){return!!(e!=null&&e[G])&&Object.keys(e[G]).length>0}class wu{static createAll(t){const{modelId:s,modelTypeName:o,modelData:r}=t,n=ou.create({modelId:s,modelTypeName:o}),i=new su(t,nt(n,"fsm")),c=new ru(nt(n,"offline-queue")),d=new ql(t),l=new zl(t),u={fsm:i,offlineQueue:c,companionManager:d,childResolver:l};if(bu(r)&&(u.effectManager=new Wl(o,s,r,nt(n,"effect"))),vu(r)){const h=nt(n,"subscription");u.subscriptionManager=new yu(t,r,s,c,h),u.onlineLifecycleManager=new nu(t,nt(n,"online"))}return u}}const S=T.getLogger("kos-model"),Mu="kos.extension.model.loader";class Ri{constructor({modelTypeName:t,id:s,modelData:o}){a(this,"_id");a(this,"_status");a(this,"_activeStatus");a(this,"_onlineStatus");a(this,"modelData");a(this,"modelTypeName");a(this,"initialized");a(this,"loaded");a(this,"offlineQueue");a(this,"subscriptionManager");a(this,"effectManager");a(this,"onlineLifecycleManager");a(this,"companionManager");a(this,"childResolver");a(this,"fsm");this._id=typeof s<"u"?`${s}`:t,this.modelTypeName=t,this.initialized=!1,this.loaded=!1,this.modelData=o,this._status=y.CREATED,this._activeStatus=y.INACTIVE,this._onlineStatus=y.OFFLINE;const r=wu.createAll(this);this.fsm=r.fsm,this.offlineQueue=r.offlineQueue,this.companionManager=r.companionManager,this.childResolver=r.childResolver,r.effectManager&&(this.effectManager=r.effectManager),r.subscriptionManager&&(this.subscriptionManager=r.subscriptionManager),r.onlineLifecycleManager&&(this.onlineLifecycleManager=r.onlineLifecycleManager),v.makeAutoObservable(this,{fsm:!1,effectManager:!1,subscriptionManager:!1,onlineLifecycleManager:!1,companionManager:!1,childResolver:!1,offlineQueue:!1}),Vl(this)}get companionModels(){return this.companionManager}set status(t){this._status=t}get status(){return this._status}get modelId(){return this._id}get id(){return this._id}get activeStatus(){return this._activeStatus}set activeStatus(t){this._activeStatus=t}get onlineStatus(){return this._onlineStatus}set onlineStatus(t){this._onlineStatus=t}get modelManager(){return globalThis.kos.modelManager}isActive(){return this._status===y.ACTIVE}isOnline(){return this._onlineStatus===y.ONLINE}isReady(){return this._status===y.READY}async deactivate(){var t,s,o;S.debug(`deactivating model ${this.modelTypeName} with id ${this.modelId}`);try{const r=k.getContext(this.modelId);await((s=(t=this.modelData)==null?void 0:t.deactivate)==null?void 0:s.call(t,r)),S.debug(`Model ${this.modelTypeName} with id ${this.modelId} deactivated`),(o=this.subscriptionManager)==null||o.deactivate()}catch(r){throw S.debug(`Model ${this.modelId} failed to deactivated`),r}}async activate(){var t,s,o;S.debug(`activating model ${this.modelTypeName} with id ${this.modelId}`),await ct(this,x.ACTIVATE);try{const r=k.getContext(this.modelId);await((s=(t=this.modelData)==null?void 0:t.activate)==null?void 0:s.call(t,r)),S.debug(`Model ${this.modelTypeName} with id ${this.modelId} subscribing to all topics`),(o=this.subscriptionManager)==null||o.registerAll(x.ACTIVATE),S.debug(`Model ${this.modelTypeName} with id ${this.modelId} activated`)}catch(r){throw S.debug(`Model ${this.modelId} failed to activate`),r}}async whenInitialized(){await Hr([{condition:()=>this.status===y.FAILED,onMatch:()=>{throw new Error(`Failed to initialize model ${this.modelId}`)}},{condition:()=>this.initialized,onMatch:()=>{S.debug(`Model ${this.modelId} is initialized`)}}])}async whenReady(){await Hr([{condition:()=>this.status===y.FAILED,onMatch:()=>{throw new Error(`Failed to ready model ${this.modelId}`)}},{condition:()=>this.status===y.READY,onMatch:()=>{S.debug(`Model ${this.modelId} is ready`)}}])}async ready(){var t,s,o;if(this.fsm.current===y.READY){S.debug(`already readying model ${this.modelTypeName} with id ${this.modelId} returning`);return}try{S.debug(`readying model ${this.modelTypeName} with id ${this.modelId}`),await ct(this,x.READY),await yi(this,zo.READY,x.READY);const r=k.getContext(this.modelId);await((s=(t=this.modelData)==null?void 0:t.ready)==null?void 0:s.call(t,r)),this.offlineQueue.flush(),(o=this.subscriptionManager)==null||o.registerAll(x.READY),S.debug(`Model ${this.modelId} is ready`);const n={modelId:this.modelId,modelType:this.modelTypeName};N(ri(this.modelTypeName,this.modelId),n),N(ni(this.modelTypeName),n)}catch(r){throw S.error(r),Error(r)}}async load(){var o,r,n,i;const{modelTypeName:t,modelId:s}=this;if(this.fsm.current===y.LOADED||this.fsm.current===y.LOADING){S.debug(`Model ${t} with id ${s} already loaded or loading`);return}S.debug(`Loading model ${t} with id ${s}`),await ct(this,x.LOAD);try{const c=k.getContext(s),d=`${Mu}.${t}`,l=await C.loader.executeLoader(d,{});l&&(S.info(`Setting loaded context for ${s}, type: ${t}`),c==null||c.set(d,l)),await((r=(o=this.modelData)==null?void 0:o.load)==null?void 0:r.call(o,c)),this.loaded=!0,S.debug(`Model ${t} with id ${s} successfully loaded`),(n=this.subscriptionManager)==null||n.registerAll(x.LOAD),(i=this.effectManager)==null||i.setup()}catch(c){throw S.error(`Model ${s} failed to load`,c),c}}async unload(){var t,s,o,r,n;S.debug(`unloading model ${this.modelTypeName} with id ${this.modelId}`);try{const i=this.getChildren().map(d=>{var l;return(l=d.unload)==null?void 0:l.call(d)}).filter(d=>!!d);await Promise.allSettled(i);const c=k.getContext(this.modelId);await((s=(t=this.modelData)==null?void 0:t.unload)==null?void 0:s.call(t,c)),this.loaded=!1,(o=this.onlineLifecycleManager)==null||o.dispose(),S.debug(`Model ${this.modelTypeName} with id ${this.modelId} unloaded`),(r=this.effectManager)==null||r.disposeAll(),(n=this.subscriptionManager)==null||n.disposeAll()}catch(i){throw S.debug(`Model ${this.modelId} failed to unload`),i}}async init(){var r,n,i;const{modelId:t,modelTypeName:s}=this,o=k.getContext(t);S.debug(`Initializing model ${s} with id ${t}`),await ct(this,x.INIT);try{await((n=(r=this.modelData)==null?void 0:r.init)==null?void 0:n.call(r,o)),this.initialized=!0,S.debug(`Model ${s} with id ${t} initialized`),(i=this.onlineLifecycleManager)==null||i.register(),this.registerSubscribers(x.INIT)}catch(c){throw S.error(`Model ${t} failed to initialize`,c),c}}async registerSubscribers(t){var s;S.debug(`registering subscribers in ${this.modelTypeName} with id ${this.modelId}`),(s=this.subscriptionManager)==null||s.registerAll(t)}async online(){var s,o;S.debug(`online model ${this.modelTypeName} with id ${this.modelId}`),this.registerSubscribers();const t=k.getContext(this.modelId);await((o=(s=this.modelData)==null?void 0:s.online)==null?void 0:o.call(s,t))}async offline(){var s,o,r;S.debug(`offline model ${this.modelTypeName} with id ${this.modelId}`),(s=this.subscriptionManager)==null||s.disposeAll();const t=k.getContext(this.modelId);await((r=(o=this.modelData)==null?void 0:o.offline)==null?void 0:r.call(o,t))}accept(t){t.visit(this)}getChildren(){return this.childResolver.resolve()}addCompanionModel(t){this.companionManager.add(t)}clearCompanionModels(){this.companionManager.clear()}}const Li=e=>typeof e=="function",qr=f.createLogger({name:"kos-model-instantiator"});class _u{constructor(t,s){this.registry=t,this.cache=s}createModelInstance(t,s,o={}){const r=this.registry.models[t];if(!r)throw new Error(`No model registered for type ${t}`);const n=r.singleton?t:s;if(this.cache.restoreFromDeleteCache(n),!this.cache.hasModel(n)){qr.debug(`Creating model instance: ${t} [${n}]`);const c=r.create?r.create({modelTypeId:t,id:n,options:o}):new r.class(n,o),d=new Ri({modelTypeName:t,id:n,modelData:c});this.cache.addModel(d),this._createCompanionModels(d,o)}const i=this.cache.getModelById(n);if(!i)throw qr.error(`Model ${t} [${n}] not found in cache`),new Error(`Model ${t} [${n}] not found in cache`);return{model:i,data:i.modelData}}_createCompanionModels(t,s){var n;const o=t.modelTypeName,r=((n=this.registry.companionModels)==null?void 0:n[o])||[];for(const{type:i}of r){const c=Li(i)?i(t.modelData,s):i;if(!c)continue;const d=`${c}-${t.modelId}`,l=this.createModelInstance(c,d,{data:s,companionParent:t.modelData,kosParentId:t.modelId});l!=null&&l.model&&t.addCompanionModel(l.model)}}}let Eu=class{constructor(t){this._registry=t}get registry(){return this._registry}getModelTypeRegistry(t){const s=this.registry.models[t];if(!s)throw new Error(`No registration for model type ${t}`);return s}registerModel(t){const s=t.type;this.registry.models[s]||(this.registry.models={...this.registry.models,...t.registration})}registerCompanionModel(t,s){var o,r;(o=this.registry).companionModels??(o.companionModels={}),(r=this.registry.companionModels)[t]??(r[t]=[]),this.registry.companionModels[t].some(n=>n.type===s)||this.registry.companionModels[t].push({type:s})}getModelSubscriptions(t){var s;return((s=this.getModelTypeRegistry(t))==null?void 0:s.subscriptions)||{}}getDataModelBuilder(t){var o;const s=(o=this.getModelTypeRegistry(t))==null?void 0:o.builder;if(!s)throw new Error(`No builder found for model type ${t}`);return s}getModelFactory(t){return et(t)}};const Pi=10,Wr=f.createLogger({name:"kos-model-manager"});class ki{constructor(){a(this,"cache");a(this,"instantiator");a(this,"dependencies");a(this,"_registry");globalThis.kos=globalThis.kos||{},this.dependencies=new $l,globalThis.kos.modelManager=this,globalThis.kos.resolveKosModel=t=>{const s=this.getModelById(t);if(s)return s.modelData||{}},globalThis.kos.kosModelJson=t=>{var o,r;const s=this.getModelById(t);if(s)return((r=(o=s.modelData).toJSON)==null?void 0:r.call(o))||{}},globalThis.kos.kosModelDebug=t=>{var o;const s=this.getModelById(t);if(s)return((o=s.modelData)==null?void 0:o.debugState)||{}},globalThis.kos.kmd=globalThis.kos.kosModelDebug,globalThis.kos.kmj=globalThis.kos.kosModelJson}static create(t,s){const o=this.getInstance(s);return o._registry=new Eu(t),o.cache=new Ol(t.preloadModels),o.instantiator=new _u(t,o.cache),o}static getInstance(t){var s,o;return(!((s=globalThis.kos)!=null&&s.modelManager)||t)&&(Wr.debug("Creating new instance of KosModelManager"),new this),(o=globalThis.kos)==null?void 0:o.modelManager}get registry(){return this._registry.registry}get preloadedModels(){return this.cache.preload(t=>(Wr.debug(`preloading ${t}`),typeof t=="string"?this.createModelInstance(t).model:this.createModelInstance(t.modelType,t.modelId,t.options).model))}get models(){return this.cache.models}getModelById(t){return this.cache.getModelById(t)}addModel(t){return this.cache.addModel(t)}removeModel(t){this.cache.removeModel(t.modelId)}hasModel(t){return this.cache.hasModel(t)}getModelsByType(t,s){return Array.from(this.models).filter(o=>o.modelTypeName===t).filter(o=>s?s(o.modelData):!0).map(o=>o.modelData)}getModelSubscriptions(t){return this._registry.getModelSubscriptions(t)}getDataModelBuilder(t){return this._registry.getDataModelBuilder(t)}getModelFactory(t){return et(t)}addDependency(t,s){this.cache.restoreFromDeleteCache(s),this.dependencies.add(t,s)}removeDependency(t,s){this.dependencies.remove(t,s)}async reloadModel(t){if(t.id){const s=this.getModelById(t.id);s&&await s.fsm.transitionTo(D.RESET,y.RESETTING)}}async initiateDestroyModel(t){if(!t.id)throw new Error("Model ID is required");if(!this.dependencies.canDestroy(t.id))return;const s=this.getModelById(t.id);s&&(this.cache.markForDeletion(s),Zn.addToDeletionQueue(t.id,setTimeout(()=>this.destroyModel(s),Pi)))}async destroyModel(t){var s;t!=null&&t.modelId&&this.dependencies.canDestroy(t.modelId)&&(await((s=t.unload)==null?void 0:s.call(t)),this.removeModel(t))}createModelInstance(t,s,o={}){return this.instantiator.createModelInstance(t,s,o)}registerCompanionModel(t,s){this._registry.registerCompanionModel(t,s)}registerModel(t){this._registry.registerModel(t)}}const Iu=async({context:e,extension:t})=>{const s=await C.loader.executeLoader(t,{});return e==null||e.set(t,s),s},Tu=async({extension:e,contextData:t,data:s})=>await C.dataMapper.executeMapper(e,s,t),$u=async({extension:e,contextData:t,data:s})=>await C.propertyMapper.executeMapper(e,s,t),Ou=Object.freeze(Object.defineProperty({__proto__:null,executeDataMapperExtension:Tu,executeLoaderExtension:Iu,executePropertyMapperExtension:$u},Symbol.toStringTag,{value:"Module"})),Du="Extensions";class Su{constructor(){a(this,"extensions");this.extensions={}}register(t,s,o){this.extensions[t]={},this.extensions[t][s]={component:o}}get(t,s){if(!this.extensions[t])throw new Error(`Extension point ${t} not found`);return this.extensions[t][s]}get allExtensions(){return this.extensions}}var cs=(e=>(e.CREATING="creating",e.CREATED="created",e.INITIALIZING="initializing",e.INITIALIZED="initialized",e.LOADING="loading",e.LOADED="loaded",e.ONLINE="online",e.READYING="readying",e.READY="ready",e.OFFLINE="offline",e.UNLOADING="unloading",e.UNLOADED="unloaded",e.RELOADING="reloading",e))(cs||{}),Ne=(e=>(e.CREATE="create",e.INITIALIZE="init",e.READY="ready",e.GO_ONLINE="go_online",e.GO_OFFLINE="go_offline",e.UNLOAD="unload",e.RELOAD="reload",e))(Ne||{});const Au=e=>{const t=m.createMachine("offline",{online:m.state(m.transition("go_offline","offline",m.action(()=>{e.offline(),v.runInAction(()=>{e.isOnline=!1})}))),offline:m.state(m.transition("go_online","online",m.action(()=>{e.online(),v.runInAction(()=>{e.isOnline=!0})})))}),s=m.interpret(t,n=>T.debug(n.machine.current)),o=m.createMachine({creating:m.state(m.transition("create","created")),created:m.state(m.immediate("initializing")),initializing:m.invoke(()=>e.init(),m.transition("done","initialized")),initialized:m.state(m.immediate("loading")),loading:m.invoke(()=>e.load(),m.transition("done","loaded")),loaded:m.state(m.immediate("readying"),m.transition("unload","unloading")),readying:m.invoke(()=>e.ready(),m.transition("done","ready",m.action(()=>{v.runInAction(()=>{e.status="ready"})}))),reloading:m.invoke(()=>e.reload(),m.transition("done","loading")),ready:m.state(m.transition("reload","reloading"),m.transition("unload","unloaded",m.action(e.unload.bind(e))),m.transition("go_online","ready",m.action(()=>{s.send("go_online")})),m.transition("go_offline","ready",m.action(()=>{s.send("go_offline")}))),unloaded:m.state()});return{service:m.interpret(o,n=>T.debug(n.machine.current)),online:s}},J=async e=>{if(e.id){const t=E.getInstance().modelManager.getModelById(e.id);if(!t)throw new Error(`Model with ID ${e.id} not found`);await(t==null?void 0:t.whenReady())}else throw new Error("Data model must have a valid ID");return e},Oe=async e=>{await E.getInstance().whenReady(),await E.getInstance().modelManager.initiateDestroyModel(e)},Cu=async e=>{if(await E.getInstance().whenReady(),!e.id)throw new Error("Model ID is required");const t=E.getInstance().modelManager.getModelById(e.id);t&&await t.fsm.transitionTo(D.UNLOAD,y.UNLOADED)},xi=async e=>{await E.getInstance().whenReady(),await E.getInstance().modelManager.reloadModel(e),f.debug(`reload model initiated for model ${e.id}, model ready: ${fs(e)} - ${Date.now()} `),await J(e),f.debug(`reload model complete for model ${e.id}, model ready: ${fs(e)} - ${Date.now()} `)},Ru=async e=>{if(await E.getInstance().whenReady(),!e)throw new Error("Model ID is required");const t=E.getInstance().modelManager.getModelById(e);return t==null?void 0:t.modelTypeName},Fi=async e=>{if(await E.getInstance().whenReady(),!e)throw new Error("Model ID is required");const t=E.getInstance().modelManager.getModelById(e);return{model:t==null?void 0:t.modelData,type:t==null?void 0:t.modelTypeName}},Xe=e=>{if(!e)throw new Error("Model ID is required");const t=E.getInstance().modelManager.getModelById(e);return{model:t==null?void 0:t.modelData,type:t==null?void 0:t.modelTypeName}},Ni=(e,t)=>{if(!e)throw new Error("Model type is required");return E.getInstance().modelManager.getModelsByType(e).filter(r=>Object.keys(t).every(n=>r[n]===t[n]))},Lu=(e,t)=>Ni(e,t)[0],Pu=(e,t)=>{if(!e.id)throw new Error("Model ID is required");const s=E.getInstance().modelManager.getModelById(e.id);if(!s)throw new Error("Model not found");const o=s.companionModels.get(t);return o==null?void 0:o.modelData},ku=e=>{if(!e.id)throw new Error("Model ID is required");const t=E.getInstance().modelManager.getModelById(e.id);if(!t)throw new Error("Model not found");return Array.from(t.companionModels.all()).map(o=>o.modelData)},xu=e=>{if(!e)throw new Error("Model ID is required");const t=E.getInstance().modelManager.getModelById(e);if(!t)throw new Error("Model not found");return t.companionModels.data},wo=(e,t)=>{const s=E.getInstance().modelManager.getModelById(e);if(!s){f.info(`Model not found for id ${e}`);return}return Array.from(s.companionModels.all()).find(r=>t(r.modelData))},te=e=>t=>Object.getPrototypeOf(t).modelTypeId===e,fs=e=>{const t=E.getInstance().modelManager.getModelById(e.id);if(!t)throw new Error("Model not found");return t.isReady()},Fu=f.createLogger({name:"kos-model-factory"}),$t={byModelType:e=>E.getInstance().modelManager.getModelFactory(e),getModelInstance:(e,t,s)=>{const o=$t.byModelType(t);if(!o)throw Fu.error(`No registered factory found for model type ${t}. Please register a factory for this model type. `),Error(`No factory found for model type ${t}`);return o.build(e,s)}},H={Factory:{create:e=>t=>(s,o)=>(o&&k.setParentContext(t,o),$t.getModelInstance(t,e,s))},Singleton:{create:e=>(t,s)=>(s&&k.setParentContext(e,s),$t.getModelInstance(e,e,t))},Model:{instance:e=>t=>$t.getModelInstance(t,e)}};window.KosRegistry=window.KosRegistry||{coreModels:new Map,preloadModels:[],companionModels:new Map,models:new Map};const Zr=window.KosRegistry.coreModels,ro=window.KosRegistry.preloadModels,no=window.KosRegistry.companionModels,Jt=window.KosRegistry.models,$={model:{registerLegacyModel:e=>(t,s)=>(Zr.set(t,s),{preload:$.model.preloadModel(e),model:$.model.register(e),companion:$.companion.register(e),legacy:$.model.registerLegacyModel(e),root:e}),preloadModel:e=>t=>(ro.includes(t)||ro.push(t),{preload:$.model.preloadModel(e),model:$.model.register(e),companion:$.companion.register(e),legacy:$.model.registerLegacyModel(e),root:e}),register:e=>(t,s)=>{const o=io(t)?t.registration():t;return Jt.set(o.type,o),io(t)&&t.relatedModels.forEach(r=>Jt.set(r.type,r.registration())),E.getInstance().isReady&&(E.getInstance().modelManager.registry.models[o.type]||(console.info(`Model with type ${o.type} doesn't exist. Adding new registration`),E.getInstance().modelManager.registry.models[o.type]=o.registration[o.type],io(t)&&t.relatedModels.forEach(r=>E.getInstance().modelManager.registry.models[r.type]=r.registration().registration))),s&&$.model.preloadModel(e)(o.type),{preload:$.model.preloadModel(e),model:$.model.register(e),companion:$.companion.register(e),legacy:$.model.registerLegacyModel(e),root:e}},get:e=>Jt.get(e),getAll:()=>Array.from(Jt.entries()),getPreloadModels:()=>ro,getLegacyModels:()=>Array.from(Zr.entries()).reduce((e,[t,s])=>(e[t]=s,e),{})},companion:{register:e=>(t,s)=>{const o=no.get(t)||[];return o.push(s),no.set(t,o),{preload:$.model.preloadModel(e),model:$.model.register(e),companion:$.companion.register(e),legacy:$.model.registerLegacyModel(e),root:e}},getAll:()=>Array.from(no.entries())}},Ui=$.model.registerLegacyModel,ji=$.model.register,Nu=$.companion.register,Uu=$.model.preloadModel,Bi=e=>typeof e.updateModel=="function",io=e=>e.registration!==void 0&&typeof e.registration=="function";class Ki{constructor(t){a(this,"singleton");a(this,"type");a(this,"loader");a(this,"class");a(this,"guard");a(this,"factory");a(this,"relatedModels",[]);this.singleton=t.singleton,this.guard=te(t.type),this.type=t.type,this.loader=`kos.extension.model.loader.${t.type}`,this.factory=t.factory,this.class=t.class}addRelatedModel(t){this.relatedModels.push(t)}registerRelatedModels(){this.relatedModels.forEach(t=>t.register())}register(){$.model.register({})(this.registration()),this.registerRelatedModels()}}class ae extends Ki{constructor(t){super({...t,singleton:!1,factory:H.Factory.create(t.type)})}instance(t){const s=this.factory(t);return{get:()=>{const o=Xe(t);if(!o)throw new Error("Model not found with id "+t);if(this.guard(o))return o;throw new Error("Model is not of type "+this.type)},forceUpdate:{options:o=>({build:()=>{const r=s(o);if(this.guard(r)){if(Bi(r))r.updateModel(o);else throw new Error(`Model ${this.type} is not updateable. Please implement UpdateAware interface`);return r}else throw new Error("Model is not of type "+this.type)}})},options:o=>({build:()=>{const r=s(o);if(this.guard(r))return r;throw new Error("Model is not of type "+this.type)}})}}registration(){return{type:this.type,predicate:this.guard,registration:{[this.type]:{class:this.class,singleton:!1}},factory:this.factory}}}class pe extends Ki{constructor(t){super({...t,singleton:!0,factory:H.Singleton.create(t.type)})}instance(){const t=this.factory;return{get:()=>{const o=Xe(this.type);if(!o)throw new Error("Model not found with id "+this.type);if(this.guard(o))return o;throw new Error(`Model is not of type ${this.type}. Received type ${Object.getPrototypeOf(o).modelTypeId}`)},forceUpdate:{options:o=>({build:()=>{const r=t(o);if(this.guard(r)){if(Bi(r))r.updateModel(o);else throw new Error(`Model ${this.type} is not updateable. Please implement UpdateAware interface`);return r}else throw new Error(`Model is not of type ${this.type}. Received type ${Object.getPrototypeOf(r).modelTypeId}`)}})},options:o=>({build:()=>{const r=t(o);if(this.guard(r))return r;throw new Error(`Model is not of type ${this.type}. Received type ${Object.getPrototypeOf(r).modelTypeId}`)}})}}registration(){return{type:this.type,predicate:this.guard,registration:{[this.type]:{class:this.class,singleton:!0}},factory:this.factory}}}const U=f.createLogger({name:"kos-core"}),ju=()=>{const e=ee(),t=e==null?void 0:e.alias,s=process.env.KOS_CONNECTION_ALIAS;return t||s||void 0},Bu=()=>{const e=window.location.protocol,t=ee(),s=t==null?void 0:t.host;let o;try{o=new URL(s).protocol==="https:"?"wss://":"ws://"}catch{}return o||(e==="https:"?"wss://":"ws://")},Ku=()=>{const e=window.location.hostname,t=process.env.KOS_HOST,s=ee(),o=s==null?void 0:s.host;let r;try{r=new URL(o).hostname}catch{}return r??t??e},Gu=()=>{const e=window.location.port,t=process.env.KOS_PORT,s=ee(),o=s==null?void 0:s.host;let r;try{r=new URL(o).port}catch{}return r??t??e},Hu=(e,t)=>{let s;return{promise:new Promise((n,i)=>{s=setTimeout(()=>{t?f.error(`Model ${t.modelId} - ${t.modelTypeName} preloading - timed out after ${e}ms`):f.error(`KOS Core preloading timed out after ${e}ms`),i(new Error(`Model ${t==null?void 0:t.modelId} - ${t==null?void 0:t.modelTypeName} - timed out after ${e}ms`))},e)}),cancel:()=>{s&&clearTimeout(s)}}},Jr=e=>typeof e.reload=="function",Vu=e=>typeof e.unload=="function";var Gi=(e=>(e.LOGGED_IN="logged_in",e.LOGGED_OUT="logged_out",e))(Gi||{});class E{constructor(t){a(this,"fsmService");a(this,"status");a(this,"initialized");a(this,"loaded");a(this,"_transport");a(this,"modelManager");a(this,"authState");a(this,"isOnline");a(this,"_reloading");a(this,"_unloading");a(this,"connectionAlias");this.initialized=!1,this.connectionAlias=t,this.loaded=!1,this.isOnline=!1,this.status=cs.CREATED,this.authState="logged_out",this._reloading=!1,this._unloading=!1,v.makeAutoObservable(this),j("token",c=>{c&&(this.transport.token=c.body)}),j(Tt.CONNECTED,async()=>{await this.whenReady(),this.fsmService.service.send(Ne.GO_ONLINE)}),j(Tt.DISCONNECTED,async()=>{this.fsmService.service.send(Ne.GO_OFFLINE)}),j("/studioServer/auth/LOGGED_IN",()=>{this.authState="logged_in",this.transport.authorized=!0}),j("/studioServer/auth/LOGIN_REQUIRED",()=>{this.authState="logged_out",this.transport.authorized=!1}),j(Tt.RELOAD,()=>{this.fsmService.service.send(Ne.RELOAD)}),j("/studio/project/reload",()=>{this.fsmService.service.send(Ne.RELOAD)});const s=Ht.getInstance(),o=Ku(),r=Gu(),n=Bu();s.host=o,s.port=Number.parseInt(r),s.protocol=n,process.env.KOS_ALLOW_ANONYMOUS==="true"&&(s.authorized=!0);const i=ju()??t;i&&(s.alias=i.replace("{{TIMESTAMP}}",Date.now().toString())),this._transport=s.init(),this.fsmService=Au(this),this.fsmService.service.send(Ne.CREATE)}get onlineStatus(){return this.isOnline&&!this._reloading&&!this._unloading}get reloading(){return this._reloading}get unloading(){return this._unloading}async reload(){var r,n,i,c;const t=Date.now();if(this._reloading){U.info("reload already in progress");return}this._reloading=!0,U.warn("reloading KOS Core"),U.warn("reloading preloaded models");const s=this.modelManager;for(const d of s.preloadedModels)Jr(d.modelData)&&(U.info(`reloading model ${d.modelId}`),(r=d.unload)==null||r.call(d),await d.modelData.reload(),(n=d.registerSubscribers)==null||n.call(d),U.info(`reloading model ${d.modelId} complete`));for(const d of s.models)!s.preloadedModels.includes(d)&&Jr(d.modelData)&&((i=d.unload)==null||i.call(d),await d.modelData.reload(),(c=d.registerSubscribers)==null||c.call(d));const o=Date.now()-t;setTimeout(()=>{v.runInAction(()=>{U.warn("reloading KOS Core complete"),this._reloading=!1})},1e3-o)}async online(){U.debug("KOS Core going online"),await this._transport.whenReady(),U.debug("KOS Transport Ready. Calling online() for models"),N("/kosCore/online","/kosCore/online"),console.timeEnd("kosCore:startup")}async offline(){U.debug("KOS Core going offline"),N("/kosCore/offline","/kosCore/offline")}async unload(){var r;U.debug("Unloading KOS Core");const t=Date.now();this._unloading=!0,U.debug("unloading KOS Core");const s=this.modelManager;for(const n of s.models)Vu(n.modelData)&&((r=n.unload)==null||r.call(n));const o=Date.now()-t;setTimeout(()=>{v.runInAction(()=>{this._unloading=!1})},1e3-o)}async whenReady(){await v.when(()=>this.status===cs.READY)}async ready(){U.debug("Readying KOS Core"),await this._transport.whenReady();const t=this.modelManager.preloadedModels.map(r=>({modelId:r.modelId,model:r,promise:r.whenReady()})),o=(await Promise.allSettled(t.map(r=>{const{promise:n,cancel:i}=Hu(5e3,r.model);Promise.race([r.promise.then(()=>{i()}),n])}))).filter(r=>r.status==="rejected");if(o.length)throw U.error(`There were ${o.length} failed models on model preloading`),Error(`There were ${o.length} failed models on model preloading`);U.debug("leaving kos-core ready() ")}get isReady(){return this.status===cs.READY}set transport(t){this._transport=t}get transport(){return this._transport}get coreInitialized(){return this.initialized}get modelsLoaded(){return this.loaded}async init(){U.debug("entering kos-core init()"),console.time("kosCore:startup"),console.time("kosCore:init"),await this._transport.whenReady(),this.initialized=!0,U.debug("initialized - leaving kos-core init()"),console.timeEnd("kosCore:init")}async load(){U.debug("entering kos-core load()"),console.time("kosCore:load"),this.loaded=!0,U.debug("loaded - leaving kos-core load()"),console.timeEnd("kosCore:load")}static create(t,s,o){var i,c,d;const r=this.getInstance({reset:s,connectionAlias:o});(i=t.extensions)!=null&&i.dataMapper&&Object.keys(t.extensions.dataMapper).forEach(l=>{var h,p;const u=(p=(h=t.extensions)==null?void 0:h.dataMapper)==null?void 0:p[l];u&&(Array.isArray(u)?u.forEach(w=>{C.dataMapper.registerDataMapper(l,w)}):C.dataMapper.registerDataMapper(l,u))}),(c=t.extensions)!=null&&c.propertyMapper&&Object.keys(t.extensions.propertyMapper).forEach(l=>{var h,p;const u=(p=(h=t.extensions)==null?void 0:h.propertyMapper)==null?void 0:p[l];u&&C.propertyMapper.registerPropertyMapper(l,u)}),(d=t.extensions)!=null&&d.contextLoader&&Object.keys(t.extensions.contextLoader).forEach(l=>{var h,p;const u=(p=(h=t.extensions)==null?void 0:h.contextLoader)==null?void 0:p[l];u&&C.loader.registerLoader(l,u)}),$.model.getAll().forEach(([,l])=>{t.models={...t.models,...l.registration}}),t.models={...t.models,...$.model.getLegacyModels()},$.companion.getAll().forEach(([l,u])=>{t.companionModels={...t.companionModels},t.companionModels[l]=t.companionModels[l]||[];for(const h of u)t.companionModels[l].push({type:h})}),$.model.getPreloadModels().forEach(l=>{t.preloadModels.includes(l)||t.preloadModels.push(l)});const n=ki.create(t,s);return r.modelManager=n,r}static getInstance(t){return this._instance=window.KosCore,(!this._instance||t!=null&&t.reset)&&(window.KosCore=new this(t==null?void 0:t.connectionAlias),this._instance=window.KosCore),this._instance}}a(E,"_instance");const Qr=f.createLogger({name:"kos-fetch"}),Yu=process.env.KOS_WS_TIMEOUT?parseInt(process.env.KOS_WS_TIMEOUT):3e4,zu=()=>new Promise(e=>{setTimeout(()=>{e(!0)},0)}),qu=e=>e!=null&&e.studio?wi:e!=null&&e.fos?Mi:_i,Wu=async(e,t)=>{const s=E.getInstance().transport;await s.whenReady();const o=Qe(),r=new URL(e),n=`${r.pathname}${r.search}`;Qr.debug(`path: ${n}`);const i=(t==null?void 0:t.timeout)||Yu,c=qu(t),d=ve(c({path:n,requestId:o,method:(t==null?void 0:t.method)||"GET",destinationAddress:(t==null?void 0:t.destinationAddress)||"",ordered:t==null?void 0:t.ordered,tracker:t==null?void 0:t.tracker,bridge:t==null?void 0:t.bridge}),t==null?void 0:t.body);return new Promise(l=>{const u=new AbortController,h=setTimeout(()=>{Qr.error(`Timeout occurred - url: ${e}`),u.abort(),l({headers:mo({}),status:404,ok:!1,json:async()=>null,body:yo(""),redirected:!1,statusText:"",type:"basic",url:"",clone:function(){throw new Error("Function not implemented.")},bodyUsed:!1,arrayBuffer:function(){throw new Error("Function not implemented.")},blob:function(){throw new Error("Function not implemented.")},formData:function(){throw new Error("Function not implemented.")},text:function(){throw new Error("Function not implemented.")}})},i),{unsubscribe:p}=j(o,b=>{var I,A,se;clearTimeout(h);const _={headers:mo((b==null?void 0:b.headers)||{}),status:((I=b==null?void 0:b.headers)==null?void 0:I.status)&&parseInt((A=b==null?void 0:b.headers)==null?void 0:A.status)||200,ok:((se=b==null?void 0:b.headers)==null?void 0:se.status)==="200",json:async()=>{var we;try{return(we=b==null?void 0:b.body)!=null&&we.length?JSON.parse(b.body):null}catch{throw Error("Not a JSON response")}},text:async()=>(b==null?void 0:b.body)||"",body:yo((b==null?void 0:b.body)||""),redirected:!1,statusText:"",type:"basic",url:"",clone:function(){throw new Error("Function not implemented.")},bodyUsed:!1,arrayBuffer:function(){throw new Error("Function not implemented.")},blob:function(){throw new Error("Function not implemented.")},formData:function(){throw new Error("Function not implemented.")}};p(),zu().then(()=>l(_))}),w=t!=null&&t.fos?s.fosSocket:s.socket;if(!w)throw Error(`No web socket transport available: ${t}`);w==null||w.send(d)})};exports.BASE_URL="kos:";exports.kosFetch=Wu;if(process.env.KOS_MOCK_FETCH==="true"){const e=process.env.KOS_PORT||"9999";exports.kosFetch=fetch,exports.BASE_URL=`http://localhost:${e}`}const Zu=f.createLogger({name:"kos-model-visitor",group:"kos-ui-core"});class Ju{constructor(){a(this,"visitedModels",new Set);this.visitedModels=new Set}start(t){var o;if(t.id===void 0)throw new Error("rootModel must have an id");const s=E.getInstance().modelManager.getModelById(t.id);if(!s)throw new Error(`Could not find rootModel with id: ${t.id}`);this.visitedModels.clear(),(o=s.accept)==null||o.call(s,this)}visit(t){var o;if(this.visitedModels.has(t.modelId)){Zu.info(`model ${t.modelId} already visited`);return}const s=!!this.visitModel(t.modelData,this);this.visitedModels.add(t.modelId),!s&&((o=t.getChildren)==null||o.call(t).forEach(r=>{var n;(n=r.accept)==null||n.call(r,this)}))}}const Hi=()=>({isMock:!1,URL:exports.BASE_URL}),Qu=f.createLogger({name:"kos-service-request"}),Xu="errUnknown";async function Qt(e,t,s,o,r){const n=o!=null&&o.path?Object.keys(o.path).reduce((h,p)=>String(h).replace(`{${p}}`,o==null?void 0:o.path[p]),String(e)):String(e),i=o!=null&&o.query?Object.keys(o.query).map(h=>`${h}=${o.query[h]}`).join("&"):"",c=`${Hi().URL}${n}${i?`?${encodeURIComponent(i)}`:""}`;Qu.debug(`fullUrl: ${c}`);const d={method:String(t).toUpperCase(),body:null,...s};r&&(d.body=JSON.stringify(r));const l=await exports.kosFetch(c,d);return l.status<200||l.status>=400?[`${l.statusText||Xu}`,null]:[null,(await l.json()).data]}function Zo(){return{get:(e,t,s)=>Qt(e,"get",s,t),post:(e,t,s,o)=>Qt(e,"post",o,t,s),put:(e,t,s,o)=>Qt(e,"put",o,t,s),delete:(e,t,s)=>Qt(e,"delete",s,t)}}class Vi{constructor(){a(this,"middlewares",[])}use(t){this.middlewares.push(t)}async execute(t){let s=0;const o=async()=>{s++,s<this.middlewares.length&&await this.middlewares[s](t,o)};await this.middlewares[s](t,o)}}const eh=async(e,t)=>{const s=new Vi;t.forEach(r=>s.use(r));const o={data:e,result:{}};return await s.execute(o),o.result},et=e=>({type:e,build:(t,s)=>E.getInstance().modelManager.createModelInstance(e,t,s).data,buildAsync:async(t,s)=>{const o=E.getInstance().modelManager.createModelInstance(e,t,s);return await o.model.whenInitialized(),o.data}}),th=e=>{E.getInstance().modelManager.registerModel(e)},sh=(e,t)=>{E.getInstance().modelManager.registerCompanionModel(e,t)},Yi=Symbol("KosObservableData");class zi{constructor(){a(this,"map");a(this,"atomMap",new Map);a(this,"proxyHandler",{get:(t,s)=>{var o;return t[s]!==void 0?t[s]:this.atomMap.has(s)&&(o=this.atomMap.get(s))!=null&&o.reportObserved()?this.getValue(s):this.getValue(s)},set:(t,s,o)=>{var r;return this.setValue(s,o),this.atomMap.has(s)||this.atomMap.set(s,v.createAtom(s.toString())),(r=this.atomMap.get(s))==null||r.reportChanged(),!0},ownKeys:()=>Array.from(this.map.keys())});this.map=v.observable.map(new Map)}setValue(t,s){this.map.set(t,s)}getValue(t){return this.map.get(t)}has(t){return this.map.has(t)}get entries(){return Array.from(this.map.entries())}get keys(){return Array.from(this.map.keys())}get values(){return Array.from(this.map.values())}setValues(t){t&&Object.keys(t).forEach(s=>{this.setValue(s,t[s])})}get proxy(){return new Proxy(this,this.proxyHandler)}}zi.prototype[Yi]=!0;function oh(e,t){return new Proxy(e,{construct:(s,o)=>{const r=new e(...o);return r.setValues(t),r.proxy}})}const ye=e=>{const t=oh(zi,e);return new t(e)},Xr="/kos/ui/internal/heartbeat/",rh=({relationshipId:e,destinationAddress:t,onAbort:s,waitTime:o,beatTime:r})=>{const n=E.getInstance().transport,i=new AbortController;let c=performance.now();const d=n.subscribeTopic({topic:`${Xr}${e}`,callback:()=>{c=performance.now()}}),l=o??3e3,u=window.setInterval(()=>{let _=performance.now()-c;_=_/1e3,_>l/1e3&&i.abort()},l),h=r??2e3,p=window.setInterval(()=>{Si({msg:{},options:{topic:`${Xr}${e}`,destinationAddress:t}})},h),w=()=>{window.clearInterval(p),window.clearInterval(u),d()},b=()=>{w(),s&&s(),i.signal.removeEventListener("abort",b)};return i.signal.addEventListener("abort",b),{cleanUpHeartbeat:w}},qi=(...e)=>t=>e.reduce((s,o)=>o(s),t),nh={maxAttempts:5,baseDelayMs:100,backoffFactor:1.5};async function ih(e,t){let s=1;const o={...nh,...t},{maxAttempts:r,baseDelayMs:n,backoffFactor:i}=o;let c=n;for(;s<=r;)try{return await e()}catch(d){if(f.error(`Attempt ${s} failed: ${d}`),s<r)c=n*Math.pow(i,s),await new Promise(l=>setTimeout(l,c)),s++;else throw d}throw new Error("All attempts failed")}const ah=f.createLogger({name:"kos-service-request"}),q=e=>({isMock:!1,URL:exports.BASE_URL}),ch=(e,t,s)=>async({id:o,tracker:r,urlOverride:n,ordered:i,studio:c,fos:d,bridge:l,destinationAddress:u})=>{const h={method:"DELETE"};e&&(h.destinationAddress=e),r&&(h.tracker=r),tt(h,{ordered:i,studio:c,fos:d,bridge:l,destinationAddress:u});const p=await s(n||`${t}/${o}`,h);if(!p.ok)throw Error(`There was a problem deleting the model; returned status ${p.status}`);return await p.json()},tt=(e,{ordered:t,studio:s,fos:o,destinationAddress:r,bridge:n,timeout:i})=>(i&&(e.timeout=i),t&&(e.ordered=t),s&&(e.studio=s),o&&(e.fos=o),n&&(e.bridge=n),(r||r==="")&&(e.destinationAddress=r),e),dh=(e,t,s)=>async({urlOverride:o,ordered:r,studio:n,fos:i,bridge:c,timeout:d,destinationAddress:l})=>{const u={method:"GET"};e&&(u.destinationAddress=e),tt(u,{timeout:d,ordered:r,studio:n,fos:i,bridge:c,destinationAddress:l});const p=await s(o||t,u);if(!p.ok){let b;try{b=await p.json()}catch{}throw new ce(`There was a problem retrieving the model; returned status ${p.status}`,b)}return await p.json()},lh=(e,t,s)=>async({urlOverride:o,ordered:r,studio:n,fos:i,bridge:c,tracker:d,timeout:l,destinationAddress:u})=>{const h={method:"GET"};e&&(h.destinationAddress=e),d&&(h.tracker=d),tt(h,{timeout:l,ordered:r,studio:n,fos:i,bridge:c,destinationAddress:u});const p=o||t;ah.debug(`resolvedUrl: ${p}`);const w=await s(p,h);if(!w.ok){let _;try{_=await w.json()}catch{}throw new ce(`There was a problem retrieving the model; returned status ${w.status}`,_)}return await w.json()},uh=(e,t,s)=>async({urlOverride:o,id:r,ordered:n,studio:i,fos:c,bridge:d,timeout:l,destinationAddress:u})=>{const h={method:"GET"};e&&(h.destinationAddress=e),tt(h,{timeout:l,ordered:n,studio:i,fos:c,bridge:d,destinationAddress:u});const p=o||`${t}/${r}`,w=await s(p,h);if(!w.ok){let _;try{_=await w.json()}catch{}throw new ce(`There was a problem retrieving the model; returned status ${w.status}`,_)}return await w.json()};class ce extends Error{constructor(s,o){super(s);a(this,"payload");this.name="FetchException",this.payload=o}}const en=(e,t,s)=>async({model:o,urlOverride:r,ordered:n,tracker:i,studio:c,fos:d,bridge:l,timeout:u,destinationAddress:h})=>{const p={method:"POST",body:typeof o=="string"?o:JSON.stringify(o)};e&&(p.destinationAddress=e),i&&(p.tracker=i),tt(p,{timeout:u,ordered:n,studio:c,fos:d,bridge:l,destinationAddress:h});const w=await s(r||t,p);if(!w.ok){let _;try{_=await w.json()}catch{}throw new ce(`There was a problem sending the POST data; returned status ${w.status}`,_)}return await w.json()},tn=(e="POST",t,s,o)=>async({model:r,id:n,urlOverride:i,ordered:c,studio:d,fos:l,bridge:u,timeout:h,destinationAddress:p})=>{const w={method:e};r&&(w.body=JSON.stringify(r)),t&&(w.destinationAddress=t),tt(w,{timeout:h,ordered:c,studio:d,fos:l,bridge:u,destinationAddress:p});const b=await o(i||`${s}/${n}`,w);if(!b.ok){let I;try{I=await b.json()}catch{}throw new ce(`There was a problem modifying the model; returned status ${b.status}`,I)}return await b.json()},V={build:({destinationAddress:e="",basePath:t,getAllPath:s,getOnePath:o,deleteModelPath:r,addModelPath:n,modifyModelPath:i,mock:c=!1})=>{const d=c?fetch:exports.kosFetch;return{getAll:dh(e,s||t,d),getModelById:uh(e,o||t,d),getOne:lh(e,o||t,d),addModel:en(e,n||t,d),deleteModel:ch(e,r||t,d),modifyModel:tn("POST",e,i||t,d),putModel:tn("PUT",e,i||t,d),postModel:en(e,n||t,d)}}},hh=Qe(),Wi=()=>`kos-${hh}`,gh=e=>!!e&&!e.includes("VM_SERVICE")&&e.startsWith(Wi()),Jo=async(e,t=6e4)=>new Promise((s,o)=>{const{unsubscribe:r}=j(e,i=>{T.debug(`recieved response for refId ${e}: ${i}`),r(),clearTimeout(n);try{const c=i!=null&&i.body?JSON.parse(i.body):{};s(c)}catch{const c=(i==null?void 0:i.body)||{};s(c)}}),n=setTimeout(()=>{r(),o(Error(`Request with ID ${e} timed out. Cancelling.`))},t)}),fh=async(e,t,s)=>{const o=Jo(s),r=await Promise.allSettled([e(t),o]);if(r[0].status==="fulfilled"){if(r[1].status==="rejected")throw Error(r[1].reason);if(r[0].value){if(r[1].value.error)throw Error(r[1].value.error);return r[0].value.data=r[1].value,r[0].value}}else throw Error(r[0].reason)},ph=async({topic:e,msg:t,requestId:s})=>{const o=s??Qe(),r=Jo(o);N(e,t,{sync:o});const n=await r;if(n.error)throw Error(n.error);return n},ue=new Map;class Zi{constructor(t){a(this,"_context");a(this,"_parent");a(this,"_id");this._id=t,this._context=new v.ObservableMap({}),this._parent="",v.makeAutoObservable(this)}setParent(t){Y(()=>{this._parent=t})}get id(){return this._id}get context(){return this._context}get parentModel(){var t;if(this._parent)return(t=Xe(this._parent))==null?void 0:t.model}get(t){var s;if(this._context.has(t))return this._context.get(t);if(this._parent)return(s=ue.get(this._parent))==null?void 0:s.get(t)}set(t,s){this._context.set(t,s)}remove(t){this._context.delete(t)}clear(){this._context.clear()}}const k={createContext:(e,t)=>{const s=ue.get(e)??new Zi(e);if(t){if(!ue.has(t))throw new Error(`Parent context ${t} does not exist`);s.setParent(t)}else e!=="root"&&s.setParent("root");return ue.set(e,s),s},getContext:e=>ue.get(e),deleteContext:e=>{ue.delete(e)},setParentContext:(e,t)=>{var s;if(!ue.has(t))throw new Error(`Parent context ${t} does not exist`);(s=ue.get(e))==null||s.setParent(t)},rootContext:()=>ue.get("root")};k.createContext("root");const mh=e=>k.getContext(e.id);function yh(e,t){return e.length!==t.length?!1:e.every(s=>t.includes(s))}class Qo{constructor({container:t,key:s}){a(this,"_container");a(this,"_map");a(this,"_key");a(this,"data");this._container=t,this._map=v.observable.map(new Map),this._key=s,this.data=ye(),this.generateIndex(),v.autorun(()=>{this._container.revision&&this.generateIndex()}),v.makeAutoObservable(this)}refresh(){this.generateIndex()}addItemToIndex(t,s,o=this._map,r=this.data){const n=o.get(t)||new Set;n.add(s),o.set(t,n),r[t]=Array.from(n)}resolveIndex(t,s){this.data.keys.filter(r=>!Object.keys(s).includes(r)).forEach(r=>{delete this.data[r],this._map.delete(r)}),Object.keys(s).forEach(r=>{const n=s[r],i=this.data[r]||[];if(yh(n,i))f.debug(`KosContainerIndex - Index ${r} is the same`);else{this.data[r]=n;const c=t.get(r)||new Set;this._map.set(r,c)}})}generateIndex(){v.runInAction(async()=>{const t=new Map,s={};for(const o of this._container.data){const r=typeof this._key=="function"?await this._key(o):o[this._key];Array.isArray(r)?r.forEach(n=>{this.addItemToIndex(n,o,t,s)}):typeof r=="string"||typeof r=="number"?this.addItemToIndex(String(r),o,t,s):typeof r=="boolean"&&this.addItemToIndex(String(r),o,t,s)}this.resolveIndex(t,s)})}get keys(){return Array.from(this._map.keys())}get index(){return this._map}getByKey(t){const s=this._map.get(t);return s?Array.from(s):[]}}function bh(e,t,s=[]){const o=Object.getOwnPropertyDescriptors(e);return Object.keys(o).filter(i=>v.isComputedProp(e,i)).filter(i=>s.includes(i)).map(i=>v.reaction(()=>e[i],(c,d)=>{t({name:i,newValue:c,oldValue:d})}))}const it=f.createLogger({name:"kos-container-model"});class le{constructor(t){a(this,"_data");a(this,"_sortKey");a(this,"_revision");a(this,"_index");a(this,"_optionsMap");a(this,"_disposerMap",new Map);a(this,"_parentId");a(this,"idx");this._data=v.observable.map(new Map),this._sortKey=t==null?void 0:t.sortKey,this._revision=1;const s=t!=null&&t.extensionId?C.indexExtension.loadIndexExtensions(t.extensionId):{},o=(t==null?void 0:t.indexMap)||{};this._optionsMap={...o,...s};const r=t!=null&&t.indexMap?Object.keys(t.indexMap).reduce((n,i)=>(n[i]=void 0,n),{}):{};this._index=v.observable.map(r),this.idx=ye(),this._parentId=t==null?void 0:t.parentId,v.makeAutoObservable(this),this.init()}init(){Object.keys(this._optionsMap).forEach(t=>{const s=this._optionsMap[t],o=new Qo({container:this,key:s});this._index.set(t,o),this.idx[t]=o.data})}[Symbol.iterator](){return this.data[Symbol.iterator]()}get index(){return this._index}get revision(){return this._revision}get indexKeys(){return Array.from(this.index.keys()).reduce((t,s)=>{var o;return t[s]=(o=this.index.get(s))==null?void 0:o.keys,t},{})}sortFn(t,s){const o=this._sortKey;return o?String(t[o]).localeCompare(String(s[o]),void 0,{numeric:!0}):0}get data(){const t=Array.from(this._data.values());return this._sortKey&&t.sort(this.sortFn.bind(this)),t}increment(){v.runInAction(()=>{this._revision=this._revision+1})}addAll(t){v.runInAction(()=>{t.forEach(s=>this.addModel(s,!0))}),this.increment()}removeAll(t){v.runInAction(()=>{t.forEach(s=>this.removeModel(s,!0)),this.increment()})}addModel(t,s){this._data.set(t.id||"",t),t.id&&this._parentId&&k.setParentContext(t.id,this._parentId),s||this.increment();const o=this._disposerMap.get(t.id);o&&(o(),this._disposerMap.delete(t.id));const r=Object.entries(this._optionsMap||{}),n=Object.values(this._optionsMap||{}),i=new Map(r.map(([u,h])=>[h,u])),c=u=>{var p,w;n.includes(u.name)&&((p=this.index.get(i.get(u.name)))==null||p.refresh());const h=r.filter(([,b])=>typeof b=="function");for(const[b]of h)(w=this.index.get(b))==null||w.refresh()},d=bh(t,c,n.filter(u=>typeof u=="string")),l=v.observe(t,c);this._disposerMap.set(t.id||"",()=>[l,...d].forEach(u=>u()))}removeModel(t,s){this._data.delete(t),s||this.increment();const o=this._disposerMap.get(t);o&&(o(),this._disposerMap.delete(t))}updateModel(t){this._data.set(t.id||"",t),this.increment()}getModel(t){return this._data.get(t)}getIndexKeys(t){return this.index.has(t)?this.index.get(t).keys??[]:(it.info(`index ${t} not found in ${Array.from(this.index.keys())}`),[])}getIndexByKey(t,s){if(this.index.has(t)){const o=this.index.get(t);return o.index.has(s)?o.getByKey(s):(it.info(`key ${s} not found in ${t} index: ${Array.from(o.index.keys())}`),[])}else return it.info(`index ${t} not found in ${Array.from(this.index.keys())}`),[]}async clear(){this._data.forEach(t=>{const s=t.id;Oe(t).then(()=>{it.debug(`${s} destroyed, removing from map`),this.removeModel(s,!0)}).catch(o=>it.error(o))}),this.increment()}filter(t,s){return this.data.filter(t,s)}sort(t){return this.data.sort(t)}map(t,s){return this.data.map(t,s)}forEach(t,s){this.data.forEach(t,s)}toJSON(){return{indexes:this.indexKeys,data:this.data.map(s=>({id:s.id,type:s.constructor.name}))}}}const ao=f.createLogger({name:"kos-data-container"});class Ji{constructor(t){a(this,"_data");a(this,"_sortKey");a(this,"_revision");a(this,"_index");a(this,"_optionsMap");a(this,"_disposerMap",new Map);a(this,"idx");this._data=v.observable.map(new Map),this._sortKey=t==null?void 0:t.sortKey,this._revision=1,this._optionsMap=(t==null?void 0:t.indexMap)||{};const s=t!=null&&t.indexMap?Object.keys(t.indexMap).reduce((o,r)=>(o[r]=void 0,o),{}):{};this._index=v.observable.map(s),this.idx=ye(),v.makeAutoObservable(this,{}),this.init()}init(){Object.keys(this._optionsMap).forEach(t=>{const s=this._optionsMap[t],o=new Qo({container:this,key:s});this._index.set(t,o),this.idx[t]=o.data})}[Symbol.iterator](){return this.data[Symbol.iterator]()}get index(){return this._index}get indexKeys(){return Array.from(this.index.keys()).reduce((t,s)=>{var o;return t[s]=(o=this.index.get(s))==null?void 0:o.keys,t},{})}get revision(){return this._revision}addAll(t){v.runInAction(()=>{t.forEach(s=>this.addModel(s))})}removeAll(t){v.runInAction(()=>{t.forEach(s=>this.removeModel(s))})}sortFn(t,s){const o=this._sortKey;return o?String(t[o]).localeCompare(String(s[o]),void 0,{numeric:!0}):0}get data(){const t=Array.from(this._data.values());return this._sortKey&&t.sort(this.sortFn.bind(this)),t}increment(){v.runInAction(()=>{this._revision=this._revision+1})}addModel(t,s){const o=v.isObservable(t)?t:v.observable.object(t),r=this._disposerMap.get(t.id);r&&(r(),this._disposerMap.delete(t.id)),this._data.set(o.id||"",o),s||this.increment();const n=v.observe(o,i=>{Object.values(this._optionsMap||{}).includes(i.name)&&this.increment()});this._disposerMap.set(o.id||"",n)}removeModel(t){this._data.delete(t),this.increment();const s=this._disposerMap.get(t);s&&(s(),this._disposerMap.delete(t))}updateModel(t){const s=v.observable.object(t);this._data.set(s.id||"",s),this.increment()}getModel(t){return this._data.get(t)}getIndexKeys(t){return this.index.has(t)?this.index.get(t).keys??[]:(ao.info(`index ${t} not found in ${Array.from(this.index.keys())}`),[])}getIndexByKey(t,s){if(this.index.has(t)){const o=this.index.get(t);return o.index.has(s)?o.getByKey(s):(ao.info(`key ${s} not found in ${t} index: ${Array.from(o.index.keys())}`),[])}else return ao.info(`index ${t} not found in ${Array.from(this.index.keys())}`),[]}async clear(){this._data.clear(),this.increment()}filter(t,s){return this.data.filter(t,s)}sort(t){return this.data.sort(t)}map(t,s){return this.data.map(t,s)}forEach(t,s){this.data.forEach(t,s)}toJSON(){return{indexes:this.indexKeys,data:this.data.map(s=>({id:s.id}))}}}class vh{constructor({type:t,model:s,childRegistration:o}){a(this,"type");a(this,"childRegistration");a(this,"model");this.type=t,this.model=s,this.childRegistration=o}get factory(){return H.Factory.create(this.type)}get registration(){return{[this.type]:{class:this.model,singleton:!1,factory:this.factory},...this.childRegistration}}get predicate(){return te(this.type)}}class wh{constructor({type:t,model:s,childRegistration:o}){a(this,"type");a(this,"model");a(this,"childRegistration");this.type=t,this.model=s,this.childRegistration=o}get factory(){return H.Singleton.create(this.type)}get registration(){return{[this.type]:{class:this.model,singleton:!0,factory:this.factory},...this.childRegistration}}get predicate(){return te(this.type)}}class Qi{constructor(){a(this,"_token");v.makeAutoObservable(this),j("token",t=>{this.token=t==null?void 0:t.body})}get token(){return this._token}set token(t){this._token=t}}class Xi{constructor(){a(this,"routes",[]);a(this,"openApiRoutes",[])}use(t,s,...o){this.routes.push({method:t,path:s,middlewares:o});const r=this.extractOpenApiParams(s);this.openApiRoutes.push({method:t,path:s,parameters:r})}async handle(t,s){var c;const{path:o,query:r,params:n}=this.extractPathParams(t.path),i={...t,params:n,query:r};for(const d of this.routes){const l=this.matchRoute(d.path,o);if(d.method===t.method&&l){i.params=l;let u=0;const h=async()=>{if(u<d.middlewares.length){const p=d.middlewares[u++];await p(i,s,h)}};await h();return}}(c=s.status)==null||c.call(s,404).send({error:"Route not found"})}extractOpenApiParams(t){return t.split("/").filter(s=>s.startsWith(":")).map(s=>({name:s.slice(1),in:"path",required:!0,schema:{type:"string"}}))}generateOpenApiSpec(){const t={};for(const s of this.openApiRoutes)t[s.path]||(t[s.path]={}),t[s.path][s.method.toLowerCase()]={summary:s.description||`Handles ${s.method} ${s.path}`,parameters:s.parameters||[],responses:{200:{description:"Successful response"}}};return{openapi:"3.0.0",info:{title:"Kos Router API",version:"1.0.0",description:"Dynamically generated OpenAPI documentation"},paths:t}}extractPathParams(t){const[s,o]=t.split("?"),r=this.parseQueryParams(o);for(const n of this.routes){const i=this.matchRoute(n.path,s);if(i)return{path:s,query:r,params:i}}return{path:s,query:r,params:{}}}matchRoute(t,s){const o=t.split("/").filter(Boolean),r=s.split("/").filter(Boolean);if(o.length!==r.length)return null;const n={};for(let i=0;i<o.length;i++)if(o[i].startsWith(":"))n[o[i].slice(1)]=decodeURIComponent(r[i]);else if(o[i]!==r[i])return null;return n}parseQueryParams(t){return t?t.split("&").reduce((s,o)=>{const[r,n]=o.split("=").map(decodeURIComponent);return s[r]=n??"",s},{}):{}}}const ea=f.createLogger({name:"intent-service"}),Mh=e=>{jo(`/kos/intent/${e.type}`)?N(`/kos/intent/${e.type}`,e.options,{"kos.intent.type":e.type}):ea.info(`No subscribers for intent ${e.type}. Intent not sent.`)},_h=async e=>new Promise(t=>{const{type:s,options:o}=e;if(jo(`/kos/intent/${e.type}`)){const r=Qe(),{unsubscribe:n}=j(r,c=>{clearTimeout(i),n(),c&&(c.headers=c.headers||{},c.headers["kos.intent.type"]=s,c.headers.responseId=r),t([null,{body:c==null?void 0:c.body,payload:c}])}),i=setTimeout(()=>{n(),t([`Intent ${s} timed out after 1 second`,null]),console.warn(`Intent ${s} timed out after 1 second`)},1e3);N(`/kos/intent/${s}`,o,{"kos.intent.type":s,sync:r})}else ea.info(`No subscribers for intent ${e.type}. Intent not sent.`),t([null,{body:void 0,payload:void 0}])}),Mo=v.when,Xo=v.computed,Y=v.runInAction,F=v.autorun,ta=v.reaction,er=v.observable,tr="Not Assigned",Eh="kos.trouble.added",Ih="kos.trouble.removed";var re=(e=>(e.TroubleRank="kos.trouble.rank.mapper",e.TroubleColor="kos.trouble.color.mapper",e.TroubleRole="kos.trouble.role.mapper",e))(re||{}),Ot=(e=>(e.TIME_CHANGE="/kos/internal/time/time",e.DAY_CHANGE="/kos/internal/time/day",e.TIMEZONE_CHANGE="/kos/internal/time/timezone",e))(Ot||{});const sa=f.createLogger({name:"config-bean-service",group:"Services"}),sr=exports.BASE_URL,oa=e=>(e==null?void 0:e.decimals)!==void 0,{postModel:Th,getOne:$h}=V.build({destinationAddress:"",basePath:`${sr}/kos/config/`}),ra=async(e,t,s="/api/kos/config")=>(sa.debug(`sending modify request for ConfigBean: ${e}`),Th({model:t,urlOverride:`${sr}${s}/${e}`})),na=async(e,t="/api/kos/config")=>(sa.debug(`sending get request for ConfigBean: ${e}`),await $h({urlOverride:`${sr}${t}/details/${e}/15`})),or=e=>e.toLowerCase()==="true"||e.toLowerCase()==="false",Us=e=>{try{const t=Number(e);return!isNaN(t)}catch{return!1}};function ia(e=[]){return e.reverse().reduce((t,s)=>{const{overrides:o}=s;return o&&(t={...t,...o}),t},{})}function aa(e,t="",s={}){for(const o in e)if(Object.prototype.hasOwnProperty.call(e,o)){const r=t?`${t}.${o}`:o;typeof e[o]=="object"&&e[o]!==null&&!Array.isArray(e[o])?aa(e[o],r,s):s[r]=e[o]}return s}const ca=(e,t)=>{const s=e.details[0].bean||ia(e.details[0].scopes),o=aa(s);v.runInAction(()=>{const r={...o};t.props.setValues(r)})},da=(e,t)=>{v.runInAction(()=>{e.changes.forEach(s=>{const o=s.attr;let r=s.currentValue,n=s.previousValue;typeof r=="string"&&or(r)&&(r=r.toLowerCase()=="true",n=(n==null?void 0:n.toLowerCase())=="true"),typeof r=="string"&&Us(r)&&(r=Number(r),n=Number(n)),t.props[o]=r,t.prevProps[o]=n})})},la=e=>Object.fromEntries(e.props.entries),Oh=e=>t=>s=>e.build(t,s);var Dh=Object.defineProperty,Sh=Object.getOwnPropertyDescriptor,ua=(e,t,s,o)=>{for(var r=o>1?void 0:o?Sh(t,s):t,n=e.length-1,i;n>=0;n--)(i=e[n])&&(r=(o?i(t,s,r):i(r))||r);return o&&r&&Dh(t,s,r),r};function Ah(e,t){for(const s of e)if(new RegExp(`^${s}$`).test(t))return s}const rr="config-bean-model",Xt=f.getLogger(rr),Ch=Se("path");let ps=class{constructor(e,t){a(this,"_modifyConfigBean");a(this,"_getConfigBean");a(this,"_schema");a(this,"id");a(this,"path");a(this,"props");a(this,"prevProps");a(this,"serviceBasePath");Object.assign(this,t),this.id=e,this.path=t.path,this.serviceBasePath=t.serviceBasePath;const{modifyConfigBean:s=ra,getConfigBean:o=na}=t;this._modifyConfigBean=s,this._getConfigBean=o,this.props=ye(),this.prevProps=ye()}get values(){return this.props.values}async ready(){Xt.debug(`readying config bean ${this.path}`),Xt.debug(`complete readying config bean ${this.path}`)}async load(){Xt.debug(`loading config bean ${this.path}`);const e=await this._getConfigBean(this.path,this.serviceBasePath);if(e!=null&&e.data){const t=e.data;ca(t,this),Xt.debug(this.values);const s=e==null?void 0:e.data.details[0].schema;Y(()=>{s&&(this._schema=s)})}}get schemaKeys(){var e;return Object.keys(((e=this._schema)==null?void 0:e.schema)||{})}getSchemaForProperty(e){var s,o;if(this.schemaKeys.includes(e))return(s=this._schema)==null?void 0:s.schema[e];const t=Ah(this.schemaKeys,e);if(t)return(o=this._schema)==null?void 0:o.schema[t]}async updateProperty(e,t){this.props[e]=t,await this.updateConfigBean()}async updateConfigBean(){const e=la(this);await this._modifyConfigBean(this.path,e,this.serviceBasePath)}handleConfigBeanUpdated(e){da(e,this)}};ua([R({topic:`/kos/config/${Ch}`,websocket:!0})],ps.prototype,"handleConfigBeanUpdated",1);ps=ua([O(rr)],ps);const At=new ae({class:ps,type:rr}),js=({path:e,lazy:t,serviceBasePath:s})=>(o,r)=>{o[P]=o[P]||{},o[P][r]={modelType:At.type,id:`${At.type}-${e}`,options:{path:e,serviceBasePath:s},lifecycle:x.INIT,lazy:t}},{URL:ha}=q(),{getOne:Rh,getAll:Lh}=V.build({basePath:`${ha}/api/kos/regions/info`}),ga=async()=>await Rh({}),fa=async()=>await Lh({urlOverride:`${ha}/api/kos/regions`}),Ph=Object.freeze(Object.defineProperty({__proto__:null,getRegionInfo:ga,getRegions:fa},Symbol.toStringTag,{value:"Module"}));var Z=(e=>(e[e.family=0]="family",e[e.scale=1]="scale",e[e.offset=2]="offset",e[e.decimals=3]="decimals",e[e.alias=4]="alias",e[e.system=5]="system",e))(Z||{});const pa={s:["time",1,0,0],second:["time",1,0,0],m:["time",1/60,0,0],minute:["time",1/60,0,0],h:["time",1/3600,0,0],hour:["time",1/3600,0,0],day:["time",1/86400,0,0],week:["time",1/604800,0,0],month:["time",1/2628e3,0,0],year:["time",1/31536e3,0,0],default:["time",1/.001,0,0],ms:["time",1/.001,0,0],millisecond:["time",1/.001,0,0],microsecond:["time",1/1e-6,0,0],nanosecond:["time",1/1e-9,0,0],picosecond:["time",1/1e-12,0,0]};function kh(e,t){const s=t.id,o=t.units.reduce((r,n)=>{const i=[n.measure,n.scale,n.offset,n.decimals,n.alias,s];return r[n.name]=i,n.alias&&(r[n.alias]=i),r},{...pa});return{...e,...o}}function xh(e,t){const s=t.id,o=t.units.reduce((r,n)=>{const i=r[n.measure]||{},c=i[s]||{};i[s]=c;const d=[n.measure,n.scale,n.offset,n.decimals,n.alias,s];return c[n.name]=d,Object.hasOwn(n,"default")&&Object.defineProperty(c,"default",{value:d,writable:!0,enumerable:!0,configurable:!0}),r[n.measure]=i,n.alias&&(r[n.alias]=i),r},{time:{[s]:{...pa}}});return Object.keys(o).forEach(r=>{e[r]={...e[r],...o[r]}}),e}function Fh(e,t){const s=t.id,o=t.units.reduce((r,n)=>{const i=r[n.measure]||{};return Object.hasOwn(n,"default")&&(i[s]=n.name),r[n.measure]=i,r},{time:{[s]:"millisecond"}});return Object.keys(o).forEach(r=>{e[r]={...e[r],...o[r]}}),e}var Nh=Object.defineProperty,Uh=Object.getOwnPropertyDescriptor,nr=(e,t,s,o)=>{for(var r=o>1?void 0:o?Uh(t,s):t,n=e.length-1,i;n>=0;n--)(i=e[n])&&(r=(o?i(t,s,r):i(r))||r);return o&&r&&Nh(t,s,r),r};const ds="region-info-model",at=f.createLogger({name:"region-info-model"});let Ct=class{constructor(e){a(this,"id");a(this,"unitSystemMap");a(this,"measureMap");a(this,"defaultMeasureMap");a(this,"regionMap");a(this,"timeFormats");a(this,"dateFormats");a(this,"unitSystems");a(this,"regionSource");a(this,"region");a(this,"regions",[]);a(this,"timeZoneMap",{});this.id=e,this.unitSystems={},this.unitSystemMap={},this.measureMap={},this.defaultMeasureMap={},this.timeFormats={},this.regions=[],this.dateFormats={},this.timeZoneMap={},this.regionMap={}}get availableRegions(){return this.regions}get defaultUnitSystem(){return String(this.regionSource.props.unitSystemId).toLowerCase()||""}get unitSystemId(){return this.defaultUnitSystem}get timeFormatId(){const e=this.regionSource.props.timeFormatId;if(!e)return"";const t=String(e),s=this.timeFormats[t];return s?String(s.id):""}get selectedTimeFormat(){const e=this.timeFormatId;return e?String(this.timeFormats[e].format):"HH:mm:ss"}get is12HourTimeFormat(){const e=this.timeFormatId;return e?this.timeFormats[e].ampm:!0}get dateFormatId(){const e=this.regionSource.props.dateFormatId;if(!e)return"";const t=String(e);return t?this.dateFormats[t].id:""}get selectedDateFormat(){const e=this.dateFormatId;return e?this.dateFormats[e].format:""}get selectedDateOrder(){const e=this.dateFormatId;return e?this.dateFormats[e].order.toLowerCase():"dmy"}get selectedCountry(){return this.regionSource.props.country||"en"}get selectedTimeZone(){return this.regionSource.props.timeZone||""}get timeZones(){return this.regionId?this.timeZoneMap[this.regionId]||[]:[]}get allTimeZones(){return Intl.supportedValuesOf("timeZone")}get regionId(){return this.region.props.regionId||""}get selectedRegion(){return this.regionMap[this.regionId]}get selectedUnitSystem(){return String(this.regionSource.props.unitSystemId)||""}get timeFormatOptions(){return Object.keys(this.timeFormats).map(e=>({id:e,format:this.timeFormats[e].format,ampm:this.timeFormats[e].ampm}))}get dateFormatOptions(){return Object.keys(this.dateFormats).map(e=>({id:e,format:this.dateFormats[e].format,order:this.dateFormats[e].order}))}get unitSystemOptions(){return Object.keys(this.unitSystems).map(e=>({id:e,name:e}))}setSelectedTimeFormat(e){if(!this.timeFormatOptions.find(t=>t.id===e))throw Error(`Invalid time format id. Must be one of ${this.timeFormatOptions.map(t=>t.id).join(", ")}`);this.regionSource.updateProperty("timeFormatId",e)}setSelectedDateFormat(e){if(!this.dateFormatOptions.find(t=>t.id===e))throw Error(`Invalid date format id. Must be one of ${this.dateFormatOptions.map(t=>t.id).join(", ")}`);this.regionSource.updateProperty("dateFormatId",e)}setSelectedUnitSystem(e){if(!this.unitSystemOptions.find(t=>t.id===e))throw Error(`Invalid date format id. Must be one of ${this.unitSystemOptions.map(t=>t.id).join(", ")}`);this.regionSource.updateProperty("unitSystemId",e)}getUnitSystem(e){if(!e)return this.defaultUnitSystem;const t=e==="drt"?"second":e,s=this.unitSystemMap[t];if(!s)throw Error(`No unit found with name: ${t}. Unit should be one of ${Object.keys(this.unitSystemMap).join(", ")}`);return s[Z.system]}getUnitMeasure(e){const t=e==="drt"?"second":e,s=this.unitSystemMap[t];if(!s)throw Error(`No unit found with name: ${t}. Unit should be one of ${Object.keys(this.unitSystemMap).join(", ")}`);return s[Z.family]}getDefaultUnitDecimalPlaces(e,t,s){if(!e||!t)throw Error("Measure and unit system are required");const o=s==="drt"?"second":s,r=this.measureMap[e];if(!r)throw Error(`No unit systems found for measure: ${e}. Measure should come from list of measures: ${Object.keys(this.measureMap).join(", ")}`);const n=r[t.toLowerCase()];if(!n)throw Error(`No unit system found for measure: ${e} and unit system: ${t}. Unit system should come form list of unit systems: ${Object.keys(r).join(", ")}`);const i=n[o||"default"];if(!i)throw Error(`No unit "${o||"default"}" found for measure: ${e} and unit system: ${t}. Unit should come from list of units: ${Object.keys(n).join(", ")}`);return i[Z.decimals]}getDefaultUnitForMeasure(e,t){if(!e||!t)throw Error("Measure and unit system are required");const s=this.defaultMeasureMap[e];if(!s)throw Error(`No unit systems found for measure: ${e}. Measure should come from list of measures: ${Object.keys(this.measureMap).join(", ")}`);const o=s[t.toLowerCase()];if(!o)throw Error(`No unit system found for measure: ${e} and unit system: ${t}. Unit system should come form list of unit systems: ${Object.keys(s).join(", ")}`);return o}convertByUnit(e,t,s){if(t[Z.family]!==s[Z.family])throw new Error(`Cannot convert between units of different families: ${t[Z.family]} and ${s[Z.family]}`);const o=t[Z.offset],r=t[Z.scale],n=s[Z.scale],i=s[Z.offset],c=s[Z.decimals];return((e-o)/(r/n)+i).toFixed(c)}convertByUnitName(e,t,s){const o=this.unitSystemMap[t],r=this.unitSystemMap[s];if(!o||!r)throw new Error(`No unit found with name: ${t} or ${s}. Unit should be one of ${Object.keys(this.unitSystemMap).join(", ")}`);return this.convertByUnit(e,o,r)}convert(e,t,s){var c,d;if(t.unit&&s.unit)return this.convertByUnitName(e,t.unit,s.unit);const o=t.unit||"",r=s.unit||"";let n=this.unitSystemMap[o],i=this.unitSystemMap[r];if(!i&&s.measure&&s.system){const l=this.measureMap[s.measure];if(!l)throw Error(`Could not find measure ${s.measure}. Measure should be one of ${Object.keys(this.measureMap).join(", ")}`);i=(c=l[s.system])==null?void 0:c.default,i||at.info("Could not find default unit for measure",s.measure)}if(!n&&t.measure&&t.system){const l=this.measureMap[t.measure];if(!l)throw Error(`Could not find measure ${s.measure}. Measure should be one of ${Object.keys(this.measureMap).join(", ")}`);n=(d=l[t.system])==null?void 0:d.default,n||at.info("Could not find default unit for measure",t.measure)}return!n||!i?(at.warn("Could not find unit to convert to or from. Return value as is"),String(e)):this.convertByUnit(e,n,i)}async init(){at.debug("initializing region info")}async load(){at.debug("loading region info");const e=await fa();e&&(this.regions=e.data.map(s=>s.id),this.timeZoneMap=e.data.reduce((s,o)=>({...s,[o.id]:o.timeZones}),this.timeZoneMap),this.regionMap=e.data.reduce((s,o)=>({...s,[o.id]:o}),{}));const t=await ga();t&&(this.unitSystems=t.data.unitSystems.reduce((s,o)=>{const r={id:o.id,name:o.id};return s[o.id]=r,s},this.unitSystems),this.unitSystemMap=t.data.unitSystems.reduce(kh,{}),this.measureMap=t.data.unitSystems.reduce(xh,{}),this.defaultMeasureMap=t.data.unitSystems.reduce(Fh,{}),this.timeFormats=t.data.timeFormats.reduce((s,o)=>({...s,[o.id]:o}),{}),this.dateFormats=t.data.dateFormats.reduce((s,o)=>({...s,[o.id]:o}),{}))}async ready(){var e,t;await((t=(e=this.regionSource).ready)==null?void 0:t.call(e))}};nr([js({path:"kos:service:region:settings"})],Ct.prototype,"regionSource",2);nr([js({path:"kos:service:region"})],Ct.prototype,"region",2);Ct=nr([O(ds)],Ct);const z={registration:{[ds]:{class:Ct,singleton:!0}},type:ds,factory:H.Singleton.create(ds)},sn=({source:e,defaultSystem:t="si",defaultMeasure:s})=>{let o={system:t,measure:s};return typeof e=="string"?o={...o,unit:e}:o={...o,...e},o},ma=(e,t,s)=>{const{model:o}=Xe(z.type);if(!o)throw new Error("RegionInfo model not found");if(!fs(o))throw new Error("RegionInfo model not ready");const r={system:o.defaultUnitSystem},n=sn({source:t}),i=sn({source:s||r,defaultMeasure:o.getUnitMeasure(n.unit||"")});return o.convert(e,n,i)};function on({start:e,end:t,count:s,decimals:o=0}){if(typeof e!="number"||typeof t!="number"||typeof s!="number")throw new Error("All input values should be numbers.");if(s<2)throw new Error("Count should be at least 2 for distribution.");if(e>=t)throw new Error("Start should be less than end.");const r=(t-e)/(s-1),n=[];for(let i=0;i<s;i++){const c=Math.round(e+i*r);n.push(c.toFixed(o))}return n}function rn({start:e,end:t,interval:s,decimals:o=0}){if(typeof e!="number"||typeof t!="number"||typeof s!="number")throw new Error("All input values should be numbers.");if(s<=0)throw new Error("Interval should be a positive number.");if(e>=t)throw new Error("Start should be less than end.");const r=[];let n=e;for(;n<=t;)r.push(n.toFixed(o)),n+=s;return r[r.length-1]!==t.toString()&&r.push(t.toString()),r}const Pe=(e,t)=>s=>!e||!t?s:Us(s)?ma(Number(s),e,t):s,jh=(e,t,s,o)=>{if((e==null?void 0:e.type)==="enum"||!(e!=null&&e.options))return[];if(e.options.type==="rangeCount")return on(e.options).map(Pe(s,o));if(e.options.type==="rangeInterval")return rn(e.options).map(Pe(s,o));if(e.options.type==="list"){const{list:r}=e.options;return r.map(Pe(s,o))}else{if(e.options.type==="unitSystemRangeCount"&&t)return on(e.options.unitSystems[t]).map(Pe(s,o));if(e.options.type==="unitSystemRangeInterval"&&t)return rn(e.options.unitSystems[t]).map(Pe(s,o));if(e.options.type==="unitSystemList"&&t){const{list:r}=e.options.unitSystems[t];return r.map(Pe(s,o))}}return[]},Bh=(e,t)=>{if(!((e==null?void 0:e.type)==="enum"||!(e!=null&&e.options)))return e.options.type==="unitSystemRangeCount"&&t?{type:"rangeCount",...e.options.unitSystems[t]}:e.options.type==="unitSystemRangeInterval"&&t?{type:"rangeInterval",...e.options.unitSystems[t]}:e.options.type==="unitSystemList"&&t?{type:"list",...e.options.unitSystems[t]}:e.options.type==="unitSystemKeypad"&&t?{type:"keypad",...e.options.unitSystems[t]}:e.options};var Kh=Object.defineProperty,Gh=Object.getOwnPropertyDescriptor,ir=(e,t,s,o)=>{for(var r=o>1?void 0:o?Gh(t,s):t,n=e.length-1,i;n>=0;n--)(i=e[n])&&(r=(o?i(t,s,r):i(r))||r);return o&&r&&Kh(t,s,r),r};function Hh(e){return(e==null?void 0:e.type)==="enum"}function Vh(e){switch(e){case"s":return"second";case"ms":return"millisecond";case"min":return"minute";case"h":return"hour";case"d":return"day";case"w":return"week";case"m":return"month";case"y":return"year";case"ml":return"milliliter";default:return e}}function Yh(e,t){const s=new Date;s.setHours(0,0,0,0);const o=new Date(s.getTime()+e*1e3);return me.format(o,t)}const ls="config-bean-prop-model",ke=f.createLogger({name:"config-bean-prop-model"}),zh=Se("path"),qh=Se("serviceBasePath");let Rt=class{constructor(e,t){a(this,"id");a(this,"path");a(this,"attribute");a(this,"converter");a(this,"formatter");a(this,"optionsExpander");a(this,"serviceBasePath");a(this,"regionInfo");a(this,"bean");this.id=e,this.path=t.path,this.attribute=t.attribute,this.converter=t.converter,this.formatter=t.formatter,this.serviceBasePath=t.serviceBasePath,this.optionsExpander=t.optionsExpander}getDefaultUnitDecimalPlaces(e,t,s){if(!e)throw new Error("measure is required");if(!t)throw new Error("unitSystem is required");return oa(this.displayOptions)?this.displayOptions.decimals:this.regionInfo.getDefaultUnitDecimalPlaces(e,t,s)}getDefaultUnitForMeasure(e,t){if(!e)throw new Error("measure is required");if(!t)throw new Error("unitSystem is required");return this.regionInfo.getDefaultUnitForMeasure(e,t)}get schemaType(){const e=this.bean.getSchemaForProperty(this.attribute);return e!=null&&e.type?e.type:"String"}get schemaFormat(){const e=this.bean.getSchemaForProperty(this.attribute);return e!=null&&e.format?Vh(e.format):""}get options(){var i;const e=this.regionInfo.defaultUnitSystem,t=this.getConverter(),s=((i=t==null?void 0:t.to)==null?void 0:i.system)??e,o=this.bean.getSchemaForProperty(this.attribute),r=Hh(o)?o.values:jh(o,s,t==null?void 0:t.from,t==null?void 0:t.to),n=r.length>0?r.map(c=>({label:c,value:c})):[];return this.optionsExpander?typeof this.optionsExpander=="function"?this.optionsExpander(s,r):this.optionsExpander:n}convertUnit(e,t,s){const o=(e==null?void 0:e.measure)||s,r=(e==null?void 0:e.system)||t,n=e==null?void 0:e.unit;return{measure:o,system:r,unit:n}}getConverterUnits(){const e=this.regionInfo.defaultUnitSystem,t=this.getConverter();if(!t)throw Error("No converter defined");const s=t.measure,o=this.convertUnit(t.from,"si",s),r=this.convertUnit(t.to,e,s);return{backend:o,display:r}}set value(e){this.updateProperty(e)}get value(){return this.getValue(!0)}get rawValue(){return this.bean.props[this.attribute]}get significantValue(){var r,n;const e=this.value,t=this.regionInfo.defaultUnitSystem,s=this.getConverter(),o=(s==null?void 0:s.measure)||((r=s==null?void 0:s.to)==null?void 0:r.measure);if(!isNaN(e)&&s&&o){const i=this.getDefaultUnitDecimalPlaces(o,t,(n=s==null?void 0:s.to)==null?void 0:n.unit);try{const d=this.getFormatterOptions(s);if(d){let l=String(e);return l=d.formatToParts(Number(e))[0].value,Number(l)}}catch(d){ke.info(`error formatting value ${e}`,d)}return Number(e).toFixed(i)}return e}get previousValue(){return this.getValue(!1)}getValue(e){const t=this.bean[e?"props":"prevProps"][this.attribute];if(typeof t=="boolean")return t;if(this.getConverter()&&!isNaN(t)){const{backend:o,display:r}=this.getConverterUnits();return this.regionInfo.convert(Number(t),o,r)}return t||""}async activate(){ke.debug(`activating config bean ${this.id}`)}get displayValue(){const e=this.value;if(typeof e=="boolean")return String(e);if(this.schemaFormat==="drt"){const s=this.regionInfo.is12HourTimeFormat?"h:mm:ss a":"HH:mm:ss";return Yh(e,s)}if(!isNaN(e))try{const t=this.getConverter(),s=this.getFormatterOptions(t);if(s){let o=String(e);return o=s.format(Number(e)),o}}catch(t){ke.error(`error formatting value ${e}`,t)}return String(e)}get unit(){const e=this.getConverter();if(!isNaN(this.value)){const t=this.getFormatterOptions(e);if(t){const o=t.formatToParts(Number(this.value)).find(r=>r.type==="unit");return(o==null?void 0:o.value)??this.getDefaultUnit(e)}}return this.getDefaultUnit(e)}get displayOptions(){var r;const e=this.bean.getSchemaForProperty(this.attribute),t=this.regionInfo.defaultUnitSystem,s=this.getConverter(),o=((r=s==null?void 0:s.to)==null?void 0:r.system)??t;return Bh(e,o)}getMeasureFromFormat(){const e=this.schemaFormat;return e?this.regionInfo.getUnitMeasure(e):""}getConverterFromFormat(){const e=this.getMeasureFromFormat();if(e){const t=this.regionInfo.selectedUnitSystem;return{unit:this.schemaFormat||this.regionInfo.getDefaultUnitForMeasure(e,t),measure:e}}return{}}getDefaultUnit(e){var o,r;const t=this.regionInfo.defaultUnitSystem,s=e==null?void 0:e.measure;return s?((o=e==null?void 0:e.to)==null?void 0:o.unit)||this.getDefaultUnitForMeasure(s,((r=e==null?void 0:e.to)==null?void 0:r.system)||t):this.getConverterFromFormat().unit}getFormatterOptions(e){var n,i,c;const t=this.regionInfo.defaultUnitSystem,s=e==null?void 0:e.measure,o=new Intl.NumberFormat().resolvedOptions().locale;let r=null;if(s||this.formatter){const d=s?{style:"unit",unit:this.getDefaultUnit(e)}:null,l=this.formatter||d;if(l){let u=typeof l=="function"?l(((n=e==null?void 0:e.to)==null?void 0:n.system)||t):l;s&&(u={unit:this.getDefaultUnit(e),...u},u.style==="unit"&&(u.maximumFractionDigits=u.maximumFractionDigits??this.getDefaultUnitDecimalPlaces(s,((i=e==null?void 0:e.to)==null?void 0:i.system)||t,(c=e==null?void 0:e.to)==null?void 0:c.unit)));try{r=new Intl.NumberFormat(o,{...u})}catch(h){ke.error(`error creating formatter ${u}. Returning the raw value`,h)}}else ke.debug(`no formatter found for config bean prop ${this.id}. Returning the raw value`)}return r}getConverter(){var o,r,n,i,c,d,l,u,h,p,w;const{unit:e,measure:t}=this.getConverterFromFormat(),s=e==="drt"?"second":e;if(this.converter){const b=(o=this.converter)==null?void 0:o.measure,_=(n=(r=this.converter)==null?void 0:r.to)==null?void 0:n.measure,I=(c=(i=this.converter)==null?void 0:i.from)==null?void 0:c.measure,A=b||_||I||t,se=((l=(d=this.converter)==null?void 0:d.to)==null?void 0:l.unit)||this.regionInfo.getDefaultUnitForMeasure(A,((h=(u=this.converter)==null?void 0:u.to)==null?void 0:h.system)??this.regionInfo.defaultUnitSystem),we=((w=(p=this.converter)==null?void 0:p.to)==null?void 0:w.system)??this.regionInfo.getUnitSystem(se),rt=this.schemaFormat==="drt"?"second":this.schemaFormat||s;return{...this.converter,from:{unit:rt,...this.converter.from},to:{...this.converter.to,unit:se,system:we},measure:A}}if(s&&t){const b=this.regionInfo.getDefaultUnitForMeasure(t,this.regionInfo.defaultUnitSystem),_=this.regionInfo.getUnitSystem(s),I=this.regionInfo.getUnitSystem(b);return{measure:t,to:{unit:_===I?s:b}}}}async updateProperty(e){ke.debug(`updating property ${this.attribute} with value ${e}`);let t=e;if(this.getConverter()&&!isNaN(t)){const{backend:r,display:n}=this.getConverterUnits();t=this.regionInfo.convert(Number(t),n,r)}const o=Array.isArray(t)?JSON.stringify(t):String(t);await this.bean.updateProperty(this.attribute,o)}};ir([Ae({modelType:z.type})],Rt.prototype,"regionInfo",2);ir([js({path:zh,serviceBasePath:qh})],Rt.prototype,"bean",2);Rt=ir([O(ls)],Rt);const Ce={registration:{[ls]:{class:Rt,singleton:!1}},type:ls,factory:H.Factory.create(ls)};function Wh(e){const{path:t,attribute:s,converter:o,formatter:r,lazy:n,optionsExpander:i,serviceBasePath:c}=e,d=o;return d&&(typeof d!="function"&&typeof d.from=="string"&&(d.from={unit:d.from}),typeof d!="function"&&typeof d.to=="string"&&(d.to={unit:d.to})),(l,u)=>{l[P]=l[P]||{},l[P][u]={modelType:Ce.type,id:`${t}-${s}`,options:{path:t,attribute:s,serviceBasePath:c,converter:d,formatter:r,optionsExpander:i},lifecycle:x.INIT,lazy:n}}}class Zh{constructor(t,s){a(this,"futures");a(this,"defaultContext");a(this,"context");a(this,"disposers",new Map);a(this,"container");this.futures=er.map(new Map),this.context="",this.defaultContext=s||"",this.container=t,v.makeAutoObservable(this)}get allFutures(){return Array.from(this.futures.values())}get future(){return this.futures.get(this.defaultContext)}addFuture(t,s){this.futures.set(s||t.id,t),this.context=s||t.id;const o=F(()=>{var r,n;(t.endState||t.progress)&&((n=(r=this.container)==null?void 0:r.onFutureUpdate)==null||n.call(r,t))});this.disposers.set(s||t.id,o)}removeFuture(t){var s;this.futures.delete(t||this.context),(s=this.disposers.get(t||this.context))==null||s(),this.disposers.delete(t||this.context)}getFuture(t){return this.futures.get(t||this.context)}get futureMap(){return this.futures}}class ar{constructor(t){a(this,"disposer");a(this,"_future");a(this,"container");a(this,"onFutureUpdate");this._future=void 0,this.container=t,v.makeAutoObservable(this)}removeFuture(){var t;this._future=void 0,(t=this.disposer)==null||t.call(this),this.disposer=void 0}get future(){return this._future}getFuture(){return this._future}addFuture(t){this._future=t;const s=F(()=>{var o,r;(t.endState||t.progress)&&((r=(o=this.container)==null?void 0:o.onFutureUpdate)==null||r.call(o,t))});this.disposer=s}get allFutures(){return this._future?[this._future]:[]}get timeRemaining(){var t;return((t=this._future)==null?void 0:t.timeRemaining)||""}get status(){var t;return((t=this._future)==null?void 0:t.status)||"NOT_RESOLVED"}get progress(){var t;return((t=this._future)==null?void 0:t.progress)||-1}async cancel(){if(this._future)try{await this._future.cancelFuture()}catch(t){throw f.error(t),t}}}const ya="future-model",st=et(ya),Bs=f.createLogger({name:"future-service",group:"Services"}),{isMock:Jh,URL:Vt}=q();var Ge=(e=>(e.Success="SUCCESS",e.Fail="FAIL",e.Aborted="ABORT",e.Canceled="CANCEL",e))(Ge||{});const{getAll:Qh,modifyModel:Xh,addModel:eg,deleteModel:tg,postModel:sg}=V.build({destinationAddress:"",basePath:`${Vt}/api/future`,mock:Jh}),og=async()=>await Qh({}),ba=async(e,t="/api/kos/future")=>(Bs.info(`sending delete request for Future: ${e}`),await tg({id:e,urlOverride:`${Vt}${t}/${e}`})),va=async(e,t="/api/kos/future")=>(Bs.info("sending add request for Future"),await eg({model:e,urlOverride:`${Vt}${t}`})),rg=async(e,t,s="/api/kos/future")=>(Bs.info(`sending modify request for Future: ${e}`),Xh({model:t,id:e,urlOverride:`${Vt}${s}/${e}`})),wa=async(e,t="/api/kos/future")=>(Bs.info(`sending cancel request for Future: ${e}`),sg({urlOverride:`${Vt}${t}/${e}/cancel`,ordered:!0,model:{}})),cr=e=>({id:String(e.id),progress:e.progress,remainingTimeMs:e.remainingTimeMs,endState:e.endState,reason:e.reason,clientData:e.clientData,reasonData:e.reasonData,note:e.note,tracker:e.tracker}),dr=(e,t)=>{f.debug(`future dto ${e.id} end state ${e.endState}`),f.debug(`future model ${t.id} end state ${t.endState}`),t.endState?f.debug(`future model ${t.id} is already complete`):(f.debug(`updating future model ${t.id}`),v.runInAction(()=>{const s=cr(e);Y(()=>{Object.keys(s).forEach(o=>{o==="id"?(t.futureId=s.id,s.tracker||(t.id=s.id)):o==="tracker"?t.id=s.tracker:t[o]=s[o]})})}))},Ma=e=>t=>s=>e.build(String(t),s),lr=e=>t=>qi(cr,Ma(e)(t.tracker||t.id))(t);var ng=Object.defineProperty,ig=Object.getOwnPropertyDescriptor,_a=(e,t,s,o)=>{for(var r=o>1?void 0:o?ig(t,s):t,n=e.length-1,i;n>=0;n--)(i=e[n])&&(r=(o?i(t,s,r):i(r))||r);return o&&r&&ng(t,s,r),r};const co=f.getLogger(st.type);let ms=class{constructor(e,t,s){a(this,"logger");a(this,"_cancelFuture");a(this,"futureId");Object.assign(this,t),this.logger=s.logger,this.id=e,this.futureId=t.id,this.namespace=t.namespace||"kos",this._cancelFuture=wa,Mo(()=>this.status===Ge.Success||this.status===Ge.Fail,()=>{co.info(`Future ${this.id} has completed with status ${this.status}`),Oe(this)})}async load(){co.debug(`loading Future ${this.id}`)}unload(){co.info(`unloading Future ${this.id}`)}async cancelFuture(){const e=this.namespace==="studio"?"/api/future":`/api/${this.namespace}/future`;await Mo(()=>this.futureId!==tr),await this._cancelFuture(this.futureId,e)}get status(){return this.endState?this.endState:this.progress>-1?"IN_PROGRESS":"NOT_ACTIVE"}get timeRemaining(){var c,d;const e=this.remainingTimeMs||-1;if(e<0)return"";const t={year:1e3*60*60*24*365,month:1e3*60*60*24*30,day:1e3*60*60*24,hour:1e3*60*60,minute:1e3*60,second:1e3};let s="second",o=0;for(const[l,u]of Object.entries(t))if(Math.abs(e)>=u){s=l,o=Math.round(e/u);break}const n=new Intl.RelativeTimeFormat("en",{numeric:"auto"}).formatToParts(o,s);return n.length===3?`${((c=n[1])==null?void 0:c.value)??0} ${((d=n[2])==null?void 0:d.value)??""}`:"0 seconds"}handleFutureUpdated(e){this.logger.debug(`Future ${this.id} updated. future: ${e.id} endState: ${e.endState} progress: ${e.progress} remainingTimeMs: ${e.remainingTimeMs}`),dr(e,this)}};_a([R({topic:`kos.future/${hs}`})],ms.prototype,"handleFutureUpdated",1);ms=_a([O(st.type)],ms);const Ea=ms,Ia=Zo();var ag=Object.defineProperty,cg=Object.getOwnPropertyDescriptor,Ta=(e,t,s,o)=>{for(var r=o>1?void 0:o?cg(t,s):t,n=e.length-1,i;n>=0;n--)(i=e[n])&&(r=(o?i(t,s,r):i(r))||r);return o&&r&&ag(t,s,r),r};const $a="browser-router-model",dg="kos.http.request",lg="kos.http.response";let ys=class{constructor(e,t,s){a(this,"_id");a(this,"logger");a(this,"router");this._id=e,this.logger=s.logger,this.router=new Xi}get id(){return this._id}async handleRequest(e,t){const s=t.headers["src-addr"],o=t.headers["dst-addr"],r=t.headers.url,n=t.headers.method,i=t.headers["request-id"],c={id:i,method:n,path:r,body:e};let d=200;const l={send:u=>{this.logger.debug(`sending response to ${o}`),this.logger.debug(u),Ai({msg:u,options:{responseId:i,destinationAddress:s,type:lg,sourceAddress:o,status:d}})},status:function(u){return d=u,this}};if(c.path==="/openapi.json"){l.send(this.router.generateOpenApiSpec());return}await this.router.handle(c,l)}use(e,t,...s){this.router.use(e,t,...s)}async init(){this.logger.debug(`initializing browser-router ${this.id}`)}async load(){this.logger.debug(`loading browser-router ${this.id}`)}};Ta([R({topic:dg})],ys.prototype,"handleRequest",1);ys=Ta([O($a)],ys);const Ks=new pe({class:ys,type:$a}),Oa="future-container-model",be=et(Oa),Da=e=>lr(st)(e),ug=e=>{const t=Da(e);return be.build(be.type,{}).addFutureModel(t),t},hg=e=>be.build(be.type,{}).getFuture(String(e)),De={buildFutureModel:Da,initiateFuture:ug,getFuture:hg};var gg=Object.defineProperty,fg=Object.getOwnPropertyDescriptor,ur=(e,t,s,o)=>{for(var r=o>1?void 0:o?fg(t,s):t,n=e.length-1,i;n>=0;n--)(i=e[n])&&(r=(o?i(t,s,r):i(r))||r);return o&&r&&gg(t,s,r),r};const es=f.getLogger(be.type);let Lt=class{constructor(e,t,s){a(this,"id");a(this,"logger");a(this,"_deleteFuture");a(this,"_addFuture");a(this,"_futures");a(this,"createModel");a(this,"deleteModel");const{deleteFuture:o=ba,addFuture:r=va}=t;this.logger=s.logger,this._deleteFuture=o,this._addFuture=r,this.id=e,this._futures=new le,this.createModel=this.createFuture,this.deleteModel=this.removeFuture}get futures(){return this._futures.data}get models(){return this.futures}getFuture(e){return this._futures.getModel(e)}addFutureModel(e){this._futures.addModel(e)}removeFutureModel(e){this._futures.removeModel(e)}async removeFuture(e){try{await this._deleteFuture(e)}catch(t){es.error("error deleting a Future"),es.error(t)}}async createFuture(e){try{const t=await this._addFuture(e),s=t==null?void 0:t.data;if(s){const o=lr(st)(s);return this.addFutureModel(o),o}}catch(t){throw es.error("error creating a Future"),es.error(t),t}}handleFutureUpdated(e,t){const s=De.buildFutureModel(e);this.addFutureModel(s);const o=`kos.future/${e.tracker||e.id}`;this.logger.debug(`publishing future update to ${o}`),N(o,t.body,t.headers)}};ur([ie],Lt.prototype,"_futures",2);ur([R({topic:"kos.future"})],Lt.prototype,"handleFutureUpdated",1);Lt=ur([O(be.type)],Lt);const Sa=Lt,{URL:Yt}=q(),{getOne:pg,postModel:mg,deleteModel:Aa}=V.build({basePath:`${Yt}/api/keyVal`}),_o=f.createLogger({name:"key-value-service",group:"Services"}),Ca=async(e,t)=>{await Aa({urlOverride:`${Yt}/api/keyVal/${e}/${t}`,id:t})},Ra=async(e,t,s)=>{const o=await mg({urlOverride:`${Yt}/api/keyVal/${e}/${t}`,model:s.toString()});if((o==null?void 0:o.status)!==200)throw _o.error("Failed to update studio-state data",o),new Error(`Failed to update studio-state data for namespace ${e}`);return o.data},La=async(e="studio")=>{_o.debug("sending GET for studio-state");const t=await pg({urlOverride:`${Yt}/api/keyVal/${e}`});if((t==null?void 0:t.status)!==200)throw _o.error("Failed to retrieve studio-state data",t),new Error(`Failed to retrieve studio-state data for namespace ${e}`);return t.data},yg=async e=>{await Aa({urlOverride:`${Yt}/api/keyVal/${e}}`,id:""})},bg=Object.freeze(Object.defineProperty({__proto__:null,deleteKeyValue:Ca,deleteKeyValueNamespace:yg,getKeyValue:La,updateKeyValue:Ra},Symbol.toStringTag,{value:"Module"}));var vg=Object.defineProperty,wg=Object.getOwnPropertyDescriptor,hr=(e,t,s,o)=>{for(var r=o>1?void 0:o?wg(t,s):t,n=e.length-1,i;n>=0;n--)(i=e[n])&&(r=(o?i(t,s,r):i(r))||r);return o&&r&&vg(t,s,r),r};const Pa="key-value-model";let Pt=class{constructor(e,t,s){a(this,"id");a(this,"logger");a(this,"namespace");a(this,"data");this.id=e,this.logger=s.logger,this.data=ye(),this.namespace=t.namespace||"studio"}async init(){this.logger.debug(`initializing studio-state ${this.id}`)}async updateState(e,t){this.logger.debug(`updating studio-state ${e} with value ${t}`),t!==void 0?(await Ra(this.namespace,e,t),this.data[e]=t):(await Ca(this.namespace,e),this.data[e]=void 0)}async load(){this.logger.debug(`loading studio-state ${this.id}`);const e=await La(this.namespace);this.data.setValues(e)}handleStateUpdate(e){e.namespace===this.namespace&&(this.data[e.key]=e.value)}handleStateDelete(e){e.namespace===this.namespace&&(this.data[e.key]=void 0)}};hr([R({topic:"/keyVal/set"})],Pt.prototype,"handleStateUpdate",1);hr([R({topic:"/keyVal/remove"})],Pt.prototype,"handleStateDelete",1);Pt=hr([O(Pa)],Pt);const gr=new ae({class:Pt,type:Pa}),{URL:zt}=q(),{postModel:fr,getOne:Mg}=V.build({basePath:`${zt}/api/kos-time`});f.createLogger({name:"kos-time-service",group:"Services"});const ka=async e=>{const t=await fr({model:e,urlOverride:`${zt}/api/kos/time/time`});if((t==null?void 0:t.status)!==200)throw Error("Failed to set time");return t.data},xa=async e=>{const t=await fr({model:e,urlOverride:`${zt}/api/kos/time/date`});if((t==null?void 0:t.status)!==200)throw Error("Failed to set time");return t.data},Fa=async e=>{const t=await fr({model:{},urlOverride:`${zt}/api/kos/time/timezone?tz=${e}`});if((t==null?void 0:t.status)!==200)throw Error("Failed to set timezone");return t.data},Na=async()=>{const e=await Mg({urlOverride:`${zt}/api/kos/time/timezone`});if((e==null?void 0:e.status)!==200)throw Error("Failed to set timezone");return e.data.timeZone},_g=Object.freeze(Object.defineProperty({__proto__:null,getTimezone:Na,setDate:xa,setTime:ka,setTimezone:Fa},Symbol.toStringTag,{value:"Module"}));var Eg=Object.defineProperty,Ig=Object.getOwnPropertyDescriptor,Gs=(e,t,s,o)=>{for(var r=o>1?void 0:o?Ig(t,s):t,n=e.length-1,i;n>=0;n--)(i=e[n])&&(r=(o?i(t,s,r):i(r))||r);return o&&r&&Eg(t,s,r),r};const dt="kos-time-model",Tg="/kos/time/time",$g="/kos/time/day",Og="/kos/time/timezone";let He=class{constructor(e,t,s){a(this,"id");a(this,"logger");a(this,"timezone");this.id=e,this.logger=s.logger,this.timezone=""}async updateSystemTime(e){await ka(e)}async updateSystemDate(e){await xa(e)}async updateSystemTimezone(e){await Fa(e)}handleTimeChange(){N(Ot.TIME_CHANGE,{})}handleDayChange(){N(Ot.DAY_CHANGE,{})}async handleTimeZoneChange(){await this.retrieveTimezone(),N(Ot.TIMEZONE_CHANGE,{})}async init(){this.logger.debug(`initializing kos-time ${this.id}`)}async retrieveTimezone(){const e=await Na();this.setTimezone(e)}setTimezone(e){this.timezone=e}async load(){this.logger.debug(`loading kos-time ${this.id}`),this.retrieveTimezone()}};Gs([R({topic:Tg,websocket:!0})],He.prototype,"handleTimeChange",1);Gs([R({topic:$g,websocket:!0})],He.prototype,"handleDayChange",1);Gs([R({topic:Og,websocket:!0})],He.prototype,"handleTimeZoneChange",1);He=Gs([O(dt)],He);const bs={registration:{[dt]:{class:He,singleton:!0}},type:dt,predicate:te(dt),factory:H.Singleton.create(dt)};var Dg=Object.defineProperty,Sg=Object.getOwnPropertyDescriptor,Ua=(e,t,s,o)=>{for(var r=o>1?void 0:o?Sg(t,s):t,n=e.length-1,i;n>=0;n--)(i=e[n])&&(r=(o?i(t,s,r):i(r))||r);return o&&r&&Dg(t,s,r),r};const ja="log-block-container-model";let vs=class{constructor(e,t,s){a(this,"id");a(this,"logger");a(this,"_models");this.id=e,this.logger=s.logger,this._models=new le({parentId:e,sortKey:"blockNum"})}getModel(e){return this._models.getModel(e)}get models(){return this._models}get data(){return this._models.data}addModel(e){this._models.addModel(e)}removeModel(e){this._models.removeModel(e)}async init(){this.logger.debug(`initializing log-block-container container ${this.id}`)}async load(){this.logger.debug(`loading log-block-container container ${this.id}`)}};Ua([ie],vs.prototype,"_models",2);vs=Ua([O(ja)],vs);const Re=Zo(),Ag=f.createLogger({name:"log-stream-container-service",group:"Services"}),Ba=()=>{var o;const e=ee(),s=(e==null?void 0:e.connId)||((o=window==null?void 0:window.kosBridge)==null?void 0:o.call(window,"connId"));return f.error(`getKosConnectionId: ${s}`),s},ot=Ba(),Cg="/api/kos/logs/node/{nodeId}/streams",Ka=async()=>(Ag.debug("sending GET for log-stream-container"),await Re.get(Cg,{path:{nodeId:"primary"}},{destinationAddress:ot})),Ga=async(e,t="primary")=>{await Re.post("/api/kos/logs/node/{nodeId}/{stream}/subscribe",{path:{nodeId:t,stream:e}},void 0,{destinationAddress:ot})},Ha=async e=>{await Re.post("/api/kos/logs/node/{nodeId}/{stream}/unsubscribe",{path:{nodeId:"primary",stream:e}},void 0,{destinationAddress:ot})},Rg=async()=>{await Re.post("/api/kos/logs/overrides",{},{level:"WARN",name:"com.example",nodeType:"java",type:"package"},{destinationAddress:ot})},Va=async e=>await Re.get("/api/kos/logs/node/{nodeId}/{stream}/blocks",{path:{nodeId:"primary",stream:e}},{destinationAddress:ot}),Ya=async(e,t)=>await Re.get("/api/kos/logs/node/{nodeId}/{stream}/blocks/{blockId}",{path:{nodeId:"primary",stream:e,blockId:t}},{destinationAddress:ot}),Lg=Object.freeze(Object.defineProperty({__proto__:null,createOverride:Rg,getKosConnectionId:Ba,getLogStreamBlock:Ya,getLogStreamBlocks:Va,getLogStreams:Ka,subscribeToLogStream:Ga,unsubscribeFromLogStream:Ha},Symbol.toStringTag,{value:"Module"}));var Pg=Object.defineProperty,kg=Object.getOwnPropertyDescriptor,xg=(e,t,s,o)=>{for(var r=o>1?void 0:o?kg(t,s):t,n=e.length-1,i;n>=0;n--)(i=e[n])&&(r=(o?i(t,s,r):i(r))||r);return o&&r&&Pg(t,s,r),r};const za="log-block-model";let Eo=class{constructor(e,t,s){a(this,"id");a(this,"logger");a(this,"nodeId");a(this,"stream");a(this,"blockNum");a(this,"startLineNum");a(this,"endLineNum");a(this,"startTime");a(this,"endTime");a(this,"lineCount");a(this,"lines");a(this,"inc");this.id=e,this.logger=s.logger,this.nodeId=t.nodeId,this.stream=t.stream,this.blockNum=t.blockNum,this.startLineNum=t.startLineNum,this.endLineNum=t.endLineNum,this.startTime=t.startTime,this.endTime=t.endTime,this.lineCount=t.lineCount,this.lines=[],this.inc=0}async syncLines(){const[e,t]=await Ya(this.stream,this.blockNum);if(e){this.logger.error(`Failed to get log block ${this.blockNum}`);return}t&&this.addLines(t.lines,!0)}updateModel(e){this.startLineNum=e.startLineNum,this.endLineNum=e.endLineNum,this.startTime=e.startTime,this.endTime=e.endTime,this.lineCount=e.lineCount}addLines(e,t){const s=t?[]:this.lines;this.lines=[...s,...e],this.inc+=1}async init(){this.logger.debug(`initializing log-block ${this.id}`)}async load(){this.logger.debug(`loading log-block ${this.id}`)}};Eo=xg([O(za)],Eo);const kt=new ae({class:Eo,type:za}),Hs=new ae({class:vs,type:ja});Hs.addRelatedModel(kt);var Fg=Object.defineProperty,Ng=Object.getOwnPropertyDescriptor,qa=(e,t,s,o)=>{for(var r=o>1?void 0:o?Ng(t,s):t,n=e.length-1,i;n>=0;n--)(i=e[n])&&(r=(o?i(t,s,r):i(r))||r);return o&&r&&Fg(t,s,r),r};const Wa="log-stream-model";let ws=class{constructor(e,t,s){a(this,"id");a(this,"logger");a(this,"nodeId");a(this,"_blocks");a(this,"name");a(this,"currentBlockId");a(this,"isResetting");a(this,"generatorInstance");a(this,"shouldStop",!1);this.id=e,this.logger=s.logger,this.currentBlockId="",this.name=t.name,this.nodeId=t.nodeId,this.isResetting=!0,this._blocks=Hs.instance(`${e}-blocks`).options({}).build()}get firstLineNum(){const e=this.populated[0];return e?e.startLineNum:0}get currentBlock(){const e=this.currentBlockId;return this._blocks.getModel(e)}get populated(){return this._blocks.data.filter(e=>e.lines.length>0)}get blocks(){return this._blocks.data}get totalLineCount(){return this.populated.reduce((e,t)=>e+t.lineCount,0)}accept(e){e.visit(this)}updateBlock(e){var o;let t=this._blocks.models.getModel(`${e.stream}-block-${e.blockNum}`);const s={nodeId:e.nodeId,blockNum:e.blockNum,endLineNum:e.endLineNum,lineCount:e.lineCount,startLineNum:e.startLineNum,stream:this.name,endTime:new Date(e.endTime),startTime:new Date(e.startTime)};t||(t=kt.instance(`${e.stream}-block-${e.blockNum}`).options(s).build(),this._blocks.addModel(t)),t&&t.updateModel(s),(!this.currentBlock||e.blockNum>=((o=this.currentBlock)==null?void 0:o.blockNum))&&(this.currentBlockId=`${e.stream}-block-${e.blockNum}`)}addBlock(e){var s;const t=kt.instance(`${e.stream}-block-${e.blockNum}`).options({nodeId:e.nodeId,blockNum:e.blockNum,endLineNum:e.endLineNum,lineCount:e.lineCount,startLineNum:e.startLineNum,stream:this.name,endTime:new Date(e.endTime),startTime:new Date(e.startTime)}).build();this._blocks.addModel(t),(!this.currentBlock||e.blockNum>=((s=this.currentBlock)==null?void 0:s.blockNum))&&(this.currentBlockId=`${e.stream}-block-${e.blockNum}`)}removeBlock(e){this._blocks.models.removeModel(`${this.name}-block-${e}`)}async subscribe(){await Ga(this.name)}async unsubscribe(){await Ha(this.name)}async reset(){if(this.isResetting=!0,this.populated.length>0)return;this.logger.debug(`resetting log-stream ${this.id}`);for(const t of this._blocks.models.data)t.lines=[];const e=this._blocks.data[this._blocks.data.length-1];e&&await e.syncLines(),this.isResetting=!1}async init(){this.logger.debug(`initializing log-stream ${this.id}`)}async load(){this.logger.debug(`loading log-stream ${this.id}`);const[e,t]=await Va(this.name);if(e){this.logger.error(`Error loading log stream: ${e}`);return}if(t)for(const o of t)this.addBlock(o);const s=this._blocks.data[this._blocks.data.length-1];if(s&&await s.syncLines(),this._blocks.data.length>1){const o=this._blocks.data[this._blocks.data.length-2];o&&await o.syncLines()}}start(){return this.shouldStop=!1,this.generatorInstance=this.streamLogs(),this.generatorInstance}stop(){var e;this.shouldStop=!0,(e=this.generatorInstance)==null||e.next(),console.log("Requested generator stop.")}async*streamLogs(){const e=[];let t=null,s=0,o=this.currentBlockId;const r=ta(()=>{const n=this.currentBlock;return n?{blockId:this.currentBlockId,lineCount:n.lines.length}:null},n=>{const i=this.currentBlock;if(i)if(o!==(n==null?void 0:n.blockId))o=n==null?void 0:n.blockId,s=0,e.push(...i.lines);else{const c=i.lines.slice(s);e.push(...c),s+=c.length}t&&(t(),t=null)},{fireImmediately:!0});try{for(const n of this.populated.filter(i=>i!==this.currentBlock))for(const i of n.lines)yield i;for(;;)for(e.length===0&&await new Promise(n=>t=n);e.length>0;)yield e.shift()}finally{r()}}};qa([ie],ws.prototype,"_blocks",2);ws=qa([O(Wa)],ws);const Dt=new ae({class:ws,type:Wa});var Ug=Object.defineProperty,jg=Object.getOwnPropertyDescriptor,Le=(e,t,s,o)=>{for(var r=o>1?void 0:o?jg(t,s):t,n=e.length-1,i;n>=0;n--)(i=e[n])&&(r=(o?i(t,s,r):i(r))||r);return o&&r&&Ug(t,s,r),r};const Za="log-stream-container-model",Bg="/kos/logs/subscription/addBlock/*",Kg="/kos/logs/subscription/updateBlock/*",Gg="/kos/logs/subscription/removeBlock/*",Hg="/kos/logs/subscription/lines/*",Ja="/kos/logs/streams/add/*";let he=class{constructor(e,t,s){a(this,"id");a(this,"logger");a(this,"selectedStream");a(this,"_models");this.id=e,this.logger=s.logger,this._models=new le({parentId:e}),this.selectedStream=void 0}getModel(e){return this._models.getModel(e)}get models(){return this._models}get data(){return this._models.data}updateModel(e){}addModel(e){this._models.addModel(e)}removeModel(e){this._models.removeModel(e)}updateSelectedStream(e){this.selectedStream=e}handleStreamAdded(e){this.logger.debug(`Received topic: ${Ja}`);const t=e.stream,s=Dt.instance(t).options({name:t,nodeId:"primary"}).build();this.addModel(s)}handleAddBlock(e,t){this.logger.debug(`Received topic: ${t.headers.topic}`);const s=e.stream,o=this.models.getModel(s);o&&o.addBlock(e)}handleRemoveBlock(e,t){this.logger.debug(`Received topic: ${t.headers.topic}`);const s=e.stream,o=this.models.getModel(s);o&&o.removeBlock(e.blockNum)}handleUpdateBlock(e,t){this.logger.debug(`Received topic: ${t.headers.topic}`);const s=e.stream,o=this.models.getModel(s);o&&o.updateBlock(e)}handleLogLine(e,t){var r;this.logger.debug(`Received topic: ${t.headers.topic}`);const s=e.stream,o=this.models.getModel(s);o&&((r=o.currentBlock)==null||r.addLines(e.lines))}async init(){this.logger.debug(`initializing log-stream-container container ${this.id}`)}async subscribeToLogStream(e){const t=Dt.instance(e).options({name:e,nodeId:"primary"}).build();this.addModel(t),await t.subscribe()}async load(){this.logger.debug(`loading log-stream-container container ${this.id}`);const[e,t]=await Ka();if(e){this.logger.error(`Error loading log-streams: ${e}`);return}t&&t.forEach(s=>{const o=Dt.instance(s).options({name:s,nodeId:"primary"}).build();this.addModel(o)})}};Le([ie],he.prototype,"_models",2);Le([R({topic:[Ja],websocket:!0})],he.prototype,"handleStreamAdded",1);Le([R({topic:[Bg],websocket:!0})],he.prototype,"handleAddBlock",1);Le([R({topic:[Gg],websocket:!0})],he.prototype,"handleRemoveBlock",1);Le([R({topic:[Kg],websocket:!0})],he.prototype,"handleUpdateBlock",1);Le([R({topic:[Hg],websocket:!0})],he.prototype,"handleLogLine",1);he=Le([O(Za)],he);const qt=new pe({class:he,type:Za});qt.addRelatedModel(Dt);qt.addRelatedModel(Hs);qt.addRelatedModel(kt);const Vg=e=>e.rank!==void 0,Yg=e=>e.visibleRole!==void 0,zg=e=>e.color!==void 0,qg=e=>{const t=e.info;return Vg(t)?t.rank:0},Wg=e=>{const t=e.info;return zg(t)?t.color:"orange"},Zg=e=>{const t=e.info;return Yg(t)?t.visibleRole:"TECHNICIAN"},{URL:pr}=q(),{getAll:Jg,postModel:Qa}=V.build({basePath:`${pr}/api/kos/troubles`}),Xa=async()=>await Jg({}),ec=async(e,t)=>{try{const s=await Qa({model:{},urlOverride:`${pr}/api/kos/troubles/resolve/${e}`,tracker:t});return s!=null&&s.data&&De.initiateFuture(s.data),s.data}catch{const o={id:t||"",endState:Ge.Fail,tracker:t,reason:"Failed to resolve trouble"};return De.initiateFuture(o),o}},Qg=async(e,t)=>{try{const s=await Qa({model:e,urlOverride:`${pr}/api/kos/troubles/resolve/`,tracker:t});return s!=null&&s.data&&De.initiateFuture(s.data),s.data}catch{const o={id:t||"",endState:Ge.Fail,tracker:t,reason:"Failed to resolve troubles"};return De.initiateFuture(o),o}},Xg=Object.freeze(Object.defineProperty({__proto__:null,bulkResolveTroubles:Qg,getTroubles:Xa,resolveTrouble:ec},Symbol.toStringTag,{value:"Module"})),Ms="troubleDataMapper",ts=new Map;Yo(Ms,{register:(e,t)=>{var s;ts.has(e)||ts.set(e,[]),(s=ts.get(e))==null||s.push(t)},execute:async(e,t)=>{const s=ts.get(e);if(!s)return{...t.data};const o=s.map(i=>i(t));return(await Promise.allSettled(o)).reduce((i,c)=>(c.status==="fulfilled"?i={...i,...c.value}:f.info(`Trouble mapper ${e} failed: ${c.reason}`),i),{...t.data})}});const Wt="troubleMapper",ss=new Map;Yo(Wt,{register:(e,t)=>{var s;ss.has(e)||ss.set(e,[]),(s=ss.get(e))==null||s.push(t)},execute:async(e,t)=>{const s=ss.get(e);if(!s)return[];const o=s.map(i=>i(t)),n=(await Promise.allSettled(o)).map(i=>i.status==="fulfilled"?i.value:(f.info(`Trouble mapper ${e} failed: ${i.reason}`),[])).flat();return Array.from(new Set(n))}});C[Wt].register("nozzle",async e=>[e.data.nozzlePath]);C[Wt].register("path",async e=>[e.data.path]);const ef=async e=>{const t=new Set,s=e.ifaces,o=s==null?void 0:s.map(n=>C[Wt].execute(n,e));return(await Promise.allSettled(o)).forEach(n=>{n.status==="fulfilled"&&n.value.forEach(i=>t.add(i))}),Array.from(t)},tc=async e=>{const t=e.ifaces,s=t==null?void 0:t.map(i=>C[Ms].execute(i,e)),o=C[Ms].execute(e.type,e);s.push(o);const n=(await Promise.allSettled(s)).reduce((i,c)=>(c.status==="fulfilled"&&(i={...i,...c.value}),i),{});return{...e.data,...n}};class tf{constructor(){a(this,"type","ResolvableTrouble");a(this,"title","Resolvable Trouble");a(this,"subtitle","Trouble")}}class sf{constructor(){a(this,"type","BlockPumpTrouble");a(this,"title","Block Pump Trouble");a(this,"subtitle","Trouble")}}class xe{static getHandler(t){switch(t){case"ResolvableTrouble":return new tf;case"BlockPumpTrouble":return new sf;default:return}}}var of=Object.defineProperty,rf=Object.getOwnPropertyDescriptor,sc=(e,t,s,o)=>{for(var r=o>1?void 0:o?rf(t,s):t,n=e.length-1,i;n>=0;n--)(i=e[n])&&(r=(o?i(t,s,r):i(r))||r);return o&&r&&of(t,s,r),r};const lt="trouble-model";function os(e){return typeof e.shouldDefer=="boolean"}let _s=class{constructor(e,{resolvable:t,tags:s,info:o,id:r,clientData:n,rank:i,ifaces:c,type:d,group:l,createTime:u,role:h,color:p,...w},b){a(this,"id");a(this,"logger");a(this,"_troubleId");a(this,"_resolvable");a(this,"type");a(this,"futureHandler");a(this,"ifaces");a(this,"clientData");a(this,"info");a(this,"role");a(this,"color");a(this,"tags");a(this,"data");a(this,"rank");a(this,"group");a(this,"createTime");a(this,"_mapped",{});this.id=e,this.logger=b.logger,this.type=d,this._troubleId=r,this._resolvable=!!t,this.ifaces=c,this.rank=i,this.role=h,this.color=p,this.tags=s,this.info=o,this.group=l,this.createTime=u,this.clientData=n,this.data={},Object.assign(this.data,w),this.futureHandler=new ar(this)}getTitleWithContext(e){var s,o;const t=e?(o=(s=xe.getHandler(this.type))==null?void 0:s.context)==null?void 0:o[e]:xe.getHandler(this.type);return(t==null?void 0:t.title)||"Trouble"}getSubtitleWithContext(e){var s,o;const t=e?(o=(s=xe.getHandler(this.type))==null?void 0:s.context)==null?void 0:o[e]:xe.getHandler(this.type);return(t==null?void 0:t.subtitle)||"Trouble"}get rawId(){return this._troubleId}get title(){var e;return((e=xe.getHandler(this.type))==null?void 0:e.title)||"Trouble"}get subtitle(){var e;return((e=xe.getHandler(this.type))==null?void 0:e.subtitle)||"Trouble"}get troubleId(){return this._troubleId}get resolvable(){return this._resolvable}get future(){return this.futureHandler.future}async resolveMappedData(){return await tc(this)}get deferredCompanion(){const e=wo(this.id,t=>os(t));if(e&&os(e.modelData))return e.modelData}get deferred(){return this.deferredCompanion?this.deferredCompanion.deferred:!1}get shouldDefer(){const e=wo(this.id,t=>os(t));return e&&os(e.modelData)?e.modelData.shouldDefer:!1}clearDefer(){var e;(e=this.deferredCompanion)==null||e.clearDefer()}defer(){var e;(e=this.deferredCompanion)==null||e.defer()}getChildren(){return[...this.futureHandler.allFutures]}async resolve(e){var t;if(!this._resolvable)throw this.logger.error(`attempting to resolve an unresolvable trouble with id ${this._troubleId}`),new Error("Trouble is not resolvable");if(this.shouldDefer){(t=this.deferredCompanion)==null||t.defer();return}return await ec(this._troubleId,e)}};sc([Ar()],_s.prototype,"resolve",1);_s=sc([O(lt)],_s);const xt={registration:{[lt]:{class:_s,singleton:!1}},type:lt,predicate:te(lt),factory:H.Factory.create(lt)};var nf=Object.defineProperty,af=Object.getOwnPropertyDescriptor,Vs=(e,t,s,o)=>{for(var r=o>1?void 0:o?af(t,s):t,n=e.length-1,i;n>=0;n--)(i=e[n])&&(r=(o?i(t,s,r):i(r))||r);return o&&r&&nf(t,s,r),r};const nn=f.createLogger({name:"trouble-container-model"});function an(e){return C.propertyMapper.hasMapper(re.TroubleRank)?C.propertyMapper.executeMapper(re.TroubleRank,e):qg(e)}function cn(e){return(C.propertyMapper.hasMapper(re.TroubleColor)?C.propertyMapper.executeMapper(re.TroubleColor,e):Wg(e)).toLowerCase()}function dn(e){return(C.propertyMapper.hasMapper(re.TroubleRole)?C.propertyMapper.executeMapper(re.TroubleRole,e):Zg(e)).toLowerCase()}const cf="trouble-container-model";class X{}a(X,"INDEX_TROUBLES_BY_IFACE","byIface"),a(X,"INDEX_TROUBLES_BY_TYPE","byType"),a(X,"INDEX_TROUBLES_BY_GROUP","byGroup"),a(X,"INDEX_TROUBLES_BY_DEFERRED","byDeferred"),a(X,"SORT_KEY_RANK","rank"),a(X,"TROUBLES_DEFERRED","true");let Ve=class{constructor(e){a(this,"id");a(this,"troubles");this.id=e,this.troubles=new le({indexMap:{[X.INDEX_TROUBLES_BY_IFACE]:ef,[X.INDEX_TROUBLES_BY_TYPE]:"type",[X.INDEX_TROUBLES_BY_GROUP]:"group",[X.INDEX_TROUBLES_BY_DEFERRED]:"deferred"},sortKey:X.SORT_KEY_RANK,parentId:e})}async load(){nn.debug("loading trouble container");const e=await Xa();try{e==null||e.data.forEach(t=>{const s={...t,rank:an(t),color:cn(t),role:dn(t),id:String(t.id)},o=xt.factory(`trouble-${t.id}`)(s);this.troubles.addModel(o)})}catch(t){throw nn.error(t),t}}handleTroubleRemoved(e){const t=`trouble-${e}`,s=this.troubles.getModel(t);this.troubles.removeModel(t),s&&Oe(s)}handleTroubleAdded(e){const t={...e,rank:an(e),color:cn(e),role:dn(e),id:String(e.id)};if(t.role==="NONE")return;const s=xt.factory(`trouble-${e.id}`)(t);this.troubles.addModel(s)}};Vs([ie],Ve.prototype,"troubles",2);Vs([R({topic:"/kos/trouble/remove",websocket:!0,lifecycle:x.INIT})],Ve.prototype,"handleTroubleRemoved",1);Vs([R({topic:"/kos/trouble/add",websocket:!0})],Ve.prototype,"handleTroubleAdded",1);Ve=Vs([O(cf)],Ve);const rs="trouble-container-model",Ye={registration:{[rs]:{class:Ve,singleton:!0}},type:rs,predicate:te(rs),factory:H.Singleton.create(rs)},{URL:oc}=q(),{getAll:df}=V.build({basePath:`${oc}/api/kos/ota`}),ln=f.createLogger({name:"ota-service",group:"Services"}),lf=async()=>{ln.debug("sending GET request to /api/kos/ota/artifacts");const e=await df({urlOverride:`${oc}/api/kos/ota/artifacts`});return ln.debug("getArtifacts - response:",e),e==null?void 0:e.data};var uf=Object.defineProperty,hf=Object.getOwnPropertyDescriptor,Ys=(e,t,s,o)=>{for(var r=o>1?void 0:o?hf(t,s):t,n=e.length-1,i;n>=0;n--)(i=e[n])&&(r=(o?i(t,s,r):i(r))||r);return o&&r&&uf(t,s,r),r};const rc="ota-model",gf=e=>{let t=null;for(const s in e){const o=e[s],r=o.lastUpdateTime;(!t||t.lastUpdateTime<r)&&(t=o)}return t},lo=e=>{const t=e.artifactInfo,s=gf(e.requests),o=(t==null?void 0:t.identifier)||(s==null?void 0:s.kabId);if(!o)return;let r;switch(e.status){case"INSTALLED":r="ready";break;case"INVALID":r="error";break;case"MISSING":r=((s==null?void 0:s.currentSize)||0)>0?"downloading":"idle";break;case"STAGED":r="pending"}const n=t===void 0;return{id:o,manifest:n,label:t==null?void 0:t.version,name:t==null?void 0:t.name,status:r,error:r==="error"?s==null?void 0:s.lastErrorReason:void 0,errorCount:r==="error"?s==null?void 0:s.errorCount:0,progress:r==="downloading"&&s&&!n?s.currentSize/(t==null?void 0:t.size)*100:void 0,size:t==null?void 0:t.size}};let ze=class{constructor(e,t,s){a(this,"id");a(this,"logger");a(this,"data",new Ji);a(this,"troubleContainer");this.id=e,this.logger=s.logger}get downloadInProgressTrouble(){var t;return(t=this.troubleContainer.troubles.getIndexByKey("byType","OTADownloadInProgressTrouble"))==null?void 0:t[0]}get updatePendingTrouble(){var t;return(t=this.troubleContainer.troubles.getIndexByKey("byType","OTAUpdatePendingTrouble"))==null?void 0:t[0]}get pausedDueToErrorsTrouble(){var t;return(t=this.troubleContainer.troubles.getIndexByKey("byType","OTAPausedDueToErrorsTrouble"))==null?void 0:t[0]}get updates(){return this.data}get status(){return this.pausedDueToErrorsTrouble?"error":this.downloadInProgressTrouble?"downloading":this.updatePendingTrouble?"pending":"idle"}installAndReboot(){var e;this.updatePendingTrouble||this.logger.error("installAndReboot - OTAUpdatePendingTrouble not present"),this.logger.debug("installAndReboot - resolve OTAUpdatePendingTrouble"),(e=this.updatePendingTrouble)==null||e.resolve()}async init(){this.logger.debug(`initializing ota ${this.id}`)}async load(){this.logger.debug(`loading ota ${this.id}`);try{const e=await lf();e&&e.forEach(t=>{const s=lo(t);s&&this.data.addModel(s)})}catch(e){this.logger.error(`loading ota ${this.id} - error:`,e)}}async handleAllArtifacts(e){this.logger.debug("handleAllArtifacts:",e),await this.data.clear();try{e.forEach(t=>{const s=lo(t);s&&this.data.addModel(s)})}catch(t){this.logger.error(`handleAllArtifacts ${this.id} - error:`,t)}}handleChangedArtifacts(e){this.logger.debug("handleChangedArtifacts:",e);try{e.forEach(t=>{const s=lo(t);s&&this.data.updateModel(s)})}catch(t){this.logger.error(`handleChangedArtifacts ${this.id} - error:`,t)}}};Ys([Ae({modelType:Ye.type})],ze.prototype,"troubleContainer",2);Ys([R({topic:"/kos/ota/artifacts/all",websocket:!0})],ze.prototype,"handleAllArtifacts",1);Ys([R({topic:"/kos/ota/artifacts/changed",websocket:!0})],ze.prototype,"handleChangedArtifacts",1);ze=Ys([O(rc)],ze);const Es=new pe({class:ze,type:rc}),un=f.createLogger({name:"software-info-service",group:"Services"}),nc=async()=>{un.debug("sending GET for software-info");const[e,t]=await Ia.get("/api/kos/manifest/info");if(!t)throw un.error("Failed to fetch software-info",e),new ce("Failed to fetch software-info");return t},ff=Object.freeze(Object.defineProperty({__proto__:null,getSoftwareInfos:nc},Symbol.toStringTag,{value:"Module"}));var pf=Object.defineProperty,mf=Object.getOwnPropertyDescriptor,yf=(e,t,s,o)=>{for(var r=o>1?void 0:o?mf(t,s):t,n=e.length-1,i;n>=0;n--)(i=e[n])&&(r=(o?i(t,s,r):i(r))||r);return o&&r&&pf(t,s,r),r};const ut="software-info-model";let Io=class{constructor(e,t,s){a(this,"id");a(this,"logger");a(this,"nodes");this.id=e,this.logger=s.logger,this.nodes=[]}async init(){this.logger.debug(`initializing software-info ${this.id}`)}groupBy(e,t){return e.reduce((s,o)=>(s[o[t]]=[...s[o[t]]||[],o],s),{})}async load(){this.logger.debug(`loading software-info ${this.id}`);try{const e=await nc(),t=(e==null?void 0:e.nodes)||{};Y(()=>{const o=Object.keys(t).map(r=>t[r][0]).map(r=>({nodeName:r.node,group:this.groupBy(r.artifacts,"group")}));this.nodes=o})}catch(e){e instanceof ce&&this.logger.error("Failed to fetch software-info",e)}}};Io=yf([O(ut)],Io);const Is={registration:{[ut]:{class:Io,singleton:!1}},type:ut,predicate:te(ut),factory:H.Factory.create(ut)},{URL:ic}=q(),{getOne:bf}=V.build({basePath:`${ic}/api/kos/state`}),vf=f.createLogger({name:"state-bean-service",group:"Services"}),ac=async({path:e})=>(vf.debug("sending GET for state-bean"),await bf({urlOverride:`${ic}/api/kos/state/${e}`})),wf=Object.freeze(Object.defineProperty({__proto__:null,getStateBeanData:ac},Symbol.toStringTag,{value:"Module"}));var Mf=Object.defineProperty,_f=Object.getOwnPropertyDescriptor,cc=(e,t,s,o)=>{for(var r=o>1?void 0:o?_f(t,s):t,n=e.length-1,i;n>=0;n--)(i=e[n])&&(r=(o?i(t,s,r):i(r))||r);return o&&r&&Mf(t,s,r),r};const ht="state-bean-model",Ef=Se("path");let Ts=class{constructor(e,t,s){a(this,"id");a(this,"path");a(this,"props");a(this,"logger");this.id=e,this.logger=s.logger,this.props=er.map(new Map),po(t,this)}updateModel(e){po(e,this)}handleConfigBeanUpdated(e){Object.entries(e).forEach(([t,s])=>{let o=s;typeof o=="string"&&or(o)&&(o=o.toLowerCase()=="true"),typeof o=="string"&&Us(o)&&(o=Number(o)),this.props.set(t,o)})}async init(){this.logger.debug(`initializing state-bean ${this.id}`)}updateProps(e){Object.entries(e).forEach(([t,s])=>{this.props.set(t,s)})}async load(){this.logger.debug(`loading state-bean ${this.id}`);const e=await ac({path:this.path});e!=null&&e.data&&this.updateProps(e.data)}};cc([R({topic:`/kos/state/${Ef}`,websocket:!0})],Ts.prototype,"handleConfigBeanUpdated",1);Ts=cc([O(ht)],Ts);const Ft={registration:{[ht]:{class:Ts,singleton:!1}},type:ht,predicate:te(ht),factory:H.Factory.create(ht)};var If=Object.defineProperty,Tf=Object.getOwnPropertyDescriptor,dc=(e,t,s,o)=>{for(var r=o>1?void 0:o?Tf(t,s):t,n=e.length-1,i;n>=0;n--)(i=e[n])&&(r=(o?i(t,s,r):i(r))||r);return o&&r&&If(t,s,r),r};const gt="state-prop-model",hn=Se("path");let $s=class{constructor(e,t,s){a(this,"id");a(this,"path");a(this,"attribute");a(this,"logger");a(this,"stateBean");this.id=e,this.logger=s.logger,this.path=t.path,this.attribute=t.attribute}get value(){return this.stateBean.props.get(this.attribute)}async init(){this.logger.debug(`initializing state-prop ${this.id}`)}async load(){this.logger.debug(`loading state-prop ${this.id}`)}toString(){var e;return((e=this.value)==null?void 0:e.toString())??""}};dc([Ae({modelType:Ft.type,id:`state-bean-${hn}`,options:{path:hn}})],$s.prototype,"stateBean",2);$s=dc([O(gt)],$s);const mr={registration:{[gt]:{class:$s,singleton:!1}},type:gt,predicate:te(gt),factory:H.Factory.create(gt)},{URL:$f}=q(),{getAll:Of}=V.build({basePath:`${$f}/api/state-prop`}),Df=f.createLogger({name:"state-prop-service",group:"Services"}),Sf=async()=>(Df.debug("sending GET for state-prop"),await Of({})),Af=Object.freeze(Object.defineProperty({__proto__:null,getStateProps:Sf},Symbol.toStringTag,{value:"Module"})),{URL:yr}=q(),{getOne:lc}=V.build({basePath:`${yr}/api/translation`}),St=f.createLogger({name:"translation-service",group:"Services"}),Cf=()=>{const e=window.location.origin,t=ee();return(t==null?void 0:t.host)||e},uc=async(e,t)=>{St.debug("sending GET for translation");const s=t??Cf();try{const o=await fetch(`${s}${e}`);return o.status!==200?(St.warn(`Failed to fetch translations at ${e}: ${o.status}`),{}):await o.json()}catch(o){throw St.error("Error fetching translations",o),o}},Rf=async()=>{St.debug("getting localization descriptor");const e=await lc({urlOverride:`${yr}/api/system/kos/localization`});if((e==null?void 0:e.status)!==200)throw new Error(`Failed to get tool localization descriptor ${e==null?void 0:e.status}`);return e.data},hc=e=>async()=>{St.debug("getting kos localization descriptor");const t=await lc({urlOverride:`${yr}/api/kos/localization/contexts`});if((t==null?void 0:t.status)!==200)throw new Error(`Failed to get tool localization descriptor ${t==null?void 0:t.status}`);return t.data[e]},gc="langResolver";var Lf=Object.defineProperty,Pf=Object.getOwnPropertyDescriptor,kf=(e,t,s,o)=>{for(var r=o>1?void 0:o?Pf(t,s):t,n=e.length-1,i;n>=0;n--)(i=e[n])&&(r=(o?i(t,s,r):i(r))||r);return o&&r&&Lf(t,s,r),r};const ft="translation-model";function xf(e){const t=typeof e=="string",s=t?!1:!!(e!=null&&e.data)&&typeof(e==null?void 0:e.data)!="string",o=t?e:e==null?void 0:e.defaultValue,r=t||e==null?void 0:e.context,n=t?void 0:s?e==null?void 0:e.data:e;return{isBasicOptions:t,defaultValue:o,context:r,data:n}}function fc(e,t=""){return Object.keys(e).reduce((s,o)=>{const r=t?`${t}.${o}`:o;if(typeof e[o]=="object"&&e[o]!==null){const n=fc(e[o],r);return{...s,...n}}else return{...s,[r]:e[o]}},{})}function pc(e,t){const s={...e};for(const o in t)Object.prototype.hasOwnProperty.call(t,o)&&(typeof t[o]=="object"&&t[o]!==null&&typeof e[o]=="object"&&e[o]!==null?s[o]=pc(e[o],t[o]):s[o]=t[o]);return s}const To=(e,t)=>{const s=/__(.*?)__/g,o=e.replace(s,(r,n)=>Object.prototype.hasOwnProperty.call(t||{},n.trim())?t==null?void 0:t[n.trim()]:r);return o===e?o:s.test(o)?To(o,t):o},ns=(e,t,s)=>{const o=/{{(.*?)}}/g,n=To(e,t).replace(o,(c,d)=>Object.prototype.hasOwnProperty.call(s||{},d.trim())?s==null?void 0:s[d.trim()]:c);return To(n,t)},gn=(e,t)=>{if(t.includes(":")){const[s,o]=t.split(":");return{namespace:s,key:o}}else return{namespace:e,key:t}};let $o=class{constructor(e,t,s){a(this,"id");a(this,"namespace");a(this,"descriptor");a(this,"defaultLocale");a(this,"currentLocale");a(this,"bundleResolver");a(this,"data");a(this,"logger");a(this,"resolver");a(this,"disposer");a(this,"context");a(this,"rootUrl");this.id=e,this.defaultLocale=t.defaultLocale||"en",this.currentLocale=t.currentLocale||"en",this.namespace=t.namespace,this.descriptor=t.descriptor,this.rootUrl=t.rootUrl,this.data={},this.resolver=t.resolver||s.kosContext.get(gc),this.bundleResolver=t.bundleResolver,this.logger=s.logger,this.context=s.kosContext.parentModel}getTranslationLocales(e){const t=this.descriptor[e];if(!e||!t)return[this.defaultLocale];if(!this.defaultLocale&&!t.fallbacks)return[e];let s=t.fallbacks||[this.defaultLocale];return s.includes(e)||(s=[e,...s]),s}async loadTranslations(){const e=this.getTranslationLocales(this.currentLocale).reverse(),t=e.map(o=>{if(this.bundleResolver){const r=k.getContext(this.id);return this.bundleResolver(this.namespace,o,r)}try{const r=this.resolver(this.namespace,o);return uc(r,this.rootUrl)}catch{return Promise.resolve({})}}),s=await Promise.allSettled(t);Y(()=>{const o=s.reduce((r,n,i)=>(n.status==="fulfilled"?(this.logger.debug(`resolved ${e[i]}`,n.value),n.value&&(r=pc(r,n.value))):this.logger.error(`failed to load translation ${this.id} for ${e[i]}`),r),{});this.data=fc(o)})}async init(){this.logger.debug(`initializing translation ${this.id}`)}exists(e){const{namespace:t,key:s}=gn(this.namespace,e);if(t!==this.namespace){const o=this.context.getModel(t);return o?o.exists(s):!1}return!!this.data[s]}resolveKey(e,t){if(!e)return this.logger.debug("key is empty"),"";const{defaultValue:s,context:o,data:r}=xf(t),{namespace:n,key:i}=gn(this.namespace,e),c=`${i}_${o}`;if(n!==this.namespace){const d=this.context.getModel(n);return d?d.resolveKey(i,t):i}if(o&&this.data[c]){const d=this.data[c];return Array.isArray(d)?d.map(l=>ns(l,this.data,r)):ns(this.data[c],this.data,r)}if(this.data[i]){const d=this.data[c];return Array.isArray(d)?d.map(l=>ns(l,this.data,r)):ns(this.data[i],this.data,r)}return s??i}unload(){this.logger.debug(`unloading translation ${this.id}`),this.disposer&&this.disposer()}async load(){this.logger.debug(`loading translation ${this.id}`),await this.loadTranslations()}async ready(){this.logger.debug(`ready translation ${this.id}`),this.disposer=v.reaction(()=>this.currentLocale,(e,t)=>{this.logger.info(`translation langs for namespace ${this.id} changed from ${t} to ${e}`),this.loadTranslations()})}};$o=kf([Ns(),O(ft)],$o);const Os={registration:{[ft]:{class:$o,singleton:!1}},type:ft,predicate:te(ft),factory:H.Factory.create(ft)};var Ff=Object.defineProperty,Nf=Object.getOwnPropertyDescriptor,mc=(e,t,s,o)=>{for(var r=o>1?void 0:o?Nf(t,s):t,n=e.length-1,i;n>=0;n--)(i=e[n])&&(r=(o?i(t,s,r):i(r))||r);return o&&r&&Ff(t,s,r),r};const pt="translation-container-model",Uf=(e,t="/")=>e.join(t).replace(new RegExp(t+"{1,}","g"),t);function jf(e,t){const s=this.descriptor.namespaces[e];if(!s)throw new Error(`namespace ${e} not found in descriptor`);const o=s.basePath,r=s.locales[t].file;return Uf([o,r])}let Ds=class{constructor(e,t,s){a(this,"id");a(this,"lang");a(this,"rootUrl");a(this,"descriptor");a(this,"_defaultNamespace");a(this,"resolver");a(this,"logger");a(this,"descriptorUrl");a(this,"namespaces",[]);a(this,"_models");this.id=e,this.lang=t.lang||"en",this.descriptor=t.descriptor,this._defaultNamespace=t.defaultNamespace,this.descriptorUrl=t.descriptorUrl,this.rootUrl=t.rootUrl,this.resolver=t.resolver||jf.bind(this),s.kosContext.set(gc,this.resolver),this.logger=s.logger,this._models=new le({parentId:e})}set currentLocale(e){this.lang=e,this.models.data.forEach(t=>{t.currentLocale=e})}get defaultNamespace(){return this._defaultNamespace?this.getModel(`translation-${this._defaultNamespace}`):void 0}getModel(e){return this.logger.debug(`getting model ${e}`),this._models.getModel(`translation-${e}`)}get models(){return this._models}get data(){return this._models.data}async reload(){this._models.clear(),await xi(this);for(const e of this.namespaces){const t=this.resolveNamespace(e);await J(t)}}resolveNamespace(e){var s;if((s=this.descriptor.namespaces)==null?void 0:s[e]){const o=Object.keys(this.descriptor.namespaces[e].locales)[0],r=this.descriptor.namespaces[e].locales[o].defaultLocale,n=Os.factory(`translation-${e}`)({kosParentId:this.id,namespace:e,rootUrl:this.rootUrl,currentLocale:this.lang,defaultLocale:r,descriptor:this.descriptor.namespaces[e].locales,resolver:this.resolver});return this.addModel(n),this.namespaces.includes(e)||Y(()=>{this.namespaces.push(e)}),n}else{this.logger.warn(`namespace ${e} not found in descriptor`);const o=Os.factory(`translation-${e}`)({kosParentId:this.id,namespace:e,rootUrl:this.rootUrl,currentLocale:this.lang,defaultLocale:this.lang,descriptor:{},resolver:this.resolver});return this.addModel(o),o}}addModel(e){this._models.addModel(e)}removeModel(e){this._models.removeModel(e)}async init(){this.logger.debug(`initializing translation-container container ${this.id}`)}async load(){this.logger.debug(`loading translation-container container ${this.id}`)}};mc([ie],Ds.prototype,"_models",2);Ds=mc([O(pt)],Ds);const ge={registration:{[pt]:{class:Ds,singleton:!0}},type:pt,predicate:te(pt),factory:H.Singleton.create(pt)},Bf={set(e,t){const s=k.getContext(ge.type);s&&s.set(e,t)},get(e){const t=k.getContext(ge.type);return t==null?void 0:t.get(e)}},yc={async init(e){const t=ge.factory(e);return await J(t),{translations:t}}},Kf=(e,t)=>{const s=t.type;return e[s]||(e[s]=[]),e[s].push(t),e},bc="kos-ws-event",br=et(bc);var Gf=Object.defineProperty,Hf=Object.getOwnPropertyDescriptor,vr=(e,t,s,o)=>{for(var r=o>1?void 0:o?Hf(t,s):t,n=e.length-1,i;n>=0;n--)(i=e[n])&&(r=(o?i(t,s,r):i(r))||r);return o&&r&&Gf(t,s,r),r};const Vf=({headers:e,body:t})=>Object.entries(e).map(([o,r])=>`${o}:${r}`).join("\\n")+"\\n\\n"+t;exports.WsEventModel=class{constructor(t){a(this,"id");a(this,"events");a(this,"_topicMap");this.id=t,this.events=v.observable.map(new Map),this._topicMap=new Map}get websocketEvents(){return Array.from(this.events.values())}handleSendEvent(t,s){this.processEvent(s,!0)}handleReceiveEvent(t,s){this.processEvent(s)}processEvent(t,s=!1){f.debug("kos event received");const{body:o,headers:r}=t.body,n=r["request-id"]||r["response-id"],i=r["request-id"]||r["response-id"]||r.topic||r.type;if(i){let c=i;if(n)c=`${c}-${s?"send":"receive"}`;else{const l=this._topicMap.get(i)||0;c=`${c}-${l+1}`,this._topicMap.set(i,l+1)}const d={msgId:c,content:o,headers:r,timestamp:Date.now(),raw:Vf({headers:r,body:o}),direction:s?"send":"receive",mocked:!!r.mocked};this.events.set(c,d),f.debug(`logged ${this.events.size} events`)}}};vr([R({topic:[Gt.SEND]})],exports.WsEventModel.prototype,"handleSendEvent",1);vr([R({topic:[Gt.RECEIVED]})],exports.WsEventModel.prototype,"handleReceiveEvent",1);exports.WsEventModel=vr([O(br.type)],exports.WsEventModel);const fn=ee(),Yf=fn.debug==="true"||fn.debug===!0,zf="/api/system/canvas",vc=async(e,t)=>{const s=t||zf,o=`${exports.BASE_URL}${s}`;await exports.kosFetch(o,{method:"POST",headers:{hide:Yf?"true":"false"},body:e})},qf=Object.freeze(Object.defineProperty({__proto__:null,sendCanvasData:vc},Symbol.toStringTag,{value:"Module"})),Wf=(e,t,s)=>e>>5<<5|t>>5<<2|s>>6;function Zf(e,t,s){if(t==="base64"){const o=s?e.filter((r,n)=>n%4!==3):Array.from(e);return btoa(String.fromCharCode(...o))}else{const o=[];for(let r=0;r<e.length;r+=4)o.push(Wf(e[r],e[r+1],e[r+2]));return String.fromCharCode(...o)}}var Jf=Object.defineProperty,Qf=Object.getOwnPropertyDescriptor,wc=(e,t,s,o)=>{for(var r=o>1?void 0:o?Qf(t,s):t,n=e.length-1,i;n>=0;n--)(i=e[n])&&(r=(o?i(t,s,r):i(r))||r);return o&&r&&Jf(t,s,r),r};const Mc="canvas-renderer-model";function uo(e){return typeof e.onDone=="function"}let Ss=class{constructor(e,t,s){a(this,"id");a(this,"router");a(this,"logger");a(this,"_renderer",null);a(this,"isStreaming",!1);a(this,"renderLoopId",null);a(this,"sendIntervalId",null);a(this,"timeoutId",null);a(this,"apiPath");a(this,"endpointName");a(this,"width",50);a(this,"height",30);a(this,"fps",10);a(this,"durationMs",null);a(this,"_onFrame",null);this.id=e,this.logger=s.logger,this.width=t.width??50,this.height=t.height??30,this.fps=t.fps??10,this.durationMs=t.durationMs??null,this.apiPath=t.apiPath??"/api/system/canvas",this.endpointName=t.endpoint}set onFrame(e){this._onFrame=e}set renderer(e){var t,s;this._renderer&&(this.stopStreaming(),(s=(t=this._renderer).dispose)==null||s.call(t)),this._renderer=e,this.isStreaming&&this.startStreaming()}sendDataFrame(e,t){vc(e,t)}checkOneShot(){var t,s;if(uo(this._renderer)&&((s=(t=this._renderer).isOneShot)==null?void 0:s.call(t))===!0&&this._renderer.isOneShotDone){requestAnimationFrame(()=>{this.stopStreaming()});return}}handleFrame(e){var s;const t=Zf(e,"base64",!0);this.sendDataFrame(t,this.apiPath),(s=this._onFrame)==null||s.call(this,t)}stopStreaming(){var e,t;this.isStreaming=!1,this.renderLoopId&&cancelAnimationFrame(this.renderLoopId),this.sendIntervalId&&clearInterval(this.sendIntervalId),this.timeoutId&&clearTimeout(this.timeoutId),(t=(e=this._renderer)==null?void 0:e.pause)==null||t.call(e)}startStreaming(){var e,t,s,o,r,n;{if(!this._renderer)return;if(!this.apiPath){this.logger.error(`No endpoint configured for canvas renderer ${this.id}`);return}this.isStreaming=!0,this._renderer.reset(),(t=(e=this._renderer).play)==null||t.call(e);const i=uo(this._renderer);this._renderer.renderFrame(this.width,this.height);const c=(o=(s=this._renderer).readPixels)==null?void 0:o.call(s,this.width,this.height);if(c&&this._onFrame&&this.handleFrame(c),uo(this._renderer)&&((n=(r=this._renderer).isOneShot)==null?void 0:n.call(r))===!0&&this._renderer.isOneShotDone){requestAnimationFrame(()=>{this.stopStreaming()});return}const l=()=>{var u;(u=this._renderer)==null||u.renderFrame(this.width,this.height),this.renderLoopId=requestAnimationFrame(l)};this.renderLoopId=requestAnimationFrame(l),this.sendIntervalId=setInterval(()=>{var h,p;const u=(p=(h=this._renderer)==null?void 0:h.readPixels)==null?void 0:p.call(h,this.width,this.height);u&&this._onFrame&&(this.handleFrame(u),this.checkOneShot())},1e3/this.fps),!i&&this.durationMs!=null&&(this.timeoutId=setTimeout(()=>{this.stopStreaming()},this.durationMs))}}async init(){this.logger.debug(`initializing canvas-renderer ${this.id}`)}async load(){this.logger.debug(`loading canvas-renderer ${this.id}`),this.router.use("POST",`/api/ui/canvas/${this.endpointName}/stop`,async(e,t)=>{this.stopStreaming(),t.send({status:"OK"})}),this.router.use("POST",`/api/ui/canvas/${this.endpointName}/start`,async(e,t)=>{this.startStreaming(),t.send({status:"OK"})})}};wc([Ae({modelType:Ks.type})],Ss.prototype,"router",2);Ss=wc([O(Mc)],Ss);const wr=new ae({class:Ss,type:Mc});class Xf{constructor(t){a(this,"video");a(this,"canvas");a(this,"ctx");a(this,"lastUpdate",0);a(this,"doneCallback",null);this.video=document.createElement("video"),this.video.src=t,this.video.crossOrigin="anonymous",this.video.muted=!0,this.video.loop=!1,this.canvas=document.createElement("canvas");const s=this.canvas.getContext("2d");if(!s)throw new Error("2D canvas not supported");this.ctx=s,this.handleEnded=this.handleEnded.bind(this),this.video.addEventListener("ended",this.handleEnded)}handleEnded(){this.doneCallback&&this.doneCallback()}reset(){this.video.pause(),this.video.currentTime=0,this.lastUpdate=performance.now()}play(){this.video.play().catch(console.warn)}pause(){this.video.pause()}renderFrame(t,s){this.canvas.width=t,this.canvas.height=s,this.video.readyState>=2&&this.ctx.drawImage(this.video,0,0,t,s)}readPixels(t,s){return this.ctx.getImageData(0,0,t,s).data}onDone(t){this.doneCallback=t}dispose(){this.video.pause(),this.video.removeAttribute("src"),this.video.load(),this.video.remove(),this.video.removeEventListener("ended",this.handleEnded),this.doneCallback=null}shouldStep(t){const s=performance.now();return s-this.lastUpdate>=t?(this.lastUpdate=s,!0):!1}}class _c{constructor(){a(this,"canvas");a(this,"ctx");a(this,"lastUpdate",0);this.canvas=document.createElement("canvas");const t=this.canvas.getContext("2d");if(!t)throw new Error("2D canvas not supported");this.ctx=t}dispose(){this.ctx.clearRect(0,0,this.canvas.width,this.canvas.height),this.canvas.remove()}shouldStep(t){const s=performance.now();return s-this.lastUpdate>=t?(this.lastUpdate=s,!0):!1}readPixels(t,s){return this.ctx.getImageData(0,0,t,s).data}}function Ec(e){class t extends e{constructor(){super(...arguments);a(this,"doneCallback",null);a(this,"oneShotDone",!1)}isOneShot(){return!0}onDone(r){this.doneCallback=r}signalDoneIfNeeded(){var r;this.oneShotDone||((r=this.doneCallback)==null||r.call(this),this.oneShotDone=!0)}resetOneShot(){this.doneCallback=null,this.oneShotDone=!1}get isOneShotDone(){return this.oneShotDone}}return t}const ep=Ec(_c);class tp extends ep{constructor(s){super();a(this,"img");a(this,"loaded",!1);this.img=new Image,this.img.src=s,this.img.crossOrigin="anonymous",this.img.onload=()=>{this.loaded=!0}}reset(){this.resetOneShot()}renderFrame(s,o){!this.loaded||this.isOneShotDone||(this.canvas.width=s,this.canvas.height=o,this.ctx.drawImage(this.img,0,0,s,o),this.signalDoneIfNeeded())}}const sp=Ec(_c);class pn extends sp{constructor(s=0,o=0,r=0){super();a(this,"color");this.color=`rgb(${s},${o},${r})`}setColor(s,o,r){this.color=`rgb(${s},${o},${r})`,this.resetOneShot()}reset(){this.resetOneShot()}renderFrame(s,o){this.isOneShotDone||(this.canvas.width=s,this.canvas.height=o,this.ctx.fillStyle=this.color,this.ctx.fillRect(0,0,s,o),this.signalDoneIfNeeded())}}const mn=({mode:e,data:t})=>{switch(e){case"color":{const{r:s,g:o,b:r}=t;return t?new pn(s,o,r):new pn(0,0,0)}case"image":return t?new tp(t.src):null;case"video":return t?new Xf(t.src):null;default:throw new Error(`Unknown mode: ${e}`)}};var op=Object.defineProperty,rp=Object.getOwnPropertyDescriptor,Mr=(e,t,s,o)=>{for(var r=o>1?void 0:o?rp(t,s):t,n=e.length-1,i;n>=0;n--)(i=e[n])&&(r=(o?i(t,s,r):i(r))||r);return o&&r&&op(t,s,r),r};const Ic="canvas-dispatcher-model";function np(e){if(e=e.replace(/^#/,""),e.length===3&&(e=e.split("").map(s=>s+s).join("")),e.length!==6)return null;const t=parseInt(e,16);return{r:t>>16&255,g:t>>8&255,b:t&255}}let Nt=class{constructor(e,t,s){a(this,"id");a(this,"logger");a(this,"_content",new Map);a(this,"_patterns",new Map);a(this,"_endpointRenderers");a(this,"router");a(this,"pattern");a(this,"data");this.id=e,this.logger=s.logger,this._endpointRenderers=new le}addNamedEndpoint(e,t){this._endpointRenderers.getModel(e)&&this.logger.warn(`Endpoint "${e}" already exists. Overwriting.`);const s=wr.instance(e).options({apiPath:t.apiPath,width:t.width,height:t.height,fps:t.fps,durationMs:t.durationMs??null,endpoint:e}).build();return this._endpointRenderers.addModel(s),s}addContent(e,t){this._content.has(e)&&this.logger.warn(`Content "${e}" already exists. Overwriting.`),this._content.set(e,t)}addPattern(e,t){this._patterns.has(e)&&this.logger.warn(`Pattern "${e}" already exists. Overwriting.`),this._patterns.set(e,t)}async load(e){var s;const t=e==null?void 0:e.get(qe.loader);t&&((s=t.patterns)==null||s.forEach(o=>{if(!o.id||!o.type||!o.data){this.logger.warn(`Invalid pattern data: ${JSON.stringify(o)}`);return}this.addPattern(o.id,o)})),this.router.use("POST","/api/ui/canvas/patterns",async(o,r)=>{var c,d;const n=o.body,i=Array.isArray(n)?n:[n];if(i.some(l=>!l.id||!l.type||!l.data)){(c=r.status)==null||c.call(r,400).send({error:"Invalid pattern data"});return}for(const l of i)this._patterns.has(l.id)&&this.logger.warn(`Pattern "${l.id}" already exists. Overwriting.`),this.addPattern(l.id,l);(d=r.status)==null||d.call(r,200).send({status:"OK"})}),this.router.use("POST","/api/ui/canvas/pattern/:endpoint/:pattern",async(o,r)=>{var u,h,p;const n=o.params.pattern,i=o.params.endpoint,c=this._endpointRenderers.getModel(i);if(!c){(u=r.status)==null||u.call(r,404).send({error:`Endpoint "${i}" not found`});return}if(!this._patterns.has(n)){(h=r.status)==null||h.call(r,404).send({error:`Pattern "${n}" not found`});return}const d=this._patterns.get(n),l=d.type;this.data=d.data,c.renderer=mn({mode:l,data:this.data}),c.startStreaming(),(p=r.status)==null||p.call(r,200).send({status:"OK"})}),this.router.use("POST","/api/ui/canvas/color/:endpoint/:color",async(o,r)=>{var p,w,b;const n=o.params.color,i=np(n);if(!i){(p=r.status)==null||p.call(r,400).send({error:"Invalid color format"});return}const c=o.params.endpoint,d=this._endpointRenderers.getModel(c);if(!d){(w=r.status)==null||w.call(r,404).send({error:`Endpoint "${c}" not found`});return}const{r:l,b:u,g:h}=i;d.renderer=mn({mode:"color",data:{r:l,g:h,b:u}}),d.startStreaming(),(b=r.status)==null||b.call(r,200).send({status:"OK"})}),this.router.use("POST","/api/ui/canvas/endpoint",async(o,r)=>{var i,c;const n=o.body;if(!n.apiPath||!n.id){(i=r.status)==null||i.call(r,400).send({error:"Name and path are required"});return}this.addNamedEndpoint(n.id,n),(c=r.status)==null||c.call(r,200).send({status:"OK"})})}};Mr([ie],Nt.prototype,"_endpointRenderers",2);Mr([Ae({modelType:Ks.type})],Nt.prototype,"router",2);Nt=Mr([O(Ic)],Nt);const qe=new pe({class:Nt,type:Ic}),{URL:_r}=q(),{getOne:Tc}=V.build({basePath:`${_r}/api/device`}),As=f.createLogger({name:"device-service",group:"Services"}),$c=async()=>{As.debug("sending GET for device serial number");try{const e=await Tc({urlOverride:`${_r}/api/kos/device/serialNumber`});return[void 0,e==null?void 0:e.data.serialNumber]}catch(e){if(e instanceof ce)return As.error(`Error fetching device serial number: ${e.payload.error}`),[e.payload.error,void 0]}return["unknownError",void 0]},Oc=async()=>{As.debug("sending GET for device details");try{const e=await Tc({urlOverride:`${_r}/api/kos/device`});return e?[void 0,e.data]:["unknownError",void 0]}catch(e){if(e instanceof ce)return As.error(`Error fetching device serial number: ${e.payload.error}`),[e.payload.error,void 0]}return["unknownError",void 0]},ip=Object.freeze(Object.defineProperty({__proto__:null,getDeviceDetails:Oc,getSerialNumber:$c},Symbol.toStringTag,{value:"Module"}));var ap=Object.defineProperty,cp=Object.getOwnPropertyDescriptor,Dc=(e,t,s,o)=>{for(var r=o>1?void 0:o?cp(t,s):t,n=e.length-1,i;n>=0;n--)(i=e[n])&&(r=(o?i(t,s,r):i(r))||r);return o&&r&&ap(t,s,r),r};const Sc="device-model",dp="/kos/criticalData/changed",lp="/kos/criticalData/available";let Cs=class{constructor(e,t,s){a(this,"id");a(this,"logger");a(this,"_serialNumber");a(this,"_name");a(this,"_nodeId");this.id=e,this.logger=s.logger,this._serialNumber="unassigned",this._name="unassigned",this._nodeId="unassigned"}get serialNumber(){return this._serialNumber}get name(){return this._name}get nodeId(){return this._nodeId}get nodeType(){const[e]=this.nodeId.split("-");return e}get nodeName(){const[,e]=this.nodeId.split("-");return e}updateModel(e){this._serialNumber=e.serialNumber??"unassigned",this._name=e.name??"unassigned",this._nodeId=e.nodeId??"unassigned"}async loadDeviceData(){const[e,t]=await Oc();if(e){this.logger.error(`Error fetching device serial number: ${e}`);return}if(t){const{name:s,nodeId:o}=t;this.updateModel({name:s,nodeId:o,serialNumber:this.serialNumber})}}async loadSerialNumber(){const[e,t]=await $c();if(e){this.logger.error(`Error fetching device serial number: ${e}`);return}this.updateModel({serialNumber:t,name:this.name,nodeId:this.nodeId})}async handleCriticalDataChanged(){this.logger.debug(`Critical data changed for device ${this.id}`),await this.loadSerialNumber()}async init(){this.logger.debug(`initializing device ${this.id}`)}async load(){this.logger.debug(`loading device ${this.id}`),await this.loadDeviceData(),await this.loadSerialNumber()}};Dc([R({topic:[dp,lp],websocket:!0})],Cs.prototype,"handleCriticalDataChanged",1);Cs=Dc([O(Sc)],Cs);const Rs=new pe({class:Cs,type:Sc});var up=Object.defineProperty,hp=Object.getOwnPropertyDescriptor,gp=(e,t,s,o)=>{for(var r=o>1?void 0:o?hp(t,s):t,n=e.length-1,i;n>=0;n--)(i=e[n])&&(r=(o?i(t,s,r):i(r))||r);return o&&r&&up(t,s,r),r};const Ac="network-interface-model";let Oo=class{constructor(e,t,s){a(this,"id");a(this,"name");a(this,"type");a(this,"nmdevicestate");a(this,"hwaddress");a(this,"mtu");a(this,"configured");a(this,"wifi");a(this,"ethernet");a(this,"ip4settings");a(this,"category");a(this,"logger");this.id=e,this.logger=s.logger,this.name=t.name,this.type=t.type,this.nmdevicestate=t.nmdevicestate,this.hwaddress=t.hwaddress,this.mtu=t.mtu,this.configured=t.configured,this.wifi=t.wifi,this.ethernet=t.ethernet,this.ip4settings=t.ip4settings,this.category=t.category}updateModel(e){this.name=e.name,this.type=e.type,this.nmdevicestate=e.nmdevicestate,this.hwaddress=e.hwaddress,this.mtu=e.mtu,this.configured=e.configured,this.wifi=e.wifi,this.ethernet=e.ethernet,this.ip4settings=e.ip4settings,this.category=e.category}async init(){this.logger.debug(`initializing network-interface ${this.id}`)}async load(){this.logger.debug(`loading network-interface ${this.id}`)}};Oo=gp([O(Ac)],Oo);const Er=new ae({class:Oo,type:Ac}),{URL:fp}=q(),{getAll:pp}=V.build({basePath:`${fp}/api/kos/network/interfaces`}),yn=f.createLogger({name:"network-interface-service",group:"Services"}),Cc=async()=>{yn.debug("sending GET for copy-logs");try{const e=await pp({});return[void 0,e==null?void 0:e.data]}catch(e){if(e instanceof ce)return yn.error(`Error fetching log file size: ${e.payload.error}`),[e.payload.error,void 0]}return["unknownError",void 0]},mp=Object.freeze(Object.defineProperty({__proto__:null,getNetworkInterfaces:Cc},Symbol.toStringTag,{value:"Module"}));var yp=Object.defineProperty,bp=Object.getOwnPropertyDescriptor,Rc=(e,t,s,o)=>{for(var r=o>1?void 0:o?bp(t,s):t,n=e.length-1,i;n>=0;n--)(i=e[n])&&(r=(o?i(t,s,r):i(r))||r);return o&&r&&yp(t,s,r),r};const Lc="network-interface-container-model";let Ls=class{constructor(e,t,s){a(this,"id");a(this,"logger");a(this,"_models");this.id=e,this.logger=s.logger,this._models=new le({parentId:e,indexMap:{byCategory:"category"}})}getModel(e){return this._models.getModel(e)}get models(){return this._models}get data(){return this._models.data}addModel(e){this._models.addModel(e)}removeModel(e){this._models.removeModel(e)}async init(){this.logger.debug(`initializing network-interface-container container ${this.id}`)}async refreshInterfaces(){this.logger.debug("refreshing interfaces");const[e,t]=await Cc();if(e){this.logger.error(`Error loading network interfaces: ${e}`);return}t&&t.forEach(s=>{const o=Er.instance(s.name).forceUpdate.options(s).build();this.addModel(o)})}async load(){this.logger.debug(`loading network-interface-container container ${this.id}`),this.refreshInterfaces()}};Rc([ie],Ls.prototype,"_models",2);Ls=Rc([O(Lc)],Ls);const Ut=new pe({class:Ls,type:Lc});Ut.addRelatedModel(Er);const{URL:vp}=q(),{getAll:wp}=V.build({basePath:`${vp}/api/kos/storage/devices`}),bn=f.createLogger({name:"storage-device-service",group:"Services"}),Pc=async()=>{bn.debug("sending GET for storage-device");const e=await wp({});return!(e!=null&&e.data)||e.status!==200?(bn.error("Failed to retrieve storage-device data",e),[]):e.data},Mp=Object.freeze(Object.defineProperty({__proto__:null,getStorageDevices:Pc},Symbol.toStringTag,{value:"Module"}));var _p=Object.defineProperty,Ep=Object.getOwnPropertyDescriptor,Ip=(e,t,s,o)=>{for(var r=o>1?void 0:o?Ep(t,s):t,n=e.length-1,i;n>=0;n--)(i=e[n])&&(r=(o?i(t,s,r):i(r))||r);return o&&r&&_p(t,s,r),r};const kc="storage-device-model";let Do=class{constructor(e,t,s){a(this,"id");a(this,"mountDir");a(this,"removed");a(this,"vendor");a(this,"runTimeMs");a(this,"model");a(this,"nodeId");a(this,"local");a(this,"label");a(this,"syspath");a(this,"logger");this.id=e,this.logger=s.logger,this.mountDir=t.mountDir,this.removed=t.removed,this.vendor=t.vendor,this.runTimeMs=t.runTimeMs,this.model=t.model,this.nodeId=t.nodeId,this.local=t.local,this.label=t.label,this.syspath=t.syspath}updateModel(e){this.mountDir=e.mountDir,this.removed=e.removed,this.vendor=e.vendor,this.runTimeMs=e.runTimeMs,this.model=e.model,this.nodeId=e.nodeId,this.local=e.local,this.label=e.label,this.syspath=e.syspath}async init(){this.logger.debug(`initializing storage-device ${this.id}`)}async load(){this.logger.debug(`loading storage-device ${this.id}`)}};Do=Ip([Ns(),O(kc)],Do);const Ps=new ae({class:Do,type:kc});var Tp=Object.defineProperty,$p=Object.getOwnPropertyDescriptor,Ir=(e,t,s,o)=>{for(var r=o>1?void 0:o?$p(t,s):t,n=e.length-1,i;n>=0;n--)(i=e[n])&&(r=(o?i(t,s,r):i(r))||r);return o&&r&&Tp(t,s,r),r};const xc="storage-device-container-model",Op="/kos/storage";let jt=class{constructor(e,t,s){a(this,"id");a(this,"logger");a(this,"_models");this.id=e,this.logger=s.logger,this._models=new le({parentId:e})}getModel(e){return this._models.getModel(e)}get models(){return this._models}get data(){return this._models.data}addModel(e){this._models.addModel(e)}removeModel(e){this._models.removeModel(e)}async init(){this.logger.debug(`initializing storage-device-container container ${this.id}`)}get isStorageInserted(){return this.data.length>0}get volumes(){return this.data}handleStorageAvailability(e){this._models.data.filter(s=>!e.find(o=>o.id===s.id)).forEach(s=>{this.removeModel(s.id)}),e.forEach(s=>{const o=this.getModel(s.id);if(o){const r={...s,kosParentId:this.id};o.updateModel(r)}else{const r={...s,kosParentId:this.id},n=Ps.instance(s.id).options(r).build();this.addModel(n)}})}async load(){this.logger.debug(`loading storage-device-container container ${this.id}`),(await Pc()).forEach(t=>{const s={...t,kosParentId:this.id},o=Ps.instance(t.id).options(s).build();this.addModel(o)})}};Ir([ie],jt.prototype,"_models",2);Ir([R({topic:Op,websocket:!0})],jt.prototype,"handleStorageAvailability",1);jt=Ir([O(xc)],jt);const We=new pe({class:jt,type:xc});We.addRelatedModel(Ps);const{URL:Tr}=q(),{getAll:Dp,postModel:Sp}=V.build({basePath:`${Tr}/api/kos/update/available`}),vn=f.createLogger({name:"usb-update-service",group:"Services"}),Fc=async()=>{vn.debug("sending GET for usb-update");const e=await Dp({urlOverride:`${Tr}/api/kos/update/available`});return!(e!=null&&e.data)||(e==null?void 0:e.status)!==200?(vn.error("Failed to retrieve usb-update data",e),[]):e.data},Nc=async(e,t,s)=>{const o=await Sp({model:{manifestId:e,deviceId:t},tracker:s,urlOverride:`${Tr}/api/kos/update/install`});if(!(o!=null&&o.data))throw new Error("No response from server");return o.data},Ap=Object.freeze(Object.defineProperty({__proto__:null,getAvailableUpdates:Fc,installUpdate:Nc},Symbol.toStringTag,{value:"Module"}));var Cp=Object.defineProperty,Rp=Object.getOwnPropertyDescriptor,Uc=(e,t,s,o)=>{for(var r=o>1?void 0:o?Rp(t,s):t,n=e.length-1,i;n>=0;n--)(i=e[n])&&(r=(o?i(t,s,r):i(r))||r);return o&&r&&Cp(t,s,r),r};const jc="usb-update-model";let ks=class{constructor(e,t,s){a(this,"id");a(this,"active");a(this,"blocked");a(this,"createTime");a(this,"deviceId");a(this,"manifestId");a(this,"notes");a(this,"futureHandler");a(this,"logger");this.id=e,this.logger=s.logger,this.active=t.active,this.blocked=t.blocked,this.createTime=t.createTime,this.deviceId=t.deviceId,this.manifestId=t.manifestId,this.notes=t.notes,this.futureHandler=new ar(this)}updateModel(e){this.active=e.active,this.blocked=e.blocked,this.createTime=e.createTime,this.deviceId=e.deviceId,this.manifestId=e.manifestId,this.notes=e.notes}reset(){this.futureHandler.removeFuture()}get future(){return this.futureHandler.future}async install(e){if(!e)throw new Error("No tracker provided");return this.logger.info(`Installing update for manifest ${this.manifestId} from device ${this.deviceId}`),Nc(this.manifestId,this.deviceId,e)}async init(){this.logger.debug(`initializing usb-update ${this.id}`)}async load(){this.logger.debug(`loading usb-update ${this.id}`)}};Uc([Ar()],ks.prototype,"install",1);ks=Uc([O(jc)],ks);const $r=new ae({class:ks,type:jc});var Lp=Object.defineProperty,Pp=Object.getOwnPropertyDescriptor,zs=(e,t,s,o)=>{for(var r=o>1?void 0:o?Pp(t,s):t,n=e.length-1,i;n>=0;n--)(i=e[n])&&(r=(o?i(t,s,r):i(r))||r);return o&&r&&Lp(t,s,r),r};const Bc="usb-update-container-model";let Ze=class{constructor(e,t,s){a(this,"id");a(this,"disposer");a(this,"storageService");a(this,"_activeUpdate");a(this,"logger");a(this,"_models");this.id=e,this.logger=s.logger,this._models=new le({parentId:e})}getModel(e){return this._models.getModel(e)}get models(){return this._models}get data(){return this._models.data}addModel(e){this._models.addModel(e)}removeModel(e){this._models.removeModel(e)}get activeUpdate(){return this._activeUpdate}reset(){this.clearActiveUpdate()}clearActiveUpdate(){this._activeUpdate=void 0}updateActiveUpdate(e){this._activeUpdate=e}get isUsbInserted(){return this.storageService.isStorageInserted}get hasAvailableUpdates(){return this._models.data.length>0}async syncAvailableUpdates(){const e=await Fc();Y(()=>{const t=e.map(s=>`${s.deviceId}-${s.manifestId}`);this._models.data.filter(s=>!t.includes(s.id)).forEach(s=>this.removeModel(s.id)),e.forEach(s=>{const o=`${s.deviceId}-${s.manifestId}`,r=$r.instance(o).forceUpdate.options({...s,createTime:new Date(s.createTime)}).build();this.addModel(r)}),this.data.length===1?this.updateActiveUpdate(this.data[0]):this.clearActiveUpdate()})}usbInsertedEffect(){this.isUsbInserted?this.syncAvailableUpdates():(this._models.clear(),this.clearActiveUpdate())}async init(){this.logger.debug(`initializing usb-update-container container ${this.id}`)}unload(){var e;(e=this.disposer)==null||e.call(this)}async activate(){this.logger.debug(`activating usb-update-container container ${this.id}`),await this.syncAvailableUpdates()}async load(){this.logger.debug(`loading usb-update-container container ${this.id}`)}};zs([Ae({modelType:We.type})],Ze.prototype,"storageService",2);zs([ie],Ze.prototype,"_models",2);zs([ai({dependencies:e=>[e.isUsbInserted]})],Ze.prototype,"usbInsertedEffect",1);Ze=zs([O(Bc)],Ze);const Bt=new pe({class:Ze,type:Bc});Bt.addRelatedModel($r);const kp=()=>({...{[st.type]:{class:Ea},[be.type]:{class:Sa,singleton:!0},...z.registration,...Ce.registration,...Ye.registration,...Os.registration,...ge.registration,[br.type]:{class:exports.WsEventModel,singleton:!0},...Ft.registration,...mr.registration,...bs.registration}}),Or=kp(),xp={models:Or,preloadModels:[]},Fp=!0,Kc=e=>()=>{const t=Or;return ji(So)(xt).model(Ye).model(We).model(Bt).model(Rs).model(Es).model(At).model(Is).model(gr).model(Ut).model(qe).model(wr).model(Ks,Fp).model(qt),Object.keys(t).forEach(s=>{const o=t[s];Ui(So)(s,o)}),{preload:$.model.preloadModel(e),model:$.model.register(e),companion:$.companion.register(e),legacy:$.model.registerLegacyModel(e)}},ne={};ne.core={models:Kc(ne)};ne.preload=$.model.preloadModel(ne);ne.model=$.model.register(ne);ne.companion=$.companion.register(ne);ne.legacy=$.model.registerLegacyModel(ne);const So=ne;class Np{registerTroubleRankMapper(t){return C.propertyMapper.registerPropertyMapper(re.TroubleRank,t),this}registerTroubleRoleMapper(t){return C.propertyMapper.registerPropertyMapper(re.TroubleRole,t),this}registerTroubleColorMapper(t){return C.propertyMapper.registerPropertyMapper(re.TroubleColor,t),this}registerModelLoader(t,s){C.loader.registerLoader(t,s)}registerCanvasPatternLoader(t){C.loader.registerLoader(qe.loader,t)}}const Up=async(e,t)=>{const s=gr.instance(e).options({}).build(),o=t?`${t}-`:"";return await J(s),{getState:r=>s.data[`${o}${r}`],updateState:async(r,n)=>{await s.updateState(`${o}${r}`,n)},clean:async()=>{for(const r of s.data.keys)await s.updateState(`${o}${r}`,void 0)},unsubscribe:()=>{Oe(s)}}},Gc="kos:service:region",Hc="regionId",jp=`${Gc}-${Hc}`,Vc=async e=>{const t=Ce.factory(jp)({path:Gc,attribute:Hc});await J(t),t.updateProperty(e)},Dr="/kos-timer-event",Sr="defaultTimerEnd",mt=f.createLogger({name:"timer-manager"}),Bp=e=>e.updateProperty!==void 0;class Yc{constructor(t,s,o){a(this,"name");a(this,"timeout");a(this,"timer");a(this,"state","inactive");a(this,"decrementValue",1);a(this,"remainingTime");a(this,"timeoutActions",new Map);this.name=t;const r=typeof s=="number"?s:s.value||60;this.timeout=r,this.state="inactive",this.remainingTime=r,Bp(s)&&F(()=>{f.info(`Updating config value timer ${t} with new timeout value ${s.value}`);const n=s.value||60;this.updateTimeout(n)}),this.addTimeoutAction({name:Sr}),o&&o.forEach(n=>{this.addTimeoutAction(n)})}get id(){return this.name}start(){if(this.state==="active"){mt.debug(`Timer ${this.name} already started`);return}(this.state==="inactive"||this.state==="paused")&&(this.state="active",this.timer=setInterval(()=>this.updateTimer(),1e3))}pause(){this.timer&&(mt.debug(`Pausing timer ${this.name}`),this.state="paused",clearInterval(this.timer))}restart(){this.pause(),this.remainingTime=this.timeout,this.start()}reset(){this.pause(),this.remainingTime=this.timeout,this.state="inactive"}updateTimeout(t){this.timeout=t,this.restart()}addTimeoutAction(t){const s=t.remainingTime??0;this.timeoutActions.has(s)||this.timeoutActions.set(s,[]);const o=t.name,r=this.timeoutActions.get(s).find(n=>n.name===o);r?r.action=t.action:this.timeoutActions.get(s).push(t)}removeTimeoutAction(t){for(const[s,o]of this.timeoutActions.entries()){const r=o.filter(n=>n.name!==t);r.length===0?this.timeoutActions.delete(s):this.timeoutActions.set(s,r)}}updateTimer(){if(this.remainingTime=Math.round((this.remainingTime-this.decrementValue)*100)/100,this.remainingTime<=0){this.state==="active"&&this.executeActions(0),this.pause();return}this.state==="active"&&this.executeActions(this.remainingTime)}executeActions(t){this.timeoutActions.has(t)&&this.timeoutActions.get(t).forEach(s=>{var o;mt.debug(`Executing timer action ${s.name} at ${t}`),(o=s.action)==null||o.call(s,s.name,t),this.notifyTimeoutAction(s),s.singleUse&&(mt.info(`${this.name} Removing single-use action ${s.name}`),this.removeTimeoutAction(s.name))})}notifyTimeoutAction(t){N(Dr,{name:this.name,action:t.name,remainingTime:this.remainingTime})}}const yt=new Map,Fe=(e,t)=>{const s=yt.get(e);if(!s){mt.error(`Timer ${e} not found`);return}t(s)},zc={createRelativeTimer(e,t,s){const o=new Date,r=Math.round((t.getTime()-o.getTime())/1e3);return this.createTimer(e,r,s)},createTimer(e,t=60,s){if(yt.has(e))return yt.get(e);const o=new Yc(e,t,s);return yt.set(e,o),o},getTimer(e){return yt.get(e)},clearTimer(e){Fe(e,t=>t.pause())},restartTimer(e){Fe(e,t=>t.restart())},resetTimer(e){Fe(e,t=>t.reset())},addTimeoutAction(e,t){Fe(e,s=>s.addTimeoutAction(t))},removeTimeoutAction(e,t){Fe(e,s=>s.removeTimeoutAction(t))},startTimer(e){Fe(e,t=>t.start())}},qc="kos:service:region:settings",Wc="timeZone",Kp=`${qc}-${Wc}`,Ao=async e=>{const t=Ce.factory(Kp)({path:qc,attribute:Wc});await J(t),t.updateProperty(e)},Gp=e=>!e||!e.data;function Ar(e={}){const{alias:t,namespace:s}=e;return(o,r,n)=>{o[wt]=o[wt]||{};const i=n.value,c=async function(...d){const l=Qe();f.debug(`Calling future service ${r} with tracker ${l}`);const u=De.initiateFuture({tracker:l,id:tr});s&&(u.namespace=s),f.debug(`waiting for future ${u.id} to be ready`),await J(u),f.debug(`future ${u.id} is ready`),Y(()=>{f.debug(`Adding future ${u.id} to futureHandler`),this.futureHandler.addFuture(u,t)});try{const h=await i.apply(this,[...d,l]);f.debug(`received future response for ${l}`,h);const p=Gp(h)?h:h==null?void 0:h.data;return p?(p.progress=1,f.debug("mapping future response to future model"),u.endState?f.debug(`future ${u.id} has already completed. Not updating the model`):dr(p,u)):this.futureHandler.removeFuture(t),p}catch(h){throw f.error(h),h}};o[wt][r]={handler:c}}}const Hp=({path:e})=>(t,s)=>{t[P]=t[P]||{},t[P][s]={modelType:Ft.type,id:`${Ft.type}-${e}`,options:{path:e},lifecycle:x.INIT}};function Vp(e){const{path:t,attribute:s}=e;return(o,r)=>{o[P]=o[P]||{},o[P][r]={modelType:mr.type,id:`${t}-${s}`,options:{path:t,attribute:s},lifecycle:x.INIT}}}const je=f.createLogger({name:"services",group:"Services"}),Yp=async(e,t)=>Zc(e,t,`${exports.BASE_URL}/api/server/login`),Zc=async(e,t,s=`${exports.BASE_URL}/api/login`)=>{const o=await exports.kosFetch(`${s}`,{method:"POST",destinationAddress:"",body:JSON.stringify({email:e,password:t})});if(!o.ok){const n=await o.json();throw Error(`${n==null?void 0:n.error}`)}return await o.json()},zp=async e=>Jc(e,`${exports.BASE_URL}/api/server/startPasswordReset`,""),Jc=async(e,t=`${exports.BASE_URL}/api/startPasswordReset`,s="server")=>{const o=await exports.kosFetch(`${t}?email=${e}`,{method:"POST",destinationAddress:s});if(!o.ok)throw Error(`There was a problem reseting config; returned status ${o.status}`);return await o.json()},qp=async(e,t)=>Qc(e,t,`${exports.BASE_URL}/api/server/resetPassword`),Qc=async(e,t,s=`${exports.BASE_URL}/api/resetPassword`)=>{je.debug(`resetting password with token ${e} and password ${t.replace(/./g,"*")}`);const o=await exports.kosFetch(`${s}`,{method:"POST",destinationAddress:"",body:JSON.stringify({token:e,password:t})});if(je.debug(`password reset returned status ${o.status}`),!o.ok){je.error(`password reset failed with message ${o.statusText}`);const n=await o.json();throw Error(`${n==null?void 0:n.error}:There was a problem resetting the password.`)}return await o.json()},Wp=async(e,t,s)=>Xc(e,t,s,`${exports.BASE_URL}/api/server/acceptInvite`),Xc=async(e,t,s,o=`${exports.BASE_URL}/api/server/acceptInvite`)=>{je.debug(`accepting invite with token ${e} and password ${t.replace(/./g,"*")}`);const r=await exports.kosFetch(`${o}`,{method:"POST",destinationAddress:"",body:JSON.stringify({token:e,password:t,name:s})});if(je.debug(`invitation accept returned status ${r.status}`),!r.ok){je.error(`invite failed with message ${r.statusText}`);const i=await r.json();throw Error(`${i==null?void 0:i.error}:There was a problem accepting the invite.`)}return await r.json()},Zp=Ie.keyframes`
|
|
78
78
|
0% {
|
|
79
79
|
left: -90px;
|
|
80
80
|
color: #eee;
|
|
@@ -86,13 +86,13 @@ ${d}topics:${t}
|
|
|
86
86
|
left: 90px;
|
|
87
87
|
color: #eee;
|
|
88
88
|
}
|
|
89
|
-
`,
|
|
89
|
+
`,Jp=Ie.css`
|
|
90
90
|
font-size: 100px;
|
|
91
91
|
margin-top: -80px;
|
|
92
92
|
position: relative;
|
|
93
|
-
animation: ${
|
|
93
|
+
animation: ${Zp} ease-in-out infinite alternate;
|
|
94
94
|
animation-duration: 1.2s;
|
|
95
|
-
`,
|
|
95
|
+
`,Qp=({children:e})=>En.createPortal(e,document.body);function ed({message:e="Wait a moment while we load your app.",theme:t="light"}){return M.jsx(Qp,{children:M.jsxs(Xp,{theme:t,children:[e,M.jsx("div",{css:Jp,children:"."})]})})}const Xp=Po.div`
|
|
96
96
|
padding-inline: 20px;
|
|
97
97
|
width: 100%;
|
|
98
98
|
height: 100vh;
|
|
@@ -106,7 +106,7 @@ ${d}topics:${t}
|
|
|
106
106
|
left: 0;
|
|
107
107
|
color: ${({theme:e})=>e==="light"?"black":"white"};
|
|
108
108
|
z-index: 10000;
|
|
109
|
-
`;class
|
|
109
|
+
`;class td extends g.Component{constructor(t){super(t),this.state={error:null,errorInfo:null}}componentDidCatch(t,s){this.setState({error:t,errorInfo:s})}render(){return this.state.errorInfo?this.props.fallback||M.jsxs("div",{children:[M.jsx("h2",{children:"Something went wrong."}),M.jsxs("details",{style:{whiteSpace:"pre-wrap"},children:[this.state.error&&this.state.error.toString(),M.jsx("br",{}),this.state.errorInfo.componentStack]})]}):this.props.children}}const em={normal:"#B5F7F6",warn:"#F3D78A",error:"#FC8486"},tm=({value:e=0,title:t,status:s="normal",subtitle:o})=>{const r=Ie.css`
|
|
110
110
|
display: flex;
|
|
111
111
|
flex-direction: column;
|
|
112
112
|
`,n=Ie.css`
|
|
@@ -126,11 +126,11 @@ ${d}topics:${t}
|
|
|
126
126
|
`,c=Ie.css`
|
|
127
127
|
width: ${e}%;
|
|
128
128
|
height: 35px;
|
|
129
|
-
background-color: ${
|
|
129
|
+
background-color: ${em[s]};
|
|
130
130
|
text-align: center;
|
|
131
131
|
line-height: 32px;
|
|
132
132
|
color: black;
|
|
133
|
-
`,
|
|
133
|
+
`,d=Ie.css`
|
|
134
134
|
animation: indeterminateAnimation 1s infinite linear;
|
|
135
135
|
transform-origin: 0% 50%;
|
|
136
136
|
@keyframes indeterminateAnimation {
|
|
@@ -144,5 +144,17 @@ ${d}topics:${t}
|
|
|
144
144
|
transform: translateX(100%) scaleX(0.5);
|
|
145
145
|
}
|
|
146
146
|
}
|
|
147
|
-
`;return M.jsxs("div",{css:r,children:[M.jsxs("div",{css:n,children:[M.jsx("div",{css:i,children:t}),M.jsx("div",{css:[c,e<0?l:""]})]}),M.jsx("div",{children:o})]})},Im={setModel:()=>!1},Hs=h.createContext(Im),Tm=()=>{const e=h.useContext(Hs);if(e==null)throw new Error("useModels must be used within a KosModelProvider");return e.model},Uc=({children:e})=>{const[t,s]=h.useState(),o=h.useCallback(r=>(s(r),!0),[s]);return M.jsx(Hs.Provider,{value:{model:t,setModel:o},children:e})},jc=f.createLogger({name:"kos-model-hierarchy-context"}),$m={models:[],addModel:()=>{jc.debug("Default implementation being used. Do Nothing.")}},Vs=h.createContext($m),Om=({children:e})=>{const[t,s]=h.useState([]),o=h.useCallback(r=>{t.includes(r)||(jc.debug("adding to hierarchy context",r.id),s(n=>[...n,r]))},[t]);return M.jsx(Vs.Provider,{value:{models:t,addModel:o},children:e})},Dm=()=>!0,Bc=e=>{const t=h.useContext(Vs);if(!t)throw new Error("useContextModelHierarchy must be used within a KosModelCollectionProvider");const s=(e==null?void 0:e.filter)||Dm;return h.useMemo(()=>t.models.filter(s),[t.models,s])},Sm=e=>Bc({filter:s=>{const o=Je(s.id);return(o==null?void 0:o.type)===e}})[0],Am=f.createLogger({name:"kos-model-loader"}),Cm=()=>M.jsx("div",{}),Kc=({fallback:e,children:t,...s})=>M.jsx(Uc,{children:M.jsx(Fc,{fallback:e,children:M.jsx(h.Suspense,{children:M.jsx(Gc,{...s,children:t})})})}),Gc=e=>{const[t,s]=h.useState(),[o,r]=h.useState(!1),{setModel:n}=h.useContext(Hs),i=h.useContext(Vs);if(h.useEffect(()=>{e.model&&(s(e.model),n(e.model),r(!0),i&&i.addModel(e.model))},[i,e.model,n]),e.error)throw Am.error(e.error),new Error(e.error);const c=e.loading||M.jsx(Cm,{});return M.jsx(M.Fragment,{children:t&&o?e.children:c})},ls={header:{title:"Model",createLabel:"Create new Model",deleteLabel:"Delete"},createModal:{okText:"OK",cancelText:"Cancel",title:"Create New Model"}},Hc=h.createContext(ls),Rm=({translations:e=ls,children:t})=>{const s={header:{...ls.header,...e.header},createModal:{...ls.createModal,...e.createModal}};return M.jsx(Hc.Provider,{value:s,children:t})};function Lm(e,t){const s=_.create(e,!1,t),o=s.whenReady().then(()=>s);return Lo(o)}const Vc=h.createContext(void 0),km=(e={models:{},preloadModels:[]},t)=>{const s=Lm(e,t),o=({children:r})=>{const n=s.read(),[i,c]=h.useState(n.isOnline);return h.useEffect(()=>{const l=N(()=>{c(n.isOnline)});return()=>{l()}},[n]),M.jsx(Vc.Provider,{value:{kosCore:n,online:i},children:r})};return{KosCoreContextProvider:un.observer(o)}},Yc=()=>{const e=h.useContext(Vc);if(e===void 0)throw new Error("useKosCore must be used within a KosCoreContextProvider");return e},Pm=8,xm=(e=0)=>new Promise(t=>{setTimeout(()=>{t(!0)},2**e*10)}),Te=new Map;function Nm(e,t){if(Te.has(e)){const s=Te.get(e);if(s.status==="finished"){const o=_.getInstance().modelManager.getModelById(e);return{kosModel:o,model:o==null?void 0:o.modelData}}else throw s.promise}else{const s=t().then(()=>{Te.set(e,{status:"finished",key:e})},r=>{throw Te.set(e,{status:"error",error:r}),r}),o={status:"pending",promise:s};throw Te.set(e,o),s}}function Fm(e,t){return Nm(e,t)}async function Um(e,t){const{modelId:s,factory:o,modelType:r,options:n,activate:i}=t;let c=0;await e.whenReady();let l;if(n){const u=typeof r=="string"?e.modelManager.getModelFactory(r):o;if(!u)throw Error("No Factory Specified. Cannot create a new instance");l=u.build(s,n)}const d=e.modelManager.getModelById(s);if(!d){if(c>Pm)throw Error(`KOS Model ${s} has not been found`);await xm(c),c=c+1}return await(d==null?void 0:d.whenReady()),d?(l=d.modelData,{kosModel:d,model:l}):{kosModel:void 0,model:void 0}}const B=e=>{const{modelId:t,modelType:s,activate:o,destroyOnUnmount:r}=e,n=Yc(),[i,c]=h.useState(!1),[l,d]=h.useState(),{kosModel:u,model:g}=Fm(t||s||"",()=>Um(n.kosCore,e));return h.useEffect(()=>{async function y(){try{return await n.kosCore.whenReady(),o&&await(u==null?void 0:u.fsm.transitionTo(O.GO_ACTIVE,p.ACTIVE)),c(!0),u}catch(b){d(b.message)}}let v;return n.kosCore&&t&&y().then(b=>{v=N(()=>{const E=(b==null?void 0:b.status)===p.READY;c(E)})}).catch(b=>{console.error(b)}),()=>{if(o){if(g!=null&&g.id){const b=n.kosCore.modelManager.getModelById(g.id);b==null||b.fsm.transitionTo(O.GO_INACTIVE,p.INACTIVE).then(()=>{if(r){const E=g.id;Oe(g).then(()=>{Te.delete(E),v==null||v()})}})}}else r&&g&&Oe(g).then(()=>{Te.delete(t),v==null||v()})}},[o,r,n.kosCore,u,g,t]),{model:g,ready:i,error:l,status:{model:g,ready:i,error:l},KosModelLoader:Kc}},Mr=()=>{const e=ps.type;return B({modelId:e,modelType:ps.type,options:{}})},Er=h.createContext(void 0),jm=({children:e})=>{const{model:t,ready:s}=Mr(),o=h.useMemo(()=>s&&t?{model:t}:{},[s,t]);return M.jsx(Er.Provider,{value:o,children:e})},Bm=()=>{const e=h.useContext(Er);if(!e)throw new Error("useKosTimeContext must be used within a KosTimeProvider");return e},_r=()=>{const e=Es.type;return B({modelId:e,modelType:Es.type,options:{}})};function Km(e){return()=>t=>{const{model:s,status:o,KosModelLoader:r}=_r();return M.jsx(r,{...o,children:M.jsx(e,{...t,softwareInfo:s})})}}const Ir=h.createContext(void 0),Gm=({children:e})=>{const{model:t,ready:s}=_r(),o=h.useMemo(()=>s&&t?{model:t}:{},[s,t]);return M.jsx(Ir.Provider,{value:o,children:e})},Hm=()=>{const e=h.useContext(Ir);if(!e)throw new Error("useSoftwareInfoContext must be used within a SoftwareInfoProvider");return e},zc=new ji,qc=h.createContext(zc);function Vm({children:e}){return M.jsx(qc.Provider,{value:zc,children:e})}const Tr=h.createContext(void 0),Ym=()=>{const e=window.location.origin,t=ae();return(t==null?void 0:t.host)||e},zm=({children:e,appContext:t,locale:s="en",resolver:o,rootUrl:r,descriptorResolver:n})=>{const[i,c]=h.useState(!1),[l,d]=h.useState(),[u,g]=h.useState(),y=r||Ym(),v=h.useMemo(()=>t??"app/system",[t]);h.useEffect(()=>{async function I(){const te=(Array.isArray(v)?v:[v]).map(Q=>(n||tc(Q))()),Ys=(await Promise.allSettled(te)).map(Q=>{if(Q.status==="rejected"){f.warn("Failed to load localization descriptor",Q.reason);return}return Q.value}).filter(Q=>!!Q).reverse().reduce((Q,Me)=>{const zs=Me.path;return Object.keys(Me.namespaces).forEach(qs=>{const Ws=Me.namespaces[qs];Ws.basePath=zs}),{...Q,namespaces:{...Q.namespaces,...Me.namespaces}}},{});d(Ys)}I()},[v,n]),h.useEffect(()=>{async function I(){if(l){const A=y,{translations:te}=await ic.init({lang:s,descriptor:l,defaultNamespace:"common",resolver:o,rootUrl:A});g(te),c(!0)}}I()},[s,l,o,y]);const b=h.useMemo(()=>i?{setLocale:I=>{u&&(u.currentLocale=I)}}:{setLocale:()=>{throw new Error("Translations not ready")}},[i,u]),E=i?e:null;return M.jsx(Tr.Provider,{value:b,children:E})},qm=()=>{const e=h.useContext(Tr);if(!e)throw new Error("useTranslationContainerContext must be used within a TranslationContainerProvider");return e},Wc=()=>{const e=Ss.type;return B({modelId:e,modelType:Ss.type,options:{}})};function Wm(e){return t=>{const{model:s,status:o,KosModelLoader:r}=Wc();return M.jsx(r,{...o,children:M.jsx(e,{...t,device:s})})}}function Zm(e,t,s){const o=new Promise(r=>{_.getInstance().whenReady().then(()=>{const{model:n}=_.getInstance().modelManager.createModelInstance(e,t??e,s);return n.whenReady().then(()=>{r(n.modelData)})})});return Lo(o)}function Jm(e){return t=>{const{model:s,status:o,KosModelLoader:r}=Mr();return M.jsx(r,{...o,children:M.jsx(e,{...t,kosTime:s})})}}const Zc=()=>{const e=xt.type;return B({modelId:e,modelType:xt.type,options:{}})};function Qm(e){return t=>{const{model:s,status:o,KosModelLoader:r}=Zc();return M.jsx(r,{...o,children:M.jsx(e,{...t,networkInterfaceContainer:s})})}}const Jc=()=>{const e=Ms.type;return B({modelId:e,modelType:Ms.type,options:{}})};function Xm(e){return t=>{const{model:s,status:o,KosModelLoader:r}=Jc();return M.jsx(r,{...o,children:M.jsx(e,{...t,oTA:s})})}}function ep(e,t){h.useEffect(()=>{function s(r){e.current&&!e.current.contains(r.target)&&t()}function o(r){r.key==="Escape"&&t()}return document.addEventListener("mousedown",s),document.addEventListener("keydown",o,!1),()=>{document.removeEventListener("mousedown",s),document.removeEventListener("keydown",o,!1)}},[e,t])}function tp(e){const t=h.useRef(null),s=e.onAlert;return ep(t,s),M.jsx("div",{ref:t,style:{width:"100%"},children:e.children})}const sp=e=>{var d;const{stateProp:t}=e,[s,o]=h.useState((d=e.stateProp)==null?void 0:d.value),[r,n]=h.useState(!1),[i,c]=h.useState(void 0);return h.useEffect(()=>{async function u(g){try{g&&(await J(g),n(!0))}catch(y){c(y.message)}}u(t)},[t]),h.useEffect(()=>{const u=N(()=>{t&&r&&o(t.value)});return()=>{u()}},[r,t]),[s,{ready:r,error:i}]},Qc=()=>{const[e,t]=h.useState(!1),[s,o]=h.useState([]),r=ze.type,n=B({modelId:r,modelType:ze.type,options:{}});return h.useEffect(()=>{const i=N(()=>{var c,l;t(((c=n.model)==null?void 0:c.isStorageInserted)??!1),o(((l=n.model)==null?void 0:l.data)??[])});return()=>{i()}},[n.model]),{...n,inserted:e,devices:s}};function op(e){return t=>{const{model:s,status:o,KosModelLoader:r}=Qc();return M.jsx(r,{...o,children:M.jsx(e,{...t,storageDeviceContainer:s})})}}const rp=({timerName:e,onTimerExpired:t,timerEventActions:s,autoStart:o})=>{const r=Ac.getTimer(e);return h.useEffect(()=>{const n=j(br,i=>{const{name:c,action:l,remainingTime:d}=i==null?void 0:i.body;c===e&&r&&(l===wr?t({name:c,action:l,remainingTime:d,timer:r}):s!=null&&s[l]&&s[l]({name:c,action:l,remainingTime:d,timer:r}))});return o&&(r==null||r.start()),()=>{n.unsubscribe()}},[o,t,r,s,e]),{timer:r,start:r==null?void 0:r.start.bind(r),reset:r==null?void 0:r.reset.bind(r),pause:r==null?void 0:r.pause.bind(r)}},np=e=>{const t=/[\\^$.*+?()[\]{}|]/g;return RegExp(t.source).test(e)?e.replace(t,"\\$&"):e},ip=e=>e instanceof RegExp,ap=e=>typeof e=="string",cp=(e,t,s)=>{if(e===""||t==="")return e;let o=t;ip(o)||(o=new RegExp("("+np(o)+")","gi"));const r=e.split(o);for(let n=1,i=r.length;n<i;n+=2)r[n]=s(r[n],n);return r},Xc=(e,t,s)=>{let o=e;return Array.isArray(o)||(o=[o]),o.flatMap(r=>ap(r)?cp(r,t,s):r)};function lp(e,t){let s=e;return Object.entries(t).forEach(([o,r])=>{const n=new RegExp(`<${o}>(.*?)</${o}>|<${o}/>`,"g");s=Xc(s,n,(i,c)=>r.type==="br"?M.jsx("br",{}):h.cloneElement(r,{key:`${o}-${c}`},i))}),s}const dp=e=>{const{i18nKey:t,t:s,defaults:o,components:r,values:n={},context:i}=e,c=s(t,{defaultValue:o,data:n,context:i,returnObjects:!0}),l=lp(c,r||{});return M.jsx("span",{className:e.className,children:l})},Fe=new Map;function up(e,t){if(Fe.has(e)){const s=Fe.get(e);if(s.status==="finished")return s.result;throw s.promise}else{const s=t().then(r=>{Fe.set(e,{status:"finished",result:r})},r=>{throw Fe.set(e,{status:"error",error:r}),r}),o={status:"pending",promise:s};throw Fe.set(e,o),s}}function To(e,t){return up(e,t)}const hp=async()=>{const e=await Ti(he.type);return await J(e.model),e.model},gp=async(e,t,s)=>{const o=e.resolveNamespace(t);await J(o);for(const r of s){const n=e.resolveNamespace(r);await J(n),Fe.set(r,{status:"finished",result:n})}return o},fp=(e,t)=>{const s=[e].flat(),[o,...r]=s,n=To(he.type,hp),i=s.join("__"),c=To(i,()=>gp(n,o,r)),l=h.useMemo(()=>({exists:u=>{const g=t!=null&&t.keyPrefix?`${t.keyPrefix}.${u}`:u;return c?c.exists(g):!1}}),[t==null?void 0:t.keyPrefix,c]);return{t:h.useCallback((u,g)=>{const y=t!=null&&t.keyPrefix?`${t.keyPrefix}.${u}`:u;return c?c.resolveKey(y,g):(f.debug(`Translation model ${e} not ready for key: ${y}`),y)},[t==null?void 0:t.keyPrefix,e,c]),i18n:l}},el=()=>{const e=he.type;return B({modelId:e,modelType:he.type,options:{}})};function mp(e){return t=>{const{model:s,status:o,KosModelLoader:r}=el();return M.jsx(r,{...o,children:M.jsx(e,{...t,translationContainer:s})})}}const pp=e=>B({modelId:e,modelType:kt.type}),$r=()=>B({modelId:Ve.type,modelType:Ve.type,options:{}}),yp=({troubleType:e,condition:t})=>{const{model:s}=$r(),[o,r]=h.useState(!1),[n,i]=h.useState([]),c=h.useCallback(()=>{var l,d;return n.length>0&&((l=n[0])!=null&&l.resolvable)?(d=n[0])==null?void 0:d.resolve():Promise.resolve(void 0)},[n]);return h.useEffect(()=>N(()=>{const d=(e?s==null?void 0:s.troubles.getIndexByKey("byType",e):s==null?void 0:s.troubles.data)||[],u=t?d.filter(t):d;r(u.length>0),i(u)}),[t,s,e]),[o,c,n.length>0?n[0]:void 0,n]};function bp(e){return t=>{const{model:s,status:o,KosModelLoader:r}=$r();return M.jsx(r,{...o,children:M.jsx(e,{...t,troubleContainer:s})})}}const tl=()=>{const e=Ft.type,t=B({modelId:e,modelType:Ft.type,options:{},activate:!0,destroyOnUnmount:!0}),[s,o]=h.useState(!1),[r,n]=h.useState(!1),[i,c]=h.useState([]);return h.useEffect(()=>{const l=N(()=>{var d,u,g;o(((d=t.model)==null?void 0:d.isUsbInserted)??!1),n(((u=t.model)==null?void 0:u.hasAvailableUpdates)??!1),c(((g=t.model)==null?void 0:g.data)??[])});return()=>{l()}},[t.model]),{...t,inserted:s,updateAvailable:r,updates:i}};function wp(e){return t=>{const{model:s,status:o,KosModelLoader:r}=tl();return M.jsx(r,{...o,children:M.jsx(e,{...t,usbUpdateContainer:s})})}}const vp=({path:e,propKey:t})=>{const{status:s}=B({modelType:Dt.type,modelId:e,options:{path:e}}),[o,r]=h.useState(!1),[n,i]=h.useState(),[c,l]=h.useState(""),[d,u]=h.useState(),g=y=>{n&&t&&n.updateProperty(t,y)};return h.useEffect(()=>{var y;s.model&&i(s.model),s.model&&t&&((y=s.model)!=null&&y.props.has(t)?l(s.model.props[t]):u(`property ${t} not found`)),s.ready&&r(s.ready)},[s.ready,s.model,t]),h.useEffect(()=>{t&&w.autorun(()=>{const y=n==null?void 0:n.props[t];l(y||"")})},[n,t]),{config:n,ready:o,value:c,error:d,updateValue:g}},Mp=(e,t)=>{switch(t.type){case"UPDATE":return t.payload;default:return e}},sl=({configProperty:e,optionsTransformer:t})=>{const[s,o]=h.useState(!1),[r,n]=h.useState(""),[i,c]=h.useReducer(Mp,{value:String(e==null?void 0:e.value),displayValue:e==null?void 0:e.displayValue,significantValue:e==null?void 0:e.significantValue,unit:e==null?void 0:e.unit,options:e==null?void 0:e.options,mappedOptions:[],updateProperty:e==null?void 0:e.updateProperty,displayOptions:e==null?void 0:e.displayOptions}),l=h.useCallback(d=>{var g;let u="factory";typeof d=="string"?u=d:(g=d==null?void 0:d.target)!=null&&g.value&&(u=d.target.value),u&&(e==null||e.updateProperty(u))},[e]);return h.useEffect(()=>{async function d(u){try{u&&(await J(u),o(!0))}catch(g){n(g.message)}}d(e)},[e]),h.useEffect(()=>{const d=N(()=>{if(e&&s){let u=[];t&&(u=t(e.options)),c({type:"UPDATE",payload:{value:String(e.value),displayValue:e.displayValue,significantValue:e.significantValue,unit:e.unit,options:e.options,mappedOptions:u,updateProperty:e.updateProperty,displayOptions:e==null?void 0:e.displayOptions}})}});return()=>{d()}},[e,t,s]),{...i,configSelectProps:{onChange:l,value:i.value,options:t?i.mappedOptions||[]:i.options||[]},ready:s,error:r}};function Ep(e,t){const s=t??new Date().getFullYear(),o=[31,28,31,30,31,30,31,31,30,31,30,31];return e===1&&(s%4===0&&s%100!==0||s%400===0)?29:o[e]??0}function _p(e,t){return new Date(e,t,0).getDate()}function ol(e,t){const s=Ep(t,e),o=[];for(let r=1;r<=s;r++)o.push(r);return o}function rl(){return[...Array(12).keys()].map(t=>new Date(0,t).getMonth())}function nl(e=[2018,2028]){const t=[];for(let s=e[0];s<=e[1];s++)t.push(s);return t}function il(e,t=[2018,2028]){const s=nl(t);return e==="long"?s:s.map(o=>Number(o.toString().substring(2)))}function Or(e="numeric",t="en-US"){const s=new Intl.DateTimeFormat(t,{month:e,timeZone:"UTC"}).format;return[...Array(12).keys()].map(o=>s(new Date(Date.UTC(0,o,1))))}function Ip({locale:e="en-US",year:t,month:s,day:o,formatOptions:r={weekday:"long",year:"numeric",month:"long",day:"numeric"},displayOrder:n}){const i=s-1,c=new Date(t,i,o),l=new Intl.DateTimeFormat(e,{month:r.month}).format(c),d=new Intl.DateTimeFormat(e,{year:r.year}).format(c),u=new Intl.DateTimeFormat(e,{day:r.day}).format(c);return n?n=="MMDDYY"?`${l} ${u} ${d}`:n==="DDMMYY"?`${u} ${l} ${d}`:n==="YYMMDD"?`${d} ${l} ${u}`:`${d} ${u} ${l}`:new Intl.DateTimeFormat(e,r).format(c)}function se(e){return e.toString().length===2?new Date(Date.parse(`01 Jan 20${e}`)).getFullYear():e}function Tp(e){return typeof e=="string"?new Date(Date.parse(`01 ${e.substring(0,3)} 2023`)).getMonth()+1:e}function al(e,t,s){const o=se(t),r=new Date(o,e,1).getDay(),n=new Date(o,e+1,0).getDate();return[...Array(42).keys()].map(c=>c<r||c>n+r-1?{label:"",value:0,disabled:!0}:s[c-r])}function pt(e,t,s){const o=t-1,r=new Date(e,o,s);return new Date(r).getMonth()===o&&new Date(r).getDate()===s}function yt(e,t){return new Date(e,t,0).getDate()}function cl(e="en-US",t="short"){const s=new Intl.DateTimeFormat(e,{weekday:t}).format;return[...Array(7).keys()].map(o=>s(new Date(Date.UTC(2021,5,o))))}function ll({locale:e="en-US",year:t=new Date().getFullYear(),month:s=new Date().getMonth(),yearRange:o=[2018,2028],daysOfWeekFilter:r=[],formatOptions:{yearFormat:n="long",monthFormat:i="long",dayFormat:c="short"}={}}){const l=Dr(n,o),d=dl(n,o,e),u=ul(i,e),g=hl(i,e),y=Sr(t,s),v=gl(t,s,e,r),b=pl(s,t,v),E=fl(e,c);return{daysArray:y,monthsArray:u,yearsArray:l,yearsOptionsArray:d,monthsOptionsArray:g,daysOptionsArray:v,calendarDayArray:b,dayNamesArray:E}}function Dr(e="long",t=[2018,2028]){return h.useMemo(()=>il(e,t),[e,t])}function dl(e="long",t=[2018,2028],s="en-US"){const o=Dr(e,t);return h.useMemo(()=>o.map(n=>({label:n.toLocaleString(s).replace(",",""),value:n})),[s,o])}function ul(e,t="en-US"){return h.useMemo(()=>Or(e,t),[e,t])}function hl(e,t="en-US"){const s=h.useMemo(()=>rl(),[]),o=h.useMemo(()=>Or(e,t),[e,t]);return h.useMemo(()=>[...Array(12).keys()].map(n=>({label:o[n],value:Number(s[n])})),[o,s])}function Sr(e,t){const s=se(e);return h.useMemo(()=>ol(s,t),[t,s])}const $p=(e,t,s,o=[])=>{const r=new Date(e,t,s).getDay();return o.length>0&&o.includes(r)};function gl(e,t,s="en-US",o=[]){const r=Sr(e,t);return h.useMemo(()=>r.map(i=>({label:i.toLocaleString(s),value:i,disabled:$p(e,t,i,o)})),[o,s,t,r,e])}function fl(e="en-US",t="short"){return h.useMemo(()=>cl(e,t),[e,t])}function ml({year:e=new Date().getFullYear(),month:t=new Date().getMonth(),day:s=new Date().getDate(),formatString:o}){const r=t,n=new Date(e,r,s);return{formattedDate:me.format(n,o)}}function pl(e,t,s){return h.useMemo(()=>al(e,t,s),[e,t,s])}var yl=(e=>(e.MMDDYY="MMDDYY",e.DDMMYY="DDMMYY",e.YYMMDD="YYMMDD",e.YYDDMM="YYDDMM",e))(yl||{});function Op({locale:e="en-US",date:{year:t=new Date().getFullYear(),month:s=new Date().getMonth(),day:o=new Date().getDate()}={year:new Date().getFullYear(),month:new Date().getMonth(),day:new Date().getDate()},formatOptions:{yearFormat:r="long",monthFormat:n="long",dayFormat:i="short",formatString:c="yyyy/MM/dd"}={},filterOptions:{yearsRange:l=[2018,2028],daysOfWeekFilter:d=[]}={}}){const[u,g]=h.useState(t),[y,v]=h.useState(l),[b,E]=h.useState(s),[I,A]=h.useState(o);h.useEffect(()=>{g(t)},[t]),h.useEffect(()=>{E(s)},[s]),h.useEffect(()=>{A(o)},[o]);const{yearsArray:te,yearsOptionsArray:ve,monthsArray:st,monthsOptionsArray:Ys,daysArray:Q,daysOptionsArray:Me,calendarDayArray:zs,dayNamesArray:qs}=ll({locale:e,year:u,yearRange:y,month:b,formatOptions:{yearFormat:r,monthFormat:n,dayFormat:i},daysOfWeekFilter:d}),{formattedDate:Ws}=ml({year:u,month:b,day:I,formatString:c});return{dateActions:{setYear:g,setYearRange:v,setMonth:E,setDay:A,nextMonth:()=>{const K=b<11?se(u):se(u+1),W=b<11?b+1:0;if(!pt(K,W,I)){const Ee=yt(K,W);A(Ee)}W===0&&g(K),E(W)},previousMonth:()=>{const K=se(b===0?u-1:u),W=b===0?11:b-1;if(!pt(K,W,I)){const Ee=yt(K,W);A(Ee)}W===11&&g(K),E(W)},nextYear:()=>{const K=u<y[1]?u+1:y[0],W=se(K);if(pt(W,b,I))g(K);else{const Ee=yt(se(u+1),b);A(Ee),g(K)}},previousYear:()=>{const K=u>y[0]?u-1:y[0],W=se(K);if(pt(W,b,I))g(K);else{const Ee=yt(se(u-1),b);A(Ee),g(K)}}},dateState:{year:u,yearRange:y,month:b,day:I,yearsArray:te,yearsOptionsArray:ve,monthsArray:st,monthsOptionsArray:Ys,daysArray:Q,daysOptionsArray:Me,calendarDayNames:qs,calendarDayArray:zs,formattedDate:Ws}}}function bl({date:e=new Date,dateFormat:t,timeFormat:s,options:o={}}){const[r,n]=h.useState("Formatting Time..."),[i,c]=h.useState("Formatting Date..."),l=!!o.ignoreDateFormat,{model:d,ready:u}=B({modelId:z.type,modelType:z.type,options:{}}),g=typeof e=="string"?me.parseISO(e):e;return h.useEffect(()=>{l?c(""):t?c(me.format(g,t)):u&&c(me.format(g,d!=null&&d.selectedDateFormat?d==null?void 0:d.selectedDateFormat:""))},[l,e,t,g,d,u]),h.useEffect(()=>{s?n(me.format(g,s)):u&&n(me.format(g,d!=null&&d.selectedTimeFormat?d==null?void 0:d.selectedTimeFormat:""))},[e,s,g,d,u]),{formattedDate:i,formattedTime:r}}const wl=({secondsFromMidnight:e=0})=>{const[t,s]=h.useState(0),[o,r]=h.useState(0),[n,i]=h.useState(0),[c,l]=h.useState(new Date),{formattedTime:d}=bl({date:c,options:{ignoreDateFormat:!0}});return h.useEffect(()=>{const u=Number(e),g=Math.floor(u/3600),y=Math.floor(u%3600/60),v=u%60;s(g),r(y),i(v);const b=new Date;b.setHours(0,0,0,0);const E=new Date(b.getTime()+u*1e3);l(new Date(E))},[e]),{hours:t,minutes:o,seconds:n,formattedTime:d,timeActions:{setHours:s,setMinutes:r,setSeconds:i}}},Dp=({configProperty:e})=>{const{value:t}=sl({configProperty:e}),s=parseInt(t||"0",10),{hours:o,minutes:r,seconds:n,formattedTime:i,timeActions:c}=wl({secondsFromMidnight:s}),l=h.useRef();return h.useEffect(()=>{const d=o*3600+r*60+n;return l.current&&clearTimeout(l.current),l.current=setTimeout(()=>{e&&e.updateProperty(d.toString())},100),()=>{l.current&&clearTimeout(l.current)}},[e,o,r,n]),{hours:o,minutes:r,seconds:n,formattedTime:i,timeActions:c}};function Sp(e,t={}){const{intervalMs:s=5*60*1e3,immediate:o=!0}=t;h.useEffect(()=>{const r=()=>{try{e({__warmup:!0})}catch{}};o&&("requestIdleCallback"in window?requestIdleCallback(r):setTimeout(r,1));const n=s?setInterval(r,s):null;return()=>{n&&clearInterval(n)}},[e,s,o])}const Ap=e=>M.jsx("option",{title:e.id,value:e.format,children:e.format},e.id),Cp=(e=Ap)=>{const[t,s]=h.useState([]),[o,r]=h.useState(),{model:n,ready:i}=B({modelType:z.type,modelId:z.type,options:{}});h.useEffect(()=>{const l=N(()=>{s((n==null?void 0:n.dateFormatOptions.map(e))||[])});return()=>{l()}},[n,i,e]),h.useEffect(()=>{const l=N(()=>{n!=null&&n.dateFormatId&&(n!=null&&n.selectedDateFormat)&&r({id:n==null?void 0:n.dateFormatId,value:n==null?void 0:n.selectedDateFormat})});return()=>{l()}},[n==null?void 0:n.selectedDateFormat,n==null?void 0:n.dateFormatId]);const c=h.useCallback(l=>{var u;let d="";typeof l=="string"?d=l:(u=l==null?void 0:l.target)!=null&&u.value&&(d=l.target.value),d&&(n==null||n.setSelectedDateFormat(d))},[n]);return{raw:(n==null?void 0:n.dateFormatOptions.map(l=>l.id))??[],regionModel:n,selectedDateFormat:(o==null?void 0:o.value)||"",dateFormatId:(o==null?void 0:o.id)||"",updateDateFormat:c,props:{onChange:c,value:(o==null?void 0:o.id)||"",options:t}}},Rp=e=>M.jsx("option",{title:e,value:e,children:e},e),vl="kos:service:region:settings",Ml="timeZone",Lp=`${vl}-${Ml}`,kp=(e=Rp)=>{const[t,s]=h.useState([]),[o,r]=h.useState(""),{model:n,ready:i}=B({modelType:z.type,modelId:z.type,options:{}}),c=Ae.factory(Lp)({path:vl,attribute:Ml});h.useEffect(()=>{const d=N(()=>{s((n==null?void 0:n.timeZones.map(e))||[]),n!=null&&n.timeZones.length&&Io(n==null?void 0:n.timeZones[0])});return()=>{d()}},[n,i,e]),h.useEffect(()=>{const d=N(()=>{r(c.value||"")});return()=>{d()}},[c.value]);const l=h.useCallback(d=>{var g;let u="factory";typeof d=="string"?u=d:(g=d==null?void 0:d.target)!=null&&g.value&&(u=d.target.value),u&&Io(u)},[]);return{options:t,raw:(n==null?void 0:n.timeZones)??[],regionModel:n,selectedTimeZone:o,timeZones:(n==null?void 0:n.timeZones)??[],updateTimeZone:l,selectProps:{onChange:l,value:o,options:t}}},El="kos:service:region",_l="regionId",Pp=`${El}-${_l}`,xp=e=>M.jsx("option",{title:e,value:e,children:e},e),Il=(e=xp)=>{const[t,s]=h.useState([]),[o,r]=h.useState("factory"),{model:n,ready:i}=B({modelType:z.type,modelId:z.type,options:{}}),c=Ae.factory(Pp)({path:El,attribute:_l});h.useEffect(()=>{const d=N(()=>{s((n==null?void 0:n.availableRegions.map(e))||[])});return()=>{d()}},[n,i,e]),h.useEffect(()=>{const d=N(()=>{r(c.value||"factory")});return()=>{d()}},[c.value]);const l=h.useCallback(d=>{var g;let u="factory";typeof d=="string"?u=d:(g=d==null?void 0:d.target)!=null&&g.value&&(u=d.target.value),u&&Dc(u)},[]);return{raw:(n==null?void 0:n.availableRegions)??[],regionModel:n,regionData:n==null?void 0:n.selectedRegion,selectedRegion:o,updateRegion:l,regionSelectProps:{onChange:l,value:o,options:t}}},Np=e=>M.jsx("option",{title:e.id,value:e.format,children:e.format},e.id),Fp=(e=Np)=>{const[t,s]=h.useState([]),[o,r]=h.useState(),{model:n,ready:i}=B({modelType:z.type,modelId:z.type,options:{}});h.useEffect(()=>{const l=N(()=>{s((n==null?void 0:n.timeFormatOptions.map(e))||[])});return()=>{l()}},[n,i,e]),h.useEffect(()=>{const l=N(()=>{n!=null&&n.timeFormatId&&(n!=null&&n.selectedTimeFormat)&&r({id:n==null?void 0:n.timeFormatId,value:n==null?void 0:n.selectedTimeFormat})});return()=>{l()}},[n==null?void 0:n.selectedTimeFormat,n==null?void 0:n.timeFormatId]);const c=h.useCallback(l=>{var u;let d="";typeof l=="string"?d=l:(u=l==null?void 0:l.target)!=null&&u.value&&(d=l.target.value),d&&(n==null||n.setSelectedTimeFormat(d))},[n]);return{raw:(n==null?void 0:n.timeFormatOptions.map(l=>l.id))??[],regionModel:n,selectedTimeFormat:(o==null?void 0:o.value)??"",timeFormatId:(o==null?void 0:o.id)??"",updateTimeFormat:c,props:{onChange:c,value:(o==null?void 0:o.id)??"",options:t}}},Up=(e,t)=>h.useMemo(()=>Vo(e),t),jp={config:{attributes:!0,childList:!0,subtree:!0}};function Bp(e,t,s=jp){const[o,r]=h.useState(null);h.useEffect(()=>{if(!t||typeof t!="function")throw new Error("A valid callback function is required");const n=new MutationObserver(t);r(n)},[t,s,r]),h.useEffect(()=>{if(!o)return()=>{};if(!e)throw new Error("A valid DOM element is required");const{config:n}=s;try{o.observe(e,n)}catch(i){f.error(i)}return()=>{o&&o.disconnect()}},[o,e,s])}const Tl={validateStart:function(e){return!0},validateStop:function(e){const t=e.event.currentTarget.getBoundingClientRect(),[s,o]=e.xy;return s<t.left||s>t.right||o<t.top||o>t.bottom}},io=f.createLogger({name:"usePressGesture",group:"kos-hooks"});function Kp({onPressed:e,onRelease:t,intersectionStrategy:s=Tl}){const o=h.useRef(!1),r=Fl.useGesture({onDragStart:l=>{io.info("onDragStart",l.type),s.validateStart(l)&&(e&&e(),o.current=!0)},onDrag:l=>{io.info("onDrag",l.type),o.current&&s.validateStop(l)&&(t&&t(),o.current=!1)},onDragEnd:l=>{io.info("onDragEnd",l.type),o.current&&t&&(t(),o.current=!1)}}),n=()=>{e&&e(),o.current=!0},i=()=>{o.current&&t&&(t(),o.current=!1)},c=()=>{o.current&&t&&(t(),o.current=!1)};return{dom:r,mesh:()=>({onPointerDown:n,onPointerUp:i,onPointerOut:c})}}const $l=()=>{const[e,t]=h.useState(!1),s=_.getInstance();return h.useEffect(()=>{const o=N(()=>{s&&s.reloading!==e&&t(s.reloading)});return()=>{o()}},[s,e]),[e]};function Ol(e=!1,t="2-digit"){return h.useMemo(()=>{const s=e?12:24;return Array.from({length:s},(o,r)=>{const n=e&&r===0?12:r%s;return{id:r,label:t==="2-digit"?n.toString().padStart(2,"0"):n.toString()}})},[t,e])}function $o(e,t="2-digit",s=0,o=0){return h.useMemo(()=>Array.from({length:e},(r,n)=>{const i=String(n+s);return{id:n+o,label:t==="2-digit"?i.padStart(2,"0"):i}}),[e,s,o,t])}function Dl(e="en-US"){return h.useMemo(()=>["AM","PM"].map(t=>{const s=new Intl.DateTimeFormat(e,{hour:"2-digit",hour12:!0}).formatToParts(new Date().setHours(t==="AM"?0:12))[2].value;return{id:s,label:s}}),[e])}function Sl({formatOptions:{hour12:e=!0,hour:t="2-digit",minute:s="2-digit",second:o="2-digit"}={hour12:!0,hour:"2-digit",minute:"2-digit",second:"2-digit"},locale:r="en-US"}){const n=Ol(e,t),i=$o(60,s),c=$o(60,o),l=Dl(r);return{hourOptions:n,minuteOptions:i,secondOptions:c,amPmOptions:l}}function Al(e,t){return me.format(e,t)}function Cl({formatOptions:e,initialDate:t=new Date,locale:s="en-US",format:o="HH:mm"}){const[r,n]=h.useState(t),i=h.useCallback(E=>{n(I=>{const A=new Date(I);return A.setHours(Number(E)),A})},[]),c=h.useCallback(E=>{n(I=>{const A=new Date(I);return A.setMinutes(Number(E)),A})},[]),l=h.useCallback(E=>{n(I=>{const A=new Date(I);return A.setSeconds(Number(E)),A})},[]),d=h.useCallback(E=>{const I=new Date(E);n(I)},[]),u=Al(r,o),{hourOptions:g,minuteOptions:y,secondOptions:v,amPmOptions:b}=Sl({formatOptions:e,locale:s});return{amPmOptions:b,formattedTime:u,hourOptions:g,minuteOptions:y,secondOptions:v,setHours:i,setMinutes:c,setSeconds:l,setTime:d,time:new Date(r)}}const Gp=e=>{const{regionModel:t}=Il(),s=h.useMemo(()=>({hour12:t==null?void 0:t.is12HourTimeFormat}),[t==null?void 0:t.is12HourTimeFormat]);return Cl({...e,locale:t==null?void 0:t.regionId,format:t==null?void 0:t.selectedTimeFormat,formatOptions:s})};function Hp(e){return t=>{const[s]=$l();return s?M.jsx(Nc,{message:"Wait a moment while your project reloads..."}):M.jsx(e,{...t})}}const cn=f.createLogger({name:"studio-properties-service",group:"Services"}),Vp="/api/kos/studio/properties",Rl=async e=>{if(cn.debug("sending GET for studio-properties"),!e)throw cn.error("connectionId is undefined"),new Error("connectionId is undefined");return await Ce.get(Vp,{},{destinationAddress:e,timeout:500})},Yp=Object.freeze(Object.defineProperty({__proto__:null,getStudioProperties:Rl},Symbol.toStringTag,{value:"Module"}));var zp=Object.defineProperty,qp=Object.getOwnPropertyDescriptor,Wp=(e,t,s,o)=>{for(var r=o>1?void 0:o?qp(t,s):t,n=e.length-1,i;n>=0;n--)(i=e[n])&&(r=(o?i(t,s,r):i(r))||r);return o&&r&&zp(t,s,r),r};const Ll="studio-properties-model",Zp="/kos/studio/properties",ln={"kos.studio.tool.legacy":1};let Oo=class{constructor(e,t,s){a(this,"id");a(this,"connectionId");a(this,"unsubscribe",null);a(this,"logger");a(this,"data");this.id=e,this.logger=s.logger,this.data=pe(),this.connectionId=t.connectionId}async init(){this.logger.debug(`initializing studio-properties ${this.id}`)}async load(){this.logger.debug(`loading studio-properties ${this.id}`)}async terminatePropertiesSession(){var e;(e=this.unsubscribe)==null||e.call(this)}async initializePropertiesSession(){this.unsubscribe=Kt.getInstance().subscribeTopic({topic:Zp,destinationAddress:this.connectionId,callback:s=>{this.logger.error(`Received studio-properties message for connection ${this.connectionId}: ${JSON.stringify(s)}`)}});const[e,t]=await Rl(this.connectionId);if(e){this.logger.error(`Error loading studio-properties: ${e}`),this.data.setValues(ln);return}if(t){const s=Object.keys(t).reduce((o,r)=>(o[r]=t[r]??r,o),{});this.data.setValues(s??ln),f.ifDebug(()=>this.logger.debug(`studio-properties loaded: ${JSON.stringify(s)}`))}}get(e){return this.data[e]}createObservableProperty(e){return Vo(()=>this.get(e))}};Oo=Wp([D(Ll)],Oo);const Jp=new le({class:Oo,type:Ll});Object.defineProperty(exports,"makeAutoObservable",{enumerable:!0,get:()=>w.makeAutoObservable});Object.defineProperty(exports,"makeObservable",{enumerable:!0,get:()=>w.makeObservable});Object.defineProperty(exports,"kosComponent",{enumerable:!0,get:()=>un.observer});exports.AuthState=Ci;exports.BrowserKosRouter=Bi;exports.BrowserRouter=ma;exports.ChildModels=wt;exports.ConfigBean=Dt;exports.CoreExtensionManager=im;exports.CoreModels=yr;exports.CreateModelTranslationsContext=Hc;exports.CreateModelTranslationsProvider=Rm;exports.DateDisplayFormat=yl;exports.DateHelpers=Zl;exports.DependencyLifecycle=x;exports.DependencyModels=k;exports.Device=Ss;exports.DeviceServices=Df;exports.DomIntersectionStrategy=Tl;exports.EVENT_KOS_MODEL_READY=Co;exports.EVENT_TROUBLE_ADDED=nh;exports.EVENT_TROUBLE_REMOVED=ih;exports.EXTENSION_TROUBLE_DATA_MAPPER=ws;exports.EXTENSION_TROUBLE_MAPPER=zt;exports.ErrorBoundaryWithFallback=Fc;exports.EventBus=Kl;exports.ExtensionManager=C;exports.FUTURE_CONTAINER_MODEL_TYPE=pa;exports.FUTURE_MODEL_TYPE=na;exports.FUTURE_NOT_ASSIGNED=zo;exports.FeatureFlagService=Sn;exports.FetchError=ne;exports.FutureContainerFactory=ye;exports.FutureContainerModel=ba;exports.FutureEndState=Ke;exports.FutureFactory=et;exports.FutureHandler=Xo;exports.FutureManager=De;exports.FutureModel=ua;exports.FutureService=bt;exports.HEADER_CACHE_CONTROL=mn;exports.HEADER_CONTENT_TYPE=fn;exports.HEADER_DESTINATION_ADDR=ge;exports.HEADER_FOS_REQUEST_ID=pn;exports.HEADER_METHOD=Ls;exports.HEADER_ORDERED=So;exports.HEADER_REQUEST_ID=Ut;exports.HEADER_REQUEST_TYPE=ie;exports.HEADER_RESPONSE_ID=ks;exports.HEADER_SOURCE_ADDR=gn;exports.HEADER_TOPIC=hn;exports.HEADER_URL=We;exports.HEADER_WORK_TRACKER=Ao;exports.KOS_MODEL_ID=ds;exports.KeyValue=nr;exports.KeyValueServices=eg;exports.Kos=H;exports.KosConfigPropertySpec=Ae;exports.KosContainerIndex=Ho;exports.KosContextBean=Fi;exports.KosContextManager=P;exports.KosCore=_;exports.KosCoreModelPropertyMapper=oe;exports.KosDataContainer=Ui;exports.KosDependencyTypes=hd;exports.KosExtensionUtils=du;exports.KosFeatureFlags=Jl;exports.KosFetchMethods=ai;exports.KosGlobalConfig=No;exports.KosLog=f;exports.KosMockEvents=wn;exports.KosModel=vi;exports.KosModelCollectionProvider=Om;exports.KosModelContainer=fe;exports.KosModelContext=Hs;exports.KosModelEvents=O;exports.KosModelFactory=It;exports.KosModelLoader=Kc;exports.KosModelLoaderDisplay=Gc;exports.KosModelManager=_i;exports.KosModelProvider=Uc;exports.KosModelRegistrationFactory=le;exports.KosModelRegistry=_o;exports.KosModelState=p;exports.KosModelSymbol=qn;exports.KosModelVisitor=Lu;exports.KosObservableData=ki;exports.KosRegistration=th;exports.KosSingletonRegistration=sh;exports.KosTime=ps;exports.KosTimeContext=Er;exports.KosTimeProvider=jm;exports.KosTimeServices=rg;exports.KosTimer=Sc;exports.KosToken=ji;exports.KosTranslationProvider=zm;exports.KosTranslations=ic;exports.KosWSTransportStatus=wi;exports.KosWsEvents=jt;exports.LOGIN_HOST=yn;exports.LOGIN_URL=Ul;exports.LoadingMessage=Nc;exports.LogBlock=Lt;exports.LogBlockContainer=js;exports.LogConfig=Mt;exports.LogStream=$t;exports.LogStreamContainer=Yt;exports.LogStreamServices=mg;exports.MODEL_DELETION_DELAY=Ei;exports.MiddlewareChain=Li;exports.ModelEffects=$e;exports.MultipleFutureHandler=Rh;exports.NestedModelContext=Vs;exports.NetworkInterface=gr;exports.NetworkInterfaceContainer=xt;exports.NetworkInterfaceServices=Ff;exports.ObservableData=pe;exports.Ota=Ms;exports.OutsideAlerter=tp;exports.PLUGIN_EXTENSION_NAME=uu;exports.PORT=bn;exports.PROFILE_LOG_DEBUG=kn;exports.PROFILE_LOG_INFO=Pn;exports.PROFILE_RELAX_STORE_VALIDATION=Xl;exports.PROFILE_TOOLS_PREVIEW=Ln;exports.ParentModel=vt;exports.PluginExtensionManager=hu;exports.ProgressBar=_m;exports.ReferenceConfig=rs;exports.RegionInfo=z;exports.RegionServices=ph;exports.RegistrationManager=$;exports.Registry=rm;exports.STATUS=Do;exports.ServiceFactory=V;exports.SingletonKosModelRegistrationFactory=we;exports.SoftwareInfo=Es;exports.SoftwareInfoContext=Ir;exports.SoftwareInfoProvider=Gm;exports.SoftwareInfoServices=Wg;exports.StateBean=Pt;exports.StateBeanServices=tf;exports.StateProp=cr;exports.StatePropServices=hf;exports.StorageDevice=Cs;exports.StorageDeviceContainer=ze;exports.StorageDeviceServices=Gf;exports.StudioProperties=Jp;exports.StudioPropertiesServices=Yp;exports.SubscriptionHandlers=G;exports.TIMER_END=wr;exports.TIMER_EVENT=br;exports.TimerManager=Ac;exports.TokenContext=qc;exports.TokenProvider=Vm;exports.Topics=Tt;exports.Trans=dp;exports.TransitionMap=ns;exports.Transitions=Uo;exports.Translation=Ts;exports.TranslationContainer=he;exports.TranslationContainerContext=Tr;exports.TranslationContext=_f;exports.TransportFactory=go;exports.Trouble=kt;exports.TroubleContainer=Ve;exports.TroubleServices=Pg;exports.Troubles=X;exports.UsbUpdate=pr;exports.UsbUpdateContainer=Ft;exports.UsbUpdateServices=Qf;exports.WS_EVENT_TYPE=ac;exports.WebSocketEvents=_t;exports.WebSocketTransport=Kt;exports.WsEventFactory=dr;exports.acceptOrgInvitation=xc;exports.addDaysToDate=En;exports.addFuture=aa;exports.addMonthsToDate=Mn;exports.api=ha;exports.applyMixins=Hl;exports.arraysEqual=Vl;exports.buildConfigBeanModel=lh;exports.buildFuture=sr;exports.buildFutureModel=la;exports.cancelFuture=ca;exports.convert=ra;exports.convertFileSizeRaw=Gl;exports.createBaseMessage=di;exports.createBroadcastMessageResponse=fi;exports.createClient=Ko;exports.createFosBaseMessage=li;exports.createHeaders=lo;exports.createKosHtpMessageResponse=mi;exports.createKosMessage=hi;exports.createKosMessageResponse=pi;exports.createMessageBody=be;exports.createModelDependency=si;exports.createOptionKey=gd;exports.createPropKey=Se;exports.createReadableStream=uo;exports.createStudioMessage=ci;exports.createStudioMessageRequest=ui;exports.createStudioMessageResponse=gi;exports.debounce=Dn;exports.deleteFuture=ia;exports.destroyKosModel=Oe;exports.evaluateScopes=qi;exports.executeChildrenModelLifecycle=ni;exports.executeDependentModelLifecycle=it;exports.executeListLifecycle=ri;exports.fetchModel=Zm;exports.findModel=pu;exports.findModels=$i;exports.formatDate=Tn;exports.formatDateSince=vn;exports.formatDateTime=On;exports.formatTime=$n;exports.getAllKosCompanionModels=bu;exports.getCalendarMonthArray=al;exports.getConfigBean=zi;exports.getDayStrings=cl;exports.getDays=_p;exports.getDaysArray=ol;exports.getDaysInMonth=xo;exports.getDependenciesByLifecycle=oi;exports.getFormattedDate=Ip;exports.getFormattedMonth=Tp;exports.getFormattedMonthsArray=Or;exports.getFormattedYear=se;exports.getFormattedYearsArray=il;exports.getFutures=Uh;exports.getKosCompanionModel=yu;exports.getKosLocalizationDescriptor=tc;exports.getKosMessageLogging=jn;exports.getKosModel=Ti;exports.getKosModelSync=Je;exports.getKosModelType=mu;exports.getKosSessionKey=Ni;exports.getLastDayOfMonth=yt;exports.getLocalizationDescriptor=ff;exports.getLogLevel=Un;exports.getLogMessageToStudio=Bn;exports.getMessageBody=ho;exports.getMonthsArray=rl;exports.getObservableCompanions=wu;exports.getQueryParams=ae;exports.getTranslations=ec;exports.getYearsArray=nl;exports.hasDecimals=Vi;exports.hasKosProfile=ao;exports.hslStringToHex=Cn;exports.hslToHex=An;exports.initKosProvider=km;exports.isBoolean=Wo;exports.isKosCompanionTypeFactory=Mi;exports.isKosDataModel=Et;exports.isKosLoggingEnabled=sd;exports.isKosModel=ee;exports.isKosModelContainer=jo;exports.isKosModelReady=hs;exports.isLeapYear=Po;exports.isLocalRefId=Wu;exports.isNumber=xs;exports.isPrintable=Dd;exports.isValidDate=pt;exports.kosAction=Y;exports.kosAutoEffect=N;exports.kosChild=ce;exports.kosCompanion=Md;exports.kosComputed=Vo;exports.kosConfigBean=Ns;exports.kosConfigProperty=Ch;exports.kosContext=Ed;exports.kosDependency=Bt;exports.kosEffect=Gi;exports.kosFuture=vr;exports.kosLogger=_d;exports.kosModel=D;exports.kosModelEffect=Wn;exports.kosObservable=Yo;exports.kosParentAware=Ps;exports.kosReference=Id;exports.kosStateBean=hm;exports.kosStateProp=gm;exports.kosSubscribe=Td;exports.kosTopicHandler=R;exports.kosWhen=mo;exports.login=Lc;exports.mapConfigBeanModelToDto=Qi;exports.mapDataToModel=co;exports.mapDtoToConfigBeanModel=Zi;exports.mapDtoToFutureModel=tr;exports.mapDtoToFutureOptions=er;exports.mapUpdateDtoToConfigBeanModel=Ji;exports.modelEventTopicFactory=Yn;exports.modelFactory=Qe;exports.modelTypeEventTopicFactory=zn;exports.modifyConfigBean=Yi;exports.modifyFuture=jh;exports.pairedClientHeartbeat=ju;exports.pipe=xi;exports.preloadKosModel=Eu;exports.processId=Wl;exports.processMiddleware=xu;exports.registerCompanionModel=Mu;exports.registerCoreModels=Tc;exports.registerExtensionPoint=Fo;exports.registerKosModel=Di;exports.registerLegacyModel=Oi;exports.resetKosModel=Ii;exports.resetPassword=Pc;exports.resolveBaseUrl=Ri;exports.resolveChild=ii;exports.resolveContainerDeltas=Yl;exports.resolveItemListDeltas=ql;exports.resolveKosCompanion=fo;exports.resolveKosContext=Qu;exports.resolveKosProfiles=Nn;exports.resolveListDeltas=zl;exports.resolveServiceUrl=q;exports.resolveVariable=Rn;exports.retryWithExponentialBackoff=Ku;exports.sendAsyncIntent=rh;exports.sendBroadcastMessage=zd;exports.sendIntent=oh;exports.sendKosHttpMessageResponse=bi;exports.sendKosMessage=Hd;exports.sendKosMessageResponse=yi;exports.sendRequest=Zu;exports.sendStudioMessage=Yd;exports.sendStudioMessageRequest=Vd;exports.startPasswordReset=kc;exports.stringComponentInsert=Xc;exports.studioAcceptOrgInvitation=ym;exports.studioLogin=fm;exports.studioResetPassword=pm;exports.studioStartPasswordReset=mm;exports.subscribeStore=am;exports.syncPublish=Ju;exports.transitionToActive=Qn;exports.transitionToInit=ti;exports.transitionToLoad=ei;exports.transitionToReady=Xn;exports.transitionToUnload=Od;exports.troubleByTypeReducer=If;exports.troubleDataFactory=Ha;exports.unloadKosModel=fu;exports.updateCompanionModelRegistration=Fu;exports.updateModelRegistration=Nu;exports.updateRegion=Dc;exports.updateTimeZone=Io;exports.useAmPmValues=Dl;exports.useCalendarDayArray=pl;exports.useConfigBean=vp;exports.useConfigProperty=sl;exports.useContextModel=Tm;exports.useContextModelHierarchy=Bc;exports.useDateArrays=ll;exports.useDateProps=Op;exports.useDateRelativeConfig=Dp;exports.useDateRelativeData=wl;exports.useDayNames=fl;exports.useDayOptions=gl;exports.useDays=Sr;exports.useDevice=Wc;exports.useFormattedDate=ml;exports.useFormattedTime=Al;exports.useFunctionWarmup=Sp;exports.useHourValues=Ol;exports.useKosCore=Yc;exports.useKosDateFormats=Cp;exports.useKosModel=B;exports.useKosRegions=Il;exports.useKosTime=Mr;exports.useKosTimeContext=Bm;exports.useKosTimeFormats=Fp;exports.useKosTimeZones=kp;exports.useKosTranslation=fp;exports.useKosTranslationContext=qm;exports.useLocalComputed=Up;exports.useModelFromHierarchy=Sm;exports.useMonths=ul;exports.useMonthsOptions=hl;exports.useMutationObserver=Bp;exports.useNetworkInterfaceContainer=Zc;exports.useOta=Jc;exports.usePressGesture=Kp;exports.useProjectReload=$l;exports.useRegionTimeProps=Gp;exports.useRegionalTimeDate=bl;exports.useSoftwareInfo=_r;exports.useSoftwareInfoContext=Hm;exports.useStateProperty=sp;exports.useStorageDeviceContainer=Qc;exports.useSuspenseData=To;exports.useTimeOptions=Sl;exports.useTimeProps=Cl;exports.useTimeValues=$o;exports.useTimer=rp;exports.useTranslationContainer=el;exports.useTroubleContainerModel=$r;exports.useTroubleModel=pp;exports.useTroublePresence=yp;exports.useUsbUpdateContainer=tl;exports.useYears=Dr;exports.useYearsOptions=dl;exports.uuid=Ze;exports.variableToHex=Ql;exports.waitForRequest=Go;exports.whenReady=J;exports.withDevice=Wm;exports.withKosTime=Jm;exports.withNetworkInterfaceContainer=Qm;exports.withOta=Xm;exports.withProjectReloading=Hp;exports.withSoftwareInfo=Km;exports.withStorageDeviceContainer=op;exports.withTranslationContainer=mp;exports.withTroubleContainer=bp;exports.withUsbUpdateContainer=wp;exports.wrapPromise=Lo;
|
|
147
|
+
`;return M.jsxs("div",{css:r,children:[M.jsxs("div",{css:n,children:[M.jsx("div",{css:i,children:t}),M.jsx("div",{css:[c,e<0?d:""]})]}),M.jsx("div",{children:o})]})},sm={setModel:()=>!1},qs=g.createContext(sm),om=()=>{const e=g.useContext(qs);if(e==null)throw new Error("useModels must be used within a KosModelProvider");return e.model},sd=({children:e})=>{const[t,s]=g.useState(),o=g.useCallback(r=>(s(r),!0),[s]);return M.jsx(qs.Provider,{value:{model:t,setModel:o},children:e})},od=f.createLogger({name:"kos-model-hierarchy-context"}),rm={models:[],addModel:()=>{od.debug("Default implementation being used. Do Nothing.")}},Ws=g.createContext(rm),nm=({children:e})=>{const[t,s]=g.useState([]),o=g.useCallback(r=>{t.includes(r)||(od.debug("adding to hierarchy context",r.id),s(n=>[...n,r]))},[t]);return M.jsx(Ws.Provider,{value:{models:t,addModel:o},children:e})},im=()=>!0,rd=e=>{const t=g.useContext(Ws);if(!t)throw new Error("useContextModelHierarchy must be used within a KosModelCollectionProvider");const s=(e==null?void 0:e.filter)||im;return g.useMemo(()=>t.models.filter(s),[t.models,s])},am=e=>rd({filter:s=>{const o=Xe(s.id);return(o==null?void 0:o.type)===e}})[0],cm=f.createLogger({name:"kos-model-loader"}),dm=()=>M.jsx("div",{}),nd=({fallback:e,children:t,...s})=>M.jsx(sd,{children:M.jsx(td,{fallback:e,children:M.jsx(g.Suspense,{children:M.jsx(id,{...s,children:t})})})}),id=e=>{const[t,s]=g.useState(),[o,r]=g.useState(!1),{setModel:n}=g.useContext(qs),i=g.useContext(Ws);if(g.useEffect(()=>{e.model&&(s(e.model),n(e.model),r(!0),i&&i.addModel(e.model))},[i,e.model,n]),e.error)throw cm.error(e.error),new Error(e.error);const c=e.loading||M.jsx(dm,{});return M.jsx(M.Fragment,{children:t&&o?e.children:c})},us={header:{title:"Model",createLabel:"Create new Model",deleteLabel:"Delete"},createModal:{okText:"OK",cancelText:"Cancel",title:"Create New Model"}},ad=g.createContext(us),lm=({translations:e=us,children:t})=>{const s={header:{...us.header,...e.header},createModal:{...us.createModal,...e.createModal}};return M.jsx(ad.Provider,{value:s,children:t})};function um(e,t){const s=E.create(e,!1,t),o=s.whenReady().then(()=>s);return Bo(o)}const cd=g.createContext(void 0),hm=(e={models:{},preloadModels:[]},t)=>{const s=um(e,t),o=({children:r})=>{const n=s.read(),[i,c]=g.useState(n.isOnline);return g.useEffect(()=>{const d=F(()=>{c(n.isOnline)});return()=>{d()}},[n]),M.jsx(cd.Provider,{value:{kosCore:n,online:i},children:r})};return{KosCoreContextProvider:ko.observer(o)}},dd=()=>{const e=g.useContext(cd);if(e===void 0)throw new Error("useKosCore must be used within a KosCoreContextProvider");return e},gm=8,fm=(e=0)=>new Promise(t=>{setTimeout(()=>{t(!0)},2**e*10)}),Te=new Map;function pm(e,t){if(Te.has(e)){const s=Te.get(e);if(s.status==="finished"){const o=E.getInstance().modelManager.getModelById(e);return{kosModel:o,model:o==null?void 0:o.modelData}}else throw s.promise}else{const s=t().then(()=>{Te.set(e,{status:"finished",key:e})},r=>{throw Te.set(e,{status:"error",error:r}),r}),o={status:"pending",promise:s};throw Te.set(e,o),s}}function mm(e,t){return pm(e,t)}async function ym(e,t){const{modelId:s,factory:o,modelType:r,options:n,activate:i}=t;let c=0;await e.whenReady();let d;if(n){const u=typeof r=="string"?e.modelManager.getModelFactory(r):o;if(!u)throw Error("No Factory Specified. Cannot create a new instance");d=u.build(s,n)}const l=e.modelManager.getModelById(s);if(!l){if(c>gm)throw Error(`KOS Model ${s} has not been found`);await fm(c),c=c+1}return await(l==null?void 0:l.whenReady()),l?(d=l.modelData,{kosModel:l,model:d}):{kosModel:void 0,model:void 0}}const B=e=>{const{modelId:t,modelType:s,activate:o,destroyOnUnmount:r}=e,n=dd(),[i,c]=g.useState(!1),[d,l]=g.useState(),{kosModel:u,model:h}=mm(t||s||"",()=>ym(n.kosCore,e));return g.useEffect(()=>{async function p(){try{return await n.kosCore.whenReady(),o&&await(u==null?void 0:u.fsm.transitionTo(D.GO_ACTIVE,y.ACTIVE)),c(!0),u}catch(b){l(b.message)}}let w;return n.kosCore&&t&&p().then(b=>{w=F(()=>{const _=(b==null?void 0:b.status)===y.READY;c(_)})}).catch(b=>{console.error(b)}),()=>{if(o){if(h!=null&&h.id){const b=n.kosCore.modelManager.getModelById(h.id);b==null||b.fsm.transitionTo(D.GO_INACTIVE,y.INACTIVE).then(()=>{if(r){const _=h.id;Oe(h).then(()=>{Te.delete(_),w==null||w()})}})}}else r&&h&&Oe(h).then(()=>{Te.delete(t),w==null||w()})}},[o,r,n.kosCore,u,h,t]),{model:h,ready:i,error:d,status:{model:h,ready:i,error:d},KosModelLoader:nd}},Cr=()=>{const e=bs.type;return B({modelId:e,modelType:bs.type,options:{}})},Rr=g.createContext(void 0),bm=({children:e})=>{const{model:t,ready:s}=Cr(),o=g.useMemo(()=>s&&t?{model:t}:{},[s,t]);return M.jsx(Rr.Provider,{value:o,children:e})},vm=()=>{const e=g.useContext(Rr);if(!e)throw new Error("useKosTimeContext must be used within a KosTimeProvider");return e},Lr=()=>{const e=Is.type;return B({modelId:e,modelType:Is.type,options:{}})};function wm(e){return()=>t=>{const{model:s,status:o,KosModelLoader:r}=Lr();return M.jsx(r,{...o,children:M.jsx(e,{...t,softwareInfo:s})})}}const Pr=g.createContext(void 0),Mm=({children:e})=>{const{model:t,ready:s}=Lr(),o=g.useMemo(()=>s&&t?{model:t}:{},[s,t]);return M.jsx(Pr.Provider,{value:o,children:e})},_m=()=>{const e=g.useContext(Pr);if(!e)throw new Error("useSoftwareInfoContext must be used within a SoftwareInfoProvider");return e},ld=new Qi,ud=g.createContext(ld);function Em({children:e}){return M.jsx(ud.Provider,{value:ld,children:e})}const kr=g.createContext(void 0),Im=()=>{const e=window.location.origin,t=ee();return(t==null?void 0:t.host)||e},Tm=({children:e,appContext:t,locale:s="en",resolver:o,rootUrl:r,descriptorResolver:n})=>{const[i,c]=g.useState(!1),[d,l]=g.useState(),[u,h]=g.useState(),p=r||Im(),w=g.useMemo(()=>t??"app/system",[t]);g.useEffect(()=>{async function I(){const se=(Array.isArray(w)?w:[w]).map(Q=>(n||hc(Q))()),Zs=(await Promise.allSettled(se)).map(Q=>{if(Q.status==="rejected"){f.warn("Failed to load localization descriptor",Q.reason);return}return Q.value}).filter(Q=>!!Q).reverse().reduce((Q,Me)=>{const Js=Me.path;return Object.keys(Me.namespaces).forEach(Qs=>{const Xs=Me.namespaces[Qs];Xs.basePath=Js}),{...Q,namespaces:{...Q.namespaces,...Me.namespaces}}},{});l(Zs)}I()},[w,n]),g.useEffect(()=>{async function I(){if(d){const A=p,{translations:se}=await yc.init({lang:s,descriptor:d,defaultNamespace:"common",resolver:o,rootUrl:A});h(se),c(!0)}}I()},[s,d,o,p]);const b=g.useMemo(()=>i?{setLocale:I=>{u&&(u.currentLocale=I)}}:{setLocale:()=>{throw new Error("Translations not ready")}},[i,u]),_=i?e:null;return M.jsx(kr.Provider,{value:b,children:_})},$m=()=>{const e=g.useContext(kr);if(!e)throw new Error("useTranslationContainerContext must be used within a TranslationContainerProvider");return e},Om=()=>{const e=qe.type;return B({modelId:e,modelType:qe.type,options:{}})};function Dm(e){return t=>{const{model:s,status:o,KosModelLoader:r}=Om();return M.jsx(r,{...o,children:M.jsx(e,{...t,canvasDispatcher:s})})}}const Sm=(e,t,s)=>{const o=atob(e),r=new Uint8ClampedArray(t*s*4);for(let n=0,i=0;n<o.length&&i<r.length;n+=3,i+=4)r[i]=o.charCodeAt(n),r[i+1]=o.charCodeAt(n+1),r[i+2]=o.charCodeAt(n+2),r[i+3]=255;return r},Am=(e,t,s)=>{const o=new Uint8ClampedArray(t*s*4);for(let r=0;r<e.length;r++){const n=e.charCodeAt(r),i=(n>>5&7)*255/7,c=(n>>2&7)*255/7,d=(n&3)*255/3,l=r*4;o[l]=i,o[l+1]=c,o[l+2]=d,o[l+3]=255}return o};function Cm({ctx:e,format:t,dataString:s,width:o,height:r,pixelSize:n}){const i=t==="base64"?Sm(s,o,r):Am(s,o,r),c=new ImageData(i,o,r),d=document.createElement("canvas");d.width=o,d.height=r;const l=d.getContext("2d");l==null||l.putImageData(c,0,0),e.imageSmoothingEnabled=!1,e.clearRect(0,0,o*n,r*n),e.drawImage(d,0,0,o*n,r*n)}const Rm=f.createLogger({name:"canvas-streamer"});Rm.debug("main-view component loaded");const ho=10,hd=ko.observer(({canvasDispatcher:e,height:t=30,width:s=50,defaultFps:o=10,showPreview:r=!1,name:n,apiPath:i="/api/system/canvas"})=>{const c=g.useRef(null),[d,l]=g.useState();g.useEffect(()=>{const h=e.addNamedEndpoint(n,{apiPath:i,fps:o,width:s,height:t,id:n});l(h)},[e]);const u=g.useCallback(h=>{if(c.current&&r){const p=c.current.getContext("2d");p&&Cm({ctx:p,format:"base64",dataString:h,height:t,width:s,pixelSize:ho})}},[s,t,r]);return g.useEffect(()=>{d&&(d.onFrame=u,d.width=s,d.height=t,d.fps=o)},[d,u,s,t,o]),r&&En.createPortal(M.jsx(Pm,{children:M.jsx(km,{children:M.jsx("canvas",{ref:c,width:s*ho,height:t*ho,style:{border:"1px solid black"}})})}),document.body)}),Lm=Dm(hd),Pm=Po.div`
|
|
148
|
+
display: flex;
|
|
149
|
+
flex-direction: column;
|
|
150
|
+
gap: 8px;
|
|
151
|
+
|
|
152
|
+
width: 100%;
|
|
153
|
+
justify-content: space-between;
|
|
154
|
+
align-items: center;
|
|
155
|
+
`,km=Po.div`
|
|
156
|
+
display: flex;
|
|
157
|
+
flex-direction: column;
|
|
158
|
+
align-items: center;
|
|
159
|
+
`,gd=()=>{const e=Rs.type;return B({modelId:e,modelType:Rs.type,options:{}})};function xm(e){return t=>{const{model:s,status:o,KosModelLoader:r}=gd();return M.jsx(r,{...o,children:M.jsx(e,{...t,device:s})})}}function Fm(e,t,s){const o=new Promise(r=>{E.getInstance().whenReady().then(()=>{const{model:n}=E.getInstance().modelManager.createModelInstance(e,t??e,s);return n.whenReady().then(()=>{r(n.modelData)})})});return Bo(o)}function Nm(e){return t=>{const{model:s,status:o,KosModelLoader:r}=Cr();return M.jsx(r,{...o,children:M.jsx(e,{...t,kosTime:s})})}}const fd=()=>{const e=Ut.type;return B({modelId:e,modelType:Ut.type,options:{}})};function Um(e){return t=>{const{model:s,status:o,KosModelLoader:r}=fd();return M.jsx(r,{...o,children:M.jsx(e,{...t,networkInterfaceContainer:s})})}}const pd=()=>{const e=Es.type;return B({modelId:e,modelType:Es.type,options:{}})};function jm(e){return t=>{const{model:s,status:o,KosModelLoader:r}=pd();return M.jsx(r,{...o,children:M.jsx(e,{...t,oTA:s})})}}function Bm(e,t){g.useEffect(()=>{function s(r){e.current&&!e.current.contains(r.target)&&t()}function o(r){r.key==="Escape"&&t()}return document.addEventListener("mousedown",s),document.addEventListener("keydown",o,!1),()=>{document.removeEventListener("mousedown",s),document.removeEventListener("keydown",o,!1)}},[e,t])}function Km(e){const t=g.useRef(null),s=e.onAlert;return Bm(t,s),M.jsx("div",{ref:t,style:{width:"100%"},children:e.children})}const Gm=e=>{var l;const{stateProp:t}=e,[s,o]=g.useState((l=e.stateProp)==null?void 0:l.value),[r,n]=g.useState(!1),[i,c]=g.useState(void 0);return g.useEffect(()=>{async function u(h){try{h&&(await J(h),n(!0))}catch(p){c(p.message)}}u(t)},[t]),g.useEffect(()=>{const u=F(()=>{t&&r&&o(t.value)});return()=>{u()}},[r,t]),[s,{ready:r,error:i}]},md=()=>{const[e,t]=g.useState(!1),[s,o]=g.useState([]),r=We.type,n=B({modelId:r,modelType:We.type,options:{}});return g.useEffect(()=>{const i=F(()=>{var c,d;t(((c=n.model)==null?void 0:c.isStorageInserted)??!1),o(((d=n.model)==null?void 0:d.data)??[])});return()=>{i()}},[n.model]),{...n,inserted:e,devices:s}};function Hm(e){return t=>{const{model:s,status:o,KosModelLoader:r}=md();return M.jsx(r,{...o,children:M.jsx(e,{...t,storageDeviceContainer:s})})}}const Vm=({timerName:e,onTimerExpired:t,timerEventActions:s,autoStart:o})=>{const r=zc.getTimer(e);return g.useEffect(()=>{const n=j(Dr,i=>{const{name:c,action:d,remainingTime:l}=i==null?void 0:i.body;c===e&&r&&(d===Sr?t({name:c,action:d,remainingTime:l,timer:r}):s!=null&&s[d]&&s[d]({name:c,action:d,remainingTime:l,timer:r}))});return o&&(r==null||r.start()),()=>{n.unsubscribe()}},[o,t,r,s,e]),{timer:r,start:r==null?void 0:r.start.bind(r),reset:r==null?void 0:r.reset.bind(r),pause:r==null?void 0:r.pause.bind(r)}},Ym=e=>{const t=/[\\^$.*+?()[\]{}|]/g;return RegExp(t.source).test(e)?e.replace(t,"\\$&"):e},zm=e=>e instanceof RegExp,qm=e=>typeof e=="string",Wm=(e,t,s)=>{if(e===""||t==="")return e;let o=t;zm(o)||(o=new RegExp("("+Ym(o)+")","gi"));const r=e.split(o);for(let n=1,i=r.length;n<i;n+=2)r[n]=s(r[n],n);return r},yd=(e,t,s)=>{let o=e;return Array.isArray(o)||(o=[o]),o.flatMap(r=>qm(r)?Wm(r,t,s):r)};function Zm(e,t){let s=e;return Object.entries(t).forEach(([o,r])=>{const n=new RegExp(`<${o}>(.*?)</${o}>|<${o}/>`,"g");s=yd(s,n,(i,c)=>r.type==="br"?M.jsx("br",{}):g.cloneElement(r,{key:`${o}-${c}`},i))}),s}const Jm=e=>{const{i18nKey:t,t:s,defaults:o,components:r,values:n={},context:i}=e,c=s(t,{defaultValue:o,data:n,context:i,returnObjects:!0}),d=Zm(c,r||{});return M.jsx("span",{className:e.className,children:d})},Ue=new Map;function Qm(e,t){if(Ue.has(e)){const s=Ue.get(e);if(s.status==="finished")return s.result;throw s.promise}else{const s=t().then(r=>{Ue.set(e,{status:"finished",result:r})},r=>{throw Ue.set(e,{status:"error",error:r}),r}),o={status:"pending",promise:s};throw Ue.set(e,o),s}}function Co(e,t){return Qm(e,t)}const Xm=async()=>{const e=await Fi(ge.type);return await J(e.model),e.model},ey=async(e,t,s)=>{const o=e.resolveNamespace(t);await J(o);for(const r of s){const n=e.resolveNamespace(r);await J(n),Ue.set(r,{status:"finished",result:n})}return o},ty=(e,t)=>{const s=[e].flat(),[o,...r]=s,n=Co(ge.type,Xm),i=s.join("__"),c=Co(i,()=>ey(n,o,r)),d=g.useMemo(()=>({exists:u=>{const h=t!=null&&t.keyPrefix?`${t.keyPrefix}.${u}`:u;return c?c.exists(h):!1}}),[t==null?void 0:t.keyPrefix,c]);return{t:g.useCallback((u,h)=>{const p=t!=null&&t.keyPrefix?`${t.keyPrefix}.${u}`:u;return c?c.resolveKey(p,h):(f.debug(`Translation model ${e} not ready for key: ${p}`),p)},[t==null?void 0:t.keyPrefix,e,c]),i18n:d}},bd=()=>{const e=ge.type;return B({modelId:e,modelType:ge.type,options:{}})};function sy(e){return t=>{const{model:s,status:o,KosModelLoader:r}=bd();return M.jsx(r,{...o,children:M.jsx(e,{...t,translationContainer:s})})}}const oy=e=>B({modelId:e,modelType:xt.type}),xr=()=>B({modelId:Ye.type,modelType:Ye.type,options:{}}),ry=({troubleType:e,condition:t})=>{const{model:s}=xr(),[o,r]=g.useState(!1),[n,i]=g.useState([]),c=g.useCallback(()=>{var d,l;return n.length>0&&((d=n[0])!=null&&d.resolvable)?(l=n[0])==null?void 0:l.resolve():Promise.resolve(void 0)},[n]);return g.useEffect(()=>F(()=>{const l=(e?s==null?void 0:s.troubles.getIndexByKey("byType",e):s==null?void 0:s.troubles.data)||[],u=t?l.filter(t):l;r(u.length>0),i(u)}),[t,s,e]),[o,c,n.length>0?n[0]:void 0,n]};function ny(e){return t=>{const{model:s,status:o,KosModelLoader:r}=xr();return M.jsx(r,{...o,children:M.jsx(e,{...t,troubleContainer:s})})}}const vd=()=>{const e=Bt.type,t=B({modelId:e,modelType:Bt.type,options:{},activate:!0,destroyOnUnmount:!0}),[s,o]=g.useState(!1),[r,n]=g.useState(!1),[i,c]=g.useState([]);return g.useEffect(()=>{const d=F(()=>{var l,u,h;o(((l=t.model)==null?void 0:l.isUsbInserted)??!1),n(((u=t.model)==null?void 0:u.hasAvailableUpdates)??!1),c(((h=t.model)==null?void 0:h.data)??[])});return()=>{d()}},[t.model]),{...t,inserted:s,updateAvailable:r,updates:i}};function iy(e){return t=>{const{model:s,status:o,KosModelLoader:r}=vd();return M.jsx(r,{...o,children:M.jsx(e,{...t,usbUpdateContainer:s})})}}const ay=({path:e,propKey:t})=>{const{status:s}=B({modelType:At.type,modelId:e,options:{path:e}}),[o,r]=g.useState(!1),[n,i]=g.useState(),[c,d]=g.useState(""),[l,u]=g.useState(),h=p=>{n&&t&&n.updateProperty(t,p)};return g.useEffect(()=>{var p;s.model&&i(s.model),s.model&&t&&((p=s.model)!=null&&p.props.has(t)?d(s.model.props[t]):u(`property ${t} not found`)),s.ready&&r(s.ready)},[s.ready,s.model,t]),g.useEffect(()=>{t&&v.autorun(()=>{const p=n==null?void 0:n.props[t];d(p||"")})},[n,t]),{config:n,ready:o,value:c,error:l,updateValue:h}},cy=(e,t)=>{switch(t.type){case"UPDATE":return t.payload;default:return e}},wd=({configProperty:e,optionsTransformer:t})=>{const[s,o]=g.useState(!1),[r,n]=g.useState(""),[i,c]=g.useReducer(cy,{value:String(e==null?void 0:e.value),displayValue:e==null?void 0:e.displayValue,significantValue:e==null?void 0:e.significantValue,unit:e==null?void 0:e.unit,options:e==null?void 0:e.options,mappedOptions:[],updateProperty:e==null?void 0:e.updateProperty,displayOptions:e==null?void 0:e.displayOptions}),d=g.useCallback(l=>{var h;let u="factory";typeof l=="string"?u=l:(h=l==null?void 0:l.target)!=null&&h.value&&(u=l.target.value),u&&(e==null||e.updateProperty(u))},[e]);return g.useEffect(()=>{async function l(u){try{u&&(await J(u),o(!0))}catch(h){n(h.message)}}l(e)},[e]),g.useEffect(()=>{const l=F(()=>{if(e&&s){let u=[];t&&(u=t(e.options)),c({type:"UPDATE",payload:{value:String(e.value),displayValue:e.displayValue,significantValue:e.significantValue,unit:e.unit,options:e.options,mappedOptions:u,updateProperty:e.updateProperty,displayOptions:e==null?void 0:e.displayOptions}})}});return()=>{l()}},[e,t,s]),{...i,configSelectProps:{onChange:d,value:i.value,options:t?i.mappedOptions||[]:i.options||[]},ready:s,error:r}};function dy(e,t){const s=t??new Date().getFullYear(),o=[31,28,31,30,31,30,31,31,30,31,30,31];return e===1&&(s%4===0&&s%100!==0||s%400===0)?29:o[e]??0}function ly(e,t){return new Date(e,t,0).getDate()}function Md(e,t){const s=dy(t,e),o=[];for(let r=1;r<=s;r++)o.push(r);return o}function _d(){return[...Array(12).keys()].map(t=>new Date(0,t).getMonth())}function Ed(e=[2018,2028]){const t=[];for(let s=e[0];s<=e[1];s++)t.push(s);return t}function Id(e,t=[2018,2028]){const s=Ed(t);return e==="long"?s:s.map(o=>Number(o.toString().substring(2)))}function Fr(e="numeric",t="en-US"){const s=new Intl.DateTimeFormat(t,{month:e,timeZone:"UTC"}).format;return[...Array(12).keys()].map(o=>s(new Date(Date.UTC(0,o,1))))}function uy({locale:e="en-US",year:t,month:s,day:o,formatOptions:r={weekday:"long",year:"numeric",month:"long",day:"numeric"},displayOrder:n}){const i=s-1,c=new Date(t,i,o),d=new Intl.DateTimeFormat(e,{month:r.month}).format(c),l=new Intl.DateTimeFormat(e,{year:r.year}).format(c),u=new Intl.DateTimeFormat(e,{day:r.day}).format(c);return n?n=="MMDDYY"?`${d} ${u} ${l}`:n==="DDMMYY"?`${u} ${d} ${l}`:n==="YYMMDD"?`${l} ${d} ${u}`:`${l} ${u} ${d}`:new Intl.DateTimeFormat(e,r).format(c)}function oe(e){return e.toString().length===2?new Date(Date.parse(`01 Jan 20${e}`)).getFullYear():e}function hy(e){return typeof e=="string"?new Date(Date.parse(`01 ${e.substring(0,3)} 2023`)).getMonth()+1:e}function Td(e,t,s){const o=oe(t),r=new Date(o,e,1).getDay(),n=new Date(o,e+1,0).getDate();return[...Array(42).keys()].map(c=>c<r||c>n+r-1?{label:"",value:0,disabled:!0}:s[c-r])}function bt(e,t,s){const o=t-1,r=new Date(e,o,s);return new Date(r).getMonth()===o&&new Date(r).getDate()===s}function vt(e,t){return new Date(e,t,0).getDate()}function $d(e="en-US",t="short"){const s=new Intl.DateTimeFormat(e,{weekday:t}).format;return[...Array(7).keys()].map(o=>s(new Date(Date.UTC(2021,5,o))))}function Od({locale:e="en-US",year:t=new Date().getFullYear(),month:s=new Date().getMonth(),yearRange:o=[2018,2028],daysOfWeekFilter:r=[],formatOptions:{yearFormat:n="long",monthFormat:i="long",dayFormat:c="short"}={}}){const d=Nr(n,o),l=Dd(n,o,e),u=Sd(i,e),h=Ad(i,e),p=Ur(t,s),w=Cd(t,s,e,r),b=Pd(s,t,w),_=Rd(e,c);return{daysArray:p,monthsArray:u,yearsArray:d,yearsOptionsArray:l,monthsOptionsArray:h,daysOptionsArray:w,calendarDayArray:b,dayNamesArray:_}}function Nr(e="long",t=[2018,2028]){return g.useMemo(()=>Id(e,t),[e,t])}function Dd(e="long",t=[2018,2028],s="en-US"){const o=Nr(e,t);return g.useMemo(()=>o.map(n=>({label:n.toLocaleString(s).replace(",",""),value:n})),[s,o])}function Sd(e,t="en-US"){return g.useMemo(()=>Fr(e,t),[e,t])}function Ad(e,t="en-US"){const s=g.useMemo(()=>_d(),[]),o=g.useMemo(()=>Fr(e,t),[e,t]);return g.useMemo(()=>[...Array(12).keys()].map(n=>({label:o[n],value:Number(s[n])})),[o,s])}function Ur(e,t){const s=oe(e);return g.useMemo(()=>Md(s,t),[t,s])}const gy=(e,t,s,o=[])=>{const r=new Date(e,t,s).getDay();return o.length>0&&o.includes(r)};function Cd(e,t,s="en-US",o=[]){const r=Ur(e,t);return g.useMemo(()=>r.map(i=>({label:i.toLocaleString(s),value:i,disabled:gy(e,t,i,o)})),[o,s,t,r,e])}function Rd(e="en-US",t="short"){return g.useMemo(()=>$d(e,t),[e,t])}function Ld({year:e=new Date().getFullYear(),month:t=new Date().getMonth(),day:s=new Date().getDate(),formatString:o}){const r=t,n=new Date(e,r,s);return{formattedDate:me.format(n,o)}}function Pd(e,t,s){return g.useMemo(()=>Td(e,t,s),[e,t,s])}var kd=(e=>(e.MMDDYY="MMDDYY",e.DDMMYY="DDMMYY",e.YYMMDD="YYMMDD",e.YYDDMM="YYDDMM",e))(kd||{});function fy({locale:e="en-US",date:{year:t=new Date().getFullYear(),month:s=new Date().getMonth(),day:o=new Date().getDate()}={year:new Date().getFullYear(),month:new Date().getMonth(),day:new Date().getDate()},formatOptions:{yearFormat:r="long",monthFormat:n="long",dayFormat:i="short",formatString:c="yyyy/MM/dd"}={},filterOptions:{yearsRange:d=[2018,2028],daysOfWeekFilter:l=[]}={}}){const[u,h]=g.useState(t),[p,w]=g.useState(d),[b,_]=g.useState(s),[I,A]=g.useState(o);g.useEffect(()=>{h(t)},[t]),g.useEffect(()=>{_(s)},[s]),g.useEffect(()=>{A(o)},[o]);const{yearsArray:se,yearsOptionsArray:we,monthsArray:rt,monthsOptionsArray:Zs,daysArray:Q,daysOptionsArray:Me,calendarDayArray:Js,dayNamesArray:Qs}=Od({locale:e,year:u,yearRange:p,month:b,formatOptions:{yearFormat:r,monthFormat:n,dayFormat:i},daysOfWeekFilter:l}),{formattedDate:Xs}=Ld({year:u,month:b,day:I,formatString:c});return{dateActions:{setYear:h,setYearRange:w,setMonth:_,setDay:A,nextMonth:()=>{const K=b<11?oe(u):oe(u+1),W=b<11?b+1:0;if(!bt(K,W,I)){const _e=vt(K,W);A(_e)}W===0&&h(K),_(W)},previousMonth:()=>{const K=oe(b===0?u-1:u),W=b===0?11:b-1;if(!bt(K,W,I)){const _e=vt(K,W);A(_e)}W===11&&h(K),_(W)},nextYear:()=>{const K=u<p[1]?u+1:p[0],W=oe(K);if(bt(W,b,I))h(K);else{const _e=vt(oe(u+1),b);A(_e),h(K)}},previousYear:()=>{const K=u>p[0]?u-1:p[0],W=oe(K);if(bt(W,b,I))h(K);else{const _e=vt(oe(u-1),b);A(_e),h(K)}}},dateState:{year:u,yearRange:p,month:b,day:I,yearsArray:se,yearsOptionsArray:we,monthsArray:rt,monthsOptionsArray:Zs,daysArray:Q,daysOptionsArray:Me,calendarDayNames:Qs,calendarDayArray:Js,formattedDate:Xs}}}function xd({date:e=new Date,dateFormat:t,timeFormat:s,options:o={}}){const[r,n]=g.useState("Formatting Time..."),[i,c]=g.useState("Formatting Date..."),d=!!o.ignoreDateFormat,{model:l,ready:u}=B({modelId:z.type,modelType:z.type,options:{}}),h=typeof e=="string"?me.parseISO(e):e;return g.useEffect(()=>{d?c(""):t?c(me.format(h,t)):u&&c(me.format(h,l!=null&&l.selectedDateFormat?l==null?void 0:l.selectedDateFormat:""))},[d,e,t,h,l,u]),g.useEffect(()=>{s?n(me.format(h,s)):u&&n(me.format(h,l!=null&&l.selectedTimeFormat?l==null?void 0:l.selectedTimeFormat:""))},[e,s,h,l,u]),{formattedDate:i,formattedTime:r}}const Fd=({secondsFromMidnight:e=0})=>{const[t,s]=g.useState(0),[o,r]=g.useState(0),[n,i]=g.useState(0),[c,d]=g.useState(new Date),{formattedTime:l}=xd({date:c,options:{ignoreDateFormat:!0}});return g.useEffect(()=>{const u=Number(e),h=Math.floor(u/3600),p=Math.floor(u%3600/60),w=u%60;s(h),r(p),i(w);const b=new Date;b.setHours(0,0,0,0);const _=new Date(b.getTime()+u*1e3);d(new Date(_))},[e]),{hours:t,minutes:o,seconds:n,formattedTime:l,timeActions:{setHours:s,setMinutes:r,setSeconds:i}}},py=({configProperty:e})=>{const{value:t}=wd({configProperty:e}),s=parseInt(t||"0",10),{hours:o,minutes:r,seconds:n,formattedTime:i,timeActions:c}=Fd({secondsFromMidnight:s}),d=g.useRef();return g.useEffect(()=>{const l=o*3600+r*60+n;return d.current&&clearTimeout(d.current),d.current=setTimeout(()=>{e&&e.updateProperty(l.toString())},100),()=>{d.current&&clearTimeout(d.current)}},[e,o,r,n]),{hours:o,minutes:r,seconds:n,formattedTime:i,timeActions:c}};function my(e,t={}){const{intervalMs:s=5*60*1e3,immediate:o=!0}=t;g.useEffect(()=>{const r=()=>{try{e({__warmup:!0})}catch{}};o&&("requestIdleCallback"in window?requestIdleCallback(r):setTimeout(r,1));const n=s?setInterval(r,s):null;return()=>{n&&clearInterval(n)}},[e,s,o])}const yy=e=>M.jsx("option",{title:e.id,value:e.format,children:e.format},e.id),by=(e=yy)=>{const[t,s]=g.useState([]),[o,r]=g.useState(),{model:n,ready:i}=B({modelType:z.type,modelId:z.type,options:{}});g.useEffect(()=>{const d=F(()=>{s((n==null?void 0:n.dateFormatOptions.map(e))||[])});return()=>{d()}},[n,i,e]),g.useEffect(()=>{const d=F(()=>{n!=null&&n.dateFormatId&&(n!=null&&n.selectedDateFormat)&&r({id:n==null?void 0:n.dateFormatId,value:n==null?void 0:n.selectedDateFormat})});return()=>{d()}},[n==null?void 0:n.selectedDateFormat,n==null?void 0:n.dateFormatId]);const c=g.useCallback(d=>{var u;let l="";typeof d=="string"?l=d:(u=d==null?void 0:d.target)!=null&&u.value&&(l=d.target.value),l&&(n==null||n.setSelectedDateFormat(l))},[n]);return{raw:(n==null?void 0:n.dateFormatOptions.map(d=>d.id))??[],regionModel:n,selectedDateFormat:(o==null?void 0:o.value)||"",dateFormatId:(o==null?void 0:o.id)||"",updateDateFormat:c,props:{onChange:c,value:(o==null?void 0:o.id)||"",options:t}}},vy=e=>M.jsx("option",{title:e,value:e,children:e},e),Nd="kos:service:region:settings",Ud="timeZone",wy=`${Nd}-${Ud}`,My=(e=vy)=>{const[t,s]=g.useState([]),[o,r]=g.useState(""),{model:n,ready:i}=B({modelType:z.type,modelId:z.type,options:{}}),c=Ce.factory(wy)({path:Nd,attribute:Ud});g.useEffect(()=>{const l=F(()=>{s((n==null?void 0:n.timeZones.map(e))||[]),n!=null&&n.timeZones.length&&Ao(n==null?void 0:n.timeZones[0])});return()=>{l()}},[n,i,e]),g.useEffect(()=>{const l=F(()=>{r(c.value||"")});return()=>{l()}},[c.value]);const d=g.useCallback(l=>{var h;let u="factory";typeof l=="string"?u=l:(h=l==null?void 0:l.target)!=null&&h.value&&(u=l.target.value),u&&Ao(u)},[]);return{options:t,raw:(n==null?void 0:n.timeZones)??[],regionModel:n,selectedTimeZone:o,timeZones:(n==null?void 0:n.timeZones)??[],updateTimeZone:d,selectProps:{onChange:d,value:o,options:t}}},jd="kos:service:region",Bd="regionId",_y=`${jd}-${Bd}`,Ey=e=>M.jsx("option",{title:e,value:e,children:e},e),Kd=(e=Ey)=>{const[t,s]=g.useState([]),[o,r]=g.useState("factory"),{model:n,ready:i}=B({modelType:z.type,modelId:z.type,options:{}}),c=Ce.factory(_y)({path:jd,attribute:Bd});g.useEffect(()=>{const l=F(()=>{s((n==null?void 0:n.availableRegions.map(e))||[])});return()=>{l()}},[n,i,e]),g.useEffect(()=>{const l=F(()=>{r(c.value||"factory")});return()=>{l()}},[c.value]);const d=g.useCallback(l=>{var h;let u="factory";typeof l=="string"?u=l:(h=l==null?void 0:l.target)!=null&&h.value&&(u=l.target.value),u&&Vc(u)},[]);return{raw:(n==null?void 0:n.availableRegions)??[],regionModel:n,regionData:n==null?void 0:n.selectedRegion,selectedRegion:o,updateRegion:d,regionSelectProps:{onChange:d,value:o,options:t}}},Iy=e=>M.jsx("option",{title:e.id,value:e.format,children:e.format},e.id),Ty=(e=Iy)=>{const[t,s]=g.useState([]),[o,r]=g.useState(),{model:n,ready:i}=B({modelType:z.type,modelId:z.type,options:{}});g.useEffect(()=>{const d=F(()=>{s((n==null?void 0:n.timeFormatOptions.map(e))||[])});return()=>{d()}},[n,i,e]),g.useEffect(()=>{const d=F(()=>{n!=null&&n.timeFormatId&&(n!=null&&n.selectedTimeFormat)&&r({id:n==null?void 0:n.timeFormatId,value:n==null?void 0:n.selectedTimeFormat})});return()=>{d()}},[n==null?void 0:n.selectedTimeFormat,n==null?void 0:n.timeFormatId]);const c=g.useCallback(d=>{var u;let l="";typeof d=="string"?l=d:(u=d==null?void 0:d.target)!=null&&u.value&&(l=d.target.value),l&&(n==null||n.setSelectedTimeFormat(l))},[n]);return{raw:(n==null?void 0:n.timeFormatOptions.map(d=>d.id))??[],regionModel:n,selectedTimeFormat:(o==null?void 0:o.value)??"",timeFormatId:(o==null?void 0:o.id)??"",updateTimeFormat:c,props:{onChange:c,value:(o==null?void 0:o.id)??"",options:t}}},$y=(e,t)=>g.useMemo(()=>Xo(e),t),Oy={config:{attributes:!0,childList:!0,subtree:!0}};function Dy(e,t,s=Oy){const[o,r]=g.useState(null);g.useEffect(()=>{if(!t||typeof t!="function")throw new Error("A valid callback function is required");const n=new MutationObserver(t);r(n)},[t,s,r]),g.useEffect(()=>{if(!o)return()=>{};if(!e)throw new Error("A valid DOM element is required");const{config:n}=s;try{o.observe(e,n)}catch(i){f.error(i)}return()=>{o&&o.disconnect()}},[o,e,s])}const Gd={validateStart:function(e){return!0},validateStop:function(e){const t=e.event.currentTarget.getBoundingClientRect(),[s,o]=e.xy;return s<t.left||s>t.right||o<t.top||o>t.bottom}},go=f.createLogger({name:"usePressGesture",group:"kos-hooks"});function Sy({onPressed:e,onRelease:t,intersectionStrategy:s=Gd}){const o=g.useRef(!1),r=el.useGesture({onDragStart:d=>{go.info("onDragStart",d.type),s.validateStart(d)&&(e&&e(),o.current=!0)},onDrag:d=>{go.info("onDrag",d.type),o.current&&s.validateStop(d)&&(t&&t(),o.current=!1)},onDragEnd:d=>{go.info("onDragEnd",d.type),o.current&&t&&(t(),o.current=!1)}}),n=()=>{e&&e(),o.current=!0},i=()=>{o.current&&t&&(t(),o.current=!1)},c=()=>{o.current&&t&&(t(),o.current=!1)};return{dom:r,mesh:()=>({onPointerDown:n,onPointerUp:i,onPointerOut:c})}}const Hd=()=>{const[e,t]=g.useState(!1),s=E.getInstance();return g.useEffect(()=>{const o=F(()=>{s&&s.reloading!==e&&t(s.reloading)});return()=>{o()}},[s,e]),[e]};function Vd(e=!1,t="2-digit"){return g.useMemo(()=>{const s=e?12:24;return Array.from({length:s},(o,r)=>{const n=e&&r===0?12:r%s;return{id:r,label:t==="2-digit"?n.toString().padStart(2,"0"):n.toString()}})},[t,e])}function Ro(e,t="2-digit",s=0,o=0){return g.useMemo(()=>Array.from({length:e},(r,n)=>{const i=String(n+s);return{id:n+o,label:t==="2-digit"?i.padStart(2,"0"):i}}),[e,s,o,t])}function Yd(e="en-US"){return g.useMemo(()=>["AM","PM"].map(t=>{const s=new Intl.DateTimeFormat(e,{hour:"2-digit",hour12:!0}).formatToParts(new Date().setHours(t==="AM"?0:12))[2].value;return{id:s,label:s}}),[e])}function zd({formatOptions:{hour12:e=!0,hour:t="2-digit",minute:s="2-digit",second:o="2-digit"}={hour12:!0,hour:"2-digit",minute:"2-digit",second:"2-digit"},locale:r="en-US"}){const n=Vd(e,t),i=Ro(60,s),c=Ro(60,o),d=Yd(r);return{hourOptions:n,minuteOptions:i,secondOptions:c,amPmOptions:d}}function qd(e,t){return me.format(e,t)}function Wd({formatOptions:e,initialDate:t=new Date,locale:s="en-US",format:o="HH:mm"}){const[r,n]=g.useState(t),i=g.useCallback(_=>{n(I=>{const A=new Date(I);return A.setHours(Number(_)),A})},[]),c=g.useCallback(_=>{n(I=>{const A=new Date(I);return A.setMinutes(Number(_)),A})},[]),d=g.useCallback(_=>{n(I=>{const A=new Date(I);return A.setSeconds(Number(_)),A})},[]),l=g.useCallback(_=>{const I=new Date(_);n(I)},[]),u=qd(r,o),{hourOptions:h,minuteOptions:p,secondOptions:w,amPmOptions:b}=zd({formatOptions:e,locale:s});return{amPmOptions:b,formattedTime:u,hourOptions:h,minuteOptions:p,secondOptions:w,setHours:i,setMinutes:c,setSeconds:d,setTime:l,time:new Date(r)}}const Ay=e=>{const{regionModel:t}=Kd(),s=g.useMemo(()=>({hour12:t==null?void 0:t.is12HourTimeFormat}),[t==null?void 0:t.is12HourTimeFormat]);return Wd({...e,locale:t==null?void 0:t.regionId,format:t==null?void 0:t.selectedTimeFormat,formatOptions:s})};function Cy(e){return t=>{const[s]=Hd();return s?M.jsx(ed,{message:"Wait a moment while your project reloads..."}):M.jsx(e,{...t})}}const wn=f.createLogger({name:"studio-properties-service",group:"Services"}),Ry="/api/kos/studio/properties",Zd=async e=>{if(wn.debug("sending GET for studio-properties"),!e)throw wn.error("connectionId is undefined"),new Error("connectionId is undefined");return await Re.get(Ry,{},{destinationAddress:e,timeout:500})},Ly=Object.freeze(Object.defineProperty({__proto__:null,getStudioProperties:Zd},Symbol.toStringTag,{value:"Module"}));var Py=Object.defineProperty,ky=Object.getOwnPropertyDescriptor,xy=(e,t,s,o)=>{for(var r=o>1?void 0:o?ky(t,s):t,n=e.length-1,i;n>=0;n--)(i=e[n])&&(r=(o?i(t,s,r):i(r))||r);return o&&r&&Py(t,s,r),r};const Jd="studio-properties-model",Fy="/kos/studio/properties",Mn={"kos.studio.tool.legacy":1};let Lo=class{constructor(e,t,s){a(this,"id");a(this,"connectionId");a(this,"unsubscribe",null);a(this,"logger");a(this,"data");this.id=e,this.logger=s.logger,this.data=ye(),this.connectionId=t.connectionId}async init(){this.logger.debug(`initializing studio-properties ${this.id}`)}async load(){this.logger.debug(`loading studio-properties ${this.id}`)}async terminatePropertiesSession(){var e;(e=this.unsubscribe)==null||e.call(this)}async initializePropertiesSession(){this.unsubscribe=Ht.getInstance().subscribeTopic({topic:Fy,destinationAddress:this.connectionId,callback:s=>{this.logger.error(`Received studio-properties message for connection ${this.connectionId}: ${JSON.stringify(s)}`)}});const[e,t]=await Zd(this.connectionId);if(e){this.logger.error(`Error loading studio-properties: ${e}`),this.data.setValues(Mn);return}if(t){const s=Object.keys(t).reduce((o,r)=>(o[r]=t[r]??r,o),{});this.data.setValues(s??Mn),f.ifDebug(()=>this.logger.debug(`studio-properties loaded: ${JSON.stringify(s)}`))}}get(e){return this.data[e]}createObservableProperty(e){return Xo(()=>this.get(e))}};Lo=xy([O(Jd)],Lo);const Ny=new ae({class:Lo,type:Jd});Object.defineProperty(exports,"makeAutoObservable",{enumerable:!0,get:()=>v.makeAutoObservable});Object.defineProperty(exports,"makeObservable",{enumerable:!0,get:()=>v.makeObservable});Object.defineProperty(exports,"kosComponent",{enumerable:!0,get:()=>ko.observer});exports.AuthState=Gi;exports.BrowserKosRouter=Xi;exports.BrowserRouter=Ks;exports.CanvasDispatcher=qe;exports.CanvasDispatcherServices=qf;exports.CanvasRenderer=wr;exports.CanvasStreamer=Lm;exports.CanvasStreamerBase=hd;exports.ChildModels=Mt;exports.ConfigBean=At;exports.CoreExtensionManager=Np;exports.CoreModels=Or;exports.CreateModelTranslationsContext=ad;exports.CreateModelTranslationsProvider=lm;exports.DateDisplayFormat=kd;exports.DateHelpers=hl;exports.DependencyLifecycle=x;exports.DependencyModels=P;exports.Device=Rs;exports.DeviceServices=ip;exports.DomIntersectionStrategy=Gd;exports.EVENT_KOS_MODEL_READY=Uo;exports.EVENT_TROUBLE_ADDED=Eh;exports.EVENT_TROUBLE_REMOVED=Ih;exports.EXTENSION_TROUBLE_DATA_MAPPER=Ms;exports.EXTENSION_TROUBLE_MAPPER=Wt;exports.ErrorBoundaryWithFallback=td;exports.EventBus=rl;exports.ExtensionManager=C;exports.FUTURE_CONTAINER_MODEL_TYPE=Oa;exports.FUTURE_MODEL_TYPE=ya;exports.FUTURE_NOT_ASSIGNED=tr;exports.FeatureFlagService=Bn;exports.FetchError=ce;exports.FutureContainerFactory=be;exports.FutureContainerModel=Sa;exports.FutureEndState=Ge;exports.FutureFactory=st;exports.FutureHandler=ar;exports.FutureManager=De;exports.FutureModel=Ea;exports.FutureService=wt;exports.HEADER_CACHE_CONTROL=On;exports.HEADER_CONTENT_TYPE=$n;exports.HEADER_DESTINATION_ADDR=fe;exports.HEADER_FOS_REQUEST_ID=Dn;exports.HEADER_METHOD=xs;exports.HEADER_ORDERED=Fo;exports.HEADER_REQUEST_ID=Kt;exports.HEADER_REQUEST_TYPE=de;exports.HEADER_RESPONSE_ID=Fs;exports.HEADER_SOURCE_ADDR=Tn;exports.HEADER_TOPIC=In;exports.HEADER_URL=Je;exports.HEADER_WORK_TRACKER=No;exports.KOS_MODEL_ID=hs;exports.KeyValue=gr;exports.KeyValueServices=bg;exports.Kos=H;exports.KosConfigPropertySpec=Ce;exports.KosContainerIndex=Qo;exports.KosContextBean=Zi;exports.KosContextManager=k;exports.KosCore=E;exports.KosCoreModelPropertyMapper=re;exports.KosDataContainer=Ji;exports.KosDependencyTypes=Dl;exports.KosExtensionUtils=Ou;exports.KosFeatureFlags=gl;exports.KosFetchMethods=vi;exports.KosGlobalConfig=Vo;exports.KosLog=f;exports.KosMockEvents=Cn;exports.KosModel=Ri;exports.KosModelCollectionProvider=nm;exports.KosModelContainer=le;exports.KosModelContext=qs;exports.KosModelEvents=D;exports.KosModelFactory=$t;exports.KosModelLoader=nd;exports.KosModelLoaderDisplay=id;exports.KosModelManager=ki;exports.KosModelProvider=sd;exports.KosModelRegistrationFactory=ae;exports.KosModelRegistry=So;exports.KosModelState=y;exports.KosModelSymbol=ii;exports.KosModelVisitor=Ju;exports.KosObservableData=Yi;exports.KosRegistration=vh;exports.KosSingletonRegistration=wh;exports.KosTime=bs;exports.KosTimeContext=Rr;exports.KosTimeProvider=bm;exports.KosTimeServices=_g;exports.KosTimer=Yc;exports.KosToken=Qi;exports.KosTranslationProvider=Tm;exports.KosTranslations=yc;exports.KosWSTransportStatus=Ci;exports.KosWsEvents=Gt;exports.LOGIN_HOST=Sn;exports.LOGIN_URL=tl;exports.LoadingMessage=ed;exports.LogBlock=kt;exports.LogBlockContainer=Hs;exports.LogConfig=Et;exports.LogStream=Dt;exports.LogStreamContainer=qt;exports.LogStreamServices=Lg;exports.MODEL_DELETION_DELAY=Pi;exports.MiddlewareChain=Vi;exports.ModelEffects=$e;exports.MultipleFutureHandler=Zh;exports.NestedModelContext=Ws;exports.NetworkInterface=Er;exports.NetworkInterfaceContainer=Ut;exports.NetworkInterfaceServices=mp;exports.ObservableData=ye;exports.Ota=Es;exports.OutsideAlerter=Km;exports.PLUGIN_EXTENSION_NAME=Du;exports.PORT=An;exports.PROFILE_LOG_DEBUG=Yn;exports.PROFILE_LOG_INFO=zn;exports.PROFILE_RELAX_STORE_VALIDATION=pl;exports.PROFILE_TOOLS_PREVIEW=Vn;exports.ParentModel=_t;exports.PluginExtensionManager=Su;exports.ProgressBar=tm;exports.ReferenceConfig=is;exports.RegionInfo=z;exports.RegionServices=Ph;exports.RegistrationManager=$;exports.Registry=xp;exports.STATUS=xo;exports.ServiceFactory=V;exports.SingletonKosModelRegistrationFactory=pe;exports.SoftwareInfo=Is;exports.SoftwareInfoContext=Pr;exports.SoftwareInfoProvider=Mm;exports.SoftwareInfoServices=ff;exports.StateBean=Ft;exports.StateBeanServices=wf;exports.StateProp=mr;exports.StatePropServices=Af;exports.StorageDevice=Ps;exports.StorageDeviceContainer=We;exports.StorageDeviceServices=Mp;exports.StudioProperties=Ny;exports.StudioPropertiesServices=Ly;exports.SubscriptionHandlers=G;exports.TIMER_END=Sr;exports.TIMER_EVENT=Dr;exports.TimerManager=zc;exports.TokenContext=ud;exports.TokenProvider=Em;exports.Topics=Ot;exports.Trans=Jm;exports.TransitionMap=as;exports.Transitions=zo;exports.Translation=Os;exports.TranslationContainer=ge;exports.TranslationContainerContext=kr;exports.TranslationContext=Bf;exports.TransportFactory=vo;exports.Trouble=xt;exports.TroubleContainer=Ye;exports.TroubleServices=Xg;exports.Troubles=X;exports.UsbUpdate=$r;exports.UsbUpdateContainer=Bt;exports.UsbUpdateServices=Ap;exports.WS_EVENT_TYPE=bc;exports.WebSocketEvents=Tt;exports.WebSocketTransport=Ht;exports.WsEventFactory=br;exports.acceptOrgInvitation=Xc;exports.addDaysToDate=Pn;exports.addFuture=va;exports.addMonthsToDate=Ln;exports.api=Ia;exports.applyMixins=il;exports.arraysEqual=al;exports.buildConfigBeanModel=Oh;exports.buildFuture=lr;exports.buildFutureModel=Ma;exports.cancelFuture=wa;exports.convert=ma;exports.convertFileSizeRaw=nl;exports.createBaseMessage=_i;exports.createBroadcastMessageResponse=$i;exports.createClient=Zo;exports.createFosBaseMessage=Mi;exports.createHeaders=mo;exports.createKosHtpMessageResponse=Oi;exports.createKosMessage=Ii;exports.createKosMessageResponse=Di;exports.createMessageBody=ve;exports.createModelDependency=fi;exports.createOptionKey=Sl;exports.createPropKey=Se;exports.createReadableStream=yo;exports.createStudioMessage=wi;exports.createStudioMessageRequest=Ei;exports.createStudioMessageResponse=Ti;exports.debounce=jn;exports.deleteFuture=ba;exports.destroyKosModel=Oe;exports.evaluateScopes=ia;exports.executeChildrenModelLifecycle=yi;exports.executeDependentModelLifecycle=ct;exports.executeListLifecycle=mi;exports.fetchModel=Fm;exports.findModel=Lu;exports.findModels=Ni;exports.formatDate=Fn;exports.formatDateSince=Rn;exports.formatDateTime=Un;exports.formatTime=Nn;exports.getAllKosCompanionModels=ku;exports.getCalendarMonthArray=Td;exports.getConfigBean=na;exports.getDayStrings=$d;exports.getDays=ly;exports.getDaysArray=Md;exports.getDaysInMonth=Ho;exports.getDependenciesByLifecycle=pi;exports.getFormattedDate=uy;exports.getFormattedMonth=hy;exports.getFormattedMonthsArray=Fr;exports.getFormattedYear=oe;exports.getFormattedYearsArray=Id;exports.getFutures=og;exports.getKosCompanionModel=Pu;exports.getKosLocalizationDescriptor=hc;exports.getKosMessageLogging=Qn;exports.getKosModel=Fi;exports.getKosModelSync=Xe;exports.getKosModelType=Ru;exports.getKosSessionKey=Wi;exports.getLastDayOfMonth=vt;exports.getLocalizationDescriptor=Rf;exports.getLogLevel=Jn;exports.getLogMessageToStudio=Xn;exports.getMessageBody=bo;exports.getMonthsArray=_d;exports.getObservableCompanions=xu;exports.getQueryParams=ee;exports.getTranslations=uc;exports.getYearsArray=Ed;exports.hasDecimals=oa;exports.hasKosProfile=fo;exports.hslStringToHex=Gn;exports.hslToHex=Kn;exports.initKosProvider=hm;exports.isBoolean=or;exports.isKosCompanionTypeFactory=Li;exports.isKosDataModel=It;exports.isKosLoggingEnabled=bl;exports.isKosModel=te;exports.isKosModelContainer=qo;exports.isKosModelReady=fs;exports.isLeapYear=Go;exports.isLocalRefId=gh;exports.isNumber=Us;exports.isPrintable=Hl;exports.isValidDate=bt;exports.kosAction=Y;exports.kosAutoEffect=F;exports.kosChild=ie;exports.kosCompanion=Fl;exports.kosComputed=Xo;exports.kosConfigBean=js;exports.kosConfigProperty=Wh;exports.kosContext=Nl;exports.kosDependency=Ae;exports.kosEffect=ta;exports.kosFuture=Ar;exports.kosLogger=Ul;exports.kosModel=O;exports.kosModelEffect=ai;exports.kosObservable=er;exports.kosParentAware=Ns;exports.kosReference=jl;exports.kosStateBean=Hp;exports.kosStateProp=Vp;exports.kosSubscribe=Bl;exports.kosTopicHandler=R;exports.kosWhen=Mo;exports.login=Zc;exports.mapConfigBeanModelToDto=la;exports.mapDataToModel=po;exports.mapDtoToConfigBeanModel=ca;exports.mapDtoToFutureModel=dr;exports.mapDtoToFutureOptions=cr;exports.mapUpdateDtoToConfigBeanModel=da;exports.modelEventTopicFactory=ri;exports.modelFactory=et;exports.modelTypeEventTopicFactory=ni;exports.modifyConfigBean=ra;exports.modifyFuture=rg;exports.pairedClientHeartbeat=rh;exports.pipe=qi;exports.preloadKosModel=Uu;exports.processId=ul;exports.processMiddleware=eh;exports.registerCompanionModel=Nu;exports.registerCoreModels=Kc;exports.registerExtensionPoint=Yo;exports.registerKosModel=ji;exports.registerLegacyModel=Ui;exports.resetKosModel=xi;exports.resetPassword=Qc;exports.resolveBaseUrl=Hi;exports.resolveChild=bi;exports.resolveContainerDeltas=cl;exports.resolveItemListDeltas=ll;exports.resolveKosCompanion=wo;exports.resolveKosContext=mh;exports.resolveKosProfiles=Wn;exports.resolveListDeltas=dl;exports.resolveServiceUrl=q;exports.resolveVariable=Hn;exports.retryWithExponentialBackoff=ih;exports.sendAsyncIntent=_h;exports.sendBroadcastMessage=du;exports.sendIntent=Mh;exports.sendKosHttpMessageResponse=Ai;exports.sendKosMessage=iu;exports.sendKosMessageResponse=Si;exports.sendRequest=fh;exports.sendStudioMessage=cu;exports.sendStudioMessageRequest=au;exports.startPasswordReset=Jc;exports.stringComponentInsert=yd;exports.studioAcceptOrgInvitation=Wp;exports.studioLogin=Yp;exports.studioResetPassword=qp;exports.studioStartPasswordReset=zp;exports.subscribeStore=Up;exports.syncPublish=ph;exports.transitionToActive=li;exports.transitionToInit=gi;exports.transitionToLoad=hi;exports.transitionToReady=ui;exports.transitionToUnload=Gl;exports.troubleByTypeReducer=Kf;exports.troubleDataFactory=tc;exports.unloadKosModel=Cu;exports.updateCompanionModelRegistration=sh;exports.updateModelRegistration=th;exports.updateRegion=Vc;exports.updateTimeZone=Ao;exports.useAmPmValues=Yd;exports.useCalendarDayArray=Pd;exports.useConfigBean=ay;exports.useConfigProperty=wd;exports.useContextModel=om;exports.useContextModelHierarchy=rd;exports.useDateArrays=Od;exports.useDateProps=fy;exports.useDateRelativeConfig=py;exports.useDateRelativeData=Fd;exports.useDayNames=Rd;exports.useDayOptions=Cd;exports.useDays=Ur;exports.useDevice=gd;exports.useFormattedDate=Ld;exports.useFormattedTime=qd;exports.useFunctionWarmup=my;exports.useHourValues=Vd;exports.useKosCore=dd;exports.useKosDateFormats=by;exports.useKosModel=B;exports.useKosRegions=Kd;exports.useKosTime=Cr;exports.useKosTimeContext=vm;exports.useKosTimeFormats=Ty;exports.useKosTimeZones=My;exports.useKosTranslation=ty;exports.useKosTranslationContext=$m;exports.useLocalComputed=$y;exports.useModelFromHierarchy=am;exports.useMonths=Sd;exports.useMonthsOptions=Ad;exports.useMutationObserver=Dy;exports.useNetworkInterfaceContainer=fd;exports.useOta=pd;exports.usePressGesture=Sy;exports.useProjectReload=Hd;exports.useRegionTimeProps=Ay;exports.useRegionalTimeDate=xd;exports.useSoftwareInfo=Lr;exports.useSoftwareInfoContext=_m;exports.useStateProperty=Gm;exports.useStorageDeviceContainer=md;exports.useSuspenseData=Co;exports.useTimeOptions=zd;exports.useTimeProps=Wd;exports.useTimeValues=Ro;exports.useTimer=Vm;exports.useTranslationContainer=bd;exports.useTroubleContainerModel=xr;exports.useTroubleModel=oy;exports.useTroublePresence=ry;exports.useUsbUpdateContainer=vd;exports.useYears=Nr;exports.useYearsOptions=Dd;exports.uuid=Qe;exports.variableToHex=fl;exports.waitForRequest=Jo;exports.whenReady=J;exports.withDevice=xm;exports.withKosTime=Nm;exports.withNetworkInterfaceContainer=Um;exports.withOta=jm;exports.withProjectReloading=Cy;exports.withSoftwareInfo=wm;exports.withStorageDeviceContainer=Hm;exports.withTranslationContainer=sy;exports.withTroubleContainer=ny;exports.withUsbUpdateContainer=iy;exports.wrapPromise=Bo;
|
|
148
160
|
//# sourceMappingURL=index.cjs.map
|