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

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (359) hide show
  1. package/Alert-B3SMPD1s.cjs +31 -0
  2. package/Alert-B3SMPD1s.cjs.map +1 -0
  3. package/Alert-YsPScpSE.js +32 -0
  4. package/Alert-YsPScpSE.js.map +1 -0
  5. package/Autocomplete-C_lW1VER.js +337 -0
  6. package/Autocomplete-C_lW1VER.js.map +1 -0
  7. package/Autocomplete-CejWztBY.cjs +336 -0
  8. package/Autocomplete-CejWztBY.cjs.map +1 -0
  9. package/Avatar-Dw5rzayR.cjs +166 -0
  10. package/Avatar-Dw5rzayR.cjs.map +1 -0
  11. package/Avatar-H8akSege.js +167 -0
  12. package/Avatar-H8akSege.js.map +1 -0
  13. package/Button-C17mExpd.cjs.map +1 -1
  14. package/Button-UkkP-bNw.js.map +1 -1
  15. package/Card-DYKGY-NG.js +116 -0
  16. package/Card-DYKGY-NG.js.map +1 -0
  17. package/Card-Dr1-ATRY.cjs +115 -0
  18. package/Card-Dr1-ATRY.cjs.map +1 -0
  19. package/Checkbox-BCqMFWt4.cjs +187 -0
  20. package/Checkbox-BCqMFWt4.cjs.map +1 -0
  21. package/Checkbox-gB5YKkVo.js +188 -0
  22. package/Checkbox-gB5YKkVo.js.map +1 -0
  23. package/{components/DateRangePicker/DateRangePicker.js → Chip-OPYQ1uQ_.js} +33 -35
  24. package/Chip-OPYQ1uQ_.js.map +1 -0
  25. package/{components/DateRangePicker/DateRangePicker.cjs → Chip-qoJLDiva.cjs} +33 -36
  26. package/Chip-qoJLDiva.cjs.map +1 -0
  27. package/DatePicker-_IGWc3I5.js +178 -0
  28. package/DatePicker-_IGWc3I5.js.map +1 -0
  29. package/DatePicker-t7uDTZMl.cjs +177 -0
  30. package/DatePicker-t7uDTZMl.cjs.map +1 -0
  31. package/DateTimePicker-BxQyjTCY.cjs +229 -0
  32. package/DateTimePicker-BxQyjTCY.cjs.map +1 -0
  33. package/DateTimePicker-CrmWav_j.js +230 -0
  34. package/DateTimePicker-CrmWav_j.js.map +1 -0
  35. package/Input-CScC87J5.cjs +185 -0
  36. package/Input-CScC87J5.cjs.map +1 -0
  37. package/Input-DP_fKl38.js +186 -0
  38. package/Input-DP_fKl38.js.map +1 -0
  39. package/Modal-BFpX5AFV.js +347 -0
  40. package/Modal-BFpX5AFV.js.map +1 -0
  41. package/Modal-CkpuI8ns.cjs +346 -0
  42. package/Modal-CkpuI8ns.cjs.map +1 -0
  43. package/RadioGroup-Dd0rHXSX.cjs +202 -0
  44. package/RadioGroup-Dd0rHXSX.cjs.map +1 -0
  45. package/RadioGroup-bO-ahP9T.js +203 -0
  46. package/RadioGroup-bO-ahP9T.js.map +1 -0
  47. package/Select-BY5Y0qZ1.js +376 -0
  48. package/Select-BY5Y0qZ1.js.map +1 -0
  49. package/Select-CURrHSyl.cjs +375 -0
  50. package/Select-CURrHSyl.cjs.map +1 -0
  51. package/Spinner-B6sThC1p.js +74 -0
  52. package/Spinner-B6sThC1p.js.map +1 -0
  53. package/Spinner-D7qRmNS9.cjs +73 -0
  54. package/Spinner-D7qRmNS9.cjs.map +1 -0
  55. package/Stat-BUcFCGrz.cjs +83 -0
  56. package/Stat-BUcFCGrz.cjs.map +1 -0
  57. package/Stat-C06A_izS.js +84 -0
  58. package/Stat-C06A_izS.js.map +1 -0
  59. package/StatusMessage-B3nXpuRl.cjs +88 -0
  60. package/StatusMessage-B3nXpuRl.cjs.map +1 -0
  61. package/StatusMessage-D0WgSBx7.js +89 -0
  62. package/StatusMessage-D0WgSBx7.js.map +1 -0
  63. package/Step-BArsou1V.js +301 -0
  64. package/Step-BArsou1V.js.map +1 -0
  65. package/Step-Nd7SJbRZ.cjs +300 -0
  66. package/Step-Nd7SJbRZ.cjs.map +1 -0
  67. package/Switch-CQFOopYy.cjs +182 -0
  68. package/Switch-CQFOopYy.cjs.map +1 -0
  69. package/Switch-D72dpkH2.js +183 -0
  70. package/Switch-D72dpkH2.js.map +1 -0
  71. package/Tab-BbP8jBcK.cjs +110 -0
  72. package/Tab-BbP8jBcK.cjs.map +1 -0
  73. package/Tab-BxSxKJsP.js +111 -0
  74. package/Tab-BxSxKJsP.js.map +1 -0
  75. package/Table-C2LbW0B1.js +531 -0
  76. package/Table-C2LbW0B1.js.map +1 -0
  77. package/Table-C4OM6rrC.cjs +530 -0
  78. package/Table-C4OM6rrC.cjs.map +1 -0
  79. package/components/ActionMenu/ActionMenu.cjs +52 -52
  80. package/components/ActionMenu/ActionMenu.cjs.map +1 -1
  81. package/components/ActionMenu/ActionMenu.d.ts +20 -36
  82. package/components/ActionMenu/ActionMenu.js +55 -55
  83. package/components/ActionMenu/ActionMenu.js.map +1 -1
  84. package/components/ActionMenu/index.d.ts +2 -2
  85. package/components/Alert/Alert.cjs +6 -0
  86. package/components/Alert/Alert.cjs.map +1 -0
  87. package/components/Alert/Alert.d.ts +31 -0
  88. package/components/Alert/Alert.js +6 -0
  89. package/components/Alert/Alert.js.map +1 -0
  90. package/components/Alert/index.d.ts +2 -0
  91. package/components/Alert.d.ts +6 -0
  92. package/components/AppBar/AppBar.cjs +3 -220
  93. package/components/AppBar/AppBar.cjs.map +1 -1
  94. package/components/AppBar/AppBar.d.ts +6 -6
  95. package/components/AppBar/AppBar.js +6 -223
  96. package/components/AppBar/AppBar.js.map +1 -1
  97. package/components/AppBar/index.d.ts +0 -6
  98. package/components/Autocomplete/Autocomplete.cjs +4 -311
  99. package/components/Autocomplete/Autocomplete.cjs.map +1 -1
  100. package/components/Autocomplete/Autocomplete.d.ts +8 -6
  101. package/components/Autocomplete/Autocomplete.helpers.d.ts +8 -4
  102. package/components/Autocomplete/Autocomplete.js +4 -311
  103. package/components/Autocomplete/Autocomplete.js.map +1 -1
  104. package/components/Autocomplete/_parts/AutocompleteOption.d.ts +5 -8
  105. package/components/Autocomplete/index.d.ts +1 -1
  106. package/components/Avatar/Avatar.cjs +2 -160
  107. package/components/Avatar/Avatar.cjs.map +1 -1
  108. package/components/Avatar/Avatar.d.ts +16 -1
  109. package/components/Avatar/Avatar.js +2 -160
  110. package/components/Avatar/Avatar.js.map +1 -1
  111. package/components/Avatar/index.d.ts +1 -0
  112. package/components/Button/Button.d.ts +5 -5
  113. package/components/Button/index.d.ts +1 -0
  114. package/components/Card/Card.cjs +4 -184
  115. package/components/Card/Card.cjs.map +1 -1
  116. package/components/Card/Card.d.ts +21 -50
  117. package/components/Card/Card.js +4 -184
  118. package/components/Card/Card.js.map +1 -1
  119. package/components/Card/Card.sx.d.ts +3 -6
  120. package/components/Card/index.d.ts +1 -1
  121. package/components/Checkbox/Checkbox.cjs +6 -0
  122. package/components/Checkbox/Checkbox.cjs.map +1 -0
  123. package/components/Checkbox/Checkbox.d.ts +55 -0
  124. package/components/Checkbox/Checkbox.js +6 -0
  125. package/components/Checkbox/Checkbox.js.map +1 -0
  126. package/components/Checkbox/Checkbox.sx.d.ts +13 -0
  127. package/components/Checkbox/index.d.ts +2 -0
  128. package/components/Checkbox.d.ts +6 -0
  129. package/components/Chip/Chip.cjs +4 -72
  130. package/components/Chip/Chip.cjs.map +1 -1
  131. package/components/Chip/Chip.js +3 -71
  132. package/components/Chip/Chip.js.map +1 -1
  133. package/components/Chip/index.d.ts +2 -1
  134. package/components/Chip.d.ts +4 -0
  135. package/components/Column/Column.cjs +1 -1
  136. package/components/Column/Column.cjs.map +1 -1
  137. package/components/Column/Column.d.ts +1 -1
  138. package/components/Column/Column.js +1 -1
  139. package/components/Column/Column.js.map +1 -1
  140. package/components/Column/index.d.ts +1 -0
  141. package/components/DatePicker/DatePicker.cjs +3 -200
  142. package/components/DatePicker/DatePicker.cjs.map +1 -1
  143. package/components/DatePicker/DatePicker.d.ts +1 -13
  144. package/components/DatePicker/DatePicker.js +3 -200
  145. package/components/DatePicker/DatePicker.js.map +1 -1
  146. package/components/DatePicker/index.d.ts +1 -1
  147. package/components/DateTimePicker/DateTimePicker.cjs +3 -219
  148. package/components/DateTimePicker/DateTimePicker.cjs.map +1 -1
  149. package/components/DateTimePicker/DateTimePicker.d.ts +10 -6
  150. package/components/DateTimePicker/DateTimePicker.definitions.d.ts +2 -0
  151. package/components/DateTimePicker/DateTimePicker.helpers.d.ts +4 -2
  152. package/components/DateTimePicker/DateTimePicker.js +3 -219
  153. package/components/DateTimePicker/DateTimePicker.js.map +1 -1
  154. package/components/DateTimePicker/index.d.ts +1 -1
  155. package/components/Drawer/Drawer.cjs +25 -24
  156. package/components/Drawer/Drawer.cjs.map +1 -1
  157. package/components/Drawer/Drawer.d.ts +8 -1
  158. package/components/Drawer/Drawer.js +26 -25
  159. package/components/Drawer/Drawer.js.map +1 -1
  160. package/components/Drawer/DrawerItem.d.ts +6 -1
  161. package/components/Gallery/Gallery.cjs +154 -79
  162. package/components/Gallery/Gallery.cjs.map +1 -1
  163. package/components/Gallery/Gallery.d.ts +25 -9
  164. package/components/Gallery/Gallery.js +154 -79
  165. package/components/Gallery/Gallery.js.map +1 -1
  166. package/components/Gallery/GalleryLightbox.d.ts +6 -10
  167. package/components/Gallery/GalleryMain.d.ts +3 -7
  168. package/components/Gallery/GalleryThumbnails.d.ts +7 -11
  169. package/components/Gallery/index.d.ts +2 -1
  170. package/components/Gallery.d.ts +4 -0
  171. package/components/Icon/Icon.cjs +6 -8
  172. package/components/Icon/Icon.cjs.map +1 -1
  173. package/components/Icon/Icon.d.ts +11 -17
  174. package/components/Icon/Icon.js +6 -8
  175. package/components/Icon/Icon.js.map +1 -1
  176. package/components/Icon/index.d.ts +2 -1
  177. package/components/Icon.d.ts +4 -0
  178. package/components/Input/Input.cjs +3 -172
  179. package/components/Input/Input.cjs.map +1 -1
  180. package/components/Input/Input.d.ts +9 -2
  181. package/components/Input/Input.definitions.d.ts +1 -0
  182. package/components/Input/Input.helpers.d.ts +3 -3
  183. package/components/Input/Input.js +3 -172
  184. package/components/Input/Input.js.map +1 -1
  185. package/components/Input/index.d.ts +1 -1
  186. package/components/InputGroup/InputGroup.cjs +23 -22
  187. package/components/InputGroup/InputGroup.cjs.map +1 -1
  188. package/components/InputGroup/InputGroup.d.ts +4 -4
  189. package/components/InputGroup/InputGroup.js +22 -21
  190. package/components/InputGroup/InputGroup.js.map +1 -1
  191. package/components/InputGroup/index.d.ts +2 -1
  192. package/components/InputGroup.d.ts +4 -0
  193. package/components/Modal/Modal.cjs +7 -317
  194. package/components/Modal/Modal.cjs.map +1 -1
  195. package/components/Modal/Modal.d.ts +20 -5
  196. package/components/Modal/Modal.js +6 -316
  197. package/components/Modal/Modal.js.map +1 -1
  198. package/components/Modal/ModalBody.d.ts +6 -1
  199. package/components/Modal/ModalFooter.d.ts +4 -4
  200. package/components/Modal/ModalHeader.d.ts +6 -1
  201. package/components/Modal/index.d.ts +3 -1
  202. package/components/Modal.d.ts +4 -0
  203. package/components/RadioGroup/RadioGroup.cjs +6 -0
  204. package/components/RadioGroup/RadioGroup.cjs.map +1 -0
  205. package/components/RadioGroup/RadioGroup.d.ts +59 -0
  206. package/components/RadioGroup/RadioGroup.definitions.d.ts +6 -0
  207. package/components/RadioGroup/RadioGroup.js +6 -0
  208. package/components/RadioGroup/RadioGroup.js.map +1 -0
  209. package/components/RadioGroup/RadioGroup.sx.d.ts +20 -0
  210. package/components/RadioGroup/index.d.ts +2 -0
  211. package/components/RadioGroup.d.ts +6 -0
  212. package/components/Select/Select.cjs +4 -445
  213. package/components/Select/Select.cjs.map +1 -1
  214. package/components/Select/Select.d.ts +37 -18
  215. package/components/Select/Select.helpers.d.ts +5 -19
  216. package/components/Select/Select.js +4 -445
  217. package/components/Select/Select.js.map +1 -1
  218. package/components/Select/index.d.ts +1 -1
  219. package/components/Spinner/Spinner.cjs +6 -0
  220. package/components/Spinner/Spinner.cjs.map +1 -0
  221. package/components/Spinner/Spinner.d.ts +26 -0
  222. package/components/Spinner/Spinner.js +6 -0
  223. package/components/Spinner/Spinner.js.map +1 -0
  224. package/components/Spinner/index.d.ts +2 -0
  225. package/components/Spinner.d.ts +6 -0
  226. package/components/Stat/Stat.cjs +4 -83
  227. package/components/Stat/Stat.cjs.map +1 -1
  228. package/components/Stat/Stat.js +3 -82
  229. package/components/Stat/Stat.js.map +1 -1
  230. package/components/Stat/index.d.ts +2 -1
  231. package/components/Stat.d.ts +4 -0
  232. package/components/StatusMessage/StatusMessage.cjs +4 -77
  233. package/components/StatusMessage/StatusMessage.cjs.map +1 -1
  234. package/components/StatusMessage/StatusMessage.d.ts +20 -36
  235. package/components/StatusMessage/StatusMessage.js +3 -76
  236. package/components/StatusMessage/StatusMessage.js.map +1 -1
  237. package/components/StatusMessage/index.d.ts +2 -1
  238. package/components/StatusMessage.d.ts +4 -0
  239. package/components/Stepper/Stepper.cjs +8 -47
  240. package/components/Stepper/Stepper.cjs.map +1 -1
  241. package/components/Stepper/Stepper.d.ts +9 -8
  242. package/components/Stepper/Stepper.js +7 -46
  243. package/components/Stepper/Stepper.js.map +1 -1
  244. package/{hooks/Wizard/WizardContext.d.ts → components/Stepper/StepperContext.d.ts} +29 -23
  245. package/components/Stepper/_hooks/useHorizontalScroll.d.ts +19 -0
  246. package/components/Stepper/_parts/StepperScrollArrow.d.ts +19 -0
  247. package/components/Stepper/index.d.ts +6 -2
  248. package/components/Stepper.d.ts +4 -0
  249. package/components/Switch/Switch.cjs +6 -0
  250. package/components/Switch/Switch.cjs.map +1 -0
  251. package/components/Switch/Switch.d.ts +48 -0
  252. package/components/Switch/Switch.definitions.d.ts +7 -0
  253. package/components/Switch/Switch.js +6 -0
  254. package/components/Switch/Switch.js.map +1 -0
  255. package/components/Switch/Switch.sx.d.ts +22 -0
  256. package/components/Switch/Switch.types.d.ts +1 -0
  257. package/components/Switch/index.d.ts +2 -0
  258. package/components/Switch.d.ts +6 -0
  259. package/components/Table/Table.cjs +2 -528
  260. package/components/Table/Table.cjs.map +1 -1
  261. package/components/Table/Table.d.ts +1 -1
  262. package/components/Table/Table.js +2 -528
  263. package/components/Table/Table.js.map +1 -1
  264. package/components/Tabs/Tabs.cjs +5 -94
  265. package/components/Tabs/Tabs.cjs.map +1 -1
  266. package/components/Tabs/Tabs.d.ts +21 -16
  267. package/components/Tabs/Tabs.js +4 -93
  268. package/components/Tabs/Tabs.js.map +1 -1
  269. package/components/Tabs/index.d.ts +4 -2
  270. package/components/Tabs.d.ts +4 -0
  271. package/components/Timeline/Timeline.cjs +3 -2
  272. package/components/Timeline/Timeline.cjs.map +1 -1
  273. package/components/Timeline/Timeline.d.ts +4 -8
  274. package/components/Timeline/Timeline.js +3 -2
  275. package/components/Timeline/Timeline.js.map +1 -1
  276. package/components/Timeline/index.d.ts +4 -2
  277. package/components/Timeline.d.ts +4 -0
  278. package/components/_shared/mergeSx.d.ts +7 -0
  279. package/{formField.sx-DfVbMe0V.js → formField.sx-8_QRnKxv.js} +2 -11
  280. package/formField.sx-8_QRnKxv.js.map +1 -0
  281. package/{formField.sx-CQ1mbk9M.cjs → formField.sx-BAX7KwMR.cjs} +10 -19
  282. package/formField.sx-BAX7KwMR.cjs.map +1 -0
  283. package/index.cjs +96 -6
  284. package/index.cjs.map +1 -1
  285. package/index.d.ts +36 -0
  286. package/index.js +70 -4
  287. package/index.js.map +1 -1
  288. package/local/affiliations/affiliations.dev.soyfri.com-key.pem +28 -0
  289. package/local/affiliations/affiliations.dev.soyfri.com.pem +27 -0
  290. package/local/aficiliaciones/afiliaciones.dev.soyfri.com-key.pem +28 -0
  291. package/local/aficiliaciones/afiliaciones.dev.soyfri.com.pem +27 -0
  292. package/local/afiliaciones/afiliaciones.dev.soyfri.com-key.pem +28 -0
  293. package/local/afiliaciones/afiliaciones.dev.soyfri.com.pem +27 -0
  294. package/local/root/rootCA-key.pem +40 -0
  295. package/local/root/rootCA.pem +30 -0
  296. package/local/soporte/supportweb.dev.soyfri.com-key.pem +28 -0
  297. package/local/soporte/supportweb.dev.soyfri.com.pem +27 -0
  298. package/local/support/supportweb.dev.soyfri.com-key.pem +28 -0
  299. package/local/support/supportweb.dev.soyfri.com.pem +27 -0
  300. package/mergeSx-BXoNZjB_.js +10 -0
  301. package/mergeSx-BXoNZjB_.js.map +1 -0
  302. package/mergeSx-Dbccoo_H.cjs +9 -0
  303. package/mergeSx-Dbccoo_H.cjs.map +1 -0
  304. package/mui.d.ts +3 -1
  305. package/package.json +78 -73
  306. package/{resolvePreset-CT3kU-K2.cjs → resolvePreset-CxTI6_Ln.cjs} +3 -3
  307. package/{resolvePreset-CT3kU-K2.cjs.map → resolvePreset-CxTI6_Ln.cjs.map} +1 -1
  308. package/{resolvePreset-B-IB0ehH.js → resolvePreset-K6_BfWHD.js} +3 -3
  309. package/{resolvePreset-B-IB0ehH.js.map → resolvePreset-K6_BfWHD.js.map} +1 -1
  310. package/theme/componentStyles.d.ts +1 -1
  311. package/tokens-BRrcP_p_.js +21 -0
  312. package/tokens-BRrcP_p_.js.map +1 -0
  313. package/tokens-jaWWNk39.cjs +20 -0
  314. package/tokens-jaWWNk39.cjs.map +1 -0
  315. package/utils/index.d.ts +2 -0
  316. package/{components/ScrollTopButton → utils}/scrollToTop.d.ts +6 -7
  317. package/components/AppBar/AppBarBrand.d.ts +0 -31
  318. package/components/AppBar/AppBarUserMenu.d.ts +0 -65
  319. package/components/Autocomplete/Autocomplete.types.d.ts +0 -1
  320. package/components/DatePicker/DatePicker.types.d.ts +0 -1
  321. package/components/DateRangePicker/DateRangePicker.cjs.map +0 -1
  322. package/components/DateRangePicker/DateRangePicker.d.ts +0 -15
  323. package/components/DateRangePicker/DateRangePicker.definitions.d.ts +0 -6
  324. package/components/DateRangePicker/DateRangePicker.js.map +0 -1
  325. package/components/DateRangePicker/index.d.ts +0 -1
  326. package/components/DateRangePicker.d.ts +0 -2
  327. package/components/DateTimePicker/DateTimePicker.types.d.ts +0 -1
  328. package/components/Input/Input.types.d.ts +0 -1
  329. package/components/PageLoader/PageLoader.cjs +0 -61
  330. package/components/PageLoader/PageLoader.cjs.map +0 -1
  331. package/components/PageLoader/PageLoader.d.ts +0 -38
  332. package/components/PageLoader/PageLoader.js +0 -61
  333. package/components/PageLoader/PageLoader.js.map +0 -1
  334. package/components/PageLoader/index.d.ts +0 -2
  335. package/components/PageLoader.d.ts +0 -6
  336. package/components/ScrollTopButton/ScrollTopButton.cjs +0 -79
  337. package/components/ScrollTopButton/ScrollTopButton.cjs.map +0 -1
  338. package/components/ScrollTopButton/ScrollTopButton.d.ts +0 -48
  339. package/components/ScrollTopButton/ScrollTopButton.js +0 -79
  340. package/components/ScrollTopButton/ScrollTopButton.js.map +0 -1
  341. package/components/ScrollTopButton/index.d.ts +0 -4
  342. package/components/ScrollTopButton.d.ts +0 -6
  343. package/components/Select/Select.definitions.d.ts +0 -17
  344. package/components/Select/Select.types.d.ts +0 -1
  345. package/components/Select/_parts/SelectSearchHeader.d.ts +0 -15
  346. package/formField.sx-CQ1mbk9M.cjs.map +0 -1
  347. package/formField.sx-DfVbMe0V.js.map +0 -1
  348. package/hooks/Wizard/Wizard.cjs +0 -7
  349. package/hooks/Wizard/Wizard.cjs.map +0 -1
  350. package/hooks/Wizard/Wizard.js +0 -7
  351. package/hooks/Wizard/Wizard.js.map +0 -1
  352. package/hooks/Wizard/index.d.ts +0 -3
  353. package/hooks/Wizard/useWizard.d.ts +0 -9
  354. package/hooks/Wizard.d.ts +0 -2
  355. package/useWizard-CWdIxZzX.cjs +0 -94
  356. package/useWizard-CWdIxZzX.cjs.map +0 -1
  357. package/useWizard-CWq--C3o.js +0 -95
  358. package/useWizard-CWq--C3o.js.map +0 -1
  359. /package/{styles.css → index.css} +0 -0
@@ -1,6 +1,7 @@
1
1
  import { jsxs, jsx, Fragment } from "react/jsx-runtime";
2
2
  import { useState, useRef, useEffect } from "react";
3
3
  import { Box, IconButton, Dialog, DialogContent, Stack, Typography, DialogActions, useMediaQuery } from "@mui/material";
4
+ import { useTheme } from "@mui/material/styles";
4
5
  import KeyboardArrowUpIcon from "@mui/icons-material/KeyboardArrowUp";
5
6
  import KeyboardArrowDownIcon from "@mui/icons-material/KeyboardArrowDown";
6
7
  import KeyboardArrowLeftIcon from "@mui/icons-material/KeyboardArrowLeft";
@@ -15,14 +16,15 @@ import RotateRightIcon from "@mui/icons-material/RotateRight";
15
16
  import RestartAltIcon from "@mui/icons-material/RestartAlt";
16
17
  import CloseIcon from "@mui/icons-material/Close";
17
18
  import { B as Button } from "../../Button-UkkP-bNw.js";
19
+ import { r as resolvePreset } from "../../resolvePreset-K6_BfWHD.js";
18
20
  const GalleryThumbnails = ({
19
21
  items,
20
22
  selectedIdx,
21
23
  onSelect,
22
24
  thumbStartIdx,
23
- THUMB_VISIBLE_COUNT,
24
- handleThumbUp,
25
- handleThumbDown,
25
+ visibleCount,
26
+ onThumbUp,
27
+ onThumbDown,
26
28
  isMobile
27
29
  }) => /* @__PURE__ */ jsxs(
28
30
  Box,
@@ -34,7 +36,7 @@ const GalleryThumbnails = ({
34
36
  minWidth: 70,
35
37
  width: 70,
36
38
  borderRadius: 1,
37
- bgcolor: "#f8f9fa",
39
+ bgcolor: "grey.100",
38
40
  boxSizing: "border-box",
39
41
  py: 1,
40
42
  mb: isMobile ? 2 : 0,
@@ -45,37 +47,55 @@ const GalleryThumbnails = ({
45
47
  IconButton,
46
48
  {
47
49
  size: "small",
48
- onClick: handleThumbUp,
50
+ onClick: onThumbUp,
49
51
  disabled: thumbStartIdx === 0,
52
+ "aria-label": isMobile ? "Miniatura anterior" : "Miniaturas arriba",
50
53
  sx: { mb: isMobile ? 0 : 1, mr: isMobile ? 1 : 0 },
51
54
  children: isMobile ? /* @__PURE__ */ jsx(KeyboardArrowLeftIcon, {}) : /* @__PURE__ */ jsx(KeyboardArrowUpIcon, {})
52
55
  }
53
56
  ),
54
- items.slice(thumbStartIdx, thumbStartIdx + THUMB_VISIBLE_COUNT).map((item, idx) => {
57
+ items.slice(thumbStartIdx, thumbStartIdx + visibleCount).map((item, idx) => {
58
+ var _a;
55
59
  const realIdx = thumbStartIdx + idx;
60
+ const isSelected = selectedIdx === realIdx;
61
+ const handleSelect = () => onSelect(realIdx);
56
62
  return /* @__PURE__ */ jsx(
57
63
  Box,
58
64
  {
59
- onClick: () => onSelect(realIdx),
65
+ role: "button",
66
+ tabIndex: 0,
67
+ "aria-label": item.title,
68
+ "aria-pressed": isSelected,
69
+ onClick: handleSelect,
70
+ onKeyDown: (e) => {
71
+ if (e.key === "Enter" || e.key === " ") {
72
+ e.preventDefault();
73
+ handleSelect();
74
+ }
75
+ },
60
76
  sx: {
61
77
  cursor: "pointer",
62
78
  width: 60,
63
79
  height: 60,
64
80
  borderRadius: 1,
65
- border: selectedIdx === realIdx ? "2px solid #1976d2" : "2px solid #eee",
81
+ border: (theme) => `2px solid ${isSelected ? theme.palette.primary.main : theme.palette.divider}`,
66
82
  overflow: "hidden",
67
- bgcolor: "#eee",
83
+ bgcolor: "action.hover",
68
84
  display: "flex",
69
85
  alignItems: "center",
70
86
  justifyContent: "center",
71
87
  flexShrink: 0,
72
- m: isMobile ? "0 4px" : "4px 0"
88
+ m: isMobile ? "0 4px" : "4px 0",
89
+ outline: "none",
90
+ "&:focus-visible": {
91
+ boxShadow: (theme) => `0 0 0 2px ${theme.palette.primary.main}`
92
+ }
73
93
  },
74
94
  children: /* @__PURE__ */ jsx(
75
95
  Box,
76
96
  {
77
97
  component: "img",
78
- src: item.thumbnail,
98
+ src: (_a = item.thumbnail) != null ? _a : item.url,
79
99
  alt: item.title,
80
100
  sx: {
81
101
  width: "100%",
@@ -85,15 +105,16 @@ const GalleryThumbnails = ({
85
105
  }
86
106
  )
87
107
  },
88
- realIdx
108
+ `${realIdx}-${item.url}`
89
109
  );
90
110
  }),
91
111
  /* @__PURE__ */ jsx(
92
112
  IconButton,
93
113
  {
94
114
  size: "small",
95
- onClick: handleThumbDown,
96
- disabled: thumbStartIdx + THUMB_VISIBLE_COUNT >= items.length,
115
+ onClick: onThumbDown,
116
+ disabled: thumbStartIdx + visibleCount >= items.length,
117
+ "aria-label": isMobile ? "Miniatura siguiente" : "Miniaturas abajo",
97
118
  sx: { mt: isMobile ? 0 : 1, ml: isMobile ? 1 : 0 },
98
119
  children: isMobile ? /* @__PURE__ */ jsx(KeyboardArrowRightIcon, {}) : /* @__PURE__ */ jsx(KeyboardArrowDownIcon, {})
99
120
  }
@@ -113,7 +134,7 @@ const GalleryMain = ({ item, onOpenLightbox, isMobile }) => /* @__PURE__ */ jsxs
113
134
  alignItems: "center",
114
135
  position: "relative",
115
136
  borderRadius: 1,
116
- bgcolor: "#f8f9fa",
137
+ bgcolor: "grey.100",
117
138
  overflow: "hidden",
118
139
  mx: "auto"
119
140
  },
@@ -140,7 +161,7 @@ const GalleryMain = ({ item, onOpenLightbox, isMobile }) => /* @__PURE__ */ jsxs
140
161
  width: "100%",
141
162
  height: "100%",
142
163
  objectFit: "contain",
143
- bgcolor: "#000",
164
+ bgcolor: "common.black",
144
165
  borderRadius: 1
145
166
  }
146
167
  }
@@ -163,27 +184,35 @@ const GalleryMain = ({ item, onOpenLightbox, isMobile }) => /* @__PURE__ */ jsxs
163
184
  /* @__PURE__ */ jsx(
164
185
  IconButton,
165
186
  {
166
- onClick: onOpenLightbox,
187
+ onClick: (e) => {
188
+ e.stopPropagation();
189
+ onOpenLightbox();
190
+ },
191
+ "aria-label": "Abrir en pantalla completa",
167
192
  sx: {
168
193
  position: "absolute",
169
194
  top: 16,
170
195
  right: 16,
171
- bgcolor: "#1976d2",
172
- "&:hover": { bgcolor: "#1565c0" },
196
+ bgcolor: "primary.main",
197
+ color: "primary.contrastText",
198
+ "&:hover": { bgcolor: "primary.dark" },
173
199
  boxShadow: 2
174
200
  },
175
- children: /* @__PURE__ */ jsx(FullscreenIcon, { sx: { color: "#fff" } })
201
+ children: /* @__PURE__ */ jsx(FullscreenIcon, {})
176
202
  }
177
203
  )
178
204
  ]
179
205
  }
180
206
  );
207
+ const ZOOM_MIN = 0.25;
208
+ const ZOOM_MAX = 5;
209
+ const ZOOM_STEP = 0.25;
181
210
  const GalleryLightbox = ({
182
211
  open,
183
212
  onClose,
184
213
  item,
185
- handlePrev,
186
- handleNext,
214
+ onPrev,
215
+ onNext,
187
216
  zoom,
188
217
  setZoom,
189
218
  rotation,
@@ -202,11 +231,28 @@ const GalleryLightbox = ({
202
231
  gap: 2
203
232
  },
204
233
  children: [
205
- /* @__PURE__ */ jsxs(Stack, { direction: "row", justifyContent: "space-between", alignItems: "center", width: "100%", children: [
206
- /* @__PURE__ */ jsx(IconButton, { onClick: handlePrev, children: /* @__PURE__ */ jsx(ArrowBackIosNewIcon, {}) }),
207
- /* @__PURE__ */ jsx(Typography, { variant: "subtitle1", fontWeight: 600, sx: { flex: 1, textAlign: "center" }, children: item.title }),
208
- /* @__PURE__ */ jsx(IconButton, { onClick: handleNext, children: /* @__PURE__ */ jsx(ArrowForwardIosIcon, {}) })
209
- ] }),
234
+ /* @__PURE__ */ jsxs(
235
+ Stack,
236
+ {
237
+ direction: "row",
238
+ justifyContent: "space-between",
239
+ alignItems: "center",
240
+ width: "100%",
241
+ children: [
242
+ /* @__PURE__ */ jsx(IconButton, { onClick: onPrev, "aria-label": "Anterior", children: /* @__PURE__ */ jsx(ArrowBackIosNewIcon, {}) }),
243
+ /* @__PURE__ */ jsx(
244
+ Typography,
245
+ {
246
+ variant: "subtitle1",
247
+ fontWeight: 600,
248
+ sx: { flex: 1, textAlign: "center" },
249
+ children: item.title
250
+ }
251
+ ),
252
+ /* @__PURE__ */ jsx(IconButton, { onClick: onNext, "aria-label": "Siguiente", children: /* @__PURE__ */ jsx(ArrowForwardIosIcon, {}) })
253
+ ]
254
+ }
255
+ ),
210
256
  item.type === "video" ? /* @__PURE__ */ jsx(
211
257
  Box,
212
258
  {
@@ -217,10 +263,10 @@ const GalleryLightbox = ({
217
263
  autoPlay: true,
218
264
  sx: {
219
265
  width: "100%",
220
- maxWidth: "900px",
266
+ maxWidth: 900,
221
267
  maxHeight: "70vh",
222
268
  objectFit: "contain",
223
- bgcolor: "#000",
269
+ bgcolor: "common.black",
224
270
  borderRadius: 1
225
271
  }
226
272
  },
@@ -235,7 +281,7 @@ const GalleryLightbox = ({
235
281
  transform: `scale(${zoom}) rotate(${rotation}deg)`,
236
282
  transition: "transform 0.2s ease",
237
283
  width: "100%",
238
- maxWidth: "900px",
284
+ maxWidth: 900,
239
285
  maxHeight: "70vh",
240
286
  objectFit: "contain",
241
287
  borderRadius: 1
@@ -262,7 +308,8 @@ const GalleryLightbox = ({
262
308
  {
263
309
  variant: "outlined",
264
310
  startIcon: /* @__PURE__ */ jsx(ZoomInIcon, {}),
265
- onClick: () => setZoom((z) => z + 0.25),
311
+ onClick: () => setZoom((z) => Math.min(ZOOM_MAX, z + ZOOM_STEP)),
312
+ disabled: zoom >= ZOOM_MAX,
266
313
  children: "Zoom +"
267
314
  }
268
315
  ),
@@ -271,7 +318,8 @@ const GalleryLightbox = ({
271
318
  {
272
319
  variant: "outlined",
273
320
  startIcon: /* @__PURE__ */ jsx(ZoomOutIcon, {}),
274
- onClick: () => setZoom((z) => Math.max(0.25, z - 0.25)),
321
+ onClick: () => setZoom((z) => Math.max(ZOOM_MIN, z - ZOOM_STEP)),
322
+ disabled: zoom <= ZOOM_MIN,
275
323
  children: "Zoom −"
276
324
  }
277
325
  )
@@ -281,7 +329,8 @@ const GalleryLightbox = ({
281
329
  Button,
282
330
  {
283
331
  variant: "outlined",
284
- onClick: () => setRotation((r) => r - 90),
332
+ "aria-label": "Rotar a la izquierda",
333
+ onClick: () => setRotation((r) => (r - 90) % 360),
285
334
  children: /* @__PURE__ */ jsx(RotateLeftIcon, {})
286
335
  }
287
336
  ),
@@ -289,7 +338,8 @@ const GalleryLightbox = ({
289
338
  Button,
290
339
  {
291
340
  variant: "outlined",
292
- onClick: () => setRotation((r) => r + 90),
341
+ "aria-label": "Rotar a la derecha",
342
+ onClick: () => setRotation((r) => (r + 90) % 360),
293
343
  children: /* @__PURE__ */ jsx(RotateRightIcon, {})
294
344
  }
295
345
  )
@@ -320,7 +370,14 @@ const GalleryLightbox = ({
320
370
  }
321
371
  )
322
372
  ] });
323
- const Gallery = ({ items, maxWidth = "600px" }) => {
373
+ const Gallery = ({
374
+ items,
375
+ maxWidth = "600px",
376
+ preset,
377
+ sx,
378
+ className
379
+ }) => {
380
+ const theme = useTheme();
324
381
  const isMobile = useMediaQuery("(max-width:700px)");
325
382
  const [selectedIdx, setSelectedIdx] = useState(0);
326
383
  const [openLightbox, setOpenLightbox] = useState(false);
@@ -334,16 +391,14 @@ const Gallery = ({ items, maxWidth = "600px" }) => {
334
391
  };
335
392
  const handleThumbDown = () => {
336
393
  setThumbStartIdx(
337
- (prev) => Math.min(items.length - THUMB_VISIBLE_COUNT, prev + 1)
394
+ (prev) => Math.max(0, Math.min(items.length - THUMB_VISIBLE_COUNT, prev + 1))
338
395
  );
339
396
  };
340
397
  const handlePrev = () => {
341
398
  setSelectedIdx((idx) => idx === 0 ? items.length - 1 : idx - 1);
342
399
  };
343
400
  const handleNext = () => {
344
- setSelectedIdx(
345
- (idx) => idx === items.length - 1 ? 0 : idx + 1
346
- );
401
+ setSelectedIdx((idx) => idx === items.length - 1 ? 0 : idx + 1);
347
402
  };
348
403
  useEffect(() => {
349
404
  if (!openLightbox) return;
@@ -367,51 +422,71 @@ const Gallery = ({ items, maxWidth = "600px" }) => {
367
422
  var _a;
368
423
  if (openLightbox && ((_a = items[selectedIdx]) == null ? void 0 : _a.type) === "video" && videoRef.current) {
369
424
  videoRef.current.currentTime = 0;
370
- videoRef.current.play();
425
+ videoRef.current.play().catch(() => {
426
+ });
371
427
  }
372
428
  setZoom(1);
373
429
  setRotation(0);
374
430
  }, [openLightbox, selectedIdx, items]);
375
- return /* @__PURE__ */ jsxs(Stack, { direction: isMobile ? "column" : "row", gap: 3, sx: { maxWidth, mx: "auto", minHeight: 300 }, children: [
376
- /* @__PURE__ */ jsx(
377
- GalleryThumbnails,
378
- {
379
- items,
380
- selectedIdx,
381
- onSelect: setSelectedIdx,
382
- thumbStartIdx,
383
- THUMB_VISIBLE_COUNT,
384
- handleThumbUp,
385
- handleThumbDown,
386
- isMobile
387
- }
388
- ),
389
- /* @__PURE__ */ jsx(
390
- GalleryMain,
391
- {
392
- item: items[selectedIdx],
393
- onOpenLightbox: () => setOpenLightbox(true),
394
- isMobile
395
- }
396
- ),
397
- /* @__PURE__ */ jsx(
398
- GalleryLightbox,
399
- {
400
- open: openLightbox,
401
- onClose: () => setOpenLightbox(false),
402
- item: items[selectedIdx],
403
- handlePrev,
404
- handleNext,
405
- zoom,
406
- setZoom,
407
- rotation,
408
- setRotation,
409
- videoRef
410
- }
411
- )
412
- ] });
431
+ if (!items || items.length === 0) return null;
432
+ const safeSelectedIdx = Math.max(0, Math.min(selectedIdx, items.length - 1));
433
+ const currentItem = items[safeSelectedIdx];
434
+ const presetSx = resolvePreset("Gallery", preset, theme);
435
+ const rootSx = [
436
+ { maxWidth, mx: "auto", minHeight: 300 },
437
+ ...presetSx ? [presetSx] : [],
438
+ ...Array.isArray(sx) ? sx : sx ? [sx] : []
439
+ ];
440
+ return /* @__PURE__ */ jsxs(
441
+ Stack,
442
+ {
443
+ direction: isMobile ? "column" : "row",
444
+ gap: 3,
445
+ className,
446
+ sx: rootSx,
447
+ children: [
448
+ /* @__PURE__ */ jsx(
449
+ GalleryThumbnails,
450
+ {
451
+ items,
452
+ selectedIdx: safeSelectedIdx,
453
+ onSelect: setSelectedIdx,
454
+ thumbStartIdx,
455
+ visibleCount: THUMB_VISIBLE_COUNT,
456
+ onThumbUp: handleThumbUp,
457
+ onThumbDown: handleThumbDown,
458
+ isMobile
459
+ }
460
+ ),
461
+ /* @__PURE__ */ jsx(
462
+ GalleryMain,
463
+ {
464
+ item: currentItem,
465
+ onOpenLightbox: () => setOpenLightbox(true),
466
+ isMobile
467
+ }
468
+ ),
469
+ /* @__PURE__ */ jsx(
470
+ GalleryLightbox,
471
+ {
472
+ open: openLightbox,
473
+ onClose: () => setOpenLightbox(false),
474
+ item: currentItem,
475
+ onPrev: handlePrev,
476
+ onNext: handleNext,
477
+ zoom,
478
+ setZoom,
479
+ rotation,
480
+ setRotation,
481
+ videoRef
482
+ }
483
+ )
484
+ ]
485
+ }
486
+ );
413
487
  };
414
488
  export {
415
- Gallery
489
+ Gallery,
490
+ Gallery as default
416
491
  };
417
492
  //# sourceMappingURL=Gallery.js.map
@@ -1 +1 @@
1
- {"version":3,"file":"Gallery.js","sources":["../../../src/components/Gallery/GalleryThumbnails.tsx","../../../src/components/Gallery/GalleryMain.tsx","../../../src/components/Gallery/GalleryLightbox.tsx","../../../src/components/Gallery/Gallery.tsx"],"sourcesContent":["import React from \"react\";\nimport { Box, IconButton } from \"@mui/material\";\nimport KeyboardArrowUpIcon from \"@mui/icons-material/KeyboardArrowUp\";\nimport KeyboardArrowDownIcon from \"@mui/icons-material/KeyboardArrowDown\";\nimport KeyboardArrowLeftIcon from \"@mui/icons-material/KeyboardArrowLeft\";\nimport KeyboardArrowRightIcon from \"@mui/icons-material/KeyboardArrowRight\";\n\n\ninterface Props {\n items: Array<{\n url: string;\n type: string;\n title: string;\n thumbnail: string;\n }>;\n selectedIdx: number;\n onSelect: (idx: number) => void;\n thumbStartIdx: number;\n THUMB_VISIBLE_COUNT: number;\n handleThumbUp: () => void;\n handleThumbDown: () => void;\n isMobile: boolean;\n}\n\nexport const GalleryThumbnails = ({\n items,\n selectedIdx,\n onSelect,\n thumbStartIdx,\n THUMB_VISIBLE_COUNT,\n handleThumbUp,\n handleThumbDown,\n isMobile,\n}: Props) => (\n <Box\n sx={{\n display: \"flex\",\n flexDirection: isMobile ? \"row\" : \"column\",\n alignItems: \"center\",\n minWidth: 70,\n width: 70,\n borderRadius: 1,\n bgcolor: \"#f8f9fa\",\n boxSizing: \"border-box\",\n py: 1,\n mb: isMobile ? 2 : 0,\n px: isMobile ? 1 : 0,\n }}\n >\n <IconButton\n size=\"small\"\n onClick={handleThumbUp}\n disabled={thumbStartIdx === 0}\n sx={{ mb: isMobile ? 0 : 1, mr: isMobile ? 1 : 0 }}\n >\n {isMobile ? <KeyboardArrowLeftIcon /> : <KeyboardArrowUpIcon />}\n </IconButton>\n {items\n .slice(thumbStartIdx, thumbStartIdx + THUMB_VISIBLE_COUNT)\n .map((item, idx) => {\n const realIdx = thumbStartIdx + idx;\n return (\n <Box\n key={realIdx}\n onClick={() => onSelect(realIdx)}\n sx={{\n cursor: \"pointer\",\n width: 60,\n height: 60,\n borderRadius: 1,\n border:\n selectedIdx === realIdx\n ? \"2px solid #1976d2\"\n : \"2px solid #eee\",\n overflow: \"hidden\",\n bgcolor: \"#eee\",\n display: \"flex\",\n alignItems: \"center\",\n justifyContent: \"center\",\n flexShrink: 0,\n m: isMobile ? \"0 4px\" : \"4px 0\",\n }}\n >\n <Box\n component=\"img\"\n src={item.thumbnail}\n alt={item.title}\n sx={{\n width: \"100%\",\n height: \"100%\",\n objectFit: \"cover\",\n }}\n />\n </Box>\n );\n })}\n <IconButton\n size=\"small\"\n onClick={handleThumbDown}\n disabled={thumbStartIdx + THUMB_VISIBLE_COUNT >= items.length}\n sx={{ mt: isMobile ? 0 : 1, ml: isMobile ? 1 : 0 }}\n >\n {isMobile ? <KeyboardArrowRightIcon /> : <KeyboardArrowDownIcon />}\n </IconButton>\n </Box>\n);","import React from \"react\";\nimport { Box, IconButton } from \"@mui/material\";\nimport FullscreenIcon from \"@mui/icons-material/Fullscreen\";\n\ninterface Props {\n item: {\n url: string;\n type: \"image\" | \"video\" | string;\n title: string;\n thumbnail: string;\n};\n onOpenLightbox: () => void;\n isMobile: boolean;\n}\n\nexport const GalleryMain = ({ item, onOpenLightbox, isMobile }: Props) => (\n <Box\n sx={{\n width: isMobile ? \"80%\" : '100%',\n maxHeight: 431,\n maxWidth: isMobile ? \"80%\" : '100%',\n display: \"flex\",\n justifyContent: \"center\",\n alignItems: \"center\",\n position: \"relative\",\n borderRadius: 1,\n bgcolor: \"#f8f9fa\",\n overflow: \"hidden\",\n mx: \"auto\",\n }}\n >\n <Box\n sx={{\n width: \"100%\",\n height: \"100%\",\n cursor: \"pointer\",\n display: \"flex\",\n alignItems: \"center\",\n justifyContent: \"center\",\n }}\n onClick={onOpenLightbox}\n >\n {item.type === \"video\" ? (\n <Box\n component=\"video\"\n controls\n src={item.url}\n sx={{\n width: \"100%\",\n height: \"100%\",\n objectFit: \"contain\",\n bgcolor: \"#000\",\n borderRadius: 1,\n }}\n />\n ) : (\n <Box\n component=\"img\"\n src={item.url}\n alt={item.title}\n sx={{\n width: \"100%\",\n height: \"100%\",\n objectFit: \"contain\",\n borderRadius: 1,\n }}\n />\n )}\n </Box>\n <IconButton\n onClick={onOpenLightbox}\n sx={{\n position: \"absolute\",\n top: 16,\n right: 16,\n bgcolor: \"#1976d2\",\n \"&:hover\": { bgcolor: \"#1565c0\" },\n boxShadow: 2,\n }}\n >\n <FullscreenIcon sx={{ color: \"#fff\" }} />\n </IconButton>\n </Box>\n);","import React from \"react\";\nimport {\n Dialog,\n DialogContent,\n DialogActions,\n Stack,\n IconButton,\n Box,\n Typography,\n} from \"@mui/material\";\nimport ArrowBackIosNewIcon from \"@mui/icons-material/ArrowBackIosNew\";\nimport ArrowForwardIosIcon from \"@mui/icons-material/ArrowForwardIos\";\nimport ZoomInIcon from \"@mui/icons-material/ZoomIn\";\nimport ZoomOutIcon from \"@mui/icons-material/ZoomOut\";\nimport RotateLeftIcon from \"@mui/icons-material/RotateLeft\";\nimport RotateRightIcon from \"@mui/icons-material/RotateRight\";\nimport RestartAltIcon from \"@mui/icons-material/RestartAlt\";\nimport CloseIcon from \"@mui/icons-material/Close\";\nimport { Button } from \"../Button\";\n\n\ninterface Props {\n open: boolean;\n onClose: () => void;\n item: {\n url: string;\n type: \"image\" | \"video\" | string;\n title: string;\n thumbnail: string;\n };\n handlePrev: () => void;\n handleNext: () => void;\n zoom: number;\n setZoom: React.Dispatch<React.SetStateAction<number>>;\n rotation: number;\n setRotation: React.Dispatch<React.SetStateAction<number>>;\n videoRef?: React.RefObject<HTMLVideoElement | null>;\n}\n\nexport const GalleryLightbox = ({\n open,\n onClose,\n item,\n handlePrev,\n handleNext,\n zoom,\n setZoom,\n rotation,\n setRotation,\n videoRef,\n}: Props) => (\n <Dialog open={open} onClose={onClose} fullWidth maxWidth=\"lg\">\n <DialogContent\n sx={{\n minHeight: 431,\n display: \"flex\",\n flexDirection: \"column\",\n alignItems: \"center\",\n justifyContent: \"center\",\n gap: 2,\n }}\n >\n <Stack direction=\"row\" justifyContent=\"space-between\" alignItems=\"center\" width=\"100%\">\n <IconButton onClick={handlePrev}>\n <ArrowBackIosNewIcon />\n </IconButton>\n <Typography variant=\"subtitle1\" fontWeight={600} sx={{ flex: 1, textAlign: \"center\" }}>\n {item.title}\n </Typography>\n <IconButton onClick={handleNext}>\n <ArrowForwardIosIcon />\n </IconButton>\n </Stack>\n {item.type === \"video\" ? (\n <Box\n component=\"video\"\n key={item.url}\n ref={videoRef}\n src={item.url}\n controls\n autoPlay\n sx={{\n width: \"100%\",\n maxWidth: \"900px\",\n maxHeight: \"70vh\",\n objectFit: \"contain\",\n bgcolor: \"#000\",\n borderRadius: 1,\n }}\n />\n ) : (\n <Box\n component=\"img\"\n src={item.url}\n alt={item.title}\n sx={{\n transform: `scale(${zoom}) rotate(${rotation}deg)`,\n transition: \"transform 0.2s ease\",\n width: \"100%\",\n maxWidth: \"900px\",\n maxHeight: \"70vh\",\n objectFit: \"contain\",\n borderRadius: 1,\n }}\n />\n )}\n </DialogContent>\n <DialogActions\n sx={{\n display: \"flex\",\n justifyContent: item.type === 'image' ? \"space-between\" : \"end\",\n flexWrap: \"wrap\",\n gap: 1,\n }}\n >\n\n {item.type === 'image' && <>\n <Stack direction=\"row\" spacing={1}>\n <Button\n variant=\"outlined\"\n startIcon={<ZoomInIcon />}\n onClick={() => setZoom((z) => z + 0.25)}\n >\n Zoom +\n </Button>\n <Button\n variant=\"outlined\"\n startIcon={<ZoomOutIcon />}\n onClick={() => setZoom((z) => Math.max(0.25, z - 0.25))}\n >\n Zoom −\n </Button>\n </Stack>\n <Stack direction=\"row\" spacing={1}>\n <Button\n variant=\"outlined\"\n onClick={() => setRotation((r) => r - 90)}\n >\n <RotateLeftIcon />\n </Button>\n <Button\n variant=\"outlined\"\n onClick={() => setRotation((r) => r + 90)}\n >\n <RotateRightIcon />\n </Button>\n </Stack>\n <Button\n variant=\"outlined\"\n startIcon={<RestartAltIcon />}\n onClick={() => {\n setZoom(1);\n setRotation(0);\n }}\n >\n Reset\n </Button>\n\n </>\n }\n <Button\n variant=\"contained\"\n startIcon={<CloseIcon />}\n onClick={onClose}\n >\n Cerrar\n </Button>\n </DialogActions>\n </Dialog >\n);","import React, { useState, useRef, useEffect } from \"react\";\nimport { Stack, useMediaQuery } from \"@mui/material\";\nimport { GalleryThumbnails } from \"./GalleryThumbnails\";\nimport { GalleryMain } from \"./GalleryMain\";\nimport { GalleryLightbox } from \"./GalleryLightbox\";\n\nexport interface Props {\n items: Array<{\n url: string;\n type: \"image\" | \"video\" | string;\n title: string;\n thumbnail: string;\n}>;\n maxWidth?: string;\n}\n\n\nexport const Gallery:React.FC<Props> = ({ items, maxWidth='600px' }: Props) => {\n const isMobile = useMediaQuery(\"(max-width:700px)\");\n const [selectedIdx, setSelectedIdx] = useState(0);\n const [openLightbox, setOpenLightbox] = useState(false);\n const [zoom, setZoom] = useState(1);\n const [rotation, setRotation] = useState(0);\n const videoRef = useRef<HTMLVideoElement | null>(null);\n\n const [thumbStartIdx, setThumbStartIdx] = useState(0);\n const THUMB_VISIBLE_COUNT = isMobile ? 3 : 5;\n\n // Flechas para miniaturas\n const handleThumbUp = () => {\n setThumbStartIdx((prev) => Math.max(0, prev - 1));\n };\n const handleThumbDown = () => {\n setThumbStartIdx((prev) =>\n Math.min(items.length - THUMB_VISIBLE_COUNT, prev + 1)\n );\n };\n\n // Navegación entre imágenes\n const handlePrev = () => {\n setSelectedIdx((idx) => (idx === 0 ? items.length - 1 : idx - 1));\n };\n const handleNext = () => {\n setSelectedIdx((idx) =>\n idx === items.length - 1 ? 0 : idx + 1\n );\n };\n\n // Acciones de teclado\n useEffect(() => {\n if (!openLightbox) return;\n const handleKey = (e: KeyboardEvent) => {\n switch (e.key) {\n case \"ArrowLeft\":\n handlePrev();\n break;\n case \"ArrowRight\":\n handleNext();\n break;\n case \"Escape\":\n setOpenLightbox(false);\n break;\n default:\n break;\n }\n };\n window.addEventListener(\"keydown\", handleKey);\n return () => window.removeEventListener(\"keydown\", handleKey);\n }, [openLightbox, items.length]);\n\n // Reset zoom/rotación y autoplay video\n useEffect(() => {\n if (\n openLightbox &&\n items[selectedIdx]?.type === \"video\" &&\n videoRef.current\n ) {\n videoRef.current.currentTime = 0;\n videoRef.current.play();\n }\n setZoom(1);\n setRotation(0);\n }, [openLightbox, selectedIdx, items]);\n\n return (\n <Stack direction={isMobile ? \"column\" : \"row\"} gap={3} sx={{ maxWidth: maxWidth, mx: \"auto\", minHeight: 300 }}>\n <GalleryThumbnails\n items={items}\n selectedIdx={selectedIdx}\n onSelect={setSelectedIdx}\n thumbStartIdx={thumbStartIdx}\n THUMB_VISIBLE_COUNT={THUMB_VISIBLE_COUNT}\n handleThumbUp={handleThumbUp}\n handleThumbDown={handleThumbDown}\n isMobile={isMobile}\n />\n <GalleryMain\n item={items[selectedIdx]}\n onOpenLightbox={() => setOpenLightbox(true)}\n isMobile={isMobile}\n />\n <GalleryLightbox\n open={openLightbox}\n onClose={() => setOpenLightbox(false)}\n item={items[selectedIdx]}\n handlePrev={handlePrev}\n handleNext={handleNext}\n zoom={zoom}\n setZoom={setZoom}\n rotation={rotation}\n setRotation={setRotation}\n videoRef={videoRef}\n />\n </Stack>\n );\n};\n\nexport default Gallery;"],"names":[],"mappings":"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"}
1
+ {"version":3,"file":"Gallery.js","sources":["../../../src/components/Gallery/GalleryThumbnails.tsx","../../../src/components/Gallery/GalleryMain.tsx","../../../src/components/Gallery/GalleryLightbox.tsx","../../../src/components/Gallery/Gallery.tsx"],"sourcesContent":["import { Box, IconButton } from '@mui/material';\nimport KeyboardArrowUpIcon from '@mui/icons-material/KeyboardArrowUp';\nimport KeyboardArrowDownIcon from '@mui/icons-material/KeyboardArrowDown';\nimport KeyboardArrowLeftIcon from '@mui/icons-material/KeyboardArrowLeft';\nimport KeyboardArrowRightIcon from '@mui/icons-material/KeyboardArrowRight';\n\nimport type { GalleryItem } from './Gallery';\n\ninterface Props {\n items: GalleryItem[];\n selectedIdx: number;\n onSelect: (idx: number) => void;\n thumbStartIdx: number;\n visibleCount: number;\n onThumbUp: () => void;\n onThumbDown: () => void;\n isMobile: boolean;\n}\n\nexport const GalleryThumbnails = ({\n items,\n selectedIdx,\n onSelect,\n thumbStartIdx,\n visibleCount,\n onThumbUp,\n onThumbDown,\n isMobile,\n}: Props) => (\n <Box\n sx={{\n display: 'flex',\n flexDirection: isMobile ? 'row' : 'column',\n alignItems: 'center',\n minWidth: 70,\n width: 70,\n borderRadius: 1,\n bgcolor: 'grey.100',\n boxSizing: 'border-box',\n py: 1,\n mb: isMobile ? 2 : 0,\n px: isMobile ? 1 : 0,\n }}\n >\n <IconButton\n size=\"small\"\n onClick={onThumbUp}\n disabled={thumbStartIdx === 0}\n aria-label={isMobile ? 'Miniatura anterior' : 'Miniaturas arriba'}\n sx={{ mb: isMobile ? 0 : 1, mr: isMobile ? 1 : 0 }}\n >\n {isMobile ? <KeyboardArrowLeftIcon /> : <KeyboardArrowUpIcon />}\n </IconButton>\n {items\n .slice(thumbStartIdx, thumbStartIdx + visibleCount)\n .map((item, idx) => {\n const realIdx = thumbStartIdx + idx;\n const isSelected = selectedIdx === realIdx;\n const handleSelect = () => onSelect(realIdx);\n return (\n <Box\n key={`${realIdx}-${item.url}`}\n role=\"button\"\n tabIndex={0}\n aria-label={item.title}\n aria-pressed={isSelected}\n onClick={handleSelect}\n onKeyDown={(e) => {\n if (e.key === 'Enter' || e.key === ' ') {\n e.preventDefault();\n handleSelect();\n }\n }}\n sx={{\n cursor: 'pointer',\n width: 60,\n height: 60,\n borderRadius: 1,\n border: (theme) =>\n `2px solid ${\n isSelected ? theme.palette.primary.main : theme.palette.divider\n }`,\n overflow: 'hidden',\n bgcolor: 'action.hover',\n display: 'flex',\n alignItems: 'center',\n justifyContent: 'center',\n flexShrink: 0,\n m: isMobile ? '0 4px' : '4px 0',\n outline: 'none',\n '&:focus-visible': {\n boxShadow: (theme) =>\n `0 0 0 2px ${theme.palette.primary.main}`,\n },\n }}\n >\n <Box\n component=\"img\"\n src={item.thumbnail ?? item.url}\n alt={item.title}\n sx={{\n width: '100%',\n height: '100%',\n objectFit: 'cover',\n }}\n />\n </Box>\n );\n })}\n <IconButton\n size=\"small\"\n onClick={onThumbDown}\n disabled={thumbStartIdx + visibleCount >= items.length}\n aria-label={isMobile ? 'Miniatura siguiente' : 'Miniaturas abajo'}\n sx={{ mt: isMobile ? 0 : 1, ml: isMobile ? 1 : 0 }}\n >\n {isMobile ? <KeyboardArrowRightIcon /> : <KeyboardArrowDownIcon />}\n </IconButton>\n </Box>\n);\n\nexport default GalleryThumbnails;\n","import { Box, IconButton } from '@mui/material';\nimport FullscreenIcon from '@mui/icons-material/Fullscreen';\n\nimport type { GalleryItem } from './Gallery';\n\ninterface Props {\n item: GalleryItem;\n onOpenLightbox: () => void;\n isMobile: boolean;\n}\n\nexport const GalleryMain = ({ item, onOpenLightbox, isMobile }: Props) => (\n <Box\n sx={{\n width: isMobile ? '80%' : '100%',\n maxHeight: 431,\n maxWidth: isMobile ? '80%' : '100%',\n display: 'flex',\n justifyContent: 'center',\n alignItems: 'center',\n position: 'relative',\n borderRadius: 1,\n bgcolor: 'grey.100',\n overflow: 'hidden',\n mx: 'auto',\n }}\n >\n <Box\n sx={{\n width: '100%',\n height: '100%',\n cursor: 'pointer',\n display: 'flex',\n alignItems: 'center',\n justifyContent: 'center',\n }}\n onClick={onOpenLightbox}\n >\n {item.type === 'video' ? (\n <Box\n component=\"video\"\n controls\n src={item.url}\n sx={{\n width: '100%',\n height: '100%',\n objectFit: 'contain',\n bgcolor: 'common.black',\n borderRadius: 1,\n }}\n />\n ) : (\n <Box\n component=\"img\"\n src={item.url}\n alt={item.title}\n sx={{\n width: '100%',\n height: '100%',\n objectFit: 'contain',\n borderRadius: 1,\n }}\n />\n )}\n </Box>\n <IconButton\n onClick={(e) => {\n e.stopPropagation();\n onOpenLightbox();\n }}\n aria-label=\"Abrir en pantalla completa\"\n sx={{\n position: 'absolute',\n top: 16,\n right: 16,\n bgcolor: 'primary.main',\n color: 'primary.contrastText',\n '&:hover': { bgcolor: 'primary.dark' },\n boxShadow: 2,\n }}\n >\n <FullscreenIcon />\n </IconButton>\n </Box>\n);\n\nexport default GalleryMain;\n","import React from 'react';\nimport {\n Dialog,\n DialogContent,\n DialogActions,\n Stack,\n IconButton,\n Box,\n Typography,\n} from '@mui/material';\nimport ArrowBackIosNewIcon from '@mui/icons-material/ArrowBackIosNew';\nimport ArrowForwardIosIcon from '@mui/icons-material/ArrowForwardIos';\nimport ZoomInIcon from '@mui/icons-material/ZoomIn';\nimport ZoomOutIcon from '@mui/icons-material/ZoomOut';\nimport RotateLeftIcon from '@mui/icons-material/RotateLeft';\nimport RotateRightIcon from '@mui/icons-material/RotateRight';\nimport RestartAltIcon from '@mui/icons-material/RestartAlt';\nimport CloseIcon from '@mui/icons-material/Close';\n\nimport { Button } from '../Button';\nimport type { GalleryItem } from './Gallery';\n\nconst ZOOM_MIN = 0.25;\nconst ZOOM_MAX = 5;\nconst ZOOM_STEP = 0.25;\n\ninterface Props {\n open: boolean;\n onClose: () => void;\n item: GalleryItem;\n onPrev: () => void;\n onNext: () => void;\n zoom: number;\n setZoom: React.Dispatch<React.SetStateAction<number>>;\n rotation: number;\n setRotation: React.Dispatch<React.SetStateAction<number>>;\n videoRef?: React.RefObject<HTMLVideoElement | null>;\n}\n\nexport const GalleryLightbox = ({\n open,\n onClose,\n item,\n onPrev,\n onNext,\n zoom,\n setZoom,\n rotation,\n setRotation,\n videoRef,\n}: Props) => (\n <Dialog open={open} onClose={onClose} fullWidth maxWidth=\"lg\">\n <DialogContent\n sx={{\n minHeight: 431,\n display: 'flex',\n flexDirection: 'column',\n alignItems: 'center',\n justifyContent: 'center',\n gap: 2,\n }}\n >\n <Stack\n direction=\"row\"\n justifyContent=\"space-between\"\n alignItems=\"center\"\n width=\"100%\"\n >\n <IconButton onClick={onPrev} aria-label=\"Anterior\">\n <ArrowBackIosNewIcon />\n </IconButton>\n <Typography\n variant=\"subtitle1\"\n fontWeight={600}\n sx={{ flex: 1, textAlign: 'center' }}\n >\n {item.title}\n </Typography>\n <IconButton onClick={onNext} aria-label=\"Siguiente\">\n <ArrowForwardIosIcon />\n </IconButton>\n </Stack>\n\n {item.type === 'video' ? (\n <Box\n component=\"video\"\n key={item.url}\n ref={videoRef}\n src={item.url}\n controls\n autoPlay\n sx={{\n width: '100%',\n maxWidth: 900,\n maxHeight: '70vh',\n objectFit: 'contain',\n bgcolor: 'common.black',\n borderRadius: 1,\n }}\n />\n ) : (\n <Box\n component=\"img\"\n src={item.url}\n alt={item.title}\n sx={{\n transform: `scale(${zoom}) rotate(${rotation}deg)`,\n transition: 'transform 0.2s ease',\n width: '100%',\n maxWidth: 900,\n maxHeight: '70vh',\n objectFit: 'contain',\n borderRadius: 1,\n }}\n />\n )}\n </DialogContent>\n\n <DialogActions\n sx={{\n display: 'flex',\n justifyContent: item.type === 'image' ? 'space-between' : 'end',\n flexWrap: 'wrap',\n gap: 1,\n }}\n >\n {item.type === 'image' && (\n <>\n <Stack direction=\"row\" spacing={1}>\n <Button\n variant=\"outlined\"\n startIcon={<ZoomInIcon />}\n onClick={() => setZoom((z) => Math.min(ZOOM_MAX, z + ZOOM_STEP))}\n disabled={zoom >= ZOOM_MAX}\n >\n Zoom +\n </Button>\n <Button\n variant=\"outlined\"\n startIcon={<ZoomOutIcon />}\n onClick={() => setZoom((z) => Math.max(ZOOM_MIN, z - ZOOM_STEP))}\n disabled={zoom <= ZOOM_MIN}\n >\n Zoom −\n </Button>\n </Stack>\n <Stack direction=\"row\" spacing={1}>\n <Button\n variant=\"outlined\"\n aria-label=\"Rotar a la izquierda\"\n onClick={() => setRotation((r) => (r - 90) % 360)}\n >\n <RotateLeftIcon />\n </Button>\n <Button\n variant=\"outlined\"\n aria-label=\"Rotar a la derecha\"\n onClick={() => setRotation((r) => (r + 90) % 360)}\n >\n <RotateRightIcon />\n </Button>\n </Stack>\n <Button\n variant=\"outlined\"\n startIcon={<RestartAltIcon />}\n onClick={() => {\n setZoom(1);\n setRotation(0);\n }}\n >\n Reset\n </Button>\n </>\n )}\n <Button\n variant=\"contained\"\n startIcon={<CloseIcon />}\n onClick={onClose}\n >\n Cerrar\n </Button>\n </DialogActions>\n </Dialog>\n);\n\nexport default GalleryLightbox;\n","import React, { useState, useRef, useEffect } from 'react';\nimport { Stack, useMediaQuery } from '@mui/material';\nimport { useTheme, type SxProps, type Theme } from '@mui/material/styles';\n\nimport { GalleryThumbnails } from './GalleryThumbnails';\nimport { GalleryMain } from './GalleryMain';\nimport { GalleryLightbox } from './GalleryLightbox';\nimport { resolvePreset } from '../_shared/resolvePreset';\n\n// ── Tipos de dominio ─────────────────────────────────────────────────────\nexport interface GalleryItem {\n url: string;\n /**\n * Tipo del item. Los literales `\"image\"` / `\"video\"` activan el render\n * específico; cualquier otro string se trata como imagen por default.\n */\n type: 'image' | 'video' | (string & {});\n title: string;\n /** Si no se provee, se usa `url` como thumbnail. */\n thumbnail?: string;\n}\n\nexport interface GalleryProps {\n items: GalleryItem[];\n /** Ancho máximo del contenedor. Default: `'600px'`. */\n maxWidth?: string | number;\n /**\n * Nombre del preset de estilo registrado en `theme.styles.Gallery`.\n * - `\"default\"` (o ausente) = estilo built-in del paquete.\n */\n preset?: string;\n /** sx del contenedor raíz. Se mergea después del preset. */\n sx?: SxProps<Theme>;\n className?: string;\n}\n\nexport const Gallery: React.FC<GalleryProps> = ({\n items,\n maxWidth = '600px',\n preset,\n sx,\n className,\n}) => {\n const theme = useTheme();\n const isMobile = useMediaQuery('(max-width:700px)');\n const [selectedIdx, setSelectedIdx] = useState(0);\n const [openLightbox, setOpenLightbox] = useState(false);\n const [zoom, setZoom] = useState(1);\n const [rotation, setRotation] = useState(0);\n const videoRef = useRef<HTMLVideoElement | null>(null);\n\n const [thumbStartIdx, setThumbStartIdx] = useState(0);\n const THUMB_VISIBLE_COUNT = isMobile ? 3 : 5;\n\n const handleThumbUp = () => {\n setThumbStartIdx((prev) => Math.max(0, prev - 1));\n };\n const handleThumbDown = () => {\n setThumbStartIdx((prev) =>\n Math.max(0, Math.min(items.length - THUMB_VISIBLE_COUNT, prev + 1)),\n );\n };\n\n const handlePrev = () => {\n setSelectedIdx((idx) => (idx === 0 ? items.length - 1 : idx - 1));\n };\n const handleNext = () => {\n setSelectedIdx((idx) => (idx === items.length - 1 ? 0 : idx + 1));\n };\n\n useEffect(() => {\n if (!openLightbox) return;\n const handleKey = (e: KeyboardEvent) => {\n switch (e.key) {\n case 'ArrowLeft':\n handlePrev();\n break;\n case 'ArrowRight':\n handleNext();\n break;\n case 'Escape':\n setOpenLightbox(false);\n break;\n }\n };\n window.addEventListener('keydown', handleKey);\n return () => window.removeEventListener('keydown', handleKey);\n }, [openLightbox, items.length]);\n\n // Reset zoom/rotación al navegar o abrir. Autoplay del video con catch\n // para evitar unhandled rejections por políticas de autoplay del browser.\n useEffect(() => {\n if (\n openLightbox &&\n items[selectedIdx]?.type === 'video' &&\n videoRef.current\n ) {\n videoRef.current.currentTime = 0;\n videoRef.current.play().catch(() => {\n /* autoplay bloqueado — el usuario puede dar play manualmente */\n });\n }\n setZoom(1);\n setRotation(0);\n }, [openLightbox, selectedIdx, items]);\n\n if (!items || items.length === 0) return null;\n\n const safeSelectedIdx = Math.max(0, Math.min(selectedIdx, items.length - 1));\n const currentItem = items[safeSelectedIdx];\n\n const presetSx = resolvePreset('Gallery', preset, theme);\n\n const rootSx: SxProps<Theme> = [\n { maxWidth, mx: 'auto', minHeight: 300 },\n ...(presetSx ? [presetSx] : []),\n ...(Array.isArray(sx) ? sx : sx ? [sx] : []),\n ];\n\n return (\n <Stack\n direction={isMobile ? 'column' : 'row'}\n gap={3}\n className={className}\n sx={rootSx}\n >\n <GalleryThumbnails\n items={items}\n selectedIdx={safeSelectedIdx}\n onSelect={setSelectedIdx}\n thumbStartIdx={thumbStartIdx}\n visibleCount={THUMB_VISIBLE_COUNT}\n onThumbUp={handleThumbUp}\n onThumbDown={handleThumbDown}\n isMobile={isMobile}\n />\n <GalleryMain\n item={currentItem}\n onOpenLightbox={() => setOpenLightbox(true)}\n isMobile={isMobile}\n />\n <GalleryLightbox\n open={openLightbox}\n onClose={() => setOpenLightbox(false)}\n item={currentItem}\n onPrev={handlePrev}\n onNext={handleNext}\n zoom={zoom}\n setZoom={setZoom}\n rotation={rotation}\n setRotation={setRotation}\n videoRef={videoRef}\n />\n </Stack>\n );\n};\n\nexport default Gallery;\n"],"names":[],"mappings":";;;;;;;;;;;;;;;;;;;AAmBO,MAAM,oBAAoB,CAAC;AAAA,EAChC;AAAA,EACA;AAAA,EACA;AAAA,EACA;AAAA,EACA;AAAA,EACA;AAAA,EACA;AAAA,EACA;AACF,MACE;AAAA,EAAC;AAAA,EAAA;AAAA,IACC,IAAI;AAAA,MACF,SAAS;AAAA,MACT,eAAe,WAAW,QAAQ;AAAA,MAClC,YAAY;AAAA,MACZ,UAAU;AAAA,MACV,OAAO;AAAA,MACP,cAAc;AAAA,MACd,SAAS;AAAA,MACT,WAAW;AAAA,MACX,IAAI;AAAA,MACJ,IAAI,WAAW,IAAI;AAAA,MACnB,IAAI,WAAW,IAAI;AAAA,IAAA;AAAA,IAGrB,UAAA;AAAA,MAAA;AAAA,QAAC;AAAA,QAAA;AAAA,UACC,MAAK;AAAA,UACL,SAAS;AAAA,UACT,UAAU,kBAAkB;AAAA,UAC5B,cAAY,WAAW,uBAAuB;AAAA,UAC9C,IAAI,EAAE,IAAI,WAAW,IAAI,GAAG,IAAI,WAAW,IAAI,EAAA;AAAA,UAE9C,UAAA,WAAW,oBAAC,uBAAA,CAAA,CAAsB,wBAAM,qBAAA,CAAA,CAAoB;AAAA,QAAA;AAAA,MAAA;AAAA,MAE9D,MACE,MAAM,eAAe,gBAAgB,YAAY,EACjD,IAAI,CAAC,MAAM,QAAQ;;AAClB,cAAM,UAAU,gBAAgB;AAChC,cAAM,aAAa,gBAAgB;AACnC,cAAM,eAAe,MAAM,SAAS,OAAO;AAC3C,eACE;AAAA,UAAC;AAAA,UAAA;AAAA,YAEC,MAAK;AAAA,YACL,UAAU;AAAA,YACV,cAAY,KAAK;AAAA,YACjB,gBAAc;AAAA,YACd,SAAS;AAAA,YACT,WAAW,CAAC,MAAM;AAChB,kBAAI,EAAE,QAAQ,WAAW,EAAE,QAAQ,KAAK;AACtC,kBAAE,eAAA;AACF,6BAAA;AAAA,cACF;AAAA,YACF;AAAA,YACA,IAAI;AAAA,cACF,QAAQ;AAAA,cACR,OAAO;AAAA,cACP,QAAQ;AAAA,cACR,cAAc;AAAA,cACd,QAAQ,CAAC,UACP,aACE,aAAa,MAAM,QAAQ,QAAQ,OAAO,MAAM,QAAQ,OAC1D;AAAA,cACF,UAAU;AAAA,cACV,SAAS;AAAA,cACT,SAAS;AAAA,cACT,YAAY;AAAA,cACZ,gBAAgB;AAAA,cAChB,YAAY;AAAA,cACZ,GAAG,WAAW,UAAU;AAAA,cACxB,SAAS;AAAA,cACT,mBAAmB;AAAA,gBACjB,WAAW,CAAC,UACV,aAAa,MAAM,QAAQ,QAAQ,IAAI;AAAA,cAAA;AAAA,YAC3C;AAAA,YAGF,UAAA;AAAA,cAAC;AAAA,cAAA;AAAA,gBACC,WAAU;AAAA,gBACV,MAAK,UAAK,cAAL,YAAkB,KAAK;AAAA,gBAC5B,KAAK,KAAK;AAAA,gBACV,IAAI;AAAA,kBACF,OAAO;AAAA,kBACP,QAAQ;AAAA,kBACR,WAAW;AAAA,gBAAA;AAAA,cACb;AAAA,YAAA;AAAA,UACF;AAAA,UA5CK,GAAG,OAAO,IAAI,KAAK,GAAG;AAAA,QAAA;AAAA,MA+CjC,CAAC;AAAA,MACH;AAAA,QAAC;AAAA,QAAA;AAAA,UACC,MAAK;AAAA,UACL,SAAS;AAAA,UACT,UAAU,gBAAgB,gBAAgB,MAAM;AAAA,UAChD,cAAY,WAAW,wBAAwB;AAAA,UAC/C,IAAI,EAAE,IAAI,WAAW,IAAI,GAAG,IAAI,WAAW,IAAI,EAAA;AAAA,UAE9C,UAAA,WAAW,oBAAC,wBAAA,CAAA,CAAuB,wBAAM,uBAAA,CAAA,CAAsB;AAAA,QAAA;AAAA,MAAA;AAAA,IAClE;AAAA,EAAA;AACF;AC3GK,MAAM,cAAc,CAAC,EAAE,MAAM,gBAAgB,eAClD;AAAA,EAAC;AAAA,EAAA;AAAA,IACC,IAAI;AAAA,MACF,OAAO,WAAW,QAAQ;AAAA,MAC1B,WAAW;AAAA,MACX,UAAU,WAAW,QAAQ;AAAA,MAC7B,SAAS;AAAA,MACT,gBAAgB;AAAA,MAChB,YAAY;AAAA,MACZ,UAAU;AAAA,MACV,cAAc;AAAA,MACd,SAAS;AAAA,MACT,UAAU;AAAA,MACV,IAAI;AAAA,IAAA;AAAA,IAGN,UAAA;AAAA,MAAA;AAAA,QAAC;AAAA,QAAA;AAAA,UACC,IAAI;AAAA,YACF,OAAO;AAAA,YACP,QAAQ;AAAA,YACR,QAAQ;AAAA,YACR,SAAS;AAAA,YACT,YAAY;AAAA,YACZ,gBAAgB;AAAA,UAAA;AAAA,UAElB,SAAS;AAAA,UAER,UAAA,KAAK,SAAS,UACb;AAAA,YAAC;AAAA,YAAA;AAAA,cACC,WAAU;AAAA,cACV,UAAQ;AAAA,cACR,KAAK,KAAK;AAAA,cACV,IAAI;AAAA,gBACF,OAAO;AAAA,gBACP,QAAQ;AAAA,gBACR,WAAW;AAAA,gBACX,SAAS;AAAA,gBACT,cAAc;AAAA,cAAA;AAAA,YAChB;AAAA,UAAA,IAGF;AAAA,YAAC;AAAA,YAAA;AAAA,cACC,WAAU;AAAA,cACV,KAAK,KAAK;AAAA,cACV,KAAK,KAAK;AAAA,cACV,IAAI;AAAA,gBACF,OAAO;AAAA,gBACP,QAAQ;AAAA,gBACR,WAAW;AAAA,gBACX,cAAc;AAAA,cAAA;AAAA,YAChB;AAAA,UAAA;AAAA,QACF;AAAA,MAAA;AAAA,MAGJ;AAAA,QAAC;AAAA,QAAA;AAAA,UACC,SAAS,CAAC,MAAM;AACd,cAAE,gBAAA;AACF,2BAAA;AAAA,UACF;AAAA,UACA,cAAW;AAAA,UACX,IAAI;AAAA,YACF,UAAU;AAAA,YACV,KAAK;AAAA,YACL,OAAO;AAAA,YACP,SAAS;AAAA,YACT,OAAO;AAAA,YACP,WAAW,EAAE,SAAS,eAAA;AAAA,YACtB,WAAW;AAAA,UAAA;AAAA,UAGb,8BAAC,gBAAA,CAAA,CAAe;AAAA,QAAA;AAAA,MAAA;AAAA,IAClB;AAAA,EAAA;AACF;AC7DF,MAAM,WAAW;AACjB,MAAM,WAAW;AACjB,MAAM,YAAY;AAeX,MAAM,kBAAkB,CAAC;AAAA,EAC9B;AAAA,EACA;AAAA,EACA;AAAA,EACA;AAAA,EACA;AAAA,EACA;AAAA,EACA;AAAA,EACA;AAAA,EACA;AAAA,EACA;AACF,2BACG,QAAA,EAAO,MAAY,SAAkB,WAAS,MAAC,UAAS,MACvD,UAAA;AAAA,EAAA;AAAA,IAAC;AAAA,IAAA;AAAA,MACC,IAAI;AAAA,QACF,WAAW;AAAA,QACX,SAAS;AAAA,QACT,eAAe;AAAA,QACf,YAAY;AAAA,QACZ,gBAAgB;AAAA,QAChB,KAAK;AAAA,MAAA;AAAA,MAGP,UAAA;AAAA,QAAA;AAAA,UAAC;AAAA,UAAA;AAAA,YACC,WAAU;AAAA,YACV,gBAAe;AAAA,YACf,YAAW;AAAA,YACX,OAAM;AAAA,YAEN,UAAA;AAAA,cAAA,oBAAC,cAAW,SAAS,QAAQ,cAAW,YACtC,UAAA,oBAAC,uBAAoB,EAAA,CACvB;AAAA,cACA;AAAA,gBAAC;AAAA,gBAAA;AAAA,kBACC,SAAQ;AAAA,kBACR,YAAY;AAAA,kBACZ,IAAI,EAAE,MAAM,GAAG,WAAW,SAAA;AAAA,kBAEzB,UAAA,KAAK;AAAA,gBAAA;AAAA,cAAA;AAAA,cAER,oBAAC,cAAW,SAAS,QAAQ,cAAW,aACtC,UAAA,oBAAC,uBAAoB,EAAA,CACvB;AAAA,YAAA;AAAA,UAAA;AAAA,QAAA;AAAA,QAGD,KAAK,SAAS,UACb;AAAA,UAAC;AAAA,UAAA;AAAA,YACC,WAAU;AAAA,YAEV,KAAK;AAAA,YACL,KAAK,KAAK;AAAA,YACV,UAAQ;AAAA,YACR,UAAQ;AAAA,YACR,IAAI;AAAA,cACF,OAAO;AAAA,cACP,UAAU;AAAA,cACV,WAAW;AAAA,cACX,WAAW;AAAA,cACX,SAAS;AAAA,cACT,cAAc;AAAA,YAAA;AAAA,UAChB;AAAA,UAZK,KAAK;AAAA,QAAA,IAeZ;AAAA,UAAC;AAAA,UAAA;AAAA,YACC,WAAU;AAAA,YACV,KAAK,KAAK;AAAA,YACV,KAAK,KAAK;AAAA,YACV,IAAI;AAAA,cACF,WAAW,SAAS,IAAI,YAAY,QAAQ;AAAA,cAC5C,YAAY;AAAA,cACZ,OAAO;AAAA,cACP,UAAU;AAAA,cACV,WAAW;AAAA,cACX,WAAW;AAAA,cACX,cAAc;AAAA,YAAA;AAAA,UAChB;AAAA,QAAA;AAAA,MACF;AAAA,IAAA;AAAA,EAAA;AAAA,EAIJ;AAAA,IAAC;AAAA,IAAA;AAAA,MACC,IAAI;AAAA,QACF,SAAS;AAAA,QACT,gBAAgB,KAAK,SAAS,UAAU,kBAAkB;AAAA,QAC1D,UAAU;AAAA,QACV,KAAK;AAAA,MAAA;AAAA,MAGN,UAAA;AAAA,QAAA,KAAK,SAAS,WACb,qBAAA,UAAA,EACE,UAAA;AAAA,UAAA,qBAAC,OAAA,EAAM,WAAU,OAAM,SAAS,GAC9B,UAAA;AAAA,YAAA;AAAA,cAAC;AAAA,cAAA;AAAA,gBACC,SAAQ;AAAA,gBACR,+BAAY,YAAA,EAAW;AAAA,gBACvB,SAAS,MAAM,QAAQ,CAAC,MAAM,KAAK,IAAI,UAAU,IAAI,SAAS,CAAC;AAAA,gBAC/D,UAAU,QAAQ;AAAA,gBACnB,UAAA;AAAA,cAAA;AAAA,YAAA;AAAA,YAGD;AAAA,cAAC;AAAA,cAAA;AAAA,gBACC,SAAQ;AAAA,gBACR,+BAAY,aAAA,EAAY;AAAA,gBACxB,SAAS,MAAM,QAAQ,CAAC,MAAM,KAAK,IAAI,UAAU,IAAI,SAAS,CAAC;AAAA,gBAC/D,UAAU,QAAQ;AAAA,gBACnB,UAAA;AAAA,cAAA;AAAA,YAAA;AAAA,UAED,GACF;AAAA,UACA,qBAAC,OAAA,EAAM,WAAU,OAAM,SAAS,GAC9B,UAAA;AAAA,YAAA;AAAA,cAAC;AAAA,cAAA;AAAA,gBACC,SAAQ;AAAA,gBACR,cAAW;AAAA,gBACX,SAAS,MAAM,YAAY,CAAC,OAAO,IAAI,MAAM,GAAG;AAAA,gBAEhD,8BAAC,gBAAA,CAAA,CAAe;AAAA,cAAA;AAAA,YAAA;AAAA,YAElB;AAAA,cAAC;AAAA,cAAA;AAAA,gBACC,SAAQ;AAAA,gBACR,cAAW;AAAA,gBACX,SAAS,MAAM,YAAY,CAAC,OAAO,IAAI,MAAM,GAAG;AAAA,gBAEhD,8BAAC,iBAAA,CAAA,CAAgB;AAAA,cAAA;AAAA,YAAA;AAAA,UACnB,GACF;AAAA,UACA;AAAA,YAAC;AAAA,YAAA;AAAA,cACC,SAAQ;AAAA,cACR,+BAAY,gBAAA,EAAe;AAAA,cAC3B,SAAS,MAAM;AACb,wBAAQ,CAAC;AACT,4BAAY,CAAC;AAAA,cACf;AAAA,cACD,UAAA;AAAA,YAAA;AAAA,UAAA;AAAA,QAED,GACF;AAAA,QAEF;AAAA,UAAC;AAAA,UAAA;AAAA,YACC,SAAQ;AAAA,YACR,+BAAY,WAAA,EAAU;AAAA,YACtB,SAAS;AAAA,YACV,UAAA;AAAA,UAAA;AAAA,QAAA;AAAA,MAED;AAAA,IAAA;AAAA,EAAA;AACF,GACF;AClJK,MAAM,UAAkC,CAAC;AAAA,EAC9C;AAAA,EACA,WAAW;AAAA,EACX;AAAA,EACA;AAAA,EACA;AACF,MAAM;AACJ,QAAM,QAAQ,SAAA;AACd,QAAM,WAAW,cAAc,mBAAmB;AAClD,QAAM,CAAC,aAAa,cAAc,IAAI,SAAS,CAAC;AAChD,QAAM,CAAC,cAAc,eAAe,IAAI,SAAS,KAAK;AACtD,QAAM,CAAC,MAAM,OAAO,IAAI,SAAS,CAAC;AAClC,QAAM,CAAC,UAAU,WAAW,IAAI,SAAS,CAAC;AAC1C,QAAM,WAAW,OAAgC,IAAI;AAErD,QAAM,CAAC,eAAe,gBAAgB,IAAI,SAAS,CAAC;AACpD,QAAM,sBAAsB,WAAW,IAAI;AAE3C,QAAM,gBAAgB,MAAM;AAC1B,qBAAiB,CAAC,SAAS,KAAK,IAAI,GAAG,OAAO,CAAC,CAAC;AAAA,EAClD;AACA,QAAM,kBAAkB,MAAM;AAC5B;AAAA,MAAiB,CAAC,SAChB,KAAK,IAAI,GAAG,KAAK,IAAI,MAAM,SAAS,qBAAqB,OAAO,CAAC,CAAC;AAAA,IAAA;AAAA,EAEtE;AAEA,QAAM,aAAa,MAAM;AACvB,mBAAe,CAAC,QAAS,QAAQ,IAAI,MAAM,SAAS,IAAI,MAAM,CAAE;AAAA,EAClE;AACA,QAAM,aAAa,MAAM;AACvB,mBAAe,CAAC,QAAS,QAAQ,MAAM,SAAS,IAAI,IAAI,MAAM,CAAE;AAAA,EAClE;AAEA,YAAU,MAAM;AACd,QAAI,CAAC,aAAc;AACnB,UAAM,YAAY,CAAC,MAAqB;AACtC,cAAQ,EAAE,KAAA;AAAA,QACR,KAAK;AACH,qBAAA;AACA;AAAA,QACF,KAAK;AACH,qBAAA;AACA;AAAA,QACF,KAAK;AACH,0BAAgB,KAAK;AACrB;AAAA,MAAA;AAAA,IAEN;AACA,WAAO,iBAAiB,WAAW,SAAS;AAC5C,WAAO,MAAM,OAAO,oBAAoB,WAAW,SAAS;AAAA,EAC9D,GAAG,CAAC,cAAc,MAAM,MAAM,CAAC;AAI/B,YAAU,MAAM;;AACd,QACE,kBACA,WAAM,WAAW,MAAjB,mBAAoB,UAAS,WAC7B,SAAS,SACT;AACA,eAAS,QAAQ,cAAc;AAC/B,eAAS,QAAQ,KAAA,EAAO,MAAM,MAAM;AAAA,MAEpC,CAAC;AAAA,IACH;AACA,YAAQ,CAAC;AACT,gBAAY,CAAC;AAAA,EACf,GAAG,CAAC,cAAc,aAAa,KAAK,CAAC;AAErC,MAAI,CAAC,SAAS,MAAM,WAAW,EAAG,QAAO;AAEzC,QAAM,kBAAkB,KAAK,IAAI,GAAG,KAAK,IAAI,aAAa,MAAM,SAAS,CAAC,CAAC;AAC3E,QAAM,cAAc,MAAM,eAAe;AAEzC,QAAM,WAAW,cAAc,WAAW,QAAQ,KAAK;AAEvD,QAAM,SAAyB;AAAA,IAC7B,EAAE,UAAU,IAAI,QAAQ,WAAW,IAAA;AAAA,IACnC,GAAI,WAAW,CAAC,QAAQ,IAAI,CAAA;AAAA,IAC5B,GAAI,MAAM,QAAQ,EAAE,IAAI,KAAK,KAAK,CAAC,EAAE,IAAI,CAAA;AAAA,EAAC;AAG5C,SACE;AAAA,IAAC;AAAA,IAAA;AAAA,MACC,WAAW,WAAW,WAAW;AAAA,MACjC,KAAK;AAAA,MACL;AAAA,MACA,IAAI;AAAA,MAEJ,UAAA;AAAA,QAAA;AAAA,UAAC;AAAA,UAAA;AAAA,YACC;AAAA,YACA,aAAa;AAAA,YACb,UAAU;AAAA,YACV;AAAA,YACA,cAAc;AAAA,YACd,WAAW;AAAA,YACX,aAAa;AAAA,YACb;AAAA,UAAA;AAAA,QAAA;AAAA,QAEF;AAAA,UAAC;AAAA,UAAA;AAAA,YACC,MAAM;AAAA,YACN,gBAAgB,MAAM,gBAAgB,IAAI;AAAA,YAC1C;AAAA,UAAA;AAAA,QAAA;AAAA,QAEF;AAAA,UAAC;AAAA,UAAA;AAAA,YACC,MAAM;AAAA,YACN,SAAS,MAAM,gBAAgB,KAAK;AAAA,YACpC,MAAM;AAAA,YACN,QAAQ;AAAA,YACR,QAAQ;AAAA,YACR;AAAA,YACA;AAAA,YACA;AAAA,YACA;AAAA,YACA;AAAA,UAAA;AAAA,QAAA;AAAA,MACF;AAAA,IAAA;AAAA,EAAA;AAGN;"}
@@ -1,20 +1,16 @@
1
1
  import { default as React } from 'react';
2
+ import { GalleryItem } from './Gallery';
2
3
  interface Props {
3
4
  open: boolean;
4
5
  onClose: () => void;
5
- item: {
6
- url: string;
7
- type: "image" | "video" | string;
8
- title: string;
9
- thumbnail: string;
10
- };
11
- handlePrev: () => void;
12
- handleNext: () => void;
6
+ item: GalleryItem;
7
+ onPrev: () => void;
8
+ onNext: () => void;
13
9
  zoom: number;
14
10
  setZoom: React.Dispatch<React.SetStateAction<number>>;
15
11
  rotation: number;
16
12
  setRotation: React.Dispatch<React.SetStateAction<number>>;
17
13
  videoRef?: React.RefObject<HTMLVideoElement | null>;
18
14
  }
19
- export declare const GalleryLightbox: ({ open, onClose, item, handlePrev, handleNext, zoom, setZoom, rotation, setRotation, videoRef, }: Props) => import("react/jsx-runtime").JSX.Element;
20
- export {};
15
+ export declare const GalleryLightbox: ({ open, onClose, item, onPrev, onNext, zoom, setZoom, rotation, setRotation, videoRef, }: Props) => import("react/jsx-runtime").JSX.Element;
16
+ export default GalleryLightbox;
@@ -1,12 +1,8 @@
1
+ import { GalleryItem } from './Gallery';
1
2
  interface Props {
2
- item: {
3
- url: string;
4
- type: "image" | "video" | string;
5
- title: string;
6
- thumbnail: string;
7
- };
3
+ item: GalleryItem;
8
4
  onOpenLightbox: () => void;
9
5
  isMobile: boolean;
10
6
  }
11
7
  export declare const GalleryMain: ({ item, onOpenLightbox, isMobile }: Props) => import("react/jsx-runtime").JSX.Element;
12
- export {};
8
+ export default GalleryMain;
@@ -1,17 +1,13 @@
1
+ import { GalleryItem } from './Gallery';
1
2
  interface Props {
2
- items: Array<{
3
- url: string;
4
- type: string;
5
- title: string;
6
- thumbnail: string;
7
- }>;
3
+ items: GalleryItem[];
8
4
  selectedIdx: number;
9
5
  onSelect: (idx: number) => void;
10
6
  thumbStartIdx: number;
11
- THUMB_VISIBLE_COUNT: number;
12
- handleThumbUp: () => void;
13
- handleThumbDown: () => void;
7
+ visibleCount: number;
8
+ onThumbUp: () => void;
9
+ onThumbDown: () => void;
14
10
  isMobile: boolean;
15
11
  }
16
- export declare const GalleryThumbnails: ({ items, selectedIdx, onSelect, thumbStartIdx, THUMB_VISIBLE_COUNT, handleThumbUp, handleThumbDown, isMobile, }: Props) => import("react/jsx-runtime").JSX.Element;
17
- export {};
12
+ export declare const GalleryThumbnails: ({ items, selectedIdx, onSelect, thumbStartIdx, visibleCount, onThumbUp, onThumbDown, isMobile, }: Props) => import("react/jsx-runtime").JSX.Element;
13
+ export default GalleryThumbnails;
@@ -1 +1,2 @@
1
- export { default as Gallery } from './Gallery';
1
+ export { Gallery, default } from './Gallery';
2
+ export type { GalleryProps, GalleryItem } from './Gallery';
@@ -1,2 +1,6 @@
1
1
  export * from './Gallery/index'
2
2
  export {}
3
+ import _default from './Gallery/index'
4
+ export default _default
5
+ export * from './Gallery/index'
6
+ export {}
@@ -1,6 +1,5 @@
1
1
  "use strict";
2
- Object.defineProperty(exports, Symbol.toStringTag, { value: "Module" });
3
- require('../../styles.css');;/* empty css */
2
+ Object.defineProperties(exports, { __esModule: { value: true }, [Symbol.toStringTag]: { value: "Module" } });
4
3
  const jsxRuntime = require("react/jsx-runtime");
5
4
  const React = require("react");
6
5
  const material = require("@mui/material");
@@ -54,13 +53,10 @@ const Icon = ({
54
53
  size = "sm",
55
54
  black,
56
55
  white,
57
- className
56
+ className,
57
+ sx
58
58
  }) => {
59
- const finalColor = React.useMemo(() => {
60
- if (white) return "white";
61
- if (black) return "black";
62
- return color;
63
- }, [color, white, black]);
59
+ const finalColor = white ? "white" : black ? "black" : color;
64
60
  const iconSize = sizeMap[size];
65
61
  const content = React.useMemo(() => {
66
62
  if (children) return children;
@@ -101,6 +97,7 @@ const Icon = ({
101
97
  spin,
102
98
  outlined,
103
99
  className: `hsi-icon ${className || ""}`,
100
+ sx,
104
101
  children: content
105
102
  }
106
103
  )
@@ -108,4 +105,5 @@ const Icon = ({
108
105
  );
109
106
  };
110
107
  exports.Icon = Icon;
108
+ exports.default = Icon;
111
109
  //# sourceMappingURL=Icon.cjs.map