feat(24-shipment-presets-ui): kolorowe przyciski presetów, popup tworzenia, autofill formularza

Phase 24 complete:
- SCSS moduł _shipment-presets.scss (przyciski, popup, color picker)
- Sekcja presetów nad formularzem przesyłki z przyciskiem "Dodaj"
- Popup tworzenia presetu z nazwą i wyborem koloru (8 opcji)
- JS autofill: carrier, usługa dostawy, wymiary, waga, label format
- Obsługa 3 paneli: Allegro searchable, InPost select, Apaczka select

Co-Authored-By: Claude Opus 4.6 (1M context) <noreply@anthropic.com>
This commit is contained in:
2026-03-22 23:42:56 +01:00
parent 03a237e7d2
commit e379557533
8 changed files with 740 additions and 2874 deletions

View File

@@ -0,0 +1,94 @@
.shipment-presets {
display: flex;
flex-wrap: wrap;
gap: 8px;
align-items: center;
margin-bottom: 16px;
}
.shipment-presets__btn {
display: inline-flex;
align-items: center;
gap: 4px;
padding: 6px 14px;
border: none;
border-radius: 6px;
background: var(--preset-color, #3b82f6);
color: #fff;
font-size: 13px;
font-weight: 500;
cursor: pointer;
transition: opacity 0.15s;
line-height: 1.4;
&:hover {
opacity: 0.85;
}
}
.shipment-presets__add {
display: inline-flex;
align-items: center;
gap: 4px;
padding: 6px 14px;
border: 1px dashed #ccc;
border-radius: 6px;
background: transparent;
color: #666;
font-size: 13px;
cursor: pointer;
transition: border-color 0.15s, color 0.15s;
line-height: 1.4;
&:hover {
border-color: #999;
color: #444;
}
}
.preset-modal {
position: fixed;
inset: 0;
background: rgba(0, 0, 0, 0.4);
z-index: 1000;
display: flex;
align-items: center;
justify-content: center;
}
.preset-modal__content {
background: #fff;
border-radius: 8px;
padding: 24px;
min-width: 360px;
max-width: 420px;
box-shadow: 0 8px 32px rgba(0, 0, 0, 0.2);
h3 {
margin: 0 0 4px;
font-size: 16px;
}
}
.preset-modal__colors {
display: flex;
gap: 8px;
flex-wrap: wrap;
}
.preset-modal__color-swatch {
width: 28px;
height: 28px;
border-radius: 50%;
cursor: pointer;
border: 2px solid transparent;
transition: border-color 0.15s;
&:hover {
border-color: #aaa;
}
&.is-selected {
border-color: #333;
}
}