| 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,
      }),
    },
  ],
});
 |