@ultraviolet/ui 1.51.3 → 1.51.5

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 (156) hide show
  1. package/dist/components/ActionBar/index.cjs +32 -0
  2. package/dist/components/Alert/index.cjs +117 -0
  3. package/dist/components/Avatar/index.cjs +59 -0
  4. package/dist/components/Badge/index.cjs +101 -0
  5. package/dist/components/Banner/assets/default-image-small.svg.cjs +3 -0
  6. package/dist/components/Banner/assets/default-image.svg.cjs +3 -0
  7. package/dist/components/Banner/index.cjs +118 -0
  8. package/dist/components/BarChart/Tooltip.cjs +42 -0
  9. package/dist/components/BarChart/index.cjs +69 -0
  10. package/dist/components/BarStack/index.cjs +116 -0
  11. package/dist/components/Breadcrumbs/index.cjs +75 -0
  12. package/dist/components/Bullet/index.cjs +86 -0
  13. package/dist/components/Button/index.cjs +251 -0
  14. package/dist/components/Card/index.cjs +54 -0
  15. package/dist/components/Carousel/index.cjs +125 -0
  16. package/dist/components/Checkbox/index.cjs +264 -0
  17. package/dist/components/CheckboxGroup/index.cjs +118 -0
  18. package/dist/components/CopyButton/index.cjs +25 -0
  19. package/dist/components/DateInput/datepicker.css.cjs +3 -0
  20. package/dist/components/DateInput/index.cjs +185 -0
  21. package/dist/components/Dialog/Context.cjs +13 -0
  22. package/dist/components/Dialog/index.cjs +68 -0
  23. package/dist/components/Dialog/index.d.ts +4 -4
  24. package/dist/components/Dialog/subComponents/Button.cjs +15 -0
  25. package/dist/components/Dialog/subComponents/Buttons.cjs +12 -0
  26. package/dist/components/Dialog/subComponents/CancelButton.cjs +9 -0
  27. package/dist/components/Dialog/subComponents/Stack.cjs +8 -0
  28. package/dist/components/Dialog/subComponents/Text.cjs +8 -0
  29. package/dist/components/EmptyState/index.cjs +92 -0
  30. package/dist/components/Expandable/index.cjs +77 -0
  31. package/dist/components/GlobalAlert/GlobalAlertLink.cjs +23 -0
  32. package/dist/components/GlobalAlert/index.cjs +61 -0
  33. package/dist/components/LineChart/CustomLegend.cjs +115 -0
  34. package/dist/components/LineChart/Tooltip.cjs +37 -0
  35. package/dist/components/LineChart/helpers.cjs +52 -0
  36. package/dist/components/LineChart/index.cjs +101 -0
  37. package/dist/components/Link/index.cjs +130 -0
  38. package/dist/components/List/Body.cjs +18 -0
  39. package/dist/components/List/Cell.cjs +43 -0
  40. package/dist/components/List/HeaderCell.cjs +84 -0
  41. package/dist/components/List/HeaderRow.cjs +38 -0
  42. package/dist/components/List/ListContext.cjs +136 -0
  43. package/dist/components/List/Row.cjs +163 -0
  44. package/dist/components/List/SelectBar.cjs +54 -0
  45. package/dist/components/List/SkeletonRows.cjs +57 -0
  46. package/dist/components/List/constants.cjs +6 -0
  47. package/dist/components/List/index.cjs +62 -0
  48. package/dist/components/Loader/index.cjs +79 -0
  49. package/dist/components/Menu/Item.cjs +92 -0
  50. package/dist/components/Menu/index.cjs +118 -0
  51. package/dist/components/MenuV2/Group.cjs +23 -0
  52. package/dist/components/MenuV2/Item.cjs +114 -0
  53. package/dist/components/MenuV2/index.cjs +92 -0
  54. package/dist/components/Meter/index.cjs +65 -0
  55. package/dist/components/Modal/Dialog.cjs +143 -0
  56. package/dist/components/Modal/Disclosure.cjs +44 -0
  57. package/dist/components/Modal/constants.cjs +52 -0
  58. package/dist/components/Modal/index.cjs +81 -0
  59. package/dist/components/Notice/index.cjs +25 -0
  60. package/dist/components/Notification/index.cjs +49 -0
  61. package/dist/components/Notification/react-toastify.css.cjs +3 -0
  62. package/dist/components/NumberInput/helpers.cjs +10 -0
  63. package/dist/components/NumberInput/index.cjs +264 -0
  64. package/dist/components/NumberInputV2/index.cjs +223 -0
  65. package/dist/components/Pagination/getPageNumbers.cjs +23 -0
  66. package/dist/components/Pagination/index.cjs +90 -0
  67. package/dist/components/PasswordCheck/index.cjs +26 -0
  68. package/dist/components/PasswordStrengthMeter/index.cjs +98 -0
  69. package/dist/components/PieChart/Legends.cjs +143 -0
  70. package/dist/components/PieChart/Tooltip.cjs +50 -0
  71. package/dist/components/PieChart/index.cjs +103 -0
  72. package/dist/components/Popover/index.cjs +102 -0
  73. package/dist/components/Popup/animations.cjs +25 -0
  74. package/dist/components/Popup/helpers.cjs +216 -0
  75. package/dist/components/Popup/index.cjs +299 -0
  76. package/dist/components/ProgressBar/index.cjs +55 -0
  77. package/dist/components/Radio/index.cjs +135 -0
  78. package/dist/components/RadioGroup/index.cjs +101 -0
  79. package/dist/components/Row/index.cjs +36 -0
  80. package/dist/components/SelectInput/index.cjs +520 -0
  81. package/dist/components/SelectInputV2/Dropdown.cjs +431 -0
  82. package/dist/components/SelectInputV2/Dropdown.js +14 -14
  83. package/dist/components/SelectInputV2/DropdownOption.cjs +64 -0
  84. package/dist/components/SelectInputV2/SearchBarDropdown.cjs +109 -0
  85. package/dist/components/SelectInputV2/SelectBar.cjs +227 -0
  86. package/dist/components/SelectInputV2/SelectBar.d.ts +2 -1
  87. package/dist/components/SelectInputV2/SelectBar.js +8 -7
  88. package/dist/components/SelectInputV2/SelectInputProvider.cjs +182 -0
  89. package/dist/components/SelectInputV2/SelectInputProvider.d.ts +3 -2
  90. package/dist/components/SelectInputV2/SelectInputProvider.js +15 -4
  91. package/dist/components/SelectInputV2/findOptionInOptions.cjs +12 -0
  92. package/dist/components/SelectInputV2/index.cjs +91 -0
  93. package/dist/components/SelectInputV2/index.js +8 -6
  94. package/dist/components/SelectInputV2/types.cjs +13 -0
  95. package/dist/components/SelectableCard/index.cjs +139 -0
  96. package/dist/components/SelectableCardGroup/index.cjs +109 -0
  97. package/dist/components/Separator/index.cjs +58 -0
  98. package/dist/components/Skeleton/Block.cjs +40 -0
  99. package/dist/components/Skeleton/Blocks.cjs +40 -0
  100. package/dist/components/Skeleton/BoxWithIcon.cjs +38 -0
  101. package/dist/components/Skeleton/Donut.cjs +63 -0
  102. package/dist/components/Skeleton/IconSkeleton.cjs +24 -0
  103. package/dist/components/Skeleton/Line.cjs +18 -0
  104. package/dist/components/Skeleton/List.cjs +58 -0
  105. package/dist/components/Skeleton/Slider.cjs +42 -0
  106. package/dist/components/Skeleton/Square.cjs +14 -0
  107. package/dist/components/Skeleton/index.cjs +81 -0
  108. package/dist/components/Snippet/index.cjs +184 -0
  109. package/dist/components/Stack/index.cjs +31 -0
  110. package/dist/components/Status/index.cjs +74 -0
  111. package/dist/components/StepList/index.cjs +60 -0
  112. package/dist/components/Stepper/index.cjs +147 -0
  113. package/dist/components/SwitchButton/FocusOverlay.cjs +40 -0
  114. package/dist/components/SwitchButton/index.cjs +78 -0
  115. package/dist/components/Table/Body.cjs +7 -0
  116. package/dist/components/Table/Cell.cjs +21 -0
  117. package/dist/components/Table/Header.cjs +18 -0
  118. package/dist/components/Table/HeaderCell.cjs +82 -0
  119. package/dist/components/Table/HeaderRow.cjs +23 -0
  120. package/dist/components/Table/Row.cjs +82 -0
  121. package/dist/components/Table/SelectBar.cjs +54 -0
  122. package/dist/components/Table/SkeletonRows.cjs +56 -0
  123. package/dist/components/Table/TableContext.cjs +88 -0
  124. package/dist/components/Table/index.cjs +69 -0
  125. package/dist/components/Tabs/Tab.cjs +122 -0
  126. package/dist/components/Tabs/TabMenu.cjs +64 -0
  127. package/dist/components/Tabs/TabMenuItem.cjs +36 -0
  128. package/dist/components/Tabs/TabsContext.cjs +7 -0
  129. package/dist/components/Tabs/index.cjs +104 -0
  130. package/dist/components/Tag/index.cjs +147 -0
  131. package/dist/components/TagInput/index.cjs +255 -0
  132. package/dist/components/TagList/index.cjs +100 -0
  133. package/dist/components/Text/index.cjs +84 -0
  134. package/dist/components/TextArea/index.cjs +160 -0
  135. package/dist/components/TextInput/index.cjs +390 -0
  136. package/dist/components/TextInputV2/index.cjs +192 -0
  137. package/dist/components/TimeInput/index.cjs +28 -0
  138. package/dist/components/Toaster/index.cjs +85 -0
  139. package/dist/components/Toaster/react-toastify.css.cjs +3 -0
  140. package/dist/components/Toggle/index.cjs +138 -0
  141. package/dist/components/ToggleGroup/index.cjs +98 -0
  142. package/dist/components/Tooltip/index.cjs +42 -0
  143. package/dist/components/VerificationCode/index.cjs +219 -0
  144. package/dist/helpers/isJSON.cjs +10 -0
  145. package/dist/helpers/legend.cjs +14 -0
  146. package/dist/helpers/recursivelyGetChildrenString.cjs +14 -0
  147. package/dist/hooks/useIsOverflowing.cjs +23 -0
  148. package/dist/index.cjs +196 -0
  149. package/dist/theme/index.cjs +34 -0
  150. package/dist/utils/animations.cjs +276 -0
  151. package/dist/utils/capitalize.cjs +3 -0
  152. package/dist/utils/ids.cjs +8 -0
  153. package/dist/utils/normalize.cjs +36 -0
  154. package/dist/utils/responsive/Breakpoint.cjs +16 -0
  155. package/dist/utils/responsive/utilities.cjs +15 -0
  156. package/package.json +24 -6
@@ -0,0 +1,122 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, Symbol.toStringTag, { value: "Module" });
3
+ const jsxRuntime = require("@emotion/react/jsx-runtime");
4
+ const _styled = require("@emotion/styled/base");
5
+ const React = require("react");
6
+ const index = require("../Badge/index.cjs");
7
+ const index$3 = require("../Stack/index.cjs");
8
+ const index$1 = require("../Text/index.cjs");
9
+ const index$2 = require("../Tooltip/index.cjs");
10
+ const TabsContext = require("./TabsContext.cjs");
11
+ const _interopDefaultCompat = (e) => e && typeof e === "object" && "default" in e ? e : { default: e };
12
+ const _styled__default = /* @__PURE__ */ _interopDefaultCompat(_styled);
13
+ const StyledBadge = /* @__PURE__ */ _styled__default.default(index.Badge, process.env.NODE_ENV === "production" ? {
14
+ target: "e1hzf7cr4"
15
+ } : {
16
+ target: "e1hzf7cr4",
17
+ label: "StyledBadge"
18
+ })("padding:0 ", ({
19
+ theme
20
+ }) => theme.space["1"], ";margin-left:", ({
21
+ theme
22
+ }) => 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"]} */"));
23
+ const StyledText = /* @__PURE__ */ _styled__default.default(index$1.Text, process.env.NODE_ENV === "production" ? {
24
+ target: "e1hzf7cr3"
25
+ } : {
26
+ target: "e1hzf7cr3",
27
+ label: "StyledText"
28
+ })(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"]} */");
29
+ const StyledTooltip = /* @__PURE__ */ _styled__default.default(index$2.Tooltip, process.env.NODE_ENV === "production" ? {
30
+ target: "e1hzf7cr2"
31
+ } : {
32
+ target: "e1hzf7cr2",
33
+ label: "StyledTooltip"
34
+ })(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"]} */");
35
+ const BadgeContainer = /* @__PURE__ */ _styled__default.default("span", process.env.NODE_ENV === "production" ? {
36
+ target: "e1hzf7cr1"
37
+ } : {
38
+ target: "e1hzf7cr1",
39
+ label: "BadgeContainer"
40
+ })("margin-left:", ({
41
+ theme
42
+ }) => 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"]} */"));
43
+ const StyledTabButton = /* @__PURE__ */ _styled__default.default("button", process.env.NODE_ENV === "production" ? {
44
+ target: "e1hzf7cr0"
45
+ } : {
46
+ target: "e1hzf7cr0",
47
+ label: "StyledTabButton"
48
+ })("display:flex;flex-direction:row;padding:", ({
49
+ theme
50
+ }) => `${theme.space["1"]} ${theme.space["2"]}`, ";cursor:pointer;justify-content:center;align-items:baseline;white-space:nowrap;color:", ({
51
+ theme
52
+ }) => 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:", ({
53
+ theme
54
+ }) => theme.colors.neutral.border, ";outline:none;font-size:", ({
55
+ theme
56
+ }) => theme.typography.bodyStrong.fontSize, ";font-family:", ({
57
+ theme
58
+ }) => theme.typography.bodyStrong.fontFamily, ";font-weight:", ({
59
+ theme
60
+ }) => theme.typography.bodyStrong.weight, ";letter-spacing:", ({
61
+ theme
62
+ }) => theme.typography.bodyStrong.letterSpacing, ";line-height:", ({
63
+ theme
64
+ }) => theme.typography.bodyStrong.lineHeight, ";&:hover,&:active,&:focus{text-decoration:none;outline:none;}&:focus-visible{outline:auto;}&[aria-selected='true']{color:", ({
65
+ theme
66
+ }) => theme.colors.primary.text, ";border-bottom-color:", ({
67
+ theme
68
+ }) => theme.colors.primary.border, ";", StyledText, "{color:", ({
69
+ theme
70
+ }) => theme.colors.primary.text, ";}}&[aria-disabled='false']:not(:disabled){&:hover,&:focus,&:active{outline:none;color:", ({
71
+ theme
72
+ }) => theme.colors.primary.text, ";border-bottom-color:", ({
73
+ theme
74
+ }) => theme.colors.primary.border, ";&[data-is-selected='false']{", StyledBadge, "{background-color:", ({
75
+ theme
76
+ }) => theme.colors.primary.background, ";border-color:", ({
77
+ theme
78
+ }) => theme.colors.primary.background, ";color:", ({
79
+ theme
80
+ }) => theme.colors.primary.text, ";}", StyledText, "{color:", ({
81
+ theme
82
+ }) => 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"]} */"));
83
+ const Tab = React.forwardRef(({
84
+ as,
85
+ badge,
86
+ children,
87
+ className,
88
+ counter,
89
+ disabled = false,
90
+ onClick,
91
+ onKeyDown,
92
+ subtitle,
93
+ tooltip,
94
+ value,
95
+ ...props
96
+ }, ref) => {
97
+ const {
98
+ selected,
99
+ onChange
100
+ } = TabsContext.useTabsContext();
101
+ const computedAs = as ?? "button";
102
+ const isSelected = React.useMemo(() => value !== void 0 && selected === value, [value, selected]);
103
+ return /* @__PURE__ */ jsxRuntime.jsx(StyledTooltip, { text: tooltip, children: /* @__PURE__ */ jsxRuntime.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) => {
104
+ if (value !== void 0) {
105
+ onChange(value);
106
+ }
107
+ onClick?.(event);
108
+ }, onKeyDown: (event) => {
109
+ onKeyDown?.(event);
110
+ if (!event.defaultPrevented && !disabled && value)
111
+ onChange(value);
112
+ }, "data-is-selected": isSelected, ...props, children: /* @__PURE__ */ jsxRuntime.jsxs(index$3.Stack, { direction: "column", gap: 0.5, children: [
113
+ /* @__PURE__ */ jsxRuntime.jsxs(index$3.Stack, { direction: "row", alignItems: "center", children: [
114
+ children,
115
+ typeof counter === "number" || typeof counter === "string" ? /* @__PURE__ */ jsxRuntime.jsx(StyledBadge, { sentiment: isSelected ? "primary" : "neutral", prominence: isSelected ? "strong" : "default", size: "medium", children: counter }) : null,
116
+ badge ? /* @__PURE__ */ jsxRuntime.jsx(BadgeContainer, { children: badge }) : null
117
+ ] }),
118
+ subtitle ? /* @__PURE__ */ jsxRuntime.jsx(index$3.Stack, { direction: "row", children: /* @__PURE__ */ jsxRuntime.jsx(StyledText, { as: "span", variant: "bodySmall", sentiment: "neutral", prominence: "weak", children: subtitle }) }) : null
119
+ ] }) }) });
120
+ });
121
+ exports.StyledTabButton = StyledTabButton;
122
+ exports.Tab = Tab;
@@ -0,0 +1,64 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, Symbol.toStringTag, { value: "Module" });
3
+ const jsxRuntime = require("@emotion/react/jsx-runtime");
4
+ const _styled = require("@emotion/styled/base");
5
+ const icons = require("@ultraviolet/icons");
6
+ const React = require("react");
7
+ const index = require("../MenuV2/index.cjs");
8
+ const Tab = require("./Tab.cjs");
9
+ const _interopDefaultCompat = (e) => e && typeof e === "object" && "default" in e ? e : { default: e };
10
+ const _styled__default = /* @__PURE__ */ _interopDefaultCompat(_styled);
11
+ function _EMOTION_STRINGIFIED_CSS_ERROR__() {
12
+ 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).";
13
+ }
14
+ const ArrowIcon = /* @__PURE__ */ _styled__default.default(icons.Icon, process.env.NODE_ENV === "production" ? {
15
+ target: "edb1sh92"
16
+ } : {
17
+ target: "edb1sh92",
18
+ label: "ArrowIcon"
19
+ })(process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi9ob21lL3J1bm5lci93b3JrL3VsdHJhdmlvbGV0L3VsdHJhdmlvbGV0L3BhY2thZ2VzL3VpL3NyYy9jb21wb25lbnRzL1RhYnMvVGFiTWVudS50c3giXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBWThCIiwiZmlsZSI6Ii9ob21lL3J1bm5lci93b3JrL3VsdHJhdmlvbGV0L3VsdHJhdmlvbGV0L3BhY2thZ2VzL3VpL3NyYy9jb21wb25lbnRzL1RhYnMvVGFiTWVudS50c3giLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgc3R5bGVkIGZyb20gJ0BlbW90aW9uL3N0eWxlZCdcbmltcG9ydCB7IEljb24gfSBmcm9tICdAdWx0cmF2aW9sZXQvaWNvbnMnXG5pbXBvcnQgdHlwZSB7XG4gIEJ1dHRvbkhUTUxBdHRyaWJ1dGVzLFxuICBDb21wb25lbnRQcm9wcyxcbiAgUmVhY3ROb2RlLFxuICBSZWYsXG59IGZyb20gJ3JlYWN0J1xuaW1wb3J0IHsgZm9yd2FyZFJlZiB9IGZyb20gJ3JlYWN0J1xuaW1wb3J0IHsgTWVudVYyIH0gZnJvbSAnLi4vTWVudVYyJ1xuaW1wb3J0IHsgU3R5bGVkVGFiQnV0dG9uIH0gZnJvbSAnLi9UYWInXG5cbmNvbnN0IEFycm93SWNvbiA9IHN0eWxlZChJY29uKWBgXG5jb25zdCBTdHlsZWRNZW51ID0gc3R5bGVkKFN0eWxlZFRhYkJ1dHRvbilgXG4gICR7QXJyb3dJY29ufSB7XG4gICAgY29sb3I6IGluaGVyaXQ7XG4gICAgbWFyZ2luLWxlZnQ6ICR7KHsgdGhlbWUgfSkgPT4gdGhlbWUuc3BhY2VbJzEnXX07XG4gICAgdHJhbnNpdGlvbjogMzAwbXMgdHJhbnNmb3JtIGVhc2Utb3V0O1xuICB9XG5cbiAgJlthcmlhLWV4cGFuZGVkPSd0cnVlJ10gJHtBcnJvd0ljb259IHtcbiAgICB0cmFuc2Zvcm06IHJvdGF0ZSgtMTgwZGVnKTtcbiAgfVxuYFxuXG4vLyBUaGlzIHdpbGwgd3JhcCBhbmQgZ2l2ZSB0aGUgcG9zaXRpb25pbmcgdG8gdGhlIHBvcHVwIGRpdiB0aGF0IGlzIGFkZGVkIG9udG8gdGhlIGRpc2Nsb3N1cmVcbmNvbnN0IFN0eWxlZFBvc2l0aW9uaW5nV3JhcHBlciA9IHN0eWxlZC5kaXZgXG4gIGRpc3BsYXk6IGZsZXg7XG4gIHBvc2l0aW9uOiBzdGlja3k7XG4gIHRvcDogMDtcbiAgYm90dG9tOiAwO1xuICByaWdodDogMDtcbmBcblxudHlwZSBUYWJNZW51UHJvcHMgPSB7XG4gIGNoaWxkcmVuOiBSZWFjdE5vZGVcbiAgZGlzY2xvc3VyZTogUmVhY3ROb2RlXG4gIHZpc2libGU/OiBDb21wb25lbnRQcm9wczx0eXBlb2YgTWVudVYyPlsndmlzaWJsZSddXG4gIGlkPzogQ29tcG9uZW50UHJvcHM8dHlwZW9mIE1lbnVWMj5bJ2lkJ11cbn0gJiBPbWl0PEJ1dHRvbkhUTUxBdHRyaWJ1dGVzPEhUTUxCdXR0b25FbGVtZW50PiwgJ2FyaWEtZGlzYWJsZWQnPlxuXG5leHBvcnQgY29uc3QgVGFiTWVudSA9IGZvcndhcmRSZWYoXG4gIChcbiAgICB7XG4gICAgICBjaGlsZHJlbixcbiAgICAgIGRpc2Nsb3N1cmUsXG4gICAgICB2aXNpYmxlLFxuICAgICAgaWQsXG4gICAgICBkaXNhYmxlZCxcbiAgICAgIGNsYXNzTmFtZSxcbiAgICAgIC4uLnByb3BzXG4gICAgfTogVGFiTWVudVByb3BzLFxuICAgIHJlZjogUmVmPEhUTUxCdXR0b25FbGVtZW50PixcbiAgKSA9PiAoXG4gICAgPFN0eWxlZFBvc2l0aW9uaW5nV3JhcHBlcj5cbiAgICAgIDxNZW51VjJcbiAgICAgICAgdmlzaWJsZT17dmlzaWJsZX1cbiAgICAgICAgaWQ9e2lkfVxuICAgICAgICByZWY9e3JlZn1cbiAgICAgICAgcG9ydGFsVGFyZ2V0PXtkb2N1bWVudC5ib2R5fSAvLyBXZSBuZWVkIHRvIGF0dGFjaCBpdCB0byB0aGUgYm9keSB0byBhdm9pZCBvdmVyZmxvdyBpc3N1ZXNcbiAgICAgICAgZGlzY2xvc3VyZT17XG4gICAgICAgICAgPFN0eWxlZE1lbnVcbiAgICAgICAgICAgIHJvbGU9XCJ0YWJcIlxuICAgICAgICAgICAgYXJpYS1kaXNhYmxlZD17ZGlzYWJsZWQgPz8gJ2ZhbHNlJ31cbiAgICAgICAgICAgIGRpc2FibGVkPXtkaXNhYmxlZH1cbiAgICAgICAgICAgIGFyaWEtaGFzcG9wdXA9XCJtZW51XCJcbiAgICAgICAgICAgIGNsYXNzTmFtZT17Y2xhc3NOYW1lfVxuICAgICAgICAgICAgey4uLnByb3BzfVxuICAgICAgICAgID5cbiAgICAgICAgICAgIHtkaXNjbG9zdXJlfVxuICAgICAgICAgICAgPEFycm93SWNvbiBuYW1lPVwiYXJyb3ctZG93blwiIC8+XG4gICAgICAgICAgPC9TdHlsZWRNZW51PlxuICAgICAgICB9XG4gICAgICA+XG4gICAgICAgIHtjaGlsZHJlbn1cbiAgICAgIDwvTWVudVYyPlxuICAgIDwvU3R5bGVkUG9zaXRpb25pbmdXcmFwcGVyPlxuICApLFxuKVxuIl19 */");
20
+ const StyledMenu = /* @__PURE__ */ _styled__default.default(Tab.StyledTabButton, process.env.NODE_ENV === "production" ? {
21
+ target: "edb1sh91"
22
+ } : {
23
+ target: "edb1sh91",
24
+ label: "StyledMenu"
25
+ })(ArrowIcon, "{color:inherit;margin-left:", ({
26
+ theme
27
+ }) => 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 */"));
28
+ const StyledPositioningWrapper = /* @__PURE__ */ _styled__default.default("div", process.env.NODE_ENV === "production" ? {
29
+ target: "edb1sh90"
30
+ } : {
31
+ target: "edb1sh90",
32
+ label: "StyledPositioningWrapper"
33
+ })(process.env.NODE_ENV === "production" ? {
34
+ name: "1hlymjl",
35
+ styles: "display:flex;position:sticky;top:0;bottom:0;right:0"
36
+ } : {
37
+ name: "1hlymjl",
38
+ styles: "display:flex;position:sticky;top:0;bottom:0;right:0",
39
+ map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi9ob21lL3J1bm5lci93b3JrL3VsdHJhdmlvbGV0L3VsdHJhdmlvbGV0L3BhY2thZ2VzL3VpL3NyYy9jb21wb25lbnRzL1RhYnMvVGFiTWVudS50c3giXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBMEIyQyIsImZpbGUiOiIvaG9tZS9ydW5uZXIvd29yay91bHRyYXZpb2xldC91bHRyYXZpb2xldC9wYWNrYWdlcy91aS9zcmMvY29tcG9uZW50cy9UYWJzL1RhYk1lbnUudHN4Iiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHN0eWxlZCBmcm9tICdAZW1vdGlvbi9zdHlsZWQnXG5pbXBvcnQgeyBJY29uIH0gZnJvbSAnQHVsdHJhdmlvbGV0L2ljb25zJ1xuaW1wb3J0IHR5cGUge1xuICBCdXR0b25IVE1MQXR0cmlidXRlcyxcbiAgQ29tcG9uZW50UHJvcHMsXG4gIFJlYWN0Tm9kZSxcbiAgUmVmLFxufSBmcm9tICdyZWFjdCdcbmltcG9ydCB7IGZvcndhcmRSZWYgfSBmcm9tICdyZWFjdCdcbmltcG9ydCB7IE1lbnVWMiB9IGZyb20gJy4uL01lbnVWMidcbmltcG9ydCB7IFN0eWxlZFRhYkJ1dHRvbiB9IGZyb20gJy4vVGFiJ1xuXG5jb25zdCBBcnJvd0ljb24gPSBzdHlsZWQoSWNvbilgYFxuY29uc3QgU3R5bGVkTWVudSA9IHN0eWxlZChTdHlsZWRUYWJCdXR0b24pYFxuICAke0Fycm93SWNvbn0ge1xuICAgIGNvbG9yOiBpbmhlcml0O1xuICAgIG1hcmdpbi1sZWZ0OiAkeyh7IHRoZW1lIH0pID0+IHRoZW1lLnNwYWNlWycxJ119O1xuICAgIHRyYW5zaXRpb246IDMwMG1zIHRyYW5zZm9ybSBlYXNlLW91dDtcbiAgfVxuXG4gICZbYXJpYS1leHBhbmRlZD0ndHJ1ZSddICR7QXJyb3dJY29ufSB7XG4gICAgdHJhbnNmb3JtOiByb3RhdGUoLTE4MGRlZyk7XG4gIH1cbmBcblxuLy8gVGhpcyB3aWxsIHdyYXAgYW5kIGdpdmUgdGhlIHBvc2l0aW9uaW5nIHRvIHRoZSBwb3B1cCBkaXYgdGhhdCBpcyBhZGRlZCBvbnRvIHRoZSBkaXNjbG9zdXJlXG5jb25zdCBTdHlsZWRQb3NpdGlvbmluZ1dyYXBwZXIgPSBzdHlsZWQuZGl2YFxuICBkaXNwbGF5OiBmbGV4O1xuICBwb3NpdGlvbjogc3RpY2t5O1xuICB0b3A6IDA7XG4gIGJvdHRvbTogMDtcbiAgcmlnaHQ6IDA7XG5gXG5cbnR5cGUgVGFiTWVudVByb3BzID0ge1xuICBjaGlsZHJlbjogUmVhY3ROb2RlXG4gIGRpc2Nsb3N1cmU6IFJlYWN0Tm9kZVxuICB2aXNpYmxlPzogQ29tcG9uZW50UHJvcHM8dHlwZW9mIE1lbnVWMj5bJ3Zpc2libGUnXVxuICBpZD86IENvbXBvbmVudFByb3BzPHR5cGVvZiBNZW51VjI+WydpZCddXG59ICYgT21pdDxCdXR0b25IVE1MQXR0cmlidXRlczxIVE1MQnV0dG9uRWxlbWVudD4sICdhcmlhLWRpc2FibGVkJz5cblxuZXhwb3J0IGNvbnN0IFRhYk1lbnUgPSBmb3J3YXJkUmVmKFxuICAoXG4gICAge1xuICAgICAgY2hpbGRyZW4sXG4gICAgICBkaXNjbG9zdXJlLFxuICAgICAgdmlzaWJsZSxcbiAgICAgIGlkLFxuICAgICAgZGlzYWJsZWQsXG4gICAgICBjbGFzc05hbWUsXG4gICAgICAuLi5wcm9wc1xuICAgIH06IFRhYk1lbnVQcm9wcyxcbiAgICByZWY6IFJlZjxIVE1MQnV0dG9uRWxlbWVudD4sXG4gICkgPT4gKFxuICAgIDxTdHlsZWRQb3NpdGlvbmluZ1dyYXBwZXI+XG4gICAgICA8TWVudVYyXG4gICAgICAgIHZpc2libGU9e3Zpc2libGV9XG4gICAgICAgIGlkPXtpZH1cbiAgICAgICAgcmVmPXtyZWZ9XG4gICAgICAgIHBvcnRhbFRhcmdldD17ZG9jdW1lbnQuYm9keX0gLy8gV2UgbmVlZCB0byBhdHRhY2ggaXQgdG8gdGhlIGJvZHkgdG8gYXZvaWQgb3ZlcmZsb3cgaXNzdWVzXG4gICAgICAgIGRpc2Nsb3N1cmU9e1xuICAgICAgICAgIDxTdHlsZWRNZW51XG4gICAgICAgICAgICByb2xlPVwidGFiXCJcbiAgICAgICAgICAgIGFyaWEtZGlzYWJsZWQ9e2Rpc2FibGVkID8/ICdmYWxzZSd9XG4gICAgICAgICAgICBkaXNhYmxlZD17ZGlzYWJsZWR9XG4gICAgICAgICAgICBhcmlhLWhhc3BvcHVwPVwibWVudVwiXG4gICAgICAgICAgICBjbGFzc05hbWU9e2NsYXNzTmFtZX1cbiAgICAgICAgICAgIHsuLi5wcm9wc31cbiAgICAgICAgICA+XG4gICAgICAgICAgICB7ZGlzY2xvc3VyZX1cbiAgICAgICAgICAgIDxBcnJvd0ljb24gbmFtZT1cImFycm93LWRvd25cIiAvPlxuICAgICAgICAgIDwvU3R5bGVkTWVudT5cbiAgICAgICAgfVxuICAgICAgPlxuICAgICAgICB7Y2hpbGRyZW59XG4gICAgICA8L01lbnVWMj5cbiAgICA8L1N0eWxlZFBvc2l0aW9uaW5nV3JhcHBlcj5cbiAgKSxcbilcbiJdfQ== */",
40
+ toString: _EMOTION_STRINGIFIED_CSS_ERROR__
41
+ });
42
+ const TabMenu = React.forwardRef(({
43
+ children,
44
+ disclosure,
45
+ visible,
46
+ id,
47
+ disabled,
48
+ className,
49
+ ...props
50
+ }, ref) => /* @__PURE__ */ jsxRuntime.jsx(StyledPositioningWrapper, { children: /* @__PURE__ */ jsxRuntime.jsx(
51
+ index.MenuV2,
52
+ {
53
+ visible,
54
+ id,
55
+ ref,
56
+ portalTarget: document.body,
57
+ disclosure: /* @__PURE__ */ jsxRuntime.jsxs(StyledMenu, { role: "tab", "aria-disabled": disabled ?? "false", disabled, "aria-haspopup": "menu", className, ...props, children: [
58
+ disclosure,
59
+ /* @__PURE__ */ jsxRuntime.jsx(ArrowIcon, { name: "arrow-down" })
60
+ ] }),
61
+ children
62
+ }
63
+ ) }));
64
+ exports.TabMenu = TabMenu;
@@ -0,0 +1,36 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, Symbol.toStringTag, { value: "Module" });
3
+ const jsxRuntime = require("@emotion/react/jsx-runtime");
4
+ const _styled = require("@emotion/styled/base");
5
+ const React = require("react");
6
+ const Item = require("../MenuV2/Item.cjs");
7
+ const TabsContext = require("./TabsContext.cjs");
8
+ const _interopDefaultCompat = (e) => e && typeof e === "object" && "default" in e ? e : { default: e };
9
+ const _styled__default = /* @__PURE__ */ _interopDefaultCompat(_styled);
10
+ const StyledMenuItem = /* @__PURE__ */ _styled__default.default(Item, process.env.NODE_ENV === "production" ? {
11
+ target: "eeet93f0"
12
+ } : {
13
+ target: "eeet93f0",
14
+ label: "StyledMenuItem"
15
+ })("&[aria-selected='true']{color:", ({
16
+ theme
17
+ }) => theme.colors.primary.text, ";}" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi9ob21lL3J1bm5lci93b3JrL3VsdHJhdmlvbGV0L3VsdHJhdmlvbGV0L3BhY2thZ2VzL3VpL3NyYy9jb21wb25lbnRzL1RhYnMvVGFiTWVudUl0ZW0udHN4Il0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQU1tQyIsImZpbGUiOiIvaG9tZS9ydW5uZXIvd29yay91bHRyYXZpb2xldC91bHRyYXZpb2xldC9wYWNrYWdlcy91aS9zcmMvY29tcG9uZW50cy9UYWJzL1RhYk1lbnVJdGVtLnRzeCIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCBzdHlsZWQgZnJvbSAnQGVtb3Rpb24vc3R5bGVkJ1xuaW1wb3J0IHR5cGUgeyBDb21wb25lbnRQcm9wcyB9IGZyb20gJ3JlYWN0J1xuaW1wb3J0IHsgdXNlTWVtbyB9IGZyb20gJ3JlYWN0J1xuaW1wb3J0IEl0ZW0gZnJvbSAnLi4vTWVudVYyL0l0ZW0nXG5pbXBvcnQgeyB1c2VUYWJzQ29udGV4dCB9IGZyb20gJy4vVGFic0NvbnRleHQnXG5cbmNvbnN0IFN0eWxlZE1lbnVJdGVtID0gc3R5bGVkKEl0ZW0pYFxuICAmW2FyaWEtc2VsZWN0ZWQ9J3RydWUnXSB7XG4gICAgY29sb3I6ICR7KHsgdGhlbWUgfSkgPT4gdGhlbWUuY29sb3JzLnByaW1hcnkudGV4dH07XG4gIH1cbmBcblxudHlwZSBUYWJNZW51SXRlbVByb3BzID0ge1xuICB2YWx1ZT86IHN0cmluZyB8IG51bWJlclxufSAmIENvbXBvbmVudFByb3BzPHR5cGVvZiBTdHlsZWRNZW51SXRlbT5cblxuZXhwb3J0IGNvbnN0IFRhYk1lbnVJdGVtID0gKHtcbiAgdmFsdWUsXG4gIGNoaWxkcmVuLFxuICBvbkNsaWNrLFxuICAuLi5wcm9wc1xufTogVGFiTWVudUl0ZW1Qcm9wcykgPT4ge1xuICBjb25zdCB7IHNlbGVjdGVkLCBvbkNoYW5nZSB9ID0gdXNlVGFic0NvbnRleHQoKVxuXG4gIGNvbnN0IGlzU2VsZWN0ZWQgPSB1c2VNZW1vKFxuICAgICgpID0+IHZhbHVlICE9PSB1bmRlZmluZWQgJiYgc2VsZWN0ZWQgPT09IHZhbHVlLFxuICAgIFt2YWx1ZSwgc2VsZWN0ZWRdLFxuICApXG5cbiAgcmV0dXJuIChcbiAgICA8U3R5bGVkTWVudUl0ZW1cbiAgICAgIG9uQ2xpY2s9e2V2ZW50ID0+IHtcbiAgICAgICAgaWYgKHZhbHVlICE9PSB1bmRlZmluZWQpIHtcbiAgICAgICAgICBvbkNoYW5nZSh2YWx1ZSlcbiAgICAgICAgfVxuICAgICAgICBvbkNsaWNrPy4oZXZlbnQpXG4gICAgICB9fVxuICAgICAgYXJpYS1zZWxlY3RlZD17aXNTZWxlY3RlZH1cbiAgICAgIHsuLi5wcm9wc31cbiAgICA+XG4gICAgICB7Y2hpbGRyZW59XG4gICAgPC9TdHlsZWRNZW51SXRlbT5cbiAgKVxufVxuIl19 */"));
18
+ const TabMenuItem = ({
19
+ value,
20
+ children,
21
+ onClick,
22
+ ...props
23
+ }) => {
24
+ const {
25
+ selected,
26
+ onChange
27
+ } = TabsContext.useTabsContext();
28
+ const isSelected = React.useMemo(() => value !== void 0 && selected === value, [value, selected]);
29
+ return /* @__PURE__ */ jsxRuntime.jsx(StyledMenuItem, { onClick: (event) => {
30
+ if (value !== void 0) {
31
+ onChange(value);
32
+ }
33
+ onClick?.(event);
34
+ }, "aria-selected": isSelected, ...props, children });
35
+ };
36
+ exports.TabMenuItem = TabMenuItem;
@@ -0,0 +1,7 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, Symbol.toStringTag, { value: "Module" });
3
+ const React = require("react");
4
+ const TabsContext = React.createContext({});
5
+ const useTabsContext = () => React.useContext(TabsContext);
6
+ exports.TabsContext = TabsContext;
7
+ exports.useTabsContext = useTabsContext;
@@ -0,0 +1,104 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, Symbol.toStringTag, { value: "Module" });
3
+ const jsxRuntime = require("@emotion/react/jsx-runtime");
4
+ const _styled = require("@emotion/styled/base");
5
+ const React = require("react");
6
+ const Tab = require("./Tab.cjs");
7
+ const TabMenu = require("./TabMenu.cjs");
8
+ const TabMenuItem = require("./TabMenuItem.cjs");
9
+ const TabsContext = require("./TabsContext.cjs");
10
+ const _interopDefaultCompat = (e) => e && typeof e === "object" && "default" in e ? e : { default: e };
11
+ const _styled__default = /* @__PURE__ */ _interopDefaultCompat(_styled);
12
+ const MenuContainer = /* @__PURE__ */ _styled__default.default("div", process.env.NODE_ENV === "production" ? {
13
+ target: "ewug27g2"
14
+ } : {
15
+ target: "ewug27g2",
16
+ label: "MenuContainer"
17
+ })("display:flex;flex-direction:column;", Tab.StyledTabButton, "{font-size:", ({
18
+ theme
19
+ }) => theme.typography.bodySmall.fontSize, ";line-height:", ({
20
+ theme
21
+ }) => theme.typography.bodySmall.lineHeight, ";font-weight:inherit;padding:", ({
22
+ theme
23
+ }) => `${theme.space["1"]} ${theme.space["2"]}`, ";border-bottom-width:1.5px;width:100%;cursor:pointer;min-width:110px;background-color:transparent;&[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,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi9ob21lL3J1bm5lci93b3JrL3VsdHJhdmlvbGV0L3VsdHJhdmlvbGV0L3BhY2thZ2VzL3VpL3NyYy9jb21wb25lbnRzL1RhYnMvaW5kZXgudHN4Il0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQWdCZ0MiLCJmaWxlIjoiL2hvbWUvcnVubmVyL3dvcmsvdWx0cmF2aW9sZXQvdWx0cmF2aW9sZXQvcGFja2FnZXMvdWkvc3JjL2NvbXBvbmVudHMvVGFicy9pbmRleC50c3giLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgc3R5bGVkIGZyb20gJ0BlbW90aW9uL3N0eWxlZCdcbmltcG9ydCB7XG4gIENoaWxkcmVuLFxuICBjbG9uZUVsZW1lbnQsXG4gIGlzVmFsaWRFbGVtZW50LFxuICB1c2VFZmZlY3QsXG4gIHVzZU1lbW8sXG4gIHVzZVJlZixcbiAgdXNlU3RhdGUsXG59IGZyb20gJ3JlYWN0J1xuaW1wb3J0IHR5cGUgeyBIVE1MQXR0cmlidXRlcywgUmVhY3RFbGVtZW50LCBSZWFjdE5vZGUgfSBmcm9tICdyZWFjdCdcbmltcG9ydCB7IFN0eWxlZFRhYkJ1dHRvbiwgVGFiIH0gZnJvbSAnLi9UYWInXG5pbXBvcnQgeyBUYWJNZW51IH0gZnJvbSAnLi9UYWJNZW51J1xuaW1wb3J0IHsgVGFiTWVudUl0ZW0gfSBmcm9tICcuL1RhYk1lbnVJdGVtJ1xuaW1wb3J0IHsgVGFic0NvbnRleHQgfSBmcm9tICcuL1RhYnNDb250ZXh0J1xuXG5jb25zdCBNZW51Q29udGFpbmVyID0gc3R5bGVkLmRpdmBcbiAgZGlzcGxheTogZmxleDtcbiAgZmxleC1kaXJlY3Rpb246IGNvbHVtbjtcblxuICAke1N0eWxlZFRhYkJ1dHRvbn0ge1xuICAgIGZvbnQtc2l6ZTogJHsoeyB0aGVtZSB9KSA9PiB0aGVtZS50eXBvZ3JhcGh5LmJvZHlTbWFsbC5mb250U2l6ZX07XG4gICAgbGluZS1oZWlnaHQ6ICR7KHsgdGhlbWUgfSkgPT4gdGhlbWUudHlwb2dyYXBoeS5ib2R5U21hbGwubGluZUhlaWdodH07XG4gICAgZm9udC13ZWlnaHQ6IGluaGVyaXQ7XG4gICAgcGFkZGluZzogJHsoeyB0aGVtZSB9KSA9PiBgJHt0aGVtZS5zcGFjZVsnMSddfSAke3RoZW1lLnNwYWNlWycyJ119YH07XG4gICAgYm9yZGVyLWJvdHRvbS13aWR0aDogMS41cHg7XG4gICAgd2lkdGg6IDEwMCU7XG4gICAgY3Vyc29yOiBwb2ludGVyO1xuICAgIG1pbi13aWR0aDogMTEwcHg7XG4gICAgYmFja2dyb3VuZC1jb2xvcjogdHJhbnNwYXJlbnQ7XG4gICAgJlthcmlhLWRpc2FibGVkPSd0cnVlJ10sXG4gICAgJjpkaXNhYmxlZCB7XG4gICAgICBjdXJzb3I6IG5vdC1hbGxvd2VkO1xuICAgICAgZmlsdGVyOiBncmF5c2NhbGUoMSkgb3BhY2l0eSg1MCUpO1xuICAgIH1cbiAgfVxuYFxuXG4vLyBNaWdyYXRpb24gdG8gTWVudVYyIHdpbGwgbm90IHdvcmsgYXMgZXhwZWN0ZWQgaGVyZS5cbmNvbnN0IFN0eWxlZFRhYk1lbnUgPSBzdHlsZWQoVGFiTWVudSlgXG4gIHBvc2l0aW9uOiBzdGlja3k7XG4gIHJpZ2h0OiAwO1xuICB0b3A6IDA7XG4gIGJvdHRvbTogMDtcbiAgYmFja2dyb3VuZDogJHsoeyB0aGVtZSB9KSA9PiB0aGVtZS5jb2xvcnMubmV1dHJhbC5iYWNrZ3JvdW5kfTtcbiAgYm94LXNoYWRvdzogJHsoeyB0aGVtZSB9KSA9PiB0aGVtZS5zaGFkb3dzLm1lbnV9O1xuYFxuXG5jb25zdCBUYWJzQ29udGFpbmVyID0gc3R5bGVkLmRpdmBcbiAgZGlzcGxheTogZmxleDtcbiAgZmxleC13cmFwOiBub3dyYXA7XG4gIG92ZXJmbG93LXg6IHNjcm9sbDtcbiAgcG9zaXRpb246IHJlbGF0aXZlO1xuICB6LWluZGV4OiAwO1xuICAtbXMtb3ZlcmZsb3ctc3R5bGU6IG5vbmU7IC8qIElFIGFuZCBFZGdlICovXG4gIHNjcm9sbGJhci13aWR0aDogbm9uZTsgLyogRmlyZWZveCAqL1xuXG4gICY6OmFmdGVyIHtcbiAgICB6LWluZGV4OiAtMTtcbiAgICBjb250ZW50OiAnJztcbiAgICBwb3NpdGlvbjogYWJzb2x1dGU7XG4gICAgYm90dG9tOiAwO1xuICAgIGxlZnQ6IDA7XG4gICAgcmlnaHQ6IDA7XG4gICAgaGVpZ2h0OiAycHg7XG4gICAgYmFja2dyb3VuZDogJHsoeyB0aGVtZSB9KSA9PiB0aGVtZS5jb2xvcnMubmV1dHJhbC5ib3JkZXJ9O1xuICB9XG5cbiAgJjo6LXdlYmtpdC1zY3JvbGxiYXIge1xuICAgIGRpc3BsYXk6IG5vbmU7XG4gIH1cbmBcblxudHlwZSBUYWJzUHJvcHMgPSB7XG4gIHNlbGVjdGVkPzogc3RyaW5nIHwgbnVtYmVyXG4gIG9uQ2hhbmdlOiAoZGF0YTogc3RyaW5nIHwgbnVtYmVyKSA9PiB2b2lkXG4gIG1vcmVEaXNjbG9zdXJlPzogUmVhY3ROb2RlXG4gIGNsYXNzTmFtZT86IHN0cmluZ1xuICAnZGF0YS10ZXN0aWQnPzogc3RyaW5nXG59ICYgT21pdDxIVE1MQXR0cmlidXRlczxIVE1MRWxlbWVudD4sICdvbkNoYW5nZScgfCAncm9sZSc+XG5cbmNvbnN0IFNIQURPV19USFJFU0hPTEQgPSAxMFxuXG4vKipcbiAqIFRhYnMgY29tcG9uZW50IGlzIHVzZWQgdG8gZGlzcGxheSBhIHNldCBvZiB0YWJzIHdpdGggYSBzaW5nbGUgdGFiIHNlbGVjdGVkIGF0IGEgdGltZS5cbiAqL1xuZXhwb3J0IGNvbnN0IFRhYnMgPSAoe1xuICBjaGlsZHJlbiA9IG51bGwsXG4gIG9uQ2hhbmdlLFxuICBtb3JlRGlzY2xvc3VyZSA9ICdNb3JlJyxcbiAgc2VsZWN0ZWQsXG4gIGNsYXNzTmFtZSxcbiAgJ2RhdGEtdGVzdGlkJzogZGF0YVRlc3RJZCxcbiAgLi4ucHJvcHNcbn06IFRhYnNQcm9wcykgPT4ge1xuICBjb25zdCB0YWJzUmVmID0gdXNlUmVmPEhUTUxEaXZFbGVtZW50Pih7fSBhcyBIVE1MRGl2RWxlbWVudClcbiAgY29uc3QgbW9yZVN0YXRpY1JlZiA9IHVzZVJlZjxIVE1MQnV0dG9uRWxlbWVudD4obnVsbClcbiAgY29uc3QgW2Rpc3BsYXlNb3JlLCBzZXREaXNwbGF5TW9yZV0gPSB1c2VTdGF0ZShmYWxzZSlcbiAgY29uc3QgdmFsdWUgPSB1c2VNZW1vKFxuICAgICgpID0+ICh7XG4gICAgICBvbkNoYW5nZSxcbiAgICAgIHNlbGVjdGVkLFxuICAgIH0pLFxuICAgIFtzZWxlY3RlZCwgb25DaGFuZ2VdLFxuICApXG5cbiAgdXNlRWZmZWN0KCgpID0+IHtcbiAgICBzZXREaXNwbGF5TW9yZSh0YWJzUmVmLmN1cnJlbnQuc2Nyb2xsV2lkdGggPiB0YWJzUmVmLmN1cnJlbnQuY2xpZW50V2lkdGgpXG4gIH0sIFtjaGlsZHJlbl0pXG5cbiAgLy8gU2Nyb2xsIGF1dG9tYXRpY2FsbHkgdG8gdGhlIHRhYlxuICB1c2VFZmZlY3QoKCkgPT4ge1xuICAgIGNvbnN0IHRhYiA9IHRhYnNSZWYuY3VycmVudC5xdWVyeVNlbGVjdG9yKFxuICAgICAgYFtyb2xlPSd0YWInXVthcmlhLXNlbGVjdGVkPSd0cnVlJ11gLFxuICAgICkgYXMgSFRNTEVsZW1lbnRcblxuICAgIGlmICh0YWIgJiYgdGFic1JlZi5jdXJyZW50LnNjcm9sbFRvKSB7XG4gICAgICB0YWJzUmVmLmN1cnJlbnQuc2Nyb2xsVG8oeyBsZWZ0OiB0YWIub2Zmc2V0TGVmdCwgYmVoYXZpb3I6ICdzbW9vdGgnIH0pXG4gICAgfVxuICB9LCBbc2VsZWN0ZWRdKVxuXG4gIC8vIENoYW5nZSB0aGUgbW9yZUJ1dHRvbiBzdHlsZSBhdXRvbWF0aWNhbGx5IGJhc2VkIG9uIHRoZSBzY3JvbGwgdG8gc2hvdyB0aGF0IGEgc2Nyb2xsIGVmZmVjdCBpcyBwb3NzaWJsZS5cbiAgdXNlRWZmZWN0KCgpID0+IHtcbiAgICBjb25zdCBlbGVtZW50ID0gdGFic1JlZi5jdXJyZW50XG4gICAgY29uc3QgbW9yZUVsZW1lbnQgPSBtb3JlU3RhdGljUmVmLmN1cnJlbnRcbiAgICBjb25zdCBoYW5kbGVyID0gKCkgPT4ge1xuICAgICAgaWYgKG1vcmVFbGVtZW50Py5zdHlsZSkge1xuICAgICAgICBtb3JlRWxlbWVudC5zdHlsZS5ib3hTaGFkb3cgPVxuICAgICAgICAgIGVsZW1lbnQuc2Nyb2xsTGVmdCArIFNIQURPV19USFJFU0hPTEQgPlxuICAgICAgICAgIGVsZW1lbnQuc2Nyb2xsV2lkdGggLSBlbGVtZW50LmNsaWVudFdpZHRoXG4gICAgICAgICAgICA/ICdub25lJ1xuICAgICAgICAgICAgOiAnJ1xuICAgICAgfVxuICAgIH1cbiAgICBpZiAoZGlzcGxheU1vcmUpIHtcbiAgICAgIGVsZW1lbnQuYWRkRXZlbnRMaXN0ZW5lcignc2Nyb2xsJywgaGFuZGxlcilcbiAgICB9XG5cbiAgICByZXR1cm4gKCkgPT4ge1xuICAgICAgaWYgKGRpc3BsYXlNb3JlKSBlbGVtZW50LnJlbW92ZUV2ZW50TGlzdGVuZXIoJ3Njcm9sbCcsIGhhbmRsZXIpXG4gICAgfVxuICB9LCBbZGlzcGxheU1vcmVdKVxuXG4gIC8vIG1hcHBpbmcgb2YgdGFiIGNoaWxkcmVuIHRvIGF2b2lkIHVzaW5nIHN1YnRpdGxlIHByb3BzXG4gIGNvbnN0IG1lbnVJdGVtQ2hpbGRyZW4gPSBDaGlsZHJlbi5tYXAoY2hpbGRyZW4sIGNoaWxkID0+IHtcbiAgICBpZiAoaXNWYWxpZEVsZW1lbnQ8dHlwZW9mIFRhYj4oY2hpbGQpKSB7XG4gICAgICByZXR1cm4gY2xvbmVFbGVtZW50KGNoaWxkIGFzIFJlYWN0RWxlbWVudCwge1xuICAgICAgICAuLi5jaGlsZC5wcm9wcyxcbiAgICAgICAgc3VidGl0bGU6IG51bGwsXG4gICAgICB9KVxuICAgIH1cblxuICAgIHJldHVybiBudWxsXG4gIH0pXG5cbiAgcmV0dXJuIChcbiAgICA8VGFic0NvbnRleHQuUHJvdmlkZXIgdmFsdWU9e3ZhbHVlfT5cbiAgICAgIDxUYWJzQ29udGFpbmVyXG4gICAgICAgIHJlZj17dGFic1JlZn1cbiAgICAgICAgcm9sZT1cInRhYmxpc3RcIlxuICAgICAgICBjbGFzc05hbWU9e2NsYXNzTmFtZX1cbiAgICAgICAgZGF0YS10ZXN0aWQ9e2RhdGFUZXN0SWR9XG4gICAgICAgIHsuLi5wcm9wc31cbiAgICAgID5cbiAgICAgICAge2NoaWxkcmVufVxuICAgICAgICB7ZGlzcGxheU1vcmUgPyAoXG4gICAgICAgICAgPFN0eWxlZFRhYk1lbnUgcmVmPXttb3JlU3RhdGljUmVmfSBkaXNjbG9zdXJlPXttb3JlRGlzY2xvc3VyZX0+XG4gICAgICAgICAgICA8TWVudUNvbnRhaW5lcj57bWVudUl0ZW1DaGlsZHJlbn08L01lbnVDb250YWluZXI+XG4gICAgICAgICAgPC9TdHlsZWRUYWJNZW51PlxuICAgICAgICApIDogbnVsbH1cbiAgICAgIDwvVGFic0NvbnRhaW5lcj5cbiAgICA8L1RhYnNDb250ZXh0LlByb3ZpZGVyPlxuICApXG59XG5cblRhYnMuVGFiID0gVGFiXG5UYWJzLk1lbnUgPSBUYWJNZW51XG5UYWJzLk1lbnVJdGVtID0gVGFiTWVudUl0ZW1cbiJdfQ== */"));
24
+ const StyledTabMenu = /* @__PURE__ */ _styled__default.default(TabMenu.TabMenu, process.env.NODE_ENV === "production" ? {
25
+ target: "ewug27g1"
26
+ } : {
27
+ target: "ewug27g1",
28
+ label: "StyledTabMenu"
29
+ })("position:sticky;right:0;top:0;bottom:0;background:", ({
30
+ theme
31
+ }) => theme.colors.neutral.background, ";box-shadow:", ({
32
+ theme
33
+ }) => theme.shadows.menu, ";" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi9ob21lL3J1bm5lci93b3JrL3VsdHJhdmlvbGV0L3VsdHJhdmlvbGV0L3BhY2thZ2VzL3VpL3NyYy9jb21wb25lbnRzL1RhYnMvaW5kZXgudHN4Il0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQXVDcUMiLCJmaWxlIjoiL2hvbWUvcnVubmVyL3dvcmsvdWx0cmF2aW9sZXQvdWx0cmF2aW9sZXQvcGFja2FnZXMvdWkvc3JjL2NvbXBvbmVudHMvVGFicy9pbmRleC50c3giLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgc3R5bGVkIGZyb20gJ0BlbW90aW9uL3N0eWxlZCdcbmltcG9ydCB7XG4gIENoaWxkcmVuLFxuICBjbG9uZUVsZW1lbnQsXG4gIGlzVmFsaWRFbGVtZW50LFxuICB1c2VFZmZlY3QsXG4gIHVzZU1lbW8sXG4gIHVzZVJlZixcbiAgdXNlU3RhdGUsXG59IGZyb20gJ3JlYWN0J1xuaW1wb3J0IHR5cGUgeyBIVE1MQXR0cmlidXRlcywgUmVhY3RFbGVtZW50LCBSZWFjdE5vZGUgfSBmcm9tICdyZWFjdCdcbmltcG9ydCB7IFN0eWxlZFRhYkJ1dHRvbiwgVGFiIH0gZnJvbSAnLi9UYWInXG5pbXBvcnQgeyBUYWJNZW51IH0gZnJvbSAnLi9UYWJNZW51J1xuaW1wb3J0IHsgVGFiTWVudUl0ZW0gfSBmcm9tICcuL1RhYk1lbnVJdGVtJ1xuaW1wb3J0IHsgVGFic0NvbnRleHQgfSBmcm9tICcuL1RhYnNDb250ZXh0J1xuXG5jb25zdCBNZW51Q29udGFpbmVyID0gc3R5bGVkLmRpdmBcbiAgZGlzcGxheTogZmxleDtcbiAgZmxleC1kaXJlY3Rpb246IGNvbHVtbjtcblxuICAke1N0eWxlZFRhYkJ1dHRvbn0ge1xuICAgIGZvbnQtc2l6ZTogJHsoeyB0aGVtZSB9KSA9PiB0aGVtZS50eXBvZ3JhcGh5LmJvZHlTbWFsbC5mb250U2l6ZX07XG4gICAgbGluZS1oZWlnaHQ6ICR7KHsgdGhlbWUgfSkgPT4gdGhlbWUudHlwb2dyYXBoeS5ib2R5U21hbGwubGluZUhlaWdodH07XG4gICAgZm9udC13ZWlnaHQ6IGluaGVyaXQ7XG4gICAgcGFkZGluZzogJHsoeyB0aGVtZSB9KSA9PiBgJHt0aGVtZS5zcGFjZVsnMSddfSAke3RoZW1lLnNwYWNlWycyJ119YH07XG4gICAgYm9yZGVyLWJvdHRvbS13aWR0aDogMS41cHg7XG4gICAgd2lkdGg6IDEwMCU7XG4gICAgY3Vyc29yOiBwb2ludGVyO1xuICAgIG1pbi13aWR0aDogMTEwcHg7XG4gICAgYmFja2dyb3VuZC1jb2xvcjogdHJhbnNwYXJlbnQ7XG4gICAgJlthcmlhLWRpc2FibGVkPSd0cnVlJ10sXG4gICAgJjpkaXNhYmxlZCB7XG4gICAgICBjdXJzb3I6IG5vdC1hbGxvd2VkO1xuICAgICAgZmlsdGVyOiBncmF5c2NhbGUoMSkgb3BhY2l0eSg1MCUpO1xuICAgIH1cbiAgfVxuYFxuXG4vLyBNaWdyYXRpb24gdG8gTWVudVYyIHdpbGwgbm90IHdvcmsgYXMgZXhwZWN0ZWQgaGVyZS5cbmNvbnN0IFN0eWxlZFRhYk1lbnUgPSBzdHlsZWQoVGFiTWVudSlgXG4gIHBvc2l0aW9uOiBzdGlja3k7XG4gIHJpZ2h0OiAwO1xuICB0b3A6IDA7XG4gIGJvdHRvbTogMDtcbiAgYmFja2dyb3VuZDogJHsoeyB0aGVtZSB9KSA9PiB0aGVtZS5jb2xvcnMubmV1dHJhbC5iYWNrZ3JvdW5kfTtcbiAgYm94LXNoYWRvdzogJHsoeyB0aGVtZSB9KSA9PiB0aGVtZS5zaGFkb3dzLm1lbnV9O1xuYFxuXG5jb25zdCBUYWJzQ29udGFpbmVyID0gc3R5bGVkLmRpdmBcbiAgZGlzcGxheTogZmxleDtcbiAgZmxleC13cmFwOiBub3dyYXA7XG4gIG92ZXJmbG93LXg6IHNjcm9sbDtcbiAgcG9zaXRpb246IHJlbGF0aXZlO1xuICB6LWluZGV4OiAwO1xuICAtbXMtb3ZlcmZsb3ctc3R5bGU6IG5vbmU7IC8qIElFIGFuZCBFZGdlICovXG4gIHNjcm9sbGJhci13aWR0aDogbm9uZTsgLyogRmlyZWZveCAqL1xuXG4gICY6OmFmdGVyIHtcbiAgICB6LWluZGV4OiAtMTtcbiAgICBjb250ZW50OiAnJztcbiAgICBwb3NpdGlvbjogYWJzb2x1dGU7XG4gICAgYm90dG9tOiAwO1xuICAgIGxlZnQ6IDA7XG4gICAgcmlnaHQ6IDA7XG4gICAgaGVpZ2h0OiAycHg7XG4gICAgYmFja2dyb3VuZDogJHsoeyB0aGVtZSB9KSA9PiB0aGVtZS5jb2xvcnMubmV1dHJhbC5ib3JkZXJ9O1xuICB9XG5cbiAgJjo6LXdlYmtpdC1zY3JvbGxiYXIge1xuICAgIGRpc3BsYXk6IG5vbmU7XG4gIH1cbmBcblxudHlwZSBUYWJzUHJvcHMgPSB7XG4gIHNlbGVjdGVkPzogc3RyaW5nIHwgbnVtYmVyXG4gIG9uQ2hhbmdlOiAoZGF0YTogc3RyaW5nIHwgbnVtYmVyKSA9PiB2b2lkXG4gIG1vcmVEaXNjbG9zdXJlPzogUmVhY3ROb2RlXG4gIGNsYXNzTmFtZT86IHN0cmluZ1xuICAnZGF0YS10ZXN0aWQnPzogc3RyaW5nXG59ICYgT21pdDxIVE1MQXR0cmlidXRlczxIVE1MRWxlbWVudD4sICdvbkNoYW5nZScgfCAncm9sZSc+XG5cbmNvbnN0IFNIQURPV19USFJFU0hPTEQgPSAxMFxuXG4vKipcbiAqIFRhYnMgY29tcG9uZW50IGlzIHVzZWQgdG8gZGlzcGxheSBhIHNldCBvZiB0YWJzIHdpdGggYSBzaW5nbGUgdGFiIHNlbGVjdGVkIGF0IGEgdGltZS5cbiAqL1xuZXhwb3J0IGNvbnN0IFRhYnMgPSAoe1xuICBjaGlsZHJlbiA9IG51bGwsXG4gIG9uQ2hhbmdlLFxuICBtb3JlRGlzY2xvc3VyZSA9ICdNb3JlJyxcbiAgc2VsZWN0ZWQsXG4gIGNsYXNzTmFtZSxcbiAgJ2RhdGEtdGVzdGlkJzogZGF0YVRlc3RJZCxcbiAgLi4ucHJvcHNcbn06IFRhYnNQcm9wcykgPT4ge1xuICBjb25zdCB0YWJzUmVmID0gdXNlUmVmPEhUTUxEaXZFbGVtZW50Pih7fSBhcyBIVE1MRGl2RWxlbWVudClcbiAgY29uc3QgbW9yZVN0YXRpY1JlZiA9IHVzZVJlZjxIVE1MQnV0dG9uRWxlbWVudD4obnVsbClcbiAgY29uc3QgW2Rpc3BsYXlNb3JlLCBzZXREaXNwbGF5TW9yZV0gPSB1c2VTdGF0ZShmYWxzZSlcbiAgY29uc3QgdmFsdWUgPSB1c2VNZW1vKFxuICAgICgpID0+ICh7XG4gICAgICBvbkNoYW5nZSxcbiAgICAgIHNlbGVjdGVkLFxuICAgIH0pLFxuICAgIFtzZWxlY3RlZCwgb25DaGFuZ2VdLFxuICApXG5cbiAgdXNlRWZmZWN0KCgpID0+IHtcbiAgICBzZXREaXNwbGF5TW9yZSh0YWJzUmVmLmN1cnJlbnQuc2Nyb2xsV2lkdGggPiB0YWJzUmVmLmN1cnJlbnQuY2xpZW50V2lkdGgpXG4gIH0sIFtjaGlsZHJlbl0pXG5cbiAgLy8gU2Nyb2xsIGF1dG9tYXRpY2FsbHkgdG8gdGhlIHRhYlxuICB1c2VFZmZlY3QoKCkgPT4ge1xuICAgIGNvbnN0IHRhYiA9IHRhYnNSZWYuY3VycmVudC5xdWVyeVNlbGVjdG9yKFxuICAgICAgYFtyb2xlPSd0YWInXVthcmlhLXNlbGVjdGVkPSd0cnVlJ11gLFxuICAgICkgYXMgSFRNTEVsZW1lbnRcblxuICAgIGlmICh0YWIgJiYgdGFic1JlZi5jdXJyZW50LnNjcm9sbFRvKSB7XG4gICAgICB0YWJzUmVmLmN1cnJlbnQuc2Nyb2xsVG8oeyBsZWZ0OiB0YWIub2Zmc2V0TGVmdCwgYmVoYXZpb3I6ICdzbW9vdGgnIH0pXG4gICAgfVxuICB9LCBbc2VsZWN0ZWRdKVxuXG4gIC8vIENoYW5nZSB0aGUgbW9yZUJ1dHRvbiBzdHlsZSBhdXRvbWF0aWNhbGx5IGJhc2VkIG9uIHRoZSBzY3JvbGwgdG8gc2hvdyB0aGF0IGEgc2Nyb2xsIGVmZmVjdCBpcyBwb3NzaWJsZS5cbiAgdXNlRWZmZWN0KCgpID0+IHtcbiAgICBjb25zdCBlbGVtZW50ID0gdGFic1JlZi5jdXJyZW50XG4gICAgY29uc3QgbW9yZUVsZW1lbnQgPSBtb3JlU3RhdGljUmVmLmN1cnJlbnRcbiAgICBjb25zdCBoYW5kbGVyID0gKCkgPT4ge1xuICAgICAgaWYgKG1vcmVFbGVtZW50Py5zdHlsZSkge1xuICAgICAgICBtb3JlRWxlbWVudC5zdHlsZS5ib3hTaGFkb3cgPVxuICAgICAgICAgIGVsZW1lbnQuc2Nyb2xsTGVmdCArIFNIQURPV19USFJFU0hPTEQgPlxuICAgICAgICAgIGVsZW1lbnQuc2Nyb2xsV2lkdGggLSBlbGVtZW50LmNsaWVudFdpZHRoXG4gICAgICAgICAgICA/ICdub25lJ1xuICAgICAgICAgICAgOiAnJ1xuICAgICAgfVxuICAgIH1cbiAgICBpZiAoZGlzcGxheU1vcmUpIHtcbiAgICAgIGVsZW1lbnQuYWRkRXZlbnRMaXN0ZW5lcignc2Nyb2xsJywgaGFuZGxlcilcbiAgICB9XG5cbiAgICByZXR1cm4gKCkgPT4ge1xuICAgICAgaWYgKGRpc3BsYXlNb3JlKSBlbGVtZW50LnJlbW92ZUV2ZW50TGlzdGVuZXIoJ3Njcm9sbCcsIGhhbmRsZXIpXG4gICAgfVxuICB9LCBbZGlzcGxheU1vcmVdKVxuXG4gIC8vIG1hcHBpbmcgb2YgdGFiIGNoaWxkcmVuIHRvIGF2b2lkIHVzaW5nIHN1YnRpdGxlIHByb3BzXG4gIGNvbnN0IG1lbnVJdGVtQ2hpbGRyZW4gPSBDaGlsZHJlbi5tYXAoY2hpbGRyZW4sIGNoaWxkID0+IHtcbiAgICBpZiAoaXNWYWxpZEVsZW1lbnQ8dHlwZW9mIFRhYj4oY2hpbGQpKSB7XG4gICAgICByZXR1cm4gY2xvbmVFbGVtZW50KGNoaWxkIGFzIFJlYWN0RWxlbWVudCwge1xuICAgICAgICAuLi5jaGlsZC5wcm9wcyxcbiAgICAgICAgc3VidGl0bGU6IG51bGwsXG4gICAgICB9KVxuICAgIH1cblxuICAgIHJldHVybiBudWxsXG4gIH0pXG5cbiAgcmV0dXJuIChcbiAgICA8VGFic0NvbnRleHQuUHJvdmlkZXIgdmFsdWU9e3ZhbHVlfT5cbiAgICAgIDxUYWJzQ29udGFpbmVyXG4gICAgICAgIHJlZj17dGFic1JlZn1cbiAgICAgICAgcm9sZT1cInRhYmxpc3RcIlxuICAgICAgICBjbGFzc05hbWU9e2NsYXNzTmFtZX1cbiAgICAgICAgZGF0YS10ZXN0aWQ9e2RhdGFUZXN0SWR9XG4gICAgICAgIHsuLi5wcm9wc31cbiAgICAgID5cbiAgICAgICAge2NoaWxkcmVufVxuICAgICAgICB7ZGlzcGxheU1vcmUgPyAoXG4gICAgICAgICAgPFN0eWxlZFRhYk1lbnUgcmVmPXttb3JlU3RhdGljUmVmfSBkaXNjbG9zdXJlPXttb3JlRGlzY2xvc3VyZX0+XG4gICAgICAgICAgICA8TWVudUNvbnRhaW5lcj57bWVudUl0ZW1DaGlsZHJlbn08L01lbnVDb250YWluZXI+XG4gICAgICAgICAgPC9TdHlsZWRUYWJNZW51PlxuICAgICAgICApIDogbnVsbH1cbiAgICAgIDwvVGFic0NvbnRhaW5lcj5cbiAgICA8L1RhYnNDb250ZXh0LlByb3ZpZGVyPlxuICApXG59XG5cblRhYnMuVGFiID0gVGFiXG5UYWJzLk1lbnUgPSBUYWJNZW51XG5UYWJzLk1lbnVJdGVtID0gVGFiTWVudUl0ZW1cbiJdfQ== */"));
34
+ const TabsContainer = /* @__PURE__ */ _styled__default.default("div", process.env.NODE_ENV === "production" ? {
35
+ target: "ewug27g0"
36
+ } : {
37
+ target: "ewug27g0",
38
+ label: "TabsContainer"
39
+ })("display:flex;flex-wrap:nowrap;overflow-x:scroll;position:relative;z-index:0;-ms-overflow-style:none;scrollbar-width:none;&::after{z-index:-1;content:'';position:absolute;bottom:0;left:0;right:0;height:2px;background:", ({
40
+ theme
41
+ }) => theme.colors.neutral.border, ";}&::-webkit-scrollbar{display:none;}" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi9ob21lL3J1bm5lci93b3JrL3VsdHJhdmlvbGV0L3VsdHJhdmlvbGV0L3BhY2thZ2VzL3VpL3NyYy9jb21wb25lbnRzL1RhYnMvaW5kZXgudHN4Il0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQWdEZ0MiLCJmaWxlIjoiL2hvbWUvcnVubmVyL3dvcmsvdWx0cmF2aW9sZXQvdWx0cmF2aW9sZXQvcGFja2FnZXMvdWkvc3JjL2NvbXBvbmVudHMvVGFicy9pbmRleC50c3giLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgc3R5bGVkIGZyb20gJ0BlbW90aW9uL3N0eWxlZCdcbmltcG9ydCB7XG4gIENoaWxkcmVuLFxuICBjbG9uZUVsZW1lbnQsXG4gIGlzVmFsaWRFbGVtZW50LFxuICB1c2VFZmZlY3QsXG4gIHVzZU1lbW8sXG4gIHVzZVJlZixcbiAgdXNlU3RhdGUsXG59IGZyb20gJ3JlYWN0J1xuaW1wb3J0IHR5cGUgeyBIVE1MQXR0cmlidXRlcywgUmVhY3RFbGVtZW50LCBSZWFjdE5vZGUgfSBmcm9tICdyZWFjdCdcbmltcG9ydCB7IFN0eWxlZFRhYkJ1dHRvbiwgVGFiIH0gZnJvbSAnLi9UYWInXG5pbXBvcnQgeyBUYWJNZW51IH0gZnJvbSAnLi9UYWJNZW51J1xuaW1wb3J0IHsgVGFiTWVudUl0ZW0gfSBmcm9tICcuL1RhYk1lbnVJdGVtJ1xuaW1wb3J0IHsgVGFic0NvbnRleHQgfSBmcm9tICcuL1RhYnNDb250ZXh0J1xuXG5jb25zdCBNZW51Q29udGFpbmVyID0gc3R5bGVkLmRpdmBcbiAgZGlzcGxheTogZmxleDtcbiAgZmxleC1kaXJlY3Rpb246IGNvbHVtbjtcblxuICAke1N0eWxlZFRhYkJ1dHRvbn0ge1xuICAgIGZvbnQtc2l6ZTogJHsoeyB0aGVtZSB9KSA9PiB0aGVtZS50eXBvZ3JhcGh5LmJvZHlTbWFsbC5mb250U2l6ZX07XG4gICAgbGluZS1oZWlnaHQ6ICR7KHsgdGhlbWUgfSkgPT4gdGhlbWUudHlwb2dyYXBoeS5ib2R5U21hbGwubGluZUhlaWdodH07XG4gICAgZm9udC13ZWlnaHQ6IGluaGVyaXQ7XG4gICAgcGFkZGluZzogJHsoeyB0aGVtZSB9KSA9PiBgJHt0aGVtZS5zcGFjZVsnMSddfSAke3RoZW1lLnNwYWNlWycyJ119YH07XG4gICAgYm9yZGVyLWJvdHRvbS13aWR0aDogMS41cHg7XG4gICAgd2lkdGg6IDEwMCU7XG4gICAgY3Vyc29yOiBwb2ludGVyO1xuICAgIG1pbi13aWR0aDogMTEwcHg7XG4gICAgYmFja2dyb3VuZC1jb2xvcjogdHJhbnNwYXJlbnQ7XG4gICAgJlthcmlhLWRpc2FibGVkPSd0cnVlJ10sXG4gICAgJjpkaXNhYmxlZCB7XG4gICAgICBjdXJzb3I6IG5vdC1hbGxvd2VkO1xuICAgICAgZmlsdGVyOiBncmF5c2NhbGUoMSkgb3BhY2l0eSg1MCUpO1xuICAgIH1cbiAgfVxuYFxuXG4vLyBNaWdyYXRpb24gdG8gTWVudVYyIHdpbGwgbm90IHdvcmsgYXMgZXhwZWN0ZWQgaGVyZS5cbmNvbnN0IFN0eWxlZFRhYk1lbnUgPSBzdHlsZWQoVGFiTWVudSlgXG4gIHBvc2l0aW9uOiBzdGlja3k7XG4gIHJpZ2h0OiAwO1xuICB0b3A6IDA7XG4gIGJvdHRvbTogMDtcbiAgYmFja2dyb3VuZDogJHsoeyB0aGVtZSB9KSA9PiB0aGVtZS5jb2xvcnMubmV1dHJhbC5iYWNrZ3JvdW5kfTtcbiAgYm94LXNoYWRvdzogJHsoeyB0aGVtZSB9KSA9PiB0aGVtZS5zaGFkb3dzLm1lbnV9O1xuYFxuXG5jb25zdCBUYWJzQ29udGFpbmVyID0gc3R5bGVkLmRpdmBcbiAgZGlzcGxheTogZmxleDtcbiAgZmxleC13cmFwOiBub3dyYXA7XG4gIG92ZXJmbG93LXg6IHNjcm9sbDtcbiAgcG9zaXRpb246IHJlbGF0aXZlO1xuICB6LWluZGV4OiAwO1xuICAtbXMtb3ZlcmZsb3ctc3R5bGU6IG5vbmU7IC8qIElFIGFuZCBFZGdlICovXG4gIHNjcm9sbGJhci13aWR0aDogbm9uZTsgLyogRmlyZWZveCAqL1xuXG4gICY6OmFmdGVyIHtcbiAgICB6LWluZGV4OiAtMTtcbiAgICBjb250ZW50OiAnJztcbiAgICBwb3NpdGlvbjogYWJzb2x1dGU7XG4gICAgYm90dG9tOiAwO1xuICAgIGxlZnQ6IDA7XG4gICAgcmlnaHQ6IDA7XG4gICAgaGVpZ2h0OiAycHg7XG4gICAgYmFja2dyb3VuZDogJHsoeyB0aGVtZSB9KSA9PiB0aGVtZS5jb2xvcnMubmV1dHJhbC5ib3JkZXJ9O1xuICB9XG5cbiAgJjo6LXdlYmtpdC1zY3JvbGxiYXIge1xuICAgIGRpc3BsYXk6IG5vbmU7XG4gIH1cbmBcblxudHlwZSBUYWJzUHJvcHMgPSB7XG4gIHNlbGVjdGVkPzogc3RyaW5nIHwgbnVtYmVyXG4gIG9uQ2hhbmdlOiAoZGF0YTogc3RyaW5nIHwgbnVtYmVyKSA9PiB2b2lkXG4gIG1vcmVEaXNjbG9zdXJlPzogUmVhY3ROb2RlXG4gIGNsYXNzTmFtZT86IHN0cmluZ1xuICAnZGF0YS10ZXN0aWQnPzogc3RyaW5nXG59ICYgT21pdDxIVE1MQXR0cmlidXRlczxIVE1MRWxlbWVudD4sICdvbkNoYW5nZScgfCAncm9sZSc+XG5cbmNvbnN0IFNIQURPV19USFJFU0hPTEQgPSAxMFxuXG4vKipcbiAqIFRhYnMgY29tcG9uZW50IGlzIHVzZWQgdG8gZGlzcGxheSBhIHNldCBvZiB0YWJzIHdpdGggYSBzaW5nbGUgdGFiIHNlbGVjdGVkIGF0IGEgdGltZS5cbiAqL1xuZXhwb3J0IGNvbnN0IFRhYnMgPSAoe1xuICBjaGlsZHJlbiA9IG51bGwsXG4gIG9uQ2hhbmdlLFxuICBtb3JlRGlzY2xvc3VyZSA9ICdNb3JlJyxcbiAgc2VsZWN0ZWQsXG4gIGNsYXNzTmFtZSxcbiAgJ2RhdGEtdGVzdGlkJzogZGF0YVRlc3RJZCxcbiAgLi4ucHJvcHNcbn06IFRhYnNQcm9wcykgPT4ge1xuICBjb25zdCB0YWJzUmVmID0gdXNlUmVmPEhUTUxEaXZFbGVtZW50Pih7fSBhcyBIVE1MRGl2RWxlbWVudClcbiAgY29uc3QgbW9yZVN0YXRpY1JlZiA9IHVzZVJlZjxIVE1MQnV0dG9uRWxlbWVudD4obnVsbClcbiAgY29uc3QgW2Rpc3BsYXlNb3JlLCBzZXREaXNwbGF5TW9yZV0gPSB1c2VTdGF0ZShmYWxzZSlcbiAgY29uc3QgdmFsdWUgPSB1c2VNZW1vKFxuICAgICgpID0+ICh7XG4gICAgICBvbkNoYW5nZSxcbiAgICAgIHNlbGVjdGVkLFxuICAgIH0pLFxuICAgIFtzZWxlY3RlZCwgb25DaGFuZ2VdLFxuICApXG5cbiAgdXNlRWZmZWN0KCgpID0+IHtcbiAgICBzZXREaXNwbGF5TW9yZSh0YWJzUmVmLmN1cnJlbnQuc2Nyb2xsV2lkdGggPiB0YWJzUmVmLmN1cnJlbnQuY2xpZW50V2lkdGgpXG4gIH0sIFtjaGlsZHJlbl0pXG5cbiAgLy8gU2Nyb2xsIGF1dG9tYXRpY2FsbHkgdG8gdGhlIHRhYlxuICB1c2VFZmZlY3QoKCkgPT4ge1xuICAgIGNvbnN0IHRhYiA9IHRhYnNSZWYuY3VycmVudC5xdWVyeVNlbGVjdG9yKFxuICAgICAgYFtyb2xlPSd0YWInXVthcmlhLXNlbGVjdGVkPSd0cnVlJ11gLFxuICAgICkgYXMgSFRNTEVsZW1lbnRcblxuICAgIGlmICh0YWIgJiYgdGFic1JlZi5jdXJyZW50LnNjcm9sbFRvKSB7XG4gICAgICB0YWJzUmVmLmN1cnJlbnQuc2Nyb2xsVG8oeyBsZWZ0OiB0YWIub2Zmc2V0TGVmdCwgYmVoYXZpb3I6ICdzbW9vdGgnIH0pXG4gICAgfVxuICB9LCBbc2VsZWN0ZWRdKVxuXG4gIC8vIENoYW5nZSB0aGUgbW9yZUJ1dHRvbiBzdHlsZSBhdXRvbWF0aWNhbGx5IGJhc2VkIG9uIHRoZSBzY3JvbGwgdG8gc2hvdyB0aGF0IGEgc2Nyb2xsIGVmZmVjdCBpcyBwb3NzaWJsZS5cbiAgdXNlRWZmZWN0KCgpID0+IHtcbiAgICBjb25zdCBlbGVtZW50ID0gdGFic1JlZi5jdXJyZW50XG4gICAgY29uc3QgbW9yZUVsZW1lbnQgPSBtb3JlU3RhdGljUmVmLmN1cnJlbnRcbiAgICBjb25zdCBoYW5kbGVyID0gKCkgPT4ge1xuICAgICAgaWYgKG1vcmVFbGVtZW50Py5zdHlsZSkge1xuICAgICAgICBtb3JlRWxlbWVudC5zdHlsZS5ib3hTaGFkb3cgPVxuICAgICAgICAgIGVsZW1lbnQuc2Nyb2xsTGVmdCArIFNIQURPV19USFJFU0hPTEQgPlxuICAgICAgICAgIGVsZW1lbnQuc2Nyb2xsV2lkdGggLSBlbGVtZW50LmNsaWVudFdpZHRoXG4gICAgICAgICAgICA/ICdub25lJ1xuICAgICAgICAgICAgOiAnJ1xuICAgICAgfVxuICAgIH1cbiAgICBpZiAoZGlzcGxheU1vcmUpIHtcbiAgICAgIGVsZW1lbnQuYWRkRXZlbnRMaXN0ZW5lcignc2Nyb2xsJywgaGFuZGxlcilcbiAgICB9XG5cbiAgICByZXR1cm4gKCkgPT4ge1xuICAgICAgaWYgKGRpc3BsYXlNb3JlKSBlbGVtZW50LnJlbW92ZUV2ZW50TGlzdGVuZXIoJ3Njcm9sbCcsIGhhbmRsZXIpXG4gICAgfVxuICB9LCBbZGlzcGxheU1vcmVdKVxuXG4gIC8vIG1hcHBpbmcgb2YgdGFiIGNoaWxkcmVuIHRvIGF2b2lkIHVzaW5nIHN1YnRpdGxlIHByb3BzXG4gIGNvbnN0IG1lbnVJdGVtQ2hpbGRyZW4gPSBDaGlsZHJlbi5tYXAoY2hpbGRyZW4sIGNoaWxkID0+IHtcbiAgICBpZiAoaXNWYWxpZEVsZW1lbnQ8dHlwZW9mIFRhYj4oY2hpbGQpKSB7XG4gICAgICByZXR1cm4gY2xvbmVFbGVtZW50KGNoaWxkIGFzIFJlYWN0RWxlbWVudCwge1xuICAgICAgICAuLi5jaGlsZC5wcm9wcyxcbiAgICAgICAgc3VidGl0bGU6IG51bGwsXG4gICAgICB9KVxuICAgIH1cblxuICAgIHJldHVybiBudWxsXG4gIH0pXG5cbiAgcmV0dXJuIChcbiAgICA8VGFic0NvbnRleHQuUHJvdmlkZXIgdmFsdWU9e3ZhbHVlfT5cbiAgICAgIDxUYWJzQ29udGFpbmVyXG4gICAgICAgIHJlZj17dGFic1JlZn1cbiAgICAgICAgcm9sZT1cInRhYmxpc3RcIlxuICAgICAgICBjbGFzc05hbWU9e2NsYXNzTmFtZX1cbiAgICAgICAgZGF0YS10ZXN0aWQ9e2RhdGFUZXN0SWR9XG4gICAgICAgIHsuLi5wcm9wc31cbiAgICAgID5cbiAgICAgICAge2NoaWxkcmVufVxuICAgICAgICB7ZGlzcGxheU1vcmUgPyAoXG4gICAgICAgICAgPFN0eWxlZFRhYk1lbnUgcmVmPXttb3JlU3RhdGljUmVmfSBkaXNjbG9zdXJlPXttb3JlRGlzY2xvc3VyZX0+XG4gICAgICAgICAgICA8TWVudUNvbnRhaW5lcj57bWVudUl0ZW1DaGlsZHJlbn08L01lbnVDb250YWluZXI+XG4gICAgICAgICAgPC9TdHlsZWRUYWJNZW51PlxuICAgICAgICApIDogbnVsbH1cbiAgICAgIDwvVGFic0NvbnRhaW5lcj5cbiAgICA8L1RhYnNDb250ZXh0LlByb3ZpZGVyPlxuICApXG59XG5cblRhYnMuVGFiID0gVGFiXG5UYWJzLk1lbnUgPSBUYWJNZW51XG5UYWJzLk1lbnVJdGVtID0gVGFiTWVudUl0ZW1cbiJdfQ== */"));
42
+ const SHADOW_THRESHOLD = 10;
43
+ const Tabs = ({
44
+ children = null,
45
+ onChange,
46
+ moreDisclosure = "More",
47
+ selected,
48
+ className,
49
+ "data-testid": dataTestId,
50
+ ...props
51
+ }) => {
52
+ const tabsRef = React.useRef({});
53
+ const moreStaticRef = React.useRef(null);
54
+ const [displayMore, setDisplayMore] = React.useState(false);
55
+ const value = React.useMemo(() => ({
56
+ onChange,
57
+ selected
58
+ }), [selected, onChange]);
59
+ React.useEffect(() => {
60
+ setDisplayMore(tabsRef.current.scrollWidth > tabsRef.current.clientWidth);
61
+ }, [children]);
62
+ React.useEffect(() => {
63
+ const tab = tabsRef.current.querySelector(`[role='tab'][aria-selected='true']`);
64
+ if (tab && tabsRef.current.scrollTo) {
65
+ tabsRef.current.scrollTo({
66
+ left: tab.offsetLeft,
67
+ behavior: "smooth"
68
+ });
69
+ }
70
+ }, [selected]);
71
+ React.useEffect(() => {
72
+ const element = tabsRef.current;
73
+ const moreElement = moreStaticRef.current;
74
+ const handler = () => {
75
+ if (moreElement?.style) {
76
+ moreElement.style.boxShadow = element.scrollLeft + SHADOW_THRESHOLD > element.scrollWidth - element.clientWidth ? "none" : "";
77
+ }
78
+ };
79
+ if (displayMore) {
80
+ element.addEventListener("scroll", handler);
81
+ }
82
+ return () => {
83
+ if (displayMore)
84
+ element.removeEventListener("scroll", handler);
85
+ };
86
+ }, [displayMore]);
87
+ const menuItemChildren = React.Children.map(children, (child) => {
88
+ if (React.isValidElement(child)) {
89
+ return React.cloneElement(child, {
90
+ ...child.props,
91
+ subtitle: null
92
+ });
93
+ }
94
+ return null;
95
+ });
96
+ return /* @__PURE__ */ jsxRuntime.jsx(TabsContext.TabsContext.Provider, { value, children: /* @__PURE__ */ jsxRuntime.jsxs(TabsContainer, { ref: tabsRef, role: "tablist", className, "data-testid": dataTestId, ...props, children: [
97
+ children,
98
+ displayMore ? /* @__PURE__ */ jsxRuntime.jsx(StyledTabMenu, { ref: moreStaticRef, disclosure: moreDisclosure, children: /* @__PURE__ */ jsxRuntime.jsx(MenuContainer, { children: menuItemChildren }) }) : null
99
+ ] }) });
100
+ };
101
+ Tabs.Tab = Tab.Tab;
102
+ Tabs.Menu = TabMenu.TabMenu;
103
+ Tabs.MenuItem = TabMenuItem.TabMenuItem;
104
+ exports.Tabs = Tabs;