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
|
// Analogous implementation for withReverseReferenceList, for contributions.
import withReverseList_template from './helpers/withReverseList-template.js';
import {input} from '#composite';
import {withFlattenedList, withMappedList, withPropertyFromList}
from '#composite/data';
export default withReverseList_template({
annotation: `withReverseContributionList`,
propertyInputName: 'list',
outputName: '#reverseContributionList',
customCompositionSteps: () => [
withPropertyFromList({
list: input('data'),
property: input('list'),
}).outputs({
'#values': '#contributionLists',
}),
withFlattenedList({
list: '#contributionLists',
}).outputs({
'#flattenedList': '#referencingThings',
}),
withPropertyFromList({
list: '#referencingThings',
property: input.value('artist'),
}),
withMappedList({
list: '#referencingThings.artist',
map: input.value(artist => [artist]),
}).outputs({
'#mappedList': '#referencedThings',
}),
],
});
|