grommet
Version:
focus on the essential experience
62 lines (61 loc) • 3.28 kB
JavaScript
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 };