« get me outta code hell

content, client, css: generateGroupGalleryPage: series view - hsmusic-wiki - HSMusic - static wiki software cataloguing collaborative creation
about summary refs log tree commit diff
path: root/src/content/dependencies/generateGroupGalleryPageAlbumsByDateView.js
diff options
context:
space:
mode:
author(quasar) nebula <qznebula@protonmail.com>2025-05-04 19:16:15 -0300
committer(quasar) nebula <qznebula@protonmail.com>2025-05-06 15:20:24 -0300
commit72f6fc9659fe4cc6ea60229e636421a78fe98f29 (patch)
treef5f073bec80c68e543015aadd6d6a4384ac5a8b7 /src/content/dependencies/generateGroupGalleryPageAlbumsByDateView.js
parentfedd22c523ec5c20b098cc478170ef096ab1b58e (diff)
content, client, css: generateGroupGalleryPage: series view
Diffstat (limited to 'src/content/dependencies/generateGroupGalleryPageAlbumsByDateView.js')
-rw-r--r--src/content/dependencies/generateGroupGalleryPageAlbumsByDateView.js37
1 files changed, 37 insertions, 0 deletions
diff --git a/src/content/dependencies/generateGroupGalleryPageAlbumsByDateView.js b/src/content/dependencies/generateGroupGalleryPageAlbumsByDateView.js
new file mode 100644
index 00000000..54f4b8cb
--- /dev/null
+++ b/src/content/dependencies/generateGroupGalleryPageAlbumsByDateView.js
@@ -0,0 +1,37 @@
+import {sortChronologically} from '#sort';
+
+export default {
+  contentDependencies: ['generateGroupGalleryPageAlbumGrid'],
+  extraDependencies: ['html', 'language'],
+
+  query: (group) => ({
+    albums:
+      sortChronologically(group.albums, {latestFirst: true}),
+  }),
+
+  relations: (relation, query, _group) => ({
+    albumGrid:
+      relation('generateGroupGalleryPageAlbumGrid', query.albums),
+  }),
+
+  slots: {
+    attributes: {
+      type: 'attributes',
+      mutable: false,
+    },
+  },
+
+  generate: (relations, slots, {html, language}) =>
+    language.encapsulate('groupGalleryPage.albumsByDate', capsule =>
+      html.tag('div', {id: 'group-album-gallery-by-date'},
+        slots.attributes,
+
+        {[html.onlyIfContent]: true},
+
+        html.tag('section', [
+          html.tag('h2',
+            language.$(capsule, 'title')),
+
+          relations.albumGrid,
+        ]))),
+};