pleroma/app/soapbox/features/compose/containers/poll_form_container.js

53 lines
1.4 KiB
JavaScript
Raw Normal View History

2020-03-27 13:59:38 -07:00
import { connect } from 'react-redux';
import { addPollOption, removePollOption, changePollOption, changePollSettings, removePoll } from '../../../actions/compose';
2020-03-27 13:59:38 -07:00
import {
clearComposeSuggestions,
fetchComposeSuggestions,
selectComposeSuggestion,
} from '../../../actions/compose';
import PollForm from '../components/poll_form';
2020-03-27 13:59:38 -07:00
const mapStateToProps = state => ({
suggestions: state.getIn(['compose', 'suggestions']),
options: state.getIn(['compose', 'poll', 'options']),
expiresIn: state.getIn(['compose', 'poll', 'expires_in']),
isMultiple: state.getIn(['compose', 'poll', 'multiple']),
});
const mapDispatchToProps = dispatch => ({
onAddOption(title) {
dispatch(addPollOption(title));
},
onRemoveOption(index) {
dispatch(removePollOption(index));
},
onChangeOption(index, title) {
dispatch(changePollOption(index, title));
},
onChangeSettings(expiresIn, isMultiple) {
dispatch(changePollSettings(expiresIn, isMultiple));
},
onClearSuggestions() {
2020-03-27 13:59:38 -07:00
dispatch(clearComposeSuggestions());
},
onFetchSuggestions(token) {
2020-03-27 13:59:38 -07:00
dispatch(fetchComposeSuggestions(token));
},
onSuggestionSelected(position, token, accountId, path) {
2020-03-27 13:59:38 -07:00
dispatch(selectComposeSuggestion(position, token, accountId, path));
},
onRemovePoll() {
dispatch(removePoll());
},
2020-03-27 13:59:38 -07:00
});
export default connect(mapStateToProps, mapDispatchToProps)(PollForm);