Files
ArchiveBox/archivebox/templates/static/admin.css
Claude 2e6dcb2b87 Improve admin snapshot list/grid views with better UX
- Add prominent view mode switcher with List/Grid toggle buttons
- Improve filter sidebar CSS with modern styling, rounded corners
- Add live progress bar for in-progress snapshots showing hooks status
- Show plugin icons only when output directory has content
- Display archive result output_size sum from new field
- Show hooks succeeded/total count in size column
- Add get_progress_stats() method to Snapshot model
- Add CSS for progress spinner and status badges
- Update grid view template with progress indicator for archiving cards
- Add tests for admin views, search, and progress stats
2025-12-31 11:28:03 +00:00

503 lines
10 KiB
CSS
Executable File

/* * {
-webkit-box-sizing: border-box;
-moz-box-sizing: border-box;
box-sizing: border-box;
} */
#logo {
height: 30px;
vertical-align: -6px;
padding-right: 5px;
}
#site-name:hover a {
opacity: 0.9;
}
#site-name .loader {
height: 25px;
width: 25px;
display: inline-block;
border-width: 3px;
vertical-align: -3px;
margin-right: 5px;
margin-top: 2px;
}
#branding h1, #branding h1 a:link, #branding h1 a:visited {
color: mintcream;
}
#header {
background: #aa1e55;
padding: 6px 14px;
}
#content {
padding: 8px 8px;
}
#user-tools {
font-size: 13px;
}
div.breadcrumbs {
background: #772948;
color: #f5dd5d;
padding: 6px 15px;
}
#toolbar #searchbar {
height: 25px;
}
/* View Mode Switcher - Prominent Toggle */
#snapshot-view-mode {
float: right;
margin-bottom: -40px;
display: inline-flex;
align-items: center;
margin-top: 3px;
margin-right: 10px;
font-size: 13px;
background: #f1f5f9;
border: 1px solid #e2e8f0;
border-radius: 8px;
padding: 2px;
gap: 2px;
}
#snapshot-view-mode a {
display: inline-flex;
align-items: center;
justify-content: center;
gap: 4px;
padding: 6px 12px;
color: #64748b;
text-decoration: none;
border-radius: 6px;
font-weight: 500;
transition: all 0.15s ease;
white-space: nowrap;
}
#snapshot-view-mode a:hover {
color: #334155;
background: #e2e8f0;
}
#snapshot-view-mode a.active {
background: #fff;
color: #1e293b;
box-shadow: 0 1px 3px rgba(0,0,0,0.1);
}
#snapshot-view-mode .view-icon {
font-size: 14px;
line-height: 1;
}
body.model-snapshot.change-list div.breadcrumbs,
body.model-snapshot.change-list #content .object-tools {
display: none;
}
.module h2, .module caption, .inline-group h2 {
background: #772948;
}
#content .adv-data textarea {
width: 82vw;
max-width: 100%;
min-height: 100px;
height: auto;
background-color: #145454;
color: #f1f1fd;
font-size: 12px;
font-family: monospace;
border-radius: 8px;
line-height: 1.2;
padding: 6px 9px;
}
#content .object-tools {
margin-top: -35px;
margin-right: -10px;
float: right;
}
#content .object-tools a:link, #content .object-tools a:visited {
border-radius: 0px;
background-color: #f5dd5d;
color: #333;
font-size: 12px;
font-weight: 800;
}
#content .object-tools a.addlink {
background-blend-mode: difference;
}
#content #changelist #toolbar {
padding: 0px;
background: none;
margin-bottom: 10px;
border-top: 0px;
border-bottom: 0px;
}
#content #changelist #toolbar form input[type="submit"] {
border-color: #aa1e55;
}
#content #changelist-filter li.selected a {
color: #aa1e55;
}
/*#content #changelist .actions {
position: fixed;
bottom: 0px;
z-index: 800;
}*/
#content #changelist .actions {
float: right;
margin-top: -34px;
padding: 0px;
background: none;
margin-right: 0px;
width: auto;
max-height: 40px;
display: block;
}
@media (max-width: 1000px) {
#content #changelist .actions {
max-height: 200px;
}
}
#content #changelist .actions .button {
border-radius: 2px;
background-color: #f5dd5d;
color: #333;
font-size: 12px;
font-weight: 800;
margin-right: 4px;
box-shadow: 4px 4px 4px rgba(0,0,0,0.02);
border: 1px solid rgba(0,0,0,0.08);
}
#content #changelist .actions .button:hover {
border: 1px solid rgba(0,0,0,0.2);
opacity: 0.9;
}
#content #changelist .actions .button[name=verify_snapshots], #content #changelist .actions .button[name=update_titles] {
background-color: #dedede;
color: #333;
}
#content #changelist .actions .button[name=update_snapshots] {
background-color: #9ee54b;
color: #333;
}
#content #changelist .actions .button[name=resnapshot_snapshot] {
background-color:lightseagreen;
color: #333;
}
#content #changelist .actions .button[name=overwrite_snapshots] {
background-color: #ffaa31;
color: #333;
margin-left: 10px;
}
#content #changelist .actions .button[name=delete_snapshots] {
background-color: #f91f74;
color: rgb(255 248 252 / 64%);
}
#content #changelist .actions .button[name=add_tags] {
}
#content #changelist .actions .button[name=remove_tags] {
margin-right: 25px;
}
#content #changelist .actions > label {
max-height: 25px;
}
#content #changelist .actions > label {
width: auto !important;
min-width: 90px;
}
#content #changelist .actions > label > select {
margin-top: 3px;
}
/* Filter Sidebar - Improved Layout */
#content #changelist-filter {
background: #fff;
border: 1px solid #e2e8f0;
border-radius: 10px;
box-shadow: 0 1px 3px rgba(0,0,0,0.05);
overflow: hidden;
}
#content #changelist-filter h2 {
border-radius: 0;
background: #f8fafc;
color: #475569;
font-size: 11px;
font-weight: 600;
text-transform: uppercase;
letter-spacing: 0.05em;
padding: 10px 12px;
margin: 0;
border-bottom: 1px solid #e2e8f0;
}
#content #changelist-filter h3 {
font-size: 11px;
font-weight: 600;
color: #64748b;
text-transform: uppercase;
letter-spacing: 0.03em;
padding: 10px 12px 4px;
margin: 0;
background: transparent;
}
#content #changelist-filter ul {
padding: 0 6px 8px;
margin: 0;
list-style: none;
}
#content #changelist-filter li {
margin: 0;
}
#content #changelist-filter li a {
display: block;
padding: 6px 10px;
color: #475569;
text-decoration: none;
font-size: 12px;
border-radius: 5px;
transition: background 0.15s ease, color 0.15s ease;
white-space: nowrap;
overflow: hidden;
text-overflow: ellipsis;
}
#content #changelist-filter li a:hover {
background: #f1f5f9;
color: #1e293b;
}
#content #changelist-filter li.selected a {
background: #eff6ff;
color: #2563eb;
font-weight: 500;
}
#content #changelist-filter-clear {
padding: 8px 12px;
margin: 0;
border-bottom: 1px solid #e2e8f0;
background: #fef2f2;
}
#content #changelist-filter-clear a {
color: #dc2626;
font-size: 12px;
font-weight: 500;
text-decoration: none;
}
#content #changelist-filter-clear a:hover {
text-decoration: underline;
}
#changelist .paginator {
border-top: 0px;
border-bottom: 0px;
}
@media (min-width: 767px) {
#content #changelist-filter {
top: 35px;
width: 160px;
margin-bottom: 35px;
}
.change-list .filtered .results,
.change-list .filtered .paginator,
.filtered #toolbar,
.filtered div.xfull {
margin-right: 168px;
}
}
@media (max-width: 1127px) {
#content #changelist .actions {
position: fixed;
bottom: 6px;
left: 10px;
float: left;
z-index: 1000;
}
}
#content a img.favicon {
height: 20px;
max-width: 28px;
vertical-align: -5px;
padding-right: 6px;
}
#content td, #content th {
vertical-align: middle;
padding: 4px;
}
#content #changelist table input {
vertical-align: -2px;
}
#content thead th .text a {
padding: 8px 4px;
}
#content th.field-added, #content td.field-updated {
word-break: break-word;
min-width: 135px;
white-space: normal;
}
#content th.field-title_str {
min-width: 300px;
}
#content td.field-files {
white-space: nowrap;
}
#content td.field-files .exists-True {
opacity: 1;
}
#content td.field-files .exists-False {
opacity: 0.1;
filter: grayscale(100%);
}
#content td.field-size {
white-space: nowrap;
}
#content td.field-url_str {
word-break: break-all;
min-width: 200px;
}
#content tr b.status-pending {
font-weight: 200;
opacity: 0.6;
}
.loader {
border: 16px solid #f3f3f3; /* Light grey */
border-top: 16px solid #3498db; /* Blue */
border-radius: 50%;
width: 30px;
height: 30px;
box-sizing: border-box;
animation: spin 2s linear infinite;
}
@keyframes spin {
0% { transform: rotate(0deg); }
100% { transform: rotate(360deg); }
}
.tag {
float: right;
border-radius: 5px;
background-color: #bfdfff;
padding: 2px 5px;
margin-left: 4px;
margin-top: 1px;
}
.exists-False {
opacity: 0.1;
filter: grayscale(100%);
}
#result_list tbody td.field-cmd_str pre,
#result_list tbody td.field-output_str pre {
max-width: 22vw;
word-wrap: anywhere;
white-space: break-spaces;
max-height: 40px;
overflow: hidden;
margin: 2px;
background-color: rgba(0,0,0,0.05);
padding: 1px 4px 16px 8px;
border-radius: 4px;
}
#result_list tbody td.field-extractor {
font-weight: 800;
font-variant: small-caps;
}
#result_list tbody td.field-status {
font-variant: small-caps;
}
.inline-group .tabular td.original p {
margin-top: -28px;
}
tbody .output-link {
float: right;
margin-bottom: -25px;
margin-right: -3px;
margin-top: -4px;
opacity: 0.4;
box-shadow: 4px 4px 4px rgba(0,0,0,0.1);
}
tbody .output-link:hover {opacity: 1;}
@keyframes fadeIn {
0% { opacity: 0; }
30% { opacity: 0.1;}
100% { opacity: 1; }
}
.fade-in-progress-url {
animation: fadeIn 14s;
}
/* Snapshot Progress Spinner */
.snapshot-progress-spinner {
display: inline-block;
width: 12px;
height: 12px;
border: 2px solid #e2e8f0;
border-top-color: #3b82f6;
border-radius: 50%;
animation: snapshot-spin 0.8s linear infinite;
}
@keyframes snapshot-spin {
to { transform: rotate(360deg); }
}
/* Status Badges */
.status-badge {
display: inline-block;
padding: 2px 8px;
border-radius: 12px;
font-size: 11px;
font-weight: 500;
}
.status-badge.queued { background: #fef3c7; color: #f59e0b; }
.status-badge.started { background: #dbeafe; color: #3b82f6; }
.status-badge.sealed { background: #d1fae5; color: #10b981; }
.status-badge.succeeded { background: #d1fae5; color: #10b981; }
.status-badge.failed { background: #fee2e2; color: #ef4444; }
.status-badge.backoff { background: #fef3c7; color: #f59e0b; }
.status-badge.skipped { background: #f3f4f6; color: #6b7280; }
/* Progress Bar */
.snapshot-progress-bar {
background: #e2e8f0;
border-radius: 4px;
height: 6px;
overflow: hidden;
}
.snapshot-progress-bar-fill {
height: 100%;
transition: width 0.3s ease;
border-radius: 4px;
}