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
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
|
import {input, templateCompositeFrom} from '#composite';
import {stitchArrays} from '#sugar';
import {isCommentary} from '#validators';
import {commentaryRegexCaseSensitive} from '#wiki-data';
import {
fillMissingListItems,
withFlattenedList,
withPropertiesFromList,
withUnflattenedList,
} from '#composite/data';
import inputSoupyFind from './inputSoupyFind.js';
import processContentEntryDates from './processContentEntryDates.js';
import withParsedContentEntries from './withParsedContentEntries.js';
import withResolvedReferenceList from './withResolvedReferenceList.js';
export default templateCompositeFrom({
annotation: `withParsedCommentaryEntries`,
inputs: {
from: input({validate: isCommentary}),
},
outputs: ['#parsedCommentaryEntries'],
steps: () => [
withParsedContentEntries({
from: input('from'),
caseSensitiveRegex: input.value(commentaryRegexCaseSensitive),
}),
withPropertiesFromList({
list: '#parsedContentEntryHeadings',
prefix: input.value('#entries'),
properties: input.value([
'artistReferences',
'artistDisplayText',
'annotation',
'date',
'secondDate',
'dateKind',
'accessDate',
'accessKind',
]),
}),
// The artistReferences group will always have a value, since it's required
// for the line to match in the first place.
{
dependencies: ['#entries.artistReferences'],
compute: (continuation, {
['#entries.artistReferences']: artistReferenceTexts,
}) => continuation({
['#entries.artistReferences']:
artistReferenceTexts
.map(text => text.split(',').map(ref => ref.trim())),
}),
},
withFlattenedList({
list: '#entries.artistReferences',
}),
withResolvedReferenceList({
list: '#flattenedList',
find: inputSoupyFind.input('artist'),
notFoundMode: input.value('null'),
}),
withUnflattenedList({
list: '#resolvedReferenceList',
}).outputs({
'#unflattenedList': '#entries.artists',
}),
fillMissingListItems({
list: '#entries.artistDisplayText',
fill: input.value(null),
}),
fillMissingListItems({
list: '#entries.annotation',
fill: input.value(null),
}),
processContentEntryDates(),
{
dependencies: [
'#entries.artists',
'#entries.artistDisplayText',
'#entries.annotation',
'#entries.date',
'#entries.secondDate',
'#entries.dateKind',
'#entries.accessDate',
'#entries.accessKind',
'#parsedContentEntryBodies',
],
compute: (continuation, {
['#entries.artists']: artists,
['#entries.artistDisplayText']: artistDisplayText,
['#entries.annotation']: annotation,
['#entries.date']: date,
['#entries.secondDate']: secondDate,
['#entries.dateKind']: dateKind,
['#entries.accessDate']: accessDate,
['#entries.accessKind']: accessKind,
['#parsedContentEntryBodies']: body,
}) => continuation({
['#parsedCommentaryEntries']:
stitchArrays({
artists,
artistDisplayText,
annotation,
date,
secondDate,
dateKind,
accessDate,
accessKind,
body,
}),
}),
},
],
});
|