@inseefr/lunatic 3.4.5-rc.0 → 3.4.6-rc.0

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 (743) hide show
  1. package/esm/components/Accordion/Accordion.d.ts +7 -0
  2. package/esm/components/Accordion/Accordion.js +6 -0
  3. package/esm/components/Accordion/Accordion.js.map +1 -0
  4. package/esm/components/CheckboxBoolean/CheckboxBoolean.d.ts +10 -0
  5. package/esm/components/CheckboxBoolean/CheckboxBoolean.js +19 -0
  6. package/esm/components/CheckboxBoolean/CheckboxBoolean.js.map +1 -0
  7. package/esm/components/CheckboxBoolean/CheckboxBoolean.spec.d.ts +1 -0
  8. package/esm/components/CheckboxBoolean/CheckboxBoolean.spec.js +37 -0
  9. package/esm/components/CheckboxBoolean/CheckboxBoolean.spec.js.map +1 -0
  10. package/esm/components/CheckboxGroup/CheckboxGroup.d.ts +2 -0
  11. package/esm/components/CheckboxGroup/CheckboxGroup.js +7 -0
  12. package/esm/components/CheckboxGroup/CheckboxGroup.js.map +1 -0
  13. package/esm/components/CheckboxGroup/CustomCheckboxGroup.d.ts +7 -0
  14. package/esm/components/CheckboxGroup/CustomCheckboxGroup.js +17 -0
  15. package/esm/components/CheckboxGroup/CustomCheckboxGroup.js.map +1 -0
  16. package/esm/components/CheckboxGroup/CustomCheckboxGroup.spec.d.ts +1 -0
  17. package/esm/components/CheckboxGroup/CustomCheckboxGroup.spec.js +45 -0
  18. package/esm/components/CheckboxGroup/CustomCheckboxGroup.spec.js.map +1 -0
  19. package/esm/components/CheckboxOne/CheckboxOne.d.ts +5 -0
  20. package/esm/components/CheckboxOne/CheckboxOne.js +10 -0
  21. package/esm/components/CheckboxOne/CheckboxOne.js.map +1 -0
  22. package/esm/components/CheckboxOne/CheckboxOne.spec.d.ts +1 -0
  23. package/esm/components/CheckboxOne/CheckboxOne.spec.js +24 -0
  24. package/esm/components/CheckboxOne/CheckboxOne.spec.js.map +1 -0
  25. package/esm/components/Datepicker/Datepicker.d.ts +9 -0
  26. package/esm/components/Datepicker/Datepicker.js +66 -0
  27. package/esm/components/Datepicker/Datepicker.js.map +1 -0
  28. package/esm/components/Datepicker/Datepicker.spec.d.ts +1 -0
  29. package/esm/components/Datepicker/Datepicker.spec.js +75 -0
  30. package/esm/components/Datepicker/Datepicker.spec.js.map +1 -0
  31. package/esm/components/Datepicker/DatepickerField.d.ts +12 -0
  32. package/esm/components/Datepicker/DatepickerField.js +13 -0
  33. package/esm/components/Datepicker/DatepickerField.js.map +1 -0
  34. package/esm/components/Dropdown/Dropdown.d.ts +9 -0
  35. package/esm/components/Dropdown/Dropdown.js +15 -0
  36. package/esm/components/Dropdown/Dropdown.js.map +1 -0
  37. package/esm/components/Dropdown/Dropdown.spec.d.ts +1 -0
  38. package/esm/components/Dropdown/Dropdown.spec.js +38 -0
  39. package/esm/components/Dropdown/Dropdown.spec.js.map +1 -0
  40. package/esm/components/Dropdown/renderer/SimpleLabelRenderer.d.ts +8 -0
  41. package/esm/components/Dropdown/renderer/SimpleLabelRenderer.js +19 -0
  42. package/esm/components/Dropdown/renderer/SimpleLabelRenderer.js.map +1 -0
  43. package/esm/components/Dropdown/renderer/SimpleOptionRenderer.d.ts +7 -0
  44. package/esm/components/Dropdown/renderer/SimpleOptionRenderer.js +10 -0
  45. package/esm/components/Dropdown/renderer/SimpleOptionRenderer.js.map +1 -0
  46. package/esm/components/Duration/Duration.d.ts +9 -0
  47. package/esm/components/Duration/Duration.js +34 -0
  48. package/esm/components/Duration/Duration.js.map +1 -0
  49. package/esm/components/Duration/durationUtils.d.ts +47 -0
  50. package/esm/components/Duration/durationUtils.js +26 -0
  51. package/esm/components/Duration/durationUtils.js.map +1 -0
  52. package/esm/components/Duration/formatDuration.d.ts +2 -0
  53. package/esm/components/Duration/formatDuration.js +18 -0
  54. package/esm/components/Duration/formatDuration.js.map +1 -0
  55. package/esm/components/Duration/formatDuration.spec.d.ts +1 -0
  56. package/esm/components/Duration/formatDuration.spec.js +16 -0
  57. package/esm/components/Duration/formatDuration.spec.js.map +1 -0
  58. package/esm/components/Duration/getDurationFromValue.d.ts +8 -0
  59. package/esm/components/Duration/getDurationFromValue.js +36 -0
  60. package/esm/components/Duration/getDurationFromValue.js.map +1 -0
  61. package/esm/components/FilterDescription/FilterDescription.d.ts +7 -0
  62. package/esm/components/FilterDescription/FilterDescription.js +3 -0
  63. package/esm/components/FilterDescription/FilterDescription.js.map +1 -0
  64. package/esm/components/FilterDescription/FilterDescription.spec.d.ts +1 -0
  65. package/esm/components/FilterDescription/FilterDescription.spec.js +16 -0
  66. package/esm/components/FilterDescription/FilterDescription.spec.js.map +1 -0
  67. package/esm/components/Input/Input.d.ts +9 -0
  68. package/esm/components/Input/Input.js +15 -0
  69. package/esm/components/Input/Input.js.map +1 -0
  70. package/esm/components/Input/Input.spec.d.ts +1 -0
  71. package/esm/components/Input/Input.spec.js +52 -0
  72. package/esm/components/Input/Input.spec.js.map +1 -0
  73. package/esm/components/InputNumber/InputNumber.d.ts +9 -0
  74. package/esm/components/InputNumber/InputNumber.js +15 -0
  75. package/esm/components/InputNumber/InputNumber.js.map +1 -0
  76. package/esm/components/InputNumber/InputNumber.spec.d.ts +1 -0
  77. package/esm/components/InputNumber/InputNumber.spec.js +76 -0
  78. package/esm/components/InputNumber/InputNumber.spec.js.map +1 -0
  79. package/esm/components/InputNumber/InputNumberThousand.d.ts +14 -0
  80. package/esm/components/InputNumber/InputNumberThousand.js +20 -0
  81. package/esm/components/InputNumber/InputNumberThousand.js.map +1 -0
  82. package/esm/components/Loop/Loop.d.ts +15 -0
  83. package/esm/components/Loop/Loop.js +56 -0
  84. package/esm/components/Loop/Loop.js.map +1 -0
  85. package/esm/components/Loop/constant.d.ts +4 -0
  86. package/esm/components/Loop/constant.js +10 -0
  87. package/esm/components/Loop/constant.js.map +1 -0
  88. package/esm/components/LunaticComponents.d.ts +22 -0
  89. package/esm/components/LunaticComponents.js +83 -0
  90. package/esm/components/LunaticComponents.js.map +1 -0
  91. package/esm/components/PairwiseLinks/PairwiseLinks.d.ts +2 -0
  92. package/esm/components/PairwiseLinks/PairwiseLinks.js +42 -0
  93. package/esm/components/PairwiseLinks/PairwiseLinks.js.map +1 -0
  94. package/esm/components/Question/Question.d.ts +9 -0
  95. package/esm/components/Question/Question.js +16 -0
  96. package/esm/components/Question/Question.js.map +1 -0
  97. package/esm/components/Radio/Radio.d.ts +9 -0
  98. package/esm/components/Radio/Radio.js +10 -0
  99. package/esm/components/Radio/Radio.js.map +1 -0
  100. package/esm/components/RosterForLoop/RosterForLoop.d.ts +5 -0
  101. package/esm/components/RosterForLoop/RosterForLoop.js +63 -0
  102. package/esm/components/RosterForLoop/RosterForLoop.js.map +1 -0
  103. package/esm/components/RosterForLoop/RosterForLoop.spec.d.ts +1 -0
  104. package/esm/components/RosterForLoop/RosterForLoop.spec.js +28 -0
  105. package/esm/components/RosterForLoop/RosterForLoop.spec.js.map +1 -0
  106. package/esm/components/Roundabout/CustomRoundabout.d.ts +16 -0
  107. package/esm/components/Roundabout/CustomRoundabout.js +31 -0
  108. package/esm/components/Roundabout/CustomRoundabout.js.map +1 -0
  109. package/esm/components/Roundabout/Roundabout.d.ts +5 -0
  110. package/esm/components/Roundabout/Roundabout.js +28 -0
  111. package/esm/components/Roundabout/Roundabout.js.map +1 -0
  112. package/esm/components/Roundabout/roundabout.spec.d.ts +1 -0
  113. package/esm/components/Roundabout/roundabout.spec.js +47 -0
  114. package/esm/components/Roundabout/roundabout.spec.js.map +1 -0
  115. package/esm/components/Sequence/Sequence.d.ts +3 -0
  116. package/esm/components/Sequence/Sequence.js +9 -0
  117. package/esm/components/Sequence/Sequence.js.map +1 -0
  118. package/esm/components/Subsequence/Subsequence.d.ts +3 -0
  119. package/esm/components/Subsequence/Subsequence.js +9 -0
  120. package/esm/components/Subsequence/Subsequence.js.map +1 -0
  121. package/esm/components/Subsequence/Subsequence.spec.d.ts +1 -0
  122. package/esm/components/Subsequence/Subsequence.spec.js +43 -0
  123. package/esm/components/Subsequence/Subsequence.spec.js.map +1 -0
  124. package/esm/components/Suggester/CustomSuggester.d.ts +29 -0
  125. package/esm/components/Suggester/CustomSuggester.js +19 -0
  126. package/esm/components/Suggester/CustomSuggester.js.map +1 -0
  127. package/esm/components/Suggester/Suggester.d.ts +2 -0
  128. package/esm/components/Suggester/Suggester.js +104 -0
  129. package/esm/components/Suggester/Suggester.js.map +1 -0
  130. package/esm/components/Suggester/SuggesterNotification.d.ts +9 -0
  131. package/esm/components/Suggester/SuggesterNotification.js +15 -0
  132. package/esm/components/Suggester/SuggesterNotification.js.map +1 -0
  133. package/esm/components/Suggester/SuggesterType.d.ts +5 -0
  134. package/esm/components/Suggester/SuggesterType.js +2 -0
  135. package/esm/components/Suggester/SuggesterType.js.map +1 -0
  136. package/esm/components/Suggester/useSuggestions.d.ts +17 -0
  137. package/esm/components/Suggester/useSuggestions.js +85 -0
  138. package/esm/components/Suggester/useSuggestions.js.map +1 -0
  139. package/esm/components/Summary/Summary.d.ts +25 -0
  140. package/esm/components/Summary/Summary.js +65 -0
  141. package/esm/components/Summary/Summary.js.map +1 -0
  142. package/esm/components/Switch/Switch.d.ts +20 -0
  143. package/esm/components/Switch/Switch.js +30 -0
  144. package/esm/components/Switch/Switch.js.map +1 -0
  145. package/esm/components/Table/Table.d.ts +2 -0
  146. package/esm/components/Table/Table.js +9 -0
  147. package/esm/components/Table/Table.js.map +1 -0
  148. package/esm/components/Text/Text.d.ts +2 -0
  149. package/esm/components/Text/Text.js +4 -0
  150. package/esm/components/Text/Text.js.map +1 -0
  151. package/esm/components/Textarea/Textarea.d.ts +9 -0
  152. package/esm/components/Textarea/Textarea.js +14 -0
  153. package/esm/components/Textarea/Textarea.js.map +1 -0
  154. package/esm/components/Textarea/Textarea.spec.d.ts +1 -0
  155. package/esm/components/Textarea/Textarea.spec.js +31 -0
  156. package/esm/components/Textarea/Textarea.spec.js.map +1 -0
  157. package/esm/components/library.d.ts +73 -0
  158. package/esm/components/library.js +52 -0
  159. package/esm/components/library.js.map +1 -0
  160. package/esm/components/shared/Button/Button.d.ts +14 -0
  161. package/esm/components/shared/Button/Button.js +13 -0
  162. package/esm/components/shared/Button/Button.js.map +1 -0
  163. package/esm/components/shared/Button/Button.spec.d.ts +1 -0
  164. package/esm/components/shared/Button/Button.spec.js +51 -0
  165. package/esm/components/shared/Button/Button.spec.js.map +1 -0
  166. package/esm/components/shared/Button/IconButton.d.ts +6 -0
  167. package/esm/components/shared/Button/IconButton.js +7 -0
  168. package/esm/components/shared/Button/IconButton.js.map +1 -0
  169. package/esm/components/shared/Button/IconButton.spec.d.ts +1 -0
  170. package/esm/components/shared/Button/IconButton.spec.js +53 -0
  171. package/esm/components/shared/Button/IconButton.spec.js.map +1 -0
  172. package/esm/components/shared/Checkbox/CheckboxOption.d.ts +15 -0
  173. package/esm/components/shared/Checkbox/CheckboxOption.js +26 -0
  174. package/esm/components/shared/Checkbox/CheckboxOption.js.map +1 -0
  175. package/esm/components/shared/Checkbox/CheckboxOption.spec.d.ts +1 -0
  176. package/esm/components/shared/Checkbox/CheckboxOption.spec.js +52 -0
  177. package/esm/components/shared/Checkbox/CheckboxOption.spec.js.map +1 -0
  178. package/esm/components/shared/Checkbox/getShortcutKey.d.ts +1 -0
  179. package/esm/components/shared/Checkbox/getShortcutKey.js +3 -0
  180. package/esm/components/shared/Checkbox/getShortcutKey.js.map +1 -0
  181. package/esm/components/shared/Combobox/Combobox.d.ts +25 -0
  182. package/esm/components/shared/Combobox/Combobox.js +97 -0
  183. package/esm/components/shared/Combobox/Combobox.js.map +1 -0
  184. package/esm/components/shared/Combobox/Combobox.stories.d.ts +6 -0
  185. package/esm/components/shared/Combobox/Combobox.stories.js +47 -0
  186. package/esm/components/shared/Combobox/Combobox.stories.js.map +1 -0
  187. package/esm/components/shared/Combobox/ComboboxContainer.d.ts +11 -0
  188. package/esm/components/shared/Combobox/ComboboxContainer.js +6 -0
  189. package/esm/components/shared/Combobox/ComboboxContainer.js.map +1 -0
  190. package/esm/components/shared/Combobox/ComboboxContainer.spec.d.ts +1 -0
  191. package/esm/components/shared/Combobox/ComboboxContainer.spec.js +24 -0
  192. package/esm/components/shared/Combobox/ComboboxContainer.spec.js.map +1 -0
  193. package/esm/components/shared/Combobox/ComboboxContent.d.ts +10 -0
  194. package/esm/components/shared/Combobox/ComboboxContent.js +35 -0
  195. package/esm/components/shared/Combobox/ComboboxContent.js.map +1 -0
  196. package/esm/components/shared/Combobox/ComboboxContentBox.d.ts +7 -0
  197. package/esm/components/shared/Combobox/ComboboxContentBox.js +7 -0
  198. package/esm/components/shared/Combobox/ComboboxContentBox.js.map +1 -0
  199. package/esm/components/shared/Combobox/ComboboxType.d.ts +51 -0
  200. package/esm/components/shared/Combobox/ComboboxType.js +2 -0
  201. package/esm/components/shared/Combobox/ComboboxType.js.map +1 -0
  202. package/esm/components/shared/Combobox/Panel/ComboboxOption.d.ts +7 -0
  203. package/esm/components/shared/Combobox/Panel/ComboboxOption.js +15 -0
  204. package/esm/components/shared/Combobox/Panel/ComboboxOption.js.map +1 -0
  205. package/esm/components/shared/Combobox/Panel/ComboboxOption.spec.d.ts +1 -0
  206. package/esm/components/shared/Combobox/Panel/ComboboxOption.spec.js +33 -0
  207. package/esm/components/shared/Combobox/Panel/ComboboxOption.spec.js.map +1 -0
  208. package/esm/components/shared/Combobox/Panel/ComboboxOptionContainer.d.ts +8 -0
  209. package/esm/components/shared/Combobox/Panel/ComboboxOptionContainer.js +36 -0
  210. package/esm/components/shared/Combobox/Panel/ComboboxOptionContainer.js.map +1 -0
  211. package/esm/components/shared/Combobox/Panel/ComboboxOptionContainer.spec.d.ts +1 -0
  212. package/esm/components/shared/Combobox/Panel/ComboboxOptionContainer.spec.js +18 -0
  213. package/esm/components/shared/Combobox/Panel/ComboboxOptionContainer.spec.js.map +1 -0
  214. package/esm/components/shared/Combobox/Panel/ComboboxPanel.d.ts +5 -0
  215. package/esm/components/shared/Combobox/Panel/ComboboxPanel.js +30 -0
  216. package/esm/components/shared/Combobox/Panel/ComboboxPanel.js.map +1 -0
  217. package/esm/components/shared/Combobox/Panel/ComboboxPanel.spec.d.ts +1 -0
  218. package/esm/components/shared/Combobox/Panel/ComboboxPanel.spec.js +57 -0
  219. package/esm/components/shared/Combobox/Panel/ComboboxPanel.spec.js.map +1 -0
  220. package/esm/components/shared/Combobox/Panel/ComboboxPanelContainer.d.ts +8 -0
  221. package/esm/components/shared/Combobox/Panel/ComboboxPanelContainer.js +8 -0
  222. package/esm/components/shared/Combobox/Panel/ComboboxPanelContainer.js.map +1 -0
  223. package/esm/components/shared/Combobox/Panel/ComboboxPanelContainer.spec.d.ts +1 -0
  224. package/esm/components/shared/Combobox/Panel/ComboboxPanelContainer.spec.js +31 -0
  225. package/esm/components/shared/Combobox/Panel/ComboboxPanelContainer.spec.js.map +1 -0
  226. package/esm/components/shared/Combobox/Selection/ComboboxClearButton.d.ts +8 -0
  227. package/esm/components/shared/Combobox/Selection/ComboboxClearButton.js +28 -0
  228. package/esm/components/shared/Combobox/Selection/ComboboxClearButton.js.map +1 -0
  229. package/esm/components/shared/Combobox/Selection/ComboboxClearButton.spec.d.ts +1 -0
  230. package/esm/components/shared/Combobox/Selection/ComboboxClearButton.spec.js +53 -0
  231. package/esm/components/shared/Combobox/Selection/ComboboxClearButton.spec.js.map +1 -0
  232. package/esm/components/shared/Combobox/Selection/ComboboxInput.d.ts +11 -0
  233. package/esm/components/shared/Combobox/Selection/ComboboxInput.js +21 -0
  234. package/esm/components/shared/Combobox/Selection/ComboboxInput.js.map +1 -0
  235. package/esm/components/shared/Combobox/Selection/ComboboxLabelSelection.d.ts +10 -0
  236. package/esm/components/shared/Combobox/Selection/ComboboxLabelSelection.js +31 -0
  237. package/esm/components/shared/Combobox/Selection/ComboboxLabelSelection.js.map +1 -0
  238. package/esm/components/shared/Combobox/Selection/ComboboxLabelSelection.spec.d.ts +1 -0
  239. package/esm/components/shared/Combobox/Selection/ComboboxLabelSelection.spec.js +27 -0
  240. package/esm/components/shared/Combobox/Selection/ComboboxLabelSelection.spec.js.map +1 -0
  241. package/esm/components/shared/Combobox/Selection/ComboboxSelection.d.ts +6 -0
  242. package/esm/components/shared/Combobox/Selection/ComboboxSelection.js +18 -0
  243. package/esm/components/shared/Combobox/Selection/ComboboxSelection.js.map +1 -0
  244. package/esm/components/shared/Combobox/Selection/ComboboxSelection.spec.d.ts +1 -0
  245. package/esm/components/shared/Combobox/Selection/ComboboxSelection.spec.js +36 -0
  246. package/esm/components/shared/Combobox/Selection/ComboboxSelection.spec.js.map +1 -0
  247. package/esm/components/shared/Combobox/constants.d.ts +9 -0
  248. package/esm/components/shared/Combobox/constants.js +10 -0
  249. package/esm/components/shared/Combobox/constants.js.map +1 -0
  250. package/esm/components/shared/Combobox/index.d.ts +0 -0
  251. package/esm/components/shared/Combobox/index.js +2 -0
  252. package/esm/components/shared/Combobox/index.js.map +1 -0
  253. package/esm/components/shared/ComponentErrors/ComponentErrors.d.ts +14 -0
  254. package/esm/components/shared/ComponentErrors/ComponentErrors.js +24 -0
  255. package/esm/components/shared/ComponentErrors/ComponentErrors.js.map +1 -0
  256. package/esm/components/shared/ComponentErrors/ComponentErrors.spec.d.ts +1 -0
  257. package/esm/components/shared/ComponentErrors/ComponentErrors.spec.js +40 -0
  258. package/esm/components/shared/ComponentErrors/ComponentErrors.spec.js.map +1 -0
  259. package/esm/components/shared/ComponentWrapper.d.ts +25 -0
  260. package/esm/components/shared/ComponentWrapper.js +28 -0
  261. package/esm/components/shared/ComponentWrapper.js.map +1 -0
  262. package/esm/components/shared/Declarations/Declarations.d.ts +16 -0
  263. package/esm/components/shared/Declarations/Declarations.js +14 -0
  264. package/esm/components/shared/Declarations/Declarations.js.map +1 -0
  265. package/esm/components/shared/Declarations/Declarations.spec.d.ts +1 -0
  266. package/esm/components/shared/Declarations/Declarations.spec.js +66 -0
  267. package/esm/components/shared/Declarations/Declarations.spec.js.map +1 -0
  268. package/esm/components/shared/Fieldset/Fieldset.d.ts +9 -0
  269. package/esm/components/shared/Fieldset/Fieldset.js +28 -0
  270. package/esm/components/shared/Fieldset/Fieldset.js.map +1 -0
  271. package/esm/components/shared/Fieldset/Fieldset.spec.d.ts +1 -0
  272. package/esm/components/shared/Fieldset/Fieldset.spec.js +25 -0
  273. package/esm/components/shared/Fieldset/Fieldset.spec.js.map +1 -0
  274. package/esm/components/shared/HOC/slottableComponent.d.ts +101 -0
  275. package/esm/components/shared/HOC/slottableComponent.js +31 -0
  276. package/esm/components/shared/HOC/slottableComponent.js.map +1 -0
  277. package/esm/components/shared/Icons/checkbox-checked-icon.d.ts +2 -0
  278. package/esm/components/shared/Icons/checkbox-checked-icon.js +6 -0
  279. package/esm/components/shared/Icons/checkbox-checked-icon.js.map +1 -0
  280. package/esm/components/shared/Icons/checkbox-disabled-icon.d.ts +2 -0
  281. package/esm/components/shared/Icons/checkbox-disabled-icon.js +6 -0
  282. package/esm/components/shared/Icons/checkbox-disabled-icon.js.map +1 -0
  283. package/esm/components/shared/Icons/checkbox-unchecked-icon.d.ts +2 -0
  284. package/esm/components/shared/Icons/checkbox-unchecked-icon.js +6 -0
  285. package/esm/components/shared/Icons/checkbox-unchecked-icon.js.map +1 -0
  286. package/esm/components/shared/Icons/closed-icon.d.ts +2 -0
  287. package/esm/components/shared/Icons/closed-icon.js +6 -0
  288. package/esm/components/shared/Icons/closed-icon.js.map +1 -0
  289. package/esm/components/shared/Icons/cross-icon.d.ts +2 -0
  290. package/esm/components/shared/Icons/cross-icon.js +6 -0
  291. package/esm/components/shared/Icons/cross-icon.js.map +1 -0
  292. package/esm/components/shared/Icons/icon-props.d.ts +5 -0
  293. package/esm/components/shared/Icons/icon-props.js +2 -0
  294. package/esm/components/shared/Icons/icon-props.js.map +1 -0
  295. package/esm/components/shared/Icons/index.d.ts +10 -0
  296. package/esm/components/shared/Icons/index.js +11 -0
  297. package/esm/components/shared/Icons/index.js.map +1 -0
  298. package/esm/components/shared/Icons/load-icon.d.ts +2 -0
  299. package/esm/components/shared/Icons/load-icon.js +6 -0
  300. package/esm/components/shared/Icons/load-icon.js.map +1 -0
  301. package/esm/components/shared/Icons/lunatic-icon.d.ts +4 -0
  302. package/esm/components/shared/Icons/lunatic-icon.js +6 -0
  303. package/esm/components/shared/Icons/lunatic-icon.js.map +1 -0
  304. package/esm/components/shared/Icons/network-icon.d.ts +2 -0
  305. package/esm/components/shared/Icons/network-icon.js +6 -0
  306. package/esm/components/shared/Icons/network-icon.js.map +1 -0
  307. package/esm/components/shared/Icons/on-drag-icon.d.ts +2 -0
  308. package/esm/components/shared/Icons/on-drag-icon.js +6 -0
  309. package/esm/components/shared/Icons/on-drag-icon.js.map +1 -0
  310. package/esm/components/shared/Icons/opened-icon.d.ts +2 -0
  311. package/esm/components/shared/Icons/opened-icon.js +6 -0
  312. package/esm/components/shared/Icons/opened-icon.js.map +1 -0
  313. package/esm/components/shared/Icons/radio-checked-icon.d.ts +3 -0
  314. package/esm/components/shared/Icons/radio-checked-icon.js +7 -0
  315. package/esm/components/shared/Icons/radio-checked-icon.js.map +1 -0
  316. package/esm/components/shared/Icons/radio-unchecked-icon.d.ts +2 -0
  317. package/esm/components/shared/Icons/radio-unchecked-icon.js +6 -0
  318. package/esm/components/shared/Icons/radio-unchecked-icon.js.map +1 -0
  319. package/esm/components/shared/Label/Label.d.ts +10 -0
  320. package/esm/components/shared/Label/Label.js +15 -0
  321. package/esm/components/shared/Label/Label.js.map +1 -0
  322. package/esm/components/shared/Label/Label.spec.d.ts +1 -0
  323. package/esm/components/shared/Label/Label.spec.js +19 -0
  324. package/esm/components/shared/Label/Label.spec.js.map +1 -0
  325. package/esm/components/shared/LabelDescription.d.ts +7 -0
  326. package/esm/components/shared/LabelDescription.js +11 -0
  327. package/esm/components/shared/LabelDescription.js.map +1 -0
  328. package/esm/components/shared/MDLabel/MDLabel.d.ts +5 -0
  329. package/esm/components/shared/MDLabel/MDLabel.js +20 -0
  330. package/esm/components/shared/MDLabel/MDLabel.js.map +1 -0
  331. package/esm/components/shared/MDLabel/MDLabel.spec.d.ts +1 -0
  332. package/esm/components/shared/MDLabel/MDLabel.spec.js +107 -0
  333. package/esm/components/shared/MDLabel/MDLabel.spec.js.map +1 -0
  334. package/esm/components/shared/MDLabel/MarkdownLink.d.ts +7 -0
  335. package/esm/components/shared/MDLabel/MarkdownLink.js +14 -0
  336. package/esm/components/shared/MDLabel/MarkdownLink.js.map +1 -0
  337. package/esm/components/shared/MDLabel/RouterLink.d.ts +6 -0
  338. package/esm/components/shared/MDLabel/RouterLink.js +7 -0
  339. package/esm/components/shared/MDLabel/RouterLink.js.map +1 -0
  340. package/esm/components/shared/Missing/Missing.d.ts +14 -0
  341. package/esm/components/shared/Missing/Missing.js +52 -0
  342. package/esm/components/shared/Missing/Missing.js.map +1 -0
  343. package/esm/components/shared/Missing/Missing.spec.d.ts +1 -0
  344. package/esm/components/shared/Missing/Missing.spec.js +45 -0
  345. package/esm/components/shared/Missing/Missing.spec.js.map +1 -0
  346. package/esm/components/shared/ModalControls/ModalControls.d.ts +10 -0
  347. package/esm/components/shared/ModalControls/ModalControls.js +29 -0
  348. package/esm/components/shared/ModalControls/ModalControls.js.map +1 -0
  349. package/esm/components/shared/ModalControls/ModalControls.spec.d.ts +1 -0
  350. package/esm/components/shared/ModalControls/ModalControls.spec.js +61 -0
  351. package/esm/components/shared/ModalControls/ModalControls.spec.js.map +1 -0
  352. package/esm/components/shared/Notification.d.ts +8 -0
  353. package/esm/components/shared/Notification.js +8 -0
  354. package/esm/components/shared/Notification.js.map +1 -0
  355. package/esm/components/shared/Radio/RadioGroup.d.ts +7 -0
  356. package/esm/components/shared/Radio/RadioGroup.js +23 -0
  357. package/esm/components/shared/Radio/RadioGroup.js.map +1 -0
  358. package/esm/components/shared/Radio/RadioOption.d.ts +17 -0
  359. package/esm/components/shared/Radio/RadioOption.js +38 -0
  360. package/esm/components/shared/Radio/RadioOption.js.map +1 -0
  361. package/esm/components/shared/Radio/RadioOption.spec.d.ts +1 -0
  362. package/esm/components/shared/Radio/RadioOption.spec.js +46 -0
  363. package/esm/components/shared/Radio/RadioOption.spec.js.map +1 -0
  364. package/esm/components/shared/Table/Table.d.ts +8 -0
  365. package/esm/components/shared/Table/Table.js +13 -0
  366. package/esm/components/shared/Table/Table.js.map +1 -0
  367. package/esm/components/shared/Table/Table.spec.d.ts +1 -0
  368. package/esm/components/shared/Table/Table.spec.js +15 -0
  369. package/esm/components/shared/Table/Table.spec.js.map +1 -0
  370. package/esm/components/shared/Table/TableHeader.d.ts +2 -0
  371. package/esm/components/shared/Table/TableHeader.js +14 -0
  372. package/esm/components/shared/Table/TableHeader.js.map +1 -0
  373. package/esm/components/shared/Table/Tbody.d.ts +6 -0
  374. package/esm/components/shared/Table/Tbody.js +8 -0
  375. package/esm/components/shared/Table/Tbody.js.map +1 -0
  376. package/esm/components/shared/Table/Tbody.spec.d.ts +1 -0
  377. package/esm/components/shared/Table/Tbody.spec.js +22 -0
  378. package/esm/components/shared/Table/Tbody.spec.js.map +1 -0
  379. package/esm/components/shared/Table/Td.d.ts +11 -0
  380. package/esm/components/shared/Table/Td.js +8 -0
  381. package/esm/components/shared/Table/Td.js.map +1 -0
  382. package/esm/components/shared/Table/Td.spec.d.ts +1 -0
  383. package/esm/components/shared/Table/Td.spec.js +21 -0
  384. package/esm/components/shared/Table/Td.spec.js.map +1 -0
  385. package/esm/components/shared/Table/Th.d.ts +10 -0
  386. package/esm/components/shared/Table/Th.js +8 -0
  387. package/esm/components/shared/Table/Th.js.map +1 -0
  388. package/esm/components/shared/Table/Th.spec.d.ts +1 -0
  389. package/esm/components/shared/Table/Th.spec.js +25 -0
  390. package/esm/components/shared/Table/Th.spec.js.map +1 -0
  391. package/esm/components/shared/Table/Thead.d.ts +6 -0
  392. package/esm/components/shared/Table/Thead.js +8 -0
  393. package/esm/components/shared/Table/Thead.js.map +1 -0
  394. package/esm/components/shared/Table/Thead.spec.d.ts +1 -0
  395. package/esm/components/shared/Table/Thead.spec.js +12 -0
  396. package/esm/components/shared/Table/Thead.spec.js.map +1 -0
  397. package/esm/components/shared/Table/Tr.d.ts +7 -0
  398. package/esm/components/shared/Table/Tr.js +8 -0
  399. package/esm/components/shared/Table/Tr.js.map +1 -0
  400. package/esm/components/shared/Table/Tr.spec.d.ts +1 -0
  401. package/esm/components/shared/Table/Tr.spec.js +19 -0
  402. package/esm/components/shared/Table/Tr.spec.js.map +1 -0
  403. package/esm/components/shared/Table/index.d.ts +7 -0
  404. package/esm/components/shared/Table/index.js +8 -0
  405. package/esm/components/shared/Table/index.js.map +1 -0
  406. package/esm/components/type.d.ts +305 -0
  407. package/esm/components/type.js +2 -0
  408. package/esm/components/type.js.map +1 -0
  409. package/esm/constants/component-types.d.ts +1 -0
  410. package/esm/constants/component-types.js +2 -0
  411. package/esm/constants/component-types.js.map +1 -0
  412. package/esm/constants/declarations.d.ts +9 -0
  413. package/esm/constants/declarations.js +12 -0
  414. package/esm/constants/declarations.js.map +1 -0
  415. package/esm/constants/event-types.d.ts +10 -0
  416. package/esm/constants/event-types.js +13 -0
  417. package/esm/constants/event-types.js.map +1 -0
  418. package/esm/constants/index.d.ts +5 -0
  419. package/esm/constants/index.js +6 -0
  420. package/esm/constants/index.js.map +1 -0
  421. package/esm/constants/indexedDBStore.d.ts +21 -0
  422. package/esm/constants/indexedDBStore.js +19 -0
  423. package/esm/constants/indexedDBStore.js.map +1 -0
  424. package/esm/constants/supported-preferences.d.ts +1 -0
  425. package/esm/constants/supported-preferences.js +10 -0
  426. package/esm/constants/supported-preferences.js.map +1 -0
  427. package/esm/constants/value-types.d.ts +5 -0
  428. package/esm/constants/value-types.js +6 -0
  429. package/esm/constants/value-types.js.map +1 -0
  430. package/esm/constants/variable-types.d.ts +2 -0
  431. package/esm/constants/variable-types.js +5 -0
  432. package/esm/constants/variable-types.js.map +1 -0
  433. package/esm/hooks/use-auto-focus.d.ts +6 -0
  434. package/esm/hooks/use-auto-focus.js +19 -0
  435. package/esm/hooks/use-auto-focus.js.map +1 -0
  436. package/esm/hooks/use-track-changes.d.ts +11 -0
  437. package/esm/hooks/use-track-changes.js +41 -0
  438. package/esm/hooks/use-track-changes.js.map +1 -0
  439. package/esm/hooks/use-why-render.d.ts +4 -0
  440. package/esm/hooks/use-why-render.js +14 -0
  441. package/esm/hooks/use-why-render.js.map +1 -0
  442. package/esm/hooks/useDebounce.d.ts +4 -0
  443. package/esm/hooks/useDebounce.js +24 -0
  444. package/esm/hooks/useDebounce.js.map +1 -0
  445. package/esm/hooks/useDocumentEvent.d.ts +2 -0
  446. package/esm/hooks/useDocumentEvent.js +18 -0
  447. package/esm/hooks/useDocumentEvent.js.map +1 -0
  448. package/esm/hooks/useKeyboardKey.d.ts +4 -0
  449. package/esm/hooks/useKeyboardKey.js +25 -0
  450. package/esm/hooks/useKeyboardKey.js.map +1 -0
  451. package/esm/hooks/useListKeyboardHandler.d.ts +11 -0
  452. package/esm/hooks/useListKeyboardHandler.js +28 -0
  453. package/esm/hooks/useListKeyboardHandler.js.map +1 -0
  454. package/esm/hooks/useRefSync.d.ts +4 -0
  455. package/esm/hooks/useRefSync.js +10 -0
  456. package/esm/hooks/useRefSync.js.map +1 -0
  457. package/esm/i18n/build-dictionary.d.ts +24 -0
  458. package/esm/i18n/build-dictionary.js +37 -0
  459. package/esm/i18n/build-dictionary.js.map +1 -0
  460. package/esm/i18n/dictionary.d.ts +57 -0
  461. package/esm/i18n/dictionary.js +27 -0
  462. package/esm/i18n/dictionary.js.map +1 -0
  463. package/esm/i18n/index.d.ts +7 -0
  464. package/esm/i18n/index.js +13 -0
  465. package/esm/i18n/index.js.map +1 -0
  466. package/esm/i18n/inputNumberProps.d.ts +13 -0
  467. package/esm/i18n/inputNumberProps.js +7 -0
  468. package/esm/i18n/inputNumberProps.js.map +1 -0
  469. package/esm/index.d.ts +14 -0
  470. package/esm/index.js +12 -0
  471. package/esm/index.js.map +1 -0
  472. package/esm/tests/setup.d.ts +1 -0
  473. package/esm/tests/setup.js +18 -0
  474. package/esm/tests/setup.js.map +1 -0
  475. package/esm/tests/utils/lunatic.d.ts +19 -0
  476. package/esm/tests/utils/lunatic.js +31 -0
  477. package/esm/tests/utils/lunatic.js.map +1 -0
  478. package/esm/tests/utils/timer.d.ts +1 -0
  479. package/esm/tests/utils/timer.js +4 -0
  480. package/esm/tests/utils/timer.js.map +1 -0
  481. package/esm/tsconfig-esm.tsbuildinfo +1 -0
  482. package/esm/type.source.d.ts +408 -0
  483. package/esm/type.source.js +7 -0
  484. package/esm/type.source.js.map +1 -0
  485. package/esm/type.utils.d.ts +5 -0
  486. package/esm/type.utils.js +2 -0
  487. package/esm/type.utils.js.map +1 -0
  488. package/esm/use-lunatic/actions.d.ts +50 -0
  489. package/esm/use-lunatic/actions.js +26 -0
  490. package/esm/use-lunatic/actions.js.map +1 -0
  491. package/esm/use-lunatic/commons/check-loops.d.ts +30 -0
  492. package/esm/use-lunatic/commons/check-loops.js +63 -0
  493. package/esm/use-lunatic/commons/check-loops.js.map +1 -0
  494. package/esm/use-lunatic/commons/check-pager.d.ts +5 -0
  495. package/esm/use-lunatic/commons/check-pager.js +17 -0
  496. package/esm/use-lunatic/commons/check-pager.js.map +1 -0
  497. package/esm/use-lunatic/commons/compile-controls.d.ts +9 -0
  498. package/esm/use-lunatic/commons/compile-controls.js +156 -0
  499. package/esm/use-lunatic/commons/compile-controls.js.map +1 -0
  500. package/esm/use-lunatic/commons/component.d.ts +22 -0
  501. package/esm/use-lunatic/commons/component.js +22 -0
  502. package/esm/use-lunatic/commons/component.js.map +1 -0
  503. package/esm/use-lunatic/commons/create-map-pages.d.ts +6 -0
  504. package/esm/use-lunatic/commons/create-map-pages.js +58 -0
  505. package/esm/use-lunatic/commons/create-map-pages.js.map +1 -0
  506. package/esm/use-lunatic/commons/execute-condition-filter.d.ts +3 -0
  507. package/esm/use-lunatic/commons/execute-condition-filter.js +11 -0
  508. package/esm/use-lunatic/commons/execute-condition-filter.js.map +1 -0
  509. package/esm/use-lunatic/commons/fill-components/fill-component-expressions.d.ts +34 -0
  510. package/esm/use-lunatic/commons/fill-components/fill-component-expressions.js +149 -0
  511. package/esm/use-lunatic/commons/fill-components/fill-component-expressions.js.map +1 -0
  512. package/esm/use-lunatic/commons/fill-components/fill-component-expressions.spec.d.ts +1 -0
  513. package/esm/use-lunatic/commons/fill-components/fill-component-expressions.spec.js +83 -0
  514. package/esm/use-lunatic/commons/fill-components/fill-component-expressions.spec.js.map +1 -0
  515. package/esm/use-lunatic/commons/fill-components/fill-components.d.ts +25 -0
  516. package/esm/use-lunatic/commons/fill-components/fill-components.js +41 -0
  517. package/esm/use-lunatic/commons/fill-components/fill-components.js.map +1 -0
  518. package/esm/use-lunatic/commons/get-compatible-vtl-expression.d.ts +7 -0
  519. package/esm/use-lunatic/commons/get-compatible-vtl-expression.js +19 -0
  520. package/esm/use-lunatic/commons/get-compatible-vtl-expression.js.map +1 -0
  521. package/esm/use-lunatic/commons/get-components-from-state.d.ts +5 -0
  522. package/esm/use-lunatic/commons/get-components-from-state.js +22 -0
  523. package/esm/use-lunatic/commons/get-components-from-state.js.map +1 -0
  524. package/esm/use-lunatic/commons/index.d.ts +6 -0
  525. package/esm/use-lunatic/commons/index.js +7 -0
  526. package/esm/use-lunatic/commons/index.js.map +1 -0
  527. package/esm/use-lunatic/commons/is-First-last-page.d.ts +6 -0
  528. package/esm/use-lunatic/commons/is-First-last-page.js +8 -0
  529. package/esm/use-lunatic/commons/is-First-last-page.js.map +1 -0
  530. package/esm/use-lunatic/commons/is-paginated-loop.d.ts +6 -0
  531. package/esm/use-lunatic/commons/is-paginated-loop.js +5 -0
  532. package/esm/use-lunatic/commons/is-paginated-loop.js.map +1 -0
  533. package/esm/use-lunatic/commons/is-roundabout.d.ts +2 -0
  534. package/esm/use-lunatic/commons/is-roundabout.js +5 -0
  535. package/esm/use-lunatic/commons/is-roundabout.js.map +1 -0
  536. package/esm/use-lunatic/commons/page-navigation.d.ts +7 -0
  537. package/esm/use-lunatic/commons/page-navigation.js +95 -0
  538. package/esm/use-lunatic/commons/page-navigation.js.map +1 -0
  539. package/esm/use-lunatic/commons/page-navigation.spec.d.ts +1 -0
  540. package/esm/use-lunatic/commons/page-navigation.spec.js +136 -0
  541. package/esm/use-lunatic/commons/page-navigation.spec.js.map +1 -0
  542. package/esm/use-lunatic/commons/page-tag.d.ts +23 -0
  543. package/esm/use-lunatic/commons/page-tag.js +56 -0
  544. package/esm/use-lunatic/commons/page-tag.js.map +1 -0
  545. package/esm/use-lunatic/commons/page-tag.spec.d.ts +1 -0
  546. package/esm/use-lunatic/commons/page-tag.spec.js +38 -0
  547. package/esm/use-lunatic/commons/page-tag.spec.js.map +1 -0
  548. package/esm/use-lunatic/commons/page.d.ts +11 -0
  549. package/esm/use-lunatic/commons/page.js +35 -0
  550. package/esm/use-lunatic/commons/page.js.map +1 -0
  551. package/esm/use-lunatic/commons/variables/behaviours/cleaning-behaviour.d.ts +7 -0
  552. package/esm/use-lunatic/commons/variables/behaviours/cleaning-behaviour.js +55 -0
  553. package/esm/use-lunatic/commons/variables/behaviours/cleaning-behaviour.js.map +1 -0
  554. package/esm/use-lunatic/commons/variables/behaviours/missing-behaviour.d.ts +7 -0
  555. package/esm/use-lunatic/commons/variables/behaviours/missing-behaviour.js +26 -0
  556. package/esm/use-lunatic/commons/variables/behaviours/missing-behaviour.js.map +1 -0
  557. package/esm/use-lunatic/commons/variables/behaviours/resizing-behaviour.d.ts +7 -0
  558. package/esm/use-lunatic/commons/variables/behaviours/resizing-behaviour.js +62 -0
  559. package/esm/use-lunatic/commons/variables/behaviours/resizing-behaviour.js.map +1 -0
  560. package/esm/use-lunatic/commons/variables/errors.d.ts +19 -0
  561. package/esm/use-lunatic/commons/variables/errors.js +28 -0
  562. package/esm/use-lunatic/commons/variables/errors.js.map +1 -0
  563. package/esm/use-lunatic/commons/variables/get-questionnaire-data.d.ts +3 -0
  564. package/esm/use-lunatic/commons/variables/get-questionnaire-data.js +53 -0
  565. package/esm/use-lunatic/commons/variables/get-questionnaire-data.js.map +1 -0
  566. package/esm/use-lunatic/commons/variables/lunatic-variables-store.d.ts +90 -0
  567. package/esm/use-lunatic/commons/variables/lunatic-variables-store.js +349 -0
  568. package/esm/use-lunatic/commons/variables/lunatic-variables-store.js.map +1 -0
  569. package/esm/use-lunatic/commons/variables/lunatic-variables-store.spec.d.ts +1 -0
  570. package/esm/use-lunatic/commons/variables/lunatic-variables-store.spec.js +438 -0
  571. package/esm/use-lunatic/commons/variables/lunatic-variables-store.spec.js.map +1 -0
  572. package/esm/use-lunatic/hooks/use-loop-variables.d.ts +5 -0
  573. package/esm/use-lunatic/hooks/use-loop-variables.js +18 -0
  574. package/esm/use-lunatic/hooks/use-loop-variables.js.map +1 -0
  575. package/esm/use-lunatic/hooks/use-page-has-response.d.ts +6 -0
  576. package/esm/use-lunatic/hooks/use-page-has-response.js +89 -0
  577. package/esm/use-lunatic/hooks/use-page-has-response.js.map +1 -0
  578. package/esm/use-lunatic/hooks/useOverview.d.ts +16 -0
  579. package/esm/use-lunatic/hooks/useOverview.js +92 -0
  580. package/esm/use-lunatic/hooks/useOverview.js.map +1 -0
  581. package/esm/use-lunatic/hooks/useWarnDepChange.d.ts +6 -0
  582. package/esm/use-lunatic/hooks/useWarnDepChange.js +17 -0
  583. package/esm/use-lunatic/hooks/useWarnDepChange.js.map +1 -0
  584. package/esm/use-lunatic/logger/ConsoleLogger.d.ts +5 -0
  585. package/esm/use-lunatic/logger/ConsoleLogger.js +12 -0
  586. package/esm/use-lunatic/logger/ConsoleLogger.js.map +1 -0
  587. package/esm/use-lunatic/logger/type.d.ts +9 -0
  588. package/esm/use-lunatic/logger/type.js +2 -0
  589. package/esm/use-lunatic/logger/type.js.map +1 -0
  590. package/esm/use-lunatic/lunatic-context.d.ts +28 -0
  591. package/esm/use-lunatic/lunatic-context.js +44 -0
  592. package/esm/use-lunatic/lunatic-context.js.map +1 -0
  593. package/esm/use-lunatic/props/getComponentTypeProps.d.ts +291 -0
  594. package/esm/use-lunatic/props/getComponentTypeProps.js +165 -0
  595. package/esm/use-lunatic/props/getComponentTypeProps.js.map +1 -0
  596. package/esm/use-lunatic/props/propIterations.d.ts +7 -0
  597. package/esm/use-lunatic/props/propIterations.js +26 -0
  598. package/esm/use-lunatic/props/propIterations.js.map +1 -0
  599. package/esm/use-lunatic/props/propMissingResponse.d.ts +9 -0
  600. package/esm/use-lunatic/props/propMissingResponse.js +13 -0
  601. package/esm/use-lunatic/props/propMissingResponse.js.map +1 -0
  602. package/esm/use-lunatic/props/propOptions.d.ts +37 -0
  603. package/esm/use-lunatic/props/propOptions.js +75 -0
  604. package/esm/use-lunatic/props/propOptions.js.map +1 -0
  605. package/esm/use-lunatic/props/propOptions.spec.d.ts +1 -0
  606. package/esm/use-lunatic/props/propOptions.spec.js +57 -0
  607. package/esm/use-lunatic/props/propOptions.spec.js.map +1 -0
  608. package/esm/use-lunatic/props/propValue.d.ts +6 -0
  609. package/esm/use-lunatic/props/propValue.js +29 -0
  610. package/esm/use-lunatic/props/propValue.js.map +1 -0
  611. package/esm/use-lunatic/props/propValue.spec.d.ts +1 -0
  612. package/esm/use-lunatic/props/propValue.spec.js +54 -0
  613. package/esm/use-lunatic/props/propValue.spec.js.map +1 -0
  614. package/esm/use-lunatic/reducer/commons/auto-explore-loop.d.ts +5 -0
  615. package/esm/use-lunatic/reducer/commons/auto-explore-loop.js +52 -0
  616. package/esm/use-lunatic/reducer/commons/auto-explore-loop.js.map +1 -0
  617. package/esm/use-lunatic/reducer/commons/index.d.ts +2 -0
  618. package/esm/use-lunatic/reducer/commons/index.js +3 -0
  619. package/esm/use-lunatic/reducer/commons/index.js.map +1 -0
  620. package/esm/use-lunatic/reducer/commons/resize-array-variable.d.ts +5 -0
  621. package/esm/use-lunatic/reducer/commons/resize-array-variable.js +21 -0
  622. package/esm/use-lunatic/reducer/commons/resize-array-variable.js.map +1 -0
  623. package/esm/use-lunatic/reducer/commons/validate-condition-filter.d.ts +6 -0
  624. package/esm/use-lunatic/reducer/commons/validate-condition-filter.js +12 -0
  625. package/esm/use-lunatic/reducer/commons/validate-condition-filter.js.map +1 -0
  626. package/esm/use-lunatic/reducer/controls/check-base-control.d.ts +2 -0
  627. package/esm/use-lunatic/reducer/controls/check-base-control.js +35 -0
  628. package/esm/use-lunatic/reducer/controls/check-base-control.js.map +1 -0
  629. package/esm/use-lunatic/reducer/controls/check-roundabout-control.d.ts +9 -0
  630. package/esm/use-lunatic/reducer/controls/check-roundabout-control.js +22 -0
  631. package/esm/use-lunatic/reducer/controls/check-roundabout-control.js.map +1 -0
  632. package/esm/use-lunatic/reducer/overview/overviewOnInit.d.ts +6 -0
  633. package/esm/use-lunatic/reducer/overview/overviewOnInit.js +50 -0
  634. package/esm/use-lunatic/reducer/overview/overviewOnInit.js.map +1 -0
  635. package/esm/use-lunatic/reducer/reduce-go-next-page.d.ts +2 -0
  636. package/esm/use-lunatic/reducer/reduce-go-next-page.js +62 -0
  637. package/esm/use-lunatic/reducer/reduce-go-next-page.js.map +1 -0
  638. package/esm/use-lunatic/reducer/reduce-go-previous-page.d.ts +2 -0
  639. package/esm/use-lunatic/reducer/reduce-go-previous-page.js +31 -0
  640. package/esm/use-lunatic/reducer/reduce-go-previous-page.js.map +1 -0
  641. package/esm/use-lunatic/reducer/reduce-go-to-page.d.ts +3 -0
  642. package/esm/use-lunatic/reducer/reduce-go-to-page.js +55 -0
  643. package/esm/use-lunatic/reducer/reduce-go-to-page.js.map +1 -0
  644. package/esm/use-lunatic/reducer/reduce-handle-changes.d.ts +6 -0
  645. package/esm/use-lunatic/reducer/reduce-handle-changes.js +26 -0
  646. package/esm/use-lunatic/reducer/reduce-handle-changes.js.map +1 -0
  647. package/esm/use-lunatic/reducer/reducer.d.ts +3 -0
  648. package/esm/use-lunatic/reducer/reducer.js +20 -0
  649. package/esm/use-lunatic/reducer/reducer.js.map +1 -0
  650. package/esm/use-lunatic/reducer/reducerInitializer.d.ts +14 -0
  651. package/esm/use-lunatic/reducer/reducerInitializer.js +130 -0
  652. package/esm/use-lunatic/reducer/reducerInitializer.js.map +1 -0
  653. package/esm/use-lunatic/replace-component-sequence.d.ts +36 -0
  654. package/esm/use-lunatic/replace-component-sequence.js +19 -0
  655. package/esm/use-lunatic/replace-component-sequence.js.map +1 -0
  656. package/esm/use-lunatic/type.d.ts +166 -0
  657. package/esm/use-lunatic/type.js +2 -0
  658. package/esm/use-lunatic/type.js.map +1 -0
  659. package/esm/use-lunatic/use-lunatic.d.ts +37 -0
  660. package/esm/use-lunatic/use-lunatic.js +140 -0
  661. package/esm/use-lunatic/use-lunatic.js.map +1 -0
  662. package/esm/utils/array.d.ts +32 -0
  663. package/esm/utils/array.js +107 -0
  664. package/esm/utils/array.js.map +1 -0
  665. package/esm/utils/array.spec.d.ts +1 -0
  666. package/esm/utils/array.spec.js +42 -0
  667. package/esm/utils/array.spec.js.map +1 -0
  668. package/esm/utils/constants/alphabet.d.ts +1 -0
  669. package/esm/utils/constants/alphabet.js +2 -0
  670. package/esm/utils/constants/alphabet.js.map +1 -0
  671. package/esm/utils/constants/features.d.ts +4 -0
  672. package/esm/utils/constants/features.js +5 -0
  673. package/esm/utils/constants/features.js.map +1 -0
  674. package/esm/utils/constants/index.d.ts +5 -0
  675. package/esm/utils/constants/index.js +6 -0
  676. package/esm/utils/constants/index.js.map +1 -0
  677. package/esm/utils/constants/links.d.ts +2 -0
  678. package/esm/utils/constants/links.js +3 -0
  679. package/esm/utils/constants/links.js.map +1 -0
  680. package/esm/utils/constants/missing.d.ts +2 -0
  681. package/esm/utils/constants/missing.js +3 -0
  682. package/esm/utils/constants/missing.js.map +1 -0
  683. package/esm/utils/constants/variable-status.d.ts +5 -0
  684. package/esm/utils/constants/variable-status.js +6 -0
  685. package/esm/utils/constants/variable-status.js.map +1 -0
  686. package/esm/utils/constants/variable-types.d.ts +1 -0
  687. package/esm/utils/constants/variable-types.js +2 -0
  688. package/esm/utils/constants/variable-types.js.map +1 -0
  689. package/esm/utils/dom.d.ts +14 -0
  690. package/esm/utils/dom.js +23 -0
  691. package/esm/utils/dom.js.map +1 -0
  692. package/esm/utils/env.d.ts +1 -0
  693. package/esm/utils/env.js +13 -0
  694. package/esm/utils/env.js.map +1 -0
  695. package/esm/utils/function.d.ts +5 -0
  696. package/esm/utils/function.js +23 -0
  697. package/esm/utils/function.js.map +1 -0
  698. package/esm/utils/is-element.d.ts +3 -0
  699. package/esm/utils/is-element.js +6 -0
  700. package/esm/utils/is-element.js.map +1 -0
  701. package/esm/utils/is-object.d.ts +4 -0
  702. package/esm/utils/is-object.js +7 -0
  703. package/esm/utils/is-object.js.map +1 -0
  704. package/esm/utils/logger.d.ts +6 -0
  705. package/esm/utils/logger.js +15 -0
  706. package/esm/utils/logger.js.map +1 -0
  707. package/esm/utils/number.d.ts +9 -0
  708. package/esm/utils/number.js +32 -0
  709. package/esm/utils/number.js.map +1 -0
  710. package/esm/utils/number.spec.d.ts +1 -0
  711. package/esm/utils/number.spec.js +10 -0
  712. package/esm/utils/number.spec.js.map +1 -0
  713. package/esm/utils/object.d.ts +6 -0
  714. package/esm/utils/object.js +27 -0
  715. package/esm/utils/object.js.map +1 -0
  716. package/esm/utils/search/SearchInterface.d.ts +12 -0
  717. package/esm/utils/search/SearchInterface.js +2 -0
  718. package/esm/utils/search/SearchInterface.js.map +1 -0
  719. package/esm/utils/search/SearchMinisearch.d.ts +11 -0
  720. package/esm/utils/search/SearchMinisearch.js +39 -0
  721. package/esm/utils/search/SearchMinisearch.js.map +1 -0
  722. package/esm/utils/search/SuggestersDatabase.d.ts +15 -0
  723. package/esm/utils/search/SuggestersDatabase.js +38 -0
  724. package/esm/utils/search/SuggestersDatabase.js.map +1 -0
  725. package/esm/utils/search/melauto.d.ts +15 -0
  726. package/esm/utils/search/melauto.js +44 -0
  727. package/esm/utils/search/melauto.js.map +1 -0
  728. package/esm/utils/search/tokenizer.d.ts +14 -0
  729. package/esm/utils/search/tokenizer.js +57 -0
  730. package/esm/utils/search/tokenizer.js.map +1 -0
  731. package/esm/utils/to-number.d.ts +4 -0
  732. package/esm/utils/to-number.js +13 -0
  733. package/esm/utils/to-number.js.map +1 -0
  734. package/esm/utils/variables.d.ts +5 -0
  735. package/esm/utils/variables.js +21 -0
  736. package/esm/utils/variables.js.map +1 -0
  737. package/esm/utils/variables.spec.d.ts +1 -0
  738. package/esm/utils/variables.spec.js +83 -0
  739. package/esm/utils/variables.spec.js.map +1 -0
  740. package/esm/utils/vtl.d.ts +14 -0
  741. package/esm/utils/vtl.js +93 -0
  742. package/esm/utils/vtl.js.map +1 -0
  743. package/package.json +750 -2
@@ -0,0 +1,7 @@
1
+ export declare const Accordion: import("react").ComponentType<import("../type").LunaticBaseProps<string> & import("../type").LunaticExtraProps & {
2
+ componentType?: "Accordion";
3
+ items: {
4
+ label: import("react").ReactNode;
5
+ body: import("react").ReactNode;
6
+ }[];
7
+ }>;
@@ -0,0 +1,6 @@
1
+ import { jsx as _jsx, jsxs as _jsxs } from "react/jsx-runtime";
2
+ import { slottableComponent } from '../shared/HOC/slottableComponent';
3
+ export const Accordion = slottableComponent('Accordion', function Accordion({ items }) {
4
+ return (_jsx("div", { className: "lunatic-accordion", children: items.map((item, k) => (_jsxs("details", { children: [_jsx("summary", { children: item.label }), item.body] }, k))) }));
5
+ });
6
+ //# sourceMappingURL=Accordion.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"Accordion.js","sourceRoot":"","sources":["../../../src/components/Accordion/Accordion.tsx"],"names":[],"mappings":";AAAA,OAAO,EAAE,kBAAkB,EAAE,MAAM,kCAAkC,CAAC;AAGtE,MAAM,CAAC,MAAM,SAAS,GAAG,kBAAkB,CAC1C,WAAW,EACX,SAAS,SAAS,CAAC,EAAE,KAAK,EAAE;IAC3B,OAAO,CACN,cAAK,SAAS,EAAC,mBAAmB,YAChC,KAAK,CAAC,GAAG,CAAC,CAAC,IAAI,EAAE,CAAC,EAAE,EAAE,CAAC,CACvB,8BACC,4BAAU,IAAI,CAAC,KAAK,GAAW,EAC9B,IAAI,CAAC,IAAI,KAFG,CAAC,CAGL,CACV,CAAC,GACG,CACN,CAAC;AACH,CAAC,CACD,CAAC"}
@@ -0,0 +1,10 @@
1
+ import type { LunaticComponentProps } from '../type';
2
+ import type { LunaticError } from '../../use-lunatic/type';
3
+ export declare function CheckboxBoolean({ handleChanges, response, errors, value, ...props }: LunaticComponentProps<'CheckboxBoolean'>): import("react/jsx-runtime").JSX.Element;
4
+ type CustomProps = Omit<LunaticComponentProps<'CheckboxBoolean'>, 'response' | 'handleChanges' | 'errors' | 'value'> & {
5
+ onChange: () => void;
6
+ errors?: LunaticError[];
7
+ checked?: boolean;
8
+ };
9
+ export declare const CustomCheckboxBoolean: import("react").ComponentType<CustomProps>;
10
+ export {};
@@ -0,0 +1,19 @@
1
+ import { jsx as _jsx, Fragment as _Fragment, jsxs as _jsxs } from "react/jsx-runtime";
2
+ import { ComponentErrors, getComponentErrors, } from '../shared/ComponentErrors/ComponentErrors';
3
+ import { CheckboxOption } from '../shared/Checkbox/CheckboxOption';
4
+ import { slottableComponent } from '../shared/HOC/slottableComponent';
5
+ import { Declarations } from '../shared/Declarations/Declarations';
6
+ export function CheckboxBoolean({ handleChanges, response, errors, value, ...props }) {
7
+ const checked = !!value;
8
+ return (_jsx(CustomCheckboxBoolean, { ...props, checked: checked, onChange: () => handleChanges([
9
+ {
10
+ name: response.name,
11
+ value: !checked,
12
+ },
13
+ ]), errors: getComponentErrors(errors, props.id) }));
14
+ }
15
+ export const CustomCheckboxBoolean = slottableComponent('CheckboxBoolean', (props) => {
16
+ const { disabled, checked, id, onChange, label, declarations, description, errors, } = props;
17
+ return (_jsxs("div", { className: "lunatic-checkbox-boolean", children: [_jsx(CheckboxOption, { disabled: disabled, checked: checked, id: id, onCheck: onChange, label: _jsxs(_Fragment, { children: [label, _jsx(Declarations, { type: "AFTER_QUESTION_TEXT", declarations: declarations })] }), description: description, invalid: !!errors }), _jsx(ComponentErrors, { errors: errors })] }));
18
+ });
19
+ //# sourceMappingURL=CheckboxBoolean.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"CheckboxBoolean.js","sourceRoot":"","sources":["../../../src/components/CheckboxBoolean/CheckboxBoolean.tsx"],"names":[],"mappings":";AACA,OAAO,EACN,eAAe,EACf,kBAAkB,GAClB,MAAM,2CAA2C,CAAC;AACnD,OAAO,EAAE,cAAc,EAAE,MAAM,mCAAmC,CAAC;AACnE,OAAO,EAAE,kBAAkB,EAAE,MAAM,kCAAkC,CAAC;AACtE,OAAO,EAAE,YAAY,EAAE,MAAM,qCAAqC,CAAC;AAGnE,MAAM,UAAU,eAAe,CAAC,EAC/B,aAAa,EACb,QAAQ,EACR,MAAM,EACN,KAAK,EACL,GAAG,KAAK,EACkC;IAC1C,MAAM,OAAO,GAAG,CAAC,CAAC,KAAK,CAAC;IACxB,OAAO,CACN,KAAC,qBAAqB,OACjB,KAAK,EACT,OAAO,EAAE,OAAO,EAChB,QAAQ,EAAE,GAAG,EAAE,CACd,aAAa,CAAC;YACb;gBACC,IAAI,EAAE,QAAQ,CAAC,IAAI;gBACnB,KAAK,EAAE,CAAC,OAAO;aACf;SACD,CAAC,EAEH,MAAM,EAAE,kBAAkB,CAAC,MAAM,EAAE,KAAK,CAAC,EAAE,CAAC,GAC3C,CACF,CAAC;AACH,CAAC;AAWD,MAAM,CAAC,MAAM,qBAAqB,GAAG,kBAAkB,CACtD,iBAAiB,EACjB,CAAC,KAAK,EAAE,EAAE;IACT,MAAM,EACL,QAAQ,EACR,OAAO,EACP,EAAE,EACF,QAAQ,EACR,KAAK,EACL,YAAY,EACZ,WAAW,EACX,MAAM,GACN,GAAG,KAAK,CAAC;IACV,OAAO,CACN,eAAK,SAAS,EAAC,0BAA0B,aACxC,KAAC,cAAc,IACd,QAAQ,EAAE,QAAQ,EAClB,OAAO,EAAE,OAAO,EAChB,EAAE,EAAE,EAAE,EACN,OAAO,EAAE,QAAQ,EACjB,KAAK,EACJ,8BACE,KAAK,EACN,KAAC,YAAY,IACZ,IAAI,EAAC,qBAAqB,EAC1B,YAAY,EAAE,YAAY,GACzB,IACA,EAEJ,WAAW,EAAE,WAAW,EACxB,OAAO,EAAE,CAAC,CAAC,MAAM,GAChB,EACF,KAAC,eAAe,IAAC,MAAM,EAAE,MAAM,GAAI,IAC9B,CACN,CAAC;AACH,CAAC,CACD,CAAC"}
@@ -0,0 +1,37 @@
1
+ import { jsx as _jsx } from "react/jsx-runtime";
2
+ import { render, fireEvent } from '@testing-library/react';
3
+ import { CheckboxBoolean } from './CheckboxBoolean';
4
+ import { describe, it, expect, vi, afterEach } from 'vitest';
5
+ describe('CheckboxBoolean', () => {
6
+ const label = 'I accept the terms and conditions';
7
+ const description = 'You must accept the terms and conditions to continue.';
8
+ const handleChanges = vi.fn();
9
+ const response = { name: 'demo' };
10
+ afterEach(() => {
11
+ vi.resetAllMocks();
12
+ });
13
+ it('renders label ', () => {
14
+ const { getByText } = render(_jsx(CheckboxBoolean, { id: "checkbox", label: label, value: true, handleChanges: handleChanges, response: response }));
15
+ expect(getByText(label)).toBeInTheDocument();
16
+ });
17
+ it('renders unchecked checkbox', () => {
18
+ const { getByRole } = render(_jsx(CheckboxBoolean, { id: "checkbox", label: label, description: description, value: false, handleChanges: handleChanges, response: response }));
19
+ const checkbox = getByRole('checkbox');
20
+ expect(checkbox).not.toBeChecked();
21
+ expect(checkbox).toBeEnabled();
22
+ });
23
+ it('renders checked checkbox', () => {
24
+ const { getByRole } = render(_jsx(CheckboxBoolean, { id: 'checkbox', label: label, description: description, value: true, handleChanges: handleChanges, response: response }));
25
+ const checkbox = getByRole('checkbox');
26
+ expect(checkbox).toBeChecked();
27
+ expect(checkbox).toBeEnabled();
28
+ });
29
+ it('calls onClick when checkbox is clicked', () => {
30
+ const { getByRole } = render(_jsx(CheckboxBoolean, { id: "checkbox", label: label, description: description, value: false, handleChanges: handleChanges, response: response }));
31
+ const checkbox = getByRole('checkbox');
32
+ fireEvent.click(checkbox);
33
+ expect(handleChanges).toHaveBeenCalledTimes(1);
34
+ expect(handleChanges).toHaveBeenCalledWith([{ ...response, value: true }]);
35
+ });
36
+ });
37
+ //# sourceMappingURL=CheckboxBoolean.spec.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"CheckboxBoolean.spec.js","sourceRoot":"","sources":["../../../src/components/CheckboxBoolean/CheckboxBoolean.spec.tsx"],"names":[],"mappings":"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"}
@@ -0,0 +1,2 @@
1
+ import type { LunaticComponentProps } from '../type';
2
+ export declare function CheckboxGroup({ id, shortcut, readOnly, options, disabled, errors, label, description, declarations, orientation, }: LunaticComponentProps<'CheckboxGroup'>): import("react/jsx-runtime").JSX.Element;
@@ -0,0 +1,7 @@
1
+ import { jsx as _jsx } from "react/jsx-runtime";
2
+ import { CustomCheckboxGroup } from './CustomCheckboxGroup';
3
+ import { getComponentErrors } from '../shared/ComponentErrors/ComponentErrors';
4
+ export function CheckboxGroup({ id, shortcut, readOnly, options, disabled, errors, label, description, declarations, orientation, }) {
5
+ return (_jsx(CustomCheckboxGroup, { id: id, description: description, options: options, label: label, errors: getComponentErrors(errors, id), shortcut: shortcut, disabled: disabled, readOnly: readOnly, declarations: declarations, orientation: orientation }));
6
+ }
7
+ //# sourceMappingURL=CheckboxGroup.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"CheckboxGroup.js","sourceRoot":"","sources":["../../../src/components/CheckboxGroup/CheckboxGroup.tsx"],"names":[],"mappings":";AACA,OAAO,EAAE,mBAAmB,EAAE,MAAM,uBAAuB,CAAC;AAC5D,OAAO,EAAE,kBAAkB,EAAE,MAAM,2CAA2C,CAAC;AAE/E,MAAM,UAAU,aAAa,CAAC,EAC7B,EAAE,EACF,QAAQ,EACR,QAAQ,EACR,OAAO,EACP,QAAQ,EACR,MAAM,EACN,KAAK,EACL,WAAW,EACX,YAAY,EACZ,WAAW,GAC6B;IACxC,OAAO,CACN,KAAC,mBAAmB,IACnB,EAAE,EAAE,EAAE,EACN,WAAW,EAAE,WAAW,EACxB,OAAO,EAAE,OAAO,EAChB,KAAK,EAAE,KAAK,EACZ,MAAM,EAAE,kBAAkB,CAAC,MAAM,EAAE,EAAE,CAAC,EACtC,QAAQ,EAAE,QAAQ,EAClB,QAAQ,EAAE,QAAQ,EAClB,QAAQ,EAAE,QAAQ,EAClB,YAAY,EAAE,YAAY,EAC1B,WAAW,EAAE,WAAW,GACvB,CACF,CAAC;AACH,CAAC"}
@@ -0,0 +1,7 @@
1
+ import type { LunaticError } from '../../use-lunatic/type';
2
+ import type { LunaticComponentProps } from '../type';
3
+ type Props = Pick<LunaticComponentProps<'CheckboxGroup'>, 'id' | 'label' | 'description' | 'declarations' | 'shortcut' | 'readOnly' | 'disabled' | 'options' | 'orientation'> & {
4
+ errors?: LunaticError[];
5
+ };
6
+ export declare const CustomCheckboxGroup: import("react").ComponentType<Props>;
7
+ export {};
@@ -0,0 +1,17 @@
1
+ import { jsx as _jsx, jsxs as _jsxs } from "react/jsx-runtime";
2
+ import { slottableComponent } from '../shared/HOC/slottableComponent';
3
+ import { ComponentErrors } from '../shared/ComponentErrors/ComponentErrors';
4
+ import { Fieldset } from '../shared/Fieldset/Fieldset';
5
+ import { CheckboxOption } from '../shared/Checkbox/CheckboxOption';
6
+ import { getShortcutKey } from '../shared/Checkbox/getShortcutKey';
7
+ import { Declarations } from '../shared/Declarations/Declarations';
8
+ import { CustomInput } from '../Input/Input';
9
+ export const CustomCheckboxGroup = slottableComponent('CheckboxGroup', ({ options, label, description, errors, shortcut, disabled, readOnly, declarations, orientation, }) => {
10
+ return (_jsxs(Fieldset, { className: "lunatic-checkbox-group", legend: label, description: description, children: [_jsx(Declarations, { type: "AFTER_QUESTION_TEXT", declarations: declarations }), _jsx("div", { className: `lunatic-checkboxes lunatic-checkboxes--${orientation}`, children: options.map((option, index) => {
11
+ var _a;
12
+ return (_jsxs("div", { className: `lunatic-checkbox-group-option`, children: [_jsx(CheckboxOption, { ...option, disabled: disabled, readOnly: readOnly, shortcut: shortcut, invalid: !!errors, id: option.id, codeModality: shortcut ? getShortcutKey(index, options.length) : undefined }), option.onDetailChange && option.checked && (_jsx(CustomInput, { id: "detailId", label: (_a = option.detailLabel) !== null && _a !== void 0 ? _a : 'Précisez :', value: typeof option.detailValue === 'string'
13
+ ? option.detailValue
14
+ : '', onChange: option.onDetailChange, disabled: disabled }))] }, option.id));
15
+ }) }), _jsx(ComponentErrors, { errors: errors })] }));
16
+ });
17
+ //# sourceMappingURL=CustomCheckboxGroup.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"CustomCheckboxGroup.js","sourceRoot":"","sources":["../../../src/components/CheckboxGroup/CustomCheckboxGroup.tsx"],"names":[],"mappings":";AACA,OAAO,EAAE,kBAAkB,EAAE,MAAM,kCAAkC,CAAC;AACtE,OAAO,EAAE,eAAe,EAAE,MAAM,2CAA2C,CAAC;AAC5E,OAAO,EAAE,QAAQ,EAAE,MAAM,6BAA6B,CAAC;AACvD,OAAO,EAAE,cAAc,EAAE,MAAM,mCAAmC,CAAC;AACnE,OAAO,EAAE,cAAc,EAAE,MAAM,mCAAmC,CAAC;AAEnE,OAAO,EAAE,YAAY,EAAE,MAAM,qCAAqC,CAAC;AACnE,OAAO,EAAE,WAAW,EAAE,MAAM,gBAAgB,CAAC;AAiB7C,MAAM,CAAC,MAAM,mBAAmB,GAAG,kBAAkB,CACpD,eAAe,EACf,CAAC,EACA,OAAO,EACP,KAAK,EACL,WAAW,EACX,MAAM,EACN,QAAQ,EACR,QAAQ,EACR,QAAQ,EACR,YAAY,EACZ,WAAW,GACJ,EAAE,EAAE;IACX,OAAO,CACN,MAAC,QAAQ,IACR,SAAS,EAAC,wBAAwB,EAClC,MAAM,EAAE,KAAK,EACb,WAAW,EAAE,WAAW,aAExB,KAAC,YAAY,IAAC,IAAI,EAAC,qBAAqB,EAAC,YAAY,EAAE,YAAY,GAAI,EACvE,cACC,SAAS,EAAE,0CAA0C,WAAW,EAAE,YAEjE,OAAO,CAAC,GAAG,CAAC,CAAC,MAAM,EAAE,KAAK,EAAE,EAAE;;oBAC9B,OAAO,CACN,eAAK,SAAS,EAAE,+BAA+B,aAC9C,KAAC,cAAc,OACV,MAAM,EACV,QAAQ,EAAE,QAAQ,EAClB,QAAQ,EAAE,QAAQ,EAClB,QAAQ,EAAE,QAAQ,EAClB,OAAO,EAAE,CAAC,CAAC,MAAM,EACjB,EAAE,EAAE,MAAM,CAAC,EAAE,EACb,YAAY,EACX,QAAQ,CAAC,CAAC,CAAC,cAAc,CAAC,KAAK,EAAE,OAAO,CAAC,MAAM,CAAC,CAAC,CAAC,CAAC,SAAS,GAE5D,EACD,MAAM,CAAC,cAAc,IAAI,MAAM,CAAC,OAAO,IAAI,CAC3C,KAAC,WAAW,IACX,EAAE,EAAC,UAAU,EACb,KAAK,EAAE,MAAA,MAAM,CAAC,WAAW,mCAAI,YAAY,EACzC,KAAK,EACJ,OAAO,MAAM,CAAC,WAAW,KAAK,QAAQ;oCACrC,CAAC,CAAC,MAAM,CAAC,WAAW;oCACpB,CAAC,CAAC,EAAE,EAEN,QAAQ,EAAE,MAAM,CAAC,cAAc,EAC/B,QAAQ,EAAE,QAAQ,GACjB,CACF,KAxBoD,MAAM,CAAC,EAAE,CAyBzD,CACN,CAAC;gBACH,CAAC,CAAC,GACG,EACN,KAAC,eAAe,IAAC,MAAM,EAAE,MAAM,GAAI,IACzB,CACX,CAAC;AACH,CAAC,CACD,CAAC"}
@@ -0,0 +1,45 @@
1
+ import { jsx as _jsx } from "react/jsx-runtime";
2
+ import { render, fireEvent } from '@testing-library/react';
3
+ import { describe, it, expect, vi } from 'vitest';
4
+ import { CustomCheckboxGroup } from './CustomCheckboxGroup';
5
+ describe('CheckboxGroupContent', () => {
6
+ const options = [
7
+ {
8
+ id: '1',
9
+ label: 'Option 1',
10
+ checked: false,
11
+ name: 'option1',
12
+ onCheck: vi.fn(),
13
+ },
14
+ {
15
+ id: '2',
16
+ label: 'Option 2',
17
+ checked: true,
18
+ name: 'option2',
19
+ onCheck: vi.fn(),
20
+ },
21
+ {
22
+ id: '3',
23
+ label: 'Option 3',
24
+ checked: false,
25
+ name: 'option3',
26
+ onCheck: vi.fn(),
27
+ },
28
+ ];
29
+ it('calls onCheck callback when an option is clicked', () => {
30
+ const { getByLabelText } = render(_jsx(CustomCheckboxGroup, { options: options, id: "test-checkbox-group" }));
31
+ const option1 = getByLabelText('Option 1');
32
+ const option2 = getByLabelText('Option 2');
33
+ const option3 = getByLabelText('Option 3');
34
+ fireEvent.click(option1);
35
+ expect(options[0].onCheck).toHaveBeenCalledTimes(1);
36
+ expect(options[0].onCheck).toHaveBeenCalledWith(true);
37
+ fireEvent.click(option2);
38
+ expect(options[1].onCheck).toHaveBeenCalledTimes(1);
39
+ expect(options[1].onCheck).toHaveBeenCalledWith(false);
40
+ fireEvent.click(option3);
41
+ expect(options[2].onCheck).toHaveBeenCalledTimes(1);
42
+ expect(options[2].onCheck).toHaveBeenCalledWith(true);
43
+ });
44
+ });
45
+ //# sourceMappingURL=CustomCheckboxGroup.spec.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"CustomCheckboxGroup.spec.js","sourceRoot":"","sources":["../../../src/components/CheckboxGroup/CustomCheckboxGroup.spec.tsx"],"names":[],"mappings":";AAAA,OAAO,EAAE,MAAM,EAAE,SAAS,EAAE,MAAM,wBAAwB,CAAC;AAC3D,OAAO,EAAE,QAAQ,EAAE,EAAE,EAAE,MAAM,EAAE,EAAE,EAAE,MAAM,QAAQ,CAAC;AAClD,OAAO,EAAE,mBAAmB,EAAE,MAAM,uBAAuB,CAAC;AAE5D,QAAQ,CAAC,sBAAsB,EAAE,GAAG,EAAE;IACrC,MAAM,OAAO,GAAG;QACf;YACC,EAAE,EAAE,GAAG;YACP,KAAK,EAAE,UAAU;YACjB,OAAO,EAAE,KAAK;YACd,IAAI,EAAE,SAAS;YACf,OAAO,EAAE,EAAE,CAAC,EAAE,EAAE;SAChB;QACD;YACC,EAAE,EAAE,GAAG;YACP,KAAK,EAAE,UAAU;YACjB,OAAO,EAAE,IAAI;YACb,IAAI,EAAE,SAAS;YACf,OAAO,EAAE,EAAE,CAAC,EAAE,EAAE;SAChB;QACD;YACC,EAAE,EAAE,GAAG;YACP,KAAK,EAAE,UAAU;YACjB,OAAO,EAAE,KAAK;YACd,IAAI,EAAE,SAAS;YACf,OAAO,EAAE,EAAE,CAAC,EAAE,EAAE;SAChB;KACD,CAAC;IAEF,EAAE,CAAC,kDAAkD,EAAE,GAAG,EAAE;QAC3D,MAAM,EAAE,cAAc,EAAE,GAAG,MAAM,CAChC,KAAC,mBAAmB,IAAC,OAAO,EAAE,OAAO,EAAE,EAAE,EAAC,qBAAqB,GAAG,CAClE,CAAC;QAEF,MAAM,OAAO,GAAG,cAAc,CAAC,UAAU,CAAC,CAAC;QAC3C,MAAM,OAAO,GAAG,cAAc,CAAC,UAAU,CAAC,CAAC;QAC3C,MAAM,OAAO,GAAG,cAAc,CAAC,UAAU,CAAC,CAAC;QAE3C,SAAS,CAAC,KAAK,CAAC,OAAO,CAAC,CAAC;QACzB,MAAM,CAAC,OAAO,CAAC,CAAC,CAAC,CAAC,OAAO,CAAC,CAAC,qBAAqB,CAAC,CAAC,CAAC,CAAC;QACpD,MAAM,CAAC,OAAO,CAAC,CAAC,CAAC,CAAC,OAAO,CAAC,CAAC,oBAAoB,CAAC,IAAI,CAAC,CAAC;QAEtD,SAAS,CAAC,KAAK,CAAC,OAAO,CAAC,CAAC;QACzB,MAAM,CAAC,OAAO,CAAC,CAAC,CAAC,CAAC,OAAO,CAAC,CAAC,qBAAqB,CAAC,CAAC,CAAC,CAAC;QACpD,MAAM,CAAC,OAAO,CAAC,CAAC,CAAC,CAAC,OAAO,CAAC,CAAC,oBAAoB,CAAC,KAAK,CAAC,CAAC;QAEvD,SAAS,CAAC,KAAK,CAAC,OAAO,CAAC,CAAC;QACzB,MAAM,CAAC,OAAO,CAAC,CAAC,CAAC,CAAC,OAAO,CAAC,CAAC,qBAAqB,CAAC,CAAC,CAAC,CAAC;QACpD,MAAM,CAAC,OAAO,CAAC,CAAC,CAAC,CAAC,OAAO,CAAC,CAAC,oBAAoB,CAAC,IAAI,CAAC,CAAC;IACvD,CAAC,CAAC,CAAC;AACJ,CAAC,CAAC,CAAC"}
@@ -0,0 +1,5 @@
1
+ import type { LunaticComponentProps } from '../type';
2
+ /**
3
+ * Checkbox acting as a radio (only one option can be checked at a time)
4
+ */
5
+ export declare function CheckboxOne({ options, value, id, label, description, errors, disabled, readOnly, shortcut, declarations, orientation, }: LunaticComponentProps<'CheckboxOne'>): import("react/jsx-runtime").JSX.Element;
@@ -0,0 +1,10 @@
1
+ import { jsx as _jsx } from "react/jsx-runtime";
2
+ import { RadioGroup } from '../shared/Radio/RadioGroup';
3
+ import { getComponentErrors } from '../shared/ComponentErrors/ComponentErrors';
4
+ /**
5
+ * Checkbox acting as a radio (only one option can be checked at a time)
6
+ */
7
+ export function CheckboxOne({ options, value, id, label, description, errors, disabled, readOnly, shortcut, declarations, orientation, }) {
8
+ return (_jsx(RadioGroup, { id: id, className: "lunatic-checkbox-one", options: options, value: value, disabled: disabled, readOnly: readOnly, errors: getComponentErrors(errors, id), label: label, description: description, checkboxStyle: true, shortcut: shortcut, declarations: declarations, orientation: orientation !== null && orientation !== void 0 ? orientation : 'vertical', clearable: true }));
9
+ }
10
+ //# sourceMappingURL=CheckboxOne.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"CheckboxOne.js","sourceRoot":"","sources":["../../../src/components/CheckboxOne/CheckboxOne.tsx"],"names":[],"mappings":";AAAA,OAAO,EAAE,UAAU,EAAE,MAAM,4BAA4B,CAAC;AAExD,OAAO,EAAE,kBAAkB,EAAE,MAAM,2CAA2C,CAAC;AAE/E;;GAEG;AACH,MAAM,UAAU,WAAW,CAAC,EAC3B,OAAO,EACP,KAAK,EACL,EAAE,EACF,KAAK,EACL,WAAW,EACX,MAAM,EACN,QAAQ,EACR,QAAQ,EACR,QAAQ,EACR,YAAY,EACZ,WAAW,GAC2B;IACtC,OAAO,CACN,KAAC,UAAU,IACV,EAAE,EAAE,EAAE,EACN,SAAS,EAAC,sBAAsB,EAChC,OAAO,EAAE,OAAO,EAChB,KAAK,EAAE,KAAK,EACZ,QAAQ,EAAE,QAAQ,EAClB,QAAQ,EAAE,QAAQ,EAClB,MAAM,EAAE,kBAAkB,CAAC,MAAM,EAAE,EAAE,CAAC,EACtC,KAAK,EAAE,KAAK,EACZ,WAAW,EAAE,WAAW,EACxB,aAAa,EAAE,IAAI,EACnB,QAAQ,EAAE,QAAQ,EAClB,YAAY,EAAE,YAAY,EAC1B,WAAW,EAAE,WAAW,aAAX,WAAW,cAAX,WAAW,GAAI,UAAU,EACtC,SAAS,SACR,CACF,CAAC;AACH,CAAC"}
@@ -0,0 +1 @@
1
+ export {};
@@ -0,0 +1,24 @@
1
+ import { jsx as _jsx } from "react/jsx-runtime";
2
+ import { render, fireEvent } from '@testing-library/react';
3
+ import { CheckboxOne } from './CheckboxOne';
4
+ import { describe, it, expect, vi } from 'vitest';
5
+ describe('CheckboxOne component', () => {
6
+ const onCheck = vi.fn();
7
+ const options = [
8
+ { label: 'Option 1', value: 'option-1', onCheck: onCheck, checked: false },
9
+ { label: 'Option 2', value: 'option-2', onCheck: onCheck, checked: false },
10
+ { label: 'Option 3', value: 'option-3', onCheck: onCheck, checked: false },
11
+ ];
12
+ it('renders the component with correct props', () => {
13
+ const { getByText } = render(_jsx(CheckboxOne, { options: options, value: "option-1", id: "checkbox-one", handleChanges: onCheck }));
14
+ expect(getByText('Option 1')).toBeInTheDocument();
15
+ expect(getByText('Option 2')).toBeInTheDocument();
16
+ expect(getByText('Option 3')).toBeInTheDocument();
17
+ });
18
+ it('calls onSelect when an option is selected', () => {
19
+ const { getByText } = render(_jsx(CheckboxOne, { options: options, value: "option-1", id: "checkbox-one", label: "Checkbox One", description: "Choose one option", handleChanges: onCheck }));
20
+ fireEvent.click(getByText('Option 2'));
21
+ expect(onCheck).toHaveBeenCalledTimes(1);
22
+ });
23
+ });
24
+ //# sourceMappingURL=CheckboxOne.spec.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"CheckboxOne.spec.js","sourceRoot":"","sources":["../../../src/components/CheckboxOne/CheckboxOne.spec.tsx"],"names":[],"mappings":";AAAA,OAAO,EAAE,MAAM,EAAE,SAAS,EAAE,MAAM,wBAAwB,CAAC;AAC3D,OAAO,EAAE,WAAW,EAAE,MAAM,eAAe,CAAC;AAC5C,OAAO,EAAE,QAAQ,EAAE,EAAE,EAAE,MAAM,EAAE,EAAE,EAAE,MAAM,QAAQ,CAAC;AAElD,QAAQ,CAAC,uBAAuB,EAAE,GAAG,EAAE;IACtC,MAAM,OAAO,GAAG,EAAE,CAAC,EAAE,EAAE,CAAC;IACxB,MAAM,OAAO,GAAG;QACf,EAAE,KAAK,EAAE,UAAU,EAAE,KAAK,EAAE,UAAU,EAAE,OAAO,EAAE,OAAO,EAAE,OAAO,EAAE,KAAK,EAAE;QAC1E,EAAE,KAAK,EAAE,UAAU,EAAE,KAAK,EAAE,UAAU,EAAE,OAAO,EAAE,OAAO,EAAE,OAAO,EAAE,KAAK,EAAE;QAC1E,EAAE,KAAK,EAAE,UAAU,EAAE,KAAK,EAAE,UAAU,EAAE,OAAO,EAAE,OAAO,EAAE,OAAO,EAAE,KAAK,EAAE;KAC5C,CAAC;IAEhC,EAAE,CAAC,0CAA0C,EAAE,GAAG,EAAE;QACnD,MAAM,EAAE,SAAS,EAAE,GAAG,MAAM,CAC3B,KAAC,WAAW,IACX,OAAO,EAAE,OAAO,EAChB,KAAK,EAAC,UAAU,EAChB,EAAE,EAAC,cAAc,EACjB,aAAa,EAAE,OAAO,GACrB,CACF,CAAC;QAEF,MAAM,CAAC,SAAS,CAAC,UAAU,CAAC,CAAC,CAAC,iBAAiB,EAAE,CAAC;QAClD,MAAM,CAAC,SAAS,CAAC,UAAU,CAAC,CAAC,CAAC,iBAAiB,EAAE,CAAC;QAClD,MAAM,CAAC,SAAS,CAAC,UAAU,CAAC,CAAC,CAAC,iBAAiB,EAAE,CAAC;IACnD,CAAC,CAAC,CAAC;IAEH,EAAE,CAAC,2CAA2C,EAAE,GAAG,EAAE;QACpD,MAAM,EAAE,SAAS,EAAE,GAAG,MAAM,CAC3B,KAAC,WAAW,IACX,OAAO,EAAE,OAAO,EAChB,KAAK,EAAC,UAAU,EAChB,EAAE,EAAC,cAAc,EACjB,KAAK,EAAC,cAAc,EACpB,WAAW,EAAC,mBAAmB,EAC/B,aAAa,EAAE,OAAO,GACrB,CACF,CAAC;QAEF,SAAS,CAAC,KAAK,CAAC,SAAS,CAAC,UAAU,CAAC,CAAC,CAAC;QAEvC,MAAM,CAAC,OAAO,CAAC,CAAC,qBAAqB,CAAC,CAAC,CAAC,CAAC;IAC1C,CAAC,CAAC,CAAC;AACJ,CAAC,CAAC,CAAC"}
@@ -0,0 +1,9 @@
1
+ import type { LunaticComponentProps } from '../type';
2
+ import type { LunaticError } from '../../use-lunatic/type';
3
+ export declare function Datepicker({ dateFormat, response, handleChanges, errors, ...props }: LunaticComponentProps<'Datepicker'>): import("react/jsx-runtime").JSX.Element;
4
+ type CustomProps = Omit<LunaticComponentProps<'Datepicker'>, 'response' | 'handleChanges' | 'errors'> & {
5
+ onChange: (s: string | null) => void;
6
+ errors?: LunaticError[];
7
+ };
8
+ export declare const CustomDatepicker: import("react").ComponentType<CustomProps>;
9
+ export {};
@@ -0,0 +1,66 @@
1
+ import { jsx as _jsx, jsxs as _jsxs } from "react/jsx-runtime";
2
+ import { useState } from 'react';
3
+ import { DatepickerField } from './DatepickerField';
4
+ import { slottableComponent } from '../shared/HOC/slottableComponent';
5
+ import { Label } from '../shared/Label/Label';
6
+ import { ComponentErrors, getComponentErrors, } from '../shared/ComponentErrors/ComponentErrors';
7
+ import { Declarations } from '../shared/Declarations/Declarations';
8
+ export function Datepicker({ dateFormat = 'YYYY-MM-DD', response, handleChanges, errors, ...props }) {
9
+ return (_jsx(CustomDatepicker, { ...props, dateFormat: dateFormat !== null && dateFormat !== void 0 ? dateFormat : 'YYYY-MM-DD', onChange: (value) => handleChanges([{ name: response.name, value }]), errors: getComponentErrors(errors, props.id) }));
10
+ }
11
+ export const CustomDatepicker = slottableComponent('Datepicker', (props) => {
12
+ const { disabled, readOnly, value = '', dateFormat = 'YYYY-MM-DD', id, label, errors, description, declarations, onChange, } = props;
13
+ const labelId = `lunatic-datepicker-${id}`;
14
+ const showDay = dateFormat.includes('DD');
15
+ const showMonth = dateFormat.includes('MM');
16
+ // Raw state, we allow invalid dates to be typed
17
+ const [numbers, setNumbers] = useState(() => numbersFromDateString(value !== null && value !== void 0 ? value : undefined));
18
+ const setNumber = (index) => (value) => {
19
+ const newNumbers = [...numbers];
20
+ newNumbers[index] = value;
21
+ setNumbers(newNumbers);
22
+ onNumbersChange(newNumbers);
23
+ };
24
+ const onNumbersChange = (numbers) => {
25
+ const formatParts = dateFormat.split('-');
26
+ const hasNaNIndex = numbers.findIndex((v) => Number.isNaN(v));
27
+ // Date has a missing part
28
+ if (hasNaNIndex > -1 && hasNaNIndex <= formatParts.length - 1) {
29
+ onChange(null);
30
+ return;
31
+ }
32
+ // Date is not valid
33
+ if (dateFormat === 'YYYY-MM-DD' && !isDateValid(numbers)) {
34
+ onChange(null);
35
+ return;
36
+ }
37
+ const result = formatParts
38
+ .map((v, k) => numbers[k].toString().padStart(v.length, '0'))
39
+ .join('-');
40
+ onChange(result);
41
+ };
42
+ const extraProps = {
43
+ readOnly,
44
+ disabled,
45
+ };
46
+ return (_jsxs("div", { className: "lunatic-input", children: [_jsx(Label, { htmlFor: id, id: labelId, description: description, children: label }), _jsx(Declarations, { type: "AFTER_QUESTION_TEXT", declarations: declarations, id: id }), _jsxs("div", { className: "lunaticDatepickerFields", children: [showDay && (_jsx(DatepickerField, { id: id + 'day', label: "Jour", description: "Exemple: 14", max: 31, value: numbers[2], onChange: setNumber(2), ...extraProps })), showMonth && (_jsx(DatepickerField, { id: id + 'month', label: "Mois", description: "Exemple: 07", max: 12, value: numbers[1], onChange: setNumber(1), ...extraProps })), _jsx(DatepickerField, { id: id + 'year', label: "Ann\u00E9e", description: "Exemple: 2023", value: numbers[0], max: 9999, onChange: setNumber(0), ...extraProps })] }), _jsx(ComponentErrors, { errors: errors })] }));
47
+ });
48
+ function numbersFromDateString(s) {
49
+ if (!s) {
50
+ return [NaN, NaN, NaN];
51
+ }
52
+ const parts = s.split('-');
53
+ return [
54
+ parseInt(parts[0], 10),
55
+ parseInt(parts[1], 10),
56
+ parseInt(parts[2], 10),
57
+ ];
58
+ }
59
+ function isDateValid(dateArray) {
60
+ const [year, month, day] = dateArray;
61
+ const date = new Date(year, month - 1, day);
62
+ return (date.getFullYear() === year &&
63
+ date.getMonth() === month - 1 &&
64
+ date.getDate() === day);
65
+ }
66
+ //# sourceMappingURL=Datepicker.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"Datepicker.js","sourceRoot":"","sources":["../../../src/components/Datepicker/Datepicker.tsx"],"names":[],"mappings":"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"}
@@ -0,0 +1 @@
1
+ export {};
@@ -0,0 +1,75 @@
1
+ import { jsx as _jsx } from "react/jsx-runtime";
2
+ import { fireEvent, render, screen } from '@testing-library/react';
3
+ import { beforeEach, describe, expect, it, vi } from 'vitest';
4
+ import { Datepicker } from './Datepicker';
5
+ describe('Datepicker', () => {
6
+ const mockOnChange = vi.fn();
7
+ const baseProps = {
8
+ value: '1999-01-01',
9
+ executeExpression: vi.fn,
10
+ response: { name: 'demo' },
11
+ 'aria-labelledby': 'datepicker',
12
+ id: 'datepicker',
13
+ };
14
+ beforeEach(() => {
15
+ mockOnChange.mockClear();
16
+ });
17
+ ['YYYY-MM-DD', 'YYYY-MM', 'YYYY'].forEach((format) => {
18
+ it('should render properly with format ' + format, () => {
19
+ const { container } = render(_jsx(Datepicker, { ...baseProps, handleChanges: mockOnChange, dateFormat: format }));
20
+ expect(container).toMatchSnapshot();
21
+ });
22
+ });
23
+ it('handle change correctly for format YYYY-MM-DD', () => {
24
+ render(_jsx(Datepicker, { ...baseProps, dateFormat: "YYYY-MM-DD", handleChanges: mockOnChange }));
25
+ fireEvent.change(screen.getByLabelText(/Année/), {
26
+ target: { valueAsNumber: 2023 },
27
+ });
28
+ expect(mockOnChange).toHaveBeenLastCalledWith([
29
+ {
30
+ ...baseProps.response,
31
+ value: '2023-01-01',
32
+ },
33
+ ]);
34
+ fireEvent.change(screen.getByLabelText(/Mois/), {
35
+ target: { valueAsNumber: 2 },
36
+ });
37
+ fireEvent.change(screen.getByLabelText(/Jour/), {
38
+ target: { valueAsNumber: 30 },
39
+ });
40
+ expect(mockOnChange).toHaveBeenLastCalledWith([
41
+ { ...baseProps.response, value: null },
42
+ ]);
43
+ });
44
+ it('handle change correctly for format YYYY-MM', () => {
45
+ render(_jsx(Datepicker, { ...baseProps, dateFormat: "YYYY-MM", value: "1999-01", handleChanges: mockOnChange }));
46
+ fireEvent.change(screen.getByLabelText(/Année/), {
47
+ target: { valueAsNumber: 2023 },
48
+ });
49
+ expect(mockOnChange).toHaveBeenLastCalledWith([
50
+ {
51
+ ...baseProps.response,
52
+ value: '2023-01',
53
+ },
54
+ ]);
55
+ fireEvent.change(screen.getByLabelText(/Mois/), {
56
+ target: { valueAsNumber: 10 },
57
+ });
58
+ expect(mockOnChange).toHaveBeenLastCalledWith([
59
+ {
60
+ ...baseProps.response,
61
+ value: '2023-10',
62
+ },
63
+ ]);
64
+ });
65
+ it('handle change correctly for year YYYY', () => {
66
+ render(_jsx(Datepicker, { ...baseProps, dateFormat: "YYYY", value: "1999", handleChanges: mockOnChange }));
67
+ fireEvent.change(screen.getByLabelText(/Année/), {
68
+ target: { valueAsNumber: 2023 },
69
+ });
70
+ expect(mockOnChange).toHaveBeenLastCalledWith([
71
+ { ...baseProps.response, value: '2023' },
72
+ ]);
73
+ });
74
+ });
75
+ //# sourceMappingURL=Datepicker.spec.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"Datepicker.spec.js","sourceRoot":"","sources":["../../../src/components/Datepicker/Datepicker.spec.tsx"],"names":[],"mappings":"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"}
@@ -0,0 +1,12 @@
1
+ type Props = {
2
+ id: string;
3
+ label: string;
4
+ description: string;
5
+ max?: number;
6
+ onChange: (value: number) => void;
7
+ value?: number;
8
+ readOnly?: boolean;
9
+ disabled?: boolean;
10
+ };
11
+ export declare function DatepickerField({ label, id, description, onChange, value, max, readOnly, disabled, }: Props): import("react/jsx-runtime").JSX.Element;
12
+ export {};
@@ -0,0 +1,13 @@
1
+ import { jsx as _jsx, jsxs as _jsxs } from "react/jsx-runtime";
2
+ import classNames from 'classnames';
3
+ export function DatepickerField({ label, id, description, onChange, value, max, readOnly, disabled, }) {
4
+ const handleChange = (e) => {
5
+ if (!Number.isNaN(e.target.valueAsNumber) &&
6
+ ((max && e.target.valueAsNumber > max) || e.target.valueAsNumber < 1)) {
7
+ return;
8
+ }
9
+ onChange(e.target.valueAsNumber);
10
+ };
11
+ return (_jsxs("div", { className: classNames('lunaticDatepickerField', (!max || max > 999) && 'lunaticDatepickerFieldLarge'), children: [_jsxs("label", { htmlFor: id, children: [label, _jsx("span", { className: "lunaticDatepickerHint", children: description })] }), _jsx("input", { id: id, type: "number", min: 1, max: max, readOnly: readOnly, disabled: disabled, value: Number.isNaN(value) ? '' : value, onChange: handleChange, onFocus: (e) => e.target.select() })] }));
12
+ }
13
+ //# sourceMappingURL=DatepickerField.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"DatepickerField.js","sourceRoot":"","sources":["../../../src/components/Datepicker/DatepickerField.tsx"],"names":[],"mappings":";AAAA,OAAO,UAAU,MAAM,YAAY,CAAC;AAcpC,MAAM,UAAU,eAAe,CAAC,EAC/B,KAAK,EACL,EAAE,EACF,WAAW,EACX,QAAQ,EACR,KAAK,EACL,GAAG,EACH,QAAQ,EACR,QAAQ,GACD;IACP,MAAM,YAAY,GAAyC,CAAC,CAAC,EAAE,EAAE;QAChE,IACC,CAAC,MAAM,CAAC,KAAK,CAAC,CAAC,CAAC,MAAM,CAAC,aAAa,CAAC;YACrC,CAAC,CAAC,GAAG,IAAI,CAAC,CAAC,MAAM,CAAC,aAAa,GAAG,GAAG,CAAC,IAAI,CAAC,CAAC,MAAM,CAAC,aAAa,GAAG,CAAC,CAAC,EACpE,CAAC;YACF,OAAO;QACR,CAAC;QACD,QAAQ,CAAC,CAAC,CAAC,MAAM,CAAC,aAAa,CAAC,CAAC;IAClC,CAAC,CAAC;IACF,OAAO,CACN,eACC,SAAS,EAAE,UAAU,CACpB,wBAAwB,EACxB,CAAC,CAAC,GAAG,IAAI,GAAG,GAAG,GAAG,CAAC,IAAI,6BAA6B,CACpD,aAED,iBAAO,OAAO,EAAE,EAAE,aAChB,KAAK,EACN,eAAM,SAAS,EAAC,uBAAuB,YAAE,WAAW,GAAQ,IACrD,EACR,gBACC,EAAE,EAAE,EAAE,EACN,IAAI,EAAC,QAAQ,EACb,GAAG,EAAE,CAAC,EACN,GAAG,EAAE,GAAG,EACR,QAAQ,EAAE,QAAQ,EAClB,QAAQ,EAAE,QAAQ,EAClB,KAAK,EAAE,MAAM,CAAC,KAAK,CAAC,KAAK,CAAC,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,KAAK,EACvC,QAAQ,EAAE,YAAY,EACtB,OAAO,EAAE,CAAC,CAAC,EAAE,EAAE,CAAC,CAAC,CAAC,MAAM,CAAC,MAAM,EAAE,GAChC,IACG,CACN,CAAC;AACH,CAAC"}
@@ -0,0 +1,9 @@
1
+ import type { LunaticComponentProps } from '../type';
2
+ import type { LunaticError } from '../../use-lunatic/type';
3
+ export declare function Dropdown({ handleChanges, response, errors, ...props }: LunaticComponentProps<'Dropdown'>): import("react/jsx-runtime").JSX.Element;
4
+ type CustomProps = Omit<LunaticComponentProps<'Dropdown'>, 'response' | 'handleChanges' | 'errors'> & {
5
+ onChange: (v: string | null) => void;
6
+ errors?: LunaticError[];
7
+ };
8
+ export declare const CustomDropdown: import("react").ComponentType<CustomProps>;
9
+ export {};
@@ -0,0 +1,15 @@
1
+ import { jsx as _jsx } from "react/jsx-runtime";
2
+ import { getComponentErrors } from '../shared/ComponentErrors/ComponentErrors';
3
+ import { slottableComponent } from '../shared/HOC/slottableComponent';
4
+ import { SimpleOptionRenderer } from './renderer/SimpleOptionRenderer';
5
+ import { SimpleLabelRenderer } from './renderer/SimpleLabelRenderer';
6
+ import { Combobox } from '../shared/Combobox/Combobox';
7
+ import classNames from 'classnames';
8
+ export function Dropdown({ handleChanges, response, errors, ...props }) {
9
+ return (_jsx(CustomDropdown, { ...props, onChange: (value) => handleChanges([{ name: response.name, value }]), errors: getComponentErrors(errors, props.id) }));
10
+ }
11
+ export const CustomDropdown = slottableComponent('Dropdown', (props) => {
12
+ const { id, disabled, options, className, value, declarations, description, label, errors, onChange, readOnly, } = props;
13
+ return (_jsx(Combobox, { id: id, className: classNames(className, 'lunatic-dropdown'), disabled: disabled, readOnly: readOnly, options: options, editable: false, onSelect: onChange, optionRenderer: SimpleOptionRenderer, labelRenderer: SimpleLabelRenderer, value: value, label: label, errors: errors, description: description, declarations: declarations }));
14
+ });
15
+ //# sourceMappingURL=Dropdown.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"Dropdown.js","sourceRoot":"","sources":["../../../src/components/Dropdown/Dropdown.tsx"],"names":[],"mappings":";AACA,OAAO,EAAE,kBAAkB,EAAE,MAAM,2CAA2C,CAAC;AAC/E,OAAO,EAAE,kBAAkB,EAAE,MAAM,kCAAkC,CAAC;AACtE,OAAO,EAAE,oBAAoB,EAAE,MAAM,iCAAiC,CAAC;AACvE,OAAO,EAAE,mBAAmB,EAAE,MAAM,gCAAgC,CAAC;AACrE,OAAO,EAAE,QAAQ,EAAE,MAAM,6BAA6B,CAAC;AACvD,OAAO,UAAU,MAAM,YAAY,CAAC;AAGpC,MAAM,UAAU,QAAQ,CAAC,EACxB,aAAa,EACb,QAAQ,EACR,MAAM,EACN,GAAG,KAAK,EAC2B;IACnC,OAAO,CACN,KAAC,cAAc,OACV,KAAK,EACT,QAAQ,EAAE,CAAC,KAAK,EAAE,EAAE,CAAC,aAAa,CAAC,CAAC,EAAE,IAAI,EAAE,QAAQ,CAAC,IAAI,EAAE,KAAK,EAAE,CAAC,CAAC,EACpE,MAAM,EAAE,kBAAkB,CAAC,MAAM,EAAE,KAAK,CAAC,EAAE,CAAC,GAC3C,CACF,CAAC;AACH,CAAC;AAUD,MAAM,CAAC,MAAM,cAAc,GAAG,kBAAkB,CAC/C,UAAU,EACV,CAAC,KAAK,EAAE,EAAE;IACT,MAAM,EACL,EAAE,EACF,QAAQ,EACR,OAAO,EACP,SAAS,EACT,KAAK,EACL,YAAY,EACZ,WAAW,EACX,KAAK,EACL,MAAM,EACN,QAAQ,EACR,QAAQ,GACR,GAAG,KAAK,CAAC;IAEV,OAAO,CACN,KAAC,QAAQ,IACR,EAAE,EAAE,EAAE,EACN,SAAS,EAAE,UAAU,CAAC,SAAS,EAAE,kBAAkB,CAAC,EACpD,QAAQ,EAAE,QAAQ,EAClB,QAAQ,EAAE,QAAQ,EAClB,OAAO,EAAE,OAAO,EAChB,QAAQ,EAAE,KAAK,EACf,QAAQ,EAAE,QAAQ,EAClB,cAAc,EAAE,oBAAoB,EACpC,aAAa,EAAE,mBAAmB,EAClC,KAAK,EAAE,KAAK,EACZ,KAAK,EAAE,KAAK,EACZ,MAAM,EAAE,MAAM,EACd,WAAW,EAAE,WAAW,EACxB,YAAY,EAAE,YAAY,GACzB,CACF,CAAC;AACH,CAAC,CACD,CAAC"}
@@ -0,0 +1 @@
1
+ export {};
@@ -0,0 +1,38 @@
1
+ import { jsx as _jsx } from "react/jsx-runtime";
2
+ import { render } from '@testing-library/react';
3
+ import { beforeEach, describe, expect, it, vi } from 'vitest';
4
+ import { Dropdown } from './Dropdown';
5
+ describe('Dropdown', () => {
6
+ const mockOnSelect = vi.fn();
7
+ const baseProps = {
8
+ value: 'toto',
9
+ id: 'dropdown',
10
+ 'aria-labelledby': 'dropdown',
11
+ options: [
12
+ {
13
+ value: 'toto',
14
+ description: 'toto',
15
+ label: 'toto',
16
+ },
17
+ ],
18
+ response: { name: 'demo' },
19
+ handleChanges: mockOnSelect,
20
+ };
21
+ beforeEach(() => {
22
+ mockOnSelect.mockClear();
23
+ });
24
+ it('renders without crashing', () => {
25
+ const { container } = render(_jsx(Dropdown, { ...baseProps }));
26
+ expect(container).toMatchSnapshot();
27
+ });
28
+ it('should handle readOnly', () => {
29
+ const { container } = render(_jsx(Dropdown, { ...baseProps, readOnly: true }));
30
+ expect(container).toMatchSnapshot();
31
+ const selection = container.querySelector('.lunatic-combo-box-content');
32
+ selection.focus();
33
+ expect(selection).toHaveFocus();
34
+ const span = selection === null || selection === void 0 ? void 0 : selection.querySelector('span');
35
+ expect(span).toHaveTextContent('toto');
36
+ });
37
+ });
38
+ //# sourceMappingURL=Dropdown.spec.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"Dropdown.spec.js","sourceRoot":"","sources":["../../../src/components/Dropdown/Dropdown.spec.tsx"],"names":[],"mappings":";AAAA,OAAO,EAAE,MAAM,EAAE,MAAM,wBAAwB,CAAC;AAChD,OAAO,EAAE,UAAU,EAAE,QAAQ,EAAE,MAAM,EAAE,EAAE,EAAE,EAAE,EAAE,MAAM,QAAQ,CAAC;AAC9D,OAAO,EAAE,QAAQ,EAAE,MAAM,YAAY,CAAC;AAEtC,QAAQ,CAAC,UAAU,EAAE,GAAG,EAAE;IACzB,MAAM,YAAY,GAAG,EAAE,CAAC,EAAE,EAAE,CAAC;IAE7B,MAAM,SAAS,GAAG;QACjB,KAAK,EAAE,MAAM;QACb,EAAE,EAAE,UAAU;QACd,iBAAiB,EAAE,UAAU;QAC7B,OAAO,EAAE;YACR;gBACC,KAAK,EAAE,MAAM;gBACb,WAAW,EAAE,MAAM;gBACnB,KAAK,EAAE,MAAM;aACb;SACD;QACD,QAAQ,EAAE,EAAE,IAAI,EAAE,MAAM,EAAE;QAC1B,aAAa,EAAE,YAAY;KAC3B,CAAC;IAEF,UAAU,CAAC,GAAG,EAAE;QACf,YAAY,CAAC,SAAS,EAAE,CAAC;IAC1B,CAAC,CAAC,CAAC;IAEH,EAAE,CAAC,0BAA0B,EAAE,GAAG,EAAE;QACnC,MAAM,EAAE,SAAS,EAAE,GAAG,MAAM,CAAC,KAAC,QAAQ,OAAK,SAAS,GAAI,CAAC,CAAC;QAC1D,MAAM,CAAC,SAAS,CAAC,CAAC,eAAe,EAAE,CAAC;IACrC,CAAC,CAAC,CAAC;IAEH,EAAE,CAAC,wBAAwB,EAAE,GAAG,EAAE;QACjC,MAAM,EAAE,SAAS,EAAE,GAAG,MAAM,CAAC,KAAC,QAAQ,OAAK,SAAS,EAAE,QAAQ,SAAG,CAAC,CAAC;QACnE,MAAM,CAAC,SAAS,CAAC,CAAC,eAAe,EAAE,CAAC;QAEpC,MAAM,SAAS,GAAG,SAAS,CAAC,aAAa,CAAC,4BAA4B,CAAC,CAAC;QACvE,SAAyB,CAAC,KAAK,EAAE,CAAC;QACnC,MAAM,CAAC,SAAS,CAAC,CAAC,WAAW,EAAE,CAAC;QAChC,MAAM,IAAI,GAAG,SAAS,aAAT,SAAS,uBAAT,SAAS,CAAE,aAAa,CAAC,MAAM,CAAC,CAAC;QAC9C,MAAM,CAAC,IAAI,CAAC,CAAC,iBAAiB,CAAC,MAAM,CAAC,CAAC;IACxC,CAAC,CAAC,CAAC;AACJ,CAAC,CAAC,CAAC"}
@@ -0,0 +1,8 @@
1
+ import type { ComboboxOptionType } from '../../shared/Combobox/ComboboxType';
2
+ type Props = {
3
+ option?: ComboboxOptionType;
4
+ placeholder?: string;
5
+ search?: string;
6
+ };
7
+ export declare function SimpleLabelRenderer({ option, placeholder, search }: Props): import("react/jsx-runtime").JSX.Element;
8
+ export {};
@@ -0,0 +1,19 @@
1
+ import { jsx as _jsx } from "react/jsx-runtime";
2
+ function getContent(option, search) {
3
+ if (option) {
4
+ const { value, label } = option;
5
+ return label || value;
6
+ }
7
+ if (search === null || search === void 0 ? void 0 : search.trim().length) {
8
+ return search;
9
+ }
10
+ return null;
11
+ }
12
+ export function SimpleLabelRenderer({ option, placeholder, search }) {
13
+ const content = getContent(option, search);
14
+ if (content) {
15
+ return _jsx("span", { className: "selection", children: content });
16
+ }
17
+ return _jsx("span", { className: "placeholder", children: placeholder });
18
+ }
19
+ //# sourceMappingURL=SimpleLabelRenderer.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"SimpleLabelRenderer.js","sourceRoot":"","sources":["../../../../src/components/Dropdown/renderer/SimpleLabelRenderer.tsx"],"names":[],"mappings":";AAQA,SAAS,UAAU,CAAC,MAAuB,EAAE,MAAe;IAC3D,IAAI,MAAM,EAAE,CAAC;QACZ,MAAM,EAAE,KAAK,EAAE,KAAK,EAAE,GAAG,MAAM,CAAC;QAChC,OAAO,KAAK,IAAI,KAAK,CAAC;IACvB,CAAC;IACD,IAAI,MAAM,aAAN,MAAM,uBAAN,MAAM,CAAE,IAAI,GAAG,MAAM,EAAE,CAAC;QAC3B,OAAO,MAAM,CAAC;IACf,CAAC;IACD,OAAO,IAAI,CAAC;AACb,CAAC;AAED,MAAM,UAAU,mBAAmB,CAAC,EAAE,MAAM,EAAE,WAAW,EAAE,MAAM,EAAS;IACzE,MAAM,OAAO,GAAG,UAAU,CAAC,MAAM,EAAE,MAAM,CAAC,CAAC;IAC3C,IAAI,OAAO,EAAE,CAAC;QACb,OAAO,eAAM,SAAS,EAAC,WAAW,YAAE,OAAO,GAAQ,CAAC;IACrD,CAAC;IACD,OAAO,eAAM,SAAS,EAAC,aAAa,YAAE,WAAW,GAAQ,CAAC;AAC3D,CAAC"}
@@ -0,0 +1,7 @@
1
+ import type { ComboboxOptionType } from '../../shared/Combobox/ComboboxType';
2
+ type Props = {
3
+ option: ComboboxOptionType;
4
+ selected?: boolean;
5
+ };
6
+ export declare function SimpleOptionRenderer({ option, selected }: Props): import("react/jsx-runtime").JSX.Element;
7
+ export {};