diff options
Diffstat (limited to 'playlist-utils.js')
-rw-r--r-- | playlist-utils.js | 47 |
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])) + } + } +} |