2019-05-21 17:18:11 -04:00
|
|
|
// @flow
|
|
|
|
import React, { useRef } from 'react';
|
|
|
|
import { Modal } from 'modal/modal';
|
2019-12-02 12:30:08 -05:00
|
|
|
import { formatFileSystemPath } from 'util/url';
|
2019-05-21 17:18:11 -04:00
|
|
|
|
|
|
|
type Props = {
|
2022-09-02 12:43:35 -04:00
|
|
|
upload: (File) => void,
|
2019-05-21 17:18:11 -04:00
|
|
|
filePath: string,
|
|
|
|
closeModal: () => void,
|
|
|
|
showToast: ({}) => void,
|
|
|
|
};
|
|
|
|
|
|
|
|
function ModalAutoGenerateThumbnail(props: Props) {
|
|
|
|
const { closeModal, filePath, upload, showToast } = props;
|
|
|
|
const playerRef = useRef();
|
2019-10-07 16:02:32 -04:00
|
|
|
let videoSrc;
|
|
|
|
if (typeof filePath === 'string') {
|
2019-12-02 12:30:08 -05:00
|
|
|
videoSrc = formatFileSystemPath(filePath);
|
2019-10-07 16:02:32 -04:00
|
|
|
} else {
|
|
|
|
videoSrc = URL.createObjectURL(filePath);
|
|
|
|
}
|
2019-05-21 17:18:11 -04:00
|
|
|
|
|
|
|
function uploadImage() {
|
|
|
|
const imageBuffer = captureSnapshot();
|
2019-11-22 16:13:00 -05:00
|
|
|
// $FlowFixMe
|
2019-10-07 16:02:32 -04:00
|
|
|
const file = new File([imageBuffer], 'thumbnail.png', { type: 'image/png' });
|
2019-11-22 16:13:00 -05:00
|
|
|
|
2019-05-21 17:18:11 -04:00
|
|
|
if (imageBuffer) {
|
2019-11-22 16:13:00 -05:00
|
|
|
// $FlowFixMe
|
2019-10-07 16:02:32 -04:00
|
|
|
upload(file);
|
2019-05-21 17:18:11 -04:00
|
|
|
closeModal();
|
|
|
|
} else {
|
|
|
|
onError();
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
function captureSnapshot(): ?Buffer {
|
|
|
|
const player = playerRef.current;
|
|
|
|
if (!player) {
|
|
|
|
return;
|
|
|
|
}
|
|
|
|
|
|
|
|
const canvas = document.createElement('canvas');
|
|
|
|
canvas.width = player.videoWidth;
|
|
|
|
canvas.height = player.videoHeight;
|
|
|
|
const context = canvas.getContext('2d');
|
|
|
|
context.drawImage(player, 0, 0, canvas.width, canvas.height);
|
|
|
|
const dataURL = canvas.toDataURL();
|
|
|
|
const rawData = dataURL.replace(/data:image\/\w+;base64,/i, '');
|
|
|
|
canvas.remove();
|
|
|
|
return Buffer.from(rawData, 'base64');
|
|
|
|
}
|
|
|
|
|
|
|
|
function resize(): void {
|
|
|
|
const player = playerRef.current;
|
|
|
|
if (!player) {
|
|
|
|
return;
|
|
|
|
}
|
|
|
|
|
|
|
|
const fixedWidth = 450;
|
|
|
|
const videoWidth = player.videoWidth;
|
|
|
|
const videoHeight = player.videoHeight;
|
|
|
|
player.width = fixedWidth;
|
|
|
|
player.height = Math.floor(videoHeight * (fixedWidth / videoWidth));
|
|
|
|
}
|
|
|
|
|
|
|
|
function onError(): void {
|
|
|
|
showToast({ isError: true, message: __("Something didn't work. Please try again.") });
|
|
|
|
}
|
|
|
|
|
|
|
|
return (
|
|
|
|
<Modal
|
|
|
|
isOpen
|
2020-08-26 16:28:33 -04:00
|
|
|
title={__('Upload thumbnail')}
|
2019-05-21 17:18:11 -04:00
|
|
|
contentLabel={__('Confirm Thumbnail Upload')}
|
|
|
|
type="confirm"
|
|
|
|
confirmButtonLabel={__('Upload')}
|
|
|
|
onConfirmed={uploadImage}
|
|
|
|
onAborted={closeModal}
|
|
|
|
>
|
2019-11-22 16:13:00 -05:00
|
|
|
<p className="section__subtitle">{__('Pause at any time to select a thumbnail from your video')}.</p>
|
2019-07-21 17:31:22 -04:00
|
|
|
<video ref={playerRef} src={videoSrc} onLoadedMetadata={resize} onError={onError} controls />
|
2019-05-21 17:18:11 -04:00
|
|
|
</Modal>
|
|
|
|
);
|
|
|
|
}
|
|
|
|
|
|
|
|
export default ModalAutoGenerateThumbnail;
|