@ultraviolet/ui 1.78.1 → 1.80.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (39) hide show
  1. package/dist/components/Banner/index.cjs +7 -7
  2. package/dist/components/Banner/index.d.ts +4 -0
  3. package/dist/components/Banner/index.js +7 -7
  4. package/dist/components/Drawer/index.d.ts +19 -0
  5. package/dist/components/List/Cell.cjs +8 -5
  6. package/dist/components/List/Cell.d.ts +2 -1
  7. package/dist/components/List/Cell.js +8 -5
  8. package/dist/components/List/HeaderCell.cjs +25 -11
  9. package/dist/components/List/HeaderCell.d.ts +4 -1
  10. package/dist/components/List/HeaderCell.js +24 -10
  11. package/dist/components/List/HeaderRow.cjs +21 -10
  12. package/dist/components/List/HeaderRow.js +22 -11
  13. package/dist/components/List/Row.cjs +76 -48
  14. package/dist/components/List/Row.d.ts +2 -2
  15. package/dist/components/List/Row.js +78 -50
  16. package/dist/components/List/SkeletonRows.cjs +5 -5
  17. package/dist/components/List/SkeletonRows.js +5 -5
  18. package/dist/components/List/index.cjs +10 -19
  19. package/dist/components/List/index.d.ts +6 -3
  20. package/dist/components/List/index.js +10 -19
  21. package/dist/components/Table/Cell.cjs +3 -4
  22. package/dist/components/Table/Cell.js +3 -4
  23. package/dist/components/Table/HeaderCell.cjs +7 -6
  24. package/dist/components/Table/HeaderCell.js +7 -6
  25. package/dist/components/Table/HeaderRow.cjs +4 -1
  26. package/dist/components/Table/HeaderRow.js +4 -1
  27. package/dist/components/Table/Row.cjs +41 -25
  28. package/dist/components/Table/Row.js +44 -28
  29. package/dist/components/Table/constants.cjs +0 -6
  30. package/dist/components/Table/constants.d.ts +0 -5
  31. package/dist/components/Table/constants.js +0 -6
  32. package/dist/components/Table/index.cjs +2 -4
  33. package/dist/components/Table/index.js +2 -4
  34. package/package.json +4 -4
  35. package/dist/components/List/Body.cjs +0 -18
  36. package/dist/components/List/Body.d.ts +0 -6
  37. package/dist/components/List/Body.js +0 -16
  38. package/dist/components/List/constants.cjs +0 -6
  39. package/dist/components/List/constants.js +0 -6
@@ -13,58 +13,65 @@ const _styled__default = /* @__PURE__ */ _interopDefaultCompat(_styled);
13
13
  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
- const ExpandableWrapper = /* @__PURE__ */ _styled__default.default("div", process.env.NODE_ENV === "production" ? {
17
- shouldForwardProp: (prop) => !["padding"].includes(prop),
18
- target: "ei4uyz13"
16
+ const ExpandableWrapper = /* @__PURE__ */ _styled__default.default("tr", process.env.NODE_ENV === "production" ? {
17
+ target: "ei4uyz15"
19
18
  } : {
20
- shouldForwardProp: (prop) => !["padding"].includes(prop),
21
- target: "ei4uyz13",
19
+ target: "ei4uyz15",
22
20
  label: "ExpandableWrapper"
23
- })("grid-column:1/-1;grid-column-start:1;border-top:1px solid ", ({
21
+ })("width:100%;display:table-row;vertical-align:middle;cursor:auto;background:", ({
24
22
  theme
25
- }) => theme.colors.neutral.border, ";margin:0 -", ({
23
+ }) => theme.colors.neutral.backgroundWeak, ";border-radius:0 0 ", ({
26
24
  theme
27
- }) => theme.space["2"], ";padding:", ({
28
- theme,
29
- padding
30
- }) => padding ? theme.space[padding] : theme.space["2"], ";cursor:auto;background:", ({
25
+ }) => theme.radii.default, " ", ({
31
26
  theme
32
- }) => theme.colors.neutral.backgroundWeak, ";border-radius:0 0 ", ({
27
+ }) => theme.radii.default, ";transform:translate3d(0, -", ({
28
+ theme
29
+ }) => theme.space["2"], ', 0);position:relative;&:before{content:"";position:absolute;top:0;left:0;right:0;bottom:0;border:1px solid ', ({
30
+ theme
31
+ }) => theme.colors.neutral.border, ";border-top:none;border-radius:0 0 ", ({
33
32
  theme
34
33
  }) => theme.radii.default, " ", ({
35
34
  theme
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, useRef } 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\nconst StyledCheckbox = styled(Checkbox, {\n  shouldForwardProp: prop => !['inRange'].includes(prop),\n})<{ inRange: boolean }>`\n\n    rect {\n      ${({ theme, inRange }) => (inRange ? `fill: ${theme.colors.neutral.backgroundHover};stroke: ${theme.colors.neutral.borderHover};` : '')}\n    }\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      refList,\n      inRange,\n    } = useListContext()\n\n    const checkboxRef = useRef<HTMLInputElement>(null)\n\n    const isSelectDisabled =\n      disabled || (selectDisabled !== undefined && selectDisabled !== false)\n\n    const hasExpandable = !!expandable\n    useEffect(() => {\n      if (hasExpandable) {\n        const unregisterCallback = registerExpandableRow(id, expanded)\n\n        return unregisterCallback\n      }\n\n      return undefined\n    }, [id, hasExpandable, registerExpandableRow, expanded, expandRow])\n\n    useEffect(() => {\n      if (!isSelectDisabled) {\n        const unregisterCallback = registerSelectableRow(id)\n\n        return unregisterCallback\n      }\n\n      return undefined\n    }, [id, registerSelectableRow, isSelectDisabled])\n\n    const toggleRowExpand = useCallback(() => {\n      if (expandedRowIds[id]) {\n        collapseRow(id)\n      } else {\n        expandRow(id)\n      }\n    }, [collapseRow, expandRow, expandedRowIds, id])\n\n    const canClickRowToExpand = !disabled && !!expandable && !expandButton\n\n    useEffect(() => {\n      const refAtEffectStart = refList.current\n      const { current } = checkboxRef\n\n      if (refAtEffectStart && current && !refAtEffectStart.includes(current)) {\n        refList.current.push(current)\n      }\n    }, [refList])\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={selectable && !!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                <StyledCheckbox\n                  name=\"list-select-checkbox\"\n                  aria-label=\"select\"\n                  checked={selectedRowIds[id]}\n                  value={id}\n                  ref={checkboxRef}\n                  onChange={() => {\n                    if (selectedRowIds[id]) {\n                      unselectRow(id)\n                    } else {\n                      selectRow(id)\n                    }\n                  }}\n                  disabled={isSelectDisabled}\n                  inRange={inRange.includes(id)}\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"]} */"));
35
+ }) => theme.radii.default, ";pointer-events:none;transition:box-shadow 200ms ease,border-color 200ms ease;}" + (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":"AAiBmC","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 {\n  Children,\n  forwardRef,\n  useCallback,\n  useEffect,\n  useId,\n  useRef,\n} from 'react'\nimport type { SENTIMENTS, space } from '../../theme'\nimport { Button } from '../Button'\nimport { Checkbox } from '../Checkbox'\nimport { Tooltip } from '../Tooltip'\nimport { Cell } from './Cell'\nimport { useListContext } from './ListContext'\n\nconst ExpandableWrapper = styled.tr`\n  width: 100%;\n  display: table-row;\n  vertical-align: middle;\n  cursor: auto;\n  background: ${({ theme }) => theme.colors.neutral.backgroundWeak};\n  border-radius: 0 0 ${({ theme }) => theme.radii.default} ${({ theme }) => theme.radii.default};\n  transform: translate3d(0, -${({ theme }) => theme.space['2']}, 0);\n  position: relative;\n\n  &:before {\n    content: \"\";\n    position: absolute;\n    top: 0; /* Adjust based on border width and spacing */\n    left: 0;\n    right: 0;\n    bottom: 0; /* Adjust based on border width and spacing */\n    border: 1px solid ${({ theme }) => theme.colors.neutral.border};\n    border-top: none;\n    border-radius: 0 0 ${({ theme }) => theme.radii.default} ${({ theme }) => theme.radii.default};\n    pointer-events: none;\n    transition:\n      box-shadow 200ms ease,\n      border-color 200ms ease;\n  }\n`\n\nconst StyledCheckbox = styled(Checkbox, {\n  shouldForwardProp: prop => !['inRange'].includes(prop),\n})<{ inRange: boolean }>`\n\n    rect {\n      ${({ theme, inRange }) => (inRange ? `fill: ${theme.colors.neutral.backgroundHover};stroke: ${theme.colors.neutral.borderHover};` : '')}\n    }\n`\n\nexport const StyledRow = styled('tr', {\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  display: table-row;\n  vertical-align: middle;\n  position: relative;\n  box-shadow: none;\n  background-color: ${({ theme }) => theme.colors.neutral.background};\n  font-size: ${({ theme }) => theme.typography.bodySmall.fontSize};\n  column-gap: ${({ theme }) => theme.space['2']};\n\n  &[role='button row'] {\n    cursor: pointer;\n  }\n\n  position: relative;\n\n  &:before {\n    content: \"\";\n    position: absolute;\n    top: 0; /* Adjust based on border width and spacing */\n    left: 0;\n    right: 0;\n    bottom: 0; /* Adjust based on border width and spacing */\n    border: 1px solid ${({ theme }) => theme.colors.neutral.border};\n    border-radius: ${({ theme }) => theme.radii.default};\n    pointer-events: none;\n    transition:\n      box-shadow 200ms ease,\n      border-color 200ms ease;\n  }\n\n  &:hover::before {\n    border-color: ${({ theme }) => theme.colors.primary.border};\n  }\n\n  &:hover + ${ExpandableWrapper}:before {\n    border-color: ${({ theme }) => theme.colors.primary.border};\n  }\n\n  &[aria-expanded='true']:before {\n    border-radius: ${({ theme }) => theme.radii.default} ${({ theme }) => theme.radii.default} 0 0;\n    border-bottom-color: ${({ theme }) => theme.colors.neutral.border};\n  }\n\n  ${({ theme, sentiment }) =>\n    `\n    color: ${theme.colors[sentiment].text};\n    border-color: ${theme.colors[sentiment].border};\n    background-color: ${theme.colors[sentiment].background};\n    & [data-expandable-content] {\n      border-color: ${theme.colors[sentiment].border};\n    }\n\n    ${\n      sentiment === 'neutral'\n        ? `&: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    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\nconst NoPaddingCell = styled(Cell)`\n  padding: 0;\n\n  &:first-of-type {\n    padding-left: ${({ theme }) => theme.space['2']};\n  }\n`\n\nconst ExpandableCell = styled(Cell, {\n  shouldForwardProp: prop => !['padding'].includes(prop),\n})<{ padding?: keyof typeof space }>`\n  padding: ${({ theme, padding }) => (padding ? theme.space[padding] : theme.space['2'])};\n`\n\ntype RowProps = {\n  children: ReactNode\n  id: string\n  expandable?: ReactNode\n  /**\n   * Row cannot be selected if this prop is provided. boolean true disabled selection, a string disable selection and a tooltip will be displayed on checkbox hover.\n   * */\n  selectDisabled?: boolean | string\n  disabled?: boolean\n  sentiment?: (typeof SENTIMENTS)[number]\n  expanded?: boolean\n  className?: string\n  /**\n   * Define a custom padding for the content in the expandable\n   */\n  expandablePadding?: keyof typeof space\n  '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<HTMLTableRowElement>,\n  ) => {\n    const {\n      selectable,\n      registerExpandableRow,\n      expandedRowIds,\n      expandRow,\n      collapseRow,\n      registerSelectableRow,\n      selectedRowIds,\n      selectRow,\n      unselectRow,\n      expandButton,\n      refList,\n      inRange,\n    } = useListContext()\n\n    const expandedRowId = useId()\n\n    const checkboxRef = useRef<HTMLInputElement>(null)\n\n    const isSelectDisabled =\n      disabled || (selectDisabled !== undefined && selectDisabled !== false)\n\n    const hasExpandable = !!expandable\n    useEffect(() => {\n      if (hasExpandable) {\n        const unregisterCallback = registerExpandableRow(id, expanded)\n\n        return unregisterCallback\n      }\n\n      return undefined\n    }, [id, hasExpandable, registerExpandableRow, expanded, expandRow])\n\n    useEffect(() => {\n      if (!isSelectDisabled) {\n        const unregisterCallback = registerSelectableRow(id)\n\n        return unregisterCallback\n      }\n\n      return undefined\n    }, [id, registerSelectableRow, isSelectDisabled])\n\n    const toggleRowExpand = useCallback(() => {\n      if (expandedRowIds[id]) {\n        collapseRow(id)\n      } else {\n        expandRow(id)\n      }\n    }, [collapseRow, expandRow, expandedRowIds, id])\n\n    const canClickRowToExpand = !disabled && !!expandable && !expandButton\n\n    useEffect(() => {\n      const refAtEffectStart = refList.current\n      const { current } = checkboxRef\n\n      if (refAtEffectStart && current && !refAtEffectStart.includes(current)) {\n        refList.current.push(current)\n      }\n    }, [refList])\n\n    const childrenLength =\n      Children.count(children) + (selectable ? 1 : 0) + (expandButton ? 1 : 0)\n\n    return (\n      <>\n        <StyledRow\n          className={className}\n          ref={ref}\n          role={canClickRowToExpand ? 'button row' : undefined}\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          aria-controls={\n            expandable && expandedRowIds[id] ? expandedRowId : undefined\n          }\n          data-highlight={selectable && !!selectedRowIds[id]}\n          data-testid={dataTestid}\n        >\n          {selectable ? (\n            <NoPaddingCell preventClick={canClickRowToExpand}>\n              <StyledCheckboxContainer>\n                <Tooltip\n                  text={\n                    typeof selectDisabled === 'string'\n                      ? selectDisabled\n                      : undefined\n                  }\n                >\n                  <StyledCheckbox\n                    name=\"list-select-checkbox\"\n                    aria-label=\"select\"\n                    checked={selectedRowIds[id]}\n                    value={id}\n                    ref={checkboxRef}\n                    onChange={() => {\n                      if (selectedRowIds[id]) {\n                        unselectRow(id)\n                      } else {\n                        selectRow(id)\n                      }\n                    }}\n                    disabled={isSelectDisabled}\n                    inRange={inRange.includes(id)}\n                  />\n                </Tooltip>\n              </StyledCheckboxContainer>\n            </NoPaddingCell>\n          ) : null}\n          {expandButton ? (\n            <NoPaddingCell>\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            </NoPaddingCell>\n          ) : null}\n          {children}\n        </StyledRow>\n        {expandable && expandedRowIds[id] ? (\n          <ExpandableWrapper\n            id={expandedRowId}\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            <ExpandableCell\n              colSpan={childrenLength}\n              padding={expandablePadding}\n            >\n              {expandable}\n            </ExpandableCell>\n          </ExpandableWrapper>\n        ) : null}\n      </>\n    )\n  },\n)\n"]} */"));
37
36
  const StyledCheckbox = /* @__PURE__ */ _styled__default.default(index.Checkbox, process.env.NODE_ENV === "production" ? {
38
37
  shouldForwardProp: (prop) => !["inRange"].includes(prop),
39
- target: "ei4uyz12"
38
+ target: "ei4uyz14"
40
39
  } : {
41
40
  shouldForwardProp: (prop) => !["inRange"].includes(prop),
42
- target: "ei4uyz12",
41
+ target: "ei4uyz14",
43
42
  label: "StyledCheckbox"
44
43
  })("rect{", ({
45
44
  theme,
46
45
  inRange
47
- }) => inRange ? `fill: ${theme.colors.neutral.backgroundHover};stroke: ${theme.colors.neutral.borderHover};` : "", ";}" + (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":"AAyBwB","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, useRef } 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\nconst StyledCheckbox = styled(Checkbox, {\n  shouldForwardProp: prop => !['inRange'].includes(prop),\n})<{ inRange: boolean }>`\n\n    rect {\n      ${({ theme, inRange }) => (inRange ? `fill: ${theme.colors.neutral.backgroundHover};stroke: ${theme.colors.neutral.borderHover};` : '')}\n    }\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      refList,\n      inRange,\n    } = useListContext()\n\n    const checkboxRef = useRef<HTMLInputElement>(null)\n\n    const isSelectDisabled =\n      disabled || (selectDisabled !== undefined && selectDisabled !== false)\n\n    const hasExpandable = !!expandable\n    useEffect(() => {\n      if (hasExpandable) {\n        const unregisterCallback = registerExpandableRow(id, expanded)\n\n        return unregisterCallback\n      }\n\n      return undefined\n    }, [id, hasExpandable, registerExpandableRow, expanded, expandRow])\n\n    useEffect(() => {\n      if (!isSelectDisabled) {\n        const unregisterCallback = registerSelectableRow(id)\n\n        return unregisterCallback\n      }\n\n      return undefined\n    }, [id, registerSelectableRow, isSelectDisabled])\n\n    const toggleRowExpand = useCallback(() => {\n      if (expandedRowIds[id]) {\n        collapseRow(id)\n      } else {\n        expandRow(id)\n      }\n    }, [collapseRow, expandRow, expandedRowIds, id])\n\n    const canClickRowToExpand = !disabled && !!expandable && !expandButton\n\n    useEffect(() => {\n      const refAtEffectStart = refList.current\n      const { current } = checkboxRef\n\n      if (refAtEffectStart && current && !refAtEffectStart.includes(current)) {\n        refList.current.push(current)\n      }\n    }, [refList])\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={selectable && !!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                <StyledCheckbox\n                  name=\"list-select-checkbox\"\n                  aria-label=\"select\"\n                  checked={selectedRowIds[id]}\n                  value={id}\n                  ref={checkboxRef}\n                  onChange={() => {\n                    if (selectedRowIds[id]) {\n                      unselectRow(id)\n                    } else {\n                      selectRow(id)\n                    }\n                  }}\n                  disabled={isSelectDisabled}\n                  inRange={inRange.includes(id)}\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"]} */"));
48
- const StyledRow = /* @__PURE__ */ _styled__default.default("div", process.env.NODE_ENV === "production" ? {
46
+ }) => inRange ? `fill: ${theme.colors.neutral.backgroundHover};stroke: ${theme.colors.neutral.borderHover};` : "", ";}" + (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":"AA8CwB","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 {\n  Children,\n  forwardRef,\n  useCallback,\n  useEffect,\n  useId,\n  useRef,\n} from 'react'\nimport type { SENTIMENTS, space } from '../../theme'\nimport { Button } from '../Button'\nimport { Checkbox } from '../Checkbox'\nimport { Tooltip } from '../Tooltip'\nimport { Cell } from './Cell'\nimport { useListContext } from './ListContext'\n\nconst ExpandableWrapper = styled.tr`\n  width: 100%;\n  display: table-row;\n  vertical-align: middle;\n  cursor: auto;\n  background: ${({ theme }) => theme.colors.neutral.backgroundWeak};\n  border-radius: 0 0 ${({ theme }) => theme.radii.default} ${({ theme }) => theme.radii.default};\n  transform: translate3d(0, -${({ theme }) => theme.space['2']}, 0);\n  position: relative;\n\n  &:before {\n    content: \"\";\n    position: absolute;\n    top: 0; /* Adjust based on border width and spacing */\n    left: 0;\n    right: 0;\n    bottom: 0; /* Adjust based on border width and spacing */\n    border: 1px solid ${({ theme }) => theme.colors.neutral.border};\n    border-top: none;\n    border-radius: 0 0 ${({ theme }) => theme.radii.default} ${({ theme }) => theme.radii.default};\n    pointer-events: none;\n    transition:\n      box-shadow 200ms ease,\n      border-color 200ms ease;\n  }\n`\n\nconst StyledCheckbox = styled(Checkbox, {\n  shouldForwardProp: prop => !['inRange'].includes(prop),\n})<{ inRange: boolean }>`\n\n    rect {\n      ${({ theme, inRange }) => (inRange ? `fill: ${theme.colors.neutral.backgroundHover};stroke: ${theme.colors.neutral.borderHover};` : '')}\n    }\n`\n\nexport const StyledRow = styled('tr', {\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  display: table-row;\n  vertical-align: middle;\n  position: relative;\n  box-shadow: none;\n  background-color: ${({ theme }) => theme.colors.neutral.background};\n  font-size: ${({ theme }) => theme.typography.bodySmall.fontSize};\n  column-gap: ${({ theme }) => theme.space['2']};\n\n  &[role='button row'] {\n    cursor: pointer;\n  }\n\n  position: relative;\n\n  &:before {\n    content: \"\";\n    position: absolute;\n    top: 0; /* Adjust based on border width and spacing */\n    left: 0;\n    right: 0;\n    bottom: 0; /* Adjust based on border width and spacing */\n    border: 1px solid ${({ theme }) => theme.colors.neutral.border};\n    border-radius: ${({ theme }) => theme.radii.default};\n    pointer-events: none;\n    transition:\n      box-shadow 200ms ease,\n      border-color 200ms ease;\n  }\n\n  &:hover::before {\n    border-color: ${({ theme }) => theme.colors.primary.border};\n  }\n\n  &:hover + ${ExpandableWrapper}:before {\n    border-color: ${({ theme }) => theme.colors.primary.border};\n  }\n\n  &[aria-expanded='true']:before {\n    border-radius: ${({ theme }) => theme.radii.default} ${({ theme }) => theme.radii.default} 0 0;\n    border-bottom-color: ${({ theme }) => theme.colors.neutral.border};\n  }\n\n  ${({ theme, sentiment }) =>\n    `\n    color: ${theme.colors[sentiment].text};\n    border-color: ${theme.colors[sentiment].border};\n    background-color: ${theme.colors[sentiment].background};\n    & [data-expandable-content] {\n      border-color: ${theme.colors[sentiment].border};\n    }\n\n    ${\n      sentiment === 'neutral'\n        ? `&: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    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\nconst NoPaddingCell = styled(Cell)`\n  padding: 0;\n\n  &:first-of-type {\n    padding-left: ${({ theme }) => theme.space['2']};\n  }\n`\n\nconst ExpandableCell = styled(Cell, {\n  shouldForwardProp: prop => !['padding'].includes(prop),\n})<{ padding?: keyof typeof space }>`\n  padding: ${({ theme, padding }) => (padding ? theme.space[padding] : theme.space['2'])};\n`\n\ntype RowProps = {\n  children: ReactNode\n  id: string\n  expandable?: ReactNode\n  /**\n   * Row cannot be selected if this prop is provided. boolean true disabled selection, a string disable selection and a tooltip will be displayed on checkbox hover.\n   * */\n  selectDisabled?: boolean | string\n  disabled?: boolean\n  sentiment?: (typeof SENTIMENTS)[number]\n  expanded?: boolean\n  className?: string\n  /**\n   * Define a custom padding for the content in the expandable\n   */\n  expandablePadding?: keyof typeof space\n  '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<HTMLTableRowElement>,\n  ) => {\n    const {\n      selectable,\n      registerExpandableRow,\n      expandedRowIds,\n      expandRow,\n      collapseRow,\n      registerSelectableRow,\n      selectedRowIds,\n      selectRow,\n      unselectRow,\n      expandButton,\n      refList,\n      inRange,\n    } = useListContext()\n\n    const expandedRowId = useId()\n\n    const checkboxRef = useRef<HTMLInputElement>(null)\n\n    const isSelectDisabled =\n      disabled || (selectDisabled !== undefined && selectDisabled !== false)\n\n    const hasExpandable = !!expandable\n    useEffect(() => {\n      if (hasExpandable) {\n        const unregisterCallback = registerExpandableRow(id, expanded)\n\n        return unregisterCallback\n      }\n\n      return undefined\n    }, [id, hasExpandable, registerExpandableRow, expanded, expandRow])\n\n    useEffect(() => {\n      if (!isSelectDisabled) {\n        const unregisterCallback = registerSelectableRow(id)\n\n        return unregisterCallback\n      }\n\n      return undefined\n    }, [id, registerSelectableRow, isSelectDisabled])\n\n    const toggleRowExpand = useCallback(() => {\n      if (expandedRowIds[id]) {\n        collapseRow(id)\n      } else {\n        expandRow(id)\n      }\n    }, [collapseRow, expandRow, expandedRowIds, id])\n\n    const canClickRowToExpand = !disabled && !!expandable && !expandButton\n\n    useEffect(() => {\n      const refAtEffectStart = refList.current\n      const { current } = checkboxRef\n\n      if (refAtEffectStart && current && !refAtEffectStart.includes(current)) {\n        refList.current.push(current)\n      }\n    }, [refList])\n\n    const childrenLength =\n      Children.count(children) + (selectable ? 1 : 0) + (expandButton ? 1 : 0)\n\n    return (\n      <>\n        <StyledRow\n          className={className}\n          ref={ref}\n          role={canClickRowToExpand ? 'button row' : undefined}\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          aria-controls={\n            expandable && expandedRowIds[id] ? expandedRowId : undefined\n          }\n          data-highlight={selectable && !!selectedRowIds[id]}\n          data-testid={dataTestid}\n        >\n          {selectable ? (\n            <NoPaddingCell preventClick={canClickRowToExpand}>\n              <StyledCheckboxContainer>\n                <Tooltip\n                  text={\n                    typeof selectDisabled === 'string'\n                      ? selectDisabled\n                      : undefined\n                  }\n                >\n                  <StyledCheckbox\n                    name=\"list-select-checkbox\"\n                    aria-label=\"select\"\n                    checked={selectedRowIds[id]}\n                    value={id}\n                    ref={checkboxRef}\n                    onChange={() => {\n                      if (selectedRowIds[id]) {\n                        unselectRow(id)\n                      } else {\n                        selectRow(id)\n                      }\n                    }}\n                    disabled={isSelectDisabled}\n                    inRange={inRange.includes(id)}\n                  />\n                </Tooltip>\n              </StyledCheckboxContainer>\n            </NoPaddingCell>\n          ) : null}\n          {expandButton ? (\n            <NoPaddingCell>\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            </NoPaddingCell>\n          ) : null}\n          {children}\n        </StyledRow>\n        {expandable && expandedRowIds[id] ? (\n          <ExpandableWrapper\n            id={expandedRowId}\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            <ExpandableCell\n              colSpan={childrenLength}\n              padding={expandablePadding}\n            >\n              {expandable}\n            </ExpandableCell>\n          </ExpandableWrapper>\n        ) : null}\n      </>\n    )\n  },\n)\n"]} */"));
47
+ const StyledRow = /* @__PURE__ */ _styled__default.default("tr", process.env.NODE_ENV === "production" ? {
49
48
  shouldForwardProp: (prop) => !["sentiment"].includes(prop),
50
- target: "ei4uyz11"
49
+ target: "ei4uyz13"
51
50
  } : {
52
51
  shouldForwardProp: (prop) => !["sentiment"].includes(prop),
53
- target: "ei4uyz11",
52
+ target: "ei4uyz13",
54
53
  label: "StyledRow"
55
- })("position:relative;border:1px solid ", ({
54
+ })("display:table-row;vertical-align:middle;position:relative;box-shadow:none;background-color:", ({
55
+ theme
56
+ }) => theme.colors.neutral.background, ";font-size:", ({
57
+ theme
58
+ }) => theme.typography.bodySmall.fontSize, ";column-gap:", ({
59
+ theme
60
+ }) => theme.space["2"], `;&[role='button row']{cursor:pointer;}position:relative;&:before{content:"";position:absolute;top:0;left:0;right:0;bottom:0;border:1px solid `, ({
56
61
  theme
57
62
  }) => theme.colors.neutral.border, ";border-radius:", ({
58
63
  theme
59
- }) => theme.radii.default, ";transition:box-shadow 200ms ease,border-color 200ms ease;box-shadow:none;background-color:", ({
64
+ }) => theme.radii.default, ";pointer-events:none;transition:box-shadow 200ms ease,border-color 200ms ease;}&:hover::before{border-color:", ({
60
65
  theme
61
- }) => theme.colors.neutral.background, ";font-size:", ({
66
+ }) => theme.colors.primary.border, ";}&:hover+", ExpandableWrapper, ":before{border-color:", ({
62
67
  theme
63
- }) => theme.typography.bodySmall.fontSize, ";column-gap:", ({
68
+ }) => theme.colors.primary.border, ";}&[aria-expanded='true']:before{border-radius:", ({
69
+ theme
70
+ }) => theme.radii.default, " ", ({
64
71
  theme
65
- }) => theme.space["2"], ";padding:0 ", ({
72
+ }) => theme.radii.default, " 0 0;border-bottom-color:", ({
66
73
  theme
67
- }) => theme.space["2"], ";&[role='button row']{cursor:pointer;}", ({
74
+ }) => theme.colors.neutral.border, ";}", ({
68
75
  theme,
69
76
  sentiment
70
77
  }) => `
@@ -84,26 +91,43 @@ const StyledRow = /* @__PURE__ */ _styled__default.default("div", process.env.NO
84
91
  theme
85
92
  }) => theme.colors.primary.border, ";box-shadow:", ({
86
93
  theme
87
- }) => theme.shadows.hoverPrimary, ";}&[aria-disabled='true']{border:1px solid ", ({
88
- theme
89
- }) => theme.colors.neutral.borderDisabled, ";background-color:", ({
94
+ }) => theme.shadows.hoverPrimary, ";}&[aria-disabled='true']{background-color:", ({
90
95
  theme
91
96
  }) => theme.colors.neutral.backgroundDisabled, ";color:", ({
92
97
  theme
93
- }) => 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":"AAoCE","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, useRef } 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\nconst StyledCheckbox = styled(Checkbox, {\n  shouldForwardProp: prop => !['inRange'].includes(prop),\n})<{ inRange: boolean }>`\n\n    rect {\n      ${({ theme, inRange }) => (inRange ? `fill: ${theme.colors.neutral.backgroundHover};stroke: ${theme.colors.neutral.borderHover};` : '')}\n    }\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      refList,\n      inRange,\n    } = useListContext()\n\n    const checkboxRef = useRef<HTMLInputElement>(null)\n\n    const isSelectDisabled =\n      disabled || (selectDisabled !== undefined && selectDisabled !== false)\n\n    const hasExpandable = !!expandable\n    useEffect(() => {\n      if (hasExpandable) {\n        const unregisterCallback = registerExpandableRow(id, expanded)\n\n        return unregisterCallback\n      }\n\n      return undefined\n    }, [id, hasExpandable, registerExpandableRow, expanded, expandRow])\n\n    useEffect(() => {\n      if (!isSelectDisabled) {\n        const unregisterCallback = registerSelectableRow(id)\n\n        return unregisterCallback\n      }\n\n      return undefined\n    }, [id, registerSelectableRow, isSelectDisabled])\n\n    const toggleRowExpand = useCallback(() => {\n      if (expandedRowIds[id]) {\n        collapseRow(id)\n      } else {\n        expandRow(id)\n      }\n    }, [collapseRow, expandRow, expandedRowIds, id])\n\n    const canClickRowToExpand = !disabled && !!expandable && !expandButton\n\n    useEffect(() => {\n      const refAtEffectStart = refList.current\n      const { current } = checkboxRef\n\n      if (refAtEffectStart && current && !refAtEffectStart.includes(current)) {\n        refList.current.push(current)\n      }\n    }, [refList])\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={selectable && !!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                <StyledCheckbox\n                  name=\"list-select-checkbox\"\n                  aria-label=\"select\"\n                  checked={selectedRowIds[id]}\n                  value={id}\n                  ref={checkboxRef}\n                  onChange={() => {\n                    if (selectedRowIds[id]) {\n                      unselectRow(id)\n                    } else {\n                      selectRow(id)\n                    }\n                  }}\n                  disabled={isSelectDisabled}\n                  inRange={inRange.includes(id)}\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"]} */"));
98
+ }) => 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":"AAyDE","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 {\n  Children,\n  forwardRef,\n  useCallback,\n  useEffect,\n  useId,\n  useRef,\n} from 'react'\nimport type { SENTIMENTS, space } from '../../theme'\nimport { Button } from '../Button'\nimport { Checkbox } from '../Checkbox'\nimport { Tooltip } from '../Tooltip'\nimport { Cell } from './Cell'\nimport { useListContext } from './ListContext'\n\nconst ExpandableWrapper = styled.tr`\n  width: 100%;\n  display: table-row;\n  vertical-align: middle;\n  cursor: auto;\n  background: ${({ theme }) => theme.colors.neutral.backgroundWeak};\n  border-radius: 0 0 ${({ theme }) => theme.radii.default} ${({ theme }) => theme.radii.default};\n  transform: translate3d(0, -${({ theme }) => theme.space['2']}, 0);\n  position: relative;\n\n  &:before {\n    content: \"\";\n    position: absolute;\n    top: 0; /* Adjust based on border width and spacing */\n    left: 0;\n    right: 0;\n    bottom: 0; /* Adjust based on border width and spacing */\n    border: 1px solid ${({ theme }) => theme.colors.neutral.border};\n    border-top: none;\n    border-radius: 0 0 ${({ theme }) => theme.radii.default} ${({ theme }) => theme.radii.default};\n    pointer-events: none;\n    transition:\n      box-shadow 200ms ease,\n      border-color 200ms ease;\n  }\n`\n\nconst StyledCheckbox = styled(Checkbox, {\n  shouldForwardProp: prop => !['inRange'].includes(prop),\n})<{ inRange: boolean }>`\n\n    rect {\n      ${({ theme, inRange }) => (inRange ? `fill: ${theme.colors.neutral.backgroundHover};stroke: ${theme.colors.neutral.borderHover};` : '')}\n    }\n`\n\nexport const StyledRow = styled('tr', {\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  display: table-row;\n  vertical-align: middle;\n  position: relative;\n  box-shadow: none;\n  background-color: ${({ theme }) => theme.colors.neutral.background};\n  font-size: ${({ theme }) => theme.typography.bodySmall.fontSize};\n  column-gap: ${({ theme }) => theme.space['2']};\n\n  &[role='button row'] {\n    cursor: pointer;\n  }\n\n  position: relative;\n\n  &:before {\n    content: \"\";\n    position: absolute;\n    top: 0; /* Adjust based on border width and spacing */\n    left: 0;\n    right: 0;\n    bottom: 0; /* Adjust based on border width and spacing */\n    border: 1px solid ${({ theme }) => theme.colors.neutral.border};\n    border-radius: ${({ theme }) => theme.radii.default};\n    pointer-events: none;\n    transition:\n      box-shadow 200ms ease,\n      border-color 200ms ease;\n  }\n\n  &:hover::before {\n    border-color: ${({ theme }) => theme.colors.primary.border};\n  }\n\n  &:hover + ${ExpandableWrapper}:before {\n    border-color: ${({ theme }) => theme.colors.primary.border};\n  }\n\n  &[aria-expanded='true']:before {\n    border-radius: ${({ theme }) => theme.radii.default} ${({ theme }) => theme.radii.default} 0 0;\n    border-bottom-color: ${({ theme }) => theme.colors.neutral.border};\n  }\n\n  ${({ theme, sentiment }) =>\n    `\n    color: ${theme.colors[sentiment].text};\n    border-color: ${theme.colors[sentiment].border};\n    background-color: ${theme.colors[sentiment].background};\n    & [data-expandable-content] {\n      border-color: ${theme.colors[sentiment].border};\n    }\n\n    ${\n      sentiment === 'neutral'\n        ? `&: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    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\nconst NoPaddingCell = styled(Cell)`\n  padding: 0;\n\n  &:first-of-type {\n    padding-left: ${({ theme }) => theme.space['2']};\n  }\n`\n\nconst ExpandableCell = styled(Cell, {\n  shouldForwardProp: prop => !['padding'].includes(prop),\n})<{ padding?: keyof typeof space }>`\n  padding: ${({ theme, padding }) => (padding ? theme.space[padding] : theme.space['2'])};\n`\n\ntype RowProps = {\n  children: ReactNode\n  id: string\n  expandable?: ReactNode\n  /**\n   * Row cannot be selected if this prop is provided. boolean true disabled selection, a string disable selection and a tooltip will be displayed on checkbox hover.\n   * */\n  selectDisabled?: boolean | string\n  disabled?: boolean\n  sentiment?: (typeof SENTIMENTS)[number]\n  expanded?: boolean\n  className?: string\n  /**\n   * Define a custom padding for the content in the expandable\n   */\n  expandablePadding?: keyof typeof space\n  '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<HTMLTableRowElement>,\n  ) => {\n    const {\n      selectable,\n      registerExpandableRow,\n      expandedRowIds,\n      expandRow,\n      collapseRow,\n      registerSelectableRow,\n      selectedRowIds,\n      selectRow,\n      unselectRow,\n      expandButton,\n      refList,\n      inRange,\n    } = useListContext()\n\n    const expandedRowId = useId()\n\n    const checkboxRef = useRef<HTMLInputElement>(null)\n\n    const isSelectDisabled =\n      disabled || (selectDisabled !== undefined && selectDisabled !== false)\n\n    const hasExpandable = !!expandable\n    useEffect(() => {\n      if (hasExpandable) {\n        const unregisterCallback = registerExpandableRow(id, expanded)\n\n        return unregisterCallback\n      }\n\n      return undefined\n    }, [id, hasExpandable, registerExpandableRow, expanded, expandRow])\n\n    useEffect(() => {\n      if (!isSelectDisabled) {\n        const unregisterCallback = registerSelectableRow(id)\n\n        return unregisterCallback\n      }\n\n      return undefined\n    }, [id, registerSelectableRow, isSelectDisabled])\n\n    const toggleRowExpand = useCallback(() => {\n      if (expandedRowIds[id]) {\n        collapseRow(id)\n      } else {\n        expandRow(id)\n      }\n    }, [collapseRow, expandRow, expandedRowIds, id])\n\n    const canClickRowToExpand = !disabled && !!expandable && !expandButton\n\n    useEffect(() => {\n      const refAtEffectStart = refList.current\n      const { current } = checkboxRef\n\n      if (refAtEffectStart && current && !refAtEffectStart.includes(current)) {\n        refList.current.push(current)\n      }\n    }, [refList])\n\n    const childrenLength =\n      Children.count(children) + (selectable ? 1 : 0) + (expandButton ? 1 : 0)\n\n    return (\n      <>\n        <StyledRow\n          className={className}\n          ref={ref}\n          role={canClickRowToExpand ? 'button row' : undefined}\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          aria-controls={\n            expandable && expandedRowIds[id] ? expandedRowId : undefined\n          }\n          data-highlight={selectable && !!selectedRowIds[id]}\n          data-testid={dataTestid}\n        >\n          {selectable ? (\n            <NoPaddingCell preventClick={canClickRowToExpand}>\n              <StyledCheckboxContainer>\n                <Tooltip\n                  text={\n                    typeof selectDisabled === 'string'\n                      ? selectDisabled\n                      : undefined\n                  }\n                >\n                  <StyledCheckbox\n                    name=\"list-select-checkbox\"\n                    aria-label=\"select\"\n                    checked={selectedRowIds[id]}\n                    value={id}\n                    ref={checkboxRef}\n                    onChange={() => {\n                      if (selectedRowIds[id]) {\n                        unselectRow(id)\n                      } else {\n                        selectRow(id)\n                      }\n                    }}\n                    disabled={isSelectDisabled}\n                    inRange={inRange.includes(id)}\n                  />\n                </Tooltip>\n              </StyledCheckboxContainer>\n            </NoPaddingCell>\n          ) : null}\n          {expandButton ? (\n            <NoPaddingCell>\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            </NoPaddingCell>\n          ) : null}\n          {children}\n        </StyledRow>\n        {expandable && expandedRowIds[id] ? (\n          <ExpandableWrapper\n            id={expandedRowId}\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            <ExpandableCell\n              colSpan={childrenLength}\n              padding={expandablePadding}\n            >\n              {expandable}\n            </ExpandableCell>\n          </ExpandableWrapper>\n        ) : null}\n      </>\n    )\n  },\n)\n"]} */"));
94
99
  const StyledCheckboxContainer = /* @__PURE__ */ _styled__default.default("div", process.env.NODE_ENV === "production" ? {
95
- target: "ei4uyz10"
100
+ target: "ei4uyz12"
96
101
  } : {
97
- target: "ei4uyz10",
102
+ target: "ei4uyz12",
98
103
  label: "StyledCheckboxContainer"
99
104
  })(process.env.NODE_ENV === "production" ? {
100
105
  name: "zjik7",
101
106
  styles: "display:flex"
102
107
  } : {
103
108
  name: "zjik7",
104
- styles: "display:flex/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["/home/runner/work/ultraviolet/ultraviolet/packages/ui/src/components/List/Row.tsx"],"names":[],"mappings":"AAwF0C","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, useRef } 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\nconst StyledCheckbox = styled(Checkbox, {\n  shouldForwardProp: prop => !['inRange'].includes(prop),\n})<{ inRange: boolean }>`\n\n    rect {\n      ${({ theme, inRange }) => (inRange ? `fill: ${theme.colors.neutral.backgroundHover};stroke: ${theme.colors.neutral.borderHover};` : '')}\n    }\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      refList,\n      inRange,\n    } = useListContext()\n\n    const checkboxRef = useRef<HTMLInputElement>(null)\n\n    const isSelectDisabled =\n      disabled || (selectDisabled !== undefined && selectDisabled !== false)\n\n    const hasExpandable = !!expandable\n    useEffect(() => {\n      if (hasExpandable) {\n        const unregisterCallback = registerExpandableRow(id, expanded)\n\n        return unregisterCallback\n      }\n\n      return undefined\n    }, [id, hasExpandable, registerExpandableRow, expanded, expandRow])\n\n    useEffect(() => {\n      if (!isSelectDisabled) {\n        const unregisterCallback = registerSelectableRow(id)\n\n        return unregisterCallback\n      }\n\n      return undefined\n    }, [id, registerSelectableRow, isSelectDisabled])\n\n    const toggleRowExpand = useCallback(() => {\n      if (expandedRowIds[id]) {\n        collapseRow(id)\n      } else {\n        expandRow(id)\n      }\n    }, [collapseRow, expandRow, expandedRowIds, id])\n\n    const canClickRowToExpand = !disabled && !!expandable && !expandButton\n\n    useEffect(() => {\n      const refAtEffectStart = refList.current\n      const { current } = checkboxRef\n\n      if (refAtEffectStart && current && !refAtEffectStart.includes(current)) {\n        refList.current.push(current)\n      }\n    }, [refList])\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={selectable && !!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                <StyledCheckbox\n                  name=\"list-select-checkbox\"\n                  aria-label=\"select\"\n                  checked={selectedRowIds[id]}\n                  value={id}\n                  ref={checkboxRef}\n                  onChange={() => {\n                    if (selectedRowIds[id]) {\n                      unselectRow(id)\n                    } else {\n                      selectRow(id)\n                    }\n                  }}\n                  disabled={isSelectDisabled}\n                  inRange={inRange.includes(id)}\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"]} */",
109
+ styles: "display:flex/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["/home/runner/work/ultraviolet/ultraviolet/packages/ui/src/components/List/Row.tsx"],"names":[],"mappings":"AAsI0C","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 {\n  Children,\n  forwardRef,\n  useCallback,\n  useEffect,\n  useId,\n  useRef,\n} from 'react'\nimport type { SENTIMENTS, space } from '../../theme'\nimport { Button } from '../Button'\nimport { Checkbox } from '../Checkbox'\nimport { Tooltip } from '../Tooltip'\nimport { Cell } from './Cell'\nimport { useListContext } from './ListContext'\n\nconst ExpandableWrapper = styled.tr`\n  width: 100%;\n  display: table-row;\n  vertical-align: middle;\n  cursor: auto;\n  background: ${({ theme }) => theme.colors.neutral.backgroundWeak};\n  border-radius: 0 0 ${({ theme }) => theme.radii.default} ${({ theme }) => theme.radii.default};\n  transform: translate3d(0, -${({ theme }) => theme.space['2']}, 0);\n  position: relative;\n\n  &:before {\n    content: \"\";\n    position: absolute;\n    top: 0; /* Adjust based on border width and spacing */\n    left: 0;\n    right: 0;\n    bottom: 0; /* Adjust based on border width and spacing */\n    border: 1px solid ${({ theme }) => theme.colors.neutral.border};\n    border-top: none;\n    border-radius: 0 0 ${({ theme }) => theme.radii.default} ${({ theme }) => theme.radii.default};\n    pointer-events: none;\n    transition:\n      box-shadow 200ms ease,\n      border-color 200ms ease;\n  }\n`\n\nconst StyledCheckbox = styled(Checkbox, {\n  shouldForwardProp: prop => !['inRange'].includes(prop),\n})<{ inRange: boolean }>`\n\n    rect {\n      ${({ theme, inRange }) => (inRange ? `fill: ${theme.colors.neutral.backgroundHover};stroke: ${theme.colors.neutral.borderHover};` : '')}\n    }\n`\n\nexport const StyledRow = styled('tr', {\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  display: table-row;\n  vertical-align: middle;\n  position: relative;\n  box-shadow: none;\n  background-color: ${({ theme }) => theme.colors.neutral.background};\n  font-size: ${({ theme }) => theme.typography.bodySmall.fontSize};\n  column-gap: ${({ theme }) => theme.space['2']};\n\n  &[role='button row'] {\n    cursor: pointer;\n  }\n\n  position: relative;\n\n  &:before {\n    content: \"\";\n    position: absolute;\n    top: 0; /* Adjust based on border width and spacing */\n    left: 0;\n    right: 0;\n    bottom: 0; /* Adjust based on border width and spacing */\n    border: 1px solid ${({ theme }) => theme.colors.neutral.border};\n    border-radius: ${({ theme }) => theme.radii.default};\n    pointer-events: none;\n    transition:\n      box-shadow 200ms ease,\n      border-color 200ms ease;\n  }\n\n  &:hover::before {\n    border-color: ${({ theme }) => theme.colors.primary.border};\n  }\n\n  &:hover + ${ExpandableWrapper}:before {\n    border-color: ${({ theme }) => theme.colors.primary.border};\n  }\n\n  &[aria-expanded='true']:before {\n    border-radius: ${({ theme }) => theme.radii.default} ${({ theme }) => theme.radii.default} 0 0;\n    border-bottom-color: ${({ theme }) => theme.colors.neutral.border};\n  }\n\n  ${({ theme, sentiment }) =>\n    `\n    color: ${theme.colors[sentiment].text};\n    border-color: ${theme.colors[sentiment].border};\n    background-color: ${theme.colors[sentiment].background};\n    & [data-expandable-content] {\n      border-color: ${theme.colors[sentiment].border};\n    }\n\n    ${\n      sentiment === 'neutral'\n        ? `&: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    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\nconst NoPaddingCell = styled(Cell)`\n  padding: 0;\n\n  &:first-of-type {\n    padding-left: ${({ theme }) => theme.space['2']};\n  }\n`\n\nconst ExpandableCell = styled(Cell, {\n  shouldForwardProp: prop => !['padding'].includes(prop),\n})<{ padding?: keyof typeof space }>`\n  padding: ${({ theme, padding }) => (padding ? theme.space[padding] : theme.space['2'])};\n`\n\ntype RowProps = {\n  children: ReactNode\n  id: string\n  expandable?: ReactNode\n  /**\n   * Row cannot be selected if this prop is provided. boolean true disabled selection, a string disable selection and a tooltip will be displayed on checkbox hover.\n   * */\n  selectDisabled?: boolean | string\n  disabled?: boolean\n  sentiment?: (typeof SENTIMENTS)[number]\n  expanded?: boolean\n  className?: string\n  /**\n   * Define a custom padding for the content in the expandable\n   */\n  expandablePadding?: keyof typeof space\n  '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<HTMLTableRowElement>,\n  ) => {\n    const {\n      selectable,\n      registerExpandableRow,\n      expandedRowIds,\n      expandRow,\n      collapseRow,\n      registerSelectableRow,\n      selectedRowIds,\n      selectRow,\n      unselectRow,\n      expandButton,\n      refList,\n      inRange,\n    } = useListContext()\n\n    const expandedRowId = useId()\n\n    const checkboxRef = useRef<HTMLInputElement>(null)\n\n    const isSelectDisabled =\n      disabled || (selectDisabled !== undefined && selectDisabled !== false)\n\n    const hasExpandable = !!expandable\n    useEffect(() => {\n      if (hasExpandable) {\n        const unregisterCallback = registerExpandableRow(id, expanded)\n\n        return unregisterCallback\n      }\n\n      return undefined\n    }, [id, hasExpandable, registerExpandableRow, expanded, expandRow])\n\n    useEffect(() => {\n      if (!isSelectDisabled) {\n        const unregisterCallback = registerSelectableRow(id)\n\n        return unregisterCallback\n      }\n\n      return undefined\n    }, [id, registerSelectableRow, isSelectDisabled])\n\n    const toggleRowExpand = useCallback(() => {\n      if (expandedRowIds[id]) {\n        collapseRow(id)\n      } else {\n        expandRow(id)\n      }\n    }, [collapseRow, expandRow, expandedRowIds, id])\n\n    const canClickRowToExpand = !disabled && !!expandable && !expandButton\n\n    useEffect(() => {\n      const refAtEffectStart = refList.current\n      const { current } = checkboxRef\n\n      if (refAtEffectStart && current && !refAtEffectStart.includes(current)) {\n        refList.current.push(current)\n      }\n    }, [refList])\n\n    const childrenLength =\n      Children.count(children) + (selectable ? 1 : 0) + (expandButton ? 1 : 0)\n\n    return (\n      <>\n        <StyledRow\n          className={className}\n          ref={ref}\n          role={canClickRowToExpand ? 'button row' : undefined}\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          aria-controls={\n            expandable && expandedRowIds[id] ? expandedRowId : undefined\n          }\n          data-highlight={selectable && !!selectedRowIds[id]}\n          data-testid={dataTestid}\n        >\n          {selectable ? (\n            <NoPaddingCell preventClick={canClickRowToExpand}>\n              <StyledCheckboxContainer>\n                <Tooltip\n                  text={\n                    typeof selectDisabled === 'string'\n                      ? selectDisabled\n                      : undefined\n                  }\n                >\n                  <StyledCheckbox\n                    name=\"list-select-checkbox\"\n                    aria-label=\"select\"\n                    checked={selectedRowIds[id]}\n                    value={id}\n                    ref={checkboxRef}\n                    onChange={() => {\n                      if (selectedRowIds[id]) {\n                        unselectRow(id)\n                      } else {\n                        selectRow(id)\n                      }\n                    }}\n                    disabled={isSelectDisabled}\n                    inRange={inRange.includes(id)}\n                  />\n                </Tooltip>\n              </StyledCheckboxContainer>\n            </NoPaddingCell>\n          ) : null}\n          {expandButton ? (\n            <NoPaddingCell>\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            </NoPaddingCell>\n          ) : null}\n          {children}\n        </StyledRow>\n        {expandable && expandedRowIds[id] ? (\n          <ExpandableWrapper\n            id={expandedRowId}\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            <ExpandableCell\n              colSpan={childrenLength}\n              padding={expandablePadding}\n            >\n              {expandable}\n            </ExpandableCell>\n          </ExpandableWrapper>\n        ) : null}\n      </>\n    )\n  },\n)\n"]} */",
105
110
  toString: _EMOTION_STRINGIFIED_CSS_ERROR__
106
111
  });
112
+ const NoPaddingCell = /* @__PURE__ */ _styled__default.default(Cell.Cell, process.env.NODE_ENV === "production" ? {
113
+ target: "ei4uyz11"
114
+ } : {
115
+ target: "ei4uyz11",
116
+ label: "NoPaddingCell"
117
+ })("padding:0;&:first-of-type{padding-left:", ({
118
+ theme
119
+ }) => theme.space["2"], ";}" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["/home/runner/work/ultraviolet/ultraviolet/packages/ui/src/components/List/Row.tsx"],"names":[],"mappings":"AA0IkC","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 {\n  Children,\n  forwardRef,\n  useCallback,\n  useEffect,\n  useId,\n  useRef,\n} from 'react'\nimport type { SENTIMENTS, space } from '../../theme'\nimport { Button } from '../Button'\nimport { Checkbox } from '../Checkbox'\nimport { Tooltip } from '../Tooltip'\nimport { Cell } from './Cell'\nimport { useListContext } from './ListContext'\n\nconst ExpandableWrapper = styled.tr`\n  width: 100%;\n  display: table-row;\n  vertical-align: middle;\n  cursor: auto;\n  background: ${({ theme }) => theme.colors.neutral.backgroundWeak};\n  border-radius: 0 0 ${({ theme }) => theme.radii.default} ${({ theme }) => theme.radii.default};\n  transform: translate3d(0, -${({ theme }) => theme.space['2']}, 0);\n  position: relative;\n\n  &:before {\n    content: \"\";\n    position: absolute;\n    top: 0; /* Adjust based on border width and spacing */\n    left: 0;\n    right: 0;\n    bottom: 0; /* Adjust based on border width and spacing */\n    border: 1px solid ${({ theme }) => theme.colors.neutral.border};\n    border-top: none;\n    border-radius: 0 0 ${({ theme }) => theme.radii.default} ${({ theme }) => theme.radii.default};\n    pointer-events: none;\n    transition:\n      box-shadow 200ms ease,\n      border-color 200ms ease;\n  }\n`\n\nconst StyledCheckbox = styled(Checkbox, {\n  shouldForwardProp: prop => !['inRange'].includes(prop),\n})<{ inRange: boolean }>`\n\n    rect {\n      ${({ theme, inRange }) => (inRange ? `fill: ${theme.colors.neutral.backgroundHover};stroke: ${theme.colors.neutral.borderHover};` : '')}\n    }\n`\n\nexport const StyledRow = styled('tr', {\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  display: table-row;\n  vertical-align: middle;\n  position: relative;\n  box-shadow: none;\n  background-color: ${({ theme }) => theme.colors.neutral.background};\n  font-size: ${({ theme }) => theme.typography.bodySmall.fontSize};\n  column-gap: ${({ theme }) => theme.space['2']};\n\n  &[role='button row'] {\n    cursor: pointer;\n  }\n\n  position: relative;\n\n  &:before {\n    content: \"\";\n    position: absolute;\n    top: 0; /* Adjust based on border width and spacing */\n    left: 0;\n    right: 0;\n    bottom: 0; /* Adjust based on border width and spacing */\n    border: 1px solid ${({ theme }) => theme.colors.neutral.border};\n    border-radius: ${({ theme }) => theme.radii.default};\n    pointer-events: none;\n    transition:\n      box-shadow 200ms ease,\n      border-color 200ms ease;\n  }\n\n  &:hover::before {\n    border-color: ${({ theme }) => theme.colors.primary.border};\n  }\n\n  &:hover + ${ExpandableWrapper}:before {\n    border-color: ${({ theme }) => theme.colors.primary.border};\n  }\n\n  &[aria-expanded='true']:before {\n    border-radius: ${({ theme }) => theme.radii.default} ${({ theme }) => theme.radii.default} 0 0;\n    border-bottom-color: ${({ theme }) => theme.colors.neutral.border};\n  }\n\n  ${({ theme, sentiment }) =>\n    `\n    color: ${theme.colors[sentiment].text};\n    border-color: ${theme.colors[sentiment].border};\n    background-color: ${theme.colors[sentiment].background};\n    & [data-expandable-content] {\n      border-color: ${theme.colors[sentiment].border};\n    }\n\n    ${\n      sentiment === 'neutral'\n        ? `&: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    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\nconst NoPaddingCell = styled(Cell)`\n  padding: 0;\n\n  &:first-of-type {\n    padding-left: ${({ theme }) => theme.space['2']};\n  }\n`\n\nconst ExpandableCell = styled(Cell, {\n  shouldForwardProp: prop => !['padding'].includes(prop),\n})<{ padding?: keyof typeof space }>`\n  padding: ${({ theme, padding }) => (padding ? theme.space[padding] : theme.space['2'])};\n`\n\ntype RowProps = {\n  children: ReactNode\n  id: string\n  expandable?: ReactNode\n  /**\n   * Row cannot be selected if this prop is provided. boolean true disabled selection, a string disable selection and a tooltip will be displayed on checkbox hover.\n   * */\n  selectDisabled?: boolean | string\n  disabled?: boolean\n  sentiment?: (typeof SENTIMENTS)[number]\n  expanded?: boolean\n  className?: string\n  /**\n   * Define a custom padding for the content in the expandable\n   */\n  expandablePadding?: keyof typeof space\n  '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<HTMLTableRowElement>,\n  ) => {\n    const {\n      selectable,\n      registerExpandableRow,\n      expandedRowIds,\n      expandRow,\n      collapseRow,\n      registerSelectableRow,\n      selectedRowIds,\n      selectRow,\n      unselectRow,\n      expandButton,\n      refList,\n      inRange,\n    } = useListContext()\n\n    const expandedRowId = useId()\n\n    const checkboxRef = useRef<HTMLInputElement>(null)\n\n    const isSelectDisabled =\n      disabled || (selectDisabled !== undefined && selectDisabled !== false)\n\n    const hasExpandable = !!expandable\n    useEffect(() => {\n      if (hasExpandable) {\n        const unregisterCallback = registerExpandableRow(id, expanded)\n\n        return unregisterCallback\n      }\n\n      return undefined\n    }, [id, hasExpandable, registerExpandableRow, expanded, expandRow])\n\n    useEffect(() => {\n      if (!isSelectDisabled) {\n        const unregisterCallback = registerSelectableRow(id)\n\n        return unregisterCallback\n      }\n\n      return undefined\n    }, [id, registerSelectableRow, isSelectDisabled])\n\n    const toggleRowExpand = useCallback(() => {\n      if (expandedRowIds[id]) {\n        collapseRow(id)\n      } else {\n        expandRow(id)\n      }\n    }, [collapseRow, expandRow, expandedRowIds, id])\n\n    const canClickRowToExpand = !disabled && !!expandable && !expandButton\n\n    useEffect(() => {\n      const refAtEffectStart = refList.current\n      const { current } = checkboxRef\n\n      if (refAtEffectStart && current && !refAtEffectStart.includes(current)) {\n        refList.current.push(current)\n      }\n    }, [refList])\n\n    const childrenLength =\n      Children.count(children) + (selectable ? 1 : 0) + (expandButton ? 1 : 0)\n\n    return (\n      <>\n        <StyledRow\n          className={className}\n          ref={ref}\n          role={canClickRowToExpand ? 'button row' : undefined}\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          aria-controls={\n            expandable && expandedRowIds[id] ? expandedRowId : undefined\n          }\n          data-highlight={selectable && !!selectedRowIds[id]}\n          data-testid={dataTestid}\n        >\n          {selectable ? (\n            <NoPaddingCell preventClick={canClickRowToExpand}>\n              <StyledCheckboxContainer>\n                <Tooltip\n                  text={\n                    typeof selectDisabled === 'string'\n                      ? selectDisabled\n                      : undefined\n                  }\n                >\n                  <StyledCheckbox\n                    name=\"list-select-checkbox\"\n                    aria-label=\"select\"\n                    checked={selectedRowIds[id]}\n                    value={id}\n                    ref={checkboxRef}\n                    onChange={() => {\n                      if (selectedRowIds[id]) {\n                        unselectRow(id)\n                      } else {\n                        selectRow(id)\n                      }\n                    }}\n                    disabled={isSelectDisabled}\n                    inRange={inRange.includes(id)}\n                  />\n                </Tooltip>\n              </StyledCheckboxContainer>\n            </NoPaddingCell>\n          ) : null}\n          {expandButton ? (\n            <NoPaddingCell>\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            </NoPaddingCell>\n          ) : null}\n          {children}\n        </StyledRow>\n        {expandable && expandedRowIds[id] ? (\n          <ExpandableWrapper\n            id={expandedRowId}\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            <ExpandableCell\n              colSpan={childrenLength}\n              padding={expandablePadding}\n            >\n              {expandable}\n            </ExpandableCell>\n          </ExpandableWrapper>\n        ) : null}\n      </>\n    )\n  },\n)\n"]} */"));
120
+ const ExpandableCell = /* @__PURE__ */ _styled__default.default(Cell.Cell, process.env.NODE_ENV === "production" ? {
121
+ shouldForwardProp: (prop) => !["padding"].includes(prop),
122
+ target: "ei4uyz10"
123
+ } : {
124
+ shouldForwardProp: (prop) => !["padding"].includes(prop),
125
+ target: "ei4uyz10",
126
+ label: "ExpandableCell"
127
+ })("padding:", ({
128
+ theme,
129
+ padding
130
+ }) => padding ? theme.space[padding] : theme.space["2"], ";" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["/home/runner/work/ultraviolet/ultraviolet/packages/ui/src/components/List/Row.tsx"],"names":[],"mappings":"AAoJoC","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 {\n  Children,\n  forwardRef,\n  useCallback,\n  useEffect,\n  useId,\n  useRef,\n} from 'react'\nimport type { SENTIMENTS, space } from '../../theme'\nimport { Button } from '../Button'\nimport { Checkbox } from '../Checkbox'\nimport { Tooltip } from '../Tooltip'\nimport { Cell } from './Cell'\nimport { useListContext } from './ListContext'\n\nconst ExpandableWrapper = styled.tr`\n  width: 100%;\n  display: table-row;\n  vertical-align: middle;\n  cursor: auto;\n  background: ${({ theme }) => theme.colors.neutral.backgroundWeak};\n  border-radius: 0 0 ${({ theme }) => theme.radii.default} ${({ theme }) => theme.radii.default};\n  transform: translate3d(0, -${({ theme }) => theme.space['2']}, 0);\n  position: relative;\n\n  &:before {\n    content: \"\";\n    position: absolute;\n    top: 0; /* Adjust based on border width and spacing */\n    left: 0;\n    right: 0;\n    bottom: 0; /* Adjust based on border width and spacing */\n    border: 1px solid ${({ theme }) => theme.colors.neutral.border};\n    border-top: none;\n    border-radius: 0 0 ${({ theme }) => theme.radii.default} ${({ theme }) => theme.radii.default};\n    pointer-events: none;\n    transition:\n      box-shadow 200ms ease,\n      border-color 200ms ease;\n  }\n`\n\nconst StyledCheckbox = styled(Checkbox, {\n  shouldForwardProp: prop => !['inRange'].includes(prop),\n})<{ inRange: boolean }>`\n\n    rect {\n      ${({ theme, inRange }) => (inRange ? `fill: ${theme.colors.neutral.backgroundHover};stroke: ${theme.colors.neutral.borderHover};` : '')}\n    }\n`\n\nexport const StyledRow = styled('tr', {\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  display: table-row;\n  vertical-align: middle;\n  position: relative;\n  box-shadow: none;\n  background-color: ${({ theme }) => theme.colors.neutral.background};\n  font-size: ${({ theme }) => theme.typography.bodySmall.fontSize};\n  column-gap: ${({ theme }) => theme.space['2']};\n\n  &[role='button row'] {\n    cursor: pointer;\n  }\n\n  position: relative;\n\n  &:before {\n    content: \"\";\n    position: absolute;\n    top: 0; /* Adjust based on border width and spacing */\n    left: 0;\n    right: 0;\n    bottom: 0; /* Adjust based on border width and spacing */\n    border: 1px solid ${({ theme }) => theme.colors.neutral.border};\n    border-radius: ${({ theme }) => theme.radii.default};\n    pointer-events: none;\n    transition:\n      box-shadow 200ms ease,\n      border-color 200ms ease;\n  }\n\n  &:hover::before {\n    border-color: ${({ theme }) => theme.colors.primary.border};\n  }\n\n  &:hover + ${ExpandableWrapper}:before {\n    border-color: ${({ theme }) => theme.colors.primary.border};\n  }\n\n  &[aria-expanded='true']:before {\n    border-radius: ${({ theme }) => theme.radii.default} ${({ theme }) => theme.radii.default} 0 0;\n    border-bottom-color: ${({ theme }) => theme.colors.neutral.border};\n  }\n\n  ${({ theme, sentiment }) =>\n    `\n    color: ${theme.colors[sentiment].text};\n    border-color: ${theme.colors[sentiment].border};\n    background-color: ${theme.colors[sentiment].background};\n    & [data-expandable-content] {\n      border-color: ${theme.colors[sentiment].border};\n    }\n\n    ${\n      sentiment === 'neutral'\n        ? `&: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    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\nconst NoPaddingCell = styled(Cell)`\n  padding: 0;\n\n  &:first-of-type {\n    padding-left: ${({ theme }) => theme.space['2']};\n  }\n`\n\nconst ExpandableCell = styled(Cell, {\n  shouldForwardProp: prop => !['padding'].includes(prop),\n})<{ padding?: keyof typeof space }>`\n  padding: ${({ theme, padding }) => (padding ? theme.space[padding] : theme.space['2'])};\n`\n\ntype RowProps = {\n  children: ReactNode\n  id: string\n  expandable?: ReactNode\n  /**\n   * Row cannot be selected if this prop is provided. boolean true disabled selection, a string disable selection and a tooltip will be displayed on checkbox hover.\n   * */\n  selectDisabled?: boolean | string\n  disabled?: boolean\n  sentiment?: (typeof SENTIMENTS)[number]\n  expanded?: boolean\n  className?: string\n  /**\n   * Define a custom padding for the content in the expandable\n   */\n  expandablePadding?: keyof typeof space\n  '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<HTMLTableRowElement>,\n  ) => {\n    const {\n      selectable,\n      registerExpandableRow,\n      expandedRowIds,\n      expandRow,\n      collapseRow,\n      registerSelectableRow,\n      selectedRowIds,\n      selectRow,\n      unselectRow,\n      expandButton,\n      refList,\n      inRange,\n    } = useListContext()\n\n    const expandedRowId = useId()\n\n    const checkboxRef = useRef<HTMLInputElement>(null)\n\n    const isSelectDisabled =\n      disabled || (selectDisabled !== undefined && selectDisabled !== false)\n\n    const hasExpandable = !!expandable\n    useEffect(() => {\n      if (hasExpandable) {\n        const unregisterCallback = registerExpandableRow(id, expanded)\n\n        return unregisterCallback\n      }\n\n      return undefined\n    }, [id, hasExpandable, registerExpandableRow, expanded, expandRow])\n\n    useEffect(() => {\n      if (!isSelectDisabled) {\n        const unregisterCallback = registerSelectableRow(id)\n\n        return unregisterCallback\n      }\n\n      return undefined\n    }, [id, registerSelectableRow, isSelectDisabled])\n\n    const toggleRowExpand = useCallback(() => {\n      if (expandedRowIds[id]) {\n        collapseRow(id)\n      } else {\n        expandRow(id)\n      }\n    }, [collapseRow, expandRow, expandedRowIds, id])\n\n    const canClickRowToExpand = !disabled && !!expandable && !expandButton\n\n    useEffect(() => {\n      const refAtEffectStart = refList.current\n      const { current } = checkboxRef\n\n      if (refAtEffectStart && current && !refAtEffectStart.includes(current)) {\n        refList.current.push(current)\n      }\n    }, [refList])\n\n    const childrenLength =\n      Children.count(children) + (selectable ? 1 : 0) + (expandButton ? 1 : 0)\n\n    return (\n      <>\n        <StyledRow\n          className={className}\n          ref={ref}\n          role={canClickRowToExpand ? 'button row' : undefined}\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          aria-controls={\n            expandable && expandedRowIds[id] ? expandedRowId : undefined\n          }\n          data-highlight={selectable && !!selectedRowIds[id]}\n          data-testid={dataTestid}\n        >\n          {selectable ? (\n            <NoPaddingCell preventClick={canClickRowToExpand}>\n              <StyledCheckboxContainer>\n                <Tooltip\n                  text={\n                    typeof selectDisabled === 'string'\n                      ? selectDisabled\n                      : undefined\n                  }\n                >\n                  <StyledCheckbox\n                    name=\"list-select-checkbox\"\n                    aria-label=\"select\"\n                    checked={selectedRowIds[id]}\n                    value={id}\n                    ref={checkboxRef}\n                    onChange={() => {\n                      if (selectedRowIds[id]) {\n                        unselectRow(id)\n                      } else {\n                        selectRow(id)\n                      }\n                    }}\n                    disabled={isSelectDisabled}\n                    inRange={inRange.includes(id)}\n                  />\n                </Tooltip>\n              </StyledCheckboxContainer>\n            </NoPaddingCell>\n          ) : null}\n          {expandButton ? (\n            <NoPaddingCell>\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            </NoPaddingCell>\n          ) : null}\n          {children}\n        </StyledRow>\n        {expandable && expandedRowIds[id] ? (\n          <ExpandableWrapper\n            id={expandedRowId}\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            <ExpandableCell\n              colSpan={childrenLength}\n              padding={expandablePadding}\n            >\n              {expandable}\n            </ExpandableCell>\n          </ExpandableWrapper>\n        ) : null}\n      </>\n    )\n  },\n)\n"]} */"));
107
131
  const Row = React.forwardRef(({
108
132
  children,
109
133
  id,
@@ -130,6 +154,7 @@ const Row = React.forwardRef(({
130
154
  refList,
131
155
  inRange
132
156
  } = ListContext.useListContext();
157
+ const expandedRowId = React.useId();
133
158
  const checkboxRef = React.useRef(null);
134
159
  const isSelectDisabled = disabled || selectDisabled !== void 0 && selectDisabled !== false;
135
160
  const hasExpandable = !!expandable;
@@ -164,26 +189,29 @@ const Row = React.forwardRef(({
164
189
  refList.current.push(current);
165
190
  }
166
191
  }, [refList]);
167
- return /* @__PURE__ */ jsxRuntime.jsxs(StyledRow, { className, ref, role: canClickRowToExpand ? "button row" : "row", onClick: canClickRowToExpand ? toggleRowExpand : void 0, onKeyDown: canClickRowToExpand ? (event) => {
168
- if (event.key === " ") {
169
- toggleRowExpand();
170
- event.preventDefault();
171
- }
172
- } : void 0, tabIndex: canClickRowToExpand ? 0 : -1, sentiment, "aria-disabled": disabled, "aria-expanded": expandable ? expandedRowIds[id] : void 0, "data-highlight": selectable && !!selectedRowIds[id], "data-testid": dataTestid, children: [
173
- selectable ? /* @__PURE__ */ jsxRuntime.jsx(Cell.Cell, { preventClick: canClickRowToExpand, children: /* @__PURE__ */ jsxRuntime.jsx(StyledCheckboxContainer, { children: /* @__PURE__ */ jsxRuntime.jsx(index$1.Tooltip, { text: typeof selectDisabled === "string" ? selectDisabled : void 0, children: /* @__PURE__ */ jsxRuntime.jsx(StyledCheckbox, { name: "list-select-checkbox", "aria-label": "select", checked: selectedRowIds[id], value: id, ref: checkboxRef, onChange: () => {
174
- if (selectedRowIds[id]) {
175
- unselectRow(id);
176
- } else {
177
- selectRow(id);
192
+ const childrenLength = React.Children.count(children) + (selectable ? 1 : 0) + (expandButton ? 1 : 0);
193
+ return /* @__PURE__ */ jsxRuntime.jsxs(jsxRuntime.Fragment, { children: [
194
+ /* @__PURE__ */ jsxRuntime.jsxs(StyledRow, { className, ref, role: canClickRowToExpand ? "button row" : void 0, onClick: canClickRowToExpand ? toggleRowExpand : void 0, onKeyDown: canClickRowToExpand ? (event) => {
195
+ if (event.key === " ") {
196
+ toggleRowExpand();
197
+ event.preventDefault();
178
198
  }
179
- }, disabled: isSelectDisabled, inRange: inRange.includes(id) }) }) }) }) : null,
180
- expandButton ? /* @__PURE__ */ jsxRuntime.jsx(Cell.Cell, { children: /* @__PURE__ */ jsxRuntime.jsx(index$2.Button, { disabled: disabled || !expandable, icon: expandedRowIds[id] ? "arrow-up" : "arrow-down", onClick: toggleRowExpand, size: "small", sentiment, variant: "ghost", "aria-label": "expand", "data-testid": "list-expand-button" }) }) : null,
181
- children,
182
- expandable && expandedRowIds[id] ? /* @__PURE__ */ jsxRuntime.jsx(ExpandableWrapper, { "data-expandable-content": true, onClick: canClickRowToExpand ? (e) => {
199
+ } : void 0, tabIndex: canClickRowToExpand ? 0 : -1, sentiment, "aria-disabled": disabled, "aria-expanded": expandable ? expandedRowIds[id] : void 0, "aria-controls": expandable && expandedRowIds[id] ? expandedRowId : void 0, "data-highlight": selectable && !!selectedRowIds[id], "data-testid": dataTestid, children: [
200
+ selectable ? /* @__PURE__ */ jsxRuntime.jsx(NoPaddingCell, { preventClick: canClickRowToExpand, children: /* @__PURE__ */ jsxRuntime.jsx(StyledCheckboxContainer, { children: /* @__PURE__ */ jsxRuntime.jsx(index$1.Tooltip, { text: typeof selectDisabled === "string" ? selectDisabled : void 0, children: /* @__PURE__ */ jsxRuntime.jsx(StyledCheckbox, { name: "list-select-checkbox", "aria-label": "select", checked: selectedRowIds[id], value: id, ref: checkboxRef, onChange: () => {
201
+ if (selectedRowIds[id]) {
202
+ unselectRow(id);
203
+ } else {
204
+ selectRow(id);
205
+ }
206
+ }, disabled: isSelectDisabled, inRange: inRange.includes(id) }) }) }) }) : null,
207
+ expandButton ? /* @__PURE__ */ jsxRuntime.jsx(NoPaddingCell, { children: /* @__PURE__ */ jsxRuntime.jsx(index$2.Button, { disabled: disabled || !expandable, icon: expandedRowIds[id] ? "arrow-up" : "arrow-down", onClick: toggleRowExpand, size: "small", sentiment, variant: "ghost", "aria-label": "expand", "data-testid": "list-expand-button" }) }) : null,
208
+ children
209
+ ] }),
210
+ expandable && expandedRowIds[id] ? /* @__PURE__ */ jsxRuntime.jsx(ExpandableWrapper, { id: expandedRowId, "data-expandable-content": true, onClick: canClickRowToExpand ? (e) => {
183
211
  e.stopPropagation();
184
212
  } : void 0, onKeyDown: canClickRowToExpand ? (e) => {
185
213
  e.stopPropagation();
186
- } : void 0, padding: expandablePadding, children: expandable }) : null
214
+ } : void 0, children: /* @__PURE__ */ jsxRuntime.jsx(ExpandableCell, { colSpan: childrenLength, padding: expandablePadding, children: expandable }) }) : null
187
215
  ] });
188
216
  });
189
217
  exports.Row = Row;
@@ -5,7 +5,7 @@ export declare const StyledRow: import("@emotion/styled").StyledComponent<{
5
5
  as?: React.ElementType;
6
6
  } & {
7
7
  sentiment: (typeof SENTIMENTS)[number];
8
- }, import("react").DetailedHTMLProps<import("react").HTMLAttributes<HTMLDivElement>, HTMLDivElement>, {}>;
8
+ }, import("react").DetailedHTMLProps<import("react").HTMLAttributes<HTMLTableRowElement>, HTMLTableRowElement>, {}>;
9
9
  type RowProps = {
10
10
  children: ReactNode;
11
11
  id: string;
@@ -24,5 +24,5 @@ type RowProps = {
24
24
  expandablePadding?: keyof typeof space;
25
25
  'data-testid'?: string;
26
26
  };
27
- export declare const Row: import("react").ForwardRefExoticComponent<RowProps & import("react").RefAttributes<HTMLDivElement>>;
27
+ export declare const Row: import("react").ForwardRefExoticComponent<RowProps & import("react").RefAttributes<HTMLTableRowElement>>;
28
28
  export {};