Chats: allow files to be removed before sending

This commit is contained in:
Alex Gleason 2020-09-06 17:09:06 -05:00
parent 49d2121017
commit a02155846d
No known key found for this signature in database
GPG key ID: 7211D1F99744FBB7
2 changed files with 35 additions and 3 deletions

View file

@ -13,6 +13,8 @@ import ChatMessageList from './chat_message_list';
import UploadButton from 'soapbox/features/compose/components/upload_button';
import { uploadMedia } from 'soapbox/actions/media';
import UploadProgress from 'soapbox/features/compose/components/upload_progress';
import { truncateFilename } from 'soapbox/utils/media';
import IconButton from 'soapbox/components/icon_button';
const messages = defineMessages({
placeholder: { id: 'chat_box.input.placeholder', defaultMessage: 'Send a message…' },
@ -24,6 +26,8 @@ const mapStateToProps = (state, { chatId }) => ({
chatMessageIds: state.getIn(['chat_message_lists', chatId], ImmutableOrderedSet()),
});
const fileKeyGen = () => Math.floor((Math.random() * 0x10000));
export default @connect(mapStateToProps)
@injectIntl
class ChatBox extends ImmutablePureComponent {
@ -43,6 +47,7 @@ class ChatBox extends ImmutablePureComponent {
attachment: undefined,
isUploading: false,
uploadProgress: 0,
resetFileKey: fileKeyGen(),
})
state = this.initialState()
@ -122,6 +127,10 @@ class ChatBox extends ImmutablePureComponent {
this.markRead();
}
handleRemoveFile = (e) => {
this.setState({ attachment: undefined, resetFileKey: fileKeyGen() });
}
onUploadProgress = (e) => {
const { loaded, total } = e;
this.setState({ uploadProgress: loaded/total });
@ -148,14 +157,19 @@ class ChatBox extends ImmutablePureComponent {
return (
<div className='chat-box__attachment'>
{attachment.preview_url}
<div className='chat-box__filename'>
{truncateFilename(attachment.preview_url, 20)}
</div>
<div class='chat-box__remove-attachment'>
<IconButton icon='remove' onClick={this.handleRemoveFile} />
</div>
</div>
);
}
render() {
const { chatMessageIds, chatId, intl } = this.props;
const { content, isUploading, uploadProgress } = this.state;
const { content, isUploading, uploadProgress, resetFileKey } = this.state;
if (!chatMessageIds) return null;
return (
@ -164,7 +178,7 @@ class ChatBox extends ImmutablePureComponent {
{this.renderAttachment()}
<UploadProgress active={isUploading} progress={uploadProgress*100} />
<div className='chat-box__actions simple_form'>
<UploadButton onSelectFile={this.handleFiles} />
<UploadButton onSelectFile={this.handleFiles} resetFileKey={resetFileKey} />
<textarea
rows={1}
placeholder={intl.formatMessage(messages.placeholder)}

View file

@ -184,6 +184,7 @@
.upload-progress {
padding: 0 10px;
align-items: center;
height: 25px;
.fa {
font-size: 22px;
@ -200,6 +201,23 @@
}
}
&__attachment {
display: flex;
align-items: center;
font-size: 13px;
padding: 0 10px;
height: 25px;
.chat-box__remove-attachment {
margin-left: auto;
.icon-button > div {
display: flex;
align-items: center;
}
}
}
&__actions {
background: var(--foreground-color);
margin-top: auto;