@material-ui/lab
Version:
Material-UI Lab - Incubator for Material-UI React components.
242 lines (203 loc) • 7.7 kB
JavaScript
"use strict";
var _interopRequireWildcard = require("@babel/runtime/helpers/interopRequireWildcard");
var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault");
Object.defineProperty(exports, "__esModule", {
value: true
});
exports.default = exports.styles = void 0;
var _objectWithoutProperties2 = _interopRequireDefault(require("@babel/runtime/helpers/objectWithoutProperties"));
var _extends2 = _interopRequireDefault(require("@babel/runtime/helpers/extends"));
var React = _interopRequireWildcard(require("react"));
var _propTypes = _interopRequireDefault(require("prop-types"));
var _clsx = _interopRequireDefault(require("clsx"));
var _styles = require("@material-ui/core/styles");
var _Fab = _interopRequireDefault(require("@material-ui/core/Fab"));
var _Tooltip = _interopRequireDefault(require("@material-ui/core/Tooltip"));
var _utils = require("@material-ui/core/utils");
// @inheritedComponent Tooltip
var styles = function styles(theme) {
return {
/* Styles applied to the Fab component. */
fab: {
margin: 8,
color: theme.palette.text.secondary,
backgroundColor: theme.palette.background.paper,
'&:hover': {
backgroundColor: (0, _styles.emphasize)(theme.palette.background.paper, 0.15)
},
transition: "".concat(theme.transitions.create('transform', {
duration: theme.transitions.duration.shorter
}), ", opacity 0.8s"),
opacity: 1
},
/* Styles applied to the Fab component if `open={false}`. */
fabClosed: {
opacity: 0,
transform: 'scale(0)'
},
/* Styles applied to the root element if `tooltipOpen={true}`. */
staticTooltip: {
position: 'relative',
display: 'flex',
'& $staticTooltipLabel': {
transition: theme.transitions.create(['transform', 'opacity'], {
duration: theme.transitions.duration.shorter
}),
opacity: 1
}
},
/* Styles applied to the root element if `tooltipOpen={true}` and `open={false}`. */
staticTooltipClosed: {
'& $staticTooltipLabel': {
opacity: 0,
transform: 'scale(0.5)'
}
},
/* Styles applied to the static tooltip label if `tooltipOpen={true}`. */
staticTooltipLabel: (0, _extends2.default)({
position: 'absolute'
}, theme.typography.body1, {
backgroundColor: theme.palette.background.paper,
borderRadius: theme.shape.borderRadius,
boxShadow: theme.shadows[1],
color: theme.palette.text.secondary,
padding: '4px 16px',
wordBreak: 'keep-all'
}),
/* Styles applied to the root if `tooltipOpen={true}` and `tooltipPlacement="left"`` */
tooltipPlacementLeft: {
alignItems: 'center',
'& $staticTooltipLabel': {
transformOrigin: '100% 50%',
right: '100%',
marginRight: 8
}
},
/* Styles applied to the root if `tooltipOpen={true}` and `tooltipPlacement="right"`` */
tooltipPlacementRight: {
alignItems: 'center',
'& $staticTooltipLabel': {
transformOrigin: '0% 50%',
left: '100%',
marginLeft: 8
}
}
};
};
exports.styles = styles;
var SpeedDialAction = /*#__PURE__*/React.forwardRef(function SpeedDialAction(props, ref) {
var classes = props.classes,
className = props.className,
_props$delay = props.delay,
delay = _props$delay === void 0 ? 0 : _props$delay,
_props$FabProps = props.FabProps,
FabProps = _props$FabProps === void 0 ? {} : _props$FabProps,
icon = props.icon,
id = props.id,
open = props.open,
TooltipClasses = props.TooltipClasses,
_props$tooltipOpen = props.tooltipOpen,
tooltipOpenProp = _props$tooltipOpen === void 0 ? false : _props$tooltipOpen,
_props$tooltipPlaceme = props.tooltipPlacement,
tooltipPlacement = _props$tooltipPlaceme === void 0 ? 'left' : _props$tooltipPlaceme,
tooltipTitle = props.tooltipTitle,
other = (0, _objectWithoutProperties2.default)(props, ["classes", "className", "delay", "FabProps", "icon", "id", "open", "TooltipClasses", "tooltipOpen", "tooltipPlacement", "tooltipTitle"]);
var _React$useState = React.useState(tooltipOpenProp),
tooltipOpen = _React$useState[0],
setTooltipOpen = _React$useState[1];
var handleTooltipClose = function handleTooltipClose() {
setTooltipOpen(false);
};
var handleTooltipOpen = function handleTooltipOpen() {
setTooltipOpen(true);
};
var transitionStyle = {
transitionDelay: "".concat(delay, "ms")
};
var fab = /*#__PURE__*/React.createElement(_Fab.default, (0, _extends2.default)({
size: "small",
className: (0, _clsx.default)(classes.fab, className, !open && classes.fabClosed),
tabIndex: -1,
role: "menuitem",
"aria-describedby": "".concat(id, "-label")
}, FabProps, {
style: (0, _extends2.default)({}, transitionStyle, FabProps.style)
}), icon);
if (tooltipOpenProp) {
return /*#__PURE__*/React.createElement("span", (0, _extends2.default)({
id: id,
ref: ref,
className: (0, _clsx.default)(classes.staticTooltip, classes["tooltipPlacement".concat((0, _utils.capitalize)(tooltipPlacement))], !open && classes.staticTooltipClosed)
}, other), /*#__PURE__*/React.createElement("span", {
style: transitionStyle,
id: "".concat(id, "-label"),
className: classes.staticTooltipLabel
}, tooltipTitle), fab);
}
return /*#__PURE__*/React.createElement(_Tooltip.default, (0, _extends2.default)({
id: id,
ref: ref,
title: tooltipTitle,
placement: tooltipPlacement,
onClose: handleTooltipClose,
onOpen: handleTooltipOpen,
open: open && tooltipOpen,
classes: TooltipClasses
}, other), fab);
});
process.env.NODE_ENV !== "production" ? SpeedDialAction.propTypes = {
// ----------------------------- Warning --------------------------------
// | These PropTypes are generated from the TypeScript type definitions |
// | To update them edit the d.ts file and run "yarn proptypes" |
// ----------------------------------------------------------------------
/**
* Override or extend the styles applied to the component.
* See [CSS API](#css) below for more details.
*/
classes: _propTypes.default.object,
/**
* @ignore
*/
className: _propTypes.default.string,
/**
* Adds a transition delay, to allow a series of SpeedDialActions to be animated.
*/
delay: _propTypes.default.number,
/**
* Props applied to the [`Fab`](/api/fab/) component.
*/
FabProps: _propTypes.default.object,
/**
* The Icon to display in the SpeedDial Fab.
*/
icon: _propTypes.default.node,
/**
* This prop is used to help implement the accessibility logic.
* If you don't provide this prop. It falls back to a randomly generated id.
*/
id: _propTypes.default.string,
/**
* If `true`, the tooltip is shown.
*/
open: _propTypes.default.bool,
/**
* `classes` prop applied to the [`Tooltip`](/api/tooltip/) element.
*/
TooltipClasses: _propTypes.default.object,
/**
* Make the tooltip always visible when the SpeedDial is open.
*/
tooltipOpen: _propTypes.default.bool,
/**
* Placement of the tooltip.
*/
tooltipPlacement: _propTypes.default.oneOf(['bottom-end', 'bottom-start', 'bottom', 'left-end', 'left-start', 'left', 'right-end', 'right-start', 'right', 'top-end', 'top-start', 'top']),
/**
* Label to display in the tooltip.
*/
tooltipTitle: _propTypes.default.node
} : void 0;
var _default = (0, _styles.withStyles)(styles, {
name: 'MuiSpeedDialAction'
})(SpeedDialAction);
exports.default = _default;