@miravo/cli-linux-arm64-musl 0.7.4 → 0.7.5
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/console-dist/assets/{api-DimikzPd.js → api-D8oAzcVE.js} +1 -1
- package/console-dist/assets/catalog-B70TugE6.js +1 -0
- package/console-dist/assets/{catalog-CbdG58Mn.js → catalog-B_wh8kje.js} +1 -1
- package/console-dist/assets/{catalog-source-C4jQdH37.js → catalog-source-BU77f8QO.js} +1 -1
- package/console-dist/assets/control-CaFfl-Mp.js +1 -0
- package/console-dist/assets/control-DCNd1A3U.js +1 -0
- package/console-dist/assets/events-BjMeLN1K.js +1 -0
- package/console-dist/assets/{events-BP1rvN5g.js → events-CeR9wTII.js} +1 -1
- package/console-dist/assets/fleet-C9wGf070.js +1 -0
- package/console-dist/assets/{fleet-ne7gllQE.js → fleet-CH141gbg.js} +1 -1
- package/console-dist/assets/{index-Ds1n4iXS.js → index-ClSUHPGP.js} +3 -3
- package/console-dist/assets/{instance-detail-k6fWu2DS.js → instance-detail-DWELGCE1.js} +1 -1
- package/console-dist/assets/{login-BmyMgUK4.js → login-C5dQKX2Y.js} +1 -1
- package/console-dist/assets/{models-C_UOiHSF.js → models-CFdqSxB3.js} +1 -1
- package/console-dist/assets/models-hAhKpuYB.js +1 -0
- package/console-dist/assets/platforms-Bh63oQIi.js +1 -0
- package/console-dist/assets/{platforms-CmsbDw-2.js → platforms-BwYPf2Sg.js} +1 -1
- package/console-dist/assets/{query-fetch-error-Bcg_UjHM.js → query-fetch-error-NbPqVPRR.js} +1 -1
- package/console-dist/assets/{route-preload-BO6weHRR.js → route-preload-DQgHHtBj.js} +2 -2
- package/console-dist/assets/{tags-DORoU260.js → tags-BI93Dvh2.js} +1 -1
- package/console-dist/assets/tags-_ufsHpn5.js +1 -0
- package/console-dist/assets/{transition-nav-link-nVD3H66a.js → transition-nav-link-Ct6VIy2S.js} +1 -1
- package/console-dist/assets/{use-engine-command-mutation-C8S_hX0O.js → use-engine-command-mutation-CcfqRB7j.js} +1 -1
- package/console-dist/assets/{use-platform-stream-CZLW085n.js → use-platform-stream-DBZo6HMM.js} +1 -1
- package/console-dist/assets/{use-transition-navigate-jMR-y4bs.js → use-transition-navigate-jTHkLHMS.js} +1 -1
- package/console-dist/assets/{validation-DLydiTzj.js → validation-DRj8OKvB.js} +1 -1
- package/console-dist/index.html +17 -17
- package/miravo +0 -0
- package/package.json +1 -1
- package/console-dist/assets/catalog-8tLjGq7E.js +0 -1
- package/console-dist/assets/control-4ugKUt8n.js +0 -1
- package/console-dist/assets/control-BVr4X_wI.js +0 -1
- package/console-dist/assets/events-BcZCvJ63.js +0 -1
- package/console-dist/assets/fleet-nhb_0n25.js +0 -1
- package/console-dist/assets/models-DiO_AS9_.js +0 -1
- package/console-dist/assets/platforms-npS30Kgk.js +0 -1
- package/console-dist/assets/tags-nwfbo5cT.js +0 -1
|
@@ -1 +1 @@
|
|
|
1
|
-
import{a as e}from"./rolldown-runtime-COnpUsM8.js";import{c as t}from"./vendor-charts-95ykyDlI.js";import{at as n}from"./vendor-ui-CWUk2ulb.js";import{J as r,S as i,X as a,Y as o,b as s,o as c,x as l}from"./api-DimikzPd.js";import{a as u,c as d,i as f,r as p,t as m}from"./query-fetch-error-Bcg_UjHM.js";import{t as h}from"./proxy-Be4WzmcS.js";import{t as g}from"./AnimatePresence-CPmH1DMY.js";import{i as _,r as v}from"./dist-xY0pK9Wy.js";import{n as y}from"./chunk-OE4NN4TA-DBWZidbW.js";import{a as b,i as x,l as S,n as C,o as w,r as ee,s as T,t as E}from"./copy-button-BvU3RDZa.js";import{C as D,S as O,m as k,o as A,u as j,w as M,x as N}from"./format-CshN6yEB.js";import{n as P,t as F}from"./utils-XFKvwlFT.js";import{t as I}from"./activity-Cy_niK56.js";import{t as L}from"./arrow-right-BjBb4z7g.js";import{C as R,E as te,S as z,T as B,_ as ne,a as V,b as re,c as ie,d as ae,f as H,g as oe,i as se,l as ce,m as le,n as ue,o as de,p as U,r as fe,s as pe,t as me,u as he,v as ge,w as _e,y as ve}from"./use-platform-stream-CZLW085n.js";import{n as ye,t as be}from"./catalog-template-icons-3S8RvUxD.js";import{c as xe,i as W,l as Se,n as Ce,s as we,t as Te}from"./select-CmlY1M1a.js";import{a as Ee,i as De,r as G}from"./platform-targets-BIQ1lKOg.js";import{c as Oe,i as ke,n as Ae,o as je,r as Me,s as Ne,t as Pe}from"./tabs-4SeH2unv.js";import{i as Fe,n as K,r as Ie,t as Le}from"./checkbox-C_4HRnS_.js";import{t as Re}from"./layers-1figUpjG.js";import{t as ze}from"./triangle-alert-BXrJNk3g.js";import{i as Be,n as Ve,t as He}from"./tooltip-D1ydB4g3.js";import{t as Ue}from"./badge-eIn_7YrK.js";import{a as We,i as Ge,n as Ke,o as qe,r as Je,s as Ye,t as Xe}from"./dropdown-menu-CrPXVXpG.js";import{t as Ze}from"./label-CMBWxUhA.js";import{t as q}from"./get-error-message-Dk8elqEP.js";var Qe=class extends d{constructor(e,t){super(e,t)}bindMethods(){super.bindMethods(),this.fetchNextPage=this.fetchNextPage.bind(this),this.fetchPreviousPage=this.fetchPreviousPage.bind(this)}setOptions(e){super.setOptions({...e,behavior:a()})}getOptimisticResult(e){return e.behavior=a(),super.getOptimisticResult(e)}fetchNextPage(e){return this.fetch({...e,meta:{fetchMore:{direction:`forward`}}})}fetchPreviousPage(e){return this.fetch({...e,meta:{fetchMore:{direction:`backward`}}})}createResult(e,t){let{state:n}=e,i=super.createResult(e,t),{isFetching:a,isRefetching:s,isError:c,isRefetchError:l}=i,u=n.fetchMeta?.fetchMore?.direction,d=c&&u===`forward`,f=a&&u===`forward`,p=c&&u===`backward`,m=a&&u===`backward`;return{...i,fetchNextPage:this.fetchNextPage,fetchPreviousPage:this.fetchPreviousPage,hasNextPage:r(t,n.data),hasPreviousPage:o(t,n.data),isFetchNextPageError:d,isFetchingNextPage:f,isFetchPreviousPageError:p,isFetchingPreviousPage:m,isRefetchError:l&&!d&&!p,isRefetching:s&&!f&&!m}}};function $e(e,t){return u(e,Qe,t)}var et=P(`clipboard-list`,[[`rect`,{width:`8`,height:`4`,x:`8`,y:`2`,rx:`1`,ry:`1`,key:`tgr4d6`}],[`path`,{d:`M16 4h2a2 2 0 0 1 2 2v14a2 2 0 0 1-2 2H6a2 2 0 0 1-2-2V6a2 2 0 0 1 2-2h2`,key:`116196`}],[`path`,{d:`M12 11h4`,key:`1jrz19`}],[`path`,{d:`M12 16h4`,key:`n85exb`}],[`path`,{d:`M8 11h.01`,key:`1dfujw`}],[`path`,{d:`M8 16h.01`,key:`18s6g9`}]]),tt=P(`clock-3`,[[`circle`,{cx:`12`,cy:`12`,r:`10`,key:`1mglay`}],[`path`,{d:`M12 6v6h4`,key:`135r8i`}]]),nt=P(`ellipsis`,[[`circle`,{cx:`12`,cy:`12`,r:`1`,key:`41hilf`}],[`circle`,{cx:`19`,cy:`12`,r:`1`,key:`1wjl8i`}],[`circle`,{cx:`5`,cy:`12`,r:`1`,key:`1pcz8c`}]]),rt=P(`pencil`,[[`path`,{d:`M21.174 6.812a1 1 0 0 0-3.986-3.987L3.842 16.174a2 2 0 0 0-.5.83l-1.321 4.352a.5.5 0 0 0 .623.622l4.353-1.32a2 2 0 0 0 .83-.497z`,key:`1a8usu`}],[`path`,{d:`m15 5 4 4`,key:`1mk7zo`}]]),it=P(`upload`,[[`path`,{d:`M12 3v12`,key:`1x0j5s`}],[`path`,{d:`m17 8-5-5-5 5`,key:`7q97r8`}],[`path`,{d:`M21 15v4a2 2 0 0 1-2 2H5a2 2 0 0 1-2-2v-4`,key:`ih7n3h`}]]),J=e(t(),1),Y=n();function X({className:e,...t}){return(0,Y.jsx)(`div`,{"data-slot":`skeleton`,className:F(`animate-pulse rounded-[var(--miravo-radius-tight)] bg-muted`,e),...t})}var at=`rounded-(--miravo-radius-stadium-sm) border border-dashed border-border/55 bg-muted/10`;function ot(){return(0,Y.jsx)(`p`,{className:`mt-2 text-pretty text-sm leading-relaxed text-muted-foreground`,children:`Add a target to get started.`})}function st({onClick:e}){return(0,Y.jsxs)(O,{type:`button`,size:`sm`,className:`h-7 shrink-0 gap-1.5 text-xs`,onClick:e,children:[(0,Y.jsx)(B,{className:`size-3.5`,"aria-hidden":!0}),`Add Target`]})}function ct({titleId:e,frameIcon:t,description:n,children:r}){return(0,Y.jsx)(`section`,{"aria-labelledby":e,className:at,children:(0,Y.jsxs)(`div`,{className:`flex flex-col items-center gap-4 px-4 py-10 text-center`,children:[(0,Y.jsx)(`div`,{className:`flex size-12 items-center justify-center rounded-(--miravo-radius-stadium-sm) border border-dashed border-border/50`,children:t}),(0,Y.jsxs)(`div`,{className:`max-w-sm`,children:[(0,Y.jsx)(`h2`,{id:e,className:`font-heading text-sm font-semibold tracking-tight text-foreground`,children:`No targets yet`}),n]}),r]})})}function lt({stream:e,onReset:t,catalogTemplates:n}){if(!e.operation&&e.status!==`running`)return null;let{title:r,subtitle:i}=ve(e),a=e.status===`complete`,o=e.status===`error`,s=e.status===`running`,c=a||o,l=e.cancelRequested;async function u(){await e.cancel().catch(()=>{})}return(0,Y.jsx)(U,{title:r,subtitle:i,footerAction:s&&e.operation?.operationId?(0,Y.jsx)(`div`,{className:`ml-auto shrink-0`,children:(0,Y.jsx)(`button`,{type:`button`,onClick:u,disabled:l,"aria-busy":l,className:F(D({variant:`outline`,size:`sm`}),`group h-8 gap-1.5 px-3 text-xs`,l?`cursor-not-allowed`:`hover:bg-destructive/12 hover:text-destructive hover:border-destructive/35`),children:l?(0,Y.jsxs)(Y.Fragment,{children:[(0,Y.jsx)(je,{className:`size-3.5 shrink-0 animate-spin text-muted-foreground`,"aria-hidden":!0}),(0,Y.jsx)(h.span,{animate:{opacity:[1,.72,1]},transition:{duration:1.25,repeat:1/0,ease:`easeInOut`},className:`font-medium text-foreground`,children:`Cancelling…`})]}):(0,Y.jsxs)(Y.Fragment,{children:[(0,Y.jsx)(M,{className:`size-3.5 shrink-0 text-foreground/65 group-hover:text-destructive`,"aria-hidden":!0}),(0,Y.jsx)(h.span,{animate:{opacity:[1,.88,1]},transition:{duration:2.2,repeat:1/0,ease:`easeInOut`},children:`Cancel`})]})})}):c?(0,Y.jsxs)(`div`,{className:`flex w-full flex-col gap-1.5`,children:[(0,Y.jsxs)(`div`,{className:`flex min-w-0 w-full flex-1 flex-wrap items-center justify-between gap-x-3 gap-y-1`,children:[(0,Y.jsxs)(y,{to:`/platforms?tab=activity`,className:F(D({variant:`ghost`,size:`xs`}),`group inline-flex h-6 shrink-0 items-center gap-1.5 px-2 text-[11px] font-medium text-foreground/80`,`hover:bg-primary/12 hover:text-primary`),children:[(0,Y.jsx)(I,{className:`size-3 shrink-0 text-foreground/70 group-hover:text-primary`,"aria-hidden":!0}),`View full activity`,(0,Y.jsx)(Ee,{className:`size-2.5 shrink-0 text-foreground/50 group-hover:text-primary`,"aria-hidden":!0})]}),(0,Y.jsx)(`div`,{className:`flex shrink-0 items-center`,children:(0,Y.jsx)(O,{type:`button`,variant:`secondary`,size:`xs`,className:`h-6 px-2.5 text-[11px] font-medium`,onClick:t,children:`Close`})})]}),e.operation?.status===`cancelled`||o&&e.operation?(0,Y.jsx)(ne,{type:e.operation.type,errorMessage:e.operation.error,className:`mt-2.5 w-full min-w-0`}):null]}):void 0,onDismiss:t,children:e.operation?(0,Y.jsx)(oe,{operation:e.operation,catalogTemplates:n,logs:e.logs}):(0,Y.jsxs)(`div`,{className:`flex flex-col gap-2 py-1`,children:[(0,Y.jsxs)(`div`,{className:`flex items-center gap-2`,children:[(0,Y.jsx)(je,{className:`size-3.5 animate-spin text-primary`,"aria-hidden":!0}),(0,Y.jsx)(`span`,{className:`text-xs text-foreground/78`,children:`Connecting to Litmus Edge…`})]}),(0,Y.jsx)(`div`,{className:`h-1 w-full overflow-hidden rounded-full bg-muted/55`,children:(0,Y.jsx)(h.div,{className:`h-full w-2/5 rounded-full bg-primary`,animate:{x:[`-100%`,`250%`]},transition:{duration:1.2,repeat:1/0,ease:`easeInOut`}})})]})})}var ut=`miravo:platforms:recent-template-ids`,dt=8,ft=`miravo:platforms:last-target-id`;function Z(){if(typeof window>`u`)return[];try{let e=window.localStorage.getItem(ut),t=e?JSON.parse(e):[];return Array.isArray(t)?t.filter(e=>typeof e==`string`):[]}catch{return[]}}function pt(e){if(typeof window>`u`)return;let t=[e,...Z().filter(t=>t!==e)].slice(0,dt);try{window.localStorage.setItem(ut,JSON.stringify(t))}catch{}}function mt(){if(!(typeof window>`u`))try{return window.localStorage.getItem(ft)??void 0}catch{return}}function ht(e){if(!(typeof window>`u`))try{window.localStorage.setItem(ft,e)}catch{}}function gt(e){return e instanceof DOMException&&e.name===`AbortError`||e instanceof Error&&e.name===`AbortError`}function _t(e){return e.map(e=>e.length===0?e:e.charAt(0).toUpperCase()+e.slice(1)).join(`, `)}function vt({onCloseTable:e,planKind:t=`apply`}){return(0,Y.jsx)(`div`,{className:`border-b border-border/40 px-3 py-3 sm:px-4`,children:(0,Y.jsxs)(`div`,{className:`flex gap-3`,children:[(0,Y.jsx)(`div`,{className:`flex size-10 shrink-0 items-center justify-center rounded-[var(--miravo-radius-stadium-sm)] border border-border/50 bg-muted/15`,children:(0,Y.jsx)(et,{className:`size-4 text-muted-foreground`,"aria-hidden":!0})}),(0,Y.jsxs)(`div`,{className:`flex min-w-0 flex-1 items-start gap-1 pt-0.5 sm:gap-2`,children:[(0,Y.jsxs)(`div`,{className:`min-w-0 flex-1`,children:[(0,Y.jsxs)(`div`,{className:`flex flex-wrap items-baseline gap-2`,children:[(0,Y.jsx)(`p`,{className:`font-heading text-[11px] font-semibold uppercase tracking-[0.14em] text-foreground`,children:t===`cleanup`?`Expected removals`:`Expected changes`}),(0,Y.jsx)(`span`,{className:`rounded-[var(--miravo-radius-tight)] border border-primary/25 bg-primary/5 px-1.5 py-px font-mono text-[9px] uppercase tracking-wider text-primary/90`,children:`Draft`})]}),(0,Y.jsx)(`p`,{className:`mt-1.5 max-w-prose text-[10px] leading-relaxed text-muted-foreground`,children:t===`cleanup`?`Preview only — nothing runs until you confirm cleanup.`:`Preview only — nothing runs until you confirm deploy.`})]}),e&&(0,Y.jsx)(O,{type:`button`,variant:`ghost`,size:`icon`,className:`size-8 shrink-0 text-muted-foreground hover:text-foreground`,onClick:e,"aria-label":`Close table`,children:(0,Y.jsx)(M,{className:`size-4`,"aria-hidden":!0})})]})]})})}var yt={create:`border-success/30 bg-success/12 text-success`,update:`border-info/30 bg-info/12 text-info`,replace:`border-chart-2/30 bg-chart-2/12 text-chart-2`,delete:`border-destructive/30 bg-destructive/12 text-destructive`,noop:`border-border/50 bg-muted/50 text-foreground/75`,blocked:`border-warning/30 bg-warning/12 text-warning`};function bt({plan:e,planKind:t}){let n=t===`apply`&&e.sourceHostname!=null&&e.sourceHostname!==``;return(0,Y.jsx)(`div`,{className:`border-b border-border/35 bg-muted/10 px-3 py-2 sm:px-4`,children:(0,Y.jsxs)(`div`,{className:`flex flex-col gap-1.5 text-[10px] leading-snug sm:flex-row sm:flex-wrap sm:items-baseline sm:gap-x-4 sm:gap-y-1`,children:[(0,Y.jsxs)(`div`,{className:`flex min-w-0 flex-wrap items-baseline gap-x-2 gap-y-0.5`,children:[(0,Y.jsx)(`span`,{className:`shrink-0 font-mono text-[9px] uppercase tracking-wider text-muted-foreground/85`,children:`Target LE`}),(0,Y.jsx)(`span`,{className:`font-mono text-foreground/90 wrap-anywhere`,children:e.targetHost})]}),n?(0,Y.jsxs)(`div`,{className:`flex min-w-0 flex-wrap items-baseline gap-x-2 gap-y-0.5 sm:border-l sm:border-border/50 sm:pl-4`,children:[(0,Y.jsx)(`span`,{className:`shrink-0 font-mono text-[9px] uppercase tracking-wider text-muted-foreground/85`,children:z}),(0,Y.jsx)(`span`,{className:`font-mono text-foreground/90 wrap-anywhere`,children:e.sourceHostname})]}):null]})})}function xt({entries:e}){let t=e.reduce((e,t)=>(e[t.action]++,e),{create:0,update:0,replace:0,delete:0,noop:0,blocked:0});return(0,Y.jsxs)(`div`,{className:`flex flex-wrap items-center gap-2 border-b border-border/35 px-3 py-2.5 sm:px-4`,children:[(0,Y.jsx)(`span`,{className:`sr-only`,children:`Summary of planned actions`}),(0,Y.jsx)(`span`,{className:`font-mono text-[9px] uppercase tracking-[0.18em] text-muted-foreground`,children:`Manifest`}),(0,Y.jsx)(`span`,{className:`hidden h-3 w-px bg-border/60 sm:block`,"aria-hidden":!0}),(0,Y.jsxs)(`div`,{className:`flex min-w-0 flex-1 flex-wrap items-center gap-2`,children:[t.create>0&&(0,Y.jsxs)(`span`,{className:`inline-flex items-center rounded-[var(--miravo-radius-tight)] border border-success/25 bg-success/10 px-2 py-0.5 font-mono text-[10px] tabular-nums text-success`,children:[`+`,t.create,` new`]}),t.update>0&&(0,Y.jsxs)(`span`,{className:`inline-flex items-center rounded-[var(--miravo-radius-tight)] border border-info/25 bg-info/10 px-2 py-0.5 font-mono text-[10px] tabular-nums text-info`,children:[`~`,t.update,` update`]}),t.replace>0&&(0,Y.jsxs)(`span`,{className:`inline-flex items-center rounded-[var(--miravo-radius-tight)] border border-chart-2/25 bg-chart-2/10 px-2 py-0.5 font-mono text-[10px] tabular-nums text-chart-2`,children:[`↺`,t.replace,` replace`]}),t.delete>0&&(0,Y.jsxs)(`span`,{className:`inline-flex items-center rounded-[var(--miravo-radius-tight)] border border-destructive/25 bg-destructive/10 px-2 py-0.5 font-mono text-[10px] tabular-nums text-destructive`,children:[`−`,t.delete,` remove`]}),t.noop>0&&(0,Y.jsxs)(`span`,{className:`inline-flex items-center rounded-[var(--miravo-radius-tight)] border border-border/50 bg-muted/50 px-2 py-0.5 font-mono text-[10px] tabular-nums text-foreground/75`,children:[`=`,t.noop,` unchanged`]}),t.blocked>0&&(0,Y.jsxs)(`span`,{className:`inline-flex items-center rounded-[var(--miravo-radius-tight)] border border-warning/25 bg-warning/10 px-2 py-0.5 font-mono text-[10px] tabular-nums text-warning`,children:[t.blocked,` skipped`]})]})]})}function St({plan:e,onCloseTable:t,planKind:n=`apply`}){return e.entries.length===0?(0,Y.jsxs)(`div`,{className:`overflow-hidden rounded-[var(--miravo-radius-stadium-sm)] border border-dashed border-border/55`,children:[(0,Y.jsx)(vt,{onCloseTable:t,planKind:n}),(0,Y.jsx)(bt,{plan:e,planKind:n}),(0,Y.jsxs)(`div`,{className:`flex flex-col items-center gap-3 px-4 py-10 text-center`,children:[(0,Y.jsx)(`div`,{className:`flex size-12 items-center justify-center rounded-[var(--miravo-radius-stadium-sm)] border border-border/50`,children:(0,Y.jsx)(et,{className:`size-6 text-muted-foreground/45`,"aria-hidden":!0})}),(0,Y.jsxs)(`div`,{children:[(0,Y.jsx)(`p`,{className:`font-heading text-sm font-semibold tracking-tight text-foreground`,children:n===`cleanup`?`Nothing to remove`:`Nothing to change`}),(0,Y.jsx)(`p`,{className:`mx-auto mt-2 max-w-sm text-[11px] leading-relaxed text-muted-foreground`,children:n===`cleanup`?`No Miravo-managed resources matched this cleanup scope on the environment — nothing would be deleted.`:`This environment already matches what is on the target — no create or update steps.`})]})]})]}):(0,Y.jsxs)(`div`,{className:`overflow-hidden rounded-[var(--miravo-radius-stadium-sm)] border border-border/45`,children:[(0,Y.jsx)(vt,{onCloseTable:t,planKind:n}),(0,Y.jsx)(bt,{plan:e,planKind:n}),(0,Y.jsx)(xt,{entries:e.entries}),(0,Y.jsx)(`div`,{className:`overflow-x-auto`,children:(0,Y.jsxs)(`table`,{className:`w-full min-w-lg text-xs`,children:[(0,Y.jsx)(`caption`,{className:`sr-only`,children:n===`cleanup`?`Detailed list of planned cleanup actions in deletion order`:`Detailed list of create, update, and delete actions in deployment order`}),(0,Y.jsx)(`thead`,{children:(0,Y.jsxs)(`tr`,{className:`border-b border-border/45`,children:[(0,Y.jsx)(`th`,{scope:`col`,className:`sticky top-0 z-10 bg-background px-3 py-2 text-left font-heading text-[9px] font-semibold uppercase tracking-[0.14em] text-muted-foreground sm:px-3.5`,children:`Action`}),(0,Y.jsx)(`th`,{scope:`col`,className:`sticky top-0 z-10 bg-background px-3 py-2 text-left font-heading text-[9px] font-semibold uppercase tracking-[0.14em] text-muted-foreground sm:px-3.5`,children:`Type`}),(0,Y.jsx)(`th`,{scope:`col`,className:`sticky top-0 z-10 bg-background px-3 py-2 text-left font-heading text-[9px] font-semibold uppercase tracking-[0.14em] text-muted-foreground sm:px-3.5`,children:`Name`}),(0,Y.jsx)(`th`,{scope:`col`,className:`sticky top-0 z-10 hidden bg-background px-3 py-2 text-left font-heading text-[9px] font-semibold uppercase tracking-[0.14em] text-muted-foreground sm:table-cell sm:px-3.5`,children:`Protocol`}),(0,Y.jsx)(`th`,{scope:`col`,className:`sticky top-0 z-10 hidden bg-background px-3 py-2 text-left font-heading text-[9px] font-semibold uppercase tracking-[0.14em] text-muted-foreground md:table-cell md:px-3.5`,children:`Detail`})]})}),(0,Y.jsx)(`tbody`,{children:e.entries.map((e,t)=>(0,Y.jsxs)(`tr`,{className:F(`border-b border-border/25 transition-colors`,t%2==1?`bg-muted/35`:`bg-transparent`,`hover:bg-primary/4`),children:[(0,Y.jsx)(`td`,{className:`px-3 py-2 align-middle sm:px-3.5`,children:(0,Y.jsx)(Ue,{variant:`outline`,className:F(`border px-1.5 py-0 font-mono text-[10px] uppercase tracking-wide`,yt[e.action]),children:e.action})}),(0,Y.jsx)(`td`,{className:`px-3 py-2 align-middle font-mono text-[11px] text-foreground sm:px-3.5`,children:e.resourceType}),(0,Y.jsx)(`td`,{className:`max-w-[min(16rem,28vw)] truncate px-3 py-2 align-middle font-mono text-[11px] text-foreground sm:max-w-xs sm:px-3.5`,children:e.name}),(0,Y.jsx)(`td`,{className:`hidden px-3 py-2 align-middle font-mono text-[11px] text-muted-foreground sm:table-cell sm:px-3.5`,children:e.protocol??`—`}),(0,Y.jsx)(`td`,{className:`hidden max-w-xs truncate px-3 py-2 align-middle text-[11px] text-muted-foreground md:table-cell md:px-3.5`,children:e.blockReason??e.detail??`—`})]},`${e.action}-${e.resourceType}-${e.name}-${e.protocol??``}-${e.detail??e.blockReason??``}`))})]})}),(0,Y.jsxs)(`div`,{className:`flex flex-col gap-2 border-t border-border/40 px-3 py-3 text-[10px] text-muted-foreground sm:flex-row sm:items-center sm:justify-between sm:gap-4 sm:px-4`,children:[(0,Y.jsxs)(`span`,{children:[(0,Y.jsx)(`span`,{className:`font-mono tabular-nums text-foreground/90`,children:e.entries.length}),` `,(0,Y.jsxs)(`span`,{className:`text-muted-foreground/90`,children:[e.entries.length===1?`action`:`actions`,` queued`]})]}),(0,Y.jsxs)(`div`,{className:`flex min-w-0 flex-wrap items-center gap-x-2 gap-y-1 font-mono text-[10px] wrap-anywhere`,children:[(0,Y.jsx)(`span`,{className:`shrink-0 text-[9px] uppercase tracking-wider text-muted-foreground/80`,children:`Scope`}),(0,Y.jsx)(`span`,{className:`min-w-0 text-foreground/90`,children:_t(e.scope)})]})]})]})}var Ct=[`s1`,`s2`,`s3`,`s4`];function wt(){return(0,Y.jsxs)(`div`,{className:`overflow-hidden rounded-[var(--miravo-radius-stadium-sm)] border border-border/45`,role:`status`,"aria-busy":`true`,"aria-live":`polite`,children:[(0,Y.jsx)(`span`,{className:`sr-only`,children:`Loading plan preview`}),(0,Y.jsx)(`div`,{className:`border-b border-border/40 px-3 py-3 sm:px-4`,children:(0,Y.jsxs)(`div`,{className:`flex gap-3`,children:[(0,Y.jsx)(X,{className:`size-10 shrink-0 rounded-[var(--miravo-radius-stadium-sm)]`}),(0,Y.jsx)(`div`,{className:`flex min-w-0 flex-1 items-start gap-1 pt-0.5 sm:gap-2`,children:(0,Y.jsxs)(`div`,{className:`min-w-0 flex-1`,children:[(0,Y.jsxs)(`div`,{className:`flex flex-wrap items-baseline gap-2`,children:[(0,Y.jsx)(X,{className:`h-3.5 w-40`}),(0,Y.jsx)(X,{className:`h-4 w-11 rounded-[var(--miravo-radius-tight)] border`})]}),(0,Y.jsx)(X,{className:`mt-1.5 h-3 max-w-prose`})]})})]})}),(0,Y.jsxs)(`div`,{className:`flex flex-wrap items-center gap-2 border-b border-border/35 px-3 py-2.5 sm:px-4`,children:[(0,Y.jsx)(X,{className:`h-2.5 w-14`}),(0,Y.jsx)(X,{className:`hidden h-3 w-px shrink-0 sm:block`}),(0,Y.jsxs)(`div`,{className:`flex min-w-0 flex-1 flex-wrap items-center gap-2`,children:[(0,Y.jsx)(X,{className:`h-5 w-18 rounded-[var(--miravo-radius-tight)]`}),(0,Y.jsx)(X,{className:`h-5 w-24 rounded-[var(--miravo-radius-tight)]`}),(0,Y.jsx)(X,{className:`h-5 w-20 rounded-[var(--miravo-radius-tight)]`})]})]}),(0,Y.jsx)(`div`,{className:`overflow-x-auto`,children:(0,Y.jsxs)(`table`,{className:`w-full min-w-lg text-xs`,"aria-hidden":!0,children:[(0,Y.jsx)(`thead`,{children:(0,Y.jsxs)(`tr`,{className:`border-b border-border/45`,children:[(0,Y.jsx)(`th`,{scope:`col`,className:`sticky top-0 z-10 bg-background px-3 py-2 text-left sm:px-3.5`,children:(0,Y.jsx)(X,{className:`h-2.5 w-12`})}),(0,Y.jsx)(`th`,{scope:`col`,className:`sticky top-0 z-10 bg-background px-3 py-2 text-left sm:px-3.5`,children:(0,Y.jsx)(X,{className:`h-2.5 w-9`})}),(0,Y.jsx)(`th`,{scope:`col`,className:`sticky top-0 z-10 bg-background px-3 py-2 text-left sm:px-3.5`,children:(0,Y.jsx)(X,{className:`h-2.5 w-10`})}),(0,Y.jsx)(`th`,{scope:`col`,className:`sticky top-0 z-10 hidden bg-background px-3 py-2 text-left sm:table-cell sm:px-3.5`,children:(0,Y.jsx)(X,{className:`h-2.5 w-14`})}),(0,Y.jsx)(`th`,{scope:`col`,className:`sticky top-0 z-10 hidden bg-background px-3 py-2 text-left md:table-cell md:px-3.5`,children:(0,Y.jsx)(X,{className:`h-2.5 w-11`})})]})}),(0,Y.jsx)(`tbody`,{children:Ct.map((e,t)=>(0,Y.jsxs)(`tr`,{className:F(`border-b border-border/25 transition-colors`,t%2==1?`bg-muted/35`:`bg-transparent`,`hover:bg-primary/4`),children:[(0,Y.jsx)(`td`,{className:`px-3 py-2 align-middle sm:px-3.5`,children:(0,Y.jsx)(X,{className:`h-5 w-13 rounded-[var(--miravo-radius-tight)]`})}),(0,Y.jsx)(`td`,{className:`px-3 py-2 align-middle sm:px-3.5`,children:(0,Y.jsx)(X,{className:`h-3.5 w-16 font-mono`})}),(0,Y.jsx)(`td`,{className:`max-w-[min(16rem,28vw)] px-3 py-2 align-middle sm:max-w-xs sm:px-3.5`,children:(0,Y.jsx)(X,{className:`h-3.5 w-full max-w-48 font-mono`})}),(0,Y.jsx)(`td`,{className:`hidden px-3 py-2 align-middle sm:table-cell sm:px-3.5`,children:(0,Y.jsx)(X,{className:`h-3.5 w-10 font-mono`})}),(0,Y.jsx)(`td`,{className:`hidden max-w-xs px-3 py-2 align-middle md:table-cell md:px-3.5`,children:(0,Y.jsx)(X,{className:`h-3.5 w-full max-w-40`})})]},e))})]})}),(0,Y.jsxs)(`div`,{className:`flex flex-col gap-2 border-t border-border/40 px-3 py-3 text-[10px] text-muted-foreground sm:flex-row sm:items-center sm:justify-between sm:gap-4 sm:px-4`,children:[(0,Y.jsxs)(`span`,{className:`inline-flex items-center gap-1`,children:[(0,Y.jsx)(X,{className:`inline-block h-3 w-6 rounded-[var(--miravo-radius-tight)]`}),(0,Y.jsx)(X,{className:`inline-block h-3 w-28`})]}),(0,Y.jsxs)(`div`,{className:`flex min-w-0 flex-wrap items-center gap-x-2 gap-y-1 font-mono text-[10px] wrap-anywhere`,children:[(0,Y.jsx)(X,{className:`h-2.5 w-8 shrink-0`}),(0,Y.jsx)(X,{className:`h-6 min-w-32 rounded-[var(--miravo-radius-tight)] border border-border/50 px-2 py-0.5`}),(0,Y.jsx)(X,{className:`h-1 w-1 shrink-0 rounded-full`}),(0,Y.jsx)(X,{className:`h-2.5 w-10 shrink-0`}),(0,Y.jsx)(X,{className:`h-3 min-w-16 max-w-56 flex-1`})]})]})]})}var Tt=50;function Et({open:e,type:t,targetLabel:n,targetHostname:r,templates:i,templatesLoading:a,templatesError:o,onRetryTemplates:s,onOpenChange:c,onSelect:l}){let[u,d]=(0,J.useState)(``),[f,p]=(0,J.useState)(Z),m=(0,J.useDeferredValue)(u);(0,J.useEffect)(()=>{e&&(d(``),p(Z()))},[e]);let h=(0,J.useMemo)(()=>{let e=m.trim().toLowerCase(),t=new Map(f.map((e,t)=>[e,t])),n=[],r=new Set;for(let t of i){if(r.has(t.id))continue;r.add(t.id);let i=[t.name,t.id,t.category,t.description??``,t.models.join(` `)].join(` `).toLowerCase();e!==``&&!i.includes(e)||n.push(t)}return n.sort((e,n)=>{let r=t.get(e.id)??1/0,i=t.get(n.id)??1/0;return r===i?e.name.localeCompare(n.name):r-i}),{items:n.slice(0,Tt),total:n.length,recentRank:t}},[i,m,f]),g=t===`apply`?`Apply environment`:`Cleanup environment`,_=e=>{pt(e.id),l(e)};return(0,Y.jsx)(C,{open:e,onOpenChange:c,children:(0,Y.jsxs)(ee,{className:`flex max-h-[82vh] min-h-0 flex-col gap-0 overflow-hidden p-0 sm:max-w-xl`,children:[(0,Y.jsxs)(`div`,{className:`shrink-0 border-b border-border/60 px-5 pb-3 pt-5`,children:[(0,Y.jsx)(T,{className:`text-sm font-semibold`,children:g}),(0,Y.jsxs)(x,{className:`mt-1 text-xs`,children:[n,` / `,r]})]}),(0,Y.jsx)(`div`,{className:`shrink-0 border-b border-border/45 px-5 py-3`,children:(0,Y.jsxs)(`div`,{className:`relative`,children:[(0,Y.jsx)(_e,{className:`pointer-events-none absolute left-2.5 top-1/2 size-3.5 -translate-y-1/2 text-muted-foreground`,"aria-hidden":!0}),(0,Y.jsx)(N,{value:u,onChange:e=>d(e.currentTarget.value),className:`h-9 pl-8`,placeholder:`Search environments`,autoFocus:!0})]})}),(0,Y.jsx)(`div`,{className:`min-h-0 flex-1 overflow-y-auto px-3 py-3`,children:a&&i.length===0?(0,Y.jsx)(`div`,{className:`rounded-[var(--miravo-radius-tight)] border border-border/50 px-3 py-2 text-xs text-muted-foreground`,children:`Loading environments...`}):o&&i.length===0?(0,Y.jsxs)(`div`,{className:`flex items-center justify-between gap-3 rounded-[var(--miravo-radius-tight)] border border-warning/25 bg-warning/5 px-3 py-2 text-xs text-warning`,children:[(0,Y.jsx)(`span`,{children:`Could not load environments.`}),(0,Y.jsx)(O,{type:`button`,variant:`ghost`,size:`sm`,className:`h-7 text-warning hover:text-warning`,onClick:s,children:`Retry`})]}):h.items.length===0?(0,Y.jsx)(`div`,{className:`rounded-[var(--miravo-radius-tight)] border border-border/50 px-3 py-2 text-xs text-muted-foreground`,children:`No matching environments.`}):(0,Y.jsx)(`div`,{className:`flex flex-col gap-1`,children:h.items.map(e=>{let t=h.recentRank.has(e.id);return(0,Y.jsxs)(`button`,{type:`button`,className:`flex min-h-12 w-full min-w-0 items-center gap-2 rounded-[var(--miravo-radius-tight)] px-2 py-2 text-left text-xs transition-colors hover:bg-muted/45 focus-visible:outline-none focus-visible:ring-2 focus-visible:ring-ring/70`,onClick:()=>_(e),children:[(0,Y.jsx)(`span`,{className:`flex size-8 shrink-0 items-center justify-center rounded-[var(--miravo-radius-tight)] border border-border/35 bg-muted/25 text-primary`,children:(0,Y.jsx)(be,{id:e.id,className:`size-3.5`})}),(0,Y.jsxs)(`span`,{className:`min-w-0 flex-1`,children:[(0,Y.jsxs)(`span`,{className:`flex min-w-0 items-center gap-2`,children:[(0,Y.jsx)(`span`,{className:`truncate font-medium text-foreground`,children:e.name}),t?(0,Y.jsx)(`span`,{className:`shrink-0 rounded-[var(--miravo-radius-tight)] border border-primary/25 bg-primary/8 px-1.5 py-px font-mono text-[9px] uppercase tracking-wider text-primary`,children:`Recent`}):null]}),(0,Y.jsxs)(`span`,{className:`mt-0.5 block truncate font-mono text-[11px] text-muted-foreground`,children:[e.id,` / `,e.instanceCount,` instances`]})]})]},e.id)})})}),h.total>h.items.length?(0,Y.jsxs)(`div`,{className:`shrink-0 border-t border-border/45 px-5 py-2 text-[11px] text-muted-foreground`,children:[`Showing `,h.items.length,` of `,h.total,`. Refine search.`]}):null]})})}function Dt({targets:e,stream:t}){let[n,r]=(0,J.useState)(`apply`),[a,o]=(0,J.useState)(``),[l,u]=(0,J.useState)(``),[d,p]=(0,J.useState)(!1),[g,_]=(0,J.useState)(null),[v,y]=(0,J.useState)(!1),[b,x]=(0,J.useState)(!1),[C,w]=(0,J.useState)(!1),[ee]=(0,J.useState)(mt),T=(0,J.useRef)(0),E=(0,J.useRef)(null),D=t.status===`running`,k=n===`apply`,A=f({queryKey:s.catalog.templates(),queryFn:()=>c(`/catalog/templates`,i.catalogTemplates)}),j=A.data??[],N=j.find(e=>e.id===l),P=e.find(e=>e.id===a),I=k?!!a&&!!l:!!a&&(d||!!l),L=(0,J.useCallback)(()=>{T.current+=1,E.current?.abort(),E.current=null,y(!1),_(null)},[]);(0,J.useEffect)(()=>{if(!(l||j.length===0||d))for(let e of Z()){let t=j.find(t=>t.id===e);if(t){u(t.id);return}}},[l,j,d]);let te=(0,J.useCallback)(()=>{L(),S.message(`Preview cancelled`)},[L]),z=e=>{D||(r(e),L(),p(!1))},B=(0,J.useCallback)(async e=>{if(e===`apply`){if(!a||!l)return}else if(!a||!d&&!l)return;t.operation&&t.status!==`running`&&t.reset(),E.current?.abort(),T.current+=1;let n=T.current,r=new AbortController;E.current=r,y(!0),_(null);try{let t=e===`apply`?await ce({targetId:a,template:l},{signal:r.signal}):await ie({targetId:a,...d?{allManaged:!0}:{template:l}},{signal:r.signal});if(n!==T.current)return;_(t.plan)}catch(t){if(n!==T.current||gt(t))return;S.error(q(t,e===`apply`?`Plan failed`:`Cleanup plan failed`))}finally{n===T.current&&y(!1)}},[a,l,d,t]),ne=(0,J.useCallback)(e=>{x(!1),L();let{scope:r,ifUnmanaged:i}=e;ht(a),l&&pt(l),n===`apply`?t.startApply({targetId:a,template:l,scope:r,ifUnmanaged:i}):t.startCleanup({targetId:a,...d?{allManaged:!0}:{template:l},scope:r})},[n,a,l,d,t,L]),V=!k&&d,H=I&&!D,oe=k?Ie:R,se=`Awaiting selection`;H&&(se=k?`Commit apply`:`Commit cleanup`);let de=V?`All managed resources`:N?.name??`Select environment`,U=(0,Y.jsx)(Re,{className:`size-3.5`,"aria-hidden":!0});V?U=(0,Y.jsx)(R,{className:`size-3.5`,"aria-hidden":!0}):N&&(U=(0,Y.jsx)(be,{id:N.id,className:`size-3.5`}));let fe=k?`Provisions devices, tags, and Digital Twin models from the selected environment on the selected target.`:`Removes Miravo-managed resources for this environment from the selected target.`;V&&(fe=`Removes all Miravo-managed resources from the target (ignores environment scope).`);let pe=P?`${P.label} / ${de}`:`Select target and environment`;return(0,Y.jsxs)(`div`,{className:`flex flex-col gap-4`,children:[(0,Y.jsxs)(`div`,{className:`flex flex-wrap items-center gap-3`,children:[(0,Y.jsxs)(`div`,{role:`toolbar`,"aria-label":`Operation mode`,className:`inline-flex items-center gap-0.5 rounded-[var(--miravo-radius-pill)] border border-border/50 bg-muted/15 p-0.5`,children:[(0,Y.jsxs)(`button`,{type:`button`,"aria-pressed":k,className:F(`relative flex items-center gap-1.5 rounded-[var(--miravo-radius-pill)] px-4 py-1.5 text-xs font-medium transition-colors`,k?`text-primary`:`text-muted-foreground hover:text-foreground`),onClick:()=>z(`apply`),disabled:D,children:[k&&(0,Y.jsx)(h.span,{layoutId:`mode-pill`,className:`absolute inset-0 rounded-[var(--miravo-radius-pill)] bg-primary/15 shadow-sm`,transition:{type:`spring`,stiffness:500,damping:40}}),(0,Y.jsx)(it,{className:`relative z-10 size-3.5`}),(0,Y.jsx)(`span`,{className:`relative z-10`,children:`Apply`})]}),(0,Y.jsxs)(`button`,{type:`button`,"aria-pressed":!k,className:F(`relative flex items-center gap-1.5 rounded-[var(--miravo-radius-pill)] px-4 py-1.5 text-xs font-medium transition-colors`,k?`text-muted-foreground hover:text-foreground`:`text-destructive`),onClick:()=>z(`cleanup`),disabled:D,children:[!k&&(0,Y.jsx)(h.span,{layoutId:`mode-pill`,className:`absolute inset-0 rounded-[var(--miravo-radius-pill)] bg-destructive/15 shadow-sm`,transition:{type:`spring`,stiffness:500,damping:40}}),(0,Y.jsx)(R,{className:`relative z-10 size-3.5`}),(0,Y.jsx)(`span`,{className:`relative z-10`,children:`Cleanup`})]})]}),(0,Y.jsx)(ue,{stream:t})]}),(0,Y.jsx)(le,{children:(0,Y.jsxs)(`div`,{className:`flex flex-col gap-3.5`,children:[(0,Y.jsxs)(`div`,{className:`flex items-start gap-3 border-b border-border/25 pb-3`,children:[(0,Y.jsx)(`div`,{className:`flex size-9 shrink-0 items-center justify-center rounded-[var(--miravo-radius-stadium-sm)] border border-primary/25 bg-primary/9 shadow-[inset_0_1px_0_0_var(--miravo-inset-highlight)]`,children:(0,Y.jsx)(Re,{className:`size-4 text-primary`,"aria-hidden":!0})}),(0,Y.jsxs)(`div`,{className:`min-w-0 flex-1`,children:[(0,Y.jsx)(`p`,{className:`font-heading text-[11px] font-semibold uppercase tracking-[0.12em] text-foreground`,children:`Litmus Edge`}),(0,Y.jsx)(`p`,{className:`mt-0.5 text-[11px] leading-relaxed text-muted-foreground`,children:fe})]})]}),(0,Y.jsxs)(`div`,{className:`grid grid-cols-1 gap-3 sm:grid-cols-2`,children:[(0,Y.jsxs)(`div`,{className:`space-y-1.5`,children:[(0,Y.jsx)(Ze,{className:`font-heading text-[11px] font-medium uppercase tracking-[0.14em] text-muted-foreground`,children:`Target`}),(0,Y.jsx)(ae,{targets:e,value:a,onValueChange:e=>{o(e),ht(e),L()},preferredTargetId:ee,disabled:D,size:`sm`,className:`min-w-0 w-full text-xs`})]}),(0,Y.jsxs)(`div`,{className:`space-y-1.5`,children:[(0,Y.jsx)(Ze,{className:`font-heading text-[11px] font-medium uppercase tracking-[0.14em] text-muted-foreground`,children:`Environment`}),A.isError&&!A.data&&(0,Y.jsx)(m,{message:q(A.error,`Failed to load environments.`),onRetry:()=>void A.refetch(),isRetrying:A.isFetching&&!A.isPending}),(0,Y.jsxs)(`button`,{type:`button`,disabled:V||D||!P,onClick:()=>w(!0),className:F(`flex h-9 min-h-9 w-full min-w-0 items-center justify-between gap-1.5 rounded-[var(--miravo-radius-stadium-sm)] border border-input bg-input/30 px-2.5 py-0 text-left text-xs outline-none transition-colors select-none`,`hover:bg-input/50 focus-visible:border-primary/35 focus-visible:ring-2 focus-visible:ring-primary/22`,`disabled:pointer-events-none disabled:cursor-not-allowed disabled:bg-input/50 disabled:opacity-50`),"aria-label":`Environment`,children:[(0,Y.jsxs)(`span`,{className:`flex min-w-0 items-center gap-2`,children:[(0,Y.jsx)(`span`,{className:`flex size-7 shrink-0 items-center justify-center rounded-[var(--miravo-radius-stadium-sm)] border border-border/35 bg-muted/25 text-primary`,children:U}),(0,Y.jsx)(`span`,{className:`min-w-0 flex-1 truncate font-medium text-foreground`,children:de})]}),(0,Y.jsx)(Se,{className:`pointer-events-none size-4 shrink-0 text-muted-foreground`,"aria-hidden":!0})]})]})]}),(0,Y.jsxs)(`button`,{type:`button`,disabled:!H||v,onClick:()=>x(!0),className:F(`group flex w-full min-h-14 min-w-0 items-stretch overflow-hidden rounded-[var(--miravo-radius-stadium-lg)] text-left outline-none`,`transition-[border-color,box-shadow,background-color] duration-200 ease-out`,`focus-visible:ring-2 focus-visible:ring-ring/70 focus-visible:ring-offset-2 focus-visible:ring-offset-background`,`disabled:pointer-events-none disabled:opacity-55`,H?[`border-2 border-primary/40 bg-background`,`bg-linear-to-r from-primary/12 via-background to-background`,`shadow-[inset_0_1px_0_0_rgba(255,255,255,0.025)]`,`hover:border-primary/56 hover:shadow-[inset_0_1px_0_0_rgba(255,255,255,0.025),0_0_14px_-8px_color-mix(in_srgb,var(--primary)_18%,transparent),0_0_22px_-12px_color-mix(in_srgb,var(--primary)_8%,transparent)]`]:[`border border-dashed border-border/65 bg-muted/15`,`hover:bg-muted/22`]),children:[(0,Y.jsx)(`span`,{className:`relative flex w-18 shrink-0 items-center justify-center bg-transparent`,"aria-hidden":!0,children:(0,Y.jsx)(oe,{className:F(`relative size-5`,H?`text-primary`:`text-muted-foreground`)})}),(0,Y.jsxs)(`span`,{className:`flex min-w-0 flex-1 flex-col justify-center gap-0.5 overflow-hidden px-3 py-2.5 sm:px-4`,children:[(0,Y.jsx)(`span`,{className:F(`font-heading text-[11px] font-semibold uppercase tracking-[0.18em]`,H?`text-primary`:`text-muted-foreground`),children:se}),(0,Y.jsx)(`span`,{className:F(`truncate font-mono text-[13px] leading-tight tracking-tight`,H?`text-foreground`:`text-muted-foreground`),children:pe})]}),(0,Y.jsx)(`span`,{className:F(`flex shrink-0 items-center pr-2.5 sm:pr-3`,H&&`pl-1`),children:(0,Y.jsx)(`span`,{className:F(`flex size-9 items-center justify-center rounded-[var(--miravo-radius-stadium-sm)] border bg-transparent transition-[border-color,color] duration-200`,H?`border-primary/40 text-primary group-hover:border-primary/55`:`border-border/45 text-muted-foreground`),"aria-hidden":!0,children:(0,Y.jsx)(Ee,{className:`size-4`,strokeWidth:2.25})})})]}),!k&&(0,Y.jsx)(`div`,{className:`flex w-full min-w-0 flex-wrap items-center justify-end gap-2`,children:(0,Y.jsxs)(Ze,{id:`all-managed-label`,htmlFor:`all-managed`,"aria-disabled":D,className:F(`inline-flex h-8 w-fit max-w-full cursor-pointer items-center gap-2 text-xs font-medium leading-none`,D&&`pointer-events-none opacity-40`),children:[(0,Y.jsx)(Le,{id:`all-managed`,checked:d,onCheckedChange:e=>{p(e===!0),L()},disabled:D}),(0,Y.jsx)(`span`,{className:`shrink-0`,children:`Remove all Miravo managed resources`})]})})]})}),(v||g)&&!D&&(0,Y.jsxs)(`div`,{className:`flex flex-col gap-2`,children:[v&&(0,Y.jsx)(`div`,{className:`flex w-full min-w-0 flex-wrap items-center justify-end gap-2`,children:(0,Y.jsxs)(O,{type:`button`,variant:`ghost`,size:`sm`,className:`h-8 shrink-0 gap-1.5 px-2 text-xs text-muted-foreground hover:text-foreground`,onClick:te,children:[(0,Y.jsx)(M,{className:`size-3.5`,"aria-hidden":!0}),`Cancel preview`]})}),v&&(0,Y.jsx)(wt,{}),g&&!v&&(0,Y.jsx)(St,{plan:g,planKind:k?`apply`:`cleanup`,onCloseTable:L})]}),P&&C?(0,Y.jsx)(Et,{open:!0,type:n,targetLabel:P.label,targetHostname:P.hostname,templates:j,templatesLoading:A.isPending&&A.data===void 0,templatesError:A.isError&&j.length===0,onRetryTemplates:()=>void A.refetch(),onOpenChange:w,onSelect:e=>{u(e.id),pt(e.id),p(!1),L(),k&&t.reset(),w(!1)}}):null,P&&(0,Y.jsx)(re,{open:b,onOpenChange:x,type:n,label:V?`All managed resources`:N?.name??l,targetLabel:P.label,hostname:P.hostname,sourceHostname:P.sourceHostname,onConfirm:ne,applyPreview:k?{onPreview:()=>void B(`apply`),planLoading:v,disabled:!a||!l||D}:void 0,cleanupPreview:k?void 0:{onPreview:()=>void B(`cleanup`),planLoading:v,disabled:!a||!d&&!l||D}})]})}function Ot(){return(0,Y.jsx)(`section`,{"aria-labelledby":`platforms-operation-log-empty-title`,className:at,children:(0,Y.jsxs)(`div`,{className:`flex flex-col items-center gap-4 px-4 py-8 text-center sm:py-10`,children:[(0,Y.jsx)(`div`,{className:`flex size-12 items-center justify-center rounded-(--miravo-radius-stadium-sm) border border-dashed border-border/50`,children:(0,Y.jsx)(I,{className:`size-6 text-muted-foreground/45`,"aria-hidden":!0})}),(0,Y.jsxs)(`div`,{className:`max-w-sm`,children:[(0,Y.jsx)(`h2`,{id:`platforms-operation-log-empty-title`,className:`font-heading text-sm font-semibold tracking-tight text-foreground`,children:`No operations yet`}),(0,Y.jsx)(`p`,{className:`mt-2 text-pretty text-sm leading-relaxed text-muted-foreground`,children:`Run apply or cleanup from the Operations tab. Finished runs show up here with full detail.`})]})]})})}function kt(e){let t=new Date(e),n=new Date,r=new Date(n);return r.setDate(n.getDate()-1),t.toDateString()===n.toDateString()?`Today`:t.toDateString()===r.toDateString()?`Yesterday`:t.toLocaleDateString(`en-US`,{weekday:`short`,month:`short`,day:`numeric`})}function At(e){let t=new Map;for(let n of e){let e=new Date(n.completedAt).toDateString(),r=t.get(e);r?r.push(n):t.set(e,[n])}return Array.from(t.entries()).map(([,e])=>({label:kt(e[0]?.completedAt??Date.now()),ops:e}))}function jt(e,t){return e===`device`?t.operationType===`apply`?`Tag/register writes per device step—not a device count.`:`One count per device removed from DeviceHub.`:e===`model`?`One count per model in this run.`:e===`instance`?`One count per twin instance in this run.`:`Sets the device parameter to the bound DeviceHub device.`}var Mt={devices:`Devices`,models:`DT models`,instances:`DT instances`},Q={create:`inline-flex items-center rounded-[var(--miravo-radius-tight)] border border-success/35 bg-success/12 px-1.5 py-0.5 font-mono text-[10px] tabular-nums text-success`,update:`inline-flex items-center rounded-[var(--miravo-radius-tight)] border border-primary/35 bg-primary/12 px-1.5 py-0.5 font-mono text-[10px] tabular-nums text-primary`,replace:`inline-flex items-center rounded-[var(--miravo-radius-tight)] border border-chart-2/35 bg-chart-2/12 px-1.5 py-0.5 font-mono text-[10px] tabular-nums text-chart-2`,delete:`inline-flex items-center rounded-[var(--miravo-radius-tight)] border border-destructive/35 bg-destructive/12 px-1.5 py-0.5 font-mono text-[10px] tabular-nums text-destructive`,noop:`inline-flex items-center rounded-[var(--miravo-radius-tight)] border border-border/55 bg-muted/55 px-1.5 py-0.5 font-mono text-[10px] tabular-nums text-foreground/78`,failed:`inline-flex items-center rounded-[var(--miravo-radius-tight)] border border-destructive/40 bg-destructive/18 px-1.5 py-0.5 font-mono text-[10px] font-semibold tabular-nums text-destructive`};function Nt(e){return[{key:`device`,title:`DeviceHub — protocol tags`,subtitle:jt(`device`,e),counts:e.resourceCounts.device},{key:`model`,title:`Digital Twin models`,subtitle:jt(`model`,e),counts:e.resourceCounts.model},{key:`instance`,title:`Twin instances`,subtitle:jt(`instance`,e),counts:e.resourceCounts.instance},{key:`param-sync`,title:`Parameter sync`,subtitle:jt(`param-sync`,e),counts:e.resourceCounts[`param-sync`]}].filter(e=>e.counts.total>0||e.counts.failed>0)}function Pt(e){return e.length===0?`Default (devices, models, instances)`:e.map(e=>Mt[e]??e).join(` · `)}function Ft(e){let t=[];return e.filters.area&&t.push(`Area ${e.filters.area}`),e.filters.line&&t.push(`Line ${e.filters.line}`),e.filters.instance&&t.push(`Instance ${e.filters.instance}`),t.length>0?t.join(` · `):null}function $(e,t,n){if(e===`device`)switch(t){case`create`:return`+${n} tags (new device)`;case`update`:return`${n} tags rewritten`;case`replace`:return`↻${n} tags (device replaced)`;case`delete`:return`−${n} removed`;case`noop`:return`=${n} unchanged`}switch(t){case`create`:return`+${n} created`;case`update`:return`${n} updated`;case`replace`:return`↻${n} replaced`;case`delete`:return`−${n} removed`;case`noop`:return`=${n} unchanged`}}function It({row:e}){let{key:t,counts:n}=e;return(0,Y.jsxs)(`div`,{className:`flex min-w-0 flex-1 flex-wrap items-center gap-1.5`,children:[n.create>0&&(0,Y.jsx)(`span`,{className:Q.create,children:$(t,`create`,n.create)}),n.update>0&&(0,Y.jsx)(`span`,{className:Q.update,children:$(t,`update`,n.update)}),n.replace>0&&(0,Y.jsx)(`span`,{className:Q.replace,children:$(t,`replace`,n.replace)}),n.delete>0&&(0,Y.jsx)(`span`,{className:Q.delete,children:$(t,`delete`,n.delete)}),n.noop>0&&(0,Y.jsx)(`span`,{className:Q.noop,children:$(t,`noop`,n.noop)}),n.failed>0&&(0,Y.jsx)(`span`,{className:Q.failed,children:`${n.failed} failed`})]})}function Lt(e){return e.resourceCounts.device.noop+e.resourceCounts.model.noop+e.resourceCounts.instance.noop+e.resourceCounts[`param-sync`].noop}function Rt({op:e}){let t=Ft(e),n=Lt(e);return(0,Y.jsxs)(`div`,{className:`rounded-[var(--miravo-radius-tight)] border border-border/50 bg-muted/25 px-3 py-2.5`,children:[(0,Y.jsx)(`p`,{className:`font-mono text-[10px] uppercase tracking-[0.16em] text-foreground/72`,children:`Run context`}),(0,Y.jsxs)(`dl`,{className:`mt-2 grid grid-cols-[minmax(0,7.5rem)_1fr] gap-x-3 gap-y-1.5 text-xs sm:grid-cols-[9rem_1fr]`,children:[(0,Y.jsx)(`dt`,{className:`text-foreground/70`,children:`Operation`}),(0,Y.jsx)(`dd`,{className:`font-medium capitalize text-foreground`,children:e.operationType}),(0,Y.jsx)(`dt`,{className:`text-foreground/70`,children:`Target host`}),(0,Y.jsx)(`dd`,{className:`break-all font-mono text-[11px] text-foreground`,children:e.hostname}),(0,Y.jsx)(`dt`,{className:`text-foreground/70`,children:`Scope`}),(0,Y.jsx)(`dd`,{className:`text-foreground`,children:Pt(e.scope)}),t&&(0,Y.jsxs)(Y.Fragment,{children:[(0,Y.jsx)(`dt`,{className:`text-foreground/70`,children:`Filters`}),(0,Y.jsx)(`dd`,{className:`text-foreground`,children:t})]}),(0,Y.jsx)(`dt`,{className:`text-foreground/70`,children:`Duration`}),(0,Y.jsxs)(`dd`,{className:`tabular-nums text-foreground`,children:[(e.durationMs/1e3).toFixed(1),`s`]}),(0,Y.jsx)(`dt`,{className:`text-foreground/70`,children:`Outcome`}),(0,Y.jsxs)(`dd`,{className:`text-foreground`,children:[(0,Y.jsx)(`span`,{className:`tabular-nums`,children:e.successCount}),` steps succeeded`,n>0&&(0,Y.jsxs)(`span`,{className:`text-foreground/72`,children:[` `,`· `,(0,Y.jsx)(`span`,{className:`tabular-nums`,children:n}),` unchanged`]}),e.failedCount>0&&(0,Y.jsxs)(`span`,{className:`text-destructive`,children:[` `,`· `,(0,Y.jsx)(`span`,{className:`tabular-nums`,children:e.failedCount}),` failed`]}),e.blockedCount>0&&(0,Y.jsxs)(`span`,{className:`text-warning`,children:[` `,`· `,(0,Y.jsx)(`span`,{className:`tabular-nums`,children:e.blockedCount}),` blocked in plan`]})]})]})]})}function zt({status:e}){switch(e){case`success`:return(0,Y.jsx)(Oe,{className:`mt-px size-4 shrink-0 text-success`});case`failed`:return(0,Y.jsx)(Ne,{className:`mt-px size-4 shrink-0 text-destructive`});case`partial`:case`blocked`:return(0,Y.jsx)(ze,{className:`mt-px size-4 shrink-0 text-warning`});case`noop`:return(0,Y.jsx)(tt,{className:`mt-px size-4 shrink-0 text-foreground/55`})}}function Bt(e){let t=e.operationType===`apply`?`Applied`:`Cleaned up`,n=`${(e.durationMs/1e3).toFixed(1)}s`,r=[];e.successCount>0&&r.push(`${e.successCount} resources`);let i=Lt(e);return i>0&&r.push(`${i} unchanged`),e.failedCount>0&&r.push(`${e.failedCount} failed`),e.blockedCount>0&&r.push(`${e.blockedCount} blocked`),r.length===0?`${t} · no changes · ${n}`:`${t} · ${r.join(`, `)} · ${n}`}function Vt(e){return e.operationType===`cleanup`&&e.successCount===0&&e.failedCount===0&&e.blockedCount===0?`No Miravo-managed resources were found to clean up.`:e.failedCount>0&&e.blockedCount>0?`No per-phase counts — failures and blocked plan entries.`:e.failedCount>0?`No per-phase counts — run failed.`:e.blockedCount>0?`No per-phase counts — blocked plan entries.`:Lt(e)>0?`No resources were mutated. Existing managed resources already matched the desired state.`:`No per-phase counts recorded.`}function Ht({op:e}){let t=Nt(e);return t.length===0?(0,Y.jsx)(`p`,{className:`py-1 text-sm text-foreground/75`,children:Vt(e)}):(0,Y.jsxs)(`div`,{className:`space-y-3 pt-1`,children:[(0,Y.jsx)(`div`,{className:`flex flex-col divide-y divide-border/45 rounded-[var(--miravo-radius-tight)] border border-border/50`,children:t.map(e=>(0,Y.jsxs)(`div`,{className:`flex flex-col gap-2 px-3 py-2.5 sm:flex-row sm:items-start sm:gap-4`,children:[(0,Y.jsxs)(`div`,{className:`min-w-0 shrink-0 sm:w-[11.5rem]`,children:[(0,Y.jsxs)(`div`,{className:`flex items-center gap-1`,children:[(0,Y.jsx)(`span`,{className:`text-xs font-medium leading-snug text-foreground`,children:e.title}),(0,Y.jsxs)(He,{children:[(0,Y.jsx)(Be,{type:`button`,className:`inline-flex shrink-0 items-center justify-center rounded-[var(--miravo-radius-tight)] p-0.5 text-foreground/60 hover:bg-muted/50 hover:text-foreground`,"aria-label":`About ${e.title}`,children:(0,Y.jsx)(Fe,{className:`size-3.5`,"aria-hidden":!0})}),(0,Y.jsx)(Ve,{side:`top`,className:`max-w-xs text-left`,children:e.subtitle})]})]}),(0,Y.jsx)(`p`,{className:`mt-0.5 text-[11px] leading-snug text-foreground/72 sm:hidden`,children:e.subtitle})]}),(0,Y.jsx)(It,{row:e})]},e.key))}),e.blockedCount>0&&(0,Y.jsxs)(`p`,{className:`rounded-[var(--miravo-radius-tight)] border border-warning/20 bg-warning/5 px-2.5 py-1.5 text-[11px] text-warning`,children:[(0,Y.jsx)(`span`,{className:`font-medium`,children:e.blockedCount}),` plan entries were blocked (skipped). Open a `,(0,Y.jsx)(`span`,{className:`font-medium`,children:`deploy preview`}),` before running to see block reasons.`]})]})}function Ut({operation:e}){let[t,n]=(0,J.useState)(!1);return(0,Y.jsxs)(`div`,{className:F(`overflow-hidden rounded-[var(--miravo-radius-stadium-sm)] border border-border/55`,`transition-colors duration-150`),children:[(0,Y.jsxs)(`button`,{type:`button`,"aria-expanded":t,onClick:()=>n(e=>!e),className:F(`flex w-full items-start gap-3 p-3.5 text-left`,`transition-colors duration-100`,`hover:bg-muted/25`,t&&`bg-muted/18`),children:[(0,Y.jsx)(zt,{status:e.status}),(0,Y.jsxs)(`div`,{className:`flex min-w-0 flex-1 flex-col gap-1`,children:[(0,Y.jsxs)(`div`,{className:`flex items-start justify-between gap-4`,children:[(0,Y.jsxs)(`p`,{className:`min-w-0 truncate text-sm`,children:[(0,Y.jsx)(`span`,{className:`font-medium text-foreground`,children:j(e.templateId)}),(0,Y.jsx)(`span`,{className:`mx-1.5 text-foreground/50`,children:`→`}),(0,Y.jsx)(`span`,{className:`text-foreground/82`,children:e.targetLabel})]}),(0,Y.jsx)(`time`,{dateTime:new Date(e.completedAt).toISOString(),title:A(e.completedAt),className:`shrink-0 text-xs text-foreground/75`,children:k(e.completedAt)})]}),(0,Y.jsx)(`p`,{className:`text-xs text-foreground/78`,children:Bt(e)}),(e.failedCount>0||e.status===`failed`)&&(0,Y.jsx)(`p`,{className:`text-[11px] leading-snug text-foreground/72`,children:ge(e.operationType,e.error)})]}),(0,Y.jsx)(Se,{className:F(`mt-0.5 size-3.5 shrink-0 text-foreground/55 transition-transform duration-150`,t&&`rotate-180`)})]}),(0,Y.jsx)(g,{initial:!1,children:t&&(0,Y.jsx)(h.div,{initial:{opacity:0,height:0},animate:{opacity:1,height:`auto`},exit:{opacity:0,height:0},transition:{duration:.2,ease:`easeOut`},className:`overflow-hidden`,children:(0,Y.jsxs)(`div`,{className:`space-y-3 border-t border-border/45 px-4 pb-3 pt-3`,children:[(0,Y.jsx)(Rt,{op:e}),e.error&&(0,Y.jsxs)(`div`,{className:`relative rounded-[var(--miravo-radius-tight)] border border-destructive/40 bg-destructive/15 px-3 py-2 pr-10 text-xs font-medium`,children:[(0,Y.jsx)(`div`,{className:`absolute top-1.5 right-1.5 z-10`,children:(0,Y.jsx)(E,{value:e.error,label:`Copy error`,className:`text-destructive hover:bg-destructive/25 hover:text-foreground`})}),(0,Y.jsx)(`p`,{className:`whitespace-normal break-words text-destructive [overflow-wrap:anywhere]`,children:e.error}),(0,Y.jsx)(`p`,{className:`mt-2 text-[11px] font-normal leading-snug text-foreground/78 [overflow-wrap:anywhere]`,children:ge(e.operationType,e.error)})]}),(0,Y.jsx)(Ht,{op:e})]})})})]})}function Wt({label:e}){return(0,Y.jsxs)(`div`,{className:`flex items-center gap-3 py-1`,children:[(0,Y.jsx)(`div`,{className:`h-px flex-1 bg-border/65`}),(0,Y.jsx)(`span`,{className:`text-xs font-medium text-foreground/78`,children:e}),(0,Y.jsx)(`div`,{className:`h-px flex-1 bg-border/65`})]})}var Gt={type:``,status:``,target:``,search:``},Kt={_all:`All types`,apply:`Apply`,cleanup:`Cleanup`},qt={_all:`All statuses`,success:`Success`,partial:`Partial`,failed:`Failed`,blocked:`Blocked`,noop:`No-op`},Jt=`h-7 min-h-7 gap-1.5 border-border/50 bg-transparent px-2 text-xs hover:bg-muted/30 focus:ring-0`;function Yt({filters:e,targetOptions:t,hasFilters:n,searchRef:r,onTypeChange:i,onStatusChange:a,onTargetChange:o,onSearchChange:s,onClear:c}){return(0,Y.jsxs)(`div`,{className:`flex flex-wrap items-center gap-1.5 border-b border-border/50 px-3 py-2`,children:[(0,Y.jsxs)(Te,{value:e.type||`_all`,onValueChange:e=>e&&i(e===`_all`?``:e),children:[(0,Y.jsx)(we,{size:`sm`,className:Jt,"aria-label":`Operation type`,children:(0,Y.jsx)(xe,{children:e=>Kt[e??`_all`]??Kt._all})}),(0,Y.jsxs)(Ce,{children:[(0,Y.jsx)(W,{value:`_all`,children:`All types`}),(0,Y.jsx)(W,{value:`apply`,children:`Apply`}),(0,Y.jsx)(W,{value:`cleanup`,children:`Cleanup`})]})]}),(0,Y.jsxs)(Te,{value:e.status||`_all`,onValueChange:e=>e&&a(e===`_all`?``:e),children:[(0,Y.jsx)(we,{size:`sm`,className:Jt,"aria-label":`Operation status`,children:(0,Y.jsx)(xe,{children:e=>qt[e??`_all`]??qt._all})}),(0,Y.jsxs)(Ce,{children:[(0,Y.jsx)(W,{value:`_all`,children:`All statuses`}),(0,Y.jsx)(W,{value:`success`,children:`Success`}),(0,Y.jsx)(W,{value:`partial`,children:`Partial`}),(0,Y.jsx)(W,{value:`failed`,children:`Failed`}),(0,Y.jsx)(W,{value:`blocked`,children:`Blocked`}),(0,Y.jsx)(W,{value:`noop`,children:`No-op`})]})]}),t.length>1&&(0,Y.jsxs)(Te,{value:e.target||`_all`,onValueChange:e=>e&&o(e===`_all`?``:e),children:[(0,Y.jsx)(we,{size:`sm`,className:Jt,"aria-label":`Target filter`,children:(0,Y.jsx)(xe,{children:e=>!e||e===`_all`?`All targets`:e})}),(0,Y.jsxs)(Ce,{children:[(0,Y.jsx)(W,{value:`_all`,children:`All targets`}),t.map(e=>(0,Y.jsx)(W,{value:e,children:e},e))]})]}),(0,Y.jsxs)(`div`,{className:`relative flex min-w-[140px] flex-1 items-center`,children:[(0,Y.jsx)(`input`,{ref:r,type:`search`,value:e.search,onChange:e=>s(e.target.value),placeholder:`Search environment or target…`,"aria-describedby":`ops-search-shortcut`,className:F(`h-7 w-full rounded-[var(--miravo-radius-tight)] border border-border/50 bg-transparent pl-2 pr-7 text-xs`,`placeholder:text-foreground/60 focus:outline-none focus:ring-1 focus:ring-ring/40`,e.search&&`pr-2`)}),(0,Y.jsx)(`span`,{id:`ops-search-shortcut`,className:`sr-only`,children:`Press slash to focus search`}),!e.search&&(0,Y.jsx)(`kbd`,{"aria-hidden":!0,className:`pointer-events-none absolute right-2 flex h-4 items-center rounded-[var(--miravo-radius-tight)] border border-border/60 bg-muted/50 px-1 font-mono text-[10px] text-foreground/65`,children:`/`})]}),n&&(0,Y.jsxs)(`button`,{type:`button`,onClick:c,className:`flex h-7 items-center gap-1 rounded-[var(--miravo-radius-tight)] px-2 text-xs text-foreground/72 transition-colors hover:bg-muted/40 hover:text-foreground`,children:[(0,Y.jsx)(M,{className:`size-3`}),`Clear`]})]})}function Xt({operations:e,totalKnown:t,isLoading:n,error:r,onRefresh:i,hasNextPage:a=!1,isFetchingNextPage:o=!1,loadMoreError:s=null,onRetryLoadMore:c,onLoadMore:l}){let[u,d]=(0,J.useState)(!1),[f,m]=(0,J.useState)(Gt),_=(0,J.useRef)(null);(0,J.useEffect)(()=>{let e=e=>{if(e.key!==`/`||e.metaKey||e.ctrlKey||e.altKey)return;let t=e.target.tagName;t===`INPUT`||t===`TEXTAREA`||t===`SELECT`||(e.preventDefault(),_.current?.focus())};return window.addEventListener(`keydown`,e),()=>window.removeEventListener(`keydown`,e)},[]);let v=()=>{d(!0),i(),S.success(`Operations refreshed`),setTimeout(()=>d(!1),600)},y=(0,J.useMemo)(()=>{let t=new Set;for(let n of e){let e=n.targetLabel;t.add(e)}return[...t].sort()},[e]),b=(0,J.useMemo)(()=>{let t=e;if(f.type&&(t=t.filter(e=>e.operationType===f.type)),f.status&&(t=t.filter(e=>e.status===f.status)),f.target&&(t=t.filter(e=>e.targetLabel===f.target)),f.search){let e=f.search.toLowerCase();t=t.filter(t=>{let n=t.targetLabel;return t.templateId.toLowerCase().includes(e)||j(t.templateId).toLowerCase().includes(e)||n.toLowerCase().includes(e)})}return t},[e,f]),x=f.type!==``||f.status!==``||f.target!==``||f.search!==``,C=(0,J.useMemo)(()=>At(b),[b]);return(0,Y.jsxs)(`div`,{className:`flex h-full flex-col rounded-[var(--miravo-radius-stadium-sm)] border border-border/55`,children:[(0,Y.jsxs)(`div`,{className:`flex items-center justify-between border-b border-border/50 px-3.5 py-2.5`,children:[(0,Y.jsxs)(`div`,{className:`flex items-center gap-2`,children:[(0,Y.jsx)(`span`,{className:`text-sm font-medium text-foreground`,children:`Operation log`}),e.length>0&&(0,Y.jsx)(`span`,{className:`font-mono text-xs tabular-nums text-foreground/75`,children:typeof t==`number`&&t>0&&e.length<t?`${e.length} / ${t}`:String(e.length)})]}),(0,Y.jsx)(`button`,{type:`button`,onClick:v,disabled:u,"aria-label":`Refresh operation list`,className:`relative rounded-[var(--miravo-radius-tight)] p-1 text-foreground/70 transition-colors before:absolute before:inset-[-10px] before:content-[''] hover:bg-muted/50 hover:text-foreground disabled:pointer-events-none`,children:(0,Y.jsx)(p,{className:F(`size-3.5`,u&&`animate-spin`),"aria-hidden":!0})})]}),(0,Y.jsx)(Yt,{filters:f,targetOptions:y,hasFilters:x,searchRef:_,onTypeChange:e=>m(t=>({...t,type:e})),onStatusChange:e=>m(t=>({...t,status:e})),onTargetChange:e=>m(t=>({...t,target:e})),onSearchChange:e=>m(t=>({...t,search:e})),onClear:()=>m(Gt)}),(0,Y.jsxs)(`div`,{className:`flex flex-1 min-h-0 flex-col gap-2 overflow-y-auto overscroll-y-contain p-3`,children:[r&&(0,Y.jsxs)(`p`,{className:`py-2 text-xs text-destructive`,children:[`✕ `,r.message]}),n&&e.length===0&&!r&&(0,Y.jsx)(`p`,{className:`py-4 text-sm text-foreground/75`,children:`Loading…`}),!n&&e.length===0&&!r&&(0,Y.jsx)(Ot,{}),!n&&e.length>0&&b.length===0&&(0,Y.jsxs)(`p`,{className:`py-6 text-center text-sm text-foreground/75`,children:[`No operations match your filters.`,` `,(0,Y.jsx)(`button`,{type:`button`,onClick:()=>m(Gt),className:`text-primary hover:underline`,children:`Clear filters`})]}),x&&b.length>0&&b.length!==e.length&&(0,Y.jsxs)(`p`,{className:`text-xs text-foreground/75`,children:[`Showing`,` `,(0,Y.jsx)(`span`,{className:`font-medium tabular-nums text-foreground`,children:b.length}),` of`,` `,(0,Y.jsx)(`span`,{className:`tabular-nums`,children:e.length}),` loaded`]}),!x&&typeof t==`number`&&t>0&&e.length<t&&(0,Y.jsxs)(`p`,{className:`text-xs text-foreground/75`,children:[`Showing`,` `,(0,Y.jsx)(`span`,{className:`font-medium tabular-nums text-foreground`,children:e.length}),` `,`of `,(0,Y.jsx)(`span`,{className:`tabular-nums`,children:t}),`. Load more for older entries.`]}),(0,Y.jsx)(g,{initial:!1,children:C.map(e=>(0,Y.jsxs)(h.div,{className:`flex flex-col gap-2`,children:[(0,Y.jsx)(Wt,{label:e.label}),(0,Y.jsx)(g,{initial:!1,children:e.ops.map(e=>(0,Y.jsx)(h.div,{initial:b.length>40?!1:{opacity:0,x:-6},animate:{opacity:1,x:0},transition:{type:`spring`,stiffness:400,damping:35},children:(0,Y.jsx)(Ut,{operation:e})},`${e.operationId}-${e.completedAt}`))})]},e.label))}),s?(0,Y.jsxs)(`div`,{role:`alert`,className:`flex shrink-0 flex-col items-center gap-2 border-t border-border/50 pt-3 pb-1 text-center`,children:[(0,Y.jsxs)(`p`,{className:`text-xs text-destructive`,children:[`Could not load older entries: `,s.message]}),c?(0,Y.jsx)(O,{type:`button`,variant:`outline`,size:`sm`,onClick:c,children:`Retry`}):null]}):a&&l?(0,Y.jsx)(`div`,{className:`flex shrink-0 justify-center border-t border-border/50 pt-3 pb-1`,children:(0,Y.jsx)(O,{type:`button`,variant:`outline`,size:`sm`,className:`min-w-[7rem]`,disabled:o,"aria-busy":o,"aria-label":o?`Loading older operations`:`Load older operations`,onClick:l,children:o?`Loading…`:`Load more`})}):null]})]})}function Zt({target:e,templates:t,templatesLoading:n,templatesError:r,isStreaming:i,onRetryTemplates:a,onSelect:o}){let s=t.length===0&&!n&&!r,[c,l]=(0,J.useState)(null);return(0,Y.jsxs)(Y.Fragment,{children:[(0,Y.jsx)(`div`,{className:`absolute right-3 top-3 z-20`,children:(0,Y.jsxs)(Xe,{children:[(0,Y.jsx)(Ye,{render:(0,Y.jsx)(O,{type:`button`,variant:`ghost`,size:`icon-sm`,disabled:i,className:`border border-border/45 bg-background/70 text-muted-foreground shadow-[inset_0_1px_0_0_var(--miravo-inset-highlight)] hover:border-primary/30 hover:bg-muted/55 hover:text-foreground`,"aria-label":`Open quick actions for ${e.label}`}),children:(0,Y.jsx)(nt,{className:`size-3.5`,"aria-hidden":!0})}),(0,Y.jsx)(Ke,{align:`end`,sideOffset:6,className:`min-w-56`,children:(0,Y.jsxs)(Je,{children:[(0,Y.jsx)(We,{className:`text-[10px] uppercase tracking-[0.14em]`,children:`Quick actions`}),(0,Y.jsx)(qe,{className:`bg-border/60`}),(0,Y.jsxs)(Ge,{disabled:s,className:`h-9 gap-2 text-xs`,onClick:()=>l(`apply`),children:[(0,Y.jsx)(Ie,{className:`size-3.5 shrink-0 text-primary`,"aria-hidden":!0}),(0,Y.jsx)(`span`,{className:`min-w-0 truncate`,children:`Apply environment...`})]}),(0,Y.jsxs)(Ge,{disabled:s,className:`h-9 gap-2 text-xs`,onClick:()=>l(`cleanup`),children:[(0,Y.jsx)(R,{className:`size-3.5 shrink-0 text-muted-foreground`,"aria-hidden":!0}),(0,Y.jsx)(`span`,{className:`min-w-0 truncate`,children:`Cleanup environment...`})]}),(0,Y.jsx)(qe,{className:`bg-border/60`}),(0,Y.jsxs)(Ge,{variant:`destructive`,className:`h-9 gap-2 text-xs`,onClick:()=>o({type:`cleanup`,target:e,allManaged:!0}),children:[(0,Y.jsx)(R,{className:`size-3.5 shrink-0`,"aria-hidden":!0}),(0,Y.jsx)(`span`,{className:`min-w-0 truncate`,children:`Cleanup all managed`})]})]})})]})}),c?(0,Y.jsx)(Et,{open:!0,type:c,targetLabel:e.label,targetHostname:e.hostname,templates:t,templatesLoading:n,templatesError:r,onRetryTemplates:a,onOpenChange:e=>{e||l(null)},onSelect:t=>{o({type:c,target:e,templateId:t.id}),l(null)}},c):null]})}function Qt({selection:e,templates:t,stream:n,onSelectionChange:r}){let[i,a]=(0,J.useState)(!1),[o,s]=(0,J.useState)(null),[c,l]=(0,J.useState)(!1),u=(0,J.useRef)(0),d=(0,J.useRef)(null),f=(0,J.useRef)(!1),p=n.status===`running`,m=(0,J.useCallback)(()=>{u.current+=1,f.current=!1,d.current?.abort(),d.current=null,l(!1),s(null)},[]);(0,J.useEffect)(()=>{e&&(m(),a(!0))},[e,m]),(0,J.useEffect)(()=>()=>{u.current+=1,f.current=!1,d.current?.abort(),d.current=null},[]);let h=e?.templateId==null?void 0:t.find(t=>t.id===e.templateId)?.name??e.templateId,g=e?.type===`cleanup`&&e.allManaged?`All managed resources`:h??``,_=(0,J.useCallback)(async()=>{if(!e||e.type===`apply`&&!e.templateId||e.type===`cleanup`&&!e.allManaged&&!e.templateId)return;n.operation&&n.status!==`running`&&n.reset(),f.current=!0,d.current?.abort(),u.current+=1;let t=u.current,r=new AbortController;d.current=r,l(!0),s(null);try{let n=e.type===`apply`?await ce({targetId:e.target.id,template:e.templateId},{signal:r.signal}):await ie({targetId:e.target.id,...e.allManaged?{allManaged:!0}:{template:e.templateId}},{signal:r.signal});if(t!==u.current)return;s(n.plan)}catch(n){if(t!==u.current||gt(n))return;S.error(q(n,e.type===`apply`?`Plan failed`:`Cleanup plan failed`))}finally{t===u.current&&(l(!1),f.current=!1)}},[e,n]),v=(0,J.useCallback)(t=>{if(e){if(a(!1),m(),r(null),e.type===`apply`){n.startApply({targetId:e.target.id,template:e.templateId,scope:t.scope,ifUnmanaged:t.ifUnmanaged,...t.deviceName?{deviceName:t.deviceName}:{}});return}n.startCleanup({targetId:e.target.id,...e.allManaged?{allManaged:!0}:{template:e.templateId},scope:t.scope})}},[e,n,m,r]),y=e=>{a(e),!(e||f.current)&&(m(),r(null))},b=()=>{m(),r(null)};return(0,Y.jsxs)(Y.Fragment,{children:[e&&(0,Y.jsx)(re,{open:i,onOpenChange:y,type:e.type,label:g,targetLabel:e.target.label,hostname:e.target.hostname,sourceHostname:e.target.sourceHostname,onConfirm:v,applyPreview:e.type===`apply`?{onPreview:()=>void _(),planLoading:c,disabled:!e.templateId||p}:void 0,cleanupPreview:e.type===`cleanup`?{onPreview:()=>void _(),planLoading:c,disabled:!e.allManaged&&!e.templateId||p}:void 0}),(c||o)&&!p&&e?(0,Y.jsxs)(`div`,{className:`flex flex-col gap-2`,children:[(0,Y.jsxs)(`div`,{className:`flex w-full min-w-0 flex-wrap items-center justify-between gap-2`,children:[(0,Y.jsxs)(`div`,{className:`flex min-w-0 items-center gap-1.5 text-[11px] text-muted-foreground`,children:[(0,Y.jsx)(te,{className:`size-3.5 shrink-0 text-primary`,"aria-hidden":!0}),(0,Y.jsxs)(`span`,{className:`truncate`,children:[`Preview for `,e.target.label,`: `,g]})]}),(0,Y.jsxs)(O,{type:`button`,variant:`ghost`,size:`sm`,className:`h-8 shrink-0 gap-1.5 px-2 text-xs text-muted-foreground hover:text-foreground`,onClick:b,children:[(0,Y.jsx)(M,{className:`size-3.5`,"aria-hidden":!0}),`Close preview`]})]}),c?(0,Y.jsx)(wt,{}):o?(0,Y.jsx)(St,{plan:o,planKind:e.type,onCloseTable:b}):null]}):null]})}function $t(e){return De.find(t=>t.id===e)?.label??e}function en(e){if(!e)return`var(--tooltip-border)`;switch(e.status){case`success`:return`var(--success)`;case`partial`:case`blocked`:return`var(--warning)`;case`noop`:return`var(--muted-foreground)`;case`failed`:return`var(--destructive)`}}function tn({status:e}){switch(e){case`success`:return(0,Y.jsx)(Oe,{className:`size-3 text-success`});case`partial`:case`blocked`:return(0,Y.jsx)(ze,{className:`size-3 text-warning`});case`noop`:return(0,Y.jsx)(tt,{className:`size-3 text-muted-foreground`});case`failed`:return(0,Y.jsx)(Ne,{className:`size-3 text-destructive`})}}function nn({target:e,lastOp:t,onEdit:n,onDelete:r,quickActions:i}){return(0,Y.jsxs)(`div`,{className:`env-orbital relative overflow-hidden border`,style:{"--_status":en(t)},children:[i,(0,Y.jsx)(`div`,{className:`relative z-10 px-4 pt-3.5 pb-3 pr-12`,children:(0,Y.jsx)(`p`,{className:`font-heading text-[13px] font-semibold leading-tight tracking-tight text-foreground`,children:e.label})}),(0,Y.jsx)(`div`,{className:`relative z-10 px-4 py-0.5`,children:(0,Y.jsx)(`p`,{className:`font-mono text-xs tracking-tight text-muted-foreground`,children:e.hostname})}),(0,Y.jsxs)(`div`,{className:`relative z-10 mx-4 mb-3 flex items-center gap-2`,children:[(0,Y.jsx)(`span`,{className:`min-w-0 truncate font-mono text-[11px] text-muted-foreground`,children:e.sourceHostname}),(0,Y.jsx)(`div`,{className:`env-orbital-path min-w-6 flex-1`}),(0,Y.jsx)(L,{className:`size-3 shrink-0 text-muted-foreground`})]}),(0,Y.jsxs)(`div`,{className:`relative z-10 flex items-center gap-2 border-t border-border/30 px-3 py-1.5`,children:[(0,Y.jsxs)(`span`,{className:`flex shrink-0 items-center gap-1.5 rounded-full border border-border/40 px-2 py-0.5`,children:[(0,Y.jsx)(`span`,{className:`protocol-card-live-dot size-[5px]`}),(0,Y.jsx)(`span`,{className:`text-[11px] font-medium tracking-wide text-muted-foreground`,children:$t(e.platformId)})]}),t&&(0,Y.jsxs)(`span`,{className:`flex min-w-0 items-center gap-1 truncate text-[11px] text-muted-foreground`,children:[(0,Y.jsx)(tn,{status:t.status}),t.operationType===`apply`?`Applied`:`Cleaned`,` `,(0,Y.jsx)(`time`,{dateTime:new Date(t.completedAt).toISOString(),title:A(t.completedAt),children:k(t.completedAt)})]}),(0,Y.jsxs)(`div`,{className:`ml-auto flex shrink-0 items-center gap-0.5`,children:[(0,Y.jsx)(O,{variant:`ghost`,size:`icon-sm`,"aria-label":`Edit target`,onClick:n,children:(0,Y.jsx)(rt,{className:`size-3`})}),(0,Y.jsx)(O,{variant:`ghost`,size:`icon-sm`,className:`text-destructive hover:text-destructive`,"aria-label":`Delete target`,onClick:r,children:(0,Y.jsx)(R,{className:`size-3`})})]})]})]})}function rn({onClick:e}){return(0,Y.jsxs)(`button`,{type:`button`,onClick:e,className:`env-orbital group h-full w-full flex flex-col items-center justify-center gap-2 border border-dashed py-10 text-muted-foreground transition-colors hover:border-primary/30 hover:text-primary`,style:{"--_status":`var(--tooltip-border)`},children:[(0,Y.jsx)(B,{className:`size-5 transition-transform group-hover:scale-110`}),(0,Y.jsx)(`span`,{className:`text-xs`,children:`Add Target`})]})}function an({targets:e,onMutate:t,lastOpByTarget:n,templates:r,templatesLoading:i,templatesError:a,onRetryTemplates:o,stream:s}){let[c,l]=(0,J.useState)(!1),[u,d]=(0,J.useState)(null),[f,p]=(0,J.useState)(G.id),[m,_]=(0,J.useState)({label:``,hostname:``,apiToken:``,sourceHostname:``}),[v,y]=(0,J.useState)(!1),[E,D]=(0,J.useState)(!1),{testing:k,runTest:A,cancelInFlight:j}=fe(),[M,N]=(0,J.useState)(null),[P,F]=(0,J.useState)(null),I=s.status===`running`,L=f===G.id&&m.hostname.trim().length>0&&m.sourceHostname.trim().length>0&&(u!==null||m.apiToken.trim().length>0),R=()=>{d(null),p(G.id),_({label:``,hostname:``,apiToken:``,sourceHostname:``}),D(!1),l(!0)},te=e=>{d(e.id),p(De.some(t=>t.id===e.platformId)?e.platformId:G.id),_({label:e.label,hostname:e.hostname,apiToken:``,sourceHostname:e.sourceHostname}),D(!1),l(!0)},z=async()=>{if(f!==G.id){S.error(`${$t(f)} target setup is coming soon.`);return}if(!m.label||!m.hostname||!m.sourceHostname){S.error(`Label, hostname, and source host are required.`);return}if(!u&&!m.apiToken){S.error(`API token is required for new targets.`);return}y(!0);try{u?(await he(u,{platformId:f,label:m.label,hostname:m.hostname,sourceHostname:m.sourceHostname,...m.apiToken?{apiToken:m.apiToken}:{}}),S.success(`Target updated.`)):(await se({...m,platformId:f}),S.success(`Target added.`)),l(!1),t()}catch(e){S.error(q(e,`Failed to save target.`))}finally{y(!1)}};return(0,Y.jsxs)(`div`,{className:`flex flex-col gap-4`,children:[(0,Y.jsxs)(`div`,{className:`flex items-center justify-between gap-3`,children:[(0,Y.jsxs)(`div`,{className:`flex min-w-0 items-center gap-2`,children:[(0,Y.jsx)(`h2`,{className:`flex h-5 items-center text-xs font-medium leading-none uppercase tracking-wider text-muted-foreground`,children:`Platform Targets`}),e.length>0?(0,Y.jsx)(Ue,{variant:`secondary`,className:`relative -top-px h-5 shrink-0 px-1.5 py-0 font-mono text-[10px] leading-none tabular-nums`,children:e.length}):null]}),(0,Y.jsxs)(O,{size:`sm`,className:`h-7 shrink-0 gap-1.5 text-xs`,onClick:R,children:[(0,Y.jsx)(B,{className:`size-3.5`}),` Add Target`]})]}),e.length===0?(0,Y.jsx)(ct,{titleId:`platforms-targets-empty-title`,frameIcon:(0,Y.jsx)(K,{className:`size-6 text-muted-foreground/45`,"aria-hidden":!0}),description:(0,Y.jsx)(ot,{}),children:(0,Y.jsx)(st,{onClick:R})}):(0,Y.jsx)(`div`,{className:`grid grid-cols-1 gap-3 @2xl/main:grid-cols-2 @5xl/main:grid-cols-3`,children:(0,Y.jsxs)(g,{children:[e.map((e,t)=>(0,Y.jsx)(h.div,{initial:{opacity:0,y:10},animate:{opacity:1,y:0},exit:{opacity:0,scale:.96,transition:{duration:.15}},transition:{type:`spring`,stiffness:380,damping:30,delay:t*.04},children:(0,Y.jsx)(nn,{target:e,lastOp:n.get(e.id),onEdit:()=>te(e),onDelete:()=>N(e),quickActions:(0,Y.jsx)(Zt,{target:e,templates:r,templatesLoading:i,templatesError:a,isStreaming:I,onRetryTemplates:o,onSelect:F})})},e.id)),(0,Y.jsx)(h.div,{initial:{opacity:0,y:10},animate:{opacity:1,y:0},transition:{type:`spring`,stiffness:380,damping:30,delay:e.length*.04},children:(0,Y.jsx)(rn,{onClick:R})},`add-card`)]})}),(0,Y.jsx)(Qt,{selection:P,templates:r,stream:s,onSelectionChange:F}),(0,Y.jsx)(H,{open:c,editing:u!==null,platformId:f,form:m,showToken:E,saving:v,testing:k,canTestConnection:L,onOpenChange:l,onPlatformChange:p,onFormChange:_,onShowTokenChange:D,onSave:()=>void z(),onTestConnection:()=>{L&&A({...u?{targetId:u}:{},hostname:m.hostname.trim(),sourceHostname:m.sourceHostname.trim(),...m.apiToken.trim()?{apiToken:m.apiToken.trim()}:{}})},onCancelInFlight:j}),(0,Y.jsx)(C,{open:M!==null,onOpenChange:e=>!e&&N(null),children:(0,Y.jsxs)(ee,{children:[(0,Y.jsxs)(w,{children:[(0,Y.jsx)(T,{children:`Remove Target`}),(0,Y.jsxs)(x,{children:[`Remove “`,M?.label,`”? This only deletes the saved credentials — it does not affect resources on the target platform.`]})]}),(0,Y.jsxs)(b,{children:[(0,Y.jsx)(O,{variant:`outline`,onClick:()=>N(null),children:`Cancel`}),(0,Y.jsx)(O,{variant:`destructive`,onClick:async()=>{if(!M)return;let e=M.id;N(null);try{await V(e),S.success(`Target removed.`),t()}catch(e){S.error(q(e,`Failed to remove target.`))}},children:`Remove`})]})]})})]})}var on=25;function sn({status:e}){switch(e){case`success`:return(0,Y.jsx)(Oe,{className:`size-3 text-success`});case`partial`:case`blocked`:return(0,Y.jsx)(ze,{className:`size-3 text-warning`});case`noop`:return(0,Y.jsx)(tt,{className:`size-3 text-muted-foreground`});case`failed`:return(0,Y.jsx)(Ne,{className:`size-3 text-destructive`})}}function cn({targetCount:e,opCount:t,lastOp:n}){return(0,Y.jsxs)(`div`,{className:`flex flex-wrap items-center gap-x-3 gap-y-1 text-xs text-muted-foreground`,children:[(0,Y.jsxs)(`span`,{className:`flex items-center gap-1.5`,children:[(0,Y.jsx)(K,{className:`size-3`}),(0,Y.jsx)(`span`,{className:`font-mono`,children:e}),` target`,e===1?``:`s`]}),(0,Y.jsx)(`span`,{className:`hidden h-3 w-px bg-border/40 sm:inline-block`}),(0,Y.jsxs)(`span`,{className:`flex items-center gap-1`,children:[(0,Y.jsx)(g,{mode:`popLayout`,initial:!1,children:(0,Y.jsx)(h.span,{initial:{opacity:0,y:-6},animate:{opacity:1,y:0},exit:{opacity:0,y:6},transition:{type:`spring`,stiffness:500,damping:35},className:`font-mono tabular-nums`,children:t},t)}),` `,`operation`,t===1?``:`s`]}),n&&(0,Y.jsxs)(Y.Fragment,{children:[(0,Y.jsx)(`span`,{className:`hidden h-3 w-px bg-border/40 sm:inline-block`}),(0,Y.jsxs)(`span`,{className:`flex items-center gap-1.5`,children:[(0,Y.jsx)(sn,{status:n.status}),(0,Y.jsxs)(`span`,{children:[n.operationType===`apply`?`Applied`:`Cleaned`,` `,(0,Y.jsx)(`time`,{dateTime:new Date(n.completedAt).toISOString(),title:A(n.completedAt),children:k(n.completedAt)})]})]})]})]})}function ln(){let e=f({queryKey:s.platforms.targets(),queryFn:()=>pe()}),t=e.data??[],n=$e({queryKey:s.platforms.operationsList(),queryFn:({pageParam:e})=>de({limit:on,offset:e}),initialPageParam:0,getNextPageParam:(e,t,n)=>e.hasMore&&e.operations.length>0?n+on:void 0}),r=(0,J.useMemo)(()=>n.data?.pages.flatMap(e=>e.operations)??[],[n.data]),a=n.data?.pages[0]?.total??0,o=f({queryKey:s.catalog.templates(),queryFn:()=>c(`/catalog/templates`,i.catalogTemplates)}),u=o.data??[],d=me(),p=(0,J.useRef)(d.status);(0,J.useEffect)(()=>{let e=p.current;p.current=d.status,e===`running`&&d.status===`complete`&&l.invalidateQueries({queryKey:s.platforms.operationsList()})},[d.status]);let y=(0,J.useMemo)(()=>{let e=new Map;for(let t of r)e.has(t.targetId)||e.set(t.targetId,t);return e},[r]),[b,x]=_(`tab`,v([`targets`,`operations`,`activity`]).withDefault(`targets`)),S;return S=e.isPending&&e.data===void 0?null:e.isError&&e.data===void 0?(0,Y.jsx)(m,{message:q(e.error,`Could not load targets.`),onRetry:()=>void e.refetch(),isRetrying:e.isFetching&&!e.isPending}):t.length===0?(0,Y.jsx)(ct,{titleId:`platforms-operations-empty-title`,frameIcon:(0,Y.jsx)(K,{className:`size-6 text-muted-foreground/45`,"aria-hidden":!0}),description:(0,Y.jsx)(ot,{}),children:(0,Y.jsx)(st,{onClick:()=>void x(`targets`)})}):(0,Y.jsx)(Dt,{targets:t,stream:d}),(0,Y.jsxs)(`div`,{className:`mx-auto flex h-full w-full min-w-0 max-w-screen-2xl flex-col gap-5 p-4 sm:gap-6 sm:p-6`,children:[(0,Y.jsxs)(`div`,{className:`flex shrink-0 flex-col gap-2`,children:[(0,Y.jsx)(`h1`,{className:`font-heading text-2xl font-semibold tracking-tight`,children:`Platforms`}),(0,Y.jsx)(`p`,{className:`text-sm text-muted-foreground`,children:`Connect Platforms as targets, then apply templates or run cleanup from Operations.`}),(0,Y.jsx)(cn,{targetCount:t.length,opCount:a,lastOp:r[0]})]}),(0,Y.jsxs)(Pe,{value:b,onValueChange:e=>{x(e)},className:`flex-1 min-h-0`,children:[(0,Y.jsx)(`div`,{className:`shrink-0 overflow-x-auto`,children:(0,Y.jsxs)(Me,{variant:`line`,className:`h-10! gap-0.5 min-w-max`,children:[(0,Y.jsxs)(ke,{value:`targets`,className:`gap-1.5 px-3 text-sm`,children:[(0,Y.jsx)(K,{className:`size-3.5 shrink-0`}),`Targets`]}),(0,Y.jsxs)(ke,{value:`operations`,className:`gap-1.5 px-3 text-sm`,children:[(0,Y.jsx)(ye,{className:`size-3.5 shrink-0`}),`Operations`]}),(0,Y.jsxs)(ke,{value:`activity`,className:`gap-1.5 px-3 text-sm`,children:[(0,Y.jsx)(I,{className:`size-3.5 shrink-0`}),`Activity`]})]})}),(0,Y.jsx)(Ae,{value:`targets`,className:`flex-1 py-2`,children:(0,Y.jsx)(h.div,{initial:{opacity:0,y:6},animate:{opacity:1,y:0},transition:{duration:.15,ease:`easeOut`},children:e.isError&&e.data===void 0?(0,Y.jsx)(m,{message:q(e.error,`Failed to load targets.`),onRetry:()=>void e.refetch(),isRetrying:e.isFetching&&!e.isPending}):(0,Y.jsx)(an,{targets:t,onMutate:()=>void e.refetch(),lastOpByTarget:y,templates:u,templatesLoading:o.isPending&&o.data===void 0,templatesError:o.isError&&u.length===0,onRetryTemplates:()=>void o.refetch(),stream:d})},`targets`)}),(0,Y.jsx)(Ae,{value:`operations`,className:`flex-1 py-2`,children:(0,Y.jsx)(h.div,{initial:{opacity:0,y:6},animate:{opacity:1,y:0},transition:{duration:.15,ease:`easeOut`},children:S},`operations`)}),(0,Y.jsx)(Ae,{value:`activity`,className:`flex flex-col flex-1 min-h-0 py-2`,children:(0,Y.jsx)(h.div,{initial:{opacity:0,y:6},animate:{opacity:1,y:0},transition:{duration:.15,ease:`easeOut`},className:`flex flex-col flex-1 min-h-0`,children:(0,Y.jsx)(Xt,{operations:r,totalKnown:a,isLoading:n.isPending&&!n.data,error:n.error,onRefresh:()=>void l.invalidateQueries({queryKey:s.platforms.operationsList()}),hasNextPage:n.hasNextPage,isFetchingNextPage:n.isFetchingNextPage,loadMoreError:n.isFetchNextPageError&&n.error instanceof Error?n.error:null,onRetryLoadMore:()=>void n.fetchNextPage(),onLoadMore:()=>void n.fetchNextPage()})},`activity`)})]}),(0,Y.jsx)(g,{children:d.operation||d.status===`running`?(0,Y.jsx)(lt,{stream:d,onReset:d.reset,catalogTemplates:u}):null})]})}export{ln as t};
|
|
1
|
+
import{a as e}from"./rolldown-runtime-COnpUsM8.js";import{c as t}from"./vendor-charts-95ykyDlI.js";import{at as n}from"./vendor-ui-CWUk2ulb.js";import{J as r,S as i,X as a,Y as o,b as s,o as c,x as l}from"./api-D8oAzcVE.js";import{a as u,c as d,i as f,r as p,t as m}from"./query-fetch-error-NbPqVPRR.js";import{t as h}from"./proxy-Be4WzmcS.js";import{t as g}from"./AnimatePresence-CPmH1DMY.js";import{i as _,r as v}from"./dist-xY0pK9Wy.js";import{n as y}from"./chunk-OE4NN4TA-DBWZidbW.js";import{a as b,i as x,l as S,n as C,o as w,r as ee,s as T,t as E}from"./copy-button-BvU3RDZa.js";import{C as D,S as O,m as k,o as A,u as j,w as M,x as N}from"./format-CshN6yEB.js";import{n as P,t as F}from"./utils-XFKvwlFT.js";import{t as I}from"./activity-Cy_niK56.js";import{t as L}from"./arrow-right-BjBb4z7g.js";import{C as R,E as te,S as z,T as B,_ as ne,a as V,b as re,c as ie,d as ae,f as H,g as oe,i as se,l as ce,m as le,n as ue,o as de,p as U,r as fe,s as pe,t as me,u as he,v as ge,w as _e,y as ve}from"./use-platform-stream-DBZo6HMM.js";import{n as ye,t as be}from"./catalog-template-icons-3S8RvUxD.js";import{c as xe,i as W,l as Se,n as Ce,s as we,t as Te}from"./select-CmlY1M1a.js";import{a as Ee,i as De,r as G}from"./platform-targets-BIQ1lKOg.js";import{c as Oe,i as ke,n as Ae,o as je,r as Me,s as Ne,t as Pe}from"./tabs-4SeH2unv.js";import{i as Fe,n as K,r as Ie,t as Le}from"./checkbox-C_4HRnS_.js";import{t as Re}from"./layers-1figUpjG.js";import{t as ze}from"./triangle-alert-BXrJNk3g.js";import{i as Be,n as Ve,t as He}from"./tooltip-D1ydB4g3.js";import{t as Ue}from"./badge-eIn_7YrK.js";import{a as We,i as Ge,n as Ke,o as qe,r as Je,s as Ye,t as Xe}from"./dropdown-menu-CrPXVXpG.js";import{t as Ze}from"./label-CMBWxUhA.js";import{t as q}from"./get-error-message-Dk8elqEP.js";var Qe=class extends d{constructor(e,t){super(e,t)}bindMethods(){super.bindMethods(),this.fetchNextPage=this.fetchNextPage.bind(this),this.fetchPreviousPage=this.fetchPreviousPage.bind(this)}setOptions(e){super.setOptions({...e,behavior:a()})}getOptimisticResult(e){return e.behavior=a(),super.getOptimisticResult(e)}fetchNextPage(e){return this.fetch({...e,meta:{fetchMore:{direction:`forward`}}})}fetchPreviousPage(e){return this.fetch({...e,meta:{fetchMore:{direction:`backward`}}})}createResult(e,t){let{state:n}=e,i=super.createResult(e,t),{isFetching:a,isRefetching:s,isError:c,isRefetchError:l}=i,u=n.fetchMeta?.fetchMore?.direction,d=c&&u===`forward`,f=a&&u===`forward`,p=c&&u===`backward`,m=a&&u===`backward`;return{...i,fetchNextPage:this.fetchNextPage,fetchPreviousPage:this.fetchPreviousPage,hasNextPage:r(t,n.data),hasPreviousPage:o(t,n.data),isFetchNextPageError:d,isFetchingNextPage:f,isFetchPreviousPageError:p,isFetchingPreviousPage:m,isRefetchError:l&&!d&&!p,isRefetching:s&&!f&&!m}}};function $e(e,t){return u(e,Qe,t)}var et=P(`clipboard-list`,[[`rect`,{width:`8`,height:`4`,x:`8`,y:`2`,rx:`1`,ry:`1`,key:`tgr4d6`}],[`path`,{d:`M16 4h2a2 2 0 0 1 2 2v14a2 2 0 0 1-2 2H6a2 2 0 0 1-2-2V6a2 2 0 0 1 2-2h2`,key:`116196`}],[`path`,{d:`M12 11h4`,key:`1jrz19`}],[`path`,{d:`M12 16h4`,key:`n85exb`}],[`path`,{d:`M8 11h.01`,key:`1dfujw`}],[`path`,{d:`M8 16h.01`,key:`18s6g9`}]]),tt=P(`clock-3`,[[`circle`,{cx:`12`,cy:`12`,r:`10`,key:`1mglay`}],[`path`,{d:`M12 6v6h4`,key:`135r8i`}]]),nt=P(`ellipsis`,[[`circle`,{cx:`12`,cy:`12`,r:`1`,key:`41hilf`}],[`circle`,{cx:`19`,cy:`12`,r:`1`,key:`1wjl8i`}],[`circle`,{cx:`5`,cy:`12`,r:`1`,key:`1pcz8c`}]]),rt=P(`pencil`,[[`path`,{d:`M21.174 6.812a1 1 0 0 0-3.986-3.987L3.842 16.174a2 2 0 0 0-.5.83l-1.321 4.352a.5.5 0 0 0 .623.622l4.353-1.32a2 2 0 0 0 .83-.497z`,key:`1a8usu`}],[`path`,{d:`m15 5 4 4`,key:`1mk7zo`}]]),it=P(`upload`,[[`path`,{d:`M12 3v12`,key:`1x0j5s`}],[`path`,{d:`m17 8-5-5-5 5`,key:`7q97r8`}],[`path`,{d:`M21 15v4a2 2 0 0 1-2 2H5a2 2 0 0 1-2-2v-4`,key:`ih7n3h`}]]),J=e(t(),1),Y=n();function X({className:e,...t}){return(0,Y.jsx)(`div`,{"data-slot":`skeleton`,className:F(`animate-pulse rounded-[var(--miravo-radius-tight)] bg-muted`,e),...t})}var at=`rounded-(--miravo-radius-stadium-sm) border border-dashed border-border/55 bg-muted/10`;function ot(){return(0,Y.jsx)(`p`,{className:`mt-2 text-pretty text-sm leading-relaxed text-muted-foreground`,children:`Add a target to get started.`})}function st({onClick:e}){return(0,Y.jsxs)(O,{type:`button`,size:`sm`,className:`h-7 shrink-0 gap-1.5 text-xs`,onClick:e,children:[(0,Y.jsx)(B,{className:`size-3.5`,"aria-hidden":!0}),`Add Target`]})}function ct({titleId:e,frameIcon:t,description:n,children:r}){return(0,Y.jsx)(`section`,{"aria-labelledby":e,className:at,children:(0,Y.jsxs)(`div`,{className:`flex flex-col items-center gap-4 px-4 py-10 text-center`,children:[(0,Y.jsx)(`div`,{className:`flex size-12 items-center justify-center rounded-(--miravo-radius-stadium-sm) border border-dashed border-border/50`,children:t}),(0,Y.jsxs)(`div`,{className:`max-w-sm`,children:[(0,Y.jsx)(`h2`,{id:e,className:`font-heading text-sm font-semibold tracking-tight text-foreground`,children:`No targets yet`}),n]}),r]})})}function lt({stream:e,onReset:t,catalogTemplates:n}){if(!e.operation&&e.status!==`running`)return null;let{title:r,subtitle:i}=ve(e),a=e.status===`complete`,o=e.status===`error`,s=e.status===`running`,c=a||o,l=e.cancelRequested;async function u(){await e.cancel().catch(()=>{})}return(0,Y.jsx)(U,{title:r,subtitle:i,footerAction:s&&e.operation?.operationId?(0,Y.jsx)(`div`,{className:`ml-auto shrink-0`,children:(0,Y.jsx)(`button`,{type:`button`,onClick:u,disabled:l,"aria-busy":l,className:F(D({variant:`outline`,size:`sm`}),`group h-8 gap-1.5 px-3 text-xs`,l?`cursor-not-allowed`:`hover:bg-destructive/12 hover:text-destructive hover:border-destructive/35`),children:l?(0,Y.jsxs)(Y.Fragment,{children:[(0,Y.jsx)(je,{className:`size-3.5 shrink-0 animate-spin text-muted-foreground`,"aria-hidden":!0}),(0,Y.jsx)(h.span,{animate:{opacity:[1,.72,1]},transition:{duration:1.25,repeat:1/0,ease:`easeInOut`},className:`font-medium text-foreground`,children:`Cancelling…`})]}):(0,Y.jsxs)(Y.Fragment,{children:[(0,Y.jsx)(M,{className:`size-3.5 shrink-0 text-foreground/65 group-hover:text-destructive`,"aria-hidden":!0}),(0,Y.jsx)(h.span,{animate:{opacity:[1,.88,1]},transition:{duration:2.2,repeat:1/0,ease:`easeInOut`},children:`Cancel`})]})})}):c?(0,Y.jsxs)(`div`,{className:`flex w-full flex-col gap-1.5`,children:[(0,Y.jsxs)(`div`,{className:`flex min-w-0 w-full flex-1 flex-wrap items-center justify-between gap-x-3 gap-y-1`,children:[(0,Y.jsxs)(y,{to:`/platforms?tab=activity`,className:F(D({variant:`ghost`,size:`xs`}),`group inline-flex h-6 shrink-0 items-center gap-1.5 px-2 text-[11px] font-medium text-foreground/80`,`hover:bg-primary/12 hover:text-primary`),children:[(0,Y.jsx)(I,{className:`size-3 shrink-0 text-foreground/70 group-hover:text-primary`,"aria-hidden":!0}),`View full activity`,(0,Y.jsx)(Ee,{className:`size-2.5 shrink-0 text-foreground/50 group-hover:text-primary`,"aria-hidden":!0})]}),(0,Y.jsx)(`div`,{className:`flex shrink-0 items-center`,children:(0,Y.jsx)(O,{type:`button`,variant:`secondary`,size:`xs`,className:`h-6 px-2.5 text-[11px] font-medium`,onClick:t,children:`Close`})})]}),e.operation?.status===`cancelled`||o&&e.operation?(0,Y.jsx)(ne,{type:e.operation.type,errorMessage:e.operation.error,className:`mt-2.5 w-full min-w-0`}):null]}):void 0,onDismiss:t,children:e.operation?(0,Y.jsx)(oe,{operation:e.operation,catalogTemplates:n,logs:e.logs}):(0,Y.jsxs)(`div`,{className:`flex flex-col gap-2 py-1`,children:[(0,Y.jsxs)(`div`,{className:`flex items-center gap-2`,children:[(0,Y.jsx)(je,{className:`size-3.5 animate-spin text-primary`,"aria-hidden":!0}),(0,Y.jsx)(`span`,{className:`text-xs text-foreground/78`,children:`Connecting to Litmus Edge…`})]}),(0,Y.jsx)(`div`,{className:`h-1 w-full overflow-hidden rounded-full bg-muted/55`,children:(0,Y.jsx)(h.div,{className:`h-full w-2/5 rounded-full bg-primary`,animate:{x:[`-100%`,`250%`]},transition:{duration:1.2,repeat:1/0,ease:`easeInOut`}})})]})})}var ut=`miravo:platforms:recent-template-ids`,dt=8,ft=`miravo:platforms:last-target-id`;function Z(){if(typeof window>`u`)return[];try{let e=window.localStorage.getItem(ut),t=e?JSON.parse(e):[];return Array.isArray(t)?t.filter(e=>typeof e==`string`):[]}catch{return[]}}function pt(e){if(typeof window>`u`)return;let t=[e,...Z().filter(t=>t!==e)].slice(0,dt);try{window.localStorage.setItem(ut,JSON.stringify(t))}catch{}}function mt(){if(!(typeof window>`u`))try{return window.localStorage.getItem(ft)??void 0}catch{return}}function ht(e){if(!(typeof window>`u`))try{window.localStorage.setItem(ft,e)}catch{}}function gt(e){return e instanceof DOMException&&e.name===`AbortError`||e instanceof Error&&e.name===`AbortError`}function _t(e){return e.map(e=>e.length===0?e:e.charAt(0).toUpperCase()+e.slice(1)).join(`, `)}function vt({onCloseTable:e,planKind:t=`apply`}){return(0,Y.jsx)(`div`,{className:`border-b border-border/40 px-3 py-3 sm:px-4`,children:(0,Y.jsxs)(`div`,{className:`flex gap-3`,children:[(0,Y.jsx)(`div`,{className:`flex size-10 shrink-0 items-center justify-center rounded-[var(--miravo-radius-stadium-sm)] border border-border/50 bg-muted/15`,children:(0,Y.jsx)(et,{className:`size-4 text-muted-foreground`,"aria-hidden":!0})}),(0,Y.jsxs)(`div`,{className:`flex min-w-0 flex-1 items-start gap-1 pt-0.5 sm:gap-2`,children:[(0,Y.jsxs)(`div`,{className:`min-w-0 flex-1`,children:[(0,Y.jsxs)(`div`,{className:`flex flex-wrap items-baseline gap-2`,children:[(0,Y.jsx)(`p`,{className:`font-heading text-[11px] font-semibold uppercase tracking-[0.14em] text-foreground`,children:t===`cleanup`?`Expected removals`:`Expected changes`}),(0,Y.jsx)(`span`,{className:`rounded-[var(--miravo-radius-tight)] border border-primary/25 bg-primary/5 px-1.5 py-px font-mono text-[9px] uppercase tracking-wider text-primary/90`,children:`Draft`})]}),(0,Y.jsx)(`p`,{className:`mt-1.5 max-w-prose text-[10px] leading-relaxed text-muted-foreground`,children:t===`cleanup`?`Preview only — nothing runs until you confirm cleanup.`:`Preview only — nothing runs until you confirm deploy.`})]}),e&&(0,Y.jsx)(O,{type:`button`,variant:`ghost`,size:`icon`,className:`size-8 shrink-0 text-muted-foreground hover:text-foreground`,onClick:e,"aria-label":`Close table`,children:(0,Y.jsx)(M,{className:`size-4`,"aria-hidden":!0})})]})]})})}var yt={create:`border-success/30 bg-success/12 text-success`,update:`border-info/30 bg-info/12 text-info`,replace:`border-chart-2/30 bg-chart-2/12 text-chart-2`,delete:`border-destructive/30 bg-destructive/12 text-destructive`,noop:`border-border/50 bg-muted/50 text-foreground/75`,blocked:`border-warning/30 bg-warning/12 text-warning`};function bt({plan:e,planKind:t}){let n=t===`apply`&&e.sourceHostname!=null&&e.sourceHostname!==``;return(0,Y.jsx)(`div`,{className:`border-b border-border/35 bg-muted/10 px-3 py-2 sm:px-4`,children:(0,Y.jsxs)(`div`,{className:`flex flex-col gap-1.5 text-[10px] leading-snug sm:flex-row sm:flex-wrap sm:items-baseline sm:gap-x-4 sm:gap-y-1`,children:[(0,Y.jsxs)(`div`,{className:`flex min-w-0 flex-wrap items-baseline gap-x-2 gap-y-0.5`,children:[(0,Y.jsx)(`span`,{className:`shrink-0 font-mono text-[9px] uppercase tracking-wider text-muted-foreground/85`,children:`Target LE`}),(0,Y.jsx)(`span`,{className:`font-mono text-foreground/90 wrap-anywhere`,children:e.targetHost})]}),n?(0,Y.jsxs)(`div`,{className:`flex min-w-0 flex-wrap items-baseline gap-x-2 gap-y-0.5 sm:border-l sm:border-border/50 sm:pl-4`,children:[(0,Y.jsx)(`span`,{className:`shrink-0 font-mono text-[9px] uppercase tracking-wider text-muted-foreground/85`,children:z}),(0,Y.jsx)(`span`,{className:`font-mono text-foreground/90 wrap-anywhere`,children:e.sourceHostname})]}):null]})})}function xt({entries:e}){let t=e.reduce((e,t)=>(e[t.action]++,e),{create:0,update:0,replace:0,delete:0,noop:0,blocked:0});return(0,Y.jsxs)(`div`,{className:`flex flex-wrap items-center gap-2 border-b border-border/35 px-3 py-2.5 sm:px-4`,children:[(0,Y.jsx)(`span`,{className:`sr-only`,children:`Summary of planned actions`}),(0,Y.jsx)(`span`,{className:`font-mono text-[9px] uppercase tracking-[0.18em] text-muted-foreground`,children:`Manifest`}),(0,Y.jsx)(`span`,{className:`hidden h-3 w-px bg-border/60 sm:block`,"aria-hidden":!0}),(0,Y.jsxs)(`div`,{className:`flex min-w-0 flex-1 flex-wrap items-center gap-2`,children:[t.create>0&&(0,Y.jsxs)(`span`,{className:`inline-flex items-center rounded-[var(--miravo-radius-tight)] border border-success/25 bg-success/10 px-2 py-0.5 font-mono text-[10px] tabular-nums text-success`,children:[`+`,t.create,` new`]}),t.update>0&&(0,Y.jsxs)(`span`,{className:`inline-flex items-center rounded-[var(--miravo-radius-tight)] border border-info/25 bg-info/10 px-2 py-0.5 font-mono text-[10px] tabular-nums text-info`,children:[`~`,t.update,` update`]}),t.replace>0&&(0,Y.jsxs)(`span`,{className:`inline-flex items-center rounded-[var(--miravo-radius-tight)] border border-chart-2/25 bg-chart-2/10 px-2 py-0.5 font-mono text-[10px] tabular-nums text-chart-2`,children:[`↺`,t.replace,` replace`]}),t.delete>0&&(0,Y.jsxs)(`span`,{className:`inline-flex items-center rounded-[var(--miravo-radius-tight)] border border-destructive/25 bg-destructive/10 px-2 py-0.5 font-mono text-[10px] tabular-nums text-destructive`,children:[`−`,t.delete,` remove`]}),t.noop>0&&(0,Y.jsxs)(`span`,{className:`inline-flex items-center rounded-[var(--miravo-radius-tight)] border border-border/50 bg-muted/50 px-2 py-0.5 font-mono text-[10px] tabular-nums text-foreground/75`,children:[`=`,t.noop,` unchanged`]}),t.blocked>0&&(0,Y.jsxs)(`span`,{className:`inline-flex items-center rounded-[var(--miravo-radius-tight)] border border-warning/25 bg-warning/10 px-2 py-0.5 font-mono text-[10px] tabular-nums text-warning`,children:[t.blocked,` skipped`]})]})]})}function St({plan:e,onCloseTable:t,planKind:n=`apply`}){return e.entries.length===0?(0,Y.jsxs)(`div`,{className:`overflow-hidden rounded-[var(--miravo-radius-stadium-sm)] border border-dashed border-border/55`,children:[(0,Y.jsx)(vt,{onCloseTable:t,planKind:n}),(0,Y.jsx)(bt,{plan:e,planKind:n}),(0,Y.jsxs)(`div`,{className:`flex flex-col items-center gap-3 px-4 py-10 text-center`,children:[(0,Y.jsx)(`div`,{className:`flex size-12 items-center justify-center rounded-[var(--miravo-radius-stadium-sm)] border border-border/50`,children:(0,Y.jsx)(et,{className:`size-6 text-muted-foreground/45`,"aria-hidden":!0})}),(0,Y.jsxs)(`div`,{children:[(0,Y.jsx)(`p`,{className:`font-heading text-sm font-semibold tracking-tight text-foreground`,children:n===`cleanup`?`Nothing to remove`:`Nothing to change`}),(0,Y.jsx)(`p`,{className:`mx-auto mt-2 max-w-sm text-[11px] leading-relaxed text-muted-foreground`,children:n===`cleanup`?`No Miravo-managed resources matched this cleanup scope on the environment — nothing would be deleted.`:`This environment already matches what is on the target — no create or update steps.`})]})]})]}):(0,Y.jsxs)(`div`,{className:`overflow-hidden rounded-[var(--miravo-radius-stadium-sm)] border border-border/45`,children:[(0,Y.jsx)(vt,{onCloseTable:t,planKind:n}),(0,Y.jsx)(bt,{plan:e,planKind:n}),(0,Y.jsx)(xt,{entries:e.entries}),(0,Y.jsx)(`div`,{className:`overflow-x-auto`,children:(0,Y.jsxs)(`table`,{className:`w-full min-w-lg text-xs`,children:[(0,Y.jsx)(`caption`,{className:`sr-only`,children:n===`cleanup`?`Detailed list of planned cleanup actions in deletion order`:`Detailed list of create, update, and delete actions in deployment order`}),(0,Y.jsx)(`thead`,{children:(0,Y.jsxs)(`tr`,{className:`border-b border-border/45`,children:[(0,Y.jsx)(`th`,{scope:`col`,className:`sticky top-0 z-10 bg-background px-3 py-2 text-left font-heading text-[9px] font-semibold uppercase tracking-[0.14em] text-muted-foreground sm:px-3.5`,children:`Action`}),(0,Y.jsx)(`th`,{scope:`col`,className:`sticky top-0 z-10 bg-background px-3 py-2 text-left font-heading text-[9px] font-semibold uppercase tracking-[0.14em] text-muted-foreground sm:px-3.5`,children:`Type`}),(0,Y.jsx)(`th`,{scope:`col`,className:`sticky top-0 z-10 bg-background px-3 py-2 text-left font-heading text-[9px] font-semibold uppercase tracking-[0.14em] text-muted-foreground sm:px-3.5`,children:`Name`}),(0,Y.jsx)(`th`,{scope:`col`,className:`sticky top-0 z-10 hidden bg-background px-3 py-2 text-left font-heading text-[9px] font-semibold uppercase tracking-[0.14em] text-muted-foreground sm:table-cell sm:px-3.5`,children:`Protocol`}),(0,Y.jsx)(`th`,{scope:`col`,className:`sticky top-0 z-10 hidden bg-background px-3 py-2 text-left font-heading text-[9px] font-semibold uppercase tracking-[0.14em] text-muted-foreground md:table-cell md:px-3.5`,children:`Detail`})]})}),(0,Y.jsx)(`tbody`,{children:e.entries.map((e,t)=>(0,Y.jsxs)(`tr`,{className:F(`border-b border-border/25 transition-colors`,t%2==1?`bg-muted/35`:`bg-transparent`,`hover:bg-primary/4`),children:[(0,Y.jsx)(`td`,{className:`px-3 py-2 align-middle sm:px-3.5`,children:(0,Y.jsx)(Ue,{variant:`outline`,className:F(`border px-1.5 py-0 font-mono text-[10px] uppercase tracking-wide`,yt[e.action]),children:e.action})}),(0,Y.jsx)(`td`,{className:`px-3 py-2 align-middle font-mono text-[11px] text-foreground sm:px-3.5`,children:e.resourceType}),(0,Y.jsx)(`td`,{className:`max-w-[min(16rem,28vw)] truncate px-3 py-2 align-middle font-mono text-[11px] text-foreground sm:max-w-xs sm:px-3.5`,children:e.name}),(0,Y.jsx)(`td`,{className:`hidden px-3 py-2 align-middle font-mono text-[11px] text-muted-foreground sm:table-cell sm:px-3.5`,children:e.protocol??`—`}),(0,Y.jsx)(`td`,{className:`hidden max-w-xs truncate px-3 py-2 align-middle text-[11px] text-muted-foreground md:table-cell md:px-3.5`,children:e.blockReason??e.detail??`—`})]},`${e.action}-${e.resourceType}-${e.name}-${e.protocol??``}-${e.detail??e.blockReason??``}`))})]})}),(0,Y.jsxs)(`div`,{className:`flex flex-col gap-2 border-t border-border/40 px-3 py-3 text-[10px] text-muted-foreground sm:flex-row sm:items-center sm:justify-between sm:gap-4 sm:px-4`,children:[(0,Y.jsxs)(`span`,{children:[(0,Y.jsx)(`span`,{className:`font-mono tabular-nums text-foreground/90`,children:e.entries.length}),` `,(0,Y.jsxs)(`span`,{className:`text-muted-foreground/90`,children:[e.entries.length===1?`action`:`actions`,` queued`]})]}),(0,Y.jsxs)(`div`,{className:`flex min-w-0 flex-wrap items-center gap-x-2 gap-y-1 font-mono text-[10px] wrap-anywhere`,children:[(0,Y.jsx)(`span`,{className:`shrink-0 text-[9px] uppercase tracking-wider text-muted-foreground/80`,children:`Scope`}),(0,Y.jsx)(`span`,{className:`min-w-0 text-foreground/90`,children:_t(e.scope)})]})]})]})}var Ct=[`s1`,`s2`,`s3`,`s4`];function wt(){return(0,Y.jsxs)(`div`,{className:`overflow-hidden rounded-[var(--miravo-radius-stadium-sm)] border border-border/45`,role:`status`,"aria-busy":`true`,"aria-live":`polite`,children:[(0,Y.jsx)(`span`,{className:`sr-only`,children:`Loading plan preview`}),(0,Y.jsx)(`div`,{className:`border-b border-border/40 px-3 py-3 sm:px-4`,children:(0,Y.jsxs)(`div`,{className:`flex gap-3`,children:[(0,Y.jsx)(X,{className:`size-10 shrink-0 rounded-[var(--miravo-radius-stadium-sm)]`}),(0,Y.jsx)(`div`,{className:`flex min-w-0 flex-1 items-start gap-1 pt-0.5 sm:gap-2`,children:(0,Y.jsxs)(`div`,{className:`min-w-0 flex-1`,children:[(0,Y.jsxs)(`div`,{className:`flex flex-wrap items-baseline gap-2`,children:[(0,Y.jsx)(X,{className:`h-3.5 w-40`}),(0,Y.jsx)(X,{className:`h-4 w-11 rounded-[var(--miravo-radius-tight)] border`})]}),(0,Y.jsx)(X,{className:`mt-1.5 h-3 max-w-prose`})]})})]})}),(0,Y.jsxs)(`div`,{className:`flex flex-wrap items-center gap-2 border-b border-border/35 px-3 py-2.5 sm:px-4`,children:[(0,Y.jsx)(X,{className:`h-2.5 w-14`}),(0,Y.jsx)(X,{className:`hidden h-3 w-px shrink-0 sm:block`}),(0,Y.jsxs)(`div`,{className:`flex min-w-0 flex-1 flex-wrap items-center gap-2`,children:[(0,Y.jsx)(X,{className:`h-5 w-18 rounded-[var(--miravo-radius-tight)]`}),(0,Y.jsx)(X,{className:`h-5 w-24 rounded-[var(--miravo-radius-tight)]`}),(0,Y.jsx)(X,{className:`h-5 w-20 rounded-[var(--miravo-radius-tight)]`})]})]}),(0,Y.jsx)(`div`,{className:`overflow-x-auto`,children:(0,Y.jsxs)(`table`,{className:`w-full min-w-lg text-xs`,"aria-hidden":!0,children:[(0,Y.jsx)(`thead`,{children:(0,Y.jsxs)(`tr`,{className:`border-b border-border/45`,children:[(0,Y.jsx)(`th`,{scope:`col`,className:`sticky top-0 z-10 bg-background px-3 py-2 text-left sm:px-3.5`,children:(0,Y.jsx)(X,{className:`h-2.5 w-12`})}),(0,Y.jsx)(`th`,{scope:`col`,className:`sticky top-0 z-10 bg-background px-3 py-2 text-left sm:px-3.5`,children:(0,Y.jsx)(X,{className:`h-2.5 w-9`})}),(0,Y.jsx)(`th`,{scope:`col`,className:`sticky top-0 z-10 bg-background px-3 py-2 text-left sm:px-3.5`,children:(0,Y.jsx)(X,{className:`h-2.5 w-10`})}),(0,Y.jsx)(`th`,{scope:`col`,className:`sticky top-0 z-10 hidden bg-background px-3 py-2 text-left sm:table-cell sm:px-3.5`,children:(0,Y.jsx)(X,{className:`h-2.5 w-14`})}),(0,Y.jsx)(`th`,{scope:`col`,className:`sticky top-0 z-10 hidden bg-background px-3 py-2 text-left md:table-cell md:px-3.5`,children:(0,Y.jsx)(X,{className:`h-2.5 w-11`})})]})}),(0,Y.jsx)(`tbody`,{children:Ct.map((e,t)=>(0,Y.jsxs)(`tr`,{className:F(`border-b border-border/25 transition-colors`,t%2==1?`bg-muted/35`:`bg-transparent`,`hover:bg-primary/4`),children:[(0,Y.jsx)(`td`,{className:`px-3 py-2 align-middle sm:px-3.5`,children:(0,Y.jsx)(X,{className:`h-5 w-13 rounded-[var(--miravo-radius-tight)]`})}),(0,Y.jsx)(`td`,{className:`px-3 py-2 align-middle sm:px-3.5`,children:(0,Y.jsx)(X,{className:`h-3.5 w-16 font-mono`})}),(0,Y.jsx)(`td`,{className:`max-w-[min(16rem,28vw)] px-3 py-2 align-middle sm:max-w-xs sm:px-3.5`,children:(0,Y.jsx)(X,{className:`h-3.5 w-full max-w-48 font-mono`})}),(0,Y.jsx)(`td`,{className:`hidden px-3 py-2 align-middle sm:table-cell sm:px-3.5`,children:(0,Y.jsx)(X,{className:`h-3.5 w-10 font-mono`})}),(0,Y.jsx)(`td`,{className:`hidden max-w-xs px-3 py-2 align-middle md:table-cell md:px-3.5`,children:(0,Y.jsx)(X,{className:`h-3.5 w-full max-w-40`})})]},e))})]})}),(0,Y.jsxs)(`div`,{className:`flex flex-col gap-2 border-t border-border/40 px-3 py-3 text-[10px] text-muted-foreground sm:flex-row sm:items-center sm:justify-between sm:gap-4 sm:px-4`,children:[(0,Y.jsxs)(`span`,{className:`inline-flex items-center gap-1`,children:[(0,Y.jsx)(X,{className:`inline-block h-3 w-6 rounded-[var(--miravo-radius-tight)]`}),(0,Y.jsx)(X,{className:`inline-block h-3 w-28`})]}),(0,Y.jsxs)(`div`,{className:`flex min-w-0 flex-wrap items-center gap-x-2 gap-y-1 font-mono text-[10px] wrap-anywhere`,children:[(0,Y.jsx)(X,{className:`h-2.5 w-8 shrink-0`}),(0,Y.jsx)(X,{className:`h-6 min-w-32 rounded-[var(--miravo-radius-tight)] border border-border/50 px-2 py-0.5`}),(0,Y.jsx)(X,{className:`h-1 w-1 shrink-0 rounded-full`}),(0,Y.jsx)(X,{className:`h-2.5 w-10 shrink-0`}),(0,Y.jsx)(X,{className:`h-3 min-w-16 max-w-56 flex-1`})]})]})]})}var Tt=50;function Et({open:e,type:t,targetLabel:n,targetHostname:r,templates:i,templatesLoading:a,templatesError:o,onRetryTemplates:s,onOpenChange:c,onSelect:l}){let[u,d]=(0,J.useState)(``),[f,p]=(0,J.useState)(Z),m=(0,J.useDeferredValue)(u);(0,J.useEffect)(()=>{e&&(d(``),p(Z()))},[e]);let h=(0,J.useMemo)(()=>{let e=m.trim().toLowerCase(),t=new Map(f.map((e,t)=>[e,t])),n=[],r=new Set;for(let t of i){if(r.has(t.id))continue;r.add(t.id);let i=[t.name,t.id,t.category,t.description??``,t.models.join(` `)].join(` `).toLowerCase();e!==``&&!i.includes(e)||n.push(t)}return n.sort((e,n)=>{let r=t.get(e.id)??1/0,i=t.get(n.id)??1/0;return r===i?e.name.localeCompare(n.name):r-i}),{items:n.slice(0,Tt),total:n.length,recentRank:t}},[i,m,f]),g=t===`apply`?`Apply environment`:`Cleanup environment`,_=e=>{pt(e.id),l(e)};return(0,Y.jsx)(C,{open:e,onOpenChange:c,children:(0,Y.jsxs)(ee,{className:`flex max-h-[82vh] min-h-0 flex-col gap-0 overflow-hidden p-0 sm:max-w-xl`,children:[(0,Y.jsxs)(`div`,{className:`shrink-0 border-b border-border/60 px-5 pb-3 pt-5`,children:[(0,Y.jsx)(T,{className:`text-sm font-semibold`,children:g}),(0,Y.jsxs)(x,{className:`mt-1 text-xs`,children:[n,` / `,r]})]}),(0,Y.jsx)(`div`,{className:`shrink-0 border-b border-border/45 px-5 py-3`,children:(0,Y.jsxs)(`div`,{className:`relative`,children:[(0,Y.jsx)(_e,{className:`pointer-events-none absolute left-2.5 top-1/2 size-3.5 -translate-y-1/2 text-muted-foreground`,"aria-hidden":!0}),(0,Y.jsx)(N,{value:u,onChange:e=>d(e.currentTarget.value),className:`h-9 pl-8`,placeholder:`Search environments`,autoFocus:!0})]})}),(0,Y.jsx)(`div`,{className:`min-h-0 flex-1 overflow-y-auto px-3 py-3`,children:a&&i.length===0?(0,Y.jsx)(`div`,{className:`rounded-[var(--miravo-radius-tight)] border border-border/50 px-3 py-2 text-xs text-muted-foreground`,children:`Loading environments...`}):o&&i.length===0?(0,Y.jsxs)(`div`,{className:`flex items-center justify-between gap-3 rounded-[var(--miravo-radius-tight)] border border-warning/25 bg-warning/5 px-3 py-2 text-xs text-warning`,children:[(0,Y.jsx)(`span`,{children:`Could not load environments.`}),(0,Y.jsx)(O,{type:`button`,variant:`ghost`,size:`sm`,className:`h-7 text-warning hover:text-warning`,onClick:s,children:`Retry`})]}):h.items.length===0?(0,Y.jsx)(`div`,{className:`rounded-[var(--miravo-radius-tight)] border border-border/50 px-3 py-2 text-xs text-muted-foreground`,children:`No matching environments.`}):(0,Y.jsx)(`div`,{className:`flex flex-col gap-1`,children:h.items.map(e=>{let t=h.recentRank.has(e.id);return(0,Y.jsxs)(`button`,{type:`button`,className:`flex min-h-12 w-full min-w-0 items-center gap-2 rounded-[var(--miravo-radius-tight)] px-2 py-2 text-left text-xs transition-colors hover:bg-muted/45 focus-visible:outline-none focus-visible:ring-2 focus-visible:ring-ring/70`,onClick:()=>_(e),children:[(0,Y.jsx)(`span`,{className:`flex size-8 shrink-0 items-center justify-center rounded-[var(--miravo-radius-tight)] border border-border/35 bg-muted/25 text-primary`,children:(0,Y.jsx)(be,{id:e.id,className:`size-3.5`})}),(0,Y.jsxs)(`span`,{className:`min-w-0 flex-1`,children:[(0,Y.jsxs)(`span`,{className:`flex min-w-0 items-center gap-2`,children:[(0,Y.jsx)(`span`,{className:`truncate font-medium text-foreground`,children:e.name}),t?(0,Y.jsx)(`span`,{className:`shrink-0 rounded-[var(--miravo-radius-tight)] border border-primary/25 bg-primary/8 px-1.5 py-px font-mono text-[9px] uppercase tracking-wider text-primary`,children:`Recent`}):null]}),(0,Y.jsxs)(`span`,{className:`mt-0.5 block truncate font-mono text-[11px] text-muted-foreground`,children:[e.id,` / `,e.instanceCount,` instances`]})]})]},e.id)})})}),h.total>h.items.length?(0,Y.jsxs)(`div`,{className:`shrink-0 border-t border-border/45 px-5 py-2 text-[11px] text-muted-foreground`,children:[`Showing `,h.items.length,` of `,h.total,`. Refine search.`]}):null]})})}function Dt({targets:e,stream:t}){let[n,r]=(0,J.useState)(`apply`),[a,o]=(0,J.useState)(``),[l,u]=(0,J.useState)(``),[d,p]=(0,J.useState)(!1),[g,_]=(0,J.useState)(null),[v,y]=(0,J.useState)(!1),[b,x]=(0,J.useState)(!1),[C,w]=(0,J.useState)(!1),[ee]=(0,J.useState)(mt),T=(0,J.useRef)(0),E=(0,J.useRef)(null),D=t.status===`running`,k=n===`apply`,A=f({queryKey:s.catalog.templates(),queryFn:()=>c(`/catalog/templates`,i.catalogTemplates)}),j=A.data??[],N=j.find(e=>e.id===l),P=e.find(e=>e.id===a),I=k?!!a&&!!l:!!a&&(d||!!l),L=(0,J.useCallback)(()=>{T.current+=1,E.current?.abort(),E.current=null,y(!1),_(null)},[]);(0,J.useEffect)(()=>{if(!(l||j.length===0||d))for(let e of Z()){let t=j.find(t=>t.id===e);if(t){u(t.id);return}}},[l,j,d]);let te=(0,J.useCallback)(()=>{L(),S.message(`Preview cancelled`)},[L]),z=e=>{D||(r(e),L(),p(!1))},B=(0,J.useCallback)(async e=>{if(e===`apply`){if(!a||!l)return}else if(!a||!d&&!l)return;t.operation&&t.status!==`running`&&t.reset(),E.current?.abort(),T.current+=1;let n=T.current,r=new AbortController;E.current=r,y(!0),_(null);try{let t=e===`apply`?await ce({targetId:a,template:l},{signal:r.signal}):await ie({targetId:a,...d?{allManaged:!0}:{template:l}},{signal:r.signal});if(n!==T.current)return;_(t.plan)}catch(t){if(n!==T.current||gt(t))return;S.error(q(t,e===`apply`?`Plan failed`:`Cleanup plan failed`))}finally{n===T.current&&y(!1)}},[a,l,d,t]),ne=(0,J.useCallback)(e=>{x(!1),L();let{scope:r,ifUnmanaged:i}=e;ht(a),l&&pt(l),n===`apply`?t.startApply({targetId:a,template:l,scope:r,ifUnmanaged:i}):t.startCleanup({targetId:a,...d?{allManaged:!0}:{template:l},scope:r})},[n,a,l,d,t,L]),V=!k&&d,H=I&&!D,oe=k?Ie:R,se=`Awaiting selection`;H&&(se=k?`Commit apply`:`Commit cleanup`);let de=V?`All managed resources`:N?.name??`Select environment`,U=(0,Y.jsx)(Re,{className:`size-3.5`,"aria-hidden":!0});V?U=(0,Y.jsx)(R,{className:`size-3.5`,"aria-hidden":!0}):N&&(U=(0,Y.jsx)(be,{id:N.id,className:`size-3.5`}));let fe=k?`Provisions devices, tags, and Digital Twin models from the selected environment on the selected target.`:`Removes Miravo-managed resources for this environment from the selected target.`;V&&(fe=`Removes all Miravo-managed resources from the target (ignores environment scope).`);let pe=P?`${P.label} / ${de}`:`Select target and environment`;return(0,Y.jsxs)(`div`,{className:`flex flex-col gap-4`,children:[(0,Y.jsxs)(`div`,{className:`flex flex-wrap items-center gap-3`,children:[(0,Y.jsxs)(`div`,{role:`toolbar`,"aria-label":`Operation mode`,className:`inline-flex items-center gap-0.5 rounded-[var(--miravo-radius-pill)] border border-border/50 bg-muted/15 p-0.5`,children:[(0,Y.jsxs)(`button`,{type:`button`,"aria-pressed":k,className:F(`relative flex items-center gap-1.5 rounded-[var(--miravo-radius-pill)] px-4 py-1.5 text-xs font-medium transition-colors`,k?`text-primary`:`text-muted-foreground hover:text-foreground`),onClick:()=>z(`apply`),disabled:D,children:[k&&(0,Y.jsx)(h.span,{layoutId:`mode-pill`,className:`absolute inset-0 rounded-[var(--miravo-radius-pill)] bg-primary/15 shadow-sm`,transition:{type:`spring`,stiffness:500,damping:40}}),(0,Y.jsx)(it,{className:`relative z-10 size-3.5`}),(0,Y.jsx)(`span`,{className:`relative z-10`,children:`Apply`})]}),(0,Y.jsxs)(`button`,{type:`button`,"aria-pressed":!k,className:F(`relative flex items-center gap-1.5 rounded-[var(--miravo-radius-pill)] px-4 py-1.5 text-xs font-medium transition-colors`,k?`text-muted-foreground hover:text-foreground`:`text-destructive`),onClick:()=>z(`cleanup`),disabled:D,children:[!k&&(0,Y.jsx)(h.span,{layoutId:`mode-pill`,className:`absolute inset-0 rounded-[var(--miravo-radius-pill)] bg-destructive/15 shadow-sm`,transition:{type:`spring`,stiffness:500,damping:40}}),(0,Y.jsx)(R,{className:`relative z-10 size-3.5`}),(0,Y.jsx)(`span`,{className:`relative z-10`,children:`Cleanup`})]})]}),(0,Y.jsx)(ue,{stream:t})]}),(0,Y.jsx)(le,{children:(0,Y.jsxs)(`div`,{className:`flex flex-col gap-3.5`,children:[(0,Y.jsxs)(`div`,{className:`flex items-start gap-3 border-b border-border/25 pb-3`,children:[(0,Y.jsx)(`div`,{className:`flex size-9 shrink-0 items-center justify-center rounded-[var(--miravo-radius-stadium-sm)] border border-primary/25 bg-primary/9 shadow-[inset_0_1px_0_0_var(--miravo-inset-highlight)]`,children:(0,Y.jsx)(Re,{className:`size-4 text-primary`,"aria-hidden":!0})}),(0,Y.jsxs)(`div`,{className:`min-w-0 flex-1`,children:[(0,Y.jsx)(`p`,{className:`font-heading text-[11px] font-semibold uppercase tracking-[0.12em] text-foreground`,children:`Litmus Edge`}),(0,Y.jsx)(`p`,{className:`mt-0.5 text-[11px] leading-relaxed text-muted-foreground`,children:fe})]})]}),(0,Y.jsxs)(`div`,{className:`grid grid-cols-1 gap-3 sm:grid-cols-2`,children:[(0,Y.jsxs)(`div`,{className:`space-y-1.5`,children:[(0,Y.jsx)(Ze,{className:`font-heading text-[11px] font-medium uppercase tracking-[0.14em] text-muted-foreground`,children:`Target`}),(0,Y.jsx)(ae,{targets:e,value:a,onValueChange:e=>{o(e),ht(e),L()},preferredTargetId:ee,disabled:D,size:`sm`,className:`min-w-0 w-full text-xs`})]}),(0,Y.jsxs)(`div`,{className:`space-y-1.5`,children:[(0,Y.jsx)(Ze,{className:`font-heading text-[11px] font-medium uppercase tracking-[0.14em] text-muted-foreground`,children:`Environment`}),A.isError&&!A.data&&(0,Y.jsx)(m,{message:q(A.error,`Failed to load environments.`),onRetry:()=>void A.refetch(),isRetrying:A.isFetching&&!A.isPending}),(0,Y.jsxs)(`button`,{type:`button`,disabled:V||D||!P,onClick:()=>w(!0),className:F(`flex h-9 min-h-9 w-full min-w-0 items-center justify-between gap-1.5 rounded-[var(--miravo-radius-stadium-sm)] border border-input bg-input/30 px-2.5 py-0 text-left text-xs outline-none transition-colors select-none`,`hover:bg-input/50 focus-visible:border-primary/35 focus-visible:ring-2 focus-visible:ring-primary/22`,`disabled:pointer-events-none disabled:cursor-not-allowed disabled:bg-input/50 disabled:opacity-50`),"aria-label":`Environment`,children:[(0,Y.jsxs)(`span`,{className:`flex min-w-0 items-center gap-2`,children:[(0,Y.jsx)(`span`,{className:`flex size-7 shrink-0 items-center justify-center rounded-[var(--miravo-radius-stadium-sm)] border border-border/35 bg-muted/25 text-primary`,children:U}),(0,Y.jsx)(`span`,{className:`min-w-0 flex-1 truncate font-medium text-foreground`,children:de})]}),(0,Y.jsx)(Se,{className:`pointer-events-none size-4 shrink-0 text-muted-foreground`,"aria-hidden":!0})]})]})]}),(0,Y.jsxs)(`button`,{type:`button`,disabled:!H||v,onClick:()=>x(!0),className:F(`group flex w-full min-h-14 min-w-0 items-stretch overflow-hidden rounded-[var(--miravo-radius-stadium-lg)] text-left outline-none`,`transition-[border-color,box-shadow,background-color] duration-200 ease-out`,`focus-visible:ring-2 focus-visible:ring-ring/70 focus-visible:ring-offset-2 focus-visible:ring-offset-background`,`disabled:pointer-events-none disabled:opacity-55`,H?[`border-2 border-primary/40 bg-background`,`bg-linear-to-r from-primary/12 via-background to-background`,`shadow-[inset_0_1px_0_0_rgba(255,255,255,0.025)]`,`hover:border-primary/56 hover:shadow-[inset_0_1px_0_0_rgba(255,255,255,0.025),0_0_14px_-8px_color-mix(in_srgb,var(--primary)_18%,transparent),0_0_22px_-12px_color-mix(in_srgb,var(--primary)_8%,transparent)]`]:[`border border-dashed border-border/65 bg-muted/15`,`hover:bg-muted/22`]),children:[(0,Y.jsx)(`span`,{className:`relative flex w-18 shrink-0 items-center justify-center bg-transparent`,"aria-hidden":!0,children:(0,Y.jsx)(oe,{className:F(`relative size-5`,H?`text-primary`:`text-muted-foreground`)})}),(0,Y.jsxs)(`span`,{className:`flex min-w-0 flex-1 flex-col justify-center gap-0.5 overflow-hidden px-3 py-2.5 sm:px-4`,children:[(0,Y.jsx)(`span`,{className:F(`font-heading text-[11px] font-semibold uppercase tracking-[0.18em]`,H?`text-primary`:`text-muted-foreground`),children:se}),(0,Y.jsx)(`span`,{className:F(`truncate font-mono text-[13px] leading-tight tracking-tight`,H?`text-foreground`:`text-muted-foreground`),children:pe})]}),(0,Y.jsx)(`span`,{className:F(`flex shrink-0 items-center pr-2.5 sm:pr-3`,H&&`pl-1`),children:(0,Y.jsx)(`span`,{className:F(`flex size-9 items-center justify-center rounded-[var(--miravo-radius-stadium-sm)] border bg-transparent transition-[border-color,color] duration-200`,H?`border-primary/40 text-primary group-hover:border-primary/55`:`border-border/45 text-muted-foreground`),"aria-hidden":!0,children:(0,Y.jsx)(Ee,{className:`size-4`,strokeWidth:2.25})})})]}),!k&&(0,Y.jsx)(`div`,{className:`flex w-full min-w-0 flex-wrap items-center justify-end gap-2`,children:(0,Y.jsxs)(Ze,{id:`all-managed-label`,htmlFor:`all-managed`,"aria-disabled":D,className:F(`inline-flex h-8 w-fit max-w-full cursor-pointer items-center gap-2 text-xs font-medium leading-none`,D&&`pointer-events-none opacity-40`),children:[(0,Y.jsx)(Le,{id:`all-managed`,checked:d,onCheckedChange:e=>{p(e===!0),L()},disabled:D}),(0,Y.jsx)(`span`,{className:`shrink-0`,children:`Remove all Miravo managed resources`})]})})]})}),(v||g)&&!D&&(0,Y.jsxs)(`div`,{className:`flex flex-col gap-2`,children:[v&&(0,Y.jsx)(`div`,{className:`flex w-full min-w-0 flex-wrap items-center justify-end gap-2`,children:(0,Y.jsxs)(O,{type:`button`,variant:`ghost`,size:`sm`,className:`h-8 shrink-0 gap-1.5 px-2 text-xs text-muted-foreground hover:text-foreground`,onClick:te,children:[(0,Y.jsx)(M,{className:`size-3.5`,"aria-hidden":!0}),`Cancel preview`]})}),v&&(0,Y.jsx)(wt,{}),g&&!v&&(0,Y.jsx)(St,{plan:g,planKind:k?`apply`:`cleanup`,onCloseTable:L})]}),P&&C?(0,Y.jsx)(Et,{open:!0,type:n,targetLabel:P.label,targetHostname:P.hostname,templates:j,templatesLoading:A.isPending&&A.data===void 0,templatesError:A.isError&&j.length===0,onRetryTemplates:()=>void A.refetch(),onOpenChange:w,onSelect:e=>{u(e.id),pt(e.id),p(!1),L(),k&&t.reset(),w(!1)}}):null,P&&(0,Y.jsx)(re,{open:b,onOpenChange:x,type:n,label:V?`All managed resources`:N?.name??l,targetLabel:P.label,hostname:P.hostname,sourceHostname:P.sourceHostname,onConfirm:ne,applyPreview:k?{onPreview:()=>void B(`apply`),planLoading:v,disabled:!a||!l||D}:void 0,cleanupPreview:k?void 0:{onPreview:()=>void B(`cleanup`),planLoading:v,disabled:!a||!d&&!l||D}})]})}function Ot(){return(0,Y.jsx)(`section`,{"aria-labelledby":`platforms-operation-log-empty-title`,className:at,children:(0,Y.jsxs)(`div`,{className:`flex flex-col items-center gap-4 px-4 py-8 text-center sm:py-10`,children:[(0,Y.jsx)(`div`,{className:`flex size-12 items-center justify-center rounded-(--miravo-radius-stadium-sm) border border-dashed border-border/50`,children:(0,Y.jsx)(I,{className:`size-6 text-muted-foreground/45`,"aria-hidden":!0})}),(0,Y.jsxs)(`div`,{className:`max-w-sm`,children:[(0,Y.jsx)(`h2`,{id:`platforms-operation-log-empty-title`,className:`font-heading text-sm font-semibold tracking-tight text-foreground`,children:`No operations yet`}),(0,Y.jsx)(`p`,{className:`mt-2 text-pretty text-sm leading-relaxed text-muted-foreground`,children:`Run apply or cleanup from the Operations tab. Finished runs show up here with full detail.`})]})]})})}function kt(e){let t=new Date(e),n=new Date,r=new Date(n);return r.setDate(n.getDate()-1),t.toDateString()===n.toDateString()?`Today`:t.toDateString()===r.toDateString()?`Yesterday`:t.toLocaleDateString(`en-US`,{weekday:`short`,month:`short`,day:`numeric`})}function At(e){let t=new Map;for(let n of e){let e=new Date(n.completedAt).toDateString(),r=t.get(e);r?r.push(n):t.set(e,[n])}return Array.from(t.entries()).map(([,e])=>({label:kt(e[0]?.completedAt??Date.now()),ops:e}))}function jt(e,t){return e===`device`?t.operationType===`apply`?`Tag/register writes per device step—not a device count.`:`One count per device removed from DeviceHub.`:e===`model`?`One count per model in this run.`:e===`instance`?`One count per twin instance in this run.`:`Sets the device parameter to the bound DeviceHub device.`}var Mt={devices:`Devices`,models:`DT models`,instances:`DT instances`},Q={create:`inline-flex items-center rounded-[var(--miravo-radius-tight)] border border-success/35 bg-success/12 px-1.5 py-0.5 font-mono text-[10px] tabular-nums text-success`,update:`inline-flex items-center rounded-[var(--miravo-radius-tight)] border border-primary/35 bg-primary/12 px-1.5 py-0.5 font-mono text-[10px] tabular-nums text-primary`,replace:`inline-flex items-center rounded-[var(--miravo-radius-tight)] border border-chart-2/35 bg-chart-2/12 px-1.5 py-0.5 font-mono text-[10px] tabular-nums text-chart-2`,delete:`inline-flex items-center rounded-[var(--miravo-radius-tight)] border border-destructive/35 bg-destructive/12 px-1.5 py-0.5 font-mono text-[10px] tabular-nums text-destructive`,noop:`inline-flex items-center rounded-[var(--miravo-radius-tight)] border border-border/55 bg-muted/55 px-1.5 py-0.5 font-mono text-[10px] tabular-nums text-foreground/78`,failed:`inline-flex items-center rounded-[var(--miravo-radius-tight)] border border-destructive/40 bg-destructive/18 px-1.5 py-0.5 font-mono text-[10px] font-semibold tabular-nums text-destructive`};function Nt(e){return[{key:`device`,title:`DeviceHub — protocol tags`,subtitle:jt(`device`,e),counts:e.resourceCounts.device},{key:`model`,title:`Digital Twin models`,subtitle:jt(`model`,e),counts:e.resourceCounts.model},{key:`instance`,title:`Twin instances`,subtitle:jt(`instance`,e),counts:e.resourceCounts.instance},{key:`param-sync`,title:`Parameter sync`,subtitle:jt(`param-sync`,e),counts:e.resourceCounts[`param-sync`]}].filter(e=>e.counts.total>0||e.counts.failed>0)}function Pt(e){return e.length===0?`Default (devices, models, instances)`:e.map(e=>Mt[e]??e).join(` · `)}function Ft(e){let t=[];return e.filters.area&&t.push(`Area ${e.filters.area}`),e.filters.line&&t.push(`Line ${e.filters.line}`),e.filters.instance&&t.push(`Instance ${e.filters.instance}`),t.length>0?t.join(` · `):null}function $(e,t,n){if(e===`device`)switch(t){case`create`:return`+${n} tags (new device)`;case`update`:return`${n} tags rewritten`;case`replace`:return`↻${n} tags (device replaced)`;case`delete`:return`−${n} removed`;case`noop`:return`=${n} unchanged`}switch(t){case`create`:return`+${n} created`;case`update`:return`${n} updated`;case`replace`:return`↻${n} replaced`;case`delete`:return`−${n} removed`;case`noop`:return`=${n} unchanged`}}function It({row:e}){let{key:t,counts:n}=e;return(0,Y.jsxs)(`div`,{className:`flex min-w-0 flex-1 flex-wrap items-center gap-1.5`,children:[n.create>0&&(0,Y.jsx)(`span`,{className:Q.create,children:$(t,`create`,n.create)}),n.update>0&&(0,Y.jsx)(`span`,{className:Q.update,children:$(t,`update`,n.update)}),n.replace>0&&(0,Y.jsx)(`span`,{className:Q.replace,children:$(t,`replace`,n.replace)}),n.delete>0&&(0,Y.jsx)(`span`,{className:Q.delete,children:$(t,`delete`,n.delete)}),n.noop>0&&(0,Y.jsx)(`span`,{className:Q.noop,children:$(t,`noop`,n.noop)}),n.failed>0&&(0,Y.jsx)(`span`,{className:Q.failed,children:`${n.failed} failed`})]})}function Lt(e){return e.resourceCounts.device.noop+e.resourceCounts.model.noop+e.resourceCounts.instance.noop+e.resourceCounts[`param-sync`].noop}function Rt({op:e}){let t=Ft(e),n=Lt(e);return(0,Y.jsxs)(`div`,{className:`rounded-[var(--miravo-radius-tight)] border border-border/50 bg-muted/25 px-3 py-2.5`,children:[(0,Y.jsx)(`p`,{className:`font-mono text-[10px] uppercase tracking-[0.16em] text-foreground/72`,children:`Run context`}),(0,Y.jsxs)(`dl`,{className:`mt-2 grid grid-cols-[minmax(0,7.5rem)_1fr] gap-x-3 gap-y-1.5 text-xs sm:grid-cols-[9rem_1fr]`,children:[(0,Y.jsx)(`dt`,{className:`text-foreground/70`,children:`Operation`}),(0,Y.jsx)(`dd`,{className:`font-medium capitalize text-foreground`,children:e.operationType}),(0,Y.jsx)(`dt`,{className:`text-foreground/70`,children:`Target host`}),(0,Y.jsx)(`dd`,{className:`break-all font-mono text-[11px] text-foreground`,children:e.hostname}),(0,Y.jsx)(`dt`,{className:`text-foreground/70`,children:`Scope`}),(0,Y.jsx)(`dd`,{className:`text-foreground`,children:Pt(e.scope)}),t&&(0,Y.jsxs)(Y.Fragment,{children:[(0,Y.jsx)(`dt`,{className:`text-foreground/70`,children:`Filters`}),(0,Y.jsx)(`dd`,{className:`text-foreground`,children:t})]}),(0,Y.jsx)(`dt`,{className:`text-foreground/70`,children:`Duration`}),(0,Y.jsxs)(`dd`,{className:`tabular-nums text-foreground`,children:[(e.durationMs/1e3).toFixed(1),`s`]}),(0,Y.jsx)(`dt`,{className:`text-foreground/70`,children:`Outcome`}),(0,Y.jsxs)(`dd`,{className:`text-foreground`,children:[(0,Y.jsx)(`span`,{className:`tabular-nums`,children:e.successCount}),` steps succeeded`,n>0&&(0,Y.jsxs)(`span`,{className:`text-foreground/72`,children:[` `,`· `,(0,Y.jsx)(`span`,{className:`tabular-nums`,children:n}),` unchanged`]}),e.failedCount>0&&(0,Y.jsxs)(`span`,{className:`text-destructive`,children:[` `,`· `,(0,Y.jsx)(`span`,{className:`tabular-nums`,children:e.failedCount}),` failed`]}),e.blockedCount>0&&(0,Y.jsxs)(`span`,{className:`text-warning`,children:[` `,`· `,(0,Y.jsx)(`span`,{className:`tabular-nums`,children:e.blockedCount}),` blocked in plan`]})]})]})]})}function zt({status:e}){switch(e){case`success`:return(0,Y.jsx)(Oe,{className:`mt-px size-4 shrink-0 text-success`});case`failed`:return(0,Y.jsx)(Ne,{className:`mt-px size-4 shrink-0 text-destructive`});case`partial`:case`blocked`:return(0,Y.jsx)(ze,{className:`mt-px size-4 shrink-0 text-warning`});case`noop`:return(0,Y.jsx)(tt,{className:`mt-px size-4 shrink-0 text-foreground/55`})}}function Bt(e){let t=e.operationType===`apply`?`Applied`:`Cleaned up`,n=`${(e.durationMs/1e3).toFixed(1)}s`,r=[];e.successCount>0&&r.push(`${e.successCount} resources`);let i=Lt(e);return i>0&&r.push(`${i} unchanged`),e.failedCount>0&&r.push(`${e.failedCount} failed`),e.blockedCount>0&&r.push(`${e.blockedCount} blocked`),r.length===0?`${t} · no changes · ${n}`:`${t} · ${r.join(`, `)} · ${n}`}function Vt(e){return e.operationType===`cleanup`&&e.successCount===0&&e.failedCount===0&&e.blockedCount===0?`No Miravo-managed resources were found to clean up.`:e.failedCount>0&&e.blockedCount>0?`No per-phase counts — failures and blocked plan entries.`:e.failedCount>0?`No per-phase counts — run failed.`:e.blockedCount>0?`No per-phase counts — blocked plan entries.`:Lt(e)>0?`No resources were mutated. Existing managed resources already matched the desired state.`:`No per-phase counts recorded.`}function Ht({op:e}){let t=Nt(e);return t.length===0?(0,Y.jsx)(`p`,{className:`py-1 text-sm text-foreground/75`,children:Vt(e)}):(0,Y.jsxs)(`div`,{className:`space-y-3 pt-1`,children:[(0,Y.jsx)(`div`,{className:`flex flex-col divide-y divide-border/45 rounded-[var(--miravo-radius-tight)] border border-border/50`,children:t.map(e=>(0,Y.jsxs)(`div`,{className:`flex flex-col gap-2 px-3 py-2.5 sm:flex-row sm:items-start sm:gap-4`,children:[(0,Y.jsxs)(`div`,{className:`min-w-0 shrink-0 sm:w-[11.5rem]`,children:[(0,Y.jsxs)(`div`,{className:`flex items-center gap-1`,children:[(0,Y.jsx)(`span`,{className:`text-xs font-medium leading-snug text-foreground`,children:e.title}),(0,Y.jsxs)(He,{children:[(0,Y.jsx)(Be,{type:`button`,className:`inline-flex shrink-0 items-center justify-center rounded-[var(--miravo-radius-tight)] p-0.5 text-foreground/60 hover:bg-muted/50 hover:text-foreground`,"aria-label":`About ${e.title}`,children:(0,Y.jsx)(Fe,{className:`size-3.5`,"aria-hidden":!0})}),(0,Y.jsx)(Ve,{side:`top`,className:`max-w-xs text-left`,children:e.subtitle})]})]}),(0,Y.jsx)(`p`,{className:`mt-0.5 text-[11px] leading-snug text-foreground/72 sm:hidden`,children:e.subtitle})]}),(0,Y.jsx)(It,{row:e})]},e.key))}),e.blockedCount>0&&(0,Y.jsxs)(`p`,{className:`rounded-[var(--miravo-radius-tight)] border border-warning/20 bg-warning/5 px-2.5 py-1.5 text-[11px] text-warning`,children:[(0,Y.jsx)(`span`,{className:`font-medium`,children:e.blockedCount}),` plan entries were blocked (skipped). Open a `,(0,Y.jsx)(`span`,{className:`font-medium`,children:`deploy preview`}),` before running to see block reasons.`]})]})}function Ut({operation:e}){let[t,n]=(0,J.useState)(!1);return(0,Y.jsxs)(`div`,{className:F(`overflow-hidden rounded-[var(--miravo-radius-stadium-sm)] border border-border/55`,`transition-colors duration-150`),children:[(0,Y.jsxs)(`button`,{type:`button`,"aria-expanded":t,onClick:()=>n(e=>!e),className:F(`flex w-full items-start gap-3 p-3.5 text-left`,`transition-colors duration-100`,`hover:bg-muted/25`,t&&`bg-muted/18`),children:[(0,Y.jsx)(zt,{status:e.status}),(0,Y.jsxs)(`div`,{className:`flex min-w-0 flex-1 flex-col gap-1`,children:[(0,Y.jsxs)(`div`,{className:`flex items-start justify-between gap-4`,children:[(0,Y.jsxs)(`p`,{className:`min-w-0 truncate text-sm`,children:[(0,Y.jsx)(`span`,{className:`font-medium text-foreground`,children:j(e.templateId)}),(0,Y.jsx)(`span`,{className:`mx-1.5 text-foreground/50`,children:`→`}),(0,Y.jsx)(`span`,{className:`text-foreground/82`,children:e.targetLabel})]}),(0,Y.jsx)(`time`,{dateTime:new Date(e.completedAt).toISOString(),title:A(e.completedAt),className:`shrink-0 text-xs text-foreground/75`,children:k(e.completedAt)})]}),(0,Y.jsx)(`p`,{className:`text-xs text-foreground/78`,children:Bt(e)}),(e.failedCount>0||e.status===`failed`)&&(0,Y.jsx)(`p`,{className:`text-[11px] leading-snug text-foreground/72`,children:ge(e.operationType,e.error)})]}),(0,Y.jsx)(Se,{className:F(`mt-0.5 size-3.5 shrink-0 text-foreground/55 transition-transform duration-150`,t&&`rotate-180`)})]}),(0,Y.jsx)(g,{initial:!1,children:t&&(0,Y.jsx)(h.div,{initial:{opacity:0,height:0},animate:{opacity:1,height:`auto`},exit:{opacity:0,height:0},transition:{duration:.2,ease:`easeOut`},className:`overflow-hidden`,children:(0,Y.jsxs)(`div`,{className:`space-y-3 border-t border-border/45 px-4 pb-3 pt-3`,children:[(0,Y.jsx)(Rt,{op:e}),e.error&&(0,Y.jsxs)(`div`,{className:`relative rounded-[var(--miravo-radius-tight)] border border-destructive/40 bg-destructive/15 px-3 py-2 pr-10 text-xs font-medium`,children:[(0,Y.jsx)(`div`,{className:`absolute top-1.5 right-1.5 z-10`,children:(0,Y.jsx)(E,{value:e.error,label:`Copy error`,className:`text-destructive hover:bg-destructive/25 hover:text-foreground`})}),(0,Y.jsx)(`p`,{className:`whitespace-normal break-words text-destructive [overflow-wrap:anywhere]`,children:e.error}),(0,Y.jsx)(`p`,{className:`mt-2 text-[11px] font-normal leading-snug text-foreground/78 [overflow-wrap:anywhere]`,children:ge(e.operationType,e.error)})]}),(0,Y.jsx)(Ht,{op:e})]})})})]})}function Wt({label:e}){return(0,Y.jsxs)(`div`,{className:`flex items-center gap-3 py-1`,children:[(0,Y.jsx)(`div`,{className:`h-px flex-1 bg-border/65`}),(0,Y.jsx)(`span`,{className:`text-xs font-medium text-foreground/78`,children:e}),(0,Y.jsx)(`div`,{className:`h-px flex-1 bg-border/65`})]})}var Gt={type:``,status:``,target:``,search:``},Kt={_all:`All types`,apply:`Apply`,cleanup:`Cleanup`},qt={_all:`All statuses`,success:`Success`,partial:`Partial`,failed:`Failed`,blocked:`Blocked`,noop:`No-op`},Jt=`h-7 min-h-7 gap-1.5 border-border/50 bg-transparent px-2 text-xs hover:bg-muted/30 focus:ring-0`;function Yt({filters:e,targetOptions:t,hasFilters:n,searchRef:r,onTypeChange:i,onStatusChange:a,onTargetChange:o,onSearchChange:s,onClear:c}){return(0,Y.jsxs)(`div`,{className:`flex flex-wrap items-center gap-1.5 border-b border-border/50 px-3 py-2`,children:[(0,Y.jsxs)(Te,{value:e.type||`_all`,onValueChange:e=>e&&i(e===`_all`?``:e),children:[(0,Y.jsx)(we,{size:`sm`,className:Jt,"aria-label":`Operation type`,children:(0,Y.jsx)(xe,{children:e=>Kt[e??`_all`]??Kt._all})}),(0,Y.jsxs)(Ce,{children:[(0,Y.jsx)(W,{value:`_all`,children:`All types`}),(0,Y.jsx)(W,{value:`apply`,children:`Apply`}),(0,Y.jsx)(W,{value:`cleanup`,children:`Cleanup`})]})]}),(0,Y.jsxs)(Te,{value:e.status||`_all`,onValueChange:e=>e&&a(e===`_all`?``:e),children:[(0,Y.jsx)(we,{size:`sm`,className:Jt,"aria-label":`Operation status`,children:(0,Y.jsx)(xe,{children:e=>qt[e??`_all`]??qt._all})}),(0,Y.jsxs)(Ce,{children:[(0,Y.jsx)(W,{value:`_all`,children:`All statuses`}),(0,Y.jsx)(W,{value:`success`,children:`Success`}),(0,Y.jsx)(W,{value:`partial`,children:`Partial`}),(0,Y.jsx)(W,{value:`failed`,children:`Failed`}),(0,Y.jsx)(W,{value:`blocked`,children:`Blocked`}),(0,Y.jsx)(W,{value:`noop`,children:`No-op`})]})]}),t.length>1&&(0,Y.jsxs)(Te,{value:e.target||`_all`,onValueChange:e=>e&&o(e===`_all`?``:e),children:[(0,Y.jsx)(we,{size:`sm`,className:Jt,"aria-label":`Target filter`,children:(0,Y.jsx)(xe,{children:e=>!e||e===`_all`?`All targets`:e})}),(0,Y.jsxs)(Ce,{children:[(0,Y.jsx)(W,{value:`_all`,children:`All targets`}),t.map(e=>(0,Y.jsx)(W,{value:e,children:e},e))]})]}),(0,Y.jsxs)(`div`,{className:`relative flex min-w-[140px] flex-1 items-center`,children:[(0,Y.jsx)(`input`,{ref:r,type:`search`,value:e.search,onChange:e=>s(e.target.value),placeholder:`Search environment or target…`,"aria-describedby":`ops-search-shortcut`,className:F(`h-7 w-full rounded-[var(--miravo-radius-tight)] border border-border/50 bg-transparent pl-2 pr-7 text-xs`,`placeholder:text-foreground/60 focus:outline-none focus:ring-1 focus:ring-ring/40`,e.search&&`pr-2`)}),(0,Y.jsx)(`span`,{id:`ops-search-shortcut`,className:`sr-only`,children:`Press slash to focus search`}),!e.search&&(0,Y.jsx)(`kbd`,{"aria-hidden":!0,className:`pointer-events-none absolute right-2 flex h-4 items-center rounded-[var(--miravo-radius-tight)] border border-border/60 bg-muted/50 px-1 font-mono text-[10px] text-foreground/65`,children:`/`})]}),n&&(0,Y.jsxs)(`button`,{type:`button`,onClick:c,className:`flex h-7 items-center gap-1 rounded-[var(--miravo-radius-tight)] px-2 text-xs text-foreground/72 transition-colors hover:bg-muted/40 hover:text-foreground`,children:[(0,Y.jsx)(M,{className:`size-3`}),`Clear`]})]})}function Xt({operations:e,totalKnown:t,isLoading:n,error:r,onRefresh:i,hasNextPage:a=!1,isFetchingNextPage:o=!1,loadMoreError:s=null,onRetryLoadMore:c,onLoadMore:l}){let[u,d]=(0,J.useState)(!1),[f,m]=(0,J.useState)(Gt),_=(0,J.useRef)(null);(0,J.useEffect)(()=>{let e=e=>{if(e.key!==`/`||e.metaKey||e.ctrlKey||e.altKey)return;let t=e.target.tagName;t===`INPUT`||t===`TEXTAREA`||t===`SELECT`||(e.preventDefault(),_.current?.focus())};return window.addEventListener(`keydown`,e),()=>window.removeEventListener(`keydown`,e)},[]);let v=()=>{d(!0),i(),S.success(`Operations refreshed`),setTimeout(()=>d(!1),600)},y=(0,J.useMemo)(()=>{let t=new Set;for(let n of e){let e=n.targetLabel;t.add(e)}return[...t].sort()},[e]),b=(0,J.useMemo)(()=>{let t=e;if(f.type&&(t=t.filter(e=>e.operationType===f.type)),f.status&&(t=t.filter(e=>e.status===f.status)),f.target&&(t=t.filter(e=>e.targetLabel===f.target)),f.search){let e=f.search.toLowerCase();t=t.filter(t=>{let n=t.targetLabel;return t.templateId.toLowerCase().includes(e)||j(t.templateId).toLowerCase().includes(e)||n.toLowerCase().includes(e)})}return t},[e,f]),x=f.type!==``||f.status!==``||f.target!==``||f.search!==``,C=(0,J.useMemo)(()=>At(b),[b]);return(0,Y.jsxs)(`div`,{className:`flex h-full flex-col rounded-[var(--miravo-radius-stadium-sm)] border border-border/55`,children:[(0,Y.jsxs)(`div`,{className:`flex items-center justify-between border-b border-border/50 px-3.5 py-2.5`,children:[(0,Y.jsxs)(`div`,{className:`flex items-center gap-2`,children:[(0,Y.jsx)(`span`,{className:`text-sm font-medium text-foreground`,children:`Operation log`}),e.length>0&&(0,Y.jsx)(`span`,{className:`font-mono text-xs tabular-nums text-foreground/75`,children:typeof t==`number`&&t>0&&e.length<t?`${e.length} / ${t}`:String(e.length)})]}),(0,Y.jsx)(`button`,{type:`button`,onClick:v,disabled:u,"aria-label":`Refresh operation list`,className:`relative rounded-[var(--miravo-radius-tight)] p-1 text-foreground/70 transition-colors before:absolute before:inset-[-10px] before:content-[''] hover:bg-muted/50 hover:text-foreground disabled:pointer-events-none`,children:(0,Y.jsx)(p,{className:F(`size-3.5`,u&&`animate-spin`),"aria-hidden":!0})})]}),(0,Y.jsx)(Yt,{filters:f,targetOptions:y,hasFilters:x,searchRef:_,onTypeChange:e=>m(t=>({...t,type:e})),onStatusChange:e=>m(t=>({...t,status:e})),onTargetChange:e=>m(t=>({...t,target:e})),onSearchChange:e=>m(t=>({...t,search:e})),onClear:()=>m(Gt)}),(0,Y.jsxs)(`div`,{className:`flex flex-1 min-h-0 flex-col gap-2 overflow-y-auto overscroll-y-contain p-3`,children:[r&&(0,Y.jsxs)(`p`,{className:`py-2 text-xs text-destructive`,children:[`✕ `,r.message]}),n&&e.length===0&&!r&&(0,Y.jsx)(`p`,{className:`py-4 text-sm text-foreground/75`,children:`Loading…`}),!n&&e.length===0&&!r&&(0,Y.jsx)(Ot,{}),!n&&e.length>0&&b.length===0&&(0,Y.jsxs)(`p`,{className:`py-6 text-center text-sm text-foreground/75`,children:[`No operations match your filters.`,` `,(0,Y.jsx)(`button`,{type:`button`,onClick:()=>m(Gt),className:`text-primary hover:underline`,children:`Clear filters`})]}),x&&b.length>0&&b.length!==e.length&&(0,Y.jsxs)(`p`,{className:`text-xs text-foreground/75`,children:[`Showing`,` `,(0,Y.jsx)(`span`,{className:`font-medium tabular-nums text-foreground`,children:b.length}),` of`,` `,(0,Y.jsx)(`span`,{className:`tabular-nums`,children:e.length}),` loaded`]}),!x&&typeof t==`number`&&t>0&&e.length<t&&(0,Y.jsxs)(`p`,{className:`text-xs text-foreground/75`,children:[`Showing`,` `,(0,Y.jsx)(`span`,{className:`font-medium tabular-nums text-foreground`,children:e.length}),` `,`of `,(0,Y.jsx)(`span`,{className:`tabular-nums`,children:t}),`. Load more for older entries.`]}),(0,Y.jsx)(g,{initial:!1,children:C.map(e=>(0,Y.jsxs)(h.div,{className:`flex flex-col gap-2`,children:[(0,Y.jsx)(Wt,{label:e.label}),(0,Y.jsx)(g,{initial:!1,children:e.ops.map(e=>(0,Y.jsx)(h.div,{initial:b.length>40?!1:{opacity:0,x:-6},animate:{opacity:1,x:0},transition:{type:`spring`,stiffness:400,damping:35},children:(0,Y.jsx)(Ut,{operation:e})},`${e.operationId}-${e.completedAt}`))})]},e.label))}),s?(0,Y.jsxs)(`div`,{role:`alert`,className:`flex shrink-0 flex-col items-center gap-2 border-t border-border/50 pt-3 pb-1 text-center`,children:[(0,Y.jsxs)(`p`,{className:`text-xs text-destructive`,children:[`Could not load older entries: `,s.message]}),c?(0,Y.jsx)(O,{type:`button`,variant:`outline`,size:`sm`,onClick:c,children:`Retry`}):null]}):a&&l?(0,Y.jsx)(`div`,{className:`flex shrink-0 justify-center border-t border-border/50 pt-3 pb-1`,children:(0,Y.jsx)(O,{type:`button`,variant:`outline`,size:`sm`,className:`min-w-[7rem]`,disabled:o,"aria-busy":o,"aria-label":o?`Loading older operations`:`Load older operations`,onClick:l,children:o?`Loading…`:`Load more`})}):null]})]})}function Zt({target:e,templates:t,templatesLoading:n,templatesError:r,isStreaming:i,onRetryTemplates:a,onSelect:o}){let s=t.length===0&&!n&&!r,[c,l]=(0,J.useState)(null);return(0,Y.jsxs)(Y.Fragment,{children:[(0,Y.jsx)(`div`,{className:`absolute right-3 top-3 z-20`,children:(0,Y.jsxs)(Xe,{children:[(0,Y.jsx)(Ye,{render:(0,Y.jsx)(O,{type:`button`,variant:`ghost`,size:`icon-sm`,disabled:i,className:`border border-border/45 bg-background/70 text-muted-foreground shadow-[inset_0_1px_0_0_var(--miravo-inset-highlight)] hover:border-primary/30 hover:bg-muted/55 hover:text-foreground`,"aria-label":`Open quick actions for ${e.label}`}),children:(0,Y.jsx)(nt,{className:`size-3.5`,"aria-hidden":!0})}),(0,Y.jsx)(Ke,{align:`end`,sideOffset:6,className:`min-w-56`,children:(0,Y.jsxs)(Je,{children:[(0,Y.jsx)(We,{className:`text-[10px] uppercase tracking-[0.14em]`,children:`Quick actions`}),(0,Y.jsx)(qe,{className:`bg-border/60`}),(0,Y.jsxs)(Ge,{disabled:s,className:`h-9 gap-2 text-xs`,onClick:()=>l(`apply`),children:[(0,Y.jsx)(Ie,{className:`size-3.5 shrink-0 text-primary`,"aria-hidden":!0}),(0,Y.jsx)(`span`,{className:`min-w-0 truncate`,children:`Apply environment...`})]}),(0,Y.jsxs)(Ge,{disabled:s,className:`h-9 gap-2 text-xs`,onClick:()=>l(`cleanup`),children:[(0,Y.jsx)(R,{className:`size-3.5 shrink-0 text-muted-foreground`,"aria-hidden":!0}),(0,Y.jsx)(`span`,{className:`min-w-0 truncate`,children:`Cleanup environment...`})]}),(0,Y.jsx)(qe,{className:`bg-border/60`}),(0,Y.jsxs)(Ge,{variant:`destructive`,className:`h-9 gap-2 text-xs`,onClick:()=>o({type:`cleanup`,target:e,allManaged:!0}),children:[(0,Y.jsx)(R,{className:`size-3.5 shrink-0`,"aria-hidden":!0}),(0,Y.jsx)(`span`,{className:`min-w-0 truncate`,children:`Cleanup all managed`})]})]})})]})}),c?(0,Y.jsx)(Et,{open:!0,type:c,targetLabel:e.label,targetHostname:e.hostname,templates:t,templatesLoading:n,templatesError:r,onRetryTemplates:a,onOpenChange:e=>{e||l(null)},onSelect:t=>{o({type:c,target:e,templateId:t.id}),l(null)}},c):null]})}function Qt({selection:e,templates:t,stream:n,onSelectionChange:r}){let[i,a]=(0,J.useState)(!1),[o,s]=(0,J.useState)(null),[c,l]=(0,J.useState)(!1),u=(0,J.useRef)(0),d=(0,J.useRef)(null),f=(0,J.useRef)(!1),p=n.status===`running`,m=(0,J.useCallback)(()=>{u.current+=1,f.current=!1,d.current?.abort(),d.current=null,l(!1),s(null)},[]);(0,J.useEffect)(()=>{e&&(m(),a(!0))},[e,m]),(0,J.useEffect)(()=>()=>{u.current+=1,f.current=!1,d.current?.abort(),d.current=null},[]);let h=e?.templateId==null?void 0:t.find(t=>t.id===e.templateId)?.name??e.templateId,g=e?.type===`cleanup`&&e.allManaged?`All managed resources`:h??``,_=(0,J.useCallback)(async()=>{if(!e||e.type===`apply`&&!e.templateId||e.type===`cleanup`&&!e.allManaged&&!e.templateId)return;n.operation&&n.status!==`running`&&n.reset(),f.current=!0,d.current?.abort(),u.current+=1;let t=u.current,r=new AbortController;d.current=r,l(!0),s(null);try{let n=e.type===`apply`?await ce({targetId:e.target.id,template:e.templateId},{signal:r.signal}):await ie({targetId:e.target.id,...e.allManaged?{allManaged:!0}:{template:e.templateId}},{signal:r.signal});if(t!==u.current)return;s(n.plan)}catch(n){if(t!==u.current||gt(n))return;S.error(q(n,e.type===`apply`?`Plan failed`:`Cleanup plan failed`))}finally{t===u.current&&(l(!1),f.current=!1)}},[e,n]),v=(0,J.useCallback)(t=>{if(e){if(a(!1),m(),r(null),e.type===`apply`){n.startApply({targetId:e.target.id,template:e.templateId,scope:t.scope,ifUnmanaged:t.ifUnmanaged,...t.deviceName?{deviceName:t.deviceName}:{}});return}n.startCleanup({targetId:e.target.id,...e.allManaged?{allManaged:!0}:{template:e.templateId},scope:t.scope})}},[e,n,m,r]),y=e=>{a(e),!(e||f.current)&&(m(),r(null))},b=()=>{m(),r(null)};return(0,Y.jsxs)(Y.Fragment,{children:[e&&(0,Y.jsx)(re,{open:i,onOpenChange:y,type:e.type,label:g,targetLabel:e.target.label,hostname:e.target.hostname,sourceHostname:e.target.sourceHostname,onConfirm:v,applyPreview:e.type===`apply`?{onPreview:()=>void _(),planLoading:c,disabled:!e.templateId||p}:void 0,cleanupPreview:e.type===`cleanup`?{onPreview:()=>void _(),planLoading:c,disabled:!e.allManaged&&!e.templateId||p}:void 0}),(c||o)&&!p&&e?(0,Y.jsxs)(`div`,{className:`flex flex-col gap-2`,children:[(0,Y.jsxs)(`div`,{className:`flex w-full min-w-0 flex-wrap items-center justify-between gap-2`,children:[(0,Y.jsxs)(`div`,{className:`flex min-w-0 items-center gap-1.5 text-[11px] text-muted-foreground`,children:[(0,Y.jsx)(te,{className:`size-3.5 shrink-0 text-primary`,"aria-hidden":!0}),(0,Y.jsxs)(`span`,{className:`truncate`,children:[`Preview for `,e.target.label,`: `,g]})]}),(0,Y.jsxs)(O,{type:`button`,variant:`ghost`,size:`sm`,className:`h-8 shrink-0 gap-1.5 px-2 text-xs text-muted-foreground hover:text-foreground`,onClick:b,children:[(0,Y.jsx)(M,{className:`size-3.5`,"aria-hidden":!0}),`Close preview`]})]}),c?(0,Y.jsx)(wt,{}):o?(0,Y.jsx)(St,{plan:o,planKind:e.type,onCloseTable:b}):null]}):null]})}function $t(e){return De.find(t=>t.id===e)?.label??e}function en(e){if(!e)return`var(--tooltip-border)`;switch(e.status){case`success`:return`var(--success)`;case`partial`:case`blocked`:return`var(--warning)`;case`noop`:return`var(--muted-foreground)`;case`failed`:return`var(--destructive)`}}function tn({status:e}){switch(e){case`success`:return(0,Y.jsx)(Oe,{className:`size-3 text-success`});case`partial`:case`blocked`:return(0,Y.jsx)(ze,{className:`size-3 text-warning`});case`noop`:return(0,Y.jsx)(tt,{className:`size-3 text-muted-foreground`});case`failed`:return(0,Y.jsx)(Ne,{className:`size-3 text-destructive`})}}function nn({target:e,lastOp:t,onEdit:n,onDelete:r,quickActions:i}){return(0,Y.jsxs)(`div`,{className:`env-orbital relative overflow-hidden border`,style:{"--_status":en(t)},children:[i,(0,Y.jsx)(`div`,{className:`relative z-10 px-4 pt-3.5 pb-3 pr-12`,children:(0,Y.jsx)(`p`,{className:`font-heading text-[13px] font-semibold leading-tight tracking-tight text-foreground`,children:e.label})}),(0,Y.jsx)(`div`,{className:`relative z-10 px-4 py-0.5`,children:(0,Y.jsx)(`p`,{className:`font-mono text-xs tracking-tight text-muted-foreground`,children:e.hostname})}),(0,Y.jsxs)(`div`,{className:`relative z-10 mx-4 mb-3 flex items-center gap-2`,children:[(0,Y.jsx)(`span`,{className:`min-w-0 truncate font-mono text-[11px] text-muted-foreground`,children:e.sourceHostname}),(0,Y.jsx)(`div`,{className:`env-orbital-path min-w-6 flex-1`}),(0,Y.jsx)(L,{className:`size-3 shrink-0 text-muted-foreground`})]}),(0,Y.jsxs)(`div`,{className:`relative z-10 flex items-center gap-2 border-t border-border/30 px-3 py-1.5`,children:[(0,Y.jsxs)(`span`,{className:`flex shrink-0 items-center gap-1.5 rounded-full border border-border/40 px-2 py-0.5`,children:[(0,Y.jsx)(`span`,{className:`protocol-card-live-dot size-[5px]`}),(0,Y.jsx)(`span`,{className:`text-[11px] font-medium tracking-wide text-muted-foreground`,children:$t(e.platformId)})]}),t&&(0,Y.jsxs)(`span`,{className:`flex min-w-0 items-center gap-1 truncate text-[11px] text-muted-foreground`,children:[(0,Y.jsx)(tn,{status:t.status}),t.operationType===`apply`?`Applied`:`Cleaned`,` `,(0,Y.jsx)(`time`,{dateTime:new Date(t.completedAt).toISOString(),title:A(t.completedAt),children:k(t.completedAt)})]}),(0,Y.jsxs)(`div`,{className:`ml-auto flex shrink-0 items-center gap-0.5`,children:[(0,Y.jsx)(O,{variant:`ghost`,size:`icon-sm`,"aria-label":`Edit target`,onClick:n,children:(0,Y.jsx)(rt,{className:`size-3`})}),(0,Y.jsx)(O,{variant:`ghost`,size:`icon-sm`,className:`text-destructive hover:text-destructive`,"aria-label":`Delete target`,onClick:r,children:(0,Y.jsx)(R,{className:`size-3`})})]})]})]})}function rn({onClick:e}){return(0,Y.jsxs)(`button`,{type:`button`,onClick:e,className:`env-orbital group h-full w-full flex flex-col items-center justify-center gap-2 border border-dashed py-10 text-muted-foreground transition-colors hover:border-primary/30 hover:text-primary`,style:{"--_status":`var(--tooltip-border)`},children:[(0,Y.jsx)(B,{className:`size-5 transition-transform group-hover:scale-110`}),(0,Y.jsx)(`span`,{className:`text-xs`,children:`Add Target`})]})}function an({targets:e,onMutate:t,lastOpByTarget:n,templates:r,templatesLoading:i,templatesError:a,onRetryTemplates:o,stream:s}){let[c,l]=(0,J.useState)(!1),[u,d]=(0,J.useState)(null),[f,p]=(0,J.useState)(G.id),[m,_]=(0,J.useState)({label:``,hostname:``,apiToken:``,sourceHostname:``}),[v,y]=(0,J.useState)(!1),[E,D]=(0,J.useState)(!1),{testing:k,runTest:A,cancelInFlight:j}=fe(),[M,N]=(0,J.useState)(null),[P,F]=(0,J.useState)(null),I=s.status===`running`,L=f===G.id&&m.hostname.trim().length>0&&m.sourceHostname.trim().length>0&&(u!==null||m.apiToken.trim().length>0),R=()=>{d(null),p(G.id),_({label:``,hostname:``,apiToken:``,sourceHostname:``}),D(!1),l(!0)},te=e=>{d(e.id),p(De.some(t=>t.id===e.platformId)?e.platformId:G.id),_({label:e.label,hostname:e.hostname,apiToken:``,sourceHostname:e.sourceHostname}),D(!1),l(!0)},z=async()=>{if(f!==G.id){S.error(`${$t(f)} target setup is coming soon.`);return}if(!m.label||!m.hostname||!m.sourceHostname){S.error(`Label, hostname, and source host are required.`);return}if(!u&&!m.apiToken){S.error(`API token is required for new targets.`);return}y(!0);try{u?(await he(u,{platformId:f,label:m.label,hostname:m.hostname,sourceHostname:m.sourceHostname,...m.apiToken?{apiToken:m.apiToken}:{}}),S.success(`Target updated.`)):(await se({...m,platformId:f}),S.success(`Target added.`)),l(!1),t()}catch(e){S.error(q(e,`Failed to save target.`))}finally{y(!1)}};return(0,Y.jsxs)(`div`,{className:`flex flex-col gap-4`,children:[(0,Y.jsxs)(`div`,{className:`flex items-center justify-between gap-3`,children:[(0,Y.jsxs)(`div`,{className:`flex min-w-0 items-center gap-2`,children:[(0,Y.jsx)(`h2`,{className:`flex h-5 items-center text-xs font-medium leading-none uppercase tracking-wider text-muted-foreground`,children:`Platform Targets`}),e.length>0?(0,Y.jsx)(Ue,{variant:`secondary`,className:`relative -top-px h-5 shrink-0 px-1.5 py-0 font-mono text-[10px] leading-none tabular-nums`,children:e.length}):null]}),(0,Y.jsxs)(O,{size:`sm`,className:`h-7 shrink-0 gap-1.5 text-xs`,onClick:R,children:[(0,Y.jsx)(B,{className:`size-3.5`}),` Add Target`]})]}),e.length===0?(0,Y.jsx)(ct,{titleId:`platforms-targets-empty-title`,frameIcon:(0,Y.jsx)(K,{className:`size-6 text-muted-foreground/45`,"aria-hidden":!0}),description:(0,Y.jsx)(ot,{}),children:(0,Y.jsx)(st,{onClick:R})}):(0,Y.jsx)(`div`,{className:`grid grid-cols-1 gap-3 @2xl/main:grid-cols-2 @5xl/main:grid-cols-3`,children:(0,Y.jsxs)(g,{children:[e.map((e,t)=>(0,Y.jsx)(h.div,{initial:{opacity:0,y:10},animate:{opacity:1,y:0},exit:{opacity:0,scale:.96,transition:{duration:.15}},transition:{type:`spring`,stiffness:380,damping:30,delay:t*.04},children:(0,Y.jsx)(nn,{target:e,lastOp:n.get(e.id),onEdit:()=>te(e),onDelete:()=>N(e),quickActions:(0,Y.jsx)(Zt,{target:e,templates:r,templatesLoading:i,templatesError:a,isStreaming:I,onRetryTemplates:o,onSelect:F})})},e.id)),(0,Y.jsx)(h.div,{initial:{opacity:0,y:10},animate:{opacity:1,y:0},transition:{type:`spring`,stiffness:380,damping:30,delay:e.length*.04},children:(0,Y.jsx)(rn,{onClick:R})},`add-card`)]})}),(0,Y.jsx)(Qt,{selection:P,templates:r,stream:s,onSelectionChange:F}),(0,Y.jsx)(H,{open:c,editing:u!==null,platformId:f,form:m,showToken:E,saving:v,testing:k,canTestConnection:L,onOpenChange:l,onPlatformChange:p,onFormChange:_,onShowTokenChange:D,onSave:()=>void z(),onTestConnection:()=>{L&&A({...u?{targetId:u}:{},hostname:m.hostname.trim(),sourceHostname:m.sourceHostname.trim(),...m.apiToken.trim()?{apiToken:m.apiToken.trim()}:{}})},onCancelInFlight:j}),(0,Y.jsx)(C,{open:M!==null,onOpenChange:e=>!e&&N(null),children:(0,Y.jsxs)(ee,{children:[(0,Y.jsxs)(w,{children:[(0,Y.jsx)(T,{children:`Remove Target`}),(0,Y.jsxs)(x,{children:[`Remove “`,M?.label,`”? This only deletes the saved credentials — it does not affect resources on the target platform.`]})]}),(0,Y.jsxs)(b,{children:[(0,Y.jsx)(O,{variant:`outline`,onClick:()=>N(null),children:`Cancel`}),(0,Y.jsx)(O,{variant:`destructive`,onClick:async()=>{if(!M)return;let e=M.id;N(null);try{await V(e),S.success(`Target removed.`),t()}catch(e){S.error(q(e,`Failed to remove target.`))}},children:`Remove`})]})]})})]})}var on=25;function sn({status:e}){switch(e){case`success`:return(0,Y.jsx)(Oe,{className:`size-3 text-success`});case`partial`:case`blocked`:return(0,Y.jsx)(ze,{className:`size-3 text-warning`});case`noop`:return(0,Y.jsx)(tt,{className:`size-3 text-muted-foreground`});case`failed`:return(0,Y.jsx)(Ne,{className:`size-3 text-destructive`})}}function cn({targetCount:e,opCount:t,lastOp:n}){return(0,Y.jsxs)(`div`,{className:`flex flex-wrap items-center gap-x-3 gap-y-1 text-xs text-muted-foreground`,children:[(0,Y.jsxs)(`span`,{className:`flex items-center gap-1.5`,children:[(0,Y.jsx)(K,{className:`size-3`}),(0,Y.jsx)(`span`,{className:`font-mono`,children:e}),` target`,e===1?``:`s`]}),(0,Y.jsx)(`span`,{className:`hidden h-3 w-px bg-border/40 sm:inline-block`}),(0,Y.jsxs)(`span`,{className:`flex items-center gap-1`,children:[(0,Y.jsx)(g,{mode:`popLayout`,initial:!1,children:(0,Y.jsx)(h.span,{initial:{opacity:0,y:-6},animate:{opacity:1,y:0},exit:{opacity:0,y:6},transition:{type:`spring`,stiffness:500,damping:35},className:`font-mono tabular-nums`,children:t},t)}),` `,`operation`,t===1?``:`s`]}),n&&(0,Y.jsxs)(Y.Fragment,{children:[(0,Y.jsx)(`span`,{className:`hidden h-3 w-px bg-border/40 sm:inline-block`}),(0,Y.jsxs)(`span`,{className:`flex items-center gap-1.5`,children:[(0,Y.jsx)(sn,{status:n.status}),(0,Y.jsxs)(`span`,{children:[n.operationType===`apply`?`Applied`:`Cleaned`,` `,(0,Y.jsx)(`time`,{dateTime:new Date(n.completedAt).toISOString(),title:A(n.completedAt),children:k(n.completedAt)})]})]})]})]})}function ln(){let e=f({queryKey:s.platforms.targets(),queryFn:()=>pe()}),t=e.data??[],n=$e({queryKey:s.platforms.operationsList(),queryFn:({pageParam:e})=>de({limit:on,offset:e}),initialPageParam:0,getNextPageParam:(e,t,n)=>e.hasMore&&e.operations.length>0?n+on:void 0}),r=(0,J.useMemo)(()=>n.data?.pages.flatMap(e=>e.operations)??[],[n.data]),a=n.data?.pages[0]?.total??0,o=f({queryKey:s.catalog.templates(),queryFn:()=>c(`/catalog/templates`,i.catalogTemplates)}),u=o.data??[],d=me(),p=(0,J.useRef)(d.status);(0,J.useEffect)(()=>{let e=p.current;p.current=d.status,e===`running`&&d.status===`complete`&&l.invalidateQueries({queryKey:s.platforms.operationsList()})},[d.status]);let y=(0,J.useMemo)(()=>{let e=new Map;for(let t of r)e.has(t.targetId)||e.set(t.targetId,t);return e},[r]),[b,x]=_(`tab`,v([`targets`,`operations`,`activity`]).withDefault(`targets`)),S;return S=e.isPending&&e.data===void 0?null:e.isError&&e.data===void 0?(0,Y.jsx)(m,{message:q(e.error,`Could not load targets.`),onRetry:()=>void e.refetch(),isRetrying:e.isFetching&&!e.isPending}):t.length===0?(0,Y.jsx)(ct,{titleId:`platforms-operations-empty-title`,frameIcon:(0,Y.jsx)(K,{className:`size-6 text-muted-foreground/45`,"aria-hidden":!0}),description:(0,Y.jsx)(ot,{}),children:(0,Y.jsx)(st,{onClick:()=>void x(`targets`)})}):(0,Y.jsx)(Dt,{targets:t,stream:d}),(0,Y.jsxs)(`div`,{className:`mx-auto flex h-full w-full min-w-0 max-w-screen-2xl flex-col gap-5 p-4 sm:gap-6 sm:p-6`,children:[(0,Y.jsxs)(`div`,{className:`flex shrink-0 flex-col gap-2`,children:[(0,Y.jsx)(`h1`,{className:`font-heading text-2xl font-semibold tracking-tight`,children:`Platforms`}),(0,Y.jsx)(`p`,{className:`text-sm text-muted-foreground`,children:`Connect Platforms as targets, then apply templates or run cleanup from Operations.`}),(0,Y.jsx)(cn,{targetCount:t.length,opCount:a,lastOp:r[0]})]}),(0,Y.jsxs)(Pe,{value:b,onValueChange:e=>{x(e)},className:`flex-1 min-h-0`,children:[(0,Y.jsx)(`div`,{className:`shrink-0 overflow-x-auto`,children:(0,Y.jsxs)(Me,{variant:`line`,className:`h-10! gap-0.5 min-w-max`,children:[(0,Y.jsxs)(ke,{value:`targets`,className:`gap-1.5 px-3 text-sm`,children:[(0,Y.jsx)(K,{className:`size-3.5 shrink-0`}),`Targets`]}),(0,Y.jsxs)(ke,{value:`operations`,className:`gap-1.5 px-3 text-sm`,children:[(0,Y.jsx)(ye,{className:`size-3.5 shrink-0`}),`Operations`]}),(0,Y.jsxs)(ke,{value:`activity`,className:`gap-1.5 px-3 text-sm`,children:[(0,Y.jsx)(I,{className:`size-3.5 shrink-0`}),`Activity`]})]})}),(0,Y.jsx)(Ae,{value:`targets`,className:`flex-1 py-2`,children:(0,Y.jsx)(h.div,{initial:{opacity:0,y:6},animate:{opacity:1,y:0},transition:{duration:.15,ease:`easeOut`},children:e.isError&&e.data===void 0?(0,Y.jsx)(m,{message:q(e.error,`Failed to load targets.`),onRetry:()=>void e.refetch(),isRetrying:e.isFetching&&!e.isPending}):(0,Y.jsx)(an,{targets:t,onMutate:()=>void e.refetch(),lastOpByTarget:y,templates:u,templatesLoading:o.isPending&&o.data===void 0,templatesError:o.isError&&u.length===0,onRetryTemplates:()=>void o.refetch(),stream:d})},`targets`)}),(0,Y.jsx)(Ae,{value:`operations`,className:`flex-1 py-2`,children:(0,Y.jsx)(h.div,{initial:{opacity:0,y:6},animate:{opacity:1,y:0},transition:{duration:.15,ease:`easeOut`},children:S},`operations`)}),(0,Y.jsx)(Ae,{value:`activity`,className:`flex flex-col flex-1 min-h-0 py-2`,children:(0,Y.jsx)(h.div,{initial:{opacity:0,y:6},animate:{opacity:1,y:0},transition:{duration:.15,ease:`easeOut`},className:`flex flex-col flex-1 min-h-0`,children:(0,Y.jsx)(Xt,{operations:r,totalKnown:a,isLoading:n.isPending&&!n.data,error:n.error,onRefresh:()=>void l.invalidateQueries({queryKey:s.platforms.operationsList()}),hasNextPage:n.hasNextPage,isFetchingNextPage:n.isFetchingNextPage,loadMoreError:n.isFetchNextPageError&&n.error instanceof Error?n.error:null,onRetryLoadMore:()=>void n.fetchNextPage(),onLoadMore:()=>void n.fetchNextPage()})},`activity`)})]}),(0,Y.jsx)(g,{children:d.operation||d.status===`running`?(0,Y.jsx)(lt,{stream:d,onReset:d.reset,catalogTemplates:u}):null})]})}export{ln as t};
|
|
@@ -1 +1 @@
|
|
|
1
|
-
import{a as e}from"./rolldown-runtime-COnpUsM8.js";import{c as t}from"./vendor-charts-95ykyDlI.js";import{at as n}from"./vendor-ui-CWUk2ulb.js";import{$ as r,Q as i,Z as a,at as o,ct as s,dt as c,et as l,ft as u,it as d,lt as f,ot as p,rt as m,st as h,tt as g,ut as _}from"./api-DimikzPd.js";import{S as v}from"./format-CshN6yEB.js";import{n as y,t as b}from"./utils-XFKvwlFT.js";var x=class extends u{constructor(e,t){super(),this.options=t,this.#e=e,this.#s=null,this.#o=r(),this.bindMethods(),this.setOptions(t)}#e;#t=void 0;#n=void 0;#r=void 0;#i;#a;#o;#s;#c;#l;#u;#d;#f;#p;#m=new Set;bindMethods(){this.refetch=this.refetch.bind(this)}onSubscribe(){this.listeners.size===1&&(this.#t.addObserver(this),C(this.#t,this.options)?this.#h():this.updateResult(),this.#y())}onUnsubscribe(){this.hasListeners()||this.destroy()}shouldFetchOnReconnect(){return w(this.#t,this.options,this.options.refetchOnReconnect)}shouldFetchOnWindowFocus(){return w(this.#t,this.options,this.options.refetchOnWindowFocus)}destroy(){this.listeners=new Set,this.#b(),this.#x(),this.#t.removeObserver(this)}setOptions(e){let t=this.options,n=this.#t;if(this.options=this.#e.defaultQueryOptions(e),this.options.enabled!==void 0&&typeof this.options.enabled!=`boolean`&&typeof this.options.enabled!=`function`&&typeof o(this.options.enabled,this.#t)!=`boolean`)throw Error(`Expected enabled to be a boolean or a callback that returns a boolean`);this.#S(),this.#t.setOptions(this.options),t._defaulted&&!h(this.options,t)&&this.#e.getQueryCache().notify({type:`observerOptionsUpdated`,query:this.#t,observer:this});let r=this.hasListeners();r&&T(this.#t,n,this.options,t)&&this.#h(),this.updateResult(),r&&(this.#t!==n||o(this.options.enabled,this.#t)!==o(t.enabled,this.#t)||p(this.options.staleTime,this.#t)!==p(t.staleTime,this.#t))&&this.#g();let i=this.#_();r&&(this.#t!==n||o(this.options.enabled,this.#t)!==o(t.enabled,this.#t)||i!==this.#p)&&this.#v(i)}getOptimisticResult(e){let t=this.#e.getQueryCache().build(this.#e,e),n=this.createResult(t,e);return D(this,n)&&(this.#r=n,this.#a=this.options,this.#i=this.#t.state),n}getCurrentResult(){return this.#r}trackResult(e,t){return new Proxy(e,{get:(e,n)=>(this.trackProp(n),t?.(n),n===`promise`&&(this.trackProp(`data`),!this.options.experimental_prefetchInRender&&this.#o.status===`pending`&&this.#o.reject(Error(`experimental_prefetchInRender feature flag is not enabled`))),Reflect.get(e,n))})}trackProp(e){this.#m.add(e)}getCurrentQuery(){return this.#t}refetch({...e}={}){return this.fetch({...e})}fetchOptimistic(e){let t=this.#e.defaultQueryOptions(e),n=this.#e.getQueryCache().build(this.#e,t);return n.fetch().then(()=>this.createResult(n,t))}fetch(e){return this.#h({...e,cancelRefetch:e.cancelRefetch??!0}).then(()=>(this.updateResult(),this.#r))}#h(e){this.#S();let t=this.#t.fetch(this.options,e);return e?.throwOnError||(t=t.catch(m)),t}#g(){this.#b();let e=p(this.options.staleTime,this.#t);if(l.isServer()||this.#r.isStale||!g(e))return;let t=f(this.#r.dataUpdatedAt,e)+1;this.#d=_.setTimeout(()=>{this.#r.isStale||this.updateResult()},t)}#_(){return(typeof this.options.refetchInterval==`function`?this.options.refetchInterval(this.#t):this.options.refetchInterval)??!1}#v(e){this.#x(),this.#p=e,!(l.isServer()||o(this.options.enabled,this.#t)===!1||!g(this.#p)||this.#p===0)&&(this.#f=_.setInterval(()=>{(this.options.refetchIntervalInBackground||c.isFocused())&&this.#h()},this.#p))}#y(){this.#g(),this.#v(this.#_())}#b(){this.#d!==void 0&&(_.clearTimeout(this.#d),this.#d=void 0)}#x(){this.#f!==void 0&&(_.clearInterval(this.#f),this.#f=void 0)}createResult(e,t){let n=this.#t,i=this.options,s=this.#r,c=this.#i,l=this.#a,u=e===n?this.#n:e.state,{state:f}=e,p={...f},m=!1,h;if(t._optimisticResults){let r=this.hasListeners(),o=!r&&C(e,t),s=r&&T(e,n,t,i);(o||s)&&(p={...p,...a(f.data,e.options)}),t._optimisticResults===`isRestoring`&&(p.fetchStatus=`idle`)}let{error:g,errorUpdatedAt:_,status:v}=p;h=p.data;let y=!1;if(t.placeholderData!==void 0&&h===void 0&&v===`pending`){let e;s?.isPlaceholderData&&t.placeholderData===l?.placeholderData?(e=s.data,y=!0):e=typeof t.placeholderData==`function`?t.placeholderData(this.#u?.state.data,this.#u):t.placeholderData,e!==void 0&&(v=`success`,h=d(s?.data,e,t),m=!0)}if(t.select&&h!==void 0&&!y)if(s&&h===c?.data&&t.select===this.#c)h=this.#l;else try{this.#c=t.select,h=t.select(h),h=d(s?.data,h,t),this.#l=h,this.#s=null}catch(e){this.#s=e}this.#s&&(g=this.#s,h=this.#l,_=Date.now(),v=`error`);let b=p.fetchStatus===`fetching`,x=v===`pending`,S=v===`error`,w=x&&b,D=h!==void 0,O={status:v,fetchStatus:p.fetchStatus,isPending:x,isSuccess:v===`success`,isError:S,isInitialLoading:w,isLoading:w,data:h,dataUpdatedAt:p.dataUpdatedAt,error:g,errorUpdatedAt:_,failureCount:p.fetchFailureCount,failureReason:p.fetchFailureReason,errorUpdateCount:p.errorUpdateCount,isFetched:e.isFetched(),isFetchedAfterMount:p.dataUpdateCount>u.dataUpdateCount||p.errorUpdateCount>u.errorUpdateCount,isFetching:b,isRefetching:b&&!x,isLoadingError:S&&!D,isPaused:p.fetchStatus===`paused`,isPlaceholderData:m,isRefetchError:S&&D,isStale:E(e,t),refetch:this.refetch,promise:this.#o,isEnabled:o(t.enabled,e)!==!1};if(this.options.experimental_prefetchInRender){let t=O.data!==void 0,i=O.status===`error`&&!t,a=e=>{i?e.reject(O.error):t&&e.resolve(O.data)},o=()=>{a(this.#o=O.promise=r())},s=this.#o;switch(s.status){case`pending`:e.queryHash===n.queryHash&&a(s);break;case`fulfilled`:(i||O.data!==s.value)&&o();break;case`rejected`:(!i||O.error!==s.reason)&&o();break}}return O}updateResult(){let e=this.#r,t=this.createResult(this.#t,this.options);this.#i=this.#t.state,this.#a=this.options,this.#i.data!==void 0&&(this.#u=this.#t),!h(t,e)&&(this.#r=t,this.#C({listeners:(()=>{if(!e)return!0;let{notifyOnChangeProps:t}=this.options,n=typeof t==`function`?t():t;if(n===`all`||!n&&!this.#m.size)return!0;let r=new Set(n??this.#m);return this.options.throwOnError&&r.add(`error`),Object.keys(this.#r).some(t=>{let n=t;return this.#r[n]!==e[n]&&r.has(n)})})()}))}#S(){let e=this.#e.getQueryCache().build(this.#e,this.options);if(e===this.#t)return;let t=this.#t;this.#t=e,this.#n=e.state,this.hasListeners()&&(t?.removeObserver(this),e.addObserver(this))}onQueryUpdate(){this.updateResult(),this.hasListeners()&&this.#y()}#C(e){i.batch(()=>{e.listeners&&this.listeners.forEach(e=>{e(this.#r)}),this.#e.getQueryCache().notify({query:this.#t,type:`observerResultsUpdated`})})}};function S(e,t){return o(t.enabled,e)!==!1&&e.state.data===void 0&&!(e.state.status===`error`&&t.retryOnMount===!1)}function C(e,t){return S(e,t)||e.state.data!==void 0&&w(e,t,t.refetchOnMount)}function w(e,t,n){if(o(t.enabled,e)!==!1&&p(t.staleTime,e)!==`static`){let r=typeof n==`function`?n(e):n;return r===`always`||r!==!1&&E(e,t)}return!1}function T(e,t,n,r){return(e!==t||o(r.enabled,e)===!1)&&(!n.suspense||e.state.status!==`error`)&&E(e,n)}function E(e,t){return o(t.enabled,e)!==!1&&e.isStaleByTime(p(t.staleTime,e))}function D(e,t){return!h(e.getCurrentResult(),t)}var O=e(t(),1),k=n(),A=O.createContext(void 0),j=e=>{let t=O.useContext(A);if(e)return e;if(!t)throw Error(`No QueryClient set, use QueryClientProvider to set one`);return t},M=({client:e,children:t})=>(O.useEffect(()=>(e.mount(),()=>{e.unmount()}),[e]),(0,k.jsx)(A.Provider,{value:e,children:t})),N=O.createContext(!1),P=()=>O.useContext(N);N.Provider;function F(){let e=!1;return{clearReset:()=>{e=!1},reset:()=>{e=!0},isReset:()=>e}}var I=O.createContext(F()),L=()=>O.useContext(I),R=(e,t,n)=>{let r=n?.state.error&&typeof e.throwOnError==`function`?s(e.throwOnError,[n.state.error,n]):e.throwOnError;(e.suspense||e.experimental_prefetchInRender||r)&&(t.isReset()||(e.retryOnMount=!1))},z=e=>{O.useEffect(()=>{e.clearReset()},[e])},B=({result:e,errorResetBoundary:t,throwOnError:n,query:r,suspense:i})=>e.isError&&!t.isReset()&&!e.isFetching&&r&&(i&&e.data===void 0||s(n,[e.error,r])),V=e=>{if(e.suspense){let t=1e3,n=e=>e===`static`?e:Math.max(e??t,t),r=e.staleTime;e.staleTime=typeof r==`function`?(...e)=>n(r(...e)):n(r),typeof e.gcTime==`number`&&(e.gcTime=Math.max(e.gcTime,t))}},H=(e,t)=>e.isLoading&&e.isFetching&&!t,U=(e,t)=>e?.suspense&&t.isPending,W=(e,t,n)=>t.fetchOptimistic(e).catch(()=>{n.clearReset()});function G(e,t,n){let r=P(),a=L(),o=j(n),s=o.defaultQueryOptions(e);o.getDefaultOptions().queries?._experimental_beforeQuery?.(s);let c=o.getQueryCache().get(s.queryHash);s._optimisticResults=r?`isRestoring`:`optimistic`,V(s),R(s,a,c),z(a);let u=!o.getQueryCache().get(s.queryHash),[d]=O.useState(()=>new t(o,s)),f=d.getOptimisticResult(s),p=!r&&e.subscribed!==!1;if(O.useSyncExternalStore(O.useCallback(e=>{let t=p?d.subscribe(i.batchCalls(e)):m;return d.updateResult(),t},[d,p]),()=>d.getCurrentResult(),()=>d.getCurrentResult()),O.useEffect(()=>{d.setOptions(s)},[s,d]),U(s,f))throw W(s,d,a);if(B({result:f,errorResetBoundary:a,throwOnError:s.throwOnError,query:c,suspense:s.suspense}))throw f.error;return o.getDefaultOptions().queries?._experimental_afterQuery?.(s,f),s.experimental_prefetchInRender&&!l.isServer()&&H(f,r)&&(u?W(s,d,a):c?.promise)?.catch(m).finally(()=>{d.updateResult()}),s.notifyOnChangeProps?f:d.trackResult(f)}function K(e,t){return G(e,x,t)}var q=y(`refresh-cw`,[[`path`,{d:`M3 12a9 9 0 0 1 9-9 9.75 9.75 0 0 1 6.74 2.74L21 8`,key:`v9h5vc`}],[`path`,{d:`M21 3v5h-5`,key:`1q7to0`}],[`path`,{d:`M21 12a9 9 0 0 1-9 9 9.75 9.75 0 0 1-6.74-2.74L3 16`,key:`3uifl3`}],[`path`,{d:`M8 16H3v5`,key:`1cv678`}]]);function J({role:e=`status`,"aria-live":t=`polite`,"aria-atomic":n=!0,className:r,eyebrow:i,stamp:a,title:o,children:s,detailLabel:c=`Technical detail`,detail:l,primaryLabel:u,onPrimary:d,primaryIcon:f,primaryDisabled:p,primaryBusy:m,secondaryLabel:h,onSecondary:g}){return(0,k.jsx)(`div`,{role:e,"aria-live":t,"aria-atomic":n,className:b(`relative overflow-hidden rounded-[var(--miravo-radius-stadium-lg)] border border-primary/20 bg-transparent`,r),children:(0,k.jsx)(`div`,{className:`p-5 sm:p-6`,children:(0,k.jsxs)(`div`,{className:`min-w-0 space-y-4`,children:[(0,k.jsxs)(`div`,{className:`space-y-3`,children:[(0,k.jsx)(`p`,{className:`font-mono text-[0.65rem] uppercase tracking-[0.38em] text-muted-foreground`,children:i}),(0,k.jsxs)(`div`,{className:`flex items-end gap-3`,children:[(0,k.jsx)(`span`,{className:`font-heading text-3xl font-black leading-none tracking-[-0.06em] text-transparent [-webkit-text-stroke:1px_color-mix(in_srgb,var(--primary)_50%,transparent)] sm:text-4xl`,"aria-hidden":!0,children:a}),(0,k.jsx)(`div`,{className:`mb-1.5 h-px min-w-8 flex-1 bg-linear-to-r from-primary/55 to-transparent`})]}),(0,k.jsx)(`h2`,{className:`text-lg font-semibold tracking-[-0.03em] text-foreground sm:text-xl`,children:o}),s?(0,k.jsx)(`div`,{className:`space-y-2 text-sm leading-relaxed text-muted-foreground`,children:s}):null]}),(0,k.jsxs)(`div`,{className:`rounded-[var(--miravo-radius-stadium-sm)] border border-border/80 bg-background/55 p-4 backdrop-blur-sm`,children:[(0,k.jsx)(`div`,{className:`mb-2 font-mono text-[0.65rem] uppercase tracking-[0.28em] text-muted-foreground`,children:c}),(0,k.jsx)(`p`,{className:`wrap-break-word font-mono text-sm leading-relaxed text-primary`,children:l})]}),(0,k.jsxs)(`div`,{className:`flex flex-col gap-2 sm:flex-row sm:flex-wrap`,children:[(0,k.jsxs)(v,{type:`button`,onClick:d,disabled:!!(p||m),"aria-busy":m,className:b(`inline-flex w-full items-center justify-center gap-2 rounded-[var(--miravo-radius-stadium-sm)] border border-foreground/15 bg-foreground px-4 py-2.5 font-medium text-background shadow-none transition hover:bg-foreground/90 sm:w-auto`,m&&`pointer-events-none opacity-90`),children:[f,u]}),h&&g?(0,k.jsx)(v,{type:`button`,variant:`ghost`,size:`sm`,className:`sm:self-center`,onClick:g,children:h}):null]})]})})})}function Y({message:e,onRetry:t,isRetrying:n}){return(0,k.jsxs)(J,{role:`alert`,eyebrow:`Data link fault`,stamp:`ERR`,title:`Couldn't reach Miravo`,detail:e,primaryLabel:`Retry request`,onPrimary:t,primaryBusy:!!n,primaryIcon:(0,k.jsx)(q,{className:b(`size-4 shrink-0`,n&&`animate-spin`),"aria-hidden":!0}),children:[(0,k.jsxs)(`p`,{children:[(0,k.jsx)(`span`,{className:`text-foreground`,children:`Most often:`}),` the Miravo admin server isn't running, or this browser can't reach it (wrong host, port, or firewall).`]}),(0,k.jsx)(`p`,{children:`Start or restart Miravo if needed, use the correct link to the Miravo Console, then try again.`})]})}export{G as a,x as c,K as i,J as n,M as o,q as r,j as s,Y as t};
|
|
1
|
+
import{a as e}from"./rolldown-runtime-COnpUsM8.js";import{c as t}from"./vendor-charts-95ykyDlI.js";import{at as n}from"./vendor-ui-CWUk2ulb.js";import{$ as r,Q as i,Z as a,at as o,ct as s,dt as c,et as l,ft as u,it as d,lt as f,ot as p,rt as m,st as h,tt as g,ut as _}from"./api-D8oAzcVE.js";import{S as v}from"./format-CshN6yEB.js";import{n as y,t as b}from"./utils-XFKvwlFT.js";var x=class extends u{constructor(e,t){super(),this.options=t,this.#e=e,this.#s=null,this.#o=r(),this.bindMethods(),this.setOptions(t)}#e;#t=void 0;#n=void 0;#r=void 0;#i;#a;#o;#s;#c;#l;#u;#d;#f;#p;#m=new Set;bindMethods(){this.refetch=this.refetch.bind(this)}onSubscribe(){this.listeners.size===1&&(this.#t.addObserver(this),C(this.#t,this.options)?this.#h():this.updateResult(),this.#y())}onUnsubscribe(){this.hasListeners()||this.destroy()}shouldFetchOnReconnect(){return w(this.#t,this.options,this.options.refetchOnReconnect)}shouldFetchOnWindowFocus(){return w(this.#t,this.options,this.options.refetchOnWindowFocus)}destroy(){this.listeners=new Set,this.#b(),this.#x(),this.#t.removeObserver(this)}setOptions(e){let t=this.options,n=this.#t;if(this.options=this.#e.defaultQueryOptions(e),this.options.enabled!==void 0&&typeof this.options.enabled!=`boolean`&&typeof this.options.enabled!=`function`&&typeof o(this.options.enabled,this.#t)!=`boolean`)throw Error(`Expected enabled to be a boolean or a callback that returns a boolean`);this.#S(),this.#t.setOptions(this.options),t._defaulted&&!h(this.options,t)&&this.#e.getQueryCache().notify({type:`observerOptionsUpdated`,query:this.#t,observer:this});let r=this.hasListeners();r&&T(this.#t,n,this.options,t)&&this.#h(),this.updateResult(),r&&(this.#t!==n||o(this.options.enabled,this.#t)!==o(t.enabled,this.#t)||p(this.options.staleTime,this.#t)!==p(t.staleTime,this.#t))&&this.#g();let i=this.#_();r&&(this.#t!==n||o(this.options.enabled,this.#t)!==o(t.enabled,this.#t)||i!==this.#p)&&this.#v(i)}getOptimisticResult(e){let t=this.#e.getQueryCache().build(this.#e,e),n=this.createResult(t,e);return D(this,n)&&(this.#r=n,this.#a=this.options,this.#i=this.#t.state),n}getCurrentResult(){return this.#r}trackResult(e,t){return new Proxy(e,{get:(e,n)=>(this.trackProp(n),t?.(n),n===`promise`&&(this.trackProp(`data`),!this.options.experimental_prefetchInRender&&this.#o.status===`pending`&&this.#o.reject(Error(`experimental_prefetchInRender feature flag is not enabled`))),Reflect.get(e,n))})}trackProp(e){this.#m.add(e)}getCurrentQuery(){return this.#t}refetch({...e}={}){return this.fetch({...e})}fetchOptimistic(e){let t=this.#e.defaultQueryOptions(e),n=this.#e.getQueryCache().build(this.#e,t);return n.fetch().then(()=>this.createResult(n,t))}fetch(e){return this.#h({...e,cancelRefetch:e.cancelRefetch??!0}).then(()=>(this.updateResult(),this.#r))}#h(e){this.#S();let t=this.#t.fetch(this.options,e);return e?.throwOnError||(t=t.catch(m)),t}#g(){this.#b();let e=p(this.options.staleTime,this.#t);if(l.isServer()||this.#r.isStale||!g(e))return;let t=f(this.#r.dataUpdatedAt,e)+1;this.#d=_.setTimeout(()=>{this.#r.isStale||this.updateResult()},t)}#_(){return(typeof this.options.refetchInterval==`function`?this.options.refetchInterval(this.#t):this.options.refetchInterval)??!1}#v(e){this.#x(),this.#p=e,!(l.isServer()||o(this.options.enabled,this.#t)===!1||!g(this.#p)||this.#p===0)&&(this.#f=_.setInterval(()=>{(this.options.refetchIntervalInBackground||c.isFocused())&&this.#h()},this.#p))}#y(){this.#g(),this.#v(this.#_())}#b(){this.#d!==void 0&&(_.clearTimeout(this.#d),this.#d=void 0)}#x(){this.#f!==void 0&&(_.clearInterval(this.#f),this.#f=void 0)}createResult(e,t){let n=this.#t,i=this.options,s=this.#r,c=this.#i,l=this.#a,u=e===n?this.#n:e.state,{state:f}=e,p={...f},m=!1,h;if(t._optimisticResults){let r=this.hasListeners(),o=!r&&C(e,t),s=r&&T(e,n,t,i);(o||s)&&(p={...p,...a(f.data,e.options)}),t._optimisticResults===`isRestoring`&&(p.fetchStatus=`idle`)}let{error:g,errorUpdatedAt:_,status:v}=p;h=p.data;let y=!1;if(t.placeholderData!==void 0&&h===void 0&&v===`pending`){let e;s?.isPlaceholderData&&t.placeholderData===l?.placeholderData?(e=s.data,y=!0):e=typeof t.placeholderData==`function`?t.placeholderData(this.#u?.state.data,this.#u):t.placeholderData,e!==void 0&&(v=`success`,h=d(s?.data,e,t),m=!0)}if(t.select&&h!==void 0&&!y)if(s&&h===c?.data&&t.select===this.#c)h=this.#l;else try{this.#c=t.select,h=t.select(h),h=d(s?.data,h,t),this.#l=h,this.#s=null}catch(e){this.#s=e}this.#s&&(g=this.#s,h=this.#l,_=Date.now(),v=`error`);let b=p.fetchStatus===`fetching`,x=v===`pending`,S=v===`error`,w=x&&b,D=h!==void 0,O={status:v,fetchStatus:p.fetchStatus,isPending:x,isSuccess:v===`success`,isError:S,isInitialLoading:w,isLoading:w,data:h,dataUpdatedAt:p.dataUpdatedAt,error:g,errorUpdatedAt:_,failureCount:p.fetchFailureCount,failureReason:p.fetchFailureReason,errorUpdateCount:p.errorUpdateCount,isFetched:e.isFetched(),isFetchedAfterMount:p.dataUpdateCount>u.dataUpdateCount||p.errorUpdateCount>u.errorUpdateCount,isFetching:b,isRefetching:b&&!x,isLoadingError:S&&!D,isPaused:p.fetchStatus===`paused`,isPlaceholderData:m,isRefetchError:S&&D,isStale:E(e,t),refetch:this.refetch,promise:this.#o,isEnabled:o(t.enabled,e)!==!1};if(this.options.experimental_prefetchInRender){let t=O.data!==void 0,i=O.status===`error`&&!t,a=e=>{i?e.reject(O.error):t&&e.resolve(O.data)},o=()=>{a(this.#o=O.promise=r())},s=this.#o;switch(s.status){case`pending`:e.queryHash===n.queryHash&&a(s);break;case`fulfilled`:(i||O.data!==s.value)&&o();break;case`rejected`:(!i||O.error!==s.reason)&&o();break}}return O}updateResult(){let e=this.#r,t=this.createResult(this.#t,this.options);this.#i=this.#t.state,this.#a=this.options,this.#i.data!==void 0&&(this.#u=this.#t),!h(t,e)&&(this.#r=t,this.#C({listeners:(()=>{if(!e)return!0;let{notifyOnChangeProps:t}=this.options,n=typeof t==`function`?t():t;if(n===`all`||!n&&!this.#m.size)return!0;let r=new Set(n??this.#m);return this.options.throwOnError&&r.add(`error`),Object.keys(this.#r).some(t=>{let n=t;return this.#r[n]!==e[n]&&r.has(n)})})()}))}#S(){let e=this.#e.getQueryCache().build(this.#e,this.options);if(e===this.#t)return;let t=this.#t;this.#t=e,this.#n=e.state,this.hasListeners()&&(t?.removeObserver(this),e.addObserver(this))}onQueryUpdate(){this.updateResult(),this.hasListeners()&&this.#y()}#C(e){i.batch(()=>{e.listeners&&this.listeners.forEach(e=>{e(this.#r)}),this.#e.getQueryCache().notify({query:this.#t,type:`observerResultsUpdated`})})}};function S(e,t){return o(t.enabled,e)!==!1&&e.state.data===void 0&&!(e.state.status===`error`&&t.retryOnMount===!1)}function C(e,t){return S(e,t)||e.state.data!==void 0&&w(e,t,t.refetchOnMount)}function w(e,t,n){if(o(t.enabled,e)!==!1&&p(t.staleTime,e)!==`static`){let r=typeof n==`function`?n(e):n;return r===`always`||r!==!1&&E(e,t)}return!1}function T(e,t,n,r){return(e!==t||o(r.enabled,e)===!1)&&(!n.suspense||e.state.status!==`error`)&&E(e,n)}function E(e,t){return o(t.enabled,e)!==!1&&e.isStaleByTime(p(t.staleTime,e))}function D(e,t){return!h(e.getCurrentResult(),t)}var O=e(t(),1),k=n(),A=O.createContext(void 0),j=e=>{let t=O.useContext(A);if(e)return e;if(!t)throw Error(`No QueryClient set, use QueryClientProvider to set one`);return t},M=({client:e,children:t})=>(O.useEffect(()=>(e.mount(),()=>{e.unmount()}),[e]),(0,k.jsx)(A.Provider,{value:e,children:t})),N=O.createContext(!1),P=()=>O.useContext(N);N.Provider;function F(){let e=!1;return{clearReset:()=>{e=!1},reset:()=>{e=!0},isReset:()=>e}}var I=O.createContext(F()),L=()=>O.useContext(I),R=(e,t,n)=>{let r=n?.state.error&&typeof e.throwOnError==`function`?s(e.throwOnError,[n.state.error,n]):e.throwOnError;(e.suspense||e.experimental_prefetchInRender||r)&&(t.isReset()||(e.retryOnMount=!1))},z=e=>{O.useEffect(()=>{e.clearReset()},[e])},B=({result:e,errorResetBoundary:t,throwOnError:n,query:r,suspense:i})=>e.isError&&!t.isReset()&&!e.isFetching&&r&&(i&&e.data===void 0||s(n,[e.error,r])),V=e=>{if(e.suspense){let t=1e3,n=e=>e===`static`?e:Math.max(e??t,t),r=e.staleTime;e.staleTime=typeof r==`function`?(...e)=>n(r(...e)):n(r),typeof e.gcTime==`number`&&(e.gcTime=Math.max(e.gcTime,t))}},H=(e,t)=>e.isLoading&&e.isFetching&&!t,U=(e,t)=>e?.suspense&&t.isPending,W=(e,t,n)=>t.fetchOptimistic(e).catch(()=>{n.clearReset()});function G(e,t,n){let r=P(),a=L(),o=j(n),s=o.defaultQueryOptions(e);o.getDefaultOptions().queries?._experimental_beforeQuery?.(s);let c=o.getQueryCache().get(s.queryHash);s._optimisticResults=r?`isRestoring`:`optimistic`,V(s),R(s,a,c),z(a);let u=!o.getQueryCache().get(s.queryHash),[d]=O.useState(()=>new t(o,s)),f=d.getOptimisticResult(s),p=!r&&e.subscribed!==!1;if(O.useSyncExternalStore(O.useCallback(e=>{let t=p?d.subscribe(i.batchCalls(e)):m;return d.updateResult(),t},[d,p]),()=>d.getCurrentResult(),()=>d.getCurrentResult()),O.useEffect(()=>{d.setOptions(s)},[s,d]),U(s,f))throw W(s,d,a);if(B({result:f,errorResetBoundary:a,throwOnError:s.throwOnError,query:c,suspense:s.suspense}))throw f.error;return o.getDefaultOptions().queries?._experimental_afterQuery?.(s,f),s.experimental_prefetchInRender&&!l.isServer()&&H(f,r)&&(u?W(s,d,a):c?.promise)?.catch(m).finally(()=>{d.updateResult()}),s.notifyOnChangeProps?f:d.trackResult(f)}function K(e,t){return G(e,x,t)}var q=y(`refresh-cw`,[[`path`,{d:`M3 12a9 9 0 0 1 9-9 9.75 9.75 0 0 1 6.74 2.74L21 8`,key:`v9h5vc`}],[`path`,{d:`M21 3v5h-5`,key:`1q7to0`}],[`path`,{d:`M21 12a9 9 0 0 1-9 9 9.75 9.75 0 0 1-6.74-2.74L3 16`,key:`3uifl3`}],[`path`,{d:`M8 16H3v5`,key:`1cv678`}]]);function J({role:e=`status`,"aria-live":t=`polite`,"aria-atomic":n=!0,className:r,eyebrow:i,stamp:a,title:o,children:s,detailLabel:c=`Technical detail`,detail:l,primaryLabel:u,onPrimary:d,primaryIcon:f,primaryDisabled:p,primaryBusy:m,secondaryLabel:h,onSecondary:g}){return(0,k.jsx)(`div`,{role:e,"aria-live":t,"aria-atomic":n,className:b(`relative overflow-hidden rounded-[var(--miravo-radius-stadium-lg)] border border-primary/20 bg-transparent`,r),children:(0,k.jsx)(`div`,{className:`p-5 sm:p-6`,children:(0,k.jsxs)(`div`,{className:`min-w-0 space-y-4`,children:[(0,k.jsxs)(`div`,{className:`space-y-3`,children:[(0,k.jsx)(`p`,{className:`font-mono text-[0.65rem] uppercase tracking-[0.38em] text-muted-foreground`,children:i}),(0,k.jsxs)(`div`,{className:`flex items-end gap-3`,children:[(0,k.jsx)(`span`,{className:`font-heading text-3xl font-black leading-none tracking-[-0.06em] text-transparent [-webkit-text-stroke:1px_color-mix(in_srgb,var(--primary)_50%,transparent)] sm:text-4xl`,"aria-hidden":!0,children:a}),(0,k.jsx)(`div`,{className:`mb-1.5 h-px min-w-8 flex-1 bg-linear-to-r from-primary/55 to-transparent`})]}),(0,k.jsx)(`h2`,{className:`text-lg font-semibold tracking-[-0.03em] text-foreground sm:text-xl`,children:o}),s?(0,k.jsx)(`div`,{className:`space-y-2 text-sm leading-relaxed text-muted-foreground`,children:s}):null]}),(0,k.jsxs)(`div`,{className:`rounded-[var(--miravo-radius-stadium-sm)] border border-border/80 bg-background/55 p-4 backdrop-blur-sm`,children:[(0,k.jsx)(`div`,{className:`mb-2 font-mono text-[0.65rem] uppercase tracking-[0.28em] text-muted-foreground`,children:c}),(0,k.jsx)(`p`,{className:`wrap-break-word font-mono text-sm leading-relaxed text-primary`,children:l})]}),(0,k.jsxs)(`div`,{className:`flex flex-col gap-2 sm:flex-row sm:flex-wrap`,children:[(0,k.jsxs)(v,{type:`button`,onClick:d,disabled:!!(p||m),"aria-busy":m,className:b(`inline-flex w-full items-center justify-center gap-2 rounded-[var(--miravo-radius-stadium-sm)] border border-foreground/15 bg-foreground px-4 py-2.5 font-medium text-background shadow-none transition hover:bg-foreground/90 sm:w-auto`,m&&`pointer-events-none opacity-90`),children:[f,u]}),h&&g?(0,k.jsx)(v,{type:`button`,variant:`ghost`,size:`sm`,className:`sm:self-center`,onClick:g,children:h}):null]})]})})})}function Y({message:e,onRetry:t,isRetrying:n}){return(0,k.jsxs)(J,{role:`alert`,eyebrow:`Data link fault`,stamp:`ERR`,title:`Couldn't reach Miravo`,detail:e,primaryLabel:`Retry request`,onPrimary:t,primaryBusy:!!n,primaryIcon:(0,k.jsx)(q,{className:b(`size-4 shrink-0`,n&&`animate-spin`),"aria-hidden":!0}),children:[(0,k.jsxs)(`p`,{children:[(0,k.jsx)(`span`,{className:`text-foreground`,children:`Most often:`}),` the Miravo admin server isn't running, or this browser can't reach it (wrong host, port, or firewall).`]}),(0,k.jsx)(`p`,{children:`Start or restart Miravo if needed, use the correct link to the Miravo Console, then try again.`})]})}export{G as a,x as c,K as i,J as n,M as o,q as r,j as s,Y as t};
|
|
@@ -1,2 +1,2 @@
|
|
|
1
|
-
const __vite__mapDeps=(i,m=__vite__mapDeps,d=(m.f||(m.f=["assets/fleet-
|
|
2
|
-
import{d as e}from"./chunk-OE4NN4TA-DBWZidbW.js";var t=[{test:e=>e===`/`,load:()=>e(()=>import(`./fleet-
|
|
1
|
+
const __vite__mapDeps=(i,m=__vite__mapDeps,d=(m.f||(m.f=["assets/fleet-C9wGf070.js","assets/fleet-CH141gbg.js","assets/rolldown-runtime-COnpUsM8.js","assets/chunk-OE4NN4TA-DBWZidbW.js","assets/vendor-charts-95ykyDlI.js","assets/api-D8oAzcVE.js","assets/vendor-ui-CWUk2ulb.js","assets/format-CshN6yEB.js","assets/utils-XFKvwlFT.js","assets/arrow-right-BjBb4z7g.js","assets/arrow-up-down-C1oJAmrw.js","assets/select-CmlY1M1a.js","assets/circle-question-mark-CJvcT6V6.js","assets/dist-xY0pK9Wy.js","assets/engine-store-DMULdR_V.js","assets/shallow-Cin0mLuv.js","assets/badge-eIn_7YrK.js","assets/combobox-BCaV1Wbo.js","assets/select-display-items-Bqb6Sbg6.js","assets/tooltip-D1ydB4g3.js","assets/transition-types-2i1blGlR.js","assets/catalog-B70TugE6.js","assets/catalog-B_wh8kje.js","assets/query-fetch-error-NbPqVPRR.js","assets/AnimatePresence-CPmH1DMY.js","assets/proxy-Be4WzmcS.js","assets/use-platform-stream-DBZo6HMM.js","assets/platform-targets-BIQ1lKOg.js","assets/tabs-4SeH2unv.js","assets/copy-button-BvU3RDZa.js","assets/checkbox-C_4HRnS_.js","assets/triangle-alert-BXrJNk3g.js","assets/label-CMBWxUhA.js","assets/catalog-template-icons-3S8RvUxD.js","assets/catalog-source-BU77f8QO.js","assets/download-DmUZKo9N.js","assets/get-error-message-Dk8elqEP.js","assets/use-engine-command-mutation-CcfqRB7j.js","assets/runtime-link-PMxeHxd6.js","assets/models-hAhKpuYB.js","assets/models-CFdqSxB3.js","assets/activity-Cy_niK56.js","assets/events-BjMeLN1K.js","assets/events-CeR9wTII.js","assets/auth-screen-backdrop-Cr8qBSXP.js","assets/use-transition-navigate-jTHkLHMS.js","assets/control-CaFfl-Mp.js","assets/control-DCNd1A3U.js","assets/validation-DRj8OKvB.js","assets/layers-1figUpjG.js","assets/transition-nav-link-Ct6VIy2S.js","assets/tags-_ufsHpn5.js","assets/tags-BI93Dvh2.js","assets/vendor-table-BAHQgdwg.js","assets/dropdown-menu-CrPXVXpG.js","assets/platforms-Bh63oQIi.js","assets/platforms-BwYPf2Sg.js","assets/instance-detail-DWELGCE1.js","assets/login-C5dQKX2Y.js"])))=>i.map(i=>d[i]);
|
|
2
|
+
import{d as e}from"./chunk-OE4NN4TA-DBWZidbW.js";var t=[{test:e=>e===`/`,load:()=>e(()=>import(`./fleet-C9wGf070.js`),__vite__mapDeps([0,1,2,3,4,5,6,7,8,9,10,11,12,13,14,15,16,17,18,19,20]))},{test:e=>e===`/catalog`,load:()=>e(()=>import(`./catalog-B70TugE6.js`),__vite__mapDeps([21,22,2,5,6,4,23,7,8,24,25,26,11,27,28,12,29,19,30,31,16,32,33,34,35,36,37,14,38]))},{test:e=>e===`/models`,load:()=>e(()=>import(`./models-hAhKpuYB.js`),__vite__mapDeps([39,40,2,5,6,4,23,7,8,24,25,41,26,11,27,28,12,29,19,30,31,16,32,34,35,36,37,14,38]))},{test:e=>e===`/events`,load:()=>e(()=>import(`./events-BjMeLN1K.js`),__vite__mapDeps([42,43,2,3,4,5,6,23,7,8,24,25,11,14,44,16,17,18,45,36,38,20]))},{test:e=>e===`/control`,load:()=>e(()=>import(`./control-CaFfl-Mp.js`),__vite__mapDeps([46,47,2,5,6,4,7,8,24,25,41,9,11,28,29,19,48,30,49,37,14,38,31,13,15,50,3,45,16,17,32]))},{test:e=>e===`/tags`,load:()=>e(()=>import(`./tags-_ufsHpn5.js`),__vite__mapDeps([51,52,2,3,4,5,6,23,7,8,53,10,11,27,29,19,35,13,14,44,17,54,32,36]))},{test:e=>e===`/platforms`,load:()=>e(()=>import(`./platforms-Bh63oQIi.js`),__vite__mapDeps([55,56,2,3,4,5,6,23,7,8,24,25,41,9,26,11,27,28,12,29,19,30,31,16,32,33,49,13,54,36]))},{test:e=>e.startsWith(`/instance/`),load:()=>e(()=>import(`./instance-detail-DWELGCE1.js`),__vite__mapDeps([57,2,3,4,5,6,23,7,8,25,41,28,29,19,48,37,14,38,31,13,44,16,36,20]))},{test:e=>e===`/login`,load:()=>e(()=>import(`./login-C5dQKX2Y.js`),__vite__mapDeps([58,2,5,6,4,50,3,45,36]))}],n=new Set;function r(e){if(!e.startsWith(`/`))return null;let t=e.indexOf(`?`),n=e.indexOf(`#`),r=t===-1?n===-1?e.length:n:n===-1?t:Math.min(t,n);return e.slice(0,r)}function i(e){let i=r(e);if(!i||n.has(i))return;let a=t.find(e=>e.test(i));a&&(n.add(i),a.load().catch(()=>{n.delete(i)}))}export{i as t};
|
|
@@ -1,4 +1,4 @@
|
|
|
1
|
-
import{a as e}from"./rolldown-runtime-COnpUsM8.js";import{c as t}from"./vendor-charts-95ykyDlI.js";import{at as n}from"./vendor-ui-CWUk2ulb.js";import{S as r,b as i,nt as a,o}from"./api-
|
|
1
|
+
import{a as e}from"./rolldown-runtime-COnpUsM8.js";import{c as t}from"./vendor-charts-95ykyDlI.js";import{at as n}from"./vendor-ui-CWUk2ulb.js";import{S as r,b as i,nt as a,o}from"./api-D8oAzcVE.js";import{i as s,t as c}from"./query-fetch-error-NbPqVPRR.js";import{i as l,n as u,t as d}from"./dist-xY0pK9Wy.js";import{n as f}from"./chunk-OE4NN4TA-DBWZidbW.js";import{a as p,i as m,n as h,o as g,r as _,s as v,t as y}from"./copy-button-BvU3RDZa.js";import{S as b,c as x,u as S,v as C,w,x as T,y as ee}from"./format-CshN6yEB.js";import{n as E,t as te}from"./utils-XFKvwlFT.js";import{t as D}from"./arrow-up-down-C1oJAmrw.js";import{c as O,i as k,l as ne,n as A,s as j,t as M}from"./select-CmlY1M1a.js";import{a as re,n as N,r as P}from"./platform-targets-BIQ1lKOg.js";import{t as ie}from"./download-DmUZKo9N.js";import{i as F,n as I,t as L}from"./tooltip-D1ydB4g3.js";import{r as ae}from"./engine-store-DMULdR_V.js";import{n as oe}from"./auth-screen-backdrop-Cr8qBSXP.js";import{a as se,i as ce,n as le,o as ue,r as de,s as fe,t as pe}from"./dropdown-menu-CrPXVXpG.js";import{t as R}from"./label-CMBWxUhA.js";import{t as me}from"./get-error-message-Dk8elqEP.js";import{a as z,i as B,n as V,o as he,r as H,s as ge,t as U}from"./combobox-BCaV1Wbo.js";import{a as _e,i as ve,n as ye,o as be,r as xe,t as Se}from"./vendor-table-BAHQgdwg.js";var Ce=E(`arrow-down`,[[`path`,{d:`M12 5v14`,key:`s699le`}],[`path`,{d:`m19 12-7 7-7-7`,key:`1idqje`}]]),we=E(`arrow-up`,[[`path`,{d:`m5 12 7-7 7 7`,key:`hav0vg`}],[`path`,{d:`M12 19V5`,key:`x0mq9r`}]]),Te=E(`braces`,[[`path`,{d:`M8 3H7a2 2 0 0 0-2 2v5a2 2 0 0 1-2 2 2 2 0 0 1 2 2v5c0 1.1.9 2 2 2h1`,key:`ezmyqa`}],[`path`,{d:`M16 21h1a2 2 0 0 0 2-2v-5c0-1.1.9-2 2-2a2 2 0 0 1-2-2V5a2 2 0 0 0-2-2h-1`,key:`e1hn23`}]]),Ee=E(`chevron-left`,[[`path`,{d:`m15 18-6-6 6-6`,key:`1wnfg3`}]]),De=E(`database`,[[`ellipse`,{cx:`12`,cy:`5`,rx:`9`,ry:`3`,key:`msslwz`}],[`path`,{d:`M3 5V19A9 3 0 0 0 21 19V5`,key:`1wlel7`}],[`path`,{d:`M3 12A9 3 0 0 0 21 12`,key:`mv7ke4`}]]),Oe=E(`external-link`,[[`path`,{d:`M15 3h6v6`,key:`1q9fwt`}],[`path`,{d:`M10 14 21 3`,key:`gplh6r`}],[`path`,{d:`M18 13v6a2 2 0 0 1-2 2H5a2 2 0 0 1-2-2V8a2 2 0 0 1 2-2h6`,key:`a6xqqp`}]]),ke=E(`table-2`,[[`path`,{d:`M9 3H5a2 2 0 0 0-2 2v4m6-6h10a2 2 0 0 1 2 2v4M9 3v18m0 0h10a2 2 0 0 0 2-2V9M9 21H5a2 2 0 0 1-2-2V9m0 0h18`,key:`gugj83`}]]),W=e(t(),1),Ae={mqtt:`MQTT Client`,opcua:`OPC UA Client Advanced`,modbus:`Modbus TCP`},G={Boolean:`bool`,Int32:`int32`,UInt16:`uint16`,UInt32:`uint32`,Float:`float32`,Double:`float64`,String:`string`},K={float32:`float32`,int32:`int32`,uint32:`uint32`,uint16:`word`,boolean:`word`},je=`deviceId,deviceName,driverName,name,tagName,description,valueType,registerId,publishCoV,tagFormula,metaData,Retain,Qos,address,count,pollingInterval,endianness`;function Me(e,t,n){let r=[je];for(let i of n){let n=Ae[i]??i;for(let a of e){let e=a.protocols[i];e&&r.push(q(i,{deviceName:t,driverName:n,memberName:a.member,browsePath:a.browsePath,dataType:a.dataType,protocolData:e,unit:a.unit,euRange:a.euRange,model:a.model,instance:a.instance,access:a.access}))}}return`${r.join(`
|
|
2
2
|
`)}\n`}function q(e,t){switch(e){case`mqtt`:return J(t);case`opcua`:return Ne(t);case`modbus`:return Pe(t);default:throw Error(`Unsupported LE export protocol: "${e}"`)}}function J(e){let t=typeof e.protocolData?.topic==`string`?e.protocolData.topic:`${e.browsePath}/${e.memberName}`;return[``,Y(e.deviceName),Y(e.driverName),Y(t),Y(e.memberName),``,`string`,``,`false`,``,X(e),`Disable`,`0`,``,``,``,``].join(`,`)}function Ne(e){let t=typeof e.protocolData?.nodeId==`string`?e.protocolData.nodeId:`ns=1;s=${e.browsePath}/${e.memberName}`,n=G[e.dataType]??`string`;return[``,Y(e.deviceName),Y(e.driverName),Y(t),Y(e.memberName),``,n,``,`false`,``,X(e),``,``,``,``,``,``].join(`,`)}function Pe(e){let t=K[String(e.protocolData?.registerType??``)]??`float32`,n=e.protocolData?.address;return[``,Y(e.deviceName),Y(e.driverName),`H`,Y(e.memberName),``,t,``,`false`,``,X(e),``,``,typeof n==`number`?String(n):`0`,`1`,`1.0000000000`,`AB CD`].join(`,`)}function Y(e){return e.includes(`,`)||e.includes(`"`)||e.includes(`
|
|
3
3
|
`)?`"${e.replace(/"/g,`""`)}"`:e}function X(e){let t={uns_path:e.browsePath?`${e.browsePath}/${e.memberName}`:e.memberName,model:e.model,instance:e.instance,access:e.access};return e.unit!=null&&(t.unit=e.unit),e.euRange!=null&&(t.eu_range_min=String(e.euRange[0]),t.eu_range_max=String(e.euRange[1])),Y(JSON.stringify(t))}var Z=n(),Fe={mqtt:`MQTT`,opcua:`OPC UA`,modbus:`Modbus`},Ie=[{id:P.id,label:P.label}];function Le({open:e,onOpenChange:t,tags:n,totalTags:r,enabledProtocols:i,selectedInstance:a}){let[o,s]=(0,W.useState)(`litmus-edge`),[c,l]=(0,W.useState)(``),[u,d]=(0,W.useState)(``),f=(0,W.useRef)(null),y=(0,W.useRef)(!1);(0,W.useEffect)(()=>{e&&!y.current&&(s(P.id),l(a??``),d(i[0]??``),setTimeout(()=>f.current?.focus(),80)),y.current=e},[e,i,a]);let x=c.trim()!==``&&u!==``,S=o===P.id?x:!1,C=(0,W.useCallback)(()=>{if(o===P.id){let e=Me(n,c.trim(),[u]),r=new Blob([e],{type:`text/csv`}),i=URL.createObjectURL(r),a=document.createElement(`a`);a.href=i,a.download=`${c.trim()}-litmus-edge-tags.csv`,a.click(),URL.revokeObjectURL(i),t(!1)}},[o,c,n,u,t]),w=n.length<r,ee=(0,W.useMemo)(()=>[...Ie.map(e=>({value:e.id,label:e.label})),...N.map(e=>({value:e.id,label:e.label}))],[]),E=(0,W.useMemo)(()=>i.map(e=>({value:e,label:Fe[e]??e.toUpperCase()})),[i]);return(0,Z.jsx)(h,{open:e,onOpenChange:t,children:(0,Z.jsxs)(_,{className:`sm:max-w-lg`,children:[(0,Z.jsxs)(g,{children:[(0,Z.jsx)(v,{children:`Export for Platform`}),(0,Z.jsx)(m,{children:w?`Exporting ${n.length} of ${r} tags based on current table filters.`:`Exporting all ${n.length} tags. Use table filters to narrow scope.`})]}),(0,Z.jsxs)(`div`,{className:`flex flex-col gap-4 py-1`,children:[(0,Z.jsxs)(`div`,{className:`flex flex-col gap-1.5`,children:[(0,Z.jsx)(R,{className:`text-sm`,children:`Platform`}),(0,Z.jsxs)(M,{value:o,onValueChange:e=>e&&s(e),items:ee,children:[(0,Z.jsx)(j,{className:`w-full text-sm`,children:(0,Z.jsx)(O,{placeholder:`Select platform`})}),(0,Z.jsxs)(A,{children:[Ie.map(e=>(0,Z.jsx)(k,{value:e.id,children:e.label},e.id)),N.map(e=>(0,Z.jsx)(k,{value:e.id,disabled:!0,children:e.label},e.id))]})]})]}),o===P.id&&(0,Z.jsxs)(Z.Fragment,{children:[(0,Z.jsxs)(`div`,{className:`flex flex-col gap-1.5`,children:[(0,Z.jsxs)(R,{htmlFor:`device-name`,className:`text-sm`,children:[`Device name `,(0,Z.jsx)(`span`,{className:`text-destructive`,children:`*`})]}),(0,Z.jsx)(T,{id:`device-name`,ref:f,placeholder:`e.g. DTW-FAB-PLC`,value:c,onChange:e=>l(e.target.value),onKeyDown:e=>e.key===`Enter`&&S&&C(),className:`font-mono text-sm`})]}),(0,Z.jsxs)(`div`,{className:`flex flex-col gap-1.5`,children:[(0,Z.jsx)(R,{className:`text-sm`,children:`Protocol`}),(0,Z.jsxs)(M,{value:u||void 0,onValueChange:e=>e&&d(e),items:E,children:[(0,Z.jsx)(j,{className:`w-full text-sm`,children:(0,Z.jsx)(O,{placeholder:`Select a protocol`})}),(0,Z.jsx)(A,{children:i.map(e=>(0,Z.jsx)(k,{value:e,children:Fe[e]??e.toUpperCase()},e))})]})]})]})]}),(0,Z.jsxs)(p,{children:[(0,Z.jsx)(b,{variant:`outline`,size:`sm`,onClick:()=>t(!1),children:`Cancel`}),(0,Z.jsxs)(b,{size:`sm`,className:`gap-1.5`,disabled:!S,onClick:C,children:[(0,Z.jsx)(ie,{className:`size-3.5`}),`Download CSV`]})]})]})})}var Re=`border-border/70 bg-popover/98 font-body text-sm shadow-xl ring-1 ring-foreground/12 backdrop-blur-sm supports-backdrop-filter:bg-popover/90 p-1.5`,ze=`px-2 pb-1 font-heading text-[9px] font-semibold tracking-[0.14em] text-muted-foreground uppercase`,Be=`h-8 gap-1.5 border-border/80 bg-background/80 text-xs font-medium shadow-sm transition-colors hover:border-primary/35 hover:bg-accent/40`,Ve=`gap-2.5 rounded-[var(--miravo-radius-tight)] py-2 pl-2 pr-2 text-[13px] data-[highlighted]:bg-sidebar-accent data-[highlighted]:text-sidebar-accent-foreground`;function He({protocol:e,instance:t,model:n,member:r,enabledProtocols:i,hasFilters:a,memberSearchRef:o,onProtocolChange:s,onInstanceChange:c,onModelChange:l,onMemberChange:u,onClearFilters:d,onInstanceSearch:f,onModelSearch:p,filteredInstanceOptions:m,filteredModelOptions:h}){let g=(0,W.useMemo)(()=>[{value:`all`,label:`All protocols`},...i.map(e=>({value:e,label:e.toUpperCase()}))],[i]);return(0,Z.jsxs)(`div`,{className:`flex flex-wrap items-center gap-2`,children:[(0,Z.jsxs)(M,{value:e||`all`,onValueChange:e=>s(!e||e===`all`?``:e),items:g,children:[(0,Z.jsx)(j,{className:`h-8 w-[140px]`,"aria-label":`Protocol filter`,children:(0,Z.jsx)(O,{placeholder:`All protocols`})}),(0,Z.jsxs)(A,{alignItemWithTrigger:!1,align:`start`,children:[(0,Z.jsx)(k,{value:`all`,children:`All protocols`}),i.map(e=>(0,Z.jsx)(k,{value:e,children:e.toUpperCase()},e))]})]}),(0,Z.jsxs)(U,{value:t?{value:t,label:x(t)}:null,onValueChange:e=>c(e?.value??``),isItemEqualToValue:(e,t)=>e?.value===t?.value,onInputValueChange:f,children:[(0,Z.jsx)(H,{placeholder:`All instances`,className:`h-8 w-[200px]`,showClear:!!t}),(0,Z.jsx)(V,{children:(0,Z.jsxs)(z,{children:[m.map(([e,t])=>(0,Z.jsxs)(B,{value:{value:e,label:x(e)},children:[(0,Z.jsx)(`span`,{className:`min-w-0 flex-1 truncate`,children:x(e)}),(0,Z.jsxs)(`span`,{className:`shrink-0 tabular-nums text-muted-foreground`,children:[`(`,t,`)`]})]},e)),m.length===0&&(0,Z.jsx)(`p`,{className:`py-2 text-center text-xs text-muted-foreground`,children:`No instances found`})]})})]}),(0,Z.jsxs)(U,{value:n?{value:n,label:S(n)}:null,onValueChange:e=>l(e?.value??``),isItemEqualToValue:(e,t)=>e?.value===t?.value,onInputValueChange:p,children:[(0,Z.jsx)(H,{placeholder:`All models`,className:`h-8 w-[200px]`,showClear:!!n}),(0,Z.jsx)(V,{children:(0,Z.jsxs)(z,{children:[h.map(([e,t])=>(0,Z.jsxs)(B,{value:{value:e,label:S(e)},children:[(0,Z.jsx)(`span`,{className:`min-w-0 flex-1 truncate`,children:S(e)}),(0,Z.jsxs)(`span`,{className:`shrink-0 tabular-nums text-muted-foreground`,children:[`(`,t,`)`]})]},e)),h.length===0&&(0,Z.jsx)(`p`,{className:`py-2 text-center text-xs text-muted-foreground`,children:`No models found`})]})})]}),(0,Z.jsxs)(`div`,{className:`relative`,children:[(0,Z.jsx)(T,{ref:o,placeholder:`Search member…`,className:`h-8 w-[160px] pr-7`,value:r,onChange:e=>u(e.target.value)}),!r&&(0,Z.jsx)(`kbd`,{className:`pointer-events-none absolute top-1/2 right-2 -translate-y-1/2 rounded-[var(--miravo-radius-tight)] border border-border bg-muted px-1 font-mono text-[10px] text-muted-foreground`,children:`/`})]}),a&&(0,Z.jsxs)(b,{variant:`ghost`,size:`sm`,className:`h-8 gap-1 text-xs`,onClick:d,children:[(0,Z.jsx)(w,{className:`size-3`}),`Clear`]})]})}function Q({sorted:e}){return e===`asc`?(0,Z.jsx)(we,{className:`ml-1 inline size-3`}):e===`desc`?(0,Z.jsx)(Ce,{className:`ml-1 inline size-3`}):(0,Z.jsx)(D,{className:`ml-1 inline size-3 opacity-30`})}function Ue(e,t=1,n=2){let r=e.split(`/`);return r.length<=t+n+1?e:[...r.slice(0,t),`...`,...r.slice(-n)].join(`/`)}function We({label:e,value:t,collapsible:n}){let r=n?Ue(t):t;return(0,Z.jsxs)(`div`,{className:`min-w-0`,children:[(0,Z.jsx)(`p`,{className:`text-[10px] uppercase tracking-wider text-muted-foreground`,children:e}),(0,Z.jsx)(y,{value:t,label:`Copy ${e}`,tooltipSide:`top`,render:({icon:e})=>(0,Z.jsxs)(`button`,{type:`button`,className:`mt-0.5 flex items-start gap-1 font-mono text-xs hover:text-foreground`,children:[n?(0,Z.jsxs)(Z.Fragment,{children:[(0,Z.jsx)(`span`,{className:`break-all lg:hidden`,children:r}),(0,Z.jsx)(`span`,{className:`hidden break-all lg:inline`,children:t})]}):(0,Z.jsx)(`span`,{className:`break-all`,children:t}),(0,Z.jsx)(`span`,{className:`mt-0.5 shrink-0 text-muted-foreground`,children:e})]})})]})}function Ge({tag:e,enabledProtocols:t}){let n=`${e.browsePath}/${e.member}`,r=e.protocols.opcua,i=e.protocols.modbus,a=e.access===`readwrite`?`rw`:e.access;return(0,Z.jsxs)(`div`,{className:`flex flex-col gap-3 text-xs`,children:[(0,Z.jsxs)(`div`,{className:`flex flex-wrap gap-x-10 gap-y-2.5`,children:[(0,Z.jsx)(We,{label:`Topic / UNS`,value:n,collapsible:!0}),t.includes(`opcua`)&&typeof r?.nodeId==`string`&&(0,Z.jsx)(We,{label:`OPC UA NodeId`,value:r.nodeId,collapsible:!0}),t.includes(`modbus`)&&i?.address!=null&&(0,Z.jsxs)(`div`,{className:`min-w-0`,children:[(0,Z.jsx)(`p`,{className:`text-[10px] uppercase tracking-wider text-muted-foreground`,children:`Modbus`}),(0,Z.jsxs)(`p`,{className:`mt-0.5 font-mono`,children:[`addr=`,String(i.address),` regs=`,String(i.count),` `,String(i.registerType)]})]})]}),(0,Z.jsxs)(`div`,{className:`flex flex-wrap items-center gap-x-4 gap-y-1 text-muted-foreground`,children:[(0,Z.jsxs)(L,{children:[(0,Z.jsx)(F,{className:`font-mono`,render:(0,Z.jsx)(`span`,{}),children:e.dataType}),(0,Z.jsx)(I,{side:`top`,children:`Data type`})]}),e.unit&&(0,Z.jsxs)(L,{children:[(0,Z.jsx)(F,{className:`font-mono`,render:(0,Z.jsx)(`span`,{}),children:e.unit}),(0,Z.jsx)(I,{side:`top`,children:`Unit`})]}),(0,Z.jsxs)(L,{children:[(0,Z.jsx)(F,{className:`font-mono`,render:(0,Z.jsx)(`span`,{}),children:a}),(0,Z.jsx)(I,{side:`top`,children:`Access: r / w / rw`})]}),e.euRange&&(0,Z.jsxs)(L,{children:[(0,Z.jsxs)(F,{className:`font-mono`,render:(0,Z.jsx)(`span`,{}),children:[`[`,e.euRange[0],`, `,e.euRange[1],`]`]}),(0,Z.jsx)(I,{side:`top`,children:`EU range (min, max)`})]}),(0,Z.jsxs)(L,{children:[(0,Z.jsxs)(F,{render:(0,Z.jsx)(f,{to:`/instance/${e.instance}`,className:`inline-flex items-center gap-1 text-primary underline-offset-4 hover:underline`,"aria-label":`Open instance`}),children:[`View instance`,(0,Z.jsx)(Oe,{className:`size-3`})]}),(0,Z.jsx)(I,{side:`top`,children:`Open instance`})]})]})]})}var Ke=[{id:`expand`,meta:{cellClass:`!pl-2 !pr-0 w-0`},header:()=>(0,Z.jsx)(`span`,{className:`sr-only`,children:`Expand row`}),enableSorting:!1,cell:({row:e})=>(0,Z.jsx)(`button`,{type:`button`,className:`inline-flex size-5 items-center justify-center rounded-[var(--miravo-radius-tight)] text-muted-foreground hover:text-foreground`,"aria-label":e.getIsExpanded()?`Collapse row`:`Expand row`,"aria-expanded":e.getIsExpanded(),onClick:t=>{t.stopPropagation(),e.toggleExpanded()},children:(0,Z.jsx)(ne,{className:`size-3.5 transition-transform ${e.getIsExpanded()?`rotate-0`:`-rotate-90`}`})})},{accessorKey:`instance`,header:({column:e})=>(0,Z.jsxs)(`button`,{type:`button`,className:`inline-flex items-center`,onClick:e.getToggleSortingHandler(),children:[`Instance`,(0,Z.jsx)(Q,{sorted:e.getIsSorted()})]}),cell:({getValue:e})=>(0,Z.jsx)(`span`,{className:`block max-w-[18rem] truncate font-mono text-xs`,title:e(),children:e()})},{accessorKey:`member`,header:({column:e})=>(0,Z.jsxs)(`button`,{type:`button`,className:`inline-flex items-center`,onClick:e.getToggleSortingHandler(),children:[`Member`,(0,Z.jsx)(Q,{sorted:e.getIsSorted()})]}),cell:({getValue:e})=>(0,Z.jsx)(`span`,{className:`block max-w-[20rem] truncate font-mono text-xs`,title:e(),children:e()})},{accessorKey:`model`,header:({column:e})=>(0,Z.jsxs)(`button`,{type:`button`,className:`inline-flex items-center`,onClick:e.getToggleSortingHandler(),children:[`Model`,(0,Z.jsx)(Q,{sorted:e.getIsSorted()})]}),cell:({getValue:e})=>(0,Z.jsx)(`span`,{className:`block max-w-[18rem] truncate text-xs`,title:e(),children:e()})},{accessorKey:`dataType`,meta:{hideClass:`hidden lg:table-cell`},header:({column:e})=>(0,Z.jsxs)(`button`,{type:`button`,className:`inline-flex items-center`,onClick:e.getToggleSortingHandler(),children:[`Type`,(0,Z.jsx)(Q,{sorted:e.getIsSorted()})]}),cell:({getValue:e})=>(0,Z.jsx)(`span`,{className:`font-mono text-xs`,children:e()})},{accessorKey:`unit`,meta:{hideClass:`hidden lg:table-cell`},header:`Unit`,enableSorting:!1,cell:({getValue:e})=>(0,Z.jsx)(`span`,{className:`text-xs text-muted-foreground`,children:e()??`—`})},{accessorKey:`access`,meta:{hideClass:`hidden lg:table-cell`},header:`Access`,enableSorting:!1,cell:({getValue:e})=>{let t=e();return(0,Z.jsx)(`span`,{className:`font-mono text-xs`,children:t===`readwrite`?`rw`:t})}}];function qe(e,t){let n=new Blob([e],{type:`text/csv`}),r=URL.createObjectURL(n),i=document.createElement(`a`);i.href=r,i.download=t,i.click(),URL.revokeObjectURL(r)}var Je=[10,15,25,50,100],Ye=15,Xe=100;function Ze(e){return Je.includes(e)?e:Ye}function Qe(e){return/[",\r\n]/.test(e)?`"${e.replaceAll(`"`,`""`)}"`:e}function $(){let[e,t]=(0,W.useState)(!1),n=(0,W.useRef)(null);(0,W.useEffect)(()=>{let e=e=>{if(e.key!==`/`||e.metaKey||e.ctrlKey||e.altKey)return;let t=e.target.tagName;t===`INPUT`||t===`TEXTAREA`||t===`SELECT`||(e.preventDefault(),n.current?.focus())};return window.addEventListener(`keydown`,e),()=>window.removeEventListener(`keydown`,e)},[]);let[p,m]=l(`protocol`,u.withDefault(``)),[h,g]=l(`instance`,u.withDefault(``)),[_,v]=l(`model`,u.withDefault(``)),[y,x]=l(`member`,u.withDefault(``)),[S,w]=l(`perPage`,d.withDefault(Ye)),T=Ze(S),E=ae(e=>e.instanceCount),D=s({queryKey:i.tags.manifest(E),queryFn:()=>o(`/manifest`,r.manifest),placeholderData:a}),N=D.data??null,P=D.isError,F=D.isPending&&!N&&!P,I=me(D.error,`Failed to fetch manifest.`),L=N?.tags??[],R=N?.summary?.enabledProtocols??[],z=(0,W.useDeferredValue)(y),B=(0,W.useMemo)(()=>L.filter(e=>e.kind===`variable`),[L]),V=(0,W.useMemo)(()=>{let e=new Map;for(let t of B)e.set(t.instance,(e.get(t.instance)??0)+1);return[...e.entries()].sort((e,t)=>e[0].localeCompare(t[0]))},[B]),H=(0,W.useMemo)(()=>{let e=new Map;for(let t of B)e.set(t.model,(e.get(t.model)??0)+1);return[...e.entries()].sort((e,t)=>e[0].localeCompare(t[0]))},[B]),U=(0,W.useMemo)(()=>{let e=z.trim().toLowerCase();if(!p&&!h&&!_&&!e)return B;let t=[];for(let n of B)p&&n.protocols[p]==null||h&&n.instance!==h||_&&n.model!==_||e&&!n.member.toLowerCase().includes(e)||t.push(n);return t},[B,p,h,_,z]),[Ce,we]=(0,W.useState)([]),[Oe,Ae]=(0,W.useState)({}),[G,K]=(0,W.useState)(0),je=p!==``||h!==``||_!==``||y!==``,Me=(0,W.useCallback)(()=>{m(``),g(``),v(``),x(``),K(0)},[m,g,v,x]),q=ye({data:U,columns:Ke,getCoreRowModel:xe(),getSortedRowModel:be(),getExpandedRowModel:ve(),getRowCanExpand:()=>!0,getPaginationRowModel:_e(),onSortingChange:we,onExpandedChange:Ae,onPaginationChange:e=>{let t=typeof e==`function`?e({pageIndex:G,pageSize:T}):e;K(t.pageIndex),w(t.pageSize)},state:{sorting:Ce,expanded:Oe,pagination:{pageIndex:G,pageSize:T}}}),J=Math.ceil(U.length/T);(0,W.useEffect)(()=>{S!==T&&w(T)},[T,S,w]),(0,W.useEffect)(()=>{J>0&&G>=J&&K(J-1)},[J,G]);let Ne=(0,W.useCallback)(e=>{K(0),w(e)},[w]),Pe=(0,W.useCallback)(e=>{K(0),m(e)},[m]),Y=(0,W.useCallback)(e=>{K(0),g(e)},[g]),X=(0,W.useCallback)(e=>{K(0),v(e)},[v]),Fe=(0,W.useCallback)(e=>{K(0),x(e)},[x]),[Ie,Q]=(0,W.useState)(``),[Ue,We]=(0,W.useState)(``),$=(0,W.useDeferredValue)(Ie),$e=(0,W.useDeferredValue)(Ue),et=(0,W.useMemo)(()=>($?V.filter(([e])=>C(e,$)):V).slice(0,Xe),[V,$]),tt=(0,W.useMemo)(()=>($e?H.filter(([e])=>ee(e,$e)):H).slice(0,Xe),[H,$e]),nt=q.getRowModel().rows,rt=nt.length,it=rt===0||U.length===0?0:G*T+1,at=rt===0||U.length===0?0:G*T+rt,ot=J,st=U.length===0||ot===0?0:G+1,ct=(0,W.useCallback)(()=>{let e=p?[p]:R,t=[`instance`,`member`,`model`,`dataType`,`unit`,`access`,`browsePath`,...e.includes(`mqtt`)?[`mqtt_topic`]:[],...e.includes(`opcua`)?[`opcua_nodeId`]:[],...e.includes(`modbus`)?[`modbus_address`,`modbus_count`,`modbus_encoding`]:[]],n=U.map(t=>{let n=t.protocols.mqtt,r=t.protocols.opcua,i=t.protocols.modbus;return[t.instance,t.member,t.model,t.dataType,t.unit??``,t.access,t.browsePath,...e.includes(`mqtt`)?[String(n?.topic??``)]:[],...e.includes(`opcua`)?[String(r?.nodeId??``)]:[],...e.includes(`modbus`)?[String(i?.address??``),String(i?.count??``),String(i?.registerType??``)]:[]]});qe([t.map(Qe).join(`,`),...n.map(e=>e.map(Qe).join(`,`))].join(`
|
|
4
4
|
`),`miravo-tags.csv`)},[U,p,R]);return P&&!N?(0,Z.jsx)(oe,{className:`min-h-full`,children:(0,Z.jsx)(`div`,{className:`flex min-h-[40vh] flex-col items-center justify-center p-6 sm:p-12`,children:(0,Z.jsx)(`div`,{className:`w-full max-w-md`,children:(0,Z.jsx)(c,{message:I,onRetry:()=>void D.refetch(),isRetrying:D.isFetching})})})}):(0,Z.jsxs)(`div`,{className:`mx-auto flex w-full max-w-screen-2xl flex-col gap-5 p-4 sm:gap-6 sm:p-6`,children:[P&&N?(0,Z.jsx)(c,{message:`${I} Showing cached tags.`,onRetry:()=>void D.refetch(),isRetrying:D.isFetching}):null,(0,Z.jsxs)(`div`,{className:`flex items-center justify-between`,children:[(0,Z.jsxs)(`div`,{className:`flex flex-col gap-1`,children:[(0,Z.jsx)(`h1`,{className:`font-heading text-2xl font-semibold tracking-tight`,children:`Tag Explorer`}),(0,Z.jsx)(`p`,{className:`text-sm text-muted-foreground`,children:F?`Loading tag manifest...`:`${N?.summary?.totalInstances??0} instances · ${R.length} protocols`})]}),(0,Z.jsxs)(pe,{children:[(0,Z.jsxs)(fe,{render:(0,Z.jsx)(b,{variant:`outline`,size:`sm`,className:te(Be,`px-3`)}),children:[(0,Z.jsx)(ie,{className:`size-3.5 opacity-90`,"aria-hidden":!0}),`Export`,(0,Z.jsx)(ne,{className:`size-3 opacity-60`,"aria-hidden":!0})]}),(0,Z.jsx)(le,{align:`end`,sideOffset:6,className:te(`min-w-[13.5rem]`,Re),children:(0,Z.jsxs)(de,{children:[(0,Z.jsx)(se,{className:ze,children:`Export`}),(0,Z.jsx)(ue,{className:`bg-border/60`}),(0,Z.jsxs)(ce,{onClick:ct,className:Ve,children:[(0,Z.jsx)(ke,{className:`size-3.5 shrink-0 text-primary`,"aria-hidden":!0}),`Download CSV`]}),(0,Z.jsxs)(ce,{onClick:()=>t(!0),className:Ve,children:[(0,Z.jsx)(Te,{className:`size-3.5 shrink-0 text-primary`,"aria-hidden":!0}),`Export for Platform…`]})]})})]})]}),(0,Z.jsx)(He,{protocol:p,instance:h,model:_,member:y,enabledProtocols:R,hasFilters:je,memberSearchRef:n,onProtocolChange:Pe,onInstanceChange:Y,onModelChange:X,onMemberChange:Fe,onClearFilters:Me,onInstanceSearch:Q,onModelSearch:We,filteredInstanceOptions:et,filteredModelOptions:tt}),U.length!==B.length&&B.length>0&&(0,Z.jsxs)(`p`,{className:`text-xs text-muted-foreground`,children:[`Showing`,` `,(0,Z.jsx)(`span`,{className:`font-medium tabular-nums text-foreground`,children:U.length}),` of`,` `,(0,Z.jsx)(`span`,{className:`tabular-nums`,children:B.length}),` tags`]}),(0,Z.jsx)(he,{className:`min-w-0 py-0`,children:(0,Z.jsx)(ge,{className:`p-0`,children:(0,Z.jsx)(`div`,{className:`min-w-0 overflow-auto`,children:(0,Z.jsxs)(`table`,{className:`w-full caption-bottom text-sm`,children:[(0,Z.jsx)(`thead`,{className:`sticky top-0 z-10 border-b bg-background [&_tr]:border-b`,children:q.getHeaderGroups().map(e=>(0,Z.jsx)(`tr`,{className:`border-b transition-colors hover:bg-sidebar-accent hover:text-sidebar-accent-foreground`,children:e.headers.map(e=>{let t=e.column.columnDef.meta;return(0,Z.jsx)(`th`,{className:`h-10 whitespace-nowrap px-1.5 text-left text-xs font-medium text-muted-foreground sm:px-4 ${t?.hideClass??``} ${t?.cellClass??``}`,children:e.isPlaceholder?null:Se(e.column.columnDef.header,e.getContext())},e.id)})},e.id))}),(0,Z.jsx)(`tbody`,{className:`[&_tr:last-child]:border-0`,children:F?null:nt.length>0?nt.map(e=>{let t=e.getIsExpanded(),n=e.getVisibleCells();return(0,Z.jsxs)(W.Fragment,{children:[(0,Z.jsx)(`tr`,{"aria-expanded":t,tabIndex:0,className:`cursor-pointer border-b transition-colors hover:bg-sidebar-accent hover:text-sidebar-accent-foreground focus-visible:bg-sidebar-accent focus-visible:outline-none`,onClick:()=>e.toggleExpanded(),onKeyDown:t=>{t.key!==`Enter`&&t.key!==` `||(t.preventDefault(),e.toggleExpanded())},children:n.map(e=>{let t=e.column.columnDef.meta;return(0,Z.jsx)(`td`,{className:`whitespace-nowrap px-1.5 py-1.5 text-left sm:px-4 ${t?.hideClass??``} ${t?.cellClass??``}`,children:Se(e.column.columnDef.cell,e.getContext())},e.id)})}),t&&(0,Z.jsx)(`tr`,{children:(0,Z.jsx)(`td`,{colSpan:n.length,className:`p-0`,children:(0,Z.jsx)(`div`,{className:`border-b`,children:(0,Z.jsx)(`div`,{className:`px-1.5 py-3 pl-6 sm:px-4 sm:pl-10`,children:(0,Z.jsx)(Ge,{tag:e.original,enabledProtocols:R})})})})})]},e.id)}):(0,Z.jsx)(`tr`,{children:(0,Z.jsx)(`td`,{colSpan:Ke.length,className:`h-32 px-2 text-center sm:px-4`,children:B.length===0?(0,Z.jsxs)(`div`,{className:`flex flex-col items-center gap-2`,children:[(0,Z.jsx)(De,{className:`size-8 text-muted-foreground`}),(0,Z.jsx)(`p`,{className:`text-sm text-muted-foreground`,children:`No tags available`}),(0,Z.jsx)(f,{to:`/catalog`,className:`text-xs text-primary underline-offset-4 hover:underline`,children:`Start an environment from the Catalog to generate tags`})]}):(0,Z.jsxs)(`p`,{className:`text-sm text-muted-foreground`,children:[`No matching tags.`,` `,(0,Z.jsx)(`span`,{className:`text-xs`,children:`Try adjusting your filters.`})]})})})})]})})})}),(0,Z.jsx)(`div`,{className:`px-3 py-2 text-xs text-muted-foreground`,children:(0,Z.jsxs)(`div`,{className:`flex flex-col gap-2 sm:flex-row sm:items-center sm:justify-between sm:gap-4`,children:[(0,Z.jsxs)(`div`,{className:`flex items-center justify-between gap-3 sm:justify-start sm:gap-5`,children:[(0,Z.jsxs)(`p`,{className:`min-w-0 leading-tight`,children:[(0,Z.jsx)(`span`,{className:`font-medium tabular-nums text-foreground`,children:it===0?`0`:`${it}\u2013${at}`}),` `,(0,Z.jsxs)(`span`,{className:`text-muted-foreground`,children:[`of `,U.length,` tags`]})]}),(0,Z.jsxs)(`div`,{className:`flex shrink-0 items-center gap-1.5 whitespace-nowrap`,children:[(0,Z.jsxs)(M,{value:String(T),onValueChange:e=>e&&Ne(Number(e)),children:[(0,Z.jsx)(j,{className:`h-8 w-[4.25rem]`,"aria-label":`Rows per page`,children:(0,Z.jsx)(O,{})}),(0,Z.jsx)(A,{children:Je.map(e=>(0,Z.jsx)(k,{value:String(e),children:e},e))})]}),(0,Z.jsx)(`span`,{className:`hidden text-muted-foreground sm:inline`,children:`per page`})]})]}),(0,Z.jsxs)(`nav`,{className:`flex items-center justify-center gap-2 border-border/60 border-t pt-2 sm:justify-end sm:border-0 sm:pt-0`,"aria-label":`Table pages`,children:[(0,Z.jsx)(b,{variant:`outline`,size:`sm`,className:`h-8 w-8 shrink-0 p-0`,disabled:!q.getCanPreviousPage(),onClick:()=>q.previousPage(),"aria-label":`Previous page`,children:(0,Z.jsx)(Ee,{className:`size-3.5`})}),(0,Z.jsxs)(`span`,{className:`min-w-[5ch] text-center text-sm font-medium tabular-nums whitespace-nowrap text-foreground`,children:[st,` / `,ot]}),(0,Z.jsx)(b,{variant:`outline`,size:`sm`,className:`h-8 w-8 shrink-0 p-0`,disabled:!q.getCanNextPage(),onClick:()=>q.nextPage(),"aria-label":`Next page`,children:(0,Z.jsx)(re,{className:`size-3.5`})})]})]})}),(0,Z.jsx)(Le,{open:e,onOpenChange:t,tags:U,totalTags:L.length,enabledProtocols:R,selectedInstance:h||void 0})]})}export{$ as t};
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
import{t as e}from"./tags-BI93Dvh2.js";export{e as TagsPage};
|
package/console-dist/assets/{transition-nav-link-nVD3H66a.js → transition-nav-link-Ct6VIy2S.js}
RENAMED
|
@@ -1 +1 @@
|
|
|
1
|
-
import{at as e}from"./vendor-ui-CWUk2ulb.js";import{r as t}from"./chunk-OE4NN4TA-DBWZidbW.js";import{t as n}from"./route-preload-
|
|
1
|
+
import{at as e}from"./vendor-ui-CWUk2ulb.js";import{r as t}from"./chunk-OE4NN4TA-DBWZidbW.js";import{t as n}from"./route-preload-DQgHHtBj.js";import{t as r}from"./use-transition-navigate-jTHkLHMS.js";var i=e();function a(e){return e.button===0&&!e.metaKey&&!e.altKey&&!e.ctrlKey&&!e.shiftKey}function o({to:e,transitionType:o,preloadOnIntent:s=!0,onClick:c,...l}){let u=r();return(0,i.jsx)(t,{...l,to:e,onMouseEnter:t=>{l.onMouseEnter?.(t),s&&n(e)},onFocus:t=>{l.onFocus?.(t),s&&n(e)},onClick:t=>{c?.(t),!t.defaultPrevented&&(l.reloadDocument||l.target&&l.target!==`_self`||l.download||a(t)&&(t.preventDefault(),u(e,{transitionType:o})))}})}export{o as t};
|
|
@@ -1 +1 @@
|
|
|
1
|
-
import{a as e}from"./rolldown-runtime-COnpUsM8.js";import{c as t}from"./vendor-charts-95ykyDlI.js";import{C as n,c as r,d as i,n as a,x as o}from"./api-
|
|
1
|
+
import{a as e}from"./rolldown-runtime-COnpUsM8.js";import{c as t}from"./vendor-charts-95ykyDlI.js";import{C as n,c as r,d as i,n as a,x as o}from"./api-D8oAzcVE.js";import{l as s}from"./copy-button-BvU3RDZa.js";import{n as c}from"./utils-XFKvwlFT.js";import{r as l}from"./engine-store-DMULdR_V.js";import{n as u,r as d,t as f}from"./runtime-link-PMxeHxd6.js";var p=c(`play`,[[`path`,{d:`M5 5a2 2 0 0 1 3.008-1.728l11.997 6.998a2 2 0 0 1 .003 3.458l-12 7A2 2 0 0 1 5 19z`,key:`10ikf1`}]]),m=`group relative border border-solid border-border transition-colors hover:border-muted-foreground/25`,h=`group relative border border-solid border-border`,g=`blueprint-card ${m} overflow-hidden rounded-[var(--miravo-radius-stadium-sm)]`,_=`${h} w-full min-w-0 overflow-hidden rounded-[var(--miravo-radius-stadium-sm)] bg-transparent`,v=`${h} w-full min-w-0 overflow-hidden rounded-[var(--miravo-radius-stadium-sm)] bg-transparent`,y=`blueprint-card catalog-card-frame group relative border border-solid overflow-hidden rounded-[var(--miravo-radius-stadium-sm)]`,b=y,x=`border-border bg-muted/40 text-primary shadow-none hover:border-muted-foreground/30 hover:bg-muted/60 hover:text-primary focus-visible:border-ring border-border bg-muted/30 hover:border-muted-foreground/35 hover:bg-muted/45 [&_svg]:text-primary`,S=e(t(),1),C=new Set([`spawn`,`removeInstance`,`loadTemplate`,`unloadTemplateRun`,`resetEnvironment`,`enableAdapter`,`disableAdapter`]);function w(e){if(e instanceof f){s.error(`Command not sent`,{description:e.detail});return}if(e instanceof a){s.error(e.result.message,{description:e.result.error});return}if(n.is(e)){s.error(e.message,{description:e.hint});return}if(e instanceof TypeError){if(typeof navigator<`u`&&navigator.onLine===!1){s.error(`Command not sent`,{description:`This browser is offline — reconnect to the network and try again.`});return}let{connectionState:e}=l.getState(),t=d(e);if(t){s.error(`Command not sent`,{description:t});return}s.error(`Command failed`,{description:`Could not reach the Miravo server — it may have stopped or restarted.`});return}s.error(`Command failed`,{description:e instanceof Error?e.message:`Unknown error.`})}async function T(){try{let e=await r();if(o.setQueryData([`bootstrap`],e),e.authenticated){let t=l.getState();e.runtime.revision>=t.lastRevision&&t.replaceRuntime(e.runtime,{allowSameRevision:!0})}else l.getState().markUnauthenticated()}catch{}finally{o.invalidateQueries({queryKey:[`bootstrap`]})}}function E(){let[e,t]=(0,S.useState)(!1);return{mutate:(0,S.useCallback)(e=>{try{u(l.getState().connectionState)}catch(e){w(e);return}t(!0),i(e).then(t=>{if(s.success(t.message),C.has(e.type))return T()}).catch(w).finally(()=>{t(!1)})},[]),mutateAsync:(0,S.useCallback)(async e=>{try{u(l.getState().connectionState)}catch(e){throw w(e),e}t(!0);try{let t=await i(e);return s.success(t.message),C.has(e.type)&&await T(),t}catch(e){throw w(e),e}finally{t(!1)}},[]),isPending:e}}export{v as a,p as c,y as i,x as n,_ as o,g as r,b as s,E as t};
|