feat(web): adapt to horizontal config structure

This commit is contained in:
Ali BARIN
2024-09-20 10:44:34 +00:00
parent 8a17c5eaab
commit 89b1cb9353
3 changed files with 47 additions and 30 deletions

View File

@@ -2,7 +2,6 @@ import PropTypes from 'prop-types';
import CssBaseline from '@mui/material/CssBaseline'; import CssBaseline from '@mui/material/CssBaseline';
import { ThemeProvider as BaseThemeProvider } from '@mui/material/styles'; import { ThemeProvider as BaseThemeProvider } from '@mui/material/styles';
import clone from 'lodash/clone'; import clone from 'lodash/clone';
import get from 'lodash/get';
import set from 'lodash/set'; import set from 'lodash/set';
import * as React from 'react'; import * as React from 'react';
@@ -10,18 +9,33 @@ import useAutomatischInfo from 'hooks/useAutomatischInfo';
import useAutomatischConfig from 'hooks/useAutomatischConfig'; import useAutomatischConfig from 'hooks/useAutomatischConfig';
import { defaultTheme, mationTheme } from 'styles/theme'; import { defaultTheme, mationTheme } from 'styles/theme';
const overrideIfGiven = (theme, key, value) => {
if (value) {
set(theme, key, value);
}
};
const customizeTheme = (theme, config) => { const customizeTheme = (theme, config) => {
// `clone` is needed so that the new theme reference triggers re-render // `clone` is needed so that the new theme reference triggers re-render
const shallowDefaultTheme = clone(theme); const shallowDefaultTheme = clone(theme);
for (const key in config) { overrideIfGiven(
const value = config[key]; shallowDefaultTheme,
const exists = get(theme, key); 'palette.primary.main',
config.palettePrimaryMain,
);
if (exists) { overrideIfGiven(
set(shallowDefaultTheme, key, value); shallowDefaultTheme,
} 'palette.primary.light',
} config.palettePrimaryLight,
);
overrideIfGiven(
shallowDefaultTheme,
'palette.primary.dark',
config.palettePrimaryDark,
);
return shallowDefaultTheme; return shallowDefaultTheme;
}; };

View File

@@ -6,7 +6,7 @@ export default function useAdminUpdateConfig(appKey) {
const query = useMutation({ const query = useMutation({
mutationFn: async (payload) => { mutationFn: async (payload) => {
const { data } = await api.patch(`/v1/admin/config`, payload); const { data } = await api.patch('/v1/admin/config', payload);
return data; return data;
}, },

View File

@@ -2,7 +2,7 @@ import LoadingButton from '@mui/lab/LoadingButton';
import Grid from '@mui/material/Grid'; import Grid from '@mui/material/Grid';
import Skeleton from '@mui/material/Skeleton'; import Skeleton from '@mui/material/Skeleton';
import Stack from '@mui/material/Stack'; import Stack from '@mui/material/Stack';
import merge from 'lodash/merge'; import mergeWith from 'lodash/mergeWith';
import * as React from 'react'; import * as React from 'react';
import ColorInput from 'components/ColorInput'; import ColorInput from 'components/ColorInput';
@@ -10,7 +10,6 @@ import Container from 'components/Container';
import Form from 'components/Form'; import Form from 'components/Form';
import PageTitle from 'components/PageTitle'; import PageTitle from 'components/PageTitle';
import TextField from 'components/TextField'; import TextField from 'components/TextField';
import nestObject from 'helpers/nestObject';
import useAdminUpdateConfig from 'hooks/useAdminUpdateConfig'; import useAdminUpdateConfig from 'hooks/useAdminUpdateConfig';
import useAutomatischConfig from 'hooks/useAutomatischConfig'; import useAutomatischConfig from 'hooks/useAutomatischConfig';
import useFormatMessage from 'hooks/useFormatMessage'; import useFormatMessage from 'hooks/useFormatMessage';
@@ -27,9 +26,17 @@ const getPrimaryLightColor = (color) => color || primaryLightColor;
const defaultValues = { const defaultValues = {
title: 'Automatisch', title: 'Automatisch',
'palette.primary.main': primaryMainColor, palettePrimaryMain: primaryMainColor,
'palette.primary.dark': primaryDarkColor, palettePrimaryDark: primaryDarkColor,
'palette.primary.light': primaryLightColor, palettePrimaryLight: primaryLightColor,
};
const mergeIfGiven = (oldValue, newValue) => {
if (newValue) {
return newValue;
}
return oldValue;
}; };
export default function UserInterface() { export default function UserInterface() {
@@ -39,21 +46,16 @@ export default function UserInterface() {
const config = configData?.data; const config = configData?.data;
const enqueueSnackbar = useEnqueueSnackbar(); const enqueueSnackbar = useEnqueueSnackbar();
const configWithDefaults = merge({}, defaultValues, nestObject(config)); const configWithDefaults = mergeWith(defaultValues, config, mergeIfGiven);
const handleUserInterfaceUpdate = async (uiData) => { const handleUserInterfaceUpdate = async (uiData) => {
try { try {
const input = { const input = {
title: uiData?.title, title: uiData.title,
'palette.primary.main': getPrimaryMainColor( palettePrimaryMain: getPrimaryMainColor(uiData.palettePrimaryMain),
uiData?.palette?.primary.main, palettePrimaryDark: getPrimaryDarkColor(uiData.palettePrimaryDark),
), palettePrimaryLight: getPrimaryLightColor(uiData.palettePrimaryLight),
'palette.primary.dark': getPrimaryDarkColor( 'logo.svgData': uiData.logoSvgData,
uiData?.palette?.primary.dark,
),
'palette.primary.light': getPrimaryLightColor(
uiData?.palette?.primary.light,
),
'logo.svgData': uiData?.logo?.svgData,
}; };
await updateConfig(input); await updateConfig(input);
enqueueSnackbar(formatMessage('userInterfacePage.successfullyUpdated'), { enqueueSnackbar(formatMessage('userInterfacePage.successfullyUpdated'), {
@@ -66,6 +68,7 @@ export default function UserInterface() {
throw new Error('Failed while updating!'); throw new Error('Failed while updating!');
} }
}; };
return ( return (
<Container sx={{ py: 3, display: 'flex', justifyContent: 'center' }}> <Container sx={{ py: 3, display: 'flex', justifyContent: 'center' }}>
<Grid container item xs={12} sm={10} md={9}> <Grid container item xs={12} sm={10} md={9}>
@@ -96,7 +99,7 @@ export default function UserInterface() {
/> />
<ColorInput <ColorInput
name="palette.primary.main" name="palettePrimaryMain"
label={formatMessage( label={formatMessage(
'userInterfacePage.primaryMainColorFieldLabel', 'userInterfacePage.primaryMainColorFieldLabel',
)} )}
@@ -105,7 +108,7 @@ export default function UserInterface() {
/> />
<ColorInput <ColorInput
name="palette.primary.dark" name="palettePrimaryDark"
label={formatMessage( label={formatMessage(
'userInterfacePage.primaryDarkColorFieldLabel', 'userInterfacePage.primaryDarkColorFieldLabel',
)} )}
@@ -114,7 +117,7 @@ export default function UserInterface() {
/> />
<ColorInput <ColorInput
name="palette.primary.light" name="palettePrimaryLight"
label={formatMessage( label={formatMessage(
'userInterfacePage.primaryLightColorFieldLabel', 'userInterfacePage.primaryLightColorFieldLabel',
)} )}
@@ -123,7 +126,7 @@ export default function UserInterface() {
/> />
<TextField <TextField
name="logo.svgData" name="logoSvgData"
label={formatMessage('userInterfacePage.svgDataFieldLabel')} label={formatMessage('userInterfacePage.svgDataFieldLabel')}
multiline multiline
fullWidth fullWidth