@adversity/coding-tool-x 3.1.1 → 3.1.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.
Files changed (38) hide show
  1. package/CHANGELOG.md +24 -0
  2. package/dist/web/assets/{ConfigTemplates-ZrK_s7ma.js → ConfigTemplates-DvcbKKdS.js} +1 -1
  3. package/dist/web/assets/Home-BJKPCBuk.css +1 -0
  4. package/dist/web/assets/Home-Cw-F_Wnu.js +1 -0
  5. package/dist/web/assets/{PluginManager-BD7QUZbU.js → PluginManager-jy_4GVxI.js} +1 -1
  6. package/dist/web/assets/{ProjectList-DRb1DuHV.js → ProjectList-Df1-NcNr.js} +1 -1
  7. package/dist/web/assets/{SessionList-lZ0LKzfT.js → SessionList-UWcZtC2r.js} +1 -1
  8. package/dist/web/assets/{SkillManager-C1xG5B4Q.js → SkillManager-IRdseMKB.js} +1 -1
  9. package/dist/web/assets/{Terminal-DksBo_lM.js → Terminal-BasTyDut.js} +1 -1
  10. package/dist/web/assets/{WorkspaceManager-Burx7XOo.js → WorkspaceManager-D-D2kK1V.js} +1 -1
  11. package/dist/web/assets/index-CoB3zF0K.css +1 -0
  12. package/dist/web/assets/index-CryrSLv8.js +2 -0
  13. package/dist/web/index.html +2 -2
  14. package/package.json +1 -1
  15. package/src/config/default.js +2 -0
  16. package/src/config/model-metadata.js +415 -0
  17. package/src/config/model-pricing.js +23 -93
  18. package/src/server/api/opencode-channels.js +84 -6
  19. package/src/server/api/opencode-proxy.js +41 -32
  20. package/src/server/api/opencode-sessions.js +4 -62
  21. package/src/server/api/settings.js +111 -0
  22. package/src/server/codex-proxy-server.js +6 -4
  23. package/src/server/gemini-proxy-server.js +6 -4
  24. package/src/server/index.js +13 -4
  25. package/src/server/opencode-proxy-server.js +1197 -86
  26. package/src/server/proxy-server.js +6 -4
  27. package/src/server/services/codex-sessions.js +105 -6
  28. package/src/server/services/env-checker.js +24 -1
  29. package/src/server/services/env-manager.js +29 -1
  30. package/src/server/services/opencode-channels.js +3 -1
  31. package/src/server/services/opencode-sessions.js +486 -218
  32. package/src/server/services/opencode-settings-manager.js +172 -36
  33. package/src/server/services/response-decoder.js +21 -0
  34. package/src/server/websocket-server.js +24 -5
  35. package/dist/web/assets/Home-B8YfhZ3c.js +0 -1
  36. package/dist/web/assets/Home-Di2qsylF.css +0 -1
  37. package/dist/web/assets/index-Ufv5rCa5.css +0 -1
  38. package/dist/web/assets/index-lAkrRC3h.js +0 -2
@@ -1,6 +1,25 @@
1
1
  const fs = require('fs');
2
2
  const path = require('path');
3
3
  const { NATIVE_PATHS } = require('../../config/paths');
4
+ const { resolveModelMetadata } = require('../../config/model-metadata');
5
+
6
+ /**
7
+ * 根据模型 ID 查找 limit(context + output)
8
+ * 委托给集中式 model-metadata.js
9
+ */
10
+ function resolveModelLimit(modelId) {
11
+ const meta = resolveModelMetadata(modelId);
12
+ return meta ? meta.limit : null;
13
+ }
14
+
15
+ /**
16
+ * 根据模型 ID 查找定价信息
17
+ * 委托给集中式 model-metadata.js
18
+ */
19
+ function resolveModelCost(modelId) {
20
+ const meta = resolveModelMetadata(modelId);
21
+ return meta ? meta.pricing : null;
22
+ }
4
23
 
5
24
  const CONFIG_DIR = NATIVE_PATHS.opencode.config;
6
25
  const CONFIG_PATHS = {
@@ -13,6 +32,7 @@ const EMPTY_SENTINEL = '__CC_TOOL_NO_FILE__';
13
32
  const PROXY_PROVIDER_ID = 'ctx-proxy';
14
33
  const LEGACY_PROVIDER_ID = 'openai';
15
34
  const PROXY_API_KEY = 'PROXY_KEY';
35
+ const MANAGED_PROVIDER_MARKER = '__ctx_managed__';
16
36
 
17
37
  function ensureConfigDir() {
18
38
  if (!fs.existsSync(CONFIG_DIR)) {
@@ -106,18 +126,28 @@ function writeConfig(filePath, config) {
106
126
  fs.writeFileSync(filePath, content, 'utf8');
107
127
  }
108
128
 
109
- function normalizeOpenCodeModel(modelId) {
129
+ function normalizeOpenCodeModel(modelId, providerId) {
110
130
  const normalized = String(modelId || '').trim();
111
131
  if (!normalized) {
112
132
  return '';
113
133
  }
114
134
 
115
- // OpenCode 要求格式为 provider/model。这里统一绑定到 ctx-proxy provider,
116
- // 避免落到内置 openai provider 的模型清单。
117
- if (normalized.startsWith(`${PROXY_PROVIDER_ID}/`)) {
135
+ const pid = String(providerId || PROXY_PROVIDER_ID).trim() || PROXY_PROVIDER_ID;
136
+
137
+ // Already has a provider/ prefix - keep as-is only if it matches the expected provider
138
+ if (normalized.includes('/')) {
118
139
  return normalized;
119
140
  }
120
- return `${PROXY_PROVIDER_ID}/${normalized}`;
141
+ return `${pid}/${normalized}`;
142
+ }
143
+
144
+ function sanitizeProviderKey(name) {
145
+ return String(name || '')
146
+ .toLowerCase()
147
+ .replace(/[^a-z0-9-]/g, '-')
148
+ .replace(/-+/g, '-')
149
+ .replace(/^-|-$/g, '')
150
+ || 'channel';
121
151
  }
122
152
 
123
153
  function isLocalProxyBaseUrl(url) {
@@ -141,8 +171,16 @@ function isManagedProxyProvider(provider) {
141
171
 
142
172
  function isManagedProxyConfig(config) {
143
173
  if (!config || typeof config !== 'object') return false;
144
- return isManagedProxyProvider(config?.provider?.[PROXY_PROVIDER_ID])
145
- || isLegacyProxyProvider(config?.provider?.[LEGACY_PROVIDER_ID]);
174
+ // Check legacy single-provider format
175
+ if (isManagedProxyProvider(config?.provider?.[PROXY_PROVIDER_ID])
176
+ || isLegacyProxyProvider(config?.provider?.[LEGACY_PROVIDER_ID])) {
177
+ return true;
178
+ }
179
+ // Check per-channel provider format (any provider with PROXY_API_KEY + local baseURL)
180
+ if (config?.provider && typeof config.provider === 'object') {
181
+ return Object.values(config.provider).some(p => isManagedProxyProvider(p));
182
+ }
183
+ return false;
146
184
  }
147
185
 
148
186
  function buildModelsMap(models = [], fallbackModel = '') {
@@ -156,7 +194,28 @@ function buildModelsMap(models = [], fallbackModel = '') {
156
194
  const key = trimmed.toLowerCase();
157
195
  if (seen.has(key)) return;
158
196
  seen.add(key);
159
- map[trimmed] = { name: trimmed };
197
+
198
+ const entry = { name: trimmed };
199
+
200
+ // 注入 limit(context + output),供 OpenCode 显示 "X% used"
201
+ // OpenCode schema 要求 limit 必须同时包含 context 和 output
202
+ const limit = resolveModelLimit(trimmed);
203
+ if (limit) {
204
+ entry.limit = { context: limit.context, output: limit.output };
205
+ }
206
+
207
+ // 注入定价信息,供 OpenCode 计算 cost
208
+ const pricing = resolveModelCost(trimmed);
209
+ if (pricing) {
210
+ entry.cost = {
211
+ input: pricing.input,
212
+ output: pricing.output,
213
+ cache_read: pricing.cacheRead,
214
+ cache_write: pricing.cacheCreation
215
+ };
216
+ }
217
+
218
+ map[trimmed] = entry;
160
219
  };
161
220
 
162
221
  if (Array.isArray(models)) {
@@ -168,9 +227,21 @@ function buildModelsMap(models = [], fallbackModel = '') {
168
227
  }
169
228
 
170
229
  function resolveProxyBaseUrl(config) {
171
- return config?.provider?.[PROXY_PROVIDER_ID]?.options?.baseURL
172
- || config?.provider?.[LEGACY_PROVIDER_ID]?.options?.baseURL
173
- || '';
230
+ if (config?.provider?.[PROXY_PROVIDER_ID]?.options?.baseURL) {
231
+ return config.provider[PROXY_PROVIDER_ID].options.baseURL;
232
+ }
233
+ if (config?.provider?.[LEGACY_PROVIDER_ID]?.options?.baseURL) {
234
+ return config.provider[LEGACY_PROVIDER_ID].options.baseURL;
235
+ }
236
+ // Check per-channel managed providers
237
+ if (config?.provider && typeof config.provider === 'object') {
238
+ for (const p of Object.values(config.provider)) {
239
+ if (isManagedProxyProvider(p) && p?.options?.baseURL) {
240
+ return p.options.baseURL;
241
+ }
242
+ }
243
+ }
244
+ return '';
174
245
  }
175
246
 
176
247
  function backupConfig(filePath) {
@@ -257,38 +328,98 @@ function setProxyConfig(proxyPort, options = {}) {
257
328
  if (isLegacyProxyProvider(next.provider[LEGACY_PROVIDER_ID])) {
258
329
  delete next.provider[LEGACY_PROVIDER_ID];
259
330
  }
260
-
261
331
  if (Object.prototype.hasOwnProperty.call(next.provider[LEGACY_PROVIDER_ID] || {}, 'model')) {
262
332
  delete next.provider[LEGACY_PROVIDER_ID].model;
263
333
  }
264
334
 
265
- const modelsMap = buildModelsMap(options.models, options.model);
266
- const modelIds = Object.keys(modelsMap);
267
-
268
- if (modelIds.length > 0) {
269
- next.provider[PROXY_PROVIDER_ID] = {
270
- npm: '@ai-sdk/openai-compatible',
271
- name: 'CTX Proxy',
272
- options: {
273
- baseURL: `http://127.0.0.1:${proxyPort}/v1`,
274
- apiKey: PROXY_API_KEY
275
- },
276
- models: modelsMap
277
- };
335
+ // Remove old single ctx-proxy provider (superseded by per-channel providers)
336
+ delete next.provider[PROXY_PROVIDER_ID];
337
+
338
+ // Remove any previously managed per-channel providers that are no longer in the current list
339
+ Object.keys(next.provider).forEach((key) => {
340
+ if (isManagedProxyProvider(next.provider[key])) {
341
+ delete next.provider[key];
342
+ }
343
+ });
344
+
345
+ const channels = Array.isArray(options.channels) ? options.channels : null;
346
+
347
+ if (channels && channels.length > 0) {
348
+ // Per-channel mode: write one provider entry per channel
349
+ const usedKeys = new Set();
350
+ let firstProviderId = null;
351
+ let firstModelId = null;
352
+
353
+ channels.forEach((ch) => {
354
+ const rawKey = sanitizeProviderKey(ch.providerKey || ch.name || '');
355
+ // Ensure uniqueness
356
+ let key = rawKey;
357
+ let suffix = 2;
358
+ while (usedKeys.has(key)) {
359
+ key = `${rawKey}-${suffix}`;
360
+ suffix += 1;
361
+ }
362
+ usedKeys.add(key);
363
+
364
+ const modelsMap = buildModelsMap(ch.models, ch.model);
365
+ const modelIds = Object.keys(modelsMap);
366
+
367
+ if (modelIds.length > 0) {
368
+ next.provider[key] = {
369
+ npm: '@ai-sdk/openai-compatible',
370
+ name: ch.name || key,
371
+ options: {
372
+ baseURL: `http://127.0.0.1:${proxyPort}/v1`,
373
+ apiKey: PROXY_API_KEY
374
+ },
375
+ models: modelsMap
376
+ };
377
+
378
+ if (firstProviderId === null) {
379
+ firstProviderId = key;
380
+ firstModelId = ch.model || modelIds[0] || null;
381
+ }
382
+ }
383
+ });
384
+
385
+ // Write top-level model pointing to first channel's first model
386
+ const topModel = options.model || (firstProviderId && firstModelId
387
+ ? `${firstProviderId}/${firstModelId}`
388
+ : null);
389
+ if (topModel) {
390
+ const resolved = normalizeOpenCodeModel(topModel, firstProviderId || PROXY_PROVIDER_ID);
391
+ if (resolved) {
392
+ next.model = resolved;
393
+ }
394
+ } else if (isOldManagedModelRef(next.model)) {
395
+ delete next.model;
396
+ }
278
397
  } else {
279
- // 无模型时不暴露 provider,避免出现误导性的 provider.openai/provider 列表。
280
- delete next.provider[PROXY_PROVIDER_ID];
281
- }
398
+ // Fallback: legacy flat-model mode (single ctx-proxy provider)
399
+ const modelsMap = buildModelsMap(options.models, options.model);
400
+ const modelIds = Object.keys(modelsMap);
401
+
402
+ if (modelIds.length > 0) {
403
+ next.provider[PROXY_PROVIDER_ID] = {
404
+ npm: '@ai-sdk/openai-compatible',
405
+ name: 'CTX Proxy',
406
+ options: {
407
+ baseURL: `http://127.0.0.1:${proxyPort}/v1`,
408
+ apiKey: PROXY_API_KEY
409
+ },
410
+ models: modelsMap
411
+ };
412
+ }
282
413
 
283
- // 写入顶层 model(OpenCode 要求 provider/model 格式),无显式模型时兜底第一个模型。
284
- const fallbackModel = options.model || modelIds[0] || '';
285
- if (fallbackModel) {
286
- const resolvedModel = normalizeOpenCodeModel(fallbackModel);
287
- if (resolvedModel) {
288
- next.model = resolvedModel;
414
+ const fallbackModel = options.model || modelIds[0] || '';
415
+ if (fallbackModel) {
416
+ const resolvedModel = normalizeOpenCodeModel(fallbackModel, PROXY_PROVIDER_ID);
417
+ if (resolvedModel) {
418
+ next.model = resolvedModel;
419
+ }
420
+ } else if (isOldManagedModelRef(next.model)) {
421
+ delete next.model;
289
422
  }
290
- } else if (String(next.model || '').startsWith(`${PROXY_PROVIDER_ID}/`) || String(next.model || '').startsWith(`${LEGACY_PROVIDER_ID}/`)) {
291
- delete next.model;
292
423
  }
293
424
 
294
425
  writeConfig(filePath, next);
@@ -296,6 +427,11 @@ function setProxyConfig(proxyPort, options = {}) {
296
427
  return { success: true, port: proxyPort, path: filePath };
297
428
  }
298
429
 
430
+ function isOldManagedModelRef(modelRef) {
431
+ const s = String(modelRef || '');
432
+ return s.startsWith(`${PROXY_PROVIDER_ID}/`) || s.startsWith(`${LEGACY_PROVIDER_ID}/`);
433
+ }
434
+
299
435
  function restoreSettings() {
300
436
  const restored = [
301
437
  restoreConfig(CONFIG_PATHS.opencodec),
@@ -0,0 +1,21 @@
1
+ const zlib = require('zlib');
2
+
3
+ function createDecodedStream(res) {
4
+ const encoding = String(res.headers['content-encoding'] || '').toLowerCase();
5
+
6
+ if (encoding.includes('gzip')) {
7
+ return res.pipe(zlib.createGunzip());
8
+ }
9
+ if (encoding.includes('deflate')) {
10
+ return res.pipe(zlib.createInflate());
11
+ }
12
+ if (encoding.includes('br') && typeof zlib.createBrotliDecompress === 'function') {
13
+ return res.pipe(zlib.createBrotliDecompress());
14
+ }
15
+
16
+ return res;
17
+ }
18
+
19
+ module.exports = {
20
+ createDecodedStream
21
+ };
@@ -33,6 +33,29 @@ let websocketOptions = {
33
33
  host: '127.0.0.1',
34
34
  allowRemoteTerminal: false
35
35
  };
36
+ const HISTORY_CHUNK_SIZE = 50;
37
+
38
+ function sendPersistedLogsInChunks(ws, logs) {
39
+ let index = 0;
40
+
41
+ const sendChunk = () => {
42
+ if (ws.readyState !== WebSocket.OPEN) {
43
+ return;
44
+ }
45
+
46
+ const end = Math.min(index + HISTORY_CHUNK_SIZE, logs.length);
47
+ for (let i = index; i < end; i++) {
48
+ ws.send(JSON.stringify(logs[i]));
49
+ }
50
+ index = end;
51
+
52
+ if (index < logs.length) {
53
+ setImmediate(sendChunk);
54
+ }
55
+ };
56
+
57
+ setImmediate(sendChunk);
58
+ }
36
59
 
37
60
  function parseHostHeader(hostHeader) {
38
61
  const value = String(hostHeader || '').trim();
@@ -309,11 +332,7 @@ function startWebSocketServer(httpServer, options = {}) {
309
332
 
310
333
  // 发送历史日志给新连接的客户端
311
334
  if (logsCache.length > 0) {
312
- logsCache.forEach(log => {
313
- if (ws.readyState === WebSocket.OPEN) {
314
- ws.send(JSON.stringify(log));
315
- }
316
- });
335
+ sendPersistedLogsInChunks(ws, logsCache);
317
336
  }
318
337
 
319
338
  // 处理客户端消息
@@ -1 +0,0 @@
1
- import{d as e}from"./vendors-CO3Upi1d.js";import{a6 as a,f as l,r as n,w as s,h as c,K as t,a8 as o,c as i,o as u,a as d,W as r,X as v,a0 as p,Y as h,N as y,a3 as g,_ as m,p as k,F as f,$ as T,L as b,Z as x,v as _}from"./vue-vendor-DqyWIXEb.js";import{_ as C,u as w,a as $,R as q,g as z,b as S,c as L,d as I,e as O,f as j,h as M,t as N,i as A,j as F,k as P,l as U,m as D,n as E,o as V,s as J}from"./index-lAkrRC3h.js";import{E as G,r as K,q as R,p as Y,ar as B,Y as H,as as W,at as X,au as Z,av as Q,ac as ee,i as ae,A as le,aw as ne,ax as se,a as ce,T as te}from"./icons-kcfLIMBB.js";import{M as oe,N as ie,c as ue,b as de,a as re,_ as ve,B as pe,s as he}from"./naive-ui-CSrLusZZ.js";import"./markdown-C9MYpaSi.js";const ye={class:"channel-column"},ge={class:"drag-handle",title:"拖拽排序"},me={class:"header-icon"},ke={class:"channel-title"},fe={class:"mcp-quick-panel"},Te={class:"panel-title"},be={key:0,class:"no-items"},xe={key:1,class:"mcp-quick-list"},_e={class:"mcp-item-icon"},Ce={class:"mcp-item-info"},we={class:"mcp-item-name"},$e={class:"mcp-item-type"},qe={key:1,class:"claude-extra-area"},ze={class:"skills-quick-panel"},Se={class:"panel-title"},Le={key:0,class:"no-items"},Ie={key:1,class:"skills-quick-list"},Oe={class:"skill-item-icon"},je={class:"skill-item-info"},Me={class:"skill-item-name"},Ne={class:"skill-item-desc"},Ae={key:0,class:"channel-content"},Fe={class:"card"},Pe={class:"card-header"},Ue={key:0,class:"runtime-badge"},De={class:"card-body",style:{padding:"6px 10px"}},Ee={class:"proxy-info-row"},Ve={class:"proxy-status"},Je={class:"proxy-port"},Ge={class:"channel-name"},Ke={class:"channel-quick-panel"},Re={class:"panel-title"},Ye={key:0,class:"no-channels"},Be={key:1,class:"channel-quick-list"},He={class:"channel-quick-info"},We={class:"channel-quick-name"},Xe={class:"channel-metrics"},Ze={class:"metric-item"},Qe={class:"metric-value"},ea={class:"metric-item"},aa={class:"metric-value"},la={class:"metric-item"},na={class:"metric-value"},sa={class:"metric-item"},ca={class:"card"},ta={class:"card-header compact"},oa={class:"card-body",style:{padding:"8px 10px"}},ia={class:"quick-access-list"},ua={class:"access-icon"},da={class:"access-content"},ra={class:"access-value"},va={class:"access-icon"},pa={class:"access-content"},ha={class:"access-value"},ya={class:"access-icon"},ga={class:"access-content"},ma={class:"access-goto"},ka={class:"card-header compact"},fa={class:"card-body",style:{padding:"8px 10px"}},Ta={class:"stats-inline stats-3col"},ba={class:"stat-inline-item stat-requests"},xa={class:"stat-info"},_a={class:"stat-inline-item stat-input"},Ca={class:"stat-info"},wa={class:"stat-inline-item stat-output"},$a={class:"stat-info"},qa={key:1,class:"card logs-card"},za={class:"collapse-header"},Sa={class:"collapse-content scrollable-content"},La={class:"logs-table-wrapper"},Ia={key:0,class:"empty-logs"},Oa={key:0,class:"action-content"},ja={class:"action-msg"},Ma={class:"action-time"},Na={class:"locked-content"},Aa={class:"lock-icon"},Fa="channelLocks",Pa=C({__name:"ChannelColumn",props:{channelType:{type:String,required:!0,validator:e=>["claude","codex","gemini","opencode"].includes(e)}},setup(e){const C=e,V=a(),J=oe(),{claudeProxy:Pa,codexProxy:Ua,geminiProxy:Da,opencodeProxy:Ea,claudeChannels:Va,codexChannels:Ja,geminiChannels:Ga,opencodeChannels:Ka,schedulerState:Ra,getProxyState:Ya,startProxy:Ba,stopProxy:Ha,getLogs:Wa,clearLogsForSource:Xa,loadChannels:Za,logLimit:Qa,statsInterval:el}=w(),{dashboardData:al,loadDashboard:ll}=$(),nl={claude:{title:"ClaudeCode",subtitle:"智能编程助手",icon:Y},codex:{title:"Codex-CLI",subtitle:"高效代码生成",icon:R},gemini:{title:"Gemini-CLI",subtitle:"多模态AI助手",icon:K},opencode:{title:"OpenCode",subtitle:"AI 代码助手",icon:G}},sl=l(()=>nl[C.channelType].title);l(()=>nl[C.channelType].subtitle);const cl=l(()=>nl[C.channelType].icon),tl=l(()=>"claude"===C.channelType?Pa.value:"codex"===C.channelType?Ua.value:"gemini"===C.channelType?Da.value:"opencode"===C.channelType?Ea.value:{}),ol=l(()=>"claude"===C.channelType?"Claude":"codex"===C.channelType?"Codex":"gemini"===C.channelType?"Gemini":"opencode"===C.channelType?"OpenCode":""),il=n({projects:0,sessions:0}),ul=n({requests:0,tokens:0,cost:0}),dl=n({requests:0,tokens:0,cost:0}),rl={requests:0,tokens:0,cost:3};let vl={requests:null,tokens:null,cost:null};const pl=n({requests:!1,tokens:!1,cost:!1}),hl=l(()=>{var e,a,l;const n="claude"===C.channelType?"claude":"codex"===C.channelType?"codex":"opencode"===C.channelType?"opencode":"gemini";return(null==(l=null==(a=null==(e=al.value)?void 0:e.todayStats)?void 0:a[n])?void 0:l.byModel)||{}});function yl(e,a,l,n=600){vl[e]&&cancelAnimationFrame(vl[e]),pl.value[e]=!0;const s=Date.now(),c=()=>{const t=Date.now()-s,o=Math.min(t/n,1),i=1-Math.pow(1-o,2),u=a+(l-a)*i,d=rl[e]??0,r=Math.pow(10,d),v=d>0?Math.round(u*r)/r:Math.round(u);dl.value[e]=v,o<1?vl[e]=requestAnimationFrame(c):pl.value[e]=!1};vl[e]=requestAnimationFrame(c)}const gl=n(!1),ml=n(0),kl=n([]),fl=n(0),Tl=n([]),bl=l(()=>({claude:"Claude",codex:"Codex",gemini:"Gemini",opencode:"OpenCode"}[C.channelType]||""));async function xl(){if(["claude","codex","opencode"].includes(C.channelType))try{const e=await O(!1,C.channelType);if(e.success&&e.skills){const a=e.skills.filter(e=>e.installed);ml.value=a.length,kl.value=a.slice(0,10).map(e=>({...e,_uninstalling:!1}))}}catch(e){}}async function _l(){try{const e=await j();if(e.success&&e.servers){const a=Object.values(e.servers).filter(e=>{var a;return!0===(null==(a=e.apps)?void 0:a[C.channelType])});fl.value=a.length,Tl.value=a.slice(0,10).map(e=>({...e,_toggling:!1}))}}catch(e){}}function Cl(e){try{const a=localStorage.getItem(Fa),l=a?JSON.parse(a):{};l[C.channelType]=e,localStorage.setItem(Fa,JSON.stringify(l))}catch(a){}}const wl=n(function(){try{const e=localStorage.getItem(Fa);if(e){return JSON.parse(e)[C.channelType]||!1}}catch(e){}return!1}());async function $l(){wl.value=!wl.value,Cl(wl.value);try{if(await E("channelLocks",C.channelType,wl.value),al.value){const e=al.value.uiConfig||{},a={...e.channelLocks||{}};a[C.channelType]=wl.value,al.value={...al.value,uiConfig:{...e,channelLocks:a}}}}catch(e){}}const ql=n(!0);function zl(e){e.detail&&void 0!==e.detail.showLogs&&(ql.value=e.detail.showLogs)}const Sl=n(Date.now()),Ll=l(()=>{if(!tl.value.running)return"";const e=tl.value.startTime;if(!e)return"";const a=Sl.value-e;if(a<=0)return"";const l=Math.floor(a/1e3),n=Math.floor(l/3600),s=Math.floor(l%3600/60),c=l%60;let t="已运行 ";return n>0&&(t+=`${n}小时`),s>0&&(t+=`${s}分`),(c>0||0===n&&0===s)&&(t+=`${c}秒`),t}),Il=n(null),Ol=l(()=>Qa.value),jl={claude:Wa("claude"),codex:Wa("codex"),gemini:Wa("gemini"),opencode:Wa("opencode")},Ml=l(()=>((jl[C.channelType]||jl.claude).value||[]).slice(0,Ol.value));let Nl=null,Al=null,Fl=null,Pl=!1,Ul=null;const Dl=l(()=>{let e=[];"claude"===C.channelType?e=Va.value||[]:"codex"===C.channelType?e=Ja.value||[]:"gemini"===C.channelType?e=Ga.value||[]:"opencode"===C.channelType&&(e=Ka.value||[]);return[...e.filter(e=>!1!==e.enabled),...e.filter(e=>!1===e.enabled)]});function El(e){const a=Ra[C.channelType];if(!a||!a.channels)return 0;const l=a.channels.find(a=>a.id===e);return l?l.inflight:0}const Vl=l(()=>{var e;const a=Dl.value.filter(e=>!1!==e.enabled).length;return(null==(e=tl.value.proxy)?void 0:e.running)?`${a}个渠道调度中`:Dl.value.length>0?`${a}个渠道已启用`:"无渠道"}),Jl=n({});function Gl(e){return Jl.value[e]||{requests:0,tokens:0,cost:0}}async function Kl(){var e;try{let a;if("claude"===C.channelType?a=await z():"codex"===C.channelType?a=await S():"gemini"===C.channelType?a=await L():"opencode"===C.channelType&&(a=await I()),a&&a.byChannel){const l={};for(const[n,s]of Object.entries(a.byChannel))l[n]={requests:s.requests||0,tokens:(null==(e=s.tokens)?void 0:e.total)||0,cost:s.cost||0};Jl.value=l}}catch(a){}}async function Rl(e){var a,l;const n=Ya(C.channelType);n.value.loading=!0;try{let a;a=e?await Ba(C.channelType):await Ha(C.channelType),!1!==a.success?J.success(e?`${sl.value} 代理已启动`:`${sl.value} 代理已停止`):(J.error(a.error||"操作失败"),n.value.running=!e)}catch(s){J.error((null==(l=null==(a=s.response)?void 0:a.data)?void 0:l.error)||s.message||"操作失败"),n.value.running=!e}finally{n.value.loading=!1}}function Yl(){V.push({name:`${C.channelType}-projects`})}function Bl(){V.push({name:`${C.channelType}-projects`})}function Hl(){var e,a;const l=null==(a=null==(e=al.value)?void 0:e.counts)?void 0:a[C.channelType];il.value.projects=(null==l?void 0:l.projectCount)||0,il.value.sessions=(null==l?void 0:l.sessionCount)||0}async function Wl(){if(al.value&&al.value.todayStats){const e=al.value.todayStats[C.channelType];e&&(ul.value.requests=e.requests||0,ul.value.tokens=e.tokens||0,ul.value.cost=e.cost||0)}Hl()}function Xl(){Xa(C.channelType)}function Zl(){window.dispatchEvent(new CustomEvent("open-skills-drawer"))}return s(Ml,e=>{var a;const l=(null==(a=e[0])?void 0:a.id)||null;if(!l||l===Nl)return void(Nl=l);Nl=l,Ul&&clearTimeout(Ul),Ul=setTimeout(()=>{Kl()},5e3);(!Il.value||Il.value.scrollTop<20)&&_(()=>{Il.value&&(Il.value.scrollTop=0)})}),s(()=>ul.value.requests,e=>{yl("requests",dl.value.requests,e,600)}),s(()=>ul.value.tokens,e=>{yl("tokens",dl.value.tokens,e,600)}),s(()=>ul.value.cost,e=>{yl("cost",dl.value.cost,e,600)}),s(()=>C.channelType,()=>{var e;Nl=(null==(e=Ml.value[0])?void 0:e.id)||null}),s(()=>{var e,a;return null==(a=null==(e=al.value)?void 0:e.counts)?void 0:a[C.channelType]},()=>{Hl()}),s(el,()=>{Pl&&function(){Al&&(clearInterval(Al),Al=null);const e=el.value||30,a=Math.max(1e3*e,1e4);Al=setInterval(()=>{Wl(),Kl()},a)}()}),c(async()=>{await ll(),await Wl(),await Kl(),xl(),_l(),async function(){var e,a;try{if(al.value&&al.value.uiConfig)ql.value=!1!==(null==(e=al.value.uiConfig.panelVisibility)?void 0:e.showLogs);else{const e=await M();e.success&&e.config&&(ql.value=!1!==(null==(a=e.config.panelVisibility)?void 0:a.showLogs))}}catch(l){}}(),async function(){var e,a;try{let l=!1;if(al.value&&al.value.uiConfig)l=(null==(e=al.value.uiConfig.channelLocks)?void 0:e[C.channelType])||!1;else{const e=await M();e.success&&e.config&&(l=(null==(a=e.config.channelLocks)?void 0:a[C.channelType])||!1)}wl.value=l,Cl(l)}catch(l){}}(),window.addEventListener("panel-visibility-change",zl),dl.value={...ul.value},Pl=!0,Fl=setInterval(()=>{Sl.value=Date.now()},1e3)}),t(()=>{Pl=!1,Al&&clearInterval(Al),Fl&&clearInterval(Fl),Ul&&clearTimeout(Ul),window.removeEventListener("panel-visibility-change",zl),Object.values(vl).forEach(e=>{e&&cancelAnimationFrame(e)})}),(a,l)=>{const n=o("n-collapse"),s=o("n-collapse-item");return u(),i("div",ye,[d("div",{class:b(["channel-header",e.channelType])},[d("div",ge,[v(y(ie),{size:16},{default:h(()=>[v(y(B))]),_:1})]),d("div",me,[v(y(ie),{size:20},{default:h(()=>[(u(),p(g(cl.value)))]),_:1})]),d("h2",ke,m(sl.value),1),fl.value>0?(u(),p(y(ve),{key:0,trigger:"click",placement:"bottom",width:340,class:"mcp-popover"},{trigger:h(()=>[v(y(re),{type:"info",size:"small",bordered:!1,class:"mcp-count-tag clickable"},{default:h(()=>[k(" 已启用 "+m(fl.value)+" 个 MCP ",1)]),_:1})]),default:h(()=>[d("div",fe,[d("div",Te,[l[3]||(l[3]=d("span",null,"已启用的 MCP 服务",-1)),v(y(ue),{depth:"3",style:{"font-size":"11px"}},{default:h(()=>[k(m(bl.value)+" 平台",1)]),_:1})]),0===Tl.value.length?(u(),i("div",be,[v(y(ue),{depth:"3"},{default:h(()=>[...l[4]||(l[4]=[k("暂无启用的 MCP 服务",-1)])]),_:1})])):(u(),i("div",xe,[(u(!0),i(f,null,T(Tl.value,e=>(u(),i("div",{key:e.id,class:"mcp-quick-item"},[d("div",_e,[v(y(ie),{size:14},{default:h(()=>[v(y(H))]),_:1})]),d("div",Ce,[d("span",we,m(e.name),1),d("span",$e,m(e.transportType||"stdio"),1)]),v(y(de),{size:"small",value:!0,"onUpdate:value":a=>async function(e,a){e._toggling=!0;try{await N(e.id,C.channelType,a),J.success(a?`已启用 ${e.name}`:`已禁用 ${e.name}`),await _l()}catch(l){J.error("操作失败: "+(l.message||"未知错误"))}finally{e._toggling=!1}}(e,a),loading:e._toggling},null,8,["onUpdate:value","loading"])]))),128))]))])]),_:1})):r("",!0),"claude"===e.channelType?(u(),i("div",qe,[ml.value>0?(u(),p(y(ve),{key:0,trigger:"click",placement:"bottom",width:340,class:"skills-popover"},{trigger:h(()=>[v(y(re),{type:"success",size:"small",bordered:!1,class:"skills-count-tag clickable"},{default:h(()=>[k(m(ml.value)+" 个技能 ",1)]),_:1})]),default:h(()=>[d("div",ze,[d("div",Se,[l[6]||(l[6]=d("span",null,"已安装的技能",-1)),v(y(pe),{text:"",size:"tiny",onClick:Zl},{default:h(()=>[...l[5]||(l[5]=[k(" 管理全部 ",-1)])]),_:1})]),0===kl.value.length?(u(),i("div",Le,[v(y(ue),{depth:"3"},{default:h(()=>[...l[7]||(l[7]=[k("暂无已安装的技能",-1)])]),_:1})])):(u(),i("div",Ie,[(u(!0),i(f,null,T(kl.value,e=>(u(),i("div",{key:e.id,class:"skill-quick-item"},[d("div",Oe,[v(y(ie),{size:14},{default:h(()=>[v(y(G))]),_:1})]),d("div",je,[d("span",Me,m(e.name),1),d("span",Ne,m(e.description||"无描述"),1)]),v(y(pe),{size:"tiny",tertiary:"",type:"error",onClick:a=>async function(e){e._uninstalling=!0;try{const a=await A(e.directory,C.channelType);a.success?(J.success(`已卸载 ${e.name}`),await xl()):J.error(a.error||"卸载失败")}catch(a){J.error("卸载失败: "+(a.message||"未知错误"))}finally{e._uninstalling=!1}}(e),loading:e._uninstalling},{default:h(()=>[...l[8]||(l[8]=[k(" 卸载 ",-1)])]),_:1},8,["onClick","loading"])]))),128))]))])]),_:1})):r("",!0),v(y(he),{trigger:"hover"},{trigger:h(()=>[v(y(pe),{text:"",class:"skills-button",onClick:Zl,title:"Skills 技能管理"},{icon:h(()=>[v(y(ie),{size:18},{default:h(()=>[v(y(G))]),_:1})]),_:1})]),default:h(()=>[l[9]||(l[9]=k(" Skills 技能管理 ",-1))]),_:1})])):r("",!0),v(y(pe),{text:"",class:"lock-button",onClick:$l,title:wl.value?"解锁此列":"锁定此列"},{icon:h(()=>[v(y(ie),{size:18},{default:h(()=>[wl.value?(u(),p(y(W),{key:0})):(u(),p(y(X),{key:1}))]),_:1})]),_:1},8,["title"])],2),wl.value?r("",!0):(u(),i("div",Ae,[d("div",Fe,[d("div",Pe,[v(y(ie),{size:16},{default:h(()=>[v(y(Z))]),_:1}),l[10]||(l[10]=d("h3",{class:"card-title"},"代理控制",-1)),tl.value.running&&Ll.value?(u(),i("span",Ue,m(Ll.value),1)):r("",!0),v(y(de),{value:tl.value.running,"onUpdate:value":[l[0]||(l[0]=e=>tl.value.running=e),Rl],loading:tl.value.loading,size:"small",style:{"margin-left":"auto"}},null,8,["value","loading"])]),d("div",De,[d("div",Ee,[d("div",Ve,[d("div",{class:b(["status-dot",{active:tl.value.running}])},null,2),v(y(ue),{type:tl.value.running?"success":"default",style:{"font-size":"12px"}},{default:h(()=>[k(m(tl.value.running?"运行中":"已停止"),1)]),_:1},8,["type"]),d("span",Je,"端口: "+m(tl.value.port),1)]),v(y(ve),{trigger:"click",placement:"bottom",width:320,class:"channel-popover"},{trigger:h(()=>[v(y(pe),{text:"",size:"tiny",class:"channel-status"},{default:h(()=>[d("span",Ge,m(Vl.value),1)]),_:1})]),default:h(()=>[d("div",Ke,[d("div",Re,[l[12]||(l[12]=d("span",null,"渠道快捷管理",-1)),v(y(ue),{depth:"3",style:{"font-size":"11px"}},{default:h(()=>[...l[11]||(l[11]=[k("点击开关切换状态",-1)])]),_:1})]),0===Dl.value.length?(u(),i("div",Ye,[v(y(ue),{depth:"3"},{default:h(()=>[...l[13]||(l[13]=[k("暂无配置渠道",-1)])]),_:1})])):(u(),i("div",Be,[(u(!0),i(f,null,T(Dl.value,e=>{var a,n;return u(),i("div",{key:e.id,class:b(["channel-quick-item",{disabled:!1===e.enabled}])},[d("div",He,[d("span",We,m(e.name),1),"frozen"===(null==(a=e.health)?void 0:a.status)?(u(),p(y(re),{key:0,size:"tiny",type:"error",bordered:!1},{default:h(()=>[...l[14]||(l[14]=[k(" 冻结 ",-1)])]),_:1})):r("",!0),v(y(de),{size:"small",value:!1!==e.enabled,"onUpdate:value":a=>async function(e,a){try{let l;"claude"===C.channelType?l=F:"codex"===C.channelType?l=P:"gemini"===C.channelType?l=U:"opencode"===C.channelType&&(l=D),l&&(await l(e.id,{enabled:a}),J.success(a?`渠道「${e.name}」已启用`:`渠道「${e.name}」已停用`),await Za())}catch(l){J.error("操作失败: "+l.message)}}(e,a),style:{"margin-left":"auto"}},null,8,["value","onUpdate:value"])]),d("div",Xe,[d("span",Ze,[l[15]||(l[15]=d("span",{class:"metric-label"},"请求",-1)),d("span",Qe,m(Gl(e.id).requests),1)]),d("span",ea,[l[16]||(l[16]=d("span",{class:"metric-label"},"Tokens",-1)),d("span",aa,m((n=Gl(e.id).tokens,n>=1e6?(n/1e6).toFixed(1)+"M":n>=1e3?(n/1e3).toFixed(1)+"K":n.toString())),1)]),d("span",la,[l[17]||(l[17]=d("span",{class:"metric-label"},"权重",-1)),d("span",na,m(e.weight||1),1)]),d("span",sa,[l[18]||(l[18]=d("span",{class:"metric-label"},"并发",-1)),d("span",{class:b(["metric-value",{active:El(e.id)>0}])},m(El(e.id))+m(e.maxConcurrency?`/${e.maxConcurrency}`:""),3)])])],2)}),128))]))])]),_:1})])])]),d("div",ca,[d("div",ta,[v(y(ie),{size:14},{default:h(()=>[v(y(Q))]),_:1}),l[19]||(l[19]=d("h3",{class:"card-title"},"快速访问",-1))]),d("div",oa,[d("div",ia,[d("div",{class:"access-card access-card-projects clickable",onClick:Yl},[d("div",ua,[v(y(ie),{size:16},{default:h(()=>[v(y(ee))]),_:1})]),d("div",da,[l[20]||(l[20]=d("span",{class:"access-label"},"项目",-1)),d("span",ra,m(il.value.projects),1)])]),d("div",{class:"access-card access-card-sessions clickable",onClick:l[1]||(l[1]=e=>gl.value=!0)},[d("div",va,[v(y(ie),{size:16},{default:h(()=>[v(y(ae))]),_:1})]),d("div",pa,[l[21]||(l[21]=d("span",{class:"access-label"},"最新对话",-1)),d("span",ha,m(il.value.sessions),1)])]),d("div",{class:"access-card access-card-goto clickable",onClick:Bl},[d("div",ya,[v(y(ie),{size:16},{default:h(()=>[v(y(le))]),_:1})]),d("div",ga,[l[22]||(l[22]=d("span",{class:"access-label"},"前往",-1)),d("span",ma,m(ol.value),1)])])])])]),d("div",{class:b(["card stats-card",`stats-card-${e.channelType}`])},[d("div",ka,[v(y(ie),{size:14},{default:h(()=>[v(y(ne))]),_:1}),l[23]||(l[23]=d("h3",{class:"card-title"},"今日数据",-1))]),d("div",fa,[d("div",Ta,[d("div",ba,[l[25]||(l[25]=d("div",{class:"stat-icon-dot requests"},null,-1)),d("div",xa,[l[24]||(l[24]=d("span",{class:"stat-label"},"请求",-1)),d("span",{class:b(["stat-value",{animating:pl.value.requests}])},m(dl.value.requests),3)])]),d("div",_a,[l[27]||(l[27]=d("div",{class:"stat-icon-dot tokens"},null,-1)),d("div",Ca,[l[26]||(l[26]=d("span",{class:"stat-label"},"总 Tokens",-1)),d("span",{class:b(["stat-value",{animating:pl.value.tokens}])},m((t=dl.value.tokens,t>=1e6?(t/1e6).toFixed(1)+"M":t>=1e3?(t/1e3).toFixed(1)+"K":t.toString())),3)])]),d("div",wa,[l[29]||(l[29]=d("div",{class:"stat-icon-dot cost"},null,-1)),d("div",$a,[l[28]||(l[28]=d("span",{class:"stat-label"},"成本 / USD",-1)),d("span",{class:b(["stat-value",{animating:pl.value.cost}])},m((c=dl.value.cost,!c||Number.isNaN(c)?"$0":"$"+Number(c).toFixed(3))),3)])])])])],2),Object.keys(hl.value).length>0?(u(),i("div",{key:0,class:b(["card chart-card",`chart-card-${e.channelType}`])},[v(n,{"default-expanded-names":[],accordion:""})],2)):r("",!0),ql.value?(u(),i("div",qa,[v(n,{"default-expanded-names":[],accordion:""},{default:h(()=>[v(s,{name:"realtime-logs"},{header:h(()=>[d("div",za,[v(y(ie),{size:14,style:{"margin-right":"8px"}},{default:h(()=>[v(y(se))]),_:1}),l[30]||(l[30]=d("span",{class:"collapse-title"},"实时日志",-1)),v(y(pe),{text:"",size:"tiny",onClick:x(Xl,["stop"]),style:{"margin-left":"auto"},title:"清空日志"},{icon:h(()=>[v(y(ie),{size:14},{default:h(()=>[v(y(te))]),_:1})]),_:1})])]),default:h(()=>[d("div",Sa,[d("div",La,[d("div",{class:b(["logs-table-header",`logs-header-${e.channelType}`])},[d("div",{class:b(["log-col col-channel",`col-channel-${e.channelType}`])},"渠道",2),d("div",{class:b(["log-col col-token",`col-token-${e.channelType}`])},"请求",2),d("div",{class:b(["log-col col-token",`col-token-${e.channelType}`])},"回复",2),"claude"===e.channelType?(u(),i(f,{key:0},[d("div",{class:b(["log-col col-token",`col-token-${e.channelType}`])},"写入",2),d("div",{class:b(["log-col col-token",`col-token-${e.channelType}`])},"命中",2)],64)):"codex"===e.channelType?(u(),i(f,{key:1},[d("div",{class:b(["log-col col-token",`col-token-${e.channelType}`])},"推理",2),d("div",{class:b(["log-col col-token",`col-token-${e.channelType}`])},"缓存",2)],64)):"gemini"===e.channelType?(u(),i(f,{key:2},[d("div",{class:b(["log-col col-token",`col-token-${e.channelType}`])},"缓存",2),d("div",{class:b(["log-col col-token",`col-token-${e.channelType}`])},"总计",2)],64)):"opencode"===e.channelType?(u(),i(f,{key:3},[d("div",{class:b(["log-col col-token",`col-token-${e.channelType}`])},"缓存",2),d("div",{class:b(["log-col col-token",`col-token-${e.channelType}`])},"总计",2)],64)):r("",!0),d("div",{class:b(["log-col col-time",`col-time-${e.channelType}`])},"时间",2)],2),d("div",{class:"logs-container",ref_key:"logsContainer",ref:Il},[0===Ml.value.length?(u(),i("div",Ia,[v(y(ie),{size:32,depth:"3",style:{"margin-bottom":"8px"}},{default:h(()=>[v(y(se))]),_:1}),v(y(ue),{depth:"3",style:{"font-size":"12px","font-weight":"500"}},{default:h(()=>[...l[31]||(l[31]=[k("暂无实时日志",-1)])]),_:1}),v(y(ue),{depth:"3",style:{"font-size":"11px","margin-top":"4px"}},{default:h(()=>[...l[32]||(l[32]=[k("开启代理后将显示请求记录",-1)])]),_:1})])):r("",!0),(u(!0),i(f,null,T(Ml.value,a=>{var l,n,s,c,t,o,p,g,T,x;return u(),i("div",{key:a.id,class:b(["log-row",{"action-row":"action"===a.type,"new-log":a.isNew}])},["action"===a.type?(u(),i("div",Oa,[v(y(ie),{size:12,color:"#18a058"},{default:h(()=>[v(y(ce))]),_:1}),d("span",ja,m(a.message),1),d("span",Ma,m(a.time),1)])):(u(),i(f,{key:1},[d("div",{class:b(["log-col col-channel",`col-channel-${e.channelType}`])},[v(y(re),{size:"tiny",type:"success"},{default:h(()=>[k(m(a.channel),1)]),_:2},1024)],2),d("div",{class:b(["log-col col-token",`col-token-${e.channelType}`])},m((null==(l=a.tokens)?void 0:l.input)||0),3),d("div",{class:b(["log-col col-token",`col-token-${e.channelType}`])},m((null==(n=a.tokens)?void 0:n.output)||0),3),"claude"===e.channelType?(u(),i(f,{key:0},[d("div",{class:b(["log-col col-token",`col-token-${e.channelType}`])},m((null==(s=a.tokens)?void 0:s.cacheCreation)||0),3),d("div",{class:b(["log-col col-token",`col-token-${e.channelType}`])},m((null==(c=a.tokens)?void 0:c.cacheRead)||0),3)],64)):"codex"===e.channelType?(u(),i(f,{key:1},[d("div",{class:b(["log-col col-token",`col-token-${e.channelType}`])},m((null==(t=a.tokens)?void 0:t.reasoning)||0),3),d("div",{class:b(["log-col col-token",`col-token-${e.channelType}`])},m((null==(o=a.tokens)?void 0:o.cached)||0),3)],64)):"gemini"===e.channelType?(u(),i(f,{key:2},[d("div",{class:b(["log-col col-token",`col-token-${e.channelType}`])},m((null==(p=a.tokens)?void 0:p.cached)||0),3),d("div",{class:b(["log-col col-token",`col-token-${e.channelType}`])},m((null==(g=a.tokens)?void 0:g.total)||0),3)],64)):"opencode"===e.channelType?(u(),i(f,{key:3},[d("div",{class:b(["log-col col-token",`col-token-${e.channelType}`])},m((null==(T=a.tokens)?void 0:T.cached)||0),3),d("div",{class:b(["log-col col-token",`col-token-${e.channelType}`])},m((null==(x=a.tokens)?void 0:x.total)||0),3)],64)):r("",!0),d("div",{class:b(["log-col col-time",`col-time-${e.channelType}`])},m(a.time),3)],64))],2)}),128))],512)])])]),_:1})]),_:1})])):r("",!0)])),wl.value?(u(),i("div",{key:1,class:b(["locked-overlay",`locked-${e.channelType}`])},[d("div",Na,[d("div",Aa,[v(y(ie),{size:48},{default:h(()=>[v(y(W))]),_:1})]),l[34]||(l[34]=d("h3",{class:"locked-title"},"该渠道已锁定",-1)),v(y(ue),{depth:"3",class:"locked-hint"},{default:h(()=>[...l[33]||(l[33]=[k(" 点击上方按钮解锁以查看内容 ",-1)])]),_:1})])],2)):r("",!0),v(q,{visible:gl.value,"onUpdate:visible":l[2]||(l[2]=e=>gl.value=e),channel:e.channelType},null,8,["visible","channel"])]);var c,t}}},[["__scopeId","data-v-6e326af1"]]),Ua=n({theme:"light",panelVisibility:{showChannels:!0,showLogs:!0},channelLocks:{claude:!1,codex:!1,gemini:!1},channelCollapse:{claude:[],codex:[],gemini:[]},channelOrder:{claude:[],codex:[],gemini:[]}});let Da=!1;async function Ea(){if(Da)return Ua.value;try{const e=await M();e.success&&e.config&&(Ua.value=e.config,Da=!0)}catch(e){}return Ua.value}const Va={class:"dashboard-container"},Ja="dashboardChannelOrder",Ga=C({__name:"Home",setup(a){const l=["claude","codex","gemini","opencode"],{uiConfig:s,updateConfig:t,loadUIConfig:o}=(Da||Ea(),{uiConfig:Ua,loadUIConfig:Ea,saveConfig:async function(e){try{const a=await J(e);return!!a.success&&(Ua.value=a.config,!0)}catch(a){return!1}},updateConfig:async function(e,a){try{const l=await V(e,a);return!!l.success&&(Ua.value=l.config,!0)}catch(l){return!1}},updateNestedConfig:async function(e,a,l){try{const n=await E(e,a,l);return!!n.success&&(Ua.value=n.config,!0)}catch(n){return!1}}});function d(e){try{localStorage.setItem(Ja,JSON.stringify(e))}catch(a){}}const r=n(function(){try{const e=localStorage.getItem(Ja);if(e){const a=JSON.parse(e);if(Array.isArray(a)&&4===a.length)return a}}catch(e){}return l}().map(e=>({type:e})));async function g(){const e=r.value.map(e=>e.type);d(e),await t("dashboardChannelOrder",e)}return c(async()=>{if(await o(),s.value.dashboardChannelOrder&&Array.isArray(s.value.dashboardChannelOrder)&&4===s.value.dashboardChannelOrder.length){const e=s.value.dashboardChannelOrder;r.value=e.map(e=>({type:e})),d(e)}}),(a,l)=>(u(),i("div",Va,[v(y(e),{modelValue:r.value,"onUpdate:modelValue":l[0]||(l[0]=e=>r.value=e),class:"dashboard-grid","item-key":"type",animation:200,handle:".drag-handle",onEnd:g},{item:h(({element:e})=>[(u(),p(Pa,{"channel-type":e.type,key:e.type},null,8,["channel-type"]))]),_:1},8,["modelValue"])]))}},[["__scopeId","data-v-4a01933c"]]);export{Ga as default};
@@ -1 +0,0 @@
1
- .channel-column[data-v-6e326af1]{display:flex;flex-direction:column;height:100%;min-height:0;background:var(--gradient-card);border:1px solid var(--border-primary);border-radius:8px;overflow:hidden;box-shadow:var(--shadow-sm)}.channel-header[data-v-6e326af1]{display:flex;align-items:center;gap:10px;padding:12px 14px;background:var(--bg-primary);position:relative}.drag-handle[data-v-6e326af1]{cursor:grab;color:var(--text-tertiary);display:flex;align-items:center;padding:4px;margin:-4px 0 -4px -4px;border-radius:4px;transition:all .2s}.drag-handle[data-v-6e326af1]:hover{color:var(--text-secondary);background:var(--bg-tertiary)}.drag-handle[data-v-6e326af1]:active{cursor:grabbing}.channel-header[data-v-6e326af1]:after{content:"";position:absolute;bottom:0;left:14px;right:14px;height:2px;border-radius:1px}.channel-header.claude[data-v-6e326af1]{background:linear-gradient(135deg,rgba(24,160,88,.08) 0%,transparent 100%)}.channel-header.claude[data-v-6e326af1]:after{background:linear-gradient(90deg,#18a058,#18a0584d)}.channel-header.codex[data-v-6e326af1]{background:linear-gradient(135deg,rgba(59,130,246,.08) 0%,transparent 100%)}.channel-header.codex[data-v-6e326af1]:after{background:linear-gradient(90deg,#3b82f6,#3b82f64d)}.channel-header.gemini[data-v-6e326af1]{background:linear-gradient(135deg,rgba(168,85,247,.08) 0%,transparent 100%)}.channel-header.gemini[data-v-6e326af1]:after{background:linear-gradient(90deg,#a855f7,#a855f74d)}.channel-header.opencode[data-v-6e326af1]{background:linear-gradient(135deg,rgba(234,88,12,.08) 0%,transparent 100%)}.channel-header.opencode[data-v-6e326af1]:after{background:linear-gradient(90deg,#ea580c,#ea580c4d)}.header-icon[data-v-6e326af1]{width:32px;height:32px;border-radius:6px;display:flex;align-items:center;justify-content:center;box-shadow:0 2px 8px #0000001a}.channel-header.claude .header-icon[data-v-6e326af1]{background:linear-gradient(135deg,#18a058,#15803d);color:#fff}.channel-header.codex .header-icon[data-v-6e326af1]{background:linear-gradient(135deg,#3b82f6,#2563eb);color:#fff}.channel-header.gemini .header-icon[data-v-6e326af1]{background:linear-gradient(135deg,#a855f7,#9333ea);color:#fff}.channel-header.opencode .header-icon[data-v-6e326af1]{background:linear-gradient(135deg,#ea580c,#c2410c);color:#fff}.channel-title[data-v-6e326af1]{font-size:15px;font-weight:700;margin:0;color:var(--text-primary);letter-spacing:.3px}.channel-content[data-v-6e326af1]{flex:1;min-height:0;overflow:hidden;padding:10px;display:flex;flex-direction:column;gap:8px}.card[data-v-6e326af1]{background:var(--bg-primary);border:1px solid var(--border-primary);border-radius:8px;overflow:hidden;transition:all .3s cubic-bezier(.4,0,.2,1);box-shadow:0 2px 12px #0000000d;position:relative}.card[data-v-6e326af1]:before{content:"";position:absolute;top:0;left:0;right:0;height:1px;background:linear-gradient(90deg,transparent,rgba(255,255,255,.1),transparent);opacity:0;transition:opacity .3s ease}.card[data-v-6e326af1]:hover{box-shadow:0 6px 20px #0000001a;border-color:var(--border-secondary)}.card[data-v-6e326af1]:hover:before{opacity:1}.card.clickable[data-v-6e326af1]{cursor:pointer}.card.clickable[data-v-6e326af1]:hover{border-color:#18a058;transform:translateY(-2px);box-shadow:0 8px 24px #18a0582e}.card.clickable[data-v-6e326af1]:after{content:"";position:absolute;top:0;right:0;bottom:0;left:0;background:linear-gradient(135deg,rgba(24,160,88,.02) 0%,transparent 100%);opacity:0;transition:opacity .3s ease;pointer-events:none}.card.clickable[data-v-6e326af1]:hover:after{opacity:1}.card-header[data-v-6e326af1]{display:flex;align-items:center;gap:8px;padding:10px 12px;background:linear-gradient(180deg,var(--bg-secondary) 0%,var(--bg-primary) 100%);border-bottom:1px solid var(--border-primary);position:relative;min-height:24px}.card-header.compact[data-v-6e326af1]{padding:8px 12px}.card-header .n-icon[data-v-6e326af1]{color:var(--text-tertiary);transition:color .2s ease}.card:hover .card-header .n-icon[data-v-6e326af1]{color:var(--text-secondary)}.card-title[data-v-6e326af1]{font-size:11px;font-weight:700;margin:0;color:var(--text-secondary);text-transform:uppercase;letter-spacing:.8px}.runtime-badge[data-v-6e326af1]{display:inline-flex;align-items:center;padding:3px 8px;margin-left:8px;font-size:10px;font-weight:600;color:#10b981;background:linear-gradient(135deg,#10b9811a,#34d3991a);border:1px solid rgba(16,185,129,.2);border-radius:4px;white-space:nowrap;animation:pulse-runtime-6e326af1 2s ease-in-out infinite}@keyframes pulse-runtime-6e326af1{0%,to{opacity:1;transform:scale(1)}50%{opacity:.8;transform:scale(.98)}}.card-body[data-v-6e326af1]{padding:12px;background:var(--bg-primary)}.card-body.compact[data-v-6e326af1]{padding:10px 12px}.proxy-control[data-v-6e326af1]{display:flex;justify-content:space-between;align-items:center;gap:16px}.proxy-info[data-v-6e326af1]{display:flex;flex-direction:column;gap:4px}.proxy-info-row[data-v-6e326af1]{display:flex;align-items:center;justify-content:space-between}.proxy-status[data-v-6e326af1]{display:flex;align-items:center;gap:6px}.proxy-port[data-v-6e326af1]{font-size:11px;color:var(--text-secondary);margin-left:6px}.channel-selector[data-v-6e326af1]{display:flex;align-items:center;padding:4px 8px;background:linear-gradient(135deg,var(--bg-secondary) 0%,var(--bg-tertiary) 100%);border:1px solid var(--border-primary);border-radius:4px;color:var(--text-secondary);transition:all .2s ease}.channel-selector[data-v-6e326af1]:hover{background:var(--hover-bg);border-color:var(--border-secondary);color:var(--text-primary)}.channel-selector[data-v-6e326af1]:disabled{opacity:.5;cursor:not-allowed}.channel-name[data-v-6e326af1]{font-size:11px;font-weight:500;max-width:90px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.status-dot[data-v-6e326af1]{width:8px;height:8px;border-radius:50%;background:var(--border-secondary);transition:all .3s ease}.status-dot.active[data-v-6e326af1]{background:#18a058;box-shadow:0 0 8px #18a05880}.quick-stats[data-v-6e326af1]{display:flex;gap:16px;padding:4px 0}.stat-item[data-v-6e326af1]{flex:1;display:flex;flex-direction:column;align-items:center;gap:2px;padding:4px 0}.stat-divider[data-v-6e326af1]{width:1px;background:linear-gradient(180deg,transparent 0%,var(--border-primary) 50%,transparent 100%)}.quick-access-list[data-v-6e326af1]{display:grid;grid-template-columns:repeat(3,1fr);gap:6px}.access-card[data-v-6e326af1]{display:flex;align-items:center;gap:8px;padding:8px 10px;border-radius:6px;background:var(--bg-secondary);border:1px solid var(--border-color);transition:all .3s cubic-bezier(.4,0,.2,1);position:relative;min-height:52px;overflow:hidden}.access-card[data-v-6e326af1]:before{content:"";position:absolute;top:0;right:0;bottom:0;left:0;opacity:0;transition:opacity .3s ease;pointer-events:none}.access-icon[data-v-6e326af1]{width:32px;height:32px;border-radius:5px;display:flex;align-items:center;justify-content:center;flex-shrink:0;transition:all .3s ease}.access-content[data-v-6e326af1]{display:flex;flex-direction:column;gap:4px;flex:1}.access-card-projects .access-icon[data-v-6e326af1]{background:linear-gradient(135deg,#6366f126,#8b5cf626);color:#6366f1}.access-card-projects[data-v-6e326af1]:before{background:linear-gradient(135deg,#6366f114,#8b5cf614)}.access-card-projects:hover .access-icon[data-v-6e326af1]{background:linear-gradient(135deg,#6366f140,#8b5cf640);transform:scale(1.1) rotate(-5deg)}.access-card-sessions .access-icon[data-v-6e326af1]{background:linear-gradient(135deg,#10b98126,#05966926);color:#10b981}.access-card-sessions[data-v-6e326af1]:before{background:linear-gradient(135deg,#10b98114,#05966914)}.access-card-sessions:hover .access-icon[data-v-6e326af1]{background:linear-gradient(135deg,#10b98140,#05966940);transform:scale(1.1) rotate(5deg)}.access-card-goto .access-icon[data-v-6e326af1]{background:linear-gradient(135deg,#f59e0b26,#fb923c26);color:#f59e0b}.access-card-goto[data-v-6e326af1]:before{background:linear-gradient(135deg,#f59e0b14,#fb923c14)}.access-card-goto:hover .access-icon[data-v-6e326af1]{background:linear-gradient(135deg,#f59e0b40,#fb923c40);transform:scale(1.1) translate(3px)}.access-card.clickable[data-v-6e326af1]:hover{transform:translateY(-2px);box-shadow:0 8px 20px #0000001a;border-color:var(--border-secondary)}.access-card.clickable[data-v-6e326af1]:hover:before{opacity:1}.access-card.clickable[data-v-6e326af1]:active{transform:translateY(0)}.access-label[data-v-6e326af1]{display:block;font-size:10px;font-weight:600;color:var(--text-secondary);text-transform:uppercase;letter-spacing:.3px}.access-value[data-v-6e326af1]{display:block;font-size:18px;font-weight:800;color:var(--text-primary);line-height:1}.access-goto[data-v-6e326af1]{display:block;font-size:12px;font-weight:700;color:var(--text-primary);line-height:1.2;white-space:nowrap}.stats-inline[data-v-6e326af1]{display:grid;grid-template-columns:repeat(4,1fr);gap:8px}.stats-inline.stats-3col[data-v-6e326af1]{grid-template-columns:repeat(3,1fr)}.stat-inline-item[data-v-6e326af1]{display:flex;align-items:center;gap:8px;padding:10px;background:var(--bg-secondary);border-radius:6px;border:1px solid var(--border-primary);transition:all .2s ease}.stat-inline-item[data-v-6e326af1]:hover{border-color:var(--border-secondary);background:var(--hover-bg)}.stat-icon-dot[data-v-6e326af1]{width:8px;height:8px;border-radius:50%;flex-shrink:0}.stat-icon-dot.requests[data-v-6e326af1]{background:#3b82f6;box-shadow:0 0 6px #3b82f680}.stat-icon-dot.tokens[data-v-6e326af1]{background:#18a058;box-shadow:0 0 6px #18a05880}.stat-icon-dot.cost[data-v-6e326af1]{background:#f59e0b;box-shadow:0 0 6px #f59e0b80}.stat-info[data-v-6e326af1]{display:flex;flex-direction:column;gap:1px;min-width:0}.stat-label[data-v-6e326af1]{font-size:10px;color:var(--text-tertiary);font-weight:500;text-transform:uppercase;letter-spacing:.2px}.stat-value[data-v-6e326af1]{font-size:16px;font-weight:700;color:var(--text-primary);line-height:1.2;transition:all .3s ease}.stat-value.animating[data-v-6e326af1]{animation:numberChange-6e326af1 .6s ease}@keyframes numberChange-6e326af1{0%{transform:translateY(-6px);opacity:.5}50%{transform:translateY(0);opacity:1;color:var(--primary-color)}to{transform:translateY(0);opacity:1}}.stats-card[data-v-6e326af1],.chart-card[data-v-6e326af1]{border-left:2px solid transparent}.stats-card-claude[data-v-6e326af1],.chart-card[data-v-6e326af1]:has(+.stats-card-claude),.card[data-v-6e326af1]:has(.panel-card):nth-child(4){border-left-color:#18a058}.chart-card.chart-card-claude[data-v-6e326af1]{border-left-color:#18a058}.stats-card-codex[data-v-6e326af1],.chart-card[data-v-6e326af1]:has(+.stats-card-codex),.card[data-v-6e326af1]:has(.panel-card):nth-child(4){border-left-color:#3b82f6}.chart-card.chart-card-codex[data-v-6e326af1]{border-left-color:#3b82f6}.stats-card-gemini[data-v-6e326af1],.chart-card[data-v-6e326af1]:has(+.stats-card-gemini),.card[data-v-6e326af1]:has(.panel-card):nth-child(4){border-left-color:#a855f7}.chart-card.chart-card-gemini[data-v-6e326af1]{border-left-color:#a855f7}.stats-card-opencode[data-v-6e326af1],.chart-card[data-v-6e326af1]:has(+.stats-card-opencode),.card[data-v-6e326af1]:has(.panel-card):nth-child(4){border-left-color:#ea580c}.chart-card.chart-card-opencode[data-v-6e326af1]{border-left-color:#ea580c}.chart-card[data-v-6e326af1]{padding:0;overflow:hidden}.chart-card[data-v-6e326af1] .panel-card{border:none;border-radius:0;box-shadow:none;background:transparent}.stat-requests .stat-value[data-v-6e326af1]{color:#3b82f6}.stat-input .stat-value[data-v-6e326af1]{color:#18a058}.stat-output .stat-value[data-v-6e326af1]{color:#f59e0b}.token-label[data-v-6e326af1]{display:flex;align-items:center;gap:8px}.token-dot[data-v-6e326af1]{width:8px;height:8px;border-radius:50%}.logs-card[data-v-6e326af1]{flex:1;min-height:0;display:flex;flex-direction:column;overflow:hidden;border:1px solid var(--border-primary);border-radius:6px}.logs-card[data-v-6e326af1] .n-collapse,.logs-card[data-v-6e326af1] .n-collapse-item{flex:1;min-height:0;display:flex;flex-direction:column;background:transparent}.logs-card .card-header[data-v-6e326af1]{background:linear-gradient(135deg,var(--bg-secondary) 0%,var(--bg-tertiary) 100%)}.logs-table-wrapper[data-v-6e326af1]{flex:1;min-height:0;display:flex;flex-direction:column;overflow:hidden;background:var(--bg-primary)}.logs-table-header[data-v-6e326af1]{display:flex;padding:10px 12px;background:linear-gradient(180deg,var(--bg-tertiary) 0%,var(--bg-secondary) 100%);border-bottom:2px solid var(--border-primary);font-size:11px;font-weight:700;color:var(--text-tertiary);text-transform:uppercase;letter-spacing:.6px;flex-shrink:0}.logs-header-claude .log-col[data-v-6e326af1]{color:#18a058b3;font-weight:600}.logs-header-codex .log-col[data-v-6e326af1]{color:#3b82f6b3;font-weight:600}.logs-header-gemini .log-col[data-v-6e326af1]{color:#a855f7b3;font-weight:600}.logs-header-opencode .log-col[data-v-6e326af1]{color:#ea580cb3;font-weight:600}[data-theme=dark] .logs-header-claude .log-col[data-v-6e326af1]{color:#34d399a6}[data-theme=dark] .logs-header-codex .log-col[data-v-6e326af1]{color:#60a5faa6}[data-theme=dark] .logs-header-gemini .log-col[data-v-6e326af1]{color:#c084fca6}[data-theme=dark] .logs-header-opencode .log-col[data-v-6e326af1]{color:#fb923ca6}.logs-container[data-v-6e326af1]{flex:1;min-height:0;overflow-y:auto;overflow-x:hidden}.logs-container[data-v-6e326af1]::-webkit-scrollbar{width:4px}.logs-container[data-v-6e326af1]::-webkit-scrollbar-thumb{background:#18a0584d;border-radius:2px}.logs-container[data-v-6e326af1]::-webkit-scrollbar-thumb:hover{background:#18a05880}.empty-logs[data-v-6e326af1]{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:40px 20px;color:var(--text-tertiary);min-height:200px;text-align:center}.log-row[data-v-6e326af1]{display:flex;align-items:center;padding:10px 12px;min-height:40px;border-bottom:1px solid var(--border-primary);font-size:12px;transition:all .2s ease;background:var(--bg-primary);position:relative}.log-row[data-v-6e326af1]:nth-child(2n){background:var(--bg-secondary)}.log-row[data-v-6e326af1]:hover{background:var(--hover-bg);transform:translate(2px)}.log-row.new-log[data-v-6e326af1]{animation:newLogPulse-6e326af1 4.5s cubic-bezier(.25,.46,.45,.94) forwards;border-left:3px solid #18a058}@keyframes newLogPulse-6e326af1{0%{background:linear-gradient(90deg,#18a05826,#18a0580f);box-shadow:0 0 8px #18a05833}5%{background:linear-gradient(90deg,#18a0582e,#18a05814);box-shadow:0 0 12px 1px #18a05840}15%{background:linear-gradient(90deg,#18a05829,#18a05812);box-shadow:0 0 10px 1px #18a05833}30%{background:linear-gradient(90deg,#18a0581f,#18a0580d);box-shadow:0 0 6px #18a05826}50%{background:linear-gradient(90deg,#18a05814,#18a05808);box-shadow:0 0 4px #18a0581a}70%{background:linear-gradient(90deg,#18a0580a,#18a05804);box-shadow:0 0 2px #18a0580f}85%{background:linear-gradient(90deg,#18a05805,#18a05802);box-shadow:0 0 1px #18a05808}to{background:transparent;box-shadow:0 0 #18a05800;border-left-color:transparent}}[data-theme=dark] .log-row.new-log[data-v-6e326af1]{animation:newLogPulseDark-6e326af1 4.5s cubic-bezier(.25,.46,.45,.94) forwards}@keyframes newLogPulseDark-6e326af1{0%{background:linear-gradient(90deg,#18a05833,#18a05814);box-shadow:0 0 10px #18a05840}5%{background:linear-gradient(90deg,#18a0583d,#18a0581a);box-shadow:0 0 14px 2px #18a0584d}15%{background:linear-gradient(90deg,#18a05836,#18a05817);box-shadow:0 0 12px 1px #18a05840}30%{background:linear-gradient(90deg,#18a05829,#18a05812);box-shadow:0 0 8px 1px #18a0582e}50%{background:linear-gradient(90deg,#18a0581c,#18a0580b);box-shadow:0 0 5px #18a0581f}70%{background:linear-gradient(90deg,#18a0580f,#18a05806);box-shadow:0 0 3px #18a05814}85%{background:linear-gradient(90deg,#18a05808,#18a05803);box-shadow:0 0 1px #18a0580a}to{background:transparent;box-shadow:0 0 #18a05800;border-left-color:transparent}}.log-row.new-log.action-row[data-v-6e326af1]{border-left:3px solid #18a058}.log-row.action-row[data-v-6e326af1]{background:linear-gradient(90deg,#18a0581f,#18a0580a);border-left:3px solid #18a058;padding-left:8px}.log-row.action-row[data-v-6e326af1]:hover{background:linear-gradient(90deg,#18a0582e,#18a05814)}.action-content[data-v-6e326af1]{display:flex;align-items:center;gap:8px;width:100%}.action-msg[data-v-6e326af1]{flex:1;font-size:11px;color:#18a058;font-weight:600;letter-spacing:.2px}.action-time[data-v-6e326af1]{font-size:10px;font-family:SF Mono,Monaco,monospace;color:var(--text-tertiary);background:#18a0581a;padding:2px 6px;border-radius:4px}.log-col[data-v-6e326af1]{display:flex;align-items:center;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.col-channel[data-v-6e326af1]{min-width:0}.col-channel .n-tag[data-v-6e326af1]{max-width:100%;font-size:11px;font-weight:600;border-radius:4px;padding:3px 10px}.col-token[data-v-6e326af1]{justify-content:center;font-family:SF Mono,Monaco,Consolas,monospace;font-size:12px;font-weight:600;color:var(--text-secondary);background:#00000008;padding:4px 8px;border-radius:4px;margin:0 3px}[data-theme=dark] .col-token[data-v-6e326af1]{background:#ffffff0f}.col-time[data-v-6e326af1]{justify-content:flex-end;font-family:SF Mono,Monaco,Consolas,monospace;font-size:11px;font-weight:500;color:var(--text-tertiary);padding-right:2px;opacity:.85}.log-row:hover .col-time[data-v-6e326af1]{opacity:1;color:var(--text-secondary)}.col-channel-claude[data-v-6e326af1]{flex:2 1 60px;min-width:50px}.col-token-claude[data-v-6e326af1]{flex:1 1 40px;min-width:35px}.col-time-claude[data-v-6e326af1]{flex:1.5 1 55px;min-width:50px}.col-channel-codex[data-v-6e326af1]{flex:2 1 60px;min-width:50px}.col-token-codex[data-v-6e326af1]{flex:1 1 40px;min-width:35px}.col-time-codex[data-v-6e326af1]{flex:1.5 1 55px;min-width:50px}.col-channel-gemini[data-v-6e326af1]{flex:2.5 1 70px;min-width:55px}.col-token-gemini[data-v-6e326af1]{flex:1.2 1 45px;min-width:40px}.col-time-gemini[data-v-6e326af1]{flex:1.8 1 60px;min-width:55px}.col-channel-opencode[data-v-6e326af1]{flex:2.5 1 70px;min-width:55px}.col-token-opencode[data-v-6e326af1]{flex:1.2 1 45px;min-width:40px}.col-time-opencode[data-v-6e326af1]{flex:1.8 1 60px;min-width:55px}.claude-extra-area[data-v-6e326af1]{display:flex;align-items:center;gap:6px;margin-left:auto}.mcp-count-tag[data-v-6e326af1],.skills-count-tag[data-v-6e326af1]{font-size:10px;font-weight:500;padding:0 8px;height:22px;line-height:22px;border-radius:4px;cursor:pointer;transition:all .2s ease}.mcp-count-tag.clickable[data-v-6e326af1]:hover,.skills-count-tag.clickable[data-v-6e326af1]:hover{transform:scale(1.03);filter:brightness(1.1)}.mcp-quick-panel[data-v-6e326af1],.skills-quick-panel[data-v-6e326af1]{padding:2px 0}.mcp-quick-panel .panel-title[data-v-6e326af1],.skills-quick-panel .panel-title[data-v-6e326af1]{display:flex;justify-content:space-between;align-items:center;padding:6px 10px 8px;border-bottom:1px solid var(--border-primary);margin-bottom:4px}.mcp-quick-panel .panel-title span[data-v-6e326af1]:first-child,.skills-quick-panel .panel-title span[data-v-6e326af1]:first-child{font-size:13px;font-weight:600;color:var(--text-primary)}.no-items[data-v-6e326af1]{padding:16px 10px;text-align:center}.mcp-quick-list[data-v-6e326af1],.skills-quick-list[data-v-6e326af1]{max-height:300px;overflow-y:auto;padding:0 4px 4px}.mcp-quick-item[data-v-6e326af1],.skill-quick-item[data-v-6e326af1]{display:flex;align-items:center;gap:8px;padding:8px 10px;border-radius:5px;margin-bottom:4px;background:var(--bg-secondary);transition:all .2s ease}.mcp-quick-item[data-v-6e326af1]:hover,.skill-quick-item[data-v-6e326af1]:hover{background:var(--hover-bg)}.mcp-item-icon[data-v-6e326af1],.skill-item-icon[data-v-6e326af1]{width:24px;height:24px;border-radius:5px;display:flex;align-items:center;justify-content:center;flex-shrink:0}.mcp-item-icon[data-v-6e326af1]{background:linear-gradient(135deg,#3b82f626,#3b82f60d);color:#3b82f6}.skill-item-icon[data-v-6e326af1]{background:linear-gradient(135deg,#18a05826,#18a0580d);color:#18a058}.mcp-item-info[data-v-6e326af1],.skill-item-info[data-v-6e326af1]{flex:1;min-width:0;display:flex;flex-direction:column;gap:1px}.mcp-item-name[data-v-6e326af1],.skill-item-name[data-v-6e326af1]{font-size:12px;font-weight:600;color:var(--text-primary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.mcp-item-type[data-v-6e326af1]{font-size:10px;color:var(--text-tertiary);text-transform:uppercase}.skill-item-desc[data-v-6e326af1]{font-size:10px;color:var(--text-tertiary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.mcp-item-status[data-v-6e326af1]{flex-shrink:0}.mcp-item-status .status-dot[data-v-6e326af1]{width:8px;height:8px;border-radius:50%;background:var(--border-secondary)}.mcp-item-status.online .status-dot[data-v-6e326af1]{background:#18a058;box-shadow:0 0 6px #18a05880}.mcp-item-status.error .status-dot[data-v-6e326af1]{background:#d03050;box-shadow:0 0 6px #d0305080}.mcp-quick-list[data-v-6e326af1]::-webkit-scrollbar,.skills-quick-list[data-v-6e326af1]::-webkit-scrollbar{width:4px}.mcp-quick-list[data-v-6e326af1]::-webkit-scrollbar-thumb,.skills-quick-list[data-v-6e326af1]::-webkit-scrollbar-thumb{background:#00000026;border-radius:2px}[data-theme=dark] .mcp-quick-list[data-v-6e326af1]::-webkit-scrollbar-thumb,[data-theme=dark] .skills-quick-list[data-v-6e326af1]::-webkit-scrollbar-thumb{background:#ffffff26}.skills-button[data-v-6e326af1]{padding:6px!important;width:30px;height:30px;display:flex;align-items:center;justify-content:center;border-radius:5px;background:var(--bg-secondary);border:1px solid var(--border-primary);transition:all .25s cubic-bezier(.4,0,.2,1);box-shadow:0 2px 4px #0000000d}.skills-button .n-icon[data-v-6e326af1]{color:var(--text-color-3);transition:all .25s ease}.skills-button[data-v-6e326af1]:hover{background:linear-gradient(135deg,#18a0581a,#18a0580d);border-color:#18a0584d;box-shadow:0 4px 12px #18a05826;transform:translateY(-1px)}.skills-button:hover .n-icon[data-v-6e326af1]{color:#18a058;transform:scale(1.1)}.skills-button[data-v-6e326af1]:active{transform:translateY(0);box-shadow:0 2px 4px #0000000d}.lock-button[data-v-6e326af1]{margin-left:6px;padding:6px!important;width:30px;height:30px;display:flex;align-items:center;justify-content:center;border-radius:5px;background:var(--bg-secondary);border:1px solid var(--border-primary);transition:all .25s cubic-bezier(.4,0,.2,1);box-shadow:0 2px 4px #0000000d}.lock-button .n-icon[data-v-6e326af1]{color:var(--text-color-3);transition:all .25s ease}.lock-button[data-v-6e326af1]:hover{background:linear-gradient(135deg,#6b72801a,#6b72800d);border-color:#6b72804d;box-shadow:0 4px 12px #0000001a;transform:translateY(-1px)}.lock-button:hover .n-icon[data-v-6e326af1]{color:var(--text-color-1);transform:scale(1.1)}.lock-button[data-v-6e326af1]:active{transform:translateY(0);box-shadow:0 2px 4px #0000000d}.locked-overlay[data-v-6e326af1]{flex:1;display:flex;align-items:center;justify-content:center;border-radius:6px;margin:10px;position:relative;overflow:hidden;background:var(--bg-secondary);border:1px solid var(--border-primary);-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px)}.locked-overlay[data-v-6e326af1]:before{content:"";position:absolute;width:400px;height:400px;border-radius:50%;top:50%;left:50%;transform:translate(-50%,-50%);opacity:.4;filter:blur(60px);pointer-events:none}.locked-claude[data-v-6e326af1]{background:linear-gradient(135deg,rgba(24,160,88,.03) 0%,var(--bg-secondary) 50%,rgba(24,160,88,.02) 100%)}.locked-claude[data-v-6e326af1]:before{background:radial-gradient(circle,rgba(24,160,88,.15) 0%,transparent 70%)}.locked-codex[data-v-6e326af1]{background:linear-gradient(135deg,rgba(59,130,246,.03) 0%,var(--bg-secondary) 50%,rgba(59,130,246,.02) 100%)}.locked-codex[data-v-6e326af1]:before{background:radial-gradient(circle,rgba(59,130,246,.15) 0%,transparent 70%)}.locked-gemini[data-v-6e326af1]{background:linear-gradient(135deg,rgba(168,85,247,.03) 0%,var(--bg-secondary) 50%,rgba(168,85,247,.02) 100%)}.locked-gemini[data-v-6e326af1]:before{background:radial-gradient(circle,rgba(168,85,247,.15) 0%,transparent 70%)}.locked-opencode[data-v-6e326af1]{background:linear-gradient(135deg,rgba(234,88,12,.03) 0%,var(--bg-secondary) 50%,rgba(234,88,12,.02) 100%)}.locked-opencode[data-v-6e326af1]:before{background:radial-gradient(circle,rgba(234,88,12,.15) 0%,transparent 70%)}.locked-content[data-v-6e326af1]{display:flex;flex-direction:column;align-items:center;gap:20px;padding:60px 40px;text-align:center;position:relative;z-index:1}.lock-icon[data-v-6e326af1]{width:96px;height:96px;display:flex;align-items:center;justify-content:center;border-radius:10px;background:var(--bg-primary);border:2px solid var(--border-primary);margin-bottom:8px;position:relative;box-shadow:0 8px 24px #0000001f;animation:lock-float-6e326af1 3s ease-in-out infinite}@keyframes lock-float-6e326af1{0%,to{transform:translateY(0)}50%{transform:translateY(-6px)}}.lock-icon[data-v-6e326af1]:before{content:"";position:absolute;top:-8px;right:-8px;bottom:-8px;left:-8px;border-radius:20px;opacity:.6;filter:blur(12px)}.locked-claude .lock-icon[data-v-6e326af1]{background:linear-gradient(135deg,rgba(24,160,88,.12) 0%,var(--bg-primary) 100%);border-color:#18a05840;box-shadow:0 8px 24px #18a05826,0 0 0 1px #18a0581a inset}.locked-claude .lock-icon[data-v-6e326af1]:before{background:radial-gradient(circle,rgba(24,160,88,.3) 0%,transparent 60%)}.locked-claude .lock-icon .n-icon[data-v-6e326af1]{color:#18a058;filter:drop-shadow(0 2px 4px rgba(24,160,88,.3))}.locked-codex .lock-icon[data-v-6e326af1]{background:linear-gradient(135deg,rgba(59,130,246,.12) 0%,var(--bg-primary) 100%);border-color:#3b82f640;box-shadow:0 8px 24px #3b82f626,0 0 0 1px #3b82f61a inset}.locked-codex .lock-icon[data-v-6e326af1]:before{background:radial-gradient(circle,rgba(59,130,246,.3) 0%,transparent 60%)}.locked-codex .lock-icon .n-icon[data-v-6e326af1]{color:#3b82f6;filter:drop-shadow(0 2px 4px rgba(59,130,246,.3))}.locked-gemini .lock-icon[data-v-6e326af1]{background:linear-gradient(135deg,rgba(168,85,247,.12) 0%,var(--bg-primary) 100%);border-color:#a855f740;box-shadow:0 8px 24px #a855f726,0 0 0 1px #a855f71a inset}.locked-gemini .lock-icon[data-v-6e326af1]:before{background:radial-gradient(circle,rgba(168,85,247,.3) 0%,transparent 60%)}.locked-gemini .lock-icon .n-icon[data-v-6e326af1]{color:#a855f7;filter:drop-shadow(0 2px 4px rgba(168,85,247,.3))}.locked-opencode .lock-icon[data-v-6e326af1]{background:linear-gradient(135deg,rgba(234,88,12,.12) 0%,var(--bg-primary) 100%);border-color:#ea580c40;box-shadow:0 8px 24px #ea580c26,0 0 0 1px #ea580c1a inset}.locked-opencode .lock-icon[data-v-6e326af1]:before{background:radial-gradient(circle,rgba(234,88,12,.3) 0%,transparent 60%)}.locked-opencode .lock-icon .n-icon[data-v-6e326af1]{color:#ea580c;filter:drop-shadow(0 2px 4px rgba(234,88,12,.3))}.lock-icon .n-icon[data-v-6e326af1]{opacity:.85;position:relative;z-index:1}.locked-title[data-v-6e326af1]{font-size:17px;font-weight:600;color:var(--text-color-1);margin:0;letter-spacing:.3px}.locked-hint[data-v-6e326af1]{font-size:13px;color:var(--text-color-3);max-width:220px;line-height:1.7;opacity:.9}.channel-status[data-v-6e326af1]{cursor:pointer;padding:4px 8px!important;border-radius:4px;transition:all .2s ease}.channel-status[data-v-6e326af1]:hover{background:var(--hover-bg)}.channel-quick-panel[data-v-6e326af1]{padding:4px 0}.panel-title[data-v-6e326af1]{display:flex;justify-content:space-between;align-items:center;padding:8px 12px 12px;border-bottom:1px solid var(--border-primary);margin-bottom:8px}.panel-title span[data-v-6e326af1]:first-child{font-size:13px;font-weight:600;color:var(--text-primary)}.no-channels[data-v-6e326af1]{padding:24px 12px;text-align:center}.channel-quick-list[data-v-6e326af1]{max-height:360px;overflow-y:auto}.channel-quick-item[data-v-6e326af1]{display:flex;flex-direction:column;gap:8px;padding:10px 12px;border-radius:6px;margin:0 4px 6px;background:var(--bg-secondary);transition:all .2s ease}.channel-quick-item[data-v-6e326af1]:hover{background:var(--hover-bg)}.channel-quick-item.disabled[data-v-6e326af1]{opacity:.6}.channel-quick-info[data-v-6e326af1]{display:flex;align-items:center;gap:8px;width:100%}.channel-quick-name[data-v-6e326af1]{font-size:13px;font-weight:600;color:var(--text-primary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.channel-metrics[data-v-6e326af1]{display:flex;gap:6px;width:100%}.channel-metrics .metric-item[data-v-6e326af1]{flex:1;display:flex;flex-direction:column;align-items:center;gap:2px;padding:6px 4px;background:var(--bg-primary);border-radius:4px;border:1px solid var(--border-primary)}.channel-metrics .metric-label[data-v-6e326af1]{font-size:10px;color:var(--text-tertiary);font-weight:500}.channel-metrics .metric-value[data-v-6e326af1]{font-size:12px;font-weight:700;color:var(--text-primary);font-family:SF Mono,Monaco,monospace}.channel-metrics .metric-value.active[data-v-6e326af1]{color:#f59e0b}.channel-quick-item.disabled .channel-metrics .metric-value[data-v-6e326af1]{color:var(--text-tertiary)}.channel-quick-list[data-v-6e326af1]::-webkit-scrollbar{width:4px}.channel-quick-list[data-v-6e326af1]::-webkit-scrollbar-thumb{background:#00000026;border-radius:2px}[data-theme=dark] .channel-quick-list[data-v-6e326af1]::-webkit-scrollbar-thumb{background:#ffffff26}@media (max-width: 1024px){.channel-column[data-v-6e326af1]{border-radius:6px}.card-header[data-v-6e326af1]{padding:8px 10px}.card-title[data-v-6e326af1]{font-size:13px}.stats-inline[data-v-6e326af1]{gap:6px}.stat-inline-item[data-v-6e326af1]{padding:8px}.stat-value[data-v-6e326af1]{font-size:14px}.stat-label[data-v-6e326af1]{font-size:9px}.logs-table-header[data-v-6e326af1]{padding:8px 10px;font-size:10px}.log-row[data-v-6e326af1]{padding:8px 10px;font-size:11px}}@media (max-width: 768px){.channel-column[data-v-6e326af1]{border-radius:6px;min-height:300px;height:auto;max-height:400px}.card-header[data-v-6e326af1]{padding:8px;gap:6px}.card-title[data-v-6e326af1]{font-size:12px}.stats-inline[data-v-6e326af1]{gap:4px}.stat-inline-item[data-v-6e326af1]{padding:6px;gap:6px}.stat-icon-dot[data-v-6e326af1]{width:6px;height:6px}.stat-value[data-v-6e326af1]{font-size:13px}.stat-label[data-v-6e326af1]{font-size:8px}.logs-card[data-v-6e326af1]{min-height:150px}.logs-table-header[data-v-6e326af1]{padding:6px 8px;font-size:9px}.log-row[data-v-6e326af1]{padding:6px 8px;font-size:10px;min-height:32px}.col-token[data-v-6e326af1]{font-size:10px;padding:2px 4px}.col-time[data-v-6e326af1]{font-size:9px}.mcp-count-tag[data-v-6e326af1],.skills-count-tag[data-v-6e326af1]{font-size:9px;padding:0 6px;height:18px;line-height:18px}.skills-button[data-v-6e326af1]{padding:4px 8px;font-size:10px;gap:4px}.lock-button[data-v-6e326af1]{width:26px;height:26px}}@media (max-width: 640px){.channel-column[data-v-6e326af1]{min-height:250px;max-height:350px}.card-header[data-v-6e326af1]{padding:6px;gap:4px;flex-wrap:wrap}.card-title[data-v-6e326af1]{font-size:11px}.stats-card .card-content[data-v-6e326af1]{padding:6px}.stats-inline[data-v-6e326af1]{gap:3px;flex-wrap:wrap}.stat-inline-item[data-v-6e326af1]{padding:5px;gap:4px;min-width:calc(33% - 3px);flex:1 1 auto}.stat-icon-dot[data-v-6e326af1]{width:5px;height:5px}.stat-value[data-v-6e326af1]{font-size:12px}.stat-label[data-v-6e326af1]{font-size:7px}.logs-card[data-v-6e326af1]{min-height:120px}.logs-table-header[data-v-6e326af1]{padding:5px 6px;font-size:8px;letter-spacing:.3px}.log-row[data-v-6e326af1]{padding:5px 6px;font-size:9px;min-height:28px}.col-channel .n-tag[data-v-6e326af1]{font-size:9px;padding:2px 6px}.col-token[data-v-6e326af1]{font-size:9px;padding:2px 3px;margin:0 1px}.col-time[data-v-6e326af1]{font-size:8px}.claude-extra-area[data-v-6e326af1]{gap:4px}.mcp-count-tag[data-v-6e326af1],.skills-count-tag[data-v-6e326af1]{font-size:8px;padding:0 4px;height:16px;line-height:16px}.skills-button[data-v-6e326af1]{padding:3px 6px;font-size:9px;gap:3px}.skills-button .n-icon[data-v-6e326af1]{font-size:12px!important}.lock-button[data-v-6e326af1]{width:24px;height:24px;margin-left:4px}.lock-button .n-icon[data-v-6e326af1]{font-size:12px!important}.locked-content[data-v-6e326af1]{padding:30px 20px;gap:12px}.lock-icon[data-v-6e326af1]{width:64px;height:64px}.lock-icon .n-icon[data-v-6e326af1]{font-size:28px!important}.lock-title[data-v-6e326af1]{font-size:14px}.lock-subtitle[data-v-6e326af1]{font-size:10px}.unlock-btn[data-v-6e326af1]{padding:8px 16px;font-size:11px}}@media (max-width: 480px){.channel-column[data-v-6e326af1]{min-height:220px;max-height:300px}.card-header[data-v-6e326af1]{padding:5px}.card-title[data-v-6e326af1]{font-size:10px}.stats-inline[data-v-6e326af1]{gap:2px}.stat-inline-item[data-v-6e326af1]{padding:4px;gap:3px}.stat-value[data-v-6e326af1]{font-size:11px}.stat-label[data-v-6e326af1]{font-size:6px}.logs-table-header[data-v-6e326af1]{padding:4px 5px;font-size:7px}.log-row[data-v-6e326af1]{padding:4px 5px;font-size:8px;min-height:24px}.col-token[data-v-6e326af1]{font-size:8px}.col-time[data-v-6e326af1]{font-size:7px}}.collapse-header[data-v-6e326af1]{display:flex;align-items:center;width:100%;font-weight:500;font-size:13px;color:var(--text-color-1)}.collapse-title[data-v-6e326af1]{flex:1}.collapse-content[data-v-6e326af1]{flex:1;min-height:0;display:flex;flex-direction:column;padding-top:8px}.scrollable-content[data-v-6e326af1]{flex:1;min-height:0;overflow-y:auto;overflow-x:hidden}.scrollable-content[data-v-6e326af1]::-webkit-scrollbar{width:6px}.scrollable-content[data-v-6e326af1]::-webkit-scrollbar-track{background:#0000000d;border-radius:3px}.scrollable-content[data-v-6e326af1]::-webkit-scrollbar-thumb{background:#0003;border-radius:3px;transition:background .2s}.scrollable-content[data-v-6e326af1]::-webkit-scrollbar-thumb:hover{background:#0000004d}.card[data-v-6e326af1]:not(.logs-card) .n-collapse{background:transparent}.card[data-v-6e326af1]:not(.logs-card) .n-collapse-item{background:transparent}.card[data-v-6e326af1] .n-collapse-item__header{padding:12px 16px;background:transparent;transition:all .3s ease}.card[data-v-6e326af1] .n-collapse-item__header:hover{background:#00000005}.card[data-v-6e326af1] .n-collapse-item__header-main{width:100%}.card[data-v-6e326af1]:not(.logs-card) .n-collapse-item__content-wrapper{padding:0 16px 12px}.card[data-v-6e326af1]:not(.logs-card) .n-collapse-item__content-inner{padding-top:0}.logs-card[data-v-6e326af1] .n-collapse-item__content-wrapper{padding:0 16px;flex:1;min-height:0;display:flex;flex-direction:column}.logs-card[data-v-6e326af1] .n-collapse-item__content-inner{padding-top:0;flex:1;min-height:0;display:flex;flex-direction:column}.chart-card[data-v-6e326af1]:has(.n-collapse),.logs-card[data-v-6e326af1]:has(.n-collapse){padding:0}.collapse-content .logs-table-wrapper[data-v-6e326af1]{margin:0}@media (max-width: 480px){.collapse-header[data-v-6e326af1]{font-size:11px}}.dashboard-container[data-v-4a01933c]{height:100%;background:var(--bg-primary);overflow:hidden;padding:12px;box-sizing:border-box;display:flex;flex-direction:column}.dashboard-grid[data-v-4a01933c]{display:grid;grid-template-columns:repeat(4,1fr);gap:12px;flex:1;min-height:0;overflow:hidden;box-sizing:border-box}.dashboard-grid[data-v-4a01933c] .sortable-ghost{opacity:.4}.dashboard-grid[data-v-4a01933c] .sortable-chosen{box-shadow:0 8px 24px #00000026}@media (max-width: 1600px){.dashboard-grid[data-v-4a01933c]{grid-template-columns:repeat(3,1fr)}}@media (max-width: 1200px){.dashboard-grid[data-v-4a01933c]{grid-template-columns:repeat(2,1fr)}}@media (max-width: 1024px){.dashboard-container[data-v-4a01933c]{padding:10px}.dashboard-grid[data-v-4a01933c]{gap:10px}}@media (max-width: 900px){.dashboard-grid[data-v-4a01933c]{grid-template-columns:1fr}}@media (max-width: 768px){.dashboard-container[data-v-4a01933c]{padding:8px;overflow-y:auto}.dashboard-grid[data-v-4a01933c]{gap:8px;overflow:visible;min-height:auto}}@media (max-width: 640px){.dashboard-container[data-v-4a01933c]{padding:6px}.dashboard-grid[data-v-4a01933c]{gap:6px}}@media (max-width: 480px){.dashboard-container[data-v-4a01933c]{padding:4px}.dashboard-grid[data-v-4a01933c]{gap:4px}}