| 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'),
    }),
  ],
});
 |