From 9a066c88ac21863d7c4d30e0f91e8651c2077aab Mon Sep 17 00:00:00 2001 From: poignatov Date: Thu, 5 Feb 2026 13:52:13 +0300 Subject: [PATCH] =?UTF-8?q?4.21.0:=20=D0=98=D1=81=D0=BF=D1=80=D0=B0=D0=B2?= =?UTF-8?q?=D0=BB=D0=B5=D0=BD=D0=B8=D0=B5=20=D0=BD=D0=B0=D0=B2=D0=B8=D0=B3?= =?UTF-8?q?=D0=B0=D1=86=D0=B8=D0=B8=20=D0=B8=20=D0=B8=D1=81=D1=82=D0=BE?= =?UTF-8?q?=D1=80=D0=B8=D0=B8?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit --- VERSION | 2 +- play-life-web/package.json | 2 +- play-life-web/src/App.jsx | 29 +++++++++++++++++-- play-life-web/src/components/AddWords.jsx | 2 +- play-life-web/src/components/BoardForm.jsx | 2 +- .../src/components/DictionaryList.jsx | 2 +- .../src/components/FullStatistics.jsx | 2 +- .../src/components/ProjectPriorityManager.jsx | 2 +- play-life-web/src/components/TaskDetail.jsx | 4 ++- play-life-web/src/components/TaskForm.jsx | 2 +- play-life-web/src/components/TaskList.jsx | 11 +++++-- play-life-web/src/components/TestWords.jsx | 2 +- .../src/components/WishlistDetail.jsx | 21 +++++++++++--- play-life-web/src/components/WishlistForm.jsx | 7 +---- play-life-web/src/components/WordList.jsx | 2 +- 15 files changed, 67 insertions(+), 25 deletions(-) diff --git a/VERSION b/VERSION index 3cb13fb..7c6be31 100644 --- a/VERSION +++ b/VERSION @@ -1 +1 @@ -4.20.7 +4.21.0 diff --git a/play-life-web/package.json b/play-life-web/package.json index 03f676b..2a7ad45 100644 --- a/play-life-web/package.json +++ b/play-life-web/package.json @@ -1,6 +1,6 @@ { "name": "play-life-web", - "version": "4.20.7", + "version": "4.21.0", "type": "module", "scripts": { "dev": "vite", diff --git a/play-life-web/src/App.jsx b/play-life-web/src/App.jsx index e148c57..84ea96c 100644 --- a/play-life-web/src/App.jsx +++ b/play-life-web/src/App.jsx @@ -750,8 +750,33 @@ function AppContent() { setTabParams(params) // Обновляем URL только для глубоких табов if (isNewTabDeep) { - // Сохраняем текущий таб как предыдущий при переходе на глубокий таб - updateUrl(tab, params, activeTab) + // Проверяем, была ли последняя запись в истории от модального окна + const currentState = window.history.state || {} + const isFromModal = currentState.modalOpen === true + const isNavigatingToForm = tab === 'task-form' || tab === 'wishlist-form' + + if (isFromModal && isNavigatingToForm) { + // Заменяем запись модального окна на запись формы редактирования + // Используем replaceState вместо pushState, сохраняя activeTab как previousTab + const url = new URL(window.location) + url.searchParams.set('tab', tab) + // Удаляем старые параметры + const keysToRemove = [] + url.searchParams.forEach((value, key) => { + if (key !== 'tab') keysToRemove.push(key) + }) + keysToRemove.forEach(key => url.searchParams.delete(key)) + // Добавляем новые параметры + Object.entries(params).forEach(([key, value]) => { + if (value !== undefined && value !== null) { + url.searchParams.set(key, typeof value === 'object' ? JSON.stringify(value) : value) + } + }) + window.history.replaceState({ tab, params, previousTab: activeTab }, '', url) + } else { + // Сохраняем текущий таб как предыдущий при переходе на глубокий таб + updateUrl(tab, params, activeTab) + } } else if (isNewTabMain && isCurrentTabDeep) { // При переходе с глубокого таба на основной - очищаем URL и сохраняем таб в state clearUrl(tab) diff --git a/play-life-web/src/components/AddWords.jsx b/play-life-web/src/components/AddWords.jsx index 19b9288..979ab8d 100644 --- a/play-life-web/src/components/AddWords.jsx +++ b/play-life-web/src/components/AddWords.jsx @@ -139,7 +139,7 @@ function AddWords({ onNavigate, dictionaryId, dictionaryName }) { } const handleClose = () => { - onNavigate?.('words', dictionaryId !== undefined && dictionaryId !== null ? { dictionaryId } : {}) + window.history.back() } // Show loading state while fetching dictionary name diff --git a/play-life-web/src/components/BoardForm.jsx b/play-life-web/src/components/BoardForm.jsx index 40927ee..7823648 100644 --- a/play-life-web/src/components/BoardForm.jsx +++ b/play-life-web/src/components/BoardForm.jsx @@ -156,7 +156,7 @@ function BoardForm({ boardId, onNavigate, onSaved }) { } const handleClose = () => { - onNavigate('wishlist') + window.history.back() } if (loadingBoard) { diff --git a/play-life-web/src/components/DictionaryList.jsx b/play-life-web/src/components/DictionaryList.jsx index 78a7337..74eecd8 100644 --- a/play-life-web/src/components/DictionaryList.jsx +++ b/play-life-web/src/components/DictionaryList.jsx @@ -94,7 +94,7 @@ function DictionaryList({ onNavigate, refreshTrigger = 0 }) { {/* Кнопка закрытия */}