@nextclaw/ui 0.5.40 → 0.5.41
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/CHANGELOG.md +6 -0
- package/dist/assets/{ChannelsList-B30C2Tc1.js → ChannelsList-C2Qd0t9b.js} +1 -1
- package/dist/assets/{ChatPage-avQKMYYz.js → ChatPage-BqlsPWdy.js} +1 -1
- package/dist/assets/{CronConfig-BMlXWhYq.js → CronConfig-CdvpKuSy.js} +1 -1
- package/dist/assets/{DocBrowser-DJvqOv4P.js → DocBrowser-Bgmeukiz.js} +1 -1
- package/dist/assets/{MarketplacePage-ClpeHXw_.js → MarketplacePage-t3Sib5LO.js} +3 -3
- package/dist/assets/{ModelConfig-C7goS4WN.js → ModelConfig-DZUg-4N3.js} +1 -1
- package/dist/assets/{ProvidersList-D-PD0V-a.js → ProvidersList-BvtEBIdN.js} +1 -1
- package/dist/assets/{RuntimeConfig-CIv4GGnC.js → RuntimeConfig-Dv-06ffH.js} +1 -1
- package/dist/assets/{SecretsConfig-4_Q0C2xp.js → SecretsConfig-Djc-_j3o.js} +1 -1
- package/dist/assets/{SessionsConfig-CtSAiFfb.js → SessionsConfig-BY8rxQ7m.js} +1 -1
- package/dist/assets/{card-sNuXU_r7.js → card-ITZ1xl10.js} +1 -1
- package/dist/assets/{index-C1zSMeji.js → index-C8UPX5Q7.js} +2 -2
- package/dist/assets/{label-D4Ubt_vJ.js → label-BowGMNYa.js} +1 -1
- package/dist/assets/{logos-DKUohpuv.js → logos-BlD3kGKz.js} +1 -1
- package/dist/assets/{page-layout-BrRUG9hW.js → page-layout-C62p_dlG.js} +1 -1
- package/dist/assets/{switch-B3olqa--.js → switch-CpKwqv79.js} +1 -1
- package/dist/assets/{tabs-custom-ClgZ4Lyg.js → tabs-custom-D1fYWpL_.js} +1 -1
- package/dist/assets/{useConfig-DiBU1IBR.js → useConfig-0trWsjx9.js} +1 -1
- package/dist/assets/{useConfirmDialog-i-F39tiz.js → useConfirmDialog-B_7sVz-j.js} +1 -1
- package/dist/index.html +1 -1
- package/package.json +1 -1
- package/src/components/marketplace/MarketplacePage.tsx +2 -2
|
@@ -1 +1 @@
|
|
|
1
|
-
import{j as e,r as c,F as ee,g as J,m as se,s as te,J as ae,O as re,U as ne}from"./vendor-DN_iJQc4.js";import{P as le,a as oe,B as ie}from"./page-layout-BrRUG9hW.js";import{C as K}from"./card-sNuXU_r7.js";import{I as Y,u as ce,a as de,b as me,c as xe}from"./useConfig-DiBU1IBR.js";import{L as $}from"./label-D4Ubt_vJ.js";import{c as B,t as d,S as ue,a as he,b as fe,d as pe,e as ge,D as Ne,f as je}from"./index-C1zSMeji.js";import{h as A}from"./config-hints-CApS3K_7.js";function u({className:a,...n}){return e.jsx("div",{className:B("animate-pulse rounded-md bg-slate-200",a),...n})}function ye(a){const n=new Set;for(const r of a){const l=r.trim();l.length>0&&n.add(l)}return[...n]}function we({id:a,value:n,onChange:r,options:l,placeholder:m,className:N,inputClassName:x,emptyText:C,createText:b,maxItems:S=Number.POSITIVE_INFINITY,onEnter:k}){const[v,h]=c.useState(!1),j=c.useMemo(()=>ye(l),[l]),i=n.trim().toLowerCase(),f=c.useMemo(()=>{const t=j.map((o,y)=>({option:o,index:y}));i.length>0&&t.sort((o,y)=>{const w=o.option.toLowerCase(),M=y.option.toLowerCase(),T=w===i?0:w.startsWith(i)?1:w.includes(i)?2:3,I=M===i?0:M.startsWith(i)?1:M.includes(i)?2:3;return T!==I?T-I:o.index-y.index});const g=t.map(o=>o.option);return Number.isFinite(S)?g.slice(0,Math.max(1,S)):g},[j,i,S]),P=n.trim().length>0&&j.some(t=>t===n.trim());return e.jsxs("div",{className:B("relative",N),onBlur:()=>{setTimeout(()=>h(!1),120)},children:[e.jsx(Y,{id:a,value:n,onFocus:()=>h(!0),onChange:t=>{r(t.target.value),v||h(!0)},onKeyDown:t=>{t.key==="Enter"&&(k&&(t.preventDefault(),k()),h(!1))},placeholder:m,className:B("pr-10",x)}),e.jsx("button",{type:"button",onMouseDown:t=>t.preventDefault(),onClick:()=>h(t=>!t),className:"absolute inset-y-0 right-0 inline-flex w-10 items-center justify-center text-gray-400 hover:text-gray-600","aria-label":"toggle model options",children:e.jsx(ee,{className:"h-4 w-4"})}),v&&e.jsx("div",{className:"absolute z-20 mt-1 w-full overflow-hidden rounded-xl border border-gray-200 bg-white shadow-lg",children:e.jsxs("div",{className:"max-h-60 overflow-y-auto py-1",children:[!P&&n.trim().length>0&&e.jsxs("button",{type:"button",onMouseDown:t=>t.preventDefault(),onClick:()=>{r(n.trim()),h(!1)},className:"flex w-full items-center gap-2 px-3 py-2 text-left text-sm hover:bg-gray-50",children:[e.jsx(J,{className:"h-4 w-4 text-transparent"}),e.jsx("span",{className:"truncate text-gray-700",children:b?b.replace("{value}",n.trim()):n.trim()})]}),f.map(t=>e.jsxs("button",{type:"button",onMouseDown:g=>g.preventDefault(),onClick:()=>{r(t),h(!1)},className:"flex w-full items-center gap-2 px-3 py-2 text-left text-sm hover:bg-gray-50",children:[e.jsx(J,{className:B("h-4 w-4",t===n.trim()?"text-primary":"text-transparent")}),e.jsx("span",{className:"truncate text-gray-700",children:t})]},t)),f.length===0&&n.trim().length===0&&e.jsx("div",{className:"px-3 py-2 text-sm text-gray-500",children:C??"No models available"})]})})]})}function z(a){if(!a||a.length===0)return[];const n=new Set;for(const r of a){const l=r.trim();l&&n.add(l)}return[...n]}function be(a,n){const r=a.trim(),l=n.trim();if(!r||!l)return r;const m=`${l}/`;return r.startsWith(m)?r.slice(m.length):r}function D(a,n){let r=a.trim();if(!r)return"";for(const l of n)r=be(r,l);return r.trim()}function ve(a,n){const r=a.trim();if(!r)return null;let l=null;for(const m of n)for(const N of m.aliases){const x=N.trim();x&&(r===x||r.startsWith(`${x}/`))&&(!l||x.length>l.score)&&(l={name:m.name,score:x.length})}return(l==null?void 0:l.name)??null}function Ie(){const{data:a,isLoading:n}=ce(),{data:r}=de(),{data:l}=me(),m=xe(),[N,x]=c.useState(""),[C,b]=c.useState(""),[S,k]=c.useState(""),[v,h]=c.useState(8192),j=l==null?void 0:l.uiHints,i=A("agents.defaults.model",j),f=A("agents.defaults.workspace",j),P=A("agents.defaults.maxTokens",j),t=c.useMemo(()=>((r==null?void 0:r.providers)??[]).map(s=>{var R,V,_,q,G;const L=(s.modelPrefix||s.name||"").trim(),p=z([s.modelPrefix||"",s.name||""]),U=z((s.defaultModels??[]).map(W=>D(W,p))),O=z((((V=(R=a==null?void 0:a.providers)==null?void 0:R[s.name])==null?void 0:V.models)??[]).map(W=>D(W,p))),F=z([...U,...O]),E=(G=(q=(_=a==null?void 0:a.providers)==null?void 0:_[s.name])==null?void 0:q.displayName)==null?void 0:G.trim();return{name:s.name,displayName:E||s.displayName||s.name,prefix:L,aliases:p,models:F}}),[r,a]),g=c.useMemo(()=>new Map(t.map(s=>[s.name,s])),[t]),o=g.get(N)??t[0],y=(o==null?void 0:o.name)??"",w=c.useMemo(()=>(o==null?void 0:o.aliases)??[],[o]),M=c.useMemo(()=>(o==null?void 0:o.models)??[],[o]);c.useEffect(()=>{N||t.length===0||x(t[0].name)},[N,t]),c.useEffect(()=>{var O,F,E;if(!((O=a==null?void 0:a.agents)!=null&&O.defaults))return;const s=(a.agents.defaults.model||"").trim(),p=ve(s,t)??((F=t[0])==null?void 0:F.name)??"",U=((E=g.get(p))==null?void 0:E.aliases)??[];x(p),b(D(s,U)),k(a.agents.defaults.workspace||""),h(a.agents.defaults.maxTokens||8192)},[a,t,g]);const T=c.useMemo(()=>{const s=new Set;for(const L of M){const p=L.trim();p&&s.add(p)}return[...s]},[M]),I=c.useMemo(()=>{const s=D(C,w);return s?!o||!o.prefix?s:`${o.prefix}/${s}`:""},[C,o,w]),Q=(i==null?void 0:i.help)??"",X=s=>{x(s),b("")},Z=s=>{b(D(s,w))},H=s=>{s.preventDefault(),m.mutate({model:I,maxTokens:v})};return n?e.jsxs("div",{className:"max-w-2xl space-y-6",children:[e.jsxs("div",{className:"space-y-2",children:[e.jsx(u,{className:"h-8 w-32"}),e.jsx(u,{className:"h-4 w-48"})]}),e.jsxs(K,{className:"rounded-2xl border-gray-200 p-6",children:[e.jsxs("div",{className:"flex items-center gap-4 mb-6",children:[e.jsx(u,{className:"h-12 w-12 rounded-xl"}),e.jsxs("div",{className:"space-y-2",children:[e.jsx(u,{className:"h-5 w-24"}),e.jsx(u,{className:"h-3 w-32"})]})]}),e.jsx(u,{className:"h-4 w-20 mb-2"}),e.jsx(u,{className:"h-10 w-full rounded-xl"})]}),e.jsxs(K,{className:"rounded-2xl border-gray-200 p-6",children:[e.jsx(u,{className:"h-5 w-24 mb-2"}),e.jsx(u,{className:"h-3 w-40 mb-6"}),e.jsx("div",{className:"space-y-6",children:e.jsxs("div",{children:[e.jsx(u,{className:"h-4 w-28 mb-3"}),e.jsx(u,{className:"h-2 w-full rounded-full"})]})})]})]}):e.jsxs(le,{children:[e.jsx(oe,{title:d("modelPageTitle"),description:d("modelPageDescription")}),e.jsxs("form",{onSubmit:H,className:"space-y-8",children:[e.jsxs("div",{className:"grid grid-cols-1 md:grid-cols-2 gap-8",children:[e.jsxs("div",{className:"p-8 rounded-2xl bg-white border border-gray-200 shadow-card",children:[e.jsxs("div",{className:"flex items-center gap-4 mb-8",children:[e.jsx("div",{className:"h-10 w-10 rounded-xl bg-primary flex items-center justify-center text-white",children:e.jsx(se,{className:"h-5 w-5"})}),e.jsx("h3",{className:"text-lg font-bold text-gray-900",children:d("defaultModel")})]}),e.jsxs("div",{className:"space-y-2",children:[e.jsx($,{htmlFor:"model",className:"text-xs font-semibold text-gray-500 uppercase tracking-wider",children:(i==null?void 0:i.label)??"Model Name"}),e.jsxs("div",{className:"flex flex-col gap-2 sm:flex-row sm:items-center",children:[e.jsx("div",{className:"sm:w-[38%] sm:min-w-[170px]",children:e.jsxs(ue,{value:y,onValueChange:X,children:[e.jsx(he,{className:"h-10 w-full rounded-xl",children:e.jsx(fe,{placeholder:d("providersSelectPlaceholder")})}),e.jsx(pe,{children:t.map(s=>e.jsx(ge,{value:s.name,children:s.displayName},s.name))})]})}),e.jsx("span",{className:"hidden h-10 items-center justify-center leading-none text-lg font-semibold text-gray-300 sm:inline-flex",children:"/"}),e.jsx(we,{id:"model",value:C,onChange:Z,options:T,placeholder:(i==null?void 0:i.placeholder)??"gpt-5.1",className:"sm:flex-1",inputClassName:"h-10 rounded-xl",emptyText:d("modelPickerNoOptions"),createText:d("modelPickerUseCustom")},y)]}),e.jsx("p",{className:"text-xs text-gray-400",children:Q}),e.jsx("p",{className:"text-xs text-gray-500",children:d("modelInputCustomHint")}),e.jsxs("a",{href:`${Ne}/guide/model-selection`,className:"inline-flex items-center gap-1.5 text-xs text-primary hover:text-primary-hover transition-colors",children:[e.jsx(te,{className:"h-3.5 w-3.5"}),d("channelsGuideTitle")]})]})]}),e.jsxs("div",{className:"p-8 rounded-2xl bg-white border border-gray-200 shadow-card",children:[e.jsxs("div",{className:"flex items-center gap-4 mb-8",children:[e.jsx("div",{className:"h-10 w-10 rounded-xl bg-primary flex items-center justify-center text-white",children:e.jsx(ae,{className:"h-5 w-5"})}),e.jsx("h3",{className:"text-lg font-bold text-gray-900",children:d("workspace")})]}),e.jsxs("div",{className:"space-y-2",children:[e.jsx($,{htmlFor:"workspace",className:"text-xs font-semibold text-gray-500 uppercase tracking-wider",children:(f==null?void 0:f.label)??"Default Path"}),e.jsx(Y,{id:"workspace",value:S,onChange:s=>k(s.target.value),placeholder:(f==null?void 0:f.placeholder)??"/path/to/workspace",className:"rounded-xl"})]})]})]}),e.jsxs("div",{className:"p-8 rounded-2xl bg-white border border-gray-200 shadow-card",children:[e.jsxs("div",{className:"flex items-center gap-4 mb-10",children:[e.jsx("div",{className:"h-10 w-10 rounded-xl bg-primary flex items-center justify-center text-white",children:e.jsx(re,{className:"h-5 w-5"})}),e.jsx("h3",{className:"text-lg font-bold text-gray-900",children:d("generationParameters")})]}),e.jsx("div",{className:"grid grid-cols-1 gap-12",children:e.jsxs("div",{className:"space-y-4",children:[e.jsxs("div",{className:"flex justify-between items-center mb-2",children:[e.jsx($,{className:"text-xs font-semibold text-gray-500 uppercase tracking-wider",children:(P==null?void 0:P.label)??d("maxTokens")}),e.jsx("span",{className:"text-sm font-semibold text-gray-900",children:je(v)})]}),e.jsx("input",{type:"range",min:"1000",max:"32000",step:"1000",value:v,onChange:s=>h(parseInt(s.target.value)),className:"w-full h-1 bg-gray-200 rounded-full appearance-none cursor-pointer accent-primary"})]})})]}),e.jsx("div",{className:"flex justify-end pt-4",children:e.jsx(ie,{type:"submit",disabled:m.isPending,size:"lg",children:m.isPending?e.jsx(ne,{className:"h-5 w-5 animate-spin"}):d("saveChanges")})})]})]})}export{Ie as ModelConfig};
|
|
1
|
+
import{j as e,r as c,F as ee,g as J,m as se,s as te,J as ae,O as re,U as ne}from"./vendor-DN_iJQc4.js";import{P as le,a as oe,B as ie}from"./page-layout-C62p_dlG.js";import{C as K}from"./card-ITZ1xl10.js";import{I as Y,u as ce,a as de,b as me,c as xe}from"./useConfig-0trWsjx9.js";import{L as $}from"./label-BowGMNYa.js";import{c as B,t as d,S as ue,a as he,b as fe,d as pe,e as ge,D as Ne,f as je}from"./index-C8UPX5Q7.js";import{h as A}from"./config-hints-CApS3K_7.js";function u({className:a,...n}){return e.jsx("div",{className:B("animate-pulse rounded-md bg-slate-200",a),...n})}function ye(a){const n=new Set;for(const r of a){const l=r.trim();l.length>0&&n.add(l)}return[...n]}function we({id:a,value:n,onChange:r,options:l,placeholder:m,className:N,inputClassName:x,emptyText:C,createText:b,maxItems:S=Number.POSITIVE_INFINITY,onEnter:k}){const[v,h]=c.useState(!1),j=c.useMemo(()=>ye(l),[l]),i=n.trim().toLowerCase(),f=c.useMemo(()=>{const t=j.map((o,y)=>({option:o,index:y}));i.length>0&&t.sort((o,y)=>{const w=o.option.toLowerCase(),M=y.option.toLowerCase(),T=w===i?0:w.startsWith(i)?1:w.includes(i)?2:3,I=M===i?0:M.startsWith(i)?1:M.includes(i)?2:3;return T!==I?T-I:o.index-y.index});const g=t.map(o=>o.option);return Number.isFinite(S)?g.slice(0,Math.max(1,S)):g},[j,i,S]),P=n.trim().length>0&&j.some(t=>t===n.trim());return e.jsxs("div",{className:B("relative",N),onBlur:()=>{setTimeout(()=>h(!1),120)},children:[e.jsx(Y,{id:a,value:n,onFocus:()=>h(!0),onChange:t=>{r(t.target.value),v||h(!0)},onKeyDown:t=>{t.key==="Enter"&&(k&&(t.preventDefault(),k()),h(!1))},placeholder:m,className:B("pr-10",x)}),e.jsx("button",{type:"button",onMouseDown:t=>t.preventDefault(),onClick:()=>h(t=>!t),className:"absolute inset-y-0 right-0 inline-flex w-10 items-center justify-center text-gray-400 hover:text-gray-600","aria-label":"toggle model options",children:e.jsx(ee,{className:"h-4 w-4"})}),v&&e.jsx("div",{className:"absolute z-20 mt-1 w-full overflow-hidden rounded-xl border border-gray-200 bg-white shadow-lg",children:e.jsxs("div",{className:"max-h-60 overflow-y-auto py-1",children:[!P&&n.trim().length>0&&e.jsxs("button",{type:"button",onMouseDown:t=>t.preventDefault(),onClick:()=>{r(n.trim()),h(!1)},className:"flex w-full items-center gap-2 px-3 py-2 text-left text-sm hover:bg-gray-50",children:[e.jsx(J,{className:"h-4 w-4 text-transparent"}),e.jsx("span",{className:"truncate text-gray-700",children:b?b.replace("{value}",n.trim()):n.trim()})]}),f.map(t=>e.jsxs("button",{type:"button",onMouseDown:g=>g.preventDefault(),onClick:()=>{r(t),h(!1)},className:"flex w-full items-center gap-2 px-3 py-2 text-left text-sm hover:bg-gray-50",children:[e.jsx(J,{className:B("h-4 w-4",t===n.trim()?"text-primary":"text-transparent")}),e.jsx("span",{className:"truncate text-gray-700",children:t})]},t)),f.length===0&&n.trim().length===0&&e.jsx("div",{className:"px-3 py-2 text-sm text-gray-500",children:C??"No models available"})]})})]})}function z(a){if(!a||a.length===0)return[];const n=new Set;for(const r of a){const l=r.trim();l&&n.add(l)}return[...n]}function be(a,n){const r=a.trim(),l=n.trim();if(!r||!l)return r;const m=`${l}/`;return r.startsWith(m)?r.slice(m.length):r}function D(a,n){let r=a.trim();if(!r)return"";for(const l of n)r=be(r,l);return r.trim()}function ve(a,n){const r=a.trim();if(!r)return null;let l=null;for(const m of n)for(const N of m.aliases){const x=N.trim();x&&(r===x||r.startsWith(`${x}/`))&&(!l||x.length>l.score)&&(l={name:m.name,score:x.length})}return(l==null?void 0:l.name)??null}function Ie(){const{data:a,isLoading:n}=ce(),{data:r}=de(),{data:l}=me(),m=xe(),[N,x]=c.useState(""),[C,b]=c.useState(""),[S,k]=c.useState(""),[v,h]=c.useState(8192),j=l==null?void 0:l.uiHints,i=A("agents.defaults.model",j),f=A("agents.defaults.workspace",j),P=A("agents.defaults.maxTokens",j),t=c.useMemo(()=>((r==null?void 0:r.providers)??[]).map(s=>{var R,V,_,q,G;const L=(s.modelPrefix||s.name||"").trim(),p=z([s.modelPrefix||"",s.name||""]),U=z((s.defaultModels??[]).map(W=>D(W,p))),O=z((((V=(R=a==null?void 0:a.providers)==null?void 0:R[s.name])==null?void 0:V.models)??[]).map(W=>D(W,p))),F=z([...U,...O]),E=(G=(q=(_=a==null?void 0:a.providers)==null?void 0:_[s.name])==null?void 0:q.displayName)==null?void 0:G.trim();return{name:s.name,displayName:E||s.displayName||s.name,prefix:L,aliases:p,models:F}}),[r,a]),g=c.useMemo(()=>new Map(t.map(s=>[s.name,s])),[t]),o=g.get(N)??t[0],y=(o==null?void 0:o.name)??"",w=c.useMemo(()=>(o==null?void 0:o.aliases)??[],[o]),M=c.useMemo(()=>(o==null?void 0:o.models)??[],[o]);c.useEffect(()=>{N||t.length===0||x(t[0].name)},[N,t]),c.useEffect(()=>{var O,F,E;if(!((O=a==null?void 0:a.agents)!=null&&O.defaults))return;const s=(a.agents.defaults.model||"").trim(),p=ve(s,t)??((F=t[0])==null?void 0:F.name)??"",U=((E=g.get(p))==null?void 0:E.aliases)??[];x(p),b(D(s,U)),k(a.agents.defaults.workspace||""),h(a.agents.defaults.maxTokens||8192)},[a,t,g]);const T=c.useMemo(()=>{const s=new Set;for(const L of M){const p=L.trim();p&&s.add(p)}return[...s]},[M]),I=c.useMemo(()=>{const s=D(C,w);return s?!o||!o.prefix?s:`${o.prefix}/${s}`:""},[C,o,w]),Q=(i==null?void 0:i.help)??"",X=s=>{x(s),b("")},Z=s=>{b(D(s,w))},H=s=>{s.preventDefault(),m.mutate({model:I,maxTokens:v})};return n?e.jsxs("div",{className:"max-w-2xl space-y-6",children:[e.jsxs("div",{className:"space-y-2",children:[e.jsx(u,{className:"h-8 w-32"}),e.jsx(u,{className:"h-4 w-48"})]}),e.jsxs(K,{className:"rounded-2xl border-gray-200 p-6",children:[e.jsxs("div",{className:"flex items-center gap-4 mb-6",children:[e.jsx(u,{className:"h-12 w-12 rounded-xl"}),e.jsxs("div",{className:"space-y-2",children:[e.jsx(u,{className:"h-5 w-24"}),e.jsx(u,{className:"h-3 w-32"})]})]}),e.jsx(u,{className:"h-4 w-20 mb-2"}),e.jsx(u,{className:"h-10 w-full rounded-xl"})]}),e.jsxs(K,{className:"rounded-2xl border-gray-200 p-6",children:[e.jsx(u,{className:"h-5 w-24 mb-2"}),e.jsx(u,{className:"h-3 w-40 mb-6"}),e.jsx("div",{className:"space-y-6",children:e.jsxs("div",{children:[e.jsx(u,{className:"h-4 w-28 mb-3"}),e.jsx(u,{className:"h-2 w-full rounded-full"})]})})]})]}):e.jsxs(le,{children:[e.jsx(oe,{title:d("modelPageTitle"),description:d("modelPageDescription")}),e.jsxs("form",{onSubmit:H,className:"space-y-8",children:[e.jsxs("div",{className:"grid grid-cols-1 md:grid-cols-2 gap-8",children:[e.jsxs("div",{className:"p-8 rounded-2xl bg-white border border-gray-200 shadow-card",children:[e.jsxs("div",{className:"flex items-center gap-4 mb-8",children:[e.jsx("div",{className:"h-10 w-10 rounded-xl bg-primary flex items-center justify-center text-white",children:e.jsx(se,{className:"h-5 w-5"})}),e.jsx("h3",{className:"text-lg font-bold text-gray-900",children:d("defaultModel")})]}),e.jsxs("div",{className:"space-y-2",children:[e.jsx($,{htmlFor:"model",className:"text-xs font-semibold text-gray-500 uppercase tracking-wider",children:(i==null?void 0:i.label)??"Model Name"}),e.jsxs("div",{className:"flex flex-col gap-2 sm:flex-row sm:items-center",children:[e.jsx("div",{className:"sm:w-[38%] sm:min-w-[170px]",children:e.jsxs(ue,{value:y,onValueChange:X,children:[e.jsx(he,{className:"h-10 w-full rounded-xl",children:e.jsx(fe,{placeholder:d("providersSelectPlaceholder")})}),e.jsx(pe,{children:t.map(s=>e.jsx(ge,{value:s.name,children:s.displayName},s.name))})]})}),e.jsx("span",{className:"hidden h-10 items-center justify-center leading-none text-lg font-semibold text-gray-300 sm:inline-flex",children:"/"}),e.jsx(we,{id:"model",value:C,onChange:Z,options:T,placeholder:(i==null?void 0:i.placeholder)??"gpt-5.1",className:"sm:flex-1",inputClassName:"h-10 rounded-xl",emptyText:d("modelPickerNoOptions"),createText:d("modelPickerUseCustom")},y)]}),e.jsx("p",{className:"text-xs text-gray-400",children:Q}),e.jsx("p",{className:"text-xs text-gray-500",children:d("modelInputCustomHint")}),e.jsxs("a",{href:`${Ne}/guide/model-selection`,className:"inline-flex items-center gap-1.5 text-xs text-primary hover:text-primary-hover transition-colors",children:[e.jsx(te,{className:"h-3.5 w-3.5"}),d("channelsGuideTitle")]})]})]}),e.jsxs("div",{className:"p-8 rounded-2xl bg-white border border-gray-200 shadow-card",children:[e.jsxs("div",{className:"flex items-center gap-4 mb-8",children:[e.jsx("div",{className:"h-10 w-10 rounded-xl bg-primary flex items-center justify-center text-white",children:e.jsx(ae,{className:"h-5 w-5"})}),e.jsx("h3",{className:"text-lg font-bold text-gray-900",children:d("workspace")})]}),e.jsxs("div",{className:"space-y-2",children:[e.jsx($,{htmlFor:"workspace",className:"text-xs font-semibold text-gray-500 uppercase tracking-wider",children:(f==null?void 0:f.label)??"Default Path"}),e.jsx(Y,{id:"workspace",value:S,onChange:s=>k(s.target.value),placeholder:(f==null?void 0:f.placeholder)??"/path/to/workspace",className:"rounded-xl"})]})]})]}),e.jsxs("div",{className:"p-8 rounded-2xl bg-white border border-gray-200 shadow-card",children:[e.jsxs("div",{className:"flex items-center gap-4 mb-10",children:[e.jsx("div",{className:"h-10 w-10 rounded-xl bg-primary flex items-center justify-center text-white",children:e.jsx(re,{className:"h-5 w-5"})}),e.jsx("h3",{className:"text-lg font-bold text-gray-900",children:d("generationParameters")})]}),e.jsx("div",{className:"grid grid-cols-1 gap-12",children:e.jsxs("div",{className:"space-y-4",children:[e.jsxs("div",{className:"flex justify-between items-center mb-2",children:[e.jsx($,{className:"text-xs font-semibold text-gray-500 uppercase tracking-wider",children:(P==null?void 0:P.label)??d("maxTokens")}),e.jsx("span",{className:"text-sm font-semibold text-gray-900",children:je(v)})]}),e.jsx("input",{type:"range",min:"1000",max:"32000",step:"1000",value:v,onChange:s=>h(parseInt(s.target.value)),className:"w-full h-1 bg-gray-200 rounded-full appearance-none cursor-pointer accent-primary"})]})})]}),e.jsx("div",{className:"flex justify-end pt-4",children:e.jsx(ie,{type:"submit",disabled:m.isPending,size:"lg",children:m.isPending?e.jsx(ne,{className:"h-5 w-5 animate-spin"}):d("saveChanges")})})]})]})}export{Ie as ModelConfig};
|
|
@@ -1 +1 @@
|
|
|
1
|
-
import{r as p,j as e,aa as Ae,ab as Ce,a8 as me,a6 as ne,ac as se,K as ue,a1 as Pe,m as De,ad as Le,ae as Me,af as Se,ag as te,a0 as Ee}from"./vendor-DN_iJQc4.js";import{I,u as xe,a as he,b as pe,g as Te,h as Be,i as Ke,j as $e}from"./useConfig-DiBU1IBR.js";import{B as S,P as ke,a as Ie}from"./page-layout-BrRUG9hW.js";import{L as W}from"./label-D4Ubt_vJ.js";import{t,c as J,S as Fe,a as Oe,b as _e,d as Re,e as We}from"./index-C1zSMeji.js";import{C as He,a as ze,S as ye,b as Ge,c as Ve,L as qe,g as Ue}from"./logos-DKUohpuv.js";import{h as q}from"./config-hints-CApS3K_7.js";import{T as Qe}from"./tabs-custom-ClgZ4Lyg.js";function Xe({maskedValue:s,isSet:a,className:n,...i}){const[u,b]=p.useState(!1);return e.jsxs("div",{className:"relative",children:[e.jsx(I,{type:u?"text":"password",className:J("pr-20",n),placeholder:a?`${t("apiKeySet")} (${t("unchanged")})`:"",...i}),e.jsx("div",{className:"absolute right-2 top-1/2 -translate-y-1/2 flex gap-1",children:(a||s)&&e.jsx(S,{type:"button",variant:"ghost",size:"icon",className:"h-7 w-7",onClick:()=>b(!u),children:u?e.jsx(Ae,{className:"h-4 w-4"}):e.jsx(Ce,{className:"h-4 w-4"})})})]})}function Ye({value:s,onChange:a,className:n}){const i=s?Object.entries(s):[],u=(m,x,g)=>{const f=[...i];f[m]=[x,g],a(Object.fromEntries(f))},b=()=>{a({...s,"":""})},y=m=>{const x=i.filter((g,f)=>f!==m);a(Object.fromEntries(x))};return e.jsxs("div",{className:J("space-y-2",n),children:[i.map(([m,x],g)=>e.jsxs("div",{className:"flex gap-2",children:[e.jsx(I,{type:"text",value:m,onChange:f=>u(g,f.target.value,x),placeholder:t("headerName"),className:"flex-1"}),e.jsx(I,{type:"text",value:x,onChange:f=>u(g,m,f.target.value),placeholder:t("headerValue"),className:"flex-1"}),e.jsx(S,{type:"button",variant:"ghost",size:"icon",onClick:()=>y(g),children:e.jsx(me,{className:"h-4 w-4 text-red-500"})})]},g)),e.jsxs(S,{type:"button",variant:"outline",size:"sm",onClick:b,children:[e.jsx(ne,{className:"h-4 w-4 mr-2"}),t("add")]})]})}function U(s){if(!s)return null;const a=Object.entries(s).map(([n,i])=>[n.trim(),i]).filter(([n])=>n.length>0);return a.length===0?null:Object.fromEntries(a)}function de(s,a){const n=U(s),i=U(a);if(n===null&&i===null)return!0;if(!n||!i)return!1;const u=Object.entries(n).sort(([y],[m])=>y.localeCompare(m)),b=Object.entries(i).sort(([y],[m])=>y.localeCompare(m));return u.length!==b.length?!1:u.every(([y,m],x)=>y===b[x][0]&&m===b[x][1])}function ae(s){if(!s||s.length===0)return[];const a=new Set;for(const n of s){const i=n.trim();i&&a.add(i)}return[...a]}function Je(s,a){const n=s.trim();if(!n||!a.trim())return n;const i=`${a.trim()}/`;return n.startsWith(i)?n.slice(i.length):n}function Y(s,a){let n=s.trim();if(!n)return"";for(const i of a){const u=i.trim();u&&(n=Je(n,u))}return n.trim()}function re(s,a){return s.length!==a.length?!1:s.every((n,i)=>n===a[i])}function Ze(s,a){const n=[...s];for(const i of a)n.includes(i)||n.push(i);return n}function es(s,a){return a.length===0?s:a.every(i=>!s.includes(i))?Ze(s,a):a}function ss(s,a){return re(s,a)?[]:s}function ts({providerName:s,onProviderDeleted:a}){const{data:n}=xe(),{data:i}=he(),{data:u}=pe(),b=Te(),y=Be(),m=Ke(),[x,g]=p.useState(""),[f,B]=p.useState(""),[K,F]=p.useState(null),[E,A]=p.useState("auto"),[C,$]=p.useState([]),[o,d]=p.useState(""),[N,v]=p.useState(""),r=i==null?void 0:i.providers.find(l=>l.name===s),c=s?n==null?void 0:n.providers[s]:null,L=u==null?void 0:u.uiHints,P=!!(r!=null&&r.isCustom),T=s?q(`providers.${s}.apiKey`,L):void 0,w=s?q(`providers.${s}.apiBase`,L):void 0,O=s?q(`providers.${s}.extraHeaders`,L):void 0,k=s?q(`providers.${s}.wireApi`,L):void 0,Z=(r==null?void 0:r.displayName)||s||"",_=((c==null?void 0:c.displayName)||"").trim()||Z,fe=N.trim()||_||s||t("providersSelectPlaceholder"),le=(r==null?void 0:r.modelPrefix)||s||"",R=p.useMemo(()=>ae([le,s||""]),[le,s]),Q=(r==null?void 0:r.defaultApiBase)||"",H=(c==null?void 0:c.apiBase)||Q,ee=U((c==null?void 0:c.extraHeaders)||null),z=(c==null?void 0:c.wireApi)||(r==null?void 0:r.defaultWireApi)||"auto",X=p.useMemo(()=>ae(((r==null?void 0:r.defaultModels)??[]).map(l=>Y(l,R))),[r==null?void 0:r.defaultModels,R]),ie=p.useMemo(()=>ae(((c==null?void 0:c.models)??[]).map(l=>Y(l,R))),[c==null?void 0:c.models,R]),G=p.useMemo(()=>es(X,ie),[X,ie]),ge=s==="minimax"?t("providerApiBaseHelpMinimax"):(w==null?void 0:w.help)||t("providerApiBaseHelp");p.useEffect(()=>{if(!s){g(""),B(""),F(null),A("auto"),$([]),d(""),v("");return}g(""),B(H),F((c==null?void 0:c.extraHeaders)||null),A(z),$(G),d(""),v(_)},[s,H,c==null?void 0:c.extraHeaders,z,G,_]);const ce=p.useMemo(()=>{if(!s)return!1;const l=x.trim().length>0,j=f.trim()!==H.trim(),D=!de(K,ee),h=r!=null&&r.supportsWireApi?E!==z:!1,M=!re(C,G),V=P?N.trim()!==_:!1;return l||j||D||h||M||V},[s,P,N,_,x,f,H,K,ee,r==null?void 0:r.supportsWireApi,E,z,C,G]),je=()=>{g(""),B(Q),F(null),A((r==null?void 0:r.defaultWireApi)||"auto"),$(X),d(""),v(Z)},oe=()=>{const l=Y(o,R);if(l){if(C.includes(l)){d("");return}$(j=>[...j,l]),d("")}},be=l=>{if(l.preventDefault(),!s)return;const j={},D=x.trim(),h=f.trim(),M=U(K),V=N.trim();P&&V!==_&&(j.displayName=V.length>0?V:null),D.length>0&&(j.apiKey=D),h!==H.trim()&&(j.apiBase=h.length>0&&h!==Q?h:null),de(M,ee)||(j.extraHeaders=M),r!=null&&r.supportsWireApi&&E!==z&&(j.wireApi=E),re(C,G)||(j.models=ss(C,X)),b.mutate({provider:s,data:j})},Ne=async()=>{if(!s)return;const l=C.find(h=>h.trim().length>0)??"",j=Y(l,R),D={apiBase:f.trim(),extraHeaders:U(K),model:j||null};x.trim().length>0&&(D.apiKey=x.trim()),r!=null&&r.supportsWireApi&&(D.wireApi=E);try{const h=await m.mutateAsync({provider:s,data:D});if(h.success){te.success(`${t("providerTestConnectionSuccess")} (${h.latencyMs}ms)`);return}const M=[`provider=${h.provider}`,`latency=${h.latencyMs}ms`];h.model&&M.push(`model=${h.model}`),te.error(`${t("providerTestConnectionFailed")}: ${h.message} | ${M.join(" | ")}`)}catch(h){const M=h instanceof Error?h.message:String(h);te.error(`${t("providerTestConnectionFailed")}: ${M}`)}},ve=async()=>{if(!(!s||!P||!window.confirm(t("providerDeleteConfirm"))))try{await y.mutateAsync({provider:s}),a==null||a(s)}catch{}};if(!s||!r||!c)return e.jsx("div",{className:He,children:e.jsxs("div",{children:[e.jsx("h3",{className:"text-base font-semibold text-gray-900",children:t("providersSelectTitle")}),e.jsx("p",{className:"mt-2 text-sm text-gray-500",children:t("providersSelectDescription")})]})});const we=c.apiKeySet?t("statusReady"):t("statusSetup");return e.jsxs("div",{className:ze,children:[e.jsx("div",{className:"border-b border-gray-100 px-6 py-5",children:e.jsxs("div",{className:"flex flex-wrap items-center justify-between gap-3",children:[e.jsxs("div",{className:"min-w-0",children:[e.jsx("h3",{className:"truncate text-lg font-semibold text-gray-900",children:fe}),e.jsx("p",{className:"mt-1 text-sm text-gray-500",children:t("providerFormDescription")})]}),e.jsx(ye,{status:c.apiKeySet?"ready":"setup",label:we})]})}),e.jsxs("form",{onSubmit:be,className:"flex min-h-0 flex-1 flex-col",children:[e.jsxs("div",{className:"min-h-0 flex-1 space-y-6 overflow-y-auto px-6 py-5",children:[P&&e.jsxs("div",{className:"space-y-2.5",children:[e.jsxs(W,{htmlFor:"providerDisplayName",className:"flex items-center gap-2 text-sm font-medium text-gray-900",children:[e.jsx(se,{className:"h-3.5 w-3.5 text-gray-500"}),t("providerDisplayName")]}),e.jsx(I,{id:"providerDisplayName",type:"text",value:N,onChange:l=>v(l.target.value),placeholder:Z||t("providerDisplayNamePlaceholder"),className:"rounded-xl"}),e.jsx("p",{className:"text-xs text-gray-500",children:t("providerDisplayNameHelp")})]}),e.jsxs("div",{className:"space-y-2.5",children:[e.jsxs(W,{htmlFor:"apiKey",className:"flex items-center gap-2 text-sm font-medium text-gray-900",children:[e.jsx(ue,{className:"h-3.5 w-3.5 text-gray-500"}),(T==null?void 0:T.label)??t("apiKey")]}),e.jsx(Xe,{id:"apiKey",value:x,isSet:c.apiKeySet,onChange:l=>g(l.target.value),placeholder:c.apiKeySet?t("apiKeySet"):(T==null?void 0:T.placeholder)??t("enterApiKey"),className:"rounded-xl"}),e.jsx("p",{className:"text-xs text-gray-500",children:t("leaveBlankToKeepUnchanged")})]}),e.jsxs("div",{className:"space-y-2.5",children:[e.jsxs(W,{htmlFor:"apiBase",className:"flex items-center gap-2 text-sm font-medium text-gray-900",children:[e.jsx(Pe,{className:"h-3.5 w-3.5 text-gray-500"}),(w==null?void 0:w.label)??t("apiBase")]}),e.jsx(I,{id:"apiBase",type:"text",value:f,onChange:l=>B(l.target.value),placeholder:Q||(w==null?void 0:w.placeholder)||"https://api.example.com",className:"rounded-xl"}),e.jsx("p",{className:"text-xs text-gray-500",children:ge}),P&&e.jsx("p",{className:"text-xs text-gray-500",children:t("providerOpenAICompatHint")})]}),r.supportsWireApi&&e.jsxs("div",{className:"space-y-2.5",children:[e.jsxs(W,{htmlFor:"wireApi",className:"flex items-center gap-2 text-sm font-medium text-gray-900",children:[e.jsx(se,{className:"h-3.5 w-3.5 text-gray-500"}),(k==null?void 0:k.label)??t("wireApi")]}),e.jsxs(Fe,{value:E,onValueChange:l=>A(l),children:[e.jsx(Oe,{className:"rounded-xl",children:e.jsx(_e,{})}),e.jsx(Re,{children:(r.wireApiOptions||["auto","chat","responses"]).map(l=>e.jsx(We,{value:l,children:l==="chat"?t("wireApiChat"):l==="responses"?t("wireApiResponses"):t("wireApiAuto")},l))})]}),(k==null?void 0:k.help)&&e.jsx("p",{className:"text-xs text-gray-500",children:k.help})]}),e.jsxs("div",{className:"space-y-2.5",children:[e.jsxs(W,{className:"flex items-center gap-2 text-sm font-medium text-gray-900",children:[e.jsx(se,{className:"h-3.5 w-3.5 text-gray-500"}),(O==null?void 0:O.label)??t("extraHeaders")]}),e.jsx(Ye,{value:K,onChange:F}),e.jsx("p",{className:"text-xs text-gray-500",children:(O==null?void 0:O.help)||t("providerExtraHeadersHelp")})]}),e.jsxs("div",{className:"space-y-2.5",children:[e.jsxs(W,{className:"flex items-center gap-2 text-sm font-medium text-gray-900",children:[e.jsx(De,{className:"h-3.5 w-3.5 text-gray-500"}),t("providerModelsTitle")]}),e.jsxs("div",{className:"flex items-center gap-2",children:[e.jsx(I,{value:o,onChange:l=>d(l.target.value),onKeyDown:l=>{l.key==="Enter"&&(l.preventDefault(),oe())},placeholder:t("providerModelInputPlaceholder"),className:"flex-1"}),e.jsxs(S,{type:"button",variant:"outline",onClick:oe,disabled:o.trim().length===0,children:[e.jsx(ne,{className:"mr-1.5 h-4 w-4"}),t("providerAddModel")]})]}),e.jsx("p",{className:"text-xs text-gray-500",children:t("providerModelInputHint")}),C.length===0?e.jsx("div",{className:"rounded-xl border border-dashed border-gray-200 bg-gray-50 px-3 py-2 text-xs text-gray-500",children:t("providerModelsEmpty")}):e.jsx("div",{className:"flex flex-wrap gap-2",children:C.map(l=>e.jsxs("div",{className:"group inline-flex max-w-full items-center gap-1 rounded-full border border-gray-200 bg-white px-3 py-1.5",children:[e.jsx("span",{className:"max-w-[180px] truncate text-sm text-gray-800 sm:max-w-[240px]",children:l}),e.jsx("button",{type:"button",onClick:()=>$(j=>j.filter(D=>D!==l)),className:"inline-flex h-5 w-5 items-center justify-center rounded-full text-gray-400 transition-opacity hover:bg-gray-100 hover:text-gray-600 opacity-100 md:opacity-0 md:group-hover:opacity-100 md:group-focus-within:opacity-100","aria-label":t("remove"),children:e.jsx(Le,{className:"h-3 w-3"})})]},l))}),e.jsx("p",{className:"text-xs text-gray-500",children:t("providerModelsHelp")})]})]}),e.jsxs("div",{className:"flex flex-wrap items-center justify-between gap-3 border-t border-gray-100 px-6 py-4",children:[e.jsxs("div",{className:"flex flex-wrap items-center gap-2",children:[e.jsxs(S,{type:"button",variant:"outline",onClick:je,children:[e.jsx(Me,{className:"mr-2 h-4 w-4"}),t("resetToDefault")]}),P&&e.jsxs(S,{type:"button",variant:"outline",onClick:ve,disabled:y.isPending,children:[e.jsx(me,{className:"mr-2 h-4 w-4"}),y.isPending?t("saving"):t("providerDelete")]}),e.jsxs(S,{type:"button",variant:"outline",onClick:Ne,disabled:m.isPending,children:[e.jsx(Se,{className:"mr-2 h-4 w-4"}),m.isPending?t("providerTestingConnection"):t("providerTestConnection")]})]}),e.jsx(S,{type:"submit",disabled:b.isPending||!ce,children:b.isPending?t("saving"):ce?t("save"):t("unchanged")})]})]})]})}function as(s){if(!s)return null;try{const a=new URL(s),n=a.pathname&&a.pathname!=="/"?a.pathname:"";return`${a.host}${n}`}catch{return s.replace(/^https?:\/\//,"")}}function xs(){const{data:s}=xe(),{data:a}=he(),{data:n}=pe(),i=$e(),[u,b]=p.useState("installed"),[y,m]=p.useState(),[x,g]=p.useState(""),f=n==null?void 0:n.uiHints,B=(a==null?void 0:a.providers)??[],K=(s==null?void 0:s.providers)??{},F=B.filter(o=>{var d;return(d=K[o.name])==null?void 0:d.apiKeySet}).length,E=[{id:"installed",label:t("providersTabConfigured"),count:F},{id:"all",label:t("providersTabAll"),count:B.length}],A=p.useMemo(()=>{const o=(a==null?void 0:a.providers)??[],d=(s==null?void 0:s.providers)??{},N=x.trim().toLowerCase();return o.filter(v=>{var r;return u==="installed"?!!((r=d[v.name])!=null&&r.apiKeySet):!0}).filter(v=>{var L,P;return N?(((P=(L=d[v.name])==null?void 0:L.displayName)==null?void 0:P.trim())||v.displayName||v.name).toLowerCase().includes(N)||v.name.toLowerCase().includes(N):!0})},[a,s,u,x]);p.useEffect(()=>{if(A.length===0){m(void 0);return}A.some(d=>d.name===y)||m(A[0].name)},[A,y]);const C=y,$=async()=>{try{const o=await i.mutateAsync({data:{}});b("all"),g(""),m(o.name)}catch{}};return!s||!a?e.jsx("div",{className:"p-8",children:t("providersLoading")}):e.jsxs(ke,{children:[e.jsx(Ie,{title:t("providersPageTitle"),description:t("providersPageDescription")}),e.jsxs("div",{className:Ge,children:[e.jsxs("section",{className:Ve,children:[e.jsxs("div",{className:"border-b border-gray-100 px-4 pt-4 pb-3 space-y-3",children:[e.jsx(Qe,{tabs:E,activeTab:u,onChange:b,className:"mb-0"}),e.jsxs(S,{type:"button",variant:"outline",className:"w-full justify-center",onClick:$,disabled:i.isPending,children:[e.jsx(ne,{className:"mr-2 h-4 w-4"}),i.isPending?t("saving"):t("providerAddCustom")]})]}),e.jsx("div",{className:"border-b border-gray-100 px-4 py-3",children:e.jsxs("div",{className:"relative",children:[e.jsx(Ee,{className:"pointer-events-none absolute left-3 top-1/2 h-4 w-4 -translate-y-1/2 text-gray-400"}),e.jsx(I,{value:x,onChange:o=>g(o.target.value),placeholder:t("providersFilterPlaceholder"),className:"h-10 rounded-xl pl-9"})]})}),e.jsxs("div",{className:"min-h-0 flex-1 space-y-2 overflow-y-auto p-3",children:[A.map(o=>{var w;const d=s.providers[o.name],N=!!(d!=null&&d.apiKeySet),v=C===o.name,r=((w=d==null?void 0:d.displayName)==null?void 0:w.trim())||o.displayName||o.name,c=q(`providers.${o.name}`,f),L=(d==null?void 0:d.apiBase)||o.defaultApiBase||"",T=as(L)||(c==null?void 0:c.help)||t("providersDefaultDescription");return e.jsx("button",{type:"button",onClick:()=>m(o.name),className:J("w-full rounded-xl border p-2.5 text-left transition-all",v?"border-primary/30 bg-primary-50/40 shadow-sm":"border-gray-200/70 bg-white hover:border-gray-300 hover:bg-gray-50/70"),children:e.jsxs("div",{className:"flex items-start justify-between gap-3",children:[e.jsxs("div",{className:"flex min-w-0 items-center gap-3",children:[e.jsx(qe,{name:o.name,src:Ue(o.name),className:J("h-10 w-10 rounded-lg border",N?"border-primary/30 bg-white":"border-gray-200/70 bg-white"),imgClassName:"h-5 w-5 object-contain",fallback:e.jsx("span",{className:"text-sm font-semibold uppercase text-gray-500",children:o.name[0]})}),e.jsxs("div",{className:"min-w-0",children:[e.jsx("p",{className:"truncate text-sm font-semibold text-gray-900",children:r}),e.jsx("p",{className:"line-clamp-1 text-[11px] text-gray-500",children:T})]})]}),e.jsx(ye,{status:N?"ready":"setup",label:N?t("statusReady"):t("statusSetup"),className:"min-w-[56px] justify-center"})]})},o.name)}),A.length===0&&e.jsxs("div",{className:"flex h-full min-h-[220px] flex-col items-center justify-center rounded-xl border border-dashed border-gray-200 bg-gray-50/70 py-10 text-center",children:[e.jsx("div",{className:"mb-3 flex h-10 w-10 items-center justify-center rounded-lg bg-white",children:e.jsx(ue,{className:"h-5 w-5 text-gray-300"})}),e.jsx("p",{className:"text-sm font-medium text-gray-700",children:t("providersNoMatch")})]})]})]}),e.jsx(ts,{providerName:C,onProviderDeleted:o=>{o===y&&m(void 0)}})]})]})}export{xs as ProvidersList};
|
|
1
|
+
import{r as p,j as e,aa as Ae,ab as Ce,a8 as me,a6 as ne,ac as se,K as ue,a1 as Pe,m as De,ad as Le,ae as Me,af as Se,ag as te,a0 as Ee}from"./vendor-DN_iJQc4.js";import{I,u as xe,a as he,b as pe,g as Te,h as Be,i as Ke,j as $e}from"./useConfig-0trWsjx9.js";import{B as S,P as ke,a as Ie}from"./page-layout-C62p_dlG.js";import{L as W}from"./label-BowGMNYa.js";import{t,c as J,S as Fe,a as Oe,b as _e,d as Re,e as We}from"./index-C8UPX5Q7.js";import{C as He,a as ze,S as ye,b as Ge,c as Ve,L as qe,g as Ue}from"./logos-BlD3kGKz.js";import{h as q}from"./config-hints-CApS3K_7.js";import{T as Qe}from"./tabs-custom-D1fYWpL_.js";function Xe({maskedValue:s,isSet:a,className:n,...i}){const[u,b]=p.useState(!1);return e.jsxs("div",{className:"relative",children:[e.jsx(I,{type:u?"text":"password",className:J("pr-20",n),placeholder:a?`${t("apiKeySet")} (${t("unchanged")})`:"",...i}),e.jsx("div",{className:"absolute right-2 top-1/2 -translate-y-1/2 flex gap-1",children:(a||s)&&e.jsx(S,{type:"button",variant:"ghost",size:"icon",className:"h-7 w-7",onClick:()=>b(!u),children:u?e.jsx(Ae,{className:"h-4 w-4"}):e.jsx(Ce,{className:"h-4 w-4"})})})]})}function Ye({value:s,onChange:a,className:n}){const i=s?Object.entries(s):[],u=(m,x,g)=>{const f=[...i];f[m]=[x,g],a(Object.fromEntries(f))},b=()=>{a({...s,"":""})},y=m=>{const x=i.filter((g,f)=>f!==m);a(Object.fromEntries(x))};return e.jsxs("div",{className:J("space-y-2",n),children:[i.map(([m,x],g)=>e.jsxs("div",{className:"flex gap-2",children:[e.jsx(I,{type:"text",value:m,onChange:f=>u(g,f.target.value,x),placeholder:t("headerName"),className:"flex-1"}),e.jsx(I,{type:"text",value:x,onChange:f=>u(g,m,f.target.value),placeholder:t("headerValue"),className:"flex-1"}),e.jsx(S,{type:"button",variant:"ghost",size:"icon",onClick:()=>y(g),children:e.jsx(me,{className:"h-4 w-4 text-red-500"})})]},g)),e.jsxs(S,{type:"button",variant:"outline",size:"sm",onClick:b,children:[e.jsx(ne,{className:"h-4 w-4 mr-2"}),t("add")]})]})}function U(s){if(!s)return null;const a=Object.entries(s).map(([n,i])=>[n.trim(),i]).filter(([n])=>n.length>0);return a.length===0?null:Object.fromEntries(a)}function de(s,a){const n=U(s),i=U(a);if(n===null&&i===null)return!0;if(!n||!i)return!1;const u=Object.entries(n).sort(([y],[m])=>y.localeCompare(m)),b=Object.entries(i).sort(([y],[m])=>y.localeCompare(m));return u.length!==b.length?!1:u.every(([y,m],x)=>y===b[x][0]&&m===b[x][1])}function ae(s){if(!s||s.length===0)return[];const a=new Set;for(const n of s){const i=n.trim();i&&a.add(i)}return[...a]}function Je(s,a){const n=s.trim();if(!n||!a.trim())return n;const i=`${a.trim()}/`;return n.startsWith(i)?n.slice(i.length):n}function Y(s,a){let n=s.trim();if(!n)return"";for(const i of a){const u=i.trim();u&&(n=Je(n,u))}return n.trim()}function re(s,a){return s.length!==a.length?!1:s.every((n,i)=>n===a[i])}function Ze(s,a){const n=[...s];for(const i of a)n.includes(i)||n.push(i);return n}function es(s,a){return a.length===0?s:a.every(i=>!s.includes(i))?Ze(s,a):a}function ss(s,a){return re(s,a)?[]:s}function ts({providerName:s,onProviderDeleted:a}){const{data:n}=xe(),{data:i}=he(),{data:u}=pe(),b=Te(),y=Be(),m=Ke(),[x,g]=p.useState(""),[f,B]=p.useState(""),[K,F]=p.useState(null),[E,A]=p.useState("auto"),[C,$]=p.useState([]),[o,d]=p.useState(""),[N,v]=p.useState(""),r=i==null?void 0:i.providers.find(l=>l.name===s),c=s?n==null?void 0:n.providers[s]:null,L=u==null?void 0:u.uiHints,P=!!(r!=null&&r.isCustom),T=s?q(`providers.${s}.apiKey`,L):void 0,w=s?q(`providers.${s}.apiBase`,L):void 0,O=s?q(`providers.${s}.extraHeaders`,L):void 0,k=s?q(`providers.${s}.wireApi`,L):void 0,Z=(r==null?void 0:r.displayName)||s||"",_=((c==null?void 0:c.displayName)||"").trim()||Z,fe=N.trim()||_||s||t("providersSelectPlaceholder"),le=(r==null?void 0:r.modelPrefix)||s||"",R=p.useMemo(()=>ae([le,s||""]),[le,s]),Q=(r==null?void 0:r.defaultApiBase)||"",H=(c==null?void 0:c.apiBase)||Q,ee=U((c==null?void 0:c.extraHeaders)||null),z=(c==null?void 0:c.wireApi)||(r==null?void 0:r.defaultWireApi)||"auto",X=p.useMemo(()=>ae(((r==null?void 0:r.defaultModels)??[]).map(l=>Y(l,R))),[r==null?void 0:r.defaultModels,R]),ie=p.useMemo(()=>ae(((c==null?void 0:c.models)??[]).map(l=>Y(l,R))),[c==null?void 0:c.models,R]),G=p.useMemo(()=>es(X,ie),[X,ie]),ge=s==="minimax"?t("providerApiBaseHelpMinimax"):(w==null?void 0:w.help)||t("providerApiBaseHelp");p.useEffect(()=>{if(!s){g(""),B(""),F(null),A("auto"),$([]),d(""),v("");return}g(""),B(H),F((c==null?void 0:c.extraHeaders)||null),A(z),$(G),d(""),v(_)},[s,H,c==null?void 0:c.extraHeaders,z,G,_]);const ce=p.useMemo(()=>{if(!s)return!1;const l=x.trim().length>0,j=f.trim()!==H.trim(),D=!de(K,ee),h=r!=null&&r.supportsWireApi?E!==z:!1,M=!re(C,G),V=P?N.trim()!==_:!1;return l||j||D||h||M||V},[s,P,N,_,x,f,H,K,ee,r==null?void 0:r.supportsWireApi,E,z,C,G]),je=()=>{g(""),B(Q),F(null),A((r==null?void 0:r.defaultWireApi)||"auto"),$(X),d(""),v(Z)},oe=()=>{const l=Y(o,R);if(l){if(C.includes(l)){d("");return}$(j=>[...j,l]),d("")}},be=l=>{if(l.preventDefault(),!s)return;const j={},D=x.trim(),h=f.trim(),M=U(K),V=N.trim();P&&V!==_&&(j.displayName=V.length>0?V:null),D.length>0&&(j.apiKey=D),h!==H.trim()&&(j.apiBase=h.length>0&&h!==Q?h:null),de(M,ee)||(j.extraHeaders=M),r!=null&&r.supportsWireApi&&E!==z&&(j.wireApi=E),re(C,G)||(j.models=ss(C,X)),b.mutate({provider:s,data:j})},Ne=async()=>{if(!s)return;const l=C.find(h=>h.trim().length>0)??"",j=Y(l,R),D={apiBase:f.trim(),extraHeaders:U(K),model:j||null};x.trim().length>0&&(D.apiKey=x.trim()),r!=null&&r.supportsWireApi&&(D.wireApi=E);try{const h=await m.mutateAsync({provider:s,data:D});if(h.success){te.success(`${t("providerTestConnectionSuccess")} (${h.latencyMs}ms)`);return}const M=[`provider=${h.provider}`,`latency=${h.latencyMs}ms`];h.model&&M.push(`model=${h.model}`),te.error(`${t("providerTestConnectionFailed")}: ${h.message} | ${M.join(" | ")}`)}catch(h){const M=h instanceof Error?h.message:String(h);te.error(`${t("providerTestConnectionFailed")}: ${M}`)}},ve=async()=>{if(!(!s||!P||!window.confirm(t("providerDeleteConfirm"))))try{await y.mutateAsync({provider:s}),a==null||a(s)}catch{}};if(!s||!r||!c)return e.jsx("div",{className:He,children:e.jsxs("div",{children:[e.jsx("h3",{className:"text-base font-semibold text-gray-900",children:t("providersSelectTitle")}),e.jsx("p",{className:"mt-2 text-sm text-gray-500",children:t("providersSelectDescription")})]})});const we=c.apiKeySet?t("statusReady"):t("statusSetup");return e.jsxs("div",{className:ze,children:[e.jsx("div",{className:"border-b border-gray-100 px-6 py-5",children:e.jsxs("div",{className:"flex flex-wrap items-center justify-between gap-3",children:[e.jsxs("div",{className:"min-w-0",children:[e.jsx("h3",{className:"truncate text-lg font-semibold text-gray-900",children:fe}),e.jsx("p",{className:"mt-1 text-sm text-gray-500",children:t("providerFormDescription")})]}),e.jsx(ye,{status:c.apiKeySet?"ready":"setup",label:we})]})}),e.jsxs("form",{onSubmit:be,className:"flex min-h-0 flex-1 flex-col",children:[e.jsxs("div",{className:"min-h-0 flex-1 space-y-6 overflow-y-auto px-6 py-5",children:[P&&e.jsxs("div",{className:"space-y-2.5",children:[e.jsxs(W,{htmlFor:"providerDisplayName",className:"flex items-center gap-2 text-sm font-medium text-gray-900",children:[e.jsx(se,{className:"h-3.5 w-3.5 text-gray-500"}),t("providerDisplayName")]}),e.jsx(I,{id:"providerDisplayName",type:"text",value:N,onChange:l=>v(l.target.value),placeholder:Z||t("providerDisplayNamePlaceholder"),className:"rounded-xl"}),e.jsx("p",{className:"text-xs text-gray-500",children:t("providerDisplayNameHelp")})]}),e.jsxs("div",{className:"space-y-2.5",children:[e.jsxs(W,{htmlFor:"apiKey",className:"flex items-center gap-2 text-sm font-medium text-gray-900",children:[e.jsx(ue,{className:"h-3.5 w-3.5 text-gray-500"}),(T==null?void 0:T.label)??t("apiKey")]}),e.jsx(Xe,{id:"apiKey",value:x,isSet:c.apiKeySet,onChange:l=>g(l.target.value),placeholder:c.apiKeySet?t("apiKeySet"):(T==null?void 0:T.placeholder)??t("enterApiKey"),className:"rounded-xl"}),e.jsx("p",{className:"text-xs text-gray-500",children:t("leaveBlankToKeepUnchanged")})]}),e.jsxs("div",{className:"space-y-2.5",children:[e.jsxs(W,{htmlFor:"apiBase",className:"flex items-center gap-2 text-sm font-medium text-gray-900",children:[e.jsx(Pe,{className:"h-3.5 w-3.5 text-gray-500"}),(w==null?void 0:w.label)??t("apiBase")]}),e.jsx(I,{id:"apiBase",type:"text",value:f,onChange:l=>B(l.target.value),placeholder:Q||(w==null?void 0:w.placeholder)||"https://api.example.com",className:"rounded-xl"}),e.jsx("p",{className:"text-xs text-gray-500",children:ge}),P&&e.jsx("p",{className:"text-xs text-gray-500",children:t("providerOpenAICompatHint")})]}),r.supportsWireApi&&e.jsxs("div",{className:"space-y-2.5",children:[e.jsxs(W,{htmlFor:"wireApi",className:"flex items-center gap-2 text-sm font-medium text-gray-900",children:[e.jsx(se,{className:"h-3.5 w-3.5 text-gray-500"}),(k==null?void 0:k.label)??t("wireApi")]}),e.jsxs(Fe,{value:E,onValueChange:l=>A(l),children:[e.jsx(Oe,{className:"rounded-xl",children:e.jsx(_e,{})}),e.jsx(Re,{children:(r.wireApiOptions||["auto","chat","responses"]).map(l=>e.jsx(We,{value:l,children:l==="chat"?t("wireApiChat"):l==="responses"?t("wireApiResponses"):t("wireApiAuto")},l))})]}),(k==null?void 0:k.help)&&e.jsx("p",{className:"text-xs text-gray-500",children:k.help})]}),e.jsxs("div",{className:"space-y-2.5",children:[e.jsxs(W,{className:"flex items-center gap-2 text-sm font-medium text-gray-900",children:[e.jsx(se,{className:"h-3.5 w-3.5 text-gray-500"}),(O==null?void 0:O.label)??t("extraHeaders")]}),e.jsx(Ye,{value:K,onChange:F}),e.jsx("p",{className:"text-xs text-gray-500",children:(O==null?void 0:O.help)||t("providerExtraHeadersHelp")})]}),e.jsxs("div",{className:"space-y-2.5",children:[e.jsxs(W,{className:"flex items-center gap-2 text-sm font-medium text-gray-900",children:[e.jsx(De,{className:"h-3.5 w-3.5 text-gray-500"}),t("providerModelsTitle")]}),e.jsxs("div",{className:"flex items-center gap-2",children:[e.jsx(I,{value:o,onChange:l=>d(l.target.value),onKeyDown:l=>{l.key==="Enter"&&(l.preventDefault(),oe())},placeholder:t("providerModelInputPlaceholder"),className:"flex-1"}),e.jsxs(S,{type:"button",variant:"outline",onClick:oe,disabled:o.trim().length===0,children:[e.jsx(ne,{className:"mr-1.5 h-4 w-4"}),t("providerAddModel")]})]}),e.jsx("p",{className:"text-xs text-gray-500",children:t("providerModelInputHint")}),C.length===0?e.jsx("div",{className:"rounded-xl border border-dashed border-gray-200 bg-gray-50 px-3 py-2 text-xs text-gray-500",children:t("providerModelsEmpty")}):e.jsx("div",{className:"flex flex-wrap gap-2",children:C.map(l=>e.jsxs("div",{className:"group inline-flex max-w-full items-center gap-1 rounded-full border border-gray-200 bg-white px-3 py-1.5",children:[e.jsx("span",{className:"max-w-[180px] truncate text-sm text-gray-800 sm:max-w-[240px]",children:l}),e.jsx("button",{type:"button",onClick:()=>$(j=>j.filter(D=>D!==l)),className:"inline-flex h-5 w-5 items-center justify-center rounded-full text-gray-400 transition-opacity hover:bg-gray-100 hover:text-gray-600 opacity-100 md:opacity-0 md:group-hover:opacity-100 md:group-focus-within:opacity-100","aria-label":t("remove"),children:e.jsx(Le,{className:"h-3 w-3"})})]},l))}),e.jsx("p",{className:"text-xs text-gray-500",children:t("providerModelsHelp")})]})]}),e.jsxs("div",{className:"flex flex-wrap items-center justify-between gap-3 border-t border-gray-100 px-6 py-4",children:[e.jsxs("div",{className:"flex flex-wrap items-center gap-2",children:[e.jsxs(S,{type:"button",variant:"outline",onClick:je,children:[e.jsx(Me,{className:"mr-2 h-4 w-4"}),t("resetToDefault")]}),P&&e.jsxs(S,{type:"button",variant:"outline",onClick:ve,disabled:y.isPending,children:[e.jsx(me,{className:"mr-2 h-4 w-4"}),y.isPending?t("saving"):t("providerDelete")]}),e.jsxs(S,{type:"button",variant:"outline",onClick:Ne,disabled:m.isPending,children:[e.jsx(Se,{className:"mr-2 h-4 w-4"}),m.isPending?t("providerTestingConnection"):t("providerTestConnection")]})]}),e.jsx(S,{type:"submit",disabled:b.isPending||!ce,children:b.isPending?t("saving"):ce?t("save"):t("unchanged")})]})]})]})}function as(s){if(!s)return null;try{const a=new URL(s),n=a.pathname&&a.pathname!=="/"?a.pathname:"";return`${a.host}${n}`}catch{return s.replace(/^https?:\/\//,"")}}function xs(){const{data:s}=xe(),{data:a}=he(),{data:n}=pe(),i=$e(),[u,b]=p.useState("installed"),[y,m]=p.useState(),[x,g]=p.useState(""),f=n==null?void 0:n.uiHints,B=(a==null?void 0:a.providers)??[],K=(s==null?void 0:s.providers)??{},F=B.filter(o=>{var d;return(d=K[o.name])==null?void 0:d.apiKeySet}).length,E=[{id:"installed",label:t("providersTabConfigured"),count:F},{id:"all",label:t("providersTabAll"),count:B.length}],A=p.useMemo(()=>{const o=(a==null?void 0:a.providers)??[],d=(s==null?void 0:s.providers)??{},N=x.trim().toLowerCase();return o.filter(v=>{var r;return u==="installed"?!!((r=d[v.name])!=null&&r.apiKeySet):!0}).filter(v=>{var L,P;return N?(((P=(L=d[v.name])==null?void 0:L.displayName)==null?void 0:P.trim())||v.displayName||v.name).toLowerCase().includes(N)||v.name.toLowerCase().includes(N):!0})},[a,s,u,x]);p.useEffect(()=>{if(A.length===0){m(void 0);return}A.some(d=>d.name===y)||m(A[0].name)},[A,y]);const C=y,$=async()=>{try{const o=await i.mutateAsync({data:{}});b("all"),g(""),m(o.name)}catch{}};return!s||!a?e.jsx("div",{className:"p-8",children:t("providersLoading")}):e.jsxs(ke,{children:[e.jsx(Ie,{title:t("providersPageTitle"),description:t("providersPageDescription")}),e.jsxs("div",{className:Ge,children:[e.jsxs("section",{className:Ve,children:[e.jsxs("div",{className:"border-b border-gray-100 px-4 pt-4 pb-3 space-y-3",children:[e.jsx(Qe,{tabs:E,activeTab:u,onChange:b,className:"mb-0"}),e.jsxs(S,{type:"button",variant:"outline",className:"w-full justify-center",onClick:$,disabled:i.isPending,children:[e.jsx(ne,{className:"mr-2 h-4 w-4"}),i.isPending?t("saving"):t("providerAddCustom")]})]}),e.jsx("div",{className:"border-b border-gray-100 px-4 py-3",children:e.jsxs("div",{className:"relative",children:[e.jsx(Ee,{className:"pointer-events-none absolute left-3 top-1/2 h-4 w-4 -translate-y-1/2 text-gray-400"}),e.jsx(I,{value:x,onChange:o=>g(o.target.value),placeholder:t("providersFilterPlaceholder"),className:"h-10 rounded-xl pl-9"})]})}),e.jsxs("div",{className:"min-h-0 flex-1 space-y-2 overflow-y-auto p-3",children:[A.map(o=>{var w;const d=s.providers[o.name],N=!!(d!=null&&d.apiKeySet),v=C===o.name,r=((w=d==null?void 0:d.displayName)==null?void 0:w.trim())||o.displayName||o.name,c=q(`providers.${o.name}`,f),L=(d==null?void 0:d.apiBase)||o.defaultApiBase||"",T=as(L)||(c==null?void 0:c.help)||t("providersDefaultDescription");return e.jsx("button",{type:"button",onClick:()=>m(o.name),className:J("w-full rounded-xl border p-2.5 text-left transition-all",v?"border-primary/30 bg-primary-50/40 shadow-sm":"border-gray-200/70 bg-white hover:border-gray-300 hover:bg-gray-50/70"),children:e.jsxs("div",{className:"flex items-start justify-between gap-3",children:[e.jsxs("div",{className:"flex min-w-0 items-center gap-3",children:[e.jsx(qe,{name:o.name,src:Ue(o.name),className:J("h-10 w-10 rounded-lg border",N?"border-primary/30 bg-white":"border-gray-200/70 bg-white"),imgClassName:"h-5 w-5 object-contain",fallback:e.jsx("span",{className:"text-sm font-semibold uppercase text-gray-500",children:o.name[0]})}),e.jsxs("div",{className:"min-w-0",children:[e.jsx("p",{className:"truncate text-sm font-semibold text-gray-900",children:r}),e.jsx("p",{className:"line-clamp-1 text-[11px] text-gray-500",children:T})]})]}),e.jsx(ye,{status:N?"ready":"setup",label:N?t("statusReady"):t("statusSetup"),className:"min-w-[56px] justify-center"})]})},o.name)}),A.length===0&&e.jsxs("div",{className:"flex h-full min-h-[220px] flex-col items-center justify-center rounded-xl border border-dashed border-gray-200 bg-gray-50/70 py-10 text-center",children:[e.jsx("div",{className:"mb-3 flex h-10 w-10 items-center justify-center rounded-lg bg-white",children:e.jsx(ue,{className:"h-5 w-5 text-gray-300"})}),e.jsx("p",{className:"text-sm font-medium text-gray-700",children:t("providersNoMatch")})]})]})]}),e.jsx(ts,{providerName:C,onProviderDeleted:o=>{o===y&&m(void 0)}})]})]})}export{xs as ProvidersList};
|
|
@@ -1 +1 @@
|
|
|
1
|
-
import{r as p,j as e,a8 as Y,a6 as Z,al as le,ag as H}from"./vendor-DN_iJQc4.js";import{u as oe,b as ce,m as de,I as d}from"./useConfig-
|
|
1
|
+
import{r as p,j as e,a8 as Y,a6 as Z,al as le,ag as H}from"./vendor-DN_iJQc4.js";import{u as oe,b as ce,m as de,I as d}from"./useConfig-0trWsjx9.js";import{P as ie,a as me,B as N}from"./page-layout-C62p_dlG.js";import{C as B,a as M,b as O,c as R,d as $}from"./card-ITZ1xl10.js";import{S as he}from"./switch-CpKwqv79.js";import{t,S as ee,a as ae,b as se,d as te,e as P}from"./index-C8UPX5Q7.js";import{h as I}from"./config-hints-CApS3K_7.js";const ue=[{value:"main",label:"main"},{value:"per-peer",label:"per-peer"},{value:"per-channel-peer",label:"per-channel-peer"},{value:"per-account-channel-peer",label:"per-account-channel-peer"}];function pe(){return{id:"",default:!1,workspace:"",model:"",maxTokens:void 0,contextTokens:void 0,maxToolIterations:void 0}}function xe(){return{agentId:"",match:{channel:"",accountId:""}}}function z(i){const w=i.trim();if(!w)return;const x=Number.parseInt(w,10);return Number.isFinite(x)?x:void 0}function ye(){const{data:i,isLoading:w}=oe(),{data:x}=ce(),_=de(),[S,y]=p.useState([]),[D,b]=p.useState([]),[L,q]=p.useState("per-channel-peer"),[K,F]=p.useState(0),[V,U]=p.useState(2e5);p.useEffect(()=>{var a,r,n;i&&(y((i.agents.list??[]).map(s=>({id:s.id??"",default:!!s.default,workspace:s.workspace??"",model:s.model??"",maxTokens:s.maxTokens,contextTokens:s.contextTokens,maxToolIterations:s.maxToolIterations}))),b((i.bindings??[]).map(s=>{var o,l,c;return{agentId:s.agentId??"",match:{channel:((o=s.match)==null?void 0:o.channel)??"",accountId:((l=s.match)==null?void 0:l.accountId)??"",peer:(c=s.match)!=null&&c.peer?{kind:s.match.peer.kind,id:s.match.peer.id}:void 0}}})),q(((a=i.session)==null?void 0:a.dmScope)??"per-channel-peer"),F(((n=(r=i.session)==null?void 0:r.agentToAgent)==null?void 0:n.maxPingPongTurns)??0),U(i.agents.defaults.contextTokens??2e5))},[i]);const g=x==null?void 0:x.uiHints,h=I("session.dmScope",g),j=I("session.agentToAgent.maxPingPongTurns",g),f=I("agents.defaults.contextTokens",g),A=I("agents.list.*.contextTokens",g),v=I("agents.list",g),k=I("bindings",g),re=p.useMemo(()=>{const a=new Set(["main"]);return S.forEach(r=>{const n=r.id.trim();n&&a.add(n)}),a},[S]),u=(a,r)=>{y(n=>n.map((s,o)=>o===a?{...s,...r}:s))},T=(a,r)=>{b(n=>n.map((s,o)=>o===a?r:s))},ne=()=>{try{const a=S.map((s,o)=>{var m,C;const l=s.id.trim();if(!l)throw new Error(t("agentIdRequiredError").replace("{index}",String(o)));const c={id:l};return s.default&&(c.default=!0),(m=s.workspace)!=null&&m.trim()&&(c.workspace=s.workspace.trim()),(C=s.model)!=null&&C.trim()&&(c.model=s.model.trim()),typeof s.maxTokens=="number"&&(c.maxTokens=s.maxTokens),typeof s.contextTokens=="number"&&(c.contextTokens=Math.max(1e3,s.contextTokens)),typeof s.maxToolIterations=="number"&&(c.maxToolIterations=s.maxToolIterations),c}),r=a.map(s=>s.id).filter((s,o,l)=>l.indexOf(s)!==o);if(r.length>0){H.error(`${t("duplicateAgentId")}: ${r[0]}`);return}const n=D.map((s,o)=>{var J,Q,W,X;const l=s.agentId.trim(),c=s.match.channel.trim(),m=((J=s.match.accountId)==null?void 0:J.trim())??"",C=(Q=s.match.peer)==null?void 0:Q.kind,G=((X=(W=s.match.peer)==null?void 0:W.id)==null?void 0:X.trim())??"";if(!l)throw new Error(t("bindingAgentIdRequired").replace("{index}",String(o)));if(!re.has(l))throw new Error(`${t("bindingAgentIdNotFound").replace("{index}",String(o))}: ${l}`);if(!c)throw new Error(t("bindingChannelRequired").replace("{index}",String(o)));const E={agentId:l,match:{channel:c}};if(m&&(E.match.accountId=m),C){if(!G)throw new Error(t("bindingPeerIdRequired").replace("{index}",String(o)));E.match.peer={kind:C,id:G}}return E});_.mutate({data:{agents:{defaults:{contextTokens:Math.max(1e3,V)},list:a},bindings:n,session:{dmScope:L,agentToAgent:{maxPingPongTurns:Math.min(5,Math.max(0,K))}}}})}catch(a){const r=a instanceof Error?a.message:String(a);H.error(r)}};return w||!i?e.jsx("div",{className:"p-8 text-gray-400",children:t("runtimeLoading")}):e.jsxs(ie,{className:"space-y-6",children:[e.jsx(me,{title:t("runtimePageTitle"),description:t("runtimePageDescription")}),e.jsxs(B,{children:[e.jsxs(M,{children:[e.jsx(O,{children:(h==null?void 0:h.label)??t("dmScope")}),e.jsx(R,{children:(h==null?void 0:h.help)??t("dmScopeHelp")})]}),e.jsxs($,{className:"space-y-4",children:[e.jsxs("div",{className:"space-y-2",children:[e.jsx("label",{className:"text-sm font-medium text-gray-800",children:(f==null?void 0:f.label)??t("defaultContextTokens")}),e.jsx(d,{type:"number",min:1e3,step:1e3,value:V,onChange:a=>U(Math.max(1e3,Number.parseInt(a.target.value,10)||1e3))}),e.jsx("p",{className:"text-xs text-gray-500",children:(f==null?void 0:f.help)??t("defaultContextTokensHelp")})]}),e.jsxs("div",{className:"space-y-2",children:[e.jsx("label",{className:"text-sm font-medium text-gray-800",children:(h==null?void 0:h.label)??t("dmScope")}),e.jsxs(ee,{value:L,onValueChange:a=>q(a),children:[e.jsx(ae,{children:e.jsx(se,{})}),e.jsx(te,{children:ue.map(a=>e.jsx(P,{value:a.value,children:a.label},a.value))})]})]}),e.jsxs("div",{className:"space-y-2",children:[e.jsx("label",{className:"text-sm font-medium text-gray-800",children:(j==null?void 0:j.label)??t("maxPingPongTurns")}),e.jsx(d,{type:"number",min:0,max:5,value:K,onChange:a=>F(Math.max(0,Number.parseInt(a.target.value,10)||0))}),e.jsx("p",{className:"text-xs text-gray-500",children:(j==null?void 0:j.help)??t("maxPingPongTurnsHelp")})]})]})]}),e.jsxs(B,{children:[e.jsxs(M,{children:[e.jsx(O,{children:(v==null?void 0:v.label)??t("agentList")}),e.jsx(R,{children:(v==null?void 0:v.help)??t("agentListHelp")})]}),e.jsxs($,{className:"space-y-3",children:[S.map((a,r)=>e.jsxs("div",{className:"rounded-xl border border-gray-200 p-3 space-y-3",children:[e.jsxs("div",{className:"grid grid-cols-1 md:grid-cols-2 gap-3",children:[e.jsx(d,{value:a.id,onChange:n=>u(r,{id:n.target.value}),placeholder:t("agentIdPlaceholder")}),e.jsx(d,{value:a.workspace??"",onChange:n=>u(r,{workspace:n.target.value}),placeholder:t("workspaceOverridePlaceholder")}),e.jsx(d,{value:a.model??"",onChange:n=>u(r,{model:n.target.value}),placeholder:t("modelOverridePlaceholder")}),e.jsxs("div",{className:"grid grid-cols-1 md:grid-cols-3 gap-2",children:[e.jsx(d,{type:"number",min:1,value:a.maxTokens??"",onChange:n=>u(r,{maxTokens:z(n.target.value)}),placeholder:t("maxTokensPlaceholder")}),e.jsx(d,{type:"number",min:1e3,step:1e3,value:a.contextTokens??"",onChange:n=>u(r,{contextTokens:z(n.target.value)}),placeholder:(A==null?void 0:A.label)??t("contextTokensPlaceholder")}),e.jsx(d,{type:"number",min:1,value:a.maxToolIterations??"",onChange:n=>u(r,{maxToolIterations:z(n.target.value)}),placeholder:t("maxToolsPlaceholder")})]})]}),e.jsxs("div",{className:"flex items-center justify-between",children:[e.jsxs("div",{className:"flex items-center gap-2 text-sm text-gray-600",children:[e.jsx(he,{checked:!!a.default,onCheckedChange:n=>{if(!n){u(r,{default:!1});return}y(s=>s.map((o,l)=>({...o,default:l===r})))}}),e.jsx("span",{children:t("defaultAgent")})]}),e.jsxs(N,{type:"button",variant:"outline",size:"sm",onClick:()=>y(n=>n.filter((s,o)=>o!==r)),children:[e.jsx(Y,{className:"h-4 w-4 mr-1"}),t("remove")]})]})]},`${r}-${a.id}`)),e.jsxs(N,{type:"button",variant:"outline",onClick:()=>y(a=>[...a,pe()]),children:[e.jsx(Z,{className:"h-4 w-4 mr-2"}),t("addAgent")]})]})]}),e.jsxs(B,{children:[e.jsxs(M,{children:[e.jsx(O,{children:(k==null?void 0:k.label)??t("bindings")}),e.jsx(R,{children:(k==null?void 0:k.help)??t("bindingsHelp")})]}),e.jsxs($,{className:"space-y-3",children:[D.map((a,r)=>{var s,o;const n=((s=a.match.peer)==null?void 0:s.kind)??"";return e.jsxs("div",{className:"rounded-xl border border-gray-200 p-3 space-y-3",children:[e.jsxs("div",{className:"grid grid-cols-1 md:grid-cols-2 lg:grid-cols-3 gap-3",children:[e.jsx(d,{value:a.agentId,onChange:l=>T(r,{...a,agentId:l.target.value}),placeholder:t("targetAgentIdPlaceholder")}),e.jsx(d,{value:a.match.channel,onChange:l=>T(r,{...a,match:{...a.match,channel:l.target.value}}),placeholder:t("channelPlaceholder")}),e.jsx(d,{value:a.match.accountId??"",onChange:l=>T(r,{...a,match:{...a.match,accountId:l.target.value}}),placeholder:t("accountIdOptionalPlaceholder")}),e.jsxs(ee,{value:n||"__none__",onValueChange:l=>{var m;const c=l==="__none__"?"":l;if(!c){T(r,{...a,match:{...a.match,peer:void 0}});return}T(r,{...a,match:{...a.match,peer:{kind:c,id:((m=a.match.peer)==null?void 0:m.id)??""}}})},children:[e.jsx(ae,{children:e.jsx(se,{})}),e.jsxs(te,{children:[e.jsx(P,{value:"__none__",children:t("peerKindOptional")}),e.jsx(P,{value:"direct",children:"direct"}),e.jsx(P,{value:"group",children:"group"}),e.jsx(P,{value:"channel",children:"channel"})]})]}),e.jsx(d,{value:((o=a.match.peer)==null?void 0:o.id)??"",onChange:l=>T(r,{...a,match:{...a.match,peer:n?{kind:n,id:l.target.value}:void 0}}),placeholder:t("peerIdPlaceholder")})]}),e.jsx("div",{className:"flex justify-end",children:e.jsxs(N,{type:"button",variant:"outline",size:"sm",onClick:()=>b(l=>l.filter((c,m)=>m!==r)),children:[e.jsx(Y,{className:"h-4 w-4 mr-1"}),t("remove")]})})]},`${r}-${a.agentId}`)}),e.jsxs(N,{type:"button",variant:"outline",onClick:()=>b(a=>[...a,xe()]),children:[e.jsx(Z,{className:"h-4 w-4 mr-2"}),t("addBinding")]})]})]}),e.jsx("div",{className:"flex justify-end",children:e.jsxs(N,{type:"button",onClick:ne,disabled:_.isPending,children:[e.jsx(le,{className:"h-4 w-4 mr-2"}),_.isPending?t("saving"):t("saveRuntimeSettings")]})})]})}export{ye as RuntimeConfig};
|
|
@@ -1,3 +1,3 @@
|
|
|
1
|
-
import{r as u,j as e,a8 as H,a6 as L,al as G,ag as J}from"./vendor-DN_iJQc4.js";import{u as K,t as Q,I as h}from"./useConfig-
|
|
1
|
+
import{r as u,j as e,a8 as H,a6 as L,al as G,ag as J}from"./vendor-DN_iJQc4.js";import{u as K,t as Q,I as h}from"./useConfig-0trWsjx9.js";import{P as W,a as X,B as _}from"./page-layout-C62p_dlG.js";import{C as R,a as T,b as M,c as O,d as A}from"./card-ITZ1xl10.js";import{L as k}from"./label-BowGMNYa.js";import{t as a,S as x,a as m,b as p,d as j,e as o}from"./index-C8UPX5Q7.js";import{S as Y}from"./switch-CpKwqv79.js";const U=["env","file","exec"];function N(n=""){return{alias:n,source:"env",prefix:"",path:"",command:"",argsText:"",cwd:"",timeoutMs:5e3}}function Z(){return{path:"",source:"env",provider:"",id:""}}function ee(n,l){return l.source==="env"?{...N(n),source:"env",prefix:l.prefix??""}:l.source==="file"?{...N(n),source:"file",path:l.path}:{...N(n),source:"exec",command:l.command,argsText:(l.args??[]).join(`
|
|
2
2
|
`),cwd:l.cwd??"",timeoutMs:l.timeoutMs??5e3}}function se(n){return n.source==="env"?{source:"env",...n.prefix.trim()?{prefix:n.prefix.trim()}:{}}:n.source==="file"?{source:"file",path:n.path.trim(),format:"json"}:{source:"exec",command:n.command.trim(),args:n.argsText.split(`
|
|
3
3
|
`).map(l=>l.trim()).filter(Boolean),...n.cwd.trim()?{cwd:n.cwd.trim()}:{},timeoutMs:Math.max(1,Math.trunc(n.timeoutMs||5e3))}}function oe(){const{data:n,isLoading:l}=K(),P=Q(),[D,y]=u.useState(!0),[I,E]=u.useState(""),[V,S]=u.useState(""),[F,$]=u.useState(""),[C,f]=u.useState([]),[q,v]=u.useState([]);u.useEffect(()=>{const s=n==null?void 0:n.secrets;if(!s){y(!0),E(""),S(""),$(""),f([]),v([]);return}y(!!s.enabled),E(s.defaults.env??""),S(s.defaults.file??""),$(s.defaults.exec??"");const t=Object.entries(s.providers).map(([c,i])=>ee(c,i)),r=Object.entries(s.refs).map(([c,i])=>({path:c,source:i.source,provider:i.provider??"",id:i.id}));f(t),v(r)},[n==null?void 0:n.secrets]);const w=u.useMemo(()=>{const s=C.map(t=>t.alias.trim()).filter(Boolean);return Array.from(new Set(s))},[C]),d=(s,t)=>{f(r=>r.map((c,i)=>i===s?{...c,...t}:c))},b=(s,t)=>{v(r=>r.map((c,i)=>i===s?{...c,...t}:c))},z=()=>{try{const s={};for(const[r,c]of C.entries()){const i=c.alias.trim();if(!i)throw new Error(`${a("providerAlias")} #${r+1} ${a("isRequired")}`);if(s[i])throw new Error(`${a("providerAlias")}: ${i} (${a("duplicate")})`);if(c.source==="file"&&!c.path.trim())throw new Error(`${a("secretFilePath")} #${r+1} ${a("isRequired")}`);if(c.source==="exec"&&!c.command.trim())throw new Error(`${a("secretExecCommand")} #${r+1} ${a("isRequired")}`);s[i]=se(c)}const t={};for(const[r,c]of q.entries()){const i=c.path.trim(),B=c.id.trim();if(!i)throw new Error(`${a("secretConfigPath")} #${r+1} ${a("isRequired")}`);if(!B)throw new Error(`${a("secretId")} #${r+1} ${a("isRequired")}`);const g=c.provider.trim();if(g&&!s[g])throw new Error(`${a("secretProviderAlias")}: ${g} ${a("notFound")}`);t[i]={source:c.source,...g?{provider:g}:{},id:B}}P.mutate({data:{enabled:D,defaults:{env:I.trim()||null,file:V.trim()||null,exec:F.trim()||null},providers:s,refs:t}})}catch(s){const t=s instanceof Error?s.message:String(s);J.error(t)}};return l?e.jsx("div",{className:"p-8 text-gray-400",children:a("loading")}):e.jsxs(W,{className:"space-y-6",children:[e.jsx(X,{title:a("secretsPageTitle"),description:a("secretsPageDescription")}),e.jsxs(R,{children:[e.jsxs(T,{children:[e.jsx(M,{children:a("secrets")}),e.jsx(O,{children:a("secretsEnabledHelp")})]}),e.jsxs(A,{className:"space-y-4",children:[e.jsxs("div",{className:"flex items-center justify-between rounded-xl border border-gray-200 p-3",children:[e.jsxs("div",{children:[e.jsx("p",{className:"text-sm font-medium text-gray-800",children:a("enabled")}),e.jsx("p",{className:"text-xs text-gray-500",children:a("secretsEnabledHelp")})]}),e.jsx(Y,{checked:D,onCheckedChange:y})]}),e.jsxs("div",{className:"grid grid-cols-1 md:grid-cols-3 gap-3",children:[e.jsxs("div",{className:"space-y-2",children:[e.jsx(k,{children:a("defaultEnvProvider")}),e.jsxs(x,{value:I||"__none__",onValueChange:s=>E(s==="__none__"?"":s),children:[e.jsx(m,{children:e.jsx(p,{placeholder:a("noneOption")})}),e.jsxs(j,{children:[e.jsx(o,{value:"__none__",children:a("noneOption")}),w.map(s=>e.jsx(o,{value:s,children:s},s))]})]})]}),e.jsxs("div",{className:"space-y-2",children:[e.jsx(k,{children:a("defaultFileProvider")}),e.jsxs(x,{value:V||"__none__",onValueChange:s=>S(s==="__none__"?"":s),children:[e.jsx(m,{children:e.jsx(p,{placeholder:a("noneOption")})}),e.jsxs(j,{children:[e.jsx(o,{value:"__none__",children:a("noneOption")}),w.map(s=>e.jsx(o,{value:s,children:s},s))]})]})]}),e.jsxs("div",{className:"space-y-2",children:[e.jsx(k,{children:a("defaultExecProvider")}),e.jsxs(x,{value:F||"__none__",onValueChange:s=>$(s==="__none__"?"":s),children:[e.jsx(m,{children:e.jsx(p,{placeholder:a("noneOption")})}),e.jsxs(j,{children:[e.jsx(o,{value:"__none__",children:a("noneOption")}),w.map(s=>e.jsx(o,{value:s,children:s},s))]})]})]})]})]})]}),e.jsxs(R,{children:[e.jsxs(T,{children:[e.jsx(M,{children:a("secretProvidersTitle")}),e.jsx(O,{children:a("secretProvidersDescription")})]}),e.jsxs(A,{className:"space-y-3",children:[C.map((s,t)=>e.jsxs("div",{className:"rounded-xl border border-gray-200 p-3 space-y-3",children:[e.jsxs("div",{className:"grid grid-cols-1 md:grid-cols-3 gap-3",children:[e.jsx(h,{value:s.alias,onChange:r=>d(t,{alias:r.target.value}),placeholder:a("providerAlias")}),e.jsxs(x,{value:s.source,onValueChange:r=>d(t,{source:r}),children:[e.jsx(m,{children:e.jsx(p,{})}),e.jsx(j,{children:U.map(r=>e.jsx(o,{value:r,children:r},r))})]}),e.jsxs(_,{type:"button",variant:"outline",onClick:()=>f(r=>r.filter((c,i)=>i!==t)),children:[e.jsx(H,{className:"h-4 w-4 mr-2"}),a("removeProvider")]})]}),s.source==="env"&&e.jsx(h,{value:s.prefix,onChange:r=>d(t,{prefix:r.target.value}),placeholder:a("envPrefix")}),s.source==="file"&&e.jsx(h,{value:s.path,onChange:r=>d(t,{path:r.target.value}),placeholder:a("secretFilePath")}),s.source==="exec"&&e.jsxs("div",{className:"space-y-2",children:[e.jsx(h,{value:s.command,onChange:r=>d(t,{command:r.target.value}),placeholder:a("secretExecCommand")}),e.jsx("textarea",{className:"min-h-[84px] w-full rounded-lg border border-gray-200 bg-white px-3 py-2 text-xs font-mono",value:s.argsText,onChange:r=>d(t,{argsText:r.target.value}),placeholder:a("secretExecArgs")}),e.jsxs("div",{className:"grid grid-cols-1 md:grid-cols-2 gap-2",children:[e.jsx(h,{value:s.cwd,onChange:r=>d(t,{cwd:r.target.value}),placeholder:a("secretExecCwd")}),e.jsx(h,{type:"number",min:1,value:s.timeoutMs,onChange:r=>d(t,{timeoutMs:Number.parseInt(r.target.value,10)||5e3}),placeholder:a("secretExecTimeoutMs")})]})]})]},`provider-${t}`)),e.jsxs(_,{type:"button",variant:"outline",onClick:()=>f(s=>[...s,N()]),children:[e.jsx(L,{className:"h-4 w-4 mr-2"}),a("addSecretProvider")]})]})]}),e.jsxs(R,{children:[e.jsxs(T,{children:[e.jsx(M,{children:a("secretRefsTitle")}),e.jsx(O,{children:a("secretRefsDescription")})]}),e.jsxs(A,{className:"space-y-3",children:[q.map((s,t)=>e.jsx("div",{className:"rounded-xl border border-gray-200 p-3 space-y-3",children:e.jsxs("div",{className:"grid grid-cols-1 md:grid-cols-2 gap-3",children:[e.jsx(h,{value:s.path,onChange:r=>b(t,{path:r.target.value}),placeholder:a("secretConfigPath")}),e.jsx(h,{value:s.id,onChange:r=>b(t,{id:r.target.value}),placeholder:a("secretId")}),e.jsxs(x,{value:s.source,onValueChange:r=>b(t,{source:r}),children:[e.jsx(m,{children:e.jsx(p,{})}),e.jsx(j,{children:U.map(r=>e.jsx(o,{value:r,children:r},r))})]}),e.jsxs("div",{className:"grid grid-cols-[1fr_auto] gap-2",children:[e.jsxs(x,{value:s.provider||"__none__",onValueChange:r=>b(t,{provider:r==="__none__"?"":r}),children:[e.jsx(m,{children:e.jsx(p,{placeholder:a("secretProviderAlias")})}),e.jsxs(j,{children:[e.jsx(o,{value:"__none__",children:a("noneOption")}),w.map(r=>e.jsx(o,{value:r,children:r},r))]})]}),e.jsx(_,{type:"button",variant:"outline",onClick:()=>v(r=>r.filter((c,i)=>i!==t)),children:e.jsx(H,{className:"h-4 w-4"})})]})]})},`ref-${t}`)),e.jsxs(_,{type:"button",variant:"outline",onClick:()=>v(s=>[...s,Z()]),children:[e.jsx(L,{className:"h-4 w-4 mr-2"}),a("addSecretRef")]})]})]}),e.jsx("div",{className:"flex justify-end",children:e.jsxs(_,{type:"button",onClick:z,disabled:P.isPending,children:[e.jsx(G,{className:"h-4 w-4 mr-2"}),P.isPending?a("saving"):a("save")]})})]})}export{oe as SecretsConfig};
|
|
@@ -1,2 +1,2 @@
|
|
|
1
|
-
import{r as l,j as e,a5 as T,a0 as Y,am as A,ac as $,aj as W,M as U,an as X,X as G,Y as J}from"./vendor-DN_iJQc4.js";import{u as Z}from"./useConfirmDialog-
|
|
1
|
+
import{r as l,j as e,a5 as T,a0 as Y,am as A,ac as $,aj as W,M as U,an as X,X as G,Y as J}from"./vendor-DN_iJQc4.js";import{u as Z}from"./useConfirmDialog-B_7sVz-j.js";import{d as ee,e as se,n as te,f as ae,I as S}from"./useConfig-0trWsjx9.js";import{P as re,a as le,B as g}from"./page-layout-C62p_dlG.js";import{t,c as o,S as ne,a as ie,b as oe,d as de,e as K,i as ce,g as xe}from"./index-C8UPX5Q7.js";import{e as me}from"./chat-message-D0s61C4e.js";const u="__unknown_channel__";function he(a){return xe(a)}function j(a){const n=a.indexOf(":");return n<=0?u:a.slice(0,n).trim()||u}function C(a){return a===u?t("sessionsUnknownChannel"):a}function ge({session:a,channel:n,isSelected:i,onSelect:f}){const r=C(n),p=a.label||a.key.split(":").pop()||a.key;return e.jsxs("button",{onClick:f,className:o("w-full text-left p-3.5 rounded-xl transition-all duration-200 outline-none focus:outline-none focus:ring-0 group",i?"bg-brand-50 border border-brand-100/50":"bg-transparent border border-transparent hover:bg-gray-50/80"),children:[e.jsxs("div",{className:"flex items-start justify-between mb-1.5",children:[e.jsx("div",{className:o("font-semibold truncate pr-2 flex-1 text-sm",i?"text-brand-800":"text-gray-900"),children:p}),e.jsx("div",{className:o("text-[10px] font-bold px-2 py-0.5 rounded-full shrink-0 capitalize",i?"bg-white text-brand-600 shadow-[0_1px_2px_rgba(0,0,0,0.02)]":"bg-gray-100 text-gray-500"),children:r})]}),e.jsxs("div",{className:o("flex items-center text-xs justify-between mt-2 font-medium",i?"text-brand-600/80":"text-gray-400"),children:[e.jsxs("div",{className:"flex items-center gap-1.5",children:[e.jsx(X,{className:"w-3.5 h-3.5 opacity-70"}),e.jsx("span",{className:"truncate max-w-[100px]",children:ce(a.updatedAt)})]}),e.jsxs("div",{className:"flex items-center gap-1",children:[e.jsx(U,{className:"w-3.5 h-3.5 opacity-70"}),e.jsx("span",{children:a.messageCount})]})]})]})}function ue({message:a}){const n=a.role.toLowerCase()==="user",i=me(a.content).trim();return e.jsx("div",{className:o("flex w-full mb-6",n?"justify-end":"justify-start"),children:e.jsxs("div",{className:o("max-w-[85%] rounded-[1.25rem] p-5 flex gap-3 text-sm",n?"bg-primary text-white rounded-tr-sm":"bg-gray-50 text-gray-800 rounded-tl-sm border border-gray-100/50"),children:[e.jsx("div",{className:"shrink-0 pt-0.5",children:n?e.jsx(G,{className:"w-4 h-4 text-primary-100"}):e.jsx(J,{className:"w-4 h-4 text-gray-400"})}),e.jsxs("div",{className:"flex-1 space-y-1 overflow-x-hidden",children:[e.jsxs("div",{className:"flex items-baseline justify-between gap-4 mb-2",children:[e.jsx("span",{className:o("font-semibold text-xs",n?"text-primary-50":"text-gray-900 capitalize"),children:a.role}),e.jsx("span",{className:o("text-[10px]",n?"text-primary-200":"text-gray-400"),children:he(a.timestamp)})]}),e.jsx("div",{className:"whitespace-pre-wrap break-words leading-relaxed text-[15px]",children:i||"-"})]})]})})}function Ne(){var z,H,E;const[a,n]=l.useState(""),[i]=l.useState(100),[f]=l.useState(0),[r,p]=l.useState(null),[y,B]=l.useState("all"),[M,v]=l.useState(""),[L,N]=l.useState(""),[w,k]=l.useState(!1),F=l.useMemo(()=>({q:a.trim()||void 0,limit:i,activeMinutes:f}),[a,i,f]),h=ee(F),x=se(r,200),b=te(),D=ae(),{confirm:_,ConfirmDialog:Q}=Z(),c=l.useMemo(()=>{var s;return((s=h.data)==null?void 0:s.sessions)??[]},[(z=h.data)==null?void 0:z.sessions]),d=l.useMemo(()=>c.find(s=>s.key===r),[c,r]),q=l.useMemo(()=>{const s=new Set;for(const m of c)s.add(j(m.key));return Array.from(s).sort((m,I)=>m===u?1:I===u?-1:m.localeCompare(I))},[c]),P=l.useMemo(()=>y==="all"?c:c.filter(s=>j(s.key)===y),[c,y]);l.useEffect(()=>{d?(v(d.label||""),N(d.preferredModel||"")):(v(""),N("")),k(!1)},[d]);const O=()=>{r&&(b.mutate({key:r,data:{label:M.trim()||null,preferredModel:L.trim()||null}}),k(!1))},R=async()=>{if(!r)return;await _({title:t("sessionsClearHistory")+"?",variant:"destructive",confirmLabel:t("sessionsClearHistory")})&&b.mutate({key:r,data:{clearHistory:!0}})},V=async()=>{if(!r)return;await _({title:t("sessionsDeleteConfirm")+"?",variant:"destructive",confirmLabel:t("sessionsDeleteConfirm")})&&D.mutate({key:r},{onSuccess:()=>p(null)})};return e.jsxs(re,{fullHeight:!0,children:[e.jsx(le,{title:t("sessionsPageTitle"),description:t("sessionsPageDescription")}),e.jsxs("div",{className:"flex-1 flex gap-6 min-h-0 relative",children:[e.jsxs("div",{className:"w-[320px] flex flex-col shrink-0 bg-white rounded-2xl shadow-sm border border-gray-200 overflow-hidden",children:[e.jsxs("div",{className:"px-4 py-4 border-b border-gray-100 bg-white z-10 shrink-0 space-y-3",children:[e.jsxs("div",{className:"flex items-center justify-between",children:[e.jsxs("span",{className:"text-[11px] font-semibold text-gray-400 uppercase tracking-wider",children:[c.length," ",t("sessionsListTitle")]}),e.jsx(g,{variant:"ghost",size:"icon",className:"h-7 w-7 rounded-lg text-gray-400 hover:text-gray-700 hover:bg-gray-100",onClick:()=>h.refetch(),children:e.jsx(T,{className:o("h-3.5 w-3.5",h.isFetching&&"animate-spin")})})]}),e.jsxs(ne,{value:y,onValueChange:B,children:[e.jsx(ie,{className:"w-full h-8.5 rounded-lg bg-gray-50/50 hover:bg-gray-100 border-gray-200 focus:ring-0 shadow-none text-xs font-medium text-gray-700",children:e.jsx(oe,{placeholder:t("sessionsAllChannels")})}),e.jsxs(de,{className:"rounded-xl shadow-lg border-gray-100 max-w-[280px]",children:[e.jsx(K,{value:"all",className:"rounded-lg text-xs",children:t("sessionsAllChannels")}),q.map(s=>e.jsx(K,{value:s,className:"rounded-lg text-xs truncate pr-6",children:C(s)},s))]})]}),e.jsxs("div",{className:"relative w-full",children:[e.jsx(Y,{className:"h-3.5 w-3.5 absolute left-3 top-2.5 text-gray-400"}),e.jsx(S,{value:a,onChange:s=>n(s.target.value),placeholder:t("sessionsSearchPlaceholder"),className:"pl-8 h-8.5 rounded-lg bg-gray-50/50 border-gray-200 focus-visible:bg-white text-xs"})]})]}),e.jsx("div",{className:"flex-1 overflow-y-auto p-3 space-y-1 pb-10 custom-scrollbar relative",children:h.isLoading?e.jsx("div",{className:"text-sm text-gray-400 p-4 text-center",children:t("sessionsLoading")}):P.length===0?e.jsxs("div",{className:"text-sm text-gray-400 p-4 text-center border-2 border-dashed border-gray-100 rounded-xl mt-4",children:[e.jsx(A,{className:"w-8 h-8 mx-auto mb-2 text-gray-300"}),t("sessionsEmpty")]}):P.map(s=>e.jsx(ge,{session:s,channel:j(s.key),isSelected:r===s.key,onSelect:()=>p(s.key)},s.key))})]}),e.jsxs("div",{className:"flex-1 min-w-0 flex flex-col overflow-hidden relative bg-white rounded-2xl shadow-sm border border-gray-200",children:[(b.isPending||D.isPending)&&e.jsx("div",{className:"absolute top-0 left-0 w-full h-1 bg-primary/20 overflow-hidden z-20",children:e.jsx("div",{className:"h-full bg-primary animate-pulse w-1/3 rounded-r-full"})}),r&&d?e.jsxs(e.Fragment,{children:[e.jsxs("div",{className:"shrink-0 border-b border-gray-100 bg-white px-8 py-5 z-10 space-y-4",children:[e.jsxs("div",{className:"flex items-center justify-between",children:[e.jsxs("div",{className:"flex items-center gap-4",children:[e.jsx("div",{className:"h-12 w-12 rounded-[14px] bg-gray-50 border border-gray-100 flex items-center justify-center text-gray-400 shrink-0",children:e.jsx($,{className:"h-6 w-6"})}),e.jsxs("div",{children:[e.jsxs("div",{className:"flex items-center gap-2.5 mb-1.5",children:[e.jsx("h3",{className:"text-lg font-bold text-gray-900 tracking-tight",children:d.label||d.key.split(":").pop()||d.key}),e.jsx("span",{className:"text-[10px] font-bold px-2 py-0.5 rounded-full bg-gray-100 text-gray-500 uppercase tracking-widest",children:C(j(d.key))})]}),e.jsx("div",{className:"text-xs text-gray-500 font-mono break-all line-clamp-1 opacity-70",title:r,children:r})]})]}),e.jsxs("div",{className:"flex items-center gap-2 shrink-0",children:[e.jsxs(g,{variant:"outline",size:"sm",onClick:()=>k(!w),className:o("h-8.5 rounded-lg shadow-none border-gray-200 transition-all text-xs font-semibold",w?"bg-gray-100 text-gray-900":"hover:bg-gray-50 hover:text-gray-900"),children:[e.jsx(W,{className:"w-3.5 h-3.5 mr-1.5"}),t("sessionsMetadata")]}),e.jsx(g,{variant:"outline",size:"sm",onClick:R,className:"h-8.5 rounded-lg shadow-none hover:bg-gray-50 hover:text-gray-900 border-gray-200 text-xs font-semibold text-gray-500",children:t("sessionsClearHistory")}),e.jsx(g,{variant:"outline",size:"sm",onClick:V,className:"h-8.5 rounded-lg shadow-none hover:bg-red-50 hover:text-red-600 hover:border-red-200 border-gray-200 text-xs font-semibold text-red-500",children:t("delete")})]})]}),w&&e.jsxs("div",{className:"flex items-center gap-3 bg-gray-50/50 p-3 rounded-lg border border-gray-100 animate-slide-in",children:[e.jsx(S,{placeholder:t("sessionsLabelPlaceholder"),value:M,onChange:s=>v(s.target.value),className:"h-8 text-sm bg-white"}),e.jsx(S,{placeholder:t("sessionsModelPlaceholder"),value:L,onChange:s=>N(s.target.value),className:"h-8 text-sm bg-white"}),e.jsx(g,{size:"sm",onClick:O,className:"h-8 px-4 shrink-0 shadow-none",disabled:b.isPending,children:t("sessionsSaveMeta")})]})]}),e.jsxs("div",{className:`flex-1 overflow-y-auto p-6 relative
|
|
2
2
|
[&::-webkit-scrollbar]:w-2 [&::-webkit-scrollbar-thumb]:bg-gray-300/80 [&::-webkit-scrollbar-thumb]:rounded-full`,children:[x.isLoading&&e.jsx("div",{className:"absolute inset-0 flex items-center justify-center bg-gray-50/50 backdrop-blur-sm z-10",children:e.jsxs("div",{className:"flex flex-col items-center gap-3 animate-pulse",children:[e.jsx(T,{className:"w-6 h-6 text-primary animate-spin"}),e.jsx("span",{className:"text-sm font-medium text-gray-500",children:t("sessionsHistoryLoading")})]})}),x.error&&e.jsx("div",{className:"text-center p-6 bg-red-50 rounded-xl text-red-600 border border-red-100 text-sm",children:x.error.message}),!x.isLoading&&((H=x.data)==null?void 0:H.messages.length)===0&&e.jsxs("div",{className:"h-full flex flex-col items-center justify-center text-gray-400",children:[e.jsx(U,{className:"w-12 h-12 mb-3 text-gray-300"}),e.jsx("p",{className:"text-sm",children:t("sessionsEmpty")})]}),e.jsx("div",{className:"max-w-3xl mx-auto",children:(((E=x.data)==null?void 0:E.messages)??[]).map((s,m)=>e.jsx(ue,{message:s},`${s.timestamp}-${m}`))})]})]}):e.jsxs("div",{className:"flex-1 flex flex-col items-center justify-center text-gray-400 p-8 h-full bg-white",children:[e.jsx("div",{className:"w-20 h-20 bg-gray-50 rounded-3xl flex items-center justify-center mb-6 border border-gray-100 shadow-[0_2px_8px_-2px_rgba(0,0,0,0.02)] rotate-3",children:e.jsx(A,{className:"h-8 w-8 text-gray-300 -rotate-3"})}),e.jsx("h3",{className:"text-lg font-bold text-gray-900 mb-2",children:t("sessionsNoSelectionTitle")}),e.jsx("p",{className:"text-sm text-center max-w-sm leading-relaxed",children:t("sessionsNoSelectionDescription")})]})]})]}),e.jsx(Q,{})]})}export{Ne as SessionsConfig};
|
|
@@ -1 +1 @@
|
|
|
1
|
-
import{r as s,j as t}from"./vendor-DN_iJQc4.js";import{c as d}from"./index-
|
|
1
|
+
import{r as s,j as t}from"./vendor-DN_iJQc4.js";import{c as d}from"./index-C8UPX5Q7.js";const i=s.forwardRef(({className:a,hover:e=!0,...r},o)=>t.jsx("div",{ref:o,className:d("rounded-2xl border border-gray-200/50 bg-white text-card-foreground shadow-card transition-all duration-base",e&&"hover:shadow-card-hover hover:border-gray-200",a),...r}));i.displayName="Card";const c=s.forwardRef(({className:a,...e},r)=>t.jsx("div",{ref:r,className:d("flex flex-col space-y-1.5 p-6",a),...e}));c.displayName="CardHeader";const l=s.forwardRef(({className:a,...e},r)=>t.jsx("h3",{ref:r,className:d("text-[15px] font-semibold leading-tight tracking-tight text-gray-900",a),...e}));l.displayName="CardTitle";const n=s.forwardRef(({className:a,...e},r)=>t.jsx("p",{ref:r,className:d("text-[13px] text-gray-400 leading-relaxed",a),...e}));n.displayName="CardDescription";const p=s.forwardRef(({className:a,...e},r)=>t.jsx("div",{ref:r,className:d("p-6 pt-0",a),...e}));p.displayName="CardContent";const x=s.forwardRef(({className:a,...e},r)=>t.jsx("div",{ref:r,className:d("flex items-center justify-between p-6 pt-0",a),...e}));x.displayName="CardFooter";export{i as C,c as a,l as b,n as c,p as d};
|