diff options
Diffstat (limited to 'src/data/things')
-rw-r--r-- | src/data/things/album.js | 35 | ||||
-rw-r--r-- | src/data/things/track.js | 30 |
2 files changed, 55 insertions, 10 deletions
diff --git a/src/data/things/album.js b/src/data/things/album.js index fc5c9d7e..9137ac31 100644 --- a/src/data/things/album.js +++ b/src/data/things/album.js @@ -67,6 +67,7 @@ export class Album extends Thing { static [Thing.getPropertyDescriptors] = ({ ArtTag, + Artwork, Group, Track, TrackSection, @@ -269,13 +270,8 @@ export class Album extends Thing { reverse: soupyReverse(), // used for referencedArtworkList (mixedFind) - albumData: wikiData({ - class: input.value(Album), - }), - - // used for referencedArtworkList (mixedFind) - trackData: wikiData({ - class: input.value(Track), + artworkData: wikiData({ + class: input.value(Artwork), }), // used for withMatchingContributionPresets (indirectly by Contribution) @@ -381,6 +377,31 @@ export class Album extends Thing { ? [] : [album.name]), }, + + albumPrimaryArtwork: { + [Thing.findThisThingOnly]: false, + + referenceTypes: [ + 'album', + 'album-referencing-artworks', + 'album-referenced-artworks', + ], + + bindTo: 'artworkData', + + include: (artwork, {Artwork, Album}) => + artwork instanceof Artwork && + artwork.thing instanceof Album && + artwork === artwork.thing.coverArtworks[0], + + getMatchableNames: ({thing: album}) => + (album.alwaysReferenceByDirectory + ? [] + : [album.name]), + + getMatchableDirectories: ({thing: album}) => + [album.directory], + }, }; static [Thing.reverseSpecs] = { 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] = { |