4 changed files with 530 additions and 97 deletions
@ -0,0 +1,281 @@ |
|||||
|
/* Upload Summary Styles */ |
||||
|
.upload-summary { |
||||
|
margin: 1.5rem 0; |
||||
|
padding: 1.5rem; |
||||
|
border-radius: 6px; |
||||
|
background-color: var(--content-bg); |
||||
|
box-shadow: var(--dashboard-shadow); |
||||
|
color: var(--content-text); |
||||
|
} |
||||
|
|
||||
|
.upload-summary h3 { |
||||
|
margin-top: 0; |
||||
|
font-size: 1.25rem; |
||||
|
color: var(--dashboard-header-color); |
||||
|
margin-bottom: 1rem; |
||||
|
} |
||||
|
|
||||
|
.upload-stats { |
||||
|
display: flex; |
||||
|
gap: 1.5rem; |
||||
|
margin-bottom: 1rem; |
||||
|
} |
||||
|
|
||||
|
.stat-box { |
||||
|
flex: 1; |
||||
|
padding: 1rem; |
||||
|
border-radius: 4px; |
||||
|
background-color: var(--input-bg); |
||||
|
box-shadow: 0 1px 3px rgba(0, 0, 0, 0.1); |
||||
|
text-align: center; |
||||
|
} |
||||
|
|
||||
|
.stat-value { |
||||
|
font-size: 2rem; |
||||
|
font-weight: 600; |
||||
|
margin-bottom: 0.25rem; |
||||
|
color: var(--content-text); |
||||
|
} |
||||
|
|
||||
|
.stat-label { |
||||
|
font-size: 0.875rem; |
||||
|
color: var(--label-color); |
||||
|
} |
||||
|
|
||||
|
.success-stat .stat-value { |
||||
|
color: var(--btn-success-bg); |
||||
|
} |
||||
|
|
||||
|
.error-stat .stat-value { |
||||
|
color: var(--btn-warning-bg); |
||||
|
} |
||||
|
|
||||
|
/* Job Results Styles */ |
||||
|
.job-results { |
||||
|
margin-top: 1.5rem; |
||||
|
} |
||||
|
|
||||
|
.job-result { |
||||
|
padding: 1rem; |
||||
|
margin-bottom: 0.5rem; |
||||
|
border-radius: 4px; |
||||
|
border: var(--input-border); |
||||
|
border-left-width: 4px; |
||||
|
background-color: var(--content-bg); |
||||
|
box-shadow: var(--dashboard-shadow); |
||||
|
color: var(--content-text); |
||||
|
} |
||||
|
|
||||
|
.job-result.success { |
||||
|
border-left-color: var(--btn-success-bg); |
||||
|
} |
||||
|
|
||||
|
.job-result.error { |
||||
|
border-left-color: var(--btn-warning-bg); |
||||
|
} |
||||
|
|
||||
|
.job-id { |
||||
|
font-weight: 600; |
||||
|
display: block; |
||||
|
margin-bottom: 0.5rem; |
||||
|
color: var(--dashboard-header-color); |
||||
|
} |
||||
|
|
||||
|
.file-results { |
||||
|
margin-left: 1rem; |
||||
|
margin-top: 0.5rem; |
||||
|
} |
||||
|
|
||||
|
.file-result { |
||||
|
padding: 0.75rem; |
||||
|
margin-bottom: 0.5rem; |
||||
|
border-radius: 4px; |
||||
|
display: flex; |
||||
|
align-items: center; |
||||
|
background-color: var(--input-bg); |
||||
|
border: var(--input-border); |
||||
|
} |
||||
|
|
||||
|
.file-result.success { |
||||
|
background-color: rgba(var(--btn-success-rgb, 52, 211, 153), 0.1); |
||||
|
border-color: rgba(var(--btn-success-rgb, 52, 211, 153), 0.3); |
||||
|
} |
||||
|
|
||||
|
.file-result.error { |
||||
|
background-color: rgba(var(--btn-warning-rgb, 248, 113, 113), 0.1); |
||||
|
border-color: rgba(var(--btn-warning-rgb, 248, 113, 113), 0.3); |
||||
|
} |
||||
|
|
||||
|
.status-icon { |
||||
|
font-size: 1.25rem; |
||||
|
margin-right: 0.75rem; |
||||
|
} |
||||
|
|
||||
|
.success .status-icon { |
||||
|
color: var(--btn-success-bg); |
||||
|
} |
||||
|
|
||||
|
.error .status-icon { |
||||
|
color: var(--btn-warning-bg); |
||||
|
} |
||||
|
|
||||
|
.file-name { |
||||
|
font-weight: 500; |
||||
|
margin-right: 0.5rem; |
||||
|
color: var(--content-text); |
||||
|
} |
||||
|
|
||||
|
.file-message { |
||||
|
color: var(--label-color); |
||||
|
font-size: 0.875rem; |
||||
|
} |
||||
|
|
||||
|
/* Upload Progress Styles */ |
||||
|
.upload-progress { |
||||
|
background-color: var(--content-bg); |
||||
|
border-radius: 6px; |
||||
|
padding: 1.5rem; |
||||
|
margin: 1.5rem 0; |
||||
|
box-shadow: var(--dashboard-shadow); |
||||
|
} |
||||
|
|
||||
|
.progress-info { |
||||
|
display: flex; |
||||
|
align-items: center; |
||||
|
justify-content: space-between; |
||||
|
margin-bottom: 0.75rem; |
||||
|
} |
||||
|
|
||||
|
.progress-info span { |
||||
|
font-weight: 500; |
||||
|
color: var(--content-text); |
||||
|
} |
||||
|
|
||||
|
.spinner { |
||||
|
border: 3px solid rgba(0, 0, 0, 0.1); |
||||
|
border-radius: 50%; |
||||
|
border-top: 3px solid var(--btn-primary-bg); |
||||
|
width: 20px; |
||||
|
height: 20px; |
||||
|
animation: spin 1s linear infinite; |
||||
|
} |
||||
|
|
||||
|
@keyframes spin { |
||||
|
0% { |
||||
|
transform: rotate(0deg); |
||||
|
} |
||||
|
|
||||
|
100% { |
||||
|
transform: rotate(360deg); |
||||
|
} |
||||
|
} |
||||
|
|
||||
|
.progress { |
||||
|
height: 0.5rem; |
||||
|
background-color: var(--progress-bg, #e2e8f0); |
||||
|
border-radius: 999px; |
||||
|
overflow: hidden; |
||||
|
} |
||||
|
|
||||
|
.progress-bar { |
||||
|
height: 100%; |
||||
|
width: 100%; |
||||
|
background-color: var(--progress-fill, #4299e1); |
||||
|
background-image: linear-gradient(45deg, rgba(255, 255, 255, .15) 25%, transparent 25%, transparent 50%, rgba(255, 255, 255, .15) 50%, rgba(255, 255, 255, .15) 75%, transparent 75%, transparent); |
||||
|
background-size: 1rem 1rem; |
||||
|
border-radius: 999px; |
||||
|
animation: progress-animation 1s linear infinite; |
||||
|
} |
||||
|
|
||||
|
@keyframes progress-animation { |
||||
|
0% { |
||||
|
background-position: 1rem 0; |
||||
|
} |
||||
|
|
||||
|
100% { |
||||
|
background-position: 0 0; |
||||
|
} |
||||
|
} |
||||
|
|
||||
|
#upload-status { |
||||
|
margin-top: 0.75rem; |
||||
|
font-size: 0.875rem; |
||||
|
color: var(--label-color); |
||||
|
} |
||||
|
|
||||
|
.pulsing { |
||||
|
animation: pulse 2s infinite; |
||||
|
} |
||||
|
|
||||
|
@keyframes pulse { |
||||
|
0% { |
||||
|
opacity: 0.6; |
||||
|
} |
||||
|
|
||||
|
50% { |
||||
|
opacity: 1; |
||||
|
} |
||||
|
|
||||
|
100% { |
||||
|
opacity: 0.6; |
||||
|
} |
||||
|
} |
||||
|
|
||||
|
.advice { |
||||
|
font-weight: 500; |
||||
|
color: var(--btn-primary-bg); |
||||
|
} |
||||
|
|
||||
|
/* CSV Preview styles */ |
||||
|
#csv-preview { |
||||
|
margin-top: 1rem; |
||||
|
padding: 1rem; |
||||
|
background-color: var(--content-bg); |
||||
|
border-radius: 6px; |
||||
|
border-left: 4px solid var(--btn-primary-bg); |
||||
|
} |
||||
|
|
||||
|
.csv-sample { |
||||
|
margin-top: 0.5rem; |
||||
|
padding: 0.75rem; |
||||
|
background-color: var(--input-bg); |
||||
|
border-radius: 4px; |
||||
|
box-shadow: var(--dashboard-shadow); |
||||
|
} |
||||
|
|
||||
|
#csv-preview p { |
||||
|
margin: 0.5rem 0; |
||||
|
color: var(--content-text); |
||||
|
} |
||||
|
|
||||
|
/* HTMX indicator styles */ |
||||
|
.htmx-indicator { |
||||
|
opacity: 0; |
||||
|
transition: opacity 200ms ease-in; |
||||
|
} |
||||
|
|
||||
|
.htmx-request .htmx-indicator { |
||||
|
opacity: 1; |
||||
|
} |
||||
|
|
||||
|
.htmx-request.htmx-indicator { |
||||
|
opacity: 1; |
||||
|
} |
||||
|
|
||||
|
.loading-indicator { |
||||
|
display: inline-block; |
||||
|
width: 1rem; |
||||
|
height: 1rem; |
||||
|
border: 2px solid rgba(0, 0, 0, 0.1); |
||||
|
border-radius: 50%; |
||||
|
border-top-color: var(--btn-primary-bg); |
||||
|
animation: spin 1s linear infinite; |
||||
|
margin-left: 0.5rem; |
||||
|
vertical-align: middle; |
||||
|
} |
||||
|
|
||||
|
:root.dark-theme .spinner, |
||||
|
:root.dark-theme .loading-indicator { |
||||
|
border-color: rgba(255, 255, 255, 0.1); |
||||
|
border-top-color: var(--btn-primary-bg); |
||||
|
} |
||||
Loading…
Reference in new issue