@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
@@ -0,0 +1,271 @@
1
+ import React from 'react';
2
+ import { fireEvent, render, screen, waitFor } from '@testing-library/react';
3
+ import type { FieldSpec } from '@digigov/form';
4
+ import FormBuilder, { Field } from '@digigov/form';
5
+ import { Button } from '@digigov/ui/form/Button';
6
+
7
+ beforeAll(() => {
8
+ global.ResizeObserver = class ResizeObserver {
9
+ observe() {
10
+ // do nothing
11
+ }
12
+ unobserve() {
13
+ // do nothing
14
+ }
15
+ disconnect() {
16
+ // do nothing
17
+ }
18
+ };
19
+ });
20
+
21
+ const fieldSpec: FieldSpec = {
22
+ key: 'fieldset_multiplicity',
23
+ type: 'array',
24
+ editable: true,
25
+ label: {
26
+ primary: 'Fieldset multiplicity (μέχρι 5)',
27
+ },
28
+ extra: {
29
+ noIndex: true,
30
+ tableCellActionsLabel: '',
31
+ border: true,
32
+ variant: 'dialog',
33
+ labelSize: 'md',
34
+ tableContainer: {
35
+ mb: 0,
36
+ },
37
+ stackProps: {
38
+ spacing: 2,
39
+ justifyContent: 'flex-end',
40
+ direction: 'row',
41
+ },
42
+ max: 5,
43
+ label: {
44
+ object: {
45
+ append: {
46
+ label: 'Αποθήκευση',
47
+ props: {
48
+ color: 'primary',
49
+ },
50
+ },
51
+ edit: {
52
+ label: 'Αποθήκευση',
53
+ props: {
54
+ color: 'primary',
55
+ },
56
+ },
57
+ cancel: {
58
+ label: 'Ακύρωση',
59
+ props: {
60
+ variant: 'button',
61
+ color: 'secondary',
62
+ },
63
+ },
64
+ add: 'Προσθήκη',
65
+ addButtonVariant: 'link',
66
+ delete: 'Αφαίρεση',
67
+ deleteButtonVariant: 'link',
68
+ nothing_added: 'Δεν έχουν προστεθεί στοιχεία',
69
+ nothing_added_props: {
70
+ style: {
71
+ color: 'var(--color-gray-600)',
72
+ },
73
+ margin: 0,
74
+ paddingLeft: 2,
75
+ },
76
+ },
77
+ },
78
+ of: {
79
+ type: 'object',
80
+ extra: {
81
+ fields: [
82
+ {
83
+ key: 'fieldset_multiplicity_required',
84
+ name: 'fieldset_multiplicity_required',
85
+ type: 'string',
86
+ label: {
87
+ primary: '"required label"',
88
+ },
89
+ required: true,
90
+ editable: true,
91
+ layout: {},
92
+ },
93
+ {
94
+ key: 'fieldset_multiplicity_optional',
95
+ name: 'fieldset_multiplicity_optional',
96
+ type: 'string',
97
+ label: {
98
+ primary: '"optional label"',
99
+ },
100
+ required: false,
101
+ editable: true,
102
+ layout: {},
103
+ },
104
+ ],
105
+ },
106
+ },
107
+ },
108
+ };
109
+
110
+ describe('fieldset_multiplicity case from dilosi', () => {
111
+ const submitHandler = vi.fn();
112
+ const TestForm = () => (
113
+ <FormBuilder onSubmit={submitHandler}>
114
+ <Field name="fieldset_multiplicity" {...fieldSpec} />
115
+ <Button type="submit">Συνέχεια</Button>
116
+ </FormBuilder>
117
+ );
118
+ let addButton: HTMLButtonElement;
119
+
120
+ beforeEach(() => {
121
+ render(<TestForm />);
122
+ addButton = screen.getByRole('button', { name: 'Προσθήκη' });
123
+ expect(addButton).toBeInTheDocument();
124
+ });
125
+
126
+ beforeEach(() => {
127
+ submitHandler.mockClear();
128
+ });
129
+
130
+ it('should render', async () => {
131
+ expect(
132
+ screen.getByText('Fieldset multiplicity (μέχρι 5)')
133
+ ).toBeInTheDocument();
134
+ });
135
+
136
+ it('should open dialog on add button click', async () => {
137
+ fireEvent.click(addButton);
138
+ expect(screen.getByRole('dialog')).toBeInTheDocument();
139
+ expect(screen.getByText('"required label"')).toBeInTheDocument();
140
+ expect(screen.getByText('"optional label"')).toBeInTheDocument();
141
+ });
142
+ it('should submit required value', async () => {
143
+ fireEvent.click(addButton);
144
+ expect(screen.getByRole('dialog')).toBeInTheDocument();
145
+
146
+ const saveButton = screen.getByRole('button', { name: 'Αποθήκευση' });
147
+ fireEvent.click(saveButton);
148
+
149
+ expect(submitHandler).not.toHaveBeenCalled();
150
+ await waitFor(() =>
151
+ expect(
152
+ screen.getByText('Το πεδίο είναι υποχρεωτικό.')
153
+ ).toBeInTheDocument()
154
+ );
155
+
156
+ const requiredInput = screen.getAllByRole('textbox')[0];
157
+ fireEvent.change(requiredInput, { target: { value: 'Required value' } });
158
+
159
+ fireEvent.click(saveButton);
160
+
161
+ await waitFor(() => {
162
+ expect(screen.queryByRole('dialog')).not.toBeInTheDocument();
163
+ });
164
+ expect(screen.getByText('Required value')).toBeInTheDocument();
165
+ expect(submitHandler).not.toHaveBeenCalled();
166
+
167
+ const submitButton = screen.getByRole('button', { name: 'Συνέχεια' });
168
+ fireEvent.click(submitButton);
169
+
170
+ await waitFor(() => {
171
+ expect(submitHandler).toHaveBeenCalledWith({
172
+ fieldset_multiplicity: [
173
+ {
174
+ fieldset_multiplicity_required: 'Required value',
175
+ fieldset_multiplicity_optional: '',
176
+ },
177
+ ],
178
+ });
179
+ });
180
+ });
181
+ it('should submit both required and optional values', async () => {
182
+ fireEvent.click(addButton);
183
+ expect(screen.getByRole('dialog')).toBeInTheDocument();
184
+
185
+ const requiredInput = screen.getAllByRole('textbox')[0];
186
+ fireEvent.change(requiredInput, { target: { value: 'Required value' } });
187
+ const optionalInput = screen.getAllByRole('textbox')[1];
188
+ fireEvent.change(optionalInput, { target: { value: 'Optional value' } });
189
+
190
+ const saveButton = screen.getByRole('button', { name: 'Αποθήκευση' });
191
+ fireEvent.click(saveButton);
192
+
193
+ await waitFor(() => {
194
+ expect(screen.queryByRole('dialog')).not.toBeInTheDocument();
195
+ });
196
+ expect(screen.getByText('Required value')).toBeInTheDocument();
197
+ expect(screen.getByText('Optional value')).toBeInTheDocument();
198
+ expect(submitHandler).not.toHaveBeenCalled();
199
+
200
+ const submitButton = screen.getByRole('button', { name: 'Συνέχεια' });
201
+ fireEvent.click(submitButton);
202
+
203
+ await waitFor(() => {
204
+ expect(submitHandler).toHaveBeenCalledWith({
205
+ fieldset_multiplicity: [
206
+ {
207
+ fieldset_multiplicity_required: 'Required value',
208
+ fieldset_multiplicity_optional: 'Optional value',
209
+ },
210
+ ],
211
+ });
212
+ });
213
+ });
214
+ it('should allow adding up to max items', async () => {
215
+ for (let i = 0; i < 5; i++) {
216
+ fireEvent.click(addButton);
217
+ expect(screen.getByRole('dialog')).toBeInTheDocument();
218
+
219
+ const requiredInput = screen.getAllByRole('textbox')[0];
220
+ fireEvent.change(requiredInput, {
221
+ target: { value: `Required value ${i}` },
222
+ });
223
+ const optionalInput = screen.getAllByRole('textbox')[1];
224
+ fireEvent.change(optionalInput, {
225
+ target: { value: `Optional value ${i}` },
226
+ });
227
+
228
+ const saveButton = screen.getByRole('button', { name: 'Αποθήκευση' });
229
+ fireEvent.click(saveButton);
230
+
231
+ await waitFor(() => {
232
+ expect(screen.queryByRole('dialog')).not.toBeInTheDocument();
233
+ });
234
+ expect(screen.getByText(`Required value ${i}`)).toBeInTheDocument();
235
+ expect(screen.getByText(`Optional value ${i}`)).toBeInTheDocument();
236
+ }
237
+
238
+ expect(addButton).toBeDisabled();
239
+
240
+ expect(submitHandler).not.toHaveBeenCalled();
241
+ const submitButton = screen.getByRole('button', { name: 'Συνέχεια' });
242
+ fireEvent.click(submitButton);
243
+
244
+ await waitFor(() =>
245
+ expect(submitHandler).toHaveBeenCalledWith({
246
+ fieldset_multiplicity: [
247
+ {
248
+ fieldset_multiplicity_required: 'Required value 0',
249
+ fieldset_multiplicity_optional: 'Optional value 0',
250
+ },
251
+ {
252
+ fieldset_multiplicity_required: 'Required value 1',
253
+ fieldset_multiplicity_optional: 'Optional value 1',
254
+ },
255
+ {
256
+ fieldset_multiplicity_required: 'Required value 2',
257
+ fieldset_multiplicity_optional: 'Optional value 2',
258
+ },
259
+ {
260
+ fieldset_multiplicity_required: 'Required value 3',
261
+ fieldset_multiplicity_optional: 'Optional value 3',
262
+ },
263
+ {
264
+ fieldset_multiplicity_required: 'Required value 4',
265
+ fieldset_multiplicity_optional: 'Optional value 4',
266
+ },
267
+ ],
268
+ })
269
+ );
270
+ });
271
+ });
@@ -0,0 +1,280 @@
1
+ import React from 'react';
2
+ import { fireEvent, render, screen, waitFor } from '@testing-library/react';
3
+ import user from '@testing-library/user-event';
4
+ import type { FieldSpec } from '@digigov/form';
5
+ import FormBuilder, { Field } from '@digigov/form';
6
+ import { Button } from '@digigov/ui/form/Button';
7
+
8
+ beforeAll(() => {
9
+ global.ResizeObserver = class ResizeObserver {
10
+ observe() {
11
+ // do nothing
12
+ }
13
+ unobserve() {
14
+ // do nothing
15
+ }
16
+ disconnect() {
17
+ // do nothing
18
+ }
19
+ };
20
+ });
21
+
22
+ const fieldSpec: FieldSpec = {
23
+ key: 'attachment_multiplicity',
24
+ type: 'array',
25
+ editable: true,
26
+ required: false,
27
+ label: {
28
+ primary: 'attachment multiplicity',
29
+ secondary: 'Ο χρήστης μπορεί να προσθέσει τιμές (σύνολο από 1 έως 10)',
30
+ },
31
+ extra: {
32
+ border: false,
33
+ editVariant: 'optional',
34
+ label: {
35
+ object: {
36
+ add: 'Προσθήκη',
37
+ addButtonVariant: 'link',
38
+ append: {
39
+ label: 'Αποθήκευση',
40
+ },
41
+ cancel: {
42
+ label: 'Ακύρωση',
43
+ },
44
+ delete: 'Αφαίρεση',
45
+ deleteButtonVariant: 'link',
46
+ edit: {
47
+ label: 'Αποθήκευση',
48
+ },
49
+ nothing_added: 'Δεν έχουν προστεθεί στοιχεία',
50
+ nothing_added_props: {
51
+ margin: 0,
52
+ paddingLeft: 2,
53
+ style: {
54
+ color: 'var(--color-gray-600)',
55
+ },
56
+ },
57
+ },
58
+ },
59
+ limit: {
60
+ maxSize: 5242880,
61
+ },
62
+ max: 10,
63
+ min: 0,
64
+ noHeader: true,
65
+ noIndex: true,
66
+ of: {
67
+ editable: true,
68
+ name: undefined,
69
+ key: undefined,
70
+ label: {},
71
+ type: 'file',
72
+ extra: {
73
+ containerProps: {
74
+ variant: 'border',
75
+ },
76
+ limit: {
77
+ maxSize: 5242880,
78
+ },
79
+ noResetButton: true,
80
+ resetButtonProps: {
81
+ color: 'warning',
82
+ },
83
+ uploadButtonProps: {
84
+ variant: 'link',
85
+ },
86
+ },
87
+ },
88
+ stackProps: {
89
+ direction: 'row',
90
+ justifyContent: 'flex-end',
91
+ spacing: 2,
92
+ },
93
+ tableContainer: {
94
+ mb: 0,
95
+ },
96
+ variant: 'dialog',
97
+ },
98
+ };
99
+
100
+ describe('multiplicity_attachment case from dilosi', () => {
101
+ const submitHandler = vi.fn();
102
+
103
+ const TestForm = () => (
104
+ <FormBuilder onSubmit={submitHandler}>
105
+ <Field name="multiplicity_attachment" {...fieldSpec} />
106
+ <Button type="submit">Συνέχεια</Button>
107
+ </FormBuilder>
108
+ );
109
+
110
+ beforeEach(() => {
111
+ submitHandler.mockClear();
112
+ });
113
+
114
+ it('should render', async () => {
115
+ render(<TestForm />);
116
+ expect(screen.getByText('attachment multiplicity')).toBeInTheDocument();
117
+ const addButton = screen.getByRole('button', { name: 'Προσθήκη' });
118
+ expect(addButton).toBeInTheDocument();
119
+ });
120
+
121
+ it('should open dialog on add button click', async () => {
122
+ render(<TestForm />);
123
+ const addButton = screen.getByRole('button', { name: 'Προσθήκη' });
124
+ fireEvent.click(addButton);
125
+ expect(screen.getByText('Αποθήκευση')).toBeInTheDocument();
126
+ expect(screen.getByRole('dialog')).toBeInTheDocument();
127
+ expect(screen.getByText('Επιλογή αρχείου')).toBeInTheDocument();
128
+ });
129
+ it('should add a new item on dialog form submission', async () => {
130
+ render(<TestForm />);
131
+ const addButton = screen.getByRole('button', { name: 'Προσθήκη' });
132
+ fireEvent.click(addButton);
133
+ const fileInput = screen.getByLabelText('Επιλογή αρχείου');
134
+ const file = new File(['file content'], 'test-file.txt', {
135
+ type: 'text/plain',
136
+ });
137
+ fireEvent.change(fileInput, { target: { files: [file] } });
138
+ const saveButton = screen.getByRole('button', { name: 'Αποθήκευση' });
139
+ fireEvent.click(saveButton);
140
+ expect(screen.getByText('test-file.txt')).toBeInTheDocument();
141
+ });
142
+ it('should submit added item on main form', async () => {
143
+ render(<TestForm />);
144
+ const addButton = screen.getByRole('button', { name: 'Προσθήκη' });
145
+ await user.click(addButton);
146
+ const fileInput = screen.getByLabelText('Επιλογή αρχείου');
147
+ const file = new File(['file content'], 'test-file.txt', {
148
+ type: 'text/plain',
149
+ });
150
+ await user.upload(fileInput, file);
151
+ await waitFor(() => {
152
+ expect(screen.getByText(/test-file.txt/)).toBeInTheDocument();
153
+ });
154
+
155
+ const saveButton = screen.getByRole('button', { name: 'Αποθήκευση' });
156
+ await user.click(saveButton);
157
+
158
+ await waitFor(() => {
159
+ expect(screen.queryByRole('dialog')).not.toBeInTheDocument();
160
+ expect(screen.getByText('test-file.txt')).toBeInTheDocument();
161
+ });
162
+ expect(screen.getByText('Επεξεργασία')).toBeInTheDocument();
163
+ expect(screen.getByText('Διαγραφή')).toBeInTheDocument();
164
+
165
+ const submitButton = screen.getByRole('button', { name: 'Συνέχεια' });
166
+ await user.click(submitButton);
167
+
168
+ await waitFor(() => {
169
+ expect(submitHandler).toHaveBeenCalledTimes(1);
170
+ expect(submitHandler).toHaveBeenCalledWith({
171
+ multiplicity_attachment: expect.any(Array),
172
+ });
173
+ });
174
+
175
+ const callArgs = submitHandler.mock.calls[0][0];
176
+
177
+ expect(Array.isArray(callArgs.multiplicity_attachment)).toBe(true);
178
+ expect(callArgs.multiplicity_attachment).toHaveLength(1);
179
+ expect(callArgs.multiplicity_attachment[0]).toBeInstanceOf(FileList);
180
+ expect(callArgs.multiplicity_attachment[0][0].name).toBe('test-file.txt');
181
+ });
182
+ it('should submit multiple added items', async () => {
183
+ render(<TestForm />);
184
+ const addButton = screen.getByRole('button', { name: 'Προσθήκη' });
185
+
186
+ // First file
187
+ await user.click(addButton);
188
+ const file1 = new File(['file content'], 'file-1.txt', {
189
+ type: 'text/plain',
190
+ });
191
+ await user.upload(screen.getByLabelText('Επιλογή αρχείου'), file1);
192
+ await waitFor(() => {
193
+ expect(screen.getByText(/file-1.txt/)).toBeInTheDocument();
194
+ });
195
+
196
+ await user.click(screen.getByRole('button', { name: 'Αποθήκευση' }));
197
+
198
+ await waitFor(() => {
199
+ expect(screen.queryByRole('dialog')).not.toBeInTheDocument();
200
+ });
201
+ expect(screen.getByText('file-1.txt')).toBeInTheDocument();
202
+ expect(screen.getByText('Επεξεργασία')).toBeInTheDocument();
203
+ expect(screen.getByText('Διαγραφή')).toBeInTheDocument();
204
+
205
+ // Second file
206
+ await user.click(addButton);
207
+ const file2 = new File(['file content'], 'file-2.txt', {
208
+ type: 'text/plain',
209
+ });
210
+ await user.upload(screen.getByLabelText('Επιλογή αρχείου'), file2);
211
+ await waitFor(() => {
212
+ expect(screen.getByText(/file-2.txt/)).toBeInTheDocument();
213
+ });
214
+
215
+ await user.click(screen.getByRole('button', { name: 'Αποθήκευση' }));
216
+
217
+ await waitFor(() => {
218
+ expect(screen.queryByRole('dialog')).not.toBeInTheDocument();
219
+ });
220
+ expect(screen.getByText('file-1.txt')).toBeInTheDocument();
221
+ expect(screen.getByText('file-2.txt')).toBeInTheDocument();
222
+
223
+ const submitButton = screen.getByRole('button', { name: 'Συνέχεια' });
224
+ await user.click(submitButton);
225
+
226
+ await waitFor(() => {
227
+ expect(submitHandler).toHaveBeenCalledTimes(1);
228
+ expect(submitHandler).toHaveBeenCalledWith({
229
+ multiplicity_attachment: [expect.any(FileList), expect.any(FileList)],
230
+ });
231
+ });
232
+
233
+ const callArgs = submitHandler.mock.calls[0][0];
234
+
235
+ expect(Array.isArray(callArgs.multiplicity_attachment)).toBe(true);
236
+ expect(callArgs.multiplicity_attachment).toHaveLength(2);
237
+ expect(callArgs.multiplicity_attachment[0]).toBeInstanceOf(FileList);
238
+ expect(callArgs.multiplicity_attachment[0][0].name).toBe('file-1.txt');
239
+
240
+ expect(callArgs.multiplicity_attachment[1]).toBeInstanceOf(FileList);
241
+ expect(callArgs.multiplicity_attachment[1][0].name).toBe('file-2.txt');
242
+ });
243
+ it('should allow editing of added item', async () => {
244
+ render(<TestForm />);
245
+ const addButton = screen.getByRole('button', { name: 'Προσθήκη' });
246
+ await user.click(addButton);
247
+ const fileInput = screen.getByLabelText('Επιλογή αρχείου');
248
+ const file = new File(['file content'], 'test-file.txt', {
249
+ type: 'text/plain',
250
+ });
251
+ await user.upload(fileInput, file);
252
+ expect(screen.getByText(/test-file.txt/)).toBeInTheDocument();
253
+ const saveButton = screen.getByRole('button', { name: 'Αποθήκευση' });
254
+ await user.click(saveButton);
255
+ await waitFor(() =>
256
+ expect(screen.queryByRole('dialog')).not.toBeInTheDocument()
257
+ );
258
+ expect(screen.getByText(/test-file.txt/)).toBeInTheDocument();
259
+
260
+ const editButton = screen.getByRole('button', { name: 'Επεξεργασία' });
261
+ await user.click(editButton);
262
+
263
+ await waitFor(() => {
264
+ expect(screen.getByRole('dialog')).toBeInTheDocument();
265
+ const dialog = screen.getByRole('dialog');
266
+
267
+ expect(dialog).toHaveTextContent(/test-file.txt/);
268
+ });
269
+ const editFileInput = screen.getByLabelText(/Αντικατάσταση/);
270
+ expect(screen.getByRole('dialog')).toBeInTheDocument();
271
+ const newFile = new File(['new content'], 'new-file.txt', {
272
+ type: 'text/plain',
273
+ });
274
+ await user.upload(editFileInput, newFile);
275
+ const saveEditButton = screen.getByRole('button', { name: 'Αποθήκευση' });
276
+ await user.click(saveEditButton);
277
+ expect(screen.queryByRole('dialog')).not.toBeInTheDocument();
278
+ expect(screen.getByText(/new-file.txt/)).toBeInTheDocument();
279
+ });
280
+ });
@@ -0,0 +1,131 @@
1
+ import React from 'react';
2
+ import { fireEvent, render, screen, waitFor } from '@testing-library/react';
3
+ import type { FieldSpec } from '@digigov/form';
4
+ import FormBuilder, { Field } from '@digigov/form';
5
+ import { Button } from '@digigov/ui/form/Button';
6
+
7
+ beforeAll(() => {
8
+ global.ResizeObserver = class ResizeObserver {
9
+ observe() {
10
+ // do nothing
11
+ }
12
+ unobserve() {
13
+ // do nothing
14
+ }
15
+ disconnect() {
16
+ // do nothing
17
+ }
18
+ };
19
+ });
20
+
21
+ const fieldSpec: FieldSpec = {
22
+ key: 'multiplicity_required',
23
+ editable: true,
24
+ type: 'array',
25
+ required: true,
26
+ label: {
27
+ primary: '"required" μέχρι 10',
28
+ secondary: 'Ο χρήστης μπορεί να προσθέσει τιμές (σύνολο από 1 έως 10)',
29
+ },
30
+ extra: {
31
+ variant: 'dialog',
32
+ editVariant: 'required',
33
+ min: 1,
34
+ max: 10,
35
+ noHeader: true,
36
+ noIndex: true,
37
+ label: {
38
+ object: {
39
+ add: 'Προσθήκη',
40
+ addButtonVariant: 'link',
41
+ append: {
42
+ label: 'Αποθήκευση',
43
+ },
44
+ delete: 'Αφαίρεση',
45
+ deleteButtonVariant: 'link',
46
+ cancel: {
47
+ label: 'Ακύρωση',
48
+ },
49
+ edit: {
50
+ label: 'Αποθήκευση',
51
+ },
52
+ nothing_added: 'Δεν έχουν προστεθεί στοιχεία',
53
+ },
54
+ },
55
+ of: {
56
+ editable: true,
57
+ key: undefined,
58
+ name: undefined,
59
+ type: 'string',
60
+ required: true,
61
+ label: {},
62
+ },
63
+ },
64
+ };
65
+
66
+ describe('multiplicity_required case from dilosi', () => {
67
+ const submitHandler = vi.fn();
68
+
69
+ const TestForm = () => (
70
+ <FormBuilder onSubmit={submitHandler}>
71
+ <Field name="multiplicity_required" {...fieldSpec} />
72
+ <Button type="submit">Συνέχεια</Button>
73
+ </FormBuilder>
74
+ );
75
+
76
+ beforeEach(() => {
77
+ submitHandler.mockClear();
78
+ });
79
+
80
+ it('should render', async () => {
81
+ render(<TestForm />);
82
+ expect(screen.getByText('"required" μέχρι 10')).toBeInTheDocument();
83
+ const addButton = screen.getByRole('button', { name: 'Προσθήκη' });
84
+ expect(addButton).toBeInTheDocument();
85
+ });
86
+
87
+ it('should open dialog on add button click', async () => {
88
+ render(<TestForm />);
89
+ const addButton = screen.getByRole('button', { name: 'Προσθήκη' });
90
+ fireEvent.click(addButton);
91
+ expect(screen.getByRole('dialog')).toBeInTheDocument();
92
+ });
93
+ it('should add a new item on dialog form submission', async () => {
94
+ render(<TestForm />);
95
+ const addButton = screen.getByRole('button', { name: 'Προσθήκη' });
96
+ fireEvent.click(addButton);
97
+
98
+ const inputField = screen.getByRole('textbox');
99
+ fireEvent.change(inputField, { target: { value: 'Test Value' } });
100
+ expect(inputField).toHaveValue('Test Value');
101
+ const submitButton = screen.getByRole('button', { name: 'Αποθήκευση' });
102
+ fireEvent.click(submitButton);
103
+ expect(await screen.findByRole('dialog')).not.toBeVisible();
104
+
105
+ expect(screen.getByText('Test Value')).toBeInTheDocument();
106
+ expect(submitHandler).not.toHaveBeenCalled();
107
+ });
108
+ it('should submit added item on main form', async () => {
109
+ render(<TestForm />);
110
+ const addButton = screen.getByRole('button', { name: 'Προσθήκη' });
111
+ fireEvent.click(addButton);
112
+
113
+ const inputField = screen.getByRole('textbox');
114
+ fireEvent.change(inputField, { target: { value: 'Test Value' } });
115
+ expect(inputField).toHaveValue('Test Value');
116
+ const submitButton = screen.getByRole('button', { name: 'Αποθήκευση' });
117
+ fireEvent.click(submitButton);
118
+ expect(await screen.findByRole('dialog')).not.toBeVisible();
119
+
120
+ expect(screen.getByText('Test Value')).toBeInTheDocument();
121
+ const continueButton = screen.getByRole('button', { name: 'Συνέχεια' });
122
+ fireEvent.click(continueButton);
123
+
124
+ await waitFor(() => {
125
+ expect(submitHandler).toHaveBeenCalledTimes(1);
126
+ });
127
+ expect(submitHandler).toHaveBeenCalledWith({
128
+ multiplicity_required: ['Test Value'],
129
+ });
130
+ });
131
+ });