@digigov/form 2.0.0-a402a664 → 2.0.0-a64dc016

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 (715) hide show
  1. package/Field/ErrorGroup.d.ts +4 -4
  2. package/Field/ErrorGroup.js +53 -0
  3. package/Field/FieldBase.d.ts +1 -1
  4. package/Field/FieldBase.js +77 -0
  5. package/Field/FieldBaseContainer.d.ts +2 -2
  6. package/Field/FieldBaseContainer.js +43 -0
  7. package/Field/FieldConditional.d.ts +1 -1
  8. package/Field/FieldConditional.js +45 -0
  9. package/Field/index.d.ts +1 -1
  10. package/Field/index.js +70 -118
  11. package/Field/types.d.ts +14 -11
  12. package/Field/types.js +0 -0
  13. package/Field/utils/evaluateFieldWithConditions.d.ts +2 -2
  14. package/Field/utils/evaluateFieldWithConditions.js +19 -0
  15. package/Field/utils/resolveField.d.ts +3 -0
  16. package/Field/utils/resolveField.js +32 -0
  17. package/Field/utils/useField.d.ts +1 -1
  18. package/Field/utils/useField.js +47 -0
  19. package/FieldArray/BaseFieldArray.d.ts +5 -0
  20. package/FieldArray/BaseFieldArray.js +46 -0
  21. package/FieldArray/FormDialog/ArrayDisplay/ArrayContainerDisplay.d.ts +9 -0
  22. package/FieldArray/FormDialog/ArrayDisplay/ArrayContainerDisplay.js +13 -0
  23. package/FieldArray/FormDialog/ArrayDisplay/ArrayItemDisplay.d.ts +26 -0
  24. package/FieldArray/FormDialog/ArrayDisplay/ArrayItemDisplay.js +117 -0
  25. package/FieldArray/FormDialog/ArrayDisplay/ArrayItemHeader.d.ts +5 -0
  26. package/FieldArray/FormDialog/ArrayDisplay/ArrayItemHeader.js +6 -0
  27. package/FieldArray/FormDialog/ArrayDisplay/index.d.ts +15 -0
  28. package/FieldArray/FormDialog/ArrayDisplay/index.js +32 -0
  29. package/FieldArray/FormDialog/ArrayEditModal.d.ts +24 -0
  30. package/FieldArray/FormDialog/ArrayEditModal.js +138 -0
  31. package/FieldArray/FormDialog/index.d.ts +19 -0
  32. package/FieldArray/FormDialog/index.js +184 -382
  33. package/FieldArray/index.d.ts +4 -2
  34. package/FieldArray/index.js +61 -110
  35. package/FieldObject/index.d.ts +4 -4
  36. package/FieldObject/index.js +52 -84
  37. package/Fieldset/FieldsetWithContext.js +27 -0
  38. package/Fieldset/index.d.ts +1 -1
  39. package/Fieldset/index.js +18 -30
  40. package/Fieldset/types.d.ts +2 -2
  41. package/Fieldset/types.js +0 -0
  42. package/FormBuilder/index.d.ts +2 -2
  43. package/FormBuilder/index.js +233 -236
  44. package/FormContext.d.ts +2 -2
  45. package/FormContext.js +7 -0
  46. package/MultiplicityField/add-objects.d.ts +2 -2
  47. package/MultiplicityField/add-objects.js +107 -0
  48. package/MultiplicityField/index.d.ts +2 -2
  49. package/MultiplicityField/index.js +81 -119
  50. package/MultiplicityField/types.d.ts +2 -2
  51. package/MultiplicityField/types.js +0 -0
  52. package/Questions/Questions.d.ts +1 -1
  53. package/Questions/Questions.js +48 -0
  54. package/Questions/QuestionsContext.d.ts +1 -1
  55. package/Questions/QuestionsContext.js +10 -0
  56. package/Questions/Step/ReviewStep.js +32 -0
  57. package/Questions/Step/Step.d.ts +1 -1
  58. package/Questions/Step/Step.js +39 -0
  59. package/Questions/Step/StepArrayReview.d.ts +1 -1
  60. package/Questions/Step/StepArrayReview.js +35 -0
  61. package/Questions/Step/StepContext.d.ts +1 -1
  62. package/Questions/Step/StepContext.js +28 -0
  63. package/Questions/Step/StepDescription.d.ts +1 -1
  64. package/Questions/Step/StepDescription.js +18 -0
  65. package/Questions/Step/StepForm.d.ts +2 -2
  66. package/Questions/Step/StepForm.js +29 -0
  67. package/Questions/Step/StepQuote.d.ts +1 -1
  68. package/Questions/Step/StepQuote.js +5 -0
  69. package/Questions/Step/StepTitle.d.ts +1 -1
  70. package/Questions/Step/StepTitle.js +25 -0
  71. package/Questions/Step/getAddMoreFields.d.ts +2 -2
  72. package/Questions/Step/getAddMoreFields.js +24 -0
  73. package/Questions/Step/index.d.ts +11 -11
  74. package/Questions/Step/index.js +13 -16
  75. package/Questions/Step/types.d.ts +1 -1
  76. package/Questions/Step/types.js +0 -0
  77. package/Questions/getNextStep.d.ts +1 -1
  78. package/Questions/getNextStep.js +13 -0
  79. package/Questions/index.d.ts +2 -2
  80. package/Questions/index.js +4 -7
  81. package/Questions/types.d.ts +1 -1
  82. package/Questions/types.js +0 -0
  83. package/hooks/useFieldFocusManager.d.ts +25 -0
  84. package/hooks/useFieldFocusManager.js +83 -0
  85. package/hooks/utils.d.ts +18 -0
  86. package/hooks/utils.js +60 -0
  87. package/index.d.ts +5 -5
  88. package/index.js +8 -13
  89. package/inputs/AutoCompleteInput/index.d.ts +3 -3
  90. package/inputs/AutoCompleteInput/index.js +38 -62
  91. package/inputs/Checkboxes/index.d.ts +5 -3
  92. package/inputs/Checkboxes/index.js +50 -78
  93. package/inputs/DateInput/index.d.ts +2 -5
  94. package/inputs/DateInput/index.js +124 -128
  95. package/inputs/DateTimeInput/index.d.ts +2 -5
  96. package/inputs/DateTimeInput/index.js +178 -182
  97. package/inputs/FileInput/index.d.ts +8 -4
  98. package/inputs/FileInput/index.js +56 -65
  99. package/inputs/ImageInput/index.d.ts +2 -2
  100. package/inputs/ImageInput/index.js +74 -74
  101. package/inputs/Input/index.d.ts +3 -1
  102. package/inputs/Input/index.js +60 -69
  103. package/inputs/Label/index.d.ts +1 -1
  104. package/inputs/Label/index.js +13 -16
  105. package/inputs/OtpInput/index.d.ts +1 -5
  106. package/inputs/OtpInput/index.js +117 -141
  107. package/inputs/Radio/index.d.ts +6 -4
  108. package/inputs/Radio/index.js +71 -102
  109. package/inputs/Select/index.d.ts +4 -2
  110. package/inputs/Select/index.js +23 -32
  111. package/inputs/index.d.ts +9 -9
  112. package/inputs/index.js +10 -21
  113. package/{Field/utils/index.d.ts → inputs/registry.d.ts} +2 -1
  114. package/inputs/registry.js +80 -0
  115. package/internal.d.ts +5 -5
  116. package/internal.js +6 -0
  117. package/lazy.d.ts +97 -0
  118. package/lazy.js +163 -0
  119. package/package.json +8 -8
  120. package/registry.d.ts +82 -0
  121. package/registry.js +170 -0
  122. package/src/Field/ErrorGroup.tsx +4 -4
  123. package/src/Field/FieldBase.tsx +4 -3
  124. package/src/Field/FieldBaseContainer.tsx +68 -51
  125. package/src/Field/FieldConditional.tsx +1 -1
  126. package/src/Field/index.tsx +16 -36
  127. package/src/Field/types.tsx +14 -12
  128. package/src/Field/utils/evaluateFieldWithConditions.ts +5 -2
  129. package/src/Field/utils/resolveField.ts +58 -0
  130. package/src/Field/utils/useField.ts +3 -1
  131. package/src/FieldArray/BaseFieldArray.tsx +97 -0
  132. package/src/FieldArray/FieldArray.stories.js +1 -0
  133. package/src/FieldArray/FormDialog/ArrayDisplay/ArrayContainerDisplay.tsx +45 -0
  134. package/src/FieldArray/FormDialog/ArrayDisplay/ArrayDisplay.stories.js +14 -0
  135. package/src/FieldArray/FormDialog/ArrayDisplay/ArrayItemDisplay.tsx +337 -0
  136. package/src/FieldArray/FormDialog/ArrayDisplay/ArrayItemHeader.tsx +15 -0
  137. package/src/FieldArray/FormDialog/ArrayDisplay/__stories__/Cards.tsx +88 -0
  138. package/src/FieldArray/FormDialog/ArrayDisplay/__stories__/Default.tsx +93 -0
  139. package/src/FieldArray/FormDialog/ArrayDisplay/__stories__/ReadOnly.tsx +79 -0
  140. package/src/FieldArray/FormDialog/ArrayDisplay/__stories__/ReadOnlyCards.tsx +75 -0
  141. package/src/FieldArray/FormDialog/ArrayDisplay/__stories__/Sortable.tsx +93 -0
  142. package/src/FieldArray/FormDialog/ArrayDisplay/__stories__/SortableCards.tsx +88 -0
  143. package/src/FieldArray/FormDialog/ArrayDisplay/index.test.tsx +44 -0
  144. package/src/FieldArray/FormDialog/ArrayDisplay/index.tsx +67 -0
  145. package/src/FieldArray/FormDialog/ArrayEditModal.tsx +241 -0
  146. package/src/FieldArray/FormDialog/index.tsx +302 -0
  147. package/src/FieldArray/__stories__/CardsWithError.tsx +124 -0
  148. package/src/FieldArray/__tests__/fieldset-multiplicity.spec.tsx +271 -0
  149. package/src/FieldArray/__tests__/multiplicity-attachment.spec.tsx +280 -0
  150. package/src/FieldArray/__tests__/multiplicity-optional.spec.tsx +232 -0
  151. package/src/FieldArray/__tests__/multiplicity-required.spec.tsx +170 -0
  152. package/src/FieldArray/__tests__/nested-fieldset-multiplicity.spec.tsx +627 -0
  153. package/src/FieldArray/__tests__/preference-multiple-choice.spec.tsx +222 -0
  154. package/src/FieldArray/index.spec.tsx +355 -0
  155. package/src/FieldArray/index.test.tsx +4 -0
  156. package/src/FieldArray/index.tsx +43 -63
  157. package/src/FieldObject/index.tsx +9 -17
  158. package/src/Fieldset/FieldsetWithContext.tsx +1 -1
  159. package/src/Fieldset/index.tsx +1 -1
  160. package/src/Fieldset/types.tsx +2 -2
  161. package/src/FormBuilder/doc.mdx +1 -1
  162. package/src/FormBuilder/index.tsx +190 -145
  163. package/src/FormBuilder/scenarios.test.tsx +802 -5
  164. package/src/FormContext.tsx +3 -2
  165. package/src/MultiplicityField/__stories__/PreviewDisplay.tsx +1 -3
  166. package/src/MultiplicityField/add-objects.tsx +12 -21
  167. package/src/MultiplicityField/index.tsx +3 -2
  168. package/src/MultiplicityField/types.ts +5 -2
  169. package/src/Questions/Questions.tsx +2 -2
  170. package/src/Questions/QuestionsContext.tsx +1 -1
  171. package/src/Questions/Step/Step.tsx +1 -1
  172. package/src/Questions/Step/StepArrayReview.tsx +2 -2
  173. package/src/Questions/Step/StepContext.tsx +1 -1
  174. package/src/Questions/Step/StepDescription.tsx +2 -1
  175. package/src/Questions/Step/StepForm.tsx +2 -2
  176. package/src/Questions/Step/StepQuote.tsx +2 -1
  177. package/src/Questions/Step/StepTitle.tsx +2 -1
  178. package/src/Questions/Step/getAddMoreFields.tsx +2 -2
  179. package/src/Questions/Step/types.tsx +1 -1
  180. package/src/Questions/getNextStep.tsx +1 -1
  181. package/src/Questions/types.tsx +1 -1
  182. package/src/hooks/__tests__/useFieldFocusManager.spec.tsx +1079 -0
  183. package/src/hooks/__tests__/utils.spec.ts +568 -0
  184. package/src/hooks/useFieldFocusManager.ts +162 -0
  185. package/src/hooks/utils.ts +122 -0
  186. package/src/inputs/AutoCompleteInput/doc.mdx +2 -2
  187. package/src/inputs/AutoCompleteInput/index.tsx +4 -6
  188. package/src/inputs/Checkboxes/doc.mdx +3 -3
  189. package/src/inputs/Checkboxes/index.tsx +98 -91
  190. package/src/inputs/DateInput/DateInput.stories.js +4 -0
  191. package/src/inputs/DateInput/__stories__/WithDefaultValue.tsx +26 -0
  192. package/src/inputs/DateInput/__stories__/WithInitialValue.tsx +28 -0
  193. package/src/inputs/DateInput/__stories__/WithWrongDefaultValue.tsx +26 -0
  194. package/src/inputs/DateInput/__stories__/WithWrongInitialValue.tsx +28 -0
  195. package/src/inputs/DateInput/doc.mdx +1 -1
  196. package/src/inputs/DateInput/index.test.tsx +16 -0
  197. package/src/inputs/DateInput/index.tsx +49 -18
  198. package/src/inputs/DateTimeInput/DateTimeInput.stories.js +9 -6
  199. package/src/inputs/DateTimeInput/__stories__/WithDefaultValue.tsx +26 -0
  200. package/src/inputs/DateTimeInput/__stories__/WithInitialValue.tsx +28 -0
  201. package/src/inputs/DateTimeInput/__stories__/WithWrongDefaultValue.tsx +26 -0
  202. package/src/inputs/DateTimeInput/__stories__/WithWrongInitialValue.tsx +28 -0
  203. package/src/inputs/DateTimeInput/doc.mdx +1 -1
  204. package/src/inputs/DateTimeInput/index.test.tsx +16 -0
  205. package/src/inputs/DateTimeInput/index.tsx +77 -40
  206. package/src/inputs/FileInput/doc.mdx +1 -1
  207. package/src/inputs/FileInput/index.tsx +68 -43
  208. package/src/inputs/ImageInput/doc.mdx +3 -3
  209. package/src/inputs/ImageInput/index.tsx +6 -6
  210. package/src/inputs/Input/Input.stories.js +1 -0
  211. package/src/inputs/Input/__stories__/Rate.tsx +25 -0
  212. package/src/inputs/Input/doc.mdx +10 -10
  213. package/src/inputs/Input/index.test.tsx +4 -0
  214. package/src/inputs/Input/index.tsx +15 -8
  215. package/src/inputs/Label/doc.mdx +1 -1
  216. package/src/inputs/Label/index.tsx +1 -1
  217. package/src/inputs/OtpInput/doc.mdx +1 -1
  218. package/src/inputs/OtpInput/index.tsx +43 -34
  219. package/src/inputs/Radio/doc.mdx +3 -3
  220. package/src/inputs/Radio/index.tsx +33 -22
  221. package/src/inputs/Select/doc.mdx +1 -1
  222. package/src/inputs/Select/index.tsx +6 -4
  223. package/src/{Field/utils/index.ts → inputs/registry.ts} +3 -1
  224. package/{lazy/index.js → src/lazy.ts} +7 -29
  225. package/{registry/index.js → src/registry.ts} +29 -15
  226. package/src/types.tsx +13 -5
  227. package/src/utils.ts +14 -2
  228. package/src/validators/index.ts +34 -12
  229. package/src/validators/types.ts +1 -1
  230. package/src/validators/utils/date.ts +30 -6
  231. package/src/validators/utils/datetime.ts +123 -31
  232. package/src/validators/utils/email.ts +11 -0
  233. package/src/validators/utils/file.ts +2 -2
  234. package/src/validators/utils/iban.ts +2 -2
  235. package/src/validators/utils/image.ts +2 -2
  236. package/src/validators/utils/index.ts +9 -5
  237. package/src/validators/utils/int.ts +1 -1
  238. package/src/validators/utils/number.ts +1 -1
  239. package/src/validators/utils/otp.ts +2 -2
  240. package/src/validators/utils/phone.ts +2 -2
  241. package/src/validators/utils/postal_code.ts +2 -2
  242. package/src/validators/utils/text_limit.ts +2 -2
  243. package/types.d.ts +10 -5
  244. package/types.js +1 -0
  245. package/utils.d.ts +2 -1
  246. package/utils.js +56 -0
  247. package/validators/index.d.ts +5 -5
  248. package/validators/index.js +112 -145
  249. package/validators/types.d.ts +1 -1
  250. package/validators/types.js +0 -0
  251. package/validators/utils/afm.js +19 -0
  252. package/validators/utils/amka.js +27 -0
  253. package/validators/utils/date.d.ts +3 -3
  254. package/validators/utils/date.js +95 -0
  255. package/validators/utils/datetime.d.ts +3 -3
  256. package/validators/utils/datetime.js +121 -0
  257. package/validators/utils/email.d.ts +5 -0
  258. package/validators/utils/email.js +10 -0
  259. package/validators/utils/file.d.ts +2 -2
  260. package/validators/utils/file.js +31 -0
  261. package/validators/utils/iban.d.ts +2 -2
  262. package/validators/utils/iban.js +104 -0
  263. package/validators/utils/image.d.ts +2 -2
  264. package/validators/utils/image.js +65 -0
  265. package/validators/utils/index.d.ts +14 -14
  266. package/validators/utils/index.js +59 -93
  267. package/validators/utils/int.d.ts +1 -1
  268. package/validators/utils/int.js +13 -0
  269. package/validators/utils/number.d.ts +1 -1
  270. package/validators/utils/number.js +12 -0
  271. package/validators/utils/otp.d.ts +2 -2
  272. package/validators/utils/otp.js +21 -0
  273. package/validators/utils/phone.d.ts +2 -2
  274. package/validators/utils/phone.js +198 -0
  275. package/validators/utils/postal_code.d.ts +2 -2
  276. package/validators/utils/postal_code.js +18 -0
  277. package/validators/utils/text_limit.d.ts +2 -2
  278. package/validators/utils/text_limit.js +34 -0
  279. package/validators/utils/uuid4.js +14 -0
  280. package/Field/ErrorGroup/index.js +0 -48
  281. package/Field/ErrorGroup/package.json +0 -6
  282. package/Field/ErrorGroup.js.map +0 -7
  283. package/Field/FieldBase/index.js +0 -121
  284. package/Field/FieldBase/package.json +0 -6
  285. package/Field/FieldBase.js.map +0 -7
  286. package/Field/FieldBaseContainer/index.js +0 -35
  287. package/Field/FieldBaseContainer/package.json +0 -6
  288. package/Field/FieldBaseContainer.js.map +0 -7
  289. package/Field/FieldConditional/index.js +0 -89
  290. package/Field/FieldConditional/package.json +0 -6
  291. package/Field/FieldConditional.js.map +0 -7
  292. package/Field/index.js.map +0 -7
  293. package/Field/package.json +0 -6
  294. package/Field/types/index.js +0 -1
  295. package/Field/types/package.json +0 -6
  296. package/Field/types.js.map +0 -7
  297. package/Field/utils/calculateField/index.js +0 -27
  298. package/Field/utils/calculateField/package.json +0 -6
  299. package/Field/utils/calculateField.d.ts +0 -2
  300. package/Field/utils/calculateField.js.map +0 -7
  301. package/Field/utils/evaluateFieldWithConditions/index.js +0 -26
  302. package/Field/utils/evaluateFieldWithConditions/package.json +0 -6
  303. package/Field/utils/evaluateFieldWithConditions.js.map +0 -7
  304. package/Field/utils/index.js +0 -86
  305. package/Field/utils/index.js.map +0 -7
  306. package/Field/utils/package.json +0 -6
  307. package/Field/utils/useField/index.js +0 -64
  308. package/Field/utils/useField/package.json +0 -6
  309. package/Field/utils/useField.js.map +0 -7
  310. package/FieldArray/FieldArray.stories.d.ts +0 -10
  311. package/FieldArray/FormDialog/package.json +0 -6
  312. package/FieldArray/FormDialog.d.ts +0 -66
  313. package/FieldArray/FormDialog.js.map +0 -7
  314. package/FieldArray/__stories__/Default.d.ts +0 -2
  315. package/FieldArray/__stories__/WithExactLength.d.ts +0 -2
  316. package/FieldArray/__stories__/WithModal.d.ts +0 -2
  317. package/FieldArray/index.js.map +0 -7
  318. package/FieldArray/index.test.d.ts +0 -1
  319. package/FieldArray/package.json +0 -6
  320. package/FieldObject/index.js.map +0 -7
  321. package/FieldObject/package.json +0 -6
  322. package/Fieldset/FieldsetWithContext/index.js +0 -31
  323. package/Fieldset/FieldsetWithContext/package.json +0 -6
  324. package/Fieldset/FieldsetWithContext.js.map +0 -7
  325. package/Fieldset/index.js.map +0 -7
  326. package/Fieldset/package.json +0 -6
  327. package/Fieldset/types/index.js +0 -1
  328. package/Fieldset/types/package.json +0 -6
  329. package/Fieldset/types.js.map +0 -7
  330. package/Form.stories.d.ts +0 -4
  331. package/FormBuilder/FormBuilder.stories.d.ts +0 -12
  332. package/FormBuilder/__stories__/AutoErrorGrouping.d.ts +0 -3
  333. package/FormBuilder/__stories__/Default.d.ts +0 -3
  334. package/FormBuilder/__stories__/ErrorGrouping.d.ts +0 -3
  335. package/FormBuilder/index.js.map +0 -7
  336. package/FormBuilder/index.test.d.ts +0 -1
  337. package/FormBuilder/interaction.test.d.ts +0 -1
  338. package/FormBuilder/package.json +0 -6
  339. package/FormBuilder/scenarios.test.d.ts +0 -88
  340. package/FormContext/index.js +0 -13
  341. package/FormContext/package.json +0 -6
  342. package/FormContext.js.map +0 -7
  343. package/MultiplicityField/MultiplicityField.stories.d.ts +0 -15
  344. package/MultiplicityField/__stories__/Default.d.ts +0 -2
  345. package/MultiplicityField/__stories__/PreviewDisplay.d.ts +0 -2
  346. package/MultiplicityField/__stories__/WithExactLength.d.ts +0 -2
  347. package/MultiplicityField/__stories__/WithMaxLength.d.ts +0 -2
  348. package/MultiplicityField/__stories__/WithMinAndMaxLength.d.ts +0 -2
  349. package/MultiplicityField/__stories__/WithMinLength.d.ts +0 -2
  350. package/MultiplicityField/add-objects/index.js +0 -155
  351. package/MultiplicityField/add-objects/package.json +0 -6
  352. package/MultiplicityField/add-objects.js.map +0 -7
  353. package/MultiplicityField/index.js.map +0 -7
  354. package/MultiplicityField/index.test.d.ts +0 -1
  355. package/MultiplicityField/package.json +0 -6
  356. package/MultiplicityField/types/index.js +0 -1
  357. package/MultiplicityField/types/package.json +0 -6
  358. package/MultiplicityField/types.js.map +0 -7
  359. package/Questions/Questions/index.js +0 -67
  360. package/Questions/Questions/package.json +0 -6
  361. package/Questions/Questions.js.map +0 -7
  362. package/Questions/Questions.stories.d.ts +0 -10
  363. package/Questions/QuestionsContext/index.js +0 -11
  364. package/Questions/QuestionsContext/package.json +0 -6
  365. package/Questions/QuestionsContext.js.map +0 -7
  366. package/Questions/Step/ReviewStep/index.js +0 -38
  367. package/Questions/Step/ReviewStep/package.json +0 -6
  368. package/Questions/Step/ReviewStep.js.map +0 -7
  369. package/Questions/Step/Step/index.js +0 -54
  370. package/Questions/Step/Step/package.json +0 -6
  371. package/Questions/Step/Step.js.map +0 -7
  372. package/Questions/Step/StepArrayReview/index.js +0 -42
  373. package/Questions/Step/StepArrayReview/package.json +0 -6
  374. package/Questions/Step/StepArrayReview.js.map +0 -7
  375. package/Questions/Step/StepContext/index.js +0 -23
  376. package/Questions/Step/StepContext/package.json +0 -6
  377. package/Questions/Step/StepContext.js.map +0 -7
  378. package/Questions/Step/StepDescription/index.js +0 -24
  379. package/Questions/Step/StepDescription/package.json +0 -6
  380. package/Questions/Step/StepDescription.js.map +0 -7
  381. package/Questions/Step/StepForm/index.js +0 -34
  382. package/Questions/Step/StepForm/package.json +0 -6
  383. package/Questions/Step/StepForm.js.map +0 -7
  384. package/Questions/Step/StepQuote/index.js +0 -11
  385. package/Questions/Step/StepQuote/package.json +0 -6
  386. package/Questions/Step/StepQuote.js.map +0 -7
  387. package/Questions/Step/StepTitle/index.js +0 -44
  388. package/Questions/Step/StepTitle/package.json +0 -6
  389. package/Questions/Step/StepTitle.js.map +0 -7
  390. package/Questions/Step/getAddMoreFields/index.js +0 -29
  391. package/Questions/Step/getAddMoreFields/package.json +0 -6
  392. package/Questions/Step/getAddMoreFields.js.map +0 -7
  393. package/Questions/Step/index.js.map +0 -7
  394. package/Questions/Step/package.json +0 -6
  395. package/Questions/Step/types/index.js +0 -1
  396. package/Questions/Step/types/package.json +0 -6
  397. package/Questions/Step/types.js.map +0 -7
  398. package/Questions/__stories__/Default.d.ts +0 -3
  399. package/Questions/getNextStep/index.js +0 -22
  400. package/Questions/getNextStep/package.json +0 -6
  401. package/Questions/getNextStep.js.map +0 -7
  402. package/Questions/index.js.map +0 -7
  403. package/Questions/index.spec.d.ts +0 -1
  404. package/Questions/index.test.d.ts +0 -1
  405. package/Questions/package.json +0 -6
  406. package/Questions/types/index.js +0 -1
  407. package/Questions/types/package.json +0 -6
  408. package/Questions/types.js.map +0 -7
  409. package/cjs/Field/ErrorGroup/index.js +0 -82
  410. package/cjs/Field/ErrorGroup.js.map +0 -7
  411. package/cjs/Field/FieldBase/index.js +0 -154
  412. package/cjs/Field/FieldBase.js.map +0 -7
  413. package/cjs/Field/FieldBaseContainer/index.js +0 -68
  414. package/cjs/Field/FieldBaseContainer.js.map +0 -7
  415. package/cjs/Field/FieldConditional/index.js +0 -122
  416. package/cjs/Field/FieldConditional.js.map +0 -7
  417. package/cjs/Field/index.js +0 -150
  418. package/cjs/Field/index.js.map +0 -7
  419. package/cjs/Field/types/index.js +0 -16
  420. package/cjs/Field/types.js.map +0 -7
  421. package/cjs/Field/utils/calculateField/index.js +0 -50
  422. package/cjs/Field/utils/calculateField.js.map +0 -7
  423. package/cjs/Field/utils/evaluateFieldWithConditions/index.js +0 -49
  424. package/cjs/Field/utils/evaluateFieldWithConditions.js.map +0 -7
  425. package/cjs/Field/utils/index.js +0 -121
  426. package/cjs/Field/utils/index.js.map +0 -7
  427. package/cjs/Field/utils/useField/index.js +0 -87
  428. package/cjs/Field/utils/useField.js.map +0 -7
  429. package/cjs/FieldArray/FormDialog/index.js +0 -416
  430. package/cjs/FieldArray/FormDialog.js.map +0 -7
  431. package/cjs/FieldArray/index.js +0 -148
  432. package/cjs/FieldArray/index.js.map +0 -7
  433. package/cjs/FieldObject/index.js +0 -117
  434. package/cjs/FieldObject/index.js.map +0 -7
  435. package/cjs/Fieldset/FieldsetWithContext/index.js +0 -59
  436. package/cjs/Fieldset/FieldsetWithContext.js.map +0 -7
  437. package/cjs/Fieldset/index.js +0 -66
  438. package/cjs/Fieldset/index.js.map +0 -7
  439. package/cjs/Fieldset/types/index.js +0 -16
  440. package/cjs/Fieldset/types.js.map +0 -7
  441. package/cjs/FormBuilder/index.js +0 -278
  442. package/cjs/FormBuilder/index.js.map +0 -7
  443. package/cjs/FormContext/index.js +0 -37
  444. package/cjs/FormContext.js.map +0 -7
  445. package/cjs/MultiplicityField/add-objects/index.js +0 -183
  446. package/cjs/MultiplicityField/add-objects.js.map +0 -7
  447. package/cjs/MultiplicityField/index.js +0 -153
  448. package/cjs/MultiplicityField/index.js.map +0 -7
  449. package/cjs/MultiplicityField/types/index.js +0 -16
  450. package/cjs/MultiplicityField/types.js.map +0 -7
  451. package/cjs/Questions/Questions/index.js +0 -100
  452. package/cjs/Questions/Questions.js.map +0 -7
  453. package/cjs/Questions/QuestionsContext/index.js +0 -34
  454. package/cjs/Questions/QuestionsContext.js.map +0 -7
  455. package/cjs/Questions/Step/ReviewStep/index.js +0 -65
  456. package/cjs/Questions/Step/ReviewStep.js.map +0 -7
  457. package/cjs/Questions/Step/Step/index.js +0 -87
  458. package/cjs/Questions/Step/Step.js.map +0 -7
  459. package/cjs/Questions/Step/StepArrayReview/index.js +0 -67
  460. package/cjs/Questions/Step/StepArrayReview.js.map +0 -7
  461. package/cjs/Questions/Step/StepContext/index.js +0 -46
  462. package/cjs/Questions/Step/StepContext.js.map +0 -7
  463. package/cjs/Questions/Step/StepDescription/index.js +0 -58
  464. package/cjs/Questions/Step/StepDescription.js.map +0 -7
  465. package/cjs/Questions/Step/StepForm/index.js +0 -67
  466. package/cjs/Questions/Step/StepForm.js.map +0 -7
  467. package/cjs/Questions/Step/StepQuote/index.js +0 -44
  468. package/cjs/Questions/Step/StepQuote.js.map +0 -7
  469. package/cjs/Questions/Step/StepTitle/index.js +0 -76
  470. package/cjs/Questions/Step/StepTitle.js.map +0 -7
  471. package/cjs/Questions/Step/getAddMoreFields/index.js +0 -52
  472. package/cjs/Questions/Step/getAddMoreFields.js.map +0 -7
  473. package/cjs/Questions/Step/index.js +0 -59
  474. package/cjs/Questions/Step/index.js.map +0 -7
  475. package/cjs/Questions/Step/types/index.js +0 -16
  476. package/cjs/Questions/Step/types.js.map +0 -7
  477. package/cjs/Questions/getNextStep/index.js +0 -45
  478. package/cjs/Questions/getNextStep.js.map +0 -7
  479. package/cjs/Questions/index.js +0 -31
  480. package/cjs/Questions/index.js.map +0 -7
  481. package/cjs/Questions/types/index.js +0 -16
  482. package/cjs/Questions/types.js.map +0 -7
  483. package/cjs/index.js +0 -49
  484. package/cjs/index.js.map +0 -7
  485. package/cjs/inputs/AutoCompleteInput/index.js +0 -98
  486. package/cjs/inputs/AutoCompleteInput/index.js.map +0 -7
  487. package/cjs/inputs/Checkboxes/index.js +0 -107
  488. package/cjs/inputs/Checkboxes/index.js.map +0 -7
  489. package/cjs/inputs/DateInput/index.js +0 -168
  490. package/cjs/inputs/DateInput/index.js.map +0 -7
  491. package/cjs/inputs/DateTimeInput/index.js +0 -224
  492. package/cjs/inputs/DateTimeInput/index.js.map +0 -7
  493. package/cjs/inputs/FileInput/index.js +0 -100
  494. package/cjs/inputs/FileInput/index.js.map +0 -7
  495. package/cjs/inputs/ImageInput/__stories__/logo.d/index.js +0 -1
  496. package/cjs/inputs/ImageInput/__stories__/logo.d.js.map +0 -7
  497. package/cjs/inputs/ImageInput/index.js +0 -130
  498. package/cjs/inputs/ImageInput/index.js.map +0 -7
  499. package/cjs/inputs/Input/index.js +0 -111
  500. package/cjs/inputs/Input/index.js.map +0 -7
  501. package/cjs/inputs/Label/index.js +0 -50
  502. package/cjs/inputs/Label/index.js.map +0 -7
  503. package/cjs/inputs/OtpInput/index.js +0 -181
  504. package/cjs/inputs/OtpInput/index.js.map +0 -7
  505. package/cjs/inputs/Radio/index.js +0 -134
  506. package/cjs/inputs/Radio/index.js.map +0 -7
  507. package/cjs/inputs/Select/index.js +0 -63
  508. package/cjs/inputs/Select/index.js.map +0 -7
  509. package/cjs/inputs/index.js +0 -62
  510. package/cjs/inputs/index.js.map +0 -7
  511. package/cjs/inputs/inputsScenarios/index.js +0 -533
  512. package/cjs/inputs/inputsScenarios.js.map +0 -7
  513. package/cjs/internal/index.js +0 -38
  514. package/cjs/internal.js.map +0 -7
  515. package/cjs/lazy/index.js +0 -111
  516. package/cjs/lazy.js.map +0 -7
  517. package/cjs/locales/el/index.js +0 -35
  518. package/cjs/locales/el.js.map +0 -7
  519. package/cjs/registry/index.js +0 -195
  520. package/cjs/registry.js.map +0 -7
  521. package/cjs/types/index.js +0 -22
  522. package/cjs/types.js.map +0 -7
  523. package/cjs/utils/index.js +0 -97
  524. package/cjs/utils.js.map +0 -7
  525. package/cjs/validators/index.js +0 -165
  526. package/cjs/validators/index.js.map +0 -7
  527. package/cjs/validators/types/index.js +0 -16
  528. package/cjs/validators/types.js.map +0 -7
  529. package/cjs/validators/utils/afm/index.js +0 -55
  530. package/cjs/validators/utils/afm.js.map +0 -7
  531. package/cjs/validators/utils/amka/index.js +0 -60
  532. package/cjs/validators/utils/amka.js.map +0 -7
  533. package/cjs/validators/utils/date/index.js +0 -138
  534. package/cjs/validators/utils/date.js.map +0 -7
  535. package/cjs/validators/utils/datetime/index.js +0 -151
  536. package/cjs/validators/utils/datetime.js.map +0 -7
  537. package/cjs/validators/utils/file/index.js +0 -61
  538. package/cjs/validators/utils/file.js.map +0 -7
  539. package/cjs/validators/utils/iban/index.js +0 -142
  540. package/cjs/validators/utils/iban.js.map +0 -7
  541. package/cjs/validators/utils/image/index.js +0 -102
  542. package/cjs/validators/utils/image.js.map +0 -7
  543. package/cjs/validators/utils/index.js +0 -148
  544. package/cjs/validators/utils/index.js.map +0 -7
  545. package/cjs/validators/utils/int/index.js +0 -48
  546. package/cjs/validators/utils/int.js.map +0 -7
  547. package/cjs/validators/utils/number/index.js +0 -44
  548. package/cjs/validators/utils/number.js.map +0 -7
  549. package/cjs/validators/utils/otp/index.js +0 -54
  550. package/cjs/validators/utils/otp.js.map +0 -7
  551. package/cjs/validators/utils/phone/index.js +0 -198
  552. package/cjs/validators/utils/phone.js.map +0 -7
  553. package/cjs/validators/utils/postal_code/index.js +0 -54
  554. package/cjs/validators/utils/postal_code.js.map +0 -7
  555. package/cjs/validators/utils/text_limit/index.js +0 -69
  556. package/cjs/validators/utils/text_limit.js.map +0 -7
  557. package/cjs/validators/utils/uuid4/index.js +0 -46
  558. package/cjs/validators/utils/uuid4.js.map +0 -7
  559. package/index.js.map +0 -7
  560. package/inputs/AutoCompleteInput/AutoComplete.stories.d.ts +0 -11
  561. package/inputs/AutoCompleteInput/__stories__/Default.d.ts +0 -3
  562. package/inputs/AutoCompleteInput/__stories__/Multiple.d.ts +0 -3
  563. package/inputs/AutoCompleteInput/index.js.map +0 -7
  564. package/inputs/AutoCompleteInput/index.test.d.ts +0 -1
  565. package/inputs/AutoCompleteInput/package.json +0 -6
  566. package/inputs/Checkboxes/Checkboxes.stories.d.ts +0 -12
  567. package/inputs/Checkboxes/__stories__/Conditional.d.ts +0 -3
  568. package/inputs/Checkboxes/__stories__/Default.d.ts +0 -3
  569. package/inputs/Checkboxes/__stories__/WithDivider.d.ts +0 -3
  570. package/inputs/Checkboxes/index.js.map +0 -7
  571. package/inputs/Checkboxes/index.test.d.ts +0 -1
  572. package/inputs/Checkboxes/package.json +0 -6
  573. package/inputs/DateInput/DateInput.stories.d.ts +0 -10
  574. package/inputs/DateInput/__stories__/Default.d.ts +0 -3
  575. package/inputs/DateInput/index.js.map +0 -7
  576. package/inputs/DateInput/index.test.d.ts +0 -1
  577. package/inputs/DateInput/package.json +0 -6
  578. package/inputs/DateTimeInput/DateTimeInput.stories.d.ts +0 -9
  579. package/inputs/DateTimeInput/__stories__/Default.d.ts +0 -3
  580. package/inputs/DateTimeInput/index.js.map +0 -7
  581. package/inputs/DateTimeInput/index.test.d.ts +0 -1
  582. package/inputs/DateTimeInput/package.json +0 -6
  583. package/inputs/FileInput/FileInput.stories.d.ts +0 -11
  584. package/inputs/FileInput/__stories__/Default.d.ts +0 -3
  585. package/inputs/FileInput/__stories__/WithBorderAndLink.d.ts +0 -3
  586. package/inputs/FileInput/index.js.map +0 -7
  587. package/inputs/FileInput/index.test.d.ts +0 -1
  588. package/inputs/FileInput/package.json +0 -6
  589. package/inputs/ImageInput/ImageInput.stories.d.ts +0 -13
  590. package/inputs/ImageInput/__stories__/Default.d.ts +0 -3
  591. package/inputs/ImageInput/__stories__/MaxSize.d.ts +0 -3
  592. package/inputs/ImageInput/__stories__/WithInitialValues.d.ts +0 -3
  593. package/inputs/ImageInput/__stories__/WithInvalidImageDimension.d.ts +0 -3
  594. package/inputs/ImageInput/__stories__/logo.d/index.js +0 -1
  595. package/inputs/ImageInput/__stories__/logo.d/package.json +0 -6
  596. package/inputs/ImageInput/__stories__/logo.d.js.map +0 -7
  597. package/inputs/ImageInput/index.js.map +0 -7
  598. package/inputs/ImageInput/index.test.d.ts +0 -1
  599. package/inputs/ImageInput/package.json +0 -6
  600. package/inputs/Input/Input.stories.d.ts +0 -22
  601. package/inputs/Input/__stories__/AFM.d.ts +0 -3
  602. package/inputs/Input/__stories__/AMKA.d.ts +0 -3
  603. package/inputs/Input/__stories__/Boolean.d.ts +0 -3
  604. package/inputs/Input/__stories__/Email.d.ts +0 -3
  605. package/inputs/Input/__stories__/IBAN.d.ts +0 -3
  606. package/inputs/Input/__stories__/Integer.d.ts +0 -3
  607. package/inputs/Input/__stories__/LandlineNumber.d.ts +0 -3
  608. package/inputs/Input/__stories__/MobilePhone.d.ts +0 -3
  609. package/inputs/Input/__stories__/PhoneNumber.d.ts +0 -3
  610. package/inputs/Input/__stories__/PostalCode.d.ts +0 -3
  611. package/inputs/Input/__stories__/String.d.ts +0 -3
  612. package/inputs/Input/__stories__/StringWithTrimValidation.d.ts +0 -3
  613. package/inputs/Input/__stories__/TextWithLimit.d.ts +0 -3
  614. package/inputs/Input/index.js.map +0 -7
  615. package/inputs/Input/index.test.d.ts +0 -1
  616. package/inputs/Input/package.json +0 -6
  617. package/inputs/Label/Label.stories.d.ts +0 -10
  618. package/inputs/Label/__stories__/Default.d.ts +0 -3
  619. package/inputs/Label/index.js.map +0 -7
  620. package/inputs/Label/index.test.d.ts +0 -1
  621. package/inputs/Label/package.json +0 -6
  622. package/inputs/OtpInput/OtpInput.stories.d.ts +0 -10
  623. package/inputs/OtpInput/__stories__/Default.d.ts +0 -3
  624. package/inputs/OtpInput/index.js.map +0 -7
  625. package/inputs/OtpInput/index.test.d.ts +0 -1
  626. package/inputs/OtpInput/package.json +0 -6
  627. package/inputs/Radio/Radio.stories.d.ts +0 -12
  628. package/inputs/Radio/__stories__/Conditional.d.ts +0 -3
  629. package/inputs/Radio/__stories__/Default.d.ts +0 -3
  630. package/inputs/Radio/__stories__/WithDivider.d.ts +0 -3
  631. package/inputs/Radio/index.js.map +0 -7
  632. package/inputs/Radio/index.test.d.ts +0 -1
  633. package/inputs/Radio/package.json +0 -6
  634. package/inputs/Select/Select.stories.d.ts +0 -10
  635. package/inputs/Select/__stories__/Default.d.ts +0 -3
  636. package/inputs/Select/index.js.map +0 -7
  637. package/inputs/Select/index.test.d.ts +0 -1
  638. package/inputs/Select/package.json +0 -6
  639. package/inputs/index.js.map +0 -7
  640. package/inputs/inputsScenarios/index.js +0 -499
  641. package/inputs/inputsScenarios/package.json +0 -6
  642. package/inputs/inputsScenarios.d.ts +0 -296
  643. package/inputs/inputsScenarios.js.map +0 -7
  644. package/inputs/package.json +0 -6
  645. package/internal/index.js +0 -10
  646. package/internal/package.json +0 -6
  647. package/internal.js.map +0 -7
  648. package/lazy/package.json +0 -6
  649. package/locales/el/index.js +0 -6
  650. package/locales/el/package.json +0 -6
  651. package/locales/el.d.ts +0 -2
  652. package/locales/el.js.map +0 -7
  653. package/registry/package.json +0 -6
  654. package/src/Field/utils/calculateField.ts +0 -49
  655. package/src/FieldArray/FormDialog.tsx +0 -565
  656. package/src/inputs/inputsScenarios.ts +0 -496
  657. package/src/lazy.js +0 -78
  658. package/src/locales/el.ts +0 -3
  659. package/src/registry.js +0 -165
  660. package/types/index.js +0 -2
  661. package/types/package.json +0 -6
  662. package/types.js.map +0 -7
  663. package/utils/index.js +0 -74
  664. package/utils/package.json +0 -6
  665. package/utils.js.map +0 -7
  666. package/validators/index.js.map +0 -7
  667. package/validators/package.json +0 -6
  668. package/validators/types/index.js +0 -1
  669. package/validators/types/package.json +0 -6
  670. package/validators/types.js.map +0 -7
  671. package/validators/utils/afm/index.js +0 -31
  672. package/validators/utils/afm/package.json +0 -6
  673. package/validators/utils/afm.js.map +0 -7
  674. package/validators/utils/amka/index.js +0 -36
  675. package/validators/utils/amka/package.json +0 -6
  676. package/validators/utils/amka.js.map +0 -7
  677. package/validators/utils/date/index.js +0 -103
  678. package/validators/utils/date/package.json +0 -6
  679. package/validators/utils/date.js.map +0 -7
  680. package/validators/utils/datetime/index.js +0 -116
  681. package/validators/utils/datetime/package.json +0 -6
  682. package/validators/utils/datetime.js.map +0 -7
  683. package/validators/utils/file/index.js +0 -38
  684. package/validators/utils/file/package.json +0 -6
  685. package/validators/utils/file.js.map +0 -7
  686. package/validators/utils/iban/index.js +0 -118
  687. package/validators/utils/iban/package.json +0 -6
  688. package/validators/utils/iban.js.map +0 -7
  689. package/validators/utils/image/index.js +0 -79
  690. package/validators/utils/image/package.json +0 -6
  691. package/validators/utils/image.js.map +0 -7
  692. package/validators/utils/index.js.map +0 -7
  693. package/validators/utils/int/index.js +0 -24
  694. package/validators/utils/int/package.json +0 -6
  695. package/validators/utils/int.js.map +0 -7
  696. package/validators/utils/number/index.js +0 -20
  697. package/validators/utils/number/package.json +0 -6
  698. package/validators/utils/number.js.map +0 -7
  699. package/validators/utils/otp/index.js +0 -30
  700. package/validators/utils/otp/package.json +0 -6
  701. package/validators/utils/otp.js.map +0 -7
  702. package/validators/utils/package.json +0 -6
  703. package/validators/utils/phone/index.js +0 -172
  704. package/validators/utils/phone/package.json +0 -6
  705. package/validators/utils/phone.js.map +0 -7
  706. package/validators/utils/postal_code/index.js +0 -30
  707. package/validators/utils/postal_code/package.json +0 -6
  708. package/validators/utils/postal_code.js.map +0 -7
  709. package/validators/utils/text_limit/index.js +0 -45
  710. package/validators/utils/text_limit/package.json +0 -6
  711. package/validators/utils/text_limit.js.map +0 -7
  712. package/validators/utils/uuid4/index.js +0 -22
  713. package/validators/utils/uuid4/package.json +0 -6
  714. package/validators/utils/uuid4.js.map +0 -7
  715. package/validators/validators.spec.d.ts +0 -1
@@ -0,0 +1,162 @@
1
+ import { useCallback, useEffect, useRef } from 'react';
2
+ import type { Control, FieldValues, Ref, UseFormReturn } from 'react-hook-form';
3
+ import {
4
+ extractFieldEntries,
5
+ mapElementsToFields,
6
+ sortElementsByPosition,
7
+ } from '@digigov/form/hooks/utils';
8
+
9
+ export interface UseFieldFocusManagerProps<T extends FieldValues> {
10
+ enabled?: boolean;
11
+ control: Control<T>;
12
+ subscribe: UseFormReturn['subscribe'];
13
+ setFocus: UseFormReturn['setFocus'];
14
+ }
15
+
16
+ /**
17
+ * Custom hook to manage focus on form fields.
18
+ *
19
+ * It collects all focusable elements from the form fields and sorts them according to their position in the DOM.
20
+ */
21
+ export function useFieldFocusManager<T extends FieldValues>({
22
+ enabled = true,
23
+ control,
24
+ subscribe,
25
+ setFocus,
26
+ }: UseFieldFocusManagerProps<T>) {
27
+ /** Array to hold any external focusable elements registered by the user */
28
+ const customFocusableElements = useRef(new Map<string, HTMLElement>());
29
+ /** Map to hold focusable elements by field name */
30
+ const focusableElements = useRef(new Map<string, Ref>());
31
+
32
+ // When disabled, clear custom focusable elements and focusable elements map
33
+ useEffect(() => {
34
+ if (!enabled) {
35
+ customFocusableElements.current.clear();
36
+ focusableElements.current.clear();
37
+ return;
38
+ }
39
+ }, [enabled]);
40
+
41
+ const updateFocusableElements = useCallback(() => {
42
+ // Clear existing focusable elements
43
+ focusableElements.current.clear();
44
+ // Extract from form fields
45
+ const formElements = extractFieldEntries(control._fields);
46
+ // Extract from custom elements (convert to FieldRefs format first)
47
+ const customFieldRefs = mapElementsToFields(
48
+ customFocusableElements.current
49
+ );
50
+ const customElements = extractFieldEntries(customFieldRefs);
51
+
52
+ // Combine both maps
53
+ const combinedElements = new Map(formElements);
54
+ customElements.forEach((element, fieldName) => {
55
+ combinedElements.set(fieldName, element);
56
+ });
57
+
58
+ // Sort once by DOM position
59
+ focusableElements.current = sortElementsByPosition(combinedElements);
60
+ }, [control._fields]);
61
+
62
+ // Register / unregister custom focusable elements
63
+ const registerCustomFocusableElement = useCallback(
64
+ (fieldName: string, element: HTMLElement) => {
65
+ if (fieldName && element) {
66
+ customFocusableElements.current.set(fieldName, element);
67
+ updateFocusableElements();
68
+ }
69
+
70
+ return function unregister() {
71
+ customFocusableElements.current.delete(fieldName);
72
+ updateFocusableElements();
73
+ };
74
+ },
75
+ [updateFocusableElements]
76
+ );
77
+
78
+ // Collect focusable elements when fields change
79
+ useEffect(() => {
80
+ if (!enabled || !subscribe) return;
81
+ const callback = subscribe({
82
+ formState: {
83
+ errors: true,
84
+ // Subscribe to any form state change that might indicate field structure changes
85
+ },
86
+ callback: () => {
87
+ // Defer to next tick to ensure DOM is updated
88
+ setTimeout(updateFocusableElements, 0);
89
+ },
90
+ });
91
+
92
+ // Initial update
93
+ updateFocusableElements();
94
+
95
+ return () => callback();
96
+ }, [enabled, updateFocusableElements, subscribe]);
97
+
98
+ // Subscribe to errors and focus the first field (according to the DOM) with an error
99
+ const focusOnError = useCallback(
100
+ (errors: Record<string, any>) => {
101
+ if (!enabled) return;
102
+ if (!errors || Object.keys(errors).length === 0) return;
103
+ for (const [fieldName, element] of Array.from(
104
+ focusableElements.current
105
+ )) {
106
+ if (hasFieldError(errors, fieldName)) {
107
+ if (element && typeof element.focus === 'function') {
108
+ element.focus(); // Focus the element directly
109
+ return;
110
+ } else if (element && element.name) {
111
+ setFocus(fieldName); // Field is registered with react-hook-form
112
+ return;
113
+ }
114
+ }
115
+ }
116
+ },
117
+ [enabled, setFocus]
118
+ );
119
+
120
+ return {
121
+ /**
122
+ * Registers a custom focusable element with the given field name.
123
+ *
124
+ * Returns a callback function to unregister the element by field name.
125
+ *
126
+ * @param fieldName - The name of the field to associate with the element.
127
+ * @param element - The HTML element to register as focusable.
128
+ */
129
+ registerCustomFocusableElement,
130
+ focusOnError,
131
+ };
132
+ }
133
+
134
+ // Helper function to check for nested field errors
135
+ function hasFieldError(
136
+ errors: Record<string, any>,
137
+ fieldName: string
138
+ ): boolean {
139
+ if (!errors || typeof errors !== 'object') return false;
140
+
141
+ // Handle direct field names first
142
+ if (errors[fieldName]) {
143
+ return true;
144
+ }
145
+
146
+ // Split the field name and traverse the error object
147
+ const keys = fieldName.split(/[.[\]]+/).filter(Boolean);
148
+ let current = errors;
149
+
150
+ for (const key of keys) {
151
+ if (current && typeof current === 'object') {
152
+ current = current[key];
153
+ } else {
154
+ return false;
155
+ }
156
+ }
157
+
158
+ // Check if we found a truthy error value
159
+ return !!current;
160
+ }
161
+
162
+ export default useFieldFocusManager;
@@ -0,0 +1,122 @@
1
+ import type { Field, FieldRefs, Ref } from 'react-hook-form';
2
+
3
+ /**
4
+ * Recursively extracts field entries from nested form field structure.
5
+ * Handles both regular nested objects and array-like structures.
6
+ */
7
+ export function extractFieldEntries(
8
+ fields: FieldRefs,
9
+ prefix = ''
10
+ ): Map<string, Ref> {
11
+ const elementMap = new Map<string, Ref>();
12
+
13
+ const fieldEntries = Object.entries(fields);
14
+ if (fieldEntries.length === 0) return elementMap;
15
+
16
+ Object.entries(fields).forEach(([fieldName, field]) => {
17
+ if (!field) return;
18
+ const fullFieldName = prefix ? `${prefix}.${fieldName}` : fieldName;
19
+
20
+ // Handle direct field with ref
21
+ if (isField(field)) {
22
+ const element = field._f.ref;
23
+ if (element) {
24
+ elementMap.set(fullFieldName, element);
25
+ }
26
+ }
27
+
28
+ // Handle array fields (numeric keys indicate array indices)
29
+ else if (isFieldRefs(field)) {
30
+ // Check if any keys are numeric (indicating an array structure)
31
+ // Filter out non-numeric keys like '_f' which contains field metadata
32
+ const keys = Object.keys(field);
33
+ const numericKeys = keys.filter((key) => /^\d+$/.test(key));
34
+ const hasNumericKeys = numericKeys.length > 0;
35
+
36
+ if (hasNumericKeys) {
37
+ // Process only the numeric array indices, ignore metadata keys like '_f'
38
+ numericKeys.forEach((index) => {
39
+ const arrayItem = field[index];
40
+ if (arrayItem && isFieldRefs(arrayItem)) {
41
+ const nestedEntries = extractFieldEntries(
42
+ arrayItem,
43
+ `${fullFieldName}.${index}`
44
+ );
45
+ // Merge nested entries into main map
46
+ nestedEntries.forEach((element, fieldName) => {
47
+ elementMap.set(fieldName, element);
48
+ });
49
+ }
50
+ });
51
+ } else {
52
+ // Handle regular nested objects
53
+ const nestedEntries = extractFieldEntries(field, fullFieldName);
54
+ // Merge nested entries into main map
55
+ nestedEntries.forEach((element, fieldName) => {
56
+ elementMap.set(fieldName, element);
57
+ });
58
+ }
59
+ }
60
+ });
61
+
62
+ return elementMap;
63
+ }
64
+
65
+ /** Type guard to check if a ref is a Field object */
66
+ const isField = (fieldRef: FieldRefs[keyof FieldRefs]): fieldRef is Field =>
67
+ Boolean(
68
+ fieldRef &&
69
+ typeof fieldRef === 'object' &&
70
+ '_f' in fieldRef &&
71
+ fieldRef._f &&
72
+ 'ref' in fieldRef._f
73
+ );
74
+
75
+ /** Type guard to check if a ref is a FieldRefs object (nested fields) */
76
+ const isFieldRefs = (
77
+ fieldRef: FieldRefs[keyof FieldRefs]
78
+ ): fieldRef is FieldRefs =>
79
+ Boolean(fieldRef && typeof fieldRef === 'object' && !isField(fieldRef));
80
+
81
+ /**
82
+ * Sorts a map of HTML elements by their position in the DOM.
83
+ * Elements appearing earlier in the document order come first.
84
+ */
85
+ export function sortElementsByPosition(
86
+ elements: Map<string, Ref>
87
+ ): Map<string, Ref> {
88
+ const sortedEntries = Array.from(elements.entries()).sort(([, a], [, b]) => {
89
+ if (isActualHTMLElement(a) && isActualHTMLElement(b)) {
90
+ const aPosition = a.compareDocumentPosition(b);
91
+ if (aPosition & Node.DOCUMENT_POSITION_FOLLOWING) return -1;
92
+ if (aPosition & Node.DOCUMENT_POSITION_PRECEDING) return 1;
93
+ }
94
+ return 0; // keep original order
95
+ });
96
+ return new Map(sortedEntries);
97
+ }
98
+
99
+ /** Type guard to check if a ref is an actual HTML element */
100
+ const isActualHTMLElement = (ref: Ref): ref is Ref & HTMLElement =>
101
+ ref instanceof HTMLElement && typeof ref.focus === 'function';
102
+
103
+ /**
104
+ * Maps a collection of HTML elements to a FieldRefs structure.
105
+ *
106
+ * It's not a direct conversion, but rather a way to create a simple FieldRefs
107
+ * structure that can be used with React Hook Form.
108
+ */
109
+ export function mapElementsToFields(
110
+ elements: Map<string, HTMLElement>
111
+ ): Record<string, Field> {
112
+ const fields = {};
113
+ elements.forEach((element, fieldName) => {
114
+ fields[fieldName] = {
115
+ _f: {
116
+ ref: element,
117
+ name: fieldName,
118
+ },
119
+ };
120
+ });
121
+ return fields;
122
+ }
@@ -11,8 +11,8 @@ options as the users type and also let them select an option from the list.
11
11
 
12
12
  ### Default
13
13
 
14
- <code src="@digigov/form/inputs/AutoCompleteInput/__stories__/Default.tsx" />
14
+ <code src="@digigov/form/src/inputs/AutoCompleteInput/__stories__/Default.tsx" />
15
15
 
16
16
  ### Display multiple values
17
17
 
18
- <code src="@digigov/form/inputs/AutoCompleteInput/__stories__/Multiple.tsx" />
18
+ <code src="@digigov/form/src/inputs/AutoCompleteInput/__stories__/Multiple.tsx" />
@@ -1,10 +1,8 @@
1
1
  import React, { useCallback } from 'react';
2
- import { ControlledFieldProps } from '@digigov/form/Field/types';
3
- import { FieldOptionProps } from '@digigov/form/inputs/Label';
4
- import {
5
- AutoComplete,
6
- AutoCompleteProps as UIAutoCompleteProps,
7
- } from '@digigov/ui/form/AutoComplete';
2
+ import type { ControlledFieldProps } from '@digigov/form/Field/types';
3
+ import type { FieldOptionProps } from '@digigov/form/inputs/Label';
4
+ import type { AutoCompleteProps as UIAutoCompleteProps } from '@digigov/ui/form/AutoComplete';
5
+ import { AutoComplete } from '@digigov/ui/form/AutoComplete';
8
6
  import { Hint } from '@digigov/ui/typography/Hint';
9
7
  import { Base } from '@digigov/ui/utils/Base';
10
8
  export interface AutoCompleteInputExtra
@@ -10,14 +10,14 @@ Checkboxes are used to let a user select one or more options of a limited number
10
10
 
11
11
  ### Default
12
12
 
13
- <code src="@digigov/form/inputs/Checkboxes/__stories__/Default.tsx" />
13
+ <code src="@digigov/form/src/inputs/Checkboxes/__stories__/Default.tsx" />
14
14
 
15
15
 
16
16
  ### Conditional
17
17
 
18
- <code src="@digigov/form/inputs/Checkboxes/__stories__/Conditional.tsx" />
18
+ <code src="@digigov/form/src/inputs/Checkboxes/__stories__/Conditional.tsx" />
19
19
 
20
20
 
21
21
  ### With divider
22
22
 
23
- <code src="@digigov/form/inputs/Checkboxes/__stories__/WithDivider.tsx" />
23
+ <code src="@digigov/form/src/inputs/Checkboxes/__stories__/WithDivider.tsx" />
@@ -1,6 +1,8 @@
1
1
  import React, { useState } from 'react';
2
- import { ControlledFieldProps } from '@digigov/form/Field/types';
3
- import { FieldOptionProps } from '@digigov/form/inputs/Label';
2
+ import type { UseFormReturn } from 'react-hook-form';
3
+ import type { ControlledFieldProps } from '@digigov/form/Field/types';
4
+ import type { FieldOptionProps } from '@digigov/form/inputs/Label';
5
+ import { omit } from '@digigov/form/utils';
4
6
  import {
5
7
  Checkbox,
6
8
  CheckboxItem,
@@ -17,98 +19,103 @@ export interface CheckboxesProps
17
19
  options: FieldOptionProps[];
18
20
  };
19
21
  fieldComponent: React.FC<Omit<ControlledFieldProps, 'value' | 'onChange'>>;
22
+ resetField: UseFormReturn['resetField'];
20
23
  }
21
24
 
22
- export const Checkboxes: React.FC<CheckboxesProps> = ({
23
- name,
24
- onChange,
25
- value,
26
- extra: { options, className },
27
- disabled,
28
- Field,
29
- ...props
30
- }) => {
31
- if (!value) value = [];
32
- const handleChange =
33
- (optionValue, idx, show) =>
34
- (evt): void => {
35
- let newValue;
36
- if (evt.currentTarget.checked) {
37
- // eslint-disable-next-line @typescript-eslint/ban-ts-comment
38
- // @ts-ignore
39
- newValue = value.concat([optionValue]);
40
- } else {
41
- // eslint-disable-next-line @typescript-eslint/ban-ts-comment
42
- // @ts-ignore
43
- newValue = value.filter((val) => val !== optionValue);
44
- }
45
- if (show && show.length > 0) {
46
- setChecked((items) =>
47
- items.map((item, index) => (index === idx ? !item : item))
48
- );
49
- }
25
+ export const Checkboxes = React.forwardRef<HTMLInputElement, CheckboxesProps>(
26
+ (
27
+ {
28
+ name,
29
+ onChange,
30
+ value,
31
+ extra: { options, className },
32
+ disabled,
33
+ Field,
34
+ ...props
35
+ },
36
+ ref
37
+ ) => {
38
+ if (!value) value = [];
39
+ const handleChange =
40
+ (optionValue, idx, show) =>
41
+ (evt): void => {
42
+ let newValue: any = [];
43
+ if (evt.currentTarget.checked) {
44
+ newValue = value.concat([optionValue]);
45
+ } else {
46
+ newValue = value.filter((val) => val !== optionValue);
47
+ }
48
+ if (show && show.length > 0) {
49
+ setChecked((items) =>
50
+ items.map((item, index) => (index === idx ? !item : item))
51
+ );
52
+ }
50
53
 
51
- // reset value to undefined instead of an empty array
52
- // so the error state mechanism can throw validation errors
53
- if (newValue.length === 0) newValue = undefined;
54
- onChange(newValue);
55
- };
56
- const { t } = useTranslation();
57
- const [checked, setChecked] = useState(
58
- Array<boolean>(options.length).fill(false)
59
- );
60
- return (
61
- <Checkbox className={className}>
62
- {options.map(
63
- (
64
- {
65
- label,
66
- value: v,
67
- show,
68
- disabled: optionDisabled,
69
- selected,
70
- ...option
71
- },
72
- index
73
- ) => (
74
- <React.Fragment key={index}>
75
- <CheckboxItem
76
- key={`${name}.${index}`}
77
- name={`${name}.${v}`}
78
- id={`${name}.${v}`}
79
- value={v}
80
- disabled={disabled || optionDisabled}
81
- checked={value?.includes(v)}
82
- onChange={handleChange(v, index, show)}
83
- {...option}
84
- {...{
85
- ...props,
86
- reset: undefined,
87
- defaultValue: undefined,
88
- error: undefined,
89
- onBlur: undefined,
90
- required: undefined,
91
- 'aria-describedby': undefined,
92
- type: 'checkbox',
93
- }}
94
- >
95
- {(label && label.primary && t(label.primary)) || value}
96
- {label && label.secondary && <Hint>{t(label.secondary)}</Hint>}
97
- </CheckboxItem>
54
+ // reset value to undefined instead of an empty array
55
+ // so the error state mechanism can throw validation errors
56
+ if (newValue.length === 0) newValue = undefined;
57
+ onChange(newValue);
58
+ };
59
+ const { t } = useTranslation();
60
+ const [checked, setChecked] = useState(
61
+ Array<boolean>(options.length).fill(false)
62
+ );
63
+ return (
64
+ <Checkbox className={className}>
65
+ {options.map(
66
+ (
67
+ {
68
+ label,
69
+ value: v,
70
+ show,
71
+ disabled: optionDisabled,
72
+ selected,
73
+ ...option
74
+ },
75
+ index
76
+ ) => (
77
+ <React.Fragment key={index}>
78
+ <CheckboxItem
79
+ ref={index === 0 ? ref : undefined}
80
+ key={`${name}.${index}`}
81
+ name={`${name}.${v}`}
82
+ id={`${name}.${v}`}
83
+ value={v}
84
+ disabled={disabled || optionDisabled}
85
+ checked={value?.includes(v)}
86
+ onChange={handleChange(v, index, show)}
87
+ {...option}
88
+ {...{
89
+ ...omit(props, ['resetField']),
90
+ reset: undefined,
91
+ defaultValue: undefined,
92
+ error: undefined,
93
+ onBlur: undefined,
94
+ required: undefined,
95
+ 'aria-describedby': undefined,
96
+ type: 'checkbox',
97
+ }}
98
+ >
99
+ {(label && label.primary && t(label.primary)) || value}
100
+ {label && label.secondary && <Hint>{t(label.secondary)}</Hint>}
101
+ </CheckboxItem>
98
102
 
99
- {!!checked[index] && show && Field && (
100
- <CheckboxConditional>
101
- {show.map((fieldName) => (
102
- <Field name={fieldName} key={fieldName} />
103
- ))}
104
- </CheckboxConditional>
105
- )}
106
- {selected && selected()}
107
- </React.Fragment>
108
- )
109
- )}
110
- </Checkbox>
111
- );
112
- };
103
+ {!!checked[index] && show && Field && (
104
+ <CheckboxConditional>
105
+ {show.map((fieldName) => (
106
+ <Field name={fieldName} key={fieldName} />
107
+ ))}
108
+ </CheckboxConditional>
109
+ )}
110
+ {selected && selected()}
111
+ </React.Fragment>
112
+ )
113
+ )}
114
+ </Checkbox>
115
+ );
116
+ }
117
+ );
118
+
119
+ Checkboxes.displayName = 'Checkboxes';
113
120
 
114
121
  export default Checkboxes;
@@ -8,3 +8,7 @@ export default {
8
8
  displayName: 'DateInput',
9
9
  };
10
10
  export { Default } from '@digigov/form/inputs/DateInput/__stories__/Default';
11
+ export { WithDefaultValue } from '@digigov/form/inputs/DateInput/__stories__/WithDefaultValue';
12
+ export { WithWrongDefaultValue } from '@digigov/form/inputs/DateInput/__stories__/WithWrongDefaultValue';
13
+ export { WithInitialValue } from '@digigov/form/inputs/DateInput/__stories__/WithInitialValue';
14
+ export { WithWrongInitialValue } from '@digigov/form/inputs/DateInput/__stories__/WithWrongInitialValue';
@@ -0,0 +1,26 @@
1
+ import React from 'react';
2
+ import FormBuilder, { Field } from '@digigov/form';
3
+ import { Button } from '@digigov/ui/form/Button';
4
+
5
+ const fields = [
6
+ {
7
+ key: 'date_example',
8
+ type: 'date',
9
+ required: true,
10
+ defaultValue: '05/11/2020',
11
+ label: {
12
+ primary: 'Πότε εκδόθηκε το διαβατήριο σας;',
13
+ secondary: 'Για παράδειγμα, 05 11 2020',
14
+ },
15
+ } as const,
16
+ ];
17
+
18
+ export const WithDefaultValue = (_: any) => (
19
+ <FormBuilder onSubmit={(data) => console.log(data)}>
20
+ {fields.map(({ key, ...field }) => {
21
+ return <Field {...field} name={key} key={key} />;
22
+ })}
23
+ <Button type="submit">Συνέχεια</Button>
24
+ </FormBuilder>
25
+ );
26
+ export default WithDefaultValue;
@@ -0,0 +1,28 @@
1
+ import React from 'react';
2
+ import FormBuilder, { Field } from '@digigov/form';
3
+ import { Button } from '@digigov/ui/form/Button';
4
+
5
+ const fields = [
6
+ {
7
+ key: 'date_example',
8
+ type: 'date',
9
+ required: true,
10
+ label: {
11
+ primary: 'Πότε εκδόθηκε το διαβατήριο σας;',
12
+ secondary: 'Για παράδειγμα, 05 11 2020',
13
+ },
14
+ } as const,
15
+ ];
16
+
17
+ export const WithInitialValue = (_: any) => (
18
+ <FormBuilder
19
+ initial={{ date_example: '05/01/2020' }}
20
+ onSubmit={(data) => console.log(data)}
21
+ >
22
+ {fields.map(({ key, ...field }) => {
23
+ return <Field {...field} name={key} key={key} />;
24
+ })}
25
+ <Button type="submit">Συνέχεια</Button>
26
+ </FormBuilder>
27
+ );
28
+ export default WithInitialValue;
@@ -0,0 +1,26 @@
1
+ import React from 'react';
2
+ import FormBuilder, { Field } from '@digigov/form';
3
+ import { Button } from '@digigov/ui/form/Button';
4
+
5
+ const fields = [
6
+ {
7
+ key: 'date_example',
8
+ type: 'date',
9
+ required: true,
10
+ defaultValue: '5/1/2020',
11
+ label: {
12
+ primary: 'Πότε εκδόθηκε το διαβατήριο σας;',
13
+ secondary: 'Για παράδειγμα, 05 11 2020',
14
+ },
15
+ } as const,
16
+ ];
17
+
18
+ export const WithWrongDefaultValue = (_: any) => (
19
+ <FormBuilder onSubmit={(data) => console.log(data)}>
20
+ {fields.map(({ key, ...field }) => {
21
+ return <Field {...field} name={key} key={key} />;
22
+ })}
23
+ <Button type="submit">Συνέχεια</Button>
24
+ </FormBuilder>
25
+ );
26
+ export default WithWrongDefaultValue;
@@ -0,0 +1,28 @@
1
+ import React from 'react';
2
+ import FormBuilder, { Field } from '@digigov/form';
3
+ import { Button } from '@digigov/ui/form/Button';
4
+
5
+ const fields = [
6
+ {
7
+ key: 'date_example',
8
+ type: 'date',
9
+ required: true,
10
+ label: {
11
+ primary: 'Πότε εκδόθηκε το διαβατήριο σας;',
12
+ secondary: 'Για παράδειγμα, 05 11 2020',
13
+ },
14
+ } as const,
15
+ ];
16
+
17
+ export const WithWrongInitialValue = (_: any) => (
18
+ <FormBuilder
19
+ initial={{ date_example: '5/1/2020' }}
20
+ onSubmit={(data) => console.log(data)}
21
+ >
22
+ {fields.map(({ key, ...field }) => {
23
+ return <Field {...field} name={key} key={key} />;
24
+ })}
25
+ <Button type="submit">Συνέχεια</Button>
26
+ </FormBuilder>
27
+ );
28
+ export default WithWrongInitialValue;
@@ -13,4 +13,4 @@ either with a textbox that validates the input or a special date picker interfac
13
13
 
14
14
  ### Default
15
15
 
16
- <code src="@digigov/form/inputs/DateInput/__stories__/Default.tsx" />
16
+ <code src="@digigov/form/src/inputs/DateInput/__stories__/Default.tsx" />