import React from 'react'; import { connect } from 'react-redux'; import { defineMessages, injectIntl } from 'react-intl'; import ImmutablePureComponent from 'react-immutable-pure-component'; import PropTypes from 'prop-types'; import ImmutablePropTypes from 'react-immutable-proptypes'; import { changeSetting } from 'gabsocial/actions/settings'; import Column from '../ui/components/column'; import { SimpleForm, FieldsGroup, RadioGroup, RadioItem, } from 'gabsocial/features/forms'; import SettingsCheckbox from './components/settings_checkbox'; const messages = defineMessages({ heading: { id: 'column.preferences', defaultMessage: 'Preferences' }, }); // TODO: Pull dynamically const themes = { cobalt: 'cobalt', 'gabsocial-light': 'Light', default: 'Dark', contrast: 'High contrast', halloween: 'Halloween', neenster: 'neenster', glinner: 'glinner', lime: 'lime', }; const mapStateToProps = state => ({ settings: state.get('settings'), }); export default @connect(mapStateToProps) @injectIntl class Preferences extends ImmutablePureComponent { static propTypes = { dispatch: PropTypes.func.isRequired, intl: PropTypes.object.isRequired, settings: ImmutablePropTypes.map, }; constructor(props) { super(props); this.state = { isLoading: false }; } getFormData = (form) => { return Object.fromEntries( Array.from(form).map(i => [i.name, i.value]) ); } onThemeChange = e => { const { dispatch } = this.props; dispatch(changeSetting(['theme'], e.target.value)); } onDefaultPrivacyChange = e => { const { dispatch } = this.props; dispatch(changeSetting(['defaultPrivacy'], e.target.value)); } render() { const { settings, intl } = this.props; return (
); } }