mirror of https://github.com/mastodon/mastodon
You cannot select more than 25 topics
Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
77 lines
2.0 KiB
JavaScript
77 lines
2.0 KiB
JavaScript
import { connect } from 'react-redux';
|
|
import ComposeForm from '../components/compose_form';
|
|
import {
|
|
changeCompose,
|
|
submitCompose,
|
|
cancelReplyCompose,
|
|
clearComposeSuggestions,
|
|
fetchComposeSuggestions,
|
|
selectComposeSuggestion,
|
|
changeComposeSensitivity,
|
|
changeComposeVisibility,
|
|
changeComposeListability
|
|
} from '../../../actions/compose';
|
|
import { makeGetStatus } from '../../../selectors';
|
|
|
|
const makeMapStateToProps = () => {
|
|
const getStatus = makeGetStatus();
|
|
|
|
const mapStateToProps = function (state, props) {
|
|
return {
|
|
text: state.getIn(['compose', 'text']),
|
|
suggestion_token: state.getIn(['compose', 'suggestion_token']),
|
|
suggestions: state.getIn(['compose', 'suggestions']),
|
|
sensitive: state.getIn(['compose', 'sensitive']),
|
|
unlisted: state.getIn(['compose', 'unlisted']),
|
|
private: state.getIn(['compose', 'private']),
|
|
is_submitting: state.getIn(['compose', 'is_submitting']),
|
|
is_uploading: state.getIn(['compose', 'is_uploading']),
|
|
in_reply_to: getStatus(state, state.getIn(['compose', 'in_reply_to']))
|
|
};
|
|
};
|
|
|
|
return mapStateToProps;
|
|
};
|
|
|
|
const mapDispatchToProps = function (dispatch) {
|
|
return {
|
|
onChange (text) {
|
|
dispatch(changeCompose(text));
|
|
},
|
|
|
|
onSubmit () {
|
|
dispatch(submitCompose());
|
|
},
|
|
|
|
onCancelReply () {
|
|
dispatch(cancelReplyCompose());
|
|
},
|
|
|
|
onClearSuggestions () {
|
|
dispatch(clearComposeSuggestions());
|
|
},
|
|
|
|
onFetchSuggestions (token) {
|
|
dispatch(fetchComposeSuggestions(token));
|
|
},
|
|
|
|
onSuggestionSelected (position, token, accountId) {
|
|
dispatch(selectComposeSuggestion(position, token, accountId));
|
|
},
|
|
|
|
onChangeSensitivity (checked) {
|
|
dispatch(changeComposeSensitivity(checked));
|
|
},
|
|
|
|
onChangeVisibility (checked) {
|
|
dispatch(changeComposeVisibility(checked));
|
|
},
|
|
|
|
onChangeListability (checked) {
|
|
dispatch(changeComposeListability(checked));
|
|
}
|
|
}
|
|
};
|
|
|
|
export default connect(makeMapStateToProps, mapDispatchToProps)(ComposeForm);
|