mirror of
https://github.com/linsa-io/linsa.git
synced 2026-01-12 12:20:23 +01:00
chore(clerk): use theme from next theme insteadof manually detect it
This commit is contained in:
@@ -1,31 +1,22 @@
|
|||||||
"use client"
|
"use client"
|
||||||
|
|
||||||
import { ClerkProvider } from "@clerk/nextjs"
|
import { ClerkProvider } from "@clerk/nextjs"
|
||||||
import { dark } from "@clerk/themes"
|
import { dark } from "@clerk/themes"
|
||||||
import { useEffect, useState } from "react"
|
import { useTheme } from "next-themes"
|
||||||
|
|
||||||
export const ClerkProviderClient = ({ children }: { children: React.ReactNode }) => {
|
interface ClerkProviderClientProps {
|
||||||
const [darkMode, setDarkMode] = useState(false)
|
children: React.ReactNode
|
||||||
|
}
|
||||||
useEffect(() => {
|
|
||||||
const updateTheme = () => {
|
export const ClerkProviderClient: React.FC<ClerkProviderClientProps> = ({ children }) => {
|
||||||
setDarkMode(document.documentElement.classList.contains("dark"))
|
const { theme, systemTheme } = useTheme()
|
||||||
}
|
|
||||||
updateTheme()
|
const isDarkTheme = theme === "dark" || (theme === "system" && systemTheme === "dark")
|
||||||
|
|
||||||
const observer = new MutationObserver(updateTheme)
|
const appearance = {
|
||||||
observer.observe(document.documentElement, { attributes: true, attributeFilter: ["class"] })
|
baseTheme: isDarkTheme ? dark : undefined,
|
||||||
|
variables: { colorPrimary: isDarkTheme ? "#dddddd" : "#2e2e2e" }
|
||||||
return () => observer.disconnect()
|
}
|
||||||
}, [])
|
|
||||||
|
return <ClerkProvider appearance={appearance}>{children}</ClerkProvider>
|
||||||
return (
|
|
||||||
<ClerkProvider
|
|
||||||
appearance={{
|
|
||||||
baseTheme: darkMode ? dark : undefined,
|
|
||||||
variables: { colorPrimary: darkMode ? "#dddddd" : "#2e2e2e" }
|
|
||||||
}}
|
|
||||||
>
|
|
||||||
{children}
|
|
||||||
</ClerkProvider>
|
|
||||||
)
|
|
||||||
}
|
}
|
||||||
|
|||||||
Reference in New Issue
Block a user