Files
NotionNext/themes/NEXT/components/DarkModeButton.js
2022-03-03 15:08:19 +08:00

20 lines
713 B
JavaScript

import { useGlobal } from '@/lib/global'
import { loadDarkModeFromCookies, saveDarkModeToCookies } from '@/lib/theme'
const DarkModeButton = () => {
const { updateDarkMode } = useGlobal()
const isDarkMode = loadDarkModeFromCookies()
// 用户手动设置主题
const handleChangeDarkMode = () => {
const newTheme = (isDarkMode ? 'dark' : 'light')
saveDarkModeToCookies(newTheme)
updateDarkMode(newTheme)
}
return <div className='z-10 duration-200 text-xs cursor-pointer py-1.5 px-1'>
<i id='darkModeButton' className={`hover:scale-125 transform duration-200 fas ${isDarkMode ? 'fa-sun' : 'fa-moon'}`}
onClick={handleChangeDarkMode} />
</div>
}
export default DarkModeButton