import PropTypes from 'prop-types'; import React, { Component } from 'react'; import Alert from 'Components/Alert'; import FieldSet from 'Components/FieldSet'; import Form from 'Components/Form/Form'; import FormGroup from 'Components/Form/FormGroup'; import FormInputGroup from 'Components/Form/FormInputGroup'; import FormLabel from 'Components/Form/FormLabel'; import LoadingIndicator from 'Components/Loading/LoadingIndicator'; import PageContent from 'Components/Page/PageContent'; import PageContentBody from 'Components/Page/PageContentBody'; import { inputTypes, kinds } from 'Helpers/Props'; import SettingsToolbarConnector from 'Settings/SettingsToolbarConnector'; import themes from 'Styles/Themes'; import titleCase from 'Utilities/String/titleCase'; import translate from 'Utilities/String/translate'; export const firstDayOfWeekOptions = [ { key: 0, get value() { return translate('Sunday'); } }, { key: 1, get value() { return translate('Monday'); } } ]; export const weekColumnOptions = [ { key: 'ddd M/D', value: 'Tue 3/25' }, { key: 'ddd MM/DD', value: 'Tue 03/25' }, { key: 'ddd D/M', value: 'Tue 25/3' }, { key: 'ddd DD/MM', value: 'Tue 25/03' } ]; const shortDateFormatOptions = [ { key: 'MMM D YYYY', value: 'Mar 25 2014' }, { key: 'DD MMM YYYY', value: '25 Mar 2014' }, { key: 'MM/D/YYYY', value: '03/25/2014' }, { key: 'MM/DD/YYYY', value: '03/25/2014' }, { key: 'DD/MM/YYYY', value: '25/03/2014' }, { key: 'YYYY-MM-DD', value: '2014-03-25' } ]; const longDateFormatOptions = [ { key: 'dddd, MMMM D YYYY', value: 'Tuesday, March 25, 2014' }, { key: 'dddd, D MMMM YYYY', value: 'Tuesday, 25 March, 2014' } ]; export const timeFormatOptions = [ { key: 'h(:mm)a', value: '5pm/5:30pm' }, { key: 'HH:mm', value: '17:00/17:30' } ]; class UISettings extends Component { // // Render render() { const { isFetching, error, settings, hasSettings, onInputChange, onSavePress, languages, ...otherProps } = this.props; const themeOptions = Object.keys(themes) .map((theme) => ({ key: theme, value: titleCase(theme) })); return ( { isFetching ? : null } { !isFetching && error ? {translate('UiSettingsLoadError')} : null } { hasSettings && !isFetching && !error ?
{translate('FirstDayOfWeek')} {translate('WeekColumnHeader')}
{translate('ShortDateFormat')} {translate('LongDateFormat')} {translate('TimeFormat')} {translate('ShowRelativeDates')}
{translate('Theme')} {translate('EnableColorImpairedMode')}
{translate('UiLanguage')}
: null }
); } } UISettings.propTypes = { isFetching: PropTypes.bool.isRequired, error: PropTypes.object, settings: PropTypes.object.isRequired, hasSettings: PropTypes.bool.isRequired, languages: PropTypes.arrayOf(PropTypes.object).isRequired, onSavePress: PropTypes.func.isRequired, onInputChange: PropTypes.func.isRequired }; export default UISettings;