@pipelex/mthds-ui 0.6.4 → 0.7.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.
@@ -1,14 +1,14 @@
1
1
  /* src/graph/react/stuff/StuffViewer.css */
2
2
  .stuff-viewer {
3
- --sv-bg: var(--color-bg, #0a0a0a);
4
- --sv-surface: var(--color-surface, #16213e);
5
- --sv-surface-hover: var(--color-surface-hover, #1f2b47);
6
- --sv-border: var(--color-border, #2a3a5a);
7
- --sv-text: var(--color-text, #e2e8f0);
8
- --sv-text-muted: var(--color-text-muted, #94a3b8);
9
- --sv-accent: var(--color-accent, #3b82f6);
10
- --sv-success: #10b981;
11
- --sv-success-bg: rgba(16, 185, 129, 0.2);
3
+ --sv-bg: var(--surface-page, #0a0a0a);
4
+ --sv-surface: var(--surface-panel, #111118);
5
+ --sv-surface-hover: var(--surface-elevated, rgba(255, 255, 255, 0.06));
6
+ --sv-border: var(--border-default, rgba(255, 255, 255, 0.1));
7
+ --sv-text: var(--text-default, #e2e8f0);
8
+ --sv-text-muted: var(--text-muted, #94a3b8);
9
+ --sv-accent: var(--color-accent, #8be9fd);
10
+ --sv-success: var(--color-success, #50fa7b);
11
+ --sv-success-bg: var(--color-success-bg, rgba(80, 250, 123, 0.15));
12
12
  --sv-radius: 4px;
13
13
  --sv-font-sans: var( --font-sans, "Inter", -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif );
14
14
  --sv-font-mono: var(--font-mono, "JetBrains Mono", "Monaco", "Menlo", monospace);
@@ -66,7 +66,7 @@
66
66
  }
67
67
  .stuff-viewer-tab--active {
68
68
  background: var(--sv-accent);
69
- color: #fff;
69
+ color: var(--text-on-accent, #0e0e0e);
70
70
  }
71
71
  .stuff-viewer-actions {
72
72
  display: flex;
@@ -235,6 +235,25 @@ button.stuff-viewer-local-file--button:focus-visible {
235
235
  font-style: italic;
236
236
  font-size: 13px;
237
237
  }
238
+ .stuff-viewer-error {
239
+ border: 1px solid var(--color-status-failed, #ff5555);
240
+ border-radius: 6px;
241
+ padding: 12px;
242
+ background: rgba(255, 85, 85, 0.08);
243
+ }
244
+ .stuff-viewer-error-title {
245
+ color: var(--color-status-failed, #ff5555);
246
+ font-weight: 600;
247
+ font-size: 13px;
248
+ margin-bottom: 4px;
249
+ }
250
+ .stuff-viewer-error-detail {
251
+ color: var(--sv-text-muted);
252
+ font-family: var(--font-mono, monospace);
253
+ font-size: 12px;
254
+ white-space: pre-wrap;
255
+ word-break: break-word;
256
+ }
238
257
 
239
258
  /* src/graph/react/detail/DetailPanel.css */
240
259
  .detail-panel {
@@ -243,16 +262,13 @@ button.stuff-viewer-local-file--button:focus-visible {
243
262
  right: 0;
244
263
  width: 380px;
245
264
  height: 100%;
246
- background: #111118;
247
- border-left: 1px solid rgba(255, 255, 255, 0.1);
265
+ background: var(--surface-panel);
266
+ border-left: 1px solid var(--border-default);
248
267
  z-index: 10;
249
268
  display: flex;
250
269
  flex-direction: column;
251
- font-family:
252
- "Inter",
253
- -apple-system,
254
- sans-serif;
255
- color: #e2e8f0;
270
+ font-family: var(--font-sans);
271
+ color: var(--text-default);
256
272
  overflow: hidden;
257
273
  transition: transform 0.2s ease;
258
274
  }
@@ -282,7 +298,8 @@ button.stuff-viewer-local-file--button:focus-visible {
282
298
  }
283
299
  .detail-panel-resize-handle:hover::before,
284
300
  .detail-panel--dragging .detail-panel-resize-handle::before {
285
- background: rgba(59, 130, 246, 0.5);
301
+ background: var(--color-accent);
302
+ opacity: 0.6;
286
303
  }
287
304
  .detail-panel-resize-handle::after {
288
305
  content: "";
@@ -298,7 +315,7 @@ button.stuff-viewer-local-file--button:focus-visible {
298
315
  }
299
316
  .detail-panel-resize-handle:hover::after,
300
317
  .detail-panel--dragging .detail-panel-resize-handle::after {
301
- background: rgba(59, 130, 246, 0.8);
318
+ background: var(--color-accent);
302
319
  }
303
320
  .detail-panel--dragging {
304
321
  transition: none;
@@ -306,42 +323,44 @@ button.stuff-viewer-local-file--button:focus-visible {
306
323
  .detail-panel--dragging .detail-panel-content {
307
324
  pointer-events: none;
308
325
  }
326
+ .detail-panel-close-row {
327
+ display: flex;
328
+ justify-content: flex-end;
329
+ margin-bottom: -40px;
330
+ }
309
331
  .detail-panel-close {
310
332
  all: unset;
311
333
  cursor: pointer;
312
- position: absolute;
313
- top: 12px;
314
- right: 12px;
315
334
  width: 24px;
316
335
  height: 24px;
317
336
  display: flex;
318
337
  align-items: center;
319
338
  justify-content: center;
320
339
  border-radius: 4px;
321
- color: #64748b;
340
+ color: var(--text-dim);
322
341
  font-size: 18px;
323
342
  line-height: 1;
324
- z-index: 3;
343
+ z-index: 2;
325
344
  }
326
345
  .detail-panel-close:hover {
327
- color: #94a3b8;
328
- background: rgba(255, 255, 255, 0.06);
346
+ color: var(--text-muted);
347
+ background: var(--surface-elevated);
329
348
  }
330
349
  .detail-panel-content {
331
350
  flex: 1;
332
351
  overflow-y: auto;
333
- padding: 20px 16px;
352
+ padding: 12px 16px 20px;
334
353
  display: flex;
335
354
  flex-direction: column;
336
355
  gap: 16px;
337
356
  }
338
357
  .detail-sticky-header {
339
358
  position: sticky;
340
- top: -20px;
359
+ top: -12px;
341
360
  z-index: 1;
342
- background: #111118;
343
- padding-top: 20px;
344
- margin-top: -20px;
361
+ background: var(--surface-panel);
362
+ padding-top: 12px;
363
+ margin-top: -12px;
345
364
  display: flex;
346
365
  flex-direction: column;
347
366
  gap: 16px;
@@ -351,7 +370,7 @@ button.stuff-viewer-local-file--button:focus-visible {
351
370
  font-weight: 700;
352
371
  text-transform: uppercase;
353
372
  letter-spacing: 0.06em;
354
- color: #64748b;
373
+ color: var(--text-dim);
355
374
  margin-bottom: 6px;
356
375
  }
357
376
  .detail-header {
@@ -369,24 +388,21 @@ button.stuff-viewer-local-file--button:focus-visible {
369
388
  white-space: nowrap;
370
389
  }
371
390
  .detail-badge--operator {
372
- background: #ff6b6b;
373
- color: #0e0e0e;
391
+ background: var(--color-pipe);
392
+ color: var(--text-on-accent);
374
393
  }
375
394
  .detail-badge--controller {
376
- background: #bd93f9;
377
- color: #0e0e0e;
395
+ background: var(--color-batch-item);
396
+ color: var(--text-on-accent);
378
397
  }
379
398
  .detail-pipe-code {
380
- font-family:
381
- "JetBrains Mono",
382
- "Monaco",
383
- monospace;
399
+ font-family: var(--font-mono);
384
400
  font-size: 14px;
385
401
  font-weight: 600;
386
- color: #ff6b6b;
402
+ color: var(--color-pipe);
387
403
  }
388
404
  .detail-pipe-code--controller {
389
- color: #bd93f9;
405
+ color: var(--color-batch-item);
390
406
  }
391
407
  .detail-status {
392
408
  display: flex;
@@ -406,15 +422,12 @@ button.stuff-viewer-local-file--button:focus-visible {
406
422
  }
407
423
  .detail-duration {
408
424
  font-size: 11px;
409
- color: #64748b;
410
- font-family:
411
- "JetBrains Mono",
412
- "Monaco",
413
- monospace;
425
+ color: var(--text-dim);
426
+ font-family: var(--font-mono);
414
427
  }
415
428
  .detail-description {
416
429
  font-size: 12px;
417
- color: #94a3b8;
430
+ color: var(--text-muted);
418
431
  line-height: 1.5;
419
432
  }
420
433
  .detail-io-pill {
@@ -424,18 +437,15 @@ button.stuff-viewer-local-file--button:focus-visible {
424
437
  font-size: 11px;
425
438
  padding: 3px 8px;
426
439
  border-radius: 4px;
427
- background: rgba(255, 255, 255, 0.04);
428
- border: 1px solid rgba(255, 255, 255, 0.06);
440
+ background: var(--surface-sunken);
441
+ border: 1px solid var(--border-subtle);
429
442
  }
430
443
  .detail-io-name {
431
- font-family:
432
- "JetBrains Mono",
433
- "Monaco",
434
- monospace;
435
- color: #e2e8f0;
444
+ font-family: var(--font-mono);
445
+ color: var(--text-default);
436
446
  }
437
447
  .detail-io-concept {
438
- color: #64748b;
448
+ color: var(--text-dim);
439
449
  font-size: 10px;
440
450
  }
441
451
  .detail-io-list {
@@ -444,14 +454,11 @@ button.stuff-viewer-local-file--button:focus-visible {
444
454
  gap: 4px;
445
455
  }
446
456
  .detail-prompt-block {
447
- font-family:
448
- "JetBrains Mono",
449
- "Monaco",
450
- monospace;
457
+ font-family: var(--font-mono);
451
458
  font-size: 11px;
452
- color: #94a3b8;
453
- background: rgba(255, 255, 255, 0.03);
454
- border: 1px solid rgba(255, 255, 255, 0.06);
459
+ color: var(--text-muted);
460
+ background: var(--surface-sunken);
461
+ border: 1px solid var(--border-subtle);
455
462
  border-radius: 6px;
456
463
  padding: 10px 12px;
457
464
  white-space: pre-wrap;
@@ -473,15 +480,15 @@ button.stuff-viewer-local-file--button:focus-visible {
473
480
  align-items: center;
474
481
  gap: 4px;
475
482
  font-size: 9px;
476
- color: #64748b;
483
+ color: var(--text-dim);
477
484
  padding: 2px 6px;
478
485
  border-radius: 3px;
479
- background: rgba(255, 255, 255, 0.04);
480
- border: 1px solid rgba(255, 255, 255, 0.06);
486
+ background: var(--surface-sunken);
487
+ border: 1px solid var(--border-subtle);
481
488
  transition: color 0.15s;
482
489
  }
483
490
  .detail-prompt-expand-btn:hover {
484
- color: #94a3b8;
491
+ color: var(--text-muted);
485
492
  }
486
493
  .detail-kv-row {
487
494
  display: flex;
@@ -492,15 +499,12 @@ button.stuff-viewer-local-file--button:focus-visible {
492
499
  padding: 3px 0;
493
500
  }
494
501
  .detail-kv-key {
495
- color: #64748b;
502
+ color: var(--text-dim);
496
503
  flex-shrink: 0;
497
504
  }
498
505
  .detail-kv-value {
499
- font-family:
500
- "JetBrains Mono",
501
- "Monaco",
502
- monospace;
503
- color: #e2e8f0;
506
+ font-family: var(--font-mono);
507
+ color: var(--text-default);
504
508
  flex: 1 1 0;
505
509
  min-width: 0;
506
510
  text-align: right;
@@ -513,22 +517,16 @@ button.stuff-viewer-local-file--button:focus-visible {
513
517
  gap: 4px;
514
518
  }
515
519
  .detail-field-block-label {
516
- font-family:
517
- "JetBrains Mono",
518
- "Monaco",
519
- monospace;
520
+ font-family: var(--font-mono);
520
521
  font-size: 10px;
521
- color: #64748b;
522
+ color: var(--text-dim);
522
523
  }
523
524
  .detail-field-block-value {
524
- font-family:
525
- "JetBrains Mono",
526
- "Monaco",
527
- monospace;
525
+ font-family: var(--font-mono);
528
526
  font-size: 11px;
529
- color: #e2e8f0;
530
- background: rgba(255, 255, 255, 0.03);
531
- border: 1px solid rgba(255, 255, 255, 0.06);
527
+ color: var(--text-default);
528
+ background: var(--surface-sunken);
529
+ border: 1px solid var(--border-subtle);
532
530
  border-radius: 6px;
533
531
  padding: 8px 10px;
534
532
  white-space: pre-wrap;
@@ -546,24 +544,18 @@ button.stuff-viewer-local-file--button:focus-visible {
546
544
  margin-top: 6px;
547
545
  margin-bottom: 4px;
548
546
  padding: 4px 0 4px 8px;
549
- border-left: 2px solid rgba(80, 250, 123, 0.35);
547
+ border-left: 2px solid var(--color-success);
550
548
  }
551
549
  .detail-nested-header-name {
552
- font-family:
553
- "JetBrains Mono",
554
- "Monaco",
555
- monospace;
550
+ font-family: var(--font-mono);
556
551
  font-size: 11px;
557
552
  font-weight: 600;
558
- color: #e2e8f0;
553
+ color: var(--text-default);
559
554
  }
560
555
  .detail-nested-header-meta {
561
- font-family:
562
- "JetBrains Mono",
563
- "Monaco",
564
- monospace;
556
+ font-family: var(--font-mono);
565
557
  font-size: 9px;
566
- color: #64748b;
558
+ color: var(--text-dim);
567
559
  text-transform: uppercase;
568
560
  letter-spacing: 0.04em;
569
561
  }
@@ -575,56 +567,50 @@ button.stuff-viewer-local-file--button:focus-visible {
575
567
  .detail-schema-table th {
576
568
  text-align: left;
577
569
  font-weight: 700;
578
- color: #64748b;
570
+ color: var(--text-dim);
579
571
  font-size: 9px;
580
572
  text-transform: uppercase;
581
573
  letter-spacing: 0.06em;
582
574
  padding: 4px 6px;
583
- border-bottom: 1px solid rgba(255, 255, 255, 0.08);
575
+ border-bottom: 1px solid var(--border-default);
584
576
  }
585
577
  .detail-schema-table td {
586
578
  padding: 4px 6px;
587
- border-bottom: 1px solid rgba(255, 255, 255, 0.04);
588
- color: #94a3b8;
579
+ border-bottom: 1px solid var(--border-subtle);
580
+ color: var(--text-muted);
589
581
  }
590
582
  .detail-schema-field {
591
- font-family:
592
- "JetBrains Mono",
593
- "Monaco",
594
- monospace;
595
- color: #e2e8f0;
583
+ font-family: var(--font-mono);
584
+ color: var(--text-default);
596
585
  }
597
586
  .detail-schema-type {
598
- color: #8be9fd;
587
+ color: var(--color-accent);
599
588
  }
600
589
  .detail-schema-required {
601
- color: #ff6b6b;
590
+ color: var(--color-pipe);
602
591
  font-size: 9px;
603
592
  }
604
593
  .detail-error {
605
- background: rgba(255, 85, 85, 0.08);
606
- border: 1px solid rgba(255, 85, 85, 0.2);
594
+ background: var(--color-error-bg);
595
+ border: 1px solid var(--color-error-border);
607
596
  border-radius: 6px;
608
597
  padding: 10px 12px;
609
598
  }
610
599
  .detail-error-type {
611
600
  font-size: 12px;
612
601
  font-weight: 600;
613
- color: #ff5555;
602
+ color: var(--color-error);
614
603
  margin-bottom: 4px;
615
604
  }
616
605
  .detail-error-message {
617
606
  font-size: 11px;
618
- color: #94a3b8;
607
+ color: var(--text-muted);
619
608
  line-height: 1.5;
620
609
  }
621
610
  .detail-error-stack {
622
- font-family:
623
- "JetBrains Mono",
624
- "Monaco",
625
- monospace;
611
+ font-family: var(--font-mono);
626
612
  font-size: 10px;
627
- color: #64748b;
613
+ color: var(--text-dim);
628
614
  margin-top: 8px;
629
615
  max-height: 150px;
630
616
  overflow-y: auto;
@@ -643,21 +629,18 @@ button.stuff-viewer-local-file--button:focus-visible {
643
629
  font-size: 11px;
644
630
  padding: 4px 8px;
645
631
  border-radius: 4px;
646
- background: rgba(255, 255, 255, 0.03);
647
- border: 1px solid rgba(255, 255, 255, 0.06);
632
+ background: var(--surface-sunken);
633
+ border: 1px solid var(--border-subtle);
648
634
  }
649
635
  .detail-step-index {
650
- color: #64748b;
636
+ color: var(--text-dim);
651
637
  font-size: 10px;
652
638
  font-weight: 700;
653
639
  min-width: 16px;
654
640
  }
655
641
  .detail-step-code {
656
- font-family:
657
- "JetBrains Mono",
658
- "Monaco",
659
- monospace;
660
- color: #e2e8f0;
642
+ font-family: var(--font-mono);
643
+ color: var(--text-default);
661
644
  }
662
645
  .detail-tags {
663
646
  display: flex;
@@ -668,46 +651,67 @@ button.stuff-viewer-local-file--button:focus-visible {
668
651
  font-size: 10px;
669
652
  padding: 2px 6px;
670
653
  border-radius: 3px;
671
- background: rgba(255, 255, 255, 0.04);
672
- border: 1px solid rgba(255, 255, 255, 0.06);
654
+ background: var(--surface-sunken);
655
+ border: 1px solid var(--border-subtle);
673
656
  }
674
657
  .detail-tag-key {
675
- color: #64748b;
658
+ color: var(--text-dim);
676
659
  }
677
660
  .detail-tag-value {
678
- color: #e2e8f0;
679
- font-family:
680
- "JetBrains Mono",
681
- "Monaco",
682
- monospace;
661
+ color: var(--text-default);
662
+ font-family: var(--font-mono);
663
+ }
664
+ .detail-tabs {
665
+ display: flex;
666
+ gap: 2px;
667
+ border-bottom: 1px solid var(--border-default);
668
+ }
669
+ .detail-tab {
670
+ all: unset;
671
+ cursor: pointer;
672
+ font-size: 11px;
673
+ font-weight: 600;
674
+ color: var(--text-dim);
675
+ padding: 5px 10px;
676
+ border-radius: 4px 4px 0 0;
677
+ border-bottom: 2px solid transparent;
678
+ margin-bottom: -1px;
679
+ transition: color 0.15s, border-color 0.15s;
680
+ }
681
+ .detail-tab:hover {
682
+ color: var(--text-muted);
683
+ }
684
+ .detail-tab--active {
685
+ color: var(--text-default);
686
+ border-bottom-color: var(--color-accent);
687
+ }
688
+ .detail-tab:focus-visible,
689
+ .detail-panel-close:focus-visible,
690
+ .detail-prompt-expand-btn:focus-visible {
691
+ outline: 2px solid var(--color-accent);
692
+ outline-offset: 2px;
683
693
  }
684
694
  .detail-concept-code {
685
- font-family:
686
- "JetBrains Mono",
687
- "Monaco",
688
- monospace;
695
+ font-family: var(--font-mono);
689
696
  font-size: 14px;
690
697
  font-weight: 600;
691
- color: #50fa7b;
698
+ color: var(--color-success);
692
699
  }
693
700
  .detail-concept-domain {
694
701
  font-size: 11px;
695
- color: #64748b;
702
+ color: var(--text-dim);
696
703
  }
697
704
  .detail-refines {
698
705
  font-size: 11px;
699
- color: #94a3b8;
706
+ color: var(--text-muted);
700
707
  }
701
708
  .detail-refines-code {
702
- font-family:
703
- "JetBrains Mono",
704
- "Monaco",
705
- monospace;
706
- color: #8be9fd;
709
+ font-family: var(--font-mono);
710
+ color: var(--color-accent);
707
711
  }
708
712
  .detail-not-available {
709
713
  font-size: 12px;
710
- color: #64748b;
714
+ color: var(--text-dim);
711
715
  font-style: italic;
712
716
  padding: 8px 0;
713
717
  }
@@ -732,9 +736,9 @@ button.stuff-viewer-local-file--button:focus-visible {
732
736
  align-items: center;
733
737
  justify-content: center;
734
738
  border-radius: 6px;
735
- background: rgba(17, 17, 24, 0.8);
736
- border: 1px solid rgba(255, 255, 255, 0.1);
737
- color: #cbd5e1;
739
+ background: var(--surface-overlay);
740
+ border: 1px solid var(--border-default);
741
+ color: var(--text-secondary);
738
742
  backdrop-filter: blur(6px);
739
743
  transition:
740
744
  background 0.15s,
@@ -742,40 +746,37 @@ button.stuff-viewer-local-file--button:focus-visible {
742
746
  border-color 0.15s;
743
747
  }
744
748
  .graph-toolbar-btn:hover {
745
- background: rgba(30, 30, 40, 0.9);
746
- color: #f1f5f9;
747
- border-color: rgba(255, 255, 255, 0.18);
749
+ background: var(--surface-overlay-hover);
750
+ color: var(--text-primary);
751
+ border-color: var(--border-strong);
748
752
  }
749
753
  .graph-toolbar-btn:focus-visible {
750
- outline: 2px solid rgba(59, 130, 246, 0.6);
754
+ outline: 2px solid var(--focus-ring);
751
755
  outline-offset: 1px;
752
756
  }
753
757
  .graph-toolbar-btn--active {
754
- background: #3b82f6;
755
- border-color: #3b82f6;
756
- color: #ffffff;
758
+ background: var(--color-accent);
759
+ border-color: var(--color-accent);
760
+ color: var(--text-on-accent);
757
761
  }
758
762
  .graph-toolbar-btn--active:hover {
759
- background: #2563eb;
760
- border-color: #2563eb;
761
- color: #ffffff;
763
+ background: var(--color-accent);
764
+ border-color: var(--color-accent);
765
+ color: var(--text-on-accent);
766
+ filter: brightness(1.1);
762
767
  }
763
- .graph-toolbar-btn:disabled {
768
+ .graph-toolbar-btn:disabled,
769
+ .graph-toolbar-btn:disabled:hover {
764
770
  opacity: 0.4;
765
771
  cursor: not-allowed;
766
- background: rgba(17, 17, 24, 0.6);
767
- color: #64748b;
768
- border-color: rgba(255, 255, 255, 0.06);
769
- }
770
- .graph-toolbar-btn:disabled:hover {
771
- background: rgba(17, 17, 24, 0.6);
772
- color: #64748b;
773
- border-color: rgba(255, 255, 255, 0.06);
772
+ background: var(--surface-overlay-disabled);
773
+ color: var(--text-dim);
774
+ border-color: var(--border-subtle);
774
775
  }
775
776
  .graph-toolbar-separator {
776
777
  width: 1px;
777
778
  height: 18px;
778
- background: rgba(255, 255, 255, 0.12);
779
+ background: var(--border-default);
779
780
  margin: 0 2px;
780
781
  }
781
782
  /*# sourceMappingURL=index.css.map */