Notes/src/public/app/widgets/dialogs/upload_attachments.js

104 lines
4.2 KiB
JavaScript
Raw Normal View History

2024-07-25 17:14:08 +08:00
import { t } from "../../services/i18n.js";
import utils from '../../services/utils.js';
import treeService from "../../services/tree.js";
import importService from "../../services/import.js";
import options from "../../services/options.js";
import BasicWidget from "../basic_widget.js";
const TPL = `
<div class="upload-attachments-dialog modal fade mx-auto" tabindex="-1" role="dialog">
<div class="modal-dialog modal-lg" role="document">
<div class="modal-content">
<div class="modal-header">
2024-07-25 17:14:08 +08:00
<h5 class="modal-title">${t("upload_attachments.upload_attachments_to_note")}</h5>
<button type="button" class="close" data-dismiss="modal" aria-label="Close">
<span aria-hidden="true">&times;</span>
</button>
</div>
<form class="upload-attachment-form">
<div class="modal-body">
<div class="form-group">
2024-07-25 17:14:08 +08:00
<label for="upload-attachment-file-upload-input"><strong>${t("upload_attachments.choose_files")}</strong></label>
<input type="file" class="upload-attachment-file-upload-input form-control-file" multiple />
2024-07-25 17:14:08 +08:00
<p>${t("upload_attachments.files_will_be_uploaded")} <strong class="upload-attachment-note-title"></strong>.</p>
</div>
<div class="form-group">
2024-07-25 17:14:08 +08:00
<strong>${t("upload_attachments.options")}:</strong>
<div class="checkbox">
2024-07-25 17:14:08 +08:00
<label data-toggle="tooltip" title="${t("upload_attachments.tooltip")}">
<input class="shrink-images-checkbox" value="1" type="checkbox" checked> <span>${t("upload_attachments.shrink_images")}</span>
</label>
</div>
</div>
</div>
<div class="modal-footer">
2024-07-25 17:14:08 +08:00
<button class="upload-attachment-button btn btn-primary">${t("upload_attachments.upload")}</button>
</div>
</form>
</div>
</div>
</div>`;
export default class UploadAttachmentsDialog extends BasicWidget {
constructor() {
super();
this.parentNoteId = null;
}
doRender() {
this.$widget = $(TPL);
this.$form = this.$widget.find(".upload-attachment-form");
this.$noteTitle = this.$widget.find(".upload-attachment-note-title");
this.$fileUploadInput = this.$widget.find(".upload-attachment-file-upload-input");
this.$uploadButton = this.$widget.find(".upload-attachment-button");
this.$shrinkImagesCheckbox = this.$widget.find(".shrink-images-checkbox");
this.$form.on('submit', () => {
// disabling so that import is not triggered again.
this.$uploadButton.attr("disabled", "disabled");
this.uploadAttachments(this.parentNoteId);
return false;
});
this.$fileUploadInput.on('change', () => {
if (this.$fileUploadInput.val()) {
this.$uploadButton.removeAttr("disabled");
}
else {
this.$uploadButton.attr("disabled", "disabled");
}
});
this.$widget.find('[data-toggle="tooltip"]').tooltip({
html: true
});
}
async showUploadAttachmentsDialogEvent({noteId}) {
this.parentNoteId = noteId;
this.$fileUploadInput.val('').trigger('change'); // to trigger upload button disabling listener below
this.$shrinkImagesCheckbox.prop("checked", options.is('compressImages'));
this.$noteTitle.text(await treeService.getNoteTitle(this.parentNoteId));
utils.openDialog(this.$widget);
}
async uploadAttachments(parentNoteId) {
const files = Array.from(this.$fileUploadInput[0].files); // shallow copy since we're resetting the upload button below
const boolToString = $el => $el.is(":checked") ? "true" : "false";
const options = {
shrinkImages: boolToString(this.$shrinkImagesCheckbox),
};
this.$widget.modal('hide');
await importService.uploadFiles('attachments', parentNoteId, files, options);
}
}