mirror of
https://github.com/kremalicious/umami.git
synced 2024-12-24 18:26:20 +01:00
22 lines
612 B
JavaScript
22 lines
612 B
JavaScript
|
import { useDispatch, useSelector } from 'react-redux';
|
||
|
import { setTheme } from 'redux/actions/app';
|
||
|
import { getItem, setItem } from 'lib/web';
|
||
|
import { THEME_CONFIG } from 'lib/constants';
|
||
|
import { useEffect } from 'react';
|
||
|
|
||
|
export default function useLocale() {
|
||
|
const theme = useSelector(state => state.app.theme || getItem(THEME_CONFIG) || 'light');
|
||
|
const dispatch = useDispatch();
|
||
|
|
||
|
function saveTheme(value) {
|
||
|
setItem(THEME_CONFIG, value);
|
||
|
dispatch(setTheme(value));
|
||
|
}
|
||
|
|
||
|
useEffect(() => {
|
||
|
document.body.setAttribute('data-theme', theme);
|
||
|
}, [theme]);
|
||
|
|
||
|
return [theme, saveTheme];
|
||
|
}
|