2020-04-26 09:40:02 +02:00
|
|
|
import linkService from "../../services/link.js";
|
|
|
|
import server from "../../services/server.js";
|
2021-04-16 23:01:56 +02:00
|
|
|
import froca from "../../services/froca.js";
|
2023-01-03 14:31:46 +01:00
|
|
|
import NoteContextAwareWidget from "../note_context_aware_widget.js";
|
2023-08-09 22:50:41 +02:00
|
|
|
import options from "../../services/options.js";
|
2024-08-05 10:26:40 +08:00
|
|
|
import { t } from "../../services/i18n.js";
|
2019-09-07 10:11:59 +02:00
|
|
|
|
2021-02-01 20:55:35 +01:00
|
|
|
const TPL = `
|
|
|
|
<div class="edited-notes-widget">
|
2021-07-05 14:56:40 +02:00
|
|
|
<style>
|
|
|
|
.edited-notes-widget {
|
|
|
|
padding: 12px;
|
|
|
|
max-height: 200px;
|
|
|
|
width: 100%;
|
|
|
|
overflow: auto;
|
2021-02-01 20:55:35 +01:00
|
|
|
}
|
|
|
|
</style>
|
2021-02-21 22:45:32 +01:00
|
|
|
|
2024-08-05 10:26:40 +08:00
|
|
|
<div class="no-edited-notes-found">${t("edited_notes.no_edited_notes_found")}</div>
|
2021-02-21 22:45:32 +01:00
|
|
|
|
|
|
|
<div class="edited-notes-list"></div>
|
2021-02-01 20:55:35 +01:00
|
|
|
</div>
|
|
|
|
`;
|
|
|
|
|
2023-01-03 14:31:46 +01:00
|
|
|
export default class EditedNotesWidget extends NoteContextAwareWidget {
|
2021-07-05 14:56:40 +02:00
|
|
|
get name() {
|
|
|
|
return "editedNotes";
|
2019-09-09 21:23:04 +02:00
|
|
|
}
|
|
|
|
|
2020-02-08 21:54:39 +01:00
|
|
|
isEnabled() {
|
2025-01-09 18:07:02 +02:00
|
|
|
return super.isEnabled() && this.note.hasOwnedLabel("dateNote");
|
2019-09-07 10:11:59 +02:00
|
|
|
}
|
|
|
|
|
2021-07-05 14:56:40 +02:00
|
|
|
getTitle() {
|
|
|
|
return {
|
|
|
|
show: this.isEnabled(),
|
2021-10-08 22:13:39 +02:00
|
|
|
// promoted attributes have priority over edited notes
|
2025-01-09 18:07:02 +02:00
|
|
|
activate: (this.note.getPromotedDefinitionAttributes().length === 0 || !options.is("promotedAttributesOpenInRibbon")) && options.is("editedNotesOpenInRibbon"),
|
2024-08-05 10:26:40 +08:00
|
|
|
title: t("edited_notes.title"),
|
2025-01-09 18:07:02 +02:00
|
|
|
icon: "bx bx-calendar-edit"
|
2021-07-05 14:56:40 +02:00
|
|
|
};
|
|
|
|
}
|
|
|
|
|
|
|
|
async doRender() {
|
|
|
|
this.$widget = $(TPL);
|
|
|
|
this.contentSized();
|
2025-01-09 18:07:02 +02:00
|
|
|
this.$list = this.$widget.find(".edited-notes-list");
|
|
|
|
this.$noneFound = this.$widget.find(".no-edited-notes-found");
|
2021-02-01 20:55:35 +01:00
|
|
|
}
|
|
|
|
|
2020-02-02 20:02:08 +01:00
|
|
|
async refreshWithNote(note) {
|
2022-12-21 15:19:05 +01:00
|
|
|
let editedNotes = await server.get(`edited-notes/${note.getLabelValue("dateNote")}`);
|
2019-09-07 10:11:59 +02:00
|
|
|
|
2025-01-09 18:07:02 +02:00
|
|
|
editedNotes = editedNotes.filter((n) => n.noteId !== note.noteId);
|
2019-09-07 10:11:59 +02:00
|
|
|
|
2021-02-21 22:45:32 +01:00
|
|
|
this.$list.empty();
|
|
|
|
this.$noneFound.hide();
|
|
|
|
|
2019-09-07 10:11:59 +02:00
|
|
|
if (editedNotes.length === 0) {
|
2021-02-21 22:45:32 +01:00
|
|
|
this.$noneFound.show();
|
2019-09-07 10:11:59 +02:00
|
|
|
return;
|
|
|
|
}
|
|
|
|
|
2025-01-09 18:07:02 +02:00
|
|
|
const noteIds = editedNotes.flatMap((n) => n.noteId);
|
2019-09-07 10:11:59 +02:00
|
|
|
|
2021-04-16 22:57:37 +02:00
|
|
|
await froca.getNotes(noteIds, true); // preload all at once
|
2019-09-07 10:11:59 +02:00
|
|
|
|
2021-07-05 14:56:40 +02:00
|
|
|
for (let i = 0; i < editedNotes.length; i++) {
|
|
|
|
const editedNote = editedNotes[i];
|
|
|
|
const $item = $('<span class="edited-note-line">');
|
2019-09-07 10:11:59 +02:00
|
|
|
|
2019-10-22 21:59:51 +02:00
|
|
|
if (editedNote.isDeleted) {
|
2024-08-05 10:26:40 +08:00
|
|
|
const title = `${editedNote.title} ${t("edited_notes.deleted")}`;
|
2025-01-09 18:07:02 +02:00
|
|
|
$item.append($("<i>").text(title).attr("title", title));
|
|
|
|
} else {
|
|
|
|
$item.append(editedNote.notePath ? await linkService.createLink(editedNote.notePath.join("/"), { showNotePath: true }) : $("<span>").text(editedNote.title));
|
2019-09-07 10:11:59 +02:00
|
|
|
}
|
|
|
|
|
2021-07-05 14:56:40 +02:00
|
|
|
if (i < editedNotes.length - 1) {
|
|
|
|
$item.append(", ");
|
|
|
|
}
|
|
|
|
|
2021-02-21 22:45:32 +01:00
|
|
|
this.$list.append($item);
|
2019-09-07 10:11:59 +02:00
|
|
|
}
|
|
|
|
}
|
2021-02-01 20:55:35 +01:00
|
|
|
}
|