123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596 |
- import {useMemo} from 'react';
- import styled from '@emotion/styled';
- import {COL_WIDTH_MINIMUM} from 'sentry/components/gridEditable';
- import type {Alignments} from 'sentry/components/gridEditable/sortLink';
- import {
- Body as _TableWrapper,
- Grid as _Table,
- GridBody,
- GridBodyCell,
- GridBodyCellStatus,
- GridHead,
- GridHeadCell,
- GridRow,
- Header,
- HeaderButtonContainer,
- HeaderTitle,
- } from 'sentry/components/gridEditable/styles';
- import {Actions} from 'sentry/views/discover/table/cellAction';
- interface TableProps extends React.ComponentProps<typeof _TableWrapper> {}
- export function Table({children, style, ...props}: TableProps) {
- return (
- <_TableWrapper {...props}>
- <_Table style={style}>{children}</_Table>
- </_TableWrapper>
- );
- }
- interface TableStatusProps {
- children: React.ReactNode;
- }
- export function TableStatus({children}: TableStatusProps) {
- return (
- <GridRow>
- <GridBodyCellStatus>{children}</GridBodyCellStatus>
- </GridRow>
- );
- }
- export const ALLOWED_CELL_ACTIONS: Actions[] = [
- Actions.ADD,
- Actions.EXCLUDE,
- Actions.SHOW_GREATER_THAN,
- Actions.SHOW_LESS_THAN,
- ];
- const MINIMUM_COLUMN_WIDTH = COL_WIDTH_MINIMUM;
- type Item = {
- label: React.ReactNode;
- value: string;
- width?: number | 'min-content';
- };
- interface UseTableStylesOptions {
- items: Item[];
- minimumColumnWidth?: number;
- }
- export function useTableStyles({
- items,
- minimumColumnWidth = MINIMUM_COLUMN_WIDTH,
- }: UseTableStylesOptions) {
- const tableStyles = useMemo(() => {
- const columns = new Array(items.length);
- for (let i = 0; i < items.length; i++) {
- if (typeof items[i].width === 'number') {
- columns[i] = `${items[i].width}px`;
- } else {
- columns[i] = items[i].width ?? `minmax(${minimumColumnWidth}px, auto)`;
- }
- }
- return {
- gridTemplateColumns: columns.join(' '),
- };
- }, [items, minimumColumnWidth]);
- return {tableStyles};
- }
- export const TableBody = GridBody;
- export const TableRow = GridRow;
- export const TableBodyCell = GridBodyCell;
- export const TableHead = GridHead;
- export const TableHeader = Header;
- export const TableHeaderActions = HeaderButtonContainer;
- export const TableHeaderTitle = HeaderTitle;
- export const TableHeadCell = styled(GridHeadCell)<{align?: Alignments}>`
- ${p => p.align && `justify-content: ${p.align};`}
- `;
|