« get me outta code hell

Merge branch 'preview' into sheet-music-midis - hsmusic-wiki - HSMusic - static wiki software cataloguing collaborative creation
about summary refs log tree commit diff
path: root/src/data/things/validators.js
diff options
context:
space:
mode:
author(quasar) nebula <qznebula@protonmail.com>2023-02-26 18:04:59 -0400
committer(quasar) nebula <qznebula@protonmail.com>2023-02-26 18:13:48 -0400
commit999fc0c58485649aee8e4deb3ea6419aa687c228 (patch)
treef19bd9e3ad038ddfb823e20ad19868e03cc9ee4c /src/data/things/validators.js
parent212c5fe9972dad3c53826c0364376a98b6c5a3c3 (diff)
parent8d05431f0c815227ba5cd503e88b0ee531c6eeb8 (diff)
Merge branch 'preview' into sheet-music-midis
Diffstat (limited to 'src/data/things/validators.js')
-rw-r--r--src/data/things/validators.js13
1 files changed, 12 insertions, 1 deletions
diff --git a/src/data/things/validators.js b/src/data/things/validators.js
index 24db3c79..b116120a 100644
--- a/src/data/things/validators.js
+++ b/src/data/things/validators.js
@@ -195,7 +195,18 @@ export function isColor(color) {
 }
 
 export function isCommentary(commentary) {
-  return isString(commentary);
+  isString(commentary);
+
+  const [firstLine] = commentary.match(/.*/);
+  if (!firstLine.replace(/<\/b>/g, '').includes(':</i>')) {
+    throw new TypeError(`Missing commentary citation: "${
+      firstLine.length > 40
+        ? firstLine.slice(0, 40) + '...'
+        : firstLine
+    }"`);
+  }
+
+  return true;
 }
 
 const isArtistRef = validateReference('artist');