@ultraviolet/ui 1.51.2 → 1.51.3

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (127) hide show
  1. package/dist/components/ActionBar/index.js +16 -26
  2. package/dist/components/Alert/index.js +77 -88
  3. package/dist/components/Avatar/index.js +29 -26
  4. package/dist/components/Badge/index.js +36 -52
  5. package/dist/components/Banner/index.js +64 -139
  6. package/dist/components/BarChart/Tooltip.js +23 -18
  7. package/dist/components/BarChart/index.js +29 -42
  8. package/dist/components/BarStack/index.js +89 -163
  9. package/dist/components/Breadcrumbs/index.js +30 -33
  10. package/dist/components/Bullet/index.js +24 -28
  11. package/dist/components/Button/index.js +117 -159
  12. package/dist/components/Card/index.js +45 -52
  13. package/dist/components/Carousel/index.js +75 -99
  14. package/dist/components/Checkbox/index.js +246 -343
  15. package/dist/components/CheckboxGroup/index.js +60 -56
  16. package/dist/components/CopyButton/index.js +1 -15
  17. package/dist/components/DateInput/index.js +124 -243
  18. package/dist/components/Dialog/Context.js +1 -3
  19. package/dist/components/Dialog/index.js +22 -43
  20. package/dist/components/Dialog/subComponents/Button.js +1 -10
  21. package/dist/components/Dialog/subComponents/Stack.js +3 -1
  22. package/dist/components/Dialog/subComponents/Text.js +3 -1
  23. package/dist/components/EmptyState/index.js +58 -50
  24. package/dist/components/Expandable/index.js +19 -23
  25. package/dist/components/GlobalAlert/GlobalAlertLink.js +4 -20
  26. package/dist/components/GlobalAlert/index.js +34 -87
  27. package/dist/components/LineChart/CustomLegend.js +76 -72
  28. package/dist/components/LineChart/Tooltip.js +26 -37
  29. package/dist/components/LineChart/helpers.js +11 -9
  30. package/dist/components/LineChart/index.js +38 -55
  31. package/dist/components/Link/index.js +86 -125
  32. package/dist/components/List/Body.js +12 -7
  33. package/dist/components/List/Cell.js +36 -33
  34. package/dist/components/List/HeaderCell.js +54 -68
  35. package/dist/components/List/HeaderRow.js +16 -18
  36. package/dist/components/List/ListContext.js +68 -87
  37. package/dist/components/List/Row.js +136 -169
  38. package/dist/components/List/SelectBar.js +31 -14
  39. package/dist/components/List/SkeletonRows.js +42 -23
  40. package/dist/components/List/index.js +39 -59
  41. package/dist/components/Loader/index.js +44 -65
  42. package/dist/components/Menu/Item.js +52 -62
  43. package/dist/components/Menu/index.js +105 -171
  44. package/dist/components/MenuV2/Group.js +14 -16
  45. package/dist/components/MenuV2/Item.js +67 -74
  46. package/dist/components/MenuV2/index.js +76 -110
  47. package/dist/components/Meter/index.js +44 -57
  48. package/dist/components/Modal/Dialog.js +44 -100
  49. package/dist/components/Modal/index.js +23 -58
  50. package/dist/components/Notice/index.js +13 -29
  51. package/dist/components/Notification/index.js +9 -48
  52. package/dist/components/NumberInput/index.js +113 -200
  53. package/dist/components/NumberInputV2/index.js +200 -349
  54. package/dist/components/Pagination/getPageNumbers.js +3 -1
  55. package/dist/components/Pagination/index.js +45 -81
  56. package/dist/components/PasswordCheck/index.js +10 -15
  57. package/dist/components/PasswordStrengthMeter/index.js +66 -68
  58. package/dist/components/PieChart/Legends.js +121 -99
  59. package/dist/components/PieChart/Tooltip.js +35 -15
  60. package/dist/components/PieChart/index.js +68 -87
  61. package/dist/components/Popover/index.js +57 -106
  62. package/dist/components/Popup/helpers.js +24 -12
  63. package/dist/components/Popup/index.js +263 -351
  64. package/dist/components/ProgressBar/index.js +33 -51
  65. package/dist/components/Radio/index.js +119 -188
  66. package/dist/components/RadioGroup/index.js +46 -51
  67. package/dist/components/Row/index.js +11 -20
  68. package/dist/components/SelectInput/index.js +165 -212
  69. package/dist/components/SelectInputV2/Dropdown.js +233 -473
  70. package/dist/components/SelectInputV2/DropdownOption.js +44 -115
  71. package/dist/components/SelectInputV2/SearchBarDropdown.js +28 -44
  72. package/dist/components/SelectInputV2/SelectBar.js +137 -240
  73. package/dist/components/SelectInputV2/SelectInputProvider.js +45 -77
  74. package/dist/components/SelectInputV2/index.js +39 -98
  75. package/dist/components/SelectableCard/index.js +127 -183
  76. package/dist/components/SelectableCardGroup/index.js +50 -55
  77. package/dist/components/Separator/index.js +44 -64
  78. package/dist/components/Skeleton/Block.js +28 -20
  79. package/dist/components/Skeleton/Blocks.js +26 -16
  80. package/dist/components/Skeleton/BoxWithIcon.js +24 -17
  81. package/dist/components/Skeleton/Donut.js +46 -21
  82. package/dist/components/Skeleton/IconSkeleton.js +19 -9
  83. package/dist/components/Skeleton/Line.js +11 -8
  84. package/dist/components/Skeleton/List.js +48 -21
  85. package/dist/components/Skeleton/Slider.js +36 -22
  86. package/dist/components/Skeleton/Square.js +9 -7
  87. package/dist/components/Skeleton/index.js +38 -45
  88. package/dist/components/Snippet/index.js +139 -128
  89. package/dist/components/Stack/index.js +10 -17
  90. package/dist/components/Status/index.js +42 -27
  91. package/dist/components/StepList/index.js +34 -45
  92. package/dist/components/Stepper/index.js +106 -114
  93. package/dist/components/SwitchButton/FocusOverlay.js +18 -27
  94. package/dist/components/SwitchButton/index.js +39 -103
  95. package/dist/components/Table/Body.js +3 -1
  96. package/dist/components/Table/Cell.js +15 -6
  97. package/dist/components/Table/Header.js +12 -5
  98. package/dist/components/Table/HeaderCell.js +48 -91
  99. package/dist/components/Table/HeaderRow.js +11 -13
  100. package/dist/components/Table/Row.js +39 -44
  101. package/dist/components/Table/SelectBar.js +31 -14
  102. package/dist/components/Table/SkeletonRows.js +43 -11
  103. package/dist/components/Table/TableContext.js +29 -44
  104. package/dist/components/Table/index.js +37 -51
  105. package/dist/components/Tabs/Tab.js +108 -158
  106. package/dist/components/Tabs/TabMenu.js +52 -53
  107. package/dist/components/Tabs/TabMenuItem.js +19 -24
  108. package/dist/components/Tabs/TabsContext.js +1 -3
  109. package/dist/components/Tabs/index.js +44 -79
  110. package/dist/components/Tag/index.js +66 -75
  111. package/dist/components/TagInput/index.js +125 -188
  112. package/dist/components/TagList/index.js +51 -56
  113. package/dist/components/Text/index.js +10 -35
  114. package/dist/components/TextArea/index.js +140 -208
  115. package/dist/components/TextInput/index.js +326 -411
  116. package/dist/components/TextInputV2/index.js +170 -294
  117. package/dist/components/TimeInput/index.js +3 -174
  118. package/dist/components/Toaster/index.js +26 -74
  119. package/dist/components/Toggle/index.js +112 -172
  120. package/dist/components/ToggleGroup/index.js +44 -35
  121. package/dist/components/Tooltip/index.js +34 -41
  122. package/dist/components/VerificationCode/index.js +58 -63
  123. package/dist/helpers/legend.js +4 -4
  124. package/dist/theme/index.js +10 -13
  125. package/dist/utils/ids.js +3 -1
  126. package/dist/utils/responsive/Breakpoint.js +8 -6
  127. package/package.json +4 -4
@@ -1,169 +1,119 @@
1
1
  import { jsx, jsxs } from "@emotion/react/jsx-runtime";
2
- import styled from "@emotion/styled";
2
+ import _styled from "@emotion/styled/base";
3
3
  import { forwardRef, useMemo } from "react";
4
4
  import { Badge } from "../Badge/index.js";
5
5
  import { Stack } from "../Stack/index.js";
6
6
  import { Text } from "../Text/index.js";
7
7
  import { Tooltip } from "../Tooltip/index.js";
8
8
  import { useTabsContext } from "./TabsContext.js";
9
- const StyledBadge = styled(Badge)`
10
- padding: 0 ${({ theme }) => theme.space["1"]};
11
- margin-left: ${({ theme }) => theme.space["1"]};
12
- `;
13
- const StyledText = styled(Text)``;
14
- const StyledTooltip = styled(Tooltip)``;
15
- const BadgeContainer = styled.span`
16
- margin-left: ${({ theme }) => theme.space["1"]};
17
- display: flex;
18
- `;
19
- const StyledTabButton = styled("button")`
20
- display: flex;
21
- flex-direction: row;
22
- padding: ${({ theme }) => `${theme.space["1"]} ${theme.space["2"]}`};
23
- cursor: pointer;
24
- justify-content: center;
25
- align-items: baseline;
26
- white-space: nowrap;
27
- color: ${({ theme }) => theme.colors.neutral.text};
28
- text-decoration: none;
29
- user-select: none;
30
- touch-action: manipulation;
31
- transition: color 0.2s;
32
- border: none;
33
- background: none;
34
- border-bottom-width: 2px;
35
- border-bottom-style: solid;
36
- border-bottom-color: ${({ theme }) => theme.colors.neutral.border};
37
- outline: none;
38
-
39
- font-size: ${({ theme }) => theme.typography.bodyStrong.fontSize};
40
- font-family: ${({ theme }) => theme.typography.bodyStrong.fontFamily};
41
- font-weight: ${({ theme }) => theme.typography.bodyStrong.weight};
42
- letter-spacing: ${({ theme }) => theme.typography.bodyStrong.letterSpacing};
43
- line-height: ${({ theme }) => theme.typography.bodyStrong.lineHeight};
44
-
45
- &:hover,
46
- &:active,
47
- &:focus {
48
- text-decoration: none;
49
- outline: none;
50
- }
51
-
52
- &:focus-visible {
53
- outline: auto;
54
- }
55
-
56
- &[aria-selected='true'] {
57
- color: ${({ theme }) => theme.colors.primary.text};
58
- border-bottom-color: ${({ theme }) => theme.colors.primary.border};
59
-
60
- ${StyledText} {
61
- color: ${({ theme }) => theme.colors.primary.text};
9
+ const StyledBadge = /* @__PURE__ */ _styled(Badge, process.env.NODE_ENV === "production" ? {
10
+ target: "e1hzf7cr4"
11
+ } : {
12
+ target: "e1hzf7cr4",
13
+ label: "StyledBadge"
14
+ })("padding:0 ", ({
15
+ theme
16
+ }) => theme.space["1"], ";margin-left:", ({
17
+ theme
18
+ }) => theme.space["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/Tabs/Tab.tsx"],"names":[],"mappings":"AAiBiC","file":"/home/runner/work/ultraviolet/ultraviolet/packages/ui/src/components/Tabs/Tab.tsx","sourcesContent":["import styled from '@emotion/styled'\nimport type {\n  ComponentProps,\n  ElementType,\n  ForwardedRef,\n  KeyboardEventHandler,\n  MouseEventHandler,\n  ReactNode,\n  Ref,\n} from 'react'\nimport { forwardRef, useMemo } from 'react'\nimport { Badge } from '../Badge'\nimport { Stack } from '../Stack'\nimport { Text } from '../Text'\nimport { Tooltip } from '../Tooltip'\nimport { useTabsContext } from './TabsContext'\n\nconst StyledBadge = styled(Badge)`\n  padding: 0 ${({ theme }) => theme.space['1']};\n  margin-left: ${({ theme }) => theme.space['1']};\n`\n\nconst StyledText = styled(Text)``\n\nconst StyledTooltip = styled(Tooltip)``\n\nconst BadgeContainer = styled.span`\n  margin-left: ${({ theme }) => theme.space['1']};\n  display: flex;\n`\n\nexport const StyledTabButton = styled('button')`\n  display: flex;\n  flex-direction: row;\n  padding: ${({ theme }) => `${theme.space['1']} ${theme.space['2']}`};\n  cursor: pointer;\n  justify-content: center;\n  align-items: baseline;\n  white-space: nowrap;\n  color: ${({ theme }) => theme.colors.neutral.text};\n  text-decoration: none;\n  user-select: none;\n  touch-action: manipulation;\n  transition: color 0.2s;\n  border: none;\n  background: none;\n  border-bottom-width: 2px;\n  border-bottom-style: solid;\n  border-bottom-color: ${({ theme }) => theme.colors.neutral.border};\n  outline: none;\n\n  font-size: ${({ theme }) => theme.typography.bodyStrong.fontSize};\n  font-family: ${({ theme }) => theme.typography.bodyStrong.fontFamily};\n  font-weight: ${({ theme }) => theme.typography.bodyStrong.weight};\n  letter-spacing: ${({ theme }) => theme.typography.bodyStrong.letterSpacing};\n  line-height: ${({ theme }) => theme.typography.bodyStrong.lineHeight};\n\n  &:hover,\n  &:active,\n  &:focus {\n    text-decoration: none;\n    outline: none;\n  }\n\n  &:focus-visible {\n    outline: auto;\n  }\n\n  &[aria-selected='true'] {\n    color: ${({ theme }) => theme.colors.primary.text};\n    border-bottom-color: ${({ theme }) => theme.colors.primary.border};\n\n    ${StyledText} {\n      color: ${({ theme }) => theme.colors.primary.text};\n    }\n  }\n\n  &[aria-disabled='false']:not(:disabled) {\n    &:hover,\n    &:focus,\n    &:active {\n      outline: none;\n      color: ${({ theme }) => theme.colors.primary.text};\n      border-bottom-color: ${({ theme }) => theme.colors.primary.border};\n\n      &[data-is-selected='false'] {\n        ${StyledBadge} {\n          background-color: ${({ theme }) => theme.colors.primary.background};\n          border-color: ${({ theme }) => theme.colors.primary.background};\n          color: ${({ theme }) => theme.colors.primary.text};\n        }\n        ${StyledText} {\n          color: ${({ theme }) => theme.colors.primary.text};\n        }\n      }\n    }\n  }\n\n  &[aria-disabled='true'],\n  &:disabled {\n    cursor: not-allowed;\n    filter: grayscale(1) opacity(50%);\n  }\n`\n\ntype TabProps<T extends ElementType = 'button'> = {\n  as?: T\n  badge?: ReactNode\n  children?: ReactNode\n  className?: string\n  counter?: number | string\n  disabled?: boolean\n  onClick?: MouseEventHandler<HTMLElement>\n  onKeyDown?: KeyboardEventHandler<HTMLElement>\n  subtitle?: string\n  tooltip?: string\n  value?: string | number\n} & Omit<\n  ComponentProps<T>,\n  | 'as'\n  | 'badge'\n  | 'children'\n  | 'className'\n  | 'counter'\n  | 'disabled'\n  | 'value'\n  | 'tooltip'\n  | 'role'\n>\n\nexport const Tab = forwardRef(\n  <T extends ElementType = 'button'>(\n    {\n      as,\n      badge,\n      children,\n      className,\n      counter,\n      disabled = false,\n      onClick,\n      onKeyDown,\n      subtitle,\n      tooltip,\n      value,\n      ...props\n    }: TabProps<T>,\n    ref: ForwardedRef<HTMLElement>,\n  ) => {\n    const { selected, onChange } = useTabsContext()\n    const computedAs = as ?? 'button'\n    const isSelected = useMemo(\n      () => value !== undefined && selected === value,\n      [value, selected],\n    )\n\n    return (\n      <StyledTooltip text={tooltip}>\n        <StyledTabButton\n          role=\"tab\"\n          ref={ref as unknown as Ref<HTMLButtonElement>}\n          className={className}\n          as={computedAs}\n          aria-label={value ? `${value}` : undefined}\n          aria-selected={isSelected}\n          aria-disabled={disabled}\n          disabled={computedAs === 'button' ? disabled : undefined}\n          type={computedAs === 'button' ? 'button' : undefined}\n          onClick={event => {\n            if (value !== undefined) {\n              onChange(value)\n            }\n            onClick?.(event)\n          }}\n          onKeyDown={event => {\n            onKeyDown?.(event)\n            if (!event.defaultPrevented && !disabled && value) onChange(value)\n          }}\n          data-is-selected={isSelected}\n          {...props}\n        >\n          <Stack direction=\"column\" gap={0.5}>\n            <Stack direction=\"row\" alignItems=\"center\">\n              {children}\n              {typeof counter === 'number' || typeof counter === 'string' ? (\n                <StyledBadge\n                  sentiment={isSelected ? 'primary' : 'neutral'}\n                  prominence={isSelected ? 'strong' : 'default'}\n                  size=\"medium\"\n                >\n                  {counter}\n                </StyledBadge>\n              ) : null}\n              {badge ? <BadgeContainer>{badge}</BadgeContainer> : null}\n            </Stack>\n            {subtitle ? (\n              <Stack direction=\"row\">\n                <StyledText\n                  as=\"span\"\n                  variant=\"bodySmall\"\n                  sentiment=\"neutral\"\n                  prominence=\"weak\"\n                >\n                  {subtitle}\n                </StyledText>\n              </Stack>\n            ) : null}\n          </Stack>\n        </StyledTabButton>\n      </StyledTooltip>\n    )\n  },\n)\n"]} */"));
19
+ const StyledText = /* @__PURE__ */ _styled(Text, process.env.NODE_ENV === "production" ? {
20
+ target: "e1hzf7cr3"
21
+ } : {
22
+ target: "e1hzf7cr3",
23
+ label: "StyledText"
24
+ })(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/Tabs/Tab.tsx"],"names":[],"mappings":"AAsB+B","file":"/home/runner/work/ultraviolet/ultraviolet/packages/ui/src/components/Tabs/Tab.tsx","sourcesContent":["import styled from '@emotion/styled'\nimport type {\n  ComponentProps,\n  ElementType,\n  ForwardedRef,\n  KeyboardEventHandler,\n  MouseEventHandler,\n  ReactNode,\n  Ref,\n} from 'react'\nimport { forwardRef, useMemo } from 'react'\nimport { Badge } from '../Badge'\nimport { Stack } from '../Stack'\nimport { Text } from '../Text'\nimport { Tooltip } from '../Tooltip'\nimport { useTabsContext } from './TabsContext'\n\nconst StyledBadge = styled(Badge)`\n  padding: 0 ${({ theme }) => theme.space['1']};\n  margin-left: ${({ theme }) => theme.space['1']};\n`\n\nconst StyledText = styled(Text)``\n\nconst StyledTooltip = styled(Tooltip)``\n\nconst BadgeContainer = styled.span`\n  margin-left: ${({ theme }) => theme.space['1']};\n  display: flex;\n`\n\nexport const StyledTabButton = styled('button')`\n  display: flex;\n  flex-direction: row;\n  padding: ${({ theme }) => `${theme.space['1']} ${theme.space['2']}`};\n  cursor: pointer;\n  justify-content: center;\n  align-items: baseline;\n  white-space: nowrap;\n  color: ${({ theme }) => theme.colors.neutral.text};\n  text-decoration: none;\n  user-select: none;\n  touch-action: manipulation;\n  transition: color 0.2s;\n  border: none;\n  background: none;\n  border-bottom-width: 2px;\n  border-bottom-style: solid;\n  border-bottom-color: ${({ theme }) => theme.colors.neutral.border};\n  outline: none;\n\n  font-size: ${({ theme }) => theme.typography.bodyStrong.fontSize};\n  font-family: ${({ theme }) => theme.typography.bodyStrong.fontFamily};\n  font-weight: ${({ theme }) => theme.typography.bodyStrong.weight};\n  letter-spacing: ${({ theme }) => theme.typography.bodyStrong.letterSpacing};\n  line-height: ${({ theme }) => theme.typography.bodyStrong.lineHeight};\n\n  &:hover,\n  &:active,\n  &:focus {\n    text-decoration: none;\n    outline: none;\n  }\n\n  &:focus-visible {\n    outline: auto;\n  }\n\n  &[aria-selected='true'] {\n    color: ${({ theme }) => theme.colors.primary.text};\n    border-bottom-color: ${({ theme }) => theme.colors.primary.border};\n\n    ${StyledText} {\n      color: ${({ theme }) => theme.colors.primary.text};\n    }\n  }\n\n  &[aria-disabled='false']:not(:disabled) {\n    &:hover,\n    &:focus,\n    &:active {\n      outline: none;\n      color: ${({ theme }) => theme.colors.primary.text};\n      border-bottom-color: ${({ theme }) => theme.colors.primary.border};\n\n      &[data-is-selected='false'] {\n        ${StyledBadge} {\n          background-color: ${({ theme }) => theme.colors.primary.background};\n          border-color: ${({ theme }) => theme.colors.primary.background};\n          color: ${({ theme }) => theme.colors.primary.text};\n        }\n        ${StyledText} {\n          color: ${({ theme }) => theme.colors.primary.text};\n        }\n      }\n    }\n  }\n\n  &[aria-disabled='true'],\n  &:disabled {\n    cursor: not-allowed;\n    filter: grayscale(1) opacity(50%);\n  }\n`\n\ntype TabProps<T extends ElementType = 'button'> = {\n  as?: T\n  badge?: ReactNode\n  children?: ReactNode\n  className?: string\n  counter?: number | string\n  disabled?: boolean\n  onClick?: MouseEventHandler<HTMLElement>\n  onKeyDown?: KeyboardEventHandler<HTMLElement>\n  subtitle?: string\n  tooltip?: string\n  value?: string | number\n} & Omit<\n  ComponentProps<T>,\n  | 'as'\n  | 'badge'\n  | 'children'\n  | 'className'\n  | 'counter'\n  | 'disabled'\n  | 'value'\n  | 'tooltip'\n  | 'role'\n>\n\nexport const Tab = forwardRef(\n  <T extends ElementType = 'button'>(\n    {\n      as,\n      badge,\n      children,\n      className,\n      counter,\n      disabled = false,\n      onClick,\n      onKeyDown,\n      subtitle,\n      tooltip,\n      value,\n      ...props\n    }: TabProps<T>,\n    ref: ForwardedRef<HTMLElement>,\n  ) => {\n    const { selected, onChange } = useTabsContext()\n    const computedAs = as ?? 'button'\n    const isSelected = useMemo(\n      () => value !== undefined && selected === value,\n      [value, selected],\n    )\n\n    return (\n      <StyledTooltip text={tooltip}>\n        <StyledTabButton\n          role=\"tab\"\n          ref={ref as unknown as Ref<HTMLButtonElement>}\n          className={className}\n          as={computedAs}\n          aria-label={value ? `${value}` : undefined}\n          aria-selected={isSelected}\n          aria-disabled={disabled}\n          disabled={computedAs === 'button' ? disabled : undefined}\n          type={computedAs === 'button' ? 'button' : undefined}\n          onClick={event => {\n            if (value !== undefined) {\n              onChange(value)\n            }\n            onClick?.(event)\n          }}\n          onKeyDown={event => {\n            onKeyDown?.(event)\n            if (!event.defaultPrevented && !disabled && value) onChange(value)\n          }}\n          data-is-selected={isSelected}\n          {...props}\n        >\n          <Stack direction=\"column\" gap={0.5}>\n            <Stack direction=\"row\" alignItems=\"center\">\n              {children}\n              {typeof counter === 'number' || typeof counter === 'string' ? (\n                <StyledBadge\n                  sentiment={isSelected ? 'primary' : 'neutral'}\n                  prominence={isSelected ? 'strong' : 'default'}\n                  size=\"medium\"\n                >\n                  {counter}\n                </StyledBadge>\n              ) : null}\n              {badge ? <BadgeContainer>{badge}</BadgeContainer> : null}\n            </Stack>\n            {subtitle ? (\n              <Stack direction=\"row\">\n                <StyledText\n                  as=\"span\"\n                  variant=\"bodySmall\"\n                  sentiment=\"neutral\"\n                  prominence=\"weak\"\n                >\n                  {subtitle}\n                </StyledText>\n              </Stack>\n            ) : null}\n          </Stack>\n        </StyledTabButton>\n      </StyledTooltip>\n    )\n  },\n)\n"]} */");
25
+ const StyledTooltip = /* @__PURE__ */ _styled(Tooltip, process.env.NODE_ENV === "production" ? {
26
+ target: "e1hzf7cr2"
27
+ } : {
28
+ target: "e1hzf7cr2",
29
+ label: "StyledTooltip"
30
+ })(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/Tabs/Tab.tsx"],"names":[],"mappings":"AAwBqC","file":"/home/runner/work/ultraviolet/ultraviolet/packages/ui/src/components/Tabs/Tab.tsx","sourcesContent":["import styled from '@emotion/styled'\nimport type {\n  ComponentProps,\n  ElementType,\n  ForwardedRef,\n  KeyboardEventHandler,\n  MouseEventHandler,\n  ReactNode,\n  Ref,\n} from 'react'\nimport { forwardRef, useMemo } from 'react'\nimport { Badge } from '../Badge'\nimport { Stack } from '../Stack'\nimport { Text } from '../Text'\nimport { Tooltip } from '../Tooltip'\nimport { useTabsContext } from './TabsContext'\n\nconst StyledBadge = styled(Badge)`\n  padding: 0 ${({ theme }) => theme.space['1']};\n  margin-left: ${({ theme }) => theme.space['1']};\n`\n\nconst StyledText = styled(Text)``\n\nconst StyledTooltip = styled(Tooltip)``\n\nconst BadgeContainer = styled.span`\n  margin-left: ${({ theme }) => theme.space['1']};\n  display: flex;\n`\n\nexport const StyledTabButton = styled('button')`\n  display: flex;\n  flex-direction: row;\n  padding: ${({ theme }) => `${theme.space['1']} ${theme.space['2']}`};\n  cursor: pointer;\n  justify-content: center;\n  align-items: baseline;\n  white-space: nowrap;\n  color: ${({ theme }) => theme.colors.neutral.text};\n  text-decoration: none;\n  user-select: none;\n  touch-action: manipulation;\n  transition: color 0.2s;\n  border: none;\n  background: none;\n  border-bottom-width: 2px;\n  border-bottom-style: solid;\n  border-bottom-color: ${({ theme }) => theme.colors.neutral.border};\n  outline: none;\n\n  font-size: ${({ theme }) => theme.typography.bodyStrong.fontSize};\n  font-family: ${({ theme }) => theme.typography.bodyStrong.fontFamily};\n  font-weight: ${({ theme }) => theme.typography.bodyStrong.weight};\n  letter-spacing: ${({ theme }) => theme.typography.bodyStrong.letterSpacing};\n  line-height: ${({ theme }) => theme.typography.bodyStrong.lineHeight};\n\n  &:hover,\n  &:active,\n  &:focus {\n    text-decoration: none;\n    outline: none;\n  }\n\n  &:focus-visible {\n    outline: auto;\n  }\n\n  &[aria-selected='true'] {\n    color: ${({ theme }) => theme.colors.primary.text};\n    border-bottom-color: ${({ theme }) => theme.colors.primary.border};\n\n    ${StyledText} {\n      color: ${({ theme }) => theme.colors.primary.text};\n    }\n  }\n\n  &[aria-disabled='false']:not(:disabled) {\n    &:hover,\n    &:focus,\n    &:active {\n      outline: none;\n      color: ${({ theme }) => theme.colors.primary.text};\n      border-bottom-color: ${({ theme }) => theme.colors.primary.border};\n\n      &[data-is-selected='false'] {\n        ${StyledBadge} {\n          background-color: ${({ theme }) => theme.colors.primary.background};\n          border-color: ${({ theme }) => theme.colors.primary.background};\n          color: ${({ theme }) => theme.colors.primary.text};\n        }\n        ${StyledText} {\n          color: ${({ theme }) => theme.colors.primary.text};\n        }\n      }\n    }\n  }\n\n  &[aria-disabled='true'],\n  &:disabled {\n    cursor: not-allowed;\n    filter: grayscale(1) opacity(50%);\n  }\n`\n\ntype TabProps<T extends ElementType = 'button'> = {\n  as?: T\n  badge?: ReactNode\n  children?: ReactNode\n  className?: string\n  counter?: number | string\n  disabled?: boolean\n  onClick?: MouseEventHandler<HTMLElement>\n  onKeyDown?: KeyboardEventHandler<HTMLElement>\n  subtitle?: string\n  tooltip?: string\n  value?: string | number\n} & Omit<\n  ComponentProps<T>,\n  | 'as'\n  | 'badge'\n  | 'children'\n  | 'className'\n  | 'counter'\n  | 'disabled'\n  | 'value'\n  | 'tooltip'\n  | 'role'\n>\n\nexport const Tab = forwardRef(\n  <T extends ElementType = 'button'>(\n    {\n      as,\n      badge,\n      children,\n      className,\n      counter,\n      disabled = false,\n      onClick,\n      onKeyDown,\n      subtitle,\n      tooltip,\n      value,\n      ...props\n    }: TabProps<T>,\n    ref: ForwardedRef<HTMLElement>,\n  ) => {\n    const { selected, onChange } = useTabsContext()\n    const computedAs = as ?? 'button'\n    const isSelected = useMemo(\n      () => value !== undefined && selected === value,\n      [value, selected],\n    )\n\n    return (\n      <StyledTooltip text={tooltip}>\n        <StyledTabButton\n          role=\"tab\"\n          ref={ref as unknown as Ref<HTMLButtonElement>}\n          className={className}\n          as={computedAs}\n          aria-label={value ? `${value}` : undefined}\n          aria-selected={isSelected}\n          aria-disabled={disabled}\n          disabled={computedAs === 'button' ? disabled : undefined}\n          type={computedAs === 'button' ? 'button' : undefined}\n          onClick={event => {\n            if (value !== undefined) {\n              onChange(value)\n            }\n            onClick?.(event)\n          }}\n          onKeyDown={event => {\n            onKeyDown?.(event)\n            if (!event.defaultPrevented && !disabled && value) onChange(value)\n          }}\n          data-is-selected={isSelected}\n          {...props}\n        >\n          <Stack direction=\"column\" gap={0.5}>\n            <Stack direction=\"row\" alignItems=\"center\">\n              {children}\n              {typeof counter === 'number' || typeof counter === 'string' ? (\n                <StyledBadge\n                  sentiment={isSelected ? 'primary' : 'neutral'}\n                  prominence={isSelected ? 'strong' : 'default'}\n                  size=\"medium\"\n                >\n                  {counter}\n                </StyledBadge>\n              ) : null}\n              {badge ? <BadgeContainer>{badge}</BadgeContainer> : null}\n            </Stack>\n            {subtitle ? (\n              <Stack direction=\"row\">\n                <StyledText\n                  as=\"span\"\n                  variant=\"bodySmall\"\n                  sentiment=\"neutral\"\n                  prominence=\"weak\"\n                >\n                  {subtitle}\n                </StyledText>\n              </Stack>\n            ) : null}\n          </Stack>\n        </StyledTabButton>\n      </StyledTooltip>\n    )\n  },\n)\n"]} */");
31
+ const BadgeContainer = /* @__PURE__ */ _styled("span", process.env.NODE_ENV === "production" ? {
32
+ target: "e1hzf7cr1"
33
+ } : {
34
+ target: "e1hzf7cr1",
35
+ label: "BadgeContainer"
36
+ })("margin-left:", ({
37
+ theme
38
+ }) => theme.space["1"], ";display:flex;" + (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/Tabs/Tab.tsx"],"names":[],"mappings":"AA0BkC","file":"/home/runner/work/ultraviolet/ultraviolet/packages/ui/src/components/Tabs/Tab.tsx","sourcesContent":["import styled from '@emotion/styled'\nimport type {\n  ComponentProps,\n  ElementType,\n  ForwardedRef,\n  KeyboardEventHandler,\n  MouseEventHandler,\n  ReactNode,\n  Ref,\n} from 'react'\nimport { forwardRef, useMemo } from 'react'\nimport { Badge } from '../Badge'\nimport { Stack } from '../Stack'\nimport { Text } from '../Text'\nimport { Tooltip } from '../Tooltip'\nimport { useTabsContext } from './TabsContext'\n\nconst StyledBadge = styled(Badge)`\n  padding: 0 ${({ theme }) => theme.space['1']};\n  margin-left: ${({ theme }) => theme.space['1']};\n`\n\nconst StyledText = styled(Text)``\n\nconst StyledTooltip = styled(Tooltip)``\n\nconst BadgeContainer = styled.span`\n  margin-left: ${({ theme }) => theme.space['1']};\n  display: flex;\n`\n\nexport const StyledTabButton = styled('button')`\n  display: flex;\n  flex-direction: row;\n  padding: ${({ theme }) => `${theme.space['1']} ${theme.space['2']}`};\n  cursor: pointer;\n  justify-content: center;\n  align-items: baseline;\n  white-space: nowrap;\n  color: ${({ theme }) => theme.colors.neutral.text};\n  text-decoration: none;\n  user-select: none;\n  touch-action: manipulation;\n  transition: color 0.2s;\n  border: none;\n  background: none;\n  border-bottom-width: 2px;\n  border-bottom-style: solid;\n  border-bottom-color: ${({ theme }) => theme.colors.neutral.border};\n  outline: none;\n\n  font-size: ${({ theme }) => theme.typography.bodyStrong.fontSize};\n  font-family: ${({ theme }) => theme.typography.bodyStrong.fontFamily};\n  font-weight: ${({ theme }) => theme.typography.bodyStrong.weight};\n  letter-spacing: ${({ theme }) => theme.typography.bodyStrong.letterSpacing};\n  line-height: ${({ theme }) => theme.typography.bodyStrong.lineHeight};\n\n  &:hover,\n  &:active,\n  &:focus {\n    text-decoration: none;\n    outline: none;\n  }\n\n  &:focus-visible {\n    outline: auto;\n  }\n\n  &[aria-selected='true'] {\n    color: ${({ theme }) => theme.colors.primary.text};\n    border-bottom-color: ${({ theme }) => theme.colors.primary.border};\n\n    ${StyledText} {\n      color: ${({ theme }) => theme.colors.primary.text};\n    }\n  }\n\n  &[aria-disabled='false']:not(:disabled) {\n    &:hover,\n    &:focus,\n    &:active {\n      outline: none;\n      color: ${({ theme }) => theme.colors.primary.text};\n      border-bottom-color: ${({ theme }) => theme.colors.primary.border};\n\n      &[data-is-selected='false'] {\n        ${StyledBadge} {\n          background-color: ${({ theme }) => theme.colors.primary.background};\n          border-color: ${({ theme }) => theme.colors.primary.background};\n          color: ${({ theme }) => theme.colors.primary.text};\n        }\n        ${StyledText} {\n          color: ${({ theme }) => theme.colors.primary.text};\n        }\n      }\n    }\n  }\n\n  &[aria-disabled='true'],\n  &:disabled {\n    cursor: not-allowed;\n    filter: grayscale(1) opacity(50%);\n  }\n`\n\ntype TabProps<T extends ElementType = 'button'> = {\n  as?: T\n  badge?: ReactNode\n  children?: ReactNode\n  className?: string\n  counter?: number | string\n  disabled?: boolean\n  onClick?: MouseEventHandler<HTMLElement>\n  onKeyDown?: KeyboardEventHandler<HTMLElement>\n  subtitle?: string\n  tooltip?: string\n  value?: string | number\n} & Omit<\n  ComponentProps<T>,\n  | 'as'\n  | 'badge'\n  | 'children'\n  | 'className'\n  | 'counter'\n  | 'disabled'\n  | 'value'\n  | 'tooltip'\n  | 'role'\n>\n\nexport const Tab = forwardRef(\n  <T extends ElementType = 'button'>(\n    {\n      as,\n      badge,\n      children,\n      className,\n      counter,\n      disabled = false,\n      onClick,\n      onKeyDown,\n      subtitle,\n      tooltip,\n      value,\n      ...props\n    }: TabProps<T>,\n    ref: ForwardedRef<HTMLElement>,\n  ) => {\n    const { selected, onChange } = useTabsContext()\n    const computedAs = as ?? 'button'\n    const isSelected = useMemo(\n      () => value !== undefined && selected === value,\n      [value, selected],\n    )\n\n    return (\n      <StyledTooltip text={tooltip}>\n        <StyledTabButton\n          role=\"tab\"\n          ref={ref as unknown as Ref<HTMLButtonElement>}\n          className={className}\n          as={computedAs}\n          aria-label={value ? `${value}` : undefined}\n          aria-selected={isSelected}\n          aria-disabled={disabled}\n          disabled={computedAs === 'button' ? disabled : undefined}\n          type={computedAs === 'button' ? 'button' : undefined}\n          onClick={event => {\n            if (value !== undefined) {\n              onChange(value)\n            }\n            onClick?.(event)\n          }}\n          onKeyDown={event => {\n            onKeyDown?.(event)\n            if (!event.defaultPrevented && !disabled && value) onChange(value)\n          }}\n          data-is-selected={isSelected}\n          {...props}\n        >\n          <Stack direction=\"column\" gap={0.5}>\n            <Stack direction=\"row\" alignItems=\"center\">\n              {children}\n              {typeof counter === 'number' || typeof counter === 'string' ? (\n                <StyledBadge\n                  sentiment={isSelected ? 'primary' : 'neutral'}\n                  prominence={isSelected ? 'strong' : 'default'}\n                  size=\"medium\"\n                >\n                  {counter}\n                </StyledBadge>\n              ) : null}\n              {badge ? <BadgeContainer>{badge}</BadgeContainer> : null}\n            </Stack>\n            {subtitle ? (\n              <Stack direction=\"row\">\n                <StyledText\n                  as=\"span\"\n                  variant=\"bodySmall\"\n                  sentiment=\"neutral\"\n                  prominence=\"weak\"\n                >\n                  {subtitle}\n                </StyledText>\n              </Stack>\n            ) : null}\n          </Stack>\n        </StyledTabButton>\n      </StyledTooltip>\n    )\n  },\n)\n"]} */"));
39
+ const StyledTabButton = /* @__PURE__ */ _styled("button", process.env.NODE_ENV === "production" ? {
40
+ target: "e1hzf7cr0"
41
+ } : {
42
+ target: "e1hzf7cr0",
43
+ label: "StyledTabButton"
44
+ })("display:flex;flex-direction:row;padding:", ({
45
+ theme
46
+ }) => `${theme.space["1"]} ${theme.space["2"]}`, ";cursor:pointer;justify-content:center;align-items:baseline;white-space:nowrap;color:", ({
47
+ theme
48
+ }) => theme.colors.neutral.text, ";text-decoration:none;user-select:none;touch-action:manipulation;transition:color 0.2s;border:none;background:none;border-bottom-width:2px;border-bottom-style:solid;border-bottom-color:", ({
49
+ theme
50
+ }) => theme.colors.neutral.border, ";outline:none;font-size:", ({
51
+ theme
52
+ }) => theme.typography.bodyStrong.fontSize, ";font-family:", ({
53
+ theme
54
+ }) => theme.typography.bodyStrong.fontFamily, ";font-weight:", ({
55
+ theme
56
+ }) => theme.typography.bodyStrong.weight, ";letter-spacing:", ({
57
+ theme
58
+ }) => theme.typography.bodyStrong.letterSpacing, ";line-height:", ({
59
+ theme
60
+ }) => theme.typography.bodyStrong.lineHeight, ";&:hover,&:active,&:focus{text-decoration:none;outline:none;}&:focus-visible{outline:auto;}&[aria-selected='true']{color:", ({
61
+ theme
62
+ }) => theme.colors.primary.text, ";border-bottom-color:", ({
63
+ theme
64
+ }) => theme.colors.primary.border, ";", StyledText, "{color:", ({
65
+ theme
66
+ }) => theme.colors.primary.text, ";}}&[aria-disabled='false']:not(:disabled){&:hover,&:focus,&:active{outline:none;color:", ({
67
+ theme
68
+ }) => theme.colors.primary.text, ";border-bottom-color:", ({
69
+ theme
70
+ }) => theme.colors.primary.border, ";&[data-is-selected='false']{", StyledBadge, "{background-color:", ({
71
+ theme
72
+ }) => theme.colors.primary.background, ";border-color:", ({
73
+ theme
74
+ }) => theme.colors.primary.background, ";color:", ({
75
+ theme
76
+ }) => theme.colors.primary.text, ";}", StyledText, "{color:", ({
77
+ theme
78
+ }) => theme.colors.primary.text, ";}}}}&[aria-disabled='true'],&:disabled{cursor:not-allowed;filter:grayscale(1) opacity(50%);}" + (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/Tabs/Tab.tsx"],"names":[],"mappings":"AA+B+C","file":"/home/runner/work/ultraviolet/ultraviolet/packages/ui/src/components/Tabs/Tab.tsx","sourcesContent":["import styled from '@emotion/styled'\nimport type {\n  ComponentProps,\n  ElementType,\n  ForwardedRef,\n  KeyboardEventHandler,\n  MouseEventHandler,\n  ReactNode,\n  Ref,\n} from 'react'\nimport { forwardRef, useMemo } from 'react'\nimport { Badge } from '../Badge'\nimport { Stack } from '../Stack'\nimport { Text } from '../Text'\nimport { Tooltip } from '../Tooltip'\nimport { useTabsContext } from './TabsContext'\n\nconst StyledBadge = styled(Badge)`\n  padding: 0 ${({ theme }) => theme.space['1']};\n  margin-left: ${({ theme }) => theme.space['1']};\n`\n\nconst StyledText = styled(Text)``\n\nconst StyledTooltip = styled(Tooltip)``\n\nconst BadgeContainer = styled.span`\n  margin-left: ${({ theme }) => theme.space['1']};\n  display: flex;\n`\n\nexport const StyledTabButton = styled('button')`\n  display: flex;\n  flex-direction: row;\n  padding: ${({ theme }) => `${theme.space['1']} ${theme.space['2']}`};\n  cursor: pointer;\n  justify-content: center;\n  align-items: baseline;\n  white-space: nowrap;\n  color: ${({ theme }) => theme.colors.neutral.text};\n  text-decoration: none;\n  user-select: none;\n  touch-action: manipulation;\n  transition: color 0.2s;\n  border: none;\n  background: none;\n  border-bottom-width: 2px;\n  border-bottom-style: solid;\n  border-bottom-color: ${({ theme }) => theme.colors.neutral.border};\n  outline: none;\n\n  font-size: ${({ theme }) => theme.typography.bodyStrong.fontSize};\n  font-family: ${({ theme }) => theme.typography.bodyStrong.fontFamily};\n  font-weight: ${({ theme }) => theme.typography.bodyStrong.weight};\n  letter-spacing: ${({ theme }) => theme.typography.bodyStrong.letterSpacing};\n  line-height: ${({ theme }) => theme.typography.bodyStrong.lineHeight};\n\n  &:hover,\n  &:active,\n  &:focus {\n    text-decoration: none;\n    outline: none;\n  }\n\n  &:focus-visible {\n    outline: auto;\n  }\n\n  &[aria-selected='true'] {\n    color: ${({ theme }) => theme.colors.primary.text};\n    border-bottom-color: ${({ theme }) => theme.colors.primary.border};\n\n    ${StyledText} {\n      color: ${({ theme }) => theme.colors.primary.text};\n    }\n  }\n\n  &[aria-disabled='false']:not(:disabled) {\n    &:hover,\n    &:focus,\n    &:active {\n      outline: none;\n      color: ${({ theme }) => theme.colors.primary.text};\n      border-bottom-color: ${({ theme }) => theme.colors.primary.border};\n\n      &[data-is-selected='false'] {\n        ${StyledBadge} {\n          background-color: ${({ theme }) => theme.colors.primary.background};\n          border-color: ${({ theme }) => theme.colors.primary.background};\n          color: ${({ theme }) => theme.colors.primary.text};\n        }\n        ${StyledText} {\n          color: ${({ theme }) => theme.colors.primary.text};\n        }\n      }\n    }\n  }\n\n  &[aria-disabled='true'],\n  &:disabled {\n    cursor: not-allowed;\n    filter: grayscale(1) opacity(50%);\n  }\n`\n\ntype TabProps<T extends ElementType = 'button'> = {\n  as?: T\n  badge?: ReactNode\n  children?: ReactNode\n  className?: string\n  counter?: number | string\n  disabled?: boolean\n  onClick?: MouseEventHandler<HTMLElement>\n  onKeyDown?: KeyboardEventHandler<HTMLElement>\n  subtitle?: string\n  tooltip?: string\n  value?: string | number\n} & Omit<\n  ComponentProps<T>,\n  | 'as'\n  | 'badge'\n  | 'children'\n  | 'className'\n  | 'counter'\n  | 'disabled'\n  | 'value'\n  | 'tooltip'\n  | 'role'\n>\n\nexport const Tab = forwardRef(\n  <T extends ElementType = 'button'>(\n    {\n      as,\n      badge,\n      children,\n      className,\n      counter,\n      disabled = false,\n      onClick,\n      onKeyDown,\n      subtitle,\n      tooltip,\n      value,\n      ...props\n    }: TabProps<T>,\n    ref: ForwardedRef<HTMLElement>,\n  ) => {\n    const { selected, onChange } = useTabsContext()\n    const computedAs = as ?? 'button'\n    const isSelected = useMemo(\n      () => value !== undefined && selected === value,\n      [value, selected],\n    )\n\n    return (\n      <StyledTooltip text={tooltip}>\n        <StyledTabButton\n          role=\"tab\"\n          ref={ref as unknown as Ref<HTMLButtonElement>}\n          className={className}\n          as={computedAs}\n          aria-label={value ? `${value}` : undefined}\n          aria-selected={isSelected}\n          aria-disabled={disabled}\n          disabled={computedAs === 'button' ? disabled : undefined}\n          type={computedAs === 'button' ? 'button' : undefined}\n          onClick={event => {\n            if (value !== undefined) {\n              onChange(value)\n            }\n            onClick?.(event)\n          }}\n          onKeyDown={event => {\n            onKeyDown?.(event)\n            if (!event.defaultPrevented && !disabled && value) onChange(value)\n          }}\n          data-is-selected={isSelected}\n          {...props}\n        >\n          <Stack direction=\"column\" gap={0.5}>\n            <Stack direction=\"row\" alignItems=\"center\">\n              {children}\n              {typeof counter === 'number' || typeof counter === 'string' ? (\n                <StyledBadge\n                  sentiment={isSelected ? 'primary' : 'neutral'}\n                  prominence={isSelected ? 'strong' : 'default'}\n                  size=\"medium\"\n                >\n                  {counter}\n                </StyledBadge>\n              ) : null}\n              {badge ? <BadgeContainer>{badge}</BadgeContainer> : null}\n            </Stack>\n            {subtitle ? (\n              <Stack direction=\"row\">\n                <StyledText\n                  as=\"span\"\n                  variant=\"bodySmall\"\n                  sentiment=\"neutral\"\n                  prominence=\"weak\"\n                >\n                  {subtitle}\n                </StyledText>\n              </Stack>\n            ) : null}\n          </Stack>\n        </StyledTabButton>\n      </StyledTooltip>\n    )\n  },\n)\n"]} */"));
79
+ const Tab = forwardRef(({
80
+ as,
81
+ badge,
82
+ children,
83
+ className,
84
+ counter,
85
+ disabled = false,
86
+ onClick,
87
+ onKeyDown,
88
+ subtitle,
89
+ tooltip,
90
+ value,
91
+ ...props
92
+ }, ref) => {
93
+ const {
94
+ selected,
95
+ onChange
96
+ } = useTabsContext();
97
+ const computedAs = as ?? "button";
98
+ const isSelected = useMemo(() => value !== void 0 && selected === value, [value, selected]);
99
+ return /* @__PURE__ */ jsx(StyledTooltip, { text: tooltip, children: /* @__PURE__ */ jsx(StyledTabButton, { role: "tab", ref, className, as: computedAs, "aria-label": value ? `${value}` : void 0, "aria-selected": isSelected, "aria-disabled": disabled, disabled: computedAs === "button" ? disabled : void 0, type: computedAs === "button" ? "button" : void 0, onClick: (event) => {
100
+ if (value !== void 0) {
101
+ onChange(value);
62
102
  }
63
- }
64
-
65
- &[aria-disabled='false']:not(:disabled) {
66
- &:hover,
67
- &:focus,
68
- &:active {
69
- outline: none;
70
- color: ${({ theme }) => theme.colors.primary.text};
71
- border-bottom-color: ${({ theme }) => theme.colors.primary.border};
72
-
73
- &[data-is-selected='false'] {
74
- ${StyledBadge} {
75
- background-color: ${({ theme }) => theme.colors.primary.background};
76
- border-color: ${({ theme }) => theme.colors.primary.background};
77
- color: ${({ theme }) => theme.colors.primary.text};
78
- }
79
- ${StyledText} {
80
- color: ${({ theme }) => theme.colors.primary.text};
81
- }
82
- }
83
- }
84
- }
85
-
86
- &[aria-disabled='true'],
87
- &:disabled {
88
- cursor: not-allowed;
89
- filter: grayscale(1) opacity(50%);
90
- }
91
- `;
92
- const Tab = forwardRef(
93
- ({
94
- as,
95
- badge,
96
- children,
97
- className,
98
- counter,
99
- disabled = false,
100
- onClick,
101
- onKeyDown,
102
- subtitle,
103
- tooltip,
104
- value,
105
- ...props
106
- }, ref) => {
107
- const { selected, onChange } = useTabsContext();
108
- const computedAs = as ?? "button";
109
- const isSelected = useMemo(
110
- () => value !== void 0 && selected === value,
111
- [value, selected]
112
- );
113
- return /* @__PURE__ */ jsx(StyledTooltip, { text: tooltip, children: /* @__PURE__ */ jsx(
114
- StyledTabButton,
115
- {
116
- role: "tab",
117
- ref,
118
- className,
119
- as: computedAs,
120
- "aria-label": value ? `${value}` : void 0,
121
- "aria-selected": isSelected,
122
- "aria-disabled": disabled,
123
- disabled: computedAs === "button" ? disabled : void 0,
124
- type: computedAs === "button" ? "button" : void 0,
125
- onClick: (event) => {
126
- if (value !== void 0) {
127
- onChange(value);
128
- }
129
- onClick?.(event);
130
- },
131
- onKeyDown: (event) => {
132
- onKeyDown?.(event);
133
- if (!event.defaultPrevented && !disabled && value)
134
- onChange(value);
135
- },
136
- "data-is-selected": isSelected,
137
- ...props,
138
- children: /* @__PURE__ */ jsxs(Stack, { direction: "column", gap: 0.5, children: [
139
- /* @__PURE__ */ jsxs(Stack, { direction: "row", alignItems: "center", children: [
140
- children,
141
- typeof counter === "number" || typeof counter === "string" ? /* @__PURE__ */ jsx(
142
- StyledBadge,
143
- {
144
- sentiment: isSelected ? "primary" : "neutral",
145
- prominence: isSelected ? "strong" : "default",
146
- size: "medium",
147
- children: counter
148
- }
149
- ) : null,
150
- badge ? /* @__PURE__ */ jsx(BadgeContainer, { children: badge }) : null
151
- ] }),
152
- subtitle ? /* @__PURE__ */ jsx(Stack, { direction: "row", children: /* @__PURE__ */ jsx(
153
- StyledText,
154
- {
155
- as: "span",
156
- variant: "bodySmall",
157
- sentiment: "neutral",
158
- prominence: "weak",
159
- children: subtitle
160
- }
161
- ) }) : null
162
- ] })
163
- }
164
- ) });
165
- }
166
- );
103
+ onClick?.(event);
104
+ }, onKeyDown: (event) => {
105
+ onKeyDown?.(event);
106
+ if (!event.defaultPrevented && !disabled && value)
107
+ onChange(value);
108
+ }, "data-is-selected": isSelected, ...props, children: /* @__PURE__ */ jsxs(Stack, { direction: "column", gap: 0.5, children: [
109
+ /* @__PURE__ */ jsxs(Stack, { direction: "row", alignItems: "center", children: [
110
+ children,
111
+ typeof counter === "number" || typeof counter === "string" ? /* @__PURE__ */ jsx(StyledBadge, { sentiment: isSelected ? "primary" : "neutral", prominence: isSelected ? "strong" : "default", size: "medium", children: counter }) : null,
112
+ badge ? /* @__PURE__ */ jsx(BadgeContainer, { children: badge }) : null
113
+ ] }),
114
+ subtitle ? /* @__PURE__ */ jsx(Stack, { direction: "row", children: /* @__PURE__ */ jsx(StyledText, { as: "span", variant: "bodySmall", sentiment: "neutral", prominence: "weak", children: subtitle }) }) : null
115
+ ] }) }) });
116
+ });
167
117
  export {
168
118
  StyledTabButton,
169
119
  Tab
@@ -1,63 +1,62 @@
1
1
  import { jsx, jsxs } from "@emotion/react/jsx-runtime";
2
- import styled from "@emotion/styled";
2
+ import _styled from "@emotion/styled/base";
3
3
  import { Icon } from "@ultraviolet/icons";
4
4
  import { forwardRef } from "react";
5
5
  import { MenuV2 } from "../MenuV2/index.js";
6
6
  import { StyledTabButton } from "./Tab.js";
7
- const ArrowIcon = styled(Icon)``;
8
- const StyledMenu = styled(StyledTabButton)`
9
- ${ArrowIcon} {
10
- color: inherit;
11
- margin-left: ${({ theme }) => theme.space["1"]};
12
- transition: 300ms transform ease-out;
13
- }
14
-
15
- &[aria-expanded='true'] ${ArrowIcon} {
16
- transform: rotate(-180deg);
17
- }
18
- `;
19
- const StyledPositioningWrapper = styled.div`
20
- display: flex;
21
- position: sticky;
22
- top: 0;
23
- bottom: 0;
24
- right: 0;
25
- `;
26
- const TabMenu = forwardRef(
27
- ({
28
- children,
29
- disclosure,
7
+ function _EMOTION_STRINGIFIED_CSS_ERROR__() {
8
+ 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).";
9
+ }
10
+ const ArrowIcon = /* @__PURE__ */ _styled(Icon, process.env.NODE_ENV === "production" ? {
11
+ target: "edb1sh92"
12
+ } : {
13
+ target: "edb1sh92",
14
+ label: "ArrowIcon"
15
+ })(process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi9ob21lL3J1bm5lci93b3JrL3VsdHJhdmlvbGV0L3VsdHJhdmlvbGV0L3BhY2thZ2VzL3VpL3NyYy9jb21wb25lbnRzL1RhYnMvVGFiTWVudS50c3giXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBWThCIiwiZmlsZSI6Ii9ob21lL3J1bm5lci93b3JrL3VsdHJhdmlvbGV0L3VsdHJhdmlvbGV0L3BhY2thZ2VzL3VpL3NyYy9jb21wb25lbnRzL1RhYnMvVGFiTWVudS50c3giLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgc3R5bGVkIGZyb20gJ0BlbW90aW9uL3N0eWxlZCdcbmltcG9ydCB7IEljb24gfSBmcm9tICdAdWx0cmF2aW9sZXQvaWNvbnMnXG5pbXBvcnQgdHlwZSB7XG4gIEJ1dHRvbkhUTUxBdHRyaWJ1dGVzLFxuICBDb21wb25lbnRQcm9wcyxcbiAgUmVhY3ROb2RlLFxuICBSZWYsXG59IGZyb20gJ3JlYWN0J1xuaW1wb3J0IHsgZm9yd2FyZFJlZiB9IGZyb20gJ3JlYWN0J1xuaW1wb3J0IHsgTWVudVYyIH0gZnJvbSAnLi4vTWVudVYyJ1xuaW1wb3J0IHsgU3R5bGVkVGFiQnV0dG9uIH0gZnJvbSAnLi9UYWInXG5cbmNvbnN0IEFycm93SWNvbiA9IHN0eWxlZChJY29uKWBgXG5jb25zdCBTdHlsZWRNZW51ID0gc3R5bGVkKFN0eWxlZFRhYkJ1dHRvbilgXG4gICR7QXJyb3dJY29ufSB7XG4gICAgY29sb3I6IGluaGVyaXQ7XG4gICAgbWFyZ2luLWxlZnQ6ICR7KHsgdGhlbWUgfSkgPT4gdGhlbWUuc3BhY2VbJzEnXX07XG4gICAgdHJhbnNpdGlvbjogMzAwbXMgdHJhbnNmb3JtIGVhc2Utb3V0O1xuICB9XG5cbiAgJlthcmlhLWV4cGFuZGVkPSd0cnVlJ10gJHtBcnJvd0ljb259IHtcbiAgICB0cmFuc2Zvcm06IHJvdGF0ZSgtMTgwZGVnKTtcbiAgfVxuYFxuXG4vLyBUaGlzIHdpbGwgd3JhcCBhbmQgZ2l2ZSB0aGUgcG9zaXRpb25pbmcgdG8gdGhlIHBvcHVwIGRpdiB0aGF0IGlzIGFkZGVkIG9udG8gdGhlIGRpc2Nsb3N1cmVcbmNvbnN0IFN0eWxlZFBvc2l0aW9uaW5nV3JhcHBlciA9IHN0eWxlZC5kaXZgXG4gIGRpc3BsYXk6IGZsZXg7XG4gIHBvc2l0aW9uOiBzdGlja3k7XG4gIHRvcDogMDtcbiAgYm90dG9tOiAwO1xuICByaWdodDogMDtcbmBcblxudHlwZSBUYWJNZW51UHJvcHMgPSB7XG4gIGNoaWxkcmVuOiBSZWFjdE5vZGVcbiAgZGlzY2xvc3VyZTogUmVhY3ROb2RlXG4gIHZpc2libGU/OiBDb21wb25lbnRQcm9wczx0eXBlb2YgTWVudVYyPlsndmlzaWJsZSddXG4gIGlkPzogQ29tcG9uZW50UHJvcHM8dHlwZW9mIE1lbnVWMj5bJ2lkJ11cbn0gJiBPbWl0PEJ1dHRvbkhUTUxBdHRyaWJ1dGVzPEhUTUxCdXR0b25FbGVtZW50PiwgJ2FyaWEtZGlzYWJsZWQnPlxuXG5leHBvcnQgY29uc3QgVGFiTWVudSA9IGZvcndhcmRSZWYoXG4gIChcbiAgICB7XG4gICAgICBjaGlsZHJlbixcbiAgICAgIGRpc2Nsb3N1cmUsXG4gICAgICB2aXNpYmxlLFxuICAgICAgaWQsXG4gICAgICBkaXNhYmxlZCxcbiAgICAgIGNsYXNzTmFtZSxcbiAgICAgIC4uLnByb3BzXG4gICAgfTogVGFiTWVudVByb3BzLFxuICAgIHJlZjogUmVmPEhUTUxCdXR0b25FbGVtZW50PixcbiAgKSA9PiAoXG4gICAgPFN0eWxlZFBvc2l0aW9uaW5nV3JhcHBlcj5cbiAgICAgIDxNZW51VjJcbiAgICAgICAgdmlzaWJsZT17dmlzaWJsZX1cbiAgICAgICAgaWQ9e2lkfVxuICAgICAgICByZWY9e3JlZn1cbiAgICAgICAgcG9ydGFsVGFyZ2V0PXtkb2N1bWVudC5ib2R5fSAvLyBXZSBuZWVkIHRvIGF0dGFjaCBpdCB0byB0aGUgYm9keSB0byBhdm9pZCBvdmVyZmxvdyBpc3N1ZXNcbiAgICAgICAgZGlzY2xvc3VyZT17XG4gICAgICAgICAgPFN0eWxlZE1lbnVcbiAgICAgICAgICAgIHJvbGU9XCJ0YWJcIlxuICAgICAgICAgICAgYXJpYS1kaXNhYmxlZD17ZGlzYWJsZWQgPz8gJ2ZhbHNlJ31cbiAgICAgICAgICAgIGRpc2FibGVkPXtkaXNhYmxlZH1cbiAgICAgICAgICAgIGFyaWEtaGFzcG9wdXA9XCJtZW51XCJcbiAgICAgICAgICAgIGNsYXNzTmFtZT17Y2xhc3NOYW1lfVxuICAgICAgICAgICAgey4uLnByb3BzfVxuICAgICAgICAgID5cbiAgICAgICAgICAgIHtkaXNjbG9zdXJlfVxuICAgICAgICAgICAgPEFycm93SWNvbiBuYW1lPVwiYXJyb3ctZG93blwiIC8+XG4gICAgICAgICAgPC9TdHlsZWRNZW51PlxuICAgICAgICB9XG4gICAgICA+XG4gICAgICAgIHtjaGlsZHJlbn1cbiAgICAgIDwvTWVudVYyPlxuICAgIDwvU3R5bGVkUG9zaXRpb25pbmdXcmFwcGVyPlxuICApLFxuKVxuIl19 */");
16
+ const StyledMenu = /* @__PURE__ */ _styled(StyledTabButton, process.env.NODE_ENV === "production" ? {
17
+ target: "edb1sh91"
18
+ } : {
19
+ target: "edb1sh91",
20
+ label: "StyledMenu"
21
+ })(ArrowIcon, "{color:inherit;margin-left:", ({
22
+ theme
23
+ }) => theme.space["1"], ";transition:300ms transform ease-out;}&[aria-expanded='true'] ", ArrowIcon, "{transform:rotate(-180deg);}" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi9ob21lL3J1bm5lci93b3JrL3VsdHJhdmlvbGV0L3VsdHJhdmlvbGV0L3BhY2thZ2VzL3VpL3NyYy9jb21wb25lbnRzL1RhYnMvVGFiTWVudS50c3giXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBYTBDIiwiZmlsZSI6Ii9ob21lL3J1bm5lci93b3JrL3VsdHJhdmlvbGV0L3VsdHJhdmlvbGV0L3BhY2thZ2VzL3VpL3NyYy9jb21wb25lbnRzL1RhYnMvVGFiTWVudS50c3giLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgc3R5bGVkIGZyb20gJ0BlbW90aW9uL3N0eWxlZCdcbmltcG9ydCB7IEljb24gfSBmcm9tICdAdWx0cmF2aW9sZXQvaWNvbnMnXG5pbXBvcnQgdHlwZSB7XG4gIEJ1dHRvbkhUTUxBdHRyaWJ1dGVzLFxuICBDb21wb25lbnRQcm9wcyxcbiAgUmVhY3ROb2RlLFxuICBSZWYsXG59IGZyb20gJ3JlYWN0J1xuaW1wb3J0IHsgZm9yd2FyZFJlZiB9IGZyb20gJ3JlYWN0J1xuaW1wb3J0IHsgTWVudVYyIH0gZnJvbSAnLi4vTWVudVYyJ1xuaW1wb3J0IHsgU3R5bGVkVGFiQnV0dG9uIH0gZnJvbSAnLi9UYWInXG5cbmNvbnN0IEFycm93SWNvbiA9IHN0eWxlZChJY29uKWBgXG5jb25zdCBTdHlsZWRNZW51ID0gc3R5bGVkKFN0eWxlZFRhYkJ1dHRvbilgXG4gICR7QXJyb3dJY29ufSB7XG4gICAgY29sb3I6IGluaGVyaXQ7XG4gICAgbWFyZ2luLWxlZnQ6ICR7KHsgdGhlbWUgfSkgPT4gdGhlbWUuc3BhY2VbJzEnXX07XG4gICAgdHJhbnNpdGlvbjogMzAwbXMgdHJhbnNmb3JtIGVhc2Utb3V0O1xuICB9XG5cbiAgJlthcmlhLWV4cGFuZGVkPSd0cnVlJ10gJHtBcnJvd0ljb259IHtcbiAgICB0cmFuc2Zvcm06IHJvdGF0ZSgtMTgwZGVnKTtcbiAgfVxuYFxuXG4vLyBUaGlzIHdpbGwgd3JhcCBhbmQgZ2l2ZSB0aGUgcG9zaXRpb25pbmcgdG8gdGhlIHBvcHVwIGRpdiB0aGF0IGlzIGFkZGVkIG9udG8gdGhlIGRpc2Nsb3N1cmVcbmNvbnN0IFN0eWxlZFBvc2l0aW9uaW5nV3JhcHBlciA9IHN0eWxlZC5kaXZgXG4gIGRpc3BsYXk6IGZsZXg7XG4gIHBvc2l0aW9uOiBzdGlja3k7XG4gIHRvcDogMDtcbiAgYm90dG9tOiAwO1xuICByaWdodDogMDtcbmBcblxudHlwZSBUYWJNZW51UHJvcHMgPSB7XG4gIGNoaWxkcmVuOiBSZWFjdE5vZGVcbiAgZGlzY2xvc3VyZTogUmVhY3ROb2RlXG4gIHZpc2libGU/OiBDb21wb25lbnRQcm9wczx0eXBlb2YgTWVudVYyPlsndmlzaWJsZSddXG4gIGlkPzogQ29tcG9uZW50UHJvcHM8dHlwZW9mIE1lbnVWMj5bJ2lkJ11cbn0gJiBPbWl0PEJ1dHRvbkhUTUxBdHRyaWJ1dGVzPEhUTUxCdXR0b25FbGVtZW50PiwgJ2FyaWEtZGlzYWJsZWQnPlxuXG5leHBvcnQgY29uc3QgVGFiTWVudSA9IGZvcndhcmRSZWYoXG4gIChcbiAgICB7XG4gICAgICBjaGlsZHJlbixcbiAgICAgIGRpc2Nsb3N1cmUsXG4gICAgICB2aXNpYmxlLFxuICAgICAgaWQsXG4gICAgICBkaXNhYmxlZCxcbiAgICAgIGNsYXNzTmFtZSxcbiAgICAgIC4uLnByb3BzXG4gICAgfTogVGFiTWVudVByb3BzLFxuICAgIHJlZjogUmVmPEhUTUxCdXR0b25FbGVtZW50PixcbiAgKSA9PiAoXG4gICAgPFN0eWxlZFBvc2l0aW9uaW5nV3JhcHBlcj5cbiAgICAgIDxNZW51VjJcbiAgICAgICAgdmlzaWJsZT17dmlzaWJsZX1cbiAgICAgICAgaWQ9e2lkfVxuICAgICAgICByZWY9e3JlZn1cbiAgICAgICAgcG9ydGFsVGFyZ2V0PXtkb2N1bWVudC5ib2R5fSAvLyBXZSBuZWVkIHRvIGF0dGFjaCBpdCB0byB0aGUgYm9keSB0byBhdm9pZCBvdmVyZmxvdyBpc3N1ZXNcbiAgICAgICAgZGlzY2xvc3VyZT17XG4gICAgICAgICAgPFN0eWxlZE1lbnVcbiAgICAgICAgICAgIHJvbGU9XCJ0YWJcIlxuICAgICAgICAgICAgYXJpYS1kaXNhYmxlZD17ZGlzYWJsZWQgPz8gJ2ZhbHNlJ31cbiAgICAgICAgICAgIGRpc2FibGVkPXtkaXNhYmxlZH1cbiAgICAgICAgICAgIGFyaWEtaGFzcG9wdXA9XCJtZW51XCJcbiAgICAgICAgICAgIGNsYXNzTmFtZT17Y2xhc3NOYW1lfVxuICAgICAgICAgICAgey4uLnByb3BzfVxuICAgICAgICAgID5cbiAgICAgICAgICAgIHtkaXNjbG9zdXJlfVxuICAgICAgICAgICAgPEFycm93SWNvbiBuYW1lPVwiYXJyb3ctZG93blwiIC8+XG4gICAgICAgICAgPC9TdHlsZWRNZW51PlxuICAgICAgICB9XG4gICAgICA+XG4gICAgICAgIHtjaGlsZHJlbn1cbiAgICAgIDwvTWVudVYyPlxuICAgIDwvU3R5bGVkUG9zaXRpb25pbmdXcmFwcGVyPlxuICApLFxuKVxuIl19 */"));
24
+ const StyledPositioningWrapper = /* @__PURE__ */ _styled("div", process.env.NODE_ENV === "production" ? {
25
+ target: "edb1sh90"
26
+ } : {
27
+ target: "edb1sh90",
28
+ label: "StyledPositioningWrapper"
29
+ })(process.env.NODE_ENV === "production" ? {
30
+ name: "1hlymjl",
31
+ styles: "display:flex;position:sticky;top:0;bottom:0;right:0"
32
+ } : {
33
+ name: "1hlymjl",
34
+ styles: "display:flex;position:sticky;top:0;bottom:0;right:0",
35
+ map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi9ob21lL3J1bm5lci93b3JrL3VsdHJhdmlvbGV0L3VsdHJhdmlvbGV0L3BhY2thZ2VzL3VpL3NyYy9jb21wb25lbnRzL1RhYnMvVGFiTWVudS50c3giXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBMEIyQyIsImZpbGUiOiIvaG9tZS9ydW5uZXIvd29yay91bHRyYXZpb2xldC91bHRyYXZpb2xldC9wYWNrYWdlcy91aS9zcmMvY29tcG9uZW50cy9UYWJzL1RhYk1lbnUudHN4Iiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHN0eWxlZCBmcm9tICdAZW1vdGlvbi9zdHlsZWQnXG5pbXBvcnQgeyBJY29uIH0gZnJvbSAnQHVsdHJhdmlvbGV0L2ljb25zJ1xuaW1wb3J0IHR5cGUge1xuICBCdXR0b25IVE1MQXR0cmlidXRlcyxcbiAgQ29tcG9uZW50UHJvcHMsXG4gIFJlYWN0Tm9kZSxcbiAgUmVmLFxufSBmcm9tICdyZWFjdCdcbmltcG9ydCB7IGZvcndhcmRSZWYgfSBmcm9tICdyZWFjdCdcbmltcG9ydCB7IE1lbnVWMiB9IGZyb20gJy4uL01lbnVWMidcbmltcG9ydCB7IFN0eWxlZFRhYkJ1dHRvbiB9IGZyb20gJy4vVGFiJ1xuXG5jb25zdCBBcnJvd0ljb24gPSBzdHlsZWQoSWNvbilgYFxuY29uc3QgU3R5bGVkTWVudSA9IHN0eWxlZChTdHlsZWRUYWJCdXR0b24pYFxuICAke0Fycm93SWNvbn0ge1xuICAgIGNvbG9yOiBpbmhlcml0O1xuICAgIG1hcmdpbi1sZWZ0OiAkeyh7IHRoZW1lIH0pID0+IHRoZW1lLnNwYWNlWycxJ119O1xuICAgIHRyYW5zaXRpb246IDMwMG1zIHRyYW5zZm9ybSBlYXNlLW91dDtcbiAgfVxuXG4gICZbYXJpYS1leHBhbmRlZD0ndHJ1ZSddICR7QXJyb3dJY29ufSB7XG4gICAgdHJhbnNmb3JtOiByb3RhdGUoLTE4MGRlZyk7XG4gIH1cbmBcblxuLy8gVGhpcyB3aWxsIHdyYXAgYW5kIGdpdmUgdGhlIHBvc2l0aW9uaW5nIHRvIHRoZSBwb3B1cCBkaXYgdGhhdCBpcyBhZGRlZCBvbnRvIHRoZSBkaXNjbG9zdXJlXG5jb25zdCBTdHlsZWRQb3NpdGlvbmluZ1dyYXBwZXIgPSBzdHlsZWQuZGl2YFxuICBkaXNwbGF5OiBmbGV4O1xuICBwb3NpdGlvbjogc3RpY2t5O1xuICB0b3A6IDA7XG4gIGJvdHRvbTogMDtcbiAgcmlnaHQ6IDA7XG5gXG5cbnR5cGUgVGFiTWVudVByb3BzID0ge1xuICBjaGlsZHJlbjogUmVhY3ROb2RlXG4gIGRpc2Nsb3N1cmU6IFJlYWN0Tm9kZVxuICB2aXNpYmxlPzogQ29tcG9uZW50UHJvcHM8dHlwZW9mIE1lbnVWMj5bJ3Zpc2libGUnXVxuICBpZD86IENvbXBvbmVudFByb3BzPHR5cGVvZiBNZW51VjI+WydpZCddXG59ICYgT21pdDxCdXR0b25IVE1MQXR0cmlidXRlczxIVE1MQnV0dG9uRWxlbWVudD4sICdhcmlhLWRpc2FibGVkJz5cblxuZXhwb3J0IGNvbnN0IFRhYk1lbnUgPSBmb3J3YXJkUmVmKFxuICAoXG4gICAge1xuICAgICAgY2hpbGRyZW4sXG4gICAgICBkaXNjbG9zdXJlLFxuICAgICAgdmlzaWJsZSxcbiAgICAgIGlkLFxuICAgICAgZGlzYWJsZWQsXG4gICAgICBjbGFzc05hbWUsXG4gICAgICAuLi5wcm9wc1xuICAgIH06IFRhYk1lbnVQcm9wcyxcbiAgICByZWY6IFJlZjxIVE1MQnV0dG9uRWxlbWVudD4sXG4gICkgPT4gKFxuICAgIDxTdHlsZWRQb3NpdGlvbmluZ1dyYXBwZXI+XG4gICAgICA8TWVudVYyXG4gICAgICAgIHZpc2libGU9e3Zpc2libGV9XG4gICAgICAgIGlkPXtpZH1cbiAgICAgICAgcmVmPXtyZWZ9XG4gICAgICAgIHBvcnRhbFRhcmdldD17ZG9jdW1lbnQuYm9keX0gLy8gV2UgbmVlZCB0byBhdHRhY2ggaXQgdG8gdGhlIGJvZHkgdG8gYXZvaWQgb3ZlcmZsb3cgaXNzdWVzXG4gICAgICAgIGRpc2Nsb3N1cmU9e1xuICAgICAgICAgIDxTdHlsZWRNZW51XG4gICAgICAgICAgICByb2xlPVwidGFiXCJcbiAgICAgICAgICAgIGFyaWEtZGlzYWJsZWQ9e2Rpc2FibGVkID8/ICdmYWxzZSd9XG4gICAgICAgICAgICBkaXNhYmxlZD17ZGlzYWJsZWR9XG4gICAgICAgICAgICBhcmlhLWhhc3BvcHVwPVwibWVudVwiXG4gICAgICAgICAgICBjbGFzc05hbWU9e2NsYXNzTmFtZX1cbiAgICAgICAgICAgIHsuLi5wcm9wc31cbiAgICAgICAgICA+XG4gICAgICAgICAgICB7ZGlzY2xvc3VyZX1cbiAgICAgICAgICAgIDxBcnJvd0ljb24gbmFtZT1cImFycm93LWRvd25cIiAvPlxuICAgICAgICAgIDwvU3R5bGVkTWVudT5cbiAgICAgICAgfVxuICAgICAgPlxuICAgICAgICB7Y2hpbGRyZW59XG4gICAgICA8L01lbnVWMj5cbiAgICA8L1N0eWxlZFBvc2l0aW9uaW5nV3JhcHBlcj5cbiAgKSxcbilcbiJdfQ== */",
36
+ toString: _EMOTION_STRINGIFIED_CSS_ERROR__
37
+ });
38
+ const TabMenu = forwardRef(({
39
+ children,
40
+ disclosure,
41
+ visible,
42
+ id,
43
+ disabled,
44
+ className,
45
+ ...props
46
+ }, ref) => /* @__PURE__ */ jsx(StyledPositioningWrapper, { children: /* @__PURE__ */ jsx(
47
+ MenuV2,
48
+ {
30
49
  visible,
31
50
  id,
32
- disabled,
33
- className,
34
- ...props
35
- }, ref) => /* @__PURE__ */ jsx(StyledPositioningWrapper, { children: /* @__PURE__ */ jsx(
36
- MenuV2,
37
- {
38
- visible,
39
- id,
40
- ref,
41
- portalTarget: document.body,
42
- disclosure: /* @__PURE__ */ jsxs(
43
- StyledMenu,
44
- {
45
- role: "tab",
46
- "aria-disabled": disabled ?? "false",
47
- disabled,
48
- "aria-haspopup": "menu",
49
- className,
50
- ...props,
51
- children: [
52
- disclosure,
53
- /* @__PURE__ */ jsx(ArrowIcon, { name: "arrow-down" })
54
- ]
55
- }
56
- ),
57
- children
58
- }
59
- ) })
60
- );
51
+ ref,
52
+ portalTarget: document.body,
53
+ disclosure: /* @__PURE__ */ jsxs(StyledMenu, { role: "tab", "aria-disabled": disabled ?? "false", disabled, "aria-haspopup": "menu", className, ...props, children: [
54
+ disclosure,
55
+ /* @__PURE__ */ jsx(ArrowIcon, { name: "arrow-down" })
56
+ ] }),
57
+ children
58
+ }
59
+ ) }));
61
60
  export {
62
61
  TabMenu
63
62
  };
@@ -1,38 +1,33 @@
1
1
  import { jsx } from "@emotion/react/jsx-runtime";
2
- import styled from "@emotion/styled";
2
+ import _styled from "@emotion/styled/base";
3
3
  import { useMemo } from "react";
4
4
  import Item from "../MenuV2/Item.js";
5
5
  import { useTabsContext } from "./TabsContext.js";
6
- const StyledMenuItem = styled(Item)`
7
- &[aria-selected='true'] {
8
- color: ${({ theme }) => theme.colors.primary.text};
9
- }
10
- `;
6
+ const StyledMenuItem = /* @__PURE__ */ _styled(Item, process.env.NODE_ENV === "production" ? {
7
+ target: "eeet93f0"
8
+ } : {
9
+ target: "eeet93f0",
10
+ label: "StyledMenuItem"
11
+ })("&[aria-selected='true']{color:", ({
12
+ theme
13
+ }) => theme.colors.primary.text, ";}" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi9ob21lL3J1bm5lci93b3JrL3VsdHJhdmlvbGV0L3VsdHJhdmlvbGV0L3BhY2thZ2VzL3VpL3NyYy9jb21wb25lbnRzL1RhYnMvVGFiTWVudUl0ZW0udHN4Il0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQU1tQyIsImZpbGUiOiIvaG9tZS9ydW5uZXIvd29yay91bHRyYXZpb2xldC91bHRyYXZpb2xldC9wYWNrYWdlcy91aS9zcmMvY29tcG9uZW50cy9UYWJzL1RhYk1lbnVJdGVtLnRzeCIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCBzdHlsZWQgZnJvbSAnQGVtb3Rpb24vc3R5bGVkJ1xuaW1wb3J0IHR5cGUgeyBDb21wb25lbnRQcm9wcyB9IGZyb20gJ3JlYWN0J1xuaW1wb3J0IHsgdXNlTWVtbyB9IGZyb20gJ3JlYWN0J1xuaW1wb3J0IEl0ZW0gZnJvbSAnLi4vTWVudVYyL0l0ZW0nXG5pbXBvcnQgeyB1c2VUYWJzQ29udGV4dCB9IGZyb20gJy4vVGFic0NvbnRleHQnXG5cbmNvbnN0IFN0eWxlZE1lbnVJdGVtID0gc3R5bGVkKEl0ZW0pYFxuICAmW2FyaWEtc2VsZWN0ZWQ9J3RydWUnXSB7XG4gICAgY29sb3I6ICR7KHsgdGhlbWUgfSkgPT4gdGhlbWUuY29sb3JzLnByaW1hcnkudGV4dH07XG4gIH1cbmBcblxudHlwZSBUYWJNZW51SXRlbVByb3BzID0ge1xuICB2YWx1ZT86IHN0cmluZyB8IG51bWJlclxufSAmIENvbXBvbmVudFByb3BzPHR5cGVvZiBTdHlsZWRNZW51SXRlbT5cblxuZXhwb3J0IGNvbnN0IFRhYk1lbnVJdGVtID0gKHtcbiAgdmFsdWUsXG4gIGNoaWxkcmVuLFxuICBvbkNsaWNrLFxuICAuLi5wcm9wc1xufTogVGFiTWVudUl0ZW1Qcm9wcykgPT4ge1xuICBjb25zdCB7IHNlbGVjdGVkLCBvbkNoYW5nZSB9ID0gdXNlVGFic0NvbnRleHQoKVxuXG4gIGNvbnN0IGlzU2VsZWN0ZWQgPSB1c2VNZW1vKFxuICAgICgpID0+IHZhbHVlICE9PSB1bmRlZmluZWQgJiYgc2VsZWN0ZWQgPT09IHZhbHVlLFxuICAgIFt2YWx1ZSwgc2VsZWN0ZWRdLFxuICApXG5cbiAgcmV0dXJuIChcbiAgICA8U3R5bGVkTWVudUl0ZW1cbiAgICAgIG9uQ2xpY2s9e2V2ZW50ID0+IHtcbiAgICAgICAgaWYgKHZhbHVlICE9PSB1bmRlZmluZWQpIHtcbiAgICAgICAgICBvbkNoYW5nZSh2YWx1ZSlcbiAgICAgICAgfVxuICAgICAgICBvbkNsaWNrPy4oZXZlbnQpXG4gICAgICB9fVxuICAgICAgYXJpYS1zZWxlY3RlZD17aXNTZWxlY3RlZH1cbiAgICAgIHsuLi5wcm9wc31cbiAgICA+XG4gICAgICB7Y2hpbGRyZW59XG4gICAgPC9TdHlsZWRNZW51SXRlbT5cbiAgKVxufVxuIl19 */"));
11
14
  const TabMenuItem = ({
12
15
  value,
13
16
  children,
14
17
  onClick,
15
18
  ...props
16
19
  }) => {
17
- const { selected, onChange } = useTabsContext();
18
- const isSelected = useMemo(
19
- () => value !== void 0 && selected === value,
20
- [value, selected]
21
- );
22
- return /* @__PURE__ */ jsx(
23
- StyledMenuItem,
24
- {
25
- onClick: (event) => {
26
- if (value !== void 0) {
27
- onChange(value);
28
- }
29
- onClick?.(event);
30
- },
31
- "aria-selected": isSelected,
32
- ...props,
33
- children
20
+ const {
21
+ selected,
22
+ onChange
23
+ } = useTabsContext();
24
+ const isSelected = useMemo(() => value !== void 0 && selected === value, [value, selected]);
25
+ return /* @__PURE__ */ jsx(StyledMenuItem, { onClick: (event) => {
26
+ if (value !== void 0) {
27
+ onChange(value);
34
28
  }
35
- );
29
+ onClick?.(event);
30
+ }, "aria-selected": isSelected, ...props, children });
36
31
  };
37
32
  export {
38
33
  TabMenuItem
@@ -1,7 +1,5 @@
1
1
  import { createContext, useContext } from "react";
2
- const TabsContext = createContext(
3
- {}
4
- );
2
+ const TabsContext = createContext({});
5
3
  const useTabsContext = () => useContext(TabsContext);
6
4
  export {
7
5
  TabsContext,