From 5ea69b129d4d850ced2ffc524b29afe3f6c60d1b Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Vladan=20Tomi=C4=87?= Date: Tue, 19 Sep 2023 10:50:33 +0200 Subject: [PATCH 1/4] feat: multiple file upload (#499) --- .../UploadFileModal/UploadFileModal.tsx | 37 +++++++++++-------- 1 file changed, 22 insertions(+), 15 deletions(-) diff --git a/src/components/Modals/UploadFileModal/UploadFileModal.tsx b/src/components/Modals/UploadFileModal/UploadFileModal.tsx index 7b9ebc39..e91b75ca 100644 --- a/src/components/Modals/UploadFileModal/UploadFileModal.tsx +++ b/src/components/Modals/UploadFileModal/UploadFileModal.tsx @@ -33,20 +33,20 @@ const UploadFileModal: FC = ({ const [loading, setLoading] = useState(false); const [message, setMessage] = useState(null); - const [fileToUpload, setFileToUpload] = useState(null); + const [filesToUpload, setFilesToUpload] = useState(null); const [errorMessage, setErrorMessage] = useState(''); const { fdpClientRef, getAccountAddress } = useFdpStorage(); const { getRootProps, getInputProps } = useDropzone({ onDrop: (acceptedFiles: any) => { if (activePod) { - setFileToUpload(acceptedFiles[0]); + setFilesToUpload(acceptedFiles); } }, }); const { intl } = useLocales(); const handleUpload = async () => { - if (!(fileToUpload && activePod)) { + if (!(filesToUpload && activePod)) { return; } @@ -55,11 +55,15 @@ const UploadFileModal: FC = ({ const userAddress = await getAccountAddress(); const directory = directoryName || 'root'; const fdpPath = getFdpPathByDirectory(directory); - const item = await uploadFile(fdpClientRef.current, { - file: fileToUpload, - directory: directoryName, - podName: activePod, - }); + const items = await Promise.all( + filesToUpload.map((file) => + uploadFile(fdpClientRef.current, { + file, + directory: directoryName, + podName: activePod, + }) + ) + ); trackEvent({ category: 'Upload', @@ -69,7 +73,9 @@ const UploadFileModal: FC = ({ href: window.location.href, }); - addItemToCache(userAddress, activePod, fdpPath, item, ContentType.FILE); + items.forEach((item) => + addItemToCache(userAddress, activePod, fdpPath, item, ContentType.FILE) + ); updateDrive({ isUseCacheOnly: true, }); @@ -113,11 +119,12 @@ const UploadFileModal: FC = ({

- {fileToUpload ? ( -

- {intl.get('READY_TO_UPLOAD')} {fileToUpload?.name} -

- ) : null} + {filesToUpload && + filesToUpload.map((file) => ( +

+ {intl.get('READY_TO_UPLOAD')} {file?.name} +

+ ))} {errorMessage ? (
@@ -131,7 +138,7 @@ const UploadFileModal: FC = ({ variant="primary-outlined" label={intl.get('UPLOAD_CONTENT')} onClick={handleUpload} - disabled={!fileToUpload || loading} + disabled={!filesToUpload || loading} loading={loading} />
From 56f77ef825ec44eddc7b5e5d2ff5faf24c25d588 Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Vladan=20Tomi=C4=87?= Date: Wed, 20 Sep 2023 15:36:56 +0200 Subject: [PATCH 2/4] fix: folder label --- .../NavigationBars/DriveActionBar/DriveActionBarMobile.tsx | 4 ++-- src/locales/ch-CH.json | 3 ++- src/locales/de-DE.json | 3 ++- src/locales/en-US.json | 3 ++- src/locales/es-ES.json | 3 ++- src/locales/fr-FR.json | 3 ++- src/locales/hu-HU.json | 3 ++- src/locales/it-IT.json | 3 ++- src/locales/jp-JP.json | 3 ++- src/locales/pt-PT.json | 3 ++- src/locales/rs-RS.json | 3 ++- src/locales/sl-SI.json | 3 ++- src/locales/tr-TR.json | 3 ++- 13 files changed, 26 insertions(+), 14 deletions(-) diff --git a/src/components/NavigationBars/DriveActionBar/DriveActionBarMobile.tsx b/src/components/NavigationBars/DriveActionBar/DriveActionBarMobile.tsx index 08970eb6..44b81471 100644 --- a/src/components/NavigationBars/DriveActionBar/DriveActionBarMobile.tsx +++ b/src/components/NavigationBars/DriveActionBar/DriveActionBarMobile.tsx @@ -42,7 +42,7 @@ const DriveActionBarItem = ( {theme === 'light' ? imageLight : imageDark} - + {label} @@ -88,7 +88,7 @@ const DriveActionBarMobile: FC = ({ )} {DriveActionBarItem( theme, - intl.get('FOLDER'), + intl.get('NEW_FOLDER'), , , () => setShowCreateFolderModal(true) diff --git a/src/locales/ch-CH.json b/src/locales/ch-CH.json index a9fbefa8..8fb7064f 100644 --- a/src/locales/ch-CH.json +++ b/src/locales/ch-CH.json @@ -219,5 +219,6 @@ "TERMS_OF_USAGE_PARAGRAPH_3": "通过使用Fairdrive Beta版本,您同意报告在平台上发现的任何缺陷、错误或瑕疵,或者用户 - Beta测试人员已获准访问Fairdrive Beta版本的其他材料。用户理解及时准确地报告是Fairdrive Beta版本的目的,并承诺在产品的所有方面(无论是积极的还是消极的)上提供频繁的报告,并承认任何因Beta测试人员对Fairdrive项目的贡献而产生的改进、修改和变更,仍然或变为披露方的专有财产。", "FAIRDRIVE_COPYRIGHT": "© 2021 Fairdrive。保留所有权利。", "PASSPHRASE_EXPLANATION": "您的密码用于加密和解密您的数据。不要分享。", - "ROOT_DIRECTORY": "根目录 " + "ROOT_DIRECTORY": "根目录 ", + "NEW_FOLDER": "新建文件夹" } diff --git a/src/locales/de-DE.json b/src/locales/de-DE.json index 2d78d140..fba08b0c 100644 --- a/src/locales/de-DE.json +++ b/src/locales/de-DE.json @@ -219,5 +219,6 @@ "TERMS_OF_USAGE_PARAGRAPH_3": "Durch die Verwendung der Fairdrive Beta-Version erklären Sie sich damit einverstanden, alle Mängel, Fehler oder Unvollkommenheiten, die auf der Plattform oder anderen Materialien entdeckt wurden, anzuzeigen, bei denen dem Benutzer - dem Beta-Tester - Zugang zur Fairdrive Beta-Version gewährt wurde. Der Benutzer versteht, dass eine prompte und genaue Berichterstattung den Zweck der Fairdrive Beta-Version darstellt, und verpflichtet sich, seine besten Anstrengungen zu unternehmen, um häufige Berichte über alle Aspekte des Produkts sowohl positiv als auch negativ zu liefern, und erkennt an, dass Verbesserungen, Modifikationen und Änderungen, die aus oder in Verbindung mit dem Beitrag des Beta-Testers zum Fairdrive-Projekt entstehen, im ausschließlichen Eigentum der offenlegenden Partei verbleiben oder werden.", "FAIRDRIVE_COPYRIGHT": "© 2021 Fairdrive. Alle Rechte vorbehalten", "PASSPHRASE_EXPLANATION": "Ihr Kennwort wird zur Verschlüsselung und Entschlüsselung Ihrer Daten verwendet. Teilen Sie es nicht.", - "ROOT_DIRECTORY": "Stammverzeichnis" + "ROOT_DIRECTORY": "Stammverzeichnis", + "NEW_FOLDER": "Neuer Ordner" } diff --git a/src/locales/en-US.json b/src/locales/en-US.json index 6521a0a2..4196be94 100644 --- a/src/locales/en-US.json +++ b/src/locales/en-US.json @@ -219,5 +219,6 @@ "TERMS_OF_USAGE_PARAGRAPH_3": "By using Fairdrive Beta Release you agree to report any flaws, errors or imperfections discovered on the platform or other materials where the user - Beta Tester has been granted access to the Fairdrive Beta Release. The user understands that prompt and accurate reporting is the purpose of the Fairdrive Beta Release and undertakes to use best efforts to provide frequent reports on all aspects of the product both positive and negative and acknowledges that any improvements, modifications and changes arising from or in connection with the Beta Testers contribution to the Fairdrive Project, remain or become the exclusive property of the Disclosing Party.", "FAIRDRIVE_COPYRIGHT": "© 2021 Fairdrive. All rights reserved", "PASSPHRASE_EXPLANATION": "Your passphrase is used for the encryption and decryption of your data. Do not share it.", - "ROOT_DIRECTORY": "Root directory" + "ROOT_DIRECTORY": "Root directory", + "NEW_FOLDER": "New Folder" } diff --git a/src/locales/es-ES.json b/src/locales/es-ES.json index 3e812eaf..f3cfaf96 100644 --- a/src/locales/es-ES.json +++ b/src/locales/es-ES.json @@ -219,5 +219,6 @@ "TERMS_OF_USAGE_PARAGRAPH_3": "Al utilizar Fairdrive Beta Release, aceptas informar cualquier defecto, error o imperfección descubierta en la plataforma u otros materiales donde al usuario - Beta Tester se le haya concedido acceso a Fairdrive Beta Release. El usuario entiende que informar de manera rápida y precisa es el propósito de Fairdrive Beta Release y se compromete a utilizar sus mejores esfuerzos para proporcionar informes frecuentes sobre todos los aspectos del producto, tanto positivos como negativos, y reconoce que cualquier mejora, modificación y cambio que surja o en relación con la contribución de los Beta Testers al Proyecto Fairdrive, permanecen o se convierten en propiedad exclusiva de la Parte Divulgante.", "FAIRDRIVE_COPYRIGHT": "© 2021 Fairdrive. Todos los derechos reservados.", "PASSPHRASE_EXPLANATION": "Su frase de contraseña se utiliza para la encriptación y desencriptación de sus datos. No lo comparta.", - "ROOT_DIRECTORY": "Directorio raíz" + "ROOT_DIRECTORY": "Directorio raíz", + "NEW_FOLDER": "Nueva Carpeta" } diff --git a/src/locales/fr-FR.json b/src/locales/fr-FR.json index e4bb7aef..6f3cf4d5 100644 --- a/src/locales/fr-FR.json +++ b/src/locales/fr-FR.json @@ -219,5 +219,6 @@ "TERMS_OF_USAGE_PARAGRAPH_3": "En utilisant la version bêta de Fairdrive, vous acceptez de signaler tout défaut, erreur ou imperfection découvert sur la plateforme ou d'autres supports où l'utilisateur - testeur bêta a eu accès à la version bêta de Fairdrive. L'utilisateur comprend que la communication rapide et précise est le but de la version bêta de Fairdrive et s'engage à faire de son mieux pour fournir des rapports fréquents sur tous les aspects du produit, positifs et négatifs, et reconnaît que toutes les améliorations, modifications et changements découlant de la contribution du testeur bêta au projet Fairdrive restent ou deviennent la propriété exclusive de la partie révélante.", "FAIRDRIVE_COPYRIGHT": "© 2021 Fairdrive. Tous droits réservés", "PASSPHRASE_EXPLANATION": "Votre mot de passe est utilisé pour le chiffrement et le déchiffrement de vos données. Ne le partagez pas.", - "ROOT_DIRECTORY": "Répertoire racine" + "ROOT_DIRECTORY": "Répertoire racine", + "NEW_FOLDER": "Nouveau Dossier" } diff --git a/src/locales/hu-HU.json b/src/locales/hu-HU.json index 65e2c669..8f4416b6 100644 --- a/src/locales/hu-HU.json +++ b/src/locales/hu-HU.json @@ -219,5 +219,6 @@ "TERMS_OF_USAGE_PARAGRAPH_3": "A Fairdrive Béta Verzió használatával elfogadod, hogy jelents be minden hibát, hibát vagy hiányosságot, amelyet felfedeztél a platformon vagy más anyagokon, ahol a felhasználó - Béta Tesztelő hozzáférést kapott a Fairdrive Béta Verziójához. A felhasználó megérti, hogy a Fairdrive Béta Verziójának gyors és pontos jelentése a cél, és elkötelezi magát arra, hogy minden termék vonatkozásában gyakori jelentéseket nyújtson be a pozitív és negatív szempontokról, és elismeri, hogy bármely fejlesztés, módosítás és változás a Béta Tesztelő hozzájárulásából, vagy a Fairdrive Projekt hozzájárulásából eredően, a Közzétevő Fél kizárólagos tulajdonában marad vagy anná válik.", "FAIRDRIVE_COPYRIGHT": "© 2021 Fairdrive. Minden jog fenntartva", "PASSPHRASE_EXPLANATION": "A jelszót használjuk az adatok titkosításához és visszafejtéséhez. Ne ossza meg.", - "ROOT_DIRECTORY": "Gyökérkönyvtár" + "ROOT_DIRECTORY": "Gyökérkönyvtár", + "NEW_FOLDER": "Új Mappa" } diff --git a/src/locales/it-IT.json b/src/locales/it-IT.json index 349c7578..6ce16111 100644 --- a/src/locales/it-IT.json +++ b/src/locales/it-IT.json @@ -219,5 +219,6 @@ "TERMS_OF_USAGE_PARAGRAPH_3": "Utilizzando Fairdrive Beta Release accetti di segnalare eventuali difetti, errori o imperfezioni riscontrati sulla piattaforma o su altri materiali a cui l'utente - Beta Tester ha avuto accesso tramite Fairdrive Beta Release. L'utente comprende che la segnalazione tempestiva e accurata è lo scopo di Fairdrive Beta Release e si impegna a fare del suo meglio per fornire segnalazioni frequenti su tutti gli aspetti del prodotto, sia positivi che negativi, e riconosce che qualsiasi miglioramento, modifica o cambiamento derivante o in relazione al contributo dei Beta Tester al Progetto Fairdrive rimane o diventa di proprietà esclusiva della Parte che Rende la Divulgazione.", "FAIRDRIVE_COPYRIGHT": "© 2021 Fairdrive. Tutti i diritti riservati", "PASSPHRASE_EXPLANATION": "La tua frase di accesso viene utilizzata per la cifratura e la decifratura dei tuoi dati. Non condividerla.", - "ROOT_DIRECTORY": "Directory principale" + "ROOT_DIRECTORY": "Directory principale", + "NEW_FOLDER": "Nuova Cartella" } diff --git a/src/locales/jp-JP.json b/src/locales/jp-JP.json index 5fa30586..ace2b1e3 100644 --- a/src/locales/jp-JP.json +++ b/src/locales/jp-JP.json @@ -219,5 +219,6 @@ "TERMS_OF_USAGE_PARAGRAPH_3": "Fairdrive Beta Releaseを使用することにより、ユーザーはプラットフォームまたはユーザー - ベータテスターがFairdrive Beta Releaseにアクセスを許可されている他の資料上で発見したすべての欠陥、エラー、または欠陥を報告することに同意します。ユーザーは、適切な報告がFairdrive Beta Releaseの目的であり、製品のあらゆる側面について頻繁な報告を提供する最善の努力を行うことを理解し、製品へのベータテスターの貢献から生じる改良、修正、変更が開示側の独占的な財産となるか、またはなることを認識します。", "FAIRDRIVE_COPYRIGHT": "© 2021 Fairdrive. All rights reserved", "PASSPHRASE_EXPLANATION": "パスフレーズはデータの暗号化と復号化に使用されます。共有しないでください。", - "ROOT_DIRECTORY": "ルートディレクトリ" + "ROOT_DIRECTORY": "ルートディレクトリ", + "NEW_FOLDER": "新しいフォルダ" } diff --git a/src/locales/pt-PT.json b/src/locales/pt-PT.json index 2fb2525d..0b6e9768 100644 --- a/src/locales/pt-PT.json +++ b/src/locales/pt-PT.json @@ -219,5 +219,6 @@ "TERMS_OF_USAGE_PARAGRAPH_3": "Ao usar a Versão Beta do Fairdrive, você concorda em relatar quaisquer falhas, erros ou imperfeições descobertas na plataforma ou em outros materiais nos quais o usuário - Testador Beta tenha acesso à Versão Beta do Fairdrive. O usuário compreende que relatar prontamente e com precisão é o propósito da Versão Beta do Fairdrive e se compromete a fazer o melhor esforço para fornecer relatórios frequentes sobre todos os aspectos do produto, tanto positivos quanto negativos, e reconhece que quaisquer melhorias, modificações e alterações decorrentes ou relacionadas à contribuição do Testador Beta para o Projeto Fairdrive permanecem ou se tornam propriedade exclusiva da Parte Divulgadora.", "FAIRDRIVE_COPYRIGHT": "© 2021 Fairdrive. Todos os direitos reservados", "PASSPHRASE_EXPLANATION": "Sua senha é usada para a criptografia e descriptografia de seus dados. Não a compartilhe.", - "ROOT_DIRECTORY": "Diretório raiz" + "ROOT_DIRECTORY": "Diretório raiz", + "NEW_FOLDER": "Nova Pasta" } diff --git a/src/locales/rs-RS.json b/src/locales/rs-RS.json index b31fdb3b..19742e8d 100644 --- a/src/locales/rs-RS.json +++ b/src/locales/rs-RS.json @@ -219,5 +219,6 @@ "TERMS_OF_USAGE_PARAGRAPH_3": "Korišćenjem Fairdrive Beta verzije slažete se da prijavljujete sve nedostatke, greške ili nesavršenosti koje pronađete na platformi ili drugim materijalima gde je korisnik - Beta Tester dobio pristup Fairdrive Beta verziji. Korisnik razume da je brzo i tačno izveštavanje cilj Fairdrive Beta verzije i preduzimaće sve moguće napore da često izveštava o svim aspektima proizvoda, kako pozitivnim tako i negativnim, i priznaje da svaka poboljšanja, modifikacije i promene proistekle iz ili u vezi sa doprinosom Beta Testera Projektu Fairdrive ostaju ili postaju isključiva svojina Otkrivajuće strane.", "FAIRDRIVE_COPYRIGHT": "© 2021 Fairdrive. Sva prava zadržana", "PASSPHRASE_EXPLANATION": "Vaša lozinka se koristi za šifrovanje i dešifrovanje vaših podataka. Nemojte je deliti.", - "ROOT_DIRECTORY": "Koreni direktorijum" + "ROOT_DIRECTORY": "Koreni direktorijum", + "NEW_FOLDER": "Novi direktorijum" } diff --git a/src/locales/sl-SI.json b/src/locales/sl-SI.json index 89ccf891..3a0b77e3 100644 --- a/src/locales/sl-SI.json +++ b/src/locales/sl-SI.json @@ -219,5 +219,6 @@ "TERMS_OF_USAGE_PARAGRAPH_3": "Z uporabo izdaje Fairdrive Beta se strinjate, da boste poročali o napakah, napakah ali pomanjkljivostih, odkritih na platformi ali drugih materialih, kjer je uporabniku - testnemu uporabniku dodeljen dostop do izdaje Fairdrive Beta. Uporabnik razume, da je namen izdaje Fairdrive Beta hitro in natančno poročanje ter si bo prizadeval za pogosto poročanje o vseh vidikih izdelka tako pozitivnih kot negativnih ter priznava, da vsak izboljšanje, sprememba in sprememba, ki izhajajo iz ali v zvezi z doprinosom testnega uporabnika k projektu Fairdrive, ostanejo ali postanejo izključna last Disclosing Party.", "FAIRDRIVE_COPYRIGHT": "© 2021 Fairdrive. Vse pravice pridržane", "PASSPHRASE_EXPLANATION": "Vaše geslo se uporablja za šifriranje in dešifriranje vaših podatkov. Ne delite ga.", - "ROOT_DIRECTORY": "Koreninski imenik" + "ROOT_DIRECTORY": "Koreninski imenik", + "NEW_FOLDER": "Nova mapa" } diff --git a/src/locales/tr-TR.json b/src/locales/tr-TR.json index d5908bae..6360f75c 100644 --- a/src/locales/tr-TR.json +++ b/src/locales/tr-TR.json @@ -219,5 +219,6 @@ "TERMS_OF_USAGE_PARAGRAPH_3": "Fairdrive Beta Sürümünü kullanarak, kullanıcı, Beta Tester olarak Fairdrive Beta Sürümü'ne erişimi verilen diğer materyallerde bulunan hataları, hataları veya kusurları rapor etmeyi kabul eder. Kullanıcı, zamanında ve doğru rapor vermenin Fairdrive Beta Sürümü'nün amacı olduğunu anlar ve ürünün tüm yönlerine yönelik olumlu ve olumsuz sık raporlar sunma çabalarını kullanır ve bunun, İfşa Eden Tarafın münhasır mülkü olan Fairdrive Projesine Beta Tester'ın katkısından kaynaklanan veya bununla bağlantılı olarak meydana gelen tüm iyileştirmeleri, değişiklikleri ve değişiklikleri içerdiğini kabul eder.", "FAIRDRIVE_COPYRIGHT": "© 2021 Fairdrive. Tüm hakları saklıdır", "PASSPHRASE_EXPLANATION": "Parolanız, verilerinizin şifrelenmesi ve şifre çözme işlemleri için kullanılır. Paylaşmayın lütfen.", - "ROOT_DIRECTORY": "Kök dizin" + "ROOT_DIRECTORY": "Kök dizin", + "NEW_FOLDER": "Yeni Klasör" } From a26ebdfd59097fb09ad578c7c3ff5ab473060402 Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Vladan=20Tomi=C4=87?= Date: Thu, 21 Sep 2023 13:45:43 +0200 Subject: [PATCH 3/4] feat: multiple file upload --- src/components/Modals/SideModal/SideModal.tsx | 2 +- .../UploadFileModal/UploadFileModal.tsx | 111 +++++++++++++----- 2 files changed, 84 insertions(+), 29 deletions(-) diff --git a/src/components/Modals/SideModal/SideModal.tsx b/src/components/Modals/SideModal/SideModal.tsx index bb163858..c3d120bf 100644 --- a/src/components/Modals/SideModal/SideModal.tsx +++ b/src/components/Modals/SideModal/SideModal.tsx @@ -14,7 +14,7 @@ interface SideModalProps { }; headerTitle: string; className?: string; - children: ReactChild | ReactChild[]; + children: React.ReactNode; } const SideModal: FC = ({ diff --git a/src/components/Modals/UploadFileModal/UploadFileModal.tsx b/src/components/Modals/UploadFileModal/UploadFileModal.tsx index e91b75ca..a1471b2e 100644 --- a/src/components/Modals/UploadFileModal/UploadFileModal.tsx +++ b/src/components/Modals/UploadFileModal/UploadFileModal.tsx @@ -21,6 +21,7 @@ import { CreatorModalProps } from '@interfaces/handlers'; import { addItemToCache, ContentType } from '@utils/cache'; import { getFdpPathByDirectory } from '@api/pod'; import { useLocales } from '@context/LocalesContext'; +import { FileItem } from '@fairdatasociety/fdp-storage'; const UploadFileModal: FC = ({ showModal, @@ -33,11 +34,13 @@ const UploadFileModal: FC = ({ const [loading, setLoading] = useState(false); const [message, setMessage] = useState(null); - const [filesToUpload, setFilesToUpload] = useState(null); + const [filesToUpload, setFilesToUpload] = useState(null); + const [uploadedItems, setUploadedItems] = useState([]); + const [failedUplods, setFailedUplods] = useState([]); const [errorMessage, setErrorMessage] = useState(''); const { fdpClientRef, getAccountAddress } = useFdpStorage(); const { getRootProps, getInputProps } = useDropzone({ - onDrop: (acceptedFiles: any) => { + onDrop: (acceptedFiles: File[]) => { if (activePod) { setFilesToUpload(acceptedFiles); } @@ -45,24 +48,16 @@ const UploadFileModal: FC = ({ }); const { intl } = useLocales(); - const handleUpload = async () => { - if (!(filesToUpload && activePod)) { - return; - } - - setLoading(true); - try { + const onClose = async () => { + if (uploadedItems.length > 0) { const userAddress = await getAccountAddress(); const directory = directoryName || 'root'; const fdpPath = getFdpPathByDirectory(directory); - const items = await Promise.all( - filesToUpload.map((file) => - uploadFile(fdpClientRef.current, { - file, - directory: directoryName, - podName: activePod, - }) - ) + + setMessage(intl.get('SUCCESSFULLY_UPLOADED')); + + uploadedItems.forEach((item) => + addItemToCache(userAddress, activePod, fdpPath, item, ContentType.FILE) ); trackEvent({ @@ -73,14 +68,53 @@ const UploadFileModal: FC = ({ href: window.location.href, }); - items.forEach((item) => - addItemToCache(userAddress, activePod, fdpPath, item, ContentType.FILE) - ); updateDrive({ isUseCacheOnly: true, }); - closeModal(); - setMessage(intl.get('SUCCESSFULLY_UPLOADED')); + } + + closeModal(); + }; + + const handleUpload = async () => { + setErrorMessage(''); + + if (loading || !(filesToUpload && activePod)) { + return; + } + + setLoading(true); + try { + const uploadedFiles = []; + setFailedUplods([]); + + await filesToUpload.reduce(async (prevUpload, file) => { + try { + await prevUpload; + + if (uploadedItems.some(({ name }) => name === file.name)) { + uploadedFiles.push(file); + return; + } + + const item = await uploadFile(fdpClientRef.current, { + file, + directory: directoryName, + podName: activePod, + }); + + uploadedFiles.push(file); + setUploadedItems((uploadedItems) => [...uploadedItems, item]); + } catch (error) { + setFailedUplods((failedUplods) => [...failedUplods, file]); + } + }, Promise.resolve()); + + if (uploadedFiles.length === filesToUpload.length) { + onClose(); + } else { + throw new Error("Some files weren't uploaded successfully."); + } } catch (e) { setErrorMessage(`${e.message}`); } finally { @@ -88,10 +122,22 @@ const UploadFileModal: FC = ({ } }; + const getFileUploadStatus = ( + file: File + ): 'pending' | 'success' | 'failed' => { + if (uploadedItems.some((item) => item.name === file.name)) { + return 'success'; + } + if (failedUplods.some((failedFile) => failedFile.name === file.name)) { + return 'failed'; + } + return 'pending'; + }; + return ( , dark: , @@ -120,11 +166,20 @@ const UploadFileModal: FC = ({ {filesToUpload && - filesToUpload.map((file) => ( -

- {intl.get('READY_TO_UPLOAD')} {file?.name} -

- ))} + filesToUpload.map((file) => { + const status = getFileUploadStatus(file); + return ( +

+ {status === 'pending' && intl.get('READY_TO_UPLOAD')}{' '} + {file?.name} +

+ ); + })} {errorMessage ? (
From 910bf8b20f568f4e51c3d024387e706efe1135fe Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Vladan=20Tomi=C4=87?= Date: Thu, 21 Sep 2023 13:59:31 +0200 Subject: [PATCH 4/4] fix: file upload --- src/components/Modals/UploadFileModal/UploadFileModal.tsx | 3 +++ 1 file changed, 3 insertions(+) diff --git a/src/components/Modals/UploadFileModal/UploadFileModal.tsx b/src/components/Modals/UploadFileModal/UploadFileModal.tsx index a1471b2e..6dcc52ab 100644 --- a/src/components/Modals/UploadFileModal/UploadFileModal.tsx +++ b/src/components/Modals/UploadFileModal/UploadFileModal.tsx @@ -41,6 +41,9 @@ const UploadFileModal: FC = ({ const { fdpClientRef, getAccountAddress } = useFdpStorage(); const { getRootProps, getInputProps } = useDropzone({ onDrop: (acceptedFiles: File[]) => { + setUploadedItems([]); + setFailedUplods([]); + setErrorMessage(''); if (activePod) { setFilesToUpload(acceptedFiles); }