llm-simple-router 0.3.5 → 0.3.7
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/README.md +11 -0
- package/dist/admin/services.d.ts +7 -0
- package/dist/admin/services.js +63 -0
- package/dist/cli.js +0 -0
- package/dist/index.js +0 -0
- package/frontend-dist/assets/{CardContent-B40ArIqh.js → CardContent-CucI6u41.js} +1 -1
- package/frontend-dist/assets/{CardHeader-BjkSQf27.js → CardHeader-d-DYsWxe.js} +1 -1
- package/frontend-dist/assets/{CardTitle-DjG2kSF3.js → CardTitle-CIDEQkWB.js} +1 -1
- package/frontend-dist/assets/{Checkbox-Cw0rq2D9.js → Checkbox-CybCw3zS.js} +1 -1
- package/frontend-dist/assets/{CollapsibleTrigger-BvYqNbGA.js → CollapsibleTrigger-BFNhb19_.js} +1 -1
- package/frontend-dist/assets/{Collection-CQ4pV54w.js → Collection-DUBb4r6h.js} +1 -1
- package/frontend-dist/assets/{Dashboard-CsOTBnSa.js → Dashboard-DLB6iqH1.js} +1 -1
- package/frontend-dist/assets/{DialogTitle-PS2W-IfG.js → DialogTitle-Dq-5o7nJ.js} +1 -1
- package/frontend-dist/assets/{Input-toxjzsir.js → Input-HN3Il0-c.js} +1 -1
- package/frontend-dist/assets/{Label-fZNDEQjf.js → Label-CXAeFn-r.js} +1 -1
- package/frontend-dist/assets/{LogResponseViewer-B9kSncNr.js → LogResponseViewer-CyBzv02a.js} +1 -1
- package/frontend-dist/assets/{Login-DRm9DHq1.js → Login-Br3qsdxf.js} +1 -1
- package/frontend-dist/assets/{Logs-NHxebwmP.js → Logs-Cu_IftdS.js} +1 -1
- package/frontend-dist/assets/ModelMappings-DXC0sNH5.js +1 -0
- package/frontend-dist/assets/{Monitor-B5TYWb2n.js → Monitor-CKlid1sC.js} +1 -1
- package/frontend-dist/assets/{PopperContent-BvKlcZEO.js → PopperContent-CnZejY31.js} +1 -1
- package/frontend-dist/assets/Providers-8CHhW4uH.js +1 -0
- package/frontend-dist/assets/{ProxyEnhancement-B2OliarO.js → ProxyEnhancement-CkYeXwgH.js} +1 -1
- package/frontend-dist/assets/RetryRules-Csb7u9W4.js +1 -0
- package/frontend-dist/assets/RouterKeys-C6YIufmj.js +1 -0
- package/frontend-dist/assets/{RovingFocusItem-DHfpgdA0.js → RovingFocusItem-B7ZIkplZ.js} +1 -1
- package/frontend-dist/assets/{SelectValue-CFf_mD9E.js → SelectValue-B32pgmTJ.js} +1 -1
- package/frontend-dist/assets/{Setup-BMjCT-Tl.js → Setup-Df9IQo2x.js} +1 -1
- package/frontend-dist/assets/{Switch-BGCQ7puL.js → Switch-CLeo7H6d.js} +1 -1
- package/frontend-dist/assets/{TableHeader-DAOs6nSA.js → TableHeader-BpscAtT3.js} +1 -1
- package/frontend-dist/assets/{TabsTrigger-DBAYM66g.js → TabsTrigger-DErAbTuM.js} +1 -1
- package/frontend-dist/assets/{VisuallyHidden-Dh7svQf3.js → VisuallyHidden-CJBR3YB3.js} +1 -1
- package/frontend-dist/assets/{VisuallyHiddenInput-BOaRSEmd.js → VisuallyHiddenInput-Cy0VuE1l.js} +1 -1
- package/frontend-dist/assets/{alert-dialog-CUNSZqpB.js → alert-dialog-BAR1JRmT.js} +1 -1
- package/frontend-dist/assets/{button-CfQs66fX.js → button-D54q76GQ.js} +1 -1
- package/frontend-dist/assets/{client-DvdghFBq.js → client-Mb8fy_bC.js} +2 -2
- package/frontend-dist/assets/{createLucideIcon-DCD7INQf.js → createLucideIcon-CCmQ9QKM.js} +1 -1
- package/frontend-dist/assets/{dialog-DQFRGKR6.js → dialog-DSH5k5Kj.js} +1 -1
- package/frontend-dist/assets/{index--5JhZIwi.js → index-BQBtSfem.js} +1 -1
- package/frontend-dist/assets/index-H-lnTkMr.css +1 -0
- package/frontend-dist/assets/{lib-BJNsNHLO.js → lib-BgOqOzXI.js} +1 -1
- package/frontend-dist/assets/{ohash.D__AXeF1-CNudYmrX.js → ohash.D__AXeF1-p4vp6Svt.js} +1 -1
- package/frontend-dist/assets/{useClipboard-aPMKfK25.js → useClipboard-DO-38TXr.js} +1 -1
- package/frontend-dist/assets/{useForwardExpose-u2vjohek.js → useForwardExpose-CzQFheaD.js} +1 -1
- package/frontend-dist/assets/useNonce-CU-NirfM.js +1 -0
- package/frontend-dist/assets/x-DEJ1xpi5.js +1 -0
- package/frontend-dist/index.html +7 -7
- package/package.json +1 -1
- package/frontend-dist/assets/ModelMappings-DV0RPnO2.js +0 -1
- package/frontend-dist/assets/Providers-D1Rauu-D.js +0 -1
- package/frontend-dist/assets/RetryRules-BWu2gicT.js +0 -1
- package/frontend-dist/assets/RouterKeys-BP6XJCVa.js +0 -1
- package/frontend-dist/assets/index-Bx15k8FA.css +0 -1
- package/frontend-dist/assets/useNonce-ClXGIm-8.js +0 -1
- package/frontend-dist/assets/x-ILQhskuj.js +0 -1
|
@@ -1 +1 @@
|
|
|
1
|
-
import{F as e,M as t,R as n,S as r,Y as i,_ as a,dt as o,k as s,mt as c,ot as l,v as u,x as d}from"./client-
|
|
1
|
+
import{F as e,M as t,R as n,S as r,Y as i,_ as a,dt as o,k as s,mt as c,ot as l,v as u,x as d}from"./client-Mb8fy_bC.js";import{i as f,p}from"./button-D54q76GQ.js";import{S as m,a as h,c as g,d as _,g as v,i as y,m as b,o as x,u as S,x as C}from"./Collection-DUBb4r6h.js";import{t as w}from"./useForwardExpose-CzQFheaD.js";var[T,E]=m(`DialogRoot`),D=r({inheritAttrs:!1,__name:`DialogRoot`,props:{open:{type:Boolean,required:!1,default:void 0},defaultOpen:{type:Boolean,required:!1,default:!1},modal:{type:Boolean,required:!1,default:!0}},emits:[`update:open`],setup(e,{emit:t}){let r=e,i=p(r,`open`,t,{defaultValue:r.defaultOpen,passive:r.open===void 0}),a=l(),s=l(),{modal:u}=o(r);return E({open:i,modal:u,openModal:()=>{i.value=!0},onOpenChange:e=>{i.value=e},onOpenToggle:()=>{i.value=!i.value},contentId:``,titleId:``,descriptionId:``,triggerElement:a,contentElement:s}),(e,t)=>n(e.$slots,`default`,{open:c(i),close:()=>i.value=!1})}}),O=r({__name:`DialogClose`,props:{asChild:{type:Boolean,required:!1},as:{type:null,required:!1,default:`button`}},setup(t){let r=t;w();let o=T();return(t,l)=>(e(),a(c(f),s(r,{type:t.as===`button`?`button`:void 0,onClick:l[0]||=e=>c(o).onOpenChange(!1)}),{default:i(()=>[n(t.$slots,`default`)]),_:3},16,[`type`]))}}),k=r({__name:`DialogContentImpl`,props:{forceMount:{type:Boolean,required:!1},trapFocus:{type:Boolean,required:!1},disableOutsidePointerEvents:{type:Boolean,required:!1},asChild:{type:Boolean,required:!1},as:{type:null,required:!1}},emits:[`escapeKeyDown`,`pointerDownOutside`,`focusOutside`,`interactOutside`,`openAutoFocus`,`closeAutoFocus`],setup(r,{emit:o}){let l=r,u=o,f=T(),{forwardRef:p,currentElement:m}=w();return f.titleId||=S(void 0,`reka-dialog-title`),f.descriptionId||=S(void 0,`reka-dialog-description`),t(()=>{f.contentElement=m,C()!==document.body&&(f.triggerElement.value=C())}),(t,r)=>(e(),a(c(h),{"as-child":``,loop:``,trapped:l.trapFocus,onMountAutoFocus:r[5]||=e=>u(`openAutoFocus`,e),onUnmountAutoFocus:r[6]||=e=>u(`closeAutoFocus`,e)},{default:i(()=>[d(c(x),s({id:c(f).contentId,ref:c(p),as:t.as,"as-child":t.asChild,"disable-outside-pointer-events":t.disableOutsidePointerEvents,role:`dialog`,"aria-describedby":c(f).descriptionId,"aria-labelledby":c(f).titleId,"data-state":c(y)(c(f).open.value)},t.$attrs,{onDismiss:r[0]||=e=>c(f).onOpenChange(!1),onEscapeKeyDown:r[1]||=e=>u(`escapeKeyDown`,e),onFocusOutside:r[2]||=e=>u(`focusOutside`,e),onInteractOutside:r[3]||=e=>u(`interactOutside`,e),onPointerDownOutside:r[4]||=e=>u(`pointerDownOutside`,e)}),{default:i(()=>[n(t.$slots,`default`)]),_:3},16,[`id`,`as`,`as-child`,`disable-outside-pointer-events`,`aria-describedby`,`aria-labelledby`,`data-state`])]),_:3},8,[`trapped`]))}}),A=r({__name:`DialogContentModal`,props:{forceMount:{type:Boolean,required:!1},trapFocus:{type:Boolean,required:!1},disableOutsidePointerEvents:{type:Boolean,required:!1},asChild:{type:Boolean,required:!1},as:{type:null,required:!1}},emits:[`escapeKeyDown`,`pointerDownOutside`,`focusOutside`,`interactOutside`,`openAutoFocus`,`closeAutoFocus`],setup(t,{emit:r}){let o=t,l=r,u=T(),d=b(l),{forwardRef:f,currentElement:p}=w();return _(p),(t,r)=>(e(),a(k,s({...o,...c(d)},{ref:c(f),"trap-focus":c(u).open.value,"disable-outside-pointer-events":!0,onCloseAutoFocus:r[0]||=e=>{e.defaultPrevented||(e.preventDefault(),c(u).triggerElement.value?.focus())},onPointerDownOutside:r[1]||=e=>{let t=e.detail.originalEvent,n=t.button===0&&t.ctrlKey===!0;(t.button===2||n)&&e.preventDefault()},onFocusOutside:r[2]||=e=>{e.preventDefault()}}),{default:i(()=>[n(t.$slots,`default`)]),_:3},16,[`trap-focus`]))}}),j=r({__name:`DialogContentNonModal`,props:{forceMount:{type:Boolean,required:!1},trapFocus:{type:Boolean,required:!1},disableOutsidePointerEvents:{type:Boolean,required:!1},asChild:{type:Boolean,required:!1},as:{type:null,required:!1}},emits:[`escapeKeyDown`,`pointerDownOutside`,`focusOutside`,`interactOutside`,`openAutoFocus`,`closeAutoFocus`],setup(t,{emit:r}){let o=t,u=b(r);w();let d=T(),f=l(!1),p=l(!1);return(t,r)=>(e(),a(k,s({...o,...c(u)},{"trap-focus":!1,"disable-outside-pointer-events":!1,onCloseAutoFocus:r[0]||=e=>{e.defaultPrevented||(f.value||c(d).triggerElement.value?.focus(),e.preventDefault()),f.value=!1,p.value=!1},onInteractOutside:r[1]||=e=>{e.defaultPrevented||(f.value=!0,e.detail.originalEvent.type===`pointerdown`&&(p.value=!0));let t=e.target;c(d).triggerElement.value?.contains(t)&&e.preventDefault(),e.detail.originalEvent.type===`focusin`&&p.value&&e.preventDefault()}}),{default:i(()=>[n(t.$slots,`default`)]),_:3},16))}}),M=r({__name:`DialogContent`,props:{forceMount:{type:Boolean,required:!1},disableOutsidePointerEvents:{type:Boolean,required:!1},asChild:{type:Boolean,required:!1},as:{type:null,required:!1}},emits:[`escapeKeyDown`,`pointerDownOutside`,`focusOutside`,`interactOutside`,`openAutoFocus`,`closeAutoFocus`],setup(t,{emit:r}){let o=t,l=r,u=T(),d=b(l),{forwardRef:f}=w();return(t,r)=>(e(),a(c(g),{present:t.forceMount||c(u).open.value},{default:i(()=>[c(u).modal.value?(e(),a(A,s({key:0,ref:c(f)},{...o,...c(d),...t.$attrs}),{default:i(()=>[n(t.$slots,`default`)]),_:3},16)):(e(),a(j,s({key:1,ref:c(f)},{...o,...c(d),...t.$attrs}),{default:i(()=>[n(t.$slots,`default`)]),_:3},16))]),_:3},8,[`present`]))}}),N=r({__name:`DialogDescription`,props:{asChild:{type:Boolean,required:!1},as:{type:null,required:!1,default:`p`}},setup(t){let r=t;w();let o=T();return(t,l)=>(e(),a(c(f),s(r,{id:c(o).descriptionId}),{default:i(()=>[n(t.$slots,`default`)]),_:3},16,[`id`]))}}),P=r({__name:`DialogOverlayImpl`,props:{asChild:{type:Boolean,required:!1},as:{type:null,required:!1}},setup(t){let r=T();return v(!0),w(),(t,o)=>(e(),a(c(f),{as:t.as,"as-child":t.asChild,"data-state":c(r).open.value?`open`:`closed`,style:{"pointer-events":`auto`}},{default:i(()=>[n(t.$slots,`default`)]),_:3},8,[`as`,`as-child`,`data-state`]))}}),F=r({__name:`DialogOverlay`,props:{forceMount:{type:Boolean,required:!1},asChild:{type:Boolean,required:!1},as:{type:null,required:!1}},setup(t){let r=T(),{forwardRef:o}=w();return(t,l)=>c(r)?.modal.value?(e(),a(c(g),{key:0,present:t.forceMount||c(r).open.value},{default:i(()=>[d(P,s(t.$attrs,{ref:c(o),as:t.as,"as-child":t.asChild}),{default:i(()=>[n(t.$slots,`default`)]),_:3},16,[`as`,`as-child`])]),_:3},8,[`present`])):u(`v-if`,!0)}}),I=r({__name:`DialogTitle`,props:{asChild:{type:Boolean,required:!1},as:{type:null,required:!1,default:`h2`}},setup(t){let r=t,o=T();return w(),(t,l)=>(e(),a(c(f),s(r,{id:c(o).titleId}),{default:i(()=>[n(t.$slots,`default`)]),_:3},16,[`id`]))}});export{O as a,M as i,F as n,D as o,N as r,I as t};
|
|
@@ -1 +1 @@
|
|
|
1
|
-
import{F as e,S as t,X as n,c as r,gt as i,mt as a,tt as o,y as s}from"./client-
|
|
1
|
+
import{F as e,S as t,X as n,c as r,gt as i,mt as a,tt as o,y as s}from"./client-Mb8fy_bC.js";import{p as c,r as l}from"./button-D54q76GQ.js";var u=t({__name:`Input`,props:{defaultValue:{},modelValue:{},class:{type:[Boolean,null,String,Object,Array]}},emits:[`update:modelValue`],setup(t,{emit:u}){let d=t,f=c(d,`modelValue`,u,{passive:!0,defaultValue:d.defaultValue});return(t,c)=>n((e(),s(`input`,{"onUpdate:modelValue":c[0]||=e=>o(f)?f.value=e:null,"data-slot":`input`,class:i(a(l)(`dark:bg-input/30 border-input focus-visible:border-ring focus-visible:ring-ring/50 aria-invalid:ring-destructive/20 dark:aria-invalid:ring-destructive/40 aria-invalid:border-destructive dark:aria-invalid:border-destructive/50 disabled:bg-input/50 dark:disabled:bg-input/80 h-8 rounded-lg border bg-transparent px-2.5 py-1 text-base transition-colors file:h-6 file:text-sm file:font-medium focus-visible:ring-3 aria-invalid:ring-3 md:text-sm w-full min-w-0 outline-none file:inline-flex file:border-0 file:bg-transparent file:text-foreground placeholder:text-muted-foreground disabled:pointer-events-none disabled:cursor-not-allowed disabled:opacity-50`,d.class))},null,2)),[[r,a(f)]])}});export{u as t};
|
|
@@ -1 +1 @@
|
|
|
1
|
-
import{F as e,R as t,S as n,Y as r,_ as i,k as a,mt as o}from"./client-
|
|
1
|
+
import{F as e,R as t,S as n,Y as r,_ as i,k as a,mt as o}from"./client-Mb8fy_bC.js";import{b as s,i as c,r as l}from"./button-D54q76GQ.js";import{t as u}from"./useForwardExpose-CzQFheaD.js";var d=n({__name:`Label`,props:{for:{type:String,required:!1},asChild:{type:Boolean,required:!1},as:{type:null,required:!1,default:`label`}},setup(n){let s=n;return u(),(n,l)=>(e(),i(o(c),a(s,{onMousedown:l[0]||=e=>{!e.defaultPrevented&&e.detail>1&&e.preventDefault()}}),{default:r(()=>[t(n.$slots,`default`)]),_:3},16))}}),f=n({__name:`Label`,props:{for:{},asChild:{type:Boolean},as:{},class:{type:[Boolean,null,String,Object,Array]}},setup(n){let c=n,u=s(c,`class`);return(n,s)=>(e(),i(o(d),a({"data-slot":`label`},o(u),{class:o(l)(`gap-2 text-sm leading-none font-medium group-data-[disabled=true]:opacity-50 peer-disabled:opacity-50 flex items-center select-none group-data-[disabled=true]:pointer-events-none peer-disabled:cursor-not-allowed`,c.class)}),{default:r(()=>[t(n.$slots,`default`)]),_:3},16,[`class`]))}});export{f as t};
|
package/frontend-dist/assets/{LogResponseViewer-B9kSncNr.js → LogResponseViewer-CyBzv02a.js}
RENAMED
|
@@ -1,3 +1,3 @@
|
|
|
1
|
-
import{F as e,L as t,S as n,Y as r,_ as i,b as a,f as o,g as s,gt as c,h as l,it as u,mt as d,ot as ee,v as f,x as p,y as m,yt as h}from"./client-
|
|
1
|
+
import{F as e,L as t,S as n,Y as r,_ as i,b as a,f as o,g as s,gt as c,h as l,it as u,mt as d,ot as ee,v as f,x as p,y as m,yt as h}from"./client-Mb8fy_bC.js";import{n as g,r as _}from"./button-D54q76GQ.js";import{n as v,r as y,t as b}from"./CollapsibleTrigger-BFNhb19_.js";import{i as te,n as ne,r as x,t as S}from"./TabsTrigger-DErAbTuM.js";import{r as C}from"./lib-BgOqOzXI.js";import{n as w,t as T}from"./CardContent-CucI6u41.js";import{t as re}from"./CardHeader-d-DYsWxe.js";import{a as ie,i as E,n as D,o as ae,r as O,t as oe}from"./TableHeader-BpscAtT3.js";import{t as se}from"./useClipboard-DO-38TXr.js";var k=n({__name:`Skeleton`,props:{class:{type:[Boolean,null,String,Object,Array]}},setup(t){let n=t;return(t,r)=>(e(),m(`div`,{"data-slot":`skeleton`,class:c(d(_)(`bg-muted rounded-md animate-pulse`,n.class))},null,2))}}),A={class:`relative`},j={class:`bg-background text-foreground rounded-md p-3 text-xs overflow-auto max-h-[40vh] whitespace-pre-wrap break-all border`},ce=n({__name:`JsonCopyBlock`,props:{content:{},hideCopyButton:{type:Boolean}},setup(t){let n=t,{copied:o,copy:c}=se();async function l(){await c(n.content)}return(n,c)=>(e(),m(`div`,A,[t.hideCopyButton?f(``,!0):(e(),i(d(g),{key:0,variant:`outline`,size:`sm`,class:`absolute top-2 right-2 h-7 text-xs`,onClick:l},{default:r(()=>[a(h(d(o)?`已复制`:`复制`),1)]),_:1})),s(`pre`,j,h(t.content),1)]))}}),M={class:`opacity-70`},N=n({__name:`StatPill`,props:{label:{},value:{},highlight:{type:Boolean}},setup(t){return(n,o)=>(e(),i(d(C),{variant:t.highlight?`default`:`secondary`,class:`font-mono text-sm px-3 py-1.5 rounded-md gap-1`},{default:r(()=>[s(`span`,M,h(t.label)+`:`,1),a(` `+h(t.value),1)]),_:1},8,[`variant`]))}}),P=n({__name:`TagPill`,props:{label:{}},setup(t){return(n,o)=>(e(),i(d(C),{variant:`outline`,class:`font-mono text-[10px] rounded-full px-2 py-0.5`},{default:r(()=>[a(h(t.label),1)]),_:1}))}}),F={system:`bg-muted text-muted-foreground`,user:`bg-info-light text-info-dark dark:text-info`,assistant:`bg-success-light text-success-dark dark:text-success`,tool:`bg-warning-light text-warning-dark dark:text-warning`},I={thinking:`bg-info-light text-info-dark dark:text-info`,tool_use:`bg-warning-light text-warning-dark dark:text-warning`,tool_result:`bg-success-light text-success-dark dark:text-success`,text:`bg-success-light text-success-dark dark:text-success`,error:`bg-danger-light text-danger-dark dark:text-danger`},L={thinking:`border-info`,tool_use:`border-warning`,tool_result:`border-success`,text:`border-success`,error:`border-danger`},R={"system-reminder":`bg-muted text-muted-foreground`,thinking:`bg-info-light text-info-dark dark:text-info`,"antml:function_calls":`bg-warning-light text-warning-dark dark:text-warning`,"antml:function_results":`bg-success-light text-success-dark dark:text-success`,tool_use:`bg-warning-light text-warning-dark dark:text-warning`,tool_result:`bg-success-light text-success-dark dark:text-success`,"env-info":`bg-info-light text-info-dark dark:text-info`,feedback:`bg-warning-light text-warning-dark dark:text-warning`,error:`bg-danger-light text-danger-dark dark:text-danger`,"local-command-caveat":`bg-muted text-muted-foreground`,"local-command-stdout":`bg-muted text-muted-foreground`,"command-name":`bg-info-light text-info-dark dark:text-info`,"command-message":`bg-info-light text-info-dark dark:text-info`,"command-args":`bg-info-light text-info-dark dark:text-info`},z=`bg-muted text-muted-foreground`,B=e=>F[e]??z,V=e=>I[e]??z,le=e=>L[e]??`border-muted`,H=e=>R[e]??z,U={class:`w-8 h-8 rounded-full bg-teal-600 text-white flex items-center justify-center text-xs font-bold`},W={class:`flex-1`},G={class:`text-sm font-medium text-teal-900 dark:text-teal-100`},K={key:0,class:`text-xs text-teal-700 dark:text-teal-300`},q={key:0,class:`text-right text-xs text-teal-700 dark:text-teal-300 space-y-0.5`},ue=n({__name:`InfoBanner`,props:{icon:{},title:{},subtitle:{},details:{}},setup(n){return(a,c)=>(e(),i(d(w),{class:`border-teal-200 dark:border-teal-800`},{default:r(()=>[p(d(T),{class:`p-3 flex items-center gap-3 bg-teal-50 dark:bg-teal-900`},{default:r(()=>[s(`div`,U,h(n.icon),1),s(`div`,W,[s(`div`,G,h(n.title),1),n.subtitle?(e(),m(`div`,K,h(n.subtitle),1)):f(``,!0)]),n.details?.length?(e(),m(`div`,q,[(e(!0),m(o,null,t(n.details,t=>(e(),m(`div`,{key:t},h(t),1))),128))])):f(``,!0)]),_:1})]),_:1}))}}),J=2,Y=/<([a-zA-Z][a-zA-Z0-9:_-]*)(?:\s[^>]*)?>([\s\S]*?)<\/\1>/g;function X(e){let t=new RegExp(Y.source,`g`),n=[],r=0,i;for(;(i=t.exec(e))!==null;){let a=e.slice(r,i.index).trim();a&&n.push({type:`text`,text:a}),n.push({type:i[1],text:i[2]}),r=t.lastIndex}let a=e.slice(r).trim();return a&&n.push({type:`text`,text:a}),n.length>0?n:[{type:`text`,text:e}]}function Z(e){return typeof e==`string`?X(e):Array.isArray(e)?e.flatMap(e=>{let t=e,n=String(t.type||`unknown`);if(n===`text`&&typeof t.text==`string`)return X(t.text);if(n===`image`)return[{type:`image`,text:``}];if(n===`tool_use`){let e=String(t.name||``);return[{type:`tool_use`,text:t.input?JSON.stringify(t.input,null,J):``,label:e||void 0}]}if(n===`tool_result`){let e=t.content,n=``;return typeof e==`string`?n=e:Array.isArray(e)&&(n=e.map(e=>typeof e.text==`string`?e.text:JSON.stringify(e)).join(`
|
|
2
2
|
`)),[{type:`tool_result`,text:n}]}return n===`thinking`?[{type:`thinking`,text:String(t.thinking||``)}]:[{type:n,text:typeof t.text==`string`?t.text:``}]}):[{type:`text`,text:String(e??``)}]}var de={key:0,class:`flex items-center justify-between py-2 border-b mb-2 sticky top-0 z-10 bg-background`},Q={key:0,class:`text-destructive text-sm`},fe={key:1,class:`text-xs text-muted-foreground break-all`},pe={class:`flex flex-wrap gap-2`},me={class:`rounded-md border overflow-hidden mt-1`},he={key:2,class:`space-y-2`},ge={key:0,class:`text-xs text-muted-foreground`},_e={key:0},ve={key:0,class:`text-sm`},ye={key:1,class:`text-sm whitespace-pre-wrap break-all`},be={key:1,class:`text-xs text-muted-foreground`},xe={class:`mt-1 whitespace-pre-wrap break-all text-[11px] bg-muted rounded-md p-2 border`},Se={key:2,class:`text-xs`},Ce={key:3},we={class:`flex flex-wrap gap-1`},Te={key:4},Ee={key:0},De={class:`mt-1 whitespace-pre-wrap break-all text-xs bg-muted rounded p-2 border`},Oe=8,ke=1024,Ae=n({__name:`LogRequestViewer`,props:{raw:{},apiType:{},showUrl:{type:Boolean},mode:{}},setup(n){let _=n,k=ee(!1),A=u({}),j=ee(!1),{copied:M,copy:F}=se(),I=l(()=>{try{return JSON.parse(_.raw)}catch{return{}}}),L=l(()=>{try{return JSON.parse(_.raw),!1}catch{return!0}});async function R(){await F(_.raw)}let z=l(()=>{let e=I.value.headers||{},t=new Set(Object.keys(e));return Object.entries(e).filter(([e])=>t.has(e)).map(([e,t])=>e.toLowerCase()===`authorization`?[e,`Bearer sk-****`]:[e,t])}),V=l(()=>{let e=I.value.body;if(typeof e==`string`)try{return JSON.parse(e)}catch{return{}}return e||{}}),le=l(()=>(I.value.headers?.[`user-agent`]||``).includes(`claude-cli`)),U=l(()=>{let e=(I.value.headers?.[`user-agent`]||``).match(/claude-cli\/[^\s]+\s+\(([^)]+)\)/);return e?e[1]:`external, cli`}),W=l(()=>{let e=V.value.thinking;return e&&typeof e.budget_tokens==`number`?e.budget_tokens:void 0}),G=l(()=>{let e=V.value.tools;return Array.isArray(e)?e.length:void 0}),K=l(()=>{let e=[];return W.value!=null&&e.push(`thinking: ${W.value} tokens`),G.value!=null&&e.push(`tools: ${G.value} 个`),e}),q=l(()=>(V.value.messages||[]).map(e=>{let t=Z(e.content),n={};for(let e of t)e.type!==`text`&&e.text&&(n[e.type]=(n[e.type]||0)+1);let r=new Set(Object.keys(n)),i=Object.entries(n).filter(([e])=>r.has(e)).map(([e,t])=>`${e}${t>1?` x${t}`:``}`).join(`, `)||void 0;return{role:e.role,blocks:t,blockSummary:i}})),J=l(()=>(V.value.tools||[]).map(e=>e.function?.name||e.name||`unknown`).filter(Boolean)),Y=l(()=>j.value?J.value:J.value.slice(0,Oe)),X=l(()=>{let e=V.value.system;return e?Array.isArray(e)?e.map(e=>({type:e.type||`text`,text:e.text||``})):typeof e==`string`?[{type:`text`,text:e}]:[{type:`unknown`,text:JSON.stringify(e)}]:[]}),Ae=new Set([`model`,`stream`,`max_tokens`,`thinking`,`messages`,`tools`,`system`]),je=l(()=>{let e={};for(let t of Object.keys(V.value))Ae.has(t)||(e[t]=V.value[t]);return e}),$=l(()=>Object.keys(je.value));function Me(e){let t=new TextEncoder().encode(e).length;return t<ke?`${t}B`:`${(t/ke).toFixed(1)}KB`}return(l,u)=>(e(),i(d(te),{"default-value":n.mode??`structured`,"model-value":n.mode,class:`w-full`},{default:r(()=>[n.mode?f(``,!0):(e(),m(`div`,de,[p(d(ne),null,{default:r(()=>[p(d(S),{value:`structured`},{default:r(()=>[...u[2]||=[a(`结构化`,-1)]]),_:1}),p(d(S),{value:`raw`},{default:r(()=>[...u[3]||=[a(`原始 JSON`,-1)]]),_:1})]),_:1}),p(d(g),{variant:`ghost`,size:`xs`,class:`h-auto py-1`,onClick:R},{default:r(()=>[a(h(d(M)?`已复制`:`复制 JSON`),1)]),_:1})])),p(d(x),{value:`structured`,class:`space-y-3`},{default:r(()=>[L.value?(e(),m(`div`,Q,`解析失败,请切换到原始 JSON 查看`)):(e(),m(o,{key:1},[le.value?(e(),i(ue,{key:0,icon:`CC`,title:`Claude Code 请求`,subtitle:`user-agent: ${U.value}`,details:K.value},null,8,[`subtitle`,`details`])):f(``,!0),n.showUrl&&I.value.url?(e(),m(`div`,fe,h(I.value.url),1)):f(``,!0),s(`div`,pe,[I.value.body?.model?(e(),i(N,{key:0,label:`model`,value:String(I.value.body.model),highlight:!0},null,8,[`value`])):f(``,!0),I.value.body?.stream==null?f(``,!0):(e(),i(N,{key:1,label:`stream`,value:String(I.value.body.stream)},null,8,[`value`])),I.value.body?.max_tokens==null?f(``,!0):(e(),i(N,{key:2,label:`max_tokens`,value:String(I.value.body.max_tokens)},null,8,[`value`])),I.value.body?.thinking==null?f(``,!0):(e(),i(P,{key:3,label:`thinking`}))]),p(d(y),{open:k.value,"onUpdate:open":u[0]||=e=>k.value=e},{default:r(()=>[p(d(b),{"as-child":``},{default:r(()=>[p(d(g),{variant:`ghost`,size:`xs`,class:`px-0 h-auto`},{default:r(()=>[a(` Headers (`+h(z.value.length)+` 个) `,1)]),_:1})]),_:1}),p(d(v),null,{default:r(()=>[s(`div`,me,[p(d(ae),null,{default:r(()=>[p(d(oe),null,{default:r(()=>[p(d(O),null,{default:r(()=>[p(d(D),{class:`w-1/3`},{default:r(()=>[...u[4]||=[a(`Key`,-1)]]),_:1}),p(d(D),null,{default:r(()=>[...u[5]||=[a(`Value`,-1)]]),_:1})]),_:1})]),_:1}),p(d(ie),null,{default:r(()=>[(e(!0),m(o,null,t(z.value,([t,n])=>(e(),i(d(O),{key:t},{default:r(()=>[p(d(E),{class:`font-medium`},{default:r(()=>[a(h(t),1)]),_:2},1024),p(d(E),{class:`break-all`},{default:r(()=>[a(h(n),1)]),_:2},1024)]),_:2},1024))),128))]),_:1})]),_:1})])]),_:1})]),_:1},8,[`open`]),q.value.length?(e(),m(`div`,he,[u[7]||=s(`div`,{class:`text-xs font-medium text-muted-foreground`},`Messages`,-1),(e(!0),m(o,null,t(q.value,(n,l)=>(e(),i(d(w),{key:l,class:`bg-muted/40`},{default:r(()=>[p(d(re),{class:`pb-2 flex flex-row items-center gap-2`},{default:r(()=>[p(d(C),{class:c(d(B)(n.role))},{default:r(()=>[a(h(n.role),1)]),_:2},1032,[`class`]),n.blockSummary?(e(),m(`span`,ge,h(n.blockSummary),1)):f(``,!0)]),_:2},1024),p(d(T),{class:`space-y-2`},{default:r(()=>[(e(!0),m(o,null,t(n.blocks,(t,n)=>(e(),m(`div`,{key:n},[t.type===`text`?(e(),m(`div`,_e,[t.text.length>120&&!A[`${l}-${n}`]?(e(),m(`div`,ve,[a(h(t.text.slice(0,120))+` `,1),p(d(g),{variant:`link`,size:`xs`,class:`px-0 h-auto`,onClick:e=>A[`${l}-${n}`]=!0},{default:r(()=>[...u[6]||=[a(`展开`,-1)]]),_:1},8,[`onClick`])])):(e(),m(`div`,ye,h(t.text),1))])):t.text?(e(),m(`div`,be,[p(d(y),null,{default:r(()=>[p(d(b),{"as-child":``},{default:r(()=>[p(d(g),{variant:`ghost`,size:`xs`,class:`px-0 h-auto`},{default:r(()=>[p(d(C),{class:c([d(H)(t.type),`mr-1`])},{default:r(()=>[a(h(t.label||t.type),1)]),_:2},1032,[`class`]),a(` `+h(Me(t.text)),1)]),_:2},1024)]),_:2},1024),p(d(v),null,{default:r(()=>[s(`pre`,xe,h(t.text),1)]),_:2},1024)]),_:2},1024)])):(e(),m(`div`,Se,[p(d(C),{class:c([d(H)(t.type),`mr-1`])},{default:r(()=>[a(h(t.label||t.type),1)]),_:2},1032,[`class`])]))]))),128))]),_:2},1024)]),_:2},1024))),128))])):f(``,!0),J.value.length?(e(),m(`div`,Ce,[u[8]||=s(`div`,{class:`text-xs font-medium text-muted-foreground mb-1`},`Tools`,-1),s(`div`,we,[(e(!0),m(o,null,t(Y.value,t=>(e(),i(P,{key:t,label:t},null,8,[`label`]))),128)),J.value.length>8?(e(),i(d(g),{key:0,variant:`ghost`,size:`xs`,class:`px-1 h-5`,onClick:u[1]||=e=>j.value=!j.value},{default:r(()=>[a(h(j.value?`收起`:`+${J.value.length-8}`),1)]),_:1})):f(``,!0)])])):f(``,!0),X.value.length?(e(),m(`div`,Te,[u[9]||=s(`div`,{class:`text-xs font-medium text-muted-foreground mb-1`},`System`,-1),p(d(w),{class:`bg-muted/40`},{default:r(()=>[p(d(T),{class:`space-y-2`},{default:r(()=>[(e(!0),m(o,null,t(X.value,(t,n)=>(e(),m(`div`,{key:n,class:`text-sm whitespace-pre-wrap break-all`},[p(d(C),{variant:`outline`,class:`mb-1`},{default:r(()=>[a(h(t.type),1)]),_:2},1024),t.text?(e(),m(`div`,Ee,h(t.text),1)):f(``,!0)]))),128))]),_:1})]),_:1})])):f(``,!0),$.value.length?(e(),i(d(y),{key:5},{default:r(()=>[p(d(b),{"as-child":``},{default:r(()=>[p(d(g),{variant:`ghost`,size:`xs`,class:`px-0 h-auto`},{default:r(()=>[...u[10]||=[a(` 其他字段 `,-1)]]),_:1})]),_:1}),p(d(v),null,{default:r(()=>[s(`pre`,De,h(JSON.stringify(je.value,null,2)),1)]),_:1})]),_:1})):f(``,!0)],64))]),_:1}),p(d(x),{value:`raw`},{default:r(()=>[p(ce,{content:n.raw,"hide-copy-button":``},null,8,[`content`])]),_:1})]),_:1},8,[`default-value`,`model-value`]))}}),je={class:`text-xs text-foreground`},$=n({__name:`SseEventLine`,props:{eventType:{},summary:{},highlight:{type:Boolean}},setup(t){return(n,r)=>(e(),m(`div`,{class:c([`px-3 py-2 flex items-center gap-2`,t.highlight?`bg-warning/10`:``])},[s(`span`,{class:c([`px-1.5 py-0.5 rounded text-[10px] font-medium`,{"bg-teal-200 text-teal-700 dark:bg-teal-800 dark:text-teal-300":t.eventType===`message_start`,"bg-teal-300 text-teal-700 dark:bg-teal-700 dark:text-teal-200":t.eventType===`content_block_start`,"bg-muted text-muted-foreground":t.eventType===`content_block_delta`,"bg-teal-500 text-white dark:bg-teal-600":t.eventType===`message_delta`,"bg-success-light text-success":t.eventType===`message_stop`}])},h(t.eventType),3),s(`span`,je,h(t.summary),1)],2))}}),Me=5,Ne=2,Pe=3;function Fe(e,t,n){let r=l(()=>{if(!t||!e.value)return[];let n=e.value.split(`
|
|
3
3
|
`),r=[];for(let e of n){let t=e.trim();if(!t.startsWith(`data:`))continue;let n=t.slice(Me).trim();if(n===`[DONE]`){r.push({type:`done`,data:n});continue}try{let e=JSON.parse(n);r.push({type:`data`,data:e})}catch{r.push({type:`raw`,data:n})}}return r});return{sseEvents:r,assembledBlocks:l(()=>{if(!t||!e.value)return[];let n=[],i=null;for(let e of r.value){if(e.type!==`data`)continue;let t=e.data;if(t.type===`content_block_start`){let e=t.content_block;if(i={type:String(e?.type||``),content:``,eventCount:0,toolName:e?.name?String(e.name):void 0},i.type===`tool_use`&&e?.input){let t=e.input;Object.keys(t).length>0&&(i.content=JSON.stringify(t,null,Ne))}continue}if(t.type===`content_block_delta`&&i){let e=t.delta;i.content+=e.thinking||e.text||e.partial_json||``,i.eventCount++;continue}t.type===`content_block_stop`&&i&&(n.push(i),i=null)}return i&&n.push(i),n}),sseMeta:l(()=>{let e=``,t=``,n=0,i=0,a=``;for(let o of r.value){if(o.type!==`data`)continue;let r=o.data;if(r.type===`message_start`){let i=r.message;e=String(i?.id||``),t=String(i?.model||``),n=Number(i?.usage?.input_tokens??0)}if(r.type===`message_delta`){let e=r.delta,t=r.usage;a=String(e?.stop_reason||``),i=Number(t?.output_tokens??0)}}return{id:e,model:t,inputTokens:n,outputTokens:i,stopReason:a}}),openaiAssembled:l(()=>{if(n!==`openai`||!t)return null;let e=``,i=``,a=``,o=null,s=0;for(let t of r.value){if(t.type!==`data`)continue;let n=t.data,r=n.choices||[],c=r[0]?.delta;c?.role&&(e=String(c.role)),c?.content&&(i+=String(c.content),s++),r[0]?.finish_reason&&(a=String(r[0].finish_reason)),n.usage&&(o=n.usage)}return{role:e,content:i,contentEventCount:s,finishReason:a,usage:o}}),anthropicMessageStart:l(()=>{for(let e of r.value){if(e.type!==`data`)continue;let t=e.data;if(t.type===`message_start`){let e=t.message;return{id:String(e?.id||``),model:String(e?.model||``),input_tokens:Number(e?.usage?.input_tokens??0)}}}return null}),anthropicContentBlockStarts:l(()=>{let e=[];for(let t of r.value){if(t.type!==`data`)continue;let n=t.data;if(n.type===`content_block_start`){let t=n.content_block;e.push({index:Number(n.index??0),type:String(t?.type||``)})}}return e}),anthropicDeltaGroups:l(()=>{let e={};for(let t of r.value){if(t.type!==`data`)continue;let n=t.data;if(n.type!==`content_block_delta`)continue;let r=n.delta,i=String(r?.type||`unknown`);e[i]||(e[i]={deltaType:i,kept:0,folded:0,foldedChars:0});let a=e[i];if(a.kept<Pe)a.kept++;else{a.folded++;let e=r,t=String(e.thinking||e.text||e.partial_json||``);a.foldedChars+=t.length}}return Object.values(e).filter(e=>e.kept>0||e.folded>0)}),anthropicMessageDelta:l(()=>{for(let e of r.value){if(e.type!==`data`)continue;let t=e.data;if(t.type===`message_delta`){let e=t.delta,n=t.usage;return{output_tokens:Number(n?.output_tokens??0),stop_reason:String(e?.stop_reason||``)}}}return null}),anthropicMessageStop:l(()=>r.value.some(e=>e.type===`data`&&e.data.type===`message_stop`)),openaiSseRole:l(()=>{for(let e of r.value){if(e.type!==`data`)continue;let t=(e.data.choices||[])[0]?.delta;if(t?.role)return String(t.role)}return null}),openaiSseFirstContent:l(()=>{for(let e of r.value){if(e.type!==`data`)continue;let t=(e.data.choices||[])[0]?.delta;if(t?.content)return String(t.content)}return null}),openaiSseFinishReason:l(()=>{for(let e of r.value){if(e.type!==`data`)continue;let t=(e.data.choices||[])[0]?.finish_reason;if(t)return String(t)}return null}),openaiSseCollapsedCount:l(()=>{let e=0,t=!1;for(let n of r.value){if(n.type!==`data`)continue;let r=(n.data.choices||[])[0]?.delta;if(!t){r?.content&&(t=!0);continue}(r?.content||r?.role)&&e++}return e}),openaiSseUsage:l(()=>{for(let e=r.value.length-1;e>=0;e--){let t=r.value[e];if(t.type!==`data`)continue;let n=t.data.usage;if(n)return{prompt_tokens:n.prompt_tokens,completion_tokens:n.completion_tokens,total_tokens:n.total_tokens,cached_tokens:n.cached_tokens??n.prompt_tokens_details?.cached_tokens}}return null})}}var Ie={key:0,class:`flex items-center justify-between py-2 border-b mb-2 sticky top-0 z-10 bg-background`},Le={key:0,class:`text-destructive text-sm`},Re={class:`flex items-center gap-2`},ze={class:`rounded-md border overflow-hidden mt-1`},Be={class:`flex flex-wrap gap-2`},Ve={key:0,class:`space-y-2`},He={class:`mt-1 whitespace-pre-wrap break-all text-xs bg-muted rounded-md p-2 border`},Ue={key:1,class:`grid grid-cols-2 sm:grid-cols-4 gap-2`},We={class:`font-medium`},Ge={class:`font-medium`},Ke={class:`font-medium`},qe={class:`font-medium`},Je={class:`flex flex-wrap gap-2`},Ye={key:0,class:`space-y-2`},Xe={class:`flex items-center gap-2 mb-2`},Ze={key:0,class:`text-sm`},Qe={key:1,class:`grid grid-cols-2 sm:grid-cols-4 gap-2`},$e={class:`font-medium`},et={class:`font-medium`},tt={class:`font-medium`},nt={class:`font-medium`},rt={key:1,class:`space-y-3`},it={class:`flex gap-1`},at={class:`flex flex-wrap gap-2`},ot={class:`flex items-center gap-2 mb-2`},st={class:`text-xs text-muted-foreground`},ct={key:0,class:`text-xs font-mono`},lt={class:`whitespace-pre-wrap break-all text-sm bg-muted rounded-md p-3 border`},ut={key:1,class:`whitespace-pre-wrap break-all text-sm bg-muted rounded-md p-3 border max-h-[40vh] overflow-auto`},dt={class:`flex flex-wrap gap-2`},ft={class:`flex flex-wrap gap-2`},pt={class:`whitespace-pre-wrap break-all text-sm bg-muted rounded-md p-3 max-h-[40vh] overflow-auto`},mt={key:0,class:`grid grid-cols-2 sm:grid-cols-4 gap-2`},ht={class:`font-medium`},gt={class:`font-medium`},_t={class:`font-medium`},vt={key:0,class:`text-sm`},yt={key:1,class:`text-sm`},bt={key:2,class:`text-sm`},xt={key:3,class:`text-xs text-muted-foreground`},St={key:4,class:`grid grid-cols-2 sm:grid-cols-4 gap-2`},Ct={class:`font-medium`},wt={class:`font-medium`},Tt={class:`font-medium`},Et={class:`font-medium`},Dt=400,Ot=n({__name:`LogResponseViewer`,props:{raw:{},apiType:{},isStream:{type:Boolean},mode:{}},setup(n){let _=n,k=l(()=>{try{return JSON.parse(_.raw)}catch{return null}}),A=l(()=>k.value===null),j=l(()=>(k.value?.statusCode??0)>=Dt?`destructive`:`default`),M=l(()=>{let e=k.value?.headers||{};return Object.entries(e)}),P=l(()=>{if(!_.isStream&&k.value?.body)try{return JSON.parse(k.value.body)}catch{return{}}return{}}),F=l(()=>(P.value.choices||[]).map(e=>({role:e.message?.role||`assistant`,content:e.message?.content||``,finish_reason:e.finish_reason||``}))),I=l(()=>{let e=P.value.usage;return e?{prompt_tokens:e.prompt_tokens,completion_tokens:e.completion_tokens,total_tokens:e.total_tokens,cached_tokens:e.cached_tokens??e.prompt_tokens_details?.cached_tokens}:null}),L=l(()=>P.value.content||[]),R=l(()=>{let e=P.value.usage;return e?{input_tokens:e.input_tokens,output_tokens:e.output_tokens,cache_creation_input_tokens:e.cache_creation_input_tokens,cache_read_input_tokens:e.cache_read_input_tokens}:null}),{assembledBlocks:z,sseMeta:B,openaiAssembled:H,anthropicMessageStart:U,anthropicContentBlockStarts:W,anthropicDeltaGroups:G,anthropicMessageDelta:K,anthropicMessageStop:q,openaiSseRole:ue,openaiSseFirstContent:J,openaiSseFinishReason:Y,openaiSseCollapsedCount:X,openaiSseUsage:Z}=Fe(l(()=>k.value?.body),_.isStream,_.apiType),de=u({}),Q=ee(`assembled`),{copied:fe,copy:pe}=se();async function me(){await pe(_.raw)}return(l,u)=>(e(),i(d(te),{"default-value":n.mode??`structured`,"model-value":n.mode,class:`w-full`},{default:r(()=>[n.mode?f(``,!0):(e(),m(`div`,Ie,[p(d(ne),null,{default:r(()=>[p(d(S),{value:`structured`},{default:r(()=>[...u[2]||=[a(`结构化`,-1)]]),_:1}),p(d(S),{value:`raw`},{default:r(()=>[a(h(n.isStream?`原始 SSE 文本`:`原始 JSON`),1)]),_:1})]),_:1}),p(d(g),{variant:`ghost`,size:`xs`,class:`h-auto py-1`,onClick:me},{default:r(()=>[a(h(d(fe)?`已复制`:`复制`),1)]),_:1})])),p(d(x),{value:`structured`,class:`space-y-3`},{default:r(()=>[A.value?(e(),m(`div`,Le,`解析失败,请切换到原始 JSON 查看`)):(e(),m(o,{key:1},[s(`div`,Re,[p(d(C),{variant:j.value},{default:r(()=>[a(`status: `+h(k.value.statusCode),1)]),_:1},8,[`variant`])]),p(d(y),null,{default:r(()=>[p(d(b),{"as-child":``},{default:r(()=>[p(d(g),{variant:`ghost`,size:`xs`,class:`px-0 h-auto text-xs`},{default:r(()=>[a(` Headers (`+h(M.value.length)+` 个) `,1)]),_:1})]),_:1}),p(d(v),null,{default:r(()=>[s(`div`,ze,[p(d(ae),null,{default:r(()=>[p(d(oe),null,{default:r(()=>[p(d(O),null,{default:r(()=>[p(d(D),{class:`w-1/3`},{default:r(()=>[...u[3]||=[a(`Key`,-1)]]),_:1}),p(d(D),null,{default:r(()=>[...u[4]||=[a(`Value`,-1)]]),_:1})]),_:1})]),_:1}),p(d(ie),null,{default:r(()=>[(e(!0),m(o,null,t(M.value,([t,n])=>(e(),i(d(O),{key:t},{default:r(()=>[p(d(E),{class:`font-medium`},{default:r(()=>[a(h(t),1)]),_:2},1024),p(d(E),{class:`break-all`},{default:r(()=>[a(h(n),1)]),_:2},1024)]),_:2},1024))),128))]),_:1})]),_:1})])]),_:1})]),_:1}),n.isStream?(e(),m(`div`,rt,[s(`div`,it,[p(d(g),{variant:`ghost`,class:c([Q.value===`assembled`?`bg-secondary`:``,`h-auto py-1`]),size:`xs`,onClick:u[0]||=e=>Q.value=`assembled`},{default:r(()=>[...u[16]||=[a(`完整响应`,-1)]]),_:1},8,[`class`]),p(d(g),{variant:`ghost`,class:c([Q.value===`raw-events`?`bg-secondary`:``,`h-auto py-1`]),size:`xs`,onClick:u[1]||=e=>Q.value=`raw-events`},{default:r(()=>[...u[17]||=[a(`原始事件流`,-1)]]),_:1},8,[`class`])]),Q.value===`assembled`?(e(),m(o,{key:0},[n.apiType===`anthropic`?(e(),m(o,{key:0},[s(`div`,at,[d(B).id?(e(),i(N,{key:0,label:`id`,value:d(B).id},null,8,[`value`])):f(``,!0),d(B).model?(e(),i(N,{key:1,label:`model`,value:d(B).model,highlight:!0},null,8,[`value`])):f(``,!0),p(N,{label:`input`,value:String(d(B).inputTokens)},null,8,[`value`])]),(e(!0),m(o,null,t(d(z),(t,n)=>(e(),m(`div`,{key:n,class:c([`rounded-md border p-3`,d(le)(t.type)])},[s(`div`,ot,[p(d(C),{class:c(d(V)(t.type))},{default:r(()=>[a(h(t.type),1)]),_:2},1032,[`class`]),s(`span`,st,h(t.eventCount)+` 个 delta 事件`,1),t.toolName?(e(),m(`span`,ct,h(t.toolName),1)):f(``,!0)]),t.content.length>500&&!de[n]?(e(),m(o,{key:0},[s(`pre`,lt,h(t.content.slice(0,500))+`...`,1),p(d(g),{variant:`link`,size:`xs`,class:`px-0`,onClick:e=>de[n]=!0},{default:r(()=>[...u[18]||=[a(`展开全部`,-1)]]),_:1},8,[`onClick`])],64)):(e(),m(`pre`,ut,h(t.content),1))],2))),128)),s(`div`,dt,[p(N,{label:`stop_reason`,value:d(B).stopReason||`-`},null,8,[`value`]),p(N,{label:`output_tokens`,value:String(d(B).outputTokens||`-`)},null,8,[`value`])])],64)):f(``,!0),n.apiType===`openai`&&d(H)?(e(),m(o,{key:1},[s(`div`,ft,[d(H).role?(e(),i(N,{key:0,label:`role`,value:d(H).role},null,8,[`value`])):f(``,!0),p(N,{label:`content delta`,value:String(d(H).contentEventCount)},null,8,[`value`]),d(H).finishReason?(e(),i(N,{key:1,label:`finish`,value:d(H).finishReason},null,8,[`value`])):f(``,!0)]),s(`div`,{class:c([`rounded-md border p-3`,d(le)(`text`)])},[s(`pre`,pt,h(d(H).content),1)],2),d(H).usage?(e(),m(`div`,mt,[p(d(w),{class:`bg-muted/40`},{default:r(()=>[p(d(T),{class:`py-2 px-3 text-xs`},{default:r(()=>[u[19]||=s(`div`,{class:`text-muted-foreground`},`prompt_tokens`,-1),s(`div`,ht,h(d(H).usage.prompt_tokens??`-`),1)]),_:1})]),_:1}),p(d(w),{class:`bg-muted/40`},{default:r(()=>[p(d(T),{class:`py-2 px-3 text-xs`},{default:r(()=>[u[20]||=s(`div`,{class:`text-muted-foreground`},`completion_tokens`,-1),s(`div`,gt,h(d(H).usage.completion_tokens??`-`),1)]),_:1})]),_:1}),p(d(w),{class:`bg-muted/40`},{default:r(()=>[p(d(T),{class:`py-2 px-3 text-xs`},{default:r(()=>[u[21]||=s(`div`,{class:`text-muted-foreground`},`total_tokens`,-1),s(`div`,_t,h(d(H).usage.total_tokens??`-`),1)]),_:1})]),_:1})])):f(``,!0)],64)):f(``,!0)],64)):f(``,!0),Q.value===`raw-events`?(e(),m(o,{key:1},[n.apiType===`openai`?(e(),m(o,{key:0},[d(ue)?(e(),m(`div`,vt,[u[22]||=s(`span`,{class:`text-muted-foreground`},`role:`,-1),a(` `+h(d(ue)),1)])):f(``,!0),d(J)?(e(),m(`div`,yt,[u[23]||=s(`span`,{class:`text-muted-foreground`},`first content delta:`,-1),a(` `+h(d(J)),1)])):f(``,!0),d(Y)?(e(),m(`div`,bt,[u[24]||=s(`span`,{class:`text-muted-foreground`},`finish_reason:`,-1),a(` `+h(d(Y)),1)])):f(``,!0),d(X)>0?(e(),m(`div`,xt,` +`+h(d(X))+` 个 delta 事件已折叠 `,1)):f(``,!0),d(Z)?(e(),m(`div`,St,[p(d(w),{class:`bg-muted/40`},{default:r(()=>[p(d(T),{class:`py-2 px-3 text-xs`},{default:r(()=>[u[25]||=s(`div`,{class:`text-muted-foreground`},`prompt_tokens`,-1),s(`div`,Ct,h(d(Z).prompt_tokens??`-`),1)]),_:1})]),_:1}),p(d(w),{class:`bg-muted/40`},{default:r(()=>[p(d(T),{class:`py-2 px-3 text-xs`},{default:r(()=>[u[26]||=s(`div`,{class:`text-muted-foreground`},`completion_tokens`,-1),s(`div`,wt,h(d(Z).completion_tokens??`-`),1)]),_:1})]),_:1}),p(d(w),{class:`bg-muted/40`},{default:r(()=>[p(d(T),{class:`py-2 px-3 text-xs`},{default:r(()=>[u[27]||=s(`div`,{class:`text-muted-foreground`},`total_tokens`,-1),s(`div`,Tt,h(d(Z).total_tokens??`-`),1)]),_:1})]),_:1}),p(d(w),{class:`bg-muted/40`},{default:r(()=>[p(d(T),{class:`py-2 px-3 text-xs`},{default:r(()=>[u[28]||=s(`div`,{class:`text-muted-foreground`},`cached_tokens`,-1),s(`div`,Et,h(d(Z).cached_tokens??`-`),1)]),_:1})]),_:1})])):f(``,!0)],64)):f(``,!0),n.apiType===`anthropic`?(e(),m(o,{key:1},[d(U)?(e(),i($,{key:0,"event-type":`message_start`,summary:`id=${d(U).id} model=${d(U).model} input_tokens=${d(U).input_tokens}`},null,8,[`summary`])):f(``,!0),(e(!0),m(o,null,t(d(W),(t,n)=>(e(),i($,{key:`cbs-`+n,"event-type":`content_block_start`,summary:`[${t.index}] ${t.type}`},null,8,[`summary`]))),128)),(e(!0),m(o,null,t(d(G),(t,n)=>(e(),i($,{key:`dg-`+n,"event-type":`content_block_delta`,summary:`${t.deltaType} · keep ${t.kept} 个${t.folded>0?` +${t.folded} 个已折叠 (${t.foldedChars} 字符)`:``}`},null,8,[`summary`]))),128)),d(K)?(e(),i($,{key:1,"event-type":`message_delta`,summary:`output_tokens=${d(K).output_tokens} stop_reason=${d(K).stop_reason}`,highlight:!0},null,8,[`summary`])):f(``,!0),d(q)?(e(),i($,{key:2,"event-type":`message_stop`,summary:`流结束`})):f(``,!0)],64)):f(``,!0)],64)):f(``,!0)])):(e(),m(o,{key:0},[n.apiType===`openai`?(e(),m(o,{key:0},[s(`div`,Be,[P.value.id?(e(),i(N,{key:0,label:`id`,value:String(P.value.id)},null,8,[`value`])):f(``,!0),P.value.model?(e(),i(N,{key:1,label:`model`,value:String(P.value.model),highlight:!0},null,8,[`value`])):f(``,!0),P.value.system_fingerprint?(e(),i(N,{key:2,label:`fingerprint`,value:String(P.value.system_fingerprint)},null,8,[`value`])):f(``,!0)]),F.value.length?(e(),m(`div`,Ve,[u[6]||=s(`div`,{class:`text-xs font-medium text-muted-foreground`},`Choices`,-1),(e(!0),m(o,null,t(F.value,(t,n)=>(e(),i(d(w),{key:n,class:`bg-muted/40`},{default:r(()=>[p(d(re),{class:`pb-2 flex flex-row items-center gap-2`},{default:r(()=>[p(d(C),{variant:`secondary`},{default:r(()=>[a(h(t.role||`assistant`),1)]),_:2},1024),t.finish_reason?(e(),i(d(C),{key:0,variant:`outline`},{default:r(()=>[a(h(t.finish_reason),1)]),_:2},1024)):f(``,!0)]),_:2},1024),p(d(T),null,{default:r(()=>[p(d(y),null,{default:r(()=>[p(d(b),{"as-child":``},{default:r(()=>[p(d(g),{variant:`ghost`,size:`xs`,class:`px-0 h-auto text-xs`},{default:r(()=>[...u[5]||=[a(`内容`,-1)]]),_:1})]),_:1}),p(d(v),null,{default:r(()=>[s(`pre`,He,h(t.content),1)]),_:2},1024)]),_:2},1024)]),_:2},1024)]),_:2},1024))),128))])):f(``,!0),I.value?(e(),m(`div`,Ue,[p(d(w),{class:`bg-muted/40`},{default:r(()=>[p(d(T),{class:`py-2 px-3 text-xs`},{default:r(()=>[u[7]||=s(`div`,{class:`text-muted-foreground`},`prompt_tokens`,-1),s(`div`,We,h(I.value.prompt_tokens??`-`),1)]),_:1})]),_:1}),p(d(w),{class:`bg-muted/40`},{default:r(()=>[p(d(T),{class:`py-2 px-3 text-xs`},{default:r(()=>[u[8]||=s(`div`,{class:`text-muted-foreground`},`completion_tokens`,-1),s(`div`,Ge,h(I.value.completion_tokens??`-`),1)]),_:1})]),_:1}),p(d(w),{class:`bg-muted/40`},{default:r(()=>[p(d(T),{class:`py-2 px-3 text-xs`},{default:r(()=>[u[9]||=s(`div`,{class:`text-muted-foreground`},`total_tokens`,-1),s(`div`,Ke,h(I.value.total_tokens??`-`),1)]),_:1})]),_:1}),p(d(w),{class:`bg-muted/40`},{default:r(()=>[p(d(T),{class:`py-2 px-3 text-xs`},{default:r(()=>[u[10]||=s(`div`,{class:`text-muted-foreground`},`cached_tokens`,-1),s(`div`,qe,h(I.value.cached_tokens??`-`),1)]),_:1})]),_:1})])):f(``,!0)],64)):f(``,!0),n.apiType===`anthropic`?(e(),m(o,{key:1},[s(`div`,Je,[P.value.id?(e(),i(N,{key:0,label:`id`,value:String(P.value.id)},null,8,[`value`])):f(``,!0),P.value.type?(e(),i(N,{key:1,label:`type`,value:String(P.value.type)},null,8,[`value`])):f(``,!0),P.value.model?(e(),i(N,{key:2,label:`model`,value:String(P.value.model),highlight:!0},null,8,[`value`])):f(``,!0),P.value.stop_reason?(e(),i(N,{key:3,label:`stop_reason`,value:String(P.value.stop_reason)},null,8,[`value`])):f(``,!0)]),L.value.length?(e(),m(`div`,Ye,[u[11]||=s(`div`,{class:`text-xs font-medium text-muted-foreground`},`Content`,-1),(e(!0),m(o,null,t(L.value,(t,n)=>(e(),m(`div`,{key:n,class:`rounded-md border p-3`},[s(`div`,Xe,[p(d(C),{class:c(d(V)(t.type))},{default:r(()=>[a(h(t.type),1)]),_:2},1032,[`class`]),t.text?(e(),m(`span`,Ze,h(t.text),1)):f(``,!0)])]))),128))])):f(``,!0),R.value?(e(),m(`div`,Qe,[p(d(w),{class:`bg-muted/40`},{default:r(()=>[p(d(T),{class:`py-2 px-3 text-xs`},{default:r(()=>[u[12]||=s(`div`,{class:`text-muted-foreground`},`input_tokens`,-1),s(`div`,$e,h(R.value.input_tokens??`-`),1)]),_:1})]),_:1}),p(d(w),{class:`bg-muted/40`},{default:r(()=>[p(d(T),{class:`py-2 px-3 text-xs`},{default:r(()=>[u[13]||=s(`div`,{class:`text-muted-foreground`},`output_tokens`,-1),s(`div`,et,h(R.value.output_tokens??`-`),1)]),_:1})]),_:1}),p(d(w),{class:`bg-muted/40`},{default:r(()=>[p(d(T),{class:`py-2 px-3 text-xs`},{default:r(()=>[u[14]||=s(`div`,{class:`text-muted-foreground`},`cache_creation`,-1),s(`div`,tt,h(R.value.cache_creation_input_tokens??`-`),1)]),_:1})]),_:1}),p(d(w),{class:`bg-muted/40`},{default:r(()=>[p(d(T),{class:`py-2 px-3 text-xs`},{default:r(()=>[u[15]||=s(`div`,{class:`text-muted-foreground`},`cache_read`,-1),s(`div`,nt,h(R.value.cache_read_input_tokens??`-`),1)]),_:1})]),_:1})])):f(``,!0)],64)):f(``,!0)],64))],64))]),_:1}),p(d(x),{value:`raw`},{default:r(()=>[p(ce,{content:n.raw,"hide-copy-button":``},null,8,[`content`])]),_:1})]),_:1},8,[`default-value`,`model-value`]))}});export{Ae as n,k as r,Ot as t};
|
|
@@ -1 +1 @@
|
|
|
1
|
-
import{F as e,S as t,Y as n,a as r,b as i,g as a,mt as o,ot as s,t as c,u as l,v as u,x as d,y as f,yt as p}from"./client-
|
|
1
|
+
import{F as e,S as t,Y as n,a as r,b as i,g as a,mt as o,ot as s,t as c,u as l,v as u,x as d,y as f,yt as p}from"./client-Mb8fy_bC.js";import{n as m}from"./button-D54q76GQ.js";import{t as h}from"./Label-CXAeFn-r.js";import{n as g,t as _}from"./CardContent-CucI6u41.js";import{t as v}from"./Input-HN3Il0-c.js";var y={class:`min-h-screen flex items-center justify-center bg-background`},b={key:0,class:`text-destructive text-sm`},x=t({__name:`Login`,setup(t){let x=r(),S=s(``),C=s(``),w=s(!1);async function T(){if(S.value){C.value=``,w.value=!0;try{await c.login(S.value),x.push(`/`)}catch(e){C.value=e.response?.data?.error?.message||`登录失败`}finally{w.value=!1}}}return(t,r)=>(e(),f(`div`,y,[d(o(g),{class:`w-full max-w-sm shadow-lg`},{default:n(()=>[d(o(_),{class:`pt-6`},{default:n(()=>[r[2]||=a(`div`,{class:`text-center mb-6`},[a(`div`,{class:`w-12 h-12 bg-primary rounded-lg mx-auto mb-3 flex items-center justify-center`},[a(`svg`,{class:`w-7 h-7 text-white`,fill:`none`,stroke:`currentColor`,viewBox:`0 0 24 24`},[a(`path`,{"stroke-linecap":`round`,"stroke-linejoin":`round`,"stroke-width":`2`,d:`M8 9l3 3-3 3m5 0h3M5 20h14a2 2 0 002-2V6a2 2 0 00-2-2H5a2 2 0 00-2 2v12a2 2 0 002 2z`})])]),a(`h1`,{class:`text-xl font-semibold text-foreground`},`LLM Simple Router`),a(`p`,{class:`text-sm text-muted-foreground mt-1`},`管理后台登录`)],-1),a(`form`,{onSubmit:l(T,[`prevent`]),class:`space-y-4`},[a(`div`,null,[d(o(h),{class:`block text-sm font-medium text-foreground mb-1`},{default:n(()=>[...r[1]||=[i(`密码`,-1)]]),_:1}),d(o(v),{modelValue:S.value,"onUpdate:modelValue":r[0]||=e=>S.value=e,type:`password`,placeholder:`输入管理员密码`,disabled:w.value},null,8,[`modelValue`,`disabled`])]),C.value?(e(),f(`p`,b,p(C.value),1)):u(``,!0),d(o(m),{type:`submit`,class:`w-full`,disabled:w.value},{default:n(()=>[i(p(w.value?`登录中...`:`登 录`),1)]),_:1},8,[`disabled`])],32)]),_:1})]),_:1})]))}});export{x as default};
|
|
@@ -1 +1 @@
|
|
|
1
|
-
import{F as e,L as t,M as ee,S as n,Y as r,_ as i,b as a,f as o,g as s,gt as c,it as te,mt as l,ot as u,t as d,v as f,x as p,y as m,yt as h}from"./client-DvdghFBq.js";import{a as ne,i as re,n as ie,r as g,t as ae}from"./SelectValue-CFf_mD9E.js";import{n as _}from"./button-CfQs66fX.js";import{n as v,r as y,t as b}from"./CollapsibleTrigger-BvYqNbGA.js";import{a as oe,i as se,n as ce,o as le,r as x,s as S,t as C}from"./dialog-DQFRGKR6.js";import{t as ue}from"./Label-fZNDEQjf.js";import{n as w,r as T}from"./lib-BJNsNHLO.js";import{n as de,t as fe}from"./CardContent-B40ArIqh.js";import{a as pe,i as E,n as D,o as me,r as O,t as he}from"./TableHeader-DAOs6nSA.js";import{t as ge}from"./Input-toxjzsir.js";import{t as _e}from"./useClipboard-aPMKfK25.js";import{n as k,r as A,t as j}from"./LogResponseViewer-B9kSncNr.js";var ve={class:`p-6`},ye={class:`flex items-center justify-between mb-4`},be={class:`flex items-center gap-2`},xe={class:`bg-card rounded-lg border overflow-hidden`},Se={class:`font-mono`},Ce={key:2,class:`text-muted-foreground`},we={key:1,class:`text-muted-foreground`},Te={class:`flex items-center justify-between mt-4`},Ee={class:`text-sm text-muted-foreground`},De={class:`flex gap-1`},Oe={class:`px-3 py-1 text-sm text-muted-foreground`},ke={key:0,class:`font-mono text-xs text-muted-foreground font-normal select-all`},Ae={key:0,class:`space-y-3 py-4`},je={class:`flex gap-2`},Me={key:0,class:`flex items-center gap-2 mb-3 px-1`},Ne={class:`text-xs text-muted-foreground`},Pe={class:`bg-muted/50 rounded-md p-3 text-sm grid grid-cols-3 gap-2`},Fe={class:`font-medium font-mono`},Ie={key:0,class:`col-span-3`},Le={class:`font-mono text-xs`},Re={class:`font-medium`},ze={class:`font-medium`},Be={class:`font-medium`},Ve={class:`flex items-center justify-between px-4 py-2 border-b sticky top-0 z-10 bg-background`},He={class:`inline-flex h-8 items-center gap-1 rounded-md bg-muted p-1`},Ue={class:`p-4`},We={class:`flex items-center justify-between px-4 py-2 border-b sticky top-0 z-10 bg-background`},Ge={class:`inline-flex h-8 items-center gap-1 rounded-md bg-muted p-1`},Ke={class:`p-4`},qe={class:`flex items-center justify-between px-4 py-2 border-b sticky top-0 z-10 bg-background`},Je={class:`inline-flex h-8 items-center gap-1 rounded-md bg-muted p-1`},Ye={class:`p-4`},Xe={class:`flex items-center justify-between px-4 py-2 border-b sticky top-0 z-10 bg-background`},Ze={class:`inline-flex h-8 items-center gap-1 rounded-md bg-muted p-1`},Qe={class:`p-4`},$e={key:2,class:`py-8 text-center text-muted-foreground`},et={class:`mb-4`},M=20,N=n({__name:`Logs`,setup(n){let N=u([]),P=u(0),F=u(1),I=u(`all`),L=u(`all`),R=u([]),z=u(!1),B=u(30),V=u(!1),H=u(!1),U=u(null),W=u(!0),G=u(!1),K=u(!1),q=u(!1),J=te({client_request:`structured`,upstream_request:`structured`,upstream_response:`structured`,client_response:`structured`}),Y=u(null),{copy:tt}=_e();function nt(e){return U.value?{client_request:at(U.value),upstream_request:U.value.upstream_request||`{}`,upstream_response:U.value.upstream_response||U.value.response_body||`{}`,client_response:Q(U.value)}[e]:`{}`}async function X(e){await tt(nt(e))?(Y.value=e,setTimeout(()=>{Y.value=null},2e3)):w.error(`复制失败`)}function Z(e){return e===`openai`?`openai`:`anthropic`}function rt(e){if(!e)return`未知`;try{let t=JSON.parse(e);return t.action?t.detail?`${t.action}: ${t.detail}`:t.action:e}catch{return`未知`}}function it(e){return e.provider_id===`router`}function at(e){if(!e.client_request)return e.request_body||`{}`;try{let t=JSON.parse(e.client_request);if(t.body!=null)return e.client_request;if(e.request_body){try{t.body=JSON.parse(e.request_body)}catch{t.body=e.request_body}return JSON.stringify(t)}return e.client_request}catch{return e.client_request}}function Q(e){return e.client_response?e.client_response:e.response_body?JSON.stringify({statusCode:e.status_code,body:e.response_body}):``}async function ot(e){V.value=!0,H.value=!0,U.value=null,W.value=!0,G.value=!1,K.value=!1,q.value=!1,J.client_request=`structured`,J.upstream_request=`structured`,J.upstream_response=`structured`,J.client_response=`structured`;try{U.value=(await d.getLogDetail(e)).data}catch(e){console.error(`Failed to load log detail:`,e),w.error(`加载日志详情失败`)}finally{H.value=!1}}function st(e){ot(e)}function ct(e){return new Date(e).toLocaleString(`zh-CN`)}async function $(){try{let e={page:F.value,limit:M};I.value&&I.value!==`all`&&(e.api_type=I.value),L.value&&L.value!==`all`&&(e.router_key_id=L.value);let t=await d.getLogs(e);N.value=t.data.data,P.value=t.data.total}catch(e){console.error(`Failed to load logs:`,e),w.error(`加载日志失败`)}}function lt(){F.value=1,$()}function ut(){F.value>1&&(F.value--,$())}function dt(){F.value++,$()}async function ft(){try{let e=new Date(Date.now()-B.value*864e5).toISOString(),t=await d.deleteLogsBefore(e);z.value=!1,F.value=1,await $(),w.success(`已清理 ${t.data.deleted} 条日志`)}catch(e){console.error(`Failed to cleanup logs:`,e),w.error(`清理日志失败`)}}async function pt(){try{R.value=(await d.getRouterKeys()).data}catch(e){console.error(`Failed to load router keys:`,e),w.error(`加载密钥列表失败`)}}return ee(()=>{pt(),$()}),(ee,n)=>(e(),m(`div`,ve,[s(`div`,ye,[n[29]||=s(`h2`,{class:`text-lg font-semibold text-foreground`},`请求日志`,-1),s(`div`,be,[p(l(ne),{modelValue:I.value,"onUpdate:modelValue":[n[0]||=e=>I.value=e,lt]},{default:r(()=>[p(l(ie),{class:`w-[140px]`},{default:r(()=>[p(l(ae),{placeholder:`全部类型`})]),_:1}),p(l(re),null,{default:r(()=>[p(l(g),{value:`all`},{default:r(()=>[...n[24]||=[a(`全部类型`,-1)]]),_:1}),p(l(g),{value:`openai`},{default:r(()=>[...n[25]||=[a(`OpenAI`,-1)]]),_:1}),p(l(g),{value:`anthropic`},{default:r(()=>[...n[26]||=[a(`Anthropic`,-1)]]),_:1})]),_:1})]),_:1},8,[`modelValue`]),p(l(ne),{modelValue:L.value,"onUpdate:modelValue":[n[1]||=e=>L.value=e,lt]},{default:r(()=>[p(l(ie),{class:`w-48`},{default:r(()=>[p(l(ae),{placeholder:`全部密钥`})]),_:1}),p(l(re),null,{default:r(()=>[p(l(g),{value:`all`},{default:r(()=>[...n[27]||=[a(`全部密钥`,-1)]]),_:1}),(e(!0),m(o,null,t(R.value,t=>(e(),i(l(g),{key:t.id,value:t.id},{default:r(()=>[a(h(t.name),1)]),_:2},1032,[`value`]))),128))]),_:1})]),_:1},8,[`modelValue`]),p(l(_),{variant:`outline`,class:`text-destructive border-destructive hover:bg-destructive/10`,onClick:n[2]||=e=>z.value=!0},{default:r(()=>[...n[28]||=[a(` 清理日志 `,-1)]]),_:1})])]),s(`div`,xe,[p(l(me),null,{default:r(()=>[p(l(he),null,{default:r(()=>[p(l(O),{class:`bg-muted`},{default:r(()=>[p(l(D),{class:`text-muted-foreground`},{default:r(()=>[...n[30]||=[a(`ID`,-1)]]),_:1}),p(l(D),{class:`text-muted-foreground`},{default:r(()=>[...n[31]||=[a(`时间`,-1)]]),_:1}),p(l(D),{class:`text-muted-foreground`},{default:r(()=>[...n[32]||=[a(`类型`,-1)]]),_:1}),p(l(D),{class:`text-muted-foreground`},{default:r(()=>[...n[33]||=[a(`模型`,-1)]]),_:1}),p(l(D),{class:`text-muted-foreground`},{default:r(()=>[...n[34]||=[a(`实际转发`,-1)]]),_:1}),p(l(D),{class:`text-muted-foreground`},{default:r(()=>[...n[35]||=[a(`状态码`,-1)]]),_:1}),p(l(D),{class:`text-muted-foreground`},{default:r(()=>[...n[36]||=[a(`延迟`,-1)]]),_:1}),p(l(D),{class:`text-muted-foreground`},{default:r(()=>[...n[37]||=[a(`流式`,-1)]]),_:1}),p(l(D),{class:`text-muted-foreground`},{default:r(()=>[...n[38]||=[a(`重试`,-1)]]),_:1}),p(l(D),{class:`text-muted-foreground`},{default:r(()=>[...n[39]||=[a(`错误`,-1)]]),_:1}),p(l(D),{class:`text-muted-foreground`},{default:r(()=>[...n[40]||=[a(`操作`,-1)]]),_:1})]),_:1})]),_:1}),p(l(pe),null,{default:r(()=>[(e(!0),m(o,null,t(N.value,t=>(e(),i(l(O),{key:t.id,class:c({"bg-destructive/10":(t.status_code??0)>=400,"bg-warning-light":t.is_retry})},{default:r(()=>[p(l(E),{class:`font-mono text-xs text-muted-foreground`,title:t.id},{default:r(()=>[a(h(t.id.slice(0,8)),1)]),_:2},1032,[`title`]),p(l(E),{class:`text-muted-foreground`},{default:r(()=>[a(h(ct(t.created_at)),1)]),_:2},1024),p(l(E),null,{default:r(()=>[p(l(T),{variant:t.api_type===`openai`?`default`:`secondary`},{default:r(()=>[a(h(t.api_type),1)]),_:2},1032,[`variant`])]),_:2},1024),p(l(E),{class:`font-mono text-xs`},{default:r(()=>[a(h(t.model||`-`)+` `,1),t.original_model?(e(),i(l(T),{key:0,variant:`secondary`,class:`ml-1 text-xs`},{default:r(()=>[...n[41]||=[a(`已替换`,-1)]]),_:1})):f(``,!0)]),_:2},1024),p(l(E),{class:`text-xs`},{default:r(()=>[t.provider_id===`router`?(e(),i(l(T),{key:0,variant:`secondary`,class:`text-[10px] px-1 py-0`},{default:r(()=>[a(`代理增强:`+h(rt(t.upstream_request)),1)]),_:2},1024)):t.backend_model||t.provider_name?(e(),m(o,{key:1},[s(`span`,Se,h(t.backend_model||`-`),1),n[42]||=s(`span`,{class:`text-muted-foreground`},` @ `,-1),p(l(T),{variant:`outline`,class:`text-[10px] px-1 py-0`},{default:r(()=>[a(h(t.provider_name||t.provider_id||`-`),1)]),_:2},1024)],64)):(e(),m(`span`,Ce,`-`))]),_:2},1024),p(l(E),null,{default:r(()=>[p(l(T),{variant:(t.status_code??0)<400?`default`:`destructive`},{default:r(()=>[a(h(t.status_code||`-`),1)]),_:2},1032,[`variant`])]),_:2},1024),p(l(E),null,{default:r(()=>[a(h(t.latency_ms?t.latency_ms+`ms`:`-`),1)]),_:2},1024),p(l(E),null,{default:r(()=>[a(h(t.is_stream?`Yes`:`No`),1)]),_:2},1024),p(l(E),null,{default:r(()=>[t.is_retry?(e(),i(l(T),{key:0,variant:`outline`,class:`text-warning-dark border-warning`},{default:r(()=>[...n[43]||=[a(`重试`,-1)]]),_:1})):(e(),m(`span`,we,`-`))]),_:2},1024),p(l(E),{class:`text-destructive text-xs`},{default:r(()=>[a(h(t.error_message||`-`),1)]),_:2},1024),p(l(E),null,{default:r(()=>[p(l(_),{variant:`ghost`,size:`sm`,onClick:e=>ot(t.id)},{default:r(()=>[...n[44]||=[a(`详情`,-1)]]),_:1},8,[`onClick`])]),_:2},1024)]),_:2},1032,[`class`]))),128)),N.value.length===0?(e(),i(l(O),{key:0},{default:r(()=>[p(l(E),{colspan:`10`,class:`text-center text-muted-foreground py-8`},{default:r(()=>[...n[45]||=[a(`暂无日志`,-1)]]),_:1})]),_:1})):f(``,!0)]),_:1})]),_:1})]),s(`div`,Te,[s(`p`,Ee,`共 `+h(P.value)+` 条`,1),s(`div`,De,[p(l(_),{variant:`outline`,size:`sm`,onClick:ut,disabled:F.value<=1},{default:r(()=>[...n[46]||=[a(`上一页`,-1)]]),_:1},8,[`disabled`]),s(`span`,Oe,`第 `+h(F.value)+` 页`,1),p(l(_),{variant:`outline`,size:`sm`,onClick:dt,disabled:N.value.length<M},{default:r(()=>[...n[47]||=[a(`下一页`,-1)]]),_:1},8,[`disabled`])])]),p(l(S),{open:V.value,"onUpdate:open":n[20]||=e=>V.value=e},{default:r(()=>[p(l(ce),{class:`max-w-4xl max-h-[85vh]`},{default:r(()=>[p(l(x),null,{default:r(()=>[p(l(C),{class:`flex items-center gap-2`},{default:r(()=>[n[48]||=a(`请求详情 `,-1),U.value?(e(),m(`span`,ke,h(U.value.id),1)):f(``,!0)]),_:1}),p(l(oe),{class:`sr-only`},{default:r(()=>[...n[49]||=[a(`请求日志详情`,-1)]]),_:1})]),_:1}),H.value?(e(),m(`div`,Ae,[s(`div`,je,[p(l(A),{class:`h-6 w-16`}),p(l(A),{class:`h-6 w-48`}),p(l(A),{class:`h-6 w-12`})]),(e(),m(o,null,t(4,e=>p(l(A),{class:`h-12 w-full`,key:e})),64))])):U.value?(e(),m(o,{key:1},[U.value.is_retry?(e(),m(`div`,Me,[p(l(T),{variant:`outline`,class:`text-warning-dark border-warning`},{default:r(()=>[...n[50]||=[a(`重试请求`,-1)]]),_:1}),s(`span`,Ne,[n[51]||=a(` 原始请求: `,-1),p(l(_),{variant:`link`,class:`h-auto p-0 text-xs font-mono text-primary underline`,onClick:n[3]||=e=>st(U.value.original_request_id)},{default:r(()=>[a(h(U.value.original_request_id?.slice(0,8)),1)]),_:1})])])):f(``,!0),s(`div`,Pe,[s(`div`,null,[n[52]||=s(`span`,{class:`text-muted-foreground`},`类型:`,-1),n[53]||=a(),p(l(T),{variant:U.value.api_type===`openai`?`default`:`secondary`,class:`text-xs`},{default:r(()=>[a(h(U.value.api_type),1)]),_:1},8,[`variant`])]),s(`div`,null,[n[54]||=s(`span`,{class:`text-muted-foreground`},`模型:`,-1),n[55]||=a(),s(`span`,Fe,h(U.value.model||`-`),1)]),U.value.original_model?(e(),m(`div`,Ie,[n[56]||=s(`span`,{class:`text-muted-foreground`},`模型替换:`,-1),n[57]||=a(),s(`span`,Le,h(U.value.original_model)+` → `+h(U.value.backend_model||U.value.model),1)])):f(``,!0),s(`div`,null,[n[58]||=s(`span`,{class:`text-muted-foreground`},`状态码:`,-1),n[59]||=a(),p(l(T),{variant:(U.value.status_code??0)<400?`default`:`destructive`,class:`text-xs`},{default:r(()=>[a(h(U.value.status_code||`-`),1)]),_:1},8,[`variant`])]),s(`div`,null,[n[60]||=s(`span`,{class:`text-muted-foreground`},`延迟:`,-1),n[61]||=a(),s(`span`,Re,h(U.value.latency_ms?U.value.latency_ms+`ms`:`-`),1)]),s(`div`,null,[n[62]||=s(`span`,{class:`text-muted-foreground`},`流式:`,-1),n[63]||=a(),s(`span`,ze,h(U.value.is_stream?`Yes`:`No`),1)]),s(`div`,null,[n[64]||=s(`span`,{class:`text-muted-foreground`},`时间:`,-1),n[65]||=a(),s(`span`,Be,h(ct(U.value.created_at)),1)])]),p(l(y),{open:W.value,"onUpdate:open":n[7]||=e=>W.value=e,class:`border rounded-md`},{default:r(()=>[p(l(b),{"as-child":``},{default:r(()=>[p(l(_),{variant:`ghost`,class:`w-full px-4 py-3 text-left text-sm font-medium text-foreground bg-muted/50 hover:bg-muted rounded-none rounded-t-md flex items-center gap-2`},{default:r(()=>[s(`span`,{class:c([`text-xs transition-transform`,W.value?`rotate-0`:`-rotate-90`])},`▼`,2),n[66]||=a(` 客户端原始请求 `,-1)]),_:1})]),_:1}),p(l(v),null,{default:r(()=>[s(`div`,Ve,[s(`div`,He,[p(l(_),{variant:`ghost`,size:`xs`,class:c(J.client_request===`structured`?`bg-background shadow`:``),onClick:n[4]||=e=>J.client_request=`structured`},{default:r(()=>[...n[67]||=[a(`结构化`,-1)]]),_:1},8,[`class`]),p(l(_),{variant:`ghost`,size:`xs`,class:c(J.client_request===`raw`?`bg-background shadow`:``),onClick:n[5]||=e=>J.client_request=`raw`},{default:r(()=>[...n[68]||=[a(`原始 JSON`,-1)]]),_:1},8,[`class`])]),p(l(_),{variant:`ghost`,size:`xs`,class:`h-auto py-1`,onClick:n[6]||=e=>X(`client_request`)},{default:r(()=>[a(h(Y.value===`client_request`?`已复制`:`复制`),1)]),_:1})]),s(`div`,Ue,[p(k,{raw:at(U.value),"api-type":Z(U.value.api_type),mode:J.client_request},null,8,[`raw`,`api-type`,`mode`])])]),_:1})]),_:1},8,[`open`]),U.value.upstream_request&&!it(U.value)?(e(),i(l(y),{key:1,open:G.value,"onUpdate:open":n[11]||=e=>G.value=e,class:`border rounded-md`},{default:r(()=>[p(l(b),{"as-child":``},{default:r(()=>[p(l(_),{variant:`ghost`,class:`w-full px-4 py-3 text-left text-sm font-medium text-foreground bg-muted/50 hover:bg-muted rounded-none rounded-t-md flex items-center gap-2`},{default:r(()=>[s(`span`,{class:c([`text-xs transition-transform`,G.value?`rotate-0`:`-rotate-90`])},`▼`,2),n[69]||=a(` Router → LLM API 请求 `,-1)]),_:1})]),_:1}),p(l(v),null,{default:r(()=>[s(`div`,We,[s(`div`,Ge,[p(l(_),{variant:`ghost`,size:`xs`,class:c(J.upstream_request===`structured`?`bg-background shadow`:``),onClick:n[8]||=e=>J.upstream_request=`structured`},{default:r(()=>[...n[70]||=[a(`结构化`,-1)]]),_:1},8,[`class`]),p(l(_),{variant:`ghost`,size:`xs`,class:c(J.upstream_request===`raw`?`bg-background shadow`:``),onClick:n[9]||=e=>J.upstream_request=`raw`},{default:r(()=>[...n[71]||=[a(`原始 JSON`,-1)]]),_:1},8,[`class`])]),p(l(_),{variant:`ghost`,size:`xs`,class:`h-auto py-1`,onClick:n[10]||=e=>X(`upstream_request`)},{default:r(()=>[a(h(Y.value===`upstream_request`?`已复制`:`复制`),1)]),_:1})]),s(`div`,Ke,[p(k,{raw:U.value.upstream_request,"api-type":Z(U.value.api_type),"show-url":!0,mode:J.upstream_request},null,8,[`raw`,`api-type`,`mode`])])]),_:1})]),_:1},8,[`open`])):f(``,!0),it(U.value)?f(``,!0):(e(),i(l(y),{key:2,open:K.value,"onUpdate:open":n[15]||=e=>K.value=e,class:`border rounded-md`},{default:r(()=>[p(l(b),{"as-child":``},{default:r(()=>[p(l(_),{variant:`ghost`,class:`w-full px-4 py-3 text-left text-sm font-medium text-foreground bg-muted/50 hover:bg-muted rounded-none rounded-t-md flex items-center gap-2`},{default:r(()=>[s(`span`,{class:c([`text-xs transition-transform`,K.value?`rotate-0`:`-rotate-90`])},`▼`,2),n[72]||=a(` LLM API 返回的原始响应 `,-1)]),_:1})]),_:1}),p(l(v),null,{default:r(()=>[s(`div`,qe,[s(`div`,Je,[p(l(_),{variant:`ghost`,size:`xs`,class:c(J.upstream_response===`structured`?`bg-background shadow`:``),onClick:n[12]||=e=>J.upstream_response=`structured`},{default:r(()=>[...n[73]||=[a(`结构化`,-1)]]),_:1},8,[`class`]),p(l(_),{variant:`ghost`,size:`xs`,class:c(J.upstream_response===`raw`?`bg-background shadow`:``),onClick:n[13]||=e=>J.upstream_response=`raw`},{default:r(()=>[a(h(U.value.is_stream?`原始 SSE 文本`:`原始 JSON`),1)]),_:1},8,[`class`])]),p(l(_),{variant:`ghost`,size:`xs`,class:`h-auto py-1`,onClick:n[14]||=e=>X(`upstream_response`)},{default:r(()=>[a(h(Y.value===`upstream_response`?`已复制`:`复制`),1)]),_:1})]),s(`div`,Ye,[p(j,{raw:U.value.upstream_response||U.value.response_body||`{}`,"api-type":Z(U.value.api_type),"is-stream":!!U.value.is_stream,mode:J.upstream_response},null,8,[`raw`,`api-type`,`is-stream`,`mode`])])]),_:1})]),_:1},8,[`open`])),Q(U.value)?(e(),i(l(y),{key:3,open:q.value,"onUpdate:open":n[19]||=e=>q.value=e,class:`border rounded-md`},{default:r(()=>[p(l(b),{"as-child":``},{default:r(()=>[p(l(_),{variant:`ghost`,class:`w-full px-4 py-3 text-left text-sm font-medium text-foreground bg-muted/50 hover:bg-muted rounded-none rounded-t-md flex items-center gap-2`},{default:r(()=>[s(`span`,{class:c([`text-xs transition-transform`,q.value?`rotate-0`:`-rotate-90`])},`▼`,2),n[74]||=a(` Router → 客户端响应 `,-1)]),_:1})]),_:1}),p(l(v),null,{default:r(()=>[s(`div`,Xe,[s(`div`,Ze,[p(l(_),{variant:`ghost`,size:`xs`,class:c(J.client_response===`structured`?`bg-background shadow`:``),onClick:n[16]||=e=>J.client_response=`structured`},{default:r(()=>[...n[75]||=[a(`结构化`,-1)]]),_:1},8,[`class`]),p(l(_),{variant:`ghost`,size:`xs`,class:c(J.client_response===`raw`?`bg-background shadow`:``),onClick:n[17]||=e=>J.client_response=`raw`},{default:r(()=>[a(h(U.value.is_stream?`原始 SSE 文本`:`原始 JSON`),1)]),_:1},8,[`class`])]),p(l(_),{variant:`ghost`,size:`xs`,class:`h-auto py-1`,onClick:n[18]||=e=>X(`client_response`)},{default:r(()=>[a(h(Y.value===`client_response`?`已复制`:`复制`),1)]),_:1})]),s(`div`,Qe,[p(j,{raw:Q(U.value),"api-type":Z(U.value.api_type),"is-stream":!!U.value.is_stream,mode:J.client_response},null,8,[`raw`,`api-type`,`is-stream`,`mode`])])]),_:1})]),_:1},8,[`open`])):f(``,!0),U.value.error_message?(e(),i(l(de),{key:4,class:`bg-destructive/10 ring-destructive/20`},{default:r(()=>[p(l(fe),{class:`py-3 text-sm text-destructive`},{default:r(()=>[a(h(U.value.error_message),1)]),_:1})]),_:1})):f(``,!0)],64)):(e(),m(`div`,$e,`未找到日志`))]),_:1})]),_:1},8,[`open`]),p(l(S),{open:z.value,"onUpdate:open":n[23]||=e=>z.value=e},{default:r(()=>[p(l(le),null,{default:r(()=>[p(l(x),null,{default:r(()=>[p(l(C),null,{default:r(()=>[...n[76]||=[a(`清理日志`,-1)]]),_:1})]),_:1}),n[80]||=s(`p`,{class:`text-sm text-muted-foreground`},`删除指定天数之前的日志`,-1),s(`div`,et,[p(l(ue),{class:`block text-sm font-medium text-foreground mb-1`},{default:r(()=>[...n[77]||=[a(`保留最近天数`,-1)]]),_:1}),p(l(ge),{modelValue:B.value,"onUpdate:modelValue":n[21]||=e=>B.value=e,modelModifiers:{number:!0},type:`number`,min:1},null,8,[`modelValue`])]),p(l(se),null,{default:r(()=>[p(l(_),{variant:`outline`,onClick:n[22]||=e=>z.value=!1},{default:r(()=>[...n[78]||=[a(`取消`,-1)]]),_:1}),p(l(_),{variant:`destructive`,onClick:ft},{default:r(()=>[...n[79]||=[a(`确认清理`,-1)]]),_:1})]),_:1})]),_:1})]),_:1},8,[`open`])]))}});export{N as default};
|
|
1
|
+
import{F as e,L as t,M as ee,S as n,Y as r,_ as i,b as a,f as o,g as s,gt as c,it as te,mt as l,ot as u,t as d,v as f,x as p,y as m,yt as h}from"./client-Mb8fy_bC.js";import{a as ne,i as re,n as ie,r as g,t as ae}from"./SelectValue-B32pgmTJ.js";import{n as _}from"./button-D54q76GQ.js";import{n as v,r as y,t as b}from"./CollapsibleTrigger-BFNhb19_.js";import{a as oe,i as se,n as ce,o as le,r as x,s as S,t as C}from"./dialog-DSH5k5Kj.js";import{t as ue}from"./Label-CXAeFn-r.js";import{n as w,r as T}from"./lib-BgOqOzXI.js";import{n as de,t as fe}from"./CardContent-CucI6u41.js";import{a as pe,i as E,n as D,o as me,r as O,t as he}from"./TableHeader-BpscAtT3.js";import{t as ge}from"./Input-HN3Il0-c.js";import{t as _e}from"./useClipboard-DO-38TXr.js";import{n as k,r as A,t as j}from"./LogResponseViewer-CyBzv02a.js";var ve={class:`p-6`},ye={class:`flex items-center justify-between mb-4`},be={class:`flex items-center gap-2`},xe={class:`bg-card rounded-lg border overflow-hidden`},Se={class:`font-mono`},Ce={key:2,class:`text-muted-foreground`},we={key:1,class:`text-muted-foreground`},Te={class:`flex items-center justify-between mt-4`},Ee={class:`text-sm text-muted-foreground`},De={class:`flex gap-1`},Oe={class:`px-3 py-1 text-sm text-muted-foreground`},ke={key:0,class:`font-mono text-xs text-muted-foreground font-normal select-all`},Ae={key:0,class:`space-y-3 py-4`},je={class:`flex gap-2`},Me={key:0,class:`flex items-center gap-2 mb-3 px-1`},Ne={class:`text-xs text-muted-foreground`},Pe={class:`bg-muted/50 rounded-md p-3 text-sm grid grid-cols-3 gap-2`},Fe={class:`font-medium font-mono`},Ie={key:0,class:`col-span-3`},Le={class:`font-mono text-xs`},Re={class:`font-medium`},ze={class:`font-medium`},Be={class:`font-medium`},Ve={class:`flex items-center justify-between px-4 py-2 border-b sticky top-0 z-10 bg-background`},He={class:`inline-flex h-8 items-center gap-1 rounded-md bg-muted p-1`},Ue={class:`p-4`},We={class:`flex items-center justify-between px-4 py-2 border-b sticky top-0 z-10 bg-background`},Ge={class:`inline-flex h-8 items-center gap-1 rounded-md bg-muted p-1`},Ke={class:`p-4`},qe={class:`flex items-center justify-between px-4 py-2 border-b sticky top-0 z-10 bg-background`},Je={class:`inline-flex h-8 items-center gap-1 rounded-md bg-muted p-1`},Ye={class:`p-4`},Xe={class:`flex items-center justify-between px-4 py-2 border-b sticky top-0 z-10 bg-background`},Ze={class:`inline-flex h-8 items-center gap-1 rounded-md bg-muted p-1`},Qe={class:`p-4`},$e={key:2,class:`py-8 text-center text-muted-foreground`},et={class:`mb-4`},M=20,N=n({__name:`Logs`,setup(n){let N=u([]),P=u(0),F=u(1),I=u(`all`),L=u(`all`),R=u([]),z=u(!1),B=u(30),V=u(!1),H=u(!1),U=u(null),W=u(!0),G=u(!1),K=u(!1),q=u(!1),J=te({client_request:`structured`,upstream_request:`structured`,upstream_response:`structured`,client_response:`structured`}),Y=u(null),{copy:tt}=_e();function nt(e){return U.value?{client_request:at(U.value),upstream_request:U.value.upstream_request||`{}`,upstream_response:U.value.upstream_response||U.value.response_body||`{}`,client_response:Q(U.value)}[e]:`{}`}async function X(e){await tt(nt(e))?(Y.value=e,setTimeout(()=>{Y.value=null},2e3)):w.error(`复制失败`)}function Z(e){return e===`openai`?`openai`:`anthropic`}function rt(e){if(!e)return`未知`;try{let t=JSON.parse(e);return t.action?t.detail?`${t.action}: ${t.detail}`:t.action:e}catch{return`未知`}}function it(e){return e.provider_id===`router`}function at(e){if(!e.client_request)return e.request_body||`{}`;try{let t=JSON.parse(e.client_request);if(t.body!=null)return e.client_request;if(e.request_body){try{t.body=JSON.parse(e.request_body)}catch{t.body=e.request_body}return JSON.stringify(t)}return e.client_request}catch{return e.client_request}}function Q(e){return e.client_response?e.client_response:e.response_body?JSON.stringify({statusCode:e.status_code,body:e.response_body}):``}async function ot(e){V.value=!0,H.value=!0,U.value=null,W.value=!0,G.value=!1,K.value=!1,q.value=!1,J.client_request=`structured`,J.upstream_request=`structured`,J.upstream_response=`structured`,J.client_response=`structured`;try{U.value=(await d.getLogDetail(e)).data}catch(e){console.error(`Failed to load log detail:`,e),w.error(`加载日志详情失败`)}finally{H.value=!1}}function st(e){ot(e)}function ct(e){return new Date(e).toLocaleString(`zh-CN`)}async function $(){try{let e={page:F.value,limit:M};I.value&&I.value!==`all`&&(e.api_type=I.value),L.value&&L.value!==`all`&&(e.router_key_id=L.value);let t=await d.getLogs(e);N.value=t.data.data,P.value=t.data.total}catch(e){console.error(`Failed to load logs:`,e),w.error(`加载日志失败`)}}function lt(){F.value=1,$()}function ut(){F.value>1&&(F.value--,$())}function dt(){F.value++,$()}async function ft(){try{let e=new Date(Date.now()-B.value*864e5).toISOString(),t=await d.deleteLogsBefore(e);z.value=!1,F.value=1,await $(),w.success(`已清理 ${t.data.deleted} 条日志`)}catch(e){console.error(`Failed to cleanup logs:`,e),w.error(`清理日志失败`)}}async function pt(){try{R.value=(await d.getRouterKeys()).data}catch(e){console.error(`Failed to load router keys:`,e),w.error(`加载密钥列表失败`)}}return ee(()=>{pt(),$()}),(ee,n)=>(e(),m(`div`,ve,[s(`div`,ye,[n[29]||=s(`h2`,{class:`text-lg font-semibold text-foreground`},`请求日志`,-1),s(`div`,be,[p(l(ne),{modelValue:I.value,"onUpdate:modelValue":[n[0]||=e=>I.value=e,lt]},{default:r(()=>[p(l(ie),{class:`w-[140px]`},{default:r(()=>[p(l(ae),{placeholder:`全部类型`})]),_:1}),p(l(re),null,{default:r(()=>[p(l(g),{value:`all`},{default:r(()=>[...n[24]||=[a(`全部类型`,-1)]]),_:1}),p(l(g),{value:`openai`},{default:r(()=>[...n[25]||=[a(`OpenAI`,-1)]]),_:1}),p(l(g),{value:`anthropic`},{default:r(()=>[...n[26]||=[a(`Anthropic`,-1)]]),_:1})]),_:1})]),_:1},8,[`modelValue`]),p(l(ne),{modelValue:L.value,"onUpdate:modelValue":[n[1]||=e=>L.value=e,lt]},{default:r(()=>[p(l(ie),{class:`w-48`},{default:r(()=>[p(l(ae),{placeholder:`全部密钥`})]),_:1}),p(l(re),null,{default:r(()=>[p(l(g),{value:`all`},{default:r(()=>[...n[27]||=[a(`全部密钥`,-1)]]),_:1}),(e(!0),m(o,null,t(R.value,t=>(e(),i(l(g),{key:t.id,value:t.id},{default:r(()=>[a(h(t.name),1)]),_:2},1032,[`value`]))),128))]),_:1})]),_:1},8,[`modelValue`]),p(l(_),{variant:`outline`,class:`text-destructive border-destructive hover:bg-destructive/10`,onClick:n[2]||=e=>z.value=!0},{default:r(()=>[...n[28]||=[a(` 清理日志 `,-1)]]),_:1})])]),s(`div`,xe,[p(l(me),null,{default:r(()=>[p(l(he),null,{default:r(()=>[p(l(O),{class:`bg-muted`},{default:r(()=>[p(l(D),{class:`text-muted-foreground`},{default:r(()=>[...n[30]||=[a(`ID`,-1)]]),_:1}),p(l(D),{class:`text-muted-foreground`},{default:r(()=>[...n[31]||=[a(`时间`,-1)]]),_:1}),p(l(D),{class:`text-muted-foreground`},{default:r(()=>[...n[32]||=[a(`类型`,-1)]]),_:1}),p(l(D),{class:`text-muted-foreground`},{default:r(()=>[...n[33]||=[a(`模型`,-1)]]),_:1}),p(l(D),{class:`text-muted-foreground`},{default:r(()=>[...n[34]||=[a(`实际转发`,-1)]]),_:1}),p(l(D),{class:`text-muted-foreground`},{default:r(()=>[...n[35]||=[a(`状态码`,-1)]]),_:1}),p(l(D),{class:`text-muted-foreground`},{default:r(()=>[...n[36]||=[a(`延迟`,-1)]]),_:1}),p(l(D),{class:`text-muted-foreground`},{default:r(()=>[...n[37]||=[a(`流式`,-1)]]),_:1}),p(l(D),{class:`text-muted-foreground`},{default:r(()=>[...n[38]||=[a(`重试`,-1)]]),_:1}),p(l(D),{class:`text-muted-foreground`},{default:r(()=>[...n[39]||=[a(`错误`,-1)]]),_:1}),p(l(D),{class:`text-muted-foreground`},{default:r(()=>[...n[40]||=[a(`操作`,-1)]]),_:1})]),_:1})]),_:1}),p(l(pe),null,{default:r(()=>[(e(!0),m(o,null,t(N.value,t=>(e(),i(l(O),{key:t.id,class:c({"bg-destructive/10":(t.status_code??0)>=400,"bg-warning-light":t.is_retry})},{default:r(()=>[p(l(E),{class:`font-mono text-xs text-muted-foreground`,title:t.id},{default:r(()=>[a(h(t.id.slice(0,8)),1)]),_:2},1032,[`title`]),p(l(E),{class:`text-muted-foreground`},{default:r(()=>[a(h(ct(t.created_at)),1)]),_:2},1024),p(l(E),null,{default:r(()=>[p(l(T),{variant:t.api_type===`openai`?`default`:`secondary`},{default:r(()=>[a(h(t.api_type),1)]),_:2},1032,[`variant`])]),_:2},1024),p(l(E),{class:`font-mono text-xs`},{default:r(()=>[a(h(t.model||`-`)+` `,1),t.original_model?(e(),i(l(T),{key:0,variant:`secondary`,class:`ml-1 text-xs`},{default:r(()=>[...n[41]||=[a(`已替换`,-1)]]),_:1})):f(``,!0)]),_:2},1024),p(l(E),{class:`text-xs`},{default:r(()=>[t.provider_id===`router`?(e(),i(l(T),{key:0,variant:`secondary`,class:`text-[10px] px-1 py-0`},{default:r(()=>[a(`代理增强:`+h(rt(t.upstream_request)),1)]),_:2},1024)):t.backend_model||t.provider_name?(e(),m(o,{key:1},[s(`span`,Se,h(t.backend_model||`-`),1),n[42]||=s(`span`,{class:`text-muted-foreground`},` @ `,-1),p(l(T),{variant:`outline`,class:`text-[10px] px-1 py-0`},{default:r(()=>[a(h(t.provider_name||t.provider_id||`-`),1)]),_:2},1024)],64)):(e(),m(`span`,Ce,`-`))]),_:2},1024),p(l(E),null,{default:r(()=>[p(l(T),{variant:(t.status_code??0)<400?`default`:`destructive`},{default:r(()=>[a(h(t.status_code||`-`),1)]),_:2},1032,[`variant`])]),_:2},1024),p(l(E),null,{default:r(()=>[a(h(t.latency_ms?t.latency_ms+`ms`:`-`),1)]),_:2},1024),p(l(E),null,{default:r(()=>[a(h(t.is_stream?`Yes`:`No`),1)]),_:2},1024),p(l(E),null,{default:r(()=>[t.is_retry?(e(),i(l(T),{key:0,variant:`outline`,class:`text-warning-dark border-warning`},{default:r(()=>[...n[43]||=[a(`重试`,-1)]]),_:1})):(e(),m(`span`,we,`-`))]),_:2},1024),p(l(E),{class:`text-destructive text-xs`},{default:r(()=>[a(h(t.error_message||`-`),1)]),_:2},1024),p(l(E),null,{default:r(()=>[p(l(_),{variant:`ghost`,size:`sm`,onClick:e=>ot(t.id)},{default:r(()=>[...n[44]||=[a(`详情`,-1)]]),_:1},8,[`onClick`])]),_:2},1024)]),_:2},1032,[`class`]))),128)),N.value.length===0?(e(),i(l(O),{key:0},{default:r(()=>[p(l(E),{colspan:`10`,class:`text-center text-muted-foreground py-8`},{default:r(()=>[...n[45]||=[a(`暂无日志`,-1)]]),_:1})]),_:1})):f(``,!0)]),_:1})]),_:1})]),s(`div`,Te,[s(`p`,Ee,`共 `+h(P.value)+` 条`,1),s(`div`,De,[p(l(_),{variant:`outline`,size:`sm`,onClick:ut,disabled:F.value<=1},{default:r(()=>[...n[46]||=[a(`上一页`,-1)]]),_:1},8,[`disabled`]),s(`span`,Oe,`第 `+h(F.value)+` 页`,1),p(l(_),{variant:`outline`,size:`sm`,onClick:dt,disabled:N.value.length<M},{default:r(()=>[...n[47]||=[a(`下一页`,-1)]]),_:1},8,[`disabled`])])]),p(l(S),{open:V.value,"onUpdate:open":n[20]||=e=>V.value=e},{default:r(()=>[p(l(ce),{class:`max-w-4xl max-h-[85vh]`},{default:r(()=>[p(l(x),null,{default:r(()=>[p(l(C),{class:`flex items-center gap-2`},{default:r(()=>[n[48]||=a(`请求详情 `,-1),U.value?(e(),m(`span`,ke,h(U.value.id),1)):f(``,!0)]),_:1}),p(l(oe),{class:`sr-only`},{default:r(()=>[...n[49]||=[a(`请求日志详情`,-1)]]),_:1})]),_:1}),H.value?(e(),m(`div`,Ae,[s(`div`,je,[p(l(A),{class:`h-6 w-16`}),p(l(A),{class:`h-6 w-48`}),p(l(A),{class:`h-6 w-12`})]),(e(),m(o,null,t(4,e=>p(l(A),{class:`h-12 w-full`,key:e})),64))])):U.value?(e(),m(o,{key:1},[U.value.is_retry?(e(),m(`div`,Me,[p(l(T),{variant:`outline`,class:`text-warning-dark border-warning`},{default:r(()=>[...n[50]||=[a(`重试请求`,-1)]]),_:1}),s(`span`,Ne,[n[51]||=a(` 原始请求: `,-1),p(l(_),{variant:`link`,class:`h-auto p-0 text-xs font-mono text-primary underline`,onClick:n[3]||=e=>st(U.value.original_request_id)},{default:r(()=>[a(h(U.value.original_request_id?.slice(0,8)),1)]),_:1})])])):f(``,!0),s(`div`,Pe,[s(`div`,null,[n[52]||=s(`span`,{class:`text-muted-foreground`},`类型:`,-1),n[53]||=a(),p(l(T),{variant:U.value.api_type===`openai`?`default`:`secondary`,class:`text-xs`},{default:r(()=>[a(h(U.value.api_type),1)]),_:1},8,[`variant`])]),s(`div`,null,[n[54]||=s(`span`,{class:`text-muted-foreground`},`模型:`,-1),n[55]||=a(),s(`span`,Fe,h(U.value.model||`-`),1)]),U.value.original_model?(e(),m(`div`,Ie,[n[56]||=s(`span`,{class:`text-muted-foreground`},`模型替换:`,-1),n[57]||=a(),s(`span`,Le,h(U.value.original_model)+` → `+h(U.value.backend_model||U.value.model),1)])):f(``,!0),s(`div`,null,[n[58]||=s(`span`,{class:`text-muted-foreground`},`状态码:`,-1),n[59]||=a(),p(l(T),{variant:(U.value.status_code??0)<400?`default`:`destructive`,class:`text-xs`},{default:r(()=>[a(h(U.value.status_code||`-`),1)]),_:1},8,[`variant`])]),s(`div`,null,[n[60]||=s(`span`,{class:`text-muted-foreground`},`延迟:`,-1),n[61]||=a(),s(`span`,Re,h(U.value.latency_ms?U.value.latency_ms+`ms`:`-`),1)]),s(`div`,null,[n[62]||=s(`span`,{class:`text-muted-foreground`},`流式:`,-1),n[63]||=a(),s(`span`,ze,h(U.value.is_stream?`Yes`:`No`),1)]),s(`div`,null,[n[64]||=s(`span`,{class:`text-muted-foreground`},`时间:`,-1),n[65]||=a(),s(`span`,Be,h(ct(U.value.created_at)),1)])]),p(l(y),{open:W.value,"onUpdate:open":n[7]||=e=>W.value=e,class:`border rounded-md`},{default:r(()=>[p(l(b),{"as-child":``},{default:r(()=>[p(l(_),{variant:`ghost`,class:`w-full px-4 py-3 text-left text-sm font-medium text-foreground bg-muted/50 hover:bg-muted rounded-none rounded-t-md flex items-center gap-2`},{default:r(()=>[s(`span`,{class:c([`text-xs transition-transform`,W.value?`rotate-0`:`-rotate-90`])},`▼`,2),n[66]||=a(` 客户端原始请求 `,-1)]),_:1})]),_:1}),p(l(v),null,{default:r(()=>[s(`div`,Ve,[s(`div`,He,[p(l(_),{variant:`ghost`,size:`xs`,class:c(J.client_request===`structured`?`bg-background shadow`:``),onClick:n[4]||=e=>J.client_request=`structured`},{default:r(()=>[...n[67]||=[a(`结构化`,-1)]]),_:1},8,[`class`]),p(l(_),{variant:`ghost`,size:`xs`,class:c(J.client_request===`raw`?`bg-background shadow`:``),onClick:n[5]||=e=>J.client_request=`raw`},{default:r(()=>[...n[68]||=[a(`原始 JSON`,-1)]]),_:1},8,[`class`])]),p(l(_),{variant:`ghost`,size:`xs`,class:`h-auto py-1`,onClick:n[6]||=e=>X(`client_request`)},{default:r(()=>[a(h(Y.value===`client_request`?`已复制`:`复制`),1)]),_:1})]),s(`div`,Ue,[p(k,{raw:at(U.value),"api-type":Z(U.value.api_type),mode:J.client_request},null,8,[`raw`,`api-type`,`mode`])])]),_:1})]),_:1},8,[`open`]),U.value.upstream_request&&!it(U.value)?(e(),i(l(y),{key:1,open:G.value,"onUpdate:open":n[11]||=e=>G.value=e,class:`border rounded-md`},{default:r(()=>[p(l(b),{"as-child":``},{default:r(()=>[p(l(_),{variant:`ghost`,class:`w-full px-4 py-3 text-left text-sm font-medium text-foreground bg-muted/50 hover:bg-muted rounded-none rounded-t-md flex items-center gap-2`},{default:r(()=>[s(`span`,{class:c([`text-xs transition-transform`,G.value?`rotate-0`:`-rotate-90`])},`▼`,2),n[69]||=a(` Router → LLM API 请求 `,-1)]),_:1})]),_:1}),p(l(v),null,{default:r(()=>[s(`div`,We,[s(`div`,Ge,[p(l(_),{variant:`ghost`,size:`xs`,class:c(J.upstream_request===`structured`?`bg-background shadow`:``),onClick:n[8]||=e=>J.upstream_request=`structured`},{default:r(()=>[...n[70]||=[a(`结构化`,-1)]]),_:1},8,[`class`]),p(l(_),{variant:`ghost`,size:`xs`,class:c(J.upstream_request===`raw`?`bg-background shadow`:``),onClick:n[9]||=e=>J.upstream_request=`raw`},{default:r(()=>[...n[71]||=[a(`原始 JSON`,-1)]]),_:1},8,[`class`])]),p(l(_),{variant:`ghost`,size:`xs`,class:`h-auto py-1`,onClick:n[10]||=e=>X(`upstream_request`)},{default:r(()=>[a(h(Y.value===`upstream_request`?`已复制`:`复制`),1)]),_:1})]),s(`div`,Ke,[p(k,{raw:U.value.upstream_request,"api-type":Z(U.value.api_type),"show-url":!0,mode:J.upstream_request},null,8,[`raw`,`api-type`,`mode`])])]),_:1})]),_:1},8,[`open`])):f(``,!0),it(U.value)?f(``,!0):(e(),i(l(y),{key:2,open:K.value,"onUpdate:open":n[15]||=e=>K.value=e,class:`border rounded-md`},{default:r(()=>[p(l(b),{"as-child":``},{default:r(()=>[p(l(_),{variant:`ghost`,class:`w-full px-4 py-3 text-left text-sm font-medium text-foreground bg-muted/50 hover:bg-muted rounded-none rounded-t-md flex items-center gap-2`},{default:r(()=>[s(`span`,{class:c([`text-xs transition-transform`,K.value?`rotate-0`:`-rotate-90`])},`▼`,2),n[72]||=a(` LLM API 返回的原始响应 `,-1)]),_:1})]),_:1}),p(l(v),null,{default:r(()=>[s(`div`,qe,[s(`div`,Je,[p(l(_),{variant:`ghost`,size:`xs`,class:c(J.upstream_response===`structured`?`bg-background shadow`:``),onClick:n[12]||=e=>J.upstream_response=`structured`},{default:r(()=>[...n[73]||=[a(`结构化`,-1)]]),_:1},8,[`class`]),p(l(_),{variant:`ghost`,size:`xs`,class:c(J.upstream_response===`raw`?`bg-background shadow`:``),onClick:n[13]||=e=>J.upstream_response=`raw`},{default:r(()=>[a(h(U.value.is_stream?`原始 SSE 文本`:`原始 JSON`),1)]),_:1},8,[`class`])]),p(l(_),{variant:`ghost`,size:`xs`,class:`h-auto py-1`,onClick:n[14]||=e=>X(`upstream_response`)},{default:r(()=>[a(h(Y.value===`upstream_response`?`已复制`:`复制`),1)]),_:1})]),s(`div`,Ye,[p(j,{raw:U.value.upstream_response||U.value.response_body||`{}`,"api-type":Z(U.value.api_type),"is-stream":!!U.value.is_stream,mode:J.upstream_response},null,8,[`raw`,`api-type`,`is-stream`,`mode`])])]),_:1})]),_:1},8,[`open`])),Q(U.value)?(e(),i(l(y),{key:3,open:q.value,"onUpdate:open":n[19]||=e=>q.value=e,class:`border rounded-md`},{default:r(()=>[p(l(b),{"as-child":``},{default:r(()=>[p(l(_),{variant:`ghost`,class:`w-full px-4 py-3 text-left text-sm font-medium text-foreground bg-muted/50 hover:bg-muted rounded-none rounded-t-md flex items-center gap-2`},{default:r(()=>[s(`span`,{class:c([`text-xs transition-transform`,q.value?`rotate-0`:`-rotate-90`])},`▼`,2),n[74]||=a(` Router → 客户端响应 `,-1)]),_:1})]),_:1}),p(l(v),null,{default:r(()=>[s(`div`,Xe,[s(`div`,Ze,[p(l(_),{variant:`ghost`,size:`xs`,class:c(J.client_response===`structured`?`bg-background shadow`:``),onClick:n[16]||=e=>J.client_response=`structured`},{default:r(()=>[...n[75]||=[a(`结构化`,-1)]]),_:1},8,[`class`]),p(l(_),{variant:`ghost`,size:`xs`,class:c(J.client_response===`raw`?`bg-background shadow`:``),onClick:n[17]||=e=>J.client_response=`raw`},{default:r(()=>[a(h(U.value.is_stream?`原始 SSE 文本`:`原始 JSON`),1)]),_:1},8,[`class`])]),p(l(_),{variant:`ghost`,size:`xs`,class:`h-auto py-1`,onClick:n[18]||=e=>X(`client_response`)},{default:r(()=>[a(h(Y.value===`client_response`?`已复制`:`复制`),1)]),_:1})]),s(`div`,Qe,[p(j,{raw:Q(U.value),"api-type":Z(U.value.api_type),"is-stream":!!U.value.is_stream,mode:J.client_response},null,8,[`raw`,`api-type`,`is-stream`,`mode`])])]),_:1})]),_:1},8,[`open`])):f(``,!0),U.value.error_message?(e(),i(l(de),{key:4,class:`bg-destructive/10 ring-destructive/20`},{default:r(()=>[p(l(fe),{class:`py-3 text-sm text-destructive`},{default:r(()=>[a(h(U.value.error_message),1)]),_:1})]),_:1})):f(``,!0)],64)):(e(),m(`div`,$e,`未找到日志`))]),_:1})]),_:1},8,[`open`]),p(l(S),{open:z.value,"onUpdate:open":n[23]||=e=>z.value=e},{default:r(()=>[p(l(le),null,{default:r(()=>[p(l(x),null,{default:r(()=>[p(l(C),null,{default:r(()=>[...n[76]||=[a(`清理日志`,-1)]]),_:1})]),_:1}),n[80]||=s(`p`,{class:`text-sm text-muted-foreground`},`删除指定天数之前的日志`,-1),s(`div`,et,[p(l(ue),{class:`block text-sm font-medium text-foreground mb-1`},{default:r(()=>[...n[77]||=[a(`保留最近天数`,-1)]]),_:1}),p(l(ge),{modelValue:B.value,"onUpdate:modelValue":n[21]||=e=>B.value=e,modelModifiers:{number:!0},type:`number`,min:1},null,8,[`modelValue`])]),p(l(se),null,{default:r(()=>[p(l(_),{variant:`outline`,onClick:n[22]||=e=>z.value=!1},{default:r(()=>[...n[78]||=[a(`取消`,-1)]]),_:1}),p(l(_),{variant:`destructive`,onClick:ft},{default:r(()=>[...n[79]||=[a(`确认清理`,-1)]]),_:1})]),_:1})]),_:1})]),_:1},8,[`open`])]))}});export{N as default};
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
import{F as e,K as t,L as n,M as r,S as i,Y as a,_ as o,b as s,f as c,g as l,h as u,mt as d,ot as f,t as p,u as m,v as h,x as g,y as _,yt as v}from"./client-Mb8fy_bC.js";import{a as y,i as b,n as x,r as S,t as C}from"./SelectValue-B32pgmTJ.js";import{n as w}from"./button-D54q76GQ.js";import{n as T,r as E,t as D}from"./CollapsibleTrigger-BFNhb19_.js";import{a as O,i as k,o as A,r as j,s as M,t as N}from"./dialog-DSH5k5Kj.js";import{a as P,c as F,i as I,n as L,o as R,r as z,t as B}from"./alert-dialog-BAR1JRmT.js";import{t as V}from"./Label-CXAeFn-r.js";import{n as H,r as U}from"./lib-BgOqOzXI.js";import{n as ee,t as te}from"./CardContent-CucI6u41.js";import{t as W}from"./CardHeader-d-DYsWxe.js";import{t as G}from"./CardTitle-CIDEQkWB.js";import{t as K}from"./Input-HN3Il0-c.js";var q={key:0,class:`text-sm text-destructive mt-1`},J={class:`border rounded-lg p-3 space-y-3`},Y={class:`flex gap-3`},X={class:`flex-1`},Z={key:0,class:`text-sm text-destructive mt-1`},Q={class:`flex-1`},ne={key:0,class:`text-sm text-destructive mt-1`},re={class:`border rounded-lg p-3 space-y-3`},ie={class:`flex items-center justify-between`},ae={class:`flex items-end gap-2`},oe={class:`w-24`},se={key:0,class:`text-sm text-destructive mt-1`},ce={class:`w-24`},le={key:0,class:`text-sm text-destructive mt-1`},ue={class:`flex gap-3`},de={class:`flex-1`},fe={key:0,class:`text-sm text-destructive mt-1`},pe={class:`flex-1`},me={key:0,class:`text-sm text-destructive mt-1`},he={key:0,class:`text-sm text-muted-foreground`},ge={key:1,class:`border rounded-lg p-3 space-y-3`},_e={class:`flex items-center justify-between`},ve={key:0,class:`text-sm text-destructive`},ye={class:`flex gap-3`},be={class:`flex-1`},xe={key:0,class:`text-sm text-destructive mt-1`},Se={class:`flex-1`},Ce={key:0,class:`text-sm text-destructive mt-1`},we={class:`flex justify-end gap-1`},Te={key:1,class:`text-sm text-muted-foreground`},Ee=i({__name:`MappingGroupFormDialog`,props:{open:{type:Boolean},editingId:{},form:{},providers:{},providerModels:{}},emits:[`update:open`,`save`,`addWindow`,`removeWindow`,`addTarget`,`removeTarget`,`moveTargetUp`,`moveTargetDown`],setup(r,{emit:i}){let p=r,T=i,E=u(()=>p.providerModels.get(p.form.default.provider_id)||[]);function D(e){let t=p.form.windows[e]?.target?.provider_id;return t&&p.providerModels.get(t)||[]}function P(e){if(typeof e!=`string`)return;p.form.default.provider_id=e;let t=p.providerModels.get(e)||[];p.form.default.backend_model=t[0]||``}function F(e,t){if(typeof t!=`string`)return;p.form.windows[e].target.provider_id=t;let n=p.providerModels.get(t)||[];p.form.windows[e].target.backend_model=n[0]||``}function I(e){let t=p.form.targets[e]?.provider_id;return t&&p.providerModels.get(t)||[]}function L(e,t){if(typeof t!=`string`)return;p.form.targets[e].provider_id=t;let n=p.providerModels.get(t)||[];p.form.targets[e].backend_model=n[0]||``}function R(){H()&&T(`save`)}let z=/^\d{2}:\d{2}$/,B=f({});function H(){let e={};return p.form.client_model.trim()||(e.client_model=`请输入客户端模型名称`),p.form.strategy===`scheduled`?(p.form.default.provider_id||(e[`default.provider_id`]=`请选择供应商`),p.form.default.backend_model||(e[`default.backend_model`]=`请选择后端模型`),p.form.windows.forEach((t,n)=>{z.test(t.start)||(e[`window.${n}.start`]=`格式:HH:MM`),z.test(t.end)||(e[`window.${n}.end`]=`格式:HH:MM`),t.target.provider_id||(e[`window.${n}.provider_id`]=`请选择供应商`),t.target.backend_model||(e[`window.${n}.backend_model`]=`请选择后端模型`)})):(p.form.targets.length===0&&(e.targets=`至少添加一个目标`),p.form.targets.forEach((t,n)=>{t.provider_id||(e[`target.${n}.provider_id`]=`请选择供应商`),t.backend_model||(e[`target.${n}.backend_model`]=`请选择后端模型`)})),B.value=e,Object.keys(e).length===0}return t(()=>p.open,e=>{e&&(B.value={})}),(t,i)=>(e(),o(d(M),{open:r.open,"onUpdate:open":i[7]||=e=>T(`update:open`,e)},{default:a(()=>[g(d(A),{class:`max-w-2xl`},{default:a(()=>[g(d(j),null,{default:a(()=>[g(d(N),null,{default:a(()=>[s(v(r.editingId?`编辑分组`:`添加分组`),1)]),_:1}),g(d(O),null,{default:a(()=>[...i[8]||=[s(`配置客户端模型到后端供应商模型的映射规则`,-1)]]),_:1})]),_:1}),l(`form`,{onSubmit:m(R,[`prevent`]),class:`space-y-4`},[l(`div`,null,[g(d(V),{class:`block text-sm font-medium text-foreground mb-1`},{default:a(()=>[...i[9]||=[s(`客户端模型`,-1)]]),_:1}),g(d(K),{modelValue:r.form.client_model,"onUpdate:modelValue":i[0]||=e=>r.form.client_model=e,type:`text`,required:``,onInput:i[1]||=e=>delete B.value.client_model},null,8,[`modelValue`]),B.value.client_model?(e(),_(`p`,q,v(B.value.client_model),1)):h(``,!0)]),l(`div`,null,[g(d(V),{class:`block text-sm font-medium text-foreground mb-1`},{default:a(()=>[...i[10]||=[s(`策略`,-1)]]),_:1}),g(d(y),{modelValue:r.form.strategy,"onUpdate:modelValue":i[2]||=e=>r.form.strategy=e},{default:a(()=>[g(d(x),null,{default:a(()=>[g(d(C),{placeholder:`选择策略`})]),_:1}),g(d(b),null,{default:a(()=>[g(d(S),{value:`scheduled`},{default:a(()=>[...i[11]||=[s(`定时切换 (scheduled)`,-1)]]),_:1}),g(d(S),{value:`round-robin`},{default:a(()=>[...i[12]||=[s(`轮询 (round-robin)`,-1)]]),_:1}),g(d(S),{value:`random`},{default:a(()=>[...i[13]||=[s(`随机 (random)`,-1)]]),_:1}),g(d(S),{value:`failover`},{default:a(()=>[...i[14]||=[s(`故障转移 (failover)`,-1)]]),_:1})]),_:1})]),_:1},8,[`modelValue`])]),r.form.strategy===`scheduled`?(e(),_(c,{key:0},[l(`div`,J,[i[17]||=l(`div`,{class:`text-sm font-medium text-foreground`},`默认目标`,-1),l(`div`,Y,[l(`div`,X,[g(d(V),{class:`block text-xs text-muted-foreground mb-1`},{default:a(()=>[...i[15]||=[s(`供应商`,-1)]]),_:1}),g(d(y),{"model-value":r.form.default.provider_id,"onUpdate:modelValue":P},{default:a(()=>[g(d(x),null,{default:a(()=>[g(d(C),{placeholder:`选择供应商`})]),_:1}),g(d(b),null,{default:a(()=>[(e(!0),_(c,null,n(r.providers,t=>(e(),o(d(S),{key:t.id,value:t.id},{default:a(()=>[s(v(t.name),1)]),_:2},1032,[`value`]))),128))]),_:1})]),_:1},8,[`model-value`]),B.value[`default.provider_id`]?(e(),_(`p`,Z,v(B.value[`default.provider_id`]),1)):h(``,!0)]),l(`div`,Q,[g(d(V),{class:`block text-xs text-muted-foreground mb-1`},{default:a(()=>[...i[16]||=[s(`后端模型`,-1)]]),_:1}),g(d(y),{modelValue:r.form.default.backend_model,"onUpdate:modelValue":i[3]||=e=>r.form.default.backend_model=e,disabled:E.value.length===0},{default:a(()=>[g(d(x),null,{default:a(()=>[g(d(C),{placeholder:E.value.length===0?`暂无可用模型`:`选择后端模型`},null,8,[`placeholder`])]),_:1}),g(d(b),null,{default:a(()=>[(e(!0),_(c,null,n(E.value,t=>(e(),o(d(S),{key:t,value:t},{default:a(()=>[s(v(t),1)]),_:2},1032,[`value`]))),128))]),_:1})]),_:1},8,[`modelValue`,`disabled`]),B.value[`default.backend_model`]?(e(),_(`p`,ne,v(B.value[`default.backend_model`]),1)):h(``,!0)])])]),l(`div`,re,[l(`div`,ie,[i[19]||=l(`div`,{class:`text-sm font-medium text-foreground`},`时间窗口`,-1),g(d(w),{type:`button`,variant:`outline`,size:`sm`,onClick:i[4]||=e=>T(`addWindow`)},{default:a(()=>[...i[18]||=[s(`添加窗口`,-1)]]),_:1})]),(e(!0),_(c,null,n(r.form.windows,(t,u)=>(e(),_(`div`,{key:u,class:`border rounded-md p-2 space-y-2`},[l(`div`,ae,[l(`div`,oe,[g(d(V),{class:`block text-xs text-muted-foreground mb-1`},{default:a(()=>[...i[20]||=[s(`开始`,-1)]]),_:1}),g(d(K),{modelValue:t.start,"onUpdate:modelValue":e=>t.start=e,type:`text`,placeholder:`HH:MM`,required:``,onInput:e=>delete B.value[`window.${u}.start`]},null,8,[`modelValue`,`onUpdate:modelValue`,`onInput`]),B.value[`window.${u}.start`]?(e(),_(`p`,se,v(B.value[`window.${u}.start`]),1)):h(``,!0)]),i[23]||=l(`span`,{class:`text-muted-foreground pb-1.5`},`-`,-1),l(`div`,ce,[g(d(V),{class:`block text-xs text-muted-foreground mb-1`},{default:a(()=>[...i[21]||=[s(`结束`,-1)]]),_:1}),g(d(K),{modelValue:t.end,"onUpdate:modelValue":e=>t.end=e,type:`text`,placeholder:`HH:MM`,required:``,onInput:e=>delete B.value[`window.${u}.end`]},null,8,[`modelValue`,`onUpdate:modelValue`,`onInput`]),B.value[`window.${u}.end`]?(e(),_(`p`,le,v(B.value[`window.${u}.end`]),1)):h(``,!0)]),i[24]||=l(`div`,{class:`flex-1`},null,-1),g(d(w),{type:`button`,variant:`ghost`,size:`sm`,class:`text-destructive shrink-0`,onClick:e=>T(`removeWindow`,u)},{default:a(()=>[...i[22]||=[s(`删除`,-1)]]),_:1},8,[`onClick`])]),l(`div`,ue,[l(`div`,de,[g(d(V),{class:`block text-xs text-muted-foreground mb-1`},{default:a(()=>[...i[25]||=[s(`供应商`,-1)]]),_:1}),g(d(y),{"model-value":t.target.provider_id,"onUpdate:modelValue":e=>F(u,e)},{default:a(()=>[g(d(x),null,{default:a(()=>[g(d(C),{placeholder:`选择供应商`})]),_:1}),g(d(b),null,{default:a(()=>[(e(!0),_(c,null,n(r.providers,t=>(e(),o(d(S),{key:t.id,value:t.id},{default:a(()=>[s(v(t.name),1)]),_:2},1032,[`value`]))),128))]),_:1})]),_:1},8,[`model-value`,`onUpdate:modelValue`]),B.value[`window.${u}.provider_id`]?(e(),_(`p`,fe,v(B.value[`window.${u}.provider_id`]),1)):h(``,!0)]),l(`div`,pe,[g(d(V),{class:`block text-xs text-muted-foreground mb-1`},{default:a(()=>[...i[26]||=[s(`后端模型`,-1)]]),_:1}),g(d(y),{modelValue:t.target.backend_model,"onUpdate:modelValue":e=>t.target.backend_model=e,disabled:D(u).length===0},{default:a(()=>[g(d(x),null,{default:a(()=>[g(d(C),{placeholder:D(u).length===0?`暂无可用模型`:`选择后端模型`},null,8,[`placeholder`])]),_:2},1024),g(d(b),null,{default:a(()=>[(e(!0),_(c,null,n(D(u),t=>(e(),o(d(S),{key:t,value:t},{default:a(()=>[s(v(t),1)]),_:2},1032,[`value`]))),128))]),_:2},1024)]),_:2},1032,[`modelValue`,`onUpdate:modelValue`,`disabled`]),B.value[`window.${u}.backend_model`]?(e(),_(`p`,me,v(B.value[`window.${u}.backend_model`]),1)):h(``,!0)])])]))),128)),r.form.windows.length===0?(e(),_(`div`,he,`暂无窗口`)):h(``,!0)])],64)):(e(),_(`div`,ge,[l(`div`,_e,[i[28]||=l(`div`,{class:`text-sm font-medium text-foreground`},`目标列表`,-1),g(d(w),{type:`button`,variant:`outline`,size:`sm`,onClick:i[5]||=e=>T(`addTarget`)},{default:a(()=>[...i[27]||=[s(`添加目标`,-1)]]),_:1})]),B.value.targets?(e(),_(`p`,ve,v(B.value.targets),1)):h(``,!0),(e(!0),_(c,null,n(r.form.targets,(t,u)=>(e(),_(`div`,{key:u,class:`border rounded-md p-2 space-y-2`},[l(`div`,ye,[l(`div`,be,[g(d(V),{class:`block text-xs text-muted-foreground mb-1`},{default:a(()=>[...i[29]||=[s(`供应商`,-1)]]),_:1}),g(d(y),{"model-value":t.provider_id,"onUpdate:modelValue":e=>L(u,e)},{default:a(()=>[g(d(x),null,{default:a(()=>[g(d(C),{placeholder:`选择供应商`})]),_:1}),g(d(b),null,{default:a(()=>[(e(!0),_(c,null,n(r.providers,t=>(e(),o(d(S),{key:t.id,value:t.id},{default:a(()=>[s(v(t.name),1)]),_:2},1032,[`value`]))),128))]),_:1})]),_:1},8,[`model-value`,`onUpdate:modelValue`]),B.value[`target.${u}.provider_id`]?(e(),_(`p`,xe,v(B.value[`target.${u}.provider_id`]),1)):h(``,!0)]),l(`div`,Se,[g(d(V),{class:`block text-xs text-muted-foreground mb-1`},{default:a(()=>[...i[30]||=[s(`后端模型`,-1)]]),_:1}),g(d(y),{modelValue:t.backend_model,"onUpdate:modelValue":e=>t.backend_model=e,disabled:I(u).length===0},{default:a(()=>[g(d(x),null,{default:a(()=>[g(d(C),{placeholder:I(u).length===0?`暂无可用模型`:`选择后端模型`},null,8,[`placeholder`])]),_:2},1024),g(d(b),null,{default:a(()=>[(e(!0),_(c,null,n(I(u),t=>(e(),o(d(S),{key:t,value:t},{default:a(()=>[s(v(t),1)]),_:2},1032,[`value`]))),128))]),_:2},1024)]),_:2},1032,[`modelValue`,`onUpdate:modelValue`,`disabled`]),B.value[`target.${u}.backend_model`]?(e(),_(`p`,Ce,v(B.value[`target.${u}.backend_model`]),1)):h(``,!0)])]),l(`div`,we,[r.form.strategy===`failover`?(e(),o(d(w),{key:0,type:`button`,variant:`ghost`,size:`sm`,disabled:u===0,onClick:e=>T(`moveTargetUp`,u)},{default:a(()=>[...i[31]||=[s(`↑`,-1)]]),_:1},8,[`disabled`,`onClick`])):h(``,!0),r.form.strategy===`failover`?(e(),o(d(w),{key:1,type:`button`,variant:`ghost`,size:`sm`,disabled:u===r.form.targets.length-1,onClick:e=>T(`moveTargetDown`,u)},{default:a(()=>[...i[32]||=[s(`↓`,-1)]]),_:1},8,[`disabled`,`onClick`])):h(``,!0),g(d(w),{type:`button`,variant:`ghost`,size:`sm`,class:`text-destructive shrink-0`,onClick:e=>T(`removeTarget`,u)},{default:a(()=>[...i[33]||=[s(`删除`,-1)]]),_:1},8,[`onClick`])])]))),128)),r.form.targets.length===0?(e(),_(`div`,Te,`暂无目标`)):h(``,!0)])),g(d(k),null,{default:a(()=>[g(d(w),{type:`button`,variant:`outline`,onClick:i[6]||=e=>T(`update:open`,!1)},{default:a(()=>[...i[34]||=[s(`取消`,-1)]]),_:1}),g(d(w),{type:`submit`},{default:a(()=>[...i[35]||=[s(`保存`,-1)]]),_:1})]),_:1})],32)]),_:1})]),_:1},8,[`open`]))}}),De=i({__name:`MappingGroupDeleteDialog`,props:{target:{}},emits:[`confirm`,`cancel`],setup(t,{emit:n}){let r=n;return(n,i)=>(e(),o(d(F),{open:!!t.target,"onUpdate:open":i[1]||=e=>{e||r(`cancel`)}},{default:a(()=>[g(d(P),null,{default:a(()=>[g(d(L),null,{default:a(()=>[g(d(B),null,{default:a(()=>[...i[2]||=[s(`确认删除`,-1)]]),_:1}),g(d(I),null,{default:a(()=>[s(`确定要删除分组「`+v(t.target?.client_model)+`」吗?`,1)]),_:1})]),_:1}),g(d(z),null,{default:a(()=>[g(d(R),null,{default:a(()=>[...i[3]||=[s(`取消`,-1)]]),_:1}),g(d(w),{variant:`destructive`,onClick:i[0]||=e=>r(`confirm`)},{default:a(()=>[...i[4]||=[s(`删除`,-1)]]),_:1})]),_:1})]),_:1})]),_:1},8,[`open`]))}}),Oe={class:`p-6`},ke={class:`flex items-center justify-between mb-4`},Ae={class:`space-y-4`},je={class:`flex items-center gap-3`},Me={class:`flex items-center gap-2`},Ne={key:0,class:`space-y-3`},Pe={class:`flex items-center gap-2 text-sm`},$={class:`font-mono`},Fe={key:0,class:`space-y-2`},Ie={class:`font-mono text-xs bg-muted px-2 py-0.5 rounded`},Le={class:`font-mono`},Re={key:1,class:`text-sm text-muted-foreground`},ze={key:1,class:`space-y-2`},Be={key:0,class:`text-muted-foreground text-xs`},Ve={class:`font-mono`},He={key:0,class:`text-sm text-muted-foreground`},Ue={key:0,class:`text-center text-muted-foreground py-12 bg-card rounded-xl border`},We=i({__name:`ModelMappings`,setup(t){let i={client_model:``,strategy:`scheduled`,default:{backend_model:``,provider_id:``},windows:[],targets:[]},m=f([]),y=f([]),b=f(!1),x=f(null),S=f(null),C=f({...i}),O=u(()=>{let e=new Map;for(let t of y.value)e.set(t.id,t.name);return e}),k=u(()=>{let e=new Map;for(let t of y.value){let n=t.models;Array.isArray(n)&&n.length>0&&e.set(t.id,[...n])}return e}),A=u(()=>m.value.map(e=>{let t={};try{t=JSON.parse(e.rule)}catch{}return{...e,parsedRule:t}}));async function j(){let e=await Promise.allSettled([p.getMappingGroups(),p.getProviders()]);e[0].status===`fulfilled`?m.value=e[0].value.data:console.error(`Failed to load groups:`,e[0].reason),e[1].status===`fulfilled`?y.value=e[1].value:(console.error(`Failed to load providers:`,e[1].reason),H.error(`加载供应商失败`))}function M(){x.value=null;let e=y.value[0]?.id||``;C.value={client_model:``,strategy:`scheduled`,default:{backend_model:(k.value.get(e)||[])[0]||``,provider_id:e},windows:[],targets:[]},b.value=!0}function N(e){x.value=e.id;let t={};try{t=JSON.parse(e.rule)}catch{}if(e.strategy===`scheduled`)C.value={...i,client_model:e.client_model,strategy:e.strategy,default:{backend_model:t.default?.backend_model||``,provider_id:t.default?.provider_id||y.value[0]?.id||``},windows:t.windows?JSON.parse(JSON.stringify(t.windows)):[]};else{let n=y.value[0]?.id||``,r=k.value.get(n)||[];C.value={...i,client_model:e.client_model,strategy:e.strategy,targets:Array.isArray(t.targets)?t.targets.map(e=>({backend_model:e.backend_model||``,provider_id:e.provider_id||n})):[{backend_model:r[0]||``,provider_id:n}]}}b.value=!0}function P(){let e=y.value[0]?.id||``,t=k.value.get(e)||[];C.value.windows.push({start:``,end:``,target:{backend_model:t[0]||``,provider_id:e}})}function F(e){C.value.windows.splice(e,1)}function I(){let e=y.value[0]?.id||``,t=k.value.get(e)||[];C.value.targets.push({backend_model:t[0]||``,provider_id:e})}function L(e){C.value.targets.splice(e,1)}function R(e){if(e<=0)return;let t=C.value.targets;[t[e-1],t[e]]=[t[e],t[e-1]]}function z(e){let t=C.value.targets;e>=t.length-1||([t[e],t[e+1]]=[t[e+1],t[e]])}async function B(){try{let e;e=C.value.strategy===`scheduled`?JSON.stringify({default:C.value.default,windows:C.value.windows}):JSON.stringify({targets:C.value.targets});let t={client_model:C.value.client_model,strategy:C.value.strategy,rule:e};x.value?await p.updateMappingGroup(x.value,t):await p.createMappingGroup(t),b.value=!1,await j()}catch(e){console.error(`Failed to save mapping group:`,e),H.error(`保存分组失败`)}}async function V(){let e=S.value;if(e){S.value=null;try{await p.deleteMappingGroup(e.id),await j()}catch(e){console.error(`Failed to delete mapping group:`,e),H.error(`删除分组失败`)}}}return r(j),(t,r)=>(e(),_(`div`,Oe,[l(`div`,ke,[r[3]||=l(`h2`,{class:`text-lg font-semibold text-foreground`},`模型映射`,-1),g(d(w),{onClick:M,class:`flex items-center gap-1`},{default:a(()=>[...r[2]||=[l(`svg`,{class:`w-4 h-4`,fill:`none`,stroke:`currentColor`,viewBox:`0 0 24 24`},[l(`path`,{"stroke-linecap":`round`,"stroke-linejoin":`round`,"stroke-width":`2`,d:`M12 4v16m8-8H4`})],-1),s(` 添加分组 `,-1)]]),_:1})]),l(`div`,Ae,[(e(!0),_(c,null,n(A.value,t=>(e(),o(d(ee),{key:t.id},{default:a(()=>[g(d(E),{"default-open":!0},{default:a(()=>[g(d(W),{class:`flex flex-row items-center justify-between gap-4`},{default:a(()=>[l(`div`,je,[g(d(G),{class:`font-mono text-sm`},{default:a(()=>[s(v(t.client_model),1)]),_:2},1024),g(d(U),{variant:`secondary`},{default:a(()=>[s(v(t.strategy),1)]),_:2},1024)]),l(`div`,Me,[g(d(D),{"as-child":``},{default:a(()=>[g(d(w),{variant:`ghost`,size:`sm`},{default:a(()=>[...r[4]||=[s(` 展开 `,-1)]]),_:1})]),_:1}),g(d(w),{variant:`ghost`,size:`sm`,onClick:e=>N(t)},{default:a(()=>[...r[5]||=[s(`编辑`,-1)]]),_:1},8,[`onClick`]),g(d(w),{variant:`ghost`,size:`sm`,class:`text-destructive hover:text-destructive`,onClick:e=>S.value=t},{default:a(()=>[...r[6]||=[s(`删除`,-1)]]),_:1},8,[`onClick`])])]),_:2},1024),g(d(T),null,{default:a(()=>[g(d(te),null,{default:a(()=>[t.strategy===`scheduled`?(e(),_(`div`,Ne,[l(`div`,Pe,[r[7]||=l(`span`,{class:`text-muted-foreground`},`默认模型:`,-1),l(`span`,$,v(t.parsedRule.default?.backend_model||`-`),1),r[8]||=l(`span`,{class:`text-muted-foreground`},`/`,-1),l(`span`,null,v(O.value.get(t.parsedRule.default?.provider_id||``)||`-`),1)]),t.parsedRule.windows?.length?(e(),_(`div`,Fe,[r[10]||=l(`div`,{class:`text-sm text-muted-foreground`},`时间窗口`,-1),(e(!0),_(c,null,n(t.parsedRule.windows,(t,n)=>(e(),_(`div`,{key:n,class:`flex items-center gap-2 text-sm`},[l(`span`,Ie,v(t.start)+` - `+v(t.end),1),l(`span`,Le,v(t.target.backend_model),1),r[9]||=l(`span`,{class:`text-muted-foreground`},`/`,-1),l(`span`,null,v(O.value.get(t.target.provider_id)||t.target.provider_id),1)]))),128))])):(e(),_(`div`,Re,`无时间窗口`))])):(e(),_(`div`,ze,[(e(!0),_(c,null,n(t.parsedRule.targets||[],(n,i)=>(e(),_(`div`,{key:i,class:`flex items-center gap-2 text-sm`},[t.strategy===`failover`?(e(),_(`span`,Be,v(i+1)+`.`,1)):h(``,!0),l(`span`,Ve,v(n.backend_model),1),r[11]||=l(`span`,{class:`text-muted-foreground`},`/`,-1),l(`span`,null,v(O.value.get(n.provider_id)||n.provider_id),1)]))),128)),(t.parsedRule.targets||[]).length?h(``,!0):(e(),_(`div`,He,`无目标`))]))]),_:2},1024)]),_:2},1024)]),_:2},1024)]),_:2},1024))),128)),m.value.length===0?(e(),_(`div`,Ue,` 暂无映射分组 `)):h(``,!0)]),g(Ee,{open:b.value,"onUpdate:open":r[0]||=e=>b.value=e,"editing-id":x.value,form:C.value,providers:y.value,"provider-models":k.value,onSave:B,onAddWindow:P,onRemoveWindow:F,onAddTarget:I,onRemoveTarget:L,onMoveTargetUp:R,onMoveTargetDown:z},null,8,[`open`,`editing-id`,`form`,`providers`,`provider-models`]),g(De,{target:S.value,onConfirm:V,onCancel:r[1]||=e=>S.value=null},null,8,[`target`])]))}});export{We as default};
|
|
@@ -1 +1 @@
|
|
|
1
|
-
import{A as e,F as t,K as n,L as r,M as i,N as a,R as o,S as s,W as c,Y as l,_ as u,_t as d,b as f,dt as p,f as m,g as h,gt as g,h as _,it as v,k as y,mt as b,ot as x,q as S,t as C,v as w,vt as T,w as E,x as D,y as O,yt as k}from"./client-DvdghFBq.js";import{t as A}from"./createLucideIcon-DCD7INQf.js";import{E as j,b as M,f as N,i as P,n as F,r as I,w as L}from"./button-CfQs66fX.js";import{n as R,t as ee}from"./useNonce-ClXGIm-8.js";import{S as te,c as z,h as ne,l as re}from"./Collection-CQ4pV54w.js";import{t as B}from"./useForwardExpose-u2vjohek.js";import{n as V,r as H,t as U}from"./CollapsibleTrigger-BvYqNbGA.js";import{n as ie,r as ae,s as oe,t as se}from"./dialog-DQFRGKR6.js";import{i as ce,n as le,r as ue,t as de}from"./TabsTrigger-DBAYM66g.js";import{n as fe,r as W}from"./lib-BJNsNHLO.js";import{n as G,t as K}from"./CardContent-B40ArIqh.js";import{t as q}from"./CardHeader-BjkSQf27.js";import{t as J}from"./CardTitle-DjG2kSF3.js";import{a as pe,i as Y,n as X,o as me,r as he,t as ge}from"./TableHeader-DAOs6nSA.js";import{n as _e,r as ve,t as ye}from"./LogResponseViewer-B9kSncNr.js";var be=A(`brain`,[[`path`,{d:`M12 18V5`,key:`adv99a`}],[`path`,{d:`M15 13a4.17 4.17 0 0 1-3-4 4.17 4.17 0 0 1-3 4`,key:`1e3is1`}],[`path`,{d:`M17.598 6.5A3 3 0 1 0 12 5a3 3 0 1 0-5.598 1.5`,key:`1gqd8o`}],[`path`,{d:`M17.997 5.125a4 4 0 0 1 2.526 5.77`,key:`iwvgf7`}],[`path`,{d:`M18 18a4 4 0 0 0 2-7.464`,key:`efp6ie`}],[`path`,{d:`M19.967 17.483A4 4 0 1 1 12 18a4 4 0 1 1-7.967-.517`,key:`1gq6am`}],[`path`,{d:`M6 18a4 4 0 0 1-2-7.464`,key:`k1g0md`}],[`path`,{d:`M6.003 5.125a4 4 0 0 0-2.526 5.77`,key:`q97ue3`}]]),xe=A(`chevron-right`,[[`path`,{d:`m9 18 6-6-6-6`,key:`mthhwq`}]]),Se=A(`message-square`,[[`path`,{d:`M22 17a2 2 0 0 1-2 2H6.828a2 2 0 0 0-1.414.586l-2.202 2.202A.71.71 0 0 1 2 21.286V5a2 2 0 0 1 2-2h16a2 2 0 0 1 2 2z`,key:`18887p`}]]),Ce=A(`wrench`,[[`path`,{d:`M14.7 6.3a1 1 0 0 0 0 1.4l1.6 1.6a1 1 0 0 0 1.4 0l3.106-3.105c.32-.322.863-.22.983.218a6 6 0 0 1-8.259 7.057l-7.91 7.91a1 1 0 0 1-2.999-3l7.91-7.91a6 6 0 0 1 7.057-8.259c.438.12.54.662.219.984z`,key:`1ngwbx`}]]),[Z,we]=te(`ScrollAreaRoot`),Te=s({__name:`ScrollAreaRoot`,props:{type:{type:String,required:!1,default:`hover`},dir:{type:String,required:!1},scrollHideDelay:{type:Number,required:!1,default:600},asChild:{type:Boolean,required:!1},as:{type:null,required:!1}},setup(e,{expose:n}){let r=e,i=x(0),a=x(0),s=x(),c=x(),d=x(),f=x(),m=x(!1),h=x(!1),{type:g,dir:_,scrollHideDelay:v}=p(r),y=ne(_);function S(){s.value?.scrollTo({top:0})}function C(){s.value?.scrollTo({top:0,left:0})}n({viewport:s,scrollTop:S,scrollTopLeft:C});let{forwardRef:w,currentElement:E}=B();return we({type:g,dir:y,scrollHideDelay:v,scrollArea:E,viewport:s,onViewportChange:e=>{s.value=e||void 0},content:c,onContentChange:e=>{c.value=e},scrollbarX:d,scrollbarXEnabled:m,scrollbarY:f,scrollbarYEnabled:h,onScrollbarXChange:e=>{d.value=e||void 0},onScrollbarYChange:e=>{f.value=e||void 0},onScrollbarXEnabledChange:e=>{m.value=e},onScrollbarYEnabledChange:e=>{h.value=e},onCornerWidthChange:e=>{i.value=e},onCornerHeightChange:e=>{a.value=e}}),(e,n)=>(t(),u(b(P),{ref:b(w),"as-child":r.asChild,as:e.as,dir:b(y),style:T({position:`relative`,"--reka-scroll-area-corner-width":`${i.value}px`,"--reka-scroll-area-corner-height":`${a.value}px`})},{default:l(()=>[o(e.$slots,`default`)]),_:3},8,[`as-child`,`as`,`dir`,`style`]))}}),Ee=s({__name:`ScrollAreaCornerImpl`,setup(e){let r=Z(),i=x(0),a=x(0),s=_(()=>!!i.value&&!!a.value);function c(){let e=r.scrollbarX.value?.offsetHeight||0;r.onCornerHeightChange(e),a.value=e}function d(){let e=r.scrollbarY.value?.offsetWidth||0;r.onCornerWidthChange(e),i.value=e}return N(r.scrollbarX.value,c),N(r.scrollbarY.value,d),n(()=>r.scrollbarX.value,c),n(()=>r.scrollbarY.value,d),(e,n)=>s.value?(t(),u(b(P),y({key:0,style:{width:`${i.value}px`,height:`${a.value}px`,position:`absolute`,right:b(r).dir.value===`ltr`?0:void 0,left:b(r).dir.value===`rtl`?0:void 0,bottom:0}},e.$parent?.$props),{default:l(()=>[o(e.$slots,`default`)]),_:3},16,[`style`])):w(`v-if`,!0)}}),De=s({__name:`ScrollAreaCorner`,props:{asChild:{type:Boolean,required:!1},as:{type:null,required:!1}},setup(e){let n=e,{forwardRef:r}=B(),i=Z(),a=_(()=>!!i.scrollbarX.value&&!!i.scrollbarY.value),s=_(()=>i.type.value!==`scroll`&&a.value);return(e,i)=>s.value?(t(),u(Ee,y({key:0},n,{ref:b(r)}),{default:l(()=>[o(e.$slots,`default`)]),_:3},16)):w(`v-if`,!0)}});function Oe(e,t){return n=>{if(e[0]===e[1]||t[0]===t[1])return t[0];let r=(t[1]-t[0])/(e[1]-e[0]);return t[0]+r*(n-e[0])}}function ke(e){let t=Ae(e.viewport,e.content),n=e.scrollbar.paddingStart+e.scrollbar.paddingEnd,r=(e.scrollbar.size-n)*t;return Math.max(r,18)}function Ae(e,t){let n=e/t;return Number.isNaN(n)?0:n}function je(e,t=()=>{}){let n={left:e.scrollLeft,top:e.scrollTop},r=0;return(function i(){let a={left:e.scrollLeft,top:e.scrollTop},o=n.left!==a.left,s=n.top!==a.top;(o||s)&&t(),n=a,r=window.requestAnimationFrame(i)})(),()=>window.cancelAnimationFrame(r)}function Me(e,t,n=`ltr`){let r=ke(t),i=t.scrollbar.paddingStart+t.scrollbar.paddingEnd,a=t.scrollbar.size-i,o=t.content-t.viewport,s=a-r,c=n===`ltr`?[0,o]:[o*-1,0],l=R(e,c[0],c[1]);return Oe([0,o],[0,s])(l)}function Ne(e){return e?Number.parseInt(e,10):0}function Pe(e,t,n,r=`ltr`){let i=ke(n),a=i/2,o=t||a,s=i-o,c=n.scrollbar.paddingStart+o,l=n.scrollbar.size-n.scrollbar.paddingEnd-s,u=n.content-n.viewport,d=r===`ltr`?[0,u]:[u*-1,0];return Oe([c,l],d)(e)}function Fe(e,t){return e>0&&e<t}var Ie=s({__name:`ScrollAreaScrollbarX`,setup(e){let n=Z(),r=We(),{forwardRef:a,currentElement:s}=B();i(()=>{s.value&&n.onScrollbarXChange(s.value)});let c=_(()=>r.sizes.value);return(e,i)=>(t(),u(qe,{ref:b(a),"is-horizontal":!0,"data-orientation":`horizontal`,style:T({bottom:0,left:b(n).dir.value===`rtl`?`var(--reka-scroll-area-corner-width)`:0,right:b(n).dir.value===`ltr`?`var(--reka-scroll-area-corner-width)`:0,"--reka-scroll-area-thumb-width":c.value?`${b(ke)(c.value)}px`:void 0}),onOnDragScroll:i[0]||=e=>b(r).onDragScroll(e.x)},{default:l(()=>[o(e.$slots,`default`)]),_:3},8,[`style`]))}}),Le=s({__name:`ScrollAreaScrollbarY`,setup(e){let n=Z(),r=We(),{forwardRef:a,currentElement:s}=B();i(()=>{s.value&&n.onScrollbarYChange(s.value)});let c=_(()=>r.sizes.value);return(e,i)=>(t(),u(qe,{ref:b(a),"is-horizontal":!1,"data-orientation":`vertical`,style:T({top:0,right:b(n).dir.value===`ltr`?0:void 0,left:b(n).dir.value===`rtl`?0:void 0,bottom:`var(--reka-scroll-area-corner-height)`,"--reka-scroll-area-thumb-height":c.value?`${b(ke)(c.value)}px`:void 0}),onOnDragScroll:i[0]||=e=>b(r).onDragScroll(e.y)},{default:l(()=>[o(e.$slots,`default`)]),_:3},8,[`style`]))}}),Re=s({__name:`ScrollAreaScrollbarAuto`,props:{forceMount:{type:Boolean,required:!1}},setup(e){let n=Z(),r=Q(),{forwardRef:a}=B(),s=x(!1),c=L(()=>{if(n.viewport.value){let e=n.viewport.value.offsetWidth<n.viewport.value.scrollWidth,t=n.viewport.value.offsetHeight<n.viewport.value.scrollHeight;s.value=r.isHorizontal.value?e:t}},10);return i(()=>c()),N(n.viewport,c),N(n.content,c),(e,n)=>(t(),u(b(z),{present:e.forceMount||s.value},{default:l(()=>[D(Ke,y(e.$attrs,{ref:b(a),"data-state":s.value?`visible`:`hidden`}),{default:l(()=>[o(e.$slots,`default`)]),_:3},16,[`data-state`])]),_:3},8,[`present`]))}}),ze=s({inheritAttrs:!1,__name:`ScrollAreaScrollbarGlimpse`,props:{forceMount:{type:Boolean,required:!1}},setup(e){let n=Z(),r=Q(),{forwardRef:s}=B(),{state:c,dispatch:d}=re(`hidden`,{hidden:{POINTER_ENTER:`glimpse`,SCROLL:`scrolling`},glimpse:{HIDE:`hidden`,POINTER_LEAVE:`hidden`,SCROLL:`scrolling`,POINTER_ENTER:`glimpse`},scrolling:{SCROLL_END:`idle`,POINTER_ENTER:`interacting`},interacting:{SCROLL:`interacting`,POINTER_LEAVE:`idle`},idle:{HIDE:`hidden`,SCROLL:`scrolling`,POINTER_ENTER:`interacting`}}),f=_(()=>c.value!==`hidden`);function p(){d(`POINTER_ENTER`)}function m(){d(`POINTER_LEAVE`)}let h=L(()=>d(`SCROLL_END`),100);return S(e=>{if(c.value===`glimpse`){let t=window.setTimeout(d,n.scrollHideDelay.value,`HIDE`);e(()=>{window.clearTimeout(t)})}}),S(e=>{if(c.value===`idle`){let t=window.setTimeout(d,n.scrollHideDelay.value,`HIDE`);e(()=>{window.clearTimeout(t)})}}),S(e=>{let t=n.viewport.value,i=r.isHorizontal.value?`scrollLeft`:`scrollTop`;if(t){let n=t[i],r=()=>{let e=t[i];n!==e&&(d(`SCROLL`),h()),n=e};t.addEventListener(`scroll`,r),e(()=>{t.removeEventListener(`scroll`,r)})}}),i(()=>{let e=n.scrollArea.value;e&&(e.addEventListener(`pointerenter`,p),e.addEventListener(`pointerleave`,m))}),a(()=>{let e=n.scrollArea.value;e&&(e.removeEventListener(`pointerenter`,p),e.removeEventListener(`pointerleave`,m))}),(e,n)=>(t(),u(b(z),{present:e.forceMount||f.value},{default:l(()=>[D(Re,y(e.$attrs,{ref:b(s),"data-state":f.value?`visible`:`hidden`}),{default:l(()=>[o(e.$slots,`default`)]),_:3},16,[`data-state`])]),_:3},8,[`present`]))}}),Be=s({inheritAttrs:!1,__name:`ScrollAreaScrollbarHover`,props:{forceMount:{type:Boolean,required:!1}},setup(e){let n=Z(),{forwardRef:r}=B(),s,c=x(!1);function d(){window.clearTimeout(s),c.value=!0}function f(){s=window.setTimeout(()=>{c.value=!1},n.scrollHideDelay.value)}return i(()=>{let e=n.scrollArea.value;e&&(e.addEventListener(`pointerenter`,d),e.addEventListener(`pointerleave`,f))}),a(()=>{let e=n.scrollArea.value;e&&(window.clearTimeout(s),e.removeEventListener(`pointerenter`,d),e.removeEventListener(`pointerleave`,f))}),(e,n)=>(t(),u(b(z),{present:e.forceMount||c.value},{default:l(()=>[D(Re,y(e.$attrs,{ref:b(r),"data-state":c.value?`visible`:`hidden`}),{default:l(()=>[o(e.$slots,`default`)]),_:3},16,[`data-state`])]),_:3},8,[`present`]))}}),Ve=s({__name:`ScrollAreaScrollbarScroll`,props:{forceMount:{type:Boolean,required:!1}},setup(e){let n=Z(),r=Q(),{forwardRef:i}=B(),{state:a,dispatch:s}=re(`hidden`,{hidden:{SCROLL:`scrolling`},scrolling:{SCROLL_END:`idle`,POINTER_ENTER:`interacting`},interacting:{SCROLL:`interacting`,POINTER_LEAVE:`idle`},idle:{HIDE:`hidden`,SCROLL:`scrolling`,POINTER_ENTER:`interacting`}}),c=_(()=>a.value!==`hidden`);S(e=>{if(a.value===`idle`){let t=window.setTimeout(s,n.scrollHideDelay.value,`HIDE`);e(()=>{window.clearTimeout(t)})}});let d=L(()=>s(`SCROLL_END`),100);return S(e=>{let t=n.viewport.value,i=r.isHorizontal.value?`scrollLeft`:`scrollTop`;if(t){let n=t[i],r=()=>{let e=t[i];n!==e&&(s(`SCROLL`),d()),n=e};t.addEventListener(`scroll`,r),e(()=>{t.removeEventListener(`scroll`,r)})}}),(e,n)=>(t(),u(b(z),{present:e.forceMount||c.value},{default:l(()=>[D(Ke,y(e.$attrs,{ref:b(i),"data-state":c.value?`visible`:`hidden`}),{default:l(()=>[o(e.$slots,`default`)]),_:3},16,[`data-state`])]),_:3},8,[`present`]))}}),[Q,He]=te(`ScrollAreaScrollbar`),Ue=s({inheritAttrs:!1,__name:`ScrollAreaScrollbar`,props:{orientation:{type:String,required:!1,default:`vertical`},forceMount:{type:Boolean,required:!1},asChild:{type:Boolean,required:!1},as:{type:null,required:!1,default:`div`}},setup(e){let r=e,{forwardRef:i}=B(),s=Z(),c=_(()=>r.orientation===`horizontal`);n(c,()=>{c.value?s.onScrollbarXEnabledChange(!0):s.onScrollbarYEnabledChange(!0)},{immediate:!0}),a(()=>{s.onScrollbarXEnabledChange(!1),s.onScrollbarYEnabledChange(!1)});let{orientation:d,forceMount:f,asChild:m,as:h}=p(r);return He({orientation:d,forceMount:f,isHorizontal:c,as:h,asChild:m}),(e,n)=>b(s).type.value===`hover`?(t(),u(Be,y({key:0},e.$attrs,{ref:b(i),"force-mount":b(f)}),{default:l(()=>[o(e.$slots,`default`)]),_:3},16,[`force-mount`])):b(s).type.value===`scroll`?(t(),u(Ve,y({key:1},e.$attrs,{ref:b(i),"force-mount":b(f)}),{default:l(()=>[o(e.$slots,`default`)]),_:3},16,[`force-mount`])):b(s).type.value===`glimpse`?(t(),u(ze,y({key:2},e.$attrs,{ref:b(i),"force-mount":b(f)}),{default:l(()=>[o(e.$slots,`default`)]),_:3},16,[`force-mount`])):b(s).type.value===`auto`?(t(),u(Re,y({key:3},e.$attrs,{ref:b(i),"force-mount":b(f)}),{default:l(()=>[o(e.$slots,`default`)]),_:3},16,[`force-mount`])):b(s).type.value===`always`?(t(),u(Ke,y({key:4},e.$attrs,{ref:b(i),"data-state":`visible`}),{default:l(()=>[o(e.$slots,`default`)]),_:3},16)):w(`v-if`,!0)}}),[We,Ge]=te(`ScrollAreaScrollbarVisible`),Ke=s({__name:`ScrollAreaScrollbarVisible`,setup(e){let n=Z(),r=Q(),{forwardRef:i}=B(),a=x({content:0,viewport:0,scrollbar:{size:0,paddingStart:0,paddingEnd:0}}),s=_(()=>{let e=Ae(a.value.viewport,a.value.content);return e>0&&e<1}),c=x(),d=x(0);function f(e,t){if(v.value){let r=n.viewport.value.scrollLeft+e.deltaY;n.viewport.value.scrollLeft=r,Fe(r,t)&&e.preventDefault()}else{let r=n.viewport.value.scrollTop+e.deltaY;n.viewport.value.scrollTop=r,Fe(r,t)&&e.preventDefault()}}function p(e,t){v.value?d.value=t.x:d.value=t.y}function m(e){d.value=0}function h(e){a.value=e}function g(e,t){return Pe(e,d.value,a.value,t)}let v=_(()=>r.isHorizontal.value);function S(e){v.value?n.viewport.value.scrollLeft=g(e,n.dir.value):n.viewport.value.scrollTop=g(e)}function C(){if(v.value){if(n.viewport.value&&c.value){let e=n.viewport.value.scrollLeft,t=Me(e,a.value,n.dir.value);c.value.style.transform=`translate3d(${t}px, 0, 0)`}}else if(n.viewport.value&&c.value){let e=n.viewport.value.scrollTop,t=Me(e,a.value);c.value.style.transform=`translate3d(0, ${t}px, 0)`}}function w(e){c.value=e}return Ge({sizes:a,hasThumb:s,handleWheelScroll:f,handleThumbDown:p,handleThumbUp:m,handleSizeChange:h,onThumbPositionChange:C,onThumbChange:w,onDragScroll:S}),(e,n)=>v.value?(t(),u(Ie,y({key:0},e.$attrs,{ref:b(i)}),{default:l(()=>[o(e.$slots,`default`)]),_:3},16)):(t(),u(Le,y({key:1},e.$attrs,{ref:b(i)}),{default:l(()=>[o(e.$slots,`default`)]),_:3},16))}}),qe=s({__name:`ScrollAreaScrollbarImpl`,props:{isHorizontal:{type:Boolean,required:!0}},emits:[`onDragScroll`,`onWheelScroll`,`onThumbPointerDown`],setup(e,{emit:n}){let r=e,s=n,c=Z(),d=We(),f=Q(),{forwardRef:p,currentElement:m}=B(),h=x(``),g=x();function _(e){g.value&&s(`onDragScroll`,{x:e.clientX-g.value?.left,y:e.clientY-g.value?.top})}function v(e){e.button===0&&(e.target.setPointerCapture(e.pointerId),g.value=m.value.getBoundingClientRect(),h.value=document.body.style.webkitUserSelect,document.body.style.webkitUserSelect=`none`,c.viewport&&(c.viewport.value.style.scrollBehavior=`auto`),_(e))}function y(e){_(e)}function S(e){let t=e.target;t.hasPointerCapture(e.pointerId)&&t.releasePointerCapture(e.pointerId),document.body.style.webkitUserSelect=h.value,c.viewport&&(c.viewport.value.style.scrollBehavior=``),g.value=void 0}function C(e){let t=e.target,n=m.value?.contains(t),r=d.sizes.value.content-d.sizes.value.viewport;n&&d.handleWheelScroll(e,r)}i(()=>{document.addEventListener(`wheel`,C,{passive:!1})}),a(()=>{document.removeEventListener(`wheel`,C)});function w(){m.value&&(r.isHorizontal?d.handleSizeChange({content:c.viewport.value?.scrollWidth??0,viewport:c.viewport.value?.offsetWidth??0,scrollbar:{size:m.value.clientWidth??0,paddingStart:Ne(getComputedStyle(m.value).paddingLeft),paddingEnd:Ne(getComputedStyle(m.value).paddingRight)}}):d.handleSizeChange({content:c.viewport.value?.scrollHeight??0,viewport:c.viewport.value?.offsetHeight??0,scrollbar:{size:m.value?.clientHeight??0,paddingStart:Ne(getComputedStyle(m.value).paddingTop),paddingEnd:Ne(getComputedStyle(m.value).paddingBottom)}}),d.onThumbPositionChange())}return N(m,w),N(c.content,w),(e,n)=>(t(),u(b(P),{ref:b(p),style:{position:`absolute`},"data-scrollbarimpl":``,as:b(f).as.value,"as-child":b(f).asChild.value,onPointerdown:v,onPointermove:y,onPointerup:S},{default:l(()=>[o(e.$slots,`default`)]),_:3},8,[`as`,`as-child`]))}}),Je=s({__name:`ScrollAreaThumb`,props:{asChild:{type:Boolean,required:!1},as:{type:null,required:!1}},setup(e){let n=e,r=Z(),i=We();function s(e){let t=e.target.getBoundingClientRect(),n=e.clientX-t.left,r=e.clientY-t.top;i.handleThumbDown(e,{x:n,y:r})}function c(e){i.handleThumbUp(e)}let{forwardRef:d,currentElement:f}=B(),p=x(),m=_(()=>r.viewport.value);function h(){p.value||(p.value=je(m.value,i.onThumbPositionChange),i.onThumbPositionChange())}return j(_(()=>i.sizes.value),()=>{i.onThumbChange(f.value),m.value&&(i.onThumbPositionChange(),m.value.addEventListener(`scroll`,h))}),a(()=>{m.value.removeEventListener(`scroll`,h),r.viewport.value?.removeEventListener(`scroll`,h)}),(e,r)=>(t(),u(b(P),{ref:b(d),"data-state":b(i).hasThumb?`visible`:`hidden`,style:{width:`var(--reka-scroll-area-thumb-width)`,height:`var(--reka-scroll-area-thumb-height)`},"as-child":n.asChild,as:e.as,onPointerdown:s,onPointerup:c},{default:l(()=>[o(e.$slots,`default`)]),_:3},8,[`data-state`,`as-child`,`as`]))}}),Ye=s({inheritAttrs:!1,__name:`ScrollAreaViewport`,props:{nonce:{type:String,required:!1},asChild:{type:Boolean,required:!1},as:{type:null,required:!1}},setup(e,{expose:n}){let r=e,{nonce:a}=p(r),s=ee(a),c=Z(),u=x();i(()=>{c.onViewportChange(u.value),c.onContentChange(g.value)}),n({viewportElement:u});let{forwardRef:d,currentElement:g}=B();return(e,n)=>(t(),O(m,null,[h(`div`,y({ref_key:`viewportElement`,ref:u,"data-reka-scroll-area-viewport":``,style:{overflowX:b(c).scrollbarXEnabled.value?`scroll`:`hidden`,overflowY:b(c).scrollbarYEnabled.value?`scroll`:`hidden`}},e.$attrs,{tabindex:0}),[D(b(P),{ref:b(d),style:T({minWidth:b(c).scrollbarXEnabled.value?`fit-content`:void 0}),"as-child":r.asChild,as:e.as},{default:l(()=>[o(e.$slots,`default`)]),_:3},8,[`style`,`as-child`,`as`])],16),D(b(P),{as:`style`,nonce:b(s)},{default:l(()=>n[0]||=[f(` /* Hide scrollbars cross-browser and enable momentum scroll for touch devices */ [data-reka-scroll-area-viewport] { scrollbar-width:none; -ms-overflow-style:none; -webkit-overflow-scrolling:touch; } [data-reka-scroll-area-viewport]::-webkit-scrollbar { display:none; } `)]),_:1,__:[0]},8,[`nonce`])],64))}}),Xe=s({__name:`BaseSeparator`,props:{orientation:{type:String,required:!1,default:`horizontal`},decorative:{type:Boolean,required:!1},asChild:{type:Boolean,required:!1},as:{type:null,required:!1}},setup(e){let n=e,r=[`horizontal`,`vertical`];function i(e){return r.includes(e)}let a=_(()=>i(n.orientation)?n.orientation:`horizontal`),s=_(()=>a.value===`vertical`?n.orientation:void 0),c=_(()=>n.decorative?{role:`none`}:{"aria-orientation":s.value,role:`separator`});return(e,n)=>(t(),u(b(P),y({as:e.as,"as-child":e.asChild,"data-orientation":a.value},c.value),{default:l(()=>[o(e.$slots,`default`)]),_:3},16,[`as`,`as-child`,`data-orientation`]))}}),Ze=s({__name:`Separator`,props:{orientation:{type:String,required:!1,default:`horizontal`},decorative:{type:Boolean,required:!1},asChild:{type:Boolean,required:!1},as:{type:null,required:!1}},setup(e){let n=e;return(e,r)=>(t(),u(Xe,d(E(n)),{default:l(()=>[o(e.$slots,`default`)]),_:3},16))}}),Qe=s({__name:`ScrollBar`,props:{orientation:{default:`vertical`},forceMount:{type:Boolean},asChild:{type:Boolean},as:{},class:{type:[Boolean,null,String,Object,Array]}},setup(e){let n=e,r=M(n,`class`);return(i,a)=>(t(),u(b(Ue),y({"data-slot":`scroll-area-scrollbar`,"data-orientation":e.orientation},b(r),{class:b(I)(`data-[orientation=horizontal]:h-2.5 data-[orientation=horizontal]:flex-col data-[orientation=horizontal]:border-t data-[orientation=horizontal]:border-t-transparent data-[orientation=vertical]:h-full data-[orientation=vertical]:w-2.5 data-[orientation=vertical]:border-l data-[orientation=vertical]:border-l-transparent flex touch-none p-px transition-colors select-none`,n.class)}),{default:l(()=>[D(b(Je),{"data-slot":`scroll-area-thumb`,class:`rounded-full relative flex-1 bg-border`})]),_:1},16,[`data-orientation`,`class`]))}}),$e=s({__name:`ScrollArea`,props:{type:{},dir:{},scrollHideDelay:{},asChild:{type:Boolean},as:{},class:{type:[Boolean,null,String,Object,Array]}},setup(e){let n=e,r=M(n,`class`);return(e,i)=>(t(),u(b(Te),y({"data-slot":`scroll-area`},b(r),{class:b(I)(`relative`,n.class)}),{default:l(()=>[D(b(Ye),{"data-slot":`scroll-area-viewport`,class:`size-full rounded-[inherit] transition-[color,box-shadow] outline-none focus-visible:ring-[3px] focus-visible:ring-ring/50 focus-visible:outline-1`},{default:l(()=>[o(e.$slots,`default`)]),_:3}),D(Qe),D(b(De))]),_:3},16,[`class`]))}}),et={class:`grid grid-cols-2 lg:grid-cols-4 gap-4 mb-6`},tt={class:`text-2xl font-bold text-foreground mt-1`},nt={class:`text-xs text-muted-foreground mt-1`},rt={class:`text-2xl font-bold text-foreground mt-1`},it={class:`text-xs text-muted-foreground mt-1`},at={class:`text-2xl font-bold text-foreground mt-1`},ot={class:`text-xs text-muted-foreground mt-1`},st={class:`text-2xl font-bold text-foreground mt-1`},ct={class:`text-xs text-muted-foreground mt-1`},lt=s({__name:`MonitorHeader`,props:{stats:{},activeCount:{},streamCount:{}},setup(e){let n=e,r=_(()=>!n.stats||n.stats.totalRequests===0?`0.0`:(n.stats.errorCount/n.stats.totalRequests*100).toFixed(1)),i=_(()=>!n.stats||n.stats.totalRequests===0?`0.0`:(n.stats.retryCount/n.stats.totalRequests*100).toFixed(1)),a=_(()=>n.stats?n.stats.p50LatencyMs.toFixed(0):`--`);return(n,o)=>(t(),O(`div`,et,[D(b(G),null,{default:l(()=>[D(b(K),{class:`p-4`},{default:l(()=>[o[0]||=h(`p`,{class:`text-sm text-muted-foreground`},`活跃请求`,-1),h(`p`,tt,k(e.activeCount),1),h(`p`,nt,k(e.streamCount)+` 流式 / `+k(e.activeCount-e.streamCount)+` 非流式 `,1)]),_:1})]),_:1}),D(b(G),null,{default:l(()=>[D(b(K),{class:`p-4`},{default:l(()=>[o[1]||=h(`p`,{class:`text-sm text-muted-foreground`},`错误率`,-1),h(`p`,rt,k(r.value)+`%`,1),h(`p`,it,k(e.stats?.errorCount??0)+` / `+k(e.stats?.totalRequests??0),1)]),_:1})]),_:1}),D(b(G),null,{default:l(()=>[D(b(K),{class:`p-4`},{default:l(()=>[o[2]||=h(`p`,{class:`text-sm text-muted-foreground`},`P50 延迟`,-1),h(`p`,at,k(a.value)+`ms`,1),h(`p`,ot,` 平均 `+k(e.stats?.avgLatencyMs?.toFixed(0)??`--`)+`ms `,1)]),_:1})]),_:1}),D(b(G),null,{default:l(()=>[D(b(K),{class:`p-4`},{default:l(()=>[o[3]||=h(`p`,{class:`text-sm text-muted-foreground`},`重试率`,-1),h(`p`,st,k(i.value)+`%`,1),h(`p`,ct,k(e.stats?.retryCount??0)+` / `+k(e.stats?.totalRequests??0),1)]),_:1})]),_:1})]))}}),ut={class:`space-y-3`},dt={key:0,class:`text-sm text-muted-foreground`},ft={class:`flex items-center justify-between text-sm`},pt={class:`font-medium text-foreground`},mt={class:`text-muted-foreground`},ht={key:0,class:`h-2 bg-muted rounded-full overflow-hidden`},gt={key:1,class:`flex gap-3 text-xs text-muted-foreground`},_t=s({__name:`ConcurrencyPanel`,props:{providers:{}},setup(e){function n(e,t){let n=e/t;return n>=1?`bg-red-500`:n>=.8?`bg-orange-500`:n>=.5?`bg-yellow-500`:`bg-green-500`}return(i,a)=>(t(),O(`div`,ut,[e.providers.length===0?(t(),O(`div`,dt,` 暂无并发数据 `)):w(``,!0),(t(!0),O(m,null,r(e.providers,e=>(t(),O(`div`,{key:e.providerId,class:`space-y-1`},[h(`div`,ft,[h(`span`,pt,k(e.providerName),1),h(`span`,mt,[e.maxConcurrency===0?(t(),O(m,{key:0},[f(`未限制`)],64)):(t(),O(m,{key:1},[f(k(e.active)+` / `+k(e.maxConcurrency),1)],64))])]),e.maxConcurrency>0?(t(),O(`div`,ht,[h(`div`,{class:g([`h-full rounded-full transition-all duration-300`,n(e.active,e.maxConcurrency)]),style:T({width:`${Math.min(100,e.active/e.maxConcurrency*100)}%`})},null,6)])):w(``,!0),e.maxConcurrency>0?(t(),O(`div`,gt,[h(`span`,null,`排队: `+k(e.queued),1),h(`span`,null,`队列上限: `+k(e.maxQueueSize),1)])):w(``,!0)]))),128))]))}}),vt={key:0,class:`text-sm text-muted-foreground`},yt={key:1,class:`grid grid-cols-2 gap-3 text-sm`},bt={class:`font-medium text-foreground`},xt={class:`font-medium text-foreground`},St={class:`col-span-2`},Ct={class:`flex items-center justify-between`},wt={class:`text-muted-foreground`},Tt={class:`h-2 bg-muted rounded-full overflow-hidden mt-1`},Et={class:`font-medium text-foreground`},Dt={class:`font-medium text-foreground`},Ot={class:`col-span-2`},kt={class:`font-medium text-foreground`},At=s({__name:`RuntimePanel`,props:{runtime:{}},setup(e){let n=e,r=_(()=>!n.runtime||n.runtime.memoryUsage.heapTotal===0?0:Math.min(100,n.runtime.memoryUsage.heapUsed/n.runtime.memoryUsage.heapTotal*100));function i(e){let t=Math.floor(e/1e3);return`${Math.floor(t/3600)}h ${Math.floor(t%3600/60)}m ${t%60}s`}function a(e){return e<1024?`${e}B`:e<1024*1024?`${(e/1024).toFixed(1)}KB`:`${(e/(1024*1024)).toFixed(1)}MB`}return(n,o)=>e.runtime?(t(),O(`div`,yt,[h(`div`,null,[o[0]||=h(`p`,{class:`text-muted-foreground`},`运行时间`,-1),h(`p`,bt,k(i(e.runtime.uptimeMs)),1)]),h(`div`,null,[o[1]||=h(`p`,{class:`text-muted-foreground`},`内存 RSS`,-1),h(`p`,xt,k(a(e.runtime.memoryUsage.rss)),1)]),h(`div`,St,[h(`div`,Ct,[o[2]||=h(`p`,{class:`text-muted-foreground`},`Heap 使用`,-1),h(`p`,wt,k(a(e.runtime.memoryUsage.heapUsed))+` / `+k(a(e.runtime.memoryUsage.heapTotal)),1)]),h(`div`,Tt,[h(`div`,{class:`h-full bg-blue-500 rounded-full transition-all duration-300`,style:T({width:`${r.value}%`})},null,4)])]),h(`div`,null,[o[3]||=h(`p`,{class:`text-muted-foreground`},`Active Handles`,-1),h(`p`,Et,k(e.runtime.activeHandles),1)]),h(`div`,null,[o[4]||=h(`p`,{class:`text-muted-foreground`},`Active Requests`,-1),h(`p`,Dt,k(e.runtime.activeRequests),1)]),h(`div`,Ot,[o[5]||=h(`p`,{class:`text-muted-foreground`},`Event Loop 延迟`,-1),h(`p`,kt,k(e.runtime.eventLoopDelayMs.toFixed(2))+`ms`,1)])])):(t(),O(`div`,vt,`暂无运行时数据`))}}),jt={key:0,class:`text-sm text-muted-foreground`},Mt={key:1,class:`space-y-2`},Nt={class:`flex items-center justify-between text-sm`},Pt={class:`text-muted-foreground`},Ft={class:`h-2 bg-muted rounded-full overflow-hidden`},It=s({__name:`StatusCodePanel`,props:{byStatusCode:{}},setup(e){let n=e,i=_(()=>Object.values(n.byStatusCode).reduce((e,t)=>e+t,0)),a=_(()=>{let e=n.byStatusCode,t=i.value||1,r=o(e,200,299),a=o(e,400,499)-(e[429]||0),s=e[429]||0,c=o(e,500,599);return[{label:`2xx 成功`,count:r,percent:(r/t*100).toFixed(1),textClass:`text-green-600 dark:text-green-400`,barClass:`bg-green-500`},{label:`4xx 客户端错误`,count:a,percent:(a/t*100).toFixed(1),textClass:`text-yellow-600 dark:text-yellow-400`,barClass:`bg-yellow-500`},{label:`429 限流`,count:s,percent:(s/t*100).toFixed(1),textClass:`text-orange-600 dark:text-orange-400`,barClass:`bg-orange-500`},{label:`5xx 服务端错误`,count:c,percent:(c/t*100).toFixed(1),textClass:`text-red-600 dark:text-red-400`,barClass:`bg-red-500`}].filter(e=>e.count>0)});function o(e,t,n){let r=0;for(let[i,a]of Object.entries(e)){let e=Number(i);e>=t&&e<=n&&(r+=a)}return r}return(e,n)=>i.value===0?(t(),O(`div`,jt,`暂无状态码数据`)):(t(),O(`div`,Mt,[(t(!0),O(m,null,r(a.value,e=>(t(),O(`div`,{key:e.label,class:`space-y-1`},[h(`div`,Nt,[h(`span`,{class:g(e.textClass)},k(e.label),3),h(`span`,Pt,k(e.count)+` (`+k(e.percent)+`%) `,1)]),h(`div`,Ft,[h(`div`,{class:g([`h-full rounded-full transition-all duration-300`,e.barClass]),style:T({width:`${e.percent}%`})},null,6)])]))),128))]))}}),$=s({__name:`Separator`,props:{orientation:{default:`horizontal`},decorative:{type:Boolean,default:!0},asChild:{type:Boolean},as:{},class:{type:[Boolean,null,String,Object,Array]}},setup(e){let n=e,r=M(n,`class`);return(e,i)=>(t(),u(b(Ze),y({"data-slot":`separator`},b(r),{class:b(I)(`shrink-0 bg-border data-[orientation=horizontal]:h-px data-[orientation=horizontal]:w-full data-[orientation=vertical]:w-px data-[orientation=vertical]:self-stretch`,n.class)}),null,16,[`class`]))}}),Lt={key:0,class:`text-sm text-muted-foreground py-4 text-center`},Rt={key:1,class:`space-y-3`},zt={class:`flex items-center gap-2`},Bt={class:`font-medium text-foreground`},Vt={class:`text-xs text-muted-foreground font-mono`},Ht={class:`space-y-1.5 text-sm`},Ut={class:`flex justify-between`},Wt={class:`font-medium text-foreground`},Gt={class:`flex justify-between`},Kt={class:`font-medium text-foreground text-right max-w-[140px] truncate`},qt={class:`flex justify-between`},Jt={class:`font-medium text-foreground`},Yt={class:`flex justify-between`},Xt={class:`font-medium text-foreground`},Zt={class:`flex justify-between`},Qt={class:`font-medium text-foreground`},$t={class:`flex justify-between`},en={class:`font-medium text-foreground`},tn={class:`flex justify-between`},nn={class:`font-medium text-foreground`},rn={key:0,class:`flex items-center gap-1.5`},an={key:1,class:`flex items-center gap-1.5`},on={key:2},sn={class:`space-y-1`},cn={class:`text-muted-foreground w-4`},ln={class:`text-muted-foreground`},un={key:0,class:`text-red-500 truncate`},dn={key:3,class:`text-xs text-muted-foreground`},fn={key:4,class:`pt-2`},pn=s({__name:`RequestDetailPanel`,props:{request:{}},emits:[`viewDetail`],setup(e){let n=e,i=_(()=>n.request?(((n.request.completedAt??Date.now())-n.request.startTime)/1e3).toFixed(1):`--`),a=_(()=>{if(!n.request?.streamMetrics)return`--`;let e=n.request.streamMetrics;if(e.outputTokens==null||e.ttftMs==null)return`--`;let t=(n.request.completedAt??Date.now())-n.request.startTime;return t<=0?`--`:`${(e.outputTokens/(t/1e3)).toFixed(1)} tok/s`});function o(e){switch(e){case`pending`:return`default`;case`failed`:return`destructive`;case`completed`:return`secondary`;default:return`outline`}}function s(e){switch(e){case`pending`:return`进行中`;case`failed`:return`失败`;case`completed`:return`完成`;default:return e}}return(n,c)=>e.request?(t(),O(`div`,Rt,[h(`div`,zt,[h(`span`,Bt,k(e.request.model),1),e.request.isStream?(t(),u(b(W),{key:0,variant:`outline`,class:`text-xs`},{default:l(()=>[...c[1]||=[f(`SSE`,-1)]]),_:1})):w(``,!0),D(b(W),{variant:o(e.request.status)},{default:l(()=>[f(k(s(e.request.status)),1)]),_:1},8,[`variant`])]),h(`p`,Vt,k(e.request.id.slice(0,8)),1),h(`div`,Ht,[h(`div`,Ut,[c[2]||=h(`span`,{class:`text-muted-foreground`},`API 类型`,-1),h(`span`,Wt,k(e.request.apiType.toUpperCase()),1)]),D(b($)),h(`div`,Gt,[c[3]||=h(`span`,{class:`text-muted-foreground`},`Provider`,-1),h(`span`,Kt,k(e.request.providerName),1)]),D(b($)),h(`div`,qt,[c[4]||=h(`span`,{class:`text-muted-foreground`},`耗时`,-1),h(`span`,Jt,k(i.value)+`s`,1)]),D(b($)),h(`div`,Yt,[c[5]||=h(`span`,{class:`text-muted-foreground`},`TTFT`,-1),h(`span`,Xt,k(e.request.streamMetrics?.ttftMs==null?`--`:`${e.request.streamMetrics.ttftMs.toFixed(0)}ms`),1)]),D(b($)),h(`div`,Zt,[c[6]||=h(`span`,{class:`text-muted-foreground`},`Input Tokens`,-1),h(`span`,Qt,k(e.request.streamMetrics?.inputTokens??`--`),1)]),D(b($)),h(`div`,$t,[c[7]||=h(`span`,{class:`text-muted-foreground`},`Output Tokens`,-1),h(`span`,en,k(e.request.streamMetrics?.outputTokens==null?`--`:e.request.streamMetrics.outputTokens),1)]),D(b($)),h(`div`,tn,[c[8]||=h(`span`,{class:`text-muted-foreground`},`速度`,-1),h(`span`,nn,k(a.value),1)])]),e.request.streamMetrics?.isComplete?(t(),O(`div`,rn,[D(b(W),{variant:`secondary`},{default:l(()=>[...c[9]||=[f(`已完成`,-1)]]),_:1}),e.request.streamMetrics.stopReason?(t(),u(b(W),{key:0,variant:`outline`},{default:l(()=>[f(k(e.request.streamMetrics.stopReason),1)]),_:1})):w(``,!0)])):e.request.status===`pending`?(t(),O(`div`,an,[D(b(W),null,{default:l(()=>[...c[10]||=[f(`进行中`,-1)]]),_:1})])):w(``,!0),e.request.attempts.length>0?(t(),O(`div`,on,[c[11]||=h(`p`,{class:`text-xs text-muted-foreground mb-1`},`尝试历史`,-1),h(`div`,sn,[(t(!0),O(m,null,r(e.request.attempts,(e,n)=>(t(),O(`div`,{key:n,class:`flex items-center gap-2 text-xs bg-muted/50 rounded px-2 py-1`},[h(`span`,cn,`#`+k(n+1),1),h(`span`,{class:g(e.statusCode&&e.statusCode<400?`text-green-600`:`text-red-500`)},k(e.statusCode??`N/A`),3),h(`span`,ln,k(e.latencyMs.toFixed(0))+`ms`,1),e.error?(t(),O(`span`,un,k(e.error),1)):w(``,!0)]))),128))])])):w(``,!0),e.request.clientIp?(t(),O(`div`,dn,` IP: `+k(e.request.clientIp),1)):w(``,!0),e.request.status===`completed`||e.request.status===`failed`?(t(),O(`div`,fn,[D(b(F),{variant:`outline`,size:`sm`,class:`w-full`,onClick:c[0]||=t=>n.$emit(`viewDetail`,e.request.id)},{default:l(()=>[...c[12]||=[f(` 查看完整日志 `,-1)]]),_:1})])):w(``,!0)])):(t(),O(`div`,Lt,` 点击请求查看详情 `))}}),mn={key:0,class:`flex items-center justify-center h-full text-sm text-muted-foreground`},hn={key:1,class:`flex items-center justify-center h-full text-sm text-muted-foreground`},gn={key:0,class:`space-y-2`},_n={class:`rounded-md border bg-card`},vn={class:`flex items-center gap-1.5 px-2.5 py-1.5 cursor-pointer hover:bg-muted/50 rounded-t-md`},yn={class:`text-xs text-muted-foreground`},bn={class:`px-2.5 pb-2`},xn={class:`text-xs bg-muted/50 rounded p-2 overflow-y-auto whitespace-pre-wrap break-words max-h-60 text-muted-foreground italic`},Sn={key:1,class:`rounded-md border bg-card`},Cn={class:`flex items-center gap-1.5 px-2.5 py-1.5 border-b`},wn={class:`px-2.5 py-2`},Tn={class:`rounded-md border bg-card`},En={class:`flex items-center gap-1.5 px-2.5 py-1.5 cursor-pointer hover:bg-muted/50 rounded-t-md`},Dn={class:`px-2.5 pb-2`},On={class:`text-xs bg-muted/50 rounded p-2 overflow-y-auto whitespace-pre-wrap break-words max-h-60`},kn={key:1},An={class:`rounded-md border bg-card`},jn={class:`flex items-center gap-1.5 px-2.5 py-1.5 border-b`},Mn={class:`px-2.5 py-2`},Nn={key:2,class:`text-sm text-muted-foreground py-4 text-center`},Pn={key:0,class:`text-xs bg-muted/50 rounded p-2 overflow-y-auto whitespace-pre-wrap break-words max-h-[60vh]`},Fn={key:1,class:`text-sm text-muted-foreground py-4 text-center`},In=s({__name:`StreamResponseViewer`,props:{metrics:{},isStream:{type:Boolean},streamContent:{}},setup(i){let a=i,o=x(null),s=x([]),c=x({}),d=x({}),p=_(()=>{let e=a.streamContent?.blocks;return!!(e&&e.length>0&&e.some(e=>e.type!==`text`||e.content.length>0))});return n(()=>a.streamContent?.textContent,()=>{e(()=>{o.value&&(o.value.scrollTop=o.value.scrollHeight);for(let e of s.value)e.scrollTop=e.scrollHeight})}),(e,n)=>i.isStream?i.streamContent?(t(),u(b(ce),{key:2,"default-value":p.value?`structured`:`raw`,class:`flex flex-col h-full`},{default:l(()=>[D(b(le),{class:`w-fit`},{default:l(()=>[D(b(de),{value:`structured`},{default:l(()=>[...n[0]||=[f(`响应内容`,-1)]]),_:1}),D(b(de),{value:`raw`},{default:l(()=>[...n[1]||=[f(`原始 SSE`,-1)]]),_:1})]),_:1}),D(b(ue),{value:`structured`,class:`flex-1 overflow-y-auto mt-2`},{default:l(()=>[p.value?(t(),O(`div`,gn,[(t(!0),O(m,null,r(i.streamContent.blocks,(e,r)=>(t(),O(m,{key:r},[e.type===`thinking`&&e.content?(t(),u(b(H),{key:0,open:c.value[r]??!0,"onUpdate:open":e=>c.value[r]=e},{default:l(()=>[h(`div`,_n,[D(b(U),{"as-child":``},{default:l(()=>[h(`div`,vn,[D(b(xe),{class:g([`h-3 w-3 transition-transform`,{"rotate-90":c.value[r]??!0}])},null,8,[`class`]),D(b(be),{class:`h-3.5 w-3.5 text-muted-foreground`}),n[2]||=h(`span`,{class:`text-xs font-medium`},`Thinking`,-1),h(`span`,yn,`(`+k(e.content.length)+` 字符)`,1)])]),_:2},1024),D(b(V),null,{default:l(()=>[h(`div`,bn,[h(`pre`,xn,[h(`code`,null,k(e.content),1)])])]),_:2},1024)])]),_:2},1032,[`open`,`onUpdate:open`])):e.type===`text`&&e.content?(t(),O(`div`,Sn,[h(`div`,Cn,[D(b(Se),{class:`h-3.5 w-3.5 text-muted-foreground`}),n[3]||=h(`span`,{class:`text-xs font-medium`},`Reply`,-1)]),h(`div`,wn,[h(`pre`,{ref_for:!0,ref_key:`textContentRefs`,ref:s,class:`text-xs overflow-y-auto whitespace-pre-wrap break-words max-h-60`},[h(`code`,null,k(e.content),1)],512)])])):e.type===`tool_use`?(t(),u(b(H),{key:2,open:d.value[r]??!1,"onUpdate:open":e=>d.value[r]=e},{default:l(()=>[h(`div`,Tn,[D(b(U),{"as-child":``},{default:l(()=>[h(`div`,En,[D(b(xe),{class:g([`h-3 w-3 transition-transform`,{"rotate-90":d.value[r]??!1}])},null,8,[`class`]),D(b(Ce),{class:`h-3.5 w-3.5 text-muted-foreground`}),n[4]||=h(`span`,{class:`text-xs font-medium`},`Tool Use`,-1),e.name?(t(),u(b(W),{key:0,variant:`outline`,class:`text-xs`},{default:l(()=>[f(k(e.name),1)]),_:2},1024)):w(``,!0)])]),_:2},1024),D(b(V),null,{default:l(()=>[h(`div`,Dn,[h(`pre`,On,[h(`code`,null,k(e.content||`(等待数据...)`),1)])])]),_:2},1024)])]),_:2},1032,[`open`,`onUpdate:open`])):w(``,!0)],64))),128))])):i.streamContent.textContent?(t(),O(`div`,kn,[h(`div`,An,[h(`div`,jn,[D(b(Se),{class:`h-3.5 w-3.5 text-muted-foreground`}),n[5]||=h(`span`,{class:`text-xs font-medium`},`Reply`,-1)]),h(`div`,Mn,[h(`pre`,{ref_key:`textContentRef`,ref:o,class:`text-xs overflow-y-auto whitespace-pre-wrap break-words max-h-80`},[h(`code`,null,k(i.streamContent.textContent),1)],512)])])])):(t(),O(`div`,Nn,` 暂无内容 `))]),_:1}),D(b(ue),{value:`raw`,class:`flex-1 overflow-y-auto mt-2`},{default:l(()=>[i.streamContent.rawChunks?(t(),O(`pre`,Pn,[h(`code`,null,k(i.streamContent.rawChunks),1)])):(t(),O(`div`,Fn,` 暂无数据 `))]),_:1})]),_:1},8,[`default-value`])):(t(),O(`div`,hn,` 等待流数据... `)):(t(),O(`div`,mn,` 非流式请求无实时内容 `))}}),Ln={key:0,class:`text-sm text-muted-foreground py-4 text-center`},Rn={key:1,class:`text-sm text-muted-foreground py-4 text-center`},zn={class:`flex flex-wrap gap-1`},Bn={key:0,class:`text-xs text-muted-foreground`},Vn=s({__name:`ProviderStatsTable`,props:{stats:{}},setup(e){let n=e,i=_(()=>n.stats?Object.entries(n.stats.byProvider).filter(([e])=>typeof e==`string`).map(([e,t])=>({id:e,name:t.providerName,stats:t,successRate:t.totalRequests>0?t.successCount/t.totalRequests*100:0,retryRate:t.totalRequests>0?t.retryCount/t.totalRequests*100:0,p99Latency:n.stats.p99LatencyMs.toFixed(0)+`ms`})):[]);return(n,a)=>e.stats?i.value.length===0?(t(),O(`div`,Rn,` 暂无 Provider 统计 `)):(t(),u(b(me),{key:2},{default:l(()=>[D(b(ge),null,{default:l(()=>[D(b(he),null,{default:l(()=>[D(b(X),null,{default:l(()=>[...a[0]||=[f(`Provider`,-1)]]),_:1}),D(b(X),{class:`text-right`},{default:l(()=>[...a[1]||=[f(`请求数`,-1)]]),_:1}),D(b(X),{class:`text-right`},{default:l(()=>[...a[2]||=[f(`成功率`,-1)]]),_:1}),D(b(X),{class:`text-right`},{default:l(()=>[...a[3]||=[f(`平均延迟`,-1)]]),_:1}),D(b(X),{class:`text-right`},{default:l(()=>[...a[4]||=[f(`P99 延迟`,-1)]]),_:1}),D(b(X),{class:`text-right`},{default:l(()=>[...a[5]||=[f(`重试率`,-1)]]),_:1}),D(b(X),null,{default:l(()=>[...a[6]||=[f(`Top Errors`,-1)]]),_:1})]),_:1})]),_:1}),D(b(pe),null,{default:l(()=>[(t(!0),O(m,null,r(i.value,e=>(t(),u(b(he),{key:e.id},{default:l(()=>[D(b(Y),{class:`font-medium`},{default:l(()=>[f(k(e.name),1)]),_:2},1024),D(b(Y),{class:`text-right`},{default:l(()=>[f(k(e.stats.totalRequests),1)]),_:2},1024),D(b(Y),{class:`text-right`},{default:l(()=>[h(`span`,{class:g(e.successRate>=95?`text-green-600`:e.successRate>=80?`text-yellow-600`:`text-red-500`)},k(e.successRate.toFixed(1))+`% `,3)]),_:2},1024),D(b(Y),{class:`text-right`},{default:l(()=>[f(k(e.stats.avgLatencyMs.toFixed(0))+`ms`,1)]),_:2},1024),D(b(Y),{class:`text-right`},{default:l(()=>[f(k(e.p99Latency),1)]),_:2},1024),D(b(Y),{class:`text-right`},{default:l(()=>[h(`span`,{class:g(e.retryRate>10?`text-yellow-600`:``)},k(e.retryRate.toFixed(1))+`% `,3)]),_:2},1024),D(b(Y),null,{default:l(()=>[h(`div`,zn,[(t(!0),O(m,null,r(e.stats.topErrors.slice(0,3),e=>(t(),u(b(W),{key:e.code,variant:`destructive`,class:`text-xs`},{default:l(()=>[f(k(e.code)+` (`+k(e.count)+`) `,1)]),_:2},1024))),128)),e.stats.topErrors.length===0?(t(),O(`span`,Bn,`--`)):w(``,!0)])]),_:2},1024)]),_:2},1024))),128))]),_:1})]),_:1})):(t(),O(`div`,Ln,` 暂无数据 `))}}),Hn={key:0,class:`font-mono text-xs text-muted-foreground font-normal select-all`},Un={key:0,class:`space-y-3 py-4`},Wn={class:`p-4`},Gn={class:`p-4`},Kn={class:`p-4`},qn={class:`p-4`},Jn={key:2,class:`py-8 text-center text-muted-foreground`},Yn=s({__name:`LogDetailDialog`,props:{open:{type:Boolean,required:!0},openModifiers:{}},emits:[`update:open`],setup(e,{expose:n}){let i=c(e,`open`),a=x(!1),o=x(null),s=x([!0,!1,!1,!1]),d=v({client_request:`structured`,upstream_request:`structured`,upstream_response:`structured`,client_response:`structured`}),p=_(()=>o.value?.api_type===`openai`?`openai`:`anthropic`),y=_(()=>{let e=o.value;if(!e)return`{}`;if(!e.client_request)return e.request_body||`{}`;try{let t=JSON.parse(e.client_request);if(t.body!=null)return e.client_request;if(e.request_body){try{t.body=JSON.parse(e.request_body)}catch{t.body=e.request_body}return JSON.stringify(t)}}catch{return e.client_request}return e.client_request}),S=_(()=>{let e=o.value;return e?e.client_response?e.client_response:e.response_body?JSON.stringify({statusCode:e.status_code,body:e.response_body}):``:``});async function T(e){a.value=!0,o.value=null,s.value=[!0,!1,!1,!1],Object.assign(d,{client_request:`structured`,upstream_request:`structured`,upstream_response:`structured`,client_response:`structured`});try{o.value=(await C.getLogDetail(e)).data}catch(e){console.error(`Failed to load log detail:`,e),fe.error(`加载日志详情失败`)}finally{a.value=!1}}return n({load:T}),(e,n)=>(t(),u(b(oe),{open:i.value,"onUpdate:open":n[4]||=e=>i.value=e},{default:l(()=>[D(b(ie),{class:`max-w-4xl max-h-[85vh]`},{default:l(()=>[D(b(ae),null,{default:l(()=>[D(b(se),null,{default:l(()=>[n[5]||=f(`请求详情 `,-1),o.value?(t(),O(`span`,Hn,k(o.value.id.slice(0,8)),1)):w(``,!0)]),_:1})]),_:1}),a.value?(t(),O(`div`,Un,[D(b(ve),{class:`h-6 w-48`}),(t(),O(m,null,r(4,e=>D(b(ve),{key:e,class:`h-12 w-full`})),64))])):o.value?(t(),O(m,{key:1},[D(b(H),{open:s.value[0],"onUpdate:open":n[0]||=e=>s.value[0]=e,class:`border rounded-md mb-2`},{default:l(()=>[D(b(U),{"as-child":``},{default:l(()=>[D(b(F),{variant:`ghost`,class:`w-full px-4 py-3 text-left text-sm font-medium text-foreground bg-muted/50 hover:bg-muted rounded-md flex items-center gap-2`},{default:l(()=>[h(`span`,{class:g([`text-xs transition-transform`,s.value[0]?``:`-rotate-90`])},`▼`,2),n[6]||=f(` 客户端原始请求 `,-1)]),_:1})]),_:1}),D(b(V),null,{default:l(()=>[h(`div`,Wn,[D(_e,{raw:y.value,"api-type":p.value,mode:d.client_request},null,8,[`raw`,`api-type`,`mode`])])]),_:1})]),_:1},8,[`open`]),o.value.upstream_request?(t(),u(b(H),{key:0,open:s.value[1],"onUpdate:open":n[1]||=e=>s.value[1]=e,class:`border rounded-md mb-2`},{default:l(()=>[D(b(U),{"as-child":``},{default:l(()=>[D(b(F),{variant:`ghost`,class:`w-full px-4 py-3 text-left text-sm font-medium text-foreground bg-muted/50 hover:bg-muted rounded-md flex items-center gap-2`},{default:l(()=>[h(`span`,{class:g([`text-xs transition-transform`,s.value[1]?``:`-rotate-90`])},`▼`,2),n[7]||=f(` Router → LLM API 请求 `,-1)]),_:1})]),_:1}),D(b(V),null,{default:l(()=>[h(`div`,Gn,[D(_e,{raw:o.value.upstream_request,"api-type":p.value,"show-url":!0,mode:d.upstream_request},null,8,[`raw`,`api-type`,`mode`])])]),_:1})]),_:1},8,[`open`])):w(``,!0),o.value.upstream_response||o.value.response_body?(t(),u(b(H),{key:1,open:s.value[2],"onUpdate:open":n[2]||=e=>s.value[2]=e,class:`border rounded-md mb-2`},{default:l(()=>[D(b(U),{"as-child":``},{default:l(()=>[D(b(F),{variant:`ghost`,class:`w-full px-4 py-3 text-left text-sm font-medium text-foreground bg-muted/50 hover:bg-muted rounded-md flex items-center gap-2`},{default:l(()=>[h(`span`,{class:g([`text-xs transition-transform`,s.value[2]?``:`-rotate-90`])},`▼`,2),n[8]||=f(` LLM API 返回的原始响应 `,-1)]),_:1})]),_:1}),D(b(V),null,{default:l(()=>[h(`div`,Kn,[D(ye,{raw:o.value.upstream_response||o.value.response_body||`{}`,"api-type":p.value,"is-stream":!!o.value.is_stream,mode:d.upstream_response},null,8,[`raw`,`api-type`,`is-stream`,`mode`])])]),_:1})]),_:1},8,[`open`])):w(``,!0),S.value?(t(),u(b(H),{key:2,open:s.value[3],"onUpdate:open":n[3]||=e=>s.value[3]=e,class:`border rounded-md`},{default:l(()=>[D(b(U),{"as-child":``},{default:l(()=>[D(b(F),{variant:`ghost`,class:`w-full px-4 py-3 text-left text-sm font-medium text-foreground bg-muted/50 hover:bg-muted rounded-md flex items-center gap-2`},{default:l(()=>[h(`span`,{class:g([`text-xs transition-transform`,s.value[3]?``:`-rotate-90`])},`▼`,2),n[9]||=f(` Router → 客户端响应 `,-1)]),_:1})]),_:1}),D(b(V),null,{default:l(()=>[h(`div`,qn,[D(ye,{raw:S.value,"api-type":p.value,"is-stream":!!o.value.is_stream,mode:d.client_response},null,8,[`raw`,`api-type`,`is-stream`,`mode`])])]),_:1})]),_:1},8,[`open`])):w(``,!0),o.value.error_message?(t(),u(b(G),{key:3,class:`bg-destructive/10 ring-destructive/20 mt-2`},{default:l(()=>[D(b(K),{class:`py-3 text-sm text-destructive`},{default:l(()=>[f(k(o.value.error_message),1)]),_:1})]),_:1})):w(``,!0)],64)):(t(),O(`div`,Jn,`未找到日志`))]),_:1})]),_:1},8,[`open`]))}}),Xn={class:`p-6`},Zn={class:`flex items-center justify-between mb-4`},Qn={class:`flex items-center gap-2`},$n={class:`grid grid-cols-3 gap-4 mb-6`},er={class:`flex items-center justify-between`},tr={key:0,class:`text-sm text-muted-foreground py-2`},nr=[`onClick`],rr={class:`text-sm text-foreground truncate flex-1`},ir={class:`text-xs text-muted-foreground shrink-0`},ar={class:`flex items-center justify-between`},or={key:0,class:`text-sm text-muted-foreground py-2`},sr=[`onClick`],cr={class:`text-sm text-foreground truncate flex-1`},lr={class:`text-xs text-muted-foreground shrink-0`},ur={class:`flex items-center justify-between`},dr={key:0,class:`text-sm text-muted-foreground py-2`},fr=[`onClick`],pr={class:`text-sm text-foreground truncate flex-1`},mr={class:`grid grid-cols-1 lg:grid-cols-3 gap-4`},hr={key:0,class:`flex gap-4 min-h-0`},gr={class:`w-[260px] shrink-0 overflow-y-auto pr-2 border-r`},_r={class:`flex-1 min-w-0 overflow-y-auto`},vr={key:1,class:`text-sm text-muted-foreground py-4 text-center`},yr=200,br=s({__name:`Monitor`,setup(e){let n=x([]),o=x([]),s=x(null),c=x(!1),d=x(null),p=x([]),v=x(null),y=x(!1),S=_(()=>n.value.filter(e=>e.isStream).length),T=_(()=>n.value.filter(e=>!e.queued)),E=_(()=>n.value.filter(e=>e.queued===!0));function A(e){s.value=e,c.value=!0}let j=_(()=>s.value?n.value.find(e=>e.id===s.value)??o.value.find(e=>e.id===s.value)??null:null),M=x(!1),N=x(null);function P(e){c.value=!1,M.value=!0,N.value?.load(e)}function F(e){switch(e){case`pending`:return`default`;case`failed`:return`destructive`;case`completed`:return`secondary`;default:return`outline`}}function I(e){switch(e){case`pending`:return`进行中`;case`failed`:return`失败`;case`completed`:return`完成`;default:return e}}function L(e){return((Date.now()-e)/1e3).toFixed(1)}let R=null;function ee(e){let t;try{t=JSON.parse(e.data)}catch{return}switch(e.type){case`request_start`:{let e=t;o.value.some(t=>t.id===e.id)||n.value.unshift(e);break}case`request_update`:n.value=t;break;case`request_complete`:{let e=t;n.value=n.value.filter(t=>t.id!==e.id),o.value.unshift(e),o.value.length>yr&&(o.value.length=yr);break}case`concurrency_update`:p.value=t;break;case`stats_update`:d.value=t;break;case`runtime_update`:v.value=t;break}}function te(){R=new EventSource(`/admin/api/monitor/stream`),R.onopen=()=>{y.value=!0};for(let e of[`request_start`,`request_update`,`request_complete`,`concurrency_update`,`stats_update`,`runtime_update`])R.addEventListener(e,ee);R.onerror=()=>{y.value=!1,R?.close(),R=null}}function z(){R&&=(R.close(),null),y.value=!1}async function ne(){try{let[e,t,r,i,a]=await Promise.allSettled([C.getMonitorActive(),C.getMonitorRecent(),C.getMonitorStats(),C.getMonitorConcurrency(),C.getMonitorRuntime()]);e.status===`fulfilled`&&(n.value=e.value),t.status===`fulfilled`&&(o.value=t.value),r.status===`fulfilled`&&(d.value=r.value),i.status===`fulfilled`&&(p.value=i.value),a.status===`fulfilled`&&(v.value=a.value)}catch(e){console.error(`Failed to load initial monitor data:`,e),d.value=null,p.value=[],v.value=null}}return i(async()=>{await ne(),te()}),a(()=>{z()}),(e,i)=>(t(),O(`div`,Xn,[h(`div`,Zn,[i[2]||=h(`h2`,{class:`text-lg font-semibold text-foreground`},`实时监控`,-1),h(`div`,Qn,[D(b(W),{variant:y.value?`default`:`destructive`},{default:l(()=>[f(k(y.value?`已连接`:`未连接`),1)]),_:1},8,[`variant`])])]),D(lt,{stats:d.value,"active-count":n.value.length,"stream-count":S.value},null,8,[`stats`,`active-count`,`stream-count`]),h(`div`,$n,[D(b(G),null,{default:l(()=>[D(b(q),{class:`pb-2`},{default:l(()=>[h(`div`,er,[D(b(J),{class:`text-sm font-medium text-foreground`},{default:l(()=>[...i[3]||=[f(`活跃请求`,-1)]]),_:1}),D(b(W),{variant:`secondary`},{default:l(()=>[f(k(T.value.length),1)]),_:1})])]),_:1}),D(b(K),null,{default:l(()=>[D(b($e),{class:`h-64`},{default:l(()=>[T.value.length===0?(t(),O(`div`,tr,` 暂无活跃请求 `)):w(``,!0),(t(!0),O(m,null,r(T.value,e=>(t(),O(`div`,{key:e.id,class:g([`flex items-center gap-2 py-2 px-2 rounded cursor-pointer hover:bg-muted/50 transition-colors`,{"bg-muted":s.value===e.id}]),onClick:t=>A(e.id)},[D(b(W),{variant:F(e.status),class:`shrink-0`},{default:l(()=>[f(k(I(e.status)),1)]),_:2},1032,[`variant`]),h(`span`,rr,k(e.model),1),D(b(W),{variant:`outline`,class:`shrink-0 text-xs`},{default:l(()=>[f(k(e.providerName),1)]),_:2},1024),h(`span`,ir,k(L(e.startTime))+`s`,1),e.isStream?(t(),u(b(W),{key:0,variant:`outline`,class:`shrink-0 text-xs`},{default:l(()=>[...i[4]||=[f(`SSE`,-1)]]),_:1})):w(``,!0)],10,nr))),128))]),_:1})]),_:1})]),_:1}),D(b(G),null,{default:l(()=>[D(b(q),{class:`pb-2`},{default:l(()=>[h(`div`,ar,[D(b(J),{class:`text-sm font-medium text-foreground`},{default:l(()=>[...i[5]||=[f(`队列请求`,-1)]]),_:1}),D(b(W),{variant:`secondary`},{default:l(()=>[f(k(E.value.length),1)]),_:1})])]),_:1}),D(b(K),null,{default:l(()=>[D(b($e),{class:`h-64`},{default:l(()=>[E.value.length===0?(t(),O(`div`,or,` 暂无排队请求 `)):w(``,!0),(t(!0),O(m,null,r(E.value,e=>(t(),O(`div`,{key:e.id,class:g([`flex items-center gap-2 py-2 px-2 rounded cursor-pointer hover:bg-muted/50 transition-colors`,{"bg-muted":s.value===e.id}]),onClick:t=>A(e.id)},[D(b(W),{variant:`outline`,class:`shrink-0`},{default:l(()=>[...i[6]||=[f(` 排队 `,-1)]]),_:1}),h(`span`,cr,k(e.model),1),D(b(W),{variant:`outline`,class:`shrink-0 text-xs`},{default:l(()=>[f(k(e.providerName),1)]),_:2},1024),h(`span`,lr,k(L(e.startTime))+`s`,1)],10,sr))),128))]),_:1})]),_:1})]),_:1}),D(b(G),null,{default:l(()=>[D(b(q),{class:`pb-2`},{default:l(()=>[h(`div`,ur,[D(b(J),{class:`text-sm font-medium text-foreground`},{default:l(()=>[...i[7]||=[f(`已完成`,-1)]]),_:1}),D(b(W),{variant:`secondary`},{default:l(()=>[f(k(o.value.length),1)]),_:1})])]),_:1}),D(b(K),null,{default:l(()=>[D(b($e),{class:`h-64`},{default:l(()=>[o.value.length===0?(t(),O(`div`,dr,` 暂无已完成请求 `)):w(``,!0),(t(!0),O(m,null,r(o.value,e=>(t(),O(`div`,{key:e.id,class:g([`flex items-center gap-2 py-1.5 px-2 rounded cursor-pointer opacity-60 hover:opacity-80 hover:bg-muted/50 transition-colors`,{"bg-muted":s.value===e.id}]),onClick:t=>A(e.id)},[D(b(W),{variant:F(e.status),class:`shrink-0`},{default:l(()=>[f(k(I(e.status)),1)]),_:2},1032,[`variant`]),h(`span`,pr,k(e.model),1),D(b(W),{variant:`outline`,class:`shrink-0 text-xs`},{default:l(()=>[f(k(e.providerName),1)]),_:2},1024),e.isStream?(t(),u(b(W),{key:0,variant:`outline`,class:`shrink-0 text-xs`},{default:l(()=>[...i[8]||=[f(`SSE`,-1)]]),_:1})):w(``,!0)],10,fr))),128))]),_:1})]),_:1})]),_:1})]),D(b(G),{class:`mb-4`},{default:l(()=>[D(b(q),null,{default:l(()=>[D(b(J),{class:`text-sm font-medium text-foreground`},{default:l(()=>[...i[9]||=[f(`Provider 统计`,-1)]]),_:1})]),_:1}),D(b(K),null,{default:l(()=>[D(Vn,{stats:d.value},null,8,[`stats`])]),_:1})]),_:1}),h(`div`,mr,[D(b(G),null,{default:l(()=>[D(b(q),null,{default:l(()=>[D(b(J),{class:`text-sm font-medium text-foreground`},{default:l(()=>[...i[10]||=[f(`并发度`,-1)]]),_:1})]),_:1}),D(b(K),null,{default:l(()=>[D(_t,{providers:p.value},null,8,[`providers`])]),_:1})]),_:1}),D(b(G),null,{default:l(()=>[D(b(q),null,{default:l(()=>[D(b(J),{class:`text-sm font-medium text-foreground`},{default:l(()=>[...i[11]||=[f(`状态码分布`,-1)]]),_:1})]),_:1}),D(b(K),null,{default:l(()=>[D(It,{"by-status-code":d.value?.byStatusCode??{}},null,8,[`by-status-code`])]),_:1})]),_:1}),D(b(G),null,{default:l(()=>[D(b(q),null,{default:l(()=>[D(b(J),{class:`text-sm font-medium text-foreground`},{default:l(()=>[...i[12]||=[f(`运行时`,-1)]]),_:1})]),_:1}),D(b(K),null,{default:l(()=>[D(At,{runtime:v.value},null,8,[`runtime`])]),_:1})]),_:1})]),D(b(oe),{open:c.value,"onUpdate:open":i[0]||=e=>c.value=e},{default:l(()=>[D(b(ie),{class:`max-w-5xl max-h-[80vh]`},{default:l(()=>[D(b(ae),null,{default:l(()=>[D(b(se),null,{default:l(()=>[...i[13]||=[f(`请求详情`,-1)]]),_:1})]),_:1}),j.value?(t(),O(`div`,hr,[h(`div`,gr,[D(pn,{request:j.value,onViewDetail:P},null,8,[`request`])]),h(`div`,_r,[D(In,{metrics:j.value.streamMetrics??null,"is-stream":j.value.isStream,"stream-content":j.value.streamContent??void 0},null,8,[`metrics`,`is-stream`,`stream-content`])])])):(t(),O(`div`,vr,` 点击请求查看详情 `))]),_:1})]),_:1},8,[`open`]),D(Yn,{ref_key:`logDetailDialog`,ref:N,open:M.value,"onUpdate:open":i[1]||=e=>M.value=e},null,8,[`open`])]))}});export{br as default};
|
|
1
|
+
import{A as e,F as t,K as n,L as r,M as i,N as a,R as o,S as s,W as c,Y as l,_ as u,_t as d,b as f,dt as p,f as m,g as h,gt as g,h as _,it as v,k as y,mt as b,ot as x,q as S,t as C,v as w,vt as T,w as E,x as D,y as O,yt as k}from"./client-Mb8fy_bC.js";import{t as A}from"./createLucideIcon-CCmQ9QKM.js";import{E as j,b as M,f as N,i as P,n as F,r as I,w as L}from"./button-D54q76GQ.js";import{n as R,t as ee}from"./useNonce-CU-NirfM.js";import{S as te,c as z,h as ne,l as re}from"./Collection-DUBb4r6h.js";import{t as B}from"./useForwardExpose-CzQFheaD.js";import{n as V,r as H,t as U}from"./CollapsibleTrigger-BFNhb19_.js";import{n as ie,r as ae,s as oe,t as se}from"./dialog-DSH5k5Kj.js";import{i as ce,n as le,r as ue,t as de}from"./TabsTrigger-DErAbTuM.js";import{n as fe,r as W}from"./lib-BgOqOzXI.js";import{n as G,t as K}from"./CardContent-CucI6u41.js";import{t as q}from"./CardHeader-d-DYsWxe.js";import{t as J}from"./CardTitle-CIDEQkWB.js";import{a as pe,i as Y,n as X,o as me,r as he,t as ge}from"./TableHeader-BpscAtT3.js";import{n as _e,r as ve,t as ye}from"./LogResponseViewer-CyBzv02a.js";var be=A(`brain`,[[`path`,{d:`M12 18V5`,key:`adv99a`}],[`path`,{d:`M15 13a4.17 4.17 0 0 1-3-4 4.17 4.17 0 0 1-3 4`,key:`1e3is1`}],[`path`,{d:`M17.598 6.5A3 3 0 1 0 12 5a3 3 0 1 0-5.598 1.5`,key:`1gqd8o`}],[`path`,{d:`M17.997 5.125a4 4 0 0 1 2.526 5.77`,key:`iwvgf7`}],[`path`,{d:`M18 18a4 4 0 0 0 2-7.464`,key:`efp6ie`}],[`path`,{d:`M19.967 17.483A4 4 0 1 1 12 18a4 4 0 1 1-7.967-.517`,key:`1gq6am`}],[`path`,{d:`M6 18a4 4 0 0 1-2-7.464`,key:`k1g0md`}],[`path`,{d:`M6.003 5.125a4 4 0 0 0-2.526 5.77`,key:`q97ue3`}]]),xe=A(`chevron-right`,[[`path`,{d:`m9 18 6-6-6-6`,key:`mthhwq`}]]),Se=A(`message-square`,[[`path`,{d:`M22 17a2 2 0 0 1-2 2H6.828a2 2 0 0 0-1.414.586l-2.202 2.202A.71.71 0 0 1 2 21.286V5a2 2 0 0 1 2-2h16a2 2 0 0 1 2 2z`,key:`18887p`}]]),Ce=A(`wrench`,[[`path`,{d:`M14.7 6.3a1 1 0 0 0 0 1.4l1.6 1.6a1 1 0 0 0 1.4 0l3.106-3.105c.32-.322.863-.22.983.218a6 6 0 0 1-8.259 7.057l-7.91 7.91a1 1 0 0 1-2.999-3l7.91-7.91a6 6 0 0 1 7.057-8.259c.438.12.54.662.219.984z`,key:`1ngwbx`}]]),[Z,we]=te(`ScrollAreaRoot`),Te=s({__name:`ScrollAreaRoot`,props:{type:{type:String,required:!1,default:`hover`},dir:{type:String,required:!1},scrollHideDelay:{type:Number,required:!1,default:600},asChild:{type:Boolean,required:!1},as:{type:null,required:!1}},setup(e,{expose:n}){let r=e,i=x(0),a=x(0),s=x(),c=x(),d=x(),f=x(),m=x(!1),h=x(!1),{type:g,dir:_,scrollHideDelay:v}=p(r),y=ne(_);function S(){s.value?.scrollTo({top:0})}function C(){s.value?.scrollTo({top:0,left:0})}n({viewport:s,scrollTop:S,scrollTopLeft:C});let{forwardRef:w,currentElement:E}=B();return we({type:g,dir:y,scrollHideDelay:v,scrollArea:E,viewport:s,onViewportChange:e=>{s.value=e||void 0},content:c,onContentChange:e=>{c.value=e},scrollbarX:d,scrollbarXEnabled:m,scrollbarY:f,scrollbarYEnabled:h,onScrollbarXChange:e=>{d.value=e||void 0},onScrollbarYChange:e=>{f.value=e||void 0},onScrollbarXEnabledChange:e=>{m.value=e},onScrollbarYEnabledChange:e=>{h.value=e},onCornerWidthChange:e=>{i.value=e},onCornerHeightChange:e=>{a.value=e}}),(e,n)=>(t(),u(b(P),{ref:b(w),"as-child":r.asChild,as:e.as,dir:b(y),style:T({position:`relative`,"--reka-scroll-area-corner-width":`${i.value}px`,"--reka-scroll-area-corner-height":`${a.value}px`})},{default:l(()=>[o(e.$slots,`default`)]),_:3},8,[`as-child`,`as`,`dir`,`style`]))}}),Ee=s({__name:`ScrollAreaCornerImpl`,setup(e){let r=Z(),i=x(0),a=x(0),s=_(()=>!!i.value&&!!a.value);function c(){let e=r.scrollbarX.value?.offsetHeight||0;r.onCornerHeightChange(e),a.value=e}function d(){let e=r.scrollbarY.value?.offsetWidth||0;r.onCornerWidthChange(e),i.value=e}return N(r.scrollbarX.value,c),N(r.scrollbarY.value,d),n(()=>r.scrollbarX.value,c),n(()=>r.scrollbarY.value,d),(e,n)=>s.value?(t(),u(b(P),y({key:0,style:{width:`${i.value}px`,height:`${a.value}px`,position:`absolute`,right:b(r).dir.value===`ltr`?0:void 0,left:b(r).dir.value===`rtl`?0:void 0,bottom:0}},e.$parent?.$props),{default:l(()=>[o(e.$slots,`default`)]),_:3},16,[`style`])):w(`v-if`,!0)}}),De=s({__name:`ScrollAreaCorner`,props:{asChild:{type:Boolean,required:!1},as:{type:null,required:!1}},setup(e){let n=e,{forwardRef:r}=B(),i=Z(),a=_(()=>!!i.scrollbarX.value&&!!i.scrollbarY.value),s=_(()=>i.type.value!==`scroll`&&a.value);return(e,i)=>s.value?(t(),u(Ee,y({key:0},n,{ref:b(r)}),{default:l(()=>[o(e.$slots,`default`)]),_:3},16)):w(`v-if`,!0)}});function Oe(e,t){return n=>{if(e[0]===e[1]||t[0]===t[1])return t[0];let r=(t[1]-t[0])/(e[1]-e[0]);return t[0]+r*(n-e[0])}}function ke(e){let t=Ae(e.viewport,e.content),n=e.scrollbar.paddingStart+e.scrollbar.paddingEnd,r=(e.scrollbar.size-n)*t;return Math.max(r,18)}function Ae(e,t){let n=e/t;return Number.isNaN(n)?0:n}function je(e,t=()=>{}){let n={left:e.scrollLeft,top:e.scrollTop},r=0;return(function i(){let a={left:e.scrollLeft,top:e.scrollTop},o=n.left!==a.left,s=n.top!==a.top;(o||s)&&t(),n=a,r=window.requestAnimationFrame(i)})(),()=>window.cancelAnimationFrame(r)}function Me(e,t,n=`ltr`){let r=ke(t),i=t.scrollbar.paddingStart+t.scrollbar.paddingEnd,a=t.scrollbar.size-i,o=t.content-t.viewport,s=a-r,c=n===`ltr`?[0,o]:[o*-1,0],l=R(e,c[0],c[1]);return Oe([0,o],[0,s])(l)}function Ne(e){return e?Number.parseInt(e,10):0}function Pe(e,t,n,r=`ltr`){let i=ke(n),a=i/2,o=t||a,s=i-o,c=n.scrollbar.paddingStart+o,l=n.scrollbar.size-n.scrollbar.paddingEnd-s,u=n.content-n.viewport,d=r===`ltr`?[0,u]:[u*-1,0];return Oe([c,l],d)(e)}function Fe(e,t){return e>0&&e<t}var Ie=s({__name:`ScrollAreaScrollbarX`,setup(e){let n=Z(),r=We(),{forwardRef:a,currentElement:s}=B();i(()=>{s.value&&n.onScrollbarXChange(s.value)});let c=_(()=>r.sizes.value);return(e,i)=>(t(),u(qe,{ref:b(a),"is-horizontal":!0,"data-orientation":`horizontal`,style:T({bottom:0,left:b(n).dir.value===`rtl`?`var(--reka-scroll-area-corner-width)`:0,right:b(n).dir.value===`ltr`?`var(--reka-scroll-area-corner-width)`:0,"--reka-scroll-area-thumb-width":c.value?`${b(ke)(c.value)}px`:void 0}),onOnDragScroll:i[0]||=e=>b(r).onDragScroll(e.x)},{default:l(()=>[o(e.$slots,`default`)]),_:3},8,[`style`]))}}),Le=s({__name:`ScrollAreaScrollbarY`,setup(e){let n=Z(),r=We(),{forwardRef:a,currentElement:s}=B();i(()=>{s.value&&n.onScrollbarYChange(s.value)});let c=_(()=>r.sizes.value);return(e,i)=>(t(),u(qe,{ref:b(a),"is-horizontal":!1,"data-orientation":`vertical`,style:T({top:0,right:b(n).dir.value===`ltr`?0:void 0,left:b(n).dir.value===`rtl`?0:void 0,bottom:`var(--reka-scroll-area-corner-height)`,"--reka-scroll-area-thumb-height":c.value?`${b(ke)(c.value)}px`:void 0}),onOnDragScroll:i[0]||=e=>b(r).onDragScroll(e.y)},{default:l(()=>[o(e.$slots,`default`)]),_:3},8,[`style`]))}}),Re=s({__name:`ScrollAreaScrollbarAuto`,props:{forceMount:{type:Boolean,required:!1}},setup(e){let n=Z(),r=Q(),{forwardRef:a}=B(),s=x(!1),c=L(()=>{if(n.viewport.value){let e=n.viewport.value.offsetWidth<n.viewport.value.scrollWidth,t=n.viewport.value.offsetHeight<n.viewport.value.scrollHeight;s.value=r.isHorizontal.value?e:t}},10);return i(()=>c()),N(n.viewport,c),N(n.content,c),(e,n)=>(t(),u(b(z),{present:e.forceMount||s.value},{default:l(()=>[D(Ke,y(e.$attrs,{ref:b(a),"data-state":s.value?`visible`:`hidden`}),{default:l(()=>[o(e.$slots,`default`)]),_:3},16,[`data-state`])]),_:3},8,[`present`]))}}),ze=s({inheritAttrs:!1,__name:`ScrollAreaScrollbarGlimpse`,props:{forceMount:{type:Boolean,required:!1}},setup(e){let n=Z(),r=Q(),{forwardRef:s}=B(),{state:c,dispatch:d}=re(`hidden`,{hidden:{POINTER_ENTER:`glimpse`,SCROLL:`scrolling`},glimpse:{HIDE:`hidden`,POINTER_LEAVE:`hidden`,SCROLL:`scrolling`,POINTER_ENTER:`glimpse`},scrolling:{SCROLL_END:`idle`,POINTER_ENTER:`interacting`},interacting:{SCROLL:`interacting`,POINTER_LEAVE:`idle`},idle:{HIDE:`hidden`,SCROLL:`scrolling`,POINTER_ENTER:`interacting`}}),f=_(()=>c.value!==`hidden`);function p(){d(`POINTER_ENTER`)}function m(){d(`POINTER_LEAVE`)}let h=L(()=>d(`SCROLL_END`),100);return S(e=>{if(c.value===`glimpse`){let t=window.setTimeout(d,n.scrollHideDelay.value,`HIDE`);e(()=>{window.clearTimeout(t)})}}),S(e=>{if(c.value===`idle`){let t=window.setTimeout(d,n.scrollHideDelay.value,`HIDE`);e(()=>{window.clearTimeout(t)})}}),S(e=>{let t=n.viewport.value,i=r.isHorizontal.value?`scrollLeft`:`scrollTop`;if(t){let n=t[i],r=()=>{let e=t[i];n!==e&&(d(`SCROLL`),h()),n=e};t.addEventListener(`scroll`,r),e(()=>{t.removeEventListener(`scroll`,r)})}}),i(()=>{let e=n.scrollArea.value;e&&(e.addEventListener(`pointerenter`,p),e.addEventListener(`pointerleave`,m))}),a(()=>{let e=n.scrollArea.value;e&&(e.removeEventListener(`pointerenter`,p),e.removeEventListener(`pointerleave`,m))}),(e,n)=>(t(),u(b(z),{present:e.forceMount||f.value},{default:l(()=>[D(Re,y(e.$attrs,{ref:b(s),"data-state":f.value?`visible`:`hidden`}),{default:l(()=>[o(e.$slots,`default`)]),_:3},16,[`data-state`])]),_:3},8,[`present`]))}}),Be=s({inheritAttrs:!1,__name:`ScrollAreaScrollbarHover`,props:{forceMount:{type:Boolean,required:!1}},setup(e){let n=Z(),{forwardRef:r}=B(),s,c=x(!1);function d(){window.clearTimeout(s),c.value=!0}function f(){s=window.setTimeout(()=>{c.value=!1},n.scrollHideDelay.value)}return i(()=>{let e=n.scrollArea.value;e&&(e.addEventListener(`pointerenter`,d),e.addEventListener(`pointerleave`,f))}),a(()=>{let e=n.scrollArea.value;e&&(window.clearTimeout(s),e.removeEventListener(`pointerenter`,d),e.removeEventListener(`pointerleave`,f))}),(e,n)=>(t(),u(b(z),{present:e.forceMount||c.value},{default:l(()=>[D(Re,y(e.$attrs,{ref:b(r),"data-state":c.value?`visible`:`hidden`}),{default:l(()=>[o(e.$slots,`default`)]),_:3},16,[`data-state`])]),_:3},8,[`present`]))}}),Ve=s({__name:`ScrollAreaScrollbarScroll`,props:{forceMount:{type:Boolean,required:!1}},setup(e){let n=Z(),r=Q(),{forwardRef:i}=B(),{state:a,dispatch:s}=re(`hidden`,{hidden:{SCROLL:`scrolling`},scrolling:{SCROLL_END:`idle`,POINTER_ENTER:`interacting`},interacting:{SCROLL:`interacting`,POINTER_LEAVE:`idle`},idle:{HIDE:`hidden`,SCROLL:`scrolling`,POINTER_ENTER:`interacting`}}),c=_(()=>a.value!==`hidden`);S(e=>{if(a.value===`idle`){let t=window.setTimeout(s,n.scrollHideDelay.value,`HIDE`);e(()=>{window.clearTimeout(t)})}});let d=L(()=>s(`SCROLL_END`),100);return S(e=>{let t=n.viewport.value,i=r.isHorizontal.value?`scrollLeft`:`scrollTop`;if(t){let n=t[i],r=()=>{let e=t[i];n!==e&&(s(`SCROLL`),d()),n=e};t.addEventListener(`scroll`,r),e(()=>{t.removeEventListener(`scroll`,r)})}}),(e,n)=>(t(),u(b(z),{present:e.forceMount||c.value},{default:l(()=>[D(Ke,y(e.$attrs,{ref:b(i),"data-state":c.value?`visible`:`hidden`}),{default:l(()=>[o(e.$slots,`default`)]),_:3},16,[`data-state`])]),_:3},8,[`present`]))}}),[Q,He]=te(`ScrollAreaScrollbar`),Ue=s({inheritAttrs:!1,__name:`ScrollAreaScrollbar`,props:{orientation:{type:String,required:!1,default:`vertical`},forceMount:{type:Boolean,required:!1},asChild:{type:Boolean,required:!1},as:{type:null,required:!1,default:`div`}},setup(e){let r=e,{forwardRef:i}=B(),s=Z(),c=_(()=>r.orientation===`horizontal`);n(c,()=>{c.value?s.onScrollbarXEnabledChange(!0):s.onScrollbarYEnabledChange(!0)},{immediate:!0}),a(()=>{s.onScrollbarXEnabledChange(!1),s.onScrollbarYEnabledChange(!1)});let{orientation:d,forceMount:f,asChild:m,as:h}=p(r);return He({orientation:d,forceMount:f,isHorizontal:c,as:h,asChild:m}),(e,n)=>b(s).type.value===`hover`?(t(),u(Be,y({key:0},e.$attrs,{ref:b(i),"force-mount":b(f)}),{default:l(()=>[o(e.$slots,`default`)]),_:3},16,[`force-mount`])):b(s).type.value===`scroll`?(t(),u(Ve,y({key:1},e.$attrs,{ref:b(i),"force-mount":b(f)}),{default:l(()=>[o(e.$slots,`default`)]),_:3},16,[`force-mount`])):b(s).type.value===`glimpse`?(t(),u(ze,y({key:2},e.$attrs,{ref:b(i),"force-mount":b(f)}),{default:l(()=>[o(e.$slots,`default`)]),_:3},16,[`force-mount`])):b(s).type.value===`auto`?(t(),u(Re,y({key:3},e.$attrs,{ref:b(i),"force-mount":b(f)}),{default:l(()=>[o(e.$slots,`default`)]),_:3},16,[`force-mount`])):b(s).type.value===`always`?(t(),u(Ke,y({key:4},e.$attrs,{ref:b(i),"data-state":`visible`}),{default:l(()=>[o(e.$slots,`default`)]),_:3},16)):w(`v-if`,!0)}}),[We,Ge]=te(`ScrollAreaScrollbarVisible`),Ke=s({__name:`ScrollAreaScrollbarVisible`,setup(e){let n=Z(),r=Q(),{forwardRef:i}=B(),a=x({content:0,viewport:0,scrollbar:{size:0,paddingStart:0,paddingEnd:0}}),s=_(()=>{let e=Ae(a.value.viewport,a.value.content);return e>0&&e<1}),c=x(),d=x(0);function f(e,t){if(v.value){let r=n.viewport.value.scrollLeft+e.deltaY;n.viewport.value.scrollLeft=r,Fe(r,t)&&e.preventDefault()}else{let r=n.viewport.value.scrollTop+e.deltaY;n.viewport.value.scrollTop=r,Fe(r,t)&&e.preventDefault()}}function p(e,t){v.value?d.value=t.x:d.value=t.y}function m(e){d.value=0}function h(e){a.value=e}function g(e,t){return Pe(e,d.value,a.value,t)}let v=_(()=>r.isHorizontal.value);function S(e){v.value?n.viewport.value.scrollLeft=g(e,n.dir.value):n.viewport.value.scrollTop=g(e)}function C(){if(v.value){if(n.viewport.value&&c.value){let e=n.viewport.value.scrollLeft,t=Me(e,a.value,n.dir.value);c.value.style.transform=`translate3d(${t}px, 0, 0)`}}else if(n.viewport.value&&c.value){let e=n.viewport.value.scrollTop,t=Me(e,a.value);c.value.style.transform=`translate3d(0, ${t}px, 0)`}}function w(e){c.value=e}return Ge({sizes:a,hasThumb:s,handleWheelScroll:f,handleThumbDown:p,handleThumbUp:m,handleSizeChange:h,onThumbPositionChange:C,onThumbChange:w,onDragScroll:S}),(e,n)=>v.value?(t(),u(Ie,y({key:0},e.$attrs,{ref:b(i)}),{default:l(()=>[o(e.$slots,`default`)]),_:3},16)):(t(),u(Le,y({key:1},e.$attrs,{ref:b(i)}),{default:l(()=>[o(e.$slots,`default`)]),_:3},16))}}),qe=s({__name:`ScrollAreaScrollbarImpl`,props:{isHorizontal:{type:Boolean,required:!0}},emits:[`onDragScroll`,`onWheelScroll`,`onThumbPointerDown`],setup(e,{emit:n}){let r=e,s=n,c=Z(),d=We(),f=Q(),{forwardRef:p,currentElement:m}=B(),h=x(``),g=x();function _(e){g.value&&s(`onDragScroll`,{x:e.clientX-g.value?.left,y:e.clientY-g.value?.top})}function v(e){e.button===0&&(e.target.setPointerCapture(e.pointerId),g.value=m.value.getBoundingClientRect(),h.value=document.body.style.webkitUserSelect,document.body.style.webkitUserSelect=`none`,c.viewport&&(c.viewport.value.style.scrollBehavior=`auto`),_(e))}function y(e){_(e)}function S(e){let t=e.target;t.hasPointerCapture(e.pointerId)&&t.releasePointerCapture(e.pointerId),document.body.style.webkitUserSelect=h.value,c.viewport&&(c.viewport.value.style.scrollBehavior=``),g.value=void 0}function C(e){let t=e.target,n=m.value?.contains(t),r=d.sizes.value.content-d.sizes.value.viewport;n&&d.handleWheelScroll(e,r)}i(()=>{document.addEventListener(`wheel`,C,{passive:!1})}),a(()=>{document.removeEventListener(`wheel`,C)});function w(){m.value&&(r.isHorizontal?d.handleSizeChange({content:c.viewport.value?.scrollWidth??0,viewport:c.viewport.value?.offsetWidth??0,scrollbar:{size:m.value.clientWidth??0,paddingStart:Ne(getComputedStyle(m.value).paddingLeft),paddingEnd:Ne(getComputedStyle(m.value).paddingRight)}}):d.handleSizeChange({content:c.viewport.value?.scrollHeight??0,viewport:c.viewport.value?.offsetHeight??0,scrollbar:{size:m.value?.clientHeight??0,paddingStart:Ne(getComputedStyle(m.value).paddingTop),paddingEnd:Ne(getComputedStyle(m.value).paddingBottom)}}),d.onThumbPositionChange())}return N(m,w),N(c.content,w),(e,n)=>(t(),u(b(P),{ref:b(p),style:{position:`absolute`},"data-scrollbarimpl":``,as:b(f).as.value,"as-child":b(f).asChild.value,onPointerdown:v,onPointermove:y,onPointerup:S},{default:l(()=>[o(e.$slots,`default`)]),_:3},8,[`as`,`as-child`]))}}),Je=s({__name:`ScrollAreaThumb`,props:{asChild:{type:Boolean,required:!1},as:{type:null,required:!1}},setup(e){let n=e,r=Z(),i=We();function s(e){let t=e.target.getBoundingClientRect(),n=e.clientX-t.left,r=e.clientY-t.top;i.handleThumbDown(e,{x:n,y:r})}function c(e){i.handleThumbUp(e)}let{forwardRef:d,currentElement:f}=B(),p=x(),m=_(()=>r.viewport.value);function h(){p.value||(p.value=je(m.value,i.onThumbPositionChange),i.onThumbPositionChange())}return j(_(()=>i.sizes.value),()=>{i.onThumbChange(f.value),m.value&&(i.onThumbPositionChange(),m.value.addEventListener(`scroll`,h))}),a(()=>{m.value.removeEventListener(`scroll`,h),r.viewport.value?.removeEventListener(`scroll`,h)}),(e,r)=>(t(),u(b(P),{ref:b(d),"data-state":b(i).hasThumb?`visible`:`hidden`,style:{width:`var(--reka-scroll-area-thumb-width)`,height:`var(--reka-scroll-area-thumb-height)`},"as-child":n.asChild,as:e.as,onPointerdown:s,onPointerup:c},{default:l(()=>[o(e.$slots,`default`)]),_:3},8,[`data-state`,`as-child`,`as`]))}}),Ye=s({inheritAttrs:!1,__name:`ScrollAreaViewport`,props:{nonce:{type:String,required:!1},asChild:{type:Boolean,required:!1},as:{type:null,required:!1}},setup(e,{expose:n}){let r=e,{nonce:a}=p(r),s=ee(a),c=Z(),u=x();i(()=>{c.onViewportChange(u.value),c.onContentChange(g.value)}),n({viewportElement:u});let{forwardRef:d,currentElement:g}=B();return(e,n)=>(t(),O(m,null,[h(`div`,y({ref_key:`viewportElement`,ref:u,"data-reka-scroll-area-viewport":``,style:{overflowX:b(c).scrollbarXEnabled.value?`scroll`:`hidden`,overflowY:b(c).scrollbarYEnabled.value?`scroll`:`hidden`}},e.$attrs,{tabindex:0}),[D(b(P),{ref:b(d),style:T({minWidth:b(c).scrollbarXEnabled.value?`fit-content`:void 0}),"as-child":r.asChild,as:e.as},{default:l(()=>[o(e.$slots,`default`)]),_:3},8,[`style`,`as-child`,`as`])],16),D(b(P),{as:`style`,nonce:b(s)},{default:l(()=>n[0]||=[f(` /* Hide scrollbars cross-browser and enable momentum scroll for touch devices */ [data-reka-scroll-area-viewport] { scrollbar-width:none; -ms-overflow-style:none; -webkit-overflow-scrolling:touch; } [data-reka-scroll-area-viewport]::-webkit-scrollbar { display:none; } `)]),_:1,__:[0]},8,[`nonce`])],64))}}),Xe=s({__name:`BaseSeparator`,props:{orientation:{type:String,required:!1,default:`horizontal`},decorative:{type:Boolean,required:!1},asChild:{type:Boolean,required:!1},as:{type:null,required:!1}},setup(e){let n=e,r=[`horizontal`,`vertical`];function i(e){return r.includes(e)}let a=_(()=>i(n.orientation)?n.orientation:`horizontal`),s=_(()=>a.value===`vertical`?n.orientation:void 0),c=_(()=>n.decorative?{role:`none`}:{"aria-orientation":s.value,role:`separator`});return(e,n)=>(t(),u(b(P),y({as:e.as,"as-child":e.asChild,"data-orientation":a.value},c.value),{default:l(()=>[o(e.$slots,`default`)]),_:3},16,[`as`,`as-child`,`data-orientation`]))}}),Ze=s({__name:`Separator`,props:{orientation:{type:String,required:!1,default:`horizontal`},decorative:{type:Boolean,required:!1},asChild:{type:Boolean,required:!1},as:{type:null,required:!1}},setup(e){let n=e;return(e,r)=>(t(),u(Xe,d(E(n)),{default:l(()=>[o(e.$slots,`default`)]),_:3},16))}}),Qe=s({__name:`ScrollBar`,props:{orientation:{default:`vertical`},forceMount:{type:Boolean},asChild:{type:Boolean},as:{},class:{type:[Boolean,null,String,Object,Array]}},setup(e){let n=e,r=M(n,`class`);return(i,a)=>(t(),u(b(Ue),y({"data-slot":`scroll-area-scrollbar`,"data-orientation":e.orientation},b(r),{class:b(I)(`data-[orientation=horizontal]:h-2.5 data-[orientation=horizontal]:flex-col data-[orientation=horizontal]:border-t data-[orientation=horizontal]:border-t-transparent data-[orientation=vertical]:h-full data-[orientation=vertical]:w-2.5 data-[orientation=vertical]:border-l data-[orientation=vertical]:border-l-transparent flex touch-none p-px transition-colors select-none`,n.class)}),{default:l(()=>[D(b(Je),{"data-slot":`scroll-area-thumb`,class:`rounded-full relative flex-1 bg-border`})]),_:1},16,[`data-orientation`,`class`]))}}),$e=s({__name:`ScrollArea`,props:{type:{},dir:{},scrollHideDelay:{},asChild:{type:Boolean},as:{},class:{type:[Boolean,null,String,Object,Array]}},setup(e){let n=e,r=M(n,`class`);return(e,i)=>(t(),u(b(Te),y({"data-slot":`scroll-area`},b(r),{class:b(I)(`relative`,n.class)}),{default:l(()=>[D(b(Ye),{"data-slot":`scroll-area-viewport`,class:`size-full rounded-[inherit] transition-[color,box-shadow] outline-none focus-visible:ring-[3px] focus-visible:ring-ring/50 focus-visible:outline-1`},{default:l(()=>[o(e.$slots,`default`)]),_:3}),D(Qe),D(b(De))]),_:3},16,[`class`]))}}),et={class:`grid grid-cols-2 lg:grid-cols-4 gap-4 mb-6`},tt={class:`text-2xl font-bold text-foreground mt-1`},nt={class:`text-xs text-muted-foreground mt-1`},rt={class:`text-2xl font-bold text-foreground mt-1`},it={class:`text-xs text-muted-foreground mt-1`},at={class:`text-2xl font-bold text-foreground mt-1`},ot={class:`text-xs text-muted-foreground mt-1`},st={class:`text-2xl font-bold text-foreground mt-1`},ct={class:`text-xs text-muted-foreground mt-1`},lt=s({__name:`MonitorHeader`,props:{stats:{},activeCount:{},streamCount:{}},setup(e){let n=e,r=_(()=>!n.stats||n.stats.totalRequests===0?`0.0`:(n.stats.errorCount/n.stats.totalRequests*100).toFixed(1)),i=_(()=>!n.stats||n.stats.totalRequests===0?`0.0`:(n.stats.retryCount/n.stats.totalRequests*100).toFixed(1)),a=_(()=>n.stats?n.stats.p50LatencyMs.toFixed(0):`--`);return(n,o)=>(t(),O(`div`,et,[D(b(G),null,{default:l(()=>[D(b(K),{class:`p-4`},{default:l(()=>[o[0]||=h(`p`,{class:`text-sm text-muted-foreground`},`活跃请求`,-1),h(`p`,tt,k(e.activeCount),1),h(`p`,nt,k(e.streamCount)+` 流式 / `+k(e.activeCount-e.streamCount)+` 非流式 `,1)]),_:1})]),_:1}),D(b(G),null,{default:l(()=>[D(b(K),{class:`p-4`},{default:l(()=>[o[1]||=h(`p`,{class:`text-sm text-muted-foreground`},`错误率`,-1),h(`p`,rt,k(r.value)+`%`,1),h(`p`,it,k(e.stats?.errorCount??0)+` / `+k(e.stats?.totalRequests??0),1)]),_:1})]),_:1}),D(b(G),null,{default:l(()=>[D(b(K),{class:`p-4`},{default:l(()=>[o[2]||=h(`p`,{class:`text-sm text-muted-foreground`},`P50 延迟`,-1),h(`p`,at,k(a.value)+`ms`,1),h(`p`,ot,` 平均 `+k(e.stats?.avgLatencyMs?.toFixed(0)??`--`)+`ms `,1)]),_:1})]),_:1}),D(b(G),null,{default:l(()=>[D(b(K),{class:`p-4`},{default:l(()=>[o[3]||=h(`p`,{class:`text-sm text-muted-foreground`},`重试率`,-1),h(`p`,st,k(i.value)+`%`,1),h(`p`,ct,k(e.stats?.retryCount??0)+` / `+k(e.stats?.totalRequests??0),1)]),_:1})]),_:1})]))}}),ut={class:`space-y-3`},dt={key:0,class:`text-sm text-muted-foreground`},ft={class:`flex items-center justify-between text-sm`},pt={class:`font-medium text-foreground`},mt={class:`text-muted-foreground`},ht={key:0,class:`h-2 bg-muted rounded-full overflow-hidden`},gt={key:1,class:`flex gap-3 text-xs text-muted-foreground`},_t=s({__name:`ConcurrencyPanel`,props:{providers:{}},setup(e){function n(e,t){let n=e/t;return n>=1?`bg-red-500`:n>=.8?`bg-orange-500`:n>=.5?`bg-yellow-500`:`bg-green-500`}return(i,a)=>(t(),O(`div`,ut,[e.providers.length===0?(t(),O(`div`,dt,` 暂无并发数据 `)):w(``,!0),(t(!0),O(m,null,r(e.providers,e=>(t(),O(`div`,{key:e.providerId,class:`space-y-1`},[h(`div`,ft,[h(`span`,pt,k(e.providerName),1),h(`span`,mt,[e.maxConcurrency===0?(t(),O(m,{key:0},[f(`未限制`)],64)):(t(),O(m,{key:1},[f(k(e.active)+` / `+k(e.maxConcurrency),1)],64))])]),e.maxConcurrency>0?(t(),O(`div`,ht,[h(`div`,{class:g([`h-full rounded-full transition-all duration-300`,n(e.active,e.maxConcurrency)]),style:T({width:`${Math.min(100,e.active/e.maxConcurrency*100)}%`})},null,6)])):w(``,!0),e.maxConcurrency>0?(t(),O(`div`,gt,[h(`span`,null,`排队: `+k(e.queued),1),h(`span`,null,`队列上限: `+k(e.maxQueueSize),1)])):w(``,!0)]))),128))]))}}),vt={key:0,class:`text-sm text-muted-foreground`},yt={key:1,class:`grid grid-cols-2 gap-3 text-sm`},bt={class:`font-medium text-foreground`},xt={class:`font-medium text-foreground`},St={class:`col-span-2`},Ct={class:`flex items-center justify-between`},wt={class:`text-muted-foreground`},Tt={class:`h-2 bg-muted rounded-full overflow-hidden mt-1`},Et={class:`font-medium text-foreground`},Dt={class:`font-medium text-foreground`},Ot={class:`col-span-2`},kt={class:`font-medium text-foreground`},At=s({__name:`RuntimePanel`,props:{runtime:{}},setup(e){let n=e,r=_(()=>!n.runtime||n.runtime.memoryUsage.heapTotal===0?0:Math.min(100,n.runtime.memoryUsage.heapUsed/n.runtime.memoryUsage.heapTotal*100));function i(e){let t=Math.floor(e/1e3);return`${Math.floor(t/3600)}h ${Math.floor(t%3600/60)}m ${t%60}s`}function a(e){return e<1024?`${e}B`:e<1024*1024?`${(e/1024).toFixed(1)}KB`:`${(e/(1024*1024)).toFixed(1)}MB`}return(n,o)=>e.runtime?(t(),O(`div`,yt,[h(`div`,null,[o[0]||=h(`p`,{class:`text-muted-foreground`},`运行时间`,-1),h(`p`,bt,k(i(e.runtime.uptimeMs)),1)]),h(`div`,null,[o[1]||=h(`p`,{class:`text-muted-foreground`},`内存 RSS`,-1),h(`p`,xt,k(a(e.runtime.memoryUsage.rss)),1)]),h(`div`,St,[h(`div`,Ct,[o[2]||=h(`p`,{class:`text-muted-foreground`},`Heap 使用`,-1),h(`p`,wt,k(a(e.runtime.memoryUsage.heapUsed))+` / `+k(a(e.runtime.memoryUsage.heapTotal)),1)]),h(`div`,Tt,[h(`div`,{class:`h-full bg-blue-500 rounded-full transition-all duration-300`,style:T({width:`${r.value}%`})},null,4)])]),h(`div`,null,[o[3]||=h(`p`,{class:`text-muted-foreground`},`Active Handles`,-1),h(`p`,Et,k(e.runtime.activeHandles),1)]),h(`div`,null,[o[4]||=h(`p`,{class:`text-muted-foreground`},`Active Requests`,-1),h(`p`,Dt,k(e.runtime.activeRequests),1)]),h(`div`,Ot,[o[5]||=h(`p`,{class:`text-muted-foreground`},`Event Loop 延迟`,-1),h(`p`,kt,k(e.runtime.eventLoopDelayMs.toFixed(2))+`ms`,1)])])):(t(),O(`div`,vt,`暂无运行时数据`))}}),jt={key:0,class:`text-sm text-muted-foreground`},Mt={key:1,class:`space-y-2`},Nt={class:`flex items-center justify-between text-sm`},Pt={class:`text-muted-foreground`},Ft={class:`h-2 bg-muted rounded-full overflow-hidden`},It=s({__name:`StatusCodePanel`,props:{byStatusCode:{}},setup(e){let n=e,i=_(()=>Object.values(n.byStatusCode).reduce((e,t)=>e+t,0)),a=_(()=>{let e=n.byStatusCode,t=i.value||1,r=o(e,200,299),a=o(e,400,499)-(e[429]||0),s=e[429]||0,c=o(e,500,599);return[{label:`2xx 成功`,count:r,percent:(r/t*100).toFixed(1),textClass:`text-green-600 dark:text-green-400`,barClass:`bg-green-500`},{label:`4xx 客户端错误`,count:a,percent:(a/t*100).toFixed(1),textClass:`text-yellow-600 dark:text-yellow-400`,barClass:`bg-yellow-500`},{label:`429 限流`,count:s,percent:(s/t*100).toFixed(1),textClass:`text-orange-600 dark:text-orange-400`,barClass:`bg-orange-500`},{label:`5xx 服务端错误`,count:c,percent:(c/t*100).toFixed(1),textClass:`text-red-600 dark:text-red-400`,barClass:`bg-red-500`}].filter(e=>e.count>0)});function o(e,t,n){let r=0;for(let[i,a]of Object.entries(e)){let e=Number(i);e>=t&&e<=n&&(r+=a)}return r}return(e,n)=>i.value===0?(t(),O(`div`,jt,`暂无状态码数据`)):(t(),O(`div`,Mt,[(t(!0),O(m,null,r(a.value,e=>(t(),O(`div`,{key:e.label,class:`space-y-1`},[h(`div`,Nt,[h(`span`,{class:g(e.textClass)},k(e.label),3),h(`span`,Pt,k(e.count)+` (`+k(e.percent)+`%) `,1)]),h(`div`,Ft,[h(`div`,{class:g([`h-full rounded-full transition-all duration-300`,e.barClass]),style:T({width:`${e.percent}%`})},null,6)])]))),128))]))}}),$=s({__name:`Separator`,props:{orientation:{default:`horizontal`},decorative:{type:Boolean,default:!0},asChild:{type:Boolean},as:{},class:{type:[Boolean,null,String,Object,Array]}},setup(e){let n=e,r=M(n,`class`);return(e,i)=>(t(),u(b(Ze),y({"data-slot":`separator`},b(r),{class:b(I)(`shrink-0 bg-border data-[orientation=horizontal]:h-px data-[orientation=horizontal]:w-full data-[orientation=vertical]:w-px data-[orientation=vertical]:self-stretch`,n.class)}),null,16,[`class`]))}}),Lt={key:0,class:`text-sm text-muted-foreground py-4 text-center`},Rt={key:1,class:`space-y-3`},zt={class:`flex items-center gap-2`},Bt={class:`font-medium text-foreground`},Vt={class:`text-xs text-muted-foreground font-mono`},Ht={class:`space-y-1.5 text-sm`},Ut={class:`flex justify-between`},Wt={class:`font-medium text-foreground`},Gt={class:`flex justify-between`},Kt={class:`font-medium text-foreground text-right max-w-[140px] truncate`},qt={class:`flex justify-between`},Jt={class:`font-medium text-foreground`},Yt={class:`flex justify-between`},Xt={class:`font-medium text-foreground`},Zt={class:`flex justify-between`},Qt={class:`font-medium text-foreground`},$t={class:`flex justify-between`},en={class:`font-medium text-foreground`},tn={class:`flex justify-between`},nn={class:`font-medium text-foreground`},rn={key:0,class:`flex items-center gap-1.5`},an={key:1,class:`flex items-center gap-1.5`},on={key:2},sn={class:`space-y-1`},cn={class:`text-muted-foreground w-4`},ln={class:`text-muted-foreground`},un={key:0,class:`text-red-500 truncate`},dn={key:3,class:`text-xs text-muted-foreground`},fn={key:4,class:`pt-2`},pn=s({__name:`RequestDetailPanel`,props:{request:{}},emits:[`viewDetail`],setup(e){let n=e,i=_(()=>n.request?(((n.request.completedAt??Date.now())-n.request.startTime)/1e3).toFixed(1):`--`),a=_(()=>{if(!n.request?.streamMetrics)return`--`;let e=n.request.streamMetrics;if(e.outputTokens==null||e.ttftMs==null)return`--`;let t=(n.request.completedAt??Date.now())-n.request.startTime;return t<=0?`--`:`${(e.outputTokens/(t/1e3)).toFixed(1)} tok/s`});function o(e){switch(e){case`pending`:return`default`;case`failed`:return`destructive`;case`completed`:return`secondary`;default:return`outline`}}function s(e){switch(e){case`pending`:return`进行中`;case`failed`:return`失败`;case`completed`:return`完成`;default:return e}}return(n,c)=>e.request?(t(),O(`div`,Rt,[h(`div`,zt,[h(`span`,Bt,k(e.request.model),1),e.request.isStream?(t(),u(b(W),{key:0,variant:`outline`,class:`text-xs`},{default:l(()=>[...c[1]||=[f(`SSE`,-1)]]),_:1})):w(``,!0),D(b(W),{variant:o(e.request.status)},{default:l(()=>[f(k(s(e.request.status)),1)]),_:1},8,[`variant`])]),h(`p`,Vt,k(e.request.id.slice(0,8)),1),h(`div`,Ht,[h(`div`,Ut,[c[2]||=h(`span`,{class:`text-muted-foreground`},`API 类型`,-1),h(`span`,Wt,k(e.request.apiType.toUpperCase()),1)]),D(b($)),h(`div`,Gt,[c[3]||=h(`span`,{class:`text-muted-foreground`},`Provider`,-1),h(`span`,Kt,k(e.request.providerName),1)]),D(b($)),h(`div`,qt,[c[4]||=h(`span`,{class:`text-muted-foreground`},`耗时`,-1),h(`span`,Jt,k(i.value)+`s`,1)]),D(b($)),h(`div`,Yt,[c[5]||=h(`span`,{class:`text-muted-foreground`},`TTFT`,-1),h(`span`,Xt,k(e.request.streamMetrics?.ttftMs==null?`--`:`${e.request.streamMetrics.ttftMs.toFixed(0)}ms`),1)]),D(b($)),h(`div`,Zt,[c[6]||=h(`span`,{class:`text-muted-foreground`},`Input Tokens`,-1),h(`span`,Qt,k(e.request.streamMetrics?.inputTokens??`--`),1)]),D(b($)),h(`div`,$t,[c[7]||=h(`span`,{class:`text-muted-foreground`},`Output Tokens`,-1),h(`span`,en,k(e.request.streamMetrics?.outputTokens==null?`--`:e.request.streamMetrics.outputTokens),1)]),D(b($)),h(`div`,tn,[c[8]||=h(`span`,{class:`text-muted-foreground`},`速度`,-1),h(`span`,nn,k(a.value),1)])]),e.request.streamMetrics?.isComplete?(t(),O(`div`,rn,[D(b(W),{variant:`secondary`},{default:l(()=>[...c[9]||=[f(`已完成`,-1)]]),_:1}),e.request.streamMetrics.stopReason?(t(),u(b(W),{key:0,variant:`outline`},{default:l(()=>[f(k(e.request.streamMetrics.stopReason),1)]),_:1})):w(``,!0)])):e.request.status===`pending`?(t(),O(`div`,an,[D(b(W),null,{default:l(()=>[...c[10]||=[f(`进行中`,-1)]]),_:1})])):w(``,!0),e.request.attempts.length>0?(t(),O(`div`,on,[c[11]||=h(`p`,{class:`text-xs text-muted-foreground mb-1`},`尝试历史`,-1),h(`div`,sn,[(t(!0),O(m,null,r(e.request.attempts,(e,n)=>(t(),O(`div`,{key:n,class:`flex items-center gap-2 text-xs bg-muted/50 rounded px-2 py-1`},[h(`span`,cn,`#`+k(n+1),1),h(`span`,{class:g(e.statusCode&&e.statusCode<400?`text-green-600`:`text-red-500`)},k(e.statusCode??`N/A`),3),h(`span`,ln,k(e.latencyMs.toFixed(0))+`ms`,1),e.error?(t(),O(`span`,un,k(e.error),1)):w(``,!0)]))),128))])])):w(``,!0),e.request.clientIp?(t(),O(`div`,dn,` IP: `+k(e.request.clientIp),1)):w(``,!0),e.request.status===`completed`||e.request.status===`failed`?(t(),O(`div`,fn,[D(b(F),{variant:`outline`,size:`sm`,class:`w-full`,onClick:c[0]||=t=>n.$emit(`viewDetail`,e.request.id)},{default:l(()=>[...c[12]||=[f(` 查看完整日志 `,-1)]]),_:1})])):w(``,!0)])):(t(),O(`div`,Lt,` 点击请求查看详情 `))}}),mn={key:0,class:`flex items-center justify-center h-full text-sm text-muted-foreground`},hn={key:1,class:`flex items-center justify-center h-full text-sm text-muted-foreground`},gn={key:0,class:`space-y-2`},_n={class:`rounded-md border bg-card`},vn={class:`flex items-center gap-1.5 px-2.5 py-1.5 cursor-pointer hover:bg-muted/50 rounded-t-md`},yn={class:`text-xs text-muted-foreground`},bn={class:`px-2.5 pb-2`},xn={class:`text-xs bg-muted/50 rounded p-2 overflow-y-auto whitespace-pre-wrap break-words max-h-60 text-muted-foreground italic`},Sn={key:1,class:`rounded-md border bg-card`},Cn={class:`flex items-center gap-1.5 px-2.5 py-1.5 border-b`},wn={class:`px-2.5 py-2`},Tn={class:`rounded-md border bg-card`},En={class:`flex items-center gap-1.5 px-2.5 py-1.5 cursor-pointer hover:bg-muted/50 rounded-t-md`},Dn={class:`px-2.5 pb-2`},On={class:`text-xs bg-muted/50 rounded p-2 overflow-y-auto whitespace-pre-wrap break-words max-h-60`},kn={key:1},An={class:`rounded-md border bg-card`},jn={class:`flex items-center gap-1.5 px-2.5 py-1.5 border-b`},Mn={class:`px-2.5 py-2`},Nn={key:2,class:`text-sm text-muted-foreground py-4 text-center`},Pn={key:0,class:`text-xs bg-muted/50 rounded p-2 overflow-y-auto whitespace-pre-wrap break-words max-h-[60vh]`},Fn={key:1,class:`text-sm text-muted-foreground py-4 text-center`},In=s({__name:`StreamResponseViewer`,props:{metrics:{},isStream:{type:Boolean},streamContent:{}},setup(i){let a=i,o=x(null),s=x([]),c=x({}),d=x({}),p=_(()=>{let e=a.streamContent?.blocks;return!!(e&&e.length>0&&e.some(e=>e.type!==`text`||e.content.length>0))});return n(()=>a.streamContent?.textContent,()=>{e(()=>{o.value&&(o.value.scrollTop=o.value.scrollHeight);for(let e of s.value)e.scrollTop=e.scrollHeight})}),(e,n)=>i.isStream?i.streamContent?(t(),u(b(ce),{key:2,"default-value":`structured`,class:`flex flex-col h-full`},{default:l(()=>[D(b(le),{class:`w-fit`},{default:l(()=>[D(b(de),{value:`structured`},{default:l(()=>[...n[0]||=[f(`响应内容`,-1)]]),_:1}),D(b(de),{value:`raw`},{default:l(()=>[...n[1]||=[f(`原始 SSE`,-1)]]),_:1})]),_:1}),D(b(ue),{value:`structured`,class:`flex-1 overflow-y-auto mt-2`},{default:l(()=>[p.value?(t(),O(`div`,gn,[(t(!0),O(m,null,r(i.streamContent.blocks,(e,r)=>(t(),O(m,{key:r},[e.type===`thinking`&&e.content?(t(),u(b(H),{key:0,open:c.value[r]??!0,"onUpdate:open":e=>c.value[r]=e},{default:l(()=>[h(`div`,_n,[D(b(U),{"as-child":``},{default:l(()=>[h(`div`,vn,[D(b(xe),{class:g([`h-3 w-3 transition-transform`,{"rotate-90":c.value[r]??!0}])},null,8,[`class`]),D(b(be),{class:`h-3.5 w-3.5 text-muted-foreground`}),n[2]||=h(`span`,{class:`text-xs font-medium`},`Thinking`,-1),h(`span`,yn,`(`+k(e.content.length)+` 字符)`,1)])]),_:2},1024),D(b(V),null,{default:l(()=>[h(`div`,bn,[h(`pre`,xn,[h(`code`,null,k(e.content),1)])])]),_:2},1024)])]),_:2},1032,[`open`,`onUpdate:open`])):e.type===`text`&&e.content?(t(),O(`div`,Sn,[h(`div`,Cn,[D(b(Se),{class:`h-3.5 w-3.5 text-muted-foreground`}),n[3]||=h(`span`,{class:`text-xs font-medium`},`Reply`,-1)]),h(`div`,wn,[h(`pre`,{ref_for:!0,ref_key:`textContentRefs`,ref:s,class:`text-xs overflow-y-auto whitespace-pre-wrap break-words max-h-60`},[h(`code`,null,k(e.content),1)],512)])])):e.type===`tool_use`?(t(),u(b(H),{key:2,open:d.value[r]??!1,"onUpdate:open":e=>d.value[r]=e},{default:l(()=>[h(`div`,Tn,[D(b(U),{"as-child":``},{default:l(()=>[h(`div`,En,[D(b(xe),{class:g([`h-3 w-3 transition-transform`,{"rotate-90":d.value[r]??!1}])},null,8,[`class`]),D(b(Ce),{class:`h-3.5 w-3.5 text-muted-foreground`}),n[4]||=h(`span`,{class:`text-xs font-medium`},`Tool Use`,-1),e.name?(t(),u(b(W),{key:0,variant:`outline`,class:`text-xs`},{default:l(()=>[f(k(e.name),1)]),_:2},1024)):w(``,!0)])]),_:2},1024),D(b(V),null,{default:l(()=>[h(`div`,Dn,[h(`pre`,On,[h(`code`,null,k(e.content||`(等待数据...)`),1)])])]),_:2},1024)])]),_:2},1032,[`open`,`onUpdate:open`])):w(``,!0)],64))),128))])):i.streamContent.textContent?(t(),O(`div`,kn,[h(`div`,An,[h(`div`,jn,[D(b(Se),{class:`h-3.5 w-3.5 text-muted-foreground`}),n[5]||=h(`span`,{class:`text-xs font-medium`},`Reply`,-1)]),h(`div`,Mn,[h(`pre`,{ref_key:`textContentRef`,ref:o,class:`text-xs overflow-y-auto whitespace-pre-wrap break-words max-h-80`},[h(`code`,null,k(i.streamContent.textContent),1)],512)])])])):(t(),O(`div`,Nn,` 暂无内容 `))]),_:1}),D(b(ue),{value:`raw`,class:`flex-1 overflow-y-auto mt-2`},{default:l(()=>[i.streamContent.rawChunks?(t(),O(`pre`,Pn,[h(`code`,null,k(i.streamContent.rawChunks),1)])):(t(),O(`div`,Fn,` 暂无数据 `))]),_:1})]),_:1})):(t(),O(`div`,hn,` 等待流数据... `)):(t(),O(`div`,mn,` 非流式请求无实时内容 `))}}),Ln={key:0,class:`text-sm text-muted-foreground py-4 text-center`},Rn={key:1,class:`text-sm text-muted-foreground py-4 text-center`},zn={class:`flex flex-wrap gap-1`},Bn={key:0,class:`text-xs text-muted-foreground`},Vn=s({__name:`ProviderStatsTable`,props:{stats:{}},setup(e){let n=e,i=_(()=>n.stats?Object.entries(n.stats.byProvider).filter(([e])=>typeof e==`string`).map(([e,t])=>({id:e,name:t.providerName,stats:t,successRate:t.totalRequests>0?t.successCount/t.totalRequests*100:0,retryRate:t.totalRequests>0?t.retryCount/t.totalRequests*100:0,p99Latency:n.stats.p99LatencyMs.toFixed(0)+`ms`})):[]);return(n,a)=>e.stats?i.value.length===0?(t(),O(`div`,Rn,` 暂无 Provider 统计 `)):(t(),u(b(me),{key:2},{default:l(()=>[D(b(ge),null,{default:l(()=>[D(b(he),null,{default:l(()=>[D(b(X),null,{default:l(()=>[...a[0]||=[f(`Provider`,-1)]]),_:1}),D(b(X),{class:`text-right`},{default:l(()=>[...a[1]||=[f(`请求数`,-1)]]),_:1}),D(b(X),{class:`text-right`},{default:l(()=>[...a[2]||=[f(`成功率`,-1)]]),_:1}),D(b(X),{class:`text-right`},{default:l(()=>[...a[3]||=[f(`平均延迟`,-1)]]),_:1}),D(b(X),{class:`text-right`},{default:l(()=>[...a[4]||=[f(`P99 延迟`,-1)]]),_:1}),D(b(X),{class:`text-right`},{default:l(()=>[...a[5]||=[f(`重试率`,-1)]]),_:1}),D(b(X),null,{default:l(()=>[...a[6]||=[f(`Top Errors`,-1)]]),_:1})]),_:1})]),_:1}),D(b(pe),null,{default:l(()=>[(t(!0),O(m,null,r(i.value,e=>(t(),u(b(he),{key:e.id},{default:l(()=>[D(b(Y),{class:`font-medium`},{default:l(()=>[f(k(e.name),1)]),_:2},1024),D(b(Y),{class:`text-right`},{default:l(()=>[f(k(e.stats.totalRequests),1)]),_:2},1024),D(b(Y),{class:`text-right`},{default:l(()=>[h(`span`,{class:g(e.successRate>=95?`text-green-600`:e.successRate>=80?`text-yellow-600`:`text-red-500`)},k(e.successRate.toFixed(1))+`% `,3)]),_:2},1024),D(b(Y),{class:`text-right`},{default:l(()=>[f(k(e.stats.avgLatencyMs.toFixed(0))+`ms`,1)]),_:2},1024),D(b(Y),{class:`text-right`},{default:l(()=>[f(k(e.p99Latency),1)]),_:2},1024),D(b(Y),{class:`text-right`},{default:l(()=>[h(`span`,{class:g(e.retryRate>10?`text-yellow-600`:``)},k(e.retryRate.toFixed(1))+`% `,3)]),_:2},1024),D(b(Y),null,{default:l(()=>[h(`div`,zn,[(t(!0),O(m,null,r(e.stats.topErrors.slice(0,3),e=>(t(),u(b(W),{key:e.code,variant:`destructive`,class:`text-xs`},{default:l(()=>[f(k(e.code)+` (`+k(e.count)+`) `,1)]),_:2},1024))),128)),e.stats.topErrors.length===0?(t(),O(`span`,Bn,`--`)):w(``,!0)])]),_:2},1024)]),_:2},1024))),128))]),_:1})]),_:1})):(t(),O(`div`,Ln,` 暂无数据 `))}}),Hn={key:0,class:`font-mono text-xs text-muted-foreground font-normal select-all`},Un={key:0,class:`space-y-3 py-4`},Wn={class:`p-4`},Gn={class:`p-4`},Kn={class:`p-4`},qn={class:`p-4`},Jn={key:2,class:`py-8 text-center text-muted-foreground`},Yn=s({__name:`LogDetailDialog`,props:{open:{type:Boolean,required:!0},openModifiers:{}},emits:[`update:open`],setup(e,{expose:n}){let i=c(e,`open`),a=x(!1),o=x(null),s=x([!0,!1,!1,!1]),d=v({client_request:`structured`,upstream_request:`structured`,upstream_response:`structured`,client_response:`structured`}),p=_(()=>o.value?.api_type===`openai`?`openai`:`anthropic`),y=_(()=>{let e=o.value;if(!e)return`{}`;if(!e.client_request)return e.request_body||`{}`;try{let t=JSON.parse(e.client_request);if(t.body!=null)return e.client_request;if(e.request_body){try{t.body=JSON.parse(e.request_body)}catch{t.body=e.request_body}return JSON.stringify(t)}}catch{return e.client_request}return e.client_request}),S=_(()=>{let e=o.value;return e?e.client_response?e.client_response:e.response_body?JSON.stringify({statusCode:e.status_code,body:e.response_body}):``:``});async function T(e){a.value=!0,o.value=null,s.value=[!0,!1,!1,!1],Object.assign(d,{client_request:`structured`,upstream_request:`structured`,upstream_response:`structured`,client_response:`structured`});try{o.value=(await C.getLogDetail(e)).data}catch(e){console.error(`Failed to load log detail:`,e),fe.error(`加载日志详情失败`)}finally{a.value=!1}}return n({load:T}),(e,n)=>(t(),u(b(oe),{open:i.value,"onUpdate:open":n[4]||=e=>i.value=e},{default:l(()=>[D(b(ie),{class:`max-w-4xl max-h-[85vh]`},{default:l(()=>[D(b(ae),null,{default:l(()=>[D(b(se),null,{default:l(()=>[n[5]||=f(`请求详情 `,-1),o.value?(t(),O(`span`,Hn,k(o.value.id.slice(0,8)),1)):w(``,!0)]),_:1})]),_:1}),a.value?(t(),O(`div`,Un,[D(b(ve),{class:`h-6 w-48`}),(t(),O(m,null,r(4,e=>D(b(ve),{key:e,class:`h-12 w-full`})),64))])):o.value?(t(),O(m,{key:1},[D(b(H),{open:s.value[0],"onUpdate:open":n[0]||=e=>s.value[0]=e,class:`border rounded-md mb-2`},{default:l(()=>[D(b(U),{"as-child":``},{default:l(()=>[D(b(F),{variant:`ghost`,class:`w-full px-4 py-3 text-left text-sm font-medium text-foreground bg-muted/50 hover:bg-muted rounded-md flex items-center gap-2`},{default:l(()=>[h(`span`,{class:g([`text-xs transition-transform`,s.value[0]?``:`-rotate-90`])},`▼`,2),n[6]||=f(` 客户端原始请求 `,-1)]),_:1})]),_:1}),D(b(V),null,{default:l(()=>[h(`div`,Wn,[D(_e,{raw:y.value,"api-type":p.value,mode:d.client_request},null,8,[`raw`,`api-type`,`mode`])])]),_:1})]),_:1},8,[`open`]),o.value.upstream_request?(t(),u(b(H),{key:0,open:s.value[1],"onUpdate:open":n[1]||=e=>s.value[1]=e,class:`border rounded-md mb-2`},{default:l(()=>[D(b(U),{"as-child":``},{default:l(()=>[D(b(F),{variant:`ghost`,class:`w-full px-4 py-3 text-left text-sm font-medium text-foreground bg-muted/50 hover:bg-muted rounded-md flex items-center gap-2`},{default:l(()=>[h(`span`,{class:g([`text-xs transition-transform`,s.value[1]?``:`-rotate-90`])},`▼`,2),n[7]||=f(` Router → LLM API 请求 `,-1)]),_:1})]),_:1}),D(b(V),null,{default:l(()=>[h(`div`,Gn,[D(_e,{raw:o.value.upstream_request,"api-type":p.value,"show-url":!0,mode:d.upstream_request},null,8,[`raw`,`api-type`,`mode`])])]),_:1})]),_:1},8,[`open`])):w(``,!0),o.value.upstream_response||o.value.response_body?(t(),u(b(H),{key:1,open:s.value[2],"onUpdate:open":n[2]||=e=>s.value[2]=e,class:`border rounded-md mb-2`},{default:l(()=>[D(b(U),{"as-child":``},{default:l(()=>[D(b(F),{variant:`ghost`,class:`w-full px-4 py-3 text-left text-sm font-medium text-foreground bg-muted/50 hover:bg-muted rounded-md flex items-center gap-2`},{default:l(()=>[h(`span`,{class:g([`text-xs transition-transform`,s.value[2]?``:`-rotate-90`])},`▼`,2),n[8]||=f(` LLM API 返回的原始响应 `,-1)]),_:1})]),_:1}),D(b(V),null,{default:l(()=>[h(`div`,Kn,[D(ye,{raw:o.value.upstream_response||o.value.response_body||`{}`,"api-type":p.value,"is-stream":!!o.value.is_stream,mode:d.upstream_response},null,8,[`raw`,`api-type`,`is-stream`,`mode`])])]),_:1})]),_:1},8,[`open`])):w(``,!0),S.value?(t(),u(b(H),{key:2,open:s.value[3],"onUpdate:open":n[3]||=e=>s.value[3]=e,class:`border rounded-md`},{default:l(()=>[D(b(U),{"as-child":``},{default:l(()=>[D(b(F),{variant:`ghost`,class:`w-full px-4 py-3 text-left text-sm font-medium text-foreground bg-muted/50 hover:bg-muted rounded-md flex items-center gap-2`},{default:l(()=>[h(`span`,{class:g([`text-xs transition-transform`,s.value[3]?``:`-rotate-90`])},`▼`,2),n[9]||=f(` Router → 客户端响应 `,-1)]),_:1})]),_:1}),D(b(V),null,{default:l(()=>[h(`div`,qn,[D(ye,{raw:S.value,"api-type":p.value,"is-stream":!!o.value.is_stream,mode:d.client_response},null,8,[`raw`,`api-type`,`is-stream`,`mode`])])]),_:1})]),_:1},8,[`open`])):w(``,!0),o.value.error_message?(t(),u(b(G),{key:3,class:`bg-destructive/10 ring-destructive/20 mt-2`},{default:l(()=>[D(b(K),{class:`py-3 text-sm text-destructive`},{default:l(()=>[f(k(o.value.error_message),1)]),_:1})]),_:1})):w(``,!0)],64)):(t(),O(`div`,Jn,`未找到日志`))]),_:1})]),_:1},8,[`open`]))}}),Xn={class:`p-6`},Zn={class:`flex items-center justify-between mb-4`},Qn={class:`flex items-center gap-2`},$n={class:`grid grid-cols-3 gap-4 mb-6`},er={class:`flex items-center justify-between`},tr={key:0,class:`text-sm text-muted-foreground py-2`},nr=[`onClick`],rr={class:`text-sm text-foreground truncate flex-1`},ir={class:`text-xs text-muted-foreground shrink-0`},ar={class:`flex items-center justify-between`},or={key:0,class:`text-sm text-muted-foreground py-2`},sr=[`onClick`],cr={class:`text-sm text-foreground truncate flex-1`},lr={class:`text-xs text-muted-foreground shrink-0`},ur={class:`flex items-center justify-between`},dr={key:0,class:`text-sm text-muted-foreground py-2`},fr=[`onClick`],pr={class:`text-sm text-foreground truncate flex-1`},mr={class:`grid grid-cols-1 lg:grid-cols-3 gap-4`},hr={key:0,class:`flex gap-4 min-h-0`},gr={class:`w-[260px] shrink-0 overflow-y-auto pr-2 border-r`},_r={class:`flex-1 min-w-0 overflow-y-auto`},vr={key:1,class:`text-sm text-muted-foreground py-4 text-center`},yr=200,br=s({__name:`Monitor`,setup(e){let n=x([]),o=x([]),s=x(null),c=x(!1),d=x(null),p=x([]),v=x(null),y=x(!1),S=_(()=>n.value.filter(e=>e.isStream).length),T=_(()=>n.value.filter(e=>!e.queued)),E=_(()=>n.value.filter(e=>e.queued===!0));function A(e){s.value=e,c.value=!0}let j=_(()=>s.value?n.value.find(e=>e.id===s.value)??o.value.find(e=>e.id===s.value)??null:null),M=x(!1),N=x(null);function P(e){c.value=!1,M.value=!0,N.value?.load(e)}function F(e){switch(e){case`pending`:return`default`;case`failed`:return`destructive`;case`completed`:return`secondary`;default:return`outline`}}function I(e){switch(e){case`pending`:return`进行中`;case`failed`:return`失败`;case`completed`:return`完成`;default:return e}}function L(e){return((Date.now()-e)/1e3).toFixed(1)}let R=null;function ee(e){let t;try{t=JSON.parse(e.data)}catch{return}switch(e.type){case`request_start`:{let e=t;o.value.some(t=>t.id===e.id)||n.value.unshift(e);break}case`request_update`:n.value=t;break;case`request_complete`:{let e=t;n.value=n.value.filter(t=>t.id!==e.id),o.value.unshift(e),o.value.length>yr&&(o.value.length=yr);break}case`concurrency_update`:p.value=t;break;case`stats_update`:d.value=t;break;case`runtime_update`:v.value=t;break}}function te(){R=new EventSource(`/admin/api/monitor/stream`),R.onopen=()=>{y.value=!0};for(let e of[`request_start`,`request_update`,`request_complete`,`concurrency_update`,`stats_update`,`runtime_update`])R.addEventListener(e,ee);R.onerror=()=>{y.value=!1,R?.close(),R=null}}function z(){R&&=(R.close(),null),y.value=!1}async function ne(){try{let[e,t,r,i,a]=await Promise.allSettled([C.getMonitorActive(),C.getMonitorRecent(),C.getMonitorStats(),C.getMonitorConcurrency(),C.getMonitorRuntime()]);e.status===`fulfilled`&&(n.value=e.value),t.status===`fulfilled`&&(o.value=t.value),r.status===`fulfilled`&&(d.value=r.value),i.status===`fulfilled`&&(p.value=i.value),a.status===`fulfilled`&&(v.value=a.value)}catch(e){console.error(`Failed to load initial monitor data:`,e),d.value=null,p.value=[],v.value=null}}return i(async()=>{await ne(),te()}),a(()=>{z()}),(e,i)=>(t(),O(`div`,Xn,[h(`div`,Zn,[i[2]||=h(`h2`,{class:`text-lg font-semibold text-foreground`},`实时监控`,-1),h(`div`,Qn,[D(b(W),{variant:y.value?`default`:`destructive`},{default:l(()=>[f(k(y.value?`已连接`:`未连接`),1)]),_:1},8,[`variant`])])]),D(lt,{stats:d.value,"active-count":n.value.length,"stream-count":S.value},null,8,[`stats`,`active-count`,`stream-count`]),h(`div`,$n,[D(b(G),null,{default:l(()=>[D(b(q),{class:`pb-2`},{default:l(()=>[h(`div`,er,[D(b(J),{class:`text-sm font-medium text-foreground`},{default:l(()=>[...i[3]||=[f(`活跃请求`,-1)]]),_:1}),D(b(W),{variant:`secondary`},{default:l(()=>[f(k(T.value.length),1)]),_:1})])]),_:1}),D(b(K),null,{default:l(()=>[D(b($e),{class:`h-64`},{default:l(()=>[T.value.length===0?(t(),O(`div`,tr,` 暂无活跃请求 `)):w(``,!0),(t(!0),O(m,null,r(T.value,e=>(t(),O(`div`,{key:e.id,class:g([`flex items-center gap-2 py-2 px-2 rounded cursor-pointer hover:bg-muted/50 transition-colors`,{"bg-muted":s.value===e.id}]),onClick:t=>A(e.id)},[D(b(W),{variant:F(e.status),class:`shrink-0`},{default:l(()=>[f(k(I(e.status)),1)]),_:2},1032,[`variant`]),h(`span`,rr,k(e.model),1),D(b(W),{variant:`outline`,class:`shrink-0 text-xs`},{default:l(()=>[f(k(e.providerName),1)]),_:2},1024),h(`span`,ir,k(L(e.startTime))+`s`,1),e.isStream?(t(),u(b(W),{key:0,variant:`outline`,class:`shrink-0 text-xs`},{default:l(()=>[...i[4]||=[f(`SSE`,-1)]]),_:1})):w(``,!0)],10,nr))),128))]),_:1})]),_:1})]),_:1}),D(b(G),null,{default:l(()=>[D(b(q),{class:`pb-2`},{default:l(()=>[h(`div`,ar,[D(b(J),{class:`text-sm font-medium text-foreground`},{default:l(()=>[...i[5]||=[f(`队列请求`,-1)]]),_:1}),D(b(W),{variant:`secondary`},{default:l(()=>[f(k(E.value.length),1)]),_:1})])]),_:1}),D(b(K),null,{default:l(()=>[D(b($e),{class:`h-64`},{default:l(()=>[E.value.length===0?(t(),O(`div`,or,` 暂无排队请求 `)):w(``,!0),(t(!0),O(m,null,r(E.value,e=>(t(),O(`div`,{key:e.id,class:g([`flex items-center gap-2 py-2 px-2 rounded cursor-pointer hover:bg-muted/50 transition-colors`,{"bg-muted":s.value===e.id}]),onClick:t=>A(e.id)},[D(b(W),{variant:`outline`,class:`shrink-0`},{default:l(()=>[...i[6]||=[f(` 排队 `,-1)]]),_:1}),h(`span`,cr,k(e.model),1),D(b(W),{variant:`outline`,class:`shrink-0 text-xs`},{default:l(()=>[f(k(e.providerName),1)]),_:2},1024),h(`span`,lr,k(L(e.startTime))+`s`,1)],10,sr))),128))]),_:1})]),_:1})]),_:1}),D(b(G),null,{default:l(()=>[D(b(q),{class:`pb-2`},{default:l(()=>[h(`div`,ur,[D(b(J),{class:`text-sm font-medium text-foreground`},{default:l(()=>[...i[7]||=[f(`已完成`,-1)]]),_:1}),D(b(W),{variant:`secondary`},{default:l(()=>[f(k(o.value.length),1)]),_:1})])]),_:1}),D(b(K),null,{default:l(()=>[D(b($e),{class:`h-64`},{default:l(()=>[o.value.length===0?(t(),O(`div`,dr,` 暂无已完成请求 `)):w(``,!0),(t(!0),O(m,null,r(o.value,e=>(t(),O(`div`,{key:e.id,class:g([`flex items-center gap-2 py-1.5 px-2 rounded cursor-pointer opacity-60 hover:opacity-80 hover:bg-muted/50 transition-colors`,{"bg-muted":s.value===e.id}]),onClick:t=>A(e.id)},[D(b(W),{variant:F(e.status),class:`shrink-0`},{default:l(()=>[f(k(I(e.status)),1)]),_:2},1032,[`variant`]),h(`span`,pr,k(e.model),1),D(b(W),{variant:`outline`,class:`shrink-0 text-xs`},{default:l(()=>[f(k(e.providerName),1)]),_:2},1024),e.isStream?(t(),u(b(W),{key:0,variant:`outline`,class:`shrink-0 text-xs`},{default:l(()=>[...i[8]||=[f(`SSE`,-1)]]),_:1})):w(``,!0)],10,fr))),128))]),_:1})]),_:1})]),_:1})]),D(b(G),{class:`mb-4`},{default:l(()=>[D(b(q),null,{default:l(()=>[D(b(J),{class:`text-sm font-medium text-foreground`},{default:l(()=>[...i[9]||=[f(`Provider 统计`,-1)]]),_:1})]),_:1}),D(b(K),null,{default:l(()=>[D(Vn,{stats:d.value},null,8,[`stats`])]),_:1})]),_:1}),h(`div`,mr,[D(b(G),null,{default:l(()=>[D(b(q),null,{default:l(()=>[D(b(J),{class:`text-sm font-medium text-foreground`},{default:l(()=>[...i[10]||=[f(`并发度`,-1)]]),_:1})]),_:1}),D(b(K),null,{default:l(()=>[D(_t,{providers:p.value},null,8,[`providers`])]),_:1})]),_:1}),D(b(G),null,{default:l(()=>[D(b(q),null,{default:l(()=>[D(b(J),{class:`text-sm font-medium text-foreground`},{default:l(()=>[...i[11]||=[f(`状态码分布`,-1)]]),_:1})]),_:1}),D(b(K),null,{default:l(()=>[D(It,{"by-status-code":d.value?.byStatusCode??{}},null,8,[`by-status-code`])]),_:1})]),_:1}),D(b(G),null,{default:l(()=>[D(b(q),null,{default:l(()=>[D(b(J),{class:`text-sm font-medium text-foreground`},{default:l(()=>[...i[12]||=[f(`运行时`,-1)]]),_:1})]),_:1}),D(b(K),null,{default:l(()=>[D(At,{runtime:v.value},null,8,[`runtime`])]),_:1})]),_:1})]),D(b(oe),{open:c.value,"onUpdate:open":i[0]||=e=>c.value=e},{default:l(()=>[D(b(ie),{class:`max-w-5xl max-h-[80vh]`},{default:l(()=>[D(b(ae),null,{default:l(()=>[D(b(se),null,{default:l(()=>[...i[13]||=[f(`请求详情`,-1)]]),_:1})]),_:1}),j.value?(t(),O(`div`,hr,[h(`div`,gr,[D(pn,{request:j.value,onViewDetail:P},null,8,[`request`])]),h(`div`,_r,[D(In,{metrics:j.value.streamMetrics??null,"is-stream":j.value.isStream,"stream-content":j.value.streamContent??void 0},null,8,[`metrics`,`is-stream`,`stream-content`])])])):(t(),O(`div`,vr,` 点击请求查看详情 `))]),_:1})]),_:1},8,[`open`]),D(Yn,{ref_key:`logDetailDialog`,ref:N,open:M.value,"onUpdate:open":i[1]||=e=>M.value=e},null,8,[`open`])]))}});export{br as default};
|