@digigov/form 2.0.0-85c27c19 → 2.0.0-8e254888

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 (584) hide show
  1. package/Field/ErrorGroup/index.js +48 -0
  2. package/{Form.stories → Field/ErrorGroup}/package.json +1 -1
  3. package/Field/ErrorGroup.d.ts +15 -0
  4. package/Field/ErrorGroup.js.map +7 -0
  5. package/Field/FieldBase/index.js +31 -22
  6. package/Field/FieldBase.js.map +2 -2
  7. package/Field/FieldBaseContainer/index.js +5 -4
  8. package/Field/FieldBaseContainer.js.map +2 -2
  9. package/Field/FieldConditional/index.js +7 -3
  10. package/Field/FieldConditional.js.map +2 -2
  11. package/Field/index.js +10 -2
  12. package/Field/index.js.map +2 -2
  13. package/Field/types.d.ts +15 -9
  14. package/Field/utils/index.d.ts +1 -0
  15. package/Field/utils/index.js +24 -1
  16. package/Field/utils/index.js.map +2 -2
  17. package/Field/utils/useField/index.js +7 -1
  18. package/Field/utils/useField.js.map +2 -2
  19. package/FieldArray/FieldArray.stories.d.ts +1 -0
  20. package/FieldArray/FormDialog/index.js +279 -0
  21. package/{Questions/Questions.stories → FieldArray/FormDialog}/package.json +1 -1
  22. package/FieldArray/FormDialog.d.ts +53 -0
  23. package/FieldArray/FormDialog.js.map +7 -0
  24. package/FieldArray/__stories__/WithModal.d.ts +2 -0
  25. package/FieldArray/index.d.ts +6 -0
  26. package/FieldArray/index.js +59 -23
  27. package/FieldArray/index.js.map +2 -2
  28. package/FieldObject/index.d.ts +4 -0
  29. package/FieldObject/index.js +16 -8
  30. package/FieldObject/index.js.map +2 -2
  31. package/Fieldset/index.d.ts +1 -1
  32. package/Fieldset/index.js +5 -5
  33. package/Fieldset/index.js.map +2 -2
  34. package/Fieldset/types.d.ts +2 -3
  35. package/FormBuilder/FormBuilder.stories.d.ts +2 -0
  36. package/FormBuilder/__stories__/AutoErrorGrouping.d.ts +3 -0
  37. package/FormBuilder/__stories__/ErrorGrouping.d.ts +3 -0
  38. package/FormBuilder/index.d.ts +8 -2
  39. package/FormBuilder/index.js +229 -6
  40. package/FormBuilder/index.js.map +3 -3
  41. package/FormBuilder/interaction.test.d.ts +1 -0
  42. package/FormContext.js.map +2 -2
  43. package/MultiplicityField/add-objects/index.js +11 -7
  44. package/MultiplicityField/add-objects.js.map +2 -2
  45. package/MultiplicityField/index.js +17 -12
  46. package/MultiplicityField/index.js.map +2 -2
  47. package/MultiplicityField/types.d.ts +1 -2
  48. package/Questions/Questions/index.js +5 -4
  49. package/Questions/Questions.js.map +2 -2
  50. package/Questions/QuestionsContext.d.ts +0 -1
  51. package/Questions/Step/StepArrayReview.js.map +2 -2
  52. package/Questions/Step/StepContext.d.ts +0 -1
  53. package/Questions/Step/StepTitle/index.js +4 -3
  54. package/Questions/Step/StepTitle.d.ts +1 -1
  55. package/Questions/Step/StepTitle.js.map +2 -2
  56. package/Questions/Step/types.d.ts +0 -1
  57. package/Questions/types.d.ts +0 -1
  58. package/cjs/Field/ErrorGroup/index.js +82 -0
  59. package/cjs/Field/ErrorGroup.js.map +7 -0
  60. package/cjs/Field/FieldBase/index.js +30 -21
  61. package/cjs/Field/FieldBase.js.map +2 -2
  62. package/cjs/Field/FieldBaseContainer/index.js +5 -4
  63. package/cjs/Field/FieldBaseContainer.js.map +3 -3
  64. package/cjs/Field/FieldConditional/index.js +7 -3
  65. package/cjs/Field/FieldConditional.js.map +2 -2
  66. package/cjs/Field/index.js +10 -2
  67. package/cjs/Field/index.js.map +2 -2
  68. package/cjs/Field/types.js.map +1 -1
  69. package/cjs/Field/utils/index.js +24 -0
  70. package/cjs/Field/utils/index.js.map +3 -3
  71. package/cjs/Field/utils/useField/index.js +7 -1
  72. package/cjs/Field/utils/useField.js.map +2 -2
  73. package/cjs/FieldArray/FormDialog/index.js +301 -0
  74. package/cjs/FieldArray/FormDialog.js.map +7 -0
  75. package/cjs/FieldArray/index.js +58 -22
  76. package/cjs/FieldArray/index.js.map +3 -3
  77. package/cjs/FieldObject/index.js +17 -9
  78. package/cjs/FieldObject/index.js.map +3 -3
  79. package/cjs/Fieldset/index.js +10 -10
  80. package/cjs/Fieldset/index.js.map +3 -3
  81. package/cjs/Fieldset/types.js.map +1 -1
  82. package/cjs/FormBuilder/index.js +244 -5
  83. package/cjs/FormBuilder/index.js.map +3 -3
  84. package/cjs/FormContext/index.js +2 -2
  85. package/cjs/FormContext.js.map +3 -3
  86. package/cjs/MultiplicityField/add-objects/index.js +15 -11
  87. package/cjs/MultiplicityField/add-objects.js.map +3 -3
  88. package/cjs/MultiplicityField/index.js +16 -16
  89. package/cjs/MultiplicityField/index.js.map +3 -3
  90. package/cjs/MultiplicityField/types.js.map +1 -1
  91. package/cjs/Questions/Questions/index.js +5 -4
  92. package/cjs/Questions/Questions.js.map +2 -2
  93. package/cjs/Questions/Step/StepArrayReview.js.map +2 -2
  94. package/cjs/Questions/Step/StepTitle/index.js +5 -5
  95. package/cjs/Questions/Step/StepTitle.js.map +3 -3
  96. package/cjs/index.js +11 -155
  97. package/cjs/index.js.map +4 -4
  98. package/cjs/inputs/AutoCompleteInput/index.js +12 -9
  99. package/cjs/inputs/AutoCompleteInput/index.js.map +3 -3
  100. package/cjs/inputs/Checkboxes/index.js +9 -9
  101. package/cjs/inputs/Checkboxes/index.js.map +3 -3
  102. package/cjs/inputs/DateInput/index.js +10 -8
  103. package/cjs/inputs/DateInput/index.js.map +3 -3
  104. package/cjs/inputs/DateTimeInput/index.js +211 -0
  105. package/cjs/inputs/DateTimeInput/index.js.map +7 -0
  106. package/cjs/inputs/FileInput/index.js +41 -27
  107. package/cjs/inputs/FileInput/index.js.map +3 -3
  108. package/cjs/inputs/ImageInput/index.js +16 -10
  109. package/cjs/inputs/ImageInput/index.js.map +3 -3
  110. package/cjs/inputs/Input/index.js +29 -8
  111. package/cjs/inputs/Input/index.js.map +3 -3
  112. package/cjs/inputs/Input/inputsInputScenarios.js.map +2 -2
  113. package/cjs/inputs/Label/index.js +3 -3
  114. package/cjs/inputs/Label/index.js.map +3 -3
  115. package/cjs/inputs/OtpInput/index.js +1 -0
  116. package/cjs/inputs/OtpInput/index.js.map +2 -2
  117. package/cjs/inputs/Radio/index.js +57 -10
  118. package/cjs/inputs/Radio/index.js.map +3 -3
  119. package/cjs/inputs/Select/index.js +10 -5
  120. package/cjs/inputs/Select/index.js.map +3 -3
  121. package/cjs/inputs/inputsScenarios/index.js +4 -11
  122. package/cjs/inputs/inputsScenarios.js.map +2 -2
  123. package/cjs/lazy/index.js +49 -34
  124. package/cjs/lazy.js.map +3 -3
  125. package/cjs/locales/el.js.map +1 -1
  126. package/cjs/registry/index.js +72 -62
  127. package/cjs/registry.js.map +3 -3
  128. package/cjs/types.js.map +1 -1
  129. package/cjs/utils/index.js +2 -1
  130. package/cjs/utils.js.map +2 -2
  131. package/cjs/validators/index.js +44 -79
  132. package/cjs/validators/index.js.map +3 -3
  133. package/cjs/validators/utils/date/index.js +138 -0
  134. package/cjs/validators/utils/date.js.map +7 -0
  135. package/cjs/validators/utils/datetime/index.js +151 -0
  136. package/cjs/validators/utils/datetime.js.map +7 -0
  137. package/cjs/validators/utils/file/index.js +2 -2
  138. package/cjs/validators/utils/file.js.map +2 -2
  139. package/cjs/validators/utils/index.js +5 -1
  140. package/cjs/validators/utils/index.js.map +2 -2
  141. package/cjs/validators/utils/int/index.js +1 -1
  142. package/cjs/validators/utils/int.js.map +2 -2
  143. package/cjs/validators/utils/number/index.js +1 -1
  144. package/cjs/validators/utils/number.js.map +2 -2
  145. package/cjs/validators/utils/phone.js.map +2 -2
  146. package/cjs/validators/utils/postal_code.js.map +1 -1
  147. package/cjs/validators/utils/uuid4.js.map +2 -2
  148. package/index.d.ts +5 -8
  149. package/index.js +9 -152
  150. package/index.js.map +4 -4
  151. package/inputs/AutoCompleteInput/index.d.ts +1 -1
  152. package/inputs/AutoCompleteInput/index.js +14 -9
  153. package/inputs/AutoCompleteInput/index.js.map +2 -2
  154. package/inputs/Checkboxes/index.d.ts +1 -1
  155. package/inputs/Checkboxes/index.js +10 -6
  156. package/inputs/Checkboxes/index.js.map +2 -2
  157. package/inputs/DateInput/index.d.ts +1 -2
  158. package/inputs/DateInput/index.js +12 -7
  159. package/inputs/DateInput/index.js.map +2 -2
  160. package/inputs/DateTimeInput/DateTimeInput.stories.d.ts +7 -0
  161. package/inputs/DateTimeInput/__stories__/Default.d.ts +3 -0
  162. package/inputs/DateTimeInput/index.d.ts +13 -0
  163. package/inputs/DateTimeInput/index.js +181 -0
  164. package/inputs/DateTimeInput/index.js.map +7 -0
  165. package/inputs/DateTimeInput/index.test.d.ts +1 -0
  166. package/inputs/{Input/Input.stories → DateTimeInput}/package.json +1 -1
  167. package/inputs/FileInput/index.d.ts +9 -0
  168. package/inputs/FileInput/index.js +41 -27
  169. package/inputs/FileInput/index.js.map +2 -2
  170. package/inputs/ImageInput/ImageInput.stories.d.ts +1 -1
  171. package/inputs/ImageInput/__stories__/MaxSize.d.ts +3 -0
  172. package/inputs/ImageInput/index.js +15 -9
  173. package/inputs/ImageInput/index.js.map +2 -2
  174. package/inputs/Input/Input.stories.d.ts +1 -0
  175. package/inputs/Input/__stories__/StringWithTrimValidation.d.ts +3 -0
  176. package/inputs/Input/index.js +27 -6
  177. package/inputs/Input/index.js.map +3 -3
  178. package/inputs/Input/inputsInputScenarios.js.map +2 -2
  179. package/inputs/Label/index.d.ts +0 -2
  180. package/inputs/Label/index.js +2 -2
  181. package/inputs/Label/index.js.map +2 -2
  182. package/inputs/OtpInput/index.js +1 -0
  183. package/inputs/OtpInput/index.js.map +2 -2
  184. package/inputs/Radio/index.d.ts +5 -1
  185. package/inputs/Radio/index.js +58 -8
  186. package/inputs/Radio/index.js.map +2 -2
  187. package/inputs/Select/index.d.ts +1 -1
  188. package/inputs/Select/index.js +11 -3
  189. package/inputs/Select/index.js.map +2 -2
  190. package/inputs/inputsScenarios/index.js +4 -11
  191. package/inputs/inputsScenarios.d.ts +0 -42
  192. package/inputs/inputsScenarios.js.map +2 -2
  193. package/lazy/index.js +76 -65
  194. package/locales/el.js.map +1 -1
  195. package/package.json +4 -4
  196. package/registry/index.js +116 -107
  197. package/src/Field/ErrorGroup.tsx +84 -0
  198. package/src/Field/FieldBase.tsx +34 -22
  199. package/src/Field/FieldBaseContainer.tsx +7 -4
  200. package/src/Field/FieldConditional.tsx +4 -0
  201. package/src/Field/index.tsx +9 -1
  202. package/src/Field/types.tsx +15 -8
  203. package/src/Field/utils/index.ts +24 -1
  204. package/src/Field/utils/useField.ts +7 -3
  205. package/src/FieldArray/FieldArray.stories.js +1 -0
  206. package/src/FieldArray/FormDialog.tsx +378 -0
  207. package/src/FieldArray/__stories__/Default.tsx +1 -0
  208. package/src/FieldArray/__stories__/WithExactLength.tsx +1 -0
  209. package/src/FieldArray/__stories__/WithModal.tsx +159 -0
  210. package/src/FieldArray/index.test.tsx +4 -0
  211. package/src/FieldArray/index.tsx +88 -43
  212. package/src/FieldObject/index.tsx +17 -5
  213. package/src/Fieldset/index.tsx +5 -5
  214. package/src/Fieldset/types.tsx +2 -2
  215. package/src/FormBuilder/FormBuilder.stories.js +2 -0
  216. package/src/FormBuilder/__stories__/AutoErrorGrouping.tsx +63 -0
  217. package/src/FormBuilder/__stories__/ErrorGrouping.tsx +43 -0
  218. package/src/FormBuilder/{FormBuilder.mdx → doc.mdx} +20 -33
  219. package/src/FormBuilder/index.test.tsx +8 -0
  220. package/src/FormBuilder/index.tsx +264 -7
  221. package/src/FormBuilder/interaction.test.tsx +32 -0
  222. package/src/FormBuilder/scenarios.test.tsx +121 -7
  223. package/src/FormContext.tsx +1 -2
  224. package/src/MultiplicityField/add-objects.tsx +10 -8
  225. package/src/MultiplicityField/{MultiplicityField.mdx → doc.mdx} +12 -16
  226. package/src/MultiplicityField/index.tsx +16 -12
  227. package/src/MultiplicityField/types.ts +1 -2
  228. package/src/Questions/Questions.tsx +4 -4
  229. package/src/Questions/Step/StepArrayReview.tsx +1 -1
  230. package/src/Questions/Step/StepTitle.tsx +4 -3
  231. package/src/Questions/__snapshots__/index.spec.tsx.snap +10 -5
  232. package/src/Questions/{index.mdx → doc.mdx} +9 -12
  233. package/src/Questions/index.spec.tsx +14 -2
  234. package/src/create-simple-form.mdx +2 -6
  235. package/src/{index.mdx → doc.mdx} +4 -8
  236. package/src/index.ts +6 -0
  237. package/src/inputs/AutoCompleteInput/__stories__/Default.tsx +2 -10
  238. package/src/inputs/AutoCompleteInput/__stories__/Multiple.tsx +1 -8
  239. package/src/inputs/AutoCompleteInput/{index.mdx → doc.mdx} +2 -13
  240. package/src/inputs/AutoCompleteInput/index.tsx +37 -31
  241. package/src/inputs/Checkboxes/{index.mdx → doc.mdx} +5 -15
  242. package/src/inputs/Checkboxes/index.tsx +12 -8
  243. package/src/inputs/DateInput/__stories__/Default.tsx +7 -12
  244. package/src/inputs/DateInput/{index.mdx → doc.mdx} +1 -8
  245. package/src/inputs/DateInput/index.tsx +12 -7
  246. package/src/inputs/DateTimeInput/DateTimeInput.stories.js +8 -0
  247. package/src/inputs/DateTimeInput/__stories__/Default.tsx +25 -0
  248. package/src/inputs/DateTimeInput/doc.mdx +16 -0
  249. package/src/inputs/DateTimeInput/index.test.tsx +20 -0
  250. package/src/inputs/DateTimeInput/index.tsx +194 -0
  251. package/src/inputs/FileInput/{index.mdx → doc.mdx} +1 -5
  252. package/src/inputs/FileInput/index.tsx +33 -10
  253. package/src/inputs/ImageInput/ImageInput.stories.js +1 -1
  254. package/src/inputs/ImageInput/__stories__/MaxSize.tsx +37 -0
  255. package/src/inputs/ImageInput/__stories__/WithInvalidImageDimension.tsx +2 -0
  256. package/src/inputs/ImageInput/doc.mdx +23 -0
  257. package/src/inputs/ImageInput/index.test.tsx +4 -0
  258. package/src/inputs/ImageInput/index.tsx +17 -16
  259. package/src/inputs/Input/Input.stories.js +1 -0
  260. package/src/inputs/Input/__stories__/LandlineNumber.tsx +2 -1
  261. package/src/inputs/Input/__stories__/MobilePhone.tsx +1 -0
  262. package/src/inputs/Input/__stories__/PhoneNumber.tsx +1 -0
  263. package/src/inputs/Input/__stories__/PostalCode.tsx +1 -0
  264. package/src/inputs/Input/__stories__/StringWithTrimValidation.tsx +26 -0
  265. package/src/inputs/Input/__stories__/TextWithLimit.tsx +1 -0
  266. package/src/inputs/Input/doc.mdx +56 -0
  267. package/src/inputs/Input/index.test.tsx +4 -0
  268. package/src/inputs/Input/index.tsx +41 -30
  269. package/src/inputs/Input/inputsInputScenarios.ts +244 -245
  270. package/src/inputs/Label/doc.mdx +14 -0
  271. package/src/inputs/Label/index.tsx +2 -6
  272. package/src/inputs/OtpInput/{index.mdx → doc.mdx} +1 -8
  273. package/src/inputs/OtpInput/index.tsx +3 -1
  274. package/src/inputs/Radio/__stories__/Conditional.tsx +2 -1
  275. package/src/inputs/Radio/{index.mdx → doc.mdx} +5 -15
  276. package/src/inputs/Radio/index.tsx +77 -10
  277. package/src/inputs/Select/{index.mdx → doc.mdx} +1 -5
  278. package/src/inputs/Select/index.tsx +12 -4
  279. package/src/inputs/inputsScenarios.ts +174 -181
  280. package/src/installation.mdx +2 -5
  281. package/src/lazy.js +76 -62
  282. package/src/locales/el.ts +1 -1
  283. package/src/registry.js +108 -100
  284. package/src/types.tsx +3 -2
  285. package/src/utils.ts +2 -2
  286. package/src/validators/index.ts +86 -85
  287. package/src/validators/utils/date.ts +107 -0
  288. package/src/validators/utils/datetime.ts +130 -0
  289. package/src/validators/utils/file.ts +5 -3
  290. package/src/validators/utils/index.ts +2 -0
  291. package/src/validators/utils/int.ts +1 -1
  292. package/src/validators/utils/number.ts +1 -1
  293. package/src/validators/utils/phone.ts +1 -1
  294. package/src/validators/utils/postal_code.ts +1 -1
  295. package/src/validators/utils/uuid4.ts +2 -1
  296. package/src/validators/validators.spec.ts +3 -3
  297. package/types.d.ts +3 -3
  298. package/types.js.map +1 -1
  299. package/utils/index.js +2 -1
  300. package/utils.js.map +2 -2
  301. package/validators/index.js +51 -80
  302. package/validators/index.js.map +2 -2
  303. package/validators/utils/date/index.js +103 -0
  304. package/{FieldArray/FieldArray.stories → validators/utils/date}/package.json +1 -1
  305. package/validators/utils/date.d.ts +9 -0
  306. package/validators/utils/date.js.map +7 -0
  307. package/validators/utils/datetime/index.js +116 -0
  308. package/validators/utils/datetime/package.json +6 -0
  309. package/validators/utils/datetime.d.ts +9 -0
  310. package/validators/utils/datetime.js.map +7 -0
  311. package/validators/utils/file/index.js +2 -2
  312. package/validators/utils/file.js.map +2 -2
  313. package/validators/utils/index.d.ts +2 -0
  314. package/validators/utils/index.js +2 -0
  315. package/validators/utils/index.js.map +2 -2
  316. package/validators/utils/int/index.js +1 -1
  317. package/validators/utils/int.js.map +2 -2
  318. package/validators/utils/number/index.js +1 -1
  319. package/validators/utils/number.js.map +2 -2
  320. package/validators/utils/phone.d.ts +1 -1
  321. package/validators/utils/phone.js.map +2 -2
  322. package/validators/utils/postal_code.d.ts +1 -1
  323. package/validators/utils/postal_code.js.map +1 -1
  324. package/validators/utils/uuid4.js.map +2 -2
  325. package/FieldArray/FieldArray.stories/index.js +0 -14
  326. package/FieldArray/FieldArray.stories.js.map +0 -7
  327. package/FieldArray/__stories__/Default/index.js +0 -95
  328. package/FieldArray/__stories__/Default/package.json +0 -6
  329. package/FieldArray/__stories__/Default.js.map +0 -7
  330. package/FieldArray/__stories__/WithExactLength/index.js +0 -95
  331. package/FieldArray/__stories__/WithExactLength/package.json +0 -6
  332. package/FieldArray/__stories__/WithExactLength.js.map +0 -7
  333. package/Form.stories/index.js +0 -7
  334. package/Form.stories.js.map +0 -7
  335. package/FormBuilder/FormBuilder.stories/index.js +0 -12
  336. package/FormBuilder/FormBuilder.stories/package.json +0 -6
  337. package/FormBuilder/FormBuilder.stories.js.map +0 -7
  338. package/FormBuilder/__stories__/Default/index.js +0 -32
  339. package/FormBuilder/__stories__/Default/package.json +0 -6
  340. package/FormBuilder/__stories__/Default.js.map +0 -7
  341. package/MultiplicityField/MultiplicityField.stories/index.js +0 -22
  342. package/MultiplicityField/MultiplicityField.stories/package.json +0 -6
  343. package/MultiplicityField/MultiplicityField.stories.js.map +0 -7
  344. package/MultiplicityField/__stories__/Default/index.js +0 -100
  345. package/MultiplicityField/__stories__/Default/package.json +0 -6
  346. package/MultiplicityField/__stories__/Default.js.map +0 -7
  347. package/MultiplicityField/__stories__/PreviewDisplay/index.js +0 -70
  348. package/MultiplicityField/__stories__/PreviewDisplay/package.json +0 -6
  349. package/MultiplicityField/__stories__/PreviewDisplay.js.map +0 -7
  350. package/MultiplicityField/__stories__/WithExactLength/index.js +0 -97
  351. package/MultiplicityField/__stories__/WithExactLength/package.json +0 -6
  352. package/MultiplicityField/__stories__/WithExactLength.js.map +0 -7
  353. package/MultiplicityField/__stories__/WithMaxLength/index.js +0 -100
  354. package/MultiplicityField/__stories__/WithMaxLength/package.json +0 -6
  355. package/MultiplicityField/__stories__/WithMaxLength.js.map +0 -7
  356. package/MultiplicityField/__stories__/WithMinAndMaxLength/index.js +0 -101
  357. package/MultiplicityField/__stories__/WithMinAndMaxLength/package.json +0 -6
  358. package/MultiplicityField/__stories__/WithMinAndMaxLength.js.map +0 -7
  359. package/MultiplicityField/__stories__/WithMinLength/index.js +0 -100
  360. package/MultiplicityField/__stories__/WithMinLength/package.json +0 -6
  361. package/MultiplicityField/__stories__/WithMinLength.js.map +0 -7
  362. package/Questions/Questions.stories/index.js +0 -12
  363. package/Questions/Questions.stories.js.map +0 -7
  364. package/Questions/__stories__/Default/index.js +0 -108
  365. package/Questions/__stories__/Default/package.json +0 -6
  366. package/Questions/__stories__/Default.js.map +0 -7
  367. package/cjs/FieldArray/FieldArray.stories/index.js +0 -48
  368. package/cjs/FieldArray/FieldArray.stories.js.map +0 -7
  369. package/cjs/FieldArray/__stories__/Default/index.js +0 -128
  370. package/cjs/FieldArray/__stories__/Default.js.map +0 -7
  371. package/cjs/FieldArray/__stories__/WithExactLength/index.js +0 -128
  372. package/cjs/FieldArray/__stories__/WithExactLength.js.map +0 -7
  373. package/cjs/Form.stories/index.js +0 -26
  374. package/cjs/Form.stories.js.map +0 -7
  375. package/cjs/FormBuilder/FormBuilder.stories/index.js +0 -45
  376. package/cjs/FormBuilder/FormBuilder.stories.js.map +0 -7
  377. package/cjs/FormBuilder/__stories__/Default/index.js +0 -65
  378. package/cjs/FormBuilder/__stories__/Default.js.map +0 -7
  379. package/cjs/MultiplicityField/MultiplicityField.stories/index.js +0 -60
  380. package/cjs/MultiplicityField/MultiplicityField.stories.js.map +0 -7
  381. package/cjs/MultiplicityField/__stories__/Default/index.js +0 -133
  382. package/cjs/MultiplicityField/__stories__/Default.js.map +0 -7
  383. package/cjs/MultiplicityField/__stories__/PreviewDisplay/index.js +0 -86
  384. package/cjs/MultiplicityField/__stories__/PreviewDisplay.js.map +0 -7
  385. package/cjs/MultiplicityField/__stories__/WithExactLength/index.js +0 -130
  386. package/cjs/MultiplicityField/__stories__/WithExactLength.js.map +0 -7
  387. package/cjs/MultiplicityField/__stories__/WithMaxLength/index.js +0 -133
  388. package/cjs/MultiplicityField/__stories__/WithMaxLength.js.map +0 -7
  389. package/cjs/MultiplicityField/__stories__/WithMinAndMaxLength/index.js +0 -134
  390. package/cjs/MultiplicityField/__stories__/WithMinAndMaxLength.js.map +0 -7
  391. package/cjs/MultiplicityField/__stories__/WithMinLength/index.js +0 -133
  392. package/cjs/MultiplicityField/__stories__/WithMinLength.js.map +0 -7
  393. package/cjs/Questions/Questions.stories/index.js +0 -45
  394. package/cjs/Questions/Questions.stories.js.map +0 -7
  395. package/cjs/Questions/__stories__/Default/index.js +0 -136
  396. package/cjs/Questions/__stories__/Default.js.map +0 -7
  397. package/cjs/inputs/AutoCompleteInput/AutoComplete.stories/index.js +0 -48
  398. package/cjs/inputs/AutoCompleteInput/AutoComplete.stories.js.map +0 -7
  399. package/cjs/inputs/AutoCompleteInput/__stories__/Default/index.js +0 -83
  400. package/cjs/inputs/AutoCompleteInput/__stories__/Default.js.map +0 -7
  401. package/cjs/inputs/AutoCompleteInput/__stories__/Multiple/index.js +0 -84
  402. package/cjs/inputs/AutoCompleteInput/__stories__/Multiple.js.map +0 -7
  403. package/cjs/inputs/Checkboxes/Checkboxes.stories/index.js +0 -51
  404. package/cjs/inputs/Checkboxes/Checkboxes.stories.js.map +0 -7
  405. package/cjs/inputs/Checkboxes/__stories__/Conditional/index.js +0 -133
  406. package/cjs/inputs/Checkboxes/__stories__/Conditional.js.map +0 -7
  407. package/cjs/inputs/Checkboxes/__stories__/Default/index.js +0 -77
  408. package/cjs/inputs/Checkboxes/__stories__/Default.js.map +0 -7
  409. package/cjs/inputs/Checkboxes/__stories__/WithDivider/index.js +0 -78
  410. package/cjs/inputs/Checkboxes/__stories__/WithDivider.js.map +0 -7
  411. package/cjs/inputs/DateInput/DateInput.stories/index.js +0 -45
  412. package/cjs/inputs/DateInput/DateInput.stories.js.map +0 -7
  413. package/cjs/inputs/DateInput/__stories__/Default/index.js +0 -61
  414. package/cjs/inputs/DateInput/__stories__/Default.js.map +0 -7
  415. package/cjs/inputs/FileInput/FileInput.stories/index.js +0 -45
  416. package/cjs/inputs/FileInput/FileInput.stories.js.map +0 -7
  417. package/cjs/inputs/FileInput/__stories__/Default/index.js +0 -61
  418. package/cjs/inputs/FileInput/__stories__/Default.js.map +0 -7
  419. package/cjs/inputs/ImageInput/ImageInput.stories/index.js +0 -51
  420. package/cjs/inputs/ImageInput/ImageInput.stories.js.map +0 -7
  421. package/cjs/inputs/ImageInput/__stories__/Default/index.js +0 -63
  422. package/cjs/inputs/ImageInput/__stories__/Default.js.map +0 -7
  423. package/cjs/inputs/ImageInput/__stories__/WithInvalidImageDimension/index.js +0 -71
  424. package/cjs/inputs/ImageInput/__stories__/WithInvalidImageDimension.js.map +0 -7
  425. package/cjs/inputs/ImageInput/__stories__/WithInvalidImageSize/index.js +0 -68
  426. package/cjs/inputs/ImageInput/__stories__/WithInvalidImageSize.js.map +0 -7
  427. package/cjs/inputs/Input/Input.stories/index.js +0 -72
  428. package/cjs/inputs/Input/Input.stories.js.map +0 -7
  429. package/cjs/inputs/Input/__stories__/AFM/index.js +0 -63
  430. package/cjs/inputs/Input/__stories__/AFM.js.map +0 -7
  431. package/cjs/inputs/Input/__stories__/Boolean/index.js +0 -64
  432. package/cjs/inputs/Input/__stories__/Boolean.js.map +0 -7
  433. package/cjs/inputs/Input/__stories__/IBAN/index.js +0 -64
  434. package/cjs/inputs/Input/__stories__/IBAN.js.map +0 -7
  435. package/cjs/inputs/Input/__stories__/Integer/index.js +0 -78
  436. package/cjs/inputs/Input/__stories__/Integer.js.map +0 -7
  437. package/cjs/inputs/Input/__stories__/LandlineNumber/index.js +0 -67
  438. package/cjs/inputs/Input/__stories__/LandlineNumber.js.map +0 -7
  439. package/cjs/inputs/Input/__stories__/MobilePhone/index.js +0 -67
  440. package/cjs/inputs/Input/__stories__/MobilePhone.js.map +0 -7
  441. package/cjs/inputs/Input/__stories__/PhoneNumber/index.js +0 -66
  442. package/cjs/inputs/Input/__stories__/PhoneNumber.js.map +0 -7
  443. package/cjs/inputs/Input/__stories__/PostalCode/index.js +0 -64
  444. package/cjs/inputs/Input/__stories__/PostalCode.js.map +0 -7
  445. package/cjs/inputs/Input/__stories__/String/index.js +0 -64
  446. package/cjs/inputs/Input/__stories__/String.js.map +0 -7
  447. package/cjs/inputs/Input/__stories__/TextWithLimit/index.js +0 -64
  448. package/cjs/inputs/Input/__stories__/TextWithLimit.js.map +0 -7
  449. package/cjs/inputs/Label/Label.stories/index.js +0 -45
  450. package/cjs/inputs/Label/Label.stories.js.map +0 -7
  451. package/cjs/inputs/Label/__stories__/Default/index.js +0 -72
  452. package/cjs/inputs/Label/__stories__/Default.js.map +0 -7
  453. package/cjs/inputs/OtpInput/OtpInput.stories/index.js +0 -45
  454. package/cjs/inputs/OtpInput/OtpInput.stories.js.map +0 -7
  455. package/cjs/inputs/OtpInput/__stories__/Default/index.js +0 -64
  456. package/cjs/inputs/OtpInput/__stories__/Default.js.map +0 -7
  457. package/cjs/inputs/Radio/Radio.stories/index.js +0 -51
  458. package/cjs/inputs/Radio/Radio.stories.js.map +0 -7
  459. package/cjs/inputs/Radio/__stories__/Conditional/index.js +0 -133
  460. package/cjs/inputs/Radio/__stories__/Conditional.js.map +0 -7
  461. package/cjs/inputs/Radio/__stories__/Default/index.js +0 -81
  462. package/cjs/inputs/Radio/__stories__/Default.js.map +0 -7
  463. package/cjs/inputs/Radio/__stories__/WithDivider/index.js +0 -82
  464. package/cjs/inputs/Radio/__stories__/WithDivider.js.map +0 -7
  465. package/cjs/inputs/Select/Select.stories/index.js +0 -45
  466. package/cjs/inputs/Select/Select.stories.js.map +0 -7
  467. package/cjs/inputs/Select/__stories__/Default/index.js +0 -86
  468. package/cjs/inputs/Select/__stories__/Default.js.map +0 -7
  469. package/inputs/AutoCompleteInput/AutoComplete.stories/index.js +0 -14
  470. package/inputs/AutoCompleteInput/AutoComplete.stories/package.json +0 -6
  471. package/inputs/AutoCompleteInput/AutoComplete.stories.js.map +0 -7
  472. package/inputs/AutoCompleteInput/__stories__/Default/index.js +0 -50
  473. package/inputs/AutoCompleteInput/__stories__/Default/package.json +0 -6
  474. package/inputs/AutoCompleteInput/__stories__/Default.js.map +0 -7
  475. package/inputs/AutoCompleteInput/__stories__/Multiple/index.js +0 -51
  476. package/inputs/AutoCompleteInput/__stories__/Multiple/package.json +0 -6
  477. package/inputs/AutoCompleteInput/__stories__/Multiple.js.map +0 -7
  478. package/inputs/Checkboxes/Checkboxes.stories/index.js +0 -16
  479. package/inputs/Checkboxes/Checkboxes.stories/package.json +0 -6
  480. package/inputs/Checkboxes/Checkboxes.stories.js.map +0 -7
  481. package/inputs/Checkboxes/__stories__/Conditional/index.js +0 -100
  482. package/inputs/Checkboxes/__stories__/Conditional/package.json +0 -6
  483. package/inputs/Checkboxes/__stories__/Conditional.js.map +0 -7
  484. package/inputs/Checkboxes/__stories__/Default/index.js +0 -44
  485. package/inputs/Checkboxes/__stories__/Default/package.json +0 -6
  486. package/inputs/Checkboxes/__stories__/Default.js.map +0 -7
  487. package/inputs/Checkboxes/__stories__/WithDivider/index.js +0 -45
  488. package/inputs/Checkboxes/__stories__/WithDivider/package.json +0 -6
  489. package/inputs/Checkboxes/__stories__/WithDivider.js.map +0 -7
  490. package/inputs/DateInput/DateInput.stories/index.js +0 -12
  491. package/inputs/DateInput/DateInput.stories/package.json +0 -6
  492. package/inputs/DateInput/DateInput.stories.js.map +0 -7
  493. package/inputs/DateInput/__stories__/Default/index.js +0 -28
  494. package/inputs/DateInput/__stories__/Default/package.json +0 -6
  495. package/inputs/DateInput/__stories__/Default.js.map +0 -7
  496. package/inputs/FileInput/FileInput.stories/index.js +0 -12
  497. package/inputs/FileInput/FileInput.stories/package.json +0 -6
  498. package/inputs/FileInput/FileInput.stories.js.map +0 -7
  499. package/inputs/FileInput/__stories__/Default/index.js +0 -28
  500. package/inputs/FileInput/__stories__/Default/package.json +0 -6
  501. package/inputs/FileInput/__stories__/Default.js.map +0 -7
  502. package/inputs/ImageInput/ImageInput.stories/index.js +0 -16
  503. package/inputs/ImageInput/ImageInput.stories/package.json +0 -6
  504. package/inputs/ImageInput/ImageInput.stories.js.map +0 -7
  505. package/inputs/ImageInput/__stories__/Default/index.js +0 -30
  506. package/inputs/ImageInput/__stories__/Default/package.json +0 -6
  507. package/inputs/ImageInput/__stories__/Default.js.map +0 -7
  508. package/inputs/ImageInput/__stories__/WithInvalidImageDimension/index.js +0 -38
  509. package/inputs/ImageInput/__stories__/WithInvalidImageDimension/package.json +0 -6
  510. package/inputs/ImageInput/__stories__/WithInvalidImageDimension.js.map +0 -7
  511. package/inputs/ImageInput/__stories__/WithInvalidImageSize/index.js +0 -35
  512. package/inputs/ImageInput/__stories__/WithInvalidImageSize/package.json +0 -6
  513. package/inputs/ImageInput/__stories__/WithInvalidImageSize.js.map +0 -7
  514. package/inputs/Input/Input.stories/index.js +0 -30
  515. package/inputs/Input/Input.stories.js.map +0 -7
  516. package/inputs/Input/__stories__/AFM/index.js +0 -30
  517. package/inputs/Input/__stories__/AFM/package.json +0 -6
  518. package/inputs/Input/__stories__/AFM.js.map +0 -7
  519. package/inputs/Input/__stories__/Boolean/index.js +0 -31
  520. package/inputs/Input/__stories__/Boolean/package.json +0 -6
  521. package/inputs/Input/__stories__/Boolean.js.map +0 -7
  522. package/inputs/Input/__stories__/IBAN/index.js +0 -31
  523. package/inputs/Input/__stories__/IBAN/package.json +0 -6
  524. package/inputs/Input/__stories__/IBAN.js.map +0 -7
  525. package/inputs/Input/__stories__/Integer/index.js +0 -45
  526. package/inputs/Input/__stories__/Integer/package.json +0 -6
  527. package/inputs/Input/__stories__/Integer.js.map +0 -7
  528. package/inputs/Input/__stories__/LandlineNumber/index.js +0 -34
  529. package/inputs/Input/__stories__/LandlineNumber/package.json +0 -6
  530. package/inputs/Input/__stories__/LandlineNumber.js.map +0 -7
  531. package/inputs/Input/__stories__/MobilePhone/index.js +0 -34
  532. package/inputs/Input/__stories__/MobilePhone/package.json +0 -6
  533. package/inputs/Input/__stories__/MobilePhone.js.map +0 -7
  534. package/inputs/Input/__stories__/PhoneNumber/index.js +0 -33
  535. package/inputs/Input/__stories__/PhoneNumber/package.json +0 -6
  536. package/inputs/Input/__stories__/PhoneNumber.js.map +0 -7
  537. package/inputs/Input/__stories__/PostalCode/index.js +0 -31
  538. package/inputs/Input/__stories__/PostalCode/package.json +0 -6
  539. package/inputs/Input/__stories__/PostalCode.js.map +0 -7
  540. package/inputs/Input/__stories__/String/index.js +0 -31
  541. package/inputs/Input/__stories__/String/package.json +0 -6
  542. package/inputs/Input/__stories__/String.js.map +0 -7
  543. package/inputs/Input/__stories__/TextWithLimit/index.js +0 -31
  544. package/inputs/Input/__stories__/TextWithLimit/package.json +0 -6
  545. package/inputs/Input/__stories__/TextWithLimit.js.map +0 -7
  546. package/inputs/Label/Label.stories/index.js +0 -12
  547. package/inputs/Label/Label.stories/package.json +0 -6
  548. package/inputs/Label/Label.stories.js.map +0 -7
  549. package/inputs/Label/__stories__/Default/index.js +0 -39
  550. package/inputs/Label/__stories__/Default/package.json +0 -6
  551. package/inputs/Label/__stories__/Default.js.map +0 -7
  552. package/inputs/OtpInput/OtpInput.stories/index.js +0 -12
  553. package/inputs/OtpInput/OtpInput.stories/package.json +0 -6
  554. package/inputs/OtpInput/OtpInput.stories.js.map +0 -7
  555. package/inputs/OtpInput/__stories__/Default/index.js +0 -31
  556. package/inputs/OtpInput/__stories__/Default/package.json +0 -6
  557. package/inputs/OtpInput/__stories__/Default.js.map +0 -7
  558. package/inputs/Radio/Radio.stories/index.js +0 -16
  559. package/inputs/Radio/Radio.stories/package.json +0 -6
  560. package/inputs/Radio/Radio.stories.js.map +0 -7
  561. package/inputs/Radio/__stories__/Conditional/index.js +0 -100
  562. package/inputs/Radio/__stories__/Conditional/package.json +0 -6
  563. package/inputs/Radio/__stories__/Conditional.js.map +0 -7
  564. package/inputs/Radio/__stories__/Default/index.js +0 -48
  565. package/inputs/Radio/__stories__/Default/package.json +0 -6
  566. package/inputs/Radio/__stories__/Default.js.map +0 -7
  567. package/inputs/Radio/__stories__/WithDivider/index.js +0 -49
  568. package/inputs/Radio/__stories__/WithDivider/package.json +0 -6
  569. package/inputs/Radio/__stories__/WithDivider.js.map +0 -7
  570. package/inputs/Select/Select.stories/index.js +0 -12
  571. package/inputs/Select/Select.stories/package.json +0 -6
  572. package/inputs/Select/Select.stories.js.map +0 -7
  573. package/inputs/Select/__stories__/Default/index.js +0 -53
  574. package/inputs/Select/__stories__/Default/package.json +0 -6
  575. package/inputs/Select/__stories__/Default.js.map +0 -7
  576. package/lazy.d.ts +0 -72
  577. package/lazy.js.map +0 -7
  578. package/registry.d.ts +0 -70
  579. package/registry.js.map +0 -7
  580. package/src/index.tsx +0 -178
  581. package/src/inputs/ImageInput/index.mdx +0 -19
  582. package/src/inputs/Input/index.mdx +0 -95
  583. package/src/inputs/Label/index.mdx +0 -0
  584. /package/src/Field/{index.mdx → doc.mdx} +0 -0
@@ -1,7 +1,7 @@
1
1
  {
2
2
  "version": 3,
3
3
  "sources": ["../../../../src/inputs/AutoCompleteInput/index.tsx"],
4
- "sourcesContent": ["import React, { useCallback } from 'react';\nimport { ControlledFieldProps } from '@digigov/form/Field/types';\nimport { FieldOptionProps } from '@digigov/form/inputs/Label';\nimport { Hint } from '@digigov/react-core/Hint';\nimport UIAutoComplete, {\n AutoCompleteProps as UIAutoCompleteProps,\n} from '@digigov/ui/form/AutoComplete';\n\nexport interface AutoCompleteInputExtra\n extends Omit<\n UIAutoCompleteProps,\n | 'source'\n | 'id'\n | 'templates'\n | 'defaultValue'\n | 'onConfirm'\n | 'dropdownArrow'\n > {\n options: Array<FieldOptionProps>;\n}\n\nexport interface AutoCompleteInputProps\n extends Omit<ControlledFieldProps, 'value' | 'onChange' | 'extra'> {\n extra: AutoCompleteInputExtra;\n value: string;\n onChange: (v: string | string[] | undefined) => void;\n}\n\nexport const AutoCompleteInput: React.FC<AutoCompleteInputProps> = ({\n name,\n extra: { options, multiple },\n onChange,\n value,\n error,\n ...props\n}) => {\n const suggest = useCallback(function suggest(\n query: string,\n syncResults: (options: any[]) => void\n ): void {\n syncResults(\n query\n ? options.filter(function (option) {\n return (\n `${option.value} ${option.label?.primary || ''} ${option.label?.secondary || ''\n }`\n .toLowerCase()\n .indexOf(query.toLowerCase()) !== -1\n );\n })\n : options\n );\n },\n [options]);\n\n return (\n <UIAutoComplete\n multiple={multiple}\n source={suggest}\n onConfirm={(value) => {\n if (Array.isArray(value)) {\n const selectedValues = value.map(item => item.value);\n selectedValues.length > 0 ? onChange(selectedValues) : onChange(undefined);\n } else {\n onChange(value.value);\n }\n }}\n templates={{\n suggestion({ label, value }) {\n return (\n <div>\n {(label && label.primary && label.primary) || value}\n {label && label.secondary && <Hint>{label.secondary}</Hint>}\n </div>\n );\n },\n inputValue: (option) => {\n if (!option) {\n return '';\n }\n return option.label.primary || option.value;\n },\n }}\n {...{\n ...props,\n reset: undefined,\n required: undefined,\n }}\n name={name}\n id={`${name}-id`}\n defaultValue={value}\n />\n );\n};\n\nexport default AutoCompleteInput;"],
5
- "mappings": ";;;;;;;;;;;;;;;;;;;;;;;;;;;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,mBAAmC;AAGnC,kBAAqB;AACrB,0BAEO;AAsBA,MAAM,oBAAsD,CAAC;AAAA,EAClE;AAAA,EACA,OAAO,EAAE,SAAS,SAAS;AAAA,EAC3B;AAAA,EACA;AAAA,EACA;AAAA,EACA,GAAG;AACL,MAAM;AACJ,QAAM,cAAU;AAAA,IAAY,SAASA,SACnC,OACA,aACM;AACN;AAAA,QACE,QACI,QAAQ,OAAO,SAAU,QAAQ;AACjC,iBACE,GAAG,OAAO,KAAK,IAAI,OAAO,OAAO,WAAW,EAAE,IAAI,OAAO,OAAO,aAAa,EAC3E,GACC,YAAY,EACZ,QAAQ,MAAM,YAAY,CAAC,MAAM;AAAA,QAExC,CAAC,IACC;AAAA,MACN;AAAA,IACF;AAAA,IACE,CAAC,OAAO;AAAA,EAAC;AAEX,SACE,6BAAAC,QAAA;AAAA,IAAC,oBAAAC;AAAA,IAAA;AAAA,MACC;AAAA,MACA,QAAQ;AAAA,MACR,WAAW,CAACC,WAAU;AACpB,YAAI,MAAM,QAAQA,MAAK,GAAG;AACxB,gBAAM,iBAAiBA,OAAM,IAAI,UAAQ,KAAK,KAAK;AACnD,yBAAe,SAAS,IAAI,SAAS,cAAc,IAAI,SAAS,MAAS;AAAA,QAC3E,OAAO;AACL,mBAASA,OAAM,KAAK;AAAA,QACtB;AAAA,MACF;AAAA,MACA,WAAW;AAAA,QACT,WAAW,EAAE,OAAO,OAAAA,OAAM,GAAG;AAC3B,iBACE,6BAAAF,QAAA,cAAC,aACG,SAAS,MAAM,WAAW,MAAM,WAAYE,QAC7C,SAAS,MAAM,aAAa,6BAAAF,QAAA,cAAC,wBAAM,MAAM,SAAU,CACtD;AAAA,QAEJ;AAAA,QACA,YAAY,CAAC,WAAW;AACtB,cAAI,CAAC,QAAQ;AACX,mBAAO;AAAA,UACT;AACA,iBAAO,OAAO,MAAM,WAAW,OAAO;AAAA,QACxC;AAAA,MACF;AAAA,MACC,GAAG;AAAA,QACF,GAAG;AAAA,QACH,OAAO;AAAA,QACP,UAAU;AAAA,MACZ;AAAA,MACA;AAAA,MACA,IAAI,GAAG,IAAI;AAAA,MACX,cAAc;AAAA;AAAA,EAChB;AAEJ;AAEA,IAAO,4BAAQ;",
6
- "names": ["suggest", "React", "UIAutoComplete", "value"]
4
+ "sourcesContent": ["import React, { useCallback } from 'react';\nimport { ControlledFieldProps } from '@digigov/form/Field/types';\nimport { FieldOptionProps } from '@digigov/form/inputs/Label';\nimport {\n AutoComplete,\n AutoCompleteProps as UIAutoCompleteProps,\n} from '@digigov/ui/form/AutoComplete';\nimport { Hint } from '@digigov/ui/typography/Hint';\nimport { Base } from '@digigov/ui/utils/Base';\nexport interface AutoCompleteInputExtra\n extends Omit<\n UIAutoCompleteProps,\n | 'source'\n | 'id'\n | 'templates'\n | 'defaultValue'\n | 'onConfirm'\n | 'dropdownArrow'\n > {\n options: FieldOptionProps[];\n}\n\nexport interface AutoCompleteInputProps\n extends Omit<ControlledFieldProps, 'value' | 'onChange' | 'extra'> {\n extra: AutoCompleteInputExtra;\n value: string;\n onChange: (v: string | string[] | undefined) => void;\n}\n\nexport const AutoCompleteInput: React.FC<AutoCompleteInputProps> = ({\n name,\n type,\n extra: { options },\n onChange,\n value,\n ...props\n}) => {\n const suggest = useCallback(\n function suggest(\n query: string,\n syncResults: (options: any[]) => void\n ): void {\n syncResults(\n query\n ? options.filter(function (option) {\n return (\n `${option.value} ${option.label?.primary || ''} ${\n option.label?.secondary || ''\n }`\n .toLowerCase()\n .indexOf(query.toLowerCase()) !== -1\n );\n })\n : options\n );\n },\n [options]\n );\n\n return (\n <AutoComplete\n multiple={type === 'choice:multiple' ? true : false}\n source={suggest}\n onConfirm={(value) => {\n if (Array.isArray(value)) {\n const selectedValues = value.map((item) => item.value);\n if (selectedValues.length > 0) onChange(selectedValues);\n else onChange(undefined);\n } else {\n onChange(value.value);\n }\n }}\n templates={{\n suggestion({ label, value }) {\n return (\n <Base as=\"div\">\n {(label && label.primary && label.primary) || value}\n {label && label.secondary && <Hint>{label.secondary}</Hint>}\n </Base>\n );\n },\n inputValue: (option) => {\n if (!option) {\n return '';\n }\n return option.label.primary || option.value;\n },\n }}\n {...{\n ...props,\n reset: undefined,\n required: undefined,\n Field: undefined,\n }}\n name={name}\n id={`${name}-id`}\n defaultValue={value}\n />\n );\n};\n\nexport default AutoCompleteInput;\n"],
5
+ "mappings": ";;;;;;;;;;;;;;;;;;;;;;;;;;;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,mBAAmC;AAGnC,0BAGO;AACP,kBAAqB;AACrB,kBAAqB;AAqBd,MAAM,oBAAsD,CAAC;AAAA,EAClE;AAAA,EACA;AAAA,EACA,OAAO,EAAE,QAAQ;AAAA,EACjB;AAAA,EACA;AAAA,EACA,GAAG;AACL,MAAM;AACJ,QAAM,cAAU;AAAA,IACd,SAASA,SACP,OACA,aACM;AACN;AAAA,QACE,QACI,QAAQ,OAAO,SAAU,QAAQ;AAC/B,iBACE,GAAG,OAAO,KAAK,IAAI,OAAO,OAAO,WAAW,EAAE,IAC5C,OAAO,OAAO,aAAa,EAC7B,GACG,YAAY,EACZ,QAAQ,MAAM,YAAY,CAAC,MAAM;AAAA,QAExC,CAAC,IACD;AAAA,MACN;AAAA,IACF;AAAA,IACA,CAAC,OAAO;AAAA,EACV;AAEA,SACE,6BAAAC,QAAA;AAAA,IAAC;AAAA;AAAA,MACC,UAAU,SAAS,oBAAoB,OAAO;AAAA,MAC9C,QAAQ;AAAA,MACR,WAAW,CAACC,WAAU;AACpB,YAAI,MAAM,QAAQA,MAAK,GAAG;AACxB,gBAAM,iBAAiBA,OAAM,IAAI,CAAC,SAAS,KAAK,KAAK;AACrD,cAAI,eAAe,SAAS,EAAG,UAAS,cAAc;AAAA,cACjD,UAAS,MAAS;AAAA,QACzB,OAAO;AACL,mBAASA,OAAM,KAAK;AAAA,QACtB;AAAA,MACF;AAAA,MACA,WAAW;AAAA,QACT,WAAW,EAAE,OAAO,OAAAA,OAAM,GAAG;AAC3B,iBACE,6BAAAD,QAAA,cAAC,oBAAK,IAAG,SACL,SAAS,MAAM,WAAW,MAAM,WAAYC,QAC7C,SAAS,MAAM,aAAa,6BAAAD,QAAA,cAAC,wBAAM,MAAM,SAAU,CACtD;AAAA,QAEJ;AAAA,QACA,YAAY,CAAC,WAAW;AACtB,cAAI,CAAC,QAAQ;AACX,mBAAO;AAAA,UACT;AACA,iBAAO,OAAO,MAAM,WAAW,OAAO;AAAA,QACxC;AAAA,MACF;AAAA,MACC,GAAG;AAAA,QACF,GAAG;AAAA,QACH,OAAO;AAAA,QACP,UAAU;AAAA,QACV,OAAO;AAAA,MACT;AAAA,MACA;AAAA,MACA,IAAI,GAAG,IAAI;AAAA,MACX,cAAc;AAAA;AAAA,EAChB;AAEJ;AAEA,IAAO,4BAAQ;",
6
+ "names": ["suggest", "React", "value"]
7
7
  }
@@ -32,18 +32,16 @@ __export(Checkboxes_exports, {
32
32
  });
33
33
  module.exports = __toCommonJS(Checkboxes_exports);
34
34
  var import_react = __toESM(require("react"));
35
- var import_Checkbox = __toESM(require("@digigov/react-core/Checkbox"));
36
- var import_CheckboxConditional = require("@digigov/react-core/CheckboxConditional");
37
- var import_CheckboxItem = __toESM(require("@digigov/react-core/CheckboxItem"));
38
- var import_Hint = __toESM(require("@digigov/react-core/Hint"));
35
+ var import_Checkbox = require("@digigov/ui/form/Checkbox");
39
36
  var import_i18n = require("@digigov/ui/i18n");
37
+ var import_Hint = require("@digigov/ui/typography/Hint");
40
38
  const Checkboxes = ({
41
39
  name,
42
40
  onChange,
43
41
  value,
44
42
  extra: { options, className },
45
43
  disabled,
46
- fieldComponent: Field,
44
+ Field,
47
45
  ...props
48
46
  }) => {
49
47
  if (!value) value = [];
@@ -66,7 +64,7 @@ const Checkboxes = ({
66
64
  const [checked, setChecked] = (0, import_react.useState)(
67
65
  Array(options.length).fill(false)
68
66
  );
69
- return /* @__PURE__ */ import_react.default.createElement(import_Checkbox.default, { className }, options.map(
67
+ return /* @__PURE__ */ import_react.default.createElement(import_Checkbox.Checkbox, { className }, options.map(
70
68
  ({
71
69
  label,
72
70
  value: v,
@@ -75,10 +73,11 @@ const Checkboxes = ({
75
73
  selected,
76
74
  ...option
77
75
  }, index) => /* @__PURE__ */ import_react.default.createElement(import_react.default.Fragment, { key: index }, /* @__PURE__ */ import_react.default.createElement(
78
- import_CheckboxItem.default,
76
+ import_Checkbox.CheckboxItem,
79
77
  {
80
78
  key: `${name}.${index}`,
81
79
  name: `${name}.${v}`,
80
+ id: `${name}.${v}`,
82
81
  value: v,
83
82
  disabled: disabled || optionDisabled,
84
83
  checked: value?.includes(v),
@@ -90,13 +89,14 @@ const Checkboxes = ({
90
89
  defaultValue: void 0,
91
90
  onBlur: void 0,
92
91
  required: void 0,
92
+ Field: void 0,
93
93
  "aria-describedby": void 0,
94
94
  type: "checkbox"
95
95
  }
96
96
  },
97
97
  label && label.primary && t(label.primary) || value,
98
- label && label.secondary && /* @__PURE__ */ import_react.default.createElement(import_Hint.default, null, t(label.secondary))
99
- ), !!checked[index] && show && Field && /* @__PURE__ */ import_react.default.createElement(import_CheckboxConditional.CheckboxConditional, null, show.map((fieldName) => /* @__PURE__ */ import_react.default.createElement(Field, { name: fieldName, key: fieldName }))), selected && selected())
98
+ label && label.secondary && /* @__PURE__ */ import_react.default.createElement(import_Hint.Hint, null, t(label.secondary))
99
+ ), !!checked[index] && show && Field && /* @__PURE__ */ import_react.default.createElement(import_Checkbox.CheckboxConditional, null, show.map((fieldName) => /* @__PURE__ */ import_react.default.createElement(Field, { name: fieldName, key: fieldName }))), selected && selected())
100
100
  ));
101
101
  };
102
102
  var Checkboxes_default = Checkboxes;
@@ -1,7 +1,7 @@
1
1
  {
2
2
  "version": 3,
3
3
  "sources": ["../../../../src/inputs/Checkboxes/index.tsx"],
4
- "sourcesContent": ["import React, { useState } from 'react';\nimport { ControlledFieldProps } from '@digigov/form/Field/types';\nimport { FieldOptionProps } from '@digigov/form/inputs/Label';\nimport CoreCheckboxes from '@digigov/react-core/Checkbox';\nimport { CheckboxConditional } from '@digigov/react-core/CheckboxConditional';\nimport CheckboxItem from '@digigov/react-core/CheckboxItem';\nimport Hint from '@digigov/react-core/Hint';\nimport { useTranslation } from '@digigov/ui/i18n';\n\nexport interface CheckboxesProps\n extends Omit<ControlledFieldProps, 'extra' | 'value'> {\n value?: string[];\n extra: {\n className?: string;\n options: Array<FieldOptionProps>;\n };\n fieldComponent: React.FC<Omit<ControlledFieldProps, 'value' | 'onChange'>>;\n}\n\nexport const Checkboxes: React.FC<CheckboxesProps> = ({\n name,\n onChange,\n value,\n extra: { options, className },\n disabled,\n fieldComponent: Field,\n ...props\n}) => {\n if (!value) value = [];\n const handleChange =\n (optionValue, idx, show) =>\n (evt): void => {\n let newValue;\n if (evt.currentTarget.checked) {\n // eslint-disable-next-line @typescript-eslint/ban-ts-comment\n // @ts-ignore\n newValue = value.concat([optionValue]);\n } else {\n // eslint-disable-next-line @typescript-eslint/ban-ts-comment\n // @ts-ignore\n newValue = value.filter((val) => val !== optionValue);\n }\n if (show && show.length > 0) {\n setChecked((items) =>\n items.map((item, index) => (index === idx ? !item : item))\n );\n }\n\n // reset value to undefined instead of an empty array\n // so the error state mechanism can throw validation errors\n if (newValue.length === 0) newValue = undefined;\n onChange(newValue);\n };\n const { t } = useTranslation();\n const [checked, setChecked] = useState(\n Array<boolean>(options.length).fill(false)\n );\n return (\n <CoreCheckboxes className={className}>\n {options.map(\n (\n {\n label,\n value: v,\n show,\n disabled: optionDisabled,\n selected,\n ...option\n },\n index\n ) => (\n <React.Fragment key={index}>\n <CheckboxItem\n key={`${name}.${index}`}\n name={`${name}.${v}`}\n value={v}\n disabled={disabled || optionDisabled}\n checked={value?.includes(v)}\n onChange={handleChange(v, index, show)}\n {...option}\n {...{\n ...props,\n reset: undefined,\n defaultValue: undefined,\n onBlur: undefined,\n required: undefined,\n 'aria-describedby': undefined,\n type: 'checkbox',\n }}\n >\n {(label && label.primary && t(label.primary)) || value}\n {label && label.secondary && <Hint>{t(label.secondary)}</Hint>}\n </CheckboxItem>\n\n {!!checked[index] && show && Field && (\n <CheckboxConditional>\n {show.map((fieldName) => (\n <Field name={fieldName} key={fieldName} />\n ))}\n </CheckboxConditional>\n )}\n {selected && selected()}\n </React.Fragment>\n )\n )}\n </CoreCheckboxes>\n );\n};\n\nexport default Checkboxes;\n"],
5
- "mappings": ";;;;;;;;;;;;;;;;;;;;;;;;;;;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,mBAAgC;AAGhC,sBAA2B;AAC3B,iCAAoC;AACpC,0BAAyB;AACzB,kBAAiB;AACjB,kBAA+B;AAYxB,MAAM,aAAwC,CAAC;AAAA,EACpD;AAAA,EACA;AAAA,EACA;AAAA,EACA,OAAO,EAAE,SAAS,UAAU;AAAA,EAC5B;AAAA,EACA,gBAAgB;AAAA,EAChB,GAAG;AACL,MAAM;AACJ,MAAI,CAAC,MAAO,SAAQ,CAAC;AACrB,QAAM,eACJ,CAAC,aAAa,KAAK,SACnB,CAAC,QAAc;AACb,QAAI;AACJ,QAAI,IAAI,cAAc,SAAS;AAG7B,iBAAW,MAAM,OAAO,CAAC,WAAW,CAAC;AAAA,IACvC,OAAO;AAGL,iBAAW,MAAM,OAAO,CAAC,QAAQ,QAAQ,WAAW;AAAA,IACtD;AACA,QAAI,QAAQ,KAAK,SAAS,GAAG;AAC3B;AAAA,QAAW,CAAC,UACV,MAAM,IAAI,CAAC,MAAM,UAAW,UAAU,MAAM,CAAC,OAAO,IAAK;AAAA,MAC3D;AAAA,IACF;AAIA,QAAI,SAAS,WAAW,EAAG,YAAW;AACtC,aAAS,QAAQ;AAAA,EACnB;AACF,QAAM,EAAE,EAAE,QAAI,4BAAe;AAC7B,QAAM,CAAC,SAAS,UAAU,QAAI;AAAA,IAC5B,MAAe,QAAQ,MAAM,EAAE,KAAK,KAAK;AAAA,EAC3C;AACA,SACE,6BAAAA,QAAA,cAAC,gBAAAC,SAAA,EAAe,aACb,QAAQ;AAAA,IACP,CACE;AAAA,MACE;AAAA,MACA,OAAO;AAAA,MACP;AAAA,MACA,UAAU;AAAA,MACV;AAAA,MACA,GAAG;AAAA,IACL,GACA,UAEA,6BAAAD,QAAA,cAAC,aAAAA,QAAM,UAAN,EAAe,KAAK,SACnB,6BAAAA,QAAA;AAAA,MAAC,oBAAAE;AAAA,MAAA;AAAA,QACC,KAAK,GAAG,IAAI,IAAI,KAAK;AAAA,QACrB,MAAM,GAAG,IAAI,IAAI,CAAC;AAAA,QAClB,OAAO;AAAA,QACP,UAAU,YAAY;AAAA,QACtB,SAAS,OAAO,SAAS,CAAC;AAAA,QAC1B,UAAU,aAAa,GAAG,OAAO,IAAI;AAAA,QACpC,GAAG;AAAA,QACH,GAAG;AAAA,UACF,GAAG;AAAA,UACH,OAAO;AAAA,UACP,cAAc;AAAA,UACd,QAAQ;AAAA,UACR,UAAU;AAAA,UACV,oBAAoB;AAAA,UACpB,MAAM;AAAA,QACR;AAAA;AAAA,MAEE,SAAS,MAAM,WAAW,EAAE,MAAM,OAAO,KAAM;AAAA,MAChD,SAAS,MAAM,aAAa,6BAAAF,QAAA,cAAC,YAAAG,SAAA,MAAM,EAAE,MAAM,SAAS,CAAE;AAAA,IACzD,GAEC,CAAC,CAAC,QAAQ,KAAK,KAAK,QAAQ,SAC3B,6BAAAH,QAAA,cAAC,sDACE,KAAK,IAAI,CAAC,cACT,6BAAAA,QAAA,cAAC,SAAM,MAAM,WAAW,KAAK,WAAW,CACzC,CACH,GAED,YAAY,SAAS,CACxB;AAAA,EAEJ,CACF;AAEJ;AAEA,IAAO,qBAAQ;",
6
- "names": ["React", "CoreCheckboxes", "CheckboxItem", "Hint"]
4
+ "sourcesContent": ["import React, { useState } from 'react';\nimport { ControlledFieldProps } from '@digigov/form/Field/types';\nimport { FieldOptionProps } from '@digigov/form/inputs/Label';\nimport {\n Checkbox,\n CheckboxItem,\n CheckboxConditional,\n} from '@digigov/ui/form/Checkbox';\nimport { useTranslation } from '@digigov/ui/i18n';\nimport { Hint } from '@digigov/ui/typography/Hint';\n\nexport interface CheckboxesProps\n extends Omit<ControlledFieldProps, 'extra' | 'value'> {\n value?: string[];\n extra: {\n className?: string;\n options: FieldOptionProps[];\n };\n fieldComponent: React.FC<Omit<ControlledFieldProps, 'value' | 'onChange'>>;\n}\n\nexport const Checkboxes: React.FC<CheckboxesProps> = ({\n name,\n onChange,\n value,\n extra: { options, className },\n disabled,\n Field,\n ...props\n}) => {\n if (!value) value = [];\n const handleChange =\n (optionValue, idx, show) =>\n (evt): void => {\n let newValue;\n if (evt.currentTarget.checked) {\n // eslint-disable-next-line @typescript-eslint/ban-ts-comment\n // @ts-ignore\n newValue = value.concat([optionValue]);\n } else {\n // eslint-disable-next-line @typescript-eslint/ban-ts-comment\n // @ts-ignore\n newValue = value.filter((val) => val !== optionValue);\n }\n if (show && show.length > 0) {\n setChecked((items) =>\n items.map((item, index) => (index === idx ? !item : item))\n );\n }\n\n // reset value to undefined instead of an empty array\n // so the error state mechanism can throw validation errors\n if (newValue.length === 0) newValue = undefined;\n onChange(newValue);\n };\n const { t } = useTranslation();\n const [checked, setChecked] = useState(\n Array<boolean>(options.length).fill(false)\n );\n return (\n <Checkbox className={className}>\n {options.map(\n (\n {\n label,\n value: v,\n show,\n disabled: optionDisabled,\n selected,\n ...option\n },\n index\n ) => (\n <React.Fragment key={index}>\n <CheckboxItem\n key={`${name}.${index}`}\n name={`${name}.${v}`}\n id={`${name}.${v}`}\n value={v}\n disabled={disabled || optionDisabled}\n checked={value?.includes(v)}\n onChange={handleChange(v, index, show)}\n {...option}\n {...{\n ...props,\n reset: undefined,\n defaultValue: undefined,\n onBlur: undefined,\n required: undefined,\n Field: undefined,\n 'aria-describedby': undefined,\n type: 'checkbox',\n }}\n >\n {(label && label.primary && t(label.primary)) || value}\n {label && label.secondary && <Hint>{t(label.secondary)}</Hint>}\n </CheckboxItem>\n\n {!!checked[index] && show && Field && (\n <CheckboxConditional>\n {show.map((fieldName) => (\n <Field name={fieldName} key={fieldName} />\n ))}\n </CheckboxConditional>\n )}\n {selected && selected()}\n </React.Fragment>\n )\n )}\n </Checkbox>\n );\n};\n\nexport default Checkboxes;\n"],
5
+ "mappings": ";;;;;;;;;;;;;;;;;;;;;;;;;;;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,mBAAgC;AAGhC,sBAIO;AACP,kBAA+B;AAC/B,kBAAqB;AAYd,MAAM,aAAwC,CAAC;AAAA,EACpD;AAAA,EACA;AAAA,EACA;AAAA,EACA,OAAO,EAAE,SAAS,UAAU;AAAA,EAC5B;AAAA,EACA;AAAA,EACA,GAAG;AACL,MAAM;AACJ,MAAI,CAAC,MAAO,SAAQ,CAAC;AACrB,QAAM,eACJ,CAAC,aAAa,KAAK,SACnB,CAAC,QAAc;AACb,QAAI;AACJ,QAAI,IAAI,cAAc,SAAS;AAG7B,iBAAW,MAAM,OAAO,CAAC,WAAW,CAAC;AAAA,IACvC,OAAO;AAGL,iBAAW,MAAM,OAAO,CAAC,QAAQ,QAAQ,WAAW;AAAA,IACtD;AACA,QAAI,QAAQ,KAAK,SAAS,GAAG;AAC3B;AAAA,QAAW,CAAC,UACV,MAAM,IAAI,CAAC,MAAM,UAAW,UAAU,MAAM,CAAC,OAAO,IAAK;AAAA,MAC3D;AAAA,IACF;AAIA,QAAI,SAAS,WAAW,EAAG,YAAW;AACtC,aAAS,QAAQ;AAAA,EACnB;AACF,QAAM,EAAE,EAAE,QAAI,4BAAe;AAC7B,QAAM,CAAC,SAAS,UAAU,QAAI;AAAA,IAC5B,MAAe,QAAQ,MAAM,EAAE,KAAK,KAAK;AAAA,EAC3C;AACA,SACE,6BAAAA,QAAA,cAAC,4BAAS,aACP,QAAQ;AAAA,IACP,CACE;AAAA,MACE;AAAA,MACA,OAAO;AAAA,MACP;AAAA,MACA,UAAU;AAAA,MACV;AAAA,MACA,GAAG;AAAA,IACL,GACA,UAEA,6BAAAA,QAAA,cAAC,aAAAA,QAAM,UAAN,EAAe,KAAK,SACnB,6BAAAA,QAAA;AAAA,MAAC;AAAA;AAAA,QACC,KAAK,GAAG,IAAI,IAAI,KAAK;AAAA,QACrB,MAAM,GAAG,IAAI,IAAI,CAAC;AAAA,QAClB,IAAI,GAAG,IAAI,IAAI,CAAC;AAAA,QAChB,OAAO;AAAA,QACP,UAAU,YAAY;AAAA,QACtB,SAAS,OAAO,SAAS,CAAC;AAAA,QAC1B,UAAU,aAAa,GAAG,OAAO,IAAI;AAAA,QACpC,GAAG;AAAA,QACH,GAAG;AAAA,UACF,GAAG;AAAA,UACH,OAAO;AAAA,UACP,cAAc;AAAA,UACd,QAAQ;AAAA,UACR,UAAU;AAAA,UACV,OAAO;AAAA,UACP,oBAAoB;AAAA,UACpB,MAAM;AAAA,QACR;AAAA;AAAA,MAEE,SAAS,MAAM,WAAW,EAAE,MAAM,OAAO,KAAM;AAAA,MAChD,SAAS,MAAM,aAAa,6BAAAA,QAAA,cAAC,wBAAM,EAAE,MAAM,SAAS,CAAE;AAAA,IACzD,GAEC,CAAC,CAAC,QAAQ,KAAK,KAAK,QAAQ,SAC3B,6BAAAA,QAAA,cAAC,2CACE,KAAK,IAAI,CAAC,cACT,6BAAAA,QAAA,cAAC,SAAM,MAAM,WAAW,KAAK,WAAW,CACzC,CACH,GAED,YAAY,SAAS,CACxB;AAAA,EAEJ,CACF;AAEJ;AAEA,IAAO,qBAAQ;",
6
+ "names": ["React"]
7
7
  }
@@ -34,8 +34,7 @@ module.exports = __toCommonJS(DateInput_exports);
34
34
  var import_react = __toESM(require("react"));
35
35
  var import_dayjs = __toESM(require("dayjs"));
36
36
  var import_customParseFormat = __toESM(require("dayjs/plugin/customParseFormat"));
37
- var import_DateInputContainer = __toESM(require("@digigov/react-core/DateInputContainer"));
38
- var import_DateInputItem = __toESM(require("@digigov/react-core/DateInputItem"));
37
+ var import_DateInputContainer = require("@digigov/ui/form/DateInputContainer");
39
38
  var import_i18n = require("@digigov/ui/i18n");
40
39
  import_dayjs.default.extend(import_customParseFormat.default);
41
40
  function useDate(value, onChange) {
@@ -56,18 +55,18 @@ function useDate(value, onChange) {
56
55
  }
57
56
  }
58
57
  function setYear(evt) {
59
- const val = evt.target.value;
58
+ const val = evt.target.value.trim();
60
59
  set(val, month, day);
61
60
  }
62
61
  function setMonth(evt, cast) {
63
- let val = evt.target.value;
62
+ let val = evt.target.value.trim();
64
63
  if (cast && val && val.length === 1) {
65
64
  val = "0" + val;
66
65
  }
67
66
  set(year, val, day);
68
67
  }
69
68
  function setDay(evt, cast) {
70
- let val = evt.target.value;
69
+ let val = evt.target.value.trim();
71
70
  if (cast && val && val.length === 1) {
72
71
  val = "0" + val;
73
72
  }
@@ -91,9 +90,9 @@ const makeDate = (val) => {
91
90
  return "";
92
91
  };
93
92
  const DatePart = ({ label, ...props }) => {
94
- return /* @__PURE__ */ import_react.default.createElement(import_DateInputItem.default, { ...props }, label);
93
+ return /* @__PURE__ */ import_react.default.createElement(import_DateInputContainer.DateInputItem, { ...props }, label);
95
94
  };
96
- const DateInput = ({ name, type, ...props }) => {
95
+ const DateInput = ({ name, ...props }) => {
97
96
  const { t } = (0, import_i18n.useTranslation)();
98
97
  const [initial] = (0, import_react.useState)(props.value);
99
98
  const value = (0, import_react.useMemo)(() => {
@@ -103,7 +102,7 @@ const DateInput = ({ name, type, ...props }) => {
103
102
  return props.value;
104
103
  }, [props.value, initial]);
105
104
  const date = useDate(value || makeDate(props.defaultValue), props.onChange);
106
- return /* @__PURE__ */ import_react.default.createElement(import_DateInputContainer.default, null, /* @__PURE__ */ import_react.default.createElement(
105
+ return /* @__PURE__ */ import_react.default.createElement(import_DateInputContainer.DateInputContainer, null, /* @__PURE__ */ import_react.default.createElement(
107
106
  DatePart,
108
107
  {
109
108
  label: t("form.label.day"),
@@ -112,6 +111,7 @@ const DateInput = ({ name, type, ...props }) => {
112
111
  value: date.day,
113
112
  width: 2,
114
113
  name: `${name}-day`,
114
+ id: `${name}-day`,
115
115
  maxLength: "2",
116
116
  disabled: props.disabled,
117
117
  "aria-required": props["aria-required"],
@@ -126,6 +126,7 @@ const DateInput = ({ name, type, ...props }) => {
126
126
  value: date.month,
127
127
  width: 2,
128
128
  name: `${name}-month`,
129
+ id: `${name}-month`,
129
130
  maxLength: "2",
130
131
  disabled: props.disabled,
131
132
  "aria-required": props["aria-required"],
@@ -139,6 +140,7 @@ const DateInput = ({ name, type, ...props }) => {
139
140
  value: date.year,
140
141
  width: 4,
141
142
  name: `${name}-year`,
143
+ id: `${name}-year`,
142
144
  maxLength: "4",
143
145
  disabled: props.disabled,
144
146
  "aria-required": props["aria-required"],
@@ -1,7 +1,7 @@
1
1
  {
2
2
  "version": 3,
3
3
  "sources": ["../../../../src/inputs/DateInput/index.tsx"],
4
- "sourcesContent": ["import React, { useMemo, useState } from 'react';\nimport dayjs from 'dayjs';\nimport customParseFormat from 'dayjs/plugin/customParseFormat';\nimport { UncontrolledFieldProps } from '@digigov/form/Field/types';\nimport DateInputContainer from '@digigov/react-core/DateInputContainer';\nimport CoreDateInputItem from '@digigov/react-core/DateInputItem';\nimport { useTranslation } from '@digigov/ui/i18n';\ndayjs.extend(customParseFormat);\n\nexport interface DateInputProps extends Omit<UncontrolledFieldProps, 'extra'> {\n extra?: {\n max?: string;\n min?: string;\n };\n}\n\nfunction useDate(value, onChange) {\n const [year, month, day] = useMemo(() => {\n if (!value || value.length === 0) {\n onChange('');\n return ['', '', ''];\n }\n const [day, month, year] = value.split('/');\n return [year, month, day];\n }, [value]);\n\n function set(year, month, day) {\n const value = `${day || ''}/${month || ''}/${year || ''}`;\n if (!year && !month && !day) {\n onChange(null);\n } else {\n onChange(value);\n }\n }\n\n function setYear(evt) {\n const val = evt.target.value;\n set(val, month, day);\n }\n\n function setMonth(evt, cast) {\n let val = evt.target.value;\n if (cast && val && val.length === 1) {\n val = '0' + val;\n }\n set(year, val, day);\n }\n\n function setDay(evt, cast) {\n let val = evt.target.value;\n if (cast && val && val.length === 1) {\n val = '0' + val;\n }\n set(year, month, val);\n }\n\n return {\n day,\n month,\n year,\n setYear,\n setMonth,\n setDay,\n };\n}\n\nconst VALID_FORMATS = ['DD/MM/YYYY'];\n\nconst makeDate = (val) => {\n const date = dayjs(val, VALID_FORMATS, true);\n if (date.isValid()) {\n return date.format('DD/MM/YYYY');\n }\n return '';\n};\n\nconst DatePart = ({ label, ...props }) => {\n return <CoreDateInputItem {...props}>{label}</CoreDateInputItem>;\n};\n\nexport const DateInput = ({ name, type, ...props }) => {\n const { t } = useTranslation();\n const [initial] = useState(props.value);\n const value = useMemo(() => {\n if (initial === props.value) {\n return makeDate(props.value);\n }\n return props.value;\n }, [props.value, initial]);\n\n const date = useDate(value || makeDate(props.defaultValue), props.onChange);\n\n return (\n <DateInputContainer>\n <DatePart\n label={t('form.label.day')}\n onChange={date.setDay}\n onBlur={(e) => date.setDay(e, true)}\n value={date.day}\n width={2}\n name={`${name}-day`}\n maxLength=\"2\"\n disabled={props.disabled}\n aria-required={props['aria-required']}\n error={!date.day ? props.error : false}\n />\n <DatePart\n label={t('form.label.month')}\n onChange={date.setMonth}\n onBlur={(e) => date.setMonth(e, true)}\n value={date.month}\n width={2}\n name={`${name}-month`}\n maxLength=\"2\"\n disabled={props.disabled}\n aria-required={props['aria-required']}\n error={!date.month ? props.error : false}\n />\n <DatePart\n label={t('form.label.year')}\n onChange={date.setYear}\n value={date.year}\n width={4}\n name={`${name}-year`}\n maxLength=\"4\"\n disabled={props.disabled}\n aria-required={props['aria-required']}\n error={!date.year ? props.error : false}\n />\n </DateInputContainer>\n );\n};\n\nexport default DateInput;\n"],
5
- "mappings": "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",
6
- "names": ["dayjs", "customParseFormat", "day", "month", "year", "value", "React", "CoreDateInputItem", "DateInputContainer"]
4
+ "sourcesContent": ["import React, { useMemo, useState } from 'react';\nimport dayjs from 'dayjs';\nimport customParseFormat from 'dayjs/plugin/customParseFormat';\nimport { UncontrolledFieldProps } from '@digigov/form/Field/types';\nimport {\n DateInputContainer,\n DateInputItem,\n} from '@digigov/ui/form/DateInputContainer';\nimport { useTranslation } from '@digigov/ui/i18n';\ndayjs.extend(customParseFormat);\n\nexport interface DateInputProps extends Omit<UncontrolledFieldProps, 'extra'> {\n extra?: {\n max?: string;\n min?: string;\n };\n}\n\nfunction useDate(value, onChange) {\n const [year, month, day] = useMemo(() => {\n if (!value || value.length === 0) {\n onChange('');\n return ['', '', ''];\n }\n const [day, month, year] = value.split('/');\n return [year, month, day];\n }, [value]);\n\n function set(year, month, day) {\n const value = `${day || ''}/${month || ''}/${year || ''}`;\n if (!year && !month && !day) {\n onChange(null);\n } else {\n onChange(value);\n }\n }\n\n function setYear(evt) {\n const val = evt.target.value.trim();\n set(val, month, day);\n }\n\n function setMonth(evt, cast) {\n let val = evt.target.value.trim();\n if (cast && val && val.length === 1) {\n val = '0' + val;\n }\n set(year, val, day);\n }\n\n function setDay(evt, cast) {\n let val = evt.target.value.trim();\n if (cast && val && val.length === 1) {\n val = '0' + val;\n }\n set(year, month, val);\n }\n\n return {\n day,\n month,\n year,\n setYear,\n setMonth,\n setDay,\n };\n}\n\nconst VALID_FORMATS = ['DD/MM/YYYY'];\n\nconst makeDate = (val) => {\n const date = dayjs(val, VALID_FORMATS, true);\n if (date.isValid()) {\n return date.format('DD/MM/YYYY');\n }\n return '';\n};\n\nconst DatePart = ({ label, ...props }) => {\n return <DateInputItem {...props}>{label}</DateInputItem>;\n};\n\nexport const DateInput = ({ name, ...props }) => {\n const { t } = useTranslation();\n const [initial] = useState(props.value);\n const value = useMemo(() => {\n if (initial === props.value) {\n return makeDate(props.value);\n }\n return props.value;\n }, [props.value, initial]);\n\n const date = useDate(value || makeDate(props.defaultValue), props.onChange);\n\n return (\n <DateInputContainer>\n <DatePart\n label={t('form.label.day')}\n onChange={date.setDay}\n onBlur={(e) => date.setDay(e, true)}\n value={date.day}\n width={2}\n name={`${name}-day`}\n id={`${name}-day`}\n maxLength=\"2\"\n disabled={props.disabled}\n aria-required={props['aria-required']}\n error={!date.day ? props.error : false}\n />\n <DatePart\n label={t('form.label.month')}\n onChange={date.setMonth}\n onBlur={(e) => date.setMonth(e, true)}\n value={date.month}\n width={2}\n name={`${name}-month`}\n id={`${name}-month`}\n maxLength=\"2\"\n disabled={props.disabled}\n aria-required={props['aria-required']}\n error={!date.month ? props.error : false}\n />\n <DatePart\n label={t('form.label.year')}\n onChange={date.setYear}\n value={date.year}\n width={4}\n name={`${name}-year`}\n id={`${name}-year`}\n maxLength=\"4\"\n disabled={props.disabled}\n aria-required={props['aria-required']}\n error={!date.year ? props.error : false}\n />\n </DateInputContainer>\n );\n};\n\nexport default DateInput;\n"],
5
+ "mappings": "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",
6
+ "names": ["dayjs", "customParseFormat", "day", "month", "year", "value", "React"]
7
7
  }
@@ -0,0 +1,211 @@
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 DateTimeInput_exports = {};
29
+ __export(DateTimeInput_exports, {
30
+ DateTimeInput: () => DateTimeInput,
31
+ default: () => DateTimeInput_default
32
+ });
33
+ module.exports = __toCommonJS(DateTimeInput_exports);
34
+ var import_react = __toESM(require("react"));
35
+ var import_dayjs = __toESM(require("dayjs"));
36
+ var import_customParseFormat = __toESM(require("dayjs/plugin/customParseFormat"));
37
+ var import_DateInputContainer = require("@digigov/ui/form/DateInputContainer");
38
+ var import_i18n = require("@digigov/ui/i18n");
39
+ import_dayjs.default.extend(import_customParseFormat.default);
40
+ function useDateTime(value, onChange) {
41
+ const [year, month, day, hours, minutes] = (0, import_react.useMemo)(() => {
42
+ if (!value || value.length === 0) {
43
+ onChange("");
44
+ return ["", "", "", "", ""];
45
+ }
46
+ const [datePart, timePart] = value.split(" ");
47
+ const [day2, month2, year2] = datePart.split("/");
48
+ const [hours2, minutes2] = timePart ? timePart.split(":") : ["", ""];
49
+ return [year2, month2, day2, hours2, minutes2];
50
+ }, [value]);
51
+ function set(year2, month2, day2, hours2, minutes2) {
52
+ const datePart = `${day2 || ""}/${month2 || ""}/${year2 || ""}`;
53
+ const timePart = hours2 || minutes2 ? `${hours2 || ""}:${minutes2 || ""}` : "";
54
+ const value2 = timePart ? `${datePart} ${timePart}` : datePart;
55
+ if (!year2 && !month2 && !day2 && !hours2 && !minutes2) {
56
+ onChange(null);
57
+ } else {
58
+ onChange(value2);
59
+ }
60
+ }
61
+ function setYear(evt) {
62
+ const val = evt.target.value;
63
+ set(val, month, day, hours, minutes);
64
+ }
65
+ function setMonth(evt, cast) {
66
+ let val = evt.target.value;
67
+ if (cast && val && val.length === 1) {
68
+ val = "0" + val;
69
+ }
70
+ set(year, val, day, hours, minutes);
71
+ }
72
+ function setDay(evt, cast) {
73
+ let val = evt.target.value;
74
+ if (cast && val && val.length === 1) {
75
+ val = "0" + val;
76
+ }
77
+ set(year, month, val, hours, minutes);
78
+ }
79
+ function setHours(evt, cast) {
80
+ let val = evt.target.value;
81
+ if (cast && val && val.length === 1) {
82
+ val = "0" + val;
83
+ }
84
+ set(year, month, day, val, minutes);
85
+ }
86
+ function setMinutes(evt, cast) {
87
+ let val = evt.target.value;
88
+ if (cast && val && val.length === 1) {
89
+ val = "0" + val;
90
+ }
91
+ set(year, month, day, hours, val);
92
+ }
93
+ return {
94
+ day,
95
+ month,
96
+ year,
97
+ hours,
98
+ minutes,
99
+ setYear,
100
+ setMonth,
101
+ setDay,
102
+ setHours,
103
+ setMinutes
104
+ };
105
+ }
106
+ const VALID_FORMATS = ["DD/MM/YYYY HH:mm", "DD/MM/YYYY"];
107
+ const makeDateTime = (val) => {
108
+ const date = (0, import_dayjs.default)(val, VALID_FORMATS, true);
109
+ if (date.isValid()) {
110
+ return date.format("DD/MM/YYYY HH:mm");
111
+ }
112
+ return "";
113
+ };
114
+ const DateTimePart = ({ label, ...props }) => {
115
+ return /* @__PURE__ */ import_react.default.createElement(import_DateInputContainer.DateInputItem, { ...props }, label);
116
+ };
117
+ const DateTimeInput = ({ name, ...props }) => {
118
+ const { t } = (0, import_i18n.useTranslation)();
119
+ const [initial] = (0, import_react.useState)(props.value);
120
+ const value = (0, import_react.useMemo)(() => {
121
+ if (initial === props.value) {
122
+ return makeDateTime(props.value);
123
+ }
124
+ return props.value;
125
+ }, [props.value, initial]);
126
+ const datetime = useDateTime(
127
+ value || makeDateTime(props.defaultValue),
128
+ props.onChange
129
+ );
130
+ return /* @__PURE__ */ import_react.default.createElement(import_DateInputContainer.DateInputContainer, null, /* @__PURE__ */ import_react.default.createElement(
131
+ DateTimePart,
132
+ {
133
+ label: t("form.label.day"),
134
+ onChange: datetime.setDay,
135
+ onBlur: (e) => datetime.setDay(e, true),
136
+ value: datetime.day,
137
+ width: 2,
138
+ name: `${name}-day`,
139
+ maxLength: "2",
140
+ disabled: props.disabled,
141
+ "aria-required": props["aria-required"],
142
+ error: !datetime.day ? props.error : false,
143
+ id: `${name}-day`
144
+ }
145
+ ), /* @__PURE__ */ import_react.default.createElement(
146
+ DateTimePart,
147
+ {
148
+ label: t("form.label.month"),
149
+ onChange: datetime.setMonth,
150
+ onBlur: (e) => datetime.setMonth(e, true),
151
+ value: datetime.month,
152
+ width: 2,
153
+ name: `${name}-month`,
154
+ id: `${name}-month`,
155
+ maxLength: "2",
156
+ disabled: props.disabled,
157
+ "aria-required": props["aria-required"],
158
+ error: !datetime.month ? props.error : false
159
+ }
160
+ ), /* @__PURE__ */ import_react.default.createElement(
161
+ DateTimePart,
162
+ {
163
+ label: t("form.label.year"),
164
+ onChange: datetime.setYear,
165
+ value: datetime.year,
166
+ width: 4,
167
+ name: `${name}-year`,
168
+ id: `${name}-year`,
169
+ maxLength: "4",
170
+ disabled: props.disabled,
171
+ "aria-required": props["aria-required"],
172
+ error: !datetime.year ? props.error : false
173
+ }
174
+ ), /* @__PURE__ */ import_react.default.createElement(
175
+ DateTimePart,
176
+ {
177
+ label: t("form.label.hours"),
178
+ onChange: datetime.setHours,
179
+ onBlur: (e) => datetime.setHours(e, true),
180
+ value: datetime.hours,
181
+ width: 2,
182
+ name: `${name}-hours`,
183
+ id: `${name}-hours`,
184
+ maxLength: "2",
185
+ disabled: props.disabled,
186
+ "aria-required": props["aria-required"],
187
+ error: !datetime.hours ? props.error : false
188
+ }
189
+ ), /* @__PURE__ */ import_react.default.createElement(
190
+ DateTimePart,
191
+ {
192
+ label: t("form.label.minutes"),
193
+ onChange: datetime.setMinutes,
194
+ onBlur: (e) => datetime.setMinutes(e, true),
195
+ value: datetime.minutes,
196
+ width: 2,
197
+ name: `${name}-minutes`,
198
+ id: `${name}-minutes`,
199
+ maxLength: "2",
200
+ disabled: props.disabled,
201
+ "aria-required": props["aria-required"],
202
+ error: !datetime.minutes ? props.error : false
203
+ }
204
+ ));
205
+ };
206
+ var DateTimeInput_default = DateTimeInput;
207
+ // Annotate the CommonJS export names for ESM import in node:
208
+ 0 && (module.exports = {
209
+ DateTimeInput
210
+ });
211
+ //# sourceMappingURL=index.js.map
@@ -0,0 +1,7 @@
1
+ {
2
+ "version": 3,
3
+ "sources": ["../../../../src/inputs/DateTimeInput/index.tsx"],
4
+ "sourcesContent": ["import React, { useMemo, useState } from 'react';\nimport dayjs from 'dayjs';\nimport customParseFormat from 'dayjs/plugin/customParseFormat';\nimport { UncontrolledFieldProps } from '@digigov/form/Field/types';\nimport {\n DateInputContainer,\n DateInputItem,\n} from '@digigov/ui/form/DateInputContainer';\nimport { useTranslation } from '@digigov/ui/i18n';\ndayjs.extend(customParseFormat);\n\nexport interface DateTimeInputProps\n extends Omit<UncontrolledFieldProps, 'extra'> {\n extra?: {\n max?: string;\n min?: string;\n };\n}\n\nfunction useDateTime(value, onChange) {\n const [year, month, day, hours, minutes] = useMemo(() => {\n if (!value || value.length === 0) {\n onChange('');\n return ['', '', '', '', ''];\n }\n const [datePart, timePart] = value.split(' ');\n const [day, month, year] = datePart.split('/');\n const [hours, minutes] = timePart ? timePart.split(':') : ['', ''];\n return [year, month, day, hours, minutes];\n }, [value]);\n\n function set(year, month, day, hours, minutes) {\n const datePart = `${day || ''}/${month || ''}/${year || ''}`;\n const timePart = hours || minutes ? `${hours || ''}:${minutes || ''}` : '';\n const value = timePart ? `${datePart} ${timePart}` : datePart;\n\n if (!year && !month && !day && !hours && !minutes) {\n onChange(null);\n } else {\n onChange(value);\n }\n }\n\n function setYear(evt) {\n const val = evt.target.value;\n set(val, month, day, hours, minutes);\n }\n\n function setMonth(evt, cast) {\n let val = evt.target.value;\n if (cast && val && val.length === 1) {\n val = '0' + val;\n }\n set(year, val, day, hours, minutes);\n }\n\n function setDay(evt, cast) {\n let val = evt.target.value;\n if (cast && val && val.length === 1) {\n val = '0' + val;\n }\n set(year, month, val, hours, minutes);\n }\n\n function setHours(evt, cast) {\n let val = evt.target.value;\n if (cast && val && val.length === 1) {\n val = '0' + val;\n }\n set(year, month, day, val, minutes);\n }\n\n function setMinutes(evt, cast) {\n let val = evt.target.value;\n if (cast && val && val.length === 1) {\n val = '0' + val;\n }\n set(year, month, day, hours, val);\n }\n\n return {\n day,\n month,\n year,\n hours,\n minutes,\n setYear,\n setMonth,\n setDay,\n setHours,\n setMinutes,\n };\n}\n\nconst VALID_FORMATS = ['DD/MM/YYYY HH:mm', 'DD/MM/YYYY'];\n\nconst makeDateTime = (val) => {\n const date = dayjs(val, VALID_FORMATS, true);\n if (date.isValid()) {\n return date.format('DD/MM/YYYY HH:mm');\n }\n return '';\n};\n\nconst DateTimePart = ({ label, ...props }) => {\n return <DateInputItem {...props}>{label}</DateInputItem>;\n};\n\nexport const DateTimeInput = ({ name, ...props }) => {\n const { t } = useTranslation();\n const [initial] = useState(props.value);\n const value = useMemo(() => {\n if (initial === props.value) {\n return makeDateTime(props.value);\n }\n return props.value;\n }, [props.value, initial]);\n\n const datetime = useDateTime(\n value || makeDateTime(props.defaultValue),\n props.onChange\n );\n\n return (\n <DateInputContainer>\n <DateTimePart\n label={t('form.label.day')}\n onChange={datetime.setDay}\n onBlur={(e) => datetime.setDay(e, true)}\n value={datetime.day}\n width={2}\n name={`${name}-day`}\n maxLength=\"2\"\n disabled={props.disabled}\n aria-required={props['aria-required']}\n error={!datetime.day ? props.error : false}\n id={`${name}-day`}\n />\n <DateTimePart\n label={t('form.label.month')}\n onChange={datetime.setMonth}\n onBlur={(e) => datetime.setMonth(e, true)}\n value={datetime.month}\n width={2}\n name={`${name}-month`}\n id={`${name}-month`}\n maxLength=\"2\"\n disabled={props.disabled}\n aria-required={props['aria-required']}\n error={!datetime.month ? props.error : false}\n />\n <DateTimePart\n label={t('form.label.year')}\n onChange={datetime.setYear}\n value={datetime.year}\n width={4}\n name={`${name}-year`}\n id={`${name}-year`}\n maxLength=\"4\"\n disabled={props.disabled}\n aria-required={props['aria-required']}\n error={!datetime.year ? props.error : false}\n />\n <DateTimePart\n label={t('form.label.hours')}\n onChange={datetime.setHours}\n onBlur={(e) => datetime.setHours(e, true)}\n value={datetime.hours}\n width={2}\n name={`${name}-hours`}\n id={`${name}-hours`}\n maxLength=\"2\"\n disabled={props.disabled}\n aria-required={props['aria-required']}\n error={!datetime.hours ? props.error : false}\n />\n <DateTimePart\n label={t('form.label.minutes')}\n onChange={datetime.setMinutes}\n onBlur={(e) => datetime.setMinutes(e, true)}\n value={datetime.minutes}\n width={2}\n name={`${name}-minutes`}\n id={`${name}-minutes`}\n maxLength=\"2\"\n disabled={props.disabled}\n aria-required={props['aria-required']}\n error={!datetime.minutes ? props.error : false}\n />\n </DateInputContainer>\n );\n};\n\nexport default DateTimeInput;\n"],
5
+ "mappings": "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",
6
+ "names": ["dayjs", "customParseFormat", "day", "month", "year", "hours", "minutes", "value", "React"]
7
+ }
@@ -32,14 +32,16 @@ __export(FileInput_exports, {
32
32
  });
33
33
  module.exports = __toCommonJS(FileInput_exports);
34
34
  var import_react = __toESM(require("react"));
35
- var import_FileUpload = __toESM(require("@digigov/react-core/FileUpload"));
36
- var import_FileUploadContainer = __toESM(require("@digigov/react-core/FileUploadContainer"));
37
- var import_Hint = __toESM(require("@digigov/react-core/Hint"));
38
- var import_Button = __toESM(require("@digigov/ui/form/Button"));
35
+ var import_Button = require("@digigov/ui/form/Button");
36
+ var import_FileUpload = require("@digigov/ui/form/FileUpload");
39
37
  var import_i18n = require("@digigov/ui/i18n");
40
- var import_Paragraph = __toESM(require("@digigov/ui/typography/Paragraph"));
41
- const FileInput = import_react.default.forwardRef(function FileInput2({ name, extra = {}, disabled, reset, onChange, ...props }, ref) {
38
+ var import_Hint = require("@digigov/ui/typography/Hint");
39
+ var import_Paragraph = require("@digigov/ui/typography/Paragraph");
40
+ const FileInput = import_react.default.forwardRef(function FileInput2({ name, disabled, reset, onChange, extra, ...props }, ref) {
42
41
  const { t } = (0, import_i18n.useTranslation)();
42
+ const variant = extra?.variant || "none";
43
+ const buttonVariant = extra?.buttonVariant;
44
+ const resetButtonColor = extra?.resetButtonColor;
43
45
  const [files, setFiles] = (0, import_react.useState)([]);
44
46
  const handleChange = (e) => {
45
47
  const target = e.target;
@@ -49,29 +51,41 @@ const FileInput = import_react.default.forwardRef(function FileInput2({ name, ex
49
51
  setFiles(selectedFiles);
50
52
  onChange(e);
51
53
  };
52
- return /* @__PURE__ */ import_react.default.createElement(import_react.default.Fragment, null, /* @__PURE__ */ import_react.default.createElement(import_FileUploadContainer.default, { hasFiles: files && files.length > 0 }, files?.length ? /* @__PURE__ */ import_react.default.createElement(import_react.default.Fragment, null, /* @__PURE__ */ import_react.default.createElement(import_Paragraph.default, null, /* @__PURE__ */ import_react.default.createElement("b", null, t("upload.file"), ":"), " ", `${files.join(", ")}`)) : /* @__PURE__ */ import_react.default.createElement(import_Hint.default, null, t("upload.no_file")), /* @__PURE__ */ import_react.default.createElement(
53
- import_FileUpload.default,
54
+ return /* @__PURE__ */ import_react.default.createElement(import_react.default.Fragment, null, /* @__PURE__ */ import_react.default.createElement(
55
+ import_FileUpload.FileUploadContainer,
54
56
  {
55
- ref,
56
- hasFiles: !!files?.length,
57
- name,
58
- disabled,
59
- onChange: handleChange,
60
- ...{ ...props, required: void 0 }
57
+ variant,
58
+ hasFiles: files && files.length > 0
61
59
  },
62
- files?.length ? t("upload.change_file") : t("upload.choose_file")
63
- ), files !== void 0 && files.length > 0 && /* @__PURE__ */ import_react.default.createElement(import_react.default.Fragment, null, /* @__PURE__ */ import_react.default.createElement(
64
- import_Button.default,
65
- {
66
- variant: "link",
67
- onClick: (event) => {
68
- event.preventDefault();
69
- reset({ [name]: "" });
70
- setFiles(void 0);
71
- }
72
- },
73
- t("upload.reset_file")
74
- ))));
60
+ files?.length ? /* @__PURE__ */ import_react.default.createElement(import_react.default.Fragment, null, /* @__PURE__ */ import_react.default.createElement(import_Paragraph.Paragraph, null, /* @__PURE__ */ import_react.default.createElement("b", null, t("upload.file"), ":"), " ", `${files.join(", ")}`)) : /* @__PURE__ */ import_react.default.createElement(import_Hint.Hint, null, /* @__PURE__ */ import_react.default.createElement("b", null, t("upload.file"), ": "), t("upload.no_file")),
61
+ /* @__PURE__ */ import_react.default.createElement(
62
+ import_FileUpload.FileUpload,
63
+ {
64
+ ref,
65
+ hasFiles: !!files?.length,
66
+ name,
67
+ variant: buttonVariant,
68
+ disabled,
69
+ onChange: handleChange,
70
+ id: name,
71
+ ...{ ...props, required: void 0, Field: void 0 }
72
+ },
73
+ files?.length ? t("upload.change_file") : t("upload.choose_file")
74
+ ),
75
+ files !== void 0 && files.length > 0 && /* @__PURE__ */ import_react.default.createElement(import_react.default.Fragment, null, /* @__PURE__ */ import_react.default.createElement(
76
+ import_Button.Button,
77
+ {
78
+ variant: "link",
79
+ onClick: (event) => {
80
+ event.preventDefault();
81
+ reset({ [name]: "" });
82
+ setFiles(void 0);
83
+ },
84
+ color: resetButtonColor
85
+ },
86
+ t("upload.reset_file")
87
+ ))
88
+ ));
75
89
  });
76
90
  var FileInput_default = FileInput;
77
91
  // Annotate the CommonJS export names for ESM import in node:
@@ -1,7 +1,7 @@
1
1
  {
2
2
  "version": 3,
3
3
  "sources": ["../../../../src/inputs/FileInput/index.tsx"],
4
- "sourcesContent": ["import React, { useState } from 'react';\nimport { UncontrolledFieldProps } from '@digigov/form/Field/types';\nimport FileUpload from '@digigov/react-core/FileUpload';\nimport FileUploadContainer from '@digigov/react-core/FileUploadContainer';\nimport CoreHint from '@digigov/react-core/Hint';\nimport Button from '@digigov/ui/form/Button';\nimport { useTranslation } from '@digigov/ui/i18n';\nimport Paragraph from '@digigov/ui/typography/Paragraph';\nexport interface FileInputProps extends Omit<UncontrolledFieldProps, 'extra'> {\n extra?: {\n className?: string;\n multiple?: boolean;\n accept?: string;\n limit: {\n maxSize?: number;\n };\n };\n}\n\n// eslint-disable-next-line @typescript-eslint/no-explicit-any\nexport const FileInput: React.FC<any> = React.forwardRef(function FileInput(\n { name, extra = {}, disabled, reset, onChange, ...props },\n ref: any\n) {\n const { t } = useTranslation();\n const [files, setFiles] = useState<Array<string> | undefined>([]);\n const handleChange = (e) => {\n const target = e.target as HTMLInputElement;\n const selectedFiles = Array.from(\n target.files as ArrayLike<{ name: string }>\n ).map(({ name }) => name);\n setFiles(selectedFiles);\n // proceed calling the onChange provided\n // by react-hook-form\n onChange(e);\n };\n return (\n <>\n <FileUploadContainer hasFiles={files && files.length > 0}>\n {files?.length ? (\n <>\n <Paragraph>\n <b>{t('upload.file')}:</b> {`${files.join(', ')}`}\n </Paragraph>\n </>\n ) : (\n <CoreHint>{t('upload.no_file')}</CoreHint>\n )}\n <FileUpload\n ref={ref}\n hasFiles={!!files?.length}\n name={name}\n disabled={disabled}\n onChange={handleChange}\n {...{ ...props, required: undefined }}\n >\n {files?.length ? t('upload.change_file') : t('upload.choose_file')}\n </FileUpload>\n {files !== undefined && files.length > 0 && (\n <>\n <Button\n variant=\"link\"\n onClick={(event) => {\n event.preventDefault();\n reset({ [name]: '' });\n setFiles(undefined);\n }}\n >\n {t('upload.reset_file')}\n </Button>\n </>\n )}\n </FileUploadContainer>\n </>\n );\n});\n\nexport default FileInput;\n"],
5
- "mappings": ";;;;;;;;;;;;;;;;;;;;;;;;;;;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,mBAAgC;AAEhC,wBAAuB;AACvB,iCAAgC;AAChC,kBAAqB;AACrB,oBAAmB;AACnB,kBAA+B;AAC/B,uBAAsB;AAaf,MAAM,YAA2B,aAAAA,QAAM,WAAW,SAASC,WAChE,EAAE,MAAM,QAAQ,CAAC,GAAG,UAAU,OAAO,UAAU,GAAG,MAAM,GACxD,KACA;AACA,QAAM,EAAE,EAAE,QAAI,4BAAe;AAC7B,QAAM,CAAC,OAAO,QAAQ,QAAI,uBAAoC,CAAC,CAAC;AAChE,QAAM,eAAe,CAAC,MAAM;AAC1B,UAAM,SAAS,EAAE;AACjB,UAAM,gBAAgB,MAAM;AAAA,MAC1B,OAAO;AAAA,IACT,EAAE,IAAI,CAAC,EAAE,MAAAC,MAAK,MAAMA,KAAI;AACxB,aAAS,aAAa;AAGtB,aAAS,CAAC;AAAA,EACZ;AACA,SACE,6BAAAF,QAAA,2BAAAA,QAAA,gBACE,6BAAAA,QAAA,cAAC,2BAAAG,SAAA,EAAoB,UAAU,SAAS,MAAM,SAAS,KACpD,OAAO,SACN,6BAAAH,QAAA,2BAAAA,QAAA,gBACE,6BAAAA,QAAA,cAAC,iBAAAI,SAAA,MACC,6BAAAJ,QAAA,cAAC,WAAG,EAAE,aAAa,GAAE,GAAC,GAAI,KAAE,GAAG,MAAM,KAAK,IAAI,CAAC,EACjD,CACF,IAEA,6BAAAA,QAAA,cAAC,YAAAK,SAAA,MAAU,EAAE,gBAAgB,CAAE,GAEjC,6BAAAL,QAAA;AAAA,IAAC,kBAAAM;AAAA,IAAA;AAAA,MACC;AAAA,MACA,UAAU,CAAC,CAAC,OAAO;AAAA,MACnB;AAAA,MACA;AAAA,MACA,UAAU;AAAA,MACT,GAAG,EAAE,GAAG,OAAO,UAAU,OAAU;AAAA;AAAA,IAEnC,OAAO,SAAS,EAAE,oBAAoB,IAAI,EAAE,oBAAoB;AAAA,EACnE,GACC,UAAU,UAAa,MAAM,SAAS,KACrC,6BAAAN,QAAA,2BAAAA,QAAA,gBACE,6BAAAA,QAAA;AAAA,IAAC,cAAAO;AAAA,IAAA;AAAA,MACC,SAAQ;AAAA,MACR,SAAS,CAAC,UAAU;AAClB,cAAM,eAAe;AACrB,cAAM,EAAE,CAAC,IAAI,GAAG,GAAG,CAAC;AACpB,iBAAS,MAAS;AAAA,MACpB;AAAA;AAAA,IAEC,EAAE,mBAAmB;AAAA,EACxB,CACF,CAEJ,CACF;AAEJ,CAAC;AAED,IAAO,oBAAQ;",
6
- "names": ["React", "FileInput", "name", "FileUploadContainer", "Paragraph", "CoreHint", "FileUpload", "Button"]
4
+ "sourcesContent": ["import React, { useState } from 'react';\nimport { UncontrolledFieldProps } from '@digigov/form/Field/types';\nimport { Button } from '@digigov/ui/form/Button';\nimport { FileUpload, FileUploadContainer } from '@digigov/ui/form/FileUpload';\nimport { useTranslation } from '@digigov/ui/i18n';\nimport { Hint } from '@digigov/ui/typography/Hint';\nimport { Paragraph } from '@digigov/ui/typography/Paragraph';\nexport interface FileInputProps extends Omit<UncontrolledFieldProps, 'extra'> {\n extra?: {\n className?: string;\n multiple?: boolean;\n accept?: string;\n limit: {\n maxSize?: number;\n };\n variant?: 'border' | 'none';\n buttonVariant?: 'link' | 'button';\n resetButtonColor?: 'primary' | 'secondary' | 'warning';\n locales?: {\n file?: string;\n chooseFile?: string;\n changeFile?: string;\n resetFile?: string;\n };\n };\n}\n\n// eslint-disable-next-line @typescript-eslint/no-explicit-any\nexport const FileInput: React.FC<any> = React.forwardRef(function FileInput(\n { name, disabled, reset, onChange, extra, ...props },\n ref: any\n) {\n const { t } = useTranslation();\n const variant = extra?.variant || 'none';\n const buttonVariant = extra?.buttonVariant;\n const resetButtonColor = extra?.resetButtonColor;\n const [files, setFiles] = useState<string[] | undefined>([]);\n const handleChange = (e) => {\n const target = e.target as HTMLInputElement;\n const selectedFiles = Array.from(\n target.files as ArrayLike<{ name: string }>\n ).map(({ name }) => name);\n setFiles(selectedFiles);\n // proceed calling the onChange provided\n // by react-hook-form\n onChange(e);\n };\n return (\n <>\n <FileUploadContainer\n variant={variant}\n hasFiles={files && files.length > 0}\n >\n {files?.length ? (\n <>\n <Paragraph>\n <b>{t('upload.file')}:</b> {`${files.join(', ')}`}\n </Paragraph>\n </>\n ) : (\n <Hint>\n <b>\n {t('upload.file')}\n {': '}\n </b>\n {t('upload.no_file')}\n </Hint>\n )}\n <FileUpload\n ref={ref}\n hasFiles={!!files?.length}\n name={name}\n variant={buttonVariant}\n disabled={disabled}\n onChange={handleChange}\n id={name}\n {...{ ...props, required: undefined, Field: undefined }}\n >\n {files?.length ? t('upload.change_file') : t('upload.choose_file')}\n </FileUpload>\n {files !== undefined && files.length > 0 && (\n <>\n <Button\n variant=\"link\"\n onClick={(event) => {\n event.preventDefault();\n reset({ [name]: '' });\n setFiles(undefined);\n }}\n color={resetButtonColor}\n >\n {t('upload.reset_file')}\n </Button>\n </>\n )}\n </FileUploadContainer>\n </>\n );\n});\n\nexport default FileInput;\n"],
5
+ "mappings": ";;;;;;;;;;;;;;;;;;;;;;;;;;;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,mBAAgC;AAEhC,oBAAuB;AACvB,wBAAgD;AAChD,kBAA+B;AAC/B,kBAAqB;AACrB,uBAA0B;AAsBnB,MAAM,YAA2B,aAAAA,QAAM,WAAW,SAASC,WAChE,EAAE,MAAM,UAAU,OAAO,UAAU,OAAO,GAAG,MAAM,GACnD,KACA;AACA,QAAM,EAAE,EAAE,QAAI,4BAAe;AAC7B,QAAM,UAAU,OAAO,WAAW;AAClC,QAAM,gBAAgB,OAAO;AAC7B,QAAM,mBAAmB,OAAO;AAChC,QAAM,CAAC,OAAO,QAAQ,QAAI,uBAA+B,CAAC,CAAC;AAC3D,QAAM,eAAe,CAAC,MAAM;AAC1B,UAAM,SAAS,EAAE;AACjB,UAAM,gBAAgB,MAAM;AAAA,MAC1B,OAAO;AAAA,IACT,EAAE,IAAI,CAAC,EAAE,MAAAC,MAAK,MAAMA,KAAI;AACxB,aAAS,aAAa;AAGtB,aAAS,CAAC;AAAA,EACZ;AACA,SACE,6BAAAF,QAAA,2BAAAA,QAAA,gBACE,6BAAAA,QAAA;AAAA,IAAC;AAAA;AAAA,MACC;AAAA,MACA,UAAU,SAAS,MAAM,SAAS;AAAA;AAAA,IAEjC,OAAO,SACN,6BAAAA,QAAA,2BAAAA,QAAA,gBACE,6BAAAA,QAAA,cAAC,kCACC,6BAAAA,QAAA,cAAC,WAAG,EAAE,aAAa,GAAE,GAAC,GAAI,KAAE,GAAG,MAAM,KAAK,IAAI,CAAC,EACjD,CACF,IAEA,6BAAAA,QAAA,cAAC,wBACC,6BAAAA,QAAA,cAAC,WACE,EAAE,aAAa,GACf,IACH,GACC,EAAE,gBAAgB,CACrB;AAAA,IAEF,6BAAAA,QAAA;AAAA,MAAC;AAAA;AAAA,QACC;AAAA,QACA,UAAU,CAAC,CAAC,OAAO;AAAA,QACnB;AAAA,QACA,SAAS;AAAA,QACT;AAAA,QACA,UAAU;AAAA,QACV,IAAI;AAAA,QACH,GAAG,EAAE,GAAG,OAAO,UAAU,QAAW,OAAO,OAAU;AAAA;AAAA,MAErD,OAAO,SAAS,EAAE,oBAAoB,IAAI,EAAE,oBAAoB;AAAA,IACnE;AAAA,IACC,UAAU,UAAa,MAAM,SAAS,KACrC,6BAAAA,QAAA,2BAAAA,QAAA,gBACE,6BAAAA,QAAA;AAAA,MAAC;AAAA;AAAA,QACC,SAAQ;AAAA,QACR,SAAS,CAAC,UAAU;AAClB,gBAAM,eAAe;AACrB,gBAAM,EAAE,CAAC,IAAI,GAAG,GAAG,CAAC;AACpB,mBAAS,MAAS;AAAA,QACpB;AAAA,QACA,OAAO;AAAA;AAAA,MAEN,EAAE,mBAAmB;AAAA,IACxB,CACF;AAAA,EAEJ,CACF;AAEJ,CAAC;AAED,IAAO,oBAAQ;",
6
+ "names": ["React", "FileInput", "name"]
7
7
  }