UNPKG

grommet

Version:

focus on the essential experience

62 lines (61 loc) 3.28 kB
import styled, { css } from 'styled-components'; import { backgroundStyle, focusStyle, genericStyles, normalizeColor } from '../../utils'; import { defaultProps } from '../../default-props'; import { TableRow } from '../TableRow'; import { Table } from '../Table'; import { TableBody } from '../TableBody'; import { TableHeader } from '../TableHeader'; import { TableFooter } from '../TableFooter'; var StyledDataTable = styled(Table).withConfig({ displayName: "StyledDataTable", componentId: "xrlyjm-0" })(["border-spacing:0;border-collapse:collapse;height:auto;", ";"], genericStyles); StyledDataTable.defaultProps = {}; Object.setPrototypeOf(StyledDataTable.defaultProps, defaultProps); var hoverStyle = css(["", " color:", ";"], function (props) { return backgroundStyle(normalizeColor(props.theme.table && props.theme.table.row && props.theme.table.row.hover && props.theme.table.row.hover.background || props.theme.global.hover.background, props.theme), props.theme); }, function (props) { return normalizeColor(props.theme.table && props.theme.table.row && props.theme.table.row.hover && props.theme.table.row.hover.color || props.theme.global.hover.color, props.theme); }); var StyledDataTableRow = styled(TableRow).withConfig({ displayName: "StyledDataTable__StyledDataTableRow", componentId: "xrlyjm-1" })(["", " ", " &:hover{", "}", ""], function (props) { return props.size && "\n display: table;\n width: 100%;\n table-layout: fixed;\n "; }, function (props) { return props.onClick && "\n cursor: pointer;\n "; }, function (props) { return props.onClickRow && !props.active && hoverStyle; }, function (props) { return props.active && hoverStyle; }); StyledDataTableRow.defaultProps = {}; Object.setPrototypeOf(StyledDataTableRow.defaultProps, defaultProps); // focus styling other than outline doesn't work on <tbody /> var StyledDataTableBody = styled(TableBody).withConfig({ displayName: "StyledDataTable__StyledDataTableBody", componentId: "xrlyjm-2" })(["", " &:focus{", "}"], function (props) { return props.size && "\n display: block;\n width: 100%;\n max-height: " + props.theme.global.size[props.size] + ";\n overflow: auto;\n "; }, focusStyle({ skipSvgChildren: true, forceOutline: true })); StyledDataTableBody.defaultProps = {}; Object.setPrototypeOf(StyledDataTableBody.defaultProps, defaultProps); var StyledDataTableHeader = styled(TableHeader).withConfig({ displayName: "StyledDataTable__StyledDataTableHeader", componentId: "xrlyjm-3" })(["", ""], function (props) { return props.size && "\n display: table;\n width: 100%;\n table-layout: fixed;\n "; }); StyledDataTableHeader.defaultProps = {}; Object.setPrototypeOf(StyledDataTableHeader.defaultProps, defaultProps); var StyledDataTableFooter = styled(TableFooter).withConfig({ displayName: "StyledDataTable__StyledDataTableFooter", componentId: "xrlyjm-4" })(["", ""], function (props) { return props.size && "\n display: table;\n width: 100%;\n table-layout: fixed;\n "; }); StyledDataTableFooter.defaultProps = {}; Object.setPrototypeOf(StyledDataTableFooter.defaultProps, defaultProps); export { StyledDataTable, StyledDataTableRow, StyledDataTableBody, StyledDataTableHeader, StyledDataTableFooter };