2022-03-22 20:06:15 -07:00
|
|
|
import { useCallback, useEffect } from "react"
|
|
|
|
import useSharedState from "./use-shared-state"
|
|
|
|
|
|
|
|
const useTheme = () => {
|
2022-03-23 15:42:22 -07:00
|
|
|
const isClient = typeof window === "object"
|
|
|
|
const [themeType, setThemeType] = useSharedState<string>("theme", "light")
|
2022-03-22 20:06:15 -07:00
|
|
|
|
2022-03-23 15:42:22 -07:00
|
|
|
useEffect(() => {
|
|
|
|
if (!isClient) return
|
|
|
|
const storedTheme = localStorage.getItem("drift-theme")
|
|
|
|
if (storedTheme) {
|
|
|
|
setThemeType(storedTheme)
|
|
|
|
}
|
|
|
|
}, [isClient, setThemeType])
|
2022-03-22 20:06:15 -07:00
|
|
|
|
2022-03-23 15:42:22 -07:00
|
|
|
const changeTheme = useCallback(() => {
|
|
|
|
setThemeType((last) => {
|
|
|
|
const newTheme = last === "dark" ? "light" : "dark"
|
|
|
|
localStorage.setItem("drift-theme", newTheme)
|
|
|
|
return newTheme
|
|
|
|
})
|
|
|
|
}, [setThemeType])
|
2022-03-22 20:06:15 -07:00
|
|
|
|
2022-03-23 15:42:22 -07:00
|
|
|
return { theme: themeType, changeTheme }
|
2022-03-22 20:06:15 -07:00
|
|
|
}
|
|
|
|
|
2022-03-23 15:34:23 -07:00
|
|
|
export default useTheme
|