« get me outta code hell

mtui - Music Text User Interface - user-friendly command line music player
about summary refs log tree commit diff
path: root/playlist-utils.js
diff options
context:
space:
mode:
Diffstat (limited to 'playlist-utils.js')
-rw-r--r--playlist-utils.js47
1 files changed, 39 insertions, 8 deletions
diff --git a/playlist-utils.js b/playlist-utils.js
index 68cba56..1015748 100644
--- a/playlist-utils.js
+++ b/playlist-utils.js
@@ -521,24 +521,29 @@ function getTrackIndexInParent(track) {
 const nameWithoutTrackNumberSymbol = Symbol('Cached name without track number')
 function getNameWithoutTrackNumber(track) {
   // A "part" is a series of numeric digits, separated from other parts by
-  // whitespace and dashes, always preceding either the first non-numeric/
-  // separator character or (if there are no such characters) the first word
-  // (i.e. last whitespace).
+  // whitespace, dashes, and dots, always preceding either the first non-
+  // numeric/separator character or (if there are no such characters) the
+  // first word (i.e. last whitespace).
   const getNumberOfParts = ({ name }) => {
-    const match = name.match(/[^0-9\-\s]/)
+    name = name.replace(/^[\-\s.]+$/, '')
+    const match = name.match(/[^0-9\-\s.]/)
     if (match) {
-      name = name.slice(0, match.index)
+      if (match.index === 0) {
+        return 0
+      } else {
+        name = name.slice(0, match.index)
+      }
     } else if (name.includes(' ')) {
       name = name.slice(0, name.lastIndexOf(' '))
     } else {
       return 0
     }
-    name = name.replace(/[\-\s]+$/, '')
-    return name.split(/[\-\s]+/g).length
+    name = name.replace(/[\-\s.]+$/, '')
+    return name.split(/[\-\s.]+/g).length
   }
 
   const removeParts = (name, numParts) => {
-    const regex = new RegExp(`([0-9]+[\\-\\s]+){${numParts},${numParts}}`)
+    const regex = new RegExp(String.raw`[\-\s.]{0,}([0-9]+[\-\s.]+){${numParts},${numParts}}`)
     return track.name.replace(regex, '')
   }
 
@@ -710,3 +715,29 @@ module.exports = {
   isGroup, isTrack,
   isOpenable, isPlayable
 }
+
+if (require.main === module) {
+  {
+    const group = updateGroupFormat({items: [
+      {name: '- 1.01 Hello World 425', downloaderArg: 'x'},
+      {name: '1.02 Aww Yeah 371', downloaderArg: 'x'},
+      {name: ' 1.03 Here Goes 472', downloaderArg: 'x'}
+    ]})
+
+    for (let i = 0; i < group.items.length; i++) {
+      console.log(group.items[i].name, '->', getNameWithoutTrackNumber(group.items[i]))
+    }
+  }
+
+  {
+    const group = updateGroupFormat({items: [
+      {name: 'BAM #1', downloaderArg: 'x'},
+      {name: 'BAM #2', downloaderArg: 'x'},
+      {name: 'BAM #3.1 - no', downloaderArg: 'x'}
+    ]})
+
+    for (let i = 0; i < group.items.length; i++) {
+      console.log(group.items[i].name, '->', getNameWithoutTrackNumber(group.items[i]))
+    }
+  }
+}