@soyfri/shared-library 2.0.0-beta.3 → 2.0.0-beta.30
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/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/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 +94 -2
- package/index.cjs.map +1 -1
- package/index.d.ts +34 -0
- package/index.js +68 -3
- 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 +73 -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
|