@digigov/form 2.0.0-555d1027 → 2.0.0-5e7a6790

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 (396) hide show
  1. package/Field/ErrorGroup.d.ts +3 -3
  2. package/Field/ErrorGroup.js.map +1 -1
  3. package/Field/FieldBase/index.js +0 -1
  4. package/Field/FieldBase.d.ts +1 -1
  5. package/Field/FieldBase.js.map +2 -2
  6. package/Field/FieldBaseContainer/index.js +36 -34
  7. package/Field/FieldBaseContainer.d.ts +2 -2
  8. package/Field/FieldBaseContainer.js.map +2 -2
  9. package/Field/FieldConditional.d.ts +1 -1
  10. package/Field/FieldConditional.js.map +1 -1
  11. package/Field/index.d.ts +1 -1
  12. package/Field/index.js +15 -25
  13. package/Field/index.js.map +2 -2
  14. package/Field/types.d.ts +11 -10
  15. package/Field/utils/evaluateFieldWithConditions.d.ts +2 -2
  16. package/Field/utils/evaluateFieldWithConditions.js.map +2 -2
  17. package/Field/utils/resolveField/index.js +35 -0
  18. package/Field/utils/{calculateField → resolveField}/package.json +1 -1
  19. package/Field/utils/resolveField.d.ts +3 -0
  20. package/Field/utils/resolveField.js.map +7 -0
  21. package/Field/utils/useField/index.js +4 -2
  22. package/Field/utils/useField.d.ts +1 -1
  23. package/Field/utils/useField.js.map +2 -2
  24. package/FieldArray/BaseFieldArray/index.js +76 -0
  25. package/{inputs/inputsScenarios → FieldArray/BaseFieldArray}/package.json +1 -1
  26. package/FieldArray/BaseFieldArray.d.ts +5 -0
  27. package/FieldArray/BaseFieldArray.js.map +7 -0
  28. package/FieldArray/FormDialog/ArrayDisplay/ArrayDisplay.stories.d.ts +10 -0
  29. package/FieldArray/FormDialog/ArrayDisplay/ArrayItemDisplay/index.js +97 -0
  30. package/FieldArray/FormDialog/ArrayDisplay/ArrayItemDisplay/package.json +6 -0
  31. package/FieldArray/FormDialog/ArrayDisplay/ArrayItemDisplay.d.ts +22 -0
  32. package/FieldArray/FormDialog/ArrayDisplay/ArrayItemDisplay.js.map +7 -0
  33. package/FieldArray/FormDialog/ArrayDisplay/ArrayItemHeader/index.js +11 -0
  34. package/FieldArray/FormDialog/ArrayDisplay/ArrayItemHeader/package.json +6 -0
  35. package/FieldArray/FormDialog/ArrayDisplay/ArrayItemHeader.d.ts +5 -0
  36. package/FieldArray/FormDialog/ArrayDisplay/ArrayItemHeader.js.map +7 -0
  37. package/FieldArray/FormDialog/ArrayDisplay/__stories__/Default.d.ts +2 -0
  38. package/FieldArray/FormDialog/ArrayDisplay/__stories__/ReadOnly.d.ts +2 -0
  39. package/FieldArray/FormDialog/ArrayDisplay/__stories__/Sortable.d.ts +2 -0
  40. package/FieldArray/FormDialog/ArrayDisplay/index.d.ts +14 -0
  41. package/FieldArray/FormDialog/ArrayDisplay/index.js +51 -0
  42. package/FieldArray/FormDialog/ArrayDisplay/index.js.map +7 -0
  43. package/FieldArray/FormDialog/ArrayDisplay/package.json +6 -0
  44. package/FieldArray/FormDialog/ArrayEditModal/index.js +149 -0
  45. package/FieldArray/FormDialog/ArrayEditModal/package.json +6 -0
  46. package/FieldArray/FormDialog/ArrayEditModal.d.ts +26 -0
  47. package/FieldArray/FormDialog/ArrayEditModal.js.map +7 -0
  48. package/FieldArray/FormDialog/index.d.ts +19 -0
  49. package/FieldArray/FormDialog/index.js +139 -348
  50. package/FieldArray/FormDialog/index.js.map +7 -0
  51. package/FieldArray/index.d.ts +4 -2
  52. package/FieldArray/index.js +28 -54
  53. package/FieldArray/index.js.map +2 -2
  54. package/FieldObject/index.d.ts +4 -4
  55. package/FieldObject/index.js +5 -12
  56. package/FieldObject/index.js.map +2 -2
  57. package/Fieldset/FieldsetWithContext.js.map +1 -1
  58. package/Fieldset/index.d.ts +1 -1
  59. package/Fieldset/index.js.map +1 -1
  60. package/Fieldset/types.d.ts +2 -2
  61. package/FormBuilder/index.d.ts +1 -1
  62. package/FormBuilder/index.js +155 -130
  63. package/FormBuilder/index.js.map +2 -2
  64. package/FormContext.d.ts +2 -2
  65. package/FormContext.js.map +2 -2
  66. package/MultiplicityField/add-objects/index.js +10 -19
  67. package/MultiplicityField/add-objects.d.ts +1 -1
  68. package/MultiplicityField/add-objects.js.map +2 -2
  69. package/MultiplicityField/index.d.ts +2 -2
  70. package/MultiplicityField/index.js.map +2 -2
  71. package/MultiplicityField/types.d.ts +2 -2
  72. package/Questions/Questions.d.ts +1 -1
  73. package/Questions/Questions.js.map +1 -1
  74. package/Questions/QuestionsContext.d.ts +1 -1
  75. package/Questions/QuestionsContext.js.map +1 -1
  76. package/Questions/Step/Step.d.ts +1 -1
  77. package/Questions/Step/Step.js.map +1 -1
  78. package/Questions/Step/StepArrayReview.d.ts +1 -1
  79. package/Questions/Step/StepArrayReview.js.map +1 -1
  80. package/Questions/Step/StepContext.d.ts +1 -1
  81. package/Questions/Step/StepContext.js.map +1 -1
  82. package/Questions/Step/StepDescription.d.ts +1 -1
  83. package/Questions/Step/StepDescription.js.map +2 -2
  84. package/Questions/Step/StepForm.d.ts +2 -2
  85. package/Questions/Step/StepForm.js.map +1 -1
  86. package/Questions/Step/StepQuote.d.ts +1 -1
  87. package/Questions/Step/StepQuote.js.map +2 -2
  88. package/Questions/Step/StepTitle.d.ts +1 -1
  89. package/Questions/Step/StepTitle.js.map +2 -2
  90. package/Questions/Step/getAddMoreFields.d.ts +2 -2
  91. package/Questions/Step/getAddMoreFields.js.map +1 -1
  92. package/Questions/Step/types.d.ts +1 -1
  93. package/Questions/getNextStep.d.ts +1 -1
  94. package/Questions/getNextStep.js.map +1 -1
  95. package/Questions/types.d.ts +1 -1
  96. package/cjs/Field/ErrorGroup.js.map +1 -1
  97. package/cjs/Field/FieldBase/index.js +0 -1
  98. package/cjs/Field/FieldBase.js.map +2 -2
  99. package/cjs/Field/FieldBaseContainer/index.js +36 -34
  100. package/cjs/Field/FieldBaseContainer.js.map +2 -2
  101. package/cjs/Field/FieldConditional.js.map +1 -1
  102. package/cjs/Field/index.js +15 -22
  103. package/cjs/Field/index.js.map +2 -2
  104. package/cjs/Field/types.js.map +1 -1
  105. package/cjs/Field/utils/evaluateFieldWithConditions.js.map +2 -2
  106. package/cjs/Field/utils/resolveField/index.js +55 -0
  107. package/cjs/Field/utils/resolveField.js.map +7 -0
  108. package/cjs/Field/utils/useField/index.js +4 -2
  109. package/cjs/Field/utils/useField.js.map +2 -2
  110. package/cjs/FieldArray/BaseFieldArray/index.js +109 -0
  111. package/cjs/FieldArray/BaseFieldArray.js.map +7 -0
  112. package/cjs/FieldArray/FormDialog/ArrayDisplay/ArrayItemDisplay/index.js +130 -0
  113. package/cjs/FieldArray/FormDialog/ArrayDisplay/ArrayItemDisplay.js.map +7 -0
  114. package/cjs/{locales/el → FieldArray/FormDialog/ArrayDisplay/ArrayItemHeader}/index.js +16 -7
  115. package/cjs/FieldArray/FormDialog/ArrayDisplay/ArrayItemHeader.js.map +7 -0
  116. package/cjs/FieldArray/FormDialog/ArrayDisplay/index.js +84 -0
  117. package/cjs/FieldArray/FormDialog/ArrayDisplay/index.js.map +7 -0
  118. package/cjs/FieldArray/FormDialog/ArrayEditModal/index.js +177 -0
  119. package/cjs/FieldArray/FormDialog/ArrayEditModal.js.map +7 -0
  120. package/cjs/FieldArray/FormDialog/index.js +130 -331
  121. package/cjs/FieldArray/FormDialog/index.js.map +7 -0
  122. package/cjs/FieldArray/index.js +27 -53
  123. package/cjs/FieldArray/index.js.map +3 -3
  124. package/cjs/FieldObject/index.js +5 -9
  125. package/cjs/FieldObject/index.js.map +2 -2
  126. package/cjs/Fieldset/FieldsetWithContext.js.map +1 -1
  127. package/cjs/Fieldset/index.js.map +1 -1
  128. package/cjs/Fieldset/types.js.map +1 -1
  129. package/cjs/FormBuilder/index.js +156 -131
  130. package/cjs/FormBuilder/index.js.map +3 -3
  131. package/cjs/FormContext.js.map +2 -2
  132. package/cjs/MultiplicityField/add-objects/index.js +9 -13
  133. package/cjs/MultiplicityField/add-objects.js.map +2 -2
  134. package/cjs/MultiplicityField/index.js.map +2 -2
  135. package/cjs/MultiplicityField/types.js.map +1 -1
  136. package/cjs/Questions/Questions.js.map +1 -1
  137. package/cjs/Questions/QuestionsContext.js.map +1 -1
  138. package/cjs/Questions/Step/Step.js.map +1 -1
  139. package/cjs/Questions/Step/StepArrayReview.js.map +1 -1
  140. package/cjs/Questions/Step/StepContext.js.map +1 -1
  141. package/cjs/Questions/Step/StepDescription.js.map +2 -2
  142. package/cjs/Questions/Step/StepForm.js.map +1 -1
  143. package/cjs/Questions/Step/StepQuote.js.map +2 -2
  144. package/cjs/Questions/Step/StepTitle.js.map +2 -2
  145. package/cjs/Questions/Step/getAddMoreFields.js.map +1 -1
  146. package/cjs/Questions/Step/types.js.map +1 -1
  147. package/cjs/Questions/getNextStep.js.map +1 -1
  148. package/cjs/Questions/types.js.map +1 -1
  149. package/cjs/hooks/useFieldFocusManager/index.js +135 -0
  150. package/cjs/hooks/useFieldFocusManager.js.map +7 -0
  151. package/cjs/hooks/utils/index.js +98 -0
  152. package/cjs/hooks/utils.js.map +7 -0
  153. package/cjs/inputs/AutoCompleteInput/index.js.map +2 -2
  154. package/cjs/inputs/Checkboxes/index.js +67 -63
  155. package/cjs/inputs/Checkboxes/index.js.map +2 -2
  156. package/cjs/inputs/DateInput/index.js +10 -5
  157. package/cjs/inputs/DateInput/index.js.map +2 -2
  158. package/cjs/inputs/DateTimeInput/index.js +10 -5
  159. package/cjs/inputs/DateTimeInput/index.js.map +2 -2
  160. package/cjs/inputs/FileInput/index.js.map +2 -2
  161. package/cjs/inputs/ImageInput/index.js.map +1 -1
  162. package/cjs/inputs/Input/index.js +54 -56
  163. package/cjs/inputs/Input/index.js.map +2 -2
  164. package/cjs/inputs/Label/index.js.map +1 -1
  165. package/cjs/inputs/OtpInput/index.js +36 -31
  166. package/cjs/inputs/OtpInput/index.js.map +2 -2
  167. package/cjs/inputs/Radio/index.js +5 -4
  168. package/cjs/inputs/Radio/index.js.map +3 -3
  169. package/cjs/inputs/Select/index.js.map +1 -1
  170. package/cjs/{Field/utils → inputs/registry}/index.js +4 -4
  171. package/cjs/inputs/registry.js.map +7 -0
  172. package/cjs/{lazy/index.js → lazy.js} +10 -9
  173. package/cjs/lazy.js.map +2 -2
  174. package/cjs/{registry/index.js → registry.js} +23 -13
  175. package/cjs/registry.js.map +2 -2
  176. package/cjs/types.js.map +1 -1
  177. package/cjs/utils.js.map +2 -2
  178. package/cjs/validators/index.js.map +2 -2
  179. package/cjs/validators/types.js.map +1 -1
  180. package/cjs/validators/utils/date/index.js +6 -1
  181. package/cjs/validators/utils/date.js.map +2 -2
  182. package/cjs/validators/utils/datetime/index.js +6 -1
  183. package/cjs/validators/utils/datetime.js.map +2 -2
  184. package/cjs/validators/utils/file.js.map +1 -1
  185. package/cjs/validators/utils/iban.js.map +1 -1
  186. package/cjs/validators/utils/image.js.map +1 -1
  187. package/cjs/validators/utils/index.js.map +1 -1
  188. package/cjs/validators/utils/int.js.map +1 -1
  189. package/cjs/validators/utils/number.js.map +1 -1
  190. package/cjs/validators/utils/otp.js.map +1 -1
  191. package/cjs/validators/utils/phone.js.map +1 -1
  192. package/cjs/validators/utils/postal_code.js.map +1 -1
  193. package/cjs/validators/utils/text_limit.js.map +1 -1
  194. package/hooks/useFieldFocusManager/index.js +116 -0
  195. package/hooks/useFieldFocusManager/package.json +6 -0
  196. package/hooks/useFieldFocusManager.d.ts +25 -0
  197. package/hooks/useFieldFocusManager.js.map +7 -0
  198. package/hooks/utils/index.js +73 -0
  199. package/{Field → hooks}/utils/package.json +1 -1
  200. package/hooks/utils.d.ts +18 -0
  201. package/hooks/utils.js.map +7 -0
  202. package/index.js +1 -1
  203. package/inputs/AutoCompleteInput/index.d.ts +3 -3
  204. package/inputs/AutoCompleteInput/index.js +1 -3
  205. package/inputs/AutoCompleteInput/index.js.map +2 -2
  206. package/inputs/Checkboxes/index.d.ts +3 -3
  207. package/inputs/Checkboxes/index.js +67 -63
  208. package/inputs/Checkboxes/index.js.map +2 -2
  209. package/inputs/DateInput/index.d.ts +2 -5
  210. package/inputs/DateInput/index.js +10 -5
  211. package/inputs/DateInput/index.js.map +2 -2
  212. package/inputs/DateTimeInput/index.d.ts +2 -5
  213. package/inputs/DateTimeInput/index.js +10 -5
  214. package/inputs/DateTimeInput/index.js.map +2 -2
  215. package/inputs/FileInput/index.d.ts +4 -4
  216. package/inputs/FileInput/index.js +1 -4
  217. package/inputs/FileInput/index.js.map +2 -2
  218. package/inputs/ImageInput/index.d.ts +2 -2
  219. package/inputs/ImageInput/index.js.map +1 -1
  220. package/inputs/Input/index.d.ts +2 -2
  221. package/inputs/Input/index.js +54 -56
  222. package/inputs/Input/index.js.map +2 -2
  223. package/inputs/Label/index.d.ts +1 -1
  224. package/inputs/Label/index.js.map +1 -1
  225. package/inputs/OtpInput/index.d.ts +1 -5
  226. package/inputs/OtpInput/index.js +36 -31
  227. package/inputs/OtpInput/index.js.map +2 -2
  228. package/inputs/Radio/index.d.ts +4 -4
  229. package/inputs/Radio/index.js +5 -4
  230. package/inputs/Radio/index.js.map +3 -3
  231. package/inputs/Select/index.d.ts +2 -2
  232. package/inputs/Select/index.js.map +1 -1
  233. package/{Field/utils → inputs/registry}/index.js +1 -1
  234. package/{locales/el → inputs/registry}/package.json +1 -1
  235. package/{Field/utils/index.d.ts → inputs/registry.d.ts} +2 -1
  236. package/inputs/registry.js.map +7 -0
  237. package/lazy/index.js +10 -9
  238. package/package.json +4 -4
  239. package/registry/index.js +23 -13
  240. package/src/Field/ErrorGroup.tsx +3 -3
  241. package/src/Field/FieldBase.tsx +1 -2
  242. package/src/Field/FieldBaseContainer.tsx +68 -58
  243. package/src/Field/FieldConditional.tsx +1 -1
  244. package/src/Field/index.tsx +15 -33
  245. package/src/Field/types.tsx +11 -12
  246. package/src/Field/utils/evaluateFieldWithConditions.ts +5 -2
  247. package/src/Field/utils/resolveField.ts +58 -0
  248. package/src/Field/utils/useField.ts +3 -1
  249. package/src/FieldArray/BaseFieldArray.tsx +97 -0
  250. package/src/FieldArray/FormDialog/ArrayDisplay/ArrayDisplay.stories.js +11 -0
  251. package/src/FieldArray/FormDialog/ArrayDisplay/ArrayItemDisplay.tsx +165 -0
  252. package/src/FieldArray/FormDialog/ArrayDisplay/ArrayItemHeader.tsx +15 -0
  253. package/src/FieldArray/FormDialog/ArrayDisplay/__stories__/Default.tsx +93 -0
  254. package/src/FieldArray/FormDialog/ArrayDisplay/__stories__/ReadOnly.tsx +79 -0
  255. package/src/FieldArray/FormDialog/ArrayDisplay/__stories__/Sortable.tsx +93 -0
  256. package/src/FieldArray/FormDialog/ArrayDisplay/index.tsx +75 -0
  257. package/src/FieldArray/FormDialog/ArrayEditModal.tsx +233 -0
  258. package/src/FieldArray/FormDialog/index.tsx +247 -0
  259. package/src/FieldArray/__tests__/fieldset-multiplicity.spec.tsx +271 -0
  260. package/src/FieldArray/__tests__/multiplicity-attachment.spec.tsx +280 -0
  261. package/src/FieldArray/__tests__/multiplicity-required.spec.tsx +131 -0
  262. package/src/FieldArray/__tests__/nested-fieldset-multiplicity.spec.tsx +627 -0
  263. package/src/FieldArray/__tests__/preference-multiple-choice.spec.tsx +222 -0
  264. package/src/FieldArray/index.spec.tsx +355 -0
  265. package/src/FieldArray/index.tsx +34 -61
  266. package/src/FieldObject/index.tsx +9 -17
  267. package/src/Fieldset/FieldsetWithContext.tsx +1 -1
  268. package/src/Fieldset/index.tsx +1 -1
  269. package/src/Fieldset/types.tsx +2 -2
  270. package/src/FormBuilder/index.tsx +188 -142
  271. package/src/FormBuilder/scenarios.test.tsx +759 -1
  272. package/src/FormContext.tsx +3 -2
  273. package/src/MultiplicityField/add-objects.tsx +12 -21
  274. package/src/MultiplicityField/index.tsx +3 -2
  275. package/src/MultiplicityField/types.ts +5 -2
  276. package/src/Questions/Questions.tsx +2 -2
  277. package/src/Questions/QuestionsContext.tsx +1 -1
  278. package/src/Questions/Step/Step.tsx +1 -1
  279. package/src/Questions/Step/StepArrayReview.tsx +2 -2
  280. package/src/Questions/Step/StepContext.tsx +1 -1
  281. package/src/Questions/Step/StepDescription.tsx +2 -1
  282. package/src/Questions/Step/StepForm.tsx +2 -2
  283. package/src/Questions/Step/StepQuote.tsx +2 -1
  284. package/src/Questions/Step/StepTitle.tsx +2 -1
  285. package/src/Questions/Step/getAddMoreFields.tsx +2 -2
  286. package/src/Questions/Step/types.tsx +1 -1
  287. package/src/Questions/getNextStep.tsx +1 -1
  288. package/src/Questions/types.tsx +1 -1
  289. package/src/hooks/__tests__/useFieldFocusManager.spec.tsx +1079 -0
  290. package/src/hooks/__tests__/utils.spec.ts +568 -0
  291. package/src/hooks/useFieldFocusManager.ts +162 -0
  292. package/src/hooks/utils.ts +122 -0
  293. package/src/inputs/AutoCompleteInput/index.tsx +4 -6
  294. package/src/inputs/Checkboxes/index.tsx +95 -87
  295. package/src/inputs/DateInput/index.tsx +19 -6
  296. package/src/inputs/DateTimeInput/index.tsx +19 -6
  297. package/src/inputs/FileInput/index.tsx +9 -7
  298. package/src/inputs/ImageInput/index.tsx +2 -2
  299. package/src/inputs/Input/index.tsx +72 -71
  300. package/src/inputs/Label/index.tsx +1 -1
  301. package/src/inputs/OtpInput/index.tsx +43 -34
  302. package/src/inputs/Radio/index.tsx +29 -21
  303. package/src/inputs/Select/index.tsx +2 -2
  304. package/src/{Field/utils/index.ts → inputs/registry.ts} +3 -1
  305. package/src/lazy.js +10 -9
  306. package/src/registry.js +23 -13
  307. package/src/types.tsx +12 -5
  308. package/src/utils.ts +3 -2
  309. package/src/validators/index.ts +10 -9
  310. package/src/validators/types.ts +1 -1
  311. package/src/validators/utils/date.ts +8 -3
  312. package/src/validators/utils/datetime.ts +8 -3
  313. package/src/validators/utils/file.ts +2 -2
  314. package/src/validators/utils/iban.ts +2 -2
  315. package/src/validators/utils/image.ts +2 -2
  316. package/src/validators/utils/index.ts +2 -2
  317. package/src/validators/utils/int.ts +1 -1
  318. package/src/validators/utils/number.ts +1 -1
  319. package/src/validators/utils/otp.ts +2 -2
  320. package/src/validators/utils/phone.ts +2 -2
  321. package/src/validators/utils/postal_code.ts +2 -2
  322. package/src/validators/utils/text_limit.ts +2 -2
  323. package/types.d.ts +8 -4
  324. package/types.js.map +1 -1
  325. package/utils.d.ts +1 -1
  326. package/utils.js.map +2 -2
  327. package/validators/index.d.ts +5 -5
  328. package/validators/index.js.map +2 -2
  329. package/validators/types.d.ts +1 -1
  330. package/validators/utils/date/index.js +6 -1
  331. package/validators/utils/date.d.ts +2 -2
  332. package/validators/utils/date.js.map +2 -2
  333. package/validators/utils/datetime/index.js +6 -1
  334. package/validators/utils/datetime.d.ts +2 -2
  335. package/validators/utils/datetime.js.map +2 -2
  336. package/validators/utils/file.d.ts +2 -2
  337. package/validators/utils/file.js.map +1 -1
  338. package/validators/utils/iban.d.ts +2 -2
  339. package/validators/utils/iban.js.map +1 -1
  340. package/validators/utils/image.d.ts +2 -2
  341. package/validators/utils/image.js.map +1 -1
  342. package/validators/utils/index.d.ts +2 -2
  343. package/validators/utils/index.js.map +1 -1
  344. package/validators/utils/int.d.ts +1 -1
  345. package/validators/utils/int.js.map +1 -1
  346. package/validators/utils/number.d.ts +1 -1
  347. package/validators/utils/number.js.map +1 -1
  348. package/validators/utils/otp.d.ts +2 -2
  349. package/validators/utils/otp.js.map +1 -1
  350. package/validators/utils/phone.d.ts +2 -2
  351. package/validators/utils/phone.js.map +1 -1
  352. package/validators/utils/postal_code.d.ts +2 -2
  353. package/validators/utils/postal_code.js.map +1 -1
  354. package/validators/utils/text_limit.d.ts +2 -2
  355. package/validators/utils/text_limit.js.map +1 -1
  356. package/Field/utils/calculateField/index.js +0 -27
  357. package/Field/utils/calculateField.d.ts +0 -2
  358. package/Field/utils/calculateField.js.map +0 -7
  359. package/Field/utils/index.js.map +0 -7
  360. package/FieldArray/FormDialog.d.ts +0 -67
  361. package/FieldArray/FormDialog.js.map +0 -7
  362. package/FormBuilder/index.test.d.ts +0 -1
  363. package/FormBuilder/interaction.test.d.ts +0 -1
  364. package/FormBuilder/scenarios.test.d.ts +0 -88
  365. package/MultiplicityField/index.test.d.ts +0 -1
  366. package/Questions/index.spec.d.ts +0 -1
  367. package/Questions/index.test.d.ts +0 -1
  368. package/cjs/Field/utils/calculateField/index.js +0 -50
  369. package/cjs/Field/utils/calculateField.js.map +0 -7
  370. package/cjs/Field/utils/index.js.map +0 -7
  371. package/cjs/FieldArray/FormDialog.js.map +0 -7
  372. package/cjs/inputs/inputsScenarios/index.js +0 -533
  373. package/cjs/inputs/inputsScenarios.js.map +0 -7
  374. package/cjs/locales/el.js.map +0 -7
  375. package/inputs/AutoCompleteInput/index.test.d.ts +0 -1
  376. package/inputs/Checkboxes/index.test.d.ts +0 -1
  377. package/inputs/DateInput/index.test.d.ts +0 -1
  378. package/inputs/DateTimeInput/index.test.d.ts +0 -1
  379. package/inputs/FileInput/index.test.d.ts +0 -1
  380. package/inputs/ImageInput/index.test.d.ts +0 -1
  381. package/inputs/Input/index.test.d.ts +0 -1
  382. package/inputs/Label/index.test.d.ts +0 -1
  383. package/inputs/OtpInput/index.test.d.ts +0 -1
  384. package/inputs/Radio/index.test.d.ts +0 -1
  385. package/inputs/Select/index.test.d.ts +0 -1
  386. package/inputs/inputsScenarios/index.js +0 -499
  387. package/inputs/inputsScenarios.d.ts +0 -296
  388. package/inputs/inputsScenarios.js.map +0 -7
  389. package/locales/el/index.js +0 -6
  390. package/locales/el.d.ts +0 -2
  391. package/locales/el.js.map +0 -7
  392. package/src/Field/utils/calculateField.ts +0 -49
  393. package/src/FieldArray/FormDialog.tsx +0 -568
  394. package/src/inputs/inputsScenarios.ts +0 -496
  395. package/src/locales/el.ts +0 -3
  396. /package/{FieldArray/index.test.d.ts → hooks/__tests__/utils.spec.d.ts} +0 -0
@@ -1,6 +1,6 @@
1
1
  import React from 'react';
2
2
  import { useWatch } from 'react-hook-form';
3
- import { UncontrolledFieldProps } from '@digigov/form/Field/types';
3
+ import type { UncontrolledFieldProps } from '@digigov/form/Field/types';
4
4
  import { TextArea } from '@digigov/ui/form/TextArea';
5
5
  import { TextInput } from '@digigov/ui/form/TextInput';
6
6
  import { useTranslation } from '@digigov/ui/i18n';
@@ -30,87 +30,88 @@ export interface InputProps
30
30
  Field?: UncontrolledFieldProps['Field'];
31
31
  }
32
32
 
33
- export const Input: React.ExoticComponent<InputProps> = React.forwardRef(
34
- function WrappedInput({ name, control, type, extra, ...props }, ref: never) {
35
- delete props['Field'];
36
- // eslint-disable-next-line prefer-const
37
- let { multiline = false, rows, limit } = extra || {};
38
- const { className } = extra || {};
39
- // if enforced to multiline use true. Derive from type otherwise.
40
- multiline = multiline === true || type === 'text';
41
- // use explicit rows value if set. Derive from multiline otherwise.
42
- rows = rows || (multiline ? 4 : 1);
43
- // translate dilosi type to HTML Input type
44
- const fieldType = TYPES_MAP[type || 'text'] || 'text';
45
- const { t } = useTranslation();
46
- const currentValue: string | '' = useWatch({ control, name });
33
+ export const Input = React.forwardRef<
34
+ HTMLInputElement | HTMLTextAreaElement,
35
+ InputProps
36
+ >(function WrappedInput({ name, control, type, extra, ...props }, ref) {
37
+ delete props['Field'];
38
+ // eslint-disable-next-line prefer-const
39
+ let { multiline = false, rows, limit } = extra || {};
40
+ const { className } = extra || {};
41
+ // if enforced to multiline use true. Derive from type otherwise.
42
+ multiline = multiline === true || type === 'text';
43
+ // use explicit rows value if set. Derive from multiline otherwise.
44
+ rows = rows || (multiline ? 4 : 1);
45
+ // translate dilosi type to HTML Input type
46
+ const fieldType = TYPES_MAP[type || 'text'] || 'text';
47
+ const { t } = useTranslation();
48
+ const currentValue: string | '' = useWatch({ control, name });
47
49
 
48
- const getRemainingChars = (currentValue, limit) => {
49
- if (currentValue) {
50
- return limit?.max - currentValue.length;
51
- }
52
- return limit?.max;
53
- };
50
+ const getRemainingChars = (currentValue, limit) => {
51
+ if (currentValue) {
52
+ return limit?.max - currentValue.length;
53
+ }
54
+ return limit?.max;
55
+ };
54
56
 
55
- const constructRemainingText = (currentValue, limit) => {
56
- const remainingChars = getRemainingChars(currentValue, limit);
57
- let remainingText =
58
- Math.abs(remainingChars) === 1
59
- ? t('form.info.text.character')
60
- : t('form.info.text.characters');
61
- remainingText +=
62
- remainingChars > 0
63
- ? ` ${t('form.info.text.remaining')}.`
64
- : ` ${t('form.info.text.too_many')}.`;
65
- return remainingText;
66
- };
57
+ const constructRemainingText = (currentValue, limit) => {
58
+ const remainingChars = getRemainingChars(currentValue, limit);
59
+ let remainingText =
60
+ Math.abs(remainingChars) === 1
61
+ ? t('form.info.text.character')
62
+ : t('form.info.text.characters');
63
+ remainingText +=
64
+ remainingChars > 0
65
+ ? ` ${t('form.info.text.remaining')}.`
66
+ : ` ${t('form.info.text.too_many')}.`;
67
+ return remainingText;
68
+ };
67
69
 
68
- if (multiline === true) {
69
- return (
70
- <>
71
- <TextArea
72
- name={name}
73
- className={className}
74
- rows={rows}
75
- ref={ref}
76
- id={name}
77
- {...{
78
- ...props,
79
- reset: undefined,
80
- required: undefined,
81
- type: fieldType,
82
- }}
83
- />
84
- {limit?.max && (
85
- <Hint display={'flex'}>
86
- {t('form.info.text.you_have')}
87
- <Hint fontWeight="bold">
88
- &nbsp;{`${Math.abs(getRemainingChars(currentValue, limit))}`}
89
- &nbsp;
90
- </Hint>
91
- {constructRemainingText(currentValue, limit)}
92
- </Hint>
93
- )}
94
- </>
95
- );
96
- } else {
97
- return (
98
- <TextInput
70
+ if (multiline === true) {
71
+ return (
72
+ <>
73
+ <TextArea
99
74
  name={name}
100
- id={name}
101
- type={fieldType}
102
- data-type={type}
103
75
  className={className}
104
- ref={ref}
76
+ rows={rows}
77
+ ref={ref as React.RefObject<HTMLTextAreaElement>}
78
+ id={name}
105
79
  {...{
106
80
  ...props,
107
81
  reset: undefined,
108
82
  required: undefined,
83
+ type: fieldType,
109
84
  }}
110
85
  />
111
- );
112
- }
86
+ {limit?.max && (
87
+ <Hint display={'flex'}>
88
+ {t('form.info.text.you_have')}
89
+ <Hint fontWeight="bold">
90
+ &nbsp;{`${Math.abs(getRemainingChars(currentValue, limit))}`}
91
+ &nbsp;
92
+ </Hint>
93
+ {constructRemainingText(currentValue, limit)}
94
+ </Hint>
95
+ )}
96
+ </>
97
+ );
98
+ } else {
99
+ return (
100
+ <TextInput
101
+ name={name}
102
+ id={name}
103
+ type={fieldType}
104
+ data-type={type}
105
+ className={className}
106
+ ref={ref as React.RefObject<HTMLInputElement>}
107
+ {...{
108
+ ...props,
109
+ reset: undefined,
110
+ required: undefined,
111
+ }}
112
+ />
113
+ );
113
114
  }
114
- );
115
+ });
115
116
 
116
117
  export default Input;
@@ -1,5 +1,5 @@
1
1
  import React from 'react';
2
- import { FieldLabelProps } from '@digigov/form/types';
2
+ import type { FieldLabelProps } from '@digigov/form/types';
3
3
  import { LabelTitle } from '@digigov/ui/form/LabelContainer';
4
4
  import { useTranslation } from '@digigov/ui/i18n';
5
5
  import { Hint } from '@digigov/ui/typography/Hint';
@@ -120,40 +120,49 @@ export function useOtp(onChange, maxLength) {
120
120
  };
121
121
  }
122
122
 
123
- const SingleCharacterInputPart = ({ ...props }) => {
124
- return <SingleCharacterInput {...props} />;
125
- };
123
+ const SingleCharacterInputPart = React.forwardRef<
124
+ HTMLInputElement,
125
+ Record<string, any>
126
+ >(({ ...props }, ref) => {
127
+ return <SingleCharacterInput {...props} ref={ref} />;
128
+ });
129
+ SingleCharacterInputPart.displayName = 'SingleCharacterInputPart';
126
130
 
127
- export const OtpInput = ({ name, maxLength = 6, ...props }) => {
128
- const otp = useOtp(props.onChange, maxLength);
129
- return (
130
- <SingleCharacterInputs>
131
- {otp.otpValues.map((digit, idx) => (
132
- <SingleCharacterInputPart
133
- name={`${name}-${idx}`}
134
- id={`${name}-${idx}`}
135
- type="text"
136
- key={idx}
137
- autoComplete="one-time-code"
138
- pattern="\d{1}"
139
- maxLength={maxLength}
140
- value={digit}
141
- disabled={props.disabled}
142
- aria-required={props['aria-required']}
143
- onChange={(e) => otp.handleOtpChange(e, idx)}
144
- onInput={(e) => {
145
- if (e.target.value === digit) {
146
- otp.handleOtpChange(e, idx);
147
- }
148
- }}
149
- onKeyDown={(e) => otp.handleKeyDown(e, idx)}
150
- onFocus={otp.handleFocus}
151
- onPaste={otp.handlePaste}
152
- error={!digit ? props.error : false}
153
- />
154
- ))}
155
- </SingleCharacterInputs>
156
- );
157
- };
131
+ export const OtpInput = React.forwardRef<HTMLInputElement, Record<string, any>>(
132
+ ({ name, maxLength = 6, ...props }, ref) => {
133
+ const otp = useOtp(props.onChange, maxLength);
134
+ return (
135
+ <SingleCharacterInputs>
136
+ {otp.otpValues.map((digit, idx) => (
137
+ <SingleCharacterInputPart
138
+ ref={idx === 0 ? ref : null}
139
+ name={`${name}-${idx}`}
140
+ id={`${name}-${idx}`}
141
+ type="text"
142
+ key={idx}
143
+ autoComplete="one-time-code"
144
+ pattern="\d{1}"
145
+ maxLength={maxLength}
146
+ value={digit}
147
+ disabled={props.disabled}
148
+ aria-required={props['aria-required']}
149
+ onChange={(e) => otp.handleOtpChange(e, idx)}
150
+ onInput={(e) => {
151
+ if (e.target.value === digit) {
152
+ otp.handleOtpChange(e, idx);
153
+ }
154
+ }}
155
+ onKeyDown={(e) => otp.handleKeyDown(e, idx)}
156
+ onFocus={otp.handleFocus}
157
+ onPaste={otp.handlePaste}
158
+ error={!digit ? props.error : false}
159
+ />
160
+ ))}
161
+ </SingleCharacterInputs>
162
+ );
163
+ }
164
+ );
165
+
166
+ OtpInput.displayName = 'OtpInput';
158
167
 
159
168
  export default OtpInput;
@@ -1,7 +1,7 @@
1
1
  import React from 'react';
2
2
  import { useWatch } from 'react-hook-form';
3
- import { UncontrolledFieldProps } from '@digigov/form/Field/types';
4
- import { FieldOptionProps } from '@digigov/form/inputs/Label';
3
+ import type { UncontrolledFieldProps } from '@digigov/form/Field/types';
4
+ import type { FieldOptionProps } from '@digigov/form/inputs/Label';
5
5
  import {
6
6
  RadioContainer,
7
7
  RadioItem,
@@ -78,32 +78,40 @@ export const RadioButtonsGroup: React.FC<RadioButtonsGroupProps> = ({
78
78
  </RadioContainer>
79
79
  );
80
80
  };
81
- export const ControlledRadioButtonsGroup: React.FC<
81
+ export const ControlledRadioButtonsGroup = React.forwardRef<
82
+ HTMLInputElement,
82
83
  RadioButtonsGroupProps & { onChange: (e: any) => void; value: any }
83
- > = ({
84
- name,
85
- extra: { options, className },
86
- disabled,
87
- onChange,
88
- value,
89
- Field,
90
- ...props
91
- }) => {
84
+ >(function ControlledRadioButtonsGroup(
85
+ {
86
+ name,
87
+ extra: { options, className },
88
+ disabled,
89
+ onChange,
90
+ value,
91
+ Field,
92
+ ...props
93
+ },
94
+ ref
95
+ ) {
92
96
  const currentValue: string | undefined = value;
93
97
  const { t } = useTranslation();
94
98
  return (
95
99
  <RadioContainer className={className} id={name}>
96
100
  {options.map(
97
- ({
98
- label,
99
- value: v,
100
- show,
101
- disabled: optionDisabled,
102
- selected,
103
- ...option
104
- }) => (
101
+ (
102
+ {
103
+ label,
104
+ value: v,
105
+ show,
106
+ disabled: optionDisabled,
107
+ selected,
108
+ ...option
109
+ },
110
+ index
111
+ ) => (
105
112
  <React.Fragment key={`${name}.${v}`}>
106
113
  <RadioItem
114
+ ref={index === 0 ? ref : undefined}
107
115
  onChange={(e) => {
108
116
  console.log(e);
109
117
  onChange(e);
@@ -139,6 +147,6 @@ export const ControlledRadioButtonsGroup: React.FC<
139
147
  )}
140
148
  </RadioContainer>
141
149
  );
142
- };
150
+ });
143
151
 
144
152
  export default RadioButtonsGroup;
@@ -1,6 +1,6 @@
1
1
  import React from 'react';
2
- import { UncontrolledFieldProps } from '@digigov/form/Field/types';
3
- import { FieldOptionProps } from '@digigov/form/inputs/Label';
2
+ import type { UncontrolledFieldProps } from '@digigov/form/Field/types';
3
+ import type { FieldOptionProps } from '@digigov/form/inputs/Label';
4
4
  import {
5
5
  SelectContainer,
6
6
  SelectOption,
@@ -1,4 +1,4 @@
1
- import { FieldComponentRegistry } from '@digigov/form/Field/types';
1
+ import { type FieldComponentItem } from '@digigov/form/Field/types';
2
2
  import AutoCompleteInput from '@digigov/form/inputs/AutoCompleteInput';
3
3
  import Checkboxes from '@digigov/form/inputs/Checkboxes';
4
4
  import DateInput from '@digigov/form/inputs/DateInput';
@@ -10,6 +10,8 @@ import OtpInput from '@digigov/form/inputs/OtpInput';
10
10
  import Radio, { ControlledRadioButtonsGroup } from '@digigov/form/inputs/Radio';
11
11
  import Select from '@digigov/form/inputs/Select';
12
12
 
13
+ export type FieldComponentRegistry = Record<string, FieldComponentItem>;
14
+
13
15
  export const FIELD_COMPONENTS: FieldComponentRegistry = {
14
16
  text: {
15
17
  component: Input,
package/src/lazy.js CHANGED
@@ -9,10 +9,7 @@ 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
- 'FormDialog': lazy(() => import('@digigov/form/FieldArray/FormDialog').then((module) => ({ default: module['FormDialog'] }))),
13
- 'ArrayItemModal': lazy(() => import('@digigov/form/FieldArray/FormDialog').then((module) => ({ default: module['ArrayItemModal'] }))),
14
- 'ArrayItemHeader': lazy(() => import('@digigov/form/FieldArray/FormDialog').then((module) => ({ default: module['ArrayItemHeader'] }))),
15
- 'ArrayItemDisplay': lazy(() => import('@digigov/form/FieldArray/FormDialog').then((module) => ({ default: module['ArrayItemDisplay'] }))),
12
+ 'BaseFieldArray': lazy(() => import('@digigov/form/FieldArray/BaseFieldArray').then((module) => ({ default: module['BaseFieldArray'] }))),
16
13
  'FieldArray': lazy(() => import('@digigov/form/FieldArray').then((module) => ({ default: module['FieldArray'] }))),
17
14
  'FieldObject': lazy(() => import('@digigov/form/FieldObject').then((module) => ({ default: module['FieldObject'] }))),
18
15
  'FieldsetWithContext': lazy(() => import('@digigov/form/Fieldset/FieldsetWithContext').then((module) => ({ default: module['FieldsetWithContext'] }))),
@@ -45,10 +42,11 @@ export default {
45
42
  'Input': lazy(() => import('@digigov/form/inputs/Input').then((module) => ({ default: module['Input'] }))),
46
43
  'Radio': lazy(() => import('@digigov/form/inputs').then((module) => ({ default: module['Radio'] }))),
47
44
  'Select': lazy(() => import('@digigov/form/inputs/Select').then((module) => ({ default: module['Select'] }))),
48
- 'INPUTS_FIELDS': lazy(() => import('@digigov/form/inputs/inputsScenarios').then((module) => ({ default: module['INPUTS_FIELDS'] }))),
49
- 'FIELD_COMPONENTS': lazy(() => import('@digigov/form/Field/utils').then((module) => ({ default: module['FIELD_COMPONENTS'] }))),
50
- 'ALTERNATIVE_COMPONENTS': lazy(() => import('@digigov/form/Field/utils').then((module) => ({ default: module['ALTERNATIVE_COMPONENTS'] }))),
51
- 'CONTROLLED_FIELD_COMPONENTS': lazy(() => import('@digigov/form/Field/utils').then((module) => ({ default: module['CONTROLLED_FIELD_COMPONENTS'] }))),
45
+ 'FIELD_COMPONENTS': lazy(() => import('@digigov/form/inputs/registry').then((module) => ({ default: module['FIELD_COMPONENTS'] }))),
46
+ 'ALTERNATIVE_COMPONENTS': lazy(() => import('@digigov/form/inputs/registry').then((module) => ({ default: module['ALTERNATIVE_COMPONENTS'] }))),
47
+ 'CONTROLLED_FIELD_COMPONENTS': lazy(() => import('@digigov/form/inputs/registry').then((module) => ({ default: module['CONTROLLED_FIELD_COMPONENTS'] }))),
48
+ 'ArrayEditModal': lazy(() => import('@digigov/form/FieldArray/FormDialog/ArrayEditModal').then((module) => ({ default: module['ArrayEditModal'] }))),
49
+ 'FormDialog': lazy(() => import('@digigov/form/FieldArray/FormDialog').then((module) => ({ default: module['FormDialog'] }))),
52
50
  'AutoCompleteInput': lazy(() => import('@digigov/form/inputs/AutoCompleteInput').then((module) => ({ default: module['AutoCompleteInput'] }))),
53
51
  'DateTimeInput': lazy(() => import('@digigov/form/inputs/DateTimeInput').then((module) => ({ default: module['DateTimeInput'] }))),
54
52
  'Image': lazy(() => import('@digigov/form/inputs/ImageInput').then((module) => ({ default: module['Image'] }))),
@@ -74,5 +72,8 @@ export default {
74
72
  'UUID4_VALIDATOR': lazy(() => import('@digigov/form/validators/utils/uuid4').then((module) => ({ default: module['UUID4_VALIDATOR'] }))),
75
73
  'TEXT_LIMIT_VALIDATOR': lazy(() => import('@digigov/form/validators/utils/text_limit').then((module) => ({ default: module['TEXT_LIMIT_VALIDATOR'] }))),
76
74
  'INT_VALIDATOR': lazy(() => import('@digigov/form/validators/utils/int').then((module) => ({ default: module['INT_VALIDATOR'] }))),
77
- 'NUMBER_VALIDATOR': lazy(() => import('@digigov/form/validators/utils/number').then((module) => ({ default: module['NUMBER_VALIDATOR'] })))
75
+ 'NUMBER_VALIDATOR': lazy(() => import('@digigov/form/validators/utils/number').then((module) => ({ default: module['NUMBER_VALIDATOR'] }))),
76
+ 'ArrayItemDisplay': lazy(() => import('@digigov/form/FieldArray/FormDialog/ArrayDisplay/ArrayItemDisplay').then((module) => ({ default: module['ArrayItemDisplay'] }))),
77
+ 'ArrayItemHeader': lazy(() => import('@digigov/form/FieldArray/FormDialog/ArrayDisplay/ArrayItemHeader').then((module) => ({ default: module['ArrayItemHeader'] }))),
78
+ 'ArrayDisplay': lazy(() => import('@digigov/form/FieldArray/FormDialog/ArrayDisplay').then((module) => ({ default: module['ArrayDisplay'] })))
78
79
  };
package/src/registry.js CHANGED
@@ -10,7 +10,7 @@ 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_FieldArray_FormDialog from "@digigov/form/FieldArray/FormDialog";
13
+ import * as _digigov_form_FieldArray_BaseFieldArray from "@digigov/form/FieldArray/BaseFieldArray";
14
14
  import * as _digigov_form_FieldArray from "@digigov/form/FieldArray";
15
15
  import * as _digigov_form_FieldObject from "@digigov/form/FieldObject";
16
16
  import * as _digigov_form_Fieldset_FieldsetWithContext from "@digigov/form/Fieldset/FieldsetWithContext";
@@ -25,15 +25,17 @@ import * as _digigov_form_Questions_QuestionsContext from "@digigov/form/Questio
25
25
  import * as _digigov_form_Questions_getNextStep from "@digigov/form/Questions/getNextStep";
26
26
  import * as _digigov_form_Questions from "@digigov/form/Questions";
27
27
  import * as _digigov_form_Questions_types from "@digigov/form/Questions/types";
28
+ import * as _digigov_form_hooks_useFieldFocusManager from "@digigov/form/hooks/useFieldFocusManager";
29
+ import * as _digigov_form_hooks_utils from "@digigov/form/hooks/utils";
28
30
  import * as _digigov_form_inputs from "@digigov/form/inputs";
29
- import * as _digigov_form_inputs_inputsScenarios from "@digigov/form/inputs/inputsScenarios";
30
- import * as _digigov_form_locales_el from "@digigov/form/locales/el";
31
+ import * as _digigov_form_inputs_registry from "@digigov/form/inputs/registry";
31
32
  import * as _digigov_form_validators from "@digigov/form/validators";
32
33
  import * as _digigov_form_validators_types from "@digigov/form/validators/types";
33
- import * as _digigov_form_Field_utils_calculateField from "@digigov/form/Field/utils/calculateField";
34
34
  import * as _digigov_form_Field_utils_evaluateFieldWithConditions from "@digigov/form/Field/utils/evaluateFieldWithConditions";
35
- import * as _digigov_form_Field_utils from "@digigov/form/Field/utils";
35
+ import * as _digigov_form_Field_utils_resolveField from "@digigov/form/Field/utils/resolveField";
36
36
  import * as _digigov_form_Field_utils_useField from "@digigov/form/Field/utils/useField";
37
+ import * as _digigov_form_FieldArray_FormDialog_ArrayEditModal from "@digigov/form/FieldArray/FormDialog/ArrayEditModal";
38
+ import * as _digigov_form_FieldArray_FormDialog from "@digigov/form/FieldArray/FormDialog";
37
39
  import * as _digigov_form_Questions_Step_ReviewStep from "@digigov/form/Questions/Step/ReviewStep";
38
40
  import * as _digigov_form_Questions_Step_Step from "@digigov/form/Questions/Step/Step";
39
41
  import * as _digigov_form_Questions_Step_StepArrayReview from "@digigov/form/Questions/Step/StepArrayReview";
@@ -45,8 +47,8 @@ import * as _digigov_form_Questions_Step_StepTitle from "@digigov/form/Questions
45
47
  import * as _digigov_form_Questions_Step_getAddMoreFields from "@digigov/form/Questions/Step/getAddMoreFields";
46
48
  import * as _digigov_form_Questions_Step from "@digigov/form/Questions/Step";
47
49
  import * as _digigov_form_Questions_Step_types from "@digigov/form/Questions/Step/types";
48
- import * as _digigov_form_inputs_AutoCompleteInput from "@digigov/form/inputs/AutoCompleteInput";
49
50
  import * as _digigov_form_inputs_Checkboxes from "@digigov/form/inputs/Checkboxes";
51
+ import * as _digigov_form_inputs_AutoCompleteInput from "@digigov/form/inputs/AutoCompleteInput";
50
52
  import * as _digigov_form_inputs_DateInput from "@digigov/form/inputs/DateInput";
51
53
  import * as _digigov_form_inputs_DateTimeInput from "@digigov/form/inputs/DateTimeInput";
52
54
  import * as _digigov_form_inputs_FileInput from "@digigov/form/inputs/FileInput";
@@ -71,6 +73,9 @@ import * as _digigov_form_validators_utils_phone from "@digigov/form/validators/
71
73
  import * as _digigov_form_validators_utils_postal_code from "@digigov/form/validators/utils/postal_code";
72
74
  import * as _digigov_form_validators_utils_text_limit from "@digigov/form/validators/utils/text_limit";
73
75
  import * as _digigov_form_validators_utils_uuid4 from "@digigov/form/validators/utils/uuid4";
76
+ import * as _digigov_form_FieldArray_FormDialog_ArrayDisplay_ArrayItemDisplay from "@digigov/form/FieldArray/FormDialog/ArrayDisplay/ArrayItemDisplay";
77
+ import * as _digigov_form_FieldArray_FormDialog_ArrayDisplay_ArrayItemHeader from "@digigov/form/FieldArray/FormDialog/ArrayDisplay/ArrayItemHeader";
78
+ import * as _digigov_form_FieldArray_FormDialog_ArrayDisplay from "@digigov/form/FieldArray/FormDialog/ArrayDisplay";
74
79
  function lazyImport(pkgImport) {
75
80
  return new Proxy(
76
81
  {},
@@ -101,7 +106,7 @@ export default {
101
106
  '@digigov/form/Field/FieldConditional': lazyImport(_digigov_form_Field_FieldConditional),
102
107
  '@digigov/form/Field': lazyImport(_digigov_form_Field),
103
108
  '@digigov/form/Field/types': lazyImport(_digigov_form_Field_types),
104
- '@digigov/form/FieldArray/FormDialog': lazyImport(_digigov_form_FieldArray_FormDialog),
109
+ '@digigov/form/FieldArray/BaseFieldArray': lazyImport(_digigov_form_FieldArray_BaseFieldArray),
105
110
  '@digigov/form/FieldArray': lazyImport(_digigov_form_FieldArray),
106
111
  '@digigov/form/FieldObject': lazyImport(_digigov_form_FieldObject),
107
112
  '@digigov/form/Fieldset/FieldsetWithContext': lazyImport(_digigov_form_Fieldset_FieldsetWithContext),
@@ -116,15 +121,17 @@ export default {
116
121
  '@digigov/form/Questions/getNextStep': lazyImport(_digigov_form_Questions_getNextStep),
117
122
  '@digigov/form/Questions': lazyImport(_digigov_form_Questions),
118
123
  '@digigov/form/Questions/types': lazyImport(_digigov_form_Questions_types),
124
+ '@digigov/form/hooks/useFieldFocusManager': lazyImport(_digigov_form_hooks_useFieldFocusManager),
125
+ '@digigov/form/hooks/utils': lazyImport(_digigov_form_hooks_utils),
119
126
  '@digigov/form/inputs': lazyImport(_digigov_form_inputs),
120
- '@digigov/form/inputs/inputsScenarios': lazyImport(_digigov_form_inputs_inputsScenarios),
121
- '@digigov/form/locales/el': lazyImport(_digigov_form_locales_el),
127
+ '@digigov/form/inputs/registry': lazyImport(_digigov_form_inputs_registry),
122
128
  '@digigov/form/validators': lazyImport(_digigov_form_validators),
123
129
  '@digigov/form/validators/types': lazyImport(_digigov_form_validators_types),
124
- '@digigov/form/Field/utils/calculateField': lazyImport(_digigov_form_Field_utils_calculateField),
125
130
  '@digigov/form/Field/utils/evaluateFieldWithConditions': lazyImport(_digigov_form_Field_utils_evaluateFieldWithConditions),
126
- '@digigov/form/Field/utils': lazyImport(_digigov_form_Field_utils),
131
+ '@digigov/form/Field/utils/resolveField': lazyImport(_digigov_form_Field_utils_resolveField),
127
132
  '@digigov/form/Field/utils/useField': lazyImport(_digigov_form_Field_utils_useField),
133
+ '@digigov/form/FieldArray/FormDialog/ArrayEditModal': lazyImport(_digigov_form_FieldArray_FormDialog_ArrayEditModal),
134
+ '@digigov/form/FieldArray/FormDialog': lazyImport(_digigov_form_FieldArray_FormDialog),
128
135
  '@digigov/form/Questions/Step/ReviewStep': lazyImport(_digigov_form_Questions_Step_ReviewStep),
129
136
  '@digigov/form/Questions/Step/Step': lazyImport(_digigov_form_Questions_Step_Step),
130
137
  '@digigov/form/Questions/Step/StepArrayReview': lazyImport(_digigov_form_Questions_Step_StepArrayReview),
@@ -136,8 +143,8 @@ export default {
136
143
  '@digigov/form/Questions/Step/getAddMoreFields': lazyImport(_digigov_form_Questions_Step_getAddMoreFields),
137
144
  '@digigov/form/Questions/Step': lazyImport(_digigov_form_Questions_Step),
138
145
  '@digigov/form/Questions/Step/types': lazyImport(_digigov_form_Questions_Step_types),
139
- '@digigov/form/inputs/AutoCompleteInput': lazyImport(_digigov_form_inputs_AutoCompleteInput),
140
146
  '@digigov/form/inputs/Checkboxes': lazyImport(_digigov_form_inputs_Checkboxes),
147
+ '@digigov/form/inputs/AutoCompleteInput': lazyImport(_digigov_form_inputs_AutoCompleteInput),
141
148
  '@digigov/form/inputs/DateInput': lazyImport(_digigov_form_inputs_DateInput),
142
149
  '@digigov/form/inputs/DateTimeInput': lazyImport(_digigov_form_inputs_DateTimeInput),
143
150
  '@digigov/form/inputs/FileInput': lazyImport(_digigov_form_inputs_FileInput),
@@ -161,5 +168,8 @@ export default {
161
168
  '@digigov/form/validators/utils/phone': lazyImport(_digigov_form_validators_utils_phone),
162
169
  '@digigov/form/validators/utils/postal_code': lazyImport(_digigov_form_validators_utils_postal_code),
163
170
  '@digigov/form/validators/utils/text_limit': lazyImport(_digigov_form_validators_utils_text_limit),
164
- '@digigov/form/validators/utils/uuid4': lazyImport(_digigov_form_validators_utils_uuid4)
171
+ '@digigov/form/validators/utils/uuid4': lazyImport(_digigov_form_validators_utils_uuid4),
172
+ '@digigov/form/FieldArray/FormDialog/ArrayDisplay/ArrayItemDisplay': lazyImport(_digigov_form_FieldArray_FormDialog_ArrayDisplay_ArrayItemDisplay),
173
+ '@digigov/form/FieldArray/FormDialog/ArrayDisplay/ArrayItemHeader': lazyImport(_digigov_form_FieldArray_FormDialog_ArrayDisplay_ArrayItemHeader),
174
+ '@digigov/form/FieldArray/FormDialog/ArrayDisplay': lazyImport(_digigov_form_FieldArray_FormDialog_ArrayDisplay)
165
175
  };
package/src/types.tsx CHANGED
@@ -1,11 +1,11 @@
1
- import { UseFormReturn, UseFormProps, ErrorOption } from 'react-hook-form';
2
- import {
3
- FieldComponentRegistry,
1
+ import type { UseFormReturn, UseFormProps, ErrorOption } from 'react-hook-form';
2
+ import type {
4
3
  FieldLabelProps,
5
4
  FieldSpec,
6
5
  FormData,
7
6
  } from '@digigov/form/Field/types';
8
- import { ValidatorSchema } from '@digigov/form/validators/types';
7
+ import type { FieldComponentRegistry } from '@digigov/form/inputs/registry';
8
+ import type { ValidatorSchema } from '@digigov/form/validators/types';
9
9
  export * from '@digigov/form/Field/types';
10
10
  export interface FieldError {
11
11
  message: string;
@@ -18,6 +18,11 @@ export interface FieldsetSpec {
18
18
  body?: React.ReactNode;
19
19
  }
20
20
 
21
+ export type registerFieldFocus = (
22
+ fieldName: string,
23
+ element: HTMLElement
24
+ ) => (name: string) => void;
25
+
21
26
  export interface FormContextProps {
22
27
  fieldsetsMap?: Record<string, FieldsetSpec>;
23
28
  fieldsMap: Record<string, FieldSpec>;
@@ -29,14 +34,16 @@ export interface FormContextProps {
29
34
  getFieldState: UseFormReturn['getFieldState'];
30
35
  setValue: UseFormReturn['setValue'];
31
36
  getValues: UseFormReturn['getValues'];
37
+ getValuesFromParentForm?: UseFormReturn['getValues'];
32
38
  unregister: UseFormReturn['unregister'];
33
39
  formState: UseFormReturn['formState'];
34
40
  reset: UseFormReturn['reset'];
35
41
  resetField: UseFormReturn['resetField'];
36
42
  registerField: (field: FieldSpec) => void;
43
+ registerFieldFocus: registerFieldFocus;
37
44
  errors: UseFormReturn['formState']['errors'];
38
45
  componentRegistry?: FieldComponentRegistry;
39
- submit: () => Promise<void>;
46
+ submit: () => Promise<void> | void;
40
47
  }
41
48
 
42
49
  export interface FormBuilderProps {
package/src/utils.ts CHANGED
@@ -1,6 +1,7 @@
1
1
  import { validateFieldsNatively } from '@hookform/resolvers';
2
- import { appendErrors, FieldError } from 'react-hook-form';
3
- import * as Yup from 'yup';
2
+ import type { FieldError } from 'react-hook-form';
3
+ import { appendErrors } from 'react-hook-form';
4
+ import type * as Yup from 'yup';
4
5
 
5
6
  /**
6
7
  * Why `path!` ? because it could be `undefined` in some case
@@ -1,13 +1,14 @@
1
- import { MutableRefObject, useMemo } from 'react';
1
+ import type { MutableRefObject } from 'react';
2
+ import { useMemo } from 'react';
2
3
  import * as yup from 'yup';
3
- import { AnyObjectSchema, StringSchema } from 'yup';
4
- import { RequiredArraySchema } from 'yup/lib/array';
5
- import Lazy from 'yup/lib/Lazy';
6
- import { MixedSchema } from 'yup/lib/mixed';
7
- import { TypeOfShape, AssertsShape } from 'yup/lib/object';
8
- import { AnyObject } from 'yup/lib/types';
9
- import { FieldSpec } from '@digigov/form/types';
10
- import { ValidatorSchema } from '@digigov/form/validators/types';
4
+ import type { AnyObjectSchema, StringSchema } from 'yup';
5
+ import type { RequiredArraySchema } from 'yup/lib/array';
6
+ import type Lazy from 'yup/lib/Lazy';
7
+ import type { MixedSchema } from 'yup/lib/mixed';
8
+ import type { TypeOfShape, AssertsShape } from 'yup/lib/object';
9
+ import type { AnyObject } from 'yup/lib/types';
10
+ import type { FieldSpec } from '@digigov/form/types';
11
+ import type { ValidatorSchema } from '@digigov/form/validators/types';
11
12
  import {
12
13
  getYupObjectShape,
13
14
  AFM_VALIDATOR,
@@ -1,2 +1,2 @@
1
- import * as yup from 'yup';
1
+ import type * as yup from 'yup';
2
2
  export type ValidatorSchema = yup.TestConfig;
@@ -1,12 +1,13 @@
1
1
  import dayjs from 'dayjs';
2
2
  import customParseFormat from 'dayjs/plugin/customParseFormat';
3
- import { FieldSpec } from '@digigov/form/types';
4
- import { ValidatorSchema } from '@digigov/form/validators/types';
3
+ import type { FieldSpec } from '@digigov/form/types';
4
+ import type { ValidatorSchema } from '@digigov/form/validators/types';
5
5
 
6
6
  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);
@@ -40,7 +41,11 @@ const checkPartialDate = (value: string) => {
40
41
  if (day && month) {
41
42
  const dayNum = parseInt(day);
42
43
  const monthNum = parseInt(month);
43
- const yearNum = parseInt(year);
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);
44
49
  const maxDay = getDaysInMonth(monthNum, yearNum);
45
50
  if (dayNum < 1 || dayNum > maxDay) {
46
51
  return {