import { TextInput } from '@mantine/core'; import { useTranslation } from 'next-i18next'; import { ChangeEventHandler, useState } from 'react'; import { useConfigContext } from '../../../../config/provider'; import { useConfigStore } from '../../../../config/store'; export const BackgroundChanger = () => { const { t } = useTranslation('settings/customization/page-appearance'); const updateConfig = useConfigStore((x) => x.updateConfig); const { config, name: configName } = useConfigContext(); const [backgroundImageUrl, setBackgroundImageUrl] = useState( config?.settings.customization.backgroundImageUrl ); if (!configName) return null; const handleChange: ChangeEventHandler = (ev) => { const { value } = ev.currentTarget; const backgroundImageUrl = value.trim().length === 0 ? undefined : value; setBackgroundImageUrl(backgroundImageUrl); updateConfig(configName, (prev) => ({ ...prev, settings: { ...prev.settings, customization: { ...prev.settings.customization, backgroundImageUrl, }, }, })); }; return ( ); };