@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.
- package/Alert-B3SMPD1s.cjs +31 -0
- package/Alert-B3SMPD1s.cjs.map +1 -0
- package/Alert-YsPScpSE.js +32 -0
- package/Alert-YsPScpSE.js.map +1 -0
- package/Autocomplete-C_lW1VER.js +337 -0
- package/Autocomplete-C_lW1VER.js.map +1 -0
- package/Autocomplete-CejWztBY.cjs +336 -0
- package/Autocomplete-CejWztBY.cjs.map +1 -0
- package/Avatar-Dw5rzayR.cjs +166 -0
- package/Avatar-Dw5rzayR.cjs.map +1 -0
- package/Avatar-H8akSege.js +167 -0
- package/Avatar-H8akSege.js.map +1 -0
- package/Button-C17mExpd.cjs.map +1 -1
- package/Button-UkkP-bNw.js.map +1 -1
- package/Card-DYKGY-NG.js +116 -0
- package/Card-DYKGY-NG.js.map +1 -0
- package/Card-Dr1-ATRY.cjs +115 -0
- package/Card-Dr1-ATRY.cjs.map +1 -0
- package/Checkbox-BCqMFWt4.cjs +187 -0
- package/Checkbox-BCqMFWt4.cjs.map +1 -0
- package/Checkbox-gB5YKkVo.js +188 -0
- package/Checkbox-gB5YKkVo.js.map +1 -0
- package/{components/DateRangePicker/DateRangePicker.js → Chip-OPYQ1uQ_.js} +33 -35
- package/Chip-OPYQ1uQ_.js.map +1 -0
- package/{components/DateRangePicker/DateRangePicker.cjs → Chip-qoJLDiva.cjs} +33 -36
- package/Chip-qoJLDiva.cjs.map +1 -0
- package/DatePicker-_IGWc3I5.js +178 -0
- package/DatePicker-_IGWc3I5.js.map +1 -0
- package/DatePicker-t7uDTZMl.cjs +177 -0
- package/DatePicker-t7uDTZMl.cjs.map +1 -0
- package/DateTimePicker-BxQyjTCY.cjs +229 -0
- package/DateTimePicker-BxQyjTCY.cjs.map +1 -0
- package/DateTimePicker-CrmWav_j.js +230 -0
- package/DateTimePicker-CrmWav_j.js.map +1 -0
- package/Input-CScC87J5.cjs +185 -0
- package/Input-CScC87J5.cjs.map +1 -0
- package/Input-DP_fKl38.js +186 -0
- package/Input-DP_fKl38.js.map +1 -0
- package/Modal-BFpX5AFV.js +347 -0
- package/Modal-BFpX5AFV.js.map +1 -0
- package/Modal-CkpuI8ns.cjs +346 -0
- package/Modal-CkpuI8ns.cjs.map +1 -0
- package/RadioGroup-Dd0rHXSX.cjs +202 -0
- package/RadioGroup-Dd0rHXSX.cjs.map +1 -0
- package/RadioGroup-bO-ahP9T.js +203 -0
- package/RadioGroup-bO-ahP9T.js.map +1 -0
- package/Select-BY5Y0qZ1.js +376 -0
- package/Select-BY5Y0qZ1.js.map +1 -0
- package/Select-CURrHSyl.cjs +375 -0
- package/Select-CURrHSyl.cjs.map +1 -0
- package/Spinner-B6sThC1p.js +74 -0
- package/Spinner-B6sThC1p.js.map +1 -0
- package/Spinner-D7qRmNS9.cjs +73 -0
- package/Spinner-D7qRmNS9.cjs.map +1 -0
- package/Stat-BUcFCGrz.cjs +83 -0
- package/Stat-BUcFCGrz.cjs.map +1 -0
- package/Stat-C06A_izS.js +84 -0
- package/Stat-C06A_izS.js.map +1 -0
- package/StatusMessage-B3nXpuRl.cjs +88 -0
- package/StatusMessage-B3nXpuRl.cjs.map +1 -0
- package/StatusMessage-D0WgSBx7.js +89 -0
- package/StatusMessage-D0WgSBx7.js.map +1 -0
- package/Step-BArsou1V.js +301 -0
- package/Step-BArsou1V.js.map +1 -0
- package/Step-Nd7SJbRZ.cjs +300 -0
- package/Step-Nd7SJbRZ.cjs.map +1 -0
- package/Switch-CQFOopYy.cjs +182 -0
- package/Switch-CQFOopYy.cjs.map +1 -0
- package/Switch-D72dpkH2.js +183 -0
- package/Switch-D72dpkH2.js.map +1 -0
- package/Tab-BbP8jBcK.cjs +110 -0
- package/Tab-BbP8jBcK.cjs.map +1 -0
- package/Tab-BxSxKJsP.js +111 -0
- package/Tab-BxSxKJsP.js.map +1 -0
- package/Table-C2LbW0B1.js +531 -0
- package/Table-C2LbW0B1.js.map +1 -0
- package/Table-C4OM6rrC.cjs +530 -0
- package/Table-C4OM6rrC.cjs.map +1 -0
- package/components/ActionMenu/ActionMenu.cjs +52 -52
- package/components/ActionMenu/ActionMenu.cjs.map +1 -1
- package/components/ActionMenu/ActionMenu.d.ts +20 -36
- package/components/ActionMenu/ActionMenu.js +55 -55
- package/components/ActionMenu/ActionMenu.js.map +1 -1
- package/components/ActionMenu/index.d.ts +2 -2
- package/components/Alert/Alert.cjs +6 -0
- package/components/Alert/Alert.cjs.map +1 -0
- package/components/Alert/Alert.d.ts +31 -0
- package/components/Alert/Alert.js +6 -0
- package/components/Alert/Alert.js.map +1 -0
- package/components/Alert/index.d.ts +2 -0
- package/components/Alert.d.ts +6 -0
- package/components/AppBar/AppBar.cjs +3 -220
- package/components/AppBar/AppBar.cjs.map +1 -1
- package/components/AppBar/AppBar.d.ts +6 -6
- package/components/AppBar/AppBar.js +6 -223
- package/components/AppBar/AppBar.js.map +1 -1
- package/components/AppBar/index.d.ts +0 -6
- package/components/Autocomplete/Autocomplete.cjs +4 -311
- package/components/Autocomplete/Autocomplete.cjs.map +1 -1
- package/components/Autocomplete/Autocomplete.d.ts +8 -6
- package/components/Autocomplete/Autocomplete.helpers.d.ts +8 -4
- package/components/Autocomplete/Autocomplete.js +4 -311
- package/components/Autocomplete/Autocomplete.js.map +1 -1
- package/components/Autocomplete/_parts/AutocompleteOption.d.ts +5 -8
- package/components/Autocomplete/index.d.ts +1 -1
- package/components/Avatar/Avatar.cjs +2 -160
- package/components/Avatar/Avatar.cjs.map +1 -1
- package/components/Avatar/Avatar.d.ts +16 -1
- package/components/Avatar/Avatar.js +2 -160
- package/components/Avatar/Avatar.js.map +1 -1
- package/components/Avatar/index.d.ts +1 -0
- package/components/Button/Button.d.ts +5 -5
- package/components/Button/index.d.ts +1 -0
- package/components/Card/Card.cjs +4 -184
- package/components/Card/Card.cjs.map +1 -1
- package/components/Card/Card.d.ts +21 -50
- package/components/Card/Card.js +4 -184
- package/components/Card/Card.js.map +1 -1
- package/components/Card/Card.sx.d.ts +3 -6
- package/components/Card/index.d.ts +1 -1
- package/components/Checkbox/Checkbox.cjs +6 -0
- package/components/Checkbox/Checkbox.cjs.map +1 -0
- package/components/Checkbox/Checkbox.d.ts +55 -0
- package/components/Checkbox/Checkbox.js +6 -0
- package/components/Checkbox/Checkbox.js.map +1 -0
- package/components/Checkbox/Checkbox.sx.d.ts +13 -0
- package/components/Checkbox/index.d.ts +2 -0
- package/components/Checkbox.d.ts +6 -0
- package/components/Chip/Chip.cjs +4 -72
- package/components/Chip/Chip.cjs.map +1 -1
- package/components/Chip/Chip.js +3 -71
- package/components/Chip/Chip.js.map +1 -1
- package/components/Chip/index.d.ts +2 -1
- package/components/Chip.d.ts +4 -0
- package/components/Column/Column.cjs +1 -1
- package/components/Column/Column.cjs.map +1 -1
- package/components/Column/Column.d.ts +1 -1
- package/components/Column/Column.js +1 -1
- package/components/Column/Column.js.map +1 -1
- package/components/Column/index.d.ts +1 -0
- package/components/DatePicker/DatePicker.cjs +3 -200
- package/components/DatePicker/DatePicker.cjs.map +1 -1
- package/components/DatePicker/DatePicker.d.ts +1 -13
- package/components/DatePicker/DatePicker.js +3 -200
- package/components/DatePicker/DatePicker.js.map +1 -1
- package/components/DatePicker/index.d.ts +1 -1
- package/components/DateTimePicker/DateTimePicker.cjs +3 -219
- package/components/DateTimePicker/DateTimePicker.cjs.map +1 -1
- package/components/DateTimePicker/DateTimePicker.d.ts +10 -6
- package/components/DateTimePicker/DateTimePicker.definitions.d.ts +2 -0
- package/components/DateTimePicker/DateTimePicker.helpers.d.ts +4 -2
- package/components/DateTimePicker/DateTimePicker.js +3 -219
- package/components/DateTimePicker/DateTimePicker.js.map +1 -1
- package/components/DateTimePicker/index.d.ts +1 -1
- package/components/Drawer/Drawer.cjs +25 -24
- package/components/Drawer/Drawer.cjs.map +1 -1
- package/components/Drawer/Drawer.d.ts +8 -1
- package/components/Drawer/Drawer.js +26 -25
- package/components/Drawer/Drawer.js.map +1 -1
- package/components/Drawer/DrawerItem.d.ts +6 -1
- package/components/Gallery/Gallery.cjs +154 -79
- package/components/Gallery/Gallery.cjs.map +1 -1
- package/components/Gallery/Gallery.d.ts +25 -9
- package/components/Gallery/Gallery.js +154 -79
- package/components/Gallery/Gallery.js.map +1 -1
- package/components/Gallery/GalleryLightbox.d.ts +6 -10
- package/components/Gallery/GalleryMain.d.ts +3 -7
- package/components/Gallery/GalleryThumbnails.d.ts +7 -11
- package/components/Gallery/index.d.ts +2 -1
- package/components/Gallery.d.ts +4 -0
- package/components/Icon/Icon.cjs +6 -8
- package/components/Icon/Icon.cjs.map +1 -1
- package/components/Icon/Icon.d.ts +11 -17
- package/components/Icon/Icon.js +6 -8
- package/components/Icon/Icon.js.map +1 -1
- package/components/Icon/index.d.ts +2 -1
- package/components/Icon.d.ts +4 -0
- package/components/Input/Input.cjs +3 -172
- package/components/Input/Input.cjs.map +1 -1
- package/components/Input/Input.d.ts +9 -2
- package/components/Input/Input.definitions.d.ts +1 -0
- package/components/Input/Input.helpers.d.ts +3 -3
- package/components/Input/Input.js +3 -172
- package/components/Input/Input.js.map +1 -1
- package/components/Input/index.d.ts +1 -1
- package/components/InputGroup/InputGroup.cjs +23 -22
- package/components/InputGroup/InputGroup.cjs.map +1 -1
- package/components/InputGroup/InputGroup.d.ts +4 -4
- package/components/InputGroup/InputGroup.js +22 -21
- package/components/InputGroup/InputGroup.js.map +1 -1
- package/components/InputGroup/index.d.ts +2 -1
- package/components/InputGroup.d.ts +4 -0
- package/components/Modal/Modal.cjs +7 -317
- package/components/Modal/Modal.cjs.map +1 -1
- package/components/Modal/Modal.d.ts +20 -5
- package/components/Modal/Modal.js +6 -316
- package/components/Modal/Modal.js.map +1 -1
- package/components/Modal/ModalBody.d.ts +6 -1
- package/components/Modal/ModalFooter.d.ts +4 -4
- package/components/Modal/ModalHeader.d.ts +6 -1
- package/components/Modal/index.d.ts +3 -1
- package/components/Modal.d.ts +4 -0
- package/components/RadioGroup/RadioGroup.cjs +6 -0
- package/components/RadioGroup/RadioGroup.cjs.map +1 -0
- package/components/RadioGroup/RadioGroup.d.ts +59 -0
- package/components/RadioGroup/RadioGroup.definitions.d.ts +6 -0
- package/components/RadioGroup/RadioGroup.js +6 -0
- package/components/RadioGroup/RadioGroup.js.map +1 -0
- package/components/RadioGroup/RadioGroup.sx.d.ts +20 -0
- package/components/RadioGroup/index.d.ts +2 -0
- package/components/RadioGroup.d.ts +6 -0
- package/components/Select/Select.cjs +4 -445
- package/components/Select/Select.cjs.map +1 -1
- package/components/Select/Select.d.ts +37 -18
- package/components/Select/Select.helpers.d.ts +5 -19
- package/components/Select/Select.js +4 -445
- package/components/Select/Select.js.map +1 -1
- package/components/Select/index.d.ts +1 -1
- package/components/Spinner/Spinner.cjs +6 -0
- package/components/Spinner/Spinner.cjs.map +1 -0
- package/components/Spinner/Spinner.d.ts +26 -0
- package/components/Spinner/Spinner.js +6 -0
- package/components/Spinner/Spinner.js.map +1 -0
- package/components/Spinner/index.d.ts +2 -0
- package/components/Spinner.d.ts +6 -0
- package/components/Stat/Stat.cjs +4 -83
- package/components/Stat/Stat.cjs.map +1 -1
- package/components/Stat/Stat.js +3 -82
- package/components/Stat/Stat.js.map +1 -1
- package/components/Stat/index.d.ts +2 -1
- package/components/Stat.d.ts +4 -0
- package/components/StatusMessage/StatusMessage.cjs +4 -77
- package/components/StatusMessage/StatusMessage.cjs.map +1 -1
- package/components/StatusMessage/StatusMessage.d.ts +20 -36
- package/components/StatusMessage/StatusMessage.js +3 -76
- package/components/StatusMessage/StatusMessage.js.map +1 -1
- package/components/StatusMessage/index.d.ts +2 -1
- package/components/StatusMessage.d.ts +4 -0
- package/components/Stepper/Stepper.cjs +8 -47
- package/components/Stepper/Stepper.cjs.map +1 -1
- package/components/Stepper/Stepper.d.ts +9 -8
- package/components/Stepper/Stepper.js +7 -46
- package/components/Stepper/Stepper.js.map +1 -1
- package/{hooks/Wizard/WizardContext.d.ts → components/Stepper/StepperContext.d.ts} +29 -23
- package/components/Stepper/_hooks/useHorizontalScroll.d.ts +19 -0
- package/components/Stepper/_parts/StepperScrollArrow.d.ts +19 -0
- package/components/Stepper/index.d.ts +6 -2
- package/components/Stepper.d.ts +4 -0
- package/components/Switch/Switch.cjs +6 -0
- package/components/Switch/Switch.cjs.map +1 -0
- package/components/Switch/Switch.d.ts +48 -0
- package/components/Switch/Switch.definitions.d.ts +7 -0
- package/components/Switch/Switch.js +6 -0
- package/components/Switch/Switch.js.map +1 -0
- package/components/Switch/Switch.sx.d.ts +22 -0
- package/components/Switch/Switch.types.d.ts +1 -0
- package/components/Switch/index.d.ts +2 -0
- package/components/Switch.d.ts +6 -0
- package/components/Table/Table.cjs +2 -528
- package/components/Table/Table.cjs.map +1 -1
- package/components/Table/Table.d.ts +1 -1
- package/components/Table/Table.js +2 -528
- package/components/Table/Table.js.map +1 -1
- package/components/Tabs/Tabs.cjs +5 -94
- package/components/Tabs/Tabs.cjs.map +1 -1
- package/components/Tabs/Tabs.d.ts +21 -16
- package/components/Tabs/Tabs.js +4 -93
- package/components/Tabs/Tabs.js.map +1 -1
- package/components/Tabs/index.d.ts +4 -2
- package/components/Tabs.d.ts +4 -0
- package/components/Timeline/Timeline.cjs +3 -2
- package/components/Timeline/Timeline.cjs.map +1 -1
- package/components/Timeline/Timeline.d.ts +4 -8
- package/components/Timeline/Timeline.js +3 -2
- package/components/Timeline/Timeline.js.map +1 -1
- package/components/Timeline/index.d.ts +4 -2
- package/components/Timeline.d.ts +4 -0
- package/components/_shared/mergeSx.d.ts +7 -0
- package/{formField.sx-DfVbMe0V.js → formField.sx-8_QRnKxv.js} +2 -11
- package/formField.sx-8_QRnKxv.js.map +1 -0
- package/{formField.sx-CQ1mbk9M.cjs → formField.sx-BAX7KwMR.cjs} +10 -19
- package/formField.sx-BAX7KwMR.cjs.map +1 -0
- package/index.cjs +96 -6
- package/index.cjs.map +1 -1
- package/index.d.ts +36 -0
- package/index.js +70 -4
- package/index.js.map +1 -1
- package/local/affiliations/affiliations.dev.soyfri.com-key.pem +28 -0
- package/local/affiliations/affiliations.dev.soyfri.com.pem +27 -0
- package/local/aficiliaciones/afiliaciones.dev.soyfri.com-key.pem +28 -0
- package/local/aficiliaciones/afiliaciones.dev.soyfri.com.pem +27 -0
- package/local/afiliaciones/afiliaciones.dev.soyfri.com-key.pem +28 -0
- package/local/afiliaciones/afiliaciones.dev.soyfri.com.pem +27 -0
- package/local/root/rootCA-key.pem +40 -0
- package/local/root/rootCA.pem +30 -0
- package/local/soporte/supportweb.dev.soyfri.com-key.pem +28 -0
- package/local/soporte/supportweb.dev.soyfri.com.pem +27 -0
- package/local/support/supportweb.dev.soyfri.com-key.pem +28 -0
- package/local/support/supportweb.dev.soyfri.com.pem +27 -0
- package/mergeSx-BXoNZjB_.js +10 -0
- package/mergeSx-BXoNZjB_.js.map +1 -0
- package/mergeSx-Dbccoo_H.cjs +9 -0
- package/mergeSx-Dbccoo_H.cjs.map +1 -0
- package/mui.d.ts +3 -1
- package/package.json +78 -73
- package/{resolvePreset-CT3kU-K2.cjs → resolvePreset-CxTI6_Ln.cjs} +3 -3
- package/{resolvePreset-CT3kU-K2.cjs.map → resolvePreset-CxTI6_Ln.cjs.map} +1 -1
- package/{resolvePreset-B-IB0ehH.js → resolvePreset-K6_BfWHD.js} +3 -3
- package/{resolvePreset-B-IB0ehH.js.map → resolvePreset-K6_BfWHD.js.map} +1 -1
- package/theme/componentStyles.d.ts +1 -1
- package/tokens-BRrcP_p_.js +21 -0
- package/tokens-BRrcP_p_.js.map +1 -0
- package/tokens-jaWWNk39.cjs +20 -0
- package/tokens-jaWWNk39.cjs.map +1 -0
- package/utils/index.d.ts +2 -0
- package/{components/ScrollTopButton → utils}/scrollToTop.d.ts +6 -7
- package/components/AppBar/AppBarBrand.d.ts +0 -31
- package/components/AppBar/AppBarUserMenu.d.ts +0 -65
- package/components/Autocomplete/Autocomplete.types.d.ts +0 -1
- package/components/DatePicker/DatePicker.types.d.ts +0 -1
- package/components/DateRangePicker/DateRangePicker.cjs.map +0 -1
- package/components/DateRangePicker/DateRangePicker.d.ts +0 -15
- package/components/DateRangePicker/DateRangePicker.definitions.d.ts +0 -6
- package/components/DateRangePicker/DateRangePicker.js.map +0 -1
- package/components/DateRangePicker/index.d.ts +0 -1
- package/components/DateRangePicker.d.ts +0 -2
- package/components/DateTimePicker/DateTimePicker.types.d.ts +0 -1
- package/components/Input/Input.types.d.ts +0 -1
- package/components/PageLoader/PageLoader.cjs +0 -61
- package/components/PageLoader/PageLoader.cjs.map +0 -1
- package/components/PageLoader/PageLoader.d.ts +0 -38
- package/components/PageLoader/PageLoader.js +0 -61
- package/components/PageLoader/PageLoader.js.map +0 -1
- package/components/PageLoader/index.d.ts +0 -2
- package/components/PageLoader.d.ts +0 -6
- package/components/ScrollTopButton/ScrollTopButton.cjs +0 -79
- package/components/ScrollTopButton/ScrollTopButton.cjs.map +0 -1
- package/components/ScrollTopButton/ScrollTopButton.d.ts +0 -48
- package/components/ScrollTopButton/ScrollTopButton.js +0 -79
- package/components/ScrollTopButton/ScrollTopButton.js.map +0 -1
- package/components/ScrollTopButton/index.d.ts +0 -4
- package/components/ScrollTopButton.d.ts +0 -6
- package/components/Select/Select.definitions.d.ts +0 -17
- package/components/Select/Select.types.d.ts +0 -1
- package/components/Select/_parts/SelectSearchHeader.d.ts +0 -15
- package/formField.sx-CQ1mbk9M.cjs.map +0 -1
- package/formField.sx-DfVbMe0V.js.map +0 -1
- package/hooks/Wizard/Wizard.cjs +0 -7
- package/hooks/Wizard/Wizard.cjs.map +0 -1
- package/hooks/Wizard/Wizard.js +0 -7
- package/hooks/Wizard/Wizard.js.map +0 -1
- package/hooks/Wizard/index.d.ts +0 -3
- package/hooks/Wizard/useWizard.d.ts +0 -9
- package/hooks/Wizard.d.ts +0 -2
- package/useWizard-CWdIxZzX.cjs +0 -94
- package/useWizard-CWdIxZzX.cjs.map +0 -1
- package/useWizard-CWq--C3o.js +0 -95
- package/useWizard-CWq--C3o.js.map +0 -1
- /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
|
-
|
|
24
|
-
|
|
25
|
-
|
|
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: "
|
|
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:
|
|
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 +
|
|
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
|
-
|
|
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:
|
|
81
|
+
border: (theme) => `2px solid ${isSelected ? theme.palette.primary.main : theme.palette.divider}`,
|
|
66
82
|
overflow: "hidden",
|
|
67
|
-
bgcolor: "
|
|
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:
|
|
96
|
-
disabled: thumbStartIdx +
|
|
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: "
|
|
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: "
|
|
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:
|
|
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: "
|
|
172
|
-
|
|
196
|
+
bgcolor: "primary.main",
|
|
197
|
+
color: "primary.contrastText",
|
|
198
|
+
"&:hover": { bgcolor: "primary.dark" },
|
|
173
199
|
boxShadow: 2
|
|
174
200
|
},
|
|
175
|
-
children: /* @__PURE__ */ jsx(FullscreenIcon, {
|
|
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
|
-
|
|
186
|
-
|
|
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(
|
|
206
|
-
|
|
207
|
-
|
|
208
|
-
|
|
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:
|
|
266
|
+
maxWidth: 900,
|
|
221
267
|
maxHeight: "70vh",
|
|
222
268
|
objectFit: "contain",
|
|
223
|
-
bgcolor: "
|
|
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:
|
|
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 +
|
|
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(
|
|
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
|
-
|
|
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
|
-
|
|
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 = ({
|
|
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
|
-
|
|
376
|
-
|
|
377
|
-
|
|
378
|
-
|
|
379
|
-
|
|
380
|
-
|
|
381
|
-
|
|
382
|
-
|
|
383
|
-
|
|
384
|
-
|
|
385
|
-
|
|
386
|
-
|
|
387
|
-
|
|
388
|
-
|
|
389
|
-
|
|
390
|
-
|
|
391
|
-
|
|
392
|
-
|
|
393
|
-
|
|
394
|
-
|
|
395
|
-
|
|
396
|
-
|
|
397
|
-
|
|
398
|
-
|
|
399
|
-
|
|
400
|
-
|
|
401
|
-
|
|
402
|
-
|
|
403
|
-
|
|
404
|
-
|
|
405
|
-
|
|
406
|
-
|
|
407
|
-
|
|
408
|
-
|
|
409
|
-
|
|
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":"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"}
|
|
@@ -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
|
-
|
|
7
|
-
|
|
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,
|
|
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:
|
|
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
|
-
|
|
12
|
-
|
|
13
|
-
|
|
7
|
+
visibleCount: number;
|
|
8
|
+
onThumbUp: () => void;
|
|
9
|
+
onThumbDown: () => void;
|
|
14
10
|
isMobile: boolean;
|
|
15
11
|
}
|
|
16
|
-
export declare const GalleryThumbnails: ({ items, selectedIdx, onSelect, thumbStartIdx,
|
|
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
|
|
1
|
+
export { Gallery, default } from './Gallery';
|
|
2
|
+
export type { GalleryProps, GalleryItem } from './Gallery';
|
package/components/Gallery.d.ts
CHANGED
package/components/Icon/Icon.cjs
CHANGED
|
@@ -1,6 +1,5 @@
|
|
|
1
1
|
"use strict";
|
|
2
|
-
Object.
|
|
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 =
|
|
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
|