import CollapsibleWidget from "../collapsible_widget.js"; import linkService from "../../services/link.js"; import server from "../../services/server.js"; import froca from "../../services/froca.js"; const TPL = `
`; export default class EditedNotesWidget extends CollapsibleWidget { get name() { return "editedNotes"; } isEnabled() { return super.isEnabled() && this.note.hasOwnedLabel("dateNote"); } getTitle() { return { show: this.isEnabled(), activate: true, title: 'Edited Notes', icon: 'bx bx-calendar-edit' }; } async doRender() { this.$widget = $(TPL); this.contentSized(); this.$list = this.$widget.find('.edited-notes-list'); this.$noneFound = this.$widget.find('.no-edited-notes-found'); } async refreshWithNote(note) { let editedNotes = await server.get('edited-notes/' + note.getLabelValue("dateNote")); editedNotes = editedNotes.filter(n => n.noteId !== note.noteId); this.$list.empty(); this.$noneFound.hide(); if (editedNotes.length === 0) { this.$noneFound.show(); return; } const noteIds = editedNotes.flatMap(n => n.noteId); await froca.getNotes(noteIds, true); // preload all at once for (let i = 0; i < editedNotes.length; i++) { const editedNote = editedNotes[i]; const $item = $(''); if (editedNote.isDeleted) { const title = editedNote.title + " (deleted)"; $item.append( $("") .text(title) .attr("title", title) ); } else { $item.append(editedNote.notePath ? await linkService.createNoteLink(editedNote.notePath.join("/"), {showNotePath: true}) : editedNote.title); } if (i < editedNotes.length - 1) { $item.append(", "); } this.$list.append($item); } } }