fix: linux app theme (#4997)
This commit is contained in:
@@ -44,6 +44,7 @@
|
|||||||
- 修复 Windows 深色模式下首次启动客户端标题栏颜色异常
|
- 修复 Windows 深色模式下首次启动客户端标题栏颜色异常
|
||||||
- 修复静默启动不加载完整 WebView 的问题
|
- 修复静默启动不加载完整 WebView 的问题
|
||||||
- 修复 Linux WebKit 网络进程的崩溃
|
- 修复 Linux WebKit 网络进程的崩溃
|
||||||
|
- 修复 Linux GNOME/KDE 桌面下,应用主题颜色选择“系统”后,不随操作系统主题(Dark/Light)切换
|
||||||
|
|
||||||
## v2.4.2
|
## v2.4.2
|
||||||
|
|
||||||
|
|||||||
@@ -53,6 +53,13 @@ export const useCustomTheme = () => {
|
|||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
if (
|
||||||
|
typeof window !== "undefined" &&
|
||||||
|
typeof window.matchMedia === "function"
|
||||||
|
) {
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
let isMounted = true;
|
let isMounted = true;
|
||||||
|
|
||||||
const timerId = setTimeout(() => {
|
const timerId = setTimeout(() => {
|
||||||
@@ -90,6 +97,44 @@ export const useCustomTheme = () => {
|
|||||||
};
|
};
|
||||||
}, [theme_mode, appWindow, setMode]);
|
}, [theme_mode, appWindow, setMode]);
|
||||||
|
|
||||||
|
useEffect(() => {
|
||||||
|
if (theme_mode !== "system") {
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
|
if (
|
||||||
|
typeof window === "undefined" ||
|
||||||
|
typeof window.matchMedia !== "function"
|
||||||
|
) {
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
|
const mediaQuery = window.matchMedia("(prefers-color-scheme: dark)");
|
||||||
|
const syncMode = (isDark: boolean) => setMode(isDark ? "dark" : "light");
|
||||||
|
const handleChange = (event: MediaQueryListEvent) =>
|
||||||
|
syncMode(event.matches);
|
||||||
|
|
||||||
|
syncMode(mediaQuery.matches);
|
||||||
|
|
||||||
|
if (typeof mediaQuery.addEventListener === "function") {
|
||||||
|
mediaQuery.addEventListener("change", handleChange);
|
||||||
|
return () => mediaQuery.removeEventListener("change", handleChange);
|
||||||
|
}
|
||||||
|
|
||||||
|
type MediaQueryListLegacy = MediaQueryList & {
|
||||||
|
addListener?: (
|
||||||
|
listener: (this: MediaQueryList, event: MediaQueryListEvent) => void,
|
||||||
|
) => void;
|
||||||
|
removeListener?: (
|
||||||
|
listener: (this: MediaQueryList, event: MediaQueryListEvent) => void,
|
||||||
|
) => void;
|
||||||
|
};
|
||||||
|
|
||||||
|
const legacyQuery = mediaQuery as MediaQueryListLegacy;
|
||||||
|
legacyQuery.addListener?.(handleChange);
|
||||||
|
return () => legacyQuery.removeListener?.(handleChange);
|
||||||
|
}, [theme_mode, setMode]);
|
||||||
|
|
||||||
useEffect(() => {
|
useEffect(() => {
|
||||||
if (theme_mode === undefined) {
|
if (theme_mode === undefined) {
|
||||||
return;
|
return;
|
||||||
|
|||||||
Reference in New Issue
Block a user