import React from 'react'; import PropTypes from 'prop-types'; import { connect } from 'react-redux'; import { injectIntl, defineMessages } from 'react-intl'; import Toggle from 'react-toggle'; import Icon from 'soapbox/components/icon'; import { changeSetting, getSettings } from 'soapbox/actions/settings'; const messages = defineMessages({ switchOn: { id: 'chats.audio_toggle_on', defaultMessage: 'Audio notification on' }, switchOff: { id: 'chats.audio_toggle_off', defaultMessage: 'Audio notification off' }, }); const mapStateToProps = state => { return { checked: getSettings(state).getIn(['chats', 'sound'], false), }; }; const mapDispatchToProps = (dispatch) => ({ toggleAudio(setting) { dispatch(changeSetting(['chats', 'sound'], setting)); }, }); export default @connect(mapStateToProps, mapDispatchToProps) @injectIntl class AudioToggle extends React.PureComponent { static propTypes = { intl: PropTypes.object.isRequired, checked: PropTypes.bool.isRequired, toggleAudio: PropTypes.func, showLabel: PropTypes.bool, }; handleToggleAudio = () => { this.props.toggleAudio(!this.props.checked); } render() { const { intl, checked, showLabel } = this.props; const id ='chats-audio-toggle'; const label = intl.formatMessage(checked ? messages.switchOff : messages.switchOn); return (
, unchecked: }} onKeyDown={this.onKeyDown} /> {showLabel && ()}
); } }