bigbuffet-rw/app/soapbox/features/compose/containers/compose_form_container.js

88 lines
2.6 KiB
JavaScript
Raw Normal View History

import { injectIntl } from 'react-intl';
import { connect } from 'react-redux';
2020-03-27 13:59:38 -07:00
import {
changeCompose,
submitCompose,
clearComposeSuggestions,
fetchComposeSuggestions,
selectComposeSuggestion,
changeComposeSpoilerText,
insertEmojiCompose,
uploadCompose,
} from 'soapbox/actions/compose';
import { getFeatures } from 'soapbox/utils/features';
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']),
2022-06-06 11:53:09 -07:00
hasPoll: !!state.getIn(['compose', 'poll']),
2022-03-04 10:47:59 -08:00
isSubmitting: state.getIn(['compose', 'is_submitting']),
isEditing: state.getIn(['compose', 'id']) !== null,
2022-03-04 10:47:59 -08:00
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
onChange(text) {
2020-03-27 13:59:38 -07:00
dispatch(changeCompose(text));
},
onSubmit(router, group) {
2020-03-27 13:59:38 -07:00
dispatch(submitCompose(router, group));
},
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, suggestion, path) {
2020-03-27 13:59:38 -07:00
dispatch(selectComposeSuggestion(position, token, suggestion, path));
},
onChangeSpoilerText(checked) {
2020-03-27 13:59:38 -07:00
dispatch(changeComposeSpoilerText(checked));
},
onPaste(files) {
2022-03-30 07:36:01 -07:00
dispatch(uploadCompose(files, intl));
2020-03-27 13:59:38 -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
}
export default injectIntl(connect(mapStateToProps, mapDispatchToProps, mergeProps)(ComposeForm));