@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
package/Step-BArsou1V.js
ADDED
|
@@ -0,0 +1,301 @@
|
|
|
1
|
+
import { jsx, jsxs } from "react/jsx-runtime";
|
|
2
|
+
import { createContext, useState, useCallback, useMemo, useContext, useRef, useLayoutEffect, useEffect, Children, isValidElement } from "react";
|
|
3
|
+
import { IconButton, Box, Stepper as Stepper$1, Step as Step$1, StepLabel } from "@mui/material";
|
|
4
|
+
import ChevronLeftIcon from "@mui/icons-material/ChevronLeft";
|
|
5
|
+
import ChevronRightIcon from "@mui/icons-material/ChevronRight";
|
|
6
|
+
const defaultValue = {
|
|
7
|
+
currentStep: 0,
|
|
8
|
+
totalSteps: 0,
|
|
9
|
+
isFirst: true,
|
|
10
|
+
isLast: true,
|
|
11
|
+
completed: false,
|
|
12
|
+
nextStep: () => {
|
|
13
|
+
},
|
|
14
|
+
prevStep: () => {
|
|
15
|
+
},
|
|
16
|
+
goToStep: () => {
|
|
17
|
+
},
|
|
18
|
+
submitStep: () => {
|
|
19
|
+
},
|
|
20
|
+
reset: () => {
|
|
21
|
+
}
|
|
22
|
+
};
|
|
23
|
+
const StepperContext = createContext(defaultValue);
|
|
24
|
+
function useStepper() {
|
|
25
|
+
return useContext(StepperContext);
|
|
26
|
+
}
|
|
27
|
+
const StepperProvider = ({
|
|
28
|
+
totalSteps,
|
|
29
|
+
initialStep = 0,
|
|
30
|
+
onSubmit,
|
|
31
|
+
onStepChange,
|
|
32
|
+
children
|
|
33
|
+
}) => {
|
|
34
|
+
const [currentStep, setCurrentStep] = useState(initialStep);
|
|
35
|
+
const [completed, setCompleted] = useState(false);
|
|
36
|
+
const changeStep = useCallback(
|
|
37
|
+
(newStep) => {
|
|
38
|
+
setCurrentStep((prev) => {
|
|
39
|
+
if (newStep === prev) return prev;
|
|
40
|
+
if (newStep < 0 || newStep >= totalSteps) return prev;
|
|
41
|
+
onStepChange == null ? void 0 : onStepChange(newStep, prev);
|
|
42
|
+
return newStep;
|
|
43
|
+
});
|
|
44
|
+
},
|
|
45
|
+
[totalSteps, onStepChange]
|
|
46
|
+
);
|
|
47
|
+
const nextStep = useCallback(() => {
|
|
48
|
+
changeStep(currentStep + 1);
|
|
49
|
+
}, [changeStep, currentStep]);
|
|
50
|
+
const prevStep = useCallback(() => {
|
|
51
|
+
changeStep(currentStep - 1);
|
|
52
|
+
}, [changeStep, currentStep]);
|
|
53
|
+
const goToStep = useCallback(
|
|
54
|
+
(stepNumber) => {
|
|
55
|
+
changeStep(stepNumber);
|
|
56
|
+
},
|
|
57
|
+
[changeStep]
|
|
58
|
+
);
|
|
59
|
+
const submitStep = useCallback(() => {
|
|
60
|
+
setCompleted(true);
|
|
61
|
+
onSubmit == null ? void 0 : onSubmit(currentStep);
|
|
62
|
+
}, [currentStep, onSubmit]);
|
|
63
|
+
const reset = useCallback(() => {
|
|
64
|
+
setCurrentStep(initialStep);
|
|
65
|
+
setCompleted(false);
|
|
66
|
+
}, [initialStep]);
|
|
67
|
+
const value = useMemo(
|
|
68
|
+
() => ({
|
|
69
|
+
currentStep,
|
|
70
|
+
totalSteps,
|
|
71
|
+
isFirst: currentStep === 0,
|
|
72
|
+
isLast: currentStep === totalSteps - 1,
|
|
73
|
+
completed,
|
|
74
|
+
nextStep,
|
|
75
|
+
prevStep,
|
|
76
|
+
goToStep,
|
|
77
|
+
submitStep,
|
|
78
|
+
reset
|
|
79
|
+
}),
|
|
80
|
+
[
|
|
81
|
+
currentStep,
|
|
82
|
+
totalSteps,
|
|
83
|
+
completed,
|
|
84
|
+
nextStep,
|
|
85
|
+
prevStep,
|
|
86
|
+
goToStep,
|
|
87
|
+
submitStep,
|
|
88
|
+
reset
|
|
89
|
+
]
|
|
90
|
+
);
|
|
91
|
+
return /* @__PURE__ */ jsx(StepperContext.Provider, { value, children });
|
|
92
|
+
};
|
|
93
|
+
function useHorizontalScroll(enabled, deps = []) {
|
|
94
|
+
const scrollRef = useRef(null);
|
|
95
|
+
const [canScrollLeft, setCanScrollLeft] = useState(false);
|
|
96
|
+
const [canScrollRight, setCanScrollRight] = useState(false);
|
|
97
|
+
const updateScrollState = useCallback(() => {
|
|
98
|
+
const el = scrollRef.current;
|
|
99
|
+
if (!el) return;
|
|
100
|
+
const { scrollLeft, scrollWidth, clientWidth } = el;
|
|
101
|
+
setCanScrollLeft(scrollLeft > 1);
|
|
102
|
+
setCanScrollRight(scrollLeft + clientWidth < scrollWidth - 1);
|
|
103
|
+
}, []);
|
|
104
|
+
useLayoutEffect(() => {
|
|
105
|
+
if (!enabled) return;
|
|
106
|
+
updateScrollState();
|
|
107
|
+
}, [enabled, updateScrollState, ...deps]);
|
|
108
|
+
useEffect(() => {
|
|
109
|
+
if (!enabled) return;
|
|
110
|
+
const el = scrollRef.current;
|
|
111
|
+
if (!el) return;
|
|
112
|
+
el.addEventListener("scroll", updateScrollState, { passive: true });
|
|
113
|
+
const ro = new ResizeObserver(updateScrollState);
|
|
114
|
+
ro.observe(el);
|
|
115
|
+
return () => {
|
|
116
|
+
el.removeEventListener("scroll", updateScrollState);
|
|
117
|
+
ro.disconnect();
|
|
118
|
+
};
|
|
119
|
+
}, [enabled, updateScrollState]);
|
|
120
|
+
const scrollBy = useCallback((delta) => {
|
|
121
|
+
const el = scrollRef.current;
|
|
122
|
+
if (!el) return;
|
|
123
|
+
el.scrollBy({ left: delta, behavior: "smooth" });
|
|
124
|
+
}, []);
|
|
125
|
+
return { scrollRef, canScrollLeft, canScrollRight, scrollBy };
|
|
126
|
+
}
|
|
127
|
+
const StepperScrollArrow = ({
|
|
128
|
+
direction,
|
|
129
|
+
enabled,
|
|
130
|
+
visible,
|
|
131
|
+
onClick
|
|
132
|
+
}) => {
|
|
133
|
+
const isLeft = direction === "left";
|
|
134
|
+
const Icon = isLeft ? ChevronLeftIcon : ChevronRightIcon;
|
|
135
|
+
const ariaLabel = isLeft ? "Anterior" : "Siguiente";
|
|
136
|
+
return /* @__PURE__ */ jsx(
|
|
137
|
+
IconButton,
|
|
138
|
+
{
|
|
139
|
+
"aria-label": ariaLabel,
|
|
140
|
+
size: "small",
|
|
141
|
+
onClick,
|
|
142
|
+
disabled: !enabled,
|
|
143
|
+
sx: {
|
|
144
|
+
flex: "0 0 auto",
|
|
145
|
+
// Reservamos el slot siempre que haya overflow en algún lado,
|
|
146
|
+
// así el área scroll tiene un ancho estable (no saltan los
|
|
147
|
+
// steps cuando aparece/desaparece la flecha).
|
|
148
|
+
visibility: visible ? "visible" : "hidden"
|
|
149
|
+
},
|
|
150
|
+
children: /* @__PURE__ */ jsx(Icon, { fontSize: "small" })
|
|
151
|
+
}
|
|
152
|
+
);
|
|
153
|
+
};
|
|
154
|
+
const Stepper = ({
|
|
155
|
+
children,
|
|
156
|
+
orientation = "horizontal",
|
|
157
|
+
alternateLabel = false,
|
|
158
|
+
currentStep: currentStepProp,
|
|
159
|
+
keepMounted = false,
|
|
160
|
+
sx
|
|
161
|
+
}) => {
|
|
162
|
+
const stepperCtx = useStepper();
|
|
163
|
+
const currentStep = currentStepProp !== void 0 ? currentStepProp : stepperCtx.totalSteps > 0 ? stepperCtx.currentStep : 0;
|
|
164
|
+
const isHorizontal = orientation === "horizontal";
|
|
165
|
+
const steps = Children.toArray(children).filter(
|
|
166
|
+
(child) => {
|
|
167
|
+
var _a;
|
|
168
|
+
return isValidElement(child) && ((_a = child.type) == null ? void 0 : _a.displayName) === "Step";
|
|
169
|
+
}
|
|
170
|
+
);
|
|
171
|
+
const { scrollRef, canScrollLeft, canScrollRight, scrollBy } = useHorizontalScroll(
|
|
172
|
+
isHorizontal,
|
|
173
|
+
[steps.length, currentStep]
|
|
174
|
+
);
|
|
175
|
+
const showArrows = isHorizontal && (canScrollLeft || canScrollRight);
|
|
176
|
+
return /* @__PURE__ */ jsxs(Box, { sx, children: [
|
|
177
|
+
/* @__PURE__ */ jsxs(
|
|
178
|
+
Box,
|
|
179
|
+
{
|
|
180
|
+
sx: isHorizontal ? { display: "flex", alignItems: "center", width: "100%", gap: 0.5 } : void 0,
|
|
181
|
+
children: [
|
|
182
|
+
isHorizontal && /* @__PURE__ */ jsx(
|
|
183
|
+
StepperScrollArrow,
|
|
184
|
+
{
|
|
185
|
+
direction: "left",
|
|
186
|
+
enabled: canScrollLeft,
|
|
187
|
+
visible: showArrows,
|
|
188
|
+
onClick: () => scrollBy(-160)
|
|
189
|
+
}
|
|
190
|
+
),
|
|
191
|
+
/* @__PURE__ */ jsx(
|
|
192
|
+
Box,
|
|
193
|
+
{
|
|
194
|
+
ref: scrollRef,
|
|
195
|
+
sx: isHorizontal ? {
|
|
196
|
+
flex: "1 1 auto",
|
|
197
|
+
minWidth: 0,
|
|
198
|
+
overflowX: "auto",
|
|
199
|
+
scrollBehavior: "smooth",
|
|
200
|
+
WebkitOverflowScrolling: "touch",
|
|
201
|
+
scrollbarWidth: "none",
|
|
202
|
+
"&::-webkit-scrollbar": { display: "none" }
|
|
203
|
+
} : void 0,
|
|
204
|
+
children: /* @__PURE__ */ jsx(
|
|
205
|
+
Stepper$1,
|
|
206
|
+
{
|
|
207
|
+
activeStep: currentStep,
|
|
208
|
+
orientation,
|
|
209
|
+
alternativeLabel: alternateLabel,
|
|
210
|
+
sx: isHorizontal ? {
|
|
211
|
+
display: "inline-flex",
|
|
212
|
+
flexWrap: "nowrap",
|
|
213
|
+
minWidth: "100%",
|
|
214
|
+
width: "max-content",
|
|
215
|
+
"& .MuiStep-root": { flex: "0 0 auto", minWidth: 120 }
|
|
216
|
+
} : void 0,
|
|
217
|
+
children: steps.map((step, idx) => {
|
|
218
|
+
var _a;
|
|
219
|
+
const {
|
|
220
|
+
label,
|
|
221
|
+
completed,
|
|
222
|
+
disabled,
|
|
223
|
+
className,
|
|
224
|
+
sx: stepSx,
|
|
225
|
+
dotColor,
|
|
226
|
+
activeDotColor,
|
|
227
|
+
completedDotColor,
|
|
228
|
+
iconTextColor
|
|
229
|
+
} = step.props;
|
|
230
|
+
const key = (_a = step.key) != null ? _a : idx;
|
|
231
|
+
return /* @__PURE__ */ jsx(
|
|
232
|
+
Step$1,
|
|
233
|
+
{
|
|
234
|
+
completed,
|
|
235
|
+
disabled,
|
|
236
|
+
className,
|
|
237
|
+
sx: stepSx,
|
|
238
|
+
children: /* @__PURE__ */ jsx(
|
|
239
|
+
StepLabel,
|
|
240
|
+
{
|
|
241
|
+
sx: {
|
|
242
|
+
pointerEvents: "none",
|
|
243
|
+
"& .MuiStepIcon-root": { color: dotColor },
|
|
244
|
+
"& .MuiStepIcon-active": { color: activeDotColor },
|
|
245
|
+
"& .MuiStepIcon-completed": { color: completedDotColor },
|
|
246
|
+
"& .MuiStepIcon-text": { fill: iconTextColor }
|
|
247
|
+
},
|
|
248
|
+
children: label
|
|
249
|
+
}
|
|
250
|
+
)
|
|
251
|
+
},
|
|
252
|
+
key
|
|
253
|
+
);
|
|
254
|
+
})
|
|
255
|
+
}
|
|
256
|
+
)
|
|
257
|
+
}
|
|
258
|
+
),
|
|
259
|
+
isHorizontal && /* @__PURE__ */ jsx(
|
|
260
|
+
StepperScrollArrow,
|
|
261
|
+
{
|
|
262
|
+
direction: "right",
|
|
263
|
+
enabled: canScrollRight,
|
|
264
|
+
visible: showArrows,
|
|
265
|
+
onClick: () => scrollBy(160)
|
|
266
|
+
}
|
|
267
|
+
)
|
|
268
|
+
]
|
|
269
|
+
}
|
|
270
|
+
),
|
|
271
|
+
/* @__PURE__ */ jsx(Box, { mt: 2, children: keepMounted ? steps.map((step, idx) => {
|
|
272
|
+
var _a;
|
|
273
|
+
const key = (_a = step.key) != null ? _a : idx;
|
|
274
|
+
const isActive = idx === currentStep;
|
|
275
|
+
return /* @__PURE__ */ jsx(
|
|
276
|
+
Box,
|
|
277
|
+
{
|
|
278
|
+
sx: { display: isActive ? "block" : "none" },
|
|
279
|
+
"aria-hidden": !isActive,
|
|
280
|
+
children: step.props.children
|
|
281
|
+
},
|
|
282
|
+
key
|
|
283
|
+
);
|
|
284
|
+
}) : steps.map((step, idx) => {
|
|
285
|
+
var _a;
|
|
286
|
+
if (idx !== currentStep) return null;
|
|
287
|
+
const key = (_a = step.key) != null ? _a : idx;
|
|
288
|
+
return /* @__PURE__ */ jsx(Box, { children: step.props.children }, key);
|
|
289
|
+
}) })
|
|
290
|
+
] });
|
|
291
|
+
};
|
|
292
|
+
const Step = (_) => null;
|
|
293
|
+
Step.displayName = "Step";
|
|
294
|
+
export {
|
|
295
|
+
Stepper as S,
|
|
296
|
+
Step as a,
|
|
297
|
+
StepperProvider as b,
|
|
298
|
+
StepperContext as c,
|
|
299
|
+
useStepper as u
|
|
300
|
+
};
|
|
301
|
+
//# sourceMappingURL=Step-BArsou1V.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"Step-BArsou1V.js","sources":["../src/components/Stepper/StepperContext.tsx","../src/components/Stepper/_hooks/useHorizontalScroll.ts","../src/components/Stepper/_parts/StepperScrollArrow.tsx","../src/components/Stepper/Stepper.tsx","../src/components/Stepper/Step.tsx"],"sourcesContent":["import {\n createContext,\n useCallback,\n useContext,\n useMemo,\n useState,\n type FC,\n type ReactNode,\n} from 'react';\n\n/**\n * API expuesta por `useStepper()`.\n */\nexport interface StepperContextValue {\n /** Índice del paso actual (0-based). */\n currentStep: number;\n /** Total de pasos del stepper. */\n totalSteps: number;\n /** True si `currentStep === 0`. */\n isFirst: boolean;\n /** True si `currentStep === totalSteps - 1`. */\n isLast: boolean;\n /** True tras ejecutar `submitStep()` desde el último paso. */\n completed: boolean;\n /** Avanza al siguiente paso (no pasa de `totalSteps - 1`). */\n nextStep: () => void;\n /** Retrocede al paso anterior (no baja de 0). */\n prevStep: () => void;\n /** Salta a un paso específico (0-based). No-op si fuera de rango. */\n goToStep: (stepNumber: number) => void;\n /**\n * Envía el stepper. Marca `completed = true` y dispara el callback\n * `onSubmit` del provider. En el último paso suele reemplazar a `nextStep`.\n */\n submitStep: () => void;\n /** Resetea al paso inicial y limpia `completed`. */\n reset: () => void;\n}\n\nconst defaultValue: StepperContextValue = {\n currentStep: 0,\n totalSteps: 0,\n isFirst: true,\n isLast: true,\n completed: false,\n nextStep: () => {},\n prevStep: () => {},\n goToStep: () => {},\n submitStep: () => {},\n reset: () => {},\n};\n\nexport const StepperContext = createContext<StepperContextValue>(defaultValue);\n\n/**\n * Hook para consumir el `StepperContext` desde cualquier descendiente de\n * `<StepperProvider>`.\n *\n * Si se llama fuera de un provider, devuelve los valores por defecto (no-op)\n * para que componentes como `<Stepper>` puedan leerlo sin romper cuando no\n * hay provider envolvente.\n */\nexport function useStepper(): StepperContextValue {\n return useContext(StepperContext);\n}\n\nexport interface StepperProviderProps {\n /** Número total de pasos. Requerido. */\n totalSteps: number;\n /** Paso inicial (0-based). Default: 0. */\n initialStep?: number;\n /**\n * Callback disparado cuando se llama `submitStep()`. Recibe el paso actual.\n * El paquete NO ejecuta ninguna petición; queda a cargo del consumer.\n */\n onSubmit?: (currentStep: number) => void;\n /**\n * Callback disparado en cada cambio de paso (next/prev/goTo).\n * Útil para tracking o validaciones externas.\n */\n onStepChange?: (newStep: number, prevStep: number) => void;\n children?: ReactNode;\n}\n\n/**\n * Provider del stepper. Administra el `currentStep` internamente. El consumer\n * no necesita gestionar estado — solo consumirlo con `useStepper()` desde\n * cualquier descendiente.\n *\n * ```tsx\n * <StepperProvider totalSteps={3} onSubmit={handleFinalSubmit}>\n * <Stepper>\n * <Step label=\"Paso 1\"><StepOne /></Step>\n * <Step label=\"Paso 2\"><StepTwo /></Step>\n * <Step label=\"Paso 3\"><StepThree /></Step>\n * </Stepper>\n * <StepperControls />\n * </StepperProvider>\n * ```\n */\nexport const StepperProvider: FC<StepperProviderProps> = ({\n totalSteps,\n initialStep = 0,\n onSubmit,\n onStepChange,\n children,\n}) => {\n const [currentStep, setCurrentStep] = useState(initialStep);\n const [completed, setCompleted] = useState(false);\n\n const changeStep = useCallback(\n (newStep: number) => {\n setCurrentStep((prev) => {\n if (newStep === prev) return prev;\n if (newStep < 0 || newStep >= totalSteps) return prev;\n onStepChange?.(newStep, prev);\n return newStep;\n });\n },\n [totalSteps, onStepChange],\n );\n\n const nextStep = useCallback(() => {\n changeStep(currentStep + 1);\n }, [changeStep, currentStep]);\n\n const prevStep = useCallback(() => {\n changeStep(currentStep - 1);\n }, [changeStep, currentStep]);\n\n const goToStep = useCallback(\n (stepNumber: number) => {\n changeStep(stepNumber);\n },\n [changeStep],\n );\n\n const submitStep = useCallback(() => {\n setCompleted(true);\n onSubmit?.(currentStep);\n }, [currentStep, onSubmit]);\n\n const reset = useCallback(() => {\n setCurrentStep(initialStep);\n setCompleted(false);\n }, [initialStep]);\n\n const value = useMemo<StepperContextValue>(\n () => ({\n currentStep,\n totalSteps,\n isFirst: currentStep === 0,\n isLast: currentStep === totalSteps - 1,\n completed,\n nextStep,\n prevStep,\n goToStep,\n submitStep,\n reset,\n }),\n [\n currentStep,\n totalSteps,\n completed,\n nextStep,\n prevStep,\n goToStep,\n submitStep,\n reset,\n ],\n );\n\n return (\n <StepperContext.Provider value={value}>{children}</StepperContext.Provider>\n );\n};\n","import { useCallback, useEffect, useLayoutEffect, useRef, useState } from 'react';\n\n/**\n * Hook interno del Stepper para manejar scroll horizontal cuando los steps\n * no caben en el contenedor. No se exporta desde el barrel — es un detalle\n * de implementación.\n *\n * @param enabled - Si el scroll está activo (típicamente sólo en orientación horizontal).\n * @param deps - Cosas que afectan el layout y disparan un recompute (ej. cantidad de steps, paso activo).\n *\n * Retorna:\n * - `scrollRef`: ref a asignar al contenedor con `overflow-x: auto`.\n * - `canScrollLeft` / `canScrollRight`: flags para habilitar/deshabilitar flechas.\n * - `scrollBy(delta)`: imperativo con scroll suave.\n */\nexport function useHorizontalScroll(enabled: boolean, deps: unknown[] = []) {\n const scrollRef = useRef<HTMLDivElement | null>(null);\n const [canScrollLeft, setCanScrollLeft] = useState(false);\n const [canScrollRight, setCanScrollRight] = useState(false);\n\n const updateScrollState = useCallback(() => {\n const el = scrollRef.current;\n if (!el) return;\n const { scrollLeft, scrollWidth, clientWidth } = el;\n // Tolerancia de 1px por redondeos de subpixel.\n setCanScrollLeft(scrollLeft > 1);\n setCanScrollRight(scrollLeft + clientWidth < scrollWidth - 1);\n }, []);\n\n useLayoutEffect(() => {\n if (!enabled) return;\n updateScrollState();\n // eslint-disable-next-line react-hooks/exhaustive-deps\n }, [enabled, updateScrollState, ...deps]);\n\n useEffect(() => {\n if (!enabled) return;\n const el = scrollRef.current;\n if (!el) return;\n el.addEventListener('scroll', updateScrollState, { passive: true });\n const ro = new ResizeObserver(updateScrollState);\n ro.observe(el);\n return () => {\n el.removeEventListener('scroll', updateScrollState);\n ro.disconnect();\n };\n }, [enabled, updateScrollState]);\n\n const scrollBy = useCallback((delta: number) => {\n const el = scrollRef.current;\n if (!el) return;\n el.scrollBy({ left: delta, behavior: 'smooth' });\n }, []);\n\n return { scrollRef, canScrollLeft, canScrollRight, scrollBy };\n}\n","import { IconButton } from '@mui/material';\nimport ChevronLeftIcon from '@mui/icons-material/ChevronLeft';\nimport ChevronRightIcon from '@mui/icons-material/ChevronRight';\n\ninterface StepperScrollArrowProps {\n direction: 'left' | 'right';\n /** Cuando `false`, el botón está deshabilitado (por ejemplo, ya estás al inicio). */\n enabled: boolean;\n /**\n * Cuando `false`, el botón queda con `visibility: hidden` (reserva su\n * espacio pero no se ve). Útil para que el área de scroll no se corra\n * horizontalmente cuando no hay overflow en ningún lado.\n */\n visible: boolean;\n onClick: () => void;\n}\n\n/**\n * Flecha de scroll (`<` / `>`) del Stepper horizontal. Se muestra a los\n * costados del área scrollable cuando hay overflow. Componente privado —\n * no se exporta del barrel.\n */\nexport const StepperScrollArrow = ({\n direction,\n enabled,\n visible,\n onClick,\n}: StepperScrollArrowProps) => {\n const isLeft = direction === 'left';\n const Icon = isLeft ? ChevronLeftIcon : ChevronRightIcon;\n const ariaLabel = isLeft ? 'Anterior' : 'Siguiente';\n\n return (\n <IconButton\n aria-label={ariaLabel}\n size=\"small\"\n onClick={onClick}\n disabled={!enabled}\n sx={{\n flex: '0 0 auto',\n // Reservamos el slot siempre que haya overflow en algún lado,\n // así el área scroll tiene un ancho estable (no saltan los\n // steps cuando aparece/desaparece la flecha).\n visibility: visible ? 'visible' : 'hidden',\n }}\n >\n <Icon fontSize=\"small\" />\n </IconButton>\n );\n};\n","import {\n Children,\n isValidElement,\n type FC,\n type ReactElement,\n type ReactNode,\n} from 'react';\nimport {\n Stepper as MuiStepper,\n Step as MuiStep,\n StepLabel as MuiStepLabel,\n Box,\n} from '@mui/material';\n\nimport { StepProps } from './Step';\nimport { useStepper } from './StepperContext';\nimport { useHorizontalScroll } from './_hooks/useHorizontalScroll';\nimport { StepperScrollArrow } from './_parts/StepperScrollArrow';\n\nexport interface StepperProps {\n /** Uno o varios `<Step>`. Children que no sean `<Step>` se ignoran. */\n children: ReactNode;\n orientation?: 'horizontal' | 'vertical';\n alternateLabel?: boolean;\n /**\n * Índice 0-based del paso activo. Si no se provee, el Stepper intenta\n * leerlo del `StepperContext` (si está dentro de un `<StepperProvider>`).\n * Si tampoco hay provider, el default es 0.\n */\n currentStep?: number;\n keepMounted?: boolean;\n sx?: object;\n}\n\nexport const Stepper: FC<StepperProps> = ({\n children,\n orientation = 'horizontal',\n alternateLabel = false,\n currentStep: currentStepProp,\n keepMounted = false,\n sx,\n}) => {\n // Lee el paso desde el StepperContext cuando el consumer no lo pasa como prop.\n const stepperCtx = useStepper();\n const currentStep =\n currentStepProp !== undefined\n ? currentStepProp\n : stepperCtx.totalSteps > 0\n ? stepperCtx.currentStep\n : 0;\n\n const isHorizontal = orientation === 'horizontal';\n\n // Filtra los children a los que tengan displayName=\"Step\" — acepta arrays,\n // single child, fragments, y descarta cualquier otra cosa (strings, null, etc.).\n const steps: ReactElement<StepProps>[] = Children.toArray(children).filter(\n (child): child is ReactElement<StepProps> =>\n isValidElement(child) &&\n (child.type as { displayName?: string })?.displayName === 'Step',\n );\n\n const { scrollRef, canScrollLeft, canScrollRight, scrollBy } = useHorizontalScroll(\n isHorizontal,\n [steps.length, currentStep],\n );\n\n const showArrows = isHorizontal && (canScrollLeft || canScrollRight);\n\n return (\n <Box sx={sx}>\n <Box\n sx={\n isHorizontal\n ? { display: 'flex', alignItems: 'center', width: '100%', gap: 0.5 }\n : undefined\n }\n >\n {isHorizontal && (\n <StepperScrollArrow\n direction=\"left\"\n enabled={canScrollLeft}\n visible={showArrows}\n onClick={() => scrollBy(-160)}\n />\n )}\n <Box\n ref={scrollRef}\n sx={\n isHorizontal\n ? {\n flex: '1 1 auto',\n minWidth: 0,\n overflowX: 'auto',\n scrollBehavior: 'smooth',\n WebkitOverflowScrolling: 'touch',\n scrollbarWidth: 'none',\n '&::-webkit-scrollbar': { display: 'none' },\n }\n : undefined\n }\n >\n <MuiStepper\n activeStep={currentStep}\n orientation={orientation}\n alternativeLabel={alternateLabel}\n sx={\n isHorizontal\n ? {\n display: 'inline-flex',\n flexWrap: 'nowrap',\n minWidth: '100%',\n width: 'max-content',\n '& .MuiStep-root': { flex: '0 0 auto', minWidth: 120 },\n }\n : undefined\n }\n >\n {steps.map((step, idx) => {\n const {\n label,\n completed,\n disabled,\n className,\n sx: stepSx,\n dotColor,\n activeDotColor,\n completedDotColor,\n iconTextColor,\n } = step.props;\n const key = step.key ?? idx;\n return (\n <MuiStep\n key={key}\n completed={completed}\n disabled={disabled}\n className={className}\n sx={stepSx}\n >\n <MuiStepLabel\n sx={{\n pointerEvents: 'none',\n '& .MuiStepIcon-root': { color: dotColor },\n '& .MuiStepIcon-active': { color: activeDotColor },\n '& .MuiStepIcon-completed': { color: completedDotColor },\n '& .MuiStepIcon-text': { fill: iconTextColor },\n }}\n >\n {label}\n </MuiStepLabel>\n </MuiStep>\n );\n })}\n </MuiStepper>\n </Box>\n {isHorizontal && (\n <StepperScrollArrow\n direction=\"right\"\n enabled={canScrollRight}\n visible={showArrows}\n onClick={() => scrollBy(160)}\n />\n )}\n </Box>\n\n {/* Cuerpos de los steps — render según el modo `keepMounted` */}\n <Box mt={2}>\n {keepMounted\n ? steps.map((step, idx) => {\n const key = step.key ?? idx;\n const isActive = idx === currentStep;\n return (\n <Box\n key={key}\n // `display: none` mantiene el nodo en el DOM — state de los\n // hijos (inputs, useState, etc.) no se pierde al navegar.\n sx={{ display: isActive ? 'block' : 'none' }}\n // Accesibilidad: oculta del flujo de lectura pero no del DOM.\n aria-hidden={!isActive}\n >\n {step.props.children}\n </Box>\n );\n })\n : steps.map((step, idx) => {\n if (idx !== currentStep) return null;\n const key = step.key ?? idx;\n return <Box key={key}>{step.props.children}</Box>;\n })}\n </Box>\n </Box>\n );\n};\n\nexport default Stepper;\n","import React from \"react\";\nimport { StepProps as MuiStepProps } from \"@mui/material\";\n\ntype PickMuiStepProps = Pick<MuiStepProps, \"completed\" | \"disabled\" | \"sx\" | \"className\">;\n\nexport interface StepProps extends PickMuiStepProps {\n label: React.ReactNode;\n children?: React.ReactNode;\n disabled?: boolean;\n sx?: object;\n dotColor?: string; // dot base\n activeDotColor?: string; // dot activa\n completedDotColor?: string; // dot completada\n iconTextColor?: string; // número o check dentro\n}\n\nexport const Step = (_: StepProps): null => null;\n\nStep.displayName = \"Step\";\n\nexport default Step;"],"names":["MuiStepper","MuiStep","MuiStepLabel"],"mappings":"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"}
|
|
@@ -0,0 +1,300 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
const jsxRuntime = require("react/jsx-runtime");
|
|
3
|
+
const React = require("react");
|
|
4
|
+
const material = require("@mui/material");
|
|
5
|
+
const ChevronLeftIcon = require("@mui/icons-material/ChevronLeft");
|
|
6
|
+
const ChevronRightIcon = require("@mui/icons-material/ChevronRight");
|
|
7
|
+
const defaultValue = {
|
|
8
|
+
currentStep: 0,
|
|
9
|
+
totalSteps: 0,
|
|
10
|
+
isFirst: true,
|
|
11
|
+
isLast: true,
|
|
12
|
+
completed: false,
|
|
13
|
+
nextStep: () => {
|
|
14
|
+
},
|
|
15
|
+
prevStep: () => {
|
|
16
|
+
},
|
|
17
|
+
goToStep: () => {
|
|
18
|
+
},
|
|
19
|
+
submitStep: () => {
|
|
20
|
+
},
|
|
21
|
+
reset: () => {
|
|
22
|
+
}
|
|
23
|
+
};
|
|
24
|
+
const StepperContext = React.createContext(defaultValue);
|
|
25
|
+
function useStepper() {
|
|
26
|
+
return React.useContext(StepperContext);
|
|
27
|
+
}
|
|
28
|
+
const StepperProvider = ({
|
|
29
|
+
totalSteps,
|
|
30
|
+
initialStep = 0,
|
|
31
|
+
onSubmit,
|
|
32
|
+
onStepChange,
|
|
33
|
+
children
|
|
34
|
+
}) => {
|
|
35
|
+
const [currentStep, setCurrentStep] = React.useState(initialStep);
|
|
36
|
+
const [completed, setCompleted] = React.useState(false);
|
|
37
|
+
const changeStep = React.useCallback(
|
|
38
|
+
(newStep) => {
|
|
39
|
+
setCurrentStep((prev) => {
|
|
40
|
+
if (newStep === prev) return prev;
|
|
41
|
+
if (newStep < 0 || newStep >= totalSteps) return prev;
|
|
42
|
+
onStepChange == null ? void 0 : onStepChange(newStep, prev);
|
|
43
|
+
return newStep;
|
|
44
|
+
});
|
|
45
|
+
},
|
|
46
|
+
[totalSteps, onStepChange]
|
|
47
|
+
);
|
|
48
|
+
const nextStep = React.useCallback(() => {
|
|
49
|
+
changeStep(currentStep + 1);
|
|
50
|
+
}, [changeStep, currentStep]);
|
|
51
|
+
const prevStep = React.useCallback(() => {
|
|
52
|
+
changeStep(currentStep - 1);
|
|
53
|
+
}, [changeStep, currentStep]);
|
|
54
|
+
const goToStep = React.useCallback(
|
|
55
|
+
(stepNumber) => {
|
|
56
|
+
changeStep(stepNumber);
|
|
57
|
+
},
|
|
58
|
+
[changeStep]
|
|
59
|
+
);
|
|
60
|
+
const submitStep = React.useCallback(() => {
|
|
61
|
+
setCompleted(true);
|
|
62
|
+
onSubmit == null ? void 0 : onSubmit(currentStep);
|
|
63
|
+
}, [currentStep, onSubmit]);
|
|
64
|
+
const reset = React.useCallback(() => {
|
|
65
|
+
setCurrentStep(initialStep);
|
|
66
|
+
setCompleted(false);
|
|
67
|
+
}, [initialStep]);
|
|
68
|
+
const value = React.useMemo(
|
|
69
|
+
() => ({
|
|
70
|
+
currentStep,
|
|
71
|
+
totalSteps,
|
|
72
|
+
isFirst: currentStep === 0,
|
|
73
|
+
isLast: currentStep === totalSteps - 1,
|
|
74
|
+
completed,
|
|
75
|
+
nextStep,
|
|
76
|
+
prevStep,
|
|
77
|
+
goToStep,
|
|
78
|
+
submitStep,
|
|
79
|
+
reset
|
|
80
|
+
}),
|
|
81
|
+
[
|
|
82
|
+
currentStep,
|
|
83
|
+
totalSteps,
|
|
84
|
+
completed,
|
|
85
|
+
nextStep,
|
|
86
|
+
prevStep,
|
|
87
|
+
goToStep,
|
|
88
|
+
submitStep,
|
|
89
|
+
reset
|
|
90
|
+
]
|
|
91
|
+
);
|
|
92
|
+
return /* @__PURE__ */ jsxRuntime.jsx(StepperContext.Provider, { value, children });
|
|
93
|
+
};
|
|
94
|
+
function useHorizontalScroll(enabled, deps = []) {
|
|
95
|
+
const scrollRef = React.useRef(null);
|
|
96
|
+
const [canScrollLeft, setCanScrollLeft] = React.useState(false);
|
|
97
|
+
const [canScrollRight, setCanScrollRight] = React.useState(false);
|
|
98
|
+
const updateScrollState = React.useCallback(() => {
|
|
99
|
+
const el = scrollRef.current;
|
|
100
|
+
if (!el) return;
|
|
101
|
+
const { scrollLeft, scrollWidth, clientWidth } = el;
|
|
102
|
+
setCanScrollLeft(scrollLeft > 1);
|
|
103
|
+
setCanScrollRight(scrollLeft + clientWidth < scrollWidth - 1);
|
|
104
|
+
}, []);
|
|
105
|
+
React.useLayoutEffect(() => {
|
|
106
|
+
if (!enabled) return;
|
|
107
|
+
updateScrollState();
|
|
108
|
+
}, [enabled, updateScrollState, ...deps]);
|
|
109
|
+
React.useEffect(() => {
|
|
110
|
+
if (!enabled) return;
|
|
111
|
+
const el = scrollRef.current;
|
|
112
|
+
if (!el) return;
|
|
113
|
+
el.addEventListener("scroll", updateScrollState, { passive: true });
|
|
114
|
+
const ro = new ResizeObserver(updateScrollState);
|
|
115
|
+
ro.observe(el);
|
|
116
|
+
return () => {
|
|
117
|
+
el.removeEventListener("scroll", updateScrollState);
|
|
118
|
+
ro.disconnect();
|
|
119
|
+
};
|
|
120
|
+
}, [enabled, updateScrollState]);
|
|
121
|
+
const scrollBy = React.useCallback((delta) => {
|
|
122
|
+
const el = scrollRef.current;
|
|
123
|
+
if (!el) return;
|
|
124
|
+
el.scrollBy({ left: delta, behavior: "smooth" });
|
|
125
|
+
}, []);
|
|
126
|
+
return { scrollRef, canScrollLeft, canScrollRight, scrollBy };
|
|
127
|
+
}
|
|
128
|
+
const StepperScrollArrow = ({
|
|
129
|
+
direction,
|
|
130
|
+
enabled,
|
|
131
|
+
visible,
|
|
132
|
+
onClick
|
|
133
|
+
}) => {
|
|
134
|
+
const isLeft = direction === "left";
|
|
135
|
+
const Icon = isLeft ? ChevronLeftIcon : ChevronRightIcon;
|
|
136
|
+
const ariaLabel = isLeft ? "Anterior" : "Siguiente";
|
|
137
|
+
return /* @__PURE__ */ jsxRuntime.jsx(
|
|
138
|
+
material.IconButton,
|
|
139
|
+
{
|
|
140
|
+
"aria-label": ariaLabel,
|
|
141
|
+
size: "small",
|
|
142
|
+
onClick,
|
|
143
|
+
disabled: !enabled,
|
|
144
|
+
sx: {
|
|
145
|
+
flex: "0 0 auto",
|
|
146
|
+
// Reservamos el slot siempre que haya overflow en algún lado,
|
|
147
|
+
// así el área scroll tiene un ancho estable (no saltan los
|
|
148
|
+
// steps cuando aparece/desaparece la flecha).
|
|
149
|
+
visibility: visible ? "visible" : "hidden"
|
|
150
|
+
},
|
|
151
|
+
children: /* @__PURE__ */ jsxRuntime.jsx(Icon, { fontSize: "small" })
|
|
152
|
+
}
|
|
153
|
+
);
|
|
154
|
+
};
|
|
155
|
+
const Stepper = ({
|
|
156
|
+
children,
|
|
157
|
+
orientation = "horizontal",
|
|
158
|
+
alternateLabel = false,
|
|
159
|
+
currentStep: currentStepProp,
|
|
160
|
+
keepMounted = false,
|
|
161
|
+
sx
|
|
162
|
+
}) => {
|
|
163
|
+
const stepperCtx = useStepper();
|
|
164
|
+
const currentStep = currentStepProp !== void 0 ? currentStepProp : stepperCtx.totalSteps > 0 ? stepperCtx.currentStep : 0;
|
|
165
|
+
const isHorizontal = orientation === "horizontal";
|
|
166
|
+
const steps = React.Children.toArray(children).filter(
|
|
167
|
+
(child) => {
|
|
168
|
+
var _a;
|
|
169
|
+
return React.isValidElement(child) && ((_a = child.type) == null ? void 0 : _a.displayName) === "Step";
|
|
170
|
+
}
|
|
171
|
+
);
|
|
172
|
+
const { scrollRef, canScrollLeft, canScrollRight, scrollBy } = useHorizontalScroll(
|
|
173
|
+
isHorizontal,
|
|
174
|
+
[steps.length, currentStep]
|
|
175
|
+
);
|
|
176
|
+
const showArrows = isHorizontal && (canScrollLeft || canScrollRight);
|
|
177
|
+
return /* @__PURE__ */ jsxRuntime.jsxs(material.Box, { sx, children: [
|
|
178
|
+
/* @__PURE__ */ jsxRuntime.jsxs(
|
|
179
|
+
material.Box,
|
|
180
|
+
{
|
|
181
|
+
sx: isHorizontal ? { display: "flex", alignItems: "center", width: "100%", gap: 0.5 } : void 0,
|
|
182
|
+
children: [
|
|
183
|
+
isHorizontal && /* @__PURE__ */ jsxRuntime.jsx(
|
|
184
|
+
StepperScrollArrow,
|
|
185
|
+
{
|
|
186
|
+
direction: "left",
|
|
187
|
+
enabled: canScrollLeft,
|
|
188
|
+
visible: showArrows,
|
|
189
|
+
onClick: () => scrollBy(-160)
|
|
190
|
+
}
|
|
191
|
+
),
|
|
192
|
+
/* @__PURE__ */ jsxRuntime.jsx(
|
|
193
|
+
material.Box,
|
|
194
|
+
{
|
|
195
|
+
ref: scrollRef,
|
|
196
|
+
sx: isHorizontal ? {
|
|
197
|
+
flex: "1 1 auto",
|
|
198
|
+
minWidth: 0,
|
|
199
|
+
overflowX: "auto",
|
|
200
|
+
scrollBehavior: "smooth",
|
|
201
|
+
WebkitOverflowScrolling: "touch",
|
|
202
|
+
scrollbarWidth: "none",
|
|
203
|
+
"&::-webkit-scrollbar": { display: "none" }
|
|
204
|
+
} : void 0,
|
|
205
|
+
children: /* @__PURE__ */ jsxRuntime.jsx(
|
|
206
|
+
material.Stepper,
|
|
207
|
+
{
|
|
208
|
+
activeStep: currentStep,
|
|
209
|
+
orientation,
|
|
210
|
+
alternativeLabel: alternateLabel,
|
|
211
|
+
sx: isHorizontal ? {
|
|
212
|
+
display: "inline-flex",
|
|
213
|
+
flexWrap: "nowrap",
|
|
214
|
+
minWidth: "100%",
|
|
215
|
+
width: "max-content",
|
|
216
|
+
"& .MuiStep-root": { flex: "0 0 auto", minWidth: 120 }
|
|
217
|
+
} : void 0,
|
|
218
|
+
children: steps.map((step, idx) => {
|
|
219
|
+
var _a;
|
|
220
|
+
const {
|
|
221
|
+
label,
|
|
222
|
+
completed,
|
|
223
|
+
disabled,
|
|
224
|
+
className,
|
|
225
|
+
sx: stepSx,
|
|
226
|
+
dotColor,
|
|
227
|
+
activeDotColor,
|
|
228
|
+
completedDotColor,
|
|
229
|
+
iconTextColor
|
|
230
|
+
} = step.props;
|
|
231
|
+
const key = (_a = step.key) != null ? _a : idx;
|
|
232
|
+
return /* @__PURE__ */ jsxRuntime.jsx(
|
|
233
|
+
material.Step,
|
|
234
|
+
{
|
|
235
|
+
completed,
|
|
236
|
+
disabled,
|
|
237
|
+
className,
|
|
238
|
+
sx: stepSx,
|
|
239
|
+
children: /* @__PURE__ */ jsxRuntime.jsx(
|
|
240
|
+
material.StepLabel,
|
|
241
|
+
{
|
|
242
|
+
sx: {
|
|
243
|
+
pointerEvents: "none",
|
|
244
|
+
"& .MuiStepIcon-root": { color: dotColor },
|
|
245
|
+
"& .MuiStepIcon-active": { color: activeDotColor },
|
|
246
|
+
"& .MuiStepIcon-completed": { color: completedDotColor },
|
|
247
|
+
"& .MuiStepIcon-text": { fill: iconTextColor }
|
|
248
|
+
},
|
|
249
|
+
children: label
|
|
250
|
+
}
|
|
251
|
+
)
|
|
252
|
+
},
|
|
253
|
+
key
|
|
254
|
+
);
|
|
255
|
+
})
|
|
256
|
+
}
|
|
257
|
+
)
|
|
258
|
+
}
|
|
259
|
+
),
|
|
260
|
+
isHorizontal && /* @__PURE__ */ jsxRuntime.jsx(
|
|
261
|
+
StepperScrollArrow,
|
|
262
|
+
{
|
|
263
|
+
direction: "right",
|
|
264
|
+
enabled: canScrollRight,
|
|
265
|
+
visible: showArrows,
|
|
266
|
+
onClick: () => scrollBy(160)
|
|
267
|
+
}
|
|
268
|
+
)
|
|
269
|
+
]
|
|
270
|
+
}
|
|
271
|
+
),
|
|
272
|
+
/* @__PURE__ */ jsxRuntime.jsx(material.Box, { mt: 2, children: keepMounted ? steps.map((step, idx) => {
|
|
273
|
+
var _a;
|
|
274
|
+
const key = (_a = step.key) != null ? _a : idx;
|
|
275
|
+
const isActive = idx === currentStep;
|
|
276
|
+
return /* @__PURE__ */ jsxRuntime.jsx(
|
|
277
|
+
material.Box,
|
|
278
|
+
{
|
|
279
|
+
sx: { display: isActive ? "block" : "none" },
|
|
280
|
+
"aria-hidden": !isActive,
|
|
281
|
+
children: step.props.children
|
|
282
|
+
},
|
|
283
|
+
key
|
|
284
|
+
);
|
|
285
|
+
}) : steps.map((step, idx) => {
|
|
286
|
+
var _a;
|
|
287
|
+
if (idx !== currentStep) return null;
|
|
288
|
+
const key = (_a = step.key) != null ? _a : idx;
|
|
289
|
+
return /* @__PURE__ */ jsxRuntime.jsx(material.Box, { children: step.props.children }, key);
|
|
290
|
+
}) })
|
|
291
|
+
] });
|
|
292
|
+
};
|
|
293
|
+
const Step = (_) => null;
|
|
294
|
+
Step.displayName = "Step";
|
|
295
|
+
exports.Step = Step;
|
|
296
|
+
exports.Stepper = Stepper;
|
|
297
|
+
exports.StepperContext = StepperContext;
|
|
298
|
+
exports.StepperProvider = StepperProvider;
|
|
299
|
+
exports.useStepper = useStepper;
|
|
300
|
+
//# sourceMappingURL=Step-Nd7SJbRZ.cjs.map
|