vimd 0.5.0 → 0.5.2
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/dist/core/folder-mode/assets/folder-mode.css +168 -51
- package/dist/core/folder-mode/assets/folder-mode.js +602 -100
- package/dist/core/folder-mode/folder-mode-server.d.ts +4 -0
- package/dist/core/folder-mode/folder-mode-server.d.ts.map +1 -1
- package/dist/core/folder-mode/folder-mode-server.js +18 -4
- package/dist/templates/folder-mode.html +28 -25
- package/package.json +1 -1
- package/templates/folder-mode.html +28 -25
|
@@ -3,6 +3,7 @@
|
|
|
3
3
|
*/
|
|
4
4
|
|
|
5
5
|
:root {
|
|
6
|
+
/* Sidebar */
|
|
6
7
|
--sidebar-bg: #252526;
|
|
7
8
|
--sidebar-text: #cccccc;
|
|
8
9
|
--sidebar-text-muted: #858585;
|
|
@@ -10,11 +11,24 @@
|
|
|
10
11
|
--sidebar-selected: #094771;
|
|
11
12
|
--sidebar-border: #3c3c3c;
|
|
12
13
|
--sidebar-header-bg: #3c3c3c;
|
|
13
|
-
--sidebar-width:
|
|
14
|
+
--sidebar-width: 280px;
|
|
14
15
|
--sidebar-min-width: 150px;
|
|
15
16
|
--sidebar-max-width: 500px;
|
|
16
|
-
--toggle-bar-width: 20px;
|
|
17
17
|
--resizer-width: 4px;
|
|
18
|
+
|
|
19
|
+
/* Panel header (light theme) */
|
|
20
|
+
--panel-header-border: #e0e0e0;
|
|
21
|
+
--panel-filename-color: #666;
|
|
22
|
+
--panel-close-color: #999;
|
|
23
|
+
--panel-close-hover: #333;
|
|
24
|
+
--panel-active-color: #007acc;
|
|
25
|
+
|
|
26
|
+
/* Context menu */
|
|
27
|
+
--context-menu-bg: #ffffff;
|
|
28
|
+
--context-menu-border: #e0e0e0;
|
|
29
|
+
--context-menu-hover: #f5f5f5;
|
|
30
|
+
--context-menu-text: #333;
|
|
31
|
+
--context-menu-shadow: rgba(0, 0, 0, 0.15);
|
|
18
32
|
}
|
|
19
33
|
|
|
20
34
|
* {
|
|
@@ -24,6 +38,8 @@
|
|
|
24
38
|
html, body {
|
|
25
39
|
margin: 0;
|
|
26
40
|
padding: 0;
|
|
41
|
+
width: 100%;
|
|
42
|
+
max-width: none;
|
|
27
43
|
height: 100%;
|
|
28
44
|
overflow: hidden;
|
|
29
45
|
}
|
|
@@ -31,27 +47,12 @@ html, body {
|
|
|
31
47
|
/* Container */
|
|
32
48
|
.vimd-container {
|
|
33
49
|
display: flex;
|
|
50
|
+
width: 100vw;
|
|
34
51
|
height: 100vh;
|
|
35
52
|
overflow: hidden;
|
|
36
53
|
background: #1e1e1e;
|
|
37
54
|
}
|
|
38
55
|
|
|
39
|
-
/* Toggle bar (visible when sidebar is collapsed) */
|
|
40
|
-
.vimd-sidebar-toggle-bar {
|
|
41
|
-
width: var(--toggle-bar-width);
|
|
42
|
-
min-width: var(--toggle-bar-width);
|
|
43
|
-
background: var(--sidebar-bg);
|
|
44
|
-
border-right: 1px solid var(--sidebar-border);
|
|
45
|
-
display: none;
|
|
46
|
-
flex-direction: column;
|
|
47
|
-
align-items: center;
|
|
48
|
-
padding-top: 8px;
|
|
49
|
-
}
|
|
50
|
-
|
|
51
|
-
.vimd-sidebar-toggle-bar.visible {
|
|
52
|
-
display: flex;
|
|
53
|
-
}
|
|
54
|
-
|
|
55
56
|
/* Sidebar */
|
|
56
57
|
.vimd-sidebar {
|
|
57
58
|
width: var(--sidebar-width);
|
|
@@ -63,15 +64,6 @@ html, body {
|
|
|
63
64
|
flex-direction: column;
|
|
64
65
|
position: relative;
|
|
65
66
|
border-right: 1px solid var(--sidebar-border);
|
|
66
|
-
transition: width 0.15s ease, min-width 0.15s ease, opacity 0.15s ease;
|
|
67
|
-
}
|
|
68
|
-
|
|
69
|
-
.vimd-sidebar.collapsed {
|
|
70
|
-
width: 0;
|
|
71
|
-
min-width: 0;
|
|
72
|
-
border-right: none;
|
|
73
|
-
overflow: hidden;
|
|
74
|
-
opacity: 0;
|
|
75
67
|
}
|
|
76
68
|
|
|
77
69
|
/* Sidebar header */
|
|
@@ -85,11 +77,12 @@ html, body {
|
|
|
85
77
|
min-height: 35px;
|
|
86
78
|
}
|
|
87
79
|
|
|
80
|
+
/* Header title (VSCode-style) */
|
|
88
81
|
.vimd-folder-name {
|
|
89
82
|
font-size: 11px;
|
|
90
|
-
font-weight:
|
|
83
|
+
font-weight: 400;
|
|
91
84
|
text-transform: uppercase;
|
|
92
|
-
letter-spacing: 0.
|
|
85
|
+
letter-spacing: 0.04em;
|
|
93
86
|
color: var(--sidebar-text-muted);
|
|
94
87
|
overflow: hidden;
|
|
95
88
|
text-overflow: ellipsis;
|
|
@@ -97,26 +90,6 @@ html, body {
|
|
|
97
90
|
flex: 1;
|
|
98
91
|
}
|
|
99
92
|
|
|
100
|
-
/* Toggle button */
|
|
101
|
-
.vimd-toggle-btn {
|
|
102
|
-
background: transparent;
|
|
103
|
-
border: none;
|
|
104
|
-
color: var(--sidebar-text);
|
|
105
|
-
cursor: pointer;
|
|
106
|
-
padding: 4px;
|
|
107
|
-
display: flex;
|
|
108
|
-
align-items: center;
|
|
109
|
-
justify-content: center;
|
|
110
|
-
border-radius: 3px;
|
|
111
|
-
opacity: 0.7;
|
|
112
|
-
transition: opacity 0.1s, background 0.1s;
|
|
113
|
-
}
|
|
114
|
-
|
|
115
|
-
.vimd-toggle-btn:hover {
|
|
116
|
-
opacity: 1;
|
|
117
|
-
background: var(--sidebar-hover);
|
|
118
|
-
}
|
|
119
|
-
|
|
120
93
|
/* File tree */
|
|
121
94
|
.vimd-tree {
|
|
122
95
|
flex: 1;
|
|
@@ -237,10 +210,117 @@ html, body {
|
|
|
237
210
|
|
|
238
211
|
/* Preview area */
|
|
239
212
|
.vimd-preview {
|
|
213
|
+
flex: 1;
|
|
214
|
+
display: flex;
|
|
215
|
+
overflow: hidden;
|
|
216
|
+
background: #ffffff;
|
|
217
|
+
}
|
|
218
|
+
|
|
219
|
+
/* Panel */
|
|
220
|
+
.vimd-panel {
|
|
221
|
+
flex: 1;
|
|
222
|
+
display: flex;
|
|
223
|
+
flex-direction: column;
|
|
224
|
+
overflow: hidden;
|
|
225
|
+
min-width: 100px;
|
|
226
|
+
}
|
|
227
|
+
|
|
228
|
+
/* Split view: Panel 1 (initial 720px, resizable) */
|
|
229
|
+
.vimd-panel.split-panel1 {
|
|
230
|
+
flex: none;
|
|
231
|
+
/* width is set by JS */
|
|
232
|
+
}
|
|
233
|
+
|
|
234
|
+
/* Split view: Panel 2 (takes remaining space) */
|
|
235
|
+
.vimd-panel.split-panel2 {
|
|
236
|
+
flex: 1;
|
|
237
|
+
}
|
|
238
|
+
|
|
239
|
+
.vimd-panel-body {
|
|
240
240
|
flex: 1;
|
|
241
241
|
overflow-y: auto;
|
|
242
242
|
overflow-x: hidden;
|
|
243
|
-
|
|
243
|
+
}
|
|
244
|
+
|
|
245
|
+
/* Panel header */
|
|
246
|
+
.vimd-panel-header {
|
|
247
|
+
display: none;
|
|
248
|
+
align-items: center;
|
|
249
|
+
justify-content: flex-start;
|
|
250
|
+
gap: 8px;
|
|
251
|
+
height: 28px;
|
|
252
|
+
padding: 4px 16px;
|
|
253
|
+
background: transparent;
|
|
254
|
+
border-bottom: 1px solid var(--panel-header-border);
|
|
255
|
+
position: relative;
|
|
256
|
+
flex-shrink: 0;
|
|
257
|
+
}
|
|
258
|
+
|
|
259
|
+
.vimd-panel-header.visible {
|
|
260
|
+
display: flex;
|
|
261
|
+
}
|
|
262
|
+
|
|
263
|
+
.vimd-panel-header.active::after {
|
|
264
|
+
content: '';
|
|
265
|
+
position: absolute;
|
|
266
|
+
bottom: 0;
|
|
267
|
+
left: 0;
|
|
268
|
+
right: 0;
|
|
269
|
+
height: 2px;
|
|
270
|
+
background: var(--panel-active-color);
|
|
271
|
+
}
|
|
272
|
+
|
|
273
|
+
.vimd-panel-filename {
|
|
274
|
+
font-size: 12px;
|
|
275
|
+
color: var(--panel-filename-color);
|
|
276
|
+
overflow: hidden;
|
|
277
|
+
text-overflow: ellipsis;
|
|
278
|
+
white-space: nowrap;
|
|
279
|
+
max-width: calc(100% - 30px);
|
|
280
|
+
}
|
|
281
|
+
|
|
282
|
+
.vimd-panel-filename:hover {
|
|
283
|
+
overflow: visible;
|
|
284
|
+
white-space: normal;
|
|
285
|
+
word-break: break-all;
|
|
286
|
+
}
|
|
287
|
+
|
|
288
|
+
.vimd-panel-close {
|
|
289
|
+
background: none;
|
|
290
|
+
border: none;
|
|
291
|
+
font-size: 16px;
|
|
292
|
+
color: var(--panel-close-color);
|
|
293
|
+
cursor: pointer;
|
|
294
|
+
flex-shrink: 0;
|
|
295
|
+
width: 20px;
|
|
296
|
+
height: 20px;
|
|
297
|
+
display: flex;
|
|
298
|
+
align-items: center;
|
|
299
|
+
justify-content: center;
|
|
300
|
+
border-radius: 3px;
|
|
301
|
+
}
|
|
302
|
+
|
|
303
|
+
.vimd-panel-close:hover {
|
|
304
|
+
color: var(--panel-close-hover);
|
|
305
|
+
background: rgba(0, 0, 0, 0.05);
|
|
306
|
+
}
|
|
307
|
+
|
|
308
|
+
/* Panel resizer (between panels) */
|
|
309
|
+
.vimd-panel-resizer {
|
|
310
|
+
width: 4px;
|
|
311
|
+
background: transparent;
|
|
312
|
+
cursor: ew-resize;
|
|
313
|
+
flex-shrink: 0;
|
|
314
|
+
display: none;
|
|
315
|
+
}
|
|
316
|
+
|
|
317
|
+
.vimd-panel-resizer.visible {
|
|
318
|
+
display: block;
|
|
319
|
+
}
|
|
320
|
+
|
|
321
|
+
.vimd-panel-resizer:hover,
|
|
322
|
+
.vimd-panel-resizer.active {
|
|
323
|
+
background: var(--panel-active-color);
|
|
244
324
|
}
|
|
245
325
|
|
|
246
326
|
/* Welcome screen */
|
|
@@ -273,10 +353,15 @@ html, body {
|
|
|
273
353
|
.vimd-content {
|
|
274
354
|
display: none;
|
|
275
355
|
padding: 32px;
|
|
276
|
-
max-width:
|
|
356
|
+
max-width: 720px;
|
|
277
357
|
margin: 0 auto;
|
|
278
358
|
}
|
|
279
359
|
|
|
360
|
+
.vimd-content pre,
|
|
361
|
+
.vimd-content table {
|
|
362
|
+
overflow-x: auto;
|
|
363
|
+
}
|
|
364
|
+
|
|
280
365
|
.vimd-content.visible {
|
|
281
366
|
display: block;
|
|
282
367
|
}
|
|
@@ -306,3 +391,35 @@ html, body {
|
|
|
306
391
|
margin: 0;
|
|
307
392
|
font-size: 14px;
|
|
308
393
|
}
|
|
394
|
+
|
|
395
|
+
/* Context menu */
|
|
396
|
+
.vimd-context-menu {
|
|
397
|
+
display: none;
|
|
398
|
+
position: fixed;
|
|
399
|
+
background: var(--context-menu-bg);
|
|
400
|
+
border: 1px solid var(--context-menu-border);
|
|
401
|
+
border-radius: 4px;
|
|
402
|
+
box-shadow: 0 2px 8px var(--context-menu-shadow);
|
|
403
|
+
min-width: 150px;
|
|
404
|
+
z-index: 1000;
|
|
405
|
+
padding: 4px 0;
|
|
406
|
+
}
|
|
407
|
+
|
|
408
|
+
.vimd-context-menu.visible {
|
|
409
|
+
display: block;
|
|
410
|
+
}
|
|
411
|
+
|
|
412
|
+
.vimd-context-item {
|
|
413
|
+
padding: 6px 12px;
|
|
414
|
+
cursor: pointer;
|
|
415
|
+
font-size: 13px;
|
|
416
|
+
color: var(--context-menu-text);
|
|
417
|
+
}
|
|
418
|
+
|
|
419
|
+
.vimd-context-item:hover {
|
|
420
|
+
background: var(--context-menu-hover);
|
|
421
|
+
}
|
|
422
|
+
|
|
423
|
+
.vimd-context-item.hidden {
|
|
424
|
+
display: none;
|
|
425
|
+
}
|