@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.
- package/CHANGELOG.md +24 -0
- package/dist/web/assets/{ConfigTemplates-ZrK_s7ma.js → ConfigTemplates-DvcbKKdS.js} +1 -1
- package/dist/web/assets/Home-BJKPCBuk.css +1 -0
- package/dist/web/assets/Home-Cw-F_Wnu.js +1 -0
- package/dist/web/assets/{PluginManager-BD7QUZbU.js → PluginManager-jy_4GVxI.js} +1 -1
- package/dist/web/assets/{ProjectList-DRb1DuHV.js → ProjectList-Df1-NcNr.js} +1 -1
- package/dist/web/assets/{SessionList-lZ0LKzfT.js → SessionList-UWcZtC2r.js} +1 -1
- package/dist/web/assets/{SkillManager-C1xG5B4Q.js → SkillManager-IRdseMKB.js} +1 -1
- package/dist/web/assets/{Terminal-DksBo_lM.js → Terminal-BasTyDut.js} +1 -1
- package/dist/web/assets/{WorkspaceManager-Burx7XOo.js → WorkspaceManager-D-D2kK1V.js} +1 -1
- package/dist/web/assets/index-CoB3zF0K.css +1 -0
- package/dist/web/assets/index-CryrSLv8.js +2 -0
- package/dist/web/index.html +2 -2
- package/package.json +1 -1
- package/src/config/default.js +2 -0
- package/src/config/model-metadata.js +415 -0
- package/src/config/model-pricing.js +23 -93
- package/src/server/api/opencode-channels.js +84 -6
- package/src/server/api/opencode-proxy.js +41 -32
- package/src/server/api/opencode-sessions.js +4 -62
- package/src/server/api/settings.js +111 -0
- package/src/server/codex-proxy-server.js +6 -4
- package/src/server/gemini-proxy-server.js +6 -4
- package/src/server/index.js +13 -4
- package/src/server/opencode-proxy-server.js +1197 -86
- package/src/server/proxy-server.js +6 -4
- package/src/server/services/codex-sessions.js +105 -6
- package/src/server/services/env-checker.js +24 -1
- package/src/server/services/env-manager.js +29 -1
- package/src/server/services/opencode-channels.js +3 -1
- package/src/server/services/opencode-sessions.js +486 -218
- package/src/server/services/opencode-settings-manager.js +172 -36
- package/src/server/services/response-decoder.js +21 -0
- package/src/server/websocket-server.js +24 -5
- package/dist/web/assets/Home-B8YfhZ3c.js +0 -1
- package/dist/web/assets/Home-Di2qsylF.css +0 -1
- package/dist/web/assets/index-Ufv5rCa5.css +0 -1
- 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
|
-
|
|
116
|
-
|
|
117
|
-
if
|
|
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 `${
|
|
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
|
-
|
|
145
|
-
|
|
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
|
-
|
|
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
|
-
|
|
172
|
-
|
|
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
|
-
|
|
266
|
-
|
|
267
|
-
|
|
268
|
-
|
|
269
|
-
|
|
270
|
-
|
|
271
|
-
|
|
272
|
-
|
|
273
|
-
|
|
274
|
-
|
|
275
|
-
|
|
276
|
-
|
|
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
|
-
//
|
|
280
|
-
|
|
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
|
-
|
|
284
|
-
|
|
285
|
-
|
|
286
|
-
|
|
287
|
-
|
|
288
|
-
|
|
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
|
-
|
|
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}}
|