From 14695a52ddb01874f86aff806cb6da818546877c Mon Sep 17 00:00:00 2001 From: Usman Baig Date: Thu, 26 Mar 2026 00:17:58 +0100 Subject: [PATCH] =?UTF-8?q?feat:=20dropdown-style=20animation=20on=20conte?= =?UTF-8?q?nt=20=E2=80=94=20glass=20stays=20during=20exit=20via=20onExitCo?= =?UTF-8?q?mplete?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit --- .../settings/unified/UnifiedSettingsModal.tsx | 24 +++++++++++++------ 1 file changed, 17 insertions(+), 7 deletions(-) diff --git a/components/settings/unified/UnifiedSettingsModal.tsx b/components/settings/unified/UnifiedSettingsModal.tsx index 6a865a0..baf9bea 100644 --- a/components/settings/unified/UnifiedSettingsModal.tsx +++ b/components/settings/unified/UnifiedSettingsModal.tsx @@ -240,6 +240,7 @@ export default function UnifiedSettingsModal() { const [hasPendingAction, setHasPendingAction] = useState(false) const saveHandlerRef = useRef<(() => Promise) | null>(null) const [saving, setSaving] = useState(false) + const [showGlass, setShowGlass] = useState(false) const handleDirtyChange = useCallback((dirty: boolean) => { isDirtyRef.current = dirty @@ -305,6 +306,7 @@ export default function UnifiedSettingsModal() { isDirtyRef.current = false pendingActionRef.current = null setHasPendingAction(false) + setShowGlass(true) } }, [isOpen]) @@ -382,19 +384,26 @@ export default function UnifiedSettingsModal() { onClick={handleBackdropClick} /> - {/* Glass panel — always mounted, instant show/hide, blur always composited */} + {/* Glass panel — always mounted, blur always composited */}
e.stopPropagation()} > - {/* Content fades in/out independently — glass stays solid */} - {isOpen && ( -
+ {/* Content animates in/out — glass panel stays visible during exit */} + setShowGlass(false)}> + {isOpen && ( + {/* Header */}
@@ -468,8 +477,9 @@ export default function UnifiedSettingsModal() { )} -
- )} + + )} +