@ultraviolet/ui 3.0.0-beta.13 → 3.0.0-beta.14

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 (75) hide show
  1. package/dist/components/Alert/styles.css.cjs +1 -0
  2. package/dist/components/Alert/styles.css.js +1 -0
  3. package/dist/components/Breadcrumbs/components/Item.cjs +25 -42
  4. package/dist/components/Breadcrumbs/components/Item.d.ts +3 -2
  5. package/dist/components/Breadcrumbs/components/Item.js +25 -40
  6. package/dist/components/Breadcrumbs/components/styles.css.cjs +16 -0
  7. package/dist/components/Breadcrumbs/components/styles.css.d.ts +12 -0
  8. package/dist/components/Breadcrumbs/components/styles.css.js +16 -0
  9. package/dist/components/Breadcrumbs/index.cjs +2 -19
  10. package/dist/components/Breadcrumbs/index.js +2 -17
  11. package/dist/components/Breadcrumbs/styles.css.cjs +5 -0
  12. package/dist/components/Breadcrumbs/styles.css.d.ts +1 -0
  13. package/dist/components/Breadcrumbs/styles.css.js +5 -0
  14. package/dist/components/Button/index.cjs +3 -2
  15. package/dist/components/Button/index.d.ts +2 -1
  16. package/dist/components/Button/index.js +3 -2
  17. package/dist/components/Card/index.cjs +9 -43
  18. package/dist/components/Card/index.js +4 -36
  19. package/dist/components/Card/styles.css.cjs +7 -0
  20. package/dist/components/Card/styles.css.d.ts +2 -0
  21. package/dist/components/Card/styles.css.js +7 -0
  22. package/dist/components/Checkbox/index.cjs +7 -205
  23. package/dist/components/Checkbox/index.d.ts +0 -20
  24. package/dist/components/Checkbox/index.js +8 -204
  25. package/dist/components/Checkbox/styles.css.cjs +17 -0
  26. package/dist/components/Checkbox/styles.css.d.ts +7 -0
  27. package/dist/components/Checkbox/styles.css.js +17 -0
  28. package/dist/components/CheckboxGroup/index.cjs +3 -34
  29. package/dist/components/CheckboxGroup/index.js +3 -32
  30. package/dist/components/CheckboxGroup/styles.css.cjs +7 -0
  31. package/dist/components/CheckboxGroup/styles.css.d.ts +2 -0
  32. package/dist/components/CheckboxGroup/styles.css.js +7 -0
  33. package/dist/components/Chip/index.d.ts +1 -1
  34. package/dist/components/Chip/styles.css.cjs +0 -1
  35. package/dist/components/Chip/styles.css.js +0 -1
  36. package/dist/components/Dialog/index.d.ts +1 -0
  37. package/dist/components/Drawer/index.cjs +18 -13
  38. package/dist/components/Drawer/index.js +18 -13
  39. package/dist/components/ExpandableCard/index.cjs +13 -97
  40. package/dist/components/ExpandableCard/index.js +9 -91
  41. package/dist/components/ExpandableCard/styles.css.cjs +17 -0
  42. package/dist/components/ExpandableCard/styles.css.d.ts +7 -0
  43. package/dist/components/ExpandableCard/styles.css.js +17 -0
  44. package/dist/components/Popup/styles.css.cjs +1 -0
  45. package/dist/components/Popup/styles.css.js +1 -0
  46. package/dist/components/Popup/variables.css.cjs +0 -1
  47. package/dist/components/Popup/variables.css.js +0 -1
  48. package/dist/components/RadioGroup/index.cjs +2 -20
  49. package/dist/components/RadioGroup/index.js +2 -18
  50. package/dist/components/RadioGroup/styles.css.cjs +5 -0
  51. package/dist/components/RadioGroup/styles.css.d.ts +1 -0
  52. package/dist/components/RadioGroup/styles.css.js +5 -0
  53. package/dist/components/SelectInput/SelectBar.cjs +9 -9
  54. package/dist/components/SelectInput/SelectBar.js +9 -9
  55. package/dist/components/SelectableCard/index.cjs +19 -18
  56. package/dist/components/SelectableCard/index.js +16 -15
  57. package/dist/components/Tag/index.cjs +16 -104
  58. package/dist/components/Tag/index.d.ts +2 -2
  59. package/dist/components/Tag/index.js +12 -99
  60. package/dist/components/Tag/styles.css.cjs +10 -0
  61. package/dist/components/Tag/styles.css.d.ts +34 -0
  62. package/dist/components/Tag/styles.css.js +10 -0
  63. package/dist/components/Text/style.css.cjs +1 -0
  64. package/dist/components/Text/style.css.js +1 -0
  65. package/dist/components/Text/variables.css.cjs +0 -1
  66. package/dist/components/Text/variables.css.js +0 -1
  67. package/dist/components/ToggleGroup/index.cjs +2 -20
  68. package/dist/components/ToggleGroup/index.js +2 -18
  69. package/dist/components/ToggleGroup/styles.css.cjs +5 -0
  70. package/dist/components/ToggleGroup/styles.css.d.ts +1 -0
  71. package/dist/components/ToggleGroup/styles.css.js +5 -0
  72. package/dist/ui.css +1 -1
  73. package/package.json +2 -2
  74. package/dist/components/Breadcrumbs/constants.cjs +0 -4
  75. package/dist/components/Breadcrumbs/constants.js +0 -4
@@ -1,94 +1,12 @@
1
1
  "use client";
2
2
  import { jsxs, jsx } from "@emotion/react/jsx-runtime";
3
- import _styled from "@emotion/styled/base";
4
3
  import { useTheme } from "@emotion/react";
5
4
  import { DragIcon, ArrowDownIcon } from "@ultraviolet/icons";
6
5
  import { forwardRef, useRef, useState, useCallback } from "react";
7
6
  import { Stack } from "../Stack/index.js";
8
7
  import { Tooltip } from "../Tooltip/index.js";
9
8
  import { ExpandableCardTitle } from "./components/Title.js";
10
- const StyledArrowIcon = /* @__PURE__ */ _styled(ArrowDownIcon, process.env.NODE_ENV === "production" ? {
11
- target: "e143cpd66"
12
- } : {
13
- target: "e143cpd66",
14
- label: "StyledArrowIcon"
15
- })(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/ExpandableCard/index.tsx"],"names":[],"mappings":"AAkB6C","file":"/home/runner/work/ultraviolet/ultraviolet/packages/ui/src/components/ExpandableCard/index.tsx","sourcesContent":["'use client'\n\nimport { useTheme } from '@emotion/react'\nimport styled from '@emotion/styled'\nimport { ArrowDownIcon, DragIcon } from '@ultraviolet/icons'\nimport type {\n  DetailsHTMLAttributes,\n  DragEvent,\n  ForwardedRef,\n  KeyboardEvent,\n  ReactNode,\n} from 'react'\nimport { forwardRef, useCallback, useRef, useState } from 'react'\nimport type { XOR } from '../../types'\nimport { Stack } from '../Stack'\nimport { Tooltip } from '../Tooltip'\nimport { ExpandableCardTitle } from './components/Title'\n\nconst StyledArrowIcon = styled(ArrowDownIcon)``\n\nconst DropableArea = styled.div`\n  height: ${({ theme }) => theme.space['3']};\n  border-bottom: 2px solid;\n  border-color: transparent;\n  padding: ${({ theme }) => theme.space['0.5']} 0;\n  width: 100%;\n  bottom: -5px;\n  position: absolute;\n\n  &[data-first=\"true\"] {\n    top: -${({ theme }) => theme.space['3']};\n  }\n\n  &::after {\n    content: '';\n    left: 0;\n    bottom: -4px;\n    height: 0px;\n    width: 0px;\n    border: 3px solid;\n    border-color: inherit;\n    border-radius: ${({ theme }) => theme.radii.circle};\n    display: flex;\n    margin-top:  -${({ theme }) => theme.space['1']};\n    margin-left: -${({ theme }) => theme.space['0.25']};\n    position: absolute;\n  }\n`\n\nconst StyledSummary = styled.summary`\n  display: flex;\n  flex-direction: row;\n  align-items: center;\n  gap:  ${({ theme }) => theme.space['2']};\n  padding: ${({ theme }) => theme.space['3']};\n  list-style-type: none;\n\n  cursor: pointer;\n  &[data-disabled=\"true\"] {\n    background: ${({ theme }) => theme.colors.neutral.backgroundWeak};\n    border-radius: ${({ theme }) => theme.radii.default};\n    cursor: not-allowed;\n  }\n`\n\nconst StyledContent = styled.div`\n  border-top: 1px solid ${({ theme }) => theme.colors.neutral.border};\n  padding: ${({ theme }) => theme.space['3']};\n\n`\n\nconst StyledDetails = styled.details`\n  border: 1px solid ${({ theme }) => theme.colors.neutral.border};\n  border-radius: ${({ theme }) => theme.radii.default};\n  width: 100%;\n  transition: border-color 0.2s ease-in-out;\n\n  &[open] {\n    border-color: ${({ theme }) => theme.colors.primary.border};\n\n    & > ${StyledContent} {\n      border-color: ${({ theme }) => theme.colors.primary.border};\n    }\n\n   ${StyledArrowIcon} {\n      transform: rotate(180deg);\n    }\n  }\n\n  &[data-clicking=\"true\"] {\n    box-shadow: ${({ theme }) => `${theme.shadows.raised[0]}, ${theme.shadows.raised[1]}`};\n    border-color: ${({ theme }) => theme.colors.primary.border};\n\n  }\n`\nconst StyledStack = styled(Stack)`\n  position: relative;\n    &:hover > ${StyledDetails} {\n      border-color: ${({ theme }) => theme.colors.primary.border};\n    }\n  `\n\nconst DragIconContainer = styled(Stack)`\n  height: 100%;\n  opacity: 0;\n  transition: opacity 0.2s ease-in-out;\n  cursor: grab;\n  padding-top: calc(${({ theme }) => theme.space['3']} + 2px);\n\n  &[data-visible=\"true\"] {\n    opacity: 1;\n  }\n  &:focus-within {\n    opacity: 1;\n  }\n\n  &:active {\n    cursor: grabbing;\n    opacity: 1;\n  }\n`\n\nexport const EXPANDABLE_CARD_SIZE = ['medium', 'large'] as const\n\ntype DraggableListType = { value?: string }\ntype ExpandableCardSize = (typeof EXPANDABLE_CARD_SIZE)[number]\n\ntype DraggableProps =\n  | {\n      draggable: true\n      value: string\n      draggableTooltip?: string\n      onDrop?: (newValue: string, oldValue: string) => void\n      /**\n       * Index of the card in the  of draggable cards\n       */\n      index: number\n      /**\n       * You this prop to handle drag and drop with the keyboard (accessibility)\n       */\n      onKeyDown?: (event: KeyboardEvent<HTMLDivElement>) => void\n    }\n  | {\n      draggable?: never\n      value?: never\n      draggableTooltip?: never\n      onDrop?: never\n      index?: never\n      onKeyDown?: never\n    }\ntype CommonProps = {\n  header: ReactNode\n  size?: ExpandableCardSize\n  name?: string\n  children: ReactNode\n  disabled?: boolean\n  'data-testid'?: string\n  className?: string\n  /** Uncontrolled but open by default */\n  open?: DetailsHTMLAttributes<HTMLDetailsElement>['open']\n} & DraggableProps\n\ntype ExpandableCardProps = XOR<\n  [CommonProps & { expanded: boolean; onToggleExpand: () => void }, CommonProps]\n>\nconst BaseExpandableCard = forwardRef(\n  (\n    {\n      header,\n      name,\n      size = 'medium',\n      children,\n      disabled,\n      expanded,\n      onToggleExpand,\n      className,\n      draggable,\n      value,\n      draggableTooltip = 'Click and drag to move',\n      onDrop,\n      index,\n      onKeyDown,\n      'data-testid': dataTestId,\n      open,\n    }: ExpandableCardProps,\n    ref: ForwardedRef<HTMLDetailsElement>,\n  ) => {\n    const headerRef = useRef<HTMLDivElement>(null)\n    const containerRef = useRef<HTMLDivElement>(null)\n    const draggableRef = useRef<HTMLDivElement>(null)\n    const draggableFirstRef = useRef<HTMLDivElement>(null)\n    const [isHovered, setIsHovered] = useState(false)\n    const [clicking, setClicking] = useState(false)\n\n    const theme = useTheme()\n\n    const handleMouseEnter = () => {\n      setIsHovered(true)\n    }\n    const handleMouseLeave = () => {\n      setIsHovered(false)\n    }\n\n    const onDragStart = useCallback(\n      (event: DragEvent<HTMLDivElement>) => {\n        event.dataTransfer.setData('text/plain', JSON.stringify({ value }))\n      },\n      [value],\n    )\n\n    const onDragEnd = useCallback(() => setClicking(false), [])\n\n    const onDrag = useCallback(\n      (\n        event: DragEvent<HTMLDivElement>,\n        borderColor: string,\n        isFirst?: boolean,\n      ) => {\n        const refElement = isFirst ? draggableFirstRef : draggableRef\n        event.preventDefault()\n        if (refElement.current) {\n          refElement.current.style.borderColor = borderColor\n        }\n      },\n      [],\n    )\n\n    const handleDrop = useCallback(\n      (event: DragEvent<HTMLDivElement>, isFirst?: boolean) => {\n        event.preventDefault()\n        if (draggableRef.current) {\n          draggableRef.current.style.borderColor = 'transparent'\n        }\n\n        if (event?.dataTransfer) {\n          const data = JSON.parse(\n            event.dataTransfer.getData('text'),\n          ) as DraggableListType\n\n          onDrop?.(isFirst ? '' : value, data.value ?? '')\n        }\n      },\n      [onDrop, value],\n    )\n\n    return (\n      <StyledStack\n        data-draggable={draggable}\n        data-name={name}\n        data-value={value}\n        direction=\"row\"\n        draggable={draggable}\n        gap={2}\n        onDragEnd={onDragEnd}\n        onDragStart={onDragStart}\n        onMouseEnter={handleMouseEnter}\n        onMouseLeave={handleMouseLeave}\n        ref={containerRef}\n        width=\"100%\"\n      >\n        {draggable ? (\n          <DragIconContainer\n            data-testid={`draggable-icon-${value}`}\n            data-visible={isHovered}\n            justifyContent=\"center\"\n            onKeyDown={(event: KeyboardEvent<HTMLDivElement>) => {\n              if (event.key === 'Enter' || event.key === ' ') {\n                event.preventDefault()\n                if (clicking && containerRef.current) {\n                  setClicking(false)\n                  setIsHovered(false)\n                } else if (containerRef.current) {\n                  setClicking(true)\n                  setIsHovered(true)\n                }\n              }\n              if (clicking) {\n                onKeyDown?.(event)\n              }\n            }}\n            onMouseDown={() => setClicking(true)}\n            onMouseUp={() => setClicking(false)}\n          >\n            <Tooltip\n              text={draggableTooltip}\n              visible={clicking ? false : undefined} // Hide the tooltip when dragging the card\n            >\n              <DragIcon\n                disabled={disabled}\n                prominence={clicking ? 'strong' : 'weak'}\n                sentiment=\"neutral\"\n                size=\"small\"\n              />\n            </Tooltip>\n          </DragIconContainer>\n        ) : null}\n        <StyledDetails\n          className={className}\n          data-clicking={clicking}\n          data-testid={dataTestId}\n          key={clicking ? 'closed' : 'open'}\n          name={name}\n          open={open ?? expanded}\n          ref={ref}\n          tabIndex={disabled ? -1 : undefined}\n        >\n          <StyledSummary\n            data-disabled={!!disabled}\n            data-testid={dataTestId ? `${dataTestId}-summary` : undefined}\n            onClick={event => {\n              if (disabled || onToggleExpand) {\n                onToggleExpand?.()\n                event.preventDefault()\n              }\n            }}\n            onKeyDown={\n              onToggleExpand\n                ? event => {\n                    if (\n                      event.key === ' ' &&\n                      event.target === headerRef.current\n                    ) {\n                      onToggleExpand()\n                      event.preventDefault()\n                    }\n                  }\n                : undefined\n            }\n            ref={headerRef}\n          >\n            <StyledArrowIcon disabled={disabled} sentiment=\"neutral\" />\n            {typeof header === 'string' ? (\n              <ExpandableCardTitle disabled={disabled} size={size}>\n                {header}\n              </ExpandableCardTitle>\n            ) : (\n              header\n            )}\n          </StyledSummary>\n          <StyledContent>{children}</StyledContent>\n        </StyledDetails>\n        {draggable && index === 0 ? (\n          <DropableArea\n            data-first\n            onDragLeave={event => onDrag(event, 'transparent', true)}\n            onDragOver={event =>\n              onDrag(event, theme.colors.primary.border, true)\n            }\n            onDrop={event => handleDrop(event, true)}\n            ref={draggableFirstRef}\n          />\n        ) : null}\n        {draggable ? (\n          <DropableArea\n            data-testid={`${value}-dropable-area`}\n            onDragLeave={event => onDrag(event, 'transparent')}\n            onDragOver={event => onDrag(event, theme.colors.primary.border)}\n            onDrop={handleDrop}\n            ref={draggableRef}\n          />\n        ) : null}\n      </StyledStack>\n    )\n  },\n)\n\n// /**\n//  * ExpandableCard is a card that can be collapsed and expanded to reveal more content.\n//  */\nexport const ExpandableCard = Object.assign(BaseExpandableCard, {\n  Title: ExpandableCardTitle,\n})\n"]} */");
16
- const DropableArea = /* @__PURE__ */ _styled("div", process.env.NODE_ENV === "production" ? {
17
- target: "e143cpd65"
18
- } : {
19
- target: "e143cpd65",
20
- label: "DropableArea"
21
- })("height:", ({
22
- theme
23
- }) => theme.space["3"], ";border-bottom:2px solid;border-color:transparent;padding:", ({
24
- theme
25
- }) => theme.space["0.5"], ' 0;width:100%;bottom:-5px;position:absolute;&[data-first="true"]{top:-', ({
26
- theme
27
- }) => theme.space["3"], ";}&::after{content:'';left:0;bottom:-4px;height:0px;width:0px;border:3px solid;border-color:inherit;border-radius:", ({
28
- theme
29
- }) => theme.radii.circle, ";display:flex;margin-top:-", ({
30
- theme
31
- }) => theme.space["1"], ";margin-left:-", ({
32
- theme
33
- }) => theme.space["0.25"], ";position:absolute;}" + (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/ExpandableCard/index.tsx"],"names":[],"mappings":"AAoB+B","file":"/home/runner/work/ultraviolet/ultraviolet/packages/ui/src/components/ExpandableCard/index.tsx","sourcesContent":["'use client'\n\nimport { useTheme } from '@emotion/react'\nimport styled from '@emotion/styled'\nimport { ArrowDownIcon, DragIcon } from '@ultraviolet/icons'\nimport type {\n  DetailsHTMLAttributes,\n  DragEvent,\n  ForwardedRef,\n  KeyboardEvent,\n  ReactNode,\n} from 'react'\nimport { forwardRef, useCallback, useRef, useState } from 'react'\nimport type { XOR } from '../../types'\nimport { Stack } from '../Stack'\nimport { Tooltip } from '../Tooltip'\nimport { ExpandableCardTitle } from './components/Title'\n\nconst StyledArrowIcon = styled(ArrowDownIcon)``\n\nconst DropableArea = styled.div`\n  height: ${({ theme }) => theme.space['3']};\n  border-bottom: 2px solid;\n  border-color: transparent;\n  padding: ${({ theme }) => theme.space['0.5']} 0;\n  width: 100%;\n  bottom: -5px;\n  position: absolute;\n\n  &[data-first=\"true\"] {\n    top: -${({ theme }) => theme.space['3']};\n  }\n\n  &::after {\n    content: '';\n    left: 0;\n    bottom: -4px;\n    height: 0px;\n    width: 0px;\n    border: 3px solid;\n    border-color: inherit;\n    border-radius: ${({ theme }) => theme.radii.circle};\n    display: flex;\n    margin-top:  -${({ theme }) => theme.space['1']};\n    margin-left: -${({ theme }) => theme.space['0.25']};\n    position: absolute;\n  }\n`\n\nconst StyledSummary = styled.summary`\n  display: flex;\n  flex-direction: row;\n  align-items: center;\n  gap:  ${({ theme }) => theme.space['2']};\n  padding: ${({ theme }) => theme.space['3']};\n  list-style-type: none;\n\n  cursor: pointer;\n  &[data-disabled=\"true\"] {\n    background: ${({ theme }) => theme.colors.neutral.backgroundWeak};\n    border-radius: ${({ theme }) => theme.radii.default};\n    cursor: not-allowed;\n  }\n`\n\nconst StyledContent = styled.div`\n  border-top: 1px solid ${({ theme }) => theme.colors.neutral.border};\n  padding: ${({ theme }) => theme.space['3']};\n\n`\n\nconst StyledDetails = styled.details`\n  border: 1px solid ${({ theme }) => theme.colors.neutral.border};\n  border-radius: ${({ theme }) => theme.radii.default};\n  width: 100%;\n  transition: border-color 0.2s ease-in-out;\n\n  &[open] {\n    border-color: ${({ theme }) => theme.colors.primary.border};\n\n    & > ${StyledContent} {\n      border-color: ${({ theme }) => theme.colors.primary.border};\n    }\n\n   ${StyledArrowIcon} {\n      transform: rotate(180deg);\n    }\n  }\n\n  &[data-clicking=\"true\"] {\n    box-shadow: ${({ theme }) => `${theme.shadows.raised[0]}, ${theme.shadows.raised[1]}`};\n    border-color: ${({ theme }) => theme.colors.primary.border};\n\n  }\n`\nconst StyledStack = styled(Stack)`\n  position: relative;\n    &:hover > ${StyledDetails} {\n      border-color: ${({ theme }) => theme.colors.primary.border};\n    }\n  `\n\nconst DragIconContainer = styled(Stack)`\n  height: 100%;\n  opacity: 0;\n  transition: opacity 0.2s ease-in-out;\n  cursor: grab;\n  padding-top: calc(${({ theme }) => theme.space['3']} + 2px);\n\n  &[data-visible=\"true\"] {\n    opacity: 1;\n  }\n  &:focus-within {\n    opacity: 1;\n  }\n\n  &:active {\n    cursor: grabbing;\n    opacity: 1;\n  }\n`\n\nexport const EXPANDABLE_CARD_SIZE = ['medium', 'large'] as const\n\ntype DraggableListType = { value?: string }\ntype ExpandableCardSize = (typeof EXPANDABLE_CARD_SIZE)[number]\n\ntype DraggableProps =\n  | {\n      draggable: true\n      value: string\n      draggableTooltip?: string\n      onDrop?: (newValue: string, oldValue: string) => void\n      /**\n       * Index of the card in the  of draggable cards\n       */\n      index: number\n      /**\n       * You this prop to handle drag and drop with the keyboard (accessibility)\n       */\n      onKeyDown?: (event: KeyboardEvent<HTMLDivElement>) => void\n    }\n  | {\n      draggable?: never\n      value?: never\n      draggableTooltip?: never\n      onDrop?: never\n      index?: never\n      onKeyDown?: never\n    }\ntype CommonProps = {\n  header: ReactNode\n  size?: ExpandableCardSize\n  name?: string\n  children: ReactNode\n  disabled?: boolean\n  'data-testid'?: string\n  className?: string\n  /** Uncontrolled but open by default */\n  open?: DetailsHTMLAttributes<HTMLDetailsElement>['open']\n} & DraggableProps\n\ntype ExpandableCardProps = XOR<\n  [CommonProps & { expanded: boolean; onToggleExpand: () => void }, CommonProps]\n>\nconst BaseExpandableCard = forwardRef(\n  (\n    {\n      header,\n      name,\n      size = 'medium',\n      children,\n      disabled,\n      expanded,\n      onToggleExpand,\n      className,\n      draggable,\n      value,\n      draggableTooltip = 'Click and drag to move',\n      onDrop,\n      index,\n      onKeyDown,\n      'data-testid': dataTestId,\n      open,\n    }: ExpandableCardProps,\n    ref: ForwardedRef<HTMLDetailsElement>,\n  ) => {\n    const headerRef = useRef<HTMLDivElement>(null)\n    const containerRef = useRef<HTMLDivElement>(null)\n    const draggableRef = useRef<HTMLDivElement>(null)\n    const draggableFirstRef = useRef<HTMLDivElement>(null)\n    const [isHovered, setIsHovered] = useState(false)\n    const [clicking, setClicking] = useState(false)\n\n    const theme = useTheme()\n\n    const handleMouseEnter = () => {\n      setIsHovered(true)\n    }\n    const handleMouseLeave = () => {\n      setIsHovered(false)\n    }\n\n    const onDragStart = useCallback(\n      (event: DragEvent<HTMLDivElement>) => {\n        event.dataTransfer.setData('text/plain', JSON.stringify({ value }))\n      },\n      [value],\n    )\n\n    const onDragEnd = useCallback(() => setClicking(false), [])\n\n    const onDrag = useCallback(\n      (\n        event: DragEvent<HTMLDivElement>,\n        borderColor: string,\n        isFirst?: boolean,\n      ) => {\n        const refElement = isFirst ? draggableFirstRef : draggableRef\n        event.preventDefault()\n        if (refElement.current) {\n          refElement.current.style.borderColor = borderColor\n        }\n      },\n      [],\n    )\n\n    const handleDrop = useCallback(\n      (event: DragEvent<HTMLDivElement>, isFirst?: boolean) => {\n        event.preventDefault()\n        if (draggableRef.current) {\n          draggableRef.current.style.borderColor = 'transparent'\n        }\n\n        if (event?.dataTransfer) {\n          const data = JSON.parse(\n            event.dataTransfer.getData('text'),\n          ) as DraggableListType\n\n          onDrop?.(isFirst ? '' : value, data.value ?? '')\n        }\n      },\n      [onDrop, value],\n    )\n\n    return (\n      <StyledStack\n        data-draggable={draggable}\n        data-name={name}\n        data-value={value}\n        direction=\"row\"\n        draggable={draggable}\n        gap={2}\n        onDragEnd={onDragEnd}\n        onDragStart={onDragStart}\n        onMouseEnter={handleMouseEnter}\n        onMouseLeave={handleMouseLeave}\n        ref={containerRef}\n        width=\"100%\"\n      >\n        {draggable ? (\n          <DragIconContainer\n            data-testid={`draggable-icon-${value}`}\n            data-visible={isHovered}\n            justifyContent=\"center\"\n            onKeyDown={(event: KeyboardEvent<HTMLDivElement>) => {\n              if (event.key === 'Enter' || event.key === ' ') {\n                event.preventDefault()\n                if (clicking && containerRef.current) {\n                  setClicking(false)\n                  setIsHovered(false)\n                } else if (containerRef.current) {\n                  setClicking(true)\n                  setIsHovered(true)\n                }\n              }\n              if (clicking) {\n                onKeyDown?.(event)\n              }\n            }}\n            onMouseDown={() => setClicking(true)}\n            onMouseUp={() => setClicking(false)}\n          >\n            <Tooltip\n              text={draggableTooltip}\n              visible={clicking ? false : undefined} // Hide the tooltip when dragging the card\n            >\n              <DragIcon\n                disabled={disabled}\n                prominence={clicking ? 'strong' : 'weak'}\n                sentiment=\"neutral\"\n                size=\"small\"\n              />\n            </Tooltip>\n          </DragIconContainer>\n        ) : null}\n        <StyledDetails\n          className={className}\n          data-clicking={clicking}\n          data-testid={dataTestId}\n          key={clicking ? 'closed' : 'open'}\n          name={name}\n          open={open ?? expanded}\n          ref={ref}\n          tabIndex={disabled ? -1 : undefined}\n        >\n          <StyledSummary\n            data-disabled={!!disabled}\n            data-testid={dataTestId ? `${dataTestId}-summary` : undefined}\n            onClick={event => {\n              if (disabled || onToggleExpand) {\n                onToggleExpand?.()\n                event.preventDefault()\n              }\n            }}\n            onKeyDown={\n              onToggleExpand\n                ? event => {\n                    if (\n                      event.key === ' ' &&\n                      event.target === headerRef.current\n                    ) {\n                      onToggleExpand()\n                      event.preventDefault()\n                    }\n                  }\n                : undefined\n            }\n            ref={headerRef}\n          >\n            <StyledArrowIcon disabled={disabled} sentiment=\"neutral\" />\n            {typeof header === 'string' ? (\n              <ExpandableCardTitle disabled={disabled} size={size}>\n                {header}\n              </ExpandableCardTitle>\n            ) : (\n              header\n            )}\n          </StyledSummary>\n          <StyledContent>{children}</StyledContent>\n        </StyledDetails>\n        {draggable && index === 0 ? (\n          <DropableArea\n            data-first\n            onDragLeave={event => onDrag(event, 'transparent', true)}\n            onDragOver={event =>\n              onDrag(event, theme.colors.primary.border, true)\n            }\n            onDrop={event => handleDrop(event, true)}\n            ref={draggableFirstRef}\n          />\n        ) : null}\n        {draggable ? (\n          <DropableArea\n            data-testid={`${value}-dropable-area`}\n            onDragLeave={event => onDrag(event, 'transparent')}\n            onDragOver={event => onDrag(event, theme.colors.primary.border)}\n            onDrop={handleDrop}\n            ref={draggableRef}\n          />\n        ) : null}\n      </StyledStack>\n    )\n  },\n)\n\n// /**\n//  * ExpandableCard is a card that can be collapsed and expanded to reveal more content.\n//  */\nexport const ExpandableCard = Object.assign(BaseExpandableCard, {\n  Title: ExpandableCardTitle,\n})\n"]} */"));
34
- const StyledSummary = /* @__PURE__ */ _styled("summary", process.env.NODE_ENV === "production" ? {
35
- target: "e143cpd64"
36
- } : {
37
- target: "e143cpd64",
38
- label: "StyledSummary"
39
- })("display:flex;flex-direction:row;align-items:center;gap:", ({
40
- theme
41
- }) => theme.space["2"], ";padding:", ({
42
- theme
43
- }) => theme.space["3"], ';list-style-type:none;cursor:pointer;&[data-disabled="true"]{background:', ({
44
- theme
45
- }) => theme.colors.neutral.backgroundWeak, ";border-radius:", ({
46
- theme
47
- }) => theme.radii.default, ";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/ExpandableCard/index.tsx"],"names":[],"mappings":"AAiDoC","file":"/home/runner/work/ultraviolet/ultraviolet/packages/ui/src/components/ExpandableCard/index.tsx","sourcesContent":["'use client'\n\nimport { useTheme } from '@emotion/react'\nimport styled from '@emotion/styled'\nimport { ArrowDownIcon, DragIcon } from '@ultraviolet/icons'\nimport type {\n  DetailsHTMLAttributes,\n  DragEvent,\n  ForwardedRef,\n  KeyboardEvent,\n  ReactNode,\n} from 'react'\nimport { forwardRef, useCallback, useRef, useState } from 'react'\nimport type { XOR } from '../../types'\nimport { Stack } from '../Stack'\nimport { Tooltip } from '../Tooltip'\nimport { ExpandableCardTitle } from './components/Title'\n\nconst StyledArrowIcon = styled(ArrowDownIcon)``\n\nconst DropableArea = styled.div`\n  height: ${({ theme }) => theme.space['3']};\n  border-bottom: 2px solid;\n  border-color: transparent;\n  padding: ${({ theme }) => theme.space['0.5']} 0;\n  width: 100%;\n  bottom: -5px;\n  position: absolute;\n\n  &[data-first=\"true\"] {\n    top: -${({ theme }) => theme.space['3']};\n  }\n\n  &::after {\n    content: '';\n    left: 0;\n    bottom: -4px;\n    height: 0px;\n    width: 0px;\n    border: 3px solid;\n    border-color: inherit;\n    border-radius: ${({ theme }) => theme.radii.circle};\n    display: flex;\n    margin-top:  -${({ theme }) => theme.space['1']};\n    margin-left: -${({ theme }) => theme.space['0.25']};\n    position: absolute;\n  }\n`\n\nconst StyledSummary = styled.summary`\n  display: flex;\n  flex-direction: row;\n  align-items: center;\n  gap:  ${({ theme }) => theme.space['2']};\n  padding: ${({ theme }) => theme.space['3']};\n  list-style-type: none;\n\n  cursor: pointer;\n  &[data-disabled=\"true\"] {\n    background: ${({ theme }) => theme.colors.neutral.backgroundWeak};\n    border-radius: ${({ theme }) => theme.radii.default};\n    cursor: not-allowed;\n  }\n`\n\nconst StyledContent = styled.div`\n  border-top: 1px solid ${({ theme }) => theme.colors.neutral.border};\n  padding: ${({ theme }) => theme.space['3']};\n\n`\n\nconst StyledDetails = styled.details`\n  border: 1px solid ${({ theme }) => theme.colors.neutral.border};\n  border-radius: ${({ theme }) => theme.radii.default};\n  width: 100%;\n  transition: border-color 0.2s ease-in-out;\n\n  &[open] {\n    border-color: ${({ theme }) => theme.colors.primary.border};\n\n    & > ${StyledContent} {\n      border-color: ${({ theme }) => theme.colors.primary.border};\n    }\n\n   ${StyledArrowIcon} {\n      transform: rotate(180deg);\n    }\n  }\n\n  &[data-clicking=\"true\"] {\n    box-shadow: ${({ theme }) => `${theme.shadows.raised[0]}, ${theme.shadows.raised[1]}`};\n    border-color: ${({ theme }) => theme.colors.primary.border};\n\n  }\n`\nconst StyledStack = styled(Stack)`\n  position: relative;\n    &:hover > ${StyledDetails} {\n      border-color: ${({ theme }) => theme.colors.primary.border};\n    }\n  `\n\nconst DragIconContainer = styled(Stack)`\n  height: 100%;\n  opacity: 0;\n  transition: opacity 0.2s ease-in-out;\n  cursor: grab;\n  padding-top: calc(${({ theme }) => theme.space['3']} + 2px);\n\n  &[data-visible=\"true\"] {\n    opacity: 1;\n  }\n  &:focus-within {\n    opacity: 1;\n  }\n\n  &:active {\n    cursor: grabbing;\n    opacity: 1;\n  }\n`\n\nexport const EXPANDABLE_CARD_SIZE = ['medium', 'large'] as const\n\ntype DraggableListType = { value?: string }\ntype ExpandableCardSize = (typeof EXPANDABLE_CARD_SIZE)[number]\n\ntype DraggableProps =\n  | {\n      draggable: true\n      value: string\n      draggableTooltip?: string\n      onDrop?: (newValue: string, oldValue: string) => void\n      /**\n       * Index of the card in the  of draggable cards\n       */\n      index: number\n      /**\n       * You this prop to handle drag and drop with the keyboard (accessibility)\n       */\n      onKeyDown?: (event: KeyboardEvent<HTMLDivElement>) => void\n    }\n  | {\n      draggable?: never\n      value?: never\n      draggableTooltip?: never\n      onDrop?: never\n      index?: never\n      onKeyDown?: never\n    }\ntype CommonProps = {\n  header: ReactNode\n  size?: ExpandableCardSize\n  name?: string\n  children: ReactNode\n  disabled?: boolean\n  'data-testid'?: string\n  className?: string\n  /** Uncontrolled but open by default */\n  open?: DetailsHTMLAttributes<HTMLDetailsElement>['open']\n} & DraggableProps\n\ntype ExpandableCardProps = XOR<\n  [CommonProps & { expanded: boolean; onToggleExpand: () => void }, CommonProps]\n>\nconst BaseExpandableCard = forwardRef(\n  (\n    {\n      header,\n      name,\n      size = 'medium',\n      children,\n      disabled,\n      expanded,\n      onToggleExpand,\n      className,\n      draggable,\n      value,\n      draggableTooltip = 'Click and drag to move',\n      onDrop,\n      index,\n      onKeyDown,\n      'data-testid': dataTestId,\n      open,\n    }: ExpandableCardProps,\n    ref: ForwardedRef<HTMLDetailsElement>,\n  ) => {\n    const headerRef = useRef<HTMLDivElement>(null)\n    const containerRef = useRef<HTMLDivElement>(null)\n    const draggableRef = useRef<HTMLDivElement>(null)\n    const draggableFirstRef = useRef<HTMLDivElement>(null)\n    const [isHovered, setIsHovered] = useState(false)\n    const [clicking, setClicking] = useState(false)\n\n    const theme = useTheme()\n\n    const handleMouseEnter = () => {\n      setIsHovered(true)\n    }\n    const handleMouseLeave = () => {\n      setIsHovered(false)\n    }\n\n    const onDragStart = useCallback(\n      (event: DragEvent<HTMLDivElement>) => {\n        event.dataTransfer.setData('text/plain', JSON.stringify({ value }))\n      },\n      [value],\n    )\n\n    const onDragEnd = useCallback(() => setClicking(false), [])\n\n    const onDrag = useCallback(\n      (\n        event: DragEvent<HTMLDivElement>,\n        borderColor: string,\n        isFirst?: boolean,\n      ) => {\n        const refElement = isFirst ? draggableFirstRef : draggableRef\n        event.preventDefault()\n        if (refElement.current) {\n          refElement.current.style.borderColor = borderColor\n        }\n      },\n      [],\n    )\n\n    const handleDrop = useCallback(\n      (event: DragEvent<HTMLDivElement>, isFirst?: boolean) => {\n        event.preventDefault()\n        if (draggableRef.current) {\n          draggableRef.current.style.borderColor = 'transparent'\n        }\n\n        if (event?.dataTransfer) {\n          const data = JSON.parse(\n            event.dataTransfer.getData('text'),\n          ) as DraggableListType\n\n          onDrop?.(isFirst ? '' : value, data.value ?? '')\n        }\n      },\n      [onDrop, value],\n    )\n\n    return (\n      <StyledStack\n        data-draggable={draggable}\n        data-name={name}\n        data-value={value}\n        direction=\"row\"\n        draggable={draggable}\n        gap={2}\n        onDragEnd={onDragEnd}\n        onDragStart={onDragStart}\n        onMouseEnter={handleMouseEnter}\n        onMouseLeave={handleMouseLeave}\n        ref={containerRef}\n        width=\"100%\"\n      >\n        {draggable ? (\n          <DragIconContainer\n            data-testid={`draggable-icon-${value}`}\n            data-visible={isHovered}\n            justifyContent=\"center\"\n            onKeyDown={(event: KeyboardEvent<HTMLDivElement>) => {\n              if (event.key === 'Enter' || event.key === ' ') {\n                event.preventDefault()\n                if (clicking && containerRef.current) {\n                  setClicking(false)\n                  setIsHovered(false)\n                } else if (containerRef.current) {\n                  setClicking(true)\n                  setIsHovered(true)\n                }\n              }\n              if (clicking) {\n                onKeyDown?.(event)\n              }\n            }}\n            onMouseDown={() => setClicking(true)}\n            onMouseUp={() => setClicking(false)}\n          >\n            <Tooltip\n              text={draggableTooltip}\n              visible={clicking ? false : undefined} // Hide the tooltip when dragging the card\n            >\n              <DragIcon\n                disabled={disabled}\n                prominence={clicking ? 'strong' : 'weak'}\n                sentiment=\"neutral\"\n                size=\"small\"\n              />\n            </Tooltip>\n          </DragIconContainer>\n        ) : null}\n        <StyledDetails\n          className={className}\n          data-clicking={clicking}\n          data-testid={dataTestId}\n          key={clicking ? 'closed' : 'open'}\n          name={name}\n          open={open ?? expanded}\n          ref={ref}\n          tabIndex={disabled ? -1 : undefined}\n        >\n          <StyledSummary\n            data-disabled={!!disabled}\n            data-testid={dataTestId ? `${dataTestId}-summary` : undefined}\n            onClick={event => {\n              if (disabled || onToggleExpand) {\n                onToggleExpand?.()\n                event.preventDefault()\n              }\n            }}\n            onKeyDown={\n              onToggleExpand\n                ? event => {\n                    if (\n                      event.key === ' ' &&\n                      event.target === headerRef.current\n                    ) {\n                      onToggleExpand()\n                      event.preventDefault()\n                    }\n                  }\n                : undefined\n            }\n            ref={headerRef}\n          >\n            <StyledArrowIcon disabled={disabled} sentiment=\"neutral\" />\n            {typeof header === 'string' ? (\n              <ExpandableCardTitle disabled={disabled} size={size}>\n                {header}\n              </ExpandableCardTitle>\n            ) : (\n              header\n            )}\n          </StyledSummary>\n          <StyledContent>{children}</StyledContent>\n        </StyledDetails>\n        {draggable && index === 0 ? (\n          <DropableArea\n            data-first\n            onDragLeave={event => onDrag(event, 'transparent', true)}\n            onDragOver={event =>\n              onDrag(event, theme.colors.primary.border, true)\n            }\n            onDrop={event => handleDrop(event, true)}\n            ref={draggableFirstRef}\n          />\n        ) : null}\n        {draggable ? (\n          <DropableArea\n            data-testid={`${value}-dropable-area`}\n            onDragLeave={event => onDrag(event, 'transparent')}\n            onDragOver={event => onDrag(event, theme.colors.primary.border)}\n            onDrop={handleDrop}\n            ref={draggableRef}\n          />\n        ) : null}\n      </StyledStack>\n    )\n  },\n)\n\n// /**\n//  * ExpandableCard is a card that can be collapsed and expanded to reveal more content.\n//  */\nexport const ExpandableCard = Object.assign(BaseExpandableCard, {\n  Title: ExpandableCardTitle,\n})\n"]} */"));
48
- const StyledContent = /* @__PURE__ */ _styled("div", process.env.NODE_ENV === "production" ? {
49
- target: "e143cpd63"
50
- } : {
51
- target: "e143cpd63",
52
- label: "StyledContent"
53
- })("border-top:1px solid ", ({
54
- theme
55
- }) => theme.colors.neutral.border, ";padding:", ({
56
- theme
57
- }) => theme.space["3"], ";" + (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/ExpandableCard/index.tsx"],"names":[],"mappings":"AAiEgC","file":"/home/runner/work/ultraviolet/ultraviolet/packages/ui/src/components/ExpandableCard/index.tsx","sourcesContent":["'use client'\n\nimport { useTheme } from '@emotion/react'\nimport styled from '@emotion/styled'\nimport { ArrowDownIcon, DragIcon } from '@ultraviolet/icons'\nimport type {\n  DetailsHTMLAttributes,\n  DragEvent,\n  ForwardedRef,\n  KeyboardEvent,\n  ReactNode,\n} from 'react'\nimport { forwardRef, useCallback, useRef, useState } from 'react'\nimport type { XOR } from '../../types'\nimport { Stack } from '../Stack'\nimport { Tooltip } from '../Tooltip'\nimport { ExpandableCardTitle } from './components/Title'\n\nconst StyledArrowIcon = styled(ArrowDownIcon)``\n\nconst DropableArea = styled.div`\n  height: ${({ theme }) => theme.space['3']};\n  border-bottom: 2px solid;\n  border-color: transparent;\n  padding: ${({ theme }) => theme.space['0.5']} 0;\n  width: 100%;\n  bottom: -5px;\n  position: absolute;\n\n  &[data-first=\"true\"] {\n    top: -${({ theme }) => theme.space['3']};\n  }\n\n  &::after {\n    content: '';\n    left: 0;\n    bottom: -4px;\n    height: 0px;\n    width: 0px;\n    border: 3px solid;\n    border-color: inherit;\n    border-radius: ${({ theme }) => theme.radii.circle};\n    display: flex;\n    margin-top:  -${({ theme }) => theme.space['1']};\n    margin-left: -${({ theme }) => theme.space['0.25']};\n    position: absolute;\n  }\n`\n\nconst StyledSummary = styled.summary`\n  display: flex;\n  flex-direction: row;\n  align-items: center;\n  gap:  ${({ theme }) => theme.space['2']};\n  padding: ${({ theme }) => theme.space['3']};\n  list-style-type: none;\n\n  cursor: pointer;\n  &[data-disabled=\"true\"] {\n    background: ${({ theme }) => theme.colors.neutral.backgroundWeak};\n    border-radius: ${({ theme }) => theme.radii.default};\n    cursor: not-allowed;\n  }\n`\n\nconst StyledContent = styled.div`\n  border-top: 1px solid ${({ theme }) => theme.colors.neutral.border};\n  padding: ${({ theme }) => theme.space['3']};\n\n`\n\nconst StyledDetails = styled.details`\n  border: 1px solid ${({ theme }) => theme.colors.neutral.border};\n  border-radius: ${({ theme }) => theme.radii.default};\n  width: 100%;\n  transition: border-color 0.2s ease-in-out;\n\n  &[open] {\n    border-color: ${({ theme }) => theme.colors.primary.border};\n\n    & > ${StyledContent} {\n      border-color: ${({ theme }) => theme.colors.primary.border};\n    }\n\n   ${StyledArrowIcon} {\n      transform: rotate(180deg);\n    }\n  }\n\n  &[data-clicking=\"true\"] {\n    box-shadow: ${({ theme }) => `${theme.shadows.raised[0]}, ${theme.shadows.raised[1]}`};\n    border-color: ${({ theme }) => theme.colors.primary.border};\n\n  }\n`\nconst StyledStack = styled(Stack)`\n  position: relative;\n    &:hover > ${StyledDetails} {\n      border-color: ${({ theme }) => theme.colors.primary.border};\n    }\n  `\n\nconst DragIconContainer = styled(Stack)`\n  height: 100%;\n  opacity: 0;\n  transition: opacity 0.2s ease-in-out;\n  cursor: grab;\n  padding-top: calc(${({ theme }) => theme.space['3']} + 2px);\n\n  &[data-visible=\"true\"] {\n    opacity: 1;\n  }\n  &:focus-within {\n    opacity: 1;\n  }\n\n  &:active {\n    cursor: grabbing;\n    opacity: 1;\n  }\n`\n\nexport const EXPANDABLE_CARD_SIZE = ['medium', 'large'] as const\n\ntype DraggableListType = { value?: string }\ntype ExpandableCardSize = (typeof EXPANDABLE_CARD_SIZE)[number]\n\ntype DraggableProps =\n  | {\n      draggable: true\n      value: string\n      draggableTooltip?: string\n      onDrop?: (newValue: string, oldValue: string) => void\n      /**\n       * Index of the card in the  of draggable cards\n       */\n      index: number\n      /**\n       * You this prop to handle drag and drop with the keyboard (accessibility)\n       */\n      onKeyDown?: (event: KeyboardEvent<HTMLDivElement>) => void\n    }\n  | {\n      draggable?: never\n      value?: never\n      draggableTooltip?: never\n      onDrop?: never\n      index?: never\n      onKeyDown?: never\n    }\ntype CommonProps = {\n  header: ReactNode\n  size?: ExpandableCardSize\n  name?: string\n  children: ReactNode\n  disabled?: boolean\n  'data-testid'?: string\n  className?: string\n  /** Uncontrolled but open by default */\n  open?: DetailsHTMLAttributes<HTMLDetailsElement>['open']\n} & DraggableProps\n\ntype ExpandableCardProps = XOR<\n  [CommonProps & { expanded: boolean; onToggleExpand: () => void }, CommonProps]\n>\nconst BaseExpandableCard = forwardRef(\n  (\n    {\n      header,\n      name,\n      size = 'medium',\n      children,\n      disabled,\n      expanded,\n      onToggleExpand,\n      className,\n      draggable,\n      value,\n      draggableTooltip = 'Click and drag to move',\n      onDrop,\n      index,\n      onKeyDown,\n      'data-testid': dataTestId,\n      open,\n    }: ExpandableCardProps,\n    ref: ForwardedRef<HTMLDetailsElement>,\n  ) => {\n    const headerRef = useRef<HTMLDivElement>(null)\n    const containerRef = useRef<HTMLDivElement>(null)\n    const draggableRef = useRef<HTMLDivElement>(null)\n    const draggableFirstRef = useRef<HTMLDivElement>(null)\n    const [isHovered, setIsHovered] = useState(false)\n    const [clicking, setClicking] = useState(false)\n\n    const theme = useTheme()\n\n    const handleMouseEnter = () => {\n      setIsHovered(true)\n    }\n    const handleMouseLeave = () => {\n      setIsHovered(false)\n    }\n\n    const onDragStart = useCallback(\n      (event: DragEvent<HTMLDivElement>) => {\n        event.dataTransfer.setData('text/plain', JSON.stringify({ value }))\n      },\n      [value],\n    )\n\n    const onDragEnd = useCallback(() => setClicking(false), [])\n\n    const onDrag = useCallback(\n      (\n        event: DragEvent<HTMLDivElement>,\n        borderColor: string,\n        isFirst?: boolean,\n      ) => {\n        const refElement = isFirst ? draggableFirstRef : draggableRef\n        event.preventDefault()\n        if (refElement.current) {\n          refElement.current.style.borderColor = borderColor\n        }\n      },\n      [],\n    )\n\n    const handleDrop = useCallback(\n      (event: DragEvent<HTMLDivElement>, isFirst?: boolean) => {\n        event.preventDefault()\n        if (draggableRef.current) {\n          draggableRef.current.style.borderColor = 'transparent'\n        }\n\n        if (event?.dataTransfer) {\n          const data = JSON.parse(\n            event.dataTransfer.getData('text'),\n          ) as DraggableListType\n\n          onDrop?.(isFirst ? '' : value, data.value ?? '')\n        }\n      },\n      [onDrop, value],\n    )\n\n    return (\n      <StyledStack\n        data-draggable={draggable}\n        data-name={name}\n        data-value={value}\n        direction=\"row\"\n        draggable={draggable}\n        gap={2}\n        onDragEnd={onDragEnd}\n        onDragStart={onDragStart}\n        onMouseEnter={handleMouseEnter}\n        onMouseLeave={handleMouseLeave}\n        ref={containerRef}\n        width=\"100%\"\n      >\n        {draggable ? (\n          <DragIconContainer\n            data-testid={`draggable-icon-${value}`}\n            data-visible={isHovered}\n            justifyContent=\"center\"\n            onKeyDown={(event: KeyboardEvent<HTMLDivElement>) => {\n              if (event.key === 'Enter' || event.key === ' ') {\n                event.preventDefault()\n                if (clicking && containerRef.current) {\n                  setClicking(false)\n                  setIsHovered(false)\n                } else if (containerRef.current) {\n                  setClicking(true)\n                  setIsHovered(true)\n                }\n              }\n              if (clicking) {\n                onKeyDown?.(event)\n              }\n            }}\n            onMouseDown={() => setClicking(true)}\n            onMouseUp={() => setClicking(false)}\n          >\n            <Tooltip\n              text={draggableTooltip}\n              visible={clicking ? false : undefined} // Hide the tooltip when dragging the card\n            >\n              <DragIcon\n                disabled={disabled}\n                prominence={clicking ? 'strong' : 'weak'}\n                sentiment=\"neutral\"\n                size=\"small\"\n              />\n            </Tooltip>\n          </DragIconContainer>\n        ) : null}\n        <StyledDetails\n          className={className}\n          data-clicking={clicking}\n          data-testid={dataTestId}\n          key={clicking ? 'closed' : 'open'}\n          name={name}\n          open={open ?? expanded}\n          ref={ref}\n          tabIndex={disabled ? -1 : undefined}\n        >\n          <StyledSummary\n            data-disabled={!!disabled}\n            data-testid={dataTestId ? `${dataTestId}-summary` : undefined}\n            onClick={event => {\n              if (disabled || onToggleExpand) {\n                onToggleExpand?.()\n                event.preventDefault()\n              }\n            }}\n            onKeyDown={\n              onToggleExpand\n                ? event => {\n                    if (\n                      event.key === ' ' &&\n                      event.target === headerRef.current\n                    ) {\n                      onToggleExpand()\n                      event.preventDefault()\n                    }\n                  }\n                : undefined\n            }\n            ref={headerRef}\n          >\n            <StyledArrowIcon disabled={disabled} sentiment=\"neutral\" />\n            {typeof header === 'string' ? (\n              <ExpandableCardTitle disabled={disabled} size={size}>\n                {header}\n              </ExpandableCardTitle>\n            ) : (\n              header\n            )}\n          </StyledSummary>\n          <StyledContent>{children}</StyledContent>\n        </StyledDetails>\n        {draggable && index === 0 ? (\n          <DropableArea\n            data-first\n            onDragLeave={event => onDrag(event, 'transparent', true)}\n            onDragOver={event =>\n              onDrag(event, theme.colors.primary.border, true)\n            }\n            onDrop={event => handleDrop(event, true)}\n            ref={draggableFirstRef}\n          />\n        ) : null}\n        {draggable ? (\n          <DropableArea\n            data-testid={`${value}-dropable-area`}\n            onDragLeave={event => onDrag(event, 'transparent')}\n            onDragOver={event => onDrag(event, theme.colors.primary.border)}\n            onDrop={handleDrop}\n            ref={draggableRef}\n          />\n        ) : null}\n      </StyledStack>\n    )\n  },\n)\n\n// /**\n//  * ExpandableCard is a card that can be collapsed and expanded to reveal more content.\n//  */\nexport const ExpandableCard = Object.assign(BaseExpandableCard, {\n  Title: ExpandableCardTitle,\n})\n"]} */"));
58
- const StyledDetails = /* @__PURE__ */ _styled("details", process.env.NODE_ENV === "production" ? {
59
- target: "e143cpd62"
60
- } : {
61
- target: "e143cpd62",
62
- label: "StyledDetails"
63
- })("border:1px solid ", ({
64
- theme
65
- }) => theme.colors.neutral.border, ";border-radius:", ({
66
- theme
67
- }) => theme.radii.default, ";width:100%;transition:border-color 0.2s ease-in-out;&[open]{border-color:", ({
68
- theme
69
- }) => theme.colors.primary.border, ";&>", StyledContent, "{border-color:", ({
70
- theme
71
- }) => theme.colors.primary.border, ";}", StyledArrowIcon, '{transform:rotate(180deg);}}&[data-clicking="true"]{box-shadow:', ({
72
- theme
73
- }) => `${theme.shadows.raised[0]}, ${theme.shadows.raised[1]}`, ";border-color:", ({
74
- theme
75
- }) => theme.colors.primary.border, ";}" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["/home/runner/work/ultraviolet/ultraviolet/packages/ui/src/components/ExpandableCard/index.tsx"],"names":[],"mappings":"AAuEoC","file":"/home/runner/work/ultraviolet/ultraviolet/packages/ui/src/components/ExpandableCard/index.tsx","sourcesContent":["'use client'\n\nimport { useTheme } from '@emotion/react'\nimport styled from '@emotion/styled'\nimport { ArrowDownIcon, DragIcon } from '@ultraviolet/icons'\nimport type {\n  DetailsHTMLAttributes,\n  DragEvent,\n  ForwardedRef,\n  KeyboardEvent,\n  ReactNode,\n} from 'react'\nimport { forwardRef, useCallback, useRef, useState } from 'react'\nimport type { XOR } from '../../types'\nimport { Stack } from '../Stack'\nimport { Tooltip } from '../Tooltip'\nimport { ExpandableCardTitle } from './components/Title'\n\nconst StyledArrowIcon = styled(ArrowDownIcon)``\n\nconst DropableArea = styled.div`\n  height: ${({ theme }) => theme.space['3']};\n  border-bottom: 2px solid;\n  border-color: transparent;\n  padding: ${({ theme }) => theme.space['0.5']} 0;\n  width: 100%;\n  bottom: -5px;\n  position: absolute;\n\n  &[data-first=\"true\"] {\n    top: -${({ theme }) => theme.space['3']};\n  }\n\n  &::after {\n    content: '';\n    left: 0;\n    bottom: -4px;\n    height: 0px;\n    width: 0px;\n    border: 3px solid;\n    border-color: inherit;\n    border-radius: ${({ theme }) => theme.radii.circle};\n    display: flex;\n    margin-top:  -${({ theme }) => theme.space['1']};\n    margin-left: -${({ theme }) => theme.space['0.25']};\n    position: absolute;\n  }\n`\n\nconst StyledSummary = styled.summary`\n  display: flex;\n  flex-direction: row;\n  align-items: center;\n  gap:  ${({ theme }) => theme.space['2']};\n  padding: ${({ theme }) => theme.space['3']};\n  list-style-type: none;\n\n  cursor: pointer;\n  &[data-disabled=\"true\"] {\n    background: ${({ theme }) => theme.colors.neutral.backgroundWeak};\n    border-radius: ${({ theme }) => theme.radii.default};\n    cursor: not-allowed;\n  }\n`\n\nconst StyledContent = styled.div`\n  border-top: 1px solid ${({ theme }) => theme.colors.neutral.border};\n  padding: ${({ theme }) => theme.space['3']};\n\n`\n\nconst StyledDetails = styled.details`\n  border: 1px solid ${({ theme }) => theme.colors.neutral.border};\n  border-radius: ${({ theme }) => theme.radii.default};\n  width: 100%;\n  transition: border-color 0.2s ease-in-out;\n\n  &[open] {\n    border-color: ${({ theme }) => theme.colors.primary.border};\n\n    & > ${StyledContent} {\n      border-color: ${({ theme }) => theme.colors.primary.border};\n    }\n\n   ${StyledArrowIcon} {\n      transform: rotate(180deg);\n    }\n  }\n\n  &[data-clicking=\"true\"] {\n    box-shadow: ${({ theme }) => `${theme.shadows.raised[0]}, ${theme.shadows.raised[1]}`};\n    border-color: ${({ theme }) => theme.colors.primary.border};\n\n  }\n`\nconst StyledStack = styled(Stack)`\n  position: relative;\n    &:hover > ${StyledDetails} {\n      border-color: ${({ theme }) => theme.colors.primary.border};\n    }\n  `\n\nconst DragIconContainer = styled(Stack)`\n  height: 100%;\n  opacity: 0;\n  transition: opacity 0.2s ease-in-out;\n  cursor: grab;\n  padding-top: calc(${({ theme }) => theme.space['3']} + 2px);\n\n  &[data-visible=\"true\"] {\n    opacity: 1;\n  }\n  &:focus-within {\n    opacity: 1;\n  }\n\n  &:active {\n    cursor: grabbing;\n    opacity: 1;\n  }\n`\n\nexport const EXPANDABLE_CARD_SIZE = ['medium', 'large'] as const\n\ntype DraggableListType = { value?: string }\ntype ExpandableCardSize = (typeof EXPANDABLE_CARD_SIZE)[number]\n\ntype DraggableProps =\n  | {\n      draggable: true\n      value: string\n      draggableTooltip?: string\n      onDrop?: (newValue: string, oldValue: string) => void\n      /**\n       * Index of the card in the  of draggable cards\n       */\n      index: number\n      /**\n       * You this prop to handle drag and drop with the keyboard (accessibility)\n       */\n      onKeyDown?: (event: KeyboardEvent<HTMLDivElement>) => void\n    }\n  | {\n      draggable?: never\n      value?: never\n      draggableTooltip?: never\n      onDrop?: never\n      index?: never\n      onKeyDown?: never\n    }\ntype CommonProps = {\n  header: ReactNode\n  size?: ExpandableCardSize\n  name?: string\n  children: ReactNode\n  disabled?: boolean\n  'data-testid'?: string\n  className?: string\n  /** Uncontrolled but open by default */\n  open?: DetailsHTMLAttributes<HTMLDetailsElement>['open']\n} & DraggableProps\n\ntype ExpandableCardProps = XOR<\n  [CommonProps & { expanded: boolean; onToggleExpand: () => void }, CommonProps]\n>\nconst BaseExpandableCard = forwardRef(\n  (\n    {\n      header,\n      name,\n      size = 'medium',\n      children,\n      disabled,\n      expanded,\n      onToggleExpand,\n      className,\n      draggable,\n      value,\n      draggableTooltip = 'Click and drag to move',\n      onDrop,\n      index,\n      onKeyDown,\n      'data-testid': dataTestId,\n      open,\n    }: ExpandableCardProps,\n    ref: ForwardedRef<HTMLDetailsElement>,\n  ) => {\n    const headerRef = useRef<HTMLDivElement>(null)\n    const containerRef = useRef<HTMLDivElement>(null)\n    const draggableRef = useRef<HTMLDivElement>(null)\n    const draggableFirstRef = useRef<HTMLDivElement>(null)\n    const [isHovered, setIsHovered] = useState(false)\n    const [clicking, setClicking] = useState(false)\n\n    const theme = useTheme()\n\n    const handleMouseEnter = () => {\n      setIsHovered(true)\n    }\n    const handleMouseLeave = () => {\n      setIsHovered(false)\n    }\n\n    const onDragStart = useCallback(\n      (event: DragEvent<HTMLDivElement>) => {\n        event.dataTransfer.setData('text/plain', JSON.stringify({ value }))\n      },\n      [value],\n    )\n\n    const onDragEnd = useCallback(() => setClicking(false), [])\n\n    const onDrag = useCallback(\n      (\n        event: DragEvent<HTMLDivElement>,\n        borderColor: string,\n        isFirst?: boolean,\n      ) => {\n        const refElement = isFirst ? draggableFirstRef : draggableRef\n        event.preventDefault()\n        if (refElement.current) {\n          refElement.current.style.borderColor = borderColor\n        }\n      },\n      [],\n    )\n\n    const handleDrop = useCallback(\n      (event: DragEvent<HTMLDivElement>, isFirst?: boolean) => {\n        event.preventDefault()\n        if (draggableRef.current) {\n          draggableRef.current.style.borderColor = 'transparent'\n        }\n\n        if (event?.dataTransfer) {\n          const data = JSON.parse(\n            event.dataTransfer.getData('text'),\n          ) as DraggableListType\n\n          onDrop?.(isFirst ? '' : value, data.value ?? '')\n        }\n      },\n      [onDrop, value],\n    )\n\n    return (\n      <StyledStack\n        data-draggable={draggable}\n        data-name={name}\n        data-value={value}\n        direction=\"row\"\n        draggable={draggable}\n        gap={2}\n        onDragEnd={onDragEnd}\n        onDragStart={onDragStart}\n        onMouseEnter={handleMouseEnter}\n        onMouseLeave={handleMouseLeave}\n        ref={containerRef}\n        width=\"100%\"\n      >\n        {draggable ? (\n          <DragIconContainer\n            data-testid={`draggable-icon-${value}`}\n            data-visible={isHovered}\n            justifyContent=\"center\"\n            onKeyDown={(event: KeyboardEvent<HTMLDivElement>) => {\n              if (event.key === 'Enter' || event.key === ' ') {\n                event.preventDefault()\n                if (clicking && containerRef.current) {\n                  setClicking(false)\n                  setIsHovered(false)\n                } else if (containerRef.current) {\n                  setClicking(true)\n                  setIsHovered(true)\n                }\n              }\n              if (clicking) {\n                onKeyDown?.(event)\n              }\n            }}\n            onMouseDown={() => setClicking(true)}\n            onMouseUp={() => setClicking(false)}\n          >\n            <Tooltip\n              text={draggableTooltip}\n              visible={clicking ? false : undefined} // Hide the tooltip when dragging the card\n            >\n              <DragIcon\n                disabled={disabled}\n                prominence={clicking ? 'strong' : 'weak'}\n                sentiment=\"neutral\"\n                size=\"small\"\n              />\n            </Tooltip>\n          </DragIconContainer>\n        ) : null}\n        <StyledDetails\n          className={className}\n          data-clicking={clicking}\n          data-testid={dataTestId}\n          key={clicking ? 'closed' : 'open'}\n          name={name}\n          open={open ?? expanded}\n          ref={ref}\n          tabIndex={disabled ? -1 : undefined}\n        >\n          <StyledSummary\n            data-disabled={!!disabled}\n            data-testid={dataTestId ? `${dataTestId}-summary` : undefined}\n            onClick={event => {\n              if (disabled || onToggleExpand) {\n                onToggleExpand?.()\n                event.preventDefault()\n              }\n            }}\n            onKeyDown={\n              onToggleExpand\n                ? event => {\n                    if (\n                      event.key === ' ' &&\n                      event.target === headerRef.current\n                    ) {\n                      onToggleExpand()\n                      event.preventDefault()\n                    }\n                  }\n                : undefined\n            }\n            ref={headerRef}\n          >\n            <StyledArrowIcon disabled={disabled} sentiment=\"neutral\" />\n            {typeof header === 'string' ? (\n              <ExpandableCardTitle disabled={disabled} size={size}>\n                {header}\n              </ExpandableCardTitle>\n            ) : (\n              header\n            )}\n          </StyledSummary>\n          <StyledContent>{children}</StyledContent>\n        </StyledDetails>\n        {draggable && index === 0 ? (\n          <DropableArea\n            data-first\n            onDragLeave={event => onDrag(event, 'transparent', true)}\n            onDragOver={event =>\n              onDrag(event, theme.colors.primary.border, true)\n            }\n            onDrop={event => handleDrop(event, true)}\n            ref={draggableFirstRef}\n          />\n        ) : null}\n        {draggable ? (\n          <DropableArea\n            data-testid={`${value}-dropable-area`}\n            onDragLeave={event => onDrag(event, 'transparent')}\n            onDragOver={event => onDrag(event, theme.colors.primary.border)}\n            onDrop={handleDrop}\n            ref={draggableRef}\n          />\n        ) : null}\n      </StyledStack>\n    )\n  },\n)\n\n// /**\n//  * ExpandableCard is a card that can be collapsed and expanded to reveal more content.\n//  */\nexport const ExpandableCard = Object.assign(BaseExpandableCard, {\n  Title: ExpandableCardTitle,\n})\n"]} */"));
76
- const StyledStack = /* @__PURE__ */ _styled(Stack, process.env.NODE_ENV === "production" ? {
77
- target: "e143cpd61"
78
- } : {
79
- target: "e143cpd61",
80
- label: "StyledStack"
81
- })("position:relative;&:hover>", StyledDetails, "{border-color:", ({
82
- theme
83
- }) => theme.colors.primary.border, ";}" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["/home/runner/work/ultraviolet/ultraviolet/packages/ui/src/components/ExpandableCard/index.tsx"],"names":[],"mappings":"AA+FiC","file":"/home/runner/work/ultraviolet/ultraviolet/packages/ui/src/components/ExpandableCard/index.tsx","sourcesContent":["'use client'\n\nimport { useTheme } from '@emotion/react'\nimport styled from '@emotion/styled'\nimport { ArrowDownIcon, DragIcon } from '@ultraviolet/icons'\nimport type {\n  DetailsHTMLAttributes,\n  DragEvent,\n  ForwardedRef,\n  KeyboardEvent,\n  ReactNode,\n} from 'react'\nimport { forwardRef, useCallback, useRef, useState } from 'react'\nimport type { XOR } from '../../types'\nimport { Stack } from '../Stack'\nimport { Tooltip } from '../Tooltip'\nimport { ExpandableCardTitle } from './components/Title'\n\nconst StyledArrowIcon = styled(ArrowDownIcon)``\n\nconst DropableArea = styled.div`\n  height: ${({ theme }) => theme.space['3']};\n  border-bottom: 2px solid;\n  border-color: transparent;\n  padding: ${({ theme }) => theme.space['0.5']} 0;\n  width: 100%;\n  bottom: -5px;\n  position: absolute;\n\n  &[data-first=\"true\"] {\n    top: -${({ theme }) => theme.space['3']};\n  }\n\n  &::after {\n    content: '';\n    left: 0;\n    bottom: -4px;\n    height: 0px;\n    width: 0px;\n    border: 3px solid;\n    border-color: inherit;\n    border-radius: ${({ theme }) => theme.radii.circle};\n    display: flex;\n    margin-top:  -${({ theme }) => theme.space['1']};\n    margin-left: -${({ theme }) => theme.space['0.25']};\n    position: absolute;\n  }\n`\n\nconst StyledSummary = styled.summary`\n  display: flex;\n  flex-direction: row;\n  align-items: center;\n  gap:  ${({ theme }) => theme.space['2']};\n  padding: ${({ theme }) => theme.space['3']};\n  list-style-type: none;\n\n  cursor: pointer;\n  &[data-disabled=\"true\"] {\n    background: ${({ theme }) => theme.colors.neutral.backgroundWeak};\n    border-radius: ${({ theme }) => theme.radii.default};\n    cursor: not-allowed;\n  }\n`\n\nconst StyledContent = styled.div`\n  border-top: 1px solid ${({ theme }) => theme.colors.neutral.border};\n  padding: ${({ theme }) => theme.space['3']};\n\n`\n\nconst StyledDetails = styled.details`\n  border: 1px solid ${({ theme }) => theme.colors.neutral.border};\n  border-radius: ${({ theme }) => theme.radii.default};\n  width: 100%;\n  transition: border-color 0.2s ease-in-out;\n\n  &[open] {\n    border-color: ${({ theme }) => theme.colors.primary.border};\n\n    & > ${StyledContent} {\n      border-color: ${({ theme }) => theme.colors.primary.border};\n    }\n\n   ${StyledArrowIcon} {\n      transform: rotate(180deg);\n    }\n  }\n\n  &[data-clicking=\"true\"] {\n    box-shadow: ${({ theme }) => `${theme.shadows.raised[0]}, ${theme.shadows.raised[1]}`};\n    border-color: ${({ theme }) => theme.colors.primary.border};\n\n  }\n`\nconst StyledStack = styled(Stack)`\n  position: relative;\n    &:hover > ${StyledDetails} {\n      border-color: ${({ theme }) => theme.colors.primary.border};\n    }\n  `\n\nconst DragIconContainer = styled(Stack)`\n  height: 100%;\n  opacity: 0;\n  transition: opacity 0.2s ease-in-out;\n  cursor: grab;\n  padding-top: calc(${({ theme }) => theme.space['3']} + 2px);\n\n  &[data-visible=\"true\"] {\n    opacity: 1;\n  }\n  &:focus-within {\n    opacity: 1;\n  }\n\n  &:active {\n    cursor: grabbing;\n    opacity: 1;\n  }\n`\n\nexport const EXPANDABLE_CARD_SIZE = ['medium', 'large'] as const\n\ntype DraggableListType = { value?: string }\ntype ExpandableCardSize = (typeof EXPANDABLE_CARD_SIZE)[number]\n\ntype DraggableProps =\n  | {\n      draggable: true\n      value: string\n      draggableTooltip?: string\n      onDrop?: (newValue: string, oldValue: string) => void\n      /**\n       * Index of the card in the  of draggable cards\n       */\n      index: number\n      /**\n       * You this prop to handle drag and drop with the keyboard (accessibility)\n       */\n      onKeyDown?: (event: KeyboardEvent<HTMLDivElement>) => void\n    }\n  | {\n      draggable?: never\n      value?: never\n      draggableTooltip?: never\n      onDrop?: never\n      index?: never\n      onKeyDown?: never\n    }\ntype CommonProps = {\n  header: ReactNode\n  size?: ExpandableCardSize\n  name?: string\n  children: ReactNode\n  disabled?: boolean\n  'data-testid'?: string\n  className?: string\n  /** Uncontrolled but open by default */\n  open?: DetailsHTMLAttributes<HTMLDetailsElement>['open']\n} & DraggableProps\n\ntype ExpandableCardProps = XOR<\n  [CommonProps & { expanded: boolean; onToggleExpand: () => void }, CommonProps]\n>\nconst BaseExpandableCard = forwardRef(\n  (\n    {\n      header,\n      name,\n      size = 'medium',\n      children,\n      disabled,\n      expanded,\n      onToggleExpand,\n      className,\n      draggable,\n      value,\n      draggableTooltip = 'Click and drag to move',\n      onDrop,\n      index,\n      onKeyDown,\n      'data-testid': dataTestId,\n      open,\n    }: ExpandableCardProps,\n    ref: ForwardedRef<HTMLDetailsElement>,\n  ) => {\n    const headerRef = useRef<HTMLDivElement>(null)\n    const containerRef = useRef<HTMLDivElement>(null)\n    const draggableRef = useRef<HTMLDivElement>(null)\n    const draggableFirstRef = useRef<HTMLDivElement>(null)\n    const [isHovered, setIsHovered] = useState(false)\n    const [clicking, setClicking] = useState(false)\n\n    const theme = useTheme()\n\n    const handleMouseEnter = () => {\n      setIsHovered(true)\n    }\n    const handleMouseLeave = () => {\n      setIsHovered(false)\n    }\n\n    const onDragStart = useCallback(\n      (event: DragEvent<HTMLDivElement>) => {\n        event.dataTransfer.setData('text/plain', JSON.stringify({ value }))\n      },\n      [value],\n    )\n\n    const onDragEnd = useCallback(() => setClicking(false), [])\n\n    const onDrag = useCallback(\n      (\n        event: DragEvent<HTMLDivElement>,\n        borderColor: string,\n        isFirst?: boolean,\n      ) => {\n        const refElement = isFirst ? draggableFirstRef : draggableRef\n        event.preventDefault()\n        if (refElement.current) {\n          refElement.current.style.borderColor = borderColor\n        }\n      },\n      [],\n    )\n\n    const handleDrop = useCallback(\n      (event: DragEvent<HTMLDivElement>, isFirst?: boolean) => {\n        event.preventDefault()\n        if (draggableRef.current) {\n          draggableRef.current.style.borderColor = 'transparent'\n        }\n\n        if (event?.dataTransfer) {\n          const data = JSON.parse(\n            event.dataTransfer.getData('text'),\n          ) as DraggableListType\n\n          onDrop?.(isFirst ? '' : value, data.value ?? '')\n        }\n      },\n      [onDrop, value],\n    )\n\n    return (\n      <StyledStack\n        data-draggable={draggable}\n        data-name={name}\n        data-value={value}\n        direction=\"row\"\n        draggable={draggable}\n        gap={2}\n        onDragEnd={onDragEnd}\n        onDragStart={onDragStart}\n        onMouseEnter={handleMouseEnter}\n        onMouseLeave={handleMouseLeave}\n        ref={containerRef}\n        width=\"100%\"\n      >\n        {draggable ? (\n          <DragIconContainer\n            data-testid={`draggable-icon-${value}`}\n            data-visible={isHovered}\n            justifyContent=\"center\"\n            onKeyDown={(event: KeyboardEvent<HTMLDivElement>) => {\n              if (event.key === 'Enter' || event.key === ' ') {\n                event.preventDefault()\n                if (clicking && containerRef.current) {\n                  setClicking(false)\n                  setIsHovered(false)\n                } else if (containerRef.current) {\n                  setClicking(true)\n                  setIsHovered(true)\n                }\n              }\n              if (clicking) {\n                onKeyDown?.(event)\n              }\n            }}\n            onMouseDown={() => setClicking(true)}\n            onMouseUp={() => setClicking(false)}\n          >\n            <Tooltip\n              text={draggableTooltip}\n              visible={clicking ? false : undefined} // Hide the tooltip when dragging the card\n            >\n              <DragIcon\n                disabled={disabled}\n                prominence={clicking ? 'strong' : 'weak'}\n                sentiment=\"neutral\"\n                size=\"small\"\n              />\n            </Tooltip>\n          </DragIconContainer>\n        ) : null}\n        <StyledDetails\n          className={className}\n          data-clicking={clicking}\n          data-testid={dataTestId}\n          key={clicking ? 'closed' : 'open'}\n          name={name}\n          open={open ?? expanded}\n          ref={ref}\n          tabIndex={disabled ? -1 : undefined}\n        >\n          <StyledSummary\n            data-disabled={!!disabled}\n            data-testid={dataTestId ? `${dataTestId}-summary` : undefined}\n            onClick={event => {\n              if (disabled || onToggleExpand) {\n                onToggleExpand?.()\n                event.preventDefault()\n              }\n            }}\n            onKeyDown={\n              onToggleExpand\n                ? event => {\n                    if (\n                      event.key === ' ' &&\n                      event.target === headerRef.current\n                    ) {\n                      onToggleExpand()\n                      event.preventDefault()\n                    }\n                  }\n                : undefined\n            }\n            ref={headerRef}\n          >\n            <StyledArrowIcon disabled={disabled} sentiment=\"neutral\" />\n            {typeof header === 'string' ? (\n              <ExpandableCardTitle disabled={disabled} size={size}>\n                {header}\n              </ExpandableCardTitle>\n            ) : (\n              header\n            )}\n          </StyledSummary>\n          <StyledContent>{children}</StyledContent>\n        </StyledDetails>\n        {draggable && index === 0 ? (\n          <DropableArea\n            data-first\n            onDragLeave={event => onDrag(event, 'transparent', true)}\n            onDragOver={event =>\n              onDrag(event, theme.colors.primary.border, true)\n            }\n            onDrop={event => handleDrop(event, true)}\n            ref={draggableFirstRef}\n          />\n        ) : null}\n        {draggable ? (\n          <DropableArea\n            data-testid={`${value}-dropable-area`}\n            onDragLeave={event => onDrag(event, 'transparent')}\n            onDragOver={event => onDrag(event, theme.colors.primary.border)}\n            onDrop={handleDrop}\n            ref={draggableRef}\n          />\n        ) : null}\n      </StyledStack>\n    )\n  },\n)\n\n// /**\n//  * ExpandableCard is a card that can be collapsed and expanded to reveal more content.\n//  */\nexport const ExpandableCard = Object.assign(BaseExpandableCard, {\n  Title: ExpandableCardTitle,\n})\n"]} */"));
84
- const DragIconContainer = /* @__PURE__ */ _styled(Stack, process.env.NODE_ENV === "production" ? {
85
- target: "e143cpd60"
86
- } : {
87
- target: "e143cpd60",
88
- label: "DragIconContainer"
89
- })("height:100%;opacity:0;transition:opacity 0.2s ease-in-out;cursor:grab;padding-top:calc(", ({
90
- theme
91
- }) => theme.space["3"], ' + 2px);&[data-visible="true"]{opacity:1;}&:focus-within{opacity:1;}&:active{cursor:grabbing;opacity:1;}' + (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/ExpandableCard/index.tsx"],"names":[],"mappings":"AAsGuC","file":"/home/runner/work/ultraviolet/ultraviolet/packages/ui/src/components/ExpandableCard/index.tsx","sourcesContent":["'use client'\n\nimport { useTheme } from '@emotion/react'\nimport styled from '@emotion/styled'\nimport { ArrowDownIcon, DragIcon } from '@ultraviolet/icons'\nimport type {\n  DetailsHTMLAttributes,\n  DragEvent,\n  ForwardedRef,\n  KeyboardEvent,\n  ReactNode,\n} from 'react'\nimport { forwardRef, useCallback, useRef, useState } from 'react'\nimport type { XOR } from '../../types'\nimport { Stack } from '../Stack'\nimport { Tooltip } from '../Tooltip'\nimport { ExpandableCardTitle } from './components/Title'\n\nconst StyledArrowIcon = styled(ArrowDownIcon)``\n\nconst DropableArea = styled.div`\n  height: ${({ theme }) => theme.space['3']};\n  border-bottom: 2px solid;\n  border-color: transparent;\n  padding: ${({ theme }) => theme.space['0.5']} 0;\n  width: 100%;\n  bottom: -5px;\n  position: absolute;\n\n  &[data-first=\"true\"] {\n    top: -${({ theme }) => theme.space['3']};\n  }\n\n  &::after {\n    content: '';\n    left: 0;\n    bottom: -4px;\n    height: 0px;\n    width: 0px;\n    border: 3px solid;\n    border-color: inherit;\n    border-radius: ${({ theme }) => theme.radii.circle};\n    display: flex;\n    margin-top:  -${({ theme }) => theme.space['1']};\n    margin-left: -${({ theme }) => theme.space['0.25']};\n    position: absolute;\n  }\n`\n\nconst StyledSummary = styled.summary`\n  display: flex;\n  flex-direction: row;\n  align-items: center;\n  gap:  ${({ theme }) => theme.space['2']};\n  padding: ${({ theme }) => theme.space['3']};\n  list-style-type: none;\n\n  cursor: pointer;\n  &[data-disabled=\"true\"] {\n    background: ${({ theme }) => theme.colors.neutral.backgroundWeak};\n    border-radius: ${({ theme }) => theme.radii.default};\n    cursor: not-allowed;\n  }\n`\n\nconst StyledContent = styled.div`\n  border-top: 1px solid ${({ theme }) => theme.colors.neutral.border};\n  padding: ${({ theme }) => theme.space['3']};\n\n`\n\nconst StyledDetails = styled.details`\n  border: 1px solid ${({ theme }) => theme.colors.neutral.border};\n  border-radius: ${({ theme }) => theme.radii.default};\n  width: 100%;\n  transition: border-color 0.2s ease-in-out;\n\n  &[open] {\n    border-color: ${({ theme }) => theme.colors.primary.border};\n\n    & > ${StyledContent} {\n      border-color: ${({ theme }) => theme.colors.primary.border};\n    }\n\n   ${StyledArrowIcon} {\n      transform: rotate(180deg);\n    }\n  }\n\n  &[data-clicking=\"true\"] {\n    box-shadow: ${({ theme }) => `${theme.shadows.raised[0]}, ${theme.shadows.raised[1]}`};\n    border-color: ${({ theme }) => theme.colors.primary.border};\n\n  }\n`\nconst StyledStack = styled(Stack)`\n  position: relative;\n    &:hover > ${StyledDetails} {\n      border-color: ${({ theme }) => theme.colors.primary.border};\n    }\n  `\n\nconst DragIconContainer = styled(Stack)`\n  height: 100%;\n  opacity: 0;\n  transition: opacity 0.2s ease-in-out;\n  cursor: grab;\n  padding-top: calc(${({ theme }) => theme.space['3']} + 2px);\n\n  &[data-visible=\"true\"] {\n    opacity: 1;\n  }\n  &:focus-within {\n    opacity: 1;\n  }\n\n  &:active {\n    cursor: grabbing;\n    opacity: 1;\n  }\n`\n\nexport const EXPANDABLE_CARD_SIZE = ['medium', 'large'] as const\n\ntype DraggableListType = { value?: string }\ntype ExpandableCardSize = (typeof EXPANDABLE_CARD_SIZE)[number]\n\ntype DraggableProps =\n  | {\n      draggable: true\n      value: string\n      draggableTooltip?: string\n      onDrop?: (newValue: string, oldValue: string) => void\n      /**\n       * Index of the card in the  of draggable cards\n       */\n      index: number\n      /**\n       * You this prop to handle drag and drop with the keyboard (accessibility)\n       */\n      onKeyDown?: (event: KeyboardEvent<HTMLDivElement>) => void\n    }\n  | {\n      draggable?: never\n      value?: never\n      draggableTooltip?: never\n      onDrop?: never\n      index?: never\n      onKeyDown?: never\n    }\ntype CommonProps = {\n  header: ReactNode\n  size?: ExpandableCardSize\n  name?: string\n  children: ReactNode\n  disabled?: boolean\n  'data-testid'?: string\n  className?: string\n  /** Uncontrolled but open by default */\n  open?: DetailsHTMLAttributes<HTMLDetailsElement>['open']\n} & DraggableProps\n\ntype ExpandableCardProps = XOR<\n  [CommonProps & { expanded: boolean; onToggleExpand: () => void }, CommonProps]\n>\nconst BaseExpandableCard = forwardRef(\n  (\n    {\n      header,\n      name,\n      size = 'medium',\n      children,\n      disabled,\n      expanded,\n      onToggleExpand,\n      className,\n      draggable,\n      value,\n      draggableTooltip = 'Click and drag to move',\n      onDrop,\n      index,\n      onKeyDown,\n      'data-testid': dataTestId,\n      open,\n    }: ExpandableCardProps,\n    ref: ForwardedRef<HTMLDetailsElement>,\n  ) => {\n    const headerRef = useRef<HTMLDivElement>(null)\n    const containerRef = useRef<HTMLDivElement>(null)\n    const draggableRef = useRef<HTMLDivElement>(null)\n    const draggableFirstRef = useRef<HTMLDivElement>(null)\n    const [isHovered, setIsHovered] = useState(false)\n    const [clicking, setClicking] = useState(false)\n\n    const theme = useTheme()\n\n    const handleMouseEnter = () => {\n      setIsHovered(true)\n    }\n    const handleMouseLeave = () => {\n      setIsHovered(false)\n    }\n\n    const onDragStart = useCallback(\n      (event: DragEvent<HTMLDivElement>) => {\n        event.dataTransfer.setData('text/plain', JSON.stringify({ value }))\n      },\n      [value],\n    )\n\n    const onDragEnd = useCallback(() => setClicking(false), [])\n\n    const onDrag = useCallback(\n      (\n        event: DragEvent<HTMLDivElement>,\n        borderColor: string,\n        isFirst?: boolean,\n      ) => {\n        const refElement = isFirst ? draggableFirstRef : draggableRef\n        event.preventDefault()\n        if (refElement.current) {\n          refElement.current.style.borderColor = borderColor\n        }\n      },\n      [],\n    )\n\n    const handleDrop = useCallback(\n      (event: DragEvent<HTMLDivElement>, isFirst?: boolean) => {\n        event.preventDefault()\n        if (draggableRef.current) {\n          draggableRef.current.style.borderColor = 'transparent'\n        }\n\n        if (event?.dataTransfer) {\n          const data = JSON.parse(\n            event.dataTransfer.getData('text'),\n          ) as DraggableListType\n\n          onDrop?.(isFirst ? '' : value, data.value ?? '')\n        }\n      },\n      [onDrop, value],\n    )\n\n    return (\n      <StyledStack\n        data-draggable={draggable}\n        data-name={name}\n        data-value={value}\n        direction=\"row\"\n        draggable={draggable}\n        gap={2}\n        onDragEnd={onDragEnd}\n        onDragStart={onDragStart}\n        onMouseEnter={handleMouseEnter}\n        onMouseLeave={handleMouseLeave}\n        ref={containerRef}\n        width=\"100%\"\n      >\n        {draggable ? (\n          <DragIconContainer\n            data-testid={`draggable-icon-${value}`}\n            data-visible={isHovered}\n            justifyContent=\"center\"\n            onKeyDown={(event: KeyboardEvent<HTMLDivElement>) => {\n              if (event.key === 'Enter' || event.key === ' ') {\n                event.preventDefault()\n                if (clicking && containerRef.current) {\n                  setClicking(false)\n                  setIsHovered(false)\n                } else if (containerRef.current) {\n                  setClicking(true)\n                  setIsHovered(true)\n                }\n              }\n              if (clicking) {\n                onKeyDown?.(event)\n              }\n            }}\n            onMouseDown={() => setClicking(true)}\n            onMouseUp={() => setClicking(false)}\n          >\n            <Tooltip\n              text={draggableTooltip}\n              visible={clicking ? false : undefined} // Hide the tooltip when dragging the card\n            >\n              <DragIcon\n                disabled={disabled}\n                prominence={clicking ? 'strong' : 'weak'}\n                sentiment=\"neutral\"\n                size=\"small\"\n              />\n            </Tooltip>\n          </DragIconContainer>\n        ) : null}\n        <StyledDetails\n          className={className}\n          data-clicking={clicking}\n          data-testid={dataTestId}\n          key={clicking ? 'closed' : 'open'}\n          name={name}\n          open={open ?? expanded}\n          ref={ref}\n          tabIndex={disabled ? -1 : undefined}\n        >\n          <StyledSummary\n            data-disabled={!!disabled}\n            data-testid={dataTestId ? `${dataTestId}-summary` : undefined}\n            onClick={event => {\n              if (disabled || onToggleExpand) {\n                onToggleExpand?.()\n                event.preventDefault()\n              }\n            }}\n            onKeyDown={\n              onToggleExpand\n                ? event => {\n                    if (\n                      event.key === ' ' &&\n                      event.target === headerRef.current\n                    ) {\n                      onToggleExpand()\n                      event.preventDefault()\n                    }\n                  }\n                : undefined\n            }\n            ref={headerRef}\n          >\n            <StyledArrowIcon disabled={disabled} sentiment=\"neutral\" />\n            {typeof header === 'string' ? (\n              <ExpandableCardTitle disabled={disabled} size={size}>\n                {header}\n              </ExpandableCardTitle>\n            ) : (\n              header\n            )}\n          </StyledSummary>\n          <StyledContent>{children}</StyledContent>\n        </StyledDetails>\n        {draggable && index === 0 ? (\n          <DropableArea\n            data-first\n            onDragLeave={event => onDrag(event, 'transparent', true)}\n            onDragOver={event =>\n              onDrag(event, theme.colors.primary.border, true)\n            }\n            onDrop={event => handleDrop(event, true)}\n            ref={draggableFirstRef}\n          />\n        ) : null}\n        {draggable ? (\n          <DropableArea\n            data-testid={`${value}-dropable-area`}\n            onDragLeave={event => onDrag(event, 'transparent')}\n            onDragOver={event => onDrag(event, theme.colors.primary.border)}\n            onDrop={handleDrop}\n            ref={draggableRef}\n          />\n        ) : null}\n      </StyledStack>\n    )\n  },\n)\n\n// /**\n//  * ExpandableCard is a card that can be collapsed and expanded to reveal more content.\n//  */\nexport const ExpandableCard = Object.assign(BaseExpandableCard, {\n  Title: ExpandableCardTitle,\n})\n"]} */"));
9
+ import { stackClass, dragIconContainer, detailsClass, summaryClass, arrowIcon, content, dropableArea } from "./styles.css.js";
92
10
  const BaseExpandableCard = forwardRef(({
93
11
  header,
94
12
  name,
@@ -143,8 +61,8 @@ const BaseExpandableCard = forwardRef(({
143
61
  onDrop?.(isFirst ? "" : value, data.value ?? "");
144
62
  }
145
63
  }, [onDrop, value]);
146
- return /* @__PURE__ */ jsxs(StyledStack, { "data-draggable": draggable, "data-name": name, "data-value": value, direction: "row", draggable, gap: 2, onDragEnd, onDragStart, onMouseEnter: handleMouseEnter, onMouseLeave: handleMouseLeave, ref: containerRef, width: "100%", children: [
147
- draggable ? /* @__PURE__ */ jsx(DragIconContainer, { "data-testid": `draggable-icon-${value}`, "data-visible": isHovered, justifyContent: "center", onKeyDown: (event) => {
64
+ return /* @__PURE__ */ jsxs(Stack, { className: stackClass, "data-draggable": draggable, "data-name": name, "data-value": value, direction: "row", draggable, gap: 2, onDragEnd, onDragStart, onMouseEnter: handleMouseEnter, onMouseLeave: handleMouseLeave, ref: containerRef, width: "100%", children: [
65
+ draggable ? /* @__PURE__ */ jsx(Stack, { className: dragIconContainer, "data-testid": `draggable-icon-${value}`, "data-visible": isHovered, justifyContent: "center", onKeyDown: (event) => {
148
66
  if (event.key === "Enter" || event.key === " ") {
149
67
  event.preventDefault();
150
68
  if (clicking && containerRef.current) {
@@ -166,8 +84,8 @@ const BaseExpandableCard = forwardRef(({
166
84
  children: /* @__PURE__ */ jsx(DragIcon, { disabled, prominence: clicking ? "strong" : "weak", sentiment: "neutral", size: "small" })
167
85
  }
168
86
  ) }) : null,
169
- /* @__PURE__ */ jsxs(StyledDetails, { className, "data-clicking": clicking, "data-testid": dataTestId, name, open: open ?? expanded, ref, tabIndex: disabled ? -1 : void 0, children: [
170
- /* @__PURE__ */ jsxs(StyledSummary, { "data-disabled": !!disabled, "data-testid": dataTestId ? `${dataTestId}-summary` : void 0, onClick: (event) => {
87
+ /* @__PURE__ */ jsxs("details", { className: `${className ? `${className} ` : ""}${detailsClass}`, "data-clicking": clicking, "data-testid": dataTestId, name, open: open ?? expanded, ref, tabIndex: disabled ? -1 : void 0, children: [
88
+ /* @__PURE__ */ jsxs("summary", { className: summaryClass, "data-disabled": !!disabled, "data-testid": dataTestId ? `${dataTestId}-summary` : void 0, onClick: (event) => {
171
89
  if (disabled || onToggleExpand) {
172
90
  onToggleExpand?.();
173
91
  event.preventDefault();
@@ -178,13 +96,13 @@ const BaseExpandableCard = forwardRef(({
178
96
  event.preventDefault();
179
97
  }
180
98
  } : void 0, ref: headerRef, children: [
181
- /* @__PURE__ */ jsx(StyledArrowIcon, { disabled, sentiment: "neutral" }),
99
+ /* @__PURE__ */ jsx(ArrowDownIcon, { className: arrowIcon, disabled, sentiment: "neutral" }),
182
100
  typeof header === "string" ? /* @__PURE__ */ jsx(ExpandableCardTitle, { disabled, size, children: header }) : header
183
101
  ] }),
184
- /* @__PURE__ */ jsx(StyledContent, { children })
102
+ /* @__PURE__ */ jsx("div", { className: content, children })
185
103
  ] }, clicking ? "closed" : "open"),
186
- draggable && index === 0 ? /* @__PURE__ */ jsx(DropableArea, { "data-first": true, onDragLeave: (event) => onDrag(event, "transparent", true), onDragOver: (event) => onDrag(event, theme.colors.primary.border, true), onDrop: (event) => handleDrop(event, true), ref: draggableFirstRef }) : null,
187
- draggable ? /* @__PURE__ */ jsx(DropableArea, { "data-testid": `${value}-dropable-area`, onDragLeave: (event) => onDrag(event, "transparent"), onDragOver: (event) => onDrag(event, theme.colors.primary.border), onDrop: handleDrop, ref: draggableRef }) : null
104
+ draggable && index === 0 ? /* @__PURE__ */ jsx("div", { className: dropableArea, "data-first": true, onDragLeave: (event) => onDrag(event, "transparent", true), onDragOver: (event) => onDrag(event, theme.colors.primary.border, true), onDrop: (event) => handleDrop(event, true), ref: draggableFirstRef }) : null,
105
+ draggable ? /* @__PURE__ */ jsx("div", { className: dropableArea, "data-testid": `${value}-dropable-area`, onDragLeave: (event) => onDrag(event, "transparent"), onDragOver: (event) => onDrag(event, theme.colors.primary.border), onDrop: handleDrop, ref: draggableRef }) : null
188
106
  ] });
189
107
  });
190
108
  const ExpandableCard = Object.assign(BaseExpandableCard, {
@@ -0,0 +1,17 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, Symbol.toStringTag, { value: "Module" });
3
+ ;/* empty css */
4
+ var arrowIcon = "uv_jd0jfn0";
5
+ var dropableArea = "uv_jd0jfn1";
6
+ var summaryClass = "uv_jd0jfn2";
7
+ var content = "uv_jd0jfn3";
8
+ var detailsClass = "uv_jd0jfn4";
9
+ var stackClass = "uv_jd0jfn5";
10
+ var dragIconContainer = "uv_jd0jfn6";
11
+ exports.arrowIcon = arrowIcon;
12
+ exports.content = content;
13
+ exports.detailsClass = detailsClass;
14
+ exports.dragIconContainer = dragIconContainer;
15
+ exports.dropableArea = dropableArea;
16
+ exports.stackClass = stackClass;
17
+ exports.summaryClass = summaryClass;
@@ -0,0 +1,7 @@
1
+ export declare const arrowIcon: string;
2
+ export declare const dropableArea: string;
3
+ export declare const summaryClass: string;
4
+ export declare const content: string;
5
+ export declare const detailsClass: string;
6
+ export declare const stackClass: string;
7
+ export declare const dragIconContainer: string;
@@ -0,0 +1,17 @@
1
+ /* empty css */
2
+ var arrowIcon = "uv_jd0jfn0";
3
+ var dropableArea = "uv_jd0jfn1";
4
+ var summaryClass = "uv_jd0jfn2";
5
+ var content = "uv_jd0jfn3";
6
+ var detailsClass = "uv_jd0jfn4";
7
+ var stackClass = "uv_jd0jfn5";
8
+ var dragIconContainer = "uv_jd0jfn6";
9
+ export {
10
+ arrowIcon,
11
+ content,
12
+ detailsClass,
13
+ dragIconContainer,
14
+ dropableArea,
15
+ stackClass,
16
+ summaryClass
17
+ };
@@ -1,5 +1,6 @@
1
1
  "use strict";
2
2
  Object.defineProperty(exports, Symbol.toStringTag, { value: "Module" });
3
+ ;/* empty css */
3
4
  ;/* empty css */
4
5
  const createRuntimeFn = require("@vanilla-extract/recipes/createRuntimeFn");
5
6
  var containerPopup = createRuntimeFn.createRuntimeFn({ defaultClassName: "uv_w40vpo2", variantClassNames: { hasMaxHeight: { true: "uv_w40vpo3" } }, defaultVariants: {}, compoundVariants: [] });
@@ -1,3 +1,4 @@
1
+ /* empty css */
1
2
  /* empty css */
2
3
  import { createRuntimeFn } from "@vanilla-extract/recipes/createRuntimeFn";
3
4
  var containerPopup = createRuntimeFn({ defaultClassName: "uv_w40vpo2", variantClassNames: { hasMaxHeight: { true: "uv_w40vpo3" } }, defaultVariants: {}, compoundVariants: [] });
@@ -1,6 +1,5 @@
1
1
  "use strict";
2
2
  Object.defineProperty(exports, Symbol.toStringTag, { value: "Module" });
3
- ;/* empty css */
4
3
  var arrowTop = "var(--uv_ozfz3c0)";
5
4
  var arrowLeft = "var(--uv_ozfz3c1)";
6
5
  var arrowTransform = "var(--uv_ozfz3c2)";
@@ -1,4 +1,3 @@
1
- /* empty css */
2
1
  var arrowTop = "var(--uv_ozfz3c0)";
3
2
  var arrowLeft = "var(--uv_ozfz3c1)";
4
3
  var arrowTransform = "var(--uv_ozfz3c2)";
@@ -2,17 +2,12 @@
2
2
  "use strict";
3
3
  Object.defineProperty(exports, Symbol.toStringTag, { value: "Module" });
4
4
  const jsxRuntime = require("@emotion/react/jsx-runtime");
5
- const _styled = require("@emotion/styled/base");
6
5
  const react = require("react");
7
6
  const index$1 = require("../Label/index.cjs");
8
7
  const index$3 = require("../Radio/index.cjs");
9
8
  const index = require("../Stack/index.cjs");
10
9
  const index$2 = require("../Text/index.cjs");
11
- const _interopDefaultCompat = (e) => e && typeof e === "object" && "default" in e ? e : { default: e };
12
- const _styled__default = /* @__PURE__ */ _interopDefaultCompat(_styled);
13
- function _EMOTION_STRINGIFIED_CSS_ERROR__() {
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
- }
10
+ const styles_css = require("./styles.css.cjs");
16
11
  const RadioGroupContext = react.createContext(void 0);
17
12
  const RadioGroupRadio = ({
18
13
  onFocus,
@@ -40,19 +35,6 @@ const RadioGroupRadio = ({
40
35
  } = context;
41
36
  return /* @__PURE__ */ jsxRuntime.jsx(index$3.Radio, { autoFocus, checked: groupValue === value, className, "data-testid": dataTestId, disabled, error: error || errorContext, helper, label, name: groupName, onBlur, onChange, onFocus, onKeyDown, tooltip, value });
42
37
  };
43
- const FieldSet = /* @__PURE__ */ _styled__default.default("fieldset", process.env.NODE_ENV === "production" ? {
44
- target: "e15shfap0"
45
- } : {
46
- target: "e15shfap0",
47
- label: "FieldSet"
48
- })(process.env.NODE_ENV === "production" ? {
49
- name: "7o2an9",
50
- styles: "border:none;padding:0;margin:0"
51
- } : {
52
- name: "7o2an9",
53
- styles: "border:none;padding:0;margin:0/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi9ob21lL3J1bm5lci93b3JrL3VsdHJhdmlvbGV0L3VsdHJhdmlvbGV0L3BhY2thZ2VzL3VpL3NyYy9jb21wb25lbnRzL1JhZGlvR3JvdXAvaW5kZXgudHN4Il0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQW9FZ0MiLCJmaWxlIjoiL2hvbWUvcnVubmVyL3dvcmsvdWx0cmF2aW9sZXQvdWx0cmF2aW9sZXQvcGFja2FnZXMvdWkvc3JjL2NvbXBvbmVudHMvUmFkaW9Hcm91cC9pbmRleC50c3giLCJzb3VyY2VzQ29udGVudCI6WyIndXNlIGNsaWVudCdcblxuaW1wb3J0IHN0eWxlZCBmcm9tICdAZW1vdGlvbi9zdHlsZWQnXG5pbXBvcnQgdHlwZSB7IENvbXBvbmVudFByb3BzLCBJbnB1dEhUTUxBdHRyaWJ1dGVzLCBSZWFjdE5vZGUgfSBmcm9tICdyZWFjdCdcbmltcG9ydCB7IGNyZWF0ZUNvbnRleHQsIHVzZUNvbnRleHQsIHVzZU1lbW8gfSBmcm9tICdyZWFjdCdcbmltcG9ydCB7IExhYmVsIH0gZnJvbSAnLi4vTGFiZWwnXG5pbXBvcnQgeyBSYWRpbyB9IGZyb20gJy4uL1JhZGlvJ1xuaW1wb3J0IHsgU3RhY2sgfSBmcm9tICcuLi9TdGFjaydcbmltcG9ydCB7IFRleHQgfSBmcm9tICcuLi9UZXh0J1xuXG50eXBlIFJhZGlvR3JvdXBDb250ZXh0VHlwZSA9IHtcbiAgZ3JvdXBOYW1lPzogc3RyaW5nXG4gIGdyb3VwVmFsdWU6IHN0cmluZyB8IG51bWJlclxuICBlcnJvcjogYm9vbGVhblxufSAmIFJlcXVpcmVkPFBpY2s8SW5wdXRIVE1MQXR0cmlidXRlczxIVE1MSW5wdXRFbGVtZW50PiwgJ29uQ2hhbmdlJz4+ICZcbiAgUGljazxJbnB1dEhUTUxBdHRyaWJ1dGVzPEhUTUxJbnB1dEVsZW1lbnQ+LCAncmVxdWlyZWQnPlxuXG5jb25zdCBSYWRpb0dyb3VwQ29udGV4dCA9IGNyZWF0ZUNvbnRleHQ8UmFkaW9Hcm91cENvbnRleHRUeXBlIHwgdW5kZWZpbmVkPihcbiAgdW5kZWZpbmVkLFxuKVxuXG50eXBlIFJhZGlvR3JvdXBSYWRpb1Byb3BzID0gT21pdDxcbiAgQ29tcG9uZW50UHJvcHM8dHlwZW9mIFJhZGlvPixcbiAgJ29uQ2hhbmdlJyB8ICdjaGVja2VkJyB8ICdyZXF1aXJlZCcgfCAnbmFtZSdcbj5cbmNvbnN0IFJhZGlvR3JvdXBSYWRpbyA9ICh7XG4gIG9uRm9jdXMsXG4gIG9uQmx1cixcbiAgZGlzYWJsZWQsXG4gIGVycm9yLFxuICB2YWx1ZSxcbiAgbGFiZWwsXG4gIGhlbHBlcixcbiAgY2xhc3NOYW1lLFxuICBhdXRvRm9jdXMsXG4gIG9uS2V5RG93bixcbiAgdG9vbHRpcCxcbiAgJ2RhdGEtdGVzdGlkJzogZGF0YVRlc3RJZCxcbn06IFJhZGlvR3JvdXBSYWRpb1Byb3BzKSA9PiB7XG4gIGNvbnN0IGNvbnRleHQgPSB1c2VDb250ZXh0KFJhZGlvR3JvdXBDb250ZXh0KVxuXG4gIGlmICghY29udGV4dCkge1xuICAgIHRocm93IG5ldyBFcnJvcignUmFkaW9Hcm91cC5SYWRpbyBjYW4gb25seSBiZSB1c2VkIGluc2lkZSBhIFJhZGlvR3JvdXAnKVxuICB9XG5cbiAgY29uc3QgeyBncm91cE5hbWUsIG9uQ2hhbmdlLCBncm91cFZhbHVlLCBlcnJvcjogZXJyb3JDb250ZXh0IH0gPSBjb250ZXh0XG5cbiAgcmV0dXJuIChcbiAgICA8UmFkaW9cbiAgICAgIGF1dG9Gb2N1cz17YXV0b0ZvY3VzfVxuICAgICAgY2hlY2tlZD17Z3JvdXBWYWx1ZSA9PT0gdmFsdWV9XG4gICAgICBjbGFzc05hbWU9e2NsYXNzTmFtZX1cbiAgICAgIGRhdGEtdGVzdGlkPXtkYXRhVGVzdElkfVxuICAgICAgZGlzYWJsZWQ9e2Rpc2FibGVkfVxuICAgICAgZXJyb3I9e2Vycm9yIHx8IGVycm9yQ29udGV4dH1cbiAgICAgIGhlbHBlcj17aGVscGVyfVxuICAgICAgbGFiZWw9e2xhYmVsfVxuICAgICAgbmFtZT17Z3JvdXBOYW1lfVxuICAgICAgb25CbHVyPXtvbkJsdXJ9XG4gICAgICBvbkNoYW5nZT17b25DaGFuZ2V9XG4gICAgICBvbkZvY3VzPXtvbkZvY3VzfVxuICAgICAgb25LZXlEb3duPXtvbktleURvd259XG4gICAgICB0b29sdGlwPXt0b29sdGlwfVxuICAgICAgdmFsdWU9e3ZhbHVlfVxuICAgIC8+XG4gIClcbn1cblxuY29uc3QgRmllbGRTZXQgPSBzdHlsZWQuZmllbGRzZXRgXG4gIGJvcmRlcjogbm9uZTtcbiAgcGFkZGluZzogMDtcbiAgbWFyZ2luOiAwO1xuYFxuXG50eXBlIFJhZGlvR3JvdXBQcm9wcyA9IHtcbiAgbGVnZW5kPzogc3RyaW5nXG4gIGxlZ2VuZERlc2NyaXB0aW9uPzogUmVhY3ROb2RlXG4gIHZhbHVlOiBzdHJpbmcgfCBudW1iZXJcbiAgY2xhc3NOYW1lPzogc3RyaW5nXG4gIGhlbHBlcj86IFJlYWN0Tm9kZVxuICBlcnJvcj86IFJlYWN0Tm9kZVxuICBkaXJlY3Rpb24/OiAncm93JyB8ICdjb2x1bW4nXG4gIGNoaWxkcmVuOiBSZWFjdE5vZGVcbiAgZGVzY3JpcHRpb24/OiBSZWFjdE5vZGVcbn0gJiBSZXF1aXJlZDxQaWNrPElucHV0SFRNTEF0dHJpYnV0ZXM8SFRNTElucHV0RWxlbWVudD4sICdvbkNoYW5nZSc+PiAmXG4gIFBpY2s8SW5wdXRIVE1MQXR0cmlidXRlczxIVE1MSW5wdXRFbGVtZW50PiwgJ3JlcXVpcmVkJyB8ICduYW1lJz5cblxuLyoqXG4gKiBSYWRpb0dyb3VwIGlzIGEgY29tcG9uZW50IHRoYXQgYWxsb3dzIHVzZXJzIHRvIHNlbGVjdCBvbmUgb3B0aW9uIGZyb20gYSBsaXN0IG9mIG9wdGlvbnMgdXNpbmcgcmFkaW8uXG4gKi9cbmV4cG9ydCBjb25zdCBSYWRpb0dyb3VwID0gKHtcbiAgbGVnZW5kLFxuICBsZWdlbmREZXNjcmlwdGlvbixcbiAgdmFsdWUsXG4gIGNsYXNzTmFtZSxcbiAgaGVscGVyLFxuICBlcnJvcixcbiAgZGlyZWN0aW9uID0gJ2NvbHVtbicsXG4gIGNoaWxkcmVuLFxuICBvbkNoYW5nZSxcbiAgbmFtZSxcbiAgZGVzY3JpcHRpb24sXG4gIHJlcXVpcmVkID0gZmFsc2UsXG59OiBSYWRpb0dyb3VwUHJvcHMpID0+IHtcbiAgY29uc3QgY29udGV4dFZhbHVlID0gdXNlTWVtbyhcbiAgICAoKSA9PiAoe1xuICAgICAgZXJyb3I6ICEhZXJyb3IsXG4gICAgICBncm91cE5hbWU6IG5hbWUsXG4gICAgICBncm91cFZhbHVlOiB2YWx1ZSxcbiAgICAgIG9uQ2hhbmdlLFxuICAgICAgcmVxdWlyZWQsXG4gICAgfSksXG4gICAgW25hbWUsIHZhbHVlLCBvbkNoYW5nZSwgcmVxdWlyZWQsIGVycm9yXSxcbiAgKVxuXG4gIHJldHVybiAoXG4gICAgPFJhZGlvR3JvdXBDb250ZXh0LlByb3ZpZGVyIHZhbHVlPXtjb250ZXh0VmFsdWV9PlxuICAgICAgPFN0YWNrIGdhcD17MX0+XG4gICAgICAgIDxGaWVsZFNldCBjbGFzc05hbWU9e2NsYXNzTmFtZX0+XG4gICAgICAgICAgPFN0YWNrIGdhcD17MS41fT5cbiAgICAgICAgICAgIHtsZWdlbmQgfHwgZGVzY3JpcHRpb24gPyAoXG4gICAgICAgICAgICAgIDxTdGFjayBnYXA9ezAuNX0+XG4gICAgICAgICAgICAgICAge2xlZ2VuZCA/IChcbiAgICAgICAgICAgICAgICAgIDxMYWJlbFxuICAgICAgICAgICAgICAgICAgICBhcz1cImxlZ2VuZFwiXG4gICAgICAgICAgICAgICAgICAgIGxhYmVsRGVzY3JpcHRpb249e2xlZ2VuZERlc2NyaXB0aW9ufVxuICAgICAgICAgICAgICAgICAgICByZXF1aXJlZD17cmVxdWlyZWR9XG4gICAgICAgICAgICAgICAgICA+XG4gICAgICAgICAgICAgICAgICAgIHtsZWdlbmR9XG4gICAgICAgICAgICAgICAgICA8L0xhYmVsPlxuICAgICAgICAgICAgICAgICkgOiBudWxsfVxuICAgICAgICAgICAgICAgIHtkZXNjcmlwdGlvbiA/IChcbiAgICAgICAgICAgICAgICAgIDxUZXh0XG4gICAgICAgICAgICAgICAgICAgIGFzPXt0eXBlb2YgZGVzY3JpcHRpb24gPT09ICdzdHJpbmcnID8gJ3AnIDogJ2Rpdid9XG4gICAgICAgICAgICAgICAgICAgIHByb21pbmVuY2U9XCJ3ZWFrXCJcbiAgICAgICAgICAgICAgICAgICAgc2VudGltZW50PVwibmV1dHJhbFwiXG4gICAgICAgICAgICAgICAgICAgIHZhcmlhbnQ9XCJib2R5U21hbGxcIlxuICAgICAgICAgICAgICAgICAgPlxuICAgICAgICAgICAgICAgICAgICB7ZGVzY3JpcHRpb259XG4gICAgICAgICAgICAgICAgICA8L1RleHQ+XG4gICAgICAgICAgICAgICAgKSA6IG51bGx9XG4gICAgICAgICAgICAgIDwvU3RhY2s+XG4gICAgICAgICAgICApIDogbnVsbH1cbiAgICAgICAgICAgIDxTdGFja1xuICAgICAgICAgICAgICBhbGlnbkl0ZW1zPVwic3RhcnRcIlxuICAgICAgICAgICAgICBkaXJlY3Rpb249e2RpcmVjdGlvbn1cbiAgICAgICAgICAgICAgZ2FwPXtkaXJlY3Rpb24gPT09ICdjb2x1bW4nID8gMSA6IDJ9XG4gICAgICAgICAgICA+XG4gICAgICAgICAgICAgIHtjaGlsZHJlbn1cbiAgICAgICAgICAgIDwvU3RhY2s+XG4gICAgICAgICAgPC9TdGFjaz5cbiAgICAgICAgPC9GaWVsZFNldD5cbiAgICAgICAge2hlbHBlciA/IChcbiAgICAgICAgICA8VGV4dFxuICAgICAgICAgICAgYXM9XCJzcGFuXCJcbiAgICAgICAgICAgIHByb21pbmVuY2U9XCJ3ZWFrXCJcbiAgICAgICAgICAgIHNlbnRpbWVudD1cIm5ldXRyYWxcIlxuICAgICAgICAgICAgdmFyaWFudD1cImNhcHRpb25cIlxuICAgICAgICAgID5cbiAgICAgICAgICAgIHtoZWxwZXJ9XG4gICAgICAgICAgPC9UZXh0PlxuICAgICAgICApIDogbnVsbH1cbiAgICAgICAge2Vycm9yID8gKFxuICAgICAgICAgIDxUZXh0IGFzPVwic3BhblwiIHNlbnRpbWVudD1cImRhbmdlclwiIHZhcmlhbnQ9XCJjYXB0aW9uXCI+XG4gICAgICAgICAgICB7ZXJyb3J9XG4gICAgICAgICAgPC9UZXh0PlxuICAgICAgICApIDogbnVsbH1cbiAgICAgIDwvU3RhY2s+XG4gICAgPC9SYWRpb0dyb3VwQ29udGV4dC5Qcm92aWRlcj5cbiAgKVxufVxuXG5SYWRpb0dyb3VwLlJhZGlvID0gUmFkaW9Hcm91cFJhZGlvXG4iXX0= */",
54
- toString: _EMOTION_STRINGIFIED_CSS_ERROR__
55
- });
56
38
  const RadioGroup = ({
57
39
  legend,
58
40
  legendDescription,
@@ -75,7 +57,7 @@ const RadioGroup = ({
75
57
  required
76
58
  }), [name, value, onChange, required, error]);
77
59
  return /* @__PURE__ */ jsxRuntime.jsx(RadioGroupContext.Provider, { value: contextValue, children: /* @__PURE__ */ jsxRuntime.jsxs(index.Stack, { gap: 1, children: [
78
- /* @__PURE__ */ jsxRuntime.jsx(FieldSet, { className, children: /* @__PURE__ */ jsxRuntime.jsxs(index.Stack, { gap: 1.5, children: [
60
+ /* @__PURE__ */ jsxRuntime.jsx("fieldset", { className: `${className ? `${className} ` : ""}${styles_css.fieldset}`, children: /* @__PURE__ */ jsxRuntime.jsxs(index.Stack, { gap: 1.5, children: [
79
61
  legend || description ? /* @__PURE__ */ jsxRuntime.jsxs(index.Stack, { gap: 0.5, children: [
80
62
  legend ? /* @__PURE__ */ jsxRuntime.jsx(index$1.Label, { as: "legend", labelDescription: legendDescription, required, children: legend }) : null,
81
63
  description ? /* @__PURE__ */ jsxRuntime.jsx(index$2.Text, { as: typeof description === "string" ? "p" : "div", prominence: "weak", sentiment: "neutral", variant: "bodySmall", children: description }) : null
@@ -1,14 +1,11 @@
1
1
  "use client";
2
2
  import { jsx, jsxs } from "@emotion/react/jsx-runtime";
3
- import _styled from "@emotion/styled/base";
4
3
  import { useMemo, createContext, useContext } from "react";
5
4
  import { Label } from "../Label/index.js";
6
5
  import { Radio } from "../Radio/index.js";
7
6
  import { Stack } from "../Stack/index.js";
8
7
  import { Text } from "../Text/index.js";
9
- function _EMOTION_STRINGIFIED_CSS_ERROR__() {
10
- return "You have tried to stringify object returned from `css` function. It isn't supposed to be used directly (e.g. as value of the `className` prop), but rather handed to emotion so it can handle it (e.g. as value of `css` prop).";
11
- }
8
+ import { fieldset } from "./styles.css.js";
12
9
  const RadioGroupContext = createContext(void 0);
13
10
  const RadioGroupRadio = ({
14
11
  onFocus,
@@ -36,19 +33,6 @@ const RadioGroupRadio = ({
36
33
  } = context;
37
34
  return /* @__PURE__ */ jsx(Radio, { autoFocus, checked: groupValue === value, className, "data-testid": dataTestId, disabled, error: error || errorContext, helper, label, name: groupName, onBlur, onChange, onFocus, onKeyDown, tooltip, value });
38
35
  };
39
- const FieldSet = /* @__PURE__ */ _styled("fieldset", process.env.NODE_ENV === "production" ? {
40
- target: "e15shfap0"
41
- } : {
42
- target: "e15shfap0",
43
- label: "FieldSet"
44
- })(process.env.NODE_ENV === "production" ? {
45
- name: "7o2an9",
46
- styles: "border:none;padding:0;margin:0"
47
- } : {
48
- name: "7o2an9",
49
- styles: "border:none;padding:0;margin:0/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi9ob21lL3J1bm5lci93b3JrL3VsdHJhdmlvbGV0L3VsdHJhdmlvbGV0L3BhY2thZ2VzL3VpL3NyYy9jb21wb25lbnRzL1JhZGlvR3JvdXAvaW5kZXgudHN4Il0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQW9FZ0MiLCJmaWxlIjoiL2hvbWUvcnVubmVyL3dvcmsvdWx0cmF2aW9sZXQvdWx0cmF2aW9sZXQvcGFja2FnZXMvdWkvc3JjL2NvbXBvbmVudHMvUmFkaW9Hcm91cC9pbmRleC50c3giLCJzb3VyY2VzQ29udGVudCI6WyIndXNlIGNsaWVudCdcblxuaW1wb3J0IHN0eWxlZCBmcm9tICdAZW1vdGlvbi9zdHlsZWQnXG5pbXBvcnQgdHlwZSB7IENvbXBvbmVudFByb3BzLCBJbnB1dEhUTUxBdHRyaWJ1dGVzLCBSZWFjdE5vZGUgfSBmcm9tICdyZWFjdCdcbmltcG9ydCB7IGNyZWF0ZUNvbnRleHQsIHVzZUNvbnRleHQsIHVzZU1lbW8gfSBmcm9tICdyZWFjdCdcbmltcG9ydCB7IExhYmVsIH0gZnJvbSAnLi4vTGFiZWwnXG5pbXBvcnQgeyBSYWRpbyB9IGZyb20gJy4uL1JhZGlvJ1xuaW1wb3J0IHsgU3RhY2sgfSBmcm9tICcuLi9TdGFjaydcbmltcG9ydCB7IFRleHQgfSBmcm9tICcuLi9UZXh0J1xuXG50eXBlIFJhZGlvR3JvdXBDb250ZXh0VHlwZSA9IHtcbiAgZ3JvdXBOYW1lPzogc3RyaW5nXG4gIGdyb3VwVmFsdWU6IHN0cmluZyB8IG51bWJlclxuICBlcnJvcjogYm9vbGVhblxufSAmIFJlcXVpcmVkPFBpY2s8SW5wdXRIVE1MQXR0cmlidXRlczxIVE1MSW5wdXRFbGVtZW50PiwgJ29uQ2hhbmdlJz4+ICZcbiAgUGljazxJbnB1dEhUTUxBdHRyaWJ1dGVzPEhUTUxJbnB1dEVsZW1lbnQ+LCAncmVxdWlyZWQnPlxuXG5jb25zdCBSYWRpb0dyb3VwQ29udGV4dCA9IGNyZWF0ZUNvbnRleHQ8UmFkaW9Hcm91cENvbnRleHRUeXBlIHwgdW5kZWZpbmVkPihcbiAgdW5kZWZpbmVkLFxuKVxuXG50eXBlIFJhZGlvR3JvdXBSYWRpb1Byb3BzID0gT21pdDxcbiAgQ29tcG9uZW50UHJvcHM8dHlwZW9mIFJhZGlvPixcbiAgJ29uQ2hhbmdlJyB8ICdjaGVja2VkJyB8ICdyZXF1aXJlZCcgfCAnbmFtZSdcbj5cbmNvbnN0IFJhZGlvR3JvdXBSYWRpbyA9ICh7XG4gIG9uRm9jdXMsXG4gIG9uQmx1cixcbiAgZGlzYWJsZWQsXG4gIGVycm9yLFxuICB2YWx1ZSxcbiAgbGFiZWwsXG4gIGhlbHBlcixcbiAgY2xhc3NOYW1lLFxuICBhdXRvRm9jdXMsXG4gIG9uS2V5RG93bixcbiAgdG9vbHRpcCxcbiAgJ2RhdGEtdGVzdGlkJzogZGF0YVRlc3RJZCxcbn06IFJhZGlvR3JvdXBSYWRpb1Byb3BzKSA9PiB7XG4gIGNvbnN0IGNvbnRleHQgPSB1c2VDb250ZXh0KFJhZGlvR3JvdXBDb250ZXh0KVxuXG4gIGlmICghY29udGV4dCkge1xuICAgIHRocm93IG5ldyBFcnJvcignUmFkaW9Hcm91cC5SYWRpbyBjYW4gb25seSBiZSB1c2VkIGluc2lkZSBhIFJhZGlvR3JvdXAnKVxuICB9XG5cbiAgY29uc3QgeyBncm91cE5hbWUsIG9uQ2hhbmdlLCBncm91cFZhbHVlLCBlcnJvcjogZXJyb3JDb250ZXh0IH0gPSBjb250ZXh0XG5cbiAgcmV0dXJuIChcbiAgICA8UmFkaW9cbiAgICAgIGF1dG9Gb2N1cz17YXV0b0ZvY3VzfVxuICAgICAgY2hlY2tlZD17Z3JvdXBWYWx1ZSA9PT0gdmFsdWV9XG4gICAgICBjbGFzc05hbWU9e2NsYXNzTmFtZX1cbiAgICAgIGRhdGEtdGVzdGlkPXtkYXRhVGVzdElkfVxuICAgICAgZGlzYWJsZWQ9e2Rpc2FibGVkfVxuICAgICAgZXJyb3I9e2Vycm9yIHx8IGVycm9yQ29udGV4dH1cbiAgICAgIGhlbHBlcj17aGVscGVyfVxuICAgICAgbGFiZWw9e2xhYmVsfVxuICAgICAgbmFtZT17Z3JvdXBOYW1lfVxuICAgICAgb25CbHVyPXtvbkJsdXJ9XG4gICAgICBvbkNoYW5nZT17b25DaGFuZ2V9XG4gICAgICBvbkZvY3VzPXtvbkZvY3VzfVxuICAgICAgb25LZXlEb3duPXtvbktleURvd259XG4gICAgICB0b29sdGlwPXt0b29sdGlwfVxuICAgICAgdmFsdWU9e3ZhbHVlfVxuICAgIC8+XG4gIClcbn1cblxuY29uc3QgRmllbGRTZXQgPSBzdHlsZWQuZmllbGRzZXRgXG4gIGJvcmRlcjogbm9uZTtcbiAgcGFkZGluZzogMDtcbiAgbWFyZ2luOiAwO1xuYFxuXG50eXBlIFJhZGlvR3JvdXBQcm9wcyA9IHtcbiAgbGVnZW5kPzogc3RyaW5nXG4gIGxlZ2VuZERlc2NyaXB0aW9uPzogUmVhY3ROb2RlXG4gIHZhbHVlOiBzdHJpbmcgfCBudW1iZXJcbiAgY2xhc3NOYW1lPzogc3RyaW5nXG4gIGhlbHBlcj86IFJlYWN0Tm9kZVxuICBlcnJvcj86IFJlYWN0Tm9kZVxuICBkaXJlY3Rpb24/OiAncm93JyB8ICdjb2x1bW4nXG4gIGNoaWxkcmVuOiBSZWFjdE5vZGVcbiAgZGVzY3JpcHRpb24/OiBSZWFjdE5vZGVcbn0gJiBSZXF1aXJlZDxQaWNrPElucHV0SFRNTEF0dHJpYnV0ZXM8SFRNTElucHV0RWxlbWVudD4sICdvbkNoYW5nZSc+PiAmXG4gIFBpY2s8SW5wdXRIVE1MQXR0cmlidXRlczxIVE1MSW5wdXRFbGVtZW50PiwgJ3JlcXVpcmVkJyB8ICduYW1lJz5cblxuLyoqXG4gKiBSYWRpb0dyb3VwIGlzIGEgY29tcG9uZW50IHRoYXQgYWxsb3dzIHVzZXJzIHRvIHNlbGVjdCBvbmUgb3B0aW9uIGZyb20gYSBsaXN0IG9mIG9wdGlvbnMgdXNpbmcgcmFkaW8uXG4gKi9cbmV4cG9ydCBjb25zdCBSYWRpb0dyb3VwID0gKHtcbiAgbGVnZW5kLFxuICBsZWdlbmREZXNjcmlwdGlvbixcbiAgdmFsdWUsXG4gIGNsYXNzTmFtZSxcbiAgaGVscGVyLFxuICBlcnJvcixcbiAgZGlyZWN0aW9uID0gJ2NvbHVtbicsXG4gIGNoaWxkcmVuLFxuICBvbkNoYW5nZSxcbiAgbmFtZSxcbiAgZGVzY3JpcHRpb24sXG4gIHJlcXVpcmVkID0gZmFsc2UsXG59OiBSYWRpb0dyb3VwUHJvcHMpID0+IHtcbiAgY29uc3QgY29udGV4dFZhbHVlID0gdXNlTWVtbyhcbiAgICAoKSA9PiAoe1xuICAgICAgZXJyb3I6ICEhZXJyb3IsXG4gICAgICBncm91cE5hbWU6IG5hbWUsXG4gICAgICBncm91cFZhbHVlOiB2YWx1ZSxcbiAgICAgIG9uQ2hhbmdlLFxuICAgICAgcmVxdWlyZWQsXG4gICAgfSksXG4gICAgW25hbWUsIHZhbHVlLCBvbkNoYW5nZSwgcmVxdWlyZWQsIGVycm9yXSxcbiAgKVxuXG4gIHJldHVybiAoXG4gICAgPFJhZGlvR3JvdXBDb250ZXh0LlByb3ZpZGVyIHZhbHVlPXtjb250ZXh0VmFsdWV9PlxuICAgICAgPFN0YWNrIGdhcD17MX0+XG4gICAgICAgIDxGaWVsZFNldCBjbGFzc05hbWU9e2NsYXNzTmFtZX0+XG4gICAgICAgICAgPFN0YWNrIGdhcD17MS41fT5cbiAgICAgICAgICAgIHtsZWdlbmQgfHwgZGVzY3JpcHRpb24gPyAoXG4gICAgICAgICAgICAgIDxTdGFjayBnYXA9ezAuNX0+XG4gICAgICAgICAgICAgICAge2xlZ2VuZCA/IChcbiAgICAgICAgICAgICAgICAgIDxMYWJlbFxuICAgICAgICAgICAgICAgICAgICBhcz1cImxlZ2VuZFwiXG4gICAgICAgICAgICAgICAgICAgIGxhYmVsRGVzY3JpcHRpb249e2xlZ2VuZERlc2NyaXB0aW9ufVxuICAgICAgICAgICAgICAgICAgICByZXF1aXJlZD17cmVxdWlyZWR9XG4gICAgICAgICAgICAgICAgICA+XG4gICAgICAgICAgICAgICAgICAgIHtsZWdlbmR9XG4gICAgICAgICAgICAgICAgICA8L0xhYmVsPlxuICAgICAgICAgICAgICAgICkgOiBudWxsfVxuICAgICAgICAgICAgICAgIHtkZXNjcmlwdGlvbiA/IChcbiAgICAgICAgICAgICAgICAgIDxUZXh0XG4gICAgICAgICAgICAgICAgICAgIGFzPXt0eXBlb2YgZGVzY3JpcHRpb24gPT09ICdzdHJpbmcnID8gJ3AnIDogJ2Rpdid9XG4gICAgICAgICAgICAgICAgICAgIHByb21pbmVuY2U9XCJ3ZWFrXCJcbiAgICAgICAgICAgICAgICAgICAgc2VudGltZW50PVwibmV1dHJhbFwiXG4gICAgICAgICAgICAgICAgICAgIHZhcmlhbnQ9XCJib2R5U21hbGxcIlxuICAgICAgICAgICAgICAgICAgPlxuICAgICAgICAgICAgICAgICAgICB7ZGVzY3JpcHRpb259XG4gICAgICAgICAgICAgICAgICA8L1RleHQ+XG4gICAgICAgICAgICAgICAgKSA6IG51bGx9XG4gICAgICAgICAgICAgIDwvU3RhY2s+XG4gICAgICAgICAgICApIDogbnVsbH1cbiAgICAgICAgICAgIDxTdGFja1xuICAgICAgICAgICAgICBhbGlnbkl0ZW1zPVwic3RhcnRcIlxuICAgICAgICAgICAgICBkaXJlY3Rpb249e2RpcmVjdGlvbn1cbiAgICAgICAgICAgICAgZ2FwPXtkaXJlY3Rpb24gPT09ICdjb2x1bW4nID8gMSA6IDJ9XG4gICAgICAgICAgICA+XG4gICAgICAgICAgICAgIHtjaGlsZHJlbn1cbiAgICAgICAgICAgIDwvU3RhY2s+XG4gICAgICAgICAgPC9TdGFjaz5cbiAgICAgICAgPC9GaWVsZFNldD5cbiAgICAgICAge2hlbHBlciA/IChcbiAgICAgICAgICA8VGV4dFxuICAgICAgICAgICAgYXM9XCJzcGFuXCJcbiAgICAgICAgICAgIHByb21pbmVuY2U9XCJ3ZWFrXCJcbiAgICAgICAgICAgIHNlbnRpbWVudD1cIm5ldXRyYWxcIlxuICAgICAgICAgICAgdmFyaWFudD1cImNhcHRpb25cIlxuICAgICAgICAgID5cbiAgICAgICAgICAgIHtoZWxwZXJ9XG4gICAgICAgICAgPC9UZXh0PlxuICAgICAgICApIDogbnVsbH1cbiAgICAgICAge2Vycm9yID8gKFxuICAgICAgICAgIDxUZXh0IGFzPVwic3BhblwiIHNlbnRpbWVudD1cImRhbmdlclwiIHZhcmlhbnQ9XCJjYXB0aW9uXCI+XG4gICAgICAgICAgICB7ZXJyb3J9XG4gICAgICAgICAgPC9UZXh0PlxuICAgICAgICApIDogbnVsbH1cbiAgICAgIDwvU3RhY2s+XG4gICAgPC9SYWRpb0dyb3VwQ29udGV4dC5Qcm92aWRlcj5cbiAgKVxufVxuXG5SYWRpb0dyb3VwLlJhZGlvID0gUmFkaW9Hcm91cFJhZGlvXG4iXX0= */",
50
- toString: _EMOTION_STRINGIFIED_CSS_ERROR__
51
- });
52
36
  const RadioGroup = ({
53
37
  legend,
54
38
  legendDescription,
@@ -71,7 +55,7 @@ const RadioGroup = ({
71
55
  required
72
56
  }), [name, value, onChange, required, error]);
73
57
  return /* @__PURE__ */ jsx(RadioGroupContext.Provider, { value: contextValue, children: /* @__PURE__ */ jsxs(Stack, { gap: 1, children: [
74
- /* @__PURE__ */ jsx(FieldSet, { className, children: /* @__PURE__ */ jsxs(Stack, { gap: 1.5, children: [
58
+ /* @__PURE__ */ jsx("fieldset", { className: `${className ? `${className} ` : ""}${fieldset}`, children: /* @__PURE__ */ jsxs(Stack, { gap: 1.5, children: [
75
59
  legend || description ? /* @__PURE__ */ jsxs(Stack, { gap: 0.5, children: [
76
60
  legend ? /* @__PURE__ */ jsx(Label, { as: "legend", labelDescription: legendDescription, required, children: legend }) : null,
77
61
  description ? /* @__PURE__ */ jsx(Text, { as: typeof description === "string" ? "p" : "div", prominence: "weak", sentiment: "neutral", variant: "bodySmall", children: description }) : null
@@ -0,0 +1,5 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, Symbol.toStringTag, { value: "Module" });
3
+ ;/* empty css */
4
+ var fieldset = "uv_1ec5h6m0";
5
+ exports.fieldset = fieldset;
@@ -0,0 +1 @@
1
+ export declare const fieldset: string;
@@ -0,0 +1,5 @@
1
+ /* empty css */
2
+ var fieldset = "uv_1ec5h6m0";
3
+ export {
4
+ fieldset
5
+ };