@cliangdev/flux-plugin 0.2.0 → 0.3.0

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 (108) hide show
  1. package/README.md +11 -7
  2. package/agents/coder.md +150 -25
  3. package/bin/install.cjs +171 -16
  4. package/commands/breakdown.md +47 -10
  5. package/commands/dashboard.md +29 -0
  6. package/commands/flux.md +92 -12
  7. package/commands/implement.md +166 -17
  8. package/commands/linear.md +6 -5
  9. package/commands/prd.md +996 -82
  10. package/manifest.json +2 -1
  11. package/package.json +9 -11
  12. package/skills/flux-orchestrator/SKILL.md +11 -3
  13. package/skills/prd-writer/SKILL.md +761 -0
  14. package/skills/ux-ui-design/SKILL.md +346 -0
  15. package/skills/ux-ui-design/references/design-tokens.md +359 -0
  16. package/src/__tests__/version.test.ts +37 -0
  17. package/src/adapters/local/.gitkeep +0 -0
  18. package/src/dashboard/__tests__/api.test.ts +211 -0
  19. package/src/dashboard/browser.ts +35 -0
  20. package/src/dashboard/public/app.js +869 -0
  21. package/src/dashboard/public/index.html +90 -0
  22. package/src/dashboard/public/styles.css +807 -0
  23. package/src/dashboard/public/vendor/highlight.css +10 -0
  24. package/src/dashboard/public/vendor/highlight.min.js +8422 -0
  25. package/src/dashboard/public/vendor/marked.min.js +2210 -0
  26. package/src/dashboard/server.ts +296 -0
  27. package/src/dashboard/watchers.ts +83 -0
  28. package/src/server/__tests__/config.test.ts +163 -0
  29. package/src/server/adapters/__tests__/a-client-linear.test.ts +197 -0
  30. package/src/server/adapters/__tests__/adapter-factory.test.ts +230 -0
  31. package/src/server/adapters/__tests__/dependency-ops.test.ts +429 -0
  32. package/src/server/adapters/__tests__/document-ops.test.ts +306 -0
  33. package/src/server/adapters/__tests__/linear-adapter.test.ts +91 -0
  34. package/src/server/adapters/__tests__/linear-config.test.ts +425 -0
  35. package/src/server/adapters/__tests__/linear-criteria-parser.test.ts +287 -0
  36. package/src/server/adapters/__tests__/linear-description-test.ts +238 -0
  37. package/src/server/adapters/__tests__/linear-epic-crud.test.ts +496 -0
  38. package/src/server/adapters/__tests__/linear-mappers-description.test.ts +276 -0
  39. package/src/server/adapters/__tests__/linear-mappers-epic.test.ts +294 -0
  40. package/src/server/adapters/__tests__/linear-mappers-prd.test.ts +300 -0
  41. package/src/server/adapters/__tests__/linear-mappers-task.test.ts +197 -0
  42. package/src/server/adapters/__tests__/linear-prd-crud.test.ts +620 -0
  43. package/src/server/adapters/__tests__/linear-stats.test.ts +450 -0
  44. package/src/server/adapters/__tests__/linear-task-crud.test.ts +534 -0
  45. package/src/server/adapters/__tests__/linear-types.test.ts +243 -0
  46. package/src/server/adapters/__tests__/status-ops.test.ts +441 -0
  47. package/src/server/adapters/factory.ts +90 -0
  48. package/src/server/adapters/index.ts +9 -0
  49. package/src/server/adapters/linear/adapter.ts +1141 -0
  50. package/src/server/adapters/linear/client.ts +169 -0
  51. package/src/server/adapters/linear/config.ts +152 -0
  52. package/src/server/adapters/linear/helpers/criteria-parser.ts +197 -0
  53. package/src/server/adapters/linear/helpers/index.ts +7 -0
  54. package/src/server/adapters/linear/index.ts +16 -0
  55. package/src/server/adapters/linear/mappers/description.ts +136 -0
  56. package/src/server/adapters/linear/mappers/epic.ts +81 -0
  57. package/src/server/adapters/linear/mappers/index.ts +27 -0
  58. package/src/server/adapters/linear/mappers/prd.ts +178 -0
  59. package/src/server/adapters/linear/mappers/task.ts +82 -0
  60. package/src/server/adapters/linear/types.ts +264 -0
  61. package/src/server/adapters/local-adapter.ts +1009 -0
  62. package/src/server/adapters/types.ts +293 -0
  63. package/src/server/config.ts +73 -0
  64. package/src/server/db/__tests__/queries.test.ts +473 -0
  65. package/src/server/db/ids.ts +17 -0
  66. package/src/server/db/index.ts +69 -0
  67. package/src/server/db/queries.ts +142 -0
  68. package/src/server/db/refs.ts +60 -0
  69. package/src/server/db/schema.ts +97 -0
  70. package/src/server/db/sqlite.ts +10 -0
  71. package/src/server/index.ts +81 -0
  72. package/src/server/tools/__tests__/crud.test.ts +411 -0
  73. package/src/server/tools/__tests__/get-version.test.ts +27 -0
  74. package/src/server/tools/__tests__/mcp-interface.test.ts +479 -0
  75. package/src/server/tools/__tests__/query.test.ts +405 -0
  76. package/src/server/tools/__tests__/z-configure-linear.test.ts +511 -0
  77. package/src/server/tools/__tests__/z-get-linear-url.test.ts +108 -0
  78. package/src/server/tools/configure-linear.ts +373 -0
  79. package/src/server/tools/create-epic.ts +44 -0
  80. package/src/server/tools/create-prd.ts +40 -0
  81. package/src/server/tools/create-task.ts +47 -0
  82. package/src/server/tools/criteria.ts +50 -0
  83. package/src/server/tools/delete-entity.ts +76 -0
  84. package/src/server/tools/dependencies.ts +55 -0
  85. package/src/server/tools/get-entity.ts +240 -0
  86. package/src/server/tools/get-linear-url.ts +28 -0
  87. package/src/server/tools/get-stats.ts +52 -0
  88. package/src/server/tools/get-version.ts +20 -0
  89. package/src/server/tools/index.ts +158 -0
  90. package/src/server/tools/init-project.ts +108 -0
  91. package/src/server/tools/query-entities.ts +167 -0
  92. package/src/server/tools/render-status.ts +219 -0
  93. package/src/server/tools/update-entity.ts +140 -0
  94. package/src/server/tools/update-status.ts +166 -0
  95. package/src/server/utils/__tests__/mcp-response.test.ts +331 -0
  96. package/src/server/utils/logger.ts +9 -0
  97. package/src/server/utils/mcp-response.ts +254 -0
  98. package/src/server/utils/status-transitions.ts +160 -0
  99. package/src/status-line/__tests__/status-line.test.ts +215 -0
  100. package/src/status-line/index.ts +147 -0
  101. package/src/utils/__tests__/chalk-import.test.ts +32 -0
  102. package/src/utils/__tests__/display.test.ts +97 -0
  103. package/src/utils/__tests__/status-renderer.test.ts +310 -0
  104. package/src/utils/display.ts +62 -0
  105. package/src/utils/status-renderer.ts +214 -0
  106. package/src/version.ts +5 -0
  107. package/dist/server/index.js +0 -87063
  108. package/skills/prd-template/SKILL.md +0 -242
@@ -0,0 +1,807 @@
1
+ * {
2
+ box-sizing: border-box;
3
+ margin: 0;
4
+ padding: 0;
5
+ }
6
+
7
+ :root {
8
+ --bg-primary: #ffffff;
9
+ --bg-secondary: #f5f5f5;
10
+ --bg-tertiary: #e8e8e8;
11
+ --text-primary: #1a1a1a;
12
+ --text-secondary: #666666;
13
+ --border-color: #ddd;
14
+ --accent-color: #0066cc;
15
+ --link-color: #0066cc;
16
+ --success-color: #28a745;
17
+ --warning-color: #e69500;
18
+ --danger-color: #dc3545;
19
+ --sidebar-width: 280px;
20
+ --header-height: 48px;
21
+ --code-bg: #f6f8fa;
22
+ --selected-bg: #0066cc;
23
+ --hover-bg: #e8e8e8;
24
+ }
25
+
26
+ /* VSCode-inspired dark theme */
27
+ [data-theme="dark"] {
28
+ --bg-primary: #1e1e1e;
29
+ --bg-secondary: #252526;
30
+ --bg-tertiary: #2d2d2d;
31
+ --text-primary: #d4d4d4;
32
+ --text-secondary: #9d9d9d;
33
+ --border-color: #3c3c3c;
34
+ --accent-color: #6cb6ff;
35
+ --link-color: #58a6ff;
36
+ --success-color: #89d185;
37
+ --warning-color: #cca700;
38
+ --danger-color: #f14c4c;
39
+ --code-bg: #1e1e1e;
40
+ --selected-bg: #094771;
41
+ --hover-bg: #2a2d2e;
42
+ }
43
+
44
+ body {
45
+ font-family:
46
+ -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, Oxygen, Ubuntu,
47
+ sans-serif;
48
+ font-size: 14px;
49
+ line-height: 1.5;
50
+ color: var(--text-primary);
51
+ background: var(--bg-primary);
52
+ }
53
+
54
+ /* Header */
55
+ #header {
56
+ position: fixed;
57
+ top: 0;
58
+ left: 0;
59
+ right: 0;
60
+ height: var(--header-height);
61
+ background: var(--bg-primary);
62
+ border-bottom: 1px solid var(--border-color);
63
+ display: flex;
64
+ align-items: center;
65
+ justify-content: space-between;
66
+ padding: 0 16px;
67
+ z-index: 100;
68
+ }
69
+
70
+ .header-left {
71
+ display: flex;
72
+ align-items: center;
73
+ gap: 12px;
74
+ }
75
+
76
+ .logo {
77
+ font-weight: 600;
78
+ font-size: 16px;
79
+ }
80
+
81
+ .header-center {
82
+ display: flex;
83
+ align-items: center;
84
+ gap: 12px;
85
+ }
86
+
87
+ #search {
88
+ padding: 6px 12px;
89
+ border: 1px solid var(--border-color);
90
+ border-radius: 4px;
91
+ width: 200px;
92
+ }
93
+
94
+ #status-filter {
95
+ padding: 6px 12px;
96
+ border: 1px solid var(--border-color);
97
+ border-radius: 4px;
98
+ }
99
+
100
+ .header-right {
101
+ display: flex;
102
+ align-items: center;
103
+ gap: 12px;
104
+ }
105
+
106
+ #theme-toggle {
107
+ background: none;
108
+ border: 1px solid var(--border-color);
109
+ border-radius: 4px;
110
+ padding: 4px 8px;
111
+ cursor: pointer;
112
+ font-size: 14px;
113
+ color: var(--text-primary);
114
+ display: flex;
115
+ align-items: center;
116
+ gap: 4px;
117
+ }
118
+
119
+ #theme-toggle:hover {
120
+ background: var(--bg-secondary);
121
+ }
122
+
123
+ #connection-status {
124
+ font-size: 12px;
125
+ padding: 4px 8px;
126
+ border-radius: 4px;
127
+ }
128
+
129
+ #connection-status.connected {
130
+ color: var(--success-color);
131
+ }
132
+
133
+ #connection-status.reconnecting {
134
+ color: var(--warning-color);
135
+ }
136
+
137
+ #connection-status.disconnected {
138
+ color: var(--danger-color);
139
+ }
140
+
141
+ /* Main Layout */
142
+ #main {
143
+ display: flex;
144
+ margin-top: var(--header-height);
145
+ height: calc(100vh - var(--header-height));
146
+ }
147
+
148
+ /* Sidebar */
149
+ #sidebar {
150
+ width: var(--sidebar-width);
151
+ min-width: 200px;
152
+ max-width: 500px;
153
+ border-right: 1px solid var(--border-color);
154
+ overflow-y: auto;
155
+ background: var(--bg-secondary);
156
+ position: relative;
157
+ flex-shrink: 0;
158
+ }
159
+
160
+ #sidebar-resize {
161
+ position: absolute;
162
+ top: 0;
163
+ right: 0;
164
+ width: 4px;
165
+ height: 100%;
166
+ cursor: col-resize;
167
+ background: transparent;
168
+ z-index: 10;
169
+ }
170
+
171
+ #sidebar-resize:hover,
172
+ #sidebar-resize.dragging {
173
+ background: var(--accent-color);
174
+ }
175
+
176
+ #sidebar section {
177
+ padding: 12px;
178
+ border-bottom: 1px solid var(--border-color);
179
+ }
180
+
181
+ #sidebar h3 {
182
+ font-size: 11px;
183
+ text-transform: uppercase;
184
+ color: var(--text-secondary);
185
+ margin-bottom: 8px;
186
+ }
187
+
188
+ /* Tags */
189
+ #tags-list {
190
+ display: flex;
191
+ flex-wrap: wrap;
192
+ gap: 6px;
193
+ }
194
+
195
+ .tag-pill {
196
+ padding: 4px 8px;
197
+ background: var(--bg-tertiary);
198
+ border-radius: 12px;
199
+ font-size: 12px;
200
+ cursor: pointer;
201
+ transition: background 0.2s;
202
+ }
203
+
204
+ .tag-pill:hover {
205
+ background: var(--border-color);
206
+ }
207
+
208
+ .tag-pill.active {
209
+ background: var(--selected-bg);
210
+ color: #ffffff;
211
+ }
212
+
213
+ .tag-count {
214
+ opacity: 0.7;
215
+ margin-left: 4px;
216
+ }
217
+
218
+ /* Tree */
219
+ #tree {
220
+ font-size: 13px;
221
+ }
222
+
223
+ .tree-node {
224
+ cursor: pointer;
225
+ user-select: none;
226
+ }
227
+
228
+ .tree-node-content {
229
+ display: flex;
230
+ align-items: center;
231
+ padding: 4px 8px;
232
+ gap: 6px;
233
+ border-radius: 4px;
234
+ }
235
+
236
+ .tree-node-content:hover {
237
+ background: var(--hover-bg);
238
+ }
239
+
240
+ .tree-node-content.selected {
241
+ background: var(--selected-bg);
242
+ color: #ffffff;
243
+ }
244
+
245
+ .tree-expand {
246
+ width: 16px;
247
+ text-align: center;
248
+ font-size: 10px;
249
+ }
250
+
251
+ .tree-status {
252
+ font-size: 10px;
253
+ }
254
+
255
+ .tree-status.pending {
256
+ color: var(--text-secondary);
257
+ }
258
+ .tree-status.in-progress {
259
+ color: var(--warning-color);
260
+ }
261
+ .tree-status.completed {
262
+ color: var(--success-color);
263
+ }
264
+
265
+ .tree-ref {
266
+ font-weight: 500;
267
+ font-size: 12px;
268
+ opacity: 0.8;
269
+ }
270
+
271
+ .tree-title {
272
+ flex: 1;
273
+ overflow: hidden;
274
+ text-overflow: ellipsis;
275
+ white-space: nowrap;
276
+ }
277
+
278
+ .tree-children {
279
+ margin-left: 16px;
280
+ }
281
+
282
+ .tree-children.collapsed {
283
+ display: none;
284
+ }
285
+
286
+ /* Content Panel */
287
+ #content-panel {
288
+ flex: 1;
289
+ overflow-y: auto;
290
+ padding: 24px;
291
+ }
292
+
293
+ #content-header {
294
+ margin-bottom: 16px;
295
+ padding-bottom: 16px;
296
+ border-bottom: 1px solid var(--border-color);
297
+ }
298
+
299
+ #content-header:empty {
300
+ display: none;
301
+ }
302
+
303
+ #content-header h1 {
304
+ font-size: 20px;
305
+ margin-bottom: 8px;
306
+ }
307
+
308
+ .content-meta {
309
+ display: flex;
310
+ gap: 16px;
311
+ font-size: 13px;
312
+ color: var(--text-secondary);
313
+ }
314
+
315
+ .content-meta span {
316
+ display: flex;
317
+ align-items: center;
318
+ gap: 4px;
319
+ }
320
+
321
+ /* Markdown Content */
322
+ #content-body {
323
+ line-height: 1.6;
324
+ }
325
+
326
+ #content-body h1,
327
+ #content-body h2,
328
+ #content-body h3,
329
+ #content-body h4 {
330
+ margin-top: 24px;
331
+ margin-bottom: 12px;
332
+ }
333
+
334
+ #content-body h1 {
335
+ font-size: 24px;
336
+ }
337
+ #content-body h2 {
338
+ font-size: 20px;
339
+ }
340
+ #content-body h3 {
341
+ font-size: 16px;
342
+ }
343
+
344
+ #content-body p {
345
+ margin-bottom: 12px;
346
+ }
347
+
348
+ #content-body ul,
349
+ #content-body ol {
350
+ margin-bottom: 12px;
351
+ padding-left: 24px;
352
+ }
353
+
354
+ #content-body li {
355
+ margin-bottom: 4px;
356
+ }
357
+
358
+ #content-body code {
359
+ background: var(--bg-secondary);
360
+ padding: 2px 6px;
361
+ border-radius: 3px;
362
+ font-size: 13px;
363
+ }
364
+
365
+ #content-body pre {
366
+ background: var(--bg-secondary);
367
+ padding: 16px;
368
+ border-radius: 6px;
369
+ overflow-x: auto;
370
+ margin-bottom: 12px;
371
+ }
372
+
373
+ #content-body pre code {
374
+ padding: 0;
375
+ background: none;
376
+ }
377
+
378
+ #content-body table {
379
+ width: 100%;
380
+ border-collapse: collapse;
381
+ margin-bottom: 12px;
382
+ }
383
+
384
+ #content-body th,
385
+ #content-body td {
386
+ border: 1px solid var(--border-color);
387
+ padding: 8px 12px;
388
+ text-align: left;
389
+ }
390
+
391
+ #content-body th {
392
+ background: var(--bg-secondary);
393
+ }
394
+
395
+ #content-body blockquote {
396
+ border-left: 4px solid var(--accent-color);
397
+ padding-left: 16px;
398
+ margin-left: 0;
399
+ color: var(--text-secondary);
400
+ }
401
+
402
+ #content-body a {
403
+ color: var(--link-color);
404
+ text-decoration: none;
405
+ }
406
+
407
+ #content-body a:hover {
408
+ text-decoration: underline;
409
+ }
410
+
411
+ /* Empty State */
412
+ .empty-state {
413
+ display: flex;
414
+ flex-direction: column;
415
+ align-items: center;
416
+ justify-content: center;
417
+ height: 300px;
418
+ color: var(--text-secondary);
419
+ text-align: center;
420
+ }
421
+
422
+ .empty-state p:first-child {
423
+ font-size: 48px;
424
+ margin-bottom: 16px;
425
+ }
426
+
427
+ /* Acceptance Criteria */
428
+ .criteria-list {
429
+ margin-top: 16px;
430
+ }
431
+
432
+ .criteria-item {
433
+ display: flex;
434
+ align-items: flex-start;
435
+ gap: 8px;
436
+ padding: 8px 0;
437
+ border-bottom: 1px solid var(--bg-tertiary);
438
+ }
439
+
440
+ .criteria-checkbox {
441
+ margin-top: 2px;
442
+ }
443
+
444
+ .criteria-text {
445
+ flex: 1;
446
+ }
447
+
448
+ .criteria-met {
449
+ color: var(--success-color);
450
+ }
451
+
452
+ /* Progress Bar */
453
+ .progress-bar {
454
+ height: 8px;
455
+ background: var(--bg-tertiary);
456
+ border-radius: 4px;
457
+ overflow: hidden;
458
+ margin-top: 8px;
459
+ }
460
+
461
+ .progress-fill {
462
+ height: 100%;
463
+ background: var(--success-color);
464
+ transition: width 0.3s;
465
+ }
466
+
467
+ /* Dependencies */
468
+ .dependencies {
469
+ margin-top: 16px;
470
+ padding: 12px;
471
+ background: var(--bg-secondary);
472
+ border-radius: 6px;
473
+ }
474
+
475
+ .dependencies h4 {
476
+ font-size: 13px;
477
+ margin-bottom: 8px;
478
+ }
479
+
480
+ .dependency-item {
481
+ display: flex;
482
+ align-items: center;
483
+ gap: 8px;
484
+ padding: 4px 0;
485
+ }
486
+
487
+ .dependency-status {
488
+ font-size: 12px;
489
+ }
490
+
491
+ /* Form elements in dark mode */
492
+ #search,
493
+ #status-filter {
494
+ background: var(--bg-primary);
495
+ color: var(--text-primary);
496
+ }
497
+
498
+ /* VSCode Dark+ inspired syntax highlighting */
499
+ [data-theme="dark"] .hljs {
500
+ background: var(--bg-secondary);
501
+ color: #d4d4d4;
502
+ }
503
+
504
+ [data-theme="dark"] .hljs-keyword,
505
+ [data-theme="dark"] .hljs-selector-tag {
506
+ color: #569cd6;
507
+ }
508
+
509
+ [data-theme="dark"] .hljs-literal,
510
+ [data-theme="dark"] .hljs-number {
511
+ color: #b5cea8;
512
+ }
513
+
514
+ [data-theme="dark"] .hljs-string,
515
+ [data-theme="dark"] .hljs-doctag,
516
+ [data-theme="dark"] .hljs-regexp {
517
+ color: #ce9178;
518
+ }
519
+
520
+ [data-theme="dark"] .hljs-title,
521
+ [data-theme="dark"] .hljs-section,
522
+ [data-theme="dark"] .hljs-selector-id {
523
+ color: #dcdcaa;
524
+ }
525
+
526
+ [data-theme="dark"] .hljs-name,
527
+ [data-theme="dark"] .hljs-tag,
528
+ [data-theme="dark"] .hljs-selector-class {
529
+ color: #4ec9b0;
530
+ }
531
+
532
+ [data-theme="dark"] .hljs-type,
533
+ [data-theme="dark"] .hljs-built_in,
534
+ [data-theme="dark"] .hljs-class {
535
+ color: #4ec9b0;
536
+ }
537
+
538
+ [data-theme="dark"] .hljs-attribute,
539
+ [data-theme="dark"] .hljs-variable,
540
+ [data-theme="dark"] .hljs-template-variable {
541
+ color: #9cdcfe;
542
+ }
543
+
544
+ [data-theme="dark"] .hljs-comment,
545
+ [data-theme="dark"] .hljs-quote {
546
+ color: #6a9955;
547
+ }
548
+
549
+ [data-theme="dark"] .hljs-deletion {
550
+ color: #ce9178;
551
+ background: #5a2020;
552
+ }
553
+
554
+ [data-theme="dark"] .hljs-addition {
555
+ color: #b5cea8;
556
+ background: #203520;
557
+ }
558
+
559
+ [data-theme="dark"] .hljs-meta {
560
+ color: #c586c0;
561
+ }
562
+
563
+ [data-theme="dark"] .hljs-link {
564
+ color: #4fc1ff;
565
+ }
566
+
567
+ /* Dependency Graph Toggle Button */
568
+ #dep-graph-toggle {
569
+ background: none;
570
+ border: 1px solid var(--border-color);
571
+ border-radius: 4px;
572
+ padding: 6px 12px;
573
+ cursor: pointer;
574
+ font-size: 13px;
575
+ color: var(--text-primary);
576
+ display: flex;
577
+ align-items: center;
578
+ gap: 6px;
579
+ }
580
+
581
+ #dep-graph-toggle:hover {
582
+ background: var(--bg-secondary);
583
+ }
584
+
585
+ #dep-graph-icon {
586
+ font-size: 12px;
587
+ color: var(--accent-color);
588
+ }
589
+
590
+ /* Dependency Graph Overlay */
591
+ #dep-graph-overlay {
592
+ position: fixed;
593
+ top: 0;
594
+ left: 0;
595
+ right: 0;
596
+ bottom: 0;
597
+ background: rgba(0, 0, 0, 0.6);
598
+ z-index: 200;
599
+ display: flex;
600
+ align-items: center;
601
+ justify-content: center;
602
+ }
603
+
604
+ #dep-graph-overlay.hidden {
605
+ display: none;
606
+ }
607
+
608
+ #dep-graph-container {
609
+ background: var(--bg-primary);
610
+ border-radius: 8px;
611
+ width: 90vw;
612
+ height: 85vh;
613
+ max-width: 1200px;
614
+ display: flex;
615
+ flex-direction: column;
616
+ box-shadow: 0 8px 32px rgba(0, 0, 0, 0.3);
617
+ }
618
+
619
+ #dep-graph-header {
620
+ display: flex;
621
+ align-items: center;
622
+ justify-content: space-between;
623
+ padding: 16px 20px;
624
+ border-bottom: 1px solid var(--border-color);
625
+ }
626
+
627
+ #dep-graph-header h2 {
628
+ font-size: 16px;
629
+ font-weight: 600;
630
+ margin: 0;
631
+ }
632
+
633
+ #dep-graph-controls {
634
+ display: flex;
635
+ align-items: center;
636
+ gap: 12px;
637
+ }
638
+
639
+ #dep-type-filter {
640
+ padding: 6px 12px;
641
+ border: 1px solid var(--border-color);
642
+ border-radius: 4px;
643
+ background: var(--bg-primary);
644
+ color: var(--text-primary);
645
+ font-size: 13px;
646
+ }
647
+
648
+ #dep-graph-close {
649
+ background: none;
650
+ border: none;
651
+ font-size: 24px;
652
+ cursor: pointer;
653
+ color: var(--text-secondary);
654
+ padding: 4px 8px;
655
+ line-height: 1;
656
+ }
657
+
658
+ #dep-graph-close:hover {
659
+ color: var(--text-primary);
660
+ }
661
+
662
+ #dep-graph-content {
663
+ flex: 1;
664
+ overflow: auto;
665
+ padding: 20px;
666
+ }
667
+
668
+ #dep-graph-svg {
669
+ display: block;
670
+ margin: 0 auto;
671
+ }
672
+
673
+ #dep-graph-legend {
674
+ display: flex;
675
+ align-items: center;
676
+ justify-content: center;
677
+ gap: 24px;
678
+ padding: 12px 20px;
679
+ border-top: 1px solid var(--border-color);
680
+ font-size: 12px;
681
+ color: var(--text-secondary);
682
+ }
683
+
684
+ .legend-item {
685
+ display: flex;
686
+ align-items: center;
687
+ gap: 6px;
688
+ }
689
+
690
+ .legend-box {
691
+ width: 14px;
692
+ height: 10px;
693
+ border-radius: 2px;
694
+ }
695
+
696
+ .legend-box.pending {
697
+ background: var(--text-secondary);
698
+ }
699
+
700
+ .legend-box.in-progress {
701
+ background: var(--warning-color);
702
+ }
703
+
704
+ .legend-box.completed {
705
+ background: var(--success-color);
706
+ }
707
+
708
+ .legend-arrow {
709
+ color: var(--text-secondary);
710
+ }
711
+
712
+ /* SVG Graph Styles */
713
+ #dep-graph-svg .node {
714
+ cursor: pointer;
715
+ }
716
+
717
+ #dep-graph-svg .node-box {
718
+ stroke-width: 2px;
719
+ rx: 6;
720
+ ry: 6;
721
+ }
722
+
723
+ #dep-graph-svg .node-box.pending {
724
+ fill: var(--bg-secondary);
725
+ stroke: var(--text-secondary);
726
+ }
727
+
728
+ #dep-graph-svg .node-box.in-progress {
729
+ fill: color-mix(in srgb, var(--warning-color) 15%, var(--bg-secondary));
730
+ stroke: var(--warning-color);
731
+ }
732
+
733
+ #dep-graph-svg .node-box.completed {
734
+ fill: color-mix(in srgb, var(--success-color) 15%, var(--bg-secondary));
735
+ stroke: var(--success-color);
736
+ }
737
+
738
+ #dep-graph-svg .node:hover .node-box {
739
+ stroke-width: 3px;
740
+ filter: brightness(1.1);
741
+ }
742
+
743
+ #dep-graph-svg .node-ref {
744
+ font-size: 11px;
745
+ font-weight: 600;
746
+ fill: var(--text-primary);
747
+ pointer-events: none;
748
+ text-anchor: start;
749
+ }
750
+
751
+ #dep-graph-svg .node-title {
752
+ font-size: 10px;
753
+ fill: var(--text-primary);
754
+ pointer-events: none;
755
+ text-anchor: start;
756
+ }
757
+
758
+ #dep-graph-svg .node-status {
759
+ font-size: 9px;
760
+ font-weight: 500;
761
+ text-transform: capitalize;
762
+ pointer-events: none;
763
+ text-anchor: start;
764
+ }
765
+
766
+ #dep-graph-svg .node-status.pending {
767
+ fill: var(--text-secondary);
768
+ }
769
+
770
+ #dep-graph-svg .node-status.in-progress {
771
+ fill: var(--warning-color);
772
+ }
773
+
774
+ #dep-graph-svg .node-status.completed {
775
+ fill: var(--success-color);
776
+ }
777
+
778
+ #dep-graph-svg .edge {
779
+ stroke: var(--text-secondary);
780
+ stroke-width: 2px;
781
+ fill: none;
782
+ }
783
+
784
+ #dep-graph-svg .edge.circular {
785
+ stroke: var(--danger-color);
786
+ stroke-dasharray: 4, 2;
787
+ }
788
+
789
+ #dep-graph-svg .edge-dot {
790
+ fill: var(--text-secondary);
791
+ }
792
+
793
+ #dep-graph-svg .edge-dot.circular {
794
+ fill: var(--danger-color);
795
+ }
796
+
797
+ /* Empty state for no dependencies */
798
+ .dep-graph-empty {
799
+ text-align: center;
800
+ color: var(--text-secondary);
801
+ padding: 60px;
802
+ }
803
+
804
+ .dep-graph-empty p:first-child {
805
+ font-size: 48px;
806
+ margin-bottom: 16px;
807
+ }