From 5b4f7bd906d658116b384122518c43a577141368 Mon Sep 17 00:00:00 2001 From: "(quasar) nebula" Date: Tue, 23 Apr 2024 16:48:35 -0300 Subject: content: generateTrackChronologyLinks: inline scoping logic --- .../generateScopedTrackChronologyLinks.js | 89 ---------------- .../dependencies/generateTrackChronologyLinks.js | 116 ++++++++++++++++++--- 2 files changed, 102 insertions(+), 103 deletions(-) delete mode 100644 src/content/dependencies/generateScopedTrackChronologyLinks.js diff --git a/src/content/dependencies/generateScopedTrackChronologyLinks.js b/src/content/dependencies/generateScopedTrackChronologyLinks.js deleted file mode 100644 index 87a7c0fd..00000000 --- a/src/content/dependencies/generateScopedTrackChronologyLinks.js +++ /dev/null @@ -1,89 +0,0 @@ -import {sortAlbumsTracksChronologically} from '#sort'; - -import getChronologyRelations from '../util/getChronologyRelations.js'; - -export default { - contentDependencies: [ - 'generateChronologyLinks', - 'linkAlbum', - 'linkArtist', - 'linkTrack', - ], - - relations(relation, album, track) { - const albumFilter = - (album - ? track => track.album === album - : () => true); - - return { - chronologyLinks: - relation('generateChronologyLinks'), - - artistChronologyContributions: - getChronologyRelations(track, { - contributions: [ - ...track.artistContribs ?? [], - ...track.contributorContribs ?? [], - ], - - linkArtist: artist => relation('linkArtist', artist), - linkThing: track => relation('linkTrack', track), - - getThings(artist) { - const getDate = thing => thing.date; - - const things = - ([ - ...artist.tracksAsArtist, - ...artist.tracksAsContributor, - ]).filter(getDate) - .filter(albumFilter); - - return sortAlbumsTracksChronologically(things, {getDate}); - }, - }), - - coverArtistChronologyContributions: - getChronologyRelations(track, { - contributions: track.coverArtistContribs ?? [], - - linkArtist: artist => relation('linkArtist', artist), - - linkThing: trackOrAlbum => - (trackOrAlbum.album - ? relation('linkTrack', trackOrAlbum) - : relation('linkAlbum', trackOrAlbum)), - - getThings(artist) { - const getDate = thing => thing.coverArtDate ?? thing.date; - - const things = - ([ - ...artist.albumsAsCoverArtist, - ...artist.tracksAsCoverArtist, - ]).filter(getDate) - .filter(albumFilter); - - return sortAlbumsTracksChronologically(things, {getDate}); - }, - }), - }; - }, - - generate: (relations) => - relations.chronologyLinks.slots({ - showOnly: true, - - chronologyInfoSets: [ - { - headingString: 'misc.chronology.heading.track', - contributions: relations.artistChronologyContributions, - }, - { - headingString: 'misc.chronology.heading.coverArt', - contributions: relations.coverArtistChronologyContributions, - }, - ], - }), -}; diff --git a/src/content/dependencies/generateTrackChronologyLinks.js b/src/content/dependencies/generateTrackChronologyLinks.js index accb9ef1..fd676942 100644 --- a/src/content/dependencies/generateTrackChronologyLinks.js +++ b/src/content/dependencies/generateTrackChronologyLinks.js @@ -1,30 +1,118 @@ +import {sortAlbumsTracksChronologically} from '#sort'; + +import getChronologyRelations from '../util/getChronologyRelations.js'; + export default { contentDependencies: [ + 'generateChronologyLinks', 'generateChronologyLinksScopeSwitcher', - 'generateScopedTrackChronologyLinks', + 'linkAlbum', + 'linkArtist', + 'linkTrack', ], - relations: (relation, track) => ({ - scopeSwitcher: - relation('generateChronologyLinksScopeSwitcher'), + relations(relation, track) { + function getScopedRelations(album) { + const albumFilter = + (album + ? track => track.album === album + : () => true); + + return { + chronologyLinks: + relation('generateChronologyLinks'), + + artistChronologyContributions: + getChronologyRelations(track, { + contributions: [ + ...track.artistContribs ?? [], + ...track.contributorContribs ?? [], + ], + + linkArtist: artist => relation('linkArtist', artist), + linkThing: track => relation('linkTrack', track), + + getThings(artist) { + const getDate = thing => thing.date; + + const things = + ([ + ...artist.tracksAsArtist, + ...artist.tracksAsContributor, + ]).filter(getDate) + .filter(albumFilter); + + return sortAlbumsTracksChronologically(things, {getDate}); + }, + }), + + coverArtistChronologyContributions: + getChronologyRelations(track, { + contributions: track.coverArtistContribs ?? [], + + linkArtist: artist => relation('linkArtist', artist), + + linkThing: trackOrAlbum => + (trackOrAlbum.album + ? relation('linkTrack', trackOrAlbum) + : relation('linkAlbum', trackOrAlbum)), + + getThings(artist) { + const getDate = thing => thing.coverArtDate ?? thing.date; + + const things = + ([ + ...artist.albumsAsCoverArtist, + ...artist.tracksAsCoverArtist, + ]).filter(getDate) + .filter(albumFilter); + + return sortAlbumsTracksChronologically(things, {getDate}); + }, + }), + }; + } + + return { + scopeSwitcher: + relation('generateChronologyLinksScopeSwitcher'), + + wiki: + getScopedRelations(null), + + album: + getScopedRelations(track.album), + }; + }, - wikiChronologyLinks: - relation('generateScopedTrackChronologyLinks', null, track), + generate(relations) { + function slotScopedRelations(scope) { + return scope.chronologyLinks.slots({ + showOnly: true, - albumChronologyLinks: - relation('generateScopedTrackChronologyLinks', track.album, track), - }), + chronologyInfoSets: [ + { + headingString: 'misc.chronology.heading.track', + contributions: scope.artistChronologyContributions, + }, + { + headingString: 'misc.chronology.heading.coverArt', + contributions: scope.coverArtistChronologyContributions, + }, + ], + }); + } - generate: (relations) => - relations.scopeSwitcher.slots({ + return relations.scopeSwitcher.slots({ scopes: [ 'wiki', 'album', ], contents: [ - relations.wikiChronologyLinks, - relations.albumChronologyLinks, + slotScopedRelations(relations.wiki), + slotScopedRelations(relations.album), ], - }), + }); + }, }; -- cgit 1.3.0-6-gf8a5