You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.

82 lines
3.5 KiB

  1. import PureRenderMixin from 'react-addons-pure-render-mixin';
  2. import ImmutablePropTypes from 'react-immutable-proptypes';
  3. import { FormattedMessage } from 'react-intl';
  4. import ColumnCollapsable from '../../../components/column_collapsable';
  5. import SettingToggle from './setting_toggle';
  6. const outerStyle = {
  7. background: '#373b4a',
  8. padding: '15px'
  9. };
  10. const sectionStyle = {
  11. cursor: 'default',
  12. display: 'block',
  13. fontWeight: '500',
  14. color: '#9baec8',
  15. marginBottom: '10px'
  16. };
  17. const rowStyle = {
  18. };
  19. const ColumnSettings = React.createClass({
  20. propTypes: {
  21. settings: ImmutablePropTypes.map.isRequired,
  22. onChange: React.PropTypes.func.isRequired,
  23. onSave: React.PropTypes.func.isRequired
  24. },
  25. mixins: [PureRenderMixin],
  26. render () {
  27. const { settings, onChange, onSave } = this.props;
  28. const alertStr = <FormattedMessage id='notifications.column_settings.alert' defaultMessage='Desktop notifications' />;
  29. const showStr = <FormattedMessage id='notifications.column_settings.show' defaultMessage='Show in column' />;
  30. const soundStr = <FormattedMessage id='notifications.column_settings.sound' defaultMessage='Play sound' />;
  31. return (
  32. <ColumnCollapsable icon='sliders' fullHeight={616} onCollapse={onSave}>
  33. <div style={outerStyle}>
  34. <span style={sectionStyle}><FormattedMessage id='notifications.column_settings.follow' defaultMessage='New followers:' /></span>
  35. <div style={rowStyle}>
  36. <SettingToggle settings={settings} settingKey={['alerts', 'follow']} onChange={onChange} label={alertStr} />
  37. <SettingToggle settings={settings} settingKey={['shows', 'follow']} onChange={onChange} label={showStr} />
  38. <SettingToggle settings={settings} settingKey={['sounds', 'follow']} onChange={onChange} label={soundStr} />
  39. </div>
  40. <span style={sectionStyle}><FormattedMessage id='notifications.column_settings.favourite' defaultMessage='Favourites:' /></span>
  41. <div style={rowStyle}>
  42. <SettingToggle settings={settings} settingKey={['alerts', 'favourite']} onChange={onChange} label={alertStr} />
  43. <SettingToggle settings={settings} settingKey={['shows', 'favourite']} onChange={onChange} label={showStr} />
  44. <SettingToggle settings={settings} settingKey={['sounds', 'favourite']} onChange={onChange} label={soundStr} />
  45. </div>
  46. <span style={sectionStyle}><FormattedMessage id='notifications.column_settings.mention' defaultMessage='Mentions:' /></span>
  47. <div style={rowStyle}>
  48. <SettingToggle settings={settings} settingKey={['alerts', 'mention']} onChange={onChange} label={alertStr} />
  49. <SettingToggle settings={settings} settingKey={['shows', 'mention']} onChange={onChange} label={showStr} />
  50. <SettingToggle settings={settings} settingKey={['sounds', 'mention']} onChange={onChange} label={soundStr} />
  51. </div>
  52. <span style={sectionStyle}><FormattedMessage id='notifications.column_settings.reblog' defaultMessage='Boosts:' /></span>
  53. <div style={rowStyle}>
  54. <SettingToggle settings={settings} settingKey={['alerts', 'reblog']} onChange={onChange} label={alertStr} />
  55. <SettingToggle settings={settings} settingKey={['shows', 'reblog']} onChange={onChange} label={showStr} />
  56. <SettingToggle settings={settings} settingKey={['sounds', 'reblog']} onChange={onChange} label={soundStr} />
  57. </div>
  58. </div>
  59. </ColumnCollapsable>
  60. );
  61. }
  62. });
  63. export default ColumnSettings;