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

58 lines
1.3 KiB
JavaScript
Raw Normal View History

2020-03-27 13:59:38 -07:00
import { connect } from 'react-redux';
2020-03-27 13:59:38 -07:00
import {
addPollOption,
removePollOption,
changePollOption,
changePollSettings,
removePoll,
2020-03-27 13:59:38 -07:00
clearComposeSuggestions,
fetchComposeSuggestions,
selectComposeSuggestion,
} from '../../../actions/compose';
2022-06-06 10:19:45 -07:00
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);