@soyfri/shared-library 1.5.0 → 1.6.0-beta.1

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 (565) hide show
  1. package/Button-C17mExpd.cjs.map +1 -0
  2. package/Button-UkkP-bNw.js.map +1 -0
  3. package/components/ActionMenu/ActionMenu.cjs +107 -0
  4. package/components/ActionMenu/ActionMenu.cjs.map +1 -0
  5. package/components/ActionMenu/ActionMenu.d.ts +44 -0
  6. package/components/ActionMenu/ActionMenu.js +107 -0
  7. package/components/ActionMenu/ActionMenu.js.map +1 -0
  8. package/components/ActionMenu/index.d.ts +2 -0
  9. package/components/ActionMenu.d.ts +6 -0
  10. package/components/AppBar/AppBar.cjs +129 -0
  11. package/components/AppBar/AppBar.cjs.map +1 -0
  12. package/components/AppBar/AppBar.d.ts +55 -0
  13. package/components/AppBar/AppBar.js +129 -0
  14. package/components/AppBar/AppBar.js.map +1 -0
  15. package/components/AppBar/AppBar.sx.d.ts +12 -0
  16. package/components/AppBar/AppBarContext.d.ts +18 -0
  17. package/components/AppBar/AppBarMenuToggle.d.ts +39 -0
  18. package/components/AppBar/index.d.ts +6 -0
  19. package/components/AppBar.d.ts +6 -0
  20. package/components/Autocomplete/Autocomplete.cjs +313 -0
  21. package/components/Autocomplete/Autocomplete.cjs.map +1 -0
  22. package/components/Autocomplete/Autocomplete.d.ts +86 -0
  23. package/components/Autocomplete/Autocomplete.definitions.d.ts +16 -0
  24. package/components/Autocomplete/Autocomplete.helpers.d.ts +22 -0
  25. package/components/Autocomplete/Autocomplete.js +313 -0
  26. package/components/Autocomplete/Autocomplete.js.map +1 -0
  27. package/components/Autocomplete/Autocomplete.sx.d.ts +7 -0
  28. package/components/Autocomplete/_parts/AutocompleteChips.d.ts +20 -0
  29. package/components/Autocomplete/_parts/AutocompleteLoader.d.ts +9 -0
  30. package/components/Autocomplete/_parts/AutocompleteOption.d.ts +16 -0
  31. package/components/Autocomplete/index.d.ts +2 -0
  32. package/components/Autocomplete.d.ts +6 -0
  33. package/components/Avatar/Avatar.cjs +162 -0
  34. package/components/Avatar/Avatar.cjs.map +1 -0
  35. package/components/Avatar/Avatar.d.ts +33 -0
  36. package/components/Avatar/Avatar.definitions.d.ts +11 -0
  37. package/components/Avatar/Avatar.js +162 -0
  38. package/components/Avatar/Avatar.js.map +1 -0
  39. package/components/Avatar/index.d.ts +2 -0
  40. package/{dist/components → components}/Button/Button.d.ts +5 -5
  41. package/{dist/components → components}/Button/index.d.ts +1 -0
  42. package/components/Card/Card.cjs +98 -0
  43. package/components/Card/Card.cjs.map +1 -0
  44. package/components/Card/Card.d.ts +36 -0
  45. package/components/Card/Card.js +98 -0
  46. package/components/Card/Card.js.map +1 -0
  47. package/components/Card/Card.sx.d.ts +14 -0
  48. package/components/Card/index.d.ts +4 -0
  49. package/components/Card.d.ts +6 -0
  50. package/components/Checkbox/Checkbox.cjs +189 -0
  51. package/components/Checkbox/Checkbox.cjs.map +1 -0
  52. package/components/Checkbox/Checkbox.d.ts +55 -0
  53. package/components/Checkbox/Checkbox.js +189 -0
  54. package/components/Checkbox/Checkbox.js.map +1 -0
  55. package/components/Checkbox/Checkbox.sx.d.ts +13 -0
  56. package/components/Checkbox/index.d.ts +2 -0
  57. package/components/Checkbox.d.ts +6 -0
  58. package/{dist/components → components}/Chip/Chip.cjs +2 -1
  59. package/components/Chip/Chip.cjs.map +1 -0
  60. package/{dist/components → components}/Chip/Chip.js +2 -1
  61. package/components/Chip/Chip.js.map +1 -0
  62. package/components/Chip/index.d.ts +2 -0
  63. package/components/Chip.d.ts +6 -0
  64. package/components/DatePicker/DatePicker.cjs +180 -0
  65. package/components/DatePicker/DatePicker.cjs.map +1 -0
  66. package/components/DatePicker/DatePicker.d.ts +44 -0
  67. package/{dist/components → components}/DatePicker/DatePicker.definitions.d.ts +1 -0
  68. package/components/DatePicker/DatePicker.helpers.d.ts +7 -0
  69. package/components/DatePicker/DatePicker.js +180 -0
  70. package/components/DatePicker/DatePicker.js.map +1 -0
  71. package/components/DatePicker/DatePicker.sx.d.ts +9 -0
  72. package/components/DatePicker/index.d.ts +2 -0
  73. package/components/DatePicker.d.ts +6 -0
  74. package/components/DateTimePicker/DateTimePicker.cjs +198 -0
  75. package/components/DateTimePicker/DateTimePicker.cjs.map +1 -0
  76. package/components/DateTimePicker/DateTimePicker.d.ts +57 -0
  77. package/{dist/components → components}/DateTimePicker/DateTimePicker.definitions.d.ts +3 -0
  78. package/components/DateTimePicker/DateTimePicker.helpers.d.ts +13 -0
  79. package/components/DateTimePicker/DateTimePicker.js +198 -0
  80. package/components/DateTimePicker/DateTimePicker.js.map +1 -0
  81. package/components/DateTimePicker/DateTimePicker.sx.d.ts +7 -0
  82. package/components/DateTimePicker/index.d.ts +2 -0
  83. package/components/DateTimePicker.d.ts +6 -0
  84. package/components/Drawer/Drawer.cjs +274 -0
  85. package/components/Drawer/Drawer.cjs.map +1 -0
  86. package/components/Drawer/Drawer.d.ts +60 -0
  87. package/components/Drawer/Drawer.js +274 -0
  88. package/components/Drawer/Drawer.js.map +1 -0
  89. package/components/Drawer/Drawer.sx.d.ts +23 -0
  90. package/components/Drawer/DrawerContext.d.ts +18 -0
  91. package/components/Drawer/DrawerItem.d.ts +40 -0
  92. package/components/Drawer/index.d.ts +6 -0
  93. package/components/Drawer.d.ts +6 -0
  94. package/{dist/components → components}/Gallery/Gallery.cjs +154 -79
  95. package/components/Gallery/Gallery.cjs.map +1 -0
  96. package/components/Gallery/Gallery.d.ts +28 -0
  97. package/{dist/components → components}/Gallery/Gallery.js +154 -79
  98. package/components/Gallery/Gallery.js.map +1 -0
  99. package/components/Gallery/GalleryLightbox.d.ts +16 -0
  100. package/{dist/components → components}/Gallery/GalleryMain.d.ts +3 -7
  101. package/components/Gallery/GalleryThumbnails.d.ts +13 -0
  102. package/components/Gallery/index.d.ts +2 -0
  103. package/components/Gallery.d.ts +6 -0
  104. package/{dist/components → components}/Icon/Icon.cjs +49 -10
  105. package/components/Icon/Icon.cjs.map +1 -0
  106. package/components/Icon/Icon.d.ts +48 -0
  107. package/{dist/components → components}/Icon/Icon.js +49 -10
  108. package/components/Icon/Icon.js.map +1 -0
  109. package/components/Icon/index.d.ts +2 -0
  110. package/components/Icon.d.ts +6 -0
  111. package/components/Input/Input.cjs +188 -0
  112. package/components/Input/Input.cjs.map +1 -0
  113. package/components/Input/Input.d.ts +44 -0
  114. package/{dist/components → components}/Input/Input.definitions.d.ts +6 -2
  115. package/components/Input/Input.helpers.d.ts +14 -0
  116. package/components/Input/Input.js +188 -0
  117. package/components/Input/Input.js.map +1 -0
  118. package/components/Input/Input.sx.d.ts +8 -0
  119. package/components/Input/index.d.ts +2 -0
  120. package/components/Input.d.ts +6 -0
  121. package/components/InputGroup/InputGroup.cjs +140 -0
  122. package/components/InputGroup/InputGroup.cjs.map +1 -0
  123. package/components/InputGroup/InputGroup.d.ts +42 -0
  124. package/components/InputGroup/InputGroup.definitions.d.ts +6 -0
  125. package/components/InputGroup/InputGroup.js +140 -0
  126. package/components/InputGroup/InputGroup.js.map +1 -0
  127. package/components/InputGroup/index.d.ts +2 -0
  128. package/components/InputGroup.d.ts +6 -0
  129. package/components/Modal/Modal.cjs +348 -0
  130. package/components/Modal/Modal.cjs.map +1 -0
  131. package/components/Modal/Modal.d.ts +80 -0
  132. package/components/Modal/Modal.js +348 -0
  133. package/components/Modal/Modal.js.map +1 -0
  134. package/components/Modal/ModalBody.d.ts +11 -0
  135. package/components/Modal/ModalFooter.d.ts +27 -0
  136. package/components/Modal/ModalHeader.d.ts +11 -0
  137. package/components/Modal/index.d.ts +8 -0
  138. package/components/Modal.d.ts +6 -0
  139. package/components/RadioGroup/RadioGroup.cjs +204 -0
  140. package/components/RadioGroup/RadioGroup.cjs.map +1 -0
  141. package/components/RadioGroup/RadioGroup.d.ts +59 -0
  142. package/components/RadioGroup/RadioGroup.definitions.d.ts +6 -0
  143. package/components/RadioGroup/RadioGroup.js +204 -0
  144. package/components/RadioGroup/RadioGroup.js.map +1 -0
  145. package/components/RadioGroup/RadioGroup.sx.d.ts +20 -0
  146. package/components/RadioGroup/index.d.ts +2 -0
  147. package/components/RadioGroup.d.ts +6 -0
  148. package/components/Select/Select.cjs +313 -0
  149. package/components/Select/Select.cjs.map +1 -0
  150. package/components/Select/Select.d.ts +95 -0
  151. package/components/Select/Select.helpers.d.ts +15 -0
  152. package/components/Select/Select.js +313 -0
  153. package/components/Select/Select.js.map +1 -0
  154. package/components/Select/Select.sx.d.ts +7 -0
  155. package/components/Select/_parts/SelectMenuItem.d.ts +20 -0
  156. package/components/Select/index.d.ts +2 -0
  157. package/components/Select.d.ts +6 -0
  158. package/{dist/components → components}/Stat/Stat.cjs +2 -2
  159. package/{dist/components → components}/Stat/Stat.cjs.map +1 -1
  160. package/{dist/components → components}/Stat/Stat.js +2 -2
  161. package/{dist/components → components}/Stat/Stat.js.map +1 -1
  162. package/components/Stat/index.d.ts +2 -0
  163. package/components/Stat.d.ts +6 -0
  164. package/components/StatusMessage/StatusMessage.cjs +108 -0
  165. package/components/StatusMessage/StatusMessage.cjs.map +1 -0
  166. package/components/StatusMessage/StatusMessage.d.ts +28 -0
  167. package/components/StatusMessage/StatusMessage.js +108 -0
  168. package/components/StatusMessage/StatusMessage.js.map +1 -0
  169. package/components/StatusMessage/StatusMessageContext.d.ts +16 -0
  170. package/components/StatusMessage/index.d.ts +4 -0
  171. package/components/StatusMessage.d.ts +6 -0
  172. package/components/Stepper/Stepper.cjs +326 -0
  173. package/components/Stepper/Stepper.cjs.map +1 -0
  174. package/components/Stepper/Stepper.d.ts +17 -0
  175. package/components/Stepper/Stepper.js +326 -0
  176. package/components/Stepper/Stepper.js.map +1 -0
  177. package/components/Stepper/StepperContext.d.ts +73 -0
  178. package/components/Stepper/_hooks/useHorizontalScroll.d.ts +19 -0
  179. package/components/Stepper/_parts/StepperScrollArrow.d.ts +19 -0
  180. package/components/Stepper/index.d.ts +6 -0
  181. package/components/Stepper.d.ts +6 -0
  182. package/components/Switch/Switch.cjs +184 -0
  183. package/components/Switch/Switch.cjs.map +1 -0
  184. package/components/Switch/Switch.d.ts +48 -0
  185. package/components/Switch/Switch.definitions.d.ts +7 -0
  186. package/components/Switch/Switch.js +184 -0
  187. package/components/Switch/Switch.js.map +1 -0
  188. package/components/Switch/Switch.sx.d.ts +22 -0
  189. package/components/Switch/Switch.types.d.ts +1 -0
  190. package/components/Switch/index.d.ts +2 -0
  191. package/components/Switch.d.ts +6 -0
  192. package/components/Tabs/Tabs.cjs +112 -0
  193. package/components/Tabs/Tabs.cjs.map +1 -0
  194. package/components/Tabs/Tabs.d.ts +24 -0
  195. package/components/Tabs/Tabs.js +112 -0
  196. package/components/Tabs/Tabs.js.map +1 -0
  197. package/components/Tabs/index.d.ts +4 -0
  198. package/components/Tabs.d.ts +6 -0
  199. package/{dist/components → components}/Timeline/Timeline.cjs +3 -2
  200. package/components/Timeline/Timeline.cjs.map +1 -0
  201. package/components/Timeline/Timeline.d.ts +9 -0
  202. package/{dist/components → components}/Timeline/Timeline.js +3 -2
  203. package/components/Timeline/Timeline.js.map +1 -0
  204. package/components/Timeline/index.d.ts +4 -0
  205. package/components/Timeline.d.ts +6 -0
  206. package/components/_shared/formField.sx.d.ts +33 -0
  207. package/components/_shared/mergeSx.d.ts +7 -0
  208. package/components/_shared/resolvePreset.d.ts +18 -0
  209. package/formField.sx-8_QRnKxv.js +68 -0
  210. package/formField.sx-8_QRnKxv.js.map +1 -0
  211. package/formField.sx-BAX7KwMR.cjs +67 -0
  212. package/formField.sx-BAX7KwMR.cjs.map +1 -0
  213. package/index.cjs +153 -0
  214. package/index.cjs.map +1 -0
  215. package/index.d.ts +4 -0
  216. package/index.js +51 -0
  217. package/index.js.map +1 -0
  218. package/mergeSx-BXoNZjB_.js +10 -0
  219. package/mergeSx-BXoNZjB_.js.map +1 -0
  220. package/mergeSx-Dbccoo_H.cjs +9 -0
  221. package/mergeSx-Dbccoo_H.cjs.map +1 -0
  222. package/mui.d.ts +7 -0
  223. package/package.json +164 -43
  224. package/resolvePreset-B-IB0ehH.js +15 -0
  225. package/resolvePreset-B-IB0ehH.js.map +1 -0
  226. package/resolvePreset-CT3kU-K2.cjs +14 -0
  227. package/resolvePreset-CT3kU-K2.cjs.map +1 -0
  228. package/theme/componentStyles.d.ts +32 -0
  229. package/theme/tokens.d.ts +28 -0
  230. package/tokens-BRrcP_p_.js +21 -0
  231. package/tokens-BRrcP_p_.js.map +1 -0
  232. package/tokens-jaWWNk39.cjs +20 -0
  233. package/tokens-jaWWNk39.cjs.map +1 -0
  234. package/utils/index.d.ts +2 -0
  235. package/utils/scrollToTop.d.ts +28 -0
  236. package/.dockerignore +0 -8
  237. package/.github/workflows/publish.yml +0 -107
  238. package/.prettierrc +0 -3
  239. package/.storybook/main.ts +0 -19
  240. package/.storybook/preview.ts +0 -14
  241. package/.storybook/vitest.setup.ts +0 -9
  242. package/Dockerfile +0 -37
  243. package/build.js +0 -102
  244. package/chromatic.config.json +0 -5
  245. package/cleanDirectories.js +0 -40
  246. package/dist/Button-C17mExpd.cjs.map +0 -1
  247. package/dist/Button-UkkP-bNw.js.map +0 -1
  248. package/dist/DatePicker-BSNboVhN.js +0 -201
  249. package/dist/DatePicker-BSNboVhN.js.map +0 -1
  250. package/dist/DatePicker-BoqxWAhj.cjs +0 -200
  251. package/dist/DatePicker-BoqxWAhj.cjs.map +0 -1
  252. package/dist/Input-DFHs7cJ_.js +0 -171
  253. package/dist/Input-DFHs7cJ_.js.map +0 -1
  254. package/dist/Input-c8MwNNPg.cjs +0 -170
  255. package/dist/Input-c8MwNNPg.cjs.map +0 -1
  256. package/dist/Select-BO2N56sm.cjs +0 -411
  257. package/dist/Select-BO2N56sm.cjs.map +0 -1
  258. package/dist/Select-BcLkyHSE.js +0 -412
  259. package/dist/Select-BcLkyHSE.js.map +0 -1
  260. package/dist/components/Autocomplete/Autocomplete.cjs +0 -109
  261. package/dist/components/Autocomplete/Autocomplete.cjs.map +0 -1
  262. package/dist/components/Autocomplete/Autocomplete.d.ts +0 -28
  263. package/dist/components/Autocomplete/Autocomplete.definitions.d.ts +0 -9
  264. package/dist/components/Autocomplete/Autocomplete.js +0 -109
  265. package/dist/components/Autocomplete/Autocomplete.js.map +0 -1
  266. package/dist/components/Autocomplete/index.d.ts +0 -1
  267. package/dist/components/Autocomplete.d.ts +0 -2
  268. package/dist/components/Avatar/Avatar.cjs +0 -126
  269. package/dist/components/Avatar/Avatar.cjs.map +0 -1
  270. package/dist/components/Avatar/Avatar.d.ts +0 -19
  271. package/dist/components/Avatar/Avatar.js +0 -126
  272. package/dist/components/Avatar/Avatar.js.map +0 -1
  273. package/dist/components/Avatar/index.d.ts +0 -1
  274. package/dist/components/Card/Card.cjs +0 -28
  275. package/dist/components/Card/Card.cjs.map +0 -1
  276. package/dist/components/Card/Card.d.ts +0 -13
  277. package/dist/components/Card/Card.js +0 -28
  278. package/dist/components/Card/Card.js.map +0 -1
  279. package/dist/components/Card/index.d.ts +0 -1
  280. package/dist/components/Card.d.ts +0 -2
  281. package/dist/components/Chip/Chip.cjs.map +0 -1
  282. package/dist/components/Chip/Chip.js.map +0 -1
  283. package/dist/components/Chip/index.d.ts +0 -1
  284. package/dist/components/Chip.d.ts +0 -2
  285. package/dist/components/DatePicker/DatePicker.cjs +0 -5
  286. package/dist/components/DatePicker/DatePicker.cjs.map +0 -1
  287. package/dist/components/DatePicker/DatePicker.d.ts +0 -18
  288. package/dist/components/DatePicker/DatePicker.js +0 -5
  289. package/dist/components/DatePicker/DatePicker.js.map +0 -1
  290. package/dist/components/DatePicker/index.d.ts +0 -1
  291. package/dist/components/DatePicker.d.ts +0 -2
  292. package/dist/components/DateTimePicker/DateTimePicker.cjs +0 -208
  293. package/dist/components/DateTimePicker/DateTimePicker.cjs.map +0 -1
  294. package/dist/components/DateTimePicker/DateTimePicker.d.ts +0 -28
  295. package/dist/components/DateTimePicker/DateTimePicker.js +0 -208
  296. package/dist/components/DateTimePicker/DateTimePicker.js.map +0 -1
  297. package/dist/components/DateTimePicker/index.d.ts +0 -1
  298. package/dist/components/DateTimePicker.d.ts +0 -2
  299. package/dist/components/Gallery/Gallery.cjs.map +0 -1
  300. package/dist/components/Gallery/Gallery.d.ts +0 -12
  301. package/dist/components/Gallery/Gallery.js.map +0 -1
  302. package/dist/components/Gallery/GalleryLightbox.d.ts +0 -20
  303. package/dist/components/Gallery/GalleryThumbnails.d.ts +0 -17
  304. package/dist/components/Gallery/index.d.ts +0 -1
  305. package/dist/components/Gallery.d.ts +0 -2
  306. package/dist/components/Icon/Icon.cjs.map +0 -1
  307. package/dist/components/Icon/Icon.d.ts +0 -21
  308. package/dist/components/Icon/Icon.js.map +0 -1
  309. package/dist/components/Icon/index.d.ts +0 -1
  310. package/dist/components/Icon.d.ts +0 -2
  311. package/dist/components/Input/Input.cjs +0 -5
  312. package/dist/components/Input/Input.cjs.map +0 -1
  313. package/dist/components/Input/Input.d.ts +0 -32
  314. package/dist/components/Input/Input.js +0 -5
  315. package/dist/components/Input/Input.js.map +0 -1
  316. package/dist/components/Input/index.d.ts +0 -1
  317. package/dist/components/Input.d.ts +0 -2
  318. package/dist/components/InputGroup/InputGroup.cjs +0 -126
  319. package/dist/components/InputGroup/InputGroup.cjs.map +0 -1
  320. package/dist/components/InputGroup/InputGroup.d.ts +0 -6
  321. package/dist/components/InputGroup/InputGroup.js +0 -126
  322. package/dist/components/InputGroup/InputGroup.js.map +0 -1
  323. package/dist/components/InputGroup/index.d.ts +0 -1
  324. package/dist/components/InputGroup.d.ts +0 -2
  325. package/dist/components/Modal/Modal.cjs +0 -209
  326. package/dist/components/Modal/Modal.cjs.map +0 -1
  327. package/dist/components/Modal/Modal.d.ts +0 -29
  328. package/dist/components/Modal/Modal.js +0 -209
  329. package/dist/components/Modal/Modal.js.map +0 -1
  330. package/dist/components/Modal/ModalBody.d.ts +0 -6
  331. package/dist/components/Modal/ModalFooter.d.ts +0 -19
  332. package/dist/components/Modal/ModalHeader.d.ts +0 -6
  333. package/dist/components/Modal/index.d.ts +0 -1
  334. package/dist/components/Modal.d.ts +0 -2
  335. package/dist/components/Select/Select.cjs +0 -6
  336. package/dist/components/Select/Select.cjs.map +0 -1
  337. package/dist/components/Select/Select.d.ts +0 -60
  338. package/dist/components/Select/Select.definitions.d.ts +0 -14
  339. package/dist/components/Select/Select.js +0 -6
  340. package/dist/components/Select/Select.js.map +0 -1
  341. package/dist/components/Select/index.d.ts +0 -1
  342. package/dist/components/Select.d.ts +0 -2
  343. package/dist/components/Stat/index.d.ts +0 -1
  344. package/dist/components/Stat.d.ts +0 -2
  345. package/dist/components/StatusMessage/StatusMessage.cjs +0 -79
  346. package/dist/components/StatusMessage/StatusMessage.cjs.map +0 -1
  347. package/dist/components/StatusMessage/StatusMessage.d.ts +0 -44
  348. package/dist/components/StatusMessage/StatusMessage.js +0 -79
  349. package/dist/components/StatusMessage/StatusMessage.js.map +0 -1
  350. package/dist/components/StatusMessage/index.d.ts +0 -1
  351. package/dist/components/StatusMessage.d.ts +0 -2
  352. package/dist/components/Stepper/Stepper.cjs +0 -46
  353. package/dist/components/Stepper/Stepper.cjs.map +0 -1
  354. package/dist/components/Stepper/Stepper.d.ts +0 -11
  355. package/dist/components/Stepper/Stepper.js +0 -46
  356. package/dist/components/Stepper/Stepper.js.map +0 -1
  357. package/dist/components/Stepper/index.d.ts +0 -2
  358. package/dist/components/Stepper.d.ts +0 -2
  359. package/dist/components/Tabs/Tabs.cjs +0 -96
  360. package/dist/components/Tabs/Tabs.cjs.map +0 -1
  361. package/dist/components/Tabs/Tabs.d.ts +0 -19
  362. package/dist/components/Tabs/Tabs.js +0 -96
  363. package/dist/components/Tabs/Tabs.js.map +0 -1
  364. package/dist/components/Tabs/index.d.ts +0 -2
  365. package/dist/components/Tabs.d.ts +0 -2
  366. package/dist/components/Timeline/Timeline.cjs.map +0 -1
  367. package/dist/components/Timeline/Timeline.d.ts +0 -13
  368. package/dist/components/Timeline/Timeline.js.map +0 -1
  369. package/dist/components/Timeline/index.d.ts +0 -2
  370. package/dist/components/Timeline.d.ts +0 -2
  371. package/dist/index.cjs +0 -2
  372. package/dist/index.cjs.map +0 -1
  373. package/dist/index.d.ts +0 -0
  374. package/dist/index.js +0 -2
  375. package/dist/index.js.map +0 -1
  376. package/dist/styles.css +0 -112
  377. package/rollup.config.cjs +0 -87
  378. package/src/components/Autocomplete/Autocomplete.definitions.ts +0 -254
  379. package/src/components/Autocomplete/Autocomplete.stories.tsx +0 -387
  380. package/src/components/Autocomplete/Autocomplete.tsx +0 -139
  381. package/src/components/Autocomplete/index.ts +0 -1
  382. package/src/components/Avatar/Avatar.stories.tsx +0 -54
  383. package/src/components/Avatar/Avatar.tsx +0 -143
  384. package/src/components/Avatar/index.ts +0 -1
  385. package/src/components/Button/Button.definition.ts +0 -97
  386. package/src/components/Button/Button.stories.tsx +0 -285
  387. package/src/components/Button/Button.tsx +0 -67
  388. package/src/components/Button/index.ts +0 -1
  389. package/src/components/Card/Card.definition.ts +0 -5
  390. package/src/components/Card/Card.stories.tsx +0 -32
  391. package/src/components/Card/Card.tsx +0 -44
  392. package/src/components/Card/index.ts +0 -1
  393. package/src/components/Chip/Chip.definitions.ts +0 -167
  394. package/src/components/Chip/Chip.stories.tsx +0 -265
  395. package/src/components/Chip/Chip.tsx +0 -61
  396. package/src/components/Chip/index.ts +0 -1
  397. package/src/components/Column/Column.tsx +0 -29
  398. package/src/components/Column/index.ts +0 -1
  399. package/src/components/DatePicker/DatePicker.definitions.ts +0 -205
  400. package/src/components/DatePicker/DatePicker.stories.tsx +0 -282
  401. package/src/components/DatePicker/DatePicker.tsx +0 -165
  402. package/src/components/DatePicker/index.ts +0 -1
  403. package/src/components/DateRangePicker/DateRangePicker.definitions.ts +0 -191
  404. package/src/components/DateRangePicker/DateRangePicker.stories.tsx +0 -252
  405. package/src/components/DateRangePicker/DateRangePicker.tsx +0 -56
  406. package/src/components/DateRangePicker/index.ts +0 -1
  407. package/src/components/DateTimePicker/DateTimePicker.definitions.ts +0 -232
  408. package/src/components/DateTimePicker/DateTimePicker.stories.tsx +0 -390
  409. package/src/components/DateTimePicker/DateTimePicker.tsx +0 -191
  410. package/src/components/DateTimePicker/index.ts +0 -1
  411. package/src/components/Flyout/Flyout.stories.tsx +0 -274
  412. package/src/components/Flyout/Flyout.tsx +0 -122
  413. package/src/components/Flyout/index.ts +0 -1
  414. package/src/components/Gallery/Gallery.definition.tsx +0 -37
  415. package/src/components/Gallery/Gallery.stories.tsx +0 -82
  416. package/src/components/Gallery/Gallery.tsx +0 -118
  417. package/src/components/Gallery/GalleryLightbox.tsx +0 -170
  418. package/src/components/Gallery/GalleryMain.tsx +0 -84
  419. package/src/components/Gallery/GalleryThumbnails.tsx +0 -106
  420. package/src/components/Gallery/index.ts +0 -1
  421. package/src/components/Icon/Icon.stories.tsx +0 -54
  422. package/src/components/Icon/Icon.tsx +0 -94
  423. package/src/components/Icon/index.ts +0 -2
  424. package/src/components/Input/Input.definitions.ts +0 -252
  425. package/src/components/Input/Input.stories.tsx +0 -387
  426. package/src/components/Input/Input.tsx +0 -186
  427. package/src/components/Input/index.ts +0 -1
  428. package/src/components/InputGroup/InputGroup.stories.tsx +0 -136
  429. package/src/components/InputGroup/InputGroup.tsx +0 -136
  430. package/src/components/InputGroup/index.ts +0 -1
  431. package/src/components/MenuButton/MenuButton.stories.tsx +0 -197
  432. package/src/components/MenuButton/MenuButton.tsx +0 -100
  433. package/src/components/MenuButton/index.ts +0 -1
  434. package/src/components/Modal/Modal.stories.tsx +0 -293
  435. package/src/components/Modal/Modal.tsx +0 -173
  436. package/src/components/Modal/ModalBody.tsx +0 -16
  437. package/src/components/Modal/ModalFooter.tsx +0 -61
  438. package/src/components/Modal/ModalHeader.tsx +0 -18
  439. package/src/components/Modal/index.ts +0 -1
  440. package/src/components/Select/Select.definitions.ts +0 -488
  441. package/src/components/Select/Select.stories.tsx +0 -569
  442. package/src/components/Select/Select.tsx +0 -468
  443. package/src/components/Select/index.ts +0 -1
  444. package/src/components/Stat/Stat.stories.tsx +0 -85
  445. package/src/components/Stat/Stat.tsx +0 -117
  446. package/src/components/Stat/index.ts +0 -2
  447. package/src/components/StatusMessage/StatusMessage.stories.tsx +0 -130
  448. package/src/components/StatusMessage/StatusMessage.tsx +0 -162
  449. package/src/components/StatusMessage/index.ts +0 -2
  450. package/src/components/Stepper/Step.tsx +0 -21
  451. package/src/components/Stepper/Stepper.definition.ts +0 -75
  452. package/src/components/Stepper/Stepper.stories.tsx +0 -122
  453. package/src/components/Stepper/Stepper.tsx +0 -59
  454. package/src/components/Stepper/index.ts +0 -2
  455. package/src/components/Table/EmptyTable.png +0 -0
  456. package/src/components/Table/Table.definition.ts +0 -580
  457. package/src/components/Table/Table.stories.tsx +0 -853
  458. package/src/components/Table/Table.tsx +0 -495
  459. package/src/components/Table/data.ts +0 -134
  460. package/src/components/Table/exportsUtils.ts +0 -195
  461. package/src/components/Table/index.ts +0 -3
  462. package/src/components/Table/types.ts +0 -34
  463. package/src/components/Tabs/Tab.definition.ts +0 -53
  464. package/src/components/Tabs/Tab.tsx +0 -19
  465. package/src/components/Tabs/Tabs.stories.tsx +0 -118
  466. package/src/components/Tabs/Tabs.tsx +0 -99
  467. package/src/components/Tabs/_tabUtils.tsx +0 -4
  468. package/src/components/Tabs/index.ts +0 -2
  469. package/src/components/Timeline/Timeline.definition.ts +0 -43
  470. package/src/components/Timeline/Timeline.stories.tsx +0 -108
  471. package/src/components/Timeline/Timeline.tsx +0 -49
  472. package/src/components/Timeline/TimelineItem.tsx +0 -31
  473. package/src/components/Timeline/index.ts +0 -2
  474. package/src/components/Tooltip/Tooltip.stories.tsx +0 -117
  475. package/src/components/Tooltip/Tooltip.tsx +0 -58
  476. package/src/components/Tooltip/index.ts +0 -1
  477. package/src/hooks/ClipBoard/ClipBoard.stories.tsx +0 -168
  478. package/src/hooks/ClipBoard/ClipBoard.tsx +0 -131
  479. package/src/hooks/ClipBoard/ClipboardUnifiedDemo.tsx +0 -111
  480. package/src/hooks/ClipBoard/index.ts +0 -1
  481. package/src/index.ts +0 -1
  482. package/src/styles.css +0 -3
  483. package/tailwind.config.js +0 -10
  484. package/tsconfig.json +0 -48
  485. package/tsup.config.js +0 -41
  486. package/vite.config.js +0 -132
  487. package/vitest.config.ts +0 -35
  488. /package/{dist/Button-C17mExpd.cjs → Button-C17mExpd.cjs} +0 -0
  489. /package/{dist/Button-UkkP-bNw.js → Button-UkkP-bNw.js} +0 -0
  490. /package/{Readme.md → README.md} +0 -0
  491. /package/{dist/components → components}/Avatar.d.ts +0 -0
  492. /package/{dist/components → components}/Button/Button.cjs +0 -0
  493. /package/{dist/components → components}/Button/Button.cjs.map +0 -0
  494. /package/{dist/components → components}/Button/Button.definition.d.ts +0 -0
  495. /package/{dist/components → components}/Button/Button.js +0 -0
  496. /package/{dist/components → components}/Button/Button.js.map +0 -0
  497. /package/{dist/components → components}/Button.d.ts +0 -0
  498. /package/{dist/components → components}/Card/Card.definition.d.ts +0 -0
  499. /package/{dist/components → components}/Chip/Chip.d.ts +0 -0
  500. /package/{dist/components → components}/Chip/Chip.definitions.d.ts +0 -0
  501. /package/{dist/components → components}/Column/Column.cjs +0 -0
  502. /package/{dist/components → components}/Column/Column.cjs.map +0 -0
  503. /package/{dist/components → components}/Column/Column.d.ts +0 -0
  504. /package/{dist/components → components}/Column/Column.js +0 -0
  505. /package/{dist/components → components}/Column/Column.js.map +0 -0
  506. /package/{dist/components → components}/Column/index.d.ts +0 -0
  507. /package/{dist/components → components}/Column.d.ts +0 -0
  508. /package/{dist/components → components}/DateRangePicker/DateRangePicker.cjs +0 -0
  509. /package/{dist/components → components}/DateRangePicker/DateRangePicker.cjs.map +0 -0
  510. /package/{dist/components → components}/DateRangePicker/DateRangePicker.d.ts +0 -0
  511. /package/{dist/components → components}/DateRangePicker/DateRangePicker.definitions.d.ts +0 -0
  512. /package/{dist/components → components}/DateRangePicker/DateRangePicker.js +0 -0
  513. /package/{dist/components → components}/DateRangePicker/DateRangePicker.js.map +0 -0
  514. /package/{dist/components → components}/DateRangePicker/index.d.ts +0 -0
  515. /package/{dist/components → components}/DateRangePicker.d.ts +0 -0
  516. /package/{dist/components → components}/Flyout/Flyout.cjs +0 -0
  517. /package/{dist/components → components}/Flyout/Flyout.cjs.map +0 -0
  518. /package/{dist/components → components}/Flyout/Flyout.d.ts +0 -0
  519. /package/{dist/components → components}/Flyout/Flyout.js +0 -0
  520. /package/{dist/components → components}/Flyout/Flyout.js.map +0 -0
  521. /package/{dist/components → components}/Flyout/index.d.ts +0 -0
  522. /package/{dist/components → components}/Flyout.d.ts +0 -0
  523. /package/{dist/components → components}/Gallery/Gallery.definition.d.ts +0 -0
  524. /package/{dist/components → components}/MenuButton/MenuButton.cjs +0 -0
  525. /package/{dist/components → components}/MenuButton/MenuButton.cjs.map +0 -0
  526. /package/{dist/components → components}/MenuButton/MenuButton.d.ts +0 -0
  527. /package/{dist/components → components}/MenuButton/MenuButton.js +0 -0
  528. /package/{dist/components → components}/MenuButton/MenuButton.js.map +0 -0
  529. /package/{dist/components → components}/MenuButton/index.d.ts +0 -0
  530. /package/{dist/components → components}/MenuButton.d.ts +0 -0
  531. /package/{dist/components → components}/Stat/Stat.d.ts +0 -0
  532. /package/{dist/components → components}/Stepper/Step.d.ts +0 -0
  533. /package/{dist/components → components}/Stepper/Stepper.definition.d.ts +0 -0
  534. /package/{dist/components → components}/Table/Table.cjs +0 -0
  535. /package/{dist/components → components}/Table/Table.cjs.map +0 -0
  536. /package/{dist/components → components}/Table/Table.d.ts +0 -0
  537. /package/{dist/components → components}/Table/Table.definition.d.ts +0 -0
  538. /package/{dist/components → components}/Table/Table.js +0 -0
  539. /package/{dist/components → components}/Table/Table.js.map +0 -0
  540. /package/{dist/components → components}/Table/data.d.ts +0 -0
  541. /package/{dist/components → components}/Table/exportsUtils.d.ts +0 -0
  542. /package/{dist/components → components}/Table/index.d.ts +0 -0
  543. /package/{dist/components → components}/Table/types.d.ts +0 -0
  544. /package/{dist/components → components}/Table.d.ts +0 -0
  545. /package/{dist/components → components}/Tabs/Tab.d.ts +0 -0
  546. /package/{dist/components → components}/Tabs/Tab.definition.d.ts +0 -0
  547. /package/{dist/components → components}/Tabs/_tabUtils.d.ts +0 -0
  548. /package/{dist/components → components}/Timeline/Timeline.definition.d.ts +0 -0
  549. /package/{dist/components → components}/Timeline/TimelineItem.d.ts +0 -0
  550. /package/{dist/components → components}/Tooltip/Tooltip.cjs +0 -0
  551. /package/{dist/components → components}/Tooltip/Tooltip.cjs.map +0 -0
  552. /package/{dist/components → components}/Tooltip/Tooltip.d.ts +0 -0
  553. /package/{dist/components → components}/Tooltip/Tooltip.js +0 -0
  554. /package/{dist/components → components}/Tooltip/Tooltip.js.map +0 -0
  555. /package/{dist/components → components}/Tooltip/index.d.ts +0 -0
  556. /package/{dist/components → components}/Tooltip.d.ts +0 -0
  557. /package/{dist/hooks → hooks}/ClipBoard/ClipBoard.cjs +0 -0
  558. /package/{dist/hooks → hooks}/ClipBoard/ClipBoard.cjs.map +0 -0
  559. /package/{dist/hooks → hooks}/ClipBoard/ClipBoard.d.ts +0 -0
  560. /package/{dist/hooks → hooks}/ClipBoard/ClipBoard.js +0 -0
  561. /package/{dist/hooks → hooks}/ClipBoard/ClipBoard.js.map +0 -0
  562. /package/{dist/hooks → hooks}/ClipBoard/ClipboardUnifiedDemo.d.ts +0 -0
  563. /package/{dist/hooks → hooks}/ClipBoard/index.d.ts +0 -0
  564. /package/{dist/hooks → hooks}/ClipBoard.d.ts +0 -0
  565. /package/{dist/index.css → index.css} +0 -0
@@ -0,0 +1,188 @@
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 } from "../../formField.sx-8_QRnKxv.js";
37
+ import { F as FIELD_INPUT_PADDING_Y } from "../../tokens-BRrcP_p_.js";
38
+ import { r as resolvePreset } from "../../resolvePreset-B-IB0ehH.js";
39
+ const parseValue = (raw, type) => {
40
+ if (type !== "number") return raw;
41
+ if (raw === "" || raw === "-") return raw;
42
+ const n = parseFloat(raw);
43
+ return isNaN(n) ? raw : n;
44
+ };
45
+ const buildSlotProps = (type, min, max, maxLength, customSlotProps, customInputProps, readOnly) => {
46
+ const numberAttrs = type === "number" ? __spreadValues({ min: min != null ? min : Number.NEGATIVE_INFINITY }, max !== void 0 && { max }) : {};
47
+ return __spreadProps(__spreadValues({}, customSlotProps), {
48
+ htmlInput: __spreadValues(__spreadValues(__spreadValues(__spreadValues(__spreadValues({}, customInputProps), customSlotProps == null ? void 0 : customSlotProps.htmlInput), numberAttrs), maxLength !== void 0 && { maxLength }), readOnly && { readOnly: true }),
49
+ // Dejamos que MUI maneje el shrink nativamente (animación inside → up).
50
+ // El consumidor puede forzar shrink con slotProps.inputLabel.shrink=true si lo necesita.
51
+ inputLabel: __spreadValues({}, customSlotProps == null ? void 0 : customSlotProps.inputLabel)
52
+ });
53
+ };
54
+ const buildInputSx = (borderRadius, labelPosition) => {
55
+ const radius = typeof borderRadius === "number" ? `${borderRadius}px` : borderRadius;
56
+ return buildFormFieldSx({
57
+ borderRadius,
58
+ labelPosition,
59
+ extraOutsideSx: {
60
+ "& .MuiInputBase-input": {
61
+ paddingTop: FIELD_INPUT_PADDING_Y,
62
+ paddingBottom: FIELD_INPUT_PADDING_Y
63
+ },
64
+ // Filled: quitar el padding-top reservado para el label flotante dentro.
65
+ "& .MuiFilledInput-root": {
66
+ paddingTop: 0,
67
+ borderRadius: `${radius} ${radius} 0 0`
68
+ },
69
+ "& .MuiFilledInput-input": {
70
+ paddingTop: FIELD_INPUT_PADDING_Y
71
+ },
72
+ // Standard: quitar el margin-top reservado para el label flotante.
73
+ "& .MuiInput-root": {
74
+ marginTop: 0
75
+ }
76
+ }
77
+ });
78
+ };
79
+ const Input = (props) => {
80
+ const _a = props, {
81
+ type = "text",
82
+ variant = "outlined",
83
+ size = "small",
84
+ borderRadius = 10,
85
+ labelPosition = "outside",
86
+ preset,
87
+ min,
88
+ max,
89
+ maxLength,
90
+ readOnly,
91
+ inputProps,
92
+ slotProps,
93
+ sx,
94
+ onBlur
95
+ } = _a, rest = __objRest(_a, [
96
+ "type",
97
+ "variant",
98
+ "size",
99
+ "borderRadius",
100
+ "labelPosition",
101
+ "preset",
102
+ "min",
103
+ "max",
104
+ "maxLength",
105
+ "readOnly",
106
+ "inputProps",
107
+ "slotProps",
108
+ "sx",
109
+ "onBlur"
110
+ ]);
111
+ const theme = useTheme();
112
+ const presetSx = resolvePreset("Input", preset, theme);
113
+ const finalSlotProps = buildSlotProps(
114
+ type,
115
+ min,
116
+ max,
117
+ maxLength,
118
+ slotProps,
119
+ inputProps,
120
+ readOnly
121
+ );
122
+ const mergedSx = [
123
+ buildInputSx(borderRadius, labelPosition),
124
+ ...presetSx ? [presetSx] : [],
125
+ ...Array.isArray(sx) ? sx : sx ? [sx] : []
126
+ ];
127
+ if ("control" in props && props.control) {
128
+ const { name, control, validation, onValueChange } = props;
129
+ return /* @__PURE__ */ jsx(
130
+ Controller,
131
+ {
132
+ name,
133
+ control,
134
+ rules: validation,
135
+ render: ({ field, fieldState: { error } }) => {
136
+ var _a2, _b;
137
+ return /* @__PURE__ */ jsx(
138
+ TextField,
139
+ __spreadProps(__spreadValues({
140
+ fullWidth: true
141
+ }, rest), {
142
+ name: field.name,
143
+ value: (_a2 = field.value) != null ? _a2 : "",
144
+ onChange: (e) => {
145
+ const parsed = parseValue(e.target.value, type);
146
+ field.onChange(parsed);
147
+ onValueChange == null ? void 0 : onValueChange(parsed);
148
+ },
149
+ onBlur: (e) => {
150
+ field.onBlur();
151
+ onBlur == null ? void 0 : onBlur(e);
152
+ },
153
+ inputRef: field.ref,
154
+ type,
155
+ variant,
156
+ size,
157
+ slotProps: finalSlotProps,
158
+ sx: mergedSx,
159
+ error: !!error || rest.error,
160
+ helperText: (_b = error == null ? void 0 : error.message) != null ? _b : rest.helperText
161
+ })
162
+ );
163
+ }
164
+ }
165
+ );
166
+ }
167
+ const { value, onChange } = props;
168
+ return /* @__PURE__ */ jsx(
169
+ TextField,
170
+ __spreadProps(__spreadValues({
171
+ fullWidth: true
172
+ }, rest), {
173
+ value: value != null ? value : "",
174
+ onChange: (e) => onChange(parseValue(e.target.value, type)),
175
+ onBlur,
176
+ type,
177
+ variant,
178
+ size,
179
+ slotProps: finalSlotProps,
180
+ sx: mergedSx
181
+ })
182
+ );
183
+ };
184
+ export {
185
+ Input,
186
+ Input as default
187
+ };
188
+ //# sourceMappingURL=Input.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"Input.js","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 } 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\", maxLength y readOnly.\n */\nexport const buildSlotProps = (\n type: InputType,\n min: number | undefined,\n max: number | undefined,\n maxLength: number | undefined,\n customSlotProps: TextFieldProps['slotProps'],\n customInputProps: InputHTMLAttributes<HTMLInputElement> | undefined,\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 ...(maxLength !== undefined && { maxLength }),\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 maxLength?: 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 // `any` plano (no `Control<any>`): RHF tipa `Control<T>` con generics en\n // posiciones tanto contravariantes como covariantes (ej. `_subjects.state`).\n // Cuando el componente o su uso involucra generics adicionales, TS se\n // confunde narroweando el discriminated union y `Control<any>` no logra\n // absorber `Control<MyForm>` en la comparación estructural profunda. El\n // `any` plano elimina ese ruido. RHF adentro sigue teniendo sus tipos\n // fuertes — solo degradamos la superficie del prop del componente.\n control: any;\n validation?: RegisterOptions;\n /**\n * Side-effect que corre después de que RHF actualiza el form state.\n * Útil para cascadas entre campos (ej. reset de municipio al cambiar\n * departamento). NO reemplaza al handler de RHF.\n */\n onValueChange?: (value: string | number) => void;\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 maxLength,\n readOnly,\n inputProps,\n slotProps,\n sx,\n onBlur,\n ...rest\n } = props as ControlledInputProps & {\n control?: Control<any>;\n validation?: RegisterOptions;\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 maxLength,\n slotProps,\n inputProps,\n readOnly,\n );\n const mergedSx = [\n buildInputSx(borderRadius, labelPosition),\n ...(presetSx ? [presetSx] : []),\n ...(Array.isArray(sx) ? sx : sx ? [sx] : []),\n ];\n\n if ('control' in props && props.control) {\n const { name, control, validation, onValueChange } = 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) => {\n const parsed = parseValue(e.target.value, type);\n field.onChange(parsed);\n onValueChange?.(parsed);\n }}\n onBlur={(e) => {\n field.onBlur();\n onBlur?.(e);\n }}\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 onBlur={onBlur}\n type={type}\n variant={variant}\n size={size}\n slotProps={finalSlotProps}\n sx={mergedSx}\n />\n );\n};\n\nexport default Input;\n"],"names":["_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,WACA,iBACA,kBACA,aACgC;AAChC,QAAM,cACJ,SAAS,WACL,iBAAE,KAAK,oBAAO,OAAO,qBAAuB,QAAQ,UAAa,EAAE,IAAA,KACnE,CAAA;AAEN,SAAO,iCACF,kBADE;AAAA,IAEL,WAAW,+EACN,mBACC,mDAAyB,YAC1B,cACC,cAAc,UAAa,EAAE,UAAA,IAC7B,YAAY,EAAE,UAAU,KAAA;AAAA;AAAA;AAAA,IAI9B,YAAY,mBACN,mDAAyB;AAAA,EAC/B;AAEJ;ACtCO,MAAM,eAAe,CAC1B,cACA,kBACyB;AACzB,QAAM,SAAS,OAAO,iBAAiB,WAAW,GAAG,YAAY,OAAO;AAExE,SAAO,iBAAiB;AAAA,IACtB;AAAA,IACA;AAAA,IACA,gBAAgB;AAAA,MACd,yBAAyB;AAAA,QACvB,YAAY;AAAA,QACZ,eAAe;AAAA,MAAA;AAAA;AAAA,MAIjB,0BAA0B;AAAA,QACxB,YAAY;AAAA,QACZ,cAAc,GAAG,MAAM,IAAI,MAAM;AAAA,MAAA;AAAA,MAEnC,2BAA2B;AAAA,QACzB,YAAY;AAAA,MAAA;AAAA;AAAA,MAId,oBAAoB;AAAA,QAClB,WAAW;AAAA,MAAA;AAAA,IACb;AAAA,EACF,CACD;AACH;AC4BO,MAAM,QAA8B,CAAC,UAAU;AACpD,QAgBI,YAfF;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,IACA;AAAA,IACA;AAAA,MAEE,IADC,iBACD,IADC;AAAA,IAdH;AAAA,IACA;AAAA,IACA;AAAA,IACA;AAAA,IACA;AAAA,IACA;AAAA,IACA;AAAA,IACA;AAAA,IACA;AAAA,IACA;AAAA,IACA;AAAA,IACA;AAAA,IACA;AAAA,IACA;AAAA;AAOF,QAAM,QAAQ,SAAA;AACd,QAAM,WAAW,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,KAAK,CAAC,EAAE,IAAI,CAAA;AAAA,EAAC;AAG5C,MAAI,aAAa,SAAS,MAAM,SAAS;AACvC,UAAM,EAAE,MAAM,SAAS,YAAY,kBAAkB;AACrD,WACE;AAAA,MAAC;AAAA,MAAA;AAAA,QACC;AAAA,QACA;AAAA,QACA,OAAO;AAAA,QACP,QAAQ,CAAC,EAAE,OAAO,YAAY,EAAE,MAAA;;AAC9B;AAAA,YAAC;AAAA,YAAA;AAAA,cACC,WAAS;AAAA,eACL,OAFL;AAAA,cAGC,MAAM,MAAM;AAAA,cACZ,QAAOA,MAAA,MAAM,UAAN,OAAAA,MAAe;AAAA,cACtB,UAAU,CAAC,MAAM;AACf,sBAAM,SAAS,WAAW,EAAE,OAAO,OAAO,IAAI;AAC9C,sBAAM,SAAS,MAAM;AACrB,+DAAgB;AAAA,cAClB;AAAA,cACA,QAAQ,CAAC,MAAM;AACb,sBAAM,OAAA;AACN,iDAAS;AAAA,cACX;AAAA,cACA,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,SACE;AAAA,IAAC;AAAA,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;AAAA,MACA,WAAW;AAAA,MACX,IAAI;AAAA,IAAA;AAAA,EAAA;AAGV;"}
@@ -0,0 +1,8 @@
1
+ import { TextFieldProps } from '@mui/material';
2
+ import { LabelPosition } from './Input';
3
+ /**
4
+ * Builder de sx para el Input. Usa el builder compartido
5
+ * `buildFormFieldSx` y añade overrides específicos de TextField
6
+ * (padding del input base, filled, standard).
7
+ */
8
+ export declare const buildInputSx: (borderRadius: number | string, labelPosition: LabelPosition) => TextFieldProps["sx"];
@@ -0,0 +1,2 @@
1
+ export { Input, default } from './Input';
2
+ export type { InputProps, BaseInputProps, RHFInputProps, ControlledInputProps, InputType, LabelPosition, } from './Input';
@@ -0,0 +1,6 @@
1
+ export * from './Input/index'
2
+ export {}
3
+ import _default from './Input/index'
4
+ export default _default
5
+ export * from './Input/index'
6
+ export {}
@@ -0,0 +1,140 @@
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
+ Object.defineProperties(exports, { __esModule: { value: true }, [Symbol.toStringTag]: { value: "Module" } });
22
+ const jsxRuntime = require("react/jsx-runtime");
23
+ const React = require("react");
24
+ const material = require("@mui/material");
25
+ const mergeSx = require("../../mergeSx-Dbccoo_H.cjs");
26
+ const tokens = require("../../tokens-jaWWNk39.cjs");
27
+ const InputGroup = ({
28
+ children,
29
+ sx,
30
+ slotSx,
31
+ borderRadius = 10,
32
+ disabled,
33
+ orientation = "horizontal",
34
+ className
35
+ }) => {
36
+ const radius = typeof borderRadius === "number" ? `${borderRadius}px` : borderRadius;
37
+ const slots = React.Children.toArray(children).filter(React.isValidElement);
38
+ const isHorizontal = orientation === "horizontal";
39
+ const baseSx = {
40
+ // Respeta el label "outside" de Input/Select: los hijos pierden su marginTop
41
+ // (ver más abajo) y el grupo reserva el mismo espacio arriba para que los
42
+ // labels floten por encima del borde del grupo.
43
+ marginTop: tokens.LABEL_MARGIN_TOP,
44
+ display: "flex",
45
+ flexDirection: isHorizontal ? "row" : "column",
46
+ alignItems: "stretch",
47
+ width: "100%",
48
+ border: (theme) => `1px solid ${theme.palette.divider}`,
49
+ borderRadius: radius,
50
+ backgroundColor: "background.paper",
51
+ transition: "border-color 200ms cubic-bezier(0.0, 0, 0.2, 1) 0ms, box-shadow 200ms cubic-bezier(0.0, 0, 0.2, 1) 0ms",
52
+ "&:focus-within": {
53
+ borderColor: "primary.main",
54
+ boxShadow: (theme) => `0 0 0 1px ${theme.palette.primary.main}`
55
+ },
56
+ opacity: disabled ? 0.6 : 1,
57
+ pointerEvents: disabled ? "none" : "auto",
58
+ // Cancelar el marginTop que Input/Select reservan en labelPosition="outside".
59
+ // El grupo ya lo reservó en su nivel externo.
60
+ "& .MuiFormControl-root, & > [data-input-group-slot] > .MuiTextField-root, & > [data-input-group-slot] > .MuiFormControl-root": {
61
+ marginTop: 0
62
+ },
63
+ // Quitar el borde del notched outline interno: el borde visible es el del
64
+ // grupo, los separadores son los borderRight/borderBottom de cada slot.
65
+ "& .MuiOutlinedInput-notchedOutline": {
66
+ border: "none"
67
+ },
68
+ // Forzar que todos los campos pinten sus esquinas cuadradas (las esquinas
69
+ // redondeadas se aplican solo al primer/último slot más abajo).
70
+ "& .MuiInputBase-root, & .MuiChip-root": {
71
+ borderRadius: 0
72
+ },
73
+ // Botones integrados: sin radius propio, altura completa, sin sombra.
74
+ "& .MuiButton-root": {
75
+ borderRadius: 0,
76
+ height: "100%",
77
+ boxShadow: "none",
78
+ border: "none"
79
+ },
80
+ // Slots: cada hijo vive en un slot neutro que lo centra verticalmente.
81
+ "& > [data-input-group-slot]": __spreadProps(__spreadValues({
82
+ flex: 1,
83
+ display: "flex",
84
+ alignItems: "center",
85
+ minWidth: 0
86
+ }, isHorizontal ? { borderRight: (theme) => `1px solid ${theme.palette.divider}` } : { borderBottom: (theme) => `1px solid ${theme.palette.divider}` }), {
87
+ "&:last-of-type": {
88
+ borderRight: "none",
89
+ borderBottom: "none"
90
+ }
91
+ }),
92
+ // Esquinas redondeadas: primer slot (izquierda o arriba).
93
+ "& > [data-input-group-slot]:first-of-type .MuiInputBase-root, & > [data-input-group-slot]:first-of-type .MuiButton-root, & > [data-input-group-slot]:first-of-type .MuiChip-root": isHorizontal ? {
94
+ borderTopLeftRadius: radius,
95
+ borderBottomLeftRadius: radius
96
+ } : {
97
+ borderTopLeftRadius: radius,
98
+ borderTopRightRadius: radius
99
+ },
100
+ // Esquinas redondeadas: último slot (derecha o abajo).
101
+ "& > [data-input-group-slot]:last-of-type .MuiInputBase-root, & > [data-input-group-slot]:last-of-type .MuiButton-root, & > [data-input-group-slot]:last-of-type .MuiChip-root": isHorizontal ? {
102
+ borderTopRightRadius: radius,
103
+ borderBottomRightRadius: radius
104
+ } : {
105
+ borderBottomLeftRadius: radius,
106
+ borderBottomRightRadius: radius
107
+ }
108
+ };
109
+ const baseSlotSx = {
110
+ flex: 1,
111
+ display: "flex",
112
+ alignItems: "center",
113
+ minWidth: 0
114
+ };
115
+ return /* @__PURE__ */ jsxRuntime.jsx(
116
+ material.Box,
117
+ {
118
+ "data-testid": "input-group",
119
+ className,
120
+ "aria-disabled": disabled ? "true" : void 0,
121
+ sx: mergeSx.mergeSx(baseSx, sx),
122
+ children: slots.map((child, i) => {
123
+ var _a;
124
+ const slotKey = (_a = child.key) != null ? _a : i;
125
+ return /* @__PURE__ */ jsxRuntime.jsx(
126
+ material.Box,
127
+ {
128
+ "data-input-group-slot": true,
129
+ sx: mergeSx.mergeSx(baseSlotSx, slotSx),
130
+ children: child
131
+ },
132
+ slotKey
133
+ );
134
+ })
135
+ }
136
+ );
137
+ };
138
+ exports.InputGroup = InputGroup;
139
+ exports.default = InputGroup;
140
+ //# sourceMappingURL=InputGroup.cjs.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"InputGroup.cjs","sources":["../../../src/components/InputGroup/InputGroup.tsx"],"sourcesContent":["import React, { Children, isValidElement } from 'react';\nimport { Box, type SxProps, type Theme } from '@mui/material';\n\nimport { mergeSx } from '../_shared/mergeSx';\nimport { LABEL_MARGIN_TOP } from '../../theme/tokens';\n\nexport interface InputGroupProps {\n children: React.ReactNode;\n /**\n * sx aplicado al contenedor raíz del grupo. Se mergea sobre los defaults.\n */\n sx?: SxProps<Theme>;\n /**\n * sx aplicado a cada slot individual. Útil para controlar flex/gap entre\n * los hijos del grupo.\n */\n slotSx?: SxProps<Theme>;\n /**\n * Radio del borde del grupo. Default: 10.\n */\n borderRadius?: number | string;\n /**\n * Desactiva visualmente el grupo (no cascada lógica — los hijos deben\n * manejar su propio `disabled`).\n */\n disabled?: boolean;\n /**\n * Orientación del grupo. Default: 'horizontal'.\n */\n orientation?: 'horizontal' | 'vertical';\n className?: string;\n}\n\n/**\n * Agrupa visualmente varios componentes de entrada (Input / Select / DatePicker /\n * Button, etc.) compartiendo un solo borde y con separadores internos.\n *\n * El grupo respeta el espacio que Input/Select reservan para su label `outside`\n * (`LABEL_MARGIN_TOP`) moviendo ese reservado al contenedor externo y\n * cancelándolo en los hijos. Los labels siguen flotando por encima del borde\n * del grupo con la misma animación que fuera del grupo.\n *\n * No inspecciona el tipo de cada hijo; aplica los overrides a través de\n * descendant selectors por CSS para funcionar con cualquier wrapper / memoizado.\n */\nexport const InputGroup: React.FC<InputGroupProps> = ({\n children,\n sx,\n slotSx,\n borderRadius = 10,\n disabled,\n orientation = 'horizontal',\n className,\n}) => {\n const radius = typeof borderRadius === 'number' ? `${borderRadius}px` : borderRadius;\n const slots = Children.toArray(children).filter(isValidElement);\n const isHorizontal = orientation === 'horizontal';\n\n const baseSx: SxProps<Theme> = {\n // Respeta el label \"outside\" de Input/Select: los hijos pierden su marginTop\n // (ver más abajo) y el grupo reserva el mismo espacio arriba para que los\n // labels floten por encima del borde del grupo.\n marginTop: LABEL_MARGIN_TOP,\n\n display: 'flex',\n flexDirection: isHorizontal ? 'row' : 'column',\n alignItems: 'stretch',\n width: '100%',\n border: (theme) => `1px solid ${theme.palette.divider}`,\n borderRadius: radius,\n backgroundColor: 'background.paper',\n transition:\n 'border-color 200ms cubic-bezier(0.0, 0, 0.2, 1) 0ms, box-shadow 200ms cubic-bezier(0.0, 0, 0.2, 1) 0ms',\n '&:focus-within': {\n borderColor: 'primary.main',\n boxShadow: (theme) => `0 0 0 1px ${theme.palette.primary.main}`,\n },\n opacity: disabled ? 0.6 : 1,\n pointerEvents: disabled ? 'none' : 'auto',\n\n // Cancelar el marginTop que Input/Select reservan en labelPosition=\"outside\".\n // El grupo ya lo reservó en su nivel externo.\n '& .MuiFormControl-root, & > [data-input-group-slot] > .MuiTextField-root, & > [data-input-group-slot] > .MuiFormControl-root':\n {\n marginTop: 0,\n },\n\n // Quitar el borde del notched outline interno: el borde visible es el del\n // grupo, los separadores son los borderRight/borderBottom de cada slot.\n '& .MuiOutlinedInput-notchedOutline': {\n border: 'none',\n },\n\n // Forzar que todos los campos pinten sus esquinas cuadradas (las esquinas\n // redondeadas se aplican solo al primer/último slot más abajo).\n '& .MuiInputBase-root, & .MuiChip-root': {\n borderRadius: 0,\n },\n\n // Botones integrados: sin radius propio, altura completa, sin sombra.\n '& .MuiButton-root': {\n borderRadius: 0,\n height: '100%',\n boxShadow: 'none',\n border: 'none',\n },\n\n // Slots: cada hijo vive en un slot neutro que lo centra verticalmente.\n '& > [data-input-group-slot]': {\n flex: 1,\n display: 'flex',\n alignItems: 'center',\n minWidth: 0,\n // Separador entre slots (horizontal: borderRight / vertical: borderBottom),\n // usando el color de divider del theme.\n ...(isHorizontal\n ? { borderRight: (theme: Theme) => `1px solid ${theme.palette.divider}` }\n : { borderBottom: (theme: Theme) => `1px solid ${theme.palette.divider}` }),\n '&:last-of-type': {\n borderRight: 'none',\n borderBottom: 'none',\n },\n },\n\n // Esquinas redondeadas: primer slot (izquierda o arriba).\n '& > [data-input-group-slot]:first-of-type .MuiInputBase-root, & > [data-input-group-slot]:first-of-type .MuiButton-root, & > [data-input-group-slot]:first-of-type .MuiChip-root':\n isHorizontal\n ? {\n borderTopLeftRadius: radius,\n borderBottomLeftRadius: radius,\n }\n : {\n borderTopLeftRadius: radius,\n borderTopRightRadius: radius,\n },\n\n // Esquinas redondeadas: último slot (derecha o abajo).\n '& > [data-input-group-slot]:last-of-type .MuiInputBase-root, & > [data-input-group-slot]:last-of-type .MuiButton-root, & > [data-input-group-slot]:last-of-type .MuiChip-root':\n isHorizontal\n ? {\n borderTopRightRadius: radius,\n borderBottomRightRadius: radius,\n }\n : {\n borderBottomLeftRadius: radius,\n borderBottomRightRadius: radius,\n },\n };\n\n const baseSlotSx: SxProps<Theme> = {\n flex: 1,\n display: 'flex',\n alignItems: 'center',\n minWidth: 0,\n };\n\n return (\n <Box\n data-testid=\"input-group\"\n className={className}\n aria-disabled={disabled ? 'true' : undefined}\n sx={mergeSx(baseSx, sx)}\n >\n {slots.map((child, i) => {\n const slotKey = (child as React.ReactElement).key ?? i;\n return (\n <Box\n key={slotKey}\n data-input-group-slot\n sx={mergeSx(baseSlotSx, slotSx)}\n >\n {child}\n </Box>\n );\n })}\n </Box>\n );\n};\n\nexport default InputGroup;\n"],"names":["Children","isValidElement","LABEL_MARGIN_TOP","jsx","Box","mergeSx"],"mappings":";;;;;;;;;;;;;;;;;;;;;;;;;;AA6CO,MAAM,aAAwC,CAAC;AAAA,EACpD;AAAA,EACA;AAAA,EACA;AAAA,EACA,eAAe;AAAA,EACf;AAAA,EACA,cAAc;AAAA,EACd;AACF,MAAM;AACJ,QAAM,SAAS,OAAO,iBAAiB,WAAW,GAAG,YAAY,OAAO;AACxE,QAAM,QAAQA,MAAAA,SAAS,QAAQ,QAAQ,EAAE,OAAOC,oBAAc;AAC9D,QAAM,eAAe,gBAAgB;AAErC,QAAM,SAAyB;AAAA;AAAA;AAAA;AAAA,IAI7B,WAAWC,OAAAA;AAAAA,IAEX,SAAS;AAAA,IACT,eAAe,eAAe,QAAQ;AAAA,IACtC,YAAY;AAAA,IACZ,OAAO;AAAA,IACP,QAAQ,CAAC,UAAU,aAAa,MAAM,QAAQ,OAAO;AAAA,IACrD,cAAc;AAAA,IACd,iBAAiB;AAAA,IACjB,YACE;AAAA,IACF,kBAAkB;AAAA,MAChB,aAAa;AAAA,MACb,WAAW,CAAC,UAAU,aAAa,MAAM,QAAQ,QAAQ,IAAI;AAAA,IAAA;AAAA,IAE/D,SAAS,WAAW,MAAM;AAAA,IAC1B,eAAe,WAAW,SAAS;AAAA;AAAA;AAAA,IAInC,gIACE;AAAA,MACE,WAAW;AAAA,IAAA;AAAA;AAAA;AAAA,IAKf,sCAAsC;AAAA,MACpC,QAAQ;AAAA,IAAA;AAAA;AAAA;AAAA,IAKV,yCAAyC;AAAA,MACvC,cAAc;AAAA,IAAA;AAAA;AAAA,IAIhB,qBAAqB;AAAA,MACnB,cAAc;AAAA,MACd,QAAQ;AAAA,MACR,WAAW;AAAA,MACX,QAAQ;AAAA,IAAA;AAAA;AAAA,IAIV,+BAA+B;AAAA,MAC7B,MAAM;AAAA,MACN,SAAS;AAAA,MACT,YAAY;AAAA,MACZ,UAAU;AAAA,OAGN,eACA,EAAE,aAAa,CAAC,UAAiB,aAAa,MAAM,QAAQ,OAAO,OACnE,EAAE,cAAc,CAAC,UAAiB,aAAa,MAAM,QAAQ,OAAO,GAAA,IAT3C;AAAA,MAU7B,kBAAkB;AAAA,QAChB,aAAa;AAAA,QACb,cAAc;AAAA,MAAA;AAAA,IAChB;AAAA;AAAA,IAIF,oLACE,eACI;AAAA,MACE,qBAAqB;AAAA,MACrB,wBAAwB;AAAA,IAAA,IAE1B;AAAA,MACE,qBAAqB;AAAA,MACrB,sBAAsB;AAAA,IAAA;AAAA;AAAA,IAI9B,iLACE,eACI;AAAA,MACE,sBAAsB;AAAA,MACtB,yBAAyB;AAAA,IAAA,IAE3B;AAAA,MACE,wBAAwB;AAAA,MACxB,yBAAyB;AAAA,IAAA;AAAA,EAC3B;AAGR,QAAM,aAA6B;AAAA,IACjC,MAAM;AAAA,IACN,SAAS;AAAA,IACT,YAAY;AAAA,IACZ,UAAU;AAAA,EAAA;AAGZ,SACEC,2BAAAA;AAAAA,IAACC,SAAAA;AAAAA,IAAA;AAAA,MACC,eAAY;AAAA,MACZ;AAAA,MACA,iBAAe,WAAW,SAAS;AAAA,MACnC,IAAIC,QAAAA,QAAQ,QAAQ,EAAE;AAAA,MAErB,UAAA,MAAM,IAAI,CAAC,OAAO,MAAM;;AACvB,cAAM,WAAW,WAA6B,QAA7B,YAAoC;AACrD,eACEF,2BAAAA;AAAAA,UAACC,SAAAA;AAAAA,UAAA;AAAA,YAEC,yBAAqB;AAAA,YACrB,IAAIC,QAAAA,QAAQ,YAAY,MAAM;AAAA,YAE7B,UAAA;AAAA,UAAA;AAAA,UAJI;AAAA,QAAA;AAAA,MAOX,CAAC;AAAA,IAAA;AAAA,EAAA;AAGP;;;"}
@@ -0,0 +1,42 @@
1
+ import { default as React } from 'react';
2
+ import { SxProps, Theme } from '@mui/material';
3
+ export interface InputGroupProps {
4
+ children: React.ReactNode;
5
+ /**
6
+ * sx aplicado al contenedor raíz del grupo. Se mergea sobre los defaults.
7
+ */
8
+ sx?: SxProps<Theme>;
9
+ /**
10
+ * sx aplicado a cada slot individual. Útil para controlar flex/gap entre
11
+ * los hijos del grupo.
12
+ */
13
+ slotSx?: SxProps<Theme>;
14
+ /**
15
+ * Radio del borde del grupo. Default: 10.
16
+ */
17
+ borderRadius?: number | string;
18
+ /**
19
+ * Desactiva visualmente el grupo (no cascada lógica — los hijos deben
20
+ * manejar su propio `disabled`).
21
+ */
22
+ disabled?: boolean;
23
+ /**
24
+ * Orientación del grupo. Default: 'horizontal'.
25
+ */
26
+ orientation?: 'horizontal' | 'vertical';
27
+ className?: string;
28
+ }
29
+ /**
30
+ * Agrupa visualmente varios componentes de entrada (Input / Select / DatePicker /
31
+ * Button, etc.) compartiendo un solo borde y con separadores internos.
32
+ *
33
+ * El grupo respeta el espacio que Input/Select reservan para su label `outside`
34
+ * (`LABEL_MARGIN_TOP`) moviendo ese reservado al contenedor externo y
35
+ * cancelándolo en los hijos. Los labels siguen flotando por encima del borde
36
+ * del grupo con la misma animación que fuera del grupo.
37
+ *
38
+ * No inspecciona el tipo de cada hijo; aplica los overrides a través de
39
+ * descendant selectors por CSS para funcionar con cualquier wrapper / memoizado.
40
+ */
41
+ export declare const InputGroup: React.FC<InputGroupProps>;
42
+ export default InputGroup;
@@ -0,0 +1,6 @@
1
+ export declare const BasicInputGroupDefinition = "\nimport { useState } from 'react';\nimport { Box, Typography } from '@mui/material';\nimport InputGroup from './InputGroup';\nimport { Input } from '../Input';\nimport { Button } from '../Button';\n\nexport const BasicInputGroupExample = () => {\n const [text, setText] = useState('');\n return (\n <Box>\n <Typography variant=\"h6\" sx={{ mb: 2 }}>\n Grupo de entrada b\u00E1sico\n </Typography>\n <InputGroup>\n <Input label=\"Buscar\" value={text} onChange={(val) => setText(val as string)} />\n <Button variant=\"outlined\">Buscar</Button>\n </InputGroup>\n </Box>\n );\n};\n";
2
+ export declare const CombinedInputGroupDefinition = "\nimport { useState } from 'react';\nimport { Box, Typography } from '@mui/material';\nimport InputGroup from './InputGroup';\nimport { Input } from '../Input';\nimport Select, { SelectOption } from '../Select/Select';\nimport { Button } from '../Button';\n\nconst basicOptions: SelectOption[] = [\n { value: '10', label: '10' },\n { value: '25', label: '25' },\n { value: '50', label: '50' },\n { value: '100', label: '100' },\n];\n\nexport const CombinedInputGroupExample = () => {\n const [text, setText] = useState('');\n const [selectValue, setSelectValue] = useState('25');\n\n return (\n <Box>\n <Typography variant=\"h6\" sx={{ mb: 2 }}>\n Grupo de entrada combinado\n </Typography>\n <InputGroup>\n <Select\n label=\"Registros\"\n options={basicOptions}\n value={selectValue}\n onChange={(val) => setSelectValue(val as string)}\n />\n <Input\n label=\"Filtrar por nombre\"\n value={text}\n onChange={(val) => setText(val as string)}\n />\n <Button variant=\"contained\">Aplicar</Button>\n </InputGroup>\n </Box>\n );\n};\n";
3
+ export declare const DatePickerInputGroupDefinition = "\nimport { useState } from 'react';\nimport { Box, Typography } from '@mui/material';\nimport dayjs, { Dayjs } from 'dayjs';\nimport InputGroup from './InputGroup';\nimport { DatePicker } from '../DatePicker';\nimport { Button } from '../Button';\n\nexport const DatePickerInputGroupExample = () => {\n const [selectedDate, setSelectedDate] = useState<Dayjs | null>(dayjs());\n\n return (\n <Box>\n <Typography variant=\"h6\" sx={{ mb: 2 }}>\n Grupo de entrada con DatePicker\n </Typography>\n <InputGroup>\n <DatePicker\n label=\"Fecha de inicio\"\n selectedDate={selectedDate}\n onDateChange={(date) => setSelectedDate(date)}\n />\n <Button variant=\"contained\">Ver calendario</Button>\n </InputGroup>\n </Box>\n );\n};\n";
4
+ export declare const VerticalInputGroupDefinition = "\nimport { useState } from 'react';\nimport { Box } from '@mui/material';\nimport InputGroup from './InputGroup';\nimport { Input } from '../Input';\n\nexport const VerticalInputGroupExample = () => {\n const [nombre, setNombre] = useState('');\n const [email, setEmail] = useState('');\n\n return (\n <Box sx={{ width: 320 }}>\n <InputGroup orientation=\"vertical\">\n <Input label=\"Nombre\" value={nombre} onChange={(val) => setNombre(val as string)} />\n <Input label=\"Email\" value={email} onChange={(val) => setEmail(val as string)} />\n </InputGroup>\n </Box>\n );\n};\n";
5
+ export declare const CustomStylingInputGroupDefinition = "\nimport { useState } from 'react';\nimport { Box } from '@mui/material';\nimport InputGroup from './InputGroup';\nimport { Input } from '../Input';\nimport { Button } from '../Button';\n\nexport const CustomStylingInputGroupExample = () => {\n const [q, setQ] = useState('');\n\n return (\n <Box sx={{ width: 500 }}>\n <InputGroup\n borderRadius={999}\n sx={{\n bgcolor: 'action.hover',\n borderColor: 'primary.main',\n }}\n >\n <Input label=\"B\u00FAsqueda avanzada\" value={q} onChange={(val) => setQ(val as string)} />\n <Button variant=\"contained\" color=\"primary\">Buscar</Button>\n </InputGroup>\n </Box>\n );\n};\n";
6
+ export declare const DisabledInputGroupDefinition = "\nimport { Box } from '@mui/material';\nimport InputGroup from './InputGroup';\nimport { Input } from '../Input';\nimport { Button } from '../Button';\n\nexport const DisabledInputGroupExample = () => (\n <Box sx={{ width: 400 }}>\n <InputGroup disabled>\n <Input label=\"B\u00FAsqueda\" value=\"\" onChange={() => {}} disabled />\n <Button variant=\"outlined\" disabled>Buscar</Button>\n </InputGroup>\n </Box>\n);\n";
@@ -0,0 +1,140 @@
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
+ import { jsx } from "react/jsx-runtime";
21
+ import { Children, isValidElement } from "react";
22
+ import { Box } from "@mui/material";
23
+ import { m as mergeSx } from "../../mergeSx-BXoNZjB_.js";
24
+ import { L as LABEL_MARGIN_TOP } from "../../tokens-BRrcP_p_.js";
25
+ const InputGroup = ({
26
+ children,
27
+ sx,
28
+ slotSx,
29
+ borderRadius = 10,
30
+ disabled,
31
+ orientation = "horizontal",
32
+ className
33
+ }) => {
34
+ const radius = typeof borderRadius === "number" ? `${borderRadius}px` : borderRadius;
35
+ const slots = Children.toArray(children).filter(isValidElement);
36
+ const isHorizontal = orientation === "horizontal";
37
+ const baseSx = {
38
+ // Respeta el label "outside" de Input/Select: los hijos pierden su marginTop
39
+ // (ver más abajo) y el grupo reserva el mismo espacio arriba para que los
40
+ // labels floten por encima del borde del grupo.
41
+ marginTop: LABEL_MARGIN_TOP,
42
+ display: "flex",
43
+ flexDirection: isHorizontal ? "row" : "column",
44
+ alignItems: "stretch",
45
+ width: "100%",
46
+ border: (theme) => `1px solid ${theme.palette.divider}`,
47
+ borderRadius: radius,
48
+ backgroundColor: "background.paper",
49
+ transition: "border-color 200ms cubic-bezier(0.0, 0, 0.2, 1) 0ms, box-shadow 200ms cubic-bezier(0.0, 0, 0.2, 1) 0ms",
50
+ "&:focus-within": {
51
+ borderColor: "primary.main",
52
+ boxShadow: (theme) => `0 0 0 1px ${theme.palette.primary.main}`
53
+ },
54
+ opacity: disabled ? 0.6 : 1,
55
+ pointerEvents: disabled ? "none" : "auto",
56
+ // Cancelar el marginTop que Input/Select reservan en labelPosition="outside".
57
+ // El grupo ya lo reservó en su nivel externo.
58
+ "& .MuiFormControl-root, & > [data-input-group-slot] > .MuiTextField-root, & > [data-input-group-slot] > .MuiFormControl-root": {
59
+ marginTop: 0
60
+ },
61
+ // Quitar el borde del notched outline interno: el borde visible es el del
62
+ // grupo, los separadores son los borderRight/borderBottom de cada slot.
63
+ "& .MuiOutlinedInput-notchedOutline": {
64
+ border: "none"
65
+ },
66
+ // Forzar que todos los campos pinten sus esquinas cuadradas (las esquinas
67
+ // redondeadas se aplican solo al primer/último slot más abajo).
68
+ "& .MuiInputBase-root, & .MuiChip-root": {
69
+ borderRadius: 0
70
+ },
71
+ // Botones integrados: sin radius propio, altura completa, sin sombra.
72
+ "& .MuiButton-root": {
73
+ borderRadius: 0,
74
+ height: "100%",
75
+ boxShadow: "none",
76
+ border: "none"
77
+ },
78
+ // Slots: cada hijo vive en un slot neutro que lo centra verticalmente.
79
+ "& > [data-input-group-slot]": __spreadProps(__spreadValues({
80
+ flex: 1,
81
+ display: "flex",
82
+ alignItems: "center",
83
+ minWidth: 0
84
+ }, isHorizontal ? { borderRight: (theme) => `1px solid ${theme.palette.divider}` } : { borderBottom: (theme) => `1px solid ${theme.palette.divider}` }), {
85
+ "&:last-of-type": {
86
+ borderRight: "none",
87
+ borderBottom: "none"
88
+ }
89
+ }),
90
+ // Esquinas redondeadas: primer slot (izquierda o arriba).
91
+ "& > [data-input-group-slot]:first-of-type .MuiInputBase-root, & > [data-input-group-slot]:first-of-type .MuiButton-root, & > [data-input-group-slot]:first-of-type .MuiChip-root": isHorizontal ? {
92
+ borderTopLeftRadius: radius,
93
+ borderBottomLeftRadius: radius
94
+ } : {
95
+ borderTopLeftRadius: radius,
96
+ borderTopRightRadius: radius
97
+ },
98
+ // Esquinas redondeadas: último slot (derecha o abajo).
99
+ "& > [data-input-group-slot]:last-of-type .MuiInputBase-root, & > [data-input-group-slot]:last-of-type .MuiButton-root, & > [data-input-group-slot]:last-of-type .MuiChip-root": isHorizontal ? {
100
+ borderTopRightRadius: radius,
101
+ borderBottomRightRadius: radius
102
+ } : {
103
+ borderBottomLeftRadius: radius,
104
+ borderBottomRightRadius: radius
105
+ }
106
+ };
107
+ const baseSlotSx = {
108
+ flex: 1,
109
+ display: "flex",
110
+ alignItems: "center",
111
+ minWidth: 0
112
+ };
113
+ return /* @__PURE__ */ jsx(
114
+ Box,
115
+ {
116
+ "data-testid": "input-group",
117
+ className,
118
+ "aria-disabled": disabled ? "true" : void 0,
119
+ sx: mergeSx(baseSx, sx),
120
+ children: slots.map((child, i) => {
121
+ var _a;
122
+ const slotKey = (_a = child.key) != null ? _a : i;
123
+ return /* @__PURE__ */ jsx(
124
+ Box,
125
+ {
126
+ "data-input-group-slot": true,
127
+ sx: mergeSx(baseSlotSx, slotSx),
128
+ children: child
129
+ },
130
+ slotKey
131
+ );
132
+ })
133
+ }
134
+ );
135
+ };
136
+ export {
137
+ InputGroup,
138
+ InputGroup as default
139
+ };
140
+ //# sourceMappingURL=InputGroup.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"InputGroup.js","sources":["../../../src/components/InputGroup/InputGroup.tsx"],"sourcesContent":["import React, { Children, isValidElement } from 'react';\nimport { Box, type SxProps, type Theme } from '@mui/material';\n\nimport { mergeSx } from '../_shared/mergeSx';\nimport { LABEL_MARGIN_TOP } from '../../theme/tokens';\n\nexport interface InputGroupProps {\n children: React.ReactNode;\n /**\n * sx aplicado al contenedor raíz del grupo. Se mergea sobre los defaults.\n */\n sx?: SxProps<Theme>;\n /**\n * sx aplicado a cada slot individual. Útil para controlar flex/gap entre\n * los hijos del grupo.\n */\n slotSx?: SxProps<Theme>;\n /**\n * Radio del borde del grupo. Default: 10.\n */\n borderRadius?: number | string;\n /**\n * Desactiva visualmente el grupo (no cascada lógica — los hijos deben\n * manejar su propio `disabled`).\n */\n disabled?: boolean;\n /**\n * Orientación del grupo. Default: 'horizontal'.\n */\n orientation?: 'horizontal' | 'vertical';\n className?: string;\n}\n\n/**\n * Agrupa visualmente varios componentes de entrada (Input / Select / DatePicker /\n * Button, etc.) compartiendo un solo borde y con separadores internos.\n *\n * El grupo respeta el espacio que Input/Select reservan para su label `outside`\n * (`LABEL_MARGIN_TOP`) moviendo ese reservado al contenedor externo y\n * cancelándolo en los hijos. Los labels siguen flotando por encima del borde\n * del grupo con la misma animación que fuera del grupo.\n *\n * No inspecciona el tipo de cada hijo; aplica los overrides a través de\n * descendant selectors por CSS para funcionar con cualquier wrapper / memoizado.\n */\nexport const InputGroup: React.FC<InputGroupProps> = ({\n children,\n sx,\n slotSx,\n borderRadius = 10,\n disabled,\n orientation = 'horizontal',\n className,\n}) => {\n const radius = typeof borderRadius === 'number' ? `${borderRadius}px` : borderRadius;\n const slots = Children.toArray(children).filter(isValidElement);\n const isHorizontal = orientation === 'horizontal';\n\n const baseSx: SxProps<Theme> = {\n // Respeta el label \"outside\" de Input/Select: los hijos pierden su marginTop\n // (ver más abajo) y el grupo reserva el mismo espacio arriba para que los\n // labels floten por encima del borde del grupo.\n marginTop: LABEL_MARGIN_TOP,\n\n display: 'flex',\n flexDirection: isHorizontal ? 'row' : 'column',\n alignItems: 'stretch',\n width: '100%',\n border: (theme) => `1px solid ${theme.palette.divider}`,\n borderRadius: radius,\n backgroundColor: 'background.paper',\n transition:\n 'border-color 200ms cubic-bezier(0.0, 0, 0.2, 1) 0ms, box-shadow 200ms cubic-bezier(0.0, 0, 0.2, 1) 0ms',\n '&:focus-within': {\n borderColor: 'primary.main',\n boxShadow: (theme) => `0 0 0 1px ${theme.palette.primary.main}`,\n },\n opacity: disabled ? 0.6 : 1,\n pointerEvents: disabled ? 'none' : 'auto',\n\n // Cancelar el marginTop que Input/Select reservan en labelPosition=\"outside\".\n // El grupo ya lo reservó en su nivel externo.\n '& .MuiFormControl-root, & > [data-input-group-slot] > .MuiTextField-root, & > [data-input-group-slot] > .MuiFormControl-root':\n {\n marginTop: 0,\n },\n\n // Quitar el borde del notched outline interno: el borde visible es el del\n // grupo, los separadores son los borderRight/borderBottom de cada slot.\n '& .MuiOutlinedInput-notchedOutline': {\n border: 'none',\n },\n\n // Forzar que todos los campos pinten sus esquinas cuadradas (las esquinas\n // redondeadas se aplican solo al primer/último slot más abajo).\n '& .MuiInputBase-root, & .MuiChip-root': {\n borderRadius: 0,\n },\n\n // Botones integrados: sin radius propio, altura completa, sin sombra.\n '& .MuiButton-root': {\n borderRadius: 0,\n height: '100%',\n boxShadow: 'none',\n border: 'none',\n },\n\n // Slots: cada hijo vive en un slot neutro que lo centra verticalmente.\n '& > [data-input-group-slot]': {\n flex: 1,\n display: 'flex',\n alignItems: 'center',\n minWidth: 0,\n // Separador entre slots (horizontal: borderRight / vertical: borderBottom),\n // usando el color de divider del theme.\n ...(isHorizontal\n ? { borderRight: (theme: Theme) => `1px solid ${theme.palette.divider}` }\n : { borderBottom: (theme: Theme) => `1px solid ${theme.palette.divider}` }),\n '&:last-of-type': {\n borderRight: 'none',\n borderBottom: 'none',\n },\n },\n\n // Esquinas redondeadas: primer slot (izquierda o arriba).\n '& > [data-input-group-slot]:first-of-type .MuiInputBase-root, & > [data-input-group-slot]:first-of-type .MuiButton-root, & > [data-input-group-slot]:first-of-type .MuiChip-root':\n isHorizontal\n ? {\n borderTopLeftRadius: radius,\n borderBottomLeftRadius: radius,\n }\n : {\n borderTopLeftRadius: radius,\n borderTopRightRadius: radius,\n },\n\n // Esquinas redondeadas: último slot (derecha o abajo).\n '& > [data-input-group-slot]:last-of-type .MuiInputBase-root, & > [data-input-group-slot]:last-of-type .MuiButton-root, & > [data-input-group-slot]:last-of-type .MuiChip-root':\n isHorizontal\n ? {\n borderTopRightRadius: radius,\n borderBottomRightRadius: radius,\n }\n : {\n borderBottomLeftRadius: radius,\n borderBottomRightRadius: radius,\n },\n };\n\n const baseSlotSx: SxProps<Theme> = {\n flex: 1,\n display: 'flex',\n alignItems: 'center',\n minWidth: 0,\n };\n\n return (\n <Box\n data-testid=\"input-group\"\n className={className}\n aria-disabled={disabled ? 'true' : undefined}\n sx={mergeSx(baseSx, sx)}\n >\n {slots.map((child, i) => {\n const slotKey = (child as React.ReactElement).key ?? i;\n return (\n <Box\n key={slotKey}\n data-input-group-slot\n sx={mergeSx(baseSlotSx, slotSx)}\n >\n {child}\n </Box>\n );\n })}\n </Box>\n );\n};\n\nexport default InputGroup;\n"],"names":[],"mappings":";;;;;;;;;;;;;;;;;;;;;;;;AA6CO,MAAM,aAAwC,CAAC;AAAA,EACpD;AAAA,EACA;AAAA,EACA;AAAA,EACA,eAAe;AAAA,EACf;AAAA,EACA,cAAc;AAAA,EACd;AACF,MAAM;AACJ,QAAM,SAAS,OAAO,iBAAiB,WAAW,GAAG,YAAY,OAAO;AACxE,QAAM,QAAQ,SAAS,QAAQ,QAAQ,EAAE,OAAO,cAAc;AAC9D,QAAM,eAAe,gBAAgB;AAErC,QAAM,SAAyB;AAAA;AAAA;AAAA;AAAA,IAI7B,WAAW;AAAA,IAEX,SAAS;AAAA,IACT,eAAe,eAAe,QAAQ;AAAA,IACtC,YAAY;AAAA,IACZ,OAAO;AAAA,IACP,QAAQ,CAAC,UAAU,aAAa,MAAM,QAAQ,OAAO;AAAA,IACrD,cAAc;AAAA,IACd,iBAAiB;AAAA,IACjB,YACE;AAAA,IACF,kBAAkB;AAAA,MAChB,aAAa;AAAA,MACb,WAAW,CAAC,UAAU,aAAa,MAAM,QAAQ,QAAQ,IAAI;AAAA,IAAA;AAAA,IAE/D,SAAS,WAAW,MAAM;AAAA,IAC1B,eAAe,WAAW,SAAS;AAAA;AAAA;AAAA,IAInC,gIACE;AAAA,MACE,WAAW;AAAA,IAAA;AAAA;AAAA;AAAA,IAKf,sCAAsC;AAAA,MACpC,QAAQ;AAAA,IAAA;AAAA;AAAA;AAAA,IAKV,yCAAyC;AAAA,MACvC,cAAc;AAAA,IAAA;AAAA;AAAA,IAIhB,qBAAqB;AAAA,MACnB,cAAc;AAAA,MACd,QAAQ;AAAA,MACR,WAAW;AAAA,MACX,QAAQ;AAAA,IAAA;AAAA;AAAA,IAIV,+BAA+B;AAAA,MAC7B,MAAM;AAAA,MACN,SAAS;AAAA,MACT,YAAY;AAAA,MACZ,UAAU;AAAA,OAGN,eACA,EAAE,aAAa,CAAC,UAAiB,aAAa,MAAM,QAAQ,OAAO,OACnE,EAAE,cAAc,CAAC,UAAiB,aAAa,MAAM,QAAQ,OAAO,GAAA,IAT3C;AAAA,MAU7B,kBAAkB;AAAA,QAChB,aAAa;AAAA,QACb,cAAc;AAAA,MAAA;AAAA,IAChB;AAAA;AAAA,IAIF,oLACE,eACI;AAAA,MACE,qBAAqB;AAAA,MACrB,wBAAwB;AAAA,IAAA,IAE1B;AAAA,MACE,qBAAqB;AAAA,MACrB,sBAAsB;AAAA,IAAA;AAAA;AAAA,IAI9B,iLACE,eACI;AAAA,MACE,sBAAsB;AAAA,MACtB,yBAAyB;AAAA,IAAA,IAE3B;AAAA,MACE,wBAAwB;AAAA,MACxB,yBAAyB;AAAA,IAAA;AAAA,EAC3B;AAGR,QAAM,aAA6B;AAAA,IACjC,MAAM;AAAA,IACN,SAAS;AAAA,IACT,YAAY;AAAA,IACZ,UAAU;AAAA,EAAA;AAGZ,SACE;AAAA,IAAC;AAAA,IAAA;AAAA,MACC,eAAY;AAAA,MACZ;AAAA,MACA,iBAAe,WAAW,SAAS;AAAA,MACnC,IAAI,QAAQ,QAAQ,EAAE;AAAA,MAErB,UAAA,MAAM,IAAI,CAAC,OAAO,MAAM;;AACvB,cAAM,WAAW,WAA6B,QAA7B,YAAoC;AACrD,eACE;AAAA,UAAC;AAAA,UAAA;AAAA,YAEC,yBAAqB;AAAA,YACrB,IAAI,QAAQ,YAAY,MAAM;AAAA,YAE7B,UAAA;AAAA,UAAA;AAAA,UAJI;AAAA,QAAA;AAAA,MAOX,CAAC;AAAA,IAAA;AAAA,EAAA;AAGP;"}
@@ -0,0 +1,2 @@
1
+ export { InputGroup, default } from './InputGroup';
2
+ export type { InputGroupProps } from './InputGroup';
@@ -0,0 +1,6 @@
1
+ export * from './InputGroup/index'
2
+ export {}
3
+ import _default from './InputGroup/index'
4
+ export default _default
5
+ export * from './InputGroup/index'
6
+ export {}