unzip file, transfer with stringify break blob
This commit is contained in:
parent
e039f04879
commit
34d3d8eea0
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;
|
||||||
}
|
}
|
||||||
|
Loading…
x
Reference in New Issue
Block a user