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
|
// Like withReverseReferenceList, but for finding all things which reference
// the current thing by a property that contains a single reference, rather
// than within a reference list.
import withReverseList_template from './helpers/withReverseList-template.js';
import {input} from '#composite';
import {withAvailabilityFilter} from '#composite/control-flow';
import {withMappedList, withPropertyFromList} from '#composite/data';
export default withReverseList_template({
annotation: `withReverseSingleReferenceList`,
propertyInputName: 'ref',
outputName: '#reverseSingleReferenceList',
customCompositionSteps: () => [
{
dependencies: [input('data')],
compute: (continuation, {
[input('data')]: data,
}) => continuation({
['#referencingThings']:
data,
}),
},
withPropertyFromList({
list: '#referencingThings',
property: input('ref'),
}).outputs({
'#values': '#individualReferencedThings',
}),
withAvailabilityFilter({
from: '#individualReferencedThings',
}),
// This map wraps each referenced thing in a single-item array.
// Each referencing thing references exactly one thing, if any.
withMappedList({
list: '#individualReferencedThings',
filter: '#availabilityFilter',
map: input.value(thing => [thing]),
}).outputs({
'#mappedList': '#referencedThings',
}),
],
});
|