X-Git-Url: http://git.scottworley.com/vopamoi/blobdiff_plain/c948f3b419535ad0774392636d2fd1166fb6e312..3a1649301b207e07fcfa1eb0a617e4c5b2f775e8:/vopamoi.ts diff --git a/vopamoi.ts b/vopamoi.ts index 6ba608a..f624db1 100644 --- a/vopamoi.ts +++ b/vopamoi.ts @@ -120,6 +120,17 @@ const Model = { } }, + insertInPriorityOrder: function (task: Element, dest: Element) { + const priority = this.getPriority(task); + for (const t of dest.children) { + if (t !== task && this.getPriority(t) < priority) { + dest.insertBefore(task, t); + return; + } + } + dest.appendChild(task); + }, + removeTag: function (createTimestamp: string, tagName: string) { const task = this.getTask(createTimestamp); if (!task) return null; @@ -133,13 +144,7 @@ const Model = { const target = this.getTask(createTimestamp); if (!target) return null; target.setAttribute("data-priority", `${priority}`); - for (const task of document.getElementsByClassName("task")) { - if (task !== target && this.getPriority(task) < priority) { - task.parentElement!.insertBefore(target, task); - return target; - } - } - document.getElementById("tasks")!.appendChild(target); + this.insertInPriorityOrder(target, target.parentElement!); return target; }, @@ -469,8 +474,12 @@ function BrowserUI() { resetTagView: function () { currentTagView = null; - for (const task of document.getElementsByClassName("task")) { + const taskList = document.getElementById("tasks")!; + for (const task of Array.from(document.getElementsByClassName("task"))) { task.classList.remove("hide"); + if (task.parentElement !== taskList) { + Model.insertInPriorityOrder(task, taskList); + } } }, @@ -517,13 +526,44 @@ function BrowserUI() { const target = this.currentTag(); if (!target) return; const tag = target.textContent!; + + if (currentTagView !== null) { + this.resetTagView(); + } + + const tasksWithTag = new Map(); for (const task of document.getElementsByClassName("task")) { + if (Model.hasTag(task, tag)) { + tasksWithTag.set(task.getElementsByClassName("desc")[0].textContent, [Model.getPriority(task), task]); + } + } + + function highestPrioritySuperTask(t: Element) { + var maxPriority = -1; + var superTask = null; + for (const child of t.getElementsByClassName("tag")) { + const e = tasksWithTag.get(child.textContent); + if (e !== undefined && e[0] > maxPriority) { + maxPriority = e[0]; + superTask = e[1]; + } + } + return superTask; + } + + for (const task of Array.from(document.getElementsByClassName("task"))) { if (Model.hasTag(task, tag)) { task.classList.remove("hide"); } else { - task.classList.add("hide"); + const superTask = highestPrioritySuperTask(task); + if (superTask !== null) { + Model.insertInPriorityOrder(task, superTask); + } else { + task.classList.add("hide"); + } } } + currentTagView = tag; }, @@ -544,6 +584,9 @@ function BrowserUI() { }, setUntaggedView: function () { + if (currentTagView !== null) { + this.resetTagView(); + } for (const task of document.getElementsByClassName("task")) { if (task.getElementsByClassName("tag").length === 0) { task.classList.remove("hide");