bigbuffet-rw/app/soapbox/features/ui/components/upload-area.tsx

74 lines
2.2 KiB
TypeScript
Raw Normal View History

import clsx from 'clsx';
import React from 'react';
2020-03-27 13:59:38 -07:00
import { FormattedMessage } from 'react-intl';
2022-05-01 10:46:06 -07:00
import { spring } from 'react-motion';
2022-03-21 11:09:01 -07:00
import { Icon, Stack, Text } from 'soapbox/components/ui';
2020-03-27 13:59:38 -07:00
2022-11-16 05:32:32 -08:00
import Motion from '../util/optional-motion';
2020-03-27 13:59:38 -07:00
2022-05-01 10:46:06 -07:00
interface IUploadArea {
/** Whether the upload area is active. */
active: boolean,
/** Callback when the upload area is closed. */
onClose: () => void,
}
/** Component to display when a file is dragged over the UI. */
const UploadArea: React.FC<IUploadArea> = ({ active, onClose }) => {
const handleKeyUp = (e: KeyboardEvent) => {
2020-03-27 13:59:38 -07:00
const keyCode = e.keyCode;
2022-03-21 11:09:01 -07:00
if (active) {
switch (keyCode) {
2022-05-11 14:06:35 -07:00
case 27:
e.preventDefault();
e.stopPropagation();
onClose();
break;
2020-03-27 13:59:38 -07:00
}
}
2022-03-21 11:09:01 -07:00
};
React.useEffect(() => {
window.addEventListener('keyup', handleKeyUp, false);
return () => window.removeEventListener('keyup', handleKeyUp);
}, []);
return (
<Motion
defaultStyle={{ backgroundOpacity: 0, backgroundScale: 0.95 }}
style={{ backgroundOpacity: spring(active ? 1 : 0, { stiffness: 150, damping: 15 }), backgroundScale: spring(active ? 1 : 0.95, { stiffness: 200, damping: 3 }) }}
>
{({ backgroundOpacity, backgroundScale }) => (
<div
className={clsx({
'flex items-center justify-center bg-gray-700/90 h-full w-full absolute left-0 top-0 z-1000 pointer-events-none': true,
2022-03-21 11:09:01 -07:00
'visible': active,
'invisible': !active,
})}
style={{ opacity: backgroundOpacity }}
>
2023-02-01 14:13:42 -08:00
<div className='relative flex h-40 w-80 p-2'>
2022-03-21 11:09:01 -07:00
<div className='absolute inset-0' style={{ transform: `scale(${backgroundScale})` }} />
<Stack space={3} justifyContent='center' alignItems='center'>
<Icon
src={require('@tabler/icons/cloud-upload.svg')}
className='h-12 w-12 text-white/90'
2022-03-21 11:09:01 -07:00
/>
<Text size='xl' theme='white'>
<FormattedMessage id='upload_area.title' defaultMessage='Drag & drop to upload' />
</Text>
</Stack>
2020-03-27 13:59:38 -07:00
</div>
2022-03-21 11:09:01 -07:00
</div>
)}
</Motion>
);
};
export default UploadArea;