import TabAwareWidget from "./tab_aware_widget.js"; import treeService from "../services/tree.js"; import linkService from "../services/link.js"; const TPL = `
`; export default class NotePathsWidget extends TabAwareWidget { doRender() { this.$widget = $(TPL); this.$currentPath = this.$widget.find('.current-path'); this.$dropdown = this.$widget.find(".dropdown"); this.$notePathList = this.$dropdown.find(".note-path-list"); this.$dropdown.on('show.bs.dropdown', () => this.renderDropdown()); return this.$widget; } async refreshWithNote(note, notePath) { let noteIdsPath = treeService.parseNotePath(notePath); noteIdsPath = noteIdsPath.slice(0, noteIdsPath.length - 1); this.$currentPath.empty(); let parentNoteId = 'root'; let curPath = ''; for (let i = 0; i < noteIdsPath.length; i++) { const noteId = noteIdsPath[i]; curPath += (curPath ? '/' : '') + noteId; this.$currentPath.append( $("") .attr('href', '#' + curPath) .addClass('no-tooltip-preview') .text(await treeService.getNoteTitle(noteId, parentNoteId)) ); if (i !== noteIdsPath.length - 1) { this.$currentPath.append(' / '); } parentNoteId = noteId; } const pathCount = note.noteId === 'root' ? 1 // root doesn't have any parent, but it's still technically 1 path : note.getBranchIds().length; this.$notePathCount.html(pathCount + " path" + (pathCount > 1 ? "s" : "")); } async renderDropdown() { this.$notePathList.empty(); if (this.noteId === 'root') { await this.addPath('root', true); return; } const pathSegments = treeService.parseNotePath(this.notePath); const activeNoteParentNoteId = pathSegments[pathSegments.length - 2]; // we know this is not root so there must be a parent for (const parentNote of this.note.getParentNotes()) { const parentNotePath = await treeService.getSomeNotePath(parentNote); // this is to avoid having root notes leading '/' const notePath = parentNotePath ? (parentNotePath + '/' + this.noteId) : this.noteId; const isCurrent = activeNoteParentNoteId === parentNote.noteId; await this.addPath(notePath, isCurrent); } const cloneLink = $("
") .addClass("dropdown-item") .append( $('