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
|
// Exposes a dependency as it is, or continues if it's unavailable.
// See withResultOfAvailabilityCheck for {mode} options.
import {input, templateCompositeFrom} from '#composite';
import inputAvailabilityCheckMode from './inputAvailabilityCheckMode.js';
import withResultOfAvailabilityCheck from './withResultOfAvailabilityCheck.js';
export default templateCompositeFrom({
annotation: `exposeDependencyOrContinue`,
inputs: {
dependency: input({acceptsNull: true}),
mode: inputAvailabilityCheckMode(),
},
steps: () => [
withResultOfAvailabilityCheck({
from: input('dependency'),
mode: input('mode'),
}),
{
dependencies: ['#availability', input('dependency')],
compute: (continuation, {
['#availability']: availability,
[input('dependency')]: dependency,
}) =>
(availability
? continuation.exit(dependency)
: continuation()),
},
],
});
|