diff options
Diffstat (limited to 'src/data/composite')
-rw-r--r-- | src/data/composite/wiki-data/withResolvedAnnotatedReferenceList.js | 49 | ||||
-rw-r--r-- | src/data/composite/wiki-properties/annotatedReferenceList.js | 37 |
2 files changed, 60 insertions, 26 deletions
diff --git a/src/data/composite/wiki-data/withResolvedAnnotatedReferenceList.js b/src/data/composite/wiki-data/withResolvedAnnotatedReferenceList.js index ac6b15fa..e2b8a0a1 100644 --- a/src/data/composite/wiki-data/withResolvedAnnotatedReferenceList.js +++ b/src/data/composite/wiki-data/withResolvedAnnotatedReferenceList.js @@ -1,9 +1,8 @@ import {input, templateCompositeFrom} from '#composite'; import {stitchArrays} from '#sugar'; -import {isString, optional, validateArrayItems, validateProperties} - from '#validators'; +import {isObject, validateArrayItems} from '#validators'; -import {withPropertiesFromList} from '#composite/data'; +import {withPropertyFromList} from '#composite/data'; import { exitWithoutDependency, @@ -21,16 +20,14 @@ export default templateCompositeFrom({ inputs: { list: input({ - validate: - validateArrayItems( - validateProperties({ - reference: isString, - annotation: optional(isString), - })), - + validate: validateArrayItems(isObject), acceptsNull: true, }), + reference: input({type: 'string', defaultValue: 'reference'}), + annotation: input({type: 'string', defaultValue: 'annotation'}), + thing: input({type: 'string', defaultValue: 'thing'}), + data: inputWikiData({allowMixedTypes: true}), find: input({type: 'function'}), @@ -53,16 +50,22 @@ export default templateCompositeFrom({ }), }), - withPropertiesFromList({ + withPropertyFromList({ + list: input('list'), + property: input('reference'), + }).outputs({ + ['#values']: '#references', + }), + + withPropertyFromList({ list: input('list'), - properties: input.value([ - 'reference', - 'annotation', - ]), + property: input('annotation'), + }).outputs({ + ['#values']: '#annotations', }), withResolvedReferenceList({ - list: '#list.reference', + list: '#references', data: input('data'), find: input('find'), notFoundMode: input.value('null'), @@ -70,18 +73,22 @@ export default templateCompositeFrom({ { dependencies: [ + input('thing'), + input('annotation'), '#resolvedReferenceList', - '#list.annotation', + '#annotations', ], compute: (continuation, { - ['#resolvedReferenceList']: thing, - ['#list.annotation']: annotation, + [input('thing')]: thingProperty, + [input('annotation')]: annotationProperty, + ['#resolvedReferenceList']: things, + ['#annotations']: annotations, }) => continuation({ ['#matches']: stitchArrays({ - thing, - annotation, + [thingProperty]: things, + [annotationProperty]: annotations, }), }), }, diff --git a/src/data/composite/wiki-properties/annotatedReferenceList.js b/src/data/composite/wiki-properties/annotatedReferenceList.js index e8e5ac8c..a5e10c82 100644 --- a/src/data/composite/wiki-properties/annotatedReferenceList.js +++ b/src/data/composite/wiki-properties/annotatedReferenceList.js @@ -1,8 +1,15 @@ import {input, templateCompositeFrom} from '#composite'; import find from '#find'; -import {validateAnnotatedReferenceList} from '#validators'; import {combineWikiDataArrays} from '#wiki-data'; +import { + isContentString, + optional, + validateArrayItems, + validateProperties, + validateReference, +} from '#validators'; + import {exposeDependency} from '#composite/control-flow'; import {inputWikiData, withResolvedAnnotatedReferenceList} from '#composite/wiki-data'; @@ -20,16 +27,36 @@ export default templateCompositeFrom({ data: inputWikiData({allowMixedTypes: true}), find: input({type: 'function'}), + + reference: input.staticValue({type: 'string', defaultValue: 'reference'}), + annotation: input.staticValue({type: 'string', defaultValue: 'annotation'}), + thing: input.staticValue({type: 'string', defaultValue: 'thing'}), }, - update: - referenceListUpdateDescription({ - validateReferenceList: validateAnnotatedReferenceList, - }), + update(staticInputs) { + const { + [input.staticValue('reference')]: referenceProperty, + [input.staticValue('annotation')]: annotationProperty, + } = staticInputs; + + return referenceListUpdateDescription({ + validateReferenceList: type => + validateArrayItems( + validateProperties({ + [referenceProperty]: validateReference(type), + [annotationProperty]: optional(isContentString), + })), + })(staticInputs); + }, steps: () => [ withResolvedAnnotatedReferenceList({ list: input.updateValue(), + + reference: input('reference'), + annotation: input('annotation'), + thing: input('thing'), + data: input('data'), find: input('find'), }), |