1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374757677787980818283848586 |
- import type {JsonFormObject} from 'sentry/components/forms/types';
- import languages from 'sentry/data/languages';
- import {timezoneOptions} from 'sentry/data/timezones';
- import {t} from 'sentry/locale';
- import {removeBodyTheme} from 'sentry/utils/removeBodyTheme';
- // Export route to make these forms searchable by label/help
- export const route = '/settings/account/details/';
- // Called before sending API request, these fields need to be sent as an
- // `options` object
- const transformOptions = (data: object) => ({options: data});
- const formGroups: JsonFormObject[] = [
- {
- // Form "section"/"panel"
- title: 'Preferences',
- fields: [
- {
- name: 'theme',
- type: 'select',
- label: t('Theme'),
- help: t(
- "Select your theme preference. It can be synced to your system's theme, always light mode, or always dark mode."
- ),
- options: [
- {value: 'light', label: t('Light')},
- {value: 'dark', label: t('Dark')},
- {value: 'system', label: t('Default to system')},
- ],
- getData: transformOptions,
- onChange: () => {
- removeBodyTheme();
- },
- },
- {
- name: 'language',
- type: 'select',
- label: t('Language'),
- options: languages.map(([value, label]) => ({value, label})),
- getData: transformOptions,
- },
- {
- name: 'timezone',
- type: 'select',
- label: t('Timezone'),
- options: timezoneOptions,
- getData: transformOptions,
- },
- {
- name: 'clock24Hours',
- type: 'boolean',
- label: t('Use a 24-hour clock'),
- getData: transformOptions,
- },
- {
- name: 'stacktraceOrder',
- type: 'select',
- required: false,
- options: [
- {value: -1, label: t('Default')},
- {value: 1, label: t('Oldest')},
- {value: 2, label: t('Newest')},
- ],
- label: t('Stack Trace Order'),
- help: t('Choose the default ordering of frames in stack traces'),
- getData: transformOptions,
- },
- {
- name: 'defaultIssueEvent',
- type: 'select',
- required: false,
- options: [
- {value: 'recommended', label: t('Recommended')},
- {value: 'latest', label: t('Latest')},
- {value: 'oldest', label: t('Oldest')},
- ],
- label: t('Default Issue Event'),
- help: t('Choose what event gets displayed by default'),
- getData: transformOptions,
- },
- ],
- },
- ];
- export default formGroups;
|