@digigov/form 2.0.0-a32ad9b2 → 2.0.0-abd768eb

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 (331) hide show
  1. package/Field/FieldBase/index.js +7 -2
  2. package/Field/FieldBase.js.map +2 -2
  3. package/Field/FieldBaseContainer/index.js +37 -18
  4. package/Field/FieldBaseContainer.d.ts +1 -1
  5. package/Field/FieldBaseContainer.js.map +2 -2
  6. package/Field/FieldConditional/index.js +4 -0
  7. package/Field/FieldConditional.js.map +2 -2
  8. package/Field/index.js +10 -4
  9. package/Field/index.js.map +2 -2
  10. package/Field/types.d.ts +10 -3
  11. package/Field/utils/index.js +3 -1
  12. package/Field/utils/index.js.map +2 -2
  13. package/Field/utils/useField/index.js +8 -1
  14. package/Field/utils/useField.js.map +2 -2
  15. package/FieldArray/FormDialog/index.js +314 -196
  16. package/FieldArray/FormDialog.d.ts +20 -7
  17. package/FieldArray/FormDialog.js.map +3 -3
  18. package/FieldArray/__stories__/Default.d.ts +1 -1
  19. package/FieldArray/__stories__/WithExactLength.d.ts +1 -1
  20. package/FieldArray/__stories__/WithModal.d.ts +1 -1
  21. package/FieldArray/index.d.ts +1 -0
  22. package/FieldArray/index.js +32 -8
  23. package/FieldArray/index.js.map +2 -2
  24. package/FieldObject/index.d.ts +3 -0
  25. package/FieldObject/index.js +26 -15
  26. package/FieldObject/index.js.map +2 -2
  27. package/FormBuilder/FormBuilder.stories.d.ts +2 -0
  28. package/FormBuilder/__stories__/AutoErrorGrouping.d.ts +1 -1
  29. package/FormBuilder/__stories__/Default.d.ts +1 -1
  30. package/FormBuilder/__stories__/ErrorGrouping.d.ts +1 -1
  31. package/FormBuilder/index.d.ts +1 -1
  32. package/FormBuilder/index.js +11 -7
  33. package/FormBuilder/index.js.map +2 -2
  34. package/FormContext/index.js +6 -2
  35. package/FormContext.d.ts +1 -0
  36. package/FormContext.js.map +2 -2
  37. package/MultiplicityField/MultiplicityField.stories.d.ts +2 -0
  38. package/MultiplicityField/__stories__/Default.d.ts +1 -1
  39. package/MultiplicityField/__stories__/PreviewDisplay.d.ts +1 -1
  40. package/MultiplicityField/__stories__/WithExactLength.d.ts +1 -1
  41. package/MultiplicityField/__stories__/WithMaxLength.d.ts +1 -1
  42. package/MultiplicityField/__stories__/WithMinAndMaxLength.d.ts +1 -1
  43. package/MultiplicityField/__stories__/WithMinLength.d.ts +1 -1
  44. package/MultiplicityField/add-objects/index.js +2 -0
  45. package/MultiplicityField/add-objects.js.map +2 -2
  46. package/MultiplicityField/index.js +4 -1
  47. package/MultiplicityField/index.js.map +2 -2
  48. package/MultiplicityField/types.d.ts +1 -0
  49. package/Questions/Questions.stories.d.ts +2 -0
  50. package/Questions/__stories__/Default.d.ts +1 -1
  51. package/cjs/Field/FieldBase/index.js +7 -2
  52. package/cjs/Field/FieldBase.js.map +2 -2
  53. package/cjs/Field/FieldBaseContainer/index.js +36 -17
  54. package/cjs/Field/FieldBaseContainer.js.map +3 -3
  55. package/cjs/Field/FieldConditional/index.js +4 -0
  56. package/cjs/Field/FieldConditional.js.map +2 -2
  57. package/cjs/Field/index.js +10 -4
  58. package/cjs/Field/index.js.map +2 -2
  59. package/cjs/Field/types.js.map +1 -1
  60. package/cjs/Field/utils/index.js +3 -1
  61. package/cjs/Field/utils/index.js.map +2 -2
  62. package/cjs/Field/utils/useField/index.js +8 -1
  63. package/cjs/Field/utils/useField.js.map +2 -2
  64. package/cjs/FieldArray/FormDialog/index.js +309 -194
  65. package/cjs/FieldArray/FormDialog.js.map +3 -3
  66. package/cjs/FieldArray/index.js +31 -7
  67. package/cjs/FieldArray/index.js.map +2 -2
  68. package/cjs/FieldObject/index.js +26 -15
  69. package/cjs/FieldObject/index.js.map +2 -2
  70. package/cjs/FormBuilder/index.js +11 -7
  71. package/cjs/FormBuilder/index.js.map +2 -2
  72. package/cjs/FormContext/index.js +7 -2
  73. package/cjs/FormContext.js.map +2 -2
  74. package/cjs/MultiplicityField/add-objects/index.js +2 -0
  75. package/cjs/MultiplicityField/add-objects.js.map +2 -2
  76. package/cjs/MultiplicityField/index.js +4 -1
  77. package/cjs/MultiplicityField/index.js.map +2 -2
  78. package/cjs/MultiplicityField/types.js.map +1 -1
  79. package/cjs/inputs/Checkboxes/index.js +2 -2
  80. package/cjs/inputs/Checkboxes/index.js.map +2 -2
  81. package/cjs/inputs/DateInput/index.js +41 -14
  82. package/cjs/inputs/DateInput/index.js.map +2 -2
  83. package/cjs/inputs/DateTimeInput/index.js +68 -34
  84. package/cjs/inputs/DateTimeInput/index.js.map +2 -2
  85. package/cjs/inputs/FileInput/index.js +52 -29
  86. package/cjs/inputs/FileInput/index.js.map +2 -2
  87. package/cjs/inputs/ImageInput/__stories__/logo.d/index.js +1 -0
  88. package/cjs/inputs/ImageInput/__stories__/logo.d.js.map +7 -0
  89. package/cjs/inputs/ImageInput/index.js +41 -10
  90. package/cjs/inputs/ImageInput/index.js.map +2 -2
  91. package/cjs/inputs/Input/index.js +4 -4
  92. package/cjs/inputs/Input/index.js.map +2 -2
  93. package/cjs/inputs/Select/index.js +4 -3
  94. package/cjs/inputs/Select/index.js.map +2 -2
  95. package/cjs/inputs/inputsScenarios/index.js +2 -2
  96. package/cjs/inputs/inputsScenarios.js.map +2 -2
  97. package/cjs/lazy/index.js +2 -1
  98. package/cjs/lazy.js.map +2 -2
  99. package/cjs/registry/index.js +6 -6
  100. package/cjs/registry.js.map +2 -2
  101. package/cjs/types.js.map +1 -1
  102. package/cjs/utils/index.js +20 -6
  103. package/cjs/utils.js.map +2 -2
  104. package/cjs/validators/index.js +11 -6
  105. package/cjs/validators/index.js.map +2 -2
  106. package/cjs/validators/utils/amka/index.js +60 -0
  107. package/cjs/validators/utils/amka.js.map +7 -0
  108. package/cjs/validators/utils/date/index.js +26 -3
  109. package/cjs/validators/utils/date.js.map +2 -2
  110. package/cjs/validators/utils/datetime/index.js +118 -24
  111. package/cjs/validators/utils/datetime.js.map +2 -2
  112. package/cjs/validators/utils/file/index.js +30 -17
  113. package/cjs/validators/utils/file.js.map +2 -2
  114. package/cjs/validators/utils/index.js +5 -1
  115. package/cjs/validators/utils/index.js.map +2 -2
  116. package/index.js +1 -1
  117. package/inputs/AutoCompleteInput/AutoComplete.stories.d.ts +2 -0
  118. package/inputs/AutoCompleteInput/__stories__/Default.d.ts +1 -1
  119. package/inputs/AutoCompleteInput/__stories__/Multiple.d.ts +1 -1
  120. package/inputs/Checkboxes/Checkboxes.stories.d.ts +2 -0
  121. package/inputs/Checkboxes/__stories__/Conditional.d.ts +1 -1
  122. package/inputs/Checkboxes/__stories__/Default.d.ts +1 -1
  123. package/inputs/Checkboxes/__stories__/WithDivider.d.ts +1 -1
  124. package/inputs/Checkboxes/index.js +2 -2
  125. package/inputs/Checkboxes/index.js.map +2 -2
  126. package/inputs/DateInput/DateInput.stories.d.ts +6 -0
  127. package/inputs/DateInput/__stories__/Default.d.ts +1 -1
  128. package/inputs/DateInput/__stories__/WithDefaultValue.d.ts +3 -0
  129. package/inputs/DateInput/__stories__/WithInitialValue.d.ts +3 -0
  130. package/inputs/DateInput/__stories__/WithWrongDefaultValue.d.ts +3 -0
  131. package/inputs/DateInput/__stories__/WithWrongInitialValue.d.ts +3 -0
  132. package/inputs/DateInput/index.js +42 -15
  133. package/inputs/DateInput/index.js.map +2 -2
  134. package/inputs/DateTimeInput/DateTimeInput.stories.d.ts +10 -3
  135. package/inputs/DateTimeInput/__stories__/Default.d.ts +1 -1
  136. package/inputs/DateTimeInput/__stories__/WithDefaultValue.d.ts +3 -0
  137. package/inputs/DateTimeInput/__stories__/WithInitialValue.d.ts +3 -0
  138. package/inputs/DateTimeInput/__stories__/WithWrongDefaultValue.d.ts +3 -0
  139. package/inputs/DateTimeInput/__stories__/WithWrongInitialValue.d.ts +3 -0
  140. package/inputs/DateTimeInput/index.js +69 -35
  141. package/inputs/DateTimeInput/index.js.map +2 -2
  142. package/inputs/FileInput/FileInput.stories.d.ts +3 -0
  143. package/inputs/FileInput/__stories__/Default.d.ts +1 -1
  144. package/inputs/FileInput/__stories__/WithBorderAndLink.d.ts +3 -0
  145. package/inputs/FileInput/index.d.ts +11 -4
  146. package/inputs/FileInput/index.js +57 -31
  147. package/inputs/FileInput/index.js.map +2 -2
  148. package/inputs/ImageInput/ImageInput.stories.d.ts +4 -1
  149. package/inputs/ImageInput/__stories__/Default.d.ts +1 -1
  150. package/inputs/ImageInput/__stories__/MaxSize.d.ts +1 -1
  151. package/inputs/ImageInput/__stories__/WithInitialValues.d.ts +3 -0
  152. package/inputs/ImageInput/__stories__/WithInvalidImageDimension.d.ts +1 -1
  153. package/inputs/ImageInput/__stories__/logo.d/index.js +1 -0
  154. package/inputs/ImageInput/__stories__/logo.d/package.json +6 -0
  155. package/inputs/ImageInput/__stories__/logo.d.js.map +7 -0
  156. package/inputs/ImageInput/index.d.ts +9 -1
  157. package/inputs/ImageInput/index.js +42 -11
  158. package/inputs/ImageInput/index.js.map +2 -2
  159. package/inputs/Input/Input.stories.d.ts +4 -0
  160. package/inputs/Input/__stories__/AFM.d.ts +1 -1
  161. package/inputs/Input/__stories__/AMKA.d.ts +3 -0
  162. package/inputs/Input/__stories__/Boolean.d.ts +1 -1
  163. package/inputs/Input/__stories__/Email.d.ts +3 -0
  164. package/inputs/Input/__stories__/IBAN.d.ts +1 -1
  165. package/inputs/Input/__stories__/Integer.d.ts +1 -1
  166. package/inputs/Input/__stories__/LandlineNumber.d.ts +1 -1
  167. package/inputs/Input/__stories__/MobilePhone.d.ts +1 -1
  168. package/inputs/Input/__stories__/PhoneNumber.d.ts +1 -1
  169. package/inputs/Input/__stories__/PostalCode.d.ts +1 -1
  170. package/inputs/Input/__stories__/String.d.ts +1 -1
  171. package/inputs/Input/__stories__/StringWithTrimValidation.d.ts +1 -1
  172. package/inputs/Input/__stories__/TextWithLimit.d.ts +1 -1
  173. package/inputs/Input/index.d.ts +2 -1
  174. package/inputs/Input/index.js +4 -4
  175. package/inputs/Input/index.js.map +2 -2
  176. package/inputs/Label/Label.stories.d.ts +2 -0
  177. package/inputs/Label/__stories__/Default.d.ts +1 -1
  178. package/inputs/OtpInput/OtpInput.stories.d.ts +2 -0
  179. package/inputs/OtpInput/__stories__/Default.d.ts +1 -1
  180. package/inputs/Radio/Radio.stories.d.ts +2 -0
  181. package/inputs/Radio/__stories__/Conditional.d.ts +1 -1
  182. package/inputs/Radio/__stories__/Default.d.ts +1 -1
  183. package/inputs/Radio/__stories__/WithDivider.d.ts +1 -1
  184. package/inputs/Select/Select.stories.d.ts +2 -0
  185. package/inputs/Select/__stories__/Default.d.ts +1 -1
  186. package/inputs/Select/index.d.ts +2 -1
  187. package/inputs/Select/index.js +4 -3
  188. package/inputs/Select/index.js.map +2 -2
  189. package/inputs/inputsScenarios/index.js +2 -2
  190. package/inputs/inputsScenarios.d.ts +1 -1
  191. package/inputs/inputsScenarios.js.map +2 -2
  192. package/lazy/index.js +2 -1
  193. package/package.json +4 -4
  194. package/registry/index.js +6 -6
  195. package/src/Field/FieldBase.tsx +6 -1
  196. package/src/Field/FieldBaseContainer.tsx +68 -48
  197. package/src/Field/FieldConditional.tsx +4 -0
  198. package/src/Field/index.tsx +15 -5
  199. package/src/Field/types.tsx +11 -3
  200. package/src/Field/utils/index.ts +2 -0
  201. package/src/Field/utils/useField.ts +9 -1
  202. package/src/FieldArray/FormDialog.tsx +430 -243
  203. package/src/FieldArray/__stories__/Default.tsx +1 -1
  204. package/src/FieldArray/__stories__/WithExactLength.tsx +1 -1
  205. package/src/FieldArray/__stories__/WithModal.tsx +4 -3
  206. package/src/FieldArray/index.tsx +53 -30
  207. package/src/FieldObject/index.tsx +33 -18
  208. package/src/FormBuilder/FormBuilder.stories.js +3 -0
  209. package/src/FormBuilder/__stories__/AutoErrorGrouping.tsx +1 -1
  210. package/src/FormBuilder/__stories__/Default.tsx +1 -1
  211. package/src/FormBuilder/__stories__/ErrorGrouping.tsx +1 -1
  212. package/src/FormBuilder/index.tsx +12 -7
  213. package/src/FormBuilder/scenarios.test.tsx +763 -5
  214. package/src/FormContext.tsx +5 -1
  215. package/src/MultiplicityField/MultiplicityField.stories.js +3 -0
  216. package/src/MultiplicityField/__stories__/Default.tsx +1 -1
  217. package/src/MultiplicityField/__stories__/PreviewDisplay.tsx +1 -1
  218. package/src/MultiplicityField/__stories__/WithExactLength.tsx +1 -1
  219. package/src/MultiplicityField/__stories__/WithMaxLength.tsx +1 -1
  220. package/src/MultiplicityField/__stories__/WithMinAndMaxLength.tsx +1 -1
  221. package/src/MultiplicityField/__stories__/WithMinLength.tsx +1 -1
  222. package/src/MultiplicityField/add-objects.tsx +2 -0
  223. package/src/MultiplicityField/index.tsx +3 -0
  224. package/src/MultiplicityField/types.ts +1 -0
  225. package/src/Questions/Questions.stories.js +3 -0
  226. package/src/Questions/__stories__/Default.tsx +1 -1
  227. package/src/inputs/AutoCompleteInput/AutoComplete.stories.js +3 -0
  228. package/src/inputs/AutoCompleteInput/__stories__/Default.tsx +1 -1
  229. package/src/inputs/AutoCompleteInput/__stories__/Multiple.tsx +1 -1
  230. package/src/inputs/Checkboxes/Checkboxes.stories.js +3 -0
  231. package/src/inputs/Checkboxes/__stories__/Conditional.tsx +1 -1
  232. package/src/inputs/Checkboxes/__stories__/Default.tsx +1 -1
  233. package/src/inputs/Checkboxes/__stories__/WithDivider.tsx +1 -1
  234. package/src/inputs/Checkboxes/index.tsx +2 -6
  235. package/src/inputs/DateInput/DateInput.stories.js +7 -0
  236. package/src/inputs/DateInput/__stories__/Default.tsx +1 -1
  237. package/src/inputs/DateInput/__stories__/WithDefaultValue.tsx +26 -0
  238. package/src/inputs/DateInput/__stories__/WithInitialValue.tsx +28 -0
  239. package/src/inputs/DateInput/__stories__/WithWrongDefaultValue.tsx +26 -0
  240. package/src/inputs/DateInput/__stories__/WithWrongInitialValue.tsx +28 -0
  241. package/src/inputs/DateInput/index.test.tsx +16 -0
  242. package/src/inputs/DateInput/index.tsx +46 -14
  243. package/src/inputs/DateTimeInput/DateTimeInput.stories.js +12 -6
  244. package/src/inputs/DateTimeInput/__stories__/Default.tsx +1 -1
  245. package/src/inputs/DateTimeInput/__stories__/WithDefaultValue.tsx +26 -0
  246. package/src/inputs/DateTimeInput/__stories__/WithInitialValue.tsx +28 -0
  247. package/src/inputs/DateTimeInput/__stories__/WithWrongDefaultValue.tsx +26 -0
  248. package/src/inputs/DateTimeInput/__stories__/WithWrongInitialValue.tsx +28 -0
  249. package/src/inputs/DateTimeInput/index.test.tsx +16 -0
  250. package/src/inputs/DateTimeInput/index.tsx +73 -34
  251. package/src/inputs/FileInput/FileInput.stories.js +4 -0
  252. package/src/inputs/FileInput/__stories__/Default.tsx +1 -1
  253. package/src/inputs/FileInput/__stories__/WithBorderAndLink.tsx +34 -0
  254. package/src/inputs/FileInput/index.test.tsx +4 -0
  255. package/src/inputs/FileInput/index.tsx +90 -48
  256. package/src/inputs/ImageInput/ImageInput.stories.js +5 -1
  257. package/src/inputs/ImageInput/__stories__/Default.tsx +1 -1
  258. package/src/inputs/ImageInput/__stories__/MaxSize.tsx +3 -2
  259. package/src/inputs/ImageInput/__stories__/WithInitialValues.tsx +45 -0
  260. package/src/inputs/ImageInput/__stories__/WithInvalidImageDimension.tsx +1 -1
  261. package/src/inputs/ImageInput/__stories__/logo.d.ts +4 -0
  262. package/src/inputs/ImageInput/__stories__/logo.png +0 -0
  263. package/src/inputs/ImageInput/index.test.tsx +21 -17
  264. package/src/inputs/ImageInput/index.tsx +100 -48
  265. package/src/inputs/Input/Input.stories.js +5 -0
  266. package/src/inputs/Input/__stories__/AFM.tsx +1 -1
  267. package/src/inputs/Input/__stories__/AMKA.tsx +23 -0
  268. package/src/inputs/Input/__stories__/Boolean.tsx +1 -1
  269. package/src/inputs/Input/__stories__/Email.tsx +23 -0
  270. package/src/inputs/Input/__stories__/IBAN.tsx +1 -1
  271. package/src/inputs/Input/__stories__/Integer.tsx +1 -1
  272. package/src/inputs/Input/__stories__/LandlineNumber.tsx +1 -1
  273. package/src/inputs/Input/__stories__/MobilePhone.tsx +1 -1
  274. package/src/inputs/Input/__stories__/PhoneNumber.tsx +1 -1
  275. package/src/inputs/Input/__stories__/PostalCode.tsx +1 -1
  276. package/src/inputs/Input/__stories__/String.tsx +1 -1
  277. package/src/inputs/Input/__stories__/StringWithTrimValidation.tsx +1 -1
  278. package/src/inputs/Input/__stories__/TextWithLimit.tsx +1 -1
  279. package/src/inputs/Input/index.test.tsx +8 -0
  280. package/src/inputs/Input/index.tsx +5 -3
  281. package/src/inputs/Label/Label.stories.js +3 -0
  282. package/src/inputs/Label/__stories__/Default.tsx +1 -1
  283. package/src/inputs/OtpInput/OtpInput.stories.js +3 -0
  284. package/src/inputs/OtpInput/__stories__/Default.tsx +1 -1
  285. package/src/inputs/Radio/Radio.stories.js +3 -0
  286. package/src/inputs/Radio/__stories__/Conditional.tsx +1 -1
  287. package/src/inputs/Radio/__stories__/Default.tsx +1 -1
  288. package/src/inputs/Radio/__stories__/WithDivider.tsx +1 -1
  289. package/src/inputs/Select/Select.stories.js +3 -0
  290. package/src/inputs/Select/__stories__/Default.tsx +1 -1
  291. package/src/inputs/Select/index.tsx +7 -4
  292. package/src/inputs/inputsScenarios.ts +2 -2
  293. package/src/lazy.js +2 -1
  294. package/src/registry.js +6 -6
  295. package/src/types.tsx +2 -1
  296. package/src/utils.ts +27 -6
  297. package/src/validators/index.ts +17 -6
  298. package/src/validators/utils/amka.ts +39 -0
  299. package/src/validators/utils/date.ts +28 -4
  300. package/src/validators/utils/datetime.ts +121 -29
  301. package/src/validators/utils/file.ts +33 -19
  302. package/src/validators/utils/index.ts +4 -1
  303. package/types.d.ts +2 -1
  304. package/types.js.map +1 -1
  305. package/utils/index.js +20 -6
  306. package/utils.d.ts +2 -0
  307. package/utils.js.map +2 -2
  308. package/validators/index.d.ts +1 -1
  309. package/validators/index.js +12 -6
  310. package/validators/index.js.map +2 -2
  311. package/validators/utils/amka/index.js +36 -0
  312. package/{inputs/Input/inputsInputScenarios → validators/utils/amka}/package.json +1 -1
  313. package/validators/utils/amka.d.ts +6 -0
  314. package/validators/utils/amka.js.map +7 -0
  315. package/validators/utils/date/index.js +26 -3
  316. package/validators/utils/date.d.ts +1 -1
  317. package/validators/utils/date.js.map +2 -2
  318. package/validators/utils/datetime/index.js +118 -24
  319. package/validators/utils/datetime.d.ts +1 -1
  320. package/validators/utils/datetime.js.map +2 -2
  321. package/validators/utils/file/index.js +30 -17
  322. package/validators/utils/file.js.map +2 -2
  323. package/validators/utils/index.d.ts +1 -0
  324. package/validators/utils/index.js +4 -1
  325. package/validators/utils/index.js.map +2 -2
  326. package/cjs/inputs/Input/inputsInputScenarios/index.js +0 -439
  327. package/cjs/inputs/Input/inputsInputScenarios.js.map +0 -7
  328. package/inputs/Input/inputsInputScenarios/index.js +0 -406
  329. package/inputs/Input/inputsInputScenarios.d.ts +0 -57
  330. package/inputs/Input/inputsInputScenarios.js.map +0 -7
  331. package/src/inputs/Input/inputsInputScenarios.ts +0 -404
@@ -432,7 +432,7 @@ export const scenarios = [
432
432
  type: 'error',
433
433
  fieldKey: 'image',
434
434
  args: {
435
- maxSizeToMb: 0.0003,
435
+ maxSize: 0.0003,
436
436
  },
437
437
  text: el.form.error.file_size,
438
438
  },
@@ -440,7 +440,7 @@ export const scenarios = [
440
440
  type: 'error',
441
441
  fieldKey: 'file',
442
442
  args: {
443
- maxSizeToMb: 0.0003,
443
+ maxSize: 0.0003,
444
444
  },
445
445
  text: el.form.error.file_size,
446
446
  },
package/src/lazy.js CHANGED
@@ -9,12 +9,12 @@ export default {
9
9
  'FieldBase': lazy(() => import('@digigov/form/Field/FieldBase').then((module) => ({ default: module['FieldBase'] }))),
10
10
  'FieldBaseContainer': lazy(() => import('@digigov/form/Field/FieldBaseContainer').then((module) => ({ default: module['FieldBaseContainer'] }))),
11
11
  'FieldConditional': lazy(() => import('@digigov/form/Field/FieldConditional').then((module) => ({ default: module['FieldConditional'] }))),
12
- 'FieldObject': lazy(() => import('@digigov/form/FieldObject').then((module) => ({ default: module['FieldObject'] }))),
13
12
  'FormDialog': lazy(() => import('@digigov/form/FieldArray/FormDialog').then((module) => ({ default: module['FormDialog'] }))),
14
13
  'ArrayItemModal': lazy(() => import('@digigov/form/FieldArray/FormDialog').then((module) => ({ default: module['ArrayItemModal'] }))),
15
14
  'ArrayItemHeader': lazy(() => import('@digigov/form/FieldArray/FormDialog').then((module) => ({ default: module['ArrayItemHeader'] }))),
16
15
  'ArrayItemDisplay': lazy(() => import('@digigov/form/FieldArray/FormDialog').then((module) => ({ default: module['ArrayItemDisplay'] }))),
17
16
  'FieldArray': lazy(() => import('@digigov/form/FieldArray').then((module) => ({ default: module['FieldArray'] }))),
17
+ 'FieldObject': lazy(() => import('@digigov/form/FieldObject').then((module) => ({ default: module['FieldObject'] }))),
18
18
  'FieldsetWithContext': lazy(() => import('@digigov/form/Fieldset/FieldsetWithContext').then((module) => ({ default: module['FieldsetWithContext'] }))),
19
19
  'FieldsetLabel': lazy(() => import('@digigov/form/Fieldset').then((module) => ({ default: module['FieldsetLabel'] }))),
20
20
  'FieldsetCaption': lazy(() => import('@digigov/form/Fieldset').then((module) => ({ default: module['FieldsetCaption'] }))),
@@ -57,6 +57,7 @@ export default {
57
57
  'RadioButtonsGroup': lazy(() => import('@digigov/form/inputs/Radio').then((module) => ({ default: module['RadioButtonsGroup'] }))),
58
58
  'ControlledRadioButtonsGroup': lazy(() => import('@digigov/form/inputs/Radio').then((module) => ({ default: module['ControlledRadioButtonsGroup'] }))),
59
59
  'AFM_VALIDATOR': lazy(() => import('@digigov/form/validators/utils').then((module) => ({ default: module['AFM_VALIDATOR'] }))),
60
+ 'AMKA_VALIDATOR': lazy(() => import('@digigov/form/validators/utils').then((module) => ({ default: module['AMKA_VALIDATOR'] }))),
60
61
  'LATER_THAN_VALIDATOR': lazy(() => import('@digigov/form/validators/utils').then((module) => ({ default: module['LATER_THAN_VALIDATOR'] }))),
61
62
  'EARLIER_THAN_VALIDATOR': lazy(() => import('@digigov/form/validators/utils').then((module) => ({ default: module['EARLIER_THAN_VALIDATOR'] }))),
62
63
  'DATE_VALIDATOR': lazy(() => import('@digigov/form/validators/utils').then((module) => ({ default: module['DATE_VALIDATOR'] }))),
package/src/registry.js CHANGED
@@ -10,9 +10,9 @@ import * as _digigov_form_Field_FieldBaseContainer from "@digigov/form/Field/Fie
10
10
  import * as _digigov_form_Field_FieldConditional from "@digigov/form/Field/FieldConditional";
11
11
  import * as _digigov_form_Field from "@digigov/form/Field";
12
12
  import * as _digigov_form_Field_types from "@digigov/form/Field/types";
13
- import * as _digigov_form_FieldObject from "@digigov/form/FieldObject";
14
13
  import * as _digigov_form_FieldArray_FormDialog from "@digigov/form/FieldArray/FormDialog";
15
14
  import * as _digigov_form_FieldArray from "@digigov/form/FieldArray";
15
+ import * as _digigov_form_FieldObject from "@digigov/form/FieldObject";
16
16
  import * as _digigov_form_Fieldset_FieldsetWithContext from "@digigov/form/Fieldset/FieldsetWithContext";
17
17
  import * as _digigov_form_Fieldset from "@digigov/form/Fieldset";
18
18
  import * as _digigov_form_Fieldset_types from "@digigov/form/Fieldset/types";
@@ -48,16 +48,16 @@ import * as _digigov_form_Questions_Step_types from "@digigov/form/Questions/Ste
48
48
  import * as _digigov_form_inputs_AutoCompleteInput from "@digigov/form/inputs/AutoCompleteInput";
49
49
  import * as _digigov_form_inputs_Checkboxes from "@digigov/form/inputs/Checkboxes";
50
50
  import * as _digigov_form_inputs_DateInput from "@digigov/form/inputs/DateInput";
51
- import * as _digigov_form_inputs_DateTimeInput from "@digigov/form/inputs/DateTimeInput";
52
51
  import * as _digigov_form_inputs_FileInput from "@digigov/form/inputs/FileInput";
52
+ import * as _digigov_form_inputs_DateTimeInput from "@digigov/form/inputs/DateTimeInput";
53
53
  import * as _digigov_form_inputs_ImageInput from "@digigov/form/inputs/ImageInput";
54
54
  import * as _digigov_form_inputs_Input from "@digigov/form/inputs/Input";
55
- import * as _digigov_form_inputs_Input_inputsInputScenarios from "@digigov/form/inputs/Input/inputsInputScenarios";
56
55
  import * as _digigov_form_inputs_Label from "@digigov/form/inputs/Label";
57
56
  import * as _digigov_form_inputs_OtpInput from "@digigov/form/inputs/OtpInput";
58
57
  import * as _digigov_form_inputs_Radio from "@digigov/form/inputs/Radio";
59
58
  import * as _digigov_form_inputs_Select from "@digigov/form/inputs/Select";
60
59
  import * as _digigov_form_validators_utils_afm from "@digigov/form/validators/utils/afm";
60
+ import * as _digigov_form_validators_utils_amka from "@digigov/form/validators/utils/amka";
61
61
  import * as _digigov_form_validators_utils_date from "@digigov/form/validators/utils/date";
62
62
  import * as _digigov_form_validators_utils_datetime from "@digigov/form/validators/utils/datetime";
63
63
  import * as _digigov_form_validators_utils_file from "@digigov/form/validators/utils/file";
@@ -101,9 +101,9 @@ export default {
101
101
  '@digigov/form/Field/FieldConditional': lazyImport(_digigov_form_Field_FieldConditional),
102
102
  '@digigov/form/Field': lazyImport(_digigov_form_Field),
103
103
  '@digigov/form/Field/types': lazyImport(_digigov_form_Field_types),
104
- '@digigov/form/FieldObject': lazyImport(_digigov_form_FieldObject),
105
104
  '@digigov/form/FieldArray/FormDialog': lazyImport(_digigov_form_FieldArray_FormDialog),
106
105
  '@digigov/form/FieldArray': lazyImport(_digigov_form_FieldArray),
106
+ '@digigov/form/FieldObject': lazyImport(_digigov_form_FieldObject),
107
107
  '@digigov/form/Fieldset/FieldsetWithContext': lazyImport(_digigov_form_Fieldset_FieldsetWithContext),
108
108
  '@digigov/form/Fieldset': lazyImport(_digigov_form_Fieldset),
109
109
  '@digigov/form/Fieldset/types': lazyImport(_digigov_form_Fieldset_types),
@@ -139,16 +139,16 @@ export default {
139
139
  '@digigov/form/inputs/AutoCompleteInput': lazyImport(_digigov_form_inputs_AutoCompleteInput),
140
140
  '@digigov/form/inputs/Checkboxes': lazyImport(_digigov_form_inputs_Checkboxes),
141
141
  '@digigov/form/inputs/DateInput': lazyImport(_digigov_form_inputs_DateInput),
142
- '@digigov/form/inputs/DateTimeInput': lazyImport(_digigov_form_inputs_DateTimeInput),
143
142
  '@digigov/form/inputs/FileInput': lazyImport(_digigov_form_inputs_FileInput),
143
+ '@digigov/form/inputs/DateTimeInput': lazyImport(_digigov_form_inputs_DateTimeInput),
144
144
  '@digigov/form/inputs/ImageInput': lazyImport(_digigov_form_inputs_ImageInput),
145
145
  '@digigov/form/inputs/Input': lazyImport(_digigov_form_inputs_Input),
146
- '@digigov/form/inputs/Input/inputsInputScenarios': lazyImport(_digigov_form_inputs_Input_inputsInputScenarios),
147
146
  '@digigov/form/inputs/Label': lazyImport(_digigov_form_inputs_Label),
148
147
  '@digigov/form/inputs/OtpInput': lazyImport(_digigov_form_inputs_OtpInput),
149
148
  '@digigov/form/inputs/Radio': lazyImport(_digigov_form_inputs_Radio),
150
149
  '@digigov/form/inputs/Select': lazyImport(_digigov_form_inputs_Select),
151
150
  '@digigov/form/validators/utils/afm': lazyImport(_digigov_form_validators_utils_afm),
151
+ '@digigov/form/validators/utils/amka': lazyImport(_digigov_form_validators_utils_amka),
152
152
  '@digigov/form/validators/utils/date': lazyImport(_digigov_form_validators_utils_date),
153
153
  '@digigov/form/validators/utils/datetime': lazyImport(_digigov_form_validators_utils_datetime),
154
154
  '@digigov/form/validators/utils/file': lazyImport(_digigov_form_validators_utils_file),
package/src/types.tsx CHANGED
@@ -1,4 +1,4 @@
1
- import { UseFormReturn, UseFormProps } from 'react-hook-form';
1
+ import { UseFormReturn, UseFormProps, ErrorOption } from 'react-hook-form';
2
2
  import {
3
3
  FieldComponentRegistry,
4
4
  FieldLabelProps,
@@ -54,6 +54,7 @@ export interface FormBuilderProps {
54
54
  componentRegistry?: FieldComponentRegistry;
55
55
  grid?: boolean;
56
56
  controlledFieldsOnly?: boolean;
57
+ errors?: ErrorOption;
57
58
  }
58
59
 
59
60
  export interface FormBaseProps
package/src/utils.ts CHANGED
@@ -13,6 +13,7 @@ const parseErrorSchema = (
13
13
  return (error.inner || []).reduce<Record<string, FieldError>>(
14
14
  (previous, error) => {
15
15
  error.path = error.path?.replace(/\[([0-9]+)\]/g, '.$1');
16
+ // error.path = error.path?.replace(/\["(.*?)"\]/g, '$1');
16
17
  if (!previous[error.path!]) {
17
18
  previous[error.path!] = { message: error.message, type: error.type! };
18
19
  }
@@ -37,6 +38,26 @@ const parseErrorSchema = (
37
38
  {}
38
39
  );
39
40
  };
41
+ function isPlainObject(obj) {
42
+ return (
43
+ typeof obj === 'object' &&
44
+ obj !== null &&
45
+ Object.prototype.toString.call(obj) === '[object Object]'
46
+ );
47
+ }
48
+ function flattenObject(obj, prefix = '') {
49
+ return Object.keys(obj).reduce((acc, key) => {
50
+ const prefixedKey = prefix ? `${prefix}.${key}` : key;
51
+
52
+ if (isPlainObject(obj[key])) {
53
+ Object.assign(acc, flattenObject(obj[key], prefixedKey));
54
+ } else {
55
+ acc[prefixedKey] = obj[key];
56
+ }
57
+
58
+ return acc;
59
+ }, {});
60
+ }
40
61
 
41
62
  export const yupResolver =
42
63
  (schema: any, schemaOptions: any = {}, resolverOptions: any = {}) =>
@@ -51,7 +72,7 @@ export const yupResolver =
51
72
  const result = await schema[
52
73
  resolverOptions.mode === 'sync' ? 'validateSync' : 'validate'
53
74
  ](
54
- values,
75
+ flattenObject(values),
55
76
  Object.assign({ abortEarly: false }, schemaOptions, { context })
56
77
  );
57
78
 
@@ -67,13 +88,13 @@ export const yupResolver =
67
88
  throw e;
68
89
  }
69
90
 
70
- const parsed = parseErrorSchema(
71
- e,
72
- !options.shouldUseNativeValidation && options.criteriaMode === 'all'
73
- );
74
91
  return {
75
92
  values: {},
76
- errors: parsed,
93
+ errors: parseErrorSchema(
94
+ e,
95
+ !options.shouldUseNativeValidation && options.criteriaMode === 'all'
96
+ ),
97
+ options,
77
98
  };
78
99
  }
79
100
  };
@@ -11,6 +11,7 @@ import { ValidatorSchema } from '@digigov/form/validators/types';
11
11
  import {
12
12
  getYupObjectShape,
13
13
  AFM_VALIDATOR,
14
+ AMKA_VALIDATOR,
14
15
  FILE_MAX_SIZE_VALIDATOR,
15
16
  IBAN_VALIDATOR,
16
17
  OTP_VALIDATOR,
@@ -30,13 +31,15 @@ import {
30
31
  import { INT_VALIDATOR } from '@digigov/form/validators/utils/int';
31
32
  import { NUMBER_VALIDATOR } from '@digigov/form/validators/utils/number';
32
33
 
33
- export const getYUPTypeMap = (): Record<string, any> => {
34
+ export const getYUPTypeMap = (
35
+ validatorRegistry?: Record<string, any>
36
+ ): Record<string, any> => {
34
37
  const yupTypeMap = {
35
38
  file: (field): MixedSchema => {
36
39
  return yup
37
40
  .mixed()
38
41
  .transform((value) => {
39
- if (!value.length) {
42
+ if (!value || value.length === 0) {
40
43
  return null;
41
44
  }
42
45
  return value;
@@ -81,10 +84,13 @@ export const getYUPTypeMap = (): Record<string, any> => {
81
84
  if (typeof field.extra.of === 'object') {
82
85
  // else if the field is an object then it is a scalar type
83
86
  // eg. number, string etc.
87
+ if (field.required) {
88
+ field.extra.min = 1;
89
+ }
84
90
  let arrayValidator = yup
85
91
  .array()
86
- .of(yupTypeMap[field.extra.of.type](field.extra.of))
87
- .required(field.required);
92
+ .nullable()
93
+ .of(yupTypeMap[field.extra.of.type](field.extra.of));
88
94
  if (field.extra.length)
89
95
  arrayValidator = arrayValidator.length(field.extra.length, {
90
96
  key: 'form.error.array.length',
@@ -133,6 +139,10 @@ export const getYUPTypeMap = (): Record<string, any> => {
133
139
  field.trim
134
140
  ? yup.string().trim().test(AFM_VALIDATOR)
135
141
  : yup.string().test(AFM_VALIDATOR),
142
+ amka: (field): yup.StringSchema =>
143
+ field.trim
144
+ ? yup.string().trim().test(AMKA_VALIDATOR)
145
+ : yup.string().test(AMKA_VALIDATOR),
136
146
  uuid4: (field): yup.StringSchema =>
137
147
  field.trim
138
148
  ? yup.string().trim().test(UUID4_VALIDATOR)
@@ -215,6 +225,7 @@ export const getYUPTypeMap = (): Record<string, any> => {
215
225
  }
216
226
  return yup.string().test(DATETIME_VALIDATOR);
217
227
  },
228
+ ...validatorRegistry,
218
229
  };
219
230
  return yupTypeMap;
220
231
  };
@@ -226,7 +237,7 @@ export function useValidationSchema(
226
237
  validatorRegistry?: Record<string, ValidatorSchema[]>
227
238
  ): Lazy<any, unknown> | AnyObjectSchema | void {
228
239
  return useMemo(() => {
229
- const yupTypeMap = getYUPTypeMap();
240
+ const yupTypeMap = getYUPTypeMap(validatorRegistry);
230
241
  return getYupObjectShape(fields, yupTypeMap, validatorRegistry);
231
- }, []);
242
+ }, [fields, validatorRegistry]);
232
243
  }
@@ -0,0 +1,39 @@
1
+ function digitSum(number) {
2
+ const sum = number > 9 ? 1 : 0;
3
+ return sum + (number % 10);
4
+ }
5
+
6
+ export function validateAMKA(amka: string): boolean {
7
+ // Validate that the last digit is the correct check digit (created using the
8
+ // Luhn algorithm https://en.wikipedia.org/wiki/Luhn_algorithm).
9
+ amka = String(amka);
10
+ const checkDigitIndex = amka.length - 1;
11
+ let sum = 0;
12
+ amka
13
+ .substring(0, checkDigitIndex)
14
+ .split('')
15
+ .reverse()
16
+ .forEach(function (value, index) {
17
+ const weight = ((index + 1) % 2) + 1;
18
+ sum += digitSum(parseInt(value, 10) * weight);
19
+ });
20
+ const sumMod10 = sum % 10;
21
+ if (sumMod10 === 0) {
22
+ return amka.substring(checkDigitIndex) === '0';
23
+ } else {
24
+ return amka.substring(checkDigitIndex) === 10 - sumMod10 + '';
25
+ }
26
+ }
27
+
28
+ export const AMKA_VALIDATOR = {
29
+ name: 'amka-validator',
30
+ message: 'form.error.amka',
31
+ test: (value): boolean => {
32
+ if (!value) return true;
33
+ const AMKA_REGEX = /^[0-9]{11}$/;
34
+ if (!AMKA_REGEX.test(value) || value === '00000000000') {
35
+ return false;
36
+ }
37
+ return validateAMKA(value);
38
+ },
39
+ };
@@ -7,14 +7,18 @@ dayjs.extend(customParseFormat);
7
7
 
8
8
  const VALID_DATE_FORMATS = ['DD/MM/YYYY'];
9
9
  const DATE_CACHE = {};
10
+ const onlyNumbersRegex = /^\d+$/;
10
11
 
11
12
  const getDate = (v: string) => {
12
13
  return DATE_CACHE[v] ? DATE_CACHE[v] : dayjs(v, VALID_DATE_FORMATS, true);
13
14
  };
14
15
 
16
+ const getDaysInMonth = (month: number, year: number): number => {
17
+ return dayjs(`${year}-${month}-01`).daysInMonth(); // e.g. 29 for Feb 2024
18
+ };
19
+
15
20
  // Function to check partial date completion
16
21
  const checkPartialDate = (value: string) => {
17
- console.log("value.split('/')", value.split('/'));
18
22
  const [day, month, year] = value.split('/');
19
23
  if (day && !month && !year) {
20
24
  return 'form.error.date.invalid_month_year';
@@ -33,9 +37,29 @@ const checkPartialDate = (value: string) => {
33
37
  }
34
38
  if (!day && month && year) {
35
39
  return 'form.error.date.invalid_day';
36
- } else {
37
- return 'form.error.date.invalid';
38
40
  }
41
+ if (day && month) {
42
+ const dayNum = parseInt(day);
43
+ const monthNum = parseInt(month);
44
+ const validYear = onlyNumbersRegex.test(year) ? year : undefined;
45
+ if (!validYear || year.length < 4) {
46
+ return 'form.error.date.invalid';
47
+ }
48
+ const yearNum = parseInt(validYear);
49
+ const maxDay = getDaysInMonth(monthNum, yearNum);
50
+ if (dayNum < 1 || dayNum > maxDay) {
51
+ return {
52
+ key: 'form.error.date.invalid_day_range',
53
+ context: {
54
+ maxDay: maxDay,
55
+ },
56
+ };
57
+ }
58
+ if (monthNum < 1 || monthNum > 12) {
59
+ return 'form.error.datetime.invalid_month_range';
60
+ }
61
+ }
62
+ return 'form.error.date.invalid';
39
63
  };
40
64
 
41
65
  export const LATER_THAN_VALIDATOR = (field: FieldSpec): ValidatorSchema => {
@@ -96,7 +120,7 @@ export const EARLIER_THAN_VALIDATOR = (field: FieldSpec): ValidatorSchema => {
96
120
 
97
121
  export const DATE_VALIDATOR = {
98
122
  name: 'date-validator',
99
- message: (v): string => {
123
+ message: (v): string | object => {
100
124
  return checkPartialDate(v.value);
101
125
  },
102
126
  test: function (value: string) {
@@ -7,6 +7,7 @@ dayjs.extend(customParseFormat);
7
7
 
8
8
  const VALID_DATETIME_FORMATS = ['DD/MM/YYYY HH:mm'];
9
9
  const DATETIME_CACHE = {};
10
+ const onlyNumbersRegex = /^\d+$/;
10
11
 
11
12
  const getDateTime = (v: string) => {
12
13
  return DATETIME_CACHE[v]
@@ -14,54 +15,145 @@ const getDateTime = (v: string) => {
14
15
  : dayjs(v, VALID_DATETIME_FORMATS, true);
15
16
  };
16
17
 
17
- // Function to check partial datetime completion
18
+ const getDaysInMonth = (month: number, year: number): number => {
19
+ return dayjs(`${year}-${month}-01`).daysInMonth(); // e.g. 29 for Feb 2024
20
+ };
21
+
18
22
  const checkPartialDateTime = (value: string) => {
19
23
  const [datePart, timePart] = value.split(' ');
20
- const [day, month, year] = datePart.split('/');
21
- const [hours, minutes] = timePart ? timePart.split(':') : [null, null];
24
+ const [day, month, year] = datePart?.split('/') ?? [];
25
+ const [hours, minutes] = timePart?.split(':') ?? [];
26
+
27
+ const hasDay = Boolean(day);
28
+ const hasMonth = Boolean(month);
29
+ const hasYear = Boolean(year);
30
+ const hasHours = Boolean(hours);
31
+ const hasMinutes = Boolean(minutes);
22
32
 
23
- // Check date part first
24
- if (day && !month && !year) {
33
+ if (hasDay && !hasMonth && !hasYear && !hasHours && !hasMinutes) {
34
+ return 'form.error.datetime.invalid_month_year_hours_minutes';
35
+ }
36
+ if (!hasDay && hasMonth && !hasYear && !hasHours && !hasMinutes) {
37
+ return 'form.error.datetime.invalid_day_year_hours_minutes';
38
+ }
39
+ if (!hasDay && !hasMonth && hasYear && !hasHours && !hasMinutes) {
40
+ return 'form.error.datetime.invalid_day_month_hours_minutes';
41
+ }
42
+ if (hasDay && hasMonth && !hasYear && !hasHours && !hasMinutes) {
43
+ return 'form.error.datetime.invalid_year_hours_minutes';
44
+ }
45
+ if (hasDay && !hasMonth && hasYear && !hasHours && !hasMinutes) {
46
+ return 'form.error.datetime.invalid_month_hours_minutes';
47
+ }
48
+ if (!hasDay && hasMonth && hasYear && !hasHours && !hasMinutes) {
49
+ return 'form.error.datetime.invalid_day_hours_minutes';
50
+ }
51
+ if (hasDay && hasMonth && hasYear && !hasHours && !hasMinutes) {
52
+ return 'form.error.datetime.invalid__hours_minutes';
53
+ }
54
+ if (hasDay && hasMonth && hasYear && hasHours && !hasMinutes) {
55
+ return 'form.error.datetime.invalid_minutes';
56
+ }
57
+ if (hasDay && hasMonth && hasYear && !hasHours && hasMinutes) {
58
+ return 'form.error.datetime.invalid_hours';
59
+ }
60
+ if (hasDay && !hasMonth && !hasYear && hasHours && !hasMinutes) {
61
+ return 'form.error.datetime.invalid_month_year_minutes';
62
+ }
63
+ if (hasDay && !hasMonth && !hasYear && !hasHours && hasMinutes) {
64
+ return 'form.error.datetime.invalid_month_year_hours';
65
+ }
66
+ if (hasDay && !hasMonth && !hasYear && hasHours && hasMinutes) {
25
67
  return 'form.error.datetime.invalid_month_year';
26
68
  }
27
- if (!day && month && !year) {
69
+ if (!hasDay && hasMonth && !hasYear && hasHours && !hasMinutes) {
70
+ return 'form.error.datetime.invalid_day_year_minutes';
71
+ }
72
+ if (!hasDay && hasMonth && !hasYear && !hasHours && hasMinutes) {
73
+ return 'form.error.datetime.invalid_day_year_hours';
74
+ }
75
+ if (!hasDay && hasMonth && !hasYear && hasHours && hasMinutes) {
28
76
  return 'form.error.datetime.invalid_day_year';
29
77
  }
30
- if (!day && !month && year) {
78
+ if (!hasDay && !hasMonth && hasYear && hasHours && !hasMinutes) {
79
+ return 'form.error.datetime.invalid_day_month_minutes';
80
+ }
81
+ if (!hasDay && !hasMonth && hasYear && !hasHours && hasMinutes) {
82
+ return 'form.error.datetime.invalid_day_month_hours';
83
+ }
84
+ if (!hasDay && !hasMonth && hasYear && hasHours && hasMinutes) {
31
85
  return 'form.error.datetime.invalid_day_month';
32
86
  }
33
- if (day && month && !year) {
87
+ if (!hasDay && !hasMonth && !hasYear && hasHours && hasMinutes) {
88
+ return 'form.error.datetime.invalid_day_month_year';
89
+ }
90
+ if (!hasDay && !hasMonth && !hasYear && !hasHours && hasMinutes) {
91
+ return 'form.error.datetime.invalid_day_month_year_hours';
92
+ }
93
+ if (hasDay && hasMonth && !hasYear && hasHours && !hasMinutes) {
94
+ return 'form.error.datetime.invalid_year_minutes';
95
+ }
96
+ if (hasDay && hasMonth && !hasYear && !hasHours && hasMinutes) {
97
+ return 'form.error.datetime.invalid_year_hours';
98
+ }
99
+ if (hasDay && hasMonth && !hasYear && hasHours && hasMinutes) {
34
100
  return 'form.error.datetime.invalid_year';
35
101
  }
36
- if (day && !month && year) {
102
+ if (hasDay && !hasMonth && hasYear && hasHours && !hasMinutes) {
103
+ return 'form.error.datetime.invalid_month_minutes';
104
+ }
105
+ if (hasDay && !hasMonth && hasYear && !hasHours && hasMinutes) {
106
+ return 'form.error.datetime.invalid_month_hours';
107
+ }
108
+ if (hasDay && !hasMonth && hasYear && hasHours && hasMinutes) {
37
109
  return 'form.error.datetime.invalid_month';
38
110
  }
39
- if (!day && month && year) {
111
+ if (!hasDay && hasMonth && hasYear && hasHours && !hasMinutes) {
112
+ return 'form.error.datetime.invalid_day_minutes';
113
+ }
114
+ if (!hasDay && hasMonth && hasYear && !hasHours && hasMinutes) {
115
+ return 'form.error.datetime.invalid_day_hours';
116
+ }
117
+ if (!hasDay && hasMonth && hasYear && hasHours && hasMinutes) {
40
118
  return 'form.error.datetime.invalid_day';
41
119
  }
42
- // If date is complete, check time part
43
- if (day && month && year) {
44
- if (hours && !minutes) {
45
- return 'form.error.datetime.invalid_minutes';
120
+ if (!hasDay && !hasMonth && !hasYear && hasHours && !hasMinutes) {
121
+ return 'form.error.datetime.invalid_day_month_year_minutes';
122
+ }
123
+ if (hasDay && hasMonth && hasYear && !hasHours && !hasMinutes) {
124
+ return 'form.error.datetime.invalid_hours_minutes';
125
+ }
126
+ if (day && month) {
127
+ const dayNum = parseInt(day);
128
+ const monthNum = parseInt(month);
129
+ const validYear = onlyNumbersRegex.test(year) ? year : undefined;
130
+ if (!validYear || year.length < 4) {
131
+ return 'form.error.datetime.invalid';
46
132
  }
47
- if (!hours && minutes) {
48
- return 'form.error.datetime.invalid_hours';
133
+ const yearNum = parseInt(validYear);
134
+ const maxDay = getDaysInMonth(monthNum, yearNum);
135
+ if (dayNum < 1 || dayNum > maxDay) {
136
+ return {
137
+ key: 'form.error.datetime.invalid_day_range',
138
+ context: {
139
+ maxDay: maxDay,
140
+ },
141
+ };
49
142
  }
50
- if (!hours && !minutes) {
51
- return 'form.error.datetime.invalid';
143
+ if (monthNum < 1 || monthNum > 12) {
144
+ return 'form.error.datetime.invalid_month_range';
145
+ }
146
+ }
147
+ if (hours && minutes) {
148
+ const hoursNum = parseInt(hours);
149
+ const minutesNum = parseInt(minutes);
150
+ if (hoursNum < 0 || hoursNum > 23) {
151
+ return 'form.error.datetime.invalid_hours_range';
52
152
  }
53
- if (hours && minutes) {
54
- const hoursNum = parseInt(hours);
55
- const minutesNum = parseInt(minutes);
56
- if (hoursNum < 0 || hoursNum > 23) {
57
- return 'form.error.datetime.invalid_hours_range';
58
- }
59
- if (minutesNum < 0 || minutesNum > 59) {
60
- return 'form.error.datetime.invalid_minutes_range';
61
- }
153
+ if (minutesNum < 0 || minutesNum > 59) {
154
+ return 'form.error.datetime.invalid_minutes_range';
62
155
  }
63
156
  }
64
-
65
157
  return 'form.error.datetime.invalid';
66
158
  };
67
159
 
@@ -119,7 +211,7 @@ export const EARLIER_THAN_DATETIME_VALIDATOR = (
119
211
 
120
212
  export const DATETIME_VALIDATOR = {
121
213
  name: 'datetime-validator',
122
- message: (v): string => {
214
+ message: (v): string | object => {
123
215
  return checkPartialDateTime(v.value);
124
216
  },
125
217
  test: function (value: string) {
@@ -3,25 +3,39 @@ import { ValidatorSchema } from '@digigov/form/validators/types';
3
3
 
4
4
  const DEFAULT_FILE_MAX_SIZE = 10000000;
5
5
 
6
- export const FILE_MAX_SIZE_VALIDATOR = (field: FieldSpec): ValidatorSchema => ({
7
- name: 'file-max-size-validator',
8
- message: {
9
- key:
10
- field.type === 'file' ? 'form.error.file_size' : 'form.error.image_size',
11
- context: {
12
- maxSizeToMb:
13
- (field?.extra?.limit?.maxSize || DEFAULT_FILE_MAX_SIZE) / 1000000,
6
+ export const FILE_MAX_SIZE_VALIDATOR = (field: FieldSpec): ValidatorSchema => {
7
+ const maxSizeInBytes = field?.extra?.limit?.maxSize || DEFAULT_FILE_MAX_SIZE;
8
+ let maxSizeTransformed = maxSizeInBytes / (1024 * 1024); // In MB
9
+ let maxSizeText = 'MB';
10
+ if (Math.round(maxSizeTransformed) === 0) {
11
+ maxSizeTransformed = Math.round(maxSizeInBytes / 1024);
12
+ maxSizeText = 'KB';
13
+ }
14
+ if (Math.round(maxSizeTransformed) === 0) {
15
+ maxSizeTransformed = maxSizeInBytes;
16
+ maxSizeText = 'Bytes';
17
+ }
18
+ return {
19
+ name: 'file-max-size-validator',
20
+ message: {
21
+ key:
22
+ field.type === 'file'
23
+ ? 'form.error.file_size'
24
+ : 'form.error.image_size',
25
+ context: {
26
+ maxSize: `${maxSizeTransformed} ${maxSizeText}`,
27
+ },
14
28
  },
15
- },
16
- test: (value: File[]): boolean => {
17
- if (value) {
18
- for (const file of value) {
19
- const maxSize = field?.extra?.limit?.maxSize || DEFAULT_FILE_MAX_SIZE;
20
- if (file.size > maxSize) {
21
- return false;
29
+ test: (value: File[]): boolean => {
30
+ if (value) {
31
+ for (const file of Array.from(value)) {
32
+ const maxSize = field?.extra?.limit?.maxSize || DEFAULT_FILE_MAX_SIZE;
33
+ if (file.size > maxSize) {
34
+ return false;
35
+ }
22
36
  }
23
37
  }
24
- }
25
- return true;
26
- },
27
- });
38
+ return true;
39
+ },
40
+ };
41
+ };
@@ -3,6 +3,7 @@ import { FieldSpec } from '@digigov/form/types';
3
3
  import { ValidatorSchema } from '@digigov/form/validators/types';
4
4
 
5
5
  export * from '@digigov/form/validators/utils/afm';
6
+ export * from '@digigov/form/validators/utils/amka';
6
7
  export * from '@digigov/form/validators/utils/file';
7
8
  export * from '@digigov/form/validators/utils/iban';
8
9
  export * from '@digigov/form/validators/utils/otp';
@@ -98,7 +99,9 @@ export function getYupObjectShape(
98
99
 
99
100
  return yup.lazy(function () {
100
101
  const fieldSchemas = computeShape(
101
- Object.values(fields.current),
102
+ Object.values(fields.current).filter(
103
+ (f: FieldSpec) => !f.key.includes('.')
104
+ ) as FieldSpec[],
102
105
  yupTypeMap,
103
106
  validatorRegistry
104
107
  );
package/types.d.ts CHANGED
@@ -1,4 +1,4 @@
1
- import { UseFormReturn, UseFormProps } from 'react-hook-form';
1
+ import { UseFormReturn, UseFormProps, ErrorOption } from 'react-hook-form';
2
2
  import { FieldComponentRegistry, FieldLabelProps, FieldSpec, FormData } from '@digigov/form/Field/types';
3
3
  import { ValidatorSchema } from '@digigov/form/validators/types';
4
4
  export * from '@digigov/form/Field/types';
@@ -46,6 +46,7 @@ export interface FormBuilderProps {
46
46
  componentRegistry?: FieldComponentRegistry;
47
47
  grid?: boolean;
48
48
  controlledFieldsOnly?: boolean;
49
+ errors?: ErrorOption;
49
50
  }
50
51
  export interface FormBaseProps extends Omit<FormBuilderProps, 'fields' | 'fieldsets' | 'auto'> {
51
52
  fieldsetsMap?: Record<string, FieldsetSpec>;
package/types.js.map CHANGED
@@ -1,7 +1,7 @@
1
1
  {
2
2
  "version": 3,
3
3
  "sources": ["../src/types.tsx"],
4
- "sourcesContent": ["import { UseFormReturn, UseFormProps } from 'react-hook-form';\nimport {\n FieldComponentRegistry,\n FieldLabelProps,\n FieldSpec,\n FormData,\n} from '@digigov/form/Field/types';\nimport { ValidatorSchema } from '@digigov/form/validators/types';\nexport * from '@digigov/form/Field/types';\nexport interface FieldError {\n message: string;\n}\n\nexport interface FieldsetSpec {\n key: string;\n fields: string[];\n label?: FieldLabelProps;\n body?: React.ReactNode;\n}\n\nexport interface FormContextProps {\n fieldsetsMap?: Record<string, FieldsetSpec>;\n fieldsMap: Record<string, FieldSpec>;\n control: UseFormReturn['control'];\n register: UseFormReturn['register'];\n trigger: UseFormReturn['trigger'];\n clearErrors: UseFormReturn['clearErrors'];\n watch: UseFormReturn['watch'];\n getFieldState: UseFormReturn['getFieldState'];\n setValue: UseFormReturn['setValue'];\n getValues: UseFormReturn['getValues'];\n unregister: UseFormReturn['unregister'];\n formState: UseFormReturn['formState'];\n reset: UseFormReturn['reset'];\n resetField: UseFormReturn['resetField'];\n registerField: (field: FieldSpec) => void;\n errors: UseFormReturn['formState']['errors'];\n componentRegistry?: FieldComponentRegistry;\n submit: () => Promise<void>;\n}\n\nexport interface FormBuilderProps {\n fields?: FieldSpec[];\n fieldsets?: FieldsetSpec[];\n initial?: FormData;\n onSubmit?: (data: FormData) => void | null | FieldError[];\n mode?: UseFormProps['mode'];\n reValidateMode?: UseFormProps['reValidateMode'];\n criteriaMode?: UseFormProps['criteriaMode'];\n children?: React.ReactNode;\n shouldFocusError?: boolean;\n auto?: boolean;\n validatorRegistry?: Record<string, ValidatorSchema[]>;\n componentRegistry?: FieldComponentRegistry;\n grid?: boolean;\n controlledFieldsOnly?: boolean;\n}\n\nexport interface FormBaseProps\n extends Omit<FormBuilderProps, 'fields' | 'fieldsets' | 'auto'> {\n fieldsetsMap?: Record<string, FieldsetSpec>;\n fieldsMap: Record<string, FieldSpec>;\n registerField: (field: FieldSpec) => void;\n resolver: any;\n}\n"],
4
+ "sourcesContent": ["import { UseFormReturn, UseFormProps, ErrorOption } from 'react-hook-form';\nimport {\n FieldComponentRegistry,\n FieldLabelProps,\n FieldSpec,\n FormData,\n} from '@digigov/form/Field/types';\nimport { ValidatorSchema } from '@digigov/form/validators/types';\nexport * from '@digigov/form/Field/types';\nexport interface FieldError {\n message: string;\n}\n\nexport interface FieldsetSpec {\n key: string;\n fields: string[];\n label?: FieldLabelProps;\n body?: React.ReactNode;\n}\n\nexport interface FormContextProps {\n fieldsetsMap?: Record<string, FieldsetSpec>;\n fieldsMap: Record<string, FieldSpec>;\n control: UseFormReturn['control'];\n register: UseFormReturn['register'];\n trigger: UseFormReturn['trigger'];\n clearErrors: UseFormReturn['clearErrors'];\n watch: UseFormReturn['watch'];\n getFieldState: UseFormReturn['getFieldState'];\n setValue: UseFormReturn['setValue'];\n getValues: UseFormReturn['getValues'];\n unregister: UseFormReturn['unregister'];\n formState: UseFormReturn['formState'];\n reset: UseFormReturn['reset'];\n resetField: UseFormReturn['resetField'];\n registerField: (field: FieldSpec) => void;\n errors: UseFormReturn['formState']['errors'];\n componentRegistry?: FieldComponentRegistry;\n submit: () => Promise<void>;\n}\n\nexport interface FormBuilderProps {\n fields?: FieldSpec[];\n fieldsets?: FieldsetSpec[];\n initial?: FormData;\n onSubmit?: (data: FormData) => void | null | FieldError[];\n mode?: UseFormProps['mode'];\n reValidateMode?: UseFormProps['reValidateMode'];\n criteriaMode?: UseFormProps['criteriaMode'];\n children?: React.ReactNode;\n shouldFocusError?: boolean;\n auto?: boolean;\n validatorRegistry?: Record<string, ValidatorSchema[]>;\n componentRegistry?: FieldComponentRegistry;\n grid?: boolean;\n controlledFieldsOnly?: boolean;\n errors?: ErrorOption;\n}\n\nexport interface FormBaseProps\n extends Omit<FormBuilderProps, 'fields' | 'fieldsets' | 'auto'> {\n fieldsetsMap?: Record<string, FieldsetSpec>;\n fieldsMap: Record<string, FieldSpec>;\n registerField: (field: FieldSpec) => void;\n resolver: any;\n}\n"],
5
5
  "mappings": "AAQA,cAAc;",
6
6
  "names": []
7
7
  }