_proposals.scss
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