gabriel / musehub public
_proposals.scss
768 lines 25.1 KB
Raw
sha256:3ff9c9863a9891bdcde71b4a43228f66d0493e38b7cc1d09fe9eb7de774046b2 feat: add repair-commit wire endpoint (API parity with repa… Opus 4.8 minor ⚠ breaking 1 day ago
1 // ─────────────────────────────────────────────────────────────────────────────
2 // Component: Proposals list (.prl-* prefix)
3 // File: src/scss/components/_proposals.scss
4 //
5 // All visual rules — colors, typography, borders, backgrounds.
6 // Page layout lives in pages/_proposals.scss.
7 // ─────────────────────────────────────────────────────────────────────────────
8
9 $proposal-open: #3fb950;
10 $proposal-merged: #a371f7;
11 $proposal-closed: #f85149;
12
13 // ── Hero ──────────────────────────────────────────────────────────────────────
14
15 .prl-hero {
16 position: relative;
17 overflow: hidden;
18 background: linear-gradient(to bottom, color-mix(in srgb, var(--bg-canvas) 60%, transparent) 0%, var(--bg-surface) 100%);
19 border-bottom: 1px solid var(--border-default);
20 padding: var(--space-10) var(--space-8) var(--space-8);
21 }
22
23 .prl-hero-glow {
24 position: absolute;
25 inset: 0;
26 pointer-events: none;
27 opacity: 0.06;
28
29 &--open { background: radial-gradient(ellipse 55% 60% at 15% 0%, #{$proposal-open} 0%, transparent 70%); }
30 &--merged { background: radial-gradient(ellipse 55% 60% at 15% 0%, #{$proposal-merged} 0%, transparent 70%); }
31 &--closed { background: radial-gradient(ellipse 55% 60% at 15% 0%, #{$proposal-closed} 0%, transparent 70%); }
32 &--all { background: radial-gradient(ellipse 55% 60% at 15% 0%, var(--color-accent) 0%, transparent 70%); }
33 }
34
35 .prl-hero-eyebrow {
36 display: inline-flex;
37 align-items: center;
38 gap: 6px;
39 font-size: 11px;
40 font-weight: var(--weight-medium);
41 color: var(--text-muted);
42 text-transform: uppercase;
43 letter-spacing: 0.07em;
44 margin-bottom: var(--space-1);
45 }
46
47 .prl-hero-title {
48 font-size: 28px;
49 font-weight: var(--weight-bold);
50 color: var(--text-primary);
51 line-height: 1.15;
52 margin: 0;
53 letter-spacing: -0.02em;
54 }
55
56 .prl-hero-sub {
57 font-size: 13px;
58 color: var(--text-muted);
59 line-height: 1.55;
60 margin: 0;
61 max-width: 440px;
62 }
63
64 .prl-new-btn {
65 display: inline-flex;
66 align-items: center;
67 gap: 7px;
68 padding: 8px 16px;
69 font-size: 13px;
70 font-weight: var(--weight-semibold);
71 color: var(--text-primary);
72 background: transparent;
73 border: 1px solid var(--border-default);
74 border-radius: var(--radius-md);
75 text-decoration: none;
76 transition: border-color var(--transition-fast), background var(--transition-fast), color var(--transition-fast);
77
78 &:hover {
79 text-decoration: none;
80 border-color: var(--color-accent);
81 color: var(--color-accent);
82 background: color-mix(in srgb, var(--color-accent) 7%, transparent);
83 }
84 }
85
86 // ── Filter / sort bar ─────────────────────────────────────────────────────────
87
88 .prl-filterbar {
89 display: flex;
90 align-items: stretch;
91 border-bottom: 1px solid var(--border-subtle);
92 background: var(--bg-surface);
93 padding: 0 var(--space-6);
94 gap: 0;
95 min-height: 44px;
96 }
97
98 .prl-tabs {
99 display: flex;
100 flex: 1;
101 gap: 0;
102 overflow-x: auto;
103 scrollbar-width: none;
104 &::-webkit-scrollbar { display: none; }
105 }
106
107 .prl-tab {
108 display: inline-flex;
109 align-items: center;
110 gap: 6px;
111 padding: 0 14px;
112 font-size: 12px;
113 font-weight: var(--weight-medium);
114 color: var(--text-muted);
115 text-decoration: none;
116 border-bottom: 2px solid transparent;
117 white-space: nowrap;
118 transition: color var(--transition-fast), border-color var(--transition-fast);
119 min-height: 44px;
120
121 &:hover { color: var(--text-secondary); text-decoration: none; }
122
123 &--active {
124 color: var(--text-primary);
125 border-bottom-color: var(--color-accent);
126 font-weight: var(--weight-semibold);
127 }
128 }
129
130 .prl-tab-pip {
131 width: 7px;
132 height: 7px;
133 border-radius: 50%;
134 flex-shrink: 0;
135 &--open { background: $proposal-open; }
136 &--merged { background: $proposal-merged; }
137 &--closed { background: $proposal-closed; }
138 }
139
140 .prl-tab-ct {
141 background: var(--bg-overlay);
142 border: 1px solid var(--border-subtle);
143 border-radius: var(--radius-full);
144 font-size: 10px;
145 font-weight: var(--weight-semibold);
146 font-family: var(--font-mono);
147 padding: 1px 5px;
148 min-width: 16px;
149 text-align: center;
150 color: var(--text-muted);
151 }
152
153 .prl-controls-divider {
154 width: 1px;
155 height: 16px;
156 background: var(--border-subtle);
157 flex-shrink: 0;
158 }
159
160 .prl-pill-group {
161 display: flex;
162 align-items: center;
163 gap: 1px;
164 }
165
166 .prl-pill {
167 font-size: 11px;
168 font-weight: var(--weight-medium);
169 color: var(--text-muted);
170 text-decoration: none;
171 padding: 3px 9px;
172 border-radius: var(--radius-full);
173 transition: background var(--transition-fast), color var(--transition-fast);
174 white-space: nowrap;
175
176 &:hover { color: var(--text-secondary); text-decoration: none; background: var(--bg-overlay); }
177
178 &--active {
179 color: var(--text-primary);
180 font-weight: var(--weight-semibold);
181 background: var(--bg-overlay);
182 border: 1px solid var(--border-subtle);
183 }
184 }
185
186 // ── Proposal row ──────────────────────────────────────────────────────────────
187
188 .prl-row {
189 display: flex;
190 align-items: flex-start;
191 gap: var(--space-4);
192 padding: 20px var(--space-6);
193 border-bottom: 1px solid var(--border-subtle);
194 text-decoration: none;
195 cursor: pointer;
196 transition: background var(--transition-fast);
197 animation: prl-row-in 180ms ease both;
198
199 &:last-child { border-bottom: none; }
200 &:nth-child(even) { background: color-mix(in srgb, var(--bg-overlay) 80%, transparent); }
201 &:hover { background: var(--bg-overlay); text-decoration: none; }
202 }
203
204 @keyframes prl-row-in {
205 from { opacity: 0; transform: translateY(4px); }
206 to { opacity: 1; transform: translateY(0); }
207 }
208
209 @for $i from 1 through 8 {
210 .prl-row:nth-child(#{$i}) { animation-delay: #{($i - 1) * 28}ms; }
211 }
212
213 .prl-row-num {
214 font-size: 11px;
215 font-family: var(--font-mono);
216 color: var(--text-muted);
217 opacity: 0.4;
218 flex-shrink: 0;
219 width: 36px;
220 text-align: right;
221 }
222
223 .prl-row-title {
224 font-size: 14px;
225 font-weight: var(--weight-semibold);
226 color: var(--text-primary);
227 line-height: 1.4;
228 display: block;
229 margin: 6px 0 4px;
230 }
231
232 // ── Key-value chip — universal badge component ────────────────────────────────
233 // Each chip has a dim key zone and a highlighted value zone.
234 // Outer element carries the color variant class.
235
236 .prl-kv {
237 display: inline-flex;
238 align-items: stretch;
239 font-size: 10px;
240 font-family: var(--font-mono);
241 border-radius: var(--radius-sm);
242 border: 1px solid var(--border-subtle);
243 overflow: hidden;
244 flex-shrink: 0;
245 letter-spacing: 0.03em;
246 }
247
248 .prl-kv-k {
249 display: inline-flex;
250 align-items: center;
251 padding: 2px 5px;
252 color: var(--text-muted);
253 font-weight: 400;
254 background: color-mix(in srgb, var(--text-primary) 5%, transparent);
255 border-right: 1px solid var(--border-subtle);
256 gap: 3px;
257 }
258
259 .prl-kv-v {
260 display: inline-flex;
261 align-items: center;
262 gap: 4px;
263 padding: 2px 7px;
264 font-weight: var(--weight-semibold);
265 color: var(--text-secondary);
266 }
267
268 // The risk value zone contains an inline progress bar
269 .prl-kv-risk-bar {
270 display: inline-block;
271 height: 5px;
272 min-width: 3px;
273 max-width: 36px;
274 border-radius: 2px;
275 opacity: 0.7;
276 }
277
278 // ── Type variants ─────────────────────────────────────────────────────────────
279 .prl-kv--type {
280 border-color: color-mix(in srgb, var(--color-accent) 20%, transparent);
281 .prl-kv-v { color: var(--color-accent); }
282 }
283 .prl-kv--type-identity-transition {
284 border-color: color-mix(in srgb, #a78bfa 25%, transparent);
285 .prl-kv-v { color: #a78bfa; }
286 }
287 .prl-kv--type-canonical-release {
288 border-color: color-mix(in srgb, #34d399 25%, transparent);
289 .prl-kv-v { color: #34d399; }
290 }
291 .prl-kv--type-stem-integration {
292 border-color: color-mix(in srgb, #60a5fa 25%, transparent);
293 .prl-kv-v { color: #60a5fa; }
294 }
295 .prl-kv--type-midi-evolution {
296 border-color: color-mix(in srgb, #f472b6 25%, transparent);
297 .prl-kv-v { color: #f472b6; }
298 }
299 .prl-kv--type-payment-settlement {
300 border-color: color-mix(in srgb, #fbbf24 25%, transparent);
301 .prl-kv-v { color: #fbbf24; }
302 }
303 .prl-kv--type-agent-delegation {
304 border-color: color-mix(in srgb, #2dd4bf 25%, transparent);
305 .prl-kv-v { color: #2dd4bf; }
306 }
307
308 // ── Risk variants ─────────────────────────────────────────────────────────────
309 .prl-kv--risk-low {
310 border-color: color-mix(in srgb, var(--color-success) 25%, transparent);
311 .prl-kv-v { color: var(--color-success); }
312 .prl-kv-risk-bar { background: var(--color-success); }
313 }
314 .prl-kv--risk-medium {
315 border-color: color-mix(in srgb, var(--color-warning) 30%, transparent);
316 .prl-kv-v { color: var(--color-warning); }
317 .prl-kv-risk-bar { background: var(--color-warning); }
318 }
319 .prl-kv--risk-high {
320 border-color: color-mix(in srgb, var(--color-orange, #f97316) 30%, transparent);
321 .prl-kv-v { color: #f97316; }
322 .prl-kv-risk-bar { background: #f97316; }
323 }
324 .prl-kv--risk-critical {
325 border-color: color-mix(in srgb, var(--color-danger) 35%, transparent);
326 .prl-kv-k { background: color-mix(in srgb, var(--color-danger) 8%, transparent); }
327 .prl-kv-v { color: $proposal-closed; }
328 .prl-kv-risk-bar { background: var(--color-danger); }
329 }
330
331 // ── Strategy variant ──────────────────────────────────────────────────────────
332 .prl-kv--strategy {
333 border-color: color-mix(in srgb, var(--color-accent) 18%, transparent);
334 .prl-kv-v { color: var(--text-secondary); }
335 }
336
337 // ── Blocked variant ───────────────────────────────────────────────────────────
338 .prl-kv--blocked {
339 border-color: color-mix(in srgb, var(--color-danger) 30%, transparent);
340 .prl-kv-k { color: var(--color-danger); background: color-mix(in srgb, var(--color-danger) 8%, transparent); }
341 .prl-kv-v { color: $proposal-closed; }
342 }
343 .prl-kv--blocks {
344 border-color: color-mix(in srgb, var(--color-warning) 30%, transparent);
345 .prl-kv-k { color: var(--color-warning); background: color-mix(in srgb, var(--color-warning) 8%, transparent); }
346 .prl-kv-v { color: var(--color-warning); }
347 }
348
349 // ── Health variants ───────────────────────────────────────────────────────────
350 .prl-kv--breakage {
351 border-color: color-mix(in srgb, var(--color-danger) 25%, transparent);
352 .prl-kv-k { color: $proposal-closed; background: color-mix(in srgb, var(--color-danger) 8%, transparent); }
353 .prl-kv-v { color: $proposal-closed; }
354 }
355 .prl-kv--gap {
356 border-color: color-mix(in srgb, var(--color-warning) 25%, transparent);
357 .prl-kv-k { color: var(--color-warning); background: color-mix(in srgb, var(--color-warning) 8%, transparent); }
358 .prl-kv-v { color: var(--color-warning); }
359 }
360
361 // ── Semver variants ───────────────────────────────────────────────────────────
362 .prl-kv--semver-major {
363 border-color: color-mix(in srgb, var(--color-danger) 30%, transparent);
364 .prl-kv-v { color: $proposal-closed; font-weight: var(--font-weight-black); }
365 }
366 .prl-kv--semver-minor {
367 border-color: color-mix(in srgb, var(--color-success) 25%, transparent);
368 .prl-kv-v { color: $proposal-open; }
369 }
370 .prl-kv--semver-patch {
371 border-color: var(--border-subtle);
372 .prl-kv-v { color: var(--text-muted); }
373 }
374
375 // ── Status variants ───────────────────────────────────────────────────────────
376 .prl-kv--ready {
377 border-color: color-mix(in srgb, var(--color-success) 25%, transparent);
378 .prl-kv-k { color: var(--color-success); background: color-mix(in srgb, var(--color-success) 8%, transparent); }
379 .prl-kv-v { color: var(--color-success); }
380 }
381 .prl-kv--settling {
382 border-color: color-mix(in srgb, var(--color-warning) 25%, transparent);
383 .prl-kv-k { color: var(--color-warning); background: color-mix(in srgb, var(--color-warning) 8%, transparent); }
384 .prl-kv-v { color: var(--color-warning); }
385 }
386 .prl-kv--draft {
387 border-color: var(--border-subtle);
388 .prl-kv-k { color: var(--text-muted); }
389 .prl-kv-v { color: var(--text-muted); }
390 }
391
392 // Commit-type badge
393 .prl-badge {
394 display: inline-block;
395 font-size: 10px;
396 font-weight: var(--weight-bold);
397 font-family: var(--font-mono);
398 padding: 1px 5px;
399 border-radius: var(--radius-sm);
400 text-transform: lowercase;
401 letter-spacing: 0.02em;
402 background: color-mix(in srgb, var(--color-accent) 10%, transparent);
403 color: var(--color-accent);
404 border: 1px solid color-mix(in srgb, var(--color-accent) 22%, transparent);
405 flex-shrink: 0;
406
407 &[data-type="feat"],
408 &[data-type="feature"] { background: color-mix(in srgb, var(--color-success) 10%, transparent); color: $proposal-open; border-color: color-mix(in srgb, var(--color-success) 22%, transparent); }
409 &[data-type="fix"],
410 &[data-type="bugfix"],
411 &[data-type="hotfix"] { background: color-mix(in srgb, var(--color-danger) 10%, transparent); color: $proposal-closed; border-color: color-mix(in srgb, var(--color-danger) 22%, transparent); }
412 &[data-type="refactor"] { background: color-mix(in srgb, var(--color-purple) 10%, transparent); color: $proposal-merged; border-color: color-mix(in srgb, var(--color-purple) 22%, transparent); }
413 &[data-type="docs"] { background: color-mix(in srgb, var(--color-warning) 10%, transparent); color: var(--color-warning); border-color: color-mix(in srgb, var(--color-warning) 22%, transparent); }
414 &[data-type="test"] { background: color-mix(in srgb, var(--color-teal) 10%, transparent); color: var(--color-teal); border-color: rgba(45, 212, 191, 0.22); }
415 &[data-type="chore"],
416 &[data-type="style"] { background: color-mix(in srgb, var(--text-secondary) 10%, transparent); color: var(--text-secondary); border-color: color-mix(in srgb, var(--text-secondary) 22%, transparent); }
417 &[data-type="redesign"] { background: rgba(245, 158, 11, 0.1); color: #f59e0b; border-color: rgba(245, 158, 11, 0.22); }
418 &[data-type="breaking"],
419 &[data-type="major"] { background: color-mix(in srgb, var(--color-danger) 15%, transparent); color: $proposal-closed; border-color: color-mix(in srgb, var(--color-danger) 30%, transparent); font-weight: var(--font-weight-black); }
420 }
421
422 // Semver impact pill
423 .prl-impact {
424 display: inline-block;
425 font-size: 9px;
426 font-weight: var(--font-weight-black);
427 font-family: var(--font-mono);
428 padding: 1px 4px;
429 border-radius: 2px;
430 text-transform: uppercase;
431 letter-spacing: 0.06em;
432 flex-shrink: 0;
433
434 &--major { background: color-mix(in srgb, var(--color-danger) 15%, transparent); color: $proposal-closed; }
435 &--minor { background: color-mix(in srgb, var(--color-success) 12%, transparent); color: $proposal-open; }
436 &--patch { background: color-mix(in srgb, var(--text-secondary) 12%, transparent); color: var(--text-secondary); }
437 }
438
439 .prl-badge--breakage {
440 background: color-mix(in srgb, var(--color-danger) 10%, transparent);
441 color: $proposal-closed;
442 border-color: color-mix(in srgb, var(--color-danger) 22%, transparent);
443 display: inline-flex;
444 align-items: center;
445 gap: 3px;
446 flex-shrink: 0;
447 }
448
449 .prl-badge--gap {
450 background: color-mix(in srgb, var(--color-warning) 10%, transparent);
451 color: var(--color-warning);
452 border-color: color-mix(in srgb, var(--color-warning) 22%, transparent);
453 display: inline-flex;
454 align-items: center;
455 gap: 3px;
456 flex-shrink: 0;
457 }
458
459 .prl-branch {
460 display: inline-flex;
461 align-items: center;
462 gap: 3px;
463 font-size: 11px;
464 font-family: var(--font-mono);
465 color: var(--text-muted);
466 background: var(--bg-overlay);
467 border: 1px solid var(--border-subtle);
468 border-radius: var(--radius-sm);
469 padding: 1px 5px;
470 max-width: 200px;
471 overflow: hidden;
472 text-overflow: ellipsis;
473 white-space: nowrap;
474
475 &--from {
476 color: var(--color-accent);
477 border-color: color-mix(in srgb, var(--color-accent) 22%, transparent);
478 background: color-mix(in srgb, var(--color-accent) 7%, transparent);
479 }
480 }
481
482 .prl-arrow { flex-shrink: 0; color: var(--text-muted); opacity: 0.5; }
483 .prl-meta-dot { opacity: 0.3; flex-shrink: 0; }
484
485 .prl-actor {
486 display: inline-flex;
487 align-items: center;
488 gap: 4px;
489 color: var(--text-secondary);
490 font-weight: var(--weight-medium);
491 flex-shrink: 0;
492 }
493
494 .prl-sigil {
495 width: 20px;
496 height: 20px;
497 border-radius: 4px;
498 flex-shrink: 0;
499 display: block;
500 }
501
502 .prl-date { color: var(--text-muted); flex-shrink: 0; }
503
504 .prl-snippet {
505 font-size: 11px;
506 color: var(--text-muted);
507 overflow: hidden;
508 white-space: nowrap;
509 text-overflow: ellipsis;
510 opacity: 0.75;
511 min-width: 0;
512 max-width: 320px;
513 }
514
515 .prl-merged-label {
516 display: inline-flex;
517 align-items: center;
518 gap: 4px;
519 font-size: 11px;
520 color: $proposal-merged;
521 opacity: 0.8;
522 }
523
524 .prl-closed-label { font-size: 11px; color: $proposal-closed; opacity: 0.7; }
525
526 .prl-sha {
527 font-size: 10px;
528 font-family: var(--font-mono);
529 color: var(--text-muted);
530 opacity: 0.6;
531 text-decoration: none;
532 transition: opacity var(--transition-fast);
533 &:hover { opacity: 1; text-decoration: underline; }
534 }
535
536 .prl-chevron {
537 flex-shrink: 0;
538 color: var(--text-muted);
539 opacity: 0;
540 transition: opacity var(--transition-fast);
541 }
542 .prl-row:hover .prl-chevron { opacity: 0.5; }
543
544 // ── Empty state ───────────────────────────────────────────────────────────────
545
546 .prl-empty-icon { opacity: 0.18; margin-bottom: var(--space-2); }
547
548 .prl-empty-title {
549 font-size: 18px;
550 font-weight: var(--weight-semibold);
551 color: var(--text-secondary);
552 }
553
554 .prl-empty-desc {
555 font-size: 13px;
556 color: var(--text-muted);
557 line-height: 1.6;
558 max-width: 380px;
559 }
560
561 .prl-empty-cli {
562 display: inline-flex;
563 align-items: center;
564 gap: 8px;
565 margin-top: var(--space-2);
566 padding: var(--space-2) var(--space-4);
567 border-radius: var(--radius-md);
568 background: var(--bg-overlay);
569 border: 1px solid var(--border-subtle);
570 font-size: 12px;
571 }
572
573 .prl-empty-cli-prompt { font-family: var(--font-mono); color: var(--text-muted); opacity: 0.5; }
574 .prl-empty-cli-cmd { font-family: var(--font-mono); color: var(--text-primary); font-weight: var(--weight-medium); }
575 .prl-empty-cli-hint { color: var(--text-muted); border-left: 1px solid var(--border-subtle); padding-left: 8px; }
576
577 // ── Proposal type badge (ptype) ───────────────────────────────────────────────
578
579 .prl-badge--ptype {
580 font-size: 9px;
581 font-weight: var(--weight-bold);
582 font-family: var(--font-mono);
583 text-transform: uppercase;
584 letter-spacing: 0.07em;
585 padding: 2px 6px;
586 border-radius: var(--radius-sm);
587 flex-shrink: 0;
588 background: color-mix(in srgb, var(--color-accent) 12%, transparent);
589 color: var(--color-accent);
590 border: 1px solid color-mix(in srgb, var(--color-accent) 25%, transparent);
591 }
592
593 // ── Inline risk display (line 1 of row) ───────────────────────────────────────
594
595 .prl-risk-inline {
596 display: inline-flex;
597 align-items: center;
598 gap: 5px;
599 flex-shrink: 0;
600 }
601
602 .prl-risk-inline-bar {
603 display: inline-block;
604 height: 6px;
605 min-width: 4px;
606 max-width: 48px;
607 border-radius: 2px;
608 }
609
610 .prl-risk-inline-label {
611 font-size: 9px;
612 font-weight: var(--weight-bold);
613 font-family: var(--font-mono);
614 text-transform: uppercase;
615 letter-spacing: 0.06em;
616 }
617
618 .prl-risk-inline--low {
619 .prl-risk-inline-bar { background: var(--color-success); }
620 .prl-risk-inline-label { color: var(--color-success); }
621 }
622 .prl-risk-inline--medium {
623 .prl-risk-inline-bar { background: var(--color-warning); }
624 .prl-risk-inline-label { color: var(--color-warning); }
625 }
626 .prl-risk-inline--high {
627 .prl-risk-inline-bar { background: var(--color-orange); }
628 .prl-risk-inline-label { color: var(--color-orange); }
629 }
630 .prl-risk-inline--critical {
631 .prl-risk-inline-bar { background: var(--color-danger-critical); }
632 .prl-risk-inline-label { color: var(--color-danger-critical); }
633 }
634
635 // ── Status indicator badges (blocked / settling / ready) ──────────────────────
636
637 .prl-dep-lock {
638 display: inline-flex;
639 align-items: center;
640 gap: 4px;
641 font-size: 10px;
642 font-family: var(--font-mono);
643 font-weight: var(--weight-semibold);
644 color: var(--color-danger);
645 background: color-mix(in srgb, var(--color-danger) 8%, transparent);
646 border: 1px solid color-mix(in srgb, var(--color-danger) 22%, transparent);
647 border-radius: var(--radius-sm);
648 padding: 1px 6px;
649 flex-shrink: 0;
650 }
651
652 .prl-settling-badge {
653 display: inline-flex;
654 align-items: center;
655 gap: 4px;
656 font-size: 10px;
657 font-family: var(--font-mono);
658 font-weight: var(--weight-semibold);
659 color: var(--color-warning);
660 background: color-mix(in srgb, var(--color-warning) 8%, transparent);
661 border: 1px solid color-mix(in srgb, var(--color-warning) 22%, transparent);
662 border-radius: var(--radius-sm);
663 padding: 1px 6px;
664 flex-shrink: 0;
665 }
666
667 .prl-merge-ready-badge {
668 display: inline-flex;
669 align-items: center;
670 gap: 4px;
671 font-size: 10px;
672 font-family: var(--font-mono);
673 font-weight: var(--weight-semibold);
674 color: var(--color-success);
675 background: color-mix(in srgb, var(--color-success) 8%, transparent);
676 border: 1px solid color-mix(in srgb, var(--color-success) 22%, transparent);
677 border-radius: var(--radius-sm);
678 padding: 1px 6px;
679 flex-shrink: 0;
680 }
681
682 // ── Approval pips ─────────────────────────────────────────────────────────────
683
684 .prl-approval-dots {
685 display: inline-flex;
686 align-items: center;
687 gap: 3px;
688 flex-shrink: 0;
689 }
690
691 .prl-approval-pip {
692 width: 7px;
693 height: 7px;
694 border-radius: 50%;
695 border: 1.5px solid var(--text-muted);
696 opacity: 0.4;
697 flex-shrink: 0;
698
699 &--filled {
700 background: var(--color-success);
701 border-color: var(--color-success);
702 opacity: 1;
703 }
704 }
705
706 .prl-approval-label {
707 font-size: 10px;
708 font-family: var(--font-mono);
709 color: var(--text-muted);
710 margin-left: 2px;
711 }
712
713 // ── Conflict count ────────────────────────────────────────────────────────────
714
715 .prl-conflict-count {
716 display: inline-flex;
717 align-items: center;
718 gap: 3px;
719 font-size: 10px;
720 font-family: var(--font-mono);
721 color: var(--color-warning);
722 flex-shrink: 0;
723
724 &--clean { color: var(--color-success); }
725 }
726
727 // ── Row footer (author · date · snippet) ──────────────────────────────────────
728
729 .prl-row-footer {
730 display: flex;
731 align-items: center;
732 flex-wrap: wrap;
733 gap: 5px;
734 font-size: 11px;
735 color: var(--text-muted);
736 min-width: 0;
737 }
738
739 .prl-author-badge {
740 display: inline-flex;
741 align-items: center;
742
743 &--agent {
744 color: var(--color-accent);
745 opacity: 0.8;
746 }
747 }
748
749 // ── Risk badge ────────────────────────────────────────────────────────────────
750
751 .prl-risk-badge {
752 display: inline-flex;
753 align-items: center;
754 font-size: 0.62rem;
755 font-weight: 700;
756 text-transform: uppercase;
757 letter-spacing: 0.07em;
758 padding: 2px 7px;
759 border-radius: 9999px;
760 border: 1px solid;
761 font-family: var(--font-mono);
762 white-space: nowrap;
763
764 &--low { color: var(--color-success); border-color: color-mix(in srgb, var(--color-success) 35%, transparent); background: color-mix(in srgb, var(--color-success) 8%, transparent); }
765 &--medium { color: var(--color-warning); border-color: color-mix(in srgb, var(--color-warning) 35%, transparent); background: color-mix(in srgb, var(--color-warning) 8%, transparent); }
766 &--high { color: var(--color-orange); border-color: color-mix(in srgb, var(--color-orange) 35%, transparent); background: color-mix(in srgb, var(--color-orange) 8%, transparent); }
767 &--critical { color: var(--color-danger-critical); border-color: color-mix(in srgb, var(--color-danger-critical) 35%, transparent); background: color-mix(in srgb, var(--color-danger-critical) 8%, transparent); }
768 }
File History 1 commit
sha256:3ff9c9863a9891bdcde71b4a43228f66d0493e38b7cc1d09fe9eb7de774046b2 feat: add repair-commit wire endpoint (API parity with repa… Opus 4.8 minor 1 day ago