2017-12-14 18:53:08 +00:00
|
|
|
const Note = require('lib/models/Note.js');
|
2017-10-07 23:17:10 +01:00
|
|
|
const ListWidget = require('tkwidgets/ListWidget.js');
|
|
|
|
|
|
|
|
class NoteListWidget extends ListWidget {
|
|
|
|
constructor() {
|
|
|
|
super();
|
|
|
|
this.selectedNoteId_ = 0;
|
|
|
|
|
2017-10-09 20:57:00 +01:00
|
|
|
this.updateIndexFromSelectedNoteId_ = false;
|
|
|
|
|
2019-07-30 09:35:42 +02:00
|
|
|
this.itemRenderer = note => {
|
2017-12-26 11:38:53 +01:00
|
|
|
let label = Note.displayTitle(note); // + ' ' + note.id;
|
2017-10-09 20:57:00 +01:00
|
|
|
if (note.is_todo) {
|
2019-09-19 22:51:18 +01:00
|
|
|
label = `[${note.todo_completed ? 'X' : ' '}] ${label}`;
|
2017-10-09 20:57:00 +01:00
|
|
|
}
|
|
|
|
return label;
|
|
|
|
};
|
2017-10-07 23:17:10 +01:00
|
|
|
}
|
|
|
|
|
|
|
|
set selectedNoteId(v) {
|
2017-10-09 20:57:00 +01:00
|
|
|
this.updateIndexFromSelectedNoteId_ = true;
|
2017-10-07 23:17:10 +01:00
|
|
|
this.selectedNoteId_ = v;
|
2017-10-09 20:57:00 +01:00
|
|
|
}
|
|
|
|
|
|
|
|
render() {
|
|
|
|
if (this.updateIndexFromSelectedNoteId_) {
|
|
|
|
const index = this.itemIndexByKey('id', this.selectedNoteId_);
|
|
|
|
this.currentIndex = index >= 0 ? index : 0;
|
|
|
|
this.updateIndexFromSelectedNoteId_ = false;
|
|
|
|
}
|
|
|
|
|
|
|
|
super.render();
|
2017-10-07 23:17:10 +01:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2019-07-30 09:35:42 +02:00
|
|
|
module.exports = NoteListWidget;
|