diff --git a/src/components/ColorSchemeToggle/ColorSchemeSwitch.tsx b/src/components/ColorSchemeToggle/ColorSchemeSwitch.tsx index d9c2cd035..410dcbaf2 100644 --- a/src/components/ColorSchemeToggle/ColorSchemeSwitch.tsx +++ b/src/components/ColorSchemeToggle/ColorSchemeSwitch.tsx @@ -39,12 +39,7 @@ export function ColorSchemeSwitch() {
- toggleColorScheme()} - size="md" - /> + toggleColorScheme()} size="md" />
Switch to {colorScheme === 'dark' ? 'light' : 'dark'} mode diff --git a/src/components/Config/SaveConfig.tsx b/src/components/Config/SaveConfig.tsx index 882f43299..d18b38ae2 100644 --- a/src/components/Config/SaveConfig.tsx +++ b/src/components/Config/SaveConfig.tsx @@ -59,20 +59,13 @@ export default function SaveConfigComponent(props: any) { - - diff --git a/src/components/Settings/AdvancedSettings.tsx b/src/components/Settings/AdvancedSettings.tsx index 45d57bb87..f3daa9786 100644 --- a/src/components/Settings/AdvancedSettings.tsx +++ b/src/components/Settings/AdvancedSettings.tsx @@ -44,9 +44,7 @@ export default function TitleChanger() { {...form.getInputProps('favicon')} /> - + diff --git a/src/components/Settings/ColorSelector.tsx b/src/components/Settings/ColorSelector.tsx index d70ab1d59..e7f175b3d 100644 --- a/src/components/Settings/ColorSelector.tsx +++ b/src/components/Settings/ColorSelector.tsx @@ -1,6 +1,7 @@ import React, { useState } from 'react'; import { ColorSwatch, Group, Popover, Text, useMantineTheme } from '@mantine/core'; import { useConfig } from '../../tools/state'; +import { useColorTheme } from '../../tools/color'; interface ColorControlProps { type: string; @@ -9,19 +10,20 @@ interface ColorControlProps { export function ColorSelector({ type }: ColorControlProps) { const { config, setConfig } = useConfig(); const [opened, setOpened] = useState(false); + + const { primaryColor, secondaryColor, setPrimaryColor, setSecondaryColor } = useColorTheme(); + const theme = useMantineTheme(); const colors = Object.keys(theme.colors).map((color) => ({ swatch: theme.colors[color][6], color, })); - const configColor = - type === 'primary' - ? config.settings.primaryColor || 'red' - : config.settings.secondaryColor || 'orange'; + const configColor = type === 'primary' ? primaryColor : secondaryColor; const setConfigColor = (color: string) => { if (type === 'primary') { + setPrimaryColor(color); setConfig({ ...config, settings: { @@ -30,6 +32,7 @@ export function ColorSelector({ type }: ColorControlProps) { }, }); } else { + setSecondaryColor(color); setConfig({ ...config, settings: { @@ -62,7 +65,7 @@ export function ColorSelector({ type }: ColorControlProps) { setOpened((o) => !o)} size={22} style={{ display: 'block', cursor: 'pointer' }} diff --git a/src/components/Settings/ModuleEnabler.tsx b/src/components/Settings/ModuleEnabler.tsx index f2061540a..14d8a2f08 100644 --- a/src/components/Settings/ModuleEnabler.tsx +++ b/src/components/Settings/ModuleEnabler.tsx @@ -13,7 +13,6 @@ export default function ModuleEnabler(props: any) { size="md" checked={config.modules?.[module.title]?.enabled ?? false} label={`Enable ${module.title}`} - color={config.settings.primaryColor || 'red'} onChange={(e) => { setConfig({ ...config, diff --git a/src/components/layout/Logo.tsx b/src/components/layout/Logo.tsx index 9ebd74395..5e1476e7e 100644 --- a/src/components/layout/Logo.tsx +++ b/src/components/layout/Logo.tsx @@ -1,10 +1,12 @@ import { Group, Image, Text } from '@mantine/core'; import { NextLink } from '@mantine/next'; import * as React from 'react'; +import { useColorTheme } from '../../tools/color'; import { useConfig } from '../../tools/state'; export function Logo({ style }: any) { const { config } = useConfig(); + const { primaryColor, secondaryColor } = useColorTheme(); return ( @@ -27,8 +29,8 @@ export function Logo({ style }: any) { weight="bold" variant="gradient" gradient={{ - from: config.settings.primaryColor || 'red', - to: config.settings.secondaryColor || 'orange', + from: primaryColor, + to: secondaryColor, deg: 145, }} > diff --git a/src/pages/_app.tsx b/src/pages/_app.tsx index f923e310b..ecdbadd00 100644 --- a/src/pages/_app.tsx +++ b/src/pages/_app.tsx @@ -6,15 +6,24 @@ import Head from 'next/head'; import { MantineProvider, ColorScheme, ColorSchemeProvider } from '@mantine/core'; import { NotificationsProvider } from '@mantine/notifications'; import { useHotkeys } from '@mantine/hooks'; -import { ConfigProvider, useConfig } from '../tools/state'; +import { ConfigProvider } from '../tools/state'; import { theme } from '../tools/theme'; import { styles } from '../tools/styles'; +import { ColorTheme } from '../tools/color'; -export default function App(props: AppProps & { colorScheme: ColorScheme }) { +export default function App(this: any, props: AppProps & { colorScheme: ColorScheme }) { const { Component, pageProps } = props; - const { config } = useConfig(); const [colorScheme, setColorScheme] = useState(props.colorScheme); + const [primaryColor, setPrimaryColor] = useState('red'); + const [secondaryColor, setSecondaryColor] = useState('orange'); + const colorTheme = { + primaryColor, + secondaryColor, + setPrimaryColor, + setSecondaryColor, + }; + const toggleColorScheme = (value?: ColorScheme) => { const nextColorScheme = value || (colorScheme === 'dark' ? 'light' : 'dark'); setColorScheme(nextColorScheme); @@ -31,24 +40,26 @@ export default function App(props: AppProps & { colorScheme: ColorScheme }) { - - - - - - - + + + + + + + + + ); diff --git a/src/pages/index.tsx b/src/pages/index.tsx index c982f3940..10d347f74 100644 --- a/src/pages/index.tsx +++ b/src/pages/index.tsx @@ -7,6 +7,7 @@ import { Config } from '../tools/types'; import { useConfig } from '../tools/state'; import { migrateToIdConfig } from '../tools/migrate'; import { getConfig } from '../tools/getConfig'; +import { useColorTheme } from '../tools/color'; import Layout from '../components/layout/Layout'; export async function getServerSideProps({ @@ -29,8 +30,11 @@ export async function getServerSideProps({ export default function HomePage(props: any) { const { config: initialConfig }: { config: Config } = props; const { setConfig } = useConfig(); + const { setPrimaryColor, setSecondaryColor } = useColorTheme(); useEffect(() => { const migratedConfig = migrateToIdConfig(initialConfig); + setPrimaryColor(migratedConfig.settings.primaryColor || 'red'); + setSecondaryColor(migratedConfig.settings.secondaryColor || 'orange'); setConfig(migratedConfig); }, [initialConfig]); return ( diff --git a/src/tools/color.ts b/src/tools/color.ts new file mode 100644 index 000000000..793b11155 --- /dev/null +++ b/src/tools/color.ts @@ -0,0 +1,23 @@ +import { createContext, useContext } from 'react'; + +type colorThemeContextType = { + primaryColor: string; + secondaryColor: string; + setPrimaryColor: (color: string) => void; + setSecondaryColor: (color: string) => void; +}; + +export const ColorTheme = createContext({ + primaryColor: 'red', + secondaryColor: 'orange', + setPrimaryColor: () => {}, + setSecondaryColor: () => {}, +}); + +export function useColorTheme() { + const context = useContext(ColorTheme); + if (context === undefined) { + throw new Error('useColorTheme must be used within a ColorTheme.Provider'); + } + return context; +}