@digigov/form 2.0.0-7d9a8d86 → 2.0.0-834daea4

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 (733) hide show
  1. package/Field/FieldBase/index.js +73 -51
  2. package/Field/FieldBase.js.map +2 -2
  3. package/Field/FieldBaseContainer/index.js +6 -20
  4. package/Field/FieldBaseContainer.js.map +2 -2
  5. package/Field/FieldConditional/index.js +61 -42
  6. package/Field/FieldConditional.js.map +2 -2
  7. package/Field/index.js +70 -36
  8. package/Field/index.js.map +2 -2
  9. package/Field/types.d.ts +40 -3
  10. package/Field/utils/calculateField/index.js +27 -0
  11. package/{inputs/Input/__stories__/Default → Field/utils/calculateField}/package.json +1 -1
  12. package/Field/utils/calculateField.d.ts +2 -0
  13. package/Field/utils/calculateField.js.map +7 -0
  14. package/Field/utils/evaluateFieldWithConditions/index.js +26 -0
  15. package/Field/utils/evaluateFieldWithConditions/package.json +6 -0
  16. package/Field/utils/evaluateFieldWithConditions.d.ts +2 -0
  17. package/Field/utils/evaluateFieldWithConditions.js.map +7 -0
  18. package/Field/utils/index.d.ts +4 -0
  19. package/Field/utils/index.js +20 -94
  20. package/Field/utils/index.js.map +7 -0
  21. package/Field/utils/useField/index.js +51 -0
  22. package/{FormBuilder/FormBuilder → Field/utils/useField}/package.json +1 -1
  23. package/Field/utils/useField.d.ts +2 -0
  24. package/Field/utils/useField.js.map +7 -0
  25. package/FieldArray/FieldArray.stories/index.js +4 -2
  26. package/FieldArray/FieldArray.stories.d.ts +2 -2
  27. package/FieldArray/FieldArray.stories.js.map +2 -2
  28. package/FieldArray/__stories__/Default/index.js +15 -17
  29. package/FieldArray/__stories__/Default.d.ts +2 -2
  30. package/FieldArray/__stories__/Default.js.map +1 -1
  31. package/FieldArray/__stories__/WithExactLength/index.js +15 -17
  32. package/FieldArray/__stories__/WithExactLength.d.ts +2 -2
  33. package/FieldArray/__stories__/WithExactLength.js.map +1 -1
  34. package/FieldArray/index.d.ts +1 -0
  35. package/FieldArray/index.js +55 -35
  36. package/FieldArray/index.js.map +2 -2
  37. package/FieldArray/index.test.d.ts +1 -0
  38. package/FieldObject/index.d.ts +3 -0
  39. package/FieldObject/index.js +46 -30
  40. package/FieldObject/index.js.map +2 -2
  41. package/Fieldset/FieldsetWithContext/index.js +12 -13
  42. package/Fieldset/FieldsetWithContext.js.map +1 -1
  43. package/Fieldset/index.d.ts +1 -1
  44. package/Fieldset/index.js +9 -18
  45. package/Fieldset/index.js.map +2 -2
  46. package/Fieldset/types.d.ts +3 -2
  47. package/Form.stories.js.map +1 -1
  48. package/FormBuilder/FormBuilder.stories/index.js +2 -1
  49. package/FormBuilder/FormBuilder.stories.d.ts +1 -1
  50. package/FormBuilder/FormBuilder.stories.js.map +2 -2
  51. package/FormBuilder/__stories__/Default/index.js +21 -15
  52. package/FormBuilder/__stories__/Default.d.ts +2 -2
  53. package/FormBuilder/__stories__/Default.js.map +1 -1
  54. package/FormBuilder/index.d.ts +8 -1
  55. package/FormBuilder/index.js +154 -2
  56. package/FormBuilder/index.js.map +3 -3
  57. package/FormBuilder/index.test.d.ts +1 -0
  58. package/FormBuilder/scenarios.test.d.ts +88 -0
  59. package/FormContext/index.js +1 -1
  60. package/FormContext.js.map +1 -1
  61. package/MultiplicityField/MultiplicityField.stories/index.js +12 -6
  62. package/MultiplicityField/MultiplicityField.stories.d.ts +6 -6
  63. package/MultiplicityField/MultiplicityField.stories.js.map +2 -2
  64. package/MultiplicityField/__stories__/Default/index.js +15 -19
  65. package/MultiplicityField/__stories__/Default.d.ts +2 -2
  66. package/MultiplicityField/__stories__/Default.js.map +1 -1
  67. package/MultiplicityField/__stories__/PreviewDisplay/index.js +6 -27
  68. package/MultiplicityField/__stories__/PreviewDisplay.d.ts +2 -2
  69. package/MultiplicityField/__stories__/PreviewDisplay.js.map +2 -2
  70. package/MultiplicityField/__stories__/WithExactLength/index.js +15 -19
  71. package/MultiplicityField/__stories__/WithExactLength.d.ts +2 -2
  72. package/MultiplicityField/__stories__/WithExactLength.js.map +2 -2
  73. package/MultiplicityField/__stories__/WithMaxLength/index.js +15 -19
  74. package/MultiplicityField/__stories__/WithMaxLength.d.ts +2 -2
  75. package/MultiplicityField/__stories__/WithMaxLength.js.map +2 -2
  76. package/MultiplicityField/__stories__/WithMinAndMaxLength/index.js +15 -19
  77. package/MultiplicityField/__stories__/WithMinAndMaxLength.d.ts +2 -2
  78. package/MultiplicityField/__stories__/WithMinAndMaxLength.js.map +2 -2
  79. package/MultiplicityField/__stories__/WithMinLength/index.js +15 -19
  80. package/MultiplicityField/__stories__/WithMinLength.d.ts +2 -2
  81. package/MultiplicityField/__stories__/WithMinLength.js.map +2 -2
  82. package/MultiplicityField/add-objects/index.js +78 -44
  83. package/MultiplicityField/add-objects.d.ts +2 -1
  84. package/MultiplicityField/add-objects.js.map +2 -2
  85. package/MultiplicityField/index.d.ts +2 -19
  86. package/MultiplicityField/index.js +74 -63
  87. package/MultiplicityField/index.js.map +2 -2
  88. package/MultiplicityField/index.test.d.ts +1 -0
  89. package/MultiplicityField/types/index.js +1 -0
  90. package/{validators/validators.spec → MultiplicityField/types}/package.json +1 -1
  91. package/MultiplicityField/types.d.ts +19 -0
  92. package/MultiplicityField/types.js.map +7 -0
  93. package/Questions/Questions/index.js +21 -15
  94. package/Questions/Questions.js.map +2 -2
  95. package/Questions/Questions.stories/index.js +2 -1
  96. package/Questions/Questions.stories.d.ts +1 -1
  97. package/Questions/Questions.stories.js.map +2 -2
  98. package/Questions/QuestionsContext/index.js +2 -2
  99. package/Questions/QuestionsContext.d.ts +0 -1
  100. package/Questions/QuestionsContext.js.map +1 -1
  101. package/Questions/Step/ReviewStep/index.js +20 -26
  102. package/Questions/Step/ReviewStep.js.map +1 -1
  103. package/Questions/Step/Step/index.js +24 -18
  104. package/Questions/Step/Step.js.map +2 -2
  105. package/Questions/Step/StepArrayReview/index.js +20 -25
  106. package/Questions/Step/StepArrayReview.js.map +1 -1
  107. package/Questions/Step/StepContext/index.js +3 -3
  108. package/Questions/Step/StepContext.d.ts +0 -1
  109. package/Questions/Step/StepContext.js.map +1 -1
  110. package/Questions/Step/StepDescription/index.js +7 -12
  111. package/Questions/Step/StepDescription.js.map +1 -1
  112. package/Questions/Step/StepForm/index.js +16 -19
  113. package/Questions/Step/StepForm.js.map +1 -1
  114. package/Questions/Step/StepQuote/index.js +2 -4
  115. package/Questions/Step/StepQuote.js.map +1 -1
  116. package/Questions/Step/StepTitle/index.js +21 -18
  117. package/Questions/Step/StepTitle.d.ts +2 -1
  118. package/Questions/Step/StepTitle.js.map +2 -2
  119. package/Questions/Step/getAddMoreFields.js.map +1 -1
  120. package/Questions/Step/index.d.ts +0 -1
  121. package/Questions/Step/index.js +0 -1
  122. package/Questions/Step/index.js.map +2 -2
  123. package/Questions/Step/types.d.ts +1 -0
  124. package/Questions/__stories__/Default/index.js +31 -38
  125. package/Questions/__stories__/Default.d.ts +2 -2
  126. package/Questions/__stories__/Default.js.map +1 -1
  127. package/Questions/getNextStep/index.js +3 -1
  128. package/Questions/getNextStep.js.map +1 -1
  129. package/Questions/index.js +1 -1
  130. package/Questions/index.js.map +1 -1
  131. package/Questions/index.test.d.ts +1 -0
  132. package/Questions/types.d.ts +1 -0
  133. package/cjs/Field/FieldBase/index.js +96 -68
  134. package/cjs/Field/FieldBase.js.map +3 -3
  135. package/cjs/Field/FieldBaseContainer/index.js +33 -41
  136. package/cjs/Field/FieldBaseContainer.js.map +3 -3
  137. package/cjs/Field/FieldConditional/index.js +83 -58
  138. package/cjs/Field/FieldConditional.js.map +3 -3
  139. package/cjs/Field/index.js +92 -55
  140. package/cjs/Field/index.js.map +3 -3
  141. package/cjs/Field/types/index.js +14 -2
  142. package/cjs/Field/types.js.map +2 -2
  143. package/cjs/Field/utils/calculateField/index.js +50 -0
  144. package/cjs/Field/utils/calculateField.js.map +7 -0
  145. package/cjs/Field/utils/evaluateFieldWithConditions/index.js +49 -0
  146. package/cjs/Field/utils/evaluateFieldWithConditions.js.map +7 -0
  147. package/cjs/Field/utils/index.js +51 -119
  148. package/cjs/Field/utils/index.js.map +7 -0
  149. package/cjs/Field/utils/useField/index.js +74 -0
  150. package/cjs/Field/utils/useField.js.map +7 -0
  151. package/cjs/FieldArray/FieldArray.stories/index.js +30 -19
  152. package/cjs/FieldArray/FieldArray.stories.js.map +3 -3
  153. package/cjs/FieldArray/__stories__/Default/index.js +37 -33
  154. package/cjs/FieldArray/__stories__/Default.js.map +2 -2
  155. package/cjs/FieldArray/__stories__/WithExactLength/index.js +37 -33
  156. package/cjs/FieldArray/__stories__/WithExactLength.js.map +2 -2
  157. package/cjs/FieldArray/index.js +77 -51
  158. package/cjs/FieldArray/index.js.map +3 -3
  159. package/cjs/FieldObject/index.js +64 -45
  160. package/cjs/FieldObject/index.js.map +3 -3
  161. package/cjs/Fieldset/FieldsetWithContext/index.js +35 -30
  162. package/cjs/Fieldset/FieldsetWithContext.js.map +2 -2
  163. package/cjs/Fieldset/index.js +33 -36
  164. package/cjs/Fieldset/index.js.map +3 -3
  165. package/cjs/Fieldset/types/index.js +14 -2
  166. package/cjs/Fieldset/types.js.map +2 -2
  167. package/cjs/Form.stories/index.js +16 -6
  168. package/cjs/Form.stories.js.map +1 -1
  169. package/cjs/FormBuilder/FormBuilder.stories/index.js +27 -18
  170. package/cjs/FormBuilder/FormBuilder.stories.js.map +3 -3
  171. package/cjs/FormBuilder/__stories__/Default/index.js +43 -31
  172. package/cjs/FormBuilder/__stories__/Default.js.map +2 -2
  173. package/cjs/FormBuilder/index.js +181 -18
  174. package/cjs/FormBuilder/index.js.map +3 -3
  175. package/cjs/FormContext/index.js +14 -18
  176. package/cjs/FormContext.js.map +2 -2
  177. package/cjs/MultiplicityField/MultiplicityField.stories/index.js +42 -23
  178. package/cjs/MultiplicityField/MultiplicityField.stories.js.map +3 -3
  179. package/cjs/MultiplicityField/__stories__/Default/index.js +37 -35
  180. package/cjs/MultiplicityField/__stories__/Default.js.map +2 -2
  181. package/cjs/MultiplicityField/__stories__/PreviewDisplay/index.js +32 -47
  182. package/cjs/MultiplicityField/__stories__/PreviewDisplay.js.map +3 -3
  183. package/cjs/MultiplicityField/__stories__/WithExactLength/index.js +37 -35
  184. package/cjs/MultiplicityField/__stories__/WithExactLength.js.map +3 -3
  185. package/cjs/MultiplicityField/__stories__/WithMaxLength/index.js +37 -35
  186. package/cjs/MultiplicityField/__stories__/WithMaxLength.js.map +3 -3
  187. package/cjs/MultiplicityField/__stories__/WithMinAndMaxLength/index.js +37 -35
  188. package/cjs/MultiplicityField/__stories__/WithMinAndMaxLength.js.map +3 -3
  189. package/cjs/MultiplicityField/__stories__/WithMinLength/index.js +37 -35
  190. package/cjs/MultiplicityField/__stories__/WithMinLength.js.map +3 -3
  191. package/cjs/MultiplicityField/add-objects/index.js +97 -60
  192. package/cjs/MultiplicityField/add-objects.js.map +3 -3
  193. package/cjs/MultiplicityField/index.js +90 -78
  194. package/cjs/MultiplicityField/index.js.map +3 -3
  195. package/cjs/MultiplicityField/types/index.js +16 -0
  196. package/cjs/MultiplicityField/types.js.map +7 -0
  197. package/cjs/Questions/Questions/index.js +42 -30
  198. package/cjs/Questions/Questions.js.map +2 -2
  199. package/cjs/Questions/Questions.stories/index.js +27 -18
  200. package/cjs/Questions/Questions.stories.js.map +3 -3
  201. package/cjs/Questions/QuestionsContext/index.js +15 -19
  202. package/cjs/Questions/QuestionsContext.js.map +1 -1
  203. package/cjs/Questions/Step/ReviewStep/index.js +43 -43
  204. package/cjs/Questions/Step/ReviewStep.js.map +2 -2
  205. package/cjs/Questions/Step/Step/index.js +45 -33
  206. package/cjs/Questions/Step/Step.js.map +2 -2
  207. package/cjs/Questions/Step/StepArrayReview/index.js +46 -45
  208. package/cjs/Questions/Step/StepArrayReview.js.map +2 -2
  209. package/cjs/Questions/Step/StepContext/index.js +16 -20
  210. package/cjs/Questions/Step/StepContext.js.map +1 -1
  211. package/cjs/Questions/Step/StepDescription/index.js +29 -28
  212. package/cjs/Questions/Step/StepDescription.js.map +2 -2
  213. package/cjs/Questions/Step/StepForm/index.js +41 -38
  214. package/cjs/Questions/Step/StepForm.js.map +2 -2
  215. package/cjs/Questions/Step/StepQuote/index.js +25 -21
  216. package/cjs/Questions/Step/StepQuote.js.map +2 -2
  217. package/cjs/Questions/Step/StepTitle/index.js +42 -34
  218. package/cjs/Questions/Step/StepTitle.js.map +3 -3
  219. package/cjs/Questions/Step/getAddMoreFields/index.js +16 -4
  220. package/cjs/Questions/Step/getAddMoreFields.js.map +1 -1
  221. package/cjs/Questions/Step/index.js +45 -28
  222. package/cjs/Questions/Step/index.js.map +3 -3
  223. package/cjs/Questions/Step/types/index.js +14 -2
  224. package/cjs/Questions/Step/types.js.map +2 -2
  225. package/cjs/Questions/__stories__/Default/index.js +59 -60
  226. package/cjs/Questions/__stories__/Default.js.map +2 -2
  227. package/cjs/Questions/getNextStep/index.js +19 -5
  228. package/cjs/Questions/getNextStep.js.map +1 -1
  229. package/cjs/Questions/index.js +19 -20
  230. package/cjs/Questions/index.js.map +1 -1
  231. package/cjs/Questions/types/index.js +14 -2
  232. package/cjs/Questions/types.js.map +2 -2
  233. package/cjs/index.js +35 -18
  234. package/cjs/index.js.map +3 -3
  235. package/cjs/inputs/AutoCompleteInput/AutoComplete.stories/index.js +30 -19
  236. package/cjs/inputs/AutoCompleteInput/AutoComplete.stories.js.map +3 -3
  237. package/cjs/inputs/AutoCompleteInput/__stories__/Default/index.js +46 -36
  238. package/cjs/inputs/AutoCompleteInput/__stories__/Default.js.map +3 -3
  239. package/cjs/inputs/AutoCompleteInput/__stories__/Multiple/index.js +50 -39
  240. package/cjs/inputs/AutoCompleteInput/__stories__/Multiple.js.map +3 -3
  241. package/cjs/inputs/AutoCompleteInput/index.js +69 -42
  242. package/cjs/inputs/AutoCompleteInput/index.js.map +3 -3
  243. package/cjs/inputs/Checkboxes/Checkboxes.stories/index.js +33 -20
  244. package/cjs/inputs/Checkboxes/Checkboxes.stories.js.map +3 -3
  245. package/cjs/inputs/Checkboxes/__stories__/Conditional/index.js +35 -29
  246. package/cjs/inputs/Checkboxes/__stories__/Conditional.js.map +2 -2
  247. package/cjs/inputs/Checkboxes/__stories__/Default/index.js +58 -46
  248. package/cjs/inputs/Checkboxes/__stories__/Default.js.map +2 -2
  249. package/cjs/inputs/Checkboxes/__stories__/WithDivider/index.js +59 -47
  250. package/cjs/inputs/Checkboxes/__stories__/WithDivider.js.map +2 -2
  251. package/cjs/inputs/Checkboxes/index.js +68 -62
  252. package/cjs/inputs/Checkboxes/index.js.map +3 -3
  253. package/cjs/inputs/DateInput/DateInput.stories/index.js +27 -18
  254. package/cjs/inputs/DateInput/DateInput.stories.js.map +3 -3
  255. package/cjs/inputs/DateInput/__stories__/Default/index.js +41 -32
  256. package/cjs/inputs/DateInput/__stories__/Default.js.map +3 -3
  257. package/cjs/inputs/DateInput/index.js +72 -60
  258. package/cjs/inputs/DateInput/index.js.map +3 -3
  259. package/cjs/inputs/FileInput/FileInput.stories/index.js +27 -18
  260. package/cjs/inputs/FileInput/FileInput.stories.js.map +3 -3
  261. package/cjs/inputs/FileInput/__stories__/Default/index.js +43 -29
  262. package/cjs/inputs/FileInput/__stories__/Default.js.map +2 -2
  263. package/cjs/inputs/FileInput/index.js +55 -42
  264. package/cjs/inputs/FileInput/index.js.map +3 -3
  265. package/cjs/inputs/ImageInput/ImageInput.stories/index.js +33 -20
  266. package/cjs/inputs/ImageInput/ImageInput.stories.js.map +3 -3
  267. package/cjs/inputs/ImageInput/__stories__/Default/index.js +35 -29
  268. package/cjs/inputs/ImageInput/__stories__/Default.js.map +2 -2
  269. package/cjs/inputs/ImageInput/__stories__/MaxSize/index.js +69 -0
  270. package/cjs/inputs/ImageInput/__stories__/MaxSize.js.map +7 -0
  271. package/cjs/inputs/ImageInput/__stories__/WithInvalidImageDimension/index.js +37 -30
  272. package/cjs/inputs/ImageInput/__stories__/WithInvalidImageDimension.js.map +3 -3
  273. package/cjs/inputs/ImageInput/__stories__/WithInvalidImageSize/index.js +35 -29
  274. package/cjs/inputs/ImageInput/__stories__/WithInvalidImageSize.js.map +2 -2
  275. package/cjs/inputs/ImageInput/index.js +72 -66
  276. package/cjs/inputs/ImageInput/index.js.map +3 -3
  277. package/cjs/inputs/Input/Input.stories/index.js +54 -27
  278. package/cjs/inputs/Input/Input.stories.js.map +3 -3
  279. package/cjs/inputs/Input/__stories__/AFM/index.js +44 -32
  280. package/cjs/inputs/Input/__stories__/AFM.js.map +2 -2
  281. package/cjs/inputs/Input/__stories__/Boolean/index.js +45 -33
  282. package/cjs/inputs/Input/__stories__/Boolean.js.map +2 -2
  283. package/cjs/inputs/Input/__stories__/IBAN/index.js +45 -33
  284. package/cjs/inputs/Input/__stories__/IBAN.js.map +2 -2
  285. package/cjs/inputs/Input/__stories__/Integer/index.js +57 -41
  286. package/cjs/inputs/Input/__stories__/Integer.js.map +2 -2
  287. package/cjs/inputs/Input/__stories__/LandlineNumber/index.js +48 -36
  288. package/cjs/inputs/Input/__stories__/LandlineNumber.js.map +2 -2
  289. package/cjs/inputs/Input/__stories__/MobilePhone/index.js +48 -36
  290. package/cjs/inputs/Input/__stories__/MobilePhone.js.map +2 -2
  291. package/cjs/inputs/Input/__stories__/PhoneNumber/index.js +47 -35
  292. package/cjs/inputs/Input/__stories__/PhoneNumber.js.map +2 -2
  293. package/cjs/inputs/Input/__stories__/PostalCode/index.js +45 -33
  294. package/cjs/inputs/Input/__stories__/PostalCode.js.map +2 -2
  295. package/cjs/inputs/Input/__stories__/String/index.js +64 -0
  296. package/cjs/inputs/Input/__stories__/String.js.map +7 -0
  297. package/cjs/inputs/Input/__stories__/TextWithLimit/index.js +64 -0
  298. package/cjs/inputs/Input/__stories__/TextWithLimit.js.map +7 -0
  299. package/cjs/inputs/Input/index.js +77 -52
  300. package/cjs/inputs/Input/index.js.map +3 -3
  301. package/cjs/inputs/Input/inputsInputScenarios/index.js +439 -0
  302. package/cjs/inputs/Input/inputsInputScenarios.js.map +7 -0
  303. package/cjs/inputs/Label/Label.stories/index.js +27 -18
  304. package/cjs/inputs/Label/Label.stories.js.map +3 -3
  305. package/cjs/inputs/Label/__stories__/Default/index.js +54 -36
  306. package/cjs/inputs/Label/__stories__/Default.js.map +3 -3
  307. package/cjs/inputs/Label/index.js +28 -28
  308. package/cjs/inputs/Label/index.js.map +3 -3
  309. package/cjs/inputs/OtpInput/OtpInput.stories/index.js +27 -18
  310. package/cjs/inputs/OtpInput/OtpInput.stories.js.map +3 -3
  311. package/cjs/inputs/OtpInput/__stories__/Default/index.js +35 -29
  312. package/cjs/inputs/OtpInput/__stories__/Default.js.map +2 -2
  313. package/cjs/inputs/OtpInput/index.js +118 -94
  314. package/cjs/inputs/OtpInput/index.js.map +3 -3
  315. package/cjs/inputs/Radio/Radio.stories/index.js +33 -20
  316. package/cjs/inputs/Radio/Radio.stories.js.map +3 -3
  317. package/cjs/inputs/Radio/__stories__/Conditional/index.js +35 -29
  318. package/cjs/inputs/Radio/__stories__/Conditional.js.map +3 -3
  319. package/cjs/inputs/Radio/__stories__/Default/index.js +62 -50
  320. package/cjs/inputs/Radio/__stories__/Default.js.map +2 -2
  321. package/cjs/inputs/Radio/__stories__/WithDivider/index.js +63 -51
  322. package/cjs/inputs/Radio/__stories__/WithDivider.js.map +2 -2
  323. package/cjs/inputs/Radio/index.js +107 -55
  324. package/cjs/inputs/Radio/index.js.map +3 -3
  325. package/cjs/inputs/Select/Select.stories/index.js +27 -18
  326. package/cjs/inputs/Select/Select.stories.js.map +3 -3
  327. package/cjs/inputs/Select/__stories__/Default/index.js +67 -55
  328. package/cjs/inputs/Select/__stories__/Default.js.map +2 -2
  329. package/cjs/inputs/Select/index.js +38 -30
  330. package/cjs/inputs/Select/index.js.map +3 -3
  331. package/cjs/inputs/index.js +30 -24
  332. package/cjs/inputs/index.js.map +1 -1
  333. package/cjs/inputs/inputsScenarios/index.js +539 -0
  334. package/cjs/inputs/inputsScenarios.js.map +7 -0
  335. package/cjs/internal/index.js +24 -77
  336. package/cjs/internal.js.map +2 -2
  337. package/cjs/lazy/index.js +87 -74
  338. package/cjs/lazy.js.map +3 -3
  339. package/cjs/locales/el/index.js +35 -0
  340. package/cjs/locales/el.js.map +7 -0
  341. package/cjs/registry/index.js +109 -88
  342. package/cjs/registry.js.map +2 -2
  343. package/cjs/types/index.js +20 -2
  344. package/cjs/types.js.map +2 -2
  345. package/cjs/utils/index.js +47 -34
  346. package/cjs/utils.js.map +3 -3
  347. package/cjs/validators/index.js +33 -88
  348. package/cjs/validators/index.js.map +2 -2
  349. package/cjs/validators/types/index.js +14 -2
  350. package/cjs/validators/types.js.map +1 -1
  351. package/cjs/validators/utils/afm/index.js +16 -4
  352. package/cjs/validators/utils/afm.js.map +1 -1
  353. package/cjs/validators/utils/date/index.js +138 -0
  354. package/cjs/validators/utils/date.js.map +7 -0
  355. package/cjs/validators/utils/file/index.js +25 -13
  356. package/cjs/validators/utils/file.js.map +2 -2
  357. package/cjs/validators/utils/iban/index.js +16 -4
  358. package/cjs/validators/utils/iban.js.map +1 -1
  359. package/cjs/validators/utils/image/index.js +18 -6
  360. package/cjs/validators/utils/image.js.map +1 -1
  361. package/cjs/validators/utils/index.js +54 -28
  362. package/cjs/validators/utils/index.js.map +2 -2
  363. package/cjs/validators/utils/int/index.js +16 -4
  364. package/cjs/validators/utils/int.js.map +1 -1
  365. package/cjs/validators/utils/number/index.js +16 -4
  366. package/cjs/validators/utils/number.js.map +1 -1
  367. package/cjs/validators/utils/otp/index.js +16 -4
  368. package/cjs/validators/utils/otp.js.map +1 -1
  369. package/cjs/validators/utils/phone/index.js +25 -6
  370. package/cjs/validators/utils/phone.js.map +2 -2
  371. package/cjs/validators/utils/postal_code/index.js +16 -4
  372. package/cjs/validators/utils/postal_code.js.map +1 -1
  373. package/cjs/validators/utils/text_limit/index.js +18 -6
  374. package/cjs/validators/utils/text_limit.js.map +1 -1
  375. package/cjs/validators/utils/uuid4/index.js +16 -4
  376. package/cjs/validators/utils/uuid4.js.map +1 -1
  377. package/index.d.ts +4 -1
  378. package/index.js +7 -2
  379. package/index.js.map +3 -3
  380. package/inputs/AutoCompleteInput/AutoComplete.stories/index.js +4 -2
  381. package/inputs/AutoCompleteInput/AutoComplete.stories.d.ts +2 -2
  382. package/inputs/AutoCompleteInput/AutoComplete.stories.js.map +2 -2
  383. package/inputs/AutoCompleteInput/__stories__/Default/index.js +22 -18
  384. package/inputs/AutoCompleteInput/__stories__/Default.d.ts +2 -2
  385. package/inputs/AutoCompleteInput/__stories__/Default.js.map +2 -2
  386. package/inputs/AutoCompleteInput/__stories__/Multiple/index.js +26 -21
  387. package/inputs/AutoCompleteInput/__stories__/Multiple.d.ts +3 -2
  388. package/inputs/AutoCompleteInput/__stories__/Multiple.js.map +2 -2
  389. package/inputs/AutoCompleteInput/index.d.ts +1 -1
  390. package/inputs/AutoCompleteInput/index.js +50 -27
  391. package/inputs/AutoCompleteInput/index.js.map +3 -3
  392. package/inputs/AutoCompleteInput/index.test.d.ts +1 -0
  393. package/inputs/Checkboxes/Checkboxes.stories/index.js +6 -3
  394. package/inputs/Checkboxes/Checkboxes.stories.d.ts +3 -3
  395. package/inputs/Checkboxes/Checkboxes.stories.js.map +2 -2
  396. package/inputs/Checkboxes/__stories__/Conditional/index.js +13 -13
  397. package/inputs/Checkboxes/__stories__/Conditional.d.ts +2 -2
  398. package/inputs/Checkboxes/__stories__/Conditional.js.map +1 -1
  399. package/inputs/Checkboxes/__stories__/Default/index.js +36 -30
  400. package/inputs/Checkboxes/__stories__/Default.d.ts +2 -2
  401. package/inputs/Checkboxes/__stories__/Default.js.map +1 -1
  402. package/inputs/Checkboxes/__stories__/WithDivider/index.js +37 -31
  403. package/inputs/Checkboxes/__stories__/WithDivider.d.ts +2 -2
  404. package/inputs/Checkboxes/__stories__/WithDivider.js.map +1 -1
  405. package/inputs/Checkboxes/index.d.ts +1 -0
  406. package/inputs/Checkboxes/index.js +51 -47
  407. package/inputs/Checkboxes/index.js.map +2 -2
  408. package/inputs/Checkboxes/index.test.d.ts +1 -0
  409. package/inputs/DateInput/DateInput.stories/index.js +2 -1
  410. package/inputs/DateInput/DateInput.stories.d.ts +1 -1
  411. package/inputs/DateInput/DateInput.stories.js.map +2 -2
  412. package/inputs/DateInput/__stories__/Default/index.js +19 -16
  413. package/inputs/DateInput/__stories__/Default.d.ts +2 -2
  414. package/inputs/DateInput/__stories__/Default.js.map +2 -2
  415. package/inputs/DateInput/index.d.ts +2 -2
  416. package/inputs/DateInput/index.js +52 -43
  417. package/inputs/DateInput/index.js.map +3 -3
  418. package/inputs/DateInput/index.test.d.ts +1 -0
  419. package/inputs/FileInput/FileInput.stories/index.js +2 -1
  420. package/inputs/FileInput/FileInput.stories.d.ts +1 -1
  421. package/inputs/FileInput/FileInput.stories.js.map +2 -2
  422. package/inputs/FileInput/__stories__/Default/index.js +21 -13
  423. package/inputs/FileInput/__stories__/Default.d.ts +2 -2
  424. package/inputs/FileInput/__stories__/Default.js.map +1 -1
  425. package/inputs/FileInput/index.js +34 -27
  426. package/inputs/FileInput/index.js.map +3 -3
  427. package/inputs/FileInput/index.test.d.ts +1 -0
  428. package/inputs/ImageInput/ImageInput.stories/index.js +6 -3
  429. package/inputs/ImageInput/ImageInput.stories.d.ts +3 -3
  430. package/inputs/ImageInput/ImageInput.stories.js.map +2 -2
  431. package/inputs/ImageInput/__stories__/Default/index.js +13 -13
  432. package/inputs/ImageInput/__stories__/Default.d.ts +2 -2
  433. package/inputs/ImageInput/__stories__/Default.js.map +1 -1
  434. package/inputs/ImageInput/__stories__/MaxSize/index.js +36 -0
  435. package/inputs/ImageInput/__stories__/MaxSize/package.json +6 -0
  436. package/inputs/ImageInput/__stories__/MaxSize.d.ts +3 -0
  437. package/inputs/ImageInput/__stories__/MaxSize.js.map +7 -0
  438. package/inputs/ImageInput/__stories__/WithInvalidImageDimension/index.js +15 -14
  439. package/inputs/ImageInput/__stories__/WithInvalidImageDimension.d.ts +2 -2
  440. package/inputs/ImageInput/__stories__/WithInvalidImageDimension.js.map +2 -2
  441. package/inputs/ImageInput/__stories__/WithInvalidImageSize/index.js +13 -13
  442. package/inputs/ImageInput/__stories__/WithInvalidImageSize.d.ts +2 -2
  443. package/inputs/ImageInput/__stories__/WithInvalidImageSize.js.map +1 -1
  444. package/inputs/ImageInput/index.js +51 -51
  445. package/inputs/ImageInput/index.js.map +3 -3
  446. package/inputs/ImageInput/index.test.d.ts +1 -0
  447. package/inputs/Input/Input.stories/index.js +20 -10
  448. package/inputs/Input/Input.stories.d.ts +10 -10
  449. package/inputs/Input/Input.stories.js.map +2 -2
  450. package/inputs/Input/__stories__/AFM/index.js +22 -16
  451. package/inputs/Input/__stories__/AFM.d.ts +2 -2
  452. package/inputs/Input/__stories__/AFM.js.map +1 -1
  453. package/inputs/Input/__stories__/Boolean/index.js +23 -17
  454. package/inputs/Input/__stories__/Boolean.d.ts +2 -2
  455. package/inputs/Input/__stories__/Boolean.js.map +1 -1
  456. package/inputs/Input/__stories__/IBAN/index.js +23 -17
  457. package/inputs/Input/__stories__/IBAN.d.ts +2 -2
  458. package/inputs/Input/__stories__/IBAN.js.map +1 -1
  459. package/inputs/Input/__stories__/Integer/index.js +35 -25
  460. package/inputs/Input/__stories__/Integer.d.ts +2 -2
  461. package/inputs/Input/__stories__/Integer.js.map +1 -1
  462. package/inputs/Input/__stories__/LandlineNumber/index.js +26 -20
  463. package/inputs/Input/__stories__/LandlineNumber.d.ts +2 -2
  464. package/inputs/Input/__stories__/LandlineNumber.js.map +1 -1
  465. package/inputs/Input/__stories__/MobilePhone/index.js +26 -20
  466. package/inputs/Input/__stories__/MobilePhone.d.ts +2 -2
  467. package/inputs/Input/__stories__/MobilePhone.js.map +1 -1
  468. package/inputs/Input/__stories__/PhoneNumber/index.js +25 -19
  469. package/inputs/Input/__stories__/PhoneNumber.d.ts +2 -2
  470. package/inputs/Input/__stories__/PhoneNumber.js.map +1 -1
  471. package/inputs/Input/__stories__/PostalCode/index.js +23 -17
  472. package/inputs/Input/__stories__/PostalCode.d.ts +2 -2
  473. package/inputs/Input/__stories__/PostalCode.js.map +1 -1
  474. package/inputs/Input/__stories__/String/index.js +31 -0
  475. package/inputs/Input/__stories__/String/package.json +6 -0
  476. package/inputs/Input/__stories__/String.d.ts +3 -0
  477. package/inputs/Input/__stories__/String.js.map +7 -0
  478. package/inputs/Input/__stories__/TextWithLimit/index.js +31 -0
  479. package/inputs/Input/__stories__/TextWithLimit/package.json +6 -0
  480. package/inputs/Input/__stories__/TextWithLimit.d.ts +3 -0
  481. package/inputs/Input/__stories__/TextWithLimit.js.map +7 -0
  482. package/inputs/Input/index.js +55 -36
  483. package/inputs/Input/index.js.map +3 -3
  484. package/inputs/Input/index.test.d.ts +1 -0
  485. package/inputs/Input/inputsInputScenarios/index.js +406 -0
  486. package/inputs/Input/inputsInputScenarios/package.json +6 -0
  487. package/inputs/Input/inputsInputScenarios.d.ts +57 -0
  488. package/inputs/Input/inputsInputScenarios.js.map +7 -0
  489. package/inputs/Label/Label.stories/index.js +2 -1
  490. package/inputs/Label/Label.stories.d.ts +1 -1
  491. package/inputs/Label/Label.stories.js.map +2 -2
  492. package/inputs/Label/__stories__/Default/index.js +32 -20
  493. package/inputs/Label/__stories__/Default.d.ts +2 -2
  494. package/inputs/Label/__stories__/Default.js.map +2 -2
  495. package/inputs/Label/index.d.ts +1 -1
  496. package/inputs/Label/index.js +6 -12
  497. package/inputs/Label/index.js.map +2 -2
  498. package/inputs/Label/index.test.d.ts +1 -0
  499. package/inputs/OtpInput/OtpInput.stories/index.js +2 -1
  500. package/inputs/OtpInput/OtpInput.stories.d.ts +1 -1
  501. package/inputs/OtpInput/OtpInput.stories.js.map +2 -2
  502. package/inputs/OtpInput/__stories__/Default/index.js +13 -13
  503. package/inputs/OtpInput/__stories__/Default.d.ts +2 -2
  504. package/inputs/OtpInput/__stories__/Default.js.map +1 -1
  505. package/inputs/OtpInput/index.d.ts +9 -2
  506. package/inputs/OtpInput/index.js +94 -77
  507. package/inputs/OtpInput/index.js.map +2 -2
  508. package/inputs/OtpInput/index.test.d.ts +1 -0
  509. package/inputs/Radio/Radio.stories/index.js +6 -3
  510. package/inputs/Radio/Radio.stories.d.ts +3 -3
  511. package/inputs/Radio/Radio.stories.js.map +2 -2
  512. package/inputs/Radio/__stories__/Conditional/index.js +13 -13
  513. package/inputs/Radio/__stories__/Conditional.d.ts +2 -2
  514. package/inputs/Radio/__stories__/Conditional.js.map +2 -2
  515. package/inputs/Radio/__stories__/Default/index.js +40 -34
  516. package/inputs/Radio/__stories__/Default.d.ts +2 -2
  517. package/inputs/Radio/__stories__/Default.js.map +1 -1
  518. package/inputs/Radio/__stories__/WithDivider/index.js +41 -35
  519. package/inputs/Radio/__stories__/WithDivider.d.ts +2 -2
  520. package/inputs/Radio/__stories__/WithDivider.js.map +1 -1
  521. package/inputs/Radio/index.d.ts +5 -0
  522. package/inputs/Radio/index.js +88 -39
  523. package/inputs/Radio/index.js.map +2 -2
  524. package/inputs/Radio/index.test.d.ts +1 -0
  525. package/inputs/Select/Select.stories/index.js +2 -1
  526. package/inputs/Select/Select.stories.d.ts +1 -1
  527. package/inputs/Select/Select.stories.js.map +2 -2
  528. package/inputs/Select/__stories__/Default/index.js +45 -39
  529. package/inputs/Select/__stories__/Default.d.ts +2 -2
  530. package/inputs/Select/__stories__/Default.js.map +1 -1
  531. package/inputs/Select/index.js +16 -14
  532. package/inputs/Select/index.js.map +2 -2
  533. package/inputs/Select/index.test.d.ts +1 -0
  534. package/inputs/index.js +9 -9
  535. package/inputs/index.js.map +2 -2
  536. package/inputs/inputsScenarios/index.js +505 -0
  537. package/inputs/inputsScenarios/package.json +6 -0
  538. package/inputs/inputsScenarios.d.ts +296 -0
  539. package/inputs/inputsScenarios.js.map +7 -0
  540. package/internal/index.js +4 -45
  541. package/internal.d.ts +2 -31
  542. package/internal.js.map +2 -2
  543. package/lazy/index.js +66 -57
  544. package/lazy.d.ts +41 -29
  545. package/lazy.js.map +2 -2
  546. package/locales/el/index.js +6 -0
  547. package/{Questions/index.spec → locales/el}/package.json +1 -1
  548. package/locales/el.d.ts +2 -0
  549. package/locales/el.js.map +7 -0
  550. package/package.json +7 -7
  551. package/registry/index.js +28 -11
  552. package/registry.d.ts +8 -1
  553. package/registry.js.map +2 -2
  554. package/src/Field/FieldBase.tsx +2 -0
  555. package/src/Field/FieldBaseContainer.tsx +4 -2
  556. package/src/Field/FieldConditional.tsx +5 -1
  557. package/src/Field/index.tsx +22 -3
  558. package/src/Field/types.tsx +68 -3
  559. package/src/Field/utils/calculateField.ts +49 -0
  560. package/src/Field/utils/evaluateFieldWithConditions.ts +30 -0
  561. package/src/Field/utils/index.ts +76 -0
  562. package/src/Field/utils/useField.ts +54 -0
  563. package/src/FieldArray/FieldArray.stories.js +2 -2
  564. package/src/FieldArray/index.test.tsx +24 -0
  565. package/src/FieldArray/index.tsx +20 -8
  566. package/src/FieldObject/index.tsx +18 -5
  567. package/src/Fieldset/index.tsx +5 -5
  568. package/src/Fieldset/types.tsx +5 -3
  569. package/src/FormBuilder/FormBuilder.stories.js +1 -1
  570. package/src/FormBuilder/{FormBuilder.mdx → doc.mdx} +20 -33
  571. package/src/FormBuilder/index.test.tsx +20 -0
  572. package/src/FormBuilder/index.tsx +178 -1
  573. package/src/FormBuilder/scenarios.test.tsx +1864 -0
  574. package/src/MultiplicityField/MultiplicityField.stories.js +6 -6
  575. package/src/MultiplicityField/__stories__/PreviewDisplay.tsx +2 -2
  576. package/src/MultiplicityField/__stories__/WithExactLength.tsx +1 -1
  577. package/src/MultiplicityField/__stories__/WithMaxLength.tsx +1 -1
  578. package/src/MultiplicityField/__stories__/WithMinAndMaxLength.tsx +1 -1
  579. package/src/MultiplicityField/__stories__/WithMinLength.tsx +1 -1
  580. package/src/MultiplicityField/add-objects.tsx +27 -12
  581. package/src/MultiplicityField/{MultiplicityField.mdx → doc.mdx} +12 -16
  582. package/src/MultiplicityField/index.test.tsx +40 -0
  583. package/src/MultiplicityField/index.tsx +20 -34
  584. package/src/MultiplicityField/types.ts +22 -0
  585. package/src/Questions/Questions.stories.js +1 -1
  586. package/src/Questions/Step/StepTitle.tsx +5 -3
  587. package/src/Questions/Step/index.ts +0 -1
  588. package/src/Questions/Step/types.tsx +1 -0
  589. package/src/Questions/__snapshots__/index.spec.tsx.snap +72 -587
  590. package/src/Questions/{index.mdx → doc.mdx} +13 -16
  591. package/src/Questions/index.spec.tsx +3 -3
  592. package/src/Questions/index.test.tsx +20 -0
  593. package/src/Questions/types.tsx +1 -0
  594. package/src/create-simple-form.mdx +2 -6
  595. package/src/{index.mdx → doc.mdx} +4 -8
  596. package/src/index.ts +4 -1
  597. package/src/inputs/AutoCompleteInput/AutoComplete.stories.js +2 -2
  598. package/src/inputs/AutoCompleteInput/__stories__/Default.tsx +26 -18
  599. package/src/inputs/AutoCompleteInput/__stories__/Multiple.tsx +27 -20
  600. package/src/inputs/AutoCompleteInput/{index.mdx → doc.mdx} +3 -8
  601. package/src/inputs/AutoCompleteInput/index.test.tsx +24 -0
  602. package/src/inputs/AutoCompleteInput/index.tsx +47 -30
  603. package/src/inputs/Checkboxes/Checkboxes.stories.js +3 -3
  604. package/src/inputs/Checkboxes/{index.mdx → doc.mdx} +5 -15
  605. package/src/inputs/Checkboxes/index.test.tsx +28 -0
  606. package/src/inputs/Checkboxes/index.tsx +35 -30
  607. package/src/inputs/DateInput/DateInput.stories.js +1 -1
  608. package/src/inputs/DateInput/__stories__/Default.tsx +21 -15
  609. package/src/inputs/DateInput/{index.mdx → doc.mdx} +1 -8
  610. package/src/inputs/DateInput/index.test.tsx +20 -0
  611. package/src/inputs/DateInput/index.tsx +7 -5
  612. package/src/inputs/FileInput/FileInput.stories.js +1 -1
  613. package/src/inputs/FileInput/{index.mdx → doc.mdx} +1 -5
  614. package/src/inputs/FileInput/index.test.tsx +20 -0
  615. package/src/inputs/FileInput/index.tsx +5 -6
  616. package/src/inputs/ImageInput/ImageInput.stories.js +4 -3
  617. package/src/inputs/ImageInput/__stories__/MaxSize.tsx +37 -0
  618. package/src/inputs/ImageInput/__stories__/WithInvalidImageDimension.tsx +2 -0
  619. package/src/inputs/ImageInput/doc.mdx +23 -0
  620. package/src/inputs/ImageInput/index.test.tsx +32 -0
  621. package/src/inputs/ImageInput/index.tsx +9 -11
  622. package/src/inputs/Input/Input.stories.js +10 -10
  623. package/src/inputs/Input/__stories__/{Default.tsx → String.tsx} +2 -2
  624. package/src/inputs/Input/__stories__/{TextWithCharacterLimit.tsx → TextWithLimit.tsx} +2 -2
  625. package/src/inputs/Input/doc.mdx +56 -0
  626. package/src/inputs/Input/index.test.tsx +56 -0
  627. package/src/inputs/Input/index.tsx +33 -30
  628. package/src/inputs/Input/inputsInputScenarios.ts +405 -0
  629. package/src/inputs/Label/Label.stories.js +1 -1
  630. package/src/inputs/Label/__stories__/Default.tsx +3 -1
  631. package/src/inputs/Label/doc.mdx +14 -0
  632. package/src/inputs/Label/index.test.tsx +20 -0
  633. package/src/inputs/Label/index.tsx +3 -7
  634. package/src/inputs/OtpInput/OtpInput.stories.js +1 -1
  635. package/src/inputs/OtpInput/{index.mdx → doc.mdx} +1 -8
  636. package/src/inputs/OtpInput/index.test.tsx +20 -0
  637. package/src/inputs/OtpInput/index.tsx +1 -1
  638. package/src/inputs/Radio/Radio.stories.js +3 -3
  639. package/src/inputs/Radio/__stories__/Conditional.tsx +2 -1
  640. package/src/inputs/Radio/{index.mdx → doc.mdx} +5 -15
  641. package/src/inputs/Radio/index.test.tsx +28 -0
  642. package/src/inputs/Radio/index.tsx +77 -8
  643. package/src/inputs/Select/Select.stories.js +1 -1
  644. package/src/inputs/Select/{index.mdx → doc.mdx} +1 -5
  645. package/src/inputs/Select/index.test.tsx +20 -0
  646. package/src/inputs/Select/index.tsx +1 -2
  647. package/src/inputs/inputsScenarios.ts +502 -0
  648. package/src/installation.mdx +2 -5
  649. package/src/internal.ts +2 -31
  650. package/src/lazy.js +25 -16
  651. package/src/locales/el.ts +3 -0
  652. package/src/registry.js +16 -2
  653. package/src/types.tsx +10 -63
  654. package/src/utils.ts +34 -33
  655. package/src/validators/index.ts +15 -70
  656. package/src/validators/utils/date.ts +107 -0
  657. package/src/validators/utils/file.ts +9 -9
  658. package/src/validators/utils/index.ts +1 -0
  659. package/src/validators/utils/phone.ts +62 -71
  660. package/src/validators/validators.spec.ts +3 -37
  661. package/types/index.js +1 -0
  662. package/types.d.ts +5 -34
  663. package/types.js.map +3 -3
  664. package/utils/index.js +34 -17
  665. package/utils.js.map +3 -3
  666. package/validators/index.js +14 -72
  667. package/validators/index.js.map +2 -2
  668. package/validators/utils/afm.js.map +1 -1
  669. package/validators/utils/date/index.js +103 -0
  670. package/validators/utils/date/package.json +6 -0
  671. package/validators/utils/date.d.ts +9 -0
  672. package/validators/utils/date.js.map +7 -0
  673. package/validators/utils/file/index.js +9 -9
  674. package/validators/utils/file.js.map +2 -2
  675. package/validators/utils/iban.js.map +1 -1
  676. package/validators/utils/image/index.js +2 -2
  677. package/validators/utils/image.js.map +1 -1
  678. package/validators/utils/index.d.ts +1 -0
  679. package/validators/utils/index.js +11 -2
  680. package/validators/utils/index.js.map +2 -2
  681. package/validators/utils/int.js.map +1 -1
  682. package/validators/utils/number.js.map +1 -1
  683. package/validators/utils/otp.js.map +1 -1
  684. package/validators/utils/phone/index.js +9 -2
  685. package/validators/utils/phone.js.map +2 -2
  686. package/validators/utils/postal_code.js.map +1 -1
  687. package/validators/utils/text_limit/index.js +2 -2
  688. package/validators/utils/text_limit.js.map +1 -1
  689. package/validators/utils/uuid4.js.map +1 -1
  690. package/Field/utils.d.ts +0 -5
  691. package/Field/utils.js.map +0 -7
  692. package/FormBuilder/FormBuilder/index.js +0 -138
  693. package/FormBuilder/FormBuilder.d.ts +0 -5
  694. package/FormBuilder/FormBuilder.js.map +0 -7
  695. package/Questions/index.spec/index.js +0 -65
  696. package/Questions/index.spec.js.map +0 -7
  697. package/cjs/Field/utils.js.map +0 -7
  698. package/cjs/FormBuilder/FormBuilder/index.js +0 -166
  699. package/cjs/FormBuilder/FormBuilder.js.map +0 -7
  700. package/cjs/Questions/index.spec/index.js +0 -83
  701. package/cjs/Questions/index.spec.js.map +0 -7
  702. package/cjs/inputs/Input/__stories__/Default/index.js +0 -52
  703. package/cjs/inputs/Input/__stories__/Default.js.map +0 -7
  704. package/cjs/inputs/Input/__stories__/TextWithCharacterLimit/index.js +0 -52
  705. package/cjs/inputs/Input/__stories__/TextWithCharacterLimit.js.map +0 -7
  706. package/cjs/validators/validators.spec/index.js +0 -104
  707. package/cjs/validators/validators.spec.js.map +0 -7
  708. package/inputs/Input/__stories__/Default/index.js +0 -25
  709. package/inputs/Input/__stories__/Default.d.ts +0 -3
  710. package/inputs/Input/__stories__/Default.js.map +0 -7
  711. package/inputs/Input/__stories__/TextWithCharacterLimit/index.js +0 -25
  712. package/inputs/Input/__stories__/TextWithCharacterLimit/package.json +0 -6
  713. package/inputs/Input/__stories__/TextWithCharacterLimit.d.ts +0 -3
  714. package/inputs/Input/__stories__/TextWithCharacterLimit.js.map +0 -7
  715. package/src/Field/utils.ts +0 -191
  716. package/src/FieldArray/FieldArray.stories.playwright.json +0 -353
  717. package/src/FormBuilder/FormBuilder.stories.playwright.json +0 -52
  718. package/src/FormBuilder/FormBuilder.tsx +0 -166
  719. package/src/MultiplicityField/MultiplicityField.stories.playwright.json +0 -1370
  720. package/src/inputs/Checkboxes/Checkboxes.stories.playwright.json +0 -85
  721. package/src/inputs/DateInput/DateInput.stories.playwright.json +0 -72
  722. package/src/inputs/FileInput/FileInput.stories.playwright.json +0 -75
  723. package/src/inputs/ImageInput/ImageInput.stories.playwright.json +0 -77
  724. package/src/inputs/ImageInput/index.mdx +0 -19
  725. package/src/inputs/Input/Input.stories.playwright.json +0 -376
  726. package/src/inputs/Input/index.mdx +0 -95
  727. package/src/inputs/Label/Label.stories.playwright.json +0 -40
  728. package/src/inputs/Label/index.mdx +0 -0
  729. package/src/inputs/Radio/Radio.stories.playwright.json +0 -73
  730. package/src/inputs/Select/Select.stories.playwright.json +0 -22
  731. package/validators/validators.spec/index.js +0 -91
  732. package/validators/validators.spec.js.map +0 -7
  733. /package/src/Field/{index.mdx → doc.mdx} +0 -0
@@ -11,6 +11,7 @@ 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';
14
15
 
15
16
  export function getYupField(field: FieldSpec, yupTypeMap: Record<string, any>) {
16
17
  const yupField = yupTypeMap[field?.type || 'string'] || yupTypeMap['string'];
@@ -4,20 +4,20 @@ import { ValidatorSchema } from '@digigov/form/validators/types';
4
4
  export type PhoneNumberType = 'landline' | 'mobile' | null;
5
5
  // add more countries from here libphonenumber-js/metadata.full.json
6
6
  const countryPhoneData = {
7
- "GR": [
8
- "30",
9
- "00",
10
- "5005000\\d{3}|8\\d{9,11}|(?:[269]\\d|70)\\d{8}",
7
+ GR: [
8
+ '30',
9
+ '00',
10
+ '5005000\\d{3}|8\\d{9,11}|(?:[269]\\d|70)\\d{8}',
11
11
  [10, 11, 12],
12
12
  [
13
- ["(\\d{2})(\\d{4})(\\d{4})", "$1 $2 $3", ["21|7"]],
13
+ ['(\\d{2})(\\d{4})(\\d{4})', '$1 $2 $3', ['21|7']],
14
14
  [
15
- "(\\d{4})(\\d{6})",
16
- "$1 $2",
17
- ["2(?:2|3[2-57-9]|4[2-469]|5[2-59]|6[2-9]|7[2-69]|8[2-49])|5"]
15
+ '(\\d{4})(\\d{6})',
16
+ '$1 $2',
17
+ ['2(?:2|3[2-57-9]|4[2-469]|5[2-59]|6[2-9]|7[2-69]|8[2-49])|5'],
18
18
  ],
19
- ["(\\d{3})(\\d{3})(\\d{4})", "$1 $2 $3", ["[2689]"]],
20
- ["(\\d{3})(\\d{3,4})(\\d{5})", "$1 $2 $3", ["8"]]
19
+ ['(\\d{3})(\\d{3})(\\d{4})', '$1 $2 $3', ['[2689]']],
20
+ ['(\\d{3})(\\d{3,4})(\\d{5})', '$1 $2 $3', ['8']],
21
21
  ],
22
22
  0,
23
23
  0,
@@ -27,93 +27,77 @@ const countryPhoneData = {
27
27
  0,
28
28
  [
29
29
  [
30
- "2(?:1\\d\\d|2(?:2[1-46-9]|[36][1-8]|4[1-7]|5[1-4]|7[1-5]|[89][1-9])|3(?:1\\d|2[1-57]|[35][1-3]|4[13]|7[1-7]|8[124-6]|9[1-79])|4(?:1\\d|2[1-8]|3[1-4]|4[13-5]|6[1-578]|9[1-5])|5(?:1\\d|[29][1-4]|3[1-5]|4[124]|5[1-6])|6(?:1\\d|[269][1-6]|3[1245]|4[1-7]|5[13-9]|7[14]|8[1-5])|7(?:1\\d|2[1-5]|3[1-6]|4[1-7]|5[1-57]|6[135]|9[125-7])|8(?:1\\d|2[1-5]|[34][1-4]|9[1-57]))\\d{6}",
31
- [10]
30
+ '2(?:1\\d\\d|2(?:2[1-46-9]|[36][1-8]|4[1-7]|5[1-4]|7[1-5]|[89][1-9])|3(?:1\\d|2[1-57]|[35][1-3]|4[13]|7[1-7]|8[124-6]|9[1-79])|4(?:1\\d|2[1-8]|3[1-4]|4[13-5]|6[1-578]|9[1-5])|5(?:1\\d|[29][1-4]|3[1-5]|4[124]|5[1-6])|6(?:1\\d|[269][1-6]|3[1245]|4[1-7]|5[13-9]|7[14]|8[1-5])|7(?:1\\d|2[1-5]|3[1-6]|4[1-7]|5[1-57]|6[135]|9[125-7])|8(?:1\\d|2[1-5]|[34][1-4]|9[1-57]))\\d{6}',
31
+ [10],
32
32
  ],
33
- ["68[57-9]\\d{7}|(?:69|94)\\d{8}", [10]],
34
- ["800\\d{7,9}"],
35
- ["90[19]\\d{7}", [10]],
36
- ["70\\d{8}", [10]],
33
+ ['68[57-9]\\d{7}|(?:69|94)\\d{8}', [10]],
34
+ ['800\\d{7,9}'],
35
+ ['90[19]\\d{7}', [10]],
36
+ ['70\\d{8}', [10]],
37
37
  0,
38
- ["5005000\\d{3}", [10]],
38
+ ['5005000\\d{3}', [10]],
39
39
  0,
40
40
  0,
41
- ["8(?:0[16]|12|[27]5|50)\\d{7}", [10]]
42
- ]
43
- ]
44
- }
41
+ ['8(?:0[16]|12|[27]5|50)\\d{7}', [10]],
42
+ ],
43
+ ],
44
+ };
45
45
 
46
46
  function expandPhoneNumberStructure(compressed) {
47
47
  const countries = Object.keys(compressed);
48
- const expanded: any = {}
48
+ const expanded: any = {};
49
49
  for (const country of countries) {
50
50
  expanded[country] = {
51
51
  fixedLine: {
52
52
  possibleLengths: {
53
- _national:
54
- compressed[country][3].map(
55
- String
56
- ),
53
+ _national: compressed[country][3].map(String),
57
54
  },
58
- nationalNumberPattern:
59
- compressed[country][11][0][0],
55
+ nationalNumberPattern: compressed[country][11][0][0],
60
56
  },
61
57
  mobile: {
62
- nationalNumberPattern:
63
- compressed[country][11][1][0],
58
+ nationalNumberPattern: compressed[country][11][1][0],
64
59
  },
65
60
  tollFree: {
66
- nationalNumberPattern:
67
- compressed[country][11][2][0],
61
+ nationalNumberPattern: compressed[country][11][2][0],
68
62
  },
69
63
  premiumRate: {
70
- nationalNumberPattern:
71
- compressed[country][11][3][0],
64
+ nationalNumberPattern: compressed[country][11][3][0],
72
65
  },
73
66
  sharedCost: {
74
- nationalNumberPattern:
75
- compressed[country][11][9][0],
67
+ nationalNumberPattern: compressed[country][11][9][0],
76
68
  },
77
69
  personalNumber: {
78
- nationalNumberPattern:
79
- compressed[country][11][4][0],
70
+ nationalNumberPattern: compressed[country][11][4][0],
80
71
  },
81
72
  uan: {
82
- nationalNumberPattern:
83
- compressed[country][11][6][0],
73
+ nationalNumberPattern: compressed[country][11][6][0],
84
74
  },
85
75
  id: country,
86
- countryCode:
87
- compressed[country][0],
88
- internationalPrefix:
89
- compressed[country][1],
90
-
91
- }
76
+ countryCode: compressed[country][0],
77
+ internationalPrefix: compressed[country][1],
78
+ };
92
79
  }
93
80
  return expanded;
94
81
  }
95
82
  const PHONENUMBER_SPEC = expandPhoneNumberStructure(countryPhoneData);
96
- export function discoverPhoneType(
97
- phoneNumber: string,
98
- config: any
99
- ): string {
83
+ export function discoverPhoneType(phoneNumber: string, config: any): string {
100
84
  const cleanNumber = phoneNumber
101
- .replace(/\D/g, "")
102
- .replace(/\s/g, "")
103
- .replace(/^\+/, "")
104
- .replace(new RegExp("^" + config.internationalPrefix, ""), "")
105
- .replace(new RegExp("^" + config.countryCode, ""), "");
85
+ .replace(/\D/g, '')
86
+ .replace(/\s/g, '')
87
+ .replace(/^\+/, '')
88
+ .replace(new RegExp('^' + config.internationalPrefix, ''), '')
89
+ .replace(new RegExp('^' + config.countryCode, ''), '');
106
90
  const categories = {
107
- "landline": config.fixedLine,
91
+ landline: config.fixedLine,
108
92
  mobile: config.mobile,
109
- "toll-free": config.tollFree,
110
- "premium-rate": config.premiumRate,
93
+ 'toll-free': config.tollFree,
94
+ 'premium-rate': config.premiumRate,
111
95
  };
112
96
 
113
97
  for (const [categoryName, categoryDetails] of Object.entries(categories)) {
114
98
  const pattern = new RegExp(
115
- "^(" + categoryDetails.nationalNumberPattern.replace(/\s/g, "") + ")$",
116
- ""
99
+ '^(' + categoryDetails.nationalNumberPattern.replace(/\s/g, '') + ')$',
100
+ ''
117
101
  );
118
102
  if (cleanNumber.match(pattern)) {
119
103
  return categoryName; // Returns the category name if the number matches the pattern
@@ -121,32 +105,36 @@ export function discoverPhoneType(
121
105
  }
122
106
 
123
107
  // If no category matches, return 'Unknown'
124
- return "unknown";
108
+ return 'unknown';
125
109
  }
126
110
  function getNumberType(phoneNumber: string, country: string) {
127
111
  const spec = PHONENUMBER_SPEC[country.toUpperCase()];
128
- if(!spec) {
112
+ if (!spec) {
129
113
  throw new Error(`Country ${country} is not supported`);
130
114
  }
131
115
  const type = discoverPhoneType(phoneNumber, spec);
132
116
  return type;
133
117
  }
134
118
 
135
- function isPhoneNumberValid(phoneNumber: string, countries: string[], types=['mobile', 'landline']) {
119
+ function isPhoneNumberValid(
120
+ phoneNumber: string,
121
+ countries: string[],
122
+ types = ['mobile', 'landline']
123
+ ) {
136
124
  return countries.some((country) => {
137
125
  const numberType = getNumberType(phoneNumber, country);
138
126
  if (numberType && types.includes(numberType)) {
139
- return true
127
+ return true;
140
128
  }
141
- return false
142
- })
129
+ return false;
130
+ });
143
131
  }
144
132
  function isNumberOfType(phoneNumber: string, country: string, type: string) {
145
133
  const numberType = getNumberType(phoneNumber, country);
146
134
  if (numberType === type) {
147
- return true
135
+ return true;
148
136
  }
149
- return false
137
+ return false;
150
138
  }
151
139
  export function validatePhoneNumber(
152
140
  phoneNumber: string,
@@ -156,12 +144,15 @@ export function validatePhoneNumber(
156
144
  if (!countries || countries.length === 0) {
157
145
  return true;
158
146
  }
159
- return isPhoneNumberValid(phoneNumber, countries, typeOfPhoneNumber? [typeOfPhoneNumber] : undefined);
147
+ return isPhoneNumberValid(
148
+ phoneNumber,
149
+ countries,
150
+ typeOfPhoneNumber ? [typeOfPhoneNumber] : undefined
151
+ );
160
152
  }
161
153
 
162
-
163
154
  function validateMobile(value): boolean {
164
- return isNumberOfType(value, 'gr','mobile');
155
+ return isNumberOfType(value, 'gr', 'mobile');
165
156
  }
166
157
 
167
158
  export const MOBILE_PHONE_VALIDATOR = {
@@ -69,54 +69,20 @@ it('validates phone number type landline with greek country code', () => {
69
69
  expect(validatePhoneNumber('2102934896', ['GR'], 'landline')).toBe(true);
70
70
  });
71
71
 
72
- it('validates phone number type landline with ch country code', () => {
73
- expect(validatePhoneNumber('2102934896', ['CH'], 'landline')).toBe(false);
74
- });
75
-
76
- it('validates phone number type landline with ch and gr countries code', () => {
77
- expect(validatePhoneNumber('2102934896', ['GR', 'CH'], 'landline')).toBe(
78
- true
79
- );
80
- });
81
-
82
- it('validatesphone number type landline with ch and gr countries code', () => {
83
- expect(validatePhoneNumber('41446681800', ['GR', 'CH'], 'landline')).toBe(
84
- true
72
+ it('throws if given country is not supported', () => {
73
+ expect(() => validatePhoneNumber('2102934896', ['CH'], 'landline')).toThrow(
74
+ 'Country CH is not supported'
85
75
  );
86
76
  });
87
77
 
88
- it('validates phone number type landline with ch and gr countries code but phone number is mobile', () => {
89
- expect(validatePhoneNumber('2102934896', ['GR', 'CH'], 'mobile')).toBe(false);
90
- });
91
-
92
- it('validates phone number type mobile with ch and gr countries code', () => {
93
- expect(validatePhoneNumber('6934100982', ['GR', 'CH'], 'mobile')).toBe(true);
94
- });
95
-
96
78
  it('validates phone number type mobile with gr country code', () => {
97
79
  expect(validatePhoneNumber('6934100982', ['GR'], 'mobile')).toBe(true);
98
80
  });
99
81
 
100
- it('validates phone number type mobile with ch country code', () => {
101
- expect(validatePhoneNumber('6934100982', ['CH'], 'mobile')).toBe(false);
102
- });
103
-
104
- it('validates phone number with no type and ch country code', () => {
105
- expect(validatePhoneNumber('6934100982', ['CH'], null)).toBe(false);
106
- });
107
-
108
82
  it('validates phone number with no type and gr country code', () => {
109
83
  expect(validatePhoneNumber('6934100982', ['gr'], null)).toBe(true);
110
84
  });
111
85
 
112
- it('validates phone number with no type and ch country code', () => {
113
- expect(validatePhoneNumber('41446681800', ['CH'], null)).toBe(true);
114
- });
115
-
116
86
  it('validates phone number with no type and gr country code', () => {
117
87
  expect(validatePhoneNumber('41446681800', ['gr'], null)).toBe(false);
118
88
  });
119
-
120
- it('validates phone number with no type and gr and ch countries code', () => {
121
- expect(validatePhoneNumber('41446681800', ['gr', 'ch'], null)).toBe(true);
122
- });
package/types/index.js CHANGED
@@ -1 +1,2 @@
1
+ export * from "@digigov/form/Field/types";
1
2
  //# sourceMappingURL=types.js.map
package/types.d.ts CHANGED
@@ -1,48 +1,16 @@
1
- /// <reference types="react" />
2
1
  import { UseFormReturn, UseFormProps } from 'react-hook-form';
3
- import { FieldComponentRegistry } from '@digigov/form/Field/types';
2
+ import { FieldComponentRegistry, FieldLabelProps, FieldSpec, FormData } from '@digigov/form/Field/types';
4
3
  import { ValidatorSchema } from '@digigov/form/validators/types';
5
- import { GridProps } from '@digigov/ui/layouts/Grid';
4
+ export * from '@digigov/form/Field/types';
6
5
  export type FieldError = {
7
6
  message: string;
8
7
  };
9
- export type FieldLabelProps = {
10
- primary?: string;
11
- secondary?: string;
12
- };
13
- export interface FieldCondition {
14
- is: string | string[] | number | number[] | boolean | boolean[];
15
- then?: Partial<FieldSpec>;
16
- else?: Partial<FieldSpec>;
17
- }
18
- export interface FieldSpec {
19
- key: string;
20
- type?: 'int' | 'string' | 'text' | 'boolean' | 'email' | 'uuid4' | 'choice:multiple' | 'choice:single' | 'mobile_phone' | 'date' | 'otp' | 'afm' | 'iban' | 'file' | 'image' | 'postal_code' | 'phone_number' | 'array' | 'object';
21
- component?: any;
22
- maxLength?: number;
23
- condition?: Record<string, FieldCondition>;
24
- controlled?: boolean;
25
- label?: FieldLabelProps;
26
- extra?: {
27
- [key: string]: any;
28
- };
29
- editable?: boolean;
30
- required?: boolean;
31
- enabled?: boolean;
32
- layout?: Record<string, GridProps['xs'] | GridProps['sm'] | GridProps['md'] | GridProps['lg'] | GridProps['xl']>;
33
- validators?: ValidatorSchema[];
34
- wrapper?: 'label' | 'fieldset';
35
- maxWidth?: string;
36
- maxHeight?: string;
37
- width?: string;
38
- }
39
8
  export interface FieldsetSpec {
40
9
  key: string;
41
10
  fields: string[];
42
11
  label?: FieldLabelProps;
43
12
  body?: React.ReactNode;
44
13
  }
45
- export type FormData = UseFormProps['defaultValues'];
46
14
  export interface FormContextProps {
47
15
  fieldsetsMap?: Record<string, FieldsetSpec>;
48
16
  fieldsMap: Record<string, FieldSpec>;
@@ -57,9 +25,11 @@ export interface FormContextProps {
57
25
  unregister: UseFormReturn['unregister'];
58
26
  formState: UseFormReturn['formState'];
59
27
  reset: UseFormReturn['reset'];
28
+ resetField: UseFormReturn['resetField'];
60
29
  registerField: (field: FieldSpec) => void;
61
30
  errors: UseFormReturn['formState']['errors'];
62
31
  componentRegistry?: FieldComponentRegistry;
32
+ submit: () => Promise<void>;
63
33
  }
64
34
  export interface FormBuilderProps {
65
35
  fields?: FieldSpec[];
@@ -75,6 +45,7 @@ export interface FormBuilderProps {
75
45
  validatorRegistry?: Record<string, ValidatorSchema[]>;
76
46
  componentRegistry?: FieldComponentRegistry;
77
47
  grid?: boolean;
48
+ controlledFieldsOnly?: boolean;
78
49
  }
79
50
  export interface FormBaseProps extends Omit<FormBuilderProps, 'fields' | 'fieldsets' | 'auto'> {
80
51
  fieldsetsMap?: Record<string, FieldsetSpec>;
package/types.js.map CHANGED
@@ -1,7 +1,7 @@
1
1
  {
2
2
  "version": 3,
3
- "sources": [],
4
- "sourcesContent": [],
5
- "mappings": "",
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"],
5
+ "mappings": "AAQA,cAAc;",
6
6
  "names": []
7
7
  }
package/utils/index.js CHANGED
@@ -1,25 +1,39 @@
1
- import {validateFieldsNatively} from "@hookform/resolvers";
2
- import {appendErrors} from "react-hook-form";
1
+ import { validateFieldsNatively } from "@hookform/resolvers";
2
+ import { appendErrors } from "react-hook-form";
3
3
  const parseErrorSchema = (error, validateAllFieldCriteria) => {
4
- return (error.inner || []).reduce((previous, error2) => {
5
- error2.path = error2.path?.replace(/\[([0-9]+)\]/g, ".$1");
6
- if (!previous[error2.path]) {
7
- previous[error2.path] = {message: error2.message, type: error2.type};
8
- }
9
- if (validateAllFieldCriteria) {
10
- const types = previous[error2.path].types;
11
- const messages = types && types[error2.type];
12
- previous[error2.path] = appendErrors(error2.path, validateAllFieldCriteria, previous, error2.type, messages ? [].concat(messages, error2.message) : error2.message);
13
- }
14
- return previous;
15
- }, {});
4
+ return (error.inner || []).reduce(
5
+ (previous, error2) => {
6
+ error2.path = error2.path?.replace(/\[([0-9]+)\]/g, ".$1");
7
+ if (!previous[error2.path]) {
8
+ previous[error2.path] = { message: error2.message, type: error2.type };
9
+ }
10
+ if (validateAllFieldCriteria) {
11
+ const types = previous[error2.path].types;
12
+ const messages = types && types[error2.type];
13
+ previous[error2.path] = appendErrors(
14
+ error2.path,
15
+ validateAllFieldCriteria,
16
+ previous,
17
+ error2.type,
18
+ messages ? [].concat(messages, error2.message) : error2.message
19
+ );
20
+ }
21
+ return previous;
22
+ },
23
+ {}
24
+ );
16
25
  };
17
26
  const yupResolver = (schema, schemaOptions = {}, resolverOptions = {}) => async (values, context, options) => {
18
27
  try {
19
28
  if (schemaOptions.context && process.env.NODE_ENV === "development") {
20
- console.warn("You should not used the yup options context. Please, use the 'useForm' context object instead");
29
+ console.warn(
30
+ "You should not used the yup options context. Please, use the 'useForm' context object instead"
31
+ );
21
32
  }
22
- const result = await schema[resolverOptions.mode === "sync" ? "validateSync" : "validate"](values, Object.assign({abortEarly: false}, schemaOptions, {context}));
33
+ const result = await schema[resolverOptions.mode === "sync" ? "validateSync" : "validate"](
34
+ values,
35
+ Object.assign({ abortEarly: false }, schemaOptions, { context })
36
+ );
23
37
  options.shouldUseNativeValidation && validateFieldsNatively({}, options);
24
38
  return {
25
39
  values: resolverOptions.rawValues ? values : result,
@@ -29,7 +43,10 @@ const yupResolver = (schema, schemaOptions = {}, resolverOptions = {}) => async
29
43
  if (!e.inner) {
30
44
  throw e;
31
45
  }
32
- const parsed = parseErrorSchema(e, !options.shouldUseNativeValidation && options.criteriaMode === "all");
46
+ const parsed = parseErrorSchema(
47
+ e,
48
+ !options.shouldUseNativeValidation && options.criteriaMode === "all"
49
+ );
33
50
  return {
34
51
  values: {},
35
52
  errors: parsed
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,\n schemaOptions: any = {},\n 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 ](values, Object.assign({ abortEarly: false }, schemaOptions, { context }));\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;AACA;AAOA,MAAM,mBAAmB,CACvB,OACA,6BACG;AACH,SAAQ,OAAM,SAAS,IAAI,OACzB,CAAC,UAAU,WAAU;AACnB,WAAM,OAAO,OAAM,MAAM,QAAQ,iBAAiB;AAClD,QAAI,CAAC,SAAS,OAAM,OAAQ;AAC1B,eAAS,OAAM,QAAS,CAAE,SAAS,OAAM,SAAS,MAAM,OAAM;AAAA;AAGhE,QAAI,0BAA0B;AAC5B,YAAM,QAAQ,SAAS,OAAM,MAAO;AACpC,YAAM,WAAW,SAAS,MAAM,OAAM;AAEtC,eAAS,OAAM,QAAS,aACtB,OAAM,MACN,0BACA,UACA,OAAM,MACN,WACK,GAAgB,OAAO,UAAsB,OAAM,WACpD,OAAM;AAAA;AAId,WAAO;AAAA,KAET;AAAA;AAIG,MAAM,cAAc,CACzB,QACA,gBAAqB,IACrB,kBAAuB,OACpB,OAAO,QAAQ,SAAS,YAAY;AACvC,MAAI;AACF,QAAI,cAAc,WAAW,QAAQ,IAAI,aAAa,eAAe;AAEnE,cAAQ,KACN;AAAA;AAIJ,UAAM,SAAS,MAAM,OACnB,gBAAgB,SAAS,SAAS,iBAAiB,YACnD,QAAQ,OAAO,OAAO,CAAE,YAAY,QAAS,eAAe,CAAE;AAEhE,YAAQ,6BAA6B,uBAAuB,IAAI;AAEhE,WAAO;AAAA,MACL,QAAQ,gBAAgB,YAAY,SAAS;AAAA,MAC7C,QAAQ;AAAA;AAAA,WAEH,GAAP;AACA,QAAI,CAAC,EAAE,OAAO;AACZ,YAAM;AAAA;AAGR,UAAM,SAAS,iBACb,GACA,CAAC,QAAQ,6BAA6B,QAAQ,iBAAiB;AAEjE,WAAO;AAAA,MACL,QAAQ;AAAA,MACR,QAAQ;AAAA;AAAA;AAAA;",
6
- "names": []
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;",
6
+ "names": ["error"]
7
7
  }
@@ -1,6 +1,4 @@
1
- import {useMemo} from "react";
2
- import dayjs from "dayjs";
3
- import customParseFormat from "dayjs/plugin/customParseFormat";
1
+ import { useMemo } from "react";
4
2
  import * as yup from "yup";
5
3
  import {
6
4
  getYupObjectShape,
@@ -13,16 +11,13 @@ import {
13
11
  TEXT_LIMIT_VALIDATOR,
14
12
  POSTALCODE_VALIDATOR,
15
13
  UUID4_VALIDATOR,
16
- IMAGE_DIMENSION_VALIDATOR
14
+ IMAGE_DIMENSION_VALIDATOR,
15
+ DATE_VALIDATOR,
16
+ LATER_THAN_VALIDATOR,
17
+ EARLIER_THAN_VALIDATOR
17
18
  } from "@digigov/form/validators/utils";
18
- import {INT_VALIDATOR} from "@digigov/form/validators/utils/int";
19
- import {NUMBER_VALIDATOR} from "@digigov/form/validators/utils/number";
20
- dayjs.extend(customParseFormat);
21
- const VALID_DATE_FORMATS = ["DD/MM/YYYY"];
22
- const DATE_CACHE = {};
23
- const getDate = (v) => {
24
- return DATE_CACHE[v] ? DATE_CACHE[v] : dayjs(v, VALID_DATE_FORMATS, true);
25
- };
19
+ import { INT_VALIDATOR } from "@digigov/form/validators/utils/int";
20
+ import { NUMBER_VALIDATOR } from "@digigov/form/validators/utils/number";
26
21
  const getYUPTypeMap = () => {
27
22
  const yupTypeMap = {
28
23
  file: (field) => {
@@ -69,6 +64,7 @@ const getYUPTypeMap = () => {
69
64
  return yup.array().of(yup.string());
70
65
  }
71
66
  },
67
+ number: () => yup.mixed().transform((_, val) => val !== "" ? Number(val) : null).test(NUMBER_VALIDATOR()),
72
68
  int: () => yup.mixed().transform((_, val) => val !== "" ? Number(val) : null).test(NUMBER_VALIDATOR()).test(INT_VALIDATOR()),
73
69
  email: () => yup.string().email("form.error.email"),
74
70
  afm: () => yup.string().test(AFM_VALIDATOR),
@@ -96,68 +92,14 @@ const getYUPTypeMap = () => {
96
92
  "choice:multiple": () => yup.array().of(yup.string()).nullable(),
97
93
  "choice:single": () => yup.string().nullable(),
98
94
  date: (field) => {
99
- let simpleDate = yup.string().nullable(true).test("date", "form.error.date.invalid", function(value) {
100
- if (!value)
101
- return true;
102
- const date = getDate(value);
103
- return date.isValid();
104
- });
105
- const params = field.extra || {};
106
- if (params.max) {
107
- let maxDate;
108
- if (params.max === "now") {
109
- const today = new Date();
110
- maxDate = new Date(today);
111
- } else {
112
- maxDate = getDate(params.max).toDate();
113
- }
114
- const maxNextDate = new Date(maxDate);
115
- maxNextDate.setDate(maxDate.getDate() + 1);
116
- simpleDate = simpleDate.test({
117
- name: "earlier-than",
118
- message: {
119
- key: "form.error.date.earlier_than",
120
- context: {
121
- maxDate: maxNextDate.toLocaleDateString()
122
- }
123
- },
124
- test: function(value) {
125
- if (!value)
126
- return true;
127
- const date = getDate(value);
128
- const isValid = +date.toDate() < +maxDate;
129
- return isValid;
130
- }
131
- });
95
+ if (field?.extra?.min) {
96
+ return yup.string().test(LATER_THAN_VALIDATOR(field));
132
97
  }
133
- if (params.min) {
134
- let minDate;
135
- if (params.min === "now") {
136
- const today = new Date();
137
- minDate = new Date(today);
138
- } else {
139
- minDate = getDate(params.min).toDate();
140
- }
141
- const minPreviousDate = new Date(minDate);
142
- minPreviousDate.setDate(minDate.getDate() - 1);
143
- simpleDate = simpleDate.test({
144
- name: "later-than",
145
- message: {
146
- key: "form.error.date.later_than",
147
- context: {
148
- minDate: minPreviousDate.toLocaleDateString()
149
- }
150
- },
151
- test: function(value) {
152
- if (!value)
153
- return true;
154
- const date = getDate(value);
155
- const isValid = +date.toDate() > +minDate;
156
- return isValid;
157
- }
158
- });
98
+ if (field?.extra?.max) {
99
+ return yup.string().test(EARLIER_THAN_VALIDATOR(field));
100
+ } else {
101
+ return yup.string().test(DATE_VALIDATOR);
159
102
  }
160
- return simpleDate;
161
103
  }
162
104
  };
163
105
  return yupTypeMap;