diff --git a/internal/server/admin/static/index.html b/internal/server/admin/static/index.html index d22c40e..37a52b6 100644 --- a/internal/server/admin/static/index.html +++ b/internal/server/admin/static/index.html @@ -15,6 +15,7 @@ --accent: #3b82f6; --ok: #22c55e; --err: #ef4444; + --sidebar-w: 260px; } * { box-sizing: border-box; margin: 0; padding: 0; } body { @@ -24,40 +25,135 @@ min-height: 100vh; line-height: 1.5; } - .page { - max-width: 1000px; - margin: 0 auto; - padding: 2rem 1.5rem; + .app { + display: flex; + min-height: 100vh; } - header { - margin-bottom: 2rem; - padding-bottom: 1.5rem; + .sidebar { + width: var(--sidebar-w); + flex-shrink: 0; + background: var(--surface); + border-right: 1px solid var(--border); + display: flex; + flex-direction: column; + position: sticky; + top: 0; + height: 100vh; + overflow: hidden; + } + .sidebar-brand { + padding: 1.25rem 1rem 1rem; border-bottom: 1px solid var(--border); } - header h1 { font-size: 1.5rem; font-weight: 600; } - header p { color: var(--muted); margin-top: 0.25rem; font-size: 0.9rem; } - .grid { - display: grid; - gap: 1rem; - grid-template-columns: repeat(auto-fit, minmax(260px, 1fr)); + .sidebar-brand h1 { font-size: 1.1rem; font-weight: 600; } + .sidebar-brand p { color: var(--muted); font-size: 0.8rem; margin-top: 0.2rem; } + .sidebar-nav { + flex: 1; + overflow-y: auto; + padding: 0.5rem 0; } - .card { + .nav-section { margin-bottom: 0.25rem; } + .nav-section-header { + display: flex; + align-items: center; + gap: 0.5rem; + width: 100%; + padding: 0.55rem 1rem; + background: none; + border: none; + color: var(--text); + font-size: 0.875rem; + font-weight: 600; + cursor: pointer; + text-align: left; + } + .nav-section-header:hover { background: rgba(255,255,255,0.04); } + .nav-section-header.active { color: var(--accent); } + .nav-chevron { + width: 0.65rem; + height: 0.65rem; + border-right: 2px solid var(--muted); + border-bottom: 2px solid var(--muted); + transform: rotate(-45deg); + transition: transform 0.15s; + flex-shrink: 0; + margin-left: auto; + } + .nav-chevron.open { transform: rotate(45deg); margin-top: -0.2rem; } + .nav-children { + padding: 0.15rem 0 0.35rem; + } + .nav-item { + display: block; + width: 100%; + padding: 0.4rem 1rem 0.4rem 1.75rem; + background: none; + border: none; + color: var(--muted); + font-size: 0.82rem; + text-align: left; + cursor: pointer; + white-space: nowrap; + overflow: hidden; + text-overflow: ellipsis; + } + .nav-item:hover { color: var(--text); background: rgba(255,255,255,0.04); } + .nav-item.selected { + color: var(--text); + background: rgba(59, 130, 246, 0.15); + border-right: 2px solid var(--accent); + } + .nav-item.add { + color: var(--accent); + font-weight: 500; + } + .nav-item.add:hover { background: rgba(59, 130, 246, 0.1); } + .nav-empty { + padding: 0.25rem 1rem 0.25rem 1.75rem; + font-size: 0.78rem; + color: var(--muted); + font-style: italic; + } + .sidebar-footer { + padding: 1rem; + border-top: 1px solid var(--border); + } + .sidebar-footer label { font-size: 0.75rem; color: var(--muted); display: block; margin-bottom: 0.35rem; } + .sidebar-footer input { + width: 100%; + padding: 0.4rem 0.6rem; + background: var(--bg); + border: 1px solid var(--border); + border-radius: 6px; + color: var(--text); + font-size: 0.78rem; + } + .api-status { font-size: 0.75rem; margin-top: 0.35rem; } + .api-status.ok { color: var(--ok); } + .api-status.err { color: var(--err); } + + .main { + flex: 1; + min-width: 0; + padding: 2rem 2rem 3rem; + max-width: 900px; + } + .main-header { + margin-bottom: 1.5rem; + padding-bottom: 1rem; + border-bottom: 1px solid var(--border); + } + .main-header h2 { font-size: 1.35rem; font-weight: 600; } + .main-header p { color: var(--muted); margin-top: 0.25rem; font-size: 0.9rem; } + + .panel { background: var(--surface); border: 1px solid var(--border); border-radius: 10px; - padding: 1.25rem; - } - .card.wide { grid-column: 1 / -1; } - .card h2 { - font-size: 0.75rem; - text-transform: uppercase; - letter-spacing: 0.06em; - color: var(--muted); - margin-bottom: 0.75rem; + padding: 1.5rem; } .muted { color: var(--muted); font-size: 0.85rem; margin-top: 0.5rem; } button { - margin-top: 1rem; padding: 0.5rem 1rem; background: var(--accent); color: #fff; @@ -74,17 +170,16 @@ color: var(--accent); } button.secondary:hover { background: rgba(59, 130, 246, 0.12); filter: none; } - .btn-row { display: flex; flex-wrap: wrap; gap: 0.5rem; margin-top: 1rem; } + .btn-row { display: flex; flex-wrap: wrap; gap: 0.5rem; margin-top: 1.25rem; align-items: center; } button.danger { background: transparent; border: 1px solid var(--err); color: var(--err); - margin-top: 0; - padding: 0.35rem 0.65rem; - font-size: 0.8rem; + padding: 0.5rem 1rem; + font-size: 0.875rem; } button.danger:hover { background: rgba(239, 68, 68, 0.12); filter: none; } - input { + input, select { width: 100%; margin-top: 0.5rem; padding: 0.5rem 0.75rem; @@ -101,65 +196,28 @@ gap: 0.5rem 1rem; grid-template-columns: repeat(auto-fit, minmax(140px, 1fr)); } - table { - width: 100%; - border-collapse: collapse; - font-size: 0.85rem; - margin-top: 0.75rem; - } - th, td { - text-align: left; - padding: 0.5rem 0.25rem; - border-bottom: 1px solid var(--border); - vertical-align: middle; - } - th { color: var(--muted); font-weight: 500; font-size: 0.75rem; } - .empty { color: var(--muted); font-size: 0.85rem; margin-top: 0.5rem; } - .msg-err { color: var(--err); font-size: 0.85rem; margin-top: 0.5rem; } - .msg-ok { color: var(--ok); font-size: 0.85rem; margin-top: 0.5rem; } - .item-grid { - display: grid; - gap: 1rem; - grid-template-columns: repeat(auto-fill, minmax(220px, 1fr)); - margin-top: 1rem; - } - .item-card { + .msg-err { color: var(--err); font-size: 0.85rem; margin-top: 0.75rem; } + .msg-ok { color: var(--ok); font-size: 0.85rem; margin-top: 0.75rem; } + .item-preview-panel { + margin-bottom: 1.25rem; background: var(--bg); border: 1px solid var(--border); border-radius: 8px; - overflow: hidden; - display: flex; - flex-direction: column; - } - .item-preview { - background: #fff; - padding: 0.75rem; + padding: 1rem; display: flex; align-items: center; justify-content: center; - min-height: 160px; + min-height: 180px; } - .item-preview img { + .item-preview-panel img { max-width: 100%; - max-height: 140px; - width: auto; - height: auto; + max-height: 160px; + background: #fff; + padding: 0.5rem; + border-radius: 4px; } - .item-body { - padding: 0.75rem; - flex: 1; - display: flex; - flex-direction: column; - gap: 0.35rem; - } - .item-body strong { font-size: 0.9rem; } - .item-body span { font-size: 0.8rem; color: var(--muted); } - .item-actions { - padding: 0 0.75rem 0.75rem; - } - .row-actions { display: flex; gap: 0.5rem; justify-content: flex-end; } .layout-preview-wrap { - margin-top: 1rem; + margin-top: 1.25rem; background: var(--bg); border: 1px solid var(--border); border-radius: 8px; @@ -181,301 +239,285 @@ } .layout-stats strong { color: var(--text); } .layout-stats span { color: var(--muted); } - select { - width: 100%; - margin-top: 0.5rem; - padding: 0.5rem 0.75rem; - background: var(--bg); - border: 1px solid var(--border); - border-radius: 6px; - color: var(--text); - font-size: 0.875rem; - } - .config-list { - display: grid; - gap: 1rem; - margin-top: 1rem; - } - .config-entry { - background: var(--bg); - border: 1px solid var(--border); - border-radius: 8px; - padding: 1rem; - } - .config-entry header { - display: flex; - justify-content: space-between; - align-items: flex-start; - gap: 1rem; - margin-bottom: 0; - padding-bottom: 0.5rem; - border-bottom: none; - } - .config-entry header h3 { + .empty-state { + color: var(--muted); font-size: 0.95rem; - font-weight: 600; + padding: 2rem 0; + text-align: center; + } + @media (max-width: 720px) { + .app { flex-direction: column; } + .sidebar { + width: 100%; + height: auto; + position: relative; + max-height: 45vh; + } + .main { padding: 1.25rem; } }
-Platten und Items verwalten
-