« get me outta code hell

withReverseSingleReferenceList.js « wiki-data « composite « data « src - hsmusic-wiki - HSMusic - static wiki software cataloguing collaborative creation
about summary refs log tree commit diff
path: root/src/data/composite/wiki-data/withReverseSingleReferenceList.js
blob: 569e9ba04677e197e496c1ee733e188ef88aeb0d (plain)
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
41
42
43
44
45
46
47
48
49
50
// Like withReverseReferenceList, but for finding all things which reference
// the current thing by a property that contains a single reference, rather
// than within a reference list.

import withReverseList_template from './helpers/withReverseList-template.js';

import {input} from '#composite';

import {withAvailabilityFilter} from '#composite/control-flow';
import {withMappedList, withPropertyFromList} from '#composite/data';

export default withReverseList_template({
  annotation: `withReverseSingleReferenceList`,

  propertyInputName: 'ref',
  outputName: '#reverseSingleReferenceList',

  customCompositionSteps: () => [
    {
      dependencies: [input('data')],
      compute: (continuation, {
        [input('data')]: data,
      }) => continuation({
        ['#referencingThings']:
          data,
      }),
    },

    withPropertyFromList({
      list: '#referencingThings',
      property: input('ref'),
    }).outputs({
      '#values': '#individualReferencedThings',
    }),

    withAvailabilityFilter({
      from: '#individualReferencedThings',
    }),

    // This map wraps each referenced thing in a single-item array.
    // Each referencing thing references exactly one thing, if any.
    withMappedList({
      list: '#individualReferencedThings',
      filter: '#availabilityFilter',
      map: input.value(thing => [thing]),
    }).outputs({
      '#mappedList': '#referencedThings',
    }),
  ],
});