@inseefr/lunatic 0.1.0-hackathon → 0.1.0-v2

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 (350) hide show
  1. package/lib/index.js +1433 -835
  2. package/lib/index.js.map +1 -1
  3. package/package.json +11 -8
  4. package/src/components/breadcrumb/component.js +29 -29
  5. package/src/components/button/index.js +1 -1
  6. package/src/components/button/lunatic-button.js +32 -0
  7. package/src/components/checkbox/checkbox-boolean/index.js +1 -0
  8. package/src/components/checkbox/checkbox-boolean/lunatic-checkbox-boolean.js +44 -0
  9. package/src/components/checkbox/checkbox-group/checkbox-group.js +78 -0
  10. package/src/components/checkbox/checkbox-group/checkbox-option.js +46 -0
  11. package/src/components/checkbox/checkbox-group/index.js +1 -0
  12. package/src/components/checkbox/checkbox-group/lunatic-checkbox-group.js +32 -0
  13. package/src/components/checkbox/checkbox-one/index.js +1 -0
  14. package/src/components/checkbox/checkbox-one/lunatic-checkbox-one.js +7 -0
  15. package/src/components/checkbox/checkbox.scss +1 -73
  16. package/src/components/checkbox/commons/checkbox-option.js +49 -0
  17. package/src/components/checkbox/commons/index.js +1 -0
  18. package/src/components/checkbox/index.js +3 -3
  19. package/src/components/commons/components/field-container/field-container.js +28 -0
  20. package/src/components/commons/components/field-container/field-container.scss +0 -0
  21. package/src/components/commons/components/field-container/index.js +1 -0
  22. package/src/components/commons/components/fieldset.js +12 -0
  23. package/src/components/commons/components/input-container.js +30 -0
  24. package/src/components/commons/components/label.js +14 -0
  25. package/src/components/commons/components/lunatic-field.js +35 -0
  26. package/src/components/commons/create-customizable-field.js +13 -0
  27. package/src/components/commons/index.js +9 -0
  28. package/src/components/commons/use-on-handle-change.js +16 -0
  29. package/src/components/commons/use-options-keydown.js +22 -0
  30. package/src/components/commons/use-previous.js +11 -0
  31. package/src/components/component-wrapper/controls/component.js +70 -0
  32. package/src/components/component-wrapper/controls/controls.scss +6 -0
  33. package/src/components/component-wrapper/controls/index.js +1 -0
  34. package/src/components/component-wrapper/controls/validators/datepicker.js +33 -0
  35. package/src/components/component-wrapper/controls/validators/index.js +16 -0
  36. package/src/components/component-wrapper/controls/validators/input-number.js +23 -0
  37. package/src/components/{missing-wrapper → component-wrapper}/index.js +1 -1
  38. package/src/components/{missing-wrapper → component-wrapper/missing}/component.js +72 -12
  39. package/src/components/component-wrapper/missing/index.js +1 -0
  40. package/src/components/{missing-wrapper → component-wrapper/missing}/missing.scss +0 -0
  41. package/src/components/component-wrapper/wrapper.js +23 -0
  42. package/src/components/components.js +22 -18
  43. package/src/components/datepicker/datepicker.js +25 -0
  44. package/src/components/datepicker/index.js +1 -1
  45. package/src/components/datepicker/lunatic-datepicker.js +50 -0
  46. package/src/components/declarations/declaration.js +11 -0
  47. package/src/components/declarations/declarations-after-text.js +8 -0
  48. package/src/components/declarations/declarations-before-text.js +8 -0
  49. package/src/components/declarations/declarations-detachable.js +8 -0
  50. package/src/components/declarations/declarations.js +35 -0
  51. package/src/components/declarations/index.js +4 -1
  52. package/src/components/declarations/wrappers/input-declarations-wrapper.js +40 -12
  53. package/src/components/declarations/wrappers/list-declarations-wrapper.js +235 -232
  54. package/src/components/dropdown/commons/actions.js +40 -31
  55. package/src/components/dropdown/commons/components/panel.js +78 -78
  56. package/src/components/dropdown/commons/reducer.js +152 -149
  57. package/src/components/dropdown/component.js +121 -115
  58. package/src/components/dropdown/dropdown-edit/dropdown-edit.js +6 -0
  59. package/src/components/dropdown/dropdown-simple/dropdown.js +8 -1
  60. package/src/components/filter-description/component.js +48 -42
  61. package/src/components/icon/component.js +31 -33
  62. package/src/components/index.scss +5 -3
  63. package/src/components/input/index.js +1 -2
  64. package/src/components/input/input.js +45 -9
  65. package/src/components/input/input.scss +0 -6
  66. package/src/components/input/lunatic-input.js +53 -0
  67. package/src/components/input-number/index.js +1 -0
  68. package/src/components/input-number/input-number.js +38 -0
  69. package/src/components/input-number/input-number.scss +0 -0
  70. package/src/components/input-number/lunatic-input-number.js +50 -0
  71. package/src/components/loop/{component.js → _old/component.js} +1 -0
  72. package/src/components/loop/{loop.scss → _old/loop.scss} +0 -0
  73. package/src/components/loop/{wrapper.js → _old/wrapper.js} +15 -15
  74. package/src/components/loop/block-for-loop/block-for-loop-ochestrator.js +6 -0
  75. package/src/components/loop/block-for-loop/block-for-loop.js +91 -0
  76. package/src/components/loop/block-for-loop/index.js +1 -0
  77. package/src/components/loop/block-for-loop/row.js +52 -0
  78. package/src/components/loop/commons/create-loop-orchestrator.js +36 -0
  79. package/src/components/loop/commons/index.js +2 -0
  80. package/src/components/loop/commons/row-component.js +52 -0
  81. package/src/components/loop/index.js +1 -1
  82. package/src/components/loop/loop.js +78 -0
  83. package/src/components/loop/roster-for-loop/add-row-button.js +12 -0
  84. package/src/components/loop/roster-for-loop/body.js +44 -0
  85. package/src/components/loop/roster-for-loop/header.js +25 -0
  86. package/src/components/loop/roster-for-loop/html-table/table.js +11 -0
  87. package/src/components/loop/roster-for-loop/html-table/tbody.js +11 -0
  88. package/src/components/loop/roster-for-loop/html-table/td.js +14 -0
  89. package/src/components/loop/roster-for-loop/html-table/th.js +11 -0
  90. package/src/components/loop/roster-for-loop/html-table/thead.js +11 -0
  91. package/src/components/loop/roster-for-loop/html-table/tr.js +11 -0
  92. package/src/components/loop/roster-for-loop/index.js +1 -0
  93. package/src/components/loop/roster-for-loop/roster-for-loop-orchestrator.js +6 -0
  94. package/src/components/loop/roster-for-loop/roster-for-loop.js +90 -0
  95. package/src/components/loop/roster-for-loop/roster-table.js +39 -0
  96. package/src/components/loop/roster-for-loop/roster.scss +42 -0
  97. package/src/components/loop/roster-for-loop/row.js +65 -0
  98. package/src/components/loop-constructor/block/component.js +2 -2
  99. package/src/components/loop-constructor/block/index.js +1 -1
  100. package/src/components/loop-constructor/index.js +1 -1
  101. package/src/components/loop-constructor/roster/component.js +2 -2
  102. package/src/components/loop-constructor/roster/index.js +1 -1
  103. package/src/components/loop-constructor/wrapper/body-component.js +6 -0
  104. package/src/components/loop-constructor/wrapper/build-components.js +33 -33
  105. package/src/components/loop-constructor/wrapper/index.js +1 -1
  106. package/src/components/modal/component.js +42 -0
  107. package/src/components/modal/index.js +1 -0
  108. package/src/components/modal/modal.scss +33 -0
  109. package/src/components/radio/index.js +1 -1
  110. package/src/components/radio/lunatic-radio-group.js +45 -0
  111. package/src/components/radio/radio-group.js +33 -0
  112. package/src/components/radio/radio-option.js +87 -0
  113. package/src/components/radio/radio.scss +52 -52
  114. package/src/components/sequence/index.js +1 -1
  115. package/src/components/sequence/sequence.js +75 -0
  116. package/src/components/subsequence/index.js +1 -1
  117. package/src/components/subsequence/subsequence.js +73 -0
  118. package/src/components/suggester/check-store.js +70 -70
  119. package/src/components/suggester/components/panel/option-container.js +11 -10
  120. package/src/components/suggester/components/panel/panel.js +20 -6
  121. package/src/components/suggester/components/selection/label.js +7 -6
  122. package/src/components/suggester/components/selection/selection.js +36 -11
  123. package/src/components/suggester/components/suggester-content.js +35 -42
  124. package/src/components/suggester/components/suggester.js +45 -26
  125. package/src/components/suggester/{components/create-on-keydown-callback.js → create-on-keydown-callback.js} +28 -28
  126. package/src/components/suggester/find-best-label/find-best-label.js +3 -1
  127. package/src/components/suggester/idb-suggester.js +2 -1
  128. package/src/components/suggester/lunatic-suggester.js +48 -96
  129. package/src/components/suggester/searching/create-searching.js +3 -1
  130. package/src/components/suggester/suggester-wrapper.js +75 -9
  131. package/src/components/switch/index.js +1 -0
  132. package/src/components/switch/lunatic-switch.js +49 -0
  133. package/src/components/switch/switch.js +72 -0
  134. package/src/components/switch/switch.scss +47 -0
  135. package/src/components/table/table.js +164 -158
  136. package/src/components/textarea/component.js +11 -5
  137. package/src/components/tooltip/response.js +58 -52
  138. package/src/stories/checkbox-boolean/data-forced.json +48 -48
  139. package/src/stories/checkbox-group/data-vtl.json +102 -102
  140. package/src/stories/cleaning/cleaning.stories.js +39 -0
  141. package/src/stories/cleaning/simple-loop.json +911 -0
  142. package/src/stories/cleaning/simpsons.json +5839 -0
  143. package/src/stories/datepicker/data.json +45 -43
  144. package/src/stories/declarations/declarations.stories.js +20 -13
  145. package/src/stories/icons/icons.stories.js +24 -16
  146. package/src/stories/loop-constructor/README.md +27 -27
  147. package/src/stories/loop-constructor/data-input-forced.json +64 -64
  148. package/src/stories/loop-constructor/data-input.json +100 -100
  149. package/src/stories/loop-constructor/data-loop-forced.json +66 -66
  150. package/src/stories/loop-constructor/data-loop-static-forced.json +66 -66
  151. package/src/stories/loop-constructor/data-loop-static.json +81 -81
  152. package/src/stories/loop-constructor/data-loop.json +81 -81
  153. package/src/stories/loop-constructor/data-roster-forced.json +68 -68
  154. package/src/stories/loop-constructor/data-roster.json +83 -83
  155. package/src/stories/loop-constructor/loop-constructor.stories.js +180 -180
  156. package/src/stories/questionnaire/logement-queen.json +23234 -0
  157. package/src/stories/questionnaire/logement.json +22068 -26812
  158. package/src/stories/questionnaire/questionnaire.stories.js +86 -29
  159. package/src/stories/questionnaire/update-external/data.json +1 -0
  160. package/src/stories/questionnaire/update-external/questionnaire.json +75 -0
  161. package/src/stories/suggester/bailleurs-sociaux-2021/fetch-bailleurs.js +12 -0
  162. package/src/stories/suggester/bailleurs-sociaux-2021/index.js +1 -0
  163. package/src/stories/suggester/data-auto.json +1 -0
  164. package/src/stories/suggester/data.json +35 -2
  165. package/src/stories/suggester/lunatic-suggester-mui.scss +27 -0
  166. package/src/stories/suggester/suggester-material-ui.js +148 -0
  167. package/src/stories/suggester/suggester-workers.stories.js +48 -1
  168. package/src/stories/suggester/suggester.stories.js +27 -1
  169. package/src/stories/switch/README.md +31 -0
  170. package/src/stories/switch/SwitchMaterialUI.js +35 -0
  171. package/src/stories/switch/data-forced.json +48 -0
  172. package/src/stories/switch/data.json +80 -0
  173. package/src/stories/switch/switch.stories.js +78 -0
  174. package/src/stories/utils/custom-lunatic.scss +28 -23
  175. package/src/stories/utils/orchestrator.js +151 -58
  176. package/src/stories/utils/waiting/index.js +1 -0
  177. package/src/stories/utils/waiting/preloader.svg +1 -0
  178. package/src/stories/utils/waiting/waiting.js +21 -0
  179. package/src/stories/utils/waiting/waiting.scss +21 -0
  180. package/src/tests/sample.spec.js +5 -0
  181. package/src/utils/icons/checkbox-checked.icon.js +25 -0
  182. package/src/utils/icons/checkbox-unchecked.icon.js +25 -0
  183. package/src/utils/icons/radio-checked.icon.js +25 -0
  184. package/src/utils/icons/radio-unchecked.icon.js +25 -0
  185. package/src/utils/lib/controls/index.js +1 -0
  186. package/src/utils/lib/controls/utils.js +146 -0
  187. package/src/utils/lib/index.js +20 -19
  188. package/src/utils/lib/pagination/navigation/shared.js +7 -4
  189. package/src/utils/lib/responses.js +9 -7
  190. package/src/utils/lib/tooltip/build-response.js +53 -41
  191. package/src/utils/store-tools/auto-load.js +2 -1
  192. package/src/utils/store-tools/create/index.js +2 -1
  193. package/src/utils/store-tools/create/update-store-info.js +26 -26
  194. package/src/utils/store-tools/index.js +7 -5
  195. package/src/utils/suggester-workers/append-to-index/create-append-task.js +3 -1
  196. package/src/utils/suggester-workers/commons-tokenizer/create-entity-tokenizer.js +56 -0
  197. package/src/utils/suggester-workers/commons-tokenizer/create-fields-tokenizer.js +56 -0
  198. package/src/utils/suggester-workers/commons-tokenizer/create-filter-stop-words.js +11 -11
  199. package/src/utils/suggester-workers/commons-tokenizer/filters/compose-filters.js +10 -0
  200. package/src/utils/suggester-workers/commons-tokenizer/filters/create-filter-stop-words.js +17 -0
  201. package/src/utils/suggester-workers/commons-tokenizer/filters/create-filter-stop-words.spec.js +14 -0
  202. package/src/utils/suggester-workers/commons-tokenizer/filters/filter-accents.js +12 -0
  203. package/src/utils/suggester-workers/commons-tokenizer/filters/filter-accents.spec.js +12 -0
  204. package/src/utils/suggester-workers/commons-tokenizer/{filter-double.js → filters/filter-double.js} +0 -0
  205. package/src/utils/suggester-workers/commons-tokenizer/filters/filter-double.spec.js +20 -0
  206. package/src/utils/suggester-workers/commons-tokenizer/{filter-length.js → filters/filter-length.js} +0 -0
  207. package/src/utils/suggester-workers/commons-tokenizer/filters/filter-length.spec.js +18 -0
  208. package/src/utils/suggester-workers/commons-tokenizer/{filter-stemmer.js → filters/filter-stemmer.js} +2 -2
  209. package/src/utils/suggester-workers/commons-tokenizer/filters/filter-stemmer.spec.js +12 -0
  210. package/src/utils/suggester-workers/commons-tokenizer/filters/filter-synonyms.js +36 -0
  211. package/src/utils/suggester-workers/commons-tokenizer/filters/filter-synonyms.spec.js +12 -0
  212. package/src/utils/suggester-workers/commons-tokenizer/filters/filter-to-lower.js +10 -0
  213. package/src/utils/suggester-workers/commons-tokenizer/filters/filter-to-lower.spec.js +12 -0
  214. package/src/utils/suggester-workers/commons-tokenizer/filters/index.js +2 -0
  215. package/src/utils/suggester-workers/commons-tokenizer/{stop-words.js → filters/stop-words.js} +0 -0
  216. package/src/utils/suggester-workers/commons-tokenizer/index.js +6 -5
  217. package/src/utils/suggester-workers/commons-tokenizer/prepare-string-indexation.js +7 -3
  218. package/src/utils/suggester-workers/commons-tokenizer/soft-tokenizer.js +1 -1
  219. package/src/utils/suggester-workers/create-worker.js +55 -0
  220. package/src/utils/suggester-workers/find-best-label/tokenize.js +2 -5
  221. package/src/utils/suggester-workers/{query-parser → searching/query-parser}/index.js +0 -0
  222. package/src/utils/suggester-workers/searching/query-parser/query-parser-soft.js +7 -0
  223. package/src/utils/suggester-workers/{query-parser → searching/query-parser}/query-parser-soft.spec.js +0 -0
  224. package/src/utils/suggester-workers/searching/query-parser/query-parser-tokenized.js +34 -0
  225. package/src/utils/suggester-workers/searching/resolve-query-parser.js +2 -2
  226. package/src/utils/suggester-workers/searching/searching.js +2 -2
  227. package/src/utils/to-expose/{calculated-variables.js → _old/calculated-variables.js} +0 -0
  228. package/src/utils/to-expose/{handler.js → _old/handler.js} +22 -0
  229. package/src/utils/to-expose/{init-questionnaire.js → _old/init-questionnaire.js} +0 -0
  230. package/src/utils/to-expose/{state.js → _old/state.js} +13 -14
  231. package/src/utils/to-expose/hooks/filter-components.js +106 -106
  232. package/src/utils/to-expose/hooks/index.js +1 -1
  233. package/src/utils/to-expose/hooks/lunatic.js +68 -7
  234. package/src/utils/to-expose/hooks/use-lunatic/actions.js +23 -0
  235. package/src/utils/to-expose/hooks/use-lunatic/commons/check-loops.js +61 -0
  236. package/src/utils/to-expose/hooks/use-lunatic/commons/create-map-pages.js +69 -0
  237. package/src/utils/to-expose/hooks/use-lunatic/commons/execute-condition-filter.js +16 -0
  238. package/src/utils/to-expose/hooks/use-lunatic/commons/execute-expression/create-execute-expression.js +182 -0
  239. package/src/utils/to-expose/hooks/use-lunatic/commons/execute-expression/create-memoizer.js +42 -0
  240. package/src/utils/to-expose/hooks/use-lunatic/commons/execute-expression/create-refresh-calculated.js +50 -0
  241. package/src/utils/to-expose/hooks/use-lunatic/commons/execute-expression/execute-expression.js +60 -0
  242. package/src/utils/to-expose/hooks/use-lunatic/commons/execute-expression/get-expressions-variables.js +22 -0
  243. package/src/utils/to-expose/hooks/use-lunatic/commons/execute-expression/index.js +1 -0
  244. package/src/utils/to-expose/hooks/use-lunatic/commons/fill-component-expressions.js +113 -0
  245. package/src/utils/to-expose/hooks/use-lunatic/commons/fill-components.js +31 -0
  246. package/src/utils/to-expose/hooks/use-lunatic/commons/get-compatible-vtl-expression.js +14 -0
  247. package/src/utils/to-expose/hooks/use-lunatic/commons/get-component-value/get-component-value.js +161 -0
  248. package/src/utils/to-expose/hooks/use-lunatic/commons/get-component-value/index.js +1 -0
  249. package/src/utils/to-expose/hooks/use-lunatic/commons/get-components-from-state.js +24 -0
  250. package/src/utils/to-expose/hooks/use-lunatic/commons/get-page-tag.js +10 -0
  251. package/src/utils/to-expose/hooks/use-lunatic/commons/index.js +12 -0
  252. package/src/utils/to-expose/hooks/use-lunatic/commons/is-First-last-page.js +8 -0
  253. package/src/utils/to-expose/hooks/use-lunatic/commons/is-paginated-loop.js +6 -0
  254. package/src/utils/to-expose/hooks/use-lunatic/commons/load-suggesters.js +59 -0
  255. package/src/utils/to-expose/hooks/use-lunatic/commons/use-components-from-state.js +20 -0
  256. package/src/utils/to-expose/hooks/use-lunatic/index.js +1 -0
  257. package/src/utils/to-expose/hooks/use-lunatic/initial-state.js +22 -0
  258. package/src/utils/to-expose/hooks/use-lunatic/reducer/commons/index.js +3 -0
  259. package/src/utils/to-expose/hooks/use-lunatic/reducer/commons/is-empty-on-empty-page.js +29 -0
  260. package/src/utils/to-expose/hooks/use-lunatic/reducer/commons/resize-array-variable.js +26 -0
  261. package/src/utils/to-expose/hooks/use-lunatic/reducer/commons/validate-loop-condition-filter.js +20 -0
  262. package/src/utils/to-expose/hooks/use-lunatic/reducer/index.js +1 -0
  263. package/src/utils/to-expose/hooks/use-lunatic/reducer/reduce-go-next-page.js +129 -0
  264. package/src/utils/to-expose/hooks/use-lunatic/reducer/reduce-go-previous-page.js +131 -0
  265. package/src/utils/to-expose/hooks/use-lunatic/reducer/reduce-handle-change/index.js +1 -0
  266. package/src/utils/to-expose/hooks/use-lunatic/reducer/reduce-handle-change/reduce-handle-change.js +69 -0
  267. package/src/utils/to-expose/hooks/use-lunatic/reducer/reduce-handle-change/reduce-variables-array.js +22 -0
  268. package/src/utils/to-expose/hooks/use-lunatic/reducer/reduce-handle-change/reduce-variables-simple.js +13 -0
  269. package/src/utils/to-expose/hooks/use-lunatic/reducer/reduce-on-init.js +166 -0
  270. package/src/utils/to-expose/hooks/use-lunatic/reducer/reduce-on-set-waiting.js +7 -0
  271. package/src/utils/to-expose/hooks/use-lunatic/reducer/reducer.js +26 -0
  272. package/src/utils/to-expose/hooks/use-lunatic/use-lunatic.js +79 -0
  273. package/src/utils/to-expose/index.js +16 -11
  274. package/src/components/button/component.js +0 -53
  275. package/src/components/checkbox/boolean.js +0 -172
  276. package/src/components/checkbox/group.js +0 -231
  277. package/src/components/checkbox/one.js +0 -11
  278. package/src/components/datepicker/component.js +0 -11
  279. package/src/components/input/input-number.js +0 -54
  280. package/src/components/missing-wrapper/wrapper.js +0 -10
  281. package/src/components/radio/component.js +0 -9
  282. package/src/components/sequence/component.js +0 -50
  283. package/src/components/subsequence/component.js +0 -49
  284. package/src/tests/components/breadcrumb.spec.js +0 -13
  285. package/src/tests/components/button.spec.js +0 -11
  286. package/src/tests/components/checkbox-boolean.spec.js +0 -45
  287. package/src/tests/components/checkbox-group.spec.js +0 -53
  288. package/src/tests/components/checkbox-one.spec.js +0 -32
  289. package/src/tests/components/datepicker.spec.js +0 -22
  290. package/src/tests/components/declarations-wrappers/input-declarations-wrapper.spec.js +0 -67
  291. package/src/tests/components/declarations-wrappers/list-declarations-wrapper.spec.js +0 -52
  292. package/src/tests/components/declarations-wrappers/simple-declarations-wrapper.spec.js +0 -21
  293. package/src/tests/components/declarations.spec.js +0 -46
  294. package/src/tests/components/input-number.spec.js +0 -194
  295. package/src/tests/components/input.spec.js +0 -18
  296. package/src/tests/components/loops/loop-static.json +0 -66
  297. package/src/tests/components/loops/loop.json +0 -258
  298. package/src/tests/components/loops/loop.spec.js +0 -30
  299. package/src/tests/components/loops/roster-for-loop.spec.js +0 -18
  300. package/src/tests/components/loops/roster-loop.json +0 -71
  301. package/src/tests/components/missing-wrapper.spec.js +0 -33
  302. package/src/tests/components/progress-bar.spec.js +0 -15
  303. package/src/tests/components/radio.spec.js +0 -27
  304. package/src/tests/components/sequence.spec.js +0 -9
  305. package/src/tests/components/subsequence.spec.js +0 -9
  306. package/src/tests/components/table.spec.js +0 -11
  307. package/src/tests/components/textarea.spec.js +0 -18
  308. package/src/tests/components/tooltip.spec.js +0 -25
  309. package/src/tests/setup/setupTests.js +0 -4
  310. package/src/tests/utils/lib/alphabet.spec.js +0 -36
  311. package/src/tests/utils/lib/array.spec.js +0 -22
  312. package/src/tests/utils/lib/checkbox/group.spec.js +0 -72
  313. package/src/tests/utils/lib/decorator/title-decorator.spec.js +0 -12
  314. package/src/tests/utils/lib/input-number.spec.js +0 -18
  315. package/src/tests/utils/lib/items-positioning.spec.js +0 -17
  316. package/src/tests/utils/lib/label-position.spec.js +0 -22
  317. package/src/tests/utils/lib/loops/bindings.spec.js +0 -75
  318. package/src/tests/utils/lib/loops/shared.spec.js +0 -82
  319. package/src/tests/utils/lib/missing/missing.spec.js +0 -74
  320. package/src/tests/utils/lib/missing/mock.js +0 -137
  321. package/src/tests/utils/lib/pagination/shared.spec.js +0 -42
  322. package/src/tests/utils/lib/responses.spec.js +0 -64
  323. package/src/tests/utils/lib/style.spec.js +0 -26
  324. package/src/tests/utils/lib/table/roster.spec.js +0 -25
  325. package/src/tests/utils/lib/tooltip/build-response.spec.js +0 -95
  326. package/src/tests/utils/lib/tooltip/content.spec.js +0 -109
  327. package/src/tests/utils/to-expose/handler/handler.spec.js +0 -94
  328. package/src/tests/utils/to-expose/handler/questionnaire.json +0 -158
  329. package/src/tests/utils/to-expose/handler/results/index.js +0 -6
  330. package/src/tests/utils/to-expose/handler/results/res-double.json +0 -158
  331. package/src/tests/utils/to-expose/handler/results/res-input-collected.json +0 -158
  332. package/src/tests/utils/to-expose/handler/results/res-input-edited.json +0 -158
  333. package/src/tests/utils/to-expose/handler/results/res-loop.json +0 -158
  334. package/src/tests/utils/to-expose/handler/results/res-matrix.json +0 -158
  335. package/src/tests/utils/to-expose/handler/results/res-responses.json +0 -158
  336. package/src/tests/utils/to-expose/hooks/use-lunatic.spec.js +0 -46
  337. package/src/tests/utils/to-expose/init-questionnaire/data.json +0 -12
  338. package/src/tests/utils/to-expose/init-questionnaire/init-questionnaire.spec.js +0 -19
  339. package/src/tests/utils/to-expose/init-questionnaire/questionnaire.json +0 -148
  340. package/src/tests/utils/to-expose/init-questionnaire/result.json +0 -181
  341. package/src/tests/utils/to-expose/interpret/interpret.spec.js +0 -48
  342. package/src/tests/utils/to-expose/state/questionnaire.json +0 -61
  343. package/src/tests/utils/to-expose/state/results.js +0 -78
  344. package/src/tests/utils/to-expose/state/state.spec.js +0 -59
  345. package/src/utils/suggester-workers/commons-tokenizer/create-tokenizer.js +0 -103
  346. package/src/utils/suggester-workers/commons-tokenizer/filter-accents-to-lower.js +0 -9
  347. package/src/utils/suggester-workers/commons-tokenizer/filter-synonyms.js +0 -10
  348. package/src/utils/suggester-workers/query-parser/query-parser-soft.js +0 -7
  349. package/src/utils/suggester-workers/query-parser/query-parser-tokenized.js +0 -31
  350. package/src/utils/suggester-workers/query-parser/query-parser-tokenized.spec.js +0 -32
@@ -1 +1 @@
1
- export { default } from './component';
1
+ export { default } from './subsequence';
@@ -0,0 +1,73 @@
1
+ import React from 'react';
2
+ import PropTypes from 'prop-types';
3
+ import { SimpleDeclarationsWrapper } from '../declarations/wrappers';
4
+ import * as U from '../../utils/lib';
5
+ import { interpret } from '../../utils/to-expose';
6
+ import {
7
+ DeclarationsBeforeText,
8
+ DeclarationsAfterText,
9
+ DeclarationsDetachable,
10
+ } from '../declarations';
11
+
12
+ // const Subsequence = ({
13
+ // id,
14
+ // label,
15
+ // declarations,
16
+ // features,
17
+ // bindings,
18
+ // style,
19
+ // logFunction,
20
+ // }) => (
21
+ // <SimpleDeclarationsWrapper
22
+ // id={id}
23
+ // declarations={declarations}
24
+ // features={features}
25
+ // bindings={bindings}
26
+ // >
27
+ // <div
28
+ // aria-label={`subsequence-${id}`}
29
+ // className="subsequence-lunatic"
30
+ // style={U.buildStyleObject(style)}
31
+ // aria-label={`subsequence-${id}`}
32
+ // >
33
+ // {interpret(features, logFunction)(bindings)(label)}
34
+ // </div>
35
+ // </SimpleDeclarationsWrapper>
36
+ // );
37
+
38
+ // Subsequence.defaultProps = {
39
+ // declarations: [],
40
+ // features: [],
41
+ // bindings: {},
42
+ // style: {},
43
+ // };
44
+
45
+ // Subsequence.propTypes = {
46
+ // id: PropTypes.string.isRequired,
47
+ // label: PropTypes.string.isRequired,
48
+ // declarations: U.declarationsPropTypes,
49
+ // features: PropTypes.arrayOf(PropTypes.string),
50
+ // bindings: PropTypes.object,
51
+ // style: PropTypes.object,
52
+ // };
53
+
54
+ // export default React.memo(Subsequence, U.areEqual);
55
+ function Subsequence({ id, declarations, label }) {
56
+ return (
57
+ <>
58
+ <DeclarationsBeforeText declarations={declarations} />
59
+ <div
60
+ aria-label={`sequence-${id}`}
61
+ className="sequence-lunatic"
62
+ // style={{}}
63
+ id={`sequence-${id}`}
64
+ >
65
+ {label}
66
+ </div>
67
+ <DeclarationsAfterText declarations={declarations} />
68
+ <DeclarationsDetachable declarations={declarations} />
69
+ </>
70
+ );
71
+ }
72
+
73
+ export default Subsequence;
@@ -1,70 +1,70 @@
1
- import React, { useEffect, useState, useCallback } from 'react';
2
- import { openDb, getEntity } from '../../utils/idb-tools';
3
- import { CONSTANTES } from '../../utils/store-tools';
4
-
5
- function CheckStore({ storeName, version, setStore, children }) {
6
- const [ready, setReady] = useState(0);
7
- const [refresh, setRefresh] = useState(false);
8
- const [disabled, setDisabled] = useState(false);
9
-
10
- const checkStore = useCallback(
11
- async function () {
12
- try {
13
- const db = await openDb(storeName, version);
14
- const info = await getEntity(db, CONSTANTES.STORE_INFO_NAME, storeName);
15
-
16
- if (db && info) {
17
- setReady(200);
18
- setStore(info);
19
- }
20
- } catch (e) {
21
- setReady(400);
22
- }
23
- },
24
- [storeName, version, setStore]
25
- );
26
-
27
- useEffect(
28
- function () {
29
- checkStore();
30
- },
31
- [checkStore]
32
- );
33
-
34
- useEffect(
35
- function () {
36
- if (refresh) {
37
- setRefresh(false);
38
- setDisabled(true);
39
- async function go() {
40
- await checkStore();
41
- setDisabled(false);
42
- }
43
-
44
- go();
45
- }
46
- },
47
- [refresh]
48
- );
49
-
50
- if (ready === 0) {
51
- return (
52
- <div className="lunatic-suggester-in-progress">
53
- Le store {storeName} est en cour de chargement.
54
- </div>
55
- );
56
- }
57
- if (ready === 200) {
58
- return children;
59
- }
60
- return (
61
- <div className="lunatic-suggester-unvailable">
62
- Le store {storeName} n'est pas disponible.
63
- <button disabled={disabled} onClick={() => setRefresh(true)}>
64
- Refresh
65
- </button>
66
- </div>
67
- );
68
- }
69
-
70
- export default CheckStore;
1
+ import React, { useEffect, useState, useCallback } from 'react';
2
+ import { openDb, getEntity } from '../../utils/idb-tools';
3
+ import { CONSTANTES } from '../../utils/store-tools';
4
+
5
+ function CheckStore({ storeName, version, setStore, children }) {
6
+ const [ready, setReady] = useState(0);
7
+ const [refresh, setRefresh] = useState(false);
8
+ const [disabled, setDisabled] = useState(false);
9
+
10
+ const checkStore = useCallback(
11
+ async function () {
12
+ try {
13
+ const db = await openDb(storeName, version);
14
+ const info = await getEntity(db, CONSTANTES.STORE_INFO_NAME, storeName);
15
+
16
+ if (db && info) {
17
+ setReady(200);
18
+ setStore(info);
19
+ }
20
+ } catch (e) {
21
+ setReady(400);
22
+ }
23
+ },
24
+ [storeName, version, setStore]
25
+ );
26
+
27
+ useEffect(
28
+ function () {
29
+ checkStore();
30
+ },
31
+ [checkStore]
32
+ );
33
+
34
+ useEffect(
35
+ function () {
36
+ if (refresh) {
37
+ setRefresh(false);
38
+ setDisabled(true);
39
+ async function go() {
40
+ await checkStore();
41
+ setDisabled(false);
42
+ }
43
+
44
+ go();
45
+ }
46
+ },
47
+ [refresh, checkStore]
48
+ );
49
+
50
+ if (ready === 0) {
51
+ return (
52
+ <div className="lunatic-suggester-in-progress">
53
+ Le store {storeName} est en cour de chargement.
54
+ </div>
55
+ );
56
+ }
57
+ if (ready === 200) {
58
+ return children;
59
+ }
60
+ return (
61
+ <div className="lunatic-suggester-unvailable">
62
+ Le store {storeName} n'est pas disponible.
63
+ <button disabled={disabled} onClick={() => setRefresh(true)}>
64
+ Refresh
65
+ </button>
66
+ </div>
67
+ );
68
+ }
69
+
70
+ export default CheckStore;
@@ -1,6 +1,5 @@
1
- import React, { useRef, useEffect } from 'react';
1
+ import React, { useRef, useEffect, useCallback } from 'react';
2
2
  import classnames from 'classnames';
3
- import { actions, SuggesterContext, useDispatch } from '../../state-management';
4
3
 
5
4
  function getMin(rect) {
6
5
  const { top } = rect;
@@ -21,15 +20,17 @@ function isVisible(optionRect, parentRect) {
21
20
  return false;
22
21
  }
23
22
 
24
- function OptionContainer({ children, index, selected }) {
23
+ function OptionContainer({ children, index, selected, onClickOption }) {
25
24
  const ref = useRef();
26
- const dispatch = useDispatch(SuggesterContext);
27
25
 
28
- function onClick(e) {
29
- e.stopPropagation();
30
- e.preventDefault();
31
- dispatch(actions.onClickOption(index));
32
- }
26
+ const onClickOptionEx = useCallback(
27
+ function (e) {
28
+ e.stopPropagation();
29
+ e.preventDefault();
30
+ onClickOption(index);
31
+ },
32
+ [onClickOption, index]
33
+ );
33
34
 
34
35
  useEffect(
35
36
  function () {
@@ -50,7 +51,7 @@ function OptionContainer({ children, index, selected }) {
50
51
  className={classnames('lunatic-suggester-option', { selected })}
51
52
  role="option"
52
53
  aria-selected={selected}
53
- onClick={onClick}
54
+ onClick={onClickOptionEx}
54
55
  ref={ref}
55
56
  >
56
57
  {children}
@@ -1,5 +1,4 @@
1
- import React, { useContext } from 'react';
2
- import { SuggesterContext } from '../../state-management';
1
+ import React from 'react';
3
2
  import PanelContainer from './panel-container';
4
3
  import OptionContainer from './option-container';
5
4
 
@@ -10,13 +9,19 @@ function getContent({
10
9
  expended,
11
10
  value,
12
11
  search,
12
+ onClickOption,
13
13
  }) {
14
14
  if (expended) {
15
15
  return options.map(function (option, index) {
16
16
  const { id } = option;
17
17
  const selected = selectedIndex === index;
18
18
  return (
19
- <OptionContainer key={id} index={index} selected={id === value}>
19
+ <OptionContainer
20
+ key={id}
21
+ index={index}
22
+ selected={id === value}
23
+ onClickOption={onClickOption}
24
+ >
20
25
  <OptionRender option={option} selected={selected} search={search} />
21
26
  </OptionContainer>
22
27
  );
@@ -25,9 +30,17 @@ function getContent({
25
30
  return undefined;
26
31
  }
27
32
 
28
- function Panel({ optionRenderer: OptionRender, value }) {
29
- const [state] = useContext(SuggesterContext);
30
- const { options, focused, selectedIndex, expended, id, search } = state;
33
+ function Panel({
34
+ optionRenderer: OptionRender,
35
+ value,
36
+ options,
37
+ focused,
38
+ selectedIndex,
39
+ expended,
40
+ id,
41
+ search,
42
+ onClickOption,
43
+ }) {
31
44
  const content = getContent({
32
45
  options,
33
46
  OptionRender,
@@ -35,6 +48,7 @@ function Panel({ optionRenderer: OptionRender, value }) {
35
48
  expended,
36
49
  value,
37
50
  search,
51
+ onClickOption,
38
52
  });
39
53
 
40
54
  return (
@@ -1,17 +1,18 @@
1
- import React, { useContext } from 'react';
1
+ import React from 'react';
2
2
  import classnames from 'classnames';
3
- import { SuggesterContext } from '../../state-management';
4
3
  import DefaultLabelRenderer from './default-label-renderer';
5
4
 
6
5
  function Label({
7
6
  labelRenderer: Renderer = DefaultLabelRenderer,
8
7
  placeholderList,
8
+ displayLabel,
9
+ expended,
10
+ selectedIndex,
11
+ options,
12
+ search,
13
+ disabled,
9
14
  }) {
10
- const [state] = useContext(SuggesterContext);
11
- const { displayLabel, expended, selectedIndex, options, search, disabled } =
12
- state;
13
15
  const displayed = displayLabel || !expended;
14
-
15
16
  const option =
16
17
  selectedIndex !== undefined ? options[selectedIndex] : undefined;
17
18
 
@@ -1,15 +1,30 @@
1
- import React, { useContext } from 'react';
2
- import { SuggesterContext, actions } from '../../state-management';
1
+ import React, { useCallback } from 'react';
3
2
  import classnames from 'classnames';
4
3
  import Label from './label';
5
4
 
6
- function Selection({ labelRenderer, placeholderList, labelledBy }, inputEl) {
7
- const [state, dispatch] = useContext(SuggesterContext);
8
- const { search, expended, id, disabled, focused } = state;
9
-
10
- function onChange(e) {
11
- dispatch(actions.onChangeSearch(e.target.value));
12
- }
5
+ function Selection(
6
+ {
7
+ labelRenderer,
8
+ placeholderList,
9
+ labelledBy,
10
+ search,
11
+ expended,
12
+ id,
13
+ disabled,
14
+ focused,
15
+ onChange,
16
+ displayLabel,
17
+ selectedIndex,
18
+ options,
19
+ },
20
+ inputEl
21
+ ) {
22
+ const onChangeEx = useCallback(
23
+ function (e) {
24
+ onChange(e.target.value);
25
+ },
26
+ [onChange]
27
+ );
13
28
 
14
29
  return (
15
30
  <div
@@ -19,6 +34,7 @@ function Selection({ labelRenderer, placeholderList, labelledBy }, inputEl) {
19
34
  disabled,
20
35
  })}
21
36
  role="combobox"
37
+ aria-controls={'todo'}
22
38
  aria-haspopup="listbox"
23
39
  aria-labelledby={labelledBy}
24
40
  aria-expanded={expended}
@@ -31,7 +47,7 @@ function Selection({ labelRenderer, placeholderList, labelledBy }, inputEl) {
31
47
  tabIndex="0"
32
48
  className="lunatic-suggester-input"
33
49
  type="text"
34
- onChange={onChange}
50
+ onChange={onChangeEx}
35
51
  value={search}
36
52
  aria-label="lunatic-suggester"
37
53
  title="suggester"
@@ -39,10 +55,19 @@ function Selection({ labelRenderer, placeholderList, labelledBy }, inputEl) {
39
55
  autoCapitalize="off"
40
56
  autoCorrect="off"
41
57
  spellCheck="false"
58
+ placeholderlist={placeholderList}
59
+ disabled={disabled}
60
+ />
61
+ <Label
62
+ labelRenderer={labelRenderer}
42
63
  placeholderList={placeholderList}
64
+ displayLabel={displayLabel}
65
+ expended={expended}
66
+ selectedIndex={selectedIndex}
67
+ options={options}
68
+ search={search}
43
69
  disabled={disabled}
44
70
  />
45
- <Label labelRenderer={labelRenderer} placeholderList={placeholderList} />
46
71
  </div>
47
72
  );
48
73
  }
@@ -1,42 +1,35 @@
1
- import React, { useRef, useCallback } from 'react';
2
- import classnames from 'classnames';
3
- import useDocumentAddEventListener from '../../../utils/to-expose/hooks/use-document-add-event-listener';
4
-
5
- function SuggesterContent({
6
- children,
7
- id,
8
- focused,
9
- onFocus,
10
- onBlur,
11
- onKeyDown,
12
- }) {
13
- const ref = useRef();
14
- const onClick = useCallback(
15
- function (e) {
16
- const { current } = ref;
17
- if (!current.contains(e.target)) {
18
- onBlur();
19
- }
20
- },
21
- [ref, onBlur]
22
- );
23
-
24
- useDocumentAddEventListener('mousedown', onClick);
25
-
26
- return (
27
- <div
28
- className={classnames('lunatic-suggester', {
29
- focused,
30
- })}
31
- onFocus={onFocus}
32
- onKeyDown={onKeyDown}
33
- ref={ref}
34
- >
35
- <div className={classnames('lunatic-suggester-content', { focused })}>
36
- {children}
37
- </div>
38
- </div>
39
- );
40
- }
41
-
42
- export default SuggesterContent;
1
+ import React, { useRef, useCallback } from 'react';
2
+ import classnames from 'classnames';
3
+ import useDocumentAddEventListener from '../../../utils/to-expose/hooks/use-document-add-event-listener';
4
+
5
+ function SuggesterContent({ children, focused, onFocus, onBlur, onKeyDown }) {
6
+ const ref = useRef();
7
+ const onClick = useCallback(
8
+ function (e) {
9
+ const { current } = ref;
10
+ if (!current.contains(e.target)) {
11
+ onBlur();
12
+ }
13
+ },
14
+ [ref, onBlur]
15
+ );
16
+
17
+ useDocumentAddEventListener('mousedown', onClick);
18
+
19
+ return (
20
+ <div
21
+ className={classnames('lunatic-suggester', {
22
+ focused,
23
+ })}
24
+ onFocus={onFocus}
25
+ onKeyDown={onKeyDown}
26
+ ref={ref}
27
+ >
28
+ <div className={classnames('lunatic-suggester-content', { focused })}>
29
+ {children}
30
+ </div>
31
+ </div>
32
+ );
33
+ }
34
+
35
+ export default SuggesterContent;
@@ -1,11 +1,10 @@
1
1
  import React, { useCallback, useContext, useRef, useMemo } from 'react';
2
2
  import classnames from 'classnames';
3
- import { actions, SuggesterContext } from '../state-management';
4
3
  import SuggesterContent from './suggester-content';
5
4
  import Selection from './selection';
6
5
  import Panel from './panel';
7
- import createOnKeyDownCallback from './create-on-keydown-callback';
8
6
  import Delete from './selection/delete';
7
+ import { createCustomizableLunaticField } from '../../commons';
9
8
  import './suggester.scss';
10
9
 
11
10
  function Suggester({
@@ -15,43 +14,44 @@ function Suggester({
15
14
  optionRenderer,
16
15
  labelRenderer,
17
16
  onSelect,
17
+ onBlur,
18
+ onDelete,
19
+ onKeyDown,
20
+ onChange,
21
+ onClickOption,
18
22
  value,
23
+ onFocus,
24
+ disabled,
25
+ id,
26
+ messageError,
27
+ search,
28
+ focused,
29
+ options,
30
+ expended,
31
+ selectedIndex,
32
+ displayLabel,
19
33
  }) {
20
34
  const inputEl = useRef();
21
- const [state, dispatch] = useContext(SuggesterContext);
22
- const { focused, id, messageError, search, disabled } = state;
23
35
 
24
- const onFocus = useCallback(
36
+ const onFocusEx = useCallback(
25
37
  function () {
26
38
  if (!disabled) {
27
39
  if (inputEl.current !== document.activeElement) {
28
40
  }
29
41
  inputEl.current.focus();
30
- dispatch(actions.onFocus());
42
+ onFocus();
31
43
  }
32
44
  },
33
- [dispatch, disabled]
45
+ [disabled, onFocus]
34
46
  );
35
47
 
36
- const onDelete = useCallback(
37
- function () {
38
- dispatch(actions.onDeleteSearch());
39
- onSelect(undefined);
40
- },
41
- [dispatch, onSelect]
42
- );
43
-
44
- const onBlur = useCallback(
48
+ const onBlurEx = useCallback(
45
49
  function () {
46
50
  if (focused) {
47
- dispatch(actions.onBlur());
51
+ onBlur();
48
52
  }
49
53
  },
50
- [dispatch, focused]
51
- );
52
- const onKeyDown = useMemo(
53
- () => createOnKeyDownCallback(dispatch),
54
- [dispatch]
54
+ [focused, onBlur]
55
55
  );
56
56
 
57
57
  if (messageError) {
@@ -64,8 +64,8 @@ function Suggester({
64
64
  <SuggesterContent
65
65
  id={id}
66
66
  focused={focused}
67
- onFocus={onFocus}
68
- onBlur={onBlur}
67
+ onFocus={onFocusEx}
68
+ onBlur={onBlurEx}
69
69
  onKeyDown={onKeyDown}
70
70
  >
71
71
  <Selection
@@ -73,8 +73,27 @@ function Suggester({
73
73
  placeholderList={placeholderList}
74
74
  labelledBy={labelledBy}
75
75
  ref={inputEl}
76
+ search={search}
77
+ expended={expended}
78
+ id={id}
79
+ disabled={disabled}
80
+ focused={focused}
81
+ displayLabel={displayLabel}
82
+ selectedIndex={selectedIndex}
83
+ options={options}
84
+ onChange={onChange}
85
+ />
86
+ <Panel
87
+ optionRenderer={optionRenderer}
88
+ value={value}
89
+ options={options}
90
+ focused={focused}
91
+ selectedIndex={selectedIndex}
92
+ expended={expended}
93
+ id={id}
94
+ search={search}
95
+ onClickOption={onClickOption}
76
96
  />
77
- <Panel optionRenderer={optionRenderer} value={value} />
78
97
  </SuggesterContent>
79
98
  <Delete
80
99
  className={classnames({ focused })}
@@ -85,4 +104,4 @@ function Suggester({
85
104
  );
86
105
  }
87
106
 
88
- export default Suggester;
107
+ export default createCustomizableLunaticField(React.memo(Suggester));
@@ -1,28 +1,28 @@
1
- import { actions } from '../state-management';
2
- import { BINDED_KEYS } from '../commons-tools';
3
-
4
- function create(dispatch) {
5
- return function (e) {
6
- const { key } = e;
7
- switch (key) {
8
- case BINDED_KEYS.Tab:
9
- e.stopPropagation();
10
- // e.preventDefault();
11
- dispatch(actions.onKeyDown(key));
12
- break;
13
- case BINDED_KEYS.ArrowDown:
14
- case BINDED_KEYS.ArrowUp:
15
- case BINDED_KEYS.Home:
16
- case BINDED_KEYS.End:
17
- case BINDED_KEYS.Enter:
18
- case BINDED_KEYS.Escape:
19
- e.preventDefault();
20
- e.stopPropagation();
21
- dispatch(actions.onKeyDown(key));
22
- break;
23
- default:
24
- }
25
- };
26
- }
27
-
28
- export default create;
1
+ import { actions } from './state-management';
2
+ import { BINDED_KEYS } from './commons-tools';
3
+
4
+ function create(dispatch) {
5
+ return function (e) {
6
+ const { key } = e;
7
+ switch (key) {
8
+ case BINDED_KEYS.Tab:
9
+ e.stopPropagation();
10
+ // e.preventDefault();
11
+ dispatch(actions.onKeyDown(key));
12
+ break;
13
+ case BINDED_KEYS.ArrowDown:
14
+ case BINDED_KEYS.ArrowUp:
15
+ case BINDED_KEYS.Home:
16
+ case BINDED_KEYS.End:
17
+ case BINDED_KEYS.Enter:
18
+ case BINDED_KEYS.Escape:
19
+ e.preventDefault();
20
+ e.stopPropagation();
21
+ dispatch(actions.onKeyDown(key));
22
+ break;
23
+ default:
24
+ }
25
+ };
26
+ }
27
+
28
+ export default create;
@@ -1,3 +1,5 @@
1
+ import { createWorker } from '../../../utils/suggester-workers/create-worker';
2
+
1
3
  const WORKER_PATH =
2
4
  process.env.LUNATIC_LABEL_WORKER_PATH ||
3
5
  process.env.REACT_APP_LUNATIC_LABEL_WORKER_PATH;
@@ -15,7 +17,7 @@ function getIdTask() {
15
17
 
16
18
  function getWorker() {
17
19
  if (!WORKER) {
18
- WORKER = new Worker(WORKER_PATH);
20
+ WORKER = createWorker(WORKER_PATH);
19
21
  WORKER.addEventListener('message', function (e) {
20
22
  const { data } = e;
21
23
  const { response, idTask } = data;