diff options
author | (quasar) nebula <qznebula@protonmail.com> | 2024-12-25 18:11:41 -0400 |
---|---|---|
committer | (quasar) nebula <qznebula@protonmail.com> | 2024-12-25 18:11:41 -0400 |
commit | a47bd0a3c5bce526fcff1cd7b8c5796bc1bf059a (patch) | |
tree | 3a0021ac9774a1f7ddbd85d2dc54fb10b3cfab21 /src/data/composite/wiki-data/withReverseAnnotatedReferenceList.js | |
parent | 0f65e26bff177bf8117c2d23972758f04dde2b93 (diff) |
data: amorphize reverse annotated reference lists
Diffstat (limited to 'src/data/composite/wiki-data/withReverseAnnotatedReferenceList.js')
-rw-r--r-- | src/data/composite/wiki-data/withReverseAnnotatedReferenceList.js | 41 |
1 files changed, 33 insertions, 8 deletions
diff --git a/src/data/composite/wiki-data/withReverseAnnotatedReferenceList.js b/src/data/composite/wiki-data/withReverseAnnotatedReferenceList.js index 168b68c0..debc68e4 100644 --- a/src/data/composite/wiki-data/withReverseAnnotatedReferenceList.js +++ b/src/data/composite/wiki-data/withReverseAnnotatedReferenceList.js @@ -5,6 +5,10 @@ // "flipping" the directionality of references: in a forward reference list, // `thing` points to the thing being referenced, while here, it points to the // referencing thing. +// +// This behavior can be customized to respect reference lists which are shaped +// differently than the default and/or to customize the reversed property and +// provide a less generic label than just "thing". import withReverseList_template from './helpers/withReverseList-template.js'; @@ -24,6 +28,12 @@ export default withReverseList_template({ propertyInputName: 'list', outputName: '#reverseAnnotatedReferenceList', + additionalInputs: { + forward: input({type: 'string', defaultValue: 'thing'}), + backward: input({type: 'string', defaultValue: 'thing'}), + annotation: input({type: 'string', defaultValue: 'annotation'}), + }, + customCompositionSteps: () => [ withPropertyFromList({ list: input('data'), @@ -52,28 +62,43 @@ export default withReverseList_template({ withPropertyFromList({ list: '#references', - property: input.value('annotation'), + property: input('annotation'), }).outputs({ - '#references.annotation': '#annotations', + '#values': '#annotations', }), { - dependencies: ['#things', '#annotations'], + dependencies: [ + input('backward'), + input('annotation'), + '#things', + '#annotations', + ], + compute: (continuation, { + [input('backward')]: thingProperty, + [input('annotation')]: annotationProperty, ['#things']: things, ['#annotations']: annotations, }) => continuation({ - ['#referencingThings']: + '#referencingThings': stitchArrays({ - thing: things, - annotation: annotations, + [thingProperty]: things, + [annotationProperty]: annotations, }), }), }, - withMappedList({ + withPropertyFromList({ list: '#references', - map: input.value(reference => [reference.thing]), + property: input('forward'), + }).outputs({ + '#values': '#individualReferencedThings', + }), + + withMappedList({ + list: '#individualReferencedThings', + map: input.value(thing => [thing]), }).outputs({ '#mappedList': '#referencedThings', }), |