unzip file, transfer with stringify break blob
This commit is contained in:
		
							
								
								
									
										2124
									
								
								js/main.js
									
									
									
									
									
								
							
							
						
						
									
										2124
									
								
								js/main.js
									
									
									
									
									
								
							
										
											
												File diff suppressed because it is too large
												Load Diff
											
										
									
								
							
										
											
												File diff suppressed because one or more lines are too long
											
										
									
								
							| @@ -200,34 +200,32 @@ export default { | |||||||
|             if (!this.isAddFilePopupVisible) this.newFileName = ''; |             if (!this.isAddFilePopupVisible) this.newFileName = ''; | ||||||
|         }, |         }, | ||||||
|         async onDrop(event) { |         async onDrop(event) { | ||||||
|             // Récupérer les données transférées (fichier JSON) |             event.preventDefault(); | ||||||
|             const file = JSON.parse(event.dataTransfer.getData('file')); |             try { | ||||||
|             // Gérer le déplacement du fichier ici |                 const fileData = JSON.parse(event.dataTransfer.getData('application/json')); | ||||||
|             await this.moveFileToTarget(file); |                  | ||||||
|  |                 if (Array.isArray(fileData.content)) { | ||||||
|  |                     fileData.content = new Uint8Array(fileData.content); | ||||||
|  |                 } | ||||||
|  |                  | ||||||
|  |                 await this.moveFileToTarget(fileData); | ||||||
|  |             } catch (error) { | ||||||
|  |                 console.error('Erreur lors du drag and drop :', error); | ||||||
|  |             } | ||||||
|         }, |         }, | ||||||
|         async moveFileToTarget(file) { |         async moveFileToTarget(file) { | ||||||
|             console.log(file); |  | ||||||
|             const fileData = JSON.parse(event.dataTransfer.getData('file')); |  | ||||||
|             console.log(fileData); |  | ||||||
|              |  | ||||||
|             const client = getClient();  // Votre client WebDAV (assurez-vous que c'est bien un client qui prend en charge les uploads) |  | ||||||
|             // Exemple d'upload de fichier via un Blob |  | ||||||
|             const path = this.current_dir + "/" + fileData.name;  // Chemin complet de destination sur le serveur WebDAV |  | ||||||
|  |  | ||||||
|             // Créer un Blob à partir du fichier (si `file` est un objet `File` ou `Blob`) |  | ||||||
|             // Exemple de conversion du fichier en Blob si nécessaire |  | ||||||
|             const fileBlob = new Blob([fileData._data.compressedContent], { type: 'application/octet-stream' }); |  | ||||||
|             console.log(fileBlob) |  | ||||||
|  |  | ||||||
|             try { |             try { | ||||||
|                 // Utilisation de PUT pour télécharger le fichier sur WebDAV |                 const client = getClient(); | ||||||
|                 await client.putFileContents(path, fileBlob); |                 const path = this.root_path + this.current_dir + file.name; | ||||||
|  |                  | ||||||
|  |                 if (ArrayBuffer.isView(file.content)) { | ||||||
|  |                     file.content = Buffer.from(file.content); | ||||||
|  |                 } | ||||||
|  |  | ||||||
|                 // Logique pour déplacer le fichier dans la liste, si nécessaire |                 await client.putFileContents(path, file.content); | ||||||
|                 await this.fetchFiles();  // Met à jour la liste des fichiers après l'upload |  | ||||||
|                 // Vous pouvez aussi retirer ce fichier du premier template, si nécessaire |  | ||||||
|                 // this.$emit('removeFile', file); |  | ||||||
|  |  | ||||||
|  |                 // Recharge les fichiers après l'opération | ||||||
|  |                 await this.fetchFiles(); | ||||||
|             } catch (error) { |             } catch (error) { | ||||||
|                 console.error('Erreur lors du déplacement du fichier:', error); |                 console.error('Erreur lors du déplacement du fichier:', error); | ||||||
|             } |             } | ||||||
|   | |||||||
| @@ -73,18 +73,16 @@ import JSZip from 'jszip'; | |||||||
| import ChevronRightIcon from 'vue-material-design-icons/ChevronRight.vue'; | import ChevronRightIcon from 'vue-material-design-icons/ChevronRight.vue'; | ||||||
| import ChevronDownIcon from 'vue-material-design-icons/ChevronDown.vue'; | import ChevronDownIcon from 'vue-material-design-icons/ChevronDown.vue'; | ||||||
|  |  | ||||||
|  |  | ||||||
| export default { | export default { | ||||||
|     name: 'WebContentViewer', |     name: 'WebContentViewer', | ||||||
|     data() { |     data() { | ||||||
|         return { |         return { | ||||||
|             zipContent: [], |             zipContent: [], | ||||||
|             pathTable: [], |             folderMap: {},  | ||||||
|             folderMap: {}, // Map to track folder open/close state |  | ||||||
|             archiveUrl: '', |             archiveUrl: '', | ||||||
|             token: '', |             token: '', | ||||||
|             ChevronRightIcon, |             ChevronRightIcon, | ||||||
|             ChevronDownIcon, |             ChevronDownIcon | ||||||
|         }; |         }; | ||||||
|     }, |     }, | ||||||
|     props: { |     props: { | ||||||
| @@ -138,10 +136,12 @@ export default { | |||||||
|                 const zip = await JSZip.loadAsync(zipData); |                 const zip = await JSZip.loadAsync(zipData); | ||||||
|  |  | ||||||
|                 const files = []; |                 const files = []; | ||||||
|  |                 const filePromises = []; | ||||||
|  |  | ||||||
|                 zip.forEach((relativePath, file) => { |                 zip.forEach((relativePath, file) => { | ||||||
|                     const pathParts = relativePath.split('/').filter(Boolean); |                     const pathParts = relativePath.split('/').filter(Boolean); | ||||||
|  |  | ||||||
|                     let currentLevel = files; |                     let currentLevel = files; | ||||||
|  |  | ||||||
|                     for (let i = 0; i < pathParts.length; i++) { |                     for (let i = 0; i < pathParts.length; i++) { | ||||||
|                         const partName = pathParts[i]; |                         const partName = pathParts[i]; | ||||||
|                         const isDirectory = i < pathParts.length - 1 || file.dir; |                         const isDirectory = i < pathParts.length - 1 || file.dir; | ||||||
| @@ -152,21 +152,35 @@ export default { | |||||||
|                                 name: partName, |                                 name: partName, | ||||||
|                                 isDirectory, |                                 isDirectory, | ||||||
|                                 size: isDirectory ? 0 : file._data.uncompressedSize, |                                 size: isDirectory ? 0 : file._data.uncompressedSize, | ||||||
|                                 children: isDirectory ? [] : null, |                                 content: isDirectory ? null : '',  // Initialiser 'content' pour les fichiers | ||||||
|                                 file: file, |                                 children: isDirectory ? [] : null | ||||||
|                             }; |                             }; | ||||||
|                             currentLevel.push(existing); |                             currentLevel.push(existing); | ||||||
|                         } |                         } | ||||||
|  |  | ||||||
|                         if (isDirectory) { |                         if (isDirectory) { | ||||||
|                             currentLevel = existing.children; |                             currentLevel = existing.children; | ||||||
|  |                         } else { | ||||||
|  |                             // Lire le contenu des fichiers non répertoires | ||||||
|  |                             if (file.dir) continue; | ||||||
|  |                             if (!existing && existing.size > 50 * 1024 * 1024) { | ||||||
|  |                                 console.warn(`Fichier ${existing.name} trop volumineux pour être chargé`); | ||||||
|  |                                 continue; | ||||||
|  |                             } | ||||||
|  |  | ||||||
|  |                             const promise = file.async("blob").then(content => { | ||||||
|  |                                 existing.content = content; | ||||||
|  |                             }); | ||||||
|  |  | ||||||
|  |                             filePromises.push(promise); | ||||||
|                         } |                         } | ||||||
|                     } |                     } | ||||||
|                 }); |                 }); | ||||||
|  |  | ||||||
|  |                 // Attendre que tous les contenus de fichier soient extraits | ||||||
|                 this.zipContent = files; |                 this.zipContent = files; | ||||||
|  |  | ||||||
|                 // Initialize folderMap |                 // Initialiser folderMap | ||||||
|                 const initializeFolderMap = (files, parentPath = '') => { |                 const initializeFolderMap = (files, parentPath = '') => { | ||||||
|                     files.forEach(file => { |                     files.forEach(file => { | ||||||
|                         const fullPath = parentPath ? `${parentPath}/${file.name}` : file.name; |                         const fullPath = parentPath ? `${parentPath}/${file.name}` : file.name; | ||||||
| @@ -178,10 +192,14 @@ export default { | |||||||
|                 }; |                 }; | ||||||
|  |  | ||||||
|                 initializeFolderMap(this.zipContent); |                 initializeFolderMap(this.zipContent); | ||||||
|  |  | ||||||
|  |                 await Promise.all(filePromises); | ||||||
|  |                 console.log('Contenu du ZIP chargé avec succès'); | ||||||
|             } catch (error) { |             } catch (error) { | ||||||
|                 console.error('Erreur lors du chargement du contenu du ZIP :', error); |                 console.error('Erreur lors du chargement du contenu du ZIP :', error); | ||||||
|             } |             } | ||||||
|         }, |         }, | ||||||
|  |  | ||||||
|         formatFileSize(size) { |         formatFileSize(size) { | ||||||
|             if (size < 1024) return `${size} B`; |             if (size < 1024) return `${size} B`; | ||||||
|             if (size < 1024 * 1024) return `${(size / 1024).toFixed(2)} KB`; |             if (size < 1024 * 1024) return `${(size / 1024).toFixed(2)} KB`; | ||||||
| @@ -193,9 +211,22 @@ export default { | |||||||
|             const currentState = this.folderMap[file.fullPath]; |             const currentState = this.folderMap[file.fullPath]; | ||||||
|             this.$set(this.folderMap, file.fullPath, !currentState); |             this.$set(this.folderMap, file.fullPath, !currentState); | ||||||
|         }, |         }, | ||||||
|         onDragStart(file, event) { |         async onDragStart(file, event) { | ||||||
|             // Sauvegarder l'objet du fichier dans l'événement |             if (!file || !file.content) { | ||||||
|             event.dataTransfer.setData('file', JSON.stringify(file.file)); |                 event.preventDefault(); | ||||||
|  |                 return; | ||||||
|  |             } | ||||||
|  |              | ||||||
|  |             let fileToTransfer = { ...file }; // Clone l'objet file | ||||||
|  |              | ||||||
|  |             if (file.content instanceof Blob) { | ||||||
|  |                 // Convertir le Blob en base64 string | ||||||
|  |                 const arrayBuffer = await file.content.arrayBuffer(); | ||||||
|  |                 const uint8Array = new Uint8Array(arrayBuffer); | ||||||
|  |                 fileToTransfer.content = Array.from(uint8Array); // Convertir Uint8Array en array normal | ||||||
|  |             } | ||||||
|  |              | ||||||
|  |             event.dataTransfer.setData('application/json', JSON.stringify(fileToTransfer)); | ||||||
|         }, |         }, | ||||||
|     }, |     }, | ||||||
| }; | }; | ||||||
|   | |||||||
| @@ -627,6 +627,10 @@ video { | |||||||
|   display: flex; |   display: flex; | ||||||
| } | } | ||||||
|  |  | ||||||
|  | .contents { | ||||||
|  |   display: contents; | ||||||
|  | } | ||||||
|  |  | ||||||
| .hidden { | .hidden { | ||||||
|   display: none; |   display: none; | ||||||
| } | } | ||||||
|   | |||||||
		Reference in New Issue
	
	Block a user