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) {
- }
- variant="outline"
- color={config.settings.primaryColor || 'red'}
- onClick={onClick}
- >
+ } variant="outline" onClick={onClick}>
Download config
}
variant="outline"
- color={config.settings.primaryColor || 'red'}
onClick={() => {
axios
.delete(`/api/configs/${config.name}`)
@@ -101,13 +94,7 @@ export default function SaveConfigComponent(props: any) {
>
Delete config
- }
- variant="outline"
- color={config.settings.primaryColor || 'red'}
- onClick={() => setOpened(true)}
- >
+ } variant="outline" onClick={() => setOpened(true)}>
Save a copy
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;
+}