🎨 Made color switcher change Mantine styles

Moved the color switcher's functions to a context provider and made Mantine's styles derived off of that context.
This commit is contained in:
Aimsucks
2022-06-08 14:58:32 +00:00
parent b26ab50c8d
commit 845d6a3d87
9 changed files with 75 additions and 53 deletions

View File

@@ -44,9 +44,7 @@ export default function TitleChanger() {
{...form.getInputProps('favicon')}
/>
<TextInput label="Background" placeholder="" {...form.getInputProps('background')} />
<Button type="submit" color={config.settings.primaryColor || 'red'}>
Save
</Button>
<Button type="submit">Save</Button>
</Group>
</form>
</Group>

View File

@@ -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) {
<ColorSwatch
component="button"
type="button"
color={theme.colors[configColor || 'red'][6]}
color={theme.colors[configColor][6]}
onClick={() => setOpened((o) => !o)}
size={22}
style={{ display: 'block', cursor: 'pointer' }}

View File

@@ -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,