2023-02-24 19:17:13 +00:00
|
|
|
import React, { useContext } from 'react';
|
2022-10-30 19:13:01 +00:00
|
|
|
import { useTranslation } from 'react-i18next';
|
2023-02-24 19:17:13 +00:00
|
|
|
import { AppContextProps, AppContext } from '../../contexts/AppContext';
|
2022-10-30 19:13:01 +00:00
|
|
|
import {
|
|
|
|
Grid,
|
|
|
|
Paper,
|
|
|
|
Switch,
|
|
|
|
useTheme,
|
|
|
|
FormControlLabel,
|
|
|
|
List,
|
|
|
|
ListItem,
|
|
|
|
ListItemIcon,
|
|
|
|
Slider,
|
|
|
|
Typography,
|
|
|
|
ToggleButtonGroup,
|
|
|
|
ToggleButton,
|
|
|
|
} from '@mui/material';
|
|
|
|
import SelectLanguage from './SelectLanguage';
|
|
|
|
import {
|
|
|
|
Translate,
|
|
|
|
Palette,
|
|
|
|
LightMode,
|
|
|
|
DarkMode,
|
|
|
|
SettingsOverscan,
|
|
|
|
Link,
|
2023-02-10 13:28:26 +00:00
|
|
|
AccountBalance,
|
|
|
|
AttachMoney,
|
2022-10-30 19:13:01 +00:00
|
|
|
} from '@mui/icons-material';
|
2022-11-07 10:13:02 +00:00
|
|
|
import { systemClient } from '../../services/System';
|
2023-02-10 13:28:26 +00:00
|
|
|
import SwapCalls from '@mui/icons-material/SwapCalls';
|
2022-10-30 19:13:01 +00:00
|
|
|
|
|
|
|
interface SettingsFormProps {
|
|
|
|
dense?: boolean;
|
2022-10-31 18:03:34 +00:00
|
|
|
showNetwork?: boolean;
|
2022-10-30 19:13:01 +00:00
|
|
|
}
|
|
|
|
|
2023-02-24 19:17:13 +00:00
|
|
|
const SettingsForm = ({ dense = false, showNetwork = false }: SettingsFormProps): JSX.Element => {
|
|
|
|
const { fav, setFav, settings, setSettings } = useContext<AppContextProps>(AppContext);
|
2022-10-30 19:13:01 +00:00
|
|
|
const theme = useTheme();
|
|
|
|
const { t } = useTranslation();
|
|
|
|
const fontSizes = [
|
|
|
|
{ label: 'XS', value: { basic: 12, pro: 10 } },
|
|
|
|
{ label: 'S', value: { basic: 13, pro: 11 } },
|
|
|
|
{ label: 'M', value: { basic: 14, pro: 12 } },
|
|
|
|
{ label: 'L', value: { basic: 15, pro: 13 } },
|
|
|
|
{ label: 'XL', value: { basic: 16, pro: 14 } },
|
|
|
|
];
|
|
|
|
|
|
|
|
return (
|
|
|
|
<Grid container spacing={1}>
|
|
|
|
<Grid item>
|
|
|
|
<List dense={dense}>
|
|
|
|
<ListItem>
|
|
|
|
<ListItemIcon>
|
|
|
|
<Translate />
|
|
|
|
</ListItemIcon>
|
|
|
|
<SelectLanguage
|
|
|
|
language={settings.language}
|
2022-11-07 10:13:02 +00:00
|
|
|
setLanguage={(language) => {
|
|
|
|
setSettings({ ...settings, language });
|
2022-11-09 22:10:32 +00:00
|
|
|
systemClient.setItem('settings_language', language);
|
2022-11-07 10:13:02 +00:00
|
|
|
}}
|
2022-10-30 19:13:01 +00:00
|
|
|
/>
|
|
|
|
</ListItem>
|
|
|
|
|
|
|
|
<ListItem>
|
|
|
|
<ListItemIcon>
|
|
|
|
<Palette />
|
|
|
|
</ListItemIcon>
|
|
|
|
<FormControlLabel
|
|
|
|
labelPlacement='end'
|
|
|
|
label={settings.mode === 'dark' ? t('Dark') : t('Light')}
|
|
|
|
control={
|
|
|
|
<Switch
|
|
|
|
checked={settings.mode === 'dark'}
|
|
|
|
checkedIcon={
|
|
|
|
<Paper
|
|
|
|
elevation={3}
|
|
|
|
sx={{
|
|
|
|
width: '1.2em',
|
|
|
|
height: '1.2em',
|
|
|
|
borderRadius: '0.4em',
|
|
|
|
backgroundColor: 'white',
|
|
|
|
position: 'relative',
|
|
|
|
top: `${7 - 0.5 * theme.typography.fontSize}px`,
|
|
|
|
}}
|
|
|
|
>
|
|
|
|
<DarkMode sx={{ width: '0.8em', height: '0.8em', color: '#666' }} />
|
|
|
|
</Paper>
|
|
|
|
}
|
|
|
|
icon={
|
|
|
|
<Paper
|
|
|
|
elevation={3}
|
|
|
|
sx={{
|
|
|
|
width: '1.2em',
|
|
|
|
height: '1.2em',
|
|
|
|
borderRadius: '0.4em',
|
|
|
|
backgroundColor: 'white',
|
|
|
|
padding: '0.07em',
|
|
|
|
position: 'relative',
|
|
|
|
top: `${7 - 0.5 * theme.typography.fontSize}px`,
|
|
|
|
}}
|
|
|
|
>
|
|
|
|
<LightMode sx={{ width: '0.67em', height: '0.67em', color: '#666' }} />
|
|
|
|
</Paper>
|
|
|
|
}
|
2022-11-07 10:13:02 +00:00
|
|
|
onChange={(e) => {
|
|
|
|
const mode = e.target.checked ? 'dark' : 'light';
|
|
|
|
setSettings({ ...settings, mode });
|
2022-11-09 22:10:32 +00:00
|
|
|
systemClient.setItem('settings_mode', mode);
|
2022-11-07 10:13:02 +00:00
|
|
|
}}
|
2022-10-30 19:13:01 +00:00
|
|
|
/>
|
|
|
|
}
|
|
|
|
/>
|
|
|
|
</ListItem>
|
|
|
|
|
|
|
|
<ListItem>
|
|
|
|
<ListItemIcon>
|
|
|
|
<SettingsOverscan />
|
|
|
|
</ListItemIcon>
|
|
|
|
<Slider
|
|
|
|
value={settings.fontSize}
|
|
|
|
min={settings.frontend == 'basic' ? 12 : 10}
|
|
|
|
max={settings.frontend == 'basic' ? 16 : 14}
|
|
|
|
step={1}
|
2022-11-07 10:13:02 +00:00
|
|
|
onChange={(e) => {
|
|
|
|
const fontSize = e.target.value;
|
|
|
|
setSettings({ ...settings, fontSize });
|
2022-11-09 22:10:32 +00:00
|
|
|
systemClient.setItem(`settings_fontsize_${settings.frontend}`, fontSize.toString());
|
2022-11-07 10:13:02 +00:00
|
|
|
}}
|
2022-10-30 19:13:01 +00:00
|
|
|
valueLabelDisplay='off'
|
|
|
|
marks={fontSizes.map(({ label, value }) => ({
|
|
|
|
label: <Typography variant='caption'>{t(label)}</Typography>,
|
|
|
|
value: settings.frontend === 'basic' ? value.basic : value.pro,
|
|
|
|
}))}
|
|
|
|
track={false}
|
|
|
|
/>
|
|
|
|
</ListItem>
|
2023-02-10 13:28:26 +00:00
|
|
|
|
|
|
|
<ListItem>
|
|
|
|
<ListItemIcon>
|
|
|
|
<AccountBalance />
|
|
|
|
</ListItemIcon>
|
|
|
|
<ToggleButtonGroup
|
|
|
|
exclusive={true}
|
|
|
|
value={fav.mode}
|
|
|
|
onChange={(e, mode) => {
|
|
|
|
setFav({ ...fav, mode, currency: mode === 'fiat' ? 0 : 1000 });
|
|
|
|
}}
|
|
|
|
>
|
|
|
|
<ToggleButton value='fiat' color='primary'>
|
|
|
|
<AttachMoney />
|
|
|
|
{t('Fiat')}
|
|
|
|
</ToggleButton>
|
|
|
|
<ToggleButton value='swap' color='secondary'>
|
|
|
|
<SwapCalls />
|
|
|
|
{t('Swaps')}
|
|
|
|
</ToggleButton>
|
|
|
|
</ToggleButtonGroup>
|
|
|
|
</ListItem>
|
|
|
|
|
2022-10-31 18:03:34 +00:00
|
|
|
{showNetwork ? (
|
2022-10-30 19:13:01 +00:00
|
|
|
<ListItem>
|
|
|
|
<ListItemIcon>
|
|
|
|
<Link />
|
|
|
|
</ListItemIcon>
|
|
|
|
<ToggleButtonGroup
|
|
|
|
exclusive={true}
|
|
|
|
value={settings.network}
|
2022-11-07 16:45:05 +00:00
|
|
|
onChange={(e, network) => {
|
|
|
|
setSettings({ ...settings, network });
|
2022-11-09 22:10:32 +00:00
|
|
|
systemClient.setItem('settings_network', network);
|
2022-11-07 16:45:05 +00:00
|
|
|
}}
|
2022-10-30 19:13:01 +00:00
|
|
|
>
|
|
|
|
<ToggleButton value='mainnet' color='primary'>
|
|
|
|
{t('Mainnet')}
|
|
|
|
</ToggleButton>
|
|
|
|
<ToggleButton value='testnet' color='secondary'>
|
|
|
|
{t('Testnet')}
|
|
|
|
</ToggleButton>
|
|
|
|
</ToggleButtonGroup>
|
|
|
|
</ListItem>
|
|
|
|
) : (
|
|
|
|
<></>
|
|
|
|
)}
|
|
|
|
</List>
|
|
|
|
</Grid>
|
|
|
|
</Grid>
|
|
|
|
);
|
|
|
|
};
|
|
|
|
|
|
|
|
export default SettingsForm;
|