ajout de la fonctionnalite de rename on drop
This commit is contained in:
parent
28d6b8d176
commit
2195b52200
@ -5,7 +5,7 @@
|
|||||||
<p>Le fichier "{{ fileName }}" existe déjà. Que voulez-vous faire ?</p>
|
<p>Le fichier "{{ fileName }}" existe déjà. Que voulez-vous faire ?</p>
|
||||||
<div class="flex justify-end mt-4 space-x-2">
|
<div class="flex justify-end mt-4 space-x-2">
|
||||||
<button @click="toggleOverwrite">Écraser</button>
|
<button @click="toggleOverwrite">Écraser</button>
|
||||||
<button @click="toggleRename">Renommer</button>
|
<button v-if="!isDirectory" @click="toggleRename">Renommer</button>
|
||||||
<button @click="onCancel">Annuler</button>
|
<button @click="onCancel">Annuler</button>
|
||||||
</div>
|
</div>
|
||||||
</div>
|
</div>
|
||||||
@ -49,10 +49,13 @@ export default {
|
|||||||
fileName: {
|
fileName: {
|
||||||
type: String,
|
type: String,
|
||||||
required: true
|
required: true
|
||||||
|
},
|
||||||
|
isDirectory:{
|
||||||
|
type: Boolean,
|
||||||
|
required: true,
|
||||||
}
|
}
|
||||||
},
|
},
|
||||||
data() {
|
data() {
|
||||||
var oldFileName = this.fileName;
|
|
||||||
var newFileName = this.fileName;
|
var newFileName = this.fileName;
|
||||||
var extension = '';
|
var extension = '';
|
||||||
if(!this.isDirectory) {
|
if(!this.isDirectory) {
|
||||||
@ -66,7 +69,6 @@ export default {
|
|||||||
displayRename: false,
|
displayRename: false,
|
||||||
displayOverwrite: false,
|
displayOverwrite: false,
|
||||||
forAll: false,
|
forAll: false,
|
||||||
oldFileName,
|
|
||||||
newFileName,
|
newFileName,
|
||||||
extension,
|
extension,
|
||||||
}
|
}
|
||||||
@ -96,7 +98,7 @@ export default {
|
|||||||
this.newFileName = newFileNameWithOriginalExtension;
|
this.newFileName = newFileNameWithOriginalExtension;
|
||||||
}
|
}
|
||||||
|
|
||||||
this.$emit("rename", { oldFileName: this.oldFileName, newFileName: this.newFileName });
|
this.$emit("rename", { newFileName: this.newFileName });
|
||||||
}
|
}
|
||||||
},
|
},
|
||||||
onInputChange() {
|
onInputChange() {
|
||||||
|
@ -128,7 +128,7 @@
|
|||||||
<EditFileName v-if="!editDialogDisabled" :initialFileName="initialFileName" :isDirectory="isDirectory"
|
<EditFileName v-if="!editDialogDisabled" :initialFileName="initialFileName" :isDirectory="isDirectory"
|
||||||
@update="updateFileName" @close="closeEditDialog">
|
@update="updateFileName" @close="closeEditDialog">
|
||||||
</EditFileName>
|
</EditFileName>
|
||||||
<FileExistsDialog v-if="!fileExistDialogDisabled" :fileName="initialFileName" @overwrite="setOverwrite" @rename="" @cancel="cancelDrop">
|
<FileExistsDialog v-if="!fileExistDialogDisabled" :fileName="initialFileName" :isDirectory="isDirectory" @overwrite="setOverwrite" @rename="setRename" @cancel="cancelDrop">
|
||||||
</FileExistsDialog>
|
</FileExistsDialog>
|
||||||
</div>
|
</div>
|
||||||
</template>
|
</template>
|
||||||
@ -196,6 +196,8 @@ export default {
|
|||||||
overwrite: false,
|
overwrite: false,
|
||||||
applyToAll: false,
|
applyToAll: false,
|
||||||
cancelOperation: false,
|
cancelOperation: false,
|
||||||
|
rename: false,
|
||||||
|
newElemName: '',
|
||||||
};
|
};
|
||||||
},
|
},
|
||||||
async mounted() {
|
async mounted() {
|
||||||
@ -259,7 +261,6 @@ export default {
|
|||||||
try {
|
try {
|
||||||
const client = getClient();
|
const client = getClient();
|
||||||
let filePath = '';
|
let filePath = '';
|
||||||
console.log(this.newFileName)
|
|
||||||
if (this.current_dir[this.current_dir.length - 1] === '/') {
|
if (this.current_dir[this.current_dir.length - 1] === '/') {
|
||||||
filePath = `${this.root_path}${this.current_dir}${this.newFileName}`;
|
filePath = `${this.root_path}${this.current_dir}${this.newFileName}`;
|
||||||
}
|
}
|
||||||
@ -349,6 +350,8 @@ export default {
|
|||||||
}
|
}
|
||||||
this.overwrite = false;
|
this.overwrite = false;
|
||||||
this.applyToAll = false;
|
this.applyToAll = false;
|
||||||
|
this.rename = false;
|
||||||
|
this.newElemName = '';
|
||||||
},
|
},
|
||||||
async moveFilesOfFolder(folder, parentPath) {
|
async moveFilesOfFolder(folder, parentPath) {
|
||||||
await this.createFolder(folder, parentPath + '/');
|
await this.createFolder(folder, parentPath + '/');
|
||||||
@ -378,13 +381,22 @@ export default {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
},
|
},
|
||||||
async moveFileToTarget(file, parentPath) {
|
async moveFileToTarget(file, parentPath, newName = null) {
|
||||||
|
this.isDirectory = false;
|
||||||
try {
|
try {
|
||||||
const client = getClient();
|
const client = getClient();
|
||||||
// Assurez-vous que le chemin parent est correctement formaté
|
// Assurez-vous que le chemin parent est correctement formaté
|
||||||
|
|
||||||
let fullPath = '';
|
let fullPath = '';
|
||||||
|
if(!this.rename) {
|
||||||
fullPath = `${this.root_path}${this.current_dir}${parentPath}${file.name}`;
|
fullPath = `${this.root_path}${this.current_dir}${parentPath}${file.name}`;
|
||||||
|
}
|
||||||
|
else if (this.rename && newName){
|
||||||
|
fullPath = `${this.root_path}${this.current_dir}${parentPath}${newName}`;
|
||||||
|
}
|
||||||
|
else {
|
||||||
|
return null;
|
||||||
|
}
|
||||||
|
|
||||||
if (ArrayBuffer.isView(file.content)) {
|
if (ArrayBuffer.isView(file.content)) {
|
||||||
file.content = Buffer.from(file.content);
|
file.content = Buffer.from(file.content);
|
||||||
@ -409,14 +421,21 @@ export default {
|
|||||||
await this.sleep(50);
|
await this.sleep(50);
|
||||||
}
|
}
|
||||||
if(!this.cancelOperation){
|
if(!this.cancelOperation){
|
||||||
|
if(this.rename) {
|
||||||
|
await this.moveFileToTarget(file, parentPath, this.newElemName);
|
||||||
|
this.rename = false;
|
||||||
|
}
|
||||||
|
else{
|
||||||
await this.moveFileToTarget(file,parentPath);
|
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);
|
||||||
}
|
}
|
||||||
},
|
},
|
||||||
async createFolder(folder, parentPath) {
|
async createFolder(folder, parentPath) {
|
||||||
|
this.isDirectory = true;
|
||||||
try {
|
try {
|
||||||
const client = getClient();
|
const client = getClient();
|
||||||
let fullPath = '';
|
let fullPath = '';
|
||||||
@ -505,6 +524,11 @@ export default {
|
|||||||
this.applyToAll = options.forAll;
|
this.applyToAll = options.forAll;
|
||||||
this.fileExistDialogDisabled = true;
|
this.fileExistDialogDisabled = true;
|
||||||
},
|
},
|
||||||
|
setRename(options) {
|
||||||
|
this.rename = true;
|
||||||
|
this.newElemName = options.newFileName;
|
||||||
|
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
|
||||||
|
Loading…
x
Reference in New Issue
Block a user