« get me outta code hell

data: split homepage-layout.js - hsmusic-wiki - HSMusic - static wiki software cataloguing collaborative creation
about summary refs log tree commit diff
path: root/src/data/things/homepage-layout/HomepageLayoutRow.js
diff options
context:
space:
mode:
author(quasar) nebula <qznebula@protonmail.com>2026-01-26 13:27:30 -0400
committer(quasar) nebula <qznebula@protonmail.com>2026-01-26 13:46:59 -0400
commit5c19b69f94b1ef913b114853264917f7eda627ed (patch)
tree040ee5d23b9d669a61b3643ccbbb908b3f594f13 /src/data/things/homepage-layout/HomepageLayoutRow.js
parentca4e9b3fd53f91e1cd95c8aa20496177ec39d669 (diff)
data: split homepage-layout.js
Diffstat (limited to 'src/data/things/homepage-layout/HomepageLayoutRow.js')
-rw-r--r--src/data/things/homepage-layout/HomepageLayoutRow.js60
1 files changed, 60 insertions, 0 deletions
diff --git a/src/data/things/homepage-layout/HomepageLayoutRow.js b/src/data/things/homepage-layout/HomepageLayoutRow.js
new file mode 100644
index 00000000..5b0899e9
--- /dev/null
+++ b/src/data/things/homepage-layout/HomepageLayoutRow.js
@@ -0,0 +1,60 @@
+import {inspect} from 'node:util';
+
+import {colors} from '#cli';
+import {V} from '#composite';
+import Thing from '#thing';
+
+import {exposeConstant} from '#composite/control-flow';
+import {soupyFind, thing} from '#composite/wiki-properties';
+
+export class HomepageLayoutRow extends Thing {
+  static [Thing.friendlyName] = `Homepage Row`;
+
+  static [Thing.getPropertyDescriptors] = ({HomepageLayoutSection}) => ({
+    // Update & expose
+
+    section: thing(V(HomepageLayoutSection)),
+
+    // Update only
+
+    find: soupyFind(),
+
+    // Expose only
+
+    isHomepageLayoutRow: exposeConstant(V(true)),
+
+    type: {
+      flags: {expose: true},
+
+      expose: {
+        compute() {
+          throw new Error(`'type' property validator must be overridden`);
+        },
+      },
+    },
+  });
+
+  static [Thing.yamlDocumentSpec] = {
+    fields: {
+      'Row': {ignore: true},
+    },
+  };
+
+  [inspect.custom](depth) {
+    const parts = [];
+
+    parts.push(Thing.prototype[inspect.custom].apply(this));
+
+    if (depth >= 0 && this.section) {
+      const sectionName = this.section.name;
+      const index = this.section.rows.indexOf(this);
+      const rowNum =
+        (index === -1
+          ? 'indeterminate position'
+          : `#${index + 1}`);
+      parts.push(` (${colors.yellow(rowNum)} in ${colors.green(sectionName)})`);
+    }
+
+    return parts.join('');
+  }
+}