Add new onboarding flow to web UI (#24619)
This commit is contained in:
		
					parent
					
						
							
								9d75b03ba4
							
						
					
				
			
			
				commit
				
					
						0461f83320
					
				
			
		
					 23 changed files with 1019 additions and 357 deletions
				
			
		|  | @ -20,6 +20,7 @@ import ImmutablePureComponent from 'react-immutable-pure-component'; | |||
| import { length } from 'stringz'; | ||||
| import { countableText } from '../util/counter'; | ||||
| import Icon from 'mastodon/components/icon'; | ||||
| import classNames from 'classnames'; | ||||
| 
 | ||||
| const allowedAroundShortCode = '><\u0085\u0020\u00a0\u1680\u2000\u2001\u2002\u2003\u2004\u2005\u2006\u2007\u2008\u2009\u200a\u202f\u205f\u3000\u2028\u2029\u0009\u000a\u000b\u000c\u000d'; | ||||
| 
 | ||||
|  | @ -70,6 +71,10 @@ class ComposeForm extends ImmutablePureComponent { | |||
|     autoFocus: false, | ||||
|   }; | ||||
| 
 | ||||
|   state = { | ||||
|     highlighted: false, | ||||
|   }; | ||||
| 
 | ||||
|   handleChange = (e) => { | ||||
|     this.props.onChange(e.target.value); | ||||
|   }; | ||||
|  | @ -143,6 +148,10 @@ class ComposeForm extends ImmutablePureComponent { | |||
|     this._updateFocusAndSelection({ }); | ||||
|   } | ||||
| 
 | ||||
|   componentWillUnmount () { | ||||
|     if (this.timeout) clearTimeout(this.timeout); | ||||
|   } | ||||
| 
 | ||||
|   componentDidUpdate (prevProps) { | ||||
|     this._updateFocusAndSelection(prevProps); | ||||
|   } | ||||
|  | @ -173,6 +182,8 @@ class ComposeForm extends ImmutablePureComponent { | |||
|       Promise.resolve().then(() => { | ||||
|         this.autosuggestTextarea.textarea.setSelectionRange(selectionStart, selectionEnd); | ||||
|         this.autosuggestTextarea.textarea.focus(); | ||||
|         this.setState({ highlighted: true }); | ||||
|         this.timeout = setTimeout(() => this.setState({ highlighted: false }), 700); | ||||
|       }).catch(console.error); | ||||
|     } else if(prevProps.isSubmitting && !this.props.isSubmitting) { | ||||
|       this.autosuggestTextarea.textarea.focus(); | ||||
|  | @ -207,6 +218,7 @@ class ComposeForm extends ImmutablePureComponent { | |||
| 
 | ||||
|   render () { | ||||
|     const { intl, onPaste, autoFocus } = this.props; | ||||
|     const { highlighted } = this.state; | ||||
|     const disabled = this.props.isSubmitting; | ||||
| 
 | ||||
|     let publishText = ''; | ||||
|  | @ -245,41 +257,43 @@ class ComposeForm extends ImmutablePureComponent { | |||
|           /> | ||||
|         </div> | ||||
| 
 | ||||
|         <AutosuggestTextarea | ||||
|           ref={this.setAutosuggestTextarea} | ||||
|           placeholder={intl.formatMessage(messages.placeholder)} | ||||
|           disabled={disabled} | ||||
|           value={this.props.text} | ||||
|           onChange={this.handleChange} | ||||
|           suggestions={this.props.suggestions} | ||||
|           onFocus={this.handleFocus} | ||||
|           onKeyDown={this.handleKeyDown} | ||||
|           onSuggestionsFetchRequested={this.onSuggestionsFetchRequested} | ||||
|           onSuggestionsClearRequested={this.onSuggestionsClearRequested} | ||||
|           onSuggestionSelected={this.onSuggestionSelected} | ||||
|           onPaste={onPaste} | ||||
|           autoFocus={autoFocus} | ||||
|           lang={this.props.lang} | ||||
|         > | ||||
|           <EmojiPickerDropdown onPickEmoji={this.handleEmojiPick} /> | ||||
|         <div className={classNames('compose-form__highlightable', { active: highlighted })}> | ||||
|           <AutosuggestTextarea | ||||
|             ref={this.setAutosuggestTextarea} | ||||
|             placeholder={intl.formatMessage(messages.placeholder)} | ||||
|             disabled={disabled} | ||||
|             value={this.props.text} | ||||
|             onChange={this.handleChange} | ||||
|             suggestions={this.props.suggestions} | ||||
|             onFocus={this.handleFocus} | ||||
|             onKeyDown={this.handleKeyDown} | ||||
|             onSuggestionsFetchRequested={this.onSuggestionsFetchRequested} | ||||
|             onSuggestionsClearRequested={this.onSuggestionsClearRequested} | ||||
|             onSuggestionSelected={this.onSuggestionSelected} | ||||
|             onPaste={onPaste} | ||||
|             autoFocus={autoFocus} | ||||
|             lang={this.props.lang} | ||||
|           > | ||||
|             <EmojiPickerDropdown onPickEmoji={this.handleEmojiPick} /> | ||||
| 
 | ||||
|           <div className='compose-form__modifiers'> | ||||
|             <UploadFormContainer /> | ||||
|             <PollFormContainer /> | ||||
|           </div> | ||||
|         </AutosuggestTextarea> | ||||
|             <div className='compose-form__modifiers'> | ||||
|               <UploadFormContainer /> | ||||
|               <PollFormContainer /> | ||||
|             </div> | ||||
|           </AutosuggestTextarea> | ||||
| 
 | ||||
|         <div className='compose-form__buttons-wrapper'> | ||||
|           <div className='compose-form__buttons'> | ||||
|             <UploadButtonContainer /> | ||||
|             <PollButtonContainer /> | ||||
|             <PrivacyDropdownContainer disabled={this.props.isEditing} /> | ||||
|             <SpoilerButtonContainer /> | ||||
|             <LanguageDropdown /> | ||||
|           </div> | ||||
|           <div className='compose-form__buttons-wrapper'> | ||||
|             <div className='compose-form__buttons'> | ||||
|               <UploadButtonContainer /> | ||||
|               <PollButtonContainer /> | ||||
|               <PrivacyDropdownContainer disabled={this.props.isEditing} /> | ||||
|               <SpoilerButtonContainer /> | ||||
|               <LanguageDropdown /> | ||||
|             </div> | ||||
| 
 | ||||
|           <div className='character-counter__wrapper'> | ||||
|             <CharacterCounter max={500} text={this.getFulltextForCharacterCounting()} /> | ||||
|             <div className='character-counter__wrapper'> | ||||
|               <CharacterCounter max={500} text={this.getFulltextForCharacterCounting()} /> | ||||
|             </div> | ||||
|           </div> | ||||
|         </div> | ||||
| 
 | ||||
|  |  | |||
		Loading…
	
	Add table
		Add a link
		
	
		Reference in a new issue