diff options
author | (quasar) nebula <qznebula@protonmail.com> | 2025-04-06 17:40:51 -0300 |
---|---|---|
committer | (quasar) nebula <qznebula@protonmail.com> | 2025-04-10 16:02:41 -0300 |
commit | a446ecc747e7919f6dee4bc3b073e7edb6156a91 (patch) | |
tree | ace69dd336957a07e3c55f275f303cac8d8c13cb /src/data/things/track.js | |
parent | 9696dbe1688dcf9641875ea7a4fab50c5776017b (diff) |
data: make referencedArtworkList work again
Using new find specs {track,album}PrimaryArtwork. It's still mixedFind, and it still does not support matching artworks besides the primary one.
Diffstat (limited to 'src/data/things/track.js')
-rw-r--r-- | src/data/things/track.js | 30 |
1 files changed, 27 insertions, 3 deletions
diff --git a/src/data/things/track.js b/src/data/things/track.js index 1cc169be..6645008c 100644 --- a/src/data/things/track.js +++ b/src/data/things/track.js @@ -347,11 +347,10 @@ export class Track extends Thing { reverse: soupyReverse(), // used for referencedArtworkList (mixedFind) - albumData: wikiData({ - class: input.value(Album), + artworkData: wikiData({ + class: input.value(Artwork), }), - // used for referencedArtworkList (mixedFind) // used for withAlwaysReferenceByDirectory (for some reason) trackData: wikiData({ class: input.value(Track), @@ -641,6 +640,31 @@ export class Track extends Thing { ? [] : [track.name]), }, + + trackPrimaryArtwork: { + [Thing.findThisThingOnly]: false, + + referenceTypes: [ + 'track', + 'track-referencing-artworks', + 'track-referenced-artworks', + ], + + bindTo: 'artworkData', + + include: (artwork, {Artwork, Track}) => + artwork instanceof Artwork && + artwork.thing instanceof Track && + artwork === artwork.thing.trackArtworks[0], + + getMatchableNames: ({thing: track}) => + (track.alwaysReferenceByDirectory + ? [] + : [track.name]), + + getMatchableDirectories: ({thing: track}) => + [track.directory], + }, }; static [Thing.reverseSpecs] = { |