@amboss/design-system 1.26.6 → 1.29.0
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/build/cjs/components/DataTable/DataTable.d.ts +12 -6
- package/build/cjs/components/DataTable/DataTable.js +1 -1
- package/build/cjs/components/DataTable/TableBody.d.ts +3 -3
- package/build/cjs/components/DataTable/TableBody.js +1 -1
- package/build/cjs/components/DataTable/TableCell.d.ts +7 -3
- package/build/cjs/components/DataTable/TableCell.js +1 -1
- package/build/cjs/components/DataTable/TableHeader.d.ts +3 -3
- package/build/cjs/components/DataTable/TableHeader.js +1 -1
- package/build/cjs/components/DropdownMenu/DropdownMenu.d.ts +3 -7
- package/build/cjs/components/DropdownMenu/DropdownMenu.js +1 -1
- package/build/cjs/components/DropdownMenu/Menu.d.ts +14 -0
- package/build/cjs/components/DropdownMenu/Menu.js +1 -0
- package/build/cjs/components/DropdownMenu/utils.d.ts +6 -0
- package/build/cjs/components/DropdownMenu/utils.js +1 -0
- package/build/cjs/components/Form/MaskedInput/MaskedInput.d.ts +2 -0
- package/build/cjs/components/Form/MaskedInput/MaskedInput.js +1 -1
- package/build/cjs/components/Icon/Icon.js +1 -1
- package/build/cjs/components/Tooltip/TooltipContent.js +1 -1
- package/build/cjs/components/Tooltip/utils.js +1 -1
- package/build/cjs/web-tokens/assets/icons.json +1 -0
- package/build/cjs/web-tokens/assets/icons16.json +1 -0
- package/build/esm/components/DataTable/DataTable.d.ts +12 -6
- package/build/esm/components/DataTable/DataTable.js +1 -1
- package/build/esm/components/DataTable/TableBody.d.ts +3 -3
- package/build/esm/components/DataTable/TableBody.js +1 -1
- package/build/esm/components/DataTable/TableCell.d.ts +7 -3
- package/build/esm/components/DataTable/TableCell.js +1 -1
- package/build/esm/components/DataTable/TableHeader.d.ts +3 -3
- package/build/esm/components/DataTable/TableHeader.js +1 -1
- package/build/esm/components/DropdownMenu/DropdownMenu.d.ts +3 -7
- package/build/esm/components/DropdownMenu/DropdownMenu.js +1 -1
- package/build/esm/components/DropdownMenu/Menu.d.ts +14 -0
- package/build/esm/components/DropdownMenu/Menu.js +1 -0
- package/build/esm/components/DropdownMenu/utils.d.ts +6 -0
- package/build/esm/components/DropdownMenu/utils.js +1 -0
- package/build/esm/components/Form/MaskedInput/MaskedInput.d.ts +2 -0
- package/build/esm/components/Form/MaskedInput/MaskedInput.js +1 -1
- package/build/esm/components/Icon/Icon.js +1 -1
- package/build/esm/components/Tooltip/TooltipContent.js +1 -1
- package/build/esm/components/Tooltip/utils.js +1 -1
- package/build/esm/web-tokens/assets/icons.json +1 -0
- package/build/esm/web-tokens/assets/icons16.json +1 -0
- package/package.json +1 -1
|
@@ -39,20 +39,26 @@ export type DataTableProps = {
|
|
|
39
39
|
*/
|
|
40
40
|
isEmpty?: boolean;
|
|
41
41
|
/**
|
|
42
|
-
* Is first column sticky on scroll
|
|
42
|
+
* Is first column sticky on horizontal scroll
|
|
43
43
|
*/
|
|
44
44
|
isFirstColumnSticky?: boolean;
|
|
45
|
+
/**
|
|
46
|
+
* Is first column sticky on horizontal scroll
|
|
47
|
+
*/
|
|
48
|
+
isLastColumnSticky?: boolean;
|
|
45
49
|
"data-e2e-test-id"?: string;
|
|
46
50
|
/** Column most recently used to sort data */
|
|
47
51
|
currentlySortedByColumn?: string;
|
|
48
|
-
/**
|
|
49
|
-
* Callback to handle sorting by column
|
|
50
|
-
*/
|
|
51
52
|
/**
|
|
52
53
|
* Empty cell content.
|
|
53
54
|
*/
|
|
54
55
|
emptyCellContent?: string;
|
|
56
|
+
/** Define a vertically scrollable table with max height */
|
|
57
|
+
maxHeight?: string | MQ<string>;
|
|
58
|
+
/**
|
|
59
|
+
* Callback to handle sorting by column
|
|
60
|
+
*/
|
|
55
61
|
onSort?: (columnName: string, desiredSortDirection: DataTableColumn["sortDirection"]) => void;
|
|
56
62
|
};
|
|
57
|
-
export declare function BaseDataTable({ caption, columns, rows, footer, currentlySortedByColumn, isFirstColumnSticky, "data-e2e-test-id": dataE2eTestId, isLoading, loadingStateScreenReaderText, isEmpty, children, emptyTableContentHeight, layout, width, bodyCellVerticalPadding, emptyCellContent, onSort, }: React.PropsWithChildren<DataTableProps>): React.ReactElement;
|
|
58
|
-
export declare function DataTable({ caption, columns, rows, footer, currentlySortedByColumn, isFirstColumnSticky, "data-e2e-test-id": dataE2eTestId, isLoading, loadingStateScreenReaderText, isEmpty, children, emptyTableContentHeight, layout, width, bodyCellVerticalPadding, emptyCellContent, onSort, }: React.PropsWithChildren<DataTableProps>): React.ReactElement;
|
|
63
|
+
export declare function BaseDataTable({ caption, columns, rows, footer, currentlySortedByColumn, isFirstColumnSticky, isLastColumnSticky, "data-e2e-test-id": dataE2eTestId, isLoading, loadingStateScreenReaderText, isEmpty, children, emptyTableContentHeight, layout, width, bodyCellVerticalPadding, emptyCellContent, maxHeight, onSort, }: React.PropsWithChildren<DataTableProps>): React.ReactElement;
|
|
64
|
+
export declare function DataTable({ caption, columns, rows, footer, currentlySortedByColumn, isFirstColumnSticky, isLastColumnSticky, "data-e2e-test-id": dataE2eTestId, isLoading, loadingStateScreenReaderText, isEmpty, children, emptyTableContentHeight, layout, width, bodyCellVerticalPadding, emptyCellContent, maxHeight, onSort, }: React.PropsWithChildren<DataTableProps>): React.ReactElement;
|
|
@@ -1 +1 @@
|
|
|
1
|
-
"use strict";Object.defineProperty(exports,"__esModule",{value:!0}),function(target,all){for(var name in all)Object.defineProperty(target,name,{enumerable:!0,get:all[name]})}(exports,{BaseDataTable:function(){return BaseDataTable},DataTable:function(){return DataTable}});const _interop_require_default=require("@swc/helpers/_/_interop_require_default"),_react=require("@swc/helpers/_/_interop_require_wildcard")._(require("react")),_styled=_interop_require_default._(require("@emotion/styled")),_TableBody=_interop_require_default._(require("./TableBody")),_TableHeader=_interop_require_default._(require("./TableHeader")),_Container=require("../Container/Container"),_ScreenReaderText=require("../../shared/ScreenReaderText"),_mediaQueries=require("../../shared/mediaQueries"),TableContainer=(0,_styled.default)("div",{target:"erdx5by0",label:"TableContainer"})(({theme,footer})=>({overflow:"auto",backgroundColor:theme.values.color.background.primary.default,borderRadius:"inherit",...footer&&{borderBottomLeftRadius:0,borderBottomRightRadius:0}}),"/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"src/components/DataTable/DataTable.tsx","sources":["src/components/DataTable/DataTable.tsx"],"sourcesContent":["import React, { useEffect, useState, useRef } from \"react\";\nimport styled from \"@emotion/styled\";\nimport TableBody from \"./TableBody\";\nimport TableHeader from \"./TableHeader\";\nimport { Container } from \"../Container/Container\";\nimport type { DataTableColumn, DataTableRow } from \"./types\";\nimport { ScreenReaderText } from \"../../shared/ScreenReaderText\";\nimport { mqValue } from \"../../shared/mediaQueries\";\nimport type { MQ } from \"../../types\";\n\nexport type DataTableProps = {\n  /** Screen reader text for table caption */\n  caption: string;\n\n  /** CSS table layout. In 'auto' layout, columns are sized according to content width. In 'fixed' layout, columns can be provided a fixed or percentage width. */\n  layout?: \"auto\" | \"fixed\";\n\n  /** Table width */\n  width?: string | MQ<string>;\n\n  /** Vertical padding on row cells to set table density, condensed (s), default (m), comfortable (l) */\n  bodyCellVerticalPadding?: \"s\" | \"m\" | \"l\" | MQ<\"s\" | \"m\" | \"l\">;\n\n  /** Height of empty/error or loading table content */\n  emptyTableContentHeight?: string | MQ<string>;\n\n  /** Footer element */\n  footer?: React.ReactElement;\n\n  /**\n   * Meta data for columns\n   * @param DataTableColumn[].name - Column name\n   * @param DataTableColumn[].label - Column label for display\n   * @param DataTableColumn[].align - Align cell content, 'left' | 'right' | 'center'\n   * @param DataTableColumn[].width - Column width\n   * @param DataTableColumn[].renderCell - Callback to render custom cell content.\n   * @param DataTableColumn[].isSortable - Is table sortable by column\n   * @param DataTableColumn[].sortDirection - Sorted as 'asc' | 'desc'\n   */\n  columns: DataTableColumn[];\n\n  /**\n   * Table content as an array of objects with values for each column\n   */\n  rows?: DataTableRow[];\n\n  /**\n   * Is loading data. You can display custom loading content with children prop.\n   */\n  isLoading?: boolean;\n\n  /** Screen reader text for loading spinner */\n  loadingStateScreenReaderText?: string;\n\n  /** Is empty or in error state. You can display custom empty/error content with children prop.\n   */\n  isEmpty?: boolean;\n\n  /**\n   * Is first column sticky on scroll\n   */\n  isFirstColumnSticky?: boolean;\n  \"data-e2e-test-id\"?: string;\n\n  /**  Column most recently used to sort data */\n  currentlySortedByColumn?: string;\n\n  /**\n   * Callback to handle sorting by column\n   */\n\n  /**\n   * Empty cell content.\n   */\n  emptyCellContent?: string;\n\n  onSort?: (\n    columnName: string,\n    desiredSortDirection: DataTableColumn[\"sortDirection\"]\n  ) => void;\n};\n\ntype TableContainerProps = Pick<DataTableProps, \"footer\">;\n\nconst TableContainer = styled.div<TableContainerProps>(({ theme, footer }) => ({\n  overflow: \"auto\",\n  backgroundColor: theme.values.color.background.primary.default,\n  borderRadius: \"inherit\",\n  ...(footer && {\n    borderBottomLeftRadius: 0,\n    borderBottomRightRadius: 0,\n  }),\n}));\n\ntype StyledTableProps = Pick<DataTableProps, \"layout\"> & {\n  tableWidth: DataTableProps[\"width\"];\n};\n\nconst StyledTable = styled.table<StyledTableProps>(\n  ({ layout, tableWidth }) => ({\n    borderSpacing: 0,\n    tableLayout: layout,\n    ...mqValue({\n      width: tableWidth,\n    }),\n  })\n);\n\nconst StyledFooter = styled.div(({ theme }) => ({\n  padding: theme.variables.size.spacing.xs,\n  backgroundColor: theme.values.color.background.primary.default,\n  borderBottomLeftRadius: \"inherit\",\n  borderBottomRightRadius: \"inherit\",\n}));\n\nexport function BaseDataTable({\n  caption,\n  columns,\n  rows = [],\n  footer,\n  currentlySortedByColumn,\n  isFirstColumnSticky = true,\n  \"data-e2e-test-id\": dataE2eTestId,\n  isLoading = false,\n  loadingStateScreenReaderText = \"Loading\",\n  isEmpty = false,\n  children,\n  emptyTableContentHeight = \"15rem\",\n  layout = \"auto\",\n  width = \"100%\",\n  bodyCellVerticalPadding = \"m\",\n  emptyCellContent = \"--\",\n  onSort,\n}: React.PropsWithChildren<DataTableProps>): React.ReactElement {\n  const [isScrolled, setIsScrolled] = useState(false);\n  const tableRef = useRef<HTMLTableElement>(null);\n  const containerRef = useRef<HTMLDivElement>(null);\n\n  useEffect(() => {\n    let observer: IntersectionObserver;\n\n    if (\n      typeof IntersectionObserver !== \"undefined\" &&\n      containerRef &&\n      containerRef.current &&\n      tableRef.current\n    ) {\n      observer = new IntersectionObserver(\n        (entries) => {\n          entries.forEach((entry) => {\n            setIsScrolled(!entry.isIntersecting);\n          });\n        },\n        {\n          root: containerRef.current,\n          threshold: 1,\n        }\n      );\n\n      observer.observe(tableRef.current);\n    }\n\n    return () => {\n      if (observer) {\n        observer.disconnect();\n      }\n    };\n  }, []);\n\n  const footerElm = footer ? <StyledFooter>{footer}</StyledFooter> : null;\n\n  return (\n    <>\n      <TableContainer ref={containerRef} footer={footer}>\n        <StyledTable\n          data-e2e-test-id={dataE2eTestId}\n          data-ds-id=\"DataTable\"\n          ref={tableRef}\n          layout={layout}\n          tableWidth={width}\n        >\n          <ScreenReaderText as=\"caption\">{caption}</ScreenReaderText>\n          <TableHeader\n            columns={columns}\n            isFirstColumnSticky={isFirstColumnSticky}\n            currentlySortedByColumn={currentlySortedByColumn}\n            isTableScrolled={isScrolled}\n            onSort={onSort}\n          />\n          <TableBody\n            columns={columns}\n            rows={rows}\n            bodyCellVerticalPadding={bodyCellVerticalPadding}\n            isTableScrolled={isScrolled}\n            isEmpty={isEmpty}\n            isLoading={isLoading}\n            loadingStateScreenReaderText={loadingStateScreenReaderText}\n            emptyTableContentHeight={emptyTableContentHeight}\n            footer={footer}\n            isFirstColumnSticky={isFirstColumnSticky}\n            emptyCellContent={emptyCellContent}\n          >\n            {children}\n          </TableBody>\n        </StyledTable>\n      </TableContainer>\n      {footerElm}\n    </>\n  );\n}\n\nexport function DataTable({\n  caption,\n  columns,\n  rows = [],\n  footer,\n  currentlySortedByColumn,\n  isFirstColumnSticky = true,\n  \"data-e2e-test-id\": dataE2eTestId,\n  isLoading = false,\n  loadingStateScreenReaderText = \"Loading\",\n  isEmpty = false,\n  children,\n  emptyTableContentHeight = \"15rem\",\n  layout = \"auto\",\n  width = \"100%\",\n  bodyCellVerticalPadding = \"m\",\n  emptyCellContent = \"--\",\n  onSort,\n}: React.PropsWithChildren<DataTableProps>): React.ReactElement {\n  return (\n    <Container elevation={1}>\n      <BaseDataTable\n        caption={caption}\n        columns={columns}\n        rows={rows}\n        footer={footer}\n        currentlySortedByColumn={currentlySortedByColumn}\n        isFirstColumnSticky={isFirstColumnSticky}\n        data-e2e-test-id={dataE2eTestId}\n        isLoading={isLoading}\n        loadingStateScreenReaderText={loadingStateScreenReaderText}\n        isEmpty={isEmpty}\n        emptyTableContentHeight={emptyTableContentHeight}\n        layout={layout}\n        width={width}\n        bodyCellVerticalPadding={bodyCellVerticalPadding}\n        emptyCellContent={emptyCellContent}\n        onSort={onSort}\n      >\n        {children}\n      </BaseDataTable>\n    </Container>\n  );\n}\n"],"names":[],"mappings":"AAoFuB"} */"),StyledTable=(0,_styled.default)("table",{target:"erdx5by1",label:"StyledTable"})(({layout,tableWidth})=>({borderSpacing:0,tableLayout:layout,...(0,_mediaQueries.mqValue)({width:tableWidth})}),"/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"src/components/DataTable/DataTable.tsx","sources":["src/components/DataTable/DataTable.tsx"],"sourcesContent":["import React, { useEffect, useState, useRef } from \"react\";\nimport styled from \"@emotion/styled\";\nimport TableBody from \"./TableBody\";\nimport TableHeader from \"./TableHeader\";\nimport { Container } from \"../Container/Container\";\nimport type { DataTableColumn, DataTableRow } from \"./types\";\nimport { ScreenReaderText } from \"../../shared/ScreenReaderText\";\nimport { mqValue } from \"../../shared/mediaQueries\";\nimport type { MQ } from \"../../types\";\n\nexport type DataTableProps = {\n  /** Screen reader text for table caption */\n  caption: string;\n\n  /** CSS table layout. In 'auto' layout, columns are sized according to content width. In 'fixed' layout, columns can be provided a fixed or percentage width. */\n  layout?: \"auto\" | \"fixed\";\n\n  /** Table width */\n  width?: string | MQ<string>;\n\n  /** Vertical padding on row cells to set table density, condensed (s), default (m), comfortable (l) */\n  bodyCellVerticalPadding?: \"s\" | \"m\" | \"l\" | MQ<\"s\" | \"m\" | \"l\">;\n\n  /** Height of empty/error or loading table content */\n  emptyTableContentHeight?: string | MQ<string>;\n\n  /** Footer element */\n  footer?: React.ReactElement;\n\n  /**\n   * Meta data for columns\n   * @param DataTableColumn[].name - Column name\n   * @param DataTableColumn[].label - Column label for display\n   * @param DataTableColumn[].align - Align cell content, 'left' | 'right' | 'center'\n   * @param DataTableColumn[].width - Column width\n   * @param DataTableColumn[].renderCell - Callback to render custom cell content.\n   * @param DataTableColumn[].isSortable - Is table sortable by column\n   * @param DataTableColumn[].sortDirection - Sorted as 'asc' | 'desc'\n   */\n  columns: DataTableColumn[];\n\n  /**\n   * Table content as an array of objects with values for each column\n   */\n  rows?: DataTableRow[];\n\n  /**\n   * Is loading data. You can display custom loading content with children prop.\n   */\n  isLoading?: boolean;\n\n  /** Screen reader text for loading spinner */\n  loadingStateScreenReaderText?: string;\n\n  /** Is empty or in error state. You can display custom empty/error content with children prop.\n   */\n  isEmpty?: boolean;\n\n  /**\n   * Is first column sticky on scroll\n   */\n  isFirstColumnSticky?: boolean;\n  \"data-e2e-test-id\"?: string;\n\n  /**  Column most recently used to sort data */\n  currentlySortedByColumn?: string;\n\n  /**\n   * Callback to handle sorting by column\n   */\n\n  /**\n   * Empty cell content.\n   */\n  emptyCellContent?: string;\n\n  onSort?: (\n    columnName: string,\n    desiredSortDirection: DataTableColumn[\"sortDirection\"]\n  ) => void;\n};\n\ntype TableContainerProps = Pick<DataTableProps, \"footer\">;\n\nconst TableContainer = styled.div<TableContainerProps>(({ theme, footer }) => ({\n  overflow: \"auto\",\n  backgroundColor: theme.values.color.background.primary.default,\n  borderRadius: \"inherit\",\n  ...(footer && {\n    borderBottomLeftRadius: 0,\n    borderBottomRightRadius: 0,\n  }),\n}));\n\ntype StyledTableProps = Pick<DataTableProps, \"layout\"> & {\n  tableWidth: DataTableProps[\"width\"];\n};\n\nconst StyledTable = styled.table<StyledTableProps>(\n  ({ layout, tableWidth }) => ({\n    borderSpacing: 0,\n    tableLayout: layout,\n    ...mqValue({\n      width: tableWidth,\n    }),\n  })\n);\n\nconst StyledFooter = styled.div(({ theme }) => ({\n  padding: theme.variables.size.spacing.xs,\n  backgroundColor: theme.values.color.background.primary.default,\n  borderBottomLeftRadius: \"inherit\",\n  borderBottomRightRadius: \"inherit\",\n}));\n\nexport function BaseDataTable({\n  caption,\n  columns,\n  rows = [],\n  footer,\n  currentlySortedByColumn,\n  isFirstColumnSticky = true,\n  \"data-e2e-test-id\": dataE2eTestId,\n  isLoading = false,\n  loadingStateScreenReaderText = \"Loading\",\n  isEmpty = false,\n  children,\n  emptyTableContentHeight = \"15rem\",\n  layout = \"auto\",\n  width = \"100%\",\n  bodyCellVerticalPadding = \"m\",\n  emptyCellContent = \"--\",\n  onSort,\n}: React.PropsWithChildren<DataTableProps>): React.ReactElement {\n  const [isScrolled, setIsScrolled] = useState(false);\n  const tableRef = useRef<HTMLTableElement>(null);\n  const containerRef = useRef<HTMLDivElement>(null);\n\n  useEffect(() => {\n    let observer: IntersectionObserver;\n\n    if (\n      typeof IntersectionObserver !== \"undefined\" &&\n      containerRef &&\n      containerRef.current &&\n      tableRef.current\n    ) {\n      observer = new IntersectionObserver(\n        (entries) => {\n          entries.forEach((entry) => {\n            setIsScrolled(!entry.isIntersecting);\n          });\n        },\n        {\n          root: containerRef.current,\n          threshold: 1,\n        }\n      );\n\n      observer.observe(tableRef.current);\n    }\n\n    return () => {\n      if (observer) {\n        observer.disconnect();\n      }\n    };\n  }, []);\n\n  const footerElm = footer ? <StyledFooter>{footer}</StyledFooter> : null;\n\n  return (\n    <>\n      <TableContainer ref={containerRef} footer={footer}>\n        <StyledTable\n          data-e2e-test-id={dataE2eTestId}\n          data-ds-id=\"DataTable\"\n          ref={tableRef}\n          layout={layout}\n          tableWidth={width}\n        >\n          <ScreenReaderText as=\"caption\">{caption}</ScreenReaderText>\n          <TableHeader\n            columns={columns}\n            isFirstColumnSticky={isFirstColumnSticky}\n            currentlySortedByColumn={currentlySortedByColumn}\n            isTableScrolled={isScrolled}\n            onSort={onSort}\n          />\n          <TableBody\n            columns={columns}\n            rows={rows}\n            bodyCellVerticalPadding={bodyCellVerticalPadding}\n            isTableScrolled={isScrolled}\n            isEmpty={isEmpty}\n            isLoading={isLoading}\n            loadingStateScreenReaderText={loadingStateScreenReaderText}\n            emptyTableContentHeight={emptyTableContentHeight}\n            footer={footer}\n            isFirstColumnSticky={isFirstColumnSticky}\n            emptyCellContent={emptyCellContent}\n          >\n            {children}\n          </TableBody>\n        </StyledTable>\n      </TableContainer>\n      {footerElm}\n    </>\n  );\n}\n\nexport function DataTable({\n  caption,\n  columns,\n  rows = [],\n  footer,\n  currentlySortedByColumn,\n  isFirstColumnSticky = true,\n  \"data-e2e-test-id\": dataE2eTestId,\n  isLoading = false,\n  loadingStateScreenReaderText = \"Loading\",\n  isEmpty = false,\n  children,\n  emptyTableContentHeight = \"15rem\",\n  layout = \"auto\",\n  width = \"100%\",\n  bodyCellVerticalPadding = \"m\",\n  emptyCellContent = \"--\",\n  onSort,\n}: React.PropsWithChildren<DataTableProps>): React.ReactElement {\n  return (\n    <Container elevation={1}>\n      <BaseDataTable\n        caption={caption}\n        columns={columns}\n        rows={rows}\n        footer={footer}\n        currentlySortedByColumn={currentlySortedByColumn}\n        isFirstColumnSticky={isFirstColumnSticky}\n        data-e2e-test-id={dataE2eTestId}\n        isLoading={isLoading}\n        loadingStateScreenReaderText={loadingStateScreenReaderText}\n        isEmpty={isEmpty}\n        emptyTableContentHeight={emptyTableContentHeight}\n        layout={layout}\n        width={width}\n        bodyCellVerticalPadding={bodyCellVerticalPadding}\n        emptyCellContent={emptyCellContent}\n        onSort={onSort}\n      >\n        {children}\n      </BaseDataTable>\n    </Container>\n  );\n}\n"],"names":[],"mappings":"AAkGoB"} */"),StyledFooter=(0,_styled.default)("div",{target:"erdx5by2",label:"StyledFooter"})(({theme})=>({padding:theme.variables.size.spacing.xs,backgroundColor:theme.values.color.background.primary.default,borderBottomLeftRadius:"inherit",borderBottomRightRadius:"inherit"}),"/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"src/components/DataTable/DataTable.tsx","sources":["src/components/DataTable/DataTable.tsx"],"sourcesContent":["import React, { useEffect, useState, useRef } from \"react\";\nimport styled from \"@emotion/styled\";\nimport TableBody from \"./TableBody\";\nimport TableHeader from \"./TableHeader\";\nimport { Container } from \"../Container/Container\";\nimport type { DataTableColumn, DataTableRow } from \"./types\";\nimport { ScreenReaderText } from \"../../shared/ScreenReaderText\";\nimport { mqValue } from \"../../shared/mediaQueries\";\nimport type { MQ } from \"../../types\";\n\nexport type DataTableProps = {\n  /** Screen reader text for table caption */\n  caption: string;\n\n  /** CSS table layout. In 'auto' layout, columns are sized according to content width. In 'fixed' layout, columns can be provided a fixed or percentage width. */\n  layout?: \"auto\" | \"fixed\";\n\n  /** Table width */\n  width?: string | MQ<string>;\n\n  /** Vertical padding on row cells to set table density, condensed (s), default (m), comfortable (l) */\n  bodyCellVerticalPadding?: \"s\" | \"m\" | \"l\" | MQ<\"s\" | \"m\" | \"l\">;\n\n  /** Height of empty/error or loading table content */\n  emptyTableContentHeight?: string | MQ<string>;\n\n  /** Footer element */\n  footer?: React.ReactElement;\n\n  /**\n   * Meta data for columns\n   * @param DataTableColumn[].name - Column name\n   * @param DataTableColumn[].label - Column label for display\n   * @param DataTableColumn[].align - Align cell content, 'left' | 'right' | 'center'\n   * @param DataTableColumn[].width - Column width\n   * @param DataTableColumn[].renderCell - Callback to render custom cell content.\n   * @param DataTableColumn[].isSortable - Is table sortable by column\n   * @param DataTableColumn[].sortDirection - Sorted as 'asc' | 'desc'\n   */\n  columns: DataTableColumn[];\n\n  /**\n   * Table content as an array of objects with values for each column\n   */\n  rows?: DataTableRow[];\n\n  /**\n   * Is loading data. You can display custom loading content with children prop.\n   */\n  isLoading?: boolean;\n\n  /** Screen reader text for loading spinner */\n  loadingStateScreenReaderText?: string;\n\n  /** Is empty or in error state. You can display custom empty/error content with children prop.\n   */\n  isEmpty?: boolean;\n\n  /**\n   * Is first column sticky on scroll\n   */\n  isFirstColumnSticky?: boolean;\n  \"data-e2e-test-id\"?: string;\n\n  /**  Column most recently used to sort data */\n  currentlySortedByColumn?: string;\n\n  /**\n   * Callback to handle sorting by column\n   */\n\n  /**\n   * Empty cell content.\n   */\n  emptyCellContent?: string;\n\n  onSort?: (\n    columnName: string,\n    desiredSortDirection: DataTableColumn[\"sortDirection\"]\n  ) => void;\n};\n\ntype TableContainerProps = Pick<DataTableProps, \"footer\">;\n\nconst TableContainer = styled.div<TableContainerProps>(({ theme, footer }) => ({\n  overflow: \"auto\",\n  backgroundColor: theme.values.color.background.primary.default,\n  borderRadius: \"inherit\",\n  ...(footer && {\n    borderBottomLeftRadius: 0,\n    borderBottomRightRadius: 0,\n  }),\n}));\n\ntype StyledTableProps = Pick<DataTableProps, \"layout\"> & {\n  tableWidth: DataTableProps[\"width\"];\n};\n\nconst StyledTable = styled.table<StyledTableProps>(\n  ({ layout, tableWidth }) => ({\n    borderSpacing: 0,\n    tableLayout: layout,\n    ...mqValue({\n      width: tableWidth,\n    }),\n  })\n);\n\nconst StyledFooter = styled.div(({ theme }) => ({\n  padding: theme.variables.size.spacing.xs,\n  backgroundColor: theme.values.color.background.primary.default,\n  borderBottomLeftRadius: \"inherit\",\n  borderBottomRightRadius: \"inherit\",\n}));\n\nexport function BaseDataTable({\n  caption,\n  columns,\n  rows = [],\n  footer,\n  currentlySortedByColumn,\n  isFirstColumnSticky = true,\n  \"data-e2e-test-id\": dataE2eTestId,\n  isLoading = false,\n  loadingStateScreenReaderText = \"Loading\",\n  isEmpty = false,\n  children,\n  emptyTableContentHeight = \"15rem\",\n  layout = \"auto\",\n  width = \"100%\",\n  bodyCellVerticalPadding = \"m\",\n  emptyCellContent = \"--\",\n  onSort,\n}: React.PropsWithChildren<DataTableProps>): React.ReactElement {\n  const [isScrolled, setIsScrolled] = useState(false);\n  const tableRef = useRef<HTMLTableElement>(null);\n  const containerRef = useRef<HTMLDivElement>(null);\n\n  useEffect(() => {\n    let observer: IntersectionObserver;\n\n    if (\n      typeof IntersectionObserver !== \"undefined\" &&\n      containerRef &&\n      containerRef.current &&\n      tableRef.current\n    ) {\n      observer = new IntersectionObserver(\n        (entries) => {\n          entries.forEach((entry) => {\n            setIsScrolled(!entry.isIntersecting);\n          });\n        },\n        {\n          root: containerRef.current,\n          threshold: 1,\n        }\n      );\n\n      observer.observe(tableRef.current);\n    }\n\n    return () => {\n      if (observer) {\n        observer.disconnect();\n      }\n    };\n  }, []);\n\n  const footerElm = footer ? <StyledFooter>{footer}</StyledFooter> : null;\n\n  return (\n    <>\n      <TableContainer ref={containerRef} footer={footer}>\n        <StyledTable\n          data-e2e-test-id={dataE2eTestId}\n          data-ds-id=\"DataTable\"\n          ref={tableRef}\n          layout={layout}\n          tableWidth={width}\n        >\n          <ScreenReaderText as=\"caption\">{caption}</ScreenReaderText>\n          <TableHeader\n            columns={columns}\n            isFirstColumnSticky={isFirstColumnSticky}\n            currentlySortedByColumn={currentlySortedByColumn}\n            isTableScrolled={isScrolled}\n            onSort={onSort}\n          />\n          <TableBody\n            columns={columns}\n            rows={rows}\n            bodyCellVerticalPadding={bodyCellVerticalPadding}\n            isTableScrolled={isScrolled}\n            isEmpty={isEmpty}\n            isLoading={isLoading}\n            loadingStateScreenReaderText={loadingStateScreenReaderText}\n            emptyTableContentHeight={emptyTableContentHeight}\n            footer={footer}\n            isFirstColumnSticky={isFirstColumnSticky}\n            emptyCellContent={emptyCellContent}\n          >\n            {children}\n          </TableBody>\n        </StyledTable>\n      </TableContainer>\n      {footerElm}\n    </>\n  );\n}\n\nexport function DataTable({\n  caption,\n  columns,\n  rows = [],\n  footer,\n  currentlySortedByColumn,\n  isFirstColumnSticky = true,\n  \"data-e2e-test-id\": dataE2eTestId,\n  isLoading = false,\n  loadingStateScreenReaderText = \"Loading\",\n  isEmpty = false,\n  children,\n  emptyTableContentHeight = \"15rem\",\n  layout = \"auto\",\n  width = \"100%\",\n  bodyCellVerticalPadding = \"m\",\n  emptyCellContent = \"--\",\n  onSort,\n}: React.PropsWithChildren<DataTableProps>): React.ReactElement {\n  return (\n    <Container elevation={1}>\n      <BaseDataTable\n        caption={caption}\n        columns={columns}\n        rows={rows}\n        footer={footer}\n        currentlySortedByColumn={currentlySortedByColumn}\n        isFirstColumnSticky={isFirstColumnSticky}\n        data-e2e-test-id={dataE2eTestId}\n        isLoading={isLoading}\n        loadingStateScreenReaderText={loadingStateScreenReaderText}\n        isEmpty={isEmpty}\n        emptyTableContentHeight={emptyTableContentHeight}\n        layout={layout}\n        width={width}\n        bodyCellVerticalPadding={bodyCellVerticalPadding}\n        emptyCellContent={emptyCellContent}\n        onSort={onSort}\n      >\n        {children}\n      </BaseDataTable>\n    </Container>\n  );\n}\n"],"names":[],"mappings":"AA4GqB"} */");function BaseDataTable({caption,columns,rows=[],footer,currentlySortedByColumn,isFirstColumnSticky=!0,"data-e2e-test-id":dataE2eTestId,isLoading=!1,loadingStateScreenReaderText="Loading",isEmpty=!1,children,emptyTableContentHeight="15rem",layout="auto",width="100%",bodyCellVerticalPadding="m",emptyCellContent="--",onSort}){let[isScrolled,setIsScrolled]=(0,_react.useState)(!1),tableRef=(0,_react.useRef)(null),containerRef=(0,_react.useRef)(null);(0,_react.useEffect)(()=>{let observer;return"undefined"!=typeof IntersectionObserver&&containerRef&&containerRef.current&&tableRef.current&&(observer=new IntersectionObserver(entries=>{entries.forEach(entry=>{setIsScrolled(!entry.isIntersecting)})},{root:containerRef.current,threshold:1})).observe(tableRef.current),()=>{observer&&observer.disconnect()}},[]);let footerElm=footer?_react.default.createElement(StyledFooter,null,footer):null;return _react.default.createElement(_react.default.Fragment,null,_react.default.createElement(TableContainer,{ref:containerRef,footer:footer},_react.default.createElement(StyledTable,{"data-e2e-test-id":dataE2eTestId,"data-ds-id":"DataTable",ref:tableRef,layout:layout,tableWidth:width},_react.default.createElement(_ScreenReaderText.ScreenReaderText,{as:"caption"},caption),_react.default.createElement(_TableHeader.default,{columns:columns,isFirstColumnSticky:isFirstColumnSticky,currentlySortedByColumn:currentlySortedByColumn,isTableScrolled:isScrolled,onSort:onSort}),_react.default.createElement(_TableBody.default,{columns:columns,rows:rows,bodyCellVerticalPadding:bodyCellVerticalPadding,isTableScrolled:isScrolled,isEmpty:isEmpty,isLoading:isLoading,loadingStateScreenReaderText:loadingStateScreenReaderText,emptyTableContentHeight:emptyTableContentHeight,footer:footer,isFirstColumnSticky:isFirstColumnSticky,emptyCellContent:emptyCellContent},children))),footerElm)}function DataTable({caption,columns,rows=[],footer,currentlySortedByColumn,isFirstColumnSticky=!0,"data-e2e-test-id":dataE2eTestId,isLoading=!1,loadingStateScreenReaderText="Loading",isEmpty=!1,children,emptyTableContentHeight="15rem",layout="auto",width="100%",bodyCellVerticalPadding="m",emptyCellContent="--",onSort}){return _react.default.createElement(_Container.Container,{elevation:1},_react.default.createElement(BaseDataTable,{caption:caption,columns:columns,rows:rows,footer:footer,currentlySortedByColumn:currentlySortedByColumn,isFirstColumnSticky:isFirstColumnSticky,"data-e2e-test-id":dataE2eTestId,isLoading:isLoading,loadingStateScreenReaderText:loadingStateScreenReaderText,isEmpty:isEmpty,emptyTableContentHeight:emptyTableContentHeight,layout:layout,width:width,bodyCellVerticalPadding:bodyCellVerticalPadding,emptyCellContent:emptyCellContent,onSort:onSort},children))}
|
|
1
|
+
"use strict";Object.defineProperty(exports,"__esModule",{value:!0}),function(target,all){for(var name in all)Object.defineProperty(target,name,{enumerable:!0,get:all[name]})}(exports,{BaseDataTable:function(){return BaseDataTable},DataTable:function(){return DataTable}});const _interop_require_default=require("@swc/helpers/_/_interop_require_default"),_react=require("@swc/helpers/_/_interop_require_wildcard")._(require("react")),_styled=_interop_require_default._(require("@emotion/styled")),_TableBody=_interop_require_default._(require("./TableBody")),_TableHeader=_interop_require_default._(require("./TableHeader")),_Container=require("../Container/Container"),_ScreenReaderText=require("../../shared/ScreenReaderText"),_mediaQueries=require("../../shared/mediaQueries");function getTableScrolledToRight(elm){let elmRect=elm.getBoundingClientRect();return elm.scrollLeft+elmRect.width>=elm.scrollWidth}const TableContainer=(0,_styled.default)("div",{target:"ecq7ipt0",label:"TableContainer"})(({theme,footer,maxHeight})=>({overflow:"auto",backgroundColor:theme.values.color.background.primary.default,borderRadius:"inherit",...(0,_mediaQueries.mqValue)({maxHeight}),...footer&&{borderBottomLeftRadius:0,borderBottomRightRadius:0}}),"/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"src/components/DataTable/DataTable.tsx","sources":["src/components/DataTable/DataTable.tsx"],"sourcesContent":["import React, { useEffect, useState, useRef, useCallback } from \"react\";\nimport styled from \"@emotion/styled\";\nimport TableBody from \"./TableBody\";\nimport TableHeader from \"./TableHeader\";\nimport { Container } from \"../Container/Container\";\nimport type { DataTableColumn, DataTableRow } from \"./types\";\nimport { ScreenReaderText } from \"../../shared/ScreenReaderText\";\nimport { mqValue } from \"../../shared/mediaQueries\";\nimport type { MQ } from \"../../types\";\n\nexport type DataTableProps = {\n  /** Screen reader text for table caption */\n  caption: string;\n\n  /** CSS table layout. In 'auto' layout, columns are sized according to content width. In 'fixed' layout, columns can be provided a fixed or percentage width. */\n  layout?: \"auto\" | \"fixed\";\n\n  /** Table width */\n  width?: string | MQ<string>;\n\n  /** Vertical padding on row cells to set table density, condensed (s), default (m), comfortable (l) */\n  bodyCellVerticalPadding?: \"s\" | \"m\" | \"l\" | MQ<\"s\" | \"m\" | \"l\">;\n\n  /** Height of empty/error or loading table content */\n  emptyTableContentHeight?: string | MQ<string>;\n\n  /** Footer element */\n  footer?: React.ReactElement;\n\n  /**\n   * Meta data for columns\n   * @param DataTableColumn[].name - Column name\n   * @param DataTableColumn[].label - Column label for display\n   * @param DataTableColumn[].align - Align cell content, 'left' | 'right' | 'center'\n   * @param DataTableColumn[].width - Column width\n   * @param DataTableColumn[].renderCell - Callback to render custom cell content.\n   * @param DataTableColumn[].isSortable - Is table sortable by column\n   * @param DataTableColumn[].sortDirection - Sorted as 'asc' | 'desc'\n   */\n  columns: DataTableColumn[];\n\n  /**\n   * Table content as an array of objects with values for each column\n   */\n  rows?: DataTableRow[];\n\n  /**\n   * Is loading data. You can display custom loading content with children prop.\n   */\n  isLoading?: boolean;\n\n  /** Screen reader text for loading spinner */\n  loadingStateScreenReaderText?: string;\n\n  /** Is empty or in error state. You can display custom empty/error content with children prop.\n   */\n  isEmpty?: boolean;\n\n  /**\n   * Is first column sticky on horizontal scroll\n   */\n  isFirstColumnSticky?: boolean;\n\n  /**\n   * Is first column sticky on horizontal scroll\n   */\n  isLastColumnSticky?: boolean;\n\n  \"data-e2e-test-id\"?: string;\n\n  /**  Column most recently used to sort data */\n  currentlySortedByColumn?: string;\n\n  /**\n   * Empty cell content.\n   */\n  emptyCellContent?: string;\n\n  /** Define a vertically scrollable table with max height */\n  maxHeight?: string | MQ<string>;\n\n  /**\n   * Callback to handle sorting by column\n   */\n  onSort?: (\n    columnName: string,\n    desiredSortDirection: DataTableColumn[\"sortDirection\"]\n  ) => void;\n};\n\nfunction getTableScrolledToRight(elm: HTMLDivElement) {\n  const elmRect = elm.getBoundingClientRect();\n\n  return elm.scrollLeft + elmRect.width >= elm.scrollWidth;\n}\n\ntype TableContainerProps = Pick<DataTableProps, \"footer\" | \"maxHeight\">;\n\nconst TableContainer = styled.div<TableContainerProps>(\n  ({ theme, footer, maxHeight }) => ({\n    overflow: \"auto\",\n    backgroundColor: theme.values.color.background.primary.default,\n    borderRadius: \"inherit\",\n\n    ...mqValue({\n      maxHeight,\n    }),\n\n    ...(footer && {\n      borderBottomLeftRadius: 0,\n      borderBottomRightRadius: 0,\n    }),\n  })\n);\n\ntype StyledTableProps = Pick<DataTableProps, \"layout\"> & {\n  tableWidth: DataTableProps[\"width\"];\n};\n\nconst StyledTable = styled.table<StyledTableProps>(\n  ({ layout, tableWidth }) => ({\n    borderSpacing: 0,\n    tableLayout: layout,\n    ...mqValue({\n      width: tableWidth,\n    }),\n  })\n);\n\nconst StyledFooter = styled.div(({ theme }) => ({\n  padding: theme.variables.size.spacing.xs,\n  backgroundColor: theme.values.color.background.primary.default,\n  borderBottomLeftRadius: \"inherit\",\n  borderBottomRightRadius: \"inherit\",\n}));\n\nexport function BaseDataTable({\n  caption,\n  columns,\n  rows = [],\n  footer,\n  currentlySortedByColumn,\n  isFirstColumnSticky = true,\n  isLastColumnSticky = false,\n  \"data-e2e-test-id\": dataE2eTestId,\n  isLoading = false,\n  loadingStateScreenReaderText = \"Loading\",\n  isEmpty = false,\n  children,\n  emptyTableContentHeight = \"15rem\",\n  layout = \"auto\",\n  width = \"100%\",\n  bodyCellVerticalPadding = \"m\",\n  emptyCellContent = \"--\",\n  maxHeight,\n  onSort,\n}: React.PropsWithChildren<DataTableProps>): React.ReactElement {\n  const [isScrolledToRight, setIsScrolledToRight] =\n    useState(isLastColumnSticky);\n  const [isScrolledToLeft, setIsScrolledToLeft] = useState(isFirstColumnSticky);\n  const tableRef = useRef<HTMLTableElement>(null);\n  const containerRef = useRef<HTMLDivElement>(null);\n\n  const handleScroll = useCallback((evt) => {\n    const elm = evt.target;\n\n    setIsScrolledToLeft(elm.scrollLeft === 0);\n    setIsScrolledToRight(getTableScrolledToRight(elm));\n  }, []);\n\n  useEffect(() => {\n    let resizeObserver: ResizeObserver;\n\n    if (\n      typeof ResizeObserver !== \"undefined\" &&\n      containerRef &&\n      containerRef.current\n    ) {\n      resizeObserver = new ResizeObserver((entries) => {\n        entries.forEach(() => {\n          setIsScrolledToLeft(containerRef.current.scrollLeft === 0);\n          setIsScrolledToRight(getTableScrolledToRight(containerRef.current));\n        });\n      });\n\n      resizeObserver.observe(containerRef.current);\n    }\n\n    return () => {\n      if (resizeObserver) {\n        resizeObserver.disconnect();\n      }\n    };\n  }, [containerRef]);\n\n  const footerElm = footer ? <StyledFooter>{footer}</StyledFooter> : null;\n\n  return (\n    <>\n      <TableContainer\n        ref={containerRef}\n        footer={footer}\n        maxHeight={maxHeight}\n        onScroll={handleScroll}\n      >\n        <StyledTable\n          data-e2e-test-id={dataE2eTestId}\n          data-ds-id=\"DataTable\"\n          ref={tableRef}\n          layout={layout}\n          tableWidth={width}\n        >\n          <ScreenReaderText as=\"caption\">{caption}</ScreenReaderText>\n          <TableHeader\n            columns={columns}\n            isFirstColumnSticky={isFirstColumnSticky}\n            isLastColumnSticky={isLastColumnSticky}\n            currentlySortedByColumn={currentlySortedByColumn}\n            isTableScrolledToLeft={isScrolledToLeft}\n            isTableScrolledToRight={isScrolledToRight}\n            maxHeight={maxHeight}\n            onSort={onSort}\n          />\n          <TableBody\n            columns={columns}\n            rows={rows}\n            bodyCellVerticalPadding={bodyCellVerticalPadding}\n            isTableScrolledToLeft={isScrolledToLeft}\n            isTableScrolledToRight={isScrolledToRight}\n            isEmpty={isEmpty}\n            isLoading={isLoading}\n            loadingStateScreenReaderText={loadingStateScreenReaderText}\n            emptyTableContentHeight={emptyTableContentHeight}\n            footer={footer}\n            isFirstColumnSticky={isFirstColumnSticky}\n            isLastColumnSticky={isLastColumnSticky}\n            emptyCellContent={emptyCellContent}\n          >\n            {children}\n          </TableBody>\n        </StyledTable>\n      </TableContainer>\n      {footerElm}\n    </>\n  );\n}\n\nexport function DataTable({\n  caption,\n  columns,\n  rows = [],\n  footer,\n  currentlySortedByColumn,\n  isFirstColumnSticky = true,\n  isLastColumnSticky = false,\n  \"data-e2e-test-id\": dataE2eTestId,\n  isLoading = false,\n  loadingStateScreenReaderText = \"Loading\",\n  isEmpty = false,\n  children,\n  emptyTableContentHeight = \"15rem\",\n  layout = \"auto\",\n  width = \"100%\",\n  bodyCellVerticalPadding = \"m\",\n  emptyCellContent = \"--\",\n  maxHeight,\n  onSort,\n}: React.PropsWithChildren<DataTableProps>): React.ReactElement {\n  return (\n    <Container elevation={1}>\n      <BaseDataTable\n        caption={caption}\n        columns={columns}\n        rows={rows}\n        footer={footer}\n        currentlySortedByColumn={currentlySortedByColumn}\n        isFirstColumnSticky={isFirstColumnSticky}\n        isLastColumnSticky={isLastColumnSticky}\n        data-e2e-test-id={dataE2eTestId}\n        isLoading={isLoading}\n        loadingStateScreenReaderText={loadingStateScreenReaderText}\n        isEmpty={isEmpty}\n        emptyTableContentHeight={emptyTableContentHeight}\n        layout={layout}\n        width={width}\n        bodyCellVerticalPadding={bodyCellVerticalPadding}\n        emptyCellContent={emptyCellContent}\n        maxHeight={maxHeight}\n        onSort={onSort}\n      >\n        {children}\n      </BaseDataTable>\n    </Container>\n  );\n}\n"],"names":[],"mappings":"AAkGuB"} */"),StyledTable=(0,_styled.default)("table",{target:"ecq7ipt1",label:"StyledTable"})(({layout,tableWidth})=>({borderSpacing:0,tableLayout:layout,...(0,_mediaQueries.mqValue)({width:tableWidth})}),"/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"src/components/DataTable/DataTable.tsx","sources":["src/components/DataTable/DataTable.tsx"],"sourcesContent":["import React, { useEffect, useState, useRef, useCallback } from \"react\";\nimport styled from \"@emotion/styled\";\nimport TableBody from \"./TableBody\";\nimport TableHeader from \"./TableHeader\";\nimport { Container } from \"../Container/Container\";\nimport type { DataTableColumn, DataTableRow } from \"./types\";\nimport { ScreenReaderText } from \"../../shared/ScreenReaderText\";\nimport { mqValue } from \"../../shared/mediaQueries\";\nimport type { MQ } from \"../../types\";\n\nexport type DataTableProps = {\n  /** Screen reader text for table caption */\n  caption: string;\n\n  /** CSS table layout. In 'auto' layout, columns are sized according to content width. In 'fixed' layout, columns can be provided a fixed or percentage width. */\n  layout?: \"auto\" | \"fixed\";\n\n  /** Table width */\n  width?: string | MQ<string>;\n\n  /** Vertical padding on row cells to set table density, condensed (s), default (m), comfortable (l) */\n  bodyCellVerticalPadding?: \"s\" | \"m\" | \"l\" | MQ<\"s\" | \"m\" | \"l\">;\n\n  /** Height of empty/error or loading table content */\n  emptyTableContentHeight?: string | MQ<string>;\n\n  /** Footer element */\n  footer?: React.ReactElement;\n\n  /**\n   * Meta data for columns\n   * @param DataTableColumn[].name - Column name\n   * @param DataTableColumn[].label - Column label for display\n   * @param DataTableColumn[].align - Align cell content, 'left' | 'right' | 'center'\n   * @param DataTableColumn[].width - Column width\n   * @param DataTableColumn[].renderCell - Callback to render custom cell content.\n   * @param DataTableColumn[].isSortable - Is table sortable by column\n   * @param DataTableColumn[].sortDirection - Sorted as 'asc' | 'desc'\n   */\n  columns: DataTableColumn[];\n\n  /**\n   * Table content as an array of objects with values for each column\n   */\n  rows?: DataTableRow[];\n\n  /**\n   * Is loading data. You can display custom loading content with children prop.\n   */\n  isLoading?: boolean;\n\n  /** Screen reader text for loading spinner */\n  loadingStateScreenReaderText?: string;\n\n  /** Is empty or in error state. You can display custom empty/error content with children prop.\n   */\n  isEmpty?: boolean;\n\n  /**\n   * Is first column sticky on horizontal scroll\n   */\n  isFirstColumnSticky?: boolean;\n\n  /**\n   * Is first column sticky on horizontal scroll\n   */\n  isLastColumnSticky?: boolean;\n\n  \"data-e2e-test-id\"?: string;\n\n  /**  Column most recently used to sort data */\n  currentlySortedByColumn?: string;\n\n  /**\n   * Empty cell content.\n   */\n  emptyCellContent?: string;\n\n  /** Define a vertically scrollable table with max height */\n  maxHeight?: string | MQ<string>;\n\n  /**\n   * Callback to handle sorting by column\n   */\n  onSort?: (\n    columnName: string,\n    desiredSortDirection: DataTableColumn[\"sortDirection\"]\n  ) => void;\n};\n\nfunction getTableScrolledToRight(elm: HTMLDivElement) {\n  const elmRect = elm.getBoundingClientRect();\n\n  return elm.scrollLeft + elmRect.width >= elm.scrollWidth;\n}\n\ntype TableContainerProps = Pick<DataTableProps, \"footer\" | \"maxHeight\">;\n\nconst TableContainer = styled.div<TableContainerProps>(\n  ({ theme, footer, maxHeight }) => ({\n    overflow: \"auto\",\n    backgroundColor: theme.values.color.background.primary.default,\n    borderRadius: \"inherit\",\n\n    ...mqValue({\n      maxHeight,\n    }),\n\n    ...(footer && {\n      borderBottomLeftRadius: 0,\n      borderBottomRightRadius: 0,\n    }),\n  })\n);\n\ntype StyledTableProps = Pick<DataTableProps, \"layout\"> & {\n  tableWidth: DataTableProps[\"width\"];\n};\n\nconst StyledTable = styled.table<StyledTableProps>(\n  ({ layout, tableWidth }) => ({\n    borderSpacing: 0,\n    tableLayout: layout,\n    ...mqValue({\n      width: tableWidth,\n    }),\n  })\n);\n\nconst StyledFooter = styled.div(({ theme }) => ({\n  padding: theme.variables.size.spacing.xs,\n  backgroundColor: theme.values.color.background.primary.default,\n  borderBottomLeftRadius: \"inherit\",\n  borderBottomRightRadius: \"inherit\",\n}));\n\nexport function BaseDataTable({\n  caption,\n  columns,\n  rows = [],\n  footer,\n  currentlySortedByColumn,\n  isFirstColumnSticky = true,\n  isLastColumnSticky = false,\n  \"data-e2e-test-id\": dataE2eTestId,\n  isLoading = false,\n  loadingStateScreenReaderText = \"Loading\",\n  isEmpty = false,\n  children,\n  emptyTableContentHeight = \"15rem\",\n  layout = \"auto\",\n  width = \"100%\",\n  bodyCellVerticalPadding = \"m\",\n  emptyCellContent = \"--\",\n  maxHeight,\n  onSort,\n}: React.PropsWithChildren<DataTableProps>): React.ReactElement {\n  const [isScrolledToRight, setIsScrolledToRight] =\n    useState(isLastColumnSticky);\n  const [isScrolledToLeft, setIsScrolledToLeft] = useState(isFirstColumnSticky);\n  const tableRef = useRef<HTMLTableElement>(null);\n  const containerRef = useRef<HTMLDivElement>(null);\n\n  const handleScroll = useCallback((evt) => {\n    const elm = evt.target;\n\n    setIsScrolledToLeft(elm.scrollLeft === 0);\n    setIsScrolledToRight(getTableScrolledToRight(elm));\n  }, []);\n\n  useEffect(() => {\n    let resizeObserver: ResizeObserver;\n\n    if (\n      typeof ResizeObserver !== \"undefined\" &&\n      containerRef &&\n      containerRef.current\n    ) {\n      resizeObserver = new ResizeObserver((entries) => {\n        entries.forEach(() => {\n          setIsScrolledToLeft(containerRef.current.scrollLeft === 0);\n          setIsScrolledToRight(getTableScrolledToRight(containerRef.current));\n        });\n      });\n\n      resizeObserver.observe(containerRef.current);\n    }\n\n    return () => {\n      if (resizeObserver) {\n        resizeObserver.disconnect();\n      }\n    };\n  }, [containerRef]);\n\n  const footerElm = footer ? <StyledFooter>{footer}</StyledFooter> : null;\n\n  return (\n    <>\n      <TableContainer\n        ref={containerRef}\n        footer={footer}\n        maxHeight={maxHeight}\n        onScroll={handleScroll}\n      >\n        <StyledTable\n          data-e2e-test-id={dataE2eTestId}\n          data-ds-id=\"DataTable\"\n          ref={tableRef}\n          layout={layout}\n          tableWidth={width}\n        >\n          <ScreenReaderText as=\"caption\">{caption}</ScreenReaderText>\n          <TableHeader\n            columns={columns}\n            isFirstColumnSticky={isFirstColumnSticky}\n            isLastColumnSticky={isLastColumnSticky}\n            currentlySortedByColumn={currentlySortedByColumn}\n            isTableScrolledToLeft={isScrolledToLeft}\n            isTableScrolledToRight={isScrolledToRight}\n            maxHeight={maxHeight}\n            onSort={onSort}\n          />\n          <TableBody\n            columns={columns}\n            rows={rows}\n            bodyCellVerticalPadding={bodyCellVerticalPadding}\n            isTableScrolledToLeft={isScrolledToLeft}\n            isTableScrolledToRight={isScrolledToRight}\n            isEmpty={isEmpty}\n            isLoading={isLoading}\n            loadingStateScreenReaderText={loadingStateScreenReaderText}\n            emptyTableContentHeight={emptyTableContentHeight}\n            footer={footer}\n            isFirstColumnSticky={isFirstColumnSticky}\n            isLastColumnSticky={isLastColumnSticky}\n            emptyCellContent={emptyCellContent}\n          >\n            {children}\n          </TableBody>\n        </StyledTable>\n      </TableContainer>\n      {footerElm}\n    </>\n  );\n}\n\nexport function DataTable({\n  caption,\n  columns,\n  rows = [],\n  footer,\n  currentlySortedByColumn,\n  isFirstColumnSticky = true,\n  isLastColumnSticky = false,\n  \"data-e2e-test-id\": dataE2eTestId,\n  isLoading = false,\n  loadingStateScreenReaderText = \"Loading\",\n  isEmpty = false,\n  children,\n  emptyTableContentHeight = \"15rem\",\n  layout = \"auto\",\n  width = \"100%\",\n  bodyCellVerticalPadding = \"m\",\n  emptyCellContent = \"--\",\n  maxHeight,\n  onSort,\n}: React.PropsWithChildren<DataTableProps>): React.ReactElement {\n  return (\n    <Container elevation={1}>\n      <BaseDataTable\n        caption={caption}\n        columns={columns}\n        rows={rows}\n        footer={footer}\n        currentlySortedByColumn={currentlySortedByColumn}\n        isFirstColumnSticky={isFirstColumnSticky}\n        isLastColumnSticky={isLastColumnSticky}\n        data-e2e-test-id={dataE2eTestId}\n        isLoading={isLoading}\n        loadingStateScreenReaderText={loadingStateScreenReaderText}\n        isEmpty={isEmpty}\n        emptyTableContentHeight={emptyTableContentHeight}\n        layout={layout}\n        width={width}\n        bodyCellVerticalPadding={bodyCellVerticalPadding}\n        emptyCellContent={emptyCellContent}\n        maxHeight={maxHeight}\n        onSort={onSort}\n      >\n        {children}\n      </BaseDataTable>\n    </Container>\n  );\n}\n"],"names":[],"mappings":"AAuHoB"} */"),StyledFooter=(0,_styled.default)("div",{target:"ecq7ipt2",label:"StyledFooter"})(({theme})=>({padding:theme.variables.size.spacing.xs,backgroundColor:theme.values.color.background.primary.default,borderBottomLeftRadius:"inherit",borderBottomRightRadius:"inherit"}),"/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"src/components/DataTable/DataTable.tsx","sources":["src/components/DataTable/DataTable.tsx"],"sourcesContent":["import React, { useEffect, useState, useRef, useCallback } from \"react\";\nimport styled from \"@emotion/styled\";\nimport TableBody from \"./TableBody\";\nimport TableHeader from \"./TableHeader\";\nimport { Container } from \"../Container/Container\";\nimport type { DataTableColumn, DataTableRow } from \"./types\";\nimport { ScreenReaderText } from \"../../shared/ScreenReaderText\";\nimport { mqValue } from \"../../shared/mediaQueries\";\nimport type { MQ } from \"../../types\";\n\nexport type DataTableProps = {\n  /** Screen reader text for table caption */\n  caption: string;\n\n  /** CSS table layout. In 'auto' layout, columns are sized according to content width. In 'fixed' layout, columns can be provided a fixed or percentage width. */\n  layout?: \"auto\" | \"fixed\";\n\n  /** Table width */\n  width?: string | MQ<string>;\n\n  /** Vertical padding on row cells to set table density, condensed (s), default (m), comfortable (l) */\n  bodyCellVerticalPadding?: \"s\" | \"m\" | \"l\" | MQ<\"s\" | \"m\" | \"l\">;\n\n  /** Height of empty/error or loading table content */\n  emptyTableContentHeight?: string | MQ<string>;\n\n  /** Footer element */\n  footer?: React.ReactElement;\n\n  /**\n   * Meta data for columns\n   * @param DataTableColumn[].name - Column name\n   * @param DataTableColumn[].label - Column label for display\n   * @param DataTableColumn[].align - Align cell content, 'left' | 'right' | 'center'\n   * @param DataTableColumn[].width - Column width\n   * @param DataTableColumn[].renderCell - Callback to render custom cell content.\n   * @param DataTableColumn[].isSortable - Is table sortable by column\n   * @param DataTableColumn[].sortDirection - Sorted as 'asc' | 'desc'\n   */\n  columns: DataTableColumn[];\n\n  /**\n   * Table content as an array of objects with values for each column\n   */\n  rows?: DataTableRow[];\n\n  /**\n   * Is loading data. You can display custom loading content with children prop.\n   */\n  isLoading?: boolean;\n\n  /** Screen reader text for loading spinner */\n  loadingStateScreenReaderText?: string;\n\n  /** Is empty or in error state. You can display custom empty/error content with children prop.\n   */\n  isEmpty?: boolean;\n\n  /**\n   * Is first column sticky on horizontal scroll\n   */\n  isFirstColumnSticky?: boolean;\n\n  /**\n   * Is first column sticky on horizontal scroll\n   */\n  isLastColumnSticky?: boolean;\n\n  \"data-e2e-test-id\"?: string;\n\n  /**  Column most recently used to sort data */\n  currentlySortedByColumn?: string;\n\n  /**\n   * Empty cell content.\n   */\n  emptyCellContent?: string;\n\n  /** Define a vertically scrollable table with max height */\n  maxHeight?: string | MQ<string>;\n\n  /**\n   * Callback to handle sorting by column\n   */\n  onSort?: (\n    columnName: string,\n    desiredSortDirection: DataTableColumn[\"sortDirection\"]\n  ) => void;\n};\n\nfunction getTableScrolledToRight(elm: HTMLDivElement) {\n  const elmRect = elm.getBoundingClientRect();\n\n  return elm.scrollLeft + elmRect.width >= elm.scrollWidth;\n}\n\ntype TableContainerProps = Pick<DataTableProps, \"footer\" | \"maxHeight\">;\n\nconst TableContainer = styled.div<TableContainerProps>(\n  ({ theme, footer, maxHeight }) => ({\n    overflow: \"auto\",\n    backgroundColor: theme.values.color.background.primary.default,\n    borderRadius: \"inherit\",\n\n    ...mqValue({\n      maxHeight,\n    }),\n\n    ...(footer && {\n      borderBottomLeftRadius: 0,\n      borderBottomRightRadius: 0,\n    }),\n  })\n);\n\ntype StyledTableProps = Pick<DataTableProps, \"layout\"> & {\n  tableWidth: DataTableProps[\"width\"];\n};\n\nconst StyledTable = styled.table<StyledTableProps>(\n  ({ layout, tableWidth }) => ({\n    borderSpacing: 0,\n    tableLayout: layout,\n    ...mqValue({\n      width: tableWidth,\n    }),\n  })\n);\n\nconst StyledFooter = styled.div(({ theme }) => ({\n  padding: theme.variables.size.spacing.xs,\n  backgroundColor: theme.values.color.background.primary.default,\n  borderBottomLeftRadius: \"inherit\",\n  borderBottomRightRadius: \"inherit\",\n}));\n\nexport function BaseDataTable({\n  caption,\n  columns,\n  rows = [],\n  footer,\n  currentlySortedByColumn,\n  isFirstColumnSticky = true,\n  isLastColumnSticky = false,\n  \"data-e2e-test-id\": dataE2eTestId,\n  isLoading = false,\n  loadingStateScreenReaderText = \"Loading\",\n  isEmpty = false,\n  children,\n  emptyTableContentHeight = \"15rem\",\n  layout = \"auto\",\n  width = \"100%\",\n  bodyCellVerticalPadding = \"m\",\n  emptyCellContent = \"--\",\n  maxHeight,\n  onSort,\n}: React.PropsWithChildren<DataTableProps>): React.ReactElement {\n  const [isScrolledToRight, setIsScrolledToRight] =\n    useState(isLastColumnSticky);\n  const [isScrolledToLeft, setIsScrolledToLeft] = useState(isFirstColumnSticky);\n  const tableRef = useRef<HTMLTableElement>(null);\n  const containerRef = useRef<HTMLDivElement>(null);\n\n  const handleScroll = useCallback((evt) => {\n    const elm = evt.target;\n\n    setIsScrolledToLeft(elm.scrollLeft === 0);\n    setIsScrolledToRight(getTableScrolledToRight(elm));\n  }, []);\n\n  useEffect(() => {\n    let resizeObserver: ResizeObserver;\n\n    if (\n      typeof ResizeObserver !== \"undefined\" &&\n      containerRef &&\n      containerRef.current\n    ) {\n      resizeObserver = new ResizeObserver((entries) => {\n        entries.forEach(() => {\n          setIsScrolledToLeft(containerRef.current.scrollLeft === 0);\n          setIsScrolledToRight(getTableScrolledToRight(containerRef.current));\n        });\n      });\n\n      resizeObserver.observe(containerRef.current);\n    }\n\n    return () => {\n      if (resizeObserver) {\n        resizeObserver.disconnect();\n      }\n    };\n  }, [containerRef]);\n\n  const footerElm = footer ? <StyledFooter>{footer}</StyledFooter> : null;\n\n  return (\n    <>\n      <TableContainer\n        ref={containerRef}\n        footer={footer}\n        maxHeight={maxHeight}\n        onScroll={handleScroll}\n      >\n        <StyledTable\n          data-e2e-test-id={dataE2eTestId}\n          data-ds-id=\"DataTable\"\n          ref={tableRef}\n          layout={layout}\n          tableWidth={width}\n        >\n          <ScreenReaderText as=\"caption\">{caption}</ScreenReaderText>\n          <TableHeader\n            columns={columns}\n            isFirstColumnSticky={isFirstColumnSticky}\n            isLastColumnSticky={isLastColumnSticky}\n            currentlySortedByColumn={currentlySortedByColumn}\n            isTableScrolledToLeft={isScrolledToLeft}\n            isTableScrolledToRight={isScrolledToRight}\n            maxHeight={maxHeight}\n            onSort={onSort}\n          />\n          <TableBody\n            columns={columns}\n            rows={rows}\n            bodyCellVerticalPadding={bodyCellVerticalPadding}\n            isTableScrolledToLeft={isScrolledToLeft}\n            isTableScrolledToRight={isScrolledToRight}\n            isEmpty={isEmpty}\n            isLoading={isLoading}\n            loadingStateScreenReaderText={loadingStateScreenReaderText}\n            emptyTableContentHeight={emptyTableContentHeight}\n            footer={footer}\n            isFirstColumnSticky={isFirstColumnSticky}\n            isLastColumnSticky={isLastColumnSticky}\n            emptyCellContent={emptyCellContent}\n          >\n            {children}\n          </TableBody>\n        </StyledTable>\n      </TableContainer>\n      {footerElm}\n    </>\n  );\n}\n\nexport function DataTable({\n  caption,\n  columns,\n  rows = [],\n  footer,\n  currentlySortedByColumn,\n  isFirstColumnSticky = true,\n  isLastColumnSticky = false,\n  \"data-e2e-test-id\": dataE2eTestId,\n  isLoading = false,\n  loadingStateScreenReaderText = \"Loading\",\n  isEmpty = false,\n  children,\n  emptyTableContentHeight = \"15rem\",\n  layout = \"auto\",\n  width = \"100%\",\n  bodyCellVerticalPadding = \"m\",\n  emptyCellContent = \"--\",\n  maxHeight,\n  onSort,\n}: React.PropsWithChildren<DataTableProps>): React.ReactElement {\n  return (\n    <Container elevation={1}>\n      <BaseDataTable\n        caption={caption}\n        columns={columns}\n        rows={rows}\n        footer={footer}\n        currentlySortedByColumn={currentlySortedByColumn}\n        isFirstColumnSticky={isFirstColumnSticky}\n        isLastColumnSticky={isLastColumnSticky}\n        data-e2e-test-id={dataE2eTestId}\n        isLoading={isLoading}\n        loadingStateScreenReaderText={loadingStateScreenReaderText}\n        isEmpty={isEmpty}\n        emptyTableContentHeight={emptyTableContentHeight}\n        layout={layout}\n        width={width}\n        bodyCellVerticalPadding={bodyCellVerticalPadding}\n        emptyCellContent={emptyCellContent}\n        maxHeight={maxHeight}\n        onSort={onSort}\n      >\n        {children}\n      </BaseDataTable>\n    </Container>\n  );\n}\n"],"names":[],"mappings":"AAiIqB"} */");function BaseDataTable({caption,columns,rows=[],footer,currentlySortedByColumn,isFirstColumnSticky=!0,isLastColumnSticky=!1,"data-e2e-test-id":dataE2eTestId,isLoading=!1,loadingStateScreenReaderText="Loading",isEmpty=!1,children,emptyTableContentHeight="15rem",layout="auto",width="100%",bodyCellVerticalPadding="m",emptyCellContent="--",maxHeight,onSort}){let[isScrolledToRight,setIsScrolledToRight]=(0,_react.useState)(isLastColumnSticky),[isScrolledToLeft,setIsScrolledToLeft]=(0,_react.useState)(isFirstColumnSticky),tableRef=(0,_react.useRef)(null),containerRef=(0,_react.useRef)(null),handleScroll=(0,_react.useCallback)(evt=>{let elm=evt.target;setIsScrolledToLeft(0===elm.scrollLeft),setIsScrolledToRight(getTableScrolledToRight(elm))},[]);(0,_react.useEffect)(()=>{let resizeObserver;return"undefined"!=typeof ResizeObserver&&containerRef&&containerRef.current&&(resizeObserver=new ResizeObserver(entries=>{entries.forEach(()=>{setIsScrolledToLeft(0===containerRef.current.scrollLeft),setIsScrolledToRight(getTableScrolledToRight(containerRef.current))})})).observe(containerRef.current),()=>{resizeObserver&&resizeObserver.disconnect()}},[containerRef]);let footerElm=footer?_react.default.createElement(StyledFooter,null,footer):null;return _react.default.createElement(_react.default.Fragment,null,_react.default.createElement(TableContainer,{ref:containerRef,footer:footer,maxHeight:maxHeight,onScroll:handleScroll},_react.default.createElement(StyledTable,{"data-e2e-test-id":dataE2eTestId,"data-ds-id":"DataTable",ref:tableRef,layout:layout,tableWidth:width},_react.default.createElement(_ScreenReaderText.ScreenReaderText,{as:"caption"},caption),_react.default.createElement(_TableHeader.default,{columns:columns,isFirstColumnSticky:isFirstColumnSticky,isLastColumnSticky:isLastColumnSticky,currentlySortedByColumn:currentlySortedByColumn,isTableScrolledToLeft:isScrolledToLeft,isTableScrolledToRight:isScrolledToRight,maxHeight:maxHeight,onSort:onSort}),_react.default.createElement(_TableBody.default,{columns:columns,rows:rows,bodyCellVerticalPadding:bodyCellVerticalPadding,isTableScrolledToLeft:isScrolledToLeft,isTableScrolledToRight:isScrolledToRight,isEmpty:isEmpty,isLoading:isLoading,loadingStateScreenReaderText:loadingStateScreenReaderText,emptyTableContentHeight:emptyTableContentHeight,footer:footer,isFirstColumnSticky:isFirstColumnSticky,isLastColumnSticky:isLastColumnSticky,emptyCellContent:emptyCellContent},children))),footerElm)}function DataTable({caption,columns,rows=[],footer,currentlySortedByColumn,isFirstColumnSticky=!0,isLastColumnSticky=!1,"data-e2e-test-id":dataE2eTestId,isLoading=!1,loadingStateScreenReaderText="Loading",isEmpty=!1,children,emptyTableContentHeight="15rem",layout="auto",width="100%",bodyCellVerticalPadding="m",emptyCellContent="--",maxHeight,onSort}){return _react.default.createElement(_Container.Container,{elevation:1},_react.default.createElement(BaseDataTable,{caption:caption,columns:columns,rows:rows,footer:footer,currentlySortedByColumn:currentlySortedByColumn,isFirstColumnSticky:isFirstColumnSticky,isLastColumnSticky:isLastColumnSticky,"data-e2e-test-id":dataE2eTestId,isLoading:isLoading,loadingStateScreenReaderText:loadingStateScreenReaderText,isEmpty:isEmpty,emptyTableContentHeight:emptyTableContentHeight,layout:layout,width:width,bodyCellVerticalPadding:bodyCellVerticalPadding,emptyCellContent:emptyCellContent,maxHeight:maxHeight,onSort:onSort},children))}
|
|
@@ -1,9 +1,9 @@
|
|
|
1
1
|
import React from "react";
|
|
2
|
+
import type { TableCellProps } from "./TableCell";
|
|
2
3
|
import type { DataTableProps } from "./DataTable";
|
|
3
4
|
export type TableBodyProps = {
|
|
4
5
|
className?: string;
|
|
5
|
-
|
|
6
|
-
|
|
7
|
-
declare function TableBody({ className, columns, rows, bodyCellVerticalPadding, isTableScrolled, isLoading, loadingStateScreenReaderText, isEmpty, emptyTableContentHeight, footer, children, isFirstColumnSticky, emptyCellContent, }: React.PropsWithChildren<TableBodyProps>): React.ReactElement;
|
|
6
|
+
} & Pick<DataTableProps, "columns" | "rows" | "isLoading" | "loadingStateScreenReaderText" | "isEmpty" | "emptyTableContentHeight" | "bodyCellVerticalPadding" | "footer" | "isFirstColumnSticky" | "isLastColumnSticky" | "emptyCellContent"> & Pick<TableCellProps, "isTableScrolledToLeft" | "isTableScrolledToRight">;
|
|
7
|
+
declare function TableBody({ className, columns, rows, bodyCellVerticalPadding, isTableScrolledToLeft, isTableScrolledToRight, isLoading, loadingStateScreenReaderText, isEmpty, emptyTableContentHeight, footer, children, isFirstColumnSticky, isLastColumnSticky, emptyCellContent, }: React.PropsWithChildren<TableBodyProps>): React.ReactElement;
|
|
8
8
|
declare const _default: React.MemoExoticComponent<typeof TableBody>;
|
|
9
9
|
export default _default;
|
|
@@ -1 +1 @@
|
|
|
1
|
-
"use strict";Object.defineProperty(exports,"__esModule",{value:!0}),Object.defineProperty(exports,"default",{enumerable:!0,get:function(){return _default}});const _interop_require_default=require("@swc/helpers/_/_interop_require_default"),_react=_interop_require_default._(require("react")),_styled=_interop_require_default._(require("@emotion/styled")),_TableCell=_interop_require_default._(require("./TableCell")),_Text=require("../Typography/Text/Text"),_LoadingSpinner=require("../LoadingSpinner/LoadingSpinner"),_mediaQueries=require("../../shared/mediaQueries"),StyledTr=(0,_styled.default)("tr",{target:"e1av951m0",label:"StyledTr"})(({theme,footer})=>({"&:hover td":{backgroundColor:theme.values.color.background.secondary.default},...!footer&&{"&:last-of-type":{td:{borderBottom:"none"}}}}),"/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoic3JjL2NvbXBvbmVudHMvRGF0YVRhYmxlL1RhYmxlQm9keS50c3giLCJzb3VyY2VzIjpbInNyYy9jb21wb25lbnRzL0RhdGFUYWJsZS9UYWJsZUJvZHkudHN4Il0sInNvdXJjZXNDb250ZW50IjpbImltcG9ydCBSZWFjdCBmcm9tIFwicmVhY3RcIjtcbmltcG9ydCBzdHlsZWQgZnJvbSBcIkBlbW90aW9uL3N0eWxlZFwiO1xuaW1wb3J0IHR5cGUgeyBEYXRhVGFibGVDb2x1bW4gfSBmcm9tIFwiLi90eXBlc1wiO1xuaW1wb3J0IHR5cGUgeyBUYWJsZUNlbGxQcm9wcyB9IGZyb20gXCIuL1RhYmxlQ2VsbFwiO1xuaW1wb3J0IFRhYmxlQ2VsbCBmcm9tIFwiLi9UYWJsZUNlbGxcIjtcbmltcG9ydCB7IFRleHQgfSBmcm9tIFwiLi4vVHlwb2dyYXBoeS9UZXh0L1RleHRcIjtcbmltcG9ydCB0eXBlIHsgRGF0YVRhYmxlUHJvcHMgfSBmcm9tIFwiLi9EYXRhVGFibGVcIjtcbmltcG9ydCB7IExvYWRpbmdTcGlubmVyIH0gZnJvbSBcIi4uL0xvYWRpbmdTcGlubmVyL0xvYWRpbmdTcGlubmVyXCI7XG5pbXBvcnQgeyBtcSwgbXFWYWx1ZSB9IGZyb20gXCIuLi8uLi9zaGFyZWQvbWVkaWFRdWVyaWVzXCI7XG5cbmV4cG9ydCB0eXBlIFRhYmxlQm9keVByb3BzID0ge1xuICBjbGFzc05hbWU/OiBzdHJpbmc7XG4gIGlzVGFibGVTY3JvbGxlZDogYm9vbGVhbjtcbn0gJiBQaWNrPFxuICBEYXRhVGFibGVQcm9wcyxcbiAgfCBcImNvbHVtbnNcIlxuICB8IFwicm93c1wiXG4gIHwgXCJpc0xvYWRpbmdcIlxuICB8IFwibG9hZGluZ1N0YXRlU2NyZWVuUmVhZGVyVGV4dFwiXG4gIHwgXCJpc0VtcHR5XCJcbiAgfCBcImVtcHR5VGFibGVDb250ZW50SGVpZ2h0XCJcbiAgfCBcImJvZHlDZWxsVmVydGljYWxQYWRkaW5nXCJcbiAgfCBcImZvb3RlclwiXG4gIHwgXCJpc0ZpcnN0Q29sdW1uU3RpY2t5XCJcbiAgfCBcImVtcHR5Q2VsbENvbnRlbnRcIlxuPjtcblxudHlwZSBTdHlsZWRUclByb3BzID0gUGljazxUYWJsZUJvZHlQcm9wcywgXCJmb290ZXJcIj47XG5cbmNvbnN0IFN0eWxlZFRyID0gc3R5bGVkLnRyPFN0eWxlZFRyUHJvcHM+KCh7IHRoZW1lLCBmb290ZXIgfSkgPT4gKHtcbiAgXCImOmhvdmVyIHRkXCI6IHtcbiAgICBiYWNrZ3JvdW5kQ29sb3I6IHRoZW1lLnZhbHVlcy5jb2xvci5iYWNrZ3JvdW5kLnNlY29uZGFyeS5kZWZhdWx0LFxuICB9LFxuXG4gIC4uLighZm9vdGVyICYmIHtcbiAgICBcIiY6bGFzdC1vZi10eXBlXCI6IHtcbiAgICAgIHRkOiB7XG4gICAgICAgIGJvcmRlckJvdHRvbTogXCJub25lXCIsXG4gICAgICB9LFxuICAgIH0sXG4gIH0pLFxufSkpO1xuXG50eXBlIFN0eWxlZFRleHRQcm9wcyA9IHtcbiAgYWxpZ25Db2x1bW4/OiBEYXRhVGFibGVDb2x1bW5bXCJhbGlnblwiXTtcbn07XG5cbmNvbnN0IFN0eWxlZFRleHQgPSBzdHlsZWQoVGV4dCk8U3R5bGVkVGV4dFByb3BzPigoeyBhbGlnbkNvbHVtbiB9KSA9PiAoe1xuICAuLi5tcVZhbHVlKHtcbiAgICB0ZXh0QWxpZ246IGFsaWduQ29sdW1uLFxuICB9KSxcbn0pKTtcblxudHlwZSBTdHlsZWRUZFByb3BzID0gVGFibGVDZWxsUHJvcHMgJlxuICBQaWNrPFRhYmxlQm9keVByb3BzLCBcImlzRmlyc3RDb2x1bW5TdGlja3lcIiB8IFwiYm9keUNlbGxWZXJ0aWNhbFBhZGRpbmdcIj47XG5cbmNvbnN0IFN0eWxlZFRkID0gc3R5bGVkKFRhYmxlQ2VsbCk8U3R5bGVkVGRQcm9wcz4oXG4gICh7IHRoZW1lLCBib2R5Q2VsbFZlcnRpY2FsUGFkZGluZyB9KSA9PiAoe1xuICAgIC4uLm1xKHtcbiAgICAgIHBhZGRpbmc6IFtcbiAgICAgICAgYm9keUNlbGxWZXJ0aWNhbFBhZGRpbmcsXG4gICAgICAgIHtcbiAgICAgICAgICBzOiBgJHt0aGVtZS52YXJpYWJsZXMuc2l6ZS5zcGFjaW5nLnN9ICR7dGhlbWUudmFyaWFibGVzLnNpemUuc3BhY2luZy5tfWAsXG4gICAgICAgICAgbTogYCR7dGhlbWUudmFyaWFibGVzLnNpemUuc3BhY2luZy5tfSAke3RoZW1lLnZhcmlhYmxlcy5zaXplLnNwYWNpbmcubX1gLFxuICAgICAgICAgIGw6IGAke3RoZW1lLnZhcmlhYmxlcy5zaXplLnNwYWNpbmcubH0gJHt0aGVtZS52YXJpYWJsZXMuc2l6ZS5zcGFjaW5nLm19YCxcbiAgICAgICAgfSBhcyBhbnksXG4gICAgICBdLFxuICAgIH0pLFxuICB9KVxuKTtcblxudHlwZSBFbXB0eVRhYmxlQm9keVByb3BzID0gUGljazxcbiAgVGFibGVCb2R5UHJvcHMsXG4gIFwiY29sdW1uc1wiIHwgXCJlbXB0eVRhYmxlQ29udGVudEhlaWdodFwiXG4+ICYge1xuICBjaGlsZHJlbjogUmVhY3QuUmVhY3RFbGVtZW50O1xufTtcblxudHlwZSBTdHlsZWRFbXB0eVRkUHJvcHMgPSBQaWNrPEVtcHR5VGFibGVCb2R5UHJvcHMsIFwiZW1wdHlUYWJsZUNvbnRlbnRIZWlnaHRcIj47XG5cbmNvbnN0IFN0eWxlZEVtcHR5VGQgPSBzdHlsZWQudGQ8U3R5bGVkRW1wdHlUZFByb3BzPihcbiAgKHsgZW1wdHlUYWJsZUNvbnRlbnRIZWlnaHQgfSkgPT4gKHtcbiAgICB0ZXh0QWxpZ246IFwiY2VudGVyXCIsXG4gICAgLi4ubXFWYWx1ZSh7XG4gICAgICBoZWlnaHQ6IGVtcHR5VGFibGVDb250ZW50SGVpZ2h0LFxuICAgIH0pLFxuICB9KVxuKTtcblxuZnVuY3Rpb24gRW1wdHlUYWJsZUJvZHkoe1xuICBjaGlsZHJlbixcbiAgY29sdW1ucyxcbiAgZW1wdHlUYWJsZUNvbnRlbnRIZWlnaHQsXG59OiBFbXB0eVRhYmxlQm9keVByb3BzKTogUmVhY3QuUmVhY3RFbGVtZW50IHtcbiAgcmV0dXJuIChcbiAgICA8dGJvZHk+XG4gICAgICA8dHI+XG4gICAgICAgIDxTdHlsZWRFbXB0eVRkXG4gICAgICAgICAgY29sU3Bhbj17Y29sdW1ucy5sZW5ndGh9XG4gICAgICAgICAgZW1wdHlUYWJsZUNvbnRlbnRIZWlnaHQ9e2VtcHR5VGFibGVDb250ZW50SGVpZ2h0fVxuICAgICAgICA+XG4gICAgICAgICAge2NoaWxkcmVufVxuICAgICAgICA8L1N0eWxlZEVtcHR5VGQ+XG4gICAgICA8L3RyPlxuICAgIDwvdGJvZHk+XG4gICk7XG59XG5cbmZ1bmN0aW9uIFRhYmxlQm9keSh7XG4gIGNsYXNzTmFtZSxcbiAgY29sdW1ucyxcbiAgcm93cyA9IFtdLFxuICBib2R5Q2VsbFZlcnRpY2FsUGFkZGluZyxcbiAgaXNUYWJsZVNjcm9sbGVkLFxuICBpc0xvYWRpbmcsXG4gIGxvYWRpbmdTdGF0ZVNjcmVlblJlYWRlclRleHQgPSBcIkxvYWRpbmdcIixcbiAgaXNFbXB0eSxcbiAgZW1wdHlUYWJsZUNvbnRlbnRIZWlnaHQsXG4gIGZvb3RlcixcbiAgY2hpbGRyZW4sXG4gIGlzRmlyc3RDb2x1bW5TdGlja3ksXG4gIGVtcHR5Q2VsbENvbnRlbnQsXG59OiBSZWFjdC5Qcm9wc1dpdGhDaGlsZHJlbjxUYWJsZUJvZHlQcm9wcz4pOiBSZWFjdC5SZWFjdEVsZW1lbnQge1xuICBpZiAoaXNMb2FkaW5nKSB7XG4gICAgY29uc3QgY3VzdG9tTG9hZGluZ0NvbnRlbnQgPSBjaGlsZHJlbiAmJiA8PntjaGlsZHJlbn08Lz47XG4gICAgY29uc3QgYm9keUNvbnRlbnQgPSBjdXN0b21Mb2FkaW5nQ29udGVudCB8fCAoXG4gICAgICA8TG9hZGluZ1NwaW5uZXIgc2NyZWVuUmVhZGVyVGV4dD17bG9hZGluZ1N0YXRlU2NyZWVuUmVhZGVyVGV4dH0gLz5cbiAgICApO1xuXG4gICAgcmV0dXJuIChcbiAgICAgIDxFbXB0eVRhYmxlQm9keVxuICAgICAgICBjb2x1bW5zPXtjb2x1bW5zfVxuICAgICAgICBlbXB0eVRhYmxlQ29udGVudEhlaWdodD17ZW1wdHlUYWJsZUNvbnRlbnRIZWlnaHR9XG4gICAgICA+XG4gICAgICAgIHtib2R5Q29udGVudH1cbiAgICAgIDwvRW1wdHlUYWJsZUJvZHk+XG4gICAgKTtcbiAgfVxuXG4gIGlmIChpc0VtcHR5KSB7XG4gICAgcmV0dXJuIChcbiAgICAgIDxFbXB0eVRhYmxlQm9keVxuICAgICAgICBjb2x1bW5zPXtjb2x1bW5zfVxuICAgICAgICBlbXB0eVRhYmxlQ29udGVudEhlaWdodD17ZW1wdHlUYWJsZUNvbnRlbnRIZWlnaHR9XG4gICAgICA+XG4gICAgICAgIDw+e2NoaWxkcmVufTwvPlxuICAgICAgPC9FbXB0eVRhYmxlQm9keT5cbiAgICApO1xuICB9XG5cbiAgY29uc3Qgcm93RWxlbWVudHMgPSByb3dzLm1hcCgocm93KSA9PiAoXG4gICAgPFN0eWxlZFRyIGtleT17cm93LmlkfSBmb290ZXI9e2Zvb3Rlcn0+XG4gICAgICB7Y29sdW1ucy5tYXAoKHsgbmFtZSwgYWxpZ24gPSBcImxlZnRcIiwgcmVuZGVyQ2VsbCB9KSA9PiB7XG4gICAgICAgIGNvbnN0IGNvbnRlbnQgPSByZW5kZXJDZWxsID8gKFxuICAgICAgICAgIHJlbmRlckNlbGwocm93KVxuICAgICAgICApIDogKFxuICAgICAgICAgIDxTdHlsZWRUZXh0IHNpemU9XCJzXCIgYWxpZ25Db2x1bW49e2FsaWdufT5cbiAgICAgICAgICAgIHtyb3dbbmFtZV0gPyByb3dbbmFtZV0gOiBlbXB0eUNlbGxDb250ZW50fVxuICAgICAgICAgIDwvU3R5bGVkVGV4dD5cbiAgICAgICAgKTtcblxuICAgICAgICByZXR1cm4gKFxuICAgICAgICAgIDxTdHlsZWRUZFxuICAgICAgICAgICAga2V5PXtuYW1lfVxuICAgICAgICAgICAgYWxpZ25Db2x1bW49e2FsaWdufVxuICAgICAgICAgICAgaXNGaXJzdENvbHVtblN0aWNreT17aXNGaXJzdENvbHVtblN0aWNreX1cbiAgICAgICAgICAgIGJvZHlDZWxsVmVydGljYWxQYWRkaW5nPXtib2R5Q2VsbFZlcnRpY2FsUGFkZGluZ31cbiAgICAgICAgICAgIGlzVGFibGVTY3JvbGxlZD17aXNUYWJsZVNjcm9sbGVkfVxuICAgICAgICAgID5cbiAgICAgICAgICAgIHtjb250ZW50fVxuICAgICAgICAgIDwvU3R5bGVkVGQ+XG4gICAgICAgICk7XG4gICAgICB9KX1cbiAgICA8L1N0eWxlZFRyPlxuICApKTtcblxuICByZXR1cm4gPHRib2R5IGNsYXNzTmFtZT17Y2xhc3NOYW1lfT57cm93RWxlbWVudHN9PC90Ym9keT47XG59XG5cbmV4cG9ydCBkZWZhdWx0IFJlYWN0Lm1lbW8oVGFibGVCb2R5KTtcbiJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUE2QmlCIn0= */"),StyledText=(0,_styled.default)(_Text.Text,{target:"e1av951m1",label:"StyledText"})(({alignColumn})=>({...(0,_mediaQueries.mqValue)({textAlign:alignColumn})}),"/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoic3JjL2NvbXBvbmVudHMvRGF0YVRhYmxlL1RhYmxlQm9keS50c3giLCJzb3VyY2VzIjpbInNyYy9jb21wb25lbnRzL0RhdGFUYWJsZS9UYWJsZUJvZHkudHN4Il0sInNvdXJjZXNDb250ZW50IjpbImltcG9ydCBSZWFjdCBmcm9tIFwicmVhY3RcIjtcbmltcG9ydCBzdHlsZWQgZnJvbSBcIkBlbW90aW9uL3N0eWxlZFwiO1xuaW1wb3J0IHR5cGUgeyBEYXRhVGFibGVDb2x1bW4gfSBmcm9tIFwiLi90eXBlc1wiO1xuaW1wb3J0IHR5cGUgeyBUYWJsZUNlbGxQcm9wcyB9IGZyb20gXCIuL1RhYmxlQ2VsbFwiO1xuaW1wb3J0IFRhYmxlQ2VsbCBmcm9tIFwiLi9UYWJsZUNlbGxcIjtcbmltcG9ydCB7IFRleHQgfSBmcm9tIFwiLi4vVHlwb2dyYXBoeS9UZXh0L1RleHRcIjtcbmltcG9ydCB0eXBlIHsgRGF0YVRhYmxlUHJvcHMgfSBmcm9tIFwiLi9EYXRhVGFibGVcIjtcbmltcG9ydCB7IExvYWRpbmdTcGlubmVyIH0gZnJvbSBcIi4uL0xvYWRpbmdTcGlubmVyL0xvYWRpbmdTcGlubmVyXCI7XG5pbXBvcnQgeyBtcSwgbXFWYWx1ZSB9IGZyb20gXCIuLi8uLi9zaGFyZWQvbWVkaWFRdWVyaWVzXCI7XG5cbmV4cG9ydCB0eXBlIFRhYmxlQm9keVByb3BzID0ge1xuICBjbGFzc05hbWU/OiBzdHJpbmc7XG4gIGlzVGFibGVTY3JvbGxlZDogYm9vbGVhbjtcbn0gJiBQaWNrPFxuICBEYXRhVGFibGVQcm9wcyxcbiAgfCBcImNvbHVtbnNcIlxuICB8IFwicm93c1wiXG4gIHwgXCJpc0xvYWRpbmdcIlxuICB8IFwibG9hZGluZ1N0YXRlU2NyZWVuUmVhZGVyVGV4dFwiXG4gIHwgXCJpc0VtcHR5XCJcbiAgfCBcImVtcHR5VGFibGVDb250ZW50SGVpZ2h0XCJcbiAgfCBcImJvZHlDZWxsVmVydGljYWxQYWRkaW5nXCJcbiAgfCBcImZvb3RlclwiXG4gIHwgXCJpc0ZpcnN0Q29sdW1uU3RpY2t5XCJcbiAgfCBcImVtcHR5Q2VsbENvbnRlbnRcIlxuPjtcblxudHlwZSBTdHlsZWRUclByb3BzID0gUGljazxUYWJsZUJvZHlQcm9wcywgXCJmb290ZXJcIj47XG5cbmNvbnN0IFN0eWxlZFRyID0gc3R5bGVkLnRyPFN0eWxlZFRyUHJvcHM+KCh7IHRoZW1lLCBmb290ZXIgfSkgPT4gKHtcbiAgXCImOmhvdmVyIHRkXCI6IHtcbiAgICBiYWNrZ3JvdW5kQ29sb3I6IHRoZW1lLnZhbHVlcy5jb2xvci5iYWNrZ3JvdW5kLnNlY29uZGFyeS5kZWZhdWx0LFxuICB9LFxuXG4gIC4uLighZm9vdGVyICYmIHtcbiAgICBcIiY6bGFzdC1vZi10eXBlXCI6IHtcbiAgICAgIHRkOiB7XG4gICAgICAgIGJvcmRlckJvdHRvbTogXCJub25lXCIsXG4gICAgICB9LFxuICAgIH0sXG4gIH0pLFxufSkpO1xuXG50eXBlIFN0eWxlZFRleHRQcm9wcyA9IHtcbiAgYWxpZ25Db2x1bW4/OiBEYXRhVGFibGVDb2x1bW5bXCJhbGlnblwiXTtcbn07XG5cbmNvbnN0IFN0eWxlZFRleHQgPSBzdHlsZWQoVGV4dCk8U3R5bGVkVGV4dFByb3BzPigoeyBhbGlnbkNvbHVtbiB9KSA9PiAoe1xuICAuLi5tcVZhbHVlKHtcbiAgICB0ZXh0QWxpZ246IGFsaWduQ29sdW1uLFxuICB9KSxcbn0pKTtcblxudHlwZSBTdHlsZWRUZFByb3BzID0gVGFibGVDZWxsUHJvcHMgJlxuICBQaWNrPFRhYmxlQm9keVByb3BzLCBcImlzRmlyc3RDb2x1bW5TdGlja3lcIiB8IFwiYm9keUNlbGxWZXJ0aWNhbFBhZGRpbmdcIj47XG5cbmNvbnN0IFN0eWxlZFRkID0gc3R5bGVkKFRhYmxlQ2VsbCk8U3R5bGVkVGRQcm9wcz4oXG4gICh7IHRoZW1lLCBib2R5Q2VsbFZlcnRpY2FsUGFkZGluZyB9KSA9PiAoe1xuICAgIC4uLm1xKHtcbiAgICAgIHBhZGRpbmc6IFtcbiAgICAgICAgYm9keUNlbGxWZXJ0aWNhbFBhZGRpbmcsXG4gICAgICAgIHtcbiAgICAgICAgICBzOiBgJHt0aGVtZS52YXJpYWJsZXMuc2l6ZS5zcGFjaW5nLnN9ICR7dGhlbWUudmFyaWFibGVzLnNpemUuc3BhY2luZy5tfWAsXG4gICAgICAgICAgbTogYCR7dGhlbWUudmFyaWFibGVzLnNpemUuc3BhY2luZy5tfSAke3RoZW1lLnZhcmlhYmxlcy5zaXplLnNwYWNpbmcubX1gLFxuICAgICAgICAgIGw6IGAke3RoZW1lLnZhcmlhYmxlcy5zaXplLnNwYWNpbmcubH0gJHt0aGVtZS52YXJpYWJsZXMuc2l6ZS5zcGFjaW5nLm19YCxcbiAgICAgICAgfSBhcyBhbnksXG4gICAgICBdLFxuICAgIH0pLFxuICB9KVxuKTtcblxudHlwZSBFbXB0eVRhYmxlQm9keVByb3BzID0gUGljazxcbiAgVGFibGVCb2R5UHJvcHMsXG4gIFwiY29sdW1uc1wiIHwgXCJlbXB0eVRhYmxlQ29udGVudEhlaWdodFwiXG4+ICYge1xuICBjaGlsZHJlbjogUmVhY3QuUmVhY3RFbGVtZW50O1xufTtcblxudHlwZSBTdHlsZWRFbXB0eVRkUHJvcHMgPSBQaWNrPEVtcHR5VGFibGVCb2R5UHJvcHMsIFwiZW1wdHlUYWJsZUNvbnRlbnRIZWlnaHRcIj47XG5cbmNvbnN0IFN0eWxlZEVtcHR5VGQgPSBzdHlsZWQudGQ8U3R5bGVkRW1wdHlUZFByb3BzPihcbiAgKHsgZW1wdHlUYWJsZUNvbnRlbnRIZWlnaHQgfSkgPT4gKHtcbiAgICB0ZXh0QWxpZ246IFwiY2VudGVyXCIsXG4gICAgLi4ubXFWYWx1ZSh7XG4gICAgICBoZWlnaHQ6IGVtcHR5VGFibGVDb250ZW50SGVpZ2h0LFxuICAgIH0pLFxuICB9KVxuKTtcblxuZnVuY3Rpb24gRW1wdHlUYWJsZUJvZHkoe1xuICBjaGlsZHJlbixcbiAgY29sdW1ucyxcbiAgZW1wdHlUYWJsZUNvbnRlbnRIZWlnaHQsXG59OiBFbXB0eVRhYmxlQm9keVByb3BzKTogUmVhY3QuUmVhY3RFbGVtZW50IHtcbiAgcmV0dXJuIChcbiAgICA8dGJvZHk+XG4gICAgICA8dHI+XG4gICAgICAgIDxTdHlsZWRFbXB0eVRkXG4gICAgICAgICAgY29sU3Bhbj17Y29sdW1ucy5sZW5ndGh9XG4gICAgICAgICAgZW1wdHlUYWJsZUNvbnRlbnRIZWlnaHQ9e2VtcHR5VGFibGVDb250ZW50SGVpZ2h0fVxuICAgICAgICA+XG4gICAgICAgICAge2NoaWxkcmVufVxuICAgICAgICA8L1N0eWxlZEVtcHR5VGQ+XG4gICAgICA8L3RyPlxuICAgIDwvdGJvZHk+XG4gICk7XG59XG5cbmZ1bmN0aW9uIFRhYmxlQm9keSh7XG4gIGNsYXNzTmFtZSxcbiAgY29sdW1ucyxcbiAgcm93cyA9IFtdLFxuICBib2R5Q2VsbFZlcnRpY2FsUGFkZGluZyxcbiAgaXNUYWJsZVNjcm9sbGVkLFxuICBpc0xvYWRpbmcsXG4gIGxvYWRpbmdTdGF0ZVNjcmVlblJlYWRlclRleHQgPSBcIkxvYWRpbmdcIixcbiAgaXNFbXB0eSxcbiAgZW1wdHlUYWJsZUNvbnRlbnRIZWlnaHQsXG4gIGZvb3RlcixcbiAgY2hpbGRyZW4sXG4gIGlzRmlyc3RDb2x1bW5TdGlja3ksXG4gIGVtcHR5Q2VsbENvbnRlbnQsXG59OiBSZWFjdC5Qcm9wc1dpdGhDaGlsZHJlbjxUYWJsZUJvZHlQcm9wcz4pOiBSZWFjdC5SZWFjdEVsZW1lbnQge1xuICBpZiAoaXNMb2FkaW5nKSB7XG4gICAgY29uc3QgY3VzdG9tTG9hZGluZ0NvbnRlbnQgPSBjaGlsZHJlbiAmJiA8PntjaGlsZHJlbn08Lz47XG4gICAgY29uc3QgYm9keUNvbnRlbnQgPSBjdXN0b21Mb2FkaW5nQ29udGVudCB8fCAoXG4gICAgICA8TG9hZGluZ1NwaW5uZXIgc2NyZWVuUmVhZGVyVGV4dD17bG9hZGluZ1N0YXRlU2NyZWVuUmVhZGVyVGV4dH0gLz5cbiAgICApO1xuXG4gICAgcmV0dXJuIChcbiAgICAgIDxFbXB0eVRhYmxlQm9keVxuICAgICAgICBjb2x1bW5zPXtjb2x1bW5zfVxuICAgICAgICBlbXB0eVRhYmxlQ29udGVudEhlaWdodD17ZW1wdHlUYWJsZUNvbnRlbnRIZWlnaHR9XG4gICAgICA+XG4gICAgICAgIHtib2R5Q29udGVudH1cbiAgICAgIDwvRW1wdHlUYWJsZUJvZHk+XG4gICAgKTtcbiAgfVxuXG4gIGlmIChpc0VtcHR5KSB7XG4gICAgcmV0dXJuIChcbiAgICAgIDxFbXB0eVRhYmxlQm9keVxuICAgICAgICBjb2x1bW5zPXtjb2x1bW5zfVxuICAgICAgICBlbXB0eVRhYmxlQ29udGVudEhlaWdodD17ZW1wdHlUYWJsZUNvbnRlbnRIZWlnaHR9XG4gICAgICA+XG4gICAgICAgIDw+e2NoaWxkcmVufTwvPlxuICAgICAgPC9FbXB0eVRhYmxlQm9keT5cbiAgICApO1xuICB9XG5cbiAgY29uc3Qgcm93RWxlbWVudHMgPSByb3dzLm1hcCgocm93KSA9PiAoXG4gICAgPFN0eWxlZFRyIGtleT17cm93LmlkfSBmb290ZXI9e2Zvb3Rlcn0+XG4gICAgICB7Y29sdW1ucy5tYXAoKHsgbmFtZSwgYWxpZ24gPSBcImxlZnRcIiwgcmVuZGVyQ2VsbCB9KSA9PiB7XG4gICAgICAgIGNvbnN0IGNvbnRlbnQgPSByZW5kZXJDZWxsID8gKFxuICAgICAgICAgIHJlbmRlckNlbGwocm93KVxuICAgICAgICApIDogKFxuICAgICAgICAgIDxTdHlsZWRUZXh0IHNpemU9XCJzXCIgYWxpZ25Db2x1bW49e2FsaWdufT5cbiAgICAgICAgICAgIHtyb3dbbmFtZV0gPyByb3dbbmFtZV0gOiBlbXB0eUNlbGxDb250ZW50fVxuICAgICAgICAgIDwvU3R5bGVkVGV4dD5cbiAgICAgICAgKTtcblxuICAgICAgICByZXR1cm4gKFxuICAgICAgICAgIDxTdHlsZWRUZFxuICAgICAgICAgICAga2V5PXtuYW1lfVxuICAgICAgICAgICAgYWxpZ25Db2x1bW49e2FsaWdufVxuICAgICAgICAgICAgaXNGaXJzdENvbHVtblN0aWNreT17aXNGaXJzdENvbHVtblN0aWNreX1cbiAgICAgICAgICAgIGJvZHlDZWxsVmVydGljYWxQYWRkaW5nPXtib2R5Q2VsbFZlcnRpY2FsUGFkZGluZ31cbiAgICAgICAgICAgIGlzVGFibGVTY3JvbGxlZD17aXNUYWJsZVNjcm9sbGVkfVxuICAgICAgICAgID5cbiAgICAgICAgICAgIHtjb250ZW50fVxuICAgICAgICAgIDwvU3R5bGVkVGQ+XG4gICAgICAgICk7XG4gICAgICB9KX1cbiAgICA8L1N0eWxlZFRyPlxuICApKTtcblxuICByZXR1cm4gPHRib2R5IGNsYXNzTmFtZT17Y2xhc3NOYW1lfT57cm93RWxlbWVudHN9PC90Ym9keT47XG59XG5cbmV4cG9ydCBkZWZhdWx0IFJlYWN0Lm1lbW8oVGFibGVCb2R5KTtcbiJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUErQ21CIn0= */"),StyledTd=(0,_styled.default)(_TableCell.default,{target:"e1av951m2",label:"StyledTd"})(({theme,bodyCellVerticalPadding})=>({...(0,_mediaQueries.mq)({padding:[bodyCellVerticalPadding,{s:`${theme.variables.size.spacing.s} ${theme.variables.size.spacing.m}`,m:`${theme.variables.size.spacing.m} ${theme.variables.size.spacing.m}`,l:`${theme.variables.size.spacing.l} ${theme.variables.size.spacing.m}`}]})}),"/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoic3JjL2NvbXBvbmVudHMvRGF0YVRhYmxlL1RhYmxlQm9keS50c3giLCJzb3VyY2VzIjpbInNyYy9jb21wb25lbnRzL0RhdGFUYWJsZS9UYWJsZUJvZHkudHN4Il0sInNvdXJjZXNDb250ZW50IjpbImltcG9ydCBSZWFjdCBmcm9tIFwicmVhY3RcIjtcbmltcG9ydCBzdHlsZWQgZnJvbSBcIkBlbW90aW9uL3N0eWxlZFwiO1xuaW1wb3J0IHR5cGUgeyBEYXRhVGFibGVDb2x1bW4gfSBmcm9tIFwiLi90eXBlc1wiO1xuaW1wb3J0IHR5cGUgeyBUYWJsZUNlbGxQcm9wcyB9IGZyb20gXCIuL1RhYmxlQ2VsbFwiO1xuaW1wb3J0IFRhYmxlQ2VsbCBmcm9tIFwiLi9UYWJsZUNlbGxcIjtcbmltcG9ydCB7IFRleHQgfSBmcm9tIFwiLi4vVHlwb2dyYXBoeS9UZXh0L1RleHRcIjtcbmltcG9ydCB0eXBlIHsgRGF0YVRhYmxlUHJvcHMgfSBmcm9tIFwiLi9EYXRhVGFibGVcIjtcbmltcG9ydCB7IExvYWRpbmdTcGlubmVyIH0gZnJvbSBcIi4uL0xvYWRpbmdTcGlubmVyL0xvYWRpbmdTcGlubmVyXCI7XG5pbXBvcnQgeyBtcSwgbXFWYWx1ZSB9IGZyb20gXCIuLi8uLi9zaGFyZWQvbWVkaWFRdWVyaWVzXCI7XG5cbmV4cG9ydCB0eXBlIFRhYmxlQm9keVByb3BzID0ge1xuICBjbGFzc05hbWU/OiBzdHJpbmc7XG4gIGlzVGFibGVTY3JvbGxlZDogYm9vbGVhbjtcbn0gJiBQaWNrPFxuICBEYXRhVGFibGVQcm9wcyxcbiAgfCBcImNvbHVtbnNcIlxuICB8IFwicm93c1wiXG4gIHwgXCJpc0xvYWRpbmdcIlxuICB8IFwibG9hZGluZ1N0YXRlU2NyZWVuUmVhZGVyVGV4dFwiXG4gIHwgXCJpc0VtcHR5XCJcbiAgfCBcImVtcHR5VGFibGVDb250ZW50SGVpZ2h0XCJcbiAgfCBcImJvZHlDZWxsVmVydGljYWxQYWRkaW5nXCJcbiAgfCBcImZvb3RlclwiXG4gIHwgXCJpc0ZpcnN0Q29sdW1uU3RpY2t5XCJcbiAgfCBcImVtcHR5Q2VsbENvbnRlbnRcIlxuPjtcblxudHlwZSBTdHlsZWRUclByb3BzID0gUGljazxUYWJsZUJvZHlQcm9wcywgXCJmb290ZXJcIj47XG5cbmNvbnN0IFN0eWxlZFRyID0gc3R5bGVkLnRyPFN0eWxlZFRyUHJvcHM+KCh7IHRoZW1lLCBmb290ZXIgfSkgPT4gKHtcbiAgXCImOmhvdmVyIHRkXCI6IHtcbiAgICBiYWNrZ3JvdW5kQ29sb3I6IHRoZW1lLnZhbHVlcy5jb2xvci5iYWNrZ3JvdW5kLnNlY29uZGFyeS5kZWZhdWx0LFxuICB9LFxuXG4gIC4uLighZm9vdGVyICYmIHtcbiAgICBcIiY6bGFzdC1vZi10eXBlXCI6IHtcbiAgICAgIHRkOiB7XG4gICAgICAgIGJvcmRlckJvdHRvbTogXCJub25lXCIsXG4gICAgICB9LFxuICAgIH0sXG4gIH0pLFxufSkpO1xuXG50eXBlIFN0eWxlZFRleHRQcm9wcyA9IHtcbiAgYWxpZ25Db2x1bW4/OiBEYXRhVGFibGVDb2x1bW5bXCJhbGlnblwiXTtcbn07XG5cbmNvbnN0IFN0eWxlZFRleHQgPSBzdHlsZWQoVGV4dCk8U3R5bGVkVGV4dFByb3BzPigoeyBhbGlnbkNvbHVtbiB9KSA9PiAoe1xuICAuLi5tcVZhbHVlKHtcbiAgICB0ZXh0QWxpZ246IGFsaWduQ29sdW1uLFxuICB9KSxcbn0pKTtcblxudHlwZSBTdHlsZWRUZFByb3BzID0gVGFibGVDZWxsUHJvcHMgJlxuICBQaWNrPFRhYmxlQm9keVByb3BzLCBcImlzRmlyc3RDb2x1bW5TdGlja3lcIiB8IFwiYm9keUNlbGxWZXJ0aWNhbFBhZGRpbmdcIj47XG5cbmNvbnN0IFN0eWxlZFRkID0gc3R5bGVkKFRhYmxlQ2VsbCk8U3R5bGVkVGRQcm9wcz4oXG4gICh7IHRoZW1lLCBib2R5Q2VsbFZlcnRpY2FsUGFkZGluZyB9KSA9PiAoe1xuICAgIC4uLm1xKHtcbiAgICAgIHBhZGRpbmc6IFtcbiAgICAgICAgYm9keUNlbGxWZXJ0aWNhbFBhZGRpbmcsXG4gICAgICAgIHtcbiAgICAgICAgICBzOiBgJHt0aGVtZS52YXJpYWJsZXMuc2l6ZS5zcGFjaW5nLnN9ICR7dGhlbWUudmFyaWFibGVzLnNpemUuc3BhY2luZy5tfWAsXG4gICAgICAgICAgbTogYCR7dGhlbWUudmFyaWFibGVzLnNpemUuc3BhY2luZy5tfSAke3RoZW1lLnZhcmlhYmxlcy5zaXplLnNwYWNpbmcubX1gLFxuICAgICAgICAgIGw6IGAke3RoZW1lLnZhcmlhYmxlcy5zaXplLnNwYWNpbmcubH0gJHt0aGVtZS52YXJpYWJsZXMuc2l6ZS5zcGFjaW5nLm19YCxcbiAgICAgICAgfSBhcyBhbnksXG4gICAgICBdLFxuICAgIH0pLFxuICB9KVxuKTtcblxudHlwZSBFbXB0eVRhYmxlQm9keVByb3BzID0gUGljazxcbiAgVGFibGVCb2R5UHJvcHMsXG4gIFwiY29sdW1uc1wiIHwgXCJlbXB0eVRhYmxlQ29udGVudEhlaWdodFwiXG4+ICYge1xuICBjaGlsZHJlbjogUmVhY3QuUmVhY3RFbGVtZW50O1xufTtcblxudHlwZSBTdHlsZWRFbXB0eVRkUHJvcHMgPSBQaWNrPEVtcHR5VGFibGVCb2R5UHJvcHMsIFwiZW1wdHlUYWJsZUNvbnRlbnRIZWlnaHRcIj47XG5cbmNvbnN0IFN0eWxlZEVtcHR5VGQgPSBzdHlsZWQudGQ8U3R5bGVkRW1wdHlUZFByb3BzPihcbiAgKHsgZW1wdHlUYWJsZUNvbnRlbnRIZWlnaHQgfSkgPT4gKHtcbiAgICB0ZXh0QWxpZ246IFwiY2VudGVyXCIsXG4gICAgLi4ubXFWYWx1ZSh7XG4gICAgICBoZWlnaHQ6IGVtcHR5VGFibGVDb250ZW50SGVpZ2h0LFxuICAgIH0pLFxuICB9KVxuKTtcblxuZnVuY3Rpb24gRW1wdHlUYWJsZUJvZHkoe1xuICBjaGlsZHJlbixcbiAgY29sdW1ucyxcbiAgZW1wdHlUYWJsZUNvbnRlbnRIZWlnaHQsXG59OiBFbXB0eVRhYmxlQm9keVByb3BzKTogUmVhY3QuUmVhY3RFbGVtZW50IHtcbiAgcmV0dXJuIChcbiAgICA8dGJvZHk+XG4gICAgICA8dHI+XG4gICAgICAgIDxTdHlsZWRFbXB0eVRkXG4gICAgICAgICAgY29sU3Bhbj17Y29sdW1ucy5sZW5ndGh9XG4gICAgICAgICAgZW1wdHlUYWJsZUNvbnRlbnRIZWlnaHQ9e2VtcHR5VGFibGVDb250ZW50SGVpZ2h0fVxuICAgICAgICA+XG4gICAgICAgICAge2NoaWxkcmVufVxuICAgICAgICA8L1N0eWxlZEVtcHR5VGQ+XG4gICAgICA8L3RyPlxuICAgIDwvdGJvZHk+XG4gICk7XG59XG5cbmZ1bmN0aW9uIFRhYmxlQm9keSh7XG4gIGNsYXNzTmFtZSxcbiAgY29sdW1ucyxcbiAgcm93cyA9IFtdLFxuICBib2R5Q2VsbFZlcnRpY2FsUGFkZGluZyxcbiAgaXNUYWJsZVNjcm9sbGVkLFxuICBpc0xvYWRpbmcsXG4gIGxvYWRpbmdTdGF0ZVNjcmVlblJlYWRlclRleHQgPSBcIkxvYWRpbmdcIixcbiAgaXNFbXB0eSxcbiAgZW1wdHlUYWJsZUNvbnRlbnRIZWlnaHQsXG4gIGZvb3RlcixcbiAgY2hpbGRyZW4sXG4gIGlzRmlyc3RDb2x1bW5TdGlja3ksXG4gIGVtcHR5Q2VsbENvbnRlbnQsXG59OiBSZWFjdC5Qcm9wc1dpdGhDaGlsZHJlbjxUYWJsZUJvZHlQcm9wcz4pOiBSZWFjdC5SZWFjdEVsZW1lbnQge1xuICBpZiAoaXNMb2FkaW5nKSB7XG4gICAgY29uc3QgY3VzdG9tTG9hZGluZ0NvbnRlbnQgPSBjaGlsZHJlbiAmJiA8PntjaGlsZHJlbn08Lz47XG4gICAgY29uc3QgYm9keUNvbnRlbnQgPSBjdXN0b21Mb2FkaW5nQ29udGVudCB8fCAoXG4gICAgICA8TG9hZGluZ1NwaW5uZXIgc2NyZWVuUmVhZGVyVGV4dD17bG9hZGluZ1N0YXRlU2NyZWVuUmVhZGVyVGV4dH0gLz5cbiAgICApO1xuXG4gICAgcmV0dXJuIChcbiAgICAgIDxFbXB0eVRhYmxlQm9keVxuICAgICAgICBjb2x1bW5zPXtjb2x1bW5zfVxuICAgICAgICBlbXB0eVRhYmxlQ29udGVudEhlaWdodD17ZW1wdHlUYWJsZUNvbnRlbnRIZWlnaHR9XG4gICAgICA+XG4gICAgICAgIHtib2R5Q29udGVudH1cbiAgICAgIDwvRW1wdHlUYWJsZUJvZHk+XG4gICAgKTtcbiAgfVxuXG4gIGlmIChpc0VtcHR5KSB7XG4gICAgcmV0dXJuIChcbiAgICAgIDxFbXB0eVRhYmxlQm9keVxuICAgICAgICBjb2x1bW5zPXtjb2x1bW5zfVxuICAgICAgICBlbXB0eVRhYmxlQ29udGVudEhlaWdodD17ZW1wdHlUYWJsZUNvbnRlbnRIZWlnaHR9XG4gICAgICA+XG4gICAgICAgIDw+e2NoaWxkcmVufTwvPlxuICAgICAgPC9FbXB0eVRhYmxlQm9keT5cbiAgICApO1xuICB9XG5cbiAgY29uc3Qgcm93RWxlbWVudHMgPSByb3dzLm1hcCgocm93KSA9PiAoXG4gICAgPFN0eWxlZFRyIGtleT17cm93LmlkfSBmb290ZXI9e2Zvb3Rlcn0+XG4gICAgICB7Y29sdW1ucy5tYXAoKHsgbmFtZSwgYWxpZ24gPSBcImxlZnRcIiwgcmVuZGVyQ2VsbCB9KSA9PiB7XG4gICAgICAgIGNvbnN0IGNvbnRlbnQgPSByZW5kZXJDZWxsID8gKFxuICAgICAgICAgIHJlbmRlckNlbGwocm93KVxuICAgICAgICApIDogKFxuICAgICAgICAgIDxTdHlsZWRUZXh0IHNpemU9XCJzXCIgYWxpZ25Db2x1bW49e2FsaWdufT5cbiAgICAgICAgICAgIHtyb3dbbmFtZV0gPyByb3dbbmFtZV0gOiBlbXB0eUNlbGxDb250ZW50fVxuICAgICAgICAgIDwvU3R5bGVkVGV4dD5cbiAgICAgICAgKTtcblxuICAgICAgICByZXR1cm4gKFxuICAgICAgICAgIDxTdHlsZWRUZFxuICAgICAgICAgICAga2V5PXtuYW1lfVxuICAgICAgICAgICAgYWxpZ25Db2x1bW49e2FsaWdufVxuICAgICAgICAgICAgaXNGaXJzdENvbHVtblN0aWNreT17aXNGaXJzdENvbHVtblN0aWNreX1cbiAgICAgICAgICAgIGJvZHlDZWxsVmVydGljYWxQYWRkaW5nPXtib2R5Q2VsbFZlcnRpY2FsUGFkZGluZ31cbiAgICAgICAgICAgIGlzVGFibGVTY3JvbGxlZD17aXNUYWJsZVNjcm9sbGVkfVxuICAgICAgICAgID5cbiAgICAgICAgICAgIHtjb250ZW50fVxuICAgICAgICAgIDwvU3R5bGVkVGQ+XG4gICAgICAgICk7XG4gICAgICB9KX1cbiAgICA8L1N0eWxlZFRyPlxuICApKTtcblxuICByZXR1cm4gPHRib2R5IGNsYXNzTmFtZT17Y2xhc3NOYW1lfT57cm93RWxlbWVudHN9PC90Ym9keT47XG59XG5cbmV4cG9ydCBkZWZhdWx0IFJlYWN0Lm1lbW8oVGFibGVCb2R5KTtcbiJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUF3RGlCIn0= */"),StyledEmptyTd=(0,_styled.default)("td",{target:"e1av951m3",label:"StyledEmptyTd"})(({emptyTableContentHeight})=>({textAlign:"center",...(0,_mediaQueries.mqValue)({height:emptyTableContentHeight})}),"/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoic3JjL2NvbXBvbmVudHMvRGF0YVRhYmxlL1RhYmxlQm9keS50c3giLCJzb3VyY2VzIjpbInNyYy9jb21wb25lbnRzL0RhdGFUYWJsZS9UYWJsZUJvZHkudHN4Il0sInNvdXJjZXNDb250ZW50IjpbImltcG9ydCBSZWFjdCBmcm9tIFwicmVhY3RcIjtcbmltcG9ydCBzdHlsZWQgZnJvbSBcIkBlbW90aW9uL3N0eWxlZFwiO1xuaW1wb3J0IHR5cGUgeyBEYXRhVGFibGVDb2x1bW4gfSBmcm9tIFwiLi90eXBlc1wiO1xuaW1wb3J0IHR5cGUgeyBUYWJsZUNlbGxQcm9wcyB9IGZyb20gXCIuL1RhYmxlQ2VsbFwiO1xuaW1wb3J0IFRhYmxlQ2VsbCBmcm9tIFwiLi9UYWJsZUNlbGxcIjtcbmltcG9ydCB7IFRleHQgfSBmcm9tIFwiLi4vVHlwb2dyYXBoeS9UZXh0L1RleHRcIjtcbmltcG9ydCB0eXBlIHsgRGF0YVRhYmxlUHJvcHMgfSBmcm9tIFwiLi9EYXRhVGFibGVcIjtcbmltcG9ydCB7IExvYWRpbmdTcGlubmVyIH0gZnJvbSBcIi4uL0xvYWRpbmdTcGlubmVyL0xvYWRpbmdTcGlubmVyXCI7XG5pbXBvcnQgeyBtcSwgbXFWYWx1ZSB9IGZyb20gXCIuLi8uLi9zaGFyZWQvbWVkaWFRdWVyaWVzXCI7XG5cbmV4cG9ydCB0eXBlIFRhYmxlQm9keVByb3BzID0ge1xuICBjbGFzc05hbWU/OiBzdHJpbmc7XG4gIGlzVGFibGVTY3JvbGxlZDogYm9vbGVhbjtcbn0gJiBQaWNrPFxuICBEYXRhVGFibGVQcm9wcyxcbiAgfCBcImNvbHVtbnNcIlxuICB8IFwicm93c1wiXG4gIHwgXCJpc0xvYWRpbmdcIlxuICB8IFwibG9hZGluZ1N0YXRlU2NyZWVuUmVhZGVyVGV4dFwiXG4gIHwgXCJpc0VtcHR5XCJcbiAgfCBcImVtcHR5VGFibGVDb250ZW50SGVpZ2h0XCJcbiAgfCBcImJvZHlDZWxsVmVydGljYWxQYWRkaW5nXCJcbiAgfCBcImZvb3RlclwiXG4gIHwgXCJpc0ZpcnN0Q29sdW1uU3RpY2t5XCJcbiAgfCBcImVtcHR5Q2VsbENvbnRlbnRcIlxuPjtcblxudHlwZSBTdHlsZWRUclByb3BzID0gUGljazxUYWJsZUJvZHlQcm9wcywgXCJmb290ZXJcIj47XG5cbmNvbnN0IFN0eWxlZFRyID0gc3R5bGVkLnRyPFN0eWxlZFRyUHJvcHM+KCh7IHRoZW1lLCBmb290ZXIgfSkgPT4gKHtcbiAgXCImOmhvdmVyIHRkXCI6IHtcbiAgICBiYWNrZ3JvdW5kQ29sb3I6IHRoZW1lLnZhbHVlcy5jb2xvci5iYWNrZ3JvdW5kLnNlY29uZGFyeS5kZWZhdWx0LFxuICB9LFxuXG4gIC4uLighZm9vdGVyICYmIHtcbiAgICBcIiY6bGFzdC1vZi10eXBlXCI6IHtcbiAgICAgIHRkOiB7XG4gICAgICAgIGJvcmRlckJvdHRvbTogXCJub25lXCIsXG4gICAgICB9LFxuICAgIH0sXG4gIH0pLFxufSkpO1xuXG50eXBlIFN0eWxlZFRleHRQcm9wcyA9IHtcbiAgYWxpZ25Db2x1bW4/OiBEYXRhVGFibGVDb2x1bW5bXCJhbGlnblwiXTtcbn07XG5cbmNvbnN0IFN0eWxlZFRleHQgPSBzdHlsZWQoVGV4dCk8U3R5bGVkVGV4dFByb3BzPigoeyBhbGlnbkNvbHVtbiB9KSA9PiAoe1xuICAuLi5tcVZhbHVlKHtcbiAgICB0ZXh0QWxpZ246IGFsaWduQ29sdW1uLFxuICB9KSxcbn0pKTtcblxudHlwZSBTdHlsZWRUZFByb3BzID0gVGFibGVDZWxsUHJvcHMgJlxuICBQaWNrPFRhYmxlQm9keVByb3BzLCBcImlzRmlyc3RDb2x1bW5TdGlja3lcIiB8IFwiYm9keUNlbGxWZXJ0aWNhbFBhZGRpbmdcIj47XG5cbmNvbnN0IFN0eWxlZFRkID0gc3R5bGVkKFRhYmxlQ2VsbCk8U3R5bGVkVGRQcm9wcz4oXG4gICh7IHRoZW1lLCBib2R5Q2VsbFZlcnRpY2FsUGFkZGluZyB9KSA9PiAoe1xuICAgIC4uLm1xKHtcbiAgICAgIHBhZGRpbmc6IFtcbiAgICAgICAgYm9keUNlbGxWZXJ0aWNhbFBhZGRpbmcsXG4gICAgICAgIHtcbiAgICAgICAgICBzOiBgJHt0aGVtZS52YXJpYWJsZXMuc2l6ZS5zcGFjaW5nLnN9ICR7dGhlbWUudmFyaWFibGVzLnNpemUuc3BhY2luZy5tfWAsXG4gICAgICAgICAgbTogYCR7dGhlbWUudmFyaWFibGVzLnNpemUuc3BhY2luZy5tfSAke3RoZW1lLnZhcmlhYmxlcy5zaXplLnNwYWNpbmcubX1gLFxuICAgICAgICAgIGw6IGAke3RoZW1lLnZhcmlhYmxlcy5zaXplLnNwYWNpbmcubH0gJHt0aGVtZS52YXJpYWJsZXMuc2l6ZS5zcGFjaW5nLm19YCxcbiAgICAgICAgfSBhcyBhbnksXG4gICAgICBdLFxuICAgIH0pLFxuICB9KVxuKTtcblxudHlwZSBFbXB0eVRhYmxlQm9keVByb3BzID0gUGljazxcbiAgVGFibGVCb2R5UHJvcHMsXG4gIFwiY29sdW1uc1wiIHwgXCJlbXB0eVRhYmxlQ29udGVudEhlaWdodFwiXG4+ICYge1xuICBjaGlsZHJlbjogUmVhY3QuUmVhY3RFbGVtZW50O1xufTtcblxudHlwZSBTdHlsZWRFbXB0eVRkUHJvcHMgPSBQaWNrPEVtcHR5VGFibGVCb2R5UHJvcHMsIFwiZW1wdHlUYWJsZUNvbnRlbnRIZWlnaHRcIj47XG5cbmNvbnN0IFN0eWxlZEVtcHR5VGQgPSBzdHlsZWQudGQ8U3R5bGVkRW1wdHlUZFByb3BzPihcbiAgKHsgZW1wdHlUYWJsZUNvbnRlbnRIZWlnaHQgfSkgPT4gKHtcbiAgICB0ZXh0QWxpZ246IFwiY2VudGVyXCIsXG4gICAgLi4ubXFWYWx1ZSh7XG4gICAgICBoZWlnaHQ6IGVtcHR5VGFibGVDb250ZW50SGVpZ2h0LFxuICAgIH0pLFxuICB9KVxuKTtcblxuZnVuY3Rpb24gRW1wdHlUYWJsZUJvZHkoe1xuICBjaGlsZHJlbixcbiAgY29sdW1ucyxcbiAgZW1wdHlUYWJsZUNvbnRlbnRIZWlnaHQsXG59OiBFbXB0eVRhYmxlQm9keVByb3BzKTogUmVhY3QuUmVhY3RFbGVtZW50IHtcbiAgcmV0dXJuIChcbiAgICA8dGJvZHk+XG4gICAgICA8dHI+XG4gICAgICAgIDxTdHlsZWRFbXB0eVRkXG4gICAgICAgICAgY29sU3Bhbj17Y29sdW1ucy5sZW5ndGh9XG4gICAgICAgICAgZW1wdHlUYWJsZUNvbnRlbnRIZWlnaHQ9e2VtcHR5VGFibGVDb250ZW50SGVpZ2h0fVxuICAgICAgICA+XG4gICAgICAgICAge2NoaWxkcmVufVxuICAgICAgICA8L1N0eWxlZEVtcHR5VGQ+XG4gICAgICA8L3RyPlxuICAgIDwvdGJvZHk+XG4gICk7XG59XG5cbmZ1bmN0aW9uIFRhYmxlQm9keSh7XG4gIGNsYXNzTmFtZSxcbiAgY29sdW1ucyxcbiAgcm93cyA9IFtdLFxuICBib2R5Q2VsbFZlcnRpY2FsUGFkZGluZyxcbiAgaXNUYWJsZVNjcm9sbGVkLFxuICBpc0xvYWRpbmcsXG4gIGxvYWRpbmdTdGF0ZVNjcmVlblJlYWRlclRleHQgPSBcIkxvYWRpbmdcIixcbiAgaXNFbXB0eSxcbiAgZW1wdHlUYWJsZUNvbnRlbnRIZWlnaHQsXG4gIGZvb3RlcixcbiAgY2hpbGRyZW4sXG4gIGlzRmlyc3RDb2x1bW5TdGlja3ksXG4gIGVtcHR5Q2VsbENvbnRlbnQsXG59OiBSZWFjdC5Qcm9wc1dpdGhDaGlsZHJlbjxUYWJsZUJvZHlQcm9wcz4pOiBSZWFjdC5SZWFjdEVsZW1lbnQge1xuICBpZiAoaXNMb2FkaW5nKSB7XG4gICAgY29uc3QgY3VzdG9tTG9hZGluZ0NvbnRlbnQgPSBjaGlsZHJlbiAmJiA8PntjaGlsZHJlbn08Lz47XG4gICAgY29uc3QgYm9keUNvbnRlbnQgPSBjdXN0b21Mb2FkaW5nQ29udGVudCB8fCAoXG4gICAgICA8TG9hZGluZ1NwaW5uZXIgc2NyZWVuUmVhZGVyVGV4dD17bG9hZGluZ1N0YXRlU2NyZWVuUmVhZGVyVGV4dH0gLz5cbiAgICApO1xuXG4gICAgcmV0dXJuIChcbiAgICAgIDxFbXB0eVRhYmxlQm9keVxuICAgICAgICBjb2x1bW5zPXtjb2x1bW5zfVxuICAgICAgICBlbXB0eVRhYmxlQ29udGVudEhlaWdodD17ZW1wdHlUYWJsZUNvbnRlbnRIZWlnaHR9XG4gICAgICA+XG4gICAgICAgIHtib2R5Q29udGVudH1cbiAgICAgIDwvRW1wdHlUYWJsZUJvZHk+XG4gICAgKTtcbiAgfVxuXG4gIGlmIChpc0VtcHR5KSB7XG4gICAgcmV0dXJuIChcbiAgICAgIDxFbXB0eVRhYmxlQm9keVxuICAgICAgICBjb2x1bW5zPXtjb2x1bW5zfVxuICAgICAgICBlbXB0eVRhYmxlQ29udGVudEhlaWdodD17ZW1wdHlUYWJsZUNvbnRlbnRIZWlnaHR9XG4gICAgICA+XG4gICAgICAgIDw+e2NoaWxkcmVufTwvPlxuICAgICAgPC9FbXB0eVRhYmxlQm9keT5cbiAgICApO1xuICB9XG5cbiAgY29uc3Qgcm93RWxlbWVudHMgPSByb3dzLm1hcCgocm93KSA9PiAoXG4gICAgPFN0eWxlZFRyIGtleT17cm93LmlkfSBmb290ZXI9e2Zvb3Rlcn0+XG4gICAgICB7Y29sdW1ucy5tYXAoKHsgbmFtZSwgYWxpZ24gPSBcImxlZnRcIiwgcmVuZGVyQ2VsbCB9KSA9PiB7XG4gICAgICAgIGNvbnN0IGNvbnRlbnQgPSByZW5kZXJDZWxsID8gKFxuICAgICAgICAgIHJlbmRlckNlbGwocm93KVxuICAgICAgICApIDogKFxuICAgICAgICAgIDxTdHlsZWRUZXh0IHNpemU9XCJzXCIgYWxpZ25Db2x1bW49e2FsaWdufT5cbiAgICAgICAgICAgIHtyb3dbbmFtZV0gPyByb3dbbmFtZV0gOiBlbXB0eUNlbGxDb250ZW50fVxuICAgICAgICAgIDwvU3R5bGVkVGV4dD5cbiAgICAgICAgKTtcblxuICAgICAgICByZXR1cm4gKFxuICAgICAgICAgIDxTdHlsZWRUZFxuICAgICAgICAgICAga2V5PXtuYW1lfVxuICAgICAgICAgICAgYWxpZ25Db2x1bW49e2FsaWdufVxuICAgICAgICAgICAgaXNGaXJzdENvbHVtblN0aWNreT17aXNGaXJzdENvbHVtblN0aWNreX1cbiAgICAgICAgICAgIGJvZHlDZWxsVmVydGljYWxQYWRkaW5nPXtib2R5Q2VsbFZlcnRpY2FsUGFkZGluZ31cbiAgICAgICAgICAgIGlzVGFibGVTY3JvbGxlZD17aXNUYWJsZVNjcm9sbGVkfVxuICAgICAgICAgID5cbiAgICAgICAgICAgIHtjb250ZW50fVxuICAgICAgICAgIDwvU3R5bGVkVGQ+XG4gICAgICAgICk7XG4gICAgICB9KX1cbiAgICA8L1N0eWxlZFRyPlxuICApKTtcblxuICByZXR1cm4gPHRib2R5IGNsYXNzTmFtZT17Y2xhc3NOYW1lfT57cm93RWxlbWVudHN9PC90Ym9keT47XG59XG5cbmV4cG9ydCBkZWZhdWx0IFJlYWN0Lm1lbW8oVGFibGVCb2R5KTtcbiJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFnRnNCIn0= */");function EmptyTableBody({children,columns,emptyTableContentHeight}){return _react.default.createElement("tbody",null,_react.default.createElement("tr",null,_react.default.createElement(StyledEmptyTd,{colSpan:columns.length,emptyTableContentHeight:emptyTableContentHeight},children)))}const _default=_react.default.memo(function({className,columns,rows=[],bodyCellVerticalPadding,isTableScrolled,isLoading,loadingStateScreenReaderText="Loading",isEmpty,emptyTableContentHeight,footer,children,isFirstColumnSticky,emptyCellContent}){if(isLoading){let bodyContent=children&&_react.default.createElement(_react.default.Fragment,null,children)||_react.default.createElement(_LoadingSpinner.LoadingSpinner,{screenReaderText:loadingStateScreenReaderText});return _react.default.createElement(EmptyTableBody,{columns:columns,emptyTableContentHeight:emptyTableContentHeight},bodyContent)}if(isEmpty)return _react.default.createElement(EmptyTableBody,{columns:columns,emptyTableContentHeight:emptyTableContentHeight},_react.default.createElement(_react.default.Fragment,null,children));let rowElements=rows.map(row=>_react.default.createElement(StyledTr,{key:row.id,footer:footer},columns.map(({name,align="left",renderCell})=>{let content=renderCell?renderCell(row):_react.default.createElement(StyledText,{size:"s",alignColumn:align},row[name]?row[name]:emptyCellContent);return _react.default.createElement(StyledTd,{key:name,alignColumn:align,isFirstColumnSticky:isFirstColumnSticky,bodyCellVerticalPadding:bodyCellVerticalPadding,isTableScrolled:isTableScrolled},content)})));return _react.default.createElement("tbody",{className:className},rowElements)});
|
|
1
|
+
"use strict";Object.defineProperty(exports,"__esModule",{value:!0}),Object.defineProperty(exports,"default",{enumerable:!0,get:function(){return _default}});const _interop_require_default=require("@swc/helpers/_/_interop_require_default"),_react=_interop_require_default._(require("react")),_styled=_interop_require_default._(require("@emotion/styled")),_TableCell=_interop_require_default._(require("./TableCell")),_Text=require("../Typography/Text/Text"),_LoadingSpinner=require("../LoadingSpinner/LoadingSpinner"),_mediaQueries=require("../../shared/mediaQueries"),StyledTr=(0,_styled.default)("tr",{target:"e13t89ug0",label:"StyledTr"})(({theme,footer})=>({"&:hover td":{backgroundColor:theme.values.color.background.secondary.default},...!footer&&{"&:last-of-type":{td:{borderBottom:"none"}}}}),"/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoic3JjL2NvbXBvbmVudHMvRGF0YVRhYmxlL1RhYmxlQm9keS50c3giLCJzb3VyY2VzIjpbInNyYy9jb21wb25lbnRzL0RhdGFUYWJsZS9UYWJsZUJvZHkudHN4Il0sInNvdXJjZXNDb250ZW50IjpbImltcG9ydCBSZWFjdCBmcm9tIFwicmVhY3RcIjtcbmltcG9ydCBzdHlsZWQgZnJvbSBcIkBlbW90aW9uL3N0eWxlZFwiO1xuaW1wb3J0IHR5cGUgeyBEYXRhVGFibGVDb2x1bW4gfSBmcm9tIFwiLi90eXBlc1wiO1xuaW1wb3J0IHR5cGUgeyBUYWJsZUNlbGxQcm9wcyB9IGZyb20gXCIuL1RhYmxlQ2VsbFwiO1xuaW1wb3J0IFRhYmxlQ2VsbCBmcm9tIFwiLi9UYWJsZUNlbGxcIjtcbmltcG9ydCB7IFRleHQgfSBmcm9tIFwiLi4vVHlwb2dyYXBoeS9UZXh0L1RleHRcIjtcbmltcG9ydCB0eXBlIHsgRGF0YVRhYmxlUHJvcHMgfSBmcm9tIFwiLi9EYXRhVGFibGVcIjtcbmltcG9ydCB7IExvYWRpbmdTcGlubmVyIH0gZnJvbSBcIi4uL0xvYWRpbmdTcGlubmVyL0xvYWRpbmdTcGlubmVyXCI7XG5pbXBvcnQgeyBtcSwgbXFWYWx1ZSB9IGZyb20gXCIuLi8uLi9zaGFyZWQvbWVkaWFRdWVyaWVzXCI7XG5cbmV4cG9ydCB0eXBlIFRhYmxlQm9keVByb3BzID0ge1xuICBjbGFzc05hbWU/OiBzdHJpbmc7XG59ICYgUGljazxcbiAgRGF0YVRhYmxlUHJvcHMsXG4gIHwgXCJjb2x1bW5zXCJcbiAgfCBcInJvd3NcIlxuICB8IFwiaXNMb2FkaW5nXCJcbiAgfCBcImxvYWRpbmdTdGF0ZVNjcmVlblJlYWRlclRleHRcIlxuICB8IFwiaXNFbXB0eVwiXG4gIHwgXCJlbXB0eVRhYmxlQ29udGVudEhlaWdodFwiXG4gIHwgXCJib2R5Q2VsbFZlcnRpY2FsUGFkZGluZ1wiXG4gIHwgXCJmb290ZXJcIlxuICB8IFwiaXNGaXJzdENvbHVtblN0aWNreVwiXG4gIHwgXCJpc0xhc3RDb2x1bW5TdGlja3lcIlxuICB8IFwiZW1wdHlDZWxsQ29udGVudFwiXG4+ICZcbiAgUGljazxUYWJsZUNlbGxQcm9wcywgXCJpc1RhYmxlU2Nyb2xsZWRUb0xlZnRcIiB8IFwiaXNUYWJsZVNjcm9sbGVkVG9SaWdodFwiPjtcblxudHlwZSBTdHlsZWRUclByb3BzID0gUGljazxUYWJsZUJvZHlQcm9wcywgXCJmb290ZXJcIj47XG5cbmNvbnN0IFN0eWxlZFRyID0gc3R5bGVkLnRyPFN0eWxlZFRyUHJvcHM+KCh7IHRoZW1lLCBmb290ZXIgfSkgPT4gKHtcbiAgXCImOmhvdmVyIHRkXCI6IHtcbiAgICBiYWNrZ3JvdW5kQ29sb3I6IHRoZW1lLnZhbHVlcy5jb2xvci5iYWNrZ3JvdW5kLnNlY29uZGFyeS5kZWZhdWx0LFxuICB9LFxuXG4gIC4uLighZm9vdGVyICYmIHtcbiAgICBcIiY6bGFzdC1vZi10eXBlXCI6IHtcbiAgICAgIHRkOiB7XG4gICAgICAgIGJvcmRlckJvdHRvbTogXCJub25lXCIsXG4gICAgICB9LFxuICAgIH0sXG4gIH0pLFxufSkpO1xuXG50eXBlIFN0eWxlZFRleHRQcm9wcyA9IHtcbiAgYWxpZ25Db2x1bW4/OiBEYXRhVGFibGVDb2x1bW5bXCJhbGlnblwiXTtcbn07XG5cbmNvbnN0IFN0eWxlZFRleHQgPSBzdHlsZWQoVGV4dCk8U3R5bGVkVGV4dFByb3BzPigoeyBhbGlnbkNvbHVtbiB9KSA9PiAoe1xuICAuLi5tcVZhbHVlKHtcbiAgICB0ZXh0QWxpZ246IGFsaWduQ29sdW1uLFxuICB9KSxcbn0pKTtcblxudHlwZSBTdHlsZWRUZFByb3BzID0gVGFibGVDZWxsUHJvcHMgJlxuICBQaWNrPFxuICAgIFRhYmxlQm9keVByb3BzLFxuICAgIFwiaXNGaXJzdENvbHVtblN0aWNreVwiIHwgXCJpc0xhc3RDb2x1bW5TdGlja3lcIiB8IFwiYm9keUNlbGxWZXJ0aWNhbFBhZGRpbmdcIlxuICA+O1xuXG5jb25zdCBTdHlsZWRUZCA9IHN0eWxlZChUYWJsZUNlbGwpPFN0eWxlZFRkUHJvcHM+KFxuICAoeyB0aGVtZSwgYm9keUNlbGxWZXJ0aWNhbFBhZGRpbmcgfSkgPT4gKHtcbiAgICAuLi5tcSh7XG4gICAgICBwYWRkaW5nOiBbXG4gICAgICAgIGJvZHlDZWxsVmVydGljYWxQYWRkaW5nLFxuICAgICAgICB7XG4gICAgICAgICAgczogYCR7dGhlbWUudmFyaWFibGVzLnNpemUuc3BhY2luZy5zfSAke3RoZW1lLnZhcmlhYmxlcy5zaXplLnNwYWNpbmcubX1gLFxuICAgICAgICAgIG06IGAke3RoZW1lLnZhcmlhYmxlcy5zaXplLnNwYWNpbmcubX0gJHt0aGVtZS52YXJpYWJsZXMuc2l6ZS5zcGFjaW5nLm19YCxcbiAgICAgICAgICBsOiBgJHt0aGVtZS52YXJpYWJsZXMuc2l6ZS5zcGFjaW5nLmx9ICR7dGhlbWUudmFyaWFibGVzLnNpemUuc3BhY2luZy5tfWAsXG4gICAgICAgIH0gYXMgYW55LFxuICAgICAgXSxcbiAgICB9KSxcbiAgfSlcbik7XG5cbnR5cGUgRW1wdHlUYWJsZUJvZHlQcm9wcyA9IFBpY2s8XG4gIFRhYmxlQm9keVByb3BzLFxuICBcImNvbHVtbnNcIiB8IFwiZW1wdHlUYWJsZUNvbnRlbnRIZWlnaHRcIlxuPiAmIHtcbiAgY2hpbGRyZW46IFJlYWN0LlJlYWN0RWxlbWVudDtcbn07XG5cbnR5cGUgU3R5bGVkRW1wdHlUZFByb3BzID0gUGljazxFbXB0eVRhYmxlQm9keVByb3BzLCBcImVtcHR5VGFibGVDb250ZW50SGVpZ2h0XCI+O1xuXG5jb25zdCBTdHlsZWRFbXB0eVRkID0gc3R5bGVkLnRkPFN0eWxlZEVtcHR5VGRQcm9wcz4oXG4gICh7IGVtcHR5VGFibGVDb250ZW50SGVpZ2h0IH0pID0+ICh7XG4gICAgdGV4dEFsaWduOiBcImNlbnRlclwiLFxuICAgIC4uLm1xVmFsdWUoe1xuICAgICAgaGVpZ2h0OiBlbXB0eVRhYmxlQ29udGVudEhlaWdodCxcbiAgICB9KSxcbiAgfSlcbik7XG5cbmZ1bmN0aW9uIEVtcHR5VGFibGVCb2R5KHtcbiAgY2hpbGRyZW4sXG4gIGNvbHVtbnMsXG4gIGVtcHR5VGFibGVDb250ZW50SGVpZ2h0LFxufTogRW1wdHlUYWJsZUJvZHlQcm9wcyk6IFJlYWN0LlJlYWN0RWxlbWVudCB7XG4gIHJldHVybiAoXG4gICAgPHRib2R5PlxuICAgICAgPHRyPlxuICAgICAgICA8U3R5bGVkRW1wdHlUZFxuICAgICAgICAgIGNvbFNwYW49e2NvbHVtbnMubGVuZ3RofVxuICAgICAgICAgIGVtcHR5VGFibGVDb250ZW50SGVpZ2h0PXtlbXB0eVRhYmxlQ29udGVudEhlaWdodH1cbiAgICAgICAgPlxuICAgICAgICAgIHtjaGlsZHJlbn1cbiAgICAgICAgPC9TdHlsZWRFbXB0eVRkPlxuICAgICAgPC90cj5cbiAgICA8L3Rib2R5PlxuICApO1xufVxuXG5mdW5jdGlvbiBUYWJsZUJvZHkoe1xuICBjbGFzc05hbWUsXG4gIGNvbHVtbnMsXG4gIHJvd3MgPSBbXSxcbiAgYm9keUNlbGxWZXJ0aWNhbFBhZGRpbmcsXG4gIGlzVGFibGVTY3JvbGxlZFRvTGVmdCxcbiAgaXNUYWJsZVNjcm9sbGVkVG9SaWdodCxcbiAgaXNMb2FkaW5nLFxuICBsb2FkaW5nU3RhdGVTY3JlZW5SZWFkZXJUZXh0ID0gXCJMb2FkaW5nXCIsXG4gIGlzRW1wdHksXG4gIGVtcHR5VGFibGVDb250ZW50SGVpZ2h0LFxuICBmb290ZXIsXG4gIGNoaWxkcmVuLFxuICBpc0ZpcnN0Q29sdW1uU3RpY2t5LFxuICBpc0xhc3RDb2x1bW5TdGlja3ksXG4gIGVtcHR5Q2VsbENvbnRlbnQsXG59OiBSZWFjdC5Qcm9wc1dpdGhDaGlsZHJlbjxUYWJsZUJvZHlQcm9wcz4pOiBSZWFjdC5SZWFjdEVsZW1lbnQge1xuICBpZiAoaXNMb2FkaW5nKSB7XG4gICAgY29uc3QgY3VzdG9tTG9hZGluZ0NvbnRlbnQgPSBjaGlsZHJlbiAmJiA8PntjaGlsZHJlbn08Lz47XG4gICAgY29uc3QgYm9keUNvbnRlbnQgPSBjdXN0b21Mb2FkaW5nQ29udGVudCB8fCAoXG4gICAgICA8TG9hZGluZ1NwaW5uZXIgc2NyZWVuUmVhZGVyVGV4dD17bG9hZGluZ1N0YXRlU2NyZWVuUmVhZGVyVGV4dH0gLz5cbiAgICApO1xuXG4gICAgcmV0dXJuIChcbiAgICAgIDxFbXB0eVRhYmxlQm9keVxuICAgICAgICBjb2x1bW5zPXtjb2x1bW5zfVxuICAgICAgICBlbXB0eVRhYmxlQ29udGVudEhlaWdodD17ZW1wdHlUYWJsZUNvbnRlbnRIZWlnaHR9XG4gICAgICA+XG4gICAgICAgIHtib2R5Q29udGVudH1cbiAgICAgIDwvRW1wdHlUYWJsZUJvZHk+XG4gICAgKTtcbiAgfVxuXG4gIGlmIChpc0VtcHR5KSB7XG4gICAgcmV0dXJuIChcbiAgICAgIDxFbXB0eVRhYmxlQm9keVxuICAgICAgICBjb2x1bW5zPXtjb2x1bW5zfVxuICAgICAgICBlbXB0eVRhYmxlQ29udGVudEhlaWdodD17ZW1wdHlUYWJsZUNvbnRlbnRIZWlnaHR9XG4gICAgICA+XG4gICAgICAgIDw+e2NoaWxkcmVufTwvPlxuICAgICAgPC9FbXB0eVRhYmxlQm9keT5cbiAgICApO1xuICB9XG5cbiAgY29uc3Qgcm93RWxlbWVudHMgPSByb3dzLm1hcCgocm93KSA9PiAoXG4gICAgPFN0eWxlZFRyIGtleT17cm93LmlkfSBmb290ZXI9e2Zvb3Rlcn0+XG4gICAgICB7Y29sdW1ucy5tYXAoKHsgbmFtZSwgYWxpZ24gPSBcImxlZnRcIiwgcmVuZGVyQ2VsbCB9KSA9PiB7XG4gICAgICAgIGNvbnN0IGNvbnRlbnQgPSByZW5kZXJDZWxsID8gKFxuICAgICAgICAgIHJlbmRlckNlbGwocm93KVxuICAgICAgICApIDogKFxuICAgICAgICAgIDxTdHlsZWRUZXh0IHNpemU9XCJzXCIgYWxpZ25Db2x1bW49e2FsaWdufT5cbiAgICAgICAgICAgIHtyb3dbbmFtZV0gPyByb3dbbmFtZV0gOiBlbXB0eUNlbGxDb250ZW50fVxuICAgICAgICAgIDwvU3R5bGVkVGV4dD5cbiAgICAgICAgKTtcblxuICAgICAgICByZXR1cm4gKFxuICAgICAgICAgIDxTdHlsZWRUZFxuICAgICAgICAgICAga2V5PXtuYW1lfVxuICAgICAgICAgICAgYWxpZ25Db2x1bW49e2FsaWdufVxuICAgICAgICAgICAgaXNGaXJzdENvbHVtblN0aWNreT17aXNGaXJzdENvbHVtblN0aWNreX1cbiAgICAgICAgICAgIGlzTGFzdENvbHVtblN0aWNreT17aXNMYXN0Q29sdW1uU3RpY2t5fVxuICAgICAgICAgICAgYm9keUNlbGxWZXJ0aWNhbFBhZGRpbmc9e2JvZHlDZWxsVmVydGljYWxQYWRkaW5nfVxuICAgICAgICAgICAgaXNUYWJsZVNjcm9sbGVkVG9MZWZ0PXtpc1RhYmxlU2Nyb2xsZWRUb0xlZnR9XG4gICAgICAgICAgICBpc1RhYmxlU2Nyb2xsZWRUb1JpZ2h0PXtpc1RhYmxlU2Nyb2xsZWRUb1JpZ2h0fVxuICAgICAgICAgID5cbiAgICAgICAgICAgIHtjb250ZW50fVxuICAgICAgICAgIDwvU3R5bGVkVGQ+XG4gICAgICAgICk7XG4gICAgICB9KX1cbiAgICA8L1N0eWxlZFRyPlxuICApKTtcblxuICByZXR1cm4gPHRib2R5IGNsYXNzTmFtZT17Y2xhc3NOYW1lfT57cm93RWxlbWVudHN9PC90Ym9keT47XG59XG5cbmV4cG9ydCBkZWZhdWx0IFJlYWN0Lm1lbW8oVGFibGVCb2R5KTtcbiJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUE4QmlCIn0= */"),StyledText=(0,_styled.default)(_Text.Text,{target:"e13t89ug1",label:"StyledText"})(({alignColumn})=>({...(0,_mediaQueries.mqValue)({textAlign:alignColumn})}),"/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoic3JjL2NvbXBvbmVudHMvRGF0YVRhYmxlL1RhYmxlQm9keS50c3giLCJzb3VyY2VzIjpbInNyYy9jb21wb25lbnRzL0RhdGFUYWJsZS9UYWJsZUJvZHkudHN4Il0sInNvdXJjZXNDb250ZW50IjpbImltcG9ydCBSZWFjdCBmcm9tIFwicmVhY3RcIjtcbmltcG9ydCBzdHlsZWQgZnJvbSBcIkBlbW90aW9uL3N0eWxlZFwiO1xuaW1wb3J0IHR5cGUgeyBEYXRhVGFibGVDb2x1bW4gfSBmcm9tIFwiLi90eXBlc1wiO1xuaW1wb3J0IHR5cGUgeyBUYWJsZUNlbGxQcm9wcyB9IGZyb20gXCIuL1RhYmxlQ2VsbFwiO1xuaW1wb3J0IFRhYmxlQ2VsbCBmcm9tIFwiLi9UYWJsZUNlbGxcIjtcbmltcG9ydCB7IFRleHQgfSBmcm9tIFwiLi4vVHlwb2dyYXBoeS9UZXh0L1RleHRcIjtcbmltcG9ydCB0eXBlIHsgRGF0YVRhYmxlUHJvcHMgfSBmcm9tIFwiLi9EYXRhVGFibGVcIjtcbmltcG9ydCB7IExvYWRpbmdTcGlubmVyIH0gZnJvbSBcIi4uL0xvYWRpbmdTcGlubmVyL0xvYWRpbmdTcGlubmVyXCI7XG5pbXBvcnQgeyBtcSwgbXFWYWx1ZSB9IGZyb20gXCIuLi8uLi9zaGFyZWQvbWVkaWFRdWVyaWVzXCI7XG5cbmV4cG9ydCB0eXBlIFRhYmxlQm9keVByb3BzID0ge1xuICBjbGFzc05hbWU/OiBzdHJpbmc7XG59ICYgUGljazxcbiAgRGF0YVRhYmxlUHJvcHMsXG4gIHwgXCJjb2x1bW5zXCJcbiAgfCBcInJvd3NcIlxuICB8IFwiaXNMb2FkaW5nXCJcbiAgfCBcImxvYWRpbmdTdGF0ZVNjcmVlblJlYWRlclRleHRcIlxuICB8IFwiaXNFbXB0eVwiXG4gIHwgXCJlbXB0eVRhYmxlQ29udGVudEhlaWdodFwiXG4gIHwgXCJib2R5Q2VsbFZlcnRpY2FsUGFkZGluZ1wiXG4gIHwgXCJmb290ZXJcIlxuICB8IFwiaXNGaXJzdENvbHVtblN0aWNreVwiXG4gIHwgXCJpc0xhc3RDb2x1bW5TdGlja3lcIlxuICB8IFwiZW1wdHlDZWxsQ29udGVudFwiXG4+ICZcbiAgUGljazxUYWJsZUNlbGxQcm9wcywgXCJpc1RhYmxlU2Nyb2xsZWRUb0xlZnRcIiB8IFwiaXNUYWJsZVNjcm9sbGVkVG9SaWdodFwiPjtcblxudHlwZSBTdHlsZWRUclByb3BzID0gUGljazxUYWJsZUJvZHlQcm9wcywgXCJmb290ZXJcIj47XG5cbmNvbnN0IFN0eWxlZFRyID0gc3R5bGVkLnRyPFN0eWxlZFRyUHJvcHM+KCh7IHRoZW1lLCBmb290ZXIgfSkgPT4gKHtcbiAgXCImOmhvdmVyIHRkXCI6IHtcbiAgICBiYWNrZ3JvdW5kQ29sb3I6IHRoZW1lLnZhbHVlcy5jb2xvci5iYWNrZ3JvdW5kLnNlY29uZGFyeS5kZWZhdWx0LFxuICB9LFxuXG4gIC4uLighZm9vdGVyICYmIHtcbiAgICBcIiY6bGFzdC1vZi10eXBlXCI6IHtcbiAgICAgIHRkOiB7XG4gICAgICAgIGJvcmRlckJvdHRvbTogXCJub25lXCIsXG4gICAgICB9LFxuICAgIH0sXG4gIH0pLFxufSkpO1xuXG50eXBlIFN0eWxlZFRleHRQcm9wcyA9IHtcbiAgYWxpZ25Db2x1bW4/OiBEYXRhVGFibGVDb2x1bW5bXCJhbGlnblwiXTtcbn07XG5cbmNvbnN0IFN0eWxlZFRleHQgPSBzdHlsZWQoVGV4dCk8U3R5bGVkVGV4dFByb3BzPigoeyBhbGlnbkNvbHVtbiB9KSA9PiAoe1xuICAuLi5tcVZhbHVlKHtcbiAgICB0ZXh0QWxpZ246IGFsaWduQ29sdW1uLFxuICB9KSxcbn0pKTtcblxudHlwZSBTdHlsZWRUZFByb3BzID0gVGFibGVDZWxsUHJvcHMgJlxuICBQaWNrPFxuICAgIFRhYmxlQm9keVByb3BzLFxuICAgIFwiaXNGaXJzdENvbHVtblN0aWNreVwiIHwgXCJpc0xhc3RDb2x1bW5TdGlja3lcIiB8IFwiYm9keUNlbGxWZXJ0aWNhbFBhZGRpbmdcIlxuICA+O1xuXG5jb25zdCBTdHlsZWRUZCA9IHN0eWxlZChUYWJsZUNlbGwpPFN0eWxlZFRkUHJvcHM+KFxuICAoeyB0aGVtZSwgYm9keUNlbGxWZXJ0aWNhbFBhZGRpbmcgfSkgPT4gKHtcbiAgICAuLi5tcSh7XG4gICAgICBwYWRkaW5nOiBbXG4gICAgICAgIGJvZHlDZWxsVmVydGljYWxQYWRkaW5nLFxuICAgICAgICB7XG4gICAgICAgICAgczogYCR7dGhlbWUudmFyaWFibGVzLnNpemUuc3BhY2luZy5zfSAke3RoZW1lLnZhcmlhYmxlcy5zaXplLnNwYWNpbmcubX1gLFxuICAgICAgICAgIG06IGAke3RoZW1lLnZhcmlhYmxlcy5zaXplLnNwYWNpbmcubX0gJHt0aGVtZS52YXJpYWJsZXMuc2l6ZS5zcGFjaW5nLm19YCxcbiAgICAgICAgICBsOiBgJHt0aGVtZS52YXJpYWJsZXMuc2l6ZS5zcGFjaW5nLmx9ICR7dGhlbWUudmFyaWFibGVzLnNpemUuc3BhY2luZy5tfWAsXG4gICAgICAgIH0gYXMgYW55LFxuICAgICAgXSxcbiAgICB9KSxcbiAgfSlcbik7XG5cbnR5cGUgRW1wdHlUYWJsZUJvZHlQcm9wcyA9IFBpY2s8XG4gIFRhYmxlQm9keVByb3BzLFxuICBcImNvbHVtbnNcIiB8IFwiZW1wdHlUYWJsZUNvbnRlbnRIZWlnaHRcIlxuPiAmIHtcbiAgY2hpbGRyZW46IFJlYWN0LlJlYWN0RWxlbWVudDtcbn07XG5cbnR5cGUgU3R5bGVkRW1wdHlUZFByb3BzID0gUGljazxFbXB0eVRhYmxlQm9keVByb3BzLCBcImVtcHR5VGFibGVDb250ZW50SGVpZ2h0XCI+O1xuXG5jb25zdCBTdHlsZWRFbXB0eVRkID0gc3R5bGVkLnRkPFN0eWxlZEVtcHR5VGRQcm9wcz4oXG4gICh7IGVtcHR5VGFibGVDb250ZW50SGVpZ2h0IH0pID0+ICh7XG4gICAgdGV4dEFsaWduOiBcImNlbnRlclwiLFxuICAgIC4uLm1xVmFsdWUoe1xuICAgICAgaGVpZ2h0OiBlbXB0eVRhYmxlQ29udGVudEhlaWdodCxcbiAgICB9KSxcbiAgfSlcbik7XG5cbmZ1bmN0aW9uIEVtcHR5VGFibGVCb2R5KHtcbiAgY2hpbGRyZW4sXG4gIGNvbHVtbnMsXG4gIGVtcHR5VGFibGVDb250ZW50SGVpZ2h0LFxufTogRW1wdHlUYWJsZUJvZHlQcm9wcyk6IFJlYWN0LlJlYWN0RWxlbWVudCB7XG4gIHJldHVybiAoXG4gICAgPHRib2R5PlxuICAgICAgPHRyPlxuICAgICAgICA8U3R5bGVkRW1wdHlUZFxuICAgICAgICAgIGNvbFNwYW49e2NvbHVtbnMubGVuZ3RofVxuICAgICAgICAgIGVtcHR5VGFibGVDb250ZW50SGVpZ2h0PXtlbXB0eVRhYmxlQ29udGVudEhlaWdodH1cbiAgICAgICAgPlxuICAgICAgICAgIHtjaGlsZHJlbn1cbiAgICAgICAgPC9TdHlsZWRFbXB0eVRkPlxuICAgICAgPC90cj5cbiAgICA8L3Rib2R5PlxuICApO1xufVxuXG5mdW5jdGlvbiBUYWJsZUJvZHkoe1xuICBjbGFzc05hbWUsXG4gIGNvbHVtbnMsXG4gIHJvd3MgPSBbXSxcbiAgYm9keUNlbGxWZXJ0aWNhbFBhZGRpbmcsXG4gIGlzVGFibGVTY3JvbGxlZFRvTGVmdCxcbiAgaXNUYWJsZVNjcm9sbGVkVG9SaWdodCxcbiAgaXNMb2FkaW5nLFxuICBsb2FkaW5nU3RhdGVTY3JlZW5SZWFkZXJUZXh0ID0gXCJMb2FkaW5nXCIsXG4gIGlzRW1wdHksXG4gIGVtcHR5VGFibGVDb250ZW50SGVpZ2h0LFxuICBmb290ZXIsXG4gIGNoaWxkcmVuLFxuICBpc0ZpcnN0Q29sdW1uU3RpY2t5LFxuICBpc0xhc3RDb2x1bW5TdGlja3ksXG4gIGVtcHR5Q2VsbENvbnRlbnQsXG59OiBSZWFjdC5Qcm9wc1dpdGhDaGlsZHJlbjxUYWJsZUJvZHlQcm9wcz4pOiBSZWFjdC5SZWFjdEVsZW1lbnQge1xuICBpZiAoaXNMb2FkaW5nKSB7XG4gICAgY29uc3QgY3VzdG9tTG9hZGluZ0NvbnRlbnQgPSBjaGlsZHJlbiAmJiA8PntjaGlsZHJlbn08Lz47XG4gICAgY29uc3QgYm9keUNvbnRlbnQgPSBjdXN0b21Mb2FkaW5nQ29udGVudCB8fCAoXG4gICAgICA8TG9hZGluZ1NwaW5uZXIgc2NyZWVuUmVhZGVyVGV4dD17bG9hZGluZ1N0YXRlU2NyZWVuUmVhZGVyVGV4dH0gLz5cbiAgICApO1xuXG4gICAgcmV0dXJuIChcbiAgICAgIDxFbXB0eVRhYmxlQm9keVxuICAgICAgICBjb2x1bW5zPXtjb2x1bW5zfVxuICAgICAgICBlbXB0eVRhYmxlQ29udGVudEhlaWdodD17ZW1wdHlUYWJsZUNvbnRlbnRIZWlnaHR9XG4gICAgICA+XG4gICAgICAgIHtib2R5Q29udGVudH1cbiAgICAgIDwvRW1wdHlUYWJsZUJvZHk+XG4gICAgKTtcbiAgfVxuXG4gIGlmIChpc0VtcHR5KSB7XG4gICAgcmV0dXJuIChcbiAgICAgIDxFbXB0eVRhYmxlQm9keVxuICAgICAgICBjb2x1bW5zPXtjb2x1bW5zfVxuICAgICAgICBlbXB0eVRhYmxlQ29udGVudEhlaWdodD17ZW1wdHlUYWJsZUNvbnRlbnRIZWlnaHR9XG4gICAgICA+XG4gICAgICAgIDw+e2NoaWxkcmVufTwvPlxuICAgICAgPC9FbXB0eVRhYmxlQm9keT5cbiAgICApO1xuICB9XG5cbiAgY29uc3Qgcm93RWxlbWVudHMgPSByb3dzLm1hcCgocm93KSA9PiAoXG4gICAgPFN0eWxlZFRyIGtleT17cm93LmlkfSBmb290ZXI9e2Zvb3Rlcn0+XG4gICAgICB7Y29sdW1ucy5tYXAoKHsgbmFtZSwgYWxpZ24gPSBcImxlZnRcIiwgcmVuZGVyQ2VsbCB9KSA9PiB7XG4gICAgICAgIGNvbnN0IGNvbnRlbnQgPSByZW5kZXJDZWxsID8gKFxuICAgICAgICAgIHJlbmRlckNlbGwocm93KVxuICAgICAgICApIDogKFxuICAgICAgICAgIDxTdHlsZWRUZXh0IHNpemU9XCJzXCIgYWxpZ25Db2x1bW49e2FsaWdufT5cbiAgICAgICAgICAgIHtyb3dbbmFtZV0gPyByb3dbbmFtZV0gOiBlbXB0eUNlbGxDb250ZW50fVxuICAgICAgICAgIDwvU3R5bGVkVGV4dD5cbiAgICAgICAgKTtcblxuICAgICAgICByZXR1cm4gKFxuICAgICAgICAgIDxTdHlsZWRUZFxuICAgICAgICAgICAga2V5PXtuYW1lfVxuICAgICAgICAgICAgYWxpZ25Db2x1bW49e2FsaWdufVxuICAgICAgICAgICAgaXNGaXJzdENvbHVtblN0aWNreT17aXNGaXJzdENvbHVtblN0aWNreX1cbiAgICAgICAgICAgIGlzTGFzdENvbHVtblN0aWNreT17aXNMYXN0Q29sdW1uU3RpY2t5fVxuICAgICAgICAgICAgYm9keUNlbGxWZXJ0aWNhbFBhZGRpbmc9e2JvZHlDZWxsVmVydGljYWxQYWRkaW5nfVxuICAgICAgICAgICAgaXNUYWJsZVNjcm9sbGVkVG9MZWZ0PXtpc1RhYmxlU2Nyb2xsZWRUb0xlZnR9XG4gICAgICAgICAgICBpc1RhYmxlU2Nyb2xsZWRUb1JpZ2h0PXtpc1RhYmxlU2Nyb2xsZWRUb1JpZ2h0fVxuICAgICAgICAgID5cbiAgICAgICAgICAgIHtjb250ZW50fVxuICAgICAgICAgIDwvU3R5bGVkVGQ+XG4gICAgICAgICk7XG4gICAgICB9KX1cbiAgICA8L1N0eWxlZFRyPlxuICApKTtcblxuICByZXR1cm4gPHRib2R5IGNsYXNzTmFtZT17Y2xhc3NOYW1lfT57cm93RWxlbWVudHN9PC90Ym9keT47XG59XG5cbmV4cG9ydCBkZWZhdWx0IFJlYWN0Lm1lbW8oVGFibGVCb2R5KTtcbiJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFnRG1CIn0= */"),StyledTd=(0,_styled.default)(_TableCell.default,{target:"e13t89ug2",label:"StyledTd"})(({theme,bodyCellVerticalPadding})=>({...(0,_mediaQueries.mq)({padding:[bodyCellVerticalPadding,{s:`${theme.variables.size.spacing.s} ${theme.variables.size.spacing.m}`,m:`${theme.variables.size.spacing.m} ${theme.variables.size.spacing.m}`,l:`${theme.variables.size.spacing.l} ${theme.variables.size.spacing.m}`}]})}),"/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoic3JjL2NvbXBvbmVudHMvRGF0YVRhYmxlL1RhYmxlQm9keS50c3giLCJzb3VyY2VzIjpbInNyYy9jb21wb25lbnRzL0RhdGFUYWJsZS9UYWJsZUJvZHkudHN4Il0sInNvdXJjZXNDb250ZW50IjpbImltcG9ydCBSZWFjdCBmcm9tIFwicmVhY3RcIjtcbmltcG9ydCBzdHlsZWQgZnJvbSBcIkBlbW90aW9uL3N0eWxlZFwiO1xuaW1wb3J0IHR5cGUgeyBEYXRhVGFibGVDb2x1bW4gfSBmcm9tIFwiLi90eXBlc1wiO1xuaW1wb3J0IHR5cGUgeyBUYWJsZUNlbGxQcm9wcyB9IGZyb20gXCIuL1RhYmxlQ2VsbFwiO1xuaW1wb3J0IFRhYmxlQ2VsbCBmcm9tIFwiLi9UYWJsZUNlbGxcIjtcbmltcG9ydCB7IFRleHQgfSBmcm9tIFwiLi4vVHlwb2dyYXBoeS9UZXh0L1RleHRcIjtcbmltcG9ydCB0eXBlIHsgRGF0YVRhYmxlUHJvcHMgfSBmcm9tIFwiLi9EYXRhVGFibGVcIjtcbmltcG9ydCB7IExvYWRpbmdTcGlubmVyIH0gZnJvbSBcIi4uL0xvYWRpbmdTcGlubmVyL0xvYWRpbmdTcGlubmVyXCI7XG5pbXBvcnQgeyBtcSwgbXFWYWx1ZSB9IGZyb20gXCIuLi8uLi9zaGFyZWQvbWVkaWFRdWVyaWVzXCI7XG5cbmV4cG9ydCB0eXBlIFRhYmxlQm9keVByb3BzID0ge1xuICBjbGFzc05hbWU/OiBzdHJpbmc7XG59ICYgUGljazxcbiAgRGF0YVRhYmxlUHJvcHMsXG4gIHwgXCJjb2x1bW5zXCJcbiAgfCBcInJvd3NcIlxuICB8IFwiaXNMb2FkaW5nXCJcbiAgfCBcImxvYWRpbmdTdGF0ZVNjcmVlblJlYWRlclRleHRcIlxuICB8IFwiaXNFbXB0eVwiXG4gIHwgXCJlbXB0eVRhYmxlQ29udGVudEhlaWdodFwiXG4gIHwgXCJib2R5Q2VsbFZlcnRpY2FsUGFkZGluZ1wiXG4gIHwgXCJmb290ZXJcIlxuICB8IFwiaXNGaXJzdENvbHVtblN0aWNreVwiXG4gIHwgXCJpc0xhc3RDb2x1bW5TdGlja3lcIlxuICB8IFwiZW1wdHlDZWxsQ29udGVudFwiXG4+ICZcbiAgUGljazxUYWJsZUNlbGxQcm9wcywgXCJpc1RhYmxlU2Nyb2xsZWRUb0xlZnRcIiB8IFwiaXNUYWJsZVNjcm9sbGVkVG9SaWdodFwiPjtcblxudHlwZSBTdHlsZWRUclByb3BzID0gUGljazxUYWJsZUJvZHlQcm9wcywgXCJmb290ZXJcIj47XG5cbmNvbnN0IFN0eWxlZFRyID0gc3R5bGVkLnRyPFN0eWxlZFRyUHJvcHM+KCh7IHRoZW1lLCBmb290ZXIgfSkgPT4gKHtcbiAgXCImOmhvdmVyIHRkXCI6IHtcbiAgICBiYWNrZ3JvdW5kQ29sb3I6IHRoZW1lLnZhbHVlcy5jb2xvci5iYWNrZ3JvdW5kLnNlY29uZGFyeS5kZWZhdWx0LFxuICB9LFxuXG4gIC4uLighZm9vdGVyICYmIHtcbiAgICBcIiY6bGFzdC1vZi10eXBlXCI6IHtcbiAgICAgIHRkOiB7XG4gICAgICAgIGJvcmRlckJvdHRvbTogXCJub25lXCIsXG4gICAgICB9LFxuICAgIH0sXG4gIH0pLFxufSkpO1xuXG50eXBlIFN0eWxlZFRleHRQcm9wcyA9IHtcbiAgYWxpZ25Db2x1bW4/OiBEYXRhVGFibGVDb2x1bW5bXCJhbGlnblwiXTtcbn07XG5cbmNvbnN0IFN0eWxlZFRleHQgPSBzdHlsZWQoVGV4dCk8U3R5bGVkVGV4dFByb3BzPigoeyBhbGlnbkNvbHVtbiB9KSA9PiAoe1xuICAuLi5tcVZhbHVlKHtcbiAgICB0ZXh0QWxpZ246IGFsaWduQ29sdW1uLFxuICB9KSxcbn0pKTtcblxudHlwZSBTdHlsZWRUZFByb3BzID0gVGFibGVDZWxsUHJvcHMgJlxuICBQaWNrPFxuICAgIFRhYmxlQm9keVByb3BzLFxuICAgIFwiaXNGaXJzdENvbHVtblN0aWNreVwiIHwgXCJpc0xhc3RDb2x1bW5TdGlja3lcIiB8IFwiYm9keUNlbGxWZXJ0aWNhbFBhZGRpbmdcIlxuICA+O1xuXG5jb25zdCBTdHlsZWRUZCA9IHN0eWxlZChUYWJsZUNlbGwpPFN0eWxlZFRkUHJvcHM+KFxuICAoeyB0aGVtZSwgYm9keUNlbGxWZXJ0aWNhbFBhZGRpbmcgfSkgPT4gKHtcbiAgICAuLi5tcSh7XG4gICAgICBwYWRkaW5nOiBbXG4gICAgICAgIGJvZHlDZWxsVmVydGljYWxQYWRkaW5nLFxuICAgICAgICB7XG4gICAgICAgICAgczogYCR7dGhlbWUudmFyaWFibGVzLnNpemUuc3BhY2luZy5zfSAke3RoZW1lLnZhcmlhYmxlcy5zaXplLnNwYWNpbmcubX1gLFxuICAgICAgICAgIG06IGAke3RoZW1lLnZhcmlhYmxlcy5zaXplLnNwYWNpbmcubX0gJHt0aGVtZS52YXJpYWJsZXMuc2l6ZS5zcGFjaW5nLm19YCxcbiAgICAgICAgICBsOiBgJHt0aGVtZS52YXJpYWJsZXMuc2l6ZS5zcGFjaW5nLmx9ICR7dGhlbWUudmFyaWFibGVzLnNpemUuc3BhY2luZy5tfWAsXG4gICAgICAgIH0gYXMgYW55LFxuICAgICAgXSxcbiAgICB9KSxcbiAgfSlcbik7XG5cbnR5cGUgRW1wdHlUYWJsZUJvZHlQcm9wcyA9IFBpY2s8XG4gIFRhYmxlQm9keVByb3BzLFxuICBcImNvbHVtbnNcIiB8IFwiZW1wdHlUYWJsZUNvbnRlbnRIZWlnaHRcIlxuPiAmIHtcbiAgY2hpbGRyZW46IFJlYWN0LlJlYWN0RWxlbWVudDtcbn07XG5cbnR5cGUgU3R5bGVkRW1wdHlUZFByb3BzID0gUGljazxFbXB0eVRhYmxlQm9keVByb3BzLCBcImVtcHR5VGFibGVDb250ZW50SGVpZ2h0XCI+O1xuXG5jb25zdCBTdHlsZWRFbXB0eVRkID0gc3R5bGVkLnRkPFN0eWxlZEVtcHR5VGRQcm9wcz4oXG4gICh7IGVtcHR5VGFibGVDb250ZW50SGVpZ2h0IH0pID0+ICh7XG4gICAgdGV4dEFsaWduOiBcImNlbnRlclwiLFxuICAgIC4uLm1xVmFsdWUoe1xuICAgICAgaGVpZ2h0OiBlbXB0eVRhYmxlQ29udGVudEhlaWdodCxcbiAgICB9KSxcbiAgfSlcbik7XG5cbmZ1bmN0aW9uIEVtcHR5VGFibGVCb2R5KHtcbiAgY2hpbGRyZW4sXG4gIGNvbHVtbnMsXG4gIGVtcHR5VGFibGVDb250ZW50SGVpZ2h0LFxufTogRW1wdHlUYWJsZUJvZHlQcm9wcyk6IFJlYWN0LlJlYWN0RWxlbWVudCB7XG4gIHJldHVybiAoXG4gICAgPHRib2R5PlxuICAgICAgPHRyPlxuICAgICAgICA8U3R5bGVkRW1wdHlUZFxuICAgICAgICAgIGNvbFNwYW49e2NvbHVtbnMubGVuZ3RofVxuICAgICAgICAgIGVtcHR5VGFibGVDb250ZW50SGVpZ2h0PXtlbXB0eVRhYmxlQ29udGVudEhlaWdodH1cbiAgICAgICAgPlxuICAgICAgICAgIHtjaGlsZHJlbn1cbiAgICAgICAgPC9TdHlsZWRFbXB0eVRkPlxuICAgICAgPC90cj5cbiAgICA8L3Rib2R5PlxuICApO1xufVxuXG5mdW5jdGlvbiBUYWJsZUJvZHkoe1xuICBjbGFzc05hbWUsXG4gIGNvbHVtbnMsXG4gIHJvd3MgPSBbXSxcbiAgYm9keUNlbGxWZXJ0aWNhbFBhZGRpbmcsXG4gIGlzVGFibGVTY3JvbGxlZFRvTGVmdCxcbiAgaXNUYWJsZVNjcm9sbGVkVG9SaWdodCxcbiAgaXNMb2FkaW5nLFxuICBsb2FkaW5nU3RhdGVTY3JlZW5SZWFkZXJUZXh0ID0gXCJMb2FkaW5nXCIsXG4gIGlzRW1wdHksXG4gIGVtcHR5VGFibGVDb250ZW50SGVpZ2h0LFxuICBmb290ZXIsXG4gIGNoaWxkcmVuLFxuICBpc0ZpcnN0Q29sdW1uU3RpY2t5LFxuICBpc0xhc3RDb2x1bW5TdGlja3ksXG4gIGVtcHR5Q2VsbENvbnRlbnQsXG59OiBSZWFjdC5Qcm9wc1dpdGhDaGlsZHJlbjxUYWJsZUJvZHlQcm9wcz4pOiBSZWFjdC5SZWFjdEVsZW1lbnQge1xuICBpZiAoaXNMb2FkaW5nKSB7XG4gICAgY29uc3QgY3VzdG9tTG9hZGluZ0NvbnRlbnQgPSBjaGlsZHJlbiAmJiA8PntjaGlsZHJlbn08Lz47XG4gICAgY29uc3QgYm9keUNvbnRlbnQgPSBjdXN0b21Mb2FkaW5nQ29udGVudCB8fCAoXG4gICAgICA8TG9hZGluZ1NwaW5uZXIgc2NyZWVuUmVhZGVyVGV4dD17bG9hZGluZ1N0YXRlU2NyZWVuUmVhZGVyVGV4dH0gLz5cbiAgICApO1xuXG4gICAgcmV0dXJuIChcbiAgICAgIDxFbXB0eVRhYmxlQm9keVxuICAgICAgICBjb2x1bW5zPXtjb2x1bW5zfVxuICAgICAgICBlbXB0eVRhYmxlQ29udGVudEhlaWdodD17ZW1wdHlUYWJsZUNvbnRlbnRIZWlnaHR9XG4gICAgICA+XG4gICAgICAgIHtib2R5Q29udGVudH1cbiAgICAgIDwvRW1wdHlUYWJsZUJvZHk+XG4gICAgKTtcbiAgfVxuXG4gIGlmIChpc0VtcHR5KSB7XG4gICAgcmV0dXJuIChcbiAgICAgIDxFbXB0eVRhYmxlQm9keVxuICAgICAgICBjb2x1bW5zPXtjb2x1bW5zfVxuICAgICAgICBlbXB0eVRhYmxlQ29udGVudEhlaWdodD17ZW1wdHlUYWJsZUNvbnRlbnRIZWlnaHR9XG4gICAgICA+XG4gICAgICAgIDw+e2NoaWxkcmVufTwvPlxuICAgICAgPC9FbXB0eVRhYmxlQm9keT5cbiAgICApO1xuICB9XG5cbiAgY29uc3Qgcm93RWxlbWVudHMgPSByb3dzLm1hcCgocm93KSA9PiAoXG4gICAgPFN0eWxlZFRyIGtleT17cm93LmlkfSBmb290ZXI9e2Zvb3Rlcn0+XG4gICAgICB7Y29sdW1ucy5tYXAoKHsgbmFtZSwgYWxpZ24gPSBcImxlZnRcIiwgcmVuZGVyQ2VsbCB9KSA9PiB7XG4gICAgICAgIGNvbnN0IGNvbnRlbnQgPSByZW5kZXJDZWxsID8gKFxuICAgICAgICAgIHJlbmRlckNlbGwocm93KVxuICAgICAgICApIDogKFxuICAgICAgICAgIDxTdHlsZWRUZXh0IHNpemU9XCJzXCIgYWxpZ25Db2x1bW49e2FsaWdufT5cbiAgICAgICAgICAgIHtyb3dbbmFtZV0gPyByb3dbbmFtZV0gOiBlbXB0eUNlbGxDb250ZW50fVxuICAgICAgICAgIDwvU3R5bGVkVGV4dD5cbiAgICAgICAgKTtcblxuICAgICAgICByZXR1cm4gKFxuICAgICAgICAgIDxTdHlsZWRUZFxuICAgICAgICAgICAga2V5PXtuYW1lfVxuICAgICAgICAgICAgYWxpZ25Db2x1bW49e2FsaWdufVxuICAgICAgICAgICAgaXNGaXJzdENvbHVtblN0aWNreT17aXNGaXJzdENvbHVtblN0aWNreX1cbiAgICAgICAgICAgIGlzTGFzdENvbHVtblN0aWNreT17aXNMYXN0Q29sdW1uU3RpY2t5fVxuICAgICAgICAgICAgYm9keUNlbGxWZXJ0aWNhbFBhZGRpbmc9e2JvZHlDZWxsVmVydGljYWxQYWRkaW5nfVxuICAgICAgICAgICAgaXNUYWJsZVNjcm9sbGVkVG9MZWZ0PXtpc1RhYmxlU2Nyb2xsZWRUb0xlZnR9XG4gICAgICAgICAgICBpc1RhYmxlU2Nyb2xsZWRUb1JpZ2h0PXtpc1RhYmxlU2Nyb2xsZWRUb1JpZ2h0fVxuICAgICAgICAgID5cbiAgICAgICAgICAgIHtjb250ZW50fVxuICAgICAgICAgIDwvU3R5bGVkVGQ+XG4gICAgICAgICk7XG4gICAgICB9KX1cbiAgICA8L1N0eWxlZFRyPlxuICApKTtcblxuICByZXR1cm4gPHRib2R5IGNsYXNzTmFtZT17Y2xhc3NOYW1lfT57cm93RWxlbWVudHN9PC90Ym9keT47XG59XG5cbmV4cG9ydCBkZWZhdWx0IFJlYWN0Lm1lbW8oVGFibGVCb2R5KTtcbiJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUE0RGlCIn0= */"),StyledEmptyTd=(0,_styled.default)("td",{target:"e13t89ug3",label:"StyledEmptyTd"})(({emptyTableContentHeight})=>({textAlign:"center",...(0,_mediaQueries.mqValue)({height:emptyTableContentHeight})}),"/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoic3JjL2NvbXBvbmVudHMvRGF0YVRhYmxlL1RhYmxlQm9keS50c3giLCJzb3VyY2VzIjpbInNyYy9jb21wb25lbnRzL0RhdGFUYWJsZS9UYWJsZUJvZHkudHN4Il0sInNvdXJjZXNDb250ZW50IjpbImltcG9ydCBSZWFjdCBmcm9tIFwicmVhY3RcIjtcbmltcG9ydCBzdHlsZWQgZnJvbSBcIkBlbW90aW9uL3N0eWxlZFwiO1xuaW1wb3J0IHR5cGUgeyBEYXRhVGFibGVDb2x1bW4gfSBmcm9tIFwiLi90eXBlc1wiO1xuaW1wb3J0IHR5cGUgeyBUYWJsZUNlbGxQcm9wcyB9IGZyb20gXCIuL1RhYmxlQ2VsbFwiO1xuaW1wb3J0IFRhYmxlQ2VsbCBmcm9tIFwiLi9UYWJsZUNlbGxcIjtcbmltcG9ydCB7IFRleHQgfSBmcm9tIFwiLi4vVHlwb2dyYXBoeS9UZXh0L1RleHRcIjtcbmltcG9ydCB0eXBlIHsgRGF0YVRhYmxlUHJvcHMgfSBmcm9tIFwiLi9EYXRhVGFibGVcIjtcbmltcG9ydCB7IExvYWRpbmdTcGlubmVyIH0gZnJvbSBcIi4uL0xvYWRpbmdTcGlubmVyL0xvYWRpbmdTcGlubmVyXCI7XG5pbXBvcnQgeyBtcSwgbXFWYWx1ZSB9IGZyb20gXCIuLi8uLi9zaGFyZWQvbWVkaWFRdWVyaWVzXCI7XG5cbmV4cG9ydCB0eXBlIFRhYmxlQm9keVByb3BzID0ge1xuICBjbGFzc05hbWU/OiBzdHJpbmc7XG59ICYgUGljazxcbiAgRGF0YVRhYmxlUHJvcHMsXG4gIHwgXCJjb2x1bW5zXCJcbiAgfCBcInJvd3NcIlxuICB8IFwiaXNMb2FkaW5nXCJcbiAgfCBcImxvYWRpbmdTdGF0ZVNjcmVlblJlYWRlclRleHRcIlxuICB8IFwiaXNFbXB0eVwiXG4gIHwgXCJlbXB0eVRhYmxlQ29udGVudEhlaWdodFwiXG4gIHwgXCJib2R5Q2VsbFZlcnRpY2FsUGFkZGluZ1wiXG4gIHwgXCJmb290ZXJcIlxuICB8IFwiaXNGaXJzdENvbHVtblN0aWNreVwiXG4gIHwgXCJpc0xhc3RDb2x1bW5TdGlja3lcIlxuICB8IFwiZW1wdHlDZWxsQ29udGVudFwiXG4+ICZcbiAgUGljazxUYWJsZUNlbGxQcm9wcywgXCJpc1RhYmxlU2Nyb2xsZWRUb0xlZnRcIiB8IFwiaXNUYWJsZVNjcm9sbGVkVG9SaWdodFwiPjtcblxudHlwZSBTdHlsZWRUclByb3BzID0gUGljazxUYWJsZUJvZHlQcm9wcywgXCJmb290ZXJcIj47XG5cbmNvbnN0IFN0eWxlZFRyID0gc3R5bGVkLnRyPFN0eWxlZFRyUHJvcHM+KCh7IHRoZW1lLCBmb290ZXIgfSkgPT4gKHtcbiAgXCImOmhvdmVyIHRkXCI6IHtcbiAgICBiYWNrZ3JvdW5kQ29sb3I6IHRoZW1lLnZhbHVlcy5jb2xvci5iYWNrZ3JvdW5kLnNlY29uZGFyeS5kZWZhdWx0LFxuICB9LFxuXG4gIC4uLighZm9vdGVyICYmIHtcbiAgICBcIiY6bGFzdC1vZi10eXBlXCI6IHtcbiAgICAgIHRkOiB7XG4gICAgICAgIGJvcmRlckJvdHRvbTogXCJub25lXCIsXG4gICAgICB9LFxuICAgIH0sXG4gIH0pLFxufSkpO1xuXG50eXBlIFN0eWxlZFRleHRQcm9wcyA9IHtcbiAgYWxpZ25Db2x1bW4/OiBEYXRhVGFibGVDb2x1bW5bXCJhbGlnblwiXTtcbn07XG5cbmNvbnN0IFN0eWxlZFRleHQgPSBzdHlsZWQoVGV4dCk8U3R5bGVkVGV4dFByb3BzPigoeyBhbGlnbkNvbHVtbiB9KSA9PiAoe1xuICAuLi5tcVZhbHVlKHtcbiAgICB0ZXh0QWxpZ246IGFsaWduQ29sdW1uLFxuICB9KSxcbn0pKTtcblxudHlwZSBTdHlsZWRUZFByb3BzID0gVGFibGVDZWxsUHJvcHMgJlxuICBQaWNrPFxuICAgIFRhYmxlQm9keVByb3BzLFxuICAgIFwiaXNGaXJzdENvbHVtblN0aWNreVwiIHwgXCJpc0xhc3RDb2x1bW5TdGlja3lcIiB8IFwiYm9keUNlbGxWZXJ0aWNhbFBhZGRpbmdcIlxuICA+O1xuXG5jb25zdCBTdHlsZWRUZCA9IHN0eWxlZChUYWJsZUNlbGwpPFN0eWxlZFRkUHJvcHM+KFxuICAoeyB0aGVtZSwgYm9keUNlbGxWZXJ0aWNhbFBhZGRpbmcgfSkgPT4gKHtcbiAgICAuLi5tcSh7XG4gICAgICBwYWRkaW5nOiBbXG4gICAgICAgIGJvZHlDZWxsVmVydGljYWxQYWRkaW5nLFxuICAgICAgICB7XG4gICAgICAgICAgczogYCR7dGhlbWUudmFyaWFibGVzLnNpemUuc3BhY2luZy5zfSAke3RoZW1lLnZhcmlhYmxlcy5zaXplLnNwYWNpbmcubX1gLFxuICAgICAgICAgIG06IGAke3RoZW1lLnZhcmlhYmxlcy5zaXplLnNwYWNpbmcubX0gJHt0aGVtZS52YXJpYWJsZXMuc2l6ZS5zcGFjaW5nLm19YCxcbiAgICAgICAgICBsOiBgJHt0aGVtZS52YXJpYWJsZXMuc2l6ZS5zcGFjaW5nLmx9ICR7dGhlbWUudmFyaWFibGVzLnNpemUuc3BhY2luZy5tfWAsXG4gICAgICAgIH0gYXMgYW55LFxuICAgICAgXSxcbiAgICB9KSxcbiAgfSlcbik7XG5cbnR5cGUgRW1wdHlUYWJsZUJvZHlQcm9wcyA9IFBpY2s8XG4gIFRhYmxlQm9keVByb3BzLFxuICBcImNvbHVtbnNcIiB8IFwiZW1wdHlUYWJsZUNvbnRlbnRIZWlnaHRcIlxuPiAmIHtcbiAgY2hpbGRyZW46IFJlYWN0LlJlYWN0RWxlbWVudDtcbn07XG5cbnR5cGUgU3R5bGVkRW1wdHlUZFByb3BzID0gUGljazxFbXB0eVRhYmxlQm9keVByb3BzLCBcImVtcHR5VGFibGVDb250ZW50SGVpZ2h0XCI+O1xuXG5jb25zdCBTdHlsZWRFbXB0eVRkID0gc3R5bGVkLnRkPFN0eWxlZEVtcHR5VGRQcm9wcz4oXG4gICh7IGVtcHR5VGFibGVDb250ZW50SGVpZ2h0IH0pID0+ICh7XG4gICAgdGV4dEFsaWduOiBcImNlbnRlclwiLFxuICAgIC4uLm1xVmFsdWUoe1xuICAgICAgaGVpZ2h0OiBlbXB0eVRhYmxlQ29udGVudEhlaWdodCxcbiAgICB9KSxcbiAgfSlcbik7XG5cbmZ1bmN0aW9uIEVtcHR5VGFibGVCb2R5KHtcbiAgY2hpbGRyZW4sXG4gIGNvbHVtbnMsXG4gIGVtcHR5VGFibGVDb250ZW50SGVpZ2h0LFxufTogRW1wdHlUYWJsZUJvZHlQcm9wcyk6IFJlYWN0LlJlYWN0RWxlbWVudCB7XG4gIHJldHVybiAoXG4gICAgPHRib2R5PlxuICAgICAgPHRyPlxuICAgICAgICA8U3R5bGVkRW1wdHlUZFxuICAgICAgICAgIGNvbFNwYW49e2NvbHVtbnMubGVuZ3RofVxuICAgICAgICAgIGVtcHR5VGFibGVDb250ZW50SGVpZ2h0PXtlbXB0eVRhYmxlQ29udGVudEhlaWdodH1cbiAgICAgICAgPlxuICAgICAgICAgIHtjaGlsZHJlbn1cbiAgICAgICAgPC9TdHlsZWRFbXB0eVRkPlxuICAgICAgPC90cj5cbiAgICA8L3Rib2R5PlxuICApO1xufVxuXG5mdW5jdGlvbiBUYWJsZUJvZHkoe1xuICBjbGFzc05hbWUsXG4gIGNvbHVtbnMsXG4gIHJvd3MgPSBbXSxcbiAgYm9keUNlbGxWZXJ0aWNhbFBhZGRpbmcsXG4gIGlzVGFibGVTY3JvbGxlZFRvTGVmdCxcbiAgaXNUYWJsZVNjcm9sbGVkVG9SaWdodCxcbiAgaXNMb2FkaW5nLFxuICBsb2FkaW5nU3RhdGVTY3JlZW5SZWFkZXJUZXh0ID0gXCJMb2FkaW5nXCIsXG4gIGlzRW1wdHksXG4gIGVtcHR5VGFibGVDb250ZW50SGVpZ2h0LFxuICBmb290ZXIsXG4gIGNoaWxkcmVuLFxuICBpc0ZpcnN0Q29sdW1uU3RpY2t5LFxuICBpc0xhc3RDb2x1bW5TdGlja3ksXG4gIGVtcHR5Q2VsbENvbnRlbnQsXG59OiBSZWFjdC5Qcm9wc1dpdGhDaGlsZHJlbjxUYWJsZUJvZHlQcm9wcz4pOiBSZWFjdC5SZWFjdEVsZW1lbnQge1xuICBpZiAoaXNMb2FkaW5nKSB7XG4gICAgY29uc3QgY3VzdG9tTG9hZGluZ0NvbnRlbnQgPSBjaGlsZHJlbiAmJiA8PntjaGlsZHJlbn08Lz47XG4gICAgY29uc3QgYm9keUNvbnRlbnQgPSBjdXN0b21Mb2FkaW5nQ29udGVudCB8fCAoXG4gICAgICA8TG9hZGluZ1NwaW5uZXIgc2NyZWVuUmVhZGVyVGV4dD17bG9hZGluZ1N0YXRlU2NyZWVuUmVhZGVyVGV4dH0gLz5cbiAgICApO1xuXG4gICAgcmV0dXJuIChcbiAgICAgIDxFbXB0eVRhYmxlQm9keVxuICAgICAgICBjb2x1bW5zPXtjb2x1bW5zfVxuICAgICAgICBlbXB0eVRhYmxlQ29udGVudEhlaWdodD17ZW1wdHlUYWJsZUNvbnRlbnRIZWlnaHR9XG4gICAgICA+XG4gICAgICAgIHtib2R5Q29udGVudH1cbiAgICAgIDwvRW1wdHlUYWJsZUJvZHk+XG4gICAgKTtcbiAgfVxuXG4gIGlmIChpc0VtcHR5KSB7XG4gICAgcmV0dXJuIChcbiAgICAgIDxFbXB0eVRhYmxlQm9keVxuICAgICAgICBjb2x1bW5zPXtjb2x1bW5zfVxuICAgICAgICBlbXB0eVRhYmxlQ29udGVudEhlaWdodD17ZW1wdHlUYWJsZUNvbnRlbnRIZWlnaHR9XG4gICAgICA+XG4gICAgICAgIDw+e2NoaWxkcmVufTwvPlxuICAgICAgPC9FbXB0eVRhYmxlQm9keT5cbiAgICApO1xuICB9XG5cbiAgY29uc3Qgcm93RWxlbWVudHMgPSByb3dzLm1hcCgocm93KSA9PiAoXG4gICAgPFN0eWxlZFRyIGtleT17cm93LmlkfSBmb290ZXI9e2Zvb3Rlcn0+XG4gICAgICB7Y29sdW1ucy5tYXAoKHsgbmFtZSwgYWxpZ24gPSBcImxlZnRcIiwgcmVuZGVyQ2VsbCB9KSA9PiB7XG4gICAgICAgIGNvbnN0IGNvbnRlbnQgPSByZW5kZXJDZWxsID8gKFxuICAgICAgICAgIHJlbmRlckNlbGwocm93KVxuICAgICAgICApIDogKFxuICAgICAgICAgIDxTdHlsZWRUZXh0IHNpemU9XCJzXCIgYWxpZ25Db2x1bW49e2FsaWdufT5cbiAgICAgICAgICAgIHtyb3dbbmFtZV0gPyByb3dbbmFtZV0gOiBlbXB0eUNlbGxDb250ZW50fVxuICAgICAgICAgIDwvU3R5bGVkVGV4dD5cbiAgICAgICAgKTtcblxuICAgICAgICByZXR1cm4gKFxuICAgICAgICAgIDxTdHlsZWRUZFxuICAgICAgICAgICAga2V5PXtuYW1lfVxuICAgICAgICAgICAgYWxpZ25Db2x1bW49e2FsaWdufVxuICAgICAgICAgICAgaXNGaXJzdENvbHVtblN0aWNreT17aXNGaXJzdENvbHVtblN0aWNreX1cbiAgICAgICAgICAgIGlzTGFzdENvbHVtblN0aWNreT17aXNMYXN0Q29sdW1uU3RpY2t5fVxuICAgICAgICAgICAgYm9keUNlbGxWZXJ0aWNhbFBhZGRpbmc9e2JvZHlDZWxsVmVydGljYWxQYWRkaW5nfVxuICAgICAgICAgICAgaXNUYWJsZVNjcm9sbGVkVG9MZWZ0PXtpc1RhYmxlU2Nyb2xsZWRUb0xlZnR9XG4gICAgICAgICAgICBpc1RhYmxlU2Nyb2xsZWRUb1JpZ2h0PXtpc1RhYmxlU2Nyb2xsZWRUb1JpZ2h0fVxuICAgICAgICAgID5cbiAgICAgICAgICAgIHtjb250ZW50fVxuICAgICAgICAgIDwvU3R5bGVkVGQ+XG4gICAgICAgICk7XG4gICAgICB9KX1cbiAgICA8L1N0eWxlZFRyPlxuICApKTtcblxuICByZXR1cm4gPHRib2R5IGNsYXNzTmFtZT17Y2xhc3NOYW1lfT57cm93RWxlbWVudHN9PC90Ym9keT47XG59XG5cbmV4cG9ydCBkZWZhdWx0IFJlYWN0Lm1lbW8oVGFibGVCb2R5KTtcbiJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFvRnNCIn0= */");function EmptyTableBody({children,columns,emptyTableContentHeight}){return _react.default.createElement("tbody",null,_react.default.createElement("tr",null,_react.default.createElement(StyledEmptyTd,{colSpan:columns.length,emptyTableContentHeight:emptyTableContentHeight},children)))}const _default=_react.default.memo(function({className,columns,rows=[],bodyCellVerticalPadding,isTableScrolledToLeft,isTableScrolledToRight,isLoading,loadingStateScreenReaderText="Loading",isEmpty,emptyTableContentHeight,footer,children,isFirstColumnSticky,isLastColumnSticky,emptyCellContent}){if(isLoading){let bodyContent=children&&_react.default.createElement(_react.default.Fragment,null,children)||_react.default.createElement(_LoadingSpinner.LoadingSpinner,{screenReaderText:loadingStateScreenReaderText});return _react.default.createElement(EmptyTableBody,{columns:columns,emptyTableContentHeight:emptyTableContentHeight},bodyContent)}if(isEmpty)return _react.default.createElement(EmptyTableBody,{columns:columns,emptyTableContentHeight:emptyTableContentHeight},_react.default.createElement(_react.default.Fragment,null,children));let rowElements=rows.map(row=>_react.default.createElement(StyledTr,{key:row.id,footer:footer},columns.map(({name,align="left",renderCell})=>{let content=renderCell?renderCell(row):_react.default.createElement(StyledText,{size:"s",alignColumn:align},row[name]?row[name]:emptyCellContent);return _react.default.createElement(StyledTd,{key:name,alignColumn:align,isFirstColumnSticky:isFirstColumnSticky,isLastColumnSticky:isLastColumnSticky,bodyCellVerticalPadding:bodyCellVerticalPadding,isTableScrolledToLeft:isTableScrolledToLeft,isTableScrolledToRight:isTableScrolledToRight},content)})));return _react.default.createElement("tbody",{className:className},rowElements)});
|
|
@@ -1,15 +1,19 @@
|
|
|
1
1
|
/// <reference types="react" />
|
|
2
|
-
import type {
|
|
2
|
+
import type { DataTableProps } from "./DataTable";
|
|
3
3
|
import type { DataTableColumn } from "./types";
|
|
4
4
|
export type TableCellProps = {
|
|
5
5
|
alignColumn?: DataTableColumn["align"];
|
|
6
6
|
columnWidth?: DataTableColumn["width"];
|
|
7
|
-
|
|
7
|
+
isTableScrolledToLeft: boolean;
|
|
8
|
+
isTableScrolledToRight: boolean;
|
|
9
|
+
} & Pick<DataTableProps, "isFirstColumnSticky" | "isLastColumnSticky">;
|
|
8
10
|
declare const TableCell: import("@emotion/styled").StyledComponent<{
|
|
9
11
|
theme?: import("@emotion/react").Theme;
|
|
10
12
|
as?: import("react").ElementType<any>;
|
|
11
13
|
} & {
|
|
12
14
|
alignColumn?: DataTableColumn["align"];
|
|
13
15
|
columnWidth?: DataTableColumn["width"];
|
|
14
|
-
|
|
16
|
+
isTableScrolledToLeft: boolean;
|
|
17
|
+
isTableScrolledToRight: boolean;
|
|
18
|
+
} & Pick<DataTableProps, "isFirstColumnSticky" | "isLastColumnSticky">, import("react").DetailedHTMLProps<import("react").TdHTMLAttributes<HTMLTableDataCellElement>, HTMLTableDataCellElement>, {}>;
|
|
15
19
|
export default TableCell;
|
|
@@ -1 +1 @@
|
|
|
1
|
-
"use strict";Object.defineProperty(exports,"__esModule",{value:!0}),Object.defineProperty(exports,"default",{enumerable:!0,get:function(){return _default}});const _styled=require("@swc/helpers/_/_interop_require_default")._(require("@emotion/styled")),_mediaQueries=require("../../shared/mediaQueries"),_default=(0,_styled.default)("td",{target:"
|
|
1
|
+
"use strict";Object.defineProperty(exports,"__esModule",{value:!0}),Object.defineProperty(exports,"default",{enumerable:!0,get:function(){return _default}});const _styled=require("@swc/helpers/_/_interop_require_default")._(require("@emotion/styled")),_mediaQueries=require("../../shared/mediaQueries"),_default=(0,_styled.default)("td",{target:"ekd3ji10",label:"TableCell"})(({theme,isFirstColumnSticky,isLastColumnSticky,isTableScrolledToLeft,isTableScrolledToRight,alignColumn,columnWidth})=>({borderBottom:`1px solid ${theme.values.color.divider.primary}`,backgroundColor:theme.values.color.background.primary.default,...(0,_mediaQueries.mqValue)({width:columnWidth,textAlign:alignColumn}),...isFirstColumnSticky&&!isTableScrolledToLeft&&{"&:first-of-type":{position:"sticky",left:0,borderRight:`1px solid ${theme.values.color.divider.primary}`}},...isLastColumnSticky&&!isTableScrolledToRight&&{"&:last-of-type":{position:"sticky",right:0,borderLeft:`1px solid ${theme.values.color.divider.primary}`}}}),"/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoic3JjL2NvbXBvbmVudHMvRGF0YVRhYmxlL1RhYmxlQ2VsbC50c3giLCJzb3VyY2VzIjpbInNyYy9jb21wb25lbnRzL0RhdGFUYWJsZS9UYWJsZUNlbGwudHN4Il0sInNvdXJjZXNDb250ZW50IjpbImltcG9ydCBzdHlsZWQgZnJvbSBcIkBlbW90aW9uL3N0eWxlZFwiO1xuaW1wb3J0IHR5cGUgeyBEYXRhVGFibGVQcm9wcyB9IGZyb20gXCIuL0RhdGFUYWJsZVwiO1xuaW1wb3J0IHR5cGUgeyBEYXRhVGFibGVDb2x1bW4gfSBmcm9tIFwiLi90eXBlc1wiO1xuaW1wb3J0IHsgbXFWYWx1ZSB9IGZyb20gXCIuLi8uLi9zaGFyZWQvbWVkaWFRdWVyaWVzXCI7XG5cbmV4cG9ydCB0eXBlIFRhYmxlQ2VsbFByb3BzID0ge1xuICBhbGlnbkNvbHVtbj86IERhdGFUYWJsZUNvbHVtbltcImFsaWduXCJdO1xuICBjb2x1bW5XaWR0aD86IERhdGFUYWJsZUNvbHVtbltcIndpZHRoXCJdO1xuICBpc1RhYmxlU2Nyb2xsZWRUb0xlZnQ6IGJvb2xlYW47XG4gIGlzVGFibGVTY3JvbGxlZFRvUmlnaHQ6IGJvb2xlYW47XG59ICYgUGljazxEYXRhVGFibGVQcm9wcywgXCJpc0ZpcnN0Q29sdW1uU3RpY2t5XCIgfCBcImlzTGFzdENvbHVtblN0aWNreVwiPjtcblxuY29uc3QgVGFibGVDZWxsID0gc3R5bGVkLnRkPFRhYmxlQ2VsbFByb3BzPihcbiAgKHtcbiAgICB0aGVtZSxcbiAgICBpc0ZpcnN0Q29sdW1uU3RpY2t5LFxuICAgIGlzTGFzdENvbHVtblN0aWNreSxcbiAgICBpc1RhYmxlU2Nyb2xsZWRUb0xlZnQsXG4gICAgaXNUYWJsZVNjcm9sbGVkVG9SaWdodCxcbiAgICBhbGlnbkNvbHVtbixcbiAgICBjb2x1bW5XaWR0aCxcbiAgfSkgPT4gKHtcbiAgICBib3JkZXJCb3R0b206IGAxcHggc29saWQgJHt0aGVtZS52YWx1ZXMuY29sb3IuZGl2aWRlci5wcmltYXJ5fWAsXG4gICAgYmFja2dyb3VuZENvbG9yOiB0aGVtZS52YWx1ZXMuY29sb3IuYmFja2dyb3VuZC5wcmltYXJ5LmRlZmF1bHQsXG5cbiAgICAuLi5tcVZhbHVlKHtcbiAgICAgIHdpZHRoOiBjb2x1bW5XaWR0aCxcbiAgICAgIHRleHRBbGlnbjogYWxpZ25Db2x1bW4sXG4gICAgfSksXG5cbiAgICAuLi4oaXNGaXJzdENvbHVtblN0aWNreSAmJlxuICAgICAgIWlzVGFibGVTY3JvbGxlZFRvTGVmdCAmJiB7XG4gICAgICAgIFwiJjpmaXJzdC1vZi10eXBlXCI6IHtcbiAgICAgICAgICBwb3NpdGlvbjogXCJzdGlja3lcIixcbiAgICAgICAgICBsZWZ0OiAwLFxuICAgICAgICAgIGJvcmRlclJpZ2h0OiBgMXB4IHNvbGlkICR7dGhlbWUudmFsdWVzLmNvbG9yLmRpdmlkZXIucHJpbWFyeX1gLFxuICAgICAgICB9LFxuICAgICAgfSksXG5cbiAgICAuLi4oaXNMYXN0Q29sdW1uU3RpY2t5ICYmXG4gICAgICAhaXNUYWJsZVNjcm9sbGVkVG9SaWdodCAmJiB7XG4gICAgICAgIFwiJjpsYXN0LW9mLXR5cGVcIjoge1xuICAgICAgICAgIHBvc2l0aW9uOiBcInN0aWNreVwiLFxuICAgICAgICAgIHJpZ2h0OiAwLFxuICAgICAgICAgIGJvcmRlckxlZnQ6IGAxcHggc29saWQgJHt0aGVtZS52YWx1ZXMuY29sb3IuZGl2aWRlci5wcmltYXJ5fWAsXG4gICAgICAgIH0sXG4gICAgICB9KSxcbiAgfSlcbik7XG5cbmV4cG9ydCBkZWZhdWx0IFRhYmxlQ2VsbDtcbiJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFZa0IifQ== */");
|
|
@@ -1,9 +1,9 @@
|
|
|
1
1
|
import React from "react";
|
|
2
|
+
import type { TableCellProps } from "./TableCell";
|
|
2
3
|
import type { DataTableProps } from "./DataTable";
|
|
3
4
|
export type TableHeaderProps = {
|
|
4
5
|
className?: string;
|
|
5
|
-
|
|
6
|
-
|
|
7
|
-
declare function TableHeader({ className, columns, isFirstColumnSticky, currentlySortedByColumn, isTableScrolled, onSort, }: TableHeaderProps): React.ReactElement;
|
|
6
|
+
} & Pick<DataTableProps, "columns" | "rows" | "onSort" | "currentlySortedByColumn" | "isFirstColumnSticky" | "isLastColumnSticky" | "maxHeight"> & Pick<TableCellProps, "isTableScrolledToLeft" | "isTableScrolledToRight">;
|
|
7
|
+
declare function TableHeader({ className, columns, isFirstColumnSticky, isLastColumnSticky, currentlySortedByColumn, isTableScrolledToLeft, isTableScrolledToRight, maxHeight, onSort, }: TableHeaderProps): React.ReactElement;
|
|
8
8
|
declare const _default: React.MemoExoticComponent<typeof TableHeader>;
|
|
9
9
|
export default _default;
|