diff --git a/src/components/upload.tsx b/src/components/upload.tsx index 3c52f24e1..4a7a85ee2 100644 --- a/src/components/upload.tsx +++ b/src/components/upload.tsx @@ -1,3 +1,12 @@ +import bookIcon from '@tabler/icons/book.svg'; +import fileCodeIcon from '@tabler/icons/file-code.svg'; +import fileSpreadsheetIcon from '@tabler/icons/file-spreadsheet.svg'; +import fileTextIcon from '@tabler/icons/file-text.svg'; +import fileZipIcon from '@tabler/icons/file-zip.svg'; +import defaultIcon from '@tabler/icons/paperclip.svg'; +import presentationIcon from '@tabler/icons/presentation.svg'; +import xIcon from '@tabler/icons/x.svg'; +import zoomInIcon from '@tabler/icons/zoom-in.svg'; import clsx from 'clsx'; import { List as ImmutableList } from 'immutable'; import React, { useState } from 'react'; @@ -6,20 +15,11 @@ import { spring } from 'react-motion'; import { openModal } from 'soapbox/actions/modals'; import Blurhash from 'soapbox/components/blurhash'; -import Icon from 'soapbox/components/icon'; -import { HStack, IconButton } from 'soapbox/components/ui'; +import { HStack, Icon, IconButton } from 'soapbox/components/ui'; import Motion from 'soapbox/features/ui/util/optional-motion'; import { useAppDispatch } from 'soapbox/hooks'; import { Attachment } from 'soapbox/types/entities'; -const bookIcon = require('@tabler/icons/book.svg'); -const fileCodeIcon = require('@tabler/icons/file-code.svg'); -const fileSpreadsheetIcon = require('@tabler/icons/file-spreadsheet.svg'); -const fileTextIcon = require('@tabler/icons/file-text.svg'); -const fileZipIcon = require('@tabler/icons/file-zip.svg'); -const defaultIcon = require('@tabler/icons/paperclip.svg'); -const presentationIcon = require('@tabler/icons/presentation.svg'); - export const MIMETYPE_ICONS: Record = { 'application/x-freearc': fileZipIcon, 'application/x-bzip': fileZipIcon, @@ -163,7 +163,7 @@ const Upload: React.FC = ({ {(withPreview && mediaType !== 'unknown' && Boolean(media.url)) && ( = ({ {onDelete && ( ({ id, shouldCondense, autoFocus, clickab const composeModifiers = !condensed && ( - + = ({ composeId }) => { +const UploadForm: React.FC = ({ composeId, onSubmit }) => { const mediaIds = useCompose(composeId).media_attachments.map((item: AttachmentEntity) => item.id); return ( @@ -22,7 +23,7 @@ const UploadForm: React.FC = ({ composeId }) => { {mediaIds.map((id: string) => ( - + ))} diff --git a/src/features/compose/components/upload.tsx b/src/features/compose/components/upload.tsx index d1896067c..4cb163553 100644 --- a/src/features/compose/components/upload.tsx +++ b/src/features/compose/components/upload.tsx @@ -1,26 +1,21 @@ import React from 'react'; -import { useHistory } from 'react-router-dom'; -import { undoUploadCompose, changeUploadCompose, submitCompose } from 'soapbox/actions/compose'; +import { undoUploadCompose, changeUploadCompose } from 'soapbox/actions/compose'; import Upload from 'soapbox/components/upload'; import { useAppDispatch, useCompose, useInstance } from 'soapbox/hooks'; interface IUploadCompose { id: string; composeId: string; + onSubmit?(): void; } -const UploadCompose: React.FC = ({ composeId, id }) => { - const history = useHistory(); +const UploadCompose: React.FC = ({ composeId, id, onSubmit }) => { const dispatch = useAppDispatch(); const { description_limit: descriptionLimit } = useInstance(); const media = useCompose(composeId).media_attachments.find(item => item.id === id)!; - const handleSubmit = () => { - dispatch(submitCompose(composeId, history)); - }; - const handleDescriptionChange = (description: string) => { dispatch(changeUploadCompose(composeId, media.id, { description })); }; @@ -34,7 +29,7 @@ const UploadCompose: React.FC = ({ composeId, id }) => { media={media} onDelete={handleDelete} onDescriptionChange={handleDescriptionChange} - onSubmit={handleSubmit} + onSubmit={onSubmit} descriptionLimit={descriptionLimit} withPreview />