Change design of compose form in web UI (#28119)
Co-authored-by: Claire <claire.github-309c@sitedethib.com>
This commit is contained in:
		
					parent
					
						
							
								42ab855b23
							
						
					
				
			
			
				commit
				
					
						6936e5aa69
					
				
			
		
					 71 changed files with 1574 additions and 1790 deletions
				
			
		|  | @ -1,36 +0,0 @@ | |||
| import { defineMessages, injectIntl } from 'react-intl'; | ||||
| 
 | ||||
| import { connect }   from 'react-redux'; | ||||
| 
 | ||||
| import { openModal } from 'mastodon/actions/modal'; | ||||
| import { logOut } from 'mastodon/utils/log_out'; | ||||
| 
 | ||||
| import { me } from '../../../initial_state'; | ||||
| import NavigationBar from '../components/navigation_bar'; | ||||
| 
 | ||||
| const messages = defineMessages({ | ||||
|   logoutMessage: { id: 'confirmations.logout.message', defaultMessage: 'Are you sure you want to log out?' }, | ||||
|   logoutConfirm: { id: 'confirmations.logout.confirm', defaultMessage: 'Log out' }, | ||||
| }); | ||||
| 
 | ||||
| const mapStateToProps = state => { | ||||
|   return { | ||||
|     account: state.getIn(['accounts', me]), | ||||
|   }; | ||||
| }; | ||||
| 
 | ||||
| const mapDispatchToProps = (dispatch, { intl }) => ({ | ||||
|   onLogout () { | ||||
|     dispatch(openModal({ | ||||
|       modalType: 'CONFIRM', | ||||
|       modalProps: { | ||||
|         message: intl.formatMessage(messages.logoutMessage), | ||||
|         confirm: intl.formatMessage(messages.logoutConfirm), | ||||
|         closeWhenConfirm: false, | ||||
|         onConfirm: () => logOut(), | ||||
|       }, | ||||
|     })); | ||||
|   }, | ||||
| }); | ||||
| 
 | ||||
| export default injectIntl(connect(mapStateToProps, mapDispatchToProps)(NavigationBar)); | ||||
|  | @ -4,7 +4,7 @@ import { addPoll, removePoll } from '../../../actions/compose'; | |||
| import PollButton from '../components/poll_button'; | ||||
| 
 | ||||
| const mapStateToProps = state => ({ | ||||
|   unavailable: state.getIn(['compose', 'is_uploading']) || (state.getIn(['compose', 'media_attachments']).size > 0), | ||||
|   disabled: state.getIn(['compose', 'is_uploading']) || (state.getIn(['compose', 'media_attachments']).size > 0), | ||||
|   active: state.getIn(['compose', 'poll']) !== null, | ||||
| }); | ||||
| 
 | ||||
|  |  | |||
|  | @ -1,53 +0,0 @@ | |||
| import { connect } from 'react-redux'; | ||||
| 
 | ||||
| import { | ||||
|   addPollOption, | ||||
|   removePollOption, | ||||
|   changePollOption, | ||||
|   changePollSettings, | ||||
|   clearComposeSuggestions, | ||||
|   fetchComposeSuggestions, | ||||
|   selectComposeSuggestion, | ||||
| } from '../../../actions/compose'; | ||||
| import PollForm from '../components/poll_form'; | ||||
| 
 | ||||
| const mapStateToProps = state => ({ | ||||
|   suggestions: state.getIn(['compose', 'suggestions']), | ||||
|   options: state.getIn(['compose', 'poll', 'options']), | ||||
|   lang: state.getIn(['compose', 'language']), | ||||
|   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 () { | ||||
|     dispatch(clearComposeSuggestions()); | ||||
|   }, | ||||
| 
 | ||||
|   onFetchSuggestions (token) { | ||||
|     dispatch(fetchComposeSuggestions(token)); | ||||
|   }, | ||||
| 
 | ||||
|   onSuggestionSelected (position, token, accountId, path) { | ||||
|     dispatch(selectComposeSuggestion(position, token, accountId, path)); | ||||
|   }, | ||||
| 
 | ||||
| }); | ||||
| 
 | ||||
| export default connect(mapStateToProps, mapDispatchToProps)(PollForm); | ||||
|  | @ -1,36 +0,0 @@ | |||
| import { connect } from 'react-redux'; | ||||
| 
 | ||||
| import { cancelReplyCompose } from '../../../actions/compose'; | ||||
| import { makeGetStatus } from '../../../selectors'; | ||||
| import ReplyIndicator from '../components/reply_indicator'; | ||||
| 
 | ||||
| const makeMapStateToProps = () => { | ||||
|   const getStatus = makeGetStatus(); | ||||
| 
 | ||||
|   const mapStateToProps = state => { | ||||
|     let statusId = state.getIn(['compose', 'id'], null); | ||||
|     let editing  = true; | ||||
| 
 | ||||
|     if (statusId === null) { | ||||
|       statusId = state.getIn(['compose', 'in_reply_to']); | ||||
|       editing  = false; | ||||
|     } | ||||
| 
 | ||||
|     return { | ||||
|       status: getStatus(state, { id: statusId }), | ||||
|       editing, | ||||
|     }; | ||||
|   }; | ||||
| 
 | ||||
|   return mapStateToProps; | ||||
| }; | ||||
| 
 | ||||
| const mapDispatchToProps = dispatch => ({ | ||||
| 
 | ||||
|   onCancel () { | ||||
|     dispatch(cancelReplyCompose()); | ||||
|   }, | ||||
| 
 | ||||
| }); | ||||
| 
 | ||||
| export default connect(makeMapStateToProps, mapDispatchToProps)(ReplyIndicator); | ||||
|  | @ -1,73 +0,0 @@ | |||
| import PropTypes from 'prop-types'; | ||||
| import { PureComponent } from 'react'; | ||||
| 
 | ||||
| import { injectIntl, defineMessages, FormattedMessage } from 'react-intl'; | ||||
| 
 | ||||
| import classNames from 'classnames'; | ||||
| 
 | ||||
| import { connect } from 'react-redux'; | ||||
| 
 | ||||
| import { changeComposeSensitivity } from 'mastodon/actions/compose'; | ||||
| 
 | ||||
| const messages = defineMessages({ | ||||
|   marked: { | ||||
|     id: 'compose_form.sensitive.marked', | ||||
|     defaultMessage: '{count, plural, one {Media is marked as sensitive} other {Media is marked as sensitive}}', | ||||
|   }, | ||||
|   unmarked: { | ||||
|     id: 'compose_form.sensitive.unmarked', | ||||
|     defaultMessage: '{count, plural, one {Media is not marked as sensitive} other {Media is not marked as sensitive}}', | ||||
|   }, | ||||
| }); | ||||
| 
 | ||||
| const mapStateToProps = state => ({ | ||||
|   active: state.getIn(['compose', 'sensitive']), | ||||
|   disabled: state.getIn(['compose', 'spoiler']), | ||||
|   mediaCount: state.getIn(['compose', 'media_attachments']).size, | ||||
| }); | ||||
| 
 | ||||
| const mapDispatchToProps = dispatch => ({ | ||||
| 
 | ||||
|   onClick () { | ||||
|     dispatch(changeComposeSensitivity()); | ||||
|   }, | ||||
| 
 | ||||
| }); | ||||
| 
 | ||||
| class SensitiveButton extends PureComponent { | ||||
| 
 | ||||
|   static propTypes = { | ||||
|     active: PropTypes.bool, | ||||
|     disabled: PropTypes.bool, | ||||
|     mediaCount: PropTypes.number, | ||||
|     onClick: PropTypes.func.isRequired, | ||||
|     intl: PropTypes.object.isRequired, | ||||
|   }; | ||||
| 
 | ||||
|   render () { | ||||
|     const { active, disabled, mediaCount, onClick, intl } = this.props; | ||||
| 
 | ||||
|     return ( | ||||
|       <div className='compose-form__sensitive-button'> | ||||
|         <label className={classNames('icon-button', { active })} title={intl.formatMessage(active ? messages.marked : messages.unmarked, { count: mediaCount })}> | ||||
|           <input | ||||
|             name='mark-sensitive' | ||||
|             type='checkbox' | ||||
|             checked={active} | ||||
|             onChange={onClick} | ||||
|             disabled={disabled} | ||||
|           /> | ||||
| 
 | ||||
|           <FormattedMessage | ||||
|             id='compose_form.sensitive.hide' | ||||
|             defaultMessage='{count, plural, one {Mark media as sensitive} other {Mark media as sensitive}}' | ||||
|             values={{ count: mediaCount }} | ||||
|           /> | ||||
|         </label> | ||||
|       </div> | ||||
|     ); | ||||
|   } | ||||
| 
 | ||||
| } | ||||
| 
 | ||||
| export default connect(mapStateToProps, mapDispatchToProps)(injectIntl(SensitiveButton)); | ||||
|  | @ -2,8 +2,10 @@ import { injectIntl, defineMessages } from 'react-intl'; | |||
| 
 | ||||
| import { connect } from 'react-redux'; | ||||
| 
 | ||||
| import WarningIcon from 'mastodon/../material-icons/400-24px/warning.svg?react'; | ||||
| import { IconButton } from 'mastodon/components/icon_button'; | ||||
| 
 | ||||
| import { changeComposeSpoilerness } from '../../../actions/compose'; | ||||
| import TextIconButton from '../components/text_icon_button'; | ||||
| 
 | ||||
| const messages = defineMessages({ | ||||
|   marked: { id: 'compose_form.spoiler.marked', defaultMessage: 'Text is hidden behind warning' }, | ||||
|  | @ -11,10 +13,12 @@ const messages = defineMessages({ | |||
| }); | ||||
| 
 | ||||
| const mapStateToProps = (state, { intl }) => ({ | ||||
|   label: 'CW', | ||||
|   iconComponent: WarningIcon, | ||||
|   title: intl.formatMessage(state.getIn(['compose', 'spoiler']) ? messages.marked : messages.unmarked), | ||||
|   active: state.getIn(['compose', 'spoiler']), | ||||
|   ariaControls: 'cw-spoiler-input', | ||||
|   size: 18, | ||||
|   inverted: true, | ||||
| }); | ||||
| 
 | ||||
| const mapDispatchToProps = dispatch => ({ | ||||
|  | @ -25,4 +29,4 @@ const mapDispatchToProps = dispatch => ({ | |||
| 
 | ||||
| }); | ||||
| 
 | ||||
| export default injectIntl(connect(mapStateToProps, mapDispatchToProps)(TextIconButton)); | ||||
| export default injectIntl(connect(mapStateToProps, mapDispatchToProps)(IconButton)); | ||||
|  |  | |||
|  | @ -4,8 +4,7 @@ import { uploadCompose } from '../../../actions/compose'; | |||
| import UploadButton from '../components/upload_button'; | ||||
| 
 | ||||
| const mapStateToProps = state => ({ | ||||
|   disabled: state.getIn(['compose', 'is_uploading']) || (state.getIn(['compose', 'media_attachments']).size + state.getIn(['compose', 'pending_media_attachments']) > 3 || state.getIn(['compose', 'media_attachments']).some(m => ['video', 'audio'].includes(m.get('type')))), | ||||
|   unavailable: state.getIn(['compose', 'poll']) !== null, | ||||
|   disabled: state.getIn(['compose', 'poll']) !== null || state.getIn(['compose', 'is_uploading']) || (state.getIn(['compose', 'media_attachments']).size + state.getIn(['compose', 'pending_media_attachments']) > 3 || state.getIn(['compose', 'media_attachments']).some(m => ['video', 'audio'].includes(m.get('type')))), | ||||
|   resetFileKey: state.getIn(['compose', 'resetFileKey']), | ||||
| }); | ||||
| 
 | ||||
|  |  | |||
|  | @ -5,6 +5,7 @@ import Upload from '../components/upload'; | |||
| 
 | ||||
| const mapStateToProps = (state, { id }) => ({ | ||||
|   media: state.getIn(['compose', 'media_attachments']).find(item => item.get('id') === id), | ||||
|   sensitive: state.getIn(['compose', 'spoiler']), | ||||
| }); | ||||
| 
 | ||||
| const mapDispatchToProps = dispatch => ({ | ||||
|  |  | |||
		Loading…
	
	Add table
		Add a link
		
	
		Reference in a new issue