1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
|
import {input, templateCompositeFrom} from '#composite';
import {isContributionList} from '#validators';
import {exposeDependencyOrContinue} from '#composite/control-flow';
import {
withRecontextualizedContributionList,
withRedatedContributionList,
withResolvedContribs,
} from '#composite/wiki-data';
import exitWithoutUniqueCoverArt from './exitWithoutUniqueCoverArt.js';
import withPropertyFromAlbum from './withPropertyFromAlbum.js';
import withTrackArtDate from './withTrackArtDate.js';
export default templateCompositeFrom({
annotation: `withCoverArtistContribs`,
inputs: {
from: input({
defaultDependency: 'coverArtistContribs',
validate: isContributionList,
acceptsNull: true,
}),
},
outputs: ['#coverArtistContribs'],
steps: () => [
exitWithoutUniqueCoverArt({
value: input.value([]),
}),
withTrackArtDate(),
withResolvedContribs({
from: input('from'),
thingProperty: input.value('coverArtistContribs'),
artistProperty: input.value('trackCoverArtistContributions'),
date: '#trackArtDate',
}).outputs({
'#resolvedContribs': '#coverArtistContribs',
}),
exposeDependencyOrContinue({
dependency: '#coverArtistContribs',
mode: input.value('empty'),
}),
withPropertyFromAlbum({
property: input.value('trackCoverArtistContribs'),
}),
withRecontextualizedContributionList({
list: '#album.trackCoverArtistContribs',
artistProperty: input.value('trackCoverArtistContributions'),
}),
withRedatedContributionList({
list: '#album.trackCoverArtistContribs',
date: '#trackArtDate',
}),
{
dependencies: ['#album.trackCoverArtistContribs'],
compute: (continuation, {
['#album.trackCoverArtistContribs']: coverArtistContribs,
}) => continuation({
['#coverArtistContribs']: coverArtistContribs,
}),
},
],
});
|