163 lines
No EOL
4.2 KiB
JavaScript
163 lines
No EOL
4.2 KiB
JavaScript
"use strict";
|
|
'use client';
|
|
|
|
var _interopRequireWildcard = require("@babel/runtime/helpers/interopRequireWildcard").default;
|
|
var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault").default;
|
|
Object.defineProperty(exports, "__esModule", {
|
|
value: true
|
|
});
|
|
exports.default = NotchedOutline;
|
|
var React = _interopRequireWildcard(require("react"));
|
|
var _propTypes = _interopRequireDefault(require("prop-types"));
|
|
var _rootShouldForwardProp = _interopRequireDefault(require("../styles/rootShouldForwardProp"));
|
|
var _zeroStyled = require("../zero-styled");
|
|
var _memoTheme = _interopRequireDefault(require("../utils/memoTheme"));
|
|
var _jsxRuntime = require("react/jsx-runtime");
|
|
var _span;
|
|
const NotchedOutlineRoot = (0, _zeroStyled.styled)('fieldset', {
|
|
name: 'MuiNotchedOutlined',
|
|
shouldForwardProp: _rootShouldForwardProp.default
|
|
})({
|
|
textAlign: 'left',
|
|
position: 'absolute',
|
|
bottom: 0,
|
|
right: 0,
|
|
top: -5,
|
|
left: 0,
|
|
margin: 0,
|
|
padding: '0 8px',
|
|
pointerEvents: 'none',
|
|
borderRadius: 'inherit',
|
|
borderStyle: 'solid',
|
|
borderWidth: 1,
|
|
overflow: 'hidden',
|
|
minWidth: '0%'
|
|
});
|
|
const NotchedOutlineLegend = (0, _zeroStyled.styled)('legend', {
|
|
name: 'MuiNotchedOutlined',
|
|
shouldForwardProp: _rootShouldForwardProp.default
|
|
})((0, _memoTheme.default)(({
|
|
theme
|
|
}) => ({
|
|
float: 'unset',
|
|
// Fix conflict with bootstrap
|
|
width: 'auto',
|
|
// Fix conflict with bootstrap
|
|
overflow: 'hidden',
|
|
// Fix Horizontal scroll when label too long
|
|
variants: [{
|
|
props: ({
|
|
ownerState
|
|
}) => !ownerState.withLabel,
|
|
style: {
|
|
padding: 0,
|
|
lineHeight: '11px',
|
|
// sync with `height` in `legend` styles
|
|
transition: theme.transitions.create('width', {
|
|
duration: 150,
|
|
easing: theme.transitions.easing.easeOut
|
|
})
|
|
}
|
|
}, {
|
|
props: ({
|
|
ownerState
|
|
}) => ownerState.withLabel,
|
|
style: {
|
|
display: 'block',
|
|
// Fix conflict with normalize.css and sanitize.css
|
|
padding: 0,
|
|
height: 11,
|
|
// sync with `lineHeight` in `legend` styles
|
|
fontSize: '0.75em',
|
|
visibility: 'hidden',
|
|
maxWidth: 0.01,
|
|
transition: theme.transitions.create('max-width', {
|
|
duration: 50,
|
|
easing: theme.transitions.easing.easeOut
|
|
}),
|
|
whiteSpace: 'nowrap',
|
|
'& > span': {
|
|
paddingLeft: 5,
|
|
paddingRight: 5,
|
|
display: 'inline-block',
|
|
opacity: 0,
|
|
visibility: 'visible'
|
|
}
|
|
}
|
|
}, {
|
|
props: ({
|
|
ownerState
|
|
}) => ownerState.withLabel && ownerState.notched,
|
|
style: {
|
|
maxWidth: '100%',
|
|
transition: theme.transitions.create('max-width', {
|
|
duration: 100,
|
|
easing: theme.transitions.easing.easeOut,
|
|
delay: 50
|
|
})
|
|
}
|
|
}]
|
|
})));
|
|
|
|
/**
|
|
* @ignore - internal component.
|
|
*/
|
|
function NotchedOutline(props) {
|
|
const {
|
|
children,
|
|
classes,
|
|
className,
|
|
label,
|
|
notched,
|
|
...other
|
|
} = props;
|
|
const withLabel = label != null && label !== '';
|
|
const ownerState = {
|
|
...props,
|
|
notched,
|
|
withLabel
|
|
};
|
|
return /*#__PURE__*/(0, _jsxRuntime.jsx)(NotchedOutlineRoot, {
|
|
"aria-hidden": true,
|
|
className: className,
|
|
ownerState: ownerState,
|
|
...other,
|
|
children: /*#__PURE__*/(0, _jsxRuntime.jsx)(NotchedOutlineLegend, {
|
|
ownerState: ownerState,
|
|
children: withLabel ? /*#__PURE__*/(0, _jsxRuntime.jsx)("span", {
|
|
children: label
|
|
}) : // notranslate needed while Google Translate will not fix zero-width space issue
|
|
_span || (_span = /*#__PURE__*/(0, _jsxRuntime.jsx)("span", {
|
|
className: "notranslate",
|
|
"aria-hidden": true,
|
|
children: "\u200B"
|
|
}))
|
|
})
|
|
});
|
|
}
|
|
process.env.NODE_ENV !== "production" ? NotchedOutline.propTypes /* remove-proptypes */ = {
|
|
/**
|
|
* The content of the component.
|
|
*/
|
|
children: _propTypes.default.node,
|
|
/**
|
|
* Override or extend the styles applied to the component.
|
|
*/
|
|
classes: _propTypes.default.object,
|
|
/**
|
|
* @ignore
|
|
*/
|
|
className: _propTypes.default.string,
|
|
/**
|
|
* The label.
|
|
*/
|
|
label: _propTypes.default.node,
|
|
/**
|
|
* If `true`, the outline is notched to accommodate the label.
|
|
*/
|
|
notched: _propTypes.default.bool.isRequired,
|
|
/**
|
|
* @ignore
|
|
*/
|
|
style: _propTypes.default.object
|
|
} : void 0; |