diff options
author | (quasar) nebula <qznebula@protonmail.com> | 2023-12-03 17:53:51 -0400 |
---|---|---|
committer | (quasar) nebula <qznebula@protonmail.com> | 2023-12-03 17:53:51 -0400 |
commit | 7039d7fa471318df40c1905cd5ac52688dc6adcf (patch) | |
tree | 6c859ab2b0ee7bf86089475952ec529f40b95b83 /src/data/composite/things/track/trackAdditionalNameList.js | |
parent | 168efd0f2685fa00259fffc9f26c7f6a30a61991 (diff) | |
parent | 2d054508f58147f5968a10f39c2f87ba62dd91f7 (diff) |
Merge branch 'preview' into time-tooltips
Diffstat (limited to 'src/data/composite/things/track/trackAdditionalNameList.js')
-rw-r--r-- | src/data/composite/things/track/trackAdditionalNameList.js | 38 |
1 files changed, 38 insertions, 0 deletions
diff --git a/src/data/composite/things/track/trackAdditionalNameList.js b/src/data/composite/things/track/trackAdditionalNameList.js new file mode 100644 index 00000000..65a2263d --- /dev/null +++ b/src/data/composite/things/track/trackAdditionalNameList.js @@ -0,0 +1,38 @@ +// Compiles additional names from various sources. + +import {input, templateCompositeFrom} from '#composite'; +import {isAdditionalNameList} from '#validators'; + +import withInferredAdditionalNames from './withInferredAdditionalNames.js'; +import withSharedAdditionalNames from './withSharedAdditionalNames.js'; + +export default templateCompositeFrom({ + annotation: `trackAdditionalNameList`, + + compose: false, + + update: {validate: isAdditionalNameList}, + + steps: () => [ + withInferredAdditionalNames(), + withSharedAdditionalNames(), + + { + dependencies: [ + '#inferredAdditionalNames', + '#sharedAdditionalNames', + input.updateValue(), + ], + + compute: ({ + ['#inferredAdditionalNames']: inferredAdditionalNames, + ['#sharedAdditionalNames']: sharedAdditionalNames, + [input.updateValue()]: providedAdditionalNames, + }) => [ + ...providedAdditionalNames ?? [], + ...sharedAdditionalNames, + ...inferredAdditionalNames, + ], + }, + ], +}); |