@inseefr/lunatic 0.2.3-experimental → 0.2.3-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 (230) hide show
  1. package/LICENSE +21 -21
  2. package/README.md +25 -23
  3. package/lib/index.js +1191 -475
  4. package/lib/index.js.map +1 -1
  5. package/package.json +174 -172
  6. package/src/components/breadcrumb/breadcrumb.scss +22 -22
  7. package/src/components/checkbox/boolean.js +172 -172
  8. package/src/components/checkbox/checkbox.scss +73 -73
  9. package/src/components/checkbox/group.js +231 -231
  10. package/src/components/checkbox/one.js +11 -11
  11. package/src/components/component-wrapper/controls/component.js +70 -0
  12. package/src/components/component-wrapper/controls/controls.scss +6 -0
  13. package/src/components/component-wrapper/controls/index.js +1 -0
  14. package/src/components/component-wrapper/controls/validators/datepicker.js +44 -0
  15. package/src/components/component-wrapper/controls/validators/index.js +16 -0
  16. package/src/components/component-wrapper/controls/validators/input-number.js +23 -0
  17. package/src/components/{missing-wrapper → component-wrapper}/index.js +0 -0
  18. package/src/components/component-wrapper/missing/component.js +200 -0
  19. package/src/components/component-wrapper/missing/index.js +1 -0
  20. package/src/components/{missing-wrapper → component-wrapper/missing}/missing.scss +32 -32
  21. package/src/components/component-wrapper/wrapper.js +23 -0
  22. package/src/components/components.js +1 -0
  23. package/src/components/datepicker/component.js +26 -11
  24. package/src/components/declarations/component.js +46 -46
  25. package/src/components/declarations/declarations.scss +40 -40
  26. package/src/components/declarations/wrappers/input-declarations-wrapper.js +328 -274
  27. package/src/components/declarations/wrappers/simple-declarations-wrapper.js +54 -54
  28. package/src/components/dropdown/commons/actions.js +65 -56
  29. package/src/components/dropdown/commons/children-to-option.js +9 -9
  30. package/src/components/dropdown/commons/cleaner-callbacks.js +58 -58
  31. package/src/components/dropdown/commons/components/dropdown-container.js +29 -29
  32. package/src/components/dropdown/commons/components/dropdown.js +204 -183
  33. package/src/components/dropdown/commons/event-callbacks/on-mousedown-callback.js +15 -15
  34. package/src/components/dropdown/commons/reducer.js +3 -0
  35. package/src/components/dropdown/commons/tools/index.js +17 -17
  36. package/src/components/dropdown/component.js +135 -135
  37. package/src/components/dropdown/dropdown-edit/dropdown-edit.js +194 -185
  38. package/src/components/dropdown/dropdown-edit/index.js +11 -11
  39. package/src/components/dropdown/dropdown-simple/dropdown.js +173 -164
  40. package/src/components/dropdown/dropdown-simple/index.js +20 -20
  41. package/src/components/dropdown/dropdown.scss +178 -178
  42. package/src/components/icon/icon.scss +15 -15
  43. package/src/components/index.js +2 -0
  44. package/src/components/index.scss +177 -175
  45. package/src/components/input/input-number.js +30 -54
  46. package/src/components/input/input.js +11 -11
  47. package/src/components/input/input.scss +31 -37
  48. package/src/components/loop/component.js +170 -169
  49. package/src/components/loop/loop.scss +13 -13
  50. package/src/components/loop/wrapper.js +1 -1
  51. package/src/components/loop-constructor/block/block.scss +10 -10
  52. package/src/components/loop-constructor/block/component.js +9 -9
  53. package/src/components/loop-constructor/roster/component.js +8 -8
  54. package/src/components/loop-constructor/wrapper/body-component.js +146 -125
  55. package/src/components/loop-constructor/wrapper/component.js +190 -190
  56. package/src/components/modal/component.js +36 -0
  57. package/src/components/modal/index.js +1 -0
  58. package/src/components/modal/modal.scss +33 -0
  59. package/src/components/progress-bar/progress-bar.scss +54 -54
  60. package/src/components/radio/component.js +9 -9
  61. package/src/components/radio/radio.scss +59 -59
  62. package/src/components/sequence/component.js +50 -50
  63. package/src/components/sequence/sequence.scss +10 -10
  64. package/src/components/subsequence/component.js +49 -49
  65. package/src/components/suggester/check-store.js +2 -4
  66. package/src/components/suggester/components/panel/default-option-renderer.js +27 -27
  67. package/src/components/suggester/components/panel/option-container.js +61 -61
  68. package/src/components/suggester/components/panel/panel.js +47 -47
  69. package/src/components/suggester/components/selection/default-label-renderer.js +31 -31
  70. package/src/components/suggester/components/selection/label.js +35 -35
  71. package/src/components/suggester/components/selection/selection.js +50 -50
  72. package/src/components/suggester/components/suggester-content.js +2 -2
  73. package/src/components/suggester/components/suggester.js +128 -88
  74. package/src/components/suggester/components/suggester.scss +101 -101
  75. package/src/components/suggester/default-style.scss +125 -125
  76. package/src/components/suggester/find-best-label/find-best-label.js +51 -49
  77. package/src/components/suggester/find-best-label/index.js +1 -1
  78. package/src/components/suggester/idb-suggester.js +73 -67
  79. package/src/components/suggester/lunatic-suggester.js +140 -137
  80. package/src/components/suggester/searching/create-searching.js +49 -47
  81. package/src/components/suggester/searching/index.js +1 -1
  82. package/src/components/suggester/state-management/actions.js +38 -38
  83. package/src/components/suggester/state-management/reducer/reduce-on-delete-search.js +11 -11
  84. package/src/components/suggester/state-management/reducer/reduce-on-init.js +29 -29
  85. package/src/components/suggester/state-management/reducer/reducer.js +38 -38
  86. package/src/components/suggester/suggester-wrapper.js +127 -121
  87. package/src/components/suggester-loader-widget/loader.js +67 -67
  88. package/src/components/suggester-loader-widget/widget.js +123 -123
  89. package/src/components/table/table.js +173 -171
  90. package/src/components/table/table.scss +26 -26
  91. package/src/components/textarea/component.js +11 -11
  92. package/src/components/textarea/textarea.scss +8 -8
  93. package/src/components/tooltip/tooltip.scss +30 -30
  94. package/src/stories/breadcrumb/breadcrumb.stories.js +21 -21
  95. package/src/stories/checkbox-boolean/data.json +78 -78
  96. package/src/stories/datepicker/data.json +3 -1
  97. package/src/stories/declarations/declarations.stories.js +116 -116
  98. package/src/stories/dropdown/README.md +44 -44
  99. package/src/stories/dropdown/data.json +98 -98
  100. package/src/stories/dropdown/dropdown.stories.js +89 -89
  101. package/src/stories/progress-bar/progress-bar.stories.js +24 -24
  102. package/src/stories/questionnaire/arithmetic-management.json +47 -0
  103. package/src/stories/questionnaire/arithmetic.json +247 -247
  104. package/src/stories/questionnaire/calc-var.json +187 -187
  105. package/src/stories/questionnaire/data-logement.json +2691 -2691
  106. package/src/stories/questionnaire/kish.json +275 -0
  107. package/src/stories/questionnaire/logement-queen.json +23390 -0
  108. package/src/stories/questionnaire/logement-s2.json +46028 -44537
  109. package/src/stories/questionnaire/logement-sequence.json +26741 -26741
  110. package/src/stories/questionnaire/logement.json +21073 -26813
  111. package/src/stories/questionnaire/loop-and-controls.json +481 -0
  112. package/src/stories/questionnaire/questionnaire.stories.js +236 -154
  113. package/src/stories/questionnaire/update-external/data.json +1 -0
  114. package/src/stories/questionnaire/update-external/questionnaire.json +75 -0
  115. package/src/stories/sequence/sequence.stories.js +32 -32
  116. package/src/stories/subsequence/subsequence.stories.js +32 -32
  117. package/src/stories/suggester/README.md +46 -46
  118. package/src/stories/suggester/bailleurs-sociaux/fetch-bailleurs.js +15 -15
  119. package/src/stories/suggester/bailleurs-sociaux/index.js +2 -2
  120. package/src/stories/suggester/bailleurs-sociaux/option-bailleur-renderer.js +58 -58
  121. package/src/stories/suggester/bailleurs-sociaux/preloader.svg +51 -51
  122. package/src/stories/suggester/bailleurs-sociaux/theme.scss +22 -22
  123. package/src/stories/suggester/bailleurs-sociaux-2021/fetch-bailleurs.js +12 -0
  124. package/src/stories/suggester/bailleurs-sociaux-2021/index.js +1 -0
  125. package/src/stories/suggester/cog-communes/fetch-cog.js +15 -15
  126. package/src/stories/suggester/data-auto.json +232 -231
  127. package/src/stories/suggester/data-vtl.json +82 -82
  128. package/src/stories/suggester/data.json +169 -136
  129. package/src/stories/suggester/naf-rev2/index.js +2 -2
  130. package/src/stories/suggester/naf-rev2/option-naf-renderer.js +17 -17
  131. package/src/stories/suggester/suggester-workers.stories.js +226 -179
  132. package/src/stories/suggester/suggester.stories.js +138 -133
  133. package/src/stories/utils/orchestrator-split.js +119 -0
  134. package/src/stories/utils/orchestrator.js +119 -108
  135. package/src/tests/components/input-number.spec.js +6 -12
  136. package/src/tests/components/loops/roster-loop.json +71 -71
  137. package/src/tests/components/missing-wrapper.spec.js +0 -1
  138. package/src/tests/utils/lib/table/roster.spec.js +25 -25
  139. package/src/tests/utils/to-expose/handler/results/res-input-edited.json +1 -1
  140. package/src/tests/utils/to-expose/init-questionnaire/questionnaire.json +148 -148
  141. package/src/tests/utils/to-expose/init-questionnaire/result.json +181 -181
  142. package/src/utils/components/dragger/dragger.scss +7 -7
  143. package/src/utils/idb-tools/create-db-opener.js +43 -43
  144. package/src/utils/idb-tools/create-open-db.js +25 -25
  145. package/src/utils/idb-tools/idb-bulk-insert.js +96 -96
  146. package/src/utils/idb-tools/index.js +10 -10
  147. package/src/utils/idb-tools/insert-entity.js +15 -15
  148. package/src/utils/idb-tools/open-db.js +13 -13
  149. package/src/utils/idb-tools/open-or-create-db.js +34 -34
  150. package/src/utils/lib/controls/index.js +1 -0
  151. package/src/utils/lib/controls/utils.js +152 -0
  152. package/src/utils/lib/decorator/title-decorator.js +16 -16
  153. package/src/utils/lib/env.js +2 -2
  154. package/src/utils/lib/index.js +2 -0
  155. package/src/utils/lib/input-number.js +1 -1
  156. package/src/utils/lib/options-positioning.js +9 -9
  157. package/src/utils/lib/pagination/navigation/shared.js +256 -253
  158. package/src/utils/lib/prop-types/lines.js +6 -6
  159. package/src/utils/lib/responses.js +11 -9
  160. package/src/utils/lib/splitting.js +142 -0
  161. package/src/utils/lib/style.js +10 -10
  162. package/src/utils/store-tools/auto-load.js +74 -73
  163. package/src/utils/suggester-workers/append-to-index/append.js +25 -25
  164. package/src/utils/suggester-workers/append-to-index/append.worker.js +16 -16
  165. package/src/utils/suggester-workers/append-to-index/create-append-task.js +45 -43
  166. package/src/utils/suggester-workers/append-to-index/index.js +2 -2
  167. package/src/utils/suggester-workers/append-to-index/prepare-entities.js +61 -61
  168. package/src/utils/suggester-workers/append-to-index/store-messages.js +21 -21
  169. package/src/utils/suggester-workers/commons-tokenizer/create-entity-tokenizer.js +56 -0
  170. package/src/utils/suggester-workers/commons-tokenizer/create-fields-tokenizer.js +56 -0
  171. package/src/utils/suggester-workers/commons-tokenizer/create-filter-stop-words.js +17 -17
  172. package/src/utils/suggester-workers/commons-tokenizer/filters/compose-filters.js +10 -0
  173. package/src/utils/suggester-workers/commons-tokenizer/filters/create-filter-stop-words.js +17 -0
  174. package/src/utils/suggester-workers/commons-tokenizer/filters/create-filter-stop-words.spec.js +14 -0
  175. package/src/utils/suggester-workers/commons-tokenizer/filters/filter-accents.js +12 -0
  176. package/src/utils/suggester-workers/commons-tokenizer/filters/filter-accents.spec.js +12 -0
  177. package/src/utils/suggester-workers/commons-tokenizer/{filter-double.js → filters/filter-double.js} +12 -12
  178. package/src/utils/suggester-workers/commons-tokenizer/filters/filter-double.spec.js +20 -0
  179. package/src/utils/suggester-workers/commons-tokenizer/{filter-length.js → filters/filter-length.js} +7 -7
  180. package/src/utils/suggester-workers/commons-tokenizer/filters/filter-length.spec.js +18 -0
  181. package/src/utils/suggester-workers/commons-tokenizer/{filter-stemmer.js → filters/filter-stemmer.js} +13 -13
  182. package/src/utils/suggester-workers/commons-tokenizer/filters/filter-stemmer.spec.js +12 -0
  183. package/src/utils/suggester-workers/commons-tokenizer/filters/filter-synonyms.js +36 -0
  184. package/src/utils/suggester-workers/commons-tokenizer/filters/filter-synonyms.spec.js +12 -0
  185. package/src/utils/suggester-workers/commons-tokenizer/filters/filter-to-lower.js +10 -0
  186. package/src/utils/suggester-workers/commons-tokenizer/filters/filter-to-lower.spec.js +12 -0
  187. package/src/utils/suggester-workers/commons-tokenizer/filters/index.js +2 -0
  188. package/src/utils/suggester-workers/commons-tokenizer/{stop-words.js → filters/stop-words.js} +118 -118
  189. package/src/utils/suggester-workers/commons-tokenizer/get-regexp-from-pattern.js +8 -8
  190. package/src/utils/suggester-workers/commons-tokenizer/get-stemmer.js +18 -18
  191. package/src/utils/suggester-workers/commons-tokenizer/index.js +9 -8
  192. package/src/utils/suggester-workers/commons-tokenizer/prepare-string-indexation.js +13 -9
  193. package/src/utils/suggester-workers/commons-tokenizer/soft-tokenizer.js +7 -7
  194. package/src/utils/suggester-workers/create-worker.js +56 -0
  195. package/src/utils/suggester-workers/find-best-label/find-best-label.js +39 -39
  196. package/src/utils/suggester-workers/find-best-label/find-best-label.worker.js +40 -40
  197. package/src/utils/suggester-workers/find-best-label/tokenize.js +30 -33
  198. package/src/utils/suggester-workers/find-best-label/tokenize.spec.js +19 -19
  199. package/src/utils/suggester-workers/searching/compute-score.js +33 -33
  200. package/src/utils/suggester-workers/searching/get-db.js +18 -18
  201. package/src/utils/suggester-workers/searching/index.js +1 -1
  202. package/src/utils/suggester-workers/searching/order/create-alphanumeric-orderer.js +20 -20
  203. package/src/utils/suggester-workers/searching/order/index.js +19 -19
  204. package/src/utils/suggester-workers/{query-parser → searching/query-parser}/index.js +2 -2
  205. package/src/utils/suggester-workers/searching/query-parser/query-parser-soft.js +7 -0
  206. package/src/utils/suggester-workers/{query-parser → searching/query-parser}/query-parser-soft.spec.js +24 -24
  207. package/src/utils/suggester-workers/searching/query-parser/query-parser-tokenized.js +34 -0
  208. package/src/utils/suggester-workers/searching/resolve-query-parser.js +27 -27
  209. package/src/utils/suggester-workers/searching/search-in-index.js +17 -17
  210. package/src/utils/suggester-workers/searching/searching.js +70 -70
  211. package/src/utils/suggester-workers/searching/searching.worker.js +11 -11
  212. package/src/utils/to-expose/calculated-variables.js +113 -113
  213. package/src/utils/to-expose/handler.js +149 -112
  214. package/src/utils/to-expose/hooks/filter-components.js +27 -12
  215. package/src/utils/to-expose/hooks/index.js +2 -1
  216. package/src/utils/to-expose/hooks/lunatic-split.js +428 -0
  217. package/src/utils/to-expose/hooks/lunatic.js +284 -188
  218. package/src/utils/to-expose/index.js +1 -1
  219. package/src/utils/to-expose/init-questionnaire.js +164 -164
  220. package/src/utils/to-expose/interpret/vtl.js +18 -18
  221. package/src/utils/to-expose/state.js +66 -58
  222. package/src/components/missing-wrapper/component.js +0 -120
  223. package/src/components/missing-wrapper/wrapper.js +0 -10
  224. package/src/tests/utils/to-expose/hooks/use-lunatic.spec.js +0 -46
  225. package/src/utils/suggester-workers/commons-tokenizer/create-tokenizer.js +0 -103
  226. package/src/utils/suggester-workers/commons-tokenizer/filter-accents-to-lower.js +0 -9
  227. package/src/utils/suggester-workers/commons-tokenizer/filter-synonyms.js +0 -10
  228. package/src/utils/suggester-workers/query-parser/query-parser-soft.js +0 -7
  229. package/src/utils/suggester-workers/query-parser/query-parser-tokenized.js +0 -31
  230. package/src/utils/suggester-workers/query-parser/query-parser-tokenized.spec.js +0 -32
@@ -1,253 +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
- )
55
- continue;
56
- const iterations = getIterations({
57
- component,
58
- bindings,
59
- featuresWithoutMD,
60
- });
61
- const { components: loopComponents } = component;
62
- const startedIteration = getStartedIteration({
63
- currentIteration,
64
- currentRootPage,
65
- page,
66
- flow,
67
- iterations,
68
- });
69
- const iterationsArray = buildIterationsArray({
70
- start: flow === FLOW_NEXT ? startedIteration : 0,
71
- end: flow === FLOW_NEXT ? iterations - 1 : startedIteration,
72
- flow,
73
- });
74
- const componentIndexArray = buildIterationsArray({
75
- start: 0,
76
- end: loopComponents.length - 1,
77
- flow,
78
- });
79
- for (const it of iterationsArray.values()) {
80
- for (const componentIndex of componentIndexArray.values()) {
81
- const loopComponent = loopComponents[componentIndex];
82
- if (
83
- hasToBeExcluded({
84
- flow,
85
- currentRootPage,
86
- page,
87
- it,
88
- currentIteration,
89
- loopComponentIndex: componentIndex,
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
-
116
- if (block.length > 0) {
117
- const loopIdOfInterest =
118
- flow === FLOW_NEXT ? block[0].id : block[block.length - 1].id;
119
- const currentComponentIndexInFiltered = filteredComponents.findIndex(
120
- (c) => c.id === id
121
- );
122
- const loopOfInterestIndex = filteredComponents.findIndex(
123
- (c) => c.id === loopIdOfInterest
124
- );
125
- if (
126
- (flow === FLOW_NEXT &&
127
- !(loopOfInterestIndex <= currentComponentIndexInFiltered)) ||
128
- (flow === FLOW_PREVIOUS &&
129
- !(loopOfInterestIndex >= currentComponentIndexInFiltered))
130
- ) {
131
- continue;
132
- }
133
- }
134
- const {
135
- conditionFilter: { bindingDependencies, value },
136
- } = component;
137
- const filterBindings = (bindingDependencies || []).reduce(
138
- (acc, b) => ({ ...acc, [b]: bindings[b] }),
139
- {}
140
- );
141
- const vectorialBindings = buildVectorialBindings(filterBindings);
142
- const res = interpret(featuresWithoutMD)(vectorialBindings)(value);
143
- if (management || res === true) return page;
144
- }
145
- }
146
- };
147
-
148
- const getStartedIteration = ({
149
- currentIteration,
150
- currentRootPage,
151
- page,
152
- flow,
153
- iterations,
154
- }) => {
155
- if (currentIteration && currentRootPage === page) return currentIteration - 1;
156
- if (flow === FLOW_NEXT) return 0;
157
- if (flow === FLOW_PREVIOUS) return iterations - 1;
158
- };
159
-
160
- const buildIterationsArray = ({ end, start, flow }) => {
161
- const array = [...Array(end - start + 1)].map((_, i) => i + start);
162
- return flow === FLOW_PREVIOUS ? array.slice().reverse() : array;
163
- };
164
-
165
- const hasToBeExcluded = ({
166
- flow,
167
- currentRootPage,
168
- page,
169
- it,
170
- currentIteration,
171
- loopComponentIndex,
172
- currentComponentIndex,
173
- loopComponent,
174
- }) => {
175
- if (flow === FLOW_NEXT)
176
- return (
177
- (currentRootPage === page &&
178
- it === currentIteration - 1 &&
179
- loopComponentIndex <= currentComponentIndex) ||
180
- !loopComponent.page
181
- );
182
- if (flow === FLOW_PREVIOUS)
183
- return (
184
- (currentRootPage === page &&
185
- it === currentIteration - 1 &&
186
- loopComponentIndex >= currentComponentIndex) ||
187
- !loopComponent.page
188
- );
189
- return false;
190
- };
191
-
192
- const getIterations = ({ component, bindings, featuresWithoutMD }) => {
193
- const { loopDependencies, iterations: iterationsFormula, lines } = component;
194
- const iterationsBindings = loopDependencies.reduce(
195
- (acc, b) => ({ ...acc, [b]: bindings[b] }),
196
- {}
197
- );
198
- const iterationsVectorialBindings =
199
- buildVectorialBindings(iterationsBindings);
200
- if (iterationsFormula) {
201
- return parseInt(
202
- interpret(featuresWithoutMD)(iterationsVectorialBindings)(
203
- iterationsFormula
204
- ),
205
- 10
206
- );
207
- }
208
- if (lines) {
209
- const { min, max } = lines;
210
- const maxRes = parseInt(
211
- interpret(featuresWithoutMD)(iterationsVectorialBindings)(max),
212
- 10
213
- );
214
- return maxRes || parseInt(min, 10);
215
- }
216
- };
217
-
218
- export const splitPage = (currentPage = '1', depth) => {
219
- const currentPageWithDepth = depth
220
- ? currentPage
221
- .split('.')
222
- .slice(0, depth + 1) // scoped
223
- .join('.')
224
- : currentPage;
225
-
226
- const currentPageWithoutIteration = currentPageWithDepth
227
- .split('#')
228
- .slice(0, -1)
229
- .join('#');
230
-
231
- const currentPageWithoutAnyIteration = currentPageWithDepth
232
- .split('.')
233
- .map((e) => e.split('#')[0])
234
- .join('.');
235
-
236
- const currentRootPage = currentPageWithoutIteration
237
- .split('.')
238
- .slice(0, -1)
239
- .join('.');
240
-
241
- const [currentComponentIndex, currentIteration] = currentPageWithDepth
242
- .split('.')
243
- .pop()
244
- .split('#')
245
- .map((c) => parseInt(c, 10));
246
-
247
- return {
248
- currentRootPage,
249
- currentComponentIndex,
250
- currentIteration,
251
- currentPageWithoutAnyIteration,
252
- };
253
- };
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,9 +1,11 @@
1
- export const getResponseName = (response) => (response && response.name) || '';
2
-
3
- export const getResponseByPreference = (preferences) => (response) => {
4
- if (!(response && response.values)) return null;
5
- return preferences.reduce((acc, p) => {
6
- const value = response.values[p];
7
- return value !== null ? value : acc;
8
- }, null);
9
- };
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
+ };