2022-08-31 02:35:06 -07:00
|
|
|
import classNames from 'clsx';
|
2022-04-10 03:46:25 -07:00
|
|
|
import React from 'react';
|
|
|
|
|
|
|
|
import { useAppSelector } from 'soapbox/hooks';
|
|
|
|
|
2022-06-07 11:46:21 -07:00
|
|
|
import SensitiveButton from '../components/sensitive-button';
|
2022-04-10 03:46:25 -07:00
|
|
|
import UploadProgress from '../components/upload-progress';
|
|
|
|
import UploadContainer from '../containers/upload_container';
|
|
|
|
|
2022-04-10 05:26:30 -07:00
|
|
|
import type { Attachment as AttachmentEntity } from 'soapbox/types/entities';
|
|
|
|
|
2022-09-10 14:52:06 -07:00
|
|
|
interface IUploadForm {
|
|
|
|
composeId: string,
|
|
|
|
}
|
|
|
|
|
|
|
|
const UploadForm: React.FC<IUploadForm> = ({ composeId }) => {
|
|
|
|
const mediaIds = useAppSelector((state) => state.compose.get(composeId)!.media_attachments.map((item: AttachmentEntity) => item.id));
|
2022-04-10 03:46:25 -07:00
|
|
|
const classes = classNames('compose-form__uploads-wrapper', {
|
|
|
|
'contains-media': mediaIds.size !== 0,
|
|
|
|
});
|
|
|
|
|
|
|
|
return (
|
|
|
|
<div className='compose-form__upload-wrapper'>
|
2022-09-10 14:52:06 -07:00
|
|
|
<UploadProgress composeId={composeId} />
|
2022-04-10 03:46:25 -07:00
|
|
|
|
|
|
|
<div className={classes}>
|
|
|
|
{mediaIds.map((id: string) => (
|
|
|
|
<UploadContainer id={id} key={id} />
|
|
|
|
))}
|
|
|
|
</div>
|
|
|
|
|
2022-09-10 14:52:06 -07:00
|
|
|
{!mediaIds.isEmpty() && <SensitiveButton composeId={composeId} />}
|
2022-04-10 03:46:25 -07:00
|
|
|
</div>
|
|
|
|
);
|
|
|
|
};
|
|
|
|
|
|
|
|
export default UploadForm;
|