mirror of
https://github.com/supabase/supabase.git
synced 2026-07-03 04:24:20 +08:00
27 lines
688 B
TypeScript
27 lines
688 B
TypeScript
import { useTheme } from './Providers'
|
|
import { IconSun, IconMoon } from '@supabase/ui'
|
|
|
|
function DarkModeToggle() {
|
|
const { isDarkMode, toggleTheme } = useTheme()
|
|
|
|
const toggleDarkMode = () => {
|
|
localStorage.setItem('supabaseDarkMode', (!isDarkMode).toString())
|
|
toggleTheme()
|
|
|
|
const key = localStorage.getItem('supabaseDarkMode')
|
|
document.documentElement.className = key === 'true' ? 'dark' : ''
|
|
}
|
|
|
|
return (
|
|
<button onClick={() => toggleDarkMode()}>
|
|
{isDarkMode ? (
|
|
<IconMoon className="text-scale-1100 stroke-2" />
|
|
) : (
|
|
<IconSun className="text-scale-1100 stroke-2" />
|
|
)}
|
|
</button>
|
|
)
|
|
}
|
|
|
|
export default DarkModeToggle
|