UNPKG

@material-ui/core

Version:

React components that implement Google's Material Design.

103 lines (92 loc) 3.27 kB
import _extends from "@babel/runtime/helpers/esm/extends"; import _objectWithoutProperties from "@babel/runtime/helpers/esm/objectWithoutProperties"; import * as React from 'react'; import PropTypes from 'prop-types'; import clsx from 'clsx'; import withStyles from '../styles/withStyles'; import Tablelvl2Context from '../Table/Tablelvl2Context'; import { alpha } from '../styles/colorManipulator'; export var styles = function styles(theme) { return { /* Styles applied to the root element. */ root: { color: 'inherit', display: 'table-row', verticalAlign: 'middle', // We disable the focus ring for mouse, touch and keyboard users. outline: 0, '&$hover:hover': { backgroundColor: theme.palette.action.hover }, '&$selected, &$selected:hover': { backgroundColor: alpha(theme.palette.secondary.main, theme.palette.action.selectedOpacity) } }, /* Pseudo-class applied to the root element if `selected={true}`. */ selected: {}, /* Pseudo-class applied to the root element if `hover={true}`. */ hover: {}, /* Styles applied to the root element if table variant="head". */ head: {}, /* Styles applied to the root element if table variant="footer". */ footer: {} }; }; var defaultComponent = 'tr'; /** * Will automatically set dynamic row height * based on the material table element parent (head, body, etc). */ var TableRow = /*#__PURE__*/React.forwardRef(function TableRow(props, ref) { var classes = props.classes, className = props.className, _props$component = props.component, Component = _props$component === void 0 ? defaultComponent : _props$component, _props$hover = props.hover, hover = _props$hover === void 0 ? false : _props$hover, _props$selected = props.selected, selected = _props$selected === void 0 ? false : _props$selected, other = _objectWithoutProperties(props, ["classes", "className", "component", "hover", "selected"]); var tablelvl2 = React.useContext(Tablelvl2Context); return /*#__PURE__*/React.createElement(Component, _extends({ ref: ref, className: clsx(classes.root, className, tablelvl2 && { 'head': classes.head, 'footer': classes.footer }[tablelvl2.variant], hover && classes.hover, selected && classes.selected), role: Component === defaultComponent ? null : 'row' }, other)); }); process.env.NODE_ENV !== "production" ? TableRow.propTypes = { /** * Should be valid <tr> children such as `TableCell`. */ children: PropTypes.node, /** * Override or extend the styles applied to the component. * See [CSS API](#css) below for more details. */ classes: PropTypes.object.isRequired, /** * @ignore */ className: PropTypes.string, /** * The component used for the root node. * Either a string to use a HTML element or a component. */ component: PropTypes /* @typescript-to-proptypes-ignore */ .elementType, /** * If `true`, the table row will shade on hover. */ hover: PropTypes.bool, /** * If `true`, the table row will have the selected shading. */ selected: PropTypes.bool } : void 0; export default withStyles(styles, { name: 'MuiTableRow' })(TableRow);