34 lines
1,023 B
TypeScript
34 lines
1,023 B
TypeScript
|
import classNames from 'classnames';
|
||
|
import React from 'react';
|
||
|
|
||
|
import { useAppSelector } from 'soapbox/hooks';
|
||
|
|
||
|
import type { Attachment as AttachmentEntity } from 'soapbox/types/entities';
|
||
|
|
||
|
// import SensitiveButtonContainer from '../containers/sensitive_button_container';
|
||
|
import UploadProgress from '../components/upload-progress';
|
||
|
import UploadContainer from '../containers/upload_container';
|
||
|
|
||
|
const UploadForm = () => {
|
||
|
const mediaIds = useAppSelector((state) => state.compose.get('media_attachments').map((item: AttachmentEntity) => item.get('id')));
|
||
|
const classes = classNames('compose-form__uploads-wrapper', {
|
||
|
'contains-media': mediaIds.size !== 0,
|
||
|
});
|
||
|
|
||
|
return (
|
||
|
<div className='compose-form__upload-wrapper'>
|
||
|
<UploadProgress />
|
||
|
|
||
|
<div className={classes}>
|
||
|
{mediaIds.map((id: string) => (
|
||
|
<UploadContainer id={id} key={id} />
|
||
|
))}
|
||
|
</div>
|
||
|
|
||
|
{/* {!mediaIds.isEmpty() && <SensitiveButtonContainer />} */}
|
||
|
</div>
|
||
|
);
|
||
|
};
|
||
|
|
||
|
export default UploadForm;
|