feat: Реализована календарная лента из 9 дней для фильтрации заказов
Основные изменения: **Компонент date_range_filter.html:** - Заменены простые кнопки на горизонтальную ленту из 9 дней - Добавлены стрелки навигации влево/вправо - Скрытые поля дат для работы с django-filter **Стили date_filter.css:** - Дизайн календарной ленты с карточками дней - Выделение сегодняшнего дня синим цветом - Выделение выбранной даты зеленым цветом - Hover-эффекты и анимации - Адаптивность для мобильных устройств - Стили для стрелок навигации **Логика date_filter.js:** - Класс DateCarousel для управления лентой - Генерация 9 дней (±4 от центральной даты) - Определение "Вчера/Сегодня/Завтра" для центральных 3 кнопок - Отображение числа (01-31) и дня недели (ПН-ВС) - Навигация стрелками (сдвиг на 1 день) - Клик по дню устанавливает дату в оба поля фильтра - Визуальная индикация выбранной даты **Формат каждой кнопки:** ┌─────────┐ │ Сегодня │ ← Текст (если вчера/сегодня/завтра) │ 07 │ ← Число месяца │ ЧТ │ ← День недели └─────────┘ **Поведение:** - По умолчанию: сегодня в центре (5-я кнопка) - Сегодняшний день выделен синим - Клик по дню фильтрует заказы за эту конкретную дату - Стрелки сдвигают весь диапазон на 1 день вперед/назад 🤖 Generated with [Claude Code](https://claude.com/claude-code) Co-Authored-By: Claude <noreply@anthropic.com>
This commit is contained in:
@@ -1,5 +1,5 @@
|
||||
/**
|
||||
* Стили для календарного фильтра по датам
|
||||
* Стили для календарного фильтра с лентой из 9 дней
|
||||
* Используется в компоненте date_range_filter.html
|
||||
*/
|
||||
|
||||
@@ -23,78 +23,185 @@
|
||||
color: #0d6efd;
|
||||
}
|
||||
|
||||
.date-range-filter .date-input {
|
||||
cursor: pointer;
|
||||
transition: border-color 0.15s ease-in-out, box-shadow 0.15s ease-in-out;
|
||||
}
|
||||
|
||||
.date-range-filter .date-input:focus {
|
||||
border-color: #0d6efd;
|
||||
box-shadow: 0 0 0 0.2rem rgba(13, 110, 253, 0.15);
|
||||
}
|
||||
|
||||
.date-range-filter .text-muted.small {
|
||||
font-size: 0.75rem;
|
||||
margin-bottom: 0.25rem;
|
||||
}
|
||||
|
||||
/* Быстрые кнопки фильтров */
|
||||
.quick-filters {
|
||||
margin-top: 0.75rem;
|
||||
}
|
||||
|
||||
.quick-filters .btn-group {
|
||||
/* Календарная лента */
|
||||
.date-carousel {
|
||||
display: flex;
|
||||
gap: 0.25rem;
|
||||
align-items: center;
|
||||
gap: 0.5rem;
|
||||
}
|
||||
|
||||
.quick-date-btn {
|
||||
font-size: 0.75rem;
|
||||
padding: 0.375rem 0.5rem;
|
||||
border-radius: 4px !important;
|
||||
.carousel-nav-btn {
|
||||
background: #fff;
|
||||
border: 1px solid #dee2e6;
|
||||
border-radius: 50%;
|
||||
width: 36px;
|
||||
height: 36px;
|
||||
display: flex;
|
||||
align-items: center;
|
||||
justify-content: center;
|
||||
cursor: pointer;
|
||||
transition: all 0.2s ease;
|
||||
flex-shrink: 0;
|
||||
}
|
||||
|
||||
.carousel-nav-btn:hover {
|
||||
background: #0d6efd;
|
||||
border-color: #0d6efd;
|
||||
color: white;
|
||||
transform: scale(1.1);
|
||||
}
|
||||
|
||||
.carousel-nav-btn:active {
|
||||
transform: scale(0.95);
|
||||
}
|
||||
|
||||
.carousel-nav-btn i {
|
||||
font-size: 1.2rem;
|
||||
}
|
||||
|
||||
/* Контейнер с днями */
|
||||
.date-carousel-container {
|
||||
display: flex;
|
||||
gap: 0.5rem;
|
||||
overflow-x: auto;
|
||||
flex: 1;
|
||||
white-space: nowrap;
|
||||
padding: 0.25rem 0;
|
||||
scrollbar-width: none; /* Firefox */
|
||||
-ms-overflow-style: none; /* IE/Edge */
|
||||
}
|
||||
|
||||
.quick-date-btn:hover {
|
||||
background-color: #0d6efd;
|
||||
color: white;
|
||||
.date-carousel-container::-webkit-scrollbar {
|
||||
display: none; /* Chrome/Safari */
|
||||
}
|
||||
|
||||
/* Кнопка дня */
|
||||
.date-btn {
|
||||
background: #fff;
|
||||
border: 2px solid #dee2e6;
|
||||
border-radius: 8px;
|
||||
padding: 0.5rem;
|
||||
min-width: 70px;
|
||||
cursor: pointer;
|
||||
transition: all 0.2s ease;
|
||||
text-align: center;
|
||||
display: flex;
|
||||
flex-direction: column;
|
||||
gap: 0.25rem;
|
||||
flex-shrink: 0;
|
||||
}
|
||||
|
||||
.date-btn:hover {
|
||||
border-color: #0d6efd;
|
||||
transform: translateY(-1px);
|
||||
box-shadow: 0 2px 4px rgba(0, 0, 0, 0.1);
|
||||
background: #f0f7ff;
|
||||
transform: translateY(-2px);
|
||||
box-shadow: 0 4px 8px rgba(0, 0, 0, 0.1);
|
||||
}
|
||||
|
||||
.quick-date-btn:active {
|
||||
transform: translateY(0);
|
||||
box-shadow: none;
|
||||
.date-btn-label {
|
||||
font-size: 0.7rem;
|
||||
font-weight: 600;
|
||||
color: #6c757d;
|
||||
text-transform: uppercase;
|
||||
}
|
||||
|
||||
.quick-date-btn.active {
|
||||
background-color: #0d6efd;
|
||||
color: white;
|
||||
.date-btn-day {
|
||||
font-size: 1.5rem;
|
||||
font-weight: 700;
|
||||
color: #212529;
|
||||
line-height: 1;
|
||||
}
|
||||
|
||||
.date-btn-weekday {
|
||||
font-size: 0.75rem;
|
||||
font-weight: 500;
|
||||
color: #6c757d;
|
||||
text-transform: uppercase;
|
||||
}
|
||||
|
||||
/* Сегодняшний день (активный) */
|
||||
.date-btn.today {
|
||||
background: #0d6efd;
|
||||
border-color: #0d6efd;
|
||||
color: white;
|
||||
}
|
||||
|
||||
.date-btn.today .date-btn-label,
|
||||
.date-btn.today .date-btn-day,
|
||||
.date-btn.today .date-btn-weekday {
|
||||
color: white;
|
||||
}
|
||||
|
||||
.date-btn.today:hover {
|
||||
background: #0b5ed7;
|
||||
border-color: #0b5ed7;
|
||||
}
|
||||
|
||||
/* Выбранный день */
|
||||
.date-btn.selected {
|
||||
background: #198754;
|
||||
border-color: #198754;
|
||||
color: white;
|
||||
}
|
||||
|
||||
.date-btn.selected .date-btn-label,
|
||||
.date-btn.selected .date-btn-day,
|
||||
.date-btn.selected .date-btn-weekday {
|
||||
color: white;
|
||||
}
|
||||
|
||||
/* Адаптивность для мобильных устройств */
|
||||
@media (max-width: 576px) {
|
||||
@media (max-width: 768px) {
|
||||
.date-range-filter {
|
||||
padding: 0.75rem;
|
||||
}
|
||||
|
||||
.quick-filters .btn-group {
|
||||
flex-wrap: wrap;
|
||||
.date-carousel {
|
||||
gap: 0.25rem;
|
||||
}
|
||||
|
||||
.quick-date-btn {
|
||||
flex: 1 1 calc(33.333% - 0.25rem);
|
||||
min-width: 0;
|
||||
.carousel-nav-btn {
|
||||
width: 32px;
|
||||
height: 32px;
|
||||
}
|
||||
|
||||
.date-btn {
|
||||
min-width: 60px;
|
||||
padding: 0.4rem;
|
||||
}
|
||||
|
||||
.date-btn-label {
|
||||
font-size: 0.65rem;
|
||||
}
|
||||
|
||||
.date-btn-day {
|
||||
font-size: 1.3rem;
|
||||
}
|
||||
|
||||
.date-btn-weekday {
|
||||
font-size: 0.7rem;
|
||||
padding: 0.35rem 0.4rem;
|
||||
}
|
||||
}
|
||||
|
||||
/* Анимация для визуальной обратной связи */
|
||||
@media (max-width: 576px) {
|
||||
.date-btn {
|
||||
min-width: 50px;
|
||||
padding: 0.3rem;
|
||||
}
|
||||
|
||||
.date-btn-label {
|
||||
font-size: 0.6rem;
|
||||
}
|
||||
|
||||
.date-btn-day {
|
||||
font-size: 1.1rem;
|
||||
}
|
||||
|
||||
.date-btn-weekday {
|
||||
font-size: 0.65rem;
|
||||
}
|
||||
}
|
||||
|
||||
/* Анимация при клике */
|
||||
@keyframes pulse {
|
||||
0% {
|
||||
transform: scale(1);
|
||||
@@ -107,6 +214,6 @@
|
||||
}
|
||||
}
|
||||
|
||||
.quick-date-btn.clicked {
|
||||
.date-btn.clicked {
|
||||
animation: pulse 0.3s ease;
|
||||
}
|
||||
|
||||
Reference in New Issue
Block a user