@chenpu17/cc-gw 0.8.16 → 0.8.18

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.
Files changed (40) hide show
  1. package/package.json +5 -5
  2. package/src/web/dist/assets/{About-BFdKK7FR.js → About-eUM4Yunu.js} +1 -1
  3. package/src/web/dist/assets/{ApiKeys-C7GJd1XE.js → ApiKeys-Btsn7hGM.js} +1 -1
  4. package/src/web/dist/assets/{ConfirmDialog-D7vLTReM.js → ConfirmDialog-Gz0TZO4h.js} +1 -1
  5. package/src/web/dist/assets/{Dashboard-BZ61IQTq.js → Dashboard-fqsy4ACs.js} +1 -1
  6. package/src/web/dist/assets/{DialogShell-BWia_d99.js → DialogShell-BTPrPt5l.js} +1 -1
  7. package/src/web/dist/assets/{Events-CM2Ddnk5.js → Events-CFoh5-D7.js} +1 -1
  8. package/src/web/dist/assets/{Help-DndY95PX.js → Help-CVtNNMfH.js} +1 -1
  9. package/src/web/dist/assets/{Login-CCMGFORE.js → Login-BPgP3ttc.js} +1 -1
  10. package/src/web/dist/assets/{Logs-W9L1HmeW.js → Logs-facmq1-X.js} +1 -1
  11. package/src/web/dist/assets/{ModelManagement-Dx1W3OOm.js → ModelManagement-Cy_vY5A5.js} +1 -1
  12. package/src/web/dist/assets/{PageSection-DVs3faWw.js → PageSection-uD1ZrEC_.js} +1 -1
  13. package/src/web/dist/assets/{PageState-Dvjip2P-.js → PageState-Cq7xpTfp.js} +1 -1
  14. package/src/web/dist/assets/{PageToolbar-BxRZF-QJ.js → PageToolbar-BBTEUrko.js} +1 -1
  15. package/src/web/dist/assets/{Profiler-DAhd7InO.js → Profiler-C4MYIrXV.js} +1 -1
  16. package/src/web/dist/assets/RoutingManagement-B7apqRxw.js +1 -0
  17. package/src/web/dist/assets/{Settings-CjF3nCh7.js → Settings-CITbVmtl.js} +1 -1
  18. package/src/web/dist/assets/{Skeleton-DHQ8ApGX.js → Skeleton-DEhFppby.js} +1 -1
  19. package/src/web/dist/assets/{app-DkubSF6m.js → app-BBdow7GJ.js} +3 -3
  20. package/src/web/dist/assets/{card-Bx5Pg_wP.js → card-Do7RepdY.js} +1 -1
  21. package/src/web/dist/assets/{gateway-DOu5TM82.js → gateway-g4snI3mT.js} +1 -1
  22. package/src/web/dist/assets/global-DWbUmocj.css +1 -0
  23. package/src/web/dist/assets/{input-b5NRkUKN.js → input-E9i52oYD.js} +1 -1
  24. package/src/web/dist/assets/{label-DUoPO5Jo.js → label-ClDL__fF.js} +1 -1
  25. package/src/web/dist/assets/{landing-BDpFbgJX.js → landing-DYbMaEZw.js} +1 -1
  26. package/src/web/dist/assets/package-BMoxvLUB.js +1 -0
  27. package/src/web/dist/assets/{popover-BAGiqp11.js → popover-CLCOu-wx.js} +1 -1
  28. package/src/web/dist/assets/{queryKeys-BpeJfcg0.js → queryKeys-BiuXKawV.js} +1 -1
  29. package/src/web/dist/assets/{select-B5oPLG9G.js → select-CohvZ6L7.js} +1 -1
  30. package/src/web/dist/assets/{switch-BDc99Vsq.js → switch-CwlkqLey.js} +1 -1
  31. package/src/web/dist/assets/{table-BG-JeOj-.js → table-CnAkbq3u.js} +1 -1
  32. package/src/web/dist/assets/{useApiQuery-4gJC8RZB.js → useApiQuery-nMqbFkID.js} +1 -1
  33. package/src/web/dist/assets/{useAppMutation-CYWYOsqL.js → useAppMutation-D2xDZiR6.js} +1 -1
  34. package/src/web/dist/assets/{useModelManagementState-Vvv4fzeh.js → useModelManagementState-Zwu7DIdu.js} +1 -1
  35. package/src/web/dist/index.html +3 -3
  36. package/src/web/dist/landing.html +4 -4
  37. package/src/web/dist/assets/RoutingManagement-DTi8Xa_u.js +0 -1
  38. package/src/web/dist/assets/global-CMwh_4v7.css +0 -1
  39. package/src/web/dist/assets/package-C-Cj5JIX.js +0 -1
  40. /package/src/web/dist/assets/{global-D8DuA4wF.js → global-CaQPIFGa.js} +0 -0
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "@chenpu17/cc-gw",
3
- "version": "0.8.16",
3
+ "version": "0.8.18",
4
4
  "private": false,
5
5
  "type": "module",
6
6
  "description": "Local-first AI gateway for personal developers and small software teams, with web console and CLI daemon.",
@@ -34,10 +34,10 @@
34
34
  "README.md"
35
35
  ],
36
36
  "optionalDependencies": {
37
- "@chenpu17/cc-gw-darwin-arm64": "0.8.16",
38
- "@chenpu17/cc-gw-linux-arm64": "0.8.16",
39
- "@chenpu17/cc-gw-linux-x64": "0.8.16",
40
- "@chenpu17/cc-gw-win32-x64": "0.8.16"
37
+ "@chenpu17/cc-gw-linux-arm64": "0.8.18",
38
+ "@chenpu17/cc-gw-linux-x64": "0.8.18",
39
+ "@chenpu17/cc-gw-darwin-arm64": "0.8.18",
40
+ "@chenpu17/cc-gw-win32-x64": "0.8.18"
41
41
  },
42
42
  "dependencies": {
43
43
  "colorette": "^2.0.20",
@@ -1 +1 @@
1
- import{r as n,j as e,ap as _,aQ as m,ax as B,Y as R}from"./vendor-DdPBfMMb.js";import{P as q}from"./PageToolbar-BxRZF-QJ.js";import{P as p}from"./PageSection-DVs3faWw.js";import{P as F,a as C}from"./PageState-Dvjip2P-.js";import{u as M}from"./useAppMutation-CYWYOsqL.js";import{u as z}from"./useApiQuery-4gJC8RZB.js";import{u as D,B as x,r as G}from"./app-DkubSF6m.js";import{B as P,q as I}from"./queryKeys-BpeJfcg0.js";import{C as d,a as c}from"./card-Bx5Pg_wP.js";import{p as Q}from"./package-C-Cj5JIX.js";import{u as $}from"./i18n-C8tBby0x.js";import"./global-D8DuA4wF.js";import"./query-QCek5MsK.js";import"./router-D2Fb4U0L.js";import"./radix-CtQBp6Ie.js";function le(){var h,f,g,v,j,N,y,w,k,S;const{t}=$(),{pushToast:r}=D(),[i,A]=n.useState(null),a=z(I.status.gateway(),{url:"/api/status",method:"GET"},{staleTime:6e4});n.useEffect(()=>{a.isError&&a.error&&r({title:t("about.toast.statusError.title"),description:a.error.message,variant:"error"})},[r,a.error,a.isError,t]);const o=M({mutationFn:async()=>G({url:"/api/version/check",method:"GET"}),successToast:s=>s.updateAvailable?{title:t("about.toast.updateAvailable.title",{version:s.latestVersion}),description:t("about.toast.updateAvailable.description",{packageName:s.packageName})}:{title:t("about.toast.upToDate.title",{version:s.currentVersion}),description:t("about.toast.upToDate.description")},errorToast:s=>({title:t("about.toast.updateError.title"),description:s.message}),onSuccess:async s=>{A(s)}}),l=Q.version,u="2026-04-27T04:39:08.284Z",V=n.useMemo(()=>{var s,T;return[{label:t("about.app.labels.name"),value:e.jsx("span",{className:"font-mono",children:"cc-gw"})},{label:t("about.app.labels.version"),value:e.jsxs("span",{"data-visual-volatile":"true",className:"font-mono text-primary",children:["v",l]})},{label:t("about.app.labels.buildTime"),value:e.jsx("span",{"data-visual-volatile":"true",children:u}),hint:t("about.app.hint.buildTime")},{label:t("about.app.labels.runtime"),value:e.jsx("span",{className:"font-mono",children:((s=a.data)==null?void 0:s.runtime)??"rust"})},{label:t("about.app.labels.backendVersion"),value:e.jsx("span",{"data-visual-volatile":"true",className:"font-mono",children:((T=a.data)==null?void 0:T.backendVersion)??"-"})}]},[l,u,(h=a.data)==null?void 0:h.backendVersion,(f=a.data)==null?void 0:f.runtime,t]),b=n.useMemo(()=>{var s;return a.data?[{label:t("about.status.labels.host"),value:a.data.host??"127.0.0.1"},{label:t("about.status.labels.port"),value:e.jsx("span",{"data-visual-volatile":"true",children:a.data.port.toLocaleString()})},{label:t("about.status.labels.providers"),value:a.data.providers.toLocaleString()},{label:t("about.status.labels.active"),value:(a.data.activeRequests??0).toLocaleString(),hint:t("about.status.hint.active")},{label:t("about.status.labels.platform"),value:a.data.platform??"-"},{label:t("about.status.labels.pid"),value:e.jsx("span",{"data-visual-volatile":"true",children:((s=a.data.pid)==null?void 0:s.toLocaleString())??"-"})}]:[]},[a.data,t]);return e.jsxs("div",{className:"flex flex-col gap-6",children:[e.jsx(q,{info:e.jsxs("span",{className:"rounded-full bg-secondary px-2.5 py-1 text-xs text-muted-foreground","data-visual-volatile":"true",children:["v",l]}),status:e.jsx("span",{className:"rounded-full bg-secondary px-2.5 py-1 text-xs text-muted-foreground",children:"manual refresh only"}),actions:e.jsxs(x,{onClick:()=>o.mutate(),disabled:o.isPending,size:"sm",children:[e.jsx(_,{className:`mr-2 h-4 w-4${o.isPending?" animate-spin":""}`,"aria-hidden":"true"}),o.isPending?t("about.support.actions.checkingUpdates"):t("about.support.actions.checkUpdates")]})}),e.jsxs("div",{className:"grid gap-4 xl:grid-cols-[minmax(0,1.35fr)_minmax(320px,0.85fr)]",children:[e.jsx(d,{className:"overflow-hidden rounded-[1.25rem] border border-white/70 bg-card/95 shadow-[0_20px_50px_-42px_rgba(15,23,42,0.24)]",children:e.jsx(c,{className:"p-5",children:e.jsxs("div",{className:"space-y-3",children:[e.jsxs("div",{className:"inline-flex items-center gap-2 rounded-full bg-secondary px-3 py-1 text-xs font-semibold uppercase tracking-wider text-muted-foreground",children:[e.jsx(m,{className:"h-3.5 w-3.5","aria-hidden":"true"}),"Runtime snapshot"]}),e.jsxs("div",{className:"flex flex-col gap-3 sm:flex-row sm:items-end sm:justify-between",children:[e.jsxs("div",{className:"min-w-0 space-y-1",children:[e.jsxs("p",{"data-visual-volatile":"true",className:"metric-number truncate text-4xl font-semibold tracking-tight text-foreground",children:[((g=a.data)==null?void 0:g.host)??"127.0.0.1",":",((v=a.data)==null?void 0:v.port)??"-"]}),e.jsx("p",{className:"text-sm text-muted-foreground",children:t("about.description")})]}),e.jsxs("div",{className:"grid grid-cols-2 gap-2 text-xs sm:w-56",children:[e.jsx(L,{label:t("about.status.labels.providers"),value:((N=(j=a.data)==null?void 0:j.providers)==null?void 0:N.toLocaleString())??"-"}),e.jsx(L,{label:t("about.status.labels.active"),value:(((y=a.data)==null?void 0:y.activeRequests)??0).toLocaleString()})]})]}),e.jsxs("div",{className:"flex flex-wrap items-center gap-2",children:[e.jsx(P,{variant:"outline",children:((w=a.data)==null?void 0:w.runtime)??"rust"}),e.jsx(P,{variant:"outline",children:((k=a.data)==null?void 0:k.platform)??"-"})]})]})})}),e.jsx(d,{className:"overflow-hidden rounded-[1.25rem] border border-white/70 bg-card/95 shadow-[0_20px_50px_-42px_rgba(15,23,42,0.24)]",children:e.jsx(c,{className:"p-5",children:e.jsxs("div",{className:"space-y-3",children:[e.jsx("p",{className:"text-xs font-semibold uppercase tracking-wider text-muted-foreground",children:"Build"}),e.jsxs("div",{className:"flex flex-wrap items-baseline justify-between gap-2",children:[e.jsxs("p",{"data-visual-volatile":"true",className:"font-mono text-xl font-semibold text-primary",children:["v",l]}),e.jsx("p",{"data-visual-volatile":"true",className:"text-xs text-muted-foreground",children:u})]}),i?e.jsxs("div",{className:"rounded-lg bg-secondary px-4 py-3 text-sm text-muted-foreground",children:[e.jsx("p",{className:"font-medium text-foreground",children:i.updateAvailable?t("about.update.available",{version:i.latestVersion}):t("about.update.current",{version:i.currentVersion})}),e.jsxs("p",{className:"mt-1",children:[t("about.update.channel",{channel:i.channel}),i.publishedAt?` · ${new Date(i.publishedAt).toLocaleString()}`:""]})]}):null,e.jsx("div",{className:"rounded-[0.95rem] bg-secondary/65 px-3.5 py-3 text-sm text-muted-foreground",children:t("about.support.tip")})]})})})]}),e.jsxs("div",{className:"grid gap-6 lg:grid-cols-2",children:[e.jsx(p,{title:t("about.app.title"),description:t("about.app.subtitle"),children:e.jsx(E,{items:V})}),e.jsx(p,{title:t("about.status.title"),description:t("about.status.subtitle"),actions:e.jsxs(x,{variant:"outline",size:"sm",onClick:()=>void a.refetch(),disabled:a.isFetching,children:[e.jsx(B,{className:J(a.isFetching),"aria-hidden":"true"}),a.isFetching?t("common.actions.refreshing"):t("common.actions.refresh")]}),children:a.isLoading?e.jsx(F,{compact:!0,label:t("about.status.loading")}):a.isError?e.jsx(C,{compact:!0,tone:"danger",icon:e.jsx(m,{className:"h-5 w-5","aria-hidden":"true"}),title:t("common.status.error"),description:((S=a.error)==null?void 0:S.message)??t("common.unknownError"),action:e.jsx(x,{variant:"outline",size:"sm",onClick:()=>void a.refetch(),children:t("common.actions.refresh")})}):b.length>0?e.jsx(E,{items:b}):e.jsx(C,{compact:!0,tone:"primary",icon:e.jsx(m,{className:"h-5 w-5","aria-hidden":"true"}),title:t("about.status.empty"),description:t("common.actions.refresh")})})]}),e.jsx(p,{title:t("about.support.title"),description:e.jsxs("span",{className:"space-y-1",children:[e.jsx("span",{className:"block text-sm font-medium text-primary",children:t("about.support.subtitle")}),e.jsx("span",{children:t("about.support.description")})]}),children:e.jsx(d,{className:"rounded-xl bg-card shadow-[var(--surface-shadow)]",children:e.jsxs(c,{className:"flex flex-col gap-4 pt-5 md:flex-row md:items-start md:justify-between",children:[e.jsxs("div",{className:"flex items-start gap-4 rounded-lg bg-secondary p-4",children:[e.jsx("div",{className:"flex h-11 w-11 items-center justify-center rounded-xl bg-primary/10 text-primary",children:e.jsx(R,{className:"h-5 w-5","aria-hidden":"true"})}),e.jsx("p",{className:"max-w-2xl text-sm text-muted-foreground",children:t("about.support.tip")})]}),e.jsx("code",{className:"inline-flex self-start rounded-lg bg-secondary px-3 py-2 text-xs font-medium",children:"~/.cc-gw/config.json"})]})})})]})}function E({items:t}){return t.length===0?null:e.jsx("dl",{className:"grid gap-3 sm:grid-cols-2",children:t.map(r=>e.jsx(d,{className:"rounded-[1rem] border border-white/70 bg-secondary/45 shadow-none",children:e.jsxs(c,{className:"p-4",children:[e.jsx("dt",{className:"text-xs font-semibold uppercase tracking-wider text-muted-foreground",children:r.label}),e.jsx("dd",{className:"metric-number mt-2 text-sm font-semibold text-foreground",children:r.value}),r.hint?e.jsx("p",{className:"mt-1 text-xs text-muted-foreground",children:r.hint}):null]})},r.label))})}function L({label:t,value:r}){return e.jsxs("div",{className:"rounded-[0.9rem] bg-secondary/65 px-3 py-2 text-right",children:[e.jsx("p",{className:"text-[10px] font-semibold uppercase tracking-[0.16em] text-muted-foreground",children:t}),e.jsx("p",{className:"metric-number mt-1 text-sm font-semibold text-foreground",children:r})]})}function J(t){return`mr-2 h-4 w-4${t?" animate-spin":""}`}export{le as default};
1
+ import{r as n,j as e,ap as _,aQ as m,ax as B,Y as R}from"./vendor-DdPBfMMb.js";import{P as q}from"./PageToolbar-BBTEUrko.js";import{P as p}from"./PageSection-uD1ZrEC_.js";import{P as F,a as C}from"./PageState-Cq7xpTfp.js";import{u as M}from"./useAppMutation-D2xDZiR6.js";import{u as z}from"./useApiQuery-nMqbFkID.js";import{u as D,B as x,r as G}from"./app-BBdow7GJ.js";import{B as P,q as I}from"./queryKeys-BiuXKawV.js";import{C as d,a as c}from"./card-Do7RepdY.js";import{p as Q}from"./package-BMoxvLUB.js";import{u as $}from"./i18n-C8tBby0x.js";import"./global-CaQPIFGa.js";import"./query-QCek5MsK.js";import"./router-D2Fb4U0L.js";import"./radix-CtQBp6Ie.js";function le(){var h,f,g,v,j,N,y,w,k,S;const{t}=$(),{pushToast:r}=D(),[i,A]=n.useState(null),a=z(I.status.gateway(),{url:"/api/status",method:"GET"},{staleTime:6e4});n.useEffect(()=>{a.isError&&a.error&&r({title:t("about.toast.statusError.title"),description:a.error.message,variant:"error"})},[r,a.error,a.isError,t]);const o=M({mutationFn:async()=>G({url:"/api/version/check",method:"GET"}),successToast:s=>s.updateAvailable?{title:t("about.toast.updateAvailable.title",{version:s.latestVersion}),description:t("about.toast.updateAvailable.description",{packageName:s.packageName})}:{title:t("about.toast.upToDate.title",{version:s.currentVersion}),description:t("about.toast.upToDate.description")},errorToast:s=>({title:t("about.toast.updateError.title"),description:s.message}),onSuccess:async s=>{A(s)}}),l=Q.version,u="2026-04-28T00:10:34.222Z",V=n.useMemo(()=>{var s,T;return[{label:t("about.app.labels.name"),value:e.jsx("span",{className:"font-mono",children:"cc-gw"})},{label:t("about.app.labels.version"),value:e.jsxs("span",{"data-visual-volatile":"true",className:"font-mono text-primary",children:["v",l]})},{label:t("about.app.labels.buildTime"),value:e.jsx("span",{"data-visual-volatile":"true",children:u}),hint:t("about.app.hint.buildTime")},{label:t("about.app.labels.runtime"),value:e.jsx("span",{className:"font-mono",children:((s=a.data)==null?void 0:s.runtime)??"rust"})},{label:t("about.app.labels.backendVersion"),value:e.jsx("span",{"data-visual-volatile":"true",className:"font-mono",children:((T=a.data)==null?void 0:T.backendVersion)??"-"})}]},[l,u,(h=a.data)==null?void 0:h.backendVersion,(f=a.data)==null?void 0:f.runtime,t]),b=n.useMemo(()=>{var s;return a.data?[{label:t("about.status.labels.host"),value:a.data.host??"127.0.0.1"},{label:t("about.status.labels.port"),value:e.jsx("span",{"data-visual-volatile":"true",children:a.data.port.toLocaleString()})},{label:t("about.status.labels.providers"),value:a.data.providers.toLocaleString()},{label:t("about.status.labels.active"),value:(a.data.activeRequests??0).toLocaleString(),hint:t("about.status.hint.active")},{label:t("about.status.labels.platform"),value:a.data.platform??"-"},{label:t("about.status.labels.pid"),value:e.jsx("span",{"data-visual-volatile":"true",children:((s=a.data.pid)==null?void 0:s.toLocaleString())??"-"})}]:[]},[a.data,t]);return e.jsxs("div",{className:"flex flex-col gap-6",children:[e.jsx(q,{info:e.jsxs("span",{className:"rounded-full bg-secondary px-2.5 py-1 text-xs text-muted-foreground","data-visual-volatile":"true",children:["v",l]}),status:e.jsx("span",{className:"rounded-full bg-secondary px-2.5 py-1 text-xs text-muted-foreground",children:"manual refresh only"}),actions:e.jsxs(x,{onClick:()=>o.mutate(),disabled:o.isPending,size:"sm",children:[e.jsx(_,{className:`mr-2 h-4 w-4${o.isPending?" animate-spin":""}`,"aria-hidden":"true"}),o.isPending?t("about.support.actions.checkingUpdates"):t("about.support.actions.checkUpdates")]})}),e.jsxs("div",{className:"grid gap-4 xl:grid-cols-[minmax(0,1.35fr)_minmax(320px,0.85fr)]",children:[e.jsx(d,{className:"overflow-hidden rounded-[1.25rem] border border-white/70 bg-card/95 shadow-[0_20px_50px_-42px_rgba(15,23,42,0.24)]",children:e.jsx(c,{className:"p-5",children:e.jsxs("div",{className:"space-y-3",children:[e.jsxs("div",{className:"inline-flex items-center gap-2 rounded-full bg-secondary px-3 py-1 text-xs font-semibold uppercase tracking-wider text-muted-foreground",children:[e.jsx(m,{className:"h-3.5 w-3.5","aria-hidden":"true"}),"Runtime snapshot"]}),e.jsxs("div",{className:"flex flex-col gap-3 sm:flex-row sm:items-end sm:justify-between",children:[e.jsxs("div",{className:"min-w-0 space-y-1",children:[e.jsxs("p",{"data-visual-volatile":"true",className:"metric-number truncate text-4xl font-semibold tracking-tight text-foreground",children:[((g=a.data)==null?void 0:g.host)??"127.0.0.1",":",((v=a.data)==null?void 0:v.port)??"-"]}),e.jsx("p",{className:"text-sm text-muted-foreground",children:t("about.description")})]}),e.jsxs("div",{className:"grid grid-cols-2 gap-2 text-xs sm:w-56",children:[e.jsx(L,{label:t("about.status.labels.providers"),value:((N=(j=a.data)==null?void 0:j.providers)==null?void 0:N.toLocaleString())??"-"}),e.jsx(L,{label:t("about.status.labels.active"),value:(((y=a.data)==null?void 0:y.activeRequests)??0).toLocaleString()})]})]}),e.jsxs("div",{className:"flex flex-wrap items-center gap-2",children:[e.jsx(P,{variant:"outline",children:((w=a.data)==null?void 0:w.runtime)??"rust"}),e.jsx(P,{variant:"outline",children:((k=a.data)==null?void 0:k.platform)??"-"})]})]})})}),e.jsx(d,{className:"overflow-hidden rounded-[1.25rem] border border-white/70 bg-card/95 shadow-[0_20px_50px_-42px_rgba(15,23,42,0.24)]",children:e.jsx(c,{className:"p-5",children:e.jsxs("div",{className:"space-y-3",children:[e.jsx("p",{className:"text-xs font-semibold uppercase tracking-wider text-muted-foreground",children:"Build"}),e.jsxs("div",{className:"flex flex-wrap items-baseline justify-between gap-2",children:[e.jsxs("p",{"data-visual-volatile":"true",className:"font-mono text-xl font-semibold text-primary",children:["v",l]}),e.jsx("p",{"data-visual-volatile":"true",className:"text-xs text-muted-foreground",children:u})]}),i?e.jsxs("div",{className:"rounded-lg bg-secondary px-4 py-3 text-sm text-muted-foreground",children:[e.jsx("p",{className:"font-medium text-foreground",children:i.updateAvailable?t("about.update.available",{version:i.latestVersion}):t("about.update.current",{version:i.currentVersion})}),e.jsxs("p",{className:"mt-1",children:[t("about.update.channel",{channel:i.channel}),i.publishedAt?` · ${new Date(i.publishedAt).toLocaleString()}`:""]})]}):null,e.jsx("div",{className:"rounded-[0.95rem] bg-secondary/65 px-3.5 py-3 text-sm text-muted-foreground",children:t("about.support.tip")})]})})})]}),e.jsxs("div",{className:"grid gap-6 lg:grid-cols-2",children:[e.jsx(p,{title:t("about.app.title"),description:t("about.app.subtitle"),children:e.jsx(E,{items:V})}),e.jsx(p,{title:t("about.status.title"),description:t("about.status.subtitle"),actions:e.jsxs(x,{variant:"outline",size:"sm",onClick:()=>void a.refetch(),disabled:a.isFetching,children:[e.jsx(B,{className:J(a.isFetching),"aria-hidden":"true"}),a.isFetching?t("common.actions.refreshing"):t("common.actions.refresh")]}),children:a.isLoading?e.jsx(F,{compact:!0,label:t("about.status.loading")}):a.isError?e.jsx(C,{compact:!0,tone:"danger",icon:e.jsx(m,{className:"h-5 w-5","aria-hidden":"true"}),title:t("common.status.error"),description:((S=a.error)==null?void 0:S.message)??t("common.unknownError"),action:e.jsx(x,{variant:"outline",size:"sm",onClick:()=>void a.refetch(),children:t("common.actions.refresh")})}):b.length>0?e.jsx(E,{items:b}):e.jsx(C,{compact:!0,tone:"primary",icon:e.jsx(m,{className:"h-5 w-5","aria-hidden":"true"}),title:t("about.status.empty"),description:t("common.actions.refresh")})})]}),e.jsx(p,{title:t("about.support.title"),description:e.jsxs("span",{className:"space-y-1",children:[e.jsx("span",{className:"block text-sm font-medium text-primary",children:t("about.support.subtitle")}),e.jsx("span",{children:t("about.support.description")})]}),children:e.jsx(d,{className:"rounded-xl bg-card shadow-[var(--surface-shadow)]",children:e.jsxs(c,{className:"flex flex-col gap-4 pt-5 md:flex-row md:items-start md:justify-between",children:[e.jsxs("div",{className:"flex items-start gap-4 rounded-lg bg-secondary p-4",children:[e.jsx("div",{className:"flex h-11 w-11 items-center justify-center rounded-xl bg-primary/10 text-primary",children:e.jsx(R,{className:"h-5 w-5","aria-hidden":"true"})}),e.jsx("p",{className:"max-w-2xl text-sm text-muted-foreground",children:t("about.support.tip")})]}),e.jsx("code",{className:"inline-flex self-start rounded-lg bg-secondary px-3 py-2 text-xs font-medium",children:"~/.cc-gw/config.json"})]})})})]})}function E({items:t}){return t.length===0?null:e.jsx("dl",{className:"grid gap-3 sm:grid-cols-2",children:t.map(r=>e.jsx(d,{className:"rounded-[1rem] border border-white/70 bg-secondary/45 shadow-none",children:e.jsxs(c,{className:"p-4",children:[e.jsx("dt",{className:"text-xs font-semibold uppercase tracking-wider text-muted-foreground",children:r.label}),e.jsx("dd",{className:"metric-number mt-2 text-sm font-semibold text-foreground",children:r.value}),r.hint?e.jsx("p",{className:"mt-1 text-xs text-muted-foreground",children:r.hint}):null]})},r.label))})}function L({label:t,value:r}){return e.jsxs("div",{className:"rounded-[0.9rem] bg-secondary/65 px-3 py-2 text-right",children:[e.jsx("p",{className:"text-[10px] font-semibold uppercase tracking-[0.16em] text-muted-foreground",children:t}),e.jsx("p",{className:"metric-number mt-1 text-sm font-semibold text-foreground",children:r})]})}function J(t){return`mr-2 h-4 w-4${t?" animate-spin":""}`}export{le as default};
@@ -1 +1 @@
1
- import{r as x,j as e,a1 as os,am as ce,V as Te,aJ as S,aK as de,aL as Ee,aM as cs,aN as Ae,aO as Me,aH as ds}from"./vendor-DdPBfMMb.js";import{r as ps,g as ae,b as te,B as h,u as xs,a as Q,s as U,L as us}from"./app-DkubSF6m.js";import{P as ms}from"./PageToolbar-BxRZF-QJ.js";import{C as hs}from"./ConfirmDialog-D7vLTReM.js";import{D as pe,A as xe,a as ue,b as me,c as qe,d as he,e as ge}from"./DialogShell-BWia_d99.js";import{I as J}from"./input-b5NRkUKN.js";import{L as P}from"./label-DUoPO5Jo.js";import{c as _}from"./global-D8DuA4wF.js";import{u as G}from"./useApiQuery-4gJC8RZB.js";import{q as N,B as C}from"./queryKeys-BpeJfcg0.js";import{u as w}from"./i18n-C8tBby0x.js";import{L as gs}from"./router-D2Fb4U0L.js";import{E as ys,T as bs,a as js,b as ke,c as L,d as fs,e as F}from"./table-BG-JeOj-.js";import{P as We}from"./PageSection-DVs3faWw.js";import{a as oe}from"./PageState-Dvjip2P-.js";import{C as X,a as ye}from"./card-Bx5Pg_wP.js";import{e as vs}from"./charts-core-CK8TVJro.js";import{u as B}from"./useAppMutation-CYWYOsqL.js";import{c as Ks}from"./clipboard-CALi6bTW.js";import"./query-QCek5MsK.js";import"./radix-CtQBp6Ie.js";import"./charts-react-CmmN-08P.js";import"./charts-engine-CWjgwbj5.js";const Le=x.forwardRef(({className:a,...s},l)=>e.jsx("textarea",{className:_("flex min-h-[80px] w-full rounded-xl border border-border bg-card px-3 py-2.5 text-sm text-foreground ring-offset-background placeholder:text-muted-foreground/50 focus-visible:outline-none focus-visible:ring-2 focus-visible:ring-ring focus-visible:ring-offset-2 disabled:cursor-not-allowed disabled:opacity-50",a),ref:l,...s}));Le.displayName="Textarea";const M={listRequest(){return{url:"/api/keys",method:"GET"}},overviewRequest(a){return{url:"/api/stats/api-keys/overview",method:"GET",params:{days:a}}},usageRequest(a,s=10){return{url:"/api/stats/api-keys/usage",method:"GET",params:{days:a,limit:s}}},customEndpointOptionsRequest(){return{url:"/api/custom-endpoints",method:"GET"}},create:async a=>ae(te.post("/api/keys",a)),update:async(a,s)=>{await ae(te.patch(`/api/keys/${a}`,s))},delete:async a=>{await ae(te.delete(`/api/keys/${a}`))},reveal:async a=>ps({url:`/api/keys/${a}/reveal`,method:"GET"})},Fe=[{value:1,labelKey:"apiKeys.analytics.range.today"},{value:7,labelKey:"apiKeys.analytics.range.week"},{value:30,labelKey:"apiKeys.analytics.range.month"}];function Ns(){var l;const a=[{id:"anthropic",label:"Anthropic"},{id:"openai",label:"OpenAI"}],s=G(N.customEndpoints.all(),M.customEndpointOptionsRequest());return x.useMemo(()=>{var o;const t=(((o=s.data)==null?void 0:o.endpoints)??[]).map(u=>({id:u.id,label:u.label||u.id}));return[...a,...t]},[(l=s.data)==null?void 0:l.endpoints])}function Oe({available:a,hint:s,onChange:l,selected:t}){const{t:o}=w(),u=t.length===0,b=()=>{l([])},f=c=>{if(t.includes(c)){l(t.filter(p=>p!==c));return}l([...t,c])};return e.jsxs("div",{className:"space-y-2",children:[e.jsx("div",{className:"rounded-lg border border-border bg-secondary px-3 py-3 text-xs text-muted-foreground",children:s}),e.jsxs("label",{className:"flex cursor-pointer items-center gap-2 rounded-lg border border-border bg-card px-3 py-2.5 transition-colors hover:border-primary/20 hover:bg-accent/50",children:[e.jsx("input",{type:"checkbox",checked:u,onChange:b,className:"h-4 w-4 rounded border-input accent-primary"}),e.jsx("span",{className:"text-sm font-medium",children:o("apiKeys.allEndpoints")})]}),e.jsx("div",{className:"grid max-h-40 gap-1 overflow-y-auto",children:a.map(c=>e.jsxs("label",{className:"flex cursor-pointer items-center gap-2 rounded-lg border border-border bg-card px-3 py-2.5 transition-colors hover:border-primary/20 hover:bg-accent/50",children:[e.jsx("input",{type:"checkbox",checked:!u&&t.includes(c.id),onChange:()=>f(c.id),className:"h-4 w-4 rounded border-input accent-primary"}),e.jsx("span",{className:"text-sm",children:c.label}),e.jsxs("span",{className:"text-xs text-muted-foreground",children:["(",c.id,")"]})]},c.id))})]})}function ws({availableEndpoints:a,isOpen:s,keyDescription:l,keyName:t,maxConcurrency:o,onDescriptionChange:u,onEndpointsChange:b,onKeyNameChange:f,onMaxConcurrencyChange:c,onOpenChange:p,onSubmit:g,selectedEndpoints:n}){const{t:r}=w();return e.jsx(pe,{open:s,onOpenChange:p,children:e.jsxs(xe,{className:"max-w-2xl",children:[e.jsxs(ue,{children:[e.jsx(me,{children:r("apiKeys.createNew")}),e.jsx(qe,{children:r("apiKeys.createDescription")})]}),e.jsxs(he,{className:"space-y-4",children:[e.jsx("div",{className:"rounded-lg border border-primary/20 bg-accent px-4 py-3 text-xs text-primary",children:r("apiKeys.selectEndpoints")}),e.jsxs("div",{className:"grid gap-3 md:grid-cols-3",children:[e.jsxs("div",{className:"rounded-lg border border-primary/20 bg-primary/5 px-3 py-3 text-xs text-primary",children:[e.jsx("p",{className:"font-semibold",children:"Restricted"}),e.jsx("p",{className:"mt-1 opacity-80",children:"Select explicit endpoints before saving."})]}),e.jsxs("div",{className:"rounded-lg border border-amber-200 bg-amber-50 px-3 py-3 text-xs text-amber-800 dark:border-amber-800 dark:bg-amber-950/30 dark:text-amber-200",children:[e.jsx("p",{className:"font-semibold",children:"Unrestricted"}),e.jsx("p",{className:"mt-1 opacity-80",children:"Leave endpoint selection empty for broad access."})]}),e.jsxs("div",{className:"rounded-lg border border-destructive/20 bg-destructive/5 px-3 py-3 text-xs text-destructive",children:[e.jsx("p",{className:"font-semibold",children:"Wildcard"}),e.jsx("p",{className:"mt-1 opacity-80",children:"Special-case key with the highest blast radius."})]})]}),e.jsxs("div",{className:"space-y-2",children:[e.jsxs(P,{htmlFor:"keyName",children:[r("apiKeys.keyNamePlaceholder")," *"]}),e.jsx(J,{id:"keyName",value:t,onChange:y=>f(y.target.value),placeholder:r("apiKeys.keyNamePlaceholder"),onKeyDown:y=>{y.key==="Enter"&&(y.preventDefault(),g())}})]}),e.jsxs("div",{className:"space-y-2",children:[e.jsx(P,{htmlFor:"keyDescription",children:r("apiKeys.descriptionLabel")}),e.jsx(Le,{id:"keyDescription",value:l,onChange:y=>u(y.target.value),placeholder:r("apiKeys.keyDescriptionPlaceholder"),rows:3})]}),e.jsxs("div",{className:"space-y-2",children:[e.jsx(P,{children:r("apiKeys.allowedEndpoints")}),e.jsx(Oe,{available:a,selected:n,onChange:b,hint:r("apiKeys.selectEndpoints")})]}),e.jsxs("div",{className:"space-y-2",children:[e.jsx(P,{htmlFor:"maxConcurrency",children:r("apiKeys.maxConcurrency")}),e.jsx(J,{id:"maxConcurrency",type:"number",min:"0",value:o,onChange:y=>c(y.target.value),placeholder:r("apiKeys.maxConcurrencyPlaceholder")}),e.jsx("p",{className:"text-xs text-muted-foreground",children:r("apiKeys.maxConcurrencyHelper")})]})]}),e.jsxs(ge,{children:[e.jsx(h,{variant:"outline",onClick:()=>p(!1),children:r("common.actions.cancel")}),e.jsx(h,{onClick:g,children:r("apiKeys.createAction")})]})]})})}function Cs({createdKey:a,onClose:s,onCopy:l}){const{t}=w();return e.jsx(pe,{open:!!a,onOpenChange:o=>{o||s()},children:e.jsxs(xe,{className:"max-w-xl",children:[e.jsx(ue,{children:e.jsxs("div",{className:"flex items-center gap-3",children:[e.jsx("div",{className:"flex h-10 w-10 items-center justify-center rounded-full bg-emerald-500/10 text-emerald-600",children:e.jsx(os,{className:"h-5 w-5","aria-hidden":"true"})}),e.jsx(me,{children:t("apiKeys.keyCreated")})]})}),e.jsxs(he,{className:"space-y-4",children:[e.jsx("p",{className:"text-sm font-medium text-amber-600 dark:text-amber-400",children:t("apiKeys.saveKeyWarning")}),e.jsx("div",{className:"rounded-lg border border-border bg-secondary px-4 py-3 font-mono text-sm",children:a==null?void 0:a.key}),a!=null&&a.description?e.jsx("p",{className:"whitespace-pre-wrap text-sm text-muted-foreground",children:a.description}):null]}),e.jsxs(ge,{children:[e.jsxs(h,{onClick:()=>l((a==null?void 0:a.key)??""),children:[e.jsx(ce,{className:"mr-2 h-4 w-4","aria-hidden":"true"}),t("common.actions.copy")]}),e.jsx(h,{variant:"outline",onClick:s,children:t("common.actions.close")})]})]})})}function Es({apiKey:a,availableEndpoints:s,maxConcurrency:l,onClose:t,onEndpointsChange:o,onMaxConcurrencyChange:u,onSave:b,selectedEndpoints:f}){const{t:c}=w();return e.jsx(pe,{open:!!a,onOpenChange:p=>{p||t()},children:e.jsxs(xe,{className:"max-w-2xl",children:[e.jsxs(ue,{children:[e.jsx(me,{children:c("apiKeys.editEndpoints")}),e.jsx(qe,{children:a==null?void 0:a.name})]}),e.jsxs(he,{className:"space-y-4",children:[!(a!=null&&a.isWildcard)&&e.jsxs(e.Fragment,{children:[e.jsx("div",{className:"rounded-lg border border-amber-200 bg-amber-50 px-4 py-3 text-xs text-amber-800 dark:border-amber-800 dark:bg-amber-950/30 dark:text-amber-200",children:c("apiKeys.allEndpoints")}),e.jsx("div",{className:"rounded-lg border border-border bg-secondary px-4 py-3 text-xs text-muted-foreground",children:"Empty selection means unrestricted access. Only explicit selections create a restricted key scope."}),e.jsx(Oe,{available:s,selected:f,onChange:o,hint:c("apiKeys.selectEndpoints")})]}),e.jsxs("div",{className:"space-y-2",children:[e.jsx(P,{htmlFor:"editMaxConcurrency",children:c("apiKeys.maxConcurrency")}),e.jsx(J,{id:"editMaxConcurrency",type:"number",min:"0",value:l,onChange:p=>u(p.target.value),placeholder:c("apiKeys.maxConcurrencyPlaceholder")}),e.jsx("p",{className:"text-xs text-muted-foreground",children:c("apiKeys.maxConcurrencyHelper")})]})]}),e.jsxs(ge,{children:[e.jsx(h,{variant:"outline",onClick:t,children:c("common.actions.cancel")}),e.jsx(h,{onClick:b,children:c("common.save")})]})]})})}function ks({deleteTarget:a,isDeleting:s,onConfirm:l,onOpenChange:t}){const{t:o}=w();return e.jsx(hs,{open:!!a,onOpenChange:t,title:o("apiKeys.deleteDialogTitle"),description:o("apiKeys.confirmDelete"),confirmLabel:a&&s===a.id?o("common.actions.loading"):o("apiKeys.actions.delete"),cancelLabel:o("common.actions.cancel"),loading:a?s===a.id:!1,onConfirm:l,children:a?e.jsx("div",{className:"rounded-lg border border-destructive/20 bg-destructive/10 px-3 py-2 font-mono text-xs text-foreground",children:a.name}):null})}function Ds(){const{t:a}=w();return e.jsx("div",{className:"rounded-[1.15rem] border border-border/55 bg-card/92 p-3 shadow-[var(--surface-shadow)] sm:p-3.5",children:e.jsxs("div",{className:"flex flex-col gap-3 lg:flex-row lg:items-center lg:justify-between",children:[e.jsxs("div",{className:"max-w-md space-y-1",children:[e.jsx("p",{className:"text-[11px] font-semibold uppercase tracking-wider text-primary/75",children:"Recommended"}),e.jsx("h2",{className:"text-sm font-semibold text-foreground",children:a("apiKeys.quickStart.title")}),e.jsx("p",{className:"text-xs leading-5 text-muted-foreground",children:a("apiKeys.quickStart.description")})]}),e.jsx("div",{className:"-mx-1 overflow-x-auto pb-1 lg:mx-0 lg:overflow-visible lg:pb-0",children:e.jsxs("div",{className:"flex gap-2 px-1 md:grid md:grid-cols-3 md:px-0 lg:max-w-3xl",children:[e.jsx(ie,{icon:e.jsx(Te,{className:"h-4 w-4","aria-hidden":"true"}),title:a("apiKeys.quickStart.create.title"),description:a("apiKeys.quickStart.create.description")}),e.jsx(ie,{icon:e.jsx(S,{className:"h-4 w-4","aria-hidden":"true"}),title:a("apiKeys.quickStart.restrict.title"),description:a("apiKeys.quickStart.restrict.description")}),e.jsx(ie,{icon:e.jsx(de,{className:"h-4 w-4","aria-hidden":"true"}),title:a("apiKeys.quickStart.wildcard.title"),description:a("apiKeys.quickStart.wildcard.description")})]})})]})})}function Ts({activeKeysValue:a,enabledKeysValue:s,loading:l,onRangeChange:t,rangeDays:o,requestsChartOption:u,totalKeysValue:b,tokensChartOption:f,usageLength:c}){const{t:p}=w();return e.jsx(We,{eyebrow:"Usage",title:p("apiKeys.analytics.title"),description:p("apiKeys.analytics.description",{days:o}),actions:e.jsx("div",{className:"flex w-full items-center gap-1 overflow-x-auto rounded-full bg-secondary p-1 sm:w-auto",children:Fe.map(g=>{const n=o===g.value;return e.jsx("button",{type:"button",onClick:()=>t(g.value),className:_("inline-flex h-8 shrink-0 items-center rounded-full px-3.5 text-xs font-medium transition-all",n?"bg-primary text-primary-foreground":"text-muted-foreground hover:bg-primary/5 hover:text-foreground"),children:p(g.labelKey)},g.value)})}),children:e.jsxs("div",{className:"space-y-6",children:[e.jsxs("div",{className:"grid gap-4 sm:grid-cols-2 xl:grid-cols-3",children:[e.jsx(ne,{label:p("apiKeys.analytics.cards.total"),value:b}),e.jsx(ne,{label:p("apiKeys.analytics.cards.enabled"),value:s}),e.jsx(ne,{label:p("apiKeys.analytics.cards.active",{days:o}),value:a})]}),e.jsxs("div",{className:"grid gap-6 lg:grid-cols-2",children:[e.jsx(De,{title:p("apiKeys.analytics.charts.requests"),loading:l,empty:c===0,emptyText:p("apiKeys.analytics.empty"),option:u}),e.jsx(De,{title:p("apiKeys.analytics.charts.tokens"),loading:l,empty:c===0,emptyText:p("apiKeys.analytics.empty"),option:f})]})]})})}function As({filteredKeys:a,formatDate:s,hasWildcard:l,isDeleting:t,isRevealing:o,keys:u,onCopy:b,onDelete:f,onEditEndpoints:c,onFilterChange:p,onHide:g,onReveal:n,onStatusFilterChange:r,onToggleEnabled:y,restrictedCount:E,revealedKeys:k,search:K,statusFilter:q,unrestrictedCount:v,viewMode:R,wildcardCount:T,onViewModeChange:z,onCreateKey:Y}){const{t:m}=w();return e.jsx(We,{eyebrow:"Inventory",title:m("apiKeys.list.title"),description:l?m("apiKeys.wildcardHint"):void 0,actions:e.jsxs("div",{className:"flex w-full flex-wrap items-center justify-between gap-2 sm:w-auto sm:justify-end",children:[e.jsxs("div",{className:"flex items-center gap-2 rounded-full bg-secondary p-1",children:[e.jsxs("button",{type:"button",onClick:()=>z("cards"),className:_("inline-flex h-8 items-center gap-1.5 rounded-full px-3 text-xs font-medium transition-all",R==="cards"?"bg-primary text-primary-foreground":"text-muted-foreground hover:bg-primary/5 hover:text-foreground"),children:[e.jsx(Ee,{className:"h-3.5 w-3.5","aria-hidden":"true"}),m("apiKeys.views.cards")]}),e.jsxs("button",{type:"button",onClick:()=>z("compact"),className:_("inline-flex h-8 items-center gap-1.5 rounded-full px-3 text-xs font-medium transition-all",R==="compact"?"bg-primary text-primary-foreground":"text-muted-foreground hover:bg-primary/5 hover:text-foreground"),children:[e.jsx(cs,{className:"h-3.5 w-3.5","aria-hidden":"true"}),m("apiKeys.views.compact")]})]}),e.jsxs("div",{className:"flex flex-wrap items-center gap-2",children:[e.jsx(C,{variant:"outline",children:`${a.length}/${u.length}`}),e.jsx(C,{variant:"outline",children:m("apiKeys.summary.wildcard",{count:T})}),e.jsx(C,{variant:"outline",children:m("apiKeys.summary.restricted",{count:E})})]})]}),children:e.jsxs("div",{className:"space-y-4",children:[e.jsxs("div",{className:"grid gap-4 md:grid-cols-3",children:[e.jsx(re,{label:m("apiKeys.list.title"),value:`${a.length}/${u.length}`,helper:m("apiKeys.filters.searchPlaceholder")}),e.jsx(re,{label:m("apiKeys.summary.wildcard",{count:T}),value:String(T),helper:m("apiKeys.wildcardHint")}),e.jsx(re,{label:m("apiKeys.summary.restricted",{count:E}),value:String(E),helper:m("apiKeys.summary.unrestricted",{count:v})})]}),e.jsxs("div",{className:"grid gap-3 rounded-xl bg-secondary p-4 lg:grid-cols-[minmax(0,0.82fr)_auto] xl:grid-cols-[minmax(0,0.95fr)_auto_auto]",children:[e.jsx(J,{value:K,onChange:j=>p(j.target.value),placeholder:m("apiKeys.filters.searchPlaceholder"),className:"lg:max-w-[680px]"}),e.jsx("div",{className:"flex min-w-max items-center gap-1 overflow-x-auto rounded-full bg-background p-1 lg:justify-self-start xl:justify-self-center",children:["all","enabled","disabled"].map(j=>e.jsx("button",{type:"button",onClick:()=>r(j),className:_("inline-flex h-8 shrink-0 items-center rounded-full px-3.5 text-xs font-medium transition-all",q===j?"bg-primary text-primary-foreground":"text-muted-foreground hover:bg-primary/5 hover:text-foreground"),children:m(`apiKeys.filters.${j}`)},j))}),e.jsxs("div",{className:"flex flex-wrap items-center gap-2 lg:col-span-2 xl:col-span-1 xl:justify-self-end",children:[e.jsx(C,{variant:"secondary",children:m("apiKeys.summary.wildcard",{count:T})}),e.jsx(C,{variant:"secondary",children:m("apiKeys.summary.restricted",{count:E})})]})]}),u.length===0?e.jsx(oe,{compact:!0,tone:"primary",className:"rounded-[1.2rem] border-border/30 bg-background/50",icon:e.jsx(Te,{className:"h-5 w-5","aria-hidden":"true"}),title:m("apiKeys.list.emptyTitle"),description:m("apiKeys.list.empty"),action:e.jsx(h,{size:"sm",onClick:Y,children:m("apiKeys.createNew")})}):a.length===0?e.jsx(oe,{compact:!0,tone:"primary",className:"rounded-[1.2rem] border-border/30 bg-background/50",icon:e.jsx(Ee,{className:"h-5 w-5","aria-hidden":"true"}),title:m("apiKeys.list.emptyFilteredTitle"),description:m("apiKeys.list.emptyFiltered"),action:e.jsx(h,{variant:"outline",size:"sm",onClick:()=>{p(""),r("all")},children:m("common.actions.reset")})}):R==="compact"?e.jsx(Ms,{filteredKeys:a,formatDate:s,isDeleting:t,isRevealing:o,onCopy:b,onDelete:f,onEditEndpoints:c,onHide:g,onReveal:n,onToggleEnabled:y,revealedKeys:k}):e.jsx("div",{className:"grid gap-4",children:a.map(j=>e.jsx(qs,{formatDate:s,isDeleting:t===j.id,isRevealing:o===j.id,keySummary:j,onCopy:b,onDelete:f,onEditEndpoints:c,onHide:g,onReveal:n,onToggleEnabled:y,revealedValue:k.get(j.id)},j.id))})]})})}function Ms({filteredKeys:a,formatDate:s,isDeleting:l,isRevealing:t,onCopy:o,onDelete:u,onEditEndpoints:b,onHide:f,onReveal:c,onToggleEnabled:p,revealedKeys:g}){const{t:n}=w();return e.jsx(X,{className:"overflow-hidden border border-border/65 bg-card/96 shadow-[0_18px_42px_rgba(15,23,42,0.06)] ring-1 ring-white/70",children:e.jsx("div",{className:"overflow-x-auto",children:e.jsxs(bs,{className:"min-w-[980px]",children:[e.jsx(js,{children:e.jsxs(ke,{className:"bg-secondary/45 hover:bg-secondary/45",children:[e.jsx(L,{children:n("apiKeys.table.name")}),e.jsx(L,{children:n("apiKeys.table.access")}),e.jsx(L,{className:"text-right",children:n("apiKeys.requestCount")}),e.jsx(L,{className:"text-right",children:n("apiKeys.totalTokens")}),e.jsx(L,{className:"text-right",children:n("apiKeys.maxConcurrency")}),e.jsx(L,{children:n("apiKeys.lastUsed")}),e.jsx(L,{className:"w-[132px] text-right",children:n("apiKeys.table.actions")})]})}),e.jsx(fs,{children:a.map(r=>{var K,q,v;const y=g.get(r.id),E=(r.totalInputTokens+r.totalOutputTokens).toLocaleString(),k=r.isWildcard?n("apiKeys.wildcard"):(((K=r.allowedEndpoints)==null?void 0:K.length)??0)>0?(q=r.allowedEndpoints)==null?void 0:q.join(", "):n("apiKeys.allEndpoints");return e.jsxs(ke,{children:[e.jsx(F,{className:"py-3",children:e.jsxs("div",{className:"min-w-0 space-y-1",children:[e.jsxs("div",{className:"flex flex-wrap items-center gap-2",children:[e.jsx("span",{className:"font-semibold text-foreground",children:r.name}),r.isWildcard?e.jsx(C,{variant:"secondary",className:"text-[11px]",children:n("apiKeys.wildcard")}):null,e.jsx(C,{variant:r.enabled?"default":"outline",className:"text-[11px]",children:r.enabled?n("apiKeys.status.enabled"):n("apiKeys.status.disabled")})]}),r.isWildcard?null:e.jsxs("div",{className:"flex min-w-0 items-center gap-1.5",children:[e.jsx("code",{className:"max-w-[220px] truncate rounded-md bg-secondary px-2 py-1 font-mono text-xs",children:y??r.maskedKey??"********"}),y?e.jsxs(e.Fragment,{children:[e.jsx(h,{variant:"ghost",size:"icon",className:"h-7 w-7",onClick:()=>o(y),"aria-label":n("common.actions.copy"),children:e.jsx(ce,{className:"h-3.5 w-3.5","aria-hidden":"true"})}),e.jsx(h,{variant:"ghost",size:"icon",className:"h-7 w-7",onClick:()=>f(r.id),"aria-label":n("apiKeys.actions.hide"),children:e.jsx(de,{className:"h-3.5 w-3.5","aria-hidden":"true"})})]}):e.jsx(h,{variant:"ghost",size:"icon",className:"h-7 w-7",onClick:()=>c(r.id),disabled:t===r.id,"aria-label":n("apiKeys.actions.reveal"),children:t===r.id?e.jsx("div",{className:"h-3.5 w-3.5 animate-spin rounded-full border-2 border-primary border-t-transparent"}):e.jsx(Ae,{className:"h-3.5 w-3.5","aria-hidden":"true"})})]})]})}),e.jsx(F,{className:"py-3",children:e.jsxs("div",{className:"max-w-[180px]",children:[e.jsx("div",{className:"truncate text-sm text-foreground",title:k,children:k}),e.jsx("div",{className:"mt-1 text-xs text-muted-foreground",children:r.isWildcard?n("apiKeys.table.accessWildcard"):(((v=r.allowedEndpoints)==null?void 0:v.length)??0)>0?n("apiKeys.endpointRestricted"):n("apiKeys.table.accessOpen")})]})}),e.jsx(F,{className:"py-3 text-right font-medium",children:r.requestCount.toLocaleString()}),e.jsx(F,{className:"py-3 text-right font-medium",children:E}),e.jsx(F,{className:"py-3 text-right font-medium",children:r.maxConcurrency?String(r.maxConcurrency):"—"}),e.jsxs(F,{className:"py-3",children:[e.jsx("div",{className:"text-sm font-medium text-foreground",children:s(r.lastUsedAt)}),e.jsx("div",{className:"mt-1 text-xs text-muted-foreground",children:s(r.createdAt)})]}),e.jsx(F,{className:"py-3",children:e.jsxs("div",{className:"flex justify-end gap-1",children:[e.jsx(h,{variant:"outline",size:"icon",onClick:()=>b(r),className:"h-8 w-8","aria-label":r.isWildcard?n("apiKeys.maxConcurrency"):n("apiKeys.editEndpoints"),title:r.isWildcard?n("apiKeys.maxConcurrency"):n("apiKeys.editEndpoints"),children:e.jsx(S,{className:"h-3.5 w-3.5","aria-hidden":"true"})}),e.jsx(h,{variant:r.enabled?"outline":"default",size:"sm",onClick:()=>p(r.id,r.enabled),className:"h-8 px-2.5 text-xs",children:r.enabled?n("apiKeys.actions.disable"):n("apiKeys.actions.enable")}),r.isWildcard?null:e.jsx(h,{variant:"ghost",size:"icon",className:"h-8 w-8 text-destructive hover:bg-destructive/10 hover:text-destructive",onClick:()=>u(r),disabled:l===r.id,"aria-label":n("apiKeys.actions.delete"),children:e.jsx(Me,{className:"h-3.5 w-3.5","aria-hidden":"true"})})]})})]},r.id)})})]})})})}function ie({description:a,icon:s,title:l}){return e.jsxs("div",{className:"w-[220px] shrink-0 rounded-[1rem] border border-border/45 bg-secondary/72 p-3 shadow-[inset_0_1px_0_rgba(255,255,255,0.6)] dark:border-white/10 dark:bg-slate-900/[0.52] dark:shadow-[inset_0_1px_0_rgba(255,255,255,0.04)] md:w-auto",children:[e.jsx("div",{className:"flex h-7 w-7 items-center justify-center rounded-[0.8rem] bg-background/85 text-primary dark:bg-slate-950/[0.62] sm:h-8 sm:w-8 sm:rounded-[0.85rem]",children:s}),e.jsx("p",{className:"mt-2 text-[12px] font-semibold leading-5 text-foreground sm:mt-2.5 sm:text-[13px]",children:l}),e.jsx("p",{className:"mt-1 line-clamp-2 text-[11px] leading-4.5 text-muted-foreground sm:text-xs sm:leading-5",children:a})]})}function qs({formatDate:a,isDeleting:s,isRevealing:l,keySummary:t,onCopy:o,onDelete:u,onEditEndpoints:b,onHide:f,onReveal:c,onToggleEnabled:p,revealedValue:g}){var y,E,k;const{t:n}=w(),r=(t.totalInputTokens+t.totalOutputTokens).toLocaleString();return e.jsx(X,{"data-testid":"api-key-card",className:"overflow-hidden border border-border/65 bg-card/96 shadow-[0_18px_42px_rgba(15,23,42,0.06)] ring-1 ring-white/70",children:e.jsx(ye,{className:"space-y-4 pt-4",children:e.jsxs("div",{className:"flex flex-col gap-4 lg:flex-row lg:items-start lg:justify-between",children:[e.jsxs("div",{className:"min-w-0 space-y-3",children:[e.jsxs("div",{className:"flex flex-wrap items-center gap-2",children:[e.jsx("h3",{className:"text-base font-semibold",children:t.name}),t.isWildcard?e.jsx(C,{variant:"secondary",children:n("apiKeys.wildcard")}):null,e.jsx(C,{variant:t.enabled?"default":"outline",children:t.enabled?n("apiKeys.status.enabled"):n("apiKeys.status.disabled")}),t.isWildcard?null:e.jsx(C,{variant:"outline",className:"text-xs",children:(((y=t.allowedEndpoints)==null?void 0:y.length)??0)>0?n("apiKeys.endpointRestricted"):n("apiKeys.allEndpoints")}),!t.isWildcard&&t.allowedEndpoints&&t.allowedEndpoints.length>0?t.allowedEndpoints.map(K=>e.jsx(C,{variant:"outline",className:"text-xs",children:K},K)):t.isWildcard?null:e.jsx(C,{variant:"secondary",className:"text-xs opacity-60",children:n("apiKeys.allEndpoints")})]}),e.jsxs("div",{className:"grid gap-2 sm:grid-cols-3",children:[e.jsx(le,{label:n("apiKeys.requestCount"),value:t.requestCount.toLocaleString()}),e.jsx(le,{label:n("apiKeys.totalTokens"),value:r}),e.jsx(le,{label:n("apiKeys.maxConcurrency"),value:t.maxConcurrency?String(t.maxConcurrency):n("apiKeys.maxConcurrencyPlaceholder")})]}),e.jsxs("div",{className:"flex flex-col gap-2 sm:flex-row sm:items-center",children:[e.jsx("code",{className:"block max-w-full break-all rounded-lg bg-secondary px-3 py-1.5 font-mono text-sm",children:t.isWildcard?n("apiKeys.wildcard"):g??t.maskedKey??"********"}),t.isWildcard?null:e.jsx("div",{className:"flex items-center gap-1 self-start",children:g?e.jsxs(e.Fragment,{children:[e.jsx(h,{variant:"ghost",size:"icon",className:"h-8 w-8",onClick:()=>o(g),"aria-label":n("common.actions.copy"),title:n("common.actions.copy"),children:e.jsx(ce,{className:"h-4 w-4","aria-hidden":"true"})}),e.jsx(h,{variant:"ghost",size:"icon",className:"h-8 w-8",onClick:()=>f(t.id),"aria-label":n("apiKeys.actions.hide"),title:n("apiKeys.actions.hide"),children:e.jsx(de,{className:"h-4 w-4","aria-hidden":"true"})})]}):e.jsx(h,{variant:"ghost",size:"icon",className:"h-8 w-8",onClick:()=>c(t.id),disabled:l,"aria-label":n("apiKeys.actions.reveal"),title:n("apiKeys.actions.reveal"),children:l?e.jsx("div",{className:"h-4 w-4 animate-spin rounded-full border-2 border-primary border-t-transparent"}):e.jsx(Ae,{className:"h-4 w-4","aria-hidden":"true"})})})]}),t.isWildcard?e.jsx("p",{className:"text-sm text-muted-foreground",children:n("apiKeys.wildcardHint")}):t.description?e.jsx("p",{className:"whitespace-pre-wrap text-sm text-muted-foreground",children:t.description}):null,t.isWildcard?null:e.jsx("div",{className:"rounded-lg bg-secondary px-3 py-2 text-xs text-muted-foreground",children:(((E=t.allowedEndpoints)==null?void 0:E.length)??0)>0?`${n("apiKeys.allowedEndpoints")}: ${(k=t.allowedEndpoints)==null?void 0:k.join(", ")}`:n("apiKeys.allEndpoints")}),e.jsxs("div",{className:"grid gap-3 text-sm sm:grid-cols-2",children:[e.jsxs("div",{className:"space-y-1",children:[e.jsx("span",{className:"text-xs font-medium uppercase tracking-wide text-muted-foreground",children:n("apiKeys.created")}),e.jsx("p",{className:"font-medium",children:a(t.createdAt)})]}),e.jsxs("div",{className:"space-y-1",children:[e.jsx("span",{className:"text-xs font-medium uppercase tracking-wide text-muted-foreground",children:n("apiKeys.lastUsed")}),e.jsx("p",{className:"font-medium",children:a(t.lastUsedAt)})]})]})]}),e.jsxs("div",{className:"grid gap-2 sm:grid-cols-2 lg:flex lg:flex-wrap lg:justify-end",children:[e.jsxs(h,{variant:"outline",size:"sm",onClick:()=>b(t),className:"w-full lg:w-auto",children:[e.jsx(S,{className:"mr-1 h-3.5 w-3.5","aria-hidden":"true"}),t.isWildcard?n("apiKeys.maxConcurrency"):n("apiKeys.editEndpoints")]}),e.jsx(h,{variant:t.enabled?"outline":"default",size:"sm",onClick:()=>p(t.id,t.enabled),className:"w-full lg:w-auto",children:t.enabled?n("apiKeys.actions.disable"):n("apiKeys.actions.enable")}),t.isWildcard?null:e.jsx(h,{variant:"ghost",size:"icon",className:"h-9 w-full text-destructive hover:bg-destructive/10 hover:text-destructive sm:w-9",onClick:()=>u(t),disabled:s,"aria-label":n("apiKeys.actions.delete"),children:e.jsx(Me,{className:"h-4 w-4","aria-hidden":"true"})})]})]})})})}function ne({label:a,value:s}){return e.jsx(X,{className:"border border-border/70 bg-secondary/70 shadow-none ring-1 ring-white/70",children:e.jsxs(ye,{className:"pt-4",children:[e.jsx("p",{className:"text-xs font-medium uppercase tracking-wider text-muted-foreground",children:a}),e.jsx("p",{className:"metric-number mt-2 text-3xl font-semibold text-foreground",children:s})]})})}function re({helper:a,label:s,value:l}){return e.jsxs("div",{className:"rounded-xl bg-card px-4 py-3 shadow-[var(--surface-shadow)]",children:[e.jsx("p",{className:"text-[11px] font-medium uppercase tracking-wider text-muted-foreground",children:s}),e.jsx("p",{className:"metric-number mt-2 text-xl font-semibold text-foreground",children:l}),e.jsx("p",{className:"mt-1 text-xs text-muted-foreground",children:a})]})}function le({label:a,value:s}){return e.jsxs("div",{className:"rounded-lg bg-secondary px-3 py-2",children:[e.jsx("p",{className:"text-[11px] font-medium uppercase tracking-wider text-muted-foreground",children:a}),e.jsx("p",{className:"mt-1 truncate text-sm font-medium",children:s})]})}function De({empty:a,emptyText:s,loading:l,option:t,title:o}){const{t:u}=w();return e.jsx(X,{children:e.jsxs(ye,{className:"space-y-4 pt-4",children:[e.jsx("h3",{className:"text-base font-semibold",children:o}),l?e.jsx("div",{className:"flex h-[280px] items-center justify-center",children:e.jsx("span",{className:"text-sm text-muted-foreground",children:u("common.loadingShort")})}):a?e.jsx(oe,{compact:!0,className:"min-h-[280px] rounded-[1.1rem] border-border/30 bg-background/50",icon:e.jsx(S,{className:"h-5 w-5","aria-hidden":"true"}),title:s,description:u("apiKeys.analytics.emptyHint"),action:e.jsx(h,{asChild:!0,variant:"ghost",size:"sm",children:e.jsx(gs,{to:"/logs",children:u("apiKeys.analytics.actions.logs")})})}):e.jsx(ys,{echarts:vs,option:t,style:{height:280},notMerge:!0,lazyUpdate:!0})]})})}function Ws(){const{t:a}=w(),{pushToast:s}=xs(),[l,t]=x.useState(!1),[o,u]=x.useState(""),[b,f]=x.useState(""),[c,p]=x.useState([]),[g,n]=x.useState(""),[r,y]=x.useState(null),[E,k]=x.useState(null),[K,q]=x.useState(null),[v,R]=Q(U.apiKeys.rangeDays,7,{serialize:i=>String(i),deserialize:i=>{const d=Number(i);return Fe.some(D=>D.value===d)?d:7}}),[T,z]=x.useState(new Map),[Y,m]=x.useState(null),[j,Z]=x.useState(null),[I,be]=x.useState([]),[H,je]=x.useState(""),[ee,Re]=Q(U.apiKeys.search,""),[V,ze]=Q(U.apiKeys.statusFilter,"all",{serialize:i=>i,deserialize:i=>i==="enabled"||i==="disabled"?i:"all"}),[Pe,_e]=Q(U.apiKeys.viewMode,"compact",{serialize:i=>i,deserialize:i=>i==="cards"?"cards":"compact"}),Ie=Ns(),fe=G(N.apiKeys.all(),M.listRequest()),He=G(N.apiKeys.overview(v),M.overviewRequest(v)),ve=G(N.apiKeys.usage(v),M.usageRequest(v)),Ke=B({mutationFn:M.create,invalidateKeys:[N.apiKeys.all(),N.apiKeys.overview(v),N.apiKeys.usage(v)],successToast:()=>({title:a("apiKeys.toast.keyCreated")}),errorToast:i=>({title:a("apiKeys.toast.createFailure",{message:i.message})})}),$=B({mutationFn:({id:i,...d})=>M.update(i,d),invalidateKeys:[N.apiKeys.all(),N.apiKeys.overview(v),N.apiKeys.usage(v)],successToast:()=>({title:a("apiKeys.toast.keyUpdated")}),errorToast:i=>({title:a("apiKeys.toast.updateFailure",{message:i.message})})}),Ne=B({mutationFn:({id:i})=>M.delete(i),invalidateKeys:[N.apiKeys.all(),N.apiKeys.overview(v),N.apiKeys.usage(v)],successToast:()=>({title:a("apiKeys.toast.keyDeleted")}),errorToast:i=>({title:a("apiKeys.toast.deleteFailure",{message:i.message})})}),we=B({mutationFn:({id:i})=>M.reveal(i),errorToast:i=>({title:a("apiKeys.toast.revealFailure"),description:i.message})}),W=fe.data??[],O=He.data,A=ve.data??[],Ve=W.some(i=>i.isWildcard),$e=W.filter(i=>i.isWildcard).length,Qe=W.filter(i=>{var d;return!i.isWildcard&&(((d=i.allowedEndpoints)==null?void 0:d.length)??0)>0}).length,Ue=W.filter(i=>{var d;return!i.isWildcard&&(((d=i.allowedEndpoints)==null?void 0:d.length)??0)===0}).length,Be=O?O.totalKeys.toLocaleString():"-",Ge=O?O.enabledKeys.toLocaleString():"-",Je=O?O.activeKeys.toLocaleString():"-",Se=x.useMemo(()=>W.filter(i=>{if(!(V==="all"||(V==="enabled"?i.enabled:!i.enabled)))return!1;const D=ee.trim().toLowerCase();return D?[i.name,i.description??"",i.maskedKey??"",...i.allowedEndpoints??[]].join(" ").toLowerCase().includes(D):!0}),[W,ee,V]),Xe=x.useMemo(()=>{const i=A.map(d=>d.apiKeyName??a("apiKeys.analytics.unknownKey"));return{tooltip:{trigger:"axis"},grid:{left:60,right:20,top:40,bottom:40},xAxis:{type:"category",data:i,axisLabel:{interval:0,rotate:20}},yAxis:{type:"value"},series:[{name:a("apiKeys.analytics.requestsSeries"),type:"bar",data:A.map(d=>d.requests),itemStyle:{color:"hsl(var(--primary))"}}]}},[a,A]),Ye=x.useMemo(()=>{const i=A.map(d=>d.apiKeyName??a("apiKeys.analytics.unknownKey"));return{tooltip:{trigger:"axis"},legend:{data:[a("apiKeys.analytics.tokens.input"),a("apiKeys.analytics.tokens.output")]},grid:{left:60,right:20,top:50,bottom:40},xAxis:{type:"category",data:i,axisLabel:{interval:0,rotate:20}},yAxis:{type:"value"},series:[{name:a("apiKeys.analytics.tokens.input"),type:"bar",stack:"tokens",itemStyle:{color:"#22c55e"},data:A.map(d=>d.inputTokens)},{name:a("apiKeys.analytics.tokens.output"),type:"bar",stack:"tokens",itemStyle:{color:"#0ea5e9"},data:A.map(d=>d.outputTokens)}]}},[a,A]),Ce=x.useCallback(()=>{u(""),f(""),p([]),n("")},[]),se=x.useCallback(i=>{t(i),i||Ce()},[Ce]),Ze=x.useCallback(async()=>{if(!o.trim()){s({title:a("apiKeys.errors.nameRequired"),variant:"error"});return}try{const i=await Ke.mutateAsync({name:o.trim(),description:b.trim()||void 0,allowedEndpoints:c.length>0?c:void 0,maxConcurrency:g?Number(g):null});y(i),se(!1)}catch{}},[Ke,se,b,c,g,o,s,a]),es=x.useCallback(async(i,d)=>{try{await $.mutateAsync({id:i,enabled:!d})}catch{}},[$]),ss=x.useCallback(async()=>{if(K){k(K.id);try{await Ne.mutateAsync({id:K.id}),q(null)}catch{}finally{k(null)}}},[K,Ne]),as=x.useCallback(async i=>{if(!T.has(i)){m(i);try{const d=await we.mutateAsync({id:i});z(D=>new Map(D).set(i,d.key))}catch{}finally{m(null)}}},[we,T]),ts=x.useCallback(i=>{z(d=>{const D=new Map(d);return D.delete(i),D})},[]),is=x.useCallback(async i=>{try{await Ks(i),s({title:a("apiKeys.toast.keyCopied"),variant:"success"})}catch(d){s({title:a("apiKeys.toast.copyFailure"),description:d instanceof Error?d.message:a("common.unknownError"),variant:"error"})}},[s,a]),ns=x.useCallback(i=>{Z(i),be(i.allowedEndpoints??[]),je(i.maxConcurrency?String(i.maxConcurrency):"")},[]),rs=x.useCallback(async()=>{if(j)try{await $.mutateAsync({id:j.id,...j.isWildcard?{}:{allowedEndpoints:I.length>0?I:null},maxConcurrency:H?Number(H):null}),Z(null)}catch{}},[j,I,H,$]),ls=x.useCallback(i=>i?new Date(i).toLocaleString():a("common.noData"),[a]);return{activeKeysValue:Je,availableEndpoints:Ie,deleteTarget:K,editEndpointsKey:j,editEndpointsSelection:I,editMaxConcurrency:H,enabledKeysValue:Ge,filteredKeys:Se,formatDate:ls,handleCopyKey:is,handleCreateDialogChange:se,handleCreateKey:Ze,handleDeleteKey:ss,handleHideKey:ts,handleOpenEditEndpoints:ns,handleRevealKey:as,handleSaveEndpoints:rs,handleToggleEnabled:es,hasWildcard:Ve,isCreateDialogOpen:l,isDeleting:E,isRevealing:Y,keys:W,keysQuery:fe,newKeyDescription:b,newKeyEndpoints:c,newKeyMaxConcurrency:g,newKeyName:o,newlyCreatedKey:r,rangeDays:v,requestsChartOption:Xe,restrictedCount:Qe,revealedKeys:T,search:ee,setDeleteTarget:q,setEditEndpointsKey:Z,setEditEndpointsSelection:be,setEditMaxConcurrency:je,setNewKeyDescription:f,setNewKeyEndpoints:p,setNewKeyMaxConcurrency:n,setNewKeyName:u,setNewlyCreatedKey:y,setRangeDays:R,setSearch:Re,setStatusFilter:ze,statusFilter:V,tokensChartOption:Ye,totalKeysValue:Be,unrestrictedCount:Ue,usage:A,usageQuery:ve,viewMode:Pe,wildcardCount:$e,setViewMode:_e}}function ta(){const{t:a}=w(),s=Ws(),l=a("apiKeys.summary.totalCount",{count:s.keys.length});return s.keysQuery.isLoading?e.jsx(us,{}):e.jsxs("div",{className:"flex flex-col gap-6",children:[e.jsx(ms,{info:l?e.jsx("span",{className:"rounded-full bg-secondary px-2.5 py-1 text-xs text-muted-foreground",children:l}):null,status:e.jsxs("span",{className:"text-xs text-muted-foreground",children:[a("apiKeys.summary.wildcard",{count:s.wildcardCount})," / ",a("apiKeys.summary.restricted",{count:s.restrictedCount})," / ",a("apiKeys.summary.unrestricted",{count:s.unrestrictedCount})]}),actions:e.jsxs(h,{size:"sm",onClick:()=>s.handleCreateDialogChange(!0),children:[e.jsx(ds,{className:"mr-2 h-4 w-4","aria-hidden":"true"}),a("apiKeys.createNew")]})}),e.jsx(Ds,{}),e.jsx(Ts,{activeKeysValue:s.activeKeysValue,enabledKeysValue:s.enabledKeysValue,loading:s.usageQuery.isLoading,onRangeChange:s.setRangeDays,rangeDays:s.rangeDays,requestsChartOption:s.requestsChartOption,totalKeysValue:s.totalKeysValue,tokensChartOption:s.tokensChartOption,usageLength:s.usage.length}),e.jsx(As,{filteredKeys:s.filteredKeys,formatDate:s.formatDate,hasWildcard:s.hasWildcard,isDeleting:s.isDeleting,isRevealing:s.isRevealing,keys:s.keys,onCopy:t=>void s.handleCopyKey(t),onDelete:s.setDeleteTarget,onEditEndpoints:s.handleOpenEditEndpoints,onFilterChange:s.setSearch,onHide:s.handleHideKey,onReveal:t=>void s.handleRevealKey(t),onStatusFilterChange:s.setStatusFilter,onToggleEnabled:(t,o)=>void s.handleToggleEnabled(t,o),restrictedCount:s.restrictedCount,revealedKeys:s.revealedKeys,search:s.search,statusFilter:s.statusFilter,unrestrictedCount:s.unrestrictedCount,viewMode:s.viewMode,wildcardCount:s.wildcardCount,onViewModeChange:s.setViewMode,onCreateKey:()=>s.handleCreateDialogChange(!0)}),e.jsx(ws,{availableEndpoints:s.availableEndpoints,isOpen:s.isCreateDialogOpen,keyDescription:s.newKeyDescription,keyName:s.newKeyName,maxConcurrency:s.newKeyMaxConcurrency,onDescriptionChange:s.setNewKeyDescription,onEndpointsChange:s.setNewKeyEndpoints,onKeyNameChange:s.setNewKeyName,onMaxConcurrencyChange:s.setNewKeyMaxConcurrency,onOpenChange:s.handleCreateDialogChange,onSubmit:()=>void s.handleCreateKey(),selectedEndpoints:s.newKeyEndpoints}),e.jsx(Cs,{createdKey:s.newlyCreatedKey,onClose:()=>s.setNewlyCreatedKey(null),onCopy:t=>void s.handleCopyKey(t)}),e.jsx(Es,{apiKey:s.editEndpointsKey,availableEndpoints:s.availableEndpoints,maxConcurrency:s.editMaxConcurrency,onClose:()=>s.setEditEndpointsKey(null),onEndpointsChange:s.setEditEndpointsSelection,onMaxConcurrencyChange:s.setEditMaxConcurrency,onSave:()=>void s.handleSaveEndpoints(),selectedEndpoints:s.editEndpointsSelection}),e.jsx(ks,{deleteTarget:s.deleteTarget,isDeleting:s.isDeleting,onConfirm:()=>void s.handleDeleteKey(),onOpenChange:t=>{!t&&s.isDeleting===null&&s.setDeleteTarget(null)}})]})}export{ta as default};
1
+ import{r as x,j as e,a1 as os,am as ce,V as Te,aJ as S,aK as de,aL as Ee,aM as cs,aN as Ae,aO as Me,aH as ds}from"./vendor-DdPBfMMb.js";import{r as ps,g as ae,b as te,B as h,u as xs,a as Q,s as U,L as us}from"./app-BBdow7GJ.js";import{P as ms}from"./PageToolbar-BBTEUrko.js";import{C as hs}from"./ConfirmDialog-Gz0TZO4h.js";import{D as pe,A as xe,a as ue,b as me,c as qe,d as he,e as ge}from"./DialogShell-BTPrPt5l.js";import{I as J}from"./input-E9i52oYD.js";import{L as P}from"./label-ClDL__fF.js";import{c as _}from"./global-CaQPIFGa.js";import{u as G}from"./useApiQuery-nMqbFkID.js";import{q as N,B as C}from"./queryKeys-BiuXKawV.js";import{u as w}from"./i18n-C8tBby0x.js";import{L as gs}from"./router-D2Fb4U0L.js";import{E as ys,T as bs,a as js,b as ke,c as L,d as fs,e as F}from"./table-CnAkbq3u.js";import{P as We}from"./PageSection-uD1ZrEC_.js";import{a as oe}from"./PageState-Cq7xpTfp.js";import{C as X,a as ye}from"./card-Do7RepdY.js";import{e as vs}from"./charts-core-CK8TVJro.js";import{u as B}from"./useAppMutation-D2xDZiR6.js";import{c as Ks}from"./clipboard-CALi6bTW.js";import"./query-QCek5MsK.js";import"./radix-CtQBp6Ie.js";import"./charts-react-CmmN-08P.js";import"./charts-engine-CWjgwbj5.js";const Le=x.forwardRef(({className:a,...s},l)=>e.jsx("textarea",{className:_("flex min-h-[80px] w-full rounded-xl border border-border bg-card px-3 py-2.5 text-sm text-foreground ring-offset-background placeholder:text-muted-foreground/50 focus-visible:outline-none focus-visible:ring-2 focus-visible:ring-ring focus-visible:ring-offset-2 disabled:cursor-not-allowed disabled:opacity-50",a),ref:l,...s}));Le.displayName="Textarea";const M={listRequest(){return{url:"/api/keys",method:"GET"}},overviewRequest(a){return{url:"/api/stats/api-keys/overview",method:"GET",params:{days:a}}},usageRequest(a,s=10){return{url:"/api/stats/api-keys/usage",method:"GET",params:{days:a,limit:s}}},customEndpointOptionsRequest(){return{url:"/api/custom-endpoints",method:"GET"}},create:async a=>ae(te.post("/api/keys",a)),update:async(a,s)=>{await ae(te.patch(`/api/keys/${a}`,s))},delete:async a=>{await ae(te.delete(`/api/keys/${a}`))},reveal:async a=>ps({url:`/api/keys/${a}/reveal`,method:"GET"})},Fe=[{value:1,labelKey:"apiKeys.analytics.range.today"},{value:7,labelKey:"apiKeys.analytics.range.week"},{value:30,labelKey:"apiKeys.analytics.range.month"}];function Ns(){var l;const a=[{id:"anthropic",label:"Anthropic"},{id:"openai",label:"OpenAI"}],s=G(N.customEndpoints.all(),M.customEndpointOptionsRequest());return x.useMemo(()=>{var o;const t=(((o=s.data)==null?void 0:o.endpoints)??[]).map(u=>({id:u.id,label:u.label||u.id}));return[...a,...t]},[(l=s.data)==null?void 0:l.endpoints])}function Oe({available:a,hint:s,onChange:l,selected:t}){const{t:o}=w(),u=t.length===0,b=()=>{l([])},f=c=>{if(t.includes(c)){l(t.filter(p=>p!==c));return}l([...t,c])};return e.jsxs("div",{className:"space-y-2",children:[e.jsx("div",{className:"rounded-lg border border-border bg-secondary px-3 py-3 text-xs text-muted-foreground",children:s}),e.jsxs("label",{className:"flex cursor-pointer items-center gap-2 rounded-lg border border-border bg-card px-3 py-2.5 transition-colors hover:border-primary/20 hover:bg-accent/50",children:[e.jsx("input",{type:"checkbox",checked:u,onChange:b,className:"h-4 w-4 rounded border-input accent-primary"}),e.jsx("span",{className:"text-sm font-medium",children:o("apiKeys.allEndpoints")})]}),e.jsx("div",{className:"grid max-h-40 gap-1 overflow-y-auto",children:a.map(c=>e.jsxs("label",{className:"flex cursor-pointer items-center gap-2 rounded-lg border border-border bg-card px-3 py-2.5 transition-colors hover:border-primary/20 hover:bg-accent/50",children:[e.jsx("input",{type:"checkbox",checked:!u&&t.includes(c.id),onChange:()=>f(c.id),className:"h-4 w-4 rounded border-input accent-primary"}),e.jsx("span",{className:"text-sm",children:c.label}),e.jsxs("span",{className:"text-xs text-muted-foreground",children:["(",c.id,")"]})]},c.id))})]})}function ws({availableEndpoints:a,isOpen:s,keyDescription:l,keyName:t,maxConcurrency:o,onDescriptionChange:u,onEndpointsChange:b,onKeyNameChange:f,onMaxConcurrencyChange:c,onOpenChange:p,onSubmit:g,selectedEndpoints:n}){const{t:r}=w();return e.jsx(pe,{open:s,onOpenChange:p,children:e.jsxs(xe,{className:"max-w-2xl",children:[e.jsxs(ue,{children:[e.jsx(me,{children:r("apiKeys.createNew")}),e.jsx(qe,{children:r("apiKeys.createDescription")})]}),e.jsxs(he,{className:"space-y-4",children:[e.jsx("div",{className:"rounded-lg border border-primary/20 bg-accent px-4 py-3 text-xs text-primary",children:r("apiKeys.selectEndpoints")}),e.jsxs("div",{className:"grid gap-3 md:grid-cols-3",children:[e.jsxs("div",{className:"rounded-lg border border-primary/20 bg-primary/5 px-3 py-3 text-xs text-primary",children:[e.jsx("p",{className:"font-semibold",children:"Restricted"}),e.jsx("p",{className:"mt-1 opacity-80",children:"Select explicit endpoints before saving."})]}),e.jsxs("div",{className:"rounded-lg border border-amber-200 bg-amber-50 px-3 py-3 text-xs text-amber-800 dark:border-amber-800 dark:bg-amber-950/30 dark:text-amber-200",children:[e.jsx("p",{className:"font-semibold",children:"Unrestricted"}),e.jsx("p",{className:"mt-1 opacity-80",children:"Leave endpoint selection empty for broad access."})]}),e.jsxs("div",{className:"rounded-lg border border-destructive/20 bg-destructive/5 px-3 py-3 text-xs text-destructive",children:[e.jsx("p",{className:"font-semibold",children:"Wildcard"}),e.jsx("p",{className:"mt-1 opacity-80",children:"Special-case key with the highest blast radius."})]})]}),e.jsxs("div",{className:"space-y-2",children:[e.jsxs(P,{htmlFor:"keyName",children:[r("apiKeys.keyNamePlaceholder")," *"]}),e.jsx(J,{id:"keyName",value:t,onChange:y=>f(y.target.value),placeholder:r("apiKeys.keyNamePlaceholder"),onKeyDown:y=>{y.key==="Enter"&&(y.preventDefault(),g())}})]}),e.jsxs("div",{className:"space-y-2",children:[e.jsx(P,{htmlFor:"keyDescription",children:r("apiKeys.descriptionLabel")}),e.jsx(Le,{id:"keyDescription",value:l,onChange:y=>u(y.target.value),placeholder:r("apiKeys.keyDescriptionPlaceholder"),rows:3})]}),e.jsxs("div",{className:"space-y-2",children:[e.jsx(P,{children:r("apiKeys.allowedEndpoints")}),e.jsx(Oe,{available:a,selected:n,onChange:b,hint:r("apiKeys.selectEndpoints")})]}),e.jsxs("div",{className:"space-y-2",children:[e.jsx(P,{htmlFor:"maxConcurrency",children:r("apiKeys.maxConcurrency")}),e.jsx(J,{id:"maxConcurrency",type:"number",min:"0",value:o,onChange:y=>c(y.target.value),placeholder:r("apiKeys.maxConcurrencyPlaceholder")}),e.jsx("p",{className:"text-xs text-muted-foreground",children:r("apiKeys.maxConcurrencyHelper")})]})]}),e.jsxs(ge,{children:[e.jsx(h,{variant:"outline",onClick:()=>p(!1),children:r("common.actions.cancel")}),e.jsx(h,{onClick:g,children:r("apiKeys.createAction")})]})]})})}function Cs({createdKey:a,onClose:s,onCopy:l}){const{t}=w();return e.jsx(pe,{open:!!a,onOpenChange:o=>{o||s()},children:e.jsxs(xe,{className:"max-w-xl",children:[e.jsx(ue,{children:e.jsxs("div",{className:"flex items-center gap-3",children:[e.jsx("div",{className:"flex h-10 w-10 items-center justify-center rounded-full bg-emerald-500/10 text-emerald-600",children:e.jsx(os,{className:"h-5 w-5","aria-hidden":"true"})}),e.jsx(me,{children:t("apiKeys.keyCreated")})]})}),e.jsxs(he,{className:"space-y-4",children:[e.jsx("p",{className:"text-sm font-medium text-amber-600 dark:text-amber-400",children:t("apiKeys.saveKeyWarning")}),e.jsx("div",{className:"rounded-lg border border-border bg-secondary px-4 py-3 font-mono text-sm",children:a==null?void 0:a.key}),a!=null&&a.description?e.jsx("p",{className:"whitespace-pre-wrap text-sm text-muted-foreground",children:a.description}):null]}),e.jsxs(ge,{children:[e.jsxs(h,{onClick:()=>l((a==null?void 0:a.key)??""),children:[e.jsx(ce,{className:"mr-2 h-4 w-4","aria-hidden":"true"}),t("common.actions.copy")]}),e.jsx(h,{variant:"outline",onClick:s,children:t("common.actions.close")})]})]})})}function Es({apiKey:a,availableEndpoints:s,maxConcurrency:l,onClose:t,onEndpointsChange:o,onMaxConcurrencyChange:u,onSave:b,selectedEndpoints:f}){const{t:c}=w();return e.jsx(pe,{open:!!a,onOpenChange:p=>{p||t()},children:e.jsxs(xe,{className:"max-w-2xl",children:[e.jsxs(ue,{children:[e.jsx(me,{children:c("apiKeys.editEndpoints")}),e.jsx(qe,{children:a==null?void 0:a.name})]}),e.jsxs(he,{className:"space-y-4",children:[!(a!=null&&a.isWildcard)&&e.jsxs(e.Fragment,{children:[e.jsx("div",{className:"rounded-lg border border-amber-200 bg-amber-50 px-4 py-3 text-xs text-amber-800 dark:border-amber-800 dark:bg-amber-950/30 dark:text-amber-200",children:c("apiKeys.allEndpoints")}),e.jsx("div",{className:"rounded-lg border border-border bg-secondary px-4 py-3 text-xs text-muted-foreground",children:"Empty selection means unrestricted access. Only explicit selections create a restricted key scope."}),e.jsx(Oe,{available:s,selected:f,onChange:o,hint:c("apiKeys.selectEndpoints")})]}),e.jsxs("div",{className:"space-y-2",children:[e.jsx(P,{htmlFor:"editMaxConcurrency",children:c("apiKeys.maxConcurrency")}),e.jsx(J,{id:"editMaxConcurrency",type:"number",min:"0",value:l,onChange:p=>u(p.target.value),placeholder:c("apiKeys.maxConcurrencyPlaceholder")}),e.jsx("p",{className:"text-xs text-muted-foreground",children:c("apiKeys.maxConcurrencyHelper")})]})]}),e.jsxs(ge,{children:[e.jsx(h,{variant:"outline",onClick:t,children:c("common.actions.cancel")}),e.jsx(h,{onClick:b,children:c("common.save")})]})]})})}function ks({deleteTarget:a,isDeleting:s,onConfirm:l,onOpenChange:t}){const{t:o}=w();return e.jsx(hs,{open:!!a,onOpenChange:t,title:o("apiKeys.deleteDialogTitle"),description:o("apiKeys.confirmDelete"),confirmLabel:a&&s===a.id?o("common.actions.loading"):o("apiKeys.actions.delete"),cancelLabel:o("common.actions.cancel"),loading:a?s===a.id:!1,onConfirm:l,children:a?e.jsx("div",{className:"rounded-lg border border-destructive/20 bg-destructive/10 px-3 py-2 font-mono text-xs text-foreground",children:a.name}):null})}function Ds(){const{t:a}=w();return e.jsx("div",{className:"rounded-[1.15rem] border border-border/55 bg-card/92 p-3 shadow-[var(--surface-shadow)] sm:p-3.5",children:e.jsxs("div",{className:"flex flex-col gap-3 lg:flex-row lg:items-center lg:justify-between",children:[e.jsxs("div",{className:"max-w-md space-y-1",children:[e.jsx("p",{className:"text-[11px] font-semibold uppercase tracking-wider text-primary/75",children:"Recommended"}),e.jsx("h2",{className:"text-sm font-semibold text-foreground",children:a("apiKeys.quickStart.title")}),e.jsx("p",{className:"text-xs leading-5 text-muted-foreground",children:a("apiKeys.quickStart.description")})]}),e.jsx("div",{className:"-mx-1 overflow-x-auto pb-1 lg:mx-0 lg:overflow-visible lg:pb-0",children:e.jsxs("div",{className:"flex gap-2 px-1 md:grid md:grid-cols-3 md:px-0 lg:max-w-3xl",children:[e.jsx(ie,{icon:e.jsx(Te,{className:"h-4 w-4","aria-hidden":"true"}),title:a("apiKeys.quickStart.create.title"),description:a("apiKeys.quickStart.create.description")}),e.jsx(ie,{icon:e.jsx(S,{className:"h-4 w-4","aria-hidden":"true"}),title:a("apiKeys.quickStart.restrict.title"),description:a("apiKeys.quickStart.restrict.description")}),e.jsx(ie,{icon:e.jsx(de,{className:"h-4 w-4","aria-hidden":"true"}),title:a("apiKeys.quickStart.wildcard.title"),description:a("apiKeys.quickStart.wildcard.description")})]})})]})})}function Ts({activeKeysValue:a,enabledKeysValue:s,loading:l,onRangeChange:t,rangeDays:o,requestsChartOption:u,totalKeysValue:b,tokensChartOption:f,usageLength:c}){const{t:p}=w();return e.jsx(We,{eyebrow:"Usage",title:p("apiKeys.analytics.title"),description:p("apiKeys.analytics.description",{days:o}),actions:e.jsx("div",{className:"flex w-full items-center gap-1 overflow-x-auto rounded-full bg-secondary p-1 sm:w-auto",children:Fe.map(g=>{const n=o===g.value;return e.jsx("button",{type:"button",onClick:()=>t(g.value),className:_("inline-flex h-8 shrink-0 items-center rounded-full px-3.5 text-xs font-medium transition-all",n?"bg-primary text-primary-foreground":"text-muted-foreground hover:bg-primary/5 hover:text-foreground"),children:p(g.labelKey)},g.value)})}),children:e.jsxs("div",{className:"space-y-6",children:[e.jsxs("div",{className:"grid gap-4 sm:grid-cols-2 xl:grid-cols-3",children:[e.jsx(ne,{label:p("apiKeys.analytics.cards.total"),value:b}),e.jsx(ne,{label:p("apiKeys.analytics.cards.enabled"),value:s}),e.jsx(ne,{label:p("apiKeys.analytics.cards.active",{days:o}),value:a})]}),e.jsxs("div",{className:"grid gap-6 lg:grid-cols-2",children:[e.jsx(De,{title:p("apiKeys.analytics.charts.requests"),loading:l,empty:c===0,emptyText:p("apiKeys.analytics.empty"),option:u}),e.jsx(De,{title:p("apiKeys.analytics.charts.tokens"),loading:l,empty:c===0,emptyText:p("apiKeys.analytics.empty"),option:f})]})]})})}function As({filteredKeys:a,formatDate:s,hasWildcard:l,isDeleting:t,isRevealing:o,keys:u,onCopy:b,onDelete:f,onEditEndpoints:c,onFilterChange:p,onHide:g,onReveal:n,onStatusFilterChange:r,onToggleEnabled:y,restrictedCount:E,revealedKeys:k,search:K,statusFilter:q,unrestrictedCount:v,viewMode:R,wildcardCount:T,onViewModeChange:z,onCreateKey:Y}){const{t:m}=w();return e.jsx(We,{eyebrow:"Inventory",title:m("apiKeys.list.title"),description:l?m("apiKeys.wildcardHint"):void 0,actions:e.jsxs("div",{className:"flex w-full flex-wrap items-center justify-between gap-2 sm:w-auto sm:justify-end",children:[e.jsxs("div",{className:"flex items-center gap-2 rounded-full bg-secondary p-1",children:[e.jsxs("button",{type:"button",onClick:()=>z("cards"),className:_("inline-flex h-8 items-center gap-1.5 rounded-full px-3 text-xs font-medium transition-all",R==="cards"?"bg-primary text-primary-foreground":"text-muted-foreground hover:bg-primary/5 hover:text-foreground"),children:[e.jsx(Ee,{className:"h-3.5 w-3.5","aria-hidden":"true"}),m("apiKeys.views.cards")]}),e.jsxs("button",{type:"button",onClick:()=>z("compact"),className:_("inline-flex h-8 items-center gap-1.5 rounded-full px-3 text-xs font-medium transition-all",R==="compact"?"bg-primary text-primary-foreground":"text-muted-foreground hover:bg-primary/5 hover:text-foreground"),children:[e.jsx(cs,{className:"h-3.5 w-3.5","aria-hidden":"true"}),m("apiKeys.views.compact")]})]}),e.jsxs("div",{className:"flex flex-wrap items-center gap-2",children:[e.jsx(C,{variant:"outline",children:`${a.length}/${u.length}`}),e.jsx(C,{variant:"outline",children:m("apiKeys.summary.wildcard",{count:T})}),e.jsx(C,{variant:"outline",children:m("apiKeys.summary.restricted",{count:E})})]})]}),children:e.jsxs("div",{className:"space-y-4",children:[e.jsxs("div",{className:"grid gap-4 md:grid-cols-3",children:[e.jsx(re,{label:m("apiKeys.list.title"),value:`${a.length}/${u.length}`,helper:m("apiKeys.filters.searchPlaceholder")}),e.jsx(re,{label:m("apiKeys.summary.wildcard",{count:T}),value:String(T),helper:m("apiKeys.wildcardHint")}),e.jsx(re,{label:m("apiKeys.summary.restricted",{count:E}),value:String(E),helper:m("apiKeys.summary.unrestricted",{count:v})})]}),e.jsxs("div",{className:"grid gap-3 rounded-xl bg-secondary p-4 lg:grid-cols-[minmax(0,0.82fr)_auto] xl:grid-cols-[minmax(0,0.95fr)_auto_auto]",children:[e.jsx(J,{value:K,onChange:j=>p(j.target.value),placeholder:m("apiKeys.filters.searchPlaceholder"),className:"lg:max-w-[680px]"}),e.jsx("div",{className:"flex min-w-max items-center gap-1 overflow-x-auto rounded-full bg-background p-1 lg:justify-self-start xl:justify-self-center",children:["all","enabled","disabled"].map(j=>e.jsx("button",{type:"button",onClick:()=>r(j),className:_("inline-flex h-8 shrink-0 items-center rounded-full px-3.5 text-xs font-medium transition-all",q===j?"bg-primary text-primary-foreground":"text-muted-foreground hover:bg-primary/5 hover:text-foreground"),children:m(`apiKeys.filters.${j}`)},j))}),e.jsxs("div",{className:"flex flex-wrap items-center gap-2 lg:col-span-2 xl:col-span-1 xl:justify-self-end",children:[e.jsx(C,{variant:"secondary",children:m("apiKeys.summary.wildcard",{count:T})}),e.jsx(C,{variant:"secondary",children:m("apiKeys.summary.restricted",{count:E})})]})]}),u.length===0?e.jsx(oe,{compact:!0,tone:"primary",className:"rounded-[1.2rem] border-border/30 bg-background/50",icon:e.jsx(Te,{className:"h-5 w-5","aria-hidden":"true"}),title:m("apiKeys.list.emptyTitle"),description:m("apiKeys.list.empty"),action:e.jsx(h,{size:"sm",onClick:Y,children:m("apiKeys.createNew")})}):a.length===0?e.jsx(oe,{compact:!0,tone:"primary",className:"rounded-[1.2rem] border-border/30 bg-background/50",icon:e.jsx(Ee,{className:"h-5 w-5","aria-hidden":"true"}),title:m("apiKeys.list.emptyFilteredTitle"),description:m("apiKeys.list.emptyFiltered"),action:e.jsx(h,{variant:"outline",size:"sm",onClick:()=>{p(""),r("all")},children:m("common.actions.reset")})}):R==="compact"?e.jsx(Ms,{filteredKeys:a,formatDate:s,isDeleting:t,isRevealing:o,onCopy:b,onDelete:f,onEditEndpoints:c,onHide:g,onReveal:n,onToggleEnabled:y,revealedKeys:k}):e.jsx("div",{className:"grid gap-4",children:a.map(j=>e.jsx(qs,{formatDate:s,isDeleting:t===j.id,isRevealing:o===j.id,keySummary:j,onCopy:b,onDelete:f,onEditEndpoints:c,onHide:g,onReveal:n,onToggleEnabled:y,revealedValue:k.get(j.id)},j.id))})]})})}function Ms({filteredKeys:a,formatDate:s,isDeleting:l,isRevealing:t,onCopy:o,onDelete:u,onEditEndpoints:b,onHide:f,onReveal:c,onToggleEnabled:p,revealedKeys:g}){const{t:n}=w();return e.jsx(X,{className:"overflow-hidden border border-border/65 bg-card/96 shadow-[0_18px_42px_rgba(15,23,42,0.06)] ring-1 ring-white/70",children:e.jsx("div",{className:"overflow-x-auto",children:e.jsxs(bs,{className:"min-w-[980px]",children:[e.jsx(js,{children:e.jsxs(ke,{className:"bg-secondary/45 hover:bg-secondary/45",children:[e.jsx(L,{children:n("apiKeys.table.name")}),e.jsx(L,{children:n("apiKeys.table.access")}),e.jsx(L,{className:"text-right",children:n("apiKeys.requestCount")}),e.jsx(L,{className:"text-right",children:n("apiKeys.totalTokens")}),e.jsx(L,{className:"text-right",children:n("apiKeys.maxConcurrency")}),e.jsx(L,{children:n("apiKeys.lastUsed")}),e.jsx(L,{className:"w-[132px] text-right",children:n("apiKeys.table.actions")})]})}),e.jsx(fs,{children:a.map(r=>{var K,q,v;const y=g.get(r.id),E=(r.totalInputTokens+r.totalOutputTokens).toLocaleString(),k=r.isWildcard?n("apiKeys.wildcard"):(((K=r.allowedEndpoints)==null?void 0:K.length)??0)>0?(q=r.allowedEndpoints)==null?void 0:q.join(", "):n("apiKeys.allEndpoints");return e.jsxs(ke,{children:[e.jsx(F,{className:"py-3",children:e.jsxs("div",{className:"min-w-0 space-y-1",children:[e.jsxs("div",{className:"flex flex-wrap items-center gap-2",children:[e.jsx("span",{className:"font-semibold text-foreground",children:r.name}),r.isWildcard?e.jsx(C,{variant:"secondary",className:"text-[11px]",children:n("apiKeys.wildcard")}):null,e.jsx(C,{variant:r.enabled?"default":"outline",className:"text-[11px]",children:r.enabled?n("apiKeys.status.enabled"):n("apiKeys.status.disabled")})]}),r.isWildcard?null:e.jsxs("div",{className:"flex min-w-0 items-center gap-1.5",children:[e.jsx("code",{className:"max-w-[220px] truncate rounded-md bg-secondary px-2 py-1 font-mono text-xs",children:y??r.maskedKey??"********"}),y?e.jsxs(e.Fragment,{children:[e.jsx(h,{variant:"ghost",size:"icon",className:"h-7 w-7",onClick:()=>o(y),"aria-label":n("common.actions.copy"),children:e.jsx(ce,{className:"h-3.5 w-3.5","aria-hidden":"true"})}),e.jsx(h,{variant:"ghost",size:"icon",className:"h-7 w-7",onClick:()=>f(r.id),"aria-label":n("apiKeys.actions.hide"),children:e.jsx(de,{className:"h-3.5 w-3.5","aria-hidden":"true"})})]}):e.jsx(h,{variant:"ghost",size:"icon",className:"h-7 w-7",onClick:()=>c(r.id),disabled:t===r.id,"aria-label":n("apiKeys.actions.reveal"),children:t===r.id?e.jsx("div",{className:"h-3.5 w-3.5 animate-spin rounded-full border-2 border-primary border-t-transparent"}):e.jsx(Ae,{className:"h-3.5 w-3.5","aria-hidden":"true"})})]})]})}),e.jsx(F,{className:"py-3",children:e.jsxs("div",{className:"max-w-[180px]",children:[e.jsx("div",{className:"truncate text-sm text-foreground",title:k,children:k}),e.jsx("div",{className:"mt-1 text-xs text-muted-foreground",children:r.isWildcard?n("apiKeys.table.accessWildcard"):(((v=r.allowedEndpoints)==null?void 0:v.length)??0)>0?n("apiKeys.endpointRestricted"):n("apiKeys.table.accessOpen")})]})}),e.jsx(F,{className:"py-3 text-right font-medium",children:r.requestCount.toLocaleString()}),e.jsx(F,{className:"py-3 text-right font-medium",children:E}),e.jsx(F,{className:"py-3 text-right font-medium",children:r.maxConcurrency?String(r.maxConcurrency):"—"}),e.jsxs(F,{className:"py-3",children:[e.jsx("div",{className:"text-sm font-medium text-foreground",children:s(r.lastUsedAt)}),e.jsx("div",{className:"mt-1 text-xs text-muted-foreground",children:s(r.createdAt)})]}),e.jsx(F,{className:"py-3",children:e.jsxs("div",{className:"flex justify-end gap-1",children:[e.jsx(h,{variant:"outline",size:"icon",onClick:()=>b(r),className:"h-8 w-8","aria-label":r.isWildcard?n("apiKeys.maxConcurrency"):n("apiKeys.editEndpoints"),title:r.isWildcard?n("apiKeys.maxConcurrency"):n("apiKeys.editEndpoints"),children:e.jsx(S,{className:"h-3.5 w-3.5","aria-hidden":"true"})}),e.jsx(h,{variant:r.enabled?"outline":"default",size:"sm",onClick:()=>p(r.id,r.enabled),className:"h-8 px-2.5 text-xs",children:r.enabled?n("apiKeys.actions.disable"):n("apiKeys.actions.enable")}),r.isWildcard?null:e.jsx(h,{variant:"ghost",size:"icon",className:"h-8 w-8 text-destructive hover:bg-destructive/10 hover:text-destructive",onClick:()=>u(r),disabled:l===r.id,"aria-label":n("apiKeys.actions.delete"),children:e.jsx(Me,{className:"h-3.5 w-3.5","aria-hidden":"true"})})]})})]},r.id)})})]})})})}function ie({description:a,icon:s,title:l}){return e.jsxs("div",{className:"w-[220px] shrink-0 rounded-[1rem] border border-border/45 bg-secondary/72 p-3 shadow-[inset_0_1px_0_rgba(255,255,255,0.6)] dark:border-white/10 dark:bg-slate-900/[0.52] dark:shadow-[inset_0_1px_0_rgba(255,255,255,0.04)] md:w-auto",children:[e.jsx("div",{className:"flex h-7 w-7 items-center justify-center rounded-[0.8rem] bg-background/85 text-primary dark:bg-slate-950/[0.62] sm:h-8 sm:w-8 sm:rounded-[0.85rem]",children:s}),e.jsx("p",{className:"mt-2 text-[12px] font-semibold leading-5 text-foreground sm:mt-2.5 sm:text-[13px]",children:l}),e.jsx("p",{className:"mt-1 line-clamp-2 text-[11px] leading-4.5 text-muted-foreground sm:text-xs sm:leading-5",children:a})]})}function qs({formatDate:a,isDeleting:s,isRevealing:l,keySummary:t,onCopy:o,onDelete:u,onEditEndpoints:b,onHide:f,onReveal:c,onToggleEnabled:p,revealedValue:g}){var y,E,k;const{t:n}=w(),r=(t.totalInputTokens+t.totalOutputTokens).toLocaleString();return e.jsx(X,{"data-testid":"api-key-card",className:"overflow-hidden border border-border/65 bg-card/96 shadow-[0_18px_42px_rgba(15,23,42,0.06)] ring-1 ring-white/70",children:e.jsx(ye,{className:"space-y-4 pt-4",children:e.jsxs("div",{className:"flex flex-col gap-4 lg:flex-row lg:items-start lg:justify-between",children:[e.jsxs("div",{className:"min-w-0 space-y-3",children:[e.jsxs("div",{className:"flex flex-wrap items-center gap-2",children:[e.jsx("h3",{className:"text-base font-semibold",children:t.name}),t.isWildcard?e.jsx(C,{variant:"secondary",children:n("apiKeys.wildcard")}):null,e.jsx(C,{variant:t.enabled?"default":"outline",children:t.enabled?n("apiKeys.status.enabled"):n("apiKeys.status.disabled")}),t.isWildcard?null:e.jsx(C,{variant:"outline",className:"text-xs",children:(((y=t.allowedEndpoints)==null?void 0:y.length)??0)>0?n("apiKeys.endpointRestricted"):n("apiKeys.allEndpoints")}),!t.isWildcard&&t.allowedEndpoints&&t.allowedEndpoints.length>0?t.allowedEndpoints.map(K=>e.jsx(C,{variant:"outline",className:"text-xs",children:K},K)):t.isWildcard?null:e.jsx(C,{variant:"secondary",className:"text-xs opacity-60",children:n("apiKeys.allEndpoints")})]}),e.jsxs("div",{className:"grid gap-2 sm:grid-cols-3",children:[e.jsx(le,{label:n("apiKeys.requestCount"),value:t.requestCount.toLocaleString()}),e.jsx(le,{label:n("apiKeys.totalTokens"),value:r}),e.jsx(le,{label:n("apiKeys.maxConcurrency"),value:t.maxConcurrency?String(t.maxConcurrency):n("apiKeys.maxConcurrencyPlaceholder")})]}),e.jsxs("div",{className:"flex flex-col gap-2 sm:flex-row sm:items-center",children:[e.jsx("code",{className:"block max-w-full break-all rounded-lg bg-secondary px-3 py-1.5 font-mono text-sm",children:t.isWildcard?n("apiKeys.wildcard"):g??t.maskedKey??"********"}),t.isWildcard?null:e.jsx("div",{className:"flex items-center gap-1 self-start",children:g?e.jsxs(e.Fragment,{children:[e.jsx(h,{variant:"ghost",size:"icon",className:"h-8 w-8",onClick:()=>o(g),"aria-label":n("common.actions.copy"),title:n("common.actions.copy"),children:e.jsx(ce,{className:"h-4 w-4","aria-hidden":"true"})}),e.jsx(h,{variant:"ghost",size:"icon",className:"h-8 w-8",onClick:()=>f(t.id),"aria-label":n("apiKeys.actions.hide"),title:n("apiKeys.actions.hide"),children:e.jsx(de,{className:"h-4 w-4","aria-hidden":"true"})})]}):e.jsx(h,{variant:"ghost",size:"icon",className:"h-8 w-8",onClick:()=>c(t.id),disabled:l,"aria-label":n("apiKeys.actions.reveal"),title:n("apiKeys.actions.reveal"),children:l?e.jsx("div",{className:"h-4 w-4 animate-spin rounded-full border-2 border-primary border-t-transparent"}):e.jsx(Ae,{className:"h-4 w-4","aria-hidden":"true"})})})]}),t.isWildcard?e.jsx("p",{className:"text-sm text-muted-foreground",children:n("apiKeys.wildcardHint")}):t.description?e.jsx("p",{className:"whitespace-pre-wrap text-sm text-muted-foreground",children:t.description}):null,t.isWildcard?null:e.jsx("div",{className:"rounded-lg bg-secondary px-3 py-2 text-xs text-muted-foreground",children:(((E=t.allowedEndpoints)==null?void 0:E.length)??0)>0?`${n("apiKeys.allowedEndpoints")}: ${(k=t.allowedEndpoints)==null?void 0:k.join(", ")}`:n("apiKeys.allEndpoints")}),e.jsxs("div",{className:"grid gap-3 text-sm sm:grid-cols-2",children:[e.jsxs("div",{className:"space-y-1",children:[e.jsx("span",{className:"text-xs font-medium uppercase tracking-wide text-muted-foreground",children:n("apiKeys.created")}),e.jsx("p",{className:"font-medium",children:a(t.createdAt)})]}),e.jsxs("div",{className:"space-y-1",children:[e.jsx("span",{className:"text-xs font-medium uppercase tracking-wide text-muted-foreground",children:n("apiKeys.lastUsed")}),e.jsx("p",{className:"font-medium",children:a(t.lastUsedAt)})]})]})]}),e.jsxs("div",{className:"grid gap-2 sm:grid-cols-2 lg:flex lg:flex-wrap lg:justify-end",children:[e.jsxs(h,{variant:"outline",size:"sm",onClick:()=>b(t),className:"w-full lg:w-auto",children:[e.jsx(S,{className:"mr-1 h-3.5 w-3.5","aria-hidden":"true"}),t.isWildcard?n("apiKeys.maxConcurrency"):n("apiKeys.editEndpoints")]}),e.jsx(h,{variant:t.enabled?"outline":"default",size:"sm",onClick:()=>p(t.id,t.enabled),className:"w-full lg:w-auto",children:t.enabled?n("apiKeys.actions.disable"):n("apiKeys.actions.enable")}),t.isWildcard?null:e.jsx(h,{variant:"ghost",size:"icon",className:"h-9 w-full text-destructive hover:bg-destructive/10 hover:text-destructive sm:w-9",onClick:()=>u(t),disabled:s,"aria-label":n("apiKeys.actions.delete"),children:e.jsx(Me,{className:"h-4 w-4","aria-hidden":"true"})})]})]})})})}function ne({label:a,value:s}){return e.jsx(X,{className:"border border-border/70 bg-secondary/70 shadow-none ring-1 ring-white/70",children:e.jsxs(ye,{className:"pt-4",children:[e.jsx("p",{className:"text-xs font-medium uppercase tracking-wider text-muted-foreground",children:a}),e.jsx("p",{className:"metric-number mt-2 text-3xl font-semibold text-foreground",children:s})]})})}function re({helper:a,label:s,value:l}){return e.jsxs("div",{className:"rounded-xl bg-card px-4 py-3 shadow-[var(--surface-shadow)]",children:[e.jsx("p",{className:"text-[11px] font-medium uppercase tracking-wider text-muted-foreground",children:s}),e.jsx("p",{className:"metric-number mt-2 text-xl font-semibold text-foreground",children:l}),e.jsx("p",{className:"mt-1 text-xs text-muted-foreground",children:a})]})}function le({label:a,value:s}){return e.jsxs("div",{className:"rounded-lg bg-secondary px-3 py-2",children:[e.jsx("p",{className:"text-[11px] font-medium uppercase tracking-wider text-muted-foreground",children:a}),e.jsx("p",{className:"mt-1 truncate text-sm font-medium",children:s})]})}function De({empty:a,emptyText:s,loading:l,option:t,title:o}){const{t:u}=w();return e.jsx(X,{children:e.jsxs(ye,{className:"space-y-4 pt-4",children:[e.jsx("h3",{className:"text-base font-semibold",children:o}),l?e.jsx("div",{className:"flex h-[280px] items-center justify-center",children:e.jsx("span",{className:"text-sm text-muted-foreground",children:u("common.loadingShort")})}):a?e.jsx(oe,{compact:!0,className:"min-h-[280px] rounded-[1.1rem] border-border/30 bg-background/50",icon:e.jsx(S,{className:"h-5 w-5","aria-hidden":"true"}),title:s,description:u("apiKeys.analytics.emptyHint"),action:e.jsx(h,{asChild:!0,variant:"ghost",size:"sm",children:e.jsx(gs,{to:"/logs",children:u("apiKeys.analytics.actions.logs")})})}):e.jsx(ys,{echarts:vs,option:t,style:{height:280},notMerge:!0,lazyUpdate:!0})]})})}function Ws(){const{t:a}=w(),{pushToast:s}=xs(),[l,t]=x.useState(!1),[o,u]=x.useState(""),[b,f]=x.useState(""),[c,p]=x.useState([]),[g,n]=x.useState(""),[r,y]=x.useState(null),[E,k]=x.useState(null),[K,q]=x.useState(null),[v,R]=Q(U.apiKeys.rangeDays,7,{serialize:i=>String(i),deserialize:i=>{const d=Number(i);return Fe.some(D=>D.value===d)?d:7}}),[T,z]=x.useState(new Map),[Y,m]=x.useState(null),[j,Z]=x.useState(null),[I,be]=x.useState([]),[H,je]=x.useState(""),[ee,Re]=Q(U.apiKeys.search,""),[V,ze]=Q(U.apiKeys.statusFilter,"all",{serialize:i=>i,deserialize:i=>i==="enabled"||i==="disabled"?i:"all"}),[Pe,_e]=Q(U.apiKeys.viewMode,"compact",{serialize:i=>i,deserialize:i=>i==="cards"?"cards":"compact"}),Ie=Ns(),fe=G(N.apiKeys.all(),M.listRequest()),He=G(N.apiKeys.overview(v),M.overviewRequest(v)),ve=G(N.apiKeys.usage(v),M.usageRequest(v)),Ke=B({mutationFn:M.create,invalidateKeys:[N.apiKeys.all(),N.apiKeys.overview(v),N.apiKeys.usage(v)],successToast:()=>({title:a("apiKeys.toast.keyCreated")}),errorToast:i=>({title:a("apiKeys.toast.createFailure",{message:i.message})})}),$=B({mutationFn:({id:i,...d})=>M.update(i,d),invalidateKeys:[N.apiKeys.all(),N.apiKeys.overview(v),N.apiKeys.usage(v)],successToast:()=>({title:a("apiKeys.toast.keyUpdated")}),errorToast:i=>({title:a("apiKeys.toast.updateFailure",{message:i.message})})}),Ne=B({mutationFn:({id:i})=>M.delete(i),invalidateKeys:[N.apiKeys.all(),N.apiKeys.overview(v),N.apiKeys.usage(v)],successToast:()=>({title:a("apiKeys.toast.keyDeleted")}),errorToast:i=>({title:a("apiKeys.toast.deleteFailure",{message:i.message})})}),we=B({mutationFn:({id:i})=>M.reveal(i),errorToast:i=>({title:a("apiKeys.toast.revealFailure"),description:i.message})}),W=fe.data??[],O=He.data,A=ve.data??[],Ve=W.some(i=>i.isWildcard),$e=W.filter(i=>i.isWildcard).length,Qe=W.filter(i=>{var d;return!i.isWildcard&&(((d=i.allowedEndpoints)==null?void 0:d.length)??0)>0}).length,Ue=W.filter(i=>{var d;return!i.isWildcard&&(((d=i.allowedEndpoints)==null?void 0:d.length)??0)===0}).length,Be=O?O.totalKeys.toLocaleString():"-",Ge=O?O.enabledKeys.toLocaleString():"-",Je=O?O.activeKeys.toLocaleString():"-",Se=x.useMemo(()=>W.filter(i=>{if(!(V==="all"||(V==="enabled"?i.enabled:!i.enabled)))return!1;const D=ee.trim().toLowerCase();return D?[i.name,i.description??"",i.maskedKey??"",...i.allowedEndpoints??[]].join(" ").toLowerCase().includes(D):!0}),[W,ee,V]),Xe=x.useMemo(()=>{const i=A.map(d=>d.apiKeyName??a("apiKeys.analytics.unknownKey"));return{tooltip:{trigger:"axis"},grid:{left:60,right:20,top:40,bottom:40},xAxis:{type:"category",data:i,axisLabel:{interval:0,rotate:20}},yAxis:{type:"value"},series:[{name:a("apiKeys.analytics.requestsSeries"),type:"bar",data:A.map(d=>d.requests),itemStyle:{color:"hsl(var(--primary))"}}]}},[a,A]),Ye=x.useMemo(()=>{const i=A.map(d=>d.apiKeyName??a("apiKeys.analytics.unknownKey"));return{tooltip:{trigger:"axis"},legend:{data:[a("apiKeys.analytics.tokens.input"),a("apiKeys.analytics.tokens.output")]},grid:{left:60,right:20,top:50,bottom:40},xAxis:{type:"category",data:i,axisLabel:{interval:0,rotate:20}},yAxis:{type:"value"},series:[{name:a("apiKeys.analytics.tokens.input"),type:"bar",stack:"tokens",itemStyle:{color:"#22c55e"},data:A.map(d=>d.inputTokens)},{name:a("apiKeys.analytics.tokens.output"),type:"bar",stack:"tokens",itemStyle:{color:"#0ea5e9"},data:A.map(d=>d.outputTokens)}]}},[a,A]),Ce=x.useCallback(()=>{u(""),f(""),p([]),n("")},[]),se=x.useCallback(i=>{t(i),i||Ce()},[Ce]),Ze=x.useCallback(async()=>{if(!o.trim()){s({title:a("apiKeys.errors.nameRequired"),variant:"error"});return}try{const i=await Ke.mutateAsync({name:o.trim(),description:b.trim()||void 0,allowedEndpoints:c.length>0?c:void 0,maxConcurrency:g?Number(g):null});y(i),se(!1)}catch{}},[Ke,se,b,c,g,o,s,a]),es=x.useCallback(async(i,d)=>{try{await $.mutateAsync({id:i,enabled:!d})}catch{}},[$]),ss=x.useCallback(async()=>{if(K){k(K.id);try{await Ne.mutateAsync({id:K.id}),q(null)}catch{}finally{k(null)}}},[K,Ne]),as=x.useCallback(async i=>{if(!T.has(i)){m(i);try{const d=await we.mutateAsync({id:i});z(D=>new Map(D).set(i,d.key))}catch{}finally{m(null)}}},[we,T]),ts=x.useCallback(i=>{z(d=>{const D=new Map(d);return D.delete(i),D})},[]),is=x.useCallback(async i=>{try{await Ks(i),s({title:a("apiKeys.toast.keyCopied"),variant:"success"})}catch(d){s({title:a("apiKeys.toast.copyFailure"),description:d instanceof Error?d.message:a("common.unknownError"),variant:"error"})}},[s,a]),ns=x.useCallback(i=>{Z(i),be(i.allowedEndpoints??[]),je(i.maxConcurrency?String(i.maxConcurrency):"")},[]),rs=x.useCallback(async()=>{if(j)try{await $.mutateAsync({id:j.id,...j.isWildcard?{}:{allowedEndpoints:I.length>0?I:null},maxConcurrency:H?Number(H):null}),Z(null)}catch{}},[j,I,H,$]),ls=x.useCallback(i=>i?new Date(i).toLocaleString():a("common.noData"),[a]);return{activeKeysValue:Je,availableEndpoints:Ie,deleteTarget:K,editEndpointsKey:j,editEndpointsSelection:I,editMaxConcurrency:H,enabledKeysValue:Ge,filteredKeys:Se,formatDate:ls,handleCopyKey:is,handleCreateDialogChange:se,handleCreateKey:Ze,handleDeleteKey:ss,handleHideKey:ts,handleOpenEditEndpoints:ns,handleRevealKey:as,handleSaveEndpoints:rs,handleToggleEnabled:es,hasWildcard:Ve,isCreateDialogOpen:l,isDeleting:E,isRevealing:Y,keys:W,keysQuery:fe,newKeyDescription:b,newKeyEndpoints:c,newKeyMaxConcurrency:g,newKeyName:o,newlyCreatedKey:r,rangeDays:v,requestsChartOption:Xe,restrictedCount:Qe,revealedKeys:T,search:ee,setDeleteTarget:q,setEditEndpointsKey:Z,setEditEndpointsSelection:be,setEditMaxConcurrency:je,setNewKeyDescription:f,setNewKeyEndpoints:p,setNewKeyMaxConcurrency:n,setNewKeyName:u,setNewlyCreatedKey:y,setRangeDays:R,setSearch:Re,setStatusFilter:ze,statusFilter:V,tokensChartOption:Ye,totalKeysValue:Be,unrestrictedCount:Ue,usage:A,usageQuery:ve,viewMode:Pe,wildcardCount:$e,setViewMode:_e}}function ta(){const{t:a}=w(),s=Ws(),l=a("apiKeys.summary.totalCount",{count:s.keys.length});return s.keysQuery.isLoading?e.jsx(us,{}):e.jsxs("div",{className:"flex flex-col gap-6",children:[e.jsx(ms,{info:l?e.jsx("span",{className:"rounded-full bg-secondary px-2.5 py-1 text-xs text-muted-foreground",children:l}):null,status:e.jsxs("span",{className:"text-xs text-muted-foreground",children:[a("apiKeys.summary.wildcard",{count:s.wildcardCount})," / ",a("apiKeys.summary.restricted",{count:s.restrictedCount})," / ",a("apiKeys.summary.unrestricted",{count:s.unrestrictedCount})]}),actions:e.jsxs(h,{size:"sm",onClick:()=>s.handleCreateDialogChange(!0),children:[e.jsx(ds,{className:"mr-2 h-4 w-4","aria-hidden":"true"}),a("apiKeys.createNew")]})}),e.jsx(Ds,{}),e.jsx(Ts,{activeKeysValue:s.activeKeysValue,enabledKeysValue:s.enabledKeysValue,loading:s.usageQuery.isLoading,onRangeChange:s.setRangeDays,rangeDays:s.rangeDays,requestsChartOption:s.requestsChartOption,totalKeysValue:s.totalKeysValue,tokensChartOption:s.tokensChartOption,usageLength:s.usage.length}),e.jsx(As,{filteredKeys:s.filteredKeys,formatDate:s.formatDate,hasWildcard:s.hasWildcard,isDeleting:s.isDeleting,isRevealing:s.isRevealing,keys:s.keys,onCopy:t=>void s.handleCopyKey(t),onDelete:s.setDeleteTarget,onEditEndpoints:s.handleOpenEditEndpoints,onFilterChange:s.setSearch,onHide:s.handleHideKey,onReveal:t=>void s.handleRevealKey(t),onStatusFilterChange:s.setStatusFilter,onToggleEnabled:(t,o)=>void s.handleToggleEnabled(t,o),restrictedCount:s.restrictedCount,revealedKeys:s.revealedKeys,search:s.search,statusFilter:s.statusFilter,unrestrictedCount:s.unrestrictedCount,viewMode:s.viewMode,wildcardCount:s.wildcardCount,onViewModeChange:s.setViewMode,onCreateKey:()=>s.handleCreateDialogChange(!0)}),e.jsx(ws,{availableEndpoints:s.availableEndpoints,isOpen:s.isCreateDialogOpen,keyDescription:s.newKeyDescription,keyName:s.newKeyName,maxConcurrency:s.newKeyMaxConcurrency,onDescriptionChange:s.setNewKeyDescription,onEndpointsChange:s.setNewKeyEndpoints,onKeyNameChange:s.setNewKeyName,onMaxConcurrencyChange:s.setNewKeyMaxConcurrency,onOpenChange:s.handleCreateDialogChange,onSubmit:()=>void s.handleCreateKey(),selectedEndpoints:s.newKeyEndpoints}),e.jsx(Cs,{createdKey:s.newlyCreatedKey,onClose:()=>s.setNewlyCreatedKey(null),onCopy:t=>void s.handleCopyKey(t)}),e.jsx(Es,{apiKey:s.editEndpointsKey,availableEndpoints:s.availableEndpoints,maxConcurrency:s.editMaxConcurrency,onClose:()=>s.setEditEndpointsKey(null),onEndpointsChange:s.setEditEndpointsSelection,onMaxConcurrencyChange:s.setEditMaxConcurrency,onSave:()=>void s.handleSaveEndpoints(),selectedEndpoints:s.editEndpointsSelection}),e.jsx(ks,{deleteTarget:s.deleteTarget,isDeleting:s.isDeleting,onConfirm:()=>void s.handleDeleteKey(),onOpenChange:t=>{!t&&s.isDeleting===null&&s.setDeleteTarget(null)}})]})}export{ta as default};
@@ -1 +1 @@
1
- import{j as s}from"./vendor-DdPBfMMb.js";import{D as m,A as p,a as j,b as u,c as D,d as f,e as g}from"./DialogShell-BWia_d99.js";import{B as o}from"./app-DkubSF6m.js";function C({open:r,onOpenChange:a,title:t,description:i,confirmLabel:n,cancelLabel:d,onConfirm:c,loading:e=!1,confirmVariant:x="destructive",children:l}){return s.jsx(m,{open:r,onOpenChange:a,children:s.jsxs(p,{className:"max-w-md",children:[s.jsxs(j,{children:[s.jsx(u,{children:t}),i?s.jsx(D,{children:i}):null]}),s.jsx(f,{className:"space-y-4",children:l?s.jsx("div",{className:"text-sm text-muted-foreground",children:l}):null}),s.jsxs(g,{children:[s.jsx(o,{variant:"outline",onClick:()=>a(!1),disabled:e,children:d}),s.jsx(o,{variant:x,onClick:()=>void c(),disabled:e,children:n})]})]})})}export{C};
1
+ import{j as s}from"./vendor-DdPBfMMb.js";import{D as m,A as p,a as j,b as u,c as D,d as f,e as g}from"./DialogShell-BTPrPt5l.js";import{B as o}from"./app-BBdow7GJ.js";function C({open:r,onOpenChange:a,title:t,description:i,confirmLabel:n,cancelLabel:d,onConfirm:c,loading:e=!1,confirmVariant:x="destructive",children:l}){return s.jsx(m,{open:r,onOpenChange:a,children:s.jsxs(p,{className:"max-w-md",children:[s.jsxs(j,{children:[s.jsx(u,{children:t}),i?s.jsx(D,{children:i}):null]}),s.jsx(f,{className:"space-y-4",children:l?s.jsx("div",{className:"text-sm text-muted-foreground",children:l}):null}),s.jsxs(g,{children:[s.jsx(o,{variant:"outline",onClick:()=>a(!1),disabled:e,children:d}),s.jsx(o,{variant:x,onClick:()=>void c(),disabled:e,children:n})]})]})})}export{C};
@@ -1 +1 @@
1
- import{j as e,ap as Ce,af as Re,W as Q,ak as _e,aq as Pe,ar as qe,O as H,as as Me,at as Ae,au as Be,av as ne,aw as De,r as u,ax as Fe,U as Oe}from"./vendor-DdPBfMMb.js";import{P as $e}from"./PageToolbar-BxRZF-QJ.js";import{P as V,a as G}from"./PageState-Dvjip2P-.js";import{B as D,u as Ge,a as ze,b as Qe,t as Ue,s as He}from"./app-DkubSF6m.js";import{S as Ve,a as Ke,b as We,c as Ye,d as q}from"./select-B5oPLG9G.js";import{c as C}from"./global-D8DuA4wF.js";import{L as Ze}from"./router-D2Fb4U0L.js";import{T as ie,a as de,b as F,c as j,d as le,e as y,E as Je}from"./table-BG-JeOj-.js";import{P as ce}from"./PageSection-DVs3faWw.js";import{S as Xe,C as et,T as tt}from"./Skeleton-DHQ8ApGX.js";import{B as k,q as I}from"./queryKeys-BpeJfcg0.js";import{C as O,a as $}from"./card-Bx5Pg_wP.js";import{g as ae}from"./utils-DSaa7c6v.js";import{u as w}from"./i18n-C8tBby0x.js";import{e as st}from"./charts-core-CK8TVJro.js";import{u as L}from"./useApiQuery-4gJC8RZB.js";import"./query-QCek5MsK.js";import"./radix-CtQBp6Ie.js";import"./charts-react-CmmN-08P.js";import"./charts-engine-CWjgwbj5.js";const M=15e3,z=6e4,T={requests:"#2563eb",input:"#059669",output:"#ea580c",cacheRead:"#7c3aed",cacheCreation:"#e11d48",latency:"#0891b2"};function R(s,t,a){return s==null?"-":`${s.toLocaleString(void 0,a)} ${t}`}function U(s){if(s==null)return"-";if(s<1024)return`${s} B`;const t=["KB","MB","GB","TB"];let a=s/1024,r=0;for(;a>=1024&&r<t.length-1;)a/=1024,r+=1;return`${a.toFixed(a>=100?0:a>=10?1:2)} ${t[r]}`}function re(s){if(s==null)return"-";const t=s<1?0:s;return t<1024?`${t.toLocaleString(void 0,{maximumFractionDigits:t>=100?0:t>=10?1:2})} B/s`:`${U(t)}/s`}function at(s){return s==null?"-":`${s.toLocaleString(void 0,{maximumFractionDigits:s>=10?0:1})}%`}function rt(){return e.jsxs("div",{className:"flex flex-col gap-6",children:[e.jsx("div",{className:"h-20 animate-pulse rounded-xl bg-card shadow-[var(--surface-shadow)]"}),e.jsx("div",{className:"grid gap-4 sm:grid-cols-2 lg:grid-cols-3 xl:grid-cols-4",children:Array.from({length:12}).map((s,t)=>e.jsx(Xe,{},t))}),e.jsx("div",{className:"grid gap-6 lg:grid-cols-2",children:Array.from({length:4}).map((s,t)=>e.jsx(et,{},t))}),e.jsx("div",{className:"rounded-xl bg-card shadow-[var(--surface-shadow)]",children:e.jsx("table",{className:"w-full",children:e.jsx("tbody",{children:Array.from({length:5}).map((s,t)=>e.jsx(tt,{columns:6},t))})})})]})}function ot({selectedEndpointLabel:s,status:t,todayRequests:a}){const{t:r}=w();return e.jsxs("div",{className:"flex flex-col gap-4 rounded-xl bg-card p-6 shadow-[var(--surface-shadow)] sm:flex-row sm:items-center sm:justify-between","data-testid":"dashboard-overview-panel",children:[e.jsxs("div",{className:"flex items-center gap-4",children:[e.jsx("div",{className:"flex h-10 w-10 items-center justify-center rounded-lg bg-primary/10",children:e.jsx(Ce,{className:"h-5 w-5 text-primary","aria-hidden":"true"})}),e.jsxs("div",{children:[e.jsxs("div",{className:"flex items-center gap-2",children:[e.jsx("h2",{className:"text-lg font-semibold text-foreground",children:s}),e.jsx(k,{variant:"success",children:r("dashboard.status.listeningLabel")})]}),e.jsxs("p",{className:"mt-0.5 text-sm text-muted-foreground",children:[e.jsxs("span",{"data-testid":"dashboard-runtime-address",children:[(t==null?void 0:t.host)??"0.0.0.0",":",(t==null?void 0:t.port)??"-"]}),e.jsx("span",{className:"mx-2 text-border",children:"·"}),r("dashboard.labels.todayRequests"),": ",a.toLocaleString(),e.jsx("span",{className:"mx-2 text-border",children:"·"}),r("dashboard.labels.providers"),": ",((t==null?void 0:t.providers)??0).toLocaleString()]})]})]}),e.jsxs("div",{className:"flex flex-wrap items-center gap-3 text-sm text-muted-foreground",children:[e.jsxs("span",{children:[r("dashboard.labels.activeClientAddresses"),": ",e.jsx("strong",{className:"text-foreground",children:((t==null?void 0:t.activeClientAddresses)??0).toLocaleString()})]}),e.jsx("span",{className:"text-border",children:"·"}),e.jsxs("span",{children:[r("dashboard.labels.activeClientSessions"),": ",e.jsx("strong",{className:"text-foreground",children:((t==null?void 0:t.activeClientSessions)??0).toLocaleString()})]})]})]})}function nt({dbSizeDisplay:s,memoryDisplay:t,overview:a,status:r}){const{t:o}=w(),c=[{icon:e.jsx(Re,{className:"h-4 w-4"}),label:o("dashboard.labels.activeRequests"),value:((r==null?void 0:r.activeRequests)??0).toLocaleString(),testId:"dashboard-spotlight-value-active"},{icon:e.jsx(Q,{className:"h-4 w-4"}),label:o("dashboard.labels.requestsPerMinute"),value:((r==null?void 0:r.requestsPerMinute)??0).toLocaleString(),testId:"dashboard-spotlight-value-rpm"},{icon:e.jsx(_e,{className:"h-4 w-4"}),label:o("dashboard.labels.outputTokensPerMinute"),value:((r==null?void 0:r.outputTokensPerMinute)??0).toLocaleString(),testId:"dashboard-spotlight-value-tpm"},{icon:e.jsx(Pe,{className:"h-4 w-4"}),label:o("dashboard.labels.cpu"),value:at(r==null?void 0:r.cpuUsagePercent),testId:"dashboard-spotlight-value-cpu"}],l=[{icon:e.jsx(Q,{className:"h-4 w-4"}),label:o("dashboard.cards.todayRequests"),value:((a==null?void 0:a.today.requests)??0).toLocaleString(),suffix:o("common.units.request")},{icon:e.jsx(qe,{className:"h-4 w-4"}),label:o("dashboard.cards.todayInput"),value:((a==null?void 0:a.today.inputTokens)??0).toLocaleString(),suffix:o("common.units.token")},{icon:e.jsx(H,{className:"h-4 w-4"}),label:o("dashboard.cards.todayOutput"),value:((a==null?void 0:a.today.outputTokens)??0).toLocaleString(),suffix:o("common.units.token")},{icon:e.jsx(Me,{className:"h-4 w-4"}),label:o("dashboard.cards.avgLatency"),value:R((a==null?void 0:a.today.avgLatencyMs)??0,o("common.units.ms"))},{icon:e.jsx(Ae,{className:"h-4 w-4"}),label:o("dashboard.labels.networkIngress"),value:re(r==null?void 0:r.networkIngressBytesPerSecond),testId:"dashboard-spotlight-value-ingress"},{icon:e.jsx(Be,{className:"h-4 w-4"}),label:o("dashboard.labels.networkEgress"),value:re(r==null?void 0:r.networkEgressBytesPerSecond),testId:"dashboard-spotlight-value-egress"},{icon:e.jsx(ne,{className:"h-4 w-4"}),label:o("dashboard.labels.database"),value:s,testId:"dashboard-spotlight-value-database"},{icon:e.jsx(De,{className:"h-4 w-4"}),label:o("dashboard.labels.memory"),value:t,testId:"dashboard-spotlight-value-memory"}];return e.jsxs("div",{className:"space-y-3","data-testid":"dashboard-spotlight-grid",children:[e.jsx("div",{className:"grid gap-3 md:grid-cols-2 xl:grid-cols-5",children:c.map((n,i)=>e.jsx(oe,{className:i===0?"md:col-span-2 xl:col-span-2":void 0,featured:i===0,icon:n.icon,label:n.label,value:n.value,valueTestId:n.testId},n.label))}),e.jsx("div",{className:"grid gap-2.5 sm:grid-cols-2 lg:grid-cols-4",children:l.map(n=>e.jsx(oe,{compact:!0,icon:n.icon,label:n.label,suffix:n.suffix,value:n.value,valueTestId:n.testId},n.label))})]})}function it({busiestDay:s,fastestTtftModel:t,topModel:a,totalRequestsInRange:r}){const{t:o}=w();return e.jsxs("div",{className:"grid gap-3 lg:grid-cols-[1.4fr_repeat(3,minmax(0,1fr))]",children:[e.jsx(A,{featured:!0,label:o("dashboard.insights.totalRequests"),value:r.toLocaleString(),hint:o("dashboard.insights.totalRequestsHint")}),e.jsx(A,{label:o("dashboard.insights.busiestDay"),value:s?s.date:"-",hint:s?o("dashboard.insights.busiestDayHint",{value:s.requestCount.toLocaleString()}):o("common.noData")}),e.jsx(A,{label:o("dashboard.insights.topModel"),value:a?`${a.provider}/${a.model}`:"-",hint:a?o("dashboard.insights.topModelHint",{value:a.requests.toLocaleString()}):o("common.noData")}),e.jsx(A,{label:o("dashboard.insights.fastestTtft"),value:t?`${t.provider}/${t.model}`:"-",hint:t?R(t.avgTtftMs,o("common.units.ms")):o("common.noData")})]})}function dt({endpointCount:s,providerCount:t,selectedEndpointLabel:a}){const r=[{title:"先配置 Provider",description:t>0?`当前已检测到 ${t} 个 Provider,可直接继续下一步。`:"先在模型供应商里接入至少 1 个上游模型服务。",href:"/models",cta:"去模型供应商",tone:"from-indigo-100 to-cyan-100"},{title:"确认默认路由入口",description:s>0?`当前已有 ${s} 个自定义端点,可继续检查默认映射是否合理。`:"把一个端点或默认路由配置清楚,后续客户端就能稳定接入。",href:"/routing",cta:"去路由管理",tone:"from-violet-100 to-fuchsia-100"},{title:"发起第一条真实请求",description:"创建 API Key,然后从常用客户端打进来一条请求,让日志、路由和延迟开始有数据。",href:"/api-keys",cta:"去 API 密钥",tone:"from-emerald-100 to-cyan-100"}];return e.jsxs("div",{className:"grid gap-4 xl:grid-cols-[minmax(0,1.2fr)_minmax(300px,0.8fr)]",children:[e.jsx(O,{className:"overflow-hidden border-white/80 bg-[linear-gradient(135deg,rgba(255,255,255,0.98),hsl(var(--primary)/0.08),rgba(236,253,245,0.8))] shadow-[0_22px_56px_-40px_rgba(15,23,42,0.24)]",children:e.jsxs($,{className:"space-y-5 pt-5",children:[e.jsxs("div",{className:"space-y-2",children:[e.jsx("div",{className:"inline-flex items-center rounded-full bg-primary/10 px-3 py-1 text-[11px] font-semibold uppercase tracking-[0.16em] text-primary",children:"Cold Start Guide"}),e.jsxs("div",{children:[e.jsx("h3",{className:"text-lg font-semibold text-foreground",children:"当前还是冷启动状态,这是正常的"}),e.jsx("p",{className:"mt-1.5 text-sm leading-6 text-muted-foreground",children:"这个仪表盘会在第一条真实请求进来后明显更有价值。现在最适合做的是把 Provider、路由和 API Key 三件事顺次走通。"})]})]}),e.jsx("div",{className:"grid gap-3 lg:grid-cols-3",children:r.map((o,c)=>e.jsxs("div",{className:"rounded-[1.1rem] border border-white/70 bg-card/88 p-4 shadow-[0_16px_40px_-34px_rgba(15,23,42,0.18)]",children:[e.jsxs("div",{className:C("flex h-10 w-10 items-center justify-center rounded-2xl bg-gradient-to-br text-sm font-semibold text-primary",o.tone),children:["0",c+1]}),e.jsx("h4",{className:"mt-3 text-sm font-semibold text-foreground",children:o.title}),e.jsx("p",{className:"mt-1.5 text-xs leading-6 text-muted-foreground",children:o.description}),e.jsx(D,{asChild:!0,variant:"ghost",size:"sm",className:"mt-3 h-8 rounded-full px-0 text-primary hover:bg-transparent hover:text-primary/80",children:e.jsx(Ze,{to:o.href,children:o.cta})})]},o.title))})]})}),e.jsx(O,{className:"border-white/80 bg-card/96 shadow-[0_20px_48px_-40px_rgba(15,23,42,0.24)]",children:e.jsxs($,{className:"space-y-4 pt-5",children:[e.jsxs("div",{children:[e.jsx("p",{className:"text-[11px] font-semibold uppercase tracking-[0.16em] text-muted-foreground/80",children:"Workspace Snapshot"}),e.jsx("h3",{className:"mt-2 text-base font-semibold text-foreground",children:a}),e.jsx("p",{className:"mt-1 text-xs leading-6 text-muted-foreground",children:"等第一批流量进来后,这里会逐步展示趋势、模型表现和最近请求。"})]}),e.jsx("div",{className:"grid gap-3 sm:grid-cols-3 xl:grid-cols-1",children:[{label:"已配置 Provider",value:String(t)},{label:"自定义端点",value:String(s)},{label:"建议下一步",value:"发起请求"}].map(o=>e.jsxs("div",{className:"rounded-[1rem] bg-secondary/45 px-4 py-3 ring-1 ring-white/70",children:[e.jsx("div",{className:"text-[11px] font-medium text-muted-foreground",children:o.label}),e.jsx("div",{className:"mt-1 text-lg font-semibold text-foreground",children:o.value})]},o.label))}),e.jsx("div",{className:"rounded-[1rem] border border-dashed border-border/45 bg-secondary/35 px-4 py-3",children:e.jsxs("p",{className:"text-xs leading-6 text-muted-foreground",children:["如果你还没确定从哪一步开始,优先去 ",e.jsx("span",{className:"font-medium text-foreground",children:"API 密钥"})," 创建一个客户端专用 key,再从常用工具发起一条最小请求。"]})})]})})]})}function lt({dailyEmpty:s,dailyOption:t,dailyPending:a,models:r,modelRequestsOption:o,modelUsagePending:c,ttftOption:l,tpotOption:n}){const{t:i}=w();return e.jsxs(e.Fragment,{children:[e.jsxs("div",{className:"grid gap-6 lg:grid-cols-2",children:[e.jsx(B,{title:i("dashboard.charts.requestsTitle"),description:i("dashboard.charts.requestsDesc"),loading:a,option:t,empty:s,emptyText:i("dashboard.charts.empty")}),e.jsx(B,{title:i("dashboard.charts.modelTitle"),description:i("dashboard.charts.modelDesc"),loading:c,option:o,empty:!r.length,emptyText:i("dashboard.charts.empty")})]}),e.jsxs("div",{className:"grid gap-6 lg:grid-cols-2",children:[e.jsx(B,{title:i("dashboard.charts.ttftTitle"),description:i("dashboard.charts.ttftDesc"),loading:c,option:l,empty:!r.some(m=>m.avgTtftMs!=null&&m.avgTtftMs>0),emptyText:i("dashboard.charts.ttftEmpty")}),e.jsx(B,{title:i("dashboard.charts.tpotTitle"),description:i("dashboard.charts.tpotDesc"),loading:c,option:n,empty:!r.some(m=>m.avgTpotMs!=null&&m.avgTpotMs>0),emptyText:i("dashboard.charts.tpotEmpty")})]})]})}function ct({models:s,loading:t}){const{t:a}=w();return e.jsx(ce,{title:a("dashboard.modelTable.title"),description:a("dashboard.modelTable.description"),children:t?e.jsx(V,{compact:!0,label:a("common.loadingShort")}):s.length===0?e.jsx(G,{compact:!0,icon:e.jsx(H,{className:"h-5 w-5","aria-hidden":"true"}),title:a("dashboard.modelTable.empty")}):e.jsx("div",{className:"overflow-auto",children:e.jsxs(ie,{children:[e.jsx(de,{children:e.jsxs(F,{children:[e.jsx(j,{children:a("dashboard.modelTable.columns.model")}),e.jsx(j,{className:"text-right",children:a("dashboard.modelTable.columns.requests")}),e.jsx(j,{className:"text-right",children:a("dashboard.modelTable.columns.latency")}),e.jsx(j,{className:"text-right",children:a("dashboard.modelTable.columns.ttft")}),e.jsx(j,{className:"text-right",children:a("dashboard.modelTable.columns.tpot")})]})}),e.jsx(le,{children:s.map(r=>e.jsxs(F,{children:[e.jsx(y,{children:e.jsxs("div",{className:"flex flex-col",children:[e.jsx("span",{className:"font-medium",children:r.provider}),e.jsx("span",{className:"text-xs text-muted-foreground",children:r.model})]})}),e.jsx(y,{className:"text-right font-medium",children:r.requests.toLocaleString()}),e.jsx(y,{className:"text-right",children:R(r.avgLatencyMs,a("common.units.ms"))}),e.jsx(y,{className:"text-right",children:R(r.avgTtftMs,a("common.units.ms"))}),e.jsx(y,{className:"text-right",children:R(r.avgTpotMs,a("common.units.msPerToken"),{maximumFractionDigits:2})})]},`${r.provider}/${r.model}`))})]})})})}function mt({records:s,loading:t}){const{t:a}=w(),r=s.map(n=>ae(n,a)),o=r.filter(n=>n.tone==="success").length,c=r.filter(n=>n.tone==="error").length,l=r.filter(n=>n.tone==="pending").length;return e.jsx(ce,{title:a("dashboard.recent.title"),description:a("dashboard.recent.subtitle",{count:5}),actions:s.length>0?e.jsxs("div",{className:"flex flex-wrap items-center gap-2",children:[e.jsx(k,{variant:"secondary",children:s.length}),e.jsxs(k,{variant:"success",children:[a("common.status.success"),": ",o]}),e.jsxs(k,{variant:"outline",className:"border-destructive/30 bg-destructive/10 text-destructive",children:[a("common.status.error"),": ",c]}),l>0?e.jsxs(k,{variant:"warning",children:[a("common.status.pending"),": ",l]}):null]}):null,children:t?e.jsx(V,{compact:!0,label:a("dashboard.recent.loading")}):s.length===0?e.jsx(G,{compact:!0,icon:e.jsx(Q,{className:"h-5 w-5","aria-hidden":"true"}),title:a("dashboard.recent.empty")}):e.jsx("div",{className:"overflow-auto",children:e.jsxs(ie,{children:[e.jsx(de,{children:e.jsxs(F,{children:[e.jsx(j,{children:a("dashboard.recent.columns.time")}),e.jsx(j,{children:a("dashboard.recent.columns.endpoint")}),e.jsx(j,{children:a("dashboard.recent.columns.provider")}),e.jsx(j,{children:a("dashboard.recent.columns.route")}),e.jsx(j,{className:"text-right",children:a("dashboard.recent.columns.latency")}),e.jsx(j,{children:a("dashboard.recent.columns.status")})]})}),e.jsx(le,{children:s.map(n=>{const i=ae(n,a);return e.jsxs(F,{children:[e.jsx(y,{children:e.jsxs("div",{className:"flex flex-col",children:[e.jsx("span",{className:"text-xs font-medium",children:new Date(n.timestamp).toLocaleString()}),e.jsxs("span",{className:"text-[11px] text-muted-foreground",children:["#",n.id]})]})}),e.jsx(y,{children:e.jsx(k,{variant:"outline",className:"text-[11px]",children:n.endpoint==="anthropic"?a("logs.endpointAnthropic"):n.endpoint==="openai"?a("logs.endpointOpenAI"):n.endpoint})}),e.jsx(y,{children:e.jsxs("div",{className:"flex flex-col",children:[e.jsx("span",{className:"font-medium",children:n.provider}),e.jsx("span",{className:"text-[11px] text-muted-foreground",children:n.stream?"stream":"sync"})]})}),e.jsx(y,{children:e.jsxs("div",{className:"flex flex-col gap-1 text-xs",children:[e.jsxs("div",{className:"flex items-center gap-1 text-muted-foreground",children:[e.jsx("span",{children:n.client_model??a("dashboard.recent.routePlaceholder")}),e.jsx("span",{children:"->"}),e.jsx("span",{className:"font-medium text-foreground",children:n.model})]}),n.error?e.jsx("span",{className:"truncate text-destructive",children:n.error}):null]})}),e.jsx(y,{className:"text-right font-medium",children:R(n.latency_ms,a("common.units.ms"))}),e.jsx(y,{children:e.jsx(k,{variant:i.variant,className:"min-w-14 justify-center",children:i.label})})]},n.id)})})]})})})}function oe({className:s,compact:t,featured:a,icon:r,label:o,value:c,suffix:l,valueTestId:n}){return e.jsxs("div",{className:C("group flex flex-col justify-between rounded-[1.15rem] border border-white/70 bg-card/95 shadow-[0_18px_42px_-36px_rgba(15,23,42,0.24)] transition-all hover:-translate-y-0.5 hover:shadow-[0_24px_48px_-38px_rgba(59,130,246,0.2)] dark:border-white/10 dark:bg-slate-950/90 dark:shadow-[0_18px_42px_-36px_rgba(0,0,0,0.72)] dark:hover:shadow-[0_24px_48px_-38px_rgba(59,130,246,0.28)]",a?"bg-[linear-gradient(135deg,hsl(var(--primary)/0.1),rgba(255,255,255,0.95)_46%,rgba(236,253,245,0.74))] p-5 dark:!bg-none dark:!bg-slate-950/90":t?"p-3.5":"p-5",s),children:[e.jsxs("div",{className:"flex items-center gap-2 text-xs text-muted-foreground",children:[e.jsx("span",{className:C("inline-flex h-7 w-7 items-center justify-center rounded-lg bg-primary/10 text-primary",t&&"h-6 w-6 rounded-md"),children:r}),e.jsx("span",{children:o})]}),e.jsxs("p",{className:C("metric-number mt-3 font-semibold tracking-tight text-foreground",a?"text-3xl":t?"text-lg":"text-2xl"),"data-testid":n,children:[c,l?e.jsx("span",{className:"ml-1 text-sm font-normal text-muted-foreground",children:l}):null]})]})}function A({featured:s,label:t,value:a,hint:r}){return e.jsx(O,{className:s?"overflow-hidden bg-[linear-gradient(135deg,rgba(255,255,255,0.98),hsl(var(--primary)/0.08))] dark:!bg-none dark:!bg-card dark:border-white/10 dark:shadow-[0_18px_42px_-36px_rgba(0,0,0,0.72)]":void 0,children:e.jsxs($,{className:C("pt-4",s&&"pb-4"),children:[e.jsx("p",{className:"text-[11px] font-medium uppercase tracking-wider text-muted-foreground",children:t}),e.jsx("p",{className:C("mt-2 line-clamp-1 font-semibold text-foreground",s?"metric-number text-2xl tracking-tight":"text-base"),children:a}),e.jsx("p",{className:"mt-1 text-xs text-muted-foreground",children:r})]})})}function B({description:s,empty:t,emptyText:a,loading:r,option:o,title:c}){const{t:l}=w();return e.jsx(O,{children:e.jsxs($,{className:"space-y-4 pt-5",children:[e.jsxs("div",{children:[e.jsx("p",{className:"text-sm font-semibold",children:c}),e.jsx("p",{className:"mt-0.5 text-xs text-muted-foreground/70",children:s})]}),r?e.jsx(V,{compact:!0,className:"min-h-[220px]",label:l("common.loadingShort")}):t?e.jsx(G,{compact:!0,className:"min-h-[188px] rounded-[1rem] border border-dashed border-border/45 bg-secondary/35",icon:e.jsx(H,{className:"h-5 w-5","aria-hidden":"true"}),title:a??l("dashboard.charts.empty"),description:s}):e.jsx("div",{className:"pt-2",children:e.jsx(Je,{echarts:st,option:o,className:"h-[40vh] min-h-[280px] max-h-[420px]",notMerge:!0,lazyUpdate:!0})})]})})}function ht(){var K,W,Y,Z,J,X,ee,te;const{t:s}=w(),{pushToast:t}=Ge(),[a,r]=ze(He.dashboard.endpointFilter,"all"),[o,c]=u.useState(!1),l=a==="all"?void 0:a,n=L(I.customEndpoints.all(),{url:"/api/custom-endpoints",method:"GET"},{refetchInterval:z,refetchIntervalInBackground:!0}),i=L(I.stats.overview(a),{url:"/api/stats/overview",method:"GET",params:l?{endpoint:l}:void 0},{refetchInterval:M,refetchIntervalInBackground:!0}),m=L(I.stats.daily(14,a),{url:"/api/stats/daily",method:"GET",params:{days:14,...l?{endpoint:l}:{}}},{refetchInterval:z,refetchIntervalInBackground:!0}),v=L(I.stats.model(7,6,a),{url:"/api/stats/model",method:"GET",params:{days:7,limit:6,...l?{endpoint:l}:{}}},{refetchInterval:z,refetchIntervalInBackground:!0}),g=L(I.status.byEndpoint(a),{url:"/api/status",method:"GET",params:l?{endpoint:l}:void 0},{refetchInterval:M,refetchIntervalInBackground:!0}),x=L(I.db.info(),{url:"/api/db/info",method:"GET"},{refetchInterval:M,refetchIntervalInBackground:!0}),N=L(I.logs.recent(a),{url:"/api/logs",method:"GET",params:{limit:5,...l?{endpoint:l}:{}}},{refetchInterval:M,refetchIntervalInBackground:!0});u.useEffect(()=>{i.isError&&i.error&&t({title:s("dashboard.toast.overviewError"),description:i.error.message,variant:"error"})},[i.error,i.isError,t,s]),u.useEffect(()=>{m.isError&&m.error&&t({title:s("dashboard.toast.dailyError"),description:m.error.message,variant:"error"})},[m.error,m.isError,t,s]),u.useEffect(()=>{v.isError&&v.error&&t({title:s("dashboard.toast.modelError"),description:v.error.message,variant:"error"})},[v.error,v.isError,t,s]),u.useEffect(()=>{g.isError&&g.error&&t({title:s("dashboard.toast.statusError"),description:g.error.message,variant:"error"})},[g.error,g.isError,t,s]),u.useEffect(()=>{x.isError&&x.error&&t({title:s("dashboard.toast.dbError"),description:x.error.message,variant:"error"})},[x.error,x.isError,t,s]),u.useEffect(()=>{N.isError&&N.error&&t({title:s("dashboard.toast.recentError"),description:N.error.message,variant:"error"})},[N.error,N.isError,t,s]);const me=u.useCallback(async()=>{await Promise.all([n.refetch(),i.refetch(),m.refetch(),v.refetch(),g.refetch(),x.refetch(),N.refetch()])},[n,x,m,N,v,i,g]),he=u.useCallback(async()=>{if(!o){c(!0);try{await Qe.post("/api/db/compact"),await x.refetch(),t({title:s("dashboard.toast.compactSuccess.title"),description:s("dashboard.toast.compactSuccess.desc"),variant:"success"})}catch(d){const h=Ue(d);t({title:s("dashboard.toast.compactError.title"),description:h.message,variant:"error"})}finally{c(!1)}}},[o,x,t,s]),pe=i.data,S=m.data??[],p=v.data??[],xe=g.data,E=x.data,ue=((K=N.data)==null?void 0:K.items)??[],ge=a==="all"?s("dashboard.filters.endpointAll"):a==="anthropic"?s("dashboard.filters.endpointAnthropic"):a==="openai"?s("dashboard.filters.endpointOpenAI"):((Z=(Y=(W=n.data)==null?void 0:W.endpoints)==null?void 0:Y.find(d=>d.id===a))==null?void 0:Z.label)||a,be=S.reduce((d,h)=>d+h.requestCount,0),fe=S.reduce((d,h)=>!d||h.requestCount>d.requestCount?h:d,null),je=p[0],ye=p.filter(d=>d.avgTtftMs!=null&&d.avgTtftMs>0).sort((d,h)=>(d.avgTtftMs??Number.POSITIVE_INFINITY)-(h.avgTtftMs??Number.POSITIVE_INFINITY))[0],ve=n.isFetching||i.isFetching||m.isFetching||v.isFetching||g.isFetching||x.isFetching||N.isFetching,Ne=i.isPending||g.isPending||x.isPending,Se=((J=i.error)==null?void 0:J.message)??((X=g.error)==null?void 0:X.message)??((ee=x.error)==null?void 0:ee.message)??null,Te=E?U(E.totalBytes??E.sizeBytes):"-",we=U(E==null?void 0:E.memoryRssBytes),Ee=u.useMemo(()=>{const d=S.map(f=>f.date),h=s("dashboard.charts.barRequests"),_=s("dashboard.charts.lineInput"),P=s("dashboard.charts.lineOutput"),b=s("dashboard.charts.lineCacheRead"),se=s("dashboard.charts.lineCacheCreation");return{tooltip:{trigger:"axis"},legend:{data:[h,_,P,b,se]},grid:{left:56,right:28,top:56,bottom:54},xAxis:{type:"category",data:d},yAxis:{type:"value"},series:[{name:h,type:"bar",data:S.map(f=>f.requestCount),itemStyle:{color:T.requests,borderRadius:[6,6,0,0]}},{name:_,type:"line",smooth:!0,data:S.map(f=>f.inputTokens),itemStyle:{color:T.input},lineStyle:{width:2}},{name:P,type:"line",smooth:!0,data:S.map(f=>f.outputTokens),itemStyle:{color:T.output},lineStyle:{width:2}},{name:b,type:"line",smooth:!0,data:S.map(f=>f.cacheReadTokens),itemStyle:{color:T.cacheRead},lineStyle:{width:2}},{name:se,type:"line",smooth:!0,data:S.map(f=>f.cacheCreationTokens),itemStyle:{color:T.cacheCreation},lineStyle:{width:2}}]}},[S,s]),Ie=u.useMemo(()=>{const d=p.map(b=>`${b.provider}/${b.model}`),h=s("dashboard.charts.barRequests"),_=s("dashboard.charts.lineInput"),P=s("dashboard.charts.lineOutput");return{tooltip:{trigger:"axis"},legend:{data:[h,_,P]},grid:{left:72,right:52,top:56,bottom:96},xAxis:{type:"category",data:d,axisLabel:{rotate:28}},yAxis:[{type:"value",name:h},{type:"value",name:s("dashboard.charts.axisTokens"),position:"right"}],series:[{name:h,type:"bar",data:p.map(b=>b.requests),itemStyle:{color:T.requests,borderRadius:[6,6,0,0]}},{name:_,type:"line",yAxisIndex:1,smooth:!0,data:p.map(b=>b.inputTokens??0),itemStyle:{color:T.input}},{name:P,type:"line",yAxisIndex:1,smooth:!0,data:p.map(b=>b.outputTokens??0),itemStyle:{color:T.output}}]}},[p,s]),Le=u.useMemo(()=>({tooltip:{trigger:"axis"},grid:{left:72,right:40,top:56,bottom:96},xAxis:{type:"category",data:p.map(d=>`${d.provider}/${d.model}`),axisLabel:{rotate:28}},yAxis:{type:"value",name:s("dashboard.charts.ttftAxis")},series:[{name:s("dashboard.charts.ttftLabel"),type:"bar",data:p.map(d=>d.avgTtftMs??0),itemStyle:{color:T.latency,borderRadius:[6,6,0,0]}}]}),[p,s]),ke=u.useMemo(()=>({tooltip:{trigger:"axis"},grid:{left:72,right:40,top:56,bottom:96},xAxis:{type:"category",data:p.map(d=>`${d.provider}/${d.model}`),axisLabel:{rotate:28}},yAxis:{type:"value",name:s("dashboard.charts.tpotAxis")},series:[{name:s("dashboard.charts.tpotLabel"),type:"bar",data:p.map(d=>d.avgTpotMs??0),itemStyle:{color:T.output,borderRadius:[6,6,0,0]}}]}),[p,s]);return{compacting:o,customEndpoints:((te=n.data)==null?void 0:te.endpoints)??[],daily:S,dailyOption:Ee,dailyPending:m.isPending,dbInfo:E,dbSizeDisplay:Te,endpointFilter:a,fastestTtftModel:ye,handleCompact:he,handleRefresh:me,bootstrapError:Se,isBootstrapping:Ne,isRefreshing:ve,latestLogsPending:N.isPending,memoryDisplay:we,modelRequestsOption:Ie,modelUsagePending:v.isPending,models:p,overview:pe,recentLogs:ue,selectedEndpointLabel:ge,setEndpointFilter:r,status:xe,topModel:je,totalRequestsInRange:be,busiestDay:fe,ttftOption:Le,tpotOption:ke}}function Pt(){var r,o;const{t:s}=w(),t=ht(),a=t.recentLogs.length===0||t.models.length===0;return e.jsxs("div",{className:"flex flex-col gap-6",children:[e.jsx($e,{info:e.jsxs("span",{className:"text-xs text-muted-foreground",children:[s("dashboard.filters.endpoint")," · ",t.selectedEndpointLabel]}),actions:e.jsxs(e.Fragment,{children:[e.jsxs(Ve,{value:t.endpointFilter,onValueChange:t.setEndpointFilter,children:[e.jsx(Ke,{className:"h-8 w-[168px]",children:e.jsx(We,{})}),e.jsxs(Ye,{children:[e.jsx(q,{value:"all",children:s("dashboard.filters.endpointAll")}),e.jsx(q,{value:"anthropic",children:s("dashboard.filters.endpointAnthropic")}),e.jsx(q,{value:"openai",children:s("dashboard.filters.endpointOpenAI")}),t.customEndpoints.map(c=>e.jsx(q,{value:c.id,children:c.label||c.id},c.id))]})]}),e.jsxs(D,{variant:"outline",size:"sm",onClick:()=>void t.handleRefresh(),disabled:t.isRefreshing,children:[e.jsx(Fe,{className:C("mr-2 h-4 w-4",t.isRefreshing&&"animate-spin"),"aria-hidden":"true"}),t.isRefreshing?s("common.actions.refreshing"):s("common.actions.refresh")]}),e.jsxs(D,{variant:"outline",size:"sm",onClick:()=>void t.handleCompact(),disabled:t.compacting,children:[e.jsx(ne,{className:"mr-2 h-4 w-4","aria-hidden":"true"}),t.compacting?s("dashboard.actions.compacting"):s("dashboard.actions.compact")]})]})}),t.isBootstrapping?e.jsx(rt,{}):t.bootstrapError?e.jsx(G,{icon:e.jsx(Oe,{className:"h-5 w-5","aria-hidden":"true"}),tone:"danger",title:s("common.status.error"),description:t.bootstrapError,action:e.jsx(D,{variant:"outline",onClick:()=>void t.handleRefresh(),children:s("common.actions.refresh")})}):e.jsxs(e.Fragment,{children:[e.jsx(ot,{selectedEndpointLabel:t.selectedEndpointLabel,status:t.status,todayRequests:((r=t.overview)==null?void 0:r.today.requests)??0}),a?e.jsx(dt,{endpointCount:t.customEndpoints.length,providerCount:((o=t.status)==null?void 0:o.providers)??0,selectedEndpointLabel:t.selectedEndpointLabel}):null,e.jsx(nt,{dbSizeDisplay:t.dbSizeDisplay,memoryDisplay:t.memoryDisplay,overview:t.overview,status:t.status}),e.jsx(it,{busiestDay:t.busiestDay,fastestTtftModel:t.fastestTtftModel,topModel:t.topModel,totalRequestsInRange:t.totalRequestsInRange}),e.jsx(lt,{dailyEmpty:!t.daily.length,dailyOption:t.dailyOption,dailyPending:t.dailyPending,models:t.models,modelRequestsOption:t.modelRequestsOption,modelUsagePending:t.modelUsagePending,ttftOption:t.ttftOption,tpotOption:t.tpotOption}),e.jsx(ct,{models:t.models,loading:t.modelUsagePending}),e.jsx(mt,{records:t.recentLogs,loading:t.latestLogsPending})]})]})}export{Pt as default};
1
+ import{j as e,ap as Ce,af as Re,W as Q,ak as _e,aq as Pe,ar as qe,O as H,as as Me,at as Ae,au as Be,av as ne,aw as De,r as u,ax as Fe,U as Oe}from"./vendor-DdPBfMMb.js";import{P as $e}from"./PageToolbar-BBTEUrko.js";import{P as V,a as G}from"./PageState-Cq7xpTfp.js";import{B as D,u as Ge,a as ze,b as Qe,t as Ue,s as He}from"./app-BBdow7GJ.js";import{S as Ve,a as Ke,b as We,c as Ye,d as q}from"./select-CohvZ6L7.js";import{c as C}from"./global-CaQPIFGa.js";import{L as Ze}from"./router-D2Fb4U0L.js";import{T as ie,a as de,b as F,c as j,d as le,e as y,E as Je}from"./table-CnAkbq3u.js";import{P as ce}from"./PageSection-uD1ZrEC_.js";import{S as Xe,C as et,T as tt}from"./Skeleton-DEhFppby.js";import{B as k,q as I}from"./queryKeys-BiuXKawV.js";import{C as O,a as $}from"./card-Do7RepdY.js";import{g as ae}from"./utils-DSaa7c6v.js";import{u as w}from"./i18n-C8tBby0x.js";import{e as st}from"./charts-core-CK8TVJro.js";import{u as L}from"./useApiQuery-nMqbFkID.js";import"./query-QCek5MsK.js";import"./radix-CtQBp6Ie.js";import"./charts-react-CmmN-08P.js";import"./charts-engine-CWjgwbj5.js";const M=15e3,z=6e4,T={requests:"#2563eb",input:"#059669",output:"#ea580c",cacheRead:"#7c3aed",cacheCreation:"#e11d48",latency:"#0891b2"};function R(s,t,a){return s==null?"-":`${s.toLocaleString(void 0,a)} ${t}`}function U(s){if(s==null)return"-";if(s<1024)return`${s} B`;const t=["KB","MB","GB","TB"];let a=s/1024,r=0;for(;a>=1024&&r<t.length-1;)a/=1024,r+=1;return`${a.toFixed(a>=100?0:a>=10?1:2)} ${t[r]}`}function re(s){if(s==null)return"-";const t=s<1?0:s;return t<1024?`${t.toLocaleString(void 0,{maximumFractionDigits:t>=100?0:t>=10?1:2})} B/s`:`${U(t)}/s`}function at(s){return s==null?"-":`${s.toLocaleString(void 0,{maximumFractionDigits:s>=10?0:1})}%`}function rt(){return e.jsxs("div",{className:"flex flex-col gap-6",children:[e.jsx("div",{className:"h-20 animate-pulse rounded-xl bg-card shadow-[var(--surface-shadow)]"}),e.jsx("div",{className:"grid gap-4 sm:grid-cols-2 lg:grid-cols-3 xl:grid-cols-4",children:Array.from({length:12}).map((s,t)=>e.jsx(Xe,{},t))}),e.jsx("div",{className:"grid gap-6 lg:grid-cols-2",children:Array.from({length:4}).map((s,t)=>e.jsx(et,{},t))}),e.jsx("div",{className:"rounded-xl bg-card shadow-[var(--surface-shadow)]",children:e.jsx("table",{className:"w-full",children:e.jsx("tbody",{children:Array.from({length:5}).map((s,t)=>e.jsx(tt,{columns:6},t))})})})]})}function ot({selectedEndpointLabel:s,status:t,todayRequests:a}){const{t:r}=w();return e.jsxs("div",{className:"flex flex-col gap-4 rounded-xl bg-card p-6 shadow-[var(--surface-shadow)] sm:flex-row sm:items-center sm:justify-between","data-testid":"dashboard-overview-panel",children:[e.jsxs("div",{className:"flex items-center gap-4",children:[e.jsx("div",{className:"flex h-10 w-10 items-center justify-center rounded-lg bg-primary/10",children:e.jsx(Ce,{className:"h-5 w-5 text-primary","aria-hidden":"true"})}),e.jsxs("div",{children:[e.jsxs("div",{className:"flex items-center gap-2",children:[e.jsx("h2",{className:"text-lg font-semibold text-foreground",children:s}),e.jsx(k,{variant:"success",children:r("dashboard.status.listeningLabel")})]}),e.jsxs("p",{className:"mt-0.5 text-sm text-muted-foreground",children:[e.jsxs("span",{"data-testid":"dashboard-runtime-address",children:[(t==null?void 0:t.host)??"0.0.0.0",":",(t==null?void 0:t.port)??"-"]}),e.jsx("span",{className:"mx-2 text-border",children:"·"}),r("dashboard.labels.todayRequests"),": ",a.toLocaleString(),e.jsx("span",{className:"mx-2 text-border",children:"·"}),r("dashboard.labels.providers"),": ",((t==null?void 0:t.providers)??0).toLocaleString()]})]})]}),e.jsxs("div",{className:"flex flex-wrap items-center gap-3 text-sm text-muted-foreground",children:[e.jsxs("span",{children:[r("dashboard.labels.activeClientAddresses"),": ",e.jsx("strong",{className:"text-foreground",children:((t==null?void 0:t.activeClientAddresses)??0).toLocaleString()})]}),e.jsx("span",{className:"text-border",children:"·"}),e.jsxs("span",{children:[r("dashboard.labels.activeClientSessions"),": ",e.jsx("strong",{className:"text-foreground",children:((t==null?void 0:t.activeClientSessions)??0).toLocaleString()})]})]})]})}function nt({dbSizeDisplay:s,memoryDisplay:t,overview:a,status:r}){const{t:o}=w(),c=[{icon:e.jsx(Re,{className:"h-4 w-4"}),label:o("dashboard.labels.activeRequests"),value:((r==null?void 0:r.activeRequests)??0).toLocaleString(),testId:"dashboard-spotlight-value-active"},{icon:e.jsx(Q,{className:"h-4 w-4"}),label:o("dashboard.labels.requestsPerMinute"),value:((r==null?void 0:r.requestsPerMinute)??0).toLocaleString(),testId:"dashboard-spotlight-value-rpm"},{icon:e.jsx(_e,{className:"h-4 w-4"}),label:o("dashboard.labels.outputTokensPerMinute"),value:((r==null?void 0:r.outputTokensPerMinute)??0).toLocaleString(),testId:"dashboard-spotlight-value-tpm"},{icon:e.jsx(Pe,{className:"h-4 w-4"}),label:o("dashboard.labels.cpu"),value:at(r==null?void 0:r.cpuUsagePercent),testId:"dashboard-spotlight-value-cpu"}],l=[{icon:e.jsx(Q,{className:"h-4 w-4"}),label:o("dashboard.cards.todayRequests"),value:((a==null?void 0:a.today.requests)??0).toLocaleString(),suffix:o("common.units.request")},{icon:e.jsx(qe,{className:"h-4 w-4"}),label:o("dashboard.cards.todayInput"),value:((a==null?void 0:a.today.inputTokens)??0).toLocaleString(),suffix:o("common.units.token")},{icon:e.jsx(H,{className:"h-4 w-4"}),label:o("dashboard.cards.todayOutput"),value:((a==null?void 0:a.today.outputTokens)??0).toLocaleString(),suffix:o("common.units.token")},{icon:e.jsx(Me,{className:"h-4 w-4"}),label:o("dashboard.cards.avgLatency"),value:R((a==null?void 0:a.today.avgLatencyMs)??0,o("common.units.ms"))},{icon:e.jsx(Ae,{className:"h-4 w-4"}),label:o("dashboard.labels.networkIngress"),value:re(r==null?void 0:r.networkIngressBytesPerSecond),testId:"dashboard-spotlight-value-ingress"},{icon:e.jsx(Be,{className:"h-4 w-4"}),label:o("dashboard.labels.networkEgress"),value:re(r==null?void 0:r.networkEgressBytesPerSecond),testId:"dashboard-spotlight-value-egress"},{icon:e.jsx(ne,{className:"h-4 w-4"}),label:o("dashboard.labels.database"),value:s,testId:"dashboard-spotlight-value-database"},{icon:e.jsx(De,{className:"h-4 w-4"}),label:o("dashboard.labels.memory"),value:t,testId:"dashboard-spotlight-value-memory"}];return e.jsxs("div",{className:"space-y-3","data-testid":"dashboard-spotlight-grid",children:[e.jsx("div",{className:"grid gap-3 md:grid-cols-2 xl:grid-cols-5",children:c.map((n,i)=>e.jsx(oe,{className:i===0?"md:col-span-2 xl:col-span-2":void 0,featured:i===0,icon:n.icon,label:n.label,value:n.value,valueTestId:n.testId},n.label))}),e.jsx("div",{className:"grid gap-2.5 sm:grid-cols-2 lg:grid-cols-4",children:l.map(n=>e.jsx(oe,{compact:!0,icon:n.icon,label:n.label,suffix:n.suffix,value:n.value,valueTestId:n.testId},n.label))})]})}function it({busiestDay:s,fastestTtftModel:t,topModel:a,totalRequestsInRange:r}){const{t:o}=w();return e.jsxs("div",{className:"grid gap-3 lg:grid-cols-[1.4fr_repeat(3,minmax(0,1fr))]",children:[e.jsx(A,{featured:!0,label:o("dashboard.insights.totalRequests"),value:r.toLocaleString(),hint:o("dashboard.insights.totalRequestsHint")}),e.jsx(A,{label:o("dashboard.insights.busiestDay"),value:s?s.date:"-",hint:s?o("dashboard.insights.busiestDayHint",{value:s.requestCount.toLocaleString()}):o("common.noData")}),e.jsx(A,{label:o("dashboard.insights.topModel"),value:a?`${a.provider}/${a.model}`:"-",hint:a?o("dashboard.insights.topModelHint",{value:a.requests.toLocaleString()}):o("common.noData")}),e.jsx(A,{label:o("dashboard.insights.fastestTtft"),value:t?`${t.provider}/${t.model}`:"-",hint:t?R(t.avgTtftMs,o("common.units.ms")):o("common.noData")})]})}function dt({endpointCount:s,providerCount:t,selectedEndpointLabel:a}){const r=[{title:"先配置 Provider",description:t>0?`当前已检测到 ${t} 个 Provider,可直接继续下一步。`:"先在模型供应商里接入至少 1 个上游模型服务。",href:"/models",cta:"去模型供应商",tone:"from-indigo-100 to-cyan-100"},{title:"确认默认路由入口",description:s>0?`当前已有 ${s} 个自定义端点,可继续检查默认映射是否合理。`:"把一个端点或默认路由配置清楚,后续客户端就能稳定接入。",href:"/routing",cta:"去路由管理",tone:"from-violet-100 to-fuchsia-100"},{title:"发起第一条真实请求",description:"创建 API Key,然后从常用客户端打进来一条请求,让日志、路由和延迟开始有数据。",href:"/api-keys",cta:"去 API 密钥",tone:"from-emerald-100 to-cyan-100"}];return e.jsxs("div",{className:"grid gap-4 xl:grid-cols-[minmax(0,1.2fr)_minmax(300px,0.8fr)]",children:[e.jsx(O,{className:"overflow-hidden border-white/80 bg-[linear-gradient(135deg,rgba(255,255,255,0.98),hsl(var(--primary)/0.08),rgba(236,253,245,0.8))] shadow-[0_22px_56px_-40px_rgba(15,23,42,0.24)]",children:e.jsxs($,{className:"space-y-5 pt-5",children:[e.jsxs("div",{className:"space-y-2",children:[e.jsx("div",{className:"inline-flex items-center rounded-full bg-primary/10 px-3 py-1 text-[11px] font-semibold uppercase tracking-[0.16em] text-primary",children:"Cold Start Guide"}),e.jsxs("div",{children:[e.jsx("h3",{className:"text-lg font-semibold text-foreground",children:"当前还是冷启动状态,这是正常的"}),e.jsx("p",{className:"mt-1.5 text-sm leading-6 text-muted-foreground",children:"这个仪表盘会在第一条真实请求进来后明显更有价值。现在最适合做的是把 Provider、路由和 API Key 三件事顺次走通。"})]})]}),e.jsx("div",{className:"grid gap-3 lg:grid-cols-3",children:r.map((o,c)=>e.jsxs("div",{className:"rounded-[1.1rem] border border-white/70 bg-card/88 p-4 shadow-[0_16px_40px_-34px_rgba(15,23,42,0.18)]",children:[e.jsxs("div",{className:C("flex h-10 w-10 items-center justify-center rounded-2xl bg-gradient-to-br text-sm font-semibold text-primary",o.tone),children:["0",c+1]}),e.jsx("h4",{className:"mt-3 text-sm font-semibold text-foreground",children:o.title}),e.jsx("p",{className:"mt-1.5 text-xs leading-6 text-muted-foreground",children:o.description}),e.jsx(D,{asChild:!0,variant:"ghost",size:"sm",className:"mt-3 h-8 rounded-full px-0 text-primary hover:bg-transparent hover:text-primary/80",children:e.jsx(Ze,{to:o.href,children:o.cta})})]},o.title))})]})}),e.jsx(O,{className:"border-white/80 bg-card/96 shadow-[0_20px_48px_-40px_rgba(15,23,42,0.24)]",children:e.jsxs($,{className:"space-y-4 pt-5",children:[e.jsxs("div",{children:[e.jsx("p",{className:"text-[11px] font-semibold uppercase tracking-[0.16em] text-muted-foreground/80",children:"Workspace Snapshot"}),e.jsx("h3",{className:"mt-2 text-base font-semibold text-foreground",children:a}),e.jsx("p",{className:"mt-1 text-xs leading-6 text-muted-foreground",children:"等第一批流量进来后,这里会逐步展示趋势、模型表现和最近请求。"})]}),e.jsx("div",{className:"grid gap-3 sm:grid-cols-3 xl:grid-cols-1",children:[{label:"已配置 Provider",value:String(t)},{label:"自定义端点",value:String(s)},{label:"建议下一步",value:"发起请求"}].map(o=>e.jsxs("div",{className:"rounded-[1rem] bg-secondary/45 px-4 py-3 ring-1 ring-white/70",children:[e.jsx("div",{className:"text-[11px] font-medium text-muted-foreground",children:o.label}),e.jsx("div",{className:"mt-1 text-lg font-semibold text-foreground",children:o.value})]},o.label))}),e.jsx("div",{className:"rounded-[1rem] border border-dashed border-border/45 bg-secondary/35 px-4 py-3",children:e.jsxs("p",{className:"text-xs leading-6 text-muted-foreground",children:["如果你还没确定从哪一步开始,优先去 ",e.jsx("span",{className:"font-medium text-foreground",children:"API 密钥"})," 创建一个客户端专用 key,再从常用工具发起一条最小请求。"]})})]})})]})}function lt({dailyEmpty:s,dailyOption:t,dailyPending:a,models:r,modelRequestsOption:o,modelUsagePending:c,ttftOption:l,tpotOption:n}){const{t:i}=w();return e.jsxs(e.Fragment,{children:[e.jsxs("div",{className:"grid gap-6 lg:grid-cols-2",children:[e.jsx(B,{title:i("dashboard.charts.requestsTitle"),description:i("dashboard.charts.requestsDesc"),loading:a,option:t,empty:s,emptyText:i("dashboard.charts.empty")}),e.jsx(B,{title:i("dashboard.charts.modelTitle"),description:i("dashboard.charts.modelDesc"),loading:c,option:o,empty:!r.length,emptyText:i("dashboard.charts.empty")})]}),e.jsxs("div",{className:"grid gap-6 lg:grid-cols-2",children:[e.jsx(B,{title:i("dashboard.charts.ttftTitle"),description:i("dashboard.charts.ttftDesc"),loading:c,option:l,empty:!r.some(m=>m.avgTtftMs!=null&&m.avgTtftMs>0),emptyText:i("dashboard.charts.ttftEmpty")}),e.jsx(B,{title:i("dashboard.charts.tpotTitle"),description:i("dashboard.charts.tpotDesc"),loading:c,option:n,empty:!r.some(m=>m.avgTpotMs!=null&&m.avgTpotMs>0),emptyText:i("dashboard.charts.tpotEmpty")})]})]})}function ct({models:s,loading:t}){const{t:a}=w();return e.jsx(ce,{title:a("dashboard.modelTable.title"),description:a("dashboard.modelTable.description"),children:t?e.jsx(V,{compact:!0,label:a("common.loadingShort")}):s.length===0?e.jsx(G,{compact:!0,icon:e.jsx(H,{className:"h-5 w-5","aria-hidden":"true"}),title:a("dashboard.modelTable.empty")}):e.jsx("div",{className:"overflow-auto",children:e.jsxs(ie,{children:[e.jsx(de,{children:e.jsxs(F,{children:[e.jsx(j,{children:a("dashboard.modelTable.columns.model")}),e.jsx(j,{className:"text-right",children:a("dashboard.modelTable.columns.requests")}),e.jsx(j,{className:"text-right",children:a("dashboard.modelTable.columns.latency")}),e.jsx(j,{className:"text-right",children:a("dashboard.modelTable.columns.ttft")}),e.jsx(j,{className:"text-right",children:a("dashboard.modelTable.columns.tpot")})]})}),e.jsx(le,{children:s.map(r=>e.jsxs(F,{children:[e.jsx(y,{children:e.jsxs("div",{className:"flex flex-col",children:[e.jsx("span",{className:"font-medium",children:r.provider}),e.jsx("span",{className:"text-xs text-muted-foreground",children:r.model})]})}),e.jsx(y,{className:"text-right font-medium",children:r.requests.toLocaleString()}),e.jsx(y,{className:"text-right",children:R(r.avgLatencyMs,a("common.units.ms"))}),e.jsx(y,{className:"text-right",children:R(r.avgTtftMs,a("common.units.ms"))}),e.jsx(y,{className:"text-right",children:R(r.avgTpotMs,a("common.units.msPerToken"),{maximumFractionDigits:2})})]},`${r.provider}/${r.model}`))})]})})})}function mt({records:s,loading:t}){const{t:a}=w(),r=s.map(n=>ae(n,a)),o=r.filter(n=>n.tone==="success").length,c=r.filter(n=>n.tone==="error").length,l=r.filter(n=>n.tone==="pending").length;return e.jsx(ce,{title:a("dashboard.recent.title"),description:a("dashboard.recent.subtitle",{count:5}),actions:s.length>0?e.jsxs("div",{className:"flex flex-wrap items-center gap-2",children:[e.jsx(k,{variant:"secondary",children:s.length}),e.jsxs(k,{variant:"success",children:[a("common.status.success"),": ",o]}),e.jsxs(k,{variant:"outline",className:"border-destructive/30 bg-destructive/10 text-destructive",children:[a("common.status.error"),": ",c]}),l>0?e.jsxs(k,{variant:"warning",children:[a("common.status.pending"),": ",l]}):null]}):null,children:t?e.jsx(V,{compact:!0,label:a("dashboard.recent.loading")}):s.length===0?e.jsx(G,{compact:!0,icon:e.jsx(Q,{className:"h-5 w-5","aria-hidden":"true"}),title:a("dashboard.recent.empty")}):e.jsx("div",{className:"overflow-auto",children:e.jsxs(ie,{children:[e.jsx(de,{children:e.jsxs(F,{children:[e.jsx(j,{children:a("dashboard.recent.columns.time")}),e.jsx(j,{children:a("dashboard.recent.columns.endpoint")}),e.jsx(j,{children:a("dashboard.recent.columns.provider")}),e.jsx(j,{children:a("dashboard.recent.columns.route")}),e.jsx(j,{className:"text-right",children:a("dashboard.recent.columns.latency")}),e.jsx(j,{children:a("dashboard.recent.columns.status")})]})}),e.jsx(le,{children:s.map(n=>{const i=ae(n,a);return e.jsxs(F,{children:[e.jsx(y,{children:e.jsxs("div",{className:"flex flex-col",children:[e.jsx("span",{className:"text-xs font-medium",children:new Date(n.timestamp).toLocaleString()}),e.jsxs("span",{className:"text-[11px] text-muted-foreground",children:["#",n.id]})]})}),e.jsx(y,{children:e.jsx(k,{variant:"outline",className:"text-[11px]",children:n.endpoint==="anthropic"?a("logs.endpointAnthropic"):n.endpoint==="openai"?a("logs.endpointOpenAI"):n.endpoint})}),e.jsx(y,{children:e.jsxs("div",{className:"flex flex-col",children:[e.jsx("span",{className:"font-medium",children:n.provider}),e.jsx("span",{className:"text-[11px] text-muted-foreground",children:n.stream?"stream":"sync"})]})}),e.jsx(y,{children:e.jsxs("div",{className:"flex flex-col gap-1 text-xs",children:[e.jsxs("div",{className:"flex items-center gap-1 text-muted-foreground",children:[e.jsx("span",{children:n.client_model??a("dashboard.recent.routePlaceholder")}),e.jsx("span",{children:"->"}),e.jsx("span",{className:"font-medium text-foreground",children:n.model})]}),n.error?e.jsx("span",{className:"truncate text-destructive",children:n.error}):null]})}),e.jsx(y,{className:"text-right font-medium",children:R(n.latency_ms,a("common.units.ms"))}),e.jsx(y,{children:e.jsx(k,{variant:i.variant,className:"min-w-14 justify-center",children:i.label})})]},n.id)})})]})})})}function oe({className:s,compact:t,featured:a,icon:r,label:o,value:c,suffix:l,valueTestId:n}){return e.jsxs("div",{className:C("group flex flex-col justify-between rounded-[1.15rem] border border-white/70 bg-card/95 shadow-[0_18px_42px_-36px_rgba(15,23,42,0.24)] transition-all hover:-translate-y-0.5 hover:shadow-[0_24px_48px_-38px_rgba(59,130,246,0.2)] dark:border-white/10 dark:bg-slate-950/90 dark:shadow-[0_18px_42px_-36px_rgba(0,0,0,0.72)] dark:hover:shadow-[0_24px_48px_-38px_rgba(59,130,246,0.28)]",a?"bg-[linear-gradient(135deg,hsl(var(--primary)/0.1),rgba(255,255,255,0.95)_46%,rgba(236,253,245,0.74))] p-5 dark:!bg-none dark:!bg-slate-950/90":t?"p-3.5":"p-5",s),children:[e.jsxs("div",{className:"flex items-center gap-2 text-xs text-muted-foreground",children:[e.jsx("span",{className:C("inline-flex h-7 w-7 items-center justify-center rounded-lg bg-primary/10 text-primary",t&&"h-6 w-6 rounded-md"),children:r}),e.jsx("span",{children:o})]}),e.jsxs("p",{className:C("metric-number mt-3 font-semibold tracking-tight text-foreground",a?"text-3xl":t?"text-lg":"text-2xl"),"data-testid":n,children:[c,l?e.jsx("span",{className:"ml-1 text-sm font-normal text-muted-foreground",children:l}):null]})]})}function A({featured:s,label:t,value:a,hint:r}){return e.jsx(O,{className:s?"overflow-hidden bg-[linear-gradient(135deg,rgba(255,255,255,0.98),hsl(var(--primary)/0.08))] dark:!bg-none dark:!bg-card dark:border-white/10 dark:shadow-[0_18px_42px_-36px_rgba(0,0,0,0.72)]":void 0,children:e.jsxs($,{className:C("pt-4",s&&"pb-4"),children:[e.jsx("p",{className:"text-[11px] font-medium uppercase tracking-wider text-muted-foreground",children:t}),e.jsx("p",{className:C("mt-2 line-clamp-1 font-semibold text-foreground",s?"metric-number text-2xl tracking-tight":"text-base"),children:a}),e.jsx("p",{className:"mt-1 text-xs text-muted-foreground",children:r})]})})}function B({description:s,empty:t,emptyText:a,loading:r,option:o,title:c}){const{t:l}=w();return e.jsx(O,{children:e.jsxs($,{className:"space-y-4 pt-5",children:[e.jsxs("div",{children:[e.jsx("p",{className:"text-sm font-semibold",children:c}),e.jsx("p",{className:"mt-0.5 text-xs text-muted-foreground/70",children:s})]}),r?e.jsx(V,{compact:!0,className:"min-h-[220px]",label:l("common.loadingShort")}):t?e.jsx(G,{compact:!0,className:"min-h-[188px] rounded-[1rem] border border-dashed border-border/45 bg-secondary/35",icon:e.jsx(H,{className:"h-5 w-5","aria-hidden":"true"}),title:a??l("dashboard.charts.empty"),description:s}):e.jsx("div",{className:"pt-2",children:e.jsx(Je,{echarts:st,option:o,className:"h-[40vh] min-h-[280px] max-h-[420px]",notMerge:!0,lazyUpdate:!0})})]})})}function ht(){var K,W,Y,Z,J,X,ee,te;const{t:s}=w(),{pushToast:t}=Ge(),[a,r]=ze(He.dashboard.endpointFilter,"all"),[o,c]=u.useState(!1),l=a==="all"?void 0:a,n=L(I.customEndpoints.all(),{url:"/api/custom-endpoints",method:"GET"},{refetchInterval:z,refetchIntervalInBackground:!0}),i=L(I.stats.overview(a),{url:"/api/stats/overview",method:"GET",params:l?{endpoint:l}:void 0},{refetchInterval:M,refetchIntervalInBackground:!0}),m=L(I.stats.daily(14,a),{url:"/api/stats/daily",method:"GET",params:{days:14,...l?{endpoint:l}:{}}},{refetchInterval:z,refetchIntervalInBackground:!0}),v=L(I.stats.model(7,6,a),{url:"/api/stats/model",method:"GET",params:{days:7,limit:6,...l?{endpoint:l}:{}}},{refetchInterval:z,refetchIntervalInBackground:!0}),g=L(I.status.byEndpoint(a),{url:"/api/status",method:"GET",params:l?{endpoint:l}:void 0},{refetchInterval:M,refetchIntervalInBackground:!0}),x=L(I.db.info(),{url:"/api/db/info",method:"GET"},{refetchInterval:M,refetchIntervalInBackground:!0}),N=L(I.logs.recent(a),{url:"/api/logs",method:"GET",params:{limit:5,...l?{endpoint:l}:{}}},{refetchInterval:M,refetchIntervalInBackground:!0});u.useEffect(()=>{i.isError&&i.error&&t({title:s("dashboard.toast.overviewError"),description:i.error.message,variant:"error"})},[i.error,i.isError,t,s]),u.useEffect(()=>{m.isError&&m.error&&t({title:s("dashboard.toast.dailyError"),description:m.error.message,variant:"error"})},[m.error,m.isError,t,s]),u.useEffect(()=>{v.isError&&v.error&&t({title:s("dashboard.toast.modelError"),description:v.error.message,variant:"error"})},[v.error,v.isError,t,s]),u.useEffect(()=>{g.isError&&g.error&&t({title:s("dashboard.toast.statusError"),description:g.error.message,variant:"error"})},[g.error,g.isError,t,s]),u.useEffect(()=>{x.isError&&x.error&&t({title:s("dashboard.toast.dbError"),description:x.error.message,variant:"error"})},[x.error,x.isError,t,s]),u.useEffect(()=>{N.isError&&N.error&&t({title:s("dashboard.toast.recentError"),description:N.error.message,variant:"error"})},[N.error,N.isError,t,s]);const me=u.useCallback(async()=>{await Promise.all([n.refetch(),i.refetch(),m.refetch(),v.refetch(),g.refetch(),x.refetch(),N.refetch()])},[n,x,m,N,v,i,g]),he=u.useCallback(async()=>{if(!o){c(!0);try{await Qe.post("/api/db/compact"),await x.refetch(),t({title:s("dashboard.toast.compactSuccess.title"),description:s("dashboard.toast.compactSuccess.desc"),variant:"success"})}catch(d){const h=Ue(d);t({title:s("dashboard.toast.compactError.title"),description:h.message,variant:"error"})}finally{c(!1)}}},[o,x,t,s]),pe=i.data,S=m.data??[],p=v.data??[],xe=g.data,E=x.data,ue=((K=N.data)==null?void 0:K.items)??[],ge=a==="all"?s("dashboard.filters.endpointAll"):a==="anthropic"?s("dashboard.filters.endpointAnthropic"):a==="openai"?s("dashboard.filters.endpointOpenAI"):((Z=(Y=(W=n.data)==null?void 0:W.endpoints)==null?void 0:Y.find(d=>d.id===a))==null?void 0:Z.label)||a,be=S.reduce((d,h)=>d+h.requestCount,0),fe=S.reduce((d,h)=>!d||h.requestCount>d.requestCount?h:d,null),je=p[0],ye=p.filter(d=>d.avgTtftMs!=null&&d.avgTtftMs>0).sort((d,h)=>(d.avgTtftMs??Number.POSITIVE_INFINITY)-(h.avgTtftMs??Number.POSITIVE_INFINITY))[0],ve=n.isFetching||i.isFetching||m.isFetching||v.isFetching||g.isFetching||x.isFetching||N.isFetching,Ne=i.isPending||g.isPending||x.isPending,Se=((J=i.error)==null?void 0:J.message)??((X=g.error)==null?void 0:X.message)??((ee=x.error)==null?void 0:ee.message)??null,Te=E?U(E.totalBytes??E.sizeBytes):"-",we=U(E==null?void 0:E.memoryRssBytes),Ee=u.useMemo(()=>{const d=S.map(f=>f.date),h=s("dashboard.charts.barRequests"),_=s("dashboard.charts.lineInput"),P=s("dashboard.charts.lineOutput"),b=s("dashboard.charts.lineCacheRead"),se=s("dashboard.charts.lineCacheCreation");return{tooltip:{trigger:"axis"},legend:{data:[h,_,P,b,se]},grid:{left:56,right:28,top:56,bottom:54},xAxis:{type:"category",data:d},yAxis:{type:"value"},series:[{name:h,type:"bar",data:S.map(f=>f.requestCount),itemStyle:{color:T.requests,borderRadius:[6,6,0,0]}},{name:_,type:"line",smooth:!0,data:S.map(f=>f.inputTokens),itemStyle:{color:T.input},lineStyle:{width:2}},{name:P,type:"line",smooth:!0,data:S.map(f=>f.outputTokens),itemStyle:{color:T.output},lineStyle:{width:2}},{name:b,type:"line",smooth:!0,data:S.map(f=>f.cacheReadTokens),itemStyle:{color:T.cacheRead},lineStyle:{width:2}},{name:se,type:"line",smooth:!0,data:S.map(f=>f.cacheCreationTokens),itemStyle:{color:T.cacheCreation},lineStyle:{width:2}}]}},[S,s]),Ie=u.useMemo(()=>{const d=p.map(b=>`${b.provider}/${b.model}`),h=s("dashboard.charts.barRequests"),_=s("dashboard.charts.lineInput"),P=s("dashboard.charts.lineOutput");return{tooltip:{trigger:"axis"},legend:{data:[h,_,P]},grid:{left:72,right:52,top:56,bottom:96},xAxis:{type:"category",data:d,axisLabel:{rotate:28}},yAxis:[{type:"value",name:h},{type:"value",name:s("dashboard.charts.axisTokens"),position:"right"}],series:[{name:h,type:"bar",data:p.map(b=>b.requests),itemStyle:{color:T.requests,borderRadius:[6,6,0,0]}},{name:_,type:"line",yAxisIndex:1,smooth:!0,data:p.map(b=>b.inputTokens??0),itemStyle:{color:T.input}},{name:P,type:"line",yAxisIndex:1,smooth:!0,data:p.map(b=>b.outputTokens??0),itemStyle:{color:T.output}}]}},[p,s]),Le=u.useMemo(()=>({tooltip:{trigger:"axis"},grid:{left:72,right:40,top:56,bottom:96},xAxis:{type:"category",data:p.map(d=>`${d.provider}/${d.model}`),axisLabel:{rotate:28}},yAxis:{type:"value",name:s("dashboard.charts.ttftAxis")},series:[{name:s("dashboard.charts.ttftLabel"),type:"bar",data:p.map(d=>d.avgTtftMs??0),itemStyle:{color:T.latency,borderRadius:[6,6,0,0]}}]}),[p,s]),ke=u.useMemo(()=>({tooltip:{trigger:"axis"},grid:{left:72,right:40,top:56,bottom:96},xAxis:{type:"category",data:p.map(d=>`${d.provider}/${d.model}`),axisLabel:{rotate:28}},yAxis:{type:"value",name:s("dashboard.charts.tpotAxis")},series:[{name:s("dashboard.charts.tpotLabel"),type:"bar",data:p.map(d=>d.avgTpotMs??0),itemStyle:{color:T.output,borderRadius:[6,6,0,0]}}]}),[p,s]);return{compacting:o,customEndpoints:((te=n.data)==null?void 0:te.endpoints)??[],daily:S,dailyOption:Ee,dailyPending:m.isPending,dbInfo:E,dbSizeDisplay:Te,endpointFilter:a,fastestTtftModel:ye,handleCompact:he,handleRefresh:me,bootstrapError:Se,isBootstrapping:Ne,isRefreshing:ve,latestLogsPending:N.isPending,memoryDisplay:we,modelRequestsOption:Ie,modelUsagePending:v.isPending,models:p,overview:pe,recentLogs:ue,selectedEndpointLabel:ge,setEndpointFilter:r,status:xe,topModel:je,totalRequestsInRange:be,busiestDay:fe,ttftOption:Le,tpotOption:ke}}function Pt(){var r,o;const{t:s}=w(),t=ht(),a=t.recentLogs.length===0||t.models.length===0;return e.jsxs("div",{className:"flex flex-col gap-6",children:[e.jsx($e,{info:e.jsxs("span",{className:"text-xs text-muted-foreground",children:[s("dashboard.filters.endpoint")," · ",t.selectedEndpointLabel]}),actions:e.jsxs(e.Fragment,{children:[e.jsxs(Ve,{value:t.endpointFilter,onValueChange:t.setEndpointFilter,children:[e.jsx(Ke,{className:"h-8 w-[168px]",children:e.jsx(We,{})}),e.jsxs(Ye,{children:[e.jsx(q,{value:"all",children:s("dashboard.filters.endpointAll")}),e.jsx(q,{value:"anthropic",children:s("dashboard.filters.endpointAnthropic")}),e.jsx(q,{value:"openai",children:s("dashboard.filters.endpointOpenAI")}),t.customEndpoints.map(c=>e.jsx(q,{value:c.id,children:c.label||c.id},c.id))]})]}),e.jsxs(D,{variant:"outline",size:"sm",onClick:()=>void t.handleRefresh(),disabled:t.isRefreshing,children:[e.jsx(Fe,{className:C("mr-2 h-4 w-4",t.isRefreshing&&"animate-spin"),"aria-hidden":"true"}),t.isRefreshing?s("common.actions.refreshing"):s("common.actions.refresh")]}),e.jsxs(D,{variant:"outline",size:"sm",onClick:()=>void t.handleCompact(),disabled:t.compacting,children:[e.jsx(ne,{className:"mr-2 h-4 w-4","aria-hidden":"true"}),t.compacting?s("dashboard.actions.compacting"):s("dashboard.actions.compact")]})]})}),t.isBootstrapping?e.jsx(rt,{}):t.bootstrapError?e.jsx(G,{icon:e.jsx(Oe,{className:"h-5 w-5","aria-hidden":"true"}),tone:"danger",title:s("common.status.error"),description:t.bootstrapError,action:e.jsx(D,{variant:"outline",onClick:()=>void t.handleRefresh(),children:s("common.actions.refresh")})}):e.jsxs(e.Fragment,{children:[e.jsx(ot,{selectedEndpointLabel:t.selectedEndpointLabel,status:t.status,todayRequests:((r=t.overview)==null?void 0:r.today.requests)??0}),a?e.jsx(dt,{endpointCount:t.customEndpoints.length,providerCount:((o=t.status)==null?void 0:o.providers)??0,selectedEndpointLabel:t.selectedEndpointLabel}):null,e.jsx(nt,{dbSizeDisplay:t.dbSizeDisplay,memoryDisplay:t.memoryDisplay,overview:t.overview,status:t.status}),e.jsx(it,{busiestDay:t.busiestDay,fastestTtftModel:t.fastestTtftModel,topModel:t.topModel,totalRequestsInRange:t.totalRequestsInRange}),e.jsx(lt,{dailyEmpty:!t.daily.length,dailyOption:t.dailyOption,dailyPending:t.dailyPending,models:t.models,modelRequestsOption:t.modelRequestsOption,modelUsagePending:t.modelUsagePending,ttftOption:t.ttftOption,tpotOption:t.tpotOption}),e.jsx(ct,{models:t.models,loading:t.modelUsagePending}),e.jsx(mt,{records:t.recentLogs,loading:t.latestLogsPending})]})]})}export{Pt as default};
@@ -1 +1 @@
1
- import{r,j as s,a7 as g}from"./vendor-DdPBfMMb.js";import{F as u,G as d,H as n,J as y,K as l,M as b,O as i}from"./radix-CtQBp6Ie.js";import{c as o}from"./global-D8DuA4wF.js";const k=u,N=y,c=r.forwardRef(({className:a,...e},t)=>s.jsx(i,{ref:t,className:o("fixed inset-0 z-50 bg-background/80 backdrop-blur-sm data-[state=open]:animate-in data-[state=closed]:animate-out data-[state=closed]:fade-out-0 data-[state=open]:fade-in-0",a),...e}));c.displayName=i.displayName;const p=r.forwardRef(({className:a,children:e,...t},x)=>s.jsxs(N,{children:[s.jsx(c,{}),s.jsxs(l,{ref:x,className:o("fixed left-[50%] top-[50%] z-50 flex max-h-[85vh] w-full max-w-lg translate-x-[-50%] translate-y-[-50%] flex-col gap-4 rounded-xl border border-border bg-background p-6 shadow-[var(--surface-shadow-lg)] duration-200 data-[state=open]:animate-in data-[state=closed]:animate-out data-[state=closed]:fade-out-0 data-[state=open]:fade-in-0 data-[state=closed]:zoom-out-95 data-[state=open]:zoom-in-95 data-[state=closed]:slide-out-to-left-1/2 data-[state=closed]:slide-out-to-top-[48%] data-[state=open]:slide-in-from-left-1/2 data-[state=open]:slide-in-from-top-[48%]",a),...t,children:[e,s.jsxs(b,{className:"absolute right-4 top-4 rounded-md p-1.5 text-muted-foreground opacity-70 ring-offset-background transition-opacity hover:opacity-100 focus:outline-none focus:ring-2 focus:ring-ring focus:ring-offset-2 disabled:pointer-events-none",children:[s.jsx(g,{className:"h-4 w-4"}),s.jsx("span",{className:"sr-only",children:"Close"})]})]})]}));p.displayName=l.displayName;const m=({className:a,...e})=>s.jsx("div",{className:o("flex shrink-0 flex-col space-y-1.5 text-center sm:text-left",a),...e});m.displayName="DialogHeader";const f=({className:a,...e})=>s.jsx("div",{className:o("flex shrink-0 flex-col-reverse sm:flex-row sm:justify-end sm:space-x-2",a),...e});f.displayName="DialogFooter";const j=r.forwardRef(({className:a,...e},t)=>s.jsx(d,{ref:t,className:o("text-lg font-semibold leading-none tracking-[-0.02em]",a),...e}));j.displayName=d.displayName;const D=r.forwardRef(({className:a,...e},t)=>s.jsx(n,{ref:t,className:o("text-sm leading-6 text-muted-foreground",a),...e}));D.displayName=n.displayName;function R({children:a,className:e}){return s.jsx(p,{className:o("gap-0 overflow-hidden p-0",e),children:a})}function A({children:a,className:e}){return s.jsx("div",{className:o("border-b border-border bg-secondary/40 px-6 py-5",e),children:s.jsx(m,{children:a})})}function C({children:a,className:e}){return s.jsx("div",{className:o("min-h-0 overflow-y-auto px-6 py-5",e),children:a})}function z({children:a,className:e}){return s.jsx(f,{className:o("border-t border-border bg-secondary/40 px-6 py-4",e),children:a})}export{R as A,k as D,A as a,j as b,D as c,C as d,z as e};
1
+ import{r,j as s,a7 as g}from"./vendor-DdPBfMMb.js";import{F as u,G as d,H as n,J as y,K as l,M as b,O as i}from"./radix-CtQBp6Ie.js";import{c as o}from"./global-CaQPIFGa.js";const k=u,N=y,c=r.forwardRef(({className:a,...e},t)=>s.jsx(i,{ref:t,className:o("fixed inset-0 z-50 bg-background/80 backdrop-blur-sm data-[state=open]:animate-in data-[state=closed]:animate-out data-[state=closed]:fade-out-0 data-[state=open]:fade-in-0",a),...e}));c.displayName=i.displayName;const p=r.forwardRef(({className:a,children:e,...t},x)=>s.jsxs(N,{children:[s.jsx(c,{}),s.jsxs(l,{ref:x,className:o("fixed left-[50%] top-[50%] z-50 flex max-h-[85vh] w-full max-w-lg translate-x-[-50%] translate-y-[-50%] flex-col gap-4 rounded-xl border border-border bg-background p-6 shadow-[var(--surface-shadow-lg)] duration-200 data-[state=open]:animate-in data-[state=closed]:animate-out data-[state=closed]:fade-out-0 data-[state=open]:fade-in-0 data-[state=closed]:zoom-out-95 data-[state=open]:zoom-in-95 data-[state=closed]:slide-out-to-left-1/2 data-[state=closed]:slide-out-to-top-[48%] data-[state=open]:slide-in-from-left-1/2 data-[state=open]:slide-in-from-top-[48%]",a),...t,children:[e,s.jsxs(b,{className:"absolute right-4 top-4 rounded-md p-1.5 text-muted-foreground opacity-70 ring-offset-background transition-opacity hover:opacity-100 focus:outline-none focus:ring-2 focus:ring-ring focus:ring-offset-2 disabled:pointer-events-none",children:[s.jsx(g,{className:"h-4 w-4"}),s.jsx("span",{className:"sr-only",children:"Close"})]})]})]}));p.displayName=l.displayName;const m=({className:a,...e})=>s.jsx("div",{className:o("flex shrink-0 flex-col space-y-1.5 text-center sm:text-left",a),...e});m.displayName="DialogHeader";const f=({className:a,...e})=>s.jsx("div",{className:o("flex shrink-0 flex-col-reverse sm:flex-row sm:justify-end sm:space-x-2",a),...e});f.displayName="DialogFooter";const j=r.forwardRef(({className:a,...e},t)=>s.jsx(d,{ref:t,className:o("text-lg font-semibold leading-none tracking-[-0.02em]",a),...e}));j.displayName=d.displayName;const D=r.forwardRef(({className:a,...e},t)=>s.jsx(n,{ref:t,className:o("text-sm leading-6 text-muted-foreground",a),...e}));D.displayName=n.displayName;function R({children:a,className:e}){return s.jsx(p,{className:o("gap-0 overflow-hidden p-0",e),children:a})}function A({children:a,className:e}){return s.jsx("div",{className:o("border-b border-border bg-secondary/40 px-6 py-5",e),children:s.jsx(m,{children:a})})}function C({children:a,className:e}){return s.jsx("div",{className:o("min-h-0 overflow-y-auto px-6 py-5",e),children:a})}function z({children:a,className:e}){return s.jsx(f,{className:o("border-t border-border bg-secondary/40 px-6 py-4",e),children:a})}export{R as A,k as D,A as a,j as b,D as c,C as d,z as e};
@@ -1 +1 @@
1
- import{r as p,j as e,ax as z,aA as F,U as k,aB as R,aC as I,aD as B,a0 as D,aE as V}from"./vendor-DdPBfMMb.js";import{L as q}from"./router-D2Fb4U0L.js";import{P as K}from"./PageToolbar-BxRZF-QJ.js";import{P as Q}from"./PageSection-DVs3faWw.js";import{P as U,a as E}from"./PageState-Dvjip2P-.js";import{u as G}from"./useApiQuery-4gJC8RZB.js";import{c as T}from"./global-D8DuA4wF.js";import{u as J,B as c}from"./app-DkubSF6m.js";import{B as u,q as O}from"./queryKeys-BpeJfcg0.js";import{C as N,a as y}from"./card-Bx5Pg_wP.js";import{I as H}from"./input-b5NRkUKN.js";import{S as W,a as X,b as Y,c as Z,d as g}from"./select-B5oPLG9G.js";import{u as _}from"./i18n-C8tBby0x.js";import"./query-QCek5MsK.js";import"./radix-CtQBp6Ie.js";function ee(s){const i=Date.now()-s,n=Math.abs(i),l=60*1e3,m=60*l,h=24*m;if(n<l){const o=Math.max(Math.round(n/1e3),1);return i>=0?`${o}s ago`:`in ${o}s`}if(n<m){const o=Math.round(n/l);return i>=0?`${o}m ago`:`in ${o}m`}if(n<h){const o=Math.round(n/m);return i>=0?`${o}h ago`:`in ${o}h`}const r=Math.round(n/h);return i>=0?`${r}d ago`:`in ${r}d`}function se(s){return new Date(s).toLocaleString()}const te={info:"secondary",warn:"outline",error:"destructive"};function je(){var C,S,L;const{t:s}=_(),{pushToast:a}=J(),[i,n]=p.useState(null),[l,m]=p.useState({level:"",type:""}),h=p.useMemo(()=>({limit:50,cursor:i??void 0,level:l.level||void 0,type:l.type.trim()||void 0}),[i,l.level,l.type]),r=G(O.events.list(h),{url:"/api/events",method:"GET",params:h});p.useEffect(()=>{r.isError&&r.error&&a({title:s("events.toast.loadFailure",{message:r.error.message}),variant:"error"})},[r.error,r.isError,a,s]);const o=()=>{n(null),m({level:"",type:""})},d=((C=r.data)==null?void 0:C.events)??[],b=((S=r.data)==null?void 0:S.nextCursor)??null,A=r.isLoading,v=r.isFetching&&!r.isLoading,x=p.useMemo(()=>{const t=[];return l.level&&t.push(s(`events.levels.${l.level}`)),l.type.trim()&&t.push(l.type.trim()),t},[l.level,l.type,s]),P=d.filter(t=>t.level==="info").length,M=d.filter(t=>t.level==="warn").length,$=d.filter(t=>t.level==="error").length;return e.jsxs("div",{className:"flex flex-col gap-5",children:[e.jsx(K,{info:d.length>0?e.jsxs("span",{className:"rounded-full bg-secondary px-2.5 py-1 text-xs text-muted-foreground",children:[d.length," events"]}):null,status:e.jsx("span",{className:"text-xs text-muted-foreground",children:s(i?"events.actions.older":"events.actions.newest")}),actions:e.jsxs(c,{variant:"outline",size:"sm",onClick:()=>void r.refetch(),disabled:v,children:[e.jsx(z,{className:T("mr-2 h-4 w-4",v&&"animate-spin"),"aria-hidden":"true"}),s(v?"common.actions.refreshing":"common.actions.refresh")]})}),e.jsxs("div",{className:"grid gap-3 sm:grid-cols-3",children:[e.jsx(w,{icon:e.jsx(F,{className:"h-4 w-4","aria-hidden":"true"}),title:s("events.levels.info"),value:P.toLocaleString(),tone:"emerald"}),e.jsx(w,{icon:e.jsx(k,{className:"h-4 w-4","aria-hidden":"true"}),title:s("events.levels.warn"),value:M.toLocaleString(),tone:"amber"}),e.jsx(w,{icon:e.jsx(R,{className:"h-4 w-4","aria-hidden":"true"}),title:s("events.levels.error"),value:$.toLocaleString(),tone:"rose"})]}),e.jsx(N,{"data-testid":"events-filters-card",className:"overflow-hidden rounded-[1.25rem] border border-white/70 bg-card/95 shadow-[0_20px_50px_-42px_rgba(15,23,42,0.24)]",children:e.jsx(y,{className:"space-y-3 p-4",children:e.jsxs("div",{className:"flex flex-col gap-3",children:[e.jsxs("div",{className:"flex flex-col gap-3 lg:flex-row lg:items-center lg:justify-between",children:[e.jsxs("div",{className:"space-y-1",children:[e.jsxs("div",{className:"flex items-center gap-2 text-sm font-semibold text-foreground",children:[e.jsx(I,{className:"h-4 w-4 text-primary","aria-hidden":"true"}),s("events.filters.title"),e.jsx(u,{variant:"outline",children:d.length})]}),e.jsx("p",{className:"text-xs text-muted-foreground",children:s("events.description")})]}),e.jsxs("div",{className:"grid gap-2 sm:flex sm:flex-wrap sm:items-center",children:[x.length>0?e.jsx(c,{variant:"ghost",size:"sm",onClick:o,className:"h-8 rounded-full px-3 text-xs sm:w-auto",children:s("common.actions.reset")}):null,e.jsxs(c,{variant:"outline",size:"sm",disabled:!i,onClick:()=>n(null),className:"h-8 rounded-full px-3 text-xs sm:w-auto",children:[e.jsx(B,{className:"mr-1 h-4 w-4","aria-hidden":"true"}),s("events.actions.newest")]}),e.jsxs(c,{variant:"outline",size:"sm",disabled:!b,onClick:()=>n(b),className:"h-8 rounded-full px-3 text-xs sm:w-auto",children:[s("events.actions.older"),e.jsx(D,{className:"ml-1 h-4 w-4","aria-hidden":"true"})]})]})]}),e.jsxs("div",{className:"flex flex-col gap-2 md:flex-row md:flex-wrap md:items-center",children:[e.jsxs(W,{value:l.level,onValueChange:t=>{n(null),m(j=>({...j,level:t==="all"?"":t}))},children:[e.jsx(X,{className:"w-full md:w-[160px]",children:e.jsx(Y,{placeholder:s("events.filters.allLevels")})}),e.jsxs(Z,{children:[e.jsx(g,{value:"all",children:s("events.filters.allLevels")}),e.jsx(g,{value:"info",children:s("events.levels.info")}),e.jsx(g,{value:"warn",children:s("events.levels.warn")}),e.jsx(g,{value:"error",children:s("events.levels.error")})]})]}),e.jsx(H,{className:"w-full md:w-[220px]",placeholder:s("events.filters.typePlaceholder"),value:l.type,onChange:t=>{n(null),m(j=>({...j,type:t.target.value}))}}),e.jsx(c,{variant:"ghost",size:"sm",onClick:o,disabled:x.length===0,className:"h-8 rounded-full px-3 text-xs md:w-auto",children:s("common.actions.reset")})]}),x.length>0?e.jsx("div",{className:"flex flex-wrap gap-2",children:x.map(t=>e.jsx(u,{variant:"secondary",children:t},t))}):null]})})}),e.jsx(Q,{title:s("events.title"),description:s(i?"events.actions.older":"events.actions.newest"),children:A?e.jsx(U,{label:s("common.loading")}):r.isError?e.jsx(E,{icon:e.jsx(k,{className:"h-5 w-5","aria-hidden":"true"}),tone:"danger",title:s("common.status.error"),description:s("events.toast.loadFailure",{message:((L=r.error)==null?void 0:L.message)??s("common.unknownError")}),action:e.jsx(c,{variant:"outline",size:"sm",onClick:()=>void r.refetch(),children:s("common.actions.refresh")})}):d.length===0?e.jsx(E,{icon:e.jsx(V,{className:"h-5 w-5","aria-hidden":"true"}),tone:"primary",title:x.length>0?s("events.empty.filteredTitle"):s("events.empty.title"),description:x.length>0?s("events.empty.filteredSubtitle"):s("events.empty.subtitle"),action:e.jsxs("div",{className:"flex flex-wrap items-center justify-center gap-2",children:[x.length>0?e.jsx(c,{variant:"outline",size:"sm",onClick:o,children:s("common.actions.reset")}):null,e.jsx(c,{asChild:!0,variant:"ghost",size:"sm",children:e.jsx(q,{to:"/logs",children:s("events.empty.actions.logs")})})]})}):e.jsx("div",{className:"grid gap-3",children:d.map(t=>e.jsx(re,{event:t},t.id))})})]})}function w({icon:s,title:a,tone:i,value:n}){return e.jsx(N,{className:"rounded-[1.15rem] border border-white/70 bg-card/95 shadow-[0_18px_42px_-38px_rgba(15,23,42,0.22)]",children:e.jsxs(y,{className:"flex items-center justify-between gap-3 p-4",children:[e.jsxs("div",{children:[e.jsx("p",{className:"text-xs font-semibold uppercase tracking-wider text-muted-foreground",children:a}),e.jsx("p",{className:"metric-number mt-1 text-[1.85rem] font-bold tracking-tight text-foreground",children:n})]}),e.jsx("div",{className:"flex h-10 w-10 items-center justify-center rounded-xl bg-secondary text-muted-foreground",children:s})]})})}function re({event:s}){const{t:a}=_(),i=s.level==="error"?"border-l-destructive":s.level==="warn"?"border-l-amber-500":"border-l-emerald-500";return e.jsx(N,{className:T("overflow-hidden rounded-[1.05rem] border border-white/70 border-l-2 bg-card/96 shadow-[0_18px_38px_-34px_rgba(15,23,42,0.2)]",i),children:e.jsxs(y,{className:"space-y-3 p-4",children:[e.jsxs("div",{className:"flex flex-col gap-2 lg:flex-row lg:items-start lg:justify-between",children:[e.jsxs("div",{className:"min-w-0 space-y-1.5",children:[e.jsxs("div",{className:"flex flex-wrap items-center gap-2",children:[e.jsx(u,{variant:te[s.level]||"secondary",className:"rounded-full text-[10px]",children:a(`events.levels.${s.level}`)}),e.jsxs(u,{variant:"outline",className:"rounded-full text-[10px]",children:["#",s.id]}),s.mode?e.jsx(u,{variant:"secondary",className:"rounded-full text-[10px]",children:s.mode}):null,s.endpoint?e.jsx(u,{variant:"outline",className:"rounded-full text-[10px]",children:s.endpoint}):null]}),e.jsxs("div",{className:"min-w-0",children:[e.jsx("h3",{className:"truncate text-[15px] font-semibold tracking-[-0.01em]",children:s.title||a("events.defaultTitle")}),e.jsx("p",{className:"mt-1 line-clamp-2 text-sm leading-5 text-muted-foreground",children:s.message||a("events.defaultMessage")})]})]}),e.jsxs("div",{className:"shrink-0 space-y-0.5 text-xs text-muted-foreground lg:text-right",children:[e.jsx("p",{children:se(s.createdAt)}),e.jsx("p",{children:ee(s.createdAt)})]})]}),e.jsxs("div",{className:"flex flex-wrap gap-2 text-sm",children:[e.jsx(f,{label:"Type",value:s.type}),e.jsx(f,{label:"Source",value:s.source}),e.jsx(f,{label:"IP",value:s.ipAddress}),e.jsx(f,{label:"API Key",value:s.apiKeyName}),e.jsx(f,{label:"User Agent",value:s.userAgent})]}),s.details?e.jsxs("details",{className:"rounded-[0.9rem] bg-secondary/50 px-3 py-2 text-sm",children:[e.jsx("summary",{className:"cursor-pointer text-xs font-medium text-primary",children:a("events.details")}),e.jsx("pre",{className:"mt-2.5 overflow-x-auto rounded-lg bg-secondary p-3 text-xs leading-6",children:JSON.stringify(s.details,null,2)})]}):null]})})}function f({label:s,value:a}){return a?e.jsxs("div",{className:"inline-flex max-w-full items-center gap-1.5 rounded-full border border-border/60 bg-secondary/55 px-2.5 py-1 text-[11px] text-muted-foreground",children:[e.jsxs("span",{className:"font-medium",children:[s,":"]}),e.jsx("span",{className:"truncate text-foreground",title:a,children:a})]}):null}export{je as default};
1
+ import{r as p,j as e,ax as z,aA as F,U as k,aB as R,aC as I,aD as B,a0 as D,aE as V}from"./vendor-DdPBfMMb.js";import{L as q}from"./router-D2Fb4U0L.js";import{P as K}from"./PageToolbar-BBTEUrko.js";import{P as Q}from"./PageSection-uD1ZrEC_.js";import{P as U,a as E}from"./PageState-Cq7xpTfp.js";import{u as G}from"./useApiQuery-nMqbFkID.js";import{c as T}from"./global-CaQPIFGa.js";import{u as J,B as c}from"./app-BBdow7GJ.js";import{B as u,q as O}from"./queryKeys-BiuXKawV.js";import{C as N,a as y}from"./card-Do7RepdY.js";import{I as H}from"./input-E9i52oYD.js";import{S as W,a as X,b as Y,c as Z,d as g}from"./select-CohvZ6L7.js";import{u as _}from"./i18n-C8tBby0x.js";import"./query-QCek5MsK.js";import"./radix-CtQBp6Ie.js";function ee(s){const i=Date.now()-s,n=Math.abs(i),l=60*1e3,m=60*l,h=24*m;if(n<l){const o=Math.max(Math.round(n/1e3),1);return i>=0?`${o}s ago`:`in ${o}s`}if(n<m){const o=Math.round(n/l);return i>=0?`${o}m ago`:`in ${o}m`}if(n<h){const o=Math.round(n/m);return i>=0?`${o}h ago`:`in ${o}h`}const r=Math.round(n/h);return i>=0?`${r}d ago`:`in ${r}d`}function se(s){return new Date(s).toLocaleString()}const te={info:"secondary",warn:"outline",error:"destructive"};function je(){var C,S,L;const{t:s}=_(),{pushToast:a}=J(),[i,n]=p.useState(null),[l,m]=p.useState({level:"",type:""}),h=p.useMemo(()=>({limit:50,cursor:i??void 0,level:l.level||void 0,type:l.type.trim()||void 0}),[i,l.level,l.type]),r=G(O.events.list(h),{url:"/api/events",method:"GET",params:h});p.useEffect(()=>{r.isError&&r.error&&a({title:s("events.toast.loadFailure",{message:r.error.message}),variant:"error"})},[r.error,r.isError,a,s]);const o=()=>{n(null),m({level:"",type:""})},d=((C=r.data)==null?void 0:C.events)??[],b=((S=r.data)==null?void 0:S.nextCursor)??null,A=r.isLoading,v=r.isFetching&&!r.isLoading,x=p.useMemo(()=>{const t=[];return l.level&&t.push(s(`events.levels.${l.level}`)),l.type.trim()&&t.push(l.type.trim()),t},[l.level,l.type,s]),P=d.filter(t=>t.level==="info").length,M=d.filter(t=>t.level==="warn").length,$=d.filter(t=>t.level==="error").length;return e.jsxs("div",{className:"flex flex-col gap-5",children:[e.jsx(K,{info:d.length>0?e.jsxs("span",{className:"rounded-full bg-secondary px-2.5 py-1 text-xs text-muted-foreground",children:[d.length," events"]}):null,status:e.jsx("span",{className:"text-xs text-muted-foreground",children:s(i?"events.actions.older":"events.actions.newest")}),actions:e.jsxs(c,{variant:"outline",size:"sm",onClick:()=>void r.refetch(),disabled:v,children:[e.jsx(z,{className:T("mr-2 h-4 w-4",v&&"animate-spin"),"aria-hidden":"true"}),s(v?"common.actions.refreshing":"common.actions.refresh")]})}),e.jsxs("div",{className:"grid gap-3 sm:grid-cols-3",children:[e.jsx(w,{icon:e.jsx(F,{className:"h-4 w-4","aria-hidden":"true"}),title:s("events.levels.info"),value:P.toLocaleString(),tone:"emerald"}),e.jsx(w,{icon:e.jsx(k,{className:"h-4 w-4","aria-hidden":"true"}),title:s("events.levels.warn"),value:M.toLocaleString(),tone:"amber"}),e.jsx(w,{icon:e.jsx(R,{className:"h-4 w-4","aria-hidden":"true"}),title:s("events.levels.error"),value:$.toLocaleString(),tone:"rose"})]}),e.jsx(N,{"data-testid":"events-filters-card",className:"overflow-hidden rounded-[1.25rem] border border-white/70 bg-card/95 shadow-[0_20px_50px_-42px_rgba(15,23,42,0.24)]",children:e.jsx(y,{className:"space-y-3 p-4",children:e.jsxs("div",{className:"flex flex-col gap-3",children:[e.jsxs("div",{className:"flex flex-col gap-3 lg:flex-row lg:items-center lg:justify-between",children:[e.jsxs("div",{className:"space-y-1",children:[e.jsxs("div",{className:"flex items-center gap-2 text-sm font-semibold text-foreground",children:[e.jsx(I,{className:"h-4 w-4 text-primary","aria-hidden":"true"}),s("events.filters.title"),e.jsx(u,{variant:"outline",children:d.length})]}),e.jsx("p",{className:"text-xs text-muted-foreground",children:s("events.description")})]}),e.jsxs("div",{className:"grid gap-2 sm:flex sm:flex-wrap sm:items-center",children:[x.length>0?e.jsx(c,{variant:"ghost",size:"sm",onClick:o,className:"h-8 rounded-full px-3 text-xs sm:w-auto",children:s("common.actions.reset")}):null,e.jsxs(c,{variant:"outline",size:"sm",disabled:!i,onClick:()=>n(null),className:"h-8 rounded-full px-3 text-xs sm:w-auto",children:[e.jsx(B,{className:"mr-1 h-4 w-4","aria-hidden":"true"}),s("events.actions.newest")]}),e.jsxs(c,{variant:"outline",size:"sm",disabled:!b,onClick:()=>n(b),className:"h-8 rounded-full px-3 text-xs sm:w-auto",children:[s("events.actions.older"),e.jsx(D,{className:"ml-1 h-4 w-4","aria-hidden":"true"})]})]})]}),e.jsxs("div",{className:"flex flex-col gap-2 md:flex-row md:flex-wrap md:items-center",children:[e.jsxs(W,{value:l.level,onValueChange:t=>{n(null),m(j=>({...j,level:t==="all"?"":t}))},children:[e.jsx(X,{className:"w-full md:w-[160px]",children:e.jsx(Y,{placeholder:s("events.filters.allLevels")})}),e.jsxs(Z,{children:[e.jsx(g,{value:"all",children:s("events.filters.allLevels")}),e.jsx(g,{value:"info",children:s("events.levels.info")}),e.jsx(g,{value:"warn",children:s("events.levels.warn")}),e.jsx(g,{value:"error",children:s("events.levels.error")})]})]}),e.jsx(H,{className:"w-full md:w-[220px]",placeholder:s("events.filters.typePlaceholder"),value:l.type,onChange:t=>{n(null),m(j=>({...j,type:t.target.value}))}}),e.jsx(c,{variant:"ghost",size:"sm",onClick:o,disabled:x.length===0,className:"h-8 rounded-full px-3 text-xs md:w-auto",children:s("common.actions.reset")})]}),x.length>0?e.jsx("div",{className:"flex flex-wrap gap-2",children:x.map(t=>e.jsx(u,{variant:"secondary",children:t},t))}):null]})})}),e.jsx(Q,{title:s("events.title"),description:s(i?"events.actions.older":"events.actions.newest"),children:A?e.jsx(U,{label:s("common.loading")}):r.isError?e.jsx(E,{icon:e.jsx(k,{className:"h-5 w-5","aria-hidden":"true"}),tone:"danger",title:s("common.status.error"),description:s("events.toast.loadFailure",{message:((L=r.error)==null?void 0:L.message)??s("common.unknownError")}),action:e.jsx(c,{variant:"outline",size:"sm",onClick:()=>void r.refetch(),children:s("common.actions.refresh")})}):d.length===0?e.jsx(E,{icon:e.jsx(V,{className:"h-5 w-5","aria-hidden":"true"}),tone:"primary",title:x.length>0?s("events.empty.filteredTitle"):s("events.empty.title"),description:x.length>0?s("events.empty.filteredSubtitle"):s("events.empty.subtitle"),action:e.jsxs("div",{className:"flex flex-wrap items-center justify-center gap-2",children:[x.length>0?e.jsx(c,{variant:"outline",size:"sm",onClick:o,children:s("common.actions.reset")}):null,e.jsx(c,{asChild:!0,variant:"ghost",size:"sm",children:e.jsx(q,{to:"/logs",children:s("events.empty.actions.logs")})})]})}):e.jsx("div",{className:"grid gap-3",children:d.map(t=>e.jsx(re,{event:t},t.id))})})]})}function w({icon:s,title:a,tone:i,value:n}){return e.jsx(N,{className:"rounded-[1.15rem] border border-white/70 bg-card/95 shadow-[0_18px_42px_-38px_rgba(15,23,42,0.22)]",children:e.jsxs(y,{className:"flex items-center justify-between gap-3 p-4",children:[e.jsxs("div",{children:[e.jsx("p",{className:"text-xs font-semibold uppercase tracking-wider text-muted-foreground",children:a}),e.jsx("p",{className:"metric-number mt-1 text-[1.85rem] font-bold tracking-tight text-foreground",children:n})]}),e.jsx("div",{className:"flex h-10 w-10 items-center justify-center rounded-xl bg-secondary text-muted-foreground",children:s})]})})}function re({event:s}){const{t:a}=_(),i=s.level==="error"?"border-l-destructive":s.level==="warn"?"border-l-amber-500":"border-l-emerald-500";return e.jsx(N,{className:T("overflow-hidden rounded-[1.05rem] border border-white/70 border-l-2 bg-card/96 shadow-[0_18px_38px_-34px_rgba(15,23,42,0.2)]",i),children:e.jsxs(y,{className:"space-y-3 p-4",children:[e.jsxs("div",{className:"flex flex-col gap-2 lg:flex-row lg:items-start lg:justify-between",children:[e.jsxs("div",{className:"min-w-0 space-y-1.5",children:[e.jsxs("div",{className:"flex flex-wrap items-center gap-2",children:[e.jsx(u,{variant:te[s.level]||"secondary",className:"rounded-full text-[10px]",children:a(`events.levels.${s.level}`)}),e.jsxs(u,{variant:"outline",className:"rounded-full text-[10px]",children:["#",s.id]}),s.mode?e.jsx(u,{variant:"secondary",className:"rounded-full text-[10px]",children:s.mode}):null,s.endpoint?e.jsx(u,{variant:"outline",className:"rounded-full text-[10px]",children:s.endpoint}):null]}),e.jsxs("div",{className:"min-w-0",children:[e.jsx("h3",{className:"truncate text-[15px] font-semibold tracking-[-0.01em]",children:s.title||a("events.defaultTitle")}),e.jsx("p",{className:"mt-1 line-clamp-2 text-sm leading-5 text-muted-foreground",children:s.message||a("events.defaultMessage")})]})]}),e.jsxs("div",{className:"shrink-0 space-y-0.5 text-xs text-muted-foreground lg:text-right",children:[e.jsx("p",{children:se(s.createdAt)}),e.jsx("p",{children:ee(s.createdAt)})]})]}),e.jsxs("div",{className:"flex flex-wrap gap-2 text-sm",children:[e.jsx(f,{label:"Type",value:s.type}),e.jsx(f,{label:"Source",value:s.source}),e.jsx(f,{label:"IP",value:s.ipAddress}),e.jsx(f,{label:"API Key",value:s.apiKeyName}),e.jsx(f,{label:"User Agent",value:s.userAgent})]}),s.details?e.jsxs("details",{className:"rounded-[0.9rem] bg-secondary/50 px-3 py-2 text-sm",children:[e.jsx("summary",{className:"cursor-pointer text-xs font-medium text-primary",children:a("events.details")}),e.jsx("pre",{className:"mt-2.5 overflow-x-auto rounded-lg bg-secondary p-3 text-xs leading-6",children:JSON.stringify(s.details,null,2)})]}):null]})})}function f({label:s,value:a}){return a?e.jsxs("div",{className:"inline-flex max-w-full items-center gap-1.5 rounded-full border border-border/60 bg-secondary/55 px-2.5 py-1 text-[11px] text-muted-foreground",children:[e.jsxs("span",{className:"font-medium",children:[s,":"]}),e.jsx("span",{className:"truncate text-foreground",title:a,children:a})]}):null}export{je as default};
@@ -1,4 +1,4 @@
1
- import{r as u,j as e}from"./vendor-DdPBfMMb.js";import{P as f}from"./PageToolbar-BxRZF-QJ.js";import{P as o}from"./PageSection-DVs3faWw.js";import{c as j}from"./clipboard-CALi6bTW.js";import{c as x}from"./global-D8DuA4wF.js";import{B as b}from"./app-DkubSF6m.js";import{u as h}from"./i18n-C8tBby0x.js";import"./query-QCek5MsK.js";import"./router-D2Fb4U0L.js";import"./radix-CtQBp6Ie.js";function P(){const{t}=h(),s=u.useMemo(()=>[{id:"tour",title:t("help.sections.consoleTour.title"),items:t("help.sections.consoleTour.items",{returnObjects:!0})},{id:"configuration",title:t("help.sections.configuration.title"),items:t("help.sections.configuration.items",{returnObjects:!0})},{id:"claude",title:t("help.sections.claudeCodeConfig.title"),items:t("help.sections.claudeCodeConfig.items",{returnObjects:!0})},{id:"codex",title:t("help.sections.codexConfig.title"),items:t("help.sections.codexConfig.items",{returnObjects:!0})},{id:"usage",title:t("help.sections.usage.title"),items:t("help.sections.usage.items",{returnObjects:!0})},{id:"tips",title:t("help.sections.tips.title"),items:t("help.sections.tips.items",{returnObjects:!0})}],[t]),i=t("help.faq.items",{returnObjects:!0}),l=u.useMemo(()=>[...s.map(n=>({id:n.id,title:n.title})),{id:"faq",title:t("help.faq.title")}],[s,t]);return e.jsxs("div",{className:"space-y-4",children:[e.jsx(f,{info:e.jsx("span",{className:"rounded-full bg-secondary px-2.5 py-1 text-xs text-muted-foreground",children:t("help.meta.guides",{count:s.length})})}),e.jsxs("div",{className:"rounded-lg border border-border/60 bg-card/80 px-4 py-3 text-sm text-muted-foreground",children:[e.jsx("p",{className:"font-medium text-foreground",children:t("help.note")}),e.jsx("p",{className:"mt-1 text-xs leading-5",children:t("help.helper")})]}),e.jsxs("div",{className:"grid gap-5 xl:grid-cols-[208px_minmax(0,1fr)] xl:items-start",children:[e.jsx("aside",{className:"hidden xl:sticky xl:top-4 xl:block",children:e.jsxs("nav",{"aria-label":t("help.meta.tocTitle"),className:"rounded-lg border border-border/60 bg-card/70 p-3",children:[e.jsx("p",{className:"mb-2 px-1 text-[11px] font-semibold uppercase tracking-wide text-muted-foreground",children:t("help.meta.tocTitle")}),e.jsx("ol",{className:"space-y-0.5 text-sm",children:l.map(n=>e.jsx("li",{children:e.jsx("a",{href:`#help-${n.id}`,className:"block truncate rounded-md px-2 py-1.5 text-muted-foreground transition hover:bg-accent hover:text-foreground",children:n.title})},n.id))})]})}),e.jsxs("div",{className:"min-w-0 space-y-5",children:[e.jsx("div",{id:"help-tour",children:e.jsx(o,{title:s[0].title,children:e.jsx(c,{items:s[0].items,compact:!0})})}),e.jsx("div",{id:"help-configuration",children:e.jsx(o,{title:s[1].title,children:e.jsx(c,{items:s[1].items})})}),e.jsxs("div",{className:"grid gap-5 lg:grid-cols-2",children:[e.jsx("div",{id:"help-claude",children:e.jsx(o,{title:s[2].title,description:t("help.meta.claudeWorkflow"),children:e.jsx(c,{items:s[2].items})})}),e.jsx("div",{id:"help-codex",children:e.jsx(o,{title:s[3].title,description:t("help.meta.codexWorkflow"),children:e.jsx(c,{items:s[3].items})})})]}),e.jsx("div",{id:"help-usage",children:e.jsx(o,{title:s[4].title,children:e.jsx(c,{items:s[4].items})})}),e.jsx("div",{id:"help-tips",children:e.jsx(o,{title:s[5].title,children:e.jsx(c,{items:s[5].items})})}),e.jsx("div",{id:"help-faq",children:e.jsx(o,{title:t("help.faq.title"),children:e.jsx(y,{items:i})})})]})]})]})}function c({items:t,compact:s=!1}){return e.jsx("ol",{className:x("flex flex-col",s?"gap-2":"gap-2.5"),children:t.map((i,l)=>e.jsxs("li",{className:x("flex gap-3 rounded-lg border border-border/50 bg-card/80",s?"p-3":"p-3.5"),children:[e.jsx("span",{className:x("flex shrink-0 items-center justify-center rounded-md bg-primary text-xs font-semibold text-primary-foreground",s?"h-6 w-6 text-[11px]":"h-7 w-7"),children:l+1}),e.jsx("div",{className:"min-w-0 flex-1 text-sm text-muted-foreground",children:e.jsx(g,{content:i})})]},`${l}-${i}`))})}function g({content:t}){const{t:s}=h(),i=t.split("```");return e.jsx("div",{className:"space-y-3",children:i.map((l,n)=>{if(!l.trim())return null;if(n%2===1){const[a,...m]=l.split(`
1
+ import{r as u,j as e}from"./vendor-DdPBfMMb.js";import{P as f}from"./PageToolbar-BBTEUrko.js";import{P as o}from"./PageSection-uD1ZrEC_.js";import{c as j}from"./clipboard-CALi6bTW.js";import{c as x}from"./global-CaQPIFGa.js";import{B as b}from"./app-BBdow7GJ.js";import{u as h}from"./i18n-C8tBby0x.js";import"./query-QCek5MsK.js";import"./router-D2Fb4U0L.js";import"./radix-CtQBp6Ie.js";function P(){const{t}=h(),s=u.useMemo(()=>[{id:"tour",title:t("help.sections.consoleTour.title"),items:t("help.sections.consoleTour.items",{returnObjects:!0})},{id:"configuration",title:t("help.sections.configuration.title"),items:t("help.sections.configuration.items",{returnObjects:!0})},{id:"claude",title:t("help.sections.claudeCodeConfig.title"),items:t("help.sections.claudeCodeConfig.items",{returnObjects:!0})},{id:"codex",title:t("help.sections.codexConfig.title"),items:t("help.sections.codexConfig.items",{returnObjects:!0})},{id:"usage",title:t("help.sections.usage.title"),items:t("help.sections.usage.items",{returnObjects:!0})},{id:"tips",title:t("help.sections.tips.title"),items:t("help.sections.tips.items",{returnObjects:!0})}],[t]),i=t("help.faq.items",{returnObjects:!0}),l=u.useMemo(()=>[...s.map(n=>({id:n.id,title:n.title})),{id:"faq",title:t("help.faq.title")}],[s,t]);return e.jsxs("div",{className:"space-y-4",children:[e.jsx(f,{info:e.jsx("span",{className:"rounded-full bg-secondary px-2.5 py-1 text-xs text-muted-foreground",children:t("help.meta.guides",{count:s.length})})}),e.jsxs("div",{className:"rounded-lg border border-border/60 bg-card/80 px-4 py-3 text-sm text-muted-foreground",children:[e.jsx("p",{className:"font-medium text-foreground",children:t("help.note")}),e.jsx("p",{className:"mt-1 text-xs leading-5",children:t("help.helper")})]}),e.jsxs("div",{className:"grid gap-5 xl:grid-cols-[208px_minmax(0,1fr)] xl:items-start",children:[e.jsx("aside",{className:"hidden xl:sticky xl:top-4 xl:block",children:e.jsxs("nav",{"aria-label":t("help.meta.tocTitle"),className:"rounded-lg border border-border/60 bg-card/70 p-3",children:[e.jsx("p",{className:"mb-2 px-1 text-[11px] font-semibold uppercase tracking-wide text-muted-foreground",children:t("help.meta.tocTitle")}),e.jsx("ol",{className:"space-y-0.5 text-sm",children:l.map(n=>e.jsx("li",{children:e.jsx("a",{href:`#help-${n.id}`,className:"block truncate rounded-md px-2 py-1.5 text-muted-foreground transition hover:bg-accent hover:text-foreground",children:n.title})},n.id))})]})}),e.jsxs("div",{className:"min-w-0 space-y-5",children:[e.jsx("div",{id:"help-tour",children:e.jsx(o,{title:s[0].title,children:e.jsx(c,{items:s[0].items,compact:!0})})}),e.jsx("div",{id:"help-configuration",children:e.jsx(o,{title:s[1].title,children:e.jsx(c,{items:s[1].items})})}),e.jsxs("div",{className:"grid gap-5 lg:grid-cols-2",children:[e.jsx("div",{id:"help-claude",children:e.jsx(o,{title:s[2].title,description:t("help.meta.claudeWorkflow"),children:e.jsx(c,{items:s[2].items})})}),e.jsx("div",{id:"help-codex",children:e.jsx(o,{title:s[3].title,description:t("help.meta.codexWorkflow"),children:e.jsx(c,{items:s[3].items})})})]}),e.jsx("div",{id:"help-usage",children:e.jsx(o,{title:s[4].title,children:e.jsx(c,{items:s[4].items})})}),e.jsx("div",{id:"help-tips",children:e.jsx(o,{title:s[5].title,children:e.jsx(c,{items:s[5].items})})}),e.jsx("div",{id:"help-faq",children:e.jsx(o,{title:t("help.faq.title"),children:e.jsx(y,{items:i})})})]})]})]})}function c({items:t,compact:s=!1}){return e.jsx("ol",{className:x("flex flex-col",s?"gap-2":"gap-2.5"),children:t.map((i,l)=>e.jsxs("li",{className:x("flex gap-3 rounded-lg border border-border/50 bg-card/80",s?"p-3":"p-3.5"),children:[e.jsx("span",{className:x("flex shrink-0 items-center justify-center rounded-md bg-primary text-xs font-semibold text-primary-foreground",s?"h-6 w-6 text-[11px]":"h-7 w-7"),children:l+1}),e.jsx("div",{className:"min-w-0 flex-1 text-sm text-muted-foreground",children:e.jsx(g,{content:i})})]},`${l}-${i}`))})}function g({content:t}){const{t:s}=h(),i=t.split("```");return e.jsx("div",{className:"space-y-3",children:i.map((l,n)=>{if(!l.trim())return null;if(n%2===1){const[a,...m]=l.split(`
2
2
  `),r=m.join(`
3
3
  `).trim();return e.jsxs("div",{className:"overflow-hidden rounded-md border border-border/55 bg-secondary/60 dark:border-white/10 dark:bg-slate-900/[0.52]",children:[e.jsxs("div",{className:"flex items-center justify-between border-b border-border/55 px-3 py-1.5 dark:border-white/10",children:[e.jsx("span",{className:"text-[11px] font-semibold uppercase tracking-wide text-muted-foreground",children:a||"bash"}),e.jsx(b,{variant:"ghost",size:"sm",className:"h-6 rounded px-2 text-[11px] text-muted-foreground hover:text-foreground",onClick:()=>j(r),children:s("common.actions.copy")})]}),e.jsx("pre",{className:"overflow-x-auto px-3 py-2.5 font-mono text-[12px] leading-6 text-foreground",children:e.jsx("code",{className:"block min-w-full whitespace-pre",children:r})})]},n)}return e.jsx(N,{content:l},n)})})}function N({content:t}){const s=t.split(`
4
4
  `).map(r=>r.trimEnd()).filter(r=>r.trim().length>0);if(s.length===0)return null;const i=s.filter(r=>/^[-•*]\s+/.test(r.trim())),l=s.filter(r=>/^\d+[).]\s+/.test(r.trim())),n=s.filter(r=>!/^([-•*]|\d+[).])\s+/.test(r.trim())),a=i.map(r=>r.replace(/^[-•*]\s+/,"")),m=l.map(r=>{const d=r.trim().match(/^(\d+)[).]\s+(.*)$/);return{index:(d==null?void 0:d[1])??"",text:(d==null?void 0:d[2])??r.trim()}});return e.jsxs("div",{className:"space-y-2",children:[n.length>0?e.jsx("div",{className:"space-y-1.5",children:n.map((r,d)=>e.jsx("p",{className:"leading-6",children:p(r)},`${r}-${d}`))}):null,a.length>0?e.jsx("ul",{className:"space-y-1.5 rounded-md bg-secondary/40 px-3 py-2 dark:bg-slate-900/[0.34]",children:a.map((r,d)=>e.jsxs("li",{className:"flex gap-2 text-sm leading-6",children:[e.jsx("span",{className:"mt-2 h-1.5 w-1.5 shrink-0 rounded-full bg-primary"}),e.jsx("span",{children:p(r)})]},`${r}-${d}`))}):null,m.length>0?e.jsx("ol",{className:"space-y-1.5 rounded-md bg-secondary/40 px-3 py-2 dark:bg-slate-900/[0.34]",children:m.map(r=>e.jsxs("li",{className:"flex gap-2.5 text-sm leading-6",children:[e.jsx("span",{className:"mt-0.5 flex h-5 min-w-5 items-center justify-center rounded-full bg-primary/15 px-1.5 text-[11px] font-semibold text-primary",children:r.index}),e.jsx("span",{children:p(r.text)})]},`${r.index}-${r.text}`))}):null]})}function p(t){return t.split(/(`[^`]+`|\*\*[^*]+\*\*)/g).map((i,l)=>i.startsWith("`")&&i.endsWith("`")?e.jsx("code",{className:"rounded bg-secondary/72 px-1.5 py-0.5 text-[0.95em] text-foreground dark:bg-slate-900/[0.58]",children:i.slice(1,-1)},l):i.startsWith("**")&&i.endsWith("**")?e.jsx("strong",{className:"font-medium text-foreground",children:i.slice(2,-2)},l):e.jsx("span",{children:i},l))}function y({items:t}){return t.length===0?null:e.jsx("dl",{className:"space-y-2",children:t.map((s,i)=>e.jsxs("details",{className:"group overflow-hidden rounded-lg border border-border/50 bg-card/80",children:[e.jsxs("summary",{className:"flex cursor-pointer list-none items-center justify-between gap-3 px-4 py-2.5 text-sm font-medium text-foreground",children:[e.jsx("span",{children:s.q}),e.jsx("span",{className:"rounded-full bg-secondary px-2 py-0.5 text-[11px] text-muted-foreground transition group-open:bg-primary/10 group-open:text-primary",children:i+1})]}),e.jsx("div",{className:"border-t border-border/50 px-4 py-3",children:e.jsx("dd",{className:"text-sm text-muted-foreground",children:e.jsx(g,{content:s.a})})})]},s.q))})}export{P as default};