transfer folder content

This commit is contained in:
GMrrc 2024-11-20 17:12:10 +01:00
parent cbf9641e5a
commit 0516a73a2d
2 changed files with 92 additions and 13 deletions

View File

@ -133,6 +133,7 @@ export default {
breadcrumbParts: [], breadcrumbParts: [],
isAddFilePopupVisible: false, isAddFilePopupVisible: false,
newFileName: '', newFileName: '',
isTransfering: false,
}; };
}, },
async mounted() { async mounted() {
@ -171,6 +172,7 @@ export default {
return this.current_dir.split('/').filter(part => part); return this.current_dir.split('/').filter(part => part);
}, },
async handleClickElem(file) { async handleClickElem(file) {
if (this.isTransfering) return;
if (file.type === 'directory') { if (file.type === 'directory') {
this.current_dir = this.current_dir === '/' ? '/' + file.basename : this.current_dir + '/' + file.basename; this.current_dir = this.current_dir === '/' ? '/' + file.basename : this.current_dir + '/' + file.basename;
this.breadcrumbParts = this.getBreadcrumbParts() this.breadcrumbParts = this.getBreadcrumbParts()
@ -180,6 +182,7 @@ export default {
} }
}, },
async handleClickBreadcrumb(index) { async handleClickBreadcrumb(index) {
if (this.isTransfering) return;
let dir = '/'; let dir = '/';
if (index >= -1) { if (index >= -1) {
dir = this.generateCrumbHref(index); dir = this.generateCrumbHref(index);
@ -207,31 +210,78 @@ export default {
}, },
async onDrop(event) { async onDrop(event) {
event.preventDefault(); event.preventDefault();
try { try {
const moveFilesOfFolder = async (folder) => {
await this.createFolder(folder);
for (const child of folder.children) {
if (child.isDirectory) {
await moveFilesOfFolder(child);
} else {
if (child.content && typeof child.content.arrayBuffer === 'function') {
child.content = await child.content.arrayBuffer();
}
await this.moveFileToTarget(child);
}
}
};
this.isTransfering = true;
const file = this.file; const file = this.file;
if (!file) return;
console.log('Fichier déposé :', file); console.log('Fichier déposé :', file);
if (file.isDirectory) {
await moveFilesOfFolder(file);
} else {
if (file.content && typeof file.content.arrayBuffer === 'function') {
file.content = await file.content.arrayBuffer(); file.content = await file.content.arrayBuffer();
}
await this.moveFileToTarget(file); await this.moveFileToTarget(file);
}
this.isTransfering = false;
} catch (error) { } catch (error) {
console.error('Erreur lors du drag and drop :', error); console.error('Erreur lors du drop :', error);
} }
}, },
async moveFileToTarget(file) { async moveFileToTarget(file) {
try { try {
const client = getClient(); const client = getClient();
const path = this.root_path + this.current_dir + file.name;
// Assurez-vous que le chemin parent est correctement formaté
const parentPath = file.parentPath ? `${file.parentPath}/` : '';
const fullPath = `${this.root_path}${this.current_dir}${parentPath}${file.name}`;
if (ArrayBuffer.isView(file.content)) { if (ArrayBuffer.isView(file.content)) {
file.content = Buffer.from(file.content); file.content = Buffer.from(file.content);
} }
await client.putFileContents(path, file.content); // Évitez les chemins incorrects en utilisant `path.normalize` si disponible
await client.putFileContents(fullPath, file.content);
// Recharge les fichiers après l'opération // Recharge les fichiers après l'opération
await this.fetchFiles(); 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);
} }
},
async createFolder(folder) {
try {
const client = getClient();
// Assurez-vous que le chemin parent est correctement formaté
const parentPath = folder.parentPath ? `${folder.parentPath}/` : '';
const fullPath = `${this.root_path}${this.current_dir}${parentPath}${folder.name}/`;
await client.createDirectory(fullPath);
await this.fetchFiles();
} catch (error) {
console.error('Erreur lors de la création du dossier :', error);
}
} }
} }
}; };

View File

@ -32,7 +32,7 @@
class="text-NcBlue w-6 h-6" class="text-NcBlue w-6 h-6"
/> />
</div> </div>
<span class="ml-2 truncate cursor-pointer">{{ file.fullPath }}</span> <span class="ml-2 truncate cursor-pointer">{{ file.name }}</span>
</div> </div>
</div> </div>
<div class="w-1/6 px-4 py-2 cursor-pointer">-</div> <div class="w-1/6 px-4 py-2 cursor-pointer">-</div>
@ -56,7 +56,7 @@
</div> </div>
</template> </template>
<div class="w-4/6 flex items-center px-4 py-2 truncate cursor-pointer"> <div class="w-4/6 flex items-center px-4 py-2 truncate cursor-pointer">
{{ file.fullPath }} {{ file.name }}
</div> </div>
<div class="w-2/6 py-2 cursor-pointer"> <div class="w-2/6 py-2 cursor-pointer">
{{ formatFileSize(file.size) }} {{ formatFileSize(file.size) }}
@ -69,9 +69,10 @@
</template> </template>
<script> <script>
import JSZip from 'jszip'; import JSZip, { files } 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';
import path from 'path';
export default { export default {
name: 'WebContentViewer', name: 'WebContentViewer',
@ -156,11 +157,13 @@ export default {
if (!existing) { if (!existing) {
existing = { existing = {
name: partName, name: pathParts[i],
isDirectory, isDirectory,
size: isDirectory ? 0 : file._data.uncompressedSize, size: isDirectory ? 0 : file._data.uncompressedSize,
content: isDirectory ? null : '', // Initialiser 'content' pour les fichiers content: isDirectory ? null : '', // Initialiser 'content' pour les fichiers
children: isDirectory ? [] : null, children: isDirectory ? [] : null,
//remove the name of the file from the path
parentPath: pathParts.slice(0, i).join('/'),
unzip: promise unzip: promise
}; };
currentLevel.push(existing); currentLevel.push(existing);
@ -206,9 +209,35 @@ export default {
}, },
async onDragStart(file) { async onDragStart(file) {
console.log('Drag start', file); console.log('Drag start', file);
await file.unzip;
this.$emit('file-upload', file); const getFilesFromFolder = (folder) => {
const files = [];
if (!folder.children || folder.children.length === 0) return files;
for (let i = 0; i < folder.children.length; i++) {
const child = folder.children[i];
if (child.isDirectory) {
files.push(...getFilesFromFolder(child));
} else {
files.push(child);
} }
}
return files;
};
try {
if (file.isDirectory) {
const files = getFilesFromFolder(file);
const filesToUnzip = files.map(file => file.unzip);
await Promise.all(filesToUnzip);
} else {
await file.unzip;
}
this.$emit('file-upload', file);
} catch (error) {
console.error('Erreur lors du drag start :', error);
}
},
}, },
}; };
</script> </script>