mango-ui-v2/components/ThemeSwitch.jsx

38 lines
1022 B
JavaScript

import { useEffect, useState } from 'react'
import { useTheme } from 'next-themes'
import { MoonIcon, SunIcon } from '@heroicons/react/outline'
import DropMenu from './DropMenu'
import MangoIcon from './MangoIcon'
const THEMES = [
{ name: 'Light', icon: <SunIcon /> },
{ name: 'Dark', icon: <MoonIcon /> },
{ name: 'Mango', icon: <MangoIcon className="stroke-current" /> },
]
const ThemeSwitch = () => {
const [mounted, setMounted] = useState(false)
const { theme, setTheme } = useTheme()
// When mounted on client, now we can show the UI
useEffect(() => setMounted(true), [])
if (!mounted) return null
return (
<DropMenu
button={
<div className="w-5 h-5">
{THEMES.find((t) => t.name === theme).icon}
</div>
}
buttonClassName="w-10 h-10 flex items-center justify-center hover:text-th-primary rounded-md focus:outline-none"
value={theme}
onChange={(theme) => setTheme(theme)}
options={THEMES}
/>
)
}
export default ThemeSwitch