-
Notifications
You must be signed in to change notification settings - Fork 1
Expand file tree
/
Copy pathLocalStorage.tsx
More file actions
107 lines (87 loc) · 3.13 KB
/
LocalStorage.tsx
File metadata and controls
107 lines (87 loc) · 3.13 KB
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
/* * * * * * * * * * * * * * * * * * * * * * * * * * * * * * *
* Tune Player - A cute music player ❤ *
* Copyright © 2026 Moebytes <moebytes.com> *
* Licensed under CC BY-NC 4.0. See license.txt for details. *
* * * * * * * * * * * * * * * * * * * * * * * * * * * * * * */
import React, {useEffect} from "react"
import {useThemeSelector, useThemeActions} from "./store"
import {Themes, OS} from "./reducers/themeReducer"
const lightColorList = {
"--closeButton": "#ff497d",
"--minimizeButton": "#ff399c",
"--maximizeButton": "#ff2eb9",
"--background": "#ffffff",
"--navColor": "#ffd6e5",
"--iconColor": "#ff63a1",
"--textColor": "#000000",
"--barColor": "#ffffff"
}
const darkColorList = {
"--closeButton": "#ff497d",
"--minimizeButton": "#ff399c",
"--maximizeButton": "#ff2eb9",
"--background": "#000000",
"--navColor": "#29091e",
"--iconColor": "#ff4c94",
"--textColor": "#ffffff",
"--barColor": "#000000"
}
const LocalStorage: React.FunctionComponent = () => {
const {theme, os, transparent, pinned} = useThemeSelector()
const {setTheme, setOS, setTransparent, setPinned} = useThemeActions()
useEffect(() => {
if (typeof window === "undefined") return
const colorList = theme.includes("light") ? lightColorList : darkColorList
for (let i = 0; i < Object.keys(colorList).length; i++) {
const key = Object.keys(colorList)[i]
const color = Object.values(colorList)[i]
document.documentElement.style.setProperty(key, color)
}
if (transparent) {
document.documentElement.style.setProperty("--background", "transparent")
document.documentElement.style.setProperty("--navColor", "transparent")
}
}, [theme, transparent])
useEffect(() => {
const initTheme = async () => {
const savedTheme = await window.ipcRenderer.invoke("get-theme")
if (savedTheme) setTheme(savedTheme as Themes)
}
initTheme()
}, [])
useEffect(() => {
window.ipcRenderer.invoke("save-theme", theme)
}, [theme])
useEffect(() => {
const initOS = async () => {
const savedOS = await window.ipcRenderer.invoke("get-os")
if (savedOS) setOS(savedOS as OS)
}
initOS()
}, [])
useEffect(() => {
window.ipcRenderer.invoke("save-os", os)
}, [os])
useEffect(() => {
const initTransparent = async () => {
const savedTransparent = await window.ipcRenderer.invoke("get-transparent")
if (savedTransparent) setTransparent(savedTransparent)
}
initTransparent()
}, [])
useEffect(() => {
window.ipcRenderer.invoke("save-transparent", transparent)
}, [transparent])
useEffect(() => {
const initPinned = async () => {
const savedPinned = await window.ipcRenderer.invoke("get-pinned")
if (savedPinned) setPinned(savedPinned)
}
initPinned()
}, [])
useEffect(() => {
window.ipcRenderer.invoke("save-pinned", pinned)
}, [pinned])
return null
}
export default LocalStorage