@digigov/form 2.0.0-7d9a8d86 → 2.0.0-85c27c19

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 (688) hide show
  1. package/Field/FieldBase/index.js +72 -51
  2. package/Field/FieldBase.js.map +2 -2
  3. package/Field/FieldBaseContainer/index.js +4 -18
  4. package/Field/FieldBaseContainer.js.map +1 -1
  5. package/Field/FieldConditional/index.js +55 -40
  6. package/Field/FieldConditional.js.map +2 -2
  7. package/Field/index.js +67 -36
  8. package/Field/index.js.map +2 -2
  9. package/Field/types.d.ts +36 -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 +3 -0
  19. package/Field/utils/index.js +4 -95
  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.js +50 -32
  35. package/FieldArray/index.js.map +2 -2
  36. package/FieldArray/index.test.d.ts +1 -0
  37. package/FieldObject/index.d.ts +1 -0
  38. package/FieldObject/index.js +41 -29
  39. package/FieldObject/index.js.map +2 -2
  40. package/Fieldset/FieldsetWithContext/index.js +12 -13
  41. package/Fieldset/FieldsetWithContext.js.map +1 -1
  42. package/Fieldset/index.js +4 -13
  43. package/Fieldset/index.js.map +1 -1
  44. package/Fieldset/types.d.ts +2 -0
  45. package/Form.stories.js.map +1 -1
  46. package/FormBuilder/FormBuilder.stories/index.js +2 -1
  47. package/FormBuilder/FormBuilder.stories.d.ts +1 -1
  48. package/FormBuilder/FormBuilder.stories.js.map +2 -2
  49. package/FormBuilder/__stories__/Default/index.js +21 -15
  50. package/FormBuilder/__stories__/Default.d.ts +2 -2
  51. package/FormBuilder/__stories__/Default.js.map +1 -1
  52. package/FormBuilder/index.d.ts +2 -1
  53. package/FormBuilder/index.js +10 -2
  54. package/FormBuilder/index.js.map +2 -2
  55. package/FormBuilder/index.test.d.ts +1 -0
  56. package/FormBuilder/scenarios.test.d.ts +88 -0
  57. package/FormContext/index.js +1 -1
  58. package/FormContext.js.map +1 -1
  59. package/MultiplicityField/MultiplicityField.stories/index.js +12 -6
  60. package/MultiplicityField/MultiplicityField.stories.d.ts +6 -6
  61. package/MultiplicityField/MultiplicityField.stories.js.map +2 -2
  62. package/MultiplicityField/__stories__/Default/index.js +15 -19
  63. package/MultiplicityField/__stories__/Default.d.ts +2 -2
  64. package/MultiplicityField/__stories__/Default.js.map +1 -1
  65. package/MultiplicityField/__stories__/PreviewDisplay/index.js +6 -27
  66. package/MultiplicityField/__stories__/PreviewDisplay.d.ts +2 -2
  67. package/MultiplicityField/__stories__/PreviewDisplay.js.map +2 -2
  68. package/MultiplicityField/__stories__/WithExactLength/index.js +15 -19
  69. package/MultiplicityField/__stories__/WithExactLength.d.ts +2 -2
  70. package/MultiplicityField/__stories__/WithExactLength.js.map +2 -2
  71. package/MultiplicityField/__stories__/WithMaxLength/index.js +15 -19
  72. package/MultiplicityField/__stories__/WithMaxLength.d.ts +2 -2
  73. package/MultiplicityField/__stories__/WithMaxLength.js.map +2 -2
  74. package/MultiplicityField/__stories__/WithMinAndMaxLength/index.js +15 -19
  75. package/MultiplicityField/__stories__/WithMinAndMaxLength.d.ts +2 -2
  76. package/MultiplicityField/__stories__/WithMinAndMaxLength.js.map +2 -2
  77. package/MultiplicityField/__stories__/WithMinLength/index.js +15 -19
  78. package/MultiplicityField/__stories__/WithMinLength.d.ts +2 -2
  79. package/MultiplicityField/__stories__/WithMinLength.js.map +2 -2
  80. package/MultiplicityField/add-objects/index.js +71 -39
  81. package/MultiplicityField/add-objects.d.ts +2 -1
  82. package/MultiplicityField/add-objects.js.map +2 -2
  83. package/MultiplicityField/index.d.ts +2 -19
  84. package/MultiplicityField/index.js +66 -59
  85. package/MultiplicityField/index.js.map +2 -2
  86. package/MultiplicityField/index.test.d.ts +1 -0
  87. package/MultiplicityField/types/index.js +1 -0
  88. package/{validators/validators.spec → MultiplicityField/types}/package.json +1 -1
  89. package/MultiplicityField/types.d.ts +19 -0
  90. package/MultiplicityField/types.js.map +7 -0
  91. package/Questions/Questions/index.js +21 -15
  92. package/Questions/Questions.js.map +2 -2
  93. package/Questions/Questions.stories/index.js +2 -1
  94. package/Questions/Questions.stories.d.ts +1 -1
  95. package/Questions/Questions.stories.js.map +2 -2
  96. package/Questions/QuestionsContext/index.js +2 -2
  97. package/Questions/QuestionsContext.js.map +1 -1
  98. package/Questions/Step/ReviewStep/index.js +20 -26
  99. package/Questions/Step/ReviewStep.js.map +1 -1
  100. package/Questions/Step/Step/index.js +24 -18
  101. package/Questions/Step/Step.js.map +2 -2
  102. package/Questions/Step/StepArrayReview/index.js +20 -25
  103. package/Questions/Step/StepArrayReview.js.map +1 -1
  104. package/Questions/Step/StepContext/index.js +3 -3
  105. package/Questions/Step/StepContext.js.map +1 -1
  106. package/Questions/Step/StepDescription/index.js +7 -12
  107. package/Questions/Step/StepDescription.js.map +1 -1
  108. package/Questions/Step/StepForm/index.js +16 -19
  109. package/Questions/Step/StepForm.js.map +1 -1
  110. package/Questions/Step/StepQuote/index.js +2 -4
  111. package/Questions/Step/StepQuote.js.map +1 -1
  112. package/Questions/Step/StepTitle/index.js +17 -15
  113. package/Questions/Step/StepTitle.d.ts +1 -0
  114. package/Questions/Step/StepTitle.js.map +2 -2
  115. package/Questions/Step/getAddMoreFields.js.map +1 -1
  116. package/Questions/Step/index.d.ts +0 -1
  117. package/Questions/Step/index.js +0 -1
  118. package/Questions/Step/index.js.map +2 -2
  119. package/Questions/Step/types.d.ts +2 -0
  120. package/Questions/__stories__/Default/index.js +31 -38
  121. package/Questions/__stories__/Default.d.ts +2 -2
  122. package/Questions/__stories__/Default.js.map +1 -1
  123. package/Questions/getNextStep/index.js +3 -1
  124. package/Questions/getNextStep.js.map +1 -1
  125. package/Questions/index.js +1 -1
  126. package/Questions/index.js.map +1 -1
  127. package/Questions/index.test.d.ts +1 -0
  128. package/Questions/types.d.ts +2 -0
  129. package/cjs/Field/FieldBase/index.js +95 -68
  130. package/cjs/Field/FieldBase.js.map +3 -3
  131. package/cjs/Field/FieldBaseContainer/index.js +33 -41
  132. package/cjs/Field/FieldBaseContainer.js.map +2 -2
  133. package/cjs/Field/FieldConditional/index.js +77 -56
  134. package/cjs/Field/FieldConditional.js.map +3 -3
  135. package/cjs/Field/index.js +89 -55
  136. package/cjs/Field/index.js.map +3 -3
  137. package/cjs/Field/types/index.js +14 -2
  138. package/cjs/Field/types.js.map +2 -2
  139. package/cjs/Field/utils/calculateField/index.js +50 -0
  140. package/cjs/Field/utils/calculateField.js.map +7 -0
  141. package/cjs/Field/utils/evaluateFieldWithConditions/index.js +49 -0
  142. package/cjs/Field/utils/evaluateFieldWithConditions.js.map +7 -0
  143. package/cjs/Field/utils/index.js +35 -121
  144. package/cjs/Field/utils/index.js.map +7 -0
  145. package/cjs/Field/utils/useField/index.js +74 -0
  146. package/cjs/Field/utils/useField.js.map +7 -0
  147. package/cjs/FieldArray/FieldArray.stories/index.js +30 -19
  148. package/cjs/FieldArray/FieldArray.stories.js.map +3 -3
  149. package/cjs/FieldArray/__stories__/Default/index.js +37 -33
  150. package/cjs/FieldArray/__stories__/Default.js.map +2 -2
  151. package/cjs/FieldArray/__stories__/WithExactLength/index.js +37 -33
  152. package/cjs/FieldArray/__stories__/WithExactLength.js.map +2 -2
  153. package/cjs/FieldArray/index.js +75 -51
  154. package/cjs/FieldArray/index.js.map +3 -3
  155. package/cjs/FieldObject/index.js +59 -44
  156. package/cjs/FieldObject/index.js.map +3 -3
  157. package/cjs/Fieldset/FieldsetWithContext/index.js +35 -30
  158. package/cjs/Fieldset/FieldsetWithContext.js.map +2 -2
  159. package/cjs/Fieldset/index.js +31 -34
  160. package/cjs/Fieldset/index.js.map +2 -2
  161. package/cjs/Fieldset/types/index.js +14 -2
  162. package/cjs/Fieldset/types.js.map +2 -2
  163. package/cjs/Form.stories/index.js +16 -6
  164. package/cjs/Form.stories.js.map +1 -1
  165. package/cjs/FormBuilder/FormBuilder.stories/index.js +27 -18
  166. package/cjs/FormBuilder/FormBuilder.stories.js.map +3 -3
  167. package/cjs/FormBuilder/__stories__/Default/index.js +43 -31
  168. package/cjs/FormBuilder/__stories__/Default.js.map +2 -2
  169. package/cjs/FormBuilder/index.js +24 -21
  170. package/cjs/FormBuilder/index.js.map +2 -2
  171. package/cjs/FormContext/index.js +14 -18
  172. package/cjs/FormContext.js.map +2 -2
  173. package/cjs/MultiplicityField/MultiplicityField.stories/index.js +42 -23
  174. package/cjs/MultiplicityField/MultiplicityField.stories.js.map +3 -3
  175. package/cjs/MultiplicityField/__stories__/Default/index.js +37 -35
  176. package/cjs/MultiplicityField/__stories__/Default.js.map +2 -2
  177. package/cjs/MultiplicityField/__stories__/PreviewDisplay/index.js +32 -47
  178. package/cjs/MultiplicityField/__stories__/PreviewDisplay.js.map +3 -3
  179. package/cjs/MultiplicityField/__stories__/WithExactLength/index.js +37 -35
  180. package/cjs/MultiplicityField/__stories__/WithExactLength.js.map +3 -3
  181. package/cjs/MultiplicityField/__stories__/WithMaxLength/index.js +37 -35
  182. package/cjs/MultiplicityField/__stories__/WithMaxLength.js.map +3 -3
  183. package/cjs/MultiplicityField/__stories__/WithMinAndMaxLength/index.js +37 -35
  184. package/cjs/MultiplicityField/__stories__/WithMinAndMaxLength.js.map +3 -3
  185. package/cjs/MultiplicityField/__stories__/WithMinLength/index.js +37 -35
  186. package/cjs/MultiplicityField/__stories__/WithMinLength.js.map +3 -3
  187. package/cjs/MultiplicityField/add-objects/index.js +94 -59
  188. package/cjs/MultiplicityField/add-objects.js.map +3 -3
  189. package/cjs/MultiplicityField/index.js +90 -77
  190. package/cjs/MultiplicityField/index.js.map +3 -3
  191. package/cjs/MultiplicityField/types/index.js +16 -0
  192. package/cjs/MultiplicityField/types.js.map +7 -0
  193. package/cjs/Questions/Questions/index.js +42 -30
  194. package/cjs/Questions/Questions.js.map +2 -2
  195. package/cjs/Questions/Questions.stories/index.js +27 -18
  196. package/cjs/Questions/Questions.stories.js.map +3 -3
  197. package/cjs/Questions/QuestionsContext/index.js +15 -19
  198. package/cjs/Questions/QuestionsContext.js.map +1 -1
  199. package/cjs/Questions/Step/ReviewStep/index.js +43 -43
  200. package/cjs/Questions/Step/ReviewStep.js.map +2 -2
  201. package/cjs/Questions/Step/Step/index.js +45 -33
  202. package/cjs/Questions/Step/Step.js.map +2 -2
  203. package/cjs/Questions/Step/StepArrayReview/index.js +46 -45
  204. package/cjs/Questions/Step/StepArrayReview.js.map +2 -2
  205. package/cjs/Questions/Step/StepContext/index.js +16 -20
  206. package/cjs/Questions/Step/StepContext.js.map +1 -1
  207. package/cjs/Questions/Step/StepDescription/index.js +29 -28
  208. package/cjs/Questions/Step/StepDescription.js.map +2 -2
  209. package/cjs/Questions/Step/StepForm/index.js +41 -38
  210. package/cjs/Questions/Step/StepForm.js.map +2 -2
  211. package/cjs/Questions/Step/StepQuote/index.js +25 -21
  212. package/cjs/Questions/Step/StepQuote.js.map +2 -2
  213. package/cjs/Questions/Step/StepTitle/index.js +41 -33
  214. package/cjs/Questions/Step/StepTitle.js.map +3 -3
  215. package/cjs/Questions/Step/getAddMoreFields/index.js +16 -4
  216. package/cjs/Questions/Step/getAddMoreFields.js.map +1 -1
  217. package/cjs/Questions/Step/index.js +45 -28
  218. package/cjs/Questions/Step/index.js.map +3 -3
  219. package/cjs/Questions/Step/types/index.js +14 -2
  220. package/cjs/Questions/Step/types.js.map +2 -2
  221. package/cjs/Questions/__stories__/Default/index.js +59 -60
  222. package/cjs/Questions/__stories__/Default.js.map +2 -2
  223. package/cjs/Questions/getNextStep/index.js +19 -5
  224. package/cjs/Questions/getNextStep.js.map +1 -1
  225. package/cjs/Questions/index.js +19 -20
  226. package/cjs/Questions/index.js.map +1 -1
  227. package/cjs/Questions/types/index.js +14 -2
  228. package/cjs/Questions/types.js.map +2 -2
  229. package/cjs/index.js +180 -19
  230. package/cjs/index.js.map +4 -4
  231. package/cjs/inputs/AutoCompleteInput/AutoComplete.stories/index.js +30 -19
  232. package/cjs/inputs/AutoCompleteInput/AutoComplete.stories.js.map +3 -3
  233. package/cjs/inputs/AutoCompleteInput/__stories__/Default/index.js +46 -36
  234. package/cjs/inputs/AutoCompleteInput/__stories__/Default.js.map +3 -3
  235. package/cjs/inputs/AutoCompleteInput/__stories__/Multiple/index.js +50 -38
  236. package/cjs/inputs/AutoCompleteInput/__stories__/Multiple.js.map +3 -3
  237. package/cjs/inputs/AutoCompleteInput/index.js +67 -42
  238. package/cjs/inputs/AutoCompleteInput/index.js.map +3 -3
  239. package/cjs/inputs/Checkboxes/Checkboxes.stories/index.js +33 -20
  240. package/cjs/inputs/Checkboxes/Checkboxes.stories.js.map +3 -3
  241. package/cjs/inputs/Checkboxes/__stories__/Conditional/index.js +35 -29
  242. package/cjs/inputs/Checkboxes/__stories__/Conditional.js.map +2 -2
  243. package/cjs/inputs/Checkboxes/__stories__/Default/index.js +58 -46
  244. package/cjs/inputs/Checkboxes/__stories__/Default.js.map +2 -2
  245. package/cjs/inputs/Checkboxes/__stories__/WithDivider/index.js +59 -47
  246. package/cjs/inputs/Checkboxes/__stories__/WithDivider.js.map +2 -2
  247. package/cjs/inputs/Checkboxes/index.js +70 -62
  248. package/cjs/inputs/Checkboxes/index.js.map +3 -3
  249. package/cjs/inputs/DateInput/DateInput.stories/index.js +27 -18
  250. package/cjs/inputs/DateInput/DateInput.stories.js.map +3 -3
  251. package/cjs/inputs/DateInput/__stories__/Default/index.js +41 -32
  252. package/cjs/inputs/DateInput/__stories__/Default.js.map +3 -3
  253. package/cjs/inputs/DateInput/index.js +73 -60
  254. package/cjs/inputs/DateInput/index.js.map +3 -3
  255. package/cjs/inputs/FileInput/FileInput.stories/index.js +27 -18
  256. package/cjs/inputs/FileInput/FileInput.stories.js.map +3 -3
  257. package/cjs/inputs/FileInput/__stories__/Default/index.js +43 -29
  258. package/cjs/inputs/FileInput/__stories__/Default.js.map +2 -2
  259. package/cjs/inputs/FileInput/index.js +56 -42
  260. package/cjs/inputs/FileInput/index.js.map +2 -2
  261. package/cjs/inputs/ImageInput/ImageInput.stories/index.js +33 -20
  262. package/cjs/inputs/ImageInput/ImageInput.stories.js.map +3 -3
  263. package/cjs/inputs/ImageInput/__stories__/Default/index.js +35 -29
  264. package/cjs/inputs/ImageInput/__stories__/Default.js.map +2 -2
  265. package/cjs/inputs/ImageInput/__stories__/WithInvalidImageDimension/index.js +35 -29
  266. package/cjs/inputs/ImageInput/__stories__/WithInvalidImageDimension.js.map +2 -2
  267. package/cjs/inputs/ImageInput/__stories__/WithInvalidImageSize/index.js +35 -29
  268. package/cjs/inputs/ImageInput/__stories__/WithInvalidImageSize.js.map +2 -2
  269. package/cjs/inputs/ImageInput/index.js +72 -66
  270. package/cjs/inputs/ImageInput/index.js.map +2 -2
  271. package/cjs/inputs/Input/Input.stories/index.js +54 -27
  272. package/cjs/inputs/Input/Input.stories.js.map +3 -3
  273. package/cjs/inputs/Input/__stories__/AFM/index.js +44 -32
  274. package/cjs/inputs/Input/__stories__/AFM.js.map +2 -2
  275. package/cjs/inputs/Input/__stories__/Boolean/index.js +45 -33
  276. package/cjs/inputs/Input/__stories__/Boolean.js.map +2 -2
  277. package/cjs/inputs/Input/__stories__/IBAN/index.js +45 -33
  278. package/cjs/inputs/Input/__stories__/IBAN.js.map +2 -2
  279. package/cjs/inputs/Input/__stories__/Integer/index.js +57 -41
  280. package/cjs/inputs/Input/__stories__/Integer.js.map +2 -2
  281. package/cjs/inputs/Input/__stories__/LandlineNumber/index.js +48 -36
  282. package/cjs/inputs/Input/__stories__/LandlineNumber.js.map +2 -2
  283. package/cjs/inputs/Input/__stories__/MobilePhone/index.js +48 -36
  284. package/cjs/inputs/Input/__stories__/MobilePhone.js.map +2 -2
  285. package/cjs/inputs/Input/__stories__/PhoneNumber/index.js +47 -35
  286. package/cjs/inputs/Input/__stories__/PhoneNumber.js.map +2 -2
  287. package/cjs/inputs/Input/__stories__/PostalCode/index.js +45 -33
  288. package/cjs/inputs/Input/__stories__/PostalCode.js.map +2 -2
  289. package/cjs/inputs/Input/__stories__/String/index.js +64 -0
  290. package/cjs/inputs/Input/__stories__/String.js.map +7 -0
  291. package/cjs/inputs/Input/__stories__/TextWithLimit/index.js +64 -0
  292. package/cjs/inputs/Input/__stories__/TextWithLimit.js.map +7 -0
  293. package/cjs/inputs/Input/index.js +65 -53
  294. package/cjs/inputs/Input/index.js.map +2 -2
  295. package/cjs/inputs/Input/inputsInputScenarios/index.js +439 -0
  296. package/cjs/inputs/Input/inputsInputScenarios.js.map +7 -0
  297. package/cjs/inputs/Label/Label.stories/index.js +27 -18
  298. package/cjs/inputs/Label/Label.stories.js.map +3 -3
  299. package/cjs/inputs/Label/__stories__/Default/index.js +54 -36
  300. package/cjs/inputs/Label/__stories__/Default.js.map +3 -3
  301. package/cjs/inputs/Label/index.js +28 -28
  302. package/cjs/inputs/Label/index.js.map +3 -3
  303. package/cjs/inputs/OtpInput/OtpInput.stories/index.js +27 -18
  304. package/cjs/inputs/OtpInput/OtpInput.stories.js.map +3 -3
  305. package/cjs/inputs/OtpInput/__stories__/Default/index.js +35 -29
  306. package/cjs/inputs/OtpInput/__stories__/Default.js.map +2 -2
  307. package/cjs/inputs/OtpInput/index.js +118 -94
  308. package/cjs/inputs/OtpInput/index.js.map +3 -3
  309. package/cjs/inputs/Radio/Radio.stories/index.js +33 -20
  310. package/cjs/inputs/Radio/Radio.stories.js.map +3 -3
  311. package/cjs/inputs/Radio/__stories__/Conditional/index.js +35 -29
  312. package/cjs/inputs/Radio/__stories__/Conditional.js.map +2 -2
  313. package/cjs/inputs/Radio/__stories__/Default/index.js +62 -50
  314. package/cjs/inputs/Radio/__stories__/Default.js.map +2 -2
  315. package/cjs/inputs/Radio/__stories__/WithDivider/index.js +63 -51
  316. package/cjs/inputs/Radio/__stories__/WithDivider.js.map +2 -2
  317. package/cjs/inputs/Radio/index.js +61 -55
  318. package/cjs/inputs/Radio/index.js.map +3 -3
  319. package/cjs/inputs/Select/Select.stories/index.js +27 -18
  320. package/cjs/inputs/Select/Select.stories.js.map +3 -3
  321. package/cjs/inputs/Select/__stories__/Default/index.js +67 -55
  322. package/cjs/inputs/Select/__stories__/Default.js.map +2 -2
  323. package/cjs/inputs/Select/index.js +39 -30
  324. package/cjs/inputs/Select/index.js.map +2 -2
  325. package/cjs/inputs/index.js +30 -24
  326. package/cjs/inputs/index.js.map +1 -1
  327. package/cjs/inputs/inputsScenarios/index.js +540 -0
  328. package/cjs/inputs/inputsScenarios.js.map +7 -0
  329. package/cjs/internal/index.js +24 -77
  330. package/cjs/internal.js.map +2 -2
  331. package/cjs/lazy/index.js +81 -74
  332. package/cjs/lazy.js.map +3 -3
  333. package/cjs/locales/el/index.js +35 -0
  334. package/cjs/locales/el.js.map +7 -0
  335. package/cjs/registry/index.js +107 -88
  336. package/cjs/registry.js.map +2 -2
  337. package/cjs/types/index.js +20 -2
  338. package/cjs/types.js.map +2 -2
  339. package/cjs/utils/index.js +47 -34
  340. package/cjs/utils.js.map +3 -3
  341. package/cjs/validators/index.js +34 -30
  342. package/cjs/validators/index.js.map +3 -3
  343. package/cjs/validators/types/index.js +14 -2
  344. package/cjs/validators/types.js.map +1 -1
  345. package/cjs/validators/utils/afm/index.js +16 -4
  346. package/cjs/validators/utils/afm.js.map +1 -1
  347. package/cjs/validators/utils/file/index.js +25 -13
  348. package/cjs/validators/utils/file.js.map +2 -2
  349. package/cjs/validators/utils/iban/index.js +16 -4
  350. package/cjs/validators/utils/iban.js.map +1 -1
  351. package/cjs/validators/utils/image/index.js +18 -6
  352. package/cjs/validators/utils/image.js.map +1 -1
  353. package/cjs/validators/utils/index.js +52 -28
  354. package/cjs/validators/utils/index.js.map +1 -1
  355. package/cjs/validators/utils/int/index.js +16 -4
  356. package/cjs/validators/utils/int.js.map +1 -1
  357. package/cjs/validators/utils/number/index.js +16 -4
  358. package/cjs/validators/utils/number.js.map +1 -1
  359. package/cjs/validators/utils/otp/index.js +16 -4
  360. package/cjs/validators/utils/otp.js.map +1 -1
  361. package/cjs/validators/utils/phone/index.js +25 -6
  362. package/cjs/validators/utils/phone.js.map +2 -2
  363. package/cjs/validators/utils/postal_code/index.js +16 -4
  364. package/cjs/validators/utils/postal_code.js.map +1 -1
  365. package/cjs/validators/utils/text_limit/index.js +18 -6
  366. package/cjs/validators/utils/text_limit.js.map +1 -1
  367. package/cjs/validators/utils/uuid4/index.js +16 -4
  368. package/cjs/validators/utils/uuid4.js.map +1 -1
  369. package/index.d.ts +7 -1
  370. package/index.js +151 -3
  371. package/index.js.map +4 -4
  372. package/inputs/AutoCompleteInput/AutoComplete.stories/index.js +4 -2
  373. package/inputs/AutoCompleteInput/AutoComplete.stories.d.ts +2 -2
  374. package/inputs/AutoCompleteInput/AutoComplete.stories.js.map +2 -2
  375. package/inputs/AutoCompleteInput/__stories__/Default/index.js +22 -18
  376. package/inputs/AutoCompleteInput/__stories__/Default.d.ts +2 -2
  377. package/inputs/AutoCompleteInput/__stories__/Default.js.map +2 -2
  378. package/inputs/AutoCompleteInput/__stories__/Multiple/index.js +26 -20
  379. package/inputs/AutoCompleteInput/__stories__/Multiple.d.ts +3 -2
  380. package/inputs/AutoCompleteInput/__stories__/Multiple.js.map +2 -2
  381. package/inputs/AutoCompleteInput/index.d.ts +1 -1
  382. package/inputs/AutoCompleteInput/index.js +45 -26
  383. package/inputs/AutoCompleteInput/index.js.map +3 -3
  384. package/inputs/AutoCompleteInput/index.test.d.ts +1 -0
  385. package/inputs/Checkboxes/Checkboxes.stories/index.js +6 -3
  386. package/inputs/Checkboxes/Checkboxes.stories.d.ts +3 -3
  387. package/inputs/Checkboxes/Checkboxes.stories.js.map +2 -2
  388. package/inputs/Checkboxes/__stories__/Conditional/index.js +13 -13
  389. package/inputs/Checkboxes/__stories__/Conditional.d.ts +2 -2
  390. package/inputs/Checkboxes/__stories__/Conditional.js.map +1 -1
  391. package/inputs/Checkboxes/__stories__/Default/index.js +36 -30
  392. package/inputs/Checkboxes/__stories__/Default.d.ts +2 -2
  393. package/inputs/Checkboxes/__stories__/Default.js.map +1 -1
  394. package/inputs/Checkboxes/__stories__/WithDivider/index.js +37 -31
  395. package/inputs/Checkboxes/__stories__/WithDivider.d.ts +2 -2
  396. package/inputs/Checkboxes/__stories__/WithDivider.js.map +1 -1
  397. package/inputs/Checkboxes/index.d.ts +1 -0
  398. package/inputs/Checkboxes/index.js +46 -44
  399. package/inputs/Checkboxes/index.js.map +2 -2
  400. package/inputs/Checkboxes/index.test.d.ts +1 -0
  401. package/inputs/DateInput/DateInput.stories/index.js +2 -1
  402. package/inputs/DateInput/DateInput.stories.d.ts +1 -1
  403. package/inputs/DateInput/DateInput.stories.js.map +2 -2
  404. package/inputs/DateInput/__stories__/Default/index.js +19 -16
  405. package/inputs/DateInput/__stories__/Default.d.ts +2 -2
  406. package/inputs/DateInput/__stories__/Default.js.map +2 -2
  407. package/inputs/DateInput/index.d.ts +2 -2
  408. package/inputs/DateInput/index.js +48 -41
  409. package/inputs/DateInput/index.js.map +3 -3
  410. package/inputs/DateInput/index.test.d.ts +1 -0
  411. package/inputs/FileInput/FileInput.stories/index.js +2 -1
  412. package/inputs/FileInput/FileInput.stories.d.ts +1 -1
  413. package/inputs/FileInput/FileInput.stories.js.map +2 -2
  414. package/inputs/FileInput/__stories__/Default/index.js +21 -13
  415. package/inputs/FileInput/__stories__/Default.d.ts +2 -2
  416. package/inputs/FileInput/__stories__/Default.js.map +1 -1
  417. package/inputs/FileInput/index.js +30 -22
  418. package/inputs/FileInput/index.js.map +2 -2
  419. package/inputs/FileInput/index.test.d.ts +1 -0
  420. package/inputs/ImageInput/ImageInput.stories/index.js +6 -3
  421. package/inputs/ImageInput/ImageInput.stories.d.ts +3 -3
  422. package/inputs/ImageInput/ImageInput.stories.js.map +2 -2
  423. package/inputs/ImageInput/__stories__/Default/index.js +13 -13
  424. package/inputs/ImageInput/__stories__/Default.d.ts +2 -2
  425. package/inputs/ImageInput/__stories__/Default.js.map +1 -1
  426. package/inputs/ImageInput/__stories__/WithInvalidImageDimension/index.js +13 -13
  427. package/inputs/ImageInput/__stories__/WithInvalidImageDimension.d.ts +2 -2
  428. package/inputs/ImageInput/__stories__/WithInvalidImageDimension.js.map +1 -1
  429. package/inputs/ImageInput/__stories__/WithInvalidImageSize/index.js +13 -13
  430. package/inputs/ImageInput/__stories__/WithInvalidImageSize.d.ts +2 -2
  431. package/inputs/ImageInput/__stories__/WithInvalidImageSize.js.map +1 -1
  432. package/inputs/ImageInput/index.js +47 -47
  433. package/inputs/ImageInput/index.js.map +2 -2
  434. package/inputs/ImageInput/index.test.d.ts +1 -0
  435. package/inputs/Input/Input.stories/index.js +20 -10
  436. package/inputs/Input/Input.stories.d.ts +10 -10
  437. package/inputs/Input/Input.stories.js.map +2 -2
  438. package/inputs/Input/__stories__/AFM/index.js +22 -16
  439. package/inputs/Input/__stories__/AFM.d.ts +2 -2
  440. package/inputs/Input/__stories__/AFM.js.map +1 -1
  441. package/inputs/Input/__stories__/Boolean/index.js +23 -17
  442. package/inputs/Input/__stories__/Boolean.d.ts +2 -2
  443. package/inputs/Input/__stories__/Boolean.js.map +1 -1
  444. package/inputs/Input/__stories__/IBAN/index.js +23 -17
  445. package/inputs/Input/__stories__/IBAN.d.ts +2 -2
  446. package/inputs/Input/__stories__/IBAN.js.map +1 -1
  447. package/inputs/Input/__stories__/Integer/index.js +35 -25
  448. package/inputs/Input/__stories__/Integer.d.ts +2 -2
  449. package/inputs/Input/__stories__/Integer.js.map +1 -1
  450. package/inputs/Input/__stories__/LandlineNumber/index.js +26 -20
  451. package/inputs/Input/__stories__/LandlineNumber.d.ts +2 -2
  452. package/inputs/Input/__stories__/LandlineNumber.js.map +1 -1
  453. package/inputs/Input/__stories__/MobilePhone/index.js +26 -20
  454. package/inputs/Input/__stories__/MobilePhone.d.ts +2 -2
  455. package/inputs/Input/__stories__/MobilePhone.js.map +1 -1
  456. package/inputs/Input/__stories__/PhoneNumber/index.js +25 -19
  457. package/inputs/Input/__stories__/PhoneNumber.d.ts +2 -2
  458. package/inputs/Input/__stories__/PhoneNumber.js.map +1 -1
  459. package/inputs/Input/__stories__/PostalCode/index.js +23 -17
  460. package/inputs/Input/__stories__/PostalCode.d.ts +2 -2
  461. package/inputs/Input/__stories__/PostalCode.js.map +1 -1
  462. package/inputs/Input/__stories__/String/index.js +31 -0
  463. package/inputs/Input/__stories__/String/package.json +6 -0
  464. package/inputs/Input/__stories__/String.d.ts +3 -0
  465. package/inputs/Input/__stories__/String.js.map +7 -0
  466. package/inputs/Input/__stories__/TextWithLimit/index.js +31 -0
  467. package/inputs/Input/__stories__/TextWithLimit/package.json +6 -0
  468. package/inputs/Input/__stories__/TextWithLimit.d.ts +3 -0
  469. package/inputs/Input/__stories__/TextWithLimit.js.map +7 -0
  470. package/inputs/Input/index.js +41 -35
  471. package/inputs/Input/index.js.map +1 -1
  472. package/inputs/Input/index.test.d.ts +1 -0
  473. package/inputs/Input/inputsInputScenarios/index.js +406 -0
  474. package/inputs/Input/inputsInputScenarios/package.json +6 -0
  475. package/inputs/Input/inputsInputScenarios.d.ts +57 -0
  476. package/inputs/Input/inputsInputScenarios.js.map +7 -0
  477. package/inputs/Label/Label.stories/index.js +2 -1
  478. package/inputs/Label/Label.stories.d.ts +1 -1
  479. package/inputs/Label/Label.stories.js.map +2 -2
  480. package/inputs/Label/__stories__/Default/index.js +32 -20
  481. package/inputs/Label/__stories__/Default.d.ts +2 -2
  482. package/inputs/Label/__stories__/Default.js.map +2 -2
  483. package/inputs/Label/index.d.ts +1 -1
  484. package/inputs/Label/index.js +4 -10
  485. package/inputs/Label/index.js.map +2 -2
  486. package/inputs/Label/index.test.d.ts +1 -0
  487. package/inputs/OtpInput/OtpInput.stories/index.js +2 -1
  488. package/inputs/OtpInput/OtpInput.stories.d.ts +1 -1
  489. package/inputs/OtpInput/OtpInput.stories.js.map +2 -2
  490. package/inputs/OtpInput/__stories__/Default/index.js +13 -13
  491. package/inputs/OtpInput/__stories__/Default.d.ts +2 -2
  492. package/inputs/OtpInput/__stories__/Default.js.map +1 -1
  493. package/inputs/OtpInput/index.d.ts +9 -2
  494. package/inputs/OtpInput/index.js +94 -77
  495. package/inputs/OtpInput/index.js.map +2 -2
  496. package/inputs/OtpInput/index.test.d.ts +1 -0
  497. package/inputs/Radio/Radio.stories/index.js +6 -3
  498. package/inputs/Radio/Radio.stories.d.ts +3 -3
  499. package/inputs/Radio/Radio.stories.js.map +2 -2
  500. package/inputs/Radio/__stories__/Conditional/index.js +13 -13
  501. package/inputs/Radio/__stories__/Conditional.d.ts +2 -2
  502. package/inputs/Radio/__stories__/Conditional.js.map +1 -1
  503. package/inputs/Radio/__stories__/Default/index.js +40 -34
  504. package/inputs/Radio/__stories__/Default.d.ts +2 -2
  505. package/inputs/Radio/__stories__/Default.js.map +1 -1
  506. package/inputs/Radio/__stories__/WithDivider/index.js +41 -35
  507. package/inputs/Radio/__stories__/WithDivider.d.ts +2 -2
  508. package/inputs/Radio/__stories__/WithDivider.js.map +1 -1
  509. package/inputs/Radio/index.d.ts +1 -0
  510. package/inputs/Radio/index.js +36 -36
  511. package/inputs/Radio/index.js.map +2 -2
  512. package/inputs/Radio/index.test.d.ts +1 -0
  513. package/inputs/Select/Select.stories/index.js +2 -1
  514. package/inputs/Select/Select.stories.d.ts +1 -1
  515. package/inputs/Select/Select.stories.js.map +2 -2
  516. package/inputs/Select/__stories__/Default/index.js +45 -39
  517. package/inputs/Select/__stories__/Default.d.ts +2 -2
  518. package/inputs/Select/__stories__/Default.js.map +1 -1
  519. package/inputs/Select/index.js +15 -12
  520. package/inputs/Select/index.js.map +1 -1
  521. package/inputs/Select/index.test.d.ts +1 -0
  522. package/inputs/index.js +9 -9
  523. package/inputs/index.js.map +2 -2
  524. package/inputs/inputsScenarios/index.js +506 -0
  525. package/inputs/inputsScenarios/package.json +6 -0
  526. package/inputs/inputsScenarios.d.ts +338 -0
  527. package/inputs/inputsScenarios.js.map +7 -0
  528. package/internal/index.js +4 -45
  529. package/internal.d.ts +2 -31
  530. package/internal.js.map +2 -2
  531. package/lazy/index.js +60 -57
  532. package/lazy.d.ts +33 -30
  533. package/lazy.js.map +2 -2
  534. package/locales/el/index.js +6 -0
  535. package/{Questions/index.spec → locales/el}/package.json +1 -1
  536. package/locales/el.d.ts +2 -0
  537. package/locales/el.js.map +7 -0
  538. package/package.json +7 -7
  539. package/registry/index.js +26 -11
  540. package/registry.d.ts +7 -1
  541. package/registry.js.map +2 -2
  542. package/src/Field/FieldBase.tsx +1 -0
  543. package/src/Field/FieldConditional.tsx +1 -1
  544. package/src/Field/index.tsx +19 -3
  545. package/src/Field/types.tsx +64 -3
  546. package/src/Field/utils/calculateField.ts +49 -0
  547. package/src/Field/utils/evaluateFieldWithConditions.ts +30 -0
  548. package/src/Field/utils/index.ts +59 -0
  549. package/src/Field/utils/useField.ts +54 -0
  550. package/src/FieldArray/FieldArray.stories.js +2 -2
  551. package/src/FieldArray/index.test.tsx +24 -0
  552. package/src/FieldArray/index.tsx +11 -3
  553. package/src/FieldObject/index.tsx +10 -3
  554. package/src/Fieldset/types.tsx +3 -1
  555. package/src/FormBuilder/FormBuilder.stories.js +1 -1
  556. package/src/FormBuilder/index.test.tsx +20 -0
  557. package/src/FormBuilder/index.tsx +7 -2
  558. package/src/FormBuilder/scenarios.test.tsx +1864 -0
  559. package/src/MultiplicityField/MultiplicityField.stories.js +6 -6
  560. package/src/MultiplicityField/__stories__/PreviewDisplay.tsx +2 -2
  561. package/src/MultiplicityField/__stories__/WithExactLength.tsx +1 -1
  562. package/src/MultiplicityField/__stories__/WithMaxLength.tsx +1 -1
  563. package/src/MultiplicityField/__stories__/WithMinAndMaxLength.tsx +1 -1
  564. package/src/MultiplicityField/__stories__/WithMinLength.tsx +1 -1
  565. package/src/MultiplicityField/add-objects.tsx +23 -9
  566. package/src/MultiplicityField/index.test.tsx +40 -0
  567. package/src/MultiplicityField/index.tsx +9 -26
  568. package/src/MultiplicityField/types.ts +22 -0
  569. package/src/Questions/Questions.stories.js +1 -1
  570. package/src/Questions/Step/StepTitle.tsx +1 -0
  571. package/src/Questions/Step/index.ts +0 -1
  572. package/src/Questions/Step/types.tsx +1 -0
  573. package/src/Questions/__snapshots__/index.spec.tsx.snap +67 -586
  574. package/src/Questions/index.mdx +4 -4
  575. package/src/Questions/index.spec.tsx +3 -3
  576. package/src/Questions/index.test.tsx +20 -0
  577. package/src/Questions/types.tsx +1 -0
  578. package/src/{FormBuilder/FormBuilder.tsx → index.tsx} +21 -9
  579. package/src/inputs/AutoCompleteInput/AutoComplete.stories.js +2 -2
  580. package/src/inputs/AutoCompleteInput/__stories__/Default.tsx +26 -18
  581. package/src/inputs/AutoCompleteInput/__stories__/Multiple.tsx +27 -19
  582. package/src/inputs/AutoCompleteInput/index.mdx +8 -2
  583. package/src/inputs/AutoCompleteInput/index.test.tsx +24 -0
  584. package/src/inputs/AutoCompleteInput/index.tsx +22 -12
  585. package/src/inputs/Checkboxes/Checkboxes.stories.js +3 -3
  586. package/src/inputs/Checkboxes/index.test.tsx +28 -0
  587. package/src/inputs/Checkboxes/index.tsx +28 -25
  588. package/src/inputs/DateInput/DateInput.stories.js +1 -1
  589. package/src/inputs/DateInput/__stories__/Default.tsx +21 -15
  590. package/src/inputs/DateInput/index.test.tsx +20 -0
  591. package/src/inputs/DateInput/index.tsx +2 -2
  592. package/src/inputs/FileInput/FileInput.stories.js +1 -1
  593. package/src/inputs/FileInput/index.test.tsx +20 -0
  594. package/src/inputs/ImageInput/ImageInput.stories.js +3 -3
  595. package/src/inputs/ImageInput/index.test.tsx +28 -0
  596. package/src/inputs/Input/Input.stories.js +10 -10
  597. package/src/inputs/Input/__stories__/{Default.tsx → String.tsx} +2 -2
  598. package/src/inputs/Input/__stories__/{TextWithCharacterLimit.tsx → TextWithLimit.tsx} +2 -2
  599. package/src/inputs/Input/index.mdx +4 -4
  600. package/src/inputs/Input/index.test.tsx +56 -0
  601. package/src/inputs/Input/inputsInputScenarios.ts +405 -0
  602. package/src/inputs/Label/Label.stories.js +1 -1
  603. package/src/inputs/Label/__stories__/Default.tsx +3 -1
  604. package/src/inputs/Label/index.test.tsx +20 -0
  605. package/src/inputs/Label/index.tsx +1 -4
  606. package/src/inputs/OtpInput/OtpInput.stories.js +1 -1
  607. package/src/inputs/OtpInput/index.test.tsx +20 -0
  608. package/src/inputs/OtpInput/index.tsx +1 -1
  609. package/src/inputs/Radio/Radio.stories.js +3 -3
  610. package/src/inputs/Radio/index.test.tsx +28 -0
  611. package/src/inputs/Radio/index.tsx +6 -3
  612. package/src/inputs/Select/Select.stories.js +1 -1
  613. package/src/inputs/Select/index.test.tsx +20 -0
  614. package/src/inputs/inputsScenarios.ts +503 -0
  615. package/src/internal.ts +2 -31
  616. package/src/lazy.js +18 -15
  617. package/src/locales/el.ts +3 -0
  618. package/src/registry.js +14 -2
  619. package/src/types.tsx +9 -63
  620. package/src/utils.ts +34 -33
  621. package/src/validators/index.ts +5 -0
  622. package/src/validators/utils/file.ts +9 -9
  623. package/src/validators/utils/phone.ts +62 -71
  624. package/src/validators/validators.spec.ts +3 -37
  625. package/types/index.js +1 -0
  626. package/types.d.ts +4 -33
  627. package/types.js.map +3 -3
  628. package/utils/index.js +34 -17
  629. package/utils.js.map +3 -3
  630. package/validators/index.js +9 -11
  631. package/validators/index.js.map +2 -2
  632. package/validators/utils/afm.js.map +1 -1
  633. package/validators/utils/file/index.js +9 -9
  634. package/validators/utils/file.js.map +2 -2
  635. package/validators/utils/iban.js.map +1 -1
  636. package/validators/utils/image/index.js +2 -2
  637. package/validators/utils/image.js.map +1 -1
  638. package/validators/utils/index.js +10 -2
  639. package/validators/utils/index.js.map +1 -1
  640. package/validators/utils/int.js.map +1 -1
  641. package/validators/utils/number.js.map +1 -1
  642. package/validators/utils/otp.js.map +1 -1
  643. package/validators/utils/phone/index.js +9 -2
  644. package/validators/utils/phone.js.map +2 -2
  645. package/validators/utils/postal_code.js.map +1 -1
  646. package/validators/utils/text_limit/index.js +2 -2
  647. package/validators/utils/text_limit.js.map +1 -1
  648. package/validators/utils/uuid4.js.map +1 -1
  649. package/Field/utils.d.ts +0 -5
  650. package/Field/utils.js.map +0 -7
  651. package/FormBuilder/FormBuilder/index.js +0 -138
  652. package/FormBuilder/FormBuilder.d.ts +0 -5
  653. package/FormBuilder/FormBuilder.js.map +0 -7
  654. package/Questions/index.spec/index.js +0 -65
  655. package/Questions/index.spec.js.map +0 -7
  656. package/cjs/Field/utils.js.map +0 -7
  657. package/cjs/FormBuilder/FormBuilder/index.js +0 -166
  658. package/cjs/FormBuilder/FormBuilder.js.map +0 -7
  659. package/cjs/Questions/index.spec/index.js +0 -83
  660. package/cjs/Questions/index.spec.js.map +0 -7
  661. package/cjs/inputs/Input/__stories__/Default/index.js +0 -52
  662. package/cjs/inputs/Input/__stories__/Default.js.map +0 -7
  663. package/cjs/inputs/Input/__stories__/TextWithCharacterLimit/index.js +0 -52
  664. package/cjs/inputs/Input/__stories__/TextWithCharacterLimit.js.map +0 -7
  665. package/cjs/validators/validators.spec/index.js +0 -104
  666. package/cjs/validators/validators.spec.js.map +0 -7
  667. package/inputs/Input/__stories__/Default/index.js +0 -25
  668. package/inputs/Input/__stories__/Default.d.ts +0 -3
  669. package/inputs/Input/__stories__/Default.js.map +0 -7
  670. package/inputs/Input/__stories__/TextWithCharacterLimit/index.js +0 -25
  671. package/inputs/Input/__stories__/TextWithCharacterLimit/package.json +0 -6
  672. package/inputs/Input/__stories__/TextWithCharacterLimit.d.ts +0 -3
  673. package/inputs/Input/__stories__/TextWithCharacterLimit.js.map +0 -7
  674. package/src/Field/utils.ts +0 -191
  675. package/src/FieldArray/FieldArray.stories.playwright.json +0 -353
  676. package/src/FormBuilder/FormBuilder.stories.playwright.json +0 -52
  677. package/src/MultiplicityField/MultiplicityField.stories.playwright.json +0 -1370
  678. package/src/index.ts +0 -3
  679. package/src/inputs/Checkboxes/Checkboxes.stories.playwright.json +0 -85
  680. package/src/inputs/DateInput/DateInput.stories.playwright.json +0 -72
  681. package/src/inputs/FileInput/FileInput.stories.playwright.json +0 -75
  682. package/src/inputs/ImageInput/ImageInput.stories.playwright.json +0 -77
  683. package/src/inputs/Input/Input.stories.playwright.json +0 -376
  684. package/src/inputs/Label/Label.stories.playwright.json +0 -40
  685. package/src/inputs/Radio/Radio.stories.playwright.json +0 -73
  686. package/src/inputs/Select/Select.stories.playwright.json +0 -22
  687. package/validators/validators.spec/index.js +0 -91
  688. package/validators/validators.spec.js.map +0 -7
package/types.d.ts CHANGED
@@ -1,48 +1,17 @@
1
1
  /// <reference types="react" />
2
2
  import { UseFormReturn, UseFormProps } from 'react-hook-form';
3
- import { FieldComponentRegistry } from '@digigov/form/Field/types';
3
+ import { FieldComponentRegistry, FieldLabelProps, FieldSpec, FormData } from '@digigov/form/Field/types';
4
4
  import { ValidatorSchema } from '@digigov/form/validators/types';
5
- import { GridProps } from '@digigov/ui/layouts/Grid';
5
+ export * from '@digigov/form/Field/types';
6
6
  export type FieldError = {
7
7
  message: string;
8
8
  };
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
9
  export interface FieldsetSpec {
40
10
  key: string;
41
11
  fields: string[];
42
12
  label?: FieldLabelProps;
43
13
  body?: React.ReactNode;
44
14
  }
45
- export type FormData = UseFormProps['defaultValues'];
46
15
  export interface FormContextProps {
47
16
  fieldsetsMap?: Record<string, FieldsetSpec>;
48
17
  fieldsMap: Record<string, FieldSpec>;
@@ -57,9 +26,11 @@ export interface FormContextProps {
57
26
  unregister: UseFormReturn['unregister'];
58
27
  formState: UseFormReturn['formState'];
59
28
  reset: UseFormReturn['reset'];
29
+ resetField: UseFormReturn['resetField'];
60
30
  registerField: (field: FieldSpec) => void;
61
31
  errors: UseFormReturn['formState']['errors'];
62
32
  componentRegistry?: FieldComponentRegistry;
33
+ submit: () => Promise<void>;
63
34
  }
64
35
  export interface FormBuilderProps {
65
36
  fields?: FieldSpec[];
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}\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,4 +1,4 @@
1
- import {useMemo} from "react";
1
+ import { useMemo } from "react";
2
2
  import dayjs from "dayjs";
3
3
  import customParseFormat from "dayjs/plugin/customParseFormat";
4
4
  import * as yup from "yup";
@@ -15,8 +15,8 @@ import {
15
15
  UUID4_VALIDATOR,
16
16
  IMAGE_DIMENSION_VALIDATOR
17
17
  } 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";
18
+ import { INT_VALIDATOR } from "@digigov/form/validators/utils/int";
19
+ import { NUMBER_VALIDATOR } from "@digigov/form/validators/utils/number";
20
20
  dayjs.extend(customParseFormat);
21
21
  const VALID_DATE_FORMATS = ["DD/MM/YYYY"];
22
22
  const DATE_CACHE = {};
@@ -69,6 +69,7 @@ const getYUPTypeMap = () => {
69
69
  return yup.array().of(yup.string());
70
70
  }
71
71
  },
72
+ number: () => yup.mixed().transform((_, val) => val !== "" ? Number(val) : null).test(NUMBER_VALIDATOR()),
72
73
  int: () => yup.mixed().transform((_, val) => val !== "" ? Number(val) : null).test(NUMBER_VALIDATOR()).test(INT_VALIDATOR()),
73
74
  email: () => yup.string().email("form.error.email"),
74
75
  afm: () => yup.string().test(AFM_VALIDATOR),
@@ -97,8 +98,7 @@ const getYUPTypeMap = () => {
97
98
  "choice:single": () => yup.string().nullable(),
98
99
  date: (field) => {
99
100
  let simpleDate = yup.string().nullable(true).test("date", "form.error.date.invalid", function(value) {
100
- if (!value)
101
- return true;
101
+ if (!value) return true;
102
102
  const date = getDate(value);
103
103
  return date.isValid();
104
104
  });
@@ -106,7 +106,7 @@ const getYUPTypeMap = () => {
106
106
  if (params.max) {
107
107
  let maxDate;
108
108
  if (params.max === "now") {
109
- const today = new Date();
109
+ const today = /* @__PURE__ */ new Date();
110
110
  maxDate = new Date(today);
111
111
  } else {
112
112
  maxDate = getDate(params.max).toDate();
@@ -122,8 +122,7 @@ const getYUPTypeMap = () => {
122
122
  }
123
123
  },
124
124
  test: function(value) {
125
- if (!value)
126
- return true;
125
+ if (!value) return true;
127
126
  const date = getDate(value);
128
127
  const isValid = +date.toDate() < +maxDate;
129
128
  return isValid;
@@ -133,7 +132,7 @@ const getYUPTypeMap = () => {
133
132
  if (params.min) {
134
133
  let minDate;
135
134
  if (params.min === "now") {
136
- const today = new Date();
135
+ const today = /* @__PURE__ */ new Date();
137
136
  minDate = new Date(today);
138
137
  } else {
139
138
  minDate = getDate(params.min).toDate();
@@ -149,8 +148,7 @@ const getYUPTypeMap = () => {
149
148
  }
150
149
  },
151
150
  test: function(value) {
152
- if (!value)
153
- return true;
151
+ if (!value) return true;
154
152
  const date = getDate(value);
155
153
  const isValid = +date.toDate() > +minDate;
156
154
  return isValid;
@@ -1,7 +1,7 @@
1
1
  {
2
2
  "version": 3,
3
3
  "sources": ["../../src/validators/index.ts"],
4
- "sourcesContent": ["import { MutableRefObject, useMemo } from 'react';\nimport dayjs from 'dayjs';\nimport customParseFormat from 'dayjs/plugin/customParseFormat';\nimport * as yup from 'yup';\nimport { AnyObjectSchema, StringSchema } from 'yup';\nimport { RequiredArraySchema } from 'yup/lib/array';\nimport Lazy from 'yup/lib/Lazy';\nimport { MixedSchema } from 'yup/lib/mixed';\nimport { TypeOfShape, AssertsShape } from 'yup/lib/object';\nimport { AnyObject } from 'yup/lib/types';\nimport { FieldSpec } from '@digigov/form/types';\nimport { ValidatorSchema } from '@digigov/form/validators/types';\nimport {\n getYupObjectShape,\n AFM_VALIDATOR,\n FILE_MAX_SIZE_VALIDATOR,\n IBAN_VALIDATOR,\n OTP_VALIDATOR,\n MOBILE_PHONE_VALIDATOR,\n PHONE_NUMBER_VALIDATOR,\n TEXT_LIMIT_VALIDATOR,\n POSTALCODE_VALIDATOR,\n UUID4_VALIDATOR,\n IMAGE_DIMENSION_VALIDATOR,\n} from '@digigov/form/validators/utils';\nimport { INT_VALIDATOR } from '@digigov/form/validators/utils/int';\nimport { NUMBER_VALIDATOR } from '@digigov/form/validators/utils/number';\ndayjs.extend(customParseFormat);\n\nconst VALID_DATE_FORMATS = ['DD/MM/YYYY'];\nconst DATE_CACHE = {};\nconst getDate = (v) => {\n return DATE_CACHE[v] ? DATE_CACHE[v] : dayjs(v, VALID_DATE_FORMATS, true);\n};\n\nexport const getYUPTypeMap = (): Record<string, any> => {\n const yupTypeMap = {\n file: (field): MixedSchema => {\n return yup\n .mixed()\n .transform((value) => {\n if (!value.length) {\n return null;\n }\n return value;\n })\n .nullable()\n .test(FILE_MAX_SIZE_VALIDATOR(field));\n },\n string: yup.string,\n boolean: yup.boolean,\n object: (\n field\n ):\n | yup.ObjectSchema<any, AnyObject, TypeOfShape<any>, AssertsShape<any>>\n | Lazy<any, unknown> => {\n return getYupObjectShape(field.extra.fields, yupTypeMap);\n },\n array: (\n field\n ):\n | yup.ArraySchema<any, AnyObject, any[] | undefined>\n | RequiredArraySchema<any, AnyObject, any[] | undefined> => {\n if (typeof field.extra.of === 'object') {\n // else if the field is an object then it is a scalar type\n // eg. number, string etc.\n let arrayValidator = yup\n .array()\n .of(yupTypeMap[field.extra.of.type](field.extra.of))\n .required(field.required);\n if (field.extra.length)\n arrayValidator = arrayValidator.length(field.extra.length, {\n key: 'form.error.array.length',\n context: {\n length: field.extra.length,\n },\n });\n if (field.extra.min)\n arrayValidator = arrayValidator.min(field.extra.min, {\n key: 'form.error.array.min',\n context: {\n min: field.extra.min,\n },\n });\n if (field.extra.max)\n arrayValidator = arrayValidator.max(field.extra.max, {\n key: 'form.error.array.max',\n context: {\n max: field.extra.max,\n },\n });\n return arrayValidator;\n } else if (typeof field.extra.of === 'string') {\n return yup.array().of(yupTypeMap[field.extra.of]());\n } else {\n // in any other case it will be string\n return yup.array().of(yup.string());\n }\n },\n int: (): MixedSchema =>\n yup\n .mixed()\n .transform((_, val) => (val !== '' ? Number(val) : null))\n .test(NUMBER_VALIDATOR())\n .test(INT_VALIDATOR()),\n email: (): yup.StringSchema => yup.string().email('form.error.email'),\n afm: (): yup.StringSchema => yup.string().test(AFM_VALIDATOR),\n uuid4: (): yup.StringSchema => yup.string().test(UUID4_VALIDATOR),\n iban: (field): yup.StringSchema => yup.string().test(IBAN_VALIDATOR(field)),\n otp: (field): yup.StringSchema => yup.string().test(OTP_VALIDATOR(field)),\n text: (field): yup.StringSchema => {\n if (field?.extra?.limit?.max || !!field?.extra?.limit?.min) {\n return yup.string().test(TEXT_LIMIT_VALIDATOR(field));\n } else {\n return yup.string();\n }\n },\n image: (field): MixedSchema => {\n return yup\n .mixed()\n .transform((value) => {\n if (!value.length || value.length === 0) {\n return null;\n }\n return value;\n })\n .nullable()\n .test(FILE_MAX_SIZE_VALIDATOR(field))\n .test(IMAGE_DIMENSION_VALIDATOR(field));\n },\n postal_code: (field): yup.StringSchema =>\n yup.string().test(POSTALCODE_VALIDATOR(field)),\n mobile_phone: (): yup.StringSchema =>\n yup.string().test(MOBILE_PHONE_VALIDATOR),\n phone_number: (field): yup.StringSchema =>\n yup.string().test(PHONE_NUMBER_VALIDATOR(field)),\n 'choice:multiple': (): yup.ArraySchema<\n yup.StringSchema<string | undefined, AnyObject, string | undefined>,\n AnyObject,\n (string | undefined)[] | null | undefined,\n (string | undefined)[] | null | undefined\n > => yup.array().of(yup.string()).nullable(),\n 'choice:single': (): StringSchema<\n string | null | undefined,\n AnyObject,\n string | null | undefined\n > => yup.string().nullable(),\n date: (field) => {\n let simpleDate = yup\n .string()\n .nullable(true)\n .test('date', 'form.error.date.invalid', function (value) {\n if (!value) return true;\n const date = getDate(value);\n return date.isValid();\n });\n const params = field.extra || {};\n if (params.max) {\n let maxDate;\n if (params.max === 'now') {\n const today = new Date();\n maxDate = new Date(today);\n } else {\n maxDate = getDate(params.max).toDate();\n }\n const maxNextDate = new Date(maxDate);\n maxNextDate.setDate(maxDate.getDate() + 1);\n simpleDate = simpleDate.test({\n name: 'earlier-than',\n message: {\n key: 'form.error.date.earlier_than',\n context: {\n maxDate: maxNextDate.toLocaleDateString(),\n },\n },\n test: function (value) {\n if (!value) return true;\n const date = getDate(value);\n const isValid = +date.toDate() < +maxDate;\n return isValid;\n },\n });\n }\n if (params.min) {\n let minDate;\n if (params.min === 'now') {\n const today = new Date();\n minDate = new Date(today);\n } else {\n minDate = getDate(params.min).toDate();\n }\n const minPreviousDate = new Date(minDate);\n minPreviousDate.setDate(minDate.getDate() - 1);\n simpleDate = simpleDate.test({\n name: 'later-than',\n message: {\n key: 'form.error.date.later_than',\n context: {\n minDate: minPreviousDate.toLocaleDateString(),\n },\n },\n test: function (value) {\n if (!value) return true;\n const date = getDate(value);\n const isValid = +date.toDate() > +minDate;\n return isValid;\n },\n });\n }\n return simpleDate;\n },\n };\n return yupTypeMap;\n};\n\nexport interface MutableRefObjectProps {}\n// Create a yup validation schema from given fields input\nexport function useValidationSchema(\n fields: FieldSpec[] | MutableRefObject<MutableRefObjectProps>,\n validatorRegistry?: Record<string, ValidatorSchema[]>\n): Lazy<any, unknown> | AnyObjectSchema | void {\n return useMemo(() => {\n const yupTypeMap = getYUPTypeMap();\n return getYupObjectShape(fields, yupTypeMap, validatorRegistry);\n }, []);\n}\n"],
5
- "mappings": "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",
4
+ "sourcesContent": ["import { MutableRefObject, useMemo } from 'react';\nimport dayjs from 'dayjs';\nimport customParseFormat from 'dayjs/plugin/customParseFormat';\nimport * as yup from 'yup';\nimport { AnyObjectSchema, StringSchema } from 'yup';\nimport { RequiredArraySchema } from 'yup/lib/array';\nimport Lazy from 'yup/lib/Lazy';\nimport { MixedSchema } from 'yup/lib/mixed';\nimport { TypeOfShape, AssertsShape } from 'yup/lib/object';\nimport { AnyObject } from 'yup/lib/types';\nimport { FieldSpec } from '@digigov/form/types';\nimport { ValidatorSchema } from '@digigov/form/validators/types';\nimport {\n getYupObjectShape,\n AFM_VALIDATOR,\n FILE_MAX_SIZE_VALIDATOR,\n IBAN_VALIDATOR,\n OTP_VALIDATOR,\n MOBILE_PHONE_VALIDATOR,\n PHONE_NUMBER_VALIDATOR,\n TEXT_LIMIT_VALIDATOR,\n POSTALCODE_VALIDATOR,\n UUID4_VALIDATOR,\n IMAGE_DIMENSION_VALIDATOR,\n} from '@digigov/form/validators/utils';\nimport { INT_VALIDATOR } from '@digigov/form/validators/utils/int';\nimport { NUMBER_VALIDATOR } from '@digigov/form/validators/utils/number';\ndayjs.extend(customParseFormat);\n\nconst VALID_DATE_FORMATS = ['DD/MM/YYYY'];\nconst DATE_CACHE = {};\nconst getDate = (v) => {\n return DATE_CACHE[v] ? DATE_CACHE[v] : dayjs(v, VALID_DATE_FORMATS, true);\n};\n\nexport const getYUPTypeMap = (): Record<string, any> => {\n const yupTypeMap = {\n file: (field): MixedSchema => {\n return yup\n .mixed()\n .transform((value) => {\n if (!value.length) {\n return null;\n }\n return value;\n })\n .nullable()\n .test(FILE_MAX_SIZE_VALIDATOR(field));\n },\n string: yup.string,\n boolean: yup.boolean,\n object: (\n field\n ):\n | yup.ObjectSchema<any, AnyObject, TypeOfShape<any>, AssertsShape<any>>\n | Lazy<any, unknown> => {\n return getYupObjectShape(field.extra.fields, yupTypeMap);\n },\n array: (\n field\n ):\n | yup.ArraySchema<any, AnyObject, any[] | undefined>\n | RequiredArraySchema<any, AnyObject, any[] | undefined> => {\n if (typeof field.extra.of === 'object') {\n // else if the field is an object then it is a scalar type\n // eg. number, string etc.\n let arrayValidator = yup\n .array()\n .of(yupTypeMap[field.extra.of.type](field.extra.of))\n .required(field.required);\n if (field.extra.length)\n arrayValidator = arrayValidator.length(field.extra.length, {\n key: 'form.error.array.length',\n context: {\n length: field.extra.length,\n },\n });\n if (field.extra.min)\n arrayValidator = arrayValidator.min(field.extra.min, {\n key: 'form.error.array.min',\n context: {\n min: field.extra.min,\n },\n });\n if (field.extra.max)\n arrayValidator = arrayValidator.max(field.extra.max, {\n key: 'form.error.array.max',\n context: {\n max: field.extra.max,\n },\n });\n return arrayValidator;\n } else if (typeof field.extra.of === 'string') {\n return yup.array().of(yupTypeMap[field.extra.of]());\n } else {\n // in any other case it will be string\n return yup.array().of(yup.string());\n }\n },\n number: (): MixedSchema =>\n yup\n .mixed()\n .transform((_, val) => (val !== '' ? Number(val) : null))\n .test(NUMBER_VALIDATOR()),\n int: (): MixedSchema =>\n yup\n .mixed()\n .transform((_, val) => (val !== '' ? Number(val) : null))\n .test(NUMBER_VALIDATOR())\n .test(INT_VALIDATOR()),\n email: (): yup.StringSchema => yup.string().email('form.error.email'),\n afm: (): yup.StringSchema => yup.string().test(AFM_VALIDATOR),\n uuid4: (): yup.StringSchema => yup.string().test(UUID4_VALIDATOR),\n iban: (field): yup.StringSchema => yup.string().test(IBAN_VALIDATOR(field)),\n otp: (field): yup.StringSchema => yup.string().test(OTP_VALIDATOR(field)),\n text: (field): yup.StringSchema => {\n if (field?.extra?.limit?.max || !!field?.extra?.limit?.min) {\n return yup.string().test(TEXT_LIMIT_VALIDATOR(field));\n } else {\n return yup.string();\n }\n },\n image: (field): MixedSchema => {\n return yup\n .mixed()\n .transform((value) => {\n if (!value.length || value.length === 0) {\n return null;\n }\n return value;\n })\n .nullable()\n .test(FILE_MAX_SIZE_VALIDATOR(field))\n .test(IMAGE_DIMENSION_VALIDATOR(field));\n },\n postal_code: (field): yup.StringSchema =>\n yup.string().test(POSTALCODE_VALIDATOR(field)),\n mobile_phone: (): yup.StringSchema =>\n yup.string().test(MOBILE_PHONE_VALIDATOR),\n phone_number: (field): yup.StringSchema =>\n yup.string().test(PHONE_NUMBER_VALIDATOR(field)),\n 'choice:multiple': (): yup.ArraySchema<\n yup.StringSchema<string | undefined, AnyObject, string | undefined>,\n AnyObject,\n (string | undefined)[] | null | undefined,\n (string | undefined)[] | null | undefined\n > => yup.array().of(yup.string()).nullable(),\n 'choice:single': (): StringSchema<\n string | null | undefined,\n AnyObject,\n string | null | undefined\n > => yup.string().nullable(),\n date: (field) => {\n let simpleDate = yup\n .string()\n .nullable(true)\n .test('date', 'form.error.date.invalid', function (value) {\n if (!value) return true;\n const date = getDate(value);\n return date.isValid();\n });\n const params = field.extra || {};\n if (params.max) {\n let maxDate;\n if (params.max === 'now') {\n const today = new Date();\n maxDate = new Date(today);\n } else {\n maxDate = getDate(params.max).toDate();\n }\n const maxNextDate = new Date(maxDate);\n maxNextDate.setDate(maxDate.getDate() + 1);\n simpleDate = simpleDate.test({\n name: 'earlier-than',\n message: {\n key: 'form.error.date.earlier_than',\n context: {\n maxDate: maxNextDate.toLocaleDateString(),\n },\n },\n test: function (value) {\n if (!value) return true;\n const date = getDate(value);\n const isValid = +date.toDate() < +maxDate;\n return isValid;\n },\n });\n }\n if (params.min) {\n let minDate;\n if (params.min === 'now') {\n const today = new Date();\n minDate = new Date(today);\n } else {\n minDate = getDate(params.min).toDate();\n }\n const minPreviousDate = new Date(minDate);\n minPreviousDate.setDate(minDate.getDate() - 1);\n simpleDate = simpleDate.test({\n name: 'later-than',\n message: {\n key: 'form.error.date.later_than',\n context: {\n minDate: minPreviousDate.toLocaleDateString(),\n },\n },\n test: function (value) {\n if (!value) return true;\n const date = getDate(value);\n const isValid = +date.toDate() > +minDate;\n return isValid;\n },\n });\n }\n return simpleDate;\n },\n };\n return yupTypeMap;\n};\n\nexport interface MutableRefObjectProps {}\n// Create a yup validation schema from given fields input\nexport function useValidationSchema(\n fields: FieldSpec[] | MutableRefObject<MutableRefObjectProps>,\n validatorRegistry?: Record<string, ValidatorSchema[]>\n): Lazy<any, unknown> | AnyObjectSchema | void {\n return useMemo(() => {\n const yupTypeMap = getYUPTypeMap();\n return getYupObjectShape(fields, yupTypeMap, validatorRegistry);\n }, []);\n}\n"],
5
+ "mappings": "AAAA,SAA2B,eAAe;AAC1C,OAAO,WAAW;AAClB,OAAO,uBAAuB;AAC9B,YAAY,SAAS;AASrB;AAAA,EACE;AAAA,EACA;AAAA,EACA;AAAA,EACA;AAAA,EACA;AAAA,EACA;AAAA,EACA;AAAA,EACA;AAAA,EACA;AAAA,EACA;AAAA,EACA;AAAA,OACK;AACP,SAAS,qBAAqB;AAC9B,SAAS,wBAAwB;AACjC,MAAM,OAAO,iBAAiB;AAE9B,MAAM,qBAAqB,CAAC,YAAY;AACxC,MAAM,aAAa,CAAC;AACpB,MAAM,UAAU,CAAC,MAAM;AACrB,SAAO,WAAW,CAAC,IAAI,WAAW,CAAC,IAAI,MAAM,GAAG,oBAAoB,IAAI;AAC1E;AAEO,MAAM,gBAAgB,MAA2B;AACtD,QAAM,aAAa;AAAA,IACjB,MAAM,CAAC,UAAuB;AAC5B,aAAO,IACJ,MAAM,EACN,UAAU,CAAC,UAAU;AACpB,YAAI,CAAC,MAAM,QAAQ;AACjB,iBAAO;AAAA,QACT;AACA,eAAO;AAAA,MACT,CAAC,EACA,SAAS,EACT,KAAK,wBAAwB,KAAK,CAAC;AAAA,IACxC;AAAA,IACA,QAAQ,IAAI;AAAA,IACZ,SAAS,IAAI;AAAA,IACb,QAAQ,CACN,UAGwB;AACxB,aAAO,kBAAkB,MAAM,MAAM,QAAQ,UAAU;AAAA,IACzD;AAAA,IACA,OAAO,CACL,UAG4D;AAC5D,UAAI,OAAO,MAAM,MAAM,OAAO,UAAU;AAGtC,YAAI,iBAAiB,IAClB,MAAM,EACN,GAAG,WAAW,MAAM,MAAM,GAAG,IAAI,EAAE,MAAM,MAAM,EAAE,CAAC,EAClD,SAAS,MAAM,QAAQ;AAC1B,YAAI,MAAM,MAAM;AACd,2BAAiB,eAAe,OAAO,MAAM,MAAM,QAAQ;AAAA,YACzD,KAAK;AAAA,YACL,SAAS;AAAA,cACP,QAAQ,MAAM,MAAM;AAAA,YACtB;AAAA,UACF,CAAC;AACH,YAAI,MAAM,MAAM;AACd,2BAAiB,eAAe,IAAI,MAAM,MAAM,KAAK;AAAA,YACnD,KAAK;AAAA,YACL,SAAS;AAAA,cACP,KAAK,MAAM,MAAM;AAAA,YACnB;AAAA,UACF,CAAC;AACH,YAAI,MAAM,MAAM;AACd,2BAAiB,eAAe,IAAI,MAAM,MAAM,KAAK;AAAA,YACnD,KAAK;AAAA,YACL,SAAS;AAAA,cACP,KAAK,MAAM,MAAM;AAAA,YACnB;AAAA,UACF,CAAC;AACH,eAAO;AAAA,MACT,WAAW,OAAO,MAAM,MAAM,OAAO,UAAU;AAC7C,eAAO,IAAI,MAAM,EAAE,GAAG,WAAW,MAAM,MAAM,EAAE,EAAE,CAAC;AAAA,MACpD,OAAO;AAEL,eAAO,IAAI,MAAM,EAAE,GAAG,IAAI,OAAO,CAAC;AAAA,MACpC;AAAA,IACF;AAAA,IACA,QAAQ,MACN,IACG,MAAM,EACN,UAAU,CAAC,GAAG,QAAS,QAAQ,KAAK,OAAO,GAAG,IAAI,IAAK,EACvD,KAAK,iBAAiB,CAAC;AAAA,IAC5B,KAAK,MACH,IACG,MAAM,EACN,UAAU,CAAC,GAAG,QAAS,QAAQ,KAAK,OAAO,GAAG,IAAI,IAAK,EACvD,KAAK,iBAAiB,CAAC,EACvB,KAAK,cAAc,CAAC;AAAA,IACzB,OAAO,MAAwB,IAAI,OAAO,EAAE,MAAM,kBAAkB;AAAA,IACpE,KAAK,MAAwB,IAAI,OAAO,EAAE,KAAK,aAAa;AAAA,IAC5D,OAAO,MAAwB,IAAI,OAAO,EAAE,KAAK,eAAe;AAAA,IAChE,MAAM,CAAC,UAA4B,IAAI,OAAO,EAAE,KAAK,eAAe,KAAK,CAAC;AAAA,IAC1E,KAAK,CAAC,UAA4B,IAAI,OAAO,EAAE,KAAK,cAAc,KAAK,CAAC;AAAA,IACxE,MAAM,CAAC,UAA4B;AACjC,UAAI,OAAO,OAAO,OAAO,OAAO,CAAC,CAAC,OAAO,OAAO,OAAO,KAAK;AAC1D,eAAO,IAAI,OAAO,EAAE,KAAK,qBAAqB,KAAK,CAAC;AAAA,MACtD,OAAO;AACL,eAAO,IAAI,OAAO;AAAA,MACpB;AAAA,IACF;AAAA,IACA,OAAO,CAAC,UAAuB;AAC7B,aAAO,IACJ,MAAM,EACN,UAAU,CAAC,UAAU;AACpB,YAAI,CAAC,MAAM,UAAU,MAAM,WAAW,GAAG;AACvC,iBAAO;AAAA,QACT;AACA,eAAO;AAAA,MACT,CAAC,EACA,SAAS,EACT,KAAK,wBAAwB,KAAK,CAAC,EACnC,KAAK,0BAA0B,KAAK,CAAC;AAAA,IAC1C;AAAA,IACA,aAAa,CAAC,UACZ,IAAI,OAAO,EAAE,KAAK,qBAAqB,KAAK,CAAC;AAAA,IAC/C,cAAc,MACZ,IAAI,OAAO,EAAE,KAAK,sBAAsB;AAAA,IAC1C,cAAc,CAAC,UACb,IAAI,OAAO,EAAE,KAAK,uBAAuB,KAAK,CAAC;AAAA,IACjD,mBAAmB,MAKd,IAAI,MAAM,EAAE,GAAG,IAAI,OAAO,CAAC,EAAE,SAAS;AAAA,IAC3C,iBAAiB,MAIZ,IAAI,OAAO,EAAE,SAAS;AAAA,IAC3B,MAAM,CAAC,UAAU;AACf,UAAI,aAAa,IACd,OAAO,EACP,SAAS,IAAI,EACb,KAAK,QAAQ,2BAA2B,SAAU,OAAO;AACxD,YAAI,CAAC,MAAO,QAAO;AACnB,cAAM,OAAO,QAAQ,KAAK;AAC1B,eAAO,KAAK,QAAQ;AAAA,MACtB,CAAC;AACH,YAAM,SAAS,MAAM,SAAS,CAAC;AAC/B,UAAI,OAAO,KAAK;AACd,YAAI;AACJ,YAAI,OAAO,QAAQ,OAAO;AACxB,gBAAM,QAAQ,oBAAI,KAAK;AACvB,oBAAU,IAAI,KAAK,KAAK;AAAA,QAC1B,OAAO;AACL,oBAAU,QAAQ,OAAO,GAAG,EAAE,OAAO;AAAA,QACvC;AACA,cAAM,cAAc,IAAI,KAAK,OAAO;AACpC,oBAAY,QAAQ,QAAQ,QAAQ,IAAI,CAAC;AACzC,qBAAa,WAAW,KAAK;AAAA,UAC3B,MAAM;AAAA,UACN,SAAS;AAAA,YACP,KAAK;AAAA,YACL,SAAS;AAAA,cACP,SAAS,YAAY,mBAAmB;AAAA,YAC1C;AAAA,UACF;AAAA,UACA,MAAM,SAAU,OAAO;AACrB,gBAAI,CAAC,MAAO,QAAO;AACnB,kBAAM,OAAO,QAAQ,KAAK;AAC1B,kBAAM,UAAU,CAAC,KAAK,OAAO,IAAI,CAAC;AAClC,mBAAO;AAAA,UACT;AAAA,QACF,CAAC;AAAA,MACH;AACA,UAAI,OAAO,KAAK;AACd,YAAI;AACJ,YAAI,OAAO,QAAQ,OAAO;AACxB,gBAAM,QAAQ,oBAAI,KAAK;AACvB,oBAAU,IAAI,KAAK,KAAK;AAAA,QAC1B,OAAO;AACL,oBAAU,QAAQ,OAAO,GAAG,EAAE,OAAO;AAAA,QACvC;AACA,cAAM,kBAAkB,IAAI,KAAK,OAAO;AACxC,wBAAgB,QAAQ,QAAQ,QAAQ,IAAI,CAAC;AAC7C,qBAAa,WAAW,KAAK;AAAA,UAC3B,MAAM;AAAA,UACN,SAAS;AAAA,YACP,KAAK;AAAA,YACL,SAAS;AAAA,cACP,SAAS,gBAAgB,mBAAmB;AAAA,YAC9C;AAAA,UACF;AAAA,UACA,MAAM,SAAU,OAAO;AACrB,gBAAI,CAAC,MAAO,QAAO;AACnB,kBAAM,OAAO,QAAQ,KAAK;AAC1B,kBAAM,UAAU,CAAC,KAAK,OAAO,IAAI,CAAC;AAClC,mBAAO;AAAA,UACT;AAAA,QACF,CAAC;AAAA,MACH;AACA,aAAO;AAAA,IACT;AAAA,EACF;AACA,SAAO;AACT;AAIO,SAAS,oBACd,QACA,mBAC6C;AAC7C,SAAO,QAAQ,MAAM;AACnB,UAAM,aAAa,cAAc;AACjC,WAAO,kBAAkB,QAAQ,YAAY,iBAAiB;AAAA,EAChE,GAAG,CAAC,CAAC;AACP;",
6
6
  "names": []
7
7
  }
@@ -2,6 +2,6 @@
2
2
  "version": 3,
3
3
  "sources": ["../../../src/validators/utils/afm.ts"],
4
4
  "sourcesContent": ["export function validateAFM(afm: string): boolean {\n if (afm.length !== 9) {\n // \"afm should be 9 digits\"\n return false;\n }\n\n if (!/^\\d+$/.test(afm)) {\n // \"This is not a number\"\n return false;\n }\n\n if (afm === '0'.repeat(9)) {\n // \"This is zero number (000000000)\"\n return false;\n }\n\n const sum = afm\n .substring(0, 8)\n .split('')\n .reduce((s, v, i) => s + (parseInt(v) << (8 - i)), 0);\n\n const calc = sum % 11;\n const d9 = parseInt(afm[8]);\n const valid = calc % 10 === d9;\n return valid;\n}\n\nexport const AFM_VALIDATOR = {\n name: 'afm-validator',\n message: 'form.error.afm',\n test: (value): boolean => {\n if (value) {\n return validateAFM(value);\n }\n return true;\n },\n};\n"],
5
- "mappings": "AAAO,qBAAqB,KAAsB;AAChD,MAAI,IAAI,WAAW,GAAG;AAEpB,WAAO;AAAA;AAGT,MAAI,CAAC,QAAQ,KAAK,MAAM;AAEtB,WAAO;AAAA;AAGT,MAAI,QAAQ,IAAI,OAAO,IAAI;AAEzB,WAAO;AAAA;AAGT,QAAM,MAAM,IACT,UAAU,GAAG,GACb,MAAM,IACN,OAAO,CAAC,GAAG,GAAG,MAAM,IAAK,UAAS,MAAO,IAAI,IAAK;AAErD,QAAM,OAAO,MAAM;AACnB,QAAM,KAAK,SAAS,IAAI;AACxB,QAAM,QAAQ,OAAO,OAAO;AAC5B,SAAO;AAAA;AAGF,MAAM,gBAAgB;AAAA,EAC3B,MAAM;AAAA,EACN,SAAS;AAAA,EACT,MAAM,CAAC,UAAmB;AACxB,QAAI,OAAO;AACT,aAAO,YAAY;AAAA;AAErB,WAAO;AAAA;AAAA;",
5
+ "mappings": "AAAO,SAAS,YAAY,KAAsB;AAChD,MAAI,IAAI,WAAW,GAAG;AAEpB,WAAO;AAAA,EACT;AAEA,MAAI,CAAC,QAAQ,KAAK,GAAG,GAAG;AAEtB,WAAO;AAAA,EACT;AAEA,MAAI,QAAQ,IAAI,OAAO,CAAC,GAAG;AAEzB,WAAO;AAAA,EACT;AAEA,QAAM,MAAM,IACT,UAAU,GAAG,CAAC,EACd,MAAM,EAAE,EACR,OAAO,CAAC,GAAG,GAAG,MAAM,KAAK,SAAS,CAAC,KAAM,IAAI,IAAK,CAAC;AAEtD,QAAM,OAAO,MAAM;AACnB,QAAM,KAAK,SAAS,IAAI,CAAC,CAAC;AAC1B,QAAM,QAAQ,OAAO,OAAO;AAC5B,SAAO;AACT;AAEO,MAAM,gBAAgB;AAAA,EAC3B,MAAM;AAAA,EACN,SAAS;AAAA,EACT,MAAM,CAAC,UAAmB;AACxB,QAAI,OAAO;AACT,aAAO,YAAY,KAAK;AAAA,IAC1B;AACA,WAAO;AAAA,EACT;AACF;",
6
6
  "names": []
7
7
  }
@@ -1,17 +1,17 @@
1
1
  const DEFAULT_FILE_MAX_SIZE = 1e7;
2
2
  const FILE_MAX_SIZE_VALIDATOR = (field) => ({
3
3
  name: "file-max-size-validator",
4
- message: "form.error.file_size",
4
+ message: {
5
+ key: "form.error.file_size",
6
+ context: {
7
+ maxSizeToMb: (field?.extra?.limit.maxSize || DEFAULT_FILE_MAX_SIZE) / 1e6
8
+ }
9
+ },
5
10
  test: (value) => {
6
- if (field?.extra?.limit && field?.extra?.limit.maxSize && value) {
7
- for (const file of value) {
8
- if (file.size >= field.extra.limit.maxSize) {
9
- return false;
10
- }
11
- }
12
- } else if (value) {
11
+ if (value) {
13
12
  for (const file of value) {
14
- if (file.size >= DEFAULT_FILE_MAX_SIZE) {
13
+ const maxSize = field?.extra?.limit?.maxSize || DEFAULT_FILE_MAX_SIZE;
14
+ if (file.size > maxSize) {
15
15
  return false;
16
16
  }
17
17
  }
@@ -1,7 +1,7 @@
1
1
  {
2
2
  "version": 3,
3
3
  "sources": ["../../../src/validators/utils/file.ts"],
4
- "sourcesContent": ["import { FieldSpec } from '@digigov/form/types';\nimport { ValidatorSchema } from '@digigov/form/validators/types';\n\nconst DEFAULT_FILE_MAX_SIZE = 10000000;\n\nexport const FILE_MAX_SIZE_VALIDATOR = (field: FieldSpec): ValidatorSchema => ({\n name: 'file-max-size-validator',\n message: 'form.error.file_size',\n test: (value: File[]): boolean => {\n if (field?.extra?.limit && field?.extra?.limit.maxSize && value) {\n for (const file of value) {\n if (file.size >= field.extra.limit.maxSize) {\n return false;\n }\n }\n } else if (value) {\n for (const file of value) {\n if (file.size >= DEFAULT_FILE_MAX_SIZE) {\n return false;\n }\n }\n }\n return true;\n },\n});\n"],
5
- "mappings": "AAGA,MAAM,wBAAwB;AAEvB,MAAM,0BAA0B,CAAC,UAAuC;AAAA,EAC7E,MAAM;AAAA,EACN,SAAS;AAAA,EACT,MAAM,CAAC,UAA2B;AAChC,QAAI,OAAO,OAAO,SAAS,OAAO,OAAO,MAAM,WAAW,OAAO;AAC/D,iBAAW,QAAQ,OAAO;AACxB,YAAI,KAAK,QAAQ,MAAM,MAAM,MAAM,SAAS;AAC1C,iBAAO;AAAA;AAAA;AAAA,eAGF,OAAO;AAChB,iBAAW,QAAQ,OAAO;AACxB,YAAI,KAAK,QAAQ,uBAAuB;AACtC,iBAAO;AAAA;AAAA;AAAA;AAIb,WAAO;AAAA;AAAA;",
4
+ "sourcesContent": ["import { FieldSpec } from '@digigov/form/types';\nimport { ValidatorSchema } from '@digigov/form/validators/types';\n\nconst DEFAULT_FILE_MAX_SIZE = 10000000;\n\nexport const FILE_MAX_SIZE_VALIDATOR = (field: FieldSpec): ValidatorSchema => ({\n name: 'file-max-size-validator',\n message: {\n key: 'form.error.file_size',\n context: {\n maxSizeToMb: (field?.extra?.limit.maxSize || DEFAULT_FILE_MAX_SIZE) / 1000000,\n },\n },\n test: (value: File[]): boolean => {\n if (value) {\n for (const file of value) {\n const maxSize = field?.extra?.limit?.maxSize || DEFAULT_FILE_MAX_SIZE\n if (file.size > maxSize) {\n return false;\n }\n }\n }\n return true;\n },\n});\n"],
5
+ "mappings": "AAGA,MAAM,wBAAwB;AAEvB,MAAM,0BAA0B,CAAC,WAAuC;AAAA,EAC7E,MAAM;AAAA,EACN,SAAS;AAAA,IACP,KAAK;AAAA,IACL,SAAS;AAAA,MACP,cAAc,OAAO,OAAO,MAAM,WAAW,yBAAyB;AAAA,IACxE;AAAA,EACF;AAAA,EACA,MAAM,CAAC,UAA2B;AAChC,QAAI,OAAO;AACT,iBAAW,QAAQ,OAAO;AACxB,cAAM,UAAU,OAAO,OAAO,OAAO,WAAW;AAChD,YAAI,KAAK,OAAO,SAAS;AACvB,iBAAO;AAAA,QACT;AAAA,MACF;AAAA,IACF;AACA,WAAO;AAAA,EACT;AACF;",
6
6
  "names": []
7
7
  }
@@ -2,6 +2,6 @@
2
2
  "version": 3,
3
3
  "sources": ["../../../src/validators/utils/iban.ts"],
4
4
  "sourcesContent": ["import { FieldSpec } from '@digigov/form/types';\nimport { ValidatorSchema } from '@digigov/form/validators/types';\nexport function validateIban(value: string, countryCode: string): boolean {\n value = value.replace(/\\s/g, '').replace(/-/g, '');\n if (value.match(/^[0-9]*$/i)) {\n // this is for greek iban without the country code\n if (value.length !== 25) {\n return false;\n }\n } else {\n value = value.toUpperCase();\n if (countryCode) {\n if (!value.startsWith(countryCode.toUpperCase())) {\n return false;\n }\n if (value.length === ibanCountryCodesLengths[countryCode.toUpperCase()]) {\n return true;\n }\n }\n if (value.length !== 27) {\n // this is for greek iban\n return false;\n }\n }\n return true;\n}\n\nexport const IBAN_VALIDATOR = (field: FieldSpec): ValidatorSchema => {\n const countryCode = field?.extra?.country;\n return {\n name: 'iban-validator',\n message: 'form.error.iban',\n test: (value: string): boolean => {\n if (!value) {\n return true;\n }\n return validateIban(value, countryCode);\n },\n };\n};\n\nconst ibanCountryCodesLengths = {\n AD: 24,\n AT: 20,\n AZ: 28,\n BH: 22,\n BY: 28,\n BE: 16,\n BA: 20,\n BR: 29,\n BG: 22,\n CR: 22,\n HR: 21,\n CY: 28,\n CZ: 24,\n DK: 18,\n DO: 28,\n EG: 29,\n SV: 28,\n EE: 20,\n FO: 18,\n FI: 18,\n FR: 27,\n GE: 22,\n DE: 22,\n GI: 23,\n GR: 27,\n GL: 18,\n GT: 28,\n VA: 22,\n HU: 28,\n IS: 26,\n IQ: 23,\n IE: 22,\n IL: 23,\n IT: 27,\n JO: 30,\n KZ: 20,\n XK: 20,\n KW: 30,\n LV: 21,\n LB: 28,\n LI: 21,\n LT: 20,\n LU: 20,\n MT: 31,\n MR: 27,\n MU: 30,\n MD: 24,\n MC: 27,\n ME: 22,\n NL: 18,\n MK: 19,\n NO: 15,\n PK: 24,\n PS: 29,\n PL: 28,\n PT: 25,\n QA: 29,\n RO: 24,\n LC: 32,\n SM: 27,\n ST: 25,\n SA: 24,\n RS: 22,\n SC: 31,\n SK: 24,\n SI: 19,\n ES: 24,\n SE: 24,\n CH: 21,\n TL: 23,\n TN: 24,\n TR: 26,\n UA: 29,\n AE: 23,\n GB: 22,\n VG: 24,\n};\n"],
5
- "mappings": "AAEO,sBAAsB,OAAe,aAA8B;AACxE,UAAQ,MAAM,QAAQ,OAAO,IAAI,QAAQ,MAAM;AAC/C,MAAI,MAAM,MAAM,cAAc;AAE5B,QAAI,MAAM,WAAW,IAAI;AACvB,aAAO;AAAA;AAAA,SAEJ;AACL,YAAQ,MAAM;AACd,QAAI,aAAa;AACf,UAAI,CAAC,MAAM,WAAW,YAAY,gBAAgB;AAChD,eAAO;AAAA;AAET,UAAI,MAAM,WAAW,wBAAwB,YAAY,gBAAgB;AACvE,eAAO;AAAA;AAAA;AAGX,QAAI,MAAM,WAAW,IAAI;AAEvB,aAAO;AAAA;AAAA;AAGX,SAAO;AAAA;AAGF,MAAM,iBAAiB,CAAC,UAAsC;AACnE,QAAM,cAAc,OAAO,OAAO;AAClC,SAAO;AAAA,IACL,MAAM;AAAA,IACN,SAAS;AAAA,IACT,MAAM,CAAC,UAA2B;AAChC,UAAI,CAAC,OAAO;AACV,eAAO;AAAA;AAET,aAAO,aAAa,OAAO;AAAA;AAAA;AAAA;AAKjC,MAAM,0BAA0B;AAAA,EAC9B,IAAI;AAAA,EACJ,IAAI;AAAA,EACJ,IAAI;AAAA,EACJ,IAAI;AAAA,EACJ,IAAI;AAAA,EACJ,IAAI;AAAA,EACJ,IAAI;AAAA,EACJ,IAAI;AAAA,EACJ,IAAI;AAAA,EACJ,IAAI;AAAA,EACJ,IAAI;AAAA,EACJ,IAAI;AAAA,EACJ,IAAI;AAAA,EACJ,IAAI;AAAA,EACJ,IAAI;AAAA,EACJ,IAAI;AAAA,EACJ,IAAI;AAAA,EACJ,IAAI;AAAA,EACJ,IAAI;AAAA,EACJ,IAAI;AAAA,EACJ,IAAI;AAAA,EACJ,IAAI;AAAA,EACJ,IAAI;AAAA,EACJ,IAAI;AAAA,EACJ,IAAI;AAAA,EACJ,IAAI;AAAA,EACJ,IAAI;AAAA,EACJ,IAAI;AAAA,EACJ,IAAI;AAAA,EACJ,IAAI;AAAA,EACJ,IAAI;AAAA,EACJ,IAAI;AAAA,EACJ,IAAI;AAAA,EACJ,IAAI;AAAA,EACJ,IAAI;AAAA,EACJ,IAAI;AAAA,EACJ,IAAI;AAAA,EACJ,IAAI;AAAA,EACJ,IAAI;AAAA,EACJ,IAAI;AAAA,EACJ,IAAI;AAAA,EACJ,IAAI;AAAA,EACJ,IAAI;AAAA,EACJ,IAAI;AAAA,EACJ,IAAI;AAAA,EACJ,IAAI;AAAA,EACJ,IAAI;AAAA,EACJ,IAAI;AAAA,EACJ,IAAI;AAAA,EACJ,IAAI;AAAA,EACJ,IAAI;AAAA,EACJ,IAAI;AAAA,EACJ,IAAI;AAAA,EACJ,IAAI;AAAA,EACJ,IAAI;AAAA,EACJ,IAAI;AAAA,EACJ,IAAI;AAAA,EACJ,IAAI;AAAA,EACJ,IAAI;AAAA,EACJ,IAAI;AAAA,EACJ,IAAI;AAAA,EACJ,IAAI;AAAA,EACJ,IAAI;AAAA,EACJ,IAAI;AAAA,EACJ,IAAI;AAAA,EACJ,IAAI;AAAA,EACJ,IAAI;AAAA,EACJ,IAAI;AAAA,EACJ,IAAI;AAAA,EACJ,IAAI;AAAA,EACJ,IAAI;AAAA,EACJ,IAAI;AAAA,EACJ,IAAI;AAAA,EACJ,IAAI;AAAA,EACJ,IAAI;AAAA,EACJ,IAAI;AAAA;",
5
+ "mappings": "AAEO,SAAS,aAAa,OAAe,aAA8B;AACxE,UAAQ,MAAM,QAAQ,OAAO,EAAE,EAAE,QAAQ,MAAM,EAAE;AACjD,MAAI,MAAM,MAAM,WAAW,GAAG;AAE5B,QAAI,MAAM,WAAW,IAAI;AACvB,aAAO;AAAA,IACT;AAAA,EACF,OAAO;AACL,YAAQ,MAAM,YAAY;AAC1B,QAAI,aAAa;AACf,UAAI,CAAC,MAAM,WAAW,YAAY,YAAY,CAAC,GAAG;AAChD,eAAO;AAAA,MACT;AACA,UAAI,MAAM,WAAW,wBAAwB,YAAY,YAAY,CAAC,GAAG;AACvE,eAAO;AAAA,MACT;AAAA,IACF;AACA,QAAI,MAAM,WAAW,IAAI;AAEvB,aAAO;AAAA,IACT;AAAA,EACF;AACA,SAAO;AACT;AAEO,MAAM,iBAAiB,CAAC,UAAsC;AACnE,QAAM,cAAc,OAAO,OAAO;AAClC,SAAO;AAAA,IACL,MAAM;AAAA,IACN,SAAS;AAAA,IACT,MAAM,CAAC,UAA2B;AAChC,UAAI,CAAC,OAAO;AACV,eAAO;AAAA,MACT;AACA,aAAO,aAAa,OAAO,WAAW;AAAA,IACxC;AAAA,EACF;AACF;AAEA,MAAM,0BAA0B;AAAA,EAC9B,IAAI;AAAA,EACJ,IAAI;AAAA,EACJ,IAAI;AAAA,EACJ,IAAI;AAAA,EACJ,IAAI;AAAA,EACJ,IAAI;AAAA,EACJ,IAAI;AAAA,EACJ,IAAI;AAAA,EACJ,IAAI;AAAA,EACJ,IAAI;AAAA,EACJ,IAAI;AAAA,EACJ,IAAI;AAAA,EACJ,IAAI;AAAA,EACJ,IAAI;AAAA,EACJ,IAAI;AAAA,EACJ,IAAI;AAAA,EACJ,IAAI;AAAA,EACJ,IAAI;AAAA,EACJ,IAAI;AAAA,EACJ,IAAI;AAAA,EACJ,IAAI;AAAA,EACJ,IAAI;AAAA,EACJ,IAAI;AAAA,EACJ,IAAI;AAAA,EACJ,IAAI;AAAA,EACJ,IAAI;AAAA,EACJ,IAAI;AAAA,EACJ,IAAI;AAAA,EACJ,IAAI;AAAA,EACJ,IAAI;AAAA,EACJ,IAAI;AAAA,EACJ,IAAI;AAAA,EACJ,IAAI;AAAA,EACJ,IAAI;AAAA,EACJ,IAAI;AAAA,EACJ,IAAI;AAAA,EACJ,IAAI;AAAA,EACJ,IAAI;AAAA,EACJ,IAAI;AAAA,EACJ,IAAI;AAAA,EACJ,IAAI;AAAA,EACJ,IAAI;AAAA,EACJ,IAAI;AAAA,EACJ,IAAI;AAAA,EACJ,IAAI;AAAA,EACJ,IAAI;AAAA,EACJ,IAAI;AAAA,EACJ,IAAI;AAAA,EACJ,IAAI;AAAA,EACJ,IAAI;AAAA,EACJ,IAAI;AAAA,EACJ,IAAI;AAAA,EACJ,IAAI;AAAA,EACJ,IAAI;AAAA,EACJ,IAAI;AAAA,EACJ,IAAI;AAAA,EACJ,IAAI;AAAA,EACJ,IAAI;AAAA,EACJ,IAAI;AAAA,EACJ,IAAI;AAAA,EACJ,IAAI;AAAA,EACJ,IAAI;AAAA,EACJ,IAAI;AAAA,EACJ,IAAI;AAAA,EACJ,IAAI;AAAA,EACJ,IAAI;AAAA,EACJ,IAAI;AAAA,EACJ,IAAI;AAAA,EACJ,IAAI;AAAA,EACJ,IAAI;AAAA,EACJ,IAAI;AAAA,EACJ,IAAI;AAAA,EACJ,IAAI;AAAA,EACJ,IAAI;AAAA,EACJ,IAAI;AAAA,EACJ,IAAI;AACN;",
6
6
  "names": []
7
7
  }
@@ -8,7 +8,7 @@ function getImageDimensions(file) {
8
8
  reader.onload = (event) => {
9
9
  const img = new Image();
10
10
  img.onload = () => {
11
- resolve({width: img.width, height: img.height});
11
+ resolve({ width: img.width, height: img.height });
12
12
  };
13
13
  img.onerror = reject;
14
14
  const result = event?.target?.result;
@@ -51,7 +51,7 @@ const IMAGE_DIMENSION_VALIDATOR = (field) => ({
51
51
  return true;
52
52
  }
53
53
  const file = value[0];
54
- const {width, height} = await getImageDimensions(file);
54
+ const { width, height } = await getImageDimensions(file);
55
55
  const maxHeight = field?.extra?.limit?.maxHeight || DEFAULT_IMAGE_MAX_HEIGHT_SIZE;
56
56
  const maxWidth = field?.extra?.limit?.maxWidth || DEFAULT_IMAGE_MAX_WIDTH_SIZE;
57
57
  const minHeight = field?.extra?.limit?.minHeight || DEFAULT_IMAGE_MIN_HEIGHT_SIZE;
@@ -2,6 +2,6 @@
2
2
  "version": 3,
3
3
  "sources": ["../../../src/validators/utils/image.ts"],
4
4
  "sourcesContent": ["import { FieldSpec } from '@digigov/form/types';\nimport { ValidatorSchema } from '@digigov/form/validators/types';\n\nconst DEFAULT_IMAGE_MAX_HEIGHT_SIZE = 2000;\nconst DEFAULT_IMAGE_MAX_WIDTH_SIZE = 2000;\nconst DEFAULT_IMAGE_MIN_HEIGHT_SIZE = 100;\nconst DEFAULT_IMAGE_MIN_WIDTH_SIZE = 100;\n\nfunction getImageDimensions(\n file: File\n): Promise<{ width: number; height: number }> {\n return new Promise((resolve, reject) => {\n const reader = new FileReader();\n reader.onload = (event) => {\n const img = new Image();\n img.onload = () => {\n resolve({ width: img.width, height: img.height });\n };\n img.onerror = reject;\n const result = event?.target?.result;\n if (result && typeof result === 'string') {\n img.src = result;\n } else {\n reject(new Error('Invalid file format'));\n }\n };\n reader.onerror = reject;\n reader.readAsDataURL(file);\n });\n}\n\nexport const IMAGE_DIMENSION_VALIDATOR = (\n field: FieldSpec\n): ValidatorSchema => ({\n name: 'image-dimension-validator',\n message: (value: any) => {\n const minHeight =\n field?.extra?.limit?.minHeight || DEFAULT_IMAGE_MIN_HEIGHT_SIZE;\n const minWidth =\n field?.extra?.limit?.minWidth || DEFAULT_IMAGE_MIN_WIDTH_SIZE;\n const maxHeight =\n field?.extra?.limit?.maxHeight || DEFAULT_IMAGE_MAX_HEIGHT_SIZE;\n const maxWidth =\n field?.extra?.limit?.maxWidth || DEFAULT_IMAGE_MAX_WIDTH_SIZE;\n if (!value || value.length === 0) {\n return {\n name: 'image-validator',\n message: 'form.error.required',\n };\n } else {\n return {\n key: 'form.error.image.image_dimension_size',\n context: {\n maxHeight: maxHeight,\n maxWidth: maxWidth,\n minHeight: minHeight,\n minWidth: minWidth,\n },\n };\n }\n },\n test: async (value: File[]): Promise<boolean> => {\n if (!value || value.length === 0) {\n return true;\n }\n const file = value[0];\n const { width, height } = await getImageDimensions(file);\n const maxHeight =\n field?.extra?.limit?.maxHeight || DEFAULT_IMAGE_MAX_HEIGHT_SIZE;\n const maxWidth =\n field?.extra?.limit?.maxWidth || DEFAULT_IMAGE_MAX_WIDTH_SIZE;\n const minHeight =\n field?.extra?.limit?.minHeight || DEFAULT_IMAGE_MIN_HEIGHT_SIZE;\n const minWidth =\n field?.extra?.limit?.minWidth || DEFAULT_IMAGE_MIN_WIDTH_SIZE;\n if (!file) {\n return true;\n }\n try {\n if (height > maxHeight || width > maxWidth) {\n return false;\n }\n if (height < minHeight || width < minWidth) {\n return false;\n }\n return true;\n } catch (error) {\n console.error('Error getting image dimensions:', error);\n return false; // Return false in case of an error.\n }\n },\n});\n"],
5
- "mappings": "AAGA,MAAM,gCAAgC;AACtC,MAAM,+BAA+B;AACrC,MAAM,gCAAgC;AACtC,MAAM,+BAA+B;AAErC,4BACE,MAC4C;AAC5C,SAAO,IAAI,QAAQ,CAAC,SAAS,WAAW;AACtC,UAAM,SAAS,IAAI;AACnB,WAAO,SAAS,CAAC,UAAU;AACzB,YAAM,MAAM,IAAI;AAChB,UAAI,SAAS,MAAM;AACjB,gBAAQ,CAAE,OAAO,IAAI,OAAO,QAAQ,IAAI;AAAA;AAE1C,UAAI,UAAU;AACd,YAAM,SAAS,OAAO,QAAQ;AAC9B,UAAI,UAAU,OAAO,WAAW,UAAU;AACxC,YAAI,MAAM;AAAA,aACL;AACL,eAAO,IAAI,MAAM;AAAA;AAAA;AAGrB,WAAO,UAAU;AACjB,WAAO,cAAc;AAAA;AAAA;AAIlB,MAAM,4BAA4B,CACvC,UACqB;AAAA,EACrB,MAAM;AAAA,EACN,SAAS,CAAC,UAAe;AACvB,UAAM,YACJ,OAAO,OAAO,OAAO,aAAa;AACpC,UAAM,WACJ,OAAO,OAAO,OAAO,YAAY;AACnC,UAAM,YACJ,OAAO,OAAO,OAAO,aAAa;AACpC,UAAM,WACJ,OAAO,OAAO,OAAO,YAAY;AACnC,QAAI,CAAC,SAAS,MAAM,WAAW,GAAG;AAChC,aAAO;AAAA,QACL,MAAM;AAAA,QACN,SAAS;AAAA;AAAA,WAEN;AACL,aAAO;AAAA,QACL,KAAK;AAAA,QACL,SAAS;AAAA,UACP;AAAA,UACA;AAAA,UACA;AAAA,UACA;AAAA;AAAA;AAAA;AAAA;AAAA,EAKR,MAAM,OAAO,UAAoC;AAC/C,QAAI,CAAC,SAAS,MAAM,WAAW,GAAG;AAChC,aAAO;AAAA;AAET,UAAM,OAAO,MAAM;AACnB,UAAM,CAAE,OAAO,UAAW,MAAM,mBAAmB;AACnD,UAAM,YACJ,OAAO,OAAO,OAAO,aAAa;AACpC,UAAM,WACJ,OAAO,OAAO,OAAO,YAAY;AACnC,UAAM,YACJ,OAAO,OAAO,OAAO,aAAa;AACpC,UAAM,WACJ,OAAO,OAAO,OAAO,YAAY;AACnC,QAAI,CAAC,MAAM;AACT,aAAO;AAAA;AAET,QAAI;AACF,UAAI,SAAS,aAAa,QAAQ,UAAU;AAC1C,eAAO;AAAA;AAET,UAAI,SAAS,aAAa,QAAQ,UAAU;AAC1C,eAAO;AAAA;AAET,aAAO;AAAA,aACA,OAAP;AACA,cAAQ,MAAM,mCAAmC;AACjD,aAAO;AAAA;AAAA;AAAA;",
5
+ "mappings": "AAGA,MAAM,gCAAgC;AACtC,MAAM,+BAA+B;AACrC,MAAM,gCAAgC;AACtC,MAAM,+BAA+B;AAErC,SAAS,mBACP,MAC4C;AAC5C,SAAO,IAAI,QAAQ,CAAC,SAAS,WAAW;AACtC,UAAM,SAAS,IAAI,WAAW;AAC9B,WAAO,SAAS,CAAC,UAAU;AACzB,YAAM,MAAM,IAAI,MAAM;AACtB,UAAI,SAAS,MAAM;AACjB,gBAAQ,EAAE,OAAO,IAAI,OAAO,QAAQ,IAAI,OAAO,CAAC;AAAA,MAClD;AACA,UAAI,UAAU;AACd,YAAM,SAAS,OAAO,QAAQ;AAC9B,UAAI,UAAU,OAAO,WAAW,UAAU;AACxC,YAAI,MAAM;AAAA,MACZ,OAAO;AACL,eAAO,IAAI,MAAM,qBAAqB,CAAC;AAAA,MACzC;AAAA,IACF;AACA,WAAO,UAAU;AACjB,WAAO,cAAc,IAAI;AAAA,EAC3B,CAAC;AACH;AAEO,MAAM,4BAA4B,CACvC,WACqB;AAAA,EACrB,MAAM;AAAA,EACN,SAAS,CAAC,UAAe;AACvB,UAAM,YACJ,OAAO,OAAO,OAAO,aAAa;AACpC,UAAM,WACJ,OAAO,OAAO,OAAO,YAAY;AACnC,UAAM,YACJ,OAAO,OAAO,OAAO,aAAa;AACpC,UAAM,WACJ,OAAO,OAAO,OAAO,YAAY;AACnC,QAAI,CAAC,SAAS,MAAM,WAAW,GAAG;AAChC,aAAO;AAAA,QACL,MAAM;AAAA,QACN,SAAS;AAAA,MACX;AAAA,IACF,OAAO;AACL,aAAO;AAAA,QACL,KAAK;AAAA,QACL,SAAS;AAAA,UACP;AAAA,UACA;AAAA,UACA;AAAA,UACA;AAAA,QACF;AAAA,MACF;AAAA,IACF;AAAA,EACF;AAAA,EACA,MAAM,OAAO,UAAoC;AAC/C,QAAI,CAAC,SAAS,MAAM,WAAW,GAAG;AAChC,aAAO;AAAA,IACT;AACA,UAAM,OAAO,MAAM,CAAC;AACpB,UAAM,EAAE,OAAO,OAAO,IAAI,MAAM,mBAAmB,IAAI;AACvD,UAAM,YACJ,OAAO,OAAO,OAAO,aAAa;AACpC,UAAM,WACJ,OAAO,OAAO,OAAO,YAAY;AACnC,UAAM,YACJ,OAAO,OAAO,OAAO,aAAa;AACpC,UAAM,WACJ,OAAO,OAAO,OAAO,YAAY;AACnC,QAAI,CAAC,MAAM;AACT,aAAO;AAAA,IACT;AACA,QAAI;AACF,UAAI,SAAS,aAAa,QAAQ,UAAU;AAC1C,eAAO;AAAA,MACT;AACA,UAAI,SAAS,aAAa,QAAQ,UAAU;AAC1C,eAAO;AAAA,MACT;AACA,aAAO;AAAA,IACT,SAAS,OAAO;AACd,cAAQ,MAAM,mCAAmC,KAAK;AACtD,aAAO;AAAA,IACT;AAAA,EACF;AACF;",
6
6
  "names": []
7
7
  }
@@ -65,7 +65,11 @@ function computeShape(fields, yupTypeMap, validatorRegistry) {
65
65
  fieldSchemas[field.key] = yupField;
66
66
  });
67
67
  for (const objectKey in objectFields) {
68
- fieldSchemas[objectKey] = getYupObjectShape(objectFields[objectKey], yupTypeMap, validatorRegistry);
68
+ fieldSchemas[objectKey] = getYupObjectShape(
69
+ objectFields[objectKey],
70
+ yupTypeMap,
71
+ validatorRegistry
72
+ );
69
73
  }
70
74
  return fieldSchemas;
71
75
  }
@@ -75,7 +79,11 @@ function getYupObjectShape(fields, yupTypeMap, validatorRegistry) {
75
79
  return yup.object().shape(fieldSchemas);
76
80
  }
77
81
  return yup.lazy(function() {
78
- const fieldSchemas = computeShape(Object.values(fields.current), yupTypeMap, validatorRegistry);
82
+ const fieldSchemas = computeShape(
83
+ Object.values(fields.current),
84
+ yupTypeMap,
85
+ validatorRegistry
86
+ );
79
87
  return yup.object().shape(fieldSchemas);
80
88
  });
81
89
  }
@@ -2,6 +2,6 @@
2
2
  "version": 3,
3
3
  "sources": ["../../../src/validators/utils/index.ts"],
4
4
  "sourcesContent": ["import * as yup from 'yup';\nimport { FieldSpec } from '@digigov/form/types';\nimport { ValidatorSchema } from '@digigov/form/validators/types';\n\nexport * from '@digigov/form/validators/utils/afm';\nexport * from '@digigov/form/validators/utils/file';\nexport * from '@digigov/form/validators/utils/iban';\nexport * from '@digigov/form/validators/utils/otp';\nexport * from '@digigov/form/validators/utils/image';\nexport * from '@digigov/form/validators/utils/phone';\nexport * from '@digigov/form/validators/utils/postal_code';\nexport * from '@digigov/form/validators/utils/uuid4';\nexport * from '@digigov/form/validators/utils/text_limit';\n\nexport function getYupField(field: FieldSpec, yupTypeMap: Record<string, any>) {\n const yupField = yupTypeMap[field?.type || 'string'] || yupTypeMap['string'];\n return yupField(field);\n}\nexport function computeShape(\n fields: FieldSpec[],\n yupTypeMap: Record<string, ValidatorSchema>,\n validatorRegistry: Record<string, ValidatorSchema[]> | undefined\n) {\n const fieldSchemas = {};\n const objectFields: Record<string, FieldSpec[]> = {};\n fields.forEach((field) => {\n let yupField = getYupField(field, yupTypeMap);\n if (field.condition) {\n for (const key in field.condition) {\n let then: any, otherwise: any;\n if (field.condition[key].then) {\n if (field.condition[key].then?.required === false) {\n then = yupField.nullable();\n } else if (field.condition[key].then?.required === true) {\n then = yupField.nullable().required('form.error.required');\n }\n }\n if (field.condition[key].else) {\n if (field.condition[key].else?.required === false) {\n otherwise = yupField.nullable();\n } else if (field.condition[key].else?.required === true) {\n otherwise = yupField.nullable().required('form.error.required');\n }\n }\n if (then || otherwise) {\n yupField = yupField.when(key, {\n is: (val) => {\n //@ts-ignore\n const is = field.condition[key].is;\n if (is === val || (Array.isArray(val) && val.includes(is))) {\n return true;\n } else {\n return false;\n }\n },\n then,\n otherwise,\n });\n }\n }\n } else if (field.required) {\n yupField = yupField.nullable().required('form.error.required');\n }\n if (validatorRegistry && field.type && validatorRegistry[field.type]) {\n validatorRegistry[field.type].forEach((validator: any) => {\n yupField = yupField.test(validator);\n });\n }\n if (field.validators) {\n field.validators.forEach((validator) => {\n yupField = yupField.test(validator);\n });\n }\n fieldSchemas[field.key] = yupField;\n });\n for (const objectKey in objectFields) {\n fieldSchemas[objectKey] = getYupObjectShape(\n objectFields[objectKey],\n yupTypeMap,\n validatorRegistry\n );\n }\n return fieldSchemas;\n}\n\nexport function getYupObjectShape(\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\n fields: FieldSpec[] | any,\n yupTypeMap: Record<string, any>,\n validatorRegistry?: Record<string, ValidatorSchema[]>\n) {\n if (!fields.current) {\n const fieldSchemas = computeShape(fields, yupTypeMap, validatorRegistry);\n return yup.object().shape(fieldSchemas);\n }\n\n return yup.lazy(function () {\n const fieldSchemas = computeShape(\n Object.values(fields.current),\n yupTypeMap,\n validatorRegistry\n );\n return yup.object().shape(fieldSchemas);\n });\n}\n"],
5
- "mappings": "AAAA;AAIA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AAEO,qBAAqB,OAAkB,YAAiC;AAC7E,QAAM,WAAW,WAAW,OAAO,QAAQ,aAAa,WAAW;AACnE,SAAO,SAAS;AAAA;AAEX,sBACL,QACA,YACA,mBACA;AACA,QAAM,eAAe;AACrB,QAAM,eAA4C;AAClD,SAAO,QAAQ,CAAC,UAAU;AACxB,QAAI,WAAW,YAAY,OAAO;AAClC,QAAI,MAAM,WAAW;AACnB,iBAAW,OAAO,MAAM,WAAW;AACjC,YAAI,MAAW;AACf,YAAI,MAAM,UAAU,KAAK,MAAM;AAC7B,cAAI,MAAM,UAAU,KAAK,MAAM,aAAa,OAAO;AACjD,mBAAO,SAAS;AAAA,qBACP,MAAM,UAAU,KAAK,MAAM,aAAa,MAAM;AACvD,mBAAO,SAAS,WAAW,SAAS;AAAA;AAAA;AAGxC,YAAI,MAAM,UAAU,KAAK,MAAM;AAC7B,cAAI,MAAM,UAAU,KAAK,MAAM,aAAa,OAAO;AACjD,wBAAY,SAAS;AAAA,qBACZ,MAAM,UAAU,KAAK,MAAM,aAAa,MAAM;AACvD,wBAAY,SAAS,WAAW,SAAS;AAAA;AAAA;AAG7C,YAAI,QAAQ,WAAW;AACrB,qBAAW,SAAS,KAAK,KAAK;AAAA,YAC5B,IAAI,CAAC,QAAQ;AAEX,oBAAM,KAAK,MAAM,UAAU,KAAK;AAChC,kBAAI,OAAO,OAAQ,MAAM,QAAQ,QAAQ,IAAI,SAAS,KAAM;AAC1D,uBAAO;AAAA,qBACF;AACL,uBAAO;AAAA;AAAA;AAAA,YAGX;AAAA,YACA;AAAA;AAAA;AAAA;AAAA,eAIG,MAAM,UAAU;AACzB,iBAAW,SAAS,WAAW,SAAS;AAAA;AAE1C,QAAI,qBAAqB,MAAM,QAAQ,kBAAkB,MAAM,OAAO;AACpE,wBAAkB,MAAM,MAAM,QAAQ,CAAC,cAAmB;AACxD,mBAAW,SAAS,KAAK;AAAA;AAAA;AAG7B,QAAI,MAAM,YAAY;AACpB,YAAM,WAAW,QAAQ,CAAC,cAAc;AACtC,mBAAW,SAAS,KAAK;AAAA;AAAA;AAG7B,iBAAa,MAAM,OAAO;AAAA;AAE5B,aAAW,aAAa,cAAc;AACpC,iBAAa,aAAa,kBACxB,aAAa,YACb,YACA;AAAA;AAGJ,SAAO;AAAA;AAGF,2BAEL,QACA,YACA,mBACA;AACA,MAAI,CAAC,OAAO,SAAS;AACnB,UAAM,eAAe,aAAa,QAAQ,YAAY;AACtD,WAAO,IAAI,SAAS,MAAM;AAAA;AAG5B,SAAO,IAAI,KAAK,WAAY;AAC1B,UAAM,eAAe,aACnB,OAAO,OAAO,OAAO,UACrB,YACA;AAEF,WAAO,IAAI,SAAS,MAAM;AAAA;AAAA;",
5
+ "mappings": "AAAA,YAAY,SAAS;AAIrB,cAAc;AACd,cAAc;AACd,cAAc;AACd,cAAc;AACd,cAAc;AACd,cAAc;AACd,cAAc;AACd,cAAc;AACd,cAAc;AAEP,SAAS,YAAY,OAAkB,YAAiC;AAC7E,QAAM,WAAW,WAAW,OAAO,QAAQ,QAAQ,KAAK,WAAW,QAAQ;AAC3E,SAAO,SAAS,KAAK;AACvB;AACO,SAAS,aACd,QACA,YACA,mBACA;AACA,QAAM,eAAe,CAAC;AACtB,QAAM,eAA4C,CAAC;AACnD,SAAO,QAAQ,CAAC,UAAU;AACxB,QAAI,WAAW,YAAY,OAAO,UAAU;AAC5C,QAAI,MAAM,WAAW;AACnB,iBAAW,OAAO,MAAM,WAAW;AACjC,YAAI,MAAW;AACf,YAAI,MAAM,UAAU,GAAG,EAAE,MAAM;AAC7B,cAAI,MAAM,UAAU,GAAG,EAAE,MAAM,aAAa,OAAO;AACjD,mBAAO,SAAS,SAAS;AAAA,UAC3B,WAAW,MAAM,UAAU,GAAG,EAAE,MAAM,aAAa,MAAM;AACvD,mBAAO,SAAS,SAAS,EAAE,SAAS,qBAAqB;AAAA,UAC3D;AAAA,QACF;AACA,YAAI,MAAM,UAAU,GAAG,EAAE,MAAM;AAC7B,cAAI,MAAM,UAAU,GAAG,EAAE,MAAM,aAAa,OAAO;AACjD,wBAAY,SAAS,SAAS;AAAA,UAChC,WAAW,MAAM,UAAU,GAAG,EAAE,MAAM,aAAa,MAAM;AACvD,wBAAY,SAAS,SAAS,EAAE,SAAS,qBAAqB;AAAA,UAChE;AAAA,QACF;AACA,YAAI,QAAQ,WAAW;AACrB,qBAAW,SAAS,KAAK,KAAK;AAAA,YAC5B,IAAI,CAAC,QAAQ;AAEX,oBAAM,KAAK,MAAM,UAAU,GAAG,EAAE;AAChC,kBAAI,OAAO,OAAQ,MAAM,QAAQ,GAAG,KAAK,IAAI,SAAS,EAAE,GAAI;AAC1D,uBAAO;AAAA,cACT,OAAO;AACL,uBAAO;AAAA,cACT;AAAA,YACF;AAAA,YACA;AAAA,YACA;AAAA,UACF,CAAC;AAAA,QACH;AAAA,MACF;AAAA,IACF,WAAW,MAAM,UAAU;AACzB,iBAAW,SAAS,SAAS,EAAE,SAAS,qBAAqB;AAAA,IAC/D;AACA,QAAI,qBAAqB,MAAM,QAAQ,kBAAkB,MAAM,IAAI,GAAG;AACpE,wBAAkB,MAAM,IAAI,EAAE,QAAQ,CAAC,cAAmB;AACxD,mBAAW,SAAS,KAAK,SAAS;AAAA,MACpC,CAAC;AAAA,IACH;AACA,QAAI,MAAM,YAAY;AACpB,YAAM,WAAW,QAAQ,CAAC,cAAc;AACtC,mBAAW,SAAS,KAAK,SAAS;AAAA,MACpC,CAAC;AAAA,IACH;AACA,iBAAa,MAAM,GAAG,IAAI;AAAA,EAC5B,CAAC;AACD,aAAW,aAAa,cAAc;AACpC,iBAAa,SAAS,IAAI;AAAA,MACxB,aAAa,SAAS;AAAA,MACtB;AAAA,MACA;AAAA,IACF;AAAA,EACF;AACA,SAAO;AACT;AAEO,SAAS,kBAEd,QACA,YACA,mBACA;AACA,MAAI,CAAC,OAAO,SAAS;AACnB,UAAM,eAAe,aAAa,QAAQ,YAAY,iBAAiB;AACvE,WAAO,IAAI,OAAO,EAAE,MAAM,YAAY;AAAA,EACxC;AAEA,SAAO,IAAI,KAAK,WAAY;AAC1B,UAAM,eAAe;AAAA,MACnB,OAAO,OAAO,OAAO,OAAO;AAAA,MAC5B;AAAA,MACA;AAAA,IACF;AACA,WAAO,IAAI,OAAO,EAAE,MAAM,YAAY;AAAA,EACxC,CAAC;AACH;",
6
6
  "names": []
7
7
  }
@@ -2,6 +2,6 @@
2
2
  "version": 3,
3
3
  "sources": ["../../../src/validators/utils/int.ts"],
4
4
  "sourcesContent": ["import { ValidatorSchema } from '@digigov/form/validators/types';\n\nexport function validateIntNumber(number: number): boolean {\n if (number === undefined) {\n return false;\n } else {\n return Number.isInteger(number) && Number(number) > 0;\n }\n}\n\nexport const INT_VALIDATOR = (): ValidatorSchema => {\n return {\n name: 'int-validator',\n message: 'form.error.positive_integer_number',\n test: (value: number): boolean => {\n if (value === null) {\n return true;\n }\n return validateIntNumber(value);\n },\n };\n};\n"],
5
- "mappings": "AAEO,2BAA2B,QAAyB;AACzD,MAAI,WAAW,QAAW;AACxB,WAAO;AAAA,SACF;AACL,WAAO,OAAO,UAAU,WAAW,OAAO,UAAU;AAAA;AAAA;AAIjD,MAAM,gBAAgB,MAAuB;AAClD,SAAO;AAAA,IACL,MAAM;AAAA,IACN,SAAS;AAAA,IACT,MAAM,CAAC,UAA2B;AAChC,UAAI,UAAU,MAAM;AAClB,eAAO;AAAA;AAET,aAAO,kBAAkB;AAAA;AAAA;AAAA;",
5
+ "mappings": "AAEO,SAAS,kBAAkB,QAAyB;AACzD,MAAI,WAAW,QAAW;AACxB,WAAO;AAAA,EACT,OAAO;AACL,WAAO,OAAO,UAAU,MAAM,KAAK,OAAO,MAAM,IAAI;AAAA,EACtD;AACF;AAEO,MAAM,gBAAgB,MAAuB;AAClD,SAAO;AAAA,IACL,MAAM;AAAA,IACN,SAAS;AAAA,IACT,MAAM,CAAC,UAA2B;AAChC,UAAI,UAAU,MAAM;AAClB,eAAO;AAAA,MACT;AACA,aAAO,kBAAkB,KAAK;AAAA,IAChC;AAAA,EACF;AACF;",
6
6
  "names": []
7
7
  }
@@ -2,6 +2,6 @@
2
2
  "version": 3,
3
3
  "sources": ["../../../src/validators/utils/number.ts"],
4
4
  "sourcesContent": ["import { ValidatorSchema } from '@digigov/form/validators/types';\n\nexport function validateNumber(number: number): boolean {\n return !Number.isNaN(number);\n}\n\nexport const NUMBER_VALIDATOR = (): ValidatorSchema => {\n return {\n name: 'number-validator',\n message: 'form.error.number',\n test: (value: number): boolean => {\n if (value === null) {\n return true;\n }\n return validateNumber(value);\n },\n };\n};\n"],
5
- "mappings": "AAEO,wBAAwB,QAAyB;AACtD,SAAO,CAAC,OAAO,MAAM;AAAA;AAGhB,MAAM,mBAAmB,MAAuB;AACrD,SAAO;AAAA,IACL,MAAM;AAAA,IACN,SAAS;AAAA,IACT,MAAM,CAAC,UAA2B;AAChC,UAAI,UAAU,MAAM;AAClB,eAAO;AAAA;AAET,aAAO,eAAe;AAAA;AAAA;AAAA;",
5
+ "mappings": "AAEO,SAAS,eAAe,QAAyB;AACtD,SAAO,CAAC,OAAO,MAAM,MAAM;AAC7B;AAEO,MAAM,mBAAmB,MAAuB;AACrD,SAAO;AAAA,IACL,MAAM;AAAA,IACN,SAAS;AAAA,IACT,MAAM,CAAC,UAA2B;AAChC,UAAI,UAAU,MAAM;AAClB,eAAO;AAAA,MACT;AACA,aAAO,eAAe,KAAK;AAAA,IAC7B;AAAA,EACF;AACF;",
6
6
  "names": []
7
7
  }
@@ -2,6 +2,6 @@
2
2
  "version": 3,
3
3
  "sources": ["../../../src/validators/utils/otp.ts"],
4
4
  "sourcesContent": ["import { FieldSpec } from '@digigov/form/types';\nimport { ValidatorSchema } from '@digigov/form/validators/types';\nexport function validateOtp(value: string, maxLength: number): boolean {\n if (value.length === maxLength) {\n return true;\n } else {\n return false;\n }\n}\n\nexport const OTP_VALIDATOR = (field: FieldSpec): ValidatorSchema => {\n const maxLength = field?.maxLength;\n return {\n name: 'otp-validator',\n message: {\n key: 'form.error.otp.less_than',\n context: {\n maxLength: field?.maxLength,\n },\n },\n test: (value: string): boolean => {\n if (!value) {\n return true;\n }\n return validateOtp(value, maxLength as number);\n },\n };\n};\n"],
5
- "mappings": "AAEO,qBAAqB,OAAe,WAA4B;AACrE,MAAI,MAAM,WAAW,WAAW;AAC9B,WAAO;AAAA,SACF;AACL,WAAO;AAAA;AAAA;AAIJ,MAAM,gBAAgB,CAAC,UAAsC;AAClE,QAAM,YAAY,OAAO;AACzB,SAAO;AAAA,IACL,MAAM;AAAA,IACN,SAAS;AAAA,MACP,KAAK;AAAA,MACL,SAAS;AAAA,QACP,WAAW,OAAO;AAAA;AAAA;AAAA,IAGtB,MAAM,CAAC,UAA2B;AAChC,UAAI,CAAC,OAAO;AACV,eAAO;AAAA;AAET,aAAO,YAAY,OAAO;AAAA;AAAA;AAAA;",
5
+ "mappings": "AAEO,SAAS,YAAY,OAAe,WAA4B;AACrE,MAAI,MAAM,WAAW,WAAW;AAC9B,WAAO;AAAA,EACT,OAAO;AACL,WAAO;AAAA,EACT;AACF;AAEO,MAAM,gBAAgB,CAAC,UAAsC;AAClE,QAAM,YAAY,OAAO;AACzB,SAAO;AAAA,IACL,MAAM;AAAA,IACN,SAAS;AAAA,MACP,KAAK;AAAA,MACL,SAAS;AAAA,QACP,WAAW,OAAO;AAAA,MACpB;AAAA,IACF;AAAA,IACA,MAAM,CAAC,UAA2B;AAChC,UAAI,CAAC,OAAO;AACV,eAAO;AAAA,MACT;AACA,aAAO,YAAY,OAAO,SAAmB;AAAA,IAC/C;AAAA,EACF;AACF;",
6
6
  "names": []
7
7
  }
@@ -83,7 +83,10 @@ function discoverPhoneType(phoneNumber, config) {
83
83
  "premium-rate": config.premiumRate
84
84
  };
85
85
  for (const [categoryName, categoryDetails] of Object.entries(categories)) {
86
- const pattern = new RegExp("^(" + categoryDetails.nationalNumberPattern.replace(/\s/g, "") + ")$", "");
86
+ const pattern = new RegExp(
87
+ "^(" + categoryDetails.nationalNumberPattern.replace(/\s/g, "") + ")$",
88
+ ""
89
+ );
87
90
  if (cleanNumber.match(pattern)) {
88
91
  return categoryName;
89
92
  }
@@ -118,7 +121,11 @@ function validatePhoneNumber(phoneNumber, countries = ["gr"], typeOfPhoneNumber)
118
121
  if (!countries || countries.length === 0) {
119
122
  return true;
120
123
  }
121
- return isPhoneNumberValid(phoneNumber, countries, typeOfPhoneNumber ? [typeOfPhoneNumber] : void 0);
124
+ return isPhoneNumberValid(
125
+ phoneNumber,
126
+ countries,
127
+ typeOfPhoneNumber ? [typeOfPhoneNumber] : void 0
128
+ );
122
129
  }
123
130
  function validateMobile(value) {
124
131
  return isNumberOfType(value, "gr", "mobile");