v1 review pass: fixed some minor bugs
This commit is contained in:
217
src/App.css
217
src/App.css
@@ -89,7 +89,6 @@
|
||||
margin-left: auto;
|
||||
}
|
||||
|
||||
|
||||
/* Forms */
|
||||
.auth-form {
|
||||
display: flex;
|
||||
@@ -139,7 +138,11 @@
|
||||
.dump-form textarea:hover,
|
||||
.auth-form input:hover,
|
||||
.auth-form textarea:hover {
|
||||
border-color: color-mix(in srgb, var(--color-accent) 45%, var(--color-border) 55%);
|
||||
border-color: color-mix(
|
||||
in srgb,
|
||||
var(--color-accent) 45%,
|
||||
var(--color-border) 55%
|
||||
);
|
||||
}
|
||||
|
||||
.dump-form input:focus,
|
||||
@@ -147,8 +150,13 @@
|
||||
.auth-form input:focus,
|
||||
.auth-form textarea:focus {
|
||||
border-color: var(--color-accent);
|
||||
background-color: color-mix(in srgb, var(--color-accent) 4%, var(--color-bg) 96%);
|
||||
box-shadow: 0 0 0 3px color-mix(in srgb, var(--color-accent) 18%, transparent);
|
||||
background-color: color-mix(
|
||||
in srgb,
|
||||
var(--color-accent) 4%,
|
||||
var(--color-bg) 96%
|
||||
);
|
||||
box-shadow: 0 0 0 3px
|
||||
color-mix(in srgb, var(--color-accent) 18%, transparent);
|
||||
}
|
||||
|
||||
/* ── New dump form ── */
|
||||
@@ -212,7 +220,7 @@
|
||||
|
||||
.dump-mode-toggle button.active {
|
||||
background: var(--color-accent);
|
||||
color: #fff;
|
||||
color: var(--color-on-accent);
|
||||
}
|
||||
|
||||
.dump-mode-toggle button:not(.active):hover {
|
||||
@@ -309,7 +317,7 @@
|
||||
border-radius: 0;
|
||||
border: none;
|
||||
background: linear-gradient(transparent, rgba(0, 0, 0, 0.38));
|
||||
color: #fff;
|
||||
color: var(--color-on-accent);
|
||||
opacity: 0;
|
||||
pointer-events: none;
|
||||
transition: opacity 0.25s ease;
|
||||
@@ -320,14 +328,13 @@
|
||||
pointer-events: auto;
|
||||
}
|
||||
|
||||
|
||||
.video-player-controls .audio-player-time {
|
||||
color: #fff;
|
||||
color: var(--color-on-accent);
|
||||
opacity: 0.85;
|
||||
}
|
||||
|
||||
.video-player-controls .audio-player-vol-btn {
|
||||
color: #fff;
|
||||
color: var(--color-on-accent);
|
||||
}
|
||||
|
||||
.video-player-controls .audio-player-track {
|
||||
@@ -350,7 +357,11 @@
|
||||
flex-wrap: nowrap;
|
||||
gap: 0.6rem;
|
||||
padding: 0.75rem 1rem;
|
||||
background: color-mix(in srgb, var(--color-accent) 8%, var(--color-surface) 92%);
|
||||
background: color-mix(
|
||||
in srgb,
|
||||
var(--color-accent) 8%,
|
||||
var(--color-surface) 92%
|
||||
);
|
||||
border-radius: 0 0 12px 12px;
|
||||
border: 2px solid var(--color-border);
|
||||
width: 100%;
|
||||
@@ -366,7 +377,7 @@
|
||||
border-radius: 50%;
|
||||
border: none;
|
||||
background: var(--color-accent);
|
||||
color: #fff;
|
||||
color: var(--color-on-accent);
|
||||
cursor: pointer;
|
||||
display: grid;
|
||||
place-items: center;
|
||||
@@ -398,7 +409,11 @@
|
||||
min-width: 48px;
|
||||
height: 4px;
|
||||
border-radius: 2px;
|
||||
background: color-mix(in srgb, var(--color-accent) 20%, var(--color-border) 80%);
|
||||
background: color-mix(
|
||||
in srgb,
|
||||
var(--color-accent) 20%,
|
||||
var(--color-border) 80%
|
||||
);
|
||||
}
|
||||
|
||||
.audio-player-track--volume {
|
||||
@@ -480,7 +495,7 @@
|
||||
|
||||
.file-download-link:hover {
|
||||
background: var(--color-accent);
|
||||
color: #fff;
|
||||
color: var(--color-on-accent);
|
||||
}
|
||||
|
||||
.dump-file-notice {
|
||||
@@ -489,7 +504,6 @@
|
||||
opacity: 0.8;
|
||||
}
|
||||
|
||||
|
||||
.rich-content-card {
|
||||
display: flex;
|
||||
border: 2px solid var(--color-border);
|
||||
@@ -505,33 +519,33 @@
|
||||
}
|
||||
|
||||
.rich-content-card--youtube {
|
||||
border-color: #c00;
|
||||
border-color: var(--color-youtube);
|
||||
}
|
||||
.rich-content-card--youtube:hover {
|
||||
border-color: #f00;
|
||||
border-color: var(--color-youtube-hover);
|
||||
}
|
||||
.rich-content-card--youtube .rich-content-badge {
|
||||
background: #c00;
|
||||
background: var(--color-youtube);
|
||||
}
|
||||
|
||||
.rich-content-card--bandcamp {
|
||||
border-color: #1da0c3;
|
||||
border-color: var(--color-bandcamp);
|
||||
}
|
||||
.rich-content-card--bandcamp:hover {
|
||||
border-color: #25c8f0;
|
||||
border-color: var(--color-bandcamp-hover);
|
||||
}
|
||||
.rich-content-card--bandcamp .rich-content-badge {
|
||||
background: #1da0c3;
|
||||
background: var(--color-bandcamp);
|
||||
}
|
||||
|
||||
.rich-content-card--soundcloud {
|
||||
border-color: #f50;
|
||||
border-color: var(--color-soundcloud);
|
||||
}
|
||||
.rich-content-card--soundcloud:hover {
|
||||
border-color: #f73;
|
||||
border-color: var(--color-soundcloud-hover);
|
||||
}
|
||||
.rich-content-card--soundcloud .rich-content-badge {
|
||||
background: #f50;
|
||||
background: var(--color-soundcloud);
|
||||
}
|
||||
|
||||
.rich-content-thumbnail {
|
||||
@@ -552,8 +566,8 @@
|
||||
|
||||
.rich-content-badge {
|
||||
display: inline-block;
|
||||
background: #c00;
|
||||
color: #fff;
|
||||
background: var(--color-youtube);
|
||||
color: var(--color-on-accent);
|
||||
font-size: 0.7rem;
|
||||
font-weight: 700;
|
||||
letter-spacing: 0.04em;
|
||||
@@ -588,7 +602,6 @@
|
||||
display: block;
|
||||
}
|
||||
|
||||
|
||||
.dump-card--fading {
|
||||
opacity: 0.28;
|
||||
}
|
||||
@@ -648,7 +661,7 @@
|
||||
justify-content: center;
|
||||
border-radius: 50%;
|
||||
background: var(--color-accent);
|
||||
color: #fff;
|
||||
color: var(--color-on-accent);
|
||||
font-weight: 700;
|
||||
user-select: none;
|
||||
flex-shrink: 0;
|
||||
@@ -682,13 +695,13 @@
|
||||
.vote-btn--active {
|
||||
border-color: var(--color-accent);
|
||||
background: var(--color-accent);
|
||||
color: #fff;
|
||||
color: var(--color-on-accent);
|
||||
}
|
||||
|
||||
.vote-btn--active:hover:not(:disabled) {
|
||||
background: var(--color-accent-hover);
|
||||
border-color: var(--color-accent-hover);
|
||||
color: #fff;
|
||||
color: var(--color-on-accent);
|
||||
}
|
||||
|
||||
.vote-btn:focus {
|
||||
@@ -696,7 +709,8 @@
|
||||
}
|
||||
|
||||
.vote-btn:focus-visible {
|
||||
box-shadow: 0 0 0 3px color-mix(in srgb, var(--color-accent) 35%, transparent);
|
||||
box-shadow: 0 0 0 3px
|
||||
color-mix(in srgb, var(--color-accent) 35%, transparent);
|
||||
}
|
||||
|
||||
.vote-btn:disabled {
|
||||
@@ -704,7 +718,6 @@
|
||||
cursor: default;
|
||||
}
|
||||
|
||||
|
||||
/* Dump OP line */
|
||||
.dump-op {
|
||||
display: flex;
|
||||
@@ -734,8 +747,8 @@
|
||||
position: absolute;
|
||||
inset: 0;
|
||||
border-radius: 50%;
|
||||
background: rgba(0, 0, 0, 0.45);
|
||||
color: #fff;
|
||||
background: var(--color-overlay);
|
||||
color: var(--color-on-accent);
|
||||
font-size: 1.1rem;
|
||||
display: flex;
|
||||
align-items: center;
|
||||
@@ -813,6 +826,26 @@
|
||||
font-weight: 600;
|
||||
}
|
||||
|
||||
.profile-header .logout-btn {
|
||||
margin-top: 0.5rem;
|
||||
}
|
||||
|
||||
.logout-btn {
|
||||
padding: 0.3rem 0.9rem;
|
||||
border: 1.5px solid var(--color-border);
|
||||
border-radius: 6px;
|
||||
background: transparent;
|
||||
color: var(--color-text-muted);
|
||||
font-size: 0.85rem;
|
||||
cursor: pointer;
|
||||
transition: border-color 0.15s, color 0.15s;
|
||||
}
|
||||
|
||||
.logout-btn:hover {
|
||||
border-color: var(--color-danger);
|
||||
color: var(--color-danger);
|
||||
}
|
||||
|
||||
.avatar-upload-label {
|
||||
display: inline-block;
|
||||
padding: 0.4rem 1rem;
|
||||
@@ -827,16 +860,15 @@
|
||||
|
||||
.avatar-upload-label:hover {
|
||||
background: var(--color-accent);
|
||||
color: #fff;
|
||||
color: var(--color-on-accent);
|
||||
}
|
||||
|
||||
.form-error {
|
||||
color: #e55;
|
||||
color: var(--color-danger);
|
||||
margin: 0;
|
||||
font-size: 0.9rem;
|
||||
}
|
||||
|
||||
|
||||
/* ── Shared layout ── */
|
||||
.page-shell {
|
||||
min-height: 100vh;
|
||||
@@ -874,9 +906,15 @@
|
||||
padding: 2rem 0;
|
||||
}
|
||||
|
||||
.page-error-actions {
|
||||
display: flex;
|
||||
align-items: center;
|
||||
gap: 1rem;
|
||||
}
|
||||
|
||||
.error-banner {
|
||||
background: #a02b2b;
|
||||
color: #fff;
|
||||
background: var(--color-danger-bg);
|
||||
color: var(--color-on-accent);
|
||||
padding: 0.6rem 1rem;
|
||||
border-radius: 8px;
|
||||
font-size: 0.9rem;
|
||||
@@ -884,9 +922,6 @@
|
||||
|
||||
/* ── Shared header ── */
|
||||
.app-header {
|
||||
position: sticky;
|
||||
top: 0;
|
||||
z-index: 10;
|
||||
display: flex;
|
||||
align-items: center;
|
||||
gap: 1rem;
|
||||
@@ -896,6 +931,45 @@
|
||||
border-bottom: 2px solid var(--color-border);
|
||||
}
|
||||
|
||||
/* ── Floating "+ New" button ── */
|
||||
.fab-new {
|
||||
position: fixed;
|
||||
bottom: 2rem;
|
||||
right: max(1.5rem, calc((100vw - 860px) / 2 + 1.5rem));
|
||||
z-index: 20;
|
||||
background: var(--color-accent);
|
||||
color: var(--color-on-accent);
|
||||
border: none;
|
||||
border-radius: 999px;
|
||||
padding: 0.6rem 1.4rem;
|
||||
font-size: 0.95rem;
|
||||
font-weight: 700;
|
||||
cursor: pointer;
|
||||
box-shadow: 0 4px 20px
|
||||
color-mix(in srgb, var(--color-accent) 50%, transparent);
|
||||
opacity: 0;
|
||||
pointer-events: none;
|
||||
transform: translateY(10px) scale(0.94);
|
||||
transition:
|
||||
opacity 0.2s ease,
|
||||
transform 0.2s ease,
|
||||
background 0.15s,
|
||||
box-shadow 0.15s;
|
||||
}
|
||||
|
||||
.fab-new--visible {
|
||||
opacity: 1;
|
||||
pointer-events: auto;
|
||||
transform: none;
|
||||
}
|
||||
|
||||
.fab-new:hover {
|
||||
background: var(--color-accent-hover);
|
||||
box-shadow: 0 6px 24px
|
||||
color-mix(in srgb, var(--color-accent) 60%, transparent);
|
||||
transform: translateY(-1px);
|
||||
}
|
||||
|
||||
@media (min-width: 740px) {
|
||||
.app-header--has-center {
|
||||
display: grid;
|
||||
@@ -920,7 +994,9 @@
|
||||
}
|
||||
|
||||
@media (min-width: 740px) {
|
||||
.app-header-center { display: flex; }
|
||||
.app-header-center {
|
||||
display: flex;
|
||||
}
|
||||
}
|
||||
|
||||
.header-center-slot {
|
||||
@@ -951,12 +1027,12 @@
|
||||
font-size: 0.95rem;
|
||||
padding: 0.35rem 0.85rem;
|
||||
border-radius: 8px;
|
||||
background: rgba(0, 0, 0, 0.2);
|
||||
background: var(--color-header-user-bg);
|
||||
transition: background 0.15s;
|
||||
}
|
||||
|
||||
.app-header-user:hover {
|
||||
background: rgba(0, 0, 0, 0.32);
|
||||
background: var(--color-header-user-bg-hover);
|
||||
}
|
||||
|
||||
/* ── Auth card ── */
|
||||
@@ -988,8 +1064,14 @@
|
||||
|
||||
/* ── Form pages (DumpCreate / DumpEdit) ── */
|
||||
@keyframes page-enter {
|
||||
from { opacity: 0; transform: translateY(10px); }
|
||||
to { opacity: 1; transform: none; }
|
||||
from {
|
||||
opacity: 0;
|
||||
transform: translateY(10px);
|
||||
}
|
||||
to {
|
||||
opacity: 1;
|
||||
transform: none;
|
||||
}
|
||||
}
|
||||
|
||||
.form-page {
|
||||
@@ -1004,9 +1086,15 @@
|
||||
.form-page--two-col {
|
||||
grid-template-columns: 1fr 1fr;
|
||||
}
|
||||
.form-page--two-col .form-page-header { grid-column: 1 / -1; }
|
||||
.form-page--two-col .dump-edit-preview { border-radius: 0 0 0 12px; }
|
||||
.form-page--two-col .dump-form { border-radius: 0 0 12px 0; }
|
||||
.form-page--two-col .form-page-header {
|
||||
grid-column: 1 / -1;
|
||||
}
|
||||
.form-page--two-col .dump-edit-preview {
|
||||
border-radius: 0 0 0 12px;
|
||||
}
|
||||
.form-page--two-col .dump-form {
|
||||
border-radius: 0 0 12px 0;
|
||||
}
|
||||
}
|
||||
|
||||
.form-page-header {
|
||||
@@ -1055,7 +1143,7 @@
|
||||
align-items: center;
|
||||
justify-content: space-between;
|
||||
padding-top: 0.75rem;
|
||||
border-top: 1px solid rgba(128, 128, 128, 0.18);
|
||||
border-top: 1px solid var(--color-border-subtle);
|
||||
margin-top: 0.5rem;
|
||||
gap: 0.75rem;
|
||||
}
|
||||
@@ -1081,15 +1169,15 @@
|
||||
|
||||
/* ── Delete button ── */
|
||||
.btn-danger {
|
||||
background: #a02b2b;
|
||||
color: #fff;
|
||||
background: var(--color-danger-bg);
|
||||
color: var(--color-on-accent);
|
||||
border-color: transparent;
|
||||
font-size: 0.85rem;
|
||||
padding: 0.4em 0.9em;
|
||||
}
|
||||
|
||||
.btn-danger:hover {
|
||||
background: #c03030;
|
||||
background: var(--color-danger-hover);
|
||||
border-color: transparent;
|
||||
}
|
||||
|
||||
@@ -1115,20 +1203,22 @@
|
||||
|
||||
.btn-primary {
|
||||
background: var(--color-accent);
|
||||
color: #fff;
|
||||
color: var(--color-on-accent);
|
||||
font-weight: 700;
|
||||
font-size: 0.95rem;
|
||||
padding: 0.45rem 1.1rem;
|
||||
border: none;
|
||||
border-radius: 8px;
|
||||
cursor: pointer;
|
||||
box-shadow: 0 2px 8px color-mix(in srgb, var(--color-accent) 40%, transparent);
|
||||
box-shadow: 0 2px 8px
|
||||
color-mix(in srgb, var(--color-accent) 40%, transparent);
|
||||
transition: background 0.15s, box-shadow 0.15s, transform 0.1s;
|
||||
}
|
||||
|
||||
.btn-primary:hover {
|
||||
background: var(--color-accent-hover);
|
||||
box-shadow: 0 4px 14px color-mix(in srgb, var(--color-accent) 50%, transparent);
|
||||
box-shadow: 0 4px 14px
|
||||
color-mix(in srgb, var(--color-accent) 50%, transparent);
|
||||
transform: translateY(-1px);
|
||||
}
|
||||
|
||||
@@ -1162,7 +1252,6 @@
|
||||
z-index: 2;
|
||||
}
|
||||
|
||||
|
||||
.index-status {
|
||||
text-align: center;
|
||||
opacity: 0.6;
|
||||
@@ -1170,7 +1259,7 @@
|
||||
}
|
||||
|
||||
.index-status--error {
|
||||
color: #e55;
|
||||
color: var(--color-danger);
|
||||
opacity: 1;
|
||||
}
|
||||
|
||||
@@ -1185,7 +1274,9 @@
|
||||
}
|
||||
|
||||
@media (min-width: 740px) {
|
||||
.index-below-header { display: none; }
|
||||
.index-below-header {
|
||||
display: none;
|
||||
}
|
||||
}
|
||||
|
||||
/* ── Feed sort buttons (shared between header center and below-header) ── */
|
||||
@@ -1216,7 +1307,7 @@
|
||||
.feed-sort-btn.active {
|
||||
border-color: var(--color-accent);
|
||||
background: var(--color-accent);
|
||||
color: #fff;
|
||||
color: var(--color-on-accent);
|
||||
}
|
||||
|
||||
/* ── Dump feed ── */
|
||||
@@ -1239,7 +1330,10 @@
|
||||
border: 2px solid var(--color-border);
|
||||
border-radius: 10px;
|
||||
background: var(--color-surface);
|
||||
transition: border-color 0.15s, grid-template-rows 0.32s ease, opacity 0.25s ease;
|
||||
transition:
|
||||
border-color 0.15s,
|
||||
grid-template-rows 0.32s ease,
|
||||
opacity 0.25s ease;
|
||||
min-width: 0;
|
||||
}
|
||||
|
||||
@@ -1299,7 +1393,6 @@
|
||||
line-height: 1.35;
|
||||
}
|
||||
|
||||
|
||||
.dump-card-inner:hover .dump-card-title {
|
||||
color: var(--color-accent);
|
||||
}
|
||||
|
||||
Reference in New Issue
Block a user