import React from 'react'; import { connect } from 'react-redux'; import { defineMessages, injectIntl, FormattedMessage } from 'react-intl'; import ImmutablePureComponent from 'react-immutable-pure-component'; import PropTypes from 'prop-types'; import ImmutablePropTypes from 'react-immutable-proptypes'; import Column from '../ui/components/column'; import { SimpleForm, FieldsGroup, TextInput, Checkbox, FileChooser, } from 'soapbox/features/forms'; import StillImage from 'soapbox/components/still_image'; import { Map as ImmutableMap, List as ImmutableList, } from 'immutable'; import { patchSoapbox } from 'soapbox/actions/soapbox'; //import { generateThemeCss } from 'soapbox/utils/theme'; const messages = defineMessages({ heading: { id: 'column.soapbox_settings', defaultMessage: 'Soapbox settings' }, promoItemIcon: { id: 'soapbox_settings.promo_panel.meta_fields.icon_placeholder', defaultMessage: 'Icon' }, promoItemLabel: { id: 'soapbox_settings.promo_panel.meta_fields.label_placeholder', defaultMessage: 'Label' }, promoItemURL: { id: 'soapbox_settings.promo_panel.meta_fields.url_placeholder', defaultMessage: 'URL' }, homeFooterItemLabel: { id: 'soapbox_settings.home_footer.meta_fields.label_placeholder', defaultMessage: 'Label' }, homeFooterItemURL: { id: 'soapbox_settings.home_footer.meta_fields.url_placeholder', defaultMessage: 'URL' }, customCssLabel: { id: 'soapbox_settings.custom_css.meta_fields.url_placeholder', defaultMessage: 'URL' }, }); const mapStateToProps = state => { const soapbox = state.get('soapbox'); return { // themeCss: generateThemeCss(soapbox.get('brandColor')), brandColor: soapbox.get('brandColor'), customCssItems: soapbox.get('customCss'), logo: soapbox.get('logo'), banner: soapbox.get('banner'), promoItems: soapbox.getIn(['promoPanel', 'items']), patronEnabled: soapbox.getIn(['extensions', 'patron']), autoPlayGif: soapbox.getIn(['defaultSettings', 'autoPlayGif']), copyright: soapbox.get('copyright'), homeFooterItems: soapbox.getIn(['navlinks', 'homeFooter']), }; }; export default @connect(mapStateToProps) // export default @connect() @injectIntl class ConfigSoapbox extends ImmutablePureComponent { static propTypes = { dispatch: PropTypes.func.isRequired, intl: PropTypes.object.isRequired, brandColor: PropTypes.string, customCssItems: ImmutablePropTypes.list, logo: PropTypes.string, banner: PropTypes.string, promoItems: ImmutablePropTypes.list, patronEnabled: PropTypes.bool, autoPlayGif: PropTypes.bool, copyright: PropTypes.string, homeFooterItems: ImmutablePropTypes.list, }; state = { isLoading: false, } constructor(props) { super(props); this.state = { logo: props.logo, banner: props.banner, brandColor: props.brandColor, customCssItems: props.customCssItems, promoItems: props.promoItems, homeFooterItems: props.homeFooterItems, copyright: props.copyright, patronEnabled: false, autoPlayGif: false, }; if (!this.state.logo) { this.state.logo = ''; } if (!this.state.banner) { this.state.banner = ''; } if (!this.state.promoItems) { this.state.promoItems = ImmutableList([ ImmutableMap({ icon: '', text: '', url: '', }), ]); }; if (!this.state.homeFooterItems) { this.state.homeFooterItems = ImmutableList([ ImmutableMap({ title: '', url: '', }), ]); }; if (!this.state.customCssItems) { this.state.customCssItems = ImmutableList([]); }; this.handlecustomCSSChange = this.handleCustomCSSChange.bind(this); this.handleAddPromoPanelItem = this.handleAddPromoPanelItem.bind(this); this.handleAddHomeFooterItem = this.handleAddHomeFooterItem.bind(this); this.handleAddCssItem = this.handleAddCssItem.bind(this); this.getCustomCssParams = this.getCustomCssParams.bind(this); } getPromoItemsParams = () => { let params = ImmutableMap(); this.state.promoItems.forEach((f, i) => params = params .set(`promo_panel_attributes[${i}][icon]`, f.get('icon')) .set(`promo_panel_attributes[${i}][text]`, f.get('text')) .set(`promo_panel_attributes[${i}][url]`, f.get('url')) ); return params; } getHomeFooterParams = () => { let params = ImmutableMap(); this.state.homeFooterItems.forEach((f, i) => params = params .set(`home_footer_attributes[${i}][title]`, f.get('title')) .set(`home_footer_attributes[${i}][url]`, f.get('url')) ); return params; } getCustomCssParams = () => { let params = ImmutableMap(); this.state.customCssItems.forEach((f, i) => params = params .set(`custom_css_attributes[${i}][url]`, f) ); return params; } getParams = () => { const { state } = this; return Object.assign({ logo: state.logo, banner: state.banner, brandColor: state.brandColor, patronEnabled: state.patronEnabled, autoPlayGif: state.autoPlayGif, copyright: state.copyright, }, this.getHomeFooterParams().toJS(), this.getPromoItemsParams().toJS(), this.getCustomCssParams().toJS()); } getFormdata = () => { const data = this.getParams(); let formData = new FormData(); for (let key in data) { const shouldAppend = Boolean(data[key] || key.startsWith('promo_panel_attributes') || key.startsWith('home_footer_attributes') || key.startsWith('custom_css_attributes') || (key === 'patronEnabled' && data.patronEnabled !== undefined) || (key === 'autoPlayGif' && data.autoPlayGif !== undefined)); if (shouldAppend) formData.append(key, data[key] || ''); } return JSON.stringify(formData); } handleSubmit = (event) => { const { dispatch } = this.props; dispatch(patchSoapbox(this.getFormdata())).then(() => { this.setState({ isLoading: false }); }).catch((error) => { this.setState({ isLoading: false }); }); this.setState({ isLoading: true }); event.preventDefault(); } handleCheckboxChange = e => { this.setState({ [e.target.name]: e.target.checked }); } handleBrandColorChange = e => { this.setState({ brandColor: e.target.value }); } handleTextChange = e => { this.setState({ [e.target.name]: e.target.value }); } handlePromoItemsChange = (i, key) => { return (e) => { this.setState({ promoItems: this.state.promoItems.setIn([i, key], e.target.value), }); }; } handleHomeFooterItemsChange = (i, key) => { return (e) => { this.setState({ homeFooterItems: this.state.homeFooterItems.setIn([i, key], e.target.value), }); }; } handleCustomCSSChange = i => { return (e) => { this.setState({ customCssItems: this.state.customCssItems.setIn([i], e.target.value), }); }; } handleFileChange = e => { const { name } = e.target; const [file] = e.target.files || []; const url = file ? URL.createObjectURL(file) : this.state[name]; this.setState({ [name]: url, [`${name}_file`]: file, }); } handleAddPromoPanelItem = () => { this.setState({ promoItems: this.state.promoItems.concat([ ImmutableMap({ icon: '', text: '', url: '', }), ]), }); } handleAddHomeFooterItem = () => { this.setState({ homeFooterItems: this.state.homeFooterItems.concat([ ImmutableMap({ title: '', url: '', }), ]), }); } handleAddCssItem = () => { this.setState({ customCssItems: this.state.customCssItems.concat(['']), }); } render() { const { intl } = this.props; return (
{this.state.logo ? () : ()}
} name='logo' hint={
{this.state.banner ? () : ()}
} name='banner' hint={} onChange={this.handleFileChange} />




} hint={} name='patronEnabled' checked={this.state.patronEnabled ? this.state.patronEnabled : this.props.patronEnabled || false} onChange={this.handleCheckboxChange} /> } hint={} name='autoPlayGif' checked={this.state.autoPlayGif ? this.state.autoPlayGif : this.props.autoPlayGif || false} onChange={this.handleCheckboxChange} />
Soapbox Icons List }} /> { this.state.promoItems.map((field, i) => (
)) }
{ this.state.homeFooterItems.map((field, i) => (
)) }
{ this.state.customCssItems.map((field, i) => (
)) }
); } }