|
|
@ -77,6 +77,18 @@ class ComposeForm extends ImmutablePureComponent { |
|
|
|
} |
|
|
|
} |
|
|
|
} |
|
|
|
} |
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
getFulltextForCharacterCounting = () => { |
|
|
|
|
|
|
|
return [this.props.spoiler? this.props.spoilerText: '', countableText(this.props.text)].join(''); |
|
|
|
|
|
|
|
} |
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
canSubmit = () => { |
|
|
|
|
|
|
|
const { isSubmitting, isChangingUpload, isUploading, anyMedia } = this.props; |
|
|
|
|
|
|
|
const fulltext = this.getFulltextForCharacterCounting(); |
|
|
|
|
|
|
|
const isOnlyWhitespace = fulltext.length !== 0 && fulltext.trim().length === 0; |
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
return !(isSubmitting || isUploading || isChangingUpload || length(fulltext) > 500 || (isOnlyWhitespace && !anyMedia)); |
|
|
|
|
|
|
|
} |
|
|
|
|
|
|
|
|
|
|
|
handleSubmit = () => { |
|
|
|
handleSubmit = () => { |
|
|
|
if (this.props.text !== this.autosuggestTextarea.textarea.value) { |
|
|
|
if (this.props.text !== this.autosuggestTextarea.textarea.value) { |
|
|
|
// Something changed the text inside the textarea (e.g. browser extensions like Grammarly)
|
|
|
|
// Something changed the text inside the textarea (e.g. browser extensions like Grammarly)
|
|
|
@ -84,11 +96,7 @@ class ComposeForm extends ImmutablePureComponent { |
|
|
|
this.props.onChange(this.autosuggestTextarea.textarea.value); |
|
|
|
this.props.onChange(this.autosuggestTextarea.textarea.value); |
|
|
|
} |
|
|
|
} |
|
|
|
|
|
|
|
|
|
|
|
// Submit disabled:
|
|
|
|
if (!this.canSubmit()) { |
|
|
|
const { isSubmitting, isChangingUpload, isUploading, anyMedia } = this.props; |
|
|
|
|
|
|
|
const fulltext = [this.props.spoilerText, countableText(this.props.text)].join(''); |
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
if (isSubmitting || isUploading || isChangingUpload || length(fulltext) > 500 || (fulltext.length !== 0 && fulltext.trim().length === 0 && !anyMedia)) { |
|
|
|
|
|
|
|
return; |
|
|
|
return; |
|
|
|
} |
|
|
|
} |
|
|
|
|
|
|
|
|
|
|
@ -178,10 +186,8 @@ class ComposeForm extends ImmutablePureComponent { |
|
|
|
} |
|
|
|
} |
|
|
|
|
|
|
|
|
|
|
|
render () { |
|
|
|
render () { |
|
|
|
const { intl, onPaste, showSearch, anyMedia } = this.props; |
|
|
|
const { intl, onPaste, showSearch } = this.props; |
|
|
|
const disabled = this.props.isSubmitting; |
|
|
|
const disabled = this.props.isSubmitting; |
|
|
|
const text = [this.props.spoilerText, countableText(this.props.text)].join(''); |
|
|
|
|
|
|
|
const disabledButton = disabled || this.props.isUploading || this.props.isChangingUpload || length(text) > 500 || (text.length !== 0 && text.trim().length === 0 && !anyMedia); |
|
|
|
|
|
|
|
let publishText = ''; |
|
|
|
let publishText = ''; |
|
|
|
|
|
|
|
|
|
|
|
if (this.props.privacy === 'private' || this.props.privacy === 'direct') { |
|
|
|
if (this.props.privacy === 'private' || this.props.privacy === 'direct') { |
|
|
@ -243,11 +249,11 @@ class ComposeForm extends ImmutablePureComponent { |
|
|
|
<PrivacyDropdownContainer /> |
|
|
|
<PrivacyDropdownContainer /> |
|
|
|
<SpoilerButtonContainer /> |
|
|
|
<SpoilerButtonContainer /> |
|
|
|
</div> |
|
|
|
</div> |
|
|
|
<div className='character-counter__wrapper'><CharacterCounter max={500} text={text} /></div> |
|
|
|
<div className='character-counter__wrapper'><CharacterCounter max={500} text={this.getFulltextForCharacterCounting()} /></div> |
|
|
|
</div> |
|
|
|
</div> |
|
|
|
|
|
|
|
|
|
|
|
<div className='compose-form__publish'> |
|
|
|
<div className='compose-form__publish'> |
|
|
|
<div className='compose-form__publish-button-wrapper'><Button text={publishText} onClick={this.handleSubmit} disabled={disabledButton} block /></div> |
|
|
|
<div className='compose-form__publish-button-wrapper'><Button text={publishText} onClick={this.handleSubmit} disabled={!this.canSubmit()} block /></div> |
|
|
|
</div> |
|
|
|
</div> |
|
|
|
</div> |
|
|
|
</div> |
|
|
|
); |
|
|
|
); |
|
|
|