From 261ee0fceb4f2c46bdcb027b473833a560fd6dbe Mon Sep 17 00:00:00 2001 From: "(quasar) nebula" Date: Wed, 12 Jun 2024 13:49:01 -0300 Subject: content: generateTrackInfoPageFeaturedByFlashesList --- src/content/dependencies/generateTrackInfoPage.js | 60 ++++------------------- 1 file changed, 10 insertions(+), 50 deletions(-) (limited to 'src/content/dependencies/generateTrackInfoPage.js') diff --git a/src/content/dependencies/generateTrackInfoPage.js b/src/content/dependencies/generateTrackInfoPage.js index eae782bc..d78c2703 100644 --- a/src/content/dependencies/generateTrackInfoPage.js +++ b/src/content/dependencies/generateTrackInfoPage.js @@ -1,4 +1,3 @@ -import {sortFlashesChronologically} from '#sort'; import {empty} from '#sugar'; export default { @@ -15,25 +14,23 @@ export default { 'generateTrackAdditionalNamesBox', 'generateTrackChronologyLinks', 'generateTrackCoverArtwork', + 'generateTrackInfoPageFeaturedByFlashesList', 'generateTrackInfoPageOtherReleasesList', 'generateTrackList', 'generateTrackListDividedByGroups', 'generateTrackReleaseInfo', 'generateTrackSocialEmbed', 'linkAlbum', - 'linkFlash', 'linkTrack', 'transformContent', ], extraDependencies: ['html', 'language', 'wikiData'], - sprawl({wikiInfo}) { - return { - divideTrackListsByGroups: wikiInfo.divideTrackListsByGroups, - enableFlashesAndGames: wikiInfo.enableFlashesAndGames, - }; - }, + sprawl: ({wikiInfo}) => ({ + divideTrackListsByGroups: + wikiInfo.divideTrackListsByGroups, + }), relations(relation, sprawl, track) { const relations = {}; @@ -120,35 +117,8 @@ export default { // Section: Flashes that feature - if (sprawl.enableFlashesAndGames) { - const sortedFeatures = - sortFlashesChronologically( - [track, ...track.otherReleases].flatMap(track => - track.featuredInFlashes.map(flash => ({ - // These aren't going to be exposed directly, they're processed - // into the appropriate relations after this sort. - flash, track, - - // These properties are only used for the sort. - act: flash.act, - date: flash.date, - })))); - - if (!empty(sortedFeatures)) { - const flashesThatFeature = sections.flashesThatFeature = {}; - - flashesThatFeature.entries = - sortedFeatures.map(({flash, track: directlyFeaturedTrack}) => - (directlyFeaturedTrack === track - ? { - flashLink: relation('linkFlash', flash), - } - : { - flashLink: relation('linkFlash', flash), - trackLink: relation('linkTrack', directlyFeaturedTrack), - })); - } - } + relations.flashesThatFeatureList = + relation('generateTrackInfoPageFeaturedByFlashesList', track); // Section: Lyrics @@ -347,7 +317,7 @@ export default { }), ]), - sec.flashesThatFeature && [ + html.tags([ relations.contentHeading.clone() .slots({ attributes: {id: 'featured-in'}, @@ -361,18 +331,8 @@ export default { language.$('releaseInfo.flashesThatFeature.sticky'), }), - html.tag('ul', sec.flashesThatFeature.entries.map(({flashLink, trackLink}) => - (trackLink - ? html.tag('li', {class: 'rerelease'}, - language.$('releaseInfo.flashesThatFeature.item.asDifferentRelease', { - flash: flashLink, - track: trackLink, - })) - : html.tag('li', - language.$('releaseInfo.flashesThatFeature.item', { - flash: flashLink, - }))))), - ], + relations.flashesThatFeatureList, + ]), sec.lyrics && [ relations.contentHeading.clone() -- cgit 1.3.0-6-gf8a5