From a6493da3ba7809dad4fd482936449e5649fa3a01 Mon Sep 17 00:00:00 2001 From: "(quasar) nebula" Date: Sat, 3 Jun 2023 09:30:56 -0300 Subject: content: generatePageLayout: divide style rules, apply default color --- src/content/dependencies/generateAlbumInfoPage.js | 6 ++---- src/content/dependencies/generateArtistInfoPage.js | 2 -- src/content/dependencies/generatePageLayout.js | 21 +++++++++++++++++---- src/content/dependencies/generateStaticPage.js | 5 ++++- src/content/dependencies/generateTrackInfoPage.js | 6 ++---- 5 files changed, 25 insertions(+), 15 deletions(-) (limited to 'src/content/dependencies') diff --git a/src/content/dependencies/generateAlbumInfoPage.js b/src/content/dependencies/generateAlbumInfoPage.js index 23755515..749dd2af 100644 --- a/src/content/dependencies/generateAlbumInfoPage.js +++ b/src/content/dependencies/generateAlbumInfoPage.js @@ -62,10 +62,8 @@ export default { title: language.$('albumPage.title', {album: data.name}), headingMode: 'sticky', - styleRules: [ - relations.albumStyleRules, - relations.colorStyleRules, - ], + colorStyleRules: [relations.colorStyleRules], + additionalStyleRules: [relations.albumStyleRules], cover: relations.content.cover, mainContent: relations.content.main.content, diff --git a/src/content/dependencies/generateArtistInfoPage.js b/src/content/dependencies/generateArtistInfoPage.js index 3a047307..9c2eecc8 100644 --- a/src/content/dependencies/generateArtistInfoPage.js +++ b/src/content/dependencies/generateArtistInfoPage.js @@ -239,8 +239,6 @@ export default { title: data.name, headingMode: 'sticky', - styleRules: [data.stylesheet].filter(Boolean), - mainClasses: ['long-content'], mainContent: [ sec.artworks && [ diff --git a/src/content/dependencies/generatePageLayout.js b/src/content/dependencies/generatePageLayout.js index be61a6cd..32effbfe 100644 --- a/src/content/dependencies/generatePageLayout.js +++ b/src/content/dependencies/generatePageLayout.js @@ -2,6 +2,7 @@ import {empty, openAggregate} from '../../util/sugar.js'; export default { contentDependencies: [ + 'generateColorStyleRules', 'generateFooterLocalizationLinks', 'generateStickyHeadingContainer', 'transformContent', @@ -19,6 +20,7 @@ export default { sprawl({wikiInfo}) { return { footerContent: wikiInfo.footerContent, + wikiColor: wikiInfo.color, wikiName: wikiInfo.nameShort, }; }, @@ -41,6 +43,9 @@ export default { relations.defaultFooterContent = relation('transformContent', sprawl.footerContent); + relations.defaultColorStyleRules = + relation('generateColorStyleRules', sprawl.wikiColor); + return relations; }, @@ -100,7 +105,12 @@ export default { socialEmbed: {type: 'html'}, - styleRules: { + colorStyleRules: { + validate: v => v.arrayOf(v.isString), + default: [], + }, + + additionalStyleRules: { validate: v => v.arrayOf(v.isString), default: [], }, @@ -456,9 +466,12 @@ export default { href: to('shared.staticFile', `site4.css?${cachebust}`), }), - html.tag('style', - {[html.onlyIfContent]: true}, - slots.styleRules), + html.tag('style', [ + (empty(slots.colorStyleRules) + ? relations.defaultColorStyleRules + : slots.colorStyleRules), + slots.additionalStyleRules, + ]), html.tag('script', { src: to('shared.staticFile', `lazy-loading.js?${cachebust}`), diff --git a/src/content/dependencies/generateStaticPage.js b/src/content/dependencies/generateStaticPage.js index e3063ff8..cbd477e0 100644 --- a/src/content/dependencies/generateStaticPage.js +++ b/src/content/dependencies/generateStaticPage.js @@ -21,7 +21,10 @@ export default { title: data.name, headingMode: 'sticky', - styleRules: [data.stylesheet].filter(Boolean), + additionalStyleRules: + (data.stylesheet + ? [data.stylesheet] + : []), mainClasses: ['long-content'], mainContent: relations.content, diff --git a/src/content/dependencies/generateTrackInfoPage.js b/src/content/dependencies/generateTrackInfoPage.js index 197d6312..b2cc0ca2 100644 --- a/src/content/dependencies/generateTrackInfoPage.js +++ b/src/content/dependencies/generateTrackInfoPage.js @@ -79,10 +79,8 @@ export default { title: language.$('trackPage.title', {track: data.name}), headingMode: 'sticky', - styleRules: [ - relations.albumStyleRules, - relations.colorStyleRules, - ], + colorStyleRules: [relations.colorStyleRules], + additionalStyleRules: [relations.albumStyleRules], cover: relations.content.cover, mainContent: relations.content.main.content, -- cgit 1.3.0-6-gf8a5