import React, { useCallback, useRef } from 'react'; import { WithTranslation } from 'react-i18next'; import { makeStyles } from 'tss-react/mui'; import { v4 as uuidv4 } from 'uuid'; import { translate } from '../../base/i18n/functions'; import Icon from '../../base/icons/components/Icon'; import { IconPlus } from '../../base/icons/svg'; import { withPixelLineHeight } from '../../base/styles/functions.web'; import { type Image, VIRTUAL_BACKGROUND_TYPE } from '../constants'; import { resizeImage } from '../functions'; import logger from '../logger'; interface IProps extends WithTranslation { /** * Callback used to set the 'loading' state of the parent component. */ setLoading: Function; /** * Callback used to set the options. */ setOptions: Function; /** * Callback used to set the storedImages array. */ setStoredImages: Function; /** * If a label should be displayed alongside the button. */ showLabel: boolean; /** * A list of images locally stored. */ storedImages: Array; } const useStyles = makeStyles()(theme => { return { label: { ...withPixelLineHeight(theme.typography.bodyShortBold), color: theme.palette.link01, marginBottom: theme.spacing(3), cursor: 'pointer', display: 'flex', alignItems: 'center' }, addBackground: { marginRight: theme.spacing(3), '& svg': { fill: `${theme.palette.link01} !important` } }, input: { display: 'none' } }; }); /** * Component used to upload an image. * * @param {Object} Props - The props of the component. * @returns {React$Node} */ function UploadImageButton({ setLoading, setOptions, setStoredImages, showLabel, storedImages, t }: IProps) { const { classes } = useStyles(); const uploadImageButton = useRef(null); const uploadImageKeyPress = useCallback(e => { if (uploadImageButton.current && (e.key === ' ' || e.key === 'Enter')) { e.preventDefault(); uploadImageButton.current.click(); } }, [ uploadImageButton.current ]); const uploadImage = useCallback(async e => { const reader = new FileReader(); const imageFile = e.target.files; reader.readAsDataURL(imageFile[0]); reader.onload = async () => { const url = await resizeImage(reader.result); const uuId = uuidv4(); setStoredImages([ ...storedImages, { id: uuId, src: url } ]); setOptions({ backgroundType: VIRTUAL_BACKGROUND_TYPE.IMAGE, enabled: true, url, selectedThumbnail: uuId }); }; logger.info('New virtual background image uploaded!'); reader.onerror = () => { setLoading(false); logger.error('Failed to upload virtual image!'); }; }, [ storedImages ]); return ( <> {showLabel && } ); } export default translate(UploadImageButton);