@amboss/design-system 3.24.3 → 3.25.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/AccessCardItem/AccessCardItem.js +1 -1
- package/build/cjs/components/Badge/Badge.js +1 -1
- package/build/cjs/components/Container/Container.js +1 -1
- package/build/cjs/components/DataTable/DataTable.d.ts +2 -2
- package/build/cjs/components/DataTable/DataTable.js +1 -1
- package/build/cjs/components/DataTable/TableBody.js +1 -1
- package/build/cjs/components/IconTile/IconTile.js +1 -1
- package/build/cjs/components/NavBar/NavBarSearchInput.js +1 -1
- package/build/cjs/shared/useIsMacOS.d.ts +1 -0
- package/build/cjs/shared/useIsMacOS.js +1 -0
- package/build/cjs/web-tokens/assets/icons.json +1 -0
- package/build/cjs/web-tokens/assets/icons16.json +1 -0
- package/build/esm/components/AccessCardItem/AccessCardItem.js +1 -1
- package/build/esm/components/Badge/Badge.js +1 -1
- package/build/esm/components/Container/Container.js +1 -1
- package/build/esm/components/DataTable/DataTable.d.ts +2 -2
- package/build/esm/components/DataTable/DataTable.js +1 -1
- package/build/esm/components/DataTable/TableBody.js +1 -1
- package/build/esm/components/IconTile/IconTile.js +1 -1
- package/build/esm/components/NavBar/NavBarSearchInput.js +1 -1
- package/build/esm/shared/useIsMacOS.d.ts +1 -0
- package/build/esm/shared/useIsMacOS.js +1 -0
- 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
|
@@ -1 +1 @@
|
|
|
1
|
-
import React from"react";import styled from"@emotion/styled";import TableCell from"./TableCell";import{Text}from"../Typography/Text/Text";import{LoadingSpinner}from"../LoadingSpinner/LoadingSpinner";import{useResponsiveStyles,useResponsiveValue}from"../../shared/mediaQueries";import{Checkbox}from"../Form/Checkbox/Checkbox";import{CHECKBOX_COLUMN}from"./constants";let StyledTr=styled("tr",{target:"e6k8n1r0",label:"StyledTr"})(({theme,footer,isSelected,verticalAlign})=>({...!isSelected&&{"&:hover td":{backgroundColor:theme.values.color.background.secondary.default}},verticalAlign,...!footer&&{"&:last-of-type":{td:{borderBottom:"none"}}}}),"/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"src/components/DataTable/TableBody.tsx","sources":["src/components/DataTable/TableBody.tsx"],"sourcesContent":["/* eslint-disable react/jsx-no-useless-fragment */\nimport type { ChangeEventHandler } from \"react\";\nimport React from \"react\";\nimport styled from \"@emotion/styled\";\nimport type { DataTableColumn, DataTableRow, DataTableRowProps } from \"./types\";\nimport type { TableCellProps } from \"./TableCell\";\nimport TableCell from \"./TableCell\";\nimport { Text } from \"../Typography/Text/Text\";\nimport type { DataTableProps } from \"./DataTable\";\nimport { LoadingSpinner } from \"../LoadingSpinner/LoadingSpinner\";\nimport {\n  useResponsiveStyles,\n  useResponsiveValue,\n} from \"../../shared/mediaQueries\";\nimport { Checkbox } from \"../Form/Checkbox/Checkbox\";\nimport { CHECKBOX_COLUMN } from \"./constants\";\n\nexport type TableBodyProps = {\n  className?: string;\n} & Pick<\n  DataTableProps,\n  | \"columns\"\n  | \"rows\"\n  | \"isLoading\"\n  | \"loadingStateScreenReaderText\"\n  | \"isEmpty\"\n  | \"emptyTableContentHeight\"\n  | \"bodyCellVerticalPadding\"\n  | \"footer\"\n  | \"isFirstColumnSticky\"\n  | \"isLastColumnSticky\"\n  | \"emptyCellContent\"\n  | \"selectedRowIds\"\n  | \"onRowSelectionChange\"\n  | \"getRowProps\"\n> &\n  Pick<TableCellProps, \"isTableScrolledToLeft\" | \"isTableScrolledToRight\">;\n\ntype StyledTrProps = {\n  isSelected?: boolean;\n} & Pick<TableBodyProps, \"footer\"> &\n  Pick<DataTableRowProps, \"verticalAlign\">;\n\nconst StyledTr = styled.tr<StyledTrProps>(\n  ({ theme, footer, isSelected, verticalAlign }) => ({\n    ...(!isSelected && {\n      \"&:hover td\": {\n        backgroundColor: theme.values.color.background.secondary.default,\n      },\n    }),\n\n    verticalAlign,\n\n    ...(!footer && {\n      \"&:last-of-type\": {\n        td: {\n          borderBottom: \"none\",\n        },\n      },\n    }),\n  })\n);\n\ntype StyledTextProps = {\n  alignColumn?: DataTableColumn[\"align\"];\n};\n\nconst StyledText = styled(Text)<StyledTextProps>(({ alignColumn }) => ({\n  ...useResponsiveValue({\n    textAlign: alignColumn,\n  }),\n}));\n\ntype StyledTdProps = TableCellProps &\n  Pick<\n    TableBodyProps,\n    \"isFirstColumnSticky\" | \"isLastColumnSticky\" | \"bodyCellVerticalPadding\"\n  >;\n\nconst StyledTd = styled(TableCell)<StyledTdProps>(\n  ({ theme, bodyCellVerticalPadding }) => ({\n    ...useResponsiveStyles({\n      padding: [\n        bodyCellVerticalPadding,\n        {\n          s: `${theme.variables.size.spacing.s} ${theme.variables.size.spacing.m}`,\n          m: `${theme.variables.size.spacing.m} ${theme.variables.size.spacing.m}`,\n          l: `${theme.variables.size.spacing.l} ${theme.variables.size.spacing.m}`,\n        } as any,\n      ],\n    }),\n  })\n);\n\ntype EmptyTableBodyProps = Pick<\n  TableBodyProps,\n  \"columns\" | \"emptyTableContentHeight\"\n> & {\n  children: React.ReactElement;\n};\n\ntype StyledEmptyTdProps = Pick<EmptyTableBodyProps, \"emptyTableContentHeight\">;\n\nconst StyledEmptyTd = styled.td<StyledEmptyTdProps>(\n  ({ emptyTableContentHeight }) => ({\n    textAlign: \"center\",\n    ...useResponsiveValue({\n      height: emptyTableContentHeight,\n    }),\n  })\n);\n\nfunction EmptyTableBody({\n  children,\n  columns,\n  emptyTableContentHeight,\n}: EmptyTableBodyProps): React.ReactElement {\n  return (\n    <tbody>\n      <tr>\n        <StyledEmptyTd\n          colSpan={columns.length}\n          emptyTableContentHeight={emptyTableContentHeight}\n        >\n          {children}\n        </StyledEmptyTd>\n      </tr>\n    </tbody>\n  );\n}\n\ntype CheckboxColumnCellContentProps = Pick<DataTableRow, \"id\"> &\n  Pick<TableBodyProps, \"selectedRowIds\" | \"onRowSelectionChange\"> &\n  Pick<DataTableRowProps, \"isSelectable\" | \"selectRowCheckboxAriaLabel\">;\n\nfunction CheckboxColumnCellContent({\n  selectRowCheckboxAriaLabel,\n  selectedRowIds,\n  onRowSelectionChange,\n  id,\n  isSelectable,\n}: CheckboxColumnCellContentProps): React.ReactElement {\n  const toggleRowSelection: ChangeEventHandler<HTMLInputElement> = (evt) => {\n    if (evt.target.checked) {\n      onRowSelectionChange([...selectedRowIds, id]);\n    } else {\n      onRowSelectionChange(selectedRowIds.filter((item) => item !== id));\n    }\n  };\n\n  return (\n    <Checkbox\n      size=\"s\"\n      aria-label={selectRowCheckboxAriaLabel}\n      checked={selectedRowIds.includes(id)}\n      disabled={!isSelectable}\n      onChange={toggleRowSelection}\n    />\n  );\n}\n\nfunction TableBody({\n  className,\n  columns,\n  rows = [],\n  bodyCellVerticalPadding,\n  isTableScrolledToLeft,\n  isTableScrolledToRight,\n  isLoading,\n  loadingStateScreenReaderText = \"Loading\",\n  isEmpty,\n  emptyTableContentHeight,\n  footer,\n  children,\n  isFirstColumnSticky,\n  isLastColumnSticky,\n  emptyCellContent,\n  selectedRowIds,\n  onRowSelectionChange,\n  getRowProps,\n}: React.PropsWithChildren<TableBodyProps>): React.ReactElement {\n  if (isLoading) {\n    const customLoadingContent = children && <>{children}</>;\n    const bodyContent = customLoadingContent || (\n      <LoadingSpinner screenReaderText={loadingStateScreenReaderText} />\n    );\n\n    return (\n      <EmptyTableBody\n        columns={columns}\n        emptyTableContentHeight={emptyTableContentHeight}\n      >\n        {bodyContent}\n      </EmptyTableBody>\n    );\n  }\n\n  if (isEmpty) {\n    return (\n      <EmptyTableBody\n        columns={columns}\n        emptyTableContentHeight={emptyTableContentHeight}\n      >\n        <>{children}</>\n      </EmptyTableBody>\n    );\n  }\n\n  const rowElements = rows.map((row) => {\n    const {\n      verticalAlign = null,\n      isActive = false,\n      isSelectable = true,\n      selectRowCheckboxAriaLabel = `Select row${row.id}`,\n    } = getRowProps?.(row) || {};\n    const isSelected = selectedRowIds.includes(row.id);\n\n    return (\n      <StyledTr\n        key={row.id}\n        footer={footer}\n        verticalAlign={verticalAlign}\n        isSelected={isSelected}\n      >\n        {columns.map(({ name, align = \"left\", renderCell }) => {\n          let content;\n          if (renderCell) {\n            content = renderCell(row);\n          } else if (name === CHECKBOX_COLUMN.name) {\n            content = (\n              <CheckboxColumnCellContent\n                selectRowCheckboxAriaLabel={selectRowCheckboxAriaLabel}\n                selectedRowIds={selectedRowIds}\n                onRowSelectionChange={onRowSelectionChange}\n                id={row.id}\n                isSelectable={isSelectable}\n              />\n            );\n          } else {\n            content = (\n              <StyledText size=\"s\" alignColumn={align}>\n                {row[name] ? row[name] : emptyCellContent}\n              </StyledText>\n            );\n          }\n\n          return (\n            <StyledTd\n              key={name}\n              alignColumn={align}\n              isFirstColumnSticky={isFirstColumnSticky}\n              isLastColumnSticky={isLastColumnSticky}\n              bodyCellVerticalPadding={bodyCellVerticalPadding}\n              isTableScrolledToLeft={isTableScrolledToLeft}\n              isTableScrolledToRight={isTableScrolledToRight}\n              isActive={isActive}\n              isSelected={isSelected}\n            >\n              {content}\n            </StyledTd>\n          );\n        })}\n      </StyledTr>\n    );\n  });\n\n  return <tbody className={className}>{rowElements}</tbody>;\n}\n\nexport default React.memo(TableBody);\n"],"names":[],"mappings":"AA2CiB"} */"),StyledText=styled(Text,{target:"e6k8n1r1",label:"StyledText"})(({alignColumn})=>({...useResponsiveValue({textAlign:alignColumn})}),"/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"src/components/DataTable/TableBody.tsx","sources":["src/components/DataTable/TableBody.tsx"],"sourcesContent":["/* eslint-disable react/jsx-no-useless-fragment */\nimport type { ChangeEventHandler } from \"react\";\nimport React from \"react\";\nimport styled from \"@emotion/styled\";\nimport type { DataTableColumn, DataTableRow, DataTableRowProps } from \"./types\";\nimport type { TableCellProps } from \"./TableCell\";\nimport TableCell from \"./TableCell\";\nimport { Text } from \"../Typography/Text/Text\";\nimport type { DataTableProps } from \"./DataTable\";\nimport { LoadingSpinner } from \"../LoadingSpinner/LoadingSpinner\";\nimport {\n  useResponsiveStyles,\n  useResponsiveValue,\n} from \"../../shared/mediaQueries\";\nimport { Checkbox } from \"../Form/Checkbox/Checkbox\";\nimport { CHECKBOX_COLUMN } from \"./constants\";\n\nexport type TableBodyProps = {\n  className?: string;\n} & Pick<\n  DataTableProps,\n  | \"columns\"\n  | \"rows\"\n  | \"isLoading\"\n  | \"loadingStateScreenReaderText\"\n  | \"isEmpty\"\n  | \"emptyTableContentHeight\"\n  | \"bodyCellVerticalPadding\"\n  | \"footer\"\n  | \"isFirstColumnSticky\"\n  | \"isLastColumnSticky\"\n  | \"emptyCellContent\"\n  | \"selectedRowIds\"\n  | \"onRowSelectionChange\"\n  | \"getRowProps\"\n> &\n  Pick<TableCellProps, \"isTableScrolledToLeft\" | \"isTableScrolledToRight\">;\n\ntype StyledTrProps = {\n  isSelected?: boolean;\n} & Pick<TableBodyProps, \"footer\"> &\n  Pick<DataTableRowProps, \"verticalAlign\">;\n\nconst StyledTr = styled.tr<StyledTrProps>(\n  ({ theme, footer, isSelected, verticalAlign }) => ({\n    ...(!isSelected && {\n      \"&:hover td\": {\n        backgroundColor: theme.values.color.background.secondary.default,\n      },\n    }),\n\n    verticalAlign,\n\n    ...(!footer && {\n      \"&:last-of-type\": {\n        td: {\n          borderBottom: \"none\",\n        },\n      },\n    }),\n  })\n);\n\ntype StyledTextProps = {\n  alignColumn?: DataTableColumn[\"align\"];\n};\n\nconst StyledText = styled(Text)<StyledTextProps>(({ alignColumn }) => ({\n  ...useResponsiveValue({\n    textAlign: alignColumn,\n  }),\n}));\n\ntype StyledTdProps = TableCellProps &\n  Pick<\n    TableBodyProps,\n    \"isFirstColumnSticky\" | \"isLastColumnSticky\" | \"bodyCellVerticalPadding\"\n  >;\n\nconst StyledTd = styled(TableCell)<StyledTdProps>(\n  ({ theme, bodyCellVerticalPadding }) => ({\n    ...useResponsiveStyles({\n      padding: [\n        bodyCellVerticalPadding,\n        {\n          s: `${theme.variables.size.spacing.s} ${theme.variables.size.spacing.m}`,\n          m: `${theme.variables.size.spacing.m} ${theme.variables.size.spacing.m}`,\n          l: `${theme.variables.size.spacing.l} ${theme.variables.size.spacing.m}`,\n        } as any,\n      ],\n    }),\n  })\n);\n\ntype EmptyTableBodyProps = Pick<\n  TableBodyProps,\n  \"columns\" | \"emptyTableContentHeight\"\n> & {\n  children: React.ReactElement;\n};\n\ntype StyledEmptyTdProps = Pick<EmptyTableBodyProps, \"emptyTableContentHeight\">;\n\nconst StyledEmptyTd = styled.td<StyledEmptyTdProps>(\n  ({ emptyTableContentHeight }) => ({\n    textAlign: \"center\",\n    ...useResponsiveValue({\n      height: emptyTableContentHeight,\n    }),\n  })\n);\n\nfunction EmptyTableBody({\n  children,\n  columns,\n  emptyTableContentHeight,\n}: EmptyTableBodyProps): React.ReactElement {\n  return (\n    <tbody>\n      <tr>\n        <StyledEmptyTd\n          colSpan={columns.length}\n          emptyTableContentHeight={emptyTableContentHeight}\n        >\n          {children}\n        </StyledEmptyTd>\n      </tr>\n    </tbody>\n  );\n}\n\ntype CheckboxColumnCellContentProps = Pick<DataTableRow, \"id\"> &\n  Pick<TableBodyProps, \"selectedRowIds\" | \"onRowSelectionChange\"> &\n  Pick<DataTableRowProps, \"isSelectable\" | \"selectRowCheckboxAriaLabel\">;\n\nfunction CheckboxColumnCellContent({\n  selectRowCheckboxAriaLabel,\n  selectedRowIds,\n  onRowSelectionChange,\n  id,\n  isSelectable,\n}: CheckboxColumnCellContentProps): React.ReactElement {\n  const toggleRowSelection: ChangeEventHandler<HTMLInputElement> = (evt) => {\n    if (evt.target.checked) {\n      onRowSelectionChange([...selectedRowIds, id]);\n    } else {\n      onRowSelectionChange(selectedRowIds.filter((item) => item !== id));\n    }\n  };\n\n  return (\n    <Checkbox\n      size=\"s\"\n      aria-label={selectRowCheckboxAriaLabel}\n      checked={selectedRowIds.includes(id)}\n      disabled={!isSelectable}\n      onChange={toggleRowSelection}\n    />\n  );\n}\n\nfunction TableBody({\n  className,\n  columns,\n  rows = [],\n  bodyCellVerticalPadding,\n  isTableScrolledToLeft,\n  isTableScrolledToRight,\n  isLoading,\n  loadingStateScreenReaderText = \"Loading\",\n  isEmpty,\n  emptyTableContentHeight,\n  footer,\n  children,\n  isFirstColumnSticky,\n  isLastColumnSticky,\n  emptyCellContent,\n  selectedRowIds,\n  onRowSelectionChange,\n  getRowProps,\n}: React.PropsWithChildren<TableBodyProps>): React.ReactElement {\n  if (isLoading) {\n    const customLoadingContent = children && <>{children}</>;\n    const bodyContent = customLoadingContent || (\n      <LoadingSpinner screenReaderText={loadingStateScreenReaderText} />\n    );\n\n    return (\n      <EmptyTableBody\n        columns={columns}\n        emptyTableContentHeight={emptyTableContentHeight}\n      >\n        {bodyContent}\n      </EmptyTableBody>\n    );\n  }\n\n  if (isEmpty) {\n    return (\n      <EmptyTableBody\n        columns={columns}\n        emptyTableContentHeight={emptyTableContentHeight}\n      >\n        <>{children}</>\n      </EmptyTableBody>\n    );\n  }\n\n  const rowElements = rows.map((row) => {\n    const {\n      verticalAlign = null,\n      isActive = false,\n      isSelectable = true,\n      selectRowCheckboxAriaLabel = `Select row${row.id}`,\n    } = getRowProps?.(row) || {};\n    const isSelected = selectedRowIds.includes(row.id);\n\n    return (\n      <StyledTr\n        key={row.id}\n        footer={footer}\n        verticalAlign={verticalAlign}\n        isSelected={isSelected}\n      >\n        {columns.map(({ name, align = \"left\", renderCell }) => {\n          let content;\n          if (renderCell) {\n            content = renderCell(row);\n          } else if (name === CHECKBOX_COLUMN.name) {\n            content = (\n              <CheckboxColumnCellContent\n                selectRowCheckboxAriaLabel={selectRowCheckboxAriaLabel}\n                selectedRowIds={selectedRowIds}\n                onRowSelectionChange={onRowSelectionChange}\n                id={row.id}\n                isSelectable={isSelectable}\n              />\n            );\n          } else {\n            content = (\n              <StyledText size=\"s\" alignColumn={align}>\n                {row[name] ? row[name] : emptyCellContent}\n              </StyledText>\n            );\n          }\n\n          return (\n            <StyledTd\n              key={name}\n              alignColumn={align}\n              isFirstColumnSticky={isFirstColumnSticky}\n              isLastColumnSticky={isLastColumnSticky}\n              bodyCellVerticalPadding={bodyCellVerticalPadding}\n              isTableScrolledToLeft={isTableScrolledToLeft}\n              isTableScrolledToRight={isTableScrolledToRight}\n              isActive={isActive}\n              isSelected={isSelected}\n            >\n              {content}\n            </StyledTd>\n          );\n        })}\n      </StyledTr>\n    );\n  });\n\n  return <tbody className={className}>{rowElements}</tbody>;\n}\n\nexport default React.memo(TableBody);\n"],"names":[],"mappings":"AAmEmB"} */"),StyledTd=styled(TableCell,{target:"e6k8n1r2",label:"StyledTd"})(({theme,bodyCellVerticalPadding})=>({...useResponsiveStyles({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,{"version":3,"file":"src/components/DataTable/TableBody.tsx","sources":["src/components/DataTable/TableBody.tsx"],"sourcesContent":["/* eslint-disable react/jsx-no-useless-fragment */\nimport type { ChangeEventHandler } from \"react\";\nimport React from \"react\";\nimport styled from \"@emotion/styled\";\nimport type { DataTableColumn, DataTableRow, DataTableRowProps } from \"./types\";\nimport type { TableCellProps } from \"./TableCell\";\nimport TableCell from \"./TableCell\";\nimport { Text } from \"../Typography/Text/Text\";\nimport type { DataTableProps } from \"./DataTable\";\nimport { LoadingSpinner } from \"../LoadingSpinner/LoadingSpinner\";\nimport {\n  useResponsiveStyles,\n  useResponsiveValue,\n} from \"../../shared/mediaQueries\";\nimport { Checkbox } from \"../Form/Checkbox/Checkbox\";\nimport { CHECKBOX_COLUMN } from \"./constants\";\n\nexport type TableBodyProps = {\n  className?: string;\n} & Pick<\n  DataTableProps,\n  | \"columns\"\n  | \"rows\"\n  | \"isLoading\"\n  | \"loadingStateScreenReaderText\"\n  | \"isEmpty\"\n  | \"emptyTableContentHeight\"\n  | \"bodyCellVerticalPadding\"\n  | \"footer\"\n  | \"isFirstColumnSticky\"\n  | \"isLastColumnSticky\"\n  | \"emptyCellContent\"\n  | \"selectedRowIds\"\n  | \"onRowSelectionChange\"\n  | \"getRowProps\"\n> &\n  Pick<TableCellProps, \"isTableScrolledToLeft\" | \"isTableScrolledToRight\">;\n\ntype StyledTrProps = {\n  isSelected?: boolean;\n} & Pick<TableBodyProps, \"footer\"> &\n  Pick<DataTableRowProps, \"verticalAlign\">;\n\nconst StyledTr = styled.tr<StyledTrProps>(\n  ({ theme, footer, isSelected, verticalAlign }) => ({\n    ...(!isSelected && {\n      \"&:hover td\": {\n        backgroundColor: theme.values.color.background.secondary.default,\n      },\n    }),\n\n    verticalAlign,\n\n    ...(!footer && {\n      \"&:last-of-type\": {\n        td: {\n          borderBottom: \"none\",\n        },\n      },\n    }),\n  })\n);\n\ntype StyledTextProps = {\n  alignColumn?: DataTableColumn[\"align\"];\n};\n\nconst StyledText = styled(Text)<StyledTextProps>(({ alignColumn }) => ({\n  ...useResponsiveValue({\n    textAlign: alignColumn,\n  }),\n}));\n\ntype StyledTdProps = TableCellProps &\n  Pick<\n    TableBodyProps,\n    \"isFirstColumnSticky\" | \"isLastColumnSticky\" | \"bodyCellVerticalPadding\"\n  >;\n\nconst StyledTd = styled(TableCell)<StyledTdProps>(\n  ({ theme, bodyCellVerticalPadding }) => ({\n    ...useResponsiveStyles({\n      padding: [\n        bodyCellVerticalPadding,\n        {\n          s: `${theme.variables.size.spacing.s} ${theme.variables.size.spacing.m}`,\n          m: `${theme.variables.size.spacing.m} ${theme.variables.size.spacing.m}`,\n          l: `${theme.variables.size.spacing.l} ${theme.variables.size.spacing.m}`,\n        } as any,\n      ],\n    }),\n  })\n);\n\ntype EmptyTableBodyProps = Pick<\n  TableBodyProps,\n  \"columns\" | \"emptyTableContentHeight\"\n> & {\n  children: React.ReactElement;\n};\n\ntype StyledEmptyTdProps = Pick<EmptyTableBodyProps, \"emptyTableContentHeight\">;\n\nconst StyledEmptyTd = styled.td<StyledEmptyTdProps>(\n  ({ emptyTableContentHeight }) => ({\n    textAlign: \"center\",\n    ...useResponsiveValue({\n      height: emptyTableContentHeight,\n    }),\n  })\n);\n\nfunction EmptyTableBody({\n  children,\n  columns,\n  emptyTableContentHeight,\n}: EmptyTableBodyProps): React.ReactElement {\n  return (\n    <tbody>\n      <tr>\n        <StyledEmptyTd\n          colSpan={columns.length}\n          emptyTableContentHeight={emptyTableContentHeight}\n        >\n          {children}\n        </StyledEmptyTd>\n      </tr>\n    </tbody>\n  );\n}\n\ntype CheckboxColumnCellContentProps = Pick<DataTableRow, \"id\"> &\n  Pick<TableBodyProps, \"selectedRowIds\" | \"onRowSelectionChange\"> &\n  Pick<DataTableRowProps, \"isSelectable\" | \"selectRowCheckboxAriaLabel\">;\n\nfunction CheckboxColumnCellContent({\n  selectRowCheckboxAriaLabel,\n  selectedRowIds,\n  onRowSelectionChange,\n  id,\n  isSelectable,\n}: CheckboxColumnCellContentProps): React.ReactElement {\n  const toggleRowSelection: ChangeEventHandler<HTMLInputElement> = (evt) => {\n    if (evt.target.checked) {\n      onRowSelectionChange([...selectedRowIds, id]);\n    } else {\n      onRowSelectionChange(selectedRowIds.filter((item) => item !== id));\n    }\n  };\n\n  return (\n    <Checkbox\n      size=\"s\"\n      aria-label={selectRowCheckboxAriaLabel}\n      checked={selectedRowIds.includes(id)}\n      disabled={!isSelectable}\n      onChange={toggleRowSelection}\n    />\n  );\n}\n\nfunction TableBody({\n  className,\n  columns,\n  rows = [],\n  bodyCellVerticalPadding,\n  isTableScrolledToLeft,\n  isTableScrolledToRight,\n  isLoading,\n  loadingStateScreenReaderText = \"Loading\",\n  isEmpty,\n  emptyTableContentHeight,\n  footer,\n  children,\n  isFirstColumnSticky,\n  isLastColumnSticky,\n  emptyCellContent,\n  selectedRowIds,\n  onRowSelectionChange,\n  getRowProps,\n}: React.PropsWithChildren<TableBodyProps>): React.ReactElement {\n  if (isLoading) {\n    const customLoadingContent = children && <>{children}</>;\n    const bodyContent = customLoadingContent || (\n      <LoadingSpinner screenReaderText={loadingStateScreenReaderText} />\n    );\n\n    return (\n      <EmptyTableBody\n        columns={columns}\n        emptyTableContentHeight={emptyTableContentHeight}\n      >\n        {bodyContent}\n      </EmptyTableBody>\n    );\n  }\n\n  if (isEmpty) {\n    return (\n      <EmptyTableBody\n        columns={columns}\n        emptyTableContentHeight={emptyTableContentHeight}\n      >\n        <>{children}</>\n      </EmptyTableBody>\n    );\n  }\n\n  const rowElements = rows.map((row) => {\n    const {\n      verticalAlign = null,\n      isActive = false,\n      isSelectable = true,\n      selectRowCheckboxAriaLabel = `Select row${row.id}`,\n    } = getRowProps?.(row) || {};\n    const isSelected = selectedRowIds.includes(row.id);\n\n    return (\n      <StyledTr\n        key={row.id}\n        footer={footer}\n        verticalAlign={verticalAlign}\n        isSelected={isSelected}\n      >\n        {columns.map(({ name, align = \"left\", renderCell }) => {\n          let content;\n          if (renderCell) {\n            content = renderCell(row);\n          } else if (name === CHECKBOX_COLUMN.name) {\n            content = (\n              <CheckboxColumnCellContent\n                selectRowCheckboxAriaLabel={selectRowCheckboxAriaLabel}\n                selectedRowIds={selectedRowIds}\n                onRowSelectionChange={onRowSelectionChange}\n                id={row.id}\n                isSelectable={isSelectable}\n              />\n            );\n          } else {\n            content = (\n              <StyledText size=\"s\" alignColumn={align}>\n                {row[name] ? row[name] : emptyCellContent}\n              </StyledText>\n            );\n          }\n\n          return (\n            <StyledTd\n              key={name}\n              alignColumn={align}\n              isFirstColumnSticky={isFirstColumnSticky}\n              isLastColumnSticky={isLastColumnSticky}\n              bodyCellVerticalPadding={bodyCellVerticalPadding}\n              isTableScrolledToLeft={isTableScrolledToLeft}\n              isTableScrolledToRight={isTableScrolledToRight}\n              isActive={isActive}\n              isSelected={isSelected}\n            >\n              {content}\n            </StyledTd>\n          );\n        })}\n      </StyledTr>\n    );\n  });\n\n  return <tbody className={className}>{rowElements}</tbody>;\n}\n\nexport default React.memo(TableBody);\n"],"names":[],"mappings":"AA+EiB"} */"),StyledEmptyTd=styled("td",{target:"e6k8n1r3",label:"StyledEmptyTd"})(({emptyTableContentHeight})=>({textAlign:"center",...useResponsiveValue({height:emptyTableContentHeight})}),"/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"src/components/DataTable/TableBody.tsx","sources":["src/components/DataTable/TableBody.tsx"],"sourcesContent":["/* eslint-disable react/jsx-no-useless-fragment */\nimport type { ChangeEventHandler } from \"react\";\nimport React from \"react\";\nimport styled from \"@emotion/styled\";\nimport type { DataTableColumn, DataTableRow, DataTableRowProps } from \"./types\";\nimport type { TableCellProps } from \"./TableCell\";\nimport TableCell from \"./TableCell\";\nimport { Text } from \"../Typography/Text/Text\";\nimport type { DataTableProps } from \"./DataTable\";\nimport { LoadingSpinner } from \"../LoadingSpinner/LoadingSpinner\";\nimport {\n  useResponsiveStyles,\n  useResponsiveValue,\n} from \"../../shared/mediaQueries\";\nimport { Checkbox } from \"../Form/Checkbox/Checkbox\";\nimport { CHECKBOX_COLUMN } from \"./constants\";\n\nexport type TableBodyProps = {\n  className?: string;\n} & Pick<\n  DataTableProps,\n  | \"columns\"\n  | \"rows\"\n  | \"isLoading\"\n  | \"loadingStateScreenReaderText\"\n  | \"isEmpty\"\n  | \"emptyTableContentHeight\"\n  | \"bodyCellVerticalPadding\"\n  | \"footer\"\n  | \"isFirstColumnSticky\"\n  | \"isLastColumnSticky\"\n  | \"emptyCellContent\"\n  | \"selectedRowIds\"\n  | \"onRowSelectionChange\"\n  | \"getRowProps\"\n> &\n  Pick<TableCellProps, \"isTableScrolledToLeft\" | \"isTableScrolledToRight\">;\n\ntype StyledTrProps = {\n  isSelected?: boolean;\n} & Pick<TableBodyProps, \"footer\"> &\n  Pick<DataTableRowProps, \"verticalAlign\">;\n\nconst StyledTr = styled.tr<StyledTrProps>(\n  ({ theme, footer, isSelected, verticalAlign }) => ({\n    ...(!isSelected && {\n      \"&:hover td\": {\n        backgroundColor: theme.values.color.background.secondary.default,\n      },\n    }),\n\n    verticalAlign,\n\n    ...(!footer && {\n      \"&:last-of-type\": {\n        td: {\n          borderBottom: \"none\",\n        },\n      },\n    }),\n  })\n);\n\ntype StyledTextProps = {\n  alignColumn?: DataTableColumn[\"align\"];\n};\n\nconst StyledText = styled(Text)<StyledTextProps>(({ alignColumn }) => ({\n  ...useResponsiveValue({\n    textAlign: alignColumn,\n  }),\n}));\n\ntype StyledTdProps = TableCellProps &\n  Pick<\n    TableBodyProps,\n    \"isFirstColumnSticky\" | \"isLastColumnSticky\" | \"bodyCellVerticalPadding\"\n  >;\n\nconst StyledTd = styled(TableCell)<StyledTdProps>(\n  ({ theme, bodyCellVerticalPadding }) => ({\n    ...useResponsiveStyles({\n      padding: [\n        bodyCellVerticalPadding,\n        {\n          s: `${theme.variables.size.spacing.s} ${theme.variables.size.spacing.m}`,\n          m: `${theme.variables.size.spacing.m} ${theme.variables.size.spacing.m}`,\n          l: `${theme.variables.size.spacing.l} ${theme.variables.size.spacing.m}`,\n        } as any,\n      ],\n    }),\n  })\n);\n\ntype EmptyTableBodyProps = Pick<\n  TableBodyProps,\n  \"columns\" | \"emptyTableContentHeight\"\n> & {\n  children: React.ReactElement;\n};\n\ntype StyledEmptyTdProps = Pick<EmptyTableBodyProps, \"emptyTableContentHeight\">;\n\nconst StyledEmptyTd = styled.td<StyledEmptyTdProps>(\n  ({ emptyTableContentHeight }) => ({\n    textAlign: \"center\",\n    ...useResponsiveValue({\n      height: emptyTableContentHeight,\n    }),\n  })\n);\n\nfunction EmptyTableBody({\n  children,\n  columns,\n  emptyTableContentHeight,\n}: EmptyTableBodyProps): React.ReactElement {\n  return (\n    <tbody>\n      <tr>\n        <StyledEmptyTd\n          colSpan={columns.length}\n          emptyTableContentHeight={emptyTableContentHeight}\n        >\n          {children}\n        </StyledEmptyTd>\n      </tr>\n    </tbody>\n  );\n}\n\ntype CheckboxColumnCellContentProps = Pick<DataTableRow, \"id\"> &\n  Pick<TableBodyProps, \"selectedRowIds\" | \"onRowSelectionChange\"> &\n  Pick<DataTableRowProps, \"isSelectable\" | \"selectRowCheckboxAriaLabel\">;\n\nfunction CheckboxColumnCellContent({\n  selectRowCheckboxAriaLabel,\n  selectedRowIds,\n  onRowSelectionChange,\n  id,\n  isSelectable,\n}: CheckboxColumnCellContentProps): React.ReactElement {\n  const toggleRowSelection: ChangeEventHandler<HTMLInputElement> = (evt) => {\n    if (evt.target.checked) {\n      onRowSelectionChange([...selectedRowIds, id]);\n    } else {\n      onRowSelectionChange(selectedRowIds.filter((item) => item !== id));\n    }\n  };\n\n  return (\n    <Checkbox\n      size=\"s\"\n      aria-label={selectRowCheckboxAriaLabel}\n      checked={selectedRowIds.includes(id)}\n      disabled={!isSelectable}\n      onChange={toggleRowSelection}\n    />\n  );\n}\n\nfunction TableBody({\n  className,\n  columns,\n  rows = [],\n  bodyCellVerticalPadding,\n  isTableScrolledToLeft,\n  isTableScrolledToRight,\n  isLoading,\n  loadingStateScreenReaderText = \"Loading\",\n  isEmpty,\n  emptyTableContentHeight,\n  footer,\n  children,\n  isFirstColumnSticky,\n  isLastColumnSticky,\n  emptyCellContent,\n  selectedRowIds,\n  onRowSelectionChange,\n  getRowProps,\n}: React.PropsWithChildren<TableBodyProps>): React.ReactElement {\n  if (isLoading) {\n    const customLoadingContent = children && <>{children}</>;\n    const bodyContent = customLoadingContent || (\n      <LoadingSpinner screenReaderText={loadingStateScreenReaderText} />\n    );\n\n    return (\n      <EmptyTableBody\n        columns={columns}\n        emptyTableContentHeight={emptyTableContentHeight}\n      >\n        {bodyContent}\n      </EmptyTableBody>\n    );\n  }\n\n  if (isEmpty) {\n    return (\n      <EmptyTableBody\n        columns={columns}\n        emptyTableContentHeight={emptyTableContentHeight}\n      >\n        <>{children}</>\n      </EmptyTableBody>\n    );\n  }\n\n  const rowElements = rows.map((row) => {\n    const {\n      verticalAlign = null,\n      isActive = false,\n      isSelectable = true,\n      selectRowCheckboxAriaLabel = `Select row${row.id}`,\n    } = getRowProps?.(row) || {};\n    const isSelected = selectedRowIds.includes(row.id);\n\n    return (\n      <StyledTr\n        key={row.id}\n        footer={footer}\n        verticalAlign={verticalAlign}\n        isSelected={isSelected}\n      >\n        {columns.map(({ name, align = \"left\", renderCell }) => {\n          let content;\n          if (renderCell) {\n            content = renderCell(row);\n          } else if (name === CHECKBOX_COLUMN.name) {\n            content = (\n              <CheckboxColumnCellContent\n                selectRowCheckboxAriaLabel={selectRowCheckboxAriaLabel}\n                selectedRowIds={selectedRowIds}\n                onRowSelectionChange={onRowSelectionChange}\n                id={row.id}\n                isSelectable={isSelectable}\n              />\n            );\n          } else {\n            content = (\n              <StyledText size=\"s\" alignColumn={align}>\n                {row[name] ? row[name] : emptyCellContent}\n              </StyledText>\n            );\n          }\n\n          return (\n            <StyledTd\n              key={name}\n              alignColumn={align}\n              isFirstColumnSticky={isFirstColumnSticky}\n              isLastColumnSticky={isLastColumnSticky}\n              bodyCellVerticalPadding={bodyCellVerticalPadding}\n              isTableScrolledToLeft={isTableScrolledToLeft}\n              isTableScrolledToRight={isTableScrolledToRight}\n              isActive={isActive}\n              isSelected={isSelected}\n            >\n              {content}\n            </StyledTd>\n          );\n        })}\n      </StyledTr>\n    );\n  });\n\n  return <tbody className={className}>{rowElements}</tbody>;\n}\n\nexport default React.memo(TableBody);\n"],"names":[],"mappings":"AAuGsB"} */");function EmptyTableBody({children,columns,emptyTableContentHeight}){return React.createElement("tbody",null,React.createElement("tr",null,React.createElement(StyledEmptyTd,{colSpan:columns.length,emptyTableContentHeight:emptyTableContentHeight},children)))}function CheckboxColumnCellContent({selectRowCheckboxAriaLabel,selectedRowIds,onRowSelectionChange,id,isSelectable}){return React.createElement(Checkbox,{size:"s","aria-label":selectRowCheckboxAriaLabel,checked:selectedRowIds.includes(id),disabled:!isSelectable,onChange:evt=>{evt.target.checked?onRowSelectionChange([...selectedRowIds,id]):onRowSelectionChange(selectedRowIds.filter(item=>item!==id))}})}export default React.memo(function({className,columns,rows=[],bodyCellVerticalPadding,isTableScrolledToLeft,isTableScrolledToRight,isLoading,loadingStateScreenReaderText="Loading",isEmpty,emptyTableContentHeight,footer,children,isFirstColumnSticky,isLastColumnSticky,emptyCellContent,selectedRowIds,onRowSelectionChange,getRowProps}){if(isLoading){let bodyContent=children&&React.createElement(React.Fragment,null,children)||React.createElement(LoadingSpinner,{screenReaderText:loadingStateScreenReaderText});return React.createElement(EmptyTableBody,{columns:columns,emptyTableContentHeight:emptyTableContentHeight},bodyContent)}if(isEmpty)return React.createElement(EmptyTableBody,{columns:columns,emptyTableContentHeight:emptyTableContentHeight},React.createElement(React.Fragment,null,children));let rowElements=rows.map(row=>{let{verticalAlign=null,isActive=!1,isSelectable=!0,selectRowCheckboxAriaLabel=`Select row${row.id}`}=getRowProps?.(row)||{},isSelected=selectedRowIds.includes(row.id);return React.createElement(StyledTr,{key:row.id,footer:footer,verticalAlign:verticalAlign,isSelected:isSelected},columns.map(({name,align="left",renderCell})=>{let content;return content=renderCell?renderCell(row):name===CHECKBOX_COLUMN.name?React.createElement(CheckboxColumnCellContent,{selectRowCheckboxAriaLabel:selectRowCheckboxAriaLabel,selectedRowIds:selectedRowIds,onRowSelectionChange:onRowSelectionChange,id:row.id,isSelectable:isSelectable}):React.createElement(StyledText,{size:"s",alignColumn:align},row[name]?row[name]:emptyCellContent),React.createElement(StyledTd,{key:name,alignColumn:align,isFirstColumnSticky:isFirstColumnSticky,isLastColumnSticky:isLastColumnSticky,bodyCellVerticalPadding:bodyCellVerticalPadding,isTableScrolledToLeft:isTableScrolledToLeft,isTableScrolledToRight:isTableScrolledToRight,isActive:isActive,isSelected:isSelected},content)}))});return React.createElement("tbody",{className:className},rowElements)});
|
|
1
|
+
import React from"react";import styled from"@emotion/styled";import TableCell from"./TableCell";import{Text}from"../Typography/Text/Text";import{LoadingSpinner}from"../LoadingSpinner/LoadingSpinner";import{useResponsiveStyles,useResponsiveValue}from"../../shared/mediaQueries";import{Checkbox}from"../Form/Checkbox/Checkbox";import{CHECKBOX_COLUMN}from"./constants";let StyledTr=styled("tr",{target:"efoata0",label:"StyledTr"})(({theme,footer,isSelected,verticalAlign})=>({...!isSelected&&{"&:hover td":{backgroundColor:theme.values.color.background.secondary.default}},verticalAlign,...!footer&&{"&:last-of-type":{td:{borderBottom:"none"}}}}),"/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"src/components/DataTable/TableBody.tsx","sources":["src/components/DataTable/TableBody.tsx"],"sourcesContent":["/* eslint-disable react/jsx-no-useless-fragment */\nimport type { ChangeEventHandler } from \"react\";\nimport React from \"react\";\nimport styled from \"@emotion/styled\";\nimport type { DataTableColumn, DataTableRow, DataTableRowProps } from \"./types\";\nimport type { TableCellProps } from \"./TableCell\";\nimport TableCell from \"./TableCell\";\nimport { Text } from \"../Typography/Text/Text\";\nimport type { DataTableProps } from \"./DataTable\";\nimport { LoadingSpinner } from \"../LoadingSpinner/LoadingSpinner\";\nimport {\n  useResponsiveStyles,\n  useResponsiveValue,\n} from \"../../shared/mediaQueries\";\nimport { Checkbox } from \"../Form/Checkbox/Checkbox\";\nimport { CHECKBOX_COLUMN } from \"./constants\";\n\nexport type TableBodyProps = {\n  className?: string;\n} & Pick<\n  DataTableProps,\n  | \"columns\"\n  | \"rows\"\n  | \"isLoading\"\n  | \"loadingStateScreenReaderText\"\n  | \"isEmpty\"\n  | \"emptyTableContentHeight\"\n  | \"bodyCellVerticalPadding\"\n  | \"footer\"\n  | \"isFirstColumnSticky\"\n  | \"isLastColumnSticky\"\n  | \"emptyCellContent\"\n  | \"selectedRowIds\"\n  | \"onRowSelectionChange\"\n  | \"getRowProps\"\n> &\n  Pick<TableCellProps, \"isTableScrolledToLeft\" | \"isTableScrolledToRight\">;\n\ntype StyledTrProps = {\n  isSelected?: boolean;\n} & Pick<TableBodyProps, \"footer\"> &\n  Pick<DataTableRowProps, \"verticalAlign\">;\n\nconst StyledTr = styled.tr<StyledTrProps>(\n  ({ theme, footer, isSelected, verticalAlign }) => ({\n    ...(!isSelected && {\n      \"&:hover td\": {\n        backgroundColor: theme.values.color.background.secondary.default,\n      },\n    }),\n\n    verticalAlign,\n\n    ...(!footer && {\n      \"&:last-of-type\": {\n        td: {\n          borderBottom: \"none\",\n        },\n      },\n    }),\n  })\n);\n\ntype StyledTextProps = {\n  alignColumn?: DataTableColumn[\"align\"];\n};\n\nconst StyledText = styled(Text)<StyledTextProps>(({ alignColumn }) => ({\n  ...useResponsiveValue({\n    textAlign: alignColumn,\n  }),\n}));\n\ntype StyledTdProps = TableCellProps &\n  Pick<\n    TableBodyProps,\n    \"isFirstColumnSticky\" | \"isLastColumnSticky\" | \"bodyCellVerticalPadding\"\n  >;\n\nconst StyledTd = styled(TableCell)<StyledTdProps>(\n  ({ theme, bodyCellVerticalPadding }) => ({\n    ...useResponsiveStyles({\n      padding: [\n        bodyCellVerticalPadding,\n        {\n          xxs: `${theme.variables.size.spacing.xxs} ${theme.variables.size.spacing.m}`,\n          xs: `${theme.variables.size.spacing.xs} ${theme.variables.size.spacing.m}`,\n          s: `${theme.variables.size.spacing.s} ${theme.variables.size.spacing.m}`,\n          m: `${theme.variables.size.spacing.m} ${theme.variables.size.spacing.m}`,\n          l: `${theme.variables.size.spacing.l} ${theme.variables.size.spacing.m}`,\n        } as any,\n      ],\n    }),\n  })\n);\n\ntype EmptyTableBodyProps = Pick<\n  TableBodyProps,\n  \"columns\" | \"emptyTableContentHeight\"\n> & {\n  children: React.ReactElement;\n};\n\ntype StyledEmptyTdProps = Pick<EmptyTableBodyProps, \"emptyTableContentHeight\">;\n\nconst StyledEmptyTd = styled.td<StyledEmptyTdProps>(\n  ({ emptyTableContentHeight }) => ({\n    textAlign: \"center\",\n    ...useResponsiveValue({\n      height: emptyTableContentHeight,\n    }),\n  })\n);\n\nfunction EmptyTableBody({\n  children,\n  columns,\n  emptyTableContentHeight,\n}: EmptyTableBodyProps): React.ReactElement {\n  return (\n    <tbody>\n      <tr>\n        <StyledEmptyTd\n          colSpan={columns.length}\n          emptyTableContentHeight={emptyTableContentHeight}\n        >\n          {children}\n        </StyledEmptyTd>\n      </tr>\n    </tbody>\n  );\n}\n\ntype CheckboxColumnCellContentProps = Pick<DataTableRow, \"id\"> &\n  Pick<TableBodyProps, \"selectedRowIds\" | \"onRowSelectionChange\"> &\n  Pick<DataTableRowProps, \"isSelectable\" | \"selectRowCheckboxAriaLabel\">;\n\nfunction CheckboxColumnCellContent({\n  selectRowCheckboxAriaLabel,\n  selectedRowIds,\n  onRowSelectionChange,\n  id,\n  isSelectable,\n}: CheckboxColumnCellContentProps): React.ReactElement {\n  const toggleRowSelection: ChangeEventHandler<HTMLInputElement> = (evt) => {\n    if (evt.target.checked) {\n      onRowSelectionChange([...selectedRowIds, id]);\n    } else {\n      onRowSelectionChange(selectedRowIds.filter((item) => item !== id));\n    }\n  };\n\n  return (\n    <Checkbox\n      size=\"s\"\n      aria-label={selectRowCheckboxAriaLabel}\n      checked={selectedRowIds.includes(id)}\n      disabled={!isSelectable}\n      onChange={toggleRowSelection}\n    />\n  );\n}\n\nfunction TableBody({\n  className,\n  columns,\n  rows = [],\n  bodyCellVerticalPadding,\n  isTableScrolledToLeft,\n  isTableScrolledToRight,\n  isLoading,\n  loadingStateScreenReaderText = \"Loading\",\n  isEmpty,\n  emptyTableContentHeight,\n  footer,\n  children,\n  isFirstColumnSticky,\n  isLastColumnSticky,\n  emptyCellContent,\n  selectedRowIds,\n  onRowSelectionChange,\n  getRowProps,\n}: React.PropsWithChildren<TableBodyProps>): React.ReactElement {\n  if (isLoading) {\n    const customLoadingContent = children && <>{children}</>;\n    const bodyContent = customLoadingContent || (\n      <LoadingSpinner screenReaderText={loadingStateScreenReaderText} />\n    );\n\n    return (\n      <EmptyTableBody\n        columns={columns}\n        emptyTableContentHeight={emptyTableContentHeight}\n      >\n        {bodyContent}\n      </EmptyTableBody>\n    );\n  }\n\n  if (isEmpty) {\n    return (\n      <EmptyTableBody\n        columns={columns}\n        emptyTableContentHeight={emptyTableContentHeight}\n      >\n        <>{children}</>\n      </EmptyTableBody>\n    );\n  }\n\n  const rowElements = rows.map((row) => {\n    const {\n      verticalAlign = null,\n      isActive = false,\n      isSelectable = true,\n      selectRowCheckboxAriaLabel = `Select row${row.id}`,\n    } = getRowProps?.(row) || {};\n    const isSelected = selectedRowIds.includes(row.id);\n\n    return (\n      <StyledTr\n        key={row.id}\n        footer={footer}\n        verticalAlign={verticalAlign}\n        isSelected={isSelected}\n      >\n        {columns.map(({ name, align = \"left\", renderCell }) => {\n          let content;\n          if (renderCell) {\n            content = renderCell(row);\n          } else if (name === CHECKBOX_COLUMN.name) {\n            content = (\n              <CheckboxColumnCellContent\n                selectRowCheckboxAriaLabel={selectRowCheckboxAriaLabel}\n                selectedRowIds={selectedRowIds}\n                onRowSelectionChange={onRowSelectionChange}\n                id={row.id}\n                isSelectable={isSelectable}\n              />\n            );\n          } else {\n            content = (\n              <StyledText size=\"s\" alignColumn={align}>\n                {row[name] ? row[name] : emptyCellContent}\n              </StyledText>\n            );\n          }\n\n          return (\n            <StyledTd\n              key={name}\n              alignColumn={align}\n              isFirstColumnSticky={isFirstColumnSticky}\n              isLastColumnSticky={isLastColumnSticky}\n              bodyCellVerticalPadding={bodyCellVerticalPadding}\n              isTableScrolledToLeft={isTableScrolledToLeft}\n              isTableScrolledToRight={isTableScrolledToRight}\n              isActive={isActive}\n              isSelected={isSelected}\n            >\n              {content}\n            </StyledTd>\n          );\n        })}\n      </StyledTr>\n    );\n  });\n\n  return <tbody className={className}>{rowElements}</tbody>;\n}\n\nexport default React.memo(TableBody);\n"],"names":[],"mappings":"AA2CiB"} */"),StyledText=styled(Text,{target:"efoata1",label:"StyledText"})(({alignColumn})=>({...useResponsiveValue({textAlign:alignColumn})}),"/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"src/components/DataTable/TableBody.tsx","sources":["src/components/DataTable/TableBody.tsx"],"sourcesContent":["/* eslint-disable react/jsx-no-useless-fragment */\nimport type { ChangeEventHandler } from \"react\";\nimport React from \"react\";\nimport styled from \"@emotion/styled\";\nimport type { DataTableColumn, DataTableRow, DataTableRowProps } from \"./types\";\nimport type { TableCellProps } from \"./TableCell\";\nimport TableCell from \"./TableCell\";\nimport { Text } from \"../Typography/Text/Text\";\nimport type { DataTableProps } from \"./DataTable\";\nimport { LoadingSpinner } from \"../LoadingSpinner/LoadingSpinner\";\nimport {\n  useResponsiveStyles,\n  useResponsiveValue,\n} from \"../../shared/mediaQueries\";\nimport { Checkbox } from \"../Form/Checkbox/Checkbox\";\nimport { CHECKBOX_COLUMN } from \"./constants\";\n\nexport type TableBodyProps = {\n  className?: string;\n} & Pick<\n  DataTableProps,\n  | \"columns\"\n  | \"rows\"\n  | \"isLoading\"\n  | \"loadingStateScreenReaderText\"\n  | \"isEmpty\"\n  | \"emptyTableContentHeight\"\n  | \"bodyCellVerticalPadding\"\n  | \"footer\"\n  | \"isFirstColumnSticky\"\n  | \"isLastColumnSticky\"\n  | \"emptyCellContent\"\n  | \"selectedRowIds\"\n  | \"onRowSelectionChange\"\n  | \"getRowProps\"\n> &\n  Pick<TableCellProps, \"isTableScrolledToLeft\" | \"isTableScrolledToRight\">;\n\ntype StyledTrProps = {\n  isSelected?: boolean;\n} & Pick<TableBodyProps, \"footer\"> &\n  Pick<DataTableRowProps, \"verticalAlign\">;\n\nconst StyledTr = styled.tr<StyledTrProps>(\n  ({ theme, footer, isSelected, verticalAlign }) => ({\n    ...(!isSelected && {\n      \"&:hover td\": {\n        backgroundColor: theme.values.color.background.secondary.default,\n      },\n    }),\n\n    verticalAlign,\n\n    ...(!footer && {\n      \"&:last-of-type\": {\n        td: {\n          borderBottom: \"none\",\n        },\n      },\n    }),\n  })\n);\n\ntype StyledTextProps = {\n  alignColumn?: DataTableColumn[\"align\"];\n};\n\nconst StyledText = styled(Text)<StyledTextProps>(({ alignColumn }) => ({\n  ...useResponsiveValue({\n    textAlign: alignColumn,\n  }),\n}));\n\ntype StyledTdProps = TableCellProps &\n  Pick<\n    TableBodyProps,\n    \"isFirstColumnSticky\" | \"isLastColumnSticky\" | \"bodyCellVerticalPadding\"\n  >;\n\nconst StyledTd = styled(TableCell)<StyledTdProps>(\n  ({ theme, bodyCellVerticalPadding }) => ({\n    ...useResponsiveStyles({\n      padding: [\n        bodyCellVerticalPadding,\n        {\n          xxs: `${theme.variables.size.spacing.xxs} ${theme.variables.size.spacing.m}`,\n          xs: `${theme.variables.size.spacing.xs} ${theme.variables.size.spacing.m}`,\n          s: `${theme.variables.size.spacing.s} ${theme.variables.size.spacing.m}`,\n          m: `${theme.variables.size.spacing.m} ${theme.variables.size.spacing.m}`,\n          l: `${theme.variables.size.spacing.l} ${theme.variables.size.spacing.m}`,\n        } as any,\n      ],\n    }),\n  })\n);\n\ntype EmptyTableBodyProps = Pick<\n  TableBodyProps,\n  \"columns\" | \"emptyTableContentHeight\"\n> & {\n  children: React.ReactElement;\n};\n\ntype StyledEmptyTdProps = Pick<EmptyTableBodyProps, \"emptyTableContentHeight\">;\n\nconst StyledEmptyTd = styled.td<StyledEmptyTdProps>(\n  ({ emptyTableContentHeight }) => ({\n    textAlign: \"center\",\n    ...useResponsiveValue({\n      height: emptyTableContentHeight,\n    }),\n  })\n);\n\nfunction EmptyTableBody({\n  children,\n  columns,\n  emptyTableContentHeight,\n}: EmptyTableBodyProps): React.ReactElement {\n  return (\n    <tbody>\n      <tr>\n        <StyledEmptyTd\n          colSpan={columns.length}\n          emptyTableContentHeight={emptyTableContentHeight}\n        >\n          {children}\n        </StyledEmptyTd>\n      </tr>\n    </tbody>\n  );\n}\n\ntype CheckboxColumnCellContentProps = Pick<DataTableRow, \"id\"> &\n  Pick<TableBodyProps, \"selectedRowIds\" | \"onRowSelectionChange\"> &\n  Pick<DataTableRowProps, \"isSelectable\" | \"selectRowCheckboxAriaLabel\">;\n\nfunction CheckboxColumnCellContent({\n  selectRowCheckboxAriaLabel,\n  selectedRowIds,\n  onRowSelectionChange,\n  id,\n  isSelectable,\n}: CheckboxColumnCellContentProps): React.ReactElement {\n  const toggleRowSelection: ChangeEventHandler<HTMLInputElement> = (evt) => {\n    if (evt.target.checked) {\n      onRowSelectionChange([...selectedRowIds, id]);\n    } else {\n      onRowSelectionChange(selectedRowIds.filter((item) => item !== id));\n    }\n  };\n\n  return (\n    <Checkbox\n      size=\"s\"\n      aria-label={selectRowCheckboxAriaLabel}\n      checked={selectedRowIds.includes(id)}\n      disabled={!isSelectable}\n      onChange={toggleRowSelection}\n    />\n  );\n}\n\nfunction TableBody({\n  className,\n  columns,\n  rows = [],\n  bodyCellVerticalPadding,\n  isTableScrolledToLeft,\n  isTableScrolledToRight,\n  isLoading,\n  loadingStateScreenReaderText = \"Loading\",\n  isEmpty,\n  emptyTableContentHeight,\n  footer,\n  children,\n  isFirstColumnSticky,\n  isLastColumnSticky,\n  emptyCellContent,\n  selectedRowIds,\n  onRowSelectionChange,\n  getRowProps,\n}: React.PropsWithChildren<TableBodyProps>): React.ReactElement {\n  if (isLoading) {\n    const customLoadingContent = children && <>{children}</>;\n    const bodyContent = customLoadingContent || (\n      <LoadingSpinner screenReaderText={loadingStateScreenReaderText} />\n    );\n\n    return (\n      <EmptyTableBody\n        columns={columns}\n        emptyTableContentHeight={emptyTableContentHeight}\n      >\n        {bodyContent}\n      </EmptyTableBody>\n    );\n  }\n\n  if (isEmpty) {\n    return (\n      <EmptyTableBody\n        columns={columns}\n        emptyTableContentHeight={emptyTableContentHeight}\n      >\n        <>{children}</>\n      </EmptyTableBody>\n    );\n  }\n\n  const rowElements = rows.map((row) => {\n    const {\n      verticalAlign = null,\n      isActive = false,\n      isSelectable = true,\n      selectRowCheckboxAriaLabel = `Select row${row.id}`,\n    } = getRowProps?.(row) || {};\n    const isSelected = selectedRowIds.includes(row.id);\n\n    return (\n      <StyledTr\n        key={row.id}\n        footer={footer}\n        verticalAlign={verticalAlign}\n        isSelected={isSelected}\n      >\n        {columns.map(({ name, align = \"left\", renderCell }) => {\n          let content;\n          if (renderCell) {\n            content = renderCell(row);\n          } else if (name === CHECKBOX_COLUMN.name) {\n            content = (\n              <CheckboxColumnCellContent\n                selectRowCheckboxAriaLabel={selectRowCheckboxAriaLabel}\n                selectedRowIds={selectedRowIds}\n                onRowSelectionChange={onRowSelectionChange}\n                id={row.id}\n                isSelectable={isSelectable}\n              />\n            );\n          } else {\n            content = (\n              <StyledText size=\"s\" alignColumn={align}>\n                {row[name] ? row[name] : emptyCellContent}\n              </StyledText>\n            );\n          }\n\n          return (\n            <StyledTd\n              key={name}\n              alignColumn={align}\n              isFirstColumnSticky={isFirstColumnSticky}\n              isLastColumnSticky={isLastColumnSticky}\n              bodyCellVerticalPadding={bodyCellVerticalPadding}\n              isTableScrolledToLeft={isTableScrolledToLeft}\n              isTableScrolledToRight={isTableScrolledToRight}\n              isActive={isActive}\n              isSelected={isSelected}\n            >\n              {content}\n            </StyledTd>\n          );\n        })}\n      </StyledTr>\n    );\n  });\n\n  return <tbody className={className}>{rowElements}</tbody>;\n}\n\nexport default React.memo(TableBody);\n"],"names":[],"mappings":"AAmEmB"} */"),StyledTd=styled(TableCell,{target:"efoata2",label:"StyledTd"})(({theme,bodyCellVerticalPadding})=>({...useResponsiveStyles({padding:[bodyCellVerticalPadding,{xxs:`${theme.variables.size.spacing.xxs} ${theme.variables.size.spacing.m}`,xs:`${theme.variables.size.spacing.xs} ${theme.variables.size.spacing.m}`,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,{"version":3,"file":"src/components/DataTable/TableBody.tsx","sources":["src/components/DataTable/TableBody.tsx"],"sourcesContent":["/* eslint-disable react/jsx-no-useless-fragment */\nimport type { ChangeEventHandler } from \"react\";\nimport React from \"react\";\nimport styled from \"@emotion/styled\";\nimport type { DataTableColumn, DataTableRow, DataTableRowProps } from \"./types\";\nimport type { TableCellProps } from \"./TableCell\";\nimport TableCell from \"./TableCell\";\nimport { Text } from \"../Typography/Text/Text\";\nimport type { DataTableProps } from \"./DataTable\";\nimport { LoadingSpinner } from \"../LoadingSpinner/LoadingSpinner\";\nimport {\n  useResponsiveStyles,\n  useResponsiveValue,\n} from \"../../shared/mediaQueries\";\nimport { Checkbox } from \"../Form/Checkbox/Checkbox\";\nimport { CHECKBOX_COLUMN } from \"./constants\";\n\nexport type TableBodyProps = {\n  className?: string;\n} & Pick<\n  DataTableProps,\n  | \"columns\"\n  | \"rows\"\n  | \"isLoading\"\n  | \"loadingStateScreenReaderText\"\n  | \"isEmpty\"\n  | \"emptyTableContentHeight\"\n  | \"bodyCellVerticalPadding\"\n  | \"footer\"\n  | \"isFirstColumnSticky\"\n  | \"isLastColumnSticky\"\n  | \"emptyCellContent\"\n  | \"selectedRowIds\"\n  | \"onRowSelectionChange\"\n  | \"getRowProps\"\n> &\n  Pick<TableCellProps, \"isTableScrolledToLeft\" | \"isTableScrolledToRight\">;\n\ntype StyledTrProps = {\n  isSelected?: boolean;\n} & Pick<TableBodyProps, \"footer\"> &\n  Pick<DataTableRowProps, \"verticalAlign\">;\n\nconst StyledTr = styled.tr<StyledTrProps>(\n  ({ theme, footer, isSelected, verticalAlign }) => ({\n    ...(!isSelected && {\n      \"&:hover td\": {\n        backgroundColor: theme.values.color.background.secondary.default,\n      },\n    }),\n\n    verticalAlign,\n\n    ...(!footer && {\n      \"&:last-of-type\": {\n        td: {\n          borderBottom: \"none\",\n        },\n      },\n    }),\n  })\n);\n\ntype StyledTextProps = {\n  alignColumn?: DataTableColumn[\"align\"];\n};\n\nconst StyledText = styled(Text)<StyledTextProps>(({ alignColumn }) => ({\n  ...useResponsiveValue({\n    textAlign: alignColumn,\n  }),\n}));\n\ntype StyledTdProps = TableCellProps &\n  Pick<\n    TableBodyProps,\n    \"isFirstColumnSticky\" | \"isLastColumnSticky\" | \"bodyCellVerticalPadding\"\n  >;\n\nconst StyledTd = styled(TableCell)<StyledTdProps>(\n  ({ theme, bodyCellVerticalPadding }) => ({\n    ...useResponsiveStyles({\n      padding: [\n        bodyCellVerticalPadding,\n        {\n          xxs: `${theme.variables.size.spacing.xxs} ${theme.variables.size.spacing.m}`,\n          xs: `${theme.variables.size.spacing.xs} ${theme.variables.size.spacing.m}`,\n          s: `${theme.variables.size.spacing.s} ${theme.variables.size.spacing.m}`,\n          m: `${theme.variables.size.spacing.m} ${theme.variables.size.spacing.m}`,\n          l: `${theme.variables.size.spacing.l} ${theme.variables.size.spacing.m}`,\n        } as any,\n      ],\n    }),\n  })\n);\n\ntype EmptyTableBodyProps = Pick<\n  TableBodyProps,\n  \"columns\" | \"emptyTableContentHeight\"\n> & {\n  children: React.ReactElement;\n};\n\ntype StyledEmptyTdProps = Pick<EmptyTableBodyProps, \"emptyTableContentHeight\">;\n\nconst StyledEmptyTd = styled.td<StyledEmptyTdProps>(\n  ({ emptyTableContentHeight }) => ({\n    textAlign: \"center\",\n    ...useResponsiveValue({\n      height: emptyTableContentHeight,\n    }),\n  })\n);\n\nfunction EmptyTableBody({\n  children,\n  columns,\n  emptyTableContentHeight,\n}: EmptyTableBodyProps): React.ReactElement {\n  return (\n    <tbody>\n      <tr>\n        <StyledEmptyTd\n          colSpan={columns.length}\n          emptyTableContentHeight={emptyTableContentHeight}\n        >\n          {children}\n        </StyledEmptyTd>\n      </tr>\n    </tbody>\n  );\n}\n\ntype CheckboxColumnCellContentProps = Pick<DataTableRow, \"id\"> &\n  Pick<TableBodyProps, \"selectedRowIds\" | \"onRowSelectionChange\"> &\n  Pick<DataTableRowProps, \"isSelectable\" | \"selectRowCheckboxAriaLabel\">;\n\nfunction CheckboxColumnCellContent({\n  selectRowCheckboxAriaLabel,\n  selectedRowIds,\n  onRowSelectionChange,\n  id,\n  isSelectable,\n}: CheckboxColumnCellContentProps): React.ReactElement {\n  const toggleRowSelection: ChangeEventHandler<HTMLInputElement> = (evt) => {\n    if (evt.target.checked) {\n      onRowSelectionChange([...selectedRowIds, id]);\n    } else {\n      onRowSelectionChange(selectedRowIds.filter((item) => item !== id));\n    }\n  };\n\n  return (\n    <Checkbox\n      size=\"s\"\n      aria-label={selectRowCheckboxAriaLabel}\n      checked={selectedRowIds.includes(id)}\n      disabled={!isSelectable}\n      onChange={toggleRowSelection}\n    />\n  );\n}\n\nfunction TableBody({\n  className,\n  columns,\n  rows = [],\n  bodyCellVerticalPadding,\n  isTableScrolledToLeft,\n  isTableScrolledToRight,\n  isLoading,\n  loadingStateScreenReaderText = \"Loading\",\n  isEmpty,\n  emptyTableContentHeight,\n  footer,\n  children,\n  isFirstColumnSticky,\n  isLastColumnSticky,\n  emptyCellContent,\n  selectedRowIds,\n  onRowSelectionChange,\n  getRowProps,\n}: React.PropsWithChildren<TableBodyProps>): React.ReactElement {\n  if (isLoading) {\n    const customLoadingContent = children && <>{children}</>;\n    const bodyContent = customLoadingContent || (\n      <LoadingSpinner screenReaderText={loadingStateScreenReaderText} />\n    );\n\n    return (\n      <EmptyTableBody\n        columns={columns}\n        emptyTableContentHeight={emptyTableContentHeight}\n      >\n        {bodyContent}\n      </EmptyTableBody>\n    );\n  }\n\n  if (isEmpty) {\n    return (\n      <EmptyTableBody\n        columns={columns}\n        emptyTableContentHeight={emptyTableContentHeight}\n      >\n        <>{children}</>\n      </EmptyTableBody>\n    );\n  }\n\n  const rowElements = rows.map((row) => {\n    const {\n      verticalAlign = null,\n      isActive = false,\n      isSelectable = true,\n      selectRowCheckboxAriaLabel = `Select row${row.id}`,\n    } = getRowProps?.(row) || {};\n    const isSelected = selectedRowIds.includes(row.id);\n\n    return (\n      <StyledTr\n        key={row.id}\n        footer={footer}\n        verticalAlign={verticalAlign}\n        isSelected={isSelected}\n      >\n        {columns.map(({ name, align = \"left\", renderCell }) => {\n          let content;\n          if (renderCell) {\n            content = renderCell(row);\n          } else if (name === CHECKBOX_COLUMN.name) {\n            content = (\n              <CheckboxColumnCellContent\n                selectRowCheckboxAriaLabel={selectRowCheckboxAriaLabel}\n                selectedRowIds={selectedRowIds}\n                onRowSelectionChange={onRowSelectionChange}\n                id={row.id}\n                isSelectable={isSelectable}\n              />\n            );\n          } else {\n            content = (\n              <StyledText size=\"s\" alignColumn={align}>\n                {row[name] ? row[name] : emptyCellContent}\n              </StyledText>\n            );\n          }\n\n          return (\n            <StyledTd\n              key={name}\n              alignColumn={align}\n              isFirstColumnSticky={isFirstColumnSticky}\n              isLastColumnSticky={isLastColumnSticky}\n              bodyCellVerticalPadding={bodyCellVerticalPadding}\n              isTableScrolledToLeft={isTableScrolledToLeft}\n              isTableScrolledToRight={isTableScrolledToRight}\n              isActive={isActive}\n              isSelected={isSelected}\n            >\n              {content}\n            </StyledTd>\n          );\n        })}\n      </StyledTr>\n    );\n  });\n\n  return <tbody className={className}>{rowElements}</tbody>;\n}\n\nexport default React.memo(TableBody);\n"],"names":[],"mappings":"AA+EiB"} */"),StyledEmptyTd=styled("td",{target:"efoata3",label:"StyledEmptyTd"})(({emptyTableContentHeight})=>({textAlign:"center",...useResponsiveValue({height:emptyTableContentHeight})}),"/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"src/components/DataTable/TableBody.tsx","sources":["src/components/DataTable/TableBody.tsx"],"sourcesContent":["/* eslint-disable react/jsx-no-useless-fragment */\nimport type { ChangeEventHandler } from \"react\";\nimport React from \"react\";\nimport styled from \"@emotion/styled\";\nimport type { DataTableColumn, DataTableRow, DataTableRowProps } from \"./types\";\nimport type { TableCellProps } from \"./TableCell\";\nimport TableCell from \"./TableCell\";\nimport { Text } from \"../Typography/Text/Text\";\nimport type { DataTableProps } from \"./DataTable\";\nimport { LoadingSpinner } from \"../LoadingSpinner/LoadingSpinner\";\nimport {\n  useResponsiveStyles,\n  useResponsiveValue,\n} from \"../../shared/mediaQueries\";\nimport { Checkbox } from \"../Form/Checkbox/Checkbox\";\nimport { CHECKBOX_COLUMN } from \"./constants\";\n\nexport type TableBodyProps = {\n  className?: string;\n} & Pick<\n  DataTableProps,\n  | \"columns\"\n  | \"rows\"\n  | \"isLoading\"\n  | \"loadingStateScreenReaderText\"\n  | \"isEmpty\"\n  | \"emptyTableContentHeight\"\n  | \"bodyCellVerticalPadding\"\n  | \"footer\"\n  | \"isFirstColumnSticky\"\n  | \"isLastColumnSticky\"\n  | \"emptyCellContent\"\n  | \"selectedRowIds\"\n  | \"onRowSelectionChange\"\n  | \"getRowProps\"\n> &\n  Pick<TableCellProps, \"isTableScrolledToLeft\" | \"isTableScrolledToRight\">;\n\ntype StyledTrProps = {\n  isSelected?: boolean;\n} & Pick<TableBodyProps, \"footer\"> &\n  Pick<DataTableRowProps, \"verticalAlign\">;\n\nconst StyledTr = styled.tr<StyledTrProps>(\n  ({ theme, footer, isSelected, verticalAlign }) => ({\n    ...(!isSelected && {\n      \"&:hover td\": {\n        backgroundColor: theme.values.color.background.secondary.default,\n      },\n    }),\n\n    verticalAlign,\n\n    ...(!footer && {\n      \"&:last-of-type\": {\n        td: {\n          borderBottom: \"none\",\n        },\n      },\n    }),\n  })\n);\n\ntype StyledTextProps = {\n  alignColumn?: DataTableColumn[\"align\"];\n};\n\nconst StyledText = styled(Text)<StyledTextProps>(({ alignColumn }) => ({\n  ...useResponsiveValue({\n    textAlign: alignColumn,\n  }),\n}));\n\ntype StyledTdProps = TableCellProps &\n  Pick<\n    TableBodyProps,\n    \"isFirstColumnSticky\" | \"isLastColumnSticky\" | \"bodyCellVerticalPadding\"\n  >;\n\nconst StyledTd = styled(TableCell)<StyledTdProps>(\n  ({ theme, bodyCellVerticalPadding }) => ({\n    ...useResponsiveStyles({\n      padding: [\n        bodyCellVerticalPadding,\n        {\n          xxs: `${theme.variables.size.spacing.xxs} ${theme.variables.size.spacing.m}`,\n          xs: `${theme.variables.size.spacing.xs} ${theme.variables.size.spacing.m}`,\n          s: `${theme.variables.size.spacing.s} ${theme.variables.size.spacing.m}`,\n          m: `${theme.variables.size.spacing.m} ${theme.variables.size.spacing.m}`,\n          l: `${theme.variables.size.spacing.l} ${theme.variables.size.spacing.m}`,\n        } as any,\n      ],\n    }),\n  })\n);\n\ntype EmptyTableBodyProps = Pick<\n  TableBodyProps,\n  \"columns\" | \"emptyTableContentHeight\"\n> & {\n  children: React.ReactElement;\n};\n\ntype StyledEmptyTdProps = Pick<EmptyTableBodyProps, \"emptyTableContentHeight\">;\n\nconst StyledEmptyTd = styled.td<StyledEmptyTdProps>(\n  ({ emptyTableContentHeight }) => ({\n    textAlign: \"center\",\n    ...useResponsiveValue({\n      height: emptyTableContentHeight,\n    }),\n  })\n);\n\nfunction EmptyTableBody({\n  children,\n  columns,\n  emptyTableContentHeight,\n}: EmptyTableBodyProps): React.ReactElement {\n  return (\n    <tbody>\n      <tr>\n        <StyledEmptyTd\n          colSpan={columns.length}\n          emptyTableContentHeight={emptyTableContentHeight}\n        >\n          {children}\n        </StyledEmptyTd>\n      </tr>\n    </tbody>\n  );\n}\n\ntype CheckboxColumnCellContentProps = Pick<DataTableRow, \"id\"> &\n  Pick<TableBodyProps, \"selectedRowIds\" | \"onRowSelectionChange\"> &\n  Pick<DataTableRowProps, \"isSelectable\" | \"selectRowCheckboxAriaLabel\">;\n\nfunction CheckboxColumnCellContent({\n  selectRowCheckboxAriaLabel,\n  selectedRowIds,\n  onRowSelectionChange,\n  id,\n  isSelectable,\n}: CheckboxColumnCellContentProps): React.ReactElement {\n  const toggleRowSelection: ChangeEventHandler<HTMLInputElement> = (evt) => {\n    if (evt.target.checked) {\n      onRowSelectionChange([...selectedRowIds, id]);\n    } else {\n      onRowSelectionChange(selectedRowIds.filter((item) => item !== id));\n    }\n  };\n\n  return (\n    <Checkbox\n      size=\"s\"\n      aria-label={selectRowCheckboxAriaLabel}\n      checked={selectedRowIds.includes(id)}\n      disabled={!isSelectable}\n      onChange={toggleRowSelection}\n    />\n  );\n}\n\nfunction TableBody({\n  className,\n  columns,\n  rows = [],\n  bodyCellVerticalPadding,\n  isTableScrolledToLeft,\n  isTableScrolledToRight,\n  isLoading,\n  loadingStateScreenReaderText = \"Loading\",\n  isEmpty,\n  emptyTableContentHeight,\n  footer,\n  children,\n  isFirstColumnSticky,\n  isLastColumnSticky,\n  emptyCellContent,\n  selectedRowIds,\n  onRowSelectionChange,\n  getRowProps,\n}: React.PropsWithChildren<TableBodyProps>): React.ReactElement {\n  if (isLoading) {\n    const customLoadingContent = children && <>{children}</>;\n    const bodyContent = customLoadingContent || (\n      <LoadingSpinner screenReaderText={loadingStateScreenReaderText} />\n    );\n\n    return (\n      <EmptyTableBody\n        columns={columns}\n        emptyTableContentHeight={emptyTableContentHeight}\n      >\n        {bodyContent}\n      </EmptyTableBody>\n    );\n  }\n\n  if (isEmpty) {\n    return (\n      <EmptyTableBody\n        columns={columns}\n        emptyTableContentHeight={emptyTableContentHeight}\n      >\n        <>{children}</>\n      </EmptyTableBody>\n    );\n  }\n\n  const rowElements = rows.map((row) => {\n    const {\n      verticalAlign = null,\n      isActive = false,\n      isSelectable = true,\n      selectRowCheckboxAriaLabel = `Select row${row.id}`,\n    } = getRowProps?.(row) || {};\n    const isSelected = selectedRowIds.includes(row.id);\n\n    return (\n      <StyledTr\n        key={row.id}\n        footer={footer}\n        verticalAlign={verticalAlign}\n        isSelected={isSelected}\n      >\n        {columns.map(({ name, align = \"left\", renderCell }) => {\n          let content;\n          if (renderCell) {\n            content = renderCell(row);\n          } else if (name === CHECKBOX_COLUMN.name) {\n            content = (\n              <CheckboxColumnCellContent\n                selectRowCheckboxAriaLabel={selectRowCheckboxAriaLabel}\n                selectedRowIds={selectedRowIds}\n                onRowSelectionChange={onRowSelectionChange}\n                id={row.id}\n                isSelectable={isSelectable}\n              />\n            );\n          } else {\n            content = (\n              <StyledText size=\"s\" alignColumn={align}>\n                {row[name] ? row[name] : emptyCellContent}\n              </StyledText>\n            );\n          }\n\n          return (\n            <StyledTd\n              key={name}\n              alignColumn={align}\n              isFirstColumnSticky={isFirstColumnSticky}\n              isLastColumnSticky={isLastColumnSticky}\n              bodyCellVerticalPadding={bodyCellVerticalPadding}\n              isTableScrolledToLeft={isTableScrolledToLeft}\n              isTableScrolledToRight={isTableScrolledToRight}\n              isActive={isActive}\n              isSelected={isSelected}\n            >\n              {content}\n            </StyledTd>\n          );\n        })}\n      </StyledTr>\n    );\n  });\n\n  return <tbody className={className}>{rowElements}</tbody>;\n}\n\nexport default React.memo(TableBody);\n"],"names":[],"mappings":"AAyGsB"} */");function EmptyTableBody({children,columns,emptyTableContentHeight}){return React.createElement("tbody",null,React.createElement("tr",null,React.createElement(StyledEmptyTd,{colSpan:columns.length,emptyTableContentHeight:emptyTableContentHeight},children)))}function CheckboxColumnCellContent({selectRowCheckboxAriaLabel,selectedRowIds,onRowSelectionChange,id,isSelectable}){return React.createElement(Checkbox,{size:"s","aria-label":selectRowCheckboxAriaLabel,checked:selectedRowIds.includes(id),disabled:!isSelectable,onChange:evt=>{evt.target.checked?onRowSelectionChange([...selectedRowIds,id]):onRowSelectionChange(selectedRowIds.filter(item=>item!==id))}})}export default React.memo(function({className,columns,rows=[],bodyCellVerticalPadding,isTableScrolledToLeft,isTableScrolledToRight,isLoading,loadingStateScreenReaderText="Loading",isEmpty,emptyTableContentHeight,footer,children,isFirstColumnSticky,isLastColumnSticky,emptyCellContent,selectedRowIds,onRowSelectionChange,getRowProps}){if(isLoading){let bodyContent=children&&React.createElement(React.Fragment,null,children)||React.createElement(LoadingSpinner,{screenReaderText:loadingStateScreenReaderText});return React.createElement(EmptyTableBody,{columns:columns,emptyTableContentHeight:emptyTableContentHeight},bodyContent)}if(isEmpty)return React.createElement(EmptyTableBody,{columns:columns,emptyTableContentHeight:emptyTableContentHeight},React.createElement(React.Fragment,null,children));let rowElements=rows.map(row=>{let{verticalAlign=null,isActive=!1,isSelectable=!0,selectRowCheckboxAriaLabel=`Select row${row.id}`}=getRowProps?.(row)||{},isSelected=selectedRowIds.includes(row.id);return React.createElement(StyledTr,{key:row.id,footer:footer,verticalAlign:verticalAlign,isSelected:isSelected},columns.map(({name,align="left",renderCell})=>{let content;return content=renderCell?renderCell(row):name===CHECKBOX_COLUMN.name?React.createElement(CheckboxColumnCellContent,{selectRowCheckboxAriaLabel:selectRowCheckboxAriaLabel,selectedRowIds:selectedRowIds,onRowSelectionChange:onRowSelectionChange,id:row.id,isSelectable:isSelectable}):React.createElement(StyledText,{size:"s",alignColumn:align},row[name]?row[name]:emptyCellContent),React.createElement(StyledTd,{key:name,alignColumn:align,isFirstColumnSticky:isFirstColumnSticky,isLastColumnSticky:isLastColumnSticky,bodyCellVerticalPadding:bodyCellVerticalPadding,isTableScrolledToLeft:isTableScrolledToLeft,isTableScrolledToRight:isTableScrolledToRight,isActive:isActive,isSelected:isSelected},content)}))});return React.createElement("tbody",{className:className},rowElements)});
|
|
@@ -1 +1 @@
|
|
|
1
|
-
import React from"react";import styled from"@emotion/styled";import isPropValid from"@emotion/is-prop-valid";import{Icon}from"../Icon/Icon";import{Box}from"../Box/Box";let IconTileWrapper=styled("div",{shouldForwardProp:prop=>isPropValid(prop)&&"color"!==prop,target:"
|
|
1
|
+
import React from"react";import styled from"@emotion/styled";import isPropValid from"@emotion/is-prop-valid";import{Icon}from"../Icon/Icon";import{Box}from"../Box/Box";let IconTileWrapper=styled("div",{shouldForwardProp:prop=>isPropValid(prop)&&"color"!==prop,target:"emq2n5f0",label:"IconTileWrapper"})(({theme,color})=>({display:"inline-block",borderRadius:"50%",border:"1px solid",borderColor:color?theme.values.color.badge.borderSubtle[color]:theme.values.color.badge.borderSubtle.default,backgroundColor:color?theme.values.color.badge.background[color]:theme.values.color.badge.background.default,color:color?theme.values.color.badge.foreground[color]:theme.values.color.badge.foreground.gray}),"/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoic3JjL2NvbXBvbmVudHMvSWNvblRpbGUvSWNvblRpbGUudHN4Iiwic291cmNlcyI6WyJzcmMvY29tcG9uZW50cy9JY29uVGlsZS9JY29uVGlsZS50c3giXSwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHR5cGUgeyBBcmlhQXR0cmlidXRlcyB9IGZyb20gXCJyZWFjdFwiO1xuaW1wb3J0IFJlYWN0IGZyb20gXCJyZWFjdFwiO1xuaW1wb3J0IHN0eWxlZCBmcm9tIFwiQGVtb3Rpb24vc3R5bGVkXCI7XG5pbXBvcnQgaXNQcm9wVmFsaWQgZnJvbSBcIkBlbW90aW9uL2lzLXByb3AtdmFsaWRcIjtcbmltcG9ydCB0eXBlIHsgSWNvbk5hbWUgfSBmcm9tIFwiLi4vSWNvbi9JY29uXCI7XG5pbXBvcnQgeyBJY29uIH0gZnJvbSBcIi4uL0ljb24vSWNvblwiO1xuaW1wb3J0IHsgQm94IH0gZnJvbSBcIi4uL0JveC9Cb3hcIjtcblxuZXhwb3J0IGludGVyZmFjZSBJY29uVGlsZVByb3BzIHtcbiAgaWNvbjogSWNvbk5hbWU7XG4gIGNvbG9yPzogXCJncmVlblwiIHwgXCJibHVlXCIgfCBcInllbGxvd1wiIHwgXCJicmFuZFwiIHwgXCJwdXJwbGVcIiB8IFwicmVkXCIgfCBcImdyYXlcIjtcbiAgXCJkYXRhLWUyZS10ZXN0LWlkXCI/OiBzdHJpbmc7XG4gIGFyaWFBdHRyaWJ1dGVzPzogQXJpYUF0dHJpYnV0ZXM7XG59XG5cbmNvbnN0IEljb25UaWxlV3JhcHBlciA9IHN0eWxlZChcImRpdlwiLCB7XG4gIHNob3VsZEZvcndhcmRQcm9wOiAocHJvcCkgPT4gaXNQcm9wVmFsaWQocHJvcCkgJiYgcHJvcCAhPT0gXCJjb2xvclwiLFxufSk8UGljazxJY29uVGlsZVByb3BzLCBcImNvbG9yXCI+PigoeyB0aGVtZSwgY29sb3IgfSkgPT4gKHtcbiAgZGlzcGxheTogXCJpbmxpbmUtYmxvY2tcIixcbiAgYm9yZGVyUmFkaXVzOiBcIjUwJVwiLFxuICBib3JkZXI6IFwiMXB4IHNvbGlkXCIsXG4gIC8vIFRPRE8gVXBkYXRlIGJhZGdlIHRva2VucyB3aXRoIGljb24tdGlsZSBzcGVjaWZpYyB0b2tlbnNcbiAgYm9yZGVyQ29sb3I6IGNvbG9yXG4gICAgPyB0aGVtZS52YWx1ZXMuY29sb3IuYmFkZ2UuYm9yZGVyU3VidGxlW2NvbG9yXVxuICAgIDogdGhlbWUudmFsdWVzLmNvbG9yLmJhZGdlLmJvcmRlclN1YnRsZS5kZWZhdWx0LFxuICBiYWNrZ3JvdW5kQ29sb3I6IGNvbG9yXG4gICAgPyB0aGVtZS52YWx1ZXMuY29sb3IuYmFkZ2UuYmFja2dyb3VuZFtjb2xvcl1cbiAgICA6IHRoZW1lLnZhbHVlcy5jb2xvci5iYWRnZS5iYWNrZ3JvdW5kLmRlZmF1bHQsXG4gIGNvbG9yOiBjb2xvclxuICAgID8gdGhlbWUudmFsdWVzLmNvbG9yLmJhZGdlLmZvcmVncm91bmRbY29sb3JdXG4gICAgOiB0aGVtZS52YWx1ZXMuY29sb3IuYmFkZ2UuZm9yZWdyb3VuZC5ncmF5LFxufSkpO1xuXG5leHBvcnQgY29uc3QgSWNvblRpbGUgPSAoe1xuICBpY29uLFxuICBjb2xvcixcbiAgYXJpYUF0dHJpYnV0ZXMsXG4gIFwiZGF0YS1lMmUtdGVzdC1pZFwiOiBkYXRhRTJlVGVzdElkLFxufTogSWNvblRpbGVQcm9wcyk6IFJlYWN0LlJlYWN0RWxlbWVudCA9PiAoXG4gIDxJY29uVGlsZVdyYXBwZXJcbiAgICBjb2xvcj17Y29sb3J9XG4gICAgZGF0YS1lMmUtdGVzdC1pZD17ZGF0YUUyZVRlc3RJZH1cbiAgICBkYXRhLWNvbG9yPXtjb2xvcn1cbiAgICBkYXRhLWRzLWlkPVwiSWNvblRpbGVcIlxuICAgIHsuLi5hcmlhQXR0cmlidXRlc31cbiAgPlxuICAgIDxCb3ggc3BhY2U9XCJzXCI+XG4gICAgICA8SWNvbiBuYW1lPXtpY29ufSBzaXplPVwibVwiIC8+XG4gICAgPC9Cb3g+XG4gIDwvSWNvblRpbGVXcmFwcGVyPlxuKTtcbiJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFld0IifQ== */");export const IconTile=({icon,color,ariaAttributes,"data-e2e-test-id":dataE2eTestId})=>React.createElement(IconTileWrapper,{color:color,"data-e2e-test-id":dataE2eTestId,"data-color":color,"data-ds-id":"IconTile",...ariaAttributes},React.createElement(Box,{space:"s"},React.createElement(Icon,{name:icon,size:"m"})));
|
|
@@ -1 +1 @@
|
|
|
1
|
-
import React,{forwardRef}from"react";import styled from"@emotion/styled";import{getInputTextStyles}from"../../shared/mixins";import{Inline}from"../Inline/Inline";import{InteractiveBox}from"../InteractiveBox/InteractiveBox";import{NAV_BAR_Z_INDEX}from"./constants";import{Text}from"../Typography/Text/Text";import{TextClamped}from"../Typography/TextClamped/TextClamped";import{PictogramButton}from"../PictogramButton/PictogramButton";import{Box}from"../Box/Box";let StyledFakeInput=styled("div",{target:"e1bw44vj0",label:"StyledFakeInput"})(({theme})=>({...getInputTextStyles({theme,size:"s"}),borderWidth:0,flexGrow:1,width:"100%",position:"relative",zIndex:NAV_BAR_Z_INDEX.overlayContent,padding:theme.variables.size.spacing.zero,backgroundColor:theme.values.color.searchInput.background.default,lineHeight:"normal",display:"flex",alignItems:"center",justifyContent:"space-between",flexWrap:"nowrap"}),"/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoic3JjL2NvbXBvbmVudHMvTmF2QmFyL05hdkJhclNlYXJjaElucHV0LnRzeCIsInNvdXJjZXMiOlsic3JjL2NvbXBvbmVudHMvTmF2QmFyL05hdkJhclNlYXJjaElucHV0LnRzeCJdLCJzb3VyY2VzQ29udGVudCI6WyIvKiBlc2xpbnQtZGlzYWJsZSByZWFjdC9qc3gtcHJvcHMtbm8tc3ByZWFkaW5nICovXG5pbXBvcnQgdHlwZSB7IEFyaWFBdHRyaWJ1dGVzIH0gZnJvbSBcInJlYWN0XCI7XG5pbXBvcnQgUmVhY3QsIHsgZm9yd2FyZFJlZiB9IGZyb20gXCJyZWFjdFwiO1xuaW1wb3J0IHN0eWxlZCBmcm9tIFwiQGVtb3Rpb24vc3R5bGVkXCI7XG5pbXBvcnQgeyBnZXRJbnB1dFRleHRTdHlsZXMgfSBmcm9tIFwiLi4vLi4vc2hhcmVkL21peGluc1wiO1xuaW1wb3J0IHsgSW5saW5lIH0gZnJvbSBcIi4uL0lubGluZS9JbmxpbmVcIjtcbmltcG9ydCB7IEludGVyYWN0aXZlQm94IH0gZnJvbSBcIi4uL0ludGVyYWN0aXZlQm94L0ludGVyYWN0aXZlQm94XCI7XG5pbXBvcnQgeyBOQVZfQkFSX1pfSU5ERVggfSBmcm9tIFwiLi9jb25zdGFudHNcIjtcbmltcG9ydCB7IFRleHQgfSBmcm9tIFwiLi4vVHlwb2dyYXBoeS9UZXh0L1RleHRcIjtcbmltcG9ydCB7IFRleHRDbGFtcGVkIH0gZnJvbSBcIi4uL1R5cG9ncmFwaHkvVGV4dENsYW1wZWQvVGV4dENsYW1wZWRcIjtcbmltcG9ydCB7IFBpY3RvZ3JhbUJ1dHRvbiB9IGZyb20gXCIuLi9QaWN0b2dyYW1CdXR0b24vUGljdG9ncmFtQnV0dG9uXCI7XG5pbXBvcnQgeyBCb3ggfSBmcm9tIFwiLi4vQm94L0JveFwiO1xuXG5jb25zdCBTdHlsZWRGYWtlSW5wdXQgPSBzdHlsZWQoXCJkaXZcIikoKHsgdGhlbWUgfSkgPT4gKHtcbiAgLi4uZ2V0SW5wdXRUZXh0U3R5bGVzKHtcbiAgICB0aGVtZSxcbiAgICBzaXplOiBcInNcIixcbiAgfSksXG4gIGJvcmRlcldpZHRoOiAwLFxuICBmbGV4R3JvdzogMSxcbiAgd2lkdGg6IFwiMTAwJVwiLFxuICBwb3NpdGlvbjogXCJyZWxhdGl2ZVwiLFxuICB6SW5kZXg6IE5BVl9CQVJfWl9JTkRFWC5vdmVybGF5Q29udGVudCxcbiAgcGFkZGluZzogdGhlbWUudmFyaWFibGVzLnNpemUuc3BhY2luZy56ZXJvLFxuICBiYWNrZ3JvdW5kQ29sb3I6IHRoZW1lLnZhbHVlcy5jb2xvci5zZWFyY2hJbnB1dC5iYWNrZ3JvdW5kLmRlZmF1bHQsXG4gIGxpbmVIZWlnaHQ6IFwibm9ybWFsXCIsXG4gIGRpc3BsYXk6IFwiZmxleFwiLFxuICBhbGlnbkl0ZW1zOiBcImNlbnRlclwiLFxuICBqdXN0aWZ5Q29udGVudDogXCJzcGFjZS1iZXR3ZWVuXCIsXG4gIGZsZXhXcmFwOiBcIm5vd3JhcFwiLFxufSkpO1xuXG5jb25zdCBJdGFsaWNUZXh0Q2xhbXBlZCA9IHN0eWxlZChUZXh0Q2xhbXBlZCkoKCkgPT4gKHtcbiAgZm9udFN0eWxlOiBcIml0YWxpY1wiLFxufSkpO1xuXG5leHBvcnQgdHlwZSBOYXZCYXJTZWFyY2hJbnB1dFByb3BzID0ge1xuICBvbkNsaWNrPzogKGU6IFJlYWN0Lk1vdXNlRXZlbnQpID0+IHZvaWQ7XG4gIG9uRm9jdXM/OiAoZTogUmVhY3QuRm9jdXNFdmVudCkgPT4gdm9pZDtcbiAgb25CbHVyPzogKGU6IFJlYWN0LkZvY3VzRXZlbnQpID0+IHZvaWQ7XG4gIG9uQ2xlYXI/OiAoZTogUmVhY3QuTW91c2VFdmVudCkgPT4gdm9pZDtcbiAgYXJpYUF0dHJpYnV0ZXM/OiBBcmlhQXR0cmlidXRlcztcbiAgdmFsdWU/OiBzdHJpbmc7XG4gIHBsYWNlaG9sZGVyPzogc3RyaW5nO1xufTtcblxuZXhwb3J0IGNvbnN0IE5hdkJhclNlYXJjaElucHV0ID0gZm9yd2FyZFJlZihcbiAgKFxuICAgIHtcbiAgICAgIG9uQmx1cixcbiAgICAgIG9uQ2xpY2ssXG4gICAgICBvbkZvY3VzLFxuICAgICAgcGxhY2Vob2xkZXIsXG4gICAgICB2YWx1ZSxcbiAgICAgIG9uQ2xlYXIsXG4gICAgICAuLi5yZXN0XG4gICAgfTogTmF2QmFyU2VhcmNoSW5wdXRQcm9wcyxcbiAgICByZWY6IFJlYWN0LlJlZjxIVE1MQnV0dG9uRWxlbWVudD5cbiAgKTogUmVhY3QuUmVhY3RFbGVtZW50ID0+IHtcbiAgICBjb25zdCBoYXNQbGFjZWhvbGRlciA9ICF2YWx1ZSAmJiAhIXBsYWNlaG9sZGVyO1xuXG4gICAgcmV0dXJuIChcbiAgICAgIDxTdHlsZWRGYWtlSW5wdXQ+XG4gICAgICAgIDxJbnRlcmFjdGl2ZUJveFxuICAgICAgICAgIHJlZj17cmVmfVxuICAgICAgICAgIG9uQ2xpY2s9e29uQ2xpY2t9XG4gICAgICAgICAgb25Gb2N1cz17b25Gb2N1c31cbiAgICAgICAgICBvbkJsdXI9e29uQmx1cn1cbiAgICAgICAgICBsU3BhY2U9XCJzXCJcbiAgICAgICAgICByU3BhY2U9XCJ4c1wiXG4gICAgICAgICAgdlNwYWNlPXtbXCJ4c1wiLCBcInh4c1wiXX1cbiAgICAgICAgICBmdWxsV2lkdGhcbiAgICAgICAgICB7Li4ucmVzdH1cbiAgICAgICAgPlxuICAgICAgICAgIDxJbmxpbmVcbiAgICAgICAgICAgIHZBbGlnbkl0ZW1zPVwiY2VudGVyXCJcbiAgICAgICAgICAgIGFsaWduSXRlbXM9XCJzcGFjZUJldHdlZW5cIlxuICAgICAgICAgICAgc3BhY2U9XCJ4eHNcIlxuICAgICAgICAgICAgbm9XcmFwXG4gICAgICAgICAgICBmdWxsV2lkdGhcbiAgICAgICAgICA+XG4gICAgICAgICAgICA8SW5saW5lIHZBbGlnbkl0ZW1zPVwiY2VudGVyXCIgYWxpZ25JdGVtcz1cImNlbnRlclwiIHNwYWNlPVwieHhzXCIgbm9XcmFwPlxuICAgICAgICAgICAgICB7dmFsdWUgJiYgKFxuICAgICAgICAgICAgICAgIDxUZXh0Q2xhbXBlZCBjb2xvcj1cInByaW1hcnlcIiBzaXplPVwibVwiIGFzPVwic3BhblwiPlxuICAgICAgICAgICAgICAgICAge3ZhbHVlfVxuICAgICAgICAgICAgICAgIDwvVGV4dENsYW1wZWQ+XG4gICAgICAgICAgICAgICl9XG4gICAgICAgICAgICAgIHtoYXNQbGFjZWhvbGRlciAmJiAoXG4gICAgICAgICAgICAgICAgPEl0YWxpY1RleHRDbGFtcGVkIHNpemU9XCJtXCIgYXM9XCJzcGFuXCIgY29sb3I9XCJ0ZXJ0aWFyeVwiPlxuICAgICAgICAgICAgICAgICAge3BsYWNlaG9sZGVyfVxuICAgICAgICAgICAgICAgIDwvSXRhbGljVGV4dENsYW1wZWQ+XG4gICAgICAgICAgICAgICl9XG4gICAgICAgICAgICA8L0lubGluZT5cbiAgICAgICAgICAgIHtoYXNQbGFjZWhvbGRlciAmJiAoXG4gICAgICAgICAgICAgIDxUZXh0IHNpemU9XCJzXCIgYXM9XCJzcGFuXCIgY29sb3I9XCJ0ZXJ0aWFyeVwiPlxuICAgICAgICAgICAgICAgIOKMmEtcbiAgICAgICAgICAgICAgPC9UZXh0PlxuICAgICAgICAgICAgKX1cbiAgICAgICAgICA8L0lubGluZT5cbiAgICAgICAgPC9JbnRlcmFjdGl2ZUJveD5cbiAgICAgICAge3ZhbHVlICYmIChcbiAgICAgICAgICA8Qm94IHNwYWNlPVwieHhzXCIgdlNwYWNlPVwieHh4c1wiPlxuICAgICAgICAgICAgPFBpY3RvZ3JhbUJ1dHRvblxuICAgICAgICAgICAgICBpY29uPVwieFwiXG4gICAgICAgICAgICAgIHNpemU9XCJ4c1wiXG4gICAgICAgICAgICAgIGNvbG9yPVwicXVhdGVybmFyeVwiXG4gICAgICAgICAgICAgIG9uQ2xpY2s9e29uQ2xlYXJ9XG4gICAgICAgICAgICAvPlxuICAgICAgICAgIDwvQm94PlxuICAgICAgICApfVxuICAgICAgPC9TdHlsZWRGYWtlSW5wdXQ+XG4gICAgKTtcbiAgfVxuKTtcbiJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFhd0IifQ== */"),ItalicTextClamped=styled(TextClamped,{target:"e1bw44vj1",label:"ItalicTextClamped"})(()=>({fontStyle:"italic"}),"/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoic3JjL2NvbXBvbmVudHMvTmF2QmFyL05hdkJhclNlYXJjaElucHV0LnRzeCIsInNvdXJjZXMiOlsic3JjL2NvbXBvbmVudHMvTmF2QmFyL05hdkJhclNlYXJjaElucHV0LnRzeCJdLCJzb3VyY2VzQ29udGVudCI6WyIvKiBlc2xpbnQtZGlzYWJsZSByZWFjdC9qc3gtcHJvcHMtbm8tc3ByZWFkaW5nICovXG5pbXBvcnQgdHlwZSB7IEFyaWFBdHRyaWJ1dGVzIH0gZnJvbSBcInJlYWN0XCI7XG5pbXBvcnQgUmVhY3QsIHsgZm9yd2FyZFJlZiB9IGZyb20gXCJyZWFjdFwiO1xuaW1wb3J0IHN0eWxlZCBmcm9tIFwiQGVtb3Rpb24vc3R5bGVkXCI7XG5pbXBvcnQgeyBnZXRJbnB1dFRleHRTdHlsZXMgfSBmcm9tIFwiLi4vLi4vc2hhcmVkL21peGluc1wiO1xuaW1wb3J0IHsgSW5saW5lIH0gZnJvbSBcIi4uL0lubGluZS9JbmxpbmVcIjtcbmltcG9ydCB7IEludGVyYWN0aXZlQm94IH0gZnJvbSBcIi4uL0ludGVyYWN0aXZlQm94L0ludGVyYWN0aXZlQm94XCI7XG5pbXBvcnQgeyBOQVZfQkFSX1pfSU5ERVggfSBmcm9tIFwiLi9jb25zdGFudHNcIjtcbmltcG9ydCB7IFRleHQgfSBmcm9tIFwiLi4vVHlwb2dyYXBoeS9UZXh0L1RleHRcIjtcbmltcG9ydCB7IFRleHRDbGFtcGVkIH0gZnJvbSBcIi4uL1R5cG9ncmFwaHkvVGV4dENsYW1wZWQvVGV4dENsYW1wZWRcIjtcbmltcG9ydCB7IFBpY3RvZ3JhbUJ1dHRvbiB9IGZyb20gXCIuLi9QaWN0b2dyYW1CdXR0b24vUGljdG9ncmFtQnV0dG9uXCI7XG5pbXBvcnQgeyBCb3ggfSBmcm9tIFwiLi4vQm94L0JveFwiO1xuXG5jb25zdCBTdHlsZWRGYWtlSW5wdXQgPSBzdHlsZWQoXCJkaXZcIikoKHsgdGhlbWUgfSkgPT4gKHtcbiAgLi4uZ2V0SW5wdXRUZXh0U3R5bGVzKHtcbiAgICB0aGVtZSxcbiAgICBzaXplOiBcInNcIixcbiAgfSksXG4gIGJvcmRlcldpZHRoOiAwLFxuICBmbGV4R3JvdzogMSxcbiAgd2lkdGg6IFwiMTAwJVwiLFxuICBwb3NpdGlvbjogXCJyZWxhdGl2ZVwiLFxuICB6SW5kZXg6IE5BVl9CQVJfWl9JTkRFWC5vdmVybGF5Q29udGVudCxcbiAgcGFkZGluZzogdGhlbWUudmFyaWFibGVzLnNpemUuc3BhY2luZy56ZXJvLFxuICBiYWNrZ3JvdW5kQ29sb3I6IHRoZW1lLnZhbHVlcy5jb2xvci5zZWFyY2hJbnB1dC5iYWNrZ3JvdW5kLmRlZmF1bHQsXG4gIGxpbmVIZWlnaHQ6IFwibm9ybWFsXCIsXG4gIGRpc3BsYXk6IFwiZmxleFwiLFxuICBhbGlnbkl0ZW1zOiBcImNlbnRlclwiLFxuICBqdXN0aWZ5Q29udGVudDogXCJzcGFjZS1iZXR3ZWVuXCIsXG4gIGZsZXhXcmFwOiBcIm5vd3JhcFwiLFxufSkpO1xuXG5jb25zdCBJdGFsaWNUZXh0Q2xhbXBlZCA9IHN0eWxlZChUZXh0Q2xhbXBlZCkoKCkgPT4gKHtcbiAgZm9udFN0eWxlOiBcIml0YWxpY1wiLFxufSkpO1xuXG5leHBvcnQgdHlwZSBOYXZCYXJTZWFyY2hJbnB1dFByb3BzID0ge1xuICBvbkNsaWNrPzogKGU6IFJlYWN0Lk1vdXNlRXZlbnQpID0+IHZvaWQ7XG4gIG9uRm9jdXM/OiAoZTogUmVhY3QuRm9jdXNFdmVudCkgPT4gdm9pZDtcbiAgb25CbHVyPzogKGU6IFJlYWN0LkZvY3VzRXZlbnQpID0+IHZvaWQ7XG4gIG9uQ2xlYXI/OiAoZTogUmVhY3QuTW91c2VFdmVudCkgPT4gdm9pZDtcbiAgYXJpYUF0dHJpYnV0ZXM/OiBBcmlhQXR0cmlidXRlcztcbiAgdmFsdWU/OiBzdHJpbmc7XG4gIHBsYWNlaG9sZGVyPzogc3RyaW5nO1xufTtcblxuZXhwb3J0IGNvbnN0IE5hdkJhclNlYXJjaElucHV0ID0gZm9yd2FyZFJlZihcbiAgKFxuICAgIHtcbiAgICAgIG9uQmx1cixcbiAgICAgIG9uQ2xpY2ssXG4gICAgICBvbkZvY3VzLFxuICAgICAgcGxhY2Vob2xkZXIsXG4gICAgICB2YWx1ZSxcbiAgICAgIG9uQ2xlYXIsXG4gICAgICAuLi5yZXN0XG4gICAgfTogTmF2QmFyU2VhcmNoSW5wdXRQcm9wcyxcbiAgICByZWY6IFJlYWN0LlJlZjxIVE1MQnV0dG9uRWxlbWVudD5cbiAgKTogUmVhY3QuUmVhY3RFbGVtZW50ID0+IHtcbiAgICBjb25zdCBoYXNQbGFjZWhvbGRlciA9ICF2YWx1ZSAmJiAhIXBsYWNlaG9sZGVyO1xuXG4gICAgcmV0dXJuIChcbiAgICAgIDxTdHlsZWRGYWtlSW5wdXQ+XG4gICAgICAgIDxJbnRlcmFjdGl2ZUJveFxuICAgICAgICAgIHJlZj17cmVmfVxuICAgICAgICAgIG9uQ2xpY2s9e29uQ2xpY2t9XG4gICAgICAgICAgb25Gb2N1cz17b25Gb2N1c31cbiAgICAgICAgICBvbkJsdXI9e29uQmx1cn1cbiAgICAgICAgICBsU3BhY2U9XCJzXCJcbiAgICAgICAgICByU3BhY2U9XCJ4c1wiXG4gICAgICAgICAgdlNwYWNlPXtbXCJ4c1wiLCBcInh4c1wiXX1cbiAgICAgICAgICBmdWxsV2lkdGhcbiAgICAgICAgICB7Li4ucmVzdH1cbiAgICAgICAgPlxuICAgICAgICAgIDxJbmxpbmVcbiAgICAgICAgICAgIHZBbGlnbkl0ZW1zPVwiY2VudGVyXCJcbiAgICAgICAgICAgIGFsaWduSXRlbXM9XCJzcGFjZUJldHdlZW5cIlxuICAgICAgICAgICAgc3BhY2U9XCJ4eHNcIlxuICAgICAgICAgICAgbm9XcmFwXG4gICAgICAgICAgICBmdWxsV2lkdGhcbiAgICAgICAgICA+XG4gICAgICAgICAgICA8SW5saW5lIHZBbGlnbkl0ZW1zPVwiY2VudGVyXCIgYWxpZ25JdGVtcz1cImNlbnRlclwiIHNwYWNlPVwieHhzXCIgbm9XcmFwPlxuICAgICAgICAgICAgICB7dmFsdWUgJiYgKFxuICAgICAgICAgICAgICAgIDxUZXh0Q2xhbXBlZCBjb2xvcj1cInByaW1hcnlcIiBzaXplPVwibVwiIGFzPVwic3BhblwiPlxuICAgICAgICAgICAgICAgICAge3ZhbHVlfVxuICAgICAgICAgICAgICAgIDwvVGV4dENsYW1wZWQ+XG4gICAgICAgICAgICAgICl9XG4gICAgICAgICAgICAgIHtoYXNQbGFjZWhvbGRlciAmJiAoXG4gICAgICAgICAgICAgICAgPEl0YWxpY1RleHRDbGFtcGVkIHNpemU9XCJtXCIgYXM9XCJzcGFuXCIgY29sb3I9XCJ0ZXJ0aWFyeVwiPlxuICAgICAgICAgICAgICAgICAge3BsYWNlaG9sZGVyfVxuICAgICAgICAgICAgICAgIDwvSXRhbGljVGV4dENsYW1wZWQ+XG4gICAgICAgICAgICAgICl9XG4gICAgICAgICAgICA8L0lubGluZT5cbiAgICAgICAgICAgIHtoYXNQbGFjZWhvbGRlciAmJiAoXG4gICAgICAgICAgICAgIDxUZXh0IHNpemU9XCJzXCIgYXM9XCJzcGFuXCIgY29sb3I9XCJ0ZXJ0aWFyeVwiPlxuICAgICAgICAgICAgICAgIOKMmEtcbiAgICAgICAgICAgICAgPC9UZXh0PlxuICAgICAgICAgICAgKX1cbiAgICAgICAgICA8L0lubGluZT5cbiAgICAgICAgPC9JbnRlcmFjdGl2ZUJveD5cbiAgICAgICAge3ZhbHVlICYmIChcbiAgICAgICAgICA8Qm94IHNwYWNlPVwieHhzXCIgdlNwYWNlPVwieHh4c1wiPlxuICAgICAgICAgICAgPFBpY3RvZ3JhbUJ1dHRvblxuICAgICAgICAgICAgICBpY29uPVwieFwiXG4gICAgICAgICAgICAgIHNpemU9XCJ4c1wiXG4gICAgICAgICAgICAgIGNvbG9yPVwicXVhdGVybmFyeVwiXG4gICAgICAgICAgICAgIG9uQ2xpY2s9e29uQ2xlYXJ9XG4gICAgICAgICAgICAvPlxuICAgICAgICAgIDwvQm94PlxuICAgICAgICApfVxuICAgICAgPC9TdHlsZWRGYWtlSW5wdXQ+XG4gICAgKTtcbiAgfVxuKTtcbiJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFnQzBCIn0= */");export const NavBarSearchInput=forwardRef(({onBlur,onClick,onFocus,placeholder,value,onClear,...rest},ref)=>{let hasPlaceholder=!value&&!!placeholder;return React.createElement(StyledFakeInput,null,React.createElement(InteractiveBox,{ref:ref,onClick:onClick,onFocus:onFocus,onBlur:onBlur,lSpace:"s",rSpace:"xs",vSpace:["xs","xxs"],fullWidth:!0,...rest},React.createElement(Inline,{vAlignItems:"center",alignItems:"spaceBetween",space:"xxs",noWrap:!0,fullWidth:!0},React.createElement(Inline,{vAlignItems:"center",alignItems:"center",space:"xxs",noWrap:!0},value&&React.createElement(TextClamped,{color:"primary",size:"m",as:"span"},value),hasPlaceholder&&React.createElement(ItalicTextClamped,{size:"m",as:"span",color:"tertiary"},placeholder)),hasPlaceholder&&React.createElement(Text,{size:"s",as:"span",color:"tertiary"},"⌘K"))),value&&React.createElement(Box,{space:"xxs",vSpace:"xxxs"},React.createElement(PictogramButton,{icon:"x",size:"xs",color:"quaternary",onClick:onClear})))});
|
|
1
|
+
import React,{forwardRef}from"react";import styled from"@emotion/styled";import{getInputTextStyles}from"../../shared/mixins";import{useIsMacOS}from"../../shared/useIsMacOS";import{Inline}from"../Inline/Inline";import{InteractiveBox}from"../InteractiveBox/InteractiveBox";import{NAV_BAR_Z_INDEX}from"./constants";import{Text}from"../Typography/Text/Text";import{TextClamped}from"../Typography/TextClamped/TextClamped";import{PictogramButton}from"../PictogramButton/PictogramButton";import{Box}from"../Box/Box";let StyledFakeInput=styled("div",{target:"e1gqbwe40",label:"StyledFakeInput"})(({theme})=>({...getInputTextStyles({theme,size:"s"}),borderWidth:0,flexGrow:1,width:"100%",position:"relative",zIndex:NAV_BAR_Z_INDEX.overlayContent,padding:theme.variables.size.spacing.zero,backgroundColor:theme.values.color.searchInput.background.default,lineHeight:"normal",display:"flex",alignItems:"center",justifyContent:"space-between",flexWrap:"nowrap"}),"/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoic3JjL2NvbXBvbmVudHMvTmF2QmFyL05hdkJhclNlYXJjaElucHV0LnRzeCIsInNvdXJjZXMiOlsic3JjL2NvbXBvbmVudHMvTmF2QmFyL05hdkJhclNlYXJjaElucHV0LnRzeCJdLCJzb3VyY2VzQ29udGVudCI6WyIvKiBlc2xpbnQtZGlzYWJsZSByZWFjdC9qc3gtcHJvcHMtbm8tc3ByZWFkaW5nICovXG5pbXBvcnQgdHlwZSB7IEFyaWFBdHRyaWJ1dGVzIH0gZnJvbSBcInJlYWN0XCI7XG5pbXBvcnQgUmVhY3QsIHsgZm9yd2FyZFJlZiB9IGZyb20gXCJyZWFjdFwiO1xuaW1wb3J0IHN0eWxlZCBmcm9tIFwiQGVtb3Rpb24vc3R5bGVkXCI7XG5pbXBvcnQgeyBnZXRJbnB1dFRleHRTdHlsZXMgfSBmcm9tIFwiLi4vLi4vc2hhcmVkL21peGluc1wiO1xuaW1wb3J0IHsgdXNlSXNNYWNPUyB9IGZyb20gXCIuLi8uLi9zaGFyZWQvdXNlSXNNYWNPU1wiO1xuaW1wb3J0IHsgSW5saW5lIH0gZnJvbSBcIi4uL0lubGluZS9JbmxpbmVcIjtcbmltcG9ydCB7IEludGVyYWN0aXZlQm94IH0gZnJvbSBcIi4uL0ludGVyYWN0aXZlQm94L0ludGVyYWN0aXZlQm94XCI7XG5pbXBvcnQgeyBOQVZfQkFSX1pfSU5ERVggfSBmcm9tIFwiLi9jb25zdGFudHNcIjtcbmltcG9ydCB7IFRleHQgfSBmcm9tIFwiLi4vVHlwb2dyYXBoeS9UZXh0L1RleHRcIjtcbmltcG9ydCB7IFRleHRDbGFtcGVkIH0gZnJvbSBcIi4uL1R5cG9ncmFwaHkvVGV4dENsYW1wZWQvVGV4dENsYW1wZWRcIjtcbmltcG9ydCB7IFBpY3RvZ3JhbUJ1dHRvbiB9IGZyb20gXCIuLi9QaWN0b2dyYW1CdXR0b24vUGljdG9ncmFtQnV0dG9uXCI7XG5pbXBvcnQgeyBCb3ggfSBmcm9tIFwiLi4vQm94L0JveFwiO1xuXG5jb25zdCBTdHlsZWRGYWtlSW5wdXQgPSBzdHlsZWQoXCJkaXZcIikoKHsgdGhlbWUgfSkgPT4gKHtcbiAgLi4uZ2V0SW5wdXRUZXh0U3R5bGVzKHtcbiAgICB0aGVtZSxcbiAgICBzaXplOiBcInNcIixcbiAgfSksXG4gIGJvcmRlcldpZHRoOiAwLFxuICBmbGV4R3JvdzogMSxcbiAgd2lkdGg6IFwiMTAwJVwiLFxuICBwb3NpdGlvbjogXCJyZWxhdGl2ZVwiLFxuICB6SW5kZXg6IE5BVl9CQVJfWl9JTkRFWC5vdmVybGF5Q29udGVudCxcbiAgcGFkZGluZzogdGhlbWUudmFyaWFibGVzLnNpemUuc3BhY2luZy56ZXJvLFxuICBiYWNrZ3JvdW5kQ29sb3I6IHRoZW1lLnZhbHVlcy5jb2xvci5zZWFyY2hJbnB1dC5iYWNrZ3JvdW5kLmRlZmF1bHQsXG4gIGxpbmVIZWlnaHQ6IFwibm9ybWFsXCIsXG4gIGRpc3BsYXk6IFwiZmxleFwiLFxuICBhbGlnbkl0ZW1zOiBcImNlbnRlclwiLFxuICBqdXN0aWZ5Q29udGVudDogXCJzcGFjZS1iZXR3ZWVuXCIsXG4gIGZsZXhXcmFwOiBcIm5vd3JhcFwiLFxufSkpO1xuXG5jb25zdCBJdGFsaWNUZXh0Q2xhbXBlZCA9IHN0eWxlZChUZXh0Q2xhbXBlZCkoKCkgPT4gKHtcbiAgZm9udFN0eWxlOiBcIml0YWxpY1wiLFxufSkpO1xuXG5leHBvcnQgdHlwZSBOYXZCYXJTZWFyY2hJbnB1dFByb3BzID0ge1xuICBvbkNsaWNrPzogKGU6IFJlYWN0Lk1vdXNlRXZlbnQpID0+IHZvaWQ7XG4gIG9uRm9jdXM/OiAoZTogUmVhY3QuRm9jdXNFdmVudCkgPT4gdm9pZDtcbiAgb25CbHVyPzogKGU6IFJlYWN0LkZvY3VzRXZlbnQpID0+IHZvaWQ7XG4gIG9uQ2xlYXI/OiAoZTogUmVhY3QuTW91c2VFdmVudCkgPT4gdm9pZDtcbiAgYXJpYUF0dHJpYnV0ZXM/OiBBcmlhQXR0cmlidXRlcztcbiAgdmFsdWU/OiBzdHJpbmc7XG4gIHBsYWNlaG9sZGVyPzogc3RyaW5nO1xufTtcblxuZXhwb3J0IGNvbnN0IE5hdkJhclNlYXJjaElucHV0ID0gZm9yd2FyZFJlZihcbiAgKFxuICAgIHtcbiAgICAgIG9uQmx1cixcbiAgICAgIG9uQ2xpY2ssXG4gICAgICBvbkZvY3VzLFxuICAgICAgcGxhY2Vob2xkZXIsXG4gICAgICB2YWx1ZSxcbiAgICAgIG9uQ2xlYXIsXG4gICAgICAuLi5yZXN0XG4gICAgfTogTmF2QmFyU2VhcmNoSW5wdXRQcm9wcyxcbiAgICByZWY6IFJlYWN0LlJlZjxIVE1MQnV0dG9uRWxlbWVudD5cbiAgKTogUmVhY3QuUmVhY3RFbGVtZW50ID0+IHtcbiAgICBjb25zdCBpc01hYyA9IHVzZUlzTWFjT1MoKTtcbiAgICBjb25zdCBob3RrZXkgPSBpc01hYyA/IChcbiAgICAgIDxUZXh0IHNpemU9XCJtXCIgYXM9XCJzcGFuXCIgY29sb3I9XCJ0ZXJ0aWFyeVwiPlxuICAgICAgICDijJhcbiAgICAgIDwvVGV4dD5cbiAgICApIDogKFxuICAgICAgXCJDdHJsK1wiXG4gICAgKTtcbiAgICBjb25zdCBoYXNQbGFjZWhvbGRlciA9ICF2YWx1ZSAmJiAhIXBsYWNlaG9sZGVyO1xuXG4gICAgcmV0dXJuIChcbiAgICAgIDxTdHlsZWRGYWtlSW5wdXQ+XG4gICAgICAgIDxJbnRlcmFjdGl2ZUJveFxuICAgICAgICAgIHJlZj17cmVmfVxuICAgICAgICAgIG9uQ2xpY2s9e29uQ2xpY2t9XG4gICAgICAgICAgb25Gb2N1cz17b25Gb2N1c31cbiAgICAgICAgICBvbkJsdXI9e29uQmx1cn1cbiAgICAgICAgICBsU3BhY2U9XCJzXCJcbiAgICAgICAgICByU3BhY2U9XCJ4c1wiXG4gICAgICAgICAgdlNwYWNlPXtbXCJ4c1wiLCBcInh4c1wiXX1cbiAgICAgICAgICBmdWxsV2lkdGhcbiAgICAgICAgICB7Li4ucmVzdH1cbiAgICAgICAgPlxuICAgICAgICAgIDxJbmxpbmVcbiAgICAgICAgICAgIHZBbGlnbkl0ZW1zPVwiY2VudGVyXCJcbiAgICAgICAgICAgIGFsaWduSXRlbXM9XCJzcGFjZUJldHdlZW5cIlxuICAgICAgICAgICAgc3BhY2U9XCJ4eHNcIlxuICAgICAgICAgICAgbm9XcmFwXG4gICAgICAgICAgICBmdWxsV2lkdGhcbiAgICAgICAgICA+XG4gICAgICAgICAgICA8SW5saW5lIHZBbGlnbkl0ZW1zPVwiY2VudGVyXCIgYWxpZ25JdGVtcz1cImNlbnRlclwiIHNwYWNlPVwieHhzXCIgbm9XcmFwPlxuICAgICAgICAgICAgICB7dmFsdWUgJiYgKFxuICAgICAgICAgICAgICAgIDxUZXh0Q2xhbXBlZCBjb2xvcj1cInByaW1hcnlcIiBzaXplPVwibVwiIGFzPVwic3BhblwiPlxuICAgICAgICAgICAgICAgICAge3ZhbHVlfVxuICAgICAgICAgICAgICAgIDwvVGV4dENsYW1wZWQ+XG4gICAgICAgICAgICAgICl9XG4gICAgICAgICAgICAgIHtoYXNQbGFjZWhvbGRlciAmJiAoXG4gICAgICAgICAgICAgICAgPEl0YWxpY1RleHRDbGFtcGVkIHNpemU9XCJtXCIgYXM9XCJzcGFuXCIgY29sb3I9XCJ0ZXJ0aWFyeVwiPlxuICAgICAgICAgICAgICAgICAge3BsYWNlaG9sZGVyfVxuICAgICAgICAgICAgICAgIDwvSXRhbGljVGV4dENsYW1wZWQ+XG4gICAgICAgICAgICAgICl9XG4gICAgICAgICAgICA8L0lubGluZT5cbiAgICAgICAgICAgIHtoYXNQbGFjZWhvbGRlciAmJiAoXG4gICAgICAgICAgICAgIDxUZXh0IHNpemU9XCJ4c1wiIGFzPVwic3BhblwiIGNvbG9yPVwidGVydGlhcnlcIj5cbiAgICAgICAgICAgICAgICB7aG90a2V5fUtcbiAgICAgICAgICAgICAgPC9UZXh0PlxuICAgICAgICAgICAgKX1cbiAgICAgICAgICA8L0lubGluZT5cbiAgICAgICAgPC9JbnRlcmFjdGl2ZUJveD5cbiAgICAgICAge3ZhbHVlICYmIChcbiAgICAgICAgICA8Qm94IHNwYWNlPVwieHhzXCIgdlNwYWNlPVwieHh4c1wiPlxuICAgICAgICAgICAgPFBpY3RvZ3JhbUJ1dHRvblxuICAgICAgICAgICAgICBpY29uPVwieFwiXG4gICAgICAgICAgICAgIHNpemU9XCJ4c1wiXG4gICAgICAgICAgICAgIGNvbG9yPVwicXVhdGVybmFyeVwiXG4gICAgICAgICAgICAgIG9uQ2xpY2s9e29uQ2xlYXJ9XG4gICAgICAgICAgICAvPlxuICAgICAgICAgIDwvQm94PlxuICAgICAgICApfVxuICAgICAgPC9TdHlsZWRGYWtlSW5wdXQ+XG4gICAgKTtcbiAgfVxuKTtcbiJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFjd0IifQ== */"),ItalicTextClamped=styled(TextClamped,{target:"e1gqbwe41",label:"ItalicTextClamped"})(()=>({fontStyle:"italic"}),"/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoic3JjL2NvbXBvbmVudHMvTmF2QmFyL05hdkJhclNlYXJjaElucHV0LnRzeCIsInNvdXJjZXMiOlsic3JjL2NvbXBvbmVudHMvTmF2QmFyL05hdkJhclNlYXJjaElucHV0LnRzeCJdLCJzb3VyY2VzQ29udGVudCI6WyIvKiBlc2xpbnQtZGlzYWJsZSByZWFjdC9qc3gtcHJvcHMtbm8tc3ByZWFkaW5nICovXG5pbXBvcnQgdHlwZSB7IEFyaWFBdHRyaWJ1dGVzIH0gZnJvbSBcInJlYWN0XCI7XG5pbXBvcnQgUmVhY3QsIHsgZm9yd2FyZFJlZiB9IGZyb20gXCJyZWFjdFwiO1xuaW1wb3J0IHN0eWxlZCBmcm9tIFwiQGVtb3Rpb24vc3R5bGVkXCI7XG5pbXBvcnQgeyBnZXRJbnB1dFRleHRTdHlsZXMgfSBmcm9tIFwiLi4vLi4vc2hhcmVkL21peGluc1wiO1xuaW1wb3J0IHsgdXNlSXNNYWNPUyB9IGZyb20gXCIuLi8uLi9zaGFyZWQvdXNlSXNNYWNPU1wiO1xuaW1wb3J0IHsgSW5saW5lIH0gZnJvbSBcIi4uL0lubGluZS9JbmxpbmVcIjtcbmltcG9ydCB7IEludGVyYWN0aXZlQm94IH0gZnJvbSBcIi4uL0ludGVyYWN0aXZlQm94L0ludGVyYWN0aXZlQm94XCI7XG5pbXBvcnQgeyBOQVZfQkFSX1pfSU5ERVggfSBmcm9tIFwiLi9jb25zdGFudHNcIjtcbmltcG9ydCB7IFRleHQgfSBmcm9tIFwiLi4vVHlwb2dyYXBoeS9UZXh0L1RleHRcIjtcbmltcG9ydCB7IFRleHRDbGFtcGVkIH0gZnJvbSBcIi4uL1R5cG9ncmFwaHkvVGV4dENsYW1wZWQvVGV4dENsYW1wZWRcIjtcbmltcG9ydCB7IFBpY3RvZ3JhbUJ1dHRvbiB9IGZyb20gXCIuLi9QaWN0b2dyYW1CdXR0b24vUGljdG9ncmFtQnV0dG9uXCI7XG5pbXBvcnQgeyBCb3ggfSBmcm9tIFwiLi4vQm94L0JveFwiO1xuXG5jb25zdCBTdHlsZWRGYWtlSW5wdXQgPSBzdHlsZWQoXCJkaXZcIikoKHsgdGhlbWUgfSkgPT4gKHtcbiAgLi4uZ2V0SW5wdXRUZXh0U3R5bGVzKHtcbiAgICB0aGVtZSxcbiAgICBzaXplOiBcInNcIixcbiAgfSksXG4gIGJvcmRlcldpZHRoOiAwLFxuICBmbGV4R3JvdzogMSxcbiAgd2lkdGg6IFwiMTAwJVwiLFxuICBwb3NpdGlvbjogXCJyZWxhdGl2ZVwiLFxuICB6SW5kZXg6IE5BVl9CQVJfWl9JTkRFWC5vdmVybGF5Q29udGVudCxcbiAgcGFkZGluZzogdGhlbWUudmFyaWFibGVzLnNpemUuc3BhY2luZy56ZXJvLFxuICBiYWNrZ3JvdW5kQ29sb3I6IHRoZW1lLnZhbHVlcy5jb2xvci5zZWFyY2hJbnB1dC5iYWNrZ3JvdW5kLmRlZmF1bHQsXG4gIGxpbmVIZWlnaHQ6IFwibm9ybWFsXCIsXG4gIGRpc3BsYXk6IFwiZmxleFwiLFxuICBhbGlnbkl0ZW1zOiBcImNlbnRlclwiLFxuICBqdXN0aWZ5Q29udGVudDogXCJzcGFjZS1iZXR3ZWVuXCIsXG4gIGZsZXhXcmFwOiBcIm5vd3JhcFwiLFxufSkpO1xuXG5jb25zdCBJdGFsaWNUZXh0Q2xhbXBlZCA9IHN0eWxlZChUZXh0Q2xhbXBlZCkoKCkgPT4gKHtcbiAgZm9udFN0eWxlOiBcIml0YWxpY1wiLFxufSkpO1xuXG5leHBvcnQgdHlwZSBOYXZCYXJTZWFyY2hJbnB1dFByb3BzID0ge1xuICBvbkNsaWNrPzogKGU6IFJlYWN0Lk1vdXNlRXZlbnQpID0+IHZvaWQ7XG4gIG9uRm9jdXM/OiAoZTogUmVhY3QuRm9jdXNFdmVudCkgPT4gdm9pZDtcbiAgb25CbHVyPzogKGU6IFJlYWN0LkZvY3VzRXZlbnQpID0+IHZvaWQ7XG4gIG9uQ2xlYXI/OiAoZTogUmVhY3QuTW91c2VFdmVudCkgPT4gdm9pZDtcbiAgYXJpYUF0dHJpYnV0ZXM/OiBBcmlhQXR0cmlidXRlcztcbiAgdmFsdWU/OiBzdHJpbmc7XG4gIHBsYWNlaG9sZGVyPzogc3RyaW5nO1xufTtcblxuZXhwb3J0IGNvbnN0IE5hdkJhclNlYXJjaElucHV0ID0gZm9yd2FyZFJlZihcbiAgKFxuICAgIHtcbiAgICAgIG9uQmx1cixcbiAgICAgIG9uQ2xpY2ssXG4gICAgICBvbkZvY3VzLFxuICAgICAgcGxhY2Vob2xkZXIsXG4gICAgICB2YWx1ZSxcbiAgICAgIG9uQ2xlYXIsXG4gICAgICAuLi5yZXN0XG4gICAgfTogTmF2QmFyU2VhcmNoSW5wdXRQcm9wcyxcbiAgICByZWY6IFJlYWN0LlJlZjxIVE1MQnV0dG9uRWxlbWVudD5cbiAgKTogUmVhY3QuUmVhY3RFbGVtZW50ID0+IHtcbiAgICBjb25zdCBpc01hYyA9IHVzZUlzTWFjT1MoKTtcbiAgICBjb25zdCBob3RrZXkgPSBpc01hYyA/IChcbiAgICAgIDxUZXh0IHNpemU9XCJtXCIgYXM9XCJzcGFuXCIgY29sb3I9XCJ0ZXJ0aWFyeVwiPlxuICAgICAgICDijJhcbiAgICAgIDwvVGV4dD5cbiAgICApIDogKFxuICAgICAgXCJDdHJsK1wiXG4gICAgKTtcbiAgICBjb25zdCBoYXNQbGFjZWhvbGRlciA9ICF2YWx1ZSAmJiAhIXBsYWNlaG9sZGVyO1xuXG4gICAgcmV0dXJuIChcbiAgICAgIDxTdHlsZWRGYWtlSW5wdXQ+XG4gICAgICAgIDxJbnRlcmFjdGl2ZUJveFxuICAgICAgICAgIHJlZj17cmVmfVxuICAgICAgICAgIG9uQ2xpY2s9e29uQ2xpY2t9XG4gICAgICAgICAgb25Gb2N1cz17b25Gb2N1c31cbiAgICAgICAgICBvbkJsdXI9e29uQmx1cn1cbiAgICAgICAgICBsU3BhY2U9XCJzXCJcbiAgICAgICAgICByU3BhY2U9XCJ4c1wiXG4gICAgICAgICAgdlNwYWNlPXtbXCJ4c1wiLCBcInh4c1wiXX1cbiAgICAgICAgICBmdWxsV2lkdGhcbiAgICAgICAgICB7Li4ucmVzdH1cbiAgICAgICAgPlxuICAgICAgICAgIDxJbmxpbmVcbiAgICAgICAgICAgIHZBbGlnbkl0ZW1zPVwiY2VudGVyXCJcbiAgICAgICAgICAgIGFsaWduSXRlbXM9XCJzcGFjZUJldHdlZW5cIlxuICAgICAgICAgICAgc3BhY2U9XCJ4eHNcIlxuICAgICAgICAgICAgbm9XcmFwXG4gICAgICAgICAgICBmdWxsV2lkdGhcbiAgICAgICAgICA+XG4gICAgICAgICAgICA8SW5saW5lIHZBbGlnbkl0ZW1zPVwiY2VudGVyXCIgYWxpZ25JdGVtcz1cImNlbnRlclwiIHNwYWNlPVwieHhzXCIgbm9XcmFwPlxuICAgICAgICAgICAgICB7dmFsdWUgJiYgKFxuICAgICAgICAgICAgICAgIDxUZXh0Q2xhbXBlZCBjb2xvcj1cInByaW1hcnlcIiBzaXplPVwibVwiIGFzPVwic3BhblwiPlxuICAgICAgICAgICAgICAgICAge3ZhbHVlfVxuICAgICAgICAgICAgICAgIDwvVGV4dENsYW1wZWQ+XG4gICAgICAgICAgICAgICl9XG4gICAgICAgICAgICAgIHtoYXNQbGFjZWhvbGRlciAmJiAoXG4gICAgICAgICAgICAgICAgPEl0YWxpY1RleHRDbGFtcGVkIHNpemU9XCJtXCIgYXM9XCJzcGFuXCIgY29sb3I9XCJ0ZXJ0aWFyeVwiPlxuICAgICAgICAgICAgICAgICAge3BsYWNlaG9sZGVyfVxuICAgICAgICAgICAgICAgIDwvSXRhbGljVGV4dENsYW1wZWQ+XG4gICAgICAgICAgICAgICl9XG4gICAgICAgICAgICA8L0lubGluZT5cbiAgICAgICAgICAgIHtoYXNQbGFjZWhvbGRlciAmJiAoXG4gICAgICAgICAgICAgIDxUZXh0IHNpemU9XCJ4c1wiIGFzPVwic3BhblwiIGNvbG9yPVwidGVydGlhcnlcIj5cbiAgICAgICAgICAgICAgICB7aG90a2V5fUtcbiAgICAgICAgICAgICAgPC9UZXh0PlxuICAgICAgICAgICAgKX1cbiAgICAgICAgICA8L0lubGluZT5cbiAgICAgICAgPC9JbnRlcmFjdGl2ZUJveD5cbiAgICAgICAge3ZhbHVlICYmIChcbiAgICAgICAgICA8Qm94IHNwYWNlPVwieHhzXCIgdlNwYWNlPVwieHh4c1wiPlxuICAgICAgICAgICAgPFBpY3RvZ3JhbUJ1dHRvblxuICAgICAgICAgICAgICBpY29uPVwieFwiXG4gICAgICAgICAgICAgIHNpemU9XCJ4c1wiXG4gICAgICAgICAgICAgIGNvbG9yPVwicXVhdGVybmFyeVwiXG4gICAgICAgICAgICAgIG9uQ2xpY2s9e29uQ2xlYXJ9XG4gICAgICAgICAgICAvPlxuICAgICAgICAgIDwvQm94PlxuICAgICAgICApfVxuICAgICAgPC9TdHlsZWRGYWtlSW5wdXQ+XG4gICAgKTtcbiAgfVxuKTtcbiJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFpQzBCIn0= */");export const NavBarSearchInput=forwardRef(({onBlur,onClick,onFocus,placeholder,value,onClear,...rest},ref)=>{let hotkey=useIsMacOS()?React.createElement(Text,{size:"m",as:"span",color:"tertiary"},"⌘"):"Ctrl+",hasPlaceholder=!value&&!!placeholder;return React.createElement(StyledFakeInput,null,React.createElement(InteractiveBox,{ref:ref,onClick:onClick,onFocus:onFocus,onBlur:onBlur,lSpace:"s",rSpace:"xs",vSpace:["xs","xxs"],fullWidth:!0,...rest},React.createElement(Inline,{vAlignItems:"center",alignItems:"spaceBetween",space:"xxs",noWrap:!0,fullWidth:!0},React.createElement(Inline,{vAlignItems:"center",alignItems:"center",space:"xxs",noWrap:!0},value&&React.createElement(TextClamped,{color:"primary",size:"m",as:"span"},value),hasPlaceholder&&React.createElement(ItalicTextClamped,{size:"m",as:"span",color:"tertiary"},placeholder)),hasPlaceholder&&React.createElement(Text,{size:"xs",as:"span",color:"tertiary"},hotkey,"K"))),value&&React.createElement(Box,{space:"xxs",vSpace:"xxxs"},React.createElement(PictogramButton,{icon:"x",size:"xs",color:"quaternary",onClick:onClear})))});
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
export declare const useIsMacOS: () => boolean;
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
import{useWindow}from"./useWindow";export const useIsMacOS=()=>{let window=useWindow(),userAgent=window?.navigator?.userAgent??"";return(window?.navigator?.platform??"").toLowerCase().includes("mac")||userAgent.toLowerCase().includes("macintosh")};
|
|
@@ -181,6 +181,7 @@
|
|
|
181
181
|
"show-all": "<svg xmlns=\"http://www.w3.org/2000/svg\" width=\"16\" height=\"16\" fill=\"none\" viewBox=\"0 0 16 16\"><path stroke=\"currentColor\" stroke-linecap=\"round\" stroke-linejoin=\"round\" stroke-width=\"2\" d=\"M13.333 2H4c-.733 0-1.333.6-1.333 1.333v3.334L.667 8l2 1.333v3.334C2.667 13.4 3.267 14 4 14h9.333c.734 0 1.334-.6 1.334-1.333V3.333c0-.733-.6-1.333-1.334-1.333\"/><path fill=\"currentColor\" d=\"M9.693 9.673H7.64l-.393 1.174H6L8.12 5.16h1.087l2.126 5.687h-1.246zm-1.74-.953h1.42L8.66 6.593z\"/></svg>",
|
|
182
182
|
"sliders": "<svg xmlns=\"http://www.w3.org/2000/svg\" width=\"24\" height=\"24\" fill=\"none\" stroke=\"currentColor\" stroke-linecap=\"round\" stroke-linejoin=\"round\" stroke-width=\"2\" viewBox=\"0 0 24 24\"><path d=\"M4 21v-7m0-4V3m8 18v-9m0-4V3m8 18v-5m0-4V3M1 14h6m2-6h6m2 8h6\"/></svg>",
|
|
183
183
|
"smartzoom": "<svg xmlns=\"http://www.w3.org/2000/svg\" width=\"24\" height=\"24\" fill=\"none\" viewBox=\"0 0 24 24\"><path fill=\"currentColor\" d=\"m7.593 15.164-1.7-1a1 1 0 0 1 1.013-1.724l1.701.999a1.002 1.002 0 0 1-1.014 1.725m7.288-8.6C17.989 7.917 20 10.926 20 14.401c0 4.676-3.504 8.372-8.151 8.6H5a1 1 0 1 1 0-1.999h6.8c3.514-.173 6.2-3.01 6.2-6.6 0-2.997-1.954-5.543-4.862-6.336a1 1 0 0 1-.598-1.475l1.076-1.817-2.545-1.42-3.695 6.37 2.561 1.43 1.103-1.862a1 1 0 0 1 1.082-.466c2.653.603 4.578 2.948 4.578 5.575 0 3.143-2.656 5.8-5.8 5.8a5.76 5.76 0 0 1-3.791-1.4H5a1 1 0 1 1 0-2h2.5c.265 0 .52.106.707.293a3.78 3.78 0 0 0 2.693 1.107c2.06 0 3.8-1.74 3.8-3.8 0-1.474-.953-2.815-2.345-3.406l-1.195 2.016a1 1 0 0 1-1.347.363l-4.3-2.4A1.003 1.003 0 0 1 5.135 9.6l4.701-8.1a.996.996 0 0 1 1.352-.37l4.299 2.4a1 1 0 0 1 .373 1.382z\"/></svg>",
|
|
184
|
+
"sop": "<svg xmlns=\"http://www.w3.org/2000/svg\" width=\"24\" height=\"24\" fill=\"currentColor\" viewBox=\"0 0 24 24\"><path d=\"M7 11a2 2 0 0 1 2 2v1h1a2 2 0 0 1 2 2v2a2 2 0 0 1-2 2H9v1a2 2 0 0 1-2 2H5a2 2 0 0 1-2-2v-1H2a2 2 0 0 1-2-2v-2a2 2 0 0 1 2-2h1v-1a2 2 0 0 1 2-2zm8-10a2 2 0 0 1 2 2h1a3 3 0 0 1 3 3v14a3 3 0 0 1-3 3h-5a1 1 0 1 1 0-2h5a1 1 0 0 0 1-1V6a1 1 0 0 0-1-1h-1a2 2 0 0 1-2 2H9a2 2 0 0 1-2-2H6a1 1 0 0 0-1 1v2a1 1 0 0 1-2 0V6a3 3 0 0 1 3-3h1a2 2 0 0 1 2-2zM5 16H2v2h3v3h2v-3h3v-2H7v-3H5zM9 5h6V3H9z\"/></svg>",
|
|
184
185
|
"sort": "<svg xmlns=\"http://www.w3.org/2000/svg\" width=\"24\" height=\"24\" fill=\"none\" viewBox=\"0 0 24 24\"><path stroke=\"currentColor\" stroke-linecap=\"round\" stroke-linejoin=\"round\" stroke-width=\"2\" d=\"M6 5v15m5-5-5 5-5-5m17 4V4m-5 5 5-5 5 5\"/></svg>",
|
|
185
186
|
"sort-ascending": "<svg xmlns=\"http://www.w3.org/2000/svg\" width=\"24\" height=\"24\" fill=\"none\" viewBox=\"0 0 24 24\"><path fill=\"currentColor\" fill-rule=\"evenodd\" d=\"m6 11 4.94-6.06a1.5 1.5 0 0 1 2.12 0L18 11z\" clip-rule=\"evenodd\"/><path fill=\"currentColor\" fill-rule=\"evenodd\" d=\"m18 13-4.94 6.06a1.5 1.5 0 0 1-2.12 0L6 13z\" clip-rule=\"evenodd\" opacity=\".3\"/></svg>",
|
|
186
187
|
"sort-descending": "<svg xmlns=\"http://www.w3.org/2000/svg\" width=\"24\" height=\"24\" fill=\"none\" viewBox=\"0 0 24 24\"><path fill=\"currentColor\" fill-rule=\"evenodd\" d=\"m18 13-4.94 6.06a1.5 1.5 0 0 1-2.12 0L6 13z\" clip-rule=\"evenodd\"/><path fill=\"currentColor\" fill-rule=\"evenodd\" d=\"m6 11 4.94-6.06a1.5 1.5 0 0 1 2.12 0L18 11z\" clip-rule=\"evenodd\" opacity=\".3\"/></svg>",
|
|
@@ -181,6 +181,7 @@
|
|
|
181
181
|
"show-all": "<svg xmlns=\"http://www.w3.org/2000/svg\" width=\"16\" height=\"16\" fill=\"none\" viewBox=\"0 0 16 16\"><path stroke=\"currentColor\" stroke-linecap=\"round\" stroke-linejoin=\"round\" stroke-width=\"2\" d=\"M4 2a1 1 0 0 0-1 1v3.222L1.638 7.67c-.091.097-.236.17-.255.3a.2.2 0 0 0 0 .06c.02.13.164.203.255.3L3 9.778V13a1 1 0 0 0 1 1h10a1 1 0 0 0 1-1V3a1 1 0 0 0-1-1z\"/><path fill=\"currentColor\" fill-rule=\"evenodd\" d=\"M8 4h2l3 8h-2l-.667-2H7.667L7 12H5zm.333 4h1.334L9 6z\" clip-rule=\"evenodd\"/></svg>",
|
|
182
182
|
"sliders": "<svg xmlns=\"http://www.w3.org/2000/svg\" width=\"16\" height=\"16\" fill=\"none\" viewBox=\"0 0 16 16\"><path stroke=\"currentColor\" stroke-linecap=\"round\" stroke-linejoin=\"round\" stroke-width=\"2\" d=\"M3 14V9m0-3V2m5 12V8m0-3V2m5 12v-3m0-3V2M1 9h4m1-4h4m1 6h4\"/></svg>",
|
|
183
183
|
"smartzoom": "<svg xmlns=\"http://www.w3.org/2000/svg\" width=\"16\" height=\"16\" fill=\"none\" viewBox=\"0 0 16 16\"><path fill=\"currentColor\" fill-rule=\"evenodd\" d=\"M4.182 5.768a1 1 0 0 0 .05 1.414l.266.248-.828.887a.25.25 0 0 0 .013.353l2.012 1.875a.25.25 0 0 0 .353-.012l.827-.887.283.263a1 1 0 0 0 1.413-.05l2.69-2.885a3.5 3.5 0 1 1-4.37 5.359L6.593 12H2v4h7c3.028 0 5.307-2.245 5.867-4.793a5.49 5.49 0 0 0-2.221-5.72l.698-.748a1 1 0 0 0-.05-1.413L10.368.598a1 1 0 0 0-1.413.05zm2.145.633L7.79 7.764l3.409-3.657-1.463-1.364z\" clip-rule=\"evenodd\"/></svg>",
|
|
184
|
+
"sop": "<svg xmlns=\"http://www.w3.org/2000/svg\" width=\"16\" height=\"16\" fill=\"currentColor\" viewBox=\"0 0 16 16\"><path fill-rule=\"evenodd\" d=\"M6.5 6A1.5 1.5 0 0 1 8 7.5V8h.5A1.5 1.5 0 0 1 10 9.5v3A1.5 1.5 0 0 1 8.5 14H8v.5A1.5 1.5 0 0 1 6.5 16h-3A1.5 1.5 0 0 1 2 14.5V14h-.5A1.5 1.5 0 0 1 0 12.5v-3A1.5 1.5 0 0 1 1.5 8H2v-.5A1.5 1.5 0 0 1 3.5 6zM4 10H2v2h2v2h2v-2h2v-2H6V8H4z\" clip-rule=\"evenodd\"/><path d=\"M10 0a1 1 0 0 1 1 1h.75C13.052 1 14 2.106 14 3.333v9.334C14 13.894 13.052 15 11.75 15H11v-2h.75c.078 0 .25-.087.25-.333V3.333c0-.246-.172-.333-.25-.333H11l-.005.103A1 1 0 0 1 10 4H6a1 1 0 0 1-1-1h-.75c-.078 0-.25.087-.25.333V5H2V3.333C2 2.106 2.948 1 4.25 1H5a1 1 0 0 1 1-1z\"/></svg>",
|
|
184
185
|
"sort": "<svg xmlns=\"http://www.w3.org/2000/svg\" width=\"16\" height=\"16\" fill=\"none\" viewBox=\"0 0 16 16\"><g stroke=\"currentColor\" stroke-linecap=\"round\" stroke-width=\"2\"><path stroke-linejoin=\"bevel\" d=\"M4 3v9\"/><path stroke-linejoin=\"round\" d=\"m7 10-3 3-3-3\"/><path stroke-linejoin=\"bevel\" d=\"M12 13V4\"/><path stroke-linejoin=\"round\" d=\"m9 6 3-3 3 3\"/></g></svg>",
|
|
185
186
|
"sort-ascending": "<svg xmlns=\"http://www.w3.org/2000/svg\" width=\"16\" height=\"16\" fill=\"none\" viewBox=\"0 0 16 16\"><path fill=\"currentColor\" fill-rule=\"evenodd\" d=\"m4.293 7 3-3.707a1 1 0 0 1 1.414 0l3 3.707z\" clip-rule=\"evenodd\"/><path fill=\"currentColor\" fill-rule=\"evenodd\" d=\"m11.707 9-3 3.707a1 1 0 0 1-1.414 0L4.293 9z\" clip-rule=\"evenodd\" opacity=\".3\"/></svg>",
|
|
186
187
|
"sort-descending": "<svg xmlns=\"http://www.w3.org/2000/svg\" width=\"16\" height=\"16\" fill=\"none\" viewBox=\"0 0 16 16\"><path fill=\"currentColor\" fill-rule=\"evenodd\" d=\"m11.707 9-3 3.707a1 1 0 0 1-1.414 0L4.293 9z\" clip-rule=\"evenodd\"/><path fill=\"currentColor\" fill-rule=\"evenodd\" d=\"m4.293 7 3-3.707a1 1 0 0 1 1.414 0l3 3.707z\" clip-rule=\"evenodd\" opacity=\".3\"/></svg>",
|