96 lines
2.8 KiB
JavaScript
Raw Normal View History

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";
import options from "../../services/options.js";
2019-09-07 10:11:59 +02: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;
}
</style>
<div class="no-edited-notes-found">No edited notes on this day yet ...</div>
<div class="edited-notes-list"></div>
</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";
}
isEnabled() {
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(),
// promoted attributes have priority over edited notes
activate:
(this.note.getPromotedDefinitionAttributes().length === 0 || !options.is('promotedAttributesOpenInRibbon'))
&& options.is('editedNotesOpenInRibbon'),
2021-07-05 14:56:40 +02:00
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');
}
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
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) {
const title = `${editedNote.title} (deleted)`;
$item.append(
$("<i>")
.text(title)
.attr("title", title)
);
2019-09-08 11:25:57 +02:00
}
else {
2022-07-05 22:40:41 +02:00
$item.append(editedNote.notePath
2023-05-29 00:19:54 +02:00
? await linkService.createLink(editedNote.notePath.join("/"), {showNotePath: true})
2022-07-05 22:40:41 +02:00
: $("<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(", ");
}
this.$list.append($item);
2019-09-07 10:11:59 +02:00
}
}
}