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
74
75
76
77
78
|
// Resolves a list of references, with each reference matched with provided
// data in the same way as withResolvedReference. By default it will filter
// out references which don't match, but this can be changed to early exit
// ({notFoundMode: 'exit'}) or leave null in place ('null').
import {input, templateCompositeFrom} from '#composite';
import {isString, validateArrayItems} from '#validators';
import {withMappedList} from '#composite/data';
import {
exitWithoutDependency,
raiseOutputWithoutDependency,
withAvailabilityFilter,
} from '#composite/control-flow';
import inputNotFoundMode from './inputNotFoundMode.js';
import inputWikiData from './inputWikiData.js';
import raiseResolvedReferenceList from './raiseResolvedReferenceList.js';
export default templateCompositeFrom({
annotation: `withResolvedReferenceList`,
inputs: {
list: input({
validate: validateArrayItems(isString),
acceptsNull: true,
}),
data: inputWikiData({allowMixedTypes: true}),
find: input({type: 'function'}),
notFoundMode: inputNotFoundMode(),
},
outputs: ['#resolvedReferenceList'],
steps: () => [
raiseOutputWithoutDependency({
dependency: input('list'),
mode: input.value('empty'),
output: input.value({
['#resolvedReferenceList']: [],
}),
}),
{
dependencies: [input('data'), input('find')],
compute: (continuation, {
[input('data')]: data,
[input('find')]: findFunction,
}) => continuation({
['#map']:
(data
? ref => findFunction(ref, data, {mode: 'quiet'})
: ref => findFunction(ref, {mode: 'quiet'})),
}),
},
withMappedList({
list: input('list'),
map: '#map',
}).outputs({
'#mappedList': '#matches',
}),
withAvailabilityFilter({
from: '#matches',
}),
raiseResolvedReferenceList({
notFoundMode: input('notFoundMode'),
results: '#matches',
filter: '#availabilityFilter',
outputs: input.value('#resolvedReferenceList'),
}),
],
});
|