@inseefr/lunatic 0.1.7 → 0.1.8-experimental

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 (427) hide show
  1. package/README.md +15 -2
  2. package/lib/index.js +2818 -596
  3. package/lib/index.js.map +1 -1
  4. package/package.json +87 -52
  5. package/src/components/breadcrumb/breadcrumb.scss +20 -0
  6. package/src/components/breadcrumb/component.js +29 -0
  7. package/src/components/breadcrumb/index.js +1 -0
  8. package/src/components/button/button.scss +11 -10
  9. package/src/components/button/component.js +43 -16
  10. package/src/components/checkbox/boolean.js +158 -45
  11. package/src/components/checkbox/checkbox.scss +55 -20
  12. package/src/components/checkbox/group.js +231 -0
  13. package/src/components/checkbox/index.js +1 -0
  14. package/src/components/checkbox/one.js +8 -90
  15. package/src/components/components.js +18 -0
  16. package/src/components/datepicker/component.js +11 -0
  17. package/src/components/datepicker/datepicker.scss +1 -0
  18. package/src/components/datepicker/index.js +1 -0
  19. package/src/components/declarations/component.js +45 -0
  20. package/src/components/declarations/declarations.scss +38 -0
  21. package/src/components/declarations/index.js +1 -0
  22. package/src/components/declarations/wrappers/index.js +3 -0
  23. package/src/components/declarations/wrappers/input-declarations-wrapper.js +269 -0
  24. package/src/components/declarations/wrappers/list-declarations-wrapper.js +232 -0
  25. package/src/components/declarations/wrappers/simple-declarations-wrapper.js +54 -0
  26. package/src/components/dropdown/commons/actions.js +56 -0
  27. package/src/components/dropdown/commons/children-to-option.js +9 -0
  28. package/src/components/dropdown/commons/cleaner-callbacks.js +58 -0
  29. package/src/components/dropdown/commons/components/dropdown-container.js +29 -0
  30. package/src/components/dropdown/commons/components/dropdown-field.js +46 -0
  31. package/src/components/dropdown/commons/components/dropdown.js +183 -0
  32. package/src/components/dropdown/commons/components/label.js +28 -0
  33. package/src/components/dropdown/commons/components/panel.js +78 -0
  34. package/src/components/dropdown/commons/event-callbacks/index.js +5 -0
  35. package/src/components/dropdown/commons/event-callbacks/on-keydown-callback.js +29 -0
  36. package/src/components/dropdown/commons/event-callbacks/on-mousedown-callback.js +11 -0
  37. package/src/components/dropdown/commons/reducer.js +149 -0
  38. package/src/components/dropdown/commons/tools/index.js +17 -0
  39. package/src/components/dropdown/component.js +128 -0
  40. package/src/components/dropdown/dropdown-edit/dropdown-edit.js +190 -0
  41. package/src/components/dropdown/dropdown-edit/icone.js +33 -0
  42. package/src/components/dropdown/dropdown-edit/index.js +11 -0
  43. package/src/components/dropdown/dropdown-edit/option.js +62 -0
  44. package/src/components/dropdown/dropdown-edit/prefix-tools.js +51 -0
  45. package/src/components/dropdown/dropdown-simple/dropdown.js +162 -0
  46. package/src/components/dropdown/dropdown-simple/index.js +20 -0
  47. package/src/components/dropdown/dropdown-simple/option.js +15 -0
  48. package/src/components/dropdown/dropdown.scss +176 -0
  49. package/src/components/dropdown/index.js +1 -0
  50. package/src/components/filter-description/component.js +42 -0
  51. package/src/components/filter-description/index.js +1 -0
  52. package/src/components/icon/assets/checkbox-checked.js +16 -0
  53. package/src/components/icon/assets/checkbox-unchecked.js +16 -0
  54. package/src/components/icon/assets/index.js +4 -0
  55. package/src/components/icon/assets/radio-checked.js +16 -0
  56. package/src/components/icon/assets/radio-unchecked.js +16 -0
  57. package/src/components/icon/component.js +33 -0
  58. package/src/components/icon/icon.scss +13 -0
  59. package/src/components/icon/index.js +1 -0
  60. package/src/components/index.js +3 -5
  61. package/src/components/index.scss +134 -12
  62. package/src/components/input/index.js +1 -0
  63. package/src/components/input/input-number.js +41 -106
  64. package/src/components/input/input.js +11 -0
  65. package/src/components/input/input.scss +30 -24
  66. package/src/components/loop/component.js +258 -0
  67. package/src/components/loop/index.js +1 -0
  68. package/src/components/loop/loop.scss +11 -0
  69. package/src/components/loop/wrapper.js +15 -0
  70. package/src/components/loop-constructor/block/block.scss +8 -0
  71. package/src/components/loop-constructor/block/component.js +9 -0
  72. package/src/components/loop-constructor/block/index.js +1 -0
  73. package/src/components/loop-constructor/index.js +1 -0
  74. package/src/components/loop-constructor/roster/component.js +8 -0
  75. package/src/components/loop-constructor/roster/index.js +1 -0
  76. package/src/components/loop-constructor/wrapper/body-component.js +122 -0
  77. package/src/components/loop-constructor/wrapper/build-components.js +33 -0
  78. package/src/components/loop-constructor/wrapper/component.js +189 -0
  79. package/src/components/loop-constructor/wrapper/index.js +1 -0
  80. package/src/components/missing-wrapper/component.js +119 -0
  81. package/src/components/missing-wrapper/index.js +1 -0
  82. package/src/components/missing-wrapper/missing.scss +30 -0
  83. package/src/components/missing-wrapper/wrapper.js +10 -0
  84. package/src/components/progress-bar/component.js +28 -0
  85. package/src/components/progress-bar/index.js +1 -0
  86. package/src/components/progress-bar/progress-bar.scss +52 -0
  87. package/src/components/radio/component.js +9 -0
  88. package/src/components/radio/index.js +1 -0
  89. package/src/components/radio/radio.scss +57 -0
  90. package/src/components/sequence/component.js +36 -13
  91. package/src/components/sequence/sequence.scss +6 -13
  92. package/src/components/subsequence/component.js +36 -14
  93. package/src/components/suggester/check-store.js +70 -0
  94. package/src/components/suggester/commons-tools/binded-keys.js +11 -0
  95. package/src/components/suggester/commons-tools/index.js +1 -0
  96. package/src/components/suggester/components/create-on-keydown-callback.js +28 -0
  97. package/src/components/suggester/components/index.js +2 -0
  98. package/src/components/suggester/components/panel/default-option-renderer.js +19 -0
  99. package/src/components/suggester/components/panel/index.js +2 -0
  100. package/src/components/suggester/components/panel/option-container.js +63 -0
  101. package/src/components/suggester/components/panel/panel-container.js +21 -0
  102. package/src/components/suggester/components/panel/panel.js +33 -0
  103. package/src/components/suggester/components/selection/default-label-renderer.js +31 -0
  104. package/src/components/suggester/components/selection/delete.js +38 -0
  105. package/src/components/suggester/components/selection/index.js +1 -0
  106. package/src/components/suggester/components/selection/label.js +31 -0
  107. package/src/components/suggester/components/selection/selection.js +50 -0
  108. package/src/components/suggester/components/suggester-content.js +42 -0
  109. package/src/components/suggester/components/suggester.js +87 -0
  110. package/src/components/suggester/components/suggester.scss +100 -0
  111. package/src/components/suggester/default-style.scss +122 -0
  112. package/src/components/suggester/idb-suggester.js +74 -0
  113. package/src/components/suggester/index.js +1 -0
  114. package/src/components/suggester/lunatic-suggester.js +148 -0
  115. package/src/components/suggester/searching/index.js +1 -0
  116. package/src/components/suggester/searching/searching.js +39 -0
  117. package/src/components/suggester/state-management/actions.js +35 -0
  118. package/src/components/suggester/state-management/index.js +6 -0
  119. package/src/components/suggester/state-management/intial-state.js +13 -0
  120. package/src/components/suggester/state-management/reducer/index.js +1 -0
  121. package/src/components/suggester/state-management/reducer/reduce-on-blur.js +5 -0
  122. package/src/components/suggester/state-management/reducer/reduce-on-change-search.js +8 -0
  123. package/src/components/suggester/state-management/reducer/reduce-on-click-option.js +8 -0
  124. package/src/components/suggester/state-management/reducer/reduce-on-error.js +8 -0
  125. package/src/components/suggester/state-management/reducer/reduce-on-focus.js +5 -0
  126. package/src/components/suggester/state-management/reducer/reduce-on-init.js +11 -0
  127. package/src/components/suggester/state-management/reducer/reduce-on-key-down.js +73 -0
  128. package/src/components/suggester/state-management/reducer/reduce-on-unexpected-error.js +7 -0
  129. package/src/components/suggester/state-management/reducer/reduce-on-update-options.js +11 -0
  130. package/src/components/suggester/state-management/reducer/reducer.js +35 -0
  131. package/src/components/suggester/state-management/suggester-context.js +4 -0
  132. package/src/components/suggester/state-management/use-dispatch.js +11 -0
  133. package/src/components/suggester/suggester-wrapper.js +101 -0
  134. package/src/components/suggester-loader-widget/create-append-task.js +43 -0
  135. package/src/components/suggester-loader-widget/index.js +1 -0
  136. package/src/components/suggester-loader-widget/loader-row.js +102 -0
  137. package/src/components/suggester-loader-widget/loader.js +67 -0
  138. package/src/components/suggester-loader-widget/progress.js +25 -0
  139. package/src/components/suggester-loader-widget/tools/action-tool.js +20 -0
  140. package/src/components/suggester-loader-widget/tools/index.js +2 -0
  141. package/src/components/suggester-loader-widget/tools/tools.js +7 -0
  142. package/src/components/suggester-loader-widget/widget-container.js +35 -0
  143. package/src/components/suggester-loader-widget/widget.js +125 -0
  144. package/src/components/suggester-loader-widget/widget.scss +176 -0
  145. package/src/components/table/index.js +1 -0
  146. package/src/components/table/table.js +171 -0
  147. package/src/components/table/table.scss +24 -0
  148. package/src/components/textarea/component.js +11 -0
  149. package/src/components/textarea/index.js +1 -0
  150. package/src/components/textarea/textarea.scss +6 -0
  151. package/src/components/tooltip/img/edited.png +0 -0
  152. package/src/components/tooltip/img/forced.png +0 -0
  153. package/src/components/tooltip/img/index.js +4 -0
  154. package/src/components/tooltip/index.js +1 -0
  155. package/src/components/tooltip/response.js +52 -0
  156. package/src/components/tooltip/tooltip.scss +27 -0
  157. package/src/constants/component-types.js +1 -0
  158. package/src/constants/declarations.js +14 -0
  159. package/src/constants/event-types.js +13 -0
  160. package/src/constants/index.js +5 -0
  161. package/src/constants/supported-preferences.js +10 -0
  162. package/src/constants/value-types.js +5 -0
  163. package/src/constants/variable-types.js +4 -0
  164. package/src/stories/breadcrumb/README.md +14 -0
  165. package/src/stories/breadcrumb/breadcrumb.stories.js +19 -0
  166. package/src/stories/button/button.stories.js +3 -39
  167. package/src/stories/checkbox-boolean/README.md +19 -12
  168. package/src/stories/checkbox-boolean/checkbox-boolean.stories.js +39 -19
  169. package/src/stories/checkbox-boolean/data-forced.json +48 -0
  170. package/src/stories/checkbox-boolean/data.json +78 -0
  171. package/src/stories/checkbox-group/README.md +29 -0
  172. package/src/stories/checkbox-group/checkbox-group.stories.js +60 -0
  173. package/src/stories/checkbox-group/data-forced.json +89 -0
  174. package/src/stories/checkbox-group/data-vtl.json +102 -0
  175. package/src/stories/checkbox-group/data.json +89 -0
  176. package/src/stories/checkbox-one/README.md +21 -12
  177. package/src/stories/checkbox-one/checkbox-one.stories.js +41 -80
  178. package/src/stories/checkbox-one/data-forced.json +33 -0
  179. package/src/stories/checkbox-one/data-vtl.json +48 -0
  180. package/src/stories/checkbox-one/data.json +33 -0
  181. package/src/stories/datepicker/README.md +31 -0
  182. package/src/stories/datepicker/data-forced.json +28 -0
  183. package/src/stories/datepicker/data.json +43 -0
  184. package/src/stories/datepicker/datepicker.stories.js +60 -0
  185. package/src/stories/declarations/README.md +19 -0
  186. package/src/stories/declarations/declarations.stories.js +112 -0
  187. package/src/stories/dropdown/README.md +44 -0
  188. package/src/stories/dropdown/data-forced.json +81 -0
  189. package/src/stories/dropdown/data-naf.json +6963 -0
  190. package/src/stories/dropdown/data-props.json +111 -0
  191. package/src/stories/dropdown/data.json +78 -0
  192. package/src/stories/dropdown/dropdown.stories.js +89 -0
  193. package/src/stories/filter-description/README.md +15 -0
  194. package/src/stories/filter-description/filter-description.stories.js +53 -0
  195. package/src/stories/icons/icons.stories.js +16 -0
  196. package/src/stories/icons/lunatic-icon.scss +10 -0
  197. package/src/stories/input/README.md +33 -0
  198. package/src/stories/input/data-forced.json +41 -0
  199. package/src/stories/input/data.json +41 -0
  200. package/src/stories/input/input.stories.js +72 -0
  201. package/src/stories/input-number/README.md +30 -15
  202. package/src/stories/input-number/data-forced.json +27 -0
  203. package/src/stories/input-number/data.json +42 -0
  204. package/src/stories/input-number/input-number.stories.js +52 -48
  205. package/src/stories/loop/README.md +25 -0
  206. package/src/stories/loop/loop.stories.js +88 -0
  207. package/src/stories/loop/with-loop/data-loop-deeper.json +298 -0
  208. package/src/stories/loop/with-loop/data-loop.json +336 -0
  209. package/src/stories/loop/with-loop/index.js +2 -0
  210. package/src/stories/loop/with-roster/data-forced.json +213 -0
  211. package/src/stories/loop/with-roster/data-loop-deeper.json +298 -0
  212. package/src/stories/loop/with-roster/data-loop.json +288 -0
  213. package/src/stories/loop/with-roster/index.js +3 -0
  214. package/src/stories/loop-constructor/README.md +27 -0
  215. package/src/stories/loop-constructor/data-input-forced.json +64 -0
  216. package/src/stories/loop-constructor/data-input.json +100 -0
  217. package/src/stories/loop-constructor/data-loop-forced.json +66 -0
  218. package/src/stories/loop-constructor/data-loop-static-forced.json +66 -0
  219. package/src/stories/loop-constructor/data-loop-static.json +81 -0
  220. package/src/stories/loop-constructor/data-loop.json +81 -0
  221. package/src/stories/loop-constructor/data-roster-forced.json +68 -0
  222. package/src/stories/loop-constructor/data-roster.json +83 -0
  223. package/src/stories/loop-constructor/loop-constructor.stories.js +180 -0
  224. package/src/stories/pagination/deeper-loop.json +327 -0
  225. package/src/stories/pagination/pagination.stories.js +60 -0
  226. package/src/stories/pagination/simple-loop.json +277 -0
  227. package/src/stories/pagination/simpsons-question.json +4952 -0
  228. package/src/stories/pagination/simpsons-sequence.json +4362 -0
  229. package/src/stories/progress-bar/README.md +13 -0
  230. package/src/stories/progress-bar/progress-bar.stories.js +24 -0
  231. package/src/stories/questionnaire/arithmetic.json +254 -0
  232. package/src/stories/questionnaire/calc-var.json +187 -0
  233. package/src/stories/questionnaire/logement.json +23402 -0
  234. package/src/stories/questionnaire/questionnaire.stories.js +119 -0
  235. package/src/stories/questionnaire/simpsons.json +4816 -0
  236. package/src/stories/radio/README.md +31 -0
  237. package/src/stories/radio/data-forced.json +32 -0
  238. package/src/stories/radio/data-vtl.json +47 -0
  239. package/src/stories/radio/data.json +32 -0
  240. package/src/stories/radio/radio.stories.js +64 -0
  241. package/src/stories/sequence/README.md +10 -5
  242. package/src/stories/sequence/sequence.stories.js +8 -26
  243. package/src/stories/subsequence/README.md +10 -5
  244. package/src/stories/subsequence/subsequence.stories.js +8 -26
  245. package/src/stories/suggester/README.md +29 -0
  246. package/src/stories/suggester/cog-communes/fetch-cog.js +11 -0
  247. package/src/stories/suggester/cog-communes/index.js +2 -0
  248. package/src/stories/suggester/cog-communes/option-cog-renderer.js +15 -0
  249. package/src/stories/suggester/cog-communes/theme.scss +12 -0
  250. package/src/stories/suggester/data-auto.json +231 -0
  251. package/src/stories/suggester/data-vtl.json +82 -0
  252. package/src/stories/suggester/data.json +83 -0
  253. package/src/stories/suggester/naf-rev2/fetch-naf.js +57 -0
  254. package/src/stories/suggester/naf-rev2/index.js +2 -0
  255. package/src/stories/suggester/naf-rev2/option-renderer.js +17 -0
  256. package/src/stories/suggester/naf-rev2/theme.scss +36 -0
  257. package/src/stories/suggester/suggester.stories.js +128 -0
  258. package/src/stories/table/README.md +29 -0
  259. package/src/stories/table/data-default.json +19 -0
  260. package/src/stories/table/data-one-axis-one-measure.json +139 -0
  261. package/src/stories/table/data-one-axis-two-measures.json +208 -0
  262. package/src/stories/table/data-one-hierarchical-axis.json +219 -0
  263. package/src/stories/table/data-roster.json +486 -0
  264. package/src/stories/table/data-two-axis-one-measure.json +507 -0
  265. package/src/stories/table/table.stories.js +82 -0
  266. package/src/stories/textarea/README.md +33 -0
  267. package/src/stories/textarea/data-forced.json +28 -0
  268. package/src/stories/textarea/data.json +43 -0
  269. package/src/stories/textarea/textarea.stories.js +68 -0
  270. package/src/stories/tooltip-response/README.md +14 -0
  271. package/src/stories/tooltip-response/md-link.json +31 -0
  272. package/src/stories/tooltip-response/md-tooltip.json +31 -0
  273. package/src/stories/tooltip-response/tooltip.stories.js +83 -0
  274. package/src/stories/utils/custom-lunatic.scss +23 -0
  275. package/src/stories/utils/img/arrow.png +0 -0
  276. package/src/stories/utils/img/check_box.svg +1 -0
  277. package/src/stories/utils/img/check_box_outline.svg +1 -0
  278. package/src/stories/utils/img/lunatic-logo.png +0 -0
  279. package/src/stories/utils/img/menu-down.svg +1 -0
  280. package/src/stories/utils/img/menu-up.svg +1 -0
  281. package/src/stories/utils/img/radio_button_checked.svg +1 -0
  282. package/src/stories/utils/img/radio_button_unchecked.svg +1 -0
  283. package/src/stories/utils/options.js +25 -0
  284. package/src/stories/utils/orchestrator.js +108 -0
  285. package/src/tests/components/breadcrumb.spec.js +13 -0
  286. package/src/tests/components/checkbox-boolean.spec.js +28 -40
  287. package/src/tests/components/checkbox-group.spec.js +53 -0
  288. package/src/tests/components/checkbox-one.spec.js +21 -39
  289. package/src/tests/components/datepicker.spec.js +22 -0
  290. package/src/tests/components/declarations-wrappers/input-declarations-wrapper.spec.js +67 -0
  291. package/src/tests/components/declarations-wrappers/list-declarations-wrapper.spec.js +52 -0
  292. package/src/tests/components/declarations-wrappers/simple-declarations-wrapper.spec.js +21 -0
  293. package/src/tests/components/declarations.spec.js +46 -0
  294. package/src/tests/components/input-number.spec.js +136 -37
  295. package/src/tests/components/input.spec.js +18 -0
  296. package/src/tests/components/loops/loop-static.json +66 -0
  297. package/src/tests/components/loops/loop.json +258 -0
  298. package/src/tests/components/loops/loop.spec.js +30 -0
  299. package/src/tests/components/loops/roster-for-loop.spec.js +18 -0
  300. package/src/tests/components/loops/roster-loop.json +69 -0
  301. package/src/tests/components/missing-wrapper.spec.js +33 -0
  302. package/src/tests/components/progress-bar.spec.js +15 -0
  303. package/src/tests/components/radio.spec.js +27 -0
  304. package/src/tests/components/table.spec.js +11 -0
  305. package/src/tests/components/textarea.spec.js +18 -0
  306. package/src/tests/components/tooltip.spec.js +25 -0
  307. package/src/tests/setup/setupTests.js +1 -1
  308. package/src/tests/utils/lib/alphabet.spec.js +36 -0
  309. package/src/tests/utils/lib/array.spec.js +22 -0
  310. package/src/tests/utils/lib/checkbox/group.spec.js +72 -0
  311. package/src/tests/utils/{decorator → lib/decorator}/title-decorator.spec.js +1 -1
  312. package/src/tests/utils/lib/input-number.spec.js +18 -0
  313. package/src/tests/utils/{items-positioning.spec.js → lib/items-positioning.spec.js} +3 -3
  314. package/src/tests/utils/{label-position.spec.js → lib/label-position.spec.js} +6 -3
  315. package/src/tests/utils/lib/loops/bindings.spec.js +75 -0
  316. package/src/tests/utils/lib/loops/shared.spec.js +82 -0
  317. package/src/tests/utils/lib/missing/missing.spec.js +74 -0
  318. package/src/tests/utils/lib/missing/mock.js +137 -0
  319. package/src/tests/utils/lib/pagination/shared.spec.js +42 -0
  320. package/src/tests/utils/lib/responses.spec.js +64 -0
  321. package/src/tests/utils/{string-utils.spec.js → lib/style.spec.js} +6 -6
  322. package/src/tests/utils/lib/table/roster.spec.js +25 -0
  323. package/src/tests/utils/lib/tooltip/build-response.spec.js +95 -0
  324. package/src/tests/utils/lib/tooltip/content.spec.js +109 -0
  325. package/src/tests/utils/to-expose/handler/handler.spec.js +94 -0
  326. package/src/tests/utils/to-expose/handler/questionnaire.json +158 -0
  327. package/src/tests/utils/to-expose/handler/results/index.js +6 -0
  328. package/src/tests/utils/to-expose/handler/results/res-double.json +158 -0
  329. package/src/tests/utils/to-expose/handler/results/res-input-collected.json +158 -0
  330. package/src/tests/utils/to-expose/handler/results/res-input-edited.json +158 -0
  331. package/src/tests/utils/to-expose/handler/results/res-loop.json +158 -0
  332. package/src/tests/utils/to-expose/handler/results/res-matrix.json +158 -0
  333. package/src/tests/utils/to-expose/handler/results/res-responses.json +158 -0
  334. package/src/tests/utils/to-expose/hooks/use-lunatic.spec.js +46 -0
  335. package/src/tests/utils/to-expose/init-questionnaire/data.json +12 -0
  336. package/src/tests/utils/to-expose/init-questionnaire/init-questionnaire.spec.js +19 -0
  337. package/src/tests/utils/to-expose/init-questionnaire/questionnaire.json +141 -0
  338. package/src/tests/utils/to-expose/init-questionnaire/result.json +174 -0
  339. package/src/tests/utils/to-expose/interpret/interpret.spec.js +48 -0
  340. package/src/tests/utils/to-expose/state/questionnaire.json +61 -0
  341. package/src/tests/utils/to-expose/state/results.js +78 -0
  342. package/src/tests/utils/to-expose/state/state.spec.js +59 -0
  343. package/src/utils/components/dragger/dragger.js +64 -0
  344. package/src/utils/components/dragger/dragger.scss +8 -0
  345. package/src/utils/components/dragger/index.js +1 -0
  346. package/src/utils/components/fab/fab.js +50 -0
  347. package/src/utils/components/fab/fab.scss +32 -0
  348. package/src/utils/components/fab/index.js +1 -0
  349. package/src/utils/components/field-wrapper.js +23 -0
  350. package/src/utils/components/is-network/index.js +1 -0
  351. package/src/utils/components/is-network/is-network.js +39 -0
  352. package/src/utils/components/is-network/use-online-status.js +51 -0
  353. package/src/utils/components/label-wrapper.js +45 -0
  354. package/src/utils/icons/closed.icon.js +24 -0
  355. package/src/utils/icons/cross.icon.js +24 -0
  356. package/src/utils/icons/load.icon.js +24 -0
  357. package/src/utils/icons/lunatic-icon.js +9 -0
  358. package/src/utils/icons/lunatic-icon.scss +4 -0
  359. package/src/utils/icons/network.icon.js +24 -0
  360. package/src/utils/icons/on-drag.icon.js +24 -0
  361. package/src/utils/icons/opened.icon.js +24 -0
  362. package/src/utils/idb-tools/clear-store.js +16 -0
  363. package/src/utils/idb-tools/get-entity.js +15 -0
  364. package/src/utils/idb-tools/get-idb.js +12 -0
  365. package/src/utils/idb-tools/index.js +4 -0
  366. package/src/utils/idb-tools/open-db.js +32 -0
  367. package/src/utils/lib/alphabet.js +1 -0
  368. package/src/utils/lib/array.js +7 -0
  369. package/src/utils/lib/checkbox/group.js +21 -0
  370. package/src/utils/lib/checkbox/index.js +1 -0
  371. package/src/utils/lib/decorator/index.js +1 -0
  372. package/src/utils/lib/decorator/title-decorator.js +16 -0
  373. package/src/utils/lib/env.js +2 -0
  374. package/src/utils/lib/event.js +15 -0
  375. package/src/utils/lib/function.js +1 -0
  376. package/src/utils/lib/index.js +19 -0
  377. package/src/utils/lib/input-number.js +6 -0
  378. package/src/utils/{label-position.js → lib/label-position.js} +4 -4
  379. package/src/utils/lib/loops/bindings.js +66 -0
  380. package/src/utils/lib/loops/build-components.js +33 -0
  381. package/src/utils/lib/loops/index.js +3 -0
  382. package/src/utils/lib/loops/shared.js +55 -0
  383. package/src/utils/lib/memo-check.js +24 -0
  384. package/src/utils/lib/missing.js +52 -0
  385. package/src/utils/{items-positioning.js → lib/options-positioning.js} +1 -1
  386. package/src/utils/lib/pagination/flow.js +2 -0
  387. package/src/utils/lib/pagination/index.js +2 -0
  388. package/src/utils/lib/pagination/navigation/index.js +1 -0
  389. package/src/utils/lib/pagination/navigation/shared.js +108 -0
  390. package/src/utils/lib/prop-types/declarations.js +22 -0
  391. package/src/utils/lib/prop-types/index.js +5 -0
  392. package/src/utils/lib/prop-types/lines.js +6 -0
  393. package/src/utils/lib/prop-types/options.js +8 -0
  394. package/src/utils/lib/prop-types/response.js +6 -0
  395. package/src/utils/lib/prop-types/value-type.js +9 -0
  396. package/src/utils/lib/responses.js +9 -0
  397. package/src/utils/{string-utils.js → lib/style.js} +0 -0
  398. package/src/utils/lib/table/index.js +1 -0
  399. package/src/utils/lib/table/roster.js +23 -0
  400. package/src/utils/lib/tooltip/build-response.js +41 -0
  401. package/src/utils/lib/tooltip/content.js +55 -0
  402. package/src/utils/lib/tooltip/index.js +6 -0
  403. package/src/utils/store-tools/auto-load.js +72 -0
  404. package/src/utils/store-tools/clear-store-data.js +8 -0
  405. package/src/utils/store-tools/clear-store-info.js +8 -0
  406. package/src/utils/store-tools/constantes.js +20 -0
  407. package/src/utils/store-tools/create/create.js +19 -0
  408. package/src/utils/store-tools/create/index.js +1 -0
  409. package/src/utils/store-tools/create/update-store-info.js +26 -0
  410. package/src/utils/store-tools/get-store-count.js +22 -0
  411. package/src/utils/store-tools/index.js +5 -0
  412. package/src/utils/store-tools/open-or-create-store.js +47 -0
  413. package/src/utils/store-tools/use-store-index.js +24 -0
  414. package/src/utils/to-expose/handler.js +137 -0
  415. package/src/utils/to-expose/hooks/filter-components.js +106 -0
  416. package/src/utils/to-expose/hooks/index.js +1 -0
  417. package/src/utils/to-expose/hooks/lunatic.js +191 -0
  418. package/src/utils/to-expose/hooks/use-document-add-event-listener.js +63 -0
  419. package/src/utils/to-expose/index.js +11 -0
  420. package/src/utils/to-expose/init-questionnaire.js +223 -0
  421. package/src/utils/to-expose/interpret/index.js +1 -0
  422. package/src/utils/to-expose/interpret/main.js +16 -0
  423. package/src/utils/to-expose/interpret/md.js +65 -0
  424. package/src/utils/to-expose/interpret/vtl.js +18 -0
  425. package/src/utils/to-expose/state.js +58 -0
  426. package/src/components/subsequence/subsequence.scss +0 -15
  427. package/src/utils/decorator/title-decorator.js +0 -18
@@ -0,0 +1,33 @@
1
+ import * as C from '../../../constants';
2
+
3
+ export const buildContentForLoopConstructor = ({ components, headers }) => {
4
+ // Start hack to find interation number
5
+ // Refactor if we have to handle complex components (vector, matrix)
6
+ const iterations =
7
+ components.find((c) => c.response).response.values[C.COLLECTED].length || 1;
8
+ // End
9
+ const initialArray = [...Array(iterations).keys()];
10
+ const uiComponents = components.map((comp) => {
11
+ const { response, ...other } = comp;
12
+ if (!response) return initialArray.map(() => comp);
13
+ // Handle reponses & cells components ?
14
+ const { name, values } = response;
15
+ return initialArray.map((rowNumber) => {
16
+ const newValues = Object.entries(values).reduce(
17
+ (acc, [key, value]) => ({
18
+ ...acc,
19
+ [key]: value ? value[rowNumber] : null,
20
+ }),
21
+ {}
22
+ );
23
+ return {
24
+ ...other,
25
+ response: { name, values: newValues },
26
+ rowNumber,
27
+ };
28
+ });
29
+ }, []);
30
+ const transpose = (m) => m[0].map((_, i) => m.map((x) => x[i]));
31
+ const rows = transpose(uiComponents);
32
+ return headers ? [headers, ...rows] : rows;
33
+ };
@@ -0,0 +1,189 @@
1
+ import React, { useState, useEffect } from 'react';
2
+ import PropTypes from 'prop-types';
3
+ import * as lunatic from '../../components';
4
+ import BodyComponent from './body-component';
5
+ import Declarations from '../../declarations';
6
+ import * as U from '../../../utils/lib';
7
+ import * as C from '../../../constants';
8
+ import { interpret } from '../../../utils/to-expose';
9
+
10
+ const LoopConstructorWrapper = ({
11
+ id: mainId,
12
+ label: mainLabel,
13
+ components,
14
+ handleChange,
15
+ lines,
16
+ declarations,
17
+ features,
18
+ bindings,
19
+ addBtnLabel,
20
+ hideBtn,
21
+ componentType,
22
+ ...otherProps
23
+ }) => {
24
+ const [todo, setTodo] = useState({});
25
+
26
+ const featuresWithoutMD = features.filter((f) => f !== 'MD');
27
+
28
+ const minLines = Math.max(
29
+ parseInt(interpret(featuresWithoutMD)(bindings)(lines.min), 10) || 1,
30
+ U.getLoopConstructorInitLines(components)
31
+ );
32
+ const maxLines = lines
33
+ ? parseInt(interpret(featuresWithoutMD)(bindings)(lines.max), 10)
34
+ : undefined;
35
+
36
+ const width = `${100 / Math.max(...components.map((row) => row.length))}%`;
37
+ const Button = lunatic.Button;
38
+ const involvedVariables = U.getInvolvedVariables(components);
39
+
40
+ const values = components.reduce(
41
+ (acc, c) => `${acc}|${Object.values(c.response?.values || {}).join('|')}`,
42
+ ''
43
+ );
44
+
45
+ // TEMP: Set static number of occurence if min = max
46
+ useEffect(() => {
47
+ if (lines.min && lines.min === lines.max) {
48
+ const min =
49
+ parseInt(interpret(featuresWithoutMD)(bindings)(lines.min), 10) || 1;
50
+ const up = involvedVariables.reduce((acc, { name }) => {
51
+ if (min <= bindings[name].length)
52
+ return { ...acc, [name]: [...bindings[name].slice(0, min)] };
53
+ const toAdd = [...Array(min - bindings[name].length).keys()].map(
54
+ () => null
55
+ );
56
+ return { ...acc, [name]: [...bindings[name], ...toAdd] };
57
+ }, {});
58
+ handleChange(up);
59
+ }
60
+ // Assume to only execute this side effect at mount
61
+ // eslint-disable-next-line react-hooks/exhaustive-deps
62
+ }, [values]);
63
+
64
+ useEffect(() => {
65
+ if (Object.keys(todo).length !== 0) {
66
+ const { up, rowNumber } = todo;
67
+ const entries = Object.entries(up);
68
+ const toUpdate = entries.reduce((_, [key, value]) => {
69
+ const previousValue = bindings[key];
70
+ const newValue = previousValue.map((v, i) =>
71
+ i === rowNumber ? value : v
72
+ );
73
+ return { ..._, [key]: newValue };
74
+ }, {});
75
+ handleChange(toUpdate);
76
+ setTodo({});
77
+ }
78
+ }, [bindings, todo, handleChange]);
79
+
80
+ const addLine = () => {
81
+ const toHandle = involvedVariables.reduce(
82
+ (acc, { name: iv }) => ({
83
+ ...acc,
84
+ [iv]: [...bindings[iv], null],
85
+ }),
86
+ {}
87
+ );
88
+ handleChange(toHandle);
89
+ };
90
+
91
+ const customBtnLabel =
92
+ (componentType === 'Loop' &&
93
+ interpret(features, otherProps?.logFunction)(bindings)(mainLabel)) ||
94
+ addBtnLabel;
95
+
96
+ return (
97
+ <>
98
+ <Declarations
99
+ id={mainId}
100
+ type={C.BEFORE_QUESTION_TEXT}
101
+ declarations={declarations}
102
+ features={features}
103
+ bindings={bindings}
104
+ />
105
+ {componentType === 'RosterForLoop' && mainLabel && (
106
+ <label
107
+ htmlFor={`loops-constructor-${mainId}`}
108
+ id={`loops-constructor-label-${mainId}`}
109
+ >
110
+ {interpret(features, otherProps?.logFunction)(bindings)(mainLabel)}
111
+ </label>
112
+ )}
113
+ <Declarations
114
+ id={mainId}
115
+ type={C.AFTER_QUESTION_TEXT}
116
+ declarations={declarations}
117
+ features={features}
118
+ bindings={bindings}
119
+ />
120
+ <BodyComponent
121
+ mainId={mainId}
122
+ componentType={componentType}
123
+ components={components}
124
+ bindings={bindings}
125
+ width={width}
126
+ features={features}
127
+ setTodo={setTodo}
128
+ {...otherProps}
129
+ />
130
+ {!hideBtn && Number.isInteger(minLines) && minLines !== maxLines && (
131
+ <Button
132
+ label="addLine"
133
+ value={customBtnLabel}
134
+ // disabled={
135
+ // Number.isInteger(minLines) && minLines === maxLines
136
+ //||
137
+ // Want to enable addition depsite of empty lines?
138
+ // U.lastLoopChildLineIsEmpty(bindings)(involvedVariables)
139
+ // }
140
+ onClick={addLine}
141
+ id={mainId}
142
+ logFunction={otherProps?.logFunction}
143
+ />
144
+ )}
145
+ <Declarations
146
+ id={mainId}
147
+ type={C.DETACHABLE}
148
+ declarations={declarations}
149
+ features={features}
150
+ bindings={bindings}
151
+ />
152
+ </>
153
+ );
154
+ };
155
+
156
+ LoopConstructorWrapper.defaultProps = {
157
+ label: '',
158
+ preferences: ['COLLECTED'],
159
+ components: [],
160
+ lines: {},
161
+ positioning: 'DEFAULT',
162
+ declarations: [],
163
+ features: [],
164
+ bindings: {},
165
+ addBtnLabel: 'Add a line',
166
+ management: false,
167
+ hideBtn: false,
168
+ style: {},
169
+ };
170
+
171
+ LoopConstructorWrapper.propTypes = {
172
+ componentType: PropTypes.string.isRequired,
173
+ id: PropTypes.string.isRequired,
174
+ label: PropTypes.string,
175
+ preferences: PropTypes.arrayOf(U.valueTypePropTypes),
176
+ components: PropTypes.array,
177
+ handleChange: PropTypes.func.isRequired,
178
+ lines: U.linesPropTypes,
179
+ positioning: PropTypes.oneOf(['DEFAULT', 'HORIZONTAL', 'VERTICAL']),
180
+ declarations: U.declarationsPropTypes,
181
+ features: PropTypes.arrayOf(PropTypes.string),
182
+ bindings: PropTypes.object,
183
+ addBtnLabel: PropTypes.string,
184
+ hideBtn: PropTypes.bool,
185
+ management: PropTypes.bool,
186
+ style: PropTypes.object,
187
+ };
188
+
189
+ export default React.memo(LoopConstructorWrapper, U.areEqual);
@@ -0,0 +1 @@
1
+ export { default } from './component';
@@ -0,0 +1,119 @@
1
+ import React, { useEffect } from 'react';
2
+ import KeyboardEventHandler from 'react-keyboard-event-handler';
3
+ import Button from '../button';
4
+ import * as U from '../../utils/lib';
5
+ import './missing.scss';
6
+
7
+ const Missing = ({ Component, props }) => {
8
+ const {
9
+ dontKnowButton = "Don't know",
10
+ refusedButton = 'Refused',
11
+ missingResponse,
12
+ handleChange,
13
+ preferences,
14
+ missingStrategy,
15
+ missingShortcut = { dontKnow: '', refused: '' },
16
+ response,
17
+ responses,
18
+ cells,
19
+ components,
20
+ savingType,
21
+ bindings,
22
+ shortcut,
23
+ } = props;
24
+
25
+ const buttonState = U.getResponseByPreference(preferences)(missingResponse);
26
+
27
+ useEffect(() => {
28
+ if (
29
+ buttonState !== null &&
30
+ U.hasToCleanMissing(savingType)({
31
+ response,
32
+ responses,
33
+ cells,
34
+ components,
35
+ })
36
+ ) {
37
+ handleChange({ [U.getResponseName(missingResponse)]: null });
38
+ }
39
+ }, [
40
+ buttonState,
41
+ handleChange,
42
+ savingType,
43
+ response,
44
+ responses,
45
+ cells,
46
+ components,
47
+ missingResponse,
48
+ ]);
49
+ const getVarsToClean = () =>
50
+ U.getToClean(savingType)({
51
+ response,
52
+ responses,
53
+ cells,
54
+ components,
55
+ });
56
+
57
+ const onClick = (value) => () => {
58
+ const isSameValue = buttonState === value;
59
+ const newValue = isSameValue ? null : value;
60
+ const toClean = getVarsToClean();
61
+ if (Object.keys(toClean)) {
62
+ handleChange(toClean);
63
+ if (U.isFunction(missingStrategy) && !isSameValue)
64
+ missingStrategy({ ...bindings, ...toClean });
65
+ } else {
66
+ if (U.isFunction(missingStrategy) && !isSameValue)
67
+ missingStrategy(bindings);
68
+ }
69
+ handleChange({ [U.getResponseName(missingResponse)]: newValue });
70
+ };
71
+
72
+ return (
73
+ <div className="missing-wrapper">
74
+ <div className="missing-component">
75
+ <Component {...props} />
76
+ </div>
77
+ <div className="missing-buttons">
78
+ <span
79
+ className={`missing-button${
80
+ buttonState === U.DK ? '-active' : ''
81
+ } missing-button-dk${buttonState === U.DK ? '-active' : ''}`}
82
+ >
83
+ <Button
84
+ label="dont-know-button"
85
+ value={dontKnowButton}
86
+ onClick={onClick(U.DK)}
87
+ />
88
+ </span>
89
+ <span
90
+ className={`missing-button${
91
+ buttonState === U.RF ? '-active' : ''
92
+ } missing-button-rf${buttonState === U.RF ? '-active' : ''}`}
93
+ >
94
+ <Button
95
+ label="refused-button"
96
+ value={refusedButton}
97
+ onClick={onClick(U.RF)}
98
+ />
99
+ </span>
100
+ </div>
101
+ {shortcut &&
102
+ missingShortcut &&
103
+ missingShortcut.dontKnow &&
104
+ missingShortcut.refused && (
105
+ <KeyboardEventHandler
106
+ handleKeys={Object.values(missingShortcut)}
107
+ onKeyEvent={(key, e) => {
108
+ e.preventDefault();
109
+ if (key === missingShortcut.dontKnow) onClick(U.DK)();
110
+ if (key === missingShortcut.refused) onClick(U.RF)();
111
+ }}
112
+ handleFocusableElements
113
+ />
114
+ )}
115
+ </div>
116
+ );
117
+ };
118
+
119
+ export default Missing;
@@ -0,0 +1 @@
1
+ export { default } from './wrapper';
@@ -0,0 +1,30 @@
1
+ .missing-wrapper {
2
+ .missing-buttons {
3
+ margin-top: 1em;
4
+ .button-lunatic {
5
+ width: 4em;
6
+ font-size: 1em;
7
+ font-weight: normal;
8
+ }
9
+ .missing-button {
10
+ .button-lunatic {
11
+ background-color: var(--color-very-very-light);
12
+ color: var(--color-primary-dark);
13
+ &:hover {
14
+ background-color: white;
15
+ color: var(--color-primary-main);
16
+ }
17
+ }
18
+ }
19
+ .missing-button-active {
20
+ .button-lunatic {
21
+ background-color: var(--color-primary-dark);
22
+ color: var(--color-very-very-light);
23
+ &:hover {
24
+ background-color: var(--color-primary-main);
25
+ color: white;
26
+ }
27
+ }
28
+ }
29
+ }
30
+ }
@@ -0,0 +1,10 @@
1
+ import React from 'react';
2
+ import Missing from './component';
3
+
4
+ const missingWrapper = (Component) => (props) => {
5
+ const { missing } = props;
6
+ if (missing) return <Missing Component={Component} props={props} />;
7
+ return <Component {...props} />;
8
+ };
9
+
10
+ export default missingWrapper;
@@ -0,0 +1,28 @@
1
+ import React from 'react';
2
+ import PropTypes from 'prop-types';
3
+ import { buildStyleObject } from '../../utils/lib';
4
+ import './progress-bar.scss';
5
+
6
+ const ProgressBar = ({ id, value, style }) => {
7
+ let controledValue = value;
8
+ if (value < 0) controledValue = 0;
9
+ if (value > 100) controledValue = 100;
10
+ return (
11
+ <div
12
+ id={`progress-${id}`}
13
+ className="progress-lunatic"
14
+ style={buildStyleObject(style)}
15
+ >
16
+ {`${controledValue.toFixed(0)} %`}
17
+ <span style={{ width: `${controledValue}%` }} />
18
+ </div>
19
+ );
20
+ };
21
+
22
+ ProgressBar.propTypes = {
23
+ id: PropTypes.string.isRequired,
24
+ value: PropTypes.number.isRequired,
25
+ style: PropTypes.object,
26
+ };
27
+
28
+ export default ProgressBar;
@@ -0,0 +1 @@
1
+ export { default } from './component';
@@ -0,0 +1,52 @@
1
+ .progress-lunatic {
2
+ height: 30px;
3
+ position: relative;
4
+ background: var(--color-disabled);
5
+ -moz-border-radius: 20px;
6
+ -webkit-border-radius: 20px;
7
+ border-radius: 20px;
8
+ padding: 5px;
9
+ box-shadow: inset 0 -1px 1px rgba(255, 255, 255, 0.3);
10
+ text-align: center;
11
+ font-weight: bold;
12
+ }
13
+
14
+ .progress-lunatic > span {
15
+ display: block;
16
+ height: 100%;
17
+ border-radius: 20px;
18
+ background-color: var(--color-primary-light);
19
+ opacity: 0.6;
20
+ box-shadow: inset 0 2px 9px rgba(255, 255, 255, 0.3),
21
+ inset 0 -2px 6px rgba(0, 0, 0, 0.4);
22
+ position: relative;
23
+ top: -18px;
24
+ overflow: hidden;
25
+ }
26
+
27
+ .progress-lunatic > span:after {
28
+ content: '';
29
+ position: absolute;
30
+ top: 0;
31
+ left: 0;
32
+ bottom: 0;
33
+ right: 0;
34
+ background-image: linear-gradient(
35
+ -45deg,
36
+ rgba(255, 255, 255, 0.2) 25%,
37
+ transparent 25%,
38
+ transparent 50%,
39
+ rgba(255, 255, 255, 0.2) 50%,
40
+ rgba(255, 255, 255, 0.2) 75%,
41
+ transparent 75%,
42
+ transparent
43
+ );
44
+ z-index: 1;
45
+ background-size: 50px 50px;
46
+ animation: move 2s linear infinite;
47
+ border-top-right-radius: 8px;
48
+ border-bottom-right-radius: 8px;
49
+ border-top-left-radius: 20px;
50
+ border-bottom-left-radius: 20px;
51
+ overflow: hidden;
52
+ }
@@ -0,0 +1,9 @@
1
+ import React from 'react';
2
+ import missingWrapper from '../missing-wrapper';
3
+ import { ListDeclarationsWrapper } from '../declarations/wrappers';
4
+ import { areEqual } from '../../utils/lib';
5
+ import './radio.scss';
6
+
7
+ const Radio = (props) => <ListDeclarationsWrapper type="radio" {...props} />;
8
+
9
+ export default React.memo(missingWrapper(Radio), areEqual);
@@ -0,0 +1 @@
1
+ export { default } from './component';
@@ -0,0 +1,57 @@
1
+ .radio-group-list {
2
+ border: 0;
3
+ outline: 0;
4
+ padding: 0;
5
+ margin-top: 0.9375rem;
6
+ }
7
+
8
+ .radio-lunatic {
9
+ position: absolute;
10
+ opacity: 0;
11
+ margin-bottom: 0;
12
+ margin-top: 0.05rem;
13
+ margin-left: 0.2rem;
14
+ height: 20px;
15
+ width: 20px;
16
+ + label {
17
+ margin-left: 2rem;
18
+ }
19
+ &:focus {
20
+ + label {
21
+ background-color: rgba(0, 0, 0, 0.05);
22
+ }
23
+ }
24
+ + label::before {
25
+ float: left;
26
+ line-height: 2rem;
27
+ }
28
+ }
29
+
30
+ .field,
31
+ .field-with-tooltip {
32
+ .radio-group-list .radio-modality {
33
+ height: 1.375em;
34
+ }
35
+ }
36
+
37
+ .radio-group-list {
38
+ .radio-modality {
39
+ label {
40
+ display: flex;
41
+ }
42
+ }
43
+ .radio-modality.radio-modality-block label {
44
+ padding-top: 0.325em;
45
+ }
46
+ .radio-modality.radio-modality-block.horizontal-options label {
47
+ padding-top: 0;
48
+ }
49
+ }
50
+
51
+ .radio-modality {
52
+ margin-bottom: 0.8em;
53
+ }
54
+
55
+ .radio-lunatic + label {
56
+ margin-top: 0.325em;
57
+ }
@@ -1,26 +1,49 @@
1
1
  import React from 'react';
2
2
  import PropTypes from 'prop-types';
3
- import { buildStyleObject } from '../../utils/string-utils';
3
+ import { SimpleDeclarationsWrapper } from '../declarations/wrappers';
4
+ import * as U from '../../utils/lib';
5
+ import { interpret } from '../../utils/to-expose';
4
6
  import './sequence.scss';
5
7
 
6
- const Sequence = ({ id, label, style }) => (
7
- <div
8
- aria-label={`sequence-${id}`}
9
- className="sequence-lunatic"
10
- style={buildStyleObject(style)}
8
+ const Sequence = ({
9
+ id,
10
+ label,
11
+ declarations,
12
+ features,
13
+ bindings,
14
+ style,
15
+ logFunction,
16
+ }) => (
17
+ <SimpleDeclarationsWrapper
18
+ id={id}
19
+ declarations={declarations}
20
+ features={features}
21
+ bindings={bindings}
11
22
  >
12
- {label}
13
- </div>
23
+ <div
24
+ aria-label={`sequence-${id}`}
25
+ className="sequence-lunatic"
26
+ style={U.buildStyleObject(style)}
27
+ >
28
+ {interpret(features, logFunction)(bindings)(label)}
29
+ </div>
30
+ </SimpleDeclarationsWrapper>
14
31
  );
15
32
 
33
+ Sequence.defaultProps = {
34
+ declarations: [],
35
+ features: [],
36
+ bindings: {},
37
+ style: {},
38
+ };
39
+
16
40
  Sequence.propTypes = {
17
41
  id: PropTypes.string.isRequired,
18
42
  label: PropTypes.string.isRequired,
43
+ declarations: U.declarationsPropTypes,
44
+ features: PropTypes.arrayOf(PropTypes.string),
45
+ bindings: PropTypes.object,
19
46
  style: PropTypes.object,
20
47
  };
21
48
 
22
- Sequence.defaultProps = {
23
- style: {},
24
- };
25
-
26
- export default Sequence;
49
+ export default React.memo(Sequence, U.areEqual);
@@ -1,15 +1,8 @@
1
- @import 'src/components/index.scss';
2
-
3
1
  .sequence-lunatic {
4
- height: 40px;
5
- box-sizing: border-box;
6
- border-radius: 0px;
7
- background-color: $main_color;
8
- border: 0.1em solid $main_color;
9
- color: white;
10
- font-weight: bold;
11
- font-size: 130%;
12
- padding-left: 10px;
13
- display: flex;
14
- align-items: center;
2
+ padding: 0;
3
+ font-size: 0.875rem;
4
+ color: var(--color-primary-light);
5
+ background-color: var(--color-secondary-contrast-text);
6
+ border: 0;
7
+ height: 1.875rem;
15
8
  }
@@ -1,26 +1,48 @@
1
1
  import React from 'react';
2
2
  import PropTypes from 'prop-types';
3
- import { buildStyleObject } from '../../utils/string-utils';
4
- import './subsequence.scss';
3
+ import { SimpleDeclarationsWrapper } from '../declarations/wrappers';
4
+ import * as U from '../../utils/lib';
5
+ import { interpret } from '../../utils/to-expose';
5
6
 
6
- const Subsequence = ({ id, label, style }) => (
7
- <div
8
- aria-label={`subsequence-${id}`}
9
- className="subsequence-lunatic"
10
- style={buildStyleObject(style)}
7
+ const Subsequence = ({
8
+ id,
9
+ label,
10
+ declarations,
11
+ features,
12
+ bindings,
13
+ style,
14
+ logFunction,
15
+ }) => (
16
+ <SimpleDeclarationsWrapper
17
+ id={id}
18
+ declarations={declarations}
19
+ features={features}
20
+ bindings={bindings}
11
21
  >
12
- {label}
13
- </div>
22
+ <div
23
+ aria-label={`subsequence-${id}`}
24
+ className="subsequence-lunatic"
25
+ style={U.buildStyleObject(style)}
26
+ >
27
+ {interpret(features, logFunction)(bindings)(label)}
28
+ </div>
29
+ </SimpleDeclarationsWrapper>
14
30
  );
15
31
 
32
+ Subsequence.defaultProps = {
33
+ declarations: [],
34
+ features: [],
35
+ bindings: {},
36
+ style: {},
37
+ };
38
+
16
39
  Subsequence.propTypes = {
17
40
  id: PropTypes.string.isRequired,
18
41
  label: PropTypes.string.isRequired,
42
+ declarations: U.declarationsPropTypes,
43
+ features: PropTypes.arrayOf(PropTypes.string),
44
+ bindings: PropTypes.object,
19
45
  style: PropTypes.object,
20
46
  };
21
47
 
22
- Subsequence.defaultProps = {
23
- style: {},
24
- };
25
-
26
- export default Subsequence;
48
+ export default React.memo(Subsequence, U.areEqual);