about summary refs log tree commit diff
path: root/app/assets/javascripts/components/features/notifications/components/setting_toggle.jsx
blob: e9bca5928d241ca81073294d9717ffd3bc751016 (plain) (blame)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
import PropTypes from 'prop-types';
import ImmutablePropTypes from 'react-immutable-proptypes';
import Toggle from 'react-toggle';

const SettingToggle = ({ settings, settingKey, label, onChange, htmlFor = '' }) => (
  <label htmlFor={htmlFor} className='setting-toggle__label'>
    <Toggle checked={settings.getIn(settingKey)} onChange={(e) => onChange(settingKey, e.target.checked)} />
    <span className='setting-toggle'>{label}</span>
  </label>
);

SettingToggle.propTypes = {
  settings: ImmutablePropTypes.map.isRequired,
  settingKey: PropTypes.array.isRequired,
  label: PropTypes.node.isRequired,
  onChange: PropTypes.func.isRequired,
  htmlFor: PropTypes.string
};

export default SettingToggle;