// ───────────────────────────────────────────────────────────────────────────── // Page: Releases (/*/releases + /*/releases/*) // File: src/scss/pages/_releases.scss // // STRUCTURAL LAYOUT ONLY — zero colors, zero typography here. // Visual rules live in components/_releases.scss. // ───────────────────────────────────────────────────────────────────────────── // ── Release list page (.rl-*) ───────────────────────────────────────────────── .rl-page { display: flex; flex-direction: column; gap: var(--space-4); } .rl-hero-inner { position: relative; display: flex; justify-content: space-between; align-items: center; gap: var(--space-6); padding: var(--space-7) 0 var(--space-6); flex-wrap: wrap; } .rl-hero-left { flex: 1; min-width: 0; } .rl-hero-meta-row { display: flex; align-items: center; gap: 8px; flex-wrap: wrap; margin-bottom: var(--space-3); } .rl-hero-actions { display: flex; align-items: center; gap: var(--space-2); flex-wrap: wrap; } .rl-hero-right { display: flex; flex-direction: column; gap: var(--space-2); flex-shrink: 0; @media (max-width: 640px) { display: none; } } .rl-stat-pill { display: flex; align-items: center; gap: 10px; } .rl-toolbar { display: flex; align-items: center; padding: 0 var(--space-4); min-height: 48px; gap: var(--space-2); flex-wrap: wrap; } .rl-tabs { display: flex; align-items: center; flex: 1; flex-wrap: wrap; } .rl-toolbar-right { display: flex; align-items: center; gap: var(--space-2); flex-shrink: 0; } .rl-list { display: flex; flex-direction: column; } .rl-row { display: flex; align-items: flex-start; gap: var(--space-4); padding: var(--space-4) var(--space-5); } .rl-row-body { flex: 1; min-width: 0; display: flex; flex-direction: column; gap: 4px; } .rl-row-title-line { display: flex; align-items: center; gap: var(--space-2); flex-wrap: wrap; } .rl-row-meta { display: flex; align-items: center; gap: 6px; flex-wrap: wrap; } .rl-row-author { display: inline-flex; align-items: center; gap: 4px; } .rl-empty { display: flex; flex-direction: column; align-items: center; justify-content: center; padding: var(--space-12) var(--space-6); text-align: center; gap: var(--space-3); } // ── Release detail page (.rd-*) ─────────────────────────────────────────────── .rd-layout { display: grid; grid-template-columns: 1fr 240px; gap: var(--space-4); align-items: start; @media (max-width: 768px) { grid-template-columns: 1fr; } } .rd-main { display: flex; flex-direction: column; gap: var(--space-3); min-width: 0; } .rd-title-row { display: flex; align-items: center; gap: var(--space-2); flex-wrap: wrap; margin-bottom: var(--space-3); } .rd-meta { display: flex; flex-wrap: wrap; gap: var(--space-4) var(--space-5); } .rd-meta-item { display: flex; flex-direction: column; gap: 2px; } .rd-meta-value { display: flex; align-items: center; gap: 5px; } .rd-stats { position: relative; display: flex; } .rd-stat { flex: 1; display: flex; flex-direction: column; align-items: center; justify-content: center; padding: var(--space-3); gap: 2px; } .rd-actions { position: relative; display: flex; align-items: center; gap: var(--space-2); padding: var(--space-2) var(--space-5) var(--space-3); flex-wrap: wrap; } .rd-section-header { display: flex; align-items: center; gap: var(--space-2); padding: var(--space-3) var(--space-4); } .rd-changelog-list { display: flex; flex-direction: column; } .rd-changelog-entry { display: flex; align-items: flex-start; gap: var(--space-3); padding: var(--space-3) var(--space-4); } .rd-changelog-body { flex: 1; min-width: 0; } .rd-changelog-meta { display: flex; align-items: center; gap: 6px; } .rd-changelog-breaking { display: flex; flex-wrap: wrap; gap: 4px; margin-top: var(--space-1); } .rd-semver-grid { display: grid; grid-template-columns: repeat(auto-fill, minmax(80px, 1fr)); gap: var(--space-2); padding: var(--space-4); } .rd-semver-cell { display: flex; flex-direction: column; align-items: center; gap: 3px; padding: var(--space-3) var(--space-2); } .rd-asset-row { display: flex; align-items: center; justify-content: space-between; gap: var(--space-3); padding: var(--space-3) var(--space-4); } .rd-asset-info { display: flex; align-items: center; gap: var(--space-3); min-width: 0; flex: 1; } .rd-asset-meta { display: flex; align-items: center; gap: 6px; flex-wrap: wrap; margin-top: 2px; } .rd-sidebar { display: flex; flex-direction: column; gap: var(--space-3); min-width: 0; } .rd-sidebar-body { padding: var(--space-3); display: flex; flex-direction: column; gap: var(--space-2); } .rd-sidebar-row { display: flex; align-items: flex-start; justify-content: space-between; gap: var(--space-2); } // ── Semantic Release Report panels (.sr-*) ──────────────────────────────────── .sr-lang-bar { display: flex; height: 8px; overflow: hidden; gap: 1px; } .sr-lang-legend { display: flex; flex-wrap: wrap; gap: 10px 18px; margin-top: 8px; } .sr-lang-item { display: flex; align-items: center; gap: 5px; } .sr-api-grid { display: grid; grid-template-columns: repeat(auto-fit, minmax(180px, 1fr)); gap: var(--space-3); margin-top: var(--space-2); } .sr-api-col-head { display: flex; align-items: center; gap: 6px; margin-bottom: var(--space-2); } .sr-api-entry { display: flex; align-items: center; gap: 5px; padding: 3px 0; } .sr-breaking-list { display: flex; flex-direction: column; gap: 6px; margin-top: var(--space-2); } .sr-breaking-entry { display: flex; align-items: center; gap: 8px; padding: 6px 10px; } .sr-hotspot-list { display: flex; flex-direction: column; gap: 5px; margin-top: var(--space-2); } .sr-hotspot-row { display: grid; grid-template-columns: 24px 130px 1fr 28px; align-items: center; gap: 8px; } .sr-refactor-list { display: flex; flex-direction: column; gap: 4px; margin-top: var(--space-2); } .sr-refactor-row { display: flex; align-items: center; gap: 8px; padding: 5px 8px; } .sr-authorship-bar { display: flex; height: 10px; overflow: hidden; margin-bottom: 8px; } .sr-authorship-legend { display: flex; justify-content: space-between; } .sr-sym-row { display: grid; grid-template-columns: 80px 1fr 30px; align-items: center; gap: 6px; margin-bottom: 5px; } // ── Release detail v2 (.rd2-*) ──────────────────────────────────────────────── .rd2-header { display: flex; align-items: flex-start; justify-content: space-between; gap: var(--space-4); padding: var(--space-4) var(--space-5); margin-bottom: var(--space-4); } .rd2-title-row { display: flex; align-items: center; gap: 10px; flex-wrap: wrap; margin-bottom: 6px; } .rd2-meta-row { display: flex; align-items: center; gap: 8px; flex-wrap: wrap; } .rd2-header-actions { display: flex; align-items: center; gap: 8px; flex-shrink: 0; } .rd2-glance { display: flex; gap: var(--space-5); align-items: stretch; padding: var(--space-4) var(--space-5); margin-bottom: var(--space-4); } .rd2-glance-hero { display: flex; align-items: center; gap: 0; flex-shrink: 0; } .rd2-hero-stat { display: flex; flex-direction: column; align-items: center; padding: 0 var(--space-4); } .rd2-glance-langs { flex: 1; min-width: 0; } .rd2-lang-bar-stacked { display: flex; height: 8px; overflow: hidden; margin-bottom: 10px; gap: 1px; } .rd2-lang-rows { display: flex; flex-direction: column; gap: 5px; } .rd2-lang-row { display: grid; grid-template-columns: 10px 88px 1fr 38px 54px 38px; align-items: center; gap: 8px; } .rd2-body { display: grid; grid-template-columns: 1fr 276px; gap: var(--space-4); align-items: start; @media (max-width: 900px) { grid-template-columns: 1fr; } } .rd2-main { display: flex; flex-direction: column; gap: var(--space-3); } .rd2-aside { display: flex; flex-direction: column; gap: var(--space-3); } .rd2-panel-head { display: flex; align-items: center; gap: 8px; padding: 10px 14px; } .rd2-api-summary { display: flex; gap: 6px; margin-left: auto; } .rd2-api-row { display: grid; grid-template-columns: 72px 1fr 70px; align-items: center; gap: 8px; padding: 4px 0; } .rd2-hotspot-row { display: grid; grid-template-columns: 10px 1fr 1fr 30px; align-items: center; gap: 8px; padding: 5px 0; } .rd2-struct-row { display: grid; grid-template-columns: 48px 1fr 80px 52px; align-items: center; gap: 8px; padding: 4px 0; } .rd2-changelog-pills { display: flex; gap: 5px; align-items: center; } .rd2-cl-entry { display: flex; gap: 10px; padding: 7px 0; } .rd2-cl-bump { flex-shrink: 0; width: 20px; height: 20px; border-radius: 50%; display: flex; align-items: center; justify-content: center; margin-top: 1px; } .rd2-cl-meta { display: flex; gap: 5px; align-items: center; margin-top: 2px; } .rd2-auth-detail { display: flex; flex-wrap: wrap; gap: 4px; margin-top: 6px; } .rd2-auth-bar { display: flex; height: 8px; overflow: hidden; margin-bottom: 10px; } .rd2-auth-legend { display: flex; flex-direction: column; gap: 6px; } .rd2-auth-item { display: flex; align-items: center; gap: 6px; } .rd2-auth-dot { width: 8px; height: 8px; border-radius: 50%; flex-shrink: 0; } .rd2-kv-list { display: flex; flex-direction: column; gap: 7px; } .rd2-kv { display: flex; align-items: center; justify-content: space-between; } .rd2-hash-row { display: flex; flex-direction: column; gap: 2px; } .rd2-sym-row { display: grid; grid-template-columns: 62px 1fr 36px; align-items: center; gap: 6px; margin-bottom: 5px; } .rd2-asset-row { display: flex; align-items: center; justify-content: space-between; padding: 8px 0; } // ── Tags page (.tag-*) ──────────────────────────────────────────────────────── .tag-page { display: flex; flex-direction: column; gap: var(--space-4); } .tag-header { padding-bottom: var(--space-2); } .tag-list { display: flex; flex-direction: column; } .tag-row { display: flex; align-items: center; gap: var(--space-3); padding: 10px 14px; } .rd2-asset-meta { display: flex; gap: 8px; margin-top: 2px; }