mirror of
https://github.com/scinote-eln/scinote-web.git
synced 2024-11-16 14:17:00 +08:00
98 lines
3 KiB
Vue
98 lines
3 KiB
Vue
<template>
|
|
<div ref="modal" @keydown.esc="close" class="modal" id="renameAttachmentModal" tabindex="-1" role="dialog">
|
|
<div class="modal-dialog modal-sm" role="document">
|
|
<div class="modal-content">
|
|
<div class="modal-header">
|
|
<button type="button" class="close" data-dismiss="modal" aria-label="Close"><i class="sn-icon sn-icon-close"></i></button>
|
|
<h4 class="modal-title">
|
|
{{ i18n.t('assets.rename_modal.title') }}
|
|
</h4>
|
|
</div>
|
|
<div class="modal-body">
|
|
<label class="sci-label">
|
|
{{ i18n.t('assets.from_clipboard.file_name')}}
|
|
</label>
|
|
<div class="flex gap-1 items-center">
|
|
<div class="sci-input-container" :class="{ 'error': error }" :data-error-text="error">
|
|
<input ref="input" v-model="name" type="text" class="sci-input-field" @keyup.enter="renameAttachment(name)" required="true" />
|
|
</div>
|
|
<div v-if="this.attachment.attributes.file_extension" class="shrink-0">.{{ this.attachment.attributes.file_extension }}</div>
|
|
</div>
|
|
</div>
|
|
<div class="modal-footer">
|
|
<button class="btn btn-secondary" @click="close">{{ i18n.t('general.cancel') }}</button>
|
|
<button class="btn btn-primary" @click="renameAttachment(name)" :disabled="error">{{ this.i18n.t('assets.context_menu.rename') }}</button>
|
|
</div>
|
|
</div>
|
|
</div>
|
|
</div>
|
|
</template>
|
|
|
|
<script>
|
|
import modalMixin from '../../modal_mixin';
|
|
import axios from '../../../../packs/custom_axios.js';
|
|
|
|
export default {
|
|
name: 'RenameAttachmentModal',
|
|
mixins: [modalMixin],
|
|
props: {
|
|
attachment: {
|
|
type: Object,
|
|
required: true
|
|
},
|
|
},
|
|
data() {
|
|
return {
|
|
name: null,
|
|
error: null
|
|
};
|
|
},
|
|
created() {
|
|
this.name = this.attachment.attributes.file_name_without_extension;
|
|
},
|
|
watch: {
|
|
name() {
|
|
this.validateName();
|
|
}
|
|
},
|
|
methods: {
|
|
validateName() {
|
|
if (!this.name || this.name.length === 0) {
|
|
this.error = this.i18n.t('assets.rename_modal.min_length_error');
|
|
} else if (this.name.length > 255) {
|
|
this.error = this.i18n.t('assets.rename_modal.max_length_error');
|
|
} else {
|
|
this.error = null;
|
|
return true;
|
|
}
|
|
return false;
|
|
},
|
|
async renameAttachment(newName) {
|
|
if (!this.validateName()) {
|
|
return;
|
|
}
|
|
|
|
let fileName = '';
|
|
|
|
if (this.attachment.attributes.file_extension) {
|
|
fileName = `${newName}.${this.attachment.attributes.file_extension}`;
|
|
} else {
|
|
fileName = newName;
|
|
}
|
|
|
|
const payload = { asset: { name: fileName } };
|
|
try {
|
|
const response = await axios.patch(this.attachment.attributes.urls.rename, payload);
|
|
this.$emit('attachment:update', response.data.data);
|
|
this.close();
|
|
} catch (error) {
|
|
if (error.response) {
|
|
this.error = error.response.data.errors || error.response.statusText;
|
|
} else {
|
|
this.error = error.message;
|
|
}
|
|
}
|
|
}
|
|
}
|
|
};
|
|
</script>
|