diff options
author | (quasar) nebula <qznebula@protonmail.com> | 2024-11-19 13:25:22 -0400 |
---|---|---|
committer | (quasar) nebula <qznebula@protonmail.com> | 2024-11-19 13:25:22 -0400 |
commit | 7cb88275fd3c813114271c0a136b12c72c5a172a (patch) | |
tree | b3b007e73c4681e206162362f5d9a8b99b6762d7 /src/content/dependencies/generateCoverArtwork.js | |
parent | 943cb8d05f5ef8572edfa081fb9912107769241a (diff) |
content: decompose generateCoverArtwork
No visual/site changes yet. This involves introducing an unfortunate mega-hack in generateStickyHeadingContainer, which sets slots on cover artworks. Very scary. Oooooo Otherwise, all cover artwork code is much more compositional. Pass-through slots (`image`) are removed in generateCoverArtwork and a partially-formed `image` slot is accepted instead.
Diffstat (limited to 'src/content/dependencies/generateCoverArtwork.js')
-rw-r--r-- | src/content/dependencies/generateCoverArtwork.js | 165 |
1 files changed, 33 insertions, 132 deletions
diff --git a/src/content/dependencies/generateCoverArtwork.js b/src/content/dependencies/generateCoverArtwork.js index 70d71bc6..50089f69 100644 --- a/src/content/dependencies/generateCoverArtwork.js +++ b/src/content/dependencies/generateCoverArtwork.js @@ -1,83 +1,29 @@ -import {stitchArrays} from '#sugar'; - export default { - contentDependencies: ['image', 'linkArtTag', 'linkArtistGallery'], - extraDependencies: ['html', 'language'], - - query: (artTags, _coverArtistContribs) => ({ - linkableArtTags: - (artTags - ? artTags.filter(tag => !tag.isContentWarning) - : []), - }), - - relations: (relation, query, artTags, coverArtistContribs) => ({ - image: - relation('image', artTags), - - tagLinks: - query.linkableArtTags - .map(tag => relation('linkArtTag', tag)), - - artistLinks: - coverArtistContribs - .map(contrib => contrib.artist) - .map(artist => - relation('linkArtistGallery', artist)), - }), - - data: (query, _artTags, _coverArtistContribs) => { - const data = {}; - - const seenShortNames = new Set(); - const duplicateShortNames = new Set(); - - for (const {nameShort: shortName} of query.linkableArtTags) { - if (seenShortNames.has(shortName)) { - duplicateShortNames.add(shortName); - } else { - seenShortNames.add(shortName); - } - } - - data.preferShortName = - query.linkableArtTags - .map(artTag => !duplicateShortNames.has(artTag.nameShort)); - - return data; - }, + contentDependencies: ['image', 'linkArtistGallery'], + extraDependencies: ['html'], slots: { - path: { - validate: v => v.validateArrayItems(v.isString), - }, - - alt: { - type: 'string', - }, - - color: { - validate: v => v.isColor, + image: { + type: 'html', + mutable: true, }, mode: { - validate: v => - v.is(...[ - 'primary-tags', - 'primary-artists', - 'thumbnail', - 'commentary', - ]), - - default: 'primary-tags', + validate: v => v.is('primary', 'thumbnail', 'commentary'), + default: 'primary', }, dimensions: { validate: v => v.isDimensions, }, + + details: { + type: 'html', + mutable: false, + }, }, - generate(data, relations, slots, {html, language}) { + generate(slots, {html}) { const square = (slots.dimensions ? slots.dimensions[0] === slots.dimensions[1] @@ -88,83 +34,38 @@ export default { ? {square: true} : {dimensions: slots.dimensions}); - switch (slots.mode) { - case 'primary-tags': - return html.tags([ - relations.image.slots({ - path: slots.path, - alt: slots.alt, - color: slots.color, + return html.tags([ + (slots.mode === 'primary' + ? slots.image.slots({ thumb: 'medium', reveal: true, link: true, ...sizeSlots, - }), - - html.tag('ul', {class: 'image-details'}, - {[html.onlyIfContent]: true}, + }) - {class: 'art-tag-details'}, - - stitchArrays({ - tagLink: relations.tagLinks, - preferShortName: data.preferShortName, - }).map(({tagLink, preferShortName}) => - html.tag('li', - tagLink.slot('preferShortName', preferShortName)))), - ]); + : slots.mode === 'thumbnail' + ? slots.image.slots({ + thumb: 'small', + reveal: false, + link: false, + ...sizeSlots, + }) - case 'primary-artists': - return html.tags([ - relations.image.slots({ - path: slots.path, - alt: slots.alt, - color: slots.color, + : slots.mode === 'commentary' + ? slots.image.slots({ thumb: 'medium', reveal: true, link: true, + lazy: true, ...sizeSlots, - }), - - html.tag('p', {class: 'image-details'}, - {[html.onlyIfContent]: true}, - - {class: 'illustrator-details'}, - - language.$('misc.coverGrid.details.coverArtists', { - artists: - language.formatConjunctionList(relations.artistLinks), - })), - ]); - - case 'thumbnail': - return relations.image.slots({ - path: slots.path, - alt: slots.alt, - color: slots.color, - thumb: 'small', - reveal: false, - link: false, - ...sizeSlots, - }); - case 'commentary': - return relations.image.slots({ - path: slots.path, - alt: slots.alt, - color: slots.color, - thumb: 'medium', - reveal: true, - link: true, - lazy: true, - ...sizeSlots, + attributes: + {class: 'commentary-art'}, + }) - attributes: - {class: 'commentary-art'}, - }); + : html.blank()), - default: - return html.blank(); - } + html.tags([slots.details], {[html.onlyIfSiblings]: true}), + ]); }, }; |