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