diff options
author | (quasar) nebula <qznebula@protonmail.com> | 2025-02-08 23:36:30 -0400 |
---|---|---|
committer | (quasar) nebula <qznebula@protonmail.com> | 2025-02-25 20:03:29 -0400 |
commit | 8051e450166464e533e80c84133de30ac3beda87 (patch) | |
tree | c830feb150663dc7353ed162a70a3f045c4911f0 /src/data | |
parent | 9251eb1af5dfbd87bbaa5aaa373dd1be162835fb (diff) |
content, data: related art tags
Diffstat (limited to 'src/data')
-rw-r--r-- | src/data/things/art-tag.js | 21 |
1 files changed, 21 insertions, 0 deletions
diff --git a/src/data/things/art-tag.js b/src/data/things/art-tag.js index f023eb76..fe4c77b2 100644 --- a/src/data/things/art-tag.js +++ b/src/data/things/art-tag.js @@ -6,11 +6,13 @@ import {sortAlphabetically, sortAlbumsTracksChronologically} from '#sort'; import Thing from '#thing'; import {unique} from '#sugar'; import {isName} from '#validators'; +import {parseAnnotatedReferences} from '#yaml'; import {exitWithoutDependency, exposeDependency, exposeUpdateValueOrContinue} from '#composite/control-flow'; import { + annotatedReferenceList, color, directory, flag, @@ -59,6 +61,16 @@ export class ArtTag extends Thing { find: soupyFind.input('artTag'), }), + relatedArtTags: annotatedReferenceList({ + class: input.value(ArtTag), + find: soupyFind.input('artTag'), + + date: input.value(null), + + reference: input.value('artTag'), + thing: input.value('artTag'), + }), + // Update only find: soupyFind(), @@ -154,6 +166,15 @@ export class ArtTag extends Thing { 'Is CW': {property: 'isContentWarning'}, 'Direct Descendant Tags': {property: 'directDescendantArtTags'}, + + 'Related Tags': { + property: 'relatedArtTags', + transform: entries => + parseAnnotatedReferences(entries, { + referenceField: 'Tag', + referenceProperty: 'artTag', + }), + }, }, }; |