@agent-link/server 0.1.187 → 0.1.188

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 (54) hide show
  1. package/dist/index.js +13 -15
  2. package/dist/index.js.map +1 -1
  3. package/package.json +3 -3
  4. package/web/dist/assets/index-C9bIrYkZ.js +320 -0
  5. package/web/dist/assets/index-C9bIrYkZ.js.map +1 -0
  6. package/web/dist/assets/index-Y1FN_mFe.css +1 -0
  7. package/web/{index.html → dist/index.html} +2 -19
  8. package/web/app.js +0 -2881
  9. package/web/css/ask-question.css +0 -333
  10. package/web/css/base.css +0 -270
  11. package/web/css/btw.css +0 -148
  12. package/web/css/chat.css +0 -176
  13. package/web/css/file-browser.css +0 -499
  14. package/web/css/input.css +0 -671
  15. package/web/css/loop.css +0 -674
  16. package/web/css/markdown.css +0 -169
  17. package/web/css/responsive.css +0 -314
  18. package/web/css/sidebar.css +0 -593
  19. package/web/css/team.css +0 -1277
  20. package/web/css/tools.css +0 -327
  21. package/web/encryption.js +0 -56
  22. package/web/modules/appHelpers.js +0 -100
  23. package/web/modules/askQuestion.js +0 -63
  24. package/web/modules/backgroundRouting.js +0 -269
  25. package/web/modules/connection.js +0 -731
  26. package/web/modules/fileAttachments.js +0 -125
  27. package/web/modules/fileBrowser.js +0 -398
  28. package/web/modules/filePreview.js +0 -213
  29. package/web/modules/i18n.js +0 -101
  30. package/web/modules/loop.js +0 -338
  31. package/web/modules/loopTemplates.js +0 -110
  32. package/web/modules/markdown.js +0 -83
  33. package/web/modules/messageHelpers.js +0 -206
  34. package/web/modules/sidebar.js +0 -402
  35. package/web/modules/streaming.js +0 -116
  36. package/web/modules/team.js +0 -396
  37. package/web/modules/teamTemplates.js +0 -360
  38. package/web/vendor/highlight.min.js +0 -1213
  39. package/web/vendor/marked.min.js +0 -6
  40. package/web/vendor/nacl-fast.min.js +0 -1
  41. package/web/vendor/nacl-util.min.js +0 -1
  42. package/web/vendor/pako.min.js +0 -2
  43. package/web/vendor/vue.global.prod.js +0 -13
  44. /package/web/{favicon.svg → dist/favicon.svg} +0 -0
  45. /package/web/{images → dist/images}/chat-iPad.webp +0 -0
  46. /package/web/{images → dist/images}/chat-iPhone.webp +0 -0
  47. /package/web/{images → dist/images}/loop-iPad.webp +0 -0
  48. /package/web/{images → dist/images}/team-iPad.webp +0 -0
  49. /package/web/{landing.html → dist/landing.html} +0 -0
  50. /package/web/{landing.zh.html → dist/landing.zh.html} +0 -0
  51. /package/web/{locales → dist/locales}/en.json +0 -0
  52. /package/web/{locales → dist/locales}/zh.json +0 -0
  53. /package/web/{vendor → dist/vendor}/github-dark.min.css +0 -0
  54. /package/web/{vendor → dist/vendor}/github.min.css +0 -0
@@ -1,499 +0,0 @@
1
- /* ══════════════════════════════════════════
2
- File Browser Panel
3
- ══════════════════════════════════════════ */
4
- .file-panel {
5
- width: 280px;
6
- flex-shrink: 0;
7
- background: var(--bg-primary);
8
- border-right: 1px solid var(--border);
9
- display: flex;
10
- flex-direction: column;
11
- overflow: hidden;
12
- position: relative;
13
- }
14
-
15
- .file-panel-resize-handle {
16
- position: absolute;
17
- top: 0;
18
- right: -3px;
19
- width: 6px;
20
- height: 100%;
21
- cursor: col-resize;
22
- z-index: 10;
23
- background: transparent;
24
- transition: background 0.15s;
25
- }
26
-
27
- .file-panel-resize-handle:hover,
28
- .file-panel-resize-handle:active {
29
- background: var(--accent);
30
- opacity: 0.4;
31
- }
32
-
33
- .file-panel-header {
34
- display: flex;
35
- align-items: center;
36
- justify-content: space-between;
37
- padding: 0.75rem;
38
- border-bottom: 1px solid var(--border);
39
- background: var(--bg-primary);
40
- flex-shrink: 0;
41
- }
42
-
43
- .file-panel-title {
44
- font-size: 0.8rem;
45
- font-weight: 600;
46
- text-transform: uppercase;
47
- letter-spacing: 0.05em;
48
- color: var(--text-secondary);
49
- }
50
-
51
- .file-panel-actions {
52
- display: flex;
53
- gap: 4px;
54
- }
55
-
56
- .file-panel-btn {
57
- display: flex;
58
- align-items: center;
59
- justify-content: center;
60
- width: 24px;
61
- height: 24px;
62
- background: none;
63
- border: none;
64
- border-radius: 4px;
65
- color: var(--text-secondary);
66
- cursor: pointer;
67
- padding: 0;
68
- }
69
-
70
- .file-panel-btn:hover {
71
- color: var(--text-primary);
72
- background: var(--bg-tertiary);
73
- }
74
-
75
- .file-panel-breadcrumb {
76
- padding: 0.5rem 0.75rem;
77
- font-size: 0.75rem;
78
- font-family: 'SF Mono', 'Fira Code', Consolas, monospace;
79
- color: var(--text-secondary);
80
- border-bottom: 1px solid var(--border);
81
- white-space: nowrap;
82
- overflow: hidden;
83
- text-overflow: ellipsis;
84
- flex-shrink: 0;
85
- }
86
-
87
- .file-tree {
88
- flex: 1;
89
- overflow-y: auto;
90
- overflow-x: hidden;
91
- padding: 0.25rem 0;
92
- }
93
-
94
- .file-tree-item {
95
- display: flex;
96
- align-items: center;
97
- gap: 6px;
98
- padding: 3px 8px;
99
- font-size: 0.8rem;
100
- font-family: 'SF Mono', 'Fira Code', Consolas, monospace;
101
- color: var(--text-primary);
102
- cursor: pointer;
103
- user-select: none;
104
- white-space: nowrap;
105
- overflow: hidden;
106
- }
107
-
108
- .file-tree-item:hover {
109
- background: var(--bg-tertiary);
110
- }
111
-
112
- .file-tree-arrow {
113
- flex-shrink: 0;
114
- width: 14px;
115
- text-align: center;
116
- font-size: 0.65rem;
117
- color: var(--text-secondary);
118
- transition: transform 0.15s ease;
119
- display: inline-block;
120
- }
121
-
122
- .file-tree-arrow.expanded {
123
- transform: rotate(90deg);
124
- }
125
-
126
- .file-tree-file-icon {
127
- flex-shrink: 0;
128
- width: 14px;
129
- text-align: center;
130
- color: var(--text-secondary);
131
- display: flex;
132
- align-items: center;
133
- justify-content: center;
134
- }
135
-
136
- .file-tree-name {
137
- flex: 1;
138
- min-width: 0;
139
- overflow: hidden;
140
- text-overflow: ellipsis;
141
- }
142
-
143
- .file-tree-spinner {
144
- width: 12px;
145
- height: 12px;
146
- border: 2px solid var(--border);
147
- border-top-color: var(--accent);
148
- border-radius: 50%;
149
- animation: spin 0.6s linear infinite;
150
- flex-shrink: 0;
151
- margin-left: auto;
152
- }
153
-
154
- .file-tree-empty {
155
- padding: 4px 8px;
156
- font-size: 0.75rem;
157
- color: var(--text-secondary);
158
- font-style: italic;
159
- }
160
-
161
- .file-tree-error {
162
- padding: 4px 8px;
163
- font-size: 0.75rem;
164
- color: var(--error, #e74c3c);
165
- }
166
-
167
- .file-panel-loading {
168
- padding: 1rem;
169
- text-align: center;
170
- color: var(--text-secondary);
171
- font-size: 0.85rem;
172
- }
173
-
174
- .file-panel-empty {
175
- padding: 1rem;
176
- text-align: center;
177
- color: var(--text-secondary);
178
- font-size: 0.85rem;
179
- }
180
-
181
- /* ── File Context Menu ── */
182
- .file-context-menu {
183
- position: fixed;
184
- z-index: 200;
185
- background: var(--bg-secondary);
186
- border: 1px solid var(--border);
187
- border-radius: 6px;
188
- box-shadow: 0 4px 12px rgba(0, 0, 0, 0.3);
189
- padding: 4px 0;
190
- min-width: 200px;
191
- }
192
-
193
- .file-context-item {
194
- display: flex;
195
- align-items: center;
196
- gap: 8px;
197
- padding: 8px 12px;
198
- font-size: 0.8rem;
199
- cursor: pointer;
200
- color: var(--text-primary);
201
- }
202
-
203
- .file-context-item:hover {
204
- background: var(--bg-tertiary);
205
- }
206
-
207
- .file-context-item svg {
208
- flex-shrink: 0;
209
- color: var(--text-secondary);
210
- }
211
-
212
- /* ── File panel transition (Vue <Transition>) ── */
213
- .file-panel-enter-active,
214
- .file-panel-leave-active {
215
- transition: width 0.2s ease, opacity 0.15s ease;
216
- overflow: hidden;
217
- }
218
- .file-panel-enter-from,
219
- .file-panel-leave-to {
220
- width: 0 !important;
221
- opacity: 0;
222
- }
223
-
224
- /* ── Mobile file browser in sidebar ── */
225
- .file-panel-mobile {
226
- display: flex;
227
- flex-direction: column;
228
- height: 100%;
229
- overflow: hidden;
230
- }
231
-
232
- .file-panel-mobile-header {
233
- display: flex;
234
- align-items: center;
235
- justify-content: space-between;
236
- padding: 0.75rem;
237
- border-bottom: 1px solid var(--border);
238
- flex-shrink: 0;
239
- }
240
-
241
- .file-panel-mobile-back {
242
- display: flex;
243
- align-items: center;
244
- gap: 4px;
245
- background: none;
246
- border: none;
247
- color: var(--accent);
248
- cursor: pointer;
249
- font-size: 0.85rem;
250
- padding: 4px 0;
251
- }
252
-
253
- .file-panel-mobile-back:hover {
254
- opacity: 0.8;
255
- }
256
-
257
- /* ══════════════════════════════════════════
258
- File Preview Panel
259
- ══════════════════════════════════════════ */
260
- .preview-panel {
261
- width: 400px;
262
- min-width: 250px;
263
- flex-shrink: 1;
264
- position: relative;
265
- display: flex;
266
- flex-direction: column;
267
- overflow: hidden;
268
- border-left: 1px solid var(--border);
269
- background: var(--bg);
270
- }
271
-
272
- .preview-panel-resize-handle {
273
- position: absolute;
274
- top: 0;
275
- left: -3px;
276
- width: 6px;
277
- height: 100%;
278
- cursor: col-resize;
279
- z-index: 10;
280
- background: transparent;
281
- transition: background 0.15s;
282
- }
283
-
284
- .preview-panel-resize-handle:hover,
285
- .preview-panel-resize-handle:active {
286
- background: var(--accent);
287
- opacity: 0.4;
288
- }
289
-
290
- .preview-panel-header {
291
- display: flex;
292
- align-items: center;
293
- gap: 0.5rem;
294
- padding: 0.5rem 0.75rem;
295
- border-bottom: 1px solid var(--border);
296
- background: var(--bg-primary);
297
- flex-shrink: 0;
298
- }
299
-
300
- .preview-panel-filename {
301
- flex: 1;
302
- font-weight: 600;
303
- font-size: 0.85rem;
304
- overflow: hidden;
305
- text-overflow: ellipsis;
306
- white-space: nowrap;
307
- }
308
-
309
- .preview-panel-size {
310
- font-size: 0.75rem;
311
- color: var(--text-secondary);
312
- flex-shrink: 0;
313
- }
314
-
315
- .preview-panel-close {
316
- background: none;
317
- border: none;
318
- font-size: 1.2rem;
319
- cursor: pointer;
320
- color: var(--text-secondary);
321
- padding: 0 0.25rem;
322
- line-height: 1;
323
- flex-shrink: 0;
324
- }
325
-
326
- .preview-panel-close:hover {
327
- color: var(--text);
328
- }
329
-
330
- .preview-md-toggle {
331
- background: none;
332
- border: 1px solid var(--border);
333
- border-radius: 4px;
334
- cursor: pointer;
335
- color: var(--text-secondary);
336
- padding: 2px 6px;
337
- line-height: 1;
338
- display: flex;
339
- align-items: center;
340
- flex-shrink: 0;
341
- }
342
-
343
- .preview-md-toggle:hover {
344
- color: var(--text);
345
- border-color: var(--text-secondary);
346
- }
347
-
348
- .preview-md-toggle.active {
349
- color: var(--accent, #6366f1);
350
- border-color: var(--accent, #6366f1);
351
- background: color-mix(in srgb, var(--accent, #6366f1) 10%, transparent);
352
- }
353
-
354
- .preview-header-actions {
355
- display: flex;
356
- align-items: center;
357
- gap: 0.5rem;
358
- }
359
-
360
- .preview-markdown-rendered {
361
- padding: 1rem;
362
- }
363
-
364
- .preview-panel-body {
365
- flex: 1;
366
- overflow: auto;
367
- padding: 0;
368
- }
369
-
370
- .preview-loading {
371
- display: flex;
372
- align-items: center;
373
- justify-content: center;
374
- height: 100%;
375
- color: var(--text-secondary);
376
- font-size: 0.85rem;
377
- }
378
-
379
- .preview-error {
380
- padding: 1rem;
381
- color: var(--error, #ef4444);
382
- font-size: 0.85rem;
383
- }
384
-
385
- .preview-text-container {
386
- overflow: auto;
387
- height: 100%;
388
- }
389
-
390
- .preview-code {
391
- margin: 0;
392
- padding: 0.75rem;
393
- font-size: 0.8rem;
394
- line-height: 1.5;
395
- white-space: pre;
396
- overflow-x: auto;
397
- background: var(--bg);
398
- font-family: var(--font-mono, 'SF Mono', 'Cascadia Code', 'Fira Code', Consolas, monospace);
399
- }
400
-
401
- .preview-code code {
402
- font-family: inherit;
403
- }
404
-
405
- .preview-image-container {
406
- display: flex;
407
- align-items: center;
408
- justify-content: center;
409
- padding: 1rem;
410
- height: 100%;
411
- }
412
-
413
- .preview-image {
414
- max-width: 100%;
415
- max-height: 100%;
416
- object-fit: contain;
417
- }
418
-
419
- .preview-truncated-notice {
420
- padding: 0.5rem 0.75rem;
421
- font-size: 0.75rem;
422
- color: var(--text-secondary);
423
- border-top: 1px solid var(--border);
424
- background: var(--bg-secondary, var(--bg-primary));
425
- text-align: center;
426
- }
427
-
428
- .preview-binary-info {
429
- display: flex;
430
- flex-direction: column;
431
- align-items: center;
432
- justify-content: center;
433
- height: 100%;
434
- gap: 0.5rem;
435
- color: var(--text-secondary);
436
- font-size: 0.85rem;
437
- }
438
-
439
- .preview-binary-icon {
440
- opacity: 0.4;
441
- margin-bottom: 0.5rem;
442
- }
443
-
444
- .preview-binary-meta {
445
- font-size: 0.75rem;
446
- color: var(--text-secondary);
447
- }
448
-
449
- /* ── Mobile file preview in sidebar ── */
450
- .file-preview-mobile {
451
- display: flex;
452
- flex-direction: column;
453
- height: 100%;
454
- overflow: hidden;
455
- }
456
-
457
- .file-preview-mobile-header {
458
- display: flex;
459
- align-items: center;
460
- justify-content: space-between;
461
- padding: 0.75rem;
462
- border-bottom: 1px solid var(--border);
463
- flex-shrink: 0;
464
- }
465
-
466
- .file-preview-mobile-size {
467
- font-size: 0.75rem;
468
- color: var(--text-secondary);
469
- }
470
-
471
- .file-preview-mobile-filename {
472
- padding: 0.5rem 0.75rem;
473
- font-size: 0.8rem;
474
- font-weight: 600;
475
- color: var(--text);
476
- border-bottom: 1px solid var(--border);
477
- white-space: nowrap;
478
- overflow: hidden;
479
- text-overflow: ellipsis;
480
- flex-shrink: 0;
481
- }
482
-
483
- .file-preview-mobile .preview-panel-body {
484
- flex: 1;
485
- overflow: auto;
486
- }
487
-
488
- /* ══════════════════════════════════════════
489
- Medium screens — file panel narrower
490
- ══════════════════════════════════════════ */
491
- @media (max-width: 1200px) and (min-width: 769px) {
492
- .file-panel {
493
- max-width: clamp(200px, 20vw, 280px);
494
- }
495
- .preview-panel {
496
- max-width: min(400px, 40vw);
497
- }
498
- }
499
-