UNPKG

4.91 kBJavaScriptView Raw
1"use strict";
2'use client';
3
4var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault").default;
5var _interopRequireWildcard = require("@babel/runtime/helpers/interopRequireWildcard").default;
6Object.defineProperty(exports, "__esModule", {
7 value: true
8});
9exports.default = void 0;
10var React = _interopRequireWildcard(require("react"));
11var _propTypes = _interopRequireDefault(require("prop-types"));
12var _clsx = _interopRequireDefault(require("clsx"));
13var _composeClasses = _interopRequireDefault(require("@mui/utils/composeClasses"));
14var _zeroStyled = require("../zero-styled");
15var _DefaultPropsProvider = require("../DefaultPropsProvider");
16var _ButtonBase = _interopRequireDefault(require("../ButtonBase"));
17var _StepLabel = _interopRequireDefault(require("../StepLabel"));
18var _isMuiElement = _interopRequireDefault(require("../utils/isMuiElement"));
19var _StepperContext = _interopRequireDefault(require("../Stepper/StepperContext"));
20var _StepContext = _interopRequireDefault(require("../Step/StepContext"));
21var _stepButtonClasses = _interopRequireWildcard(require("./stepButtonClasses"));
22var _jsxRuntime = require("react/jsx-runtime");
23const useUtilityClasses = ownerState => {
24 const {
25 classes,
26 orientation
27 } = ownerState;
28 const slots = {
29 root: ['root', orientation],
30 touchRipple: ['touchRipple']
31 };
32 return (0, _composeClasses.default)(slots, _stepButtonClasses.getStepButtonUtilityClass, classes);
33};
34const StepButtonRoot = (0, _zeroStyled.styled)(_ButtonBase.default, {
35 name: 'MuiStepButton',
36 slot: 'Root',
37 overridesResolver: (props, styles) => {
38 const {
39 ownerState
40 } = props;
41 return [{
42 [`& .${_stepButtonClasses.default.touchRipple}`]: styles.touchRipple
43 }, styles.root, styles[ownerState.orientation]];
44 }
45})({
46 width: '100%',
47 padding: '24px 16px',
48 margin: '-24px -16px',
49 boxSizing: 'content-box',
50 [`& .${_stepButtonClasses.default.touchRipple}`]: {
51 color: 'rgba(0, 0, 0, 0.3)'
52 },
53 variants: [{
54 props: {
55 orientation: 'vertical'
56 },
57 style: {
58 justifyContent: 'flex-start',
59 padding: '8px',
60 margin: '-8px'
61 }
62 }]
63});
64const StepButton = /*#__PURE__*/React.forwardRef(function StepButton(inProps, ref) {
65 const props = (0, _DefaultPropsProvider.useDefaultProps)({
66 props: inProps,
67 name: 'MuiStepButton'
68 });
69 const {
70 children,
71 className,
72 icon,
73 optional,
74 ...other
75 } = props;
76 const {
77 disabled,
78 active
79 } = React.useContext(_StepContext.default);
80 const {
81 orientation
82 } = React.useContext(_StepperContext.default);
83 const ownerState = {
84 ...props,
85 orientation
86 };
87 const classes = useUtilityClasses(ownerState);
88 const childProps = {
89 icon,
90 optional
91 };
92 const child = (0, _isMuiElement.default)(children, ['StepLabel']) ? (/*#__PURE__*/React.cloneElement(children, childProps)) : /*#__PURE__*/(0, _jsxRuntime.jsx)(_StepLabel.default, {
93 ...childProps,
94 children: children
95 });
96 return /*#__PURE__*/(0, _jsxRuntime.jsx)(StepButtonRoot, {
97 focusRipple: true,
98 disabled: disabled,
99 TouchRippleProps: {
100 className: classes.touchRipple
101 },
102 className: (0, _clsx.default)(classes.root, className),
103 ref: ref,
104 ownerState: ownerState,
105 "aria-current": active ? 'step' : undefined,
106 ...other,
107 children: child
108 });
109});
110process.env.NODE_ENV !== "production" ? StepButton.propTypes /* remove-proptypes */ = {
111 // ┌────────────────────────────── Warning ──────────────────────────────┐
112 // │ These PropTypes are generated from the TypeScript type definitions. │
113 // │ To update them, edit the d.ts file and run `pnpm proptypes`. │
114 // └─────────────────────────────────────────────────────────────────────┘
115 /**
116 * Can be a `StepLabel` or a node to place inside `StepLabel` as children.
117 */
118 children: _propTypes.default.node,
119 /**
120 * Override or extend the styles applied to the component.
121 */
122 classes: _propTypes.default.object,
123 /**
124 * @ignore
125 */
126 className: _propTypes.default.string,
127 /**
128 * The icon displayed by the step label.
129 */
130 icon: _propTypes.default.node,
131 /**
132 * The optional node to display.
133 */
134 optional: _propTypes.default.node,
135 /**
136 * The system prop that allows defining system overrides as well as additional CSS styles.
137 */
138 sx: _propTypes.default.oneOfType([_propTypes.default.arrayOf(_propTypes.default.oneOfType([_propTypes.default.func, _propTypes.default.object, _propTypes.default.bool])), _propTypes.default.func, _propTypes.default.object])
139} : void 0;
140var _default = exports.default = StepButton;
\No newline at end of file