import { Text, SegmentedControl, TextInput, Stack } from '@mantine/core'; import { useState } from 'react'; import { useTranslation } from 'next-i18next'; import { useConfig } from '../../tools/state'; import { ColorSchemeSwitch } from '../ColorSchemeToggle/ColorSchemeSwitch'; import { WidgetsPositionSwitch } from '../WidgetsPositionSwitch/WidgetsPositionSwitch'; import ConfigChanger from '../Config/ConfigChanger'; import SaveConfigComponent from '../Config/SaveConfig'; import ModuleEnabler from './ModuleEnabler'; import Tip from '../layout/Tip'; import LanguageSwitch from './LanguageSwitch'; export default function CommonSettings(args: any) { const { config, setConfig } = useConfig(); const { t } = useTranslation([ 'settings/general/search-engine', 'settings/general/config-changer', ]); const matches = [ { label: 'Google', value: 'https://google.com/search?q=' }, { label: 'DuckDuckGo', value: 'https://duckduckgo.com/?q=' }, { label: 'Bing', value: 'https://bing.com/search?q=' }, { label: 'Custom', value: 'Custom' }, ]; const [customSearchUrl, setCustomSearchUrl] = useState(config.settings.searchUrl); const [searchUrl, setSearchUrl] = useState( matches.find((match) => match.value === config.settings.searchUrl)?.value ?? 'Custom' ); return ( {t('title')} {t('tips.generalTip')} { setSearchUrl(e); setConfig({ ...config, settings: { ...config.settings, searchUrl: e, }, }); } } data={matches} /> {searchUrl === 'Custom' && ( <> {t('tips.placeholderTip')} { setCustomSearchUrl(event.currentTarget.value); setConfig({ ...config, settings: { ...config.settings, searchUrl: event.currentTarget.value, }, }); }} /> )} {t('configTip')} ); }