aboutsummaryrefslogtreecommitdiffstats
path: root/packages/main/src/controllers/nativeTheme.ts
diff options
context:
space:
mode:
Diffstat (limited to 'packages/main/src/controllers/nativeTheme.ts')
-rw-r--r--packages/main/src/controllers/nativeTheme.ts8
1 files changed, 8 insertions, 0 deletions
diff --git a/packages/main/src/controllers/nativeTheme.ts b/packages/main/src/controllers/nativeTheme.ts
index e4390a8..6548771 100644
--- a/packages/main/src/controllers/nativeTheme.ts
+++ b/packages/main/src/controllers/nativeTheme.ts
@@ -18,24 +18,32 @@
18 * SPDX-License-Identifier: AGPL-3.0-only 18 * SPDX-License-Identifier: AGPL-3.0-only
19 */ 19 */
20 20
21import consola from 'consola';
21import { nativeTheme } from 'electron'; 22import { nativeTheme } from 'electron';
22import { autorun } from 'mobx'; 23import { autorun } from 'mobx';
23 24
24import type { MainStore } from '../stores/MainStore'; 25import type { MainStore } from '../stores/MainStore';
25import { Disposer } from '../utils'; 26import { Disposer } from '../utils';
26 27
28const logger = consola.withTag('sophie:controller:nativeTheme');
29
27export function initNativeTheme(store: MainStore): Disposer { 30export function initNativeTheme(store: MainStore): Disposer {
31 logger.debug('Initializing controller');
32
28 const disposeThemeSourceReaction = autorun(() => { 33 const disposeThemeSourceReaction = autorun(() => {
29 nativeTheme.themeSource = store.config.themeSource; 34 nativeTheme.themeSource = store.config.themeSource;
35 logger.debug('Set theme source:', store.config.themeSource);
30 }); 36 });
31 37
32 store.setShouldUseDarkColors(nativeTheme.shouldUseDarkColors); 38 store.setShouldUseDarkColors(nativeTheme.shouldUseDarkColors);
33 const shouldUseDarkColorsListener = () => { 39 const shouldUseDarkColorsListener = () => {
34 store.setShouldUseDarkColors(nativeTheme.shouldUseDarkColors); 40 store.setShouldUseDarkColors(nativeTheme.shouldUseDarkColors);
41 logger.debug('Set should use dark colors:', nativeTheme.shouldUseDarkColors);
35 }; 42 };
36 nativeTheme.on('updated', shouldUseDarkColorsListener); 43 nativeTheme.on('updated', shouldUseDarkColorsListener);
37 44
38 return () => { 45 return () => {
46 logger.debug('Disposing controller');
39 nativeTheme.off('updated', shouldUseDarkColorsListener); 47 nativeTheme.off('updated', shouldUseDarkColorsListener);
40 disposeThemeSourceReaction(); 48 disposeThemeSourceReaction();
41 }; 49 };