@digigov/form 2.0.0-daaf7bdf → 2.0.0-eaf330f5

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 (603) hide show
  1. package/Field/ErrorGroup/index.js +48 -0
  2. package/{Form.stories → Field/ErrorGroup}/package.json +1 -1
  3. package/Field/ErrorGroup.d.ts +15 -0
  4. package/Field/ErrorGroup.js.map +7 -0
  5. package/Field/FieldBase/index.js +38 -25
  6. package/Field/FieldBase.js.map +2 -2
  7. package/Field/FieldBaseContainer/index.js +6 -4
  8. package/Field/FieldBaseContainer.js.map +2 -2
  9. package/Field/FieldConditional/index.js +4 -0
  10. package/Field/FieldConditional.js.map +2 -2
  11. package/Field/index.js +14 -4
  12. package/Field/index.js.map +2 -2
  13. package/Field/types.d.ts +21 -10
  14. package/Field/utils/index.js +8 -1
  15. package/Field/utils/index.js.map +2 -2
  16. package/Field/utils/useField/index.js +14 -1
  17. package/Field/utils/useField.js.map +2 -2
  18. package/FieldArray/FieldArray.stories.d.ts +1 -0
  19. package/FieldArray/FormDialog/index.js +402 -0
  20. package/{Questions/Questions.stories → FieldArray/FormDialog}/package.json +1 -1
  21. package/FieldArray/FormDialog.d.ts +67 -0
  22. package/FieldArray/FormDialog.js.map +7 -0
  23. package/FieldArray/__stories__/WithModal.d.ts +2 -0
  24. package/FieldArray/index.d.ts +6 -0
  25. package/FieldArray/index.js +99 -48
  26. package/FieldArray/index.js.map +3 -3
  27. package/FieldObject/index.d.ts +5 -0
  28. package/FieldObject/index.js +32 -17
  29. package/FieldObject/index.js.map +2 -2
  30. package/Fieldset/index.d.ts +1 -1
  31. package/Fieldset/index.js +5 -5
  32. package/Fieldset/index.js.map +2 -2
  33. package/Fieldset/types.d.ts +2 -2
  34. package/FormBuilder/FormBuilder.stories.d.ts +2 -0
  35. package/FormBuilder/__stories__/AutoErrorGrouping.d.ts +3 -0
  36. package/FormBuilder/__stories__/ErrorGrouping.d.ts +3 -0
  37. package/FormBuilder/index.js +95 -8
  38. package/FormBuilder/index.js.map +2 -2
  39. package/FormBuilder/interaction.test.d.ts +1 -0
  40. package/FormContext.js.map +2 -2
  41. package/MultiplicityField/add-objects/index.js +10 -6
  42. package/MultiplicityField/add-objects.js.map +2 -2
  43. package/MultiplicityField/index.js +14 -10
  44. package/MultiplicityField/index.js.map +2 -2
  45. package/MultiplicityField/types.d.ts +1 -2
  46. package/Questions/Questions/index.js +5 -4
  47. package/Questions/Questions.js.map +2 -2
  48. package/Questions/Step/StepArrayReview.js.map +2 -2
  49. package/Questions/Step/StepTitle/index.js +4 -3
  50. package/Questions/Step/StepTitle.d.ts +1 -1
  51. package/Questions/Step/StepTitle.js.map +2 -2
  52. package/cjs/Field/ErrorGroup/index.js +82 -0
  53. package/cjs/Field/ErrorGroup.js.map +7 -0
  54. package/cjs/Field/FieldBase/index.js +37 -24
  55. package/cjs/Field/FieldBase.js.map +2 -2
  56. package/cjs/Field/FieldBaseContainer/index.js +6 -4
  57. package/cjs/Field/FieldBaseContainer.js.map +3 -3
  58. package/cjs/Field/FieldConditional/index.js +4 -0
  59. package/cjs/Field/FieldConditional.js.map +2 -2
  60. package/cjs/Field/index.js +14 -4
  61. package/cjs/Field/index.js.map +2 -2
  62. package/cjs/Field/types.js.map +1 -1
  63. package/cjs/Field/utils/index.js +8 -1
  64. package/cjs/Field/utils/index.js.map +3 -3
  65. package/cjs/Field/utils/useField/index.js +14 -1
  66. package/cjs/Field/utils/useField.js.map +2 -2
  67. package/cjs/FieldArray/FormDialog/index.js +421 -0
  68. package/cjs/FieldArray/FormDialog.js.map +7 -0
  69. package/cjs/FieldArray/index.js +94 -46
  70. package/cjs/FieldArray/index.js.map +3 -3
  71. package/cjs/FieldObject/index.js +32 -17
  72. package/cjs/FieldObject/index.js.map +3 -3
  73. package/cjs/Fieldset/index.js +10 -10
  74. package/cjs/Fieldset/index.js.map +3 -3
  75. package/cjs/Fieldset/types.js.map +1 -1
  76. package/cjs/FormBuilder/index.js +94 -7
  77. package/cjs/FormBuilder/index.js.map +3 -3
  78. package/cjs/FormContext/index.js +2 -2
  79. package/cjs/FormContext.js.map +3 -3
  80. package/cjs/MultiplicityField/add-objects/index.js +14 -10
  81. package/cjs/MultiplicityField/add-objects.js.map +3 -3
  82. package/cjs/MultiplicityField/index.js +13 -14
  83. package/cjs/MultiplicityField/index.js.map +3 -3
  84. package/cjs/MultiplicityField/types.js.map +1 -1
  85. package/cjs/Questions/Questions/index.js +5 -4
  86. package/cjs/Questions/Questions.js.map +2 -2
  87. package/cjs/Questions/Step/StepArrayReview.js.map +2 -2
  88. package/cjs/Questions/Step/StepTitle/index.js +5 -5
  89. package/cjs/Questions/Step/StepTitle.js.map +3 -3
  90. package/cjs/inputs/AutoCompleteInput/index.js +8 -7
  91. package/cjs/inputs/AutoCompleteInput/index.js.map +3 -3
  92. package/cjs/inputs/Checkboxes/index.js +8 -9
  93. package/cjs/inputs/Checkboxes/index.js.map +3 -3
  94. package/cjs/inputs/DateInput/index.js +30 -16
  95. package/cjs/inputs/DateInput/index.js.map +3 -3
  96. package/cjs/inputs/DateTimeInput/index.js +224 -0
  97. package/cjs/inputs/DateTimeInput/index.js.map +7 -0
  98. package/cjs/inputs/FileInput/index.js +54 -36
  99. package/cjs/inputs/FileInput/index.js.map +3 -3
  100. package/cjs/inputs/ImageInput/index.js +15 -10
  101. package/cjs/inputs/ImageInput/index.js.map +3 -3
  102. package/cjs/inputs/Input/index.js +12 -4
  103. package/cjs/inputs/Input/index.js.map +2 -2
  104. package/cjs/inputs/Input/inputsInputScenarios.js.map +2 -2
  105. package/cjs/inputs/Label/index.js +3 -3
  106. package/cjs/inputs/Label/index.js.map +3 -3
  107. package/cjs/inputs/OtpInput/index.js +1 -0
  108. package/cjs/inputs/OtpInput/index.js.map +2 -2
  109. package/cjs/inputs/Radio/index.js +12 -13
  110. package/cjs/inputs/Radio/index.js.map +3 -3
  111. package/cjs/inputs/Select/index.js +11 -5
  112. package/cjs/inputs/Select/index.js.map +3 -3
  113. package/cjs/inputs/inputsScenarios/index.js +6 -12
  114. package/cjs/inputs/inputsScenarios.js.map +2 -2
  115. package/cjs/lazy/index.js +50 -36
  116. package/cjs/lazy.js.map +3 -3
  117. package/cjs/locales/el.js.map +1 -1
  118. package/cjs/registry/index.js +76 -64
  119. package/cjs/registry.js.map +3 -3
  120. package/cjs/types.js.map +1 -1
  121. package/cjs/utils/index.js +22 -7
  122. package/cjs/utils.js.map +2 -2
  123. package/cjs/validators/index.js +61 -89
  124. package/cjs/validators/index.js.map +3 -3
  125. package/cjs/validators/utils/amka/index.js +60 -0
  126. package/cjs/validators/utils/amka.js.map +7 -0
  127. package/cjs/validators/utils/date/index.js +138 -0
  128. package/cjs/validators/utils/date.js.map +7 -0
  129. package/cjs/validators/utils/datetime/index.js +151 -0
  130. package/cjs/validators/utils/datetime.js.map +7 -0
  131. package/cjs/validators/utils/file/index.js +30 -17
  132. package/cjs/validators/utils/file.js.map +2 -2
  133. package/cjs/validators/utils/index.js +10 -2
  134. package/cjs/validators/utils/index.js.map +2 -2
  135. package/cjs/validators/utils/int/index.js +1 -1
  136. package/cjs/validators/utils/int.js.map +2 -2
  137. package/cjs/validators/utils/number/index.js +1 -1
  138. package/cjs/validators/utils/number.js.map +2 -2
  139. package/cjs/validators/utils/phone.js.map +2 -2
  140. package/cjs/validators/utils/postal_code.js.map +1 -1
  141. package/cjs/validators/utils/uuid4.js.map +2 -2
  142. package/index.js +1 -1
  143. package/inputs/AutoCompleteInput/index.d.ts +1 -1
  144. package/inputs/AutoCompleteInput/index.js +10 -7
  145. package/inputs/AutoCompleteInput/index.js.map +2 -2
  146. package/inputs/Checkboxes/index.d.ts +1 -1
  147. package/inputs/Checkboxes/index.js +9 -6
  148. package/inputs/Checkboxes/index.js.map +2 -2
  149. package/inputs/DateInput/index.d.ts +1 -2
  150. package/inputs/DateInput/index.js +32 -15
  151. package/inputs/DateInput/index.js.map +2 -2
  152. package/inputs/DateTimeInput/DateTimeInput.stories.d.ts +7 -0
  153. package/inputs/DateTimeInput/__stories__/Default.d.ts +3 -0
  154. package/inputs/DateTimeInput/index.d.ts +13 -0
  155. package/inputs/DateTimeInput/index.js +194 -0
  156. package/inputs/DateTimeInput/index.js.map +7 -0
  157. package/inputs/DateTimeInput/index.test.d.ts +1 -0
  158. package/inputs/{Input/Input.stories → DateTimeInput}/package.json +1 -1
  159. package/inputs/FileInput/FileInput.stories.d.ts +1 -0
  160. package/inputs/FileInput/__stories__/WithBorderAndLink.d.ts +3 -0
  161. package/inputs/FileInput/index.d.ts +12 -0
  162. package/inputs/FileInput/index.js +58 -37
  163. package/inputs/FileInput/index.js.map +2 -2
  164. package/inputs/ImageInput/index.js +14 -9
  165. package/inputs/ImageInput/index.js.map +2 -2
  166. package/inputs/Input/Input.stories.d.ts +2 -0
  167. package/inputs/Input/__stories__/AMKA.d.ts +3 -0
  168. package/inputs/Input/__stories__/StringWithTrimValidation.d.ts +3 -0
  169. package/inputs/Input/index.d.ts +2 -1
  170. package/inputs/Input/index.js +12 -4
  171. package/inputs/Input/index.js.map +2 -2
  172. package/inputs/Input/inputsInputScenarios.js.map +2 -2
  173. package/inputs/Label/index.d.ts +0 -2
  174. package/inputs/Label/index.js +2 -2
  175. package/inputs/Label/index.js.map +2 -2
  176. package/inputs/OtpInput/index.js +1 -0
  177. package/inputs/OtpInput/index.js.map +2 -2
  178. package/inputs/Radio/index.d.ts +1 -1
  179. package/inputs/Radio/index.js +8 -5
  180. package/inputs/Radio/index.js.map +2 -2
  181. package/inputs/Select/index.d.ts +3 -2
  182. package/inputs/Select/index.js +13 -4
  183. package/inputs/Select/index.js.map +2 -2
  184. package/inputs/inputsScenarios/index.js +6 -12
  185. package/inputs/inputsScenarios.d.ts +1 -1
  186. package/inputs/inputsScenarios.js.map +2 -2
  187. package/lazy/index.js +77 -67
  188. package/locales/el.js.map +1 -1
  189. package/package.json +5 -5
  190. package/registry/index.js +119 -108
  191. package/src/Field/ErrorGroup.tsx +84 -0
  192. package/src/Field/FieldBase.tsx +55 -36
  193. package/src/Field/FieldBaseContainer.tsx +13 -7
  194. package/src/Field/FieldConditional.tsx +6 -2
  195. package/src/Field/doc.mdx +207 -0
  196. package/src/Field/index.tsx +19 -5
  197. package/src/Field/types.tsx +42 -29
  198. package/src/Field/utils/index.ts +7 -0
  199. package/src/Field/utils/useField.ts +14 -2
  200. package/src/FieldArray/FieldArray.stories.js +1 -0
  201. package/src/FieldArray/FormDialog.tsx +574 -0
  202. package/src/FieldArray/__stories__/Default.tsx +1 -0
  203. package/src/FieldArray/__stories__/WithExactLength.tsx +1 -0
  204. package/src/FieldArray/__stories__/WithModal.tsx +160 -0
  205. package/src/FieldArray/index.test.tsx +8 -0
  206. package/src/FieldArray/index.tsx +119 -62
  207. package/src/FieldObject/index.tsx +41 -20
  208. package/src/Fieldset/index.tsx +5 -5
  209. package/src/Fieldset/types.tsx +2 -2
  210. package/src/FormBuilder/FormBuilder.stories.js +2 -0
  211. package/src/FormBuilder/__stories__/AutoErrorGrouping.tsx +63 -0
  212. package/src/FormBuilder/__stories__/ErrorGrouping.tsx +43 -0
  213. package/src/FormBuilder/{FormBuilder.mdx → doc.mdx} +27 -35
  214. package/src/FormBuilder/index.test.tsx +12 -0
  215. package/src/FormBuilder/index.tsx +105 -11
  216. package/src/FormBuilder/interaction.test.tsx +40 -0
  217. package/src/FormBuilder/scenarios.test.tsx +124 -10
  218. package/src/FormContext.tsx +1 -2
  219. package/src/MultiplicityField/add-objects.tsx +11 -9
  220. package/src/MultiplicityField/{MultiplicityField.mdx → doc.mdx} +112 -98
  221. package/src/MultiplicityField/index.test.tsx +4 -0
  222. package/src/MultiplicityField/index.tsx +15 -12
  223. package/src/MultiplicityField/types.ts +1 -2
  224. package/src/Questions/Questions.tsx +4 -4
  225. package/src/Questions/Step/StepArrayReview.tsx +1 -1
  226. package/src/Questions/Step/StepTitle.tsx +4 -3
  227. package/src/Questions/__snapshots__/index.spec.tsx.snap +11 -5
  228. package/src/Questions/{index.mdx → doc.mdx} +30 -53
  229. package/src/Questions/index.spec.tsx +14 -2
  230. package/src/Questions/index.test.tsx +4 -0
  231. package/src/create-simple-form.mdx +2 -6
  232. package/src/{index.mdx → doc.mdx} +29 -18
  233. package/src/inputs/AutoCompleteInput/__stories__/Default.tsx +2 -10
  234. package/src/inputs/AutoCompleteInput/__stories__/Multiple.tsx +1 -7
  235. package/src/inputs/AutoCompleteInput/{index.mdx → doc.mdx} +2 -13
  236. package/src/inputs/AutoCompleteInput/index.test.tsx +4 -0
  237. package/src/inputs/AutoCompleteInput/index.tsx +32 -28
  238. package/src/inputs/Checkboxes/{index.mdx → doc.mdx} +5 -15
  239. package/src/inputs/Checkboxes/index.test.tsx +4 -0
  240. package/src/inputs/Checkboxes/index.tsx +29 -28
  241. package/src/inputs/DateInput/__stories__/Default.tsx +7 -12
  242. package/src/inputs/DateInput/{index.mdx → doc.mdx} +1 -8
  243. package/src/inputs/DateInput/index.test.tsx +4 -0
  244. package/src/inputs/DateInput/index.tsx +33 -14
  245. package/src/inputs/DateTimeInput/DateTimeInput.stories.js +8 -0
  246. package/src/inputs/DateTimeInput/__stories__/Default.tsx +25 -0
  247. package/src/inputs/DateTimeInput/doc.mdx +16 -0
  248. package/src/inputs/DateTimeInput/index.test.tsx +24 -0
  249. package/src/inputs/DateTimeInput/index.tsx +209 -0
  250. package/src/inputs/FileInput/FileInput.stories.js +1 -0
  251. package/src/inputs/FileInput/__stories__/WithBorderAndLink.tsx +34 -0
  252. package/src/inputs/FileInput/{index.mdx → doc.mdx} +1 -5
  253. package/src/inputs/FileInput/index.test.tsx +8 -0
  254. package/src/inputs/FileInput/index.tsx +58 -26
  255. package/src/inputs/ImageInput/ImageInput.stories.js +0 -1
  256. package/src/inputs/ImageInput/__stories__/MaxSize.tsx +2 -2
  257. package/src/inputs/ImageInput/__stories__/WithInvalidImageDimension.tsx +2 -0
  258. package/src/inputs/ImageInput/doc.mdx +23 -0
  259. package/src/inputs/ImageInput/index.test.tsx +4 -4
  260. package/src/inputs/ImageInput/index.tsx +17 -16
  261. package/src/inputs/Input/Input.stories.js +2 -0
  262. package/src/inputs/Input/__stories__/AMKA.tsx +23 -0
  263. package/src/inputs/Input/__stories__/LandlineNumber.tsx +2 -1
  264. package/src/inputs/Input/__stories__/MobilePhone.tsx +1 -0
  265. package/src/inputs/Input/__stories__/PhoneNumber.tsx +1 -0
  266. package/src/inputs/Input/__stories__/PostalCode.tsx +1 -0
  267. package/src/inputs/Input/__stories__/StringWithTrimValidation.tsx +26 -0
  268. package/src/inputs/Input/__stories__/TextWithLimit.tsx +1 -0
  269. package/src/inputs/Input/doc.mdx +56 -0
  270. package/src/inputs/Input/index.test.tsx +8 -0
  271. package/src/inputs/Input/index.tsx +30 -12
  272. package/src/inputs/Input/inputsInputScenarios.ts +244 -245
  273. package/src/inputs/Label/doc.mdx +14 -0
  274. package/src/inputs/Label/index.test.tsx +4 -0
  275. package/src/inputs/Label/index.tsx +2 -6
  276. package/src/inputs/OtpInput/{index.mdx → doc.mdx} +1 -8
  277. package/src/inputs/OtpInput/index.test.tsx +4 -0
  278. package/src/inputs/OtpInput/index.tsx +3 -1
  279. package/src/inputs/Radio/{index.mdx → doc.mdx} +5 -15
  280. package/src/inputs/Radio/index.test.tsx +4 -0
  281. package/src/inputs/Radio/index.tsx +59 -56
  282. package/src/inputs/Select/{index.mdx → doc.mdx} +1 -5
  283. package/src/inputs/Select/index.test.tsx +4 -0
  284. package/src/inputs/Select/index.tsx +18 -7
  285. package/src/inputs/inputsScenarios.ts +36 -42
  286. package/src/installation.mdx +2 -5
  287. package/src/lazy.js +77 -64
  288. package/src/locales/el.ts +1 -1
  289. package/src/registry.js +111 -101
  290. package/src/types.tsx +4 -3
  291. package/src/utils.ts +29 -8
  292. package/src/validators/index.ts +110 -98
  293. package/src/validators/utils/amka.ts +39 -0
  294. package/src/validators/utils/date.ts +107 -0
  295. package/src/validators/utils/datetime.ts +130 -0
  296. package/src/validators/utils/file.ts +33 -17
  297. package/src/validators/utils/index.ts +6 -1
  298. package/src/validators/utils/int.ts +1 -1
  299. package/src/validators/utils/number.ts +1 -1
  300. package/src/validators/utils/phone.ts +1 -1
  301. package/src/validators/utils/postal_code.ts +1 -1
  302. package/src/validators/utils/uuid4.ts +2 -1
  303. package/src/validators/validators.spec.ts +3 -3
  304. package/types.d.ts +4 -3
  305. package/types.js.map +1 -1
  306. package/utils/index.js +22 -7
  307. package/utils.d.ts +2 -0
  308. package/utils.js.map +2 -2
  309. package/validators/index.d.ts +1 -1
  310. package/validators/index.js +69 -90
  311. package/validators/index.js.map +2 -2
  312. package/validators/utils/amka/index.js +36 -0
  313. package/{FieldArray/FieldArray.stories → validators/utils/amka}/package.json +1 -1
  314. package/validators/utils/amka.d.ts +6 -0
  315. package/validators/utils/amka.js.map +7 -0
  316. package/validators/utils/date/index.js +103 -0
  317. package/validators/utils/date/package.json +6 -0
  318. package/validators/utils/date.d.ts +9 -0
  319. package/validators/utils/date.js.map +7 -0
  320. package/validators/utils/datetime/index.js +116 -0
  321. package/validators/utils/datetime/package.json +6 -0
  322. package/validators/utils/datetime.d.ts +9 -0
  323. package/validators/utils/datetime.js.map +7 -0
  324. package/validators/utils/file/index.js +30 -17
  325. package/validators/utils/file.js.map +2 -2
  326. package/validators/utils/index.d.ts +3 -0
  327. package/validators/utils/index.js +6 -1
  328. package/validators/utils/index.js.map +2 -2
  329. package/validators/utils/int/index.js +1 -1
  330. package/validators/utils/int.js.map +2 -2
  331. package/validators/utils/number/index.js +1 -1
  332. package/validators/utils/number.js.map +2 -2
  333. package/validators/utils/phone.d.ts +1 -1
  334. package/validators/utils/phone.js.map +2 -2
  335. package/validators/utils/postal_code.d.ts +1 -1
  336. package/validators/utils/postal_code.js.map +1 -1
  337. package/validators/utils/uuid4.js.map +2 -2
  338. package/FieldArray/FieldArray.stories/index.js +0 -14
  339. package/FieldArray/FieldArray.stories.js.map +0 -7
  340. package/FieldArray/__stories__/Default/index.js +0 -95
  341. package/FieldArray/__stories__/Default/package.json +0 -6
  342. package/FieldArray/__stories__/Default.js.map +0 -7
  343. package/FieldArray/__stories__/WithExactLength/index.js +0 -95
  344. package/FieldArray/__stories__/WithExactLength/package.json +0 -6
  345. package/FieldArray/__stories__/WithExactLength.js.map +0 -7
  346. package/Form.stories/index.js +0 -7
  347. package/Form.stories.js.map +0 -7
  348. package/FormBuilder/FormBuilder.stories/index.js +0 -12
  349. package/FormBuilder/FormBuilder.stories/package.json +0 -6
  350. package/FormBuilder/FormBuilder.stories.js.map +0 -7
  351. package/FormBuilder/__stories__/Default/index.js +0 -32
  352. package/FormBuilder/__stories__/Default/package.json +0 -6
  353. package/FormBuilder/__stories__/Default.js.map +0 -7
  354. package/MultiplicityField/MultiplicityField.stories/index.js +0 -22
  355. package/MultiplicityField/MultiplicityField.stories/package.json +0 -6
  356. package/MultiplicityField/MultiplicityField.stories.js.map +0 -7
  357. package/MultiplicityField/__stories__/Default/index.js +0 -100
  358. package/MultiplicityField/__stories__/Default/package.json +0 -6
  359. package/MultiplicityField/__stories__/Default.js.map +0 -7
  360. package/MultiplicityField/__stories__/PreviewDisplay/index.js +0 -70
  361. package/MultiplicityField/__stories__/PreviewDisplay/package.json +0 -6
  362. package/MultiplicityField/__stories__/PreviewDisplay.js.map +0 -7
  363. package/MultiplicityField/__stories__/WithExactLength/index.js +0 -97
  364. package/MultiplicityField/__stories__/WithExactLength/package.json +0 -6
  365. package/MultiplicityField/__stories__/WithExactLength.js.map +0 -7
  366. package/MultiplicityField/__stories__/WithMaxLength/index.js +0 -100
  367. package/MultiplicityField/__stories__/WithMaxLength/package.json +0 -6
  368. package/MultiplicityField/__stories__/WithMaxLength.js.map +0 -7
  369. package/MultiplicityField/__stories__/WithMinAndMaxLength/index.js +0 -101
  370. package/MultiplicityField/__stories__/WithMinAndMaxLength/package.json +0 -6
  371. package/MultiplicityField/__stories__/WithMinAndMaxLength.js.map +0 -7
  372. package/MultiplicityField/__stories__/WithMinLength/index.js +0 -100
  373. package/MultiplicityField/__stories__/WithMinLength/package.json +0 -6
  374. package/MultiplicityField/__stories__/WithMinLength.js.map +0 -7
  375. package/Questions/Questions.stories/index.js +0 -12
  376. package/Questions/Questions.stories.js.map +0 -7
  377. package/Questions/__stories__/Default/index.js +0 -108
  378. package/Questions/__stories__/Default/package.json +0 -6
  379. package/Questions/__stories__/Default.js.map +0 -7
  380. package/cjs/FieldArray/FieldArray.stories/index.js +0 -48
  381. package/cjs/FieldArray/FieldArray.stories.js.map +0 -7
  382. package/cjs/FieldArray/__stories__/Default/index.js +0 -128
  383. package/cjs/FieldArray/__stories__/Default.js.map +0 -7
  384. package/cjs/FieldArray/__stories__/WithExactLength/index.js +0 -128
  385. package/cjs/FieldArray/__stories__/WithExactLength.js.map +0 -7
  386. package/cjs/Form.stories/index.js +0 -26
  387. package/cjs/Form.stories.js.map +0 -7
  388. package/cjs/FormBuilder/FormBuilder.stories/index.js +0 -45
  389. package/cjs/FormBuilder/FormBuilder.stories.js.map +0 -7
  390. package/cjs/FormBuilder/__stories__/Default/index.js +0 -65
  391. package/cjs/FormBuilder/__stories__/Default.js.map +0 -7
  392. package/cjs/MultiplicityField/MultiplicityField.stories/index.js +0 -60
  393. package/cjs/MultiplicityField/MultiplicityField.stories.js.map +0 -7
  394. package/cjs/MultiplicityField/__stories__/Default/index.js +0 -133
  395. package/cjs/MultiplicityField/__stories__/Default.js.map +0 -7
  396. package/cjs/MultiplicityField/__stories__/PreviewDisplay/index.js +0 -86
  397. package/cjs/MultiplicityField/__stories__/PreviewDisplay.js.map +0 -7
  398. package/cjs/MultiplicityField/__stories__/WithExactLength/index.js +0 -130
  399. package/cjs/MultiplicityField/__stories__/WithExactLength.js.map +0 -7
  400. package/cjs/MultiplicityField/__stories__/WithMaxLength/index.js +0 -133
  401. package/cjs/MultiplicityField/__stories__/WithMaxLength.js.map +0 -7
  402. package/cjs/MultiplicityField/__stories__/WithMinAndMaxLength/index.js +0 -134
  403. package/cjs/MultiplicityField/__stories__/WithMinAndMaxLength.js.map +0 -7
  404. package/cjs/MultiplicityField/__stories__/WithMinLength/index.js +0 -133
  405. package/cjs/MultiplicityField/__stories__/WithMinLength.js.map +0 -7
  406. package/cjs/Questions/Questions.stories/index.js +0 -45
  407. package/cjs/Questions/Questions.stories.js.map +0 -7
  408. package/cjs/Questions/__stories__/Default/index.js +0 -136
  409. package/cjs/Questions/__stories__/Default.js.map +0 -7
  410. package/cjs/inputs/AutoCompleteInput/AutoComplete.stories/index.js +0 -48
  411. package/cjs/inputs/AutoCompleteInput/AutoComplete.stories.js.map +0 -7
  412. package/cjs/inputs/AutoCompleteInput/__stories__/Default/index.js +0 -83
  413. package/cjs/inputs/AutoCompleteInput/__stories__/Default.js.map +0 -7
  414. package/cjs/inputs/AutoCompleteInput/__stories__/Multiple/index.js +0 -83
  415. package/cjs/inputs/AutoCompleteInput/__stories__/Multiple.js.map +0 -7
  416. package/cjs/inputs/Checkboxes/Checkboxes.stories/index.js +0 -51
  417. package/cjs/inputs/Checkboxes/Checkboxes.stories.js.map +0 -7
  418. package/cjs/inputs/Checkboxes/__stories__/Conditional/index.js +0 -133
  419. package/cjs/inputs/Checkboxes/__stories__/Conditional.js.map +0 -7
  420. package/cjs/inputs/Checkboxes/__stories__/Default/index.js +0 -77
  421. package/cjs/inputs/Checkboxes/__stories__/Default.js.map +0 -7
  422. package/cjs/inputs/Checkboxes/__stories__/WithDivider/index.js +0 -78
  423. package/cjs/inputs/Checkboxes/__stories__/WithDivider.js.map +0 -7
  424. package/cjs/inputs/DateInput/DateInput.stories/index.js +0 -45
  425. package/cjs/inputs/DateInput/DateInput.stories.js.map +0 -7
  426. package/cjs/inputs/DateInput/__stories__/Default/index.js +0 -61
  427. package/cjs/inputs/DateInput/__stories__/Default.js.map +0 -7
  428. package/cjs/inputs/FileInput/FileInput.stories/index.js +0 -45
  429. package/cjs/inputs/FileInput/FileInput.stories.js.map +0 -7
  430. package/cjs/inputs/FileInput/__stories__/Default/index.js +0 -61
  431. package/cjs/inputs/FileInput/__stories__/Default.js.map +0 -7
  432. package/cjs/inputs/ImageInput/ImageInput.stories/index.js +0 -51
  433. package/cjs/inputs/ImageInput/ImageInput.stories.js.map +0 -7
  434. package/cjs/inputs/ImageInput/__stories__/Default/index.js +0 -63
  435. package/cjs/inputs/ImageInput/__stories__/Default.js.map +0 -7
  436. package/cjs/inputs/ImageInput/__stories__/MaxSize/index.js +0 -69
  437. package/cjs/inputs/ImageInput/__stories__/MaxSize.js.map +0 -7
  438. package/cjs/inputs/ImageInput/__stories__/WithInvalidImageDimension/index.js +0 -71
  439. package/cjs/inputs/ImageInput/__stories__/WithInvalidImageDimension.js.map +0 -7
  440. package/cjs/inputs/ImageInput/__stories__/WithInvalidImageSize/index.js +0 -68
  441. package/cjs/inputs/ImageInput/__stories__/WithInvalidImageSize.js.map +0 -7
  442. package/cjs/inputs/Input/Input.stories/index.js +0 -72
  443. package/cjs/inputs/Input/Input.stories.js.map +0 -7
  444. package/cjs/inputs/Input/__stories__/AFM/index.js +0 -63
  445. package/cjs/inputs/Input/__stories__/AFM.js.map +0 -7
  446. package/cjs/inputs/Input/__stories__/Boolean/index.js +0 -64
  447. package/cjs/inputs/Input/__stories__/Boolean.js.map +0 -7
  448. package/cjs/inputs/Input/__stories__/IBAN/index.js +0 -64
  449. package/cjs/inputs/Input/__stories__/IBAN.js.map +0 -7
  450. package/cjs/inputs/Input/__stories__/Integer/index.js +0 -78
  451. package/cjs/inputs/Input/__stories__/Integer.js.map +0 -7
  452. package/cjs/inputs/Input/__stories__/LandlineNumber/index.js +0 -67
  453. package/cjs/inputs/Input/__stories__/LandlineNumber.js.map +0 -7
  454. package/cjs/inputs/Input/__stories__/MobilePhone/index.js +0 -67
  455. package/cjs/inputs/Input/__stories__/MobilePhone.js.map +0 -7
  456. package/cjs/inputs/Input/__stories__/PhoneNumber/index.js +0 -66
  457. package/cjs/inputs/Input/__stories__/PhoneNumber.js.map +0 -7
  458. package/cjs/inputs/Input/__stories__/PostalCode/index.js +0 -64
  459. package/cjs/inputs/Input/__stories__/PostalCode.js.map +0 -7
  460. package/cjs/inputs/Input/__stories__/String/index.js +0 -64
  461. package/cjs/inputs/Input/__stories__/String.js.map +0 -7
  462. package/cjs/inputs/Input/__stories__/TextWithLimit/index.js +0 -64
  463. package/cjs/inputs/Input/__stories__/TextWithLimit.js.map +0 -7
  464. package/cjs/inputs/Label/Label.stories/index.js +0 -45
  465. package/cjs/inputs/Label/Label.stories.js.map +0 -7
  466. package/cjs/inputs/Label/__stories__/Default/index.js +0 -72
  467. package/cjs/inputs/Label/__stories__/Default.js.map +0 -7
  468. package/cjs/inputs/OtpInput/OtpInput.stories/index.js +0 -45
  469. package/cjs/inputs/OtpInput/OtpInput.stories.js.map +0 -7
  470. package/cjs/inputs/OtpInput/__stories__/Default/index.js +0 -64
  471. package/cjs/inputs/OtpInput/__stories__/Default.js.map +0 -7
  472. package/cjs/inputs/Radio/Radio.stories/index.js +0 -51
  473. package/cjs/inputs/Radio/Radio.stories.js.map +0 -7
  474. package/cjs/inputs/Radio/__stories__/Conditional/index.js +0 -133
  475. package/cjs/inputs/Radio/__stories__/Conditional.js.map +0 -7
  476. package/cjs/inputs/Radio/__stories__/Default/index.js +0 -81
  477. package/cjs/inputs/Radio/__stories__/Default.js.map +0 -7
  478. package/cjs/inputs/Radio/__stories__/WithDivider/index.js +0 -82
  479. package/cjs/inputs/Radio/__stories__/WithDivider.js.map +0 -7
  480. package/cjs/inputs/Select/Select.stories/index.js +0 -45
  481. package/cjs/inputs/Select/Select.stories.js.map +0 -7
  482. package/cjs/inputs/Select/__stories__/Default/index.js +0 -86
  483. package/cjs/inputs/Select/__stories__/Default.js.map +0 -7
  484. package/inputs/AutoCompleteInput/AutoComplete.stories/index.js +0 -14
  485. package/inputs/AutoCompleteInput/AutoComplete.stories/package.json +0 -6
  486. package/inputs/AutoCompleteInput/AutoComplete.stories.js.map +0 -7
  487. package/inputs/AutoCompleteInput/__stories__/Default/index.js +0 -50
  488. package/inputs/AutoCompleteInput/__stories__/Default/package.json +0 -6
  489. package/inputs/AutoCompleteInput/__stories__/Default.js.map +0 -7
  490. package/inputs/AutoCompleteInput/__stories__/Multiple/index.js +0 -50
  491. package/inputs/AutoCompleteInput/__stories__/Multiple/package.json +0 -6
  492. package/inputs/AutoCompleteInput/__stories__/Multiple.js.map +0 -7
  493. package/inputs/Checkboxes/Checkboxes.stories/index.js +0 -16
  494. package/inputs/Checkboxes/Checkboxes.stories/package.json +0 -6
  495. package/inputs/Checkboxes/Checkboxes.stories.js.map +0 -7
  496. package/inputs/Checkboxes/__stories__/Conditional/index.js +0 -100
  497. package/inputs/Checkboxes/__stories__/Conditional/package.json +0 -6
  498. package/inputs/Checkboxes/__stories__/Conditional.js.map +0 -7
  499. package/inputs/Checkboxes/__stories__/Default/index.js +0 -44
  500. package/inputs/Checkboxes/__stories__/Default/package.json +0 -6
  501. package/inputs/Checkboxes/__stories__/Default.js.map +0 -7
  502. package/inputs/Checkboxes/__stories__/WithDivider/index.js +0 -45
  503. package/inputs/Checkboxes/__stories__/WithDivider/package.json +0 -6
  504. package/inputs/Checkboxes/__stories__/WithDivider.js.map +0 -7
  505. package/inputs/DateInput/DateInput.stories/index.js +0 -12
  506. package/inputs/DateInput/DateInput.stories/package.json +0 -6
  507. package/inputs/DateInput/DateInput.stories.js.map +0 -7
  508. package/inputs/DateInput/__stories__/Default/index.js +0 -28
  509. package/inputs/DateInput/__stories__/Default/package.json +0 -6
  510. package/inputs/DateInput/__stories__/Default.js.map +0 -7
  511. package/inputs/FileInput/FileInput.stories/index.js +0 -12
  512. package/inputs/FileInput/FileInput.stories/package.json +0 -6
  513. package/inputs/FileInput/FileInput.stories.js.map +0 -7
  514. package/inputs/FileInput/__stories__/Default/index.js +0 -28
  515. package/inputs/FileInput/__stories__/Default/package.json +0 -6
  516. package/inputs/FileInput/__stories__/Default.js.map +0 -7
  517. package/inputs/ImageInput/ImageInput.stories/index.js +0 -16
  518. package/inputs/ImageInput/ImageInput.stories/package.json +0 -6
  519. package/inputs/ImageInput/ImageInput.stories.js.map +0 -7
  520. package/inputs/ImageInput/__stories__/Default/index.js +0 -30
  521. package/inputs/ImageInput/__stories__/Default/package.json +0 -6
  522. package/inputs/ImageInput/__stories__/Default.js.map +0 -7
  523. package/inputs/ImageInput/__stories__/MaxSize/index.js +0 -36
  524. package/inputs/ImageInput/__stories__/MaxSize/package.json +0 -6
  525. package/inputs/ImageInput/__stories__/MaxSize.js.map +0 -7
  526. package/inputs/ImageInput/__stories__/WithInvalidImageDimension/index.js +0 -38
  527. package/inputs/ImageInput/__stories__/WithInvalidImageDimension/package.json +0 -6
  528. package/inputs/ImageInput/__stories__/WithInvalidImageDimension.js.map +0 -7
  529. package/inputs/ImageInput/__stories__/WithInvalidImageSize/index.js +0 -35
  530. package/inputs/ImageInput/__stories__/WithInvalidImageSize/package.json +0 -6
  531. package/inputs/ImageInput/__stories__/WithInvalidImageSize.d.ts +0 -3
  532. package/inputs/ImageInput/__stories__/WithInvalidImageSize.js.map +0 -7
  533. package/inputs/Input/Input.stories/index.js +0 -30
  534. package/inputs/Input/Input.stories.js.map +0 -7
  535. package/inputs/Input/__stories__/AFM/index.js +0 -30
  536. package/inputs/Input/__stories__/AFM/package.json +0 -6
  537. package/inputs/Input/__stories__/AFM.js.map +0 -7
  538. package/inputs/Input/__stories__/Boolean/index.js +0 -31
  539. package/inputs/Input/__stories__/Boolean/package.json +0 -6
  540. package/inputs/Input/__stories__/Boolean.js.map +0 -7
  541. package/inputs/Input/__stories__/IBAN/index.js +0 -31
  542. package/inputs/Input/__stories__/IBAN/package.json +0 -6
  543. package/inputs/Input/__stories__/IBAN.js.map +0 -7
  544. package/inputs/Input/__stories__/Integer/index.js +0 -45
  545. package/inputs/Input/__stories__/Integer/package.json +0 -6
  546. package/inputs/Input/__stories__/Integer.js.map +0 -7
  547. package/inputs/Input/__stories__/LandlineNumber/index.js +0 -34
  548. package/inputs/Input/__stories__/LandlineNumber/package.json +0 -6
  549. package/inputs/Input/__stories__/LandlineNumber.js.map +0 -7
  550. package/inputs/Input/__stories__/MobilePhone/index.js +0 -34
  551. package/inputs/Input/__stories__/MobilePhone/package.json +0 -6
  552. package/inputs/Input/__stories__/MobilePhone.js.map +0 -7
  553. package/inputs/Input/__stories__/PhoneNumber/index.js +0 -33
  554. package/inputs/Input/__stories__/PhoneNumber/package.json +0 -6
  555. package/inputs/Input/__stories__/PhoneNumber.js.map +0 -7
  556. package/inputs/Input/__stories__/PostalCode/index.js +0 -31
  557. package/inputs/Input/__stories__/PostalCode/package.json +0 -6
  558. package/inputs/Input/__stories__/PostalCode.js.map +0 -7
  559. package/inputs/Input/__stories__/String/index.js +0 -31
  560. package/inputs/Input/__stories__/String/package.json +0 -6
  561. package/inputs/Input/__stories__/String.js.map +0 -7
  562. package/inputs/Input/__stories__/TextWithLimit/index.js +0 -31
  563. package/inputs/Input/__stories__/TextWithLimit/package.json +0 -6
  564. package/inputs/Input/__stories__/TextWithLimit.js.map +0 -7
  565. package/inputs/Label/Label.stories/index.js +0 -12
  566. package/inputs/Label/Label.stories/package.json +0 -6
  567. package/inputs/Label/Label.stories.js.map +0 -7
  568. package/inputs/Label/__stories__/Default/index.js +0 -39
  569. package/inputs/Label/__stories__/Default/package.json +0 -6
  570. package/inputs/Label/__stories__/Default.js.map +0 -7
  571. package/inputs/OtpInput/OtpInput.stories/index.js +0 -12
  572. package/inputs/OtpInput/OtpInput.stories/package.json +0 -6
  573. package/inputs/OtpInput/OtpInput.stories.js.map +0 -7
  574. package/inputs/OtpInput/__stories__/Default/index.js +0 -31
  575. package/inputs/OtpInput/__stories__/Default/package.json +0 -6
  576. package/inputs/OtpInput/__stories__/Default.js.map +0 -7
  577. package/inputs/Radio/Radio.stories/index.js +0 -16
  578. package/inputs/Radio/Radio.stories/package.json +0 -6
  579. package/inputs/Radio/Radio.stories.js.map +0 -7
  580. package/inputs/Radio/__stories__/Conditional/index.js +0 -100
  581. package/inputs/Radio/__stories__/Conditional/package.json +0 -6
  582. package/inputs/Radio/__stories__/Conditional.js.map +0 -7
  583. package/inputs/Radio/__stories__/Default/index.js +0 -48
  584. package/inputs/Radio/__stories__/Default/package.json +0 -6
  585. package/inputs/Radio/__stories__/Default.js.map +0 -7
  586. package/inputs/Radio/__stories__/WithDivider/index.js +0 -49
  587. package/inputs/Radio/__stories__/WithDivider/package.json +0 -6
  588. package/inputs/Radio/__stories__/WithDivider.js.map +0 -7
  589. package/inputs/Select/Select.stories/index.js +0 -12
  590. package/inputs/Select/Select.stories/package.json +0 -6
  591. package/inputs/Select/Select.stories.js.map +0 -7
  592. package/inputs/Select/__stories__/Default/index.js +0 -53
  593. package/inputs/Select/__stories__/Default/package.json +0 -6
  594. package/inputs/Select/__stories__/Default.js.map +0 -7
  595. package/lazy.d.ts +0 -77
  596. package/lazy.js.map +0 -7
  597. package/registry.d.ts +0 -70
  598. package/registry.js.map +0 -7
  599. package/src/Field/index.mdx +0 -6
  600. package/src/inputs/ImageInput/__stories__/WithInvalidImageSize.tsx +0 -36
  601. package/src/inputs/ImageInput/index.mdx +0 -19
  602. package/src/inputs/Input/index.mdx +0 -95
  603. package/src/inputs/Label/index.mdx +0 -0
@@ -4,15 +4,13 @@ title: FormBuilder
4
4
  sidebar_label: FormBuilder
5
5
  ---
6
6
 
7
+ # FormBuilder
8
+
7
9
  `FormBuilder` is a React component that provides an easy way to efficiently create reusable form page. Forms are a flexible mechanism for collecting user input because there are suitable widgets for entering many different types of data, including text boxes, checkboxes, radio buttons, dropdowns and so on for submission to a server. Actually when we use `stepForm` for building step-forms all we do is to render `FormBuilder` component.
8
10
 
9
11
  `stepForm` component:
10
12
 
11
- <Story
12
- packageName="@digigov/form"
13
- component="FormBuilder"
14
- story="Default.tsx"
15
- />
13
+ <code src="@digigov/form/FormBuilder/__stories__/Default.tsx" />
16
14
 
17
15
  ### Importing and using FormBuilder Component
18
16
 
@@ -31,21 +29,17 @@ import BasicLayout, {
31
29
  Main,
32
30
  Bottom,
33
31
  } from '@digigov/ui/layouts/Basic';
34
- import {FormBuilder} from '@digigov/form';
32
+ import { FormBuilder } from '@digigov/form';
35
33
 
36
34
  export default function MyComponent({ props }) {
37
-
38
35
  return (
39
36
  <BasicLayout>
40
- .
41
- .
37
+ /* code */
42
38
  <Container>
43
39
  <Main>
44
- .
45
- .
40
+ /* code */
46
41
  <FormBuilder></FormBuilder>
47
- .
48
- .
42
+ /* code */
49
43
  </Main>
50
44
  </Container>
51
45
  <Bottom>
@@ -54,7 +48,6 @@ export default function MyComponent({ props }) {
54
48
  </BasicLayout>
55
49
  );
56
50
  }
57
- }
58
51
  ```
59
52
 
60
53
  ### Props
@@ -81,9 +74,9 @@ Below are demostrated some examples for each type of field
81
74
 
82
75
  ### FormBuilder implementation
83
76
 
84
- The examples above are implemented by using the code below
77
+ The example below are implemented by using the code above.
85
78
 
86
- ```javascript
79
+ ```jsx
87
80
  import React, { useState } from 'react';
88
81
  import BasicLayout, {
89
82
  Top,
@@ -91,7 +84,11 @@ import BasicLayout, {
91
84
  Main,
92
85
  Bottom,
93
86
  } from '@digigov/ui/layouts/Basic';
94
- import Header, { HeaderTitle } from '@digigov/ui/app/Header';
87
+ import Header, {
88
+ HeaderTitle,
89
+ HeaderContent,
90
+ HeaderSection,
91
+ } from '@digigov/ui/app/Header';
95
92
  import GovGRLogo from '@digigov/ui/govgr/GovGRLogo';
96
93
  import GovGRFooter from '@digigov/ui/govgr/Footer';
97
94
  import Button from '@digigov/ui/form/Button';
@@ -99,8 +96,9 @@ import PageTitleContainer, {
99
96
  PageTitleCaption,
100
97
  PageTitleHeading,
101
98
  } from '@digigov/ui/app/PageTitleContainer';
102
- import BackButton from '@digigov/ui/form/Button/BackButton';
103
- import FormBuilder, { Fieldset, FieldsetLabel, Field } from '@digigov/form';
99
+ import BackLink from '@digigov/ui/navigation/BackLink';
100
+ import FormBuilder, { Fieldset, Field } from '@digigov/form';
101
+ import { FieldsetLabel } from '@digigov/form/Fieldset';
104
102
  import { useTranslation } from '@digigov/ui/i18n';
105
103
 
106
104
  const FIELDS = [
@@ -203,30 +201,24 @@ const initialValues = {
203
201
  string: 'default content',
204
202
  };
205
203
 
206
- const useStyles = makeStyles(
207
- {
208
- top: { minHeight: '75px' },
209
- main: {},
210
- side: {},
211
- },
212
- { name: 'MuiSite' }
213
- );
214
-
215
204
  export default function Index() {
216
- const styles = useStyles();
217
205
  const [data, setData] = useState(null);
218
206
  const { t } = useTranslation();
219
207
  return (
220
208
  <BasicLayout>
221
- <Top className={styles.top}>
209
+ <Top>
222
210
  <Header>
223
- <GovGRLogo />
224
- <HeaderTitle>Service name</HeaderTitle>
211
+ <HeaderContent>
212
+ <HeaderSection>
213
+ <GovGRLogo />
214
+ <HeaderTitle>Service name</HeaderTitle>
215
+ </HeaderSection>
216
+ </HeaderContent>
225
217
  </Header>
226
218
  </Top>
227
219
  <Container>
228
- <Main className={styles.main}>
229
- <BackButton>{t('button.back')}</BackButton>
220
+ <Main>
221
+ <BackLink>Back</BackLink>
230
222
  <PageTitleContainer>
231
223
  <PageTitleCaption>Before we start</PageTitleCaption>
232
224
  <PageTitleHeading>Submit a form</PageTitleHeading>
@@ -237,7 +229,7 @@ export default function Index() {
237
229
  initial={initialValues}
238
230
  >
239
231
  <Fieldset>
240
- <FieldsetLabel>This is a fieldset</FieldsetLabel>
232
+ <FieldsetLabel size="lg">This is a fieldset</FieldsetLabel>
241
233
  {FIELDS.map((field) => (
242
234
  <Field key={field.key} name={field.key} />
243
235
  ))}
@@ -1,19 +1,31 @@
1
1
  import React from 'react';
2
2
  import { test, expect } from '@playwright/experimental-ct-react';
3
3
  import TestVariant from '@digigov/ui/utils/TestVariant'
4
+ import { AutoErrorGrouping } from '@digigov/form/FormBuilder/__stories__/AutoErrorGrouping';
4
5
  import { Default } from '@digigov/form/FormBuilder/__stories__/Default';
6
+ import { ErrorGrouping } from '@digigov/form/FormBuilder/__stories__/ErrorGrouping';
5
7
 
6
8
  test('renders the All FormBuilder variants', async ({ mount, page }) => {
7
9
  await mount(
8
10
 
9
11
  <div>
12
+ <TestVariant title="AutoErrorGrouping">
13
+ <AutoErrorGrouping />
14
+ </TestVariant>
10
15
  <TestVariant title="Default">
11
16
  <Default />
12
17
  </TestVariant>
18
+ <TestVariant title="ErrorGrouping">
19
+ <ErrorGrouping />
20
+ </TestVariant>
13
21
  </div>
14
22
  )
15
23
  await page.evaluate(() => document.fonts.ready);
16
24
 
25
+ // Move the mouse to the top-left corner to avoid random hover issues
26
+ await page.mouse.move(0, 0);
27
+
28
+
17
29
  const screenshot = await page.screenshot({ fullPage: true, animations: 'disabled' });
18
30
  expect(screenshot).toMatchSnapshot();
19
31
  });
@@ -1,15 +1,16 @@
1
- /* eslint-disable @typescript-eslint/no-explicit-any */
2
- import React, { useCallback, useContext, useRef } from 'react';
1
+ import React, { useCallback, useContext, useEffect, useRef } from 'react';
3
2
  import { useForm } from 'react-hook-form';
4
- import Field from '@digigov/form/Field';
3
+ import { Field } from '@digigov/form/Field';
4
+ import { ErrorGroup } from '@digigov/form/Field/ErrorGroup';
5
5
  import { CONTROLLED_FIELD_COMPONENTS } from '@digigov/form/Field/utils';
6
- import Fieldset from '@digigov/form/Fieldset';
6
+ import { FieldsetWithContext } from '@digigov/form/Fieldset/FieldsetWithContext';
7
7
  import { FormContext } from '@digigov/form/FormContext';
8
8
  import { FormBaseProps, FormData, FormBuilderProps } from '@digigov/form/types';
9
9
  import { yupResolver } from '@digigov/form/utils';
10
10
  import { useValidationSchema } from '@digigov/form/validators';
11
- import { Form } from '@digigov/react-core/Form';
12
11
  import { Button } from '@digigov/ui/form/Button';
12
+ import { Form } from '@digigov/ui/form/Form';
13
+ import { useScreenSize } from '@digigov/ui/utils/hooks/useScreen';
13
14
 
14
15
  const FormBase = React.forwardRef(function FormBase(
15
16
  {
@@ -22,10 +23,11 @@ const FormBase = React.forwardRef(function FormBase(
22
23
  mode,
23
24
  initial,
24
25
  reValidateMode,
25
- shouldFocusError,
26
+ shouldFocusError = true,
26
27
  criteriaMode,
27
28
  componentRegistry,
28
29
  grid,
30
+ errors,
29
31
  ...props
30
32
  }: FormBaseProps,
31
33
  ref: React.Ref<HTMLFormElement>
@@ -41,10 +43,20 @@ const FormBase = React.forwardRef(function FormBase(
41
43
 
42
44
  const handleSubmit = useCallback(
43
45
  (data: FormData): void => {
44
- onSubmit && onSubmit(data);
46
+ if (onSubmit) {
47
+ form.reset(data);
48
+ onSubmit(data);
49
+ }
45
50
  },
46
51
  [onSubmit]
47
52
  );
53
+ useEffect(() => {
54
+ if (errors) {
55
+ for (const fieldName in errors) {
56
+ form.setError(fieldName, errors[fieldName], { shouldFocus: true });
57
+ }
58
+ }
59
+ }, [errors]);
48
60
  const submit = form.handleSubmit(handleSubmit);
49
61
  const ctx = {
50
62
  fieldsMap,
@@ -68,6 +80,7 @@ const FormBase = React.forwardRef(function FormBase(
68
80
  formRef: ref,
69
81
  submit,
70
82
  };
83
+
71
84
  return (
72
85
  <FormContext.Provider value={ctx}>
73
86
  <Form grid={grid} onSubmit={submit} ref={ref} {...props}>
@@ -77,6 +90,43 @@ const FormBase = React.forwardRef(function FormBase(
77
90
  );
78
91
  });
79
92
 
93
+ const DEFAULT_LAYOUT = {
94
+ xs: 12,
95
+ sm: 12,
96
+ md: 12,
97
+ lg: 12,
98
+ xl: 12,
99
+ };
100
+
101
+ const BREAKPOINTS = ['xs', 'sm', 'md', 'lg', 'xl'];
102
+
103
+ const groupFieldsByLayout = (fields) => {
104
+ return BREAKPOINTS.reduce((sizes, size) => {
105
+ sizes[size] = fields
106
+ .reduce((acc, item) => {
107
+ const layoutValue = item.layout?.[size] || 12;
108
+ if (layoutValue === 0) {
109
+ return [...acc, item];
110
+ }
111
+ const lastElement = acc[acc.length - 1];
112
+ const currentSum = Array.isArray(lastElement)
113
+ ? lastElement.reduce((sum, i) => sum + (i.layout?.[size] || 0), 0)
114
+ : 0;
115
+ if (!Array.isArray(lastElement) || currentSum + layoutValue > 12) {
116
+ return layoutValue === 12 ? [...acc, item] : [...acc, [item]];
117
+ }
118
+
119
+ return [...acc.slice(0, -1), [...lastElement, item]];
120
+ }, [])
121
+ .map((item) => {
122
+ if (Array.isArray(item) && item.length === 1) {
123
+ return item[0];
124
+ }
125
+ return item;
126
+ });
127
+ return sizes;
128
+ }, {});
129
+ };
80
130
  const useFormContext = () => {
81
131
  return useContext(FormContext);
82
132
  };
@@ -103,6 +153,34 @@ const FormBuilder = React.forwardRef(function FormBuilder(
103
153
  }: FormBuilderProps,
104
154
  ref: React.Ref<HTMLFormElement>
105
155
  ): React.ReactElement {
156
+ const { screenSize } = useScreenSize();
157
+ fields = fields.map((field) => {
158
+ const layout = field.layout;
159
+ if (!layout) {
160
+ return {
161
+ ...field,
162
+ layout: DEFAULT_LAYOUT,
163
+ };
164
+ }
165
+ return {
166
+ ...field,
167
+ layout: BREAKPOINTS.reduce(
168
+ (expandedLayout, breakpoint, breakpointIndex) => {
169
+ if (field?.layout?.[breakpoint]) {
170
+ expandedLayout[breakpoint] = field?.layout[breakpoint];
171
+ } else if (expandedLayout[BREAKPOINTS[breakpointIndex - 1]]) {
172
+ expandedLayout[breakpoint] =
173
+ expandedLayout[BREAKPOINTS[breakpointIndex - 1]];
174
+ } else {
175
+ expandedLayout[breakpoint] = 12;
176
+ }
177
+ return expandedLayout;
178
+ },
179
+ {}
180
+ ),
181
+ };
182
+ });
183
+
106
184
  const fieldsState = useRef(fields);
107
185
  const setFieldsState = useCallback((newFields) => {
108
186
  fieldsState.current = newFields;
@@ -138,12 +216,28 @@ const FormBuilder = React.forwardRef(function FormBuilder(
138
216
  if (auto) {
139
217
  if (fieldsets) {
140
218
  fieldChildren = fieldsets.map((fieldset) => (
141
- <Fieldset key={fieldset.key} />
219
+ <FieldsetWithContext key={fieldset.key} name={fieldset.key} />
142
220
  ));
143
221
  } else if (fields) {
144
- fieldChildren = fields.map((field) => (
145
- <Field key={field.key} name={field.key} />
146
- ));
222
+ const fieldsByLayouts = groupFieldsByLayout(fields);
223
+ const fieldsByLayoutSize = fieldsByLayouts[screenSize];
224
+ fieldChildren = fieldsByLayoutSize.map((item, index) => {
225
+ if (Array.isArray(item)) {
226
+ return (
227
+ <ErrorGroup
228
+ key={index}
229
+ screenSize={screenSize}
230
+ fieldOrder={item.map((field) => field.key)}
231
+ >
232
+ {item.map((f) => {
233
+ return <Field key={f.key} name={f.key} />;
234
+ })}
235
+ </ErrorGroup>
236
+ );
237
+ } else {
238
+ return <Field key={item.key} name={item.key} />;
239
+ }
240
+ });
147
241
  }
148
242
  }
149
243
  }
@@ -0,0 +1,40 @@
1
+ import React from 'react';
2
+ import { test, expect } from '@playwright/experimental-ct-react';
3
+
4
+ import { AutoErrorGrouping } from '@digigov/form/FormBuilder/__stories__/AutoErrorGrouping';
5
+ import { ErrorGrouping } from '@digigov/form/FormBuilder/__stories__/ErrorGrouping';
6
+
7
+ test('renders the ErrorGrouping and click submit', async ({ mount, page }) => {
8
+ await mount(<ErrorGrouping />);
9
+ await page.evaluate(() => document.fonts.ready);
10
+
11
+ // Move the mouse to the top-left corner to avoid random hover issues
12
+ await page.mouse.move(0, 0);
13
+
14
+ await page.click('text="Συνέχεια"');
15
+
16
+ const screenshot = await page.screenshot({
17
+ fullPage: true,
18
+ animations: 'disabled',
19
+ });
20
+ expect(screenshot).toMatchSnapshot();
21
+ });
22
+
23
+ test('renders the AutoErrorGrouping and click submit', async ({
24
+ mount,
25
+ page,
26
+ }) => {
27
+ await mount(<AutoErrorGrouping />);
28
+ await page.evaluate(() => document.fonts.ready);
29
+
30
+ // Move the mouse to the top-left corner to avoid random hover issues
31
+ await page.mouse.move(0, 0);
32
+
33
+ await page.click('text="Συνέχεια"');
34
+
35
+ const screenshot = await page.screenshot({
36
+ fullPage: true,
37
+ animations: 'disabled',
38
+ });
39
+ expect(screenshot).toMatchSnapshot();
40
+ });
@@ -469,7 +469,11 @@ const expectErrorMessages = async (formBuilder, scenarioExpect, expect) => {
469
469
  );
470
470
  }
471
471
  }
472
- await expect(labelLocator).toHaveText(expectText);
472
+ if (expectObj.textAssertion === 'toContainText') {
473
+ await expect(labelLocator).toContainText(expectText);
474
+ } else {
475
+ await expect(labelLocator).toHaveText(expectText);
476
+ }
473
477
  }
474
478
  }
475
479
  };
@@ -589,7 +593,7 @@ const generateScenarios = (
589
593
  };
590
594
  scenarioFill.push(finalScenarioFill);
591
595
  for (const multiplicityField of fillTemplate?.value?.of?.extra
592
- ?.fields) {
596
+ ?.fields ?? []) {
593
597
  scenarioExpect.push({
594
598
  type: 'success',
595
599
  fieldKey: `${fillTemplate.fieldKey}\\.${i}\\.${multiplicityField.fieldKey}`,
@@ -648,9 +652,9 @@ const el = {
648
652
  email: 'Συμπληρώστε μια έγκυρη ηλεκτρονική διεύθυνση (e-mail).',
649
653
  afm: 'Ο Α.Φ.Μ που πληκτρολογήσατε είναι λανθασμένος.',
650
654
  file_size:
651
- 'Το μέγεθος του αρχείου είναι μεγαλύτερο απο το επιτρεπόμενο ({{maxSizeToMb}}Mb).',
655
+ 'Το μέγεθος του αρχείου είναι μεγαλύτερο από το επιτρεπόμενο ({{maxSize}} Bytes).',
652
656
  image_size:
653
- 'Το μέγεθος της φωτογραφίας είναι μεγαλύτερο απο το επιτρεπόμενο ({{maxSizeToMb}}Mb).',
657
+ 'Το μέγεθος της φωτογραφίας είναι μεγαλύτερο από το επιτρεπόμενο ({{maxSize}} Bytes).',
654
658
  mobile_phone: 'Συμπληρώστε έναν έγκυρο αριθμό κινητού τηλεφώνου.',
655
659
  phone_number: 'Συμπληρώστε έναν έγκυρο αριθμό τηλεφώνου.',
656
660
  landline: 'Συμπληρώστε έναν έγκυρο αριθμό σταθερού τηλεφώνου.',
@@ -1118,7 +1122,7 @@ const inputsScenarios = [
1118
1122
  type: 'error',
1119
1123
  fieldKey: 'image',
1120
1124
  args: {
1121
- maxSizeToMb: 0.0003,
1125
+ maxSize: 300,
1122
1126
  },
1123
1127
  text: el.form.error.image_size,
1124
1128
  },
@@ -1126,7 +1130,7 @@ const inputsScenarios = [
1126
1130
  type: 'error',
1127
1131
  fieldKey: 'file',
1128
1132
  args: {
1129
- maxSizeToMb: 0.0003,
1133
+ maxSize: 300,
1130
1134
  },
1131
1135
  text: el.form.error.file_size,
1132
1136
  },
@@ -1289,6 +1293,54 @@ const INPUTS_INPUT_FIELDS = [
1289
1293
  },
1290
1294
  ];
1291
1295
 
1296
+ const ERROR_GROUPING_FIELDS = [
1297
+ {
1298
+ key: 'address',
1299
+ type: 'string',
1300
+ required: true,
1301
+ layout: { xl: 6, lg: 6, md: 6, xs: 6 },
1302
+ label: {
1303
+ primary: 'Οδός',
1304
+ },
1305
+ },
1306
+ {
1307
+ key: 'address_number',
1308
+ type: 'int',
1309
+ required: true,
1310
+ layout: { xl: 2, lg: 2, md: 2, xs: 6 },
1311
+ label: {
1312
+ primary: 'Αριθμός',
1313
+ },
1314
+ },
1315
+ {
1316
+ key: 'postal_code',
1317
+ type: 'postal_code',
1318
+ required: true,
1319
+ layout: { xl: 4, lg: 4, md: 4, xs: 6 },
1320
+ label: {
1321
+ primary: 'Ταχ. Κώδικας',
1322
+ },
1323
+ },
1324
+ {
1325
+ key: 'town',
1326
+ type: 'string',
1327
+ required: true,
1328
+ layout: { xl: 6, lg: 6, md: 6, xs: 6 },
1329
+ label: {
1330
+ primary: 'Πόλη',
1331
+ },
1332
+ },
1333
+ {
1334
+ key: 'country',
1335
+ type: 'string',
1336
+ required: true,
1337
+ layout: { xl: 6, lg: 6, md: 6, xs: 6 },
1338
+ label: {
1339
+ primary: 'Χώρα',
1340
+ },
1341
+ },
1342
+ ];
1343
+
1292
1344
  const inputsInputScenarios = [
1293
1345
  {
1294
1346
  title: 'success fill for inputs Input',
@@ -1410,7 +1462,8 @@ const inputsInputScenarios = [
1410
1462
  {
1411
1463
  title: 'empty fill for inputs Input',
1412
1464
  describe: 'inputs Input scenario',
1413
- fields: INPUTS_INPUT_FIELDS,
1465
+ delay: 5_000,
1466
+ fields: [...INPUTS_INPUT_FIELDS, ...ERROR_GROUPING_FIELDS],
1414
1467
  fill: [],
1415
1468
  expect: [
1416
1469
  {
@@ -1468,12 +1521,42 @@ const inputsInputScenarios = [
1468
1521
  fieldKey: 'uuid4',
1469
1522
  text: el.form.error.required,
1470
1523
  },
1524
+ {
1525
+ type: 'error',
1526
+ fieldKey: 'address',
1527
+ text: el.form.error.required,
1528
+ textAssertion: 'toContainText',
1529
+ },
1530
+ {
1531
+ type: 'error',
1532
+ fieldKey: 'address_number',
1533
+ text: el.form.error.required,
1534
+ textAssertion: 'toContainText',
1535
+ },
1536
+ {
1537
+ type: 'error',
1538
+ fieldKey: 'postal_code',
1539
+ text: el.form.error.required,
1540
+ textAssertion: 'toContainText',
1541
+ },
1542
+ {
1543
+ type: 'error',
1544
+ fieldKey: 'town',
1545
+ text: el.form.error.required,
1546
+ textAssertion: 'toContainText',
1547
+ },
1548
+ {
1549
+ type: 'error',
1550
+ fieldKey: 'country',
1551
+ text: el.form.error.required,
1552
+ textAssertion: 'toContainText',
1553
+ },
1471
1554
  ],
1472
1555
  },
1473
1556
  {
1474
1557
  title: 'incorrect types for inputs Input',
1475
1558
  describe: 'inputs Input scenario',
1476
- fields: INPUTS_INPUT_FIELDS,
1559
+ fields: [...INPUTS_INPUT_FIELDS, ...ERROR_GROUPING_FIELDS],
1477
1560
  fill: [
1478
1561
  {
1479
1562
  fieldKey: 'age',
@@ -1519,6 +1602,14 @@ const inputsInputScenarios = [
1519
1602
  fieldKey: 'uuid4',
1520
1603
  value: 'aaaaaa',
1521
1604
  },
1605
+ {
1606
+ fieldKey: 'address_number',
1607
+ value: 'aa',
1608
+ },
1609
+ {
1610
+ fieldKey: 'postal_code',
1611
+ value: 'aaaaa',
1612
+ },
1522
1613
  ],
1523
1614
  expect: [
1524
1615
  {
@@ -1576,6 +1667,18 @@ const inputsInputScenarios = [
1576
1667
  fieldKey: 'uuid4',
1577
1668
  text: el.form.error.uuid4,
1578
1669
  },
1670
+ {
1671
+ type: 'error',
1672
+ fieldKey: 'address_number',
1673
+ text: el.form.error.number,
1674
+ textAssertion: 'toContainText',
1675
+ },
1676
+ {
1677
+ type: 'error',
1678
+ fieldKey: 'postal_code',
1679
+ text: el.form.error.postalCode,
1680
+ textAssertion: 'toContainText',
1681
+ },
1579
1682
  ],
1580
1683
  },
1581
1684
  ];
@@ -1726,6 +1829,7 @@ const fieldArrayScenarioTitles = [
1726
1829
  const fieldArrayFieldsTemplate = {
1727
1830
  key: 'fieldArray',
1728
1831
  type: 'array',
1832
+ editable: true,
1729
1833
  label: {
1730
1834
  primary: 'Εξαρτώμενα μέλη',
1731
1835
  secondary:
@@ -1744,6 +1848,7 @@ const fieldArrayFieldsTemplate = {
1744
1848
  no: 'Όχι',
1745
1849
  },
1746
1850
  },
1851
+ border: 'border',
1747
1852
  of: {
1748
1853
  type: 'object',
1749
1854
  label: {
@@ -1842,16 +1947,25 @@ const scenarios = [
1842
1947
  ...inputsInputScenarios,
1843
1948
  ];
1844
1949
 
1950
+ const delay = (ms) => new Promise((resolve) => setTimeout(resolve, ms));
1951
+
1845
1952
  for (const scenario of scenarios) {
1846
1953
  test.describe(scenario.describe, () => {
1847
1954
  test(scenario.title, async ({ mount, page }) => {
1848
1955
  const formBuilder = await mount(
1849
1956
  // @ts-ignore
1850
- <FormBuilder auto={true} fields={scenario.fields} onSubmit={() => { }} />
1957
+ <FormBuilder
1958
+ auto={true}
1959
+ grid={true}
1960
+ fields={scenario.fields}
1961
+ onSubmit={() => { }}
1962
+ />
1851
1963
  );
1852
1964
  await fillFields(page, formBuilder, scenario);
1853
1965
  await submitForm(formBuilder);
1854
-
1966
+ if (scenario.delay) {
1967
+ await delay(scenario.delay);
1968
+ }
1855
1969
  const screenshot = await page.screenshot({
1856
1970
  fullPage: true,
1857
1971
  animations: 'disabled',
@@ -1,5 +1,4 @@
1
- import React from 'react';
2
- import { createContext } from 'react';
1
+ import React, { createContext } from 'react';
3
2
  import { FormContextProps } from '@digigov/form/types';
4
3
 
5
4
  export const FormContext: React.Context<FormContextProps> = createContext({
@@ -1,4 +1,3 @@
1
- /* eslint-disable react/prop-types */
2
1
  import React, { useEffect, useMemo } from 'react';
3
2
  import {
4
3
  ErrorOption,
@@ -14,16 +13,15 @@ import {
14
13
  } from '@digigov/form/Field/utils';
15
14
  import { calculateField } from '@digigov/form/Field/utils/calculateField';
16
15
  import { useField } from '@digigov/form/Field/utils/useField';
17
-
18
- import FieldObject from '@digigov/form/FieldObject';
16
+ import { FieldObject } from '@digigov/form/FieldObject';
17
+ import { Fieldset } from '@digigov/form/Fieldset';
19
18
  import type {
20
19
  MultiplicityProps,
21
20
  StashedObject,
22
21
  } from '@digigov/form/MultiplicityField/types';
23
22
  import { FieldSpec } from '@digigov/form/types';
24
- import Fieldset from '@digigov/react-core/Fieldset';
25
- import RadioConditional from '@digigov/react-core/RadioConditional';
26
- import Button from '@digigov/ui/form/Button';
23
+ import { Button } from '@digigov/ui/form/Button';
24
+ import { RadioConditional } from '@digigov/ui/form/RadioContainer';
27
25
 
28
26
  export interface AddObjectsProps
29
27
  extends Omit<MultiplicityProps, 'key' | 'component'> {
@@ -51,7 +49,7 @@ export const AddObjects: React.FC<AddObjectsProps> = ({
51
49
  getValues,
52
50
  onStash,
53
51
  error,
54
- Field
52
+ Field,
55
53
  }) => {
56
54
  const currentIndex = fields.length > 0 ? fields.length - 1 : fields.length;
57
55
  const currentName = `${name}.${currentIndex}`;
@@ -107,8 +105,10 @@ export const AddObjects: React.FC<AddObjectsProps> = ({
107
105
  (f) => `${currentName}.${f.key}`
108
106
  );
109
107
  const result = await trigger(nestedFields);
110
- result && setValue('needs-more', '');
111
- result && onStash(getValues(currentName));
108
+ if (result) {
109
+ setValue('needs-more', '');
110
+ onStash(getValues(currentName));
111
+ }
112
112
  }}
113
113
  >
114
114
  {extra?.label.object.add}
@@ -133,6 +133,7 @@ export const AddObjects: React.FC<AddObjectsProps> = ({
133
133
  control,
134
134
  register,
135
135
  reset,
136
+ resetField,
136
137
  error: needsMoreError,
137
138
  } = useField(radioField.key, radioField?.type ? radioField : null);
138
139
 
@@ -187,6 +188,7 @@ export const AddObjects: React.FC<AddObjectsProps> = ({
187
188
  control={control}
188
189
  register={register}
189
190
  reset={reset}
191
+ resetField={resetField}
190
192
  Field={Field}
191
193
  error={
192
194
  extra?.max - stashedObjects.length === 0 ||