@ultraviolet/ui 1.72.1 → 1.72.3

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.
@@ -14,8 +14,10 @@ function _EMOTION_STRINGIFIED_CSS_ERROR__() {
14
14
  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).";
15
15
  }
16
16
  const ExpandableWrapper = /* @__PURE__ */ _styled__default.default("div", process.env.NODE_ENV === "production" ? {
17
+ shouldForwardProp: (prop) => !["padding"].includes(prop),
17
18
  target: "ei4uyz12"
18
19
  } : {
20
+ shouldForwardProp: (prop) => !["padding"].includes(prop),
19
21
  target: "ei4uyz12",
20
22
  label: "ExpandableWrapper"
21
23
  })("grid-column:1/-1;grid-column-start:1;border-top:1px solid ", ({
@@ -23,14 +25,15 @@ const ExpandableWrapper = /* @__PURE__ */ _styled__default.default("div", proces
23
25
  }) => theme.colors.neutral.border, ";margin:0 -", ({
24
26
  theme
25
27
  }) => theme.space["2"], ";padding:", ({
26
- theme
27
- }) => theme.space["2"], ";cursor:auto;background:", ({
28
+ theme,
29
+ padding
30
+ }) => padding ? theme.space[padding] : theme.space["2"], ";cursor:auto;background:", ({
28
31
  theme
29
32
  }) => theme.colors.neutral.backgroundWeak, ";border-radius:0 0 ", ({
30
33
  theme
31
34
  }) => theme.radii.default, " ", ({
32
35
  theme
33
- }) => theme.radii.default, ";" + (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":"AAUoC","file":"/home/runner/work/ultraviolet/ultraviolet/packages/ui/src/components/List/Row.tsx","sourcesContent":["import styled from '@emotion/styled'\nimport type { ForwardedRef, ReactNode } from 'react'\nimport { forwardRef, useCallback, useEffect } from 'react'\nimport type { SENTIMENTS } from '../../theme'\nimport { Button } from '../Button'\nimport { Checkbox } from '../Checkbox'\nimport { Tooltip } from '../Tooltip'\nimport { Cell } from './Cell'\nimport { useListContext } from './ListContext'\n\nconst ExpandableWrapper = styled.div`\n  grid-column: 1 / -1;\n  grid-column-start: 1;\n  border-top: 1px solid ${({ theme }) => theme.colors.neutral.border};\n  margin: 0 -${({ theme }) => theme.space['2']};\n  padding: ${({ theme }) => theme.space['2']};\n  cursor: auto;\n  background: ${({ theme }) => theme.colors.neutral.backgroundWeak};\n  border-radius: 0 0 ${({ theme }) => theme.radii.default}\n    ${({ theme }) => theme.radii.default};\n`\n\nexport const StyledRow = styled('div', {\n  shouldForwardProp: prop => !['sentiment'].includes(prop),\n})<{\n  sentiment: (typeof SENTIMENTS)[number]\n}>`\n  /* List itself also apply style about common templating between HeaderRow and other Rows */\n\n  position: relative;\n  border: 1px solid ${({ theme }) => theme.colors.neutral.border};\n  border-radius: ${({ theme }) => theme.radii.default};\n  transition:\n    box-shadow 200ms ease,\n    border-color 200ms ease;\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  padding: 0 ${({ theme }) => theme.space['2']};\n\n  &[role='button row'] {\n    cursor: pointer;\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        ? `&: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    border-color: ${({ theme }) => theme.colors.primary.border};\n    box-shadow: ${({ theme }) => theme.shadows.hoverPrimary};\n  }\n\n  &[aria-disabled='true'] {\n    border: 1px solid ${({ theme }) => theme.colors.neutral.borderDisabled};\n    background-color: ${({ theme }) => theme.colors.neutral.backgroundDisabled};\n    color: ${({ theme }) => theme.colors.neutral.textDisabled};\n    cursor: not-allowed;\n  }\n`\n\nconst StyledCheckboxContainer = styled.div`\n  display: flex;\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  'data-testid'?: string\n}\n\nexport const Row = forwardRef(\n  (\n    {\n      children,\n      id,\n      expandable,\n      disabled,\n      selectDisabled,\n      sentiment = 'neutral',\n      expanded,\n      className,\n      'data-testid': dataTestid,\n    }: RowProps,\n    ref: ForwardedRef<HTMLDivElement>,\n  ) => {\n    const {\n      selectable,\n      registerExpandableRow,\n      expandedRowIds,\n      expandRow,\n      collapseRow,\n      registerSelectableRow,\n      selectedRowIds,\n      selectRow,\n      unselectRow,\n      expandButton,\n    } = useListContext()\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    return (\n      <StyledRow\n        className={className}\n        ref={ref}\n        role={canClickRowToExpand ? 'button row' : 'row'}\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        tabIndex={canClickRowToExpand ? 0 : -1}\n        sentiment={sentiment}\n        aria-disabled={disabled}\n        aria-expanded={expandable ? expandedRowIds[id] : undefined}\n        data-highlight={!!selectedRowIds[id]}\n        data-testid={dataTestid}\n      >\n        {selectable ? (\n          <Cell preventClick={canClickRowToExpand}>\n            <StyledCheckboxContainer>\n              <Tooltip\n                text={\n                  typeof selectDisabled === 'string'\n                    ? selectDisabled\n                    : undefined\n                }\n              >\n                <Checkbox\n                  name=\"list-select-checkbox\"\n                  aria-label=\"select\"\n                  checked={selectedRowIds[id]}\n                  value={id}\n                  onChange={() => {\n                    if (selectedRowIds[id]) {\n                      unselectRow(id)\n                    } else {\n                      selectRow(id)\n                    }\n                  }}\n                  disabled={isSelectDisabled}\n                />\n              </Tooltip>\n            </StyledCheckboxContainer>\n          </Cell>\n        ) : null}\n        {expandButton ? (\n          <Cell>\n            <Button\n              disabled={disabled || !expandable}\n              icon={expandedRowIds[id] ? 'arrow-up' : 'arrow-down'}\n              onClick={toggleRowExpand}\n              size=\"small\"\n              sentiment={sentiment}\n              variant=\"ghost\"\n              aria-label=\"expand\"\n              data-testid=\"list-expand-button\"\n            />\n          </Cell>\n        ) : null}\n        {children}\n        {expandable && expandedRowIds[id] ? (\n          <ExpandableWrapper\n            data-expandable-content\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            {expandable}\n          </ExpandableWrapper>\n        ) : null}\n      </StyledRow>\n    )\n  },\n)\n"]} */"));
36
+ }) => theme.radii.default, ";" + (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":"AAYoC","file":"/home/runner/work/ultraviolet/ultraviolet/packages/ui/src/components/List/Row.tsx","sourcesContent":["import styled from '@emotion/styled'\nimport type { ForwardedRef, ReactNode } from 'react'\nimport { forwardRef, useCallback, useEffect } 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 { useListContext } from './ListContext'\n\nconst ExpandableWrapper = styled('div', {\n  shouldForwardProp: prop => !['padding'].includes(prop),\n})<{ padding?: keyof typeof space }>`\n  grid-column: 1 / -1;\n  grid-column-start: 1;\n  border-top: 1px solid ${({ theme }) => theme.colors.neutral.border};\n  margin: 0 -${({ theme }) => theme.space['2']};\n  padding: ${({ theme, padding }) => (padding ? theme.space[padding] : theme.space['2'])};\n  cursor: auto;\n  background: ${({ theme }) => theme.colors.neutral.backgroundWeak};\n  border-radius: 0 0 ${({ theme }) => theme.radii.default} ${({ theme }) => theme.radii.default};\n`\n\nexport const StyledRow = styled('div', {\n  shouldForwardProp: prop => !['sentiment'].includes(prop),\n})<{\n  sentiment: (typeof SENTIMENTS)[number]\n}>`\n  /* List itself also apply style about common templating between HeaderRow and other Rows */\n\n  position: relative;\n  border: 1px solid ${({ theme }) => theme.colors.neutral.border};\n  border-radius: ${({ theme }) => theme.radii.default};\n  transition:\n    box-shadow 200ms ease,\n    border-color 200ms ease;\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  padding: 0 ${({ theme }) => theme.space['2']};\n\n  &[role='button row'] {\n    cursor: pointer;\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        ? `&: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    border-color: ${({ theme }) => theme.colors.primary.border};\n    box-shadow: ${({ theme }) => theme.shadows.hoverPrimary};\n  }\n\n  &[aria-disabled='true'] {\n    border: 1px solid ${({ theme }) => theme.colors.neutral.borderDisabled};\n    background-color: ${({ theme }) => theme.colors.neutral.backgroundDisabled};\n    color: ${({ theme }) => theme.colors.neutral.textDisabled};\n    cursor: not-allowed;\n  }\n`\n\nconst StyledCheckboxContainer = styled.div`\n  display: flex;\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  'data-testid'?: string\n}\n\nexport const Row = forwardRef(\n  (\n    {\n      children,\n      id,\n      expandable,\n      disabled,\n      selectDisabled,\n      sentiment = 'neutral',\n      expanded,\n      className,\n      expandablePadding,\n      'data-testid': dataTestid,\n    }: RowProps,\n    ref: ForwardedRef<HTMLDivElement>,\n  ) => {\n    const {\n      selectable,\n      registerExpandableRow,\n      expandedRowIds,\n      expandRow,\n      collapseRow,\n      registerSelectableRow,\n      selectedRowIds,\n      selectRow,\n      unselectRow,\n      expandButton,\n    } = useListContext()\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    return (\n      <StyledRow\n        className={className}\n        ref={ref}\n        role={canClickRowToExpand ? 'button row' : 'row'}\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        tabIndex={canClickRowToExpand ? 0 : -1}\n        sentiment={sentiment}\n        aria-disabled={disabled}\n        aria-expanded={expandable ? expandedRowIds[id] : undefined}\n        data-highlight={!!selectedRowIds[id]}\n        data-testid={dataTestid}\n      >\n        {selectable ? (\n          <Cell preventClick={canClickRowToExpand}>\n            <StyledCheckboxContainer>\n              <Tooltip\n                text={\n                  typeof selectDisabled === 'string'\n                    ? selectDisabled\n                    : undefined\n                }\n              >\n                <Checkbox\n                  name=\"list-select-checkbox\"\n                  aria-label=\"select\"\n                  checked={selectedRowIds[id]}\n                  value={id}\n                  onChange={() => {\n                    if (selectedRowIds[id]) {\n                      unselectRow(id)\n                    } else {\n                      selectRow(id)\n                    }\n                  }}\n                  disabled={isSelectDisabled}\n                />\n              </Tooltip>\n            </StyledCheckboxContainer>\n          </Cell>\n        ) : null}\n        {expandButton ? (\n          <Cell>\n            <Button\n              disabled={disabled || !expandable}\n              icon={expandedRowIds[id] ? 'arrow-up' : 'arrow-down'}\n              onClick={toggleRowExpand}\n              size=\"small\"\n              sentiment={sentiment}\n              variant=\"ghost\"\n              aria-label=\"expand\"\n              data-testid=\"list-expand-button\"\n            />\n          </Cell>\n        ) : null}\n        {children}\n        {expandable && expandedRowIds[id] ? (\n          <ExpandableWrapper\n            data-expandable-content\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            padding={expandablePadding}\n          >\n            {expandable}\n          </ExpandableWrapper>\n        ) : null}\n      </StyledRow>\n    )\n  },\n)\n"]} */"));
34
37
  const StyledRow = /* @__PURE__ */ _styled__default.default("div", process.env.NODE_ENV === "production" ? {
35
38
  shouldForwardProp: (prop) => !["sentiment"].includes(prop),
36
39
  target: "ei4uyz11"
@@ -76,7 +79,7 @@ const StyledRow = /* @__PURE__ */ _styled__default.default("div", process.env.NO
76
79
  theme
77
80
  }) => theme.colors.neutral.backgroundDisabled, ";color:", ({
78
81
  theme
79
- }) => theme.colors.neutral.textDisabled, ";cursor:not-allowed;}" + (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":"AA0BE","file":"/home/runner/work/ultraviolet/ultraviolet/packages/ui/src/components/List/Row.tsx","sourcesContent":["import styled from '@emotion/styled'\nimport type { ForwardedRef, ReactNode } from 'react'\nimport { forwardRef, useCallback, useEffect } from 'react'\nimport type { SENTIMENTS } from '../../theme'\nimport { Button } from '../Button'\nimport { Checkbox } from '../Checkbox'\nimport { Tooltip } from '../Tooltip'\nimport { Cell } from './Cell'\nimport { useListContext } from './ListContext'\n\nconst ExpandableWrapper = styled.div`\n  grid-column: 1 / -1;\n  grid-column-start: 1;\n  border-top: 1px solid ${({ theme }) => theme.colors.neutral.border};\n  margin: 0 -${({ theme }) => theme.space['2']};\n  padding: ${({ theme }) => theme.space['2']};\n  cursor: auto;\n  background: ${({ theme }) => theme.colors.neutral.backgroundWeak};\n  border-radius: 0 0 ${({ theme }) => theme.radii.default}\n    ${({ theme }) => theme.radii.default};\n`\n\nexport const StyledRow = styled('div', {\n  shouldForwardProp: prop => !['sentiment'].includes(prop),\n})<{\n  sentiment: (typeof SENTIMENTS)[number]\n}>`\n  /* List itself also apply style about common templating between HeaderRow and other Rows */\n\n  position: relative;\n  border: 1px solid ${({ theme }) => theme.colors.neutral.border};\n  border-radius: ${({ theme }) => theme.radii.default};\n  transition:\n    box-shadow 200ms ease,\n    border-color 200ms ease;\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  padding: 0 ${({ theme }) => theme.space['2']};\n\n  &[role='button row'] {\n    cursor: pointer;\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        ? `&: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    border-color: ${({ theme }) => theme.colors.primary.border};\n    box-shadow: ${({ theme }) => theme.shadows.hoverPrimary};\n  }\n\n  &[aria-disabled='true'] {\n    border: 1px solid ${({ theme }) => theme.colors.neutral.borderDisabled};\n    background-color: ${({ theme }) => theme.colors.neutral.backgroundDisabled};\n    color: ${({ theme }) => theme.colors.neutral.textDisabled};\n    cursor: not-allowed;\n  }\n`\n\nconst StyledCheckboxContainer = styled.div`\n  display: flex;\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  'data-testid'?: string\n}\n\nexport const Row = forwardRef(\n  (\n    {\n      children,\n      id,\n      expandable,\n      disabled,\n      selectDisabled,\n      sentiment = 'neutral',\n      expanded,\n      className,\n      'data-testid': dataTestid,\n    }: RowProps,\n    ref: ForwardedRef<HTMLDivElement>,\n  ) => {\n    const {\n      selectable,\n      registerExpandableRow,\n      expandedRowIds,\n      expandRow,\n      collapseRow,\n      registerSelectableRow,\n      selectedRowIds,\n      selectRow,\n      unselectRow,\n      expandButton,\n    } = useListContext()\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    return (\n      <StyledRow\n        className={className}\n        ref={ref}\n        role={canClickRowToExpand ? 'button row' : 'row'}\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        tabIndex={canClickRowToExpand ? 0 : -1}\n        sentiment={sentiment}\n        aria-disabled={disabled}\n        aria-expanded={expandable ? expandedRowIds[id] : undefined}\n        data-highlight={!!selectedRowIds[id]}\n        data-testid={dataTestid}\n      >\n        {selectable ? (\n          <Cell preventClick={canClickRowToExpand}>\n            <StyledCheckboxContainer>\n              <Tooltip\n                text={\n                  typeof selectDisabled === 'string'\n                    ? selectDisabled\n                    : undefined\n                }\n              >\n                <Checkbox\n                  name=\"list-select-checkbox\"\n                  aria-label=\"select\"\n                  checked={selectedRowIds[id]}\n                  value={id}\n                  onChange={() => {\n                    if (selectedRowIds[id]) {\n                      unselectRow(id)\n                    } else {\n                      selectRow(id)\n                    }\n                  }}\n                  disabled={isSelectDisabled}\n                />\n              </Tooltip>\n            </StyledCheckboxContainer>\n          </Cell>\n        ) : null}\n        {expandButton ? (\n          <Cell>\n            <Button\n              disabled={disabled || !expandable}\n              icon={expandedRowIds[id] ? 'arrow-up' : 'arrow-down'}\n              onClick={toggleRowExpand}\n              size=\"small\"\n              sentiment={sentiment}\n              variant=\"ghost\"\n              aria-label=\"expand\"\n              data-testid=\"list-expand-button\"\n            />\n          </Cell>\n        ) : null}\n        {children}\n        {expandable && expandedRowIds[id] ? (\n          <ExpandableWrapper\n            data-expandable-content\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            {expandable}\n          </ExpandableWrapper>\n        ) : null}\n      </StyledRow>\n    )\n  },\n)\n"]} */"));
82
+ }) => theme.colors.neutral.textDisabled, ";cursor:not-allowed;}" + (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":"AA2BE","file":"/home/runner/work/ultraviolet/ultraviolet/packages/ui/src/components/List/Row.tsx","sourcesContent":["import styled from '@emotion/styled'\nimport type { ForwardedRef, ReactNode } from 'react'\nimport { forwardRef, useCallback, useEffect } 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 { useListContext } from './ListContext'\n\nconst ExpandableWrapper = styled('div', {\n  shouldForwardProp: prop => !['padding'].includes(prop),\n})<{ padding?: keyof typeof space }>`\n  grid-column: 1 / -1;\n  grid-column-start: 1;\n  border-top: 1px solid ${({ theme }) => theme.colors.neutral.border};\n  margin: 0 -${({ theme }) => theme.space['2']};\n  padding: ${({ theme, padding }) => (padding ? theme.space[padding] : theme.space['2'])};\n  cursor: auto;\n  background: ${({ theme }) => theme.colors.neutral.backgroundWeak};\n  border-radius: 0 0 ${({ theme }) => theme.radii.default} ${({ theme }) => theme.radii.default};\n`\n\nexport const StyledRow = styled('div', {\n  shouldForwardProp: prop => !['sentiment'].includes(prop),\n})<{\n  sentiment: (typeof SENTIMENTS)[number]\n}>`\n  /* List itself also apply style about common templating between HeaderRow and other Rows */\n\n  position: relative;\n  border: 1px solid ${({ theme }) => theme.colors.neutral.border};\n  border-radius: ${({ theme }) => theme.radii.default};\n  transition:\n    box-shadow 200ms ease,\n    border-color 200ms ease;\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  padding: 0 ${({ theme }) => theme.space['2']};\n\n  &[role='button row'] {\n    cursor: pointer;\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        ? `&: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    border-color: ${({ theme }) => theme.colors.primary.border};\n    box-shadow: ${({ theme }) => theme.shadows.hoverPrimary};\n  }\n\n  &[aria-disabled='true'] {\n    border: 1px solid ${({ theme }) => theme.colors.neutral.borderDisabled};\n    background-color: ${({ theme }) => theme.colors.neutral.backgroundDisabled};\n    color: ${({ theme }) => theme.colors.neutral.textDisabled};\n    cursor: not-allowed;\n  }\n`\n\nconst StyledCheckboxContainer = styled.div`\n  display: flex;\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  'data-testid'?: string\n}\n\nexport const Row = forwardRef(\n  (\n    {\n      children,\n      id,\n      expandable,\n      disabled,\n      selectDisabled,\n      sentiment = 'neutral',\n      expanded,\n      className,\n      expandablePadding,\n      'data-testid': dataTestid,\n    }: RowProps,\n    ref: ForwardedRef<HTMLDivElement>,\n  ) => {\n    const {\n      selectable,\n      registerExpandableRow,\n      expandedRowIds,\n      expandRow,\n      collapseRow,\n      registerSelectableRow,\n      selectedRowIds,\n      selectRow,\n      unselectRow,\n      expandButton,\n    } = useListContext()\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    return (\n      <StyledRow\n        className={className}\n        ref={ref}\n        role={canClickRowToExpand ? 'button row' : 'row'}\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        tabIndex={canClickRowToExpand ? 0 : -1}\n        sentiment={sentiment}\n        aria-disabled={disabled}\n        aria-expanded={expandable ? expandedRowIds[id] : undefined}\n        data-highlight={!!selectedRowIds[id]}\n        data-testid={dataTestid}\n      >\n        {selectable ? (\n          <Cell preventClick={canClickRowToExpand}>\n            <StyledCheckboxContainer>\n              <Tooltip\n                text={\n                  typeof selectDisabled === 'string'\n                    ? selectDisabled\n                    : undefined\n                }\n              >\n                <Checkbox\n                  name=\"list-select-checkbox\"\n                  aria-label=\"select\"\n                  checked={selectedRowIds[id]}\n                  value={id}\n                  onChange={() => {\n                    if (selectedRowIds[id]) {\n                      unselectRow(id)\n                    } else {\n                      selectRow(id)\n                    }\n                  }}\n                  disabled={isSelectDisabled}\n                />\n              </Tooltip>\n            </StyledCheckboxContainer>\n          </Cell>\n        ) : null}\n        {expandButton ? (\n          <Cell>\n            <Button\n              disabled={disabled || !expandable}\n              icon={expandedRowIds[id] ? 'arrow-up' : 'arrow-down'}\n              onClick={toggleRowExpand}\n              size=\"small\"\n              sentiment={sentiment}\n              variant=\"ghost\"\n              aria-label=\"expand\"\n              data-testid=\"list-expand-button\"\n            />\n          </Cell>\n        ) : null}\n        {children}\n        {expandable && expandedRowIds[id] ? (\n          <ExpandableWrapper\n            data-expandable-content\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            padding={expandablePadding}\n          >\n            {expandable}\n          </ExpandableWrapper>\n        ) : null}\n      </StyledRow>\n    )\n  },\n)\n"]} */"));
80
83
  const StyledCheckboxContainer = /* @__PURE__ */ _styled__default.default("div", process.env.NODE_ENV === "production" ? {
81
84
  target: "ei4uyz10"
82
85
  } : {
@@ -88,7 +91,7 @@ const StyledCheckboxContainer = /* @__PURE__ */ _styled__default.default("div",
88
91
  } : {
89
92
  name: "zjik7",
90
93
  styles: "display:flex",
91
- map: "/*# 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":"AA8E0C","file":"/home/runner/work/ultraviolet/ultraviolet/packages/ui/src/components/List/Row.tsx","sourcesContent":["import styled from '@emotion/styled'\nimport type { ForwardedRef, ReactNode } from 'react'\nimport { forwardRef, useCallback, useEffect } from 'react'\nimport type { SENTIMENTS } from '../../theme'\nimport { Button } from '../Button'\nimport { Checkbox } from '../Checkbox'\nimport { Tooltip } from '../Tooltip'\nimport { Cell } from './Cell'\nimport { useListContext } from './ListContext'\n\nconst ExpandableWrapper = styled.div`\n  grid-column: 1 / -1;\n  grid-column-start: 1;\n  border-top: 1px solid ${({ theme }) => theme.colors.neutral.border};\n  margin: 0 -${({ theme }) => theme.space['2']};\n  padding: ${({ theme }) => theme.space['2']};\n  cursor: auto;\n  background: ${({ theme }) => theme.colors.neutral.backgroundWeak};\n  border-radius: 0 0 ${({ theme }) => theme.radii.default}\n    ${({ theme }) => theme.radii.default};\n`\n\nexport const StyledRow = styled('div', {\n  shouldForwardProp: prop => !['sentiment'].includes(prop),\n})<{\n  sentiment: (typeof SENTIMENTS)[number]\n}>`\n  /* List itself also apply style about common templating between HeaderRow and other Rows */\n\n  position: relative;\n  border: 1px solid ${({ theme }) => theme.colors.neutral.border};\n  border-radius: ${({ theme }) => theme.radii.default};\n  transition:\n    box-shadow 200ms ease,\n    border-color 200ms ease;\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  padding: 0 ${({ theme }) => theme.space['2']};\n\n  &[role='button row'] {\n    cursor: pointer;\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        ? `&: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    border-color: ${({ theme }) => theme.colors.primary.border};\n    box-shadow: ${({ theme }) => theme.shadows.hoverPrimary};\n  }\n\n  &[aria-disabled='true'] {\n    border: 1px solid ${({ theme }) => theme.colors.neutral.borderDisabled};\n    background-color: ${({ theme }) => theme.colors.neutral.backgroundDisabled};\n    color: ${({ theme }) => theme.colors.neutral.textDisabled};\n    cursor: not-allowed;\n  }\n`\n\nconst StyledCheckboxContainer = styled.div`\n  display: flex;\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  'data-testid'?: string\n}\n\nexport const Row = forwardRef(\n  (\n    {\n      children,\n      id,\n      expandable,\n      disabled,\n      selectDisabled,\n      sentiment = 'neutral',\n      expanded,\n      className,\n      'data-testid': dataTestid,\n    }: RowProps,\n    ref: ForwardedRef<HTMLDivElement>,\n  ) => {\n    const {\n      selectable,\n      registerExpandableRow,\n      expandedRowIds,\n      expandRow,\n      collapseRow,\n      registerSelectableRow,\n      selectedRowIds,\n      selectRow,\n      unselectRow,\n      expandButton,\n    } = useListContext()\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    return (\n      <StyledRow\n        className={className}\n        ref={ref}\n        role={canClickRowToExpand ? 'button row' : 'row'}\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        tabIndex={canClickRowToExpand ? 0 : -1}\n        sentiment={sentiment}\n        aria-disabled={disabled}\n        aria-expanded={expandable ? expandedRowIds[id] : undefined}\n        data-highlight={!!selectedRowIds[id]}\n        data-testid={dataTestid}\n      >\n        {selectable ? (\n          <Cell preventClick={canClickRowToExpand}>\n            <StyledCheckboxContainer>\n              <Tooltip\n                text={\n                  typeof selectDisabled === 'string'\n                    ? selectDisabled\n                    : undefined\n                }\n              >\n                <Checkbox\n                  name=\"list-select-checkbox\"\n                  aria-label=\"select\"\n                  checked={selectedRowIds[id]}\n                  value={id}\n                  onChange={() => {\n                    if (selectedRowIds[id]) {\n                      unselectRow(id)\n                    } else {\n                      selectRow(id)\n                    }\n                  }}\n                  disabled={isSelectDisabled}\n                />\n              </Tooltip>\n            </StyledCheckboxContainer>\n          </Cell>\n        ) : null}\n        {expandButton ? (\n          <Cell>\n            <Button\n              disabled={disabled || !expandable}\n              icon={expandedRowIds[id] ? 'arrow-up' : 'arrow-down'}\n              onClick={toggleRowExpand}\n              size=\"small\"\n              sentiment={sentiment}\n              variant=\"ghost\"\n              aria-label=\"expand\"\n              data-testid=\"list-expand-button\"\n            />\n          </Cell>\n        ) : null}\n        {children}\n        {expandable && expandedRowIds[id] ? (\n          <ExpandableWrapper\n            data-expandable-content\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            {expandable}\n          </ExpandableWrapper>\n        ) : null}\n      </StyledRow>\n    )\n  },\n)\n"]} */",
94
+ map: "/*# 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":"AA+E0C","file":"/home/runner/work/ultraviolet/ultraviolet/packages/ui/src/components/List/Row.tsx","sourcesContent":["import styled from '@emotion/styled'\nimport type { ForwardedRef, ReactNode } from 'react'\nimport { forwardRef, useCallback, useEffect } 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 { useListContext } from './ListContext'\n\nconst ExpandableWrapper = styled('div', {\n  shouldForwardProp: prop => !['padding'].includes(prop),\n})<{ padding?: keyof typeof space }>`\n  grid-column: 1 / -1;\n  grid-column-start: 1;\n  border-top: 1px solid ${({ theme }) => theme.colors.neutral.border};\n  margin: 0 -${({ theme }) => theme.space['2']};\n  padding: ${({ theme, padding }) => (padding ? theme.space[padding] : theme.space['2'])};\n  cursor: auto;\n  background: ${({ theme }) => theme.colors.neutral.backgroundWeak};\n  border-radius: 0 0 ${({ theme }) => theme.radii.default} ${({ theme }) => theme.radii.default};\n`\n\nexport const StyledRow = styled('div', {\n  shouldForwardProp: prop => !['sentiment'].includes(prop),\n})<{\n  sentiment: (typeof SENTIMENTS)[number]\n}>`\n  /* List itself also apply style about common templating between HeaderRow and other Rows */\n\n  position: relative;\n  border: 1px solid ${({ theme }) => theme.colors.neutral.border};\n  border-radius: ${({ theme }) => theme.radii.default};\n  transition:\n    box-shadow 200ms ease,\n    border-color 200ms ease;\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  padding: 0 ${({ theme }) => theme.space['2']};\n\n  &[role='button row'] {\n    cursor: pointer;\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        ? `&: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    border-color: ${({ theme }) => theme.colors.primary.border};\n    box-shadow: ${({ theme }) => theme.shadows.hoverPrimary};\n  }\n\n  &[aria-disabled='true'] {\n    border: 1px solid ${({ theme }) => theme.colors.neutral.borderDisabled};\n    background-color: ${({ theme }) => theme.colors.neutral.backgroundDisabled};\n    color: ${({ theme }) => theme.colors.neutral.textDisabled};\n    cursor: not-allowed;\n  }\n`\n\nconst StyledCheckboxContainer = styled.div`\n  display: flex;\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  'data-testid'?: string\n}\n\nexport const Row = forwardRef(\n  (\n    {\n      children,\n      id,\n      expandable,\n      disabled,\n      selectDisabled,\n      sentiment = 'neutral',\n      expanded,\n      className,\n      expandablePadding,\n      'data-testid': dataTestid,\n    }: RowProps,\n    ref: ForwardedRef<HTMLDivElement>,\n  ) => {\n    const {\n      selectable,\n      registerExpandableRow,\n      expandedRowIds,\n      expandRow,\n      collapseRow,\n      registerSelectableRow,\n      selectedRowIds,\n      selectRow,\n      unselectRow,\n      expandButton,\n    } = useListContext()\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    return (\n      <StyledRow\n        className={className}\n        ref={ref}\n        role={canClickRowToExpand ? 'button row' : 'row'}\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        tabIndex={canClickRowToExpand ? 0 : -1}\n        sentiment={sentiment}\n        aria-disabled={disabled}\n        aria-expanded={expandable ? expandedRowIds[id] : undefined}\n        data-highlight={!!selectedRowIds[id]}\n        data-testid={dataTestid}\n      >\n        {selectable ? (\n          <Cell preventClick={canClickRowToExpand}>\n            <StyledCheckboxContainer>\n              <Tooltip\n                text={\n                  typeof selectDisabled === 'string'\n                    ? selectDisabled\n                    : undefined\n                }\n              >\n                <Checkbox\n                  name=\"list-select-checkbox\"\n                  aria-label=\"select\"\n                  checked={selectedRowIds[id]}\n                  value={id}\n                  onChange={() => {\n                    if (selectedRowIds[id]) {\n                      unselectRow(id)\n                    } else {\n                      selectRow(id)\n                    }\n                  }}\n                  disabled={isSelectDisabled}\n                />\n              </Tooltip>\n            </StyledCheckboxContainer>\n          </Cell>\n        ) : null}\n        {expandButton ? (\n          <Cell>\n            <Button\n              disabled={disabled || !expandable}\n              icon={expandedRowIds[id] ? 'arrow-up' : 'arrow-down'}\n              onClick={toggleRowExpand}\n              size=\"small\"\n              sentiment={sentiment}\n              variant=\"ghost\"\n              aria-label=\"expand\"\n              data-testid=\"list-expand-button\"\n            />\n          </Cell>\n        ) : null}\n        {children}\n        {expandable && expandedRowIds[id] ? (\n          <ExpandableWrapper\n            data-expandable-content\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            padding={expandablePadding}\n          >\n            {expandable}\n          </ExpandableWrapper>\n        ) : null}\n      </StyledRow>\n    )\n  },\n)\n"]} */",
92
95
  toString: _EMOTION_STRINGIFIED_CSS_ERROR__
93
96
  });
94
97
  const Row = React.forwardRef(({
@@ -100,6 +103,7 @@ const Row = React.forwardRef(({
100
103
  sentiment = "neutral",
101
104
  expanded,
102
105
  className,
106
+ expandablePadding,
103
107
  "data-testid": dataTestid
104
108
  }, ref) => {
105
109
  const {
@@ -157,7 +161,7 @@ const Row = React.forwardRef(({
157
161
  e.stopPropagation();
158
162
  } : void 0, onKeyDown: canClickRowToExpand ? (e) => {
159
163
  e.stopPropagation();
160
- } : void 0, children: expandable }) : null
164
+ } : void 0, padding: expandablePadding, children: expandable }) : null
161
165
  ] });
162
166
  });
163
167
  exports.Row = Row;
@@ -1,5 +1,5 @@
1
1
  import type { ReactNode } from 'react';
2
- import type { SENTIMENTS } from '../../theme';
2
+ import type { SENTIMENTS, space } from '../../theme';
3
3
  export declare const StyledRow: import("@emotion/styled").StyledComponent<{
4
4
  theme?: import("@emotion/react").Theme;
5
5
  as?: React.ElementType;
@@ -18,6 +18,10 @@ type RowProps = {
18
18
  sentiment?: (typeof SENTIMENTS)[number];
19
19
  expanded?: boolean;
20
20
  className?: string;
21
+ /**
22
+ * Define a custom padding for the content in the expandable
23
+ */
24
+ expandablePadding?: keyof typeof space;
21
25
  'data-testid'?: string;
22
26
  };
23
27
  export declare const Row: import("react").ForwardRefExoticComponent<RowProps & import("react").RefAttributes<HTMLDivElement>>;
@@ -10,8 +10,10 @@ function _EMOTION_STRINGIFIED_CSS_ERROR__() {
10
10
  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).";
11
11
  }
12
12
  const ExpandableWrapper = /* @__PURE__ */ _styled("div", process.env.NODE_ENV === "production" ? {
13
+ shouldForwardProp: (prop) => !["padding"].includes(prop),
13
14
  target: "ei4uyz12"
14
15
  } : {
16
+ shouldForwardProp: (prop) => !["padding"].includes(prop),
15
17
  target: "ei4uyz12",
16
18
  label: "ExpandableWrapper"
17
19
  })("grid-column:1/-1;grid-column-start:1;border-top:1px solid ", ({
@@ -19,14 +21,15 @@ const ExpandableWrapper = /* @__PURE__ */ _styled("div", process.env.NODE_ENV ==
19
21
  }) => theme.colors.neutral.border, ";margin:0 -", ({
20
22
  theme
21
23
  }) => theme.space["2"], ";padding:", ({
22
- theme
23
- }) => theme.space["2"], ";cursor:auto;background:", ({
24
+ theme,
25
+ padding
26
+ }) => padding ? theme.space[padding] : theme.space["2"], ";cursor:auto;background:", ({
24
27
  theme
25
28
  }) => theme.colors.neutral.backgroundWeak, ";border-radius:0 0 ", ({
26
29
  theme
27
30
  }) => theme.radii.default, " ", ({
28
31
  theme
29
- }) => theme.radii.default, ";" + (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":"AAUoC","file":"/home/runner/work/ultraviolet/ultraviolet/packages/ui/src/components/List/Row.tsx","sourcesContent":["import styled from '@emotion/styled'\nimport type { ForwardedRef, ReactNode } from 'react'\nimport { forwardRef, useCallback, useEffect } from 'react'\nimport type { SENTIMENTS } from '../../theme'\nimport { Button } from '../Button'\nimport { Checkbox } from '../Checkbox'\nimport { Tooltip } from '../Tooltip'\nimport { Cell } from './Cell'\nimport { useListContext } from './ListContext'\n\nconst ExpandableWrapper = styled.div`\n  grid-column: 1 / -1;\n  grid-column-start: 1;\n  border-top: 1px solid ${({ theme }) => theme.colors.neutral.border};\n  margin: 0 -${({ theme }) => theme.space['2']};\n  padding: ${({ theme }) => theme.space['2']};\n  cursor: auto;\n  background: ${({ theme }) => theme.colors.neutral.backgroundWeak};\n  border-radius: 0 0 ${({ theme }) => theme.radii.default}\n    ${({ theme }) => theme.radii.default};\n`\n\nexport const StyledRow = styled('div', {\n  shouldForwardProp: prop => !['sentiment'].includes(prop),\n})<{\n  sentiment: (typeof SENTIMENTS)[number]\n}>`\n  /* List itself also apply style about common templating between HeaderRow and other Rows */\n\n  position: relative;\n  border: 1px solid ${({ theme }) => theme.colors.neutral.border};\n  border-radius: ${({ theme }) => theme.radii.default};\n  transition:\n    box-shadow 200ms ease,\n    border-color 200ms ease;\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  padding: 0 ${({ theme }) => theme.space['2']};\n\n  &[role='button row'] {\n    cursor: pointer;\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        ? `&: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    border-color: ${({ theme }) => theme.colors.primary.border};\n    box-shadow: ${({ theme }) => theme.shadows.hoverPrimary};\n  }\n\n  &[aria-disabled='true'] {\n    border: 1px solid ${({ theme }) => theme.colors.neutral.borderDisabled};\n    background-color: ${({ theme }) => theme.colors.neutral.backgroundDisabled};\n    color: ${({ theme }) => theme.colors.neutral.textDisabled};\n    cursor: not-allowed;\n  }\n`\n\nconst StyledCheckboxContainer = styled.div`\n  display: flex;\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  'data-testid'?: string\n}\n\nexport const Row = forwardRef(\n  (\n    {\n      children,\n      id,\n      expandable,\n      disabled,\n      selectDisabled,\n      sentiment = 'neutral',\n      expanded,\n      className,\n      'data-testid': dataTestid,\n    }: RowProps,\n    ref: ForwardedRef<HTMLDivElement>,\n  ) => {\n    const {\n      selectable,\n      registerExpandableRow,\n      expandedRowIds,\n      expandRow,\n      collapseRow,\n      registerSelectableRow,\n      selectedRowIds,\n      selectRow,\n      unselectRow,\n      expandButton,\n    } = useListContext()\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    return (\n      <StyledRow\n        className={className}\n        ref={ref}\n        role={canClickRowToExpand ? 'button row' : 'row'}\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        tabIndex={canClickRowToExpand ? 0 : -1}\n        sentiment={sentiment}\n        aria-disabled={disabled}\n        aria-expanded={expandable ? expandedRowIds[id] : undefined}\n        data-highlight={!!selectedRowIds[id]}\n        data-testid={dataTestid}\n      >\n        {selectable ? (\n          <Cell preventClick={canClickRowToExpand}>\n            <StyledCheckboxContainer>\n              <Tooltip\n                text={\n                  typeof selectDisabled === 'string'\n                    ? selectDisabled\n                    : undefined\n                }\n              >\n                <Checkbox\n                  name=\"list-select-checkbox\"\n                  aria-label=\"select\"\n                  checked={selectedRowIds[id]}\n                  value={id}\n                  onChange={() => {\n                    if (selectedRowIds[id]) {\n                      unselectRow(id)\n                    } else {\n                      selectRow(id)\n                    }\n                  }}\n                  disabled={isSelectDisabled}\n                />\n              </Tooltip>\n            </StyledCheckboxContainer>\n          </Cell>\n        ) : null}\n        {expandButton ? (\n          <Cell>\n            <Button\n              disabled={disabled || !expandable}\n              icon={expandedRowIds[id] ? 'arrow-up' : 'arrow-down'}\n              onClick={toggleRowExpand}\n              size=\"small\"\n              sentiment={sentiment}\n              variant=\"ghost\"\n              aria-label=\"expand\"\n              data-testid=\"list-expand-button\"\n            />\n          </Cell>\n        ) : null}\n        {children}\n        {expandable && expandedRowIds[id] ? (\n          <ExpandableWrapper\n            data-expandable-content\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            {expandable}\n          </ExpandableWrapper>\n        ) : null}\n      </StyledRow>\n    )\n  },\n)\n"]} */"));
32
+ }) => theme.radii.default, ";" + (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":"AAYoC","file":"/home/runner/work/ultraviolet/ultraviolet/packages/ui/src/components/List/Row.tsx","sourcesContent":["import styled from '@emotion/styled'\nimport type { ForwardedRef, ReactNode } from 'react'\nimport { forwardRef, useCallback, useEffect } 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 { useListContext } from './ListContext'\n\nconst ExpandableWrapper = styled('div', {\n  shouldForwardProp: prop => !['padding'].includes(prop),\n})<{ padding?: keyof typeof space }>`\n  grid-column: 1 / -1;\n  grid-column-start: 1;\n  border-top: 1px solid ${({ theme }) => theme.colors.neutral.border};\n  margin: 0 -${({ theme }) => theme.space['2']};\n  padding: ${({ theme, padding }) => (padding ? theme.space[padding] : theme.space['2'])};\n  cursor: auto;\n  background: ${({ theme }) => theme.colors.neutral.backgroundWeak};\n  border-radius: 0 0 ${({ theme }) => theme.radii.default} ${({ theme }) => theme.radii.default};\n`\n\nexport const StyledRow = styled('div', {\n  shouldForwardProp: prop => !['sentiment'].includes(prop),\n})<{\n  sentiment: (typeof SENTIMENTS)[number]\n}>`\n  /* List itself also apply style about common templating between HeaderRow and other Rows */\n\n  position: relative;\n  border: 1px solid ${({ theme }) => theme.colors.neutral.border};\n  border-radius: ${({ theme }) => theme.radii.default};\n  transition:\n    box-shadow 200ms ease,\n    border-color 200ms ease;\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  padding: 0 ${({ theme }) => theme.space['2']};\n\n  &[role='button row'] {\n    cursor: pointer;\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        ? `&: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    border-color: ${({ theme }) => theme.colors.primary.border};\n    box-shadow: ${({ theme }) => theme.shadows.hoverPrimary};\n  }\n\n  &[aria-disabled='true'] {\n    border: 1px solid ${({ theme }) => theme.colors.neutral.borderDisabled};\n    background-color: ${({ theme }) => theme.colors.neutral.backgroundDisabled};\n    color: ${({ theme }) => theme.colors.neutral.textDisabled};\n    cursor: not-allowed;\n  }\n`\n\nconst StyledCheckboxContainer = styled.div`\n  display: flex;\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  'data-testid'?: string\n}\n\nexport const Row = forwardRef(\n  (\n    {\n      children,\n      id,\n      expandable,\n      disabled,\n      selectDisabled,\n      sentiment = 'neutral',\n      expanded,\n      className,\n      expandablePadding,\n      'data-testid': dataTestid,\n    }: RowProps,\n    ref: ForwardedRef<HTMLDivElement>,\n  ) => {\n    const {\n      selectable,\n      registerExpandableRow,\n      expandedRowIds,\n      expandRow,\n      collapseRow,\n      registerSelectableRow,\n      selectedRowIds,\n      selectRow,\n      unselectRow,\n      expandButton,\n    } = useListContext()\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    return (\n      <StyledRow\n        className={className}\n        ref={ref}\n        role={canClickRowToExpand ? 'button row' : 'row'}\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        tabIndex={canClickRowToExpand ? 0 : -1}\n        sentiment={sentiment}\n        aria-disabled={disabled}\n        aria-expanded={expandable ? expandedRowIds[id] : undefined}\n        data-highlight={!!selectedRowIds[id]}\n        data-testid={dataTestid}\n      >\n        {selectable ? (\n          <Cell preventClick={canClickRowToExpand}>\n            <StyledCheckboxContainer>\n              <Tooltip\n                text={\n                  typeof selectDisabled === 'string'\n                    ? selectDisabled\n                    : undefined\n                }\n              >\n                <Checkbox\n                  name=\"list-select-checkbox\"\n                  aria-label=\"select\"\n                  checked={selectedRowIds[id]}\n                  value={id}\n                  onChange={() => {\n                    if (selectedRowIds[id]) {\n                      unselectRow(id)\n                    } else {\n                      selectRow(id)\n                    }\n                  }}\n                  disabled={isSelectDisabled}\n                />\n              </Tooltip>\n            </StyledCheckboxContainer>\n          </Cell>\n        ) : null}\n        {expandButton ? (\n          <Cell>\n            <Button\n              disabled={disabled || !expandable}\n              icon={expandedRowIds[id] ? 'arrow-up' : 'arrow-down'}\n              onClick={toggleRowExpand}\n              size=\"small\"\n              sentiment={sentiment}\n              variant=\"ghost\"\n              aria-label=\"expand\"\n              data-testid=\"list-expand-button\"\n            />\n          </Cell>\n        ) : null}\n        {children}\n        {expandable && expandedRowIds[id] ? (\n          <ExpandableWrapper\n            data-expandable-content\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            padding={expandablePadding}\n          >\n            {expandable}\n          </ExpandableWrapper>\n        ) : null}\n      </StyledRow>\n    )\n  },\n)\n"]} */"));
30
33
  const StyledRow = /* @__PURE__ */ _styled("div", process.env.NODE_ENV === "production" ? {
31
34
  shouldForwardProp: (prop) => !["sentiment"].includes(prop),
32
35
  target: "ei4uyz11"
@@ -72,7 +75,7 @@ const StyledRow = /* @__PURE__ */ _styled("div", process.env.NODE_ENV === "produ
72
75
  theme
73
76
  }) => theme.colors.neutral.backgroundDisabled, ";color:", ({
74
77
  theme
75
- }) => theme.colors.neutral.textDisabled, ";cursor:not-allowed;}" + (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":"AA0BE","file":"/home/runner/work/ultraviolet/ultraviolet/packages/ui/src/components/List/Row.tsx","sourcesContent":["import styled from '@emotion/styled'\nimport type { ForwardedRef, ReactNode } from 'react'\nimport { forwardRef, useCallback, useEffect } from 'react'\nimport type { SENTIMENTS } from '../../theme'\nimport { Button } from '../Button'\nimport { Checkbox } from '../Checkbox'\nimport { Tooltip } from '../Tooltip'\nimport { Cell } from './Cell'\nimport { useListContext } from './ListContext'\n\nconst ExpandableWrapper = styled.div`\n  grid-column: 1 / -1;\n  grid-column-start: 1;\n  border-top: 1px solid ${({ theme }) => theme.colors.neutral.border};\n  margin: 0 -${({ theme }) => theme.space['2']};\n  padding: ${({ theme }) => theme.space['2']};\n  cursor: auto;\n  background: ${({ theme }) => theme.colors.neutral.backgroundWeak};\n  border-radius: 0 0 ${({ theme }) => theme.radii.default}\n    ${({ theme }) => theme.radii.default};\n`\n\nexport const StyledRow = styled('div', {\n  shouldForwardProp: prop => !['sentiment'].includes(prop),\n})<{\n  sentiment: (typeof SENTIMENTS)[number]\n}>`\n  /* List itself also apply style about common templating between HeaderRow and other Rows */\n\n  position: relative;\n  border: 1px solid ${({ theme }) => theme.colors.neutral.border};\n  border-radius: ${({ theme }) => theme.radii.default};\n  transition:\n    box-shadow 200ms ease,\n    border-color 200ms ease;\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  padding: 0 ${({ theme }) => theme.space['2']};\n\n  &[role='button row'] {\n    cursor: pointer;\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        ? `&: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    border-color: ${({ theme }) => theme.colors.primary.border};\n    box-shadow: ${({ theme }) => theme.shadows.hoverPrimary};\n  }\n\n  &[aria-disabled='true'] {\n    border: 1px solid ${({ theme }) => theme.colors.neutral.borderDisabled};\n    background-color: ${({ theme }) => theme.colors.neutral.backgroundDisabled};\n    color: ${({ theme }) => theme.colors.neutral.textDisabled};\n    cursor: not-allowed;\n  }\n`\n\nconst StyledCheckboxContainer = styled.div`\n  display: flex;\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  'data-testid'?: string\n}\n\nexport const Row = forwardRef(\n  (\n    {\n      children,\n      id,\n      expandable,\n      disabled,\n      selectDisabled,\n      sentiment = 'neutral',\n      expanded,\n      className,\n      'data-testid': dataTestid,\n    }: RowProps,\n    ref: ForwardedRef<HTMLDivElement>,\n  ) => {\n    const {\n      selectable,\n      registerExpandableRow,\n      expandedRowIds,\n      expandRow,\n      collapseRow,\n      registerSelectableRow,\n      selectedRowIds,\n      selectRow,\n      unselectRow,\n      expandButton,\n    } = useListContext()\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    return (\n      <StyledRow\n        className={className}\n        ref={ref}\n        role={canClickRowToExpand ? 'button row' : 'row'}\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        tabIndex={canClickRowToExpand ? 0 : -1}\n        sentiment={sentiment}\n        aria-disabled={disabled}\n        aria-expanded={expandable ? expandedRowIds[id] : undefined}\n        data-highlight={!!selectedRowIds[id]}\n        data-testid={dataTestid}\n      >\n        {selectable ? (\n          <Cell preventClick={canClickRowToExpand}>\n            <StyledCheckboxContainer>\n              <Tooltip\n                text={\n                  typeof selectDisabled === 'string'\n                    ? selectDisabled\n                    : undefined\n                }\n              >\n                <Checkbox\n                  name=\"list-select-checkbox\"\n                  aria-label=\"select\"\n                  checked={selectedRowIds[id]}\n                  value={id}\n                  onChange={() => {\n                    if (selectedRowIds[id]) {\n                      unselectRow(id)\n                    } else {\n                      selectRow(id)\n                    }\n                  }}\n                  disabled={isSelectDisabled}\n                />\n              </Tooltip>\n            </StyledCheckboxContainer>\n          </Cell>\n        ) : null}\n        {expandButton ? (\n          <Cell>\n            <Button\n              disabled={disabled || !expandable}\n              icon={expandedRowIds[id] ? 'arrow-up' : 'arrow-down'}\n              onClick={toggleRowExpand}\n              size=\"small\"\n              sentiment={sentiment}\n              variant=\"ghost\"\n              aria-label=\"expand\"\n              data-testid=\"list-expand-button\"\n            />\n          </Cell>\n        ) : null}\n        {children}\n        {expandable && expandedRowIds[id] ? (\n          <ExpandableWrapper\n            data-expandable-content\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            {expandable}\n          </ExpandableWrapper>\n        ) : null}\n      </StyledRow>\n    )\n  },\n)\n"]} */"));
78
+ }) => theme.colors.neutral.textDisabled, ";cursor:not-allowed;}" + (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":"AA2BE","file":"/home/runner/work/ultraviolet/ultraviolet/packages/ui/src/components/List/Row.tsx","sourcesContent":["import styled from '@emotion/styled'\nimport type { ForwardedRef, ReactNode } from 'react'\nimport { forwardRef, useCallback, useEffect } 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 { useListContext } from './ListContext'\n\nconst ExpandableWrapper = styled('div', {\n  shouldForwardProp: prop => !['padding'].includes(prop),\n})<{ padding?: keyof typeof space }>`\n  grid-column: 1 / -1;\n  grid-column-start: 1;\n  border-top: 1px solid ${({ theme }) => theme.colors.neutral.border};\n  margin: 0 -${({ theme }) => theme.space['2']};\n  padding: ${({ theme, padding }) => (padding ? theme.space[padding] : theme.space['2'])};\n  cursor: auto;\n  background: ${({ theme }) => theme.colors.neutral.backgroundWeak};\n  border-radius: 0 0 ${({ theme }) => theme.radii.default} ${({ theme }) => theme.radii.default};\n`\n\nexport const StyledRow = styled('div', {\n  shouldForwardProp: prop => !['sentiment'].includes(prop),\n})<{\n  sentiment: (typeof SENTIMENTS)[number]\n}>`\n  /* List itself also apply style about common templating between HeaderRow and other Rows */\n\n  position: relative;\n  border: 1px solid ${({ theme }) => theme.colors.neutral.border};\n  border-radius: ${({ theme }) => theme.radii.default};\n  transition:\n    box-shadow 200ms ease,\n    border-color 200ms ease;\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  padding: 0 ${({ theme }) => theme.space['2']};\n\n  &[role='button row'] {\n    cursor: pointer;\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        ? `&: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    border-color: ${({ theme }) => theme.colors.primary.border};\n    box-shadow: ${({ theme }) => theme.shadows.hoverPrimary};\n  }\n\n  &[aria-disabled='true'] {\n    border: 1px solid ${({ theme }) => theme.colors.neutral.borderDisabled};\n    background-color: ${({ theme }) => theme.colors.neutral.backgroundDisabled};\n    color: ${({ theme }) => theme.colors.neutral.textDisabled};\n    cursor: not-allowed;\n  }\n`\n\nconst StyledCheckboxContainer = styled.div`\n  display: flex;\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  'data-testid'?: string\n}\n\nexport const Row = forwardRef(\n  (\n    {\n      children,\n      id,\n      expandable,\n      disabled,\n      selectDisabled,\n      sentiment = 'neutral',\n      expanded,\n      className,\n      expandablePadding,\n      'data-testid': dataTestid,\n    }: RowProps,\n    ref: ForwardedRef<HTMLDivElement>,\n  ) => {\n    const {\n      selectable,\n      registerExpandableRow,\n      expandedRowIds,\n      expandRow,\n      collapseRow,\n      registerSelectableRow,\n      selectedRowIds,\n      selectRow,\n      unselectRow,\n      expandButton,\n    } = useListContext()\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    return (\n      <StyledRow\n        className={className}\n        ref={ref}\n        role={canClickRowToExpand ? 'button row' : 'row'}\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        tabIndex={canClickRowToExpand ? 0 : -1}\n        sentiment={sentiment}\n        aria-disabled={disabled}\n        aria-expanded={expandable ? expandedRowIds[id] : undefined}\n        data-highlight={!!selectedRowIds[id]}\n        data-testid={dataTestid}\n      >\n        {selectable ? (\n          <Cell preventClick={canClickRowToExpand}>\n            <StyledCheckboxContainer>\n              <Tooltip\n                text={\n                  typeof selectDisabled === 'string'\n                    ? selectDisabled\n                    : undefined\n                }\n              >\n                <Checkbox\n                  name=\"list-select-checkbox\"\n                  aria-label=\"select\"\n                  checked={selectedRowIds[id]}\n                  value={id}\n                  onChange={() => {\n                    if (selectedRowIds[id]) {\n                      unselectRow(id)\n                    } else {\n                      selectRow(id)\n                    }\n                  }}\n                  disabled={isSelectDisabled}\n                />\n              </Tooltip>\n            </StyledCheckboxContainer>\n          </Cell>\n        ) : null}\n        {expandButton ? (\n          <Cell>\n            <Button\n              disabled={disabled || !expandable}\n              icon={expandedRowIds[id] ? 'arrow-up' : 'arrow-down'}\n              onClick={toggleRowExpand}\n              size=\"small\"\n              sentiment={sentiment}\n              variant=\"ghost\"\n              aria-label=\"expand\"\n              data-testid=\"list-expand-button\"\n            />\n          </Cell>\n        ) : null}\n        {children}\n        {expandable && expandedRowIds[id] ? (\n          <ExpandableWrapper\n            data-expandable-content\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            padding={expandablePadding}\n          >\n            {expandable}\n          </ExpandableWrapper>\n        ) : null}\n      </StyledRow>\n    )\n  },\n)\n"]} */"));
76
79
  const StyledCheckboxContainer = /* @__PURE__ */ _styled("div", process.env.NODE_ENV === "production" ? {
77
80
  target: "ei4uyz10"
78
81
  } : {
@@ -84,7 +87,7 @@ const StyledCheckboxContainer = /* @__PURE__ */ _styled("div", process.env.NODE_
84
87
  } : {
85
88
  name: "zjik7",
86
89
  styles: "display:flex",
87
- map: "/*# 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":"AA8E0C","file":"/home/runner/work/ultraviolet/ultraviolet/packages/ui/src/components/List/Row.tsx","sourcesContent":["import styled from '@emotion/styled'\nimport type { ForwardedRef, ReactNode } from 'react'\nimport { forwardRef, useCallback, useEffect } from 'react'\nimport type { SENTIMENTS } from '../../theme'\nimport { Button } from '../Button'\nimport { Checkbox } from '../Checkbox'\nimport { Tooltip } from '../Tooltip'\nimport { Cell } from './Cell'\nimport { useListContext } from './ListContext'\n\nconst ExpandableWrapper = styled.div`\n  grid-column: 1 / -1;\n  grid-column-start: 1;\n  border-top: 1px solid ${({ theme }) => theme.colors.neutral.border};\n  margin: 0 -${({ theme }) => theme.space['2']};\n  padding: ${({ theme }) => theme.space['2']};\n  cursor: auto;\n  background: ${({ theme }) => theme.colors.neutral.backgroundWeak};\n  border-radius: 0 0 ${({ theme }) => theme.radii.default}\n    ${({ theme }) => theme.radii.default};\n`\n\nexport const StyledRow = styled('div', {\n  shouldForwardProp: prop => !['sentiment'].includes(prop),\n})<{\n  sentiment: (typeof SENTIMENTS)[number]\n}>`\n  /* List itself also apply style about common templating between HeaderRow and other Rows */\n\n  position: relative;\n  border: 1px solid ${({ theme }) => theme.colors.neutral.border};\n  border-radius: ${({ theme }) => theme.radii.default};\n  transition:\n    box-shadow 200ms ease,\n    border-color 200ms ease;\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  padding: 0 ${({ theme }) => theme.space['2']};\n\n  &[role='button row'] {\n    cursor: pointer;\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        ? `&: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    border-color: ${({ theme }) => theme.colors.primary.border};\n    box-shadow: ${({ theme }) => theme.shadows.hoverPrimary};\n  }\n\n  &[aria-disabled='true'] {\n    border: 1px solid ${({ theme }) => theme.colors.neutral.borderDisabled};\n    background-color: ${({ theme }) => theme.colors.neutral.backgroundDisabled};\n    color: ${({ theme }) => theme.colors.neutral.textDisabled};\n    cursor: not-allowed;\n  }\n`\n\nconst StyledCheckboxContainer = styled.div`\n  display: flex;\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  'data-testid'?: string\n}\n\nexport const Row = forwardRef(\n  (\n    {\n      children,\n      id,\n      expandable,\n      disabled,\n      selectDisabled,\n      sentiment = 'neutral',\n      expanded,\n      className,\n      'data-testid': dataTestid,\n    }: RowProps,\n    ref: ForwardedRef<HTMLDivElement>,\n  ) => {\n    const {\n      selectable,\n      registerExpandableRow,\n      expandedRowIds,\n      expandRow,\n      collapseRow,\n      registerSelectableRow,\n      selectedRowIds,\n      selectRow,\n      unselectRow,\n      expandButton,\n    } = useListContext()\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    return (\n      <StyledRow\n        className={className}\n        ref={ref}\n        role={canClickRowToExpand ? 'button row' : 'row'}\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        tabIndex={canClickRowToExpand ? 0 : -1}\n        sentiment={sentiment}\n        aria-disabled={disabled}\n        aria-expanded={expandable ? expandedRowIds[id] : undefined}\n        data-highlight={!!selectedRowIds[id]}\n        data-testid={dataTestid}\n      >\n        {selectable ? (\n          <Cell preventClick={canClickRowToExpand}>\n            <StyledCheckboxContainer>\n              <Tooltip\n                text={\n                  typeof selectDisabled === 'string'\n                    ? selectDisabled\n                    : undefined\n                }\n              >\n                <Checkbox\n                  name=\"list-select-checkbox\"\n                  aria-label=\"select\"\n                  checked={selectedRowIds[id]}\n                  value={id}\n                  onChange={() => {\n                    if (selectedRowIds[id]) {\n                      unselectRow(id)\n                    } else {\n                      selectRow(id)\n                    }\n                  }}\n                  disabled={isSelectDisabled}\n                />\n              </Tooltip>\n            </StyledCheckboxContainer>\n          </Cell>\n        ) : null}\n        {expandButton ? (\n          <Cell>\n            <Button\n              disabled={disabled || !expandable}\n              icon={expandedRowIds[id] ? 'arrow-up' : 'arrow-down'}\n              onClick={toggleRowExpand}\n              size=\"small\"\n              sentiment={sentiment}\n              variant=\"ghost\"\n              aria-label=\"expand\"\n              data-testid=\"list-expand-button\"\n            />\n          </Cell>\n        ) : null}\n        {children}\n        {expandable && expandedRowIds[id] ? (\n          <ExpandableWrapper\n            data-expandable-content\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            {expandable}\n          </ExpandableWrapper>\n        ) : null}\n      </StyledRow>\n    )\n  },\n)\n"]} */",
90
+ map: "/*# 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":"AA+E0C","file":"/home/runner/work/ultraviolet/ultraviolet/packages/ui/src/components/List/Row.tsx","sourcesContent":["import styled from '@emotion/styled'\nimport type { ForwardedRef, ReactNode } from 'react'\nimport { forwardRef, useCallback, useEffect } 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 { useListContext } from './ListContext'\n\nconst ExpandableWrapper = styled('div', {\n  shouldForwardProp: prop => !['padding'].includes(prop),\n})<{ padding?: keyof typeof space }>`\n  grid-column: 1 / -1;\n  grid-column-start: 1;\n  border-top: 1px solid ${({ theme }) => theme.colors.neutral.border};\n  margin: 0 -${({ theme }) => theme.space['2']};\n  padding: ${({ theme, padding }) => (padding ? theme.space[padding] : theme.space['2'])};\n  cursor: auto;\n  background: ${({ theme }) => theme.colors.neutral.backgroundWeak};\n  border-radius: 0 0 ${({ theme }) => theme.radii.default} ${({ theme }) => theme.radii.default};\n`\n\nexport const StyledRow = styled('div', {\n  shouldForwardProp: prop => !['sentiment'].includes(prop),\n})<{\n  sentiment: (typeof SENTIMENTS)[number]\n}>`\n  /* List itself also apply style about common templating between HeaderRow and other Rows */\n\n  position: relative;\n  border: 1px solid ${({ theme }) => theme.colors.neutral.border};\n  border-radius: ${({ theme }) => theme.radii.default};\n  transition:\n    box-shadow 200ms ease,\n    border-color 200ms ease;\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  padding: 0 ${({ theme }) => theme.space['2']};\n\n  &[role='button row'] {\n    cursor: pointer;\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        ? `&: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    border-color: ${({ theme }) => theme.colors.primary.border};\n    box-shadow: ${({ theme }) => theme.shadows.hoverPrimary};\n  }\n\n  &[aria-disabled='true'] {\n    border: 1px solid ${({ theme }) => theme.colors.neutral.borderDisabled};\n    background-color: ${({ theme }) => theme.colors.neutral.backgroundDisabled};\n    color: ${({ theme }) => theme.colors.neutral.textDisabled};\n    cursor: not-allowed;\n  }\n`\n\nconst StyledCheckboxContainer = styled.div`\n  display: flex;\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  'data-testid'?: string\n}\n\nexport const Row = forwardRef(\n  (\n    {\n      children,\n      id,\n      expandable,\n      disabled,\n      selectDisabled,\n      sentiment = 'neutral',\n      expanded,\n      className,\n      expandablePadding,\n      'data-testid': dataTestid,\n    }: RowProps,\n    ref: ForwardedRef<HTMLDivElement>,\n  ) => {\n    const {\n      selectable,\n      registerExpandableRow,\n      expandedRowIds,\n      expandRow,\n      collapseRow,\n      registerSelectableRow,\n      selectedRowIds,\n      selectRow,\n      unselectRow,\n      expandButton,\n    } = useListContext()\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    return (\n      <StyledRow\n        className={className}\n        ref={ref}\n        role={canClickRowToExpand ? 'button row' : 'row'}\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        tabIndex={canClickRowToExpand ? 0 : -1}\n        sentiment={sentiment}\n        aria-disabled={disabled}\n        aria-expanded={expandable ? expandedRowIds[id] : undefined}\n        data-highlight={!!selectedRowIds[id]}\n        data-testid={dataTestid}\n      >\n        {selectable ? (\n          <Cell preventClick={canClickRowToExpand}>\n            <StyledCheckboxContainer>\n              <Tooltip\n                text={\n                  typeof selectDisabled === 'string'\n                    ? selectDisabled\n                    : undefined\n                }\n              >\n                <Checkbox\n                  name=\"list-select-checkbox\"\n                  aria-label=\"select\"\n                  checked={selectedRowIds[id]}\n                  value={id}\n                  onChange={() => {\n                    if (selectedRowIds[id]) {\n                      unselectRow(id)\n                    } else {\n                      selectRow(id)\n                    }\n                  }}\n                  disabled={isSelectDisabled}\n                />\n              </Tooltip>\n            </StyledCheckboxContainer>\n          </Cell>\n        ) : null}\n        {expandButton ? (\n          <Cell>\n            <Button\n              disabled={disabled || !expandable}\n              icon={expandedRowIds[id] ? 'arrow-up' : 'arrow-down'}\n              onClick={toggleRowExpand}\n              size=\"small\"\n              sentiment={sentiment}\n              variant=\"ghost\"\n              aria-label=\"expand\"\n              data-testid=\"list-expand-button\"\n            />\n          </Cell>\n        ) : null}\n        {children}\n        {expandable && expandedRowIds[id] ? (\n          <ExpandableWrapper\n            data-expandable-content\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            padding={expandablePadding}\n          >\n            {expandable}\n          </ExpandableWrapper>\n        ) : null}\n      </StyledRow>\n    )\n  },\n)\n"]} */",
88
91
  toString: _EMOTION_STRINGIFIED_CSS_ERROR__
89
92
  });
90
93
  const Row = forwardRef(({
@@ -96,6 +99,7 @@ const Row = forwardRef(({
96
99
  sentiment = "neutral",
97
100
  expanded,
98
101
  className,
102
+ expandablePadding,
99
103
  "data-testid": dataTestid
100
104
  }, ref) => {
101
105
  const {
@@ -153,7 +157,7 @@ const Row = forwardRef(({
153
157
  e.stopPropagation();
154
158
  } : void 0, onKeyDown: canClickRowToExpand ? (e) => {
155
159
  e.stopPropagation();
156
- } : void 0, children: expandable }) : null
160
+ } : void 0, padding: expandablePadding, children: expandable }) : null
157
161
  ] });
158
162
  });
159
163
  export {
@@ -37,6 +37,7 @@ export declare const List: import("react").ForwardRefExoticComponent<ListProps &
37
37
  sentiment?: "primary" | "secondary" | "neutral" | "success" | "danger" | "warning" | "info";
38
38
  expanded?: boolean;
39
39
  className?: string;
40
+ expandablePadding?: "0" | "1" | "2" | "3" | "4" | "5" | "6" | "7" | "8" | "9" | "10" | "0.25" | "0.5" | "1.5";
40
41
  'data-testid'?: string;
41
42
  } & import("react").RefAttributes<HTMLDivElement>>;
42
43
  Cell: import("react").ForwardRefExoticComponent<{
@@ -15,16 +15,16 @@ const ModalProvider = ({
15
15
  }) => {
16
16
  const [openedModals, setOpenedModals] = React.useState([]);
17
17
  const [previsousOpenedModales, setPreviousOpenedModales] = React.useState([]);
18
- const registerModal = React.useCallback((id) => {
18
+ const registerModal = React.useCallback((object) => {
19
19
  setOpenedModals((prev) => {
20
20
  setPreviousOpenedModales(prev);
21
- return [...prev, id];
21
+ return [...prev, object];
22
22
  });
23
23
  }, []);
24
24
  const unregisterModal = React.useCallback((id) => {
25
25
  setOpenedModals((prev) => {
26
26
  setPreviousOpenedModales(prev);
27
- return prev.filter((modalId) => modalId !== id);
27
+ return prev.filter((modalId) => modalId.id !== id);
28
28
  });
29
29
  }, []);
30
30
  const value = React.useMemo(() => ({
@@ -1,9 +1,13 @@
1
- import type { ReactNode } from 'react';
1
+ import type { ReactNode, Ref } from 'react';
2
+ type ModalObject = {
3
+ id: string;
4
+ ref: Ref<HTMLDialogElement>;
5
+ };
2
6
  type ModalContextValues = {
3
- openedModals: string[];
4
- registerModal: (id: string) => void;
7
+ openedModals: ModalObject[];
8
+ registerModal: (object: ModalObject) => void;
5
9
  unregisterModal: (id: string) => void;
6
- previsousOpenedModales: string[];
10
+ previsousOpenedModales: ModalObject[];
7
11
  };
8
12
  export declare const ModalContext: import("react").Context<ModalContextValues | undefined>;
9
13
  export declare const useModal: () => ModalContextValues;
@@ -13,16 +13,16 @@ const ModalProvider = ({
13
13
  }) => {
14
14
  const [openedModals, setOpenedModals] = useState([]);
15
15
  const [previsousOpenedModales, setPreviousOpenedModales] = useState([]);
16
- const registerModal = useCallback((id) => {
16
+ const registerModal = useCallback((object) => {
17
17
  setOpenedModals((prev) => {
18
18
  setPreviousOpenedModales(prev);
19
- return [...prev, id];
19
+ return [...prev, object];
20
20
  });
21
21
  }, []);
22
22
  const unregisterModal = useCallback((id) => {
23
23
  setOpenedModals((prev) => {
24
24
  setPreviousOpenedModales(prev);
25
- return prev.filter((modalId) => modalId !== id);
25
+ return prev.filter((modalId) => modalId.id !== id);
26
26
  });
27
27
  }, []);
28
28
  const value = useMemo(() => ({