Feat(Theme): Support dark mode

This commit is contained in:
2024-10-23 10:17:45 +08:00
parent b7c3fb8524
commit dbce6b9cf2
180 changed files with 3478 additions and 3199 deletions

View File

@@ -1,27 +1,65 @@
import { theme } from 'antd'
import zh_CN from 'antd/locale/zh_CN'
import BaseStyles from '@/assets/css/base.style'
import CommonStyles from '@/assets/css/common.style'
import { COLOR_PRODUCTION } from '@/constants/common.constants'
import { getRouter } from '@/router'
import FullscreenLoadingMask from '@/components/common/FullscreenLoadingMask'
export const AppContext = createContext<{ refreshRouter: () => void }>({
refreshRouter: () => undefined
export const AppContext = createContext({
refreshRouter: () => {},
isDarkMode: false
})
const App = () => {
const [routerState, setRouterState] = useState(getRouter)
const [isDarkMode, setIsDarkMode] = useState(false)
useEffect(() => {
const darkThemeMq = window.matchMedia('(prefers-color-scheme: dark)')
setIsDarkMode(darkThemeMq.matches)
const listener = (ev: MediaQueryListEvent) => {
setIsDarkMode(ev.matches)
}
darkThemeMq.addEventListener('change', listener)
return () => {
darkThemeMq.removeEventListener('change', listener)
}
}, [])
return (
<>
<AntdConfigProvider
theme={{
cssVar: true,
algorithm: isDarkMode ? theme.darkAlgorithm : undefined,
token: {
colorPrimary: COLOR_PRODUCTION,
colorLinkHover: COLOR_PRODUCTION
},
components: {
Tree: {
colorBgContainer: 'transparent'
}
}
}}
locale={zh_CN}
>
<BaseStyles />
<CommonStyles />
<AppContext.Provider
value={{
refreshRouter: () => {
setRouterState(getRouter())
}
},
isDarkMode
}}
>
<Suspense fallback={<FullscreenLoadingMask />}>
<RouterProvider router={routerState} />
</Suspense>
</AppContext.Provider>
</>
</AntdConfigProvider>
)
}