@ultraviolet/ui 3.0.0-beta.21 → 3.0.0-beta.22

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.
Files changed (70) hide show
  1. package/dist/components/Avatar/styles.css.cjs +1 -0
  2. package/dist/components/Avatar/styles.css.js +1 -0
  3. package/dist/components/Avatar/variables.css.cjs +0 -1
  4. package/dist/components/Avatar/variables.css.js +0 -1
  5. package/dist/components/Breadcrumbs/components/Item.cjs +1 -1
  6. package/dist/components/Breadcrumbs/components/Item.js +2 -2
  7. package/dist/components/Breadcrumbs/components/styles.css.cjs +3 -1
  8. package/dist/components/Breadcrumbs/components/styles.css.d.ts +1 -0
  9. package/dist/components/Breadcrumbs/components/styles.css.js +3 -1
  10. package/dist/components/Button/index.cjs +2 -1
  11. package/dist/components/Button/index.d.ts +1 -0
  12. package/dist/components/Button/index.js +2 -1
  13. package/dist/components/Dialog/index.cjs +3 -21
  14. package/dist/components/Dialog/index.d.ts +1 -0
  15. package/dist/components/Dialog/index.js +3 -19
  16. package/dist/components/Dialog/styles.css.cjs +7 -0
  17. package/dist/components/Dialog/styles.css.d.ts +2 -0
  18. package/dist/components/Dialog/styles.css.js +7 -0
  19. package/dist/components/Link/index.cjs +2 -1
  20. package/dist/components/Link/index.d.ts +1 -0
  21. package/dist/components/Link/index.js +2 -1
  22. package/dist/components/List/Cell.cjs +21 -15
  23. package/dist/components/List/Cell.d.ts +2 -1
  24. package/dist/components/List/Cell.js +21 -13
  25. package/dist/components/List/ColumnProvider.cjs +28 -0
  26. package/dist/components/List/ColumnProvider.d.ts +14 -0
  27. package/dist/components/List/ColumnProvider.js +28 -0
  28. package/dist/components/List/HeaderCell.cjs +11 -45
  29. package/dist/components/List/HeaderCell.d.ts +2 -2
  30. package/dist/components/List/HeaderCell.js +12 -44
  31. package/dist/components/List/HeaderRow.cjs +4 -25
  32. package/dist/components/List/HeaderRow.js +4 -23
  33. package/dist/components/List/Row.cjs +23 -183
  34. package/dist/components/List/Row.d.ts +0 -16
  35. package/dist/components/List/Row.js +22 -180
  36. package/dist/components/List/SkeletonRows.cjs +7 -36
  37. package/dist/components/List/SkeletonRows.js +6 -33
  38. package/dist/components/List/index.cjs +4 -32
  39. package/dist/components/List/index.d.ts +1 -0
  40. package/dist/components/List/index.js +4 -30
  41. package/dist/components/List/styles.css.cjs +35 -0
  42. package/dist/components/List/styles.css.d.ts +24 -0
  43. package/dist/components/List/styles.css.js +35 -0
  44. package/dist/components/List/variables.css.cjs +16 -0
  45. package/dist/components/List/variables.css.d.ts +7 -0
  46. package/dist/components/List/variables.css.js +16 -0
  47. package/dist/components/Menu/MenuContent.cjs +13 -77
  48. package/dist/components/Menu/MenuContent.js +13 -75
  49. package/dist/components/Menu/components/Group.cjs +2 -12
  50. package/dist/components/Menu/components/Group.js +2 -10
  51. package/dist/components/Menu/components/Item.cjs +16 -94
  52. package/dist/components/Menu/components/Item.js +16 -92
  53. package/dist/components/Menu/styles.css.cjs +24 -0
  54. package/dist/components/Menu/styles.css.d.ts +47 -0
  55. package/dist/components/Menu/styles.css.js +24 -0
  56. package/dist/components/Row/index.cjs +15 -11
  57. package/dist/components/Row/index.d.ts +2 -1
  58. package/dist/components/Row/index.js +15 -11
  59. package/dist/components/Text/style.css.cjs +1 -0
  60. package/dist/components/Text/style.css.js +1 -0
  61. package/dist/components/Text/variables.css.cjs +0 -1
  62. package/dist/components/Text/variables.css.js +0 -1
  63. package/dist/components/UnitInput/styles.css.cjs +1 -0
  64. package/dist/components/UnitInput/styles.css.js +1 -0
  65. package/dist/ui.css +1 -1
  66. package/package.json +6 -6
  67. package/dist/components/List/constants.cjs +0 -5
  68. package/dist/components/List/constants.js +0 -5
  69. package/dist/components/Menu/constants.cjs +0 -7
  70. package/dist/components/Menu/constants.js +0 -7
@@ -2,183 +2,18 @@
2
2
  "use strict";
3
3
  Object.defineProperty(exports, Symbol.toStringTag, { value: "Module" });
4
4
  const jsxRuntime = require("@emotion/react/jsx-runtime");
5
- const _styled = require("@emotion/styled/base");
6
- const react$1 = require("@emotion/react");
7
5
  const Icon = require("@ultraviolet/icons");
6
+ const themes = require("@ultraviolet/themes");
7
+ const dynamic = require("@vanilla-extract/dynamic");
8
8
  const react = require("react");
9
- const index$1 = require("../Button/index.cjs");
10
- const index$2 = require("../Checkbox/index.cjs");
9
+ const index$2 = require("../Button/index.cjs");
10
+ const index$1 = require("../Checkbox/index.cjs");
11
11
  const index = require("../Tooltip/index.cjs");
12
12
  const Cell = require("./Cell.cjs");
13
- const constants = require("./constants.cjs");
13
+ const ColumnProvider = require("./ColumnProvider.cjs");
14
14
  const ListContext = require("./ListContext.cjs");
15
- const _interopDefaultCompat = (e) => e && typeof e === "object" && "default" in e ? e : { default: e };
16
- const _styled__default = /* @__PURE__ */ _interopDefaultCompat(_styled);
17
- function _EMOTION_STRINGIFIED_CSS_ERROR__() {
18
- return "You have tried to stringify object returned from `css` function. It isn't supposed to be used directly (e.g. as value of the `className` prop), but rather handed to emotion so it can handle it (e.g. as value of `css` prop).";
19
- }
20
- const ExpandableWrapper = /* @__PURE__ */ _styled__default.default("tr", process.env.NODE_ENV === "production" ? {
21
- target: "ei4uyz15"
22
- } : {
23
- target: "ei4uyz15",
24
- label: "ExpandableWrapper"
25
- })("width:100%;display:table-row;vertical-align:middle;cursor:auto;background:", ({
26
- theme
27
- }) => theme.colors.neutral.backgroundWeak, ";border-radius:0 0 ", ({
28
- theme
29
- }) => theme.radii.default, " ", ({
30
- theme
31
- }) => theme.radii.default, ";transform:translate3d(0, -", ({
32
- theme
33
- }) => theme.space["2"], ", 0);position:relative;td,td:first-child,td:last-child{transition:box-shadow 200ms ease,border-color 200ms ease;}td{border:1px solid ", ({
34
- theme
35
- }) => theme.colors.neutral.border, ";border-top:none;border-radius:0 0 ", ({
36
- theme
37
- }) => theme.radii.default, " ", ({
38
- theme
39
- }) => theme.radii.default, ';}&[data-highlight="true"] td{border-color:', ({
40
- theme
41
- }) => theme.colors.primary.border, ";}" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["/home/runner/work/ultraviolet/ultraviolet/packages/ui/src/components/List/Row.tsx"],"names":[],"mappings":"AA6B0C","file":"/home/runner/work/ultraviolet/ultraviolet/packages/ui/src/components/List/Row.tsx","sourcesContent":["'use client'\n\nimport type { Theme } from '@emotion/react'\nimport { keyframes, useTheme } from '@emotion/react'\nimport styled from '@emotion/styled'\nimport { ArrowDownIcon, ArrowUpIcon } from '@ultraviolet/icons'\nimport type {\n  CSSProperties,\n  MouseEventHandler,\n  ReactNode,\n  RefObject,\n} from 'react'\nimport {\n  Children,\n  forwardRef,\n  useCallback,\n  useEffect,\n  useId,\n  useRef,\n} from 'react'\nimport type { SENTIMENTS, space } from '../../theme'\nimport { Button } from '../Button'\nimport { Checkbox } from '../Checkbox'\nimport { Tooltip } from '../Tooltip'\nimport { Cell } from './Cell'\nimport { SELECTABLE_CHECKBOX_SIZE } from './constants'\nimport { useListContext } from './ListContext'\nimport type { ColumnProps } from './types'\n\nexport const ExpandableWrapper = styled.tr`\n  width: 100%;\n  display: table-row;\n  vertical-align: middle;\n  cursor: auto;\n  background: ${({ theme }) => theme.colors.neutral.backgroundWeak};\n  border-radius: 0 0 ${({ theme }) => theme.radii.default} ${({ theme }) =>\n    theme.radii.default};\n  transform: translate3d(0, -${({ theme }) => theme.space['2']}, 0);\n  position: relative;\n\n  td, td:first-child, td:last-child {\n    transition:\n      box-shadow 200ms ease,\n      border-color 200ms ease;\n  }\n\n  td {\n    border: 1px solid ${({ theme }) => theme.colors.neutral.border};\n    border-top: none;\n    border-radius: 0 0 ${({ theme }) => theme.radii.default} ${({ theme }) =>\n      theme.radii.default};\n  }\n\n  &[data-highlight=\"true\"] td {\n    border-color: ${({ theme }) => theme.colors.primary.border};\n  }\n`\n\nconst StyledCheckbox = styled(Checkbox, {\n  shouldForwardProp: prop => !['inRange'].includes(prop),\n})<{ inRange: boolean }>`\n  ${({ theme, inRange }) =>\n    inRange\n      ? `\n        rect {\n          fill: ${theme.colors.neutral.backgroundHover};\n          stroke: ${theme.colors.neutral.borderHover};\n        }\n  `\n      : ''}\n\n`\n\nconst colorChange = (theme: Theme) => keyframes`\n  5% {\n    background-color: ${theme.colors.primary.background};\n  }\n  80% {\n    background-color: ${theme.colors.primary.background};\n  }\n`\n\nexport const StyledRow = styled('tr', {\n  shouldForwardProp: prop =>\n    ![\n      'highlightAnimation',\n      'sentiment',\n      'columns',\n      'columnsStartAt',\n      'data-dragging',\n      'pointerEvent',\n    ].includes(prop),\n})<{\n  sentiment: (typeof SENTIMENTS)[number]\n  columns: ColumnProps[]\n  columnsStartAt?: number\n  highlightAnimation?: boolean\n  'data-dragging'?: boolean\n}>`\n  /* List itself also apply style about common templating between HeaderRow and other Rows */\n\n  display: table-row;\n  vertical-align: middle;\n  position: relative;\n  box-shadow: none;\n  background-color: ${({ theme }) => theme.colors.neutral.background};\n  font-size: ${({ theme }) => theme.typography.bodySmall.fontSize};\n  column-gap: ${({ theme }) => theme.space['2']};\n\n  &[role='button row'] {\n    cursor: pointer;\n  }\n\n  position: relative;\n\n  td, td:first-child, td:last-child {\n    transition:\n      box-shadow 200ms ease,\n      border-color 200ms ease;\n  }\n\n  td {\n    border-top: 1px solid ${({ theme }) => theme.colors.neutral.border};\n    border-bottom: 1px solid ${({ theme }) => theme.colors.neutral.border};\n  }\n  td:first-child {\n    border-left: 1px solid ${({ theme }) => theme.colors.neutral.border};\n    border-radius: ${({ theme }) => theme.radii.default} 0 0 ${({ theme }) =>\n      theme.radii.default};\n  }\n  td:last-child {\n    border-right: 1px solid ${({ theme }) => theme.colors.neutral.border};\n    border-radius: 0 ${({ theme }) => theme.radii.default} ${({ theme }) =>\n      theme.radii.default} 0;\n  }\n\n  &:not([aria-disabled='true']):hover td, &:not([aria-disabled='true']):hover td:first-child, &:not([aria-disabled='true']):hover td:last-child {\n    border-color: ${({ theme }) => theme.colors.primary.border};\n  }\n\n  &:not([aria-disabled='true']):hover + ${ExpandableWrapper} td {\n    border-color: ${({ theme }) => theme.colors.primary.border};\n  }\n\n  &[aria-expanded='true'] td {\n    &:first-child {\n      border-left: 1px solid ${({ theme }) => theme.colors.neutral.border};\n      border-radius: ${({ theme }) => theme.radii.default} 0 0 0;\n    }\n    &:last-child {\n      border-right: 1px solid ${({ theme }) => theme.colors.neutral.border};\n      border-radius: 0 ${({ theme }) => theme.radii.default} 0 0;\n    }\n    border-bottom-color: ${({ theme }) => theme.colors.neutral.border};\n  }\n\n  ${({ theme, sentiment }) =>\n    `\n    color: ${theme.colors[sentiment].text};\n    border-color: ${theme.colors[sentiment].border};\n    background-color: ${theme.colors[sentiment].background};\n    & [data-expandable-content] {\n      border-color: ${theme.colors[sentiment].border};\n    }\n\n    ${\n      sentiment === 'neutral'\n        ? `&:not([aria-disabled='true']):hover {\n          border-color: ${theme.colors.primary.border};\n          box-shadow: ${theme.shadows.hoverPrimary};\n        }\n        `\n        : ''\n    }\n  `}\n\n  &[data-highlight='true'] {\n    td, td:first-child, td:last-child {\n      border-color: ${({ theme }) => theme.colors.primary.border};\n    }\n\n    box-shadow: ${({ theme }) => theme.shadows.hoverPrimary};\n  }\n\n  &[aria-disabled='true'] {\n    background-color: ${({ theme }) => theme.colors.neutral.backgroundDisabled};\n    color: ${({ theme }) => theme.colors.neutral.textDisabled};\n    cursor: not-allowed;\n  }\n\n  ${({ columns, columnsStartAt }) =>\n    columns.map(\n      (column, index) => `\n    td:nth-of-type(${index + 1 + (columnsStartAt ?? 0)}) {\n      ${column.width ? `width: ${column.width};` : ''}\n      ${column.minWidth ? `min-width: ${column.minWidth};` : ''}\n      ${column.maxWidth ? `max-width: ${column.maxWidth};` : ''}\n    }\n  `,\n    )}\n\n  animation: ${({ highlightAnimation, theme }) =>\n    highlightAnimation ? colorChange(theme) : undefined}\n    3s linear;\n`\n\nconst StyledCheckboxContainer = styled.div`\n  display: flex;\n`\n\nconst NoPaddingCell = styled(Cell, {\n  shouldForwardProp: prop => !['maxWidth'].includes(prop),\n})<{\n  maxWidth: string\n}>`\n  padding: 0;\n\n  &:first-of-type {\n    padding-left: ${({ theme }) => theme.space['2']};\n  }\n\n  max-width: ${({ maxWidth }) => maxWidth};\n`\n\nconst ExpandableCell = styled(Cell, {\n  shouldForwardProp: prop => !['padding'].includes(prop),\n})<{ padding?: keyof typeof space }>`\n  padding: ${({ theme, padding }) =>\n    padding ? theme.space[padding] : theme.space['2']};\n`\n\ntype RowProps = {\n  children: ReactNode\n  id: string\n  expandable?: ReactNode\n  /**\n   * Row cannot be selected if this prop is provided. boolean true disabled selection, a string disable selection and a tooltip will be displayed on checkbox hover.\n   * */\n  selectDisabled?: boolean | string\n  disabled?: boolean\n  sentiment?: (typeof SENTIMENTS)[number]\n  expanded?: boolean\n  className?: string\n  /**\n   * Define a custom padding for the content in the expandable\n   */\n  expandablePadding?: keyof typeof space\n  highlightAnimation?: boolean\n  'data-testid'?: string\n  style?: CSSProperties\n  'data-dragging'?: boolean\n  onMouseEnter?: MouseEventHandler<HTMLTableRowElement>\n  onMouseLeave?: MouseEventHandler<HTMLTableRowElement>\n}\n\nexport const Row = forwardRef<HTMLTableRowElement, RowProps>(\n  (\n    {\n      children,\n      id,\n      expandable,\n      disabled,\n      selectDisabled,\n      sentiment = 'neutral',\n      highlightAnimation,\n      expanded,\n      className,\n      expandablePadding,\n      'data-testid': dataTestid,\n      style,\n      'data-dragging': dataDragging,\n      onMouseEnter,\n      onMouseLeave,\n    },\n    forwardedRef,\n  ) => {\n    const {\n      selectable,\n      registerExpandableRow,\n      expandedRowIds,\n      expandRow,\n      collapseRow,\n      registerSelectableRow,\n      selectedRowIds,\n      expandButton,\n      inRange,\n      columns,\n      refList,\n      setRefList,\n      handleOnChange,\n    } = useListContext()\n\n    const theme = useTheme()\n\n    const expandedRowId = useId()\n\n    const checkboxRef = useRef<HTMLInputElement>(null)\n\n    const isSelectDisabled =\n      disabled || (selectDisabled !== undefined && selectDisabled !== false)\n\n    const hasExpandable = !!expandable\n    useEffect(() => {\n      if (hasExpandable) {\n        const unregisterCallback = registerExpandableRow(id, expanded)\n\n        return unregisterCallback\n      }\n\n      return undefined\n    }, [id, hasExpandable, registerExpandableRow, expanded, expandRow])\n\n    useEffect(() => {\n      if (!isSelectDisabled) {\n        const unregisterCallback = registerSelectableRow(id)\n\n        return unregisterCallback\n      }\n\n      return undefined\n    }, [id, registerSelectableRow, isSelectDisabled])\n\n    const toggleRowExpand = useCallback(() => {\n      if (expandedRowIds[id]) {\n        collapseRow(id)\n      } else {\n        expandRow(id)\n      }\n    }, [collapseRow, expandRow, expandedRowIds, id])\n\n    const canClickRowToExpand = !disabled && !!expandable && !expandButton\n\n    useEffect(() => {\n      if (\n        checkboxRef.current !== null &&\n        !refList.includes(checkboxRef as RefObject<HTMLInputElement>)\n      ) {\n        setRefList([...refList, checkboxRef as RefObject<HTMLInputElement>])\n      }\n    }, [refList, setRefList])\n\n    const childrenLength =\n      Children.count(children) + (selectable ? 1 : 0) + (expandButton ? 1 : 0)\n\n    return (\n      <>\n        <StyledRow\n          aria-controls={\n            expandable && expandedRowIds[id] ? expandedRowId : undefined\n          }\n          aria-disabled={disabled}\n          aria-expanded={expandable ? expandedRowIds[id] : undefined}\n          className={className}\n          columns={columns}\n          columnsStartAt={(selectable ? 1 : 0) + (expandButton ? 1 : 0)}\n          data-dragging={dataDragging}\n          data-highlight={selectable && !!selectedRowIds[id]}\n          data-testid={dataTestid}\n          highlightAnimation={highlightAnimation}\n          onClick={canClickRowToExpand ? toggleRowExpand : undefined}\n          onKeyDown={\n            canClickRowToExpand\n              ? event => {\n                  if (event.key === ' ') {\n                    toggleRowExpand()\n                    event.preventDefault()\n                  }\n                }\n              : undefined\n          }\n          onMouseEnter={onMouseEnter}\n          onMouseLeave={onMouseLeave}\n          ref={forwardedRef}\n          role={canClickRowToExpand ? 'button row' : undefined}\n          sentiment={sentiment}\n          style={style}\n          tabIndex={canClickRowToExpand ? 0 : -1}\n        >\n          {selectable ? (\n            <NoPaddingCell maxWidth={theme.sizing[SELECTABLE_CHECKBOX_SIZE]}>\n              <StyledCheckboxContainer>\n                <Tooltip\n                  text={\n                    typeof selectDisabled === 'string'\n                      ? selectDisabled\n                      : undefined\n                  }\n                >\n                  <StyledCheckbox\n                    aria-label=\"select\"\n                    checked={selectedRowIds[id]}\n                    disabled={isSelectDisabled}\n                    inRange={inRange?.includes(id)}\n                    name=\"list-select-checkbox\"\n                    onChange={() => handleOnChange(id, selectedRowIds[id])}\n                    ref={checkboxRef}\n                    value={id}\n                  />\n                </Tooltip>\n              </StyledCheckboxContainer>\n            </NoPaddingCell>\n          ) : null}\n          {expandButton ? (\n            <NoPaddingCell maxWidth={theme.sizing[SELECTABLE_CHECKBOX_SIZE]}>\n              <Button\n                aria-label=\"expand\"\n                data-testid=\"list-expand-button\"\n                disabled={disabled || !expandable}\n                onClick={toggleRowExpand}\n                sentiment={sentiment}\n                size=\"small\"\n                variant=\"ghost\"\n              >\n                {expandedRowIds[id] ? <ArrowUpIcon /> : <ArrowDownIcon />}\n              </Button>\n            </NoPaddingCell>\n          ) : null}\n          {children}\n        </StyledRow>\n        {expandable && expandedRowIds[id] ? (\n          <ExpandableWrapper\n            data-expandable-content\n            data-highlight={selectable && !!selectedRowIds[id]}\n            id={expandedRowId}\n            onClick={\n              canClickRowToExpand\n                ? e => {\n                    e.stopPropagation()\n                  }\n                : undefined\n            }\n            onKeyDown={\n              canClickRowToExpand\n                ? e => {\n                    e.stopPropagation()\n                  }\n                : undefined\n            }\n          >\n            <ExpandableCell\n              colSpan={childrenLength}\n              padding={expandablePadding}\n            >\n              {expandable}\n            </ExpandableCell>\n          </ExpandableWrapper>\n        ) : null}\n      </>\n    )\n  },\n)\n"]} */"));
42
- const StyledCheckbox = /* @__PURE__ */ _styled__default.default(index$2.Checkbox, process.env.NODE_ENV === "production" ? {
43
- shouldForwardProp: (prop) => !["inRange"].includes(prop),
44
- target: "ei4uyz14"
45
- } : {
46
- shouldForwardProp: (prop) => !["inRange"].includes(prop),
47
- target: "ei4uyz14",
48
- label: "StyledCheckbox"
49
- })(({
50
- theme,
51
- inRange
52
- }) => inRange ? `
53
- rect {
54
- fill: ${theme.colors.neutral.backgroundHover};
55
- stroke: ${theme.colors.neutral.borderHover};
56
- }
57
- ` : "", ";" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["/home/runner/work/ultraviolet/ultraviolet/packages/ui/src/components/List/Row.tsx"],"names":[],"mappings":"AA4DwB","file":"/home/runner/work/ultraviolet/ultraviolet/packages/ui/src/components/List/Row.tsx","sourcesContent":["'use client'\n\nimport type { Theme } from '@emotion/react'\nimport { keyframes, useTheme } from '@emotion/react'\nimport styled from '@emotion/styled'\nimport { ArrowDownIcon, ArrowUpIcon } from '@ultraviolet/icons'\nimport type {\n  CSSProperties,\n  MouseEventHandler,\n  ReactNode,\n  RefObject,\n} from 'react'\nimport {\n  Children,\n  forwardRef,\n  useCallback,\n  useEffect,\n  useId,\n  useRef,\n} from 'react'\nimport type { SENTIMENTS, space } from '../../theme'\nimport { Button } from '../Button'\nimport { Checkbox } from '../Checkbox'\nimport { Tooltip } from '../Tooltip'\nimport { Cell } from './Cell'\nimport { SELECTABLE_CHECKBOX_SIZE } from './constants'\nimport { useListContext } from './ListContext'\nimport type { ColumnProps } from './types'\n\nexport const ExpandableWrapper = styled.tr`\n  width: 100%;\n  display: table-row;\n  vertical-align: middle;\n  cursor: auto;\n  background: ${({ theme }) => theme.colors.neutral.backgroundWeak};\n  border-radius: 0 0 ${({ theme }) => theme.radii.default} ${({ theme }) =>\n    theme.radii.default};\n  transform: translate3d(0, -${({ theme }) => theme.space['2']}, 0);\n  position: relative;\n\n  td, td:first-child, td:last-child {\n    transition:\n      box-shadow 200ms ease,\n      border-color 200ms ease;\n  }\n\n  td {\n    border: 1px solid ${({ theme }) => theme.colors.neutral.border};\n    border-top: none;\n    border-radius: 0 0 ${({ theme }) => theme.radii.default} ${({ theme }) =>\n      theme.radii.default};\n  }\n\n  &[data-highlight=\"true\"] td {\n    border-color: ${({ theme }) => theme.colors.primary.border};\n  }\n`\n\nconst StyledCheckbox = styled(Checkbox, {\n  shouldForwardProp: prop => !['inRange'].includes(prop),\n})<{ inRange: boolean }>`\n  ${({ theme, inRange }) =>\n    inRange\n      ? `\n        rect {\n          fill: ${theme.colors.neutral.backgroundHover};\n          stroke: ${theme.colors.neutral.borderHover};\n        }\n  `\n      : ''}\n\n`\n\nconst colorChange = (theme: Theme) => keyframes`\n  5% {\n    background-color: ${theme.colors.primary.background};\n  }\n  80% {\n    background-color: ${theme.colors.primary.background};\n  }\n`\n\nexport const StyledRow = styled('tr', {\n  shouldForwardProp: prop =>\n    ![\n      'highlightAnimation',\n      'sentiment',\n      'columns',\n      'columnsStartAt',\n      'data-dragging',\n      'pointerEvent',\n    ].includes(prop),\n})<{\n  sentiment: (typeof SENTIMENTS)[number]\n  columns: ColumnProps[]\n  columnsStartAt?: number\n  highlightAnimation?: boolean\n  'data-dragging'?: boolean\n}>`\n  /* List itself also apply style about common templating between HeaderRow and other Rows */\n\n  display: table-row;\n  vertical-align: middle;\n  position: relative;\n  box-shadow: none;\n  background-color: ${({ theme }) => theme.colors.neutral.background};\n  font-size: ${({ theme }) => theme.typography.bodySmall.fontSize};\n  column-gap: ${({ theme }) => theme.space['2']};\n\n  &[role='button row'] {\n    cursor: pointer;\n  }\n\n  position: relative;\n\n  td, td:first-child, td:last-child {\n    transition:\n      box-shadow 200ms ease,\n      border-color 200ms ease;\n  }\n\n  td {\n    border-top: 1px solid ${({ theme }) => theme.colors.neutral.border};\n    border-bottom: 1px solid ${({ theme }) => theme.colors.neutral.border};\n  }\n  td:first-child {\n    border-left: 1px solid ${({ theme }) => theme.colors.neutral.border};\n    border-radius: ${({ theme }) => theme.radii.default} 0 0 ${({ theme }) =>\n      theme.radii.default};\n  }\n  td:last-child {\n    border-right: 1px solid ${({ theme }) => theme.colors.neutral.border};\n    border-radius: 0 ${({ theme }) => theme.radii.default} ${({ theme }) =>\n      theme.radii.default} 0;\n  }\n\n  &:not([aria-disabled='true']):hover td, &:not([aria-disabled='true']):hover td:first-child, &:not([aria-disabled='true']):hover td:last-child {\n    border-color: ${({ theme }) => theme.colors.primary.border};\n  }\n\n  &:not([aria-disabled='true']):hover + ${ExpandableWrapper} td {\n    border-color: ${({ theme }) => theme.colors.primary.border};\n  }\n\n  &[aria-expanded='true'] td {\n    &:first-child {\n      border-left: 1px solid ${({ theme }) => theme.colors.neutral.border};\n      border-radius: ${({ theme }) => theme.radii.default} 0 0 0;\n    }\n    &:last-child {\n      border-right: 1px solid ${({ theme }) => theme.colors.neutral.border};\n      border-radius: 0 ${({ theme }) => theme.radii.default} 0 0;\n    }\n    border-bottom-color: ${({ theme }) => theme.colors.neutral.border};\n  }\n\n  ${({ theme, sentiment }) =>\n    `\n    color: ${theme.colors[sentiment].text};\n    border-color: ${theme.colors[sentiment].border};\n    background-color: ${theme.colors[sentiment].background};\n    & [data-expandable-content] {\n      border-color: ${theme.colors[sentiment].border};\n    }\n\n    ${\n      sentiment === 'neutral'\n        ? `&:not([aria-disabled='true']):hover {\n          border-color: ${theme.colors.primary.border};\n          box-shadow: ${theme.shadows.hoverPrimary};\n        }\n        `\n        : ''\n    }\n  `}\n\n  &[data-highlight='true'] {\n    td, td:first-child, td:last-child {\n      border-color: ${({ theme }) => theme.colors.primary.border};\n    }\n\n    box-shadow: ${({ theme }) => theme.shadows.hoverPrimary};\n  }\n\n  &[aria-disabled='true'] {\n    background-color: ${({ theme }) => theme.colors.neutral.backgroundDisabled};\n    color: ${({ theme }) => theme.colors.neutral.textDisabled};\n    cursor: not-allowed;\n  }\n\n  ${({ columns, columnsStartAt }) =>\n    columns.map(\n      (column, index) => `\n    td:nth-of-type(${index + 1 + (columnsStartAt ?? 0)}) {\n      ${column.width ? `width: ${column.width};` : ''}\n      ${column.minWidth ? `min-width: ${column.minWidth};` : ''}\n      ${column.maxWidth ? `max-width: ${column.maxWidth};` : ''}\n    }\n  `,\n    )}\n\n  animation: ${({ highlightAnimation, theme }) =>\n    highlightAnimation ? colorChange(theme) : undefined}\n    3s linear;\n`\n\nconst StyledCheckboxContainer = styled.div`\n  display: flex;\n`\n\nconst NoPaddingCell = styled(Cell, {\n  shouldForwardProp: prop => !['maxWidth'].includes(prop),\n})<{\n  maxWidth: string\n}>`\n  padding: 0;\n\n  &:first-of-type {\n    padding-left: ${({ theme }) => theme.space['2']};\n  }\n\n  max-width: ${({ maxWidth }) => maxWidth};\n`\n\nconst ExpandableCell = styled(Cell, {\n  shouldForwardProp: prop => !['padding'].includes(prop),\n})<{ padding?: keyof typeof space }>`\n  padding: ${({ theme, padding }) =>\n    padding ? theme.space[padding] : theme.space['2']};\n`\n\ntype RowProps = {\n  children: ReactNode\n  id: string\n  expandable?: ReactNode\n  /**\n   * Row cannot be selected if this prop is provided. boolean true disabled selection, a string disable selection and a tooltip will be displayed on checkbox hover.\n   * */\n  selectDisabled?: boolean | string\n  disabled?: boolean\n  sentiment?: (typeof SENTIMENTS)[number]\n  expanded?: boolean\n  className?: string\n  /**\n   * Define a custom padding for the content in the expandable\n   */\n  expandablePadding?: keyof typeof space\n  highlightAnimation?: boolean\n  'data-testid'?: string\n  style?: CSSProperties\n  'data-dragging'?: boolean\n  onMouseEnter?: MouseEventHandler<HTMLTableRowElement>\n  onMouseLeave?: MouseEventHandler<HTMLTableRowElement>\n}\n\nexport const Row = forwardRef<HTMLTableRowElement, RowProps>(\n  (\n    {\n      children,\n      id,\n      expandable,\n      disabled,\n      selectDisabled,\n      sentiment = 'neutral',\n      highlightAnimation,\n      expanded,\n      className,\n      expandablePadding,\n      'data-testid': dataTestid,\n      style,\n      'data-dragging': dataDragging,\n      onMouseEnter,\n      onMouseLeave,\n    },\n    forwardedRef,\n  ) => {\n    const {\n      selectable,\n      registerExpandableRow,\n      expandedRowIds,\n      expandRow,\n      collapseRow,\n      registerSelectableRow,\n      selectedRowIds,\n      expandButton,\n      inRange,\n      columns,\n      refList,\n      setRefList,\n      handleOnChange,\n    } = useListContext()\n\n    const theme = useTheme()\n\n    const expandedRowId = useId()\n\n    const checkboxRef = useRef<HTMLInputElement>(null)\n\n    const isSelectDisabled =\n      disabled || (selectDisabled !== undefined && selectDisabled !== false)\n\n    const hasExpandable = !!expandable\n    useEffect(() => {\n      if (hasExpandable) {\n        const unregisterCallback = registerExpandableRow(id, expanded)\n\n        return unregisterCallback\n      }\n\n      return undefined\n    }, [id, hasExpandable, registerExpandableRow, expanded, expandRow])\n\n    useEffect(() => {\n      if (!isSelectDisabled) {\n        const unregisterCallback = registerSelectableRow(id)\n\n        return unregisterCallback\n      }\n\n      return undefined\n    }, [id, registerSelectableRow, isSelectDisabled])\n\n    const toggleRowExpand = useCallback(() => {\n      if (expandedRowIds[id]) {\n        collapseRow(id)\n      } else {\n        expandRow(id)\n      }\n    }, [collapseRow, expandRow, expandedRowIds, id])\n\n    const canClickRowToExpand = !disabled && !!expandable && !expandButton\n\n    useEffect(() => {\n      if (\n        checkboxRef.current !== null &&\n        !refList.includes(checkboxRef as RefObject<HTMLInputElement>)\n      ) {\n        setRefList([...refList, checkboxRef as RefObject<HTMLInputElement>])\n      }\n    }, [refList, setRefList])\n\n    const childrenLength =\n      Children.count(children) + (selectable ? 1 : 0) + (expandButton ? 1 : 0)\n\n    return (\n      <>\n        <StyledRow\n          aria-controls={\n            expandable && expandedRowIds[id] ? expandedRowId : undefined\n          }\n          aria-disabled={disabled}\n          aria-expanded={expandable ? expandedRowIds[id] : undefined}\n          className={className}\n          columns={columns}\n          columnsStartAt={(selectable ? 1 : 0) + (expandButton ? 1 : 0)}\n          data-dragging={dataDragging}\n          data-highlight={selectable && !!selectedRowIds[id]}\n          data-testid={dataTestid}\n          highlightAnimation={highlightAnimation}\n          onClick={canClickRowToExpand ? toggleRowExpand : undefined}\n          onKeyDown={\n            canClickRowToExpand\n              ? event => {\n                  if (event.key === ' ') {\n                    toggleRowExpand()\n                    event.preventDefault()\n                  }\n                }\n              : undefined\n          }\n          onMouseEnter={onMouseEnter}\n          onMouseLeave={onMouseLeave}\n          ref={forwardedRef}\n          role={canClickRowToExpand ? 'button row' : undefined}\n          sentiment={sentiment}\n          style={style}\n          tabIndex={canClickRowToExpand ? 0 : -1}\n        >\n          {selectable ? (\n            <NoPaddingCell maxWidth={theme.sizing[SELECTABLE_CHECKBOX_SIZE]}>\n              <StyledCheckboxContainer>\n                <Tooltip\n                  text={\n                    typeof selectDisabled === 'string'\n                      ? selectDisabled\n                      : undefined\n                  }\n                >\n                  <StyledCheckbox\n                    aria-label=\"select\"\n                    checked={selectedRowIds[id]}\n                    disabled={isSelectDisabled}\n                    inRange={inRange?.includes(id)}\n                    name=\"list-select-checkbox\"\n                    onChange={() => handleOnChange(id, selectedRowIds[id])}\n                    ref={checkboxRef}\n                    value={id}\n                  />\n                </Tooltip>\n              </StyledCheckboxContainer>\n            </NoPaddingCell>\n          ) : null}\n          {expandButton ? (\n            <NoPaddingCell maxWidth={theme.sizing[SELECTABLE_CHECKBOX_SIZE]}>\n              <Button\n                aria-label=\"expand\"\n                data-testid=\"list-expand-button\"\n                disabled={disabled || !expandable}\n                onClick={toggleRowExpand}\n                sentiment={sentiment}\n                size=\"small\"\n                variant=\"ghost\"\n              >\n                {expandedRowIds[id] ? <ArrowUpIcon /> : <ArrowDownIcon />}\n              </Button>\n            </NoPaddingCell>\n          ) : null}\n          {children}\n        </StyledRow>\n        {expandable && expandedRowIds[id] ? (\n          <ExpandableWrapper\n            data-expandable-content\n            data-highlight={selectable && !!selectedRowIds[id]}\n            id={expandedRowId}\n            onClick={\n              canClickRowToExpand\n                ? e => {\n                    e.stopPropagation()\n                  }\n                : undefined\n            }\n            onKeyDown={\n              canClickRowToExpand\n                ? e => {\n                    e.stopPropagation()\n                  }\n                : undefined\n            }\n          >\n            <ExpandableCell\n              colSpan={childrenLength}\n              padding={expandablePadding}\n            >\n              {expandable}\n            </ExpandableCell>\n          </ExpandableWrapper>\n        ) : null}\n      </>\n    )\n  },\n)\n"]} */"));
58
- const colorChange = (theme) => react$1.keyframes`
59
- 5% {
60
- background-color: ${theme.colors.primary.background};
61
- }
62
- 80% {
63
- background-color: ${theme.colors.primary.background};
64
- }
65
- `;
66
- const StyledRow = /* @__PURE__ */ _styled__default.default("tr", process.env.NODE_ENV === "production" ? {
67
- shouldForwardProp: (prop) => !["highlightAnimation", "sentiment", "columns", "columnsStartAt", "data-dragging", "pointerEvent"].includes(prop),
68
- target: "ei4uyz13"
69
- } : {
70
- shouldForwardProp: (prop) => !["highlightAnimation", "sentiment", "columns", "columnsStartAt", "data-dragging", "pointerEvent"].includes(prop),
71
- target: "ei4uyz13",
72
- label: "StyledRow"
73
- })("display:table-row;vertical-align:middle;position:relative;box-shadow:none;background-color:", ({
74
- theme
75
- }) => theme.colors.neutral.background, ";font-size:", ({
76
- theme
77
- }) => theme.typography.bodySmall.fontSize, ";column-gap:", ({
78
- theme
79
- }) => theme.space["2"], ";&[role='button row']{cursor:pointer;}position:relative;td,td:first-child,td:last-child{transition:box-shadow 200ms ease,border-color 200ms ease;}td{border-top:1px solid ", ({
80
- theme
81
- }) => theme.colors.neutral.border, ";border-bottom:1px solid ", ({
82
- theme
83
- }) => theme.colors.neutral.border, ";}td:first-child{border-left:1px solid ", ({
84
- theme
85
- }) => theme.colors.neutral.border, ";border-radius:", ({
86
- theme
87
- }) => theme.radii.default, " 0 0 ", ({
88
- theme
89
- }) => theme.radii.default, ";}td:last-child{border-right:1px solid ", ({
90
- theme
91
- }) => theme.colors.neutral.border, ";border-radius:0 ", ({
92
- theme
93
- }) => theme.radii.default, " ", ({
94
- theme
95
- }) => theme.radii.default, " 0;}&:not([aria-disabled='true']):hover td,&:not([aria-disabled='true']):hover td:first-child,&:not([aria-disabled='true']):hover td:last-child{border-color:", ({
96
- theme
97
- }) => theme.colors.primary.border, ";}&:not([aria-disabled='true']):hover+", ExpandableWrapper, " td{border-color:", ({
98
- theme
99
- }) => theme.colors.primary.border, ";}&[aria-expanded='true'] td{border-bottom-color:", ({
100
- theme
101
- }) => theme.colors.neutral.border, ";&:first-child{border-left:1px solid ", ({
102
- theme
103
- }) => theme.colors.neutral.border, ";border-radius:", ({
104
- theme
105
- }) => theme.radii.default, " 0 0 0;}&:last-child{border-right:1px solid ", ({
106
- theme
107
- }) => theme.colors.neutral.border, ";border-radius:0 ", ({
108
- theme
109
- }) => theme.radii.default, " 0 0;}}", ({
110
- theme,
111
- sentiment
112
- }) => `
113
- color: ${theme.colors[sentiment].text};
114
- border-color: ${theme.colors[sentiment].border};
115
- background-color: ${theme.colors[sentiment].background};
116
- & [data-expandable-content] {
117
- border-color: ${theme.colors[sentiment].border};
118
- }
119
-
120
- ${sentiment === "neutral" ? `&:not([aria-disabled='true']):hover {
121
- border-color: ${theme.colors.primary.border};
122
- box-shadow: ${theme.shadows.hoverPrimary};
123
- }
124
- ` : ""}
125
- `, " &[data-highlight='true']{box-shadow:", ({
126
- theme
127
- }) => theme.shadows.hoverPrimary, ";td,td:first-child,td:last-child{border-color:", ({
128
- theme
129
- }) => theme.colors.primary.border, ";}}&[aria-disabled='true']{background-color:", ({
130
- theme
131
- }) => theme.colors.neutral.backgroundDisabled, ";color:", ({
132
- theme
133
- }) => theme.colors.neutral.textDisabled, ";cursor:not-allowed;}", ({
134
- columns,
135
- columnsStartAt
136
- }) => columns.map((column, index2) => `
137
- td:nth-of-type(${index2 + 1 + (columnsStartAt ?? 0)}) {
138
- ${column.width ? `width: ${column.width};` : ""}
139
- ${column.minWidth ? `min-width: ${column.minWidth};` : ""}
140
- ${column.maxWidth ? `max-width: ${column.maxWidth};` : ""}
141
- }
142
- `), " animation:", ({
143
- highlightAnimation,
144
- theme
145
- }) => highlightAnimation ? colorChange(theme) : void 0, " 3s linear;" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["/home/runner/work/ultraviolet/ultraviolet/packages/ui/src/components/List/Row.tsx"],"names":[],"mappings":"AAkGE","file":"/home/runner/work/ultraviolet/ultraviolet/packages/ui/src/components/List/Row.tsx","sourcesContent":["'use client'\n\nimport type { Theme } from '@emotion/react'\nimport { keyframes, useTheme } from '@emotion/react'\nimport styled from '@emotion/styled'\nimport { ArrowDownIcon, ArrowUpIcon } from '@ultraviolet/icons'\nimport type {\n  CSSProperties,\n  MouseEventHandler,\n  ReactNode,\n  RefObject,\n} from 'react'\nimport {\n  Children,\n  forwardRef,\n  useCallback,\n  useEffect,\n  useId,\n  useRef,\n} from 'react'\nimport type { SENTIMENTS, space } from '../../theme'\nimport { Button } from '../Button'\nimport { Checkbox } from '../Checkbox'\nimport { Tooltip } from '../Tooltip'\nimport { Cell } from './Cell'\nimport { SELECTABLE_CHECKBOX_SIZE } from './constants'\nimport { useListContext } from './ListContext'\nimport type { ColumnProps } from './types'\n\nexport const ExpandableWrapper = styled.tr`\n  width: 100%;\n  display: table-row;\n  vertical-align: middle;\n  cursor: auto;\n  background: ${({ theme }) => theme.colors.neutral.backgroundWeak};\n  border-radius: 0 0 ${({ theme }) => theme.radii.default} ${({ theme }) =>\n    theme.radii.default};\n  transform: translate3d(0, -${({ theme }) => theme.space['2']}, 0);\n  position: relative;\n\n  td, td:first-child, td:last-child {\n    transition:\n      box-shadow 200ms ease,\n      border-color 200ms ease;\n  }\n\n  td {\n    border: 1px solid ${({ theme }) => theme.colors.neutral.border};\n    border-top: none;\n    border-radius: 0 0 ${({ theme }) => theme.radii.default} ${({ theme }) =>\n      theme.radii.default};\n  }\n\n  &[data-highlight=\"true\"] td {\n    border-color: ${({ theme }) => theme.colors.primary.border};\n  }\n`\n\nconst StyledCheckbox = styled(Checkbox, {\n  shouldForwardProp: prop => !['inRange'].includes(prop),\n})<{ inRange: boolean }>`\n  ${({ theme, inRange }) =>\n    inRange\n      ? `\n        rect {\n          fill: ${theme.colors.neutral.backgroundHover};\n          stroke: ${theme.colors.neutral.borderHover};\n        }\n  `\n      : ''}\n\n`\n\nconst colorChange = (theme: Theme) => keyframes`\n  5% {\n    background-color: ${theme.colors.primary.background};\n  }\n  80% {\n    background-color: ${theme.colors.primary.background};\n  }\n`\n\nexport const StyledRow = styled('tr', {\n  shouldForwardProp: prop =>\n    ![\n      'highlightAnimation',\n      'sentiment',\n      'columns',\n      'columnsStartAt',\n      'data-dragging',\n      'pointerEvent',\n    ].includes(prop),\n})<{\n  sentiment: (typeof SENTIMENTS)[number]\n  columns: ColumnProps[]\n  columnsStartAt?: number\n  highlightAnimation?: boolean\n  'data-dragging'?: boolean\n}>`\n  /* List itself also apply style about common templating between HeaderRow and other Rows */\n\n  display: table-row;\n  vertical-align: middle;\n  position: relative;\n  box-shadow: none;\n  background-color: ${({ theme }) => theme.colors.neutral.background};\n  font-size: ${({ theme }) => theme.typography.bodySmall.fontSize};\n  column-gap: ${({ theme }) => theme.space['2']};\n\n  &[role='button row'] {\n    cursor: pointer;\n  }\n\n  position: relative;\n\n  td, td:first-child, td:last-child {\n    transition:\n      box-shadow 200ms ease,\n      border-color 200ms ease;\n  }\n\n  td {\n    border-top: 1px solid ${({ theme }) => theme.colors.neutral.border};\n    border-bottom: 1px solid ${({ theme }) => theme.colors.neutral.border};\n  }\n  td:first-child {\n    border-left: 1px solid ${({ theme }) => theme.colors.neutral.border};\n    border-radius: ${({ theme }) => theme.radii.default} 0 0 ${({ theme }) =>\n      theme.radii.default};\n  }\n  td:last-child {\n    border-right: 1px solid ${({ theme }) => theme.colors.neutral.border};\n    border-radius: 0 ${({ theme }) => theme.radii.default} ${({ theme }) =>\n      theme.radii.default} 0;\n  }\n\n  &:not([aria-disabled='true']):hover td, &:not([aria-disabled='true']):hover td:first-child, &:not([aria-disabled='true']):hover td:last-child {\n    border-color: ${({ theme }) => theme.colors.primary.border};\n  }\n\n  &:not([aria-disabled='true']):hover + ${ExpandableWrapper} td {\n    border-color: ${({ theme }) => theme.colors.primary.border};\n  }\n\n  &[aria-expanded='true'] td {\n    &:first-child {\n      border-left: 1px solid ${({ theme }) => theme.colors.neutral.border};\n      border-radius: ${({ theme }) => theme.radii.default} 0 0 0;\n    }\n    &:last-child {\n      border-right: 1px solid ${({ theme }) => theme.colors.neutral.border};\n      border-radius: 0 ${({ theme }) => theme.radii.default} 0 0;\n    }\n    border-bottom-color: ${({ theme }) => theme.colors.neutral.border};\n  }\n\n  ${({ theme, sentiment }) =>\n    `\n    color: ${theme.colors[sentiment].text};\n    border-color: ${theme.colors[sentiment].border};\n    background-color: ${theme.colors[sentiment].background};\n    & [data-expandable-content] {\n      border-color: ${theme.colors[sentiment].border};\n    }\n\n    ${\n      sentiment === 'neutral'\n        ? `&:not([aria-disabled='true']):hover {\n          border-color: ${theme.colors.primary.border};\n          box-shadow: ${theme.shadows.hoverPrimary};\n        }\n        `\n        : ''\n    }\n  `}\n\n  &[data-highlight='true'] {\n    td, td:first-child, td:last-child {\n      border-color: ${({ theme }) => theme.colors.primary.border};\n    }\n\n    box-shadow: ${({ theme }) => theme.shadows.hoverPrimary};\n  }\n\n  &[aria-disabled='true'] {\n    background-color: ${({ theme }) => theme.colors.neutral.backgroundDisabled};\n    color: ${({ theme }) => theme.colors.neutral.textDisabled};\n    cursor: not-allowed;\n  }\n\n  ${({ columns, columnsStartAt }) =>\n    columns.map(\n      (column, index) => `\n    td:nth-of-type(${index + 1 + (columnsStartAt ?? 0)}) {\n      ${column.width ? `width: ${column.width};` : ''}\n      ${column.minWidth ? `min-width: ${column.minWidth};` : ''}\n      ${column.maxWidth ? `max-width: ${column.maxWidth};` : ''}\n    }\n  `,\n    )}\n\n  animation: ${({ highlightAnimation, theme }) =>\n    highlightAnimation ? colorChange(theme) : undefined}\n    3s linear;\n`\n\nconst StyledCheckboxContainer = styled.div`\n  display: flex;\n`\n\nconst NoPaddingCell = styled(Cell, {\n  shouldForwardProp: prop => !['maxWidth'].includes(prop),\n})<{\n  maxWidth: string\n}>`\n  padding: 0;\n\n  &:first-of-type {\n    padding-left: ${({ theme }) => theme.space['2']};\n  }\n\n  max-width: ${({ maxWidth }) => maxWidth};\n`\n\nconst ExpandableCell = styled(Cell, {\n  shouldForwardProp: prop => !['padding'].includes(prop),\n})<{ padding?: keyof typeof space }>`\n  padding: ${({ theme, padding }) =>\n    padding ? theme.space[padding] : theme.space['2']};\n`\n\ntype RowProps = {\n  children: ReactNode\n  id: string\n  expandable?: ReactNode\n  /**\n   * Row cannot be selected if this prop is provided. boolean true disabled selection, a string disable selection and a tooltip will be displayed on checkbox hover.\n   * */\n  selectDisabled?: boolean | string\n  disabled?: boolean\n  sentiment?: (typeof SENTIMENTS)[number]\n  expanded?: boolean\n  className?: string\n  /**\n   * Define a custom padding for the content in the expandable\n   */\n  expandablePadding?: keyof typeof space\n  highlightAnimation?: boolean\n  'data-testid'?: string\n  style?: CSSProperties\n  'data-dragging'?: boolean\n  onMouseEnter?: MouseEventHandler<HTMLTableRowElement>\n  onMouseLeave?: MouseEventHandler<HTMLTableRowElement>\n}\n\nexport const Row = forwardRef<HTMLTableRowElement, RowProps>(\n  (\n    {\n      children,\n      id,\n      expandable,\n      disabled,\n      selectDisabled,\n      sentiment = 'neutral',\n      highlightAnimation,\n      expanded,\n      className,\n      expandablePadding,\n      'data-testid': dataTestid,\n      style,\n      'data-dragging': dataDragging,\n      onMouseEnter,\n      onMouseLeave,\n    },\n    forwardedRef,\n  ) => {\n    const {\n      selectable,\n      registerExpandableRow,\n      expandedRowIds,\n      expandRow,\n      collapseRow,\n      registerSelectableRow,\n      selectedRowIds,\n      expandButton,\n      inRange,\n      columns,\n      refList,\n      setRefList,\n      handleOnChange,\n    } = useListContext()\n\n    const theme = useTheme()\n\n    const expandedRowId = useId()\n\n    const checkboxRef = useRef<HTMLInputElement>(null)\n\n    const isSelectDisabled =\n      disabled || (selectDisabled !== undefined && selectDisabled !== false)\n\n    const hasExpandable = !!expandable\n    useEffect(() => {\n      if (hasExpandable) {\n        const unregisterCallback = registerExpandableRow(id, expanded)\n\n        return unregisterCallback\n      }\n\n      return undefined\n    }, [id, hasExpandable, registerExpandableRow, expanded, expandRow])\n\n    useEffect(() => {\n      if (!isSelectDisabled) {\n        const unregisterCallback = registerSelectableRow(id)\n\n        return unregisterCallback\n      }\n\n      return undefined\n    }, [id, registerSelectableRow, isSelectDisabled])\n\n    const toggleRowExpand = useCallback(() => {\n      if (expandedRowIds[id]) {\n        collapseRow(id)\n      } else {\n        expandRow(id)\n      }\n    }, [collapseRow, expandRow, expandedRowIds, id])\n\n    const canClickRowToExpand = !disabled && !!expandable && !expandButton\n\n    useEffect(() => {\n      if (\n        checkboxRef.current !== null &&\n        !refList.includes(checkboxRef as RefObject<HTMLInputElement>)\n      ) {\n        setRefList([...refList, checkboxRef as RefObject<HTMLInputElement>])\n      }\n    }, [refList, setRefList])\n\n    const childrenLength =\n      Children.count(children) + (selectable ? 1 : 0) + (expandButton ? 1 : 0)\n\n    return (\n      <>\n        <StyledRow\n          aria-controls={\n            expandable && expandedRowIds[id] ? expandedRowId : undefined\n          }\n          aria-disabled={disabled}\n          aria-expanded={expandable ? expandedRowIds[id] : undefined}\n          className={className}\n          columns={columns}\n          columnsStartAt={(selectable ? 1 : 0) + (expandButton ? 1 : 0)}\n          data-dragging={dataDragging}\n          data-highlight={selectable && !!selectedRowIds[id]}\n          data-testid={dataTestid}\n          highlightAnimation={highlightAnimation}\n          onClick={canClickRowToExpand ? toggleRowExpand : undefined}\n          onKeyDown={\n            canClickRowToExpand\n              ? event => {\n                  if (event.key === ' ') {\n                    toggleRowExpand()\n                    event.preventDefault()\n                  }\n                }\n              : undefined\n          }\n          onMouseEnter={onMouseEnter}\n          onMouseLeave={onMouseLeave}\n          ref={forwardedRef}\n          role={canClickRowToExpand ? 'button row' : undefined}\n          sentiment={sentiment}\n          style={style}\n          tabIndex={canClickRowToExpand ? 0 : -1}\n        >\n          {selectable ? (\n            <NoPaddingCell maxWidth={theme.sizing[SELECTABLE_CHECKBOX_SIZE]}>\n              <StyledCheckboxContainer>\n                <Tooltip\n                  text={\n                    typeof selectDisabled === 'string'\n                      ? selectDisabled\n                      : undefined\n                  }\n                >\n                  <StyledCheckbox\n                    aria-label=\"select\"\n                    checked={selectedRowIds[id]}\n                    disabled={isSelectDisabled}\n                    inRange={inRange?.includes(id)}\n                    name=\"list-select-checkbox\"\n                    onChange={() => handleOnChange(id, selectedRowIds[id])}\n                    ref={checkboxRef}\n                    value={id}\n                  />\n                </Tooltip>\n              </StyledCheckboxContainer>\n            </NoPaddingCell>\n          ) : null}\n          {expandButton ? (\n            <NoPaddingCell maxWidth={theme.sizing[SELECTABLE_CHECKBOX_SIZE]}>\n              <Button\n                aria-label=\"expand\"\n                data-testid=\"list-expand-button\"\n                disabled={disabled || !expandable}\n                onClick={toggleRowExpand}\n                sentiment={sentiment}\n                size=\"small\"\n                variant=\"ghost\"\n              >\n                {expandedRowIds[id] ? <ArrowUpIcon /> : <ArrowDownIcon />}\n              </Button>\n            </NoPaddingCell>\n          ) : null}\n          {children}\n        </StyledRow>\n        {expandable && expandedRowIds[id] ? (\n          <ExpandableWrapper\n            data-expandable-content\n            data-highlight={selectable && !!selectedRowIds[id]}\n            id={expandedRowId}\n            onClick={\n              canClickRowToExpand\n                ? e => {\n                    e.stopPropagation()\n                  }\n                : undefined\n            }\n            onKeyDown={\n              canClickRowToExpand\n                ? e => {\n                    e.stopPropagation()\n                  }\n                : undefined\n            }\n          >\n            <ExpandableCell\n              colSpan={childrenLength}\n              padding={expandablePadding}\n            >\n              {expandable}\n            </ExpandableCell>\n          </ExpandableWrapper>\n        ) : null}\n      </>\n    )\n  },\n)\n"]} */"));
146
- const StyledCheckboxContainer = /* @__PURE__ */ _styled__default.default("div", process.env.NODE_ENV === "production" ? {
147
- target: "ei4uyz12"
148
- } : {
149
- target: "ei4uyz12",
150
- label: "StyledCheckboxContainer"
151
- })(process.env.NODE_ENV === "production" ? {
152
- name: "zjik7",
153
- styles: "display:flex"
154
- } : {
155
- name: "zjik7",
156
- styles: "display:flex/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["/home/runner/work/ultraviolet/ultraviolet/packages/ui/src/components/List/Row.tsx"],"names":[],"mappings":"AA8M0C","file":"/home/runner/work/ultraviolet/ultraviolet/packages/ui/src/components/List/Row.tsx","sourcesContent":["'use client'\n\nimport type { Theme } from '@emotion/react'\nimport { keyframes, useTheme } from '@emotion/react'\nimport styled from '@emotion/styled'\nimport { ArrowDownIcon, ArrowUpIcon } from '@ultraviolet/icons'\nimport type {\n  CSSProperties,\n  MouseEventHandler,\n  ReactNode,\n  RefObject,\n} from 'react'\nimport {\n  Children,\n  forwardRef,\n  useCallback,\n  useEffect,\n  useId,\n  useRef,\n} from 'react'\nimport type { SENTIMENTS, space } from '../../theme'\nimport { Button } from '../Button'\nimport { Checkbox } from '../Checkbox'\nimport { Tooltip } from '../Tooltip'\nimport { Cell } from './Cell'\nimport { SELECTABLE_CHECKBOX_SIZE } from './constants'\nimport { useListContext } from './ListContext'\nimport type { ColumnProps } from './types'\n\nexport const ExpandableWrapper = styled.tr`\n  width: 100%;\n  display: table-row;\n  vertical-align: middle;\n  cursor: auto;\n  background: ${({ theme }) => theme.colors.neutral.backgroundWeak};\n  border-radius: 0 0 ${({ theme }) => theme.radii.default} ${({ theme }) =>\n    theme.radii.default};\n  transform: translate3d(0, -${({ theme }) => theme.space['2']}, 0);\n  position: relative;\n\n  td, td:first-child, td:last-child {\n    transition:\n      box-shadow 200ms ease,\n      border-color 200ms ease;\n  }\n\n  td {\n    border: 1px solid ${({ theme }) => theme.colors.neutral.border};\n    border-top: none;\n    border-radius: 0 0 ${({ theme }) => theme.radii.default} ${({ theme }) =>\n      theme.radii.default};\n  }\n\n  &[data-highlight=\"true\"] td {\n    border-color: ${({ theme }) => theme.colors.primary.border};\n  }\n`\n\nconst StyledCheckbox = styled(Checkbox, {\n  shouldForwardProp: prop => !['inRange'].includes(prop),\n})<{ inRange: boolean }>`\n  ${({ theme, inRange }) =>\n    inRange\n      ? `\n        rect {\n          fill: ${theme.colors.neutral.backgroundHover};\n          stroke: ${theme.colors.neutral.borderHover};\n        }\n  `\n      : ''}\n\n`\n\nconst colorChange = (theme: Theme) => keyframes`\n  5% {\n    background-color: ${theme.colors.primary.background};\n  }\n  80% {\n    background-color: ${theme.colors.primary.background};\n  }\n`\n\nexport const StyledRow = styled('tr', {\n  shouldForwardProp: prop =>\n    ![\n      'highlightAnimation',\n      'sentiment',\n      'columns',\n      'columnsStartAt',\n      'data-dragging',\n      'pointerEvent',\n    ].includes(prop),\n})<{\n  sentiment: (typeof SENTIMENTS)[number]\n  columns: ColumnProps[]\n  columnsStartAt?: number\n  highlightAnimation?: boolean\n  'data-dragging'?: boolean\n}>`\n  /* List itself also apply style about common templating between HeaderRow and other Rows */\n\n  display: table-row;\n  vertical-align: middle;\n  position: relative;\n  box-shadow: none;\n  background-color: ${({ theme }) => theme.colors.neutral.background};\n  font-size: ${({ theme }) => theme.typography.bodySmall.fontSize};\n  column-gap: ${({ theme }) => theme.space['2']};\n\n  &[role='button row'] {\n    cursor: pointer;\n  }\n\n  position: relative;\n\n  td, td:first-child, td:last-child {\n    transition:\n      box-shadow 200ms ease,\n      border-color 200ms ease;\n  }\n\n  td {\n    border-top: 1px solid ${({ theme }) => theme.colors.neutral.border};\n    border-bottom: 1px solid ${({ theme }) => theme.colors.neutral.border};\n  }\n  td:first-child {\n    border-left: 1px solid ${({ theme }) => theme.colors.neutral.border};\n    border-radius: ${({ theme }) => theme.radii.default} 0 0 ${({ theme }) =>\n      theme.radii.default};\n  }\n  td:last-child {\n    border-right: 1px solid ${({ theme }) => theme.colors.neutral.border};\n    border-radius: 0 ${({ theme }) => theme.radii.default} ${({ theme }) =>\n      theme.radii.default} 0;\n  }\n\n  &:not([aria-disabled='true']):hover td, &:not([aria-disabled='true']):hover td:first-child, &:not([aria-disabled='true']):hover td:last-child {\n    border-color: ${({ theme }) => theme.colors.primary.border};\n  }\n\n  &:not([aria-disabled='true']):hover + ${ExpandableWrapper} td {\n    border-color: ${({ theme }) => theme.colors.primary.border};\n  }\n\n  &[aria-expanded='true'] td {\n    &:first-child {\n      border-left: 1px solid ${({ theme }) => theme.colors.neutral.border};\n      border-radius: ${({ theme }) => theme.radii.default} 0 0 0;\n    }\n    &:last-child {\n      border-right: 1px solid ${({ theme }) => theme.colors.neutral.border};\n      border-radius: 0 ${({ theme }) => theme.radii.default} 0 0;\n    }\n    border-bottom-color: ${({ theme }) => theme.colors.neutral.border};\n  }\n\n  ${({ theme, sentiment }) =>\n    `\n    color: ${theme.colors[sentiment].text};\n    border-color: ${theme.colors[sentiment].border};\n    background-color: ${theme.colors[sentiment].background};\n    & [data-expandable-content] {\n      border-color: ${theme.colors[sentiment].border};\n    }\n\n    ${\n      sentiment === 'neutral'\n        ? `&:not([aria-disabled='true']):hover {\n          border-color: ${theme.colors.primary.border};\n          box-shadow: ${theme.shadows.hoverPrimary};\n        }\n        `\n        : ''\n    }\n  `}\n\n  &[data-highlight='true'] {\n    td, td:first-child, td:last-child {\n      border-color: ${({ theme }) => theme.colors.primary.border};\n    }\n\n    box-shadow: ${({ theme }) => theme.shadows.hoverPrimary};\n  }\n\n  &[aria-disabled='true'] {\n    background-color: ${({ theme }) => theme.colors.neutral.backgroundDisabled};\n    color: ${({ theme }) => theme.colors.neutral.textDisabled};\n    cursor: not-allowed;\n  }\n\n  ${({ columns, columnsStartAt }) =>\n    columns.map(\n      (column, index) => `\n    td:nth-of-type(${index + 1 + (columnsStartAt ?? 0)}) {\n      ${column.width ? `width: ${column.width};` : ''}\n      ${column.minWidth ? `min-width: ${column.minWidth};` : ''}\n      ${column.maxWidth ? `max-width: ${column.maxWidth};` : ''}\n    }\n  `,\n    )}\n\n  animation: ${({ highlightAnimation, theme }) =>\n    highlightAnimation ? colorChange(theme) : undefined}\n    3s linear;\n`\n\nconst StyledCheckboxContainer = styled.div`\n  display: flex;\n`\n\nconst NoPaddingCell = styled(Cell, {\n  shouldForwardProp: prop => !['maxWidth'].includes(prop),\n})<{\n  maxWidth: string\n}>`\n  padding: 0;\n\n  &:first-of-type {\n    padding-left: ${({ theme }) => theme.space['2']};\n  }\n\n  max-width: ${({ maxWidth }) => maxWidth};\n`\n\nconst ExpandableCell = styled(Cell, {\n  shouldForwardProp: prop => !['padding'].includes(prop),\n})<{ padding?: keyof typeof space }>`\n  padding: ${({ theme, padding }) =>\n    padding ? theme.space[padding] : theme.space['2']};\n`\n\ntype RowProps = {\n  children: ReactNode\n  id: string\n  expandable?: ReactNode\n  /**\n   * Row cannot be selected if this prop is provided. boolean true disabled selection, a string disable selection and a tooltip will be displayed on checkbox hover.\n   * */\n  selectDisabled?: boolean | string\n  disabled?: boolean\n  sentiment?: (typeof SENTIMENTS)[number]\n  expanded?: boolean\n  className?: string\n  /**\n   * Define a custom padding for the content in the expandable\n   */\n  expandablePadding?: keyof typeof space\n  highlightAnimation?: boolean\n  'data-testid'?: string\n  style?: CSSProperties\n  'data-dragging'?: boolean\n  onMouseEnter?: MouseEventHandler<HTMLTableRowElement>\n  onMouseLeave?: MouseEventHandler<HTMLTableRowElement>\n}\n\nexport const Row = forwardRef<HTMLTableRowElement, RowProps>(\n  (\n    {\n      children,\n      id,\n      expandable,\n      disabled,\n      selectDisabled,\n      sentiment = 'neutral',\n      highlightAnimation,\n      expanded,\n      className,\n      expandablePadding,\n      'data-testid': dataTestid,\n      style,\n      'data-dragging': dataDragging,\n      onMouseEnter,\n      onMouseLeave,\n    },\n    forwardedRef,\n  ) => {\n    const {\n      selectable,\n      registerExpandableRow,\n      expandedRowIds,\n      expandRow,\n      collapseRow,\n      registerSelectableRow,\n      selectedRowIds,\n      expandButton,\n      inRange,\n      columns,\n      refList,\n      setRefList,\n      handleOnChange,\n    } = useListContext()\n\n    const theme = useTheme()\n\n    const expandedRowId = useId()\n\n    const checkboxRef = useRef<HTMLInputElement>(null)\n\n    const isSelectDisabled =\n      disabled || (selectDisabled !== undefined && selectDisabled !== false)\n\n    const hasExpandable = !!expandable\n    useEffect(() => {\n      if (hasExpandable) {\n        const unregisterCallback = registerExpandableRow(id, expanded)\n\n        return unregisterCallback\n      }\n\n      return undefined\n    }, [id, hasExpandable, registerExpandableRow, expanded, expandRow])\n\n    useEffect(() => {\n      if (!isSelectDisabled) {\n        const unregisterCallback = registerSelectableRow(id)\n\n        return unregisterCallback\n      }\n\n      return undefined\n    }, [id, registerSelectableRow, isSelectDisabled])\n\n    const toggleRowExpand = useCallback(() => {\n      if (expandedRowIds[id]) {\n        collapseRow(id)\n      } else {\n        expandRow(id)\n      }\n    }, [collapseRow, expandRow, expandedRowIds, id])\n\n    const canClickRowToExpand = !disabled && !!expandable && !expandButton\n\n    useEffect(() => {\n      if (\n        checkboxRef.current !== null &&\n        !refList.includes(checkboxRef as RefObject<HTMLInputElement>)\n      ) {\n        setRefList([...refList, checkboxRef as RefObject<HTMLInputElement>])\n      }\n    }, [refList, setRefList])\n\n    const childrenLength =\n      Children.count(children) + (selectable ? 1 : 0) + (expandButton ? 1 : 0)\n\n    return (\n      <>\n        <StyledRow\n          aria-controls={\n            expandable && expandedRowIds[id] ? expandedRowId : undefined\n          }\n          aria-disabled={disabled}\n          aria-expanded={expandable ? expandedRowIds[id] : undefined}\n          className={className}\n          columns={columns}\n          columnsStartAt={(selectable ? 1 : 0) + (expandButton ? 1 : 0)}\n          data-dragging={dataDragging}\n          data-highlight={selectable && !!selectedRowIds[id]}\n          data-testid={dataTestid}\n          highlightAnimation={highlightAnimation}\n          onClick={canClickRowToExpand ? toggleRowExpand : undefined}\n          onKeyDown={\n            canClickRowToExpand\n              ? event => {\n                  if (event.key === ' ') {\n                    toggleRowExpand()\n                    event.preventDefault()\n                  }\n                }\n              : undefined\n          }\n          onMouseEnter={onMouseEnter}\n          onMouseLeave={onMouseLeave}\n          ref={forwardedRef}\n          role={canClickRowToExpand ? 'button row' : undefined}\n          sentiment={sentiment}\n          style={style}\n          tabIndex={canClickRowToExpand ? 0 : -1}\n        >\n          {selectable ? (\n            <NoPaddingCell maxWidth={theme.sizing[SELECTABLE_CHECKBOX_SIZE]}>\n              <StyledCheckboxContainer>\n                <Tooltip\n                  text={\n                    typeof selectDisabled === 'string'\n                      ? selectDisabled\n                      : undefined\n                  }\n                >\n                  <StyledCheckbox\n                    aria-label=\"select\"\n                    checked={selectedRowIds[id]}\n                    disabled={isSelectDisabled}\n                    inRange={inRange?.includes(id)}\n                    name=\"list-select-checkbox\"\n                    onChange={() => handleOnChange(id, selectedRowIds[id])}\n                    ref={checkboxRef}\n                    value={id}\n                  />\n                </Tooltip>\n              </StyledCheckboxContainer>\n            </NoPaddingCell>\n          ) : null}\n          {expandButton ? (\n            <NoPaddingCell maxWidth={theme.sizing[SELECTABLE_CHECKBOX_SIZE]}>\n              <Button\n                aria-label=\"expand\"\n                data-testid=\"list-expand-button\"\n                disabled={disabled || !expandable}\n                onClick={toggleRowExpand}\n                sentiment={sentiment}\n                size=\"small\"\n                variant=\"ghost\"\n              >\n                {expandedRowIds[id] ? <ArrowUpIcon /> : <ArrowDownIcon />}\n              </Button>\n            </NoPaddingCell>\n          ) : null}\n          {children}\n        </StyledRow>\n        {expandable && expandedRowIds[id] ? (\n          <ExpandableWrapper\n            data-expandable-content\n            data-highlight={selectable && !!selectedRowIds[id]}\n            id={expandedRowId}\n            onClick={\n              canClickRowToExpand\n                ? e => {\n                    e.stopPropagation()\n                  }\n                : undefined\n            }\n            onKeyDown={\n              canClickRowToExpand\n                ? e => {\n                    e.stopPropagation()\n                  }\n                : undefined\n            }\n          >\n            <ExpandableCell\n              colSpan={childrenLength}\n              padding={expandablePadding}\n            >\n              {expandable}\n            </ExpandableCell>\n          </ExpandableWrapper>\n        ) : null}\n      </>\n    )\n  },\n)\n"]} */",
157
- toString: _EMOTION_STRINGIFIED_CSS_ERROR__
158
- });
159
- const NoPaddingCell = /* @__PURE__ */ _styled__default.default(Cell.Cell, process.env.NODE_ENV === "production" ? {
160
- shouldForwardProp: (prop) => !["maxWidth"].includes(prop),
161
- target: "ei4uyz11"
162
- } : {
163
- shouldForwardProp: (prop) => !["maxWidth"].includes(prop),
164
- target: "ei4uyz11",
165
- label: "NoPaddingCell"
166
- })("padding:0;&:first-of-type{padding-left:", ({
167
- theme
168
- }) => theme.space["2"], ";}max-width:", ({
169
- maxWidth
170
- }) => maxWidth, ";" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["/home/runner/work/ultraviolet/ultraviolet/packages/ui/src/components/List/Row.tsx"],"names":[],"mappings":"AAsNE","file":"/home/runner/work/ultraviolet/ultraviolet/packages/ui/src/components/List/Row.tsx","sourcesContent":["'use client'\n\nimport type { Theme } from '@emotion/react'\nimport { keyframes, useTheme } from '@emotion/react'\nimport styled from '@emotion/styled'\nimport { ArrowDownIcon, ArrowUpIcon } from '@ultraviolet/icons'\nimport type {\n  CSSProperties,\n  MouseEventHandler,\n  ReactNode,\n  RefObject,\n} from 'react'\nimport {\n  Children,\n  forwardRef,\n  useCallback,\n  useEffect,\n  useId,\n  useRef,\n} from 'react'\nimport type { SENTIMENTS, space } from '../../theme'\nimport { Button } from '../Button'\nimport { Checkbox } from '../Checkbox'\nimport { Tooltip } from '../Tooltip'\nimport { Cell } from './Cell'\nimport { SELECTABLE_CHECKBOX_SIZE } from './constants'\nimport { useListContext } from './ListContext'\nimport type { ColumnProps } from './types'\n\nexport const ExpandableWrapper = styled.tr`\n  width: 100%;\n  display: table-row;\n  vertical-align: middle;\n  cursor: auto;\n  background: ${({ theme }) => theme.colors.neutral.backgroundWeak};\n  border-radius: 0 0 ${({ theme }) => theme.radii.default} ${({ theme }) =>\n    theme.radii.default};\n  transform: translate3d(0, -${({ theme }) => theme.space['2']}, 0);\n  position: relative;\n\n  td, td:first-child, td:last-child {\n    transition:\n      box-shadow 200ms ease,\n      border-color 200ms ease;\n  }\n\n  td {\n    border: 1px solid ${({ theme }) => theme.colors.neutral.border};\n    border-top: none;\n    border-radius: 0 0 ${({ theme }) => theme.radii.default} ${({ theme }) =>\n      theme.radii.default};\n  }\n\n  &[data-highlight=\"true\"] td {\n    border-color: ${({ theme }) => theme.colors.primary.border};\n  }\n`\n\nconst StyledCheckbox = styled(Checkbox, {\n  shouldForwardProp: prop => !['inRange'].includes(prop),\n})<{ inRange: boolean }>`\n  ${({ theme, inRange }) =>\n    inRange\n      ? `\n        rect {\n          fill: ${theme.colors.neutral.backgroundHover};\n          stroke: ${theme.colors.neutral.borderHover};\n        }\n  `\n      : ''}\n\n`\n\nconst colorChange = (theme: Theme) => keyframes`\n  5% {\n    background-color: ${theme.colors.primary.background};\n  }\n  80% {\n    background-color: ${theme.colors.primary.background};\n  }\n`\n\nexport const StyledRow = styled('tr', {\n  shouldForwardProp: prop =>\n    ![\n      'highlightAnimation',\n      'sentiment',\n      'columns',\n      'columnsStartAt',\n      'data-dragging',\n      'pointerEvent',\n    ].includes(prop),\n})<{\n  sentiment: (typeof SENTIMENTS)[number]\n  columns: ColumnProps[]\n  columnsStartAt?: number\n  highlightAnimation?: boolean\n  'data-dragging'?: boolean\n}>`\n  /* List itself also apply style about common templating between HeaderRow and other Rows */\n\n  display: table-row;\n  vertical-align: middle;\n  position: relative;\n  box-shadow: none;\n  background-color: ${({ theme }) => theme.colors.neutral.background};\n  font-size: ${({ theme }) => theme.typography.bodySmall.fontSize};\n  column-gap: ${({ theme }) => theme.space['2']};\n\n  &[role='button row'] {\n    cursor: pointer;\n  }\n\n  position: relative;\n\n  td, td:first-child, td:last-child {\n    transition:\n      box-shadow 200ms ease,\n      border-color 200ms ease;\n  }\n\n  td {\n    border-top: 1px solid ${({ theme }) => theme.colors.neutral.border};\n    border-bottom: 1px solid ${({ theme }) => theme.colors.neutral.border};\n  }\n  td:first-child {\n    border-left: 1px solid ${({ theme }) => theme.colors.neutral.border};\n    border-radius: ${({ theme }) => theme.radii.default} 0 0 ${({ theme }) =>\n      theme.radii.default};\n  }\n  td:last-child {\n    border-right: 1px solid ${({ theme }) => theme.colors.neutral.border};\n    border-radius: 0 ${({ theme }) => theme.radii.default} ${({ theme }) =>\n      theme.radii.default} 0;\n  }\n\n  &:not([aria-disabled='true']):hover td, &:not([aria-disabled='true']):hover td:first-child, &:not([aria-disabled='true']):hover td:last-child {\n    border-color: ${({ theme }) => theme.colors.primary.border};\n  }\n\n  &:not([aria-disabled='true']):hover + ${ExpandableWrapper} td {\n    border-color: ${({ theme }) => theme.colors.primary.border};\n  }\n\n  &[aria-expanded='true'] td {\n    &:first-child {\n      border-left: 1px solid ${({ theme }) => theme.colors.neutral.border};\n      border-radius: ${({ theme }) => theme.radii.default} 0 0 0;\n    }\n    &:last-child {\n      border-right: 1px solid ${({ theme }) => theme.colors.neutral.border};\n      border-radius: 0 ${({ theme }) => theme.radii.default} 0 0;\n    }\n    border-bottom-color: ${({ theme }) => theme.colors.neutral.border};\n  }\n\n  ${({ theme, sentiment }) =>\n    `\n    color: ${theme.colors[sentiment].text};\n    border-color: ${theme.colors[sentiment].border};\n    background-color: ${theme.colors[sentiment].background};\n    & [data-expandable-content] {\n      border-color: ${theme.colors[sentiment].border};\n    }\n\n    ${\n      sentiment === 'neutral'\n        ? `&:not([aria-disabled='true']):hover {\n          border-color: ${theme.colors.primary.border};\n          box-shadow: ${theme.shadows.hoverPrimary};\n        }\n        `\n        : ''\n    }\n  `}\n\n  &[data-highlight='true'] {\n    td, td:first-child, td:last-child {\n      border-color: ${({ theme }) => theme.colors.primary.border};\n    }\n\n    box-shadow: ${({ theme }) => theme.shadows.hoverPrimary};\n  }\n\n  &[aria-disabled='true'] {\n    background-color: ${({ theme }) => theme.colors.neutral.backgroundDisabled};\n    color: ${({ theme }) => theme.colors.neutral.textDisabled};\n    cursor: not-allowed;\n  }\n\n  ${({ columns, columnsStartAt }) =>\n    columns.map(\n      (column, index) => `\n    td:nth-of-type(${index + 1 + (columnsStartAt ?? 0)}) {\n      ${column.width ? `width: ${column.width};` : ''}\n      ${column.minWidth ? `min-width: ${column.minWidth};` : ''}\n      ${column.maxWidth ? `max-width: ${column.maxWidth};` : ''}\n    }\n  `,\n    )}\n\n  animation: ${({ highlightAnimation, theme }) =>\n    highlightAnimation ? colorChange(theme) : undefined}\n    3s linear;\n`\n\nconst StyledCheckboxContainer = styled.div`\n  display: flex;\n`\n\nconst NoPaddingCell = styled(Cell, {\n  shouldForwardProp: prop => !['maxWidth'].includes(prop),\n})<{\n  maxWidth: string\n}>`\n  padding: 0;\n\n  &:first-of-type {\n    padding-left: ${({ theme }) => theme.space['2']};\n  }\n\n  max-width: ${({ maxWidth }) => maxWidth};\n`\n\nconst ExpandableCell = styled(Cell, {\n  shouldForwardProp: prop => !['padding'].includes(prop),\n})<{ padding?: keyof typeof space }>`\n  padding: ${({ theme, padding }) =>\n    padding ? theme.space[padding] : theme.space['2']};\n`\n\ntype RowProps = {\n  children: ReactNode\n  id: string\n  expandable?: ReactNode\n  /**\n   * Row cannot be selected if this prop is provided. boolean true disabled selection, a string disable selection and a tooltip will be displayed on checkbox hover.\n   * */\n  selectDisabled?: boolean | string\n  disabled?: boolean\n  sentiment?: (typeof SENTIMENTS)[number]\n  expanded?: boolean\n  className?: string\n  /**\n   * Define a custom padding for the content in the expandable\n   */\n  expandablePadding?: keyof typeof space\n  highlightAnimation?: boolean\n  'data-testid'?: string\n  style?: CSSProperties\n  'data-dragging'?: boolean\n  onMouseEnter?: MouseEventHandler<HTMLTableRowElement>\n  onMouseLeave?: MouseEventHandler<HTMLTableRowElement>\n}\n\nexport const Row = forwardRef<HTMLTableRowElement, RowProps>(\n  (\n    {\n      children,\n      id,\n      expandable,\n      disabled,\n      selectDisabled,\n      sentiment = 'neutral',\n      highlightAnimation,\n      expanded,\n      className,\n      expandablePadding,\n      'data-testid': dataTestid,\n      style,\n      'data-dragging': dataDragging,\n      onMouseEnter,\n      onMouseLeave,\n    },\n    forwardedRef,\n  ) => {\n    const {\n      selectable,\n      registerExpandableRow,\n      expandedRowIds,\n      expandRow,\n      collapseRow,\n      registerSelectableRow,\n      selectedRowIds,\n      expandButton,\n      inRange,\n      columns,\n      refList,\n      setRefList,\n      handleOnChange,\n    } = useListContext()\n\n    const theme = useTheme()\n\n    const expandedRowId = useId()\n\n    const checkboxRef = useRef<HTMLInputElement>(null)\n\n    const isSelectDisabled =\n      disabled || (selectDisabled !== undefined && selectDisabled !== false)\n\n    const hasExpandable = !!expandable\n    useEffect(() => {\n      if (hasExpandable) {\n        const unregisterCallback = registerExpandableRow(id, expanded)\n\n        return unregisterCallback\n      }\n\n      return undefined\n    }, [id, hasExpandable, registerExpandableRow, expanded, expandRow])\n\n    useEffect(() => {\n      if (!isSelectDisabled) {\n        const unregisterCallback = registerSelectableRow(id)\n\n        return unregisterCallback\n      }\n\n      return undefined\n    }, [id, registerSelectableRow, isSelectDisabled])\n\n    const toggleRowExpand = useCallback(() => {\n      if (expandedRowIds[id]) {\n        collapseRow(id)\n      } else {\n        expandRow(id)\n      }\n    }, [collapseRow, expandRow, expandedRowIds, id])\n\n    const canClickRowToExpand = !disabled && !!expandable && !expandButton\n\n    useEffect(() => {\n      if (\n        checkboxRef.current !== null &&\n        !refList.includes(checkboxRef as RefObject<HTMLInputElement>)\n      ) {\n        setRefList([...refList, checkboxRef as RefObject<HTMLInputElement>])\n      }\n    }, [refList, setRefList])\n\n    const childrenLength =\n      Children.count(children) + (selectable ? 1 : 0) + (expandButton ? 1 : 0)\n\n    return (\n      <>\n        <StyledRow\n          aria-controls={\n            expandable && expandedRowIds[id] ? expandedRowId : undefined\n          }\n          aria-disabled={disabled}\n          aria-expanded={expandable ? expandedRowIds[id] : undefined}\n          className={className}\n          columns={columns}\n          columnsStartAt={(selectable ? 1 : 0) + (expandButton ? 1 : 0)}\n          data-dragging={dataDragging}\n          data-highlight={selectable && !!selectedRowIds[id]}\n          data-testid={dataTestid}\n          highlightAnimation={highlightAnimation}\n          onClick={canClickRowToExpand ? toggleRowExpand : undefined}\n          onKeyDown={\n            canClickRowToExpand\n              ? event => {\n                  if (event.key === ' ') {\n                    toggleRowExpand()\n                    event.preventDefault()\n                  }\n                }\n              : undefined\n          }\n          onMouseEnter={onMouseEnter}\n          onMouseLeave={onMouseLeave}\n          ref={forwardedRef}\n          role={canClickRowToExpand ? 'button row' : undefined}\n          sentiment={sentiment}\n          style={style}\n          tabIndex={canClickRowToExpand ? 0 : -1}\n        >\n          {selectable ? (\n            <NoPaddingCell maxWidth={theme.sizing[SELECTABLE_CHECKBOX_SIZE]}>\n              <StyledCheckboxContainer>\n                <Tooltip\n                  text={\n                    typeof selectDisabled === 'string'\n                      ? selectDisabled\n                      : undefined\n                  }\n                >\n                  <StyledCheckbox\n                    aria-label=\"select\"\n                    checked={selectedRowIds[id]}\n                    disabled={isSelectDisabled}\n                    inRange={inRange?.includes(id)}\n                    name=\"list-select-checkbox\"\n                    onChange={() => handleOnChange(id, selectedRowIds[id])}\n                    ref={checkboxRef}\n                    value={id}\n                  />\n                </Tooltip>\n              </StyledCheckboxContainer>\n            </NoPaddingCell>\n          ) : null}\n          {expandButton ? (\n            <NoPaddingCell maxWidth={theme.sizing[SELECTABLE_CHECKBOX_SIZE]}>\n              <Button\n                aria-label=\"expand\"\n                data-testid=\"list-expand-button\"\n                disabled={disabled || !expandable}\n                onClick={toggleRowExpand}\n                sentiment={sentiment}\n                size=\"small\"\n                variant=\"ghost\"\n              >\n                {expandedRowIds[id] ? <ArrowUpIcon /> : <ArrowDownIcon />}\n              </Button>\n            </NoPaddingCell>\n          ) : null}\n          {children}\n        </StyledRow>\n        {expandable && expandedRowIds[id] ? (\n          <ExpandableWrapper\n            data-expandable-content\n            data-highlight={selectable && !!selectedRowIds[id]}\n            id={expandedRowId}\n            onClick={\n              canClickRowToExpand\n                ? e => {\n                    e.stopPropagation()\n                  }\n                : undefined\n            }\n            onKeyDown={\n              canClickRowToExpand\n                ? e => {\n                    e.stopPropagation()\n                  }\n                : undefined\n            }\n          >\n            <ExpandableCell\n              colSpan={childrenLength}\n              padding={expandablePadding}\n            >\n              {expandable}\n            </ExpandableCell>\n          </ExpandableWrapper>\n        ) : null}\n      </>\n    )\n  },\n)\n"]} */"));
171
- const ExpandableCell = /* @__PURE__ */ _styled__default.default(Cell.Cell, process.env.NODE_ENV === "production" ? {
172
- shouldForwardProp: (prop) => !["padding"].includes(prop),
173
- target: "ei4uyz10"
174
- } : {
175
- shouldForwardProp: (prop) => !["padding"].includes(prop),
176
- target: "ei4uyz10",
177
- label: "ExpandableCell"
178
- })("padding:", ({
179
- theme,
180
- padding
181
- }) => padding ? theme.space[padding] : theme.space["2"], ";" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["/home/runner/work/ultraviolet/ultraviolet/packages/ui/src/components/List/Row.tsx"],"names":[],"mappings":"AAkOoC","file":"/home/runner/work/ultraviolet/ultraviolet/packages/ui/src/components/List/Row.tsx","sourcesContent":["'use client'\n\nimport type { Theme } from '@emotion/react'\nimport { keyframes, useTheme } from '@emotion/react'\nimport styled from '@emotion/styled'\nimport { ArrowDownIcon, ArrowUpIcon } from '@ultraviolet/icons'\nimport type {\n  CSSProperties,\n  MouseEventHandler,\n  ReactNode,\n  RefObject,\n} from 'react'\nimport {\n  Children,\n  forwardRef,\n  useCallback,\n  useEffect,\n  useId,\n  useRef,\n} from 'react'\nimport type { SENTIMENTS, space } from '../../theme'\nimport { Button } from '../Button'\nimport { Checkbox } from '../Checkbox'\nimport { Tooltip } from '../Tooltip'\nimport { Cell } from './Cell'\nimport { SELECTABLE_CHECKBOX_SIZE } from './constants'\nimport { useListContext } from './ListContext'\nimport type { ColumnProps } from './types'\n\nexport const ExpandableWrapper = styled.tr`\n  width: 100%;\n  display: table-row;\n  vertical-align: middle;\n  cursor: auto;\n  background: ${({ theme }) => theme.colors.neutral.backgroundWeak};\n  border-radius: 0 0 ${({ theme }) => theme.radii.default} ${({ theme }) =>\n    theme.radii.default};\n  transform: translate3d(0, -${({ theme }) => theme.space['2']}, 0);\n  position: relative;\n\n  td, td:first-child, td:last-child {\n    transition:\n      box-shadow 200ms ease,\n      border-color 200ms ease;\n  }\n\n  td {\n    border: 1px solid ${({ theme }) => theme.colors.neutral.border};\n    border-top: none;\n    border-radius: 0 0 ${({ theme }) => theme.radii.default} ${({ theme }) =>\n      theme.radii.default};\n  }\n\n  &[data-highlight=\"true\"] td {\n    border-color: ${({ theme }) => theme.colors.primary.border};\n  }\n`\n\nconst StyledCheckbox = styled(Checkbox, {\n  shouldForwardProp: prop => !['inRange'].includes(prop),\n})<{ inRange: boolean }>`\n  ${({ theme, inRange }) =>\n    inRange\n      ? `\n        rect {\n          fill: ${theme.colors.neutral.backgroundHover};\n          stroke: ${theme.colors.neutral.borderHover};\n        }\n  `\n      : ''}\n\n`\n\nconst colorChange = (theme: Theme) => keyframes`\n  5% {\n    background-color: ${theme.colors.primary.background};\n  }\n  80% {\n    background-color: ${theme.colors.primary.background};\n  }\n`\n\nexport const StyledRow = styled('tr', {\n  shouldForwardProp: prop =>\n    ![\n      'highlightAnimation',\n      'sentiment',\n      'columns',\n      'columnsStartAt',\n      'data-dragging',\n      'pointerEvent',\n    ].includes(prop),\n})<{\n  sentiment: (typeof SENTIMENTS)[number]\n  columns: ColumnProps[]\n  columnsStartAt?: number\n  highlightAnimation?: boolean\n  'data-dragging'?: boolean\n}>`\n  /* List itself also apply style about common templating between HeaderRow and other Rows */\n\n  display: table-row;\n  vertical-align: middle;\n  position: relative;\n  box-shadow: none;\n  background-color: ${({ theme }) => theme.colors.neutral.background};\n  font-size: ${({ theme }) => theme.typography.bodySmall.fontSize};\n  column-gap: ${({ theme }) => theme.space['2']};\n\n  &[role='button row'] {\n    cursor: pointer;\n  }\n\n  position: relative;\n\n  td, td:first-child, td:last-child {\n    transition:\n      box-shadow 200ms ease,\n      border-color 200ms ease;\n  }\n\n  td {\n    border-top: 1px solid ${({ theme }) => theme.colors.neutral.border};\n    border-bottom: 1px solid ${({ theme }) => theme.colors.neutral.border};\n  }\n  td:first-child {\n    border-left: 1px solid ${({ theme }) => theme.colors.neutral.border};\n    border-radius: ${({ theme }) => theme.radii.default} 0 0 ${({ theme }) =>\n      theme.radii.default};\n  }\n  td:last-child {\n    border-right: 1px solid ${({ theme }) => theme.colors.neutral.border};\n    border-radius: 0 ${({ theme }) => theme.radii.default} ${({ theme }) =>\n      theme.radii.default} 0;\n  }\n\n  &:not([aria-disabled='true']):hover td, &:not([aria-disabled='true']):hover td:first-child, &:not([aria-disabled='true']):hover td:last-child {\n    border-color: ${({ theme }) => theme.colors.primary.border};\n  }\n\n  &:not([aria-disabled='true']):hover + ${ExpandableWrapper} td {\n    border-color: ${({ theme }) => theme.colors.primary.border};\n  }\n\n  &[aria-expanded='true'] td {\n    &:first-child {\n      border-left: 1px solid ${({ theme }) => theme.colors.neutral.border};\n      border-radius: ${({ theme }) => theme.radii.default} 0 0 0;\n    }\n    &:last-child {\n      border-right: 1px solid ${({ theme }) => theme.colors.neutral.border};\n      border-radius: 0 ${({ theme }) => theme.radii.default} 0 0;\n    }\n    border-bottom-color: ${({ theme }) => theme.colors.neutral.border};\n  }\n\n  ${({ theme, sentiment }) =>\n    `\n    color: ${theme.colors[sentiment].text};\n    border-color: ${theme.colors[sentiment].border};\n    background-color: ${theme.colors[sentiment].background};\n    & [data-expandable-content] {\n      border-color: ${theme.colors[sentiment].border};\n    }\n\n    ${\n      sentiment === 'neutral'\n        ? `&:not([aria-disabled='true']):hover {\n          border-color: ${theme.colors.primary.border};\n          box-shadow: ${theme.shadows.hoverPrimary};\n        }\n        `\n        : ''\n    }\n  `}\n\n  &[data-highlight='true'] {\n    td, td:first-child, td:last-child {\n      border-color: ${({ theme }) => theme.colors.primary.border};\n    }\n\n    box-shadow: ${({ theme }) => theme.shadows.hoverPrimary};\n  }\n\n  &[aria-disabled='true'] {\n    background-color: ${({ theme }) => theme.colors.neutral.backgroundDisabled};\n    color: ${({ theme }) => theme.colors.neutral.textDisabled};\n    cursor: not-allowed;\n  }\n\n  ${({ columns, columnsStartAt }) =>\n    columns.map(\n      (column, index) => `\n    td:nth-of-type(${index + 1 + (columnsStartAt ?? 0)}) {\n      ${column.width ? `width: ${column.width};` : ''}\n      ${column.minWidth ? `min-width: ${column.minWidth};` : ''}\n      ${column.maxWidth ? `max-width: ${column.maxWidth};` : ''}\n    }\n  `,\n    )}\n\n  animation: ${({ highlightAnimation, theme }) =>\n    highlightAnimation ? colorChange(theme) : undefined}\n    3s linear;\n`\n\nconst StyledCheckboxContainer = styled.div`\n  display: flex;\n`\n\nconst NoPaddingCell = styled(Cell, {\n  shouldForwardProp: prop => !['maxWidth'].includes(prop),\n})<{\n  maxWidth: string\n}>`\n  padding: 0;\n\n  &:first-of-type {\n    padding-left: ${({ theme }) => theme.space['2']};\n  }\n\n  max-width: ${({ maxWidth }) => maxWidth};\n`\n\nconst ExpandableCell = styled(Cell, {\n  shouldForwardProp: prop => !['padding'].includes(prop),\n})<{ padding?: keyof typeof space }>`\n  padding: ${({ theme, padding }) =>\n    padding ? theme.space[padding] : theme.space['2']};\n`\n\ntype RowProps = {\n  children: ReactNode\n  id: string\n  expandable?: ReactNode\n  /**\n   * Row cannot be selected if this prop is provided. boolean true disabled selection, a string disable selection and a tooltip will be displayed on checkbox hover.\n   * */\n  selectDisabled?: boolean | string\n  disabled?: boolean\n  sentiment?: (typeof SENTIMENTS)[number]\n  expanded?: boolean\n  className?: string\n  /**\n   * Define a custom padding for the content in the expandable\n   */\n  expandablePadding?: keyof typeof space\n  highlightAnimation?: boolean\n  'data-testid'?: string\n  style?: CSSProperties\n  'data-dragging'?: boolean\n  onMouseEnter?: MouseEventHandler<HTMLTableRowElement>\n  onMouseLeave?: MouseEventHandler<HTMLTableRowElement>\n}\n\nexport const Row = forwardRef<HTMLTableRowElement, RowProps>(\n  (\n    {\n      children,\n      id,\n      expandable,\n      disabled,\n      selectDisabled,\n      sentiment = 'neutral',\n      highlightAnimation,\n      expanded,\n      className,\n      expandablePadding,\n      'data-testid': dataTestid,\n      style,\n      'data-dragging': dataDragging,\n      onMouseEnter,\n      onMouseLeave,\n    },\n    forwardedRef,\n  ) => {\n    const {\n      selectable,\n      registerExpandableRow,\n      expandedRowIds,\n      expandRow,\n      collapseRow,\n      registerSelectableRow,\n      selectedRowIds,\n      expandButton,\n      inRange,\n      columns,\n      refList,\n      setRefList,\n      handleOnChange,\n    } = useListContext()\n\n    const theme = useTheme()\n\n    const expandedRowId = useId()\n\n    const checkboxRef = useRef<HTMLInputElement>(null)\n\n    const isSelectDisabled =\n      disabled || (selectDisabled !== undefined && selectDisabled !== false)\n\n    const hasExpandable = !!expandable\n    useEffect(() => {\n      if (hasExpandable) {\n        const unregisterCallback = registerExpandableRow(id, expanded)\n\n        return unregisterCallback\n      }\n\n      return undefined\n    }, [id, hasExpandable, registerExpandableRow, expanded, expandRow])\n\n    useEffect(() => {\n      if (!isSelectDisabled) {\n        const unregisterCallback = registerSelectableRow(id)\n\n        return unregisterCallback\n      }\n\n      return undefined\n    }, [id, registerSelectableRow, isSelectDisabled])\n\n    const toggleRowExpand = useCallback(() => {\n      if (expandedRowIds[id]) {\n        collapseRow(id)\n      } else {\n        expandRow(id)\n      }\n    }, [collapseRow, expandRow, expandedRowIds, id])\n\n    const canClickRowToExpand = !disabled && !!expandable && !expandButton\n\n    useEffect(() => {\n      if (\n        checkboxRef.current !== null &&\n        !refList.includes(checkboxRef as RefObject<HTMLInputElement>)\n      ) {\n        setRefList([...refList, checkboxRef as RefObject<HTMLInputElement>])\n      }\n    }, [refList, setRefList])\n\n    const childrenLength =\n      Children.count(children) + (selectable ? 1 : 0) + (expandButton ? 1 : 0)\n\n    return (\n      <>\n        <StyledRow\n          aria-controls={\n            expandable && expandedRowIds[id] ? expandedRowId : undefined\n          }\n          aria-disabled={disabled}\n          aria-expanded={expandable ? expandedRowIds[id] : undefined}\n          className={className}\n          columns={columns}\n          columnsStartAt={(selectable ? 1 : 0) + (expandButton ? 1 : 0)}\n          data-dragging={dataDragging}\n          data-highlight={selectable && !!selectedRowIds[id]}\n          data-testid={dataTestid}\n          highlightAnimation={highlightAnimation}\n          onClick={canClickRowToExpand ? toggleRowExpand : undefined}\n          onKeyDown={\n            canClickRowToExpand\n              ? event => {\n                  if (event.key === ' ') {\n                    toggleRowExpand()\n                    event.preventDefault()\n                  }\n                }\n              : undefined\n          }\n          onMouseEnter={onMouseEnter}\n          onMouseLeave={onMouseLeave}\n          ref={forwardedRef}\n          role={canClickRowToExpand ? 'button row' : undefined}\n          sentiment={sentiment}\n          style={style}\n          tabIndex={canClickRowToExpand ? 0 : -1}\n        >\n          {selectable ? (\n            <NoPaddingCell maxWidth={theme.sizing[SELECTABLE_CHECKBOX_SIZE]}>\n              <StyledCheckboxContainer>\n                <Tooltip\n                  text={\n                    typeof selectDisabled === 'string'\n                      ? selectDisabled\n                      : undefined\n                  }\n                >\n                  <StyledCheckbox\n                    aria-label=\"select\"\n                    checked={selectedRowIds[id]}\n                    disabled={isSelectDisabled}\n                    inRange={inRange?.includes(id)}\n                    name=\"list-select-checkbox\"\n                    onChange={() => handleOnChange(id, selectedRowIds[id])}\n                    ref={checkboxRef}\n                    value={id}\n                  />\n                </Tooltip>\n              </StyledCheckboxContainer>\n            </NoPaddingCell>\n          ) : null}\n          {expandButton ? (\n            <NoPaddingCell maxWidth={theme.sizing[SELECTABLE_CHECKBOX_SIZE]}>\n              <Button\n                aria-label=\"expand\"\n                data-testid=\"list-expand-button\"\n                disabled={disabled || !expandable}\n                onClick={toggleRowExpand}\n                sentiment={sentiment}\n                size=\"small\"\n                variant=\"ghost\"\n              >\n                {expandedRowIds[id] ? <ArrowUpIcon /> : <ArrowDownIcon />}\n              </Button>\n            </NoPaddingCell>\n          ) : null}\n          {children}\n        </StyledRow>\n        {expandable && expandedRowIds[id] ? (\n          <ExpandableWrapper\n            data-expandable-content\n            data-highlight={selectable && !!selectedRowIds[id]}\n            id={expandedRowId}\n            onClick={\n              canClickRowToExpand\n                ? e => {\n                    e.stopPropagation()\n                  }\n                : undefined\n            }\n            onKeyDown={\n              canClickRowToExpand\n                ? e => {\n                    e.stopPropagation()\n                  }\n                : undefined\n            }\n          >\n            <ExpandableCell\n              colSpan={childrenLength}\n              padding={expandablePadding}\n            >\n              {expandable}\n            </ExpandableCell>\n          </ExpandableWrapper>\n        ) : null}\n      </>\n    )\n  },\n)\n"]} */"));
15
+ const styles_css = require("./styles.css.cjs");
16
+ const variables_css = require("./variables.css.cjs");
182
17
  const Row = react.forwardRef(({
183
18
  children,
184
19
  id,
@@ -205,13 +40,12 @@ const Row = react.forwardRef(({
205
40
  registerSelectableRow,
206
41
  selectedRowIds,
207
42
  expandButton,
208
- inRange,
209
43
  columns,
44
+ inRange,
210
45
  refList,
211
46
  setRefList,
212
47
  handleOnChange
213
48
  } = ListContext.useListContext();
214
- const theme = react$1.useTheme();
215
49
  const expandedRowId = react.useId();
216
50
  const checkboxRef = react.useRef(null);
217
51
  const isSelectDisabled = disabled || selectDisabled !== void 0 && selectDisabled !== false;
@@ -245,23 +79,29 @@ const Row = react.forwardRef(({
245
79
  }, [refList, setRefList]);
246
80
  const childrenLength = react.Children.count(children) + (selectable ? 1 : 0) + (expandButton ? 1 : 0);
247
81
  return /* @__PURE__ */ jsxRuntime.jsxs(jsxRuntime.Fragment, { children: [
248
- /* @__PURE__ */ jsxRuntime.jsxs(StyledRow, { "aria-controls": expandable && expandedRowIds[id] ? expandedRowId : void 0, "aria-disabled": disabled, "aria-expanded": expandable ? expandedRowIds[id] : void 0, className, columns, columnsStartAt: (selectable ? 1 : 0) + (expandButton ? 1 : 0), "data-dragging": dataDragging, "data-highlight": selectable && !!selectedRowIds[id], "data-testid": dataTestid, highlightAnimation, onClick: canClickRowToExpand ? toggleRowExpand : void 0, onKeyDown: canClickRowToExpand ? (event) => {
82
+ /* @__PURE__ */ jsxRuntime.jsxs("tr", { "aria-controls": expandable && expandedRowIds[id] ? expandedRowId : void 0, "aria-disabled": disabled, "aria-expanded": expandable ? expandedRowIds[id] : void 0, className: `${className ? `${className} ` : ""}${styles_css.listRow({
83
+ highlightAnimation,
84
+ sentiment
85
+ })}`, "data-dragging": dataDragging, "data-highlight": selectable && !!selectedRowIds[id], "data-testid": dataTestid, onClick: canClickRowToExpand ? toggleRowExpand : void 0, onKeyDown: canClickRowToExpand ? (event) => {
249
86
  if (event.key === " ") {
250
87
  toggleRowExpand();
251
88
  event.preventDefault();
252
89
  }
253
- } : void 0, onMouseEnter, onMouseLeave, ref: forwardedRef, role: canClickRowToExpand ? "button row" : void 0, sentiment, style, tabIndex: canClickRowToExpand ? 0 : -1, children: [
254
- selectable ? /* @__PURE__ */ jsxRuntime.jsx(NoPaddingCell, { maxWidth: theme.sizing[constants.SELECTABLE_CHECKBOX_SIZE], children: /* @__PURE__ */ jsxRuntime.jsx(StyledCheckboxContainer, { children: /* @__PURE__ */ jsxRuntime.jsx(index.Tooltip, { text: typeof selectDisabled === "string" ? selectDisabled : void 0, children: /* @__PURE__ */ jsxRuntime.jsx(StyledCheckbox, { "aria-label": "select", checked: selectedRowIds[id], disabled: isSelectDisabled, inRange: inRange?.includes(id), name: "list-select-checkbox", onChange: () => handleOnChange(id, selectedRowIds[id]), ref: checkboxRef, value: id }) }) }) }) : null,
255
- expandButton ? /* @__PURE__ */ jsxRuntime.jsx(NoPaddingCell, { maxWidth: theme.sizing[constants.SELECTABLE_CHECKBOX_SIZE], children: /* @__PURE__ */ jsxRuntime.jsx(index$1.Button, { "aria-label": "expand", "data-testid": "list-expand-button", disabled: disabled || !expandable, onClick: toggleRowExpand, sentiment, size: "small", variant: "ghost", children: expandedRowIds[id] ? /* @__PURE__ */ jsxRuntime.jsx(Icon.ArrowUpIcon, {}) : /* @__PURE__ */ jsxRuntime.jsx(Icon.ArrowDownIcon, {}) }) }) : null,
256
- children
90
+ } : void 0, onMouseEnter, onMouseLeave, ref: forwardedRef, role: canClickRowToExpand ? "button row" : void 0, style, tabIndex: canClickRowToExpand ? 0 : -1, children: [
91
+ selectable ? /* @__PURE__ */ jsxRuntime.jsx(ColumnProvider.ColumnProvider, { width: themes.theme.sizing[300], children: /* @__PURE__ */ jsxRuntime.jsx(Cell.Cell, { className: styles_css.listNoPaddingCell, children: /* @__PURE__ */ jsxRuntime.jsx("div", { className: styles_css.listCheckboxContainer, children: /* @__PURE__ */ jsxRuntime.jsx(index.Tooltip, { text: typeof selectDisabled === "string" ? selectDisabled : void 0, children: /* @__PURE__ */ jsxRuntime.jsx(index$1.Checkbox, { "aria-label": "select", checked: selectedRowIds[id], className: inRange?.includes(id) ? styles_css.listCheckboxInRange : "", disabled: isSelectDisabled, name: "list-select-checkbox", onChange: () => handleOnChange(id, selectedRowIds[id]), ref: checkboxRef, value: id }) }) }) }) }) : null,
92
+ expandButton ? /* @__PURE__ */ jsxRuntime.jsx(ColumnProvider.ColumnProvider, { width: themes.theme.sizing[300], children: /* @__PURE__ */ jsxRuntime.jsx(Cell.Cell, { className: styles_css.listNoPaddingCell, children: /* @__PURE__ */ jsxRuntime.jsx(index$2.Button, { "aria-label": "expand", "data-testid": "list-expand-button", disabled: disabled || !expandable, onClick: toggleRowExpand, sentiment, size: "small", variant: "ghost", children: expandedRowIds[id] ? /* @__PURE__ */ jsxRuntime.jsx(Icon.ArrowUpIcon, {}) : /* @__PURE__ */ jsxRuntime.jsx(Icon.ArrowDownIcon, {}) }) }) }) : null,
93
+ react.Children.map(children, (child, index2) => {
94
+ const column = columns[index2];
95
+ return /* @__PURE__ */ jsxRuntime.jsx(ColumnProvider.ColumnProvider, { maxWidth: column?.maxWidth, minWidth: column?.minWidth, width: column?.width, children: child });
96
+ })
257
97
  ] }),
258
- expandable && expandedRowIds[id] ? /* @__PURE__ */ jsxRuntime.jsx(ExpandableWrapper, { "data-expandable-content": true, "data-highlight": selectable && !!selectedRowIds[id], id: expandedRowId, onClick: canClickRowToExpand ? (e) => {
98
+ expandable && expandedRowIds[id] ? /* @__PURE__ */ jsxRuntime.jsx("tr", { className: styles_css.listExpandableWrapper, "data-expandable-content": true, "data-highlight": selectable && !!selectedRowIds[id], id: expandedRowId, onClick: canClickRowToExpand ? (e) => {
259
99
  e.stopPropagation();
260
100
  } : void 0, onKeyDown: canClickRowToExpand ? (e) => {
261
101
  e.stopPropagation();
262
- } : void 0, children: /* @__PURE__ */ jsxRuntime.jsx(ExpandableCell, { colSpan: childrenLength, padding: expandablePadding, children: expandable }) }) : null
102
+ } : void 0, children: /* @__PURE__ */ jsxRuntime.jsx(Cell.Cell, { className: styles_css.listExpandableCell, colSpan: childrenLength, style: dynamic.assignInlineVars({
103
+ [variables_css.paddingExpandableCell]: themes.theme.space[expandablePadding ?? "2"]
104
+ }), children: expandable }) }) : null
263
105
  ] });
264
106
  });
265
- exports.ExpandableWrapper = ExpandableWrapper;
266
107
  exports.Row = Row;
267
- exports.StyledRow = StyledRow;
@@ -1,21 +1,5 @@
1
- import type { Theme } from '@emotion/react';
2
1
  import type { CSSProperties, MouseEventHandler, ReactNode } from 'react';
3
2
  import type { SENTIMENTS, space } from '../../theme';
4
- import type { ColumnProps } from './types';
5
- export declare const ExpandableWrapper: import("@emotion/styled").StyledComponent<{
6
- theme?: Theme;
7
- as?: React.ElementType;
8
- }, import("react").DetailedHTMLProps<import("react").HTMLAttributes<HTMLTableRowElement>, HTMLTableRowElement>, {}>;
9
- export declare const StyledRow: import("@emotion/styled").StyledComponent<{
10
- theme?: Theme;
11
- as?: React.ElementType;
12
- } & {
13
- sentiment: (typeof SENTIMENTS)[number];
14
- columns: ColumnProps[];
15
- columnsStartAt?: number;
16
- highlightAnimation?: boolean;
17
- 'data-dragging'?: boolean;
18
- }, import("react").DetailedHTMLProps<import("react").HTMLAttributes<HTMLTableRowElement>, HTMLTableRowElement>, {}>;
19
3
  type RowProps = {
20
4
  children: ReactNode;
21
5
  id: string;