@digigov/form 2.0.0-87b6232d → 2.0.0-8bbad051

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 (585) hide show
  1. package/Field/ErrorGroup.d.ts +3 -3
  2. package/Field/ErrorGroup.js.map +1 -1
  3. package/Field/FieldBase/index.js +5 -5
  4. package/Field/FieldBase.d.ts +1 -1
  5. package/Field/FieldBase.js.map +2 -2
  6. package/Field/FieldBaseContainer/index.js +37 -19
  7. package/Field/FieldBaseContainer.d.ts +2 -2
  8. package/Field/FieldBaseContainer.js.map +2 -2
  9. package/Field/FieldConditional/index.js +1 -1
  10. package/Field/FieldConditional.d.ts +1 -1
  11. package/Field/FieldConditional.js.map +1 -1
  12. package/Field/index.d.ts +1 -1
  13. package/Field/index.js +18 -27
  14. package/Field/index.js.map +2 -2
  15. package/Field/types.d.ts +13 -12
  16. package/Field/utils/evaluateFieldWithConditions.d.ts +2 -2
  17. package/Field/utils/evaluateFieldWithConditions.js.map +2 -2
  18. package/Field/utils/resolveField/index.js +35 -0
  19. package/Field/utils/{calculateField → resolveField}/package.json +1 -1
  20. package/Field/utils/resolveField.d.ts +3 -0
  21. package/Field/utils/resolveField.js.map +7 -0
  22. package/Field/utils/useField/index.js +4 -2
  23. package/Field/utils/useField.d.ts +1 -1
  24. package/Field/utils/useField.js.map +2 -2
  25. package/FieldArray/BaseFieldArray/index.js +76 -0
  26. package/{inputs/inputsScenarios → FieldArray/BaseFieldArray}/package.json +1 -1
  27. package/FieldArray/BaseFieldArray.d.ts +5 -0
  28. package/FieldArray/BaseFieldArray.js.map +7 -0
  29. package/FieldArray/FieldArray.stories.d.ts +1 -0
  30. package/FieldArray/FormDialog/ArrayDisplay/ArrayContainerDisplay/index.js +23 -0
  31. package/FieldArray/FormDialog/ArrayDisplay/ArrayContainerDisplay/package.json +6 -0
  32. package/FieldArray/FormDialog/ArrayDisplay/ArrayContainerDisplay.d.ts +9 -0
  33. package/FieldArray/FormDialog/ArrayDisplay/ArrayContainerDisplay.js.map +7 -0
  34. package/FieldArray/FormDialog/ArrayDisplay/ArrayDisplay.stories.d.ts +13 -0
  35. package/FieldArray/FormDialog/ArrayDisplay/ArrayItemDisplay/index.js +184 -0
  36. package/FieldArray/FormDialog/ArrayDisplay/ArrayItemDisplay/package.json +6 -0
  37. package/FieldArray/FormDialog/ArrayDisplay/ArrayItemDisplay.d.ts +26 -0
  38. package/FieldArray/FormDialog/ArrayDisplay/ArrayItemDisplay.js.map +7 -0
  39. package/FieldArray/FormDialog/ArrayDisplay/ArrayItemHeader/index.js +11 -0
  40. package/FieldArray/FormDialog/ArrayDisplay/ArrayItemHeader/package.json +6 -0
  41. package/FieldArray/FormDialog/ArrayDisplay/ArrayItemHeader.d.ts +5 -0
  42. package/FieldArray/FormDialog/ArrayDisplay/ArrayItemHeader.js.map +7 -0
  43. package/FieldArray/FormDialog/ArrayDisplay/__stories__/Cards.d.ts +2 -0
  44. package/FieldArray/FormDialog/ArrayDisplay/__stories__/Default.d.ts +2 -0
  45. package/FieldArray/FormDialog/ArrayDisplay/__stories__/ReadOnly.d.ts +2 -0
  46. package/FieldArray/FormDialog/ArrayDisplay/__stories__/ReadOnlyCards.d.ts +2 -0
  47. package/FieldArray/FormDialog/ArrayDisplay/__stories__/Sortable.d.ts +2 -0
  48. package/FieldArray/FormDialog/ArrayDisplay/__stories__/SortableCards.d.ts +2 -0
  49. package/FieldArray/FormDialog/ArrayDisplay/index.d.ts +15 -0
  50. package/FieldArray/FormDialog/ArrayDisplay/index.js +57 -0
  51. package/FieldArray/FormDialog/ArrayDisplay/index.js.map +7 -0
  52. package/{inputs/Input/inputsInputScenarios → FieldArray/FormDialog/ArrayDisplay}/package.json +1 -1
  53. package/FieldArray/FormDialog/ArrayEditModal/index.js +158 -0
  54. package/FieldArray/FormDialog/ArrayEditModal/package.json +6 -0
  55. package/FieldArray/FormDialog/ArrayEditModal.d.ts +24 -0
  56. package/FieldArray/FormDialog/ArrayEditModal.js.map +7 -0
  57. package/FieldArray/FormDialog/index.d.ts +19 -0
  58. package/FieldArray/FormDialog/index.js +183 -351
  59. package/FieldArray/FormDialog/index.js.map +7 -0
  60. package/FieldArray/__stories__/CardsWithError.d.ts +15 -0
  61. package/FieldArray/__stories__/Default.d.ts +1 -1
  62. package/FieldArray/__stories__/WithExactLength.d.ts +1 -1
  63. package/FieldArray/__stories__/WithModal.d.ts +1 -1
  64. package/FieldArray/index.d.ts +5 -3
  65. package/FieldArray/index.js +64 -98
  66. package/FieldArray/index.js.map +3 -3
  67. package/FieldObject/index.d.ts +4 -4
  68. package/FieldObject/index.js +5 -12
  69. package/FieldObject/index.js.map +2 -2
  70. package/Fieldset/FieldsetWithContext.js.map +1 -1
  71. package/Fieldset/index.d.ts +1 -1
  72. package/Fieldset/index.js.map +1 -1
  73. package/Fieldset/types.d.ts +2 -2
  74. package/FormBuilder/FormBuilder.stories.d.ts +2 -0
  75. package/FormBuilder/__stories__/AutoErrorGrouping.d.ts +1 -1
  76. package/FormBuilder/__stories__/Default.d.ts +1 -1
  77. package/FormBuilder/__stories__/ErrorGrouping.d.ts +1 -1
  78. package/FormBuilder/index.d.ts +2 -2
  79. package/FormBuilder/index.js +159 -137
  80. package/FormBuilder/index.js.map +2 -2
  81. package/FormContext/index.js +6 -2
  82. package/FormContext.d.ts +3 -2
  83. package/FormContext.js.map +2 -2
  84. package/MultiplicityField/MultiplicityField.stories.d.ts +2 -0
  85. package/MultiplicityField/__stories__/Default.d.ts +1 -1
  86. package/MultiplicityField/__stories__/PreviewDisplay.d.ts +1 -1
  87. package/MultiplicityField/__stories__/WithExactLength.d.ts +1 -1
  88. package/MultiplicityField/__stories__/WithMaxLength.d.ts +1 -1
  89. package/MultiplicityField/__stories__/WithMinAndMaxLength.d.ts +1 -1
  90. package/MultiplicityField/__stories__/WithMinLength.d.ts +1 -1
  91. package/MultiplicityField/add-objects/index.js +11 -20
  92. package/MultiplicityField/add-objects.d.ts +1 -1
  93. package/MultiplicityField/add-objects.js.map +2 -2
  94. package/MultiplicityField/index.d.ts +2 -2
  95. package/MultiplicityField/index.js +4 -2
  96. package/MultiplicityField/index.js.map +2 -2
  97. package/MultiplicityField/types.d.ts +3 -2
  98. package/Questions/Questions.d.ts +1 -1
  99. package/Questions/Questions.js.map +1 -1
  100. package/Questions/Questions.stories.d.ts +2 -0
  101. package/Questions/QuestionsContext.d.ts +1 -1
  102. package/Questions/QuestionsContext.js.map +1 -1
  103. package/Questions/Step/Step.d.ts +1 -1
  104. package/Questions/Step/Step.js.map +1 -1
  105. package/Questions/Step/StepArrayReview.d.ts +1 -1
  106. package/Questions/Step/StepArrayReview.js.map +1 -1
  107. package/Questions/Step/StepContext.d.ts +1 -1
  108. package/Questions/Step/StepContext.js.map +1 -1
  109. package/Questions/Step/StepDescription.d.ts +1 -1
  110. package/Questions/Step/StepDescription.js.map +2 -2
  111. package/Questions/Step/StepForm.d.ts +2 -2
  112. package/Questions/Step/StepForm.js.map +1 -1
  113. package/Questions/Step/StepQuote.d.ts +1 -1
  114. package/Questions/Step/StepQuote.js.map +2 -2
  115. package/Questions/Step/StepTitle.d.ts +1 -1
  116. package/Questions/Step/StepTitle.js.map +2 -2
  117. package/Questions/Step/getAddMoreFields.d.ts +2 -2
  118. package/Questions/Step/getAddMoreFields.js.map +1 -1
  119. package/Questions/Step/types.d.ts +1 -1
  120. package/Questions/__stories__/Default.d.ts +1 -1
  121. package/Questions/getNextStep.d.ts +1 -1
  122. package/Questions/getNextStep.js.map +1 -1
  123. package/Questions/types.d.ts +1 -1
  124. package/cjs/Field/ErrorGroup.js.map +1 -1
  125. package/cjs/Field/FieldBase/index.js +5 -5
  126. package/cjs/Field/FieldBase.js.map +2 -2
  127. package/cjs/Field/FieldBaseContainer/index.js +36 -18
  128. package/cjs/Field/FieldBaseContainer.js.map +3 -3
  129. package/cjs/Field/FieldConditional/index.js +1 -1
  130. package/cjs/Field/FieldConditional.js.map +1 -1
  131. package/cjs/Field/index.js +18 -24
  132. package/cjs/Field/index.js.map +2 -2
  133. package/cjs/Field/types.js.map +1 -1
  134. package/cjs/Field/utils/evaluateFieldWithConditions.js.map +2 -2
  135. package/cjs/Field/utils/resolveField/index.js +55 -0
  136. package/cjs/Field/utils/resolveField.js.map +7 -0
  137. package/cjs/Field/utils/useField/index.js +4 -2
  138. package/cjs/Field/utils/useField.js.map +2 -2
  139. package/cjs/FieldArray/BaseFieldArray/index.js +109 -0
  140. package/cjs/FieldArray/BaseFieldArray.js.map +7 -0
  141. package/cjs/FieldArray/FormDialog/ArrayDisplay/ArrayContainerDisplay/index.js +56 -0
  142. package/cjs/FieldArray/FormDialog/ArrayDisplay/ArrayContainerDisplay.js.map +7 -0
  143. package/cjs/FieldArray/FormDialog/ArrayDisplay/ArrayItemDisplay/index.js +209 -0
  144. package/cjs/FieldArray/FormDialog/ArrayDisplay/ArrayItemDisplay.js.map +7 -0
  145. package/cjs/{locales/el → FieldArray/FormDialog/ArrayDisplay/ArrayItemHeader}/index.js +16 -7
  146. package/cjs/FieldArray/FormDialog/ArrayDisplay/ArrayItemHeader.js.map +7 -0
  147. package/cjs/FieldArray/FormDialog/ArrayDisplay/index.js +90 -0
  148. package/cjs/FieldArray/FormDialog/ArrayDisplay/index.js.map +7 -0
  149. package/cjs/FieldArray/FormDialog/ArrayEditModal/index.js +186 -0
  150. package/cjs/FieldArray/FormDialog/ArrayEditModal.js.map +7 -0
  151. package/cjs/FieldArray/FormDialog/index.js +174 -334
  152. package/cjs/FieldArray/FormDialog/index.js.map +7 -0
  153. package/cjs/FieldArray/index.js +63 -94
  154. package/cjs/FieldArray/index.js.map +3 -3
  155. package/cjs/FieldObject/index.js +5 -9
  156. package/cjs/FieldObject/index.js.map +2 -2
  157. package/cjs/Fieldset/FieldsetWithContext.js.map +1 -1
  158. package/cjs/Fieldset/index.js.map +1 -1
  159. package/cjs/Fieldset/types.js.map +1 -1
  160. package/cjs/FormBuilder/index.js +160 -138
  161. package/cjs/FormBuilder/index.js.map +3 -3
  162. package/cjs/FormContext/index.js +7 -2
  163. package/cjs/FormContext.js.map +2 -2
  164. package/cjs/MultiplicityField/add-objects/index.js +10 -14
  165. package/cjs/MultiplicityField/add-objects.js.map +2 -2
  166. package/cjs/MultiplicityField/index.js +4 -2
  167. package/cjs/MultiplicityField/index.js.map +2 -2
  168. package/cjs/MultiplicityField/types.js.map +1 -1
  169. package/cjs/Questions/Questions.js.map +1 -1
  170. package/cjs/Questions/QuestionsContext.js.map +1 -1
  171. package/cjs/Questions/Step/Step.js.map +1 -1
  172. package/cjs/Questions/Step/StepArrayReview.js.map +1 -1
  173. package/cjs/Questions/Step/StepContext.js.map +1 -1
  174. package/cjs/Questions/Step/StepDescription.js.map +2 -2
  175. package/cjs/Questions/Step/StepForm.js.map +1 -1
  176. package/cjs/Questions/Step/StepQuote.js.map +2 -2
  177. package/cjs/Questions/Step/StepTitle.js.map +2 -2
  178. package/cjs/Questions/Step/getAddMoreFields.js.map +1 -1
  179. package/cjs/Questions/Step/types.js.map +1 -1
  180. package/cjs/Questions/getNextStep.js.map +1 -1
  181. package/cjs/Questions/types.js.map +1 -1
  182. package/cjs/hooks/useFieldFocusManager/index.js +135 -0
  183. package/cjs/hooks/useFieldFocusManager.js.map +7 -0
  184. package/cjs/hooks/utils/index.js +98 -0
  185. package/cjs/hooks/utils.js.map +7 -0
  186. package/cjs/inputs/AutoCompleteInput/index.js.map +2 -2
  187. package/cjs/inputs/Checkboxes/index.js +68 -62
  188. package/cjs/inputs/Checkboxes/index.js.map +2 -2
  189. package/cjs/inputs/DateInput/index.js +37 -17
  190. package/cjs/inputs/DateInput/index.js.map +2 -2
  191. package/cjs/inputs/DateTimeInput/index.js +65 -39
  192. package/cjs/inputs/DateTimeInput/index.js.map +2 -2
  193. package/cjs/inputs/FileInput/index.js +35 -24
  194. package/cjs/inputs/FileInput/index.js.map +2 -2
  195. package/cjs/inputs/ImageInput/__stories__/logo.d/index.js +1 -0
  196. package/cjs/inputs/ImageInput/__stories__/logo.d.js.map +7 -0
  197. package/cjs/inputs/ImageInput/index.js +44 -13
  198. package/cjs/inputs/ImageInput/index.js.map +2 -2
  199. package/cjs/inputs/Input/index.js +6 -4
  200. package/cjs/inputs/Input/index.js.map +2 -2
  201. package/cjs/inputs/Label/index.js.map +1 -1
  202. package/cjs/inputs/OtpInput/index.js +36 -31
  203. package/cjs/inputs/OtpInput/index.js.map +2 -2
  204. package/cjs/inputs/Radio/index.js +7 -5
  205. package/cjs/inputs/Radio/index.js.map +3 -3
  206. package/cjs/inputs/Select/index.js +2 -2
  207. package/cjs/inputs/Select/index.js.map +2 -2
  208. package/cjs/{Field/utils → inputs/registry}/index.js +8 -7
  209. package/cjs/inputs/registry.js.map +7 -0
  210. package/cjs/lazy/index.js +12 -9
  211. package/cjs/lazy.js.map +2 -2
  212. package/cjs/registry/index.js +27 -15
  213. package/cjs/registry.js.map +2 -2
  214. package/cjs/types.js.map +1 -1
  215. package/cjs/utils/index.js +9 -0
  216. package/cjs/utils.js.map +2 -2
  217. package/cjs/validators/index.js +13 -12
  218. package/cjs/validators/index.js.map +2 -2
  219. package/cjs/validators/types.js.map +1 -1
  220. package/cjs/validators/utils/date/index.js +26 -3
  221. package/cjs/validators/utils/date.js.map +2 -2
  222. package/cjs/validators/utils/datetime/index.js +118 -24
  223. package/cjs/validators/utils/datetime.js.map +2 -2
  224. package/cjs/validators/utils/email/index.js +39 -0
  225. package/cjs/validators/utils/email.js.map +7 -0
  226. package/cjs/validators/utils/file.js.map +1 -1
  227. package/cjs/validators/utils/iban.js.map +1 -1
  228. package/cjs/validators/utils/image.js.map +1 -1
  229. package/cjs/validators/utils/index.js.map +1 -1
  230. package/cjs/validators/utils/int.js.map +1 -1
  231. package/cjs/validators/utils/number.js.map +1 -1
  232. package/cjs/validators/utils/otp.js.map +1 -1
  233. package/cjs/validators/utils/phone.js.map +1 -1
  234. package/cjs/validators/utils/postal_code.js.map +1 -1
  235. package/cjs/validators/utils/text_limit.js.map +1 -1
  236. package/hooks/useFieldFocusManager/index.js +116 -0
  237. package/hooks/useFieldFocusManager/package.json +6 -0
  238. package/hooks/useFieldFocusManager.d.ts +25 -0
  239. package/hooks/useFieldFocusManager.js.map +7 -0
  240. package/hooks/utils/index.js +73 -0
  241. package/{Field → hooks}/utils/package.json +1 -1
  242. package/hooks/utils.d.ts +18 -0
  243. package/hooks/utils.js.map +7 -0
  244. package/index.js +1 -1
  245. package/inputs/AutoCompleteInput/AutoComplete.stories.d.ts +2 -0
  246. package/inputs/AutoCompleteInput/__stories__/Default.d.ts +1 -1
  247. package/inputs/AutoCompleteInput/__stories__/Multiple.d.ts +1 -1
  248. package/inputs/AutoCompleteInput/index.d.ts +3 -3
  249. package/inputs/AutoCompleteInput/index.js +1 -3
  250. package/inputs/AutoCompleteInput/index.js.map +2 -2
  251. package/inputs/Checkboxes/Checkboxes.stories.d.ts +2 -0
  252. package/inputs/Checkboxes/__stories__/Conditional.d.ts +1 -1
  253. package/inputs/Checkboxes/__stories__/Default.d.ts +1 -1
  254. package/inputs/Checkboxes/__stories__/WithDivider.d.ts +1 -1
  255. package/inputs/Checkboxes/index.d.ts +5 -3
  256. package/inputs/Checkboxes/index.js +68 -62
  257. package/inputs/Checkboxes/index.js.map +2 -2
  258. package/inputs/DateInput/DateInput.stories.d.ts +6 -0
  259. package/inputs/DateInput/__stories__/Default.d.ts +1 -1
  260. package/inputs/DateInput/__stories__/WithDefaultValue.d.ts +3 -0
  261. package/inputs/DateInput/__stories__/WithInitialValue.d.ts +3 -0
  262. package/inputs/DateInput/__stories__/WithWrongDefaultValue.d.ts +3 -0
  263. package/inputs/DateInput/__stories__/WithWrongInitialValue.d.ts +3 -0
  264. package/inputs/DateInput/index.d.ts +2 -5
  265. package/inputs/DateInput/index.js +38 -18
  266. package/inputs/DateInput/index.js.map +2 -2
  267. package/inputs/DateTimeInput/DateTimeInput.stories.d.ts +10 -3
  268. package/inputs/DateTimeInput/__stories__/Default.d.ts +1 -1
  269. package/inputs/DateTimeInput/__stories__/WithDefaultValue.d.ts +3 -0
  270. package/inputs/DateTimeInput/__stories__/WithInitialValue.d.ts +3 -0
  271. package/inputs/DateTimeInput/__stories__/WithWrongDefaultValue.d.ts +3 -0
  272. package/inputs/DateTimeInput/__stories__/WithWrongInitialValue.d.ts +3 -0
  273. package/inputs/DateTimeInput/index.d.ts +2 -5
  274. package/inputs/DateTimeInput/index.js +66 -40
  275. package/inputs/DateTimeInput/index.js.map +2 -2
  276. package/inputs/FileInput/FileInput.stories.d.ts +2 -0
  277. package/inputs/FileInput/__stories__/Default.d.ts +1 -1
  278. package/inputs/FileInput/index.d.ts +8 -4
  279. package/inputs/FileInput/index.js +37 -29
  280. package/inputs/FileInput/index.js.map +2 -2
  281. package/inputs/ImageInput/ImageInput.stories.d.ts +4 -1
  282. package/inputs/ImageInput/__stories__/Default.d.ts +1 -1
  283. package/inputs/ImageInput/__stories__/MaxSize.d.ts +1 -1
  284. package/inputs/ImageInput/__stories__/WithInitialValues.d.ts +3 -0
  285. package/inputs/ImageInput/__stories__/WithInvalidImageDimension.d.ts +1 -1
  286. package/inputs/ImageInput/__stories__/logo.d/index.js +1 -0
  287. package/inputs/ImageInput/__stories__/logo.d/package.json +6 -0
  288. package/inputs/ImageInput/__stories__/logo.d.js.map +7 -0
  289. package/inputs/ImageInput/index.d.ts +10 -2
  290. package/inputs/ImageInput/index.js +45 -14
  291. package/inputs/ImageInput/index.js.map +2 -2
  292. package/inputs/Input/Input.stories.d.ts +3 -0
  293. package/inputs/Input/__stories__/AFM.d.ts +1 -1
  294. package/inputs/Input/__stories__/Boolean.d.ts +1 -1
  295. package/inputs/Input/__stories__/Email.d.ts +3 -0
  296. package/inputs/Input/__stories__/IBAN.d.ts +1 -1
  297. package/inputs/Input/__stories__/Integer.d.ts +1 -1
  298. package/inputs/Input/__stories__/LandlineNumber.d.ts +1 -1
  299. package/inputs/Input/__stories__/MobilePhone.d.ts +1 -1
  300. package/inputs/Input/__stories__/PhoneNumber.d.ts +1 -1
  301. package/inputs/Input/__stories__/PostalCode.d.ts +1 -1
  302. package/inputs/Input/__stories__/String.d.ts +1 -1
  303. package/inputs/Input/__stories__/StringWithTrimValidation.d.ts +1 -1
  304. package/inputs/Input/__stories__/TextWithLimit.d.ts +1 -1
  305. package/inputs/Input/index.d.ts +3 -1
  306. package/inputs/Input/index.js +6 -4
  307. package/inputs/Input/index.js.map +2 -2
  308. package/inputs/Label/Label.stories.d.ts +2 -0
  309. package/inputs/Label/__stories__/Default.d.ts +1 -1
  310. package/inputs/Label/index.d.ts +1 -1
  311. package/inputs/Label/index.js.map +1 -1
  312. package/inputs/OtpInput/OtpInput.stories.d.ts +2 -0
  313. package/inputs/OtpInput/__stories__/Default.d.ts +1 -1
  314. package/inputs/OtpInput/index.d.ts +1 -5
  315. package/inputs/OtpInput/index.js +36 -31
  316. package/inputs/OtpInput/index.js.map +2 -2
  317. package/inputs/Radio/Radio.stories.d.ts +2 -0
  318. package/inputs/Radio/__stories__/Conditional.d.ts +1 -1
  319. package/inputs/Radio/__stories__/Default.d.ts +1 -1
  320. package/inputs/Radio/__stories__/WithDivider.d.ts +1 -1
  321. package/inputs/Radio/index.d.ts +6 -4
  322. package/inputs/Radio/index.js +7 -5
  323. package/inputs/Radio/index.js.map +3 -3
  324. package/inputs/Select/Select.stories.d.ts +2 -0
  325. package/inputs/Select/__stories__/Default.d.ts +1 -1
  326. package/inputs/Select/index.d.ts +4 -2
  327. package/inputs/Select/index.js +2 -2
  328. package/inputs/Select/index.js.map +2 -2
  329. package/{Field/utils → inputs/registry}/index.js +5 -4
  330. package/{locales/el → inputs/registry}/package.json +1 -1
  331. package/{Field/utils/index.d.ts → inputs/registry.d.ts} +2 -1
  332. package/inputs/registry.js.map +7 -0
  333. package/lazy/index.js +12 -9
  334. package/package.json +8 -8
  335. package/registry/index.js +27 -15
  336. package/src/Field/ErrorGroup.tsx +3 -3
  337. package/src/Field/FieldBase.tsx +16 -19
  338. package/src/Field/FieldBaseContainer.tsx +69 -51
  339. package/src/Field/FieldConditional.tsx +2 -2
  340. package/src/Field/index.tsx +18 -37
  341. package/src/Field/types.tsx +13 -14
  342. package/src/Field/utils/evaluateFieldWithConditions.ts +5 -2
  343. package/src/Field/utils/resolveField.ts +58 -0
  344. package/src/Field/utils/useField.ts +3 -1
  345. package/src/FieldArray/BaseFieldArray.tsx +97 -0
  346. package/src/FieldArray/FieldArray.stories.js +1 -0
  347. package/src/FieldArray/FormDialog/ArrayDisplay/ArrayContainerDisplay.tsx +45 -0
  348. package/src/FieldArray/FormDialog/ArrayDisplay/ArrayDisplay.stories.js +14 -0
  349. package/src/FieldArray/FormDialog/ArrayDisplay/ArrayItemDisplay.tsx +337 -0
  350. package/src/FieldArray/FormDialog/ArrayDisplay/ArrayItemHeader.tsx +15 -0
  351. package/src/FieldArray/FormDialog/ArrayDisplay/__stories__/Cards.tsx +88 -0
  352. package/src/FieldArray/FormDialog/ArrayDisplay/__stories__/Default.tsx +93 -0
  353. package/src/FieldArray/FormDialog/ArrayDisplay/__stories__/ReadOnly.tsx +79 -0
  354. package/src/FieldArray/FormDialog/ArrayDisplay/__stories__/ReadOnlyCards.tsx +75 -0
  355. package/src/FieldArray/FormDialog/ArrayDisplay/__stories__/Sortable.tsx +93 -0
  356. package/src/FieldArray/FormDialog/ArrayDisplay/__stories__/SortableCards.tsx +88 -0
  357. package/src/FieldArray/FormDialog/ArrayDisplay/index.test.tsx +44 -0
  358. package/src/FieldArray/FormDialog/ArrayDisplay/index.tsx +67 -0
  359. package/src/FieldArray/FormDialog/ArrayEditModal.tsx +241 -0
  360. package/src/FieldArray/FormDialog/index.tsx +302 -0
  361. package/src/FieldArray/__stories__/CardsWithError.tsx +124 -0
  362. package/src/FieldArray/__stories__/Default.tsx +1 -1
  363. package/src/FieldArray/__stories__/WithExactLength.tsx +1 -1
  364. package/src/FieldArray/__stories__/WithModal.tsx +1 -1
  365. package/src/FieldArray/__tests__/fieldset-multiplicity.spec.tsx +271 -0
  366. package/src/FieldArray/__tests__/multiplicity-attachment.spec.tsx +280 -0
  367. package/src/FieldArray/__tests__/multiplicity-optional.spec.tsx +232 -0
  368. package/src/FieldArray/__tests__/multiplicity-required.spec.tsx +170 -0
  369. package/src/FieldArray/__tests__/nested-fieldset-multiplicity.spec.tsx +627 -0
  370. package/src/FieldArray/__tests__/preference-multiple-choice.spec.tsx +222 -0
  371. package/src/FieldArray/index.spec.tsx +355 -0
  372. package/src/FieldArray/index.test.tsx +4 -0
  373. package/src/FieldArray/index.tsx +73 -112
  374. package/src/FieldObject/index.tsx +9 -17
  375. package/src/Fieldset/FieldsetWithContext.tsx +1 -1
  376. package/src/Fieldset/index.tsx +1 -1
  377. package/src/Fieldset/types.tsx +2 -2
  378. package/src/FormBuilder/FormBuilder.stories.js +3 -0
  379. package/src/FormBuilder/__stories__/AutoErrorGrouping.tsx +1 -1
  380. package/src/FormBuilder/__stories__/Default.tsx +1 -1
  381. package/src/FormBuilder/__stories__/ErrorGrouping.tsx +1 -1
  382. package/src/FormBuilder/index.tsx +191 -149
  383. package/src/FormBuilder/scenarios.test.tsx +761 -2
  384. package/src/FormContext.tsx +7 -2
  385. package/src/MultiplicityField/MultiplicityField.stories.js +3 -0
  386. package/src/MultiplicityField/__stories__/Default.tsx +1 -1
  387. package/src/MultiplicityField/__stories__/PreviewDisplay.tsx +2 -4
  388. package/src/MultiplicityField/__stories__/WithExactLength.tsx +1 -1
  389. package/src/MultiplicityField/__stories__/WithMaxLength.tsx +1 -1
  390. package/src/MultiplicityField/__stories__/WithMinAndMaxLength.tsx +1 -1
  391. package/src/MultiplicityField/__stories__/WithMinLength.tsx +1 -1
  392. package/src/MultiplicityField/add-objects.tsx +13 -22
  393. package/src/MultiplicityField/index.tsx +6 -3
  394. package/src/MultiplicityField/types.ts +6 -2
  395. package/src/Questions/Questions.stories.js +3 -0
  396. package/src/Questions/Questions.tsx +2 -2
  397. package/src/Questions/QuestionsContext.tsx +1 -1
  398. package/src/Questions/Step/Step.tsx +1 -1
  399. package/src/Questions/Step/StepArrayReview.tsx +2 -2
  400. package/src/Questions/Step/StepContext.tsx +1 -1
  401. package/src/Questions/Step/StepDescription.tsx +2 -1
  402. package/src/Questions/Step/StepForm.tsx +2 -2
  403. package/src/Questions/Step/StepQuote.tsx +2 -1
  404. package/src/Questions/Step/StepTitle.tsx +2 -1
  405. package/src/Questions/Step/getAddMoreFields.tsx +2 -2
  406. package/src/Questions/Step/types.tsx +1 -1
  407. package/src/Questions/__stories__/Default.tsx +1 -1
  408. package/src/Questions/getNextStep.tsx +1 -1
  409. package/src/Questions/types.tsx +1 -1
  410. package/src/hooks/__tests__/useFieldFocusManager.spec.tsx +1079 -0
  411. package/src/hooks/__tests__/utils.spec.ts +568 -0
  412. package/src/hooks/useFieldFocusManager.ts +162 -0
  413. package/src/hooks/utils.ts +122 -0
  414. package/src/inputs/AutoCompleteInput/AutoComplete.stories.js +3 -0
  415. package/src/inputs/AutoCompleteInput/__stories__/Default.tsx +1 -1
  416. package/src/inputs/AutoCompleteInput/__stories__/Multiple.tsx +1 -1
  417. package/src/inputs/AutoCompleteInput/index.tsx +4 -6
  418. package/src/inputs/Checkboxes/Checkboxes.stories.js +3 -0
  419. package/src/inputs/Checkboxes/__stories__/Conditional.tsx +1 -1
  420. package/src/inputs/Checkboxes/__stories__/Default.tsx +1 -1
  421. package/src/inputs/Checkboxes/__stories__/WithDivider.tsx +1 -1
  422. package/src/inputs/Checkboxes/index.tsx +98 -88
  423. package/src/inputs/DateInput/DateInput.stories.js +7 -0
  424. package/src/inputs/DateInput/__stories__/Default.tsx +1 -1
  425. package/src/inputs/DateInput/__stories__/WithDefaultValue.tsx +26 -0
  426. package/src/inputs/DateInput/__stories__/WithInitialValue.tsx +28 -0
  427. package/src/inputs/DateInput/__stories__/WithWrongDefaultValue.tsx +26 -0
  428. package/src/inputs/DateInput/__stories__/WithWrongInitialValue.tsx +28 -0
  429. package/src/inputs/DateInput/index.test.tsx +16 -0
  430. package/src/inputs/DateInput/index.tsx +50 -19
  431. package/src/inputs/DateTimeInput/DateTimeInput.stories.js +12 -6
  432. package/src/inputs/DateTimeInput/__stories__/Default.tsx +1 -1
  433. package/src/inputs/DateTimeInput/__stories__/WithDefaultValue.tsx +26 -0
  434. package/src/inputs/DateTimeInput/__stories__/WithInitialValue.tsx +28 -0
  435. package/src/inputs/DateTimeInput/__stories__/WithWrongDefaultValue.tsx +26 -0
  436. package/src/inputs/DateTimeInput/__stories__/WithWrongInitialValue.tsx +28 -0
  437. package/src/inputs/DateTimeInput/index.test.tsx +16 -0
  438. package/src/inputs/DateTimeInput/index.tsx +78 -41
  439. package/src/inputs/FileInput/FileInput.stories.js +3 -0
  440. package/src/inputs/FileInput/__stories__/Default.tsx +1 -1
  441. package/src/inputs/FileInput/index.tsx +68 -41
  442. package/src/inputs/ImageInput/ImageInput.stories.js +5 -1
  443. package/src/inputs/ImageInput/__stories__/Default.tsx +1 -1
  444. package/src/inputs/ImageInput/__stories__/MaxSize.tsx +3 -2
  445. package/src/inputs/ImageInput/__stories__/WithInitialValues.tsx +45 -0
  446. package/src/inputs/ImageInput/__stories__/WithInvalidImageDimension.tsx +1 -1
  447. package/src/inputs/ImageInput/__stories__/logo.d.ts +4 -0
  448. package/src/inputs/ImageInput/__stories__/logo.png +0 -0
  449. package/src/inputs/ImageInput/index.test.tsx +4 -0
  450. package/src/inputs/ImageInput/index.tsx +102 -50
  451. package/src/inputs/Input/Input.stories.js +4 -0
  452. package/src/inputs/Input/__stories__/AFM.tsx +1 -1
  453. package/src/inputs/Input/__stories__/Boolean.tsx +1 -1
  454. package/src/inputs/Input/__stories__/Email.tsx +23 -0
  455. package/src/inputs/Input/__stories__/IBAN.tsx +1 -1
  456. package/src/inputs/Input/__stories__/Integer.tsx +1 -1
  457. package/src/inputs/Input/__stories__/LandlineNumber.tsx +1 -1
  458. package/src/inputs/Input/__stories__/MobilePhone.tsx +1 -1
  459. package/src/inputs/Input/__stories__/PhoneNumber.tsx +1 -1
  460. package/src/inputs/Input/__stories__/PostalCode.tsx +1 -1
  461. package/src/inputs/Input/__stories__/String.tsx +1 -1
  462. package/src/inputs/Input/__stories__/StringWithTrimValidation.tsx +1 -1
  463. package/src/inputs/Input/__stories__/TextWithLimit.tsx +1 -1
  464. package/src/inputs/Input/index.test.tsx +8 -0
  465. package/src/inputs/Input/index.tsx +13 -8
  466. package/src/inputs/Label/Label.stories.js +3 -0
  467. package/src/inputs/Label/__stories__/Default.tsx +1 -1
  468. package/src/inputs/Label/index.tsx +1 -1
  469. package/src/inputs/OtpInput/OtpInput.stories.js +3 -0
  470. package/src/inputs/OtpInput/__stories__/Default.tsx +1 -1
  471. package/src/inputs/OtpInput/index.tsx +43 -34
  472. package/src/inputs/Radio/Radio.stories.js +3 -0
  473. package/src/inputs/Radio/__stories__/Conditional.tsx +1 -1
  474. package/src/inputs/Radio/__stories__/Default.tsx +1 -1
  475. package/src/inputs/Radio/__stories__/WithDivider.tsx +1 -1
  476. package/src/inputs/Radio/index.tsx +33 -22
  477. package/src/inputs/Select/Select.stories.js +3 -0
  478. package/src/inputs/Select/__stories__/Default.tsx +1 -1
  479. package/src/inputs/Select/index.tsx +6 -4
  480. package/src/{Field/utils/index.ts → inputs/registry.ts} +5 -2
  481. package/src/lazy.js +12 -9
  482. package/src/registry.js +27 -15
  483. package/src/types.tsx +13 -5
  484. package/src/utils.ts +14 -2
  485. package/src/validators/index.ts +28 -24
  486. package/src/validators/types.ts +1 -1
  487. package/src/validators/utils/date.ts +30 -6
  488. package/src/validators/utils/datetime.ts +123 -31
  489. package/src/validators/utils/email.ts +11 -0
  490. package/src/validators/utils/file.ts +2 -2
  491. package/src/validators/utils/iban.ts +2 -2
  492. package/src/validators/utils/image.ts +2 -2
  493. package/src/validators/utils/index.ts +2 -2
  494. package/src/validators/utils/int.ts +1 -1
  495. package/src/validators/utils/number.ts +1 -1
  496. package/src/validators/utils/otp.ts +2 -2
  497. package/src/validators/utils/phone.ts +2 -2
  498. package/src/validators/utils/postal_code.ts +2 -2
  499. package/src/validators/utils/text_limit.ts +2 -2
  500. package/types.d.ts +9 -4
  501. package/types.js.map +1 -1
  502. package/utils/index.js +8 -0
  503. package/utils.d.ts +2 -1
  504. package/utils.js.map +2 -2
  505. package/validators/index.d.ts +5 -5
  506. package/validators/index.js +13 -12
  507. package/validators/index.js.map +2 -2
  508. package/validators/types.d.ts +1 -1
  509. package/validators/utils/date/index.js +26 -3
  510. package/validators/utils/date.d.ts +3 -3
  511. package/validators/utils/date.js.map +2 -2
  512. package/validators/utils/datetime/index.js +118 -24
  513. package/validators/utils/datetime.d.ts +3 -3
  514. package/validators/utils/datetime.js.map +2 -2
  515. package/validators/utils/email/index.js +16 -0
  516. package/validators/utils/email/package.json +6 -0
  517. package/validators/utils/email.d.ts +5 -0
  518. package/validators/utils/email.js.map +7 -0
  519. package/validators/utils/file.d.ts +2 -2
  520. package/validators/utils/file.js.map +1 -1
  521. package/validators/utils/iban.d.ts +2 -2
  522. package/validators/utils/iban.js.map +1 -1
  523. package/validators/utils/image.d.ts +2 -2
  524. package/validators/utils/image.js.map +1 -1
  525. package/validators/utils/index.d.ts +2 -2
  526. package/validators/utils/index.js.map +1 -1
  527. package/validators/utils/int.d.ts +1 -1
  528. package/validators/utils/int.js.map +1 -1
  529. package/validators/utils/number.d.ts +1 -1
  530. package/validators/utils/number.js.map +1 -1
  531. package/validators/utils/otp.d.ts +2 -2
  532. package/validators/utils/otp.js.map +1 -1
  533. package/validators/utils/phone.d.ts +2 -2
  534. package/validators/utils/phone.js.map +1 -1
  535. package/validators/utils/postal_code.d.ts +2 -2
  536. package/validators/utils/postal_code.js.map +1 -1
  537. package/validators/utils/text_limit.d.ts +2 -2
  538. package/validators/utils/text_limit.js.map +1 -1
  539. package/Field/utils/calculateField/index.js +0 -27
  540. package/Field/utils/calculateField.d.ts +0 -2
  541. package/Field/utils/calculateField.js.map +0 -7
  542. package/Field/utils/index.js.map +0 -7
  543. package/FieldArray/FormDialog.d.ts +0 -67
  544. package/FieldArray/FormDialog.js.map +0 -7
  545. package/FormBuilder/index.test.d.ts +0 -1
  546. package/FormBuilder/interaction.test.d.ts +0 -1
  547. package/FormBuilder/scenarios.test.d.ts +0 -88
  548. package/MultiplicityField/index.test.d.ts +0 -1
  549. package/Questions/index.spec.d.ts +0 -1
  550. package/Questions/index.test.d.ts +0 -1
  551. package/cjs/Field/utils/calculateField/index.js +0 -50
  552. package/cjs/Field/utils/calculateField.js.map +0 -7
  553. package/cjs/Field/utils/index.js.map +0 -7
  554. package/cjs/FieldArray/FormDialog.js.map +0 -7
  555. package/cjs/inputs/Input/inputsInputScenarios/index.js +0 -439
  556. package/cjs/inputs/Input/inputsInputScenarios.js.map +0 -7
  557. package/cjs/inputs/inputsScenarios/index.js +0 -533
  558. package/cjs/inputs/inputsScenarios.js.map +0 -7
  559. package/cjs/locales/el.js.map +0 -7
  560. package/inputs/AutoCompleteInput/index.test.d.ts +0 -1
  561. package/inputs/Checkboxes/index.test.d.ts +0 -1
  562. package/inputs/DateInput/index.test.d.ts +0 -1
  563. package/inputs/DateTimeInput/index.test.d.ts +0 -1
  564. package/inputs/FileInput/index.test.d.ts +0 -1
  565. package/inputs/ImageInput/index.test.d.ts +0 -1
  566. package/inputs/Input/index.test.d.ts +0 -1
  567. package/inputs/Input/inputsInputScenarios/index.js +0 -406
  568. package/inputs/Input/inputsInputScenarios.d.ts +0 -57
  569. package/inputs/Input/inputsInputScenarios.js.map +0 -7
  570. package/inputs/Label/index.test.d.ts +0 -1
  571. package/inputs/OtpInput/index.test.d.ts +0 -1
  572. package/inputs/Radio/index.test.d.ts +0 -1
  573. package/inputs/Select/index.test.d.ts +0 -1
  574. package/inputs/inputsScenarios/index.js +0 -499
  575. package/inputs/inputsScenarios.d.ts +0 -296
  576. package/inputs/inputsScenarios.js.map +0 -7
  577. package/locales/el/index.js +0 -6
  578. package/locales/el.d.ts +0 -2
  579. package/locales/el.js.map +0 -7
  580. package/src/Field/utils/calculateField.ts +0 -49
  581. package/src/FieldArray/FormDialog.tsx +0 -574
  582. package/src/inputs/Input/inputsInputScenarios.ts +0 -404
  583. package/src/inputs/inputsScenarios.ts +0 -496
  584. package/src/locales/el.ts +0 -3
  585. /package/{FieldArray/index.test.d.ts → hooks/__tests__/utils.spec.d.ts} +0 -0
@@ -0,0 +1,7 @@
1
+ {
2
+ "version": 3,
3
+ "sources": ["../../../../../src/FieldArray/FormDialog/ArrayDisplay/ArrayContainerDisplay.tsx"],
4
+ "sourcesContent": ["import React from 'react';\nimport { ArrayItemHeader } from '@digigov/form/FieldArray/FormDialog/ArrayDisplay/ArrayItemHeader';\nimport { Table, TableBody, TableContainer } from '@digigov/ui/content';\n\nexport interface ArrayContainerDisplayProps {\n fieldArrayValues: any[];\n ofField: any;\n customField: any;\n children: React.ReactNode;\n}\n\nexport const ArrayContainerDisplay = ({\n fieldArrayValues,\n ofField,\n customField,\n children,\n}: ArrayContainerDisplayProps) => {\n return (\n <>\n {customField?.extra?.layout === 'card' ? (\n children\n ) : (\n <TableContainer {...customField.extra?.tableContainer}>\n <Table verticalAlign={customField.extra?.verticalAlign}>\n {!customField.extra?.noHeader &&\n ofField?.extra &&\n fieldArrayValues?.length > 0 && (\n <ArrayItemHeader\n labels={\n ofField.type === 'object'\n ? ofField.extra.fields.map(({ label }) => label.primary)\n : [ofField.label.primary]\n }\n disabled={customField?.editable === false}\n />\n )}\n <TableBody>{children}</TableBody>\n </Table>\n </TableContainer>\n )}\n </>\n );\n};\n\nexport default ArrayContainerDisplay;\n"],
5
+ "mappings": ";;;;;;;;;;;;;;;;;;;;;;;;;;;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,mBAAkB;AAClB,6BAAgC;AAChC,qBAAiD;AAS1C,MAAM,wBAAwB,CAAC;AAAA,EACpC;AAAA,EACA;AAAA,EACA;AAAA,EACA;AACF,MAAkC;AAChC,SACE,6BAAAA,QAAA,2BAAAA,QAAA,gBACG,aAAa,OAAO,WAAW,SAC9B,WAEA,6BAAAA,QAAA,cAAC,iCAAgB,GAAG,YAAY,OAAO,kBACrC,6BAAAA,QAAA,cAAC,wBAAM,eAAe,YAAY,OAAO,iBACtC,CAAC,YAAY,OAAO,YACnB,SAAS,SACT,kBAAkB,SAAS,KACzB,6BAAAA,QAAA;AAAA,IAAC;AAAA;AAAA,MACC,QACE,QAAQ,SAAS,WACb,QAAQ,MAAM,OAAO,IAAI,CAAC,EAAE,MAAM,MAAM,MAAM,OAAO,IACrD,CAAC,QAAQ,MAAM,OAAO;AAAA,MAE5B,UAAU,aAAa,aAAa;AAAA;AAAA,EACtC,GAEJ,6BAAAA,QAAA,cAAC,gCAAW,QAAS,CACvB,CACF,CAEJ;AAEJ;AAEA,IAAO,gCAAQ;",
6
+ "names": ["React"]
7
+ }
@@ -0,0 +1,209 @@
1
+ var __create = Object.create;
2
+ var __defProp = Object.defineProperty;
3
+ var __getOwnPropDesc = Object.getOwnPropertyDescriptor;
4
+ var __getOwnPropNames = Object.getOwnPropertyNames;
5
+ var __getProtoOf = Object.getPrototypeOf;
6
+ var __hasOwnProp = Object.prototype.hasOwnProperty;
7
+ var __export = (target, all) => {
8
+ for (var name in all)
9
+ __defProp(target, name, { get: all[name], enumerable: true });
10
+ };
11
+ var __copyProps = (to, from, except, desc) => {
12
+ if (from && typeof from === "object" || typeof from === "function") {
13
+ for (let key of __getOwnPropNames(from))
14
+ if (!__hasOwnProp.call(to, key) && key !== except)
15
+ __defProp(to, key, { get: () => from[key], enumerable: !(desc = __getOwnPropDesc(from, key)) || desc.enumerable });
16
+ }
17
+ return to;
18
+ };
19
+ var __toESM = (mod, isNodeMode, target) => (target = mod != null ? __create(__getProtoOf(mod)) : {}, __copyProps(
20
+ // If the importer is in node compatibility mode or this is not an ESM
21
+ // file that has been converted to a CommonJS file using a Babel-
22
+ // compatible transform (i.e. "__esModule" has not been set), then set
23
+ // "default" to the CommonJS "module.exports" for node compatibility.
24
+ isNodeMode || !mod || !mod.__esModule ? __defProp(target, "default", { value: mod, enumerable: true }) : target,
25
+ mod
26
+ ));
27
+ var __toCommonJS = (mod) => __copyProps(__defProp({}, "__esModule", { value: true }), mod);
28
+ var ArrayItemDisplay_exports = {};
29
+ __export(ArrayItemDisplay_exports, {
30
+ ArrayItemDisplay: () => ArrayItemDisplay
31
+ });
32
+ module.exports = __toCommonJS(ArrayItemDisplay_exports);
33
+ var import_react = __toESM(require("react"));
34
+ var import_utils = require("@digigov/form/utils");
35
+ var import_ui = require("@digigov/ui");
36
+ var import_content = require("@digigov/ui/content");
37
+ var import_Button = require("@digigov/ui/form/Button");
38
+ var import_layouts = require("@digigov/ui/layouts");
39
+ var import_Heading = __toESM(require("@digigov/ui/typography/Heading"));
40
+ var import_NormalText = require("@digigov/ui/typography/NormalText");
41
+ const ArrayItemDisplay = ({
42
+ name,
43
+ data,
44
+ edit,
45
+ remove,
46
+ disabledEdit,
47
+ disabledDelete,
48
+ disabled,
49
+ sortable,
50
+ index,
51
+ isFirst,
52
+ isLast,
53
+ move,
54
+ valueDisplay,
55
+ border = true,
56
+ wordBreak = "break-all",
57
+ stackProps = {
58
+ spacing: 4,
59
+ alignItems: "flex-end",
60
+ justifyContent: "flex-end",
61
+ direction: "column"
62
+ },
63
+ customField,
64
+ ofField,
65
+ fieldArrayValues,
66
+ error
67
+ }) => {
68
+ if (data === void 0 || data === null) {
69
+ return null;
70
+ }
71
+ if (Object.keys(data).length === 0 || Object.keys(data).length === 1 && data.id) {
72
+ return null;
73
+ }
74
+ const values = typeof data === "string" ? [data] : Object.values(data ? (0, import_utils.omit)(data, ["id"]) : {});
75
+ const borderVariant = border === false || sortable ? "none" : "border";
76
+ const hasItemButtons = !disabled && (!disabledEdit || !disabledDelete);
77
+ const fieldLabel = ofField?.type === "object" ? ofField?.extra?.fields.reduce(
78
+ (acc, { key, label }) => ({
79
+ ...acc,
80
+ [key]: label.primary
81
+ }),
82
+ {}
83
+ ) : ofField?.label?.primary;
84
+ return /* @__PURE__ */ import_react.default.createElement(import_react.default.Fragment, null, customField?.extra?.layout === "card" ? /* @__PURE__ */ import_react.default.createElement(
85
+ import_content.Card,
86
+ {
87
+ borderColor: "light",
88
+ variant: "border",
89
+ dense: true,
90
+ ...customField?.extra.cardContainer
91
+ },
92
+ sortable && /* @__PURE__ */ import_react.default.createElement(import_Heading.default, { size: "sm" }, "\u0395\u03C0\u03B9\u03BB\u03BF\u03B3\u03AE #", index + 1),
93
+ /* @__PURE__ */ import_react.default.createElement(import_content.SummaryList, { mb: 0, noLastBorder: !hasItemButtons, error: !!error }, error && Object.keys(error).length > 0 && Object.entries(error).map(([fieldKey, fieldError]) => /* @__PURE__ */ import_react.default.createElement(import_ui.ErrorMessage, { key: fieldKey, id: `${name}-error` }, `${ofField?.type === "object" && ofField?.extra?.fields ? `${fieldLabel[fieldKey] || fieldKey}: ` : ""}`, fieldError.message)), values?.map?.((value, valueIndex) => {
94
+ const key = ofField?.type === "object" ? ofField?.extra?.fields?.[valueIndex]?.key : ofField?.key;
95
+ const label = ofField?.type === "object" ? fieldLabel[key] : fieldLabel;
96
+ const shouldShowKey = !customField?.extra?.noHeader && ofField?.extra && fieldArrayValues?.length > 0;
97
+ return /* @__PURE__ */ import_react.default.createElement(import_content.SummaryListItem, { key: valueIndex }, shouldShowKey && /* @__PURE__ */ import_react.default.createElement(
98
+ import_content.SummaryListItemKey,
99
+ {
100
+ error: !!error && Object.keys(error)?.includes(key)
101
+ },
102
+ label
103
+ ), /* @__PURE__ */ import_react.default.createElement(
104
+ import_content.SummaryListItemValue,
105
+ {
106
+ error: !shouldShowKey && !!error && Object.keys(error)?.includes(key)
107
+ },
108
+ value?.name || (Array.isArray(value) ? value.join("\n") : valueDisplay ? valueDisplay(value) : value) || ""
109
+ ));
110
+ })),
111
+ disabled === true || disabledEdit === true && disabledDelete === true ? null : /* @__PURE__ */ import_react.default.createElement(import_Button.ButtonGroup, { mb: 0, ...customField?.extra?.cardButtonGroup }, disabledEdit !== true && /* @__PURE__ */ import_react.default.createElement(
112
+ import_Button.Button,
113
+ {
114
+ variant: "link",
115
+ type: "button",
116
+ onClick: () => {
117
+ edit(name);
118
+ }
119
+ },
120
+ "\u0395\u03C0\u03B5\u03BE\u03B5\u03C1\u03B3\u03B1\u03C3\u03AF\u03B1"
121
+ ), disabledDelete !== true && /* @__PURE__ */ import_react.default.createElement(
122
+ import_Button.Button,
123
+ {
124
+ variant: "link",
125
+ type: "button",
126
+ onClick: () => remove(name)
127
+ },
128
+ "\u0394\u03B9\u03B1\u03B3\u03C1\u03B1\u03C6\u03AE"
129
+ )),
130
+ sortable && /* @__PURE__ */ import_react.default.createElement(import_react.default.Fragment, null, /* @__PURE__ */ import_react.default.createElement(import_layouts.SectionBreak, null), sortable && !disabled && !(isFirst && isLast) && /* @__PURE__ */ import_react.default.createElement(import_NormalText.NormalText, { mb: 0 }, "\u039C\u03B5\u03C4\u03B1\u03BA\u03AF\u03BD\u03B7\u03C3\u03B7", " ", !isFirst && /* @__PURE__ */ import_react.default.createElement(import_react.default.Fragment, null, "\u03C0\u03C1\u03BF\u03C2 \u03C4\u03B1", " ", /* @__PURE__ */ import_react.default.createElement(
131
+ import_Button.Button,
132
+ {
133
+ type: "button",
134
+ variant: "link",
135
+ onClick: () => move(index, index - 1)
136
+ },
137
+ "\u03C0\u03AC\u03BD\u03C9"
138
+ )), !isFirst && !isLast && " \u03AE ", !isLast && /* @__PURE__ */ import_react.default.createElement(import_react.default.Fragment, null, "\u03C0\u03C1\u03BF\u03C2 \u03C4\u03B1", " ", /* @__PURE__ */ import_react.default.createElement(
139
+ import_Button.Button,
140
+ {
141
+ type: "button",
142
+ variant: "link",
143
+ onClick: () => move(index, index + 1)
144
+ },
145
+ "\u03BA\u03AC\u03C4\u03C9"
146
+ ))))
147
+ ) : /* @__PURE__ */ import_react.default.createElement(import_react.default.Fragment, null, /* @__PURE__ */ import_react.default.createElement(import_content.TableRow, null, values?.map?.((value, valueIndex) => {
148
+ const fieldKey = ofField?.type === "object" ? ofField?.extra?.fields?.[valueIndex]?.key : ofField?.key;
149
+ return /* @__PURE__ */ import_react.default.createElement(
150
+ import_content.TableDataCell,
151
+ {
152
+ key: valueIndex,
153
+ variant: borderVariant,
154
+ wordBreak,
155
+ pb: sortable ? 0 : void 0,
156
+ pt: sortable ? 4 : void 0,
157
+ highlight: !!error && Object.keys(error)?.includes(fieldKey) ? "error" : void 0
158
+ },
159
+ sortable && valueIndex === 0 && /* @__PURE__ */ import_react.default.createElement(import_Heading.default, { size: "sm", mb: 2 }, "\u0395\u03C0\u03B9\u03BB\u03BF\u03B3\u03AE #", index + 1),
160
+ value?.name || (Array.isArray(value) ? value.join("\n") : valueDisplay ? valueDisplay(value) : value) || ""
161
+ );
162
+ }), disabled === true || disabledEdit === true && disabledDelete === true ? null : /* @__PURE__ */ import_react.default.createElement(import_content.TableDataCell, { variant: borderVariant }, /* @__PURE__ */ import_react.default.createElement(import_layouts.Stack, { ...stackProps }, disabledEdit !== true && /* @__PURE__ */ import_react.default.createElement(
163
+ import_Button.Button,
164
+ {
165
+ variant: "link",
166
+ type: "button",
167
+ onClick: () => {
168
+ edit(name);
169
+ }
170
+ },
171
+ "\u0395\u03C0\u03B5\u03BE\u03B5\u03C1\u03B3\u03B1\u03C3\u03AF\u03B1"
172
+ ), disabledDelete !== true && /* @__PURE__ */ import_react.default.createElement(
173
+ import_Button.Button,
174
+ {
175
+ variant: "link",
176
+ type: "button",
177
+ onClick: () => remove(name)
178
+ },
179
+ "\u0394\u03B9\u03B1\u03B3\u03C1\u03B1\u03C6\u03AE"
180
+ )))), sortable && /* @__PURE__ */ import_react.default.createElement(import_content.TableRow, null, /* @__PURE__ */ import_react.default.createElement(
181
+ import_content.TableDataCell,
182
+ {
183
+ variant: isLast ? "none" : "border",
184
+ colSpan: disabled === true || disabledEdit === true && disabledDelete === true ? values.length : values.length + 1
185
+ },
186
+ sortable && !disabled && !(isFirst && isLast) && /* @__PURE__ */ import_react.default.createElement(import_layouts.Grid, { xs: 12, mt: 2 }, "\u039C\u03B5\u03C4\u03B1\u03BA\u03AF\u03BD\u03B7\u03C3\u03B7", " ", !isFirst && /* @__PURE__ */ import_react.default.createElement(import_react.default.Fragment, null, "\u03C0\u03C1\u03BF\u03C2 \u03C4\u03B1", " ", /* @__PURE__ */ import_react.default.createElement(
187
+ import_Button.Button,
188
+ {
189
+ type: "button",
190
+ variant: "link",
191
+ onClick: () => move(index, index - 1)
192
+ },
193
+ "\u03C0\u03AC\u03BD\u03C9"
194
+ )), !isFirst && !isLast && " \u03AE ", !isLast && /* @__PURE__ */ import_react.default.createElement(import_react.default.Fragment, null, "\u03C0\u03C1\u03BF\u03C2 \u03C4\u03B1", " ", /* @__PURE__ */ import_react.default.createElement(
195
+ import_Button.Button,
196
+ {
197
+ type: "button",
198
+ variant: "link",
199
+ onClick: () => move(index, index + 1)
200
+ },
201
+ "\u03BA\u03AC\u03C4\u03C9"
202
+ )))
203
+ ))));
204
+ };
205
+ // Annotate the CommonJS export names for ESM import in node:
206
+ 0 && (module.exports = {
207
+ ArrayItemDisplay
208
+ });
209
+ //# sourceMappingURL=ArrayItemDisplay.js.map
@@ -0,0 +1,7 @@
1
+ {
2
+ "version": 3,
3
+ "sources": ["../../../../../src/FieldArray/FormDialog/ArrayDisplay/ArrayItemDisplay.tsx"],
4
+ "sourcesContent": ["import React from 'react';\nimport type { ErrorOption, UseFieldArrayMove } from 'react-hook-form';\nimport { omit } from '@digigov/form/utils';\nimport { ErrorMessage } from '@digigov/ui';\nimport {\n Card,\n SummaryList,\n SummaryListItem,\n SummaryListItemKey,\n SummaryListItemValue,\n TableDataCell,\n TableRow,\n} from '@digigov/ui/content';\nimport { Button, ButtonGroup } from '@digigov/ui/form/Button';\nimport type { StackProps } from '@digigov/ui/layouts';\nimport { Grid, SectionBreak, Stack } from '@digigov/ui/layouts';\nimport Heading from '@digigov/ui/typography/Heading';\nimport { NormalText } from '@digigov/ui/typography/NormalText';\n\nexport interface ArrayItemDisplayProps {\n data: any;\n name: string;\n edit: (name: string) => void;\n remove: (name: string) => void;\n disabledEdit?: boolean;\n disabledDelete?: boolean;\n disabled?: boolean;\n sortable: boolean;\n index: number;\n isFirst: boolean;\n isLast: boolean;\n move: UseFieldArrayMove;\n valueDisplay?: (value) => React.ReactNode;\n border: boolean;\n wordBreak?: 'break-all' | 'none';\n stackProps?: StackProps;\n customField: any;\n ofField: any;\n fieldArrayValues: any[];\n error?: Record<string, ErrorOption> | undefined;\n}\n\nexport const ArrayItemDisplay = ({\n name,\n data,\n edit,\n remove,\n disabledEdit,\n disabledDelete,\n disabled,\n sortable,\n index,\n isFirst,\n isLast,\n move,\n valueDisplay,\n border = true,\n wordBreak = 'break-all',\n stackProps = {\n spacing: 4,\n alignItems: 'flex-end',\n justifyContent: 'flex-end',\n direction: 'column',\n },\n customField,\n ofField,\n fieldArrayValues,\n error,\n}: ArrayItemDisplayProps) => {\n if (data === undefined || data === null) {\n return null;\n }\n if (\n Object.keys(data).length === 0 ||\n (Object.keys(data).length === 1 && data.id)\n ) {\n return null;\n }\n const values: (string | Record<string, any>)[] =\n typeof data === 'string'\n ? [data]\n : Object.values(data ? omit(data, ['id']) : {});\n const borderVariant = border === false || sortable ? 'none' : 'border';\n // Show last border if there are action buttons to separate buttons from item values\n const hasItemButtons = !disabled && (!disabledEdit || !disabledDelete);\n\n const fieldLabel: Record<string, string> | string =\n ofField?.type === 'object'\n ? ofField?.extra?.fields.reduce(\n (acc: Record<string, string>, { key, label }) => ({\n ...acc,\n [key]: label.primary,\n }),\n {}\n )\n : ofField?.label?.primary;\n\n return (\n <>\n {customField?.extra?.layout === 'card' ? (\n <Card\n borderColor=\"light\"\n variant=\"border\"\n dense\n {...customField?.extra.cardContainer}\n >\n {sortable && <Heading size=\"sm\">\u0395\u03C0\u03B9\u03BB\u03BF\u03B3\u03AE #{index + 1}</Heading>}\n <SummaryList mb={0} noLastBorder={!hasItemButtons} error={!!error}>\n {error &&\n Object.keys(error).length > 0 &&\n Object.entries(error).map(([fieldKey, fieldError]) => (\n <ErrorMessage key={fieldKey} id={`${name}-error`}>\n {`${\n ofField?.type === 'object' && ofField?.extra?.fields\n ? `${fieldLabel[fieldKey] || fieldKey}: `\n : ''\n }`}\n {\n fieldError.message /* This is expected to be a SafeHTML component, not a string */\n }\n </ErrorMessage>\n ))}\n {values?.map?.((value, valueIndex) => {\n const key =\n ofField?.type === 'object'\n ? ofField?.extra?.fields?.[valueIndex]?.key\n : ofField?.key;\n const label =\n ofField?.type === 'object' ? fieldLabel[key] : fieldLabel;\n\n const shouldShowKey =\n !customField?.extra?.noHeader &&\n ofField?.extra &&\n fieldArrayValues?.length > 0;\n\n return (\n <SummaryListItem key={valueIndex}>\n {shouldShowKey && (\n <SummaryListItemKey\n error={!!error && Object.keys(error)?.includes(key)}\n >\n {label}\n </SummaryListItemKey>\n )}\n <SummaryListItemValue\n error={\n !shouldShowKey &&\n !!error &&\n Object.keys(error)?.includes(key)\n }\n >\n {(value as Record<string, any>)?.name ||\n (Array.isArray(value)\n ? value.join('\\n')\n : valueDisplay\n ? valueDisplay(value)\n : value) ||\n ''}\n </SummaryListItemValue>\n </SummaryListItem>\n );\n })}\n </SummaryList>\n {disabled === true ||\n (disabledEdit === true && disabledDelete === true) ? null : (\n <ButtonGroup mb={0} {...customField?.extra?.cardButtonGroup}>\n {disabledEdit !== true && (\n <Button\n variant=\"link\"\n type=\"button\"\n onClick={() => {\n edit(name);\n }}\n >\n \u0395\u03C0\u03B5\u03BE\u03B5\u03C1\u03B3\u03B1\u03C3\u03AF\u03B1\n </Button>\n )}\n {disabledDelete !== true && (\n <Button\n variant=\"link\"\n type=\"button\"\n onClick={() => remove(name)}\n >\n \u0394\u03B9\u03B1\u03B3\u03C1\u03B1\u03C6\u03AE\n </Button>\n )}\n </ButtonGroup>\n )}\n {sortable && (\n <>\n <SectionBreak />\n {sortable && !disabled && !(isFirst && isLast) && (\n <NormalText mb={0}>\n \u039C\u03B5\u03C4\u03B1\u03BA\u03AF\u03BD\u03B7\u03C3\u03B7{' '}\n {!isFirst && (\n <>\n \u03C0\u03C1\u03BF\u03C2 \u03C4\u03B1{' '}\n <Button\n type=\"button\"\n variant=\"link\"\n onClick={() => move(index, index - 1)}\n >\n \u03C0\u03AC\u03BD\u03C9\n </Button>\n </>\n )}\n {!isFirst && !isLast && ' \u03AE '}\n {!isLast && (\n <>\n \u03C0\u03C1\u03BF\u03C2 \u03C4\u03B1{' '}\n <Button\n type=\"button\"\n variant=\"link\"\n onClick={() => move(index, index + 1)}\n >\n \u03BA\u03AC\u03C4\u03C9\n </Button>\n </>\n )}\n </NormalText>\n )}\n </>\n )}\n </Card>\n ) : (\n <>\n <TableRow>\n {values?.map?.((value, valueIndex) => {\n const fieldKey =\n ofField?.type === 'object'\n ? ofField?.extra?.fields?.[valueIndex]?.key\n : ofField?.key;\n return (\n <TableDataCell\n key={valueIndex}\n variant={borderVariant}\n wordBreak={wordBreak}\n pb={sortable ? 0 : undefined}\n pt={sortable ? 4 : undefined}\n highlight={\n !!error && Object.keys(error)?.includes(fieldKey)\n ? 'error'\n : undefined\n }\n >\n {sortable && valueIndex === 0 && (\n <Heading size=\"sm\" mb={2}>\n \u0395\u03C0\u03B9\u03BB\u03BF\u03B3\u03AE #{index + 1}\n </Heading>\n )}\n {(value as Record<string, any>)?.name ||\n (Array.isArray(value)\n ? value.join('\\n')\n : valueDisplay\n ? valueDisplay(value)\n : value) ||\n ''}\n </TableDataCell>\n );\n })}\n {disabled === true ||\n (disabledEdit === true && disabledDelete === true) ? null : (\n <TableDataCell variant={borderVariant}>\n <Stack {...stackProps}>\n {disabledEdit !== true && (\n <Button\n variant=\"link\"\n type=\"button\"\n onClick={() => {\n edit(name);\n }}\n >\n \u0395\u03C0\u03B5\u03BE\u03B5\u03C1\u03B3\u03B1\u03C3\u03AF\u03B1\n </Button>\n )}\n {disabledDelete !== true && (\n <Button\n variant=\"link\"\n type=\"button\"\n onClick={() => remove(name)}\n >\n \u0394\u03B9\u03B1\u03B3\u03C1\u03B1\u03C6\u03AE\n </Button>\n )}\n </Stack>\n </TableDataCell>\n )}\n </TableRow>\n {sortable && (\n <TableRow>\n <TableDataCell\n variant={isLast ? 'none' : 'border'}\n colSpan={\n disabled === true ||\n (disabledEdit === true && disabledDelete === true)\n ? values.length\n : values.length + 1\n }\n >\n {sortable && !disabled && !(isFirst && isLast) && (\n <Grid xs={12} mt={2}>\n \u039C\u03B5\u03C4\u03B1\u03BA\u03AF\u03BD\u03B7\u03C3\u03B7{' '}\n {!isFirst && (\n <>\n \u03C0\u03C1\u03BF\u03C2 \u03C4\u03B1{' '}\n <Button\n type=\"button\"\n variant=\"link\"\n onClick={() => move(index, index - 1)}\n >\n \u03C0\u03AC\u03BD\u03C9\n </Button>\n </>\n )}\n {!isFirst && !isLast && ' \u03AE '}\n {!isLast && (\n <>\n \u03C0\u03C1\u03BF\u03C2 \u03C4\u03B1{' '}\n <Button\n type=\"button\"\n variant=\"link\"\n onClick={() => move(index, index + 1)}\n >\n \u03BA\u03AC\u03C4\u03C9\n </Button>\n </>\n )}\n </Grid>\n )}\n </TableDataCell>\n </TableRow>\n )}\n </>\n )}\n </>\n );\n};\n"],
5
+ "mappings": "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",
6
+ "names": ["React", "Heading"]
7
+ }
@@ -25,11 +25,20 @@ var __toESM = (mod, isNodeMode, target) => (target = mod != null ? __create(__ge
25
25
  mod
26
26
  ));
27
27
  var __toCommonJS = (mod) => __copyProps(__defProp({}, "__esModule", { value: true }), mod);
28
- var el_exports = {};
29
- __export(el_exports, {
30
- default: () => el_default
28
+ var ArrayItemHeader_exports = {};
29
+ __export(ArrayItemHeader_exports, {
30
+ ArrayItemHeader: () => ArrayItemHeader
31
31
  });
32
- module.exports = __toCommonJS(el_exports);
33
- var import_el = __toESM(require("@digigov/ui/i18n/locales/el"));
34
- var el_default = import_el.default;
35
- //# sourceMappingURL=el.js.map
32
+ module.exports = __toCommonJS(ArrayItemHeader_exports);
33
+ var import_react = __toESM(require("react"));
34
+ var import_content = require("@digigov/ui/content");
35
+ const ArrayItemHeader = ({ labels, disabled }) => {
36
+ return /* @__PURE__ */ import_react.default.createElement(import_content.TableHead, null, /* @__PURE__ */ import_react.default.createElement(import_content.TableRow, null, labels.map((label, index) => {
37
+ return /* @__PURE__ */ import_react.default.createElement(import_content.TableHeadCell, { key: index }, label);
38
+ }), !disabled && /* @__PURE__ */ import_react.default.createElement(import_content.TableHeadCell, null, "\u0395\u03BD\u03AD\u03C1\u03B3\u03B5\u03B9\u03B5\u03C2")));
39
+ };
40
+ // Annotate the CommonJS export names for ESM import in node:
41
+ 0 && (module.exports = {
42
+ ArrayItemHeader
43
+ });
44
+ //# sourceMappingURL=ArrayItemHeader.js.map
@@ -0,0 +1,7 @@
1
+ {
2
+ "version": 3,
3
+ "sources": ["../../../../../src/FieldArray/FormDialog/ArrayDisplay/ArrayItemHeader.tsx"],
4
+ "sourcesContent": ["import React from 'react';\nimport { TableHead, TableHeadCell, TableRow } from '@digigov/ui/content';\n\nexport const ArrayItemHeader = ({ labels, disabled }) => {\n return (\n <TableHead>\n <TableRow>\n {labels.map((label, index) => {\n return <TableHeadCell key={index}>{label}</TableHeadCell>;\n })}\n {!disabled && <TableHeadCell>\u0395\u03BD\u03AD\u03C1\u03B3\u03B5\u03B9\u03B5\u03C2</TableHeadCell>}\n </TableRow>\n </TableHead>\n );\n};\n"],
5
+ "mappings": ";;;;;;;;;;;;;;;;;;;;;;;;;;;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,mBAAkB;AAClB,qBAAmD;AAE5C,MAAM,kBAAkB,CAAC,EAAE,QAAQ,SAAS,MAAM;AACvD,SACE,6BAAAA,QAAA,cAAC,gCACC,6BAAAA,QAAA,cAAC,+BACE,OAAO,IAAI,CAAC,OAAO,UAAU;AAC5B,WAAO,6BAAAA,QAAA,cAAC,gCAAc,KAAK,SAAQ,KAAM;AAAA,EAC3C,CAAC,GACA,CAAC,YAAY,6BAAAA,QAAA,cAAC,oCAAc,wDAAS,CACxC,CACF;AAEJ;",
6
+ "names": ["React"]
7
+ }
@@ -0,0 +1,90 @@
1
+ var __create = Object.create;
2
+ var __defProp = Object.defineProperty;
3
+ var __getOwnPropDesc = Object.getOwnPropertyDescriptor;
4
+ var __getOwnPropNames = Object.getOwnPropertyNames;
5
+ var __getProtoOf = Object.getPrototypeOf;
6
+ var __hasOwnProp = Object.prototype.hasOwnProperty;
7
+ var __export = (target, all) => {
8
+ for (var name in all)
9
+ __defProp(target, name, { get: all[name], enumerable: true });
10
+ };
11
+ var __copyProps = (to, from, except, desc) => {
12
+ if (from && typeof from === "object" || typeof from === "function") {
13
+ for (let key of __getOwnPropNames(from))
14
+ if (!__hasOwnProp.call(to, key) && key !== except)
15
+ __defProp(to, key, { get: () => from[key], enumerable: !(desc = __getOwnPropDesc(from, key)) || desc.enumerable });
16
+ }
17
+ return to;
18
+ };
19
+ var __toESM = (mod, isNodeMode, target) => (target = mod != null ? __create(__getProtoOf(mod)) : {}, __copyProps(
20
+ // If the importer is in node compatibility mode or this is not an ESM
21
+ // file that has been converted to a CommonJS file using a Babel-
22
+ // compatible transform (i.e. "__esModule" has not been set), then set
23
+ // "default" to the CommonJS "module.exports" for node compatibility.
24
+ isNodeMode || !mod || !mod.__esModule ? __defProp(target, "default", { value: mod, enumerable: true }) : target,
25
+ mod
26
+ ));
27
+ var __toCommonJS = (mod) => __copyProps(__defProp({}, "__esModule", { value: true }), mod);
28
+ var ArrayDisplay_exports = {};
29
+ __export(ArrayDisplay_exports, {
30
+ ArrayDisplay: () => ArrayDisplay,
31
+ default: () => ArrayDisplay_default
32
+ });
33
+ module.exports = __toCommonJS(ArrayDisplay_exports);
34
+ var import_react = __toESM(require("react"));
35
+ var import_ArrayContainerDisplay = require("@digigov/form/FieldArray/FormDialog/ArrayDisplay/ArrayContainerDisplay");
36
+ var import_ArrayItemDisplay = require("@digigov/form/FieldArray/FormDialog/ArrayDisplay/ArrayItemDisplay");
37
+ const ArrayDisplay = ({
38
+ fieldArrayName,
39
+ fieldArrayValues,
40
+ ofField,
41
+ customField,
42
+ onEdit,
43
+ onRemove,
44
+ move,
45
+ sortable,
46
+ error
47
+ }) => {
48
+ return /* @__PURE__ */ import_react.default.createElement(
49
+ import_ArrayContainerDisplay.ArrayContainerDisplay,
50
+ {
51
+ fieldArrayValues,
52
+ ofField,
53
+ customField
54
+ },
55
+ fieldArrayValues?.map?.((field, index) => {
56
+ return /* @__PURE__ */ import_react.default.createElement(
57
+ import_ArrayItemDisplay.ArrayItemDisplay,
58
+ {
59
+ error: error && error[index] ? error[index] : void 0,
60
+ key: index,
61
+ name: `${fieldArrayName}.${index}`,
62
+ index,
63
+ isFirst: index === 0,
64
+ isLast: index === fieldArrayValues.length - 1,
65
+ data: field,
66
+ edit: () => onEdit(index),
67
+ stackProps: customField?.extra?.stackProps,
68
+ wordBreak: customField?.extra?.wordBreak,
69
+ valueDisplay: customField?.extra?.valueDisplay,
70
+ remove: () => onRemove(index),
71
+ border: customField.extra?.border,
72
+ move,
73
+ sortable,
74
+ disabledEdit: sortable ? true : customField.extra?.noEdit ?? false,
75
+ disabledDelete: customField.extra?.noDelete ?? false,
76
+ disabled: customField?.editable === false,
77
+ fieldArrayValues,
78
+ ofField,
79
+ customField
80
+ }
81
+ );
82
+ })
83
+ );
84
+ };
85
+ var ArrayDisplay_default = ArrayDisplay;
86
+ // Annotate the CommonJS export names for ESM import in node:
87
+ 0 && (module.exports = {
88
+ ArrayDisplay
89
+ });
90
+ //# sourceMappingURL=index.js.map
@@ -0,0 +1,7 @@
1
+ {
2
+ "version": 3,
3
+ "sources": ["../../../../../src/FieldArray/FormDialog/ArrayDisplay/index.tsx"],
4
+ "sourcesContent": ["import React from 'react';\nimport type { UseFieldArrayMove } from 'react-hook-form';\nimport { ArrayContainerDisplay } from '@digigov/form/FieldArray/FormDialog/ArrayDisplay/ArrayContainerDisplay';\nimport { ArrayItemDisplay } from '@digigov/form/FieldArray/FormDialog/ArrayDisplay/ArrayItemDisplay';\nexport interface ArrayDisplayProps {\n fieldArrayName: string;\n fieldArrayValues: any[];\n ofField: any;\n customField: any;\n onEdit: (index: number) => void;\n onRemove: (index: number) => void;\n move: UseFieldArrayMove;\n sortable: boolean;\n error?: any;\n}\n\nexport const ArrayDisplay = ({\n fieldArrayName,\n fieldArrayValues,\n ofField,\n customField,\n onEdit,\n onRemove,\n move,\n sortable,\n error,\n}: ArrayDisplayProps) => {\n return (\n <ArrayContainerDisplay\n fieldArrayValues={fieldArrayValues}\n ofField={ofField}\n customField={customField}\n >\n {fieldArrayValues?.map?.((field, index) => {\n return (\n <ArrayItemDisplay\n error={error && error[index] ? error[index] : undefined}\n key={index}\n name={`${fieldArrayName}.${index}`}\n index={index}\n isFirst={index === 0}\n isLast={index === fieldArrayValues.length - 1}\n data={field}\n edit={() => onEdit(index)}\n stackProps={customField?.extra?.stackProps}\n wordBreak={customField?.extra?.wordBreak}\n valueDisplay={customField?.extra?.valueDisplay}\n remove={() => onRemove(index)}\n border={customField.extra?.border}\n move={move}\n sortable={sortable}\n disabledEdit={\n sortable ? true : (customField.extra?.noEdit ?? false)\n }\n disabledDelete={customField.extra?.noDelete ?? false}\n disabled={customField?.editable === false}\n fieldArrayValues={fieldArrayValues}\n ofField={ofField}\n customField={customField}\n />\n );\n })}\n </ArrayContainerDisplay>\n );\n};\n\nexport default ArrayDisplay;\n"],
5
+ "mappings": ";;;;;;;;;;;;;;;;;;;;;;;;;;;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,mBAAkB;AAElB,mCAAsC;AACtC,8BAAiC;AAa1B,MAAM,eAAe,CAAC;AAAA,EAC3B;AAAA,EACA;AAAA,EACA;AAAA,EACA;AAAA,EACA;AAAA,EACA;AAAA,EACA;AAAA,EACA;AAAA,EACA;AACF,MAAyB;AACvB,SACE,6BAAAA,QAAA;AAAA,IAAC;AAAA;AAAA,MACC;AAAA,MACA;AAAA,MACA;AAAA;AAAA,IAEC,kBAAkB,MAAM,CAAC,OAAO,UAAU;AACzC,aACE,6BAAAA,QAAA;AAAA,QAAC;AAAA;AAAA,UACC,OAAO,SAAS,MAAM,KAAK,IAAI,MAAM,KAAK,IAAI;AAAA,UAC9C,KAAK;AAAA,UACL,MAAM,GAAG,cAAc,IAAI,KAAK;AAAA,UAChC;AAAA,UACA,SAAS,UAAU;AAAA,UACnB,QAAQ,UAAU,iBAAiB,SAAS;AAAA,UAC5C,MAAM;AAAA,UACN,MAAM,MAAM,OAAO,KAAK;AAAA,UACxB,YAAY,aAAa,OAAO;AAAA,UAChC,WAAW,aAAa,OAAO;AAAA,UAC/B,cAAc,aAAa,OAAO;AAAA,UAClC,QAAQ,MAAM,SAAS,KAAK;AAAA,UAC5B,QAAQ,YAAY,OAAO;AAAA,UAC3B;AAAA,UACA;AAAA,UACA,cACE,WAAW,OAAQ,YAAY,OAAO,UAAU;AAAA,UAElD,gBAAgB,YAAY,OAAO,YAAY;AAAA,UAC/C,UAAU,aAAa,aAAa;AAAA,UACpC;AAAA,UACA;AAAA,UACA;AAAA;AAAA,MACF;AAAA,IAEJ,CAAC;AAAA,EACH;AAEJ;AAEA,IAAO,uBAAQ;",
6
+ "names": ["React"]
7
+ }
@@ -0,0 +1,186 @@
1
+ var __create = Object.create;
2
+ var __defProp = Object.defineProperty;
3
+ var __getOwnPropDesc = Object.getOwnPropertyDescriptor;
4
+ var __getOwnPropNames = Object.getOwnPropertyNames;
5
+ var __getProtoOf = Object.getPrototypeOf;
6
+ var __hasOwnProp = Object.prototype.hasOwnProperty;
7
+ var __export = (target, all) => {
8
+ for (var name in all)
9
+ __defProp(target, name, { get: all[name], enumerable: true });
10
+ };
11
+ var __copyProps = (to, from, except, desc) => {
12
+ if (from && typeof from === "object" || typeof from === "function") {
13
+ for (let key of __getOwnPropNames(from))
14
+ if (!__hasOwnProp.call(to, key) && key !== except)
15
+ __defProp(to, key, { get: () => from[key], enumerable: !(desc = __getOwnPropDesc(from, key)) || desc.enumerable });
16
+ }
17
+ return to;
18
+ };
19
+ var __toESM = (mod, isNodeMode, target) => (target = mod != null ? __create(__getProtoOf(mod)) : {}, __copyProps(
20
+ // If the importer is in node compatibility mode or this is not an ESM
21
+ // file that has been converted to a CommonJS file using a Babel-
22
+ // compatible transform (i.e. "__esModule" has not been set), then set
23
+ // "default" to the CommonJS "module.exports" for node compatibility.
24
+ isNodeMode || !mod || !mod.__esModule ? __defProp(target, "default", { value: mod, enumerable: true }) : target,
25
+ mod
26
+ ));
27
+ var __toCommonJS = (mod) => __copyProps(__defProp({}, "__esModule", { value: true }), mod);
28
+ var ArrayEditModal_exports = {};
29
+ __export(ArrayEditModal_exports, {
30
+ ArrayEditModal: () => ArrayEditModal
31
+ });
32
+ module.exports = __toCommonJS(ArrayEditModal_exports);
33
+ var import_react = __toESM(require("react"));
34
+ var import_react_dom = require("react-dom");
35
+ var import_react_hook_form = require("react-hook-form");
36
+ var import_FieldObject = require("@digigov/form/FieldObject");
37
+ var import_Fieldset = require("@digigov/form/Fieldset");
38
+ var import_FormContext = require("@digigov/form/FormContext");
39
+ var import_utils = require("@digigov/form/utils");
40
+ var import_validators = require("@digigov/form/validators");
41
+ var import_Modal = require("@digigov/ui/app/Modal");
42
+ var import_Button = require("@digigov/ui/form/Button");
43
+ var import_Hint = require("@digigov/ui/typography/Hint");
44
+ const ArrayEditModal = import_react.default.forwardRef(function ArrayEditModal2({
45
+ type,
46
+ title,
47
+ hint,
48
+ defaultValue,
49
+ editOrAppend,
50
+ cancel,
51
+ addTitle,
52
+ editLabel,
53
+ editProps,
54
+ appendLabel,
55
+ appendProps,
56
+ cancelLabel,
57
+ cancelProps,
58
+ ofField,
59
+ error: customErrors,
60
+ Field,
61
+ ...modalProps
62
+ }, ref) {
63
+ const parentCtx = (0, import_FormContext.useFormContext)();
64
+ const schema = (0, import_validators.useValidationSchema)(
65
+ ofField.type === "object" && ofField.extra.fields ? Object.values(ofField.extra.fields) : [ofField]
66
+ );
67
+ const resolver = (0, import_react.useMemo)(() => {
68
+ if (!schema) return;
69
+ return (0, import_utils.yupResolver)(schema);
70
+ }, [schema]);
71
+ const parentFormOptions = parentCtx.control._options;
72
+ const form = (0, import_react_hook_form.useForm)({
73
+ resolver,
74
+ mode: parentFormOptions.mode,
75
+ reValidateMode: parentFormOptions.reValidateMode,
76
+ shouldFocusError: true,
77
+ // TODO: Consider using our own focus manager
78
+ criteriaMode: parentFormOptions.criteriaMode
79
+ });
80
+ const { reset, setValue, setError } = form;
81
+ (0, import_react.useEffect)(() => {
82
+ if (modalProps.open) {
83
+ reset(void 0);
84
+ if (type === "edit" && customErrors) {
85
+ for (const [key, error] of Object.entries(customErrors)) {
86
+ setError(
87
+ key,
88
+ typeof error === "string" ? { message: error } : error
89
+ );
90
+ }
91
+ }
92
+ if (defaultValue) {
93
+ Object.entries(defaultValue).forEach(([key, value]) => {
94
+ setValue(key, value);
95
+ });
96
+ }
97
+ if (type === "append" && ofField?.type === "object" && ofField.extra?.fields) {
98
+ ofField.extra.fields.forEach((field) => {
99
+ if (defaultValue && defaultValue[field.key] !== void 0) return;
100
+ switch (field.type) {
101
+ case "array":
102
+ setValue(field.key, []);
103
+ break;
104
+ case "object":
105
+ setValue(field.key, {});
106
+ break;
107
+ default:
108
+ setValue(field.key, "");
109
+ }
110
+ });
111
+ }
112
+ }
113
+ }, [modalProps.open, defaultValue, reset, setValue, type, ofField]);
114
+ const onSubmit = (0, import_react.useCallback)(
115
+ (data) => {
116
+ editOrAppend(data);
117
+ },
118
+ [editOrAppend]
119
+ );
120
+ const handleSubmitWithoutPropagation = (e) => {
121
+ e.preventDefault();
122
+ e.stopPropagation();
123
+ return form.handleSubmit(onSubmit)(e);
124
+ };
125
+ const formRef = (0, import_react.useRef)(null);
126
+ const ctx = {
127
+ ...parentCtx,
128
+ control: form.control,
129
+ register: form.register,
130
+ watch: form.watch,
131
+ resetField: form.resetField,
132
+ registerField: () => {
133
+ },
134
+ // If we use parent registerField, validation breaks
135
+ registerFieldFocus: () => {
136
+ return () => {
137
+ };
138
+ },
139
+ errors: form.formState.errors,
140
+ formState: form.formState,
141
+ reset: form.reset,
142
+ trigger: form.trigger,
143
+ getFieldState: form.getFieldState,
144
+ setValue: form.setValue,
145
+ clearErrors: form.clearErrors,
146
+ getValues: form.getValues,
147
+ getValuesFromParentForm: parentCtx.getValues,
148
+ unregister: form.unregister,
149
+ setError: form.setError,
150
+ formRef,
151
+ submit: form.handleSubmit(onSubmit)
152
+ };
153
+ return /* @__PURE__ */ import_react.default.createElement(ModalPortal, { ...modalProps, ref, "aria-labelledby": "modal-label" }, /* @__PURE__ */ import_react.default.createElement(import_FormContext.FormContext.Provider, { value: ctx }, /* @__PURE__ */ import_react.default.createElement("form", { onSubmit: handleSubmitWithoutPropagation, ref: formRef }, /* @__PURE__ */ import_react.default.createElement(import_Modal.ModalHeading, { id: "modal-label" }, title ? title : type === "edit" ? "\u0395\u03C0\u03B5\u03BE\u03B5\u03C1\u03B3\u03B1\u03C3\u03AF\u03B1" : addTitle || "\u03A0\u03C1\u03BF\u03C3\u03B8\u03AE\u03BA\u03B7"), /* @__PURE__ */ import_react.default.createElement(import_Modal.ModalContent, null, hint && /* @__PURE__ */ import_react.default.createElement(import_Hint.Hint, null, hint), /* @__PURE__ */ import_react.default.createElement(import_Fieldset.Fieldset, null, ofField?.type === "object" ? /* @__PURE__ */ import_react.default.createElement(
154
+ import_FieldObject.FieldObject,
155
+ {
156
+ ...ofField,
157
+ defaultValue: defaultValue || void 0,
158
+ formState: form.formState,
159
+ register: form.register,
160
+ control: form.control,
161
+ name: void 0,
162
+ Field,
163
+ error: customErrors
164
+ }
165
+ ) : /* @__PURE__ */ import_react.default.createElement(Field, { error: customErrors, ...ofField }))), /* @__PURE__ */ import_react.default.createElement(import_Modal.ModalAction, null, type === "edit" ? /* @__PURE__ */ import_react.default.createElement(import_Button.Button, { color: "secondary", ...editProps, type: "submit" }, editLabel || "\u0391\u03C0\u03BF\u03B8\u03AE\u03BA\u03B5\u03C5\u03C3\u03B7") : /* @__PURE__ */ import_react.default.createElement(import_Button.Button, { color: "primary", ...appendProps, type: "submit" }, appendLabel || "\u03A0\u03C1\u03BF\u03C3\u03B8\u03AE\u03BA\u03B7"), /* @__PURE__ */ import_react.default.createElement(
166
+ import_Button.Button,
167
+ {
168
+ variant: "link",
169
+ type: "button",
170
+ ...cancelProps,
171
+ onClick: (e) => {
172
+ e.preventDefault();
173
+ cancel();
174
+ }
175
+ },
176
+ cancelLabel || "\u0391\u03BA\u03CD\u03C1\u03C9\u03C3\u03B7"
177
+ )))));
178
+ });
179
+ const ModalPortal = (props) => {
180
+ return (0, import_react_dom.createPortal)(/* @__PURE__ */ import_react.default.createElement(import_Modal.Modal, { ...props }), document.body);
181
+ };
182
+ // Annotate the CommonJS export names for ESM import in node:
183
+ 0 && (module.exports = {
184
+ ArrayEditModal
185
+ });
186
+ //# sourceMappingURL=ArrayEditModal.js.map
@@ -0,0 +1,7 @@
1
+ {
2
+ "version": 3,
3
+ "sources": ["../../../../src/FieldArray/FormDialog/ArrayEditModal.tsx"],
4
+ "sourcesContent": ["import React, { useCallback, useEffect, useMemo, useRef } from 'react';\nimport { createPortal } from 'react-dom';\nimport type { ErrorOption, UseFormProps } from 'react-hook-form';\nimport { useForm } from 'react-hook-form';\nimport type {\n FieldProps,\n FieldSpec,\n FormData,\n} from '@digigov/form/Field/types';\nimport { FieldObject } from '@digigov/form/FieldObject';\nimport { Fieldset } from '@digigov/form/Fieldset';\nimport { FormContext, useFormContext } from '@digigov/form/FormContext';\nimport { yupResolver } from '@digigov/form/utils';\nimport { useValidationSchema } from '@digigov/form/validators';\nimport type { ModalProps } from '@digigov/ui/app/Modal';\nimport {\n Modal,\n ModalAction,\n ModalContent,\n ModalHeading,\n} from '@digigov/ui/app/Modal';\nimport { Button } from '@digigov/ui/form/Button';\nimport { Hint } from '@digigov/ui/typography/Hint';\n\nexport interface ArrayEditModalProps extends Omit<ModalProps, 'children'> {\n type: 'append' | 'edit';\n name: string;\n title?: string;\n hint?: string;\n editOrAppend: (data: FormData) => void;\n cancel: () => void;\n addTitle?: string;\n editLabel?: string;\n editProps?: any;\n appendLabel?: string;\n appendProps?: any;\n cancelLabel?: string;\n cancelProps?: any;\n ofField?: any;\n defaultValue?: any;\n Field: React.FC<FieldProps>;\n error?: ErrorOption;\n}\n\nexport const ArrayEditModal = React.forwardRef<\n HTMLDivElement,\n ArrayEditModalProps\n>(function ArrayEditModal(\n {\n type,\n title,\n hint,\n defaultValue,\n editOrAppend,\n cancel,\n addTitle,\n editLabel,\n editProps,\n appendLabel,\n appendProps,\n cancelLabel,\n cancelProps,\n ofField,\n error: customErrors,\n Field,\n ...modalProps\n },\n ref\n) {\n const parentCtx = useFormContext();\n const schema = useValidationSchema(\n ofField.type === 'object' && ofField.extra.fields\n ? Object.values(ofField.extra.fields)\n : [ofField]\n );\n\n const resolver: UseFormProps['resolver'] = useMemo(() => {\n if (!schema) return;\n\n return yupResolver(schema);\n }, [schema]);\n\n const parentFormOptions = parentCtx.control._options;\n const form = useForm({\n resolver,\n mode: parentFormOptions.mode,\n reValidateMode: parentFormOptions.reValidateMode,\n shouldFocusError: true, // TODO: Consider using our own focus manager\n criteriaMode: parentFormOptions.criteriaMode,\n });\n\n const { reset, setValue, setError } = form;\n\n // Reset form and set default values when modal opens\n useEffect(() => {\n if (modalProps.open) {\n // Reset form first to clear any previous values\n reset(undefined);\n\n // Set custom errors if in edit mode\n if (type === 'edit' && customErrors) {\n for (const [key, error] of Object.entries(customErrors)) {\n setError(\n key,\n typeof error === 'string' ? { message: error } : (error as any)\n );\n }\n }\n\n // Set default values if they exist\n if (defaultValue) {\n Object.entries(defaultValue).forEach(([key, value]) => {\n setValue(key, value);\n });\n }\n\n if (\n type === 'append' &&\n ofField?.type === 'object' &&\n ofField.extra?.fields\n ) {\n // For append mode, set empty values for all fields in case no defaultValue is provided\n ofField.extra.fields.forEach((field: FieldSpec) => {\n if (defaultValue && defaultValue[field.key] !== undefined) return;\n switch (field.type) {\n case 'array':\n setValue(field.key, []);\n break;\n case 'object':\n setValue(field.key, {});\n break;\n default:\n // TODO: This replicates legacy behaviour. Maybe reconsider this?\n setValue(field.key, '');\n }\n });\n }\n }\n }, [modalProps.open, defaultValue, reset, setValue, type, ofField]);\n\n const onSubmit = useCallback(\n (data: FormData): void => {\n editOrAppend(data);\n },\n [editOrAppend]\n );\n\n const handleSubmitWithoutPropagation = (e: React.FormEvent) => {\n e.preventDefault();\n e.stopPropagation();\n return form.handleSubmit(onSubmit)(e);\n };\n\n const formRef = useRef(null);\n\n const ctx = {\n ...parentCtx,\n control: form.control,\n register: form.register,\n watch: form.watch,\n resetField: form.resetField,\n registerField: () => {}, // If we use parent registerField, validation breaks\n registerFieldFocus: () => {\n return () => {};\n },\n errors: form.formState.errors,\n formState: form.formState,\n reset: form.reset,\n trigger: form.trigger,\n getFieldState: form.getFieldState,\n setValue: form.setValue,\n clearErrors: form.clearErrors,\n getValues: form.getValues,\n getValuesFromParentForm: parentCtx.getValues,\n unregister: form.unregister,\n setError: form.setError,\n formRef,\n submit: form.handleSubmit(onSubmit),\n };\n\n return (\n <ModalPortal {...modalProps} ref={ref} aria-labelledby=\"modal-label\">\n <FormContext.Provider value={ctx}>\n <form onSubmit={handleSubmitWithoutPropagation} ref={formRef}>\n <ModalHeading id=\"modal-label\">\n {title\n ? title\n : type === 'edit'\n ? '\u0395\u03C0\u03B5\u03BE\u03B5\u03C1\u03B3\u03B1\u03C3\u03AF\u03B1'\n : addTitle || '\u03A0\u03C1\u03BF\u03C3\u03B8\u03AE\u03BA\u03B7'}\n </ModalHeading>\n <ModalContent>\n {hint && <Hint>{hint}</Hint>}\n <Fieldset>\n {ofField?.type === 'object' ? (\n <FieldObject\n {...ofField}\n defaultValue={defaultValue || undefined}\n formState={form.formState}\n register={form.register}\n control={form.control}\n name={undefined}\n Field={Field}\n error={customErrors}\n />\n ) : (\n <Field error={customErrors} {...ofField} />\n )}\n </Fieldset>\n </ModalContent>\n <ModalAction>\n {type === 'edit' ? (\n <Button color=\"secondary\" {...editProps} type=\"submit\">\n {editLabel || '\u0391\u03C0\u03BF\u03B8\u03AE\u03BA\u03B5\u03C5\u03C3\u03B7'}\n </Button>\n ) : (\n <Button color=\"primary\" {...appendProps} type=\"submit\">\n {appendLabel || '\u03A0\u03C1\u03BF\u03C3\u03B8\u03AE\u03BA\u03B7'}\n </Button>\n )}\n <Button\n variant=\"link\"\n type=\"button\"\n {...cancelProps}\n onClick={(e) => {\n e.preventDefault();\n cancel();\n }}\n >\n {cancelLabel || '\u0391\u03BA\u03CD\u03C1\u03C9\u03C3\u03B7'}\n </Button>\n </ModalAction>\n </form>\n </FormContext.Provider>\n </ModalPortal>\n );\n});\n\nconst ModalPortal = (props: ModalProps) => {\n return createPortal(<Modal {...props} />, document.body);\n};\n"],
5
+ "mappings": "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",
6
+ "names": ["React", "ArrayEditModal"]
7
+ }