ajout fonctionalite ecraser et annuler depot

This commit is contained in:
Alexandre_BRAVO 2024-11-26 15:31:47 +01:00
parent 5625de925a
commit b40b327901
3 changed files with 51 additions and 20 deletions

View File

@ -29,15 +29,17 @@
<!-- Appliquer l'ecrasement a tous --> <!-- Appliquer l'ecrasement a tous -->
<div v-if="displayOverwrite" class="bg-NcBlack rounded-lg shadow-lg p-6 w-96"> <div v-if="displayOverwrite" class="bg-NcBlack rounded-lg shadow-lg p-6 w-96">
<h2 class="text-lg font-semibold mb-4">Vous allez ecraser le fichier/dossier</h2>
<div class="flex items-center content-evenly"> <div class="flex items-center content-evenly">
<input type="checkbox" v-model="forAll" /> <input type="checkbox" v-model="forAll" />
<p>Appliquer à tous</p> <p>Appliquer à tous*</p>
</div> </div>
<p class="text-xs text-gray-400">* ecrasera tous les fichiers qui ont le même nom sur votre dépôt</p>
<div class="flex justify-end mt-4 space-x-2"> <div class="flex justify-end mt-4 space-x-2">
<button @click="onOverwrite" class="px-4 py-2 bg-gray-200 text-gray-700 rounded-md hover:bg-gray-300 transition">Valider</button> <button @click="onOverwrite" class="px-4 py-2 bg-gray-200 text-gray-700 rounded-md hover:bg-gray-300 transition">Valider</button>
<button @click="toggleOverwrite" class="px-4 py-2 bg-gray-200 text-gray-700 rounded-md hover:bg-gray-300 transition">Annuler</button> <button @click="toggleOverwrite" class="px-4 py-2 bg-gray-200 text-gray-700 rounded-md hover:bg-gray-300 transition">Annuler</button>
</div> </div>
</div> </div>
</div> </div>
</template> </template>

View File

@ -120,7 +120,7 @@
<EditFileName v-if="!editDialogDisabled" :initialFileName="initialFileName" :isDirectory="isDirectory" @update="updateFileName" @close="closeEditDialog"> <EditFileName v-if="!editDialogDisabled" :initialFileName="initialFileName" :isDirectory="isDirectory" @update="updateFileName" @close="closeEditDialog">
</EditFileName> </EditFileName>
<FileExistsDialog v-if="!fileExistDialogDisabled" :fileName="initialFileName" @overwrite="" @rename="" @cancel="closeFileExistsDialog"> <FileExistsDialog v-if="!fileExistDialogDisabled" :fileName="initialFileName" @overwrite="setOverwrite" @rename="" @cancel="cancelDrop">
</FileExistsDialog> </FileExistsDialog>
</div> </div>
</template> </template>
@ -182,6 +182,9 @@ export default {
isDirectory: false, // Si l'element a edite est un dossier ou non isDirectory: false, // Si l'element a edite est un dossier ou non
transferProgress: 0, transferProgress: 0,
transferStatus: 'bg-blue-500', transferStatus: 'bg-blue-500',
overwrite: false,
applyToAll: false,
cancelOperation: false,
}; };
}, },
async mounted() { async mounted() {
@ -307,12 +310,15 @@ export default {
this.isTransfering = false; this.isTransfering = false;
this.transferProgress = 0; this.transferProgress = 0;
this.cancelOperation = false;
} catch (error) { } catch (error) {
console.error('Erreur lors du drop :', error); console.error('Erreur lors du drop :', error);
this.transferStatus = 'bg-red-500'; this.transferStatus = 'bg-red-500';
this.isTransfering = false; this.isTransfering = false;
} }
this.overwrite = false;
this.applyToAll = false;
}, },
async moveFilesOfFolder(folder, parentPath) { async moveFilesOfFolder(folder, parentPath) {
await this.createFolder(folder, parentPath + '/'); await this.createFolder(folder, parentPath + '/');
@ -329,14 +335,16 @@ export default {
const progressSteps = Math.floor(100 / checkChildrenInChildren(folder)); const progressSteps = Math.floor(100 / checkChildrenInChildren(folder));
for (const child of folder.children) { for (const child of folder.children) {
this.transferProgress += progressSteps; if(!this.cancelOperation){
if (child.isDirectory) { this.transferProgress += progressSteps;
await this.moveFilesOfFolder(child, parentPath + '/' + child.parentPath + '/'); if (child.isDirectory) {
} else { await this.moveFilesOfFolder(child, parentPath + '/' + child.parentPath + '/');
if (child.content && typeof child.content.arrayBuffer === 'function') { } else {
child.content = await child.content.arrayBuffer(); if (child.content && typeof child.content.arrayBuffer === 'function') {
child.content = await child.content.arrayBuffer();
}
await this.moveFileToTarget(child, parentPath + '/' + child.parentPath + '/');
} }
await this.moveFileToTarget(child, parentPath + '/' + child.parentPath + '/');
} }
} }
}, },
@ -353,10 +361,14 @@ export default {
} }
const alreadyExists = await this.elemtAlreadyExists(fullPath); const alreadyExists = await this.elemtAlreadyExists(fullPath);
if(!alreadyExists) { if(!alreadyExists || this.overwrite) {
// Évitez les chemins incorrects en utilisant `path.normalize` si disponible // Évitez les chemins incorrects en utilisant `path.normalize` si disponible
await client.putFileContents(fullPath, file.content); await client.putFileContents(fullPath, file.content);
if (this.overwrite && !this.applyToAll) {
this.overwrite = false;
}
// Recharge les fichiers après l'opération // Recharge les fichiers après l'opération
await this.fetchFiles(); await this.fetchFiles();
} }
@ -366,6 +378,9 @@ export default {
while(!this.fileExistDialogDisabled) { while(!this.fileExistDialogDisabled) {
await this.sleep(50); await this.sleep(50);
} }
if(!this.cancelOperation){
await this.moveFileToTarget(file,parentPath);
}
} }
} catch (error) { } catch (error) {
console.error('Erreur lors du déplacement du fichier:', error); console.error('Erreur lors du déplacement du fichier:', error);
@ -382,12 +397,15 @@ export default {
await client.createDirectory(fullPath); await client.createDirectory(fullPath);
await this.fetchFiles(); await this.fetchFiles();
} }
else{ else if(!this.applyToAll){
this.initialFileName = folder.name; this.initialFileName = folder.name;
this.fileExistDialogDisabled = false; this.fileExistDialogDisabled = false;
while(!this.fileExistDialogDisabled) { while(!this.fileExistDialogDisabled) {
await this.sleep(); await this.sleep();
} }
if(this.overwrite && !this.applyToAll) {
this.overwrite = false;
}
} }
} catch (error) { } catch (error) {
console.error('Erreur lors de la création du dossier :', error); console.error('Erreur lors de la création du dossier :', error);
@ -452,6 +470,11 @@ export default {
await this.fetchFiles(); await this.fetchFiles();
} }
}, },
setOverwrite(options) {
this.overwrite = true;
this.applyToAll = options.forAll;
this.fileExistDialogDisabled = true;
},
/** /**
* Check si un fichier ou un dossier existe deja sur le serveur * Check si un fichier ou un dossier existe deja sur le serveur
* @param path le chemin du fichier/dossier * @param path le chemin du fichier/dossier
@ -462,6 +485,10 @@ export default {
return exists; return exists;
}, },
cancelDrop(){
this.cancelOperation = true;
this.closeFileExistsDialog();
},
async sleep(ms) { async sleep(ms) {
return new Promise(resolve => setTimeout(resolve, ms)); return new Promise(resolve => setTimeout(resolve, ms));
} }

View File

@ -579,10 +579,6 @@ video {
} }
} }
.visible {
visibility: visible;
}
.fixed { .fixed {
position: fixed; position: fixed;
} }
@ -741,10 +737,6 @@ video {
flex-direction: column; flex-direction: column;
} }
.content-center {
align-content: center;
}
.content-evenly { .content-evenly {
align-content: space-evenly; align-content: space-evenly;
} }
@ -909,6 +901,11 @@ video {
line-height: 1.75rem; line-height: 1.75rem;
} }
.text-xs {
font-size: 0.75rem;
line-height: 1rem;
}
.font-medium { .font-medium {
font-weight: 500; font-weight: 500;
} }
@ -942,6 +939,11 @@ video {
color: rgb(255 255 255 / var(--tw-text-opacity, 1)); color: rgb(255 255 255 / var(--tw-text-opacity, 1));
} }
.text-gray-400 {
--tw-text-opacity: 1;
color: rgb(156 163 175 / var(--tw-text-opacity, 1));
}
.shadow-lg { .shadow-lg {
--tw-shadow: 0 10px 15px -3px rgb(0 0 0 / 0.1), 0 4px 6px -4px rgb(0 0 0 / 0.1); --tw-shadow: 0 10px 15px -3px rgb(0 0 0 / 0.1), 0 4px 6px -4px rgb(0 0 0 / 0.1);
--tw-shadow-colored: 0 10px 15px -3px var(--tw-shadow-color), 0 4px 6px -4px var(--tw-shadow-color); --tw-shadow-colored: 0 10px 15px -3px var(--tw-shadow-color), 0 4px 6px -4px var(--tw-shadow-color);