From 9dbcf794c4f2b9fa8a52b3302d9e3bee8b19cfec Mon Sep 17 00:00:00 2001 From: "(quasar) nebula" Date: Tue, 18 Feb 2025 14:16:18 -0400 Subject: content, css: generateAlbumSidebar: earlier/later releases Also CSS tweak for release box backgrounds, and fix generateAlbumSidebar being broken for non-track pages --- src/content/dependencies/generateAlbumSidebar.js | 54 +++++++++++++++++++++--- 1 file changed, 47 insertions(+), 7 deletions(-) (limited to 'src/content') diff --git a/src/content/dependencies/generateAlbumSidebar.js b/src/content/dependencies/generateAlbumSidebar.js index 19fa7ee7..e10e865d 100644 --- a/src/content/dependencies/generateAlbumSidebar.js +++ b/src/content/dependencies/generateAlbumSidebar.js @@ -1,4 +1,5 @@ -import {stitchArrays} from '#sugar'; +import {sortAlbumsTracksChronologically} from '#sort'; +import {stitchArrays, transposeArrays} from '#sugar'; export default { contentDependencies: [ @@ -18,7 +19,7 @@ export default { groupData.flatMap(group => group.serieses), }), - query(sprawl, album) { + query(sprawl, album, track) { const query = {}; query.groups = @@ -36,6 +37,33 @@ export default { series.albums.includes(album) && !query.groups.includes(series.group)); + if (track) { + const albumTrackMap = + new Map(transposeArrays([ + [track.album, ...track.otherReleases.map(t => t.album)], + [track, ...track.otherReleases], + ])); + + const allReleaseAlbums = + sortAlbumsTracksChronologically( + Array.from(albumTrackMap.keys())); + + const currentReleaseIndex = + allReleaseAlbums.indexOf(track.album); + + const earlierReleaseAlbums = + allReleaseAlbums.slice(0, currentReleaseIndex); + + const laterReleaseAlbums = + allReleaseAlbums.slice(currentReleaseIndex + 1); + + query.earlierReleaseTracks = + earlierReleaseAlbums.map(album => albumTrackMap.get(album)); + + query.laterReleaseTracks = + laterReleaseAlbums.map(album => albumTrackMap.get(album)); + } + return query; }, @@ -65,10 +93,19 @@ export default { .map(series => relation('generateAlbumSidebarSeriesBox', album, series)), - trackReleaseBoxes: - track.otherReleases - .map(track => - relation('generateTrackReleaseBox', track)), + earlierTrackReleaseBoxes: + (track + ? query.earlierReleaseTracks + .map(track => + relation('generateTrackReleaseBox', track)) + : null), + + laterTrackReleaseBoxes: + (track + ? query.laterReleaseTracks + .map(track => + relation('generateTrackReleaseBox', track)) + : null), }), data: (_query, _sprawl, _album, track) => ({ @@ -106,10 +143,13 @@ export default { ], data.isTrackPage && - relations.trackReleaseBoxes, + relations.earlierTrackReleaseBoxes, relations.trackListBox, + data.isTrackPage && + relations.laterTrackReleaseBoxes, + data.isTrackPage && relations.conjoinedBox.slots({ attributes: {class: 'conjoined-group-sidebar-box'}, -- cgit 1.3.0-6-gf8a5