« get me outta code hell

content: generateAlbumStyleRules: wallpaper parts - hsmusic-wiki - HSMusic - static wiki software cataloguing collaborative creation
about summary refs log tree commit diff
path: root/src
diff options
context:
space:
mode:
author(quasar) nebula <qznebula@protonmail.com>2025-01-06 19:44:18 -0400
committer(quasar) nebula <qznebula@protonmail.com>2025-01-06 19:44:18 -0400
commit1b78a825e2c3f6a535497a64840fe88be23c44f1 (patch)
tree5cc2b24b1c97c65b8edd3aa2a6a5409c8b44bd60 /src
parent1c4a398258ee6dc6fb41944574f3d6095c0a3f2a (diff)
content: generateAlbumStyleRules: wallpaper parts
Diffstat (limited to 'src')
-rw-r--r--src/content/dependencies/generateAlbumStyleRules.js47
-rw-r--r--src/url-spec.js1
2 files changed, 42 insertions, 6 deletions
diff --git a/src/content/dependencies/generateAlbumStyleRules.js b/src/content/dependencies/generateAlbumStyleRules.js
index c5acf374..6bfcc62e 100644
--- a/src/content/dependencies/generateAlbumStyleRules.js
+++ b/src/content/dependencies/generateAlbumStyleRules.js
@@ -1,4 +1,4 @@
-import {empty} from '#sugar';
+import {empty, stitchArrays} from '#sugar';
 
 export default {
   extraDependencies: ['to'],
@@ -10,8 +10,22 @@ export default {
     data.hasBanner = !empty(album.bannerArtistContribs);
 
     if (data.hasWallpaper) {
-      data.wallpaperPath = ['media.albumWallpaper', album.directory, album.wallpaperFileExtension];
-      data.wallpaperStyle = album.wallpaperStyle;
+      if (!empty(album.wallpaperParts)) {
+        data.wallpaperMode = 'parts';
+
+        data.wallpaperPaths =
+          album.wallpaperParts.map(part =>
+            (part.asset
+              ? ['media.albumWallpaperPart', album.directory, part.asset]
+              : null));
+
+        data.wallpaperStyles =
+          album.wallpaperParts.map(part => part.style);
+      } else {
+        data.wallpaperMode = 'one';
+        data.wallpaperPath = ['media.albumWallpaper', album.directory, album.wallpaperFileExtension];
+        data.wallpaperStyle = album.wallpaperStyle;
+      }
     }
 
     if (data.hasBanner) {
@@ -42,13 +56,34 @@ export default {
         ? [`${selector} {`, indent(parts), `}`]
         : []);
 
-    const wallpaperRule =
-      data.hasWallpaper &&
+    const oneWallpaperRule =
+      data.wallpaperMode === 'one' &&
         rule(`body::before`, [
           `background-image: url("${to(...data.wallpaperPath)}");`,
           data.wallpaperStyle,
         ]);
 
+    const wallpaperPartRules =
+      data.wallpaperMode === 'parts' &&
+        stitchArrays({
+          path: data.wallpaperPaths,
+          style: data.wallpaperStyles,
+        }).map(({path, style}, index) =>
+            rule(`.wallpaper-part:nth-child(${index + 1})`, [
+              path && `background-image: url("${to(...path)}");`,
+              style,
+            ]));
+
+    const nukeBasicWallpaperRule =
+      data.wallpaperMode === 'parts' &&
+        rule(`body::before`, ['display: none']);
+
+    const wallpaperRules = [
+      oneWallpaperRule,
+      ...wallpaperPartRules || [],
+      nukeBasicWallpaperRule,
+    ];
+
     const bannerRule =
       data.hasBanner &&
         rule(`#banner img`, [
@@ -64,7 +99,7 @@ export default {
       ]);
 
     return (
-      [wallpaperRule, bannerRule, dataRule]
+      [...wallpaperRules, bannerRule, dataRule]
         .filter(Boolean)
         .flat()
         .join('\n'));
diff --git a/src/url-spec.js b/src/url-spec.js
index 4a57fa0f..6ca75e7d 100644
--- a/src/url-spec.js
+++ b/src/url-spec.js
@@ -114,6 +114,7 @@ const urlSpec = {
       albumBanner: 'album-art/<>/banner.<>',
       albumCover: 'album-art/<>/cover.<>',
       albumWallpaper: 'album-art/<>/bg.<>',
+      albumWallpaperPart: 'album-art/<>/<>',
 
       artistAvatar: 'artist-avatar/<>.<>',