2023-07-24 08:37:18 +00:00
|
|
|
import { Switch, ToastPositionSetter } from '@vegaprotocol/ui-toolkit';
|
|
|
|
import { useThemeSwitcher } from '@vegaprotocol/react-helpers';
|
|
|
|
import { useTelemetryApproval } from '../../lib/hooks/use-telemetry-approval';
|
|
|
|
import type { ReactNode } from 'react';
|
2023-11-14 05:17:17 +00:00
|
|
|
import classNames from 'classnames';
|
2023-11-16 03:10:39 +00:00
|
|
|
import { useT } from '../../lib/use-t';
|
2023-07-24 08:37:18 +00:00
|
|
|
|
|
|
|
export const Settings = () => {
|
2023-11-16 03:10:39 +00:00
|
|
|
const t = useT();
|
2023-07-24 08:37:18 +00:00
|
|
|
const { theme, setTheme } = useThemeSwitcher();
|
|
|
|
const [isApproved, setIsApproved] = useTelemetryApproval();
|
|
|
|
return (
|
|
|
|
<div>
|
|
|
|
<SettingsGroup label={t('Dark mode')}>
|
|
|
|
<Switch
|
|
|
|
name="settings-theme-switch"
|
|
|
|
onCheckedChange={() => setTheme()}
|
|
|
|
checked={theme === 'dark'}
|
|
|
|
/>
|
|
|
|
</SettingsGroup>
|
|
|
|
<SettingsGroup
|
|
|
|
label={t('Share usage data')}
|
|
|
|
helpText={t(
|
|
|
|
'Help identify bugs and improve the service by sharing anonymous usage data.'
|
|
|
|
)}
|
|
|
|
>
|
|
|
|
<Switch
|
|
|
|
name="settings-telemetry-switch"
|
2023-09-01 09:00:20 +00:00
|
|
|
onCheckedChange={(isOn) => setIsApproved(isOn ? 'true' : 'false')}
|
|
|
|
checked={isApproved === 'true'}
|
2023-07-24 08:37:18 +00:00
|
|
|
/>
|
|
|
|
</SettingsGroup>
|
|
|
|
<SettingsGroup label={t('Toast location')}>
|
|
|
|
<ToastPositionSetter />
|
|
|
|
</SettingsGroup>
|
2023-11-14 05:17:17 +00:00
|
|
|
<SettingsGroup inline={false} label={t('App information')}>
|
|
|
|
<dl className="text-sm grid grid-cols-2 gap-1">
|
|
|
|
{process.env.GIT_TAG && (
|
|
|
|
<>
|
|
|
|
<dt className="text-muted">{t('Version')}</dt>
|
|
|
|
<dd>{process.env.GIT_TAG}</dd>
|
|
|
|
</>
|
|
|
|
)}
|
|
|
|
<dt className="text-muted">{t('Git commit hash')}</dt>
|
|
|
|
<dd className="break-words">{process.env.GIT_COMMIT}</dd>
|
|
|
|
</dl>
|
|
|
|
</SettingsGroup>
|
2023-07-24 08:37:18 +00:00
|
|
|
</div>
|
|
|
|
);
|
|
|
|
};
|
|
|
|
|
|
|
|
const SettingsGroup = ({
|
|
|
|
label,
|
|
|
|
helpText,
|
|
|
|
children,
|
2023-11-14 05:17:17 +00:00
|
|
|
inline = true,
|
2023-07-24 08:37:18 +00:00
|
|
|
}: {
|
|
|
|
label: string;
|
|
|
|
children: ReactNode;
|
2023-11-14 05:17:17 +00:00
|
|
|
helpText?: string;
|
|
|
|
inline?: boolean;
|
2023-07-24 08:37:18 +00:00
|
|
|
}) => {
|
|
|
|
return (
|
2023-11-14 05:17:17 +00:00
|
|
|
<div
|
|
|
|
className={classNames('mb-4 gap-2', {
|
|
|
|
'flex items-start justify-between gap-2': inline,
|
|
|
|
})}
|
|
|
|
>
|
|
|
|
<div className={classNames({ 'w-3/4': inline, 'mb-2': !inline })}>
|
2023-07-24 08:37:18 +00:00
|
|
|
<label className="text-sm">{label}</label>
|
2023-11-14 05:17:17 +00:00
|
|
|
{helpText && <p className="text-xs text-muted">{helpText}</p>}
|
2023-07-24 08:37:18 +00:00
|
|
|
</div>
|
|
|
|
{children}
|
|
|
|
</div>
|
|
|
|
);
|
|
|
|
};
|