@inseefr/lunatic 0.1.0-hackathon → 0.1.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 (421) hide show
  1. package/README.md +2 -0
  2. package/lib/index.js +1184 -468
  3. package/lib/index.js.map +1 -1
  4. package/package.json +6 -4
  5. package/src/components/breadcrumb/component.js +29 -29
  6. package/src/components/breadcrumb/index.js +1 -1
  7. package/src/components/button/button.scss +24 -24
  8. package/src/components/button/component.js +53 -53
  9. package/src/components/button/index.js +1 -1
  10. package/src/components/checkbox/boolean.js +2 -2
  11. package/src/components/checkbox/group.js +2 -2
  12. package/src/components/checkbox/index.js +3 -3
  13. package/src/components/checkbox/one.js +2 -2
  14. package/src/components/component-wrapper/controls/component.js +70 -0
  15. package/src/components/component-wrapper/controls/controls.scss +6 -0
  16. package/src/components/component-wrapper/controls/index.js +1 -0
  17. package/src/components/component-wrapper/controls/validators/datepicker.js +44 -0
  18. package/src/components/component-wrapper/controls/validators/index.js +16 -0
  19. package/src/components/component-wrapper/controls/validators/input-number.js +23 -0
  20. package/src/components/{missing-wrapper → component-wrapper}/index.js +1 -1
  21. package/src/components/component-wrapper/missing/component.js +200 -0
  22. package/src/components/component-wrapper/missing/index.js +1 -0
  23. package/src/components/{missing-wrapper → component-wrapper/missing}/missing.scss +0 -0
  24. package/src/components/component-wrapper/wrapper.js +23 -0
  25. package/src/components/components.js +19 -18
  26. package/src/components/datepicker/component.js +18 -3
  27. package/src/components/datepicker/datepicker.scss +1 -1
  28. package/src/components/datepicker/index.js +1 -1
  29. package/src/components/declarations/index.js +1 -1
  30. package/src/components/declarations/wrappers/index.js +3 -3
  31. package/src/components/declarations/wrappers/input-declarations-wrapper.js +65 -16
  32. package/src/components/declarations/wrappers/list-declarations-wrapper.js +232 -232
  33. package/src/components/dropdown/commons/actions.js +40 -31
  34. package/src/components/dropdown/commons/components/dropdown-field.js +46 -46
  35. package/src/components/dropdown/commons/components/dropdown.js +21 -0
  36. package/src/components/dropdown/commons/components/label.js +28 -28
  37. package/src/components/dropdown/commons/components/panel.js +78 -78
  38. package/src/components/dropdown/commons/event-callbacks/index.js +5 -5
  39. package/src/components/dropdown/commons/event-callbacks/on-keydown-callback.js +29 -29
  40. package/src/components/dropdown/commons/reducer.js +152 -149
  41. package/src/components/dropdown/component.js +2 -2
  42. package/src/components/dropdown/dropdown-edit/dropdown-edit.js +10 -1
  43. package/src/components/dropdown/dropdown-edit/icone.js +33 -33
  44. package/src/components/dropdown/dropdown-edit/option.js +62 -62
  45. package/src/components/dropdown/dropdown-edit/prefix-tools.js +51 -51
  46. package/src/components/dropdown/dropdown-simple/dropdown.js +11 -2
  47. package/src/components/dropdown/dropdown-simple/option.js +15 -15
  48. package/src/components/dropdown/index.js +1 -1
  49. package/src/components/filter-description/component.js +42 -42
  50. package/src/components/filter-description/index.js +1 -1
  51. package/src/components/icon/assets/checkbox-checked.js +16 -16
  52. package/src/components/icon/assets/checkbox-unchecked.js +16 -16
  53. package/src/components/icon/assets/index.js +4 -4
  54. package/src/components/icon/assets/radio-checked.js +16 -16
  55. package/src/components/icon/assets/radio-unchecked.js +16 -16
  56. package/src/components/icon/component.js +33 -33
  57. package/src/components/icon/index.js +1 -1
  58. package/src/components/index.js +5 -3
  59. package/src/components/index.scss +5 -3
  60. package/src/components/input/index.js +2 -2
  61. package/src/components/input/input-number.js +14 -39
  62. package/src/components/input/input.js +2 -2
  63. package/src/components/input/input.scss +0 -6
  64. package/src/components/loop/component.js +1 -0
  65. package/src/components/loop/index.js +1 -1
  66. package/src/components/loop/wrapper.js +15 -15
  67. package/src/components/loop-constructor/block/component.js +2 -2
  68. package/src/components/loop-constructor/block/index.js +1 -1
  69. package/src/components/loop-constructor/index.js +1 -1
  70. package/src/components/loop-constructor/roster/component.js +2 -2
  71. package/src/components/loop-constructor/roster/index.js +1 -1
  72. package/src/components/loop-constructor/wrapper/body-component.js +21 -0
  73. package/src/components/loop-constructor/wrapper/build-components.js +33 -33
  74. package/src/components/loop-constructor/wrapper/index.js +1 -1
  75. package/src/components/modal/component.js +36 -0
  76. package/src/components/modal/index.js +1 -0
  77. package/src/components/modal/modal.scss +33 -0
  78. package/src/components/progress-bar/component.js +28 -28
  79. package/src/components/progress-bar/index.js +1 -1
  80. package/src/components/radio/component.js +2 -2
  81. package/src/components/radio/index.js +1 -1
  82. package/src/components/sequence/index.js +1 -1
  83. package/src/components/subsequence/index.js +1 -1
  84. package/src/components/suggester/check-store.js +68 -70
  85. package/src/components/suggester/commons-tools/binded-keys.js +11 -11
  86. package/src/components/suggester/commons-tools/index.js +1 -1
  87. package/src/components/suggester/components/create-on-keydown-callback.js +28 -28
  88. package/src/components/suggester/components/index.js +2 -2
  89. package/src/components/suggester/components/panel/index.js +2 -2
  90. package/src/components/suggester/components/panel/option-container.js +1 -1
  91. package/src/components/suggester/components/panel/panel-container.js +21 -21
  92. package/src/components/suggester/components/selection/delete.js +38 -38
  93. package/src/components/suggester/components/selection/index.js +1 -1
  94. package/src/components/suggester/components/selection/selection.js +1 -1
  95. package/src/components/suggester/components/suggester-content.js +42 -42
  96. package/src/components/suggester/components/suggester.js +43 -3
  97. package/src/components/suggester/find-best-label/find-best-label.js +3 -1
  98. package/src/components/suggester/idb-suggester.js +7 -1
  99. package/src/components/suggester/index.js +1 -1
  100. package/src/components/suggester/lunatic-suggester.js +6 -3
  101. package/src/components/suggester/searching/create-searching.js +3 -1
  102. package/src/components/suggester/state-management/index.js +6 -6
  103. package/src/components/suggester/state-management/intial-state.js +13 -13
  104. package/src/components/suggester/state-management/reducer/index.js +1 -1
  105. package/src/components/suggester/state-management/reducer/reduce-on-blur.js +5 -5
  106. package/src/components/suggester/state-management/reducer/reduce-on-change-search.js +8 -8
  107. package/src/components/suggester/state-management/reducer/reduce-on-click-option.js +8 -8
  108. package/src/components/suggester/state-management/reducer/reduce-on-error.js +8 -8
  109. package/src/components/suggester/state-management/reducer/reduce-on-focus.js +5 -5
  110. package/src/components/suggester/state-management/reducer/reduce-on-key-down.js +73 -73
  111. package/src/components/suggester/state-management/reducer/reduce-on-unexpected-error.js +7 -7
  112. package/src/components/suggester/state-management/reducer/reduce-on-update-options.js +11 -11
  113. package/src/components/suggester/state-management/suggester-context.js +4 -4
  114. package/src/components/suggester/state-management/use-dispatch.js +11 -11
  115. package/src/components/suggester/suggester-wrapper.js +9 -3
  116. package/src/components/suggester-loader-widget/index.js +1 -1
  117. package/src/components/suggester-loader-widget/loader-row.js +102 -102
  118. package/src/components/suggester-loader-widget/progress.js +25 -25
  119. package/src/components/suggester-loader-widget/tools/action-tool.js +20 -20
  120. package/src/components/suggester-loader-widget/tools/index.js +2 -2
  121. package/src/components/suggester-loader-widget/tools/tools.js +7 -7
  122. package/src/components/suggester-loader-widget/widget-container.js +35 -35
  123. package/src/components/suggester-loader-widget/widget.scss +176 -176
  124. package/src/components/table/index.js +1 -1
  125. package/src/components/table/table.js +5 -3
  126. package/src/components/textarea/component.js +2 -2
  127. package/src/components/textarea/index.js +1 -1
  128. package/src/components/tooltip/img/index.js +4 -4
  129. package/src/components/tooltip/index.js +1 -1
  130. package/src/components/tooltip/response.js +52 -52
  131. package/src/constants/component-types.js +1 -1
  132. package/src/constants/declarations.js +14 -14
  133. package/src/constants/event-types.js +13 -13
  134. package/src/constants/index.js +5 -5
  135. package/src/constants/supported-preferences.js +10 -10
  136. package/src/constants/value-types.js +5 -5
  137. package/src/constants/variable-types.js +4 -4
  138. package/src/stories/breadcrumb/README.md +14 -14
  139. package/src/stories/button/README.md +14 -14
  140. package/src/stories/button/button.stories.js +27 -27
  141. package/src/stories/checkbox-boolean/README.md +27 -27
  142. package/src/stories/checkbox-boolean/checkbox-boolean.stories.js +54 -54
  143. package/src/stories/checkbox-boolean/data-forced.json +48 -48
  144. package/src/stories/checkbox-group/README.md +29 -29
  145. package/src/stories/checkbox-group/checkbox-group.stories.js +60 -60
  146. package/src/stories/checkbox-group/data-forced.json +89 -89
  147. package/src/stories/checkbox-group/data-vtl.json +102 -102
  148. package/src/stories/checkbox-group/data.json +89 -89
  149. package/src/stories/checkbox-one/README.md +31 -31
  150. package/src/stories/checkbox-one/checkbox-one.stories.js +57 -57
  151. package/src/stories/checkbox-one/data-forced.json +33 -33
  152. package/src/stories/checkbox-one/data-vtl.json +48 -48
  153. package/src/stories/checkbox-one/data.json +33 -33
  154. package/src/stories/datepicker/README.md +31 -31
  155. package/src/stories/datepicker/data-forced.json +28 -28
  156. package/src/stories/datepicker/data.json +45 -43
  157. package/src/stories/datepicker/datepicker.stories.js +60 -60
  158. package/src/stories/declarations/README.md +19 -19
  159. package/src/stories/dropdown/data-forced.json +81 -81
  160. package/src/stories/dropdown/data-naf.json +6963 -6963
  161. package/src/stories/dropdown/data-props.json +111 -111
  162. package/src/stories/filter-description/README.md +15 -15
  163. package/src/stories/filter-description/filter-description.stories.js +53 -53
  164. package/src/stories/icons/icons.stories.js +16 -16
  165. package/src/stories/icons/lunatic-icon.scss +10 -10
  166. package/src/stories/input/README.md +33 -33
  167. package/src/stories/input/data-forced.json +41 -41
  168. package/src/stories/input/data.json +41 -41
  169. package/src/stories/input/input.stories.js +72 -72
  170. package/src/stories/input-number/README.md +37 -37
  171. package/src/stories/input-number/data-forced.json +27 -27
  172. package/src/stories/input-number/data.json +42 -42
  173. package/src/stories/input-number/input-number.stories.js +81 -81
  174. package/src/stories/loop/README.md +25 -25
  175. package/src/stories/loop/loop.stories.js +88 -88
  176. package/src/stories/loop/with-loop/data-loop-deeper.json +298 -298
  177. package/src/stories/loop/with-loop/data-loop.json +336 -336
  178. package/src/stories/loop/with-loop/index.js +2 -2
  179. package/src/stories/loop/with-roster/data-forced.json +213 -213
  180. package/src/stories/loop/with-roster/data-loop-deeper.json +298 -298
  181. package/src/stories/loop/with-roster/data-loop.json +288 -288
  182. package/src/stories/loop/with-roster/index.js +3 -3
  183. package/src/stories/loop-constructor/README.md +27 -27
  184. package/src/stories/loop-constructor/data-input-forced.json +64 -64
  185. package/src/stories/loop-constructor/data-input.json +100 -100
  186. package/src/stories/loop-constructor/data-loop-forced.json +66 -66
  187. package/src/stories/loop-constructor/data-loop-static-forced.json +66 -66
  188. package/src/stories/loop-constructor/data-loop-static.json +81 -81
  189. package/src/stories/loop-constructor/data-loop.json +81 -81
  190. package/src/stories/loop-constructor/data-roster-forced.json +68 -68
  191. package/src/stories/loop-constructor/data-roster.json +83 -83
  192. package/src/stories/loop-constructor/loop-constructor.stories.js +180 -180
  193. package/src/stories/pagination/deeper-loop.json +327 -327
  194. package/src/stories/pagination/pagination.stories.js +60 -60
  195. package/src/stories/pagination/simple-loop.json +277 -277
  196. package/src/stories/pagination/simpsons-question.json +4952 -4952
  197. package/src/stories/pagination/simpsons-sequence.json +4362 -4362
  198. package/src/stories/progress-bar/README.md +13 -13
  199. package/src/stories/questionnaire/arithmetic-management.json +47 -0
  200. package/src/stories/questionnaire/kish.json +275 -0
  201. package/src/stories/questionnaire/logement-queen.json +23390 -0
  202. package/src/stories/questionnaire/logement-s2.json +46027 -44536
  203. package/src/stories/questionnaire/logement.json +20347 -26087
  204. package/src/stories/questionnaire/loop-and-controls.json +481 -0
  205. package/src/stories/questionnaire/questionnaire.stories.js +94 -12
  206. package/src/stories/questionnaire/simpsons.json +4816 -4816
  207. package/src/stories/questionnaire/update-external/data.json +1 -0
  208. package/src/stories/questionnaire/update-external/questionnaire.json +75 -0
  209. package/src/stories/radio/README.md +31 -31
  210. package/src/stories/radio/data-forced.json +32 -32
  211. package/src/stories/radio/data-vtl.json +47 -47
  212. package/src/stories/radio/data.json +32 -32
  213. package/src/stories/radio/radio.stories.js +64 -64
  214. package/src/stories/sequence/README.md +18 -18
  215. package/src/stories/subsequence/README.md +18 -18
  216. package/src/stories/suggester/bailleurs-sociaux-2021/fetch-bailleurs.js +12 -0
  217. package/src/stories/suggester/bailleurs-sociaux-2021/index.js +1 -0
  218. package/src/stories/suggester/cog-communes/index.js +2 -2
  219. package/src/stories/suggester/cog-communes/option-cog-renderer.js +15 -15
  220. package/src/stories/suggester/cog-communes/theme.scss +12 -12
  221. package/src/stories/suggester/data-auto.json +1 -0
  222. package/src/stories/suggester/data.json +35 -2
  223. package/src/stories/suggester/naf-rev2/fetch-naf.js +57 -57
  224. package/src/stories/suggester/naf-rev2/theme.scss +36 -36
  225. package/src/stories/suggester/suggester-workers.stories.js +48 -1
  226. package/src/stories/suggester/suggester.stories.js +5 -0
  227. package/src/stories/table/README.md +29 -29
  228. package/src/stories/table/data-default.json +19 -19
  229. package/src/stories/table/data-one-axis-one-measure.json +139 -139
  230. package/src/stories/table/data-one-axis-two-measures.json +208 -208
  231. package/src/stories/table/data-one-hierarchical-axis.json +219 -219
  232. package/src/stories/table/data-roster.json +486 -486
  233. package/src/stories/table/data-two-axis-one-measure.json +507 -507
  234. package/src/stories/table/table.stories.js +82 -82
  235. package/src/stories/textarea/README.md +33 -33
  236. package/src/stories/textarea/data-forced.json +28 -28
  237. package/src/stories/textarea/data.json +43 -43
  238. package/src/stories/textarea/textarea.stories.js +68 -68
  239. package/src/stories/tooltip-response/README.md +14 -14
  240. package/src/stories/tooltip-response/md-link.json +31 -31
  241. package/src/stories/tooltip-response/md-tooltip.json +31 -31
  242. package/src/stories/tooltip-response/tooltip.stories.js +83 -83
  243. package/src/stories/utils/custom-lunatic.scss +23 -23
  244. package/src/stories/utils/options.js +25 -25
  245. package/src/stories/utils/orchestrator-split.js +119 -0
  246. package/src/stories/utils/orchestrator.js +14 -3
  247. package/src/tests/components/breadcrumb.spec.js +13 -13
  248. package/src/tests/components/button.spec.js +11 -11
  249. package/src/tests/components/checkbox-boolean.spec.js +45 -45
  250. package/src/tests/components/checkbox-group.spec.js +53 -53
  251. package/src/tests/components/checkbox-one.spec.js +32 -32
  252. package/src/tests/components/datepicker.spec.js +22 -22
  253. package/src/tests/components/declarations-wrappers/input-declarations-wrapper.spec.js +67 -67
  254. package/src/tests/components/declarations-wrappers/list-declarations-wrapper.spec.js +52 -52
  255. package/src/tests/components/declarations-wrappers/simple-declarations-wrapper.spec.js +21 -21
  256. package/src/tests/components/declarations.spec.js +46 -46
  257. package/src/tests/components/input-number.spec.js +188 -194
  258. package/src/tests/components/input.spec.js +18 -18
  259. package/src/tests/components/loops/loop-static.json +66 -66
  260. package/src/tests/components/loops/loop.json +258 -258
  261. package/src/tests/components/loops/loop.spec.js +30 -30
  262. package/src/tests/components/loops/roster-for-loop.spec.js +18 -18
  263. package/src/tests/components/missing-wrapper.spec.js +32 -33
  264. package/src/tests/components/progress-bar.spec.js +15 -15
  265. package/src/tests/components/radio.spec.js +27 -27
  266. package/src/tests/components/sequence.spec.js +9 -9
  267. package/src/tests/components/subsequence.spec.js +9 -9
  268. package/src/tests/components/table.spec.js +11 -11
  269. package/src/tests/components/textarea.spec.js +18 -18
  270. package/src/tests/components/tooltip.spec.js +25 -25
  271. package/src/tests/setup/setupTests.js +4 -4
  272. package/src/tests/utils/lib/alphabet.spec.js +36 -36
  273. package/src/tests/utils/lib/array.spec.js +22 -22
  274. package/src/tests/utils/lib/checkbox/group.spec.js +72 -72
  275. package/src/tests/utils/lib/decorator/title-decorator.spec.js +12 -12
  276. package/src/tests/utils/lib/input-number.spec.js +18 -18
  277. package/src/tests/utils/lib/items-positioning.spec.js +17 -17
  278. package/src/tests/utils/lib/label-position.spec.js +22 -22
  279. package/src/tests/utils/lib/loops/bindings.spec.js +75 -75
  280. package/src/tests/utils/lib/loops/shared.spec.js +82 -82
  281. package/src/tests/utils/lib/missing/missing.spec.js +74 -74
  282. package/src/tests/utils/lib/missing/mock.js +137 -137
  283. package/src/tests/utils/lib/pagination/shared.spec.js +42 -42
  284. package/src/tests/utils/lib/responses.spec.js +64 -64
  285. package/src/tests/utils/lib/style.spec.js +26 -26
  286. package/src/tests/utils/lib/tooltip/build-response.spec.js +95 -95
  287. package/src/tests/utils/lib/tooltip/content.spec.js +109 -109
  288. package/src/tests/utils/to-expose/handler/handler.spec.js +94 -94
  289. package/src/tests/utils/to-expose/handler/questionnaire.json +158 -158
  290. package/src/tests/utils/to-expose/handler/results/index.js +6 -6
  291. package/src/tests/utils/to-expose/handler/results/res-double.json +158 -158
  292. package/src/tests/utils/to-expose/handler/results/res-input-collected.json +158 -158
  293. package/src/tests/utils/to-expose/handler/results/res-input-edited.json +158 -158
  294. package/src/tests/utils/to-expose/handler/results/res-loop.json +158 -158
  295. package/src/tests/utils/to-expose/handler/results/res-matrix.json +158 -158
  296. package/src/tests/utils/to-expose/handler/results/res-responses.json +158 -158
  297. package/src/tests/utils/to-expose/init-questionnaire/data.json +12 -12
  298. package/src/tests/utils/to-expose/init-questionnaire/init-questionnaire.spec.js +19 -19
  299. package/src/tests/utils/to-expose/interpret/interpret.spec.js +48 -48
  300. package/src/tests/utils/to-expose/state/questionnaire.json +61 -61
  301. package/src/tests/utils/to-expose/state/results.js +78 -78
  302. package/src/tests/utils/to-expose/state/state.spec.js +59 -59
  303. package/src/utils/components/dragger/dragger.js +64 -64
  304. package/src/utils/components/dragger/index.js +1 -1
  305. package/src/utils/components/fab/fab.js +50 -50
  306. package/src/utils/components/fab/fab.scss +32 -32
  307. package/src/utils/components/fab/index.js +1 -1
  308. package/src/utils/components/field-wrapper.js +23 -23
  309. package/src/utils/components/is-network/index.js +1 -1
  310. package/src/utils/components/is-network/is-network.js +39 -39
  311. package/src/utils/components/is-network/use-online-status.js +51 -51
  312. package/src/utils/components/label-wrapper.js +45 -45
  313. package/src/utils/icons/closed.icon.js +24 -24
  314. package/src/utils/icons/cross.icon.js +24 -24
  315. package/src/utils/icons/load.icon.js +24 -24
  316. package/src/utils/icons/lunatic-icon.js +9 -9
  317. package/src/utils/icons/lunatic-icon.scss +4 -4
  318. package/src/utils/icons/network.icon.js +24 -24
  319. package/src/utils/icons/on-drag.icon.js +24 -24
  320. package/src/utils/icons/opened.icon.js +24 -24
  321. package/src/utils/idb-tools/clear-store.js +16 -16
  322. package/src/utils/idb-tools/get-entity.js +15 -15
  323. package/src/utils/idb-tools/get-idb.js +12 -12
  324. package/src/utils/lib/alphabet.js +1 -1
  325. package/src/utils/lib/array.js +7 -7
  326. package/src/utils/lib/checkbox/group.js +21 -21
  327. package/src/utils/lib/checkbox/index.js +1 -1
  328. package/src/utils/lib/controls/index.js +1 -0
  329. package/src/utils/lib/controls/utils.js +152 -0
  330. package/src/utils/lib/decorator/index.js +1 -1
  331. package/src/utils/lib/env.js +2 -2
  332. package/src/utils/lib/event.js +15 -15
  333. package/src/utils/lib/function.js +1 -1
  334. package/src/utils/lib/index.js +21 -19
  335. package/src/utils/lib/input-number.js +6 -6
  336. package/src/utils/lib/label-position.js +12 -12
  337. package/src/utils/lib/loops/bindings.js +66 -66
  338. package/src/utils/lib/loops/build-components.js +33 -33
  339. package/src/utils/lib/loops/index.js +3 -3
  340. package/src/utils/lib/loops/shared.js +55 -55
  341. package/src/utils/lib/memo-check.js +24 -24
  342. package/src/utils/lib/missing.js +52 -52
  343. package/src/utils/lib/pagination/flow.js +2 -2
  344. package/src/utils/lib/pagination/index.js +2 -2
  345. package/src/utils/lib/pagination/navigation/index.js +1 -1
  346. package/src/utils/lib/pagination/navigation/shared.js +12 -9
  347. package/src/utils/lib/prop-types/declarations.js +22 -22
  348. package/src/utils/lib/prop-types/index.js +5 -5
  349. package/src/utils/lib/prop-types/options.js +8 -8
  350. package/src/utils/lib/prop-types/response.js +6 -6
  351. package/src/utils/lib/prop-types/value-type.js +9 -9
  352. package/src/utils/lib/responses.js +9 -7
  353. package/src/utils/lib/splitting.js +142 -0
  354. package/src/utils/lib/table/index.js +1 -1
  355. package/src/utils/lib/table/roster.js +23 -23
  356. package/src/utils/lib/tooltip/build-response.js +41 -41
  357. package/src/utils/lib/tooltip/content.js +55 -55
  358. package/src/utils/lib/tooltip/index.js +6 -6
  359. package/src/utils/store-tools/auto-load.js +2 -1
  360. package/src/utils/store-tools/clear-store-data.js +8 -8
  361. package/src/utils/store-tools/clear-store-info.js +8 -8
  362. package/src/utils/store-tools/constantes.js +20 -20
  363. package/src/utils/store-tools/create/create.js +19 -19
  364. package/src/utils/store-tools/create/index.js +1 -1
  365. package/src/utils/store-tools/create/update-store-info.js +26 -26
  366. package/src/utils/store-tools/get-store-count.js +22 -22
  367. package/src/utils/store-tools/index.js +5 -5
  368. package/src/utils/store-tools/open-or-create-store.js +47 -47
  369. package/src/utils/store-tools/use-store-index.js +24 -24
  370. package/src/utils/suggester-workers/append-to-index/create-append-task.js +3 -1
  371. package/src/utils/suggester-workers/commons-tokenizer/create-entity-tokenizer.js +56 -0
  372. package/src/utils/suggester-workers/commons-tokenizer/create-fields-tokenizer.js +56 -0
  373. package/src/utils/suggester-workers/commons-tokenizer/create-filter-stop-words.js +11 -11
  374. package/src/utils/suggester-workers/commons-tokenizer/filters/compose-filters.js +10 -0
  375. package/src/utils/suggester-workers/commons-tokenizer/filters/create-filter-stop-words.js +17 -0
  376. package/src/utils/suggester-workers/commons-tokenizer/filters/create-filter-stop-words.spec.js +14 -0
  377. package/src/utils/suggester-workers/commons-tokenizer/filters/filter-accents.js +12 -0
  378. package/src/utils/suggester-workers/commons-tokenizer/filters/filter-accents.spec.js +12 -0
  379. package/src/utils/suggester-workers/commons-tokenizer/{filter-double.js → filters/filter-double.js} +0 -0
  380. package/src/utils/suggester-workers/commons-tokenizer/filters/filter-double.spec.js +20 -0
  381. package/src/utils/suggester-workers/commons-tokenizer/{filter-length.js → filters/filter-length.js} +0 -0
  382. package/src/utils/suggester-workers/commons-tokenizer/filters/filter-length.spec.js +18 -0
  383. package/src/utils/suggester-workers/commons-tokenizer/{filter-stemmer.js → filters/filter-stemmer.js} +2 -2
  384. package/src/utils/suggester-workers/commons-tokenizer/filters/filter-stemmer.spec.js +12 -0
  385. package/src/utils/suggester-workers/commons-tokenizer/filters/filter-synonyms.js +36 -0
  386. package/src/utils/suggester-workers/commons-tokenizer/filters/filter-synonyms.spec.js +12 -0
  387. package/src/utils/suggester-workers/commons-tokenizer/filters/filter-to-lower.js +10 -0
  388. package/src/utils/suggester-workers/commons-tokenizer/filters/filter-to-lower.spec.js +12 -0
  389. package/src/utils/suggester-workers/commons-tokenizer/filters/index.js +2 -0
  390. package/src/utils/suggester-workers/commons-tokenizer/{stop-words.js → filters/stop-words.js} +0 -0
  391. package/src/utils/suggester-workers/commons-tokenizer/index.js +6 -5
  392. package/src/utils/suggester-workers/commons-tokenizer/prepare-string-indexation.js +7 -3
  393. package/src/utils/suggester-workers/commons-tokenizer/soft-tokenizer.js +1 -1
  394. package/src/utils/suggester-workers/create-worker.js +56 -0
  395. package/src/utils/suggester-workers/find-best-label/tokenize.js +2 -5
  396. package/src/utils/suggester-workers/{query-parser → searching/query-parser}/index.js +0 -0
  397. package/src/utils/suggester-workers/searching/query-parser/query-parser-soft.js +7 -0
  398. package/src/utils/suggester-workers/{query-parser → searching/query-parser}/query-parser-soft.spec.js +0 -0
  399. package/src/utils/suggester-workers/searching/query-parser/query-parser-tokenized.js +34 -0
  400. package/src/utils/suggester-workers/searching/resolve-query-parser.js +2 -2
  401. package/src/utils/suggester-workers/searching/searching.js +2 -2
  402. package/src/utils/to-expose/handler.js +68 -31
  403. package/src/utils/to-expose/hooks/filter-components.js +121 -106
  404. package/src/utils/to-expose/hooks/index.js +2 -1
  405. package/src/utils/to-expose/hooks/lunatic-split.js +428 -0
  406. package/src/utils/to-expose/hooks/lunatic.js +107 -11
  407. package/src/utils/to-expose/hooks/use-document-add-event-listener.js +63 -63
  408. package/src/utils/to-expose/index.js +11 -11
  409. package/src/utils/to-expose/interpret/index.js +1 -1
  410. package/src/utils/to-expose/interpret/main.js +16 -16
  411. package/src/utils/to-expose/interpret/md.js +65 -65
  412. package/src/utils/to-expose/state.js +23 -15
  413. package/src/components/missing-wrapper/component.js +0 -120
  414. package/src/components/missing-wrapper/wrapper.js +0 -10
  415. package/src/tests/utils/to-expose/hooks/use-lunatic.spec.js +0 -46
  416. package/src/utils/suggester-workers/commons-tokenizer/create-tokenizer.js +0 -103
  417. package/src/utils/suggester-workers/commons-tokenizer/filter-accents-to-lower.js +0 -9
  418. package/src/utils/suggester-workers/commons-tokenizer/filter-synonyms.js +0 -10
  419. package/src/utils/suggester-workers/query-parser/query-parser-soft.js +0 -7
  420. package/src/utils/suggester-workers/query-parser/query-parser-tokenized.js +0 -31
  421. package/src/utils/suggester-workers/query-parser/query-parser-tokenized.spec.js +0 -32
@@ -1,55 +1,55 @@
1
- import * as C from '../../../constants';
2
-
3
- export const getLoopConstructorInitLines = (components) =>
4
- Array.isArray(components)
5
- ? components.reduce(
6
- (_, c) =>
7
- c.response &&
8
- c.response.values[C.COLLECTED] &&
9
- c.response.values[C.COLLECTED].length > _
10
- ? c.response.values[C.COLLECTED].length
11
- : _,
12
- 0
13
- )
14
- : 0;
15
-
16
- export const getInvolvedVariables = (parentComponents) =>
17
- Array.isArray(parentComponents)
18
- ? parentComponents
19
- .reduce((_, c) => {
20
- const { response, responses, missingResponse, components, depth } = c;
21
- if (missingResponse) {
22
- const miss = { name: missingResponse.name, depth };
23
- if (response && response.name)
24
- return [..._, { name: response.name, depth }, miss];
25
- if (responses || components)
26
- return [
27
- ..._,
28
- getInvolvedVariables(responses || components),
29
- miss,
30
- ];
31
- return _;
32
- }
33
- if (response && response.name)
34
- return [..._, { name: response.name, depth }];
35
- if (responses || components)
36
- return [..._, getInvolvedVariables(responses || components)];
37
- return _;
38
- }, [])
39
- .flat()
40
- : [];
41
-
42
- export const lastLoopChildLineIsEmpty = (bindings) => (involvedVariables) =>
43
- bindings && involvedVariables
44
- ? involvedVariables
45
- .map((iv) => iv.name)
46
- .filter((iv) => bindings[iv] && bindings[iv][bindings[iv].length - 1])
47
- .length === 0
48
- : true;
49
-
50
- export const buildEmptyValue = (depth) => {
51
- if (!Number(depth) || depth <= 2) return null;
52
- return new Array(depth - 2)
53
- .fill(null)
54
- .reduce((acc) => new Array(1).fill(acc), null);
55
- };
1
+ import * as C from '../../../constants';
2
+
3
+ export const getLoopConstructorInitLines = (components) =>
4
+ Array.isArray(components)
5
+ ? components.reduce(
6
+ (_, c) =>
7
+ c.response &&
8
+ c.response.values[C.COLLECTED] &&
9
+ c.response.values[C.COLLECTED].length > _
10
+ ? c.response.values[C.COLLECTED].length
11
+ : _,
12
+ 0
13
+ )
14
+ : 0;
15
+
16
+ export const getInvolvedVariables = (parentComponents) =>
17
+ Array.isArray(parentComponents)
18
+ ? parentComponents
19
+ .reduce((_, c) => {
20
+ const { response, responses, missingResponse, components, depth } = c;
21
+ if (missingResponse) {
22
+ const miss = { name: missingResponse.name, depth };
23
+ if (response && response.name)
24
+ return [..._, { name: response.name, depth }, miss];
25
+ if (responses || components)
26
+ return [
27
+ ..._,
28
+ getInvolvedVariables(responses || components),
29
+ miss,
30
+ ];
31
+ return _;
32
+ }
33
+ if (response && response.name)
34
+ return [..._, { name: response.name, depth }];
35
+ if (responses || components)
36
+ return [..._, getInvolvedVariables(responses || components)];
37
+ return _;
38
+ }, [])
39
+ .flat()
40
+ : [];
41
+
42
+ export const lastLoopChildLineIsEmpty = (bindings) => (involvedVariables) =>
43
+ bindings && involvedVariables
44
+ ? involvedVariables
45
+ .map((iv) => iv.name)
46
+ .filter((iv) => bindings[iv] && bindings[iv][bindings[iv].length - 1])
47
+ .length === 0
48
+ : true;
49
+
50
+ export const buildEmptyValue = (depth) => {
51
+ if (!Number(depth) || depth <= 2) return null;
52
+ return new Array(depth - 2)
53
+ .fill(null)
54
+ .reduce((acc) => new Array(1).fill(acc), null);
55
+ };
@@ -1,24 +1,24 @@
1
- import isEqual from 'lodash.isequal';
2
-
3
- const VarsHasBeenUpdated = (prevProps, props) => {
4
- const { response: oldR, responses: oldRs, cells: oldC } = prevProps;
5
- const { response: newR, responses: newRs, cells: newC } = props;
6
- if (!newR && !newRs && !newC) return true;
7
- return !(
8
- (newR && isEqual(oldR, newR)) ||
9
- (newRs && isEqual(oldRs, newRs)) ||
10
- (newC && isEqual(oldC, newC))
11
- );
12
- };
13
- export const areEqual = (prevProps, props) => {
14
- if (VarsHasBeenUpdated(prevProps, props)) return false;
15
- const { bindingDependencies } = props;
16
- if (Array.isArray(bindingDependencies) && bindingDependencies.length > 0) {
17
- const { bindings: oldB } = prevProps;
18
- const { bindings: newB } = props;
19
- return !bindingDependencies
20
- .map((d) => isEqual(oldB[d], newB[d]))
21
- .includes(false);
22
- }
23
- return true;
24
- };
1
+ import isEqual from 'lodash.isequal';
2
+
3
+ const VarsHasBeenUpdated = (prevProps, props) => {
4
+ const { response: oldR, responses: oldRs, cells: oldC } = prevProps;
5
+ const { response: newR, responses: newRs, cells: newC } = props;
6
+ if (!newR && !newRs && !newC) return true;
7
+ return !(
8
+ (newR && isEqual(oldR, newR)) ||
9
+ (newRs && isEqual(oldRs, newRs)) ||
10
+ (newC && isEqual(oldC, newC))
11
+ );
12
+ };
13
+ export const areEqual = (prevProps, props) => {
14
+ if (VarsHasBeenUpdated(prevProps, props)) return false;
15
+ const { bindingDependencies } = props;
16
+ if (Array.isArray(bindingDependencies) && bindingDependencies.length > 0) {
17
+ const { bindings: oldB } = prevProps;
18
+ const { bindings: newB } = props;
19
+ return !bindingDependencies
20
+ .map((d) => isEqual(oldB[d], newB[d]))
21
+ .includes(false);
22
+ }
23
+ return true;
24
+ };
@@ -1,52 +1,52 @@
1
- import { buildNullNestedArray } from './array';
2
-
3
- export const DK = 'DK';
4
- export const RF = 'RF';
5
-
6
- export const getToClean =
7
- (savingType) =>
8
- ({ response, responses, cells, components }) => {
9
- if (response) {
10
- const resValues = response.values[savingType];
11
- if (resValues !== null) {
12
- if (Array.isArray(resValues)) {
13
- //handle nested array
14
- return { [response.name]: buildNullNestedArray(resValues) };
15
- }
16
- return { [response.name]: null };
17
- }
18
- return {};
19
- }
20
- if (responses || cells || components) {
21
- const group = responses || cells || components;
22
- return group
23
- .flat(Infinity)
24
- .reduce((acc, c) => ({ ...acc, ...getToClean(savingType)(c) }), {});
25
- }
26
- return false;
27
- };
28
-
29
- export const hasToCleanMissing =
30
- (savingType) =>
31
- ({ response, responses, cells, components }) => {
32
- if (response) {
33
- const resValues = response.values[savingType];
34
- if (resValues !== null) {
35
- if (Array.isArray(resValues)) {
36
- if (resValues.flat(Infinity).filter((r) => r !== null).length > 0)
37
- return true;
38
- return false;
39
- }
40
- return true;
41
- }
42
- return false;
43
- }
44
- if (responses || cells || components) {
45
- const group = responses || cells || components;
46
- return (
47
- group.flat(Infinity).filter((c) => hasToCleanMissing(savingType)(c))
48
- .length > 0
49
- );
50
- }
51
- return false;
52
- };
1
+ import { buildNullNestedArray } from './array';
2
+
3
+ export const DK = 'DK';
4
+ export const RF = 'RF';
5
+
6
+ export const getToClean =
7
+ (savingType) =>
8
+ ({ response, responses, cells, components }) => {
9
+ if (response) {
10
+ const resValues = response.values[savingType];
11
+ if (resValues !== null) {
12
+ if (Array.isArray(resValues)) {
13
+ //handle nested array
14
+ return { [response.name]: buildNullNestedArray(resValues) };
15
+ }
16
+ return { [response.name]: null };
17
+ }
18
+ return {};
19
+ }
20
+ if (responses || cells || components) {
21
+ const group = responses || cells || components;
22
+ return group
23
+ .flat(Infinity)
24
+ .reduce((acc, c) => ({ ...acc, ...getToClean(savingType)(c) }), {});
25
+ }
26
+ return false;
27
+ };
28
+
29
+ export const hasToCleanMissing =
30
+ (savingType) =>
31
+ ({ response, responses, cells, components }) => {
32
+ if (response) {
33
+ const resValues = response.values[savingType];
34
+ if (resValues !== null) {
35
+ if (Array.isArray(resValues)) {
36
+ if (resValues.flat(Infinity).filter((r) => r !== null).length > 0)
37
+ return true;
38
+ return false;
39
+ }
40
+ return true;
41
+ }
42
+ return false;
43
+ }
44
+ if (responses || cells || components) {
45
+ const group = responses || cells || components;
46
+ return (
47
+ group.flat(Infinity).filter((c) => hasToCleanMissing(savingType)(c))
48
+ .length > 0
49
+ );
50
+ }
51
+ return false;
52
+ };
@@ -1,2 +1,2 @@
1
- export const FLOW_NEXT = 'FLOW_NEXT';
2
- export const FLOW_PREVIOUS = 'FLOW_PREVIOUS';
1
+ export const FLOW_NEXT = 'FLOW_NEXT';
2
+ export const FLOW_PREVIOUS = 'FLOW_PREVIOUS';
@@ -1,2 +1,2 @@
1
- export * from './flow';
2
- export * from './navigation';
1
+ export * from './flow';
2
+ export * from './navigation';
@@ -1 +1 @@
1
- export * from './shared';
1
+ export * from './shared';
@@ -50,7 +50,8 @@ export const getPage = ({
50
50
  interpret(featuresWithoutMD)(loopVectorialB)(loopV) !== true ||
51
51
  (flow === FLOW_PREVIOUS &&
52
52
  currentIteration === 1 &&
53
- currentComponentIndex === 1)
53
+ currentComponentIndex === 1 &&
54
+ page === currentRootPage)
54
55
  )
55
56
  continue;
56
57
  const iterations = getIterations({
@@ -86,7 +87,6 @@ export const getPage = ({
86
87
  page,
87
88
  it,
88
89
  currentIteration,
89
- loopComponentIndex: componentIndex,
90
90
  currentComponentIndex,
91
91
  loopComponent,
92
92
  })
@@ -112,7 +112,6 @@ export const getPage = ({
112
112
  const block = filteredComponents.filter(
113
113
  (c) => c.page === page && c.componentType === 'Loop'
114
114
  );
115
-
116
115
  if (block.length > 0) {
117
116
  const loopIdOfInterest =
118
117
  flow === FLOW_NEXT ? block[0].id : block[block.length - 1].id;
@@ -168,10 +167,14 @@ const hasToBeExcluded = ({
168
167
  page,
169
168
  it,
170
169
  currentIteration,
171
- loopComponentIndex,
172
170
  currentComponentIndex,
173
171
  loopComponent,
174
172
  }) => {
173
+ const { page: loopPage, depth } = loopComponent;
174
+ const { currentComponentIndex: loopComponentIndex } = splitPage(
175
+ loopPage,
176
+ depth
177
+ );
175
178
  if (flow === FLOW_NEXT)
176
179
  return (
177
180
  (currentRootPage === page &&
@@ -218,28 +221,28 @@ const getIterations = ({ component, bindings, featuresWithoutMD }) => {
218
221
  export const splitPage = (currentPage = '1', depth) => {
219
222
  const currentPageWithDepth = depth
220
223
  ? currentPage
221
- .split('.')
224
+ ?.split('.')
222
225
  .slice(0, depth + 1) // scoped
223
226
  .join('.')
224
227
  : currentPage;
225
228
 
226
229
  const currentPageWithoutIteration = currentPageWithDepth
227
- .split('#')
230
+ ?.split('#')
228
231
  .slice(0, -1)
229
232
  .join('#');
230
233
 
231
234
  const currentPageWithoutAnyIteration = currentPageWithDepth
232
- .split('.')
235
+ ?.split('.')
233
236
  .map((e) => e.split('#')[0])
234
237
  .join('.');
235
238
 
236
239
  const currentRootPage = currentPageWithoutIteration
237
- .split('.')
240
+ ?.split('.')
238
241
  .slice(0, -1)
239
242
  .join('.');
240
243
 
241
244
  const [currentComponentIndex, currentIteration] = currentPageWithDepth
242
- .split('.')
245
+ ?.split('.')
243
246
  .pop()
244
247
  .split('#')
245
248
  .map((c) => parseInt(c, 10));
@@ -1,22 +1,22 @@
1
- import PropTypes from 'prop-types';
2
- import * as C from '../../../constants';
3
-
4
- export default PropTypes.arrayOf(
5
- PropTypes.shape({
6
- id: PropTypes.string.isRequired,
7
- declarationType: PropTypes.oneOf([
8
- C.INSTRUCTION,
9
- C.COMMENT,
10
- C.HELP,
11
- C.WARNING,
12
- C.MESSAGE_FILTER,
13
- C.STATEMENT,
14
- ]),
15
- position: PropTypes.oneOf([
16
- C.BEFORE_QUESTION_TEXT,
17
- C.AFTER_QUESTION_TEXT,
18
- C.DETACHABLE,
19
- ]),
20
- label: PropTypes.string.isRequired,
21
- })
22
- ).isRequired;
1
+ import PropTypes from 'prop-types';
2
+ import * as C from '../../../constants';
3
+
4
+ export default PropTypes.arrayOf(
5
+ PropTypes.shape({
6
+ id: PropTypes.string.isRequired,
7
+ declarationType: PropTypes.oneOf([
8
+ C.INSTRUCTION,
9
+ C.COMMENT,
10
+ C.HELP,
11
+ C.WARNING,
12
+ C.MESSAGE_FILTER,
13
+ C.STATEMENT,
14
+ ]),
15
+ position: PropTypes.oneOf([
16
+ C.BEFORE_QUESTION_TEXT,
17
+ C.AFTER_QUESTION_TEXT,
18
+ C.DETACHABLE,
19
+ ]),
20
+ label: PropTypes.string.isRequired,
21
+ })
22
+ ).isRequired;
@@ -1,5 +1,5 @@
1
- export { default as declarationsPropTypes } from './declarations';
2
- export { default as optionsPropTypes } from './options';
3
- export { default as responsePropTypes } from './response';
4
- export { default as valueTypePropTypes } from './value-type';
5
- export { default as linesPropTypes } from './lines';
1
+ export { default as declarationsPropTypes } from './declarations';
2
+ export { default as optionsPropTypes } from './options';
3
+ export { default as responsePropTypes } from './response';
4
+ export { default as valueTypePropTypes } from './value-type';
5
+ export { default as linesPropTypes } from './lines';
@@ -1,8 +1,8 @@
1
- import PropTypes from 'prop-types';
2
-
3
- export default PropTypes.arrayOf(
4
- PropTypes.shape({
5
- label: PropTypes.string.isRequired,
6
- value: PropTypes.string.isRequired,
7
- })
8
- );
1
+ import PropTypes from 'prop-types';
2
+
3
+ export default PropTypes.arrayOf(
4
+ PropTypes.shape({
5
+ label: PropTypes.string.isRequired,
6
+ value: PropTypes.string.isRequired,
7
+ })
8
+ );
@@ -1,6 +1,6 @@
1
- import PropTypes from 'prop-types';
2
-
3
- export default PropTypes.shape({
4
- name: PropTypes.string,
5
- values: PropTypes.shape({}),
6
- });
1
+ import PropTypes from 'prop-types';
2
+
3
+ export default PropTypes.shape({
4
+ name: PropTypes.string,
5
+ values: PropTypes.shape({}),
6
+ });
@@ -1,9 +1,9 @@
1
- import PropTypes from 'prop-types';
2
-
3
- export default PropTypes.oneOf([
4
- 'COLLECTED',
5
- 'PREVIOUS',
6
- 'FORCED',
7
- 'EDITED',
8
- 'INPUTED',
9
- ]);
1
+ import PropTypes from 'prop-types';
2
+
3
+ export default PropTypes.oneOf([
4
+ 'COLLECTED',
5
+ 'PREVIOUS',
6
+ 'FORCED',
7
+ 'EDITED',
8
+ 'INPUTED',
9
+ ]);
@@ -1,9 +1,11 @@
1
1
  export const getResponseName = (response) => (response && response.name) || '';
2
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
- };
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
+ };
@@ -1 +1 @@
1
- export * from './roster';
1
+ export * from './roster';
@@ -1,23 +1,23 @@
1
- const isResponseEmpty = (response) =>
2
- Object.values(response.values).filter((v) => v !== null).length === 0;
3
-
4
- export const getRosterInitLines = (cells) =>
5
- Array.isArray(cells)
6
- ? cells
7
- .filter(
8
- (line) =>
9
- line.filter(({ response }) => !response).length !== line.length
10
- )
11
- .reduce(
12
- (_, line) => [
13
- ..._,
14
- line.reduce((__, { response, label }) => {
15
- if (label) return true;
16
- if (__ || !response) return __;
17
- return !isResponseEmpty(response);
18
- }, false),
19
- ],
20
- []
21
- )
22
- .filter((b) => b).length
23
- : 0;
1
+ const isResponseEmpty = (response) =>
2
+ Object.values(response.values).filter((v) => v !== null).length === 0;
3
+
4
+ export const getRosterInitLines = (cells) =>
5
+ Array.isArray(cells)
6
+ ? cells
7
+ .filter(
8
+ (line) =>
9
+ line.filter(({ response }) => !response).length !== line.length
10
+ )
11
+ .reduce(
12
+ (_, line) => [
13
+ ..._,
14
+ line.reduce((__, { response, label }) => {
15
+ if (label) return true;
16
+ if (__ || !response) return __;
17
+ return !isResponseEmpty(response);
18
+ }, false),
19
+ ],
20
+ []
21
+ )
22
+ .filter((b) => b).length
23
+ : 0;