@digigov/form 2.0.0-6e3977bc → 2.0.0-76ec20a0

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 (665) hide show
  1. package/Field/ErrorGroup/index.js +48 -0
  2. package/{Form.stories → 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 +30 -22
  6. package/Field/FieldBase.js.map +2 -2
  7. package/Field/FieldBaseContainer/index.js +4 -3
  8. package/Field/FieldBaseContainer.js.map +2 -2
  9. package/Field/FieldConditional.js.map +1 -1
  10. package/Field/index.js +5 -0
  11. package/Field/index.js.map +2 -2
  12. package/Field/types.d.ts +12 -8
  13. package/Field/utils/index.js +6 -0
  14. package/Field/utils/index.js.map +2 -2
  15. package/Field/utils/useField/index.js +7 -1
  16. package/Field/utils/useField.js.map +2 -2
  17. package/FieldArray/FieldArray.stories.d.ts +1 -0
  18. package/FieldArray/FormDialog/index.js +279 -0
  19. package/{Questions/Questions.stories → FieldArray/FormDialog}/package.json +1 -1
  20. package/FieldArray/FormDialog.d.ts +53 -0
  21. package/FieldArray/FormDialog.js.map +7 -0
  22. package/FieldArray/__stories__/Default.d.ts +1 -1
  23. package/FieldArray/__stories__/WithExactLength.d.ts +1 -1
  24. package/FieldArray/__stories__/WithModal.d.ts +2 -0
  25. package/FieldArray/index.d.ts +5 -0
  26. package/FieldArray/index.js +58 -24
  27. package/FieldArray/index.js.map +2 -2
  28. package/FieldObject/index.d.ts +2 -0
  29. package/FieldObject/index.js +10 -6
  30. package/FieldObject/index.js.map +2 -2
  31. package/Fieldset/index.d.ts +1 -1
  32. package/Fieldset/index.js +5 -5
  33. package/Fieldset/index.js.map +2 -2
  34. package/Fieldset/types.d.ts +2 -2
  35. package/FormBuilder/FormBuilder.stories.d.ts +4 -0
  36. package/FormBuilder/__stories__/AutoErrorGrouping.d.ts +3 -0
  37. package/FormBuilder/__stories__/Default.d.ts +1 -1
  38. package/FormBuilder/__stories__/ErrorGrouping.d.ts +3 -0
  39. package/FormBuilder/index.js +85 -6
  40. package/FormBuilder/index.js.map +2 -2
  41. package/FormBuilder/interaction.test.d.ts +1 -0
  42. package/FormContext.js.map +2 -2
  43. package/MultiplicityField/MultiplicityField.stories.d.ts +2 -0
  44. package/MultiplicityField/__stories__/Default.d.ts +1 -1
  45. package/MultiplicityField/__stories__/PreviewDisplay.d.ts +1 -1
  46. package/MultiplicityField/__stories__/WithExactLength.d.ts +1 -1
  47. package/MultiplicityField/__stories__/WithMaxLength.d.ts +1 -1
  48. package/MultiplicityField/__stories__/WithMinAndMaxLength.d.ts +1 -1
  49. package/MultiplicityField/__stories__/WithMinLength.d.ts +1 -1
  50. package/MultiplicityField/add-objects/index.js +8 -6
  51. package/MultiplicityField/add-objects.js.map +2 -2
  52. package/MultiplicityField/index.js +13 -10
  53. package/MultiplicityField/index.js.map +2 -2
  54. package/MultiplicityField/types.d.ts +1 -2
  55. package/Questions/Questions/index.js +5 -4
  56. package/Questions/Questions.js.map +2 -2
  57. package/Questions/Questions.stories.d.ts +2 -0
  58. package/Questions/Step/StepArrayReview.js.map +2 -2
  59. package/Questions/Step/StepTitle/index.js +4 -3
  60. package/Questions/Step/StepTitle.d.ts +1 -1
  61. package/Questions/Step/StepTitle.js.map +2 -2
  62. package/Questions/__stories__/Default.d.ts +1 -1
  63. package/cjs/Field/ErrorGroup/index.js +82 -0
  64. package/cjs/Field/ErrorGroup.js.map +7 -0
  65. package/cjs/Field/FieldBase/index.js +29 -21
  66. package/cjs/Field/FieldBase.js.map +2 -2
  67. package/cjs/Field/FieldBaseContainer/index.js +4 -3
  68. package/cjs/Field/FieldBaseContainer.js.map +3 -3
  69. package/cjs/Field/FieldConditional.js.map +1 -1
  70. package/cjs/Field/index.js +5 -0
  71. package/cjs/Field/index.js.map +2 -2
  72. package/cjs/Field/types.js.map +1 -1
  73. package/cjs/Field/utils/index.js +6 -0
  74. package/cjs/Field/utils/index.js.map +3 -3
  75. package/cjs/Field/utils/useField/index.js +7 -1
  76. package/cjs/Field/utils/useField.js.map +2 -2
  77. package/cjs/FieldArray/FormDialog/index.js +301 -0
  78. package/cjs/FieldArray/FormDialog.js.map +7 -0
  79. package/cjs/FieldArray/index.js +57 -23
  80. package/cjs/FieldArray/index.js.map +3 -3
  81. package/cjs/FieldObject/index.js +10 -6
  82. package/cjs/FieldObject/index.js.map +3 -3
  83. package/cjs/Fieldset/index.js +10 -10
  84. package/cjs/Fieldset/index.js.map +3 -3
  85. package/cjs/Fieldset/types.js.map +1 -1
  86. package/cjs/FormBuilder/index.js +85 -6
  87. package/cjs/FormBuilder/index.js.map +3 -3
  88. package/cjs/FormContext/index.js +2 -2
  89. package/cjs/FormContext.js.map +3 -3
  90. package/cjs/MultiplicityField/add-objects/index.js +12 -10
  91. package/cjs/MultiplicityField/add-objects.js.map +3 -3
  92. package/cjs/MultiplicityField/index.js +12 -14
  93. package/cjs/MultiplicityField/index.js.map +3 -3
  94. package/cjs/MultiplicityField/types.js.map +1 -1
  95. package/cjs/Questions/Questions/index.js +5 -4
  96. package/cjs/Questions/Questions.js.map +2 -2
  97. package/cjs/Questions/Step/StepArrayReview.js.map +2 -2
  98. package/cjs/Questions/Step/StepTitle/index.js +5 -5
  99. package/cjs/Questions/Step/StepTitle.js.map +3 -3
  100. package/cjs/inputs/AutoCompleteInput/index.js +8 -7
  101. package/cjs/inputs/AutoCompleteInput/index.js.map +3 -3
  102. package/cjs/inputs/Checkboxes/index.js +8 -8
  103. package/cjs/inputs/Checkboxes/index.js.map +3 -3
  104. package/cjs/inputs/DateInput/index.js +10 -8
  105. package/cjs/inputs/DateInput/index.js.map +3 -3
  106. package/cjs/inputs/DateTimeInput/index.js +211 -0
  107. package/cjs/inputs/DateTimeInput/index.js.map +7 -0
  108. package/cjs/inputs/FileInput/index.js +41 -27
  109. package/cjs/inputs/FileInput/index.js.map +3 -3
  110. package/cjs/inputs/ImageInput/index.js +15 -10
  111. package/cjs/inputs/ImageInput/index.js.map +3 -3
  112. package/cjs/inputs/Input/index.js +13 -5
  113. package/cjs/inputs/Input/index.js.map +2 -2
  114. package/cjs/inputs/Input/inputsInputScenarios.js.map +2 -2
  115. package/cjs/inputs/Label/index.js +3 -3
  116. package/cjs/inputs/Label/index.js.map +3 -3
  117. package/cjs/inputs/OtpInput/index.js +1 -0
  118. package/cjs/inputs/OtpInput/index.js.map +2 -2
  119. package/cjs/inputs/Radio/index.js +12 -13
  120. package/cjs/inputs/Radio/index.js.map +3 -3
  121. package/cjs/inputs/Select/index.js +10 -5
  122. package/cjs/inputs/Select/index.js.map +3 -3
  123. package/cjs/inputs/inputsScenarios/index.js +4 -10
  124. package/cjs/inputs/inputsScenarios.js.map +2 -2
  125. package/cjs/lazy/index.js +48 -35
  126. package/cjs/lazy.js.map +3 -3
  127. package/cjs/locales/el.js.map +1 -1
  128. package/cjs/registry/index.js +72 -62
  129. package/cjs/registry.js.map +3 -3
  130. package/cjs/types.js.map +1 -1
  131. package/cjs/utils/index.js +2 -1
  132. package/cjs/utils.js.map +2 -2
  133. package/cjs/validators/index.js +44 -79
  134. package/cjs/validators/index.js.map +3 -3
  135. package/cjs/validators/utils/date/index.js +138 -0
  136. package/cjs/validators/utils/date.js.map +7 -0
  137. package/cjs/validators/utils/datetime/index.js +151 -0
  138. package/cjs/validators/utils/datetime.js.map +7 -0
  139. package/cjs/validators/utils/file/index.js +1 -1
  140. package/cjs/validators/utils/file.js.map +2 -2
  141. package/cjs/validators/utils/index.js +5 -1
  142. package/cjs/validators/utils/index.js.map +2 -2
  143. package/cjs/validators/utils/int/index.js +1 -1
  144. package/cjs/validators/utils/int.js.map +2 -2
  145. package/cjs/validators/utils/number/index.js +1 -1
  146. package/cjs/validators/utils/number.js.map +2 -2
  147. package/cjs/validators/utils/phone.js.map +2 -2
  148. package/cjs/validators/utils/postal_code.js.map +1 -1
  149. package/cjs/validators/utils/uuid4.js.map +2 -2
  150. package/index.js +1 -1
  151. package/inputs/AutoCompleteInput/AutoComplete.stories.d.ts +2 -0
  152. package/inputs/AutoCompleteInput/__stories__/Default.d.ts +1 -1
  153. package/inputs/AutoCompleteInput/__stories__/Multiple.d.ts +1 -1
  154. package/inputs/AutoCompleteInput/index.d.ts +1 -1
  155. package/inputs/AutoCompleteInput/index.js +10 -7
  156. package/inputs/AutoCompleteInput/index.js.map +2 -2
  157. package/inputs/Checkboxes/Checkboxes.stories.d.ts +2 -0
  158. package/inputs/Checkboxes/__stories__/Conditional.d.ts +1 -1
  159. package/inputs/Checkboxes/__stories__/Default.d.ts +1 -1
  160. package/inputs/Checkboxes/__stories__/WithDivider.d.ts +1 -1
  161. package/inputs/Checkboxes/index.d.ts +1 -1
  162. package/inputs/Checkboxes/index.js +9 -5
  163. package/inputs/Checkboxes/index.js.map +2 -2
  164. package/inputs/DateInput/DateInput.stories.d.ts +2 -0
  165. package/inputs/DateInput/__stories__/Default.d.ts +1 -1
  166. package/inputs/DateInput/index.d.ts +1 -2
  167. package/inputs/DateInput/index.js +12 -7
  168. package/inputs/DateInput/index.js.map +2 -2
  169. package/inputs/DateTimeInput/DateTimeInput.stories.d.ts +9 -0
  170. package/inputs/DateTimeInput/__stories__/Default.d.ts +3 -0
  171. package/inputs/DateTimeInput/index.d.ts +13 -0
  172. package/inputs/DateTimeInput/index.js +181 -0
  173. package/inputs/DateTimeInput/index.js.map +7 -0
  174. package/inputs/DateTimeInput/index.test.d.ts +1 -0
  175. package/inputs/{Input/Input.stories → DateTimeInput}/package.json +1 -1
  176. package/inputs/FileInput/FileInput.stories.d.ts +2 -0
  177. package/inputs/FileInput/__stories__/Default.d.ts +1 -1
  178. package/inputs/FileInput/index.d.ts +9 -0
  179. package/inputs/FileInput/index.js +41 -27
  180. package/inputs/FileInput/index.js.map +2 -2
  181. package/inputs/ImageInput/ImageInput.stories.d.ts +2 -0
  182. package/inputs/ImageInput/__stories__/Default.d.ts +1 -1
  183. package/inputs/ImageInput/__stories__/MaxSize.d.ts +1 -1
  184. package/inputs/ImageInput/__stories__/WithInvalidImageDimension.d.ts +1 -1
  185. package/inputs/ImageInput/index.js +14 -9
  186. package/inputs/ImageInput/index.js.map +2 -2
  187. package/inputs/Input/Input.stories.d.ts +3 -0
  188. package/inputs/Input/__stories__/AFM.d.ts +1 -1
  189. package/inputs/Input/__stories__/Boolean.d.ts +1 -1
  190. package/inputs/Input/__stories__/IBAN.d.ts +1 -1
  191. package/inputs/Input/__stories__/Integer.d.ts +1 -1
  192. package/inputs/Input/__stories__/LandlineNumber.d.ts +1 -1
  193. package/inputs/Input/__stories__/MobilePhone.d.ts +1 -1
  194. package/inputs/Input/__stories__/PhoneNumber.d.ts +1 -1
  195. package/inputs/Input/__stories__/PostalCode.d.ts +1 -1
  196. package/inputs/Input/__stories__/String.d.ts +1 -1
  197. package/inputs/Input/__stories__/StringWithTrimValidation.d.ts +3 -0
  198. package/inputs/Input/__stories__/TextWithLimit.d.ts +1 -1
  199. package/inputs/Input/index.js +13 -5
  200. package/inputs/Input/index.js.map +2 -2
  201. package/inputs/Input/inputsInputScenarios.js.map +2 -2
  202. package/inputs/Label/Label.stories.d.ts +2 -0
  203. package/inputs/Label/__stories__/Default.d.ts +1 -1
  204. package/inputs/Label/index.d.ts +0 -2
  205. package/inputs/Label/index.js +2 -2
  206. package/inputs/Label/index.js.map +2 -2
  207. package/inputs/OtpInput/OtpInput.stories.d.ts +2 -0
  208. package/inputs/OtpInput/__stories__/Default.d.ts +1 -1
  209. package/inputs/OtpInput/index.js +1 -0
  210. package/inputs/OtpInput/index.js.map +2 -2
  211. package/inputs/Radio/Radio.stories.d.ts +2 -0
  212. package/inputs/Radio/__stories__/Conditional.d.ts +1 -1
  213. package/inputs/Radio/__stories__/Default.d.ts +1 -1
  214. package/inputs/Radio/__stories__/WithDivider.d.ts +1 -1
  215. package/inputs/Radio/index.d.ts +1 -1
  216. package/inputs/Radio/index.js +8 -5
  217. package/inputs/Radio/index.js.map +2 -2
  218. package/inputs/Select/Select.stories.d.ts +2 -0
  219. package/inputs/Select/__stories__/Default.d.ts +1 -1
  220. package/inputs/Select/index.d.ts +1 -1
  221. package/inputs/Select/index.js +11 -3
  222. package/inputs/Select/index.js.map +2 -2
  223. package/inputs/inputsScenarios/index.js +4 -10
  224. package/inputs/inputsScenarios.js.map +2 -2
  225. package/lazy/index.js +76 -67
  226. package/locales/el.js.map +1 -1
  227. package/package.json +4 -4
  228. package/registry/index.js +116 -107
  229. package/src/Field/ErrorGroup.tsx +84 -0
  230. package/src/Field/FieldBase.tsx +33 -22
  231. package/src/Field/FieldBaseContainer.tsx +7 -4
  232. package/src/Field/FieldConditional.tsx +2 -2
  233. package/src/Field/doc.mdx +207 -0
  234. package/src/Field/index.tsx +5 -0
  235. package/src/Field/types.tsx +31 -26
  236. package/src/Field/utils/index.ts +6 -0
  237. package/src/Field/utils/useField.ts +7 -3
  238. package/src/FieldArray/FieldArray.stories.js +1 -0
  239. package/src/FieldArray/FormDialog.tsx +378 -0
  240. package/src/FieldArray/__stories__/Default.tsx +2 -1
  241. package/src/FieldArray/__stories__/WithExactLength.tsx +2 -1
  242. package/src/FieldArray/__stories__/WithModal.tsx +159 -0
  243. package/src/FieldArray/index.test.tsx +8 -0
  244. package/src/FieldArray/index.tsx +89 -47
  245. package/src/FieldObject/index.tsx +15 -7
  246. package/src/Fieldset/index.tsx +5 -5
  247. package/src/Fieldset/types.tsx +2 -2
  248. package/src/FormBuilder/FormBuilder.stories.js +5 -0
  249. package/src/FormBuilder/__stories__/AutoErrorGrouping.tsx +63 -0
  250. package/src/FormBuilder/__stories__/Default.tsx +1 -1
  251. package/src/FormBuilder/__stories__/ErrorGrouping.tsx +43 -0
  252. package/src/FormBuilder/{FormBuilder.mdx → doc.mdx} +27 -35
  253. package/src/FormBuilder/index.test.tsx +12 -0
  254. package/src/FormBuilder/index.tsx +94 -9
  255. package/src/FormBuilder/interaction.test.tsx +40 -0
  256. package/src/FormBuilder/scenarios.test.tsx +120 -6
  257. package/src/FormContext.tsx +1 -2
  258. package/src/MultiplicityField/MultiplicityField.stories.js +3 -0
  259. package/src/MultiplicityField/__stories__/Default.tsx +1 -1
  260. package/src/MultiplicityField/__stories__/PreviewDisplay.tsx +1 -1
  261. package/src/MultiplicityField/__stories__/WithExactLength.tsx +1 -1
  262. package/src/MultiplicityField/__stories__/WithMaxLength.tsx +1 -1
  263. package/src/MultiplicityField/__stories__/WithMinAndMaxLength.tsx +1 -1
  264. package/src/MultiplicityField/__stories__/WithMinLength.tsx +1 -1
  265. package/src/MultiplicityField/add-objects.tsx +9 -9
  266. package/src/MultiplicityField/{MultiplicityField.mdx → doc.mdx} +112 -98
  267. package/src/MultiplicityField/index.test.tsx +4 -0
  268. package/src/MultiplicityField/index.tsx +14 -12
  269. package/src/MultiplicityField/types.ts +1 -2
  270. package/src/Questions/Questions.stories.js +3 -0
  271. package/src/Questions/Questions.tsx +4 -4
  272. package/src/Questions/Step/StepArrayReview.tsx +1 -1
  273. package/src/Questions/Step/StepTitle.tsx +4 -3
  274. package/src/Questions/__snapshots__/index.spec.tsx.snap +11 -5
  275. package/src/Questions/__stories__/Default.tsx +1 -1
  276. package/src/Questions/{index.mdx → doc.mdx} +30 -53
  277. package/src/Questions/index.spec.tsx +14 -2
  278. package/src/Questions/index.test.tsx +4 -0
  279. package/src/create-simple-form.mdx +2 -6
  280. package/src/{index.mdx → doc.mdx} +29 -18
  281. package/src/inputs/AutoCompleteInput/AutoComplete.stories.js +3 -0
  282. package/src/inputs/AutoCompleteInput/__stories__/Default.tsx +3 -11
  283. package/src/inputs/AutoCompleteInput/__stories__/Multiple.tsx +2 -8
  284. package/src/inputs/AutoCompleteInput/{index.mdx → doc.mdx} +2 -13
  285. package/src/inputs/AutoCompleteInput/index.test.tsx +4 -0
  286. package/src/inputs/AutoCompleteInput/index.tsx +32 -28
  287. package/src/inputs/Checkboxes/Checkboxes.stories.js +3 -0
  288. package/src/inputs/Checkboxes/__stories__/Conditional.tsx +1 -1
  289. package/src/inputs/Checkboxes/__stories__/Default.tsx +1 -1
  290. package/src/inputs/Checkboxes/__stories__/WithDivider.tsx +1 -1
  291. package/src/inputs/Checkboxes/{index.mdx → doc.mdx} +5 -15
  292. package/src/inputs/Checkboxes/index.test.tsx +4 -0
  293. package/src/inputs/Checkboxes/index.tsx +32 -28
  294. package/src/inputs/DateInput/DateInput.stories.js +3 -0
  295. package/src/inputs/DateInput/__stories__/Default.tsx +8 -13
  296. package/src/inputs/DateInput/{index.mdx → doc.mdx} +1 -8
  297. package/src/inputs/DateInput/index.test.tsx +4 -0
  298. package/src/inputs/DateInput/index.tsx +12 -7
  299. package/src/inputs/DateTimeInput/DateTimeInput.stories.js +11 -0
  300. package/src/inputs/DateTimeInput/__stories__/Default.tsx +25 -0
  301. package/src/inputs/DateTimeInput/doc.mdx +16 -0
  302. package/src/inputs/DateTimeInput/index.test.tsx +24 -0
  303. package/src/inputs/DateTimeInput/index.tsx +194 -0
  304. package/src/inputs/FileInput/FileInput.stories.js +3 -0
  305. package/src/inputs/FileInput/__stories__/Default.tsx +1 -1
  306. package/src/inputs/FileInput/{index.mdx → doc.mdx} +1 -5
  307. package/src/inputs/FileInput/index.test.tsx +4 -0
  308. package/src/inputs/FileInput/index.tsx +33 -10
  309. package/src/inputs/ImageInput/ImageInput.stories.js +3 -1
  310. package/src/inputs/ImageInput/__stories__/Default.tsx +1 -1
  311. package/src/inputs/ImageInput/__stories__/MaxSize.tsx +3 -3
  312. package/src/inputs/ImageInput/__stories__/WithInvalidImageDimension.tsx +3 -1
  313. package/src/inputs/ImageInput/doc.mdx +23 -0
  314. package/src/inputs/ImageInput/index.test.tsx +20 -20
  315. package/src/inputs/ImageInput/index.tsx +17 -16
  316. package/src/inputs/Input/Input.stories.js +4 -0
  317. package/src/inputs/Input/__stories__/AFM.tsx +1 -1
  318. package/src/inputs/Input/__stories__/Boolean.tsx +1 -1
  319. package/src/inputs/Input/__stories__/IBAN.tsx +1 -1
  320. package/src/inputs/Input/__stories__/Integer.tsx +1 -1
  321. package/src/inputs/Input/__stories__/LandlineNumber.tsx +3 -2
  322. package/src/inputs/Input/__stories__/MobilePhone.tsx +2 -1
  323. package/src/inputs/Input/__stories__/PhoneNumber.tsx +2 -1
  324. package/src/inputs/Input/__stories__/PostalCode.tsx +2 -1
  325. package/src/inputs/Input/__stories__/String.tsx +1 -1
  326. package/src/inputs/Input/__stories__/StringWithTrimValidation.tsx +26 -0
  327. package/src/inputs/Input/__stories__/TextWithLimit.tsx +2 -1
  328. package/src/inputs/Input/doc.mdx +56 -0
  329. package/src/inputs/Input/index.test.tsx +8 -0
  330. package/src/inputs/Input/index.tsx +27 -11
  331. package/src/inputs/Input/inputsInputScenarios.ts +244 -245
  332. package/src/inputs/Label/Label.stories.js +3 -0
  333. package/src/inputs/Label/__stories__/Default.tsx +1 -1
  334. package/src/inputs/Label/doc.mdx +14 -0
  335. package/src/inputs/Label/index.test.tsx +4 -0
  336. package/src/inputs/Label/index.tsx +2 -6
  337. package/src/inputs/OtpInput/OtpInput.stories.js +3 -0
  338. package/src/inputs/OtpInput/__stories__/Default.tsx +1 -1
  339. package/src/inputs/OtpInput/{index.mdx → doc.mdx} +1 -8
  340. package/src/inputs/OtpInput/index.test.tsx +4 -0
  341. package/src/inputs/OtpInput/index.tsx +3 -1
  342. package/src/inputs/Radio/Radio.stories.js +3 -0
  343. package/src/inputs/Radio/__stories__/Conditional.tsx +1 -1
  344. package/src/inputs/Radio/__stories__/Default.tsx +1 -1
  345. package/src/inputs/Radio/__stories__/WithDivider.tsx +1 -1
  346. package/src/inputs/Radio/{index.mdx → doc.mdx} +5 -15
  347. package/src/inputs/Radio/index.test.tsx +4 -0
  348. package/src/inputs/Radio/index.tsx +59 -56
  349. package/src/inputs/Select/Select.stories.js +3 -0
  350. package/src/inputs/Select/__stories__/Default.tsx +1 -1
  351. package/src/inputs/Select/{index.mdx → doc.mdx} +1 -5
  352. package/src/inputs/Select/index.test.tsx +4 -0
  353. package/src/inputs/Select/index.tsx +12 -4
  354. package/src/inputs/inputsScenarios.ts +36 -42
  355. package/src/installation.mdx +2 -5
  356. package/src/lazy.js +76 -64
  357. package/src/locales/el.ts +1 -1
  358. package/src/registry.js +108 -100
  359. package/src/types.tsx +2 -2
  360. package/src/utils.ts +2 -2
  361. package/src/validators/index.ts +86 -85
  362. package/src/validators/utils/date.ts +107 -0
  363. package/src/validators/utils/datetime.ts +130 -0
  364. package/src/validators/utils/file.ts +5 -3
  365. package/src/validators/utils/index.ts +2 -0
  366. package/src/validators/utils/int.ts +1 -1
  367. package/src/validators/utils/number.ts +1 -1
  368. package/src/validators/utils/phone.ts +1 -1
  369. package/src/validators/utils/postal_code.ts +1 -1
  370. package/src/validators/utils/uuid4.ts +2 -1
  371. package/src/validators/validators.spec.ts +3 -3
  372. package/types.d.ts +2 -2
  373. package/types.js.map +1 -1
  374. package/utils/index.js +2 -1
  375. package/utils.js.map +2 -2
  376. package/validators/index.js +51 -80
  377. package/validators/index.js.map +2 -2
  378. package/validators/utils/date/index.js +103 -0
  379. package/{FieldArray/FieldArray.stories → validators/utils/date}/package.json +1 -1
  380. package/validators/utils/date.d.ts +9 -0
  381. package/validators/utils/date.js.map +7 -0
  382. package/validators/utils/datetime/index.js +116 -0
  383. package/validators/utils/datetime/package.json +6 -0
  384. package/validators/utils/datetime.d.ts +9 -0
  385. package/validators/utils/datetime.js.map +7 -0
  386. package/validators/utils/file/index.js +1 -1
  387. package/validators/utils/file.js.map +2 -2
  388. package/validators/utils/index.d.ts +2 -0
  389. package/validators/utils/index.js +2 -0
  390. package/validators/utils/index.js.map +2 -2
  391. package/validators/utils/int/index.js +1 -1
  392. package/validators/utils/int.js.map +2 -2
  393. package/validators/utils/number/index.js +1 -1
  394. package/validators/utils/number.js.map +2 -2
  395. package/validators/utils/phone.d.ts +1 -1
  396. package/validators/utils/phone.js.map +2 -2
  397. package/validators/utils/postal_code.d.ts +1 -1
  398. package/validators/utils/postal_code.js.map +1 -1
  399. package/validators/utils/uuid4.js.map +2 -2
  400. package/FieldArray/FieldArray.stories/index.js +0 -14
  401. package/FieldArray/FieldArray.stories.js.map +0 -7
  402. package/FieldArray/__stories__/Default/index.js +0 -95
  403. package/FieldArray/__stories__/Default/package.json +0 -6
  404. package/FieldArray/__stories__/Default.js.map +0 -7
  405. package/FieldArray/__stories__/WithExactLength/index.js +0 -95
  406. package/FieldArray/__stories__/WithExactLength/package.json +0 -6
  407. package/FieldArray/__stories__/WithExactLength.js.map +0 -7
  408. package/Form.stories/index.js +0 -7
  409. package/Form.stories.js.map +0 -7
  410. package/FormBuilder/FormBuilder.stories/index.js +0 -12
  411. package/FormBuilder/FormBuilder.stories/package.json +0 -6
  412. package/FormBuilder/FormBuilder.stories.js.map +0 -7
  413. package/FormBuilder/__stories__/Default/index.js +0 -32
  414. package/FormBuilder/__stories__/Default/package.json +0 -6
  415. package/FormBuilder/__stories__/Default.js.map +0 -7
  416. package/MultiplicityField/MultiplicityField.stories/index.js +0 -22
  417. package/MultiplicityField/MultiplicityField.stories/package.json +0 -6
  418. package/MultiplicityField/MultiplicityField.stories.js.map +0 -7
  419. package/MultiplicityField/__stories__/Default/index.js +0 -100
  420. package/MultiplicityField/__stories__/Default/package.json +0 -6
  421. package/MultiplicityField/__stories__/Default.js.map +0 -7
  422. package/MultiplicityField/__stories__/PreviewDisplay/index.js +0 -70
  423. package/MultiplicityField/__stories__/PreviewDisplay/package.json +0 -6
  424. package/MultiplicityField/__stories__/PreviewDisplay.js.map +0 -7
  425. package/MultiplicityField/__stories__/WithExactLength/index.js +0 -97
  426. package/MultiplicityField/__stories__/WithExactLength/package.json +0 -6
  427. package/MultiplicityField/__stories__/WithExactLength.js.map +0 -7
  428. package/MultiplicityField/__stories__/WithMaxLength/index.js +0 -100
  429. package/MultiplicityField/__stories__/WithMaxLength/package.json +0 -6
  430. package/MultiplicityField/__stories__/WithMaxLength.js.map +0 -7
  431. package/MultiplicityField/__stories__/WithMinAndMaxLength/index.js +0 -101
  432. package/MultiplicityField/__stories__/WithMinAndMaxLength/package.json +0 -6
  433. package/MultiplicityField/__stories__/WithMinAndMaxLength.js.map +0 -7
  434. package/MultiplicityField/__stories__/WithMinLength/index.js +0 -100
  435. package/MultiplicityField/__stories__/WithMinLength/package.json +0 -6
  436. package/MultiplicityField/__stories__/WithMinLength.js.map +0 -7
  437. package/Questions/Questions.stories/index.js +0 -12
  438. package/Questions/Questions.stories.js.map +0 -7
  439. package/Questions/__stories__/Default/index.js +0 -108
  440. package/Questions/__stories__/Default/package.json +0 -6
  441. package/Questions/__stories__/Default.js.map +0 -7
  442. package/cjs/FieldArray/FieldArray.stories/index.js +0 -48
  443. package/cjs/FieldArray/FieldArray.stories.js.map +0 -7
  444. package/cjs/FieldArray/__stories__/Default/index.js +0 -128
  445. package/cjs/FieldArray/__stories__/Default.js.map +0 -7
  446. package/cjs/FieldArray/__stories__/WithExactLength/index.js +0 -128
  447. package/cjs/FieldArray/__stories__/WithExactLength.js.map +0 -7
  448. package/cjs/Form.stories/index.js +0 -26
  449. package/cjs/Form.stories.js.map +0 -7
  450. package/cjs/FormBuilder/FormBuilder.stories/index.js +0 -45
  451. package/cjs/FormBuilder/FormBuilder.stories.js.map +0 -7
  452. package/cjs/FormBuilder/__stories__/Default/index.js +0 -65
  453. package/cjs/FormBuilder/__stories__/Default.js.map +0 -7
  454. package/cjs/MultiplicityField/MultiplicityField.stories/index.js +0 -60
  455. package/cjs/MultiplicityField/MultiplicityField.stories.js.map +0 -7
  456. package/cjs/MultiplicityField/__stories__/Default/index.js +0 -133
  457. package/cjs/MultiplicityField/__stories__/Default.js.map +0 -7
  458. package/cjs/MultiplicityField/__stories__/PreviewDisplay/index.js +0 -86
  459. package/cjs/MultiplicityField/__stories__/PreviewDisplay.js.map +0 -7
  460. package/cjs/MultiplicityField/__stories__/WithExactLength/index.js +0 -130
  461. package/cjs/MultiplicityField/__stories__/WithExactLength.js.map +0 -7
  462. package/cjs/MultiplicityField/__stories__/WithMaxLength/index.js +0 -133
  463. package/cjs/MultiplicityField/__stories__/WithMaxLength.js.map +0 -7
  464. package/cjs/MultiplicityField/__stories__/WithMinAndMaxLength/index.js +0 -134
  465. package/cjs/MultiplicityField/__stories__/WithMinAndMaxLength.js.map +0 -7
  466. package/cjs/MultiplicityField/__stories__/WithMinLength/index.js +0 -133
  467. package/cjs/MultiplicityField/__stories__/WithMinLength.js.map +0 -7
  468. package/cjs/Questions/Questions.stories/index.js +0 -45
  469. package/cjs/Questions/Questions.stories.js.map +0 -7
  470. package/cjs/Questions/__stories__/Default/index.js +0 -136
  471. package/cjs/Questions/__stories__/Default.js.map +0 -7
  472. package/cjs/inputs/AutoCompleteInput/AutoComplete.stories/index.js +0 -48
  473. package/cjs/inputs/AutoCompleteInput/AutoComplete.stories.js.map +0 -7
  474. package/cjs/inputs/AutoCompleteInput/__stories__/Default/index.js +0 -83
  475. package/cjs/inputs/AutoCompleteInput/__stories__/Default.js.map +0 -7
  476. package/cjs/inputs/AutoCompleteInput/__stories__/Multiple/index.js +0 -83
  477. package/cjs/inputs/AutoCompleteInput/__stories__/Multiple.js.map +0 -7
  478. package/cjs/inputs/Checkboxes/Checkboxes.stories/index.js +0 -51
  479. package/cjs/inputs/Checkboxes/Checkboxes.stories.js.map +0 -7
  480. package/cjs/inputs/Checkboxes/__stories__/Conditional/index.js +0 -133
  481. package/cjs/inputs/Checkboxes/__stories__/Conditional.js.map +0 -7
  482. package/cjs/inputs/Checkboxes/__stories__/Default/index.js +0 -77
  483. package/cjs/inputs/Checkboxes/__stories__/Default.js.map +0 -7
  484. package/cjs/inputs/Checkboxes/__stories__/WithDivider/index.js +0 -78
  485. package/cjs/inputs/Checkboxes/__stories__/WithDivider.js.map +0 -7
  486. package/cjs/inputs/DateInput/DateInput.stories/index.js +0 -45
  487. package/cjs/inputs/DateInput/DateInput.stories.js.map +0 -7
  488. package/cjs/inputs/DateInput/__stories__/Default/index.js +0 -61
  489. package/cjs/inputs/DateInput/__stories__/Default.js.map +0 -7
  490. package/cjs/inputs/FileInput/FileInput.stories/index.js +0 -45
  491. package/cjs/inputs/FileInput/FileInput.stories.js.map +0 -7
  492. package/cjs/inputs/FileInput/__stories__/Default/index.js +0 -61
  493. package/cjs/inputs/FileInput/__stories__/Default.js.map +0 -7
  494. package/cjs/inputs/ImageInput/ImageInput.stories/index.js +0 -51
  495. package/cjs/inputs/ImageInput/ImageInput.stories.js.map +0 -7
  496. package/cjs/inputs/ImageInput/__stories__/Default/index.js +0 -63
  497. package/cjs/inputs/ImageInput/__stories__/Default.js.map +0 -7
  498. package/cjs/inputs/ImageInput/__stories__/MaxSize/index.js +0 -69
  499. package/cjs/inputs/ImageInput/__stories__/MaxSize.js.map +0 -7
  500. package/cjs/inputs/ImageInput/__stories__/WithInvalidImageDimension/index.js +0 -71
  501. package/cjs/inputs/ImageInput/__stories__/WithInvalidImageDimension.js.map +0 -7
  502. package/cjs/inputs/ImageInput/__stories__/WithInvalidImageSize/index.js +0 -68
  503. package/cjs/inputs/ImageInput/__stories__/WithInvalidImageSize.js.map +0 -7
  504. package/cjs/inputs/Input/Input.stories/index.js +0 -72
  505. package/cjs/inputs/Input/Input.stories.js.map +0 -7
  506. package/cjs/inputs/Input/__stories__/AFM/index.js +0 -63
  507. package/cjs/inputs/Input/__stories__/AFM.js.map +0 -7
  508. package/cjs/inputs/Input/__stories__/Boolean/index.js +0 -64
  509. package/cjs/inputs/Input/__stories__/Boolean.js.map +0 -7
  510. package/cjs/inputs/Input/__stories__/IBAN/index.js +0 -64
  511. package/cjs/inputs/Input/__stories__/IBAN.js.map +0 -7
  512. package/cjs/inputs/Input/__stories__/Integer/index.js +0 -78
  513. package/cjs/inputs/Input/__stories__/Integer.js.map +0 -7
  514. package/cjs/inputs/Input/__stories__/LandlineNumber/index.js +0 -67
  515. package/cjs/inputs/Input/__stories__/LandlineNumber.js.map +0 -7
  516. package/cjs/inputs/Input/__stories__/MobilePhone/index.js +0 -67
  517. package/cjs/inputs/Input/__stories__/MobilePhone.js.map +0 -7
  518. package/cjs/inputs/Input/__stories__/PhoneNumber/index.js +0 -66
  519. package/cjs/inputs/Input/__stories__/PhoneNumber.js.map +0 -7
  520. package/cjs/inputs/Input/__stories__/PostalCode/index.js +0 -64
  521. package/cjs/inputs/Input/__stories__/PostalCode.js.map +0 -7
  522. package/cjs/inputs/Input/__stories__/String/index.js +0 -64
  523. package/cjs/inputs/Input/__stories__/String.js.map +0 -7
  524. package/cjs/inputs/Input/__stories__/TextWithLimit/index.js +0 -64
  525. package/cjs/inputs/Input/__stories__/TextWithLimit.js.map +0 -7
  526. package/cjs/inputs/Label/Label.stories/index.js +0 -45
  527. package/cjs/inputs/Label/Label.stories.js.map +0 -7
  528. package/cjs/inputs/Label/__stories__/Default/index.js +0 -72
  529. package/cjs/inputs/Label/__stories__/Default.js.map +0 -7
  530. package/cjs/inputs/OtpInput/OtpInput.stories/index.js +0 -45
  531. package/cjs/inputs/OtpInput/OtpInput.stories.js.map +0 -7
  532. package/cjs/inputs/OtpInput/__stories__/Default/index.js +0 -64
  533. package/cjs/inputs/OtpInput/__stories__/Default.js.map +0 -7
  534. package/cjs/inputs/Radio/Radio.stories/index.js +0 -51
  535. package/cjs/inputs/Radio/Radio.stories.js.map +0 -7
  536. package/cjs/inputs/Radio/__stories__/Conditional/index.js +0 -133
  537. package/cjs/inputs/Radio/__stories__/Conditional.js.map +0 -7
  538. package/cjs/inputs/Radio/__stories__/Default/index.js +0 -81
  539. package/cjs/inputs/Radio/__stories__/Default.js.map +0 -7
  540. package/cjs/inputs/Radio/__stories__/WithDivider/index.js +0 -82
  541. package/cjs/inputs/Radio/__stories__/WithDivider.js.map +0 -7
  542. package/cjs/inputs/Select/Select.stories/index.js +0 -45
  543. package/cjs/inputs/Select/Select.stories.js.map +0 -7
  544. package/cjs/inputs/Select/__stories__/Default/index.js +0 -86
  545. package/cjs/inputs/Select/__stories__/Default.js.map +0 -7
  546. package/inputs/AutoCompleteInput/AutoComplete.stories/index.js +0 -14
  547. package/inputs/AutoCompleteInput/AutoComplete.stories/package.json +0 -6
  548. package/inputs/AutoCompleteInput/AutoComplete.stories.js.map +0 -7
  549. package/inputs/AutoCompleteInput/__stories__/Default/index.js +0 -50
  550. package/inputs/AutoCompleteInput/__stories__/Default/package.json +0 -6
  551. package/inputs/AutoCompleteInput/__stories__/Default.js.map +0 -7
  552. package/inputs/AutoCompleteInput/__stories__/Multiple/index.js +0 -50
  553. package/inputs/AutoCompleteInput/__stories__/Multiple/package.json +0 -6
  554. package/inputs/AutoCompleteInput/__stories__/Multiple.js.map +0 -7
  555. package/inputs/Checkboxes/Checkboxes.stories/index.js +0 -16
  556. package/inputs/Checkboxes/Checkboxes.stories/package.json +0 -6
  557. package/inputs/Checkboxes/Checkboxes.stories.js.map +0 -7
  558. package/inputs/Checkboxes/__stories__/Conditional/index.js +0 -100
  559. package/inputs/Checkboxes/__stories__/Conditional/package.json +0 -6
  560. package/inputs/Checkboxes/__stories__/Conditional.js.map +0 -7
  561. package/inputs/Checkboxes/__stories__/Default/index.js +0 -44
  562. package/inputs/Checkboxes/__stories__/Default/package.json +0 -6
  563. package/inputs/Checkboxes/__stories__/Default.js.map +0 -7
  564. package/inputs/Checkboxes/__stories__/WithDivider/index.js +0 -45
  565. package/inputs/Checkboxes/__stories__/WithDivider/package.json +0 -6
  566. package/inputs/Checkboxes/__stories__/WithDivider.js.map +0 -7
  567. package/inputs/DateInput/DateInput.stories/index.js +0 -12
  568. package/inputs/DateInput/DateInput.stories/package.json +0 -6
  569. package/inputs/DateInput/DateInput.stories.js.map +0 -7
  570. package/inputs/DateInput/__stories__/Default/index.js +0 -28
  571. package/inputs/DateInput/__stories__/Default/package.json +0 -6
  572. package/inputs/DateInput/__stories__/Default.js.map +0 -7
  573. package/inputs/FileInput/FileInput.stories/index.js +0 -12
  574. package/inputs/FileInput/FileInput.stories/package.json +0 -6
  575. package/inputs/FileInput/FileInput.stories.js.map +0 -7
  576. package/inputs/FileInput/__stories__/Default/index.js +0 -28
  577. package/inputs/FileInput/__stories__/Default/package.json +0 -6
  578. package/inputs/FileInput/__stories__/Default.js.map +0 -7
  579. package/inputs/ImageInput/ImageInput.stories/index.js +0 -16
  580. package/inputs/ImageInput/ImageInput.stories/package.json +0 -6
  581. package/inputs/ImageInput/ImageInput.stories.js.map +0 -7
  582. package/inputs/ImageInput/__stories__/Default/index.js +0 -30
  583. package/inputs/ImageInput/__stories__/Default/package.json +0 -6
  584. package/inputs/ImageInput/__stories__/Default.js.map +0 -7
  585. package/inputs/ImageInput/__stories__/MaxSize/index.js +0 -36
  586. package/inputs/ImageInput/__stories__/MaxSize/package.json +0 -6
  587. package/inputs/ImageInput/__stories__/MaxSize.js.map +0 -7
  588. package/inputs/ImageInput/__stories__/WithInvalidImageDimension/index.js +0 -38
  589. package/inputs/ImageInput/__stories__/WithInvalidImageDimension/package.json +0 -6
  590. package/inputs/ImageInput/__stories__/WithInvalidImageDimension.js.map +0 -7
  591. package/inputs/ImageInput/__stories__/WithInvalidImageSize/index.js +0 -35
  592. package/inputs/ImageInput/__stories__/WithInvalidImageSize/package.json +0 -6
  593. package/inputs/ImageInput/__stories__/WithInvalidImageSize.d.ts +0 -3
  594. package/inputs/ImageInput/__stories__/WithInvalidImageSize.js.map +0 -7
  595. package/inputs/Input/Input.stories/index.js +0 -30
  596. package/inputs/Input/Input.stories.js.map +0 -7
  597. package/inputs/Input/__stories__/AFM/index.js +0 -30
  598. package/inputs/Input/__stories__/AFM/package.json +0 -6
  599. package/inputs/Input/__stories__/AFM.js.map +0 -7
  600. package/inputs/Input/__stories__/Boolean/index.js +0 -31
  601. package/inputs/Input/__stories__/Boolean/package.json +0 -6
  602. package/inputs/Input/__stories__/Boolean.js.map +0 -7
  603. package/inputs/Input/__stories__/IBAN/index.js +0 -31
  604. package/inputs/Input/__stories__/IBAN/package.json +0 -6
  605. package/inputs/Input/__stories__/IBAN.js.map +0 -7
  606. package/inputs/Input/__stories__/Integer/index.js +0 -45
  607. package/inputs/Input/__stories__/Integer/package.json +0 -6
  608. package/inputs/Input/__stories__/Integer.js.map +0 -7
  609. package/inputs/Input/__stories__/LandlineNumber/index.js +0 -34
  610. package/inputs/Input/__stories__/LandlineNumber/package.json +0 -6
  611. package/inputs/Input/__stories__/LandlineNumber.js.map +0 -7
  612. package/inputs/Input/__stories__/MobilePhone/index.js +0 -34
  613. package/inputs/Input/__stories__/MobilePhone/package.json +0 -6
  614. package/inputs/Input/__stories__/MobilePhone.js.map +0 -7
  615. package/inputs/Input/__stories__/PhoneNumber/index.js +0 -33
  616. package/inputs/Input/__stories__/PhoneNumber/package.json +0 -6
  617. package/inputs/Input/__stories__/PhoneNumber.js.map +0 -7
  618. package/inputs/Input/__stories__/PostalCode/index.js +0 -31
  619. package/inputs/Input/__stories__/PostalCode/package.json +0 -6
  620. package/inputs/Input/__stories__/PostalCode.js.map +0 -7
  621. package/inputs/Input/__stories__/String/index.js +0 -31
  622. package/inputs/Input/__stories__/String/package.json +0 -6
  623. package/inputs/Input/__stories__/String.js.map +0 -7
  624. package/inputs/Input/__stories__/TextWithLimit/index.js +0 -31
  625. package/inputs/Input/__stories__/TextWithLimit/package.json +0 -6
  626. package/inputs/Input/__stories__/TextWithLimit.js.map +0 -7
  627. package/inputs/Label/Label.stories/index.js +0 -12
  628. package/inputs/Label/Label.stories/package.json +0 -6
  629. package/inputs/Label/Label.stories.js.map +0 -7
  630. package/inputs/Label/__stories__/Default/index.js +0 -39
  631. package/inputs/Label/__stories__/Default/package.json +0 -6
  632. package/inputs/Label/__stories__/Default.js.map +0 -7
  633. package/inputs/OtpInput/OtpInput.stories/index.js +0 -12
  634. package/inputs/OtpInput/OtpInput.stories/package.json +0 -6
  635. package/inputs/OtpInput/OtpInput.stories.js.map +0 -7
  636. package/inputs/OtpInput/__stories__/Default/index.js +0 -31
  637. package/inputs/OtpInput/__stories__/Default/package.json +0 -6
  638. package/inputs/OtpInput/__stories__/Default.js.map +0 -7
  639. package/inputs/Radio/Radio.stories/index.js +0 -16
  640. package/inputs/Radio/Radio.stories/package.json +0 -6
  641. package/inputs/Radio/Radio.stories.js.map +0 -7
  642. package/inputs/Radio/__stories__/Conditional/index.js +0 -100
  643. package/inputs/Radio/__stories__/Conditional/package.json +0 -6
  644. package/inputs/Radio/__stories__/Conditional.js.map +0 -7
  645. package/inputs/Radio/__stories__/Default/index.js +0 -48
  646. package/inputs/Radio/__stories__/Default/package.json +0 -6
  647. package/inputs/Radio/__stories__/Default.js.map +0 -7
  648. package/inputs/Radio/__stories__/WithDivider/index.js +0 -49
  649. package/inputs/Radio/__stories__/WithDivider/package.json +0 -6
  650. package/inputs/Radio/__stories__/WithDivider.js.map +0 -7
  651. package/inputs/Select/Select.stories/index.js +0 -12
  652. package/inputs/Select/Select.stories/package.json +0 -6
  653. package/inputs/Select/Select.stories.js.map +0 -7
  654. package/inputs/Select/__stories__/Default/index.js +0 -53
  655. package/inputs/Select/__stories__/Default/package.json +0 -6
  656. package/inputs/Select/__stories__/Default.js.map +0 -7
  657. package/lazy.d.ts +0 -77
  658. package/lazy.js.map +0 -7
  659. package/registry.d.ts +0 -70
  660. package/registry.js.map +0 -7
  661. package/src/Field/index.mdx +0 -6
  662. package/src/inputs/ImageInput/__stories__/WithInvalidImageSize.tsx +0 -36
  663. package/src/inputs/ImageInput/index.mdx +0 -19
  664. package/src/inputs/Input/index.mdx +0 -95
  665. package/src/inputs/Label/index.mdx +0 -0
@@ -1,6 +1,4 @@
1
1
  import { MutableRefObject, useMemo } from 'react';
2
- import dayjs from 'dayjs';
3
- import customParseFormat from 'dayjs/plugin/customParseFormat';
4
2
  import * as yup from 'yup';
5
3
  import { AnyObjectSchema, StringSchema } from 'yup';
6
4
  import { RequiredArraySchema } from 'yup/lib/array';
@@ -22,16 +20,15 @@ import {
22
20
  POSTALCODE_VALIDATOR,
23
21
  UUID4_VALIDATOR,
24
22
  IMAGE_DIMENSION_VALIDATOR,
23
+ DATE_VALIDATOR,
24
+ LATER_THAN_VALIDATOR,
25
+ EARLIER_THAN_VALIDATOR,
26
+ DATETIME_VALIDATOR,
27
+ LATER_THAN_DATETIME_VALIDATOR,
28
+ EARLIER_THAN_DATETIME_VALIDATOR,
25
29
  } from '@digigov/form/validators/utils';
26
30
  import { INT_VALIDATOR } from '@digigov/form/validators/utils/int';
27
31
  import { NUMBER_VALIDATOR } from '@digigov/form/validators/utils/number';
28
- dayjs.extend(customParseFormat);
29
-
30
- const VALID_DATE_FORMATS = ['DD/MM/YYYY'];
31
- const DATE_CACHE = {};
32
- const getDate = (v) => {
33
- return DATE_CACHE[v] ? DATE_CACHE[v] : dayjs(v, VALID_DATE_FORMATS, true);
34
- };
35
32
 
36
33
  export const getYUPTypeMap = (): Record<string, any> => {
37
34
  const yupTypeMap = {
@@ -47,8 +44,28 @@ export const getYUPTypeMap = (): Record<string, any> => {
47
44
  .nullable()
48
45
  .test(FILE_MAX_SIZE_VALIDATOR(field));
49
46
  },
50
- string: yup.string,
51
- boolean: yup.boolean,
47
+ string: (field): yup.StringSchema => {
48
+ if (field.trim) {
49
+ return yup.string().trim();
50
+ } else {
51
+ return yup.string();
52
+ }
53
+ },
54
+ boolean: (): yup.BooleanSchema<
55
+ boolean | null | undefined,
56
+ AnyObject,
57
+ boolean | null | undefined
58
+ > => {
59
+ return yup
60
+ .boolean()
61
+ .nullable()
62
+ .transform((value) => {
63
+ if (value === '' || typeof value === 'string') return null;
64
+ if (typeof value === 'boolean') return value;
65
+ if (value === 0 || value === 1) return Boolean(value);
66
+ return value;
67
+ });
68
+ },
52
69
  object: (
53
70
  field
54
71
  ):
@@ -100,24 +117,39 @@ export const getYUPTypeMap = (): Record<string, any> => {
100
117
  number: (): MixedSchema =>
101
118
  yup
102
119
  .mixed()
103
- .transform((_, val) => (val !== '' ? Number(val) : null))
120
+ .transform((_, val) => (val !== '' ? Number(val) : undefined))
104
121
  .test(NUMBER_VALIDATOR()),
105
122
  int: (): MixedSchema =>
106
123
  yup
107
124
  .mixed()
108
- .transform((_, val) => (val !== '' ? Number(val) : null))
125
+ .transform((_, val) => (val !== '' ? Number(val) : undefined))
109
126
  .test(NUMBER_VALIDATOR())
110
127
  .test(INT_VALIDATOR()),
111
- email: (): yup.StringSchema => yup.string().email('form.error.email'),
112
- afm: (): yup.StringSchema => yup.string().test(AFM_VALIDATOR),
113
- uuid4: (): yup.StringSchema => yup.string().test(UUID4_VALIDATOR),
114
- iban: (field): yup.StringSchema => yup.string().test(IBAN_VALIDATOR(field)),
115
- otp: (field): yup.StringSchema => yup.string().test(OTP_VALIDATOR(field)),
128
+ email: (field): yup.StringSchema =>
129
+ field.trim
130
+ ? yup.string().trim().email('form.error.email')
131
+ : yup.string().email('form.error.email'),
132
+ afm: (field): yup.StringSchema =>
133
+ field.trim
134
+ ? yup.string().trim().test(AFM_VALIDATOR)
135
+ : yup.string().test(AFM_VALIDATOR),
136
+ uuid4: (field): yup.StringSchema =>
137
+ field.trim
138
+ ? yup.string().trim().test(UUID4_VALIDATOR)
139
+ : yup.string().test(UUID4_VALIDATOR),
140
+ iban: (field): yup.StringSchema =>
141
+ field.trim
142
+ ? yup.string().trim().test(IBAN_VALIDATOR(field))
143
+ : yup.string().trim().test(IBAN_VALIDATOR(field)),
144
+ otp: (field): yup.StringSchema =>
145
+ yup.string().trim().test(OTP_VALIDATOR(field)),
116
146
  text: (field): yup.StringSchema => {
117
147
  if (field?.extra?.limit?.max || !!field?.extra?.limit?.min) {
118
- return yup.string().test(TEXT_LIMIT_VALIDATOR(field));
148
+ return field.trim
149
+ ? yup.string().trim().test(TEXT_LIMIT_VALIDATOR(field))
150
+ : yup.string().test(TEXT_LIMIT_VALIDATOR(field));
119
151
  } else {
120
- return yup.string();
152
+ return field.trim ? yup.string().trim() : yup.string();
121
153
  }
122
154
  },
123
155
  image: (field): MixedSchema => {
@@ -134,11 +166,17 @@ export const getYUPTypeMap = (): Record<string, any> => {
134
166
  .test(IMAGE_DIMENSION_VALIDATOR(field));
135
167
  },
136
168
  postal_code: (field): yup.StringSchema =>
137
- yup.string().test(POSTALCODE_VALIDATOR(field)),
138
- mobile_phone: (): yup.StringSchema =>
139
- yup.string().test(MOBILE_PHONE_VALIDATOR),
169
+ field.trim
170
+ ? yup.string().trim().test(POSTALCODE_VALIDATOR(field))
171
+ : yup.string().test(POSTALCODE_VALIDATOR(field)),
172
+ mobile_phone: (field): yup.StringSchema =>
173
+ field.trim
174
+ ? yup.string().trim().test(MOBILE_PHONE_VALIDATOR)
175
+ : yup.string().test(MOBILE_PHONE_VALIDATOR),
140
176
  phone_number: (field): yup.StringSchema =>
141
- yup.string().test(PHONE_NUMBER_VALIDATOR(field)),
177
+ field.trim
178
+ ? yup.string().trim().test(PHONE_NUMBER_VALIDATOR(field))
179
+ : yup.string().test(PHONE_NUMBER_VALIDATOR(field)),
142
180
  'choice:multiple': (): yup.ArraySchema<
143
181
  yup.StringSchema<string | undefined, AnyObject, string | undefined>,
144
182
  AnyObject,
@@ -150,69 +188,32 @@ export const getYUPTypeMap = (): Record<string, any> => {
150
188
  AnyObject,
151
189
  string | null | undefined
152
190
  > => yup.string().nullable(),
153
- date: (field) => {
154
- let simpleDate = yup
155
- .string()
156
- .nullable(true)
157
- .test('date', 'form.error.date.invalid', function (value) {
158
- if (!value) return true;
159
- const date = getDate(value);
160
- return date.isValid();
161
- });
162
- const params = field.extra || {};
163
- if (params.max) {
164
- let maxDate;
165
- if (params.max === 'now') {
166
- const today = new Date();
167
- maxDate = new Date(today);
168
- } else {
169
- maxDate = getDate(params.max).toDate();
170
- }
171
- const maxNextDate = new Date(maxDate);
172
- maxNextDate.setDate(maxDate.getDate() + 1);
173
- simpleDate = simpleDate.test({
174
- name: 'earlier-than',
175
- message: {
176
- key: 'form.error.date.earlier_than',
177
- context: {
178
- maxDate: maxNextDate.toLocaleDateString(),
179
- },
180
- },
181
- test: function (value) {
182
- if (!value) return true;
183
- const date = getDate(value);
184
- const isValid = +date.toDate() < +maxDate;
185
- return isValid;
186
- },
187
- });
191
+ date: (
192
+ field
193
+ ): yup.StringSchema<
194
+ string | null | undefined,
195
+ AnyObject,
196
+ string | null | undefined
197
+ > => {
198
+ let schema = yup.string().nullable();
199
+ if (field?.extra?.min) {
200
+ schema = schema.test(LATER_THAN_VALIDATOR(field));
188
201
  }
189
- if (params.min) {
190
- let minDate;
191
- if (params.min === 'now') {
192
- const today = new Date();
193
- minDate = new Date(today);
194
- } else {
195
- minDate = getDate(params.min).toDate();
196
- }
197
- const minPreviousDate = new Date(minDate);
198
- minPreviousDate.setDate(minDate.getDate() - 1);
199
- simpleDate = simpleDate.test({
200
- name: 'later-than',
201
- message: {
202
- key: 'form.error.date.later_than',
203
- context: {
204
- minDate: minPreviousDate.toLocaleDateString(),
205
- },
206
- },
207
- test: function (value) {
208
- if (!value) return true;
209
- const date = getDate(value);
210
- const isValid = +date.toDate() > +minDate;
211
- return isValid;
212
- },
213
- });
202
+ if (field?.extra?.max) {
203
+ schema = schema.test(EARLIER_THAN_VALIDATOR(field));
204
+ } else {
205
+ schema = schema.test(DATE_VALIDATOR);
206
+ }
207
+ return schema;
208
+ },
209
+ datetime: (field): yup.StringSchema => {
210
+ if (field?.extra?.min) {
211
+ return yup.string().test(LATER_THAN_DATETIME_VALIDATOR(field));
212
+ }
213
+ if (field?.extra?.max) {
214
+ return yup.string().test(EARLIER_THAN_DATETIME_VALIDATOR(field));
214
215
  }
215
- return simpleDate;
216
+ return yup.string().test(DATETIME_VALIDATOR);
216
217
  },
217
218
  };
218
219
  return yupTypeMap;
@@ -0,0 +1,107 @@
1
+ import dayjs from 'dayjs';
2
+ import customParseFormat from 'dayjs/plugin/customParseFormat';
3
+ import { FieldSpec } from '@digigov/form/types';
4
+ import { ValidatorSchema } from '@digigov/form/validators/types';
5
+
6
+ dayjs.extend(customParseFormat);
7
+
8
+ const VALID_DATE_FORMATS = ['DD/MM/YYYY'];
9
+ const DATE_CACHE = {};
10
+
11
+ const getDate = (v: string) => {
12
+ return DATE_CACHE[v] ? DATE_CACHE[v] : dayjs(v, VALID_DATE_FORMATS, true);
13
+ };
14
+
15
+ // Function to check partial date completion
16
+ const checkPartialDate = (value: string) => {
17
+ console.log("value.split('/')", value.split('/'));
18
+ const [day, month, year] = value.split('/');
19
+ if (day && !month && !year) {
20
+ return 'form.error.date.invalid_month_year';
21
+ }
22
+ if (!day && month && !year) {
23
+ return 'form.error.date.invalid_day_year';
24
+ }
25
+ if (!day && !month && year) {
26
+ return 'form.error.date.invalid_day_month';
27
+ }
28
+ if (day && month && !year) {
29
+ return 'form.error.date.invalid_year';
30
+ }
31
+ if (day && !month && year) {
32
+ return 'form.error.date.invalid_month';
33
+ }
34
+ if (!day && month && year) {
35
+ return 'form.error.date.invalid_day';
36
+ } else {
37
+ return 'form.error.date.invalid';
38
+ }
39
+ };
40
+
41
+ export const LATER_THAN_VALIDATOR = (field: FieldSpec): ValidatorSchema => {
42
+ let minDate;
43
+ const params = field.extra || {};
44
+ if (params.min === 'now') {
45
+ const today = new Date();
46
+ minDate = new Date(today);
47
+ } else {
48
+ minDate = getDate(params.min).toDate();
49
+ }
50
+ const minPreviousDate = new Date(minDate);
51
+ minPreviousDate.setDate(minDate.getDate() - 1);
52
+ return {
53
+ name: 'later-than',
54
+ message: {
55
+ key: 'form.error.date.later_than',
56
+ context: {
57
+ minDate: minPreviousDate.toLocaleDateString(),
58
+ },
59
+ },
60
+ test: function (value: string) {
61
+ if (!value) return true;
62
+ const date = getDate(value);
63
+ const isValid = +date.toDate() > +minDate;
64
+ return isValid;
65
+ },
66
+ };
67
+ };
68
+
69
+ export const EARLIER_THAN_VALIDATOR = (field: FieldSpec): ValidatorSchema => {
70
+ let maxDate;
71
+ const params = field.extra || {};
72
+ if (params.max === 'now') {
73
+ const today = new Date();
74
+ maxDate = new Date(today);
75
+ } else {
76
+ maxDate = getDate(params.max).toDate();
77
+ }
78
+ const maxNextDate = new Date(maxDate);
79
+ maxNextDate.setDate(maxDate.getDate() + 1);
80
+ return {
81
+ name: 'earlier-than',
82
+ message: {
83
+ key: 'form.error.date.earlier_than',
84
+ context: {
85
+ maxDate: maxNextDate.toLocaleDateString(),
86
+ },
87
+ },
88
+ test: function (value: string) {
89
+ if (!value) return true;
90
+ const date = getDate(value);
91
+ const isValid = +date.toDate() < +maxDate;
92
+ return isValid;
93
+ },
94
+ };
95
+ };
96
+
97
+ export const DATE_VALIDATOR = {
98
+ name: 'date-validator',
99
+ message: (v): string => {
100
+ return checkPartialDate(v.value);
101
+ },
102
+ test: function (value: string) {
103
+ if (!value) return true;
104
+ const date = getDate(value);
105
+ return date.isValid();
106
+ },
107
+ };
@@ -0,0 +1,130 @@
1
+ import dayjs from 'dayjs';
2
+ import customParseFormat from 'dayjs/plugin/customParseFormat';
3
+ import { FieldSpec } from '@digigov/form/types';
4
+ import { ValidatorSchema } from '@digigov/form/validators/types';
5
+
6
+ dayjs.extend(customParseFormat);
7
+
8
+ const VALID_DATETIME_FORMATS = ['DD/MM/YYYY HH:mm'];
9
+ const DATETIME_CACHE = {};
10
+
11
+ const getDateTime = (v: string) => {
12
+ return DATETIME_CACHE[v]
13
+ ? DATETIME_CACHE[v]
14
+ : dayjs(v, VALID_DATETIME_FORMATS, true);
15
+ };
16
+
17
+ // Function to check partial datetime completion
18
+ const checkPartialDateTime = (value: string) => {
19
+ const [datePart, timePart] = value.split(' ');
20
+ const [day, month, year] = datePart.split('/');
21
+ const [hours, minutes] = timePart ? timePart.split(':') : [null, null];
22
+
23
+ // Check date part first
24
+ if (day && !month && !year) {
25
+ return 'form.error.datetime.invalid_month_year';
26
+ }
27
+ if (!day && month && !year) {
28
+ return 'form.error.datetime.invalid_day_year';
29
+ }
30
+ if (!day && !month && year) {
31
+ return 'form.error.datetime.invalid_day_month';
32
+ }
33
+ if (day && month && !year) {
34
+ return 'form.error.datetime.invalid_year';
35
+ }
36
+ if (day && !month && year) {
37
+ return 'form.error.datetime.invalid_month';
38
+ }
39
+ if (!day && month && year) {
40
+ return 'form.error.datetime.invalid_day';
41
+ }
42
+ // If date is complete, check time part
43
+ if (day && month && year) {
44
+ if (hours && !minutes) {
45
+ return 'form.error.datetime.invalid_minutes';
46
+ }
47
+ if (!hours && minutes) {
48
+ return 'form.error.datetime.invalid_hours';
49
+ }
50
+ if (!hours && !minutes) {
51
+ return 'form.error.datetime.invalid';
52
+ }
53
+ if (hours && minutes) {
54
+ const hoursNum = parseInt(hours);
55
+ const minutesNum = parseInt(minutes);
56
+ if (hoursNum < 0 || hoursNum > 23) {
57
+ return 'form.error.datetime.invalid_hours_range';
58
+ }
59
+ if (minutesNum < 0 || minutesNum > 59) {
60
+ return 'form.error.datetime.invalid_minutes_range';
61
+ }
62
+ }
63
+ }
64
+
65
+ return 'form.error.datetime.invalid';
66
+ };
67
+
68
+ export const LATER_THAN_DATETIME_VALIDATOR = (
69
+ field: FieldSpec
70
+ ): ValidatorSchema => {
71
+ let minDateTime;
72
+ const params = field.extra || {};
73
+ if (params.min === 'now') {
74
+ minDateTime = dayjs();
75
+ } else {
76
+ minDateTime = getDateTime(params.min);
77
+ }
78
+ return {
79
+ name: 'later-than-datetime',
80
+ message: {
81
+ key: 'form.error.datetime.later_than',
82
+ context: {
83
+ minDateTime: minDateTime.format('DD/MM/YYYY HH:mm'),
84
+ },
85
+ },
86
+ test: function (value: string) {
87
+ if (!value) return true;
88
+ const datetime = getDateTime(value);
89
+ return datetime.isValid() && datetime.isAfter(minDateTime);
90
+ },
91
+ };
92
+ };
93
+
94
+ export const EARLIER_THAN_DATETIME_VALIDATOR = (
95
+ field: FieldSpec
96
+ ): ValidatorSchema => {
97
+ let maxDateTime;
98
+ const params = field.extra || {};
99
+ if (params.max === 'now') {
100
+ maxDateTime = dayjs();
101
+ } else {
102
+ maxDateTime = getDateTime(params.max);
103
+ }
104
+ return {
105
+ name: 'earlier-than-datetime',
106
+ message: {
107
+ key: 'form.error.datetime.earlier_than',
108
+ context: {
109
+ maxDateTime: maxDateTime.format('DD/MM/YYYY HH:mm'),
110
+ },
111
+ },
112
+ test: function (value: string) {
113
+ if (!value) return true;
114
+ const datetime = getDateTime(value);
115
+ return datetime.isValid() && datetime.isBefore(maxDateTime);
116
+ },
117
+ };
118
+ };
119
+
120
+ export const DATETIME_VALIDATOR = {
121
+ name: 'datetime-validator',
122
+ message: (v): string => {
123
+ return checkPartialDateTime(v.value);
124
+ },
125
+ test: function (value: string) {
126
+ if (!value) return true;
127
+ const datetime = getDateTime(value);
128
+ return datetime.isValid();
129
+ },
130
+ };
@@ -6,15 +6,17 @@ const DEFAULT_FILE_MAX_SIZE = 10000000;
6
6
  export const FILE_MAX_SIZE_VALIDATOR = (field: FieldSpec): ValidatorSchema => ({
7
7
  name: 'file-max-size-validator',
8
8
  message: {
9
- key: field.type === 'file' ? 'form.error.file_size' : 'form.error.image_size',
9
+ key:
10
+ field.type === 'file' ? 'form.error.file_size' : 'form.error.image_size',
10
11
  context: {
11
- maxSizeToMb: (field?.extra?.limit.maxSize || DEFAULT_FILE_MAX_SIZE) / 1000000,
12
+ maxSizeToMb:
13
+ (field?.extra?.limit?.maxSize || DEFAULT_FILE_MAX_SIZE) / 1000000,
12
14
  },
13
15
  },
14
16
  test: (value: File[]): boolean => {
15
17
  if (value) {
16
18
  for (const file of value) {
17
- const maxSize = field?.extra?.limit?.maxSize || DEFAULT_FILE_MAX_SIZE
19
+ const maxSize = field?.extra?.limit?.maxSize || DEFAULT_FILE_MAX_SIZE;
18
20
  if (file.size > maxSize) {
19
21
  return false;
20
22
  }
@@ -11,6 +11,8 @@ export * from '@digigov/form/validators/utils/phone';
11
11
  export * from '@digigov/form/validators/utils/postal_code';
12
12
  export * from '@digigov/form/validators/utils/uuid4';
13
13
  export * from '@digigov/form/validators/utils/text_limit';
14
+ export * from '@digigov/form/validators/utils/date';
15
+ export * from '@digigov/form/validators/utils/datetime';
14
16
 
15
17
  export function getYupField(field: FieldSpec, yupTypeMap: Record<string, any>) {
16
18
  const yupField = yupTypeMap[field?.type || 'string'] || yupTypeMap['string'];
@@ -13,7 +13,7 @@ export const INT_VALIDATOR = (): ValidatorSchema => {
13
13
  name: 'int-validator',
14
14
  message: 'form.error.positive_integer_number',
15
15
  test: (value: number): boolean => {
16
- if (value === null) {
16
+ if (value === undefined) {
17
17
  return true;
18
18
  }
19
19
  return validateIntNumber(value);
@@ -9,7 +9,7 @@ export const NUMBER_VALIDATOR = (): ValidatorSchema => {
9
9
  name: 'number-validator',
10
10
  message: 'form.error.number',
11
11
  test: (value: number): boolean => {
12
- if (value === null) {
12
+ if (value === undefined) {
13
13
  return true;
14
14
  }
15
15
  return validateNumber(value);
@@ -138,7 +138,7 @@ function isNumberOfType(phoneNumber: string, country: string, type: string) {
138
138
  }
139
139
  export function validatePhoneNumber(
140
140
  phoneNumber: string,
141
- countries: Array<string> = ['gr'],
141
+ countries: string[] = ['gr'],
142
142
  typeOfPhoneNumber?: PhoneNumberType
143
143
  ): boolean {
144
144
  if (!countries || countries.length === 0) {
@@ -4,7 +4,7 @@ import { ValidatorSchema } from '@digigov/form/validators/types';
4
4
  const CODE_REGEX = /^[12345678][0-9]{4}$/;
5
5
  export function validatePostalCode(
6
6
  number: string,
7
- countries: Array<string>
7
+ countries: string[]
8
8
  ): boolean {
9
9
  if (!countries) {
10
10
  return false;
@@ -1,4 +1,5 @@
1
- const UUID4_PATTERN = /^[0-9A-F]{8}-[0-9A-F]{4}-[4][0-9A-F]{3}-[89AB][0-9A-F]{3}-[0-9A-F]{12}$/i;
1
+ const UUID4_PATTERN =
2
+ /^[0-9A-F]{8}-[0-9A-F]{4}-[4][0-9A-F]{3}-[89AB][0-9A-F]{3}-[0-9A-F]{12}$/i;
2
3
 
3
4
  export function validateUUID4(uuid4: string): boolean {
4
5
  if (uuid4.length !== 36) {
@@ -75,14 +75,14 @@ it('throws if given country is not supported', () => {
75
75
  );
76
76
  });
77
77
 
78
- it('validates phone number type mobile with gr country code', () => {
78
+ it('validates phone number type mobile with gr country code', () => {
79
79
  expect(validatePhoneNumber('6934100982', ['GR'], 'mobile')).toBe(true);
80
80
  });
81
81
 
82
- it('validates phone number with no type and gr country code', () => {
82
+ it('validates phone number with no type and gr country code', () => {
83
83
  expect(validatePhoneNumber('6934100982', ['gr'], null)).toBe(true);
84
84
  });
85
85
 
86
- it('validates phone number with no type and gr country code', () => {
86
+ it('validates invalid phone number with no type and gr country code', () => {
87
87
  expect(validatePhoneNumber('41446681800', ['gr'], null)).toBe(false);
88
88
  });
package/types.d.ts CHANGED
@@ -2,9 +2,9 @@ import { UseFormReturn, UseFormProps } from 'react-hook-form';
2
2
  import { FieldComponentRegistry, FieldLabelProps, FieldSpec, FormData } from '@digigov/form/Field/types';
3
3
  import { ValidatorSchema } from '@digigov/form/validators/types';
4
4
  export * from '@digigov/form/Field/types';
5
- export type FieldError = {
5
+ export interface FieldError {
6
6
  message: string;
7
- };
7
+ }
8
8
  export interface FieldsetSpec {
9
9
  key: string;
10
10
  fields: string[];
package/types.js.map CHANGED
@@ -1,7 +1,7 @@
1
1
  {
2
2
  "version": 3,
3
3
  "sources": ["../src/types.tsx"],
4
- "sourcesContent": ["import { UseFormReturn, UseFormProps } from 'react-hook-form';\nimport {\n FieldComponentRegistry,\n FieldLabelProps,\n FieldSpec,\n FormData,\n} from '@digigov/form/Field/types';\nimport { ValidatorSchema } from '@digigov/form/validators/types';\nexport * from '@digigov/form/Field/types';\nexport type FieldError = {\n message: string;\n};\n\nexport interface FieldsetSpec {\n key: string;\n fields: string[];\n label?: FieldLabelProps;\n body?: React.ReactNode;\n}\n\nexport interface FormContextProps {\n fieldsetsMap?: Record<string, FieldsetSpec>;\n fieldsMap: Record<string, FieldSpec>;\n control: UseFormReturn['control'];\n register: UseFormReturn['register'];\n trigger: UseFormReturn['trigger'];\n clearErrors: UseFormReturn['clearErrors'];\n watch: UseFormReturn['watch'];\n getFieldState: UseFormReturn['getFieldState'];\n setValue: UseFormReturn['setValue'];\n getValues: UseFormReturn['getValues'];\n unregister: UseFormReturn['unregister'];\n formState: UseFormReturn['formState'];\n reset: UseFormReturn['reset'];\n resetField: UseFormReturn['resetField'];\n registerField: (field: FieldSpec) => void;\n errors: UseFormReturn['formState']['errors'];\n componentRegistry?: FieldComponentRegistry;\n submit: () => Promise<void>;\n}\n\nexport interface FormBuilderProps {\n fields?: FieldSpec[];\n fieldsets?: FieldsetSpec[];\n initial?: FormData;\n onSubmit?: (data: FormData) => void | null | FieldError[];\n mode?: UseFormProps['mode'];\n reValidateMode?: UseFormProps['reValidateMode'];\n criteriaMode?: UseFormProps['criteriaMode'];\n children?: React.ReactNode;\n shouldFocusError?: boolean;\n auto?: boolean;\n validatorRegistry?: Record<string, ValidatorSchema[]>;\n componentRegistry?: FieldComponentRegistry;\n grid?: boolean;\n controlledFieldsOnly?: boolean;\n}\n\nexport interface FormBaseProps\n extends Omit<FormBuilderProps, 'fields' | 'fieldsets' | 'auto'> {\n fieldsetsMap?: Record<string, FieldsetSpec>;\n fieldsMap: Record<string, FieldSpec>;\n registerField: (field: FieldSpec) => void;\n resolver: any;\n}\n"],
4
+ "sourcesContent": ["import { UseFormReturn, UseFormProps } from 'react-hook-form';\nimport {\n FieldComponentRegistry,\n FieldLabelProps,\n FieldSpec,\n FormData,\n} from '@digigov/form/Field/types';\nimport { ValidatorSchema } from '@digigov/form/validators/types';\nexport * from '@digigov/form/Field/types';\nexport interface FieldError {\n message: string;\n}\n\nexport interface FieldsetSpec {\n key: string;\n fields: string[];\n label?: FieldLabelProps;\n body?: React.ReactNode;\n}\n\nexport interface FormContextProps {\n fieldsetsMap?: Record<string, FieldsetSpec>;\n fieldsMap: Record<string, FieldSpec>;\n control: UseFormReturn['control'];\n register: UseFormReturn['register'];\n trigger: UseFormReturn['trigger'];\n clearErrors: UseFormReturn['clearErrors'];\n watch: UseFormReturn['watch'];\n getFieldState: UseFormReturn['getFieldState'];\n setValue: UseFormReturn['setValue'];\n getValues: UseFormReturn['getValues'];\n unregister: UseFormReturn['unregister'];\n formState: UseFormReturn['formState'];\n reset: UseFormReturn['reset'];\n resetField: UseFormReturn['resetField'];\n registerField: (field: FieldSpec) => void;\n errors: UseFormReturn['formState']['errors'];\n componentRegistry?: FieldComponentRegistry;\n submit: () => Promise<void>;\n}\n\nexport interface FormBuilderProps {\n fields?: FieldSpec[];\n fieldsets?: FieldsetSpec[];\n initial?: FormData;\n onSubmit?: (data: FormData) => void | null | FieldError[];\n mode?: UseFormProps['mode'];\n reValidateMode?: UseFormProps['reValidateMode'];\n criteriaMode?: UseFormProps['criteriaMode'];\n children?: React.ReactNode;\n shouldFocusError?: boolean;\n auto?: boolean;\n validatorRegistry?: Record<string, ValidatorSchema[]>;\n componentRegistry?: FieldComponentRegistry;\n grid?: boolean;\n controlledFieldsOnly?: boolean;\n}\n\nexport interface FormBaseProps\n extends Omit<FormBuilderProps, 'fields' | 'fieldsets' | 'auto'> {\n fieldsetsMap?: Record<string, FieldsetSpec>;\n fieldsMap: Record<string, FieldSpec>;\n registerField: (field: FieldSpec) => void;\n resolver: any;\n}\n"],
5
5
  "mappings": "AAQA,cAAc;",
6
6
  "names": []
7
7
  }
package/utils/index.js CHANGED
@@ -34,7 +34,8 @@ const yupResolver = (schema, schemaOptions = {}, resolverOptions = {}) => async
34
34
  values,
35
35
  Object.assign({ abortEarly: false }, schemaOptions, { context })
36
36
  );
37
- options.shouldUseNativeValidation && validateFieldsNatively({}, options);
37
+ if (options.shouldUseNativeValidation)
38
+ validateFieldsNatively({}, options);
38
39
  return {
39
40
  values: resolverOptions.rawValues ? values : result,
40
41
  errors: {}
package/utils.js.map CHANGED
@@ -1,7 +1,7 @@
1
1
  {
2
2
  "version": 3,
3
3
  "sources": ["../src/utils.ts"],
4
- "sourcesContent": ["import { validateFieldsNatively } from '@hookform/resolvers';\nimport { appendErrors, FieldError } from 'react-hook-form';\nimport * as Yup from 'yup';\n\n/**\n * Why `path!` ? because it could be `undefined` in some case\n * https://github.com/jquense/yup#validationerrorerrors-string--arraystring-value-any-path-string\n */\nconst parseErrorSchema = (\n error: Yup.ValidationError,\n validateAllFieldCriteria: boolean\n) => {\n return (error.inner || []).reduce<Record<string, FieldError>>(\n (previous, error) => {\n error.path = error.path?.replace(/\\[([0-9]+)\\]/g, '.$1');\n if (!previous[error.path!]) {\n previous[error.path!] = { message: error.message, type: error.type! };\n }\n\n if (validateAllFieldCriteria) {\n const types = previous[error.path!].types;\n const messages = types && types[error.type!];\n\n previous[error.path!] = appendErrors(\n error.path!,\n validateAllFieldCriteria,\n previous,\n error.type!,\n messages\n ? ([] as string[]).concat(messages as string[], error.message)\n : error.message\n ) as FieldError;\n }\n\n return previous;\n },\n {}\n );\n};\n\nexport const yupResolver =\n (schema: any, schemaOptions: any = {}, resolverOptions: any = {}) =>\n async (values, context, options) => {\n try {\n if (schemaOptions.context && process.env.NODE_ENV === 'development') {\n // eslint-disable-next-line no-console\n console.warn(\n \"You should not used the yup options context. Please, use the 'useForm' context object instead\"\n );\n }\n\n const result = await schema[\n resolverOptions.mode === 'sync' ? 'validateSync' : 'validate'\n ](\n values,\n Object.assign({ abortEarly: false }, schemaOptions, { context })\n );\n\n options.shouldUseNativeValidation && validateFieldsNatively({}, options);\n\n return {\n values: resolverOptions.rawValues ? values : result,\n errors: {},\n };\n } catch (e) {\n if (!e.inner) {\n throw e;\n }\n\n const parsed = parseErrorSchema(\n e,\n !options.shouldUseNativeValidation && options.criteriaMode === 'all'\n );\n return {\n values: {},\n errors: parsed,\n };\n }\n };\n"],
5
- "mappings": "AAAA,SAAS,8BAA8B;AACvC,SAAS,oBAAgC;AAOzC,MAAM,mBAAmB,CACvB,OACA,6BACG;AACH,UAAQ,MAAM,SAAS,CAAC,GAAG;AAAA,IACzB,CAAC,UAAUA,WAAU;AACnB,MAAAA,OAAM,OAAOA,OAAM,MAAM,QAAQ,iBAAiB,KAAK;AACvD,UAAI,CAAC,SAASA,OAAM,IAAK,GAAG;AAC1B,iBAASA,OAAM,IAAK,IAAI,EAAE,SAASA,OAAM,SAAS,MAAMA,OAAM,KAAM;AAAA,MACtE;AAEA,UAAI,0BAA0B;AAC5B,cAAM,QAAQ,SAASA,OAAM,IAAK,EAAE;AACpC,cAAM,WAAW,SAAS,MAAMA,OAAM,IAAK;AAE3C,iBAASA,OAAM,IAAK,IAAI;AAAA,UACtBA,OAAM;AAAA,UACN;AAAA,UACA;AAAA,UACAA,OAAM;AAAA,UACN,WACK,CAAC,EAAe,OAAO,UAAsBA,OAAM,OAAO,IAC3DA,OAAM;AAAA,QACZ;AAAA,MACF;AAEA,aAAO;AAAA,IACT;AAAA,IACA,CAAC;AAAA,EACH;AACF;AAEO,MAAM,cACX,CAAC,QAAa,gBAAqB,CAAC,GAAG,kBAAuB,CAAC,MAC/D,OAAO,QAAQ,SAAS,YAAY;AAClC,MAAI;AACF,QAAI,cAAc,WAAW,QAAQ,IAAI,aAAa,eAAe;AAEnE,cAAQ;AAAA,QACN;AAAA,MACF;AAAA,IACF;AAEA,UAAM,SAAS,MAAM,OACnB,gBAAgB,SAAS,SAAS,iBAAiB,UACrD;AAAA,MACE;AAAA,MACA,OAAO,OAAO,EAAE,YAAY,MAAM,GAAG,eAAe,EAAE,QAAQ,CAAC;AAAA,IACjE;AAEA,YAAQ,6BAA6B,uBAAuB,CAAC,GAAG,OAAO;AAEvE,WAAO;AAAA,MACL,QAAQ,gBAAgB,YAAY,SAAS;AAAA,MAC7C,QAAQ,CAAC;AAAA,IACX;AAAA,EACF,SAAS,GAAG;AACV,QAAI,CAAC,EAAE,OAAO;AACZ,YAAM;AAAA,IACR;AAEA,UAAM,SAAS;AAAA,MACb;AAAA,MACA,CAAC,QAAQ,6BAA6B,QAAQ,iBAAiB;AAAA,IACjE;AACA,WAAO;AAAA,MACL,QAAQ,CAAC;AAAA,MACT,QAAQ;AAAA,IACV;AAAA,EACF;AACF;",
4
+ "sourcesContent": ["import { validateFieldsNatively } from '@hookform/resolvers';\nimport { appendErrors, FieldError } from 'react-hook-form';\nimport * as Yup from 'yup';\n\n/**\n * Why `path!` ? because it could be `undefined` in some case\n * https://github.com/jquense/yup#validationerrorerrors-string--arraystring-value-any-path-string\n */\nconst parseErrorSchema = (\n error: Yup.ValidationError,\n validateAllFieldCriteria: boolean\n) => {\n return (error.inner || []).reduce<Record<string, FieldError>>(\n (previous, error) => {\n error.path = error.path?.replace(/\\[([0-9]+)\\]/g, '.$1');\n if (!previous[error.path!]) {\n previous[error.path!] = { message: error.message, type: error.type! };\n }\n\n if (validateAllFieldCriteria) {\n const types = previous[error.path!].types;\n const messages = types && types[error.type!];\n\n previous[error.path!] = appendErrors(\n error.path!,\n validateAllFieldCriteria,\n previous,\n error.type!,\n messages\n ? ([] as string[]).concat(messages as string[], error.message)\n : error.message\n ) as FieldError;\n }\n\n return previous;\n },\n {}\n );\n};\n\nexport const yupResolver =\n (schema: any, schemaOptions: any = {}, resolverOptions: any = {}) =>\n async (values, context, options) => {\n try {\n if (schemaOptions.context && process.env.NODE_ENV === 'development') {\n console.warn(\n \"You should not used the yup options context. Please, use the 'useForm' context object instead\"\n );\n }\n\n const result = await schema[\n resolverOptions.mode === 'sync' ? 'validateSync' : 'validate'\n ](\n values,\n Object.assign({ abortEarly: false }, schemaOptions, { context })\n );\n\n if (options.shouldUseNativeValidation)\n validateFieldsNatively({}, options);\n\n return {\n values: resolverOptions.rawValues ? values : result,\n errors: {},\n };\n } catch (e) {\n if (!e.inner) {\n throw e;\n }\n\n const parsed = parseErrorSchema(\n e,\n !options.shouldUseNativeValidation && options.criteriaMode === 'all'\n );\n return {\n values: {},\n errors: parsed,\n };\n }\n };\n"],
5
+ "mappings": "AAAA,SAAS,8BAA8B;AACvC,SAAS,oBAAgC;AAOzC,MAAM,mBAAmB,CACvB,OACA,6BACG;AACH,UAAQ,MAAM,SAAS,CAAC,GAAG;AAAA,IACzB,CAAC,UAAUA,WAAU;AACnB,MAAAA,OAAM,OAAOA,OAAM,MAAM,QAAQ,iBAAiB,KAAK;AACvD,UAAI,CAAC,SAASA,OAAM,IAAK,GAAG;AAC1B,iBAASA,OAAM,IAAK,IAAI,EAAE,SAASA,OAAM,SAAS,MAAMA,OAAM,KAAM;AAAA,MACtE;AAEA,UAAI,0BAA0B;AAC5B,cAAM,QAAQ,SAASA,OAAM,IAAK,EAAE;AACpC,cAAM,WAAW,SAAS,MAAMA,OAAM,IAAK;AAE3C,iBAASA,OAAM,IAAK,IAAI;AAAA,UACtBA,OAAM;AAAA,UACN;AAAA,UACA;AAAA,UACAA,OAAM;AAAA,UACN,WACK,CAAC,EAAe,OAAO,UAAsBA,OAAM,OAAO,IAC3DA,OAAM;AAAA,QACZ;AAAA,MACF;AAEA,aAAO;AAAA,IACT;AAAA,IACA,CAAC;AAAA,EACH;AACF;AAEO,MAAM,cACX,CAAC,QAAa,gBAAqB,CAAC,GAAG,kBAAuB,CAAC,MAC/D,OAAO,QAAQ,SAAS,YAAY;AAClC,MAAI;AACF,QAAI,cAAc,WAAW,QAAQ,IAAI,aAAa,eAAe;AACnE,cAAQ;AAAA,QACN;AAAA,MACF;AAAA,IACF;AAEA,UAAM,SAAS,MAAM,OACnB,gBAAgB,SAAS,SAAS,iBAAiB,UACrD;AAAA,MACE;AAAA,MACA,OAAO,OAAO,EAAE,YAAY,MAAM,GAAG,eAAe,EAAE,QAAQ,CAAC;AAAA,IACjE;AAEA,QAAI,QAAQ;AACV,6BAAuB,CAAC,GAAG,OAAO;AAEpC,WAAO;AAAA,MACL,QAAQ,gBAAgB,YAAY,SAAS;AAAA,MAC7C,QAAQ,CAAC;AAAA,IACX;AAAA,EACF,SAAS,GAAG;AACV,QAAI,CAAC,EAAE,OAAO;AACZ,YAAM;AAAA,IACR;AAEA,UAAM,SAAS;AAAA,MACb;AAAA,MACA,CAAC,QAAQ,6BAA6B,QAAQ,iBAAiB;AAAA,IACjE;AACA,WAAO;AAAA,MACL,QAAQ,CAAC;AAAA,MACT,QAAQ;AAAA,IACV;AAAA,EACF;AACF;",
6
6
  "names": ["error"]
7
7
  }