78 lines
2.3 KiB
JavaScript
Raw Normal View History

2020-04-26 09:40:02 +02:00
import CollapsibleWidget from "../collapsible_widget.js";
import linkService from "../../services/link.js";
import server from "../../services/server.js";
import treeCache from "../../services/tree_cache.js";
2019-09-07 10:11:59 +02:00
const TPL = `
<div class="edited-notes-widget">
<style>
.edited-notes-widget .edited-note-line {
white-space: nowrap;
overflow-x: hidden;
text-overflow: ellipsis;
}
</style>
<div class="no-edited-notes-found">No edited notes on this day yet ...</div>
<div class="edited-notes-list"></div>
</div>
`;
2020-02-02 20:02:08 +01:00
export default class EditedNotesWidget extends CollapsibleWidget {
2020-03-16 22:14:18 +01:00
get widgetTitle() { return "Edited notes on this day"; }
2019-09-07 10:11:59 +02:00
2020-03-16 22:14:18 +01:00
get help() {
return {
title: "This contains a list of notes created or updated on this day."
};
}
isEnabled() {
return super.isEnabled()
&& this.note.hasOwnedLabel("dateNote");
2019-09-07 10:11:59 +02:00
}
async doRenderBody() {
this.$body.html(TPL);
this.$list = this.$body.find('.edited-notes-list');
this.$noneFound = this.$body.find('.no-edited-notes-found');
}
2020-02-02 20:02:08 +01:00
async refreshWithNote(note) {
let editedNotes = await server.get('edited-notes/' + note.getLabelValue("dateNote"));
2019-09-07 10:11:59 +02:00
editedNotes = editedNotes.filter(n => n.noteId !== note.noteId);
2019-09-07 10:11:59 +02:00
this.$list.empty();
this.$noneFound.hide();
2019-09-07 10:11:59 +02:00
if (editedNotes.length === 0) {
this.$noneFound.show();
2019-09-07 10:11:59 +02:00
return;
}
const noteIds = editedNotes.flatMap(n => n.noteId);
2019-09-07 10:11:59 +02:00
2019-09-08 11:25:57 +02:00
await treeCache.getNotes(noteIds, true); // preload all at once
2019-09-07 10:11:59 +02:00
for (const editedNote of editedNotes) {
const $item = $('<div class="edited-note-line">');
2019-09-07 10:11:59 +02:00
2019-10-22 21:59:51 +02:00
if (editedNote.isDeleted) {
const title = editedNote.title + " (deleted)";
$item.append(
$("<i>")
.text(title)
.attr("title", title)
);
2019-09-08 11:25:57 +02:00
}
else {
2019-12-28 21:10:02 +01:00
$item.append(editedNote.notePath ? await linkService.createNoteLink(editedNote.notePath.join("/"), {showNotePath: true}) : editedNote.title);
2019-09-07 10:11:59 +02:00
}
this.$list.append($item);
2019-09-07 10:11:59 +02:00
}
}
}