aboutsummaryrefslogtreecommitdiffstats
path: root/packages/main/src/reactions/synchronizeNativeTheme.ts
diff options
context:
space:
mode:
Diffstat (limited to 'packages/main/src/reactions/synchronizeNativeTheme.ts')
-rw-r--r--packages/main/src/reactions/synchronizeNativeTheme.ts47
1 files changed, 47 insertions, 0 deletions
diff --git a/packages/main/src/reactions/synchronizeNativeTheme.ts b/packages/main/src/reactions/synchronizeNativeTheme.ts
new file mode 100644
index 0000000..8c4edb3
--- /dev/null
+++ b/packages/main/src/reactions/synchronizeNativeTheme.ts
@@ -0,0 +1,47 @@
1/*
2 * Copyright (C) 2021-2022 Kristóf Marussy <kristof@marussy.com>
3 *
4 * This file is part of Sophie.
5 *
6 * Sophie is free software: you can redistribute it and/or modify
7 * it under the terms of the GNU Affero General Public License as
8 * published by the Free Software Foundation, version 3.
9 *
10 * This program is distributed in the hope that it will be useful,
11 * but WITHOUT ANY WARRANTY; without even the implied warranty of
12 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
13 * GNU Affero General Public License for more details.
14 *
15 * You should have received a copy of the GNU Affero General Public License
16 * along with this program. If not, see <https://www.gnu.org/licenses/>.
17 *
18 * SPDX-License-Identifier: AGPL-3.0-only
19 */
20
21import { nativeTheme } from 'electron';
22import { autorun } from 'mobx';
23
24import type SharedStore from '../stores/SharedStore';
25import type Disposer from '../utils/Disposer';
26import { getLogger } from '../utils/log';
27
28const log = getLogger('synchronizeNativeTheme');
29
30export default function initNativeTheme(store: SharedStore): Disposer {
31 const disposeThemeSourceReaction = autorun(() => {
32 nativeTheme.themeSource = store.settings.themeSource;
33 log.debug('Set theme source:', store.settings.themeSource);
34 });
35
36 store.setShouldUseDarkColors(nativeTheme.shouldUseDarkColors);
37 const shouldUseDarkColorsListener = () => {
38 store.setShouldUseDarkColors(nativeTheme.shouldUseDarkColors);
39 log.debug('Set should use dark colors:', nativeTheme.shouldUseDarkColors);
40 };
41 nativeTheme.on('updated', shouldUseDarkColorsListener);
42
43 return () => {
44 nativeTheme.off('updated', shouldUseDarkColorsListener);
45 disposeThemeSourceReaction();
46 };
47}