@soyfri/shared-library 2.0.0-beta.3 → 2.0.0-beta.31

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 (359) hide show
  1. package/Alert-B3SMPD1s.cjs +31 -0
  2. package/Alert-B3SMPD1s.cjs.map +1 -0
  3. package/Alert-YsPScpSE.js +32 -0
  4. package/Alert-YsPScpSE.js.map +1 -0
  5. package/Autocomplete-C_lW1VER.js +337 -0
  6. package/Autocomplete-C_lW1VER.js.map +1 -0
  7. package/Autocomplete-CejWztBY.cjs +336 -0
  8. package/Autocomplete-CejWztBY.cjs.map +1 -0
  9. package/Avatar-Dw5rzayR.cjs +166 -0
  10. package/Avatar-Dw5rzayR.cjs.map +1 -0
  11. package/Avatar-H8akSege.js +167 -0
  12. package/Avatar-H8akSege.js.map +1 -0
  13. package/Button-C17mExpd.cjs.map +1 -1
  14. package/Button-UkkP-bNw.js.map +1 -1
  15. package/Card-DYKGY-NG.js +116 -0
  16. package/Card-DYKGY-NG.js.map +1 -0
  17. package/Card-Dr1-ATRY.cjs +115 -0
  18. package/Card-Dr1-ATRY.cjs.map +1 -0
  19. package/Checkbox-BCqMFWt4.cjs +187 -0
  20. package/Checkbox-BCqMFWt4.cjs.map +1 -0
  21. package/Checkbox-gB5YKkVo.js +188 -0
  22. package/Checkbox-gB5YKkVo.js.map +1 -0
  23. package/{components/DateRangePicker/DateRangePicker.js → Chip-OPYQ1uQ_.js} +33 -35
  24. package/Chip-OPYQ1uQ_.js.map +1 -0
  25. package/{components/DateRangePicker/DateRangePicker.cjs → Chip-qoJLDiva.cjs} +33 -36
  26. package/Chip-qoJLDiva.cjs.map +1 -0
  27. package/DatePicker-_IGWc3I5.js +178 -0
  28. package/DatePicker-_IGWc3I5.js.map +1 -0
  29. package/DatePicker-t7uDTZMl.cjs +177 -0
  30. package/DatePicker-t7uDTZMl.cjs.map +1 -0
  31. package/DateTimePicker-BxQyjTCY.cjs +229 -0
  32. package/DateTimePicker-BxQyjTCY.cjs.map +1 -0
  33. package/DateTimePicker-CrmWav_j.js +230 -0
  34. package/DateTimePicker-CrmWav_j.js.map +1 -0
  35. package/Input-CScC87J5.cjs +185 -0
  36. package/Input-CScC87J5.cjs.map +1 -0
  37. package/Input-DP_fKl38.js +186 -0
  38. package/Input-DP_fKl38.js.map +1 -0
  39. package/Modal-BFpX5AFV.js +347 -0
  40. package/Modal-BFpX5AFV.js.map +1 -0
  41. package/Modal-CkpuI8ns.cjs +346 -0
  42. package/Modal-CkpuI8ns.cjs.map +1 -0
  43. package/RadioGroup-Dd0rHXSX.cjs +202 -0
  44. package/RadioGroup-Dd0rHXSX.cjs.map +1 -0
  45. package/RadioGroup-bO-ahP9T.js +203 -0
  46. package/RadioGroup-bO-ahP9T.js.map +1 -0
  47. package/Select-BY5Y0qZ1.js +376 -0
  48. package/Select-BY5Y0qZ1.js.map +1 -0
  49. package/Select-CURrHSyl.cjs +375 -0
  50. package/Select-CURrHSyl.cjs.map +1 -0
  51. package/Spinner-B6sThC1p.js +74 -0
  52. package/Spinner-B6sThC1p.js.map +1 -0
  53. package/Spinner-D7qRmNS9.cjs +73 -0
  54. package/Spinner-D7qRmNS9.cjs.map +1 -0
  55. package/Stat-BUcFCGrz.cjs +83 -0
  56. package/Stat-BUcFCGrz.cjs.map +1 -0
  57. package/Stat-C06A_izS.js +84 -0
  58. package/Stat-C06A_izS.js.map +1 -0
  59. package/StatusMessage-B3nXpuRl.cjs +88 -0
  60. package/StatusMessage-B3nXpuRl.cjs.map +1 -0
  61. package/StatusMessage-D0WgSBx7.js +89 -0
  62. package/StatusMessage-D0WgSBx7.js.map +1 -0
  63. package/Step-BArsou1V.js +301 -0
  64. package/Step-BArsou1V.js.map +1 -0
  65. package/Step-Nd7SJbRZ.cjs +300 -0
  66. package/Step-Nd7SJbRZ.cjs.map +1 -0
  67. package/Switch-CQFOopYy.cjs +182 -0
  68. package/Switch-CQFOopYy.cjs.map +1 -0
  69. package/Switch-D72dpkH2.js +183 -0
  70. package/Switch-D72dpkH2.js.map +1 -0
  71. package/Tab-BbP8jBcK.cjs +110 -0
  72. package/Tab-BbP8jBcK.cjs.map +1 -0
  73. package/Tab-BxSxKJsP.js +111 -0
  74. package/Tab-BxSxKJsP.js.map +1 -0
  75. package/Table-C2LbW0B1.js +531 -0
  76. package/Table-C2LbW0B1.js.map +1 -0
  77. package/Table-C4OM6rrC.cjs +530 -0
  78. package/Table-C4OM6rrC.cjs.map +1 -0
  79. package/components/ActionMenu/ActionMenu.cjs +52 -52
  80. package/components/ActionMenu/ActionMenu.cjs.map +1 -1
  81. package/components/ActionMenu/ActionMenu.d.ts +20 -36
  82. package/components/ActionMenu/ActionMenu.js +55 -55
  83. package/components/ActionMenu/ActionMenu.js.map +1 -1
  84. package/components/ActionMenu/index.d.ts +2 -2
  85. package/components/Alert/Alert.cjs +6 -0
  86. package/components/Alert/Alert.cjs.map +1 -0
  87. package/components/Alert/Alert.d.ts +31 -0
  88. package/components/Alert/Alert.js +6 -0
  89. package/components/Alert/Alert.js.map +1 -0
  90. package/components/Alert/index.d.ts +2 -0
  91. package/components/Alert.d.ts +6 -0
  92. package/components/AppBar/AppBar.cjs +3 -220
  93. package/components/AppBar/AppBar.cjs.map +1 -1
  94. package/components/AppBar/AppBar.d.ts +6 -6
  95. package/components/AppBar/AppBar.js +6 -223
  96. package/components/AppBar/AppBar.js.map +1 -1
  97. package/components/AppBar/index.d.ts +0 -6
  98. package/components/Autocomplete/Autocomplete.cjs +4 -311
  99. package/components/Autocomplete/Autocomplete.cjs.map +1 -1
  100. package/components/Autocomplete/Autocomplete.d.ts +8 -6
  101. package/components/Autocomplete/Autocomplete.helpers.d.ts +8 -4
  102. package/components/Autocomplete/Autocomplete.js +4 -311
  103. package/components/Autocomplete/Autocomplete.js.map +1 -1
  104. package/components/Autocomplete/_parts/AutocompleteOption.d.ts +5 -8
  105. package/components/Autocomplete/index.d.ts +1 -1
  106. package/components/Avatar/Avatar.cjs +2 -160
  107. package/components/Avatar/Avatar.cjs.map +1 -1
  108. package/components/Avatar/Avatar.d.ts +16 -1
  109. package/components/Avatar/Avatar.js +2 -160
  110. package/components/Avatar/Avatar.js.map +1 -1
  111. package/components/Avatar/index.d.ts +1 -0
  112. package/components/Button/Button.d.ts +5 -5
  113. package/components/Button/index.d.ts +1 -0
  114. package/components/Card/Card.cjs +4 -184
  115. package/components/Card/Card.cjs.map +1 -1
  116. package/components/Card/Card.d.ts +21 -50
  117. package/components/Card/Card.js +4 -184
  118. package/components/Card/Card.js.map +1 -1
  119. package/components/Card/Card.sx.d.ts +3 -6
  120. package/components/Card/index.d.ts +1 -1
  121. package/components/Checkbox/Checkbox.cjs +6 -0
  122. package/components/Checkbox/Checkbox.cjs.map +1 -0
  123. package/components/Checkbox/Checkbox.d.ts +55 -0
  124. package/components/Checkbox/Checkbox.js +6 -0
  125. package/components/Checkbox/Checkbox.js.map +1 -0
  126. package/components/Checkbox/Checkbox.sx.d.ts +13 -0
  127. package/components/Checkbox/index.d.ts +2 -0
  128. package/components/Checkbox.d.ts +6 -0
  129. package/components/Chip/Chip.cjs +4 -72
  130. package/components/Chip/Chip.cjs.map +1 -1
  131. package/components/Chip/Chip.js +3 -71
  132. package/components/Chip/Chip.js.map +1 -1
  133. package/components/Chip/index.d.ts +2 -1
  134. package/components/Chip.d.ts +4 -0
  135. package/components/Column/Column.cjs +1 -1
  136. package/components/Column/Column.cjs.map +1 -1
  137. package/components/Column/Column.d.ts +1 -1
  138. package/components/Column/Column.js +1 -1
  139. package/components/Column/Column.js.map +1 -1
  140. package/components/Column/index.d.ts +1 -0
  141. package/components/DatePicker/DatePicker.cjs +3 -200
  142. package/components/DatePicker/DatePicker.cjs.map +1 -1
  143. package/components/DatePicker/DatePicker.d.ts +1 -13
  144. package/components/DatePicker/DatePicker.js +3 -200
  145. package/components/DatePicker/DatePicker.js.map +1 -1
  146. package/components/DatePicker/index.d.ts +1 -1
  147. package/components/DateTimePicker/DateTimePicker.cjs +3 -219
  148. package/components/DateTimePicker/DateTimePicker.cjs.map +1 -1
  149. package/components/DateTimePicker/DateTimePicker.d.ts +10 -6
  150. package/components/DateTimePicker/DateTimePicker.definitions.d.ts +2 -0
  151. package/components/DateTimePicker/DateTimePicker.helpers.d.ts +4 -2
  152. package/components/DateTimePicker/DateTimePicker.js +3 -219
  153. package/components/DateTimePicker/DateTimePicker.js.map +1 -1
  154. package/components/DateTimePicker/index.d.ts +1 -1
  155. package/components/Drawer/Drawer.cjs +25 -24
  156. package/components/Drawer/Drawer.cjs.map +1 -1
  157. package/components/Drawer/Drawer.d.ts +8 -1
  158. package/components/Drawer/Drawer.js +26 -25
  159. package/components/Drawer/Drawer.js.map +1 -1
  160. package/components/Drawer/DrawerItem.d.ts +6 -1
  161. package/components/Gallery/Gallery.cjs +154 -79
  162. package/components/Gallery/Gallery.cjs.map +1 -1
  163. package/components/Gallery/Gallery.d.ts +25 -9
  164. package/components/Gallery/Gallery.js +154 -79
  165. package/components/Gallery/Gallery.js.map +1 -1
  166. package/components/Gallery/GalleryLightbox.d.ts +6 -10
  167. package/components/Gallery/GalleryMain.d.ts +3 -7
  168. package/components/Gallery/GalleryThumbnails.d.ts +7 -11
  169. package/components/Gallery/index.d.ts +2 -1
  170. package/components/Gallery.d.ts +4 -0
  171. package/components/Icon/Icon.cjs +6 -8
  172. package/components/Icon/Icon.cjs.map +1 -1
  173. package/components/Icon/Icon.d.ts +11 -17
  174. package/components/Icon/Icon.js +6 -8
  175. package/components/Icon/Icon.js.map +1 -1
  176. package/components/Icon/index.d.ts +2 -1
  177. package/components/Icon.d.ts +4 -0
  178. package/components/Input/Input.cjs +3 -172
  179. package/components/Input/Input.cjs.map +1 -1
  180. package/components/Input/Input.d.ts +9 -2
  181. package/components/Input/Input.definitions.d.ts +1 -0
  182. package/components/Input/Input.helpers.d.ts +3 -3
  183. package/components/Input/Input.js +3 -172
  184. package/components/Input/Input.js.map +1 -1
  185. package/components/Input/index.d.ts +1 -1
  186. package/components/InputGroup/InputGroup.cjs +23 -22
  187. package/components/InputGroup/InputGroup.cjs.map +1 -1
  188. package/components/InputGroup/InputGroup.d.ts +4 -4
  189. package/components/InputGroup/InputGroup.js +22 -21
  190. package/components/InputGroup/InputGroup.js.map +1 -1
  191. package/components/InputGroup/index.d.ts +2 -1
  192. package/components/InputGroup.d.ts +4 -0
  193. package/components/Modal/Modal.cjs +7 -317
  194. package/components/Modal/Modal.cjs.map +1 -1
  195. package/components/Modal/Modal.d.ts +20 -5
  196. package/components/Modal/Modal.js +6 -316
  197. package/components/Modal/Modal.js.map +1 -1
  198. package/components/Modal/ModalBody.d.ts +6 -1
  199. package/components/Modal/ModalFooter.d.ts +4 -4
  200. package/components/Modal/ModalHeader.d.ts +6 -1
  201. package/components/Modal/index.d.ts +3 -1
  202. package/components/Modal.d.ts +4 -0
  203. package/components/RadioGroup/RadioGroup.cjs +6 -0
  204. package/components/RadioGroup/RadioGroup.cjs.map +1 -0
  205. package/components/RadioGroup/RadioGroup.d.ts +59 -0
  206. package/components/RadioGroup/RadioGroup.definitions.d.ts +6 -0
  207. package/components/RadioGroup/RadioGroup.js +6 -0
  208. package/components/RadioGroup/RadioGroup.js.map +1 -0
  209. package/components/RadioGroup/RadioGroup.sx.d.ts +20 -0
  210. package/components/RadioGroup/index.d.ts +2 -0
  211. package/components/RadioGroup.d.ts +6 -0
  212. package/components/Select/Select.cjs +4 -445
  213. package/components/Select/Select.cjs.map +1 -1
  214. package/components/Select/Select.d.ts +37 -18
  215. package/components/Select/Select.helpers.d.ts +5 -19
  216. package/components/Select/Select.js +4 -445
  217. package/components/Select/Select.js.map +1 -1
  218. package/components/Select/index.d.ts +1 -1
  219. package/components/Spinner/Spinner.cjs +6 -0
  220. package/components/Spinner/Spinner.cjs.map +1 -0
  221. package/components/Spinner/Spinner.d.ts +26 -0
  222. package/components/Spinner/Spinner.js +6 -0
  223. package/components/Spinner/Spinner.js.map +1 -0
  224. package/components/Spinner/index.d.ts +2 -0
  225. package/components/Spinner.d.ts +6 -0
  226. package/components/Stat/Stat.cjs +4 -83
  227. package/components/Stat/Stat.cjs.map +1 -1
  228. package/components/Stat/Stat.js +3 -82
  229. package/components/Stat/Stat.js.map +1 -1
  230. package/components/Stat/index.d.ts +2 -1
  231. package/components/Stat.d.ts +4 -0
  232. package/components/StatusMessage/StatusMessage.cjs +4 -77
  233. package/components/StatusMessage/StatusMessage.cjs.map +1 -1
  234. package/components/StatusMessage/StatusMessage.d.ts +20 -36
  235. package/components/StatusMessage/StatusMessage.js +3 -76
  236. package/components/StatusMessage/StatusMessage.js.map +1 -1
  237. package/components/StatusMessage/index.d.ts +2 -1
  238. package/components/StatusMessage.d.ts +4 -0
  239. package/components/Stepper/Stepper.cjs +8 -47
  240. package/components/Stepper/Stepper.cjs.map +1 -1
  241. package/components/Stepper/Stepper.d.ts +9 -8
  242. package/components/Stepper/Stepper.js +7 -46
  243. package/components/Stepper/Stepper.js.map +1 -1
  244. package/{hooks/Wizard/WizardContext.d.ts → components/Stepper/StepperContext.d.ts} +29 -23
  245. package/components/Stepper/_hooks/useHorizontalScroll.d.ts +19 -0
  246. package/components/Stepper/_parts/StepperScrollArrow.d.ts +19 -0
  247. package/components/Stepper/index.d.ts +6 -2
  248. package/components/Stepper.d.ts +4 -0
  249. package/components/Switch/Switch.cjs +6 -0
  250. package/components/Switch/Switch.cjs.map +1 -0
  251. package/components/Switch/Switch.d.ts +48 -0
  252. package/components/Switch/Switch.definitions.d.ts +7 -0
  253. package/components/Switch/Switch.js +6 -0
  254. package/components/Switch/Switch.js.map +1 -0
  255. package/components/Switch/Switch.sx.d.ts +22 -0
  256. package/components/Switch/Switch.types.d.ts +1 -0
  257. package/components/Switch/index.d.ts +2 -0
  258. package/components/Switch.d.ts +6 -0
  259. package/components/Table/Table.cjs +2 -528
  260. package/components/Table/Table.cjs.map +1 -1
  261. package/components/Table/Table.d.ts +1 -1
  262. package/components/Table/Table.js +2 -528
  263. package/components/Table/Table.js.map +1 -1
  264. package/components/Tabs/Tabs.cjs +5 -94
  265. package/components/Tabs/Tabs.cjs.map +1 -1
  266. package/components/Tabs/Tabs.d.ts +21 -16
  267. package/components/Tabs/Tabs.js +4 -93
  268. package/components/Tabs/Tabs.js.map +1 -1
  269. package/components/Tabs/index.d.ts +4 -2
  270. package/components/Tabs.d.ts +4 -0
  271. package/components/Timeline/Timeline.cjs +3 -2
  272. package/components/Timeline/Timeline.cjs.map +1 -1
  273. package/components/Timeline/Timeline.d.ts +4 -8
  274. package/components/Timeline/Timeline.js +3 -2
  275. package/components/Timeline/Timeline.js.map +1 -1
  276. package/components/Timeline/index.d.ts +4 -2
  277. package/components/Timeline.d.ts +4 -0
  278. package/components/_shared/mergeSx.d.ts +7 -0
  279. package/{formField.sx-DfVbMe0V.js → formField.sx-8_QRnKxv.js} +2 -11
  280. package/formField.sx-8_QRnKxv.js.map +1 -0
  281. package/{formField.sx-CQ1mbk9M.cjs → formField.sx-BAX7KwMR.cjs} +10 -19
  282. package/formField.sx-BAX7KwMR.cjs.map +1 -0
  283. package/index.cjs +96 -6
  284. package/index.cjs.map +1 -1
  285. package/index.d.ts +36 -0
  286. package/index.js +70 -4
  287. package/index.js.map +1 -1
  288. package/local/affiliations/affiliations.dev.soyfri.com-key.pem +28 -0
  289. package/local/affiliations/affiliations.dev.soyfri.com.pem +27 -0
  290. package/local/aficiliaciones/afiliaciones.dev.soyfri.com-key.pem +28 -0
  291. package/local/aficiliaciones/afiliaciones.dev.soyfri.com.pem +27 -0
  292. package/local/afiliaciones/afiliaciones.dev.soyfri.com-key.pem +28 -0
  293. package/local/afiliaciones/afiliaciones.dev.soyfri.com.pem +27 -0
  294. package/local/root/rootCA-key.pem +40 -0
  295. package/local/root/rootCA.pem +30 -0
  296. package/local/soporte/supportweb.dev.soyfri.com-key.pem +28 -0
  297. package/local/soporte/supportweb.dev.soyfri.com.pem +27 -0
  298. package/local/support/supportweb.dev.soyfri.com-key.pem +28 -0
  299. package/local/support/supportweb.dev.soyfri.com.pem +27 -0
  300. package/mergeSx-BXoNZjB_.js +10 -0
  301. package/mergeSx-BXoNZjB_.js.map +1 -0
  302. package/mergeSx-Dbccoo_H.cjs +9 -0
  303. package/mergeSx-Dbccoo_H.cjs.map +1 -0
  304. package/mui.d.ts +3 -1
  305. package/package.json +78 -73
  306. package/{resolvePreset-CT3kU-K2.cjs → resolvePreset-CxTI6_Ln.cjs} +3 -3
  307. package/{resolvePreset-CT3kU-K2.cjs.map → resolvePreset-CxTI6_Ln.cjs.map} +1 -1
  308. package/{resolvePreset-B-IB0ehH.js → resolvePreset-K6_BfWHD.js} +3 -3
  309. package/{resolvePreset-B-IB0ehH.js.map → resolvePreset-K6_BfWHD.js.map} +1 -1
  310. package/theme/componentStyles.d.ts +1 -1
  311. package/tokens-BRrcP_p_.js +21 -0
  312. package/tokens-BRrcP_p_.js.map +1 -0
  313. package/tokens-jaWWNk39.cjs +20 -0
  314. package/tokens-jaWWNk39.cjs.map +1 -0
  315. package/utils/index.d.ts +2 -0
  316. package/{components/ScrollTopButton → utils}/scrollToTop.d.ts +6 -7
  317. package/components/AppBar/AppBarBrand.d.ts +0 -31
  318. package/components/AppBar/AppBarUserMenu.d.ts +0 -65
  319. package/components/Autocomplete/Autocomplete.types.d.ts +0 -1
  320. package/components/DatePicker/DatePicker.types.d.ts +0 -1
  321. package/components/DateRangePicker/DateRangePicker.cjs.map +0 -1
  322. package/components/DateRangePicker/DateRangePicker.d.ts +0 -15
  323. package/components/DateRangePicker/DateRangePicker.definitions.d.ts +0 -6
  324. package/components/DateRangePicker/DateRangePicker.js.map +0 -1
  325. package/components/DateRangePicker/index.d.ts +0 -1
  326. package/components/DateRangePicker.d.ts +0 -2
  327. package/components/DateTimePicker/DateTimePicker.types.d.ts +0 -1
  328. package/components/Input/Input.types.d.ts +0 -1
  329. package/components/PageLoader/PageLoader.cjs +0 -61
  330. package/components/PageLoader/PageLoader.cjs.map +0 -1
  331. package/components/PageLoader/PageLoader.d.ts +0 -38
  332. package/components/PageLoader/PageLoader.js +0 -61
  333. package/components/PageLoader/PageLoader.js.map +0 -1
  334. package/components/PageLoader/index.d.ts +0 -2
  335. package/components/PageLoader.d.ts +0 -6
  336. package/components/ScrollTopButton/ScrollTopButton.cjs +0 -79
  337. package/components/ScrollTopButton/ScrollTopButton.cjs.map +0 -1
  338. package/components/ScrollTopButton/ScrollTopButton.d.ts +0 -48
  339. package/components/ScrollTopButton/ScrollTopButton.js +0 -79
  340. package/components/ScrollTopButton/ScrollTopButton.js.map +0 -1
  341. package/components/ScrollTopButton/index.d.ts +0 -4
  342. package/components/ScrollTopButton.d.ts +0 -6
  343. package/components/Select/Select.definitions.d.ts +0 -17
  344. package/components/Select/Select.types.d.ts +0 -1
  345. package/components/Select/_parts/SelectSearchHeader.d.ts +0 -15
  346. package/formField.sx-CQ1mbk9M.cjs.map +0 -1
  347. package/formField.sx-DfVbMe0V.js.map +0 -1
  348. package/hooks/Wizard/Wizard.cjs +0 -7
  349. package/hooks/Wizard/Wizard.cjs.map +0 -1
  350. package/hooks/Wizard/Wizard.js +0 -7
  351. package/hooks/Wizard/Wizard.js.map +0 -1
  352. package/hooks/Wizard/index.d.ts +0 -3
  353. package/hooks/Wizard/useWizard.d.ts +0 -9
  354. package/hooks/Wizard.d.ts +0 -2
  355. package/useWizard-CWdIxZzX.cjs +0 -94
  356. package/useWizard-CWdIxZzX.cjs.map +0 -1
  357. package/useWizard-CWq--C3o.js +0 -95
  358. package/useWizard-CWq--C3o.js.map +0 -1
  359. /package/{styles.css → index.css} +0 -0
@@ -1 +1 @@
1
- {"version":3,"file":"Icon.cjs","sources":["../../../src/components/Icon/Icon.tsx"],"sourcesContent":["import React, { type ReactNode, useMemo } from 'react';\nimport { Badge, styled } from '@mui/material';\n\nexport type IconSize = 'xs' | 'sm' | 'md' | 'lg' | 'xl';\n\nexport interface IconProps {\n /**\n * Contenido icono. Modo legacy: acepta un elemento MUI o SVG ya armado.\n * Si se usa junto con `path` o `url`, `children` tiene prioridad.\n */\n children?: ReactNode;\n /**\n * Ruta SVG inline (el contenido del atributo `d` de un `<path>`). Útil para\n * los iconos custom de Metronic que vienen como strings de path.\n *\n * ```tsx\n * <Icon path=\"M12 2L2 22h20L12 2z\" />\n * ```\n *\n * Si el string contiene el tag `<svg>` completo (no solo el `d`), también\n * se soporta y se inyecta tal cual via `dangerouslySetInnerHTML`.\n */\n path?: string;\n /**\n * URL a un archivo `.svg` (asset local o remoto). Se renderiza vía `<img>`.\n *\n * ```tsx\n * <Icon url=\"/assets/icons/custom-warning.svg\" />\n * ```\n */\n url?: string;\n /**\n * Alt text cuando se usa `url`. Default: `\"icon\"`.\n */\n alt?: string;\n /**\n * ViewBox cuando se usa `path`. Default: `\"0 0 24 24\"`. Ignorado si `path`\n * ya viene como `<svg>` completo.\n */\n viewBox?: string;\n color?: string;\n outlined?: boolean;\n spin?: boolean;\n badge?: string | number;\n badgeColor?: 'primary' | 'secondary' | 'error';\n badgePosition?: {\n vertical: 'top' | 'bottom';\n horizontal: 'right' | 'left';\n };\n badgeSize?: 'small' | 'medium' | 'large';\n size?: IconSize;\n black?: boolean;\n white?: boolean;\n className?: string;\n}\n\nconst sizeMap: Record<IconSize, number> = {\n xs: 18,\n sm: 24,\n md: 36,\n lg: 48,\n xl: 64,\n};\n\nconst StyledIcon = styled('span')<{\n color?: string;\n fontSize?: number;\n spin?: boolean;\n outlined?: boolean;\n}>(({ color, fontSize, spin, outlined }) => ({\n display: 'inline-flex',\n alignItems: 'center',\n justifyContent: 'center',\n color: color,\n fontSize: fontSize,\n width: fontSize,\n height: fontSize,\n animation: spin ? 'spin 1s linear infinite' : undefined,\n border: outlined ? '1px solid currentColor' : undefined,\n borderRadius: '50%',\n padding: outlined ? 4 : 0,\n '@keyframes spin': {\n '0%': { transform: 'rotate(0deg)' },\n '100%': { transform: 'rotate(360deg)' },\n },\n '& svg': {\n width: '100%',\n height: '100%',\n fill: 'currentColor',\n display: 'block',\n },\n '& img': {\n width: '100%',\n height: '100%',\n display: 'block',\n },\n}));\n\nexport const Icon: React.FC<IconProps> = ({\n children,\n path,\n url,\n alt = 'icon',\n viewBox = '0 0 24 24',\n color = 'var(--primary-color)',\n outlined = false,\n spin = false,\n badge,\n badgeColor = 'primary',\n badgePosition = { vertical: 'bottom', horizontal: 'right' },\n size = 'sm',\n black,\n white,\n className,\n}) => {\n const finalColor = useMemo(() => {\n if (white) return 'white';\n if (black) return 'black';\n return color;\n }, [color, white, black]);\n\n const iconSize = sizeMap[size];\n\n // Resolver el contenido según la prop activa.\n const content = useMemo(() => {\n if (children) return children;\n\n if (path) {\n const trimmed = path.trim();\n // Si es un SVG completo (empieza con <svg), lo inyectamos tal cual.\n if (trimmed.startsWith('<svg')) {\n return <span dangerouslySetInnerHTML={{ __html: trimmed }} />;\n }\n // Si no, asumimos que es el atributo `d` de un <path>.\n return (\n <svg\n xmlns=\"http://www.w3.org/2000/svg\"\n viewBox={viewBox}\n fill=\"currentColor\"\n aria-hidden=\"true\"\n >\n <path d={trimmed} />\n </svg>\n );\n }\n\n if (url) {\n return <img src={url} alt={alt} />;\n }\n\n return null;\n }, [children, path, url, alt, viewBox]);\n\n return (\n <Badge\n badgeContent={badge}\n color={badgeColor}\n anchorOrigin={badgePosition}\n invisible={badge === undefined}\n sx={{ '.MuiBadge-badge': { transform: 'scale(1)' } }}\n >\n <StyledIcon\n color={finalColor}\n fontSize={iconSize}\n spin={spin}\n outlined={outlined}\n className={`hsi-icon ${className || ''}`}\n >\n {content}\n </StyledIcon>\n </Badge>\n );\n};\n\nexport default Icon;\n"],"names":["styled","useMemo","jsx","Badge"],"mappings":";;;;;;AAwDA,MAAM,UAAoC;AAAA,EACxC,IAAI;AAAA,EACJ,IAAI;AAAA,EACJ,IAAI;AAAA,EACJ,IAAI;AAAA,EACJ,IAAI;AACN;AAEA,MAAM,aAAaA,SAAAA,OAAO,MAAM,EAK7B,CAAC,EAAE,OAAO,UAAU,MAAM,gBAAgB;AAAA,EAC3C,SAAS;AAAA,EACT,YAAY;AAAA,EACZ,gBAAgB;AAAA,EAChB;AAAA,EACA;AAAA,EACA,OAAO;AAAA,EACP,QAAQ;AAAA,EACR,WAAW,OAAO,4BAA4B;AAAA,EAC9C,QAAQ,WAAW,2BAA2B;AAAA,EAC9C,cAAc;AAAA,EACd,SAAS,WAAW,IAAI;AAAA,EACxB,mBAAmB;AAAA,IACjB,MAAM,EAAE,WAAW,eAAA;AAAA,IACnB,QAAQ,EAAE,WAAW,iBAAA;AAAA,EAAiB;AAAA,EAExC,SAAS;AAAA,IACP,OAAO;AAAA,IACP,QAAQ;AAAA,IACR,MAAM;AAAA,IACN,SAAS;AAAA,EAAA;AAAA,EAEX,SAAS;AAAA,IACP,OAAO;AAAA,IACP,QAAQ;AAAA,IACR,SAAS;AAAA,EAAA;AAEb,EAAE;AAEK,MAAM,OAA4B,CAAC;AAAA,EACxC;AAAA,EACA;AAAA,EACA;AAAA,EACA,MAAM;AAAA,EACN,UAAU;AAAA,EACV,QAAQ;AAAA,EACR,WAAW;AAAA,EACX,OAAO;AAAA,EACP;AAAA,EACA,aAAa;AAAA,EACb,gBAAgB,EAAE,UAAU,UAAU,YAAY,QAAA;AAAA,EAClD,OAAO;AAAA,EACP;AAAA,EACA;AAAA,EACA;AACF,MAAM;AACJ,QAAM,aAAaC,MAAAA,QAAQ,MAAM;AAC/B,QAAI,MAAO,QAAO;AAClB,QAAI,MAAO,QAAO;AAClB,WAAO;AAAA,EACT,GAAG,CAAC,OAAO,OAAO,KAAK,CAAC;AAExB,QAAM,WAAW,QAAQ,IAAI;AAG7B,QAAM,UAAUA,MAAAA,QAAQ,MAAM;AAC5B,QAAI,SAAU,QAAO;AAErB,QAAI,MAAM;AACR,YAAM,UAAU,KAAK,KAAA;AAErB,UAAI,QAAQ,WAAW,MAAM,GAAG;AAC9B,8CAAQ,QAAA,EAAK,yBAAyB,EAAE,QAAQ,WAAW;AAAA,MAC7D;AAEA,aACEC,2BAAAA;AAAAA,QAAC;AAAA,QAAA;AAAA,UACC,OAAM;AAAA,UACN;AAAA,UACA,MAAK;AAAA,UACL,eAAY;AAAA,UAEZ,UAAAA,2BAAAA,IAAC,QAAA,EAAK,GAAG,QAAA,CAAS;AAAA,QAAA;AAAA,MAAA;AAAA,IAGxB;AAEA,QAAI,KAAK;AACP,aAAOA,2BAAAA,IAAC,OAAA,EAAI,KAAK,KAAK,IAAA,CAAU;AAAA,IAClC;AAEA,WAAO;AAAA,EACT,GAAG,CAAC,UAAU,MAAM,KAAK,KAAK,OAAO,CAAC;AAEtC,SACEA,2BAAAA;AAAAA,IAACC,SAAAA;AAAAA,IAAA;AAAA,MACC,cAAc;AAAA,MACd,OAAO;AAAA,MACP,cAAc;AAAA,MACd,WAAW,UAAU;AAAA,MACrB,IAAI,EAAE,mBAAmB,EAAE,WAAW,aAAW;AAAA,MAEjD,UAAAD,2BAAAA;AAAAA,QAAC;AAAA,QAAA;AAAA,UACC,OAAO;AAAA,UACP,UAAU;AAAA,UACV;AAAA,UACA;AAAA,UACA,WAAW,YAAY,aAAa,EAAE;AAAA,UAErC,UAAA;AAAA,QAAA;AAAA,MAAA;AAAA,IACH;AAAA,EAAA;AAGN;;"}
1
+ {"version":3,"file":"Icon.cjs","sources":["../../../src/components/Icon/Icon.tsx"],"sourcesContent":["import React, { type ReactNode, useMemo } from 'react';\nimport { Badge, styled } from '@mui/material';\nimport type { SxProps, Theme } from '@mui/material/styles';\n\nexport type IconSize = 'xs' | 'sm' | 'md' | 'lg' | 'xl';\n\nexport interface IconProps {\n /**\n * Contenido del icono. Modo legacy: acepta un elemento MUI o SVG ya armado.\n * Si se usa junto con `path` o `url`, `children` tiene prioridad.\n */\n children?: ReactNode;\n /**\n * Ruta SVG inline. Acepta dos formatos:\n * - Solo el valor del atributo `d` de un `<path>` (ej. `\"M12 2L2 22...\"`).\n * - Un SVG completo (ej. `\"<svg>...</svg>\"`).\n *\n * ⚠️ Seguridad: cuando el string empieza con `<svg`, se inyecta vía\n * `dangerouslySetInnerHTML`. **NUNCA pasar contenido proveniente de input\n * de usuario o de backends no confiables** riesgo XSS.\n */\n path?: string;\n /**\n * URL a un archivo `.svg` (asset local o remoto). Se renderiza vía `<img>`.\n * El color del icono NO aplica en este modo (limitación de `<img>`).\n */\n url?: string;\n /** Alt text cuando se usa `url`. Default: `\"icon\"`. */\n alt?: string;\n /**\n * ViewBox cuando se usa `path`. Default: `\"0 0 24 24\"`. Ignorado si `path`\n * ya viene como `<svg>` completo.\n */\n viewBox?: string;\n color?: string;\n outlined?: boolean;\n spin?: boolean;\n badge?: string | number;\n badgeColor?: 'primary' | 'secondary' | 'error';\n badgePosition?: {\n vertical: 'top' | 'bottom';\n horizontal: 'right' | 'left';\n };\n size?: IconSize;\n black?: boolean;\n white?: boolean;\n className?: string;\n sx?: SxProps<Theme>;\n}\n\nconst sizeMap: Record<IconSize, number> = {\n xs: 18,\n sm: 24,\n md: 36,\n lg: 48,\n xl: 64,\n};\n\nconst StyledIcon = styled('span')<{\n color?: string;\n fontSize?: number;\n spin?: boolean;\n outlined?: boolean;\n}>(({ color, fontSize, spin, outlined }) => ({\n display: 'inline-flex',\n alignItems: 'center',\n justifyContent: 'center',\n color: color,\n fontSize: fontSize,\n width: fontSize,\n height: fontSize,\n animation: spin ? 'spin 1s linear infinite' : undefined,\n border: outlined ? '1px solid currentColor' : undefined,\n borderRadius: '50%',\n padding: outlined ? 4 : 0,\n '@keyframes spin': {\n '0%': { transform: 'rotate(0deg)' },\n '100%': { transform: 'rotate(360deg)' },\n },\n '& svg': {\n width: '100%',\n height: '100%',\n fill: 'currentColor',\n display: 'block',\n },\n '& img': {\n width: '100%',\n height: '100%',\n display: 'block',\n },\n}));\n\nexport const Icon: React.FC<IconProps> = ({\n children,\n path,\n url,\n alt = 'icon',\n viewBox = '0 0 24 24',\n color = 'var(--primary-color)',\n outlined = false,\n spin = false,\n badge,\n badgeColor = 'primary',\n badgePosition = { vertical: 'bottom', horizontal: 'right' },\n size = 'sm',\n black,\n white,\n className,\n sx,\n}) => {\n const finalColor = white ? 'white' : black ? 'black' : color;\n const iconSize = sizeMap[size];\n\n const content = useMemo(() => {\n if (children) return children;\n\n if (path) {\n const trimmed = path.trim();\n if (trimmed.startsWith('<svg')) {\n return <span dangerouslySetInnerHTML={{ __html: trimmed }} />;\n }\n return (\n <svg\n xmlns=\"http://www.w3.org/2000/svg\"\n viewBox={viewBox}\n fill=\"currentColor\"\n aria-hidden=\"true\"\n >\n <path d={trimmed} />\n </svg>\n );\n }\n\n if (url) {\n return <img src={url} alt={alt} />;\n }\n\n return null;\n }, [children, path, url, alt, viewBox]);\n\n return (\n <Badge\n badgeContent={badge}\n color={badgeColor}\n anchorOrigin={badgePosition}\n invisible={badge === undefined}\n sx={{ '.MuiBadge-badge': { transform: 'scale(1)' } }}\n >\n <StyledIcon\n color={finalColor}\n fontSize={iconSize}\n spin={spin}\n outlined={outlined}\n className={`hsi-icon ${className || ''}`}\n sx={sx}\n >\n {content}\n </StyledIcon>\n </Badge>\n );\n};\n\nexport default Icon;\n"],"names":["styled","useMemo","jsx","Badge"],"mappings":";;;;;AAkDA,MAAM,UAAoC;AAAA,EACxC,IAAI;AAAA,EACJ,IAAI;AAAA,EACJ,IAAI;AAAA,EACJ,IAAI;AAAA,EACJ,IAAI;AACN;AAEA,MAAM,aAAaA,SAAAA,OAAO,MAAM,EAK7B,CAAC,EAAE,OAAO,UAAU,MAAM,gBAAgB;AAAA,EAC3C,SAAS;AAAA,EACT,YAAY;AAAA,EACZ,gBAAgB;AAAA,EAChB;AAAA,EACA;AAAA,EACA,OAAO;AAAA,EACP,QAAQ;AAAA,EACR,WAAW,OAAO,4BAA4B;AAAA,EAC9C,QAAQ,WAAW,2BAA2B;AAAA,EAC9C,cAAc;AAAA,EACd,SAAS,WAAW,IAAI;AAAA,EACxB,mBAAmB;AAAA,IACjB,MAAM,EAAE,WAAW,eAAA;AAAA,IACnB,QAAQ,EAAE,WAAW,iBAAA;AAAA,EAAiB;AAAA,EAExC,SAAS;AAAA,IACP,OAAO;AAAA,IACP,QAAQ;AAAA,IACR,MAAM;AAAA,IACN,SAAS;AAAA,EAAA;AAAA,EAEX,SAAS;AAAA,IACP,OAAO;AAAA,IACP,QAAQ;AAAA,IACR,SAAS;AAAA,EAAA;AAEb,EAAE;AAEK,MAAM,OAA4B,CAAC;AAAA,EACxC;AAAA,EACA;AAAA,EACA;AAAA,EACA,MAAM;AAAA,EACN,UAAU;AAAA,EACV,QAAQ;AAAA,EACR,WAAW;AAAA,EACX,OAAO;AAAA,EACP;AAAA,EACA,aAAa;AAAA,EACb,gBAAgB,EAAE,UAAU,UAAU,YAAY,QAAA;AAAA,EAClD,OAAO;AAAA,EACP;AAAA,EACA;AAAA,EACA;AAAA,EACA;AACF,MAAM;AACJ,QAAM,aAAa,QAAQ,UAAU,QAAQ,UAAU;AACvD,QAAM,WAAW,QAAQ,IAAI;AAE7B,QAAM,UAAUC,MAAAA,QAAQ,MAAM;AAC5B,QAAI,SAAU,QAAO;AAErB,QAAI,MAAM;AACR,YAAM,UAAU,KAAK,KAAA;AACrB,UAAI,QAAQ,WAAW,MAAM,GAAG;AAC9B,8CAAQ,QAAA,EAAK,yBAAyB,EAAE,QAAQ,WAAW;AAAA,MAC7D;AACA,aACEC,2BAAAA;AAAAA,QAAC;AAAA,QAAA;AAAA,UACC,OAAM;AAAA,UACN;AAAA,UACA,MAAK;AAAA,UACL,eAAY;AAAA,UAEZ,UAAAA,2BAAAA,IAAC,QAAA,EAAK,GAAG,QAAA,CAAS;AAAA,QAAA;AAAA,MAAA;AAAA,IAGxB;AAEA,QAAI,KAAK;AACP,aAAOA,2BAAAA,IAAC,OAAA,EAAI,KAAK,KAAK,IAAA,CAAU;AAAA,IAClC;AAEA,WAAO;AAAA,EACT,GAAG,CAAC,UAAU,MAAM,KAAK,KAAK,OAAO,CAAC;AAEtC,SACEA,2BAAAA;AAAAA,IAACC,SAAAA;AAAAA,IAAA;AAAA,MACC,cAAc;AAAA,MACd,OAAO;AAAA,MACP,cAAc;AAAA,MACd,WAAW,UAAU;AAAA,MACrB,IAAI,EAAE,mBAAmB,EAAE,WAAW,aAAW;AAAA,MAEjD,UAAAD,2BAAAA;AAAAA,QAAC;AAAA,QAAA;AAAA,UACC,OAAO;AAAA,UACP,UAAU;AAAA,UACV;AAAA,UACA;AAAA,UACA,WAAW,YAAY,aAAa,EAAE;AAAA,UACtC;AAAA,UAEC,UAAA;AAAA,QAAA;AAAA,MAAA;AAAA,IACH;AAAA,EAAA;AAGN;;;"}
@@ -1,34 +1,28 @@
1
1
  import { default as React, ReactNode } from 'react';
2
+ import { SxProps, Theme } from '@mui/material/styles';
2
3
  export type IconSize = 'xs' | 'sm' | 'md' | 'lg' | 'xl';
3
4
  export interface IconProps {
4
5
  /**
5
- * Contenido icono. Modo legacy: acepta un elemento MUI o SVG ya armado.
6
+ * Contenido del icono. Modo legacy: acepta un elemento MUI o SVG ya armado.
6
7
  * Si se usa junto con `path` o `url`, `children` tiene prioridad.
7
8
  */
8
9
  children?: ReactNode;
9
10
  /**
10
- * Ruta SVG inline (el contenido del atributo `d` de un `<path>`). Útil para
11
- * los iconos custom de Metronic que vienen como strings de path.
11
+ * Ruta SVG inline. Acepta dos formatos:
12
+ * - Solo el valor del atributo `d` de un `<path>` (ej. `"M12 2L2 22..."`).
13
+ * - Un SVG completo (ej. `"<svg>...</svg>"`).
12
14
  *
13
- * ```tsx
14
- * <Icon path="M12 2L2 22h20L12 2z" />
15
- * ```
16
- *
17
- * Si el string contiene el tag `<svg>` completo (no solo el `d`), también
18
- * se soporta y se inyecta tal cual via `dangerouslySetInnerHTML`.
15
+ * ⚠️ Seguridad: cuando el string empieza con `<svg`, se inyecta vía
16
+ * `dangerouslySetInnerHTML`. **NUNCA pasar contenido proveniente de input
17
+ * de usuario o de backends no confiables** — riesgo XSS.
19
18
  */
20
19
  path?: string;
21
20
  /**
22
21
  * URL a un archivo `.svg` (asset local o remoto). Se renderiza vía `<img>`.
23
- *
24
- * ```tsx
25
- * <Icon url="/assets/icons/custom-warning.svg" />
26
- * ```
22
+ * El color del icono NO aplica en este modo (limitación de `<img>`).
27
23
  */
28
24
  url?: string;
29
- /**
30
- * Alt text cuando se usa `url`. Default: `"icon"`.
31
- */
25
+ /** Alt text cuando se usa `url`. Default: `"icon"`. */
32
26
  alt?: string;
33
27
  /**
34
28
  * ViewBox cuando se usa `path`. Default: `"0 0 24 24"`. Ignorado si `path`
@@ -44,11 +38,11 @@ export interface IconProps {
44
38
  vertical: 'top' | 'bottom';
45
39
  horizontal: 'right' | 'left';
46
40
  };
47
- badgeSize?: 'small' | 'medium' | 'large';
48
41
  size?: IconSize;
49
42
  black?: boolean;
50
43
  white?: boolean;
51
44
  className?: string;
45
+ sx?: SxProps<Theme>;
52
46
  }
53
47
  export declare const Icon: React.FC<IconProps>;
54
48
  export default Icon;
@@ -1,4 +1,3 @@
1
- import '../../styles.css';/* empty css */
2
1
  import { jsx } from "react/jsx-runtime";
3
2
  import { useMemo } from "react";
4
3
  import { styled, Badge } from "@mui/material";
@@ -52,13 +51,10 @@ const Icon = ({
52
51
  size = "sm",
53
52
  black,
54
53
  white,
55
- className
54
+ className,
55
+ sx
56
56
  }) => {
57
- const finalColor = useMemo(() => {
58
- if (white) return "white";
59
- if (black) return "black";
60
- return color;
61
- }, [color, white, black]);
57
+ const finalColor = white ? "white" : black ? "black" : color;
62
58
  const iconSize = sizeMap[size];
63
59
  const content = useMemo(() => {
64
60
  if (children) return children;
@@ -99,6 +95,7 @@ const Icon = ({
99
95
  spin,
100
96
  outlined,
101
97
  className: `hsi-icon ${className || ""}`,
98
+ sx,
102
99
  children: content
103
100
  }
104
101
  )
@@ -106,6 +103,7 @@ const Icon = ({
106
103
  );
107
104
  };
108
105
  export {
109
- Icon
106
+ Icon,
107
+ Icon as default
110
108
  };
111
109
  //# sourceMappingURL=Icon.js.map
@@ -1 +1 @@
1
- {"version":3,"file":"Icon.js","sources":["../../../src/components/Icon/Icon.tsx"],"sourcesContent":["import React, { type ReactNode, useMemo } from 'react';\nimport { Badge, styled } from '@mui/material';\n\nexport type IconSize = 'xs' | 'sm' | 'md' | 'lg' | 'xl';\n\nexport interface IconProps {\n /**\n * Contenido icono. Modo legacy: acepta un elemento MUI o SVG ya armado.\n * Si se usa junto con `path` o `url`, `children` tiene prioridad.\n */\n children?: ReactNode;\n /**\n * Ruta SVG inline (el contenido del atributo `d` de un `<path>`). Útil para\n * los iconos custom de Metronic que vienen como strings de path.\n *\n * ```tsx\n * <Icon path=\"M12 2L2 22h20L12 2z\" />\n * ```\n *\n * Si el string contiene el tag `<svg>` completo (no solo el `d`), también\n * se soporta y se inyecta tal cual via `dangerouslySetInnerHTML`.\n */\n path?: string;\n /**\n * URL a un archivo `.svg` (asset local o remoto). Se renderiza vía `<img>`.\n *\n * ```tsx\n * <Icon url=\"/assets/icons/custom-warning.svg\" />\n * ```\n */\n url?: string;\n /**\n * Alt text cuando se usa `url`. Default: `\"icon\"`.\n */\n alt?: string;\n /**\n * ViewBox cuando se usa `path`. Default: `\"0 0 24 24\"`. Ignorado si `path`\n * ya viene como `<svg>` completo.\n */\n viewBox?: string;\n color?: string;\n outlined?: boolean;\n spin?: boolean;\n badge?: string | number;\n badgeColor?: 'primary' | 'secondary' | 'error';\n badgePosition?: {\n vertical: 'top' | 'bottom';\n horizontal: 'right' | 'left';\n };\n badgeSize?: 'small' | 'medium' | 'large';\n size?: IconSize;\n black?: boolean;\n white?: boolean;\n className?: string;\n}\n\nconst sizeMap: Record<IconSize, number> = {\n xs: 18,\n sm: 24,\n md: 36,\n lg: 48,\n xl: 64,\n};\n\nconst StyledIcon = styled('span')<{\n color?: string;\n fontSize?: number;\n spin?: boolean;\n outlined?: boolean;\n}>(({ color, fontSize, spin, outlined }) => ({\n display: 'inline-flex',\n alignItems: 'center',\n justifyContent: 'center',\n color: color,\n fontSize: fontSize,\n width: fontSize,\n height: fontSize,\n animation: spin ? 'spin 1s linear infinite' : undefined,\n border: outlined ? '1px solid currentColor' : undefined,\n borderRadius: '50%',\n padding: outlined ? 4 : 0,\n '@keyframes spin': {\n '0%': { transform: 'rotate(0deg)' },\n '100%': { transform: 'rotate(360deg)' },\n },\n '& svg': {\n width: '100%',\n height: '100%',\n fill: 'currentColor',\n display: 'block',\n },\n '& img': {\n width: '100%',\n height: '100%',\n display: 'block',\n },\n}));\n\nexport const Icon: React.FC<IconProps> = ({\n children,\n path,\n url,\n alt = 'icon',\n viewBox = '0 0 24 24',\n color = 'var(--primary-color)',\n outlined = false,\n spin = false,\n badge,\n badgeColor = 'primary',\n badgePosition = { vertical: 'bottom', horizontal: 'right' },\n size = 'sm',\n black,\n white,\n className,\n}) => {\n const finalColor = useMemo(() => {\n if (white) return 'white';\n if (black) return 'black';\n return color;\n }, [color, white, black]);\n\n const iconSize = sizeMap[size];\n\n // Resolver el contenido según la prop activa.\n const content = useMemo(() => {\n if (children) return children;\n\n if (path) {\n const trimmed = path.trim();\n // Si es un SVG completo (empieza con <svg), lo inyectamos tal cual.\n if (trimmed.startsWith('<svg')) {\n return <span dangerouslySetInnerHTML={{ __html: trimmed }} />;\n }\n // Si no, asumimos que es el atributo `d` de un <path>.\n return (\n <svg\n xmlns=\"http://www.w3.org/2000/svg\"\n viewBox={viewBox}\n fill=\"currentColor\"\n aria-hidden=\"true\"\n >\n <path d={trimmed} />\n </svg>\n );\n }\n\n if (url) {\n return <img src={url} alt={alt} />;\n }\n\n return null;\n }, [children, path, url, alt, viewBox]);\n\n return (\n <Badge\n badgeContent={badge}\n color={badgeColor}\n anchorOrigin={badgePosition}\n invisible={badge === undefined}\n sx={{ '.MuiBadge-badge': { transform: 'scale(1)' } }}\n >\n <StyledIcon\n color={finalColor}\n fontSize={iconSize}\n spin={spin}\n outlined={outlined}\n className={`hsi-icon ${className || ''}`}\n >\n {content}\n </StyledIcon>\n </Badge>\n );\n};\n\nexport default Icon;\n"],"names":[],"mappings":";;;;AAwDA,MAAM,UAAoC;AAAA,EACxC,IAAI;AAAA,EACJ,IAAI;AAAA,EACJ,IAAI;AAAA,EACJ,IAAI;AAAA,EACJ,IAAI;AACN;AAEA,MAAM,aAAa,OAAO,MAAM,EAK7B,CAAC,EAAE,OAAO,UAAU,MAAM,gBAAgB;AAAA,EAC3C,SAAS;AAAA,EACT,YAAY;AAAA,EACZ,gBAAgB;AAAA,EAChB;AAAA,EACA;AAAA,EACA,OAAO;AAAA,EACP,QAAQ;AAAA,EACR,WAAW,OAAO,4BAA4B;AAAA,EAC9C,QAAQ,WAAW,2BAA2B;AAAA,EAC9C,cAAc;AAAA,EACd,SAAS,WAAW,IAAI;AAAA,EACxB,mBAAmB;AAAA,IACjB,MAAM,EAAE,WAAW,eAAA;AAAA,IACnB,QAAQ,EAAE,WAAW,iBAAA;AAAA,EAAiB;AAAA,EAExC,SAAS;AAAA,IACP,OAAO;AAAA,IACP,QAAQ;AAAA,IACR,MAAM;AAAA,IACN,SAAS;AAAA,EAAA;AAAA,EAEX,SAAS;AAAA,IACP,OAAO;AAAA,IACP,QAAQ;AAAA,IACR,SAAS;AAAA,EAAA;AAEb,EAAE;AAEK,MAAM,OAA4B,CAAC;AAAA,EACxC;AAAA,EACA;AAAA,EACA;AAAA,EACA,MAAM;AAAA,EACN,UAAU;AAAA,EACV,QAAQ;AAAA,EACR,WAAW;AAAA,EACX,OAAO;AAAA,EACP;AAAA,EACA,aAAa;AAAA,EACb,gBAAgB,EAAE,UAAU,UAAU,YAAY,QAAA;AAAA,EAClD,OAAO;AAAA,EACP;AAAA,EACA;AAAA,EACA;AACF,MAAM;AACJ,QAAM,aAAa,QAAQ,MAAM;AAC/B,QAAI,MAAO,QAAO;AAClB,QAAI,MAAO,QAAO;AAClB,WAAO;AAAA,EACT,GAAG,CAAC,OAAO,OAAO,KAAK,CAAC;AAExB,QAAM,WAAW,QAAQ,IAAI;AAG7B,QAAM,UAAU,QAAQ,MAAM;AAC5B,QAAI,SAAU,QAAO;AAErB,QAAI,MAAM;AACR,YAAM,UAAU,KAAK,KAAA;AAErB,UAAI,QAAQ,WAAW,MAAM,GAAG;AAC9B,mCAAQ,QAAA,EAAK,yBAAyB,EAAE,QAAQ,WAAW;AAAA,MAC7D;AAEA,aACE;AAAA,QAAC;AAAA,QAAA;AAAA,UACC,OAAM;AAAA,UACN;AAAA,UACA,MAAK;AAAA,UACL,eAAY;AAAA,UAEZ,UAAA,oBAAC,QAAA,EAAK,GAAG,QAAA,CAAS;AAAA,QAAA;AAAA,MAAA;AAAA,IAGxB;AAEA,QAAI,KAAK;AACP,aAAO,oBAAC,OAAA,EAAI,KAAK,KAAK,IAAA,CAAU;AAAA,IAClC;AAEA,WAAO;AAAA,EACT,GAAG,CAAC,UAAU,MAAM,KAAK,KAAK,OAAO,CAAC;AAEtC,SACE;AAAA,IAAC;AAAA,IAAA;AAAA,MACC,cAAc;AAAA,MACd,OAAO;AAAA,MACP,cAAc;AAAA,MACd,WAAW,UAAU;AAAA,MACrB,IAAI,EAAE,mBAAmB,EAAE,WAAW,aAAW;AAAA,MAEjD,UAAA;AAAA,QAAC;AAAA,QAAA;AAAA,UACC,OAAO;AAAA,UACP,UAAU;AAAA,UACV;AAAA,UACA;AAAA,UACA,WAAW,YAAY,aAAa,EAAE;AAAA,UAErC,UAAA;AAAA,QAAA;AAAA,MAAA;AAAA,IACH;AAAA,EAAA;AAGN;"}
1
+ {"version":3,"file":"Icon.js","sources":["../../../src/components/Icon/Icon.tsx"],"sourcesContent":["import React, { type ReactNode, useMemo } from 'react';\nimport { Badge, styled } from '@mui/material';\nimport type { SxProps, Theme } from '@mui/material/styles';\n\nexport type IconSize = 'xs' | 'sm' | 'md' | 'lg' | 'xl';\n\nexport interface IconProps {\n /**\n * Contenido del icono. Modo legacy: acepta un elemento MUI o SVG ya armado.\n * Si se usa junto con `path` o `url`, `children` tiene prioridad.\n */\n children?: ReactNode;\n /**\n * Ruta SVG inline. Acepta dos formatos:\n * - Solo el valor del atributo `d` de un `<path>` (ej. `\"M12 2L2 22...\"`).\n * - Un SVG completo (ej. `\"<svg>...</svg>\"`).\n *\n * ⚠️ Seguridad: cuando el string empieza con `<svg`, se inyecta vía\n * `dangerouslySetInnerHTML`. **NUNCA pasar contenido proveniente de input\n * de usuario o de backends no confiables** riesgo XSS.\n */\n path?: string;\n /**\n * URL a un archivo `.svg` (asset local o remoto). Se renderiza vía `<img>`.\n * El color del icono NO aplica en este modo (limitación de `<img>`).\n */\n url?: string;\n /** Alt text cuando se usa `url`. Default: `\"icon\"`. */\n alt?: string;\n /**\n * ViewBox cuando se usa `path`. Default: `\"0 0 24 24\"`. Ignorado si `path`\n * ya viene como `<svg>` completo.\n */\n viewBox?: string;\n color?: string;\n outlined?: boolean;\n spin?: boolean;\n badge?: string | number;\n badgeColor?: 'primary' | 'secondary' | 'error';\n badgePosition?: {\n vertical: 'top' | 'bottom';\n horizontal: 'right' | 'left';\n };\n size?: IconSize;\n black?: boolean;\n white?: boolean;\n className?: string;\n sx?: SxProps<Theme>;\n}\n\nconst sizeMap: Record<IconSize, number> = {\n xs: 18,\n sm: 24,\n md: 36,\n lg: 48,\n xl: 64,\n};\n\nconst StyledIcon = styled('span')<{\n color?: string;\n fontSize?: number;\n spin?: boolean;\n outlined?: boolean;\n}>(({ color, fontSize, spin, outlined }) => ({\n display: 'inline-flex',\n alignItems: 'center',\n justifyContent: 'center',\n color: color,\n fontSize: fontSize,\n width: fontSize,\n height: fontSize,\n animation: spin ? 'spin 1s linear infinite' : undefined,\n border: outlined ? '1px solid currentColor' : undefined,\n borderRadius: '50%',\n padding: outlined ? 4 : 0,\n '@keyframes spin': {\n '0%': { transform: 'rotate(0deg)' },\n '100%': { transform: 'rotate(360deg)' },\n },\n '& svg': {\n width: '100%',\n height: '100%',\n fill: 'currentColor',\n display: 'block',\n },\n '& img': {\n width: '100%',\n height: '100%',\n display: 'block',\n },\n}));\n\nexport const Icon: React.FC<IconProps> = ({\n children,\n path,\n url,\n alt = 'icon',\n viewBox = '0 0 24 24',\n color = 'var(--primary-color)',\n outlined = false,\n spin = false,\n badge,\n badgeColor = 'primary',\n badgePosition = { vertical: 'bottom', horizontal: 'right' },\n size = 'sm',\n black,\n white,\n className,\n sx,\n}) => {\n const finalColor = white ? 'white' : black ? 'black' : color;\n const iconSize = sizeMap[size];\n\n const content = useMemo(() => {\n if (children) return children;\n\n if (path) {\n const trimmed = path.trim();\n if (trimmed.startsWith('<svg')) {\n return <span dangerouslySetInnerHTML={{ __html: trimmed }} />;\n }\n return (\n <svg\n xmlns=\"http://www.w3.org/2000/svg\"\n viewBox={viewBox}\n fill=\"currentColor\"\n aria-hidden=\"true\"\n >\n <path d={trimmed} />\n </svg>\n );\n }\n\n if (url) {\n return <img src={url} alt={alt} />;\n }\n\n return null;\n }, [children, path, url, alt, viewBox]);\n\n return (\n <Badge\n badgeContent={badge}\n color={badgeColor}\n anchorOrigin={badgePosition}\n invisible={badge === undefined}\n sx={{ '.MuiBadge-badge': { transform: 'scale(1)' } }}\n >\n <StyledIcon\n color={finalColor}\n fontSize={iconSize}\n spin={spin}\n outlined={outlined}\n className={`hsi-icon ${className || ''}`}\n sx={sx}\n >\n {content}\n </StyledIcon>\n </Badge>\n );\n};\n\nexport default Icon;\n"],"names":[],"mappings":";;;AAkDA,MAAM,UAAoC;AAAA,EACxC,IAAI;AAAA,EACJ,IAAI;AAAA,EACJ,IAAI;AAAA,EACJ,IAAI;AAAA,EACJ,IAAI;AACN;AAEA,MAAM,aAAa,OAAO,MAAM,EAK7B,CAAC,EAAE,OAAO,UAAU,MAAM,gBAAgB;AAAA,EAC3C,SAAS;AAAA,EACT,YAAY;AAAA,EACZ,gBAAgB;AAAA,EAChB;AAAA,EACA;AAAA,EACA,OAAO;AAAA,EACP,QAAQ;AAAA,EACR,WAAW,OAAO,4BAA4B;AAAA,EAC9C,QAAQ,WAAW,2BAA2B;AAAA,EAC9C,cAAc;AAAA,EACd,SAAS,WAAW,IAAI;AAAA,EACxB,mBAAmB;AAAA,IACjB,MAAM,EAAE,WAAW,eAAA;AAAA,IACnB,QAAQ,EAAE,WAAW,iBAAA;AAAA,EAAiB;AAAA,EAExC,SAAS;AAAA,IACP,OAAO;AAAA,IACP,QAAQ;AAAA,IACR,MAAM;AAAA,IACN,SAAS;AAAA,EAAA;AAAA,EAEX,SAAS;AAAA,IACP,OAAO;AAAA,IACP,QAAQ;AAAA,IACR,SAAS;AAAA,EAAA;AAEb,EAAE;AAEK,MAAM,OAA4B,CAAC;AAAA,EACxC;AAAA,EACA;AAAA,EACA;AAAA,EACA,MAAM;AAAA,EACN,UAAU;AAAA,EACV,QAAQ;AAAA,EACR,WAAW;AAAA,EACX,OAAO;AAAA,EACP;AAAA,EACA,aAAa;AAAA,EACb,gBAAgB,EAAE,UAAU,UAAU,YAAY,QAAA;AAAA,EAClD,OAAO;AAAA,EACP;AAAA,EACA;AAAA,EACA;AAAA,EACA;AACF,MAAM;AACJ,QAAM,aAAa,QAAQ,UAAU,QAAQ,UAAU;AACvD,QAAM,WAAW,QAAQ,IAAI;AAE7B,QAAM,UAAU,QAAQ,MAAM;AAC5B,QAAI,SAAU,QAAO;AAErB,QAAI,MAAM;AACR,YAAM,UAAU,KAAK,KAAA;AACrB,UAAI,QAAQ,WAAW,MAAM,GAAG;AAC9B,mCAAQ,QAAA,EAAK,yBAAyB,EAAE,QAAQ,WAAW;AAAA,MAC7D;AACA,aACE;AAAA,QAAC;AAAA,QAAA;AAAA,UACC,OAAM;AAAA,UACN;AAAA,UACA,MAAK;AAAA,UACL,eAAY;AAAA,UAEZ,UAAA,oBAAC,QAAA,EAAK,GAAG,QAAA,CAAS;AAAA,QAAA;AAAA,MAAA;AAAA,IAGxB;AAEA,QAAI,KAAK;AACP,aAAO,oBAAC,OAAA,EAAI,KAAK,KAAK,IAAA,CAAU;AAAA,IAClC;AAEA,WAAO;AAAA,EACT,GAAG,CAAC,UAAU,MAAM,KAAK,KAAK,OAAO,CAAC;AAEtC,SACE;AAAA,IAAC;AAAA,IAAA;AAAA,MACC,cAAc;AAAA,MACd,OAAO;AAAA,MACP,cAAc;AAAA,MACd,WAAW,UAAU;AAAA,MACrB,IAAI,EAAE,mBAAmB,EAAE,WAAW,aAAW;AAAA,MAEjD,UAAA;AAAA,QAAC;AAAA,QAAA;AAAA,UACC,OAAO;AAAA,UACP,UAAU;AAAA,UACV;AAAA,UACA;AAAA,UACA,WAAW,YAAY,aAAa,EAAE;AAAA,UACtC;AAAA,UAEC,UAAA;AAAA,QAAA;AAAA,MAAA;AAAA,IACH;AAAA,EAAA;AAGN;"}
@@ -1 +1,2 @@
1
- export { default as Icon } from './Icon';
1
+ export { Icon, default } from './Icon';
2
+ export type { IconProps, IconSize } from './Icon';
@@ -1,2 +1,6 @@
1
1
  export * from './Icon/index'
2
2
  export {}
3
+ import _default from './Icon/index'
4
+ export default _default
5
+ export * from './Icon/index'
6
+ export {}
@@ -1,175 +1,6 @@
1
1
  "use strict";
2
- var __defProp = Object.defineProperty;
3
- var __defProps = Object.defineProperties;
4
- var __getOwnPropDescs = Object.getOwnPropertyDescriptors;
5
- var __getOwnPropSymbols = Object.getOwnPropertySymbols;
6
- var __hasOwnProp = Object.prototype.hasOwnProperty;
7
- var __propIsEnum = Object.prototype.propertyIsEnumerable;
8
- var __defNormalProp = (obj, key, value) => key in obj ? __defProp(obj, key, { enumerable: true, configurable: true, writable: true, value }) : obj[key] = value;
9
- var __spreadValues = (a, b) => {
10
- for (var prop in b || (b = {}))
11
- if (__hasOwnProp.call(b, prop))
12
- __defNormalProp(a, prop, b[prop]);
13
- if (__getOwnPropSymbols)
14
- for (var prop of __getOwnPropSymbols(b)) {
15
- if (__propIsEnum.call(b, prop))
16
- __defNormalProp(a, prop, b[prop]);
17
- }
18
- return a;
19
- };
20
- var __spreadProps = (a, b) => __defProps(a, __getOwnPropDescs(b));
21
- var __objRest = (source, exclude) => {
22
- var target = {};
23
- for (var prop in source)
24
- if (__hasOwnProp.call(source, prop) && exclude.indexOf(prop) < 0)
25
- target[prop] = source[prop];
26
- if (source != null && __getOwnPropSymbols)
27
- for (var prop of __getOwnPropSymbols(source)) {
28
- if (exclude.indexOf(prop) < 0 && __propIsEnum.call(source, prop))
29
- target[prop] = source[prop];
30
- }
31
- return target;
32
- };
33
2
  Object.defineProperties(exports, { __esModule: { value: true }, [Symbol.toStringTag]: { value: "Module" } });
34
- const jsxRuntime = require("react/jsx-runtime");
35
- const material = require("@mui/material");
36
- const styles = require("@mui/material/styles");
37
- const reactHookForm = require("react-hook-form");
38
- const formField_sx = require("../../formField.sx-CQ1mbk9M.cjs");
39
- const resolvePreset = require("../../resolvePreset-CT3kU-K2.cjs");
40
- const parseValue = (raw, type) => {
41
- if (type !== "number") return raw;
42
- if (raw === "" || raw === "-") return raw;
43
- const n = parseFloat(raw);
44
- return isNaN(n) ? raw : n;
45
- };
46
- const buildSlotProps = (type, min, max, customSlotProps, customInputProps, _labelPosition, readOnly) => {
47
- const numberAttrs = type === "number" ? __spreadValues({ min: min != null ? min : Number.NEGATIVE_INFINITY }, max !== void 0 && { max }) : {};
48
- return __spreadProps(__spreadValues({}, customSlotProps), {
49
- htmlInput: __spreadValues(__spreadValues(__spreadValues(__spreadValues({}, customInputProps), customSlotProps == null ? void 0 : customSlotProps.htmlInput), numberAttrs), readOnly && { readOnly: true }),
50
- // Dejamos que MUI maneje el shrink nativamente (animación inside → up).
51
- // El consumidor puede forzar shrink con slotProps.inputLabel.shrink=true si lo necesita.
52
- inputLabel: __spreadValues({}, customSlotProps == null ? void 0 : customSlotProps.inputLabel)
53
- });
54
- };
55
- const buildInputSx = (borderRadius, labelPosition) => {
56
- const radius = typeof borderRadius === "number" ? `${borderRadius}px` : borderRadius;
57
- return formField_sx.buildFormFieldSx({
58
- borderRadius,
59
- labelPosition,
60
- extraOutsideSx: {
61
- "& .MuiInputBase-input": {
62
- paddingTop: formField_sx.FIELD_INPUT_PADDING_Y,
63
- paddingBottom: formField_sx.FIELD_INPUT_PADDING_Y
64
- },
65
- // Filled: quitar el padding-top reservado para el label flotante dentro.
66
- "& .MuiFilledInput-root": {
67
- paddingTop: 0,
68
- borderRadius: `${radius} ${radius} 0 0`
69
- },
70
- "& .MuiFilledInput-input": {
71
- paddingTop: formField_sx.FIELD_INPUT_PADDING_Y
72
- },
73
- // Standard: quitar el margin-top reservado para el label flotante.
74
- "& .MuiInput-root": {
75
- marginTop: 0
76
- }
77
- }
78
- });
79
- };
80
- const Input = (props) => {
81
- const _a = props, {
82
- type = "text",
83
- variant = "outlined",
84
- size = "small",
85
- borderRadius = 10,
86
- labelPosition = "outside",
87
- preset,
88
- min,
89
- max,
90
- readOnly,
91
- inputProps,
92
- slotProps,
93
- sx
94
- } = _a, rest = __objRest(_a, [
95
- "type",
96
- "variant",
97
- "size",
98
- "borderRadius",
99
- "labelPosition",
100
- "preset",
101
- "min",
102
- "max",
103
- "readOnly",
104
- "inputProps",
105
- "slotProps",
106
- "sx"
107
- ]);
108
- const theme = styles.useTheme();
109
- const presetSx = resolvePreset.resolvePreset("Input", preset, theme);
110
- const finalSlotProps = buildSlotProps(
111
- type,
112
- min,
113
- max,
114
- slotProps,
115
- inputProps,
116
- labelPosition,
117
- readOnly
118
- );
119
- const mergedSx = [
120
- buildInputSx(borderRadius, labelPosition),
121
- ...presetSx ? [presetSx] : [],
122
- ...Array.isArray(sx) ? sx : [sx]
123
- ];
124
- if ("control" in props && props.control) {
125
- const { name, control, validation } = props;
126
- return /* @__PURE__ */ jsxRuntime.jsx(
127
- reactHookForm.Controller,
128
- {
129
- name,
130
- control,
131
- rules: validation,
132
- render: ({ field, fieldState: { error } }) => {
133
- var _a2, _b;
134
- return /* @__PURE__ */ jsxRuntime.jsx(
135
- material.TextField,
136
- __spreadProps(__spreadValues({
137
- fullWidth: true
138
- }, rest), {
139
- name: field.name,
140
- value: (_a2 = field.value) != null ? _a2 : "",
141
- onChange: (e) => field.onChange(parseValue(e.target.value, type)),
142
- onBlur: field.onBlur,
143
- inputRef: field.ref,
144
- type,
145
- variant,
146
- size,
147
- slotProps: finalSlotProps,
148
- sx: mergedSx,
149
- error: !!error || rest.error,
150
- helperText: (_b = error == null ? void 0 : error.message) != null ? _b : rest.helperText
151
- })
152
- );
153
- }
154
- }
155
- );
156
- }
157
- const { value, onChange } = props;
158
- return /* @__PURE__ */ jsxRuntime.jsx(
159
- material.TextField,
160
- __spreadProps(__spreadValues({
161
- fullWidth: true
162
- }, rest), {
163
- value: value != null ? value : "",
164
- onChange: (e) => onChange(parseValue(e.target.value, type)),
165
- type,
166
- variant,
167
- size,
168
- slotProps: finalSlotProps,
169
- sx: mergedSx
170
- })
171
- );
172
- };
173
- exports.Input = Input;
174
- exports.default = Input;
3
+ const Input = require("../../Input-CScC87J5.cjs");
4
+ exports.Input = Input.Input;
5
+ exports.default = Input.Input;
175
6
  //# sourceMappingURL=Input.cjs.map
@@ -1 +1 @@
1
- {"version":3,"file":"Input.cjs","sources":["../../../src/components/Input/Input.helpers.ts","../../../src/components/Input/Input.sx.ts","../../../src/components/Input/Input.tsx"],"sourcesContent":["import type { InputHTMLAttributes } from 'react';\nimport type { TextFieldProps } from '@mui/material';\nimport type { InputType, LabelPosition } from './Input';\n\n/**\n * Convierte el valor raw del evento al tipo apropiado.\n * Para type=\"number\" intenta parsear a número; si falla, devuelve el raw\n * (permite estados intermedios como \"\" o \"-\" mientras el usuario tipea).\n */\nexport const parseValue = (raw: string, type: InputType): string | number => {\n if (type !== 'number') return raw;\n if (raw === '' || raw === '-') return raw;\n const n = parseFloat(raw);\n return isNaN(n) ? raw : n;\n};\n\n/**\n * Construye los slotProps del TextField consolidando htmlInput + inputLabel.\n * Maneja los atributos min/max cuando type=\"number\" y readOnly.\n */\nexport const buildSlotProps = (\n type: InputType,\n min: number | undefined,\n max: number | undefined,\n customSlotProps: TextFieldProps['slotProps'],\n customInputProps: InputHTMLAttributes<HTMLInputElement> | undefined,\n _labelPosition: LabelPosition,\n readOnly?: boolean,\n): TextFieldProps['slotProps'] => {\n const numberAttrs =\n type === 'number'\n ? { min: min ?? Number.NEGATIVE_INFINITY, ...(max !== undefined && { max }) }\n : {};\n\n return {\n ...customSlotProps,\n htmlInput: {\n ...customInputProps,\n ...(customSlotProps as any)?.htmlInput,\n ...numberAttrs,\n ...(readOnly && { readOnly: true }),\n },\n // Dejamos que MUI maneje el shrink nativamente (animación inside → up).\n // El consumidor puede forzar shrink con slotProps.inputLabel.shrink=true si lo necesita.\n inputLabel: {\n ...(customSlotProps as any)?.inputLabel,\n },\n };\n};\n","import type { TextFieldProps } from '@mui/material';\n\nimport { buildFormFieldSx } from '../_shared/formField.sx';\nimport { FIELD_INPUT_PADDING_Y } from '../../theme/tokens';\nimport type { LabelPosition } from './Input';\n\n/**\n * Builder de sx para el Input. Usa el builder compartido\n * `buildFormFieldSx` y añade overrides específicos de TextField\n * (padding del input base, filled, standard).\n */\nexport const buildInputSx = (\n borderRadius: number | string,\n labelPosition: LabelPosition,\n): TextFieldProps['sx'] => {\n const radius = typeof borderRadius === 'number' ? `${borderRadius}px` : borderRadius;\n\n return buildFormFieldSx({\n borderRadius,\n labelPosition,\n extraOutsideSx: {\n '& .MuiInputBase-input': {\n paddingTop: FIELD_INPUT_PADDING_Y,\n paddingBottom: FIELD_INPUT_PADDING_Y,\n },\n\n // Filled: quitar el padding-top reservado para el label flotante dentro.\n '& .MuiFilledInput-root': {\n paddingTop: 0,\n borderRadius: `${radius} ${radius} 0 0`,\n },\n '& .MuiFilledInput-input': {\n paddingTop: FIELD_INPUT_PADDING_Y,\n },\n\n // Standard: quitar el margin-top reservado para el label flotante.\n '& .MuiInput-root': {\n marginTop: 0,\n },\n },\n });\n};\n","import { TextField, type TextFieldProps } from '@mui/material';\nimport { useTheme } from '@mui/material/styles';\nimport { Controller, type Control, type RegisterOptions } from 'react-hook-form';\n\nimport { parseValue, buildSlotProps } from './Input.helpers';\nimport { buildInputSx } from './Input.sx';\nimport { resolvePreset } from '../_shared/resolvePreset';\n\n// ── Tipos de dominio ─────────────────────────────────────────────────────\nexport type InputType =\n | 'text' | 'number' | 'email' | 'password' | 'tel'\n | 'url' | 'search' | 'date' | 'datetime-local'\n | 'month' | 'week' | 'time' | 'color';\n\nexport type LabelPosition = 'outside' | 'floating';\n\n// ── Props base (todo lo común entre RHF y controlado) ────────────────────\nexport interface BaseInputProps\n extends Omit<TextFieldProps, 'value' | 'onChange' | 'type'> {\n type?: InputType;\n min?: number;\n max?: number;\n /** Border radius del input. Default: 10 */\n borderRadius?: number | string;\n /** \"outside\" = label arriba del campo (default). \"floating\" = label clásico MUI dentro del borde */\n labelPosition?: LabelPosition;\n readOnly?: boolean;\n /**\n * Nombre del preset de estilo registrado en `theme.styles.Input`.\n * - `\"default\"` (o ausente) = estilo built-in del paquete.\n * - Cualquier otro string = mergea el preset encima del estilo built-in.\n */\n preset?: string;\n}\n\n// ── Variantes discriminadas (RHF vs controlado) ──────────────────────────\nexport interface RHFInputProps extends BaseInputProps {\n name: string;\n control: Control<any>;\n validation?: RegisterOptions;\n value?: never;\n onChange?: never;\n}\n\nexport interface ControlledInputProps extends BaseInputProps {\n name?: string;\n control?: never;\n validation?: never;\n value: string | number;\n onChange: (value: string | number) => void;\n}\n\n// ── API pública final ────────────────────────────────────────────────────\nexport type InputProps = RHFInputProps | ControlledInputProps;\n\nexport const Input: React.FC<InputProps> = (props) => {\n const {\n type = 'text',\n variant = 'outlined',\n size = 'small',\n borderRadius = 10,\n labelPosition = 'outside',\n preset,\n min,\n max,\n readOnly,\n inputProps,\n slotProps,\n sx,\n ...rest\n } = props as ControlledInputProps & {\n control?: Control<any>;\n validation?: RegisterOptions;\n readOnly?: boolean;\n preset?: string;\n };\n\n const theme = useTheme();\n const presetSx = resolvePreset('Input', preset, theme);\n\n const finalSlotProps = buildSlotProps(\n type,\n min,\n max,\n slotProps,\n inputProps,\n labelPosition,\n readOnly,\n );\n const mergedSx = [\n buildInputSx(borderRadius, labelPosition),\n ...(presetSx ? [presetSx] : []),\n ...(Array.isArray(sx) ? sx : [sx]),\n ];\n\n if ('control' in props && props.control) {\n const { name, control, validation } = props as RHFInputProps;\n return (\n <Controller\n name={name}\n control={control}\n rules={validation}\n render={({ field, fieldState: { error } }) => (\n <TextField\n fullWidth\n {...rest}\n name={field.name}\n value={field.value ?? ''}\n onChange={(e) => field.onChange(parseValue(e.target.value, type))}\n onBlur={field.onBlur}\n inputRef={field.ref}\n type={type}\n variant={variant}\n size={size}\n slotProps={finalSlotProps}\n sx={mergedSx}\n error={!!error || rest.error}\n helperText={error?.message ?? rest.helperText}\n />\n )}\n />\n );\n }\n\n const { value, onChange } = props as ControlledInputProps;\n return (\n <TextField\n fullWidth\n {...rest}\n value={value ?? ''}\n onChange={(e) => onChange(parseValue(e.target.value, type))}\n type={type}\n variant={variant}\n size={size}\n slotProps={finalSlotProps}\n sx={mergedSx}\n />\n );\n};\n\nexport default Input;\n"],"names":["buildFormFieldSx","FIELD_INPUT_PADDING_Y","useTheme","resolvePreset","jsx","Controller","TextField","_a"],"mappings":";;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;AASO,MAAM,aAAa,CAAC,KAAa,SAAqC;AAC3E,MAAI,SAAS,SAAU,QAAO;AAC9B,MAAI,QAAQ,MAAM,QAAQ,IAAK,QAAO;AACtC,QAAM,IAAI,WAAW,GAAG;AACxB,SAAO,MAAM,CAAC,IAAI,MAAM;AAC1B;AAMO,MAAM,iBAAiB,CAC5B,MACA,KACA,KACA,iBACA,kBACA,gBACA,aACgC;AAChC,QAAM,cACJ,SAAS,WACL,iBAAE,KAAK,oBAAO,OAAO,qBAAuB,QAAQ,UAAa,EAAE,IAAA,KACnE,CAAA;AAEN,SAAO,iCACF,kBADE;AAAA,IAEL,WAAW,gEACN,mBACC,mDAAyB,YAC1B,cACC,YAAY,EAAE,UAAU,KAAA;AAAA;AAAA;AAAA,IAI9B,YAAY,mBACN,mDAAyB;AAAA,EAC/B;AAEJ;ACrCO,MAAM,eAAe,CAC1B,cACA,kBACyB;AACzB,QAAM,SAAS,OAAO,iBAAiB,WAAW,GAAG,YAAY,OAAO;AAExE,SAAOA,8BAAiB;AAAA,IACtB;AAAA,IACA;AAAA,IACA,gBAAgB;AAAA,MACd,yBAAyB;AAAA,QACvB,YAAYC,aAAAA;AAAAA,QACZ,eAAeA,aAAAA;AAAAA,MAAA;AAAA;AAAA,MAIjB,0BAA0B;AAAA,QACxB,YAAY;AAAA,QACZ,cAAc,GAAG,MAAM,IAAI,MAAM;AAAA,MAAA;AAAA,MAEnC,2BAA2B;AAAA,QACzB,YAAYA,aAAAA;AAAAA,MAAA;AAAA;AAAA,MAId,oBAAoB;AAAA,QAClB,WAAW;AAAA,MAAA;AAAA,IACb;AAAA,EACF,CACD;AACH;ACcO,MAAM,QAA8B,CAAC,UAAU;AACpD,QAcI,YAbF;AAAA,WAAO;AAAA,IACP,UAAU;AAAA,IACV,OAAO;AAAA,IACP,eAAe;AAAA,IACf,gBAAgB;AAAA,IAChB;AAAA,IACA;AAAA,IACA;AAAA,IACA;AAAA,IACA;AAAA,IACA;AAAA,IACA;AAAA,MAEE,IADC,iBACD,IADC;AAAA,IAZH;AAAA,IACA;AAAA,IACA;AAAA,IACA;AAAA,IACA;AAAA,IACA;AAAA,IACA;AAAA,IACA;AAAA,IACA;AAAA,IACA;AAAA,IACA;AAAA,IACA;AAAA;AASF,QAAM,QAAQC,OAAAA,SAAA;AACd,QAAM,WAAWC,cAAAA,cAAc,SAAS,QAAQ,KAAK;AAErD,QAAM,iBAAiB;AAAA,IACrB;AAAA,IACA;AAAA,IACA;AAAA,IACA;AAAA,IACA;AAAA,IACA;AAAA,IACA;AAAA,EAAA;AAEF,QAAM,WAAW;AAAA,IACf,aAAa,cAAc,aAAa;AAAA,IACxC,GAAI,WAAW,CAAC,QAAQ,IAAI,CAAA;AAAA,IAC5B,GAAI,MAAM,QAAQ,EAAE,IAAI,KAAK,CAAC,EAAE;AAAA,EAAA;AAGlC,MAAI,aAAa,SAAS,MAAM,SAAS;AACvC,UAAM,EAAE,MAAM,SAAS,WAAA,IAAe;AACtC,WACEC,2BAAAA;AAAAA,MAACC,cAAAA;AAAAA,MAAA;AAAA,QACC;AAAA,QACA;AAAA,QACA,OAAO;AAAA,QACP,QAAQ,CAAC,EAAE,OAAO,YAAY,EAAE,MAAA;;AAC9BD,4CAAAA;AAAAA,YAACE,SAAAA;AAAAA,YAAA;AAAA,cACC,WAAS;AAAA,eACL,OAFL;AAAA,cAGC,MAAM,MAAM;AAAA,cACZ,QAAOC,MAAA,MAAM,UAAN,OAAAA,MAAe;AAAA,cACtB,UAAU,CAAC,MAAM,MAAM,SAAS,WAAW,EAAE,OAAO,OAAO,IAAI,CAAC;AAAA,cAChE,QAAQ,MAAM;AAAA,cACd,UAAU,MAAM;AAAA,cAChB;AAAA,cACA;AAAA,cACA;AAAA,cACA,WAAW;AAAA,cACX,IAAI;AAAA,cACJ,OAAO,CAAC,CAAC,SAAS,KAAK;AAAA,cACvB,aAAY,oCAAO,YAAP,YAAkB,KAAK;AAAA,YAAA;AAAA,UAAA;AAAA;AAAA,MACrC;AAAA,IAAA;AAAA,EAIR;AAEA,QAAM,EAAE,OAAO,SAAA,IAAa;AAC5B,SACEH,2BAAAA;AAAAA,IAACE,SAAAA;AAAAA,IAAA;AAAA,MACC,WAAS;AAAA,OACL,OAFL;AAAA,MAGC,OAAO,wBAAS;AAAA,MAChB,UAAU,CAAC,MAAM,SAAS,WAAW,EAAE,OAAO,OAAO,IAAI,CAAC;AAAA,MAC1D;AAAA,MACA;AAAA,MACA;AAAA,MACA,WAAW;AAAA,MACX,IAAI;AAAA,IAAA;AAAA,EAAA;AAGV;;;"}
1
+ {"version":3,"file":"Input.cjs","sources":[],"sourcesContent":[],"names":[],"mappings":";;;;;"}
@@ -1,11 +1,12 @@
1
1
  import { TextFieldProps } from '@mui/material';
2
- import { Control, RegisterOptions } from 'react-hook-form';
2
+ import { RegisterOptions } from 'react-hook-form';
3
3
  export type InputType = 'text' | 'number' | 'email' | 'password' | 'tel' | 'url' | 'search' | 'date' | 'datetime-local' | 'month' | 'week' | 'time' | 'color';
4
4
  export type LabelPosition = 'outside' | 'floating';
5
5
  export interface BaseInputProps extends Omit<TextFieldProps, 'value' | 'onChange' | 'type'> {
6
6
  type?: InputType;
7
7
  min?: number;
8
8
  max?: number;
9
+ maxLength?: number;
9
10
  /** Border radius del input. Default: 10 */
10
11
  borderRadius?: number | string;
11
12
  /** "outside" = label arriba del campo (default). "floating" = label clásico MUI dentro del borde */
@@ -20,8 +21,14 @@ export interface BaseInputProps extends Omit<TextFieldProps, 'value' | 'onChange
20
21
  }
21
22
  export interface RHFInputProps extends BaseInputProps {
22
23
  name: string;
23
- control: Control<any>;
24
+ control: any;
24
25
  validation?: RegisterOptions;
26
+ /**
27
+ * Side-effect que corre después de que RHF actualiza el form state.
28
+ * Útil para cascadas entre campos (ej. reset de municipio al cambiar
29
+ * departamento). NO reemplaza al handler de RHF.
30
+ */
31
+ onValueChange?: (value: string | number) => void;
25
32
  value?: never;
26
33
  onChange?: never;
27
34
  }
@@ -12,3 +12,4 @@ export declare const FullWidthInputDefinition = "\nimport React, { useState } fr
12
12
  export declare const LabelPositionFloatingDefinition = "\nimport React, { useState } from 'react';\nimport { Input } from './Input'; // Ajusta la ruta si es necesario\nimport { Box } from '@mui/material';\n\nexport const LabelPositionExample = () => {\n const [outside, setOutside] = useState('Outside (default)');\n const [floating, setFloating] = useState('Floating');\n return (\n <Box sx={{ display: 'flex', flexDirection: 'column', gap: 3, width: 300 }}>\n <Input\n label=\"Label outside\"\n value={outside}\n onChange={setOutside}\n labelPosition=\"outside\"\n />\n <Input\n label=\"Label floating (MUI cl\u00E1sico)\"\n value={floating}\n onChange={setFloating}\n labelPosition=\"floating\"\n />\n </Box>\n );\n};\n";
13
13
  export declare const CustomBorderRadiusDefinition = "\nimport React, { useState } from 'react';\nimport { Input } from './Input'; // Ajusta la ruta si es necesario\nimport { Box } from '@mui/material';\n\nexport const CustomBorderRadiusExample = () => {\n const [v, setV] = useState('Texto');\n return (\n <Box sx={{ display: 'flex', flexDirection: 'column', gap: 3, width: 300 }}>\n <Input label=\"Sin radius\" value={v} onChange={setV} borderRadius={0} />\n <Input label=\"Radius 4px\" value={v} onChange={setV} borderRadius={4} />\n <Input label=\"Default (10px)\" value={v} onChange={setV} />\n <Input label=\"Pill (24px)\" value={v} onChange={setV} borderRadius={24} />\n </Box>\n );\n};\n";
14
14
  export declare const CustomStylingDefinition = "\nimport React, { useState } from 'react';\nimport { Input } from './Input'; // Ajusta la ruta si es necesario\nimport { Box } from '@mui/material';\n\nexport const CustomStylingExample = () => {\n const [v, setV] = useState('Custom completo');\n return (\n <Box sx={{ width: 300 }}>\n <Input\n label=\"Combinado: bg + borderColor + label color\"\n value={v}\n onChange={setV}\n sx={{\n '& .MuiInputLabel-root': { color: 'primary.main' },\n '& .MuiOutlinedInput-root': { bgcolor: '#fff7e6' },\n '& .MuiOutlinedInput-notchedOutline': {\n borderColor: 'warning.main',\n borderWidth: 2,\n },\n }}\n />\n </Box>\n );\n};\n";
15
+ export declare const MultilineInputDefinition = "\nimport React, { useState } from 'react';\nimport { Input } from './Input';\nimport { Box, Typography } from '@mui/material';\n\nexport const MultilineInputExample = () => {\n const [value, setValue] = useState('Escribe un comentario en varias l\u00EDneas...');\n return (\n <Box sx={{ width: 400 }}>\n <Input\n label=\"Comentario\"\n value={value}\n onChange={(v) => setValue(v.toString())}\n multiline\n minRows={3}\n maxRows={6}\n fullWidth\n />\n <Typography sx={{ mt: 2 }}>Valor actual: {value}</Typography>\n </Box>\n );\n};\n";
@@ -1,6 +1,6 @@
1
1
  import { InputHTMLAttributes } from 'react';
2
2
  import { TextFieldProps } from '@mui/material';
3
- import { InputType, LabelPosition } from './Input';
3
+ import { InputType } from './Input';
4
4
  /**
5
5
  * Convierte el valor raw del evento al tipo apropiado.
6
6
  * Para type="number" intenta parsear a número; si falla, devuelve el raw
@@ -9,6 +9,6 @@ import { InputType, LabelPosition } from './Input';
9
9
  export declare const parseValue: (raw: string, type: InputType) => string | number;
10
10
  /**
11
11
  * Construye los slotProps del TextField consolidando htmlInput + inputLabel.
12
- * Maneja los atributos min/max cuando type="number" y readOnly.
12
+ * Maneja los atributos min/max cuando type="number", maxLength y readOnly.
13
13
  */
14
- export declare const buildSlotProps: (type: InputType, min: number | undefined, max: number | undefined, customSlotProps: TextFieldProps["slotProps"], customInputProps: InputHTMLAttributes<HTMLInputElement> | undefined, _labelPosition: LabelPosition, readOnly?: boolean) => TextFieldProps["slotProps"];
14
+ export declare const buildSlotProps: (type: InputType, min: number | undefined, max: number | undefined, maxLength: number | undefined, customSlotProps: TextFieldProps["slotProps"], customInputProps: InputHTMLAttributes<HTMLInputElement> | undefined, readOnly?: boolean) => TextFieldProps["slotProps"];
@@ -1,175 +1,6 @@
1
- var __defProp = Object.defineProperty;
2
- var __defProps = Object.defineProperties;
3
- var __getOwnPropDescs = Object.getOwnPropertyDescriptors;
4
- var __getOwnPropSymbols = Object.getOwnPropertySymbols;
5
- var __hasOwnProp = Object.prototype.hasOwnProperty;
6
- var __propIsEnum = Object.prototype.propertyIsEnumerable;
7
- var __defNormalProp = (obj, key, value) => key in obj ? __defProp(obj, key, { enumerable: true, configurable: true, writable: true, value }) : obj[key] = value;
8
- var __spreadValues = (a, b) => {
9
- for (var prop in b || (b = {}))
10
- if (__hasOwnProp.call(b, prop))
11
- __defNormalProp(a, prop, b[prop]);
12
- if (__getOwnPropSymbols)
13
- for (var prop of __getOwnPropSymbols(b)) {
14
- if (__propIsEnum.call(b, prop))
15
- __defNormalProp(a, prop, b[prop]);
16
- }
17
- return a;
18
- };
19
- var __spreadProps = (a, b) => __defProps(a, __getOwnPropDescs(b));
20
- var __objRest = (source, exclude) => {
21
- var target = {};
22
- for (var prop in source)
23
- if (__hasOwnProp.call(source, prop) && exclude.indexOf(prop) < 0)
24
- target[prop] = source[prop];
25
- if (source != null && __getOwnPropSymbols)
26
- for (var prop of __getOwnPropSymbols(source)) {
27
- if (exclude.indexOf(prop) < 0 && __propIsEnum.call(source, prop))
28
- target[prop] = source[prop];
29
- }
30
- return target;
31
- };
32
- import { jsx } from "react/jsx-runtime";
33
- import { TextField } from "@mui/material";
34
- import { useTheme } from "@mui/material/styles";
35
- import { Controller } from "react-hook-form";
36
- import { b as buildFormFieldSx, F as FIELD_INPUT_PADDING_Y } from "../../formField.sx-DfVbMe0V.js";
37
- import { r as resolvePreset } from "../../resolvePreset-B-IB0ehH.js";
38
- const parseValue = (raw, type) => {
39
- if (type !== "number") return raw;
40
- if (raw === "" || raw === "-") return raw;
41
- const n = parseFloat(raw);
42
- return isNaN(n) ? raw : n;
43
- };
44
- const buildSlotProps = (type, min, max, customSlotProps, customInputProps, _labelPosition, readOnly) => {
45
- const numberAttrs = type === "number" ? __spreadValues({ min: min != null ? min : Number.NEGATIVE_INFINITY }, max !== void 0 && { max }) : {};
46
- return __spreadProps(__spreadValues({}, customSlotProps), {
47
- htmlInput: __spreadValues(__spreadValues(__spreadValues(__spreadValues({}, customInputProps), customSlotProps == null ? void 0 : customSlotProps.htmlInput), numberAttrs), readOnly && { readOnly: true }),
48
- // Dejamos que MUI maneje el shrink nativamente (animación inside → up).
49
- // El consumidor puede forzar shrink con slotProps.inputLabel.shrink=true si lo necesita.
50
- inputLabel: __spreadValues({}, customSlotProps == null ? void 0 : customSlotProps.inputLabel)
51
- });
52
- };
53
- const buildInputSx = (borderRadius, labelPosition) => {
54
- const radius = typeof borderRadius === "number" ? `${borderRadius}px` : borderRadius;
55
- return buildFormFieldSx({
56
- borderRadius,
57
- labelPosition,
58
- extraOutsideSx: {
59
- "& .MuiInputBase-input": {
60
- paddingTop: FIELD_INPUT_PADDING_Y,
61
- paddingBottom: FIELD_INPUT_PADDING_Y
62
- },
63
- // Filled: quitar el padding-top reservado para el label flotante dentro.
64
- "& .MuiFilledInput-root": {
65
- paddingTop: 0,
66
- borderRadius: `${radius} ${radius} 0 0`
67
- },
68
- "& .MuiFilledInput-input": {
69
- paddingTop: FIELD_INPUT_PADDING_Y
70
- },
71
- // Standard: quitar el margin-top reservado para el label flotante.
72
- "& .MuiInput-root": {
73
- marginTop: 0
74
- }
75
- }
76
- });
77
- };
78
- const Input = (props) => {
79
- const _a = props, {
80
- type = "text",
81
- variant = "outlined",
82
- size = "small",
83
- borderRadius = 10,
84
- labelPosition = "outside",
85
- preset,
86
- min,
87
- max,
88
- readOnly,
89
- inputProps,
90
- slotProps,
91
- sx
92
- } = _a, rest = __objRest(_a, [
93
- "type",
94
- "variant",
95
- "size",
96
- "borderRadius",
97
- "labelPosition",
98
- "preset",
99
- "min",
100
- "max",
101
- "readOnly",
102
- "inputProps",
103
- "slotProps",
104
- "sx"
105
- ]);
106
- const theme = useTheme();
107
- const presetSx = resolvePreset("Input", preset, theme);
108
- const finalSlotProps = buildSlotProps(
109
- type,
110
- min,
111
- max,
112
- slotProps,
113
- inputProps,
114
- labelPosition,
115
- readOnly
116
- );
117
- const mergedSx = [
118
- buildInputSx(borderRadius, labelPosition),
119
- ...presetSx ? [presetSx] : [],
120
- ...Array.isArray(sx) ? sx : [sx]
121
- ];
122
- if ("control" in props && props.control) {
123
- const { name, control, validation } = props;
124
- return /* @__PURE__ */ jsx(
125
- Controller,
126
- {
127
- name,
128
- control,
129
- rules: validation,
130
- render: ({ field, fieldState: { error } }) => {
131
- var _a2, _b;
132
- return /* @__PURE__ */ jsx(
133
- TextField,
134
- __spreadProps(__spreadValues({
135
- fullWidth: true
136
- }, rest), {
137
- name: field.name,
138
- value: (_a2 = field.value) != null ? _a2 : "",
139
- onChange: (e) => field.onChange(parseValue(e.target.value, type)),
140
- onBlur: field.onBlur,
141
- inputRef: field.ref,
142
- type,
143
- variant,
144
- size,
145
- slotProps: finalSlotProps,
146
- sx: mergedSx,
147
- error: !!error || rest.error,
148
- helperText: (_b = error == null ? void 0 : error.message) != null ? _b : rest.helperText
149
- })
150
- );
151
- }
152
- }
153
- );
154
- }
155
- const { value, onChange } = props;
156
- return /* @__PURE__ */ jsx(
157
- TextField,
158
- __spreadProps(__spreadValues({
159
- fullWidth: true
160
- }, rest), {
161
- value: value != null ? value : "",
162
- onChange: (e) => onChange(parseValue(e.target.value, type)),
163
- type,
164
- variant,
165
- size,
166
- slotProps: finalSlotProps,
167
- sx: mergedSx
168
- })
169
- );
170
- };
1
+ import { I, I as I2 } from "../../Input-DP_fKl38.js";
171
2
  export {
172
- Input,
173
- Input as default
3
+ I as Input,
4
+ I2 as default
174
5
  };
175
6
  //# sourceMappingURL=Input.js.map