2021-07-01 14:10:03 -07:00
|
|
|
import { injectIntl } from 'react-intl';
|
2022-01-10 14:17:52 -08:00
|
|
|
import { connect } from 'react-redux';
|
2022-01-10 14:25:06 -08:00
|
|
|
|
2022-03-04 10:47:59 -08:00
|
|
|
import { getFeatures } from 'soapbox/utils/features';
|
|
|
|
|
2020-03-27 13:59:38 -07:00
|
|
|
import {
|
|
|
|
changeCompose,
|
|
|
|
submitCompose,
|
|
|
|
clearComposeSuggestions,
|
|
|
|
fetchComposeSuggestions,
|
|
|
|
selectComposeSuggestion,
|
|
|
|
changeComposeSpoilerText,
|
|
|
|
insertEmojiCompose,
|
|
|
|
uploadCompose,
|
|
|
|
} from '../../../actions/compose';
|
2022-01-10 14:17:52 -08:00
|
|
|
import ComposeForm from '../components/compose_form';
|
2020-03-27 13:59:38 -07:00
|
|
|
|
2022-03-04 10:47:59 -08:00
|
|
|
const mapStateToProps = state => {
|
|
|
|
const instance = state.get('instance');
|
|
|
|
|
|
|
|
return {
|
|
|
|
text: state.getIn(['compose', 'text']),
|
|
|
|
suggestions: state.getIn(['compose', 'suggestions']),
|
|
|
|
spoiler: state.getIn(['compose', 'spoiler']),
|
|
|
|
spoilerText: state.getIn(['compose', 'spoiler_text']),
|
|
|
|
privacy: state.getIn(['compose', 'privacy']),
|
|
|
|
focusDate: state.getIn(['compose', 'focusDate']),
|
|
|
|
caretPosition: state.getIn(['compose', 'caretPosition']),
|
|
|
|
isSubmitting: state.getIn(['compose', 'is_submitting']),
|
|
|
|
isChangingUpload: state.getIn(['compose', 'is_changing_upload']),
|
|
|
|
isUploading: state.getIn(['compose', 'is_uploading']),
|
|
|
|
showSearch: state.getIn(['search', 'submitted']) && !state.getIn(['search', 'hidden']),
|
|
|
|
anyMedia: state.getIn(['compose', 'media_attachments']).size > 0,
|
2022-03-21 11:09:01 -07:00
|
|
|
isModalOpen: Boolean(state.get('modals').size && state.get('modals').last().modalType === 'COMPOSE'),
|
2022-03-04 10:47:59 -08:00
|
|
|
maxTootChars: state.getIn(['instance', 'configuration', 'statuses', 'max_characters']),
|
|
|
|
scheduledAt: state.getIn(['compose', 'schedule']),
|
|
|
|
scheduledStatusCount: state.get('scheduled_statuses').size,
|
|
|
|
features: getFeatures(instance),
|
|
|
|
};
|
|
|
|
};
|
2020-03-27 13:59:38 -07:00
|
|
|
|
2022-03-30 07:36:01 -07:00
|
|
|
const mapDispatchToProps = (dispatch, { intl }) => ({
|
2020-03-27 13:59:38 -07:00
|
|
|
|
2020-04-14 14:47:35 -07:00
|
|
|
onChange(text) {
|
2020-03-27 13:59:38 -07:00
|
|
|
dispatch(changeCompose(text));
|
|
|
|
},
|
|
|
|
|
2020-04-14 14:47:35 -07:00
|
|
|
onSubmit(router, group) {
|
2020-03-27 13:59:38 -07:00
|
|
|
dispatch(submitCompose(router, group));
|
|
|
|
},
|
|
|
|
|
2020-04-14 14:47:35 -07:00
|
|
|
onClearSuggestions() {
|
2020-03-27 13:59:38 -07:00
|
|
|
dispatch(clearComposeSuggestions());
|
|
|
|
},
|
|
|
|
|
2020-04-14 14:47:35 -07:00
|
|
|
onFetchSuggestions(token) {
|
2020-03-27 13:59:38 -07:00
|
|
|
dispatch(fetchComposeSuggestions(token));
|
|
|
|
},
|
|
|
|
|
2020-04-14 14:47:35 -07:00
|
|
|
onSuggestionSelected(position, token, suggestion, path) {
|
2020-03-27 13:59:38 -07:00
|
|
|
dispatch(selectComposeSuggestion(position, token, suggestion, path));
|
|
|
|
},
|
|
|
|
|
2020-04-14 14:47:35 -07:00
|
|
|
onChangeSpoilerText(checked) {
|
2020-03-27 13:59:38 -07:00
|
|
|
dispatch(changeComposeSpoilerText(checked));
|
|
|
|
},
|
|
|
|
|
2020-04-14 14:47:35 -07:00
|
|
|
onPaste(files) {
|
2022-03-30 07:36:01 -07:00
|
|
|
dispatch(uploadCompose(files, intl));
|
2020-03-27 13:59:38 -07:00
|
|
|
},
|
|
|
|
|
2020-04-14 14:47:35 -07:00
|
|
|
onPickEmoji(position, data, needsSpace) {
|
2020-03-27 13:59:38 -07:00
|
|
|
dispatch(insertEmojiCompose(position, data, needsSpace));
|
|
|
|
},
|
|
|
|
|
|
|
|
});
|
|
|
|
|
|
|
|
function mergeProps(stateProps, dispatchProps, ownProps) {
|
|
|
|
return Object.assign({}, ownProps, {
|
|
|
|
...stateProps,
|
2020-04-14 11:44:40 -07:00
|
|
|
...dispatchProps,
|
|
|
|
});
|
2020-03-27 13:59:38 -07:00
|
|
|
}
|
|
|
|
|
2021-07-01 14:10:03 -07:00
|
|
|
export default injectIntl(connect(mapStateToProps, mapDispatchToProps, mergeProps)(ComposeForm));
|