@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
@@ -1,495 +0,0 @@
1
- import React, { Children, isValidElement, useState, useEffect, ReactElement } from 'react';
2
- import {
3
- TableContainer,
4
- Table as MuiTable,
5
- TableHead,
6
- TableBody,
7
- TableRow,
8
- TableCell,
9
- Paper,
10
- Typography,
11
- Select,
12
- MenuItem,
13
- Box,
14
- Button,
15
- Snackbar,
16
- IconButton,
17
- Checkbox,
18
- } from '@mui/material';
19
- import MuiAlert, { AlertProps } from '@mui/material/Alert';
20
- import { ColumnProps } from '../Column/Column'; // Asegúrate de que esta ruta sea correcta
21
- import DownloadOutlinedIcon from '@mui/icons-material/DownloadOutlined';
22
- import FirstPageIcon from '@mui/icons-material/FirstPage';
23
- import LastPageIcon from '@mui/icons-material/LastPage';
24
- import KeyboardArrowLeftIcon from '@mui/icons-material/KeyboardArrowLeft';
25
- import KeyboardArrowRightIcon from '@mui/icons-material/KeyboardArrowRight';
26
-
27
- import { exportToCSV, exportToExcel } from './exportsUtils';
28
-
29
- // @ts-ignore
30
- import EmptyImage from './EmptyTable.png';
31
-
32
- export type FieldName<T> = keyof T | Array<keyof T>;
33
-
34
- interface TableProps<T> {
35
- data: T[];
36
- children: React.ReactNode;
37
-
38
- currentPage?: number;
39
- pageSize?: number;
40
- totalPages?: number;
41
- previousPage?: number;
42
- nextPage?: number;
43
- pageSizeSelectorValue?: number;
44
- onPageChange?: (newPage: number) => void;
45
- onPageSizeChange?: (newSize: number) => void;
46
- visiblePageNumbers?: number;
47
-
48
- enableCSVExport?: boolean;
49
- csvExportFileName?: string;
50
- csvExportButtonText?: string;
51
- csvExportColumns?: string[];
52
-
53
- enableExcelExport?: boolean;
54
- excelExportFileName?: string;
55
- excelExportButtonText?: string;
56
- excelExportColumns?: string[];
57
-
58
- enableRowSelection?: boolean;
59
- rowIdentifier?: keyof T;
60
- onSelectionChange?: (selectedItems: T[]) => void;
61
- showPageSizeSelector?: boolean;
62
- emptyTitle?: string;
63
- emptyMessage?: string;
64
- emptyImageSrc?: React.ReactNode;
65
- }
66
-
67
- const Alert = React.forwardRef<HTMLDivElement, AlertProps>(function Alert(
68
- props,
69
- ref,
70
- ) {
71
- return <MuiAlert elevation={6} ref={ref} variant="filled" {...props} />;
72
- });
73
-
74
- export function Table<T>({
75
- data,
76
- children,
77
- currentPage,
78
- pageSize,
79
- totalPages,
80
- previousPage,
81
- nextPage,
82
- pageSizeSelectorValue = 10,
83
- onPageChange,
84
- onPageSizeChange,
85
- visiblePageNumbers = 5,
86
- enableCSVExport = false,
87
- csvExportFileName = 'data.csv',
88
- csvExportButtonText = 'Exportar CSV',
89
- csvExportColumns,
90
- enableExcelExport = false,
91
- excelExportFileName = 'data.xlsx',
92
- excelExportButtonText = 'Exportar Excel',
93
- excelExportColumns,
94
- enableRowSelection = false,
95
- rowIdentifier,
96
- onSelectionChange,
97
- showPageSizeSelector = true,
98
- emptyTitle = 'No hay datos disponibles',
99
- emptyMessage,
100
- emptyImageSrc = <Box mb={2}>
101
- <img src={EmptyImage} alt="No data" style={{ maxWidth: '150px', opacity: 0.6 }} />
102
- </Box>,
103
- }: TableProps<T>) {
104
- const columns = Children.toArray(children).filter(
105
- (child): child is React.ReactElement<ColumnProps<T>> =>
106
- isValidElement(child) && (child.type as any).displayName === 'Column'
107
- );
108
-
109
- const [snackbarOpen, setSnackbarOpen] = useState(false);
110
- const [snackbarMessage, setSnackbarMessage] = useState("");
111
- const [snackbarSeverity, setSnackbarSeverity] = useState<AlertProps['severity']>('info');
112
-
113
- const [selectedRows, setSelectedRows] = useState<T[]>([]);
114
-
115
- useEffect(() => {
116
- setSelectedRows([]);
117
- }, [data, currentPage, pageSize]);
118
-
119
- useEffect(() => {
120
- onSelectionChange?.(selectedRows);
121
- }, [selectedRows, onSelectionChange]);
122
-
123
- const handleSnackbarClose = (event?: React.SyntheticEvent | Event, reason?: string) => {
124
- if (reason === 'clickaway') {
125
- return;
126
- }
127
- setSnackbarOpen(false);
128
- };
129
-
130
- const isControlled = typeof onPageChange === 'function' && typeof currentPage === 'number';
131
- const [internalPage, setInternalPage] = useState(1);
132
- const [internalPageSize, setInternalPageSize] = useState(pageSizeSelectorValue);
133
-
134
- const activePage = isControlled ? currentPage! : internalPage;
135
- const activePageSize = isControlled ? pageSize! : internalPageSize;
136
-
137
- const paginatedData = isControlled ? data : data.slice((activePage - 1) * activePageSize, activePage * activePageSize);
138
-
139
- const effectiveTotalPages = isControlled
140
- ? totalPages!
141
- : Math.ceil(data.length / activePageSize);
142
-
143
- const handlePageChange = (newPage: number) => {
144
- if (newPage < 1 || newPage > effectiveTotalPages) return;
145
- if (isControlled) onPageChange?.(newPage);
146
- else setInternalPage(newPage);
147
- };
148
-
149
- const handlePageSizeChange = (newSize: number) => {
150
- if (isControlled) {
151
- onPageSizeChange?.(newSize);
152
- onPageChange?.(1);
153
- } else {
154
- setInternalPageSize(newSize);
155
- setInternalPage(1);
156
- }
157
- };
158
-
159
- const getPageNumbers = () => {
160
- const pages = [];
161
- const maxPages = effectiveTotalPages;
162
- const current = activePage;
163
- const half = Math.floor(visiblePageNumbers / 2);
164
-
165
- let startPage = Math.max(1, current - half);
166
- let endPage = Math.min(maxPages, current + half);
167
-
168
- if (endPage - startPage + 1 < visiblePageNumbers) {
169
- if (startPage === 1) {
170
- endPage = Math.min(maxPages, startPage + visiblePageNumbers - 1);
171
- } else if (endPage === maxPages) {
172
- startPage = Math.max(1, maxPages - visiblePageNumbers + 1);
173
- }
174
- }
175
-
176
- for (let i = startPage; i <= endPage; i++) {
177
- pages.push(i);
178
- }
179
- return pages;
180
- };
181
-
182
- const pageNumbers = getPageNumbers();
183
-
184
- const handleSelectAllClick = (event: React.ChangeEvent<HTMLInputElement>) => {
185
- if (!rowIdentifier) {
186
- console.warn("`rowIdentifier` prop is required for row selection.");
187
- return;
188
- }
189
-
190
- if (event.target.checked) {
191
- const newSelecteds = [...selectedRows];
192
- paginatedData.forEach(row => {
193
- const rowId = row[rowIdentifier] as any;
194
- if (!newSelecteds.some(selectedRow => (selectedRow as any)[rowIdentifier] === rowId)) {
195
- newSelecteds.push(row);
196
- }
197
- });
198
- setSelectedRows(newSelecteds);
199
- } else {
200
- const newSelecteds = selectedRows.filter(selectedRow =>
201
- !paginatedData.some(row => (row as any)[rowIdentifier] === (selectedRow as any)[rowIdentifier])
202
- );
203
- setSelectedRows(newSelecteds);
204
- }
205
- };
206
-
207
- const handleRowClick = (event: React.MouseEvent<unknown>, row: T) => {
208
- if (!rowIdentifier) {
209
- console.warn("`rowIdentifier` prop is required for row selection.");
210
- return;
211
- }
212
-
213
- const rowId = row[rowIdentifier] as any;
214
- const selectedIndex = selectedRows.findIndex(selectedRow => (selectedRow as any)[rowIdentifier] === rowId);
215
- let newSelected: T[] = [];
216
-
217
- if (selectedIndex === -1) {
218
- newSelected = newSelected.concat(selectedRows, row);
219
- } else if (selectedIndex === 0) {
220
- newSelected = newSelected.concat(selectedRows.slice(1));
221
- } else if (selectedIndex === selectedRows.length - 1) {
222
- newSelected = newSelected.concat(selectedRows.slice(0, -1));
223
- } else if (selectedIndex > 0) {
224
- newSelected = newSelected.concat(
225
- selectedRows.slice(0, selectedIndex),
226
- selectedRows.slice(selectedIndex + 1),
227
- );
228
- }
229
- setSelectedRows(newSelected);
230
- };
231
-
232
- const isSelected = (row: T) => {
233
- if (!rowIdentifier) return false;
234
- return selectedRows.some(selectedRow => (selectedRow as any)[rowIdentifier] === (row as any)[rowIdentifier]);
235
- };
236
-
237
- const numSelectedOnPage = paginatedData.filter(isSelected).length;
238
- const isAllSelectedOnPage = paginatedData.length > 0 && numSelectedOnPage === paginatedData.length;
239
- const isIndeterminateOnPage = numSelectedOnPage > 0 && numSelectedOnPage < paginatedData.length;
240
-
241
- return (
242
- <TableContainer >
243
-
244
- <MuiTable sx={{ minWidth: 650 }} aria-label="custom table" style={ paginatedData.length === 0 ? { display: 'none' } : {} }>
245
- {/* Table Header */}
246
- <TableHead sx={{ backgroundColor: '#fff' }}>
247
- <TableRow>
248
- {enableRowSelection && (
249
- <TableCell padding="checkbox" sx={{ width: '50px' }}> {/* Puedes ajustar este ancho fijo si lo deseas */}
250
- <Checkbox
251
- color="primary"
252
- indeterminate={isIndeterminateOnPage}
253
- checked={isAllSelectedOnPage}
254
- onChange={handleSelectAllClick}
255
- inputProps={{ 'aria-label': 'select all desserts' }}
256
- />
257
- </TableCell>
258
- )}
259
- {columns.map((column, index) => (
260
- <TableCell
261
- key={index}
262
- sx={{
263
-
264
- fontSize: '12px',
265
- color: (theme) => theme.palette.text.secondary,
266
- width: column.props.width || 'auto', // APLICA EL ANCHO AQUÍ
267
- whiteSpace: 'nowrap', // Evita que el texto se ajuste si la columna es pequeña
268
-
269
- }}
270
- >
271
- <Typography sx={{ fontSize: '12px' }}>
272
- {column.props.name}
273
- </Typography>
274
- </TableCell>
275
- ))}
276
- </TableRow>
277
- </TableHead>
278
- {/* Table Body */}
279
- <TableBody sx={{ borderRadius: '10px', overflow: 'hidden' }}>
280
- {paginatedData.map((row, rowIndex) => {
281
- const isRowSelected = enableRowSelection && isSelected(row);
282
- return (
283
- <TableRow
284
- key={rowIndex}
285
- sx={{ backgroundColor: '#F8F8F8', '&:last-child td, &:last-child th': { border: 0 }, '&:hover': { backgroundColor: (theme) => '#FFF' } }}
286
- selected={isRowSelected}
287
- >
288
- {enableRowSelection && (
289
- <TableCell padding="checkbox" sx={{ width: '50px' }}> {/* Mismo ancho para la celda de la fila */}
290
- <Checkbox
291
- color="primary"
292
- checked={isRowSelected}
293
- onClick={(event) => handleRowClick(event, row)}
294
- inputProps={{ 'aria-labelledby': `table-checkbox-${rowIndex}` }}
295
- />
296
- </TableCell>
297
- )}
298
- {columns.map((column, colIndex) => {
299
- const { field, children: cellRenderer } = column.props;
300
-
301
- let fieldData: Partial<T>;
302
-
303
- if (Array.isArray(field)) {
304
- if(field.length === 0){
305
- fieldData = {...row};
306
- }else{
307
- fieldData = (field as Array<keyof T>).reduce((acc, currentField) => {
308
- (acc as any)[currentField] = (row as any)[currentField];
309
- return acc;
310
- }, {} as Partial<T>);
311
- }
312
-
313
- } else {
314
- fieldData = { [field]: (row as any)[field] } as Partial<T>;
315
- }
316
-
317
- return (
318
- <TableCell
319
- key={colIndex}
320
- sx={{
321
- fontSize: '14px',
322
- width: column.props.width || 'auto', // APLICA EL ANCHO AQUÍ TAMBIÉN
323
- whiteSpace: 'nowrap', // Asegura que el contenido no se rompa prematuramente
324
- padding: '12px 16px', // Asegura un padding consistente
325
- borderBottom: 'none'
326
- }}
327
- >
328
- {cellRenderer(fieldData)}
329
- </TableCell>
330
- );
331
- })}
332
- </TableRow>
333
- );
334
- })}
335
- {/* Empty table message */}
336
-
337
- </TableBody>
338
- </MuiTable>
339
-
340
- { paginatedData.length === 0 && (
341
- <Box display="flex" flexDirection="column" alignItems="center" justifyContent="center" p={4} >
342
- { emptyImageSrc }
343
-
344
- <Typography variant="body2" color="#878E9A" fontSize="18px" fontWeight="600">
345
- {emptyTitle || 'No hay datos disponibles para mostrar.'}
346
- </Typography>
347
- <Typography variant="body2" color="#878E9A" fontSize="14px" mt={1}>
348
- {emptyMessage || 'Intente ajustar sus filtros o agregar nuevos datos.'}
349
- </Typography>
350
-
351
- </Box>
352
- )
353
- }
354
-
355
- {/* Pagination and Export Controls */}
356
- {(effectiveTotalPages > 0 || enableCSVExport || enableExcelExport || (enableRowSelection && selectedRows.length > 0)) && (
357
- <Box display="flex" justifyContent="space-between" alignItems="center" p={2}>
358
- {/* Page Size Selector (Left) */}
359
- {(effectiveTotalPages > 0 && showPageSizeSelector) && (
360
- <Select
361
- size="small"
362
- value={activePageSize}
363
- onChange={(e) => handlePageSizeChange(Number(e.target.value))}
364
- >
365
- {[1, 2, 3, 5, 10, 20, 50, 100].map((size) => (
366
- <MenuItem key={size} value={size}>
367
- Mostrar {size}
368
- </MenuItem>
369
- ))}
370
- </Select>
371
- )}
372
-
373
- {/* Pagination Controls (Center) */}
374
- {effectiveTotalPages > 0 && (
375
- <Box
376
- display="flex"
377
- alignItems="center"
378
- gap={0.5}
379
- sx={{ flexGrow: 1, justifyContent: 'center' }}
380
- >
381
- <IconButton
382
- onClick={() => handlePageChange(1)}
383
- disabled={activePage <= 1}
384
- size="small"
385
- color="primary"
386
- >
387
- <FirstPageIcon fontSize="small" />
388
- </IconButton>
389
-
390
- <IconButton
391
- onClick={() => handlePageChange(activePage - 1)}
392
- disabled={activePage <= 1}
393
- size="small"
394
- color="primary"
395
- >
396
- <KeyboardArrowLeftIcon fontSize="small" />
397
- </IconButton>
398
-
399
- {pageNumbers.map((pageNumber) => (
400
- <Button
401
- key={pageNumber}
402
- onClick={() => handlePageChange(pageNumber)}
403
- variant={activePage === pageNumber ? 'contained' : 'text'}
404
- size="small"
405
- sx={{ minWidth: '32px', height: '32px' }}
406
- >
407
- {pageNumber}
408
- </Button>
409
- ))}
410
-
411
- <IconButton
412
- onClick={() => handlePageChange(activePage + 1)}
413
- disabled={activePage >= effectiveTotalPages}
414
- size="small"
415
- color="primary"
416
- >
417
- <KeyboardArrowRightIcon fontSize="small" />
418
- </IconButton>
419
-
420
- <IconButton
421
- onClick={() => handlePageChange(effectiveTotalPages)}
422
- disabled={activePage >= effectiveTotalPages}
423
- size="small"
424
- color="primary"
425
- >
426
- <LastPageIcon fontSize="small" />
427
- </IconButton>
428
- </Box>
429
- )}
430
-
431
- {enableRowSelection && selectedRows.length > 0 && (
432
- <Typography variant="subtitle2" sx={{ mr: 2 }}>
433
- {selectedRows.length} seleccionados
434
- </Typography>
435
- )}
436
-
437
- {(enableCSVExport || enableExcelExport) && (
438
- <Box display="flex" alignItems="center" gap={1}>
439
- {enableCSVExport && (
440
- <Button
441
- variant="text"
442
- color="primary"
443
- onClick={() =>
444
- exportToCSV({
445
- data,
446
- columns,
447
- fileName: csvExportFileName,
448
- exportColumns: csvExportColumns,
449
- setSnackbarOpen,
450
- setSnackbarMessage,
451
- setSnackbarSeverity,
452
- })
453
- }
454
- size="small"
455
- startIcon={<DownloadOutlinedIcon />}
456
- >
457
- {csvExportButtonText}
458
- </Button>
459
- )}
460
- {enableExcelExport && (
461
- <Button
462
- variant="text"
463
- color="primary"
464
- onClick={() =>
465
- exportToExcel({
466
- data,
467
- columns,
468
- fileName: excelExportFileName,
469
- exportColumns: excelExportColumns,
470
- setSnackbarOpen,
471
- setSnackbarMessage,
472
- setSnackbarSeverity,
473
- })
474
- }
475
- size="small"
476
- startIcon={<DownloadOutlinedIcon />}
477
- >
478
- {excelExportButtonText}
479
- </Button>
480
- )}
481
- </Box>
482
- )}
483
- </Box>
484
- )}
485
-
486
- <Snackbar open={snackbarOpen} autoHideDuration={3000} onClose={handleSnackbarClose} anchorOrigin={{ vertical: 'bottom', horizontal: 'center' }}>
487
- <Alert onClose={handleSnackbarClose} severity={snackbarSeverity} sx={{ width: '100%' }}>
488
- {snackbarMessage}
489
- </Alert>
490
- </Snackbar>
491
- </TableContainer>
492
- );
493
- }
494
-
495
- export default Table;
@@ -1,134 +0,0 @@
1
- // Datos de ejemplo
2
- export const usuarios: Usuario[] = [
3
- {
4
- id: 1,
5
- nombre: 'Juan Pérez',
6
- email: 'juan@example.com',
7
- avatar: 'https://placehold.co/50x50/F0F8FF/333333?text=JP', // Placeholder para avatar
8
- edad: 25,
9
- activo: true,
10
- rol: 'admin',
11
- fechaRegistro: '2023-01-15',
12
- puntuacion: 4.5
13
- },
14
- {
15
- id: 2,
16
- nombre: 'Ana García',
17
- email: 'ana@example.com',
18
- avatar: 'https://placehold.co/50x50/FFF0F5/333333?text=AG', // Placeholder para avatar
19
- edad: 30,
20
- activo: false,
21
- rol: 'usuario',
22
- fechaRegistro: '2023-02-20',
23
- puntuacion: 3.8
24
- },
25
- {
26
- id: 3,
27
- nombre: 'Carlos López',
28
- email: 'carlos@example.com',
29
- avatar: 'https://placehold.co/50x50/F5FFFA/333333?text=CL', // Placeholder para avatar
30
- edad: 28,
31
- activo: true,
32
- rol: 'moderador',
33
- fechaRegistro: '2023-03-10',
34
- puntuacion: 4.2
35
- },
36
- {
37
- id: 4,
38
- nombre: 'María Rodríguez',
39
- email: 'maria@example.com',
40
- avatar: 'https://placehold.co/50x50/F8F8FF/333333?text=MR', // Placeholder para avatar
41
- edad: 35,
42
- activo: true,
43
- rol: 'usuario',
44
- fechaRegistro: '2023-04-05',
45
- puntuacion: 4.9
46
- },
47
- {
48
- id: 5,
49
- nombre: 'Luis Martínez',
50
- email: 'luis@example.com',
51
- avatar: 'https://placehold.co/50x50/E6E6FA/333333?text=LM', // Placeholder para avatar
52
- edad: 22,
53
- activo: false,
54
- rol: 'usuario',
55
- fechaRegistro: '2023-05-12',
56
- puntuacion: 3.2
57
- }
58
- ]
59
-
60
- export const productos:Producto[] = [
61
- {
62
- id: 1,
63
- nombre: 'iPhone 15',
64
- precio: 999,
65
- categoria: 'Electrónicos',
66
- stock: 15,
67
- imagen: 'https://placehold.co/60x60/ADD8E6/000000?text=I15', // Placeholder para imagen
68
- enOferta: true,
69
- rating: 4.8
70
- },
71
- {
72
- id: 2,
73
- nombre: 'Samsung Galaxy S24',
74
- precio: 899,
75
- categoria: 'Electrónicos',
76
- stock: 8,
77
- imagen: 'https://placehold.co/60x60/90EE90/000000?text=S24', // Placeholder para imagen
78
- enOferta: false,
79
- rating: 4.6
80
- },
81
- {
82
- id: 3,
83
- nombre: 'MacBook Pro',
84
- precio: 1999,
85
- categoria: 'Computadoras',
86
- stock: 3,
87
- imagen: 'https://placehold.co/60x60/DDA0DD/000000?text=MBP', // Placeholder para imagen
88
- enOferta: true,
89
- rating: 4.9
90
- },
91
- {
92
- id: 4,
93
- nombre: 'Dell XPS 13',
94
- precio: 1299,
95
- categoria: 'Computadoras',
96
- stock: 0,
97
- imagen: 'https://placehold.co/60x60/FFB6C1/000000?text=DX13', // Placeholder para imagen
98
- enOferta: false,
99
- rating: 4.4
100
- }
101
- ]
102
-
103
- export const empleados:Empleado[] = [
104
- {
105
- id: 1,
106
- nombre: 'Roberto',
107
- apellido: 'Silva',
108
- departamento: 'Desarrollo',
109
- salario: 75000,
110
- fechaIngreso: '2022-01-15',
111
- activo: true,
112
- avatar: 'https://placehold.co/50x50/B0E0E6/000000?text=RS' // Placeholder para avatar
113
- },
114
- {
115
- id: 2,
116
- nombre: 'Sofía',
117
- apellido: 'Herrera',
118
- departamento: 'Diseño',
119
- salario: 65000,
120
- fechaIngreso: '2022-03-20',
121
- activo: true,
122
- avatar: 'https://placehold.co/50x50/F5DEB3/000000?text=SH' // Placeholder para avatar
123
- },
124
- {
125
- id: 3,
126
- nombre: 'Diego',
127
- apellido: 'Morales',
128
- departamento: 'Marketing',
129
- salario: 55000,
130
- fechaIngreso: '2021-11-10',
131
- activo: false,
132
- avatar: 'https://placehold.co/50x50/D8BFD8/000000?text=DM' // Placeholder para avatar
133
- }
134
- ]