@inseefr/lunatic 0.3.0-experimental → 0.3.0-prisme

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (225) hide show
  1. package/LICENSE +21 -21
  2. package/README.md +25 -23
  3. package/lib/index.esm.js +3539 -0
  4. package/lib/index.esm.js.map +1 -0
  5. package/lib/index.js +240 -282
  6. package/lib/index.js.map +1 -1
  7. package/package.json +179 -173
  8. package/src/components/breadcrumb/breadcrumb.scss +22 -22
  9. package/src/components/checkbox/boolean.js +172 -172
  10. package/src/components/checkbox/checkbox.scss +73 -73
  11. package/src/components/checkbox/group.js +231 -231
  12. package/src/components/checkbox/one.js +11 -11
  13. package/src/components/component-wrapper/controls/component.js +70 -70
  14. package/src/components/component-wrapper/controls/controls.scss +6 -6
  15. package/src/components/component-wrapper/controls/index.js +1 -1
  16. package/src/components/component-wrapper/controls/validators/datepicker.js +44 -33
  17. package/src/components/component-wrapper/controls/validators/index.js +16 -16
  18. package/src/components/component-wrapper/controls/validators/input-number.js +23 -23
  19. package/src/components/component-wrapper/index.js +1 -1
  20. package/src/components/component-wrapper/missing/component.js +200 -180
  21. package/src/components/component-wrapper/missing/index.js +1 -1
  22. package/src/components/component-wrapper/missing/missing.scss +32 -32
  23. package/src/components/component-wrapper/wrapper.js +23 -23
  24. package/src/components/components.js +19 -19
  25. package/src/components/datepicker/component.js +26 -30
  26. package/src/components/declarations/component.js +46 -46
  27. package/src/components/declarations/declarations.scss +40 -40
  28. package/src/components/declarations/wrappers/input-declarations-wrapper.js +328 -302
  29. package/src/components/declarations/wrappers/simple-declarations-wrapper.js +54 -54
  30. package/src/components/dropdown/commons/actions.js +65 -65
  31. package/src/components/dropdown/commons/children-to-option.js +9 -9
  32. package/src/components/dropdown/commons/cleaner-callbacks.js +58 -58
  33. package/src/components/dropdown/commons/components/dropdown-container.js +29 -29
  34. package/src/components/dropdown/commons/components/dropdown.js +204 -183
  35. package/src/components/dropdown/commons/components/panel.js +78 -78
  36. package/src/components/dropdown/commons/event-callbacks/on-mousedown-callback.js +15 -15
  37. package/src/components/dropdown/commons/reducer.js +152 -152
  38. package/src/components/dropdown/commons/tools/index.js +17 -17
  39. package/src/components/dropdown/component.js +135 -135
  40. package/src/components/dropdown/dropdown-edit/dropdown-edit.js +194 -191
  41. package/src/components/dropdown/dropdown-edit/index.js +11 -11
  42. package/src/components/dropdown/dropdown-simple/dropdown.js +173 -171
  43. package/src/components/dropdown/dropdown-simple/index.js +20 -20
  44. package/src/components/dropdown/dropdown.scss +178 -178
  45. package/src/components/icon/icon.scss +15 -15
  46. package/src/components/index.js +2 -0
  47. package/src/components/index.scss +177 -177
  48. package/src/components/input/input-number.js +30 -28
  49. package/src/components/input/input.js +11 -11
  50. package/src/components/input/input.scss +31 -31
  51. package/src/components/loop/component.js +170 -170
  52. package/src/components/loop/loop.scss +13 -13
  53. package/src/components/loop/wrapper.js +15 -15
  54. package/src/components/loop-constructor/block/block.scss +10 -10
  55. package/src/components/loop-constructor/block/component.js +9 -9
  56. package/src/components/loop-constructor/roster/component.js +8 -8
  57. package/src/components/loop-constructor/wrapper/body-component.js +146 -131
  58. package/src/components/loop-constructor/wrapper/component.js +190 -190
  59. package/src/components/modal/component.js +36 -36
  60. package/src/components/modal/index.js +1 -1
  61. package/src/components/modal/modal.scss +33 -33
  62. package/src/components/progress-bar/progress-bar.scss +54 -54
  63. package/src/components/radio/component.js +9 -9
  64. package/src/components/radio/radio.scss +59 -59
  65. package/src/components/sequence/component.js +50 -50
  66. package/src/components/sequence/sequence.scss +10 -10
  67. package/src/components/subsequence/component.js +49 -49
  68. package/src/components/suggester/check-store.js +2 -4
  69. package/src/components/suggester/components/panel/default-option-renderer.js +27 -27
  70. package/src/components/suggester/components/panel/option-container.js +61 -61
  71. package/src/components/suggester/components/panel/panel.js +47 -47
  72. package/src/components/suggester/components/selection/default-label-renderer.js +31 -31
  73. package/src/components/suggester/components/selection/label.js +35 -35
  74. package/src/components/suggester/components/selection/selection.js +50 -50
  75. package/src/components/suggester/components/suggester-content.js +2 -2
  76. package/src/components/suggester/components/suggester.js +128 -88
  77. package/src/components/suggester/components/suggester.scss +101 -101
  78. package/src/components/suggester/default-style.scss +125 -125
  79. package/src/components/suggester/find-best-label/find-best-label.js +51 -51
  80. package/src/components/suggester/find-best-label/index.js +1 -1
  81. package/src/components/suggester/idb-suggester.js +73 -67
  82. package/src/components/suggester/lunatic-suggester.js +140 -139
  83. package/src/components/suggester/searching/create-searching.js +49 -49
  84. package/src/components/suggester/searching/index.js +1 -1
  85. package/src/components/suggester/state-management/actions.js +38 -38
  86. package/src/components/suggester/state-management/reducer/reduce-on-delete-search.js +11 -11
  87. package/src/components/suggester/state-management/reducer/reduce-on-init.js +29 -29
  88. package/src/components/suggester/state-management/reducer/reducer.js +38 -38
  89. package/src/components/suggester/suggester-wrapper.js +127 -121
  90. package/src/components/suggester-loader-widget/loader.js +67 -67
  91. package/src/components/suggester-loader-widget/widget.js +123 -123
  92. package/src/components/table/table.js +173 -171
  93. package/src/components/table/table.scss +26 -26
  94. package/src/components/textarea/component.js +11 -11
  95. package/src/components/textarea/textarea.scss +8 -8
  96. package/src/components/tooltip/tooltip.scss +30 -30
  97. package/src/stories/breadcrumb/breadcrumb.stories.js +21 -21
  98. package/src/stories/checkbox-boolean/data.json +78 -78
  99. package/src/stories/datepicker/data.json +45 -45
  100. package/src/stories/declarations/declarations.stories.js +116 -116
  101. package/src/stories/dropdown/README.md +44 -44
  102. package/src/stories/dropdown/data.json +98 -98
  103. package/src/stories/dropdown/dropdown.stories.js +89 -89
  104. package/src/stories/progress-bar/progress-bar.stories.js +24 -24
  105. package/src/stories/questionnaire/arithmetic-management.json +47 -0
  106. package/src/stories/questionnaire/arithmetic.json +247 -247
  107. package/src/stories/questionnaire/calc-var.json +187 -187
  108. package/src/stories/questionnaire/data-logement.json +2691 -2691
  109. package/src/stories/questionnaire/kish.json +275 -0
  110. package/src/stories/questionnaire/logement-queen.json +23390 -22706
  111. package/src/stories/questionnaire/logement-s2.json +46028 -44537
  112. package/src/stories/questionnaire/logement-sequence.json +26741 -26741
  113. package/src/stories/questionnaire/logement.json +21072 -21072
  114. package/src/stories/questionnaire/loop-and-controls.json +481 -0
  115. package/src/stories/questionnaire/questionnaire.stories.js +236 -172
  116. package/src/stories/questionnaire/update-external/data.json +1 -0
  117. package/src/stories/questionnaire/update-external/questionnaire.json +75 -0
  118. package/src/stories/sequence/sequence.stories.js +32 -32
  119. package/src/stories/subsequence/subsequence.stories.js +32 -32
  120. package/src/stories/suggester/README.md +46 -46
  121. package/src/stories/suggester/bailleurs-sociaux/fetch-bailleurs.js +15 -15
  122. package/src/stories/suggester/bailleurs-sociaux/index.js +2 -2
  123. package/src/stories/suggester/bailleurs-sociaux/option-bailleur-renderer.js +58 -58
  124. package/src/stories/suggester/bailleurs-sociaux/preloader.svg +51 -51
  125. package/src/stories/suggester/bailleurs-sociaux/theme.scss +22 -22
  126. package/src/stories/suggester/bailleurs-sociaux-2021/fetch-bailleurs.js +12 -0
  127. package/src/stories/suggester/bailleurs-sociaux-2021/index.js +1 -0
  128. package/src/stories/suggester/cog-communes/fetch-cog.js +15 -15
  129. package/src/stories/suggester/data-auto.json +232 -232
  130. package/src/stories/suggester/data-vtl.json +82 -82
  131. package/src/stories/suggester/data.json +169 -136
  132. package/src/stories/suggester/naf-rev2/index.js +2 -2
  133. package/src/stories/suggester/naf-rev2/option-naf-renderer.js +17 -17
  134. package/src/stories/suggester/suggester-workers.stories.js +226 -179
  135. package/src/stories/suggester/suggester.stories.js +138 -133
  136. package/src/stories/utils/orchestrator-split.js +119 -0
  137. package/src/stories/utils/orchestrator.js +119 -110
  138. package/src/tests/components/input-number.spec.js +188 -188
  139. package/src/tests/components/loops/roster-loop.json +71 -71
  140. package/src/tests/components/missing-wrapper.spec.js +32 -32
  141. package/src/tests/utils/lib/table/roster.spec.js +25 -25
  142. package/src/tests/utils/to-expose/handler/results/res-input-edited.json +1 -1
  143. package/src/tests/utils/to-expose/init-questionnaire/questionnaire.json +148 -148
  144. package/src/tests/utils/to-expose/init-questionnaire/result.json +181 -181
  145. package/src/utils/components/dragger/dragger.scss +7 -7
  146. package/src/utils/idb-tools/create-db-opener.js +43 -43
  147. package/src/utils/idb-tools/create-open-db.js +25 -25
  148. package/src/utils/idb-tools/idb-bulk-insert.js +96 -96
  149. package/src/utils/idb-tools/index.js +10 -10
  150. package/src/utils/idb-tools/insert-entity.js +15 -15
  151. package/src/utils/idb-tools/open-db.js +13 -13
  152. package/src/utils/idb-tools/open-or-create-db.js +34 -34
  153. package/src/utils/lib/controls/index.js +1 -1
  154. package/src/utils/lib/controls/utils.js +152 -146
  155. package/src/utils/lib/decorator/title-decorator.js +16 -16
  156. package/src/utils/lib/env.js +2 -2
  157. package/src/utils/lib/index.js +21 -20
  158. package/src/utils/lib/input-number.js +1 -1
  159. package/src/utils/lib/options-positioning.js +9 -9
  160. package/src/utils/lib/pagination/navigation/shared.js +256 -256
  161. package/src/utils/lib/prop-types/lines.js +6 -6
  162. package/src/utils/lib/responses.js +11 -11
  163. package/src/utils/lib/splitting.js +142 -0
  164. package/src/utils/lib/style.js +10 -10
  165. package/src/utils/store-tools/auto-load.js +74 -74
  166. package/src/utils/suggester-workers/append-to-index/append.js +25 -25
  167. package/src/utils/suggester-workers/append-to-index/append.worker.js +16 -16
  168. package/src/utils/suggester-workers/append-to-index/create-append-task.js +45 -45
  169. package/src/utils/suggester-workers/append-to-index/index.js +2 -2
  170. package/src/utils/suggester-workers/append-to-index/prepare-entities.js +61 -61
  171. package/src/utils/suggester-workers/append-to-index/store-messages.js +21 -21
  172. package/src/utils/suggester-workers/commons-tokenizer/create-entity-tokenizer.js +56 -54
  173. package/src/utils/suggester-workers/commons-tokenizer/create-fields-tokenizer.js +56 -52
  174. package/src/utils/suggester-workers/commons-tokenizer/create-filter-stop-words.js +17 -17
  175. package/src/utils/suggester-workers/commons-tokenizer/filters/compose-filters.js +10 -10
  176. package/src/utils/suggester-workers/commons-tokenizer/filters/create-filter-stop-words.js +17 -17
  177. package/src/utils/suggester-workers/commons-tokenizer/filters/create-filter-stop-words.spec.js +14 -14
  178. package/src/utils/suggester-workers/commons-tokenizer/filters/{filter-accents-to-lower.js → filter-accents.js} +12 -12
  179. package/src/utils/suggester-workers/commons-tokenizer/filters/{filter-accents-to-lower.spec.js → filter-accents.spec.js} +12 -12
  180. package/src/utils/suggester-workers/commons-tokenizer/filters/filter-double.js +12 -12
  181. package/src/utils/suggester-workers/commons-tokenizer/filters/filter-double.spec.js +20 -20
  182. package/src/utils/suggester-workers/commons-tokenizer/filters/filter-length.js +7 -7
  183. package/src/utils/suggester-workers/commons-tokenizer/filters/filter-length.spec.js +18 -18
  184. package/src/utils/suggester-workers/commons-tokenizer/filters/filter-stemmer.js +13 -13
  185. package/src/utils/suggester-workers/commons-tokenizer/filters/filter-stemmer.spec.js +12 -12
  186. package/src/utils/suggester-workers/commons-tokenizer/filters/filter-synonyms.js +36 -10
  187. package/src/utils/suggester-workers/commons-tokenizer/filters/filter-synonyms.spec.js +12 -12
  188. package/src/utils/suggester-workers/commons-tokenizer/filters/filter-to-lower.js +10 -0
  189. package/src/utils/suggester-workers/commons-tokenizer/filters/filter-to-lower.spec.js +12 -0
  190. package/src/utils/suggester-workers/commons-tokenizer/filters/index.js +2 -2
  191. package/src/utils/suggester-workers/commons-tokenizer/filters/stop-words.js +118 -118
  192. package/src/utils/suggester-workers/commons-tokenizer/get-regexp-from-pattern.js +8 -8
  193. package/src/utils/suggester-workers/commons-tokenizer/get-stemmer.js +18 -18
  194. package/src/utils/suggester-workers/commons-tokenizer/index.js +9 -8
  195. package/src/utils/suggester-workers/commons-tokenizer/prepare-string-indexation.js +13 -13
  196. package/src/utils/suggester-workers/commons-tokenizer/soft-tokenizer.js +7 -7
  197. package/src/utils/suggester-workers/create-worker.js +56 -56
  198. package/src/utils/suggester-workers/find-best-label/find-best-label.js +39 -39
  199. package/src/utils/suggester-workers/find-best-label/find-best-label.worker.js +40 -40
  200. package/src/utils/suggester-workers/find-best-label/tokenize.js +30 -30
  201. package/src/utils/suggester-workers/find-best-label/tokenize.spec.js +19 -19
  202. package/src/utils/suggester-workers/searching/compute-score.js +33 -33
  203. package/src/utils/suggester-workers/searching/get-db.js +18 -18
  204. package/src/utils/suggester-workers/searching/index.js +1 -1
  205. package/src/utils/suggester-workers/searching/order/create-alphanumeric-orderer.js +20 -20
  206. package/src/utils/suggester-workers/searching/order/index.js +19 -19
  207. package/src/utils/suggester-workers/searching/query-parser/index.js +2 -2
  208. package/src/utils/suggester-workers/searching/query-parser/query-parser-soft.js +7 -7
  209. package/src/utils/suggester-workers/searching/query-parser/query-parser-soft.spec.js +24 -24
  210. package/src/utils/suggester-workers/searching/query-parser/query-parser-tokenized.js +34 -28
  211. package/src/utils/suggester-workers/searching/resolve-query-parser.js +27 -27
  212. package/src/utils/suggester-workers/searching/search-in-index.js +17 -17
  213. package/src/utils/suggester-workers/searching/searching.js +70 -70
  214. package/src/utils/suggester-workers/searching/searching.worker.js +11 -11
  215. package/src/utils/to-expose/calculated-variables.js +113 -113
  216. package/src/utils/to-expose/handler.js +149 -112
  217. package/src/utils/to-expose/hooks/filter-components.js +27 -12
  218. package/src/utils/to-expose/hooks/index.js +2 -1
  219. package/src/utils/to-expose/hooks/lunatic-split.js +428 -0
  220. package/src/utils/to-expose/hooks/lunatic.js +284 -235
  221. package/src/utils/to-expose/index.js +1 -1
  222. package/src/utils/to-expose/init-questionnaire.js +164 -164
  223. package/src/utils/to-expose/interpret/vtl.js +18 -18
  224. package/src/utils/to-expose/state.js +66 -58
  225. package/src/tests/utils/to-expose/hooks/use-lunatic.spec.js +0 -46
@@ -1,256 +1,256 @@
1
- import { interpret } from '../../../to-expose/interpret';
2
- import { FLOW_NEXT, FLOW_PREVIOUS } from '../flow';
3
- import {
4
- buildVectorialBindings,
5
- buildLoopBindings,
6
- } from '../../loops/bindings';
7
-
8
- export const getPage = ({
9
- components,
10
- bindings,
11
- currentPage,
12
- featuresWithoutMD,
13
- depth,
14
- flow,
15
- management,
16
- }) => {
17
- const { currentRootPage, currentComponentIndex, currentIteration } =
18
- splitPage(currentPage, depth);
19
-
20
- const filteredComponents = (
21
- flow === FLOW_PREVIOUS ? components.slice().reverse() : components
22
- ).filter(({ page }) => {
23
- if (flow === FLOW_NEXT && !currentRootPage)
24
- return parseInt(page, 10) > parseInt(currentPage, 10);
25
- if (flow === FLOW_NEXT && currentRootPage)
26
- return parseInt(page, 10) >= parseInt(currentPage, 10);
27
- if (flow === FLOW_PREVIOUS && !currentRootPage)
28
- return parseInt(page, 10) < parseInt(currentPage, 10);
29
- if (flow === FLOW_PREVIOUS && currentRootPage)
30
- return parseInt(page, 10) <= parseInt(currentPage, 10);
31
- throw new Error('Unknown type');
32
- });
33
- for (let index = 0; index < filteredComponents.length; index++) {
34
- const component = filteredComponents[index];
35
- const { id, componentType, page, paginatedLoop } = component;
36
-
37
- // TODO: Handle loop into loop
38
- // Easy way: build array with all combinations, but not efficient
39
- if (componentType === 'Loop' && paginatedLoop) {
40
- const {
41
- conditionFilter: { bindingDependencies: loopBD, value: loopV },
42
- } = component;
43
- const loopB = (loopBD || []).reduce(
44
- (acc, b) => ({ ...acc, [b]: bindings[b] }),
45
- {}
46
- );
47
- const loopVectorialB = buildVectorialBindings(loopB);
48
- if (
49
- management ||
50
- interpret(featuresWithoutMD)(loopVectorialB)(loopV) !== true ||
51
- (flow === FLOW_PREVIOUS &&
52
- currentIteration === 1 &&
53
- currentComponentIndex === 1 &&
54
- page === currentRootPage)
55
- )
56
- continue;
57
- const iterations = getIterations({
58
- component,
59
- bindings,
60
- featuresWithoutMD,
61
- });
62
- const { components: loopComponents } = component;
63
- const startedIteration = getStartedIteration({
64
- currentIteration,
65
- currentRootPage,
66
- page,
67
- flow,
68
- iterations,
69
- });
70
- const iterationsArray = buildIterationsArray({
71
- start: flow === FLOW_NEXT ? startedIteration : 0,
72
- end: flow === FLOW_NEXT ? iterations - 1 : startedIteration,
73
- flow,
74
- });
75
- const componentIndexArray = buildIterationsArray({
76
- start: 0,
77
- end: loopComponents.length - 1,
78
- flow,
79
- });
80
- for (const it of iterationsArray.values()) {
81
- for (const componentIndex of componentIndexArray.values()) {
82
- const loopComponent = loopComponents[componentIndex];
83
- if (
84
- hasToBeExcluded({
85
- flow,
86
- currentRootPage,
87
- page,
88
- it,
89
- currentIteration,
90
- currentComponentIndex,
91
- loopComponent,
92
- })
93
- )
94
- continue;
95
- const {
96
- conditionFilter: { bindingDependencies: bDLoop, value: vLoop },
97
- } = loopComponent;
98
- const loopVars = (bDLoop || []).map((b) => {
99
- if (bindings[b]) return [b, bindings[b]];
100
- return [b, null];
101
- });
102
- const loopBindings = buildLoopBindings(it)(loopVars);
103
-
104
- // Need vectorial loopBindings instead of loopBindings?
105
- const res = interpret(featuresWithoutMD)(loopBindings)(vLoop);
106
- if (management || res === true)
107
- return `${loopComponent.page}#${it + 1}`;
108
- }
109
- }
110
- } else {
111
- // Handle Simple Component + Loop on the same page
112
- const block = filteredComponents.filter(
113
- (c) => c.page === page && c.componentType === 'Loop'
114
- );
115
- if (block.length > 0) {
116
- const loopIdOfInterest =
117
- flow === FLOW_NEXT ? block[0].id : block[block.length - 1].id;
118
- const currentComponentIndexInFiltered = filteredComponents.findIndex(
119
- (c) => c.id === id
120
- );
121
- const loopOfInterestIndex = filteredComponents.findIndex(
122
- (c) => c.id === loopIdOfInterest
123
- );
124
- if (
125
- (flow === FLOW_NEXT &&
126
- !(loopOfInterestIndex <= currentComponentIndexInFiltered)) ||
127
- (flow === FLOW_PREVIOUS &&
128
- !(loopOfInterestIndex >= currentComponentIndexInFiltered))
129
- ) {
130
- continue;
131
- }
132
- }
133
- const {
134
- conditionFilter: { bindingDependencies, value },
135
- } = component;
136
- const filterBindings = (bindingDependencies || []).reduce(
137
- (acc, b) => ({ ...acc, [b]: bindings[b] }),
138
- {}
139
- );
140
- const vectorialBindings = buildVectorialBindings(filterBindings);
141
- const res = interpret(featuresWithoutMD)(vectorialBindings)(value);
142
- if (management || res === true) return page;
143
- }
144
- }
145
- };
146
-
147
- const getStartedIteration = ({
148
- currentIteration,
149
- currentRootPage,
150
- page,
151
- flow,
152
- iterations,
153
- }) => {
154
- if (currentIteration && currentRootPage === page) return currentIteration - 1;
155
- if (flow === FLOW_NEXT) return 0;
156
- if (flow === FLOW_PREVIOUS) return iterations - 1;
157
- };
158
-
159
- const buildIterationsArray = ({ end, start, flow }) => {
160
- const array = [...Array(end - start + 1)].map((_, i) => i + start);
161
- return flow === FLOW_PREVIOUS ? array.slice().reverse() : array;
162
- };
163
-
164
- const hasToBeExcluded = ({
165
- flow,
166
- currentRootPage,
167
- page,
168
- it,
169
- currentIteration,
170
- currentComponentIndex,
171
- loopComponent,
172
- }) => {
173
- const { page: loopPage, depth } = loopComponent;
174
- const { currentComponentIndex: loopComponentIndex } = splitPage(
175
- loopPage,
176
- depth
177
- );
178
- if (flow === FLOW_NEXT)
179
- return (
180
- (currentRootPage === page &&
181
- it === currentIteration - 1 &&
182
- loopComponentIndex <= currentComponentIndex) ||
183
- !loopComponent.page
184
- );
185
- if (flow === FLOW_PREVIOUS)
186
- return (
187
- (currentRootPage === page &&
188
- it === currentIteration - 1 &&
189
- loopComponentIndex >= currentComponentIndex) ||
190
- !loopComponent.page
191
- );
192
- return false;
193
- };
194
-
195
- const getIterations = ({ component, bindings, featuresWithoutMD }) => {
196
- const { loopDependencies, iterations: iterationsFormula, lines } = component;
197
- const iterationsBindings = loopDependencies.reduce(
198
- (acc, b) => ({ ...acc, [b]: bindings[b] }),
199
- {}
200
- );
201
- const iterationsVectorialBindings =
202
- buildVectorialBindings(iterationsBindings);
203
- if (iterationsFormula) {
204
- return parseInt(
205
- interpret(featuresWithoutMD)(iterationsVectorialBindings)(
206
- iterationsFormula
207
- ),
208
- 10
209
- );
210
- }
211
- if (lines) {
212
- const { min, max } = lines;
213
- const maxRes = parseInt(
214
- interpret(featuresWithoutMD)(iterationsVectorialBindings)(max),
215
- 10
216
- );
217
- return maxRes || parseInt(min, 10);
218
- }
219
- };
220
-
221
- export const splitPage = (currentPage = '1', depth) => {
222
- const currentPageWithDepth = depth
223
- ? currentPage
224
- .split('.')
225
- .slice(0, depth + 1) // scoped
226
- .join('.')
227
- : currentPage;
228
-
229
- const currentPageWithoutIteration = currentPageWithDepth
230
- .split('#')
231
- .slice(0, -1)
232
- .join('#');
233
-
234
- const currentPageWithoutAnyIteration = currentPageWithDepth
235
- .split('.')
236
- .map((e) => e.split('#')[0])
237
- .join('.');
238
-
239
- const currentRootPage = currentPageWithoutIteration
240
- .split('.')
241
- .slice(0, -1)
242
- .join('.');
243
-
244
- const [currentComponentIndex, currentIteration] = currentPageWithDepth
245
- .split('.')
246
- .pop()
247
- .split('#')
248
- .map((c) => parseInt(c, 10));
249
-
250
- return {
251
- currentRootPage,
252
- currentComponentIndex,
253
- currentIteration,
254
- currentPageWithoutAnyIteration,
255
- };
256
- };
1
+ import { interpret } from '../../../to-expose/interpret';
2
+ import { FLOW_NEXT, FLOW_PREVIOUS } from '../flow';
3
+ import {
4
+ buildVectorialBindings,
5
+ buildLoopBindings,
6
+ } from '../../loops/bindings';
7
+
8
+ export const getPage = ({
9
+ components,
10
+ bindings,
11
+ currentPage,
12
+ featuresWithoutMD,
13
+ depth,
14
+ flow,
15
+ management,
16
+ }) => {
17
+ const { currentRootPage, currentComponentIndex, currentIteration } =
18
+ splitPage(currentPage, depth);
19
+
20
+ const filteredComponents = (
21
+ flow === FLOW_PREVIOUS ? components.slice().reverse() : components
22
+ ).filter(({ page }) => {
23
+ if (flow === FLOW_NEXT && !currentRootPage)
24
+ return parseInt(page, 10) > parseInt(currentPage, 10);
25
+ if (flow === FLOW_NEXT && currentRootPage)
26
+ return parseInt(page, 10) >= parseInt(currentPage, 10);
27
+ if (flow === FLOW_PREVIOUS && !currentRootPage)
28
+ return parseInt(page, 10) < parseInt(currentPage, 10);
29
+ if (flow === FLOW_PREVIOUS && currentRootPage)
30
+ return parseInt(page, 10) <= parseInt(currentPage, 10);
31
+ throw new Error('Unknown type');
32
+ });
33
+ for (let index = 0; index < filteredComponents.length; index++) {
34
+ const component = filteredComponents[index];
35
+ const { id, componentType, page, paginatedLoop } = component;
36
+
37
+ // TODO: Handle loop into loop
38
+ // Easy way: build array with all combinations, but not efficient
39
+ if (componentType === 'Loop' && paginatedLoop) {
40
+ const {
41
+ conditionFilter: { bindingDependencies: loopBD, value: loopV },
42
+ } = component;
43
+ const loopB = (loopBD || []).reduce(
44
+ (acc, b) => ({ ...acc, [b]: bindings[b] }),
45
+ {}
46
+ );
47
+ const loopVectorialB = buildVectorialBindings(loopB);
48
+ if (
49
+ management ||
50
+ interpret(featuresWithoutMD)(loopVectorialB)(loopV) !== true ||
51
+ (flow === FLOW_PREVIOUS &&
52
+ currentIteration === 1 &&
53
+ currentComponentIndex === 1 &&
54
+ page === currentRootPage)
55
+ )
56
+ continue;
57
+ const iterations = getIterations({
58
+ component,
59
+ bindings,
60
+ featuresWithoutMD,
61
+ });
62
+ const { components: loopComponents } = component;
63
+ const startedIteration = getStartedIteration({
64
+ currentIteration,
65
+ currentRootPage,
66
+ page,
67
+ flow,
68
+ iterations,
69
+ });
70
+ const iterationsArray = buildIterationsArray({
71
+ start: flow === FLOW_NEXT ? startedIteration : 0,
72
+ end: flow === FLOW_NEXT ? iterations - 1 : startedIteration,
73
+ flow,
74
+ });
75
+ const componentIndexArray = buildIterationsArray({
76
+ start: 0,
77
+ end: loopComponents.length - 1,
78
+ flow,
79
+ });
80
+ for (const it of iterationsArray.values()) {
81
+ for (const componentIndex of componentIndexArray.values()) {
82
+ const loopComponent = loopComponents[componentIndex];
83
+ if (
84
+ hasToBeExcluded({
85
+ flow,
86
+ currentRootPage,
87
+ page,
88
+ it,
89
+ currentIteration,
90
+ currentComponentIndex,
91
+ loopComponent,
92
+ })
93
+ )
94
+ continue;
95
+ const {
96
+ conditionFilter: { bindingDependencies: bDLoop, value: vLoop },
97
+ } = loopComponent;
98
+ const loopVars = (bDLoop || []).map((b) => {
99
+ if (bindings[b]) return [b, bindings[b]];
100
+ return [b, null];
101
+ });
102
+ const loopBindings = buildLoopBindings(it)(loopVars);
103
+
104
+ // Need vectorial loopBindings instead of loopBindings?
105
+ const res = interpret(featuresWithoutMD)(loopBindings)(vLoop);
106
+ if (management || res === true)
107
+ return `${loopComponent.page}#${it + 1}`;
108
+ }
109
+ }
110
+ } else {
111
+ // Handle Simple Component + Loop on the same page
112
+ const block = filteredComponents.filter(
113
+ (c) => c.page === page && c.componentType === 'Loop'
114
+ );
115
+ if (block.length > 0) {
116
+ const loopIdOfInterest =
117
+ flow === FLOW_NEXT ? block[0].id : block[block.length - 1].id;
118
+ const currentComponentIndexInFiltered = filteredComponents.findIndex(
119
+ (c) => c.id === id
120
+ );
121
+ const loopOfInterestIndex = filteredComponents.findIndex(
122
+ (c) => c.id === loopIdOfInterest
123
+ );
124
+ if (
125
+ (flow === FLOW_NEXT &&
126
+ !(loopOfInterestIndex <= currentComponentIndexInFiltered)) ||
127
+ (flow === FLOW_PREVIOUS &&
128
+ !(loopOfInterestIndex >= currentComponentIndexInFiltered))
129
+ ) {
130
+ continue;
131
+ }
132
+ }
133
+ const {
134
+ conditionFilter: { bindingDependencies, value },
135
+ } = component;
136
+ const filterBindings = (bindingDependencies || []).reduce(
137
+ (acc, b) => ({ ...acc, [b]: bindings[b] }),
138
+ {}
139
+ );
140
+ const vectorialBindings = buildVectorialBindings(filterBindings);
141
+ const res = interpret(featuresWithoutMD)(vectorialBindings)(value);
142
+ if (management || res === true) return page;
143
+ }
144
+ }
145
+ };
146
+
147
+ const getStartedIteration = ({
148
+ currentIteration,
149
+ currentRootPage,
150
+ page,
151
+ flow,
152
+ iterations,
153
+ }) => {
154
+ if (currentIteration && currentRootPage === page) return currentIteration - 1;
155
+ if (flow === FLOW_NEXT) return 0;
156
+ if (flow === FLOW_PREVIOUS) return iterations - 1;
157
+ };
158
+
159
+ const buildIterationsArray = ({ end, start, flow }) => {
160
+ const array = [...Array(end - start + 1)].map((_, i) => i + start);
161
+ return flow === FLOW_PREVIOUS ? array.slice().reverse() : array;
162
+ };
163
+
164
+ const hasToBeExcluded = ({
165
+ flow,
166
+ currentRootPage,
167
+ page,
168
+ it,
169
+ currentIteration,
170
+ currentComponentIndex,
171
+ loopComponent,
172
+ }) => {
173
+ const { page: loopPage, depth } = loopComponent;
174
+ const { currentComponentIndex: loopComponentIndex } = splitPage(
175
+ loopPage,
176
+ depth
177
+ );
178
+ if (flow === FLOW_NEXT)
179
+ return (
180
+ (currentRootPage === page &&
181
+ it === currentIteration - 1 &&
182
+ loopComponentIndex <= currentComponentIndex) ||
183
+ !loopComponent.page
184
+ );
185
+ if (flow === FLOW_PREVIOUS)
186
+ return (
187
+ (currentRootPage === page &&
188
+ it === currentIteration - 1 &&
189
+ loopComponentIndex >= currentComponentIndex) ||
190
+ !loopComponent.page
191
+ );
192
+ return false;
193
+ };
194
+
195
+ const getIterations = ({ component, bindings, featuresWithoutMD }) => {
196
+ const { loopDependencies, iterations: iterationsFormula, lines } = component;
197
+ const iterationsBindings = loopDependencies.reduce(
198
+ (acc, b) => ({ ...acc, [b]: bindings[b] }),
199
+ {}
200
+ );
201
+ const iterationsVectorialBindings =
202
+ buildVectorialBindings(iterationsBindings);
203
+ if (iterationsFormula) {
204
+ return parseInt(
205
+ interpret(featuresWithoutMD)(iterationsVectorialBindings)(
206
+ iterationsFormula
207
+ ),
208
+ 10
209
+ );
210
+ }
211
+ if (lines) {
212
+ const { min, max } = lines;
213
+ const maxRes = parseInt(
214
+ interpret(featuresWithoutMD)(iterationsVectorialBindings)(max),
215
+ 10
216
+ );
217
+ return maxRes || parseInt(min, 10);
218
+ }
219
+ };
220
+
221
+ export const splitPage = (currentPage = '1', depth) => {
222
+ const currentPageWithDepth = depth
223
+ ? currentPage
224
+ ?.split('.')
225
+ .slice(0, depth + 1) // scoped
226
+ .join('.')
227
+ : currentPage;
228
+
229
+ const currentPageWithoutIteration = currentPageWithDepth
230
+ ?.split('#')
231
+ .slice(0, -1)
232
+ .join('#');
233
+
234
+ const currentPageWithoutAnyIteration = currentPageWithDepth
235
+ ?.split('.')
236
+ .map((e) => e.split('#')[0])
237
+ .join('.');
238
+
239
+ const currentRootPage = currentPageWithoutIteration
240
+ ?.split('.')
241
+ .slice(0, -1)
242
+ .join('.');
243
+
244
+ const [currentComponentIndex, currentIteration] = currentPageWithDepth
245
+ ?.split('.')
246
+ .pop()
247
+ .split('#')
248
+ .map((c) => parseInt(c, 10));
249
+
250
+ return {
251
+ currentRootPage,
252
+ currentComponentIndex,
253
+ currentIteration,
254
+ currentPageWithoutAnyIteration,
255
+ };
256
+ };
@@ -1,6 +1,6 @@
1
- import PropTypes from 'prop-types';
2
-
3
- export default PropTypes.shape({
4
- min: PropTypes.oneOfType([PropTypes.string, PropTypes.number]),
5
- max: PropTypes.oneOfType([PropTypes.string, PropTypes.number]),
6
- });
1
+ import PropTypes from 'prop-types';
2
+
3
+ export default PropTypes.shape({
4
+ min: PropTypes.oneOfType([PropTypes.string, PropTypes.number]),
5
+ max: PropTypes.oneOfType([PropTypes.string, PropTypes.number]),
6
+ });
@@ -1,11 +1,11 @@
1
- export const getResponseName = (response) => (response && response.name) || '';
2
-
3
- export const getResponseByPreference =
4
- (preferences = []) =>
5
- (response) => {
6
- if (!(response && response.values)) return null;
7
- return preferences.reduce((acc, p) => {
8
- const value = response.values[p];
9
- return value !== null ? value : acc;
10
- }, null);
11
- };
1
+ export const getResponseName = (response) => (response && response.name) || '';
2
+
3
+ export const getResponseByPreference =
4
+ (preferences = []) =>
5
+ (response) => {
6
+ if (!(response && response.values)) return null;
7
+ return preferences.reduce((acc, p) => {
8
+ const value = response.values[p];
9
+ return value !== null ? value : acc;
10
+ }, null);
11
+ };
@@ -0,0 +1,142 @@
1
+ const getBindingsDependenciesCalculated = (variables) => {
2
+ if (!variables) return {};
3
+ return variables.reduce((acc, { name, bindingDependencies, shapeFrom }) => {
4
+ if (shapeFrom && bindingDependencies)
5
+ return { ...acc, [name]: [...bindingDependencies, shapeFrom] };
6
+ if (bindingDependencies) return { ...acc, [name]: bindingDependencies };
7
+ if (shapeFrom) return { ...acc, [name]: [shapeFrom] };
8
+ return acc;
9
+ }, {});
10
+ };
11
+
12
+ const getAllDeps = (deps) => (variablesCalcDeps) => {
13
+ if (!deps || !variablesCalcDeps) return [];
14
+ return deps.reduce((acc, dep) => {
15
+ const depsOfDep = variablesCalcDeps[dep];
16
+ if (Array.isArray(depsOfDep)) {
17
+ return [...acc, dep, ...getAllDeps(depsOfDep)(variablesCalcDeps)];
18
+ }
19
+ return [...acc, dep];
20
+ }, []);
21
+ };
22
+
23
+ const getNestedVarsInFilterOrControl = (element) => {
24
+ if (element && Array.isArray(element?.bindingDependencies))
25
+ return element?.bindingDependencies;
26
+ return [];
27
+ };
28
+
29
+ const getNestedVarsInComponent = (component) => {
30
+ const {
31
+ componentType,
32
+ bindingDependencies = [],
33
+ conditionFilter,
34
+ controls = [],
35
+ } = component;
36
+ var bindings = [
37
+ ...bindingDependencies, // bindingDependencies of Component
38
+ ...getNestedVarsInFilterOrControl(conditionFilter), // bindingDependencies of its conditionFilter
39
+ ...controls.reduce(
40
+ (acc, c) => [...acc, ...getNestedVarsInFilterOrControl(c)],
41
+ []
42
+ ), // bindingDependencies of its controls
43
+ ];
44
+
45
+ if (componentType === 'Loop') {
46
+ const { components, loopDependencies } = component;
47
+ if (Array.isArray(loopDependencies))
48
+ bindings = [...bindings, ...loopDependencies];
49
+ if (Array.isArray(components)) {
50
+ bindings = components.reduce(
51
+ (acc, c) => [...acc, ...getNestedVarsInComponent(c)],
52
+ [...bindings]
53
+ );
54
+ }
55
+ }
56
+
57
+ return bindings;
58
+ };
59
+
60
+ const getNestedVars =
61
+ (components = []) =>
62
+ (variables) => {
63
+ const variableCalculatedDependencies =
64
+ getBindingsDependenciesCalculated(variables);
65
+ const depsVarsTemp = components
66
+ .reduce((acc, c) => {
67
+ return [...acc, ...getNestedVarsInComponent(c)];
68
+ }, [])
69
+ .filter((v, i, a) => a.indexOf(v) === i);
70
+ return getAllDeps(depsVarsTemp)(variableCalculatedDependencies).filter(
71
+ (v, i, a) => a.indexOf(v) === i
72
+ );
73
+ };
74
+
75
+ const getUsefullVariablesFromSource = (variables) => (nestedVars) => {
76
+ return variables.filter(({ variableType, name }) => {
77
+ if (variableType === 'CALCULATED' && !nestedVars.includes(name))
78
+ return false;
79
+ if (variableType === 'COLLECTED' && !nestedVars.includes(name))
80
+ return false;
81
+ return true;
82
+ });
83
+ };
84
+
85
+ export const getSplitQuestionnaireSource = (source) => {
86
+ const { components, variables, ...rest } = source;
87
+ var split = [];
88
+ var currentComponents = [];
89
+ var previousPage = null;
90
+ components.map((c) => {
91
+ const { componentType, page } = c;
92
+ // splitting by Sequence or Loop
93
+ if (
94
+ (componentType === 'Sequence' || componentType === 'Loop') &&
95
+ previousPage !== page
96
+ ) {
97
+ if (currentComponents.length > 0) split.push(currentComponents);
98
+ currentComponents = [c];
99
+ } else {
100
+ currentComponents.push(c);
101
+ }
102
+ previousPage = page;
103
+ return null;
104
+ });
105
+ if (currentComponents.length > 0) split.push(currentComponents);
106
+
107
+ return split.reduce((prev, currentSource) => {
108
+ const firstPage = currentSource[0].page;
109
+ const maxPage = currentSource[currentSource.length - 1].page;
110
+ const nestedVars = getNestedVars(currentSource)(variables);
111
+ const newVariables = getUsefullVariablesFromSource(variables)(nestedVars);
112
+
113
+ return [
114
+ ...prev,
115
+ {
116
+ ...rest,
117
+ variables: newVariables,
118
+ firstPage,
119
+ maxPage,
120
+ components: currentSource,
121
+ },
122
+ ];
123
+ }, []);
124
+ };
125
+
126
+ export const getRootPageInSources = (sources) => {
127
+ return sources.map((source) => {
128
+ const { components } = source;
129
+ return components.reduce((acc, { page }) => {
130
+ if (page) return [...acc, page];
131
+ return acc;
132
+ }, []);
133
+ });
134
+ };
135
+
136
+ export const mergeStateData = (oldData, newData) => {
137
+ return {
138
+ COLLECTED: { ...oldData.COLLECTED, ...newData.COLLECTED },
139
+ CALCULATED: { ...oldData.CALCULATED, ...newData.CALCULATED },
140
+ EXTERNAL: { ...oldData.EXTERNAL, ...newData.EXTERNAL },
141
+ };
142
+ };