@amboss/design-system 3.9.2 → 3.9.4
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 +18 -4
- package/build/cjs/components/DataTable/DataTable.js +1 -1
- package/build/cjs/components/DataTable/TableBody.d.ts +2 -2
- package/build/cjs/components/DataTable/TableBody.js +1 -1
- package/build/cjs/components/DataTable/TableCell.d.ts +5 -8
- package/build/cjs/components/DataTable/TableCell.js +1 -1
- package/build/cjs/components/DataTable/constants.d.ts +4 -0
- package/build/cjs/components/DataTable/constants.js +1 -0
- package/build/cjs/components/DataTable/header/SortableCellContent.d.ts +15 -0
- package/build/cjs/components/DataTable/header/SortableCellContent.js +1 -0
- package/build/cjs/components/DataTable/header/TableHeader.d.ts +9 -0
- package/build/cjs/components/DataTable/header/TableHeader.js +1 -0
- package/build/cjs/components/DataTable/index.d.ts +1 -0
- package/build/cjs/components/DataTable/index.js +1 -1
- package/build/cjs/components/DataTable/types.d.ts +7 -2
- package/build/cjs/components/DataTable/useDataTableSelectRows.d.ts +19 -0
- package/build/cjs/components/DataTable/useDataTableSelectRows.js +1 -0
- package/build/cjs/components/Patterns/Modal/Modal.js +3 -3
- package/build/esm/components/DataTable/DataTable.d.ts +18 -4
- package/build/esm/components/DataTable/DataTable.js +1 -1
- package/build/esm/components/DataTable/TableBody.d.ts +2 -2
- package/build/esm/components/DataTable/TableBody.js +1 -1
- package/build/esm/components/DataTable/TableCell.d.ts +5 -8
- package/build/esm/components/DataTable/TableCell.js +1 -1
- package/build/esm/components/DataTable/constants.d.ts +4 -0
- package/build/esm/components/DataTable/constants.js +1 -0
- package/build/esm/components/DataTable/header/SortableCellContent.d.ts +15 -0
- package/build/esm/components/DataTable/header/SortableCellContent.js +1 -0
- package/build/esm/components/DataTable/header/TableHeader.d.ts +9 -0
- package/build/esm/components/DataTable/header/TableHeader.js +1 -0
- package/build/esm/components/DataTable/index.d.ts +1 -0
- package/build/esm/components/DataTable/index.js +1 -1
- package/build/esm/components/DataTable/types.d.ts +7 -2
- package/build/esm/components/DataTable/useDataTableSelectRows.d.ts +19 -0
- package/build/esm/components/DataTable/useDataTableSelectRows.js +1 -0
- package/build/esm/components/Patterns/Modal/Modal.js +3 -3
- package/package.json +1 -1
- package/build/cjs/components/DataTable/TableHeader.d.ts +0 -9
- package/build/cjs/components/DataTable/TableHeader.js +0 -1
- package/build/esm/components/DataTable/TableHeader.d.ts +0 -9
- package/build/esm/components/DataTable/TableHeader.js +0 -1
package/package.json
CHANGED
|
@@ -1,9 +0,0 @@
|
|
|
1
|
-
import React from "react";
|
|
2
|
-
import type { TableCellProps } from "./TableCell";
|
|
3
|
-
import type { DataTableProps } from "./DataTable";
|
|
4
|
-
export type TableHeaderProps = {
|
|
5
|
-
className?: string;
|
|
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
|
-
declare const _default: React.MemoExoticComponent<typeof TableHeader>;
|
|
9
|
-
export default _default;
|
|
@@ -1 +0,0 @@
|
|
|
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=/*#__PURE__*/require("@swc/helpers/_/_interop_require_wildcard")._(require("react")),_styled=/*#__PURE__*/_interop_require_default._(require("@emotion/styled")),_Text=require("../Typography/Text/Text"),_Icon=require("../Icon/Icon"),_TableCell=/*#__PURE__*/_interop_require_default._(require("./TableCell")),_mediaQueries=require("../../shared/mediaQueries"),SORT_DIRECTION_ICON={asc:"sort-ascending",desc:"sort-descending"},SORT_DIRECTION_TEXT={asc:"ascending",desc:"descending"},SortIcon=(0,_styled.default)("span",{target:"e1dmdg710",label:"SortIcon"})(({theme})=>({marginLeft:theme.variables.size.spacing.xxxs,verticalAlign:"middle",color:theme.values.color.text.primary.default}),"/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"src/components/DataTable/TableHeader.tsx","sources":["src/components/DataTable/TableHeader.tsx"],"sourcesContent":["/* eslint-disable react/jsx-props-no-spreading */\n\nimport React, { useState } from \"react\";\nimport styled from \"@emotion/styled\";\nimport type { DataTableColumn } from \"./types\";\nimport { Text } from \"../Typography/Text/Text\";\nimport type { IconName } from \"../Icon/Icon\";\nimport { Icon } from \"../Icon/Icon\";\nimport type { TableCellProps } from \"./TableCell\";\nimport TableCell from \"./TableCell\";\nimport type { DataTableProps } from \"./DataTable\";\nimport { useResponsiveValue } from \"../../shared/mediaQueries\";\n\nexport type TableHeaderProps = {\n  className?: string;\n} & Pick<\n  DataTableProps,\n  | \"columns\"\n  | \"rows\"\n  | \"onSort\"\n  | \"currentlySortedByColumn\"\n  | \"isFirstColumnSticky\"\n  | \"isLastColumnSticky\"\n  | \"maxHeight\"\n> &\n  Pick<TableCellProps, \"isTableScrolledToLeft\" | \"isTableScrolledToRight\">;\n\nconst SORT_DIRECTION_ICON: Record<DataTableColumn[\"sortDirection\"], IconName> =\n  {\n    asc: \"sort-ascending\",\n    desc: \"sort-descending\",\n  };\n\nconst SORT_DIRECTION_TEXT = {\n  asc: \"ascending\" as const,\n  desc: \"descending\" as const,\n};\n\nconst SortIcon = styled.span(({ theme }) => ({\n  marginLeft: theme.variables.size.spacing.xxxs,\n  verticalAlign: \"middle\",\n  color: theme.values.color.text.primary.default,\n}));\n\ntype StyledHeaderLabelProps = {\n  alignColumn?: DataTableColumn[\"align\"];\n};\n\nconst StyledHeaderLabel = styled(Text)<StyledHeaderLabelProps>(\n  ({ theme, alignColumn }) => ({\n    fontWeight: theme.variables.weight.bold,\n    lineHeight: theme.variables.size.lineHeight.m,\n    letterSpacing: theme.variables.size.letterSpacing.s,\n    ...useResponsiveValue({\n      textAlign: alignColumn,\n    }),\n  })\n);\n\ntype StyledSortableHeaderProps = {\n  alignColumn: DataTableColumn[\"align\"];\n};\nconst StyledSortableHeader = styled.button<StyledSortableHeaderProps>(\n  ({ theme, alignColumn }) => ({\n    width: \"100%\",\n    height: theme.variables.size.lineHeight.m,\n    padding: 0,\n    background: \"none\",\n    border: \"none\",\n    cursor: \"pointer\",\n    ...useResponsiveValue({\n      textAlign: alignColumn,\n    }),\n\n    [`&:hover ${StyledHeaderLabel}`]: {\n      color: theme.values.color.text.primary.default,\n    },\n  })\n);\n\ntype SortableHeaderProps = Pick<\n  TableHeaderProps,\n  \"onSort\" | \"currentlySortedByColumn\"\n> &\n  DataTableColumn;\n\nfunction SortableHeader({\n  name,\n  label,\n  align,\n  sortDirection = \"asc\",\n  currentlySortedByColumn,\n  onSort,\n}: SortableHeaderProps): React.ReactElement {\n  const [hovered, setHovered] = useState(false);\n  const desiredSortDirection = sortDirection === \"asc\" ? \"desc\" : \"asc\";\n\n  const handleClick: React.MouseEventHandler = () => {\n    setHovered(false);\n    if (onSort) {\n      onSort(name, desiredSortDirection);\n    }\n  };\n\n  let iconName: IconName = \"sort-neutral\";\n\n  if (name === currentlySortedByColumn) {\n    iconName = SORT_DIRECTION_ICON[sortDirection];\n  }\n  if (hovered) {\n    iconName = SORT_DIRECTION_ICON[desiredSortDirection];\n  }\n\n  return (\n    <StyledSortableHeader\n      onClick={handleClick}\n      type=\"button\"\n      alignColumn={align}\n      onPointerEnter={() => setHovered(true)}\n      onPointerLeave={() => setHovered(false)}\n    >\n      <StyledHeaderLabel\n        as=\"span\"\n        size=\"xs\"\n        transform=\"uppercase\"\n        variant=\"tertiary\"\n      >\n        {label}\n      </StyledHeaderLabel>\n      <SortIcon aria-hidden=\"true\">\n        <Icon size=\"s\" name={iconName} inline />\n      </SortIcon>\n    </StyledSortableHeader>\n  );\n}\n\ntype StyledTheadProps = Pick<TableHeaderProps, \"maxHeight\">;\n\nconst StyledThead = styled.thead<StyledTheadProps>(({ maxHeight }) => ({\n  ...(maxHeight && {\n    position: \"sticky\",\n    top: 0,\n    zIndex: 1,\n  }),\n}));\n\nconst StyledTh = styled(TableCell)(({ theme }) => ({\n  padding: `${theme.variables.size.spacing.s} ${theme.variables.size.spacing.m}`,\n  whiteSpace: \"nowrap\",\n  backgroundColor: theme.values.color.background.primary.default,\n}));\n\nfunction TableHeader({\n  className,\n  columns,\n  isFirstColumnSticky,\n  isLastColumnSticky,\n  currentlySortedByColumn,\n  isTableScrolledToLeft,\n  isTableScrolledToRight,\n  maxHeight,\n  onSort,\n}: TableHeaderProps): React.ReactElement {\n  const columnElements = columns.map((column) => {\n    const {\n      isSortable,\n      label,\n      align = \"left\",\n      width,\n      name,\n      sortDirection,\n    } = column;\n    const headerElm = isSortable ? (\n      <SortableHeader\n        onSort={onSort}\n        name={name}\n        label={label}\n        sortDirection={sortDirection}\n        align={align}\n        currentlySortedByColumn={currentlySortedByColumn}\n      />\n    ) : (\n      <StyledHeaderLabel\n        size=\"xs\"\n        transform=\"uppercase\"\n        alignColumn={align}\n        variant=\"tertiary\"\n      >\n        {label}\n      </StyledHeaderLabel>\n    );\n\n    const ariaSortAttr = currentlySortedByColumn === name && {\n      \"aria-sort\": SORT_DIRECTION_TEXT[sortDirection],\n    };\n\n    return (\n      <StyledTh\n        as=\"th\"\n        alignColumn={align}\n        columnWidth={width}\n        key={name}\n        isFirstColumnSticky={isFirstColumnSticky}\n        isLastColumnSticky={isLastColumnSticky}\n        isTableScrolledToLeft={isTableScrolledToLeft}\n        isTableScrolledToRight={isTableScrolledToRight}\n        scope=\"col\"\n        {...ariaSortAttr}\n      >\n        {headerElm}\n      </StyledTh>\n    );\n  });\n\n  return (\n    <StyledThead className={className} maxHeight={maxHeight}>\n      <tr>{columnElements}</tr>\n    </StyledThead>\n  );\n}\n\nexport default React.memo(TableHeader);\n\n/* eslint-enable react/jsx-props-no-spreading */\n"],"names":[],"mappings":"AAsCiB"} */"),StyledHeaderLabel=(0,_styled.default)(_Text.Text,{target:"e1dmdg711",label:"StyledHeaderLabel"})(({theme,alignColumn})=>({fontWeight:theme.variables.weight.bold,lineHeight:theme.variables.size.lineHeight.m,letterSpacing:theme.variables.size.letterSpacing.s,...(0,_mediaQueries.useResponsiveValue)({textAlign:alignColumn})}),"/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"src/components/DataTable/TableHeader.tsx","sources":["src/components/DataTable/TableHeader.tsx"],"sourcesContent":["/* eslint-disable react/jsx-props-no-spreading */\n\nimport React, { useState } from \"react\";\nimport styled from \"@emotion/styled\";\nimport type { DataTableColumn } from \"./types\";\nimport { Text } from \"../Typography/Text/Text\";\nimport type { IconName } from \"../Icon/Icon\";\nimport { Icon } from \"../Icon/Icon\";\nimport type { TableCellProps } from \"./TableCell\";\nimport TableCell from \"./TableCell\";\nimport type { DataTableProps } from \"./DataTable\";\nimport { useResponsiveValue } from \"../../shared/mediaQueries\";\n\nexport type TableHeaderProps = {\n  className?: string;\n} & Pick<\n  DataTableProps,\n  | \"columns\"\n  | \"rows\"\n  | \"onSort\"\n  | \"currentlySortedByColumn\"\n  | \"isFirstColumnSticky\"\n  | \"isLastColumnSticky\"\n  | \"maxHeight\"\n> &\n  Pick<TableCellProps, \"isTableScrolledToLeft\" | \"isTableScrolledToRight\">;\n\nconst SORT_DIRECTION_ICON: Record<DataTableColumn[\"sortDirection\"], IconName> =\n  {\n    asc: \"sort-ascending\",\n    desc: \"sort-descending\",\n  };\n\nconst SORT_DIRECTION_TEXT = {\n  asc: \"ascending\" as const,\n  desc: \"descending\" as const,\n};\n\nconst SortIcon = styled.span(({ theme }) => ({\n  marginLeft: theme.variables.size.spacing.xxxs,\n  verticalAlign: \"middle\",\n  color: theme.values.color.text.primary.default,\n}));\n\ntype StyledHeaderLabelProps = {\n  alignColumn?: DataTableColumn[\"align\"];\n};\n\nconst StyledHeaderLabel = styled(Text)<StyledHeaderLabelProps>(\n  ({ theme, alignColumn }) => ({\n    fontWeight: theme.variables.weight.bold,\n    lineHeight: theme.variables.size.lineHeight.m,\n    letterSpacing: theme.variables.size.letterSpacing.s,\n    ...useResponsiveValue({\n      textAlign: alignColumn,\n    }),\n  })\n);\n\ntype StyledSortableHeaderProps = {\n  alignColumn: DataTableColumn[\"align\"];\n};\nconst StyledSortableHeader = styled.button<StyledSortableHeaderProps>(\n  ({ theme, alignColumn }) => ({\n    width: \"100%\",\n    height: theme.variables.size.lineHeight.m,\n    padding: 0,\n    background: \"none\",\n    border: \"none\",\n    cursor: \"pointer\",\n    ...useResponsiveValue({\n      textAlign: alignColumn,\n    }),\n\n    [`&:hover ${StyledHeaderLabel}`]: {\n      color: theme.values.color.text.primary.default,\n    },\n  })\n);\n\ntype SortableHeaderProps = Pick<\n  TableHeaderProps,\n  \"onSort\" | \"currentlySortedByColumn\"\n> &\n  DataTableColumn;\n\nfunction SortableHeader({\n  name,\n  label,\n  align,\n  sortDirection = \"asc\",\n  currentlySortedByColumn,\n  onSort,\n}: SortableHeaderProps): React.ReactElement {\n  const [hovered, setHovered] = useState(false);\n  const desiredSortDirection = sortDirection === \"asc\" ? \"desc\" : \"asc\";\n\n  const handleClick: React.MouseEventHandler = () => {\n    setHovered(false);\n    if (onSort) {\n      onSort(name, desiredSortDirection);\n    }\n  };\n\n  let iconName: IconName = \"sort-neutral\";\n\n  if (name === currentlySortedByColumn) {\n    iconName = SORT_DIRECTION_ICON[sortDirection];\n  }\n  if (hovered) {\n    iconName = SORT_DIRECTION_ICON[desiredSortDirection];\n  }\n\n  return (\n    <StyledSortableHeader\n      onClick={handleClick}\n      type=\"button\"\n      alignColumn={align}\n      onPointerEnter={() => setHovered(true)}\n      onPointerLeave={() => setHovered(false)}\n    >\n      <StyledHeaderLabel\n        as=\"span\"\n        size=\"xs\"\n        transform=\"uppercase\"\n        variant=\"tertiary\"\n      >\n        {label}\n      </StyledHeaderLabel>\n      <SortIcon aria-hidden=\"true\">\n        <Icon size=\"s\" name={iconName} inline />\n      </SortIcon>\n    </StyledSortableHeader>\n  );\n}\n\ntype StyledTheadProps = Pick<TableHeaderProps, \"maxHeight\">;\n\nconst StyledThead = styled.thead<StyledTheadProps>(({ maxHeight }) => ({\n  ...(maxHeight && {\n    position: \"sticky\",\n    top: 0,\n    zIndex: 1,\n  }),\n}));\n\nconst StyledTh = styled(TableCell)(({ theme }) => ({\n  padding: `${theme.variables.size.spacing.s} ${theme.variables.size.spacing.m}`,\n  whiteSpace: \"nowrap\",\n  backgroundColor: theme.values.color.background.primary.default,\n}));\n\nfunction TableHeader({\n  className,\n  columns,\n  isFirstColumnSticky,\n  isLastColumnSticky,\n  currentlySortedByColumn,\n  isTableScrolledToLeft,\n  isTableScrolledToRight,\n  maxHeight,\n  onSort,\n}: TableHeaderProps): React.ReactElement {\n  const columnElements = columns.map((column) => {\n    const {\n      isSortable,\n      label,\n      align = \"left\",\n      width,\n      name,\n      sortDirection,\n    } = column;\n    const headerElm = isSortable ? (\n      <SortableHeader\n        onSort={onSort}\n        name={name}\n        label={label}\n        sortDirection={sortDirection}\n        align={align}\n        currentlySortedByColumn={currentlySortedByColumn}\n      />\n    ) : (\n      <StyledHeaderLabel\n        size=\"xs\"\n        transform=\"uppercase\"\n        alignColumn={align}\n        variant=\"tertiary\"\n      >\n        {label}\n      </StyledHeaderLabel>\n    );\n\n    const ariaSortAttr = currentlySortedByColumn === name && {\n      \"aria-sort\": SORT_DIRECTION_TEXT[sortDirection],\n    };\n\n    return (\n      <StyledTh\n        as=\"th\"\n        alignColumn={align}\n        columnWidth={width}\n        key={name}\n        isFirstColumnSticky={isFirstColumnSticky}\n        isLastColumnSticky={isLastColumnSticky}\n        isTableScrolledToLeft={isTableScrolledToLeft}\n        isTableScrolledToRight={isTableScrolledToRight}\n        scope=\"col\"\n        {...ariaSortAttr}\n      >\n        {headerElm}\n      </StyledTh>\n    );\n  });\n\n  return (\n    <StyledThead className={className} maxHeight={maxHeight}>\n      <tr>{columnElements}</tr>\n    </StyledThead>\n  );\n}\n\nexport default React.memo(TableHeader);\n\n/* eslint-enable react/jsx-props-no-spreading */\n"],"names":[],"mappings":"AAgD0B"} */"),StyledSortableHeader=(0,_styled.default)("button",{target:"e1dmdg712",label:"StyledSortableHeader"})(({theme,alignColumn})=>({width:"100%",height:theme.variables.size.lineHeight.m,padding:0,background:"none",border:"none",cursor:"pointer",...(0,_mediaQueries.useResponsiveValue)({textAlign:alignColumn}),[`&:hover ${StyledHeaderLabel}`]:{color:theme.values.color.text.primary.default}}),"/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"src/components/DataTable/TableHeader.tsx","sources":["src/components/DataTable/TableHeader.tsx"],"sourcesContent":["/* eslint-disable react/jsx-props-no-spreading */\n\nimport React, { useState } from \"react\";\nimport styled from \"@emotion/styled\";\nimport type { DataTableColumn } from \"./types\";\nimport { Text } from \"../Typography/Text/Text\";\nimport type { IconName } from \"../Icon/Icon\";\nimport { Icon } from \"../Icon/Icon\";\nimport type { TableCellProps } from \"./TableCell\";\nimport TableCell from \"./TableCell\";\nimport type { DataTableProps } from \"./DataTable\";\nimport { useResponsiveValue } from \"../../shared/mediaQueries\";\n\nexport type TableHeaderProps = {\n  className?: string;\n} & Pick<\n  DataTableProps,\n  | \"columns\"\n  | \"rows\"\n  | \"onSort\"\n  | \"currentlySortedByColumn\"\n  | \"isFirstColumnSticky\"\n  | \"isLastColumnSticky\"\n  | \"maxHeight\"\n> &\n  Pick<TableCellProps, \"isTableScrolledToLeft\" | \"isTableScrolledToRight\">;\n\nconst SORT_DIRECTION_ICON: Record<DataTableColumn[\"sortDirection\"], IconName> =\n  {\n    asc: \"sort-ascending\",\n    desc: \"sort-descending\",\n  };\n\nconst SORT_DIRECTION_TEXT = {\n  asc: \"ascending\" as const,\n  desc: \"descending\" as const,\n};\n\nconst SortIcon = styled.span(({ theme }) => ({\n  marginLeft: theme.variables.size.spacing.xxxs,\n  verticalAlign: \"middle\",\n  color: theme.values.color.text.primary.default,\n}));\n\ntype StyledHeaderLabelProps = {\n  alignColumn?: DataTableColumn[\"align\"];\n};\n\nconst StyledHeaderLabel = styled(Text)<StyledHeaderLabelProps>(\n  ({ theme, alignColumn }) => ({\n    fontWeight: theme.variables.weight.bold,\n    lineHeight: theme.variables.size.lineHeight.m,\n    letterSpacing: theme.variables.size.letterSpacing.s,\n    ...useResponsiveValue({\n      textAlign: alignColumn,\n    }),\n  })\n);\n\ntype StyledSortableHeaderProps = {\n  alignColumn: DataTableColumn[\"align\"];\n};\nconst StyledSortableHeader = styled.button<StyledSortableHeaderProps>(\n  ({ theme, alignColumn }) => ({\n    width: \"100%\",\n    height: theme.variables.size.lineHeight.m,\n    padding: 0,\n    background: \"none\",\n    border: \"none\",\n    cursor: \"pointer\",\n    ...useResponsiveValue({\n      textAlign: alignColumn,\n    }),\n\n    [`&:hover ${StyledHeaderLabel}`]: {\n      color: theme.values.color.text.primary.default,\n    },\n  })\n);\n\ntype SortableHeaderProps = Pick<\n  TableHeaderProps,\n  \"onSort\" | \"currentlySortedByColumn\"\n> &\n  DataTableColumn;\n\nfunction SortableHeader({\n  name,\n  label,\n  align,\n  sortDirection = \"asc\",\n  currentlySortedByColumn,\n  onSort,\n}: SortableHeaderProps): React.ReactElement {\n  const [hovered, setHovered] = useState(false);\n  const desiredSortDirection = sortDirection === \"asc\" ? \"desc\" : \"asc\";\n\n  const handleClick: React.MouseEventHandler = () => {\n    setHovered(false);\n    if (onSort) {\n      onSort(name, desiredSortDirection);\n    }\n  };\n\n  let iconName: IconName = \"sort-neutral\";\n\n  if (name === currentlySortedByColumn) {\n    iconName = SORT_DIRECTION_ICON[sortDirection];\n  }\n  if (hovered) {\n    iconName = SORT_DIRECTION_ICON[desiredSortDirection];\n  }\n\n  return (\n    <StyledSortableHeader\n      onClick={handleClick}\n      type=\"button\"\n      alignColumn={align}\n      onPointerEnter={() => setHovered(true)}\n      onPointerLeave={() => setHovered(false)}\n    >\n      <StyledHeaderLabel\n        as=\"span\"\n        size=\"xs\"\n        transform=\"uppercase\"\n        variant=\"tertiary\"\n      >\n        {label}\n      </StyledHeaderLabel>\n      <SortIcon aria-hidden=\"true\">\n        <Icon size=\"s\" name={iconName} inline />\n      </SortIcon>\n    </StyledSortableHeader>\n  );\n}\n\ntype StyledTheadProps = Pick<TableHeaderProps, \"maxHeight\">;\n\nconst StyledThead = styled.thead<StyledTheadProps>(({ maxHeight }) => ({\n  ...(maxHeight && {\n    position: \"sticky\",\n    top: 0,\n    zIndex: 1,\n  }),\n}));\n\nconst StyledTh = styled(TableCell)(({ theme }) => ({\n  padding: `${theme.variables.size.spacing.s} ${theme.variables.size.spacing.m}`,\n  whiteSpace: \"nowrap\",\n  backgroundColor: theme.values.color.background.primary.default,\n}));\n\nfunction TableHeader({\n  className,\n  columns,\n  isFirstColumnSticky,\n  isLastColumnSticky,\n  currentlySortedByColumn,\n  isTableScrolledToLeft,\n  isTableScrolledToRight,\n  maxHeight,\n  onSort,\n}: TableHeaderProps): React.ReactElement {\n  const columnElements = columns.map((column) => {\n    const {\n      isSortable,\n      label,\n      align = \"left\",\n      width,\n      name,\n      sortDirection,\n    } = column;\n    const headerElm = isSortable ? (\n      <SortableHeader\n        onSort={onSort}\n        name={name}\n        label={label}\n        sortDirection={sortDirection}\n        align={align}\n        currentlySortedByColumn={currentlySortedByColumn}\n      />\n    ) : (\n      <StyledHeaderLabel\n        size=\"xs\"\n        transform=\"uppercase\"\n        alignColumn={align}\n        variant=\"tertiary\"\n      >\n        {label}\n      </StyledHeaderLabel>\n    );\n\n    const ariaSortAttr = currentlySortedByColumn === name && {\n      \"aria-sort\": SORT_DIRECTION_TEXT[sortDirection],\n    };\n\n    return (\n      <StyledTh\n        as=\"th\"\n        alignColumn={align}\n        columnWidth={width}\n        key={name}\n        isFirstColumnSticky={isFirstColumnSticky}\n        isLastColumnSticky={isLastColumnSticky}\n        isTableScrolledToLeft={isTableScrolledToLeft}\n        isTableScrolledToRight={isTableScrolledToRight}\n        scope=\"col\"\n        {...ariaSortAttr}\n      >\n        {headerElm}\n      </StyledTh>\n    );\n  });\n\n  return (\n    <StyledThead className={className} maxHeight={maxHeight}>\n      <tr>{columnElements}</tr>\n    </StyledThead>\n  );\n}\n\nexport default React.memo(TableHeader);\n\n/* eslint-enable react/jsx-props-no-spreading */\n"],"names":[],"mappings":"AA8D6B"} */");function SortableHeader({name,label,align,sortDirection="asc",currentlySortedByColumn,onSort}){let[hovered,setHovered]=(0,_react.useState)(!1),desiredSortDirection="asc"===sortDirection?"desc":"asc",iconName="sort-neutral";return name===currentlySortedByColumn&&(iconName=SORT_DIRECTION_ICON[sortDirection]),hovered&&(iconName=SORT_DIRECTION_ICON[desiredSortDirection]),_react.default.createElement(StyledSortableHeader,{onClick:()=>{setHovered(!1),onSort&&onSort(name,desiredSortDirection)},type:"button",alignColumn:align,onPointerEnter:()=>setHovered(!0),onPointerLeave:()=>setHovered(!1)},_react.default.createElement(StyledHeaderLabel,{as:"span",size:"xs",transform:"uppercase",variant:"tertiary"},label),_react.default.createElement(SortIcon,{"aria-hidden":"true"},_react.default.createElement(_Icon.Icon,{size:"s",name:iconName,inline:!0})))}const StyledThead=(0,_styled.default)("thead",{target:"e1dmdg713",label:"StyledThead"})(({maxHeight})=>({...maxHeight&&{position:"sticky",top:0,zIndex:1}}),"/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"src/components/DataTable/TableHeader.tsx","sources":["src/components/DataTable/TableHeader.tsx"],"sourcesContent":["/* eslint-disable react/jsx-props-no-spreading */\n\nimport React, { useState } from \"react\";\nimport styled from \"@emotion/styled\";\nimport type { DataTableColumn } from \"./types\";\nimport { Text } from \"../Typography/Text/Text\";\nimport type { IconName } from \"../Icon/Icon\";\nimport { Icon } from \"../Icon/Icon\";\nimport type { TableCellProps } from \"./TableCell\";\nimport TableCell from \"./TableCell\";\nimport type { DataTableProps } from \"./DataTable\";\nimport { useResponsiveValue } from \"../../shared/mediaQueries\";\n\nexport type TableHeaderProps = {\n  className?: string;\n} & Pick<\n  DataTableProps,\n  | \"columns\"\n  | \"rows\"\n  | \"onSort\"\n  | \"currentlySortedByColumn\"\n  | \"isFirstColumnSticky\"\n  | \"isLastColumnSticky\"\n  | \"maxHeight\"\n> &\n  Pick<TableCellProps, \"isTableScrolledToLeft\" | \"isTableScrolledToRight\">;\n\nconst SORT_DIRECTION_ICON: Record<DataTableColumn[\"sortDirection\"], IconName> =\n  {\n    asc: \"sort-ascending\",\n    desc: \"sort-descending\",\n  };\n\nconst SORT_DIRECTION_TEXT = {\n  asc: \"ascending\" as const,\n  desc: \"descending\" as const,\n};\n\nconst SortIcon = styled.span(({ theme }) => ({\n  marginLeft: theme.variables.size.spacing.xxxs,\n  verticalAlign: \"middle\",\n  color: theme.values.color.text.primary.default,\n}));\n\ntype StyledHeaderLabelProps = {\n  alignColumn?: DataTableColumn[\"align\"];\n};\n\nconst StyledHeaderLabel = styled(Text)<StyledHeaderLabelProps>(\n  ({ theme, alignColumn }) => ({\n    fontWeight: theme.variables.weight.bold,\n    lineHeight: theme.variables.size.lineHeight.m,\n    letterSpacing: theme.variables.size.letterSpacing.s,\n    ...useResponsiveValue({\n      textAlign: alignColumn,\n    }),\n  })\n);\n\ntype StyledSortableHeaderProps = {\n  alignColumn: DataTableColumn[\"align\"];\n};\nconst StyledSortableHeader = styled.button<StyledSortableHeaderProps>(\n  ({ theme, alignColumn }) => ({\n    width: \"100%\",\n    height: theme.variables.size.lineHeight.m,\n    padding: 0,\n    background: \"none\",\n    border: \"none\",\n    cursor: \"pointer\",\n    ...useResponsiveValue({\n      textAlign: alignColumn,\n    }),\n\n    [`&:hover ${StyledHeaderLabel}`]: {\n      color: theme.values.color.text.primary.default,\n    },\n  })\n);\n\ntype SortableHeaderProps = Pick<\n  TableHeaderProps,\n  \"onSort\" | \"currentlySortedByColumn\"\n> &\n  DataTableColumn;\n\nfunction SortableHeader({\n  name,\n  label,\n  align,\n  sortDirection = \"asc\",\n  currentlySortedByColumn,\n  onSort,\n}: SortableHeaderProps): React.ReactElement {\n  const [hovered, setHovered] = useState(false);\n  const desiredSortDirection = sortDirection === \"asc\" ? \"desc\" : \"asc\";\n\n  const handleClick: React.MouseEventHandler = () => {\n    setHovered(false);\n    if (onSort) {\n      onSort(name, desiredSortDirection);\n    }\n  };\n\n  let iconName: IconName = \"sort-neutral\";\n\n  if (name === currentlySortedByColumn) {\n    iconName = SORT_DIRECTION_ICON[sortDirection];\n  }\n  if (hovered) {\n    iconName = SORT_DIRECTION_ICON[desiredSortDirection];\n  }\n\n  return (\n    <StyledSortableHeader\n      onClick={handleClick}\n      type=\"button\"\n      alignColumn={align}\n      onPointerEnter={() => setHovered(true)}\n      onPointerLeave={() => setHovered(false)}\n    >\n      <StyledHeaderLabel\n        as=\"span\"\n        size=\"xs\"\n        transform=\"uppercase\"\n        variant=\"tertiary\"\n      >\n        {label}\n      </StyledHeaderLabel>\n      <SortIcon aria-hidden=\"true\">\n        <Icon size=\"s\" name={iconName} inline />\n      </SortIcon>\n    </StyledSortableHeader>\n  );\n}\n\ntype StyledTheadProps = Pick<TableHeaderProps, \"maxHeight\">;\n\nconst StyledThead = styled.thead<StyledTheadProps>(({ maxHeight }) => ({\n  ...(maxHeight && {\n    position: \"sticky\",\n    top: 0,\n    zIndex: 1,\n  }),\n}));\n\nconst StyledTh = styled(TableCell)(({ theme }) => ({\n  padding: `${theme.variables.size.spacing.s} ${theme.variables.size.spacing.m}`,\n  whiteSpace: \"nowrap\",\n  backgroundColor: theme.values.color.background.primary.default,\n}));\n\nfunction TableHeader({\n  className,\n  columns,\n  isFirstColumnSticky,\n  isLastColumnSticky,\n  currentlySortedByColumn,\n  isTableScrolledToLeft,\n  isTableScrolledToRight,\n  maxHeight,\n  onSort,\n}: TableHeaderProps): React.ReactElement {\n  const columnElements = columns.map((column) => {\n    const {\n      isSortable,\n      label,\n      align = \"left\",\n      width,\n      name,\n      sortDirection,\n    } = column;\n    const headerElm = isSortable ? (\n      <SortableHeader\n        onSort={onSort}\n        name={name}\n        label={label}\n        sortDirection={sortDirection}\n        align={align}\n        currentlySortedByColumn={currentlySortedByColumn}\n      />\n    ) : (\n      <StyledHeaderLabel\n        size=\"xs\"\n        transform=\"uppercase\"\n        alignColumn={align}\n        variant=\"tertiary\"\n      >\n        {label}\n      </StyledHeaderLabel>\n    );\n\n    const ariaSortAttr = currentlySortedByColumn === name && {\n      \"aria-sort\": SORT_DIRECTION_TEXT[sortDirection],\n    };\n\n    return (\n      <StyledTh\n        as=\"th\"\n        alignColumn={align}\n        columnWidth={width}\n        key={name}\n        isFirstColumnSticky={isFirstColumnSticky}\n        isLastColumnSticky={isLastColumnSticky}\n        isTableScrolledToLeft={isTableScrolledToLeft}\n        isTableScrolledToRight={isTableScrolledToRight}\n        scope=\"col\"\n        {...ariaSortAttr}\n      >\n        {headerElm}\n      </StyledTh>\n    );\n  });\n\n  return (\n    <StyledThead className={className} maxHeight={maxHeight}>\n      <tr>{columnElements}</tr>\n    </StyledThead>\n  );\n}\n\nexport default React.memo(TableHeader);\n\n/* eslint-enable react/jsx-props-no-spreading */\n"],"names":[],"mappings":"AA0IoB"} */"),StyledTh=(0,_styled.default)(_TableCell.default,{target:"e1dmdg714",label:"StyledTh"})(({theme})=>({padding:`${theme.variables.size.spacing.s} ${theme.variables.size.spacing.m}`,whiteSpace:"nowrap",backgroundColor:theme.values.color.background.primary.default}),"/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"src/components/DataTable/TableHeader.tsx","sources":["src/components/DataTable/TableHeader.tsx"],"sourcesContent":["/* eslint-disable react/jsx-props-no-spreading */\n\nimport React, { useState } from \"react\";\nimport styled from \"@emotion/styled\";\nimport type { DataTableColumn } from \"./types\";\nimport { Text } from \"../Typography/Text/Text\";\nimport type { IconName } from \"../Icon/Icon\";\nimport { Icon } from \"../Icon/Icon\";\nimport type { TableCellProps } from \"./TableCell\";\nimport TableCell from \"./TableCell\";\nimport type { DataTableProps } from \"./DataTable\";\nimport { useResponsiveValue } from \"../../shared/mediaQueries\";\n\nexport type TableHeaderProps = {\n  className?: string;\n} & Pick<\n  DataTableProps,\n  | \"columns\"\n  | \"rows\"\n  | \"onSort\"\n  | \"currentlySortedByColumn\"\n  | \"isFirstColumnSticky\"\n  | \"isLastColumnSticky\"\n  | \"maxHeight\"\n> &\n  Pick<TableCellProps, \"isTableScrolledToLeft\" | \"isTableScrolledToRight\">;\n\nconst SORT_DIRECTION_ICON: Record<DataTableColumn[\"sortDirection\"], IconName> =\n  {\n    asc: \"sort-ascending\",\n    desc: \"sort-descending\",\n  };\n\nconst SORT_DIRECTION_TEXT = {\n  asc: \"ascending\" as const,\n  desc: \"descending\" as const,\n};\n\nconst SortIcon = styled.span(({ theme }) => ({\n  marginLeft: theme.variables.size.spacing.xxxs,\n  verticalAlign: \"middle\",\n  color: theme.values.color.text.primary.default,\n}));\n\ntype StyledHeaderLabelProps = {\n  alignColumn?: DataTableColumn[\"align\"];\n};\n\nconst StyledHeaderLabel = styled(Text)<StyledHeaderLabelProps>(\n  ({ theme, alignColumn }) => ({\n    fontWeight: theme.variables.weight.bold,\n    lineHeight: theme.variables.size.lineHeight.m,\n    letterSpacing: theme.variables.size.letterSpacing.s,\n    ...useResponsiveValue({\n      textAlign: alignColumn,\n    }),\n  })\n);\n\ntype StyledSortableHeaderProps = {\n  alignColumn: DataTableColumn[\"align\"];\n};\nconst StyledSortableHeader = styled.button<StyledSortableHeaderProps>(\n  ({ theme, alignColumn }) => ({\n    width: \"100%\",\n    height: theme.variables.size.lineHeight.m,\n    padding: 0,\n    background: \"none\",\n    border: \"none\",\n    cursor: \"pointer\",\n    ...useResponsiveValue({\n      textAlign: alignColumn,\n    }),\n\n    [`&:hover ${StyledHeaderLabel}`]: {\n      color: theme.values.color.text.primary.default,\n    },\n  })\n);\n\ntype SortableHeaderProps = Pick<\n  TableHeaderProps,\n  \"onSort\" | \"currentlySortedByColumn\"\n> &\n  DataTableColumn;\n\nfunction SortableHeader({\n  name,\n  label,\n  align,\n  sortDirection = \"asc\",\n  currentlySortedByColumn,\n  onSort,\n}: SortableHeaderProps): React.ReactElement {\n  const [hovered, setHovered] = useState(false);\n  const desiredSortDirection = sortDirection === \"asc\" ? \"desc\" : \"asc\";\n\n  const handleClick: React.MouseEventHandler = () => {\n    setHovered(false);\n    if (onSort) {\n      onSort(name, desiredSortDirection);\n    }\n  };\n\n  let iconName: IconName = \"sort-neutral\";\n\n  if (name === currentlySortedByColumn) {\n    iconName = SORT_DIRECTION_ICON[sortDirection];\n  }\n  if (hovered) {\n    iconName = SORT_DIRECTION_ICON[desiredSortDirection];\n  }\n\n  return (\n    <StyledSortableHeader\n      onClick={handleClick}\n      type=\"button\"\n      alignColumn={align}\n      onPointerEnter={() => setHovered(true)}\n      onPointerLeave={() => setHovered(false)}\n    >\n      <StyledHeaderLabel\n        as=\"span\"\n        size=\"xs\"\n        transform=\"uppercase\"\n        variant=\"tertiary\"\n      >\n        {label}\n      </StyledHeaderLabel>\n      <SortIcon aria-hidden=\"true\">\n        <Icon size=\"s\" name={iconName} inline />\n      </SortIcon>\n    </StyledSortableHeader>\n  );\n}\n\ntype StyledTheadProps = Pick<TableHeaderProps, \"maxHeight\">;\n\nconst StyledThead = styled.thead<StyledTheadProps>(({ maxHeight }) => ({\n  ...(maxHeight && {\n    position: \"sticky\",\n    top: 0,\n    zIndex: 1,\n  }),\n}));\n\nconst StyledTh = styled(TableCell)(({ theme }) => ({\n  padding: `${theme.variables.size.spacing.s} ${theme.variables.size.spacing.m}`,\n  whiteSpace: \"nowrap\",\n  backgroundColor: theme.values.color.background.primary.default,\n}));\n\nfunction TableHeader({\n  className,\n  columns,\n  isFirstColumnSticky,\n  isLastColumnSticky,\n  currentlySortedByColumn,\n  isTableScrolledToLeft,\n  isTableScrolledToRight,\n  maxHeight,\n  onSort,\n}: TableHeaderProps): React.ReactElement {\n  const columnElements = columns.map((column) => {\n    const {\n      isSortable,\n      label,\n      align = \"left\",\n      width,\n      name,\n      sortDirection,\n    } = column;\n    const headerElm = isSortable ? (\n      <SortableHeader\n        onSort={onSort}\n        name={name}\n        label={label}\n        sortDirection={sortDirection}\n        align={align}\n        currentlySortedByColumn={currentlySortedByColumn}\n      />\n    ) : (\n      <StyledHeaderLabel\n        size=\"xs\"\n        transform=\"uppercase\"\n        alignColumn={align}\n        variant=\"tertiary\"\n      >\n        {label}\n      </StyledHeaderLabel>\n    );\n\n    const ariaSortAttr = currentlySortedByColumn === name && {\n      \"aria-sort\": SORT_DIRECTION_TEXT[sortDirection],\n    };\n\n    return (\n      <StyledTh\n        as=\"th\"\n        alignColumn={align}\n        columnWidth={width}\n        key={name}\n        isFirstColumnSticky={isFirstColumnSticky}\n        isLastColumnSticky={isLastColumnSticky}\n        isTableScrolledToLeft={isTableScrolledToLeft}\n        isTableScrolledToRight={isTableScrolledToRight}\n        scope=\"col\"\n        {...ariaSortAttr}\n      >\n        {headerElm}\n      </StyledTh>\n    );\n  });\n\n  return (\n    <StyledThead className={className} maxHeight={maxHeight}>\n      <tr>{columnElements}</tr>\n    </StyledThead>\n  );\n}\n\nexport default React.memo(TableHeader);\n\n/* eslint-enable react/jsx-props-no-spreading */\n"],"names":[],"mappings":"AAkJiB"} */"),_default=_react.default.memo(function({className,columns,isFirstColumnSticky,isLastColumnSticky,currentlySortedByColumn,isTableScrolledToLeft,isTableScrolledToRight,maxHeight,onSort}){let columnElements=columns.map(column=>{let{isSortable,label,align="left",width,name,sortDirection}=column,headerElm=isSortable?_react.default.createElement(SortableHeader,{onSort:onSort,name:name,label:label,sortDirection:sortDirection,align:align,currentlySortedByColumn:currentlySortedByColumn}):_react.default.createElement(StyledHeaderLabel,{size:"xs",transform:"uppercase",alignColumn:align,variant:"tertiary"},label),ariaSortAttr=currentlySortedByColumn===name&&{"aria-sort":SORT_DIRECTION_TEXT[sortDirection]};return _react.default.createElement(StyledTh,{as:"th",alignColumn:align,columnWidth:width,key:name,isFirstColumnSticky:isFirstColumnSticky,isLastColumnSticky:isLastColumnSticky,isTableScrolledToLeft:isTableScrolledToLeft,isTableScrolledToRight:isTableScrolledToRight,scope:"col",...ariaSortAttr},headerElm)});return _react.default.createElement(StyledThead,{className:className,maxHeight:maxHeight},_react.default.createElement("tr",null,columnElements))});
|
|
@@ -1,9 +0,0 @@
|
|
|
1
|
-
import React from "react";
|
|
2
|
-
import type { TableCellProps } from "./TableCell";
|
|
3
|
-
import type { DataTableProps } from "./DataTable";
|
|
4
|
-
export type TableHeaderProps = {
|
|
5
|
-
className?: string;
|
|
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
|
-
declare const _default: React.MemoExoticComponent<typeof TableHeader>;
|
|
9
|
-
export default _default;
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
import React,{useState}from"react";import styled from"@emotion/styled";import{Text}from"../Typography/Text/Text";import{Icon}from"../Icon/Icon";import TableCell from"./TableCell";import{useResponsiveValue}from"../../shared/mediaQueries";let SORT_DIRECTION_ICON={asc:"sort-ascending",desc:"sort-descending"},SORT_DIRECTION_TEXT={asc:"ascending",desc:"descending"},SortIcon=styled("span",{target:"e1dmdg710",label:"SortIcon"})(({theme})=>({marginLeft:theme.variables.size.spacing.xxxs,verticalAlign:"middle",color:theme.values.color.text.primary.default}),"/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"src/components/DataTable/TableHeader.tsx","sources":["src/components/DataTable/TableHeader.tsx"],"sourcesContent":["/* eslint-disable react/jsx-props-no-spreading */\n\nimport React, { useState } from \"react\";\nimport styled from \"@emotion/styled\";\nimport type { DataTableColumn } from \"./types\";\nimport { Text } from \"../Typography/Text/Text\";\nimport type { IconName } from \"../Icon/Icon\";\nimport { Icon } from \"../Icon/Icon\";\nimport type { TableCellProps } from \"./TableCell\";\nimport TableCell from \"./TableCell\";\nimport type { DataTableProps } from \"./DataTable\";\nimport { useResponsiveValue } from \"../../shared/mediaQueries\";\n\nexport type TableHeaderProps = {\n  className?: string;\n} & Pick<\n  DataTableProps,\n  | \"columns\"\n  | \"rows\"\n  | \"onSort\"\n  | \"currentlySortedByColumn\"\n  | \"isFirstColumnSticky\"\n  | \"isLastColumnSticky\"\n  | \"maxHeight\"\n> &\n  Pick<TableCellProps, \"isTableScrolledToLeft\" | \"isTableScrolledToRight\">;\n\nconst SORT_DIRECTION_ICON: Record<DataTableColumn[\"sortDirection\"], IconName> =\n  {\n    asc: \"sort-ascending\",\n    desc: \"sort-descending\",\n  };\n\nconst SORT_DIRECTION_TEXT = {\n  asc: \"ascending\" as const,\n  desc: \"descending\" as const,\n};\n\nconst SortIcon = styled.span(({ theme }) => ({\n  marginLeft: theme.variables.size.spacing.xxxs,\n  verticalAlign: \"middle\",\n  color: theme.values.color.text.primary.default,\n}));\n\ntype StyledHeaderLabelProps = {\n  alignColumn?: DataTableColumn[\"align\"];\n};\n\nconst StyledHeaderLabel = styled(Text)<StyledHeaderLabelProps>(\n  ({ theme, alignColumn }) => ({\n    fontWeight: theme.variables.weight.bold,\n    lineHeight: theme.variables.size.lineHeight.m,\n    letterSpacing: theme.variables.size.letterSpacing.s,\n    ...useResponsiveValue({\n      textAlign: alignColumn,\n    }),\n  })\n);\n\ntype StyledSortableHeaderProps = {\n  alignColumn: DataTableColumn[\"align\"];\n};\nconst StyledSortableHeader = styled.button<StyledSortableHeaderProps>(\n  ({ theme, alignColumn }) => ({\n    width: \"100%\",\n    height: theme.variables.size.lineHeight.m,\n    padding: 0,\n    background: \"none\",\n    border: \"none\",\n    cursor: \"pointer\",\n    ...useResponsiveValue({\n      textAlign: alignColumn,\n    }),\n\n    [`&:hover ${StyledHeaderLabel}`]: {\n      color: theme.values.color.text.primary.default,\n    },\n  })\n);\n\ntype SortableHeaderProps = Pick<\n  TableHeaderProps,\n  \"onSort\" | \"currentlySortedByColumn\"\n> &\n  DataTableColumn;\n\nfunction SortableHeader({\n  name,\n  label,\n  align,\n  sortDirection = \"asc\",\n  currentlySortedByColumn,\n  onSort,\n}: SortableHeaderProps): React.ReactElement {\n  const [hovered, setHovered] = useState(false);\n  const desiredSortDirection = sortDirection === \"asc\" ? \"desc\" : \"asc\";\n\n  const handleClick: React.MouseEventHandler = () => {\n    setHovered(false);\n    if (onSort) {\n      onSort(name, desiredSortDirection);\n    }\n  };\n\n  let iconName: IconName = \"sort-neutral\";\n\n  if (name === currentlySortedByColumn) {\n    iconName = SORT_DIRECTION_ICON[sortDirection];\n  }\n  if (hovered) {\n    iconName = SORT_DIRECTION_ICON[desiredSortDirection];\n  }\n\n  return (\n    <StyledSortableHeader\n      onClick={handleClick}\n      type=\"button\"\n      alignColumn={align}\n      onPointerEnter={() => setHovered(true)}\n      onPointerLeave={() => setHovered(false)}\n    >\n      <StyledHeaderLabel\n        as=\"span\"\n        size=\"xs\"\n        transform=\"uppercase\"\n        variant=\"tertiary\"\n      >\n        {label}\n      </StyledHeaderLabel>\n      <SortIcon aria-hidden=\"true\">\n        <Icon size=\"s\" name={iconName} inline />\n      </SortIcon>\n    </StyledSortableHeader>\n  );\n}\n\ntype StyledTheadProps = Pick<TableHeaderProps, \"maxHeight\">;\n\nconst StyledThead = styled.thead<StyledTheadProps>(({ maxHeight }) => ({\n  ...(maxHeight && {\n    position: \"sticky\",\n    top: 0,\n    zIndex: 1,\n  }),\n}));\n\nconst StyledTh = styled(TableCell)(({ theme }) => ({\n  padding: `${theme.variables.size.spacing.s} ${theme.variables.size.spacing.m}`,\n  whiteSpace: \"nowrap\",\n  backgroundColor: theme.values.color.background.primary.default,\n}));\n\nfunction TableHeader({\n  className,\n  columns,\n  isFirstColumnSticky,\n  isLastColumnSticky,\n  currentlySortedByColumn,\n  isTableScrolledToLeft,\n  isTableScrolledToRight,\n  maxHeight,\n  onSort,\n}: TableHeaderProps): React.ReactElement {\n  const columnElements = columns.map((column) => {\n    const {\n      isSortable,\n      label,\n      align = \"left\",\n      width,\n      name,\n      sortDirection,\n    } = column;\n    const headerElm = isSortable ? (\n      <SortableHeader\n        onSort={onSort}\n        name={name}\n        label={label}\n        sortDirection={sortDirection}\n        align={align}\n        currentlySortedByColumn={currentlySortedByColumn}\n      />\n    ) : (\n      <StyledHeaderLabel\n        size=\"xs\"\n        transform=\"uppercase\"\n        alignColumn={align}\n        variant=\"tertiary\"\n      >\n        {label}\n      </StyledHeaderLabel>\n    );\n\n    const ariaSortAttr = currentlySortedByColumn === name && {\n      \"aria-sort\": SORT_DIRECTION_TEXT[sortDirection],\n    };\n\n    return (\n      <StyledTh\n        as=\"th\"\n        alignColumn={align}\n        columnWidth={width}\n        key={name}\n        isFirstColumnSticky={isFirstColumnSticky}\n        isLastColumnSticky={isLastColumnSticky}\n        isTableScrolledToLeft={isTableScrolledToLeft}\n        isTableScrolledToRight={isTableScrolledToRight}\n        scope=\"col\"\n        {...ariaSortAttr}\n      >\n        {headerElm}\n      </StyledTh>\n    );\n  });\n\n  return (\n    <StyledThead className={className} maxHeight={maxHeight}>\n      <tr>{columnElements}</tr>\n    </StyledThead>\n  );\n}\n\nexport default React.memo(TableHeader);\n\n/* eslint-enable react/jsx-props-no-spreading */\n"],"names":[],"mappings":"AAsCiB"} */"),StyledHeaderLabel=styled(Text,{target:"e1dmdg711",label:"StyledHeaderLabel"})(({theme,alignColumn})=>({fontWeight:theme.variables.weight.bold,lineHeight:theme.variables.size.lineHeight.m,letterSpacing:theme.variables.size.letterSpacing.s,...useResponsiveValue({textAlign:alignColumn})}),"/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"src/components/DataTable/TableHeader.tsx","sources":["src/components/DataTable/TableHeader.tsx"],"sourcesContent":["/* eslint-disable react/jsx-props-no-spreading */\n\nimport React, { useState } from \"react\";\nimport styled from \"@emotion/styled\";\nimport type { DataTableColumn } from \"./types\";\nimport { Text } from \"../Typography/Text/Text\";\nimport type { IconName } from \"../Icon/Icon\";\nimport { Icon } from \"../Icon/Icon\";\nimport type { TableCellProps } from \"./TableCell\";\nimport TableCell from \"./TableCell\";\nimport type { DataTableProps } from \"./DataTable\";\nimport { useResponsiveValue } from \"../../shared/mediaQueries\";\n\nexport type TableHeaderProps = {\n  className?: string;\n} & Pick<\n  DataTableProps,\n  | \"columns\"\n  | \"rows\"\n  | \"onSort\"\n  | \"currentlySortedByColumn\"\n  | \"isFirstColumnSticky\"\n  | \"isLastColumnSticky\"\n  | \"maxHeight\"\n> &\n  Pick<TableCellProps, \"isTableScrolledToLeft\" | \"isTableScrolledToRight\">;\n\nconst SORT_DIRECTION_ICON: Record<DataTableColumn[\"sortDirection\"], IconName> =\n  {\n    asc: \"sort-ascending\",\n    desc: \"sort-descending\",\n  };\n\nconst SORT_DIRECTION_TEXT = {\n  asc: \"ascending\" as const,\n  desc: \"descending\" as const,\n};\n\nconst SortIcon = styled.span(({ theme }) => ({\n  marginLeft: theme.variables.size.spacing.xxxs,\n  verticalAlign: \"middle\",\n  color: theme.values.color.text.primary.default,\n}));\n\ntype StyledHeaderLabelProps = {\n  alignColumn?: DataTableColumn[\"align\"];\n};\n\nconst StyledHeaderLabel = styled(Text)<StyledHeaderLabelProps>(\n  ({ theme, alignColumn }) => ({\n    fontWeight: theme.variables.weight.bold,\n    lineHeight: theme.variables.size.lineHeight.m,\n    letterSpacing: theme.variables.size.letterSpacing.s,\n    ...useResponsiveValue({\n      textAlign: alignColumn,\n    }),\n  })\n);\n\ntype StyledSortableHeaderProps = {\n  alignColumn: DataTableColumn[\"align\"];\n};\nconst StyledSortableHeader = styled.button<StyledSortableHeaderProps>(\n  ({ theme, alignColumn }) => ({\n    width: \"100%\",\n    height: theme.variables.size.lineHeight.m,\n    padding: 0,\n    background: \"none\",\n    border: \"none\",\n    cursor: \"pointer\",\n    ...useResponsiveValue({\n      textAlign: alignColumn,\n    }),\n\n    [`&:hover ${StyledHeaderLabel}`]: {\n      color: theme.values.color.text.primary.default,\n    },\n  })\n);\n\ntype SortableHeaderProps = Pick<\n  TableHeaderProps,\n  \"onSort\" | \"currentlySortedByColumn\"\n> &\n  DataTableColumn;\n\nfunction SortableHeader({\n  name,\n  label,\n  align,\n  sortDirection = \"asc\",\n  currentlySortedByColumn,\n  onSort,\n}: SortableHeaderProps): React.ReactElement {\n  const [hovered, setHovered] = useState(false);\n  const desiredSortDirection = sortDirection === \"asc\" ? \"desc\" : \"asc\";\n\n  const handleClick: React.MouseEventHandler = () => {\n    setHovered(false);\n    if (onSort) {\n      onSort(name, desiredSortDirection);\n    }\n  };\n\n  let iconName: IconName = \"sort-neutral\";\n\n  if (name === currentlySortedByColumn) {\n    iconName = SORT_DIRECTION_ICON[sortDirection];\n  }\n  if (hovered) {\n    iconName = SORT_DIRECTION_ICON[desiredSortDirection];\n  }\n\n  return (\n    <StyledSortableHeader\n      onClick={handleClick}\n      type=\"button\"\n      alignColumn={align}\n      onPointerEnter={() => setHovered(true)}\n      onPointerLeave={() => setHovered(false)}\n    >\n      <StyledHeaderLabel\n        as=\"span\"\n        size=\"xs\"\n        transform=\"uppercase\"\n        variant=\"tertiary\"\n      >\n        {label}\n      </StyledHeaderLabel>\n      <SortIcon aria-hidden=\"true\">\n        <Icon size=\"s\" name={iconName} inline />\n      </SortIcon>\n    </StyledSortableHeader>\n  );\n}\n\ntype StyledTheadProps = Pick<TableHeaderProps, \"maxHeight\">;\n\nconst StyledThead = styled.thead<StyledTheadProps>(({ maxHeight }) => ({\n  ...(maxHeight && {\n    position: \"sticky\",\n    top: 0,\n    zIndex: 1,\n  }),\n}));\n\nconst StyledTh = styled(TableCell)(({ theme }) => ({\n  padding: `${theme.variables.size.spacing.s} ${theme.variables.size.spacing.m}`,\n  whiteSpace: \"nowrap\",\n  backgroundColor: theme.values.color.background.primary.default,\n}));\n\nfunction TableHeader({\n  className,\n  columns,\n  isFirstColumnSticky,\n  isLastColumnSticky,\n  currentlySortedByColumn,\n  isTableScrolledToLeft,\n  isTableScrolledToRight,\n  maxHeight,\n  onSort,\n}: TableHeaderProps): React.ReactElement {\n  const columnElements = columns.map((column) => {\n    const {\n      isSortable,\n      label,\n      align = \"left\",\n      width,\n      name,\n      sortDirection,\n    } = column;\n    const headerElm = isSortable ? (\n      <SortableHeader\n        onSort={onSort}\n        name={name}\n        label={label}\n        sortDirection={sortDirection}\n        align={align}\n        currentlySortedByColumn={currentlySortedByColumn}\n      />\n    ) : (\n      <StyledHeaderLabel\n        size=\"xs\"\n        transform=\"uppercase\"\n        alignColumn={align}\n        variant=\"tertiary\"\n      >\n        {label}\n      </StyledHeaderLabel>\n    );\n\n    const ariaSortAttr = currentlySortedByColumn === name && {\n      \"aria-sort\": SORT_DIRECTION_TEXT[sortDirection],\n    };\n\n    return (\n      <StyledTh\n        as=\"th\"\n        alignColumn={align}\n        columnWidth={width}\n        key={name}\n        isFirstColumnSticky={isFirstColumnSticky}\n        isLastColumnSticky={isLastColumnSticky}\n        isTableScrolledToLeft={isTableScrolledToLeft}\n        isTableScrolledToRight={isTableScrolledToRight}\n        scope=\"col\"\n        {...ariaSortAttr}\n      >\n        {headerElm}\n      </StyledTh>\n    );\n  });\n\n  return (\n    <StyledThead className={className} maxHeight={maxHeight}>\n      <tr>{columnElements}</tr>\n    </StyledThead>\n  );\n}\n\nexport default React.memo(TableHeader);\n\n/* eslint-enable react/jsx-props-no-spreading */\n"],"names":[],"mappings":"AAgD0B"} */"),StyledSortableHeader=styled("button",{target:"e1dmdg712",label:"StyledSortableHeader"})(({theme,alignColumn})=>({width:"100%",height:theme.variables.size.lineHeight.m,padding:0,background:"none",border:"none",cursor:"pointer",...useResponsiveValue({textAlign:alignColumn}),[`&:hover ${StyledHeaderLabel}`]:{color:theme.values.color.text.primary.default}}),"/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"src/components/DataTable/TableHeader.tsx","sources":["src/components/DataTable/TableHeader.tsx"],"sourcesContent":["/* eslint-disable react/jsx-props-no-spreading */\n\nimport React, { useState } from \"react\";\nimport styled from \"@emotion/styled\";\nimport type { DataTableColumn } from \"./types\";\nimport { Text } from \"../Typography/Text/Text\";\nimport type { IconName } from \"../Icon/Icon\";\nimport { Icon } from \"../Icon/Icon\";\nimport type { TableCellProps } from \"./TableCell\";\nimport TableCell from \"./TableCell\";\nimport type { DataTableProps } from \"./DataTable\";\nimport { useResponsiveValue } from \"../../shared/mediaQueries\";\n\nexport type TableHeaderProps = {\n  className?: string;\n} & Pick<\n  DataTableProps,\n  | \"columns\"\n  | \"rows\"\n  | \"onSort\"\n  | \"currentlySortedByColumn\"\n  | \"isFirstColumnSticky\"\n  | \"isLastColumnSticky\"\n  | \"maxHeight\"\n> &\n  Pick<TableCellProps, \"isTableScrolledToLeft\" | \"isTableScrolledToRight\">;\n\nconst SORT_DIRECTION_ICON: Record<DataTableColumn[\"sortDirection\"], IconName> =\n  {\n    asc: \"sort-ascending\",\n    desc: \"sort-descending\",\n  };\n\nconst SORT_DIRECTION_TEXT = {\n  asc: \"ascending\" as const,\n  desc: \"descending\" as const,\n};\n\nconst SortIcon = styled.span(({ theme }) => ({\n  marginLeft: theme.variables.size.spacing.xxxs,\n  verticalAlign: \"middle\",\n  color: theme.values.color.text.primary.default,\n}));\n\ntype StyledHeaderLabelProps = {\n  alignColumn?: DataTableColumn[\"align\"];\n};\n\nconst StyledHeaderLabel = styled(Text)<StyledHeaderLabelProps>(\n  ({ theme, alignColumn }) => ({\n    fontWeight: theme.variables.weight.bold,\n    lineHeight: theme.variables.size.lineHeight.m,\n    letterSpacing: theme.variables.size.letterSpacing.s,\n    ...useResponsiveValue({\n      textAlign: alignColumn,\n    }),\n  })\n);\n\ntype StyledSortableHeaderProps = {\n  alignColumn: DataTableColumn[\"align\"];\n};\nconst StyledSortableHeader = styled.button<StyledSortableHeaderProps>(\n  ({ theme, alignColumn }) => ({\n    width: \"100%\",\n    height: theme.variables.size.lineHeight.m,\n    padding: 0,\n    background: \"none\",\n    border: \"none\",\n    cursor: \"pointer\",\n    ...useResponsiveValue({\n      textAlign: alignColumn,\n    }),\n\n    [`&:hover ${StyledHeaderLabel}`]: {\n      color: theme.values.color.text.primary.default,\n    },\n  })\n);\n\ntype SortableHeaderProps = Pick<\n  TableHeaderProps,\n  \"onSort\" | \"currentlySortedByColumn\"\n> &\n  DataTableColumn;\n\nfunction SortableHeader({\n  name,\n  label,\n  align,\n  sortDirection = \"asc\",\n  currentlySortedByColumn,\n  onSort,\n}: SortableHeaderProps): React.ReactElement {\n  const [hovered, setHovered] = useState(false);\n  const desiredSortDirection = sortDirection === \"asc\" ? \"desc\" : \"asc\";\n\n  const handleClick: React.MouseEventHandler = () => {\n    setHovered(false);\n    if (onSort) {\n      onSort(name, desiredSortDirection);\n    }\n  };\n\n  let iconName: IconName = \"sort-neutral\";\n\n  if (name === currentlySortedByColumn) {\n    iconName = SORT_DIRECTION_ICON[sortDirection];\n  }\n  if (hovered) {\n    iconName = SORT_DIRECTION_ICON[desiredSortDirection];\n  }\n\n  return (\n    <StyledSortableHeader\n      onClick={handleClick}\n      type=\"button\"\n      alignColumn={align}\n      onPointerEnter={() => setHovered(true)}\n      onPointerLeave={() => setHovered(false)}\n    >\n      <StyledHeaderLabel\n        as=\"span\"\n        size=\"xs\"\n        transform=\"uppercase\"\n        variant=\"tertiary\"\n      >\n        {label}\n      </StyledHeaderLabel>\n      <SortIcon aria-hidden=\"true\">\n        <Icon size=\"s\" name={iconName} inline />\n      </SortIcon>\n    </StyledSortableHeader>\n  );\n}\n\ntype StyledTheadProps = Pick<TableHeaderProps, \"maxHeight\">;\n\nconst StyledThead = styled.thead<StyledTheadProps>(({ maxHeight }) => ({\n  ...(maxHeight && {\n    position: \"sticky\",\n    top: 0,\n    zIndex: 1,\n  }),\n}));\n\nconst StyledTh = styled(TableCell)(({ theme }) => ({\n  padding: `${theme.variables.size.spacing.s} ${theme.variables.size.spacing.m}`,\n  whiteSpace: \"nowrap\",\n  backgroundColor: theme.values.color.background.primary.default,\n}));\n\nfunction TableHeader({\n  className,\n  columns,\n  isFirstColumnSticky,\n  isLastColumnSticky,\n  currentlySortedByColumn,\n  isTableScrolledToLeft,\n  isTableScrolledToRight,\n  maxHeight,\n  onSort,\n}: TableHeaderProps): React.ReactElement {\n  const columnElements = columns.map((column) => {\n    const {\n      isSortable,\n      label,\n      align = \"left\",\n      width,\n      name,\n      sortDirection,\n    } = column;\n    const headerElm = isSortable ? (\n      <SortableHeader\n        onSort={onSort}\n        name={name}\n        label={label}\n        sortDirection={sortDirection}\n        align={align}\n        currentlySortedByColumn={currentlySortedByColumn}\n      />\n    ) : (\n      <StyledHeaderLabel\n        size=\"xs\"\n        transform=\"uppercase\"\n        alignColumn={align}\n        variant=\"tertiary\"\n      >\n        {label}\n      </StyledHeaderLabel>\n    );\n\n    const ariaSortAttr = currentlySortedByColumn === name && {\n      \"aria-sort\": SORT_DIRECTION_TEXT[sortDirection],\n    };\n\n    return (\n      <StyledTh\n        as=\"th\"\n        alignColumn={align}\n        columnWidth={width}\n        key={name}\n        isFirstColumnSticky={isFirstColumnSticky}\n        isLastColumnSticky={isLastColumnSticky}\n        isTableScrolledToLeft={isTableScrolledToLeft}\n        isTableScrolledToRight={isTableScrolledToRight}\n        scope=\"col\"\n        {...ariaSortAttr}\n      >\n        {headerElm}\n      </StyledTh>\n    );\n  });\n\n  return (\n    <StyledThead className={className} maxHeight={maxHeight}>\n      <tr>{columnElements}</tr>\n    </StyledThead>\n  );\n}\n\nexport default React.memo(TableHeader);\n\n/* eslint-enable react/jsx-props-no-spreading */\n"],"names":[],"mappings":"AA8D6B"} */");function SortableHeader({name,label,align,sortDirection="asc",currentlySortedByColumn,onSort}){let[hovered,setHovered]=useState(!1),desiredSortDirection="asc"===sortDirection?"desc":"asc",iconName="sort-neutral";return name===currentlySortedByColumn&&(iconName=SORT_DIRECTION_ICON[sortDirection]),hovered&&(iconName=SORT_DIRECTION_ICON[desiredSortDirection]),React.createElement(StyledSortableHeader,{onClick:()=>{setHovered(!1),onSort&&onSort(name,desiredSortDirection)},type:"button",alignColumn:align,onPointerEnter:()=>setHovered(!0),onPointerLeave:()=>setHovered(!1)},React.createElement(StyledHeaderLabel,{as:"span",size:"xs",transform:"uppercase",variant:"tertiary"},label),React.createElement(SortIcon,{"aria-hidden":"true"},React.createElement(Icon,{size:"s",name:iconName,inline:!0})))}let StyledThead=styled("thead",{target:"e1dmdg713",label:"StyledThead"})(({maxHeight})=>({...maxHeight&&{position:"sticky",top:0,zIndex:1}}),"/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"src/components/DataTable/TableHeader.tsx","sources":["src/components/DataTable/TableHeader.tsx"],"sourcesContent":["/* eslint-disable react/jsx-props-no-spreading */\n\nimport React, { useState } from \"react\";\nimport styled from \"@emotion/styled\";\nimport type { DataTableColumn } from \"./types\";\nimport { Text } from \"../Typography/Text/Text\";\nimport type { IconName } from \"../Icon/Icon\";\nimport { Icon } from \"../Icon/Icon\";\nimport type { TableCellProps } from \"./TableCell\";\nimport TableCell from \"./TableCell\";\nimport type { DataTableProps } from \"./DataTable\";\nimport { useResponsiveValue } from \"../../shared/mediaQueries\";\n\nexport type TableHeaderProps = {\n  className?: string;\n} & Pick<\n  DataTableProps,\n  | \"columns\"\n  | \"rows\"\n  | \"onSort\"\n  | \"currentlySortedByColumn\"\n  | \"isFirstColumnSticky\"\n  | \"isLastColumnSticky\"\n  | \"maxHeight\"\n> &\n  Pick<TableCellProps, \"isTableScrolledToLeft\" | \"isTableScrolledToRight\">;\n\nconst SORT_DIRECTION_ICON: Record<DataTableColumn[\"sortDirection\"], IconName> =\n  {\n    asc: \"sort-ascending\",\n    desc: \"sort-descending\",\n  };\n\nconst SORT_DIRECTION_TEXT = {\n  asc: \"ascending\" as const,\n  desc: \"descending\" as const,\n};\n\nconst SortIcon = styled.span(({ theme }) => ({\n  marginLeft: theme.variables.size.spacing.xxxs,\n  verticalAlign: \"middle\",\n  color: theme.values.color.text.primary.default,\n}));\n\ntype StyledHeaderLabelProps = {\n  alignColumn?: DataTableColumn[\"align\"];\n};\n\nconst StyledHeaderLabel = styled(Text)<StyledHeaderLabelProps>(\n  ({ theme, alignColumn }) => ({\n    fontWeight: theme.variables.weight.bold,\n    lineHeight: theme.variables.size.lineHeight.m,\n    letterSpacing: theme.variables.size.letterSpacing.s,\n    ...useResponsiveValue({\n      textAlign: alignColumn,\n    }),\n  })\n);\n\ntype StyledSortableHeaderProps = {\n  alignColumn: DataTableColumn[\"align\"];\n};\nconst StyledSortableHeader = styled.button<StyledSortableHeaderProps>(\n  ({ theme, alignColumn }) => ({\n    width: \"100%\",\n    height: theme.variables.size.lineHeight.m,\n    padding: 0,\n    background: \"none\",\n    border: \"none\",\n    cursor: \"pointer\",\n    ...useResponsiveValue({\n      textAlign: alignColumn,\n    }),\n\n    [`&:hover ${StyledHeaderLabel}`]: {\n      color: theme.values.color.text.primary.default,\n    },\n  })\n);\n\ntype SortableHeaderProps = Pick<\n  TableHeaderProps,\n  \"onSort\" | \"currentlySortedByColumn\"\n> &\n  DataTableColumn;\n\nfunction SortableHeader({\n  name,\n  label,\n  align,\n  sortDirection = \"asc\",\n  currentlySortedByColumn,\n  onSort,\n}: SortableHeaderProps): React.ReactElement {\n  const [hovered, setHovered] = useState(false);\n  const desiredSortDirection = sortDirection === \"asc\" ? \"desc\" : \"asc\";\n\n  const handleClick: React.MouseEventHandler = () => {\n    setHovered(false);\n    if (onSort) {\n      onSort(name, desiredSortDirection);\n    }\n  };\n\n  let iconName: IconName = \"sort-neutral\";\n\n  if (name === currentlySortedByColumn) {\n    iconName = SORT_DIRECTION_ICON[sortDirection];\n  }\n  if (hovered) {\n    iconName = SORT_DIRECTION_ICON[desiredSortDirection];\n  }\n\n  return (\n    <StyledSortableHeader\n      onClick={handleClick}\n      type=\"button\"\n      alignColumn={align}\n      onPointerEnter={() => setHovered(true)}\n      onPointerLeave={() => setHovered(false)}\n    >\n      <StyledHeaderLabel\n        as=\"span\"\n        size=\"xs\"\n        transform=\"uppercase\"\n        variant=\"tertiary\"\n      >\n        {label}\n      </StyledHeaderLabel>\n      <SortIcon aria-hidden=\"true\">\n        <Icon size=\"s\" name={iconName} inline />\n      </SortIcon>\n    </StyledSortableHeader>\n  );\n}\n\ntype StyledTheadProps = Pick<TableHeaderProps, \"maxHeight\">;\n\nconst StyledThead = styled.thead<StyledTheadProps>(({ maxHeight }) => ({\n  ...(maxHeight && {\n    position: \"sticky\",\n    top: 0,\n    zIndex: 1,\n  }),\n}));\n\nconst StyledTh = styled(TableCell)(({ theme }) => ({\n  padding: `${theme.variables.size.spacing.s} ${theme.variables.size.spacing.m}`,\n  whiteSpace: \"nowrap\",\n  backgroundColor: theme.values.color.background.primary.default,\n}));\n\nfunction TableHeader({\n  className,\n  columns,\n  isFirstColumnSticky,\n  isLastColumnSticky,\n  currentlySortedByColumn,\n  isTableScrolledToLeft,\n  isTableScrolledToRight,\n  maxHeight,\n  onSort,\n}: TableHeaderProps): React.ReactElement {\n  const columnElements = columns.map((column) => {\n    const {\n      isSortable,\n      label,\n      align = \"left\",\n      width,\n      name,\n      sortDirection,\n    } = column;\n    const headerElm = isSortable ? (\n      <SortableHeader\n        onSort={onSort}\n        name={name}\n        label={label}\n        sortDirection={sortDirection}\n        align={align}\n        currentlySortedByColumn={currentlySortedByColumn}\n      />\n    ) : (\n      <StyledHeaderLabel\n        size=\"xs\"\n        transform=\"uppercase\"\n        alignColumn={align}\n        variant=\"tertiary\"\n      >\n        {label}\n      </StyledHeaderLabel>\n    );\n\n    const ariaSortAttr = currentlySortedByColumn === name && {\n      \"aria-sort\": SORT_DIRECTION_TEXT[sortDirection],\n    };\n\n    return (\n      <StyledTh\n        as=\"th\"\n        alignColumn={align}\n        columnWidth={width}\n        key={name}\n        isFirstColumnSticky={isFirstColumnSticky}\n        isLastColumnSticky={isLastColumnSticky}\n        isTableScrolledToLeft={isTableScrolledToLeft}\n        isTableScrolledToRight={isTableScrolledToRight}\n        scope=\"col\"\n        {...ariaSortAttr}\n      >\n        {headerElm}\n      </StyledTh>\n    );\n  });\n\n  return (\n    <StyledThead className={className} maxHeight={maxHeight}>\n      <tr>{columnElements}</tr>\n    </StyledThead>\n  );\n}\n\nexport default React.memo(TableHeader);\n\n/* eslint-enable react/jsx-props-no-spreading */\n"],"names":[],"mappings":"AA0IoB"} */"),StyledTh=styled(TableCell,{target:"e1dmdg714",label:"StyledTh"})(({theme})=>({padding:`${theme.variables.size.spacing.s} ${theme.variables.size.spacing.m}`,whiteSpace:"nowrap",backgroundColor:theme.values.color.background.primary.default}),"/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"src/components/DataTable/TableHeader.tsx","sources":["src/components/DataTable/TableHeader.tsx"],"sourcesContent":["/* eslint-disable react/jsx-props-no-spreading */\n\nimport React, { useState } from \"react\";\nimport styled from \"@emotion/styled\";\nimport type { DataTableColumn } from \"./types\";\nimport { Text } from \"../Typography/Text/Text\";\nimport type { IconName } from \"../Icon/Icon\";\nimport { Icon } from \"../Icon/Icon\";\nimport type { TableCellProps } from \"./TableCell\";\nimport TableCell from \"./TableCell\";\nimport type { DataTableProps } from \"./DataTable\";\nimport { useResponsiveValue } from \"../../shared/mediaQueries\";\n\nexport type TableHeaderProps = {\n  className?: string;\n} & Pick<\n  DataTableProps,\n  | \"columns\"\n  | \"rows\"\n  | \"onSort\"\n  | \"currentlySortedByColumn\"\n  | \"isFirstColumnSticky\"\n  | \"isLastColumnSticky\"\n  | \"maxHeight\"\n> &\n  Pick<TableCellProps, \"isTableScrolledToLeft\" | \"isTableScrolledToRight\">;\n\nconst SORT_DIRECTION_ICON: Record<DataTableColumn[\"sortDirection\"], IconName> =\n  {\n    asc: \"sort-ascending\",\n    desc: \"sort-descending\",\n  };\n\nconst SORT_DIRECTION_TEXT = {\n  asc: \"ascending\" as const,\n  desc: \"descending\" as const,\n};\n\nconst SortIcon = styled.span(({ theme }) => ({\n  marginLeft: theme.variables.size.spacing.xxxs,\n  verticalAlign: \"middle\",\n  color: theme.values.color.text.primary.default,\n}));\n\ntype StyledHeaderLabelProps = {\n  alignColumn?: DataTableColumn[\"align\"];\n};\n\nconst StyledHeaderLabel = styled(Text)<StyledHeaderLabelProps>(\n  ({ theme, alignColumn }) => ({\n    fontWeight: theme.variables.weight.bold,\n    lineHeight: theme.variables.size.lineHeight.m,\n    letterSpacing: theme.variables.size.letterSpacing.s,\n    ...useResponsiveValue({\n      textAlign: alignColumn,\n    }),\n  })\n);\n\ntype StyledSortableHeaderProps = {\n  alignColumn: DataTableColumn[\"align\"];\n};\nconst StyledSortableHeader = styled.button<StyledSortableHeaderProps>(\n  ({ theme, alignColumn }) => ({\n    width: \"100%\",\n    height: theme.variables.size.lineHeight.m,\n    padding: 0,\n    background: \"none\",\n    border: \"none\",\n    cursor: \"pointer\",\n    ...useResponsiveValue({\n      textAlign: alignColumn,\n    }),\n\n    [`&:hover ${StyledHeaderLabel}`]: {\n      color: theme.values.color.text.primary.default,\n    },\n  })\n);\n\ntype SortableHeaderProps = Pick<\n  TableHeaderProps,\n  \"onSort\" | \"currentlySortedByColumn\"\n> &\n  DataTableColumn;\n\nfunction SortableHeader({\n  name,\n  label,\n  align,\n  sortDirection = \"asc\",\n  currentlySortedByColumn,\n  onSort,\n}: SortableHeaderProps): React.ReactElement {\n  const [hovered, setHovered] = useState(false);\n  const desiredSortDirection = sortDirection === \"asc\" ? \"desc\" : \"asc\";\n\n  const handleClick: React.MouseEventHandler = () => {\n    setHovered(false);\n    if (onSort) {\n      onSort(name, desiredSortDirection);\n    }\n  };\n\n  let iconName: IconName = \"sort-neutral\";\n\n  if (name === currentlySortedByColumn) {\n    iconName = SORT_DIRECTION_ICON[sortDirection];\n  }\n  if (hovered) {\n    iconName = SORT_DIRECTION_ICON[desiredSortDirection];\n  }\n\n  return (\n    <StyledSortableHeader\n      onClick={handleClick}\n      type=\"button\"\n      alignColumn={align}\n      onPointerEnter={() => setHovered(true)}\n      onPointerLeave={() => setHovered(false)}\n    >\n      <StyledHeaderLabel\n        as=\"span\"\n        size=\"xs\"\n        transform=\"uppercase\"\n        variant=\"tertiary\"\n      >\n        {label}\n      </StyledHeaderLabel>\n      <SortIcon aria-hidden=\"true\">\n        <Icon size=\"s\" name={iconName} inline />\n      </SortIcon>\n    </StyledSortableHeader>\n  );\n}\n\ntype StyledTheadProps = Pick<TableHeaderProps, \"maxHeight\">;\n\nconst StyledThead = styled.thead<StyledTheadProps>(({ maxHeight }) => ({\n  ...(maxHeight && {\n    position: \"sticky\",\n    top: 0,\n    zIndex: 1,\n  }),\n}));\n\nconst StyledTh = styled(TableCell)(({ theme }) => ({\n  padding: `${theme.variables.size.spacing.s} ${theme.variables.size.spacing.m}`,\n  whiteSpace: \"nowrap\",\n  backgroundColor: theme.values.color.background.primary.default,\n}));\n\nfunction TableHeader({\n  className,\n  columns,\n  isFirstColumnSticky,\n  isLastColumnSticky,\n  currentlySortedByColumn,\n  isTableScrolledToLeft,\n  isTableScrolledToRight,\n  maxHeight,\n  onSort,\n}: TableHeaderProps): React.ReactElement {\n  const columnElements = columns.map((column) => {\n    const {\n      isSortable,\n      label,\n      align = \"left\",\n      width,\n      name,\n      sortDirection,\n    } = column;\n    const headerElm = isSortable ? (\n      <SortableHeader\n        onSort={onSort}\n        name={name}\n        label={label}\n        sortDirection={sortDirection}\n        align={align}\n        currentlySortedByColumn={currentlySortedByColumn}\n      />\n    ) : (\n      <StyledHeaderLabel\n        size=\"xs\"\n        transform=\"uppercase\"\n        alignColumn={align}\n        variant=\"tertiary\"\n      >\n        {label}\n      </StyledHeaderLabel>\n    );\n\n    const ariaSortAttr = currentlySortedByColumn === name && {\n      \"aria-sort\": SORT_DIRECTION_TEXT[sortDirection],\n    };\n\n    return (\n      <StyledTh\n        as=\"th\"\n        alignColumn={align}\n        columnWidth={width}\n        key={name}\n        isFirstColumnSticky={isFirstColumnSticky}\n        isLastColumnSticky={isLastColumnSticky}\n        isTableScrolledToLeft={isTableScrolledToLeft}\n        isTableScrolledToRight={isTableScrolledToRight}\n        scope=\"col\"\n        {...ariaSortAttr}\n      >\n        {headerElm}\n      </StyledTh>\n    );\n  });\n\n  return (\n    <StyledThead className={className} maxHeight={maxHeight}>\n      <tr>{columnElements}</tr>\n    </StyledThead>\n  );\n}\n\nexport default React.memo(TableHeader);\n\n/* eslint-enable react/jsx-props-no-spreading */\n"],"names":[],"mappings":"AAkJiB"} */");export default React.memo(function({className,columns,isFirstColumnSticky,isLastColumnSticky,currentlySortedByColumn,isTableScrolledToLeft,isTableScrolledToRight,maxHeight,onSort}){let columnElements=columns.map(column=>{let{isSortable,label,align="left",width,name,sortDirection}=column,headerElm=isSortable?React.createElement(SortableHeader,{onSort:onSort,name:name,label:label,sortDirection:sortDirection,align:align,currentlySortedByColumn:currentlySortedByColumn}):React.createElement(StyledHeaderLabel,{size:"xs",transform:"uppercase",alignColumn:align,variant:"tertiary"},label),ariaSortAttr=currentlySortedByColumn===name&&{"aria-sort":SORT_DIRECTION_TEXT[sortDirection]};return React.createElement(StyledTh,{as:"th",alignColumn:align,columnWidth:width,key:name,isFirstColumnSticky:isFirstColumnSticky,isLastColumnSticky:isLastColumnSticky,isTableScrolledToLeft:isTableScrolledToLeft,isTableScrolledToRight:isTableScrolledToRight,scope:"col",...ariaSortAttr},headerElm)});return React.createElement(StyledThead,{className:className,maxHeight:maxHeight},React.createElement("tr",null,columnElements))});
|