signal-desktop/ts/components/CompositionUpload.tsx

62 lines
1.6 KiB
TypeScript
Raw Normal View History

2021-09-24 20:02:30 +00:00
// Copyright 2021 Signal Messenger, LLC
// SPDX-License-Identifier: AGPL-3.0-only
import type { ChangeEventHandler } from 'react';
import React, { forwardRef } from 'react';
2021-09-24 20:02:30 +00:00
import type { AttachmentDraftType } from '../types/Attachment';
import { isVideoAttachment, isImageAttachment } from '../types/Attachment';
import type { LocalizerType } from '../types/Util';
2021-09-24 20:02:30 +00:00
import {
getSupportedImageTypes,
getSupportedVideoTypes,
} from '../util/GoogleChrome';
2021-09-24 20:02:30 +00:00
export type PropsType = {
conversationId: string;
draftAttachments: ReadonlyArray<AttachmentDraftType>;
2021-09-24 20:02:30 +00:00
i18n: LocalizerType;
processAttachments: (options: {
conversationId: string;
files: ReadonlyArray<File>;
}) => unknown;
2021-09-24 20:02:30 +00:00
};
export const CompositionUpload = forwardRef<HTMLInputElement, PropsType>(
2022-11-18 00:45:19 +00:00
function CompositionUploadInner(
{ conversationId, draftAttachments, processAttachments },
2021-09-24 20:02:30 +00:00
ref
2022-11-18 00:45:19 +00:00
) {
2022-03-22 20:45:34 +00:00
const onFileInputChange: ChangeEventHandler<
HTMLInputElement
> = async event => {
const files = event.target.files || [];
2021-09-24 20:02:30 +00:00
2022-03-22 20:45:34 +00:00
await processAttachments({
conversationId,
files: Array.from(files),
});
};
2021-09-24 20:02:30 +00:00
const anyVideoOrImageAttachments = draftAttachments.some(attachment => {
return isImageAttachment(attachment) || isVideoAttachment(attachment);
});
const acceptContentTypes = anyVideoOrImageAttachments
? [...getSupportedImageTypes(), ...getSupportedVideoTypes()]
: null;
2021-09-24 20:02:30 +00:00
return (
<input
hidden
multiple
onChange={onFileInputChange}
ref={ref}
type="file"
accept={acceptContentTypes?.join(',')}
/>
2021-09-24 20:02:30 +00:00
);
}
);