From 372fc344932c5f64213dc7055b39b02bfbf34102 Mon Sep 17 00:00:00 2001 From: brusnitsyn Date: Mon, 22 Jun 2026 16:55:58 +0900 Subject: [PATCH] =?UTF-8?q?=D0=94=D0=BE=D0=B1=D0=B0=D0=B2=D0=B8=D0=BB=20?= =?UTF-8?q?=D0=BF=D0=BE=D0=B4=D0=B4=D0=B5=D1=80=D0=B6=D0=BA=D1=83=20=D0=BA?= =?UTF-8?q?=D0=BE=D0=BC=D0=BF=D0=BE=D0=BD=D0=B5=D0=BD=D1=82=D0=B0=20=D0=B4?= =?UTF-8?q?=D0=B0=D1=82=D1=8B=20=D0=B2=20=D0=BE=D1=82=D1=87=D0=B5=D1=82?= =?UTF-8?q?=D0=B0=D1=85?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit --- resources/js/Components/DatePickerQuery.vue | 11 ++++++++++- resources/js/Layouts/Components/AppUserButton.vue | 6 +++--- 2 files changed, 13 insertions(+), 4 deletions(-) diff --git a/resources/js/Components/DatePickerQuery.vue b/resources/js/Components/DatePickerQuery.vue index 3b68f4e..e7704f4 100644 --- a/resources/js/Components/DatePickerQuery.vue +++ b/resources/js/Components/DatePickerQuery.vue @@ -23,6 +23,12 @@ const props = defineProps({ hint: { type: Boolean, default: false + }, + // Локальный режим: не делать router.reload при смене даты — только обновлять модель + // (для конструктора отчётов, где период применяется по кнопке «Сформировать»). + local: { + type: Boolean, + default: false } }) @@ -174,7 +180,7 @@ const shortcuts = { const handleDateUpdate = (value) => { if (!value || !Array.isArray(value) || !value[0] || !value[1]) return - isLoading.value = true + if (!props.local) isLoading.value = true // Нормализуем в мс-таймстемпы: шорткаты/быстрый выбор отдают Date, календарь — число. // Иначе Date уходит в URL как ISO (...Z), а число остаётся числом → рассинхрон startAt/endAt. @@ -189,6 +195,9 @@ const handleDateUpdate = (value) => { modelValue.value = finalValue + // Локальный режим — без навигации, период применит кнопка «Сформировать отчёт» + if (props.local) return + // Дебаунс для предотвращения двойной отправки setTimeout(() => { if (JSON.stringify(modelValue.value) === JSON.stringify(finalValue)) { diff --git a/resources/js/Layouts/Components/AppUserButton.vue b/resources/js/Layouts/Components/AppUserButton.vue index 5f4eb25..0d0e0ae 100644 --- a/resources/js/Layouts/Components/AppUserButton.vue +++ b/resources/js/Layouts/Components/AppUserButton.vue @@ -76,6 +76,9 @@ const onSelectRole = (roleId) => { + + {{ authStore.user?.name }} + {{ initials }} - - {{ authStore.user?.name }} -