« get me outta code hell

mtui - Music Text User Interface - user-friendly command line music player
about summary refs log tree commit diff
diff options
context:
space:
mode:
-rw-r--r--ui.js29
1 files changed, 21 insertions, 8 deletions
diff --git a/ui.js b/ui.js
index b786838..20d7381 100644
--- a/ui.js
+++ b/ui.js
@@ -199,7 +199,7 @@ export default class AppElement extends FocusElement {
 
     this.timestampDictionary = new WeakMap()
 
-    this.itemMenuPage = 0
+    this.itemMenuPage = 'cursor'
 
     // We add this is a child later (so that it's on top of every element).
     this.menuLayer = new DisplayElement()
@@ -1429,6 +1429,9 @@ export default class AppElement extends FocusElement {
         })
       }
 
+      // TODO: Implement this! :P
+      // const isMarked = false
+
       // const hasNotesFile = !!getCorrespondingFileForItem(item, '.txt')
       const timestampsItem = this.hasTimestampsFile(item) && (this.timestampsExpanded(item, listing)
         ? {label: 'Collapse saved timestamps', action: () => this.collapseTimestamps(item, listing)}
@@ -1509,23 +1512,33 @@ export default class AppElement extends FocusElement {
       }
     }
 
-    const pages = [
-      this.markGrouplike.items.length && generatePageForItem(this.markGrouplike),
-      el.item && generatePageForItem(el.item)
+    const pageInfo = [
+      this.markGrouplike.items.length && {
+        id: 'mark',
+        page: generatePageForItem(this.markGrouplike),
+      },
+
+      el.item && {
+        id: 'cursor',
+        page: generatePageForItem(el.item),
+      }
     ].filter(Boolean)
 
-    // TODO: Implement this! :P
-    // const isMarked = false
+    const pages = pageInfo.map(({ page }) => page)
+
+    let pageNum = pageInfo.findIndex(({ id }) => id === this.itemMenuPage)
+    if (pageNum === -1) pageNum = pageInfo.findIndex(({ id }) => id === 'cursor')
+    if (pageNum === -1) pageNum = 0
 
     const menu = this.showContextMenu({
       x: el.absLeft,
       y: el.absTop + 1,
       pages,
-      pageNum: this.itemMenuPage
+      pageNum,
     })
 
     menu.on('page changed', pageNum => {
-      this.itemMenuPage = pageNum
+      this.itemMenuPage = pageInfo[pageNum].id
     })
   }