mango-ui-v3/components/ThemeSwitch.tsx

40 lines
1.2 KiB
TypeScript
Raw Normal View History

import { useEffect, useState } from 'react'
import { useTheme } from 'next-themes'
import { MoonIcon, SunIcon } from '@heroicons/react/outline'
import DropMenu from './DropMenu'
2021-04-15 06:22:39 -07:00
import { MangoIcon } from './icons'
import { useTranslation } from 'next-i18next'
const THEMES = [
{ name: 'Light', icon: <SunIcon className="h-4 w-4" /> },
{ name: 'Dark', icon: <MoonIcon className="h-4 w-4" /> },
{ name: 'Mango', icon: <MangoIcon className="stroke-current h-4 w-4" /> },
]
const ThemeSwitch = () => {
const { t } = useTranslation('common')
const [mounted, setMounted] = useState(false)
const { theme, setTheme } = useTheme()
// When mounted on client, now we can show the UI
useEffect(() => setMounted(true), [])
return mounted ? (
<DropMenu
button={
2021-07-30 03:30:58 -07:00
<div className="bg-th-bkg-4 flex items-center justify-center rounded-full w-8 h-8 text-th-fgd-1 focus:outline-none hover:text-th-primary">
{THEMES.find((t) => t.name === theme).icon}
</div>
}
value={theme}
onChange={(theme) => setTheme(theme)}
options={THEMES}
toolTipContent={t('change-theme')}
/>
) : (
<div className="bg-th-bkg-3 rounded-full w-8 h-8" />
)
}
export default ThemeSwitch