diff --git a/src/page/Auth/Signup/components/fileUploadModal/fileUploadModal.module.scss b/src/page/Auth/Signup/components/fileUploadModal/fileUploadModal.module.scss index 34c761a8..d65cb960 100644 --- a/src/page/Auth/Signup/components/fileUploadModal/fileUploadModal.module.scss +++ b/src/page/Auth/Signup/components/fileUploadModal/fileUploadModal.module.scss @@ -67,5 +67,6 @@ font-weight: 500; background-color: #175c8e; color: white; + cursor: pointer; } } diff --git a/src/page/Auth/Signup/components/fileUploadModal/index.tsx b/src/page/Auth/Signup/components/fileUploadModal/index.tsx index c95392b5..0b50d452 100644 --- a/src/page/Auth/Signup/components/fileUploadModal/index.tsx +++ b/src/page/Auth/Signup/components/fileUploadModal/index.tsx @@ -1,3 +1,4 @@ +import { useRef } from 'react'; import { createPortal } from 'react-dom'; import styles from './fileUploadModal.module.scss'; @@ -7,6 +8,7 @@ interface FileUploadModalProps { } export default function FileUploadModal({ onClose, onUpload }: FileUploadModalProps) { + const fileInputRef = useRef(null); const handleFileChange = (event: React.ChangeEvent) => { if (event.target.files) { onUpload(event.target.files); @@ -36,6 +38,7 @@ export default function FileUploadModal({ onClose, onUpload }: FileUploadModalPr onChange={handleFileChange} style={{ display: 'none' }} id="file-upload" + ref={fileInputRef} /> diff --git a/src/page/Auth/Signup/components/ownerInfoStep/index.tsx b/src/page/Auth/Signup/components/ownerInfoStep/index.tsx index e8717074..a5ca90e0 100644 --- a/src/page/Auth/Signup/components/ownerInfoStep/index.tsx +++ b/src/page/Auth/Signup/components/ownerInfoStep/index.tsx @@ -6,6 +6,7 @@ import FileUploadModal from 'page/Auth/Signup/components/fileUploadModal'; import useUploadFile from 'query/upload'; import { isKoinError, sendClientError } from '@bcsdlab/koin'; import showToast from 'utils/ts/showToast'; +import { toast } from 'react-toastify'; import styles from './ownerInfoStep.module.scss'; interface OwnerInfo { @@ -45,6 +46,10 @@ export default function OwnerInfoStep({ onSearch, setIsStepComplete }: OwnerInfo const response = await uploadFiles(formData); const { file_urls: fileUrls } = response.data; const formattedUrls = fileUrls.map((url: string) => ({ file_url: url })); + if (formattedUrls.length + uploadedFiles.length > 5) { + toast.error('파일은 최대 5개 등록할 수 있습니다'); + return; + } setUploadedFiles((prev) => [...prev, ...formattedUrls]); setFileNames((prev) => [...prev, ...names]); setValue('attachment_urls', [...uploadedFiles, ...formattedUrls]); @@ -157,6 +162,8 @@ export default function OwnerInfoStep({ onSearch, setIsStepComplete }: OwnerInfo }, })} placeholder="숫자만 입력해주세요." + type="text" + inputMode="numeric" onChange={handleCompanyNumberChange} /> {errors.company_number && {errors.company_number.message}}