@digigov/form 1.2.0-a7ffb5dc → 2.0.0-07ee8440

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 (776) hide show
  1. package/Field/ErrorGroup/index.js +48 -0
  2. package/{Questions/index.spec → Field/ErrorGroup}/package.json +1 -1
  3. package/Field/ErrorGroup.d.ts +15 -0
  4. package/Field/ErrorGroup.js.map +7 -0
  5. package/Field/FieldBase/index.js +112 -76
  6. package/Field/FieldBase.js.map +7 -0
  7. package/Field/FieldBaseContainer/index.js +30 -37
  8. package/Field/FieldBaseContainer.js.map +7 -0
  9. package/Field/FieldConditional/index.js +79 -53
  10. package/Field/FieldConditional.js.map +7 -0
  11. package/Field/index.js +107 -63
  12. package/Field/index.js.map +7 -0
  13. package/Field/types/index.js +1 -1
  14. package/Field/types.d.ts +44 -5
  15. package/Field/types.js.map +7 -0
  16. package/Field/utils/calculateField/index.js +27 -0
  17. package/{FieldArray/FieldArray.stories → Field/utils/calculateField}/package.json +1 -1
  18. package/Field/utils/calculateField.d.ts +2 -0
  19. package/Field/utils/calculateField.js.map +7 -0
  20. package/Field/utils/evaluateFieldWithConditions/index.js +26 -0
  21. package/{inputs/DateInput/__stories__/Default → Field/utils/evaluateFieldWithConditions}/package.json +1 -1
  22. package/Field/utils/evaluateFieldWithConditions.d.ts +2 -0
  23. package/Field/utils/evaluateFieldWithConditions.js.map +7 -0
  24. package/Field/utils/index.d.ts +4 -0
  25. package/Field/utils/index.js +47 -116
  26. package/Field/utils/index.js.map +7 -0
  27. package/Field/utils/useField/index.js +57 -0
  28. package/{FormBuilder/FormBuilder → Field/utils/useField}/package.json +1 -1
  29. package/Field/utils/useField.d.ts +2 -0
  30. package/Field/utils/useField.js.map +7 -0
  31. package/FieldArray/FieldArray.stories.d.ts +3 -2
  32. package/FieldArray/FormDialog/index.js +279 -0
  33. package/{validators/validators.spec → FieldArray/FormDialog}/package.json +1 -1
  34. package/FieldArray/FormDialog.d.ts +53 -0
  35. package/FieldArray/FormDialog.js.map +7 -0
  36. package/FieldArray/__stories__/Default.d.ts +2 -2
  37. package/FieldArray/__stories__/WithExactLength.d.ts +2 -2
  38. package/FieldArray/__stories__/WithModal.d.ts +2 -0
  39. package/FieldArray/index.d.ts +6 -0
  40. package/FieldArray/index.js +108 -59
  41. package/FieldArray/index.js.map +7 -0
  42. package/FieldArray/index.test.d.ts +1 -0
  43. package/FieldObject/index.d.ts +5 -0
  44. package/FieldObject/index.js +74 -52
  45. package/FieldObject/index.js.map +7 -0
  46. package/Fieldset/FieldsetWithContext/index.js +27 -31
  47. package/Fieldset/FieldsetWithContext.js.map +7 -0
  48. package/Fieldset/index.d.ts +1 -1
  49. package/Fieldset/index.js +27 -29
  50. package/Fieldset/index.js.map +7 -0
  51. package/Fieldset/types/index.js +1 -1
  52. package/Fieldset/types.d.ts +3 -2
  53. package/Fieldset/types.js.map +7 -0
  54. package/FormBuilder/FormBuilder.stories.d.ts +3 -1
  55. package/FormBuilder/__stories__/AutoErrorGrouping.d.ts +3 -0
  56. package/FormBuilder/__stories__/Default.d.ts +2 -2
  57. package/FormBuilder/__stories__/ErrorGrouping.d.ts +3 -0
  58. package/FormBuilder/index.d.ts +8 -1
  59. package/FormBuilder/index.js +237 -2
  60. package/FormBuilder/index.js.map +7 -0
  61. package/FormBuilder/index.test.d.ts +1 -0
  62. package/FormBuilder/interaction.test.d.ts +1 -0
  63. package/FormBuilder/scenarios.test.d.ts +88 -0
  64. package/FormContext/index.js +7 -3
  65. package/FormContext.js.map +7 -0
  66. package/MultiplicityField/MultiplicityField.stories.d.ts +6 -6
  67. package/MultiplicityField/__stories__/Default.d.ts +2 -2
  68. package/MultiplicityField/__stories__/PreviewDisplay.d.ts +2 -2
  69. package/MultiplicityField/__stories__/WithExactLength.d.ts +2 -2
  70. package/MultiplicityField/__stories__/WithMaxLength.d.ts +2 -2
  71. package/MultiplicityField/__stories__/WithMinAndMaxLength.d.ts +2 -2
  72. package/MultiplicityField/__stories__/WithMinLength.d.ts +2 -2
  73. package/MultiplicityField/add-objects/index.js +137 -132
  74. package/MultiplicityField/add-objects.d.ts +2 -1
  75. package/MultiplicityField/add-objects.js.map +7 -0
  76. package/MultiplicityField/index.d.ts +2 -19
  77. package/MultiplicityField/index.js +114 -101
  78. package/MultiplicityField/index.js.map +7 -0
  79. package/MultiplicityField/index.test.d.ts +1 -0
  80. package/MultiplicityField/types/index.js +1 -0
  81. package/MultiplicityField/types/package.json +6 -0
  82. package/MultiplicityField/types.d.ts +18 -0
  83. package/MultiplicityField/types.js.map +7 -0
  84. package/Questions/Questions/index.js +48 -56
  85. package/Questions/Questions.js.map +7 -0
  86. package/Questions/Questions.stories.d.ts +1 -1
  87. package/Questions/QuestionsContext/index.js +9 -9
  88. package/Questions/QuestionsContext.d.ts +0 -1
  89. package/Questions/QuestionsContext.js.map +7 -0
  90. package/Questions/Step/ReviewStep/index.js +35 -47
  91. package/Questions/Step/ReviewStep.js.map +7 -0
  92. package/Questions/Step/Step/index.js +39 -47
  93. package/Questions/Step/Step.js.map +7 -0
  94. package/Questions/Step/StepArrayReview/index.js +41 -45
  95. package/Questions/Step/StepArrayReview.js.map +7 -0
  96. package/Questions/Step/StepContext/index.js +15 -19
  97. package/Questions/Step/StepContext.d.ts +0 -1
  98. package/Questions/Step/StepContext.js.map +7 -0
  99. package/Questions/Step/StepDescription/index.js +22 -22
  100. package/Questions/Step/StepDescription.js.map +7 -0
  101. package/Questions/Step/StepForm/index.js +33 -43
  102. package/Questions/Step/StepForm.js.map +7 -0
  103. package/Questions/Step/StepQuote/index.js +10 -9
  104. package/Questions/Step/StepQuote.js.map +7 -0
  105. package/Questions/Step/StepTitle/index.js +41 -38
  106. package/Questions/Step/StepTitle.d.ts +2 -1
  107. package/Questions/Step/StepTitle.js.map +7 -0
  108. package/Questions/Step/getAddMoreFields/index.js +28 -20
  109. package/Questions/Step/getAddMoreFields.js.map +7 -0
  110. package/Questions/Step/index.d.ts +0 -1
  111. package/Questions/Step/index.js +16 -13
  112. package/Questions/Step/index.js.map +7 -0
  113. package/Questions/Step/types/index.js +1 -1
  114. package/Questions/Step/types.d.ts +1 -0
  115. package/Questions/Step/types.js.map +7 -0
  116. package/Questions/__stories__/Default.d.ts +2 -2
  117. package/Questions/getNextStep/index.js +12 -10
  118. package/Questions/getNextStep.js.map +7 -0
  119. package/Questions/index.js +7 -3
  120. package/Questions/index.js.map +7 -0
  121. package/Questions/index.test.d.ts +1 -0
  122. package/Questions/types/index.js +1 -1
  123. package/Questions/types.d.ts +1 -0
  124. package/Questions/types.js.map +7 -0
  125. package/cjs/Field/ErrorGroup/index.js +82 -0
  126. package/cjs/Field/ErrorGroup.js.map +7 -0
  127. package/cjs/Field/FieldBase/index.js +144 -82
  128. package/cjs/Field/FieldBase.js.map +7 -0
  129. package/cjs/Field/FieldBaseContainer/index.js +62 -43
  130. package/cjs/Field/FieldBaseContainer.js.map +7 -0
  131. package/cjs/Field/FieldConditional/index.js +111 -59
  132. package/cjs/Field/FieldConditional.js.map +7 -0
  133. package/cjs/Field/index.js +136 -72
  134. package/cjs/Field/index.js.map +7 -0
  135. package/cjs/Field/types/index.js +16 -5
  136. package/cjs/Field/types.js.map +7 -0
  137. package/cjs/Field/utils/calculateField/index.js +50 -0
  138. package/cjs/Field/utils/calculateField.js.map +7 -0
  139. package/cjs/Field/utils/evaluateFieldWithConditions/index.js +49 -0
  140. package/cjs/Field/utils/evaluateFieldWithConditions.js.map +7 -0
  141. package/cjs/Field/utils/index.js +91 -139
  142. package/cjs/Field/utils/index.js.map +7 -0
  143. package/cjs/Field/utils/useField/index.js +80 -0
  144. package/cjs/Field/utils/useField.js.map +7 -0
  145. package/cjs/FieldArray/FormDialog/index.js +301 -0
  146. package/cjs/FieldArray/FormDialog.js.map +7 -0
  147. package/cjs/FieldArray/index.js +140 -65
  148. package/cjs/FieldArray/index.js.map +7 -0
  149. package/cjs/FieldObject/index.js +103 -61
  150. package/cjs/FieldObject/index.js.map +7 -0
  151. package/cjs/Fieldset/FieldsetWithContext/index.js +54 -40
  152. package/cjs/Fieldset/FieldsetWithContext.js.map +7 -0
  153. package/cjs/Fieldset/index.js +61 -39
  154. package/cjs/Fieldset/index.js.map +7 -0
  155. package/cjs/Fieldset/types/index.js +16 -5
  156. package/cjs/Fieldset/types.js.map +7 -0
  157. package/cjs/FormBuilder/index.js +273 -8
  158. package/cjs/FormBuilder/index.js.map +7 -0
  159. package/cjs/FormContext/index.js +29 -8
  160. package/cjs/FormContext.js.map +7 -0
  161. package/cjs/MultiplicityField/add-objects/index.js +164 -138
  162. package/cjs/MultiplicityField/add-objects.js.map +7 -0
  163. package/cjs/MultiplicityField/index.js +142 -110
  164. package/cjs/MultiplicityField/index.js.map +7 -0
  165. package/cjs/MultiplicityField/types/index.js +16 -0
  166. package/cjs/MultiplicityField/types.js.map +7 -0
  167. package/cjs/Questions/Questions/index.js +80 -65
  168. package/cjs/Questions/Questions.js.map +7 -0
  169. package/cjs/Questions/QuestionsContext/index.js +31 -14
  170. package/cjs/Questions/QuestionsContext.js.map +7 -0
  171. package/cjs/Questions/Step/ReviewStep/index.js +61 -56
  172. package/cjs/Questions/Step/ReviewStep.js.map +7 -0
  173. package/cjs/Questions/Step/Step/index.js +71 -56
  174. package/cjs/Questions/Step/Step.js.map +7 -0
  175. package/cjs/Questions/Step/StepArrayReview/index.js +65 -54
  176. package/cjs/Questions/Step/StepArrayReview.js.map +7 -0
  177. package/cjs/Questions/Step/StepContext/index.js +37 -24
  178. package/cjs/Questions/Step/StepContext.js.map +7 -0
  179. package/cjs/Questions/Step/StepDescription/index.js +55 -31
  180. package/cjs/Questions/Step/StepDescription.js.map +7 -0
  181. package/cjs/Questions/Step/StepForm/index.js +65 -52
  182. package/cjs/Questions/Step/StepForm.js.map +7 -0
  183. package/cjs/Questions/Step/StepQuote/index.js +42 -15
  184. package/cjs/Questions/Step/StepQuote.js.map +7 -0
  185. package/cjs/Questions/Step/StepTitle/index.js +72 -47
  186. package/cjs/Questions/Step/StepTitle.js.map +7 -0
  187. package/cjs/Questions/Step/getAddMoreFields/index.js +50 -25
  188. package/cjs/Questions/Step/getAddMoreFields.js.map +7 -0
  189. package/cjs/Questions/Step/index.js +59 -143
  190. package/cjs/Questions/Step/index.js.map +7 -0
  191. package/cjs/Questions/Step/types/index.js +16 -5
  192. package/cjs/Questions/Step/types.js.map +7 -0
  193. package/cjs/Questions/getNextStep/index.js +33 -14
  194. package/cjs/Questions/getNextStep.js.map +7 -0
  195. package/cjs/Questions/index.js +29 -19
  196. package/cjs/Questions/index.js.map +7 -0
  197. package/cjs/Questions/types/index.js +16 -5
  198. package/cjs/Questions/types.js.map +7 -0
  199. package/cjs/index.js +47 -20
  200. package/cjs/index.js.map +7 -0
  201. package/cjs/inputs/AutoCompleteInput/index.js +92 -46
  202. package/cjs/inputs/AutoCompleteInput/index.js.map +7 -0
  203. package/cjs/inputs/Checkboxes/index.js +101 -96
  204. package/cjs/inputs/Checkboxes/index.js.map +7 -0
  205. package/cjs/inputs/DateInput/index.js +121 -109
  206. package/cjs/inputs/DateInput/index.js.map +7 -0
  207. package/cjs/inputs/DateTimeInput/index.js +206 -0
  208. package/cjs/inputs/DateTimeInput/index.js.map +7 -0
  209. package/cjs/inputs/FileInput/index.js +75 -63
  210. package/cjs/inputs/FileInput/index.js.map +7 -0
  211. package/cjs/inputs/ImageInput/index.js +95 -83
  212. package/cjs/inputs/ImageInput/index.js.map +7 -0
  213. package/cjs/inputs/Input/index.js +105 -71
  214. package/cjs/inputs/Input/index.js.map +7 -0
  215. package/cjs/inputs/Input/inputsInputScenarios/index.js +439 -0
  216. package/cjs/inputs/Input/inputsInputScenarios.js.map +7 -0
  217. package/cjs/inputs/Label/index.js +45 -24
  218. package/cjs/inputs/Label/index.js.map +7 -0
  219. package/cjs/inputs/OtpInput/index.js +142 -112
  220. package/cjs/inputs/OtpInput/index.js.map +7 -0
  221. package/cjs/inputs/Radio/index.js +131 -61
  222. package/cjs/inputs/Radio/index.js.map +7 -0
  223. package/cjs/inputs/Select/index.js +59 -36
  224. package/cjs/inputs/Select/index.js.map +7 -0
  225. package/cjs/inputs/index.js +62 -69
  226. package/cjs/inputs/index.js.map +7 -0
  227. package/cjs/inputs/inputsScenarios/index.js +533 -0
  228. package/cjs/inputs/inputsScenarios.js.map +7 -0
  229. package/cjs/internal/index.js +36 -346
  230. package/cjs/internal.js.map +7 -0
  231. package/cjs/lazy/index.js +109 -516
  232. package/cjs/lazy.js.map +7 -0
  233. package/cjs/locales/el/index.js +35 -0
  234. package/cjs/locales/el.js.map +7 -0
  235. package/cjs/registry/index.js +190 -142
  236. package/cjs/registry.js.map +7 -0
  237. package/cjs/types/index.js +22 -5
  238. package/cjs/types.js.map +7 -0
  239. package/cjs/utils/index.js +79 -83
  240. package/cjs/utils.js.map +7 -0
  241. package/cjs/validators/index.js +131 -164
  242. package/cjs/validators/index.js.map +7 -0
  243. package/cjs/validators/types/index.js +16 -5
  244. package/cjs/validators/types.js.map +7 -0
  245. package/cjs/validators/utils/afm/index.js +38 -21
  246. package/cjs/validators/utils/afm.js.map +7 -0
  247. package/cjs/validators/utils/date/index.js +138 -0
  248. package/cjs/validators/utils/date.js.map +7 -0
  249. package/cjs/validators/utils/datetime/index.js +151 -0
  250. package/cjs/validators/utils/datetime.js.map +7 -0
  251. package/cjs/validators/utils/file/index.js +44 -47
  252. package/cjs/validators/utils/file.js.map +7 -0
  253. package/cjs/validators/utils/iban/index.js +36 -17
  254. package/cjs/validators/utils/iban.js.map +7 -0
  255. package/cjs/validators/utils/image/index.js +88 -112
  256. package/cjs/validators/utils/image.js.map +7 -0
  257. package/cjs/validators/utils/index.js +99 -159
  258. package/cjs/validators/utils/index.js.map +7 -0
  259. package/cjs/validators/utils/int/index.js +35 -13
  260. package/cjs/validators/utils/int.js.map +7 -0
  261. package/cjs/validators/utils/number/index.js +34 -12
  262. package/cjs/validators/utils/number.js.map +7 -0
  263. package/cjs/validators/utils/otp/index.js +35 -13
  264. package/cjs/validators/utils/otp.js.map +7 -0
  265. package/cjs/validators/utils/phone/index.js +113 -58
  266. package/cjs/validators/utils/phone.js.map +7 -0
  267. package/cjs/validators/utils/postal_code/index.js +36 -16
  268. package/cjs/validators/utils/postal_code.js.map +7 -0
  269. package/cjs/validators/utils/text_limit/index.js +40 -25
  270. package/cjs/validators/utils/text_limit.js.map +7 -0
  271. package/cjs/validators/utils/uuid4/index.js +34 -13
  272. package/cjs/validators/utils/uuid4.js.map +7 -0
  273. package/index.d.ts +4 -1
  274. package/index.js +13 -4
  275. package/index.js.map +7 -0
  276. package/inputs/AutoCompleteInput/AutoComplete.stories.d.ts +2 -1
  277. package/inputs/AutoCompleteInput/__stories__/Default.d.ts +3 -2
  278. package/inputs/AutoCompleteInput/__stories__/Multiple.d.ts +3 -0
  279. package/inputs/AutoCompleteInput/index.d.ts +2 -2
  280. package/inputs/AutoCompleteInput/index.js +62 -37
  281. package/inputs/AutoCompleteInput/index.js.map +7 -0
  282. package/inputs/AutoCompleteInput/index.test.d.ts +1 -0
  283. package/inputs/Checkboxes/Checkboxes.stories.d.ts +3 -3
  284. package/inputs/Checkboxes/__stories__/Conditional.d.ts +3 -2
  285. package/inputs/Checkboxes/__stories__/Default.d.ts +2 -2
  286. package/inputs/Checkboxes/__stories__/WithDivider.d.ts +2 -2
  287. package/inputs/Checkboxes/index.d.ts +2 -1
  288. package/inputs/Checkboxes/index.js +73 -87
  289. package/inputs/Checkboxes/index.js.map +7 -0
  290. package/inputs/Checkboxes/index.test.d.ts +1 -0
  291. package/inputs/DateInput/DateInput.stories.d.ts +1 -1
  292. package/inputs/DateInput/__stories__/Default.d.ts +2 -2
  293. package/inputs/DateInput/index.d.ts +3 -4
  294. package/inputs/DateInput/index.js +91 -99
  295. package/inputs/DateInput/index.js.map +7 -0
  296. package/inputs/DateInput/index.test.d.ts +1 -0
  297. package/inputs/DateTimeInput/DateTimeInput.stories.d.ts +7 -0
  298. package/inputs/DateTimeInput/__stories__/Default.d.ts +3 -0
  299. package/inputs/DateTimeInput/index.d.ts +13 -0
  300. package/inputs/DateTimeInput/index.js +176 -0
  301. package/inputs/DateTimeInput/index.js.map +7 -0
  302. package/inputs/DateTimeInput/index.test.d.ts +1 -0
  303. package/inputs/DateTimeInput/package.json +6 -0
  304. package/inputs/FileInput/FileInput.stories.d.ts +1 -1
  305. package/inputs/FileInput/__stories__/Default.d.ts +2 -2
  306. package/inputs/FileInput/index.js +43 -54
  307. package/inputs/FileInput/index.js.map +7 -0
  308. package/inputs/FileInput/index.test.d.ts +1 -0
  309. package/inputs/ImageInput/ImageInput.stories.d.ts +3 -3
  310. package/inputs/ImageInput/__stories__/Default.d.ts +2 -2
  311. package/inputs/ImageInput/__stories__/MaxSize.d.ts +3 -0
  312. package/inputs/ImageInput/__stories__/WithInvalidImageDimension.d.ts +2 -2
  313. package/inputs/ImageInput/__stories__/WithInvalidImageSize.d.ts +2 -2
  314. package/inputs/ImageInput/index.js +63 -75
  315. package/inputs/ImageInput/index.js.map +7 -0
  316. package/inputs/ImageInput/index.test.d.ts +1 -0
  317. package/inputs/Input/Input.stories.d.ts +11 -10
  318. package/inputs/Input/__stories__/AFM.d.ts +2 -2
  319. package/inputs/Input/__stories__/Boolean.d.ts +2 -2
  320. package/inputs/Input/__stories__/IBAN.d.ts +2 -2
  321. package/inputs/Input/__stories__/Integer.d.ts +2 -2
  322. package/inputs/Input/__stories__/LandlineNumber.d.ts +2 -2
  323. package/inputs/Input/__stories__/MobilePhone.d.ts +2 -2
  324. package/inputs/Input/__stories__/PhoneNumber.d.ts +2 -2
  325. package/inputs/Input/__stories__/PostalCode.d.ts +2 -2
  326. package/inputs/Input/__stories__/String.d.ts +3 -0
  327. package/inputs/Input/__stories__/StringWithTrimValidation.d.ts +3 -0
  328. package/inputs/Input/__stories__/TextWithLimit.d.ts +3 -0
  329. package/inputs/Input/index.js +74 -66
  330. package/inputs/Input/index.js.map +7 -0
  331. package/inputs/Input/index.test.d.ts +1 -0
  332. package/inputs/Input/inputsInputScenarios/index.js +406 -0
  333. package/{FieldArray/__stories__/Default → inputs/Input/inputsInputScenarios}/package.json +1 -1
  334. package/inputs/Input/inputsInputScenarios.d.ts +57 -0
  335. package/inputs/Input/inputsInputScenarios.js.map +7 -0
  336. package/inputs/Label/Label.stories.d.ts +1 -1
  337. package/inputs/Label/__stories__/Default.d.ts +2 -2
  338. package/inputs/Label/index.d.ts +1 -3
  339. package/inputs/Label/index.js +12 -17
  340. package/inputs/Label/index.js.map +7 -0
  341. package/inputs/Label/index.test.d.ts +1 -0
  342. package/inputs/OtpInput/OtpInput.stories.d.ts +1 -1
  343. package/inputs/OtpInput/__stories__/Default.d.ts +2 -2
  344. package/inputs/OtpInput/index.d.ts +9 -2
  345. package/inputs/OtpInput/index.js +109 -103
  346. package/inputs/OtpInput/index.js.map +7 -0
  347. package/inputs/OtpInput/index.test.d.ts +1 -0
  348. package/inputs/Radio/Radio.stories.d.ts +3 -3
  349. package/inputs/Radio/__stories__/Conditional.d.ts +3 -2
  350. package/inputs/Radio/__stories__/Default.d.ts +2 -2
  351. package/inputs/Radio/__stories__/WithDivider.d.ts +2 -2
  352. package/inputs/Radio/index.d.ts +6 -1
  353. package/inputs/Radio/index.js +102 -55
  354. package/inputs/Radio/index.js.map +7 -0
  355. package/inputs/Radio/index.test.d.ts +1 -0
  356. package/inputs/Select/Select.stories.d.ts +1 -1
  357. package/inputs/Select/__stories__/Default.d.ts +2 -2
  358. package/inputs/Select/index.d.ts +1 -1
  359. package/inputs/Select/index.js +31 -31
  360. package/inputs/Select/index.js.map +7 -0
  361. package/inputs/Select/index.test.d.ts +1 -0
  362. package/inputs/index.js +21 -9
  363. package/inputs/index.js.map +7 -0
  364. package/inputs/inputsScenarios/index.js +499 -0
  365. package/inputs/inputsScenarios/package.json +6 -0
  366. package/inputs/inputsScenarios.d.ts +296 -0
  367. package/inputs/inputsScenarios.js.map +7 -0
  368. package/internal/index.js +10 -34
  369. package/internal.d.ts +2 -31
  370. package/internal.js.map +7 -0
  371. package/lazy/index.js +75 -393
  372. package/locales/el/index.js +6 -0
  373. package/{Form.stories → locales/el}/package.json +1 -1
  374. package/locales/el.d.ts +2 -0
  375. package/locales/el.js.map +7 -0
  376. package/package.json +7 -8
  377. package/registry/index.js +126 -99
  378. package/src/Field/ErrorGroup.tsx +84 -0
  379. package/src/Field/FieldBase.tsx +36 -22
  380. package/src/Field/FieldBaseContainer.tsx +7 -4
  381. package/src/Field/FieldConditional.tsx +5 -1
  382. package/src/Field/index.tsx +27 -3
  383. package/src/Field/types.tsx +73 -5
  384. package/src/Field/utils/calculateField.ts +49 -0
  385. package/src/Field/utils/evaluateFieldWithConditions.ts +30 -0
  386. package/src/Field/utils/index.ts +82 -0
  387. package/src/Field/utils/useField.ts +58 -0
  388. package/src/FieldArray/FieldArray.stories.js +3 -2
  389. package/src/FieldArray/FormDialog.tsx +378 -0
  390. package/src/FieldArray/__stories__/Default.tsx +1 -0
  391. package/src/FieldArray/__stories__/WithExactLength.tsx +1 -0
  392. package/src/FieldArray/__stories__/WithModal.tsx +159 -0
  393. package/src/FieldArray/index.test.tsx +28 -0
  394. package/src/FieldArray/index.tsx +92 -39
  395. package/src/FieldObject/index.tsx +27 -8
  396. package/src/Fieldset/index.tsx +5 -5
  397. package/src/Fieldset/types.tsx +5 -3
  398. package/src/FormBuilder/FormBuilder.stories.js +3 -1
  399. package/src/FormBuilder/__stories__/AutoErrorGrouping.tsx +63 -0
  400. package/src/FormBuilder/__stories__/ErrorGrouping.tsx +43 -0
  401. package/{FormBuilder/FormBuilder.mdx → src/FormBuilder/doc.mdx} +20 -33
  402. package/src/FormBuilder/index.test.tsx +28 -0
  403. package/src/FormBuilder/index.tsx +263 -1
  404. package/src/FormBuilder/interaction.test.tsx +32 -0
  405. package/src/FormBuilder/scenarios.test.tsx +1978 -0
  406. package/src/FormContext.tsx +1 -2
  407. package/src/MultiplicityField/MultiplicityField.stories.js +6 -6
  408. package/src/MultiplicityField/__stories__/PreviewDisplay.tsx +2 -2
  409. package/src/MultiplicityField/__stories__/WithExactLength.tsx +1 -1
  410. package/src/MultiplicityField/__stories__/WithMaxLength.tsx +1 -1
  411. package/src/MultiplicityField/__stories__/WithMinAndMaxLength.tsx +1 -1
  412. package/src/MultiplicityField/__stories__/WithMinLength.tsx +1 -1
  413. package/src/MultiplicityField/add-objects.tsx +31 -15
  414. package/{MultiplicityField/MultiplicityField.mdx → src/MultiplicityField/doc.mdx} +12 -16
  415. package/src/MultiplicityField/index.test.tsx +40 -0
  416. package/src/MultiplicityField/index.tsx +17 -31
  417. package/src/MultiplicityField/types.ts +21 -0
  418. package/src/Questions/Questions.stories.js +1 -1
  419. package/src/Questions/Questions.tsx +4 -4
  420. package/src/Questions/Step/StepArrayReview.tsx +1 -1
  421. package/src/Questions/Step/StepTitle.tsx +5 -3
  422. package/src/Questions/Step/index.ts +0 -1
  423. package/src/Questions/Step/types.tsx +1 -0
  424. package/src/Questions/__snapshots__/index.spec.tsx.snap +73 -587
  425. package/src/Questions/{index.mdx → doc.mdx} +13 -16
  426. package/src/Questions/index.spec.tsx +17 -5
  427. package/src/Questions/index.test.tsx +20 -0
  428. package/src/Questions/types.tsx +1 -0
  429. package/src/create-simple-form.mdx +2 -6
  430. package/{index.mdx → src/doc.mdx} +4 -8
  431. package/src/index.ts +4 -1
  432. package/src/inputs/AutoCompleteInput/AutoComplete.stories.js +2 -1
  433. package/src/inputs/AutoCompleteInput/__stories__/Default.tsx +19 -18
  434. package/src/inputs/AutoCompleteInput/__stories__/Multiple.tsx +47 -0
  435. package/src/inputs/AutoCompleteInput/doc.mdx +18 -0
  436. package/src/inputs/AutoCompleteInput/index.test.tsx +24 -0
  437. package/src/inputs/AutoCompleteInput/index.tsx +46 -29
  438. package/src/inputs/Checkboxes/Checkboxes.stories.js +3 -3
  439. package/src/inputs/Checkboxes/__stories__/Conditional.tsx +2 -3
  440. package/src/inputs/Checkboxes/doc.mdx +23 -0
  441. package/src/inputs/Checkboxes/index.test.tsx +28 -0
  442. package/src/inputs/Checkboxes/index.tsx +39 -33
  443. package/src/inputs/DateInput/DateInput.stories.js +1 -1
  444. package/src/inputs/DateInput/__stories__/Default.tsx +16 -15
  445. package/src/inputs/DateInput/doc.mdx +16 -0
  446. package/src/inputs/DateInput/index.test.tsx +20 -0
  447. package/src/inputs/DateInput/index.tsx +11 -9
  448. package/src/inputs/DateTimeInput/DateTimeInput.stories.js +8 -0
  449. package/src/inputs/DateTimeInput/__stories__/Default.tsx +25 -0
  450. package/src/inputs/DateTimeInput/doc.mdx +16 -0
  451. package/src/inputs/DateTimeInput/index.test.tsx +20 -0
  452. package/src/inputs/DateTimeInput/index.tsx +189 -0
  453. package/src/inputs/FileInput/FileInput.stories.js +1 -1
  454. package/src/inputs/FileInput/doc.mdx +15 -0
  455. package/src/inputs/FileInput/index.test.tsx +20 -0
  456. package/src/inputs/FileInput/index.tsx +8 -9
  457. package/src/inputs/ImageInput/ImageInput.stories.js +3 -3
  458. package/src/inputs/ImageInput/__stories__/MaxSize.tsx +37 -0
  459. package/src/inputs/ImageInput/__stories__/WithInvalidImageDimension.tsx +2 -0
  460. package/src/inputs/ImageInput/doc.mdx +23 -0
  461. package/src/inputs/ImageInput/index.test.tsx +32 -0
  462. package/src/inputs/ImageInput/index.tsx +16 -16
  463. package/src/inputs/Input/Input.stories.js +11 -10
  464. package/src/inputs/Input/__stories__/LandlineNumber.tsx +2 -1
  465. package/src/inputs/Input/__stories__/MobilePhone.tsx +1 -0
  466. package/src/inputs/Input/__stories__/PhoneNumber.tsx +1 -0
  467. package/src/inputs/Input/__stories__/PostalCode.tsx +1 -0
  468. package/src/inputs/Input/__stories__/{Default.tsx → String.tsx} +2 -2
  469. package/src/inputs/Input/__stories__/StringWithTrimValidation.tsx +26 -0
  470. package/src/inputs/Input/__stories__/{TextWithCharacterLimit.tsx → TextWithLimit.tsx} +3 -2
  471. package/src/inputs/Input/doc.mdx +56 -0
  472. package/src/inputs/Input/index.test.tsx +60 -0
  473. package/src/inputs/Input/index.tsx +40 -30
  474. package/src/inputs/Input/inputsInputScenarios.ts +404 -0
  475. package/src/inputs/Label/Label.stories.js +1 -1
  476. package/src/inputs/Label/__stories__/Default.tsx +3 -1
  477. package/src/inputs/Label/doc.mdx +14 -0
  478. package/src/inputs/Label/index.test.tsx +20 -0
  479. package/src/inputs/Label/index.tsx +3 -10
  480. package/src/inputs/OtpInput/OtpInput.stories.js +1 -1
  481. package/src/inputs/OtpInput/doc.mdx +16 -0
  482. package/src/inputs/OtpInput/index.test.tsx +20 -0
  483. package/src/inputs/OtpInput/index.tsx +4 -3
  484. package/src/inputs/Radio/Radio.stories.js +3 -3
  485. package/src/inputs/Radio/__stories__/Conditional.tsx +4 -1
  486. package/src/inputs/Radio/doc.mdx +23 -0
  487. package/src/inputs/Radio/index.test.tsx +28 -0
  488. package/src/inputs/Radio/index.tsx +79 -9
  489. package/src/inputs/Select/Select.stories.js +1 -1
  490. package/src/inputs/Select/doc.mdx +13 -0
  491. package/src/inputs/Select/index.test.tsx +20 -0
  492. package/src/inputs/Select/index.tsx +11 -4
  493. package/src/inputs/inputsScenarios.ts +496 -0
  494. package/src/installation.mdx +2 -5
  495. package/src/internal.ts +2 -31
  496. package/src/lazy.js +76 -59
  497. package/src/locales/el.ts +3 -0
  498. package/src/registry.js +109 -89
  499. package/src/types.tsx +11 -64
  500. package/src/utils.ts +34 -33
  501. package/src/validators/index.ts +90 -84
  502. package/src/validators/utils/date.ts +107 -0
  503. package/src/validators/utils/datetime.ts +130 -0
  504. package/src/validators/utils/file.ts +11 -9
  505. package/src/validators/utils/index.ts +2 -0
  506. package/src/validators/utils/int.ts +1 -1
  507. package/src/validators/utils/number.ts +1 -1
  508. package/src/validators/utils/phone.ts +63 -72
  509. package/src/validators/utils/postal_code.ts +1 -1
  510. package/src/validators/utils/uuid4.ts +2 -1
  511. package/src/validators/validators.spec.ts +6 -40
  512. package/types/index.js +2 -1
  513. package/types.d.ts +6 -35
  514. package/types.js.map +7 -0
  515. package/utils/index.js +57 -77
  516. package/utils.js.map +7 -0
  517. package/validators/index.js +112 -150
  518. package/validators/index.js.map +7 -0
  519. package/validators/types/index.js +1 -1
  520. package/validators/types.js.map +7 -0
  521. package/validators/utils/afm/index.js +16 -16
  522. package/validators/utils/afm.js.map +7 -0
  523. package/validators/utils/date/index.js +103 -0
  524. package/validators/utils/date/package.json +6 -0
  525. package/validators/utils/date.d.ts +9 -0
  526. package/validators/utils/date.js.map +7 -0
  527. package/validators/utils/datetime/index.js +116 -0
  528. package/{Questions/Questions.stories → validators/utils/datetime}/package.json +1 -1
  529. package/validators/utils/datetime.d.ts +9 -0
  530. package/validators/utils/datetime.js.map +7 -0
  531. package/validators/utils/file/index.js +22 -42
  532. package/validators/utils/file.js.map +7 -0
  533. package/validators/utils/iban/index.js +14 -12
  534. package/validators/utils/iban.js.map +7 -0
  535. package/validators/utils/image/index.js +66 -106
  536. package/validators/utils/image.js.map +7 -0
  537. package/validators/utils/index.d.ts +2 -0
  538. package/validators/utils/index.js +56 -48
  539. package/validators/utils/index.js.map +7 -0
  540. package/validators/utils/int/index.js +13 -8
  541. package/validators/utils/int.js.map +7 -0
  542. package/validators/utils/number/index.js +12 -7
  543. package/validators/utils/number.js.map +7 -0
  544. package/validators/utils/otp/index.js +13 -8
  545. package/validators/utils/otp.js.map +7 -0
  546. package/validators/utils/phone/index.js +89 -51
  547. package/validators/utils/phone.d.ts +1 -1
  548. package/validators/utils/phone.js.map +7 -0
  549. package/validators/utils/postal_code/index.js +14 -11
  550. package/validators/utils/postal_code.d.ts +1 -1
  551. package/validators/utils/postal_code.js.map +7 -0
  552. package/validators/utils/text_limit/index.js +18 -20
  553. package/validators/utils/text_limit.js.map +7 -0
  554. package/validators/utils/uuid4/index.js +12 -8
  555. package/validators/utils/uuid4.js.map +7 -0
  556. package/Field/utils.d.ts +0 -5
  557. package/FieldArray/FieldArray.stories/index.js +0 -8
  558. package/FieldArray/FieldArray.stories.playwright.json +0 -353
  559. package/FieldArray/__stories__/Default/index.js +0 -88
  560. package/FieldArray/__stories__/WithExactLength/index.js +0 -88
  561. package/FieldArray/__stories__/WithExactLength/package.json +0 -6
  562. package/Form.stories/index.js +0 -3
  563. package/FormBuilder/FormBuilder/index.js +0 -152
  564. package/FormBuilder/FormBuilder.d.ts +0 -5
  565. package/FormBuilder/FormBuilder.stories/index.js +0 -7
  566. package/FormBuilder/FormBuilder.stories/package.json +0 -6
  567. package/FormBuilder/FormBuilder.stories.playwright.json +0 -52
  568. package/FormBuilder/__stories__/Default/index.js +0 -26
  569. package/FormBuilder/__stories__/Default/package.json +0 -6
  570. package/MultiplicityField/MultiplicityField.stories/index.js +0 -12
  571. package/MultiplicityField/MultiplicityField.stories/package.json +0 -6
  572. package/MultiplicityField/MultiplicityField.stories.playwright.json +0 -1370
  573. package/MultiplicityField/__stories__/Default/index.js +0 -95
  574. package/MultiplicityField/__stories__/Default/package.json +0 -6
  575. package/MultiplicityField/__stories__/PreviewDisplay/index.js +0 -72
  576. package/MultiplicityField/__stories__/PreviewDisplay/package.json +0 -6
  577. package/MultiplicityField/__stories__/WithExactLength/index.js +0 -90
  578. package/MultiplicityField/__stories__/WithExactLength/package.json +0 -6
  579. package/MultiplicityField/__stories__/WithMaxLength/index.js +0 -93
  580. package/MultiplicityField/__stories__/WithMaxLength/package.json +0 -6
  581. package/MultiplicityField/__stories__/WithMinAndMaxLength/index.js +0 -94
  582. package/MultiplicityField/__stories__/WithMinAndMaxLength/package.json +0 -6
  583. package/MultiplicityField/__stories__/WithMinLength/index.js +0 -93
  584. package/MultiplicityField/__stories__/WithMinLength/package.json +0 -6
  585. package/Questions/Questions.stories/index.js +0 -7
  586. package/Questions/__snapshots__/index.spec.tsx.snap +0 -596
  587. package/Questions/__stories__/Default/index.js +0 -102
  588. package/Questions/__stories__/Default/package.json +0 -6
  589. package/Questions/index.mdx +0 -415
  590. package/Questions/index.spec/index.js +0 -59
  591. package/cjs/Field/index.mdx +0 -6
  592. package/cjs/FieldArray/FieldArray.stories/index.js +0 -38
  593. package/cjs/FieldArray/FieldArray.stories.playwright.json +0 -353
  594. package/cjs/FieldArray/__stories__/Default/index.js +0 -98
  595. package/cjs/FieldArray/__stories__/WithExactLength/index.js +0 -98
  596. package/cjs/Form.stories/index.js +0 -9
  597. package/cjs/FormBuilder/FormBuilder/index.js +0 -162
  598. package/cjs/FormBuilder/FormBuilder.mdx +0 -256
  599. package/cjs/FormBuilder/FormBuilder.stories/index.js +0 -26
  600. package/cjs/FormBuilder/FormBuilder.stories.playwright.json +0 -52
  601. package/cjs/FormBuilder/__stories__/Default/index.js +0 -36
  602. package/cjs/MultiplicityField/MultiplicityField.mdx +0 -590
  603. package/cjs/MultiplicityField/MultiplicityField.stories/index.js +0 -86
  604. package/cjs/MultiplicityField/MultiplicityField.stories.playwright.json +0 -1370
  605. package/cjs/MultiplicityField/__stories__/Default/index.js +0 -105
  606. package/cjs/MultiplicityField/__stories__/PreviewDisplay/index.js +0 -82
  607. package/cjs/MultiplicityField/__stories__/WithExactLength/index.js +0 -100
  608. package/cjs/MultiplicityField/__stories__/WithMaxLength/index.js +0 -103
  609. package/cjs/MultiplicityField/__stories__/WithMinAndMaxLength/index.js +0 -104
  610. package/cjs/MultiplicityField/__stories__/WithMinLength/index.js +0 -103
  611. package/cjs/Questions/Questions.stories/index.js +0 -26
  612. package/cjs/Questions/__snapshots__/index.spec.tsx.snap +0 -596
  613. package/cjs/Questions/__stories__/Default/index.js +0 -113
  614. package/cjs/Questions/index.mdx +0 -415
  615. package/cjs/Questions/index.spec/index.js +0 -63
  616. package/cjs/create-simple-form.mdx +0 -539
  617. package/cjs/index.mdx +0 -51
  618. package/cjs/inputs/AutoCompleteInput/AutoComplete.stories/index.js +0 -26
  619. package/cjs/inputs/AutoCompleteInput/__stories__/Default/index.js +0 -56
  620. package/cjs/inputs/Checkboxes/Checkboxes.stories/index.js +0 -50
  621. package/cjs/inputs/Checkboxes/Checkboxes.stories.playwright.json +0 -85
  622. package/cjs/inputs/Checkboxes/__stories__/Conditional/index.js +0 -102
  623. package/cjs/inputs/Checkboxes/__stories__/Default/index.js +0 -50
  624. package/cjs/inputs/Checkboxes/__stories__/WithDivider/index.js +0 -51
  625. package/cjs/inputs/Checkboxes/index.mdx +0 -0
  626. package/cjs/inputs/DateInput/DateInput.stories/index.js +0 -26
  627. package/cjs/inputs/DateInput/DateInput.stories.playwright.json +0 -72
  628. package/cjs/inputs/DateInput/__stories__/Default/index.js +0 -33
  629. package/cjs/inputs/FileInput/FileInput.stories/index.js +0 -26
  630. package/cjs/inputs/FileInput/FileInput.stories.playwright.json +0 -75
  631. package/cjs/inputs/FileInput/__stories__/Default/index.js +0 -30
  632. package/cjs/inputs/ImageInput/ImageInput.stories/index.js +0 -50
  633. package/cjs/inputs/ImageInput/ImageInput.stories.playwright.json +0 -77
  634. package/cjs/inputs/ImageInput/__stories__/Default/index.js +0 -38
  635. package/cjs/inputs/ImageInput/__stories__/WithInvalidImageDimension/index.js +0 -46
  636. package/cjs/inputs/ImageInput/__stories__/WithInvalidImageSize/index.js +0 -43
  637. package/cjs/inputs/Input/Input.stories/index.js +0 -134
  638. package/cjs/inputs/Input/Input.stories.playwright.json +0 -376
  639. package/cjs/inputs/Input/__stories__/AFM/index.js +0 -32
  640. package/cjs/inputs/Input/__stories__/Boolean/index.js +0 -33
  641. package/cjs/inputs/Input/__stories__/Default/index.js +0 -33
  642. package/cjs/inputs/Input/__stories__/IBAN/index.js +0 -33
  643. package/cjs/inputs/Input/__stories__/Integer/index.js +0 -41
  644. package/cjs/inputs/Input/__stories__/LandlineNumber/index.js +0 -36
  645. package/cjs/inputs/Input/__stories__/MobilePhone/index.js +0 -36
  646. package/cjs/inputs/Input/__stories__/PhoneNumber/index.js +0 -35
  647. package/cjs/inputs/Input/__stories__/PostalCode/index.js +0 -35
  648. package/cjs/inputs/Input/__stories__/TextWithCharacterLimit/index.js +0 -39
  649. package/cjs/inputs/Input/index.mdx +0 -8
  650. package/cjs/inputs/Label/Label.stories/index.js +0 -26
  651. package/cjs/inputs/Label/Label.stories.playwright.json +0 -40
  652. package/cjs/inputs/Label/__stories__/Default/index.js +0 -37
  653. package/cjs/inputs/Label/index.mdx +0 -0
  654. package/cjs/inputs/OtpInput/OtpInput.stories/index.js +0 -26
  655. package/cjs/inputs/OtpInput/__stories__/Default/index.js +0 -39
  656. package/cjs/inputs/Radio/Radio.stories/index.js +0 -50
  657. package/cjs/inputs/Radio/Radio.stories.playwright.json +0 -73
  658. package/cjs/inputs/Radio/__stories__/Conditional/index.js +0 -102
  659. package/cjs/inputs/Radio/__stories__/Default/index.js +0 -55
  660. package/cjs/inputs/Radio/__stories__/WithDivider/index.js +0 -56
  661. package/cjs/inputs/Radio/index.mdx +0 -0
  662. package/cjs/inputs/Select/Select.stories/index.js +0 -26
  663. package/cjs/inputs/Select/Select.stories.playwright.json +0 -22
  664. package/cjs/inputs/Select/__stories__/Default/index.js +0 -61
  665. package/cjs/installation.mdx +0 -68
  666. package/cjs/validators/validators.spec/index.js +0 -87
  667. package/create-simple-form.mdx +0 -539
  668. package/inputs/AutoCompleteInput/AutoComplete.stories/index.js +0 -7
  669. package/inputs/AutoCompleteInput/AutoComplete.stories/package.json +0 -6
  670. package/inputs/AutoCompleteInput/__stories__/Default/index.js +0 -46
  671. package/inputs/AutoCompleteInput/__stories__/Default/package.json +0 -6
  672. package/inputs/Checkboxes/Checkboxes.stories/index.js +0 -9
  673. package/inputs/Checkboxes/Checkboxes.stories/package.json +0 -6
  674. package/inputs/Checkboxes/Checkboxes.stories.playwright.json +0 -85
  675. package/inputs/Checkboxes/__stories__/Conditional/index.js +0 -92
  676. package/inputs/Checkboxes/__stories__/Conditional/package.json +0 -6
  677. package/inputs/Checkboxes/__stories__/Default/index.js +0 -40
  678. package/inputs/Checkboxes/__stories__/Default/package.json +0 -6
  679. package/inputs/Checkboxes/__stories__/WithDivider/index.js +0 -41
  680. package/inputs/Checkboxes/__stories__/WithDivider/package.json +0 -6
  681. package/inputs/Checkboxes/index.mdx +0 -0
  682. package/inputs/DateInput/DateInput.stories/index.js +0 -7
  683. package/inputs/DateInput/DateInput.stories/package.json +0 -6
  684. package/inputs/DateInput/DateInput.stories.playwright.json +0 -72
  685. package/inputs/DateInput/__stories__/Default/index.js +0 -23
  686. package/inputs/FileInput/FileInput.stories/index.js +0 -7
  687. package/inputs/FileInput/FileInput.stories/package.json +0 -6
  688. package/inputs/FileInput/FileInput.stories.playwright.json +0 -75
  689. package/inputs/FileInput/__stories__/Default/index.js +0 -20
  690. package/inputs/FileInput/__stories__/Default/package.json +0 -6
  691. package/inputs/ImageInput/ImageInput.stories/index.js +0 -9
  692. package/inputs/ImageInput/ImageInput.stories/package.json +0 -6
  693. package/inputs/ImageInput/ImageInput.stories.playwright.json +0 -77
  694. package/inputs/ImageInput/__stories__/Default/index.js +0 -28
  695. package/inputs/ImageInput/__stories__/Default/package.json +0 -6
  696. package/inputs/ImageInput/__stories__/WithInvalidImageDimension/index.js +0 -36
  697. package/inputs/ImageInput/__stories__/WithInvalidImageDimension/package.json +0 -6
  698. package/inputs/ImageInput/__stories__/WithInvalidImageSize/index.js +0 -33
  699. package/inputs/ImageInput/__stories__/WithInvalidImageSize/package.json +0 -6
  700. package/inputs/Input/Input.stories/index.js +0 -16
  701. package/inputs/Input/Input.stories/package.json +0 -6
  702. package/inputs/Input/Input.stories.playwright.json +0 -376
  703. package/inputs/Input/__stories__/AFM/index.js +0 -22
  704. package/inputs/Input/__stories__/AFM/package.json +0 -6
  705. package/inputs/Input/__stories__/Boolean/index.js +0 -23
  706. package/inputs/Input/__stories__/Boolean/package.json +0 -6
  707. package/inputs/Input/__stories__/Default/index.js +0 -23
  708. package/inputs/Input/__stories__/Default/package.json +0 -6
  709. package/inputs/Input/__stories__/Default.d.ts +0 -3
  710. package/inputs/Input/__stories__/IBAN/index.js +0 -23
  711. package/inputs/Input/__stories__/IBAN/package.json +0 -6
  712. package/inputs/Input/__stories__/Integer/index.js +0 -31
  713. package/inputs/Input/__stories__/Integer/package.json +0 -6
  714. package/inputs/Input/__stories__/LandlineNumber/index.js +0 -26
  715. package/inputs/Input/__stories__/LandlineNumber/package.json +0 -6
  716. package/inputs/Input/__stories__/MobilePhone/index.js +0 -26
  717. package/inputs/Input/__stories__/MobilePhone/package.json +0 -6
  718. package/inputs/Input/__stories__/PhoneNumber/index.js +0 -25
  719. package/inputs/Input/__stories__/PhoneNumber/package.json +0 -6
  720. package/inputs/Input/__stories__/PostalCode/index.js +0 -25
  721. package/inputs/Input/__stories__/PostalCode/package.json +0 -6
  722. package/inputs/Input/__stories__/TextWithCharacterLimit/index.js +0 -29
  723. package/inputs/Input/__stories__/TextWithCharacterLimit/package.json +0 -6
  724. package/inputs/Input/__stories__/TextWithCharacterLimit.d.ts +0 -3
  725. package/inputs/Input/index.mdx +0 -8
  726. package/inputs/Label/Label.stories/index.js +0 -7
  727. package/inputs/Label/Label.stories/package.json +0 -6
  728. package/inputs/Label/Label.stories.playwright.json +0 -40
  729. package/inputs/Label/__stories__/Default/index.js +0 -27
  730. package/inputs/Label/__stories__/Default/package.json +0 -6
  731. package/inputs/Label/index.mdx +0 -0
  732. package/inputs/OtpInput/OtpInput.stories/index.js +0 -7
  733. package/inputs/OtpInput/OtpInput.stories/package.json +0 -6
  734. package/inputs/OtpInput/__stories__/Default/index.js +0 -29
  735. package/inputs/OtpInput/__stories__/Default/package.json +0 -6
  736. package/inputs/Radio/Radio.stories/index.js +0 -9
  737. package/inputs/Radio/Radio.stories/package.json +0 -6
  738. package/inputs/Radio/Radio.stories.playwright.json +0 -73
  739. package/inputs/Radio/__stories__/Conditional/index.js +0 -92
  740. package/inputs/Radio/__stories__/Conditional/package.json +0 -6
  741. package/inputs/Radio/__stories__/Default/index.js +0 -45
  742. package/inputs/Radio/__stories__/Default/package.json +0 -6
  743. package/inputs/Radio/__stories__/WithDivider/index.js +0 -46
  744. package/inputs/Radio/__stories__/WithDivider/package.json +0 -6
  745. package/inputs/Radio/index.mdx +0 -0
  746. package/inputs/Select/Select.stories/index.js +0 -7
  747. package/inputs/Select/Select.stories/package.json +0 -6
  748. package/inputs/Select/Select.stories.playwright.json +0 -22
  749. package/inputs/Select/__stories__/Default/index.js +0 -51
  750. package/inputs/Select/__stories__/Default/package.json +0 -6
  751. package/installation.mdx +0 -68
  752. package/lazy.d.ts +0 -69
  753. package/registry.d.ts +0 -64
  754. package/src/Field/index.mdx +0 -6
  755. package/src/Field/utils.ts +0 -191
  756. package/src/FieldArray/FieldArray.stories.playwright.json +0 -353
  757. package/src/FormBuilder/FormBuilder.mdx +0 -256
  758. package/src/FormBuilder/FormBuilder.stories.playwright.json +0 -52
  759. package/src/FormBuilder/FormBuilder.tsx +0 -166
  760. package/src/MultiplicityField/MultiplicityField.mdx +0 -590
  761. package/src/MultiplicityField/MultiplicityField.stories.playwright.json +0 -1370
  762. package/src/index.mdx +0 -51
  763. package/src/inputs/Checkboxes/Checkboxes.stories.playwright.json +0 -85
  764. package/src/inputs/Checkboxes/index.mdx +0 -0
  765. package/src/inputs/DateInput/DateInput.stories.playwright.json +0 -72
  766. package/src/inputs/FileInput/FileInput.stories.playwright.json +0 -75
  767. package/src/inputs/ImageInput/ImageInput.stories.playwright.json +0 -77
  768. package/src/inputs/Input/Input.stories.playwright.json +0 -376
  769. package/src/inputs/Input/index.mdx +0 -8
  770. package/src/inputs/Label/Label.stories.playwright.json +0 -40
  771. package/src/inputs/Label/index.mdx +0 -0
  772. package/src/inputs/Radio/Radio.stories.playwright.json +0 -73
  773. package/src/inputs/Radio/index.mdx +0 -0
  774. package/src/inputs/Select/Select.stories.playwright.json +0 -22
  775. package/validators/validators.spec/index.js +0 -85
  776. /package/{Field/index.mdx → src/Field/doc.mdx} +0 -0
@@ -1,68 +1,80 @@
1
- "use strict";
2
-
3
- var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault");
4
- var _typeof = require("@babel/runtime/helpers/typeof");
5
- Object.defineProperty(exports, "__esModule", {
6
- value: true
1
+ var __create = Object.create;
2
+ var __defProp = Object.defineProperty;
3
+ var __getOwnPropDesc = Object.getOwnPropertyDescriptor;
4
+ var __getOwnPropNames = Object.getOwnPropertyNames;
5
+ var __getProtoOf = Object.getPrototypeOf;
6
+ var __hasOwnProp = Object.prototype.hasOwnProperty;
7
+ var __export = (target, all) => {
8
+ for (var name in all)
9
+ __defProp(target, name, { get: all[name], enumerable: true });
10
+ };
11
+ var __copyProps = (to, from, except, desc) => {
12
+ if (from && typeof from === "object" || typeof from === "function") {
13
+ for (let key of __getOwnPropNames(from))
14
+ if (!__hasOwnProp.call(to, key) && key !== except)
15
+ __defProp(to, key, { get: () => from[key], enumerable: !(desc = __getOwnPropDesc(from, key)) || desc.enumerable });
16
+ }
17
+ return to;
18
+ };
19
+ var __toESM = (mod, isNodeMode, target) => (target = mod != null ? __create(__getProtoOf(mod)) : {}, __copyProps(
20
+ // If the importer is in node compatibility mode or this is not an ESM
21
+ // file that has been converted to a CommonJS file using a Babel-
22
+ // compatible transform (i.e. "__esModule" has not been set), then set
23
+ // "default" to the CommonJS "module.exports" for node compatibility.
24
+ isNodeMode || !mod || !mod.__esModule ? __defProp(target, "default", { value: mod, enumerable: true }) : target,
25
+ mod
26
+ ));
27
+ var __toCommonJS = (mod) => __copyProps(__defProp({}, "__esModule", { value: true }), mod);
28
+ var FileInput_exports = {};
29
+ __export(FileInput_exports, {
30
+ FileInput: () => FileInput,
31
+ default: () => FileInput_default
7
32
  });
8
- exports["default"] = exports.FileInput = void 0;
9
- var _defineProperty2 = _interopRequireDefault(require("@babel/runtime/helpers/defineProperty"));
10
- var _extends2 = _interopRequireDefault(require("@babel/runtime/helpers/extends"));
11
- var _slicedToArray2 = _interopRequireDefault(require("@babel/runtime/helpers/slicedToArray"));
12
- var _objectWithoutProperties2 = _interopRequireDefault(require("@babel/runtime/helpers/objectWithoutProperties"));
13
- var _react = _interopRequireWildcard(require("react"));
14
- var _FileUpload = _interopRequireDefault(require("@digigov/react-core/cjs/FileUpload"));
15
- var _FileUploadContainer = _interopRequireDefault(require("@digigov/react-core/cjs/FileUploadContainer"));
16
- var _Hint = _interopRequireDefault(require("@digigov/react-core/cjs/Hint"));
17
- var _Button = _interopRequireDefault(require("@digigov/ui/cjs/form/Button"));
18
- var _i18n = require("@digigov/ui/cjs/i18n");
19
- var _Paragraph = _interopRequireDefault(require("@digigov/ui/cjs/typography/Paragraph"));
20
- var _excluded = ["name", "extra", "disabled", "reset", "onChange"];
21
- function _getRequireWildcardCache(e) { if ("function" != typeof WeakMap) return null; var r = new WeakMap(), t = new WeakMap(); return (_getRequireWildcardCache = function _getRequireWildcardCache(e) { return e ? t : r; })(e); }
22
- function _interopRequireWildcard(e, r) { if (!r && e && e.__esModule) return e; if (null === e || "object" != _typeof(e) && "function" != typeof e) return { "default": e }; var t = _getRequireWildcardCache(r); if (t && t.has(e)) return t.get(e); var n = { __proto__: null }, a = Object.defineProperty && Object.getOwnPropertyDescriptor; for (var u in e) if ("default" !== u && Object.prototype.hasOwnProperty.call(e, u)) { var i = a ? Object.getOwnPropertyDescriptor(e, u) : null; i && (i.get || i.set) ? Object.defineProperty(n, u, i) : n[u] = e[u]; } return n["default"] = e, t && t.set(e, n), n; }
23
- // eslint-disable-next-line @typescript-eslint/no-explicit-any
24
- var FileInput = exports.FileInput = /*#__PURE__*/_react["default"].forwardRef(function FileInput(_ref, ref) {
25
- var name = _ref.name,
26
- _ref$extra = _ref.extra,
27
- extra = _ref$extra === void 0 ? {} : _ref$extra,
28
- disabled = _ref.disabled,
29
- reset = _ref.reset,
30
- onChange = _ref.onChange,
31
- props = (0, _objectWithoutProperties2["default"])(_ref, _excluded);
32
- var _useTranslation = (0, _i18n.useTranslation)(),
33
- t = _useTranslation.t;
34
- var _useState = (0, _react.useState)([]),
35
- _useState2 = (0, _slicedToArray2["default"])(_useState, 2),
36
- files = _useState2[0],
37
- setFiles = _useState2[1];
38
- var handleChange = function handleChange(e) {
39
- var target = e.target;
40
- var selectedFiles = Array.from(target.files).map(function (_ref2) {
41
- var name = _ref2.name;
42
- return name;
43
- });
33
+ module.exports = __toCommonJS(FileInput_exports);
34
+ var import_react = __toESM(require("react"));
35
+ var import_Button = require("@digigov/ui/form/Button");
36
+ var import_FileUpload = require("@digigov/ui/form/FileUpload");
37
+ var import_i18n = require("@digigov/ui/i18n");
38
+ var import_Hint = require("@digigov/ui/typography/Hint");
39
+ var import_Paragraph = require("@digigov/ui/typography/Paragraph");
40
+ const FileInput = import_react.default.forwardRef(function FileInput2({ name, disabled, reset, onChange, ...props }, ref) {
41
+ const { t } = (0, import_i18n.useTranslation)();
42
+ const [files, setFiles] = (0, import_react.useState)([]);
43
+ const handleChange = (e) => {
44
+ const target = e.target;
45
+ const selectedFiles = Array.from(
46
+ target.files
47
+ ).map(({ name: name2 }) => name2);
44
48
  setFiles(selectedFiles);
45
- // proceed calling the onChange provided
46
- // by react-hook-form
47
49
  onChange(e);
48
50
  };
49
- return /*#__PURE__*/_react["default"].createElement(_react["default"].Fragment, null, /*#__PURE__*/_react["default"].createElement(_FileUploadContainer["default"], {
50
- hasFiles: files && files.length > 0
51
- }, files !== null && files !== void 0 && files.length ? /*#__PURE__*/_react["default"].createElement(_react["default"].Fragment, null, /*#__PURE__*/_react["default"].createElement(_Paragraph["default"], null, /*#__PURE__*/_react["default"].createElement("b", null, t('upload.file'), ":"), " ", "".concat(files.join(', ')))) : /*#__PURE__*/_react["default"].createElement(_Hint["default"], null, t('upload.no_file')), /*#__PURE__*/_react["default"].createElement(_FileUpload["default"], (0, _extends2["default"])({
52
- ref: ref,
53
- hasFiles: !!(files !== null && files !== void 0 && files.length),
54
- name: name,
55
- disabled: disabled,
56
- onChange: handleChange
57
- }, (0, _extends2["default"])({}, props, {
58
- required: undefined
59
- })), files !== null && files !== void 0 && files.length ? t('upload.change_file') : t('upload.choose_file')), files !== undefined && files.length > 0 && /*#__PURE__*/_react["default"].createElement(_react["default"].Fragment, null, /*#__PURE__*/_react["default"].createElement(_Button["default"], {
60
- variant: "link",
61
- onClick: function onClick(event) {
62
- event.preventDefault();
63
- reset((0, _defineProperty2["default"])({}, name, ''));
64
- setFiles(undefined);
65
- }
66
- }, t('upload.reset_file')))));
51
+ return /* @__PURE__ */ import_react.default.createElement(import_react.default.Fragment, null, /* @__PURE__ */ import_react.default.createElement(import_FileUpload.FileUploadContainer, { hasFiles: files && files.length > 0 }, files?.length ? /* @__PURE__ */ import_react.default.createElement(import_react.default.Fragment, null, /* @__PURE__ */ import_react.default.createElement(import_Paragraph.Paragraph, null, /* @__PURE__ */ import_react.default.createElement("b", null, t("upload.file"), ":"), " ", `${files.join(", ")}`)) : /* @__PURE__ */ import_react.default.createElement(import_Hint.Hint, null, t("upload.no_file")), /* @__PURE__ */ import_react.default.createElement(
52
+ import_FileUpload.FileUpload,
53
+ {
54
+ ref,
55
+ hasFiles: !!files?.length,
56
+ name,
57
+ disabled,
58
+ onChange: handleChange,
59
+ ...{ ...props, required: void 0, Field: void 0 }
60
+ },
61
+ files?.length ? t("upload.change_file") : t("upload.choose_file")
62
+ ), files !== void 0 && files.length > 0 && /* @__PURE__ */ import_react.default.createElement(import_react.default.Fragment, null, /* @__PURE__ */ import_react.default.createElement(
63
+ import_Button.Button,
64
+ {
65
+ variant: "link",
66
+ onClick: (event) => {
67
+ event.preventDefault();
68
+ reset({ [name]: "" });
69
+ setFiles(void 0);
70
+ }
71
+ },
72
+ t("upload.reset_file")
73
+ ))));
67
74
  });
68
- var _default = exports["default"] = FileInput;
75
+ var FileInput_default = FileInput;
76
+ // Annotate the CommonJS export names for ESM import in node:
77
+ 0 && (module.exports = {
78
+ FileInput
79
+ });
80
+ //# sourceMappingURL=index.js.map
@@ -0,0 +1,7 @@
1
+ {
2
+ "version": 3,
3
+ "sources": ["../../../../src/inputs/FileInput/index.tsx"],
4
+ "sourcesContent": ["import React, { useState } from 'react';\nimport { UncontrolledFieldProps } from '@digigov/form/Field/types';\nimport { Button } from '@digigov/ui/form/Button';\nimport { FileUpload, FileUploadContainer } from '@digigov/ui/form/FileUpload';\nimport { useTranslation } from '@digigov/ui/i18n';\nimport { Hint } from '@digigov/ui/typography/Hint';\nimport { Paragraph } from '@digigov/ui/typography/Paragraph';\nexport interface FileInputProps extends Omit<UncontrolledFieldProps, 'extra'> {\n extra?: {\n className?: string;\n multiple?: boolean;\n accept?: string;\n limit: {\n maxSize?: number;\n };\n };\n}\n\n// eslint-disable-next-line @typescript-eslint/no-explicit-any\nexport const FileInput: React.FC<any> = React.forwardRef(function FileInput(\n { name, disabled, reset, onChange, ...props },\n ref: any\n) {\n const { t } = useTranslation();\n const [files, setFiles] = useState<string[] | undefined>([]);\n const handleChange = (e) => {\n const target = e.target as HTMLInputElement;\n const selectedFiles = Array.from(\n target.files as ArrayLike<{ name: string }>\n ).map(({ name }) => name);\n setFiles(selectedFiles);\n // proceed calling the onChange provided\n // by react-hook-form\n onChange(e);\n };\n return (\n <>\n <FileUploadContainer hasFiles={files && files.length > 0}>\n {files?.length ? (\n <>\n <Paragraph>\n <b>{t('upload.file')}:</b> {`${files.join(', ')}`}\n </Paragraph>\n </>\n ) : (\n <Hint>{t('upload.no_file')}</Hint>\n )}\n <FileUpload\n ref={ref}\n hasFiles={!!files?.length}\n name={name}\n disabled={disabled}\n onChange={handleChange}\n {...{ ...props, required: undefined, Field: undefined }}\n >\n {files?.length ? t('upload.change_file') : t('upload.choose_file')}\n </FileUpload>\n {files !== undefined && files.length > 0 && (\n <>\n <Button\n variant=\"link\"\n onClick={(event) => {\n event.preventDefault();\n reset({ [name]: '' });\n setFiles(undefined);\n }}\n >\n {t('upload.reset_file')}\n </Button>\n </>\n )}\n </FileUploadContainer>\n </>\n );\n});\n\nexport default FileInput;\n"],
5
+ "mappings": ";;;;;;;;;;;;;;;;;;;;;;;;;;;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,mBAAgC;AAEhC,oBAAuB;AACvB,wBAAgD;AAChD,kBAA+B;AAC/B,kBAAqB;AACrB,uBAA0B;AAanB,MAAM,YAA2B,aAAAA,QAAM,WAAW,SAASC,WAChE,EAAE,MAAM,UAAU,OAAO,UAAU,GAAG,MAAM,GAC5C,KACA;AACA,QAAM,EAAE,EAAE,QAAI,4BAAe;AAC7B,QAAM,CAAC,OAAO,QAAQ,QAAI,uBAA+B,CAAC,CAAC;AAC3D,QAAM,eAAe,CAAC,MAAM;AAC1B,UAAM,SAAS,EAAE;AACjB,UAAM,gBAAgB,MAAM;AAAA,MAC1B,OAAO;AAAA,IACT,EAAE,IAAI,CAAC,EAAE,MAAAC,MAAK,MAAMA,KAAI;AACxB,aAAS,aAAa;AAGtB,aAAS,CAAC;AAAA,EACZ;AACA,SACE,6BAAAF,QAAA,2BAAAA,QAAA,gBACE,6BAAAA,QAAA,cAAC,yCAAoB,UAAU,SAAS,MAAM,SAAS,KACpD,OAAO,SACN,6BAAAA,QAAA,2BAAAA,QAAA,gBACE,6BAAAA,QAAA,cAAC,kCACC,6BAAAA,QAAA,cAAC,WAAG,EAAE,aAAa,GAAE,GAAC,GAAI,KAAE,GAAG,MAAM,KAAK,IAAI,CAAC,EACjD,CACF,IAEA,6BAAAA,QAAA,cAAC,wBAAM,EAAE,gBAAgB,CAAE,GAE7B,6BAAAA,QAAA;AAAA,IAAC;AAAA;AAAA,MACC;AAAA,MACA,UAAU,CAAC,CAAC,OAAO;AAAA,MACnB;AAAA,MACA;AAAA,MACA,UAAU;AAAA,MACT,GAAG,EAAE,GAAG,OAAO,UAAU,QAAW,OAAO,OAAU;AAAA;AAAA,IAErD,OAAO,SAAS,EAAE,oBAAoB,IAAI,EAAE,oBAAoB;AAAA,EACnE,GACC,UAAU,UAAa,MAAM,SAAS,KACrC,6BAAAA,QAAA,2BAAAA,QAAA,gBACE,6BAAAA,QAAA;AAAA,IAAC;AAAA;AAAA,MACC,SAAQ;AAAA,MACR,SAAS,CAAC,UAAU;AAClB,cAAM,eAAe;AACrB,cAAM,EAAE,CAAC,IAAI,GAAG,GAAG,CAAC;AACpB,iBAAS,MAAS;AAAA,MACpB;AAAA;AAAA,IAEC,EAAE,mBAAmB;AAAA,EACxB,CACF,CAEJ,CACF;AAEJ,CAAC;AAED,IAAO,oBAAQ;",
6
+ "names": ["React", "FileInput", "name"]
7
+ }
@@ -1,86 +1,98 @@
1
- "use strict";
2
-
3
- var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault");
4
- var _typeof = require("@babel/runtime/helpers/typeof");
5
- Object.defineProperty(exports, "__esModule", {
6
- value: true
1
+ var __create = Object.create;
2
+ var __defProp = Object.defineProperty;
3
+ var __getOwnPropDesc = Object.getOwnPropertyDescriptor;
4
+ var __getOwnPropNames = Object.getOwnPropertyNames;
5
+ var __getProtoOf = Object.getPrototypeOf;
6
+ var __hasOwnProp = Object.prototype.hasOwnProperty;
7
+ var __export = (target, all) => {
8
+ for (var name in all)
9
+ __defProp(target, name, { get: all[name], enumerable: true });
10
+ };
11
+ var __copyProps = (to, from, except, desc) => {
12
+ if (from && typeof from === "object" || typeof from === "function") {
13
+ for (let key of __getOwnPropNames(from))
14
+ if (!__hasOwnProp.call(to, key) && key !== except)
15
+ __defProp(to, key, { get: () => from[key], enumerable: !(desc = __getOwnPropDesc(from, key)) || desc.enumerable });
16
+ }
17
+ return to;
18
+ };
19
+ var __toESM = (mod, isNodeMode, target) => (target = mod != null ? __create(__getProtoOf(mod)) : {}, __copyProps(
20
+ // If the importer is in node compatibility mode or this is not an ESM
21
+ // file that has been converted to a CommonJS file using a Babel-
22
+ // compatible transform (i.e. "__esModule" has not been set), then set
23
+ // "default" to the CommonJS "module.exports" for node compatibility.
24
+ isNodeMode || !mod || !mod.__esModule ? __defProp(target, "default", { value: mod, enumerable: true }) : target,
25
+ mod
26
+ ));
27
+ var __toCommonJS = (mod) => __copyProps(__defProp({}, "__esModule", { value: true }), mod);
28
+ var ImageInput_exports = {};
29
+ __export(ImageInput_exports, {
30
+ Image: () => Image,
31
+ ImageInput: () => ImageInput,
32
+ default: () => ImageInput_default
7
33
  });
8
- exports["default"] = exports.ImageInput = exports.Image = void 0;
9
- var _extends2 = _interopRequireDefault(require("@babel/runtime/helpers/extends"));
10
- var _defineProperty2 = _interopRequireDefault(require("@babel/runtime/helpers/defineProperty"));
11
- var _slicedToArray2 = _interopRequireDefault(require("@babel/runtime/helpers/slicedToArray"));
12
- var _objectWithoutProperties2 = _interopRequireDefault(require("@babel/runtime/helpers/objectWithoutProperties"));
13
- var _react = _interopRequireWildcard(require("react"));
14
- var _FileUpload = _interopRequireDefault(require("@digigov/react-core/cjs/FileUpload"));
15
- var _FileUploadContainer = _interopRequireDefault(require("@digigov/react-core/cjs/FileUploadContainer"));
16
- var _Hint = _interopRequireDefault(require("@digigov/react-core/cjs/Hint"));
17
- var _Button = _interopRequireWildcard(require("@digigov/ui/cjs/form/Button"));
18
- var _i18n = require("@digigov/ui/cjs/i18n");
19
- var _Paragraph = _interopRequireDefault(require("@digigov/ui/cjs/typography/Paragraph"));
20
- var _excluded = ["name", "extra", "disabled", "onChange", "reset"];
21
- function _getRequireWildcardCache(e) { if ("function" != typeof WeakMap) return null; var r = new WeakMap(), t = new WeakMap(); return (_getRequireWildcardCache = function _getRequireWildcardCache(e) { return e ? t : r; })(e); }
22
- function _interopRequireWildcard(e, r) { if (!r && e && e.__esModule) return e; if (null === e || "object" != _typeof(e) && "function" != typeof e) return { "default": e }; var t = _getRequireWildcardCache(r); if (t && t.has(e)) return t.get(e); var n = { __proto__: null }, a = Object.defineProperty && Object.getOwnPropertyDescriptor; for (var u in e) if ("default" !== u && Object.prototype.hasOwnProperty.call(e, u)) { var i = a ? Object.getOwnPropertyDescriptor(e, u) : null; i && (i.get || i.set) ? Object.defineProperty(n, u, i) : n[u] = e[u]; } return n["default"] = e, t && t.set(e, n), n; }
23
- var Image = exports.Image = /*#__PURE__*/_react["default"].memo(function Image(_ref) {
24
- var src = _ref.src;
25
- return /*#__PURE__*/_react["default"].createElement("img", {
26
- src: src,
27
- className: "ds-image--ratio"
28
- });
34
+ module.exports = __toCommonJS(ImageInput_exports);
35
+ var import_react = __toESM(require("react"));
36
+ var import_Button = require("@digigov/ui/form/Button");
37
+ var import_FileUpload = require("@digigov/ui/form/FileUpload");
38
+ var import_i18n = require("@digigov/ui/i18n");
39
+ var import_Hint = require("@digigov/ui/typography/Hint");
40
+ var import_Paragraph = require("@digigov/ui/typography/Paragraph");
41
+ var import_Base = require("@digigov/ui/utils/Base");
42
+ const Image = import_react.default.memo(function Image2({ src }) {
43
+ return /* @__PURE__ */ import_react.default.createElement(import_Base.Base, { as: "img", src, className: "ds-image--ratio" });
29
44
  });
30
- var ImageInput = exports.ImageInput = /*#__PURE__*/_react["default"].forwardRef(function ImageInput(_ref2, ref) {
31
- var name = _ref2.name,
32
- _ref2$extra = _ref2.extra,
33
- extra = _ref2$extra === void 0 ? {} : _ref2$extra,
34
- disabled = _ref2.disabled,
35
- onChange = _ref2.onChange,
36
- reset = _ref2.reset,
37
- props = (0, _objectWithoutProperties2["default"])(_ref2, _excluded);
38
- var _useTranslation = (0, _i18n.useTranslation)(),
39
- t = _useTranslation.t;
40
- var _useState = (0, _react.useState)(null),
41
- _useState2 = (0, _slicedToArray2["default"])(_useState, 2),
42
- selectedImage = _useState2[0],
43
- setSelectedImage = _useState2[1];
44
- var _useState3 = (0, _react.useState)(null),
45
- _useState4 = (0, _slicedToArray2["default"])(_useState3, 2),
46
- imageUrl = _useState4[0],
47
- setImageUrl = _useState4[1];
48
- var handleImageChange = (0, _react.useCallback)(function (e) {
49
- var _target$files;
50
- e.preventDefault();
51
- var target = e.target;
52
- var selectedFile = (_target$files = target.files) === null || _target$files === void 0 ? void 0 : _target$files[0];
53
- if (selectedFile) {
54
- setSelectedImage(selectedFile);
55
- setImageUrl(URL.createObjectURL(selectedFile));
56
- }
57
- onChange(e);
58
- }, [selectedImage]);
59
- var handleDeleteImage = (0, _react.useCallback)(function (event) {
60
- event.preventDefault();
61
- reset((0, _defineProperty2["default"])({}, name, ''));
62
- setSelectedImage(null);
63
- setImageUrl('');
64
- }, [selectedImage]);
65
- return /*#__PURE__*/_react["default"].createElement(_react["default"].Fragment, null, /*#__PURE__*/_react["default"].createElement(_FileUploadContainer["default"], null, selectedImage !== null ? /*#__PURE__*/_react["default"].createElement(_react["default"].Fragment, null, /*#__PURE__*/_react["default"].createElement(_Paragraph["default"], null, /*#__PURE__*/_react["default"].createElement("b", null, t('upload.image'), ":"), " ", "".concat(selectedImage === null || selectedImage === void 0 ? void 0 : selectedImage.name))) : /*#__PURE__*/_react["default"].createElement(_Hint["default"], {
66
- className: "ds-dashed--border"
67
- }, t('upload.no_image')), /*#__PURE__*/_react["default"].createElement(_react["default"].Fragment, null, selectedImage !== null && /*#__PURE__*/_react["default"].createElement(Image, {
68
- src: imageUrl
69
- }), /*#__PURE__*/_react["default"].createElement(_Button.ButtonGroup, {
70
- marginTop: 2
71
- }, selectedImage !== null && /*#__PURE__*/_react["default"].createElement(_Button["default"], {
72
- variant: "link",
73
- onClick: handleDeleteImage
74
- }, t('upload.reset_file')), /*#__PURE__*/_react["default"].createElement(_FileUpload["default"], (0, _extends2["default"])({
75
- ref: ref,
76
- hasFiles: selectedImage !== null,
77
- name: name,
78
- disabled: disabled,
79
- accept: "image/*",
80
- onChange: handleImageChange
81
- }, (0, _extends2["default"])({}, props, {
82
- required: undefined,
83
- type: 'file'
84
- })), t('upload.choose_image'))))));
45
+ const ImageInput = import_react.default.forwardRef(
46
+ function ImageInput2({ name, disabled, onChange, reset, ...props }, ref) {
47
+ const { t } = (0, import_i18n.useTranslation)();
48
+ const [selectedImage, setSelectedImage] = (0, import_react.useState)(null);
49
+ const [imageUrl, setImageUrl] = (0, import_react.useState)(null);
50
+ const handleImageChange = (0, import_react.useCallback)(
51
+ (e) => {
52
+ e.preventDefault();
53
+ const target = e.target;
54
+ const selectedFile = target.files?.[0];
55
+ if (selectedFile) {
56
+ setSelectedImage(selectedFile);
57
+ setImageUrl(URL.createObjectURL(selectedFile));
58
+ }
59
+ onChange(e);
60
+ },
61
+ [selectedImage]
62
+ );
63
+ const handleDeleteImage = (0, import_react.useCallback)(
64
+ (event) => {
65
+ event.preventDefault();
66
+ reset({ [name]: "" });
67
+ setSelectedImage(null);
68
+ setImageUrl("");
69
+ },
70
+ [selectedImage]
71
+ );
72
+ return /* @__PURE__ */ import_react.default.createElement(import_react.default.Fragment, null, /* @__PURE__ */ import_react.default.createElement(import_FileUpload.FileUploadContainer, null, selectedImage !== null ? /* @__PURE__ */ import_react.default.createElement(import_react.default.Fragment, null, /* @__PURE__ */ import_react.default.createElement(import_Paragraph.Paragraph, null, /* @__PURE__ */ import_react.default.createElement(import_Base.Base, { as: "b" }, t("upload.image"), ":"), " ", `${selectedImage?.name}`)) : /* @__PURE__ */ import_react.default.createElement(import_Hint.Hint, { className: "ds-dashed--border" }, t("upload.no_image")), /* @__PURE__ */ import_react.default.createElement(import_react.default.Fragment, null, selectedImage !== null && /* @__PURE__ */ import_react.default.createElement(Image, { src: imageUrl }), /* @__PURE__ */ import_react.default.createElement(import_Button.ButtonGroup, { marginTop: 2 }, selectedImage !== null && /* @__PURE__ */ import_react.default.createElement(import_Button.Button, { variant: "link", onClick: handleDeleteImage }, t("upload.reset_file")), /* @__PURE__ */ import_react.default.createElement(
73
+ import_FileUpload.FileUpload,
74
+ {
75
+ ref,
76
+ hasFiles: selectedImage !== null,
77
+ name,
78
+ disabled,
79
+ accept: "image/*",
80
+ onChange: handleImageChange,
81
+ ...{
82
+ ...props,
83
+ required: void 0,
84
+ Field: void 0,
85
+ type: "file"
86
+ }
87
+ },
88
+ t("upload.choose_image")
89
+ )))));
90
+ }
91
+ );
92
+ var ImageInput_default = ImageInput;
93
+ // Annotate the CommonJS export names for ESM import in node:
94
+ 0 && (module.exports = {
95
+ Image,
96
+ ImageInput
85
97
  });
86
- var _default = exports["default"] = ImageInput;
98
+ //# sourceMappingURL=index.js.map
@@ -0,0 +1,7 @@
1
+ {
2
+ "version": 3,
3
+ "sources": ["../../../../src/inputs/ImageInput/index.tsx"],
4
+ "sourcesContent": ["import React, { useState, useCallback } from 'react';\nimport { UncontrolledFieldProps } from '@digigov/form/Field/types';\nimport { Button, ButtonGroup } from '@digigov/ui/form/Button';\nimport { FileUpload, FileUploadContainer } from '@digigov/ui/form/FileUpload';\nimport { useTranslation } from '@digigov/ui/i18n';\nimport { Hint } from '@digigov/ui/typography/Hint';\nimport { Paragraph } from '@digigov/ui/typography/Paragraph';\nimport { Base } from '@digigov/ui/utils/Base';\nexport interface ImageProps {\n src?: any;\n}\n\nexport interface Limit {\n maxSize?: number;\n maxWidth?: number;\n maxHeight?: number;\n minWidth?: number;\n minHeight?: number;\n}\n\nexport const Image: React.FC<ImageProps> = React.memo(function Image({ src }) {\n return <Base as=\"img\" src={src} className=\"ds-image--ratio\" />;\n});\nexport interface ImageInputProps extends Omit<UncontrolledFieldProps, 'extra'> {\n extra?: {\n className?: string;\n multiple?: boolean;\n accept?: string;\n limit?: Limit;\n };\n reset: (values?: any) => void;\n onChange: (e: React.ChangeEvent<HTMLInputElement>) => void;\n}\n\nexport const ImageInput: React.FC<ImageInputProps> = React.forwardRef(\n function ImageInput({ name, disabled, onChange, reset, ...props }, ref: any) {\n const { t } = useTranslation();\n const [selectedImage, setSelectedImage] = useState<File | null>(null);\n const [imageUrl, setImageUrl] = useState<string | null>(null);\n const handleImageChange = useCallback(\n (e: React.ChangeEvent<HTMLInputElement>) => {\n e.preventDefault();\n const target = e.target as HTMLInputElement;\n const selectedFile = target.files?.[0];\n\n if (selectedFile) {\n setSelectedImage(selectedFile);\n setImageUrl(URL.createObjectURL(selectedFile));\n }\n onChange(e);\n },\n [selectedImage]\n );\n\n const handleDeleteImage = useCallback(\n (event) => {\n event.preventDefault();\n reset({ [name]: '' });\n setSelectedImage(null);\n setImageUrl('');\n },\n [selectedImage]\n );\n\n return (\n <>\n <FileUploadContainer>\n {selectedImage !== null ? (\n <>\n <Paragraph>\n <Base as=\"b\">{t('upload.image')}:</Base>{' '}\n {`${selectedImage?.name}`}\n </Paragraph>\n </>\n ) : (\n <Hint className=\"ds-dashed--border\">{t('upload.no_image')}</Hint>\n )}\n <>\n {selectedImage !== null && <Image src={imageUrl} />}\n <ButtonGroup marginTop={2}>\n {selectedImage !== null && (\n <Button variant=\"link\" onClick={handleDeleteImage}>\n {t('upload.reset_file')}\n </Button>\n )}\n <FileUpload\n ref={ref}\n hasFiles={selectedImage !== null}\n name={name}\n disabled={disabled}\n accept=\"image/*\"\n onChange={handleImageChange}\n {...{\n ...props,\n required: undefined,\n Field: undefined,\n type: 'file',\n }}\n >\n {t('upload.choose_image')}\n </FileUpload>\n </ButtonGroup>\n </>\n </FileUploadContainer>\n </>\n );\n }\n);\n\nexport default ImageInput;\n"],
5
+ "mappings": ";;;;;;;;;;;;;;;;;;;;;;;;;;;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,mBAA6C;AAE7C,oBAAoC;AACpC,wBAAgD;AAChD,kBAA+B;AAC/B,kBAAqB;AACrB,uBAA0B;AAC1B,kBAAqB;AAad,MAAM,QAA8B,aAAAA,QAAM,KAAK,SAASC,OAAM,EAAE,IAAI,GAAG;AAC5E,SAAO,6BAAAD,QAAA,cAAC,oBAAK,IAAG,OAAM,KAAU,WAAU,mBAAkB;AAC9D,CAAC;AAYM,MAAM,aAAwC,aAAAA,QAAM;AAAA,EACzD,SAASE,YAAW,EAAE,MAAM,UAAU,UAAU,OAAO,GAAG,MAAM,GAAG,KAAU;AAC3E,UAAM,EAAE,EAAE,QAAI,4BAAe;AAC7B,UAAM,CAAC,eAAe,gBAAgB,QAAI,uBAAsB,IAAI;AACpE,UAAM,CAAC,UAAU,WAAW,QAAI,uBAAwB,IAAI;AAC5D,UAAM,wBAAoB;AAAA,MACxB,CAAC,MAA2C;AAC1C,UAAE,eAAe;AACjB,cAAM,SAAS,EAAE;AACjB,cAAM,eAAe,OAAO,QAAQ,CAAC;AAErC,YAAI,cAAc;AAChB,2BAAiB,YAAY;AAC7B,sBAAY,IAAI,gBAAgB,YAAY,CAAC;AAAA,QAC/C;AACA,iBAAS,CAAC;AAAA,MACZ;AAAA,MACA,CAAC,aAAa;AAAA,IAChB;AAEA,UAAM,wBAAoB;AAAA,MACxB,CAAC,UAAU;AACT,cAAM,eAAe;AACrB,cAAM,EAAE,CAAC,IAAI,GAAG,GAAG,CAAC;AACpB,yBAAiB,IAAI;AACrB,oBAAY,EAAE;AAAA,MAChB;AAAA,MACA,CAAC,aAAa;AAAA,IAChB;AAEA,WACE,6BAAAF,QAAA,2BAAAA,QAAA,gBACE,6BAAAA,QAAA,cAAC,6CACE,kBAAkB,OACjB,6BAAAA,QAAA,2BAAAA,QAAA,gBACE,6BAAAA,QAAA,cAAC,kCACC,6BAAAA,QAAA,cAAC,oBAAK,IAAG,OAAK,EAAE,cAAc,GAAE,GAAC,GAAQ,KACxC,GAAG,eAAe,IAAI,EACzB,CACF,IAEA,6BAAAA,QAAA,cAAC,oBAAK,WAAU,uBAAqB,EAAE,iBAAiB,CAAE,GAE5D,6BAAAA,QAAA,2BAAAA,QAAA,gBACG,kBAAkB,QAAQ,6BAAAA,QAAA,cAAC,SAAM,KAAK,UAAU,GACjD,6BAAAA,QAAA,cAAC,6BAAY,WAAW,KACrB,kBAAkB,QACjB,6BAAAA,QAAA,cAAC,wBAAO,SAAQ,QAAO,SAAS,qBAC7B,EAAE,mBAAmB,CACxB,GAEF,6BAAAA,QAAA;AAAA,MAAC;AAAA;AAAA,QACC;AAAA,QACA,UAAU,kBAAkB;AAAA,QAC5B;AAAA,QACA;AAAA,QACA,QAAO;AAAA,QACP,UAAU;AAAA,QACT,GAAG;AAAA,UACF,GAAG;AAAA,UACH,UAAU;AAAA,UACV,OAAO;AAAA,UACP,MAAM;AAAA,QACR;AAAA;AAAA,MAEC,EAAE,qBAAqB;AAAA,IAC1B,CACF,CACF,CACF,CACF;AAAA,EAEJ;AACF;AAEA,IAAO,qBAAQ;",
6
+ "names": ["React", "Image", "ImageInput"]
7
+ }
@@ -1,76 +1,110 @@
1
- "use strict";
2
-
3
- var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault");
4
- Object.defineProperty(exports, "__esModule", {
5
- value: true
1
+ var __create = Object.create;
2
+ var __defProp = Object.defineProperty;
3
+ var __getOwnPropDesc = Object.getOwnPropertyDescriptor;
4
+ var __getOwnPropNames = Object.getOwnPropertyNames;
5
+ var __getProtoOf = Object.getPrototypeOf;
6
+ var __hasOwnProp = Object.prototype.hasOwnProperty;
7
+ var __export = (target, all) => {
8
+ for (var name in all)
9
+ __defProp(target, name, { get: all[name], enumerable: true });
10
+ };
11
+ var __copyProps = (to, from, except, desc) => {
12
+ if (from && typeof from === "object" || typeof from === "function") {
13
+ for (let key of __getOwnPropNames(from))
14
+ if (!__hasOwnProp.call(to, key) && key !== except)
15
+ __defProp(to, key, { get: () => from[key], enumerable: !(desc = __getOwnPropDesc(from, key)) || desc.enumerable });
16
+ }
17
+ return to;
18
+ };
19
+ var __toESM = (mod, isNodeMode, target) => (target = mod != null ? __create(__getProtoOf(mod)) : {}, __copyProps(
20
+ // If the importer is in node compatibility mode or this is not an ESM
21
+ // file that has been converted to a CommonJS file using a Babel-
22
+ // compatible transform (i.e. "__esModule" has not been set), then set
23
+ // "default" to the CommonJS "module.exports" for node compatibility.
24
+ isNodeMode || !mod || !mod.__esModule ? __defProp(target, "default", { value: mod, enumerable: true }) : target,
25
+ mod
26
+ ));
27
+ var __toCommonJS = (mod) => __copyProps(__defProp({}, "__esModule", { value: true }), mod);
28
+ var Input_exports = {};
29
+ __export(Input_exports, {
30
+ Input: () => Input,
31
+ default: () => Input_default
6
32
  });
7
- exports["default"] = exports.Input = void 0;
8
- var _extends2 = _interopRequireDefault(require("@babel/runtime/helpers/extends"));
9
- var _objectWithoutProperties2 = _interopRequireDefault(require("@babel/runtime/helpers/objectWithoutProperties"));
10
- var _react = _interopRequireDefault(require("react"));
11
- var _reactHookForm = require("react-hook-form");
12
- var _reactCore = require("@digigov/react-core");
13
- var _TextArea = _interopRequireDefault(require("@digigov/react-core/cjs/TextArea"));
14
- var _TextInput = _interopRequireDefault(require("@digigov/react-core/cjs/TextInput"));
15
- var _i18n = require("@digigov/ui/cjs/i18n");
16
- var _excluded = ["name", "control", "type", "extra"];
17
- var TYPES_MAP = {
18
- string: 'text',
19
- "int": 'text',
20
- text: 'text',
21
- date: 'date'
33
+ module.exports = __toCommonJS(Input_exports);
34
+ var import_react = __toESM(require("react"));
35
+ var import_react_hook_form = require("react-hook-form");
36
+ var import_TextArea = require("@digigov/ui/form/TextArea");
37
+ var import_TextInput = require("@digigov/ui/form/TextInput");
38
+ var import_i18n = require("@digigov/ui/i18n");
39
+ var import_Hint = require("@digigov/ui/typography/Hint");
40
+ const TYPES_MAP = {
41
+ string: "text",
42
+ int: "text",
43
+ text: "text",
44
+ date: "date"
22
45
  };
23
- var Input = exports.Input = /*#__PURE__*/_react["default"].forwardRef(function WrappedInput(_ref, ref) {
24
- var name = _ref.name,
25
- control = _ref.control,
26
- type = _ref.type,
27
- extra = _ref.extra,
28
- props = (0, _objectWithoutProperties2["default"])(_ref, _excluded);
29
- // eslint-disable-next-line prefer-const
30
- var _ref2 = extra || {},
31
- _ref2$multiline = _ref2.multiline,
32
- multiline = _ref2$multiline === void 0 ? false : _ref2$multiline,
33
- rows = _ref2.rows,
34
- limit = _ref2.limit;
35
- var _ref3 = extra || {},
36
- className = _ref3.className;
37
- // if enforced to multiline use true. Derive from type otherwise.
38
- multiline = multiline === true || type === 'text';
39
- // use explicit rows value if set. Derive from multiline otherwise.
40
- rows = rows || (multiline ? 4 : 1);
41
- // translate dilosi type to HTML Input type
42
- var fieldType = TYPES_MAP[type || 'text'] || 'text';
43
- var _useTranslation = (0, _i18n.useTranslation)(),
44
- t = _useTranslation.t;
45
- var currentValue = (0, _reactHookForm.useWatch)({
46
- control: control,
47
- name: name
48
- });
49
- if (multiline === true) {
50
- return /*#__PURE__*/_react["default"].createElement(_react["default"].Fragment, null, /*#__PURE__*/_react["default"].createElement(_TextArea["default"], (0, _extends2["default"])({
51
- name: name,
52
- className: className,
53
- rows: rows,
54
- ref: ref
55
- }, (0, _extends2["default"])({}, props, {
56
- reset: undefined,
57
- required: undefined,
58
- type: fieldType
59
- }))), (limit === null || limit === void 0 ? void 0 : limit.max) && /*#__PURE__*/_react["default"].createElement(_reactCore.Hint, null, currentValue === undefined || (currentValue === null || currentValue === void 0 ? void 0 : currentValue.length) >= 0 && (currentValue === null || currentValue === void 0 ? void 0 : currentValue.length) <= (limit === null || limit === void 0 ? void 0 : limit.max) ? /*#__PURE__*/_react["default"].createElement("span", null, t('form.info.text.you_have'), ' ', /*#__PURE__*/_react["default"].createElement("b", null, !currentValue ? limit.max : (limit === null || limit === void 0 ? void 0 : limit.max) - (currentValue === null || currentValue === void 0 ? void 0 : currentValue.length)), ' ', currentValue && (limit === null || limit === void 0 ? void 0 : limit.max) - (currentValue === null || currentValue === void 0 ? void 0 : currentValue.length) === 1 ? "".concat(t('form.info.text.character')) : "".concat(t('form.info.text.characters')), ' ', t('form.info.text.remaining'), ".") : /*#__PURE__*/_react["default"].createElement("span", {
60
- style: {
61
- color: '#b60202'
46
+ const Input = import_react.default.forwardRef(
47
+ function WrappedInput({ name, control, type, extra, ...props }, ref) {
48
+ let { multiline = false, rows, limit } = extra || {};
49
+ const { className } = extra || {};
50
+ multiline = multiline === true || type === "text";
51
+ rows = rows || (multiline ? 4 : 1);
52
+ const fieldType = TYPES_MAP[type || "text"] || "text";
53
+ const { t } = (0, import_i18n.useTranslation)();
54
+ const currentValue = (0, import_react_hook_form.useWatch)({ control, name });
55
+ const getRemainingChars = (currentValue2, limit2) => {
56
+ if (currentValue2) {
57
+ return limit2?.max - currentValue2.length;
62
58
  }
63
- }, t('form.info.text.you_have'), ' ', /*#__PURE__*/_react["default"].createElement("b", null, currentValue && (currentValue === null || currentValue === void 0 ? void 0 : currentValue.length) - (limit === null || limit === void 0 ? void 0 : limit.max)), ' ', (currentValue === null || currentValue === void 0 ? void 0 : currentValue.length) - (limit === null || limit === void 0 ? void 0 : limit.max) === 1 ? "".concat(t('form.info.text.character')) : "".concat(t('form.info.text.characters')), ' ', t('form.info.text.too_many'), ".")));
64
- } else {
65
- return /*#__PURE__*/_react["default"].createElement(_TextInput["default"], (0, _extends2["default"])({
66
- name: name,
67
- type: fieldType,
68
- className: className,
69
- ref: ref
70
- }, (0, _extends2["default"])({}, props, {
71
- reset: undefined,
72
- required: undefined
73
- })));
59
+ return limit2?.max;
60
+ };
61
+ const constructRemainingText = (currentValue2, limit2) => {
62
+ const remainingChars = getRemainingChars(currentValue2, limit2);
63
+ let remainingText = Math.abs(remainingChars) === 1 ? t("form.info.text.character") : t("form.info.text.characters");
64
+ remainingText += remainingChars > 0 ? ` ${t("form.info.text.remaining")}.` : ` ${t("form.info.text.too_many")}.`;
65
+ return remainingText;
66
+ };
67
+ if (multiline === true) {
68
+ return /* @__PURE__ */ import_react.default.createElement(import_react.default.Fragment, null, /* @__PURE__ */ import_react.default.createElement(
69
+ import_TextArea.TextArea,
70
+ {
71
+ name,
72
+ className,
73
+ rows,
74
+ ref,
75
+ ...{
76
+ ...props,
77
+ reset: void 0,
78
+ required: void 0,
79
+ type: fieldType,
80
+ Field: void 0
81
+ }
82
+ }
83
+ ), limit?.max && /* @__PURE__ */ import_react.default.createElement(import_Hint.Hint, { display: "flex" }, t("form.info.text.you_have"), /* @__PURE__ */ import_react.default.createElement(import_Hint.Hint, { fontWeight: "bold" }, "\xA0", `${Math.abs(getRemainingChars(currentValue, limit))}`, "\xA0"), constructRemainingText(currentValue, limit)));
84
+ } else {
85
+ return /* @__PURE__ */ import_react.default.createElement(
86
+ import_TextInput.TextInput,
87
+ {
88
+ name,
89
+ id: name,
90
+ type: fieldType,
91
+ "data-type": type,
92
+ className,
93
+ ref,
94
+ ...{
95
+ ...props,
96
+ reset: void 0,
97
+ required: void 0,
98
+ Field: void 0
99
+ }
100
+ }
101
+ );
102
+ }
74
103
  }
104
+ );
105
+ var Input_default = Input;
106
+ // Annotate the CommonJS export names for ESM import in node:
107
+ 0 && (module.exports = {
108
+ Input
75
109
  });
76
- var _default = exports["default"] = Input;
110
+ //# sourceMappingURL=index.js.map
@@ -0,0 +1,7 @@
1
+ {
2
+ "version": 3,
3
+ "sources": ["../../../../src/inputs/Input/index.tsx"],
4
+ "sourcesContent": ["import React from 'react';\nimport { useWatch } from 'react-hook-form';\nimport { UncontrolledFieldProps } from '@digigov/form/Field/types';\nimport { TextArea } from '@digigov/ui/form/TextArea';\nimport { TextInput } from '@digigov/ui/form/TextInput';\nimport { useTranslation } from '@digigov/ui/i18n';\nimport { Hint } from '@digigov/ui/typography/Hint';\n\nconst TYPES_MAP = {\n string: 'text',\n int: 'text',\n text: 'text',\n date: 'date',\n};\n\nexport interface InputProps extends Omit<UncontrolledFieldProps, 'extra'> {\n extra?: {\n fullWidth?: boolean;\n multiline?: boolean;\n className?: string;\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\n rows?: any;\n limit: {\n min?: number;\n max?: number;\n };\n };\n}\n\nexport const Input: React.ExoticComponent<InputProps> = React.forwardRef(\n function WrappedInput({ name, control, type, extra, ...props }, ref: never) {\n // eslint-disable-next-line prefer-const\n let { multiline = false, rows, limit } = extra || {};\n const { className } = extra || {};\n // if enforced to multiline use true. Derive from type otherwise.\n multiline = multiline === true || type === 'text';\n // use explicit rows value if set. Derive from multiline otherwise.\n rows = rows || (multiline ? 4 : 1);\n // translate dilosi type to HTML Input type\n const fieldType = TYPES_MAP[type || 'text'] || 'text';\n const { t } = useTranslation();\n const currentValue: string | '' = useWatch({ control, name });\n\n const getRemainingChars = (currentValue, limit) => {\n if (currentValue) {\n return limit?.max - currentValue.length;\n }\n return limit?.max;\n };\n\n const constructRemainingText = (currentValue, limit) => {\n const remainingChars = getRemainingChars(currentValue, limit);\n let remainingText =\n Math.abs(remainingChars) === 1\n ? t('form.info.text.character')\n : t('form.info.text.characters');\n remainingText +=\n remainingChars > 0\n ? ` ${t('form.info.text.remaining')}.`\n : ` ${t('form.info.text.too_many')}.`;\n return remainingText;\n };\n\n if (multiline === true) {\n return (\n <>\n <TextArea\n name={name}\n className={className}\n rows={rows}\n ref={ref}\n {...{\n ...props,\n reset: undefined,\n required: undefined,\n type: fieldType,\n Field: undefined,\n }}\n />\n {limit?.max && (\n <Hint display={'flex'}>\n {t('form.info.text.you_have')}\n <Hint fontWeight=\"bold\">\n &nbsp;{`${Math.abs(getRemainingChars(currentValue, limit))}`}\n &nbsp;\n </Hint>\n {constructRemainingText(currentValue, limit)}\n </Hint>\n )}\n </>\n );\n } else {\n return (\n <TextInput\n name={name}\n id={name}\n type={fieldType}\n data-type={type}\n className={className}\n ref={ref}\n {...{\n ...props,\n reset: undefined,\n required: undefined,\n Field: undefined,\n }}\n />\n );\n }\n }\n);\n\nexport default Input;\n"],
5
+ "mappings": ";;;;;;;;;;;;;;;;;;;;;;;;;;;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,mBAAkB;AAClB,6BAAyB;AAEzB,sBAAyB;AACzB,uBAA0B;AAC1B,kBAA+B;AAC/B,kBAAqB;AAErB,MAAM,YAAY;AAAA,EAChB,QAAQ;AAAA,EACR,KAAK;AAAA,EACL,MAAM;AAAA,EACN,MAAM;AACR;AAgBO,MAAM,QAA2C,aAAAA,QAAM;AAAA,EAC5D,SAAS,aAAa,EAAE,MAAM,SAAS,MAAM,OAAO,GAAG,MAAM,GAAG,KAAY;AAE1E,QAAI,EAAE,YAAY,OAAO,MAAM,MAAM,IAAI,SAAS,CAAC;AACnD,UAAM,EAAE,UAAU,IAAI,SAAS,CAAC;AAEhC,gBAAY,cAAc,QAAQ,SAAS;AAE3C,WAAO,SAAS,YAAY,IAAI;AAEhC,UAAM,YAAY,UAAU,QAAQ,MAAM,KAAK;AAC/C,UAAM,EAAE,EAAE,QAAI,4BAAe;AAC7B,UAAM,mBAA4B,iCAAS,EAAE,SAAS,KAAK,CAAC;AAE5D,UAAM,oBAAoB,CAACC,eAAcC,WAAU;AACjD,UAAID,eAAc;AAChB,eAAOC,QAAO,MAAMD,cAAa;AAAA,MACnC;AACA,aAAOC,QAAO;AAAA,IAChB;AAEA,UAAM,yBAAyB,CAACD,eAAcC,WAAU;AACtD,YAAM,iBAAiB,kBAAkBD,eAAcC,MAAK;AAC5D,UAAI,gBACF,KAAK,IAAI,cAAc,MAAM,IACzB,EAAE,0BAA0B,IAC5B,EAAE,2BAA2B;AACnC,uBACE,iBAAiB,IACb,IAAI,EAAE,0BAA0B,CAAC,MACjC,IAAI,EAAE,yBAAyB,CAAC;AACtC,aAAO;AAAA,IACT;AAEA,QAAI,cAAc,MAAM;AACtB,aACE,6BAAAF,QAAA,2BAAAA,QAAA,gBACE,6BAAAA,QAAA;AAAA,QAAC;AAAA;AAAA,UACC;AAAA,UACA;AAAA,UACA;AAAA,UACA;AAAA,UACC,GAAG;AAAA,YACF,GAAG;AAAA,YACH,OAAO;AAAA,YACP,UAAU;AAAA,YACV,MAAM;AAAA,YACN,OAAO;AAAA,UACT;AAAA;AAAA,MACF,GACC,OAAO,OACN,6BAAAA,QAAA,cAAC,oBAAK,SAAS,UACZ,EAAE,yBAAyB,GAC5B,6BAAAA,QAAA,cAAC,oBAAK,YAAW,UAAO,QACf,GAAG,KAAK,IAAI,kBAAkB,cAAc,KAAK,CAAC,CAAC,IAAG,MAE/D,GACC,uBAAuB,cAAc,KAAK,CAC7C,CAEJ;AAAA,IAEJ,OAAO;AACL,aACE,6BAAAA,QAAA;AAAA,QAAC;AAAA;AAAA,UACC;AAAA,UACA,IAAI;AAAA,UACJ,MAAM;AAAA,UACN,aAAW;AAAA,UACX;AAAA,UACA;AAAA,UACC,GAAG;AAAA,YACF,GAAG;AAAA,YACH,OAAO;AAAA,YACP,UAAU;AAAA,YACV,OAAO;AAAA,UACT;AAAA;AAAA,MACF;AAAA,IAEJ;AAAA,EACF;AACF;AAEA,IAAO,gBAAQ;",
6
+ "names": ["React", "currentValue", "limit"]
7
+ }