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
|
// Exposes the update value of an {update: true} property as it is,
// or continues if it's unavailable.
//
// See withResultOfAvailabilityCheck for {mode} options.
//
// Provide {validate} here to conveniently set a custom validation check
// for this property's update value.
//
import {input, templateCompositeFrom} from '#composite';
import exposeDependencyOrContinue from './exposeDependencyOrContinue.js';
import inputAvailabilityCheckMode from './inputAvailabilityCheckMode.js';
export default templateCompositeFrom({
annotation: `exposeUpdateValueOrContinue`,
inputs: {
mode: inputAvailabilityCheckMode(),
validate: input({
type: 'function',
defaultValue: null,
}),
},
update: ({
[input.staticValue('validate')]: validate,
}) =>
(validate
? {validate}
: {}),
steps: () => [
exposeDependencyOrContinue({
dependency: input.updateValue(),
mode: input('mode'),
}),
],
});
|