@samanhappy/mcphub 1.0.1 → 1.0.2
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/dist/betterAuth.js +21 -0
- package/dist/betterAuth.js.map +1 -1
- package/dist/controllers/serverController.js +3 -0
- package/dist/controllers/serverController.js.map +1 -1
- package/dist/dao/ActivityDao.js +2 -0
- package/dist/dao/ActivityDao.js.map +1 -1
- package/dist/db/entities/Activity.js +4 -0
- package/dist/db/entities/Activity.js.map +1 -1
- package/dist/services/activityLoggingService.js +1 -0
- package/dist/services/activityLoggingService.js.map +1 -1
- package/dist/services/betterAuthConfig.js +18 -1
- package/dist/services/betterAuthConfig.js.map +1 -1
- package/dist/services/mcpService.js +41 -12
- package/dist/services/mcpService.js.map +1 -1
- package/dist/utils/rateLimit.js +3 -3
- package/frontend/dist/assets/ActivityPage-B1B9ySGe.js +2 -0
- package/frontend/dist/assets/ActivityPage-B1B9ySGe.js.map +1 -0
- package/frontend/dist/assets/{Dashboard-BUCJcvk-.js → Dashboard-CYzpYZ1d.js} +2 -2
- package/frontend/dist/assets/{Dashboard-BUCJcvk-.js.map → Dashboard-CYzpYZ1d.js.map} +1 -1
- package/frontend/dist/assets/{EndpointCopy-D5NjDdYi.js → EndpointCopy-DVmlWW-s.js} +2 -2
- package/frontend/dist/assets/{EndpointCopy-D5NjDdYi.js.map → EndpointCopy-DVmlWW-s.js.map} +1 -1
- package/frontend/dist/assets/{GroupsPage-DfLlww4U.js → GroupsPage-CsyoUc8S.js} +2 -2
- package/frontend/dist/assets/{GroupsPage-DfLlww4U.js.map → GroupsPage-CsyoUc8S.js.map} +1 -1
- package/frontend/dist/assets/LoginPage-C3t8hbb2.js +2 -0
- package/frontend/dist/assets/LoginPage-C3t8hbb2.js.map +1 -0
- package/frontend/dist/assets/{LogsPage-CTa8kuDf.js → LogsPage-DOZeagVs.js} +2 -2
- package/frontend/dist/assets/{LogsPage-CTa8kuDf.js.map → LogsPage-DOZeagVs.js.map} +1 -1
- package/frontend/dist/assets/{MarketPage-C2Rh4WJB.js → MarketPage-kMEHUGfJ.js} +2 -2
- package/frontend/dist/assets/{MarketPage-C2Rh4WJB.js.map → MarketPage-kMEHUGfJ.js.map} +1 -1
- package/frontend/dist/assets/{PromptsPage-Dh3qjX3x.js → PromptsPage-D7JYoTav.js} +2 -2
- package/frontend/dist/assets/{PromptsPage-Dh3qjX3x.js.map → PromptsPage-D7JYoTav.js.map} +1 -1
- package/frontend/dist/assets/{ResourcesPage-Bc5ZpCIh.js → ResourcesPage-BlwePI9a.js} +2 -2
- package/frontend/dist/assets/{ResourcesPage-Bc5ZpCIh.js.map → ResourcesPage-BlwePI9a.js.map} +1 -1
- package/frontend/dist/assets/{ServersPage-hgCbCglG.js → ServersPage-DrkPpCgK.js} +4 -4
- package/frontend/dist/assets/{ServersPage-hgCbCglG.js.map → ServersPage-DrkPpCgK.js.map} +1 -1
- package/frontend/dist/assets/{SettingsPage-BzNX8mXv.js → SettingsPage-BWigWLml.js} +2 -2
- package/frontend/dist/assets/{SettingsPage-BzNX8mXv.js.map → SettingsPage-BWigWLml.js.map} +1 -1
- package/frontend/dist/assets/{StatusDot-CQzailBQ.js → StatusDot-BDBIaafQ.js} +2 -2
- package/frontend/dist/assets/{StatusDot-CQzailBQ.js.map → StatusDot-BDBIaafQ.js.map} +1 -1
- package/frontend/dist/assets/{ToggleGroup-CNBBvo3C.js → ToggleGroup-OOcsllhw.js} +2 -2
- package/frontend/dist/assets/{ToggleGroup-CNBBvo3C.js.map → ToggleGroup-OOcsllhw.js.map} +1 -1
- package/frontend/dist/assets/{UsersPage-C33b7LCM.js → UsersPage-DL8E7KtW.js} +2 -2
- package/frontend/dist/assets/{UsersPage-C33b7LCM.js.map → UsersPage-DL8E7KtW.js.map} +1 -1
- package/frontend/dist/assets/index-C7wNc_3N.js +3 -0
- package/frontend/dist/assets/index-C7wNc_3N.js.map +1 -0
- package/frontend/dist/assets/{resourceService-C6umWRgq.js → resourceService-B-U4FKGB.js} +2 -2
- package/frontend/dist/assets/{resourceService-C6umWRgq.js.map → resourceService-B-U4FKGB.js.map} +1 -1
- package/frontend/dist/assets/{useServerData-P5In98R4.js → useServerData-DYoDryJj.js} +2 -2
- package/frontend/dist/assets/{useServerData-P5In98R4.js.map → useServerData-DYoDryJj.js.map} +1 -1
- package/frontend/dist/assets/useSettingsData-6utb1Z46.js +2 -0
- package/frontend/dist/assets/{useSettingsData-Cz7vKGLE.js.map → useSettingsData-6utb1Z46.js.map} +1 -1
- package/frontend/dist/index.html +1 -1
- package/package.json +1 -1
- package/frontend/dist/assets/ActivityPage-DwzGiMh_.js +0 -2
- package/frontend/dist/assets/ActivityPage-DwzGiMh_.js.map +0 -1
- package/frontend/dist/assets/LoginPage-DCjqYw_8.js +0 -2
- package/frontend/dist/assets/LoginPage-DCjqYw_8.js.map +0 -1
- package/frontend/dist/assets/index-BGiKkKzj.js +0 -3
- package/frontend/dist/assets/index-BGiKkKzj.js.map +0 -1
- package/frontend/dist/assets/useSettingsData-Cz7vKGLE.js +0 -2
|
@@ -1,3 +0,0 @@
|
|
|
1
|
-
const __vite__mapDeps=(i,m=__vite__mapDeps,d=(m.f||(m.f=["./LoginPage-DCjqYw_8.js","./framework-vendor-BUhDPOUZ.js","./i18n-vendor-Kbr87Ofu.js","./icons-vendor-CKgJB3SC.js","./Dashboard-BUCJcvk-.js","./useServerData-P5In98R4.js","./useSettingsData-Cz7vKGLE.js","./EndpointCopy-D5NjDdYi.js","./StatusDot-CQzailBQ.js","./ServersPage-hgCbCglG.js","./ToggleGroup-CNBBvo3C.js","./DeleteDialog-DRbWonMu.js","./variableDetection-DsYuiOB_.js","./ConfirmDialog-CxlizGia.js","./Pagination-BFi-X7qY.js","./GroupsPage-DfLlww4U.js","./UsersPage-C33b7LCM.js","./SettingsPage-BzNX8mXv.js","./MarketPage-C2Rh4WJB.js","./LogsPage-CTa8kuDf.js","./ActivityPage-DwzGiMh_.js","./PromptsPage-Dh3qjX3x.js","./ResourcesPage-Bc5ZpCIh.js"])))=>i.map(i=>d[i]);
|
|
2
|
-
var Qr=Object.defineProperty;var Zr=(e,r,t)=>r in e?Qr(e,r,{enumerable:!0,configurable:!0,writable:!0,value:t}):e[r]=t;var be=(e,r,t)=>Zr(e,typeof r!="symbol"?r+"":r,t);import{c as Xr,r as u,j as a,R as Ne,u as et,a as kr,b as rt,N as tt,O as Sr,d as De,B as at,e as st,f as H,g as cr}from"./framework-vendor-BUhDPOUZ.js";import{u as q,i as ot,B as nt,a as it}from"./i18n-vendor-Kbr87Ofu.js";import{X as Ae,C as lt,M as ut,S as ct,a as dt,B as mt,R as pt,U as gt,b as Ar,I as ht,L as ft,c as vt,d as yt,e as bt,f as kt,F as St,g as At,h as Pt,A as wt,i as xt}from"./icons-vendor-CKgJB3SC.js";(function(){const r=document.createElement("link").relList;if(r&&r.supports&&r.supports("modulepreload"))return;for(const o of document.querySelectorAll('link[rel="modulepreload"]'))s(o);new MutationObserver(o=>{for(const l of o)if(l.type==="childList")for(const i of l.addedNodes)i.tagName==="LINK"&&i.rel==="modulepreload"&&s(i)}).observe(document,{childList:!0,subtree:!0});function t(o){const l={};return o.integrity&&(l.integrity=o.integrity),o.referrerPolicy&&(l.referrerPolicy=o.referrerPolicy),o.crossOrigin==="use-credentials"?l.credentials="include":o.crossOrigin==="anonymous"?l.credentials="omit":l.credentials="same-origin",l}function s(o){if(o.ep)return;o.ep=!0;const l=t(o);fetch(o.href,l)}})();const Ct="modulepreload",Rt=function(e,r){return new URL(e,r).href},dr={},Q=function(r,t,s){let o=Promise.resolve();if(t&&t.length>0){let i=function(p){return Promise.all(p.map(m=>Promise.resolve(m).then(y=>({status:"fulfilled",value:y}),y=>({status:"rejected",reason:y}))))};const c=document.getElementsByTagName("link"),n=document.querySelector("meta[property=csp-nonce]"),v=(n==null?void 0:n.nonce)||(n==null?void 0:n.getAttribute("nonce"));o=i(t.map(p=>{if(p=Rt(p,s),p in dr)return;dr[p]=!0;const m=p.endsWith(".css"),y=m?'[rel="stylesheet"]':"";if(!!s)for(let I=c.length-1;I>=0;I--){const L=c[I];if(L.href===p&&(!m||L.rel==="stylesheet"))return}else if(document.querySelector(`link[href="${p}"]${y}`))return;const C=document.createElement("link");if(C.rel=m?"stylesheet":Ct,m||(C.as="script"),C.crossOrigin="",C.href=p,v&&C.setAttribute("nonce",v),document.head.appendChild(C),m)return new Promise((I,L)=>{C.addEventListener("load",I),C.addEventListener("error",()=>L(new Error(`Unable to preload CSS for ${p}`)))})}))}function l(i){const c=new Event("vite:preloadError",{cancelable:!0});if(c.payload=i,window.dispatchEvent(c),!c.defaultPrevented)throw i}return o.then(i=>{for(const c of i||[])c.status==="rejected"&&l(c.reason);return r().catch(l)})},Et=()=>window.__MCPHUB_CONFIG__||{basePath:"",version:"dev",name:"mcphub"},Ie=()=>{const r=Et().basePath||"";return r&&!r.startsWith("/")?"/"+r:r},Tt=()=>Ie()+"/api",Pr=e=>{const r=Tt(),t=e.startsWith("/")?e:"/"+e;return r+t},Nt=async()=>{try{const e=window.location.pathname,r=[e.replace(/\/[^/]*$/,"")+"/config","/config",...e.includes("/")?[e.split("/")[1]?`/${e.split("/")[1]}/config`:"/config"]:["/config"]];for(const t of r)try{const s=await fetch(t,{method:"GET",headers:{Accept:"application/json","Cache-Control":"no-cache"}});if(s.ok){const o=await s.json();if(o.success&&o.data)return o.data}}catch(s){console.debug(`Failed to load config from ${t}:`,s)}return console.warn("Could not load runtime config from server, using defaults"),{basePath:"",version:"dev",name:"mcphub"}}catch(e){return console.error("Error loading runtime config:",e),{basePath:"",version:"dev",name:"mcphub"}}},Ee=[];let qe=null,Le=null;const ke=new WeakMap;typeof document<"u"&&document.addEventListener("click",e=>{const r=e.target,t=r==null?void 0:r.closest("button");t&&(qe=t,Le&&clearTimeout(Le),Le=setTimeout(()=>{qe=null},100))},!0);const Dt=e=>{Ee.push(e)},wr=async(e,r={})=>{let t=e.toString(),s={...r};const o=qe;if(o){const l=ke.get(o)||0;ke.set(o,l+1),o.classList.add("is-loading")}try{for(const i of Ee)if(i.request){const c=await i.request(t,s);t=c.url,s=c.config}let l=await fetch(t,s);for(const i of Ee)i.response&&(l=await i.response(l));return l}catch(l){let i=l;for(const c of Ee)c.error&&(i=await c.error(i));throw i}finally{if(o){const l=ke.get(o)||0;l<=1?(ke.delete(o),o.classList.remove("is-loading")):ke.set(o,l-1)}}},ze=async(e,r={})=>{try{const t=Pr(e),s=await wr(t,r);let o;try{o=await s.json()}catch{o={success:s.ok,message:s.ok?"Request successful":`HTTP ${s.status}: ${s.statusText}`}}if(!s.ok&&typeof o=="object"&&o!==null){const l=o;l.success!==!1&&(l.success=!1,l.message=l.message||`HTTP ${s.status}: ${s.statusText}`)}return o}catch(t){return console.error("API request error:",t),{success:!1,message:t instanceof Error?t.message:"An unknown error occurred"}}},V=(e,r={})=>ze(e,{...r,method:"GET"}),ie=(e,r,t={})=>ze(e,{...t,method:"POST",headers:{"Content-Type":"application/json",...t.headers},body:r?JSON.stringify(r):void 0}),_=(e,r,t={})=>ze(e,{...t,method:"PUT",headers:{"Content-Type":"application/json",...t.headers},body:r?JSON.stringify(r):void 0}),he=(e,r={})=>ze(e,{...r,method:"DELETE"}),$e="mcphub_token",Pe=()=>localStorage.getItem($e),xr=e=>{localStorage.setItem($e,e)},Me=()=>{localStorage.removeItem($e)},Mt={request:async(e,r)=>{const t=new Headers(r.headers),s=localStorage.getItem("i18nextLng")||"en";t.set("Accept-Language",s);const o=Pe();return o&&t.set("x-auth-token",o),{url:e,config:{...r,headers:t,credentials:r.credentials??"include"}}},response:async e=>(e.status===401&&Me(),e),error:async e=>(console.error("Auth interceptor error:",e),e)},It=()=>{Dt(Mt)},zt=e=>e?e.startsWith("/")?e:`/${e}`:"/api/auth/better",Ot=e=>{if(typeof window>"u")return"";const r=Ie(),t=zt(e||"/api/auth/better");return`${window.location.origin}${r}${t}`},Lt=e=>Xr({baseURL:Ot(e),fetchOptions:{credentials:"include"}}),Ft=Lt(),jt=async e=>{try{const r=await ie("/auth/login",e);return r.success&&r.token?(xr(r.token),r):{success:!1,message:r.message||"Login failed"}}catch(r){return console.error("Login error",{error:r}),{success:!1,message:r instanceof Error?r.message:"An error occurred during login"}}},Ut=async e=>{try{const r=await ie("/auth/register",e);return r.success&&r.token?(xr(r.token),r):{success:!1,message:r.message||"Registration failed"}}catch(r){return console.error("Register error",{error:r}),{success:!1,message:"An error occurred during registration"}}},Gt=async()=>{if(!Pe())return{success:!1,message:"No authentication token"};try{return await V("/auth/user")}catch(r){return console.error("Get current user error",{error:r}),{success:!1,message:"An error occurred while fetching user data"}}},Fe=async()=>{try{return await V("/better-auth/user")}catch(e){return console.error("Get Better Auth user error",{error:e}),{success:!1,message:"An error occurred while fetching user data"}}},ui=async e=>{if(!Pe())return{success:!1,message:"No authentication token"};try{return await ie("/auth/change-password",e)}catch(t){return console.error("Change password error",{error:t}),{success:!1,message:"An error occurred while changing password"}}},Kt=()=>{Me(),Ft.signOut().catch(e=>{console.debug("Better Auth sign out failed",{error:e})})},qt=async()=>{var e,r,t;try{const s=Ie(),o=await wr(`${s}/public-config`,{method:"GET",headers:{"Content-Type":"application/json"}});if(o.ok){const l=await o.json();return{skipAuth:((e=l.data)==null?void 0:e.skipAuth)===!0,permissions:((r=l.data)==null?void 0:r.permissions)||{},betterAuth:(t=l.data)==null?void 0:t.betterAuth}}return{skipAuth:!1}}catch(s){return console.debug("Failed to get public config:",s),{skipAuth:!1}}},re={isAuthenticated:!1,loading:!0,user:null,error:null},Cr=u.createContext({auth:re,login:async()=>({success:!1}),register:async()=>!1,logout:()=>{}}),Bt=({children:e})=>{const[r,t]=u.useState(re);u.useEffect(()=>{(async()=>{const{skipAuth:c,permissions:n}=await qt();if(c){t({isAuthenticated:!0,loading:!1,user:{username:"guest",isAdmin:!0,permissions:n},error:null});return}if(!Pe()){const p=await Fe();if(p.success&&p.user){t({isAuthenticated:!0,loading:!1,user:p.user,error:null});return}t({...re,loading:!1});return}try{const p=await Gt();if(p.success&&p.user)t({isAuthenticated:!0,loading:!1,user:p.user,error:null});else{Me();const m=await Fe();m.success&&m.user?t({isAuthenticated:!0,loading:!1,user:m.user,error:null}):t({...re,loading:!1})}}catch{Me();const m=await Fe();m.success&&m.user?t({isAuthenticated:!0,loading:!1,user:m.user,error:null}):t({...re,loading:!1})}})()},[]);const s=async(i,c)=>{try{const n=await jt({username:i,password:c});return n.success&&n.token&&n.user?(t({isAuthenticated:!0,loading:!1,user:n.user,error:null}),{success:!0,isUsingDefaultPassword:n.isUsingDefaultPassword}):(t({...re,loading:!1,error:n.message||"Authentication failed"}),{success:!1,message:n.message})}catch(n){return t({...re,loading:!1,error:"Authentication failed"}),{success:!1,message:n instanceof Error?n.message:void 0}}},o=async(i,c,n=!1)=>{try{const v=await Ut({username:i,password:c,isAdmin:n});return v.success&&v.token&&v.user?(t({isAuthenticated:!0,loading:!1,user:v.user,error:null}),!0):(t({...re,loading:!1,error:v.message||"Registration failed"}),!1)}catch{return t({...re,loading:!1,error:"Registration failed"}),!1}},l=()=>{Kt(),t({...re,loading:!1})};return a.jsx(Cr.Provider,{value:{auth:r,login:s,register:o,logout:l},children:e})},fe=()=>u.useContext(Cr);function Rr(e){var r,t,s="";if(typeof e=="string"||typeof e=="number")s+=e;else if(typeof e=="object")if(Array.isArray(e)){var o=e.length;for(r=0;r<o;r++)e[r]&&(t=Rr(e[r]))&&(s&&(s+=" "),s+=t)}else for(t in e)e[t]&&(s&&(s+=" "),s+=t);return s}function Ht(){for(var e,r,t=0,s="",o=arguments.length;t<o;t++)(e=arguments[t])&&(r=Rr(e))&&(s&&(s+=" "),s+=r);return s}const _e="-",Vt=e=>{const r=_t(e),{conflictingClassGroups:t,conflictingClassGroupModifiers:s}=e;return{getClassGroupId:i=>{const c=i.split(_e);return c[0]===""&&c.length!==1&&c.shift(),Er(c,r)||$t(i)},getConflictingClassGroupIds:(i,c)=>{const n=t[i]||[];return c&&s[i]?[...n,...s[i]]:n}}},Er=(e,r)=>{var i;if(e.length===0)return r.classGroupId;const t=e[0],s=r.nextPart.get(t),o=s?Er(e.slice(1),s):void 0;if(o)return o;if(r.validators.length===0)return;const l=e.join(_e);return(i=r.validators.find(({validator:c})=>c(l)))==null?void 0:i.classGroupId},mr=/^\[(.+)\]$/,$t=e=>{if(mr.test(e)){const r=mr.exec(e)[1],t=r==null?void 0:r.substring(0,r.indexOf(":"));if(t)return"arbitrary.."+t}},_t=e=>{const{theme:r,classGroups:t}=e,s={nextPart:new Map,validators:[]};for(const o in t)Be(t[o],s,o,r);return s},Be=(e,r,t,s)=>{e.forEach(o=>{if(typeof o=="string"){const l=o===""?r:pr(r,o);l.classGroupId=t;return}if(typeof o=="function"){if(Jt(o)){Be(o(s),r,t,s);return}r.validators.push({validator:o,classGroupId:t});return}Object.entries(o).forEach(([l,i])=>{Be(i,pr(r,l),t,s)})})},pr=(e,r)=>{let t=e;return r.split(_e).forEach(s=>{t.nextPart.has(s)||t.nextPart.set(s,{nextPart:new Map,validators:[]}),t=t.nextPart.get(s)}),t},Jt=e=>e.isThemeGetter,Wt=e=>{if(e<1)return{get:()=>{},set:()=>{}};let r=0,t=new Map,s=new Map;const o=(l,i)=>{t.set(l,i),r++,r>e&&(r=0,s=t,t=new Map)};return{get(l){let i=t.get(l);if(i!==void 0)return i;if((i=s.get(l))!==void 0)return o(l,i),i},set(l,i){t.has(l)?t.set(l,i):o(l,i)}}},He="!",Ve=":",Yt=Ve.length,Qt=e=>{const{prefix:r,experimentalParseClassName:t}=e;let s=o=>{const l=[];let i=0,c=0,n=0,v;for(let C=0;C<o.length;C++){let I=o[C];if(i===0&&c===0){if(I===Ve){l.push(o.slice(n,C)),n=C+Yt;continue}if(I==="/"){v=C;continue}}I==="["?i++:I==="]"?i--:I==="("?c++:I===")"&&c--}const p=l.length===0?o:o.substring(n),m=Zt(p),y=m!==p,O=v&&v>n?v-n:void 0;return{modifiers:l,hasImportantModifier:y,baseClassName:m,maybePostfixModifierPosition:O}};if(r){const o=r+Ve,l=s;s=i=>i.startsWith(o)?l(i.substring(o.length)):{isExternal:!0,modifiers:[],hasImportantModifier:!1,baseClassName:i,maybePostfixModifierPosition:void 0}}if(t){const o=s;s=l=>t({className:l,parseClassName:o})}return s},Zt=e=>e.endsWith(He)?e.substring(0,e.length-1):e.startsWith(He)?e.substring(1):e,Xt=e=>{const r=Object.fromEntries(e.orderSensitiveModifiers.map(s=>[s,!0]));return s=>{if(s.length<=1)return s;const o=[];let l=[];return s.forEach(i=>{i[0]==="["||r[i]?(o.push(...l.sort(),i),l=[]):l.push(i)}),o.push(...l.sort()),o}},ea=e=>({cache:Wt(e.cacheSize),parseClassName:Qt(e),sortModifiers:Xt(e),...Vt(e)}),ra=/\s+/,ta=(e,r)=>{const{parseClassName:t,getClassGroupId:s,getConflictingClassGroupIds:o,sortModifiers:l}=r,i=[],c=e.trim().split(ra);let n="";for(let v=c.length-1;v>=0;v-=1){const p=c[v],{isExternal:m,modifiers:y,hasImportantModifier:O,baseClassName:C,maybePostfixModifierPosition:I}=t(p);if(m){n=p+(n.length>0?" "+n:n);continue}let L=!!I,R=s(L?C.substring(0,I):C);if(!R){if(!L){n=p+(n.length>0?" "+n:n);continue}if(R=s(C),!R){n=p+(n.length>0?" "+n:n);continue}L=!1}const z=l(y).join(":"),k=O?z+He:z,F=k+R;if(i.includes(F))continue;i.push(F);const B=o(R,L);for(let U=0;U<B.length;++U){const D=B[U];i.push(k+D)}n=p+(n.length>0?" "+n:n)}return n};function aa(){let e=0,r,t,s="";for(;e<arguments.length;)(r=arguments[e++])&&(t=Tr(r))&&(s&&(s+=" "),s+=t);return s}const Tr=e=>{if(typeof e=="string")return e;let r,t="";for(let s=0;s<e.length;s++)e[s]&&(r=Tr(e[s]))&&(t&&(t+=" "),t+=r);return t};function sa(e,...r){let t,s,o,l=i;function i(n){const v=r.reduce((p,m)=>m(p),e());return t=ea(v),s=t.cache.get,o=t.cache.set,l=c,c(n)}function c(n){const v=s(n);if(v)return v;const p=ta(n,t);return o(n,p),p}return function(){return l(aa.apply(null,arguments))}}const K=e=>{const r=t=>t[e]||[];return r.isThemeGetter=!0,r},Nr=/^\[(?:(\w[\w-]*):)?(.+)\]$/i,Dr=/^\((?:(\w[\w-]*):)?(.+)\)$/i,oa=/^\d+\/\d+$/,na=/^(\d+(\.\d+)?)?(xs|sm|md|lg|xl)$/,ia=/\d+(%|px|r?em|[sdl]?v([hwib]|min|max)|pt|pc|in|cm|mm|cap|ch|ex|r?lh|cq(w|h|i|b|min|max))|\b(calc|min|max|clamp)\(.+\)|^0$/,la=/^(rgba?|hsla?|hwb|(ok)?(lab|lch)|color-mix)\(.+\)$/,ua=/^(inset_)?-?((\d+)?\.?(\d+)[a-z]+|0)_-?((\d+)?\.?(\d+)[a-z]+|0)/,ca=/^(url|image|image-set|cross-fade|element|(repeating-)?(linear|radial|conic)-gradient)\(.+\)$/,ge=e=>oa.test(e),M=e=>!!e&&!Number.isNaN(Number(e)),ne=e=>!!e&&Number.isInteger(Number(e)),je=e=>e.endsWith("%")&&M(e.slice(0,-1)),ae=e=>na.test(e),da=()=>!0,ma=e=>ia.test(e)&&!la.test(e),Mr=()=>!1,pa=e=>ua.test(e),ga=e=>ca.test(e),ha=e=>!h(e)&&!f(e),fa=e=>ve(e,Or,Mr),h=e=>Nr.test(e),ue=e=>ve(e,Lr,ma),Ue=e=>ve(e,Sa,M),gr=e=>ve(e,Ir,Mr),va=e=>ve(e,zr,ga),xe=e=>ve(e,Fr,pa),f=e=>Dr.test(e),Se=e=>ye(e,Lr),ya=e=>ye(e,Aa),hr=e=>ye(e,Ir),ba=e=>ye(e,Or),ka=e=>ye(e,zr),Ce=e=>ye(e,Fr,!0),ve=(e,r,t)=>{const s=Nr.exec(e);return s?s[1]?r(s[1]):t(s[2]):!1},ye=(e,r,t=!1)=>{const s=Dr.exec(e);return s?s[1]?r(s[1]):t:!1},Ir=e=>e==="position"||e==="percentage",zr=e=>e==="image"||e==="url",Or=e=>e==="length"||e==="size"||e==="bg-size",Lr=e=>e==="length",Sa=e=>e==="number",Aa=e=>e==="family-name",Fr=e=>e==="shadow",Pa=()=>{const e=K("color"),r=K("font"),t=K("text"),s=K("font-weight"),o=K("tracking"),l=K("leading"),i=K("breakpoint"),c=K("container"),n=K("spacing"),v=K("radius"),p=K("shadow"),m=K("inset-shadow"),y=K("text-shadow"),O=K("drop-shadow"),C=K("blur"),I=K("perspective"),L=K("aspect"),R=K("ease"),z=K("animate"),k=()=>["auto","avoid","all","avoid-page","page","left","right","column"],F=()=>["center","top","bottom","left","right","top-left","left-top","top-right","right-top","bottom-right","right-bottom","bottom-left","left-bottom"],B=()=>[...F(),f,h],U=()=>["auto","hidden","clip","visible","scroll"],D=()=>["auto","contain","none"],P=()=>[f,h,n],b=()=>[ge,"full","auto",...P()],te=()=>[ne,"none","subgrid",f,h],Z=()=>["auto",{span:["full",ne,f,h]},ne,f,h],X=()=>[ne,"auto",f,h],se=()=>["auto","min","max","fr",f,h],le=()=>["start","end","center","between","around","evenly","stretch","baseline","center-safe","end-safe"],ee=()=>["start","end","center","stretch","center-safe","end-safe"],J=()=>["auto",...P()],Y=()=>[ge,"auto","full","dvw","dvh","lvw","lvh","svw","svh","min","max","fit",...P()],x=()=>[e,f,h],ce=()=>[...F(),hr,gr,{position:[f,h]}],de=()=>["no-repeat",{repeat:["","x","y","space","round"]}],E=()=>["auto","cover","contain",ba,fa,{size:[f,h]}],T=()=>[je,Se,ue],S=()=>["","none","full",v,f,h],N=()=>["",M,Se,ue],G=()=>["solid","dashed","dotted","double"],$=()=>["normal","multiply","screen","overlay","darken","lighten","color-dodge","color-burn","hard-light","soft-light","difference","exclusion","hue","saturation","color","luminosity"],j=()=>[M,je,hr,gr],we=()=>["","none",C,f,h],me=()=>["none",M,f,h],pe=()=>["none",M,f,h],g=()=>[M,f,h],d=()=>[ge,"full",...P()];return{cacheSize:500,theme:{animate:["spin","ping","pulse","bounce"],aspect:["video"],blur:[ae],breakpoint:[ae],color:[da],container:[ae],"drop-shadow":[ae],ease:["in","out","in-out"],font:[ha],"font-weight":["thin","extralight","light","normal","medium","semibold","bold","extrabold","black"],"inset-shadow":[ae],leading:["none","tight","snug","normal","relaxed","loose"],perspective:["dramatic","near","normal","midrange","distant","none"],radius:[ae],shadow:[ae],spacing:["px",M],text:[ae],"text-shadow":[ae],tracking:["tighter","tight","normal","wide","wider","widest"]},classGroups:{aspect:[{aspect:["auto","square",ge,h,f,L]}],container:["container"],columns:[{columns:[M,h,f,c]}],"break-after":[{"break-after":k()}],"break-before":[{"break-before":k()}],"break-inside":[{"break-inside":["auto","avoid","avoid-page","avoid-column"]}],"box-decoration":[{"box-decoration":["slice","clone"]}],box:[{box:["border","content"]}],display:["block","inline-block","inline","flex","inline-flex","table","inline-table","table-caption","table-cell","table-column","table-column-group","table-footer-group","table-header-group","table-row-group","table-row","flow-root","grid","inline-grid","contents","list-item","hidden"],sr:["sr-only","not-sr-only"],float:[{float:["right","left","none","start","end"]}],clear:[{clear:["left","right","both","none","start","end"]}],isolation:["isolate","isolation-auto"],"object-fit":[{object:["contain","cover","fill","none","scale-down"]}],"object-position":[{object:B()}],overflow:[{overflow:U()}],"overflow-x":[{"overflow-x":U()}],"overflow-y":[{"overflow-y":U()}],overscroll:[{overscroll:D()}],"overscroll-x":[{"overscroll-x":D()}],"overscroll-y":[{"overscroll-y":D()}],position:["static","fixed","absolute","relative","sticky"],inset:[{inset:b()}],"inset-x":[{"inset-x":b()}],"inset-y":[{"inset-y":b()}],start:[{start:b()}],end:[{end:b()}],top:[{top:b()}],right:[{right:b()}],bottom:[{bottom:b()}],left:[{left:b()}],visibility:["visible","invisible","collapse"],z:[{z:[ne,"auto",f,h]}],basis:[{basis:[ge,"full","auto",c,...P()]}],"flex-direction":[{flex:["row","row-reverse","col","col-reverse"]}],"flex-wrap":[{flex:["nowrap","wrap","wrap-reverse"]}],flex:[{flex:[M,ge,"auto","initial","none",h]}],grow:[{grow:["",M,f,h]}],shrink:[{shrink:["",M,f,h]}],order:[{order:[ne,"first","last","none",f,h]}],"grid-cols":[{"grid-cols":te()}],"col-start-end":[{col:Z()}],"col-start":[{"col-start":X()}],"col-end":[{"col-end":X()}],"grid-rows":[{"grid-rows":te()}],"row-start-end":[{row:Z()}],"row-start":[{"row-start":X()}],"row-end":[{"row-end":X()}],"grid-flow":[{"grid-flow":["row","col","dense","row-dense","col-dense"]}],"auto-cols":[{"auto-cols":se()}],"auto-rows":[{"auto-rows":se()}],gap:[{gap:P()}],"gap-x":[{"gap-x":P()}],"gap-y":[{"gap-y":P()}],"justify-content":[{justify:[...le(),"normal"]}],"justify-items":[{"justify-items":[...ee(),"normal"]}],"justify-self":[{"justify-self":["auto",...ee()]}],"align-content":[{content:["normal",...le()]}],"align-items":[{items:[...ee(),{baseline:["","last"]}]}],"align-self":[{self:["auto",...ee(),{baseline:["","last"]}]}],"place-content":[{"place-content":le()}],"place-items":[{"place-items":[...ee(),"baseline"]}],"place-self":[{"place-self":["auto",...ee()]}],p:[{p:P()}],px:[{px:P()}],py:[{py:P()}],ps:[{ps:P()}],pe:[{pe:P()}],pt:[{pt:P()}],pr:[{pr:P()}],pb:[{pb:P()}],pl:[{pl:P()}],m:[{m:J()}],mx:[{mx:J()}],my:[{my:J()}],ms:[{ms:J()}],me:[{me:J()}],mt:[{mt:J()}],mr:[{mr:J()}],mb:[{mb:J()}],ml:[{ml:J()}],"space-x":[{"space-x":P()}],"space-x-reverse":["space-x-reverse"],"space-y":[{"space-y":P()}],"space-y-reverse":["space-y-reverse"],size:[{size:Y()}],w:[{w:[c,"screen",...Y()]}],"min-w":[{"min-w":[c,"screen","none",...Y()]}],"max-w":[{"max-w":[c,"screen","none","prose",{screen:[i]},...Y()]}],h:[{h:["screen","lh",...Y()]}],"min-h":[{"min-h":["screen","lh","none",...Y()]}],"max-h":[{"max-h":["screen","lh",...Y()]}],"font-size":[{text:["base",t,Se,ue]}],"font-smoothing":["antialiased","subpixel-antialiased"],"font-style":["italic","not-italic"],"font-weight":[{font:[s,f,Ue]}],"font-stretch":[{"font-stretch":["ultra-condensed","extra-condensed","condensed","semi-condensed","normal","semi-expanded","expanded","extra-expanded","ultra-expanded",je,h]}],"font-family":[{font:[ya,h,r]}],"fvn-normal":["normal-nums"],"fvn-ordinal":["ordinal"],"fvn-slashed-zero":["slashed-zero"],"fvn-figure":["lining-nums","oldstyle-nums"],"fvn-spacing":["proportional-nums","tabular-nums"],"fvn-fraction":["diagonal-fractions","stacked-fractions"],tracking:[{tracking:[o,f,h]}],"line-clamp":[{"line-clamp":[M,"none",f,Ue]}],leading:[{leading:[l,...P()]}],"list-image":[{"list-image":["none",f,h]}],"list-style-position":[{list:["inside","outside"]}],"list-style-type":[{list:["disc","decimal","none",f,h]}],"text-alignment":[{text:["left","center","right","justify","start","end"]}],"placeholder-color":[{placeholder:x()}],"text-color":[{text:x()}],"text-decoration":["underline","overline","line-through","no-underline"],"text-decoration-style":[{decoration:[...G(),"wavy"]}],"text-decoration-thickness":[{decoration:[M,"from-font","auto",f,ue]}],"text-decoration-color":[{decoration:x()}],"underline-offset":[{"underline-offset":[M,"auto",f,h]}],"text-transform":["uppercase","lowercase","capitalize","normal-case"],"text-overflow":["truncate","text-ellipsis","text-clip"],"text-wrap":[{text:["wrap","nowrap","balance","pretty"]}],indent:[{indent:P()}],"vertical-align":[{align:["baseline","top","middle","bottom","text-top","text-bottom","sub","super",f,h]}],whitespace:[{whitespace:["normal","nowrap","pre","pre-line","pre-wrap","break-spaces"]}],break:[{break:["normal","words","all","keep"]}],wrap:[{wrap:["break-word","anywhere","normal"]}],hyphens:[{hyphens:["none","manual","auto"]}],content:[{content:["none",f,h]}],"bg-attachment":[{bg:["fixed","local","scroll"]}],"bg-clip":[{"bg-clip":["border","padding","content","text"]}],"bg-origin":[{"bg-origin":["border","padding","content"]}],"bg-position":[{bg:ce()}],"bg-repeat":[{bg:de()}],"bg-size":[{bg:E()}],"bg-image":[{bg:["none",{linear:[{to:["t","tr","r","br","b","bl","l","tl"]},ne,f,h],radial:["",f,h],conic:[ne,f,h]},ka,va]}],"bg-color":[{bg:x()}],"gradient-from-pos":[{from:T()}],"gradient-via-pos":[{via:T()}],"gradient-to-pos":[{to:T()}],"gradient-from":[{from:x()}],"gradient-via":[{via:x()}],"gradient-to":[{to:x()}],rounded:[{rounded:S()}],"rounded-s":[{"rounded-s":S()}],"rounded-e":[{"rounded-e":S()}],"rounded-t":[{"rounded-t":S()}],"rounded-r":[{"rounded-r":S()}],"rounded-b":[{"rounded-b":S()}],"rounded-l":[{"rounded-l":S()}],"rounded-ss":[{"rounded-ss":S()}],"rounded-se":[{"rounded-se":S()}],"rounded-ee":[{"rounded-ee":S()}],"rounded-es":[{"rounded-es":S()}],"rounded-tl":[{"rounded-tl":S()}],"rounded-tr":[{"rounded-tr":S()}],"rounded-br":[{"rounded-br":S()}],"rounded-bl":[{"rounded-bl":S()}],"border-w":[{border:N()}],"border-w-x":[{"border-x":N()}],"border-w-y":[{"border-y":N()}],"border-w-s":[{"border-s":N()}],"border-w-e":[{"border-e":N()}],"border-w-t":[{"border-t":N()}],"border-w-r":[{"border-r":N()}],"border-w-b":[{"border-b":N()}],"border-w-l":[{"border-l":N()}],"divide-x":[{"divide-x":N()}],"divide-x-reverse":["divide-x-reverse"],"divide-y":[{"divide-y":N()}],"divide-y-reverse":["divide-y-reverse"],"border-style":[{border:[...G(),"hidden","none"]}],"divide-style":[{divide:[...G(),"hidden","none"]}],"border-color":[{border:x()}],"border-color-x":[{"border-x":x()}],"border-color-y":[{"border-y":x()}],"border-color-s":[{"border-s":x()}],"border-color-e":[{"border-e":x()}],"border-color-t":[{"border-t":x()}],"border-color-r":[{"border-r":x()}],"border-color-b":[{"border-b":x()}],"border-color-l":[{"border-l":x()}],"divide-color":[{divide:x()}],"outline-style":[{outline:[...G(),"none","hidden"]}],"outline-offset":[{"outline-offset":[M,f,h]}],"outline-w":[{outline:["",M,Se,ue]}],"outline-color":[{outline:x()}],shadow:[{shadow:["","none",p,Ce,xe]}],"shadow-color":[{shadow:x()}],"inset-shadow":[{"inset-shadow":["none",m,Ce,xe]}],"inset-shadow-color":[{"inset-shadow":x()}],"ring-w":[{ring:N()}],"ring-w-inset":["ring-inset"],"ring-color":[{ring:x()}],"ring-offset-w":[{"ring-offset":[M,ue]}],"ring-offset-color":[{"ring-offset":x()}],"inset-ring-w":[{"inset-ring":N()}],"inset-ring-color":[{"inset-ring":x()}],"text-shadow":[{"text-shadow":["none",y,Ce,xe]}],"text-shadow-color":[{"text-shadow":x()}],opacity:[{opacity:[M,f,h]}],"mix-blend":[{"mix-blend":[...$(),"plus-darker","plus-lighter"]}],"bg-blend":[{"bg-blend":$()}],"mask-clip":[{"mask-clip":["border","padding","content","fill","stroke","view"]},"mask-no-clip"],"mask-composite":[{mask:["add","subtract","intersect","exclude"]}],"mask-image-linear-pos":[{"mask-linear":[M]}],"mask-image-linear-from-pos":[{"mask-linear-from":j()}],"mask-image-linear-to-pos":[{"mask-linear-to":j()}],"mask-image-linear-from-color":[{"mask-linear-from":x()}],"mask-image-linear-to-color":[{"mask-linear-to":x()}],"mask-image-t-from-pos":[{"mask-t-from":j()}],"mask-image-t-to-pos":[{"mask-t-to":j()}],"mask-image-t-from-color":[{"mask-t-from":x()}],"mask-image-t-to-color":[{"mask-t-to":x()}],"mask-image-r-from-pos":[{"mask-r-from":j()}],"mask-image-r-to-pos":[{"mask-r-to":j()}],"mask-image-r-from-color":[{"mask-r-from":x()}],"mask-image-r-to-color":[{"mask-r-to":x()}],"mask-image-b-from-pos":[{"mask-b-from":j()}],"mask-image-b-to-pos":[{"mask-b-to":j()}],"mask-image-b-from-color":[{"mask-b-from":x()}],"mask-image-b-to-color":[{"mask-b-to":x()}],"mask-image-l-from-pos":[{"mask-l-from":j()}],"mask-image-l-to-pos":[{"mask-l-to":j()}],"mask-image-l-from-color":[{"mask-l-from":x()}],"mask-image-l-to-color":[{"mask-l-to":x()}],"mask-image-x-from-pos":[{"mask-x-from":j()}],"mask-image-x-to-pos":[{"mask-x-to":j()}],"mask-image-x-from-color":[{"mask-x-from":x()}],"mask-image-x-to-color":[{"mask-x-to":x()}],"mask-image-y-from-pos":[{"mask-y-from":j()}],"mask-image-y-to-pos":[{"mask-y-to":j()}],"mask-image-y-from-color":[{"mask-y-from":x()}],"mask-image-y-to-color":[{"mask-y-to":x()}],"mask-image-radial":[{"mask-radial":[f,h]}],"mask-image-radial-from-pos":[{"mask-radial-from":j()}],"mask-image-radial-to-pos":[{"mask-radial-to":j()}],"mask-image-radial-from-color":[{"mask-radial-from":x()}],"mask-image-radial-to-color":[{"mask-radial-to":x()}],"mask-image-radial-shape":[{"mask-radial":["circle","ellipse"]}],"mask-image-radial-size":[{"mask-radial":[{closest:["side","corner"],farthest:["side","corner"]}]}],"mask-image-radial-pos":[{"mask-radial-at":F()}],"mask-image-conic-pos":[{"mask-conic":[M]}],"mask-image-conic-from-pos":[{"mask-conic-from":j()}],"mask-image-conic-to-pos":[{"mask-conic-to":j()}],"mask-image-conic-from-color":[{"mask-conic-from":x()}],"mask-image-conic-to-color":[{"mask-conic-to":x()}],"mask-mode":[{mask:["alpha","luminance","match"]}],"mask-origin":[{"mask-origin":["border","padding","content","fill","stroke","view"]}],"mask-position":[{mask:ce()}],"mask-repeat":[{mask:de()}],"mask-size":[{mask:E()}],"mask-type":[{"mask-type":["alpha","luminance"]}],"mask-image":[{mask:["none",f,h]}],filter:[{filter:["","none",f,h]}],blur:[{blur:we()}],brightness:[{brightness:[M,f,h]}],contrast:[{contrast:[M,f,h]}],"drop-shadow":[{"drop-shadow":["","none",O,Ce,xe]}],"drop-shadow-color":[{"drop-shadow":x()}],grayscale:[{grayscale:["",M,f,h]}],"hue-rotate":[{"hue-rotate":[M,f,h]}],invert:[{invert:["",M,f,h]}],saturate:[{saturate:[M,f,h]}],sepia:[{sepia:["",M,f,h]}],"backdrop-filter":[{"backdrop-filter":["","none",f,h]}],"backdrop-blur":[{"backdrop-blur":we()}],"backdrop-brightness":[{"backdrop-brightness":[M,f,h]}],"backdrop-contrast":[{"backdrop-contrast":[M,f,h]}],"backdrop-grayscale":[{"backdrop-grayscale":["",M,f,h]}],"backdrop-hue-rotate":[{"backdrop-hue-rotate":[M,f,h]}],"backdrop-invert":[{"backdrop-invert":["",M,f,h]}],"backdrop-opacity":[{"backdrop-opacity":[M,f,h]}],"backdrop-saturate":[{"backdrop-saturate":[M,f,h]}],"backdrop-sepia":[{"backdrop-sepia":["",M,f,h]}],"border-collapse":[{border:["collapse","separate"]}],"border-spacing":[{"border-spacing":P()}],"border-spacing-x":[{"border-spacing-x":P()}],"border-spacing-y":[{"border-spacing-y":P()}],"table-layout":[{table:["auto","fixed"]}],caption:[{caption:["top","bottom"]}],transition:[{transition:["","all","colors","opacity","shadow","transform","none",f,h]}],"transition-behavior":[{transition:["normal","discrete"]}],duration:[{duration:[M,"initial",f,h]}],ease:[{ease:["linear","initial",R,f,h]}],delay:[{delay:[M,f,h]}],animate:[{animate:["none",z,f,h]}],backface:[{backface:["hidden","visible"]}],perspective:[{perspective:[I,f,h]}],"perspective-origin":[{"perspective-origin":B()}],rotate:[{rotate:me()}],"rotate-x":[{"rotate-x":me()}],"rotate-y":[{"rotate-y":me()}],"rotate-z":[{"rotate-z":me()}],scale:[{scale:pe()}],"scale-x":[{"scale-x":pe()}],"scale-y":[{"scale-y":pe()}],"scale-z":[{"scale-z":pe()}],"scale-3d":["scale-3d"],skew:[{skew:g()}],"skew-x":[{"skew-x":g()}],"skew-y":[{"skew-y":g()}],transform:[{transform:[f,h,"","none","gpu","cpu"]}],"transform-origin":[{origin:B()}],"transform-style":[{transform:["3d","flat"]}],translate:[{translate:d()}],"translate-x":[{"translate-x":d()}],"translate-y":[{"translate-y":d()}],"translate-z":[{"translate-z":d()}],"translate-none":["translate-none"],accent:[{accent:x()}],appearance:[{appearance:["none","auto"]}],"caret-color":[{caret:x()}],"color-scheme":[{scheme:["normal","dark","light","light-dark","only-dark","only-light"]}],cursor:[{cursor:["auto","default","pointer","wait","text","move","help","not-allowed","none","context-menu","progress","cell","crosshair","vertical-text","alias","copy","no-drop","grab","grabbing","all-scroll","col-resize","row-resize","n-resize","e-resize","s-resize","w-resize","ne-resize","nw-resize","se-resize","sw-resize","ew-resize","ns-resize","nesw-resize","nwse-resize","zoom-in","zoom-out",f,h]}],"field-sizing":[{"field-sizing":["fixed","content"]}],"pointer-events":[{"pointer-events":["auto","none"]}],resize:[{resize:["none","","y","x"]}],"scroll-behavior":[{scroll:["auto","smooth"]}],"scroll-m":[{"scroll-m":P()}],"scroll-mx":[{"scroll-mx":P()}],"scroll-my":[{"scroll-my":P()}],"scroll-ms":[{"scroll-ms":P()}],"scroll-me":[{"scroll-me":P()}],"scroll-mt":[{"scroll-mt":P()}],"scroll-mr":[{"scroll-mr":P()}],"scroll-mb":[{"scroll-mb":P()}],"scroll-ml":[{"scroll-ml":P()}],"scroll-p":[{"scroll-p":P()}],"scroll-px":[{"scroll-px":P()}],"scroll-py":[{"scroll-py":P()}],"scroll-ps":[{"scroll-ps":P()}],"scroll-pe":[{"scroll-pe":P()}],"scroll-pt":[{"scroll-pt":P()}],"scroll-pr":[{"scroll-pr":P()}],"scroll-pb":[{"scroll-pb":P()}],"scroll-pl":[{"scroll-pl":P()}],"snap-align":[{snap:["start","end","center","align-none"]}],"snap-stop":[{snap:["normal","always"]}],"snap-type":[{snap:["none","x","y","both"]}],"snap-strictness":[{snap:["mandatory","proximity"]}],touch:[{touch:["auto","none","manipulation"]}],"touch-x":[{"touch-pan":["x","left","right"]}],"touch-y":[{"touch-pan":["y","up","down"]}],"touch-pz":["touch-pinch-zoom"],select:[{select:["none","text","all","auto"]}],"will-change":[{"will-change":["auto","scroll","contents","transform",f,h]}],fill:[{fill:["none",...x()]}],"stroke-w":[{stroke:[M,Se,ue,Ue]}],stroke:[{stroke:["none",...x()]}],"forced-color-adjust":[{"forced-color-adjust":["auto","none"]}]},conflictingClassGroups:{overflow:["overflow-x","overflow-y"],overscroll:["overscroll-x","overscroll-y"],inset:["inset-x","inset-y","start","end","top","right","bottom","left"],"inset-x":["right","left"],"inset-y":["top","bottom"],flex:["basis","grow","shrink"],gap:["gap-x","gap-y"],p:["px","py","ps","pe","pt","pr","pb","pl"],px:["pr","pl"],py:["pt","pb"],m:["mx","my","ms","me","mt","mr","mb","ml"],mx:["mr","ml"],my:["mt","mb"],size:["w","h"],"font-size":["leading"],"fvn-normal":["fvn-ordinal","fvn-slashed-zero","fvn-figure","fvn-spacing","fvn-fraction"],"fvn-ordinal":["fvn-normal"],"fvn-slashed-zero":["fvn-normal"],"fvn-figure":["fvn-normal"],"fvn-spacing":["fvn-normal"],"fvn-fraction":["fvn-normal"],"line-clamp":["display","overflow"],rounded:["rounded-s","rounded-e","rounded-t","rounded-r","rounded-b","rounded-l","rounded-ss","rounded-se","rounded-ee","rounded-es","rounded-tl","rounded-tr","rounded-br","rounded-bl"],"rounded-s":["rounded-ss","rounded-es"],"rounded-e":["rounded-se","rounded-ee"],"rounded-t":["rounded-tl","rounded-tr"],"rounded-r":["rounded-tr","rounded-br"],"rounded-b":["rounded-br","rounded-bl"],"rounded-l":["rounded-tl","rounded-bl"],"border-spacing":["border-spacing-x","border-spacing-y"],"border-w":["border-w-x","border-w-y","border-w-s","border-w-e","border-w-t","border-w-r","border-w-b","border-w-l"],"border-w-x":["border-w-r","border-w-l"],"border-w-y":["border-w-t","border-w-b"],"border-color":["border-color-x","border-color-y","border-color-s","border-color-e","border-color-t","border-color-r","border-color-b","border-color-l"],"border-color-x":["border-color-r","border-color-l"],"border-color-y":["border-color-t","border-color-b"],translate:["translate-x","translate-y","translate-none"],"translate-none":["translate","translate-x","translate-y","translate-z"],"scroll-m":["scroll-mx","scroll-my","scroll-ms","scroll-me","scroll-mt","scroll-mr","scroll-mb","scroll-ml"],"scroll-mx":["scroll-mr","scroll-ml"],"scroll-my":["scroll-mt","scroll-mb"],"scroll-p":["scroll-px","scroll-py","scroll-ps","scroll-pe","scroll-pt","scroll-pr","scroll-pb","scroll-pl"],"scroll-px":["scroll-pr","scroll-pl"],"scroll-py":["scroll-pt","scroll-pb"],touch:["touch-x","touch-y","touch-pz"],"touch-x":["touch"],"touch-y":["touch"],"touch-pz":["touch"]},conflictingClassGroupModifiers:{"font-size":["leading"]},orderSensitiveModifiers:["*","**","after","backdrop","before","details-content","file","first-letter","first-line","marker","placeholder","selection"]}},wa=sa(Pa);function Ge(...e){return wa(Ht(e))}const xa=({message:e,type:r="info",duration:t=3e3,onClose:s,visible:o})=>{const{t:l}=q();u.useEffect(()=>{if(o){const p=setTimeout(()=>{s()},t);return()=>clearTimeout(p)}},[o,t,s]);const i={success:a.jsx(lt,{className:"w-5 h-5 text-green-500"}),error:a.jsx(Ae,{className:"w-5 h-5 text-red-500"}),info:a.jsx("svg",{className:"w-5 h-5 text-blue-500",fill:"none",viewBox:"0 0 24 24",stroke:"currentColor",children:a.jsx("path",{strokeLinecap:"round",strokeLinejoin:"round",strokeWidth:2,d:"M13 16h-1v-4h-1m1-4h.01M21 12a9 9 0 11-18 0 9 9 0 0118 0z"})}),warning:a.jsx("svg",{className:"w-5 h-5 text-yellow-500",fill:"none",viewBox:"0 0 24 24",stroke:"currentColor",children:a.jsx("path",{strokeLinecap:"round",strokeLinejoin:"round",strokeWidth:2,d:"M12 9v2m0 4h.01m-6.938 4h13.856c1.54 0 2.502-1.667 1.732-3L13.732 4c-.77-1.333-2.694-1.333-3.464 0L3.34 16c-.77 1.333.192 3 1.732 3z"})})},c={success:"bg-green-50 border-green-200",error:"bg-red-50 border-red-200",info:"bg-blue-50 border-blue-200",warning:"bg-yellow-50 border-yellow-200"},n={success:"text-green-800",error:"text-red-800",info:"text-blue-800",warning:"text-yellow-800"},v={success:"border-l-4 border-l-green-500",error:"border-l-4 border-l-red-600",info:"border-l-4 border-l-blue-500",warning:"border-l-4 border-l-yellow-500"};return a.jsx("div",{className:Ge("fixed top-4 right-4 z-50 max-w-sm p-4 rounded-md shadow-lg border",c[r],v[r],"transform transition-all duration-300 ease-in-out",o?"translate-x-0 opacity-100":"translate-x-full opacity-0"),children:a.jsxs("div",{className:"flex items-start",children:[a.jsx("div",{className:"flex-shrink-0",children:i[r]}),a.jsx("div",{className:"ml-3",children:a.jsx("p",{className:Ge("text-sm font-medium",n[r]),children:e})}),a.jsx("div",{className:"ml-auto pl-3",children:a.jsx("div",{className:"-mx-1.5 -my-1.5",children:a.jsxs("button",{onClick:s,className:Ge("inline-flex rounded-md p-1.5",`hover:bg-${r}-100 focus:outline-none focus:ring-2 focus:ring-offset-2 focus:ring-${r}-500`),children:[a.jsx("span",{className:"sr-only",children:l("common.dismiss")}),a.jsx(Ae,{className:"h-5 w-5"})]})})})]})})},jr=u.createContext(void 0),Ur=()=>{const e=u.useContext(jr);if(!e)throw new Error("useToast must be used within a ToastProvider");return e},Ca=({children:e})=>{const[r,t]=u.useState({message:"",type:"info",visible:!1,duration:3e3}),s=u.useCallback((l,i="info",c=3e3)=>{t({message:l,type:i,visible:!0,duration:c})},[]),o=u.useCallback(()=>{t(l=>({...l,visible:!1}))},[]);return a.jsxs(jr.Provider,{value:{showToast:s},children:[e,a.jsx(xa,{message:r.message,type:r.type,duration:r.duration,onClose:o,visible:r.visible})]})},Gr=u.createContext(void 0),Ra=()=>{const e=u.useContext(Gr);if(!e)throw new Error("useTheme must be used within a ThemeProvider");return e},Ea=({children:e})=>{const[r,t]=u.useState(()=>localStorage.getItem("theme")||"system"),[s,o]=u.useState("light"),l=i=>{t(i),localStorage.setItem("theme",i)};return u.useEffect(()=>{const i=()=>{const n=window.document.documentElement,v=window.matchMedia("(prefers-color-scheme: dark)").matches?"dark":"light",p=r==="system"?v:r;o(p),p==="dark"?(console.log("Applying dark mode to HTML root element"),n.classList.add("dark"),document.body.style.backgroundColor="#111827"):(console.log("Removing dark mode from HTML root element"),n.classList.remove("dark"),document.body.style.backgroundColor="")},c=window.matchMedia("(prefers-color-scheme: dark)");return c.addEventListener("change",i),i(),()=>{c.removeEventListener("change",i)}},[r]),a.jsx(Gr.Provider,{value:{theme:r,setTheme:l,resolvedTheme:s},children:e})},Kr="mcphub_servers_per_page",Te=5,qr=new Set([5,10,20,50]),Ta=()=>{if(typeof window>"u")return Te;const e=window.localStorage.getItem(Kr);if(!e)return Te;const r=Number(e);return qr.has(r)?r:Te},Re={startup:{maxAttempts:60,pollingInterval:3e3},normal:{pollingInterval:1e4}},Br=u.createContext(void 0),Na=({children:e})=>{const{t:r}=q(),{auth:t}=fe(),[s,o]=u.useState([]),[l,i]=u.useState([]),[c,n]=u.useState(null),[v,p]=u.useState(0),[m,y]=u.useState(!0),[O,C]=u.useState(0),[I,L]=u.useState(null),[R,z]=u.useState(1),[k,F]=u.useState(Ta),B=u.useRef(null),U=u.useRef(0),D=u.useRef(0),P=3e3,b=()=>{B.current&&(clearInterval(B.current),B.current=null)},te=u.useCallback(E=>{const T=(E==null?void 0:E.immediate)??!0;b();const S=async()=>{try{console.log("[ServerContext] Fetching servers from API...");const N=new URLSearchParams;N.append("page",R.toString()),N.append("limit",k.toString());const[G,$]=await Promise.all([V(`/servers?${N.toString()}`),V("/servers")]);D.current=Date.now(),G&&G.success&&Array.isArray(G.data)?(o(G.data),G.pagination?L(G.pagination):L(null)):G&&Array.isArray(G)?(o(G),L(null)):(console.error("Invalid server data format",{paginatedData:G}),o([]),L(null)),$&&$.success&&Array.isArray($.data)?i($.data):$&&Array.isArray($)?i($):i([]),n(null)}catch(N){console.error("Error fetching servers during normal polling",{err:N}),navigator.onLine?N instanceof TypeError&&(N.message.includes("NetworkError")||N.message.includes("Failed to fetch"))?n(r("errors.serverConnection")):n(r("errors.serverFetch")):n(r("errors.network"))}};T&&S(),B.current=setInterval(S,Re.normal.pollingInterval)},[r,R,k]);u.useEffect(()=>{t.isAuthenticated?(console.log("[ServerContext] User authenticated, triggering refresh"),p(E=>E+1)):(console.log("[ServerContext] User not authenticated, clearing data and stopping polling"),b(),o([]),i([]),y(!1),n(null))},[t.isAuthenticated]),u.useEffect(()=>{if(!t.isAuthenticated){console.log("[ServerContext] User not authenticated, skipping polling setup");return}v>0&&(U.current=0,C(0));const E=async()=>{try{console.log("[ServerContext] Initial fetch - attempt",U.current+1);const T=new URLSearchParams;T.append("page",R.toString()),T.append("limit",k.toString());const[S,N]=await Promise.all([V(`/servers?${T.toString()}`),V("/servers")]);return D.current=Date.now(),S&&S.success&&Array.isArray(S.data)?(o(S.data),S.pagination?L(S.pagination):L(null)):S&&Array.isArray(S)?(o(S),L(null)):(console.error("Invalid server data format",{paginatedData:S}),o([]),L(null)),N&&N.success&&Array.isArray(N.data)?i(N.data):N&&Array.isArray(N)?i(N):i([]),y(!1),te({immediate:!1}),!0}catch(T){return U.current+=1,console.error("Initial loading attempt failed",{attempt:U.current,err:T}),C(U.current),navigator.onLine?n(r("errors.initialStartup")):n(r("errors.network")),U.current>=Re.startup.maxAttempts&&(console.log("Maximum startup attempts reached, switching to normal polling"),y(!1),b(),te()),!1}};return m?(b(),E(),B.current=setInterval(E,Re.startup.pollingInterval),console.log(`Started initial polling with interval: ${Re.startup.pollingInterval}ms`)):te(),()=>{b()}},[v,r,m,te,R,k]),u.useEffect(()=>{if(!I)return;const E=Math.max(1,I.totalPages||1);R>E&&z(E)},[I,R]);const Z=u.useCallback(()=>{b(),m&&(y(!0),U.current=0,C(0)),p(E=>E+1)},[m]),X=u.useCallback(()=>{const T=Date.now()-D.current;console.log("[ServerContext] refreshIfNeeded called",{timeSinceLastFetch:T}),T>=P?(console.log("[ServerContext] Triggering refresh after minimum interval",{minRefreshInterval:P}),Z()):console.log("[ServerContext] Skipping refresh because minimum interval not reached",{minRefreshInterval:P,timeSinceLastFetch:T})},[Z]),se=u.useCallback(()=>{p(E=>E+1)},[]),le=u.useCallback(async E=>{try{const T=encodeURIComponent(E.name),S=await V(`/servers/${T}`);return S&&S.success&&S.data?{name:S.data.name,status:S.data.status,tools:S.data.tools||[],config:S.data.config}:(console.error("Failed to get server config",{serverName:E.name,serverData:S}),n(r("server.invalidConfig",{serverName:E.name})),null)}catch(T){return console.error("Error fetching server config",{serverName:E.name,err:T}),n(T instanceof Error?T.message:String(T)),null}},[r]),ee=u.useCallback(async E=>{try{const T=encodeURIComponent(E),S=await he(`/servers/${T}`);return!S||!S.success?(n((S==null?void 0:S.message)||r("server.deleteError",{serverName:E})),!1):(p(N=>N+1),!0)}catch(T){return n(r("errors.general")+": "+(T instanceof Error?T.message:String(T))),!1}},[r]),J=u.useCallback(async(E,T)=>{try{const S=encodeURIComponent(E.name),N=await ie(`/servers/${S}/toggle`,{enabled:T});return!N||!N.success?(console.error("Failed to toggle server",{serverName:E.name,result:N}),n((N==null?void 0:N.message)||r("server.toggleError",{serverName:E.name})),!1):(p(G=>G+1),!0)}catch(S){return console.error("Error toggling server",{serverName:E.name,err:S}),n(S instanceof Error?S.message:String(S)),!1}},[r]),Y=u.useCallback(async E=>{try{const T=encodeURIComponent(E.name),S=await ie(`/servers/${T}/reload`,{});return!S||!S.success?(console.error("Failed to reload server",{serverName:E.name,result:S}),n(r("server.reloadError",{serverName:E.name})),!1):(Z(),!0)}catch(T){return console.error("Error reloading server",{serverName:E.name,err:T}),n(T instanceof Error?T.message:String(T)),!1}},[r,Z]),x=u.useCallback(E=>{z(E)},[]),ce=u.useCallback(E=>{const T=qr.has(E)?E:Te;typeof window<"u"&&window.localStorage.setItem(Kr,String(T)),F(T),z(1)},[]),de={servers:s,allServers:l,error:c,setError:n,isLoading:m,fetchAttempts:O,pagination:I,currentPage:R,serversPerPage:k,setCurrentPage:x,setServersPerPage:ce,triggerRefresh:Z,refreshIfNeeded:X,handleServerAdd:se,handleServerEdit:le,handleServerRemove:ee,handleServerToggle:J,handleServerReload:Y};return a.jsx(Br.Provider,{value:de,children:e})},Da=()=>{const e=u.useContext(Br);if(e===void 0)throw new Error("useServerContext must be used within a ServerProvider");return e},Ke=()=>({enabled:!0,accessTokenLifetime:3600,refreshTokenLifetime:1209600,authorizationCodeLifetime:300,requireClientSecret:!1,allowedScopes:["read","write"],requireState:!1,dynamicRegistration:{enabled:!0,allowedGrantTypes:["authorization_code","refresh_token"],requiresAuthentication:!1}}),Hr=u.createContext(void 0),ci=()=>{const e=u.useContext(Hr);if(!e)throw new Error("useSettings must be used within a SettingsProvider");return e},Ma=({children:e})=>{const{t:r}=q(),{showToast:t}=Ur(),{auth:s}=fe(),[o,l]=u.useState({enableGlobalRoute:!0,enableGroupNameRoute:!0,enableBearerAuth:!0,bearerAuthKey:"",bearerAuthHeaderName:"Authorization",jsonBodyLimit:"1mb",skipAuth:!1}),[i,c]=u.useState({bearerAuthKey:"",bearerAuthHeaderName:"Authorization",jsonBodyLimit:"1mb"}),[n,v]=u.useState({pythonIndexUrl:"",npmRegistry:"",baseUrl:"http://localhost:3000"}),[p,m]=u.useState({enabled:!1,dbUrl:"",basePacingDelayMs:void 0,embeddingProvider:"openai",embeddingEncodingFormat:"auto",openaiApiBaseUrl:"",openaiApiKey:"",openaiApiEmbeddingModel:"",azureOpenaiEndpoint:"",azureOpenaiApiKey:"",azureOpenaiApiVersion:"",azureOpenaiEmbeddingDeployment:"",azureOpenaiEmbeddingModel:"",progressiveDisclosure:!1,embeddingMaxTokens:void 0}),[y,O]=u.useState({apiKey:"",referer:"https://www.mcphub.app",title:"MCPHub",baseUrl:"https://api.mcprouter.to/v1"}),[C,I]=u.useState(Ke()),[L,R]=u.useState("-"),[z,k]=u.useState(!1),[F,B]=u.useState([]),[U,D]=u.useState(!1),[P,b]=u.useState(null),[te,Z]=u.useState(0),X=u.useCallback(()=>{Z(g=>g+1)},[]),se=u.useCallback(async()=>{var g,d,w,We,Ye,Qe,Ze,Xe,er,rr,tr,ar,sr,or,nr,ir,lr,ur;D(!0),b(null);try{const A=await V("/settings");if(A.success&&((d=(g=A.data)==null?void 0:g.systemConfig)!=null&&d.routing)&&l({enableGlobalRoute:A.data.systemConfig.routing.enableGlobalRoute??!0,enableGroupNameRoute:A.data.systemConfig.routing.enableGroupNameRoute??!0,enableBearerAuth:A.data.systemConfig.routing.enableBearerAuth??!0,bearerAuthKey:A.data.systemConfig.routing.bearerAuthKey||"",bearerAuthHeaderName:A.data.systemConfig.routing.bearerAuthHeaderName||"Authorization",jsonBodyLimit:A.data.systemConfig.routing.jsonBodyLimit||"1mb",skipAuth:A.data.systemConfig.routing.skipAuth??!1}),A.success&&((We=(w=A.data)==null?void 0:w.systemConfig)!=null&&We.install)&&v({pythonIndexUrl:A.data.systemConfig.install.pythonIndexUrl||"",npmRegistry:A.data.systemConfig.install.npmRegistry||"",baseUrl:A.data.systemConfig.install.baseUrl||"http://localhost:3000"}),A.success&&((Qe=(Ye=A.data)==null?void 0:Ye.systemConfig)!=null&&Qe.smartRouting)&&m({enabled:A.data.systemConfig.smartRouting.enabled??!1,dbUrl:A.data.systemConfig.smartRouting.dbUrl||"",basePacingDelayMs:A.data.systemConfig.smartRouting.basePacingDelayMs,embeddingProvider:A.data.systemConfig.smartRouting.embeddingProvider==="azure_openai"?"azure_openai":"openai",embeddingEncodingFormat:A.data.systemConfig.smartRouting.embeddingEncodingFormat==="base64"?"base64":A.data.systemConfig.smartRouting.embeddingEncodingFormat==="float"?"float":"auto",openaiApiBaseUrl:A.data.systemConfig.smartRouting.openaiApiBaseUrl||"",openaiApiKey:A.data.systemConfig.smartRouting.openaiApiKey||"",openaiApiEmbeddingModel:A.data.systemConfig.smartRouting.openaiApiEmbeddingModel||"",azureOpenaiEndpoint:A.data.systemConfig.smartRouting.azureOpenaiEndpoint||"",azureOpenaiApiKey:A.data.systemConfig.smartRouting.azureOpenaiApiKey||"",azureOpenaiApiVersion:A.data.systemConfig.smartRouting.azureOpenaiApiVersion||"",azureOpenaiEmbeddingDeployment:A.data.systemConfig.smartRouting.azureOpenaiEmbeddingDeployment||"",azureOpenaiEmbeddingModel:A.data.systemConfig.smartRouting.azureOpenaiEmbeddingModel||"",progressiveDisclosure:A.data.systemConfig.smartRouting.progressiveDisclosure??!1,embeddingMaxTokens:A.data.systemConfig.smartRouting.embeddingMaxTokens}),A.success&&((Xe=(Ze=A.data)==null?void 0:Ze.systemConfig)!=null&&Xe.mcpRouter)&&O({apiKey:A.data.systemConfig.mcpRouter.apiKey||"",referer:A.data.systemConfig.mcpRouter.referer||"https://www.mcphub.app",title:A.data.systemConfig.mcpRouter.title||"MCPHub",baseUrl:A.data.systemConfig.mcpRouter.baseUrl||"https://api.mcprouter.to/v1"}),A.success)if((rr=(er=A.data)==null?void 0:er.systemConfig)!=null&&rr.oauthServer){const W=A.data.systemConfig.oauthServer,oe=Ke(),Oe=oe.dynamicRegistration,Wr=Array.isArray(W.allowedScopes)?[...W.allowedScopes]:[...oe.allowedScopes],Yr=Array.isArray((tr=W.dynamicRegistration)==null?void 0:tr.allowedGrantTypes)?[...W.dynamicRegistration.allowedGrantTypes]:[...Oe.allowedGrantTypes];I({enabled:W.enabled??oe.enabled,accessTokenLifetime:W.accessTokenLifetime??oe.accessTokenLifetime,refreshTokenLifetime:W.refreshTokenLifetime??oe.refreshTokenLifetime,authorizationCodeLifetime:W.authorizationCodeLifetime??oe.authorizationCodeLifetime,requireClientSecret:W.requireClientSecret??oe.requireClientSecret,requireState:W.requireState??oe.requireState,allowedScopes:Wr,dynamicRegistration:{enabled:((ar=W.dynamicRegistration)==null?void 0:ar.enabled)??Oe.enabled,allowedGrantTypes:Yr,requiresAuthentication:((sr=W.dynamicRegistration)==null?void 0:sr.requiresAuthentication)??Oe.requiresAuthentication}})}else I(Ke());A.success&&((nr=(or=A.data)==null?void 0:or.systemConfig)==null?void 0:nr.nameSeparator)!==void 0&&R(A.data.systemConfig.nameSeparator),A.success&&((lr=(ir=A.data)==null?void 0:ir.systemConfig)==null?void 0:lr.enableSessionRebuild)!==void 0&&k(A.data.systemConfig.enableSessionRebuild),A.success&&Array.isArray((ur=A.data)==null?void 0:ur.bearerKeys)&&B(A.data.bearerKeys)}catch(A){console.error("Failed to fetch settings",{error:A}),b(A instanceof Error?A.message:"Failed to fetch settings"),t(r("errors.failedToFetchSettings"))}finally{D(!1)}},[r,t]),le=async(g,d)=>{D(!0),b(null);try{const w=await _("/system-config",{routing:{[g]:d}});return w.success?(l({...o,[g]:d}),t(r("settings.systemConfigUpdated")),!0):(b(w.error||"Failed to update routing config"),t(w.error||r("errors.failedToUpdateRoutingConfig")),!1)}catch(w){return console.error("Failed to update routing config",{key:g,value:d,error:w}),b(w instanceof Error?w.message:"Failed to update routing config"),t(r("errors.failedToUpdateRoutingConfig")),!1}finally{D(!1)}},ee=async(g,d)=>{D(!0),b(null);try{const w=await _("/system-config",{install:{[g]:d}});return w.success?(v({...n,[g]:d}),t(r("settings.systemConfigUpdated")),!0):(b(w.error||"Failed to update install config"),t(w.error||r("errors.failedToUpdateInstallConfig")),!1)}catch(w){return console.error("Failed to update install config",{key:g,value:d,error:w}),b(w instanceof Error?w.message:"Failed to update install config"),t(r("errors.failedToUpdateInstallConfig")),!1}finally{D(!1)}},J=async(g,d)=>{D(!0),b(null);try{const w=await _("/system-config",{smartRouting:{[g]:d}});return w.success?(m({...p,[g]:d}),t(r("settings.systemConfigUpdated")),!0):(b(w.error||"Failed to update smart routing config"),t(w.error||r("errors.failedToUpdateSmartRoutingConfig")),!1)}catch(w){return console.error("Failed to update smart routing config",{key:g,value:d,error:w}),b(w instanceof Error?w.message:"Failed to update smart routing config"),t(r("errors.failedToUpdateSmartRoutingConfig")),!1}finally{D(!1)}},Y=async g=>{D(!0),b(null);try{const d=await _("/system-config",{smartRouting:g});return d.success?(m({...p,...g}),t(r("settings.systemConfigUpdated")),!0):(b(d.error||"Failed to update smart routing config"),t(d.error||r("errors.failedToUpdateSmartRoutingConfig")),!1)}catch(d){return console.error("Failed to batch update smart routing config",{updates:g,error:d}),b(d instanceof Error?d.message:"Failed to update smart routing config"),t(r("errors.failedToUpdateSmartRoutingConfig")),!1}finally{D(!1)}},x=async g=>{D(!0),b(null);try{const d=await _("/system-config",{routing:g});return d.success?(l({...o,...g}),t(r("settings.systemConfigUpdated")),!0):(b(d.error||"Failed to update routing config"),t(d.error||r("errors.failedToUpdateRoutingConfig")),!1)}catch(d){return console.error("Failed to batch update routing config",{updates:g,error:d}),b(d instanceof Error?d.message:"Failed to update routing config"),t(r("errors.failedToUpdateRoutingConfig")),!1}finally{D(!1)}},ce=async(g,d)=>{D(!0),b(null);try{const w=await _("/system-config",{mcpRouter:{[g]:d}});return w.success?(O({...y,[g]:d}),t(r("settings.systemConfigUpdated")),!0):(b(w.error||"Failed to update MCP Router config"),t(w.error||r("errors.failedToUpdateMCPRouterConfig")),!1)}catch(w){return console.error("Failed to update MCP Router config",{key:g,value:d,error:w}),b(w instanceof Error?w.message:"Failed to update MCP Router config"),t(r("errors.failedToUpdateMCPRouterConfig")),!1}finally{D(!1)}},de=async g=>{D(!0),b(null);try{const d=await _("/system-config",{mcpRouter:g});return d.success?(O({...y,...g}),t(r("settings.systemConfigUpdated")),!0):(b(d.error||"Failed to update MCP Router config"),t(d.error||r("errors.failedToUpdateMCPRouterConfig")),!1)}catch(d){return console.error("Failed to batch update MCP Router config",{updates:g,error:d}),b(d instanceof Error?d.message:"Failed to update MCP Router config"),t(r("errors.failedToUpdateMCPRouterConfig")),!1}finally{D(!1)}},E=async(g,d)=>{D(!0),b(null);try{const w=await _("/system-config",{oauthServer:{[g]:d}});return w.success?(I({...C,[g]:d}),t(r("settings.systemConfigUpdated")),!0):(b(w.error||"Failed to update OAuth server config"),t(w.error||r("errors.failedToUpdateOAuthServerConfig")),!1)}catch(w){return console.error("Failed to update OAuth server config",{key:g,value:d,error:w}),b(w instanceof Error?w.message:"Failed to update OAuth server config"),t(r("errors.failedToUpdateOAuthServerConfig")),!1}finally{D(!1)}},T=async g=>{D(!0),b(null);try{const d=await _("/system-config",{oauthServer:g});return d.success?(I({...C,...g}),t(r("settings.systemConfigUpdated")),!0):(b(d.error||"Failed to update OAuth server config"),t(d.error||r("errors.failedToUpdateOAuthServerConfig")),!1)}catch(d){return console.error("Failed to batch update OAuth server config",{updates:g,error:d}),b(d instanceof Error?d.message:"Failed to update OAuth server config"),t(r("errors.failedToUpdateOAuthServerConfig")),!1}finally{D(!1)}},S=async g=>{D(!0),b(null);try{const d=await _("/system-config",{nameSeparator:g});return d.success?(R(g),t(r("settings.systemConfigUpdated")),!0):(b(d.error||"Failed to update name separator"),t(d.error||r("errors.failedToUpdateNameSeparator")),!1)}catch(d){return console.error("Failed to update name separator",{value:g,error:d}),b(d instanceof Error?d.message:"Failed to update name separator"),t(r("errors.failedToUpdateNameSeparator")),!1}finally{D(!1)}},N=async g=>{D(!0),b(null);try{const d=await _("/system-config",{enableSessionRebuild:g});return d.success?(k(g),t(r("settings.systemConfigUpdated")),!0):(b(d.error||"Failed to update session rebuild setting"),t(d.error||r("errors.failedToUpdateSessionRebuild")),!1)}catch(d){return console.error("Failed to update session rebuild setting",{value:g,error:d}),b(d instanceof Error?d.message:"Failed to update session rebuild setting"),t(r("errors.failedToUpdateSessionRebuild")),!1}finally{D(!1)}},G=async g=>{D(!0),b(null);try{return await V(`/mcp-settings/export?serverName=${g||""}`)}catch(d){console.error("Failed to export MCP settings",{serverName:g,error:d});const w=d instanceof Error?d.message:"Failed to export MCP settings";b(w),t(w)}finally{D(!1)}},$=async()=>{try{const g=await V("/auth/keys");g.success&&Array.isArray(g.data)&&B(g.data)}catch(g){console.error("Failed to refresh bearer keys",{error:g}),t(r("errors.failedToFetchSettings"))}},j=async g=>{try{const d=await ie("/auth/keys",g);return d.success&&d.data?(await $(),t(r("settings.systemConfigUpdated")),d.data):(t(d.message||r("errors.failedToUpdateRoutingConfig")),null)}catch(d){return console.error("Failed to create bearer key",{error:d}),t(r("errors.failedToUpdateRoutingConfig")),null}},we=async(g,d)=>{try{const w=await _(`/auth/keys/${g}`,d);return w.success&&w.data?(await $(),t(r("settings.systemConfigUpdated")),w.data):(t(w.message||r("errors.failedToUpdateRoutingConfig")),null)}catch(w){return console.error("Failed to update bearer key",{id:g,error:w}),t(r("errors.failedToUpdateRoutingConfig")),null}},me=async g=>{try{const d=await he(`/auth/keys/${g}`);return d.success?(await $(),t(r("settings.systemConfigUpdated")),!0):(t(d.message||r("errors.failedToUpdateRoutingConfig")),!1)}catch(d){return console.error("Failed to delete bearer key",{id:g,error:d}),t(r("errors.failedToUpdateRoutingConfig")),!1}};u.useEffect(()=>{se()},[se,te]),u.useEffect(()=>{s.isAuthenticated&&(console.log("[SettingsContext] User authenticated, triggering settings refresh"),X())},[s.isAuthenticated,X]),u.useEffect(()=>{o&&c({bearerAuthKey:o.bearerAuthKey,bearerAuthHeaderName:o.bearerAuthHeaderName,jsonBodyLimit:o.jsonBodyLimit})},[o]);const pe={routingConfig:o,tempRoutingConfig:i,setTempRoutingConfig:c,installConfig:n,smartRoutingConfig:p,mcpRouterConfig:y,oauthServerConfig:C,nameSeparator:L,enableSessionRebuild:z,bearerKeys:F,loading:U,error:P,setError:b,triggerRefresh:X,fetchSettings:se,updateRoutingConfig:le,updateInstallConfig:ee,updateSmartRoutingConfig:J,updateSmartRoutingConfigBatch:Y,updateRoutingConfigBatch:x,updateMCPRouterConfig:ce,updateMCPRouterConfigBatch:de,updateOAuthServerConfig:E,updateOAuthServerConfigBatch:T,updateNameSeparator:S,updateSessionRebuild:N,exportMCPSettings:G,refreshBearerKeys:$,createBearerKey:j,updateBearerKey:we,deleteBearerKey:me};return a.jsx(Hr.Provider,{value:pe,children:e})},Ia=()=>{const{t:e}=q(),{theme:r,setTheme:t}=Ra(),s=()=>{t(r==="light"?"dark":"light")};return a.jsx("button",{onClick:s,className:"p-2 rounded-md text-gray-500 dark:text-gray-400 hover:text-gray-900 dark:hover:text-gray-200 hover:bg-gray-100 dark:bg-gray-800 dark:hover:bg-gray-700 focus:outline-none",title:e(r==="light"?"theme.dark":"theme.light"),"aria-label":e(r==="light"?"theme.dark":"theme.light"),children:r==="light"?a.jsx(ut,{className:"h-5 w-5"}):a.jsx(ct,{className:"h-5 w-5"})})},za=e=>{const{t:r}=q();return a.jsxs("svg",{role:"img",viewBox:"0 0 24 24",xmlns:"http://www.w3.org/2000/svg",width:"24",height:"24",fill:"none",stroke:"currentColor",strokeWidth:2,...e,children:[a.jsx("title",{children:r("common.language")}),a.jsx("circle",{cx:"12",cy:"12",r:"10"}),a.jsx("path",{strokeLinecap:"round",strokeLinejoin:"round",d:"M2 12h20"}),a.jsx("path",{strokeLinecap:"round",strokeLinejoin:"round",d:"M12 2a15.3 15.3 0 014 10 15.3 15.3 0 01-4 10 15.3 15.3 0 01-4-10 15.3 15.3 0 014-10z"})]})},Oa=()=>{const{i18n:e}=q(),[r,t]=u.useState(!1),[s,o]=u.useState(e.language),l=[{code:"en",label:"English"},{code:"zh",label:"中文"},{code:"fr",label:"Français"},{code:"tr",label:"Türkçe"}];u.useEffect(()=>{o(e.language)},[e.language]),u.useEffect(()=>{const n=v=>{v.target.closest(".language-dropdown")||t(!1)};return r&&document.addEventListener("mousedown",n),()=>{document.removeEventListener("mousedown",n)}},[r]);const i=n=>{localStorage.setItem("i18nextLng",n),t(!1),window.location.reload()},c=()=>{t(!r)};return a.jsxs("div",{className:"relative language-dropdown",children:[a.jsx("button",{onClick:c,className:"p-2 rounded-md text-gray-500 dark:text-gray-400 hover:text-gray-900 dark:hover:text-gray-200 hover:bg-gray-100 dark:bg-gray-800 dark:hover:bg-gray-700 focus:outline-none","aria-label":"Language Switcher",children:a.jsx(za,{className:"h-5 w-5"})}),r&&a.jsx("div",{className:"absolute right-0 mt-2 w-24 bg-white dark:bg-gray-800 rounded-md shadow-lg border border-gray-200 dark:border-gray-700 z-50",children:a.jsx("div",{children:l.map(n=>a.jsx("button",{onClick:()=>i(n.code),className:`flex items-center w-full px-4 py-2 text-sm hover:bg-gray-100 dark:hover:bg-gray-700 ${s.startsWith(n.code)?"bg-blue-50 text-blue-700":"text-gray-700 dark:text-gray-300 hover:bg-gray-100 dark:hover:bg-gray-100"}`,children:n.label},n.code))})})]})},La=e=>{const{t:r}=q();return a.jsxs("svg",{role:"img",viewBox:"0 0 24 24",xmlns:"http://www.w3.org/2000/svg",width:"24",height:"24",fill:"currentColor",...e,children:[a.jsx("title",{children:r("common.github")}),a.jsx("path",{d:"M12 .297c-6.63 0-12 5.373-12 12 0 5.303 3.438 9.8 8.205 11.385.6.113.82-.258.82-.577 0-.285-.01-1.04-.015-2.04-3.338.724-4.042-1.61-4.042-1.61C4.422 18.07 3.633 17.7 3.633 17.7c-1.087-.744.084-.729.084-.729 1.205.084 1.838 1.236 1.838 1.236 1.07 1.835 2.809 1.305 3.495.998.108-.776.417-1.305.76-1.605-2.665-.3-5.466-1.332-5.466-5.93 0-1.31.465-2.38 1.235-3.22-.135-.303-.54-1.523.105-3.176 0 0 1.005-.322 3.3 1.23.96-.267 1.98-.399 3-.405 1.02.006 2.04.138 3 .405 2.28-1.552 3.285-1.23 3.285-1.23.645 1.653.24 2.873.12 3.176.765.84 1.23 1.91 1.23 3.22 0 4.61-2.805 5.625-5.475 5.92.42.36.81 1.096.81 2.22 0 1.606-.015 2.896-.015 3.286 0 .315.21.69.825.57C20.565 22.092 24 17.592 24 12.297c0-6.627-5.373-12-12-12"})]})},Fa=async()=>{try{const e=await V("/logs");if(!e.success)throw new Error(e.error||"Failed to fetch logs");return e.data}catch(e){throw console.error("Error fetching logs",{error:e}),e}},ja=async()=>{try{const e=await he("/logs");if(!e.success)throw new Error(e.error||"Failed to clear logs")}catch(e){throw console.error("Error clearing logs",{error:e}),e}};class Ua{constructor(){be(this,"eventSource",null);be(this,"subscribers",new Set);be(this,"reconnectTimer",null);be(this,"openAttempts",0)}subscribe(r){return this.subscribers.add(r),this.subscribers.size===1&&(this.openAttempts=0,this.openEventSource()),()=>{this.subscribers.delete(r),this.subscribers.size===0&&this.close()}}openEventSource(){this.closeEventSource();const r=Pe();if(!r){console.warn("[LogStreamManager] No token available, scheduling reconnect..."),this.scheduleReconnect();return}try{const t=Pr(`/logs/stream?token=${r}`);let s=t;try{const o=new URL(t);o.search="",s=o.toString()}catch{s=t.split("?")[0]||t}console.log("[LogStreamManager] Opening EventSource:",s),this.eventSource=new EventSource(t),this.eventSource.onmessage=o=>{this.subscribers.forEach(l=>l(o))},this.eventSource.onerror=()=>{console.warn("[LogStreamManager] EventSource error, attempting reconnect..."),this.closeEventSource(),this.subscribers.size>0&&this.scheduleReconnect()},this.openAttempts=0,console.log("[LogStreamManager] EventSource opened successfully")}catch(t){console.error("[LogStreamManager] Failed to open EventSource:",t),this.closeEventSource(),this.subscribers.size>0&&this.scheduleReconnect()}}closeEventSource(){this.eventSource&&(this.eventSource.close(),this.eventSource=null)}scheduleReconnect(){if(this.reconnectTimer!==null)return;const r=Math.min(1e3*Math.pow(2,this.openAttempts),8e3);this.openAttempts++,console.log(`[LogStreamManager] Scheduling reconnect in ${r}ms (attempt ${this.openAttempts})`),this.reconnectTimer=setTimeout(()=>{this.reconnectTimer=null,this.subscribers.size>0&&this.openEventSource()},r)}close(){this.closeEventSource(),this.reconnectTimer!==null&&(clearTimeout(this.reconnectTimer),this.reconnectTimer=null)}}const Je=new Ua,di=()=>{const[e,r]=u.useState([]),[t,s]=u.useState(!0),[o,l]=u.useState(null);return u.useEffect(()=>{let c=!0;(async()=>{try{const m=await Fa();c&&(r(m),s(!1))}catch(m){c&&(l(m instanceof Error?m:new Error("Failed to fetch logs")),s(!1))}})();const v=m=>{if(c)try{const y=JSON.parse(m.data);if(y.type==="initial")return;y.type==="log"&&r(O=>[...O,y.log])}catch(y){console.error("Error parsing SSE message",{err:y})}},p=Je.subscribe(v);return()=>{c=!1,p()}},[]),{logs:e,loading:t,error:o,clearLogs:async()=>{try{await ja(),r([])}catch(c){l(c instanceof Error?c:new Error("Failed to clear logs"))}}}},Ga=5e3,Vr=u.createContext(void 0),Ka=e=>!!e&&typeof e.serverName=="string"&&typeof e.current=="number"&&typeof e.total=="number"&&e.total>0&&e.current>=0&&e.current<=e.total&&["started","in_progress","completed","error"].includes(String(e.status)),qa=({children:e})=>{const[r,t]=u.useState([]),s=u.useRef(new Map);u.useEffect(()=>{const l=m=>{const y=s.current.get(m);y&&(clearTimeout(y),s.current.delete(m))},i=()=>{s.current.forEach(m=>clearTimeout(m)),s.current.clear()},c=m=>{t(y=>{const O=y.findIndex(I=>I.serverName===m.serverName);if(O===-1)return[...y,m];const C=[...y];return C[O]=m,C})},n=m=>{t(y=>y.filter(O=>O.serverName!==m))},v=m=>{try{const y=JSON.parse(m.data);if((y==null?void 0:y.type)!=="embedding-sync-progress"||!Ka(y.progress))return;if(l(y.progress.serverName),y.progress.status==="error"){n(y.progress.serverName);return}const O={serverName:y.progress.serverName,current:y.progress.current,total:y.progress.total,status:y.progress.status};if(c(O),y.progress.status==="completed"){const C=setTimeout(()=>{n(y.progress.serverName),s.current.delete(y.progress.serverName)},Ga);s.current.set(y.progress.serverName,C)}}catch{}},p=Je.subscribe(v);return()=>{i(),p()}},[]);const o=u.useMemo(()=>({activeSyncs:r}),[r]);return a.jsx(Vr.Provider,{value:o,children:e})},Ba=()=>{const e=u.useContext(Vr);if(!e)throw new Error("useEmbeddingSync must be used within an EmbeddingSyncProvider");return e},Ha=()=>{const{t:e}=q(),r=et(),t=kr();return u.useMemo(()=>{const s=r.pathname,o=e("app.title");if(s==="/")return[o,e("nav.dashboard")];if(s.startsWith("/servers"))return[o,e("nav.servers")];if(s.startsWith("/groups"))return[o,e("nav.groups")];if(s.startsWith("/prompts"))return[o,e("nav.prompts")];if(s.startsWith("/resources"))return[o,e("nav.resources")];if(s.startsWith("/users"))return[o,e("nav.users")];if(s.startsWith("/market")){const l=t.serverName,i=[o,e("nav.market")];return l&&i.push(l),i}return s.startsWith("/logs")?[o,e("nav.logs")]:s.startsWith("/activity")?[o,e("nav.activity")]:s.startsWith("/settings")?[o,e("nav.settings")]:[o]},[r.pathname,t,e])},Va=({onToggleSidebar:e})=>{const{t:r}=q(),{activeSyncs:t}=Ba(),s=Ha();return a.jsxs("header",{className:"hub-topbar shrink-0",children:[a.jsx("button",{onClick:e,className:"hub-icon-btn","aria-label":r("app.toggleSidebar"),children:a.jsx(dt,{size:16})}),a.jsx("div",{className:"hub-crumb flex items-center min-w-0",children:s.map((o,l)=>a.jsxs(Ne.Fragment,{children:[l>0&&a.jsx("span",{className:"sep",children:"/"}),l===s.length-1?a.jsx("b",{className:"truncate",children:o}):a.jsx("span",{className:"truncate",children:o})]},l))}),a.jsx("div",{className:"flex-1 flex justify-center px-2 min-w-0",children:t.length>0&&a.jsx("div",{className:"flex max-w-full flex-wrap justify-center gap-2",children:t.map(o=>a.jsxs("div",{className:"hub-card flex min-w-0 w-56 max-w-full flex-col px-3 py-1.5 text-xs",style:{borderRadius:7},title:r("app.embeddingSyncProgressAriaLabel",{serverName:o.serverName,current:o.current,total:o.total}),children:[a.jsx("span",{className:"truncate hub-mono text-[var(--hub-ink-2)]",children:r("app.embeddingSyncProgress",{serverName:o.serverName})}),a.jsxs("div",{className:"mt-1 flex items-center gap-2",children:[a.jsx("progress",{className:"h-1.5 flex-1",value:o.current,max:o.total,"aria-label":r("app.embeddingSyncProgressAriaLabel",{serverName:o.serverName,current:o.current,total:o.total})}),a.jsxs("span",{className:"shrink-0 hub-mono hub-num text-[var(--hub-ink-3)]",children:[o.current,"/",o.total]})]})]},o.serverName))})}),a.jsxs("div",{className:"ml-auto flex items-center gap-1 shrink-0",children:[a.jsx("a",{href:"https://github.com/samanhappy/mcphub",target:"_blank",rel:"noopener noreferrer",className:"hub-icon-btn","aria-label":"GitHub Repository",children:a.jsx(La,{className:"h-4 w-4"})}),a.jsx("a",{href:"https://docs.mcphub.app",target:"_blank",rel:"noopener noreferrer",className:"hub-icon-btn","aria-label":"Documentation",children:a.jsx(mt,{className:"h-4 w-4"})}),a.jsx(Ia,{}),a.jsx(Oa,{})]})]})},$a=()=>{const{t:e}=q(),[r,t]=u.useState([]),[s,o]=u.useState(!0),[l,i]=u.useState(null),[c,n]=u.useState(0),v=u.useCallback(async()=>{try{o(!0);const R=await V("/groups");R&&R.success&&Array.isArray(R.data)?t(R.data):(console.error("Invalid group data format:",R),t([])),i(null)}catch(R){console.error("Error fetching groups:",R),i(R instanceof Error?R.message:"Failed to fetch groups"),t([])}finally{o(!1)}},[]),p=u.useCallback(()=>{n(R=>R+1)},[]),m=async(R,z,k=[])=>{try{const F=await ie("/groups",{name:R,description:z,servers:k});return console.log("Group created successfully:",F),!F||!F.success?(i((F==null?void 0:F.message)||e("groups.createError")),F):(p(),F||null)}catch(F){return i(F instanceof Error?F.message:"Failed to create group"),null}},y=async(R,z)=>{try{const k=await _(`/groups/${R}`,z);return!k||!k.success?(i((k==null?void 0:k.message)||e("groups.updateError")),k):(p(),k||null)}catch(k){return i(k instanceof Error?k.message:"Failed to update group"),null}},O=async(R,z)=>{try{const k=await _(`/groups/${R}/servers/batch`,{servers:z});return!k||!k.success?(i((k==null?void 0:k.message)||e("groups.updateError")),null):(p(),k.data||null)}catch(k){return i(k instanceof Error?k.message:"Failed to update group servers"),null}},C=async R=>{try{const z=await he(`/groups/${R}`);return!z||!z.success?(i((z==null?void 0:z.message)||e("groups.deleteError")),z):(p(),z)}catch(z){return i(z instanceof Error?z.message:"Failed to delete group"),null}},I=async(R,z)=>{try{const k=await ie(`/groups/${R}/servers`,{serverName:z});return!k||!k.success?(i((k==null?void 0:k.message)||e("groups.serverAddError")),null):(p(),k.data||null)}catch(k){return i(k instanceof Error?k.message:"Failed to add server to group"),null}},L=async(R,z)=>{try{const k=await he(`/groups/${R}/servers/${z}`);return!k||!k.success?(i((k==null?void 0:k.message)||e("groups.serverRemoveError")),null):(p(),k.data||null)}catch(k){return i(k instanceof Error?k.message:"Failed to remove server from group"),null}};return u.useEffect(()=>{v()},[v,c]),{groups:r,loading:s,error:l,setError:i,triggerRefresh:p,createGroup:m,updateGroup:y,updateGroupServers:O,deleteGroup:C,addServerToGroup:I,removeServerFromGroup:L}},mi=({permissions:e,fallback:r=null,children:t})=>$r(e)?a.jsx(a.Fragment,{children:t}):a.jsx(a.Fragment,{children:r}),$r=e=>{const{auth:r}=fe();if(!r.isAuthenticated||!r.user)return!1;const t=r.user.permissions||[];return e==="x"&&!t.includes("x")?!1:t.includes("*")||r.user.isAdmin?!0:(Array.isArray(e)?e:[e]).some(o=>t.includes(o))},_a="https://registry.npmjs.org",Ja="@samanhappy/mcphub",_r=async()=>{try{const e=await fetch(`${_a}/${Ja}/latest`);if(!e.ok)throw new Error(`Failed to fetch latest version: ${e.status}`);return(await e.json()).version||null}catch(e){return console.error("Error checking for latest version:",e),null}},Jr=(e,r)=>{if(e==="dev")return-1;const t=e.split(".").map(Number),s=r.split(".").map(Number);for(let o=0;o<3;o++){const l=t[o]||0,i=s[o]||0;if(l>i)return-1;if(l<i)return 1}return 0},Wa=({isOpen:e,onClose:r,version:t})=>{const{t:s}=q(),[o,l]=u.useState(!1),[i,c]=u.useState(""),[n,v]=u.useState(!1),p=async()=>{v(!0);try{const m=await _r();m&&(c(m),l(Jr(t,m)>0))}catch(m){console.error("Failed to check for updates:",m)}finally{v(!1)}};return u.useEffect(()=>{e&&p()},[e,t]),e?a.jsx("div",{className:"fixed inset-0 bg-black/50 bg-opacity-30 z-50 flex items-center justify-center p-4",children:a.jsx("div",{className:"bg-white dark:bg-gray-800 rounded-lg shadow-lg max-w-md w-full",children:a.jsxs("div",{className:"p-6 relative",children:[a.jsx("button",{onClick:r,className:"absolute top-4 right-4 text-gray-400 hover:text-gray-500 dark:text-gray-500 dark:hover:text-gray-400","aria-label":s("common.close"),children:a.jsx(Ae,{className:"h-5 w-5"})}),a.jsx("h3",{className:"text-lg font-medium text-gray-900 dark:text-gray-100 mb-4",children:s("about.title")}),a.jsxs("div",{className:"space-y-4",children:[a.jsxs("div",{className:"flex items-center justify-between",children:[a.jsxs("span",{className:"text-gray-700 dark:text-gray-300",children:[s("about.currentVersion"),":"]}),a.jsx("span",{className:"font-medium text-gray-900 dark:text-gray-100",children:t})]}),o&&i&&a.jsx("div",{className:"bg-blue-50 dark:bg-blue-900 p-3 rounded",children:a.jsxs("div",{className:"flex items-start",children:[a.jsx("div",{className:"flex-shrink-0",children:a.jsx("svg",{className:"h-5 w-5 text-blue-600 dark:text-blue-300",fill:"none",viewBox:"0 0 24 24",stroke:"currentColor",children:a.jsx("path",{strokeLinecap:"round",strokeLinejoin:"round",strokeWidth:2,d:"M13 16h-1v-4h-1m1-4h.01M21 12a9 9 0 11-18 0 9 9 0 0118 0z"})})}),a.jsxs("div",{className:"ml-3 flex-1 text-sm text-blue-700 dark:text-blue-300",children:[a.jsx("p",{children:s("about.newVersionAvailable",{version:i})}),a.jsx("p",{className:"mt-1",children:a.jsx("a",{href:"https://github.com/samanhappy/mcphub",target:"_blank",rel:"noopener noreferrer",className:"text-blue-600 dark:text-blue-400 hover:underline",children:s("about.viewOnGitHub")})})]})]})}),a.jsxs("button",{onClick:p,disabled:n,className:`hub-btn mt-4 ${n?"opacity-50 cursor-not-allowed":""}`,children:[a.jsx(pt,{className:`h-4 w-4 mr-2 ${n?"animate-spin":""}`}),s(n?"about.checking":"about.checkForUpdates")]})]})]})})}):null},Ya=({open:e,onOpenChange:r})=>{const{i18n:t,t:s}=q();return e?a.jsx("div",{className:"fixed inset-0 bg-black/50 z-50 flex items-center justify-center p-4",children:a.jsx("div",{className:"bg-white dark:bg-gray-800 rounded-lg shadow-lg max-w-md w-full",children:a.jsxs("div",{className:"p-6 relative",children:[a.jsx("button",{onClick:()=>r(!1),className:"absolute top-4 right-4 text-gray-400 hover:text-gray-500 dark:text-gray-500 dark:hover:text-gray-400","aria-label":s("common.close"),children:a.jsx(Ae,{className:"h-5 w-5"})}),a.jsx("h3",{className:"text-lg font-medium text-gray-900 dark:text-gray-100 mb-4",children:s("sponsor.title")}),a.jsx("div",{className:"flex flex-col items-center justify-center py-4",children:t.language==="zh"?a.jsx("img",{src:"./assets/reward.png",alt:s("sponsor.rewardAlt"),className:"max-w-full h-auto",style:{maxHeight:"400px"}}):a.jsxs("div",{className:"text-center",children:[a.jsx("p",{className:"mb-4 text-gray-700 dark:text-gray-300",children:s("sponsor.supportMessage")}),a.jsx("a",{href:"https://ko-fi.com/samanhappy",target:"_blank",rel:"noopener noreferrer",className:"inline-flex items-center justify-center bg-[#13C3FF] text-white px-4 py-2 rounded-md hover:bg-[#00A5E5] transition-colors",children:s("sponsor.supportButton")})]})})]})})}):null},Qa=({open:e,onOpenChange:r})=>{const{t}=q();return e?a.jsx("div",{className:"fixed inset-0 bg-black/50 z-50 flex items-center justify-center p-4",children:a.jsx("div",{className:"bg-white dark:bg-gray-800 rounded-lg shadow-lg max-w-md w-full",children:a.jsxs("div",{className:"p-6 relative",children:[a.jsx("button",{onClick:()=>r(!1),className:"absolute top-4 right-4 text-gray-400 hover:text-gray-500 dark:text-gray-500 dark:hover:text-gray-400","aria-label":t("common.close"),children:a.jsx(Ae,{className:"h-5 w-5"})}),a.jsx("h3",{className:"text-lg font-medium text-gray-900 dark:text-gray-100 mb-4",children:t("wechat.title")}),a.jsxs("div",{className:"flex flex-col items-center justify-center py-4",children:[a.jsx("img",{src:"./assets/wexin.png",alt:t("wechat.qrCodeAlt"),className:"max-w-full h-auto",style:{maxHeight:"400px"}}),a.jsx("p",{className:"mt-4 text-center text-gray-700 dark:text-gray-300",children:t("wechat.scanMessage")})]})]})})}):null},Za=e=>{const{t:r}=q();return a.jsxs("svg",{role:"img",viewBox:"0 0 24 24",xmlns:"http://www.w3.org/2000/svg",width:"24",height:"24",fill:"currentColor",...e,children:[a.jsx("title",{children:r("common.wechat")}),a.jsx("path",{d:"M8.691 2.188C3.891 2.188 0 5.476 0 9.53c0 2.212 1.17 4.203 3.002 5.55a.59.59 0 0 1 .213.665l-.39 1.48c-.019.07-.048.141-.048.213 0 .163.13.295.29.295a.326.326 0 0 0 .167-.054l1.903-1.114a.864.864 0 0 1 .717-.098 10.16 10.16 0 0 0 2.837.403c.276 0 .543-.027.811-.05-.857-2.578.157-4.972 1.932-6.446 1.703-1.415 3.882-1.98 5.853-1.838-.576-3.583-4.196-6.348-8.596-6.348zM5.785 5.991c.642 0 1.162.529 1.162 1.18a1.17 1.17 0 0 1-1.162 1.178A1.17 1.17 0 0 1 4.623 7.17c0-.651.52-1.18 1.162-1.18zm5.813 0c.642 0 1.162.529 1.162 1.18a1.17 1.17 0 0 1-1.162 1.178 1.17 1.17 0 0 1-1.162-1.178c0-.651.52-1.18 1.162-1.18zm5.34 2.867c-1.797-.052-3.746.512-5.28 1.786-1.72 1.428-2.687 3.72-1.78 6.22.942 2.453 3.666 4.229 6.884 4.229.826 0 1.622-.12 2.361-.336a.722.722 0 0 1 .598.082l1.584.926a.272.272 0 0 0 .14.047c.134 0 .24-.111.24-.247 0-.06-.023-.12-.038-.177l-.327-1.233a.582.582 0 0 1-.023-.156.49.49 0 0 1 .201-.398C23.024 18.48 24 16.82 24 14.98c0-3.21-2.931-5.837-6.656-6.088V8.89c-.135-.01-.27-.027-.407-.03zm-2.53 3.274c.535 0 .969.44.969.982a.976.976 0 0 1-.969.983.976.976 0 0 1-.969-.983c0-.542.434-.982.97-.982zm4.844 0c.535 0 .969.44.969.982a.976.976 0 0 1-.969.983.976.976 0 0 1-.969-.983c0-.542.434-.982.969-.982z"})]})},Xa=e=>{const{t:r}=q();return a.jsxs("svg",{role:"img",viewBox:"0 0 24 24",xmlns:"http://www.w3.org/2000/svg",width:"24",height:"24",fill:"currentColor",...e,children:[a.jsx("title",{children:r("common.discord")}),a.jsx("path",{d:"M20.317 4.3698a19.7913 19.7913 0 00-4.8851-1.5152.0741.0741 0 00-.0785.0371c-.211.3753-.4447.8648-.6083 1.2495-1.8447-.2762-3.68-.2762-5.4868 0-.1636-.3933-.4058-.8742-.6177-1.2495a.077.077 0 00-.0785-.037 19.7363 19.7363 0 00-4.8852 1.515.0699.0699 0 00-.0321.0277C.5334 9.0458-.319 13.5799.0992 18.0578a.0824.0824 0 00.0312.0561c2.0528 1.5076 4.0413 2.4228 5.9929 3.0294a.0777.0777 0 00.0842-.0276c.4616-.6304.8731-1.2952 1.226-1.9942a.076.076 0 00-.0416-.1057c-.6528-.2476-1.2743-.5495-1.8722-.8923a.077.077 0 01-.0076-.1277c.1258-.0943.2517-.1923.3718-.2914a.0743.0743 0 01.0776-.0105c3.9278 1.7933 8.18 1.7933 12.0614 0a.0739.0739 0 01.0785.0095c.1202.099.246.1981.3728.2924a.077.077 0 01-.0066.1276 12.2986 12.2986 0 01-1.873.8914.0766.0766 0 00-.0407.1067c.3604.698.7719 1.3628 1.225 1.9932a.076.076 0 00.0842.0286c1.961-.6067 3.9495-1.5219 6.0023-3.0294a.077.077 0 00.0313-.0552c.5004-5.177-.8382-9.6739-3.5485-13.6604a.061.061 0 00-.0312-.0286zM8.02 15.3312c-1.1825 0-2.1569-1.0857-2.1569-2.419 0-1.3332.9555-2.4189 2.157-2.4189 1.2108 0 2.1757 1.0952 2.1568 2.419 0 1.3332-.9555 2.4189-2.1569 2.4189zm7.9748 0c-1.1825 0-2.1569-1.0857-2.1569-2.419 0-1.3332.9554-2.4189 2.1569-2.4189 1.2108 0 2.1757 1.0952 2.1568 2.419 0 1.3332-.946 2.4189-2.1568 2.4189Z"})]})},es=e=>{const{t:r}=q();return a.jsxs("svg",{role:"img",viewBox:"0 0 24 24",xmlns:"http://www.w3.org/2000/svg",width:"24",height:"24",fill:"currentColor",...e,children:[a.jsx("title",{children:r("sponsor.label")}),a.jsx("path",{d:"M17.625 1.499c-2.32 0-4.354 1.203-5.625 3.03-1.271-1.827-3.305-3.03-5.625-3.03C3.129 1.499 0 4.253 0 8.249c0 4.275 3.068 7.847 5.828 10.227a33.14 33.14 0 0 0 5.616 3.876l.028.017.008.003-.001.003c.163.085.342.126.521.125.179.001.358-.041.521-.125l-.001-.003.008-.003.028-.017a33.14 33.14 0 0 0 5.616-3.876C20.932 16.096 24 12.524 24 8.249c0-3.996-3.129-6.75-6.375-6.75zm-.919 15.275a30.766 30.766 0 0 1-4.703 3.316l-.004-.002-.004.002a30.955 30.955 0 0 1-4.703-3.316c-2.677-2.307-5.047-5.298-5.047-8.523 0-2.754 2.121-4.5 4.125-4.5 2.06 0 3.914 1.479 4.544 3.684.143.495.596.797 1.086.796.49.001.943-.302 1.085-.796.63-2.205 2.484-3.684 4.544-3.684 2.004 0 4.125 1.746 4.125 4.5 0 3.225-2.37 6.216-5.048 8.523z"})]})},rs=({collapsed:e,version:r})=>{var D;const{t,i18n:s}=q(),o=rt(),{auth:l,logout:i}=fe(),[c,n]=u.useState(!1),[v,p]=u.useState(!1),[m,y]=u.useState(!1),[O,C]=u.useState(!1),[I,L]=u.useState(!1),R=u.useRef(null);u.useEffect(()=>{(async()=>{try{const b=await _r();b&&p(Jr(r,b)>0)}catch(b){console.error("Error checking for new version:",b)}})()},[r]),u.useEffect(()=>{const P=b=>{R.current&&!R.current.contains(b.target)&&n(!1)};return document.addEventListener("mousedown",P),()=>{document.removeEventListener("mousedown",P)}},[]);const z=()=>{o("/settings"),n(!1)},k=()=>{i(),o("/login")},F=()=>{y(!0),n(!1)},B=()=>{C(!0),n(!1)},U=()=>{L(!0),n(!1)};return a.jsxs("div",{ref:R,className:"relative",children:[a.jsxs("button",{onClick:()=>n(!c),className:`flex ${e?"justify-center":"items-center"} w-full p-2 hover:bg-gray-100 dark:hover:bg-gray-700 transition-colors rounded-md ${c?"bg-gray-100 dark:bg-gray-700":""}`,children:[a.jsxs("div",{className:"flex-shrink-0 relative",children:[a.jsx("div",{className:"w-5 h-5 flex items-center justify-center rounded-full border border-gray-300 dark:border-gray-600 bg-gray-50 dark:bg-gray-700",children:a.jsx(gt,{className:"h-4 w-4 text-gray-700 dark:text-gray-300"})}),v&&a.jsx("span",{className:"absolute -top-1 -right-1 block w-2 h-2 bg-red-500 rounded-full"})]}),!e&&a.jsx("div",{className:"ml-3 flex flex-col items-start",children:a.jsx("span",{className:"text-sm font-medium text-gray-700 dark:text-gray-300",children:((D=l.user)==null?void 0:D.username)||t("auth.user")})})]}),c&&a.jsxs("div",{className:"absolute top-0 transform -translate-y-full left-0 w-full min-w-max bg-white border border-gray-200 dark:border-gray-700 dark:bg-gray-800 z-50",children:[a.jsxs("button",{onClick:B,className:"flex items-center w-full px-4 py-2 text-left text-sm text-gray-700 dark:text-gray-300 hover:bg-gray-100 dark:bg-gray-800 dark:hover:bg-gray-700",children:[a.jsx(es,{className:"h-4 w-4 mr-2"}),t("sponsor.label")]}),s.language==="zh"?a.jsxs("button",{onClick:U,className:"flex items-center w-full px-4 py-2 text-left text-sm text-gray-700 dark:text-gray-300 hover:bg-gray-100 dark:bg-gray-800 dark:hover:bg-gray-700",children:[a.jsx(Za,{className:"h-4 w-4 mr-2"}),t("wechat.label")]}):a.jsxs("a",{href:"https://discord.gg/qMKNsn5Q",target:"_blank",rel:"noopener noreferrer",className:"flex items-center w-full px-4 py-2 text-left text-sm text-gray-700 dark:text-gray-300 hover:bg-gray-100 dark:bg-gray-800 dark:hover:bg-gray-700",children:[a.jsx(Xa,{className:"h-4 w-4 mr-2"}),t("discord.label")]}),a.jsxs("button",{onClick:z,className:"flex items-center w-full px-4 py-2 text-left text-sm text-gray-700 dark:text-gray-300 hover:bg-gray-100 dark:bg-gray-800 dark:hover:bg-gray-700",children:[a.jsx(Ar,{className:"h-4 w-4 mr-2"}),t("nav.settings")]}),a.jsxs("button",{onClick:F,className:"flex items-center w-full px-4 py-2 text-left text-sm text-gray-700 dark:text-gray-300 hover:bg-gray-100 dark:bg-gray-800 dark:hover:bg-gray-700 relative",children:[a.jsx(ht,{className:"h-4 w-4 mr-2"}),t("about.title"),v&&a.jsx("span",{className:"absolute top-2 right-4 block w-2 h-2 bg-red-500 rounded-full"})]}),a.jsx("div",{className:"border-t border-gray-200 dark:border-gray-600"}),a.jsxs("button",{onClick:k,className:"flex items-center w-full px-4 py-2 text-left text-sm text-gray-700 dark:text-gray-300 hover:bg-gray-100 dark:bg-gray-800 dark:hover:bg-gray-700",children:[a.jsx(ft,{className:"h-4 w-4 mr-2"}),t("app.logout")]})]}),a.jsx(Wa,{isOpen:m,onClose:()=>y(!1),version:r}),a.jsx(Ya,{open:O,onOpenChange:C}),a.jsx(Qa,{open:I,onOpenChange:L})]})},ts=async()=>{var e;try{const r=await V("/activities/available");return((e=r==null?void 0:r.data)==null?void 0:e.available)||!1}catch(r){return console.error("Error checking activity availability:",r),!1}},as=(e,r,t)=>{const s=new URLSearchParams;return s.append("page",e.toString()),s.append("limit",r.toString()),t!=null&&t.server&&s.append("server",t.server),t!=null&&t.tool&&s.append("tool",t.tool),t!=null&&t.status&&s.append("status",t.status),t!=null&&t.group&&s.append("group",t.group),t!=null&&t.keyId&&s.append("keyId",t.keyId),t!=null&&t.keyName&&s.append("keyName",t.keyName),t!=null&&t.startDate&&s.append("startDate",t.startDate),t!=null&&t.endDate&&s.append("endDate",t.endDate),s.toString()},pi=async(e,r,t)=>{const s=as(e,r,t);return await V(`/activities?${s}`)},gi=async e=>await V(`/activities/${e}`),hi=async e=>{const r=new URLSearchParams;e!=null&&e.server&&r.append("server",e.server),e!=null&&e.tool&&r.append("tool",e.tool),e!=null&&e.status&&r.append("status",e.status),e!=null&&e.group&&r.append("group",e.group),e!=null&&e.keyId&&r.append("keyId",e.keyId),e!=null&&e.keyName&&r.append("keyName",e.keyName),e!=null&&e.startDate&&r.append("startDate",e.startDate),e!=null&&e.endDate&&r.append("endDate",e.endDate);const t=r.toString();return await V(`/activities/stats${t?`?${t}`:""}`)},fi=async()=>await V("/activities/filters"),vi=async(e=30)=>await he(`/activities/cleanup?daysOld=${e}`),ss=({collapsed:e})=>{var y,O;const{t:r}=q(),{auth:t}=fe(),{allServers:s}=Da(),{groups:o}=$a(),[l,i]=u.useState(!1),c="1.0.1";u.useEffect(()=>{ts().then(i).catch(()=>i(!1))},[]);const n=((y=t.user)==null?void 0:y.isAdmin)&&$r("x"),v=[{path:"/",label:r("nav.dashboard"),icon:a.jsx(vt,{className:"h-4 w-4"}),end:!0},{path:"/servers",label:r("nav.servers"),icon:a.jsx(yt,{className:"h-4 w-4"}),badge:s.length||void 0},{path:"/groups",label:r("nav.groups"),icon:a.jsx(bt,{className:"h-4 w-4"}),badge:o.length||void 0},{path:"/prompts",label:r("nav.prompts"),icon:a.jsx(kt,{className:"h-4 w-4"})},{path:"/resources",label:r("nav.resources"),icon:a.jsx(St,{className:"h-4 w-4"})},{path:"/market",label:r("nav.market"),icon:a.jsx(At,{className:"h-4 w-4"})}],p=[...n?[{path:"/users",label:r("nav.users"),icon:a.jsx(Pt,{className:"h-4 w-4"})}]:[],...l&&((O=t.user)!=null&&O.isAdmin)?[{path:"/activity",label:r("nav.activity"),icon:a.jsx(wt,{className:"h-4 w-4"})}]:[],{path:"/logs",label:r("nav.logs"),icon:a.jsx(xt,{className:"h-4 w-4"})},{path:"/settings",label:r("nav.settings"),icon:a.jsx(Ar,{className:"h-4 w-4"})}],m=C=>a.jsx(tt,{to:C.path,end:C.end,className:({isActive:I})=>["group flex items-center gap-2.5 rounded-md text-[13.5px] transition-colors",e?"justify-center px-2 py-2":"px-2.5 py-1.5",I?"bg-[var(--hub-surface)] text-[var(--hub-ink)] ring-1 ring-inset ring-[var(--hub-line)]":"text-[var(--hub-ink-2)] hover:bg-[var(--hub-surface-hover)] hover:text-[var(--hub-ink)]"].join(" "),children:({isActive:I})=>a.jsxs(a.Fragment,{children:[a.jsx("span",{className:I?"text-[var(--hub-ink)] flex-shrink-0":"text-[var(--hub-ink-3)] group-hover:text-[var(--hub-ink-2)] flex-shrink-0",children:C.icon}),!e&&a.jsxs(a.Fragment,{children:[a.jsx("span",{className:"truncate",children:C.label}),C.badge!=null&&a.jsx("span",{className:"ml-auto hub-mono hub-num text-[11px] text-[var(--hub-ink-3)]",children:C.badge})]})]})},C.path);return a.jsxs("aside",{className:"flex flex-col h-full relative shrink-0 transition-[width] duration-200 ease-out bg-[var(--hub-bg-2)] border-r border-[var(--hub-line)] "+(e?"w-14":"w-[232px]"),children:[a.jsxs("div",{className:"flex items-center gap-2.5 "+(e?"px-2 py-3 justify-center":"px-4 py-3"),children:[a.jsxs("div",{className:"relative grid h-7 w-7 place-items-center rounded-md text-white hub-mono text-[12px] font-semibold",style:{background:"linear-gradient(135deg, var(--hub-accent), oklch(0.62 0.18 285))",boxShadow:"inset 0 1px 0 rgba(255,255,255,0.14)"},children:[a.jsx("span",{children:"M"}),a.jsx("span",{className:"absolute -right-0.5 -bottom-0.5 w-[6px] h-[6px] rounded-full",style:{background:"var(--hub-ok)",boxShadow:"0 0 0 2px oklch(0.66 0.15 145 / 0.18)"}})]}),!e&&a.jsxs("div",{className:"flex items-baseline gap-1.5 min-w-0",children:[a.jsx("span",{className:"font-semibold tracking-tight text-[var(--hub-ink)] truncate",children:r("app.title")}),a.jsx("span",{className:"hub-mono text-[10.5px] text-[var(--hub-ink-3)] flex-shrink-0",children:`v${c}`})]})]}),a.jsxs("div",{className:"flex-1 overflow-y-auto pb-2",children:[!e&&a.jsx("div",{className:"hub-sect px-3 pt-2 pb-1.5",children:r("nav.workspace")}),a.jsx("nav",{className:"flex flex-col gap-px "+(e?"px-1.5":"px-2"),children:v.map(m)}),!e&&a.jsx("div",{className:"hub-sect px-3 pt-3 pb-1.5",children:r("nav.system")}),a.jsx("nav",{className:"flex flex-col gap-px "+(e?"px-1.5 mt-1":"px-2"),children:p.map(m)})]}),a.jsx("div",{className:"p-2.5 border-t border-[var(--hub-line)]",children:a.jsx(rs,{collapsed:e,version:c})})]})},os=({children:e})=>a.jsx("main",{className:"flex-1 overflow-auto",style:{background:"var(--hub-bg)"},children:a.jsx("div",{className:"mx-auto w-full max-w-[1680px] px-6 pt-6 pb-16 lg:px-8 xl:px-10",children:e})}),ns=()=>a.jsx("div",{className:"flex h-full min-h-[240px] items-center justify-center text-sm",style:{color:"var(--hub-ink-3)"},children:"Loading..."}),is=()=>{const[e,r]=Ne.useState(!1),t=()=>{r(!e)};return a.jsx(qa,{children:a.jsxs("div",{className:"flex h-screen",style:{background:"var(--hub-bg)",color:"var(--hub-ink)"},children:[a.jsx(ss,{collapsed:e}),a.jsxs("div",{className:"flex flex-1 flex-col min-w-0 min-h-0",children:[a.jsx(Va,{onToggleSidebar:t}),a.jsx(os,{children:a.jsx(u.Suspense,{fallback:a.jsx(ns,{}),children:a.jsx(Sr,{})})})]})]})})},ls=({redirectPath:e="/login"})=>{const{t:r}=q(),{auth:t}=fe();return t.loading?a.jsx("div",{className:"flex items-center justify-center h-screen",children:r("app.loading")}):t.isAuthenticated?a.jsx(Sr,{}):a.jsx(De,{to:e,replace:!0})},fr="[EMBED_SYNC_ERROR]",us=8e3,vr=3e4,cs=()=>{const{showToast:e}=Ur(),r=u.useRef(new Map);return u.useEffect(()=>{const t=c=>{const n=Date.now();r.current.forEach((p,m)=>{n-p>=vr&&r.current.delete(m)});const v=r.current.get(c);return v&&n-v<vr?!0:(r.current.set(c,n),!1)},s=c=>{const n=c.match(/server\s+"([^"]+)"/i);return(n==null?void 0:n[1])||null},o=(c,n)=>{t(c)||e(n,"error",us)},l=c=>{const n=c.replace(fr,"").trim(),v=s(n);if(n.includes("Full embeddings resync failed")){o("embedding-resync-failed","Embedding resynchronization failed. Check smart routing logs and provider limits.");return}if(v){o(`embedding-sync-error:${v}`,`Embedding synchronization failed for server "${v}". Check logs for details.`);return}o(`embedding-sync-error:${n}`,n||"Embedding synchronization failed. Check smart routing logs and provider rate limits.")},i=c=>{var n,v,p;try{const m=JSON.parse(c.data);if((m==null?void 0:m.type)==="embedding-sync-progress"){const O=typeof((n=m.progress)==null?void 0:n.serverName)=="string"?m.progress.serverName:"";(typeof((v=m.progress)==null?void 0:v.status)=="string"?m.progress.status:"")==="error"&&O&&o(`embedding-sync-error:${O}`,`Embedding synchronization failed for server "${O}". Check logs for details.`);return}if((m==null?void 0:m.type)!=="log")return;const y=String(((p=m==null?void 0:m.log)==null?void 0:p.message)||"");if(!y.includes(fr))return;l(y)}catch{}};return Je.subscribe(i)},[e]),null},ds=u.lazy(()=>Q(()=>import("./LoginPage-DCjqYw_8.js"),__vite__mapDeps([0,1,2,3]),import.meta.url)),ms=u.lazy(()=>Q(()=>import("./Dashboard-BUCJcvk-.js"),__vite__mapDeps([4,1,5,6,7,2,3,8]),import.meta.url)),ps=u.lazy(()=>Q(()=>import("./ServersPage-hgCbCglG.js"),__vite__mapDeps([9,1,8,2,6,10,3,11,12,13,14,5]),import.meta.url)),gs=u.lazy(()=>Q(()=>import("./GroupsPage-DfLlww4U.js"),__vite__mapDeps([15,1,5,6,2,3,11]),import.meta.url)),hs=u.lazy(()=>Q(()=>import("./UsersPage-C33b7LCM.js"),__vite__mapDeps([16,1,2,11,8,3]),import.meta.url)),fs=u.lazy(()=>Q(()=>import("./SettingsPage-BzNX8mXv.js"),__vite__mapDeps([17,1,2,10,3,6,7]),import.meta.url)),yr=u.lazy(()=>Q(()=>import("./MarketPage-C2Rh4WJB.js"),__vite__mapDeps([18,1,2,3,12,6,14]),import.meta.url)),vs=u.lazy(()=>Q(()=>import("./LogsPage-CTa8kuDf.js"),__vite__mapDeps([19,1,2,3]),import.meta.url)),ys=u.lazy(()=>Q(()=>import("./ActivityPage-DwzGiMh_.js"),__vite__mapDeps([20,1,14,2,3]),import.meta.url)),bs=u.lazy(()=>Q(()=>import("./PromptsPage-Dh3qjX3x.js"),__vite__mapDeps([21,1,2,13,8,3]),import.meta.url)),ks=u.lazy(()=>Q(()=>import("./ResourcesPage-Bc5ZpCIh.js"),__vite__mapDeps([22,1,2,13,8,3]),import.meta.url)),Ss=()=>{const{serverName:e}=kr();return a.jsx(De,{to:`/market/${e}?tab=cloud`,replace:!0})},As=()=>a.jsx("div",{className:"flex min-h-screen items-center justify-center text-sm text-gray-500",children:"Loading..."});function br(){const e=Ie();return a.jsx(Ea,{children:a.jsx(Bt,{children:a.jsx(Na,{children:a.jsx(Ca,{children:a.jsx(Ma,{children:a.jsxs(at,{basename:e,children:[a.jsx(cs,{}),a.jsxs(st,{children:[a.jsx(H,{path:"/login",element:a.jsx(u.Suspense,{fallback:a.jsx(As,{}),children:a.jsx(ds,{})})}),a.jsx(H,{element:a.jsx(ls,{}),children:a.jsxs(H,{element:a.jsx(is,{}),children:[a.jsx(H,{path:"/",element:a.jsx(ms,{})}),a.jsx(H,{path:"/servers",element:a.jsx(ps,{})}),a.jsx(H,{path:"/groups",element:a.jsx(gs,{})}),a.jsx(H,{path:"/prompts",element:a.jsx(bs,{})}),a.jsx(H,{path:"/resources",element:a.jsx(ks,{})}),a.jsx(H,{path:"/users",element:a.jsx(hs,{})}),a.jsx(H,{path:"/market",element:a.jsx(yr,{})}),a.jsx(H,{path:"/market/:serverName",element:a.jsx(yr,{})}),a.jsx(H,{path:"/cloud",element:a.jsx(De,{to:"/market?tab=cloud",replace:!0})}),a.jsx(H,{path:"/cloud/:serverName",element:a.jsx(Ss,{})}),a.jsx(H,{path:"/logs",element:a.jsx(vs,{})}),a.jsx(H,{path:"/activity",element:a.jsx(ys,{})}),a.jsx(H,{path:"/settings",element:a.jsx(fs,{})})]})}),a.jsx(H,{path:"*",element:a.jsx(De,{to:"/"})})]})]})})})})})})}const Ps={title:"MCPHub Dashboard",error:"Error",closeButton:"Close",noServers:"No MCP servers available",loading:"Loading...",logout:"Logout",profile:"Profile",changePassword:"Change Password",toggleSidebar:"Toggle Sidebar",welcomeUser:"Welcome, {{username}}",name:"MCPHub",embeddingSyncProgress:"Embeddings for {{serverName}}",embeddingSyncProgressAriaLabel:"Creating embeddings for {{serverName}}: {{current}} of {{total}} completed"},ws={title:"About",versionInfo:"MCPHub Version: {{version}}",newVersion:"New version available!",currentVersion:"Current version",newVersionAvailable:"New version {{version}} is available",viewOnGitHub:"View on GitHub",checkForUpdates:"Check for Updates",checking:"Checking for updates..."},xs={viewProfile:"View profile",userCenter:"User Center"},Cs={label:"Sponsor",title:"Support the Project",rewardAlt:"Reward QR Code",supportMessage:"Support the development of MCPHub by buying me a coffee!",supportButton:"Support on Ko-fi"},Rs={label:"WeChat",title:"Connect via WeChat",qrCodeAlt:"WeChat QR Code",scanMessage:"Scan this QR code to connect with us on WeChat"},Es={label:"Discord",title:"Join our Discord server",community:"Join our growing community on Discord for support, discussions, and updates!"},Ts={title:"Theme",light:"Light",dark:"Dark",system:"System"},Ns={login:"Login",loginTitle:"Login to MCPHub",slogan:"The Unified Hub for MCP Servers",subtitle:"Centralized management platform for Model Context Protocol servers. Organize, monitor, and scale multiple MCP servers with flexible routing strategies.",username:"Username",password:"Password",loggingIn:"Logging in...",orContinue:"Or continue with",loginWithGoogle:"Continue with Google",loginWithGithub:"Continue with GitHub",socialLoginFailed:"Social login failed. Please try again.",emptyFields:"Username and password cannot be empty",loginFailed:"Login failed, please check your username and password",loginError:"An error occurred during login",serverUnavailable:"Unable to connect to the server. Please check your network connection or try again later",currentPassword:"Current Password",newPassword:"New Password",confirmPassword:"Confirm Password",passwordsNotMatch:"New password and confirmation do not match",changePasswordSuccess:"Password changed successfully",changePasswordError:"Failed to change password",changePassword:"Change Password",passwordChanged:"Password changed successfully",passwordChangeError:"Failed to change password",defaultPasswordWarning:"Default Password Security Warning",defaultPasswordMessage:"You are using the default password (admin123), which poses a security risk. Please change your password immediately to protect your account.",goToSettings:"Go to Settings",passwordStrengthError:"Password does not meet security requirements",passwordMinLength:"Password must be at least 8 characters long",passwordRequireLetter:"Password must contain at least one letter",passwordRequireNumber:"Password must contain at least one number",passwordRequireSpecial:"Password must contain at least one special character",passwordStrengthHint:"Password must be at least 8 characters and contain letters, numbers, and special characters"},Ds={addServer:"Add Server",add:"Add",edit:"Edit",copy:"Copy",delete:"Delete",confirmDelete:"Are you sure you want to delete this server?",deleteWarning:"Deleting server '{{name}}' will remove it and all its data. This action cannot be undone.",status:"Status",tools:"Tools",prompts:"Prompts",name:"Server Name",description:"Server Note",descriptionPlaceholder:"Optional note to describe this server",url:"Server URL",apiKey:"API Key",save:"Save",cancel:"Cancel",invalidConfig:"Could not find configuration data for {{serverName}}",addError:"Failed to add server",editError:"Failed to edit server {{serverName}}",deleteError:"Failed to delete server {{serverName}}",updateError:"Failed to update server",editTitle:"Edit Server: {{serverName}}",type:"Server Type",typeStdio:"STDIO",typeSse:"SSE",typeStreamableHttp:"Streamable HTTP",typeOpenapi:"OpenAPI",command:"Command",arguments:"Arguments",envVars:"Environment Variables",headers:"HTTP Headers",key:"key",value:"value",enabled:"Enabled",enable:"Enable",disable:"Disable",reload:"Reload",reloadSuccess:"Server reloaded successfully",reloadError:"Failed to reload server {{serverName}}",requestOptions:"Connection Configuration",timeout:"Request Timeout",timeoutDescription:"Timeout for requests to the MCP server (ms)",maxTotalTimeout:"Maximum Total Timeout",maxTotalTimeoutDescription:"Maximum total timeout for requests sent to the MCP server (ms) (Use with progress notifications)",resetTimeoutOnProgress:"Reset Timeout on Progress",resetTimeoutOnProgressDescription:"Reset timeout on progress notifications (enabled by default)",keepAlive:"Keep-Alive Configuration",enableKeepAlive:"Enable Keep-Alive",keepAliveDescription:"Send periodic ping requests to maintain the connection. Useful for long-running connections that may timeout.",keepAliveInterval:"Interval (ms)",keepAliveIntervalDescription:"Time between keep-alive pings in milliseconds (default: 60000ms = 1 minute)",remove:"Remove",toggleError:"Failed to toggle server {{serverName}}",alreadyExists:"Server {{serverName}} already exists",invalidData:"Invalid server data provided",notFound:"Server {{serverName}} not found",namePlaceholder:"Enter server name",urlPlaceholder:"Enter server URL",commandPlaceholder:"Enter command",argumentsPlaceholder:"Enter arguments",errorDetails:"Error Details",viewErrorDetails:"View error details",copyConfig:"Copy Configuration",confirmVariables:"Confirm Variable Configuration",variablesDetected:"Variables detected in configuration. Please confirm these variables are properly configured:",detectedVariables:"Detected Variables",confirmVariablesMessage:"Please ensure these variables are properly defined in your runtime environment. Continue adding server?",confirmAndAdd:"Confirm and Add",openapi:{inputMode:"Input Mode",inputModeUrl:"Specification URL",inputModeSchema:"JSON Schema",specUrl:"OpenAPI Specification URL",schema:"OpenAPI JSON Schema",schemaHelp:"Paste your complete OpenAPI JSON schema here",security:"Security Type",securityNone:"None",securityApiKey:"API Key",securityHttp:"HTTP Authentication",securityOAuth2:"OAuth 2.0",securityOpenIdConnect:"OpenID Connect",apiKeyConfig:"API Key Configuration",apiKeyName:"Header/Parameter Name",apiKeyIn:"Location",apiKeyValue:"API Key Value",httpAuthConfig:"HTTP Authentication Configuration",httpScheme:"Authentication Scheme",httpCredentials:"Credentials",httpSchemeBasic:"Basic",httpSchemeBearer:"Bearer",httpSchemeDigest:"Digest",oauth2Config:"OAuth 2.0 Configuration",oauth2Token:"Access Token",openIdConnectConfig:"OpenID Connect Configuration",openIdConnectUrl:"Discovery URL",openIdConnectToken:"ID Token",apiKeyInHeader:"Header",apiKeyInQuery:"Query",apiKeyInCookie:"Cookie",passthroughHeaders:"Passthrough Headers",passthroughHeadersHelp:"Comma-separated list of header names to pass through from incoming MCP requests to upstream server requests (e.g., Authorization, X-API-Key)"},oauth:{sectionTitle:"OAuth Configuration",sectionDescription:"Configure client credentials for OAuth-protected servers (optional).",clientId:"Client ID",clientSecret:"Client Secret",authorizationEndpoint:"Authorization Endpoint",tokenEndpoint:"Token Endpoint",scopes:"Scopes",scopesPlaceholder:"scope1 scope2",resource:"Resource / Audience",accessToken:"Access Token",refreshToken:"Refresh Token"}},Ms={online:"Online",offline:"Offline",connecting:"Connecting",oauthRequired:"OAuth Required",clickToAuthorize:"Click to authorize with OAuth",oauthWindowOpened:"OAuth authorization window opened. Please complete the authorization."},Is={general:"Something went wrong",network:"Network connection error. Please check your internet connection",serverConnection:"Unable to connect to the server. Please check if the server is running",serverAdd:"Failed to add server. Please check the server status",serverUpdate:"Failed to edit server {{serverName}}. Please check the server status",serverFetch:"Failed to retrieve server data. Please try again later",initialStartup:"The server might be starting up. Please wait a moment as this process can take some time on first launch...",serverInstall:"Failed to install server",failedToFetchSettings:"Failed to fetch settings",failedToUpdateRouteConfig:"Failed to update route configuration",failedToUpdateSmartRoutingConfig:"Failed to update smart routing configuration"},zs={processing:"Processing...",save:"Save",cancel:"Cancel",back:"Back",refresh:"Refresh",search:"Search",clear:"Clear",view:"View",create:"Create",creating:"Creating...",update:"Update",updating:"Updating...",submitting:"Submitting...",delete:"Delete",remove:"Remove",copy:"Copy",copyId:"Copy ID",copyUrl:"Copy URL",copyJson:"Copy JSON",copySuccess:"Copied to clipboard",copyFailed:"Copy failed",copied:"Copied",close:"Close",confirm:"Confirm",language:"Language",true:"True",false:"False",dismiss:"Dismiss",github:"GitHub",wechat:"WeChat",discord:"Discord",required:"Required",itemsPerPage:"Items per page",showing:"Showing {{start}}-{{end}} of {{total}}",previous:"Previous",next:"Next",secret:"Secret",default:"Default",value:"Value",type:"Type",repeated:"Repeated",valueHint:"Value Hint",choices:"Choices",actions:"Actions",saving:"Saving...",active:"Active",inactive:"Inactive",viewAll:"View all",docs:"Docs",all:"All"},Os={rowsPerPage:"Rows per page",showing:"Showing {{from}}-{{to}} of {{total}}"},Ls={dashboard:"Dashboard",servers:"Servers",groups:"Groups",prompts:"Prompts",resources:"Resources",users:"Users",settings:"Settings",changePassword:"Change Password",market:"Market",cloud:"Cloud Market",logs:"Logs",activity:"Activity",workspace:"Workspace",system:"System"},Fs={dashboard:{title:"Dashboard",totalServers:"Total",onlineServers:"Online",disabledServers:"Disabled",offlineServers:"Offline",connectingServers:"Connecting",recentServers:"Recent Servers",endpoints:"MCP Endpoints",endpointsHint:"Use these URLs in Claude Desktop, Cursor or any MCP client"},servers:{title:"Server Management"},groups:{title:"Group Management"},prompts:{title:"Built-in Prompts"},resources:{title:"Built-in Resources"},users:{title:"User Management"},settings:{title:"Settings",language:"Language",account:"Account Settings",password:"Change Password",appearance:"Appearance",routeConfig:"Security",installConfig:"Installation",smartRouting:"Smart Routing",oauthServer:"OAuth Server"},market:{title:"Market Hub - Local and Cloud Markets"},logs:{title:"System Logs"}},js={filters:"Filters",search:"Search logs...",autoScroll:"Auto-scroll",clearLogs:"Clear logs",loading:"Loading logs...",noLogs:"No logs available.",noMatch:"No logs match the current filters.",mainProcess:"Main Process",childProcess:"Child Process",main:"Main",child:"Child"},Us={add:"Add",addNew:"Add New Group",edit:"Edit Group",delete:"Delete",confirmDelete:"Are you sure you want to delete this group?",deleteWarning:"Deleting group '{{name}}' will remove it and all its server associations. This action cannot be undone.",name:"Group Name",namePlaceholder:"Enter group name",nameRequired:"Group name is required",description:"Description",descriptionPlaceholder:"Enter group description (optional)",createError:"Failed to create group",updateError:"Failed to update group",deleteError:"Failed to delete group",serverAddError:"Failed to add server to group",serverRemoveError:"Failed to remove server from group",addServer:"Add Server to Group",selectServer:"Select a server to add",servers:"Servers in Group",remove:"Remove",noGroups:"No groups available. Create a new group to get started.",noServers:"No servers in this group.",noServerOptions:"No servers available",serverCount:"{{count}} Servers",toolSelection:"Tool Selection",promptSelection:"Prompt Selection",resourceSelection:"Resource Selection",toolsSelected:"Selected",promptsSelected:"Selected",resourcesSelected:"Selected",allTools:"All",allPrompts:"All prompts",allResources:"All resources",selectedTools:"Selected tools",selectedPrompts:"Selected prompts",selectedResources:"Selected resources",selectAll:"Select All",selectNone:"Select None",configureTools:"Configure Tools",configureCapabilities:"Configure Tools, Prompts, and Resources",previewPrompts:"[prompts: {{items}}]",previewResources:"[resources: {{items}}]",previewAllTools:"(all tools)",previewAllPrompts:"(all prompts)",previewAllResources:"(all resources)"},Gs={title:"Local Installation",official:"Official",by:"By",unknown:"Unknown",tools:"tools",search:"Search",searchPlaceholder:"Search for servers by name, category, or tags",clearFilters:"Clear",clearCategoryFilter:"",clearTagFilter:"",categories:"Categories",tags:"Tags",showTags:"Show tags",hideTags:"Hide tags",moreTags:"",noServers:"No servers found matching your search",backToList:"Back to list",install:"Install",installing:"Installing...",installed:"Installed",installServer:"Install Server: {{name}}",installSuccess:"Server {{serverName}} installed successfully",author:"Author",license:"License",repository:"Repository",examples:"Examples",arguments:"Arguments",argumentName:"Name",description:"Description",required:"Required",example:"Example",viewSchema:"View schema",fetchError:"Error fetching market servers",serverNotFound:"Server not found",searchError:"Error searching servers",filterError:"Error filtering servers by category",tagFilterError:"Error filtering servers by tag",noInstallationMethod:"No installation method available for this server",showing:"Showing {{from}}-{{to}} of {{total}} servers",perPage:"Per page",confirmVariablesMessage:"Please ensure these variables are properly defined in your runtime environment. Continue installing server?",confirmAndInstall:"Confirm and Install"},Ks={authorizeTitle:"Authorize Application",authorizeSubtitle:"Allow this application to access your MCPHub account.",buttons:{approve:"Allow access",deny:"Deny",approveSubtitle:"Recommended if you trust this application.",denySubtitle:"You can always grant access later."}},qs={title:"Cloud Support",subtitle:"Powered by MCPRouter",by:"By",server:"Server",config:"Config",created:"Created",updated:"Updated",available:"Available",description:"Description",details:"Details",tools:"Tools",tool:"tool",toolsAvailable:"{{count}} tool available||{{count}} tools available",loadingTools:"Loading tools...",noTools:"No tools available for this server",noDescription:"No description available",viewDetails:"View Details",parameters:"Parameters",result:"Result",error:"Error",callTool:"Call",calling:"Calling...",toolCallSuccess:"Tool {{toolName}} executed successfully",toolCallError:"Failed to call tool {{toolName}}: {{error}}",viewSchema:"View Schema",backToList:"Back to Cloud Market",search:"Search",searchPlaceholder:"Search cloud servers by name, title, or author",clearFilters:"Clear Filters",clearCategoryFilter:"Clear",clearTagFilter:"Clear",categories:"Categories",tags:"Tags",noCategories:"No categories found",noTags:"No tags found",noServers:"No cloud servers found",fetchError:"Error fetching cloud servers",serverNotFound:"Cloud server not found",searchError:"Error searching cloud servers",filterError:"Error filtering cloud servers by category",tagFilterError:"Error filtering cloud servers by tag",showing:"Showing {{from}}-{{to}} of {{total}} cloud servers",perPage:"Per page",apiKeyNotConfigured:"MCPRouter API key not configured",apiKeyNotConfiguredDescription:"To use cloud servers, you need to configure your MCPRouter API key.",getApiKey:"Get API Key",configureInSettings:"Configure in Settings",installServer:"Install {{name}}",installSuccess:"Server {{name}} installed successfully",installError:"Failed to install server: {{error}}"},Bs={title:"Registry",official:"Official",latest:"Latest",description:"Description",website:"Website",repository:"Repository",packages:"Packages",package:"package",remotes:"Remotes",remote:"remote",published:"Published",updated:"Updated",install:"Install",installing:"Installing...",installed:"Installed",installServer:"Install {{name}}",installSuccess:"Server {{name}} installed successfully",installError:"Failed to install server: {{error}}",noDescription:"No description available",viewDetails:"View Details",backToList:"Back to Registry",search:"Search",searchPlaceholder:"Search registry servers by name",clearFilters:"Clear",noServers:"No registry servers found",fetchError:"Error fetching registry servers",serverNotFound:"Registry server not found",showing:"Showing {{from}}-{{to}} of {{total}} registry servers",perPage:"Per page",environmentVariables:"Environment Variables",packageArguments:"Package Arguments",runtimeArguments:"Runtime Arguments",headers:"Headers"},Hs={run:"Run",running:"Running...",runTool:"Run Tool",cancel:"Cancel",noDescription:"No description available",inputSchema:"Input Schema:",runToolWithName:"Run Tool: {{name}}",execution:"Tool Execution",successful:"Successful",failed:"Failed",result:"Result:",error:"Error",errorDetails:"Error Details:",noContent:"Tool executed successfully but returned no content.",unknownError:"Unknown error occurred",jsonResponse:"JSON Response:",toolResult:"Tool result",noParameters:"This tool does not require any parameters.",selectOption:"Select an option",enterValue:"Enter {{type}} value",enabled:"Enabled",enableSuccess:"Tool {{name}} enabled successfully",disableSuccess:"Tool {{name}} disabled successfully",toggleFailed:"Failed to toggle tool status",descriptionUpdateSuccess:"Tool description updated successfully",descriptionUpdateFailed:"Failed to update tool description",restoreDefault:"Restore default",restoreDefaultSuccess:"Tool description restored to default",restoreDefaultFailed:"Failed to restore the default tool description",parameters:"Tool Parameters",formMode:"Form Mode",jsonMode:"JSON Mode",jsonConfiguration:"JSON Configuration",invalidJsonFormat:"Invalid JSON format",fixJsonBeforeSwitching:"Please fix JSON format before switching to form mode",item:"Item {{index}}",addItem:"Add {{key}} item",enterKey:"Enter {{key}}"},Vs={run:"Get",running:"Getting...",result:"Prompt Result",error:"Prompt Error",execution:"Prompt Execution",successful:"Successful",failed:"Failed",errorDetails:"Error Details:",noContent:"Prompt executed successfully but returned no content.",unknownError:"Unknown error occurred",jsonResponse:"JSON Response:",description:"Description",messages:"Messages",noDescription:"No description available",runPromptWithName:"Get Prompt: {{name}}",descriptionUpdateSuccess:"Prompt description updated successfully",descriptionUpdateFailed:"Failed to update prompt description",restoreDefault:"Restore default",restoreDefaultSuccess:"Prompt description restored to default",restoreDefaultFailed:"Failed to restore the default prompt description"},$s=JSON.parse(`{"subtitle":"Configure system settings, authentication, routing, and MCP server integrations.","enableGlobalRoute":"Enable Global Route","enableGlobalRouteDescription":"Allow connections to /sse endpoint without specifying a group ID","enableGroupNameRoute":"Enable Group Name Route","enableGroupNameRouteDescription":"Allow connections to /sse endpoint using group names instead of just group IDs","enableBearerAuth":"Enable Bearer Authentication","enableBearerAuthDescription":"Require bearer token authentication for MCP endpoints (default on)","bearerAuthKey":"Bearer Authentication Key","bearerAuthKeyDescription":"The authentication key that will be required in the Bearer token","bearerAuthKeyPlaceholder":"Enter bearer authentication key","bearerAuthHeaderName":"Bearer Auth Header Name","bearerAuthHeaderNameDescription":"Header name used to receive MCP bearer credentials. Change this when upstream passthrough headers also use Authorization.","bearerAuthHeaderNamePlaceholder":"e.g. Authorization or X-MCP-Authorization","bearerKeysSectionTitle":"Keys","bearerKeysSectionDescription":"Manage multiple keys with different access scopes.","noBearerKeys":"No keys configured yet.","bearerKeyName":"Name","bearerKeyToken":"Token","bearerKeyEnabled":"Enabled","bearerKeyAccessType":"Access scope","bearerKeyAccessAll":"All","bearerKeyAccessGroups":"Groups","bearerKeyAccessServers":"Servers","bearerKeyAccessCustom":"Custom","bearerKeyAllowedGroups":"Allowed groups","bearerKeyAllowedServers":"Allowed servers","addBearerKey":"Add key","addBearerKeyButton":"Create","bearerKeyRequired":"Name and token are required","deleteBearerKeyConfirm":"Are you sure you want to delete this key?","generate":"Generate","selectGroups":"Select Groups","selectServers":"Select Servers","selectAtLeastOneGroup":"Please select at least one group","selectAtLeastOneServer":"Please select at least one server","skipAuth":"Skip Authentication","skipAuthDescription":"Allow dashboard access without login; unauthenticated users get guest admin access (does not affect MCP endpoint auth)","jsonBodyLimit":"JSON Body Size Limit","jsonBodyLimitDescription":"Express JSON request size limit. This affects large OpenAPI schema uploads as well.","jsonBodyLimitPlaceholder":"e.g. 1mb, 5mb, 1024kb","pythonIndexUrl":"Python Package Repository URL","pythonIndexUrlDescription":"Set UV_DEFAULT_INDEX environment variable for Python package installation","pythonIndexUrlPlaceholder":"e.g. https://pypi.org/simple","npmRegistry":"NPM Registry URL","npmRegistryDescription":"Set npm_config_registry environment variable for NPM package installation","npmRegistryPlaceholder":"e.g. https://registry.npmjs.org/","baseUrl":"Base URL","baseUrlDescription":"Base URL for MCP requests and OAuth callbacks","baseUrlPlaceholder":"e.g. http://localhost:3000","installConfig":"Installation","systemConfigUpdated":"System configuration updated successfully","enableSmartRouting":"Enable Smart Routing","enableSmartRoutingDescription":"Enable smart routing feature to search the most suitable tool based on input (using $smart group name)","dbUrl":"PostgreSQL URL (requires pgvector support)","dbUrlPlaceholder":"e.g. postgresql://user:password@localhost:5432/dbname","embeddingProvider":"Embedding Provider","openaiApiBaseUrl":"OpenAI-compatible Base URL","openaiApiBaseUrlPlaceholder":"https://api.openai.com/v1","openaiApiKey":"LLM Provider API Key","openaiApiKeyPlaceholder":"Enter LLM provider API key","openaiApiEmbeddingModel":"Embedding Model Name","openaiApiEmbeddingModelPlaceholder":"text-embedding-3-small","basePacingDelayMs":"Base Pacing Delay (ms)","basePacingDelayMsDescription":"Baseline delay between embedding API requests. Defaults to 0 — the system manages rate limits automatically: it respects Retry-After headers, falls back to a 63-second cooldown, and increases the pacing delay after any 403/429 response. Set a non-zero value only if your provider enforces a fixed minimum interval between requests.","basePacingDelayMsPlaceholder":"Empty = default 0 ms","basePacingDelayMsAuto":"Default ({{value}} ms): rate limiting is managed automatically.","basePacingDelayMsZero":"0 ms (default): rate limiting is managed automatically via adaptive throttling and retry logic.","basePacingDelayMsOverride":"Custom value: overrides the default baseline pacing delay.","embeddingEncodingFormat":"Embedding Encoding Format","embeddingEncodingFormatDescription":"Encoding format for embedding vectors. Auto will detect based on provider support.","embeddingEncodingFormatAuto":"Auto (Recommended)","azureOpenaiEndpoint":"Azure OpenAI Endpoint","azureOpenaiEndpointPlaceholder":"https://YOUR_RESOURCE_NAME.openai.azure.com","azureOpenaiApiKey":"Azure OpenAI API Key","azureOpenaiApiKeyPlaceholder":"Enter Azure OpenAI API key","azureOpenaiApiVersion":"Azure OpenAI API Version","azureOpenaiApiVersionPlaceholder":"2024-02-15-preview","azureOpenaiEmbeddingDeployment":"Azure OpenAI Embedding Deployment","azureOpenaiEmbeddingDeploymentPlaceholder":"text-embedding-3-small","azureOpenaiEmbeddingModel":"Azure Embedding Model Name","azureOpenaiEmbeddingModelDescription":"The actual OpenAI model name deployed in Azure (e.g. text-embedding-3-small). Used for accurate token counting before sending text to the API.","azureOpenaiEmbeddingModelPlaceholder":"text-embedding-3-small","progressiveDisclosure":"Progressive Disclosure","progressiveDisclosureDescription":"When enabled, search_tools returns only tool names and descriptions. Use describe_tool to get full parameter schema, reducing token usage.","embeddingMaxTokens":"Max Embedding Tokens","embeddingMaxTokensDescription":"Maximum tokens for text truncation before generating embeddings. Leave empty to use the model default automatically. A custom value always overrides the model default. Manually setting this value is especially useful when using local LLM providers to prevent truncation errors.","embeddingMaxTokensPlaceholder":"Empty = auto by model","embeddingMaxTokensAuto":"Auto: {{limit}} tokens (model default for {{model}})","embeddingMaxTokensOverride":"This value overrides the model default.","smartRoutingConfigUpdated":"Smart routing configuration updated successfully","smartRoutingRequiredFields":"Database URL is required to enable smart routing. An LLM Provider API Key is required for cloud-based providers (local LLMs usually don't require an API key, enter any value to pass the form validation)","smartRoutingValidationError":"Please fill in the required fields before enabling Smart Routing: {{fields}}","smartRoutingWorkflow":"Workflow","smartRoutingWorkflowDescription":"Prompts are vectorized; top-k similar tools are fetched from pgvector and exposed to the upstream LLM.","mcpRouterConfig":"Cloud Market","mcpRouterApiKey":"MCPRouter API Key","mcpRouterApiKeyDescription":"API key for accessing MCPRouter cloud market services","mcpRouterApiKeyPlaceholder":"Enter MCPRouter API key","mcpRouterReferer":"Referer","mcpRouterRefererDescription":"Referer header for MCPRouter API requests","mcpRouterRefererPlaceholder":"https://www.mcphub.app","mcpRouterTitle":"Title","mcpRouterTitleDescription":"Title header for MCPRouter API requests","mcpRouterTitlePlaceholder":"MCPHub","mcpRouterBaseUrl":"Base URL","mcpRouterBaseUrlDescription":"Base URL for MCPRouter API","mcpRouterBaseUrlPlaceholder":"https://api.mcprouter.to/v1","systemSettings":"System Settings","nameSeparatorLabel":"Name Separator","nameSeparatorDescription":"Character used to separate server name and tool/prompt name (default: -)","enableSessionRebuild":"Enable Server Session Rebuild","enableSessionRebuildDescription":"When enabled, applies the improved server session rebuild code for better session management experience","restartRequired":"Configuration saved. It is recommended to restart the application to ensure all services load the new settings correctly.","exportMcpSettings":"Export Settings","mcpSettingsJson":"MCP Settings JSON","mcpSettingsJsonDescription":"View, copy, or download your current mcp_settings.json configuration for backup or migration to other tools","copyToClipboard":"Copy to Clipboard","downloadJson":"Download JSON","exportSuccess":"Settings exported successfully","exportError":"Failed to fetch settings","enableOauthServer":"Enable OAuth Server","enableOauthServerDescription":"Allow MCPHub to issue OAuth tokens for external clients","requireClientSecret":"Require Client Secret","requireClientSecretDescription":"When enabled, confidential clients must present a client secret (disable for PKCE-only clients)","requireState":"Require State Parameter","requireStateDescription":"Reject authorization requests that omit the OAuth state parameter","accessTokenLifetime":"Access Token Lifetime (seconds)","accessTokenLifetimeDescription":"How long issued access tokens remain valid","accessTokenLifetimePlaceholder":"e.g. 3600","refreshTokenLifetime":"Refresh Token Lifetime (seconds)","refreshTokenLifetimeDescription":"How long refresh tokens remain valid","refreshTokenLifetimePlaceholder":"e.g. 1209600","authorizationCodeLifetime":"Authorization Code Lifetime (seconds)","authorizationCodeLifetimeDescription":"How long authorization codes remain valid before they can be exchanged","authorizationCodeLifetimePlaceholder":"e.g. 300","allowedScopes":"Allowed Scopes","allowedScopesDescription":"Comma-separated list of scopes users can approve during authorization","allowedScopesPlaceholder":"e.g. read, write","enableDynamicRegistration":"Enable Dynamic Client Registration","dynamicRegistrationDescription":"Allow RFC 7591 compliant clients to self-register using the public endpoint","dynamicRegistrationAllowedGrantTypes":"Allowed Grant Types","dynamicRegistrationAllowedGrantTypesDescription":"Comma-separated list of grants permitted for dynamically registered clients","dynamicRegistrationAllowedGrantTypesPlaceholder":"e.g. authorization_code, refresh_token","dynamicRegistrationAuth":"Require Authentication","dynamicRegistrationAuthDescription":"Protect the registration endpoint so only authenticated requests can register clients","invalidNumberInput":"Please enter a valid non-negative number"}`),_s={upload:"Upload",uploadTitle:"Upload MCPB Bundle",dropFileHere:"Drop your .mcpb file here",orClickToSelect:"or click to select from your computer",invalidFileType:"Please select a valid .mcpb file",noFileSelected:"Please select a .mcpb file to upload",uploading:"Uploading...",uploadFailed:"Failed to upload MCPB file",installServer:"Install MCP Server from MCPB",extensionInfo:"Extension Information",name:"Name",version:"Version",description:"Description",author:"Author",tools:"Tools",serverName:"Server Name",serverNamePlaceholder:"Enter a name for this server",install:"Install",installing:"Installing...",installFailed:"Failed to install server from MCPB",serverExistsTitle:"Server Already Exists",serverExistsConfirm:"Server '{{serverName}}' already exists. Do you want to override it with the new version?",override:"Override"},Js={button:"Import",title:"Import Servers from JSON",inputLabel:"Server Configuration JSON",inputHelp:"Paste your server configuration JSON. Supports STDIO, SSE, and HTTP (streamable-http) server types.",preview:"Preview",previewTitle:"Preview Servers to Import",import:"Import",importing:"Importing...",invalidFormat:"Invalid JSON format. The JSON must contain an 'mcpServers' object.",parseError:"Failed to parse JSON. Please check the format and try again.",addFailed:"Failed to add server",importFailed:"Failed to import servers",partialSuccess:"Imported {{count}} of {{total}} servers successfully. Some servers failed:"},Ws={button:"Import",title:"Import Groups from JSON",inputLabel:"Group Configuration JSON",inputHelp:"Paste your group configuration JSON. Each group can contain a list of servers.",preview:"Preview",previewTitle:"Preview Groups to Import",import:"Import",importing:"Importing...",invalidFormat:"Invalid JSON format. The JSON must contain a 'groups' array.",missingName:"Each group must have a 'name' field.",parseError:"Failed to parse JSON. Please check the format and try again.",addFailed:"Failed to add group",importFailed:"Failed to import groups",partialSuccess:"Imported {{count}} of {{total}} groups successfully. Some groups failed:"},Ys={add:"Add User",addNew:"Add New User",edit:"Edit User",delete:"Delete User",create:"Create User",update:"Update User",username:"Username",password:"Password",newPassword:"New Password",confirmPassword:"Confirm Password",changePassword:"Change Password",adminRole:"Administrator",admin:"Admin",user:"User",role:"Role",actions:"Actions",addFirst:"Add your first user",permissions:"Permissions",adminPermissions:"Full system access",userPermissions:"Limited access",currentUser:"You",noUsers:"No users found",adminRequired:"Administrator access required to manage users",usernameRequired:"Username is required",passwordRequired:"Password is required",passwordTooShort:"Password must be at least 6 characters long",passwordMismatch:"Passwords do not match",usernamePlaceholder:"Enter username",passwordPlaceholder:"Enter password",newPasswordPlaceholder:"Leave empty to keep current password",confirmPasswordPlaceholder:"Confirm new password",createError:"Failed to create user",updateError:"Failed to update user",deleteError:"Failed to delete user",statsError:"Failed to fetch user statistics",deleteConfirmation:"Are you sure you want to delete user '{{username}}'? This action cannot be undone.",confirmDelete:"Delete User",deleteWarning:"Are you sure you want to delete user '{{username}}'? This action cannot be undone."},Qs={errors:{readonly:"Readonly for demo environment",invalid_credentials:"Invalid username or password",serverNameRequired:"Server name is required",serverConfigRequired:"Server configuration is required",serverConfigInvalid:"Server configuration must include either a URL, OpenAPI specification URL or schema, or command with arguments",serverTypeInvalid:"Server type must be one of: stdio, sse, streamable-http, openapi",urlRequiredForType:"URL is required for {{type}} server type",openapiSpecRequired:"OpenAPI specification URL or schema is required for openapi server type",headersInvalidFormat:"Headers must be an object",headersNotSupportedForStdio:"Headers are not supported for stdio server type",serverNotFound:"Server not found",failedToRemoveServer:"Server not found or failed to remove",internalServerError:"Internal server error",failedToGetServers:"Failed to get servers information",failedToReloadServer:"Failed to reload server",failedToGetServerSettings:"Failed to get server settings",failedToGetServerConfig:"Failed to get server configuration",failedToSaveSettings:"Failed to save settings",toolNameRequired:"Server name and tool name are required",descriptionMustBeString:"Description must be a string",groupIdRequired:"Group ID is required",groupNameRequired:"Group name is required",groupNotFound:"Group not found",groupIdAndServerNameRequired:"Group ID and server name are required",groupOrServerNotFound:"Group or server not found",toolsMustBeAllOrArray:'Tools must be "all" or an array of strings',serverNameAndToolNameRequired:"Server name and tool name are required",usernameRequired:"Username is required",userNotFound:"User not found",failedToGetUsers:"Failed to get users information",failedToGetUserInfo:"Failed to get user information",failedToGetUserStats:"Failed to get user statistics",marketServerNameRequired:"Server name is required",marketServerNotFound:"Market server not found",failedToGetMarketServers:"Failed to get market servers information",failedToGetMarketServer:"Failed to get market server information",failedToGetMarketCategories:"Failed to get market categories",failedToGetMarketTags:"Failed to get market tags",failedToSearchMarketServers:"Failed to search market servers",failedToFilterMarketServers:"Failed to filter market servers",failedToProcessMcpbFile:"Failed to process MCPB file"},success:{serverCreated:"Server created successfully",serverUpdated:"Server updated successfully",serverRemoved:"Server removed successfully",serverToggled:"Server status toggled successfully",toolToggled:"Tool {{name}} {{action}} successfully",toolDescriptionUpdated:"Tool {{name}} description updated successfully",systemConfigUpdated:"System configuration updated successfully",groupCreated:"Group created successfully",groupUpdated:"Group updated successfully",groupDeleted:"Group deleted successfully",serverAddedToGroup:"Server added to group successfully",serverRemovedFromGroup:"Server removed from group successfully",serverToolsUpdated:"Server tools updated successfully"}},Zs={authorizationFailed:"Authorization Failed",authorizationFailedError:"Error",authorizationFailedDetails:"Details",invalidRequest:"Invalid Request",missingStateParameter:"Missing required OAuth state parameter.",missingCodeParameter:"Missing required authorization code parameter.",serverNotFound:"Server Not Found",serverNotFoundMessage:"Could not find server associated with this authorization request.",sessionExpiredMessage:"The authorization session may have expired. Please try authorizing again.",authorizationSuccessful:"Authorization Successful",server:"Server",status:"Status",connected:"Connected",successMessage:"The server has been successfully authorized and connected.",autoCloseMessage:"This window will close automatically in 3 seconds...",closeNow:"Close Now",connectionError:"Connection Error",connectionErrorMessage:"Authorization was successful, but failed to connect to the server.",reconnectMessage:"Please try reconnecting from the dashboard.",configurationError:"Configuration Error",configurationErrorMessage:"Server transport does not support OAuth finishAuth(). Please ensure the server is configured with streamable-http transport.",internalError:"Internal Error",internalErrorMessage:"An unexpected error occurred while processing the OAuth callback.",closeWindow:"Close Window"},Xs={add:"Add Prompt",addNew:"Add New Prompt",edit:"Edit Prompt",delete:"Delete",noPrompts:"No built-in prompts configured",addFirst:"Add your first prompt",name:"Name",namePlaceholder:"e.g. code-review",title:"Title",titlePlaceholder:"e.g. Code Review Prompt",description:"Description",descriptionPlaceholder:"Brief description of the prompt",template:"Template",templatePlaceholder:"Enter template text with {{parameter}} placeholders...",templateHint:"Use {{paramName}} for template parameters",arguments:"Arguments",addArgument:"Add Argument",argName:"Name",argDescription:"Description",argRequired:"Required",enabled:"Enabled",active:"Active",inactive:"Inactive",nameRequired:"Name is required",templateRequired:"Template is required",fetchError:"Failed to load built-in prompts",createError:"Failed to create prompt",updateError:"Failed to update prompt",deleteError:"Failed to delete prompt",saveError:"Failed to save prompt",confirmDelete:"Delete Prompt",deleteWarning:'Are you sure you want to delete the prompt "{{name}}"? This action cannot be undone.'},eo={add:"Add Resource",addNew:"Add New Resource",edit:"Edit Resource",delete:"Delete",noResources:"No built-in resources configured",addFirst:"Add your first resource",uri:"URI",uriPlaceholder:"e.g. resource://docs/guide",name:"Name",namePlaceholder:"e.g. User Guide",description:"Description",descriptionPlaceholder:"Brief description of the resource",mimeType:"MIME Type",content:"Content",contentPlaceholder:"Enter the resource content...",enabled:"Enabled",active:"Active",inactive:"Inactive",descriptionUpdateSuccess:"Resource description updated successfully",descriptionUpdateFailed:"Failed to update resource description",restoreDefault:"Restore default",restoreDefaultSuccess:"Resource description restored to default",restoreDefaultFailed:"Failed to restore the default resource description",uriRequired:"URI is required",contentRequired:"Content is required",fetchError:"Failed to load built-in resources",createError:"Failed to create resource",updateError:"Failed to update resource",deleteError:"Failed to delete resource",saveError:"Failed to save resource",confirmDelete:"Delete Resource",deleteWarning:'Are you sure you want to delete the resource "{{name}}"? This action cannot be undone.'},ro={title:"Activity",totalCalls:"Total Calls",successCount:"Successful",errorCount:"Failed",avgDuration:"Avg Duration",timestamp:"Timestamp",server:"Server",tool:"Tool",duration:"Duration",status:"Status",group:"Group",key:"API Key",input:"Input",output:"Output",details:"Activity Details",errorMessage:"Error Message",searchServer:"Server...",searchTool:"Tool...",searchStatus:"Status...",searchGroup:"Group...",searchKeyName:"API key...",keyName:"API Key Name",allStatus:"All Status",statusSuccess:"Success",statusError:"Error",noData:"No activity data available",fetchError:"Failed to load activity data",cleanup:"Cleanup",confirmCleanup:"Are you sure you want to delete activities older than 30 days?",cleanupSuccess:"Deleted {{count}} old activities",cleanupError:"Failed to cleanup old activities",notAvailable:"Activity tracking is only available in database mode"},to={exportButton:"Export Template",importButton:"Import Template",exportTitle:"Export Configuration Template",importTitle:"Import Configuration Template",name:"Template Name",nameRequired:"Template name is required",namePlaceholder:"e.g., Frontend Dev Tools",description:"Description",descriptionPlaceholder:"e.g., Standard MCP servers for frontend development",selectGroups:"Select Groups",selectGroupsHelp:"Leave empty to export all groups",selectAll:"Select All",deselectAll:"Deselect All",includeDisabled:"Include disabled servers",exportNote:"Secrets (API keys, tokens, passwords) will be replaced with ${PLACEHOLDER} references. Recipients must supply their own credentials.",export:"Export",exporting:"Exporting...",exportFailed:"Failed to export template",import:"Import",importing:"Importing...",importFailed:"Failed to import template",invalidFormat:"Invalid template format. Must contain version, name, servers, and groups fields.",parseError:"Failed to parse JSON. Please check the format and try again.",uploadFile:"Upload Template File",or:"or",pasteJson:"Paste Template JSON",pastePlaceholder:"Paste your .mcphub-template.json content here...",version:"Version",createdAt:"Created",servers:"Servers",groups:"Groups",serversInGroup:"server(s)",envVarsNeeded:"Required Environment Variables — set these before using the imported servers:",importResult:"Servers: {{serversCreated}} created, {{serversSkipped}} skipped. Groups: {{groupsCreated}} created, {{groupsSkipped}} skipped."},ao={app:Ps,about:ws,profile:xs,sponsor:Cs,wechat:Rs,discord:Es,theme:Ts,auth:Ns,server:Ds,status:Ms,errors:Is,common:zs,pagination:Os,nav:Ls,pages:Fs,logs:js,groups:Us,market:Gs,oauthServer:Ks,cloud:qs,registry:Bs,tool:Hs,prompt:Vs,settings:$s,mcpb:_s,jsonImport:Js,groupImport:Ws,users:Ys,api:Qs,oauthCallback:Zs,builtinPrompts:Xs,builtinResources:eo,activity:ro,template:to},so={title:"MCPHub 控制面板",error:"错误",closeButton:"关闭",noServers:"没有可用的 MCP 服务器",loading:"加载中...",logout:"退出登录",profile:"个人资料",changePassword:"修改密码",toggleSidebar:"切换侧边栏",welcomeUser:"欢迎, {{username}}",name:"MCPHub",embeddingSyncProgress:"正在为 {{serverName}} 创建嵌入",embeddingSyncProgressAriaLabel:"正在为 {{serverName}} 创建嵌入:已完成 {{current}}/{{total}}"},oo={title:"关于",versionInfo:"MCPHub 版本: {{version}}",newVersion:"有新版本可用!",currentVersion:"当前版本",newVersionAvailable:"新版本 {{version}} 已发布",viewOnGitHub:"在 GitHub 上查看",checkForUpdates:"检查更新",checking:"检查更新中..."},no={viewProfile:"查看个人中心",userCenter:"个人中心"},io={label:"赞助",title:"支持项目",rewardAlt:"赞赏码",supportMessage:"通过捐赠支持 MCPHub 的开发!",supportButton:"在 Ko-fi 上支持"},lo={label:"微信",title:"微信联系",qrCodeAlt:"微信二维码",scanMessage:"扫描二维码添加微信"},uo={label:"Discord",title:"加入我们的 Discord 服务器",community:"加入我们不断壮大的 Discord 社区,获取支持、参与讨论并了解最新动态!"},co={title:"主题",light:"浅色",dark:"深色",system:"系统"},mo={login:"登录",loginTitle:"登录 MCPHub",slogan:"统一的 MCP 服务器管理平台",subtitle:"模型上下文协议服务器的集中管理平台,通过灵活的路由策略组织、监控和扩展多个 MCP 服务器。",username:"用户名",password:"密码",loggingIn:"登录中...",orContinue:"或使用以下方式继续",loginWithGoogle:"使用 Google 登录",loginWithGithub:"使用 GitHub 登录",socialLoginFailed:"社交登录失败,请重试。",emptyFields:"用户名和密码不能为空",loginFailed:"登录失败,请检查用户名和密码",loginError:"登录过程中出现错误",serverUnavailable:"无法连接到服务器,请检查网络连接或稍后再试",currentPassword:"当前密码",newPassword:"新密码",confirmPassword:"确认密码",passwordsNotMatch:"新密码与确认密码不一致",changePasswordSuccess:"密码修改成功",changePasswordError:"修改密码失败",changePassword:"修改密码",passwordChanged:"密码修改成功",passwordChangeError:"修改密码失败",defaultPasswordWarning:"默认密码安全警告",defaultPasswordMessage:"您正在使用默认密码(admin123),这存在安全风险。为了保护您的账户安全,请立即修改密码。",goToSettings:"前往修改",passwordStrengthError:"密码不符合安全要求",passwordMinLength:"密码长度至少为 8 个字符",passwordRequireLetter:"密码必须包含至少一个字母",passwordRequireNumber:"密码必须包含至少一个数字",passwordRequireSpecial:"密码必须包含至少一个特殊字符",passwordStrengthHint:"密码必须至少 8 个字符,且包含字母、数字和特殊字符"},po={addServer:"添加服务器",add:"添加",edit:"编辑",copy:"复制",delete:"删除",confirmDelete:"您确定要删除此服务器吗?",deleteWarning:"删除服务器 '{{name}}' 将会移除该服务器及其所有数据。此操作无法撤销。",status:"状态",tools:"工具",prompts:"提示词",name:"服务器名称",description:"服务器注释",descriptionPlaceholder:"可选:记录这个服务器的用途说明",url:"服务器 URL",apiKey:"API 密钥",save:"保存",cancel:"取消",addError:"添加服务器失败",editError:"编辑服务器 {{serverName}} 失败",invalidConfig:"无法找到 {{serverName}} 的配置数据",deleteError:"删除服务器 {{serverName}} 失败",updateError:"更新服务器失败",editTitle:"编辑服务器: {{serverName}}",type:"服务器类型",typeStdio:"STDIO",typeSse:"SSE",typeStreamableHttp:"流式 HTTP",typeOpenapi:"OpenAPI",command:"命令",arguments:"参数",envVars:"环境变量",headers:"HTTP 请求头",key:"键",value:"值",enabled:"已启用",enable:"启用",disable:"禁用",reload:"重载",reloadSuccess:"服务器重载成功",reloadError:"重载服务器 {{serverName}} 失败",requestOptions:"连接配置",timeout:"请求超时",timeoutDescription:"请求超时时间(毫秒)",maxTotalTimeout:"最大总超时",maxTotalTimeoutDescription:"无论是否有进度通知的最大总超时时间(毫秒)",resetTimeoutOnProgress:"收到进度通知时重置超时",resetTimeoutOnProgressDescription:"适用于发送周期性进度更新的长时间运行操作(默认开启)",keepAlive:"保活配置",enableKeepAlive:"启用保活",keepAliveDescription:"定期发送 ping 请求以维持连接。适用于可能超时的长期连接。",keepAliveInterval:"间隔时间(毫秒)",keepAliveIntervalDescription:"保活 ping 的时间间隔(默认:60000毫秒 = 1分钟)",remove:"移除",toggleError:"切换服务器 {{serverName}} 状态失败",alreadyExists:"服务器 {{serverName}} 已经存在",invalidData:"提供的服务器数据无效",notFound:"找不到服务器 {{serverName}}",namePlaceholder:"请输入服务器名称",urlPlaceholder:"请输入服务器URL",commandPlaceholder:"请输入命令",argumentsPlaceholder:"请输入参数",errorDetails:"错误详情",viewErrorDetails:"查看错误详情",copyConfig:"复制配置",confirmVariables:"确认变量配置",variablesDetected:"检测到配置中包含变量,请确认这些变量是否已正确配置:",detectedVariables:"检测到的变量",confirmVariablesMessage:"请确保这些变量在运行环境中已正确定义。是否继续添加服务器?",confirmAndAdd:"确认并添加",openapi:{inputMode:"输入模式",inputModeUrl:"规范 URL",inputModeSchema:"JSON 模式",specUrl:"OpenAPI 规范 URL",schema:"OpenAPI JSON 模式",schemaHelp:"请在此处粘贴完整的 OpenAPI JSON 模式",security:"安全类型",securityNone:"无",securityApiKey:"API 密钥",securityHttp:"HTTP 认证",securityOAuth2:"OAuth 2.0",securityOpenIdConnect:"OpenID Connect",apiKeyConfig:"API 密钥配置",apiKeyName:"请求头/参数名称",apiKeyIn:"位置",apiKeyValue:"API 密钥值",httpAuthConfig:"HTTP 认证配置",httpScheme:"认证方案",httpCredentials:"凭据",httpSchemeBasic:"Basic",httpSchemeBearer:"Bearer",httpSchemeDigest:"Digest",oauth2Config:"OAuth 2.0 配置",oauth2Token:"访问令牌",openIdConnectConfig:"OpenID Connect 配置",openIdConnectUrl:"发现 URL",openIdConnectToken:"ID 令牌",apiKeyInHeader:"请求头",apiKeyInQuery:"查询",apiKeyInCookie:"Cookie",passthroughHeaders:"透传请求头",passthroughHeadersHelp:"要从传入的 MCP 请求透传到上游服务器请求的请求头名称列表,用逗号分隔(如:Authorization, X-API-Key)"},oauth:{sectionTitle:"OAuth 配置",sectionDescription:"为需要 OAuth 的服务器配置客户端凭据(可选)。",clientId:"客户端 ID",clientSecret:"客户端密钥",authorizationEndpoint:"授权端点",tokenEndpoint:"令牌端点",scopes:"权限范围(Scopes)",scopesPlaceholder:"scope1 scope2",resource:"资源 / 受众",accessToken:"访问令牌",refreshToken:"刷新令牌"}},go={online:"在线",offline:"离线",connecting:"连接中",oauthRequired:"需要OAuth授权",clickToAuthorize:"点击进行OAuth授权",oauthWindowOpened:"OAuth授权窗口已打开,请完成授权。"},ho={general:"发生错误",network:"网络连接错误,请检查您的互联网连接",serverConnection:"无法连接到服务器,请检查服务器是否正在运行",serverAdd:"添加服务器失败,请检查服务器状态",serverUpdate:"编辑服务器 {{serverName}} 失败,请检查服务器状态",serverFetch:"获取服务器数据失败,请稍后重试",failedToReloadServer:"重载服务器失败",initialStartup:"服务器可能正在启动中。首次启动可能需要一些时间,请耐心等候...",serverInstall:"安装服务器失败",failedToFetchSettings:"获取设置失败",failedToUpdateSystemConfig:"更新系统配置失败",failedToUpdateRouteConfig:"更新路由配置失败",failedToUpdateSmartRoutingConfig:"更新智能路由配置失败"},fo={processing:"处理中...",save:"保存",cancel:"取消",back:"返回",refresh:"刷新",search:"搜索",clear:"清除",view:"查看",create:"创建",creating:"创建中...",update:"更新",updating:"更新中...",submitting:"提交中...",delete:"删除",remove:"移除",copy:"复制",copyId:"复制ID",copyUrl:"复制URL",copyJson:"复制JSON",copySuccess:"已复制到剪贴板",copyFailed:"复制失败",copied:"已复制",close:"关闭",confirm:"确认",language:"语言",true:"是",false:"否",dismiss:"忽略",github:"GitHub",wechat:"微信",itemsPerPage:"每页显示",showing:"显示第 {{start}}-{{end}} 条,共 {{total}} 条",previous:"上一页",next:"下一页",discord:"Discord",required:"必填",secret:"敏感",default:"默认值",value:"值",type:"类型",repeated:"可重复",valueHint:"值提示",choices:"可选值",actions:"操作",saving:"保存中...",active:"已激活",inactive:"未激活",viewAll:"查看全部",docs:"文档",all:"全部"},vo={rowsPerPage:"每页行数",showing:"显示第 {{from}}-{{to}} 条,共 {{total}} 条"},yo={dashboard:"仪表盘",servers:"服务器",settings:"设置",changePassword:"修改密码",groups:"分组",prompts:"提示词",resources:"资源",users:"用户",market:"市场",cloud:"云端市场",logs:"日志",activity:"活动",workspace:"工作区",system:"系统"},bo={dashboard:{title:"仪表盘",totalServers:"总数",onlineServers:"在线",disabledServers:"禁用",offlineServers:"离线",connectingServers:"连接中",recentServers:"最近的服务器",endpoints:"MCP 接入端点",endpointsHint:"把这些 URL 配到 Claude Desktop / Cursor 等 MCP 客户端即可使用"},servers:{title:"服务器管理"},settings:{title:"设置",language:"语言",account:"账户设置",password:"修改密码",appearance:"外观",routeConfig:"安全配置",installConfig:"安装",smartRouting:"智能路由",oauthServer:"OAuth"},groups:{title:"分组管理"},prompts:{title:"内置提示词"},resources:{title:"内置资源"},users:{title:"用户管理"},market:{title:"市场中心 - 本地市场和云端市场"},logs:{title:"系统日志"}},ko={filters:"筛选",search:"搜索日志...",autoScroll:"自动滚动",clearLogs:"清除日志",loading:"加载日志中...",noLogs:"暂无日志。",noMatch:"没有匹配当前筛选条件的日志。",mainProcess:"主进程",childProcess:"子进程",main:"主",child:"子"},So={add:"添加",addNew:"添加新分组",edit:"编辑分组",delete:"删除",confirmDelete:"您确定要删除此分组吗?",deleteWarning:"删除分组 '{{name}}' 将会移除该分组及其所有服务器关联。此操作无法撤销。",name:"分组名称",namePlaceholder:"请输入分组名称",nameRequired:"分组名称不能为空",description:"描述",descriptionPlaceholder:"请输入分组描述(可选)",createError:"创建分组失败",updateError:"更新分组失败",deleteError:"删除分组失败",serverAddError:"向分组添加服务器失败",serverRemoveError:"从分组移除服务器失败",addServer:"添加服务器到分组",selectServer:"选择要添加的服务器",servers:"分组中的服务器",remove:"移除",noGroups:"暂无可用分组。创建一个新分组以开始使用。",noServers:"此分组中没有服务器。",noServerOptions:"没有可用的服务器",serverCount:"{{count}} 台服务器",toolSelection:"工具选择",promptSelection:"提示词选择",resourceSelection:"资源选择",toolsSelected:"选择",promptsSelected:"选择",resourcesSelected:"选择",allTools:"全部",allPrompts:"全部提示词",allResources:"全部资源",selectedTools:"选中的工具",selectedPrompts:"选中的提示词",selectedResources:"选中的资源",selectAll:"全选",selectNone:"全不选",configureTools:"配置工具",configureCapabilities:"配置工具、提示词和资源",previewPrompts:"[提示词: {{items}}]",previewResources:"[资源: {{items}}]",previewAllTools:"(全部工具)",previewAllPrompts:"(全部提示词)",previewAllResources:"(全部资源)"},Ao={title:"本地安装",official:"官方",by:"作者",unknown:"未知",tools:"工具",search:"搜索",searchPlaceholder:"搜索服务器名称、分类或标签",clearFilters:"清除",clearCategoryFilter:"",clearTagFilter:"",categories:"分类",tags:"标签",showTags:"显示标签",hideTags:"隐藏标签",moreTags:"",noServers:"未找到匹配的服务器",backToList:"返回列表",install:"安装",installing:"安装中...",installed:"已安装",installServer:"安装服务器: {{name}}",installSuccess:"服务器 {{serverName}} 安装成功",author:"作者",license:"许可证",repository:"代码仓库",examples:"示例",arguments:"参数",argumentName:"名称",description:"描述",required:"必填",example:"示例",viewSchema:"查看结构",fetchError:"获取本地市场服务器数据失败",serverNotFound:"未找到服务器",searchError:"搜索服务器失败",filterError:"按分类筛选服务器失败",tagFilterError:"按标签筛选服务器失败",noInstallationMethod:"该服务器没有可用的安装方法",showing:"显示 {{from}}-{{to}}/{{total}} 个服务器",perPage:"每页显示",confirmVariablesMessage:"请确保这些变量在运行环境中已正确定义。是否继续安装服务器?",confirmAndInstall:"确认并安装"},Po={authorizeTitle:"授权应用",authorizeSubtitle:"允许此应用访问您的 MCPHub 账号。",buttons:{approve:"允许访问",deny:"拒绝",approveSubtitle:"如果您信任此应用,建议选择允许。",denySubtitle:"您可以在之后随时再次授权。"}},wo={title:"云端支持",subtitle:"由 MCPRouter 提供支持",by:"作者",server:"服务器",config:"配置",created:"创建时间",updated:"更新时间",available:"可用",description:"描述",details:"详细信息",tools:"工具",tool:"个工具",toolsAvailable:"{{count}} 个工具可用",loadingTools:"加载工具中...",noTools:"该服务器没有可用工具",noDescription:"无描述信息",viewDetails:"查看详情",parameters:"参数",result:"结果",error:"错误",callTool:"调用",calling:"调用中...",toolCallSuccess:"工具 {{toolName}} 执行成功",toolCallError:"调用工具 {{toolName}} 失败:{{error}}",viewSchema:"查看结构",backToList:"返回云端市场",search:"搜索",searchPlaceholder:"搜索云端服务器名称、标题或作者",clearFilters:"清除筛选",clearCategoryFilter:"清除",clearTagFilter:"清除",categories:"分类",tags:"标签",noCategories:"未找到分类",noTags:"未找到标签",noServers:"未找到云端服务器",fetchError:"获取云端服务器失败",serverNotFound:"未找到云端服务器",searchError:"搜索云端服务器失败",filterError:"按分类筛选云端服务器失败",tagFilterError:"按标签筛选云端服务器失败",showing:"显示 {{from}}-{{to}}/{{total}} 个云端服务器",perPage:"每页显示",apiKeyNotConfigured:"MCPRouter API 密钥未配置",apiKeyNotConfiguredDescription:"要使用云端服务器,您需要配置 MCPRouter API 密钥。",getApiKey:"获取 API 密钥",configureInSettings:"在设置中配置",installServer:"安装 {{name}}",installSuccess:"服务器 {{name}} 安装成功",installError:"安装服务器失败:{{error}}"},xo={title:"注册中心",official:"官方",latest:"最新版本",description:"描述",website:"网站",repository:"代码仓库",packages:"安装包",package:"安装包",remotes:"远程服务",remote:"远程服务",published:"发布时间",updated:"更新时间",install:"安装",installing:"安装中...",installed:"已安装",installServer:"安装 {{name}}",installSuccess:"服务器 {{name}} 安装成功",installError:"安装服务器失败:{{error}}",noDescription:"无描述信息",viewDetails:"查看详情",backToList:"返回注册中心",search:"搜索",searchPlaceholder:"按名称搜索注册中心服务器",clearFilters:"清除",noServers:"未找到注册中心服务器",fetchError:"获取注册中心服务器失败",serverNotFound:"未找到注册中心服务器",showing:"显示 {{from}}-{{to}}/{{total}} 个注册中心服务器",perPage:"每页显示",environmentVariables:"环境变量",packageArguments:"安装包参数",runtimeArguments:"运行时参数",headers:"请求头"},Co={run:"运行",running:"运行中...",runTool:"运行",cancel:"取消",noDescription:"无描述信息",inputSchema:"输入模式:",runToolWithName:"运行工具:{{name}}",execution:"工具执行",successful:"成功",failed:"失败",result:"结果:",error:"错误",errorDetails:"错误详情:",noContent:"工具执行成功但未返回内容。",unknownError:"发生未知错误",jsonResponse:"JSON 响应:",toolResult:"工具结果",noParameters:"此工具不需要任何参数。",selectOption:"选择一个选项",enterValue:"输入{{type}}值",enabled:"已启用",enableSuccess:"工具 {{name}} 启用成功",disableSuccess:"工具 {{name}} 禁用成功",toggleFailed:"切换工具状态失败",descriptionUpdateSuccess:"工具描述更新成功",descriptionUpdateFailed:"更新工具描述失败",restoreDefault:"恢复默认值",restoreDefaultSuccess:"工具描述已恢复为默认值",restoreDefaultFailed:"恢复默认工具描述失败",parameters:"工具参数",formMode:"表单模式",jsonMode:"JSON 模式",jsonConfiguration:"JSON 配置",invalidJsonFormat:"无效的 JSON 格式",fixJsonBeforeSwitching:"请修复 JSON 格式后再切换到表单模式",item:"项目 {{index}}",addItem:"添加 {{key}} 项目",enterKey:"输入 {{key}}"},Ro={run:"获取",running:"获取中...",result:"提示词结果",error:"提示词错误",execution:"提示词执行",successful:"成功",failed:"失败",errorDetails:"错误详情:",noContent:"提示词执行成功但未返回内容。",unknownError:"发生未知错误",jsonResponse:"JSON 响应:",description:"描述",messages:"消息",noDescription:"无描述信息",runPromptWithName:"获取提示词: {{name}}",descriptionUpdateSuccess:"提示词描述更新成功",descriptionUpdateFailed:"更新提示词描述失败",restoreDefault:"恢复默认值",restoreDefaultSuccess:"提示词描述已恢复为默认值",restoreDefaultFailed:"恢复默认提示词描述失败"},Eo={subtitle:"配置系统设置、认证、路由及 MCP 服务器集成。",enableGlobalRoute:"启用全局路由",enableGlobalRouteDescription:"允许不指定组 ID 就连接到 /sse 端点",enableGroupNameRoute:"启用组名路由",enableGroupNameRouteDescription:"允许使用组名而不仅仅是组 ID 连接到 /sse 端点",enableBearerAuth:"启用 Bearer 认证",enableBearerAuthDescription:"对 MCP 端点启用 Bearer 令牌认证(默认开启)",bearerAuthKey:"Bearer 认证密钥",bearerAuthKeyDescription:"Bearer 令牌中需要携带的认证密钥",bearerAuthKeyPlaceholder:"请输入 Bearer 认证密钥",bearerAuthHeaderName:"Bearer 认证请求头名称",bearerAuthHeaderNameDescription:"用于接收 MCP Bearer 凭证的请求头名称。当上游透传头也使用 Authorization 时,可改成其它名称以避免冲突。",bearerAuthHeaderNamePlaceholder:"例如:Authorization 或 X-MCP-Authorization",bearerKeysSectionTitle:"密钥",bearerKeysSectionDescription:"管理多条密钥,并为不同密钥配置不同的访问范围。",noBearerKeys:"当前还没有配置任何密钥。",bearerKeyName:"名称",bearerKeyToken:"密钥值",bearerKeyEnabled:"启用",bearerKeyAccessType:"访问范围",bearerKeyAccessAll:"全部",bearerKeyAccessGroups:"指定分组",bearerKeyAccessServers:"指定服务器",bearerKeyAccessCustom:"自定义",bearerKeyAllowedGroups:"允许访问的分组",bearerKeyAllowedServers:"允许访问的服务器",addBearerKey:"新增密钥",addBearerKeyButton:"创建",bearerKeyRequired:"名称和密钥值为必填项",deleteBearerKeyConfirm:"确定要删除这条密钥吗?",generate:"生成",selectGroups:"选择分组",selectServers:"选择服务器",selectAtLeastOneGroup:"请至少选择一个分组",selectAtLeastOneServer:"请至少选择一个服务器",skipAuth:"免登录开关",skipAuthDescription:"允许仪表盘免登录;未认证用户将获得 guest 管理员访问权限(不影响 MCP 端点认证)",jsonBodyLimit:"JSON 请求体大小限制",jsonBodyLimitDescription:"Express JSON 请求体大小限制,大型 OpenAPI schema 上传也会受此配置影响。",jsonBodyLimitPlaceholder:"例如:1mb、5mb、1024kb",pythonIndexUrl:"Python 包仓库地址",pythonIndexUrlDescription:"设置 UV_DEFAULT_INDEX 环境变量,用于 Python 包安装",pythonIndexUrlPlaceholder:"例如: https://pypi.org/simple",npmRegistry:"NPM 仓库地址",npmRegistryDescription:"设置 npm_config_registry 环境变量,用于 NPM 包安装",npmRegistryPlaceholder:"例如: https://registry.npmjs.org/",baseUrl:"基础地址",baseUrlDescription:"用于 MCP 请求与 OAuth 回调的基础地址",baseUrlPlaceholder:"例如: http://localhost:3000",installConfig:"安装配置",systemConfigUpdated:"系统配置更新成功",enableSmartRouting:"启用智能路由",enableSmartRoutingDescription:"开启智能路由功能,根据输入自动搜索最合适的工具(使用 $smart 分组)",dbUrl:"PostgreSQL 连接地址(必须支持 pgvector)",dbUrlPlaceholder:"例如: postgresql://user:password@localhost:5432/dbname",embeddingProvider:"嵌入提供方",openaiApiBaseUrl:"OpenAI 兼容基础地址",openaiApiBaseUrlPlaceholder:"https://api.openai.com/v1",openaiApiKey:"LLM 提供商 API 密钥",openaiApiKeyDescription:"用于访问嵌入服务的 API 密钥",openaiApiKeyPlaceholder:"请输入 LLM 提供商 API 密钥",openaiApiEmbeddingModel:"嵌入模型名称",openaiApiEmbeddingModelPlaceholder:"text-embedding-3-small",basePacingDelayMs:"基础节流延迟(毫秒)",basePacingDelayMsDescription:"向嵌入服务提供方发送请求之间的基础等待时间。默认为 0 — 系统自动管理限流:优先遵守 Retry-After 响应头,若无该头则等待 63 秒,并在每次 403/429 后自动提高节流延迟。仅当提供方要求固定最小请求间隔时才需设置非零值。",basePacingDelayMsPlaceholder:"留空 = 默认 0 毫秒",basePacingDelayMsAuto:"默认({{value}} 毫秒):限流由系统自动管理。",basePacingDelayMsZero:"0 毫秒(默认):限流通过自适应节流和重试逻辑自动管理。",basePacingDelayMsOverride:"自定义值:覆盖默认的基础节流延迟。",embeddingEncodingFormat:"嵌入编码格式",embeddingEncodingFormatDescription:"嵌入向量的编码格式。自动模式会根据服务商支持情况自动选择。",embeddingEncodingFormatAuto:"自动(推荐)",azureOpenaiEndpoint:"Azure OpenAI 终端地址",azureOpenaiEndpointPlaceholder:"https://YOUR_RESOURCE_NAME.openai.azure.com",azureOpenaiApiKey:"Azure OpenAI API 密钥",azureOpenaiApiKeyPlaceholder:"请输入 Azure OpenAI API 密钥",azureOpenaiApiVersion:"Azure OpenAI API 版本",azureOpenaiApiVersionPlaceholder:"2024-02-15-preview",azureOpenaiEmbeddingDeployment:"Azure OpenAI 嵌入部署",azureOpenaiEmbeddingDeploymentPlaceholder:"text-embedding-3-small",azureOpenaiEmbeddingModel:"Azure 嵌入模型名称",azureOpenaiEmbeddingModelDescription:"在 Azure 中部署的实际 OpenAI 模型名称(例如 text-embedding-3-small),用于在发送请求前准确进行 Token 计数。",azureOpenaiEmbeddingModelPlaceholder:"text-embedding-3-small",progressiveDisclosure:"渐进式披露",progressiveDisclosureDescription:"开启后,search_tools 只返回工具名称和描述,通过 describe_tool 获取完整参数定义,可减少 Token 消耗",embeddingMaxTokens:"最大嵌入 Token 数",embeddingMaxTokensDescription:"生成嵌入前截断文本的最大 Token 数。留空将自动使用模型默认值。设置自定义值将始终覆盖模型默认值。当使用本地 LLM 提供商时,手动设置此值特别有用,可防止截断错误。",embeddingMaxTokensPlaceholder:"留空 = 自动(按模型)",embeddingMaxTokensAuto:"自动:{{limit}} tokens({{model}} 的模型默认值)",embeddingMaxTokensOverride:"此值将覆盖模型默认值。",smartRoutingConfigUpdated:"智能路由配置更新成功",smartRoutingRequiredFields:"启用智能路由需要填写数据库连接地址。LLM 提供商 API 密钥仅在使用云端提供商时才需要(本地 LLM 通常不需要 API 密钥,可输入任意值通过表单验证)",smartRoutingValidationError:"启用智能路由前请先填写必要字段:{{fields}}",smartRoutingWorkflow:"工作流",smartRoutingWorkflowDescription:"用户的 prompt 经向量化后,在 pgvector 中检索 top-k 相似工具,仅暴露给上游 LLM。",mcpRouterConfig:"云端市场",mcpRouterApiKey:"MCPRouter API 密钥",mcpRouterApiKeyDescription:"用于访问 MCPRouter 云端市场服务的 API 密钥",mcpRouterApiKeyPlaceholder:"请输入 MCPRouter API 密钥",mcpRouterReferer:"引用地址",mcpRouterRefererDescription:"MCPRouter API 请求的引用地址头",mcpRouterRefererPlaceholder:"https://www.mcphub.app",mcpRouterTitle:"标题",mcpRouterTitleDescription:"MCPRouter API 请求的标题头",mcpRouterTitlePlaceholder:"MCPHub",mcpRouterBaseUrl:"基础地址",mcpRouterBaseUrlDescription:"MCPRouter API 的基础地址",mcpRouterBaseUrlPlaceholder:"https://api.mcprouter.to/v1",systemSettings:"系统设置",nameSeparatorLabel:"名称分隔符",nameSeparatorDescription:"用于分隔服务器名称和工具/提示名称(默认:-)",enableSessionRebuild:"启用服务端会话重建",enableSessionRebuildDescription:"开启后会应用服务端会话重建的改进代码,提供更好的会话管理体验",restartRequired:"配置已保存。为确保所有服务正确加载新设置,建议重启应用。",exportMcpSettings:"导出配置",mcpSettingsJson:"MCP 配置 JSON",mcpSettingsJsonDescription:"查看、复制或下载当前的 mcp_settings.json 配置,可用于备份或迁移到其他工具",copyToClipboard:"复制到剪贴板",downloadJson:"下载 JSON",exportSuccess:"配置导出成功",exportError:"获取配置失败",enableOauthServer:"启用 OAuth 服务器",enableOauthServerDescription:"允许 MCPHub 作为 OAuth 2.0 授权服务器向外部客户端签发令牌",requireClientSecret:"需要客户端密钥",requireClientSecretDescription:"开启后,保密客户端必须携带 client secret(如需仅使用 PKCE 的公共客户端可关闭)",requireState:"要求 state 参数",requireStateDescription:"拒绝未携带 state 参数的授权请求",accessTokenLifetime:"访问令牌有效期(秒)",accessTokenLifetimeDescription:"控制访问令牌可使用的时长",accessTokenLifetimePlaceholder:"例如:3600",refreshTokenLifetime:"刷新令牌有效期(秒)",refreshTokenLifetimeDescription:"控制刷新令牌的过期时间",refreshTokenLifetimePlaceholder:"例如:1209600",authorizationCodeLifetime:"授权码有效期(秒)",authorizationCodeLifetimeDescription:"授权码在被兑换前可保持有效的时间",authorizationCodeLifetimePlaceholder:"例如:300",allowedScopes:"允许的作用域",allowedScopesDescription:"使用逗号分隔的作用域列表,在授权时展示给用户",allowedScopesPlaceholder:"例如:read, write",enableDynamicRegistration:"启用动态客户端注册",dynamicRegistrationDescription:"允许遵循 RFC 7591 的客户端通过公共端点自行注册",dynamicRegistrationAllowedGrantTypes:"允许的授权类型",dynamicRegistrationAllowedGrantTypesDescription:"使用逗号分隔动态注册客户端可以使用的授权类型",dynamicRegistrationAllowedGrantTypesPlaceholder:"例如:authorization_code, refresh_token",dynamicRegistrationAuth:"注册需要认证",dynamicRegistrationAuthDescription:"开启后,注册端点需要认证请求才能创建客户端",invalidNumberInput:"请输入合法的非负数字"},To={upload:"上传",uploadTitle:"上传 MCPB 文件",dropFileHere:"将 .mcpb 文件拖拽到此处",orClickToSelect:"或点击从计算机选择",invalidFileType:"请选择有效的 .mcpb 文件",noFileSelected:"请选择要上传的 .mcpb 文件",uploading:"上传中...",uploadFailed:"上传 MCPB 文件失败",installServer:"从 MCPB 安装 MCP 服务器",extensionInfo:"扩展信息",name:"名称",version:"版本",description:"描述",author:"作者",tools:"工具",serverName:"服务器名称",serverNamePlaceholder:"为此服务器输入名称",install:"安装",installing:"安装中...",installFailed:"从 MCPB 安装服务器失败",serverExistsTitle:"服务器已存在",serverExistsConfirm:"服务器 '{{serverName}}' 已存在。是否要用新版本覆盖它?",override:"覆盖"},No={button:"导入",title:"从 JSON 导入服务器",inputLabel:"服务器配置 JSON",inputHelp:"粘贴您的服务器配置 JSON。支持 STDIO、SSE 和 HTTP (streamable-http) 服务器类型。",preview:"预览",previewTitle:"预览要导入的服务器",import:"导入",importing:"导入中...",invalidFormat:"无效的 JSON 格式。JSON 必须包含 'mcpServers' 对象。",parseError:"解析 JSON 失败。请检查格式后重试。",addFailed:"添加服务器失败",importFailed:"导入服务器失败",partialSuccess:"成功导入 {{count}} / {{total}} 个服务器。部分服务器失败:"},Do={button:"导入",title:"从 JSON 导入分组",inputLabel:"分组配置 JSON",inputHelp:"粘贴您的分组配置 JSON。每个分组可以包含一个服务器列表。",preview:"预览",previewTitle:"预览要导入的分组",import:"导入",importing:"导入中...",invalidFormat:"无效的 JSON 格式。JSON 必须包含 'groups' 数组。",missingName:"每个分组必须有 'name' 字段。",parseError:"解析 JSON 失败。请检查格式后重试。",addFailed:"添加分组失败",importFailed:"导入分组失败",partialSuccess:"成功导入 {{count}} / {{total}} 个分组。部分分组失败:"},Mo={add:"添加",addNew:"添加新用户",edit:"编辑用户",delete:"删除用户",create:"创建",update:"更新",username:"用户名",password:"密码",newPassword:"新密码",confirmPassword:"确认密码",changePassword:"修改密码",adminRole:"管理员",admin:"管理员",user:"用户",role:"角色",actions:"操作",addFirst:"添加第一个用户",permissions:"权限",adminPermissions:"完全系统访问权限",userPermissions:"受限访问权限",currentUser:"当前用户",noUsers:"没有找到用户",adminRequired:"需要管理员权限才能管理用户",usernameRequired:"用户名是必需的",passwordRequired:"密码是必需的",passwordTooShort:"密码至少需要6个字符",passwordMismatch:"密码不匹配",usernamePlaceholder:"输入用户名",passwordPlaceholder:"输入密码",newPasswordPlaceholder:"留空保持当前密码",confirmPasswordPlaceholder:"确认新密码",createError:"创建用户失败",updateError:"更新用户失败",deleteError:"删除用户失败",statsError:"获取用户统计失败",deleteConfirmation:"您确定要删除用户 '{{username}}' 吗?此操作无法撤消。",confirmDelete:"删除用户",deleteWarning:"您确定要删除用户 '{{username}}' 吗?此操作无法撤消。"},Io={errors:{readonly:"演示环境无法修改数据",invalid_credentials:"用户名或密码错误",serverNameRequired:"服务器名称是必需的",serverConfigRequired:"服务器配置是必需的",serverConfigInvalid:"服务器配置必须包含 URL、OpenAPI 规范 URL 或模式,或者带参数的命令",serverTypeInvalid:"服务器类型必须是以下之一:stdio、sse、streamable-http、openapi",urlRequiredForType:"{{type}} 服务器类型需要 URL",openapiSpecRequired:"openapi 服务器类型需要 OpenAPI 规范 URL 或模式",headersInvalidFormat:"请求头必须是对象格式",headersNotSupportedForStdio:"stdio 服务器类型不支持请求头",serverNotFound:"找不到服务器",failedToRemoveServer:"找不到服务器或删除失败",internalServerError:"服务器内部错误",failedToGetServers:"获取服务器信息失败",failedToGetServerSettings:"获取服务器设置失败",failedToGetServerConfig:"获取服务器配置失败",failedToSaveSettings:"保存设置失败",toolNameRequired:"服务器名称和工具名称是必需的",descriptionMustBeString:"描述必须是字符串",groupIdRequired:"分组 ID 是必需的",groupNameRequired:"分组名称是必需的",groupNotFound:"找不到分组",groupIdAndServerNameRequired:"分组 ID 和服务器名称是必需的",groupOrServerNotFound:"找不到分组或服务器",toolsMustBeAllOrArray:'工具必须是 "all" 或字符串数组',serverNameAndToolNameRequired:"服务器名称和工具名称是必需的",usernameRequired:"用户名是必需的",userNotFound:"找不到用户",failedToGetUsers:"获取用户信息失败",failedToGetUserInfo:"获取用户信息失败",failedToGetUserStats:"获取用户统计信息失败",marketServerNameRequired:"服务器名称是必需的",marketServerNotFound:"找不到市场服务器",failedToGetMarketServers:"获取市场服务器信息失败",failedToGetMarketServer:"获取市场服务器信息失败",failedToGetMarketCategories:"获取市场类别失败",failedToGetMarketTags:"获取市场标签失败",failedToSearchMarketServers:"搜索市场服务器失败",failedToFilterMarketServers:"过滤市场服务器失败",failedToProcessMcpbFile:"处理 MCPB 文件失败"},success:{serverCreated:"服务器创建成功",serverUpdated:"服务器更新成功",serverRemoved:"服务器删除成功",serverToggled:"服务器状态切换成功",toolToggled:"工具 {{name}} {{action}} 成功",toolDescriptionUpdated:"工具 {{name}} 描述更新成功",systemConfigUpdated:"系统配置更新成功",groupCreated:"分组创建成功",groupUpdated:"分组更新成功",groupDeleted:"分组删除成功",serverAddedToGroup:"服务器添加到分组成功",serverRemovedFromGroup:"服务器从分组移除成功",serverToolsUpdated:"服务器工具更新成功"}},zo={authorizationFailed:"授权失败",authorizationFailedError:"错误",authorizationFailedDetails:"详情",invalidRequest:"无效请求",missingStateParameter:"缺少必需的 OAuth 状态参数。",missingCodeParameter:"缺少必需的授权码参数。",serverNotFound:"服务器未找到",serverNotFoundMessage:"无法找到与此授权请求关联的服务器。",sessionExpiredMessage:"授权会话可能已过期。请重新进行授权。",authorizationSuccessful:"授权成功",server:"服务器",status:"状态",connected:"已连接",successMessage:"服务器已成功授权并连接。",autoCloseMessage:"此窗口将在 3 秒后自动关闭...",closeNow:"立即关闭",connectionError:"连接错误",connectionErrorMessage:"授权成功,但连接服务器失败。",reconnectMessage:"请尝试从控制面板重新连接。",configurationError:"配置错误",configurationErrorMessage:"服务器传输不支持 OAuth finishAuth()。请确保服务器配置为 streamable-http 传输。",internalError:"内部错误",internalErrorMessage:"处理 OAuth 回调时发生意外错误。",closeWindow:"关闭窗口"},Oo={add:"添加提示词",addNew:"添加新提示词",edit:"编辑提示词",delete:"删除",noPrompts:"暂无内置提示词",addFirst:"添加第一个提示词",name:"名称",namePlaceholder:"例如 code-review",title:"标题",titlePlaceholder:"例如 代码审查提示词",description:"描述",descriptionPlaceholder:"提示词的简要描述",template:"模板",templatePlaceholder:"输入包含 {{parameter}} 占位符的模板文本...",templateHint:"使用 {{paramName}} 作为模板参数",arguments:"参数",addArgument:"添加参数",argName:"名称",argDescription:"描述",argRequired:"必填",enabled:"启用",active:"已启用",inactive:"已禁用",nameRequired:"名称为必填项",templateRequired:"模板为必填项",fetchError:"加载内置提示词失败",createError:"创建提示词失败",updateError:"更新提示词失败",deleteError:"删除提示词失败",saveError:"保存提示词失败",confirmDelete:"删除提示词",deleteWarning:'确定要删除提示词 "{{name}}" 吗?此操作无法撤销。'},Lo={add:"添加资源",addNew:"添加新资源",edit:"编辑资源",delete:"删除",noResources:"暂无内置资源",addFirst:"添加第一个资源",uri:"URI",uriPlaceholder:"例如 resource://docs/guide",name:"名称",namePlaceholder:"例如 用户指南",description:"描述",descriptionPlaceholder:"资源的简要描述",mimeType:"MIME 类型",content:"内容",contentPlaceholder:"输入资源内容...",enabled:"启用",active:"已启用",inactive:"已禁用",descriptionUpdateSuccess:"资源描述更新成功",descriptionUpdateFailed:"更新资源描述失败",restoreDefault:"恢复默认值",restoreDefaultSuccess:"资源描述已恢复为默认值",restoreDefaultFailed:"恢复默认资源描述失败",uriRequired:"URI 为必填项",contentRequired:"内容为必填项",fetchError:"加载内置资源失败",createError:"创建资源失败",updateError:"更新资源失败",deleteError:"删除资源失败",saveError:"保存资源失败",confirmDelete:"删除资源",deleteWarning:'确定要删除资源 "{{name}}" 吗?此操作无法撤销。'},Fo={title:"活动",totalCalls:"总调用次数",successCount:"成功次数",errorCount:"失败次数",avgDuration:"平均耗时",timestamp:"时间",server:"服务器",tool:"工具",duration:"耗时",status:"状态",group:"分组",key:"API密钥",input:"输入",output:"输出",details:"活动详情",errorMessage:"错误信息",searchServer:"服务器...",searchTool:"工具...",searchStatus:"状态...",searchGroup:"分组...",searchKeyName:"API密钥...",keyName:"API密钥名称",allStatus:"全部状态",statusSuccess:"成功",statusError:"失败",noData:"暂无活动数据",fetchError:"加载活动数据失败",cleanup:"清理",confirmCleanup:"确定要删除30天前的活动记录吗?",cleanupSuccess:"已删除 {{count}} 条旧记录",cleanupError:"清理旧记录失败",notAvailable:"活动跟踪功能仅在数据库模式下可用"},jo={exportButton:"导出模板",importButton:"导入模板",exportTitle:"导出配置模板",importTitle:"导入配置模板",name:"模板名称",nameRequired:"模板名称不能为空",namePlaceholder:"例如:前端开发工具",description:"描述",descriptionPlaceholder:"例如:前端开发标准 MCP 服务器集合",selectGroups:"选择分组",selectGroupsHelp:"留空则导出全部分组",selectAll:"全选",deselectAll:"取消全选",includeDisabled:"包含已禁用的服务器",exportNote:"密钥(API Key、Token、密码等)将被替换为 ${PLACEHOLDER} 占位符。接收者需要提供自己的凭据。",export:"导出",exporting:"导出中...",exportFailed:"导出模板失败",import:"导入",importing:"导入中...",importFailed:"导入模板失败",invalidFormat:"模板格式无效。必须包含 version、name、servers 和 groups 字段。",parseError:"JSON 解析失败,请检查格式后重试。",uploadFile:"上传模板文件",or:"或",pasteJson:"粘贴模板 JSON",pastePlaceholder:"在此粘贴 .mcphub-template.json 内容...",version:"版本",createdAt:"创建时间",servers:"服务器",groups:"分组",serversInGroup:"个服务器",envVarsNeeded:"所需环境变量 — 请在使用导入的服务器前设置这些变量:",importResult:"服务器:创建 {{serversCreated}} 个,跳过 {{serversSkipped}} 个。分组:创建 {{groupsCreated}} 个,跳过 {{groupsSkipped}} 个。"},Uo={app:so,about:oo,profile:no,sponsor:io,wechat:lo,discord:uo,theme:co,auth:mo,server:po,status:go,errors:ho,common:fo,pagination:vo,nav:yo,pages:bo,logs:ko,groups:So,market:Ao,oauthServer:Po,cloud:wo,registry:xo,tool:Co,prompt:Ro,settings:Eo,mcpb:To,jsonImport:No,groupImport:Do,users:Mo,api:Io,oauthCallback:zo,builtinPrompts:Oo,builtinResources:Lo,activity:Fo,template:jo},Go={title:"Tableau de bord MCPHub",error:"Erreur",closeButton:"Fermer",noServers:"Aucun serveur MCP disponible",loading:"Chargement...",logout:"Déconnexion",profile:"Profil",changePassword:"Changer le mot de passe",toggleSidebar:"Basculer la barre latérale",welcomeUser:"Bienvenue, {{username}}",name:"MCPHub",embeddingSyncProgress:"Embeddings pour {{serverName}}",embeddingSyncProgressAriaLabel:"Création des embeddings pour {{serverName}} : {{current}} sur {{total}} terminés"},Ko={title:"À propos",versionInfo:"Version MCPHub : {{version}}",newVersion:"Nouvelle version disponible !",currentVersion:"Version actuelle",newVersionAvailable:"La nouvelle version {{version}} est disponible",viewOnGitHub:"Voir sur GitHub",checkForUpdates:"Vérifier les mises à jour",checking:"Vérification des mises à jour..."},qo={viewProfile:"Voir le profil",userCenter:"Centre utilisateur"},Bo={label:"Sponsor",title:"Soutenir le projet",rewardAlt:"QR Code de récompense",supportMessage:"Soutenez le développement de MCPHub en m'offrant un café !",supportButton:"Soutenir sur Ko-fi"},Ho={label:"WeChat",title:"Se connecter via WeChat",qrCodeAlt:"QR Code WeChat",scanMessage:"Scannez ce QR code pour nous contacter sur WeChat"},Vo={label:"Discord",title:"Rejoignez notre serveur Discord",community:"Rejoignez notre communauté grandissante sur Discord pour du support, des discussions et des mises à jour !"},$o={title:"Thème",light:"Clair",dark:"Sombre",system:"Système"},_o={login:"Connexion",loginTitle:"Se connecter à MCPHub",slogan:"Le Hub unifié pour les serveurs MCP",subtitle:"Plateforme de gestion centralisée pour les serveurs Model Context Protocol. Organisez, surveillez et mettez à l'échelle plusieurs serveurs MCP avec des stratégies de routage flexibles.",username:"Nom d'utilisateur",password:"Mot de passe",loggingIn:"Connexion en cours...",orContinue:"Ou continuer avec",loginWithGoogle:"Continuer avec Google",loginWithGithub:"Continuer avec GitHub",socialLoginFailed:"La connexion sociale a échoué. Veuillez réessayer.",emptyFields:"Le nom d'utilisateur et le mot de passe ne peuvent pas être vides",loginFailed:"Échec de la connexion, veuillez vérifier votre nom d'utilisateur et votre mot de passe",loginError:"Une erreur est survenue lors de la connexion",serverUnavailable:"Impossible de se connecter au serveur. Veuillez vérifier votre connexion réseau ou réessayer plus tard",currentPassword:"Mot de passe actuel",newPassword:"Nouveau mot de passe",confirmPassword:"Confirmer le mot de passe",passwordsNotMatch:"Le nouveau mot de passe et la confirmation ne correspondent pas",changePasswordSuccess:"Mot de passe changé avec succès",changePasswordError:"Échec du changement de mot de passe",changePassword:"Changer le mot de passe",passwordChanged:"Mot de passe changé avec succès",passwordChangeError:"Échec du changement de mot de passe",defaultPasswordWarning:"Avertissement de sécurité du mot de passe par défaut",defaultPasswordMessage:"Vous utilisez le mot de passe par défaut (admin123), ce qui présente un risque de sécurité. Veuillez changer votre mot de passe immédiatement pour protéger votre compte.",goToSettings:"Aller aux paramètres",passwordStrengthError:"Le mot de passe ne répond pas aux exigences de sécurité",passwordMinLength:"Le mot de passe doit contenir au moins 8 caractères",passwordRequireLetter:"Le mot de passe doit contenir au moins une lettre",passwordRequireNumber:"Le mot de passe doit contenir au moins un chiffre",passwordRequireSpecial:"Le mot de passe doit contenir au moins un caractère spécial",passwordStrengthHint:"Le mot de passe doit contenir au moins 8 caractères et inclure des lettres, des chiffres et des caractères spéciaux"},Jo={addServer:"Ajouter un serveur",add:"Ajouter",edit:"Modifier",copy:"Copier",delete:"Supprimer",confirmDelete:"Êtes-vous sûr de vouloir supprimer ce serveur ?",deleteWarning:"La suppression du serveur '{{name}}' le supprimera ainsi que toutes ses données. Cette action est irréversible.",status:"Statut",tools:"Outils",prompts:"Invites",name:"Nom du serveur",description:"Note du serveur",descriptionPlaceholder:"Optionnel : décrivez l'utilité de ce serveur",url:"URL du serveur",apiKey:"Clé API",save:"Enregistrer",cancel:"Annuler",invalidConfig:"Impossible de trouver les données de configuration pour {{serverName}}",addError:"Échec de l'ajout du serveur",editError:"Échec de la modification du serveur {{serverName}}",deleteError:"Échec de la suppression du serveur {{serverName}}",updateError:"Échec de la mise à jour du serveur",editTitle:"Modifier le serveur : {{serverName}}",type:"Type de serveur",typeStdio:"STDIO",typeSse:"SSE",typeStreamableHttp:"HTTP diffusable",typeOpenapi:"OpenAPI",command:"Commande",arguments:"Arguments",envVars:"Variables d'environnement",headers:"En-têtes HTTP",key:"clé",value:"valeur",enabled:"Activé",enable:"Activer",disable:"Désactiver",reload:"Recharger",reloadSuccess:"Serveur rechargé avec succès",reloadError:"Échec du rechargement du serveur {{serverName}}",requestOptions:"Configuration de la connexion",timeout:"Délai d'attente de la requête",timeoutDescription:"Délai d'attente pour les requêtes vers le serveur MCP (ms)",maxTotalTimeout:"Délai d'attente total maximum",maxTotalTimeoutDescription:"Délai d'attente total maximum pour les requêtes envoyées au serveur MCP (ms) (à utiliser avec les notifications de progression)",resetTimeoutOnProgress:"Réinitialiser le délai d'attente en cas de progression",resetTimeoutOnProgressDescription:"Réinitialiser le délai d'attente lors des notifications de progression (activé par défaut)",keepAlive:"Configuration du maintien de connexion",enableKeepAlive:"Activer le maintien de connexion",keepAliveDescription:"Envoyer des requêtes ping périodiques pour maintenir la connexion. Utile pour les connexions de longue durée qui peuvent expirer.",keepAliveInterval:"Intervalle (ms)",keepAliveIntervalDescription:"Temps entre les pings de maintien de connexion en millisecondes (par défaut : 60000ms = 1 minute)",remove:"Retirer",toggleError:"Échec du basculement du serveur {{serverName}}",alreadyExists:"Le serveur {{serverName}} existe déjà",invalidData:"Données de serveur invalides fournies",notFound:"Serveur {{serverName}} non trouvé",namePlaceholder:"Entrez le nom du serveur",urlPlaceholder:"Entrez l'URL du serveur",commandPlaceholder:"Entrez la commande",argumentsPlaceholder:"Entrez les arguments",errorDetails:"Détails de l'erreur",viewErrorDetails:"Voir les détails de l'erreur",copyConfig:"Copier la configuration",confirmVariables:"Confirmer la configuration des variables",variablesDetected:"Variables détectées dans la configuration. Veuillez confirmer que ces variables sont correctement configurées :",detectedVariables:"Variables détectées",confirmVariablesMessage:"Veuillez vous assurer que ces variables sont correctement définies dans votre environnement d'exécution. Continuer l'ajout du serveur ?",confirmAndAdd:"Confirmer et ajouter",openapi:{inputMode:"Mode de saisie",inputModeUrl:"URL de la spécification",inputModeSchema:"Schéma JSON",specUrl:"URL de la spécification OpenAPI",schema:"Schéma JSON OpenAPI",schemaHelp:"Collez votre schéma JSON OpenAPI complet ici",security:"Type de sécurité",securityNone:"Aucun",securityApiKey:"Clé API",securityHttp:"Authentification HTTP",securityOAuth2:"OAuth 2.0",securityOpenIdConnect:"OpenID Connect",apiKeyConfig:"Configuration de la clé API",apiKeyName:"Nom de l'en-tête/paramètre",apiKeyIn:"Emplacement",apiKeyValue:"Valeur de la clé API",httpAuthConfig:"Configuration de l'authentification HTTP",httpScheme:"Schéma d'authentification",httpCredentials:"Identifiants",httpSchemeBasic:"Basic",httpSchemeBearer:"Bearer",httpSchemeDigest:"Digest",oauth2Config:"Configuration OAuth 2.0",oauth2Token:"Jeton d'accès",openIdConnectConfig:"Configuration OpenID Connect",openIdConnectUrl:"URL de découverte",openIdConnectToken:"Jeton d'identification",apiKeyInHeader:"En-tête",apiKeyInQuery:"Requête",apiKeyInCookie:"Cookie",passthroughHeaders:"En-têtes de transmission",passthroughHeadersHelp:"Liste séparée par des virgules des noms d’en-têtes à transmettre des requêtes MCP entrantes vers les requêtes du serveur en amont (par ex. : Authorization, X-API-Key)"},oauth:{sectionTitle:"Configuration OAuth",sectionDescription:"Configurez les identifiants client pour les serveurs protégés par OAuth (optionnel).",clientId:"Identifiant client",clientSecret:"Secret client",authorizationEndpoint:"Point de terminaison d'autorisation",tokenEndpoint:"Point de terminaison de jeton",scopes:"Scopes",scopesPlaceholder:"scope1 scope2",resource:"Ressource / Audience",accessToken:"Jeton d'accès",refreshToken:"Jeton d'actualisation"}},Wo={online:"En ligne",offline:"Hors ligne",connecting:"Connexion en cours",oauthRequired:"OAuth requis",clickToAuthorize:"Cliquez pour autoriser avec OAuth",oauthWindowOpened:"Fenêtre d'autorisation OAuth ouverte. Veuillez compléter l'autorisation."},Yo={general:"Une erreur est survenue",network:"Erreur de connexion réseau. Veuillez vérifier votre connexion Internet",serverConnection:"Impossible de se connecter au serveur. Veuillez vérifier si le serveur est en cours d'exécution",serverAdd:"Échec de l'ajout du serveur. Veuillez vérifier l'état du serveur",serverUpdate:"Échec de la modification du serveur {{serverName}}. Veuillez vérifier l'état du serveur",serverFetch:"Échec de la récupération des données du serveur. Veuillez réessayer plus tard",failedToReloadServer:"Échec du rechargement du serveur",initialStartup:"Le serveur est peut-être en cours de démarrage. Veuillez patienter un instant car ce processus peut prendre du temps au premier lancement...",serverInstall:"Échec de l'installation du serveur",failedToFetchSettings:"Échec de la récupération des paramètres",failedToUpdateRouteConfig:"Échec de la mise à jour de la configuration de routage",failedToUpdateSmartRoutingConfig:"Échec de la mise à jour de la configuration du routage intelligent"},Qo={processing:"En cours de traitement...",save:"Enregistrer",cancel:"Annuler",back:"Retour",refresh:"Actualiser",search:"Rechercher",clear:"Effacer",view:"Voir",create:"Créer",creating:"Création en cours...",update:"Mettre à jour",updating:"Mise à jour en cours...",submitting:"Envoi en cours...",delete:"Supprimer",remove:"Retirer",copy:"Copier",copyId:"Copier l'ID",copyUrl:"Copier l'URL",copyJson:"Copier le JSON",copySuccess:"Copié dans le presse-papiers",copyFailed:"Échec de la copie",copied:"Copié",close:"Fermer",confirm:"Confirmer",language:"Langue",true:"Vrai",false:"Faux",dismiss:"Rejeter",github:"GitHub",wechat:"WeChat",discord:"Discord",itemsPerPage:"Éléments par page",showing:"Affichage de {{start}}-{{end}} sur {{total}}",previous:"Précédent",next:"Suivant",required:"Requis",secret:"Secret",default:"Défaut",value:"Valeur",type:"Type",repeated:"Répété",valueHint:"Indice de valeur",choices:"Choix",actions:"Actions",saving:"Enregistrement...",active:"Actif",inactive:"Inactif",viewAll:"Voir tout",docs:"Docs",all:"Tout"},Zo={rowsPerPage:"Lignes par page",showing:"Affichage de {{from}}-{{to}} sur {{total}}"},Xo={dashboard:"Tableau de bord",servers:"Serveurs",groups:"Groupes",prompts:"Prompts",resources:"Ressources",users:"Utilisateurs",settings:"Paramètres",changePassword:"Changer le mot de passe",market:"Marché",cloud:"Marché Cloud",logs:"Journaux",activity:"Activité",workspace:"Espace de travail",system:"Système"},en={dashboard:{title:"Tableau de bord",totalServers:"Total",onlineServers:"En ligne",disabledServers:"Désactivés",offlineServers:"Hors ligne",connectingServers:"En connexion",recentServers:"Serveurs récents"},servers:{title:"Gestion des serveurs"},groups:{title:"Gestion des groupes"},prompts:{title:"Prompts intégrés"},resources:{title:"Ressources intégrées"},users:{title:"Gestion des utilisateurs"},settings:{title:"Paramètres",language:"Langue",account:"Paramètres du compte",password:"Changer le mot de passe",appearance:"Apparence",routeConfig:"Sécurité",installConfig:"Installation",smartRouting:"Routage intelligent",oauthServer:"Serveur OAuth"},market:{title:"Marché Hub - Marchés locaux et Cloud"},logs:{title:"Journaux système"}},rn={filters:"Filtres",search:"Rechercher dans les journaux...",autoScroll:"Défilement automatique",clearLogs:"Effacer les journaux",loading:"Chargement des journaux...",noLogs:"Aucun journal disponible.",noMatch:"Aucun journal ne correspond aux filtres actuels.",mainProcess:"Processus principal",childProcess:"Processus enfant",main:"Principal",child:"Enfant"},tn={add:"Ajouter",addNew:"Ajouter un nouveau groupe",edit:"Modifier le groupe",delete:"Supprimer",confirmDelete:"Êtes-vous sûr de vouloir supprimer ce groupe ?",deleteWarning:"La suppression du groupe '{{name}}' le supprimera ainsi que toutes ses associations de serveurs. Cette action est irréversible.",name:"Nom du groupe",namePlaceholder:"Entrez le nom du groupe",nameRequired:"Le nom du groupe est requis",description:"Description",descriptionPlaceholder:"Entrez la description du groupe (facultatif)",createError:"Échec de la création du groupe",updateError:"Échec de la mise à jour du groupe",deleteError:"Échec de la suppression du groupe",serverAddError:"Échec de l'ajout du serveur au groupe",serverRemoveError:"Échec de la suppression du serveur du groupe",addServer:"Ajouter un serveur au groupe",selectServer:"Sélectionnez un serveur à ajouter",servers:"Serveurs dans le groupe",remove:"Retirer",noGroups:"Aucun groupe disponible. Créez un nouveau groupe pour commencer.",noServers:"Aucun serveur dans ce groupe.",noServerOptions:"Aucun serveur disponible",serverCount:"{{count}} serveurs",toolSelection:"Sélection d'outils",promptSelection:"Sélection des prompts",resourceSelection:"Sélection des ressources",toolsSelected:"Sélectionné",promptsSelected:"Sélectionné",resourcesSelected:"Sélectionné",allTools:"Tous",allPrompts:"Tous les prompts",allResources:"Toutes les ressources",selectedTools:"Outils sélectionnés",selectedPrompts:"Prompts sélectionnés",selectedResources:"Ressources sélectionnées",selectAll:"Tout sélectionner",selectNone:"Ne rien sélectionner",configureTools:"Configurer les outils",configureCapabilities:"Configurer les outils, prompts et ressources",previewPrompts:"[prompts : {{items}}]",previewResources:"[ressources : {{items}}]",previewAllTools:"(tous les outils)",previewAllPrompts:"(tous les prompts)",previewAllResources:"(toutes les ressources)"},an={title:"Installation locale",official:"Officiel",by:"Par",unknown:"Inconnu",tools:"outils",search:"Rechercher",searchPlaceholder:"Rechercher des serveurs par nom, catégorie ou tags",clearFilters:"Effacer",clearCategoryFilter:"",clearTagFilter:"",categories:"Catégories",tags:"Tags",showTags:"Afficher les tags",hideTags:"Masquer les tags",moreTags:"",noServers:"Aucun serveur trouvé correspondant à votre recherche",backToList:"Retour à la liste",install:"Installer",installing:"Installation en cours...",installed:"Installé",installServer:"Installer le serveur : {{name}}",installSuccess:"Serveur {{serverName}} installé avec succès",author:"Auteur",license:"Licence",repository:"Dépôt",examples:"Exemples",arguments:"Arguments",argumentName:"Nom",description:"Description",required:"Requis",example:"Exemple",viewSchema:"Voir le schéma",fetchError:"Erreur lors de la récupération des serveurs du marché",serverNotFound:"Serveur non trouvé",searchError:"Erreur lors de la recherche de serveurs",filterError:"Erreur lors du filtrage des serveurs par catégorie",tagFilterError:"Erreur lors du filtrage des serveurs par tag",noInstallationMethod:"Aucune méthode d'installation disponible pour ce serveur",showing:"Affichage de {{from}}-{{to}} sur {{total}} serveurs",perPage:"Par page",confirmVariablesMessage:"Veuillez vous assurer que ces variables sont correctement définies dans votre environnement d'exécution. Continuer l'installation du serveur ?",confirmAndInstall:"Confirmer et installer"},sn={authorizeTitle:"Autoriser l'application",authorizeSubtitle:"Autorisez cette application à accéder à votre compte MCPHub.",buttons:{approve:"Autoriser l'accès",deny:"Refuser",approveSubtitle:"Recommandé si vous faites confiance à cette application.",denySubtitle:"Vous pourrez toujours accorder l'accès plus tard."}},on={title:"Support Cloud",subtitle:"Propulsé par MCPRouter",by:"Par",server:"Serveur",config:"Config",created:"Créé",updated:"Mis à jour",available:"Disponible",description:"Description",details:"Détails",tools:"Outils",tool:"outil",toolsAvailable:"{{count}} outil disponible||{{count}} outils disponibles",loadingTools:"Chargement des outils...",noTools:"Aucun outil disponible pour ce serveur",noDescription:"Aucune description disponible",viewDetails:"Voir les détails",parameters:"Paramètres",result:"Résultat",error:"Erreur",callTool:"Appeler",calling:"Appel en cours...",toolCallSuccess:"L'outil {{toolName}} a été exécuté avec succès",toolCallError:"Échec de l'appel de l'outil {{toolName}} : {{error}}",viewSchema:"Voir le schéma",backToList:"Retour au marché Cloud",search:"Rechercher",searchPlaceholder:"Rechercher des serveurs cloud par nom, titre ou auteur",clearFilters:"Effacer les filtres",clearCategoryFilter:"Effacer",clearTagFilter:"Effacer",categories:"Catégories",tags:"Tags",noCategories:"Aucune catégorie trouvée",noTags:"Aucun tag trouvé",noServers:"Aucun serveur cloud trouvé",fetchError:"Erreur lors de la récupération des serveurs cloud",serverNotFound:"Serveur cloud non trouvé",searchError:"Erreur lors de la recherche de serveurs cloud",filterError:"Erreur lors du filtrage des serveurs cloud par catégorie",tagFilterError:"Erreur lors du filtrage des serveurs cloud par tag",showing:"Affichage de {{from}}-{{to}} sur {{total}} serveurs cloud",perPage:"Par page",apiKeyNotConfigured:"Clé API MCPRouter non configurée",apiKeyNotConfiguredDescription:"Pour utiliser les serveurs cloud, vous devez configurer votre clé API MCPRouter.",getApiKey:"Obtenir une clé API",configureInSettings:"Configurer dans les paramètres",installServer:"Installer {{name}}",installSuccess:"Serveur {{name}} installé avec succès",installError:"Échec de l'installation du serveur : {{error}}"},nn={title:"Registre",official:"Officiel",latest:"Dernière version",description:"Description",website:"Site web",repository:"Dépôt",packages:"Paquets",package:"paquet",remotes:"Services distants",remote:"service distant",published:"Publié",updated:"Mis à jour",install:"Installer",installing:"Installation...",installed:"Installé",installServer:"Installer {{name}}",installSuccess:"Serveur {{name}} installé avec succès",installError:"Échec de l'installation du serveur : {{error}}",noDescription:"Aucune description disponible",viewDetails:"Voir les détails",backToList:"Retour au registre",search:"Rechercher",searchPlaceholder:"Rechercher des serveurs par nom",clearFilters:"Effacer",noServers:"Aucun serveur trouvé dans le registre",fetchError:"Erreur lors de la récupération des serveurs du registre",serverNotFound:"Serveur du registre non trouvé",showing:"Affichage de {{from}}-{{to}} sur {{total}} serveurs du registre",perPage:"Par page",environmentVariables:"Variables d'environnement",packageArguments:"Arguments du paquet",runtimeArguments:"Arguments d'exécution",headers:"En-têtes"},ln={run:"Exécuter",running:"Exécution en cours...",runTool:"Exécuter l'outil",cancel:"Annuler",noDescription:"Aucune description disponible",inputSchema:"Schéma d'entrée :",runToolWithName:"Exécuter l'outil : {{name}}",execution:"Exécution de l'outil",successful:"Réussi",failed:"Échoué",result:"Résultat :",error:"Erreur",errorDetails:"Détails de l'erreur :",noContent:"L'outil a été exécuté avec succès mais n'a renvoyé aucun contenu.",unknownError:"Une erreur inconnue est survenue",jsonResponse:"Réponse JSON :",toolResult:"Résultat de l'outil",noParameters:"Cet outil ne nécessite aucun paramètre.",selectOption:"Sélectionnez une option",enterValue:"Entrez la valeur {{type}}",enabled:"Activé",enableSuccess:"Outil {{name}} activé avec succès",disableSuccess:"Outil {{name}} désactivé avec succès",toggleFailed:"Échec du basculement de l'état de l'outil",descriptionUpdateSuccess:"Description de l'outil mise à jour avec succès",descriptionUpdateFailed:"Échec de la mise à jour de la description de l'outil",restoreDefault:"Restaurer par défaut",restoreDefaultSuccess:"La description de l'outil a été restaurée à sa valeur par défaut",restoreDefaultFailed:"Échec de la restauration de la description par défaut de l'outil",parameters:"Paramètres de l'outil",formMode:"Mode formulaire",jsonMode:"Mode JSON",jsonConfiguration:"Configuration JSON",invalidJsonFormat:"Format JSON invalide",fixJsonBeforeSwitching:"Veuillez corriger le format JSON avant de passer en mode formulaire",item:"Élément {{index}}",addItem:"Ajouter un élément {{key}}",enterKey:"Entrez {{key}}"},un={run:"Obtenir",running:"Obtention en cours...",result:"Résultat de l'invite",error:"Erreur de l'invite",execution:"Exécution de l'invite",successful:"Réussi",failed:"Échoué",errorDetails:"Détails de l'erreur :",noContent:"L'invite a été exécutée avec succès mais n'a renvoyé aucun contenu.",unknownError:"Une erreur inconnue est survenue",jsonResponse:"Réponse JSON :",description:"Description",messages:"Messages",noDescription:"Aucune description disponible",runPromptWithName:"Obtenir l'invite : {{name}}",descriptionUpdateSuccess:"Description de l'invite mise à jour avec succès",descriptionUpdateFailed:"Échec de la mise à jour de la description de l'invite",restoreDefault:"Restaurer par défaut",restoreDefaultSuccess:"La description de l'invite a été restaurée à sa valeur par défaut",restoreDefaultFailed:"Échec de la restauration de la description par défaut de l'invite"},cn=JSON.parse(`{"subtitle":"Configurez les paramètres système, l'authentification, le routage et les intégrations de serveurs MCP.","enableGlobalRoute":"Activer la route globale","enableGlobalRouteDescription":"Autoriser les connexions au point de terminaison /sse sans spécifier d'ID de groupe","enableGroupNameRoute":"Activer la route par nom de groupe","enableGroupNameRouteDescription":"Autoriser les connexions au point de terminaison /sse en utilisant les noms de groupe au lieu des ID de groupe","enableBearerAuth":"Activer l'authentification Bearer","enableBearerAuthDescription":"Exiger une authentification par jeton Bearer pour les points de terminaison MCP (activé par défaut)","bearerAuthKey":"Clé d'authentification Bearer","bearerAuthKeyDescription":"La clé d'authentification qui sera requise dans le jeton Bearer","bearerAuthKeyPlaceholder":"Entrez la clé d'authentification Bearer","bearerAuthHeaderName":"Nom de l'en-tête Bearer","bearerAuthHeaderNameDescription":"Nom de l'en-tête utilisé pour recevoir les identifiants Bearer MCP. Modifiez-le si les en-têtes transmis en amont utilisent aussi Authorization.","bearerAuthHeaderNamePlaceholder":"ex. Authorization ou X-MCP-Authorization","bearerKeysSectionTitle":"Clés","bearerKeysSectionDescription":"Gérez plusieurs clés avec différentes portées d’accès.","noBearerKeys":"Aucune clé configurée pour le moment.","bearerKeyName":"Nom","bearerKeyToken":"Jeton","bearerKeyEnabled":"Activée","bearerKeyAccessType":"Portée d’accès","bearerKeyAccessAll":"Toutes","bearerKeyAccessGroups":"Groupes","bearerKeyAccessServers":"Serveurs","bearerKeyAccessCustom":"Personnalisée","bearerKeyAllowedGroups":"Groupes autorisés","bearerKeyAllowedServers":"Serveurs autorisés","addBearerKey":"Ajouter une clé","addBearerKeyButton":"Créer","bearerKeyRequired":"Le nom et le jeton sont obligatoires","deleteBearerKeyConfirm":"Voulez-vous vraiment supprimer cette clé ?","generate":"Générer","selectGroups":"Sélectionner des groupes","selectServers":"Sélectionner des serveurs","selectAtLeastOneGroup":"Veuillez sélectionner au moins un groupe","selectAtLeastOneServer":"Veuillez sélectionner au moins un serveur","skipAuth":"Ignorer l'authentification","skipAuthDescription":"Autoriser l'accès au tableau de bord sans connexion ; les utilisateurs non authentifiés obtiennent un accès administrateur guest (n'affecte pas l'auth MCP)","jsonBodyLimit":"Limite de taille du corps JSON","jsonBodyLimitDescription":"Limite de taille des requêtes JSON Express. Les gros téléchargements de schémas OpenAPI utilisent aussi ce paramètre.","jsonBodyLimitPlaceholder":"ex. 1mb, 5mb, 1024kb","pythonIndexUrl":"URL du dépôt de paquets Python","pythonIndexUrlDescription":"Définir la variable d'environnement UV_DEFAULT_INDEX pour l'installation de paquets Python","pythonIndexUrlPlaceholder":"ex. https://pypi.org/simple","npmRegistry":"URL du registre NPM","npmRegistryDescription":"Définir la variable d'environnement npm_config_registry pour l'installation de paquets NPM","npmRegistryPlaceholder":"ex. https://registry.npmjs.org/","baseUrl":"URL de base","baseUrlDescription":"URL de base pour les requêtes MCP et les callbacks OAuth","baseUrlPlaceholder":"ex. http://localhost:3000","installConfig":"Installation","systemConfigUpdated":"Configuration système mise à jour avec succès","enableSmartRouting":"Activer le routage intelligent","enableSmartRoutingDescription":"Activer la fonctionnalité de routage intelligent pour rechercher l'outil le plus approprié en fonction de l'entrée (en utilisant le nom de groupe $smart)","dbUrl":"URL PostgreSQL (nécessite le support de pgvector)","dbUrlPlaceholder":"ex. postgresql://user:password@localhost:5432/dbname","embeddingProvider":"Fournisseur d'embeddings","openaiApiBaseUrl":"URL de base compatible OpenAI","openaiApiBaseUrlPlaceholder":"https://api.openai.com/v1","openaiApiKey":"Clé API du fournisseur LLM","openaiApiKeyPlaceholder":"Entrez la clé API du fournisseur LLM","openaiApiEmbeddingModel":"Nom du modèle d'intégration","openaiApiEmbeddingModelPlaceholder":"text-embedding-3-small","basePacingDelayMs":"Délai de pacing de base (ms)","basePacingDelayMsDescription":"Délai de base entre les requêtes d'embeddings envoyées au fournisseur. Par défaut 0 — le système gère les limites de débit automatiquement : il respecte les en-têtes Retry-After, applique un délai de 63 secondes en l'absence d'en-tête, et augmente le pacing après chaque réponse 403/429. Définissez une valeur non nulle uniquement si votre fournisseur impose un intervalle minimum fixe.","basePacingDelayMsPlaceholder":"Vide = valeur par défaut 0 ms","basePacingDelayMsAuto":"Par défaut ({{value}} ms) : la gestion des limites de débit est automatique.","basePacingDelayMsZero":"0 ms (par défaut) : la gestion des limites de débit est automatique via throttling adaptatif et logique de retry.","basePacingDelayMsOverride":"Valeur personnalisée : remplace le délai de pacing de base par défaut.","embeddingEncodingFormat":"Format d'encodage des embeddings","embeddingEncodingFormatDescription":"Format d'encodage pour les vecteurs d'embedding. Auto détectera en fonction du support du fournisseur.","embeddingEncodingFormatAuto":"Auto (Recommandé)","azureOpenaiEndpoint":"Point de terminaison Azure OpenAI","azureOpenaiEndpointPlaceholder":"https://VOTRE_NOM_DE_RESSOURCE.openai.azure.com","azureOpenaiApiKey":"Clé API Azure OpenAI","azureOpenaiApiKeyPlaceholder":"Entrez la clé API Azure OpenAI","azureOpenaiApiVersion":"Version de l'API Azure OpenAI","azureOpenaiApiVersionPlaceholder":"2024-02-15-preview","azureOpenaiEmbeddingDeployment":"Déploiement d'embeddings Azure OpenAI","azureOpenaiEmbeddingDeploymentPlaceholder":"text-embedding-3-small","azureOpenaiEmbeddingModel":"Nom du modèle d'embedding Azure","azureOpenaiEmbeddingModelDescription":"Le nom réel du modèle OpenAI déployé dans Azure (ex. text-embedding-3-small). Utilisé pour le comptage précis des tokens avant l'envoi à l'API.","azureOpenaiEmbeddingModelPlaceholder":"text-embedding-3-small","smartRoutingConfigUpdated":"Configuration du routage intelligent mise à jour avec succès","progressiveDisclosure":"Divulgation progressive","progressiveDisclosureDescription":"Lorsqu'elle est activée, search_tools renvoie uniquement les noms et descriptions des outils. Utilisez describe_tool pour obtenir le schéma complet des paramètres, réduisant ainsi l'utilisation des tokens.","embeddingMaxTokens":"Tokens max pour les embeddings","embeddingMaxTokensDescription":"Nombre maximum de tokens pour la troncature du texte avant la génération des embeddings. Laissez vide pour utiliser automatiquement la valeur par défaut du modèle. Une valeur personnalisée remplace toujours la valeur par défaut du modèle. La configuration manuelle de cette valeur est particulièrement utile lors de l'utilisation de fournisseurs LLM locaux pour éviter les erreurs de troncature.","embeddingMaxTokensPlaceholder":"Vide = automatique selon le modèle","embeddingMaxTokensAuto":"Auto : {{limit}} tokens (valeur par défaut du modèle {{model}})","embeddingMaxTokensOverride":"Cette valeur remplace la valeur par défaut du modèle.","smartRoutingRequiredFields":"L'URL de la base de données est requise pour activer le routage intelligent. Une clé API du fournisseur LLM est requise pour les fournisseurs cloud (les LLM locaux ne nécessitent généralement pas de clé API, entrez n'importe quelle valeur pour passer la validation du formulaire)","smartRoutingValidationError":"Veuillez remplir les champs obligatoires avant d'activer le routage intelligent : {{fields}}","smartRoutingWorkflow":"Flux de travail","smartRoutingWorkflowDescription":"Le prompt est vectorisé ; les top-k outils similaires sont récupérés depuis pgvector et exposés au LLM en amont.","mcpRouterConfig":"Marché Cloud","mcpRouterApiKey":"Clé API MCPRouter","mcpRouterApiKeyDescription":"Clé API pour accéder aux services du marché cloud MCPRouter","mcpRouterApiKeyPlaceholder":"Entrez la clé API MCPRouter","mcpRouterReferer":"Référent","mcpRouterRefererDescription":"En-tête Referer pour les requêtes API MCPRouter","mcpRouterRefererPlaceholder":"https://www.mcphub.app","mcpRouterTitle":"Titre","mcpRouterTitleDescription":"En-tête Title pour les requêtes API MCPRouter","mcpRouterTitlePlaceholder":"MCPHub","mcpRouterBaseUrl":"URL de base","mcpRouterBaseUrlDescription":"URL de base pour l'API MCPRouter","mcpRouterBaseUrlPlaceholder":"https://api.mcprouter.to/v1","systemSettings":"Paramètres système","nameSeparatorLabel":"Séparateur de noms","nameSeparatorDescription":"Caractère utilisé pour séparer le nom du serveur et le nom de l'outil/prompt (par défaut : -)","enableSessionRebuild":"Activer la reconstruction de session serveur","enableSessionRebuildDescription":"Lorsqu'il est activé, applique le code de reconstruction de session serveur amélioré pour une meilleure expérience de gestion de session","restartRequired":"Configuration enregistrée. Il est recommandé de redémarrer l'application pour s'assurer que tous les services chargent correctement les nouveaux paramètres.","exportMcpSettings":"Exporter les paramètres","mcpSettingsJson":"JSON des paramètres MCP","mcpSettingsJsonDescription":"Afficher, copier ou télécharger votre configuration mcp_settings.json actuelle pour la sauvegarde ou la migration vers d'autres outils","copyToClipboard":"Copier dans le presse-papiers","downloadJson":"Télécharger JSON","exportSuccess":"Paramètres exportés avec succès","exportError":"Échec de la récupération des paramètres","enableOauthServer":"Activer le serveur OAuth","enableOauthServerDescription":"Permet à MCPHub d'émettre des jetons OAuth pour les clients externes","requireClientSecret":"Exiger un secret client","requireClientSecretDescription":"Lorsque activé, les clients confidentiels doivent présenter un client secret (désactivez-le pour les clients PKCE publics)","requireState":"Exiger le paramètre state","requireStateDescription":"Refuser les demandes d'autorisation qui n'incluent pas le paramètre state","accessTokenLifetime":"Durée de vie du jeton d'accès (secondes)","accessTokenLifetimeDescription":"Durée pendant laquelle les jetons d'accès émis restent valides","accessTokenLifetimePlaceholder":"ex. 3600","refreshTokenLifetime":"Durée de vie du jeton d'actualisation (secondes)","refreshTokenLifetimeDescription":"Durée pendant laquelle les jetons d'actualisation restent valides","refreshTokenLifetimePlaceholder":"ex. 1209600","authorizationCodeLifetime":"Durée de vie du code d'autorisation (secondes)","authorizationCodeLifetimeDescription":"Temps pendant lequel les codes d'autorisation peuvent être échangés","authorizationCodeLifetimePlaceholder":"ex. 300","allowedScopes":"Scopes autorisés","allowedScopesDescription":"Liste séparée par des virgules des scopes que les utilisateurs peuvent approuver","allowedScopesPlaceholder":"ex. read, write","enableDynamicRegistration":"Activer l'enregistrement dynamique","dynamicRegistrationDescription":"Autoriser les clients conformes RFC 7591 à s'enregistrer via l'endpoint public","dynamicRegistrationAllowedGrantTypes":"Types de flux autorisés","dynamicRegistrationAllowedGrantTypesDescription":"Liste séparée par des virgules des types de flux disponibles pour les clients enregistrés dynamiquement","dynamicRegistrationAllowedGrantTypesPlaceholder":"ex. authorization_code, refresh_token","dynamicRegistrationAuth":"Exiger une authentification","dynamicRegistrationAuthDescription":"Protège l'endpoint d'enregistrement afin que seules les requêtes authentifiées puissent créer des clients","invalidNumberInput":"Veuillez saisir un nombre valide supérieur ou égal à zéro"}`),dn={upload:"Télécharger",uploadTitle:"Télécharger le bundle MCPB",dropFileHere:"Déposez votre fichier .mcpb ici",orClickToSelect:"ou cliquez pour sélectionner depuis votre ordinateur",invalidFileType:"Veuillez sélectionner un fichier .mcpb valide",noFileSelected:"Veuillez sélectionner un fichier .mcpb à télécharger",uploading:"Téléchargement en cours...",uploadFailed:"Échec du téléchargement du fichier MCPB",installServer:"Installer le serveur MCP depuis MCPB",extensionInfo:"Informations sur l'extension",name:"Nom",version:"Version",description:"Description",author:"Auteur",tools:"Outils",serverName:"Nom du serveur",serverNamePlaceholder:"Entrez un nom pour ce serveur",install:"Installer",installing:"Installation en cours...",installFailed:"Échec de l'installation du serveur depuis MCPB",serverExistsTitle:"Le serveur existe déjà",serverExistsConfirm:"Le serveur '{{serverName}}' existe déjà. Voulez-vous le remplacer par la nouvelle version ?",override:"Remplacer"},mn={button:"Importer",title:"Importer des serveurs depuis JSON",inputLabel:"Configuration JSON du serveur",inputHelp:"Collez votre configuration JSON de serveur. Prend en charge les types de serveurs STDIO, SSE et HTTP (streamable-http).",preview:"Aperçu",previewTitle:"Aperçu des serveurs à importer",import:"Importer",importing:"Importation en cours...",invalidFormat:"Format JSON invalide. Le JSON doit contenir un objet 'mcpServers'.",parseError:"Échec de l'analyse du JSON. Veuillez vérifier le format et réessayer.",addFailed:"Échec de l'ajout du serveur",importFailed:"Échec de l'importation des serveurs",partialSuccess:"{{count}} serveur(s) sur {{total}} importé(s) avec succès. Certains serveurs ont échoué :"},pn={button:"Importer",title:"Importer des groupes depuis JSON",inputLabel:"Configuration JSON des groupes",inputHelp:"Collez votre configuration JSON de groupes. Chaque groupe peut contenir une liste de serveurs.",preview:"Aperçu",previewTitle:"Aperçu des groupes à importer",import:"Importer",importing:"Importation en cours...",invalidFormat:"Format JSON invalide. Le JSON doit contenir un tableau 'groups'.",missingName:"Chaque groupe doit avoir un champ 'name'.",parseError:"Échec de l'analyse du JSON. Veuillez vérifier le format et réessayer.",addFailed:"Échec de l'ajout du groupe",importFailed:"Échec de l'importation des groupes",partialSuccess:"{{count}} groupe(s) sur {{total}} importé(s) avec succès. Certains groupes ont échoué :"},gn={add:"Ajouter un utilisateur",addNew:"Ajouter un nouvel utilisateur",edit:"Modifier l'utilisateur",delete:"Supprimer l'utilisateur",create:"Créer un utilisateur",update:"Mettre à jour l'utilisateur",username:"Nom d'utilisateur",password:"Mot de passe",newPassword:"Nouveau mot de passe",confirmPassword:"Confirmer le mot de passe",changePassword:"Changer le mot de passe",adminRole:"Administrateur",admin:"Admin",user:"Utilisateur",role:"Rôle",actions:"Actions",addFirst:"Ajoutez votre premier utilisateur",permissions:"Permissions",adminPermissions:"Accès complet au système",userPermissions:"Accès limité",currentUser:"Vous",noUsers:"Aucun utilisateur trouvé",adminRequired:"Un accès administrateur est requis pour gérer les utilisateurs",usernameRequired:"Le nom d'utilisateur est requis",passwordRequired:"Le mot de passe est requis",passwordTooShort:"Le mot de passe doit comporter au moins 6 caractères",passwordMismatch:"Les mots de passe ne correspondent pas",usernamePlaceholder:"Entrez le nom d'utilisateur",passwordPlaceholder:"Entrez le mot de passe",newPasswordPlaceholder:"Laissez vide pour conserver le mot de passe actuel",confirmPasswordPlaceholder:"Confirmez le nouveau mot de passe",createError:"Échec de la création de l'utilisateur",updateError:"Échec de la mise à jour de l'utilisateur",deleteError:"Échec de la suppression de l'utilisateur",statsError:"Échec de la récupération des statistiques utilisateur",deleteConfirmation:"Êtes-vous sûr de vouloir supprimer l'utilisateur '{{username}}' ? Cette action est irréversible.",confirmDelete:"Supprimer l'utilisateur",deleteWarning:"Êtes-vous sûr de vouloir supprimer l'utilisateur '{{username}}' ? Cette action est irréversible."},hn={errors:{readonly:"Lecture seule pour l'environnement de démonstration",invalid_credentials:"Nom d'utilisateur ou mot de passe invalide",serverNameRequired:"Le nom du serveur est requis",serverConfigRequired:"La configuration du serveur est requise",serverConfigInvalid:"La configuration du serveur doit inclure une URL, une URL de spécification OpenAPI ou un schéma, ou une commande avec des arguments",serverTypeInvalid:"Le type de serveur doit être l'un des suivants : stdio, sse, streamable-http, openapi",urlRequiredForType:"L'URL est requise pour le type de serveur {{type}}",openapiSpecRequired:"L'URL de la spécification OpenAPI ou le schéma est requis pour le type de serveur openapi",headersInvalidFormat:"Les en-têtes doivent être un objet",headersNotSupportedForStdio:"Les en-têtes ne sont pas pris en charge pour le type de serveur stdio",serverNotFound:"Serveur non trouvé",failedToRemoveServer:"Serveur non trouvé ou échec de la suppression",internalServerError:"Erreur interne du serveur",failedToGetServers:"Échec de la récupération des informations sur les serveurs",failedToGetServerSettings:"Échec de la récupération des paramètres du serveur",failedToGetServerConfig:"Échec de la récupération de la configuration du serveur",failedToSaveSettings:"Échec de l'enregistrement des paramètres",toolNameRequired:"Le nom du serveur et le nom de l'outil sont requis",descriptionMustBeString:"La description doit être une chaîne de caractères",groupIdRequired:"L'ID de groupe est requis",groupNameRequired:"Le nom du groupe est requis",groupNotFound:"Groupe non trouvé",groupIdAndServerNameRequired:"L'ID de groupe和le nom du serveur sont requis",groupOrServerNotFound:"Groupe ou serveur non trouvé",toolsMustBeAllOrArray:'Les outils doivent être "all" ou un tableau de chaînes de caractères',serverNameAndToolNameRequired:"Le nom du serveur et le nom de l'outil sont requis",usernameRequired:"Le nom d'utilisateur est requis",userNotFound:"Utilisateur non trouvé",failedToGetUsers:"Échec de la récupération des informations sur les utilisateurs",failedToGetUserInfo:"Échec de la récupération des informations sur l'utilisateur",failedToGetUserStats:"Échec de la récupération des statistiques de l'utilisateur",marketServerNameRequired:"Le nom du serveur du marché est requis",marketServerNotFound:"Serveur du marché non trouvé",failedToGetMarketServers:"Échec de la récupération des informations sur les serveurs du marché",failedToGetMarketServer:"Échec de la récupération des informations sur le serveur du marché",failedToGetMarketCategories:"Échec de la récupération des catégories du marché",failedToGetMarketTags:"Échec de la récupération des tags du marché",failedToSearchMarketServers:"Échec de la recherche des serveurs du marché",failedToFilterMarketServers:"Échec du filtrage des serveurs du marché",failedToProcessMcpbFile:"Échec du traitement du fichier MCPB"},success:{serverCreated:"Serveur créé avec succès",serverUpdated:"Serveur mis à jour avec succès",serverRemoved:"Serveur supprimé avec succès",serverToggled:"État du serveur basculé avec succès",toolToggled:"Outil {{name}} {{action}} avec succès",toolDescriptionUpdated:"Description de l'outil {{name}} mise à jour avec succès",systemConfigUpdated:"Configuration système mise à jour avec succès",groupCreated:"Groupe créé avec succès",groupUpdated:"Groupe mis à jour avec succès",groupDeleted:"Groupe supprimé avec succès",serverAddedToGroup:"Serveur ajouté au groupe avec succès",serverRemovedFromGroup:"Serveur supprimé du groupe avec succès",serverToolsUpdated:"Outils du serveur mis à jour avec succès"}},fn={authorizationFailed:"Échec de l'autorisation",authorizationFailedError:"Erreur",authorizationFailedDetails:"Détails",invalidRequest:"Requête invalide",missingStateParameter:"Paramètre d'état OAuth requis manquant.",missingCodeParameter:"Paramètre de code d'autorisation requis manquant.",serverNotFound:"Serveur introuvable",serverNotFoundMessage:"Impossible de trouver le serveur associé à cette demande d'autorisation.",sessionExpiredMessage:"La session d'autorisation a peut-être expiré. Veuillez réessayer l'autorisation.",authorizationSuccessful:"Autorisation réussie",server:"Serveur",status:"État",connected:"Connecté",successMessage:"Le serveur a été autorisé et connecté avec succès.",autoCloseMessage:"Cette fenêtre se fermera automatiquement dans 3 secondes...",closeNow:"Fermer maintenant",connectionError:"Erreur de connexion",connectionErrorMessage:"L'autorisation a réussi, mais la connexion au serveur a échoué.",reconnectMessage:"Veuillez essayer de vous reconnecter à partir du tableau de bord.",configurationError:"Erreur de configuration",configurationErrorMessage:"Le transport du serveur ne prend pas en charge OAuth finishAuth(). Veuillez vous assurer que le serveur est configuré avec le transport streamable-http.",internalError:"Erreur interne",internalErrorMessage:"Une erreur inattendue s'est produite lors du traitement du callback OAuth.",closeWindow:"Fermer la fenêtre"},vn={add:"Ajouter un prompt",addNew:"Ajouter un nouveau prompt",edit:"Modifier le prompt",delete:"Supprimer",noPrompts:"Aucun prompt intégré configuré",addFirst:"Ajoutez votre premier prompt",name:"Nom",namePlaceholder:"ex. code-review",title:"Titre",titlePlaceholder:"ex. Prompt de revue de code",description:"Description",descriptionPlaceholder:"Brève description du prompt",template:"Modèle",templatePlaceholder:"Entrez le texte du modèle avec des marqueurs {{paramètre}}...",templateHint:"Utilisez {{paramName}} pour les paramètres du modèle",arguments:"Arguments",addArgument:"Ajouter un argument",argName:"Nom",argDescription:"Description",argRequired:"Requis",enabled:"Activé",active:"Actif",inactive:"Inactif",nameRequired:"Le nom est requis",templateRequired:"Le modèle est requis",fetchError:"Échec du chargement des prompts intégrés",createError:"Échec de la création du prompt",updateError:"Échec de la mise à jour du prompt",deleteError:"Échec de la suppression du prompt",saveError:"Échec de l'enregistrement du prompt",confirmDelete:"Supprimer le prompt",deleteWarning:'Êtes-vous sûr de vouloir supprimer le prompt "{{name}}" ? Cette action est irréversible.'},yn={add:"Ajouter une ressource",addNew:"Ajouter une nouvelle ressource",edit:"Modifier la ressource",delete:"Supprimer",noResources:"Aucune ressource intégrée configurée",addFirst:"Ajoutez votre première ressource",uri:"URI",uriPlaceholder:"ex. resource://docs/guide",name:"Nom",namePlaceholder:"ex. Guide utilisateur",description:"Description",descriptionPlaceholder:"Brève description de la ressource",mimeType:"Type MIME",content:"Contenu",contentPlaceholder:"Entrez le contenu de la ressource...",enabled:"Activé",active:"Actif",inactive:"Inactif",descriptionUpdateSuccess:"Description de la ressource mise à jour avec succès",descriptionUpdateFailed:"Échec de la mise à jour de la description de la ressource",restoreDefault:"Restaurer par défaut",restoreDefaultSuccess:"La description de la ressource a été restaurée à sa valeur par défaut",restoreDefaultFailed:"Échec de la restauration de la description par défaut de la ressource",uriRequired:"L'URI est requis",contentRequired:"Le contenu est requis",fetchError:"Échec du chargement des ressources intégrées",createError:"Échec de la création de la ressource",updateError:"Échec de la mise à jour de la ressource",deleteError:"Échec de la suppression de la ressource",saveError:"Échec de l'enregistrement de la ressource",confirmDelete:"Supprimer la ressource",deleteWarning:'Êtes-vous sûr de vouloir supprimer la ressource "{{name}}" ? Cette action est irréversible.'},bn={title:"Activité",totalCalls:"Total des appels",successCount:"Réussites",errorCount:"Échecs",avgDuration:"Durée moyenne",timestamp:"Horodatage",server:"Serveur",tool:"Outil",duration:"Durée",status:"Statut",group:"Groupe",key:"Clé API",input:"Entrée",output:"Sortie",details:"Détails de l’activité",errorMessage:"Message d’erreur",searchServer:"Serveur...",searchTool:"Outil...",searchStatus:"Statut...",searchGroup:"Groupe...",searchKeyName:"Clé API...",keyName:"Nom de la clé API",allStatus:"Tous les statuts",statusSuccess:"Succès",statusError:"Erreur",noData:"Aucune activité disponible",fetchError:"Impossible de charger les données d’activité",cleanup:"Nettoyer",confirmCleanup:"Voulez-vous vraiment supprimer les activités de plus de 30 jours ?",cleanupSuccess:"{{count}} anciennes activités supprimées",cleanupError:"Échec du nettoyage des anciennes activités",notAvailable:"Le suivi des activités est disponible uniquement en mode base de données"},kn={exportButton:"Exporter le modèle",importButton:"Importer le modèle",exportTitle:"Exporter le modèle de configuration",importTitle:"Importer le modèle de configuration",name:"Nom du modèle",nameRequired:"Le nom du modèle est requis",namePlaceholder:"Ex. : Outils de développement frontend",description:"Description",descriptionPlaceholder:"Ex. : Serveurs MCP standards pour le développement frontend",selectGroups:"Sélectionner les groupes",selectGroupsHelp:"Laisser vide pour exporter tous les groupes",selectAll:"Tout sélectionner",deselectAll:"Tout désélectionner",includeDisabled:"Inclure les serveurs désactivés",exportNote:"Les secrets (clés API, tokens, mots de passe) seront remplacés par des références ${PLACEHOLDER}. Les destinataires devront fournir leurs propres identifiants.",export:"Exporter",exporting:"Exportation...",exportFailed:"Échec de l'exportation du modèle",import:"Importer",importing:"Importation...",importFailed:"Échec de l'importation du modèle",invalidFormat:"Format de modèle invalide. Doit contenir les champs version, name, servers et groups.",parseError:"Échec de l'analyse JSON. Veuillez vérifier le format et réessayer.",uploadFile:"Télécharger le fichier modèle",or:"ou",pasteJson:"Coller le JSON du modèle",pastePlaceholder:"Collez le contenu de votre fichier .mcphub-template.json ici...",version:"Version",createdAt:"Créé le",servers:"Serveurs",groups:"Groupes",serversInGroup:"serveur(s)",envVarsNeeded:"Variables d'environnement requises — définissez-les avant d'utiliser les serveurs importés :",importResult:"Serveurs : {{serversCreated}} créés, {{serversSkipped}} ignorés. Groupes : {{groupsCreated}} créés, {{groupsSkipped}} ignorés."},Sn={app:Go,about:Ko,profile:qo,sponsor:Bo,wechat:Ho,discord:Vo,theme:$o,auth:_o,server:Jo,status:Wo,errors:Yo,common:Qo,pagination:Zo,nav:Xo,pages:en,logs:rn,groups:tn,market:an,oauthServer:sn,cloud:on,registry:nn,tool:ln,prompt:un,settings:cn,mcpb:dn,jsonImport:mn,groupImport:pn,users:gn,api:hn,oauthCallback:fn,builtinPrompts:vn,builtinResources:yn,activity:bn,template:kn},An={title:"MCPHub Kontrol Paneli",error:"Hata",closeButton:"Kapat",noServers:"Kullanılabilir MCP sunucusu yok",loading:"Yükleniyor...",logout:"Çıkış Yap",profile:"Profil",changePassword:"Şifre Değiştir",toggleSidebar:"Kenar Çubuğunu Aç/Kapat",welcomeUser:"Hoş geldin, {{username}}",name:"MCPHub",embeddingSyncProgress:"{{serverName}} için gömme oluşturuluyor",embeddingSyncProgressAriaLabel:"{{serverName}} için gömme oluşturuluyor: {{total}} adımdan {{current}} tamamlandı"},Pn={title:"Hakkında",versionInfo:"MCPHub Sürümü: {{version}}",newVersion:"Yeni sürüm mevcut!",currentVersion:"Mevcut sürüm",newVersionAvailable:"Yeni sürüm {{version}} mevcut",viewOnGitHub:"GitHub'da Görüntüle",checkForUpdates:"Güncellemeleri Kontrol Et",checking:"Güncellemeler kontrol ediliyor..."},wn={viewProfile:"Profili görüntüle",userCenter:"Kullanıcı Merkezi"},xn={label:"Sponsor",title:"Projeyi Destekle",rewardAlt:"Ödül QR Kodu",supportMessage:"Bana bir kahve ısmarlayarak MCPHub'ın geliştirilmesini destekleyin!",supportButton:"Ko-fi'de Destek Ol"},Cn={label:"WeChat",title:"WeChat ile Bağlan",qrCodeAlt:"WeChat QR Kodu",scanMessage:"WeChat'te bizimle bağlantı kurmak için bu QR kodunu tarayın"},Rn={label:"Discord",title:"Discord sunucumuza katılın",community:"Destek, tartışmalar ve güncellemeler için büyüyen Discord topluluğumuza katılın!"},En={title:"Tema",light:"Açık",dark:"Koyu",system:"Sistem"},Tn={login:"Giriş Yap",loginTitle:"MCPHub'a Giriş Yap",slogan:"Birleşik MCP sunucu yönetim platformu",subtitle:"Model Context Protocol sunucuları için merkezi yönetim platformu. Esnek yönlendirme stratejileri ile birden fazla MCP sunucusunu organize edin, izleyin ve ölçeklendirin.",username:"Kullanıcı Adı",password:"Şifre",loggingIn:"Giriş yapılıyor...",orContinue:"Veya şununla devam et",loginWithGoogle:"Google ile devam et",loginWithGithub:"GitHub ile devam et",socialLoginFailed:"Sosyal giriş başarısız oldu. Lütfen tekrar deneyin.",emptyFields:"Kullanıcı adı ve şifre boş olamaz",loginFailed:"Giriş başarısız, lütfen kullanıcı adınızı ve şifrenizi kontrol edin",loginError:"Giriş sırasında bir hata oluştu",serverUnavailable:"Sunucuya bağlanılamıyor. Lütfen ağ bağlantınızı kontrol edin veya daha sonra tekrar deneyin",currentPassword:"Mevcut Şifre",newPassword:"Yeni Şifre",confirmPassword:"Şifreyi Onayla",passwordsNotMatch:"Yeni şifre ve onay eşleşmiyor",changePasswordSuccess:"Şifre başarıyla değiştirildi",changePasswordError:"Şifre değişikliği başarısız oldu",changePassword:"Şifre Değiştir",passwordChanged:"Şifre başarıyla değiştirildi",passwordChangeError:"Şifre değişikliği başarısız oldu",defaultPasswordWarning:"Varsayılan Şifre Güvenlik Uyarısı",defaultPasswordMessage:"Varsayılan şifreyi (admin123) kullanıyorsunuz, bu bir güvenlik riski oluşturur. Hesabınızı korumak için lütfen şifrenizi hemen değiştirin.",goToSettings:"Ayarlara Git",passwordStrengthError:"Şifre güvenlik gereksinimlerini karşılamıyor",passwordMinLength:"Şifre en az 8 karakter uzunluğunda olmalıdır",passwordRequireLetter:"Şifre en az bir harf içermelidir",passwordRequireNumber:"Şifre en az bir rakam içermelidir",passwordRequireSpecial:"Şifre en az bir özel karakter içermelidir",passwordStrengthHint:"Şifre en az 8 karakter olmalı ve harf, rakam ve özel karakter içermelidir"},Nn={addServer:"Sunucu Ekle",add:"Ekle",edit:"Düzenle",copy:"Kopyala",delete:"Sil",confirmDelete:"Bu sunucuyu silmek istediğinizden emin misiniz?",deleteWarning:"'{{name}}' sunucusunu silmek, onu ve tüm verilerini kaldıracaktır. Bu işlem geri alınamaz.",status:"Durum",tools:"Araçlar",prompts:"İstekler",name:"Sunucu Adı",description:"Sunucu Notu",descriptionPlaceholder:"İsteğe bağlı: Bu sunucunun ne işe yaradığını yazın",url:"Sunucu URL'si",apiKey:"API Anahtarı",save:"Kaydet",cancel:"İptal",invalidConfig:"{{serverName}} için yapılandırma verisi bulunamadı",addError:"Sunucu eklenemedi",editError:"{{serverName}} sunucusu düzenlenemedi",deleteError:"{{serverName}} sunucusu silinemedi",updateError:"Sunucu güncellenemedi",editTitle:"Sunucuyu Düzenle: {{serverName}}",type:"Sunucu Türü",typeStdio:"STDIO",typeSse:"SSE",typeStreamableHttp:"Akış Yapılabilir HTTP",typeOpenapi:"OpenAPI",command:"Komut",arguments:"Argümanlar",envVars:"Ortam Değişkenleri",headers:"HTTP Başlıkları",key:"anahtar",value:"değer",enabled:"Etkin",enable:"Etkinleştir",disable:"Devre Dışı Bırak",reload:"Yeniden Yükle",reloadSuccess:"Sunucu başarıyla yeniden yüklendi",reloadError:"Sunucu {{serverName}} yeniden yüklenemedi",requestOptions:"Bağlantı Yapılandırması",timeout:"İstek Zaman Aşımı",timeoutDescription:"MCP sunucusuna yapılan istekler için zaman aşımı (ms)",maxTotalTimeout:"Maksimum Toplam Zaman Aşımı",maxTotalTimeoutDescription:"MCP sunucusuna gönderilen istekler için maksimum toplam zaman aşımı (ms) (İlerleme bildirimleriyle kullanın)",resetTimeoutOnProgress:"İlerlemede Zaman Aşımını Sıfırla",resetTimeoutOnProgressDescription:"İlerleme bildirimlerinde zaman aşımını sıfırla (varsayılan olarak etkin)",keepAlive:"Bağlantı Canlı Tutma Yapılandırması",enableKeepAlive:"Bağlantı Canlı Tutmayı Etkinleştir",keepAliveDescription:"Bağlantıyı korumak için periyodik ping istekleri gönderin. Zaman aşımına uğrayabilecek uzun süreli bağlantılar için yararlıdır.",keepAliveInterval:"Aralık (ms)",keepAliveIntervalDescription:"Canlı tutma pingleri arasındaki süre milisaniye cinsinden (varsayılan: 60000ms = 1 dakika)",remove:"Kaldır",toggleError:"{{serverName}} sunucusu açılamadı/kapatılamadı",alreadyExists:"{{serverName}} sunucusu zaten mevcut",invalidData:"Geçersiz sunucu verisi sağlandı",notFound:"{{serverName}} sunucusu bulunamadı",namePlaceholder:"Sunucu adını girin",urlPlaceholder:"Sunucu URL'sini girin",commandPlaceholder:"Komutu girin",argumentsPlaceholder:"Argümanları girin",errorDetails:"Hata Detayları",viewErrorDetails:"Hata detaylarını görüntüle",copyConfig:"Yapılandırmayı Kopyala",confirmVariables:"Değişken Yapılandırmasını Onayla",variablesDetected:"Yapılandırmada değişkenler algılandı. Lütfen bu değişkenlerin düzgün yapılandırıldığını onaylayın:",detectedVariables:"Algılanan Değişkenler",confirmVariablesMessage:"Lütfen bu değişkenlerin çalışma ortamınızda düzgün tanımlandığından emin olun. Sunucu eklemeye devam edilsin mi?",confirmAndAdd:"Onayla ve Ekle",openapi:{inputMode:"Giriş Modu",inputModeUrl:"Şartname URL'si",inputModeSchema:"JSON Şeması",specUrl:"OpenAPI Şartname URL'si",schema:"OpenAPI JSON Şeması",schemaHelp:"Eksiksiz OpenAPI JSON şemanızı buraya yapıştırın",security:"Güvenlik Türü",securityNone:"Yok",securityApiKey:"API Anahtarı",securityHttp:"HTTP Kimlik Doğrulaması",securityOAuth2:"OAuth 2.0",securityOpenIdConnect:"OpenID Connect",apiKeyConfig:"API Anahtarı Yapılandırması",apiKeyName:"Başlık/Parametre Adı",apiKeyIn:"Konum",apiKeyValue:"API Anahtarı Değeri",httpAuthConfig:"HTTP Kimlik Doğrulama Yapılandırması",httpScheme:"Kimlik Doğrulama Şeması",httpCredentials:"Kimlik Bilgileri",httpSchemeBasic:"Basit",httpSchemeBearer:"Bearer",httpSchemeDigest:"Digest",oauth2Config:"OAuth 2.0 Yapılandırması",oauth2Token:"Erişim Anahtarı",openIdConnectConfig:"OpenID Connect Yapılandırması",openIdConnectUrl:"URL'yi Keşfet",openIdConnectToken:"ID Token",apiKeyInHeader:"Başlık",apiKeyInQuery:"Sorgu",apiKeyInCookie:"Çerez",passthroughHeaders:"Geçiş Başlıkları",passthroughHeadersHelp:"Gelen MCP isteklerinden yukarı akış sunucu isteklerine geçirilecek başlık adlarının virgülle ayrılmış listesi (örn. Authorization, X-API-Key)"},oauth:{sectionTitle:"OAuth Yapılandırması",sectionDescription:"OAuth korumalı sunucular için istemci kimlik bilgilerini yapılandırın (isteğe bağlı).",clientId:"İstemci ID",clientSecret:"İstemci Gizli Anahtarı",authorizationEndpoint:"Yetkilendirme Uç Noktası",tokenEndpoint:"Token Uç Noktası",scopes:"Kapsamlar",scopesPlaceholder:"scope1 scope2",resource:"Kaynak / Hedef Kitle",accessToken:"Erişim Tokeni",refreshToken:"Yenileme Tokeni"}},Dn={online:"Çevrimiçi",offline:"Çevrimdışı",connecting:"Bağlanıyor",oauthRequired:"OAuth Gerekli",clickToAuthorize:"OAuth ile yetkilendirmek için tıklayın",oauthWindowOpened:"OAuth yetkilendirme penceresi açıldı. Lütfen yetkilendirmeyi tamamlayın."},Mn={general:"Bir şeyler yanlış gitti",network:"Ağ bağlantı hatası. Lütfen internet bağlantınızı kontrol edin",serverConnection:"Sunucuya bağlanılamıyor. Lütfen sunucunun çalışıp çalışmadığını kontrol edin",serverAdd:"Sunucu eklenemedi. Lütfen sunucu durumunu kontrol edin",serverUpdate:"{{serverName}} sunucusu düzenlenemedi. Lütfen sunucu durumunu kontrol edin",serverFetch:"Sunucu verileri alınamadı. Lütfen daha sonra tekrar deneyin",failedToReloadServer:"Sunucu yeniden yüklenemedi",initialStartup:"Sunucu başlatılıyor olabilir. İlk başlatmada bu işlem biraz zaman alabileceğinden lütfen bekleyin...",serverInstall:"Sunucu yüklenemedi",failedToFetchSettings:"Ayarlar getirilemedi",failedToUpdateRouteConfig:"Route yapılandırması güncellenemedi",failedToUpdateSmartRoutingConfig:"Akıllı yönlendirme yapılandırması güncellenemedi"},In={processing:"İşleniyor...",save:"Kaydet",cancel:"İptal",back:"Geri",refresh:"Yenile",search:"Ara",clear:"Temizle",view:"Görüntüle",create:"Oluştur",creating:"Oluşturuluyor...",update:"Güncelle",updating:"Güncelleniyor...",submitting:"Gönderiliyor...",delete:"Sil",remove:"Kaldır",copy:"Kopyala",copyId:"ID'yi Kopyala",copyUrl:"URL'yi Kopyala",copyJson:"JSON'u Kopyala",copySuccess:"Panoya kopyalandı",copyFailed:"Kopyalama başarısız",copied:"Kopyalandı",close:"Kapat",confirm:"Onayla",language:"Dil",true:"Doğru",false:"Yanlış",dismiss:"Anımsatma",github:"GitHub",wechat:"WeChat",discord:"Discord",itemsPerPage:"Sayfa başına öğe",showing:"{{total}} öğeden {{start}}-{{end}} gösteriliyor",previous:"Önceki",next:"Sonraki",required:"Gerekli",secret:"Gizli",default:"Varsayılan",value:"Değer",type:"Tür",repeated:"Tekrarlanan",valueHint:"Değer İpucu",choices:"Seçenekler",actions:"Eylemler",saving:"Kaydediliyor...",active:"Aktif",inactive:"Pasif",viewAll:"Tümünü gör",docs:"Belgeler",all:"Tümü"},zn={rowsPerPage:"Sayfa başına satır",showing:"Toplam {{total}} öğeden {{from}}-{{to}} gösteriliyor"},On={dashboard:"Kontrol Paneli",servers:"Sunucular",groups:"Gruplar",prompts:"Promptlar",resources:"Kaynaklar",users:"Kullanıcılar",settings:"Ayarlar",changePassword:"Şifre Değiştir",market:"Market",cloud:"Bulut Market",logs:"Günlükler",activity:"Etkinlik",workspace:"Çalışma Alanı",system:"Sistem"},Ln={dashboard:{title:"Kontrol Paneli",totalServers:"Toplam",onlineServers:"Çevrimiçi",disabledServers:"Devre Dışı",offlineServers:"Çevrimdışı",connectingServers:"Bağlanıyor",recentServers:"Son Sunucular"},servers:{title:"Sunucu Yönetimi"},groups:{title:"Grup Yönetimi"},prompts:{title:"Yerleşik Promptlar"},resources:{title:"Yerleşik Kaynaklar"},users:{title:"Kullanıcı Yönetimi"},settings:{title:"Ayarlar",language:"Dil",account:"Hesap Ayarları",password:"Şifre Değiştir",appearance:"Görünüm",routeConfig:"Güvenlik",installConfig:"Kurulum",smartRouting:"Akıllı Yönlendirme",oauthServer:"OAuth Sunucusu"},market:{title:"Market Yönetimi - Yerel ve Bulut Marketler"},logs:{title:"Sistem Günlükleri"}},Fn={filters:"Filtreler",search:"Günlüklerde ara...",autoScroll:"Otomatik kaydır",clearLogs:"Günlükleri temizle",loading:"Günlükler yükleniyor...",noLogs:"Kullanılabilir günlük yok.",noMatch:"Mevcut filtrelerle eşleşen günlük yok.",mainProcess:"Ana İşlem",childProcess:"Alt İşlem",main:"Ana",child:"Alt"},jn={add:"Ekle",addNew:"Yeni Grup Ekle",edit:"Grubu Düzenle",delete:"Sil",confirmDelete:"Bu grubu silmek istediğinizden emin misiniz?",deleteWarning:"'{{name}}' grubunu silmek, onu ve tüm sunucu ilişkilerini kaldıracaktır. Bu işlem geri alınamaz.",name:"Grup Adı",namePlaceholder:"Grup adını girin",nameRequired:"Grup adı gereklidir",description:"Açıklama",descriptionPlaceholder:"Grup açıklamasını girin (isteğe bağlı)",createError:"Grup oluşturulamadı",updateError:"Grup güncellenemedi",deleteError:"Grup silinemedi",serverAddError:"Sunucu gruba eklenemedi",serverRemoveError:"Sunucu gruptan kaldırılamadı",addServer:"Gruba Sunucu Ekle",selectServer:"Eklenecek bir sunucu seçin",servers:"Gruptaki Sunucular",remove:"Kaldır",noGroups:"Kullanılabilir grup yok. Başlamak için yeni bir grup oluşturun.",noServers:"Bu grupta sunucu yok.",noServerOptions:"Kullanılabilir sunucu yok",serverCount:"{{count}} Sunucu",toolSelection:"Araç Seçimi",promptSelection:"İstem Seçimi",resourceSelection:"Kaynak Seçimi",toolsSelected:"Seçildi",promptsSelected:"Seçildi",resourcesSelected:"Seçildi",allTools:"Tümü",allPrompts:"Tüm istemler",allResources:"Tüm kaynaklar",selectedTools:"Seçili araçlar",selectedPrompts:"Seçili istemler",selectedResources:"Seçili kaynaklar",selectAll:"Tümünü Seç",selectNone:"Hiçbirini Seçme",configureTools:"Araçları Yapılandır",configureCapabilities:"Araçları, istemleri ve kaynakları yapılandır",previewPrompts:"[istemler: {{items}}]",previewResources:"[kaynaklar: {{items}}]",previewAllTools:"(tüm araçlar)",previewAllPrompts:"(tüm istemler)",previewAllResources:"(tüm kaynaklar)"},Un={title:"Yerel Kurulum",official:"Resmi",by:"Geliştirici",unknown:"Bilinmeyen",tools:"araçlar",search:"Ara",searchPlaceholder:"Sunucuları isme, kategoriye veya etiketlere göre ara",clearFilters:"Temizle",clearCategoryFilter:"",clearTagFilter:"",categories:"Kategoriler",tags:"Etiketler",showTags:"Etiketleri göster",hideTags:"Etiketleri gizle",moreTags:"",noServers:"Aramanızla eşleşen sunucu bulunamadı",backToList:"Listeye dön",install:"Yükle",installing:"Yükleniyor...",installed:"Yüklendi",installServer:"Sunucu Yükle: {{name}}",installSuccess:"{{serverName}} sunucusu başarıyla yüklendi",author:"Yazar",license:"Lisans",repository:"Depo",examples:"Örnekler",arguments:"Argümanlar",argumentName:"Ad",description:"Açıklama",required:"Gerekli",example:"Örnek",viewSchema:"Şemayı görüntüle",fetchError:"Market sunucuları getirilirken hata",serverNotFound:"Sunucu bulunamadı",searchError:"Sunucular aranırken hata",filterError:"Sunucular kategoriye göre filtrelenirken hata",tagFilterError:"Sunucular etikete göre filtrelenirken hata",noInstallationMethod:"Bu sunucu için kullanılabilir kurulum yöntemi yok",showing:"{{total}} sunucudan {{from}}-{{to}} arası gösteriliyor",perPage:"Sayfa başına",confirmVariablesMessage:"Lütfen bu değişkenlerin çalışma ortamınızda düzgün tanımlandığından emin olun. Sunucu yüklemeye devam edilsin mi?",confirmAndInstall:"Onayla ve Yükle"},Gn={authorizeTitle:"Uygulamayı Yetkilendir",authorizeSubtitle:"Bu uygulamanın MCPHub hesabınıza erişmesine izin verin.",buttons:{approve:"Erişime izin ver",deny:"Reddet",approveSubtitle:"Bu uygulamaya güveniyorsanız izin vermeniz önerilir.",denySubtitle:"İstediğiniz zaman daha sonra erişim verebilirsiniz."}},Kn={title:"Bulut Desteği",subtitle:"MCPRouter tarafından desteklenmektedir",by:"Geliştirici",server:"Sunucu",config:"Yapılandırma",created:"Oluşturuldu",updated:"Güncellendi",available:"Kullanılabilir",description:"Açıklama",details:"Detaylar",tools:"Araçlar",tool:"araç",toolsAvailable:"{{count}} araç mevcut",loadingTools:"Araçlar yükleniyor...",noTools:"Bu sunucu için kullanılabilir araç yok",noDescription:"Kullanılabilir açıklama yok",viewDetails:"Detayları Görüntüle",parameters:"Parametreler",result:"Sonuç",error:"Hata",callTool:"Çalıştır",calling:"Çalıştırılıyor...",toolCallSuccess:"{{toolName}} aracı başarıyla çalıştırıldı",toolCallError:"{{toolName}} aracı çalıştırılamadı: {{error}}",viewSchema:"Şemayı Görüntüle",backToList:"Bulut Market'e Dön",search:"Ara",searchPlaceholder:"Bulut sunucularını isme, başlığa veya geliştiriciye göre ara",clearFilters:"Filtreleri Temizle",clearCategoryFilter:"Temizle",clearTagFilter:"Temizle",categories:"Kategoriler",tags:"Etiketler",noCategories:"Kategori bulunamadı",noTags:"Etiket bulunamadı",noServers:"Bulut sunucusu bulunamadı",fetchError:"Bulut sunucuları getirilirken hata",serverNotFound:"Bulut sunucusu bulunamadı",searchError:"Bulut sunucuları aranırken hata",filterError:"Bulut sunucuları kategoriye göre filtrelenirken hata",tagFilterError:"Bulut sunucuları etikete göre filtrelenirken hata",showing:"{{total}} bulut sunucusundan {{from}}-{{to}} arası gösteriliyor",perPage:"Sayfa başına",apiKeyNotConfigured:"MCPRouter API anahtarı yapılandırılmamış",apiKeyNotConfiguredDescription:"Bulut sunucularını kullanmak için MCPRouter API anahtarınızı yapılandırmanız gerekir.",getApiKey:"API Anahtarı Al",configureInSettings:"Ayarlarda Yapılandır",installServer:"{{name}} Yükle",installSuccess:"{{name}} sunucusu başarıyla yüklendi",installError:"Sunucu yüklenemedi: {{error}}"},qn={title:"Kayıt",official:"Resmi",latest:"En Son",description:"Açıklama",website:"Web Sitesi",repository:"Depo",packages:"Paketler",package:"paket",remotes:"Uzak Sunucular",remote:"uzak sunucu",published:"Yayınlandı",updated:"Güncellendi",install:"Yükle",installing:"Yükleniyor...",installed:"Yüklendi",installServer:"{{name}} Yükle",installSuccess:"{{name}} sunucusu başarıyla yüklendi",installError:"Sunucu yüklenemedi: {{error}}",noDescription:"Kullanılabilir açıklama yok",viewDetails:"Detayları Görüntüle",backToList:"Kayda Dön",search:"Ara",searchPlaceholder:"Kayıt sunucularını isme göre ara",clearFilters:"Temizle",noServers:"Kayıt sunucusu bulunamadı",fetchError:"Kayıt sunucuları getirilirken hata",serverNotFound:"Kayıt sunucusu bulunamadı",showing:"{{total}} kayıt sunucusundan {{from}}-{{to}} arası gösteriliyor",perPage:"Sayfa başına",environmentVariables:"Ortam Değişkenleri",packageArguments:"Paket Argümanları",runtimeArguments:"Çalışma Zamanı Argümanları",headers:"Başlıklar"},Bn={run:"Çalıştır",running:"Çalıştırılıyor...",runTool:"Aracı Çalıştır",cancel:"İptal",noDescription:"Kullanılabilir açıklama yok",inputSchema:"Giriş Şeması:",runToolWithName:"Aracı Çalıştır: {{name}}",execution:"Araç Çalıştırma",successful:"Başarılı",failed:"Başarısız",result:"Sonuç:",error:"Hata",errorDetails:"Hata Detayları:",noContent:"Araç başarıyla çalıştırıldı ancak içerik döndürmedi.",unknownError:"Bilinmeyen hata oluştu",jsonResponse:"JSON Yanıtı:",toolResult:"Araç sonucu",noParameters:"Bu araç herhangi bir parametre gerektirmez.",selectOption:"Bir seçenek seçin",enterValue:"{{type}} değeri girin",enabled:"Etkin",enableSuccess:"{{name}} aracı başarıyla etkinleştirildi",disableSuccess:"{{name}} aracı başarıyla devre dışı bırakıldı",toggleFailed:"Araç durumu değiştirilemedi",descriptionUpdateSuccess:"Araç açıklaması başarıyla güncellendi",descriptionUpdateFailed:"Araç açıklaması güncellenemedi",restoreDefault:"Varsayılana dön",restoreDefaultSuccess:"Araç açıklaması varsayılan değere döndürüldü",restoreDefaultFailed:"Varsayılan araç açıklamasına dönülemedi",parameters:"Araç Parametreleri",formMode:"Form Modu",jsonMode:"JSON Modu",jsonConfiguration:"JSON Yapılandırması",invalidJsonFormat:"Geçersiz JSON formatı",fixJsonBeforeSwitching:"Form moduna geçmeden önce lütfen JSON formatını düzeltin",item:"Öğe {{index}}",addItem:"{{key}} öğesi ekle",enterKey:"{{key}} girin"},Hn={run:"Getir",running:"Getiriliyor...",result:"İstek Sonucu",error:"İstek Hatası",execution:"İstek Çalıştırma",successful:"Başarılı",failed:"Başarısız",errorDetails:"Hata Detayları:",noContent:"İstek başarıyla çalıştırıldı ancak içerik döndürmedi.",unknownError:"Bilinmeyen hata oluştu",jsonResponse:"JSON Yanıtı:",description:"Açıklama",messages:"Mesajlar",noDescription:"Kullanılabilir açıklama yok",runPromptWithName:"İsteği Getir: {{name}}",descriptionUpdateSuccess:"İstek açıklaması başarıyla güncellendi",descriptionUpdateFailed:"İstek açıklaması güncellenemedi",restoreDefault:"Varsayılana dön",restoreDefaultSuccess:"İstek açıklaması varsayılan değere döndürüldü",restoreDefaultFailed:"Varsayılan istek açıklamasına dönülemedi"},Vn=JSON.parse(`{"subtitle":"Sistem ayarlarını, kimlik doğrulamayı, yönlendirmeyi ve MCP sunucu entegrasyonlarını yapılandırın.","enableGlobalRoute":"Global Yönlendirmeyi Etkinleştir","enableGlobalRouteDescription":"Grup ID'si belirtmeden /sse uç noktasına bağlantıya izin ver","enableGroupNameRoute":"Grup Adı Yönlendirmeyi Etkinleştir","enableGroupNameRouteDescription":"Sadece grup ID'leri yerine grup adları kullanarak /sse uç noktasına bağlantıya izin ver","enableBearerAuth":"Bearer Kimlik Doğrulamasını Etkinleştir","enableBearerAuthDescription":"MCP uç noktaları için bearer token kimlik doğrulaması gerektirir (varsayılan açık)","bearerAuthKey":"Bearer Kimlik Doğrulama Anahtarı","bearerAuthKeyDescription":"Bearer token'da gerekli olacak kimlik doğrulama anahtarı","bearerAuthKeyPlaceholder":"Bearer kimlik doğrulama anahtarını girin","bearerAuthHeaderName":"Bearer Kimlik Doğrulama Başlığı","bearerAuthHeaderNameDescription":"MCP bearer kimlik bilgilerinin alınacağı başlık adı. Yukarı akış passthrough başlıkları da Authorization kullanıyorsa bunu değiştirin.","bearerAuthHeaderNamePlaceholder":"örn. Authorization veya X-MCP-Authorization","bearerKeysSectionTitle":"Anahtarlar","bearerKeysSectionDescription":"Farklı erişim kapsamlarına sahip birden fazla anahtarı yönetin.","noBearerKeys":"Henüz yapılandırılmış herhangi bir anahtar yok.","bearerKeyName":"Ad","bearerKeyToken":"Token","bearerKeyEnabled":"Etkin","bearerKeyAccessType":"Erişim kapsamı","bearerKeyAccessAll":"Tümü","bearerKeyAccessGroups":"Gruplar","bearerKeyAccessServers":"Sunucular","bearerKeyAccessCustom":"Özel","bearerKeyAllowedGroups":"İzin verilen gruplar","bearerKeyAllowedServers":"İzin verilen sunucular","addBearerKey":"Anahtar ekle","addBearerKeyButton":"Oluştur","bearerKeyRequired":"Ad ve token zorunludur","deleteBearerKeyConfirm":"Bu anahtarı silmek istediğinizden emin misiniz?","generate":"Oluştur","selectGroups":"Grupları Seç","selectServers":"Sunucuları Seç","selectAtLeastOneGroup":"Lütfen en az bir grup seçin","selectAtLeastOneServer":"Lütfen en az bir sunucu seçin","skipAuth":"Kimlik Doğrulamayı Atla","skipAuthDescription":"Kontrol paneline giriş olmadan erişime izin ver; kimliği doğrulanmamış kullanıcılar guest yönetici erişimi alır (MCP kimlik doğrulamasını etkilemez)","jsonBodyLimit":"JSON Gövde Boyutu Sınırı","jsonBodyLimitDescription":"Express JSON istek boyutu sınırı. Büyük OpenAPI şema yüklemeleri de bu ayardan etkilenir.","jsonBodyLimitPlaceholder":"örn. 1mb, 5mb, 1024kb","pythonIndexUrl":"Python Paket Deposu URL'si","pythonIndexUrlDescription":"Python paket kurulumu için UV_DEFAULT_INDEX ortam değişkenini ayarla","pythonIndexUrlPlaceholder":"örn. https://pypi.org/simple","npmRegistry":"NPM Kayıt URL'si","npmRegistryDescription":"NPM paket kurulumu için npm_config_registry ortam değişkenini ayarla","npmRegistryPlaceholder":"örn. https://registry.npmjs.org/","baseUrl":"Temel URL","baseUrlDescription":"MCP istekleri ve OAuth geri çağrıları için temel URL","baseUrlPlaceholder":"örn. http://localhost:3000","installConfig":"Kurulum","systemConfigUpdated":"Sistem yapılandırması başarıyla güncellendi","enableSmartRouting":"Akıllı Yönlendirmeyi Etkinleştir","enableSmartRoutingDescription":"Girdiye göre en uygun aracı aramak için akıllı yönlendirme özelliğini etkinleştir ($smart grup adını kullanarak)","dbUrl":"PostgreSQL URL'si (pgvector desteği gerektirir)","dbUrlPlaceholder":"örn. postgresql://kullanıcı:şifre@localhost:5432/veritabanıadı","embeddingProvider":"Embedding Sağlayıcısı","openaiApiBaseUrl":"OpenAI uyumlu Temel URL","openaiApiBaseUrlPlaceholder":"https://api.openai.com/v1","openaiApiKey":"LLM Sağlayıcı API Anahtarı","openaiApiKeyPlaceholder":"LLM sağlayıcı API anahtarını girin","openaiApiEmbeddingModel":"Entegrasyon Modeli Adı","openaiApiEmbeddingModelPlaceholder":"text-embedding-3-small","basePacingDelayMs":"Temel pacing gecikmesi (ms)","basePacingDelayMsDescription":"Sağlayıcıya gönderilen embedding istekleri arasındaki temel bekleme süresi. Varsayılan 0 — sistem hız sınırlarını otomatik olarak yönetir: Retry-After başlıklarına uyar, başlık yoksa 63 saniyelik bekleme uygular ve her 403/429 yanıtından sonra pacing gecikmesini artırır. Yalnızca sağlayıcınız sabit bir minimum aralık gerektiriyorsa sıfırdan farklı bir değer ayarlayın.","basePacingDelayMsPlaceholder":"Boş = varsayılan 0 ms","basePacingDelayMsAuto":"Varsayılan ({{value}} ms): hız sınırı yönetimi otomatiktir.","basePacingDelayMsZero":"0 ms (varsayılan): hız sınırı yönetimi, uyarlanabilir pacing ve retry mantığı aracılığıyla otomatik olarak yapılır.","basePacingDelayMsOverride":"Özel değer: varsayılan temel pacing gecikmesini geçersiz kılar.","embeddingEncodingFormat":"Embedding Kodlama Formatı","embeddingEncodingFormatDescription":"Embedding vektörleri için kodlama formatı. Otomatik, sağlayıcı desteğine göre algılar.","embeddingEncodingFormatAuto":"Otomatik (Önerilen)","azureOpenaiEndpoint":"Azure OpenAI Uç Noktası","azureOpenaiEndpointPlaceholder":"https://KAYNAK_ADINIZ.openai.azure.com","azureOpenaiApiKey":"Azure OpenAI API Anahtarı","azureOpenaiApiKeyPlaceholder":"Azure OpenAI API anahtarını girin","azureOpenaiApiVersion":"Azure OpenAI API Sürümü","azureOpenaiApiVersionPlaceholder":"2024-02-15-preview","azureOpenaiEmbeddingDeployment":"Azure OpenAI Embedding Dağıtımı","azureOpenaiEmbeddingDeploymentPlaceholder":"text-embedding-3-small","azureOpenaiEmbeddingModel":"Azure Embedding Model Adı","azureOpenaiEmbeddingModelDescription":"Azure'da dağıtılan gerçek OpenAI model adı (örn. text-embedding-3-small). API'ye göndermeden önce doğru token sayımı için kullanılır.","azureOpenaiEmbeddingModelPlaceholder":"text-embedding-3-small","smartRoutingConfigUpdated":"Akıllı yönlendirme yapılandırması başarıyla güncellendi","progressiveDisclosure":"Aşamalı Açıklama","progressiveDisclosureDescription":"Etkinleştirildiğinde, search_tools yalnızca araç adlarını ve açıklamalarını döndürür. Tam parametre şemasını almak için describe_tool kullanın; bu da token kullanımını azaltır.","embeddingMaxTokens":"Maks. Embedding Token Sayısı","embeddingMaxTokensDescription":"Embedding oluşturmadan önce metin kesme için maksimum token sayısı. Model varsayılanını otomatik olarak kullanmak için boş bırakın. Özel bir değer her zaman model varsayılanını geçersiz kılar. Yerel LLM sağlayıcıları kullanırken bu değeri manuel olarak ayarlamak, kesme hatalarını önlemek için özellikle yararlıdır.","embeddingMaxTokensPlaceholder":"Boş = modele göre otomatik","embeddingMaxTokensAuto":"Otomatik: {{limit}} token ({{model}} model varsayılanı)","embeddingMaxTokensOverride":"Bu değer model varsayılanını geçersiz kılar.","smartRoutingRequiredFields":"Akıllı yönlendirmeyi etkinleştirmek için Veritabanı URL'si gereklidir. LLM Sağlayıcı API Anahtarı yalnızca bulut tabanlı sağlayıcılar için gereklidir (yerel LLM'ler genellikle API anahtarı gerektirmez, form doğrulamasını geçmek için herhangi bir değer girin)","smartRoutingValidationError":"Akıllı Yönlendirmeyi etkinleştirmeden önce lütfen gerekli alanları doldurun: {{fields}}","smartRoutingWorkflow":"İş Akışı","smartRoutingWorkflowDescription":"İstem vektörleştirilir; pgvector'dan en benzer top-k araç alınır ve üst LLM'e sunulur.","mcpRouterConfig":"Bulut Market","mcpRouterApiKey":"MCPRouter API Anahtarı","mcpRouterApiKeyDescription":"MCPRouter bulut market hizmetlerine erişim için API anahtarı","mcpRouterApiKeyPlaceholder":"MCPRouter API anahtarını girin","mcpRouterReferer":"Yönlendiren","mcpRouterRefererDescription":"MCPRouter API istekleri için Referer başlığı","mcpRouterRefererPlaceholder":"https://www.mcphub.app","mcpRouterTitle":"Başlık","mcpRouterTitleDescription":"MCPRouter API istekleri için Başlık başlığı","mcpRouterTitlePlaceholder":"MCPHub","mcpRouterBaseUrl":"Temel URL","mcpRouterBaseUrlDescription":"MCPRouter API için temel URL","mcpRouterBaseUrlPlaceholder":"https://api.mcprouter.to/v1","systemSettings":"Sistem Ayarları","nameSeparatorLabel":"İsim Ayırıcı","nameSeparatorDescription":"Sunucu adı ile araç/istek adını ayırmak için kullanılan karakter (varsayılan: -)","enableSessionRebuild":"Sunucu Oturum Yeniden Oluşturmayı Etkinleştir","enableSessionRebuildDescription":"Etkinleştirildiğinde, daha iyi oturum yönetimi deneyimi için geliştirilmiş sunucu oturum yeniden oluşturma kodunu uygular","restartRequired":"Yapılandırma kaydedildi. Tüm hizmetlerin yeni ayarları doğru şekilde yüklemesini sağlamak için uygulamayı yeniden başlatmanız önerilir.","exportMcpSettings":"Ayarları Dışa Aktar","mcpSettingsJson":"MCP Ayarları JSON","mcpSettingsJsonDescription":"Yedekleme veya diğer araçlara taşıma için mevcut mcp_settings.json yapılandırmanızı görüntüleyin, kopyalayın veya indirin","copyToClipboard":"Panoya Kopyala","downloadJson":"JSON Olarak İndir","exportSuccess":"Ayarlar başarıyla dışa aktarıldı","exportError":"Ayarlar getirilemedi","enableOauthServer":"OAuth Sunucusunu Etkinleştir","enableOauthServerDescription":"MCPHub'ın harici istemciler için OAuth jetonları vermesine izin ver","requireClientSecret":"İstemci Sırrı Zorunlu","requireClientSecretDescription":"Etkin olduğunda gizli istemciler client secret sunmalıdır (yalnızca PKCE kullanan istemciler için kapatabilirsiniz)","requireState":"State parametresi zorunlu","requireStateDescription":"State parametresi olmayan yetkilendirme isteklerini reddeder","accessTokenLifetime":"Erişim jetonu süresi (saniye)","accessTokenLifetimeDescription":"Verilen erişim jetonlarının geçerli kalacağı süre","accessTokenLifetimePlaceholder":"örn. 3600","refreshTokenLifetime":"Yenileme jetonu süresi (saniye)","refreshTokenLifetimeDescription":"Yenileme jetonlarının geçerli kalacağı süre","refreshTokenLifetimePlaceholder":"örn. 1209600","authorizationCodeLifetime":"Yetkilendirme kodu süresi (saniye)","authorizationCodeLifetimeDescription":"Yetkilendirme kodlarının takas edilebileceği süre","authorizationCodeLifetimePlaceholder":"örn. 300","allowedScopes":"İzin verilen kapsamlar","allowedScopesDescription":"Kullanıcıların onaylayabileceği kapsamların virgülle ayrılmış listesi","allowedScopesPlaceholder":"örn. read, write","enableDynamicRegistration":"Dinamik istemci kaydını etkinleştir","dynamicRegistrationDescription":"RFC 7591 uyumlu istemcilerin herkese açık uç nokta üzerinden kayıt olmasına izin ver","dynamicRegistrationAllowedGrantTypes":"İzin verilen grant türleri","dynamicRegistrationAllowedGrantTypesDescription":"Dinamik olarak kaydedilen istemciler için kullanılabilecek grant türlerinin virgülle ayrılmış listesi","dynamicRegistrationAllowedGrantTypesPlaceholder":"örn. authorization_code, refresh_token","dynamicRegistrationAuth":"Kayıt için kimlik doğrulaması iste","dynamicRegistrationAuthDescription":"Kayıt uç noktasını korur, yalnızca kimliği doğrulanmış istekler yeni istemci oluşturabilir","invalidNumberInput":"Lütfen sıfırdan küçük olmayan geçerli bir sayı girin"}`),$n={upload:"Yükle",uploadTitle:"MCPB Paketi Yükle",dropFileHere:".mcpb dosyanızı buraya bırakın",orClickToSelect:"veya bilgisayarınızdan seçmek için tıklayın",invalidFileType:"Lütfen geçerli bir .mcpb dosyası seçin",noFileSelected:"Lütfen yüklemek için bir .mcpb dosyası seçin",uploading:"Yükleniyor...",uploadFailed:"MCPB dosyası yüklenemedi",installServer:"MCPB'den MCP Sunucusu Yükle",extensionInfo:"Uzantı Bilgisi",name:"Ad",version:"Sürüm",description:"Açıklama",author:"Geliştirici",tools:"Araçlar",serverName:"Sunucu Adı",serverNamePlaceholder:"Bu sunucu için bir ad girin",install:"Yükle",installing:"Yükleniyor...",installFailed:"MCPB'den sunucu yüklenemedi",serverExistsTitle:"Sunucu Zaten Mevcut",serverExistsConfirm:"'{{serverName}}' sunucusu zaten mevcut. Yeni sürümle geçersiz kılmak istiyor musunuz?",override:"Geçersiz Kıl"},_n={button:"İçe Aktar",title:"JSON'dan Sunucuları İçe Aktar",inputLabel:"Sunucu Yapılandırma JSON",inputHelp:"Sunucu yapılandırma JSON'unuzu yapıştırın. STDIO, SSE ve HTTP (streamable-http) sunucu türlerini destekler.",preview:"Önizle",previewTitle:"İçe Aktarılacak Sunucuları Önizle",import:"İçe Aktar",importing:"İçe aktarılıyor...",invalidFormat:"Geçersiz JSON formatı. JSON bir 'mcpServers' nesnesi içermelidir.",parseError:"JSON ayrıştırılamadı. Lütfen formatı kontrol edip tekrar deneyin.",addFailed:"Sunucu eklenemedi",importFailed:"Sunucular içe aktarılamadı",partialSuccess:"{{total}} sunucudan {{count}} tanesi başarıyla içe aktarıldı. Bazı sunucular başarısız oldu:"},Jn={button:"İçe Aktar",title:"JSON'dan Grupları İçe Aktar",inputLabel:"Grup Yapılandırma JSON",inputHelp:"Grup yapılandırma JSON'unuzu yapıştırın. Her grup bir sunucu listesi içerebilir.",preview:"Önizle",previewTitle:"İçe Aktarılacak Grupları Önizle",import:"İçe Aktar",importing:"İçe aktarılıyor...",invalidFormat:"Geçersiz JSON formatı. JSON bir 'groups' dizisi içermelidir.",missingName:"Her grubun bir 'name' alanı olmalıdır.",parseError:"JSON ayrıştırılamadı. Lütfen formatı kontrol edip tekrar deneyin.",addFailed:"Grup eklenemedi",importFailed:"Gruplar içe aktarılamadı",partialSuccess:"{{total}} gruptan {{count}} tanesi başarıyla içe aktarıldı. Bazı gruplar başarısız oldu:"},Wn={add:"Kullanıcı Ekle",addNew:"Yeni Kullanıcı Ekle",edit:"Kullanıcıyı Düzenle",delete:"Kullanıcıyı Sil",create:"Kullanıcı Oluştur",update:"Kullanıcıyı Güncelle",username:"Kullanıcı Adı",password:"Şifre",newPassword:"Yeni Şifre",confirmPassword:"Şifreyi Onayla",changePassword:"Şifre Değiştir",adminRole:"Yönetici",admin:"Yönetici",user:"Kullanıcı",role:"Rol",actions:"Eylemler",addFirst:"İlk kullanıcınızı ekleyin",permissions:"İzinler",adminPermissions:"Tam sistem erişimi",userPermissions:"Sınırlı erişim",currentUser:"Siz",noUsers:"Kullanıcı bulunamadı",adminRequired:"Kullanıcıları yönetmek için yönetici erişimi gereklidir",usernameRequired:"Kullanıcı adı gereklidir",passwordRequired:"Şifre gereklidir",passwordTooShort:"Şifre en az 6 karakter uzunluğunda olmalıdır",passwordMismatch:"Şifreler eşleşmiyor",usernamePlaceholder:"Kullanıcı adını girin",passwordPlaceholder:"Şifreyi girin",newPasswordPlaceholder:"Mevcut şifreyi korumak için boş bırakın",confirmPasswordPlaceholder:"Yeni şifreyi onaylayın",createError:"Kullanıcı oluşturulamadı",updateError:"Kullanıcı güncellenemedi",deleteError:"Kullanıcı silinemedi",statsError:"Kullanıcı istatistikleri getirilemedi",deleteConfirmation:"'{{username}}' kullanıcısını silmek istediğinizden emin misiniz? Bu işlem geri alınamaz.",confirmDelete:"Kullanıcıyı Sil",deleteWarning:"'{{username}}' kullanıcısını silmek istediğinizden emin misiniz? Bu işlem geri alınamaz."},Yn={errors:{readonly:"Demo ortamı için salt okunur",invalid_credentials:"Geçersiz kullanıcı adı veya şifre",serverNameRequired:"Sunucu adı gereklidir",serverConfigRequired:"Sunucu yapılandırması gereklidir",serverConfigInvalid:"Sunucu yapılandırması bir URL, OpenAPI şartname URL'si veya şema, ya da argümanlı komut içermelidir",serverTypeInvalid:"Sunucu türü şunlardan biri olmalıdır: stdio, sse, streamable-http, openapi",urlRequiredForType:"{{type}} sunucu türü için URL gereklidir",openapiSpecRequired:"OpenAPI sunucu türü için OpenAPI şartname URL'si veya şema gereklidir",headersInvalidFormat:"Başlıklar bir nesne olmalıdır",headersNotSupportedForStdio:"Başlıklar stdio sunucu türü için desteklenmez",serverNotFound:"Sunucu bulunamadı",failedToRemoveServer:"Sunucu bulunamadı veya kaldırılamadı",internalServerError:"Dahili sunucu hatası",failedToGetServers:"Sunucu bilgileri alınamadı",failedToGetServerSettings:"Sunucu ayarları alınamadı",failedToGetServerConfig:"Sunucu yapılandırması alınamadı",failedToSaveSettings:"Ayarlar kaydedilemedi",toolNameRequired:"Sunucu adı ve araç adı gereklidir",descriptionMustBeString:"Açıklama bir string olmalıdır",groupIdRequired:"Grup ID gereklidir",groupNameRequired:"Grup adı gereklidir",groupNotFound:"Grup bulunamadı",groupIdAndServerNameRequired:"Grup ID ve sunucu adı gereklidir",groupOrServerNotFound:"Grup veya sunucu bulunamadı",toolsMustBeAllOrArray:'Araçlar "all" veya bir string dizisi olmalıdır',serverNameAndToolNameRequired:"Sunucu adı ve araç adı gereklidir",usernameRequired:"Kullanıcı adı gereklidir",userNotFound:"Kullanıcı bulunamadı",failedToGetUsers:"Kullanıcı bilgileri alınamadı",failedToGetUserInfo:"Kullanıcı bilgisi alınamadı",failedToGetUserStats:"Kullanıcı istatistikleri alınamadı",marketServerNameRequired:"Sunucu adı gereklidir",marketServerNotFound:"Market sunucusu bulunamadı",failedToGetMarketServers:"Market sunucuları bilgisi alınamadı",failedToGetMarketServer:"Market sunucusu bilgisi alınamadı",failedToGetMarketCategories:"Market kategorileri alınamadı",failedToGetMarketTags:"Market etiketleri alınamadı",failedToSearchMarketServers:"Market sunucuları aranamadı",failedToFilterMarketServers:"Market sunucuları filtrelenemedi",failedToProcessMcpbFile:"MCPB dosyası işlenemedi"},success:{serverCreated:"Sunucu başarıyla oluşturuldu",serverUpdated:"Sunucu başarıyla güncellendi",serverRemoved:"Sunucu başarıyla kaldırıldı",serverToggled:"Sunucu durumu başarıyla değiştirildi",toolToggled:"{{name}} aracı başarıyla {{action}}",toolDescriptionUpdated:"{{name}} aracının açıklaması başarıyla güncellendi",systemConfigUpdated:"Sistem yapılandırması başarıyla güncellendi",groupCreated:"Grup başarıyla oluşturuldu",groupUpdated:"Grup başarıyla güncellendi",groupDeleted:"Grup başarıyla silindi",serverAddedToGroup:"Sunucu başarıyla gruba eklendi",serverRemovedFromGroup:"Sunucu başarıyla gruptan kaldırıldı",serverToolsUpdated:"Sunucu araçları başarıyla güncellendi"}},Qn={authorizationFailed:"Yetkilendirme Başarısız",authorizationFailedError:"Hata",authorizationFailedDetails:"Detaylar",invalidRequest:"Geçersiz İstek",missingStateParameter:"Gerekli OAuth durum parametresi eksik.",missingCodeParameter:"Gerekli yetkilendirme kodu parametresi eksik.",serverNotFound:"Sunucu Bulunamadı",serverNotFoundMessage:"Bu yetkilendirme isteğiyle ilişkili sunucu bulunamadı.",sessionExpiredMessage:"Yetkilendirme oturumunun süresi dolmuş olabilir. Lütfen tekrar yetkilendirmeyi deneyin.",authorizationSuccessful:"Yetkilendirme Başarılı",server:"Sunucu",status:"Durum",connected:"Bağlandı",successMessage:"Sunucu başarıyla yetkilendirildi ve bağlandı.",autoCloseMessage:"Bu pencere 3 saniye içinde otomatik olarak kapanacak...",closeNow:"Şimdi Kapat",connectionError:"Bağlantı Hatası",connectionErrorMessage:"Yetkilendirme başarılı oldu, ancak sunucuya bağlanılamadı.",reconnectMessage:"Lütfen kontrol panelinden yeniden bağlanmayı deneyin.",configurationError:"Yapılandırma Hatası",configurationErrorMessage:"Sunucu aktarımı OAuth finishAuth() desteklemiyor. Lütfen sunucunun streamable-http aktarımıyla yapılandırıldığından emin olun.",internalError:"İçsel Hata",internalErrorMessage:"OAuth geri araması işlenirken beklenmeyen bir hata oluştu.",closeWindow:"Pencereyi Kapat"},Zn={add:"Prompt Ekle",addNew:"Yeni Prompt Ekle",edit:"Promptu Düzenle",delete:"Sil",noPrompts:"Yerleşik prompt yapılandırılmamış",addFirst:"İlk promptunuzu ekleyin",name:"Ad",namePlaceholder:"örn. code-review",title:"Başlık",titlePlaceholder:"örn. Kod İnceleme Promptu",description:"Açıklama",descriptionPlaceholder:"Promptun kısa açıklaması",template:"Şablon",templatePlaceholder:"{{parametre}} yer tutucularıyla şablon metni girin...",templateHint:"Şablon parametreleri için {{paramName}} kullanın",arguments:"Argümanlar",addArgument:"Argüman Ekle",argName:"Ad",argDescription:"Açıklama",argRequired:"Zorunlu",enabled:"Etkin",active:"Aktif",inactive:"İnaktif",nameRequired:"Ad zorunludur",templateRequired:"Şablon zorunludur",fetchError:"Yerleşik promptlar yüklenemedi",createError:"Prompt oluşturulamadı",updateError:"Prompt güncellenemedi",deleteError:"Prompt silinemedi",saveError:"Prompt kaydedilemedi",confirmDelete:"Promptu Sil",deleteWarning:'"{{name}}" promptunu silmek istediğinizden emin misiniz? Bu işlem geri alınamaz.'},Xn={add:"Kaynak Ekle",addNew:"Yeni Kaynak Ekle",edit:"Kaynağı Düzenle",delete:"Sil",noResources:"Yerleşik kaynak yapılandırılmamış",addFirst:"İlk kaynağınızı ekleyin",uri:"URI",uriPlaceholder:"örn. resource://docs/guide",name:"Ad",namePlaceholder:"örn. Kullanıcı Kılavuzu",description:"Açıklama",descriptionPlaceholder:"Kaynağın kısa açıklaması",mimeType:"MIME Türü",content:"İçerik",contentPlaceholder:"Kaynak içeriğini girin...",enabled:"Etkin",active:"Aktif",inactive:"İnaktif",descriptionUpdateSuccess:"Kaynak açıklaması başarıyla güncellendi",descriptionUpdateFailed:"Kaynak açıklaması güncellenemedi",restoreDefault:"Varsayılana dön",restoreDefaultSuccess:"Kaynak açıklaması varsayılan değere döndürüldü",restoreDefaultFailed:"Varsayılan kaynak açıklamasına dönülemedi",uriRequired:"URI zorunludur",contentRequired:"İçerik zorunludur",fetchError:"Yerleşik kaynaklar yüklenemedi",createError:"Kaynak oluşturulamadı",updateError:"Kaynak güncellenemedi",deleteError:"Kaynak silinemedi",saveError:"Kaynak kaydedilemedi",confirmDelete:"Kaynağı Sil",deleteWarning:'"{{name}}" kaynağını silmek istediğinizden emin misiniz? Bu işlem geri alınamaz.'},ei={title:"Etkinlik",totalCalls:"Toplam çağrı",successCount:"Başarılı",errorCount:"Başarısız",avgDuration:"Ort. süre",timestamp:"Zaman damgası",server:"Sunucu",tool:"Araç",duration:"Süre",status:"Durum",group:"Grup",key:"API Anahtarı",input:"Girdi",output:"Çıktı",details:"Etkinlik detayları",errorMessage:"Hata mesajı",searchServer:"Sunucu...",searchTool:"Araç...",searchStatus:"Durum...",searchGroup:"Grup...",searchKeyName:"API anahtarı...",keyName:"API Anahtarı Adı",allStatus:"Tüm durumlar",statusSuccess:"Başarılı",statusError:"Hata",noData:"Kullanılabilir etkinlik verisi yok",fetchError:"Etkinlik verileri yüklenemedi",cleanup:"Temizle",confirmCleanup:"30 günden eski etkinlikleri silmek istediğinizden emin misiniz?",cleanupSuccess:"{{count}} eski etkinlik silindi",cleanupError:"Eski etkinlikler temizlenemedi",notAvailable:"Etkinlik takibi yalnızca veritabanı modunda kullanılabilir"},ri={exportButton:"Şablon Dışa Aktar",importButton:"Şablon İçe Aktar",exportTitle:"Yapılandırma Şablonunu Dışa Aktar",importTitle:"Yapılandırma Şablonunu İçe Aktar",name:"Şablon Adı",nameRequired:"Şablon adı gereklidir",namePlaceholder:"Ör: Frontend Geliştirme Araçları",description:"Açıklama",descriptionPlaceholder:"Ör: Frontend geliştirme için standart MCP sunucuları",selectGroups:"Grupları Seç",selectGroupsHelp:"Tüm grupları dışa aktarmak için boş bırakın",selectAll:"Tümünü Seç",deselectAll:"Tümünü Kaldır",includeDisabled:"Devre dışı sunucuları dahil et",exportNote:"Gizli bilgiler (API anahtarları, tokenlar, parolalar) ${PLACEHOLDER} referanslarıyla değiştirilecektir. Alıcıların kendi kimlik bilgilerini sağlaması gerekir.",export:"Dışa Aktar",exporting:"Dışa aktarılıyor...",exportFailed:"Şablon dışa aktarılamadı",import:"İçe Aktar",importing:"İçe aktarılıyor...",importFailed:"Şablon içe aktarılamadı",invalidFormat:"Geçersiz şablon formatı. version, name, servers ve groups alanlarını içermelidir.",parseError:"JSON ayrıştırılamadı. Lütfen formatı kontrol edip tekrar deneyin.",uploadFile:"Şablon Dosyası Yükle",or:"veya",pasteJson:"Şablon JSON Yapıştır",pastePlaceholder:".mcphub-template.json içeriğinizi buraya yapıştırın...",version:"Sürüm",createdAt:"Oluşturulma",servers:"Sunucular",groups:"Gruplar",serversInGroup:"sunucu",envVarsNeeded:"Gerekli Ortam Değişkenleri — içe aktarılan sunucuları kullanmadan önce bunları ayarlayın:",importResult:"Sunucular: {{serversCreated}} oluşturuldu, {{serversSkipped}} atlandı. Gruplar: {{groupsCreated}} oluşturuldu, {{groupsSkipped}} atlandı."},ti={app:An,about:Pn,profile:wn,sponsor:xn,wechat:Cn,discord:Rn,theme:En,auth:Tn,server:Nn,status:Dn,errors:Mn,common:In,pagination:zn,nav:On,pages:Ln,logs:Fn,groups:jn,market:Un,oauthServer:Gn,cloud:Kn,registry:qn,tool:Bn,prompt:Hn,settings:Vn,mcpb:$n,jsonImport:_n,groupImport:Jn,users:Wn,api:Yn,oauthCallback:Qn,builtinPrompts:Zn,builtinResources:Xn,activity:ei,template:ri};ot.use(nt).use(it).init({resources:{en:{translation:ao},zh:{translation:Uo},fr:{translation:Sn},tr:{translation:ti}},fallbackLng:"en",debug:!1,defaultNS:"translation",interpolation:{escapeValue:!1},detection:{order:["localStorage","cookie","htmlTag","navigator"],caches:["localStorage","cookie"]}});const ai=()=>{It()};ai();async function si(){try{console.log("Loading runtime configuration...");const e=await Nt();console.log("Runtime configuration loaded:",e),window.__MCPHUB_CONFIG__=e,cr.createRoot(document.getElementById("root")).render(a.jsx(Ne.StrictMode,{children:a.jsx(br,{})}))}catch(e){console.error("Failed to initialize app:",e),console.log("Starting app with default configuration..."),window.__MCPHUB_CONFIG__={basePath:"",version:"dev",name:"mcphub"},cr.createRoot(document.getElementById("root")).render(a.jsx(Ne.StrictMode,{children:a.jsx(br,{})}))}}si();export{La as G,Oa as L,mi as P,Ia as T,Q as _,qt as a,Ie as b,Lt as c,$a as d,ie as e,he as f,Pe as g,_ as h,Ur as i,V as j,wr as k,Pr as l,Ge as m,Da as n,ui as o,ci as p,di as q,pi as r,hi as s,fi as t,fe as u,vi as v,gi as w};
|
|
3
|
-
//# sourceMappingURL=index-BGiKkKzj.js.map
|