@digigov/form 2.0.0-8e254888 → 2.0.0-a0ac149e

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 (592) hide show
  1. package/Field/ErrorGroup.d.ts +3 -3
  2. package/Field/ErrorGroup.js.map +1 -1
  3. package/Field/FieldBase/index.js +7 -4
  4. package/Field/FieldBase.d.ts +1 -1
  5. package/Field/FieldBase.js.map +2 -2
  6. package/Field/FieldBaseContainer/index.js +37 -18
  7. package/Field/FieldBaseContainer.d.ts +2 -2
  8. package/Field/FieldBaseContainer.js.map +2 -2
  9. package/Field/FieldConditional/index.js +4 -0
  10. package/Field/FieldConditional.d.ts +1 -1
  11. package/Field/FieldConditional.js.map +2 -2
  12. package/Field/index.d.ts +1 -1
  13. package/Field/index.js +25 -29
  14. package/Field/index.js.map +2 -2
  15. package/Field/types.d.ts +21 -12
  16. package/Field/utils/evaluateFieldWithConditions.d.ts +2 -2
  17. package/Field/utils/evaluateFieldWithConditions.js.map +2 -2
  18. package/Field/utils/resolveField/index.js +35 -0
  19. package/Field/utils/{calculateField → resolveField}/package.json +1 -1
  20. package/Field/utils/resolveField.d.ts +3 -0
  21. package/Field/utils/resolveField.js.map +7 -0
  22. package/Field/utils/useField/index.js +12 -3
  23. package/Field/utils/useField.d.ts +1 -1
  24. package/Field/utils/useField.js.map +2 -2
  25. package/FieldArray/BaseFieldArray/index.js +76 -0
  26. package/FieldArray/BaseFieldArray/package.json +6 -0
  27. package/FieldArray/BaseFieldArray.d.ts +5 -0
  28. package/FieldArray/BaseFieldArray.js.map +7 -0
  29. package/FieldArray/FormDialog/ArrayDisplay/ArrayDisplay.stories.d.ts +10 -0
  30. package/FieldArray/FormDialog/ArrayDisplay/ArrayItemDisplay/index.js +97 -0
  31. package/FieldArray/FormDialog/ArrayDisplay/ArrayItemDisplay/package.json +6 -0
  32. package/FieldArray/FormDialog/ArrayDisplay/ArrayItemDisplay.d.ts +22 -0
  33. package/FieldArray/FormDialog/ArrayDisplay/ArrayItemDisplay.js.map +7 -0
  34. package/FieldArray/FormDialog/ArrayDisplay/ArrayItemHeader/index.js +11 -0
  35. package/FieldArray/FormDialog/ArrayDisplay/ArrayItemHeader/package.json +6 -0
  36. package/FieldArray/FormDialog/ArrayDisplay/ArrayItemHeader.d.ts +5 -0
  37. package/FieldArray/FormDialog/ArrayDisplay/ArrayItemHeader.js.map +7 -0
  38. package/FieldArray/FormDialog/ArrayDisplay/__stories__/Default.d.ts +2 -0
  39. package/FieldArray/FormDialog/ArrayDisplay/__stories__/ReadOnly.d.ts +2 -0
  40. package/FieldArray/FormDialog/ArrayDisplay/__stories__/Sortable.d.ts +2 -0
  41. package/FieldArray/FormDialog/ArrayDisplay/index.d.ts +14 -0
  42. package/FieldArray/FormDialog/ArrayDisplay/index.js +51 -0
  43. package/FieldArray/FormDialog/ArrayDisplay/index.js.map +7 -0
  44. package/{inputs/Input/inputsInputScenarios → FieldArray/FormDialog/ArrayDisplay}/package.json +1 -1
  45. package/FieldArray/FormDialog/ArrayEditModal/index.js +149 -0
  46. package/FieldArray/FormDialog/ArrayEditModal/package.json +6 -0
  47. package/FieldArray/FormDialog/ArrayEditModal.d.ts +26 -0
  48. package/FieldArray/FormDialog/ArrayEditModal.js.map +7 -0
  49. package/FieldArray/FormDialog/index.d.ts +19 -0
  50. package/FieldArray/FormDialog/index.js +172 -258
  51. package/FieldArray/FormDialog/index.js.map +7 -0
  52. package/FieldArray/__stories__/Default.d.ts +1 -1
  53. package/FieldArray/__stories__/WithExactLength.d.ts +1 -1
  54. package/FieldArray/__stories__/WithModal.d.ts +1 -1
  55. package/FieldArray/index.d.ts +5 -2
  56. package/FieldArray/index.js +36 -57
  57. package/FieldArray/index.js.map +2 -2
  58. package/FieldObject/index.d.ts +7 -4
  59. package/FieldObject/index.js +30 -26
  60. package/FieldObject/index.js.map +2 -2
  61. package/Fieldset/FieldsetWithContext.js.map +1 -1
  62. package/Fieldset/index.d.ts +1 -1
  63. package/Fieldset/index.js.map +1 -1
  64. package/Fieldset/types.d.ts +2 -2
  65. package/FormBuilder/FormBuilder.stories.d.ts +2 -0
  66. package/FormBuilder/__stories__/AutoErrorGrouping.d.ts +1 -1
  67. package/FormBuilder/__stories__/Default.d.ts +1 -1
  68. package/FormBuilder/__stories__/ErrorGrouping.d.ts +1 -1
  69. package/FormBuilder/index.d.ts +2 -2
  70. package/FormBuilder/index.js +163 -134
  71. package/FormBuilder/index.js.map +2 -2
  72. package/FormContext/index.js +6 -2
  73. package/FormContext.d.ts +3 -2
  74. package/FormContext.js.map +2 -2
  75. package/MultiplicityField/MultiplicityField.stories.d.ts +2 -0
  76. package/MultiplicityField/__stories__/Default.d.ts +1 -1
  77. package/MultiplicityField/__stories__/PreviewDisplay.d.ts +1 -1
  78. package/MultiplicityField/__stories__/WithExactLength.d.ts +1 -1
  79. package/MultiplicityField/__stories__/WithMaxLength.d.ts +1 -1
  80. package/MultiplicityField/__stories__/WithMinAndMaxLength.d.ts +1 -1
  81. package/MultiplicityField/__stories__/WithMinLength.d.ts +1 -1
  82. package/MultiplicityField/add-objects/index.js +12 -19
  83. package/MultiplicityField/add-objects.d.ts +1 -1
  84. package/MultiplicityField/add-objects.js.map +2 -2
  85. package/MultiplicityField/index.d.ts +2 -2
  86. package/MultiplicityField/index.js +4 -1
  87. package/MultiplicityField/index.js.map +2 -2
  88. package/MultiplicityField/types.d.ts +3 -2
  89. package/Questions/Questions.d.ts +1 -1
  90. package/Questions/Questions.js.map +1 -1
  91. package/Questions/Questions.stories.d.ts +2 -0
  92. package/Questions/QuestionsContext.d.ts +1 -1
  93. package/Questions/QuestionsContext.js.map +1 -1
  94. package/Questions/Step/Step.d.ts +1 -1
  95. package/Questions/Step/Step.js.map +1 -1
  96. package/Questions/Step/StepArrayReview.d.ts +1 -1
  97. package/Questions/Step/StepArrayReview.js.map +1 -1
  98. package/Questions/Step/StepContext.d.ts +1 -1
  99. package/Questions/Step/StepContext.js.map +1 -1
  100. package/Questions/Step/StepDescription.d.ts +1 -1
  101. package/Questions/Step/StepDescription.js.map +2 -2
  102. package/Questions/Step/StepForm.d.ts +2 -2
  103. package/Questions/Step/StepForm.js.map +1 -1
  104. package/Questions/Step/StepQuote.d.ts +1 -1
  105. package/Questions/Step/StepQuote.js.map +2 -2
  106. package/Questions/Step/StepTitle.d.ts +1 -1
  107. package/Questions/Step/StepTitle.js.map +2 -2
  108. package/Questions/Step/getAddMoreFields.d.ts +2 -2
  109. package/Questions/Step/getAddMoreFields.js.map +1 -1
  110. package/Questions/Step/types.d.ts +1 -1
  111. package/Questions/__stories__/Default.d.ts +1 -1
  112. package/Questions/getNextStep.d.ts +1 -1
  113. package/Questions/getNextStep.js.map +1 -1
  114. package/Questions/types.d.ts +1 -1
  115. package/cjs/Field/ErrorGroup.js.map +1 -1
  116. package/cjs/Field/FieldBase/index.js +7 -4
  117. package/cjs/Field/FieldBase.js.map +2 -2
  118. package/cjs/Field/FieldBaseContainer/index.js +36 -17
  119. package/cjs/Field/FieldBaseContainer.js.map +3 -3
  120. package/cjs/Field/FieldConditional/index.js +4 -0
  121. package/cjs/Field/FieldConditional.js.map +2 -2
  122. package/cjs/Field/index.js +25 -26
  123. package/cjs/Field/index.js.map +2 -2
  124. package/cjs/Field/types.js.map +1 -1
  125. package/cjs/Field/utils/evaluateFieldWithConditions.js.map +2 -2
  126. package/cjs/Field/utils/resolveField/index.js +55 -0
  127. package/cjs/Field/utils/resolveField.js.map +7 -0
  128. package/cjs/Field/utils/useField/index.js +12 -3
  129. package/cjs/Field/utils/useField.js.map +2 -2
  130. package/cjs/FieldArray/BaseFieldArray/index.js +109 -0
  131. package/cjs/FieldArray/BaseFieldArray.js.map +7 -0
  132. package/cjs/FieldArray/FormDialog/ArrayDisplay/ArrayItemDisplay/index.js +130 -0
  133. package/cjs/FieldArray/FormDialog/ArrayDisplay/ArrayItemDisplay.js.map +7 -0
  134. package/cjs/{locales/el → FieldArray/FormDialog/ArrayDisplay/ArrayItemHeader}/index.js +16 -7
  135. package/cjs/FieldArray/FormDialog/ArrayDisplay/ArrayItemHeader.js.map +7 -0
  136. package/cjs/FieldArray/FormDialog/ArrayDisplay/index.js +84 -0
  137. package/cjs/FieldArray/FormDialog/ArrayDisplay/index.js.map +7 -0
  138. package/cjs/FieldArray/FormDialog/ArrayEditModal/index.js +177 -0
  139. package/cjs/FieldArray/FormDialog/ArrayEditModal.js.map +7 -0
  140. package/cjs/FieldArray/FormDialog/index.js +163 -244
  141. package/cjs/FieldArray/FormDialog/index.js.map +7 -0
  142. package/cjs/FieldArray/index.js +35 -56
  143. package/cjs/FieldArray/index.js.map +3 -3
  144. package/cjs/FieldObject/index.js +30 -23
  145. package/cjs/FieldObject/index.js.map +2 -2
  146. package/cjs/Fieldset/FieldsetWithContext.js.map +1 -1
  147. package/cjs/Fieldset/index.js.map +1 -1
  148. package/cjs/Fieldset/types.js.map +1 -1
  149. package/cjs/FormBuilder/index.js +164 -135
  150. package/cjs/FormBuilder/index.js.map +3 -3
  151. package/cjs/FormContext/index.js +7 -2
  152. package/cjs/FormContext.js.map +2 -2
  153. package/cjs/MultiplicityField/add-objects/index.js +11 -13
  154. package/cjs/MultiplicityField/add-objects.js.map +2 -2
  155. package/cjs/MultiplicityField/index.js +4 -1
  156. package/cjs/MultiplicityField/index.js.map +2 -2
  157. package/cjs/MultiplicityField/types.js.map +1 -1
  158. package/cjs/Questions/Questions.js.map +1 -1
  159. package/cjs/Questions/QuestionsContext.js.map +1 -1
  160. package/cjs/Questions/Step/Step.js.map +1 -1
  161. package/cjs/Questions/Step/StepArrayReview.js.map +1 -1
  162. package/cjs/Questions/Step/StepContext.js.map +1 -1
  163. package/cjs/Questions/Step/StepDescription.js.map +2 -2
  164. package/cjs/Questions/Step/StepForm.js.map +1 -1
  165. package/cjs/Questions/Step/StepQuote.js.map +2 -2
  166. package/cjs/Questions/Step/StepTitle.js.map +2 -2
  167. package/cjs/Questions/Step/getAddMoreFields.js.map +1 -1
  168. package/cjs/Questions/Step/types.js.map +1 -1
  169. package/cjs/Questions/getNextStep.js.map +1 -1
  170. package/cjs/Questions/types.js.map +1 -1
  171. package/cjs/hooks/useFieldFocusManager/index.js +135 -0
  172. package/cjs/hooks/useFieldFocusManager.js.map +7 -0
  173. package/cjs/hooks/utils/index.js +98 -0
  174. package/cjs/hooks/utils.js.map +7 -0
  175. package/cjs/inputs/AutoCompleteInput/index.js.map +2 -2
  176. package/cjs/inputs/Checkboxes/index.js +67 -63
  177. package/cjs/inputs/Checkboxes/index.js.map +2 -2
  178. package/cjs/inputs/DateInput/index.js +51 -19
  179. package/cjs/inputs/DateInput/index.js.map +2 -2
  180. package/cjs/inputs/DateTimeInput/index.js +78 -39
  181. package/cjs/inputs/DateTimeInput/index.js.map +2 -2
  182. package/cjs/inputs/FileInput/index.js +52 -29
  183. package/cjs/inputs/FileInput/index.js.map +2 -2
  184. package/cjs/inputs/ImageInput/__stories__/logo.d/index.js +1 -0
  185. package/cjs/inputs/ImageInput/__stories__/logo.d.js.map +7 -0
  186. package/cjs/inputs/ImageInput/index.js +41 -10
  187. package/cjs/inputs/ImageInput/index.js.map +2 -2
  188. package/cjs/inputs/Input/index.js +55 -57
  189. package/cjs/inputs/Input/index.js.map +2 -2
  190. package/cjs/inputs/Label/index.js.map +1 -1
  191. package/cjs/inputs/OtpInput/index.js +36 -31
  192. package/cjs/inputs/OtpInput/index.js.map +2 -2
  193. package/cjs/inputs/Radio/index.js +5 -4
  194. package/cjs/inputs/Radio/index.js.map +3 -3
  195. package/cjs/inputs/Select/index.js +4 -3
  196. package/cjs/inputs/Select/index.js.map +2 -2
  197. package/cjs/{Field/utils → inputs/registry}/index.js +7 -5
  198. package/cjs/inputs/registry.js.map +7 -0
  199. package/cjs/{lazy/index.js → lazy.js} +12 -10
  200. package/cjs/lazy.js.map +2 -2
  201. package/cjs/{registry/index.js → registry.js} +25 -15
  202. package/cjs/registry.js.map +2 -2
  203. package/cjs/types.js.map +1 -1
  204. package/cjs/utils/index.js +20 -6
  205. package/cjs/utils.js.map +2 -2
  206. package/cjs/validators/index.js +11 -6
  207. package/cjs/validators/index.js.map +2 -2
  208. package/cjs/validators/types.js.map +1 -1
  209. package/cjs/validators/utils/amka/index.js +60 -0
  210. package/cjs/validators/utils/amka.js.map +7 -0
  211. package/cjs/validators/utils/date/index.js +26 -3
  212. package/cjs/validators/utils/date.js.map +2 -2
  213. package/cjs/validators/utils/datetime/index.js +118 -24
  214. package/cjs/validators/utils/datetime.js.map +2 -2
  215. package/cjs/validators/utils/file/index.js +30 -17
  216. package/cjs/validators/utils/file.js.map +2 -2
  217. package/cjs/validators/utils/iban.js.map +1 -1
  218. package/cjs/validators/utils/image.js.map +1 -1
  219. package/cjs/validators/utils/index.js +5 -1
  220. package/cjs/validators/utils/index.js.map +2 -2
  221. package/cjs/validators/utils/int.js.map +1 -1
  222. package/cjs/validators/utils/number.js.map +1 -1
  223. package/cjs/validators/utils/otp.js.map +1 -1
  224. package/cjs/validators/utils/phone.js.map +1 -1
  225. package/cjs/validators/utils/postal_code.js.map +1 -1
  226. package/cjs/validators/utils/text_limit.js.map +1 -1
  227. package/hooks/useFieldFocusManager/index.js +116 -0
  228. package/hooks/useFieldFocusManager/package.json +6 -0
  229. package/hooks/useFieldFocusManager.d.ts +25 -0
  230. package/hooks/useFieldFocusManager.js.map +7 -0
  231. package/hooks/utils/index.js +73 -0
  232. package/{Field → hooks}/utils/package.json +1 -1
  233. package/hooks/utils.d.ts +18 -0
  234. package/hooks/utils.js.map +7 -0
  235. package/index.js +1 -1
  236. package/inputs/AutoCompleteInput/AutoComplete.stories.d.ts +2 -0
  237. package/inputs/AutoCompleteInput/__stories__/Default.d.ts +1 -1
  238. package/inputs/AutoCompleteInput/__stories__/Multiple.d.ts +1 -1
  239. package/inputs/AutoCompleteInput/index.d.ts +3 -3
  240. package/inputs/AutoCompleteInput/index.js +1 -3
  241. package/inputs/AutoCompleteInput/index.js.map +2 -2
  242. package/inputs/Checkboxes/Checkboxes.stories.d.ts +2 -0
  243. package/inputs/Checkboxes/__stories__/Conditional.d.ts +1 -1
  244. package/inputs/Checkboxes/__stories__/Default.d.ts +1 -1
  245. package/inputs/Checkboxes/__stories__/WithDivider.d.ts +1 -1
  246. package/inputs/Checkboxes/index.d.ts +3 -3
  247. package/inputs/Checkboxes/index.js +67 -63
  248. package/inputs/Checkboxes/index.js.map +2 -2
  249. package/inputs/DateInput/DateInput.stories.d.ts +6 -0
  250. package/inputs/DateInput/__stories__/Default.d.ts +1 -1
  251. package/inputs/DateInput/__stories__/WithDefaultValue.d.ts +3 -0
  252. package/inputs/DateInput/__stories__/WithInitialValue.d.ts +3 -0
  253. package/inputs/DateInput/__stories__/WithWrongDefaultValue.d.ts +3 -0
  254. package/inputs/DateInput/__stories__/WithWrongInitialValue.d.ts +3 -0
  255. package/inputs/DateInput/index.d.ts +2 -5
  256. package/inputs/DateInput/index.js +52 -20
  257. package/inputs/DateInput/index.js.map +2 -2
  258. package/inputs/DateTimeInput/DateTimeInput.stories.d.ts +10 -3
  259. package/inputs/DateTimeInput/__stories__/Default.d.ts +1 -1
  260. package/inputs/DateTimeInput/__stories__/WithDefaultValue.d.ts +3 -0
  261. package/inputs/DateTimeInput/__stories__/WithInitialValue.d.ts +3 -0
  262. package/inputs/DateTimeInput/__stories__/WithWrongDefaultValue.d.ts +3 -0
  263. package/inputs/DateTimeInput/__stories__/WithWrongInitialValue.d.ts +3 -0
  264. package/inputs/DateTimeInput/index.d.ts +2 -5
  265. package/inputs/DateTimeInput/index.js +79 -40
  266. package/inputs/DateTimeInput/index.js.map +2 -2
  267. package/inputs/FileInput/FileInput.stories.d.ts +3 -0
  268. package/inputs/FileInput/__stories__/Default.d.ts +1 -1
  269. package/inputs/FileInput/__stories__/WithBorderAndLink.d.ts +3 -0
  270. package/inputs/FileInput/index.d.ts +12 -5
  271. package/inputs/FileInput/index.js +53 -30
  272. package/inputs/FileInput/index.js.map +2 -2
  273. package/inputs/ImageInput/ImageInput.stories.d.ts +4 -1
  274. package/inputs/ImageInput/__stories__/Default.d.ts +1 -1
  275. package/inputs/ImageInput/__stories__/MaxSize.d.ts +1 -1
  276. package/inputs/ImageInput/__stories__/WithInitialValues.d.ts +3 -0
  277. package/inputs/ImageInput/__stories__/WithInvalidImageDimension.d.ts +1 -1
  278. package/inputs/ImageInput/__stories__/logo.d/index.js +1 -0
  279. package/inputs/ImageInput/__stories__/logo.d/package.json +6 -0
  280. package/inputs/ImageInput/__stories__/logo.d.js.map +7 -0
  281. package/inputs/ImageInput/index.d.ts +10 -2
  282. package/inputs/ImageInput/index.js +42 -11
  283. package/inputs/ImageInput/index.js.map +2 -2
  284. package/inputs/Input/Input.stories.d.ts +4 -0
  285. package/inputs/Input/__stories__/AFM.d.ts +1 -1
  286. package/inputs/Input/__stories__/AMKA.d.ts +3 -0
  287. package/inputs/Input/__stories__/Boolean.d.ts +1 -1
  288. package/inputs/Input/__stories__/Email.d.ts +3 -0
  289. package/inputs/Input/__stories__/IBAN.d.ts +1 -1
  290. package/inputs/Input/__stories__/Integer.d.ts +1 -1
  291. package/inputs/Input/__stories__/LandlineNumber.d.ts +1 -1
  292. package/inputs/Input/__stories__/MobilePhone.d.ts +1 -1
  293. package/inputs/Input/__stories__/PhoneNumber.d.ts +1 -1
  294. package/inputs/Input/__stories__/PostalCode.d.ts +1 -1
  295. package/inputs/Input/__stories__/String.d.ts +1 -1
  296. package/inputs/Input/__stories__/StringWithTrimValidation.d.ts +1 -1
  297. package/inputs/Input/__stories__/TextWithLimit.d.ts +1 -1
  298. package/inputs/Input/index.d.ts +4 -3
  299. package/inputs/Input/index.js +55 -57
  300. package/inputs/Input/index.js.map +2 -2
  301. package/inputs/Label/Label.stories.d.ts +2 -0
  302. package/inputs/Label/__stories__/Default.d.ts +1 -1
  303. package/inputs/Label/index.d.ts +1 -1
  304. package/inputs/Label/index.js.map +1 -1
  305. package/inputs/OtpInput/OtpInput.stories.d.ts +2 -0
  306. package/inputs/OtpInput/__stories__/Default.d.ts +1 -1
  307. package/inputs/OtpInput/index.d.ts +1 -5
  308. package/inputs/OtpInput/index.js +36 -31
  309. package/inputs/OtpInput/index.js.map +2 -2
  310. package/inputs/Radio/Radio.stories.d.ts +2 -0
  311. package/inputs/Radio/__stories__/Conditional.d.ts +1 -1
  312. package/inputs/Radio/__stories__/Default.d.ts +1 -1
  313. package/inputs/Radio/__stories__/WithDivider.d.ts +1 -1
  314. package/inputs/Radio/index.d.ts +4 -4
  315. package/inputs/Radio/index.js +5 -4
  316. package/inputs/Radio/index.js.map +3 -3
  317. package/inputs/Select/Select.stories.d.ts +2 -0
  318. package/inputs/Select/__stories__/Default.d.ts +1 -1
  319. package/inputs/Select/index.d.ts +4 -3
  320. package/inputs/Select/index.js +4 -3
  321. package/inputs/Select/index.js.map +2 -2
  322. package/{Field/utils → inputs/registry}/index.js +4 -2
  323. package/{locales/el → inputs/registry}/package.json +1 -1
  324. package/{Field/utils/index.d.ts → inputs/registry.d.ts} +2 -1
  325. package/inputs/registry.js.map +7 -0
  326. package/lazy/index.js +12 -10
  327. package/package.json +8 -8
  328. package/registry/index.js +25 -15
  329. package/src/Field/ErrorGroup.tsx +3 -3
  330. package/src/Field/FieldBase.tsx +7 -4
  331. package/src/Field/FieldBaseContainer.tsx +69 -48
  332. package/src/Field/FieldConditional.tsx +5 -1
  333. package/src/Field/doc.mdx +202 -1
  334. package/src/Field/index.tsx +30 -38
  335. package/src/Field/types.tsx +22 -14
  336. package/src/Field/utils/evaluateFieldWithConditions.ts +5 -2
  337. package/src/Field/utils/resolveField.ts +58 -0
  338. package/src/Field/utils/useField.ts +12 -2
  339. package/src/FieldArray/BaseFieldArray.tsx +97 -0
  340. package/src/FieldArray/FormDialog/ArrayDisplay/ArrayDisplay.stories.js +11 -0
  341. package/src/FieldArray/FormDialog/ArrayDisplay/ArrayItemDisplay.tsx +165 -0
  342. package/src/FieldArray/FormDialog/ArrayDisplay/ArrayItemHeader.tsx +15 -0
  343. package/src/FieldArray/FormDialog/ArrayDisplay/__stories__/Default.tsx +93 -0
  344. package/src/FieldArray/FormDialog/ArrayDisplay/__stories__/ReadOnly.tsx +79 -0
  345. package/src/FieldArray/FormDialog/ArrayDisplay/__stories__/Sortable.tsx +93 -0
  346. package/src/FieldArray/FormDialog/ArrayDisplay/index.tsx +75 -0
  347. package/src/FieldArray/FormDialog/ArrayEditModal.tsx +233 -0
  348. package/src/FieldArray/FormDialog/index.tsx +250 -0
  349. package/src/FieldArray/__stories__/Default.tsx +1 -1
  350. package/src/FieldArray/__stories__/WithExactLength.tsx +1 -1
  351. package/src/FieldArray/__stories__/WithModal.tsx +4 -3
  352. package/src/FieldArray/__tests__/fieldset-multiplicity.spec.tsx +271 -0
  353. package/src/FieldArray/__tests__/multiplicity-attachment.spec.tsx +280 -0
  354. package/src/FieldArray/__tests__/multiplicity-required.spec.tsx +131 -0
  355. package/src/FieldArray/__tests__/nested-fieldset-multiplicity.spec.tsx +627 -0
  356. package/src/FieldArray/__tests__/preference-multiple-choice.spec.tsx +222 -0
  357. package/src/FieldArray/index.spec.tsx +355 -0
  358. package/src/FieldArray/index.test.tsx +4 -0
  359. package/src/FieldArray/index.tsx +41 -72
  360. package/src/FieldObject/index.tsx +40 -33
  361. package/src/Fieldset/FieldsetWithContext.tsx +1 -1
  362. package/src/Fieldset/index.tsx +1 -1
  363. package/src/Fieldset/types.tsx +2 -2
  364. package/src/FormBuilder/FormBuilder.stories.js +3 -0
  365. package/src/FormBuilder/__stories__/AutoErrorGrouping.tsx +1 -1
  366. package/src/FormBuilder/__stories__/Default.tsx +1 -1
  367. package/src/FormBuilder/__stories__/ErrorGrouping.tsx +1 -1
  368. package/src/FormBuilder/doc.mdx +9 -4
  369. package/src/FormBuilder/index.test.tsx +4 -0
  370. package/src/FormBuilder/index.tsx +197 -146
  371. package/src/FormBuilder/interaction.test.tsx +8 -0
  372. package/src/FormBuilder/scenarios.test.tsx +766 -8
  373. package/src/FormContext.tsx +7 -2
  374. package/src/MultiplicityField/MultiplicityField.stories.js +3 -0
  375. package/src/MultiplicityField/__stories__/Default.tsx +1 -1
  376. package/src/MultiplicityField/__stories__/PreviewDisplay.tsx +1 -1
  377. package/src/MultiplicityField/__stories__/WithExactLength.tsx +1 -1
  378. package/src/MultiplicityField/__stories__/WithMaxLength.tsx +1 -1
  379. package/src/MultiplicityField/__stories__/WithMinAndMaxLength.tsx +1 -1
  380. package/src/MultiplicityField/__stories__/WithMinLength.tsx +1 -1
  381. package/src/MultiplicityField/add-objects.tsx +14 -21
  382. package/src/MultiplicityField/doc.mdx +101 -83
  383. package/src/MultiplicityField/index.test.tsx +4 -0
  384. package/src/MultiplicityField/index.tsx +6 -2
  385. package/src/MultiplicityField/types.ts +6 -2
  386. package/src/Questions/Questions.stories.js +3 -0
  387. package/src/Questions/Questions.tsx +2 -2
  388. package/src/Questions/QuestionsContext.tsx +1 -1
  389. package/src/Questions/Step/Step.tsx +1 -1
  390. package/src/Questions/Step/StepArrayReview.tsx +2 -2
  391. package/src/Questions/Step/StepContext.tsx +1 -1
  392. package/src/Questions/Step/StepDescription.tsx +2 -1
  393. package/src/Questions/Step/StepForm.tsx +2 -2
  394. package/src/Questions/Step/StepQuote.tsx +2 -1
  395. package/src/Questions/Step/StepTitle.tsx +2 -1
  396. package/src/Questions/Step/getAddMoreFields.tsx +2 -2
  397. package/src/Questions/Step/types.tsx +1 -1
  398. package/src/Questions/__snapshots__/index.spec.tsx.snap +2 -1
  399. package/src/Questions/__stories__/Default.tsx +1 -1
  400. package/src/Questions/doc.mdx +21 -41
  401. package/src/Questions/getNextStep.tsx +1 -1
  402. package/src/Questions/index.test.tsx +4 -0
  403. package/src/Questions/types.tsx +1 -1
  404. package/src/doc.mdx +26 -11
  405. package/src/hooks/__tests__/useFieldFocusManager.spec.tsx +1079 -0
  406. package/src/hooks/__tests__/utils.spec.ts +568 -0
  407. package/src/hooks/useFieldFocusManager.ts +162 -0
  408. package/src/hooks/utils.ts +122 -0
  409. package/src/inputs/AutoCompleteInput/AutoComplete.stories.js +3 -0
  410. package/src/inputs/AutoCompleteInput/__stories__/Default.tsx +1 -1
  411. package/src/inputs/AutoCompleteInput/__stories__/Multiple.tsx +1 -1
  412. package/src/inputs/AutoCompleteInput/index.test.tsx +4 -0
  413. package/src/inputs/AutoCompleteInput/index.tsx +4 -6
  414. package/src/inputs/Checkboxes/Checkboxes.stories.js +3 -0
  415. package/src/inputs/Checkboxes/__stories__/Conditional.tsx +1 -1
  416. package/src/inputs/Checkboxes/__stories__/Default.tsx +1 -1
  417. package/src/inputs/Checkboxes/__stories__/WithDivider.tsx +1 -1
  418. package/src/inputs/Checkboxes/index.test.tsx +4 -0
  419. package/src/inputs/Checkboxes/index.tsx +95 -91
  420. package/src/inputs/DateInput/DateInput.stories.js +7 -0
  421. package/src/inputs/DateInput/__stories__/Default.tsx +1 -1
  422. package/src/inputs/DateInput/__stories__/WithDefaultValue.tsx +26 -0
  423. package/src/inputs/DateInput/__stories__/WithInitialValue.tsx +28 -0
  424. package/src/inputs/DateInput/__stories__/WithWrongDefaultValue.tsx +26 -0
  425. package/src/inputs/DateInput/__stories__/WithWrongInitialValue.tsx +28 -0
  426. package/src/inputs/DateInput/index.test.tsx +20 -0
  427. package/src/inputs/DateInput/index.tsx +65 -20
  428. package/src/inputs/DateTimeInput/DateTimeInput.stories.js +12 -6
  429. package/src/inputs/DateTimeInput/__stories__/Default.tsx +1 -1
  430. package/src/inputs/DateTimeInput/__stories__/WithDefaultValue.tsx +26 -0
  431. package/src/inputs/DateTimeInput/__stories__/WithInitialValue.tsx +28 -0
  432. package/src/inputs/DateTimeInput/__stories__/WithWrongDefaultValue.tsx +26 -0
  433. package/src/inputs/DateTimeInput/__stories__/WithWrongInitialValue.tsx +28 -0
  434. package/src/inputs/DateTimeInput/index.test.tsx +20 -0
  435. package/src/inputs/DateTimeInput/index.tsx +92 -40
  436. package/src/inputs/FileInput/FileInput.stories.js +4 -0
  437. package/src/inputs/FileInput/__stories__/Default.tsx +1 -1
  438. package/src/inputs/FileInput/__stories__/WithBorderAndLink.tsx +34 -0
  439. package/src/inputs/FileInput/index.test.tsx +8 -0
  440. package/src/inputs/FileInput/index.tsx +91 -47
  441. package/src/inputs/ImageInput/ImageInput.stories.js +5 -1
  442. package/src/inputs/ImageInput/__stories__/Default.tsx +1 -1
  443. package/src/inputs/ImageInput/__stories__/MaxSize.tsx +3 -2
  444. package/src/inputs/ImageInput/__stories__/{WithInvalidImageSize.tsx → WithInitialValues.tsx} +12 -3
  445. package/src/inputs/ImageInput/__stories__/WithInvalidImageDimension.tsx +1 -1
  446. package/src/inputs/ImageInput/__stories__/logo.d.ts +4 -0
  447. package/src/inputs/ImageInput/__stories__/logo.png +0 -0
  448. package/src/inputs/ImageInput/index.test.tsx +8 -4
  449. package/src/inputs/ImageInput/index.tsx +101 -49
  450. package/src/inputs/Input/Input.stories.js +5 -0
  451. package/src/inputs/Input/__stories__/AFM.tsx +1 -1
  452. package/src/inputs/Input/__stories__/AMKA.tsx +23 -0
  453. package/src/inputs/Input/__stories__/Boolean.tsx +1 -1
  454. package/src/inputs/Input/__stories__/Email.tsx +23 -0
  455. package/src/inputs/Input/__stories__/IBAN.tsx +1 -1
  456. package/src/inputs/Input/__stories__/Integer.tsx +1 -1
  457. package/src/inputs/Input/__stories__/LandlineNumber.tsx +1 -1
  458. package/src/inputs/Input/__stories__/MobilePhone.tsx +1 -1
  459. package/src/inputs/Input/__stories__/PhoneNumber.tsx +1 -1
  460. package/src/inputs/Input/__stories__/PostalCode.tsx +1 -1
  461. package/src/inputs/Input/__stories__/String.tsx +1 -1
  462. package/src/inputs/Input/__stories__/StringWithTrimValidation.tsx +1 -1
  463. package/src/inputs/Input/__stories__/TextWithLimit.tsx +1 -1
  464. package/src/inputs/Input/index.test.tsx +12 -0
  465. package/src/inputs/Input/index.tsx +76 -73
  466. package/src/inputs/Label/Label.stories.js +3 -0
  467. package/src/inputs/Label/__stories__/Default.tsx +1 -1
  468. package/src/inputs/Label/index.test.tsx +4 -0
  469. package/src/inputs/Label/index.tsx +1 -1
  470. package/src/inputs/OtpInput/OtpInput.stories.js +3 -0
  471. package/src/inputs/OtpInput/__stories__/Default.tsx +1 -1
  472. package/src/inputs/OtpInput/index.test.tsx +4 -0
  473. package/src/inputs/OtpInput/index.tsx +43 -34
  474. package/src/inputs/Radio/Radio.stories.js +3 -0
  475. package/src/inputs/Radio/__stories__/Conditional.tsx +1 -1
  476. package/src/inputs/Radio/__stories__/Default.tsx +1 -1
  477. package/src/inputs/Radio/__stories__/WithDivider.tsx +1 -1
  478. package/src/inputs/Radio/index.test.tsx +4 -0
  479. package/src/inputs/Radio/index.tsx +29 -21
  480. package/src/inputs/Select/Select.stories.js +3 -0
  481. package/src/inputs/Select/__stories__/Default.tsx +1 -1
  482. package/src/inputs/Select/index.test.tsx +4 -0
  483. package/src/inputs/Select/index.tsx +9 -6
  484. package/src/{Field/utils/index.ts → inputs/registry.ts} +5 -1
  485. package/src/lazy.js +12 -10
  486. package/src/registry.js +25 -15
  487. package/src/types.tsx +13 -5
  488. package/src/utils.ts +30 -8
  489. package/src/validators/index.ts +27 -15
  490. package/src/validators/types.ts +1 -1
  491. package/src/validators/utils/amka.ts +39 -0
  492. package/src/validators/utils/date.ts +30 -6
  493. package/src/validators/utils/datetime.ts +123 -31
  494. package/src/validators/utils/file.ts +35 -21
  495. package/src/validators/utils/iban.ts +2 -2
  496. package/src/validators/utils/image.ts +2 -2
  497. package/src/validators/utils/index.ts +6 -3
  498. package/src/validators/utils/int.ts +1 -1
  499. package/src/validators/utils/number.ts +1 -1
  500. package/src/validators/utils/otp.ts +2 -2
  501. package/src/validators/utils/phone.ts +2 -2
  502. package/src/validators/utils/postal_code.ts +2 -2
  503. package/src/validators/utils/text_limit.ts +2 -2
  504. package/types.d.ts +9 -4
  505. package/types.js.map +1 -1
  506. package/utils/index.js +20 -6
  507. package/utils.d.ts +3 -1
  508. package/utils.js.map +2 -2
  509. package/validators/index.d.ts +6 -6
  510. package/validators/index.js +12 -6
  511. package/validators/index.js.map +2 -2
  512. package/validators/types.d.ts +1 -1
  513. package/validators/utils/amka/index.js +36 -0
  514. package/{inputs/inputsScenarios → validators/utils/amka}/package.json +1 -1
  515. package/validators/utils/amka.d.ts +6 -0
  516. package/validators/utils/amka.js.map +7 -0
  517. package/validators/utils/date/index.js +26 -3
  518. package/validators/utils/date.d.ts +3 -3
  519. package/validators/utils/date.js.map +2 -2
  520. package/validators/utils/datetime/index.js +118 -24
  521. package/validators/utils/datetime.d.ts +3 -3
  522. package/validators/utils/datetime.js.map +2 -2
  523. package/validators/utils/file/index.js +30 -17
  524. package/validators/utils/file.d.ts +2 -2
  525. package/validators/utils/file.js.map +2 -2
  526. package/validators/utils/iban.d.ts +2 -2
  527. package/validators/utils/iban.js.map +1 -1
  528. package/validators/utils/image.d.ts +2 -2
  529. package/validators/utils/image.js.map +1 -1
  530. package/validators/utils/index.d.ts +3 -2
  531. package/validators/utils/index.js +4 -1
  532. package/validators/utils/index.js.map +2 -2
  533. package/validators/utils/int.d.ts +1 -1
  534. package/validators/utils/int.js.map +1 -1
  535. package/validators/utils/number.d.ts +1 -1
  536. package/validators/utils/number.js.map +1 -1
  537. package/validators/utils/otp.d.ts +2 -2
  538. package/validators/utils/otp.js.map +1 -1
  539. package/validators/utils/phone.d.ts +2 -2
  540. package/validators/utils/phone.js.map +1 -1
  541. package/validators/utils/postal_code.d.ts +2 -2
  542. package/validators/utils/postal_code.js.map +1 -1
  543. package/validators/utils/text_limit.d.ts +2 -2
  544. package/validators/utils/text_limit.js.map +1 -1
  545. package/Field/utils/calculateField/index.js +0 -27
  546. package/Field/utils/calculateField.d.ts +0 -2
  547. package/Field/utils/calculateField.js.map +0 -7
  548. package/Field/utils/index.js.map +0 -7
  549. package/FieldArray/FormDialog.d.ts +0 -53
  550. package/FieldArray/FormDialog.js.map +0 -7
  551. package/FormBuilder/index.test.d.ts +0 -1
  552. package/FormBuilder/interaction.test.d.ts +0 -1
  553. package/FormBuilder/scenarios.test.d.ts +0 -88
  554. package/MultiplicityField/index.test.d.ts +0 -1
  555. package/Questions/index.spec.d.ts +0 -1
  556. package/Questions/index.test.d.ts +0 -1
  557. package/cjs/Field/utils/calculateField/index.js +0 -50
  558. package/cjs/Field/utils/calculateField.js.map +0 -7
  559. package/cjs/Field/utils/index.js.map +0 -7
  560. package/cjs/FieldArray/FormDialog.js.map +0 -7
  561. package/cjs/inputs/Input/inputsInputScenarios/index.js +0 -439
  562. package/cjs/inputs/Input/inputsInputScenarios.js.map +0 -7
  563. package/cjs/inputs/inputsScenarios/index.js +0 -533
  564. package/cjs/inputs/inputsScenarios.js.map +0 -7
  565. package/cjs/locales/el.js.map +0 -7
  566. package/inputs/AutoCompleteInput/index.test.d.ts +0 -1
  567. package/inputs/Checkboxes/index.test.d.ts +0 -1
  568. package/inputs/DateInput/index.test.d.ts +0 -1
  569. package/inputs/DateTimeInput/index.test.d.ts +0 -1
  570. package/inputs/FileInput/index.test.d.ts +0 -1
  571. package/inputs/ImageInput/__stories__/WithInvalidImageSize.d.ts +0 -3
  572. package/inputs/ImageInput/index.test.d.ts +0 -1
  573. package/inputs/Input/index.test.d.ts +0 -1
  574. package/inputs/Input/inputsInputScenarios/index.js +0 -406
  575. package/inputs/Input/inputsInputScenarios.d.ts +0 -57
  576. package/inputs/Input/inputsInputScenarios.js.map +0 -7
  577. package/inputs/Label/index.test.d.ts +0 -1
  578. package/inputs/OtpInput/index.test.d.ts +0 -1
  579. package/inputs/Radio/index.test.d.ts +0 -1
  580. package/inputs/Select/index.test.d.ts +0 -1
  581. package/inputs/inputsScenarios/index.js +0 -499
  582. package/inputs/inputsScenarios.d.ts +0 -296
  583. package/inputs/inputsScenarios.js.map +0 -7
  584. package/locales/el/index.js +0 -6
  585. package/locales/el.d.ts +0 -2
  586. package/locales/el.js.map +0 -7
  587. package/src/Field/utils/calculateField.ts +0 -49
  588. package/src/FieldArray/FormDialog.tsx +0 -378
  589. package/src/inputs/Input/inputsInputScenarios.ts +0 -404
  590. package/src/inputs/inputsScenarios.ts +0 -496
  591. package/src/locales/el.ts +0 -3
  592. /package/{FieldArray/index.test.d.ts → hooks/__tests__/utils.spec.d.ts} +0 -0
package/utils/index.js CHANGED
@@ -23,6 +23,20 @@ const parseErrorSchema = (error, validateAllFieldCriteria) => {
23
23
  {}
24
24
  );
25
25
  };
26
+ function isPlainObject(obj) {
27
+ return typeof obj === "object" && obj !== null && Object.prototype.toString.call(obj) === "[object Object]";
28
+ }
29
+ function flattenObject(obj, prefix = "") {
30
+ return Object.keys(obj).reduce((acc, key) => {
31
+ const prefixedKey = prefix ? `${prefix}.${key}` : key;
32
+ if (isPlainObject(obj[key])) {
33
+ Object.assign(acc, flattenObject(obj[key], prefixedKey));
34
+ } else {
35
+ acc[prefixedKey] = obj[key];
36
+ }
37
+ return acc;
38
+ }, {});
39
+ }
26
40
  const yupResolver = (schema, schemaOptions = {}, resolverOptions = {}) => async (values, context, options) => {
27
41
  try {
28
42
  if (schemaOptions.context && process.env.NODE_ENV === "development") {
@@ -31,7 +45,7 @@ const yupResolver = (schema, schemaOptions = {}, resolverOptions = {}) => async
31
45
  );
32
46
  }
33
47
  const result = await schema[resolverOptions.mode === "sync" ? "validateSync" : "validate"](
34
- values,
48
+ flattenObject(values),
35
49
  Object.assign({ abortEarly: false }, schemaOptions, { context })
36
50
  );
37
51
  if (options.shouldUseNativeValidation)
@@ -44,13 +58,13 @@ const yupResolver = (schema, schemaOptions = {}, resolverOptions = {}) => async
44
58
  if (!e.inner) {
45
59
  throw e;
46
60
  }
47
- const parsed = parseErrorSchema(
48
- e,
49
- !options.shouldUseNativeValidation && options.criteriaMode === "all"
50
- );
51
61
  return {
52
62
  values: {},
53
- errors: parsed
63
+ errors: parseErrorSchema(
64
+ e,
65
+ !options.shouldUseNativeValidation && options.criteriaMode === "all"
66
+ ),
67
+ options
54
68
  };
55
69
  }
56
70
  };
package/utils.d.ts CHANGED
@@ -1,8 +1,10 @@
1
- import { FieldError } from 'react-hook-form';
1
+ import type { FieldError } from 'react-hook-form';
2
2
  export declare const yupResolver: (schema: any, schemaOptions?: any, resolverOptions?: any) => (values: any, context: any, options: any) => Promise<{
3
3
  values: any;
4
4
  errors: {};
5
+ options?: undefined;
5
6
  } | {
6
7
  values: {};
7
8
  errors: Record<string, FieldError>;
9
+ options: any;
8
10
  }>;
package/utils.js.map CHANGED
@@ -1,7 +1,7 @@
1
1
  {
2
2
  "version": 3,
3
3
  "sources": ["../src/utils.ts"],
4
- "sourcesContent": ["import { validateFieldsNatively } from '@hookform/resolvers';\nimport { appendErrors, FieldError } from 'react-hook-form';\nimport * as Yup from 'yup';\n\n/**\n * Why `path!` ? because it could be `undefined` in some case\n * https://github.com/jquense/yup#validationerrorerrors-string--arraystring-value-any-path-string\n */\nconst parseErrorSchema = (\n error: Yup.ValidationError,\n validateAllFieldCriteria: boolean\n) => {\n return (error.inner || []).reduce<Record<string, FieldError>>(\n (previous, error) => {\n error.path = error.path?.replace(/\\[([0-9]+)\\]/g, '.$1');\n if (!previous[error.path!]) {\n previous[error.path!] = { message: error.message, type: error.type! };\n }\n\n if (validateAllFieldCriteria) {\n const types = previous[error.path!].types;\n const messages = types && types[error.type!];\n\n previous[error.path!] = appendErrors(\n error.path!,\n validateAllFieldCriteria,\n previous,\n error.type!,\n messages\n ? ([] as string[]).concat(messages as string[], error.message)\n : error.message\n ) as FieldError;\n }\n\n return previous;\n },\n {}\n );\n};\n\nexport const yupResolver =\n (schema: any, schemaOptions: any = {}, resolverOptions: any = {}) =>\n async (values, context, options) => {\n try {\n if (schemaOptions.context && process.env.NODE_ENV === 'development') {\n console.warn(\n \"You should not used the yup options context. Please, use the 'useForm' context object instead\"\n );\n }\n\n const result = await schema[\n resolverOptions.mode === 'sync' ? 'validateSync' : 'validate'\n ](\n values,\n Object.assign({ abortEarly: false }, schemaOptions, { context })\n );\n\n if (options.shouldUseNativeValidation)\n validateFieldsNatively({}, options);\n\n return {\n values: resolverOptions.rawValues ? values : result,\n errors: {},\n };\n } catch (e) {\n if (!e.inner) {\n throw e;\n }\n\n const parsed = parseErrorSchema(\n e,\n !options.shouldUseNativeValidation && options.criteriaMode === 'all'\n );\n return {\n values: {},\n errors: parsed,\n };\n }\n };\n"],
5
- "mappings": "AAAA,SAAS,8BAA8B;AACvC,SAAS,oBAAgC;AAOzC,MAAM,mBAAmB,CACvB,OACA,6BACG;AACH,UAAQ,MAAM,SAAS,CAAC,GAAG;AAAA,IACzB,CAAC,UAAUA,WAAU;AACnB,MAAAA,OAAM,OAAOA,OAAM,MAAM,QAAQ,iBAAiB,KAAK;AACvD,UAAI,CAAC,SAASA,OAAM,IAAK,GAAG;AAC1B,iBAASA,OAAM,IAAK,IAAI,EAAE,SAASA,OAAM,SAAS,MAAMA,OAAM,KAAM;AAAA,MACtE;AAEA,UAAI,0BAA0B;AAC5B,cAAM,QAAQ,SAASA,OAAM,IAAK,EAAE;AACpC,cAAM,WAAW,SAAS,MAAMA,OAAM,IAAK;AAE3C,iBAASA,OAAM,IAAK,IAAI;AAAA,UACtBA,OAAM;AAAA,UACN;AAAA,UACA;AAAA,UACAA,OAAM;AAAA,UACN,WACK,CAAC,EAAe,OAAO,UAAsBA,OAAM,OAAO,IAC3DA,OAAM;AAAA,QACZ;AAAA,MACF;AAEA,aAAO;AAAA,IACT;AAAA,IACA,CAAC;AAAA,EACH;AACF;AAEO,MAAM,cACX,CAAC,QAAa,gBAAqB,CAAC,GAAG,kBAAuB,CAAC,MAC/D,OAAO,QAAQ,SAAS,YAAY;AAClC,MAAI;AACF,QAAI,cAAc,WAAW,QAAQ,IAAI,aAAa,eAAe;AACnE,cAAQ;AAAA,QACN;AAAA,MACF;AAAA,IACF;AAEA,UAAM,SAAS,MAAM,OACnB,gBAAgB,SAAS,SAAS,iBAAiB,UACrD;AAAA,MACE;AAAA,MACA,OAAO,OAAO,EAAE,YAAY,MAAM,GAAG,eAAe,EAAE,QAAQ,CAAC;AAAA,IACjE;AAEA,QAAI,QAAQ;AACV,6BAAuB,CAAC,GAAG,OAAO;AAEpC,WAAO;AAAA,MACL,QAAQ,gBAAgB,YAAY,SAAS;AAAA,MAC7C,QAAQ,CAAC;AAAA,IACX;AAAA,EACF,SAAS,GAAG;AACV,QAAI,CAAC,EAAE,OAAO;AACZ,YAAM;AAAA,IACR;AAEA,UAAM,SAAS;AAAA,MACb;AAAA,MACA,CAAC,QAAQ,6BAA6B,QAAQ,iBAAiB;AAAA,IACjE;AACA,WAAO;AAAA,MACL,QAAQ,CAAC;AAAA,MACT,QAAQ;AAAA,IACV;AAAA,EACF;AACF;",
4
+ "sourcesContent": ["import { validateFieldsNatively } from '@hookform/resolvers';\nimport type { FieldError } from 'react-hook-form';\nimport { appendErrors } from 'react-hook-form';\nimport type * 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 // error.path = error.path?.replace(/\\[\"(.*?)\"\\]/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};\nfunction isPlainObject(obj) {\n return (\n typeof obj === 'object' &&\n obj !== null &&\n Object.prototype.toString.call(obj) === '[object Object]'\n );\n}\nfunction flattenObject(obj, prefix = '') {\n return Object.keys(obj).reduce((acc, key) => {\n const prefixedKey = prefix ? `${prefix}.${key}` : key;\n\n if (isPlainObject(obj[key])) {\n Object.assign(acc, flattenObject(obj[key], prefixedKey));\n } else {\n acc[prefixedKey] = obj[key];\n }\n\n return acc;\n }, {});\n}\n\nexport const yupResolver =\n (schema: any, schemaOptions: any = {}, resolverOptions: any = {}) =>\n async (values, context, options) => {\n try {\n if (schemaOptions.context && process.env.NODE_ENV === 'development') {\n console.warn(\n \"You should not used the yup options context. Please, use the 'useForm' context object instead\"\n );\n }\n\n const result = await schema[\n resolverOptions.mode === 'sync' ? 'validateSync' : 'validate'\n ](\n flattenObject(values),\n Object.assign({ abortEarly: false }, schemaOptions, { context })\n );\n\n if (options.shouldUseNativeValidation)\n validateFieldsNatively({}, options);\n\n return {\n values: resolverOptions.rawValues ? values : result,\n errors: {},\n };\n } catch (e) {\n if (!e.inner) {\n throw e;\n }\n\n return {\n values: {},\n errors: parseErrorSchema(\n e,\n !options.shouldUseNativeValidation && options.criteriaMode === 'all'\n ),\n options,\n };\n }\n };\n"],
5
+ "mappings": "AAAA,SAAS,8BAA8B;AAEvC,SAAS,oBAAoB;AAO7B,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;AAEvD,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;AACA,SAAS,cAAc,KAAK;AAC1B,SACE,OAAO,QAAQ,YACf,QAAQ,QACR,OAAO,UAAU,SAAS,KAAK,GAAG,MAAM;AAE5C;AACA,SAAS,cAAc,KAAK,SAAS,IAAI;AACvC,SAAO,OAAO,KAAK,GAAG,EAAE,OAAO,CAAC,KAAK,QAAQ;AAC3C,UAAM,cAAc,SAAS,GAAG,MAAM,IAAI,GAAG,KAAK;AAElD,QAAI,cAAc,IAAI,GAAG,CAAC,GAAG;AAC3B,aAAO,OAAO,KAAK,cAAc,IAAI,GAAG,GAAG,WAAW,CAAC;AAAA,IACzD,OAAO;AACL,UAAI,WAAW,IAAI,IAAI,GAAG;AAAA,IAC5B;AAEA,WAAO;AAAA,EACT,GAAG,CAAC,CAAC;AACP;AAEO,MAAM,cACX,CAAC,QAAa,gBAAqB,CAAC,GAAG,kBAAuB,CAAC,MAC/D,OAAO,QAAQ,SAAS,YAAY;AAClC,MAAI;AACF,QAAI,cAAc,WAAW,QAAQ,IAAI,aAAa,eAAe;AACnE,cAAQ;AAAA,QACN;AAAA,MACF;AAAA,IACF;AAEA,UAAM,SAAS,MAAM,OACnB,gBAAgB,SAAS,SAAS,iBAAiB,UACrD;AAAA,MACE,cAAc,MAAM;AAAA,MACpB,OAAO,OAAO,EAAE,YAAY,MAAM,GAAG,eAAe,EAAE,QAAQ,CAAC;AAAA,IACjE;AAEA,QAAI,QAAQ;AACV,6BAAuB,CAAC,GAAG,OAAO;AAEpC,WAAO;AAAA,MACL,QAAQ,gBAAgB,YAAY,SAAS;AAAA,MAC7C,QAAQ,CAAC;AAAA,IACX;AAAA,EACF,SAAS,GAAG;AACV,QAAI,CAAC,EAAE,OAAO;AACZ,YAAM;AAAA,IACR;AAEA,WAAO;AAAA,MACL,QAAQ,CAAC;AAAA,MACT,QAAQ;AAAA,QACN;AAAA,QACA,CAAC,QAAQ,6BAA6B,QAAQ,iBAAiB;AAAA,MACjE;AAAA,MACA;AAAA,IACF;AAAA,EACF;AACF;",
6
6
  "names": ["error"]
7
7
  }
@@ -1,9 +1,9 @@
1
- import { MutableRefObject } from 'react';
2
- import { AnyObjectSchema } from 'yup';
3
- import Lazy from 'yup/lib/Lazy';
4
- import { FieldSpec } from '@digigov/form/types';
5
- import { ValidatorSchema } from '@digigov/form/validators/types';
6
- export declare const getYUPTypeMap: () => Record<string, any>;
1
+ import type { MutableRefObject } from 'react';
2
+ import type { AnyObjectSchema } from 'yup';
3
+ import type Lazy from 'yup/lib/Lazy';
4
+ import type { FieldSpec } from '@digigov/form/types';
5
+ import type { ValidatorSchema } from '@digigov/form/validators/types';
6
+ export declare const getYUPTypeMap: (validatorRegistry?: Record<string, any>) => Record<string, any>;
7
7
  export interface MutableRefObjectProps {
8
8
  }
9
9
  export declare function useValidationSchema(fields: FieldSpec[] | MutableRefObject<MutableRefObjectProps>, validatorRegistry?: Record<string, ValidatorSchema[]>): Lazy<any, unknown> | AnyObjectSchema | void;
@@ -3,6 +3,7 @@ import * as yup from "yup";
3
3
  import {
4
4
  getYupObjectShape,
5
5
  AFM_VALIDATOR,
6
+ AMKA_VALIDATOR,
6
7
  FILE_MAX_SIZE_VALIDATOR,
7
8
  IBAN_VALIDATOR,
8
9
  OTP_VALIDATOR,
@@ -21,11 +22,11 @@ import {
21
22
  } from "@digigov/form/validators/utils";
22
23
  import { INT_VALIDATOR } from "@digigov/form/validators/utils/int";
23
24
  import { NUMBER_VALIDATOR } from "@digigov/form/validators/utils/number";
24
- const getYUPTypeMap = () => {
25
+ const getYUPTypeMap = (validatorRegistry) => {
25
26
  const yupTypeMap = {
26
27
  file: (field) => {
27
28
  return yup.mixed().transform((value) => {
28
- if (!value.length) {
29
+ if (!value || value.length === 0) {
29
30
  return null;
30
31
  }
31
32
  return value;
@@ -51,7 +52,10 @@ const getYUPTypeMap = () => {
51
52
  },
52
53
  array: (field) => {
53
54
  if (typeof field.extra.of === "object") {
54
- let arrayValidator = yup.array().of(yupTypeMap[field.extra.of.type](field.extra.of)).required(field.required);
55
+ if (field.required) {
56
+ field.extra.min = 1;
57
+ }
58
+ let arrayValidator = yup.array().nullable().of(yupTypeMap[field.extra.of.type](field.extra.of));
55
59
  if (field.extra.length)
56
60
  arrayValidator = arrayValidator.length(field.extra.length, {
57
61
  key: "form.error.array.length",
@@ -84,6 +88,7 @@ const getYUPTypeMap = () => {
84
88
  int: () => yup.mixed().transform((_, val) => val !== "" ? Number(val) : void 0).test(NUMBER_VALIDATOR()).test(INT_VALIDATOR()),
85
89
  email: (field) => field.trim ? yup.string().trim().email("form.error.email") : yup.string().email("form.error.email"),
86
90
  afm: (field) => field.trim ? yup.string().trim().test(AFM_VALIDATOR) : yup.string().test(AFM_VALIDATOR),
91
+ amka: (field) => field.trim ? yup.string().trim().test(AMKA_VALIDATOR) : yup.string().test(AMKA_VALIDATOR),
87
92
  uuid4: (field) => field.trim ? yup.string().trim().test(UUID4_VALIDATOR) : yup.string().test(UUID4_VALIDATOR),
88
93
  iban: (field) => field.trim ? yup.string().trim().test(IBAN_VALIDATOR(field)) : yup.string().trim().test(IBAN_VALIDATOR(field)),
89
94
  otp: (field) => yup.string().trim().test(OTP_VALIDATOR(field)),
@@ -127,15 +132,16 @@ const getYUPTypeMap = () => {
127
132
  return yup.string().test(EARLIER_THAN_DATETIME_VALIDATOR(field));
128
133
  }
129
134
  return yup.string().test(DATETIME_VALIDATOR);
130
- }
135
+ },
136
+ ...validatorRegistry
131
137
  };
132
138
  return yupTypeMap;
133
139
  };
134
140
  function useValidationSchema(fields, validatorRegistry) {
135
141
  return useMemo(() => {
136
- const yupTypeMap = getYUPTypeMap();
142
+ const yupTypeMap = getYUPTypeMap(validatorRegistry);
137
143
  return getYupObjectShape(fields, yupTypeMap, validatorRegistry);
138
- }, []);
144
+ }, [fields, validatorRegistry]);
139
145
  }
140
146
  export {
141
147
  getYUPTypeMap,
@@ -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 * 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 DATE_VALIDATOR,\n LATER_THAN_VALIDATOR,\n EARLIER_THAN_VALIDATOR,\n DATETIME_VALIDATOR,\n LATER_THAN_DATETIME_VALIDATOR,\n EARLIER_THAN_DATETIME_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';\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: (field): yup.StringSchema => {\n if (field.trim) {\n return yup.string().trim();\n } else {\n return yup.string();\n }\n },\n boolean: (): yup.BooleanSchema<\n boolean | null | undefined,\n AnyObject,\n boolean | null | undefined\n > => {\n return yup\n .boolean()\n .nullable()\n .transform((value) => {\n if (value === '' || typeof value === 'string') return null;\n if (typeof value === 'boolean') return value;\n if (value === 0 || value === 1) return Boolean(value);\n return value;\n });\n },\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) : undefined))\n .test(NUMBER_VALIDATOR()),\n int: (): MixedSchema =>\n yup\n .mixed()\n .transform((_, val) => (val !== '' ? Number(val) : undefined))\n .test(NUMBER_VALIDATOR())\n .test(INT_VALIDATOR()),\n email: (field): yup.StringSchema =>\n field.trim\n ? yup.string().trim().email('form.error.email')\n : yup.string().email('form.error.email'),\n afm: (field): yup.StringSchema =>\n field.trim\n ? yup.string().trim().test(AFM_VALIDATOR)\n : yup.string().test(AFM_VALIDATOR),\n uuid4: (field): yup.StringSchema =>\n field.trim\n ? yup.string().trim().test(UUID4_VALIDATOR)\n : yup.string().test(UUID4_VALIDATOR),\n iban: (field): yup.StringSchema =>\n field.trim\n ? yup.string().trim().test(IBAN_VALIDATOR(field))\n : yup.string().trim().test(IBAN_VALIDATOR(field)),\n otp: (field): yup.StringSchema =>\n yup.string().trim().test(OTP_VALIDATOR(field)),\n text: (field): yup.StringSchema => {\n if (field?.extra?.limit?.max || !!field?.extra?.limit?.min) {\n return field.trim\n ? yup.string().trim().test(TEXT_LIMIT_VALIDATOR(field))\n : yup.string().test(TEXT_LIMIT_VALIDATOR(field));\n } else {\n return field.trim ? yup.string().trim() : 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 field.trim\n ? yup.string().trim().test(POSTALCODE_VALIDATOR(field))\n : yup.string().test(POSTALCODE_VALIDATOR(field)),\n mobile_phone: (field): yup.StringSchema =>\n field.trim\n ? yup.string().trim().test(MOBILE_PHONE_VALIDATOR)\n : yup.string().test(MOBILE_PHONE_VALIDATOR),\n phone_number: (field): yup.StringSchema =>\n field.trim\n ? yup.string().trim().test(PHONE_NUMBER_VALIDATOR(field))\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: (\n field\n ): yup.StringSchema<\n string | null | undefined,\n AnyObject,\n string | null | undefined\n > => {\n let schema = yup.string().nullable();\n if (field?.extra?.min) {\n schema = schema.test(LATER_THAN_VALIDATOR(field));\n }\n if (field?.extra?.max) {\n schema = schema.test(EARLIER_THAN_VALIDATOR(field));\n } else {\n schema = schema.test(DATE_VALIDATOR);\n }\n return schema;\n },\n datetime: (field): yup.StringSchema => {\n if (field?.extra?.min) {\n return yup.string().test(LATER_THAN_DATETIME_VALIDATOR(field));\n }\n if (field?.extra?.max) {\n return yup.string().test(EARLIER_THAN_DATETIME_VALIDATOR(field));\n }\n return yup.string().test(DATETIME_VALIDATOR);\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 type { MutableRefObject } from 'react';\nimport { useMemo } from 'react';\nimport * as yup from 'yup';\nimport type { AnyObjectSchema, StringSchema } from 'yup';\nimport type { RequiredArraySchema } from 'yup/lib/array';\nimport type Lazy from 'yup/lib/Lazy';\nimport type { MixedSchema } from 'yup/lib/mixed';\nimport type { TypeOfShape, AssertsShape } from 'yup/lib/object';\nimport type { AnyObject } from 'yup/lib/types';\nimport type { FieldSpec } from '@digigov/form/types';\nimport type { ValidatorSchema } from '@digigov/form/validators/types';\nimport {\n getYupObjectShape,\n AFM_VALIDATOR,\n AMKA_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 DATE_VALIDATOR,\n LATER_THAN_VALIDATOR,\n EARLIER_THAN_VALIDATOR,\n DATETIME_VALIDATOR,\n LATER_THAN_DATETIME_VALIDATOR,\n EARLIER_THAN_DATETIME_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';\n\nexport const getYUPTypeMap = (\n validatorRegistry?: Record<string, any>\n): Record<string, any> => {\n const yupTypeMap = {\n file: (field): MixedSchema => {\n return yup\n .mixed()\n .transform((value) => {\n if (!value || value.length === 0) {\n return null;\n }\n return value;\n })\n .nullable()\n .test(FILE_MAX_SIZE_VALIDATOR(field));\n },\n string: (field): yup.StringSchema => {\n if (field.trim) {\n return yup.string().trim();\n } else {\n return yup.string();\n }\n },\n boolean: (): yup.BooleanSchema<\n boolean | null | undefined,\n AnyObject,\n boolean | null | undefined\n > => {\n return yup\n .boolean()\n .nullable()\n .transform((value) => {\n if (value === '' || typeof value === 'string') return null;\n if (typeof value === 'boolean') return value;\n if (value === 0 || value === 1) return Boolean(value);\n return value;\n });\n },\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 if (field.required) {\n field.extra.min = 1;\n }\n let arrayValidator = yup\n .array()\n .nullable()\n .of(yupTypeMap[field.extra.of.type](field.extra.of));\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) : undefined))\n .test(NUMBER_VALIDATOR()),\n int: (): MixedSchema =>\n yup\n .mixed()\n .transform((_, val) => (val !== '' ? Number(val) : undefined))\n .test(NUMBER_VALIDATOR())\n .test(INT_VALIDATOR()),\n email: (field): yup.StringSchema =>\n field.trim\n ? yup.string().trim().email('form.error.email')\n : yup.string().email('form.error.email'),\n afm: (field): yup.StringSchema =>\n field.trim\n ? yup.string().trim().test(AFM_VALIDATOR)\n : yup.string().test(AFM_VALIDATOR),\n amka: (field): yup.StringSchema =>\n field.trim\n ? yup.string().trim().test(AMKA_VALIDATOR)\n : yup.string().test(AMKA_VALIDATOR),\n uuid4: (field): yup.StringSchema =>\n field.trim\n ? yup.string().trim().test(UUID4_VALIDATOR)\n : yup.string().test(UUID4_VALIDATOR),\n iban: (field): yup.StringSchema =>\n field.trim\n ? yup.string().trim().test(IBAN_VALIDATOR(field))\n : yup.string().trim().test(IBAN_VALIDATOR(field)),\n otp: (field): yup.StringSchema =>\n yup.string().trim().test(OTP_VALIDATOR(field)),\n text: (field): yup.StringSchema => {\n if (field?.extra?.limit?.max || !!field?.extra?.limit?.min) {\n return field.trim\n ? yup.string().trim().test(TEXT_LIMIT_VALIDATOR(field))\n : yup.string().test(TEXT_LIMIT_VALIDATOR(field));\n } else {\n return field.trim ? yup.string().trim() : 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 field.trim\n ? yup.string().trim().test(POSTALCODE_VALIDATOR(field))\n : yup.string().test(POSTALCODE_VALIDATOR(field)),\n mobile_phone: (field): yup.StringSchema =>\n field.trim\n ? yup.string().trim().test(MOBILE_PHONE_VALIDATOR)\n : yup.string().test(MOBILE_PHONE_VALIDATOR),\n phone_number: (field): yup.StringSchema =>\n field.trim\n ? yup.string().trim().test(PHONE_NUMBER_VALIDATOR(field))\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: (\n field\n ): yup.StringSchema<\n string | null | undefined,\n AnyObject,\n string | null | undefined\n > => {\n let schema = yup.string().nullable();\n if (field?.extra?.min) {\n schema = schema.test(LATER_THAN_VALIDATOR(field));\n }\n if (field?.extra?.max) {\n schema = schema.test(EARLIER_THAN_VALIDATOR(field));\n } else {\n schema = schema.test(DATE_VALIDATOR);\n }\n return schema;\n },\n datetime: (field): yup.StringSchema => {\n if (field?.extra?.min) {\n return yup.string().test(LATER_THAN_DATETIME_VALIDATOR(field));\n }\n if (field?.extra?.max) {\n return yup.string().test(EARLIER_THAN_DATETIME_VALIDATOR(field));\n }\n return yup.string().test(DATETIME_VALIDATOR);\n },\n ...validatorRegistry,\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(validatorRegistry);\n return getYupObjectShape(fields, yupTypeMap, validatorRegistry);\n }, [fields, validatorRegistry]);\n}\n"],
5
+ "mappings": "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",
6
6
  "names": []
7
7
  }
@@ -1,2 +1,2 @@
1
- import * as yup from 'yup';
1
+ import type * as yup from 'yup';
2
2
  export type ValidatorSchema = yup.TestConfig;
@@ -0,0 +1,36 @@
1
+ function digitSum(number) {
2
+ const sum = number > 9 ? 1 : 0;
3
+ return sum + number % 10;
4
+ }
5
+ function validateAMKA(amka) {
6
+ amka = String(amka);
7
+ const checkDigitIndex = amka.length - 1;
8
+ let sum = 0;
9
+ amka.substring(0, checkDigitIndex).split("").reverse().forEach(function(value, index) {
10
+ const weight = (index + 1) % 2 + 1;
11
+ sum += digitSum(parseInt(value, 10) * weight);
12
+ });
13
+ const sumMod10 = sum % 10;
14
+ if (sumMod10 === 0) {
15
+ return amka.substring(checkDigitIndex) === "0";
16
+ } else {
17
+ return amka.substring(checkDigitIndex) === 10 - sumMod10 + "";
18
+ }
19
+ }
20
+ const AMKA_VALIDATOR = {
21
+ name: "amka-validator",
22
+ message: "form.error.amka",
23
+ test: (value) => {
24
+ if (!value) return true;
25
+ const AMKA_REGEX = /^[0-9]{11}$/;
26
+ if (!AMKA_REGEX.test(value) || value === "00000000000") {
27
+ return false;
28
+ }
29
+ return validateAMKA(value);
30
+ }
31
+ };
32
+ export {
33
+ AMKA_VALIDATOR,
34
+ validateAMKA
35
+ };
36
+ //# sourceMappingURL=amka.js.map
@@ -2,5 +2,5 @@
2
2
  "sideEffects": false,
3
3
  "module": "./index.js",
4
4
  "types": "./index.d.ts",
5
- "main": "../../cjs/inputs/inputsScenarios/index.js"
5
+ "main": "../../../cjs/validators/utils/amka/index.js"
6
6
  }
@@ -0,0 +1,6 @@
1
+ export declare function validateAMKA(amka: string): boolean;
2
+ export declare const AMKA_VALIDATOR: {
3
+ name: string;
4
+ message: string;
5
+ test: (value: any) => boolean;
6
+ };
@@ -0,0 +1,7 @@
1
+ {
2
+ "version": 3,
3
+ "sources": ["../../../src/validators/utils/amka.ts"],
4
+ "sourcesContent": ["function digitSum(number) {\n const sum = number > 9 ? 1 : 0;\n return sum + (number % 10);\n}\n\nexport function validateAMKA(amka: string): boolean {\n // Validate that the last digit is the correct check digit (created using the\n // Luhn algorithm https://en.wikipedia.org/wiki/Luhn_algorithm).\n amka = String(amka);\n const checkDigitIndex = amka.length - 1;\n let sum = 0;\n amka\n .substring(0, checkDigitIndex)\n .split('')\n .reverse()\n .forEach(function (value, index) {\n const weight = ((index + 1) % 2) + 1;\n sum += digitSum(parseInt(value, 10) * weight);\n });\n const sumMod10 = sum % 10;\n if (sumMod10 === 0) {\n return amka.substring(checkDigitIndex) === '0';\n } else {\n return amka.substring(checkDigitIndex) === 10 - sumMod10 + '';\n }\n}\n\nexport const AMKA_VALIDATOR = {\n name: 'amka-validator',\n message: 'form.error.amka',\n test: (value): boolean => {\n if (!value) return true;\n const AMKA_REGEX = /^[0-9]{11}$/;\n if (!AMKA_REGEX.test(value) || value === '00000000000') {\n return false;\n }\n return validateAMKA(value);\n },\n};\n"],
5
+ "mappings": "AAAA,SAAS,SAAS,QAAQ;AACxB,QAAM,MAAM,SAAS,IAAI,IAAI;AAC7B,SAAO,MAAO,SAAS;AACzB;AAEO,SAAS,aAAa,MAAuB;AAGlD,SAAO,OAAO,IAAI;AAClB,QAAM,kBAAkB,KAAK,SAAS;AACtC,MAAI,MAAM;AACV,OACG,UAAU,GAAG,eAAe,EAC5B,MAAM,EAAE,EACR,QAAQ,EACR,QAAQ,SAAU,OAAO,OAAO;AAC/B,UAAM,UAAW,QAAQ,KAAK,IAAK;AACnC,WAAO,SAAS,SAAS,OAAO,EAAE,IAAI,MAAM;AAAA,EAC9C,CAAC;AACH,QAAM,WAAW,MAAM;AACvB,MAAI,aAAa,GAAG;AAClB,WAAO,KAAK,UAAU,eAAe,MAAM;AAAA,EAC7C,OAAO;AACL,WAAO,KAAK,UAAU,eAAe,MAAM,KAAK,WAAW;AAAA,EAC7D;AACF;AAEO,MAAM,iBAAiB;AAAA,EAC5B,MAAM;AAAA,EACN,SAAS;AAAA,EACT,MAAM,CAAC,UAAmB;AACxB,QAAI,CAAC,MAAO,QAAO;AACnB,UAAM,aAAa;AACnB,QAAI,CAAC,WAAW,KAAK,KAAK,KAAK,UAAU,eAAe;AACtD,aAAO;AAAA,IACT;AACA,WAAO,aAAa,KAAK;AAAA,EAC3B;AACF;",
6
+ "names": []
7
+ }
@@ -3,11 +3,14 @@ import customParseFormat from "dayjs/plugin/customParseFormat";
3
3
  dayjs.extend(customParseFormat);
4
4
  const VALID_DATE_FORMATS = ["DD/MM/YYYY"];
5
5
  const DATE_CACHE = {};
6
+ const onlyNumbersRegex = /^\d+$/;
6
7
  const getDate = (v) => {
7
8
  return DATE_CACHE[v] ? DATE_CACHE[v] : dayjs(v, VALID_DATE_FORMATS, true);
8
9
  };
10
+ const getDaysInMonth = (month, year) => {
11
+ return dayjs(`${year}-${month}-01`).daysInMonth();
12
+ };
9
13
  const checkPartialDate = (value) => {
10
- console.log("value.split('/')", value.split("/"));
11
14
  const [day, month, year] = value.split("/");
12
15
  if (day && !month && !year) {
13
16
  return "form.error.date.invalid_month_year";
@@ -26,9 +29,29 @@ const checkPartialDate = (value) => {
26
29
  }
27
30
  if (!day && month && year) {
28
31
  return "form.error.date.invalid_day";
29
- } else {
30
- return "form.error.date.invalid";
31
32
  }
33
+ if (day && month) {
34
+ const dayNum = parseInt(day);
35
+ const monthNum = parseInt(month);
36
+ const validYear = onlyNumbersRegex.test(year) ? year : void 0;
37
+ if (!validYear || year.length < 4) {
38
+ return "form.error.date.invalid";
39
+ }
40
+ const yearNum = parseInt(validYear);
41
+ const maxDay = getDaysInMonth(monthNum, yearNum);
42
+ if (dayNum < 1 || dayNum > maxDay) {
43
+ return {
44
+ key: "form.error.date.invalid_day_range",
45
+ context: {
46
+ maxDay
47
+ }
48
+ };
49
+ }
50
+ if (monthNum < 1 || monthNum > 12) {
51
+ return "form.error.datetime.invalid_month_range";
52
+ }
53
+ }
54
+ return "form.error.date.invalid";
32
55
  };
33
56
  const LATER_THAN_VALIDATOR = (field) => {
34
57
  let minDate;
@@ -1,9 +1,9 @@
1
- import { FieldSpec } from '@digigov/form/types';
2
- import { ValidatorSchema } from '@digigov/form/validators/types';
1
+ import type { FieldSpec } from '@digigov/form/types';
2
+ import type { ValidatorSchema } from '@digigov/form/validators/types';
3
3
  export declare const LATER_THAN_VALIDATOR: (field: FieldSpec) => ValidatorSchema;
4
4
  export declare const EARLIER_THAN_VALIDATOR: (field: FieldSpec) => ValidatorSchema;
5
5
  export declare const DATE_VALIDATOR: {
6
6
  name: string;
7
- message: (v: any) => string;
7
+ message: (v: any) => string | object;
8
8
  test: (value: string) => any;
9
9
  };
@@ -1,7 +1,7 @@
1
1
  {
2
2
  "version": 3,
3
3
  "sources": ["../../../src/validators/utils/date.ts"],
4
- "sourcesContent": ["import dayjs from 'dayjs';\nimport customParseFormat from 'dayjs/plugin/customParseFormat';\nimport { FieldSpec } from '@digigov/form/types';\nimport { ValidatorSchema } from '@digigov/form/validators/types';\n\ndayjs.extend(customParseFormat);\n\nconst VALID_DATE_FORMATS = ['DD/MM/YYYY'];\nconst DATE_CACHE = {};\n\nconst getDate = (v: string) => {\n return DATE_CACHE[v] ? DATE_CACHE[v] : dayjs(v, VALID_DATE_FORMATS, true);\n};\n\n// Function to check partial date completion\nconst checkPartialDate = (value: string) => {\n console.log(\"value.split('/')\", value.split('/'));\n const [day, month, year] = value.split('/');\n if (day && !month && !year) {\n return 'form.error.date.invalid_month_year';\n }\n if (!day && month && !year) {\n return 'form.error.date.invalid_day_year';\n }\n if (!day && !month && year) {\n return 'form.error.date.invalid_day_month';\n }\n if (day && month && !year) {\n return 'form.error.date.invalid_year';\n }\n if (day && !month && year) {\n return 'form.error.date.invalid_month';\n }\n if (!day && month && year) {\n return 'form.error.date.invalid_day';\n } else {\n return 'form.error.date.invalid';\n }\n};\n\nexport const LATER_THAN_VALIDATOR = (field: FieldSpec): ValidatorSchema => {\n let minDate;\n const params = field.extra || {};\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 return {\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: string) {\n if (!value) return true;\n const date = getDate(value);\n const isValid = +date.toDate() > +minDate;\n return isValid;\n },\n };\n};\n\nexport const EARLIER_THAN_VALIDATOR = (field: FieldSpec): ValidatorSchema => {\n let maxDate;\n const params = field.extra || {};\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 return {\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: string) {\n if (!value) return true;\n const date = getDate(value);\n const isValid = +date.toDate() < +maxDate;\n return isValid;\n },\n };\n};\n\nexport const DATE_VALIDATOR = {\n name: 'date-validator',\n message: (v): string => {\n return checkPartialDate(v.value);\n },\n test: function (value: string) {\n if (!value) return true;\n const date = getDate(value);\n return date.isValid();\n },\n};\n"],
5
- "mappings": "AAAA,OAAO,WAAW;AAClB,OAAO,uBAAuB;AAI9B,MAAM,OAAO,iBAAiB;AAE9B,MAAM,qBAAqB,CAAC,YAAY;AACxC,MAAM,aAAa,CAAC;AAEpB,MAAM,UAAU,CAAC,MAAc;AAC7B,SAAO,WAAW,CAAC,IAAI,WAAW,CAAC,IAAI,MAAM,GAAG,oBAAoB,IAAI;AAC1E;AAGA,MAAM,mBAAmB,CAAC,UAAkB;AAC1C,UAAQ,IAAI,oBAAoB,MAAM,MAAM,GAAG,CAAC;AAChD,QAAM,CAAC,KAAK,OAAO,IAAI,IAAI,MAAM,MAAM,GAAG;AAC1C,MAAI,OAAO,CAAC,SAAS,CAAC,MAAM;AAC1B,WAAO;AAAA,EACT;AACA,MAAI,CAAC,OAAO,SAAS,CAAC,MAAM;AAC1B,WAAO;AAAA,EACT;AACA,MAAI,CAAC,OAAO,CAAC,SAAS,MAAM;AAC1B,WAAO;AAAA,EACT;AACA,MAAI,OAAO,SAAS,CAAC,MAAM;AACzB,WAAO;AAAA,EACT;AACA,MAAI,OAAO,CAAC,SAAS,MAAM;AACzB,WAAO;AAAA,EACT;AACA,MAAI,CAAC,OAAO,SAAS,MAAM;AACzB,WAAO;AAAA,EACT,OAAO;AACL,WAAO;AAAA,EACT;AACF;AAEO,MAAM,uBAAuB,CAAC,UAAsC;AACzE,MAAI;AACJ,QAAM,SAAS,MAAM,SAAS,CAAC;AAC/B,MAAI,OAAO,QAAQ,OAAO;AACxB,UAAM,QAAQ,oBAAI,KAAK;AACvB,cAAU,IAAI,KAAK,KAAK;AAAA,EAC1B,OAAO;AACL,cAAU,QAAQ,OAAO,GAAG,EAAE,OAAO;AAAA,EACvC;AACA,QAAM,kBAAkB,IAAI,KAAK,OAAO;AACxC,kBAAgB,QAAQ,QAAQ,QAAQ,IAAI,CAAC;AAC7C,SAAO;AAAA,IACL,MAAM;AAAA,IACN,SAAS;AAAA,MACP,KAAK;AAAA,MACL,SAAS;AAAA,QACP,SAAS,gBAAgB,mBAAmB;AAAA,MAC9C;AAAA,IACF;AAAA,IACA,MAAM,SAAU,OAAe;AAC7B,UAAI,CAAC,MAAO,QAAO;AACnB,YAAM,OAAO,QAAQ,KAAK;AAC1B,YAAM,UAAU,CAAC,KAAK,OAAO,IAAI,CAAC;AAClC,aAAO;AAAA,IACT;AAAA,EACF;AACF;AAEO,MAAM,yBAAyB,CAAC,UAAsC;AAC3E,MAAI;AACJ,QAAM,SAAS,MAAM,SAAS,CAAC;AAC/B,MAAI,OAAO,QAAQ,OAAO;AACxB,UAAM,QAAQ,oBAAI,KAAK;AACvB,cAAU,IAAI,KAAK,KAAK;AAAA,EAC1B,OAAO;AACL,cAAU,QAAQ,OAAO,GAAG,EAAE,OAAO;AAAA,EACvC;AACA,QAAM,cAAc,IAAI,KAAK,OAAO;AACpC,cAAY,QAAQ,QAAQ,QAAQ,IAAI,CAAC;AACzC,SAAO;AAAA,IACL,MAAM;AAAA,IACN,SAAS;AAAA,MACP,KAAK;AAAA,MACL,SAAS;AAAA,QACP,SAAS,YAAY,mBAAmB;AAAA,MAC1C;AAAA,IACF;AAAA,IACA,MAAM,SAAU,OAAe;AAC7B,UAAI,CAAC,MAAO,QAAO;AACnB,YAAM,OAAO,QAAQ,KAAK;AAC1B,YAAM,UAAU,CAAC,KAAK,OAAO,IAAI,CAAC;AAClC,aAAO;AAAA,IACT;AAAA,EACF;AACF;AAEO,MAAM,iBAAiB;AAAA,EAC5B,MAAM;AAAA,EACN,SAAS,CAAC,MAAc;AACtB,WAAO,iBAAiB,EAAE,KAAK;AAAA,EACjC;AAAA,EACA,MAAM,SAAU,OAAe;AAC7B,QAAI,CAAC,MAAO,QAAO;AACnB,UAAM,OAAO,QAAQ,KAAK;AAC1B,WAAO,KAAK,QAAQ;AAAA,EACtB;AACF;",
4
+ "sourcesContent": ["import dayjs from 'dayjs';\nimport customParseFormat from 'dayjs/plugin/customParseFormat';\nimport type { FieldSpec } from '@digigov/form/types';\nimport type { ValidatorSchema } from '@digigov/form/validators/types';\n\ndayjs.extend(customParseFormat);\n\nconst VALID_DATE_FORMATS = ['DD/MM/YYYY'];\nconst DATE_CACHE = {};\nconst onlyNumbersRegex = /^\\d+$/;\n\nconst getDate = (v: string) => {\n return DATE_CACHE[v] ? DATE_CACHE[v] : dayjs(v, VALID_DATE_FORMATS, true);\n};\n\nconst getDaysInMonth = (month: number, year: number): number => {\n return dayjs(`${year}-${month}-01`).daysInMonth(); // e.g. 29 for Feb 2024\n};\n\n// Function to check partial date completion\nconst checkPartialDate = (value: string) => {\n const [day, month, year] = value.split('/');\n if (day && !month && !year) {\n return 'form.error.date.invalid_month_year';\n }\n if (!day && month && !year) {\n return 'form.error.date.invalid_day_year';\n }\n if (!day && !month && year) {\n return 'form.error.date.invalid_day_month';\n }\n if (day && month && !year) {\n return 'form.error.date.invalid_year';\n }\n if (day && !month && year) {\n return 'form.error.date.invalid_month';\n }\n if (!day && month && year) {\n return 'form.error.date.invalid_day';\n }\n if (day && month) {\n const dayNum = parseInt(day);\n const monthNum = parseInt(month);\n const validYear = onlyNumbersRegex.test(year) ? year : undefined;\n if (!validYear || year.length < 4) {\n return 'form.error.date.invalid';\n }\n const yearNum = parseInt(validYear);\n const maxDay = getDaysInMonth(monthNum, yearNum);\n if (dayNum < 1 || dayNum > maxDay) {\n return {\n key: 'form.error.date.invalid_day_range',\n context: {\n maxDay: maxDay,\n },\n };\n }\n if (monthNum < 1 || monthNum > 12) {\n return 'form.error.datetime.invalid_month_range';\n }\n }\n return 'form.error.date.invalid';\n};\n\nexport const LATER_THAN_VALIDATOR = (field: FieldSpec): ValidatorSchema => {\n let minDate;\n const params = field.extra || {};\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 return {\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: string) {\n if (!value) return true;\n const date = getDate(value);\n const isValid = +date.toDate() > +minDate;\n return isValid;\n },\n };\n};\n\nexport const EARLIER_THAN_VALIDATOR = (field: FieldSpec): ValidatorSchema => {\n let maxDate;\n const params = field.extra || {};\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 return {\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: string) {\n if (!value) return true;\n const date = getDate(value);\n const isValid = +date.toDate() < +maxDate;\n return isValid;\n },\n };\n};\n\nexport const DATE_VALIDATOR = {\n name: 'date-validator',\n message: (v): string | object => {\n return checkPartialDate(v.value);\n },\n test: function (value: string) {\n if (!value) return true;\n const date = getDate(value);\n return date.isValid();\n },\n};\n"],
5
+ "mappings": "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",
6
6
  "names": []
7
7
  }
@@ -3,50 +3,144 @@ import customParseFormat from "dayjs/plugin/customParseFormat";
3
3
  dayjs.extend(customParseFormat);
4
4
  const VALID_DATETIME_FORMATS = ["DD/MM/YYYY HH:mm"];
5
5
  const DATETIME_CACHE = {};
6
+ const onlyNumbersRegex = /^\d+$/;
6
7
  const getDateTime = (v) => {
7
8
  return DATETIME_CACHE[v] ? DATETIME_CACHE[v] : dayjs(v, VALID_DATETIME_FORMATS, true);
8
9
  };
10
+ const getDaysInMonth = (month, year) => {
11
+ return dayjs(`${year}-${month}-01`).daysInMonth();
12
+ };
9
13
  const checkPartialDateTime = (value) => {
10
14
  const [datePart, timePart] = value.split(" ");
11
- const [day, month, year] = datePart.split("/");
12
- const [hours, minutes] = timePart ? timePart.split(":") : [null, null];
13
- if (day && !month && !year) {
15
+ const [day, month, year] = datePart?.split("/") ?? [];
16
+ const [hours, minutes] = timePart?.split(":") ?? [];
17
+ const hasDay = Boolean(day);
18
+ const hasMonth = Boolean(month);
19
+ const hasYear = Boolean(year);
20
+ const hasHours = Boolean(hours);
21
+ const hasMinutes = Boolean(minutes);
22
+ if (hasDay && !hasMonth && !hasYear && !hasHours && !hasMinutes) {
23
+ return "form.error.datetime.invalid_month_year_hours_minutes";
24
+ }
25
+ if (!hasDay && hasMonth && !hasYear && !hasHours && !hasMinutes) {
26
+ return "form.error.datetime.invalid_day_year_hours_minutes";
27
+ }
28
+ if (!hasDay && !hasMonth && hasYear && !hasHours && !hasMinutes) {
29
+ return "form.error.datetime.invalid_day_month_hours_minutes";
30
+ }
31
+ if (hasDay && hasMonth && !hasYear && !hasHours && !hasMinutes) {
32
+ return "form.error.datetime.invalid_year_hours_minutes";
33
+ }
34
+ if (hasDay && !hasMonth && hasYear && !hasHours && !hasMinutes) {
35
+ return "form.error.datetime.invalid_month_hours_minutes";
36
+ }
37
+ if (!hasDay && hasMonth && hasYear && !hasHours && !hasMinutes) {
38
+ return "form.error.datetime.invalid_day_hours_minutes";
39
+ }
40
+ if (hasDay && hasMonth && hasYear && !hasHours && !hasMinutes) {
41
+ return "form.error.datetime.invalid__hours_minutes";
42
+ }
43
+ if (hasDay && hasMonth && hasYear && hasHours && !hasMinutes) {
44
+ return "form.error.datetime.invalid_minutes";
45
+ }
46
+ if (hasDay && hasMonth && hasYear && !hasHours && hasMinutes) {
47
+ return "form.error.datetime.invalid_hours";
48
+ }
49
+ if (hasDay && !hasMonth && !hasYear && hasHours && !hasMinutes) {
50
+ return "form.error.datetime.invalid_month_year_minutes";
51
+ }
52
+ if (hasDay && !hasMonth && !hasYear && !hasHours && hasMinutes) {
53
+ return "form.error.datetime.invalid_month_year_hours";
54
+ }
55
+ if (hasDay && !hasMonth && !hasYear && hasHours && hasMinutes) {
14
56
  return "form.error.datetime.invalid_month_year";
15
57
  }
16
- if (!day && month && !year) {
58
+ if (!hasDay && hasMonth && !hasYear && hasHours && !hasMinutes) {
59
+ return "form.error.datetime.invalid_day_year_minutes";
60
+ }
61
+ if (!hasDay && hasMonth && !hasYear && !hasHours && hasMinutes) {
62
+ return "form.error.datetime.invalid_day_year_hours";
63
+ }
64
+ if (!hasDay && hasMonth && !hasYear && hasHours && hasMinutes) {
17
65
  return "form.error.datetime.invalid_day_year";
18
66
  }
19
- if (!day && !month && year) {
67
+ if (!hasDay && !hasMonth && hasYear && hasHours && !hasMinutes) {
68
+ return "form.error.datetime.invalid_day_month_minutes";
69
+ }
70
+ if (!hasDay && !hasMonth && hasYear && !hasHours && hasMinutes) {
71
+ return "form.error.datetime.invalid_day_month_hours";
72
+ }
73
+ if (!hasDay && !hasMonth && hasYear && hasHours && hasMinutes) {
20
74
  return "form.error.datetime.invalid_day_month";
21
75
  }
22
- if (day && month && !year) {
76
+ if (!hasDay && !hasMonth && !hasYear && hasHours && hasMinutes) {
77
+ return "form.error.datetime.invalid_day_month_year";
78
+ }
79
+ if (!hasDay && !hasMonth && !hasYear && !hasHours && hasMinutes) {
80
+ return "form.error.datetime.invalid_day_month_year_hours";
81
+ }
82
+ if (hasDay && hasMonth && !hasYear && hasHours && !hasMinutes) {
83
+ return "form.error.datetime.invalid_year_minutes";
84
+ }
85
+ if (hasDay && hasMonth && !hasYear && !hasHours && hasMinutes) {
86
+ return "form.error.datetime.invalid_year_hours";
87
+ }
88
+ if (hasDay && hasMonth && !hasYear && hasHours && hasMinutes) {
23
89
  return "form.error.datetime.invalid_year";
24
90
  }
25
- if (day && !month && year) {
91
+ if (hasDay && !hasMonth && hasYear && hasHours && !hasMinutes) {
92
+ return "form.error.datetime.invalid_month_minutes";
93
+ }
94
+ if (hasDay && !hasMonth && hasYear && !hasHours && hasMinutes) {
95
+ return "form.error.datetime.invalid_month_hours";
96
+ }
97
+ if (hasDay && !hasMonth && hasYear && hasHours && hasMinutes) {
26
98
  return "form.error.datetime.invalid_month";
27
99
  }
28
- if (!day && month && year) {
100
+ if (!hasDay && hasMonth && hasYear && hasHours && !hasMinutes) {
101
+ return "form.error.datetime.invalid_day_minutes";
102
+ }
103
+ if (!hasDay && hasMonth && hasYear && !hasHours && hasMinutes) {
104
+ return "form.error.datetime.invalid_day_hours";
105
+ }
106
+ if (!hasDay && hasMonth && hasYear && hasHours && hasMinutes) {
29
107
  return "form.error.datetime.invalid_day";
30
108
  }
31
- if (day && month && year) {
32
- if (hours && !minutes) {
33
- return "form.error.datetime.invalid_minutes";
109
+ if (!hasDay && !hasMonth && !hasYear && hasHours && !hasMinutes) {
110
+ return "form.error.datetime.invalid_day_month_year_minutes";
111
+ }
112
+ if (hasDay && hasMonth && hasYear && !hasHours && !hasMinutes) {
113
+ return "form.error.datetime.invalid_hours_minutes";
114
+ }
115
+ if (day && month) {
116
+ const dayNum = parseInt(day);
117
+ const monthNum = parseInt(month);
118
+ const validYear = onlyNumbersRegex.test(year) ? year : void 0;
119
+ if (!validYear || year.length < 4) {
120
+ return "form.error.datetime.invalid";
34
121
  }
35
- if (!hours && minutes) {
36
- return "form.error.datetime.invalid_hours";
122
+ const yearNum = parseInt(validYear);
123
+ const maxDay = getDaysInMonth(monthNum, yearNum);
124
+ if (dayNum < 1 || dayNum > maxDay) {
125
+ return {
126
+ key: "form.error.datetime.invalid_day_range",
127
+ context: {
128
+ maxDay
129
+ }
130
+ };
37
131
  }
38
- if (!hours && !minutes) {
39
- return "form.error.datetime.invalid";
132
+ if (monthNum < 1 || monthNum > 12) {
133
+ return "form.error.datetime.invalid_month_range";
40
134
  }
41
- if (hours && minutes) {
42
- const hoursNum = parseInt(hours);
43
- const minutesNum = parseInt(minutes);
44
- if (hoursNum < 0 || hoursNum > 23) {
45
- return "form.error.datetime.invalid_hours_range";
46
- }
47
- if (minutesNum < 0 || minutesNum > 59) {
48
- return "form.error.datetime.invalid_minutes_range";
49
- }
135
+ }
136
+ if (hours && minutes) {
137
+ const hoursNum = parseInt(hours);
138
+ const minutesNum = parseInt(minutes);
139
+ if (hoursNum < 0 || hoursNum > 23) {
140
+ return "form.error.datetime.invalid_hours_range";
141
+ }
142
+ if (minutesNum < 0 || minutesNum > 59) {
143
+ return "form.error.datetime.invalid_minutes_range";
50
144
  }
51
145
  }
52
146
  return "form.error.datetime.invalid";
@@ -1,9 +1,9 @@
1
- import { FieldSpec } from '@digigov/form/types';
2
- import { ValidatorSchema } from '@digigov/form/validators/types';
1
+ import type { FieldSpec } from '@digigov/form/types';
2
+ import type { ValidatorSchema } from '@digigov/form/validators/types';
3
3
  export declare const LATER_THAN_DATETIME_VALIDATOR: (field: FieldSpec) => ValidatorSchema;
4
4
  export declare const EARLIER_THAN_DATETIME_VALIDATOR: (field: FieldSpec) => ValidatorSchema;
5
5
  export declare const DATETIME_VALIDATOR: {
6
6
  name: string;
7
- message: (v: any) => string;
7
+ message: (v: any) => string | object;
8
8
  test: (value: string) => any;
9
9
  };