From 8ca0c4952ff1f66da9574b3dcb2691a252586878 Mon Sep 17 00:00:00 2001 From: William Oldham Date: Thu, 22 Feb 2024 17:54:41 +0000 Subject: [PATCH] Clean up preview code --- src/pages/Settings.tsx | 36 +++++++++++++------------- src/pages/parts/settings/ThemePart.tsx | 7 +++-- 2 files changed, 21 insertions(+), 22 deletions(-) diff --git a/src/pages/Settings.tsx b/src/pages/Settings.tsx index d4ee5292..cbac3bf6 100644 --- a/src/pages/Settings.tsx +++ b/src/pages/Settings.tsx @@ -1,5 +1,5 @@ import classNames from "classnames"; -import { useCallback, useEffect, useMemo, useRef } from "react"; +import { useCallback, useEffect, useMemo } from "react"; import { useTranslation } from "react-i18next"; import { useAsyncFn } from "react-use"; @@ -101,12 +101,10 @@ export function AccountSettings(props: { export function SettingsPage() { const { t } = useTranslation(); - const activeTheme = useThemeStore((s) => s.theme) ?? "default"; + const activeTheme = useThemeStore((s) => s.theme); const setTheme = useThemeStore((s) => s.setTheme); - const previewTheme = usePreviewThemeStore((s) => s.previewTheme) ?? "default"; + const previewTheme = usePreviewThemeStore((s) => s.previewTheme); const setPreviewTheme = usePreviewThemeStore((s) => s.setPreviewTheme); - const activeThemeRef = useRef(activeTheme); - activeThemeRef.current = activeTheme; const appLanguage = useLanguageStore((s) => s.language); const setAppLanguage = useLanguageStore((s) => s.setLanguage); @@ -147,19 +145,21 @@ export function SettingsPage() { enableThumbnails, ); - useEffect( - () => () => { - setPreviewTheme( - activeThemeRef.current === "default" ? null : activeThemeRef.current, - ); - }, - [setPreviewTheme], - ); + useEffect(() => { + setPreviewTheme(activeTheme ?? "default"); + }, [setPreviewTheme, activeTheme]); + + useEffect(() => { + // Clear preview theme on unmount + return () => { + setPreviewTheme(null); + }; + }, [setPreviewTheme]); const setThemeWithPreview = useCallback( - (v: string | null) => { - state.theme.set(v === "default" ? null : v); - setPreviewTheme(v); + (theme: string) => { + state.theme.set(theme === "default" ? null : theme); + setPreviewTheme(theme); }, [state.theme, setPreviewTheme], ); @@ -263,8 +263,8 @@ export function SettingsPage() {
diff --git a/src/pages/parts/settings/ThemePart.tsx b/src/pages/parts/settings/ThemePart.tsx index f4972eaf..f4f7c898 100644 --- a/src/pages/parts/settings/ThemePart.tsx +++ b/src/pages/parts/settings/ThemePart.tsx @@ -121,9 +121,9 @@ function ThemePreview(props: { } export function ThemePart(props: { - active: string | null; - inUse: string | null; - setTheme: (theme: string | null) => void; + active: string; + inUse: string; + setTheme: (theme: string) => void; }) { const { t } = useTranslation(); @@ -131,7 +131,6 @@ export function ThemePart(props: {
{t("settings.appearance.title")}
- {/* default theme */} {availableThemes.map((v) => (