From dc0b29d087aa335a8ffd97f7cbe1f22b2f115f09 Mon Sep 17 00:00:00 2001 From: "(quasar) nebula" Date: Wed, 12 Jun 2024 14:50:11 -0300 Subject: content: generateAlbumChronologyLinks --- .../dependencies/generateAlbumChronologyLinks.js | 53 ++++++++++++++++++++++ 1 file changed, 53 insertions(+) create mode 100644 src/content/dependencies/generateAlbumChronologyLinks.js (limited to 'src/content/dependencies/generateAlbumChronologyLinks.js') diff --git a/src/content/dependencies/generateAlbumChronologyLinks.js b/src/content/dependencies/generateAlbumChronologyLinks.js new file mode 100644 index 00000000..3dd7a18e --- /dev/null +++ b/src/content/dependencies/generateAlbumChronologyLinks.js @@ -0,0 +1,53 @@ +import {sortAlbumsTracksChronologically} from '#sort'; + +import getChronologyRelations from '../util/getChronologyRelations.js'; + +export default { + contentDependencies: [ + 'generateChronologyLinks', + 'linkAlbum', + 'linkArtist', + 'linkTrack', + ], + + relations: (relation, album) => ({ + chronologyLinks: + relation('generateChronologyLinks'), + + coverArtistChronologyContributions: + getChronologyRelations(album, { + contributions: album.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.albumCoverArtistContributions, + artist.trackCoverArtistContributions, + ]).flat() + .map(({thing}) => thing) + .filter(getDate); + + return sortAlbumsTracksChronologically(things, {getDate}); + }, + }), + }), + + generate: (relations) => + relations.chronologyLinks.slots({ + chronologyInfoSets: [ + { + headingString: 'misc.chronology.heading.coverArt', + contributions: relations.coverArtistChronologyContributions, + }, + ], + }), +} -- cgit 1.3.0-6-gf8a5