From c65e1e3c36e32cd6b0d8e7ca2f730b71b4185ed9 Mon Sep 17 00:00:00 2001 From: "(quasar) nebula" Date: Mon, 14 Oct 2024 17:16:14 -0300 Subject: content: generateGroupInfoPageAlbumsListBySeries --- .../generateGroupInfoPageAlbumsListBySeries.js | 54 ++++++++++++++++++++++ 1 file changed, 54 insertions(+) create mode 100644 src/content/dependencies/generateGroupInfoPageAlbumsListBySeries.js (limited to 'src/content/dependencies/generateGroupInfoPageAlbumsListBySeries.js') diff --git a/src/content/dependencies/generateGroupInfoPageAlbumsListBySeries.js b/src/content/dependencies/generateGroupInfoPageAlbumsListBySeries.js new file mode 100644 index 00000000..8fa90877 --- /dev/null +++ b/src/content/dependencies/generateGroupInfoPageAlbumsListBySeries.js @@ -0,0 +1,54 @@ +import {stitchArrays} from '#sugar'; + +export default { + contentDependencies: [ + 'generateContentHeading', + 'generateGroupInfoPageAlbumsListItem', + ], + + extraDependencies: ['html', 'language'], + + relations: (relation, group) => ({ + seriesHeadings: + group.serieses + .map(() => relation('generateContentHeading')), + + seriesItems: + group.serieses + .map(series => series.albums + .map(album => + relation('generateGroupInfoPageAlbumsListItem', + album, + group))), + }), + + data: (group) => ({ + seriesNames: + group.serieses + .map(series => series.name), + }), + + generate: (data, relations, {html, language}) => + language.encapsulate('groupInfoPage.albumList', listCapsule => + html.tag('dl', {class: 'group-series-list'}, + {[html.onlyIfContent]: true}, + + stitchArrays({ + name: data.seriesNames, + heading: relations.seriesHeadings, + items: relations.seriesItems, + }).map(({heading, name, items}) => + html.tags([ + heading.slots({ + tag: 'dt', + title: + language.$(listCapsule, 'series', { + series: name, + }), + }), + + html.tag('dd', + html.tag('ul', + items)), + ])))), +}; -- cgit 1.3.0-6-gf8a5