Files
WarpBox/static/css/upload.css
Daniel Legt c1489d1fbb feat(ui): add file-type icons and clamp window titles
Add a file-to-icon resolver for common MIME types/extensions so uploads
display appropriate Win98-style icons. Update upload and window CSS to
use image-based, pixelated icons, and prevent long window titles from
overflowing by adding a flex label with ellipsis handling.feat(ui): add file-type icons and clamp window titles

Add a file-to-icon resolver for common MIME types/extensions so uploads
display appropriate Win98-style icons. Update upload and window CSS to
use image-based, pixelated icons, and prevent long window titles from
overflowing by adding a flex label with ellipsis handling.
2026-04-27 18:37:05 +03:00

441 lines
7.9 KiB
CSS

.upload-window {
width: 520px;
height: 566px;
}
.upload-form {
display: flex;
flex: 1;
flex-direction: column;
min-height: 0;
}
.upload-panel {
display: flex;
flex: 1;
flex-direction: column;
min-height: 0;
margin: 0 8px 8px;
padding: 12px;
}
.upload-dropzone {
flex: 0 0 auto;
height: 88px;
box-sizing: border-box;
display: flex;
flex-direction: column;
align-items: center;
justify-content: center;
gap: 8px;
padding: 14px;
text-align: center;
background: #dfdfdf;
border: 1px dotted #000000;
}
.upload-dropzone.is-dragging {
background: #c7d8f2;
outline: 2px solid #000078;
outline-offset: -4px;
}
.upload-dropzone:focus-visible {
outline: 1px dotted #000000;
outline-offset: -5px;
}
.upload-icon {
width: 34px;
height: 30px;
position: relative;
box-sizing: border-box;
background: #ffffff;
border: 2px solid #000000;
box-shadow: inset -3px -3px 0 #dfdfdf;
}
.upload-icon::before {
content: "";
position: absolute;
right: -2px;
top: -2px;
width: 10px;
height: 10px;
box-sizing: border-box;
background: #dfdfdf;
border-left: 2px solid #000000;
border-bottom: 2px solid #000000;
}
.upload-primary {
font-size: 18px;
line-height: 18px;
font-weight: bold;
}
.upload-secondary {
font-size: 13px;
line-height: 15px;
}
.upload-input {
position: absolute;
width: 1px;
height: 1px;
overflow: hidden;
clip: rect(0, 0, 0, 0);
}
.upload-options {
flex: 0 0 auto;
display: grid;
grid-template-columns: 1fr 1fr;
gap: 6px 10px;
box-sizing: border-box;
margin: 10px 0 0;
padding: 8px 8px 10px;
background: #dfdfdf;
border-top: 1px solid #ffffff;
border-left: 1px solid #ffffff;
border-right: 1px solid #808080;
border-bottom: 1px solid #808080;
font-size: 12px;
line-height: 12px;
}
.upload-options legend {
padding: 0 4px;
font-weight: bold;
}
.upload-option-row {
grid-column: 1 / 3;
display: grid;
grid-template-columns: 76px minmax(0, 1fr);
align-items: center;
gap: 6px;
}
.upload-check-row {
display: flex;
align-items: center;
min-width: 0;
gap: 5px;
white-space: nowrap;
}
.upload-check-row input {
width: 13px;
height: 13px;
margin: 0;
}
.upload-select,
.upload-text-input {
width: 100%;
height: 22px;
box-sizing: border-box;
padding: 1px 4px;
color: #000000;
background: #ffffff;
border-top: 1px solid #808080;
border-left: 1px solid #808080;
border-right: 1px solid #ffffff;
border-bottom: 1px solid #ffffff;
font-family: inherit;
font-size: 12px;
line-height: 12px;
}
.upload-text-input {
min-width: 0;
}
.upload-text-input:disabled {
color: #808080;
background: #c0c0c0;
}
.upload-details {
flex: 0 0 auto;
display: flex;
align-items: center;
height: 28px;
margin-top: 12px;
padding: 0 8px;
box-sizing: border-box;
background: #ffffff;
border-top: 1px solid #808080;
border-left: 1px solid #808080;
border-right: 1px solid #dfdfdf;
border-bottom: 1px solid #dfdfdf;
font-size: 13px;
line-height: 13px;
}
.upload-detail-label {
flex: 0 0 auto;
margin-right: 6px;
font-weight: bold;
}
.upload-file-count {
margin-left: auto;
}
.upload-file-list {
flex: 1 1 auto;
min-height: 0;
margin-top: 8px;
overflow-y: auto;
border-top: 2px solid #808080;
border-left: 2px solid #808080;
border-right: 2px solid #ffffff;
border-bottom: 2px solid #ffffff;
}
.upload-result {
flex: 0 0 auto;
display: grid;
grid-template-columns: 72px minmax(0, 1fr) 72px;
align-items: center;
gap: 6px;
height: 36px;
box-sizing: border-box;
margin-top: 8px;
padding: 4px 6px;
background: #dfdfdf;
border-top: 1px solid #808080;
border-left: 1px solid #808080;
border-right: 1px solid #ffffff;
border-bottom: 1px solid #ffffff;
font-size: 12px;
line-height: 12px;
}
.upload-result.is-hidden {
visibility: hidden;
}
.upload-result-label {
font-weight: bold;
}
.upload-result-link {
min-width: 0;
overflow: hidden;
color: #000078;
text-overflow: ellipsis;
white-space: nowrap;
}
.upload-result-link.is-empty {
color: #555555;
pointer-events: none;
text-decoration: none;
}
.upload-share-button {
width: 72px;
height: 24px;
font-size: 12px;
line-height: 12px;
}
.upload-share-button:disabled {
color: #808080;
text-shadow: 1px 1px 0 #ffffff;
}
.upload-empty-state {
margin: 0;
padding: 9px 8px;
color: #555555;
font-size: 13px;
line-height: 13px;
}
.upload-file-row {
display: grid;
grid-template-columns: 22px minmax(0, 1fr) 82px;
grid-template-rows: 20px 8px;
align-items: center;
height: 36px;
box-sizing: border-box;
padding: 4px 8px;
border-bottom: 1px solid #dfdfdf;
font-size: 13px;
line-height: 13px;
}
.upload-file-row:nth-child(even) {
background: #f7f7f7;
}
.upload-file-row.is-uploading,
.upload-file-row.is-processing {
animation: upload-row-loading 900ms steps(2, end) infinite;
}
.upload-file-icon {
grid-row: 1 / 3;
width: 18px;
height: 18px;
object-fit: contain;
image-rendering: pixelated;
}
.upload-file-name,
.upload-file-size {
min-width: 0;
overflow: hidden;
text-overflow: ellipsis;
white-space: nowrap;
}
.upload-file-size {
text-align: right;
}
.upload-progress {
grid-column: 2 / 4;
grid-row: 2;
display: block;
height: 8px;
box-sizing: border-box;
overflow: hidden;
background: #ffffff;
border-top: 1px solid #808080;
border-left: 1px solid #808080;
border-right: 1px solid #dfdfdf;
border-bottom: 1px solid #dfdfdf;
}
.upload-progress-bar {
display: block;
width: 0%;
height: 100%;
background: #000078;
}
.upload-file-row.is-uploaded .upload-progress-bar {
background: #008000;
}
.upload-file-row.is-failed .upload-progress-bar {
width: 100%;
background: #800000;
}
@keyframes upload-row-loading {
0% {
background-color: #ffffff;
}
100% {
background-color: #e6e6e6;
}
}
.upload-actions {
display: flex;
justify-content: flex-end;
gap: 8px;
height: 40px;
box-sizing: border-box;
padding: 0 8px 8px;
}
.upload-overall {
display: grid;
grid-template-columns: minmax(0, 1fr) 42px;
align-items: center;
gap: 6px;
height: 28px;
box-sizing: border-box;
padding: 0 8px 8px;
font-size: 12px;
line-height: 12px;
}
.upload-overall-track {
height: 18px;
box-sizing: border-box;
overflow: hidden;
background: #ffffff;
border-top: 2px solid #808080;
border-left: 2px solid #808080;
border-right: 2px solid #ffffff;
border-bottom: 2px solid #ffffff;
}
.upload-overall-bar {
display: block;
width: 0%;
height: 100%;
background-color: #000078;
background-image: repeating-linear-gradient(
to right,
#000078 0,
#000078 10px,
#c0c0c0 10px,
#c0c0c0 12px
);
}
.upload-overall-percent {
min-width: 0;
text-align: right;
}
.upload-statusbar {
grid-template-columns: 1fr 96px;
}
@media (max-width: 600px) {
main {
display: block;
min-height: 100dvh;
}
.upload-window {
width: 100vw;
height: 100dvh;
border: 0;
box-shadow: none;
}
.upload-titlebar {
height: 24px;
margin: 0;
}
.upload-menu {
height: 26px;
}
.upload-panel {
margin: 0 6px 8px;
padding: 14px;
}
.upload-dropzone {
height: 96px;
min-height: 96px;
}
.upload-result {
grid-template-columns: 64px minmax(0, 1fr) 68px;
}
.upload-options {
grid-template-columns: 1fr;
}
.upload-option-row,
.upload-text-input {
grid-column: 1;
}
}