2024-11-21 17:34:13 +01:00
|
|
|
<template>
|
|
|
|
<div class="fixed inset-0 flex items-center justify-center bg-gray-700 bg-opacity-50 z-50" @click="closeModal">
|
2024-12-02 14:26:17 +01:00
|
|
|
<div class="dark:bg-NcBlack bg-white rounded-lg shadow-lg p-6 w-96" @click.stop>
|
2024-11-29 17:28:47 +01:00
|
|
|
<h2 class="text-lg font-semibold mb-4">{{ translate('modify.file.name') }}</h2>
|
2024-11-21 17:34:13 +01:00
|
|
|
<input
|
|
|
|
type="text"
|
|
|
|
v-model="newFileName"
|
|
|
|
@input="onInputChange"
|
|
|
|
@keyup.enter="save"
|
|
|
|
placeholder="Entrez le nom du fichier"
|
|
|
|
class="w-full px-4 py-2 border rounded-md focus:outline-none focus:ring-2 focus:ring-blue-500"
|
|
|
|
/>
|
|
|
|
<div class="flex justify-end mt-4 space-x-2">
|
2024-11-29 17:28:47 +01:00
|
|
|
<button @click="save" class="px-4 py-2 bg-gray-200 text-gray-700 rounded-md hover:bg-gray-300 transition">{{ translate('rename') }}</button>
|
|
|
|
<button @click="closeModal" class="px-4 py-2 bg-gray-200 text-gray-700 rounded-md hover:bg-gray-300 transition">{{ translate('cancel') }}</button>
|
2024-11-21 17:34:13 +01:00
|
|
|
</div>
|
|
|
|
</div>
|
|
|
|
</div>
|
|
|
|
</template>
|
|
|
|
|
|
|
|
<script>
|
|
|
|
export default {
|
|
|
|
name: "FileNameEditor",
|
|
|
|
props: {
|
|
|
|
initialFileName: {
|
2024-11-22 14:42:45 +01:00
|
|
|
type: String,
|
|
|
|
required: true,
|
2024-11-21 17:34:13 +01:00
|
|
|
},
|
2024-11-22 14:42:45 +01:00
|
|
|
isDirectory:{
|
|
|
|
type: Boolean,
|
|
|
|
required: true,
|
2024-11-29 17:28:47 +01:00
|
|
|
},
|
|
|
|
translate: {
|
|
|
|
type: Function,
|
|
|
|
Required: true,
|
2024-11-22 14:42:45 +01:00
|
|
|
}
|
2024-11-21 17:34:13 +01:00
|
|
|
},
|
|
|
|
data() {
|
|
|
|
var newFileName = this.initialFileName;
|
|
|
|
var extension = '';
|
2024-11-22 14:42:45 +01:00
|
|
|
if(!this.isDirectory) {
|
|
|
|
let nameSplit = newFileName.split('.');
|
|
|
|
if (nameSplit.length > 1) {
|
|
|
|
extension = nameSplit.pop();
|
|
|
|
}
|
2024-11-21 17:34:13 +01:00
|
|
|
}
|
2024-11-22 14:42:45 +01:00
|
|
|
|
2024-11-21 17:34:13 +01:00
|
|
|
return {
|
|
|
|
newFileName,
|
|
|
|
extension,
|
|
|
|
};
|
|
|
|
},
|
|
|
|
methods: {
|
|
|
|
save() {
|
|
|
|
if(this.newFileName !== ''){
|
|
|
|
// Séparer le nom de fichier sans l'extension
|
|
|
|
const fileNameWithoutExtension = this.newFileName.slice(0, this.newFileName.lastIndexOf('.'));
|
2024-11-28 14:21:35 +01:00
|
|
|
const fileNameWithoutPoints = fileNameWithoutExtension.replace(/\./g, "");
|
|
|
|
if (fileNameWithoutPoints !== '') {
|
2024-11-28 14:16:59 +01:00
|
|
|
// Re-construire le nom du fichier avec l'extension d'origine
|
|
|
|
const newFileNameWithOriginalExtension = fileNameWithoutExtension + '.' + this.extension;
|
2024-11-21 17:34:13 +01:00
|
|
|
|
2024-11-28 14:16:59 +01:00
|
|
|
if (!this.isDirectory && this.newFileName !== newFileNameWithOriginalExtension) {
|
|
|
|
// L'extension a été modifiée, on rétablit l'extension correcte
|
|
|
|
this.newFileName = newFileNameWithOriginalExtension;
|
|
|
|
}
|
2024-11-21 17:34:13 +01:00
|
|
|
|
2024-11-28 14:16:59 +01:00
|
|
|
this.$emit("update", { initialFileName: this.initialFileName, newFileName: this.newFileName });
|
|
|
|
this.closeModal();
|
|
|
|
}
|
2024-11-21 17:34:13 +01:00
|
|
|
}
|
|
|
|
},
|
|
|
|
closeModal() {
|
|
|
|
this.$emit("close");
|
|
|
|
},
|
|
|
|
onInputChange() {
|
2024-11-22 14:42:45 +01:00
|
|
|
if (!this.isDirectory) {
|
|
|
|
const fileNameWithoutExtension = this.newFileName.slice(0, this.newFileName.lastIndexOf('.'));
|
|
|
|
const newFileNameWithOriginalExtension = fileNameWithoutExtension + '.' + this.extension;
|
2024-11-21 17:34:13 +01:00
|
|
|
|
2024-11-22 14:42:45 +01:00
|
|
|
// Si l'extension est différente de celle d'origine, on la rétablit
|
|
|
|
if (this.extension !== '' && this.newFileName !== newFileNameWithOriginalExtension) {
|
|
|
|
// Vous pouvez ici vérifier si l'extension a été modifiée et la rétablir
|
|
|
|
|
|
|
|
this.newFileName = newFileNameWithOriginalExtension;
|
|
|
|
}
|
2024-11-21 17:34:13 +01:00
|
|
|
}
|
|
|
|
},
|
|
|
|
},
|
|
|
|
};
|
|
|
|
</script>
|
|
|
|
|
|
|
|
<style scoped>
|
|
|
|
|
|
|
|
</style>
|