From 3e5c8f731117b01fdf46c4fe066e1c349dee3827 Mon Sep 17 00:00:00 2001 From: "(quasar) nebula" Date: Wed, 25 Mar 2026 11:18:42 -0300 Subject: content, data: Divide Flash Lists By Sides --- .../generateTrackFeaturedInFlashesList.js | 38 ++++++++++++++++++++++ 1 file changed, 38 insertions(+) create mode 100644 src/content/dependencies/generateTrackFeaturedInFlashesList.js (limited to 'src/content/dependencies/generateTrackFeaturedInFlashesList.js') diff --git a/src/content/dependencies/generateTrackFeaturedInFlashesList.js b/src/content/dependencies/generateTrackFeaturedInFlashesList.js new file mode 100644 index 00000000..f13368d1 --- /dev/null +++ b/src/content/dependencies/generateTrackFeaturedInFlashesList.js @@ -0,0 +1,38 @@ +import {stitchArrays} from '#sugar'; + +export default { + relations: (relation, features, track) => ({ + flashLinks: + features + .map(({flash}) => relation('linkFlash', flash)), + + trackLinks: + features + .map(({as: directlyFeaturedTrack}) => + (directlyFeaturedTrack === track + ? null + : directlyFeaturedTrack.name === track.name + ? null + : relation('linkTrack', directlyFeaturedTrack))), + }), + + generate: (relations, {html, language}) => + html.tag('ul', + {[html.onlyIfContent]: true}, + + stitchArrays({ + flashLink: relations.flashLinks, + trackLink: relations.trackLinks, + }).map(({flashLink, trackLink}) => { + const attributes = html.attributes(); + const parts = ['flashList.item']; + const options = {flash: flashLink}; + + if (trackLink) { + parts.push('asDifferentRelease'); + options.track = trackLink; + } + + return html.tag('li', attributes, language.$(...parts, options)); + })), +}; -- cgit 1.3.0-6-gf8a5