2016-10-31 04:13:05 +11:00
|
|
|
import { connect } from 'react-redux';
|
|
|
|
import ComposeForm from '../components/compose_form';
|
|
|
|
import {
|
|
|
|
changeCompose,
|
|
|
|
submitCompose,
|
|
|
|
clearComposeSuggestions,
|
2016-11-13 00:33:21 +11:00
|
|
|
fetchComposeSuggestions,
|
2016-11-24 04:53:23 +11:00
|
|
|
selectComposeSuggestion,
|
2017-01-13 15:54:26 +11:00
|
|
|
changeComposeSpoilerText,
|
2017-05-21 01:31:47 +10:00
|
|
|
insertEmojiCompose,
|
2019-04-22 22:55:24 +10:00
|
|
|
uploadCompose,
|
2016-10-31 04:13:05 +11:00
|
|
|
} from '../../../actions/compose';
|
2016-09-06 00:56:43 +10:00
|
|
|
|
2017-04-24 08:38:37 +10:00
|
|
|
const mapStateToProps = state => ({
|
|
|
|
text: state.getIn(['compose', 'text']),
|
|
|
|
suggestions: state.getIn(['compose', 'suggestions']),
|
|
|
|
spoiler: state.getIn(['compose', 'spoiler']),
|
2019-04-22 22:55:24 +10:00
|
|
|
spoilerText: state.getIn(['compose', 'spoiler_text']),
|
2017-04-24 08:38:37 +10:00
|
|
|
privacy: state.getIn(['compose', 'privacy']),
|
|
|
|
focusDate: state.getIn(['compose', 'focusDate']),
|
2018-05-23 23:20:15 +10:00
|
|
|
caretPosition: state.getIn(['compose', 'caretPosition']),
|
2017-04-24 08:38:37 +10:00
|
|
|
preselectDate: state.getIn(['compose', 'preselectDate']),
|
2019-05-20 02:41:41 +10:00
|
|
|
isSubmitting: state.getIn(['compose', 'is_submitting']),
|
2022-02-10 10:15:30 +11:00
|
|
|
isEditing: state.getIn(['compose', 'id']) !== null,
|
2019-04-22 22:55:24 +10:00
|
|
|
isChangingUpload: state.getIn(['compose', 'is_changing_upload']),
|
|
|
|
isUploading: state.getIn(['compose', 'is_uploading']),
|
2017-05-21 01:31:47 +10:00
|
|
|
showSearch: state.getIn(['search', 'submitted']) && !state.getIn(['search', 'hidden']),
|
2018-03-07 18:28:52 +11:00
|
|
|
anyMedia: state.getIn(['compose', 'media_attachments']).size > 0,
|
2022-01-21 06:56:21 +11:00
|
|
|
isInReply: state.getIn(['compose', 'in_reply_to']) !== null,
|
2017-02-26 11:23:44 +11:00
|
|
|
});
|
|
|
|
|
2017-02-23 01:43:07 +11:00
|
|
|
const mapDispatchToProps = (dispatch) => ({
|
2016-09-01 00:15:12 +10:00
|
|
|
|
2017-02-23 01:43:07 +11:00
|
|
|
onChange (text) {
|
|
|
|
dispatch(changeCompose(text));
|
|
|
|
},
|
2016-09-01 06:58:10 +10:00
|
|
|
|
2018-10-11 10:31:03 +11:00
|
|
|
onSubmit (router) {
|
|
|
|
dispatch(submitCompose(router));
|
2017-02-23 01:43:07 +11:00
|
|
|
},
|
2016-10-31 04:13:05 +11:00
|
|
|
|
2017-02-23 01:43:07 +11:00
|
|
|
onClearSuggestions () {
|
|
|
|
dispatch(clearComposeSuggestions());
|
|
|
|
},
|
2016-10-31 04:13:05 +11:00
|
|
|
|
2017-02-23 01:43:07 +11:00
|
|
|
onFetchSuggestions (token) {
|
|
|
|
dispatch(fetchComposeSuggestions(token));
|
|
|
|
},
|
2016-11-13 00:33:21 +11:00
|
|
|
|
2019-05-10 06:10:27 +10:00
|
|
|
onSuggestionSelected (position, token, suggestion, path) {
|
|
|
|
dispatch(selectComposeSuggestion(position, token, suggestion, path));
|
2017-02-23 01:43:07 +11:00
|
|
|
},
|
2016-11-24 04:53:23 +11:00
|
|
|
|
2017-02-23 01:43:07 +11:00
|
|
|
onChangeSpoilerText (checked) {
|
|
|
|
dispatch(changeComposeSpoilerText(checked));
|
|
|
|
},
|
2017-01-13 15:54:26 +11:00
|
|
|
|
2017-03-01 21:56:15 +11:00
|
|
|
onPaste (files) {
|
|
|
|
dispatch(uploadCompose(files));
|
|
|
|
},
|
|
|
|
|
2018-04-17 21:50:33 +10:00
|
|
|
onPickEmoji (position, data, needsSpace) {
|
|
|
|
dispatch(insertEmojiCompose(position, data, needsSpace));
|
2017-03-02 10:57:55 +11:00
|
|
|
},
|
|
|
|
|
2017-02-23 01:43:07 +11:00
|
|
|
});
|
2016-08-26 03:52:55 +10:00
|
|
|
|
2017-02-23 01:43:07 +11:00
|
|
|
export default connect(mapStateToProps, mapDispatchToProps)(ComposeForm);
|