Theme Provider
First, you need to create a provider called providers.tsx
in your components folder.
Usage
Then you can wrap your app with the provider. For example if you are using Laravel with Inertia.js, you can put it inside your app.tsx
like so:
import React from 'react'
import ReactDOM from 'react-dom/client'
import App from './App.tsx'
import './index.css'
import { Providers } from './components/providers.tsx'
ReactDOM.createRoot(document.getElementById('root')!).render(
<React.StrictMode>
<Providers>
<App />
</Providers>
</React.StrictMode>,
)
Theme Switcher
Then for the switcher, you can use the useTheme
hook to get the current theme.
npm i hq-icons
Next create a component theme-switcher.tsx