@ultraviolet/plus 0.15.1 → 0.15.2

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 (37) hide show
  1. package/dist/components/CodeEditor/CodeEditor.js +17 -24
  2. package/dist/components/ContentCard/Skeleton.js +28 -21
  3. package/dist/components/ContentCard/index.js +143 -149
  4. package/dist/components/ContentCardGroup/Card.js +84 -76
  5. package/dist/components/ContentCardGroup/SkeletonCard.js +19 -13
  6. package/dist/components/ContentCardGroup/index.js +17 -8
  7. package/dist/components/Conversation/index.js +100 -42
  8. package/dist/components/CustomerSatisfaction/index.js +58 -81
  9. package/dist/components/EstimateCost/Components/CustomUnitInput.js +19 -34
  10. package/dist/components/EstimateCost/Components/Item.js +182 -199
  11. package/dist/components/EstimateCost/Components/LineThrough.js +12 -9
  12. package/dist/components/EstimateCost/Components/NumberInput.js +8 -15
  13. package/dist/components/EstimateCost/Components/Region.js +16 -27
  14. package/dist/components/EstimateCost/Components/Regular.js +20 -28
  15. package/dist/components/EstimateCost/Components/Strong.js +15 -12
  16. package/dist/components/EstimateCost/Components/Unit.js +27 -33
  17. package/dist/components/EstimateCost/Components/UnitInput.js +39 -87
  18. package/dist/components/EstimateCost/Components/Zone.js +16 -26
  19. package/dist/components/EstimateCost/EstimateCost.js +24 -63
  20. package/dist/components/EstimateCost/EstimateCostContent.js +148 -208
  21. package/dist/components/EstimateCost/EstimateCostProvider.js +20 -23
  22. package/dist/components/EstimateCost/OverlayComponent.js +79 -73
  23. package/dist/components/EstimateCost/OverlayContext.js +3 -1
  24. package/dist/components/EstimateCost/componentStyle.js +206 -148
  25. package/dist/components/FAQ/index.js +9 -5
  26. package/dist/components/Navigation/Navigation.js +1 -10
  27. package/dist/components/Navigation/NavigationContent.js +96 -146
  28. package/dist/components/Navigation/NavigationProvider.js +57 -90
  29. package/dist/components/Navigation/components/Group.js +37 -41
  30. package/dist/components/Navigation/components/Item.js +284 -554
  31. package/dist/components/Navigation/components/PinnedItems.js +78 -119
  32. package/dist/components/Navigation/components/Separator.js +9 -4
  33. package/dist/components/SteppedListCard/Step.js +19 -38
  34. package/dist/components/SteppedListCard/SteppedListContainer.js +39 -48
  35. package/dist/components/SteppedListCard/SteppedListContent.js +46 -24
  36. package/dist/components/SteppedListCard/helper.js +1 -3
  37. package/package.json +5 -6
@@ -1,209 +1,211 @@
1
1
  import { jsxs, Fragment, jsx } from "@emotion/react/jsx-runtime";
2
- import { css } from "@emotion/react";
3
- import styled from "@emotion/styled";
2
+ import _styled from "@emotion/styled/base";
4
3
  import { Icon, CategoryIcon } from "@ultraviolet/icons";
5
4
  import { Button, Badge, MenuV2, Stack, Text, fadeIn, Tooltip, Expandable } from "@ultraviolet/ui";
6
5
  import { useEffect, useState, useCallback, useMemo, Children, isValidElement, cloneElement } from "react";
7
6
  import { useNavigation } from "../NavigationProvider.js";
8
7
  import { shrinkHeight, ANIMATION_DURATION } from "../constants.js";
9
- const RelativeDiv = styled.div`
10
- position: relative;
11
- `;
12
- const StyledIcon = styled(Icon, {
13
- shouldForwardProp: (prop) => !["active"].includes(prop)
14
- })`
15
- position: absolute;
16
- top: 0;
17
- bottom: 0;
18
- margin: auto 0;
19
- padding: ${({ theme }) => theme.space["0.25"]};
20
- border-radius: ${({ theme }) => theme.radii.default};
21
- &:hover {
22
- background: ${({ theme }) => theme.colors.neutral.backgroundWeakHover};
23
-
24
- ${({ active, theme }) => active ? `background: ${theme.colors.primary.backgroundHover};` : null}
25
- }
26
- }
27
- `;
28
- const NeutralButtonLink = css`
29
- color: inherit;
30
- text-decoration: none;
31
- background-color: inherit;
32
- border: none;
33
- text-align: left;
34
- `;
35
- const LocalExpandButton = styled(Button)`
36
- opacity: 0;
37
- right: 0;
38
- position: absolute;
39
- left: -24px;
40
- top: 0;
41
- bottom: 0;
42
- margin: auto;
43
-
44
- &:hover,
45
- &:focus,
46
- &:active {
47
- opacity: 1;
48
- }
49
- `;
50
- const PinnedButton = LocalExpandButton.withComponent("div");
51
- const GrabIcon = styled(Icon)`
52
- opacity: 0;
53
- margin: 0 ${({ theme }) => theme.space["0.25"]};
54
- cursor: grab;
55
- `;
56
- const StyledBadge = styled(Badge)``;
57
- const StyledMenuItem = styled(MenuV2.Item, {
58
- shouldForwardProp: (prop) => !["isPinnable"].includes(prop)
59
- })`
60
- text-align: left;
61
-
62
- &:hover,
63
- &:focus,
64
- &:active {
65
- ${PinnedButton} {
66
- opacity: 1;
67
- }
68
-
69
- ${StyledBadge} {
70
- opacity: ${({ isPinnable }) => isPinnable ? 0 : 1};
71
- }
72
- }
73
- `;
74
- const StyledMenu = styled(MenuV2)`
75
- width: 180px;
76
- `;
77
- const PaddingStack = styled(Stack)`
78
- padding-left: 28px; // This value needs to be hardcoded because of the category icon size
79
- `;
80
- const AnimatedIcon = styled(Icon)``;
81
- const WrapText = styled(Text, {
82
- shouldForwardProp: (prop) => !["animation", "subLabel", "textProminence"].includes(prop)
83
- })`
84
- overflow-wrap: ${({ animation }) => animation ? "normal" : "anywhere"};
85
- white-space: ${({ animation }) => animation ? "nowrap" : "normal"};
86
- overflow: hidden;
87
- display: -webkit-box;
88
- -webkit-box-orient: vertical;
89
- -webkit-line-clamp: 2;
90
- white-space: pre-wrap;
91
- `;
92
- const StyledStack = styled(Stack)`
93
- padding-left: 28px; // This value needs to be hardcoded because of the category icon size
94
- `;
95
- const StyledContainer = styled(Stack)`
96
- ${NeutralButtonLink};
97
- border-radius: ${({ theme }) => theme.radii.default};
98
-
99
- &[data-has-no-expand='false'] {
100
- cursor: pointer;
101
- }
102
- margin-top: ${({ theme }) => theme.space["0.25"]};
103
- padding: ${({ theme }) => `calc(${theme.space["0.25"]} + ${theme.space["0.5"]}) ${theme.space["1"]}`};
104
-
105
- &[data-has-sub-label='true'] {
106
- padding: ${({ theme }) => `${theme.space["0.5"]} ${theme.space["1"]}`};
107
- }
108
-
109
- width: 100%;
110
-
111
- &:hover[data-has-no-expand='false']:not([disabled]):not(
112
- [data-is-active='true']
113
- ),
114
- &:focus[data-has-no-expand='false']:not([disabled]):not(
115
- [data-is-active='true']
116
- ) {
117
- background-color: ${({ theme }) => theme.colors.neutral.backgroundWeak};
118
- }
119
- &[data-has-active-children='true'][data-has-no-expand='false']:not(
120
- [disabled][data-is-active='true']
121
- ) {
122
- background-color: ${({ theme }) => theme.colors.neutral.backgroundWeakHover};
123
- ${WrapText} {
124
- color: ${({ theme }) => theme.colors.neutral.textWeakHover};
125
- }
126
-
127
- ${PinnedButton} {
128
- opacity: 1;
129
- }
130
-
131
- &[data-is-pinnable='true'] {
132
- ${StyledBadge} {
133
- opacity: 0;
134
- }
135
- }
136
- }
137
-
138
- &[data-has-no-expand='false']:not([disabled]) {
139
- &:hover,
140
- &:focus,
141
- &:active {
142
- ${PinnedButton}, ${GrabIcon} {
143
- opacity: 1;
144
- }
145
-
146
- ${StyledBadge} {
147
- opacity: 0;
148
- }
149
- }
150
- }
151
-
152
- &:hover[data-has-children='false'][data-is-active='false']:not([disabled]) {
153
- ${WrapText} {
154
- color: ${({ theme }) => theme.colors.neutral.textWeakHover};
155
- }
156
- }
157
-
158
- &:active[data-has-no-expand='false']:not([disabled]):not(
159
- [data-is-active='true']
160
- ) {
161
- background-color: ${({ theme }) => theme.colors.neutral.backgroundHover};
162
- }
163
-
164
- &[data-is-active='true'],
165
- &:hover[data-has-active='true'] {
166
- background-color: ${({ theme }) => theme.colors.primary.background};
167
-
168
- &:hover {
169
- background-color: ${({ theme }) => theme.colors.primary.backgroundHover};
170
- }
171
- }
172
-
173
- &[disabled] {
174
- cursor: not-allowed;
175
- background-color: unset;
176
-
177
- ${WrapText} {
178
- color: ${({ theme }) => theme.colors.neutral.textWeakDisabled};
179
- }
180
- }
181
-
182
- &[data-animation='collapse'] {
183
- animation: ${shrinkHeight} ${ANIMATION_DURATION}ms ease-in-out;
184
- ${WrapText}, ${AnimatedIcon}, ${StyledBadge} {
185
- animation: ${fadeIn} ${ANIMATION_DURATION}ms ease-in-out reverse;
186
- }
187
- }
188
-
189
- &[data-animation='expand'] {
190
- animation: ${shrinkHeight} ${ANIMATION_DURATION}ms ease-in-out reverse;
191
- ${WrapText}, ${AnimatedIcon}, ${StyledBadge} {
192
- animation: ${fadeIn} ${ANIMATION_DURATION}ms ease-in-out;
193
- }
194
-
195
- ${StyledStack} {
196
- display: none;
197
- }
198
- }
199
- `;
200
- const MenuStack = styled(Stack)`
201
- padding: ${({ theme }) => `0 ${theme.space["2"]}`};
202
- margin-top: ${({ theme }) => theme.space["0.25"]};
203
- `;
204
- const ContainerCategoryIcon = styled(Stack)`
205
- min-width: 20px;
206
- `;
8
+ function _EMOTION_STRINGIFIED_CSS_ERROR__() {
9
+ 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).";
10
+ }
11
+ const RelativeDiv = /* @__PURE__ */ _styled("div", process.env.NODE_ENV === "production" ? {
12
+ target: "e134hokc13"
13
+ } : {
14
+ target: "e134hokc13",
15
+ label: "RelativeDiv"
16
+ })(process.env.NODE_ENV === "production" ? {
17
+ name: "bjn8wh",
18
+ styles: "position:relative"
19
+ } : {
20
+ name: "bjn8wh",
21
+ styles: "position:relative",
22
+ map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["/home/runner/work/ultraviolet/ultraviolet/packages/plus/src/components/Navigation/components/Item.tsx"],"names":[],"mappings":"AAgC8B","file":"/home/runner/work/ultraviolet/ultraviolet/packages/plus/src/components/Navigation/components/Item.tsx","sourcesContent":["import { css } from '@emotion/react'\nimport styled from '@emotion/styled'\nimport { CategoryIcon, Icon } from '@ultraviolet/icons'\nimport {\n  Badge,\n  Button,\n  Expandable,\n  MenuV2,\n  Stack,\n  Text,\n  Tooltip,\n  fadeIn,\n} from '@ultraviolet/ui'\nimport type {\n  ComponentProps,\n  DragEvent,\n  JSX,\n  MouseEvent,\n  ReactNode,\n} from 'react'\nimport {\n  Children,\n  cloneElement,\n  isValidElement,\n  useCallback,\n  useEffect,\n  useMemo,\n  useState,\n} from 'react'\nimport { useNavigation } from '../NavigationProvider'\nimport { ANIMATION_DURATION, shrinkHeight } from '../constants'\n\nconst RelativeDiv = styled.div`\n  position: relative;\n`\n\nconst StyledIcon = styled(Icon, {\n  shouldForwardProp: prop => !['active'].includes(prop),\n})<{ active?: boolean }>`\n  position: absolute;\n  top: 0;\n  bottom: 0;\n  margin: auto 0;\n  padding: ${({ theme }) => theme.space['0.25']};\n  border-radius: ${({ theme }) => theme.radii.default};\n  &:hover {\n    background: ${({ theme }) => theme.colors.neutral.backgroundWeakHover};\n\n    ${({ active, theme }) => (active ? `background: ${theme.colors.primary.backgroundHover};` : null)}\n    }\n  }\n`\n\nconst NeutralButtonLink = css`\n  color: inherit;\n  text-decoration: none;\n  background-color: inherit;\n  border: none;\n  text-align: left;\n`\n\n// Pin button when the navigation is expanded\nconst LocalExpandButton = styled(Button)`\n  opacity: 0;\n  right: 0;\n  position: absolute;\n  left: -24px;\n  top: 0;\n  bottom: 0;\n  margin: auto;\n\n  &:hover,\n  &:focus,\n  &:active {\n    opacity: 1;\n  }\n`\n\nconst PinnedButton = LocalExpandButton.withComponent('div')\n\nconst GrabIcon = styled(Icon)`\n  opacity: 0;\n  margin: 0 ${({ theme }) => theme.space['0.25']};\n  cursor: grab;\n`\n\nconst StyledBadge = styled(Badge)``\n\nconst StyledMenuItem = styled(MenuV2.Item, {\n  shouldForwardProp: prop => !['isPinnable'].includes(prop),\n})<{\n  isPinnable?: boolean\n}>`\n  text-align: left;\n\n  &:hover,\n  &:focus,\n  &:active {\n    ${PinnedButton} {\n      opacity: 1;\n    }\n\n    ${StyledBadge} {\n      opacity: ${({ isPinnable }) => (isPinnable ? 0 : 1)};\n    }\n  }\n`\n\nconst StyledMenu = styled(MenuV2)`\n  width: 180px;\n`\n\nconst PaddingStack = styled(Stack)`\n  padding-left: 28px; // This value needs to be hardcoded because of the category icon size\n`\n\nconst AnimatedIcon = styled(Icon)``\n\nconst WrapText = styled(Text, {\n  shouldForwardProp: prop =>\n    !['animation', 'subLabel', 'textProminence'].includes(prop),\n})<{\n  animation?: 'collapse' | 'expand' | boolean\n  subLabel?: boolean\n}>`\n  overflow-wrap: ${({ animation }) => (animation ? 'normal' : 'anywhere')};\n  white-space: ${({ animation }) => (animation ? 'nowrap' : 'normal')};\n  overflow: hidden;\n  display: -webkit-box;\n  -webkit-box-orient: vertical;\n  -webkit-line-clamp: 2;\n  white-space: pre-wrap;\n`\n\nconst StyledStack = styled(Stack)`\n  padding-left: 28px; // This value needs to be hardcoded because of the category icon size\n`\n\nconst StyledContainer = styled(Stack)`\n  ${NeutralButtonLink};\n  border-radius: ${({ theme }) => theme.radii.default};\n\n  &[data-has-no-expand='false'] {\n    cursor: pointer;\n  }\n  margin-top: ${({ theme }) => theme.space['0.25']};\n  padding: ${({ theme }) =>\n    `calc(${theme.space['0.25']} + ${theme.space['0.5']}) ${theme.space['1']}`};\n\n  &[data-has-sub-label='true'] {\n    padding: ${({ theme }) => `${theme.space['0.5']} ${theme.space['1']}`};\n  }\n\n  width: 100%;\n\n  &:hover[data-has-no-expand='false']:not([disabled]):not(\n      [data-is-active='true']\n    ),\n  &:focus[data-has-no-expand='false']:not([disabled]):not(\n      [data-is-active='true']\n    ) {\n    background-color: ${({ theme }) => theme.colors.neutral.backgroundWeak};\n  }\n  &[data-has-active-children='true'][data-has-no-expand='false']:not(\n      [disabled][data-is-active='true']\n    ) {\n    background-color: ${({ theme }) =>\n      theme.colors.neutral.backgroundWeakHover};\n    ${WrapText} {\n      color: ${({ theme }) => theme.colors.neutral.textWeakHover};\n    }\n\n    ${PinnedButton} {\n      opacity: 1;\n    }\n\n    &[data-is-pinnable='true'] {\n      ${StyledBadge} {\n        opacity: 0;\n      }\n    }\n  }\n\n  &[data-has-no-expand='false']:not([disabled]) {\n    &:hover,\n    &:focus,\n    &:active {\n      ${PinnedButton}, ${GrabIcon} {\n        opacity: 1;\n      }\n\n      ${StyledBadge} {\n        opacity: 0;\n      }\n    }\n  }\n\n  &:hover[data-has-children='false'][data-is-active='false']:not([disabled]) {\n    ${WrapText} {\n      color: ${({ theme }) => theme.colors.neutral.textWeakHover};\n    }\n  }\n\n  &:active[data-has-no-expand='false']:not([disabled]):not(\n      [data-is-active='true']\n    ) {\n    background-color: ${({ theme }) => theme.colors.neutral.backgroundHover};\n  }\n\n  &[data-is-active='true'],\n  &:hover[data-has-active='true'] {\n    background-color: ${({ theme }) => theme.colors.primary.background};\n\n    &:hover {\n      background-color: ${({ theme }) => theme.colors.primary.backgroundHover};\n    }\n  }\n\n  &[disabled] {\n    cursor: not-allowed;\n    background-color: unset;\n\n    ${WrapText} {\n      color: ${({ theme }) => theme.colors.neutral.textWeakDisabled};\n    }\n  }\n\n  &[data-animation='collapse'] {\n    animation: ${shrinkHeight} ${ANIMATION_DURATION}ms ease-in-out;\n    ${WrapText}, ${AnimatedIcon}, ${StyledBadge} {\n      animation: ${fadeIn} ${ANIMATION_DURATION}ms ease-in-out reverse;\n    }\n  }\n\n  &[data-animation='expand'] {\n    animation: ${shrinkHeight} ${ANIMATION_DURATION}ms ease-in-out reverse;\n    ${WrapText}, ${AnimatedIcon}, ${StyledBadge} {\n      animation: ${fadeIn} ${ANIMATION_DURATION}ms ease-in-out;\n    }\n\n    ${StyledStack} {\n      display: none;\n    }\n  }\n`\n\nconst MenuStack = styled(Stack)`\n  padding: ${({ theme }) => `0 ${theme.space['2']}`};\n  margin-top: ${({ theme }) => theme.space['0.25']};\n`\n\nconst ContainerCategoryIcon = styled(Stack)`\n  min-width: 20px;\n`\n\ntype ItemType = 'default' | 'pinned' | 'pinnedGroup'\n\ntype ItemProps = {\n  children?: ReactNode\n  /**\n   * Sets a category icon on the left of the item\n   */\n  categoryIcon?: ComponentProps<typeof CategoryIcon>['name']\n  categoryIconVariant?: ComponentProps<typeof CategoryIcon>['variant']\n  /**\n   * The label of the item that will be shown.\n   * It is also used as the key for pinning.\n   */\n  label: string\n  /**\n   * It should be a unique id and will be used for pin/unpin feature.\n   */\n  id: string\n  /**\n   * Text shown under the label with a lighter color and smaller font size\n   */\n  subLabel?: string\n  /**\n   * Badge is added on the right of the item. It is hidden on hover if pinned\n   * feature is enabled\n   */\n  badgeText?: string\n  /**\n   * Defined the sentiment of the badge according to Badge component from\n   * `@ultraviolet/ui`\n   */\n  badgeSentiment?: ComponentProps<typeof Badge>['sentiment']\n  href?: string\n  /**\n   * This function will be triggered on click of the item. If the item is expandable\n   * toggle will be passed with it.\n   */\n  onClick?: (toggle?: true | false) => void\n  onPinUnpinClick?: (event: MouseEvent<HTMLDivElement>) => void\n  /**\n   * This prop is used to control if the item is expanded or collapsed\n   */\n  toggle?: boolean\n  /**\n   * Set this to true if your current page is this item.\n   */\n  active?: boolean\n  /**\n   * If you want to remove pin button on your item use this prop\n   */\n  noPinButton?: boolean\n  /**\n   * You don't need to use this prop it's used internally to control the type of the item\n   */\n  type?: ItemType\n  /**\n   * You don't need to use this prop it's used internally to control if the item has a parent\n   */\n  hasParents?: boolean\n  /**\n   * You don't need to use this prop it's used internally for pinned item to be reorganized with drag and drop\n   */\n  index?: number\n  /**\n   * When the item has href it becomes a link if not it is a button.\n   * When using an external routing tool you might need to remove both of them and use\n   * a non focusable element. This option allows you to choose the tag of the\n   * item.\n   */\n  as?: keyof JSX.IntrinsicElements\n  /**\n   * Use this prop if you want to remove the expand behavior when the item\n   * has sub items.\n   */\n  noExpand?: boolean\n  disabled?: boolean\n}\n\nexport const Item = ({\n  children,\n  categoryIcon,\n  categoryIconVariant,\n  label,\n  subLabel,\n  badgeText,\n  badgeSentiment,\n  href,\n  onClick,\n  onPinUnpinClick,\n  toggle,\n  active,\n  noPinButton,\n  type = 'default',\n  hasParents,\n  as,\n  disabled,\n  noExpand = false,\n  index,\n  id,\n}: ItemProps) => {\n  const context = useNavigation()\n\n  if (!context) {\n    throw new Error(\n      'Navigation.Item can only be used inside a NavigationProvider.',\n    )\n  }\n\n  const {\n    expanded,\n    locales,\n    pinnedFeature,\n    pinItem,\n    unpinItem,\n    pinnedItems,\n    pinLimit,\n    animation,\n    registerItem,\n  } = context\n\n  useEffect(\n    () => {\n      if (type !== 'pinnedGroup') {\n        registerItem({ [id]: { label, active, onClick } })\n      }\n    },\n    // eslint-disable-next-line react-hooks/exhaustive-deps\n    [active, id, label, registerItem],\n  )\n\n  const [internalToggle, setToggle] = useState(toggle !== false)\n\n  const triggerToggle = useCallback(\n    (value: boolean) => {\n      setToggle(value)\n      onClick?.(internalToggle)\n    },\n    [internalToggle, onClick],\n  )\n\n  useEffect(() => {\n    if (animation === 'collapse') {\n      setToggle(false)\n    }\n\n    if (animation === 'expand') {\n      setTimeout(() => {\n        setToggle(toggle ?? true)\n      }, 1)\n    }\n  }, [animation, toggle])\n\n  const PaddedStack = noExpand || type === 'pinnedGroup' ? Stack : PaddingStack\n\n  const hasHrefAndNoChildren = href && !children\n  const hasPinnedFeatureAndNoChildren =\n    pinnedFeature && !children && !noPinButton\n  const isItemPinned = pinnedItems.includes(id)\n  const shouldShowPinnedButton = useMemo(() => {\n    if (href || disabled) return false\n\n    if (hasPinnedFeatureAndNoChildren && type !== 'default') {\n      return true\n    }\n\n    if (hasPinnedFeatureAndNoChildren) {\n      return true\n    }\n\n    return false\n  }, [disabled, hasPinnedFeatureAndNoChildren, href, type])\n\n  const hasActiveChildren = useMemo(() => {\n    if (!children) return false\n\n    return (\n      Children.map(children, child =>\n        isValidElement<ItemProps>(child) ? child.props?.active : false,\n      ) as boolean[]\n    ).includes(true)\n  }, [children])\n\n  const containerTag = useMemo(() => {\n    if (as) {\n      return as\n    }\n\n    if (hasHrefAndNoChildren) {\n      return 'a'\n    }\n\n    if (noExpand) {\n      return 'div'\n    }\n\n    return 'button'\n  }, [as, hasHrefAndNoChildren, noExpand])\n\n  const Container = StyledContainer.withComponent(containerTag)\n\n  const ariaExpanded = useMemo(() => {\n    if (hasHrefAndNoChildren && internalToggle) {\n      return true\n    }\n\n    if (hasHrefAndNoChildren && !internalToggle) {\n      return false\n    }\n\n    return undefined\n  }, [hasHrefAndNoChildren, internalToggle])\n\n  const isPinDisabled = pinnedItems.length >= pinLimit\n  const pinTooltipLocale = useMemo(() => {\n    if (isPinDisabled) {\n      return locales['navigation.pin.limit']\n    }\n\n    if (isItemPinned) {\n      return locales['navigation.unpin.tooltip']\n    }\n\n    return locales['navigation.pin.tooltip']\n  }, [isItemPinned, isPinDisabled, locales])\n\n  const onDragStartTrigger = (event: DragEvent<HTMLDivElement>) => {\n    event.dataTransfer.setData('text/plain', JSON.stringify({ label, index }))\n    // eslint-disable-next-line no-param-reassign\n    event.currentTarget.style.opacity = '0.5'\n  }\n\n  const onDragStopTrigger = (event: DragEvent<HTMLDivElement>) => {\n    // eslint-disable-next-line no-param-reassign\n    event.currentTarget.style.opacity = '1'\n  }\n\n  // This content is when the navigation is expanded\n  if (expanded || (!expanded && animation === 'expand')) {\n    const renderChildren = Children.map(children, child =>\n      isValidElement<ItemProps>(child)\n        ? cloneElement(child, {\n            hasParents: true,\n          })\n        : child,\n    )\n\n    return (\n      <>\n        <Container\n          gap={1}\n          direction=\"row\"\n          alignItems=\"center\"\n          justifyContent=\"space-between\"\n          data-has-sub-label={!!subLabel}\n          onClick={() => {\n            if (children) {\n              return triggerToggle(!internalToggle)\n            }\n\n            return onClick?.()\n          }}\n          aria-expanded={ariaExpanded}\n          href={href}\n          target={href ? '_blank' : undefined}\n          data-is-pinnable={shouldShowPinnedButton}\n          data-is-active={active}\n          data-animation={animation}\n          data-has-children={!!children}\n          data-has-active-children={hasActiveChildren}\n          data-has-no-expand={noExpand}\n          disabled={disabled}\n          draggable={type === 'pinned' && expanded}\n          onDragStart={(event: DragEvent<HTMLDivElement>) =>\n            expanded ? onDragStartTrigger(event) : undefined\n          }\n          onDragEnd={(event: DragEvent<HTMLDivElement>) =>\n            expanded ? onDragStopTrigger(event) : undefined\n          }\n          id={id}\n        >\n          <Stack\n            direction=\"row\"\n            gap={1}\n            alignItems=\"center\"\n            justifyContent=\"center\"\n          >\n            {categoryIcon ? (\n              <ContainerCategoryIcon\n                alignItems=\"center\"\n                justifyContent=\"center\"\n              >\n                <CategoryIcon\n                  name={categoryIcon}\n                  variant={active ? 'primary' : categoryIconVariant}\n                  disabled={disabled}\n                />\n              </ContainerCategoryIcon>\n            ) : null}\n            {type === 'pinned' && expanded ? (\n              <GrabIcon\n                name=\"drag-vertical\"\n                sentiment=\"neutral\"\n                prominence=\"weak\"\n                size=\"small\"\n                disabled={disabled}\n              />\n            ) : null}\n            <Stack>\n              <WrapText\n                as=\"span\"\n                variant=\"bodySmallStrong\"\n                sentiment={active ? 'primary' : 'neutral'}\n                prominence={\n                  (categoryIcon || !hasParents) && !active\n                    ? 'strong'\n                    : 'default'\n                }\n                animation={animation}\n                disabled={disabled}\n              >\n                {label}\n              </WrapText>\n              {subLabel ? (\n                <WrapText\n                  as=\"span\"\n                  variant=\"caption\"\n                  sentiment=\"neutral\"\n                  prominence=\"weak\"\n                  animation={animation}\n                  disabled={disabled}\n                  subLabel\n                >\n                  {subLabel}\n                </WrapText>\n              ) : null}\n            </Stack>\n          </Stack>\n          <Stack direction=\"row\" alignItems=\"center\" gap={href ? 1 : undefined}>\n            {badgeText || hasPinnedFeatureAndNoChildren ? (\n              <>\n                {badgeText ? (\n                  <StyledBadge\n                    sentiment={badgeSentiment}\n                    size=\"small\"\n                    prominence=\"strong\"\n                    disabled={disabled}\n                  >\n                    {badgeText}\n                  </StyledBadge>\n                ) : null}\n                {shouldShowPinnedButton ? (\n                  <Tooltip\n                    text={\n                      isItemPinned\n                        ? locales['navigation.unpin.tooltip']\n                        : pinTooltipLocale\n                    }\n                    placement=\"right\"\n                  >\n                    <RelativeDiv>\n                      <PinnedButton\n                        role=\"button\"\n                        size=\"xsmall\"\n                        variant=\"ghost\"\n                        sentiment={active ? 'primary' : 'neutral'}\n                        onClick={(event: MouseEvent<HTMLDivElement>) => {\n                          event.preventDefault()\n                          event.stopPropagation() // This is to avoid click spread to the parent and change the routing\n                          if (isItemPinned) {\n                            unpinItem(id)\n                          } else {\n                            pinItem(id)\n                          }\n                          onPinUnpinClick?.(event)\n                        }}\n                        disabled={isItemPinned ? false : isPinDisabled}\n                      >\n                        <StyledIcon\n                          size=\"large\"\n                          name={isItemPinned ? 'unpin' : 'pin'}\n                          variant={isItemPinned ? 'filled' : 'outlined'}\n                          disabled={isItemPinned ? false : isPinDisabled}\n                          sentiment={active ? 'primary' : 'neutral'}\n                          active={active}\n                        />\n                      </PinnedButton>\n                    </RelativeDiv>\n                  </Tooltip>\n                ) : null}\n              </>\n            ) : null}\n            {hasHrefAndNoChildren ? (\n              <AnimatedIcon\n                name=\"open-in-new\"\n                sentiment=\"neutral\"\n                prominence=\"default\"\n                disabled={disabled}\n              />\n            ) : null}\n            {children ? (\n              <Stack gap={1} direction=\"row\" alignItems=\"center\">\n                {!animation && !noExpand ? (\n                  <AnimatedIcon\n                    name={internalToggle ? 'arrow-down' : 'arrow-right'}\n                    sentiment=\"neutral\"\n                    prominence=\"weak\"\n                  />\n                ) : null}\n              </Stack>\n            ) : null}\n          </Stack>\n        </Container>\n        {children ? (\n          <>\n            {!noExpand ? (\n              <Expandable\n                opened={internalToggle}\n                animationDuration={\n                  animation ? ANIMATION_DURATION / 2 : undefined\n                }\n              >\n                <PaddedStack>{renderChildren}</PaddedStack>\n              </Expandable>\n            ) : (\n              <PaddedStack>{renderChildren}</PaddedStack>\n            )}\n          </>\n        ) : null}\n      </>\n    )\n  }\n\n  // This content is the menu of the navigation when collapsed\n  if (categoryIcon || (Children.count(children) > 0 && !hasParents)) {\n    return (\n      <MenuStack gap={1} alignItems=\"start\" justifyContent=\"start\">\n        {Children.count(children) > 0 ? (\n          <StyledMenu\n            triggerMethod=\"hover\"\n            dynamicDomRendering={false} // As we parse the children we don't need dynamic rendering\n            disclosure={\n              <Button\n                sentiment=\"neutral\"\n                variant={hasActiveChildren ? 'filled' : 'ghost'}\n                size=\"small\"\n                icon={!categoryIcon ? 'dots-horizontal' : undefined}\n              >\n                {categoryIcon ? (\n                  <Stack\n                    direction=\"row\"\n                    gap={1}\n                    alignItems=\"center\"\n                    justifyContent=\"center\"\n                  >\n                    <CategoryIcon\n                      name={categoryIcon}\n                      variant={active ? 'primary' : categoryIconVariant}\n                    />\n                  </Stack>\n                ) : null}\n              </Button>\n            }\n            placement=\"right\"\n          >\n            {Children.map(children, child =>\n              isValidElement<ItemProps>(child)\n                ? cloneElement(child, {\n                    hasParents: true,\n                  })\n                : child,\n            )}\n          </StyledMenu>\n        ) : (\n          <Tooltip text={label} placement=\"right\" tabIndex={-1}>\n            <Button\n              sentiment=\"neutral\"\n              variant={active ? 'filled' : 'ghost'}\n              size=\"small\"\n              onClick={() => onClick?.()}\n            >\n              <Stack\n                direction=\"row\"\n                gap={1}\n                alignItems=\"center\"\n                justifyContent=\"center\"\n              >\n                <CategoryIcon\n                  name={categoryIcon ?? 'console'}\n                  variant={active ? 'primary' : categoryIconVariant}\n                />\n              </Stack>\n            </Button>\n          </Tooltip>\n        )}\n      </MenuStack>\n    )\n  }\n\n  // This content is what is inside a menu item the navigation is collapsed\n  if (hasParents) {\n    return (\n      <StyledMenuItem\n        href={href}\n        onClick={() => {\n          onClick?.()\n        }}\n        borderless\n        active={active}\n        disabled={disabled}\n        sentiment={active ? 'primary' : 'neutral'}\n        isPinnable={shouldShowPinnedButton}\n      >\n        <Stack\n          gap={1}\n          direction=\"row\"\n          alignItems=\"center\"\n          justifyContent=\"space-between\"\n          flex={1}\n          width=\"100%\"\n        >\n          <WrapText as=\"span\" variant=\"bodySmall\">\n            {label}\n          </WrapText>\n          <Stack direction=\"row\">\n            {badgeText ? (\n              <StyledBadge\n                sentiment={badgeSentiment}\n                size=\"small\"\n                prominence=\"strong\"\n                disabled={disabled}\n              >\n                {badgeText}\n              </StyledBadge>\n            ) : null}\n            {hasHrefAndNoChildren ? (\n              <AnimatedIcon\n                name=\"open-in-new\"\n                sentiment=\"neutral\"\n                prominence=\"weak\"\n                disabled={disabled}\n              />\n            ) : null}\n            {shouldShowPinnedButton ? (\n              <Tooltip\n                text={\n                  isItemPinned\n                    ? locales['navigation.unpin.tooltip']\n                    : pinTooltipLocale\n                }\n                placement=\"right\"\n              >\n                <RelativeDiv>\n                  <PinnedButton\n                    role=\"button\"\n                    size=\"xsmall\"\n                    variant=\"ghost\"\n                    sentiment={active ? 'primary' : 'neutral'}\n                    onClick={(event: MouseEvent<HTMLDivElement>) => {\n                      event.preventDefault()\n                      event.stopPropagation() // This is to avoid click spread to the parent and change the routing\n                      if (isItemPinned) {\n                        unpinItem(id)\n                      } else {\n                        pinItem(id)\n                      }\n                      onPinUnpinClick?.(event)\n                    }}\n                    disabled={isItemPinned ? false : isPinDisabled}\n                  >\n                    <StyledIcon\n                      size=\"large\"\n                      name={isItemPinned ? 'unpin' : 'pin'}\n                      variant={isItemPinned ? 'filled' : 'outlined'}\n                      disabled={isItemPinned ? false : isPinDisabled}\n                      sentiment={active ? 'primary' : 'neutral'}\n                      active={active}\n                    />\n                  </PinnedButton>\n                </RelativeDiv>\n              </Tooltip>\n            ) : null}\n          </Stack>\n        </Stack>\n      </StyledMenuItem>\n    )\n  }\n\n  // This content is for when navigation is collapsed and we show an icon of link\n  if (!hasParents && href) {\n    return (\n      <Tooltip text={label} placement=\"right\">\n        <MenuStack gap={1} alignItems=\"start\" justifyContent=\"start\">\n          <Container\n            gap={1}\n            alignItems=\"center\"\n            justifyContent=\"center\"\n            href={href}\n            target=\"_blank\"\n          >\n            <AnimatedIcon\n              name=\"open-in-new\"\n              sentiment=\"neutral\"\n              prominence=\"weak\"\n            />\n          </Container>\n        </MenuStack>\n      </Tooltip>\n    )\n  }\n\n  return null\n}\n"]} */",
23
+ toString: _EMOTION_STRINGIFIED_CSS_ERROR__
24
+ });
25
+ const StyledIcon = /* @__PURE__ */ _styled(Icon, process.env.NODE_ENV === "production" ? {
26
+ shouldForwardProp: (prop) => !["active"].includes(prop),
27
+ target: "e134hokc12"
28
+ } : {
29
+ shouldForwardProp: (prop) => !["active"].includes(prop),
30
+ target: "e134hokc12",
31
+ label: "StyledIcon"
32
+ })("position:absolute;top:0;bottom:0;margin:auto 0;padding:", ({
33
+ theme
34
+ }) => theme.space["0.25"], ";border-radius:", ({
35
+ theme
36
+ }) => theme.radii.default, ";&:hover{background:", ({
37
+ theme
38
+ }) => theme.colors.neutral.backgroundWeakHover, ";", ({
39
+ active,
40
+ theme
41
+ }) => active ? `background: ${theme.colors.primary.backgroundHover};` : null, ";}" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["/home/runner/work/ultraviolet/ultraviolet/packages/plus/src/components/Navigation/components/Item.tsx"],"names":[],"mappings":"AAsCwB","file":"/home/runner/work/ultraviolet/ultraviolet/packages/plus/src/components/Navigation/components/Item.tsx","sourcesContent":["import { css } from '@emotion/react'\nimport styled from '@emotion/styled'\nimport { CategoryIcon, Icon } from '@ultraviolet/icons'\nimport {\n  Badge,\n  Button,\n  Expandable,\n  MenuV2,\n  Stack,\n  Text,\n  Tooltip,\n  fadeIn,\n} from '@ultraviolet/ui'\nimport type {\n  ComponentProps,\n  DragEvent,\n  JSX,\n  MouseEvent,\n  ReactNode,\n} from 'react'\nimport {\n  Children,\n  cloneElement,\n  isValidElement,\n  useCallback,\n  useEffect,\n  useMemo,\n  useState,\n} from 'react'\nimport { useNavigation } from '../NavigationProvider'\nimport { ANIMATION_DURATION, shrinkHeight } from '../constants'\n\nconst RelativeDiv = styled.div`\n  position: relative;\n`\n\nconst StyledIcon = styled(Icon, {\n  shouldForwardProp: prop => !['active'].includes(prop),\n})<{ active?: boolean }>`\n  position: absolute;\n  top: 0;\n  bottom: 0;\n  margin: auto 0;\n  padding: ${({ theme }) => theme.space['0.25']};\n  border-radius: ${({ theme }) => theme.radii.default};\n  &:hover {\n    background: ${({ theme }) => theme.colors.neutral.backgroundWeakHover};\n\n    ${({ active, theme }) => (active ? `background: ${theme.colors.primary.backgroundHover};` : null)}\n    }\n  }\n`\n\nconst NeutralButtonLink = css`\n  color: inherit;\n  text-decoration: none;\n  background-color: inherit;\n  border: none;\n  text-align: left;\n`\n\n// Pin button when the navigation is expanded\nconst LocalExpandButton = styled(Button)`\n  opacity: 0;\n  right: 0;\n  position: absolute;\n  left: -24px;\n  top: 0;\n  bottom: 0;\n  margin: auto;\n\n  &:hover,\n  &:focus,\n  &:active {\n    opacity: 1;\n  }\n`\n\nconst PinnedButton = LocalExpandButton.withComponent('div')\n\nconst GrabIcon = styled(Icon)`\n  opacity: 0;\n  margin: 0 ${({ theme }) => theme.space['0.25']};\n  cursor: grab;\n`\n\nconst StyledBadge = styled(Badge)``\n\nconst StyledMenuItem = styled(MenuV2.Item, {\n  shouldForwardProp: prop => !['isPinnable'].includes(prop),\n})<{\n  isPinnable?: boolean\n}>`\n  text-align: left;\n\n  &:hover,\n  &:focus,\n  &:active {\n    ${PinnedButton} {\n      opacity: 1;\n    }\n\n    ${StyledBadge} {\n      opacity: ${({ isPinnable }) => (isPinnable ? 0 : 1)};\n    }\n  }\n`\n\nconst StyledMenu = styled(MenuV2)`\n  width: 180px;\n`\n\nconst PaddingStack = styled(Stack)`\n  padding-left: 28px; // This value needs to be hardcoded because of the category icon size\n`\n\nconst AnimatedIcon = styled(Icon)``\n\nconst WrapText = styled(Text, {\n  shouldForwardProp: prop =>\n    !['animation', 'subLabel', 'textProminence'].includes(prop),\n})<{\n  animation?: 'collapse' | 'expand' | boolean\n  subLabel?: boolean\n}>`\n  overflow-wrap: ${({ animation }) => (animation ? 'normal' : 'anywhere')};\n  white-space: ${({ animation }) => (animation ? 'nowrap' : 'normal')};\n  overflow: hidden;\n  display: -webkit-box;\n  -webkit-box-orient: vertical;\n  -webkit-line-clamp: 2;\n  white-space: pre-wrap;\n`\n\nconst StyledStack = styled(Stack)`\n  padding-left: 28px; // This value needs to be hardcoded because of the category icon size\n`\n\nconst StyledContainer = styled(Stack)`\n  ${NeutralButtonLink};\n  border-radius: ${({ theme }) => theme.radii.default};\n\n  &[data-has-no-expand='false'] {\n    cursor: pointer;\n  }\n  margin-top: ${({ theme }) => theme.space['0.25']};\n  padding: ${({ theme }) =>\n    `calc(${theme.space['0.25']} + ${theme.space['0.5']}) ${theme.space['1']}`};\n\n  &[data-has-sub-label='true'] {\n    padding: ${({ theme }) => `${theme.space['0.5']} ${theme.space['1']}`};\n  }\n\n  width: 100%;\n\n  &:hover[data-has-no-expand='false']:not([disabled]):not(\n      [data-is-active='true']\n    ),\n  &:focus[data-has-no-expand='false']:not([disabled]):not(\n      [data-is-active='true']\n    ) {\n    background-color: ${({ theme }) => theme.colors.neutral.backgroundWeak};\n  }\n  &[data-has-active-children='true'][data-has-no-expand='false']:not(\n      [disabled][data-is-active='true']\n    ) {\n    background-color: ${({ theme }) =>\n      theme.colors.neutral.backgroundWeakHover};\n    ${WrapText} {\n      color: ${({ theme }) => theme.colors.neutral.textWeakHover};\n    }\n\n    ${PinnedButton} {\n      opacity: 1;\n    }\n\n    &[data-is-pinnable='true'] {\n      ${StyledBadge} {\n        opacity: 0;\n      }\n    }\n  }\n\n  &[data-has-no-expand='false']:not([disabled]) {\n    &:hover,\n    &:focus,\n    &:active {\n      ${PinnedButton}, ${GrabIcon} {\n        opacity: 1;\n      }\n\n      ${StyledBadge} {\n        opacity: 0;\n      }\n    }\n  }\n\n  &:hover[data-has-children='false'][data-is-active='false']:not([disabled]) {\n    ${WrapText} {\n      color: ${({ theme }) => theme.colors.neutral.textWeakHover};\n    }\n  }\n\n  &:active[data-has-no-expand='false']:not([disabled]):not(\n      [data-is-active='true']\n    ) {\n    background-color: ${({ theme }) => theme.colors.neutral.backgroundHover};\n  }\n\n  &[data-is-active='true'],\n  &:hover[data-has-active='true'] {\n    background-color: ${({ theme }) => theme.colors.primary.background};\n\n    &:hover {\n      background-color: ${({ theme }) => theme.colors.primary.backgroundHover};\n    }\n  }\n\n  &[disabled] {\n    cursor: not-allowed;\n    background-color: unset;\n\n    ${WrapText} {\n      color: ${({ theme }) => theme.colors.neutral.textWeakDisabled};\n    }\n  }\n\n  &[data-animation='collapse'] {\n    animation: ${shrinkHeight} ${ANIMATION_DURATION}ms ease-in-out;\n    ${WrapText}, ${AnimatedIcon}, ${StyledBadge} {\n      animation: ${fadeIn} ${ANIMATION_DURATION}ms ease-in-out reverse;\n    }\n  }\n\n  &[data-animation='expand'] {\n    animation: ${shrinkHeight} ${ANIMATION_DURATION}ms ease-in-out reverse;\n    ${WrapText}, ${AnimatedIcon}, ${StyledBadge} {\n      animation: ${fadeIn} ${ANIMATION_DURATION}ms ease-in-out;\n    }\n\n    ${StyledStack} {\n      display: none;\n    }\n  }\n`\n\nconst MenuStack = styled(Stack)`\n  padding: ${({ theme }) => `0 ${theme.space['2']}`};\n  margin-top: ${({ theme }) => theme.space['0.25']};\n`\n\nconst ContainerCategoryIcon = styled(Stack)`\n  min-width: 20px;\n`\n\ntype ItemType = 'default' | 'pinned' | 'pinnedGroup'\n\ntype ItemProps = {\n  children?: ReactNode\n  /**\n   * Sets a category icon on the left of the item\n   */\n  categoryIcon?: ComponentProps<typeof CategoryIcon>['name']\n  categoryIconVariant?: ComponentProps<typeof CategoryIcon>['variant']\n  /**\n   * The label of the item that will be shown.\n   * It is also used as the key for pinning.\n   */\n  label: string\n  /**\n   * It should be a unique id and will be used for pin/unpin feature.\n   */\n  id: string\n  /**\n   * Text shown under the label with a lighter color and smaller font size\n   */\n  subLabel?: string\n  /**\n   * Badge is added on the right of the item. It is hidden on hover if pinned\n   * feature is enabled\n   */\n  badgeText?: string\n  /**\n   * Defined the sentiment of the badge according to Badge component from\n   * `@ultraviolet/ui`\n   */\n  badgeSentiment?: ComponentProps<typeof Badge>['sentiment']\n  href?: string\n  /**\n   * This function will be triggered on click of the item. If the item is expandable\n   * toggle will be passed with it.\n   */\n  onClick?: (toggle?: true | false) => void\n  onPinUnpinClick?: (event: MouseEvent<HTMLDivElement>) => void\n  /**\n   * This prop is used to control if the item is expanded or collapsed\n   */\n  toggle?: boolean\n  /**\n   * Set this to true if your current page is this item.\n   */\n  active?: boolean\n  /**\n   * If you want to remove pin button on your item use this prop\n   */\n  noPinButton?: boolean\n  /**\n   * You don't need to use this prop it's used internally to control the type of the item\n   */\n  type?: ItemType\n  /**\n   * You don't need to use this prop it's used internally to control if the item has a parent\n   */\n  hasParents?: boolean\n  /**\n   * You don't need to use this prop it's used internally for pinned item to be reorganized with drag and drop\n   */\n  index?: number\n  /**\n   * When the item has href it becomes a link if not it is a button.\n   * When using an external routing tool you might need to remove both of them and use\n   * a non focusable element. This option allows you to choose the tag of the\n   * item.\n   */\n  as?: keyof JSX.IntrinsicElements\n  /**\n   * Use this prop if you want to remove the expand behavior when the item\n   * has sub items.\n   */\n  noExpand?: boolean\n  disabled?: boolean\n}\n\nexport const Item = ({\n  children,\n  categoryIcon,\n  categoryIconVariant,\n  label,\n  subLabel,\n  badgeText,\n  badgeSentiment,\n  href,\n  onClick,\n  onPinUnpinClick,\n  toggle,\n  active,\n  noPinButton,\n  type = 'default',\n  hasParents,\n  as,\n  disabled,\n  noExpand = false,\n  index,\n  id,\n}: ItemProps) => {\n  const context = useNavigation()\n\n  if (!context) {\n    throw new Error(\n      'Navigation.Item can only be used inside a NavigationProvider.',\n    )\n  }\n\n  const {\n    expanded,\n    locales,\n    pinnedFeature,\n    pinItem,\n    unpinItem,\n    pinnedItems,\n    pinLimit,\n    animation,\n    registerItem,\n  } = context\n\n  useEffect(\n    () => {\n      if (type !== 'pinnedGroup') {\n        registerItem({ [id]: { label, active, onClick } })\n      }\n    },\n    // eslint-disable-next-line react-hooks/exhaustive-deps\n    [active, id, label, registerItem],\n  )\n\n  const [internalToggle, setToggle] = useState(toggle !== false)\n\n  const triggerToggle = useCallback(\n    (value: boolean) => {\n      setToggle(value)\n      onClick?.(internalToggle)\n    },\n    [internalToggle, onClick],\n  )\n\n  useEffect(() => {\n    if (animation === 'collapse') {\n      setToggle(false)\n    }\n\n    if (animation === 'expand') {\n      setTimeout(() => {\n        setToggle(toggle ?? true)\n      }, 1)\n    }\n  }, [animation, toggle])\n\n  const PaddedStack = noExpand || type === 'pinnedGroup' ? Stack : PaddingStack\n\n  const hasHrefAndNoChildren = href && !children\n  const hasPinnedFeatureAndNoChildren =\n    pinnedFeature && !children && !noPinButton\n  const isItemPinned = pinnedItems.includes(id)\n  const shouldShowPinnedButton = useMemo(() => {\n    if (href || disabled) return false\n\n    if (hasPinnedFeatureAndNoChildren && type !== 'default') {\n      return true\n    }\n\n    if (hasPinnedFeatureAndNoChildren) {\n      return true\n    }\n\n    return false\n  }, [disabled, hasPinnedFeatureAndNoChildren, href, type])\n\n  const hasActiveChildren = useMemo(() => {\n    if (!children) return false\n\n    return (\n      Children.map(children, child =>\n        isValidElement<ItemProps>(child) ? child.props?.active : false,\n      ) as boolean[]\n    ).includes(true)\n  }, [children])\n\n  const containerTag = useMemo(() => {\n    if (as) {\n      return as\n    }\n\n    if (hasHrefAndNoChildren) {\n      return 'a'\n    }\n\n    if (noExpand) {\n      return 'div'\n    }\n\n    return 'button'\n  }, [as, hasHrefAndNoChildren, noExpand])\n\n  const Container = StyledContainer.withComponent(containerTag)\n\n  const ariaExpanded = useMemo(() => {\n    if (hasHrefAndNoChildren && internalToggle) {\n      return true\n    }\n\n    if (hasHrefAndNoChildren && !internalToggle) {\n      return false\n    }\n\n    return undefined\n  }, [hasHrefAndNoChildren, internalToggle])\n\n  const isPinDisabled = pinnedItems.length >= pinLimit\n  const pinTooltipLocale = useMemo(() => {\n    if (isPinDisabled) {\n      return locales['navigation.pin.limit']\n    }\n\n    if (isItemPinned) {\n      return locales['navigation.unpin.tooltip']\n    }\n\n    return locales['navigation.pin.tooltip']\n  }, [isItemPinned, isPinDisabled, locales])\n\n  const onDragStartTrigger = (event: DragEvent<HTMLDivElement>) => {\n    event.dataTransfer.setData('text/plain', JSON.stringify({ label, index }))\n    // eslint-disable-next-line no-param-reassign\n    event.currentTarget.style.opacity = '0.5'\n  }\n\n  const onDragStopTrigger = (event: DragEvent<HTMLDivElement>) => {\n    // eslint-disable-next-line no-param-reassign\n    event.currentTarget.style.opacity = '1'\n  }\n\n  // This content is when the navigation is expanded\n  if (expanded || (!expanded && animation === 'expand')) {\n    const renderChildren = Children.map(children, child =>\n      isValidElement<ItemProps>(child)\n        ? cloneElement(child, {\n            hasParents: true,\n          })\n        : child,\n    )\n\n    return (\n      <>\n        <Container\n          gap={1}\n          direction=\"row\"\n          alignItems=\"center\"\n          justifyContent=\"space-between\"\n          data-has-sub-label={!!subLabel}\n          onClick={() => {\n            if (children) {\n              return triggerToggle(!internalToggle)\n            }\n\n            return onClick?.()\n          }}\n          aria-expanded={ariaExpanded}\n          href={href}\n          target={href ? '_blank' : undefined}\n          data-is-pinnable={shouldShowPinnedButton}\n          data-is-active={active}\n          data-animation={animation}\n          data-has-children={!!children}\n          data-has-active-children={hasActiveChildren}\n          data-has-no-expand={noExpand}\n          disabled={disabled}\n          draggable={type === 'pinned' && expanded}\n          onDragStart={(event: DragEvent<HTMLDivElement>) =>\n            expanded ? onDragStartTrigger(event) : undefined\n          }\n          onDragEnd={(event: DragEvent<HTMLDivElement>) =>\n            expanded ? onDragStopTrigger(event) : undefined\n          }\n          id={id}\n        >\n          <Stack\n            direction=\"row\"\n            gap={1}\n            alignItems=\"center\"\n            justifyContent=\"center\"\n          >\n            {categoryIcon ? (\n              <ContainerCategoryIcon\n                alignItems=\"center\"\n                justifyContent=\"center\"\n              >\n                <CategoryIcon\n                  name={categoryIcon}\n                  variant={active ? 'primary' : categoryIconVariant}\n                  disabled={disabled}\n                />\n              </ContainerCategoryIcon>\n            ) : null}\n            {type === 'pinned' && expanded ? (\n              <GrabIcon\n                name=\"drag-vertical\"\n                sentiment=\"neutral\"\n                prominence=\"weak\"\n                size=\"small\"\n                disabled={disabled}\n              />\n            ) : null}\n            <Stack>\n              <WrapText\n                as=\"span\"\n                variant=\"bodySmallStrong\"\n                sentiment={active ? 'primary' : 'neutral'}\n                prominence={\n                  (categoryIcon || !hasParents) && !active\n                    ? 'strong'\n                    : 'default'\n                }\n                animation={animation}\n                disabled={disabled}\n              >\n                {label}\n              </WrapText>\n              {subLabel ? (\n                <WrapText\n                  as=\"span\"\n                  variant=\"caption\"\n                  sentiment=\"neutral\"\n                  prominence=\"weak\"\n                  animation={animation}\n                  disabled={disabled}\n                  subLabel\n                >\n                  {subLabel}\n                </WrapText>\n              ) : null}\n            </Stack>\n          </Stack>\n          <Stack direction=\"row\" alignItems=\"center\" gap={href ? 1 : undefined}>\n            {badgeText || hasPinnedFeatureAndNoChildren ? (\n              <>\n                {badgeText ? (\n                  <StyledBadge\n                    sentiment={badgeSentiment}\n                    size=\"small\"\n                    prominence=\"strong\"\n                    disabled={disabled}\n                  >\n                    {badgeText}\n                  </StyledBadge>\n                ) : null}\n                {shouldShowPinnedButton ? (\n                  <Tooltip\n                    text={\n                      isItemPinned\n                        ? locales['navigation.unpin.tooltip']\n                        : pinTooltipLocale\n                    }\n                    placement=\"right\"\n                  >\n                    <RelativeDiv>\n                      <PinnedButton\n                        role=\"button\"\n                        size=\"xsmall\"\n                        variant=\"ghost\"\n                        sentiment={active ? 'primary' : 'neutral'}\n                        onClick={(event: MouseEvent<HTMLDivElement>) => {\n                          event.preventDefault()\n                          event.stopPropagation() // This is to avoid click spread to the parent and change the routing\n                          if (isItemPinned) {\n                            unpinItem(id)\n                          } else {\n                            pinItem(id)\n                          }\n                          onPinUnpinClick?.(event)\n                        }}\n                        disabled={isItemPinned ? false : isPinDisabled}\n                      >\n                        <StyledIcon\n                          size=\"large\"\n                          name={isItemPinned ? 'unpin' : 'pin'}\n                          variant={isItemPinned ? 'filled' : 'outlined'}\n                          disabled={isItemPinned ? false : isPinDisabled}\n                          sentiment={active ? 'primary' : 'neutral'}\n                          active={active}\n                        />\n                      </PinnedButton>\n                    </RelativeDiv>\n                  </Tooltip>\n                ) : null}\n              </>\n            ) : null}\n            {hasHrefAndNoChildren ? (\n              <AnimatedIcon\n                name=\"open-in-new\"\n                sentiment=\"neutral\"\n                prominence=\"default\"\n                disabled={disabled}\n              />\n            ) : null}\n            {children ? (\n              <Stack gap={1} direction=\"row\" alignItems=\"center\">\n                {!animation && !noExpand ? (\n                  <AnimatedIcon\n                    name={internalToggle ? 'arrow-down' : 'arrow-right'}\n                    sentiment=\"neutral\"\n                    prominence=\"weak\"\n                  />\n                ) : null}\n              </Stack>\n            ) : null}\n          </Stack>\n        </Container>\n        {children ? (\n          <>\n            {!noExpand ? (\n              <Expandable\n                opened={internalToggle}\n                animationDuration={\n                  animation ? ANIMATION_DURATION / 2 : undefined\n                }\n              >\n                <PaddedStack>{renderChildren}</PaddedStack>\n              </Expandable>\n            ) : (\n              <PaddedStack>{renderChildren}</PaddedStack>\n            )}\n          </>\n        ) : null}\n      </>\n    )\n  }\n\n  // This content is the menu of the navigation when collapsed\n  if (categoryIcon || (Children.count(children) > 0 && !hasParents)) {\n    return (\n      <MenuStack gap={1} alignItems=\"start\" justifyContent=\"start\">\n        {Children.count(children) > 0 ? (\n          <StyledMenu\n            triggerMethod=\"hover\"\n            dynamicDomRendering={false} // As we parse the children we don't need dynamic rendering\n            disclosure={\n              <Button\n                sentiment=\"neutral\"\n                variant={hasActiveChildren ? 'filled' : 'ghost'}\n                size=\"small\"\n                icon={!categoryIcon ? 'dots-horizontal' : undefined}\n              >\n                {categoryIcon ? (\n                  <Stack\n                    direction=\"row\"\n                    gap={1}\n                    alignItems=\"center\"\n                    justifyContent=\"center\"\n                  >\n                    <CategoryIcon\n                      name={categoryIcon}\n                      variant={active ? 'primary' : categoryIconVariant}\n                    />\n                  </Stack>\n                ) : null}\n              </Button>\n            }\n            placement=\"right\"\n          >\n            {Children.map(children, child =>\n              isValidElement<ItemProps>(child)\n                ? cloneElement(child, {\n                    hasParents: true,\n                  })\n                : child,\n            )}\n          </StyledMenu>\n        ) : (\n          <Tooltip text={label} placement=\"right\" tabIndex={-1}>\n            <Button\n              sentiment=\"neutral\"\n              variant={active ? 'filled' : 'ghost'}\n              size=\"small\"\n              onClick={() => onClick?.()}\n            >\n              <Stack\n                direction=\"row\"\n                gap={1}\n                alignItems=\"center\"\n                justifyContent=\"center\"\n              >\n                <CategoryIcon\n                  name={categoryIcon ?? 'console'}\n                  variant={active ? 'primary' : categoryIconVariant}\n                />\n              </Stack>\n            </Button>\n          </Tooltip>\n        )}\n      </MenuStack>\n    )\n  }\n\n  // This content is what is inside a menu item the navigation is collapsed\n  if (hasParents) {\n    return (\n      <StyledMenuItem\n        href={href}\n        onClick={() => {\n          onClick?.()\n        }}\n        borderless\n        active={active}\n        disabled={disabled}\n        sentiment={active ? 'primary' : 'neutral'}\n        isPinnable={shouldShowPinnedButton}\n      >\n        <Stack\n          gap={1}\n          direction=\"row\"\n          alignItems=\"center\"\n          justifyContent=\"space-between\"\n          flex={1}\n          width=\"100%\"\n        >\n          <WrapText as=\"span\" variant=\"bodySmall\">\n            {label}\n          </WrapText>\n          <Stack direction=\"row\">\n            {badgeText ? (\n              <StyledBadge\n                sentiment={badgeSentiment}\n                size=\"small\"\n                prominence=\"strong\"\n                disabled={disabled}\n              >\n                {badgeText}\n              </StyledBadge>\n            ) : null}\n            {hasHrefAndNoChildren ? (\n              <AnimatedIcon\n                name=\"open-in-new\"\n                sentiment=\"neutral\"\n                prominence=\"weak\"\n                disabled={disabled}\n              />\n            ) : null}\n            {shouldShowPinnedButton ? (\n              <Tooltip\n                text={\n                  isItemPinned\n                    ? locales['navigation.unpin.tooltip']\n                    : pinTooltipLocale\n                }\n                placement=\"right\"\n              >\n                <RelativeDiv>\n                  <PinnedButton\n                    role=\"button\"\n                    size=\"xsmall\"\n                    variant=\"ghost\"\n                    sentiment={active ? 'primary' : 'neutral'}\n                    onClick={(event: MouseEvent<HTMLDivElement>) => {\n                      event.preventDefault()\n                      event.stopPropagation() // This is to avoid click spread to the parent and change the routing\n                      if (isItemPinned) {\n                        unpinItem(id)\n                      } else {\n                        pinItem(id)\n                      }\n                      onPinUnpinClick?.(event)\n                    }}\n                    disabled={isItemPinned ? false : isPinDisabled}\n                  >\n                    <StyledIcon\n                      size=\"large\"\n                      name={isItemPinned ? 'unpin' : 'pin'}\n                      variant={isItemPinned ? 'filled' : 'outlined'}\n                      disabled={isItemPinned ? false : isPinDisabled}\n                      sentiment={active ? 'primary' : 'neutral'}\n                      active={active}\n                    />\n                  </PinnedButton>\n                </RelativeDiv>\n              </Tooltip>\n            ) : null}\n          </Stack>\n        </Stack>\n      </StyledMenuItem>\n    )\n  }\n\n  // This content is for when navigation is collapsed and we show an icon of link\n  if (!hasParents && href) {\n    return (\n      <Tooltip text={label} placement=\"right\">\n        <MenuStack gap={1} alignItems=\"start\" justifyContent=\"start\">\n          <Container\n            gap={1}\n            alignItems=\"center\"\n            justifyContent=\"center\"\n            href={href}\n            target=\"_blank\"\n          >\n            <AnimatedIcon\n              name=\"open-in-new\"\n              sentiment=\"neutral\"\n              prominence=\"weak\"\n            />\n          </Container>\n        </MenuStack>\n      </Tooltip>\n    )\n  }\n\n  return null\n}\n"]} */"));
42
+ const NeutralButtonLink = process.env.NODE_ENV === "production" ? {
43
+ name: "rhgg7c",
44
+ styles: "color:inherit;text-decoration:none;background-color:inherit;border:none;text-align:left"
45
+ } : {
46
+ name: "1kb8ns1-NeutralButtonLink",
47
+ styles: "color:inherit;text-decoration:none;background-color:inherit;border:none;text-align:left;label:NeutralButtonLink;",
48
+ map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["/home/runner/work/ultraviolet/ultraviolet/packages/plus/src/components/Navigation/components/Item.tsx"],"names":[],"mappings":"AAqD6B","file":"/home/runner/work/ultraviolet/ultraviolet/packages/plus/src/components/Navigation/components/Item.tsx","sourcesContent":["import { css } from '@emotion/react'\nimport styled from '@emotion/styled'\nimport { CategoryIcon, Icon } from '@ultraviolet/icons'\nimport {\n  Badge,\n  Button,\n  Expandable,\n  MenuV2,\n  Stack,\n  Text,\n  Tooltip,\n  fadeIn,\n} from '@ultraviolet/ui'\nimport type {\n  ComponentProps,\n  DragEvent,\n  JSX,\n  MouseEvent,\n  ReactNode,\n} from 'react'\nimport {\n  Children,\n  cloneElement,\n  isValidElement,\n  useCallback,\n  useEffect,\n  useMemo,\n  useState,\n} from 'react'\nimport { useNavigation } from '../NavigationProvider'\nimport { ANIMATION_DURATION, shrinkHeight } from '../constants'\n\nconst RelativeDiv = styled.div`\n  position: relative;\n`\n\nconst StyledIcon = styled(Icon, {\n  shouldForwardProp: prop => !['active'].includes(prop),\n})<{ active?: boolean }>`\n  position: absolute;\n  top: 0;\n  bottom: 0;\n  margin: auto 0;\n  padding: ${({ theme }) => theme.space['0.25']};\n  border-radius: ${({ theme }) => theme.radii.default};\n  &:hover {\n    background: ${({ theme }) => theme.colors.neutral.backgroundWeakHover};\n\n    ${({ active, theme }) => (active ? `background: ${theme.colors.primary.backgroundHover};` : null)}\n    }\n  }\n`\n\nconst NeutralButtonLink = css`\n  color: inherit;\n  text-decoration: none;\n  background-color: inherit;\n  border: none;\n  text-align: left;\n`\n\n// Pin button when the navigation is expanded\nconst LocalExpandButton = styled(Button)`\n  opacity: 0;\n  right: 0;\n  position: absolute;\n  left: -24px;\n  top: 0;\n  bottom: 0;\n  margin: auto;\n\n  &:hover,\n  &:focus,\n  &:active {\n    opacity: 1;\n  }\n`\n\nconst PinnedButton = LocalExpandButton.withComponent('div')\n\nconst GrabIcon = styled(Icon)`\n  opacity: 0;\n  margin: 0 ${({ theme }) => theme.space['0.25']};\n  cursor: grab;\n`\n\nconst StyledBadge = styled(Badge)``\n\nconst StyledMenuItem = styled(MenuV2.Item, {\n  shouldForwardProp: prop => !['isPinnable'].includes(prop),\n})<{\n  isPinnable?: boolean\n}>`\n  text-align: left;\n\n  &:hover,\n  &:focus,\n  &:active {\n    ${PinnedButton} {\n      opacity: 1;\n    }\n\n    ${StyledBadge} {\n      opacity: ${({ isPinnable }) => (isPinnable ? 0 : 1)};\n    }\n  }\n`\n\nconst StyledMenu = styled(MenuV2)`\n  width: 180px;\n`\n\nconst PaddingStack = styled(Stack)`\n  padding-left: 28px; // This value needs to be hardcoded because of the category icon size\n`\n\nconst AnimatedIcon = styled(Icon)``\n\nconst WrapText = styled(Text, {\n  shouldForwardProp: prop =>\n    !['animation', 'subLabel', 'textProminence'].includes(prop),\n})<{\n  animation?: 'collapse' | 'expand' | boolean\n  subLabel?: boolean\n}>`\n  overflow-wrap: ${({ animation }) => (animation ? 'normal' : 'anywhere')};\n  white-space: ${({ animation }) => (animation ? 'nowrap' : 'normal')};\n  overflow: hidden;\n  display: -webkit-box;\n  -webkit-box-orient: vertical;\n  -webkit-line-clamp: 2;\n  white-space: pre-wrap;\n`\n\nconst StyledStack = styled(Stack)`\n  padding-left: 28px; // This value needs to be hardcoded because of the category icon size\n`\n\nconst StyledContainer = styled(Stack)`\n  ${NeutralButtonLink};\n  border-radius: ${({ theme }) => theme.radii.default};\n\n  &[data-has-no-expand='false'] {\n    cursor: pointer;\n  }\n  margin-top: ${({ theme }) => theme.space['0.25']};\n  padding: ${({ theme }) =>\n    `calc(${theme.space['0.25']} + ${theme.space['0.5']}) ${theme.space['1']}`};\n\n  &[data-has-sub-label='true'] {\n    padding: ${({ theme }) => `${theme.space['0.5']} ${theme.space['1']}`};\n  }\n\n  width: 100%;\n\n  &:hover[data-has-no-expand='false']:not([disabled]):not(\n      [data-is-active='true']\n    ),\n  &:focus[data-has-no-expand='false']:not([disabled]):not(\n      [data-is-active='true']\n    ) {\n    background-color: ${({ theme }) => theme.colors.neutral.backgroundWeak};\n  }\n  &[data-has-active-children='true'][data-has-no-expand='false']:not(\n      [disabled][data-is-active='true']\n    ) {\n    background-color: ${({ theme }) =>\n      theme.colors.neutral.backgroundWeakHover};\n    ${WrapText} {\n      color: ${({ theme }) => theme.colors.neutral.textWeakHover};\n    }\n\n    ${PinnedButton} {\n      opacity: 1;\n    }\n\n    &[data-is-pinnable='true'] {\n      ${StyledBadge} {\n        opacity: 0;\n      }\n    }\n  }\n\n  &[data-has-no-expand='false']:not([disabled]) {\n    &:hover,\n    &:focus,\n    &:active {\n      ${PinnedButton}, ${GrabIcon} {\n        opacity: 1;\n      }\n\n      ${StyledBadge} {\n        opacity: 0;\n      }\n    }\n  }\n\n  &:hover[data-has-children='false'][data-is-active='false']:not([disabled]) {\n    ${WrapText} {\n      color: ${({ theme }) => theme.colors.neutral.textWeakHover};\n    }\n  }\n\n  &:active[data-has-no-expand='false']:not([disabled]):not(\n      [data-is-active='true']\n    ) {\n    background-color: ${({ theme }) => theme.colors.neutral.backgroundHover};\n  }\n\n  &[data-is-active='true'],\n  &:hover[data-has-active='true'] {\n    background-color: ${({ theme }) => theme.colors.primary.background};\n\n    &:hover {\n      background-color: ${({ theme }) => theme.colors.primary.backgroundHover};\n    }\n  }\n\n  &[disabled] {\n    cursor: not-allowed;\n    background-color: unset;\n\n    ${WrapText} {\n      color: ${({ theme }) => theme.colors.neutral.textWeakDisabled};\n    }\n  }\n\n  &[data-animation='collapse'] {\n    animation: ${shrinkHeight} ${ANIMATION_DURATION}ms ease-in-out;\n    ${WrapText}, ${AnimatedIcon}, ${StyledBadge} {\n      animation: ${fadeIn} ${ANIMATION_DURATION}ms ease-in-out reverse;\n    }\n  }\n\n  &[data-animation='expand'] {\n    animation: ${shrinkHeight} ${ANIMATION_DURATION}ms ease-in-out reverse;\n    ${WrapText}, ${AnimatedIcon}, ${StyledBadge} {\n      animation: ${fadeIn} ${ANIMATION_DURATION}ms ease-in-out;\n    }\n\n    ${StyledStack} {\n      display: none;\n    }\n  }\n`\n\nconst MenuStack = styled(Stack)`\n  padding: ${({ theme }) => `0 ${theme.space['2']}`};\n  margin-top: ${({ theme }) => theme.space['0.25']};\n`\n\nconst ContainerCategoryIcon = styled(Stack)`\n  min-width: 20px;\n`\n\ntype ItemType = 'default' | 'pinned' | 'pinnedGroup'\n\ntype ItemProps = {\n  children?: ReactNode\n  /**\n   * Sets a category icon on the left of the item\n   */\n  categoryIcon?: ComponentProps<typeof CategoryIcon>['name']\n  categoryIconVariant?: ComponentProps<typeof CategoryIcon>['variant']\n  /**\n   * The label of the item that will be shown.\n   * It is also used as the key for pinning.\n   */\n  label: string\n  /**\n   * It should be a unique id and will be used for pin/unpin feature.\n   */\n  id: string\n  /**\n   * Text shown under the label with a lighter color and smaller font size\n   */\n  subLabel?: string\n  /**\n   * Badge is added on the right of the item. It is hidden on hover if pinned\n   * feature is enabled\n   */\n  badgeText?: string\n  /**\n   * Defined the sentiment of the badge according to Badge component from\n   * `@ultraviolet/ui`\n   */\n  badgeSentiment?: ComponentProps<typeof Badge>['sentiment']\n  href?: string\n  /**\n   * This function will be triggered on click of the item. If the item is expandable\n   * toggle will be passed with it.\n   */\n  onClick?: (toggle?: true | false) => void\n  onPinUnpinClick?: (event: MouseEvent<HTMLDivElement>) => void\n  /**\n   * This prop is used to control if the item is expanded or collapsed\n   */\n  toggle?: boolean\n  /**\n   * Set this to true if your current page is this item.\n   */\n  active?: boolean\n  /**\n   * If you want to remove pin button on your item use this prop\n   */\n  noPinButton?: boolean\n  /**\n   * You don't need to use this prop it's used internally to control the type of the item\n   */\n  type?: ItemType\n  /**\n   * You don't need to use this prop it's used internally to control if the item has a parent\n   */\n  hasParents?: boolean\n  /**\n   * You don't need to use this prop it's used internally for pinned item to be reorganized with drag and drop\n   */\n  index?: number\n  /**\n   * When the item has href it becomes a link if not it is a button.\n   * When using an external routing tool you might need to remove both of them and use\n   * a non focusable element. This option allows you to choose the tag of the\n   * item.\n   */\n  as?: keyof JSX.IntrinsicElements\n  /**\n   * Use this prop if you want to remove the expand behavior when the item\n   * has sub items.\n   */\n  noExpand?: boolean\n  disabled?: boolean\n}\n\nexport const Item = ({\n  children,\n  categoryIcon,\n  categoryIconVariant,\n  label,\n  subLabel,\n  badgeText,\n  badgeSentiment,\n  href,\n  onClick,\n  onPinUnpinClick,\n  toggle,\n  active,\n  noPinButton,\n  type = 'default',\n  hasParents,\n  as,\n  disabled,\n  noExpand = false,\n  index,\n  id,\n}: ItemProps) => {\n  const context = useNavigation()\n\n  if (!context) {\n    throw new Error(\n      'Navigation.Item can only be used inside a NavigationProvider.',\n    )\n  }\n\n  const {\n    expanded,\n    locales,\n    pinnedFeature,\n    pinItem,\n    unpinItem,\n    pinnedItems,\n    pinLimit,\n    animation,\n    registerItem,\n  } = context\n\n  useEffect(\n    () => {\n      if (type !== 'pinnedGroup') {\n        registerItem({ [id]: { label, active, onClick } })\n      }\n    },\n    // eslint-disable-next-line react-hooks/exhaustive-deps\n    [active, id, label, registerItem],\n  )\n\n  const [internalToggle, setToggle] = useState(toggle !== false)\n\n  const triggerToggle = useCallback(\n    (value: boolean) => {\n      setToggle(value)\n      onClick?.(internalToggle)\n    },\n    [internalToggle, onClick],\n  )\n\n  useEffect(() => {\n    if (animation === 'collapse') {\n      setToggle(false)\n    }\n\n    if (animation === 'expand') {\n      setTimeout(() => {\n        setToggle(toggle ?? true)\n      }, 1)\n    }\n  }, [animation, toggle])\n\n  const PaddedStack = noExpand || type === 'pinnedGroup' ? Stack : PaddingStack\n\n  const hasHrefAndNoChildren = href && !children\n  const hasPinnedFeatureAndNoChildren =\n    pinnedFeature && !children && !noPinButton\n  const isItemPinned = pinnedItems.includes(id)\n  const shouldShowPinnedButton = useMemo(() => {\n    if (href || disabled) return false\n\n    if (hasPinnedFeatureAndNoChildren && type !== 'default') {\n      return true\n    }\n\n    if (hasPinnedFeatureAndNoChildren) {\n      return true\n    }\n\n    return false\n  }, [disabled, hasPinnedFeatureAndNoChildren, href, type])\n\n  const hasActiveChildren = useMemo(() => {\n    if (!children) return false\n\n    return (\n      Children.map(children, child =>\n        isValidElement<ItemProps>(child) ? child.props?.active : false,\n      ) as boolean[]\n    ).includes(true)\n  }, [children])\n\n  const containerTag = useMemo(() => {\n    if (as) {\n      return as\n    }\n\n    if (hasHrefAndNoChildren) {\n      return 'a'\n    }\n\n    if (noExpand) {\n      return 'div'\n    }\n\n    return 'button'\n  }, [as, hasHrefAndNoChildren, noExpand])\n\n  const Container = StyledContainer.withComponent(containerTag)\n\n  const ariaExpanded = useMemo(() => {\n    if (hasHrefAndNoChildren && internalToggle) {\n      return true\n    }\n\n    if (hasHrefAndNoChildren && !internalToggle) {\n      return false\n    }\n\n    return undefined\n  }, [hasHrefAndNoChildren, internalToggle])\n\n  const isPinDisabled = pinnedItems.length >= pinLimit\n  const pinTooltipLocale = useMemo(() => {\n    if (isPinDisabled) {\n      return locales['navigation.pin.limit']\n    }\n\n    if (isItemPinned) {\n      return locales['navigation.unpin.tooltip']\n    }\n\n    return locales['navigation.pin.tooltip']\n  }, [isItemPinned, isPinDisabled, locales])\n\n  const onDragStartTrigger = (event: DragEvent<HTMLDivElement>) => {\n    event.dataTransfer.setData('text/plain', JSON.stringify({ label, index }))\n    // eslint-disable-next-line no-param-reassign\n    event.currentTarget.style.opacity = '0.5'\n  }\n\n  const onDragStopTrigger = (event: DragEvent<HTMLDivElement>) => {\n    // eslint-disable-next-line no-param-reassign\n    event.currentTarget.style.opacity = '1'\n  }\n\n  // This content is when the navigation is expanded\n  if (expanded || (!expanded && animation === 'expand')) {\n    const renderChildren = Children.map(children, child =>\n      isValidElement<ItemProps>(child)\n        ? cloneElement(child, {\n            hasParents: true,\n          })\n        : child,\n    )\n\n    return (\n      <>\n        <Container\n          gap={1}\n          direction=\"row\"\n          alignItems=\"center\"\n          justifyContent=\"space-between\"\n          data-has-sub-label={!!subLabel}\n          onClick={() => {\n            if (children) {\n              return triggerToggle(!internalToggle)\n            }\n\n            return onClick?.()\n          }}\n          aria-expanded={ariaExpanded}\n          href={href}\n          target={href ? '_blank' : undefined}\n          data-is-pinnable={shouldShowPinnedButton}\n          data-is-active={active}\n          data-animation={animation}\n          data-has-children={!!children}\n          data-has-active-children={hasActiveChildren}\n          data-has-no-expand={noExpand}\n          disabled={disabled}\n          draggable={type === 'pinned' && expanded}\n          onDragStart={(event: DragEvent<HTMLDivElement>) =>\n            expanded ? onDragStartTrigger(event) : undefined\n          }\n          onDragEnd={(event: DragEvent<HTMLDivElement>) =>\n            expanded ? onDragStopTrigger(event) : undefined\n          }\n          id={id}\n        >\n          <Stack\n            direction=\"row\"\n            gap={1}\n            alignItems=\"center\"\n            justifyContent=\"center\"\n          >\n            {categoryIcon ? (\n              <ContainerCategoryIcon\n                alignItems=\"center\"\n                justifyContent=\"center\"\n              >\n                <CategoryIcon\n                  name={categoryIcon}\n                  variant={active ? 'primary' : categoryIconVariant}\n                  disabled={disabled}\n                />\n              </ContainerCategoryIcon>\n            ) : null}\n            {type === 'pinned' && expanded ? (\n              <GrabIcon\n                name=\"drag-vertical\"\n                sentiment=\"neutral\"\n                prominence=\"weak\"\n                size=\"small\"\n                disabled={disabled}\n              />\n            ) : null}\n            <Stack>\n              <WrapText\n                as=\"span\"\n                variant=\"bodySmallStrong\"\n                sentiment={active ? 'primary' : 'neutral'}\n                prominence={\n                  (categoryIcon || !hasParents) && !active\n                    ? 'strong'\n                    : 'default'\n                }\n                animation={animation}\n                disabled={disabled}\n              >\n                {label}\n              </WrapText>\n              {subLabel ? (\n                <WrapText\n                  as=\"span\"\n                  variant=\"caption\"\n                  sentiment=\"neutral\"\n                  prominence=\"weak\"\n                  animation={animation}\n                  disabled={disabled}\n                  subLabel\n                >\n                  {subLabel}\n                </WrapText>\n              ) : null}\n            </Stack>\n          </Stack>\n          <Stack direction=\"row\" alignItems=\"center\" gap={href ? 1 : undefined}>\n            {badgeText || hasPinnedFeatureAndNoChildren ? (\n              <>\n                {badgeText ? (\n                  <StyledBadge\n                    sentiment={badgeSentiment}\n                    size=\"small\"\n                    prominence=\"strong\"\n                    disabled={disabled}\n                  >\n                    {badgeText}\n                  </StyledBadge>\n                ) : null}\n                {shouldShowPinnedButton ? (\n                  <Tooltip\n                    text={\n                      isItemPinned\n                        ? locales['navigation.unpin.tooltip']\n                        : pinTooltipLocale\n                    }\n                    placement=\"right\"\n                  >\n                    <RelativeDiv>\n                      <PinnedButton\n                        role=\"button\"\n                        size=\"xsmall\"\n                        variant=\"ghost\"\n                        sentiment={active ? 'primary' : 'neutral'}\n                        onClick={(event: MouseEvent<HTMLDivElement>) => {\n                          event.preventDefault()\n                          event.stopPropagation() // This is to avoid click spread to the parent and change the routing\n                          if (isItemPinned) {\n                            unpinItem(id)\n                          } else {\n                            pinItem(id)\n                          }\n                          onPinUnpinClick?.(event)\n                        }}\n                        disabled={isItemPinned ? false : isPinDisabled}\n                      >\n                        <StyledIcon\n                          size=\"large\"\n                          name={isItemPinned ? 'unpin' : 'pin'}\n                          variant={isItemPinned ? 'filled' : 'outlined'}\n                          disabled={isItemPinned ? false : isPinDisabled}\n                          sentiment={active ? 'primary' : 'neutral'}\n                          active={active}\n                        />\n                      </PinnedButton>\n                    </RelativeDiv>\n                  </Tooltip>\n                ) : null}\n              </>\n            ) : null}\n            {hasHrefAndNoChildren ? (\n              <AnimatedIcon\n                name=\"open-in-new\"\n                sentiment=\"neutral\"\n                prominence=\"default\"\n                disabled={disabled}\n              />\n            ) : null}\n            {children ? (\n              <Stack gap={1} direction=\"row\" alignItems=\"center\">\n                {!animation && !noExpand ? (\n                  <AnimatedIcon\n                    name={internalToggle ? 'arrow-down' : 'arrow-right'}\n                    sentiment=\"neutral\"\n                    prominence=\"weak\"\n                  />\n                ) : null}\n              </Stack>\n            ) : null}\n          </Stack>\n        </Container>\n        {children ? (\n          <>\n            {!noExpand ? (\n              <Expandable\n                opened={internalToggle}\n                animationDuration={\n                  animation ? ANIMATION_DURATION / 2 : undefined\n                }\n              >\n                <PaddedStack>{renderChildren}</PaddedStack>\n              </Expandable>\n            ) : (\n              <PaddedStack>{renderChildren}</PaddedStack>\n            )}\n          </>\n        ) : null}\n      </>\n    )\n  }\n\n  // This content is the menu of the navigation when collapsed\n  if (categoryIcon || (Children.count(children) > 0 && !hasParents)) {\n    return (\n      <MenuStack gap={1} alignItems=\"start\" justifyContent=\"start\">\n        {Children.count(children) > 0 ? (\n          <StyledMenu\n            triggerMethod=\"hover\"\n            dynamicDomRendering={false} // As we parse the children we don't need dynamic rendering\n            disclosure={\n              <Button\n                sentiment=\"neutral\"\n                variant={hasActiveChildren ? 'filled' : 'ghost'}\n                size=\"small\"\n                icon={!categoryIcon ? 'dots-horizontal' : undefined}\n              >\n                {categoryIcon ? (\n                  <Stack\n                    direction=\"row\"\n                    gap={1}\n                    alignItems=\"center\"\n                    justifyContent=\"center\"\n                  >\n                    <CategoryIcon\n                      name={categoryIcon}\n                      variant={active ? 'primary' : categoryIconVariant}\n                    />\n                  </Stack>\n                ) : null}\n              </Button>\n            }\n            placement=\"right\"\n          >\n            {Children.map(children, child =>\n              isValidElement<ItemProps>(child)\n                ? cloneElement(child, {\n                    hasParents: true,\n                  })\n                : child,\n            )}\n          </StyledMenu>\n        ) : (\n          <Tooltip text={label} placement=\"right\" tabIndex={-1}>\n            <Button\n              sentiment=\"neutral\"\n              variant={active ? 'filled' : 'ghost'}\n              size=\"small\"\n              onClick={() => onClick?.()}\n            >\n              <Stack\n                direction=\"row\"\n                gap={1}\n                alignItems=\"center\"\n                justifyContent=\"center\"\n              >\n                <CategoryIcon\n                  name={categoryIcon ?? 'console'}\n                  variant={active ? 'primary' : categoryIconVariant}\n                />\n              </Stack>\n            </Button>\n          </Tooltip>\n        )}\n      </MenuStack>\n    )\n  }\n\n  // This content is what is inside a menu item the navigation is collapsed\n  if (hasParents) {\n    return (\n      <StyledMenuItem\n        href={href}\n        onClick={() => {\n          onClick?.()\n        }}\n        borderless\n        active={active}\n        disabled={disabled}\n        sentiment={active ? 'primary' : 'neutral'}\n        isPinnable={shouldShowPinnedButton}\n      >\n        <Stack\n          gap={1}\n          direction=\"row\"\n          alignItems=\"center\"\n          justifyContent=\"space-between\"\n          flex={1}\n          width=\"100%\"\n        >\n          <WrapText as=\"span\" variant=\"bodySmall\">\n            {label}\n          </WrapText>\n          <Stack direction=\"row\">\n            {badgeText ? (\n              <StyledBadge\n                sentiment={badgeSentiment}\n                size=\"small\"\n                prominence=\"strong\"\n                disabled={disabled}\n              >\n                {badgeText}\n              </StyledBadge>\n            ) : null}\n            {hasHrefAndNoChildren ? (\n              <AnimatedIcon\n                name=\"open-in-new\"\n                sentiment=\"neutral\"\n                prominence=\"weak\"\n                disabled={disabled}\n              />\n            ) : null}\n            {shouldShowPinnedButton ? (\n              <Tooltip\n                text={\n                  isItemPinned\n                    ? locales['navigation.unpin.tooltip']\n                    : pinTooltipLocale\n                }\n                placement=\"right\"\n              >\n                <RelativeDiv>\n                  <PinnedButton\n                    role=\"button\"\n                    size=\"xsmall\"\n                    variant=\"ghost\"\n                    sentiment={active ? 'primary' : 'neutral'}\n                    onClick={(event: MouseEvent<HTMLDivElement>) => {\n                      event.preventDefault()\n                      event.stopPropagation() // This is to avoid click spread to the parent and change the routing\n                      if (isItemPinned) {\n                        unpinItem(id)\n                      } else {\n                        pinItem(id)\n                      }\n                      onPinUnpinClick?.(event)\n                    }}\n                    disabled={isItemPinned ? false : isPinDisabled}\n                  >\n                    <StyledIcon\n                      size=\"large\"\n                      name={isItemPinned ? 'unpin' : 'pin'}\n                      variant={isItemPinned ? 'filled' : 'outlined'}\n                      disabled={isItemPinned ? false : isPinDisabled}\n                      sentiment={active ? 'primary' : 'neutral'}\n                      active={active}\n                    />\n                  </PinnedButton>\n                </RelativeDiv>\n              </Tooltip>\n            ) : null}\n          </Stack>\n        </Stack>\n      </StyledMenuItem>\n    )\n  }\n\n  // This content is for when navigation is collapsed and we show an icon of link\n  if (!hasParents && href) {\n    return (\n      <Tooltip text={label} placement=\"right\">\n        <MenuStack gap={1} alignItems=\"start\" justifyContent=\"start\">\n          <Container\n            gap={1}\n            alignItems=\"center\"\n            justifyContent=\"center\"\n            href={href}\n            target=\"_blank\"\n          >\n            <AnimatedIcon\n              name=\"open-in-new\"\n              sentiment=\"neutral\"\n              prominence=\"weak\"\n            />\n          </Container>\n        </MenuStack>\n      </Tooltip>\n    )\n  }\n\n  return null\n}\n"]} */",
49
+ toString: _EMOTION_STRINGIFIED_CSS_ERROR__
50
+ };
51
+ const LocalExpandButton = /* @__PURE__ */ _styled(Button, process.env.NODE_ENV === "production" ? {
52
+ target: "e134hokc11"
53
+ } : {
54
+ target: "e134hokc11",
55
+ label: "LocalExpandButton"
56
+ })(process.env.NODE_ENV === "production" ? {
57
+ name: "9hkyle",
58
+ styles: "opacity:0;right:0;position:absolute;left:-24px;top:0;bottom:0;margin:auto;&:hover,&:focus,&:active{opacity:1;}"
59
+ } : {
60
+ name: "9hkyle",
61
+ styles: "opacity:0;right:0;position:absolute;left:-24px;top:0;bottom:0;margin:auto;&:hover,&:focus,&:active{opacity:1;}",
62
+ map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["/home/runner/work/ultraviolet/ultraviolet/packages/plus/src/components/Navigation/components/Item.tsx"],"names":[],"mappings":"AA8DwC","file":"/home/runner/work/ultraviolet/ultraviolet/packages/plus/src/components/Navigation/components/Item.tsx","sourcesContent":["import { css } from '@emotion/react'\nimport styled from '@emotion/styled'\nimport { CategoryIcon, Icon } from '@ultraviolet/icons'\nimport {\n  Badge,\n  Button,\n  Expandable,\n  MenuV2,\n  Stack,\n  Text,\n  Tooltip,\n  fadeIn,\n} from '@ultraviolet/ui'\nimport type {\n  ComponentProps,\n  DragEvent,\n  JSX,\n  MouseEvent,\n  ReactNode,\n} from 'react'\nimport {\n  Children,\n  cloneElement,\n  isValidElement,\n  useCallback,\n  useEffect,\n  useMemo,\n  useState,\n} from 'react'\nimport { useNavigation } from '../NavigationProvider'\nimport { ANIMATION_DURATION, shrinkHeight } from '../constants'\n\nconst RelativeDiv = styled.div`\n  position: relative;\n`\n\nconst StyledIcon = styled(Icon, {\n  shouldForwardProp: prop => !['active'].includes(prop),\n})<{ active?: boolean }>`\n  position: absolute;\n  top: 0;\n  bottom: 0;\n  margin: auto 0;\n  padding: ${({ theme }) => theme.space['0.25']};\n  border-radius: ${({ theme }) => theme.radii.default};\n  &:hover {\n    background: ${({ theme }) => theme.colors.neutral.backgroundWeakHover};\n\n    ${({ active, theme }) => (active ? `background: ${theme.colors.primary.backgroundHover};` : null)}\n    }\n  }\n`\n\nconst NeutralButtonLink = css`\n  color: inherit;\n  text-decoration: none;\n  background-color: inherit;\n  border: none;\n  text-align: left;\n`\n\n// Pin button when the navigation is expanded\nconst LocalExpandButton = styled(Button)`\n  opacity: 0;\n  right: 0;\n  position: absolute;\n  left: -24px;\n  top: 0;\n  bottom: 0;\n  margin: auto;\n\n  &:hover,\n  &:focus,\n  &:active {\n    opacity: 1;\n  }\n`\n\nconst PinnedButton = LocalExpandButton.withComponent('div')\n\nconst GrabIcon = styled(Icon)`\n  opacity: 0;\n  margin: 0 ${({ theme }) => theme.space['0.25']};\n  cursor: grab;\n`\n\nconst StyledBadge = styled(Badge)``\n\nconst StyledMenuItem = styled(MenuV2.Item, {\n  shouldForwardProp: prop => !['isPinnable'].includes(prop),\n})<{\n  isPinnable?: boolean\n}>`\n  text-align: left;\n\n  &:hover,\n  &:focus,\n  &:active {\n    ${PinnedButton} {\n      opacity: 1;\n    }\n\n    ${StyledBadge} {\n      opacity: ${({ isPinnable }) => (isPinnable ? 0 : 1)};\n    }\n  }\n`\n\nconst StyledMenu = styled(MenuV2)`\n  width: 180px;\n`\n\nconst PaddingStack = styled(Stack)`\n  padding-left: 28px; // This value needs to be hardcoded because of the category icon size\n`\n\nconst AnimatedIcon = styled(Icon)``\n\nconst WrapText = styled(Text, {\n  shouldForwardProp: prop =>\n    !['animation', 'subLabel', 'textProminence'].includes(prop),\n})<{\n  animation?: 'collapse' | 'expand' | boolean\n  subLabel?: boolean\n}>`\n  overflow-wrap: ${({ animation }) => (animation ? 'normal' : 'anywhere')};\n  white-space: ${({ animation }) => (animation ? 'nowrap' : 'normal')};\n  overflow: hidden;\n  display: -webkit-box;\n  -webkit-box-orient: vertical;\n  -webkit-line-clamp: 2;\n  white-space: pre-wrap;\n`\n\nconst StyledStack = styled(Stack)`\n  padding-left: 28px; // This value needs to be hardcoded because of the category icon size\n`\n\nconst StyledContainer = styled(Stack)`\n  ${NeutralButtonLink};\n  border-radius: ${({ theme }) => theme.radii.default};\n\n  &[data-has-no-expand='false'] {\n    cursor: pointer;\n  }\n  margin-top: ${({ theme }) => theme.space['0.25']};\n  padding: ${({ theme }) =>\n    `calc(${theme.space['0.25']} + ${theme.space['0.5']}) ${theme.space['1']}`};\n\n  &[data-has-sub-label='true'] {\n    padding: ${({ theme }) => `${theme.space['0.5']} ${theme.space['1']}`};\n  }\n\n  width: 100%;\n\n  &:hover[data-has-no-expand='false']:not([disabled]):not(\n      [data-is-active='true']\n    ),\n  &:focus[data-has-no-expand='false']:not([disabled]):not(\n      [data-is-active='true']\n    ) {\n    background-color: ${({ theme }) => theme.colors.neutral.backgroundWeak};\n  }\n  &[data-has-active-children='true'][data-has-no-expand='false']:not(\n      [disabled][data-is-active='true']\n    ) {\n    background-color: ${({ theme }) =>\n      theme.colors.neutral.backgroundWeakHover};\n    ${WrapText} {\n      color: ${({ theme }) => theme.colors.neutral.textWeakHover};\n    }\n\n    ${PinnedButton} {\n      opacity: 1;\n    }\n\n    &[data-is-pinnable='true'] {\n      ${StyledBadge} {\n        opacity: 0;\n      }\n    }\n  }\n\n  &[data-has-no-expand='false']:not([disabled]) {\n    &:hover,\n    &:focus,\n    &:active {\n      ${PinnedButton}, ${GrabIcon} {\n        opacity: 1;\n      }\n\n      ${StyledBadge} {\n        opacity: 0;\n      }\n    }\n  }\n\n  &:hover[data-has-children='false'][data-is-active='false']:not([disabled]) {\n    ${WrapText} {\n      color: ${({ theme }) => theme.colors.neutral.textWeakHover};\n    }\n  }\n\n  &:active[data-has-no-expand='false']:not([disabled]):not(\n      [data-is-active='true']\n    ) {\n    background-color: ${({ theme }) => theme.colors.neutral.backgroundHover};\n  }\n\n  &[data-is-active='true'],\n  &:hover[data-has-active='true'] {\n    background-color: ${({ theme }) => theme.colors.primary.background};\n\n    &:hover {\n      background-color: ${({ theme }) => theme.colors.primary.backgroundHover};\n    }\n  }\n\n  &[disabled] {\n    cursor: not-allowed;\n    background-color: unset;\n\n    ${WrapText} {\n      color: ${({ theme }) => theme.colors.neutral.textWeakDisabled};\n    }\n  }\n\n  &[data-animation='collapse'] {\n    animation: ${shrinkHeight} ${ANIMATION_DURATION}ms ease-in-out;\n    ${WrapText}, ${AnimatedIcon}, ${StyledBadge} {\n      animation: ${fadeIn} ${ANIMATION_DURATION}ms ease-in-out reverse;\n    }\n  }\n\n  &[data-animation='expand'] {\n    animation: ${shrinkHeight} ${ANIMATION_DURATION}ms ease-in-out reverse;\n    ${WrapText}, ${AnimatedIcon}, ${StyledBadge} {\n      animation: ${fadeIn} ${ANIMATION_DURATION}ms ease-in-out;\n    }\n\n    ${StyledStack} {\n      display: none;\n    }\n  }\n`\n\nconst MenuStack = styled(Stack)`\n  padding: ${({ theme }) => `0 ${theme.space['2']}`};\n  margin-top: ${({ theme }) => theme.space['0.25']};\n`\n\nconst ContainerCategoryIcon = styled(Stack)`\n  min-width: 20px;\n`\n\ntype ItemType = 'default' | 'pinned' | 'pinnedGroup'\n\ntype ItemProps = {\n  children?: ReactNode\n  /**\n   * Sets a category icon on the left of the item\n   */\n  categoryIcon?: ComponentProps<typeof CategoryIcon>['name']\n  categoryIconVariant?: ComponentProps<typeof CategoryIcon>['variant']\n  /**\n   * The label of the item that will be shown.\n   * It is also used as the key for pinning.\n   */\n  label: string\n  /**\n   * It should be a unique id and will be used for pin/unpin feature.\n   */\n  id: string\n  /**\n   * Text shown under the label with a lighter color and smaller font size\n   */\n  subLabel?: string\n  /**\n   * Badge is added on the right of the item. It is hidden on hover if pinned\n   * feature is enabled\n   */\n  badgeText?: string\n  /**\n   * Defined the sentiment of the badge according to Badge component from\n   * `@ultraviolet/ui`\n   */\n  badgeSentiment?: ComponentProps<typeof Badge>['sentiment']\n  href?: string\n  /**\n   * This function will be triggered on click of the item. If the item is expandable\n   * toggle will be passed with it.\n   */\n  onClick?: (toggle?: true | false) => void\n  onPinUnpinClick?: (event: MouseEvent<HTMLDivElement>) => void\n  /**\n   * This prop is used to control if the item is expanded or collapsed\n   */\n  toggle?: boolean\n  /**\n   * Set this to true if your current page is this item.\n   */\n  active?: boolean\n  /**\n   * If you want to remove pin button on your item use this prop\n   */\n  noPinButton?: boolean\n  /**\n   * You don't need to use this prop it's used internally to control the type of the item\n   */\n  type?: ItemType\n  /**\n   * You don't need to use this prop it's used internally to control if the item has a parent\n   */\n  hasParents?: boolean\n  /**\n   * You don't need to use this prop it's used internally for pinned item to be reorganized with drag and drop\n   */\n  index?: number\n  /**\n   * When the item has href it becomes a link if not it is a button.\n   * When using an external routing tool you might need to remove both of them and use\n   * a non focusable element. This option allows you to choose the tag of the\n   * item.\n   */\n  as?: keyof JSX.IntrinsicElements\n  /**\n   * Use this prop if you want to remove the expand behavior when the item\n   * has sub items.\n   */\n  noExpand?: boolean\n  disabled?: boolean\n}\n\nexport const Item = ({\n  children,\n  categoryIcon,\n  categoryIconVariant,\n  label,\n  subLabel,\n  badgeText,\n  badgeSentiment,\n  href,\n  onClick,\n  onPinUnpinClick,\n  toggle,\n  active,\n  noPinButton,\n  type = 'default',\n  hasParents,\n  as,\n  disabled,\n  noExpand = false,\n  index,\n  id,\n}: ItemProps) => {\n  const context = useNavigation()\n\n  if (!context) {\n    throw new Error(\n      'Navigation.Item can only be used inside a NavigationProvider.',\n    )\n  }\n\n  const {\n    expanded,\n    locales,\n    pinnedFeature,\n    pinItem,\n    unpinItem,\n    pinnedItems,\n    pinLimit,\n    animation,\n    registerItem,\n  } = context\n\n  useEffect(\n    () => {\n      if (type !== 'pinnedGroup') {\n        registerItem({ [id]: { label, active, onClick } })\n      }\n    },\n    // eslint-disable-next-line react-hooks/exhaustive-deps\n    [active, id, label, registerItem],\n  )\n\n  const [internalToggle, setToggle] = useState(toggle !== false)\n\n  const triggerToggle = useCallback(\n    (value: boolean) => {\n      setToggle(value)\n      onClick?.(internalToggle)\n    },\n    [internalToggle, onClick],\n  )\n\n  useEffect(() => {\n    if (animation === 'collapse') {\n      setToggle(false)\n    }\n\n    if (animation === 'expand') {\n      setTimeout(() => {\n        setToggle(toggle ?? true)\n      }, 1)\n    }\n  }, [animation, toggle])\n\n  const PaddedStack = noExpand || type === 'pinnedGroup' ? Stack : PaddingStack\n\n  const hasHrefAndNoChildren = href && !children\n  const hasPinnedFeatureAndNoChildren =\n    pinnedFeature && !children && !noPinButton\n  const isItemPinned = pinnedItems.includes(id)\n  const shouldShowPinnedButton = useMemo(() => {\n    if (href || disabled) return false\n\n    if (hasPinnedFeatureAndNoChildren && type !== 'default') {\n      return true\n    }\n\n    if (hasPinnedFeatureAndNoChildren) {\n      return true\n    }\n\n    return false\n  }, [disabled, hasPinnedFeatureAndNoChildren, href, type])\n\n  const hasActiveChildren = useMemo(() => {\n    if (!children) return false\n\n    return (\n      Children.map(children, child =>\n        isValidElement<ItemProps>(child) ? child.props?.active : false,\n      ) as boolean[]\n    ).includes(true)\n  }, [children])\n\n  const containerTag = useMemo(() => {\n    if (as) {\n      return as\n    }\n\n    if (hasHrefAndNoChildren) {\n      return 'a'\n    }\n\n    if (noExpand) {\n      return 'div'\n    }\n\n    return 'button'\n  }, [as, hasHrefAndNoChildren, noExpand])\n\n  const Container = StyledContainer.withComponent(containerTag)\n\n  const ariaExpanded = useMemo(() => {\n    if (hasHrefAndNoChildren && internalToggle) {\n      return true\n    }\n\n    if (hasHrefAndNoChildren && !internalToggle) {\n      return false\n    }\n\n    return undefined\n  }, [hasHrefAndNoChildren, internalToggle])\n\n  const isPinDisabled = pinnedItems.length >= pinLimit\n  const pinTooltipLocale = useMemo(() => {\n    if (isPinDisabled) {\n      return locales['navigation.pin.limit']\n    }\n\n    if (isItemPinned) {\n      return locales['navigation.unpin.tooltip']\n    }\n\n    return locales['navigation.pin.tooltip']\n  }, [isItemPinned, isPinDisabled, locales])\n\n  const onDragStartTrigger = (event: DragEvent<HTMLDivElement>) => {\n    event.dataTransfer.setData('text/plain', JSON.stringify({ label, index }))\n    // eslint-disable-next-line no-param-reassign\n    event.currentTarget.style.opacity = '0.5'\n  }\n\n  const onDragStopTrigger = (event: DragEvent<HTMLDivElement>) => {\n    // eslint-disable-next-line no-param-reassign\n    event.currentTarget.style.opacity = '1'\n  }\n\n  // This content is when the navigation is expanded\n  if (expanded || (!expanded && animation === 'expand')) {\n    const renderChildren = Children.map(children, child =>\n      isValidElement<ItemProps>(child)\n        ? cloneElement(child, {\n            hasParents: true,\n          })\n        : child,\n    )\n\n    return (\n      <>\n        <Container\n          gap={1}\n          direction=\"row\"\n          alignItems=\"center\"\n          justifyContent=\"space-between\"\n          data-has-sub-label={!!subLabel}\n          onClick={() => {\n            if (children) {\n              return triggerToggle(!internalToggle)\n            }\n\n            return onClick?.()\n          }}\n          aria-expanded={ariaExpanded}\n          href={href}\n          target={href ? '_blank' : undefined}\n          data-is-pinnable={shouldShowPinnedButton}\n          data-is-active={active}\n          data-animation={animation}\n          data-has-children={!!children}\n          data-has-active-children={hasActiveChildren}\n          data-has-no-expand={noExpand}\n          disabled={disabled}\n          draggable={type === 'pinned' && expanded}\n          onDragStart={(event: DragEvent<HTMLDivElement>) =>\n            expanded ? onDragStartTrigger(event) : undefined\n          }\n          onDragEnd={(event: DragEvent<HTMLDivElement>) =>\n            expanded ? onDragStopTrigger(event) : undefined\n          }\n          id={id}\n        >\n          <Stack\n            direction=\"row\"\n            gap={1}\n            alignItems=\"center\"\n            justifyContent=\"center\"\n          >\n            {categoryIcon ? (\n              <ContainerCategoryIcon\n                alignItems=\"center\"\n                justifyContent=\"center\"\n              >\n                <CategoryIcon\n                  name={categoryIcon}\n                  variant={active ? 'primary' : categoryIconVariant}\n                  disabled={disabled}\n                />\n              </ContainerCategoryIcon>\n            ) : null}\n            {type === 'pinned' && expanded ? (\n              <GrabIcon\n                name=\"drag-vertical\"\n                sentiment=\"neutral\"\n                prominence=\"weak\"\n                size=\"small\"\n                disabled={disabled}\n              />\n            ) : null}\n            <Stack>\n              <WrapText\n                as=\"span\"\n                variant=\"bodySmallStrong\"\n                sentiment={active ? 'primary' : 'neutral'}\n                prominence={\n                  (categoryIcon || !hasParents) && !active\n                    ? 'strong'\n                    : 'default'\n                }\n                animation={animation}\n                disabled={disabled}\n              >\n                {label}\n              </WrapText>\n              {subLabel ? (\n                <WrapText\n                  as=\"span\"\n                  variant=\"caption\"\n                  sentiment=\"neutral\"\n                  prominence=\"weak\"\n                  animation={animation}\n                  disabled={disabled}\n                  subLabel\n                >\n                  {subLabel}\n                </WrapText>\n              ) : null}\n            </Stack>\n          </Stack>\n          <Stack direction=\"row\" alignItems=\"center\" gap={href ? 1 : undefined}>\n            {badgeText || hasPinnedFeatureAndNoChildren ? (\n              <>\n                {badgeText ? (\n                  <StyledBadge\n                    sentiment={badgeSentiment}\n                    size=\"small\"\n                    prominence=\"strong\"\n                    disabled={disabled}\n                  >\n                    {badgeText}\n                  </StyledBadge>\n                ) : null}\n                {shouldShowPinnedButton ? (\n                  <Tooltip\n                    text={\n                      isItemPinned\n                        ? locales['navigation.unpin.tooltip']\n                        : pinTooltipLocale\n                    }\n                    placement=\"right\"\n                  >\n                    <RelativeDiv>\n                      <PinnedButton\n                        role=\"button\"\n                        size=\"xsmall\"\n                        variant=\"ghost\"\n                        sentiment={active ? 'primary' : 'neutral'}\n                        onClick={(event: MouseEvent<HTMLDivElement>) => {\n                          event.preventDefault()\n                          event.stopPropagation() // This is to avoid click spread to the parent and change the routing\n                          if (isItemPinned) {\n                            unpinItem(id)\n                          } else {\n                            pinItem(id)\n                          }\n                          onPinUnpinClick?.(event)\n                        }}\n                        disabled={isItemPinned ? false : isPinDisabled}\n                      >\n                        <StyledIcon\n                          size=\"large\"\n                          name={isItemPinned ? 'unpin' : 'pin'}\n                          variant={isItemPinned ? 'filled' : 'outlined'}\n                          disabled={isItemPinned ? false : isPinDisabled}\n                          sentiment={active ? 'primary' : 'neutral'}\n                          active={active}\n                        />\n                      </PinnedButton>\n                    </RelativeDiv>\n                  </Tooltip>\n                ) : null}\n              </>\n            ) : null}\n            {hasHrefAndNoChildren ? (\n              <AnimatedIcon\n                name=\"open-in-new\"\n                sentiment=\"neutral\"\n                prominence=\"default\"\n                disabled={disabled}\n              />\n            ) : null}\n            {children ? (\n              <Stack gap={1} direction=\"row\" alignItems=\"center\">\n                {!animation && !noExpand ? (\n                  <AnimatedIcon\n                    name={internalToggle ? 'arrow-down' : 'arrow-right'}\n                    sentiment=\"neutral\"\n                    prominence=\"weak\"\n                  />\n                ) : null}\n              </Stack>\n            ) : null}\n          </Stack>\n        </Container>\n        {children ? (\n          <>\n            {!noExpand ? (\n              <Expandable\n                opened={internalToggle}\n                animationDuration={\n                  animation ? ANIMATION_DURATION / 2 : undefined\n                }\n              >\n                <PaddedStack>{renderChildren}</PaddedStack>\n              </Expandable>\n            ) : (\n              <PaddedStack>{renderChildren}</PaddedStack>\n            )}\n          </>\n        ) : null}\n      </>\n    )\n  }\n\n  // This content is the menu of the navigation when collapsed\n  if (categoryIcon || (Children.count(children) > 0 && !hasParents)) {\n    return (\n      <MenuStack gap={1} alignItems=\"start\" justifyContent=\"start\">\n        {Children.count(children) > 0 ? (\n          <StyledMenu\n            triggerMethod=\"hover\"\n            dynamicDomRendering={false} // As we parse the children we don't need dynamic rendering\n            disclosure={\n              <Button\n                sentiment=\"neutral\"\n                variant={hasActiveChildren ? 'filled' : 'ghost'}\n                size=\"small\"\n                icon={!categoryIcon ? 'dots-horizontal' : undefined}\n              >\n                {categoryIcon ? (\n                  <Stack\n                    direction=\"row\"\n                    gap={1}\n                    alignItems=\"center\"\n                    justifyContent=\"center\"\n                  >\n                    <CategoryIcon\n                      name={categoryIcon}\n                      variant={active ? 'primary' : categoryIconVariant}\n                    />\n                  </Stack>\n                ) : null}\n              </Button>\n            }\n            placement=\"right\"\n          >\n            {Children.map(children, child =>\n              isValidElement<ItemProps>(child)\n                ? cloneElement(child, {\n                    hasParents: true,\n                  })\n                : child,\n            )}\n          </StyledMenu>\n        ) : (\n          <Tooltip text={label} placement=\"right\" tabIndex={-1}>\n            <Button\n              sentiment=\"neutral\"\n              variant={active ? 'filled' : 'ghost'}\n              size=\"small\"\n              onClick={() => onClick?.()}\n            >\n              <Stack\n                direction=\"row\"\n                gap={1}\n                alignItems=\"center\"\n                justifyContent=\"center\"\n              >\n                <CategoryIcon\n                  name={categoryIcon ?? 'console'}\n                  variant={active ? 'primary' : categoryIconVariant}\n                />\n              </Stack>\n            </Button>\n          </Tooltip>\n        )}\n      </MenuStack>\n    )\n  }\n\n  // This content is what is inside a menu item the navigation is collapsed\n  if (hasParents) {\n    return (\n      <StyledMenuItem\n        href={href}\n        onClick={() => {\n          onClick?.()\n        }}\n        borderless\n        active={active}\n        disabled={disabled}\n        sentiment={active ? 'primary' : 'neutral'}\n        isPinnable={shouldShowPinnedButton}\n      >\n        <Stack\n          gap={1}\n          direction=\"row\"\n          alignItems=\"center\"\n          justifyContent=\"space-between\"\n          flex={1}\n          width=\"100%\"\n        >\n          <WrapText as=\"span\" variant=\"bodySmall\">\n            {label}\n          </WrapText>\n          <Stack direction=\"row\">\n            {badgeText ? (\n              <StyledBadge\n                sentiment={badgeSentiment}\n                size=\"small\"\n                prominence=\"strong\"\n                disabled={disabled}\n              >\n                {badgeText}\n              </StyledBadge>\n            ) : null}\n            {hasHrefAndNoChildren ? (\n              <AnimatedIcon\n                name=\"open-in-new\"\n                sentiment=\"neutral\"\n                prominence=\"weak\"\n                disabled={disabled}\n              />\n            ) : null}\n            {shouldShowPinnedButton ? (\n              <Tooltip\n                text={\n                  isItemPinned\n                    ? locales['navigation.unpin.tooltip']\n                    : pinTooltipLocale\n                }\n                placement=\"right\"\n              >\n                <RelativeDiv>\n                  <PinnedButton\n                    role=\"button\"\n                    size=\"xsmall\"\n                    variant=\"ghost\"\n                    sentiment={active ? 'primary' : 'neutral'}\n                    onClick={(event: MouseEvent<HTMLDivElement>) => {\n                      event.preventDefault()\n                      event.stopPropagation() // This is to avoid click spread to the parent and change the routing\n                      if (isItemPinned) {\n                        unpinItem(id)\n                      } else {\n                        pinItem(id)\n                      }\n                      onPinUnpinClick?.(event)\n                    }}\n                    disabled={isItemPinned ? false : isPinDisabled}\n                  >\n                    <StyledIcon\n                      size=\"large\"\n                      name={isItemPinned ? 'unpin' : 'pin'}\n                      variant={isItemPinned ? 'filled' : 'outlined'}\n                      disabled={isItemPinned ? false : isPinDisabled}\n                      sentiment={active ? 'primary' : 'neutral'}\n                      active={active}\n                    />\n                  </PinnedButton>\n                </RelativeDiv>\n              </Tooltip>\n            ) : null}\n          </Stack>\n        </Stack>\n      </StyledMenuItem>\n    )\n  }\n\n  // This content is for when navigation is collapsed and we show an icon of link\n  if (!hasParents && href) {\n    return (\n      <Tooltip text={label} placement=\"right\">\n        <MenuStack gap={1} alignItems=\"start\" justifyContent=\"start\">\n          <Container\n            gap={1}\n            alignItems=\"center\"\n            justifyContent=\"center\"\n            href={href}\n            target=\"_blank\"\n          >\n            <AnimatedIcon\n              name=\"open-in-new\"\n              sentiment=\"neutral\"\n              prominence=\"weak\"\n            />\n          </Container>\n        </MenuStack>\n      </Tooltip>\n    )\n  }\n\n  return null\n}\n"]} */",
63
+ toString: _EMOTION_STRINGIFIED_CSS_ERROR__
64
+ });
65
+ const PinnedButton = LocalExpandButton.withComponent("div", process.env.NODE_ENV === "production" ? {
66
+ target: "e134hokc14"
67
+ } : {
68
+ target: "e134hokc14",
69
+ label: "PinnedButton"
70
+ });
71
+ const GrabIcon = /* @__PURE__ */ _styled(Icon, process.env.NODE_ENV === "production" ? {
72
+ target: "e134hokc10"
73
+ } : {
74
+ target: "e134hokc10",
75
+ label: "GrabIcon"
76
+ })("opacity:0;margin:0 ", ({
77
+ theme
78
+ }) => theme.space["0.25"], ";cursor:grab;" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["/home/runner/work/ultraviolet/ultraviolet/packages/plus/src/components/Navigation/components/Item.tsx"],"names":[],"mappings":"AAgF6B","file":"/home/runner/work/ultraviolet/ultraviolet/packages/plus/src/components/Navigation/components/Item.tsx","sourcesContent":["import { css } from '@emotion/react'\nimport styled from '@emotion/styled'\nimport { CategoryIcon, Icon } from '@ultraviolet/icons'\nimport {\n  Badge,\n  Button,\n  Expandable,\n  MenuV2,\n  Stack,\n  Text,\n  Tooltip,\n  fadeIn,\n} from '@ultraviolet/ui'\nimport type {\n  ComponentProps,\n  DragEvent,\n  JSX,\n  MouseEvent,\n  ReactNode,\n} from 'react'\nimport {\n  Children,\n  cloneElement,\n  isValidElement,\n  useCallback,\n  useEffect,\n  useMemo,\n  useState,\n} from 'react'\nimport { useNavigation } from '../NavigationProvider'\nimport { ANIMATION_DURATION, shrinkHeight } from '../constants'\n\nconst RelativeDiv = styled.div`\n  position: relative;\n`\n\nconst StyledIcon = styled(Icon, {\n  shouldForwardProp: prop => !['active'].includes(prop),\n})<{ active?: boolean }>`\n  position: absolute;\n  top: 0;\n  bottom: 0;\n  margin: auto 0;\n  padding: ${({ theme }) => theme.space['0.25']};\n  border-radius: ${({ theme }) => theme.radii.default};\n  &:hover {\n    background: ${({ theme }) => theme.colors.neutral.backgroundWeakHover};\n\n    ${({ active, theme }) => (active ? `background: ${theme.colors.primary.backgroundHover};` : null)}\n    }\n  }\n`\n\nconst NeutralButtonLink = css`\n  color: inherit;\n  text-decoration: none;\n  background-color: inherit;\n  border: none;\n  text-align: left;\n`\n\n// Pin button when the navigation is expanded\nconst LocalExpandButton = styled(Button)`\n  opacity: 0;\n  right: 0;\n  position: absolute;\n  left: -24px;\n  top: 0;\n  bottom: 0;\n  margin: auto;\n\n  &:hover,\n  &:focus,\n  &:active {\n    opacity: 1;\n  }\n`\n\nconst PinnedButton = LocalExpandButton.withComponent('div')\n\nconst GrabIcon = styled(Icon)`\n  opacity: 0;\n  margin: 0 ${({ theme }) => theme.space['0.25']};\n  cursor: grab;\n`\n\nconst StyledBadge = styled(Badge)``\n\nconst StyledMenuItem = styled(MenuV2.Item, {\n  shouldForwardProp: prop => !['isPinnable'].includes(prop),\n})<{\n  isPinnable?: boolean\n}>`\n  text-align: left;\n\n  &:hover,\n  &:focus,\n  &:active {\n    ${PinnedButton} {\n      opacity: 1;\n    }\n\n    ${StyledBadge} {\n      opacity: ${({ isPinnable }) => (isPinnable ? 0 : 1)};\n    }\n  }\n`\n\nconst StyledMenu = styled(MenuV2)`\n  width: 180px;\n`\n\nconst PaddingStack = styled(Stack)`\n  padding-left: 28px; // This value needs to be hardcoded because of the category icon size\n`\n\nconst AnimatedIcon = styled(Icon)``\n\nconst WrapText = styled(Text, {\n  shouldForwardProp: prop =>\n    !['animation', 'subLabel', 'textProminence'].includes(prop),\n})<{\n  animation?: 'collapse' | 'expand' | boolean\n  subLabel?: boolean\n}>`\n  overflow-wrap: ${({ animation }) => (animation ? 'normal' : 'anywhere')};\n  white-space: ${({ animation }) => (animation ? 'nowrap' : 'normal')};\n  overflow: hidden;\n  display: -webkit-box;\n  -webkit-box-orient: vertical;\n  -webkit-line-clamp: 2;\n  white-space: pre-wrap;\n`\n\nconst StyledStack = styled(Stack)`\n  padding-left: 28px; // This value needs to be hardcoded because of the category icon size\n`\n\nconst StyledContainer = styled(Stack)`\n  ${NeutralButtonLink};\n  border-radius: ${({ theme }) => theme.radii.default};\n\n  &[data-has-no-expand='false'] {\n    cursor: pointer;\n  }\n  margin-top: ${({ theme }) => theme.space['0.25']};\n  padding: ${({ theme }) =>\n    `calc(${theme.space['0.25']} + ${theme.space['0.5']}) ${theme.space['1']}`};\n\n  &[data-has-sub-label='true'] {\n    padding: ${({ theme }) => `${theme.space['0.5']} ${theme.space['1']}`};\n  }\n\n  width: 100%;\n\n  &:hover[data-has-no-expand='false']:not([disabled]):not(\n      [data-is-active='true']\n    ),\n  &:focus[data-has-no-expand='false']:not([disabled]):not(\n      [data-is-active='true']\n    ) {\n    background-color: ${({ theme }) => theme.colors.neutral.backgroundWeak};\n  }\n  &[data-has-active-children='true'][data-has-no-expand='false']:not(\n      [disabled][data-is-active='true']\n    ) {\n    background-color: ${({ theme }) =>\n      theme.colors.neutral.backgroundWeakHover};\n    ${WrapText} {\n      color: ${({ theme }) => theme.colors.neutral.textWeakHover};\n    }\n\n    ${PinnedButton} {\n      opacity: 1;\n    }\n\n    &[data-is-pinnable='true'] {\n      ${StyledBadge} {\n        opacity: 0;\n      }\n    }\n  }\n\n  &[data-has-no-expand='false']:not([disabled]) {\n    &:hover,\n    &:focus,\n    &:active {\n      ${PinnedButton}, ${GrabIcon} {\n        opacity: 1;\n      }\n\n      ${StyledBadge} {\n        opacity: 0;\n      }\n    }\n  }\n\n  &:hover[data-has-children='false'][data-is-active='false']:not([disabled]) {\n    ${WrapText} {\n      color: ${({ theme }) => theme.colors.neutral.textWeakHover};\n    }\n  }\n\n  &:active[data-has-no-expand='false']:not([disabled]):not(\n      [data-is-active='true']\n    ) {\n    background-color: ${({ theme }) => theme.colors.neutral.backgroundHover};\n  }\n\n  &[data-is-active='true'],\n  &:hover[data-has-active='true'] {\n    background-color: ${({ theme }) => theme.colors.primary.background};\n\n    &:hover {\n      background-color: ${({ theme }) => theme.colors.primary.backgroundHover};\n    }\n  }\n\n  &[disabled] {\n    cursor: not-allowed;\n    background-color: unset;\n\n    ${WrapText} {\n      color: ${({ theme }) => theme.colors.neutral.textWeakDisabled};\n    }\n  }\n\n  &[data-animation='collapse'] {\n    animation: ${shrinkHeight} ${ANIMATION_DURATION}ms ease-in-out;\n    ${WrapText}, ${AnimatedIcon}, ${StyledBadge} {\n      animation: ${fadeIn} ${ANIMATION_DURATION}ms ease-in-out reverse;\n    }\n  }\n\n  &[data-animation='expand'] {\n    animation: ${shrinkHeight} ${ANIMATION_DURATION}ms ease-in-out reverse;\n    ${WrapText}, ${AnimatedIcon}, ${StyledBadge} {\n      animation: ${fadeIn} ${ANIMATION_DURATION}ms ease-in-out;\n    }\n\n    ${StyledStack} {\n      display: none;\n    }\n  }\n`\n\nconst MenuStack = styled(Stack)`\n  padding: ${({ theme }) => `0 ${theme.space['2']}`};\n  margin-top: ${({ theme }) => theme.space['0.25']};\n`\n\nconst ContainerCategoryIcon = styled(Stack)`\n  min-width: 20px;\n`\n\ntype ItemType = 'default' | 'pinned' | 'pinnedGroup'\n\ntype ItemProps = {\n  children?: ReactNode\n  /**\n   * Sets a category icon on the left of the item\n   */\n  categoryIcon?: ComponentProps<typeof CategoryIcon>['name']\n  categoryIconVariant?: ComponentProps<typeof CategoryIcon>['variant']\n  /**\n   * The label of the item that will be shown.\n   * It is also used as the key for pinning.\n   */\n  label: string\n  /**\n   * It should be a unique id and will be used for pin/unpin feature.\n   */\n  id: string\n  /**\n   * Text shown under the label with a lighter color and smaller font size\n   */\n  subLabel?: string\n  /**\n   * Badge is added on the right of the item. It is hidden on hover if pinned\n   * feature is enabled\n   */\n  badgeText?: string\n  /**\n   * Defined the sentiment of the badge according to Badge component from\n   * `@ultraviolet/ui`\n   */\n  badgeSentiment?: ComponentProps<typeof Badge>['sentiment']\n  href?: string\n  /**\n   * This function will be triggered on click of the item. If the item is expandable\n   * toggle will be passed with it.\n   */\n  onClick?: (toggle?: true | false) => void\n  onPinUnpinClick?: (event: MouseEvent<HTMLDivElement>) => void\n  /**\n   * This prop is used to control if the item is expanded or collapsed\n   */\n  toggle?: boolean\n  /**\n   * Set this to true if your current page is this item.\n   */\n  active?: boolean\n  /**\n   * If you want to remove pin button on your item use this prop\n   */\n  noPinButton?: boolean\n  /**\n   * You don't need to use this prop it's used internally to control the type of the item\n   */\n  type?: ItemType\n  /**\n   * You don't need to use this prop it's used internally to control if the item has a parent\n   */\n  hasParents?: boolean\n  /**\n   * You don't need to use this prop it's used internally for pinned item to be reorganized with drag and drop\n   */\n  index?: number\n  /**\n   * When the item has href it becomes a link if not it is a button.\n   * When using an external routing tool you might need to remove both of them and use\n   * a non focusable element. This option allows you to choose the tag of the\n   * item.\n   */\n  as?: keyof JSX.IntrinsicElements\n  /**\n   * Use this prop if you want to remove the expand behavior when the item\n   * has sub items.\n   */\n  noExpand?: boolean\n  disabled?: boolean\n}\n\nexport const Item = ({\n  children,\n  categoryIcon,\n  categoryIconVariant,\n  label,\n  subLabel,\n  badgeText,\n  badgeSentiment,\n  href,\n  onClick,\n  onPinUnpinClick,\n  toggle,\n  active,\n  noPinButton,\n  type = 'default',\n  hasParents,\n  as,\n  disabled,\n  noExpand = false,\n  index,\n  id,\n}: ItemProps) => {\n  const context = useNavigation()\n\n  if (!context) {\n    throw new Error(\n      'Navigation.Item can only be used inside a NavigationProvider.',\n    )\n  }\n\n  const {\n    expanded,\n    locales,\n    pinnedFeature,\n    pinItem,\n    unpinItem,\n    pinnedItems,\n    pinLimit,\n    animation,\n    registerItem,\n  } = context\n\n  useEffect(\n    () => {\n      if (type !== 'pinnedGroup') {\n        registerItem({ [id]: { label, active, onClick } })\n      }\n    },\n    // eslint-disable-next-line react-hooks/exhaustive-deps\n    [active, id, label, registerItem],\n  )\n\n  const [internalToggle, setToggle] = useState(toggle !== false)\n\n  const triggerToggle = useCallback(\n    (value: boolean) => {\n      setToggle(value)\n      onClick?.(internalToggle)\n    },\n    [internalToggle, onClick],\n  )\n\n  useEffect(() => {\n    if (animation === 'collapse') {\n      setToggle(false)\n    }\n\n    if (animation === 'expand') {\n      setTimeout(() => {\n        setToggle(toggle ?? true)\n      }, 1)\n    }\n  }, [animation, toggle])\n\n  const PaddedStack = noExpand || type === 'pinnedGroup' ? Stack : PaddingStack\n\n  const hasHrefAndNoChildren = href && !children\n  const hasPinnedFeatureAndNoChildren =\n    pinnedFeature && !children && !noPinButton\n  const isItemPinned = pinnedItems.includes(id)\n  const shouldShowPinnedButton = useMemo(() => {\n    if (href || disabled) return false\n\n    if (hasPinnedFeatureAndNoChildren && type !== 'default') {\n      return true\n    }\n\n    if (hasPinnedFeatureAndNoChildren) {\n      return true\n    }\n\n    return false\n  }, [disabled, hasPinnedFeatureAndNoChildren, href, type])\n\n  const hasActiveChildren = useMemo(() => {\n    if (!children) return false\n\n    return (\n      Children.map(children, child =>\n        isValidElement<ItemProps>(child) ? child.props?.active : false,\n      ) as boolean[]\n    ).includes(true)\n  }, [children])\n\n  const containerTag = useMemo(() => {\n    if (as) {\n      return as\n    }\n\n    if (hasHrefAndNoChildren) {\n      return 'a'\n    }\n\n    if (noExpand) {\n      return 'div'\n    }\n\n    return 'button'\n  }, [as, hasHrefAndNoChildren, noExpand])\n\n  const Container = StyledContainer.withComponent(containerTag)\n\n  const ariaExpanded = useMemo(() => {\n    if (hasHrefAndNoChildren && internalToggle) {\n      return true\n    }\n\n    if (hasHrefAndNoChildren && !internalToggle) {\n      return false\n    }\n\n    return undefined\n  }, [hasHrefAndNoChildren, internalToggle])\n\n  const isPinDisabled = pinnedItems.length >= pinLimit\n  const pinTooltipLocale = useMemo(() => {\n    if (isPinDisabled) {\n      return locales['navigation.pin.limit']\n    }\n\n    if (isItemPinned) {\n      return locales['navigation.unpin.tooltip']\n    }\n\n    return locales['navigation.pin.tooltip']\n  }, [isItemPinned, isPinDisabled, locales])\n\n  const onDragStartTrigger = (event: DragEvent<HTMLDivElement>) => {\n    event.dataTransfer.setData('text/plain', JSON.stringify({ label, index }))\n    // eslint-disable-next-line no-param-reassign\n    event.currentTarget.style.opacity = '0.5'\n  }\n\n  const onDragStopTrigger = (event: DragEvent<HTMLDivElement>) => {\n    // eslint-disable-next-line no-param-reassign\n    event.currentTarget.style.opacity = '1'\n  }\n\n  // This content is when the navigation is expanded\n  if (expanded || (!expanded && animation === 'expand')) {\n    const renderChildren = Children.map(children, child =>\n      isValidElement<ItemProps>(child)\n        ? cloneElement(child, {\n            hasParents: true,\n          })\n        : child,\n    )\n\n    return (\n      <>\n        <Container\n          gap={1}\n          direction=\"row\"\n          alignItems=\"center\"\n          justifyContent=\"space-between\"\n          data-has-sub-label={!!subLabel}\n          onClick={() => {\n            if (children) {\n              return triggerToggle(!internalToggle)\n            }\n\n            return onClick?.()\n          }}\n          aria-expanded={ariaExpanded}\n          href={href}\n          target={href ? '_blank' : undefined}\n          data-is-pinnable={shouldShowPinnedButton}\n          data-is-active={active}\n          data-animation={animation}\n          data-has-children={!!children}\n          data-has-active-children={hasActiveChildren}\n          data-has-no-expand={noExpand}\n          disabled={disabled}\n          draggable={type === 'pinned' && expanded}\n          onDragStart={(event: DragEvent<HTMLDivElement>) =>\n            expanded ? onDragStartTrigger(event) : undefined\n          }\n          onDragEnd={(event: DragEvent<HTMLDivElement>) =>\n            expanded ? onDragStopTrigger(event) : undefined\n          }\n          id={id}\n        >\n          <Stack\n            direction=\"row\"\n            gap={1}\n            alignItems=\"center\"\n            justifyContent=\"center\"\n          >\n            {categoryIcon ? (\n              <ContainerCategoryIcon\n                alignItems=\"center\"\n                justifyContent=\"center\"\n              >\n                <CategoryIcon\n                  name={categoryIcon}\n                  variant={active ? 'primary' : categoryIconVariant}\n                  disabled={disabled}\n                />\n              </ContainerCategoryIcon>\n            ) : null}\n            {type === 'pinned' && expanded ? (\n              <GrabIcon\n                name=\"drag-vertical\"\n                sentiment=\"neutral\"\n                prominence=\"weak\"\n                size=\"small\"\n                disabled={disabled}\n              />\n            ) : null}\n            <Stack>\n              <WrapText\n                as=\"span\"\n                variant=\"bodySmallStrong\"\n                sentiment={active ? 'primary' : 'neutral'}\n                prominence={\n                  (categoryIcon || !hasParents) && !active\n                    ? 'strong'\n                    : 'default'\n                }\n                animation={animation}\n                disabled={disabled}\n              >\n                {label}\n              </WrapText>\n              {subLabel ? (\n                <WrapText\n                  as=\"span\"\n                  variant=\"caption\"\n                  sentiment=\"neutral\"\n                  prominence=\"weak\"\n                  animation={animation}\n                  disabled={disabled}\n                  subLabel\n                >\n                  {subLabel}\n                </WrapText>\n              ) : null}\n            </Stack>\n          </Stack>\n          <Stack direction=\"row\" alignItems=\"center\" gap={href ? 1 : undefined}>\n            {badgeText || hasPinnedFeatureAndNoChildren ? (\n              <>\n                {badgeText ? (\n                  <StyledBadge\n                    sentiment={badgeSentiment}\n                    size=\"small\"\n                    prominence=\"strong\"\n                    disabled={disabled}\n                  >\n                    {badgeText}\n                  </StyledBadge>\n                ) : null}\n                {shouldShowPinnedButton ? (\n                  <Tooltip\n                    text={\n                      isItemPinned\n                        ? locales['navigation.unpin.tooltip']\n                        : pinTooltipLocale\n                    }\n                    placement=\"right\"\n                  >\n                    <RelativeDiv>\n                      <PinnedButton\n                        role=\"button\"\n                        size=\"xsmall\"\n                        variant=\"ghost\"\n                        sentiment={active ? 'primary' : 'neutral'}\n                        onClick={(event: MouseEvent<HTMLDivElement>) => {\n                          event.preventDefault()\n                          event.stopPropagation() // This is to avoid click spread to the parent and change the routing\n                          if (isItemPinned) {\n                            unpinItem(id)\n                          } else {\n                            pinItem(id)\n                          }\n                          onPinUnpinClick?.(event)\n                        }}\n                        disabled={isItemPinned ? false : isPinDisabled}\n                      >\n                        <StyledIcon\n                          size=\"large\"\n                          name={isItemPinned ? 'unpin' : 'pin'}\n                          variant={isItemPinned ? 'filled' : 'outlined'}\n                          disabled={isItemPinned ? false : isPinDisabled}\n                          sentiment={active ? 'primary' : 'neutral'}\n                          active={active}\n                        />\n                      </PinnedButton>\n                    </RelativeDiv>\n                  </Tooltip>\n                ) : null}\n              </>\n            ) : null}\n            {hasHrefAndNoChildren ? (\n              <AnimatedIcon\n                name=\"open-in-new\"\n                sentiment=\"neutral\"\n                prominence=\"default\"\n                disabled={disabled}\n              />\n            ) : null}\n            {children ? (\n              <Stack gap={1} direction=\"row\" alignItems=\"center\">\n                {!animation && !noExpand ? (\n                  <AnimatedIcon\n                    name={internalToggle ? 'arrow-down' : 'arrow-right'}\n                    sentiment=\"neutral\"\n                    prominence=\"weak\"\n                  />\n                ) : null}\n              </Stack>\n            ) : null}\n          </Stack>\n        </Container>\n        {children ? (\n          <>\n            {!noExpand ? (\n              <Expandable\n                opened={internalToggle}\n                animationDuration={\n                  animation ? ANIMATION_DURATION / 2 : undefined\n                }\n              >\n                <PaddedStack>{renderChildren}</PaddedStack>\n              </Expandable>\n            ) : (\n              <PaddedStack>{renderChildren}</PaddedStack>\n            )}\n          </>\n        ) : null}\n      </>\n    )\n  }\n\n  // This content is the menu of the navigation when collapsed\n  if (categoryIcon || (Children.count(children) > 0 && !hasParents)) {\n    return (\n      <MenuStack gap={1} alignItems=\"start\" justifyContent=\"start\">\n        {Children.count(children) > 0 ? (\n          <StyledMenu\n            triggerMethod=\"hover\"\n            dynamicDomRendering={false} // As we parse the children we don't need dynamic rendering\n            disclosure={\n              <Button\n                sentiment=\"neutral\"\n                variant={hasActiveChildren ? 'filled' : 'ghost'}\n                size=\"small\"\n                icon={!categoryIcon ? 'dots-horizontal' : undefined}\n              >\n                {categoryIcon ? (\n                  <Stack\n                    direction=\"row\"\n                    gap={1}\n                    alignItems=\"center\"\n                    justifyContent=\"center\"\n                  >\n                    <CategoryIcon\n                      name={categoryIcon}\n                      variant={active ? 'primary' : categoryIconVariant}\n                    />\n                  </Stack>\n                ) : null}\n              </Button>\n            }\n            placement=\"right\"\n          >\n            {Children.map(children, child =>\n              isValidElement<ItemProps>(child)\n                ? cloneElement(child, {\n                    hasParents: true,\n                  })\n                : child,\n            )}\n          </StyledMenu>\n        ) : (\n          <Tooltip text={label} placement=\"right\" tabIndex={-1}>\n            <Button\n              sentiment=\"neutral\"\n              variant={active ? 'filled' : 'ghost'}\n              size=\"small\"\n              onClick={() => onClick?.()}\n            >\n              <Stack\n                direction=\"row\"\n                gap={1}\n                alignItems=\"center\"\n                justifyContent=\"center\"\n              >\n                <CategoryIcon\n                  name={categoryIcon ?? 'console'}\n                  variant={active ? 'primary' : categoryIconVariant}\n                />\n              </Stack>\n            </Button>\n          </Tooltip>\n        )}\n      </MenuStack>\n    )\n  }\n\n  // This content is what is inside a menu item the navigation is collapsed\n  if (hasParents) {\n    return (\n      <StyledMenuItem\n        href={href}\n        onClick={() => {\n          onClick?.()\n        }}\n        borderless\n        active={active}\n        disabled={disabled}\n        sentiment={active ? 'primary' : 'neutral'}\n        isPinnable={shouldShowPinnedButton}\n      >\n        <Stack\n          gap={1}\n          direction=\"row\"\n          alignItems=\"center\"\n          justifyContent=\"space-between\"\n          flex={1}\n          width=\"100%\"\n        >\n          <WrapText as=\"span\" variant=\"bodySmall\">\n            {label}\n          </WrapText>\n          <Stack direction=\"row\">\n            {badgeText ? (\n              <StyledBadge\n                sentiment={badgeSentiment}\n                size=\"small\"\n                prominence=\"strong\"\n                disabled={disabled}\n              >\n                {badgeText}\n              </StyledBadge>\n            ) : null}\n            {hasHrefAndNoChildren ? (\n              <AnimatedIcon\n                name=\"open-in-new\"\n                sentiment=\"neutral\"\n                prominence=\"weak\"\n                disabled={disabled}\n              />\n            ) : null}\n            {shouldShowPinnedButton ? (\n              <Tooltip\n                text={\n                  isItemPinned\n                    ? locales['navigation.unpin.tooltip']\n                    : pinTooltipLocale\n                }\n                placement=\"right\"\n              >\n                <RelativeDiv>\n                  <PinnedButton\n                    role=\"button\"\n                    size=\"xsmall\"\n                    variant=\"ghost\"\n                    sentiment={active ? 'primary' : 'neutral'}\n                    onClick={(event: MouseEvent<HTMLDivElement>) => {\n                      event.preventDefault()\n                      event.stopPropagation() // This is to avoid click spread to the parent and change the routing\n                      if (isItemPinned) {\n                        unpinItem(id)\n                      } else {\n                        pinItem(id)\n                      }\n                      onPinUnpinClick?.(event)\n                    }}\n                    disabled={isItemPinned ? false : isPinDisabled}\n                  >\n                    <StyledIcon\n                      size=\"large\"\n                      name={isItemPinned ? 'unpin' : 'pin'}\n                      variant={isItemPinned ? 'filled' : 'outlined'}\n                      disabled={isItemPinned ? false : isPinDisabled}\n                      sentiment={active ? 'primary' : 'neutral'}\n                      active={active}\n                    />\n                  </PinnedButton>\n                </RelativeDiv>\n              </Tooltip>\n            ) : null}\n          </Stack>\n        </Stack>\n      </StyledMenuItem>\n    )\n  }\n\n  // This content is for when navigation is collapsed and we show an icon of link\n  if (!hasParents && href) {\n    return (\n      <Tooltip text={label} placement=\"right\">\n        <MenuStack gap={1} alignItems=\"start\" justifyContent=\"start\">\n          <Container\n            gap={1}\n            alignItems=\"center\"\n            justifyContent=\"center\"\n            href={href}\n            target=\"_blank\"\n          >\n            <AnimatedIcon\n              name=\"open-in-new\"\n              sentiment=\"neutral\"\n              prominence=\"weak\"\n            />\n          </Container>\n        </MenuStack>\n      </Tooltip>\n    )\n  }\n\n  return null\n}\n"]} */"));
79
+ const StyledBadge = /* @__PURE__ */ _styled(Badge, process.env.NODE_ENV === "production" ? {
80
+ target: "e134hokc9"
81
+ } : {
82
+ target: "e134hokc9",
83
+ label: "StyledBadge"
84
+ })(process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["/home/runner/work/ultraviolet/ultraviolet/packages/plus/src/components/Navigation/components/Item.tsx"],"names":[],"mappings":"AAsFiC","file":"/home/runner/work/ultraviolet/ultraviolet/packages/plus/src/components/Navigation/components/Item.tsx","sourcesContent":["import { css } from '@emotion/react'\nimport styled from '@emotion/styled'\nimport { CategoryIcon, Icon } from '@ultraviolet/icons'\nimport {\n  Badge,\n  Button,\n  Expandable,\n  MenuV2,\n  Stack,\n  Text,\n  Tooltip,\n  fadeIn,\n} from '@ultraviolet/ui'\nimport type {\n  ComponentProps,\n  DragEvent,\n  JSX,\n  MouseEvent,\n  ReactNode,\n} from 'react'\nimport {\n  Children,\n  cloneElement,\n  isValidElement,\n  useCallback,\n  useEffect,\n  useMemo,\n  useState,\n} from 'react'\nimport { useNavigation } from '../NavigationProvider'\nimport { ANIMATION_DURATION, shrinkHeight } from '../constants'\n\nconst RelativeDiv = styled.div`\n  position: relative;\n`\n\nconst StyledIcon = styled(Icon, {\n  shouldForwardProp: prop => !['active'].includes(prop),\n})<{ active?: boolean }>`\n  position: absolute;\n  top: 0;\n  bottom: 0;\n  margin: auto 0;\n  padding: ${({ theme }) => theme.space['0.25']};\n  border-radius: ${({ theme }) => theme.radii.default};\n  &:hover {\n    background: ${({ theme }) => theme.colors.neutral.backgroundWeakHover};\n\n    ${({ active, theme }) => (active ? `background: ${theme.colors.primary.backgroundHover};` : null)}\n    }\n  }\n`\n\nconst NeutralButtonLink = css`\n  color: inherit;\n  text-decoration: none;\n  background-color: inherit;\n  border: none;\n  text-align: left;\n`\n\n// Pin button when the navigation is expanded\nconst LocalExpandButton = styled(Button)`\n  opacity: 0;\n  right: 0;\n  position: absolute;\n  left: -24px;\n  top: 0;\n  bottom: 0;\n  margin: auto;\n\n  &:hover,\n  &:focus,\n  &:active {\n    opacity: 1;\n  }\n`\n\nconst PinnedButton = LocalExpandButton.withComponent('div')\n\nconst GrabIcon = styled(Icon)`\n  opacity: 0;\n  margin: 0 ${({ theme }) => theme.space['0.25']};\n  cursor: grab;\n`\n\nconst StyledBadge = styled(Badge)``\n\nconst StyledMenuItem = styled(MenuV2.Item, {\n  shouldForwardProp: prop => !['isPinnable'].includes(prop),\n})<{\n  isPinnable?: boolean\n}>`\n  text-align: left;\n\n  &:hover,\n  &:focus,\n  &:active {\n    ${PinnedButton} {\n      opacity: 1;\n    }\n\n    ${StyledBadge} {\n      opacity: ${({ isPinnable }) => (isPinnable ? 0 : 1)};\n    }\n  }\n`\n\nconst StyledMenu = styled(MenuV2)`\n  width: 180px;\n`\n\nconst PaddingStack = styled(Stack)`\n  padding-left: 28px; // This value needs to be hardcoded because of the category icon size\n`\n\nconst AnimatedIcon = styled(Icon)``\n\nconst WrapText = styled(Text, {\n  shouldForwardProp: prop =>\n    !['animation', 'subLabel', 'textProminence'].includes(prop),\n})<{\n  animation?: 'collapse' | 'expand' | boolean\n  subLabel?: boolean\n}>`\n  overflow-wrap: ${({ animation }) => (animation ? 'normal' : 'anywhere')};\n  white-space: ${({ animation }) => (animation ? 'nowrap' : 'normal')};\n  overflow: hidden;\n  display: -webkit-box;\n  -webkit-box-orient: vertical;\n  -webkit-line-clamp: 2;\n  white-space: pre-wrap;\n`\n\nconst StyledStack = styled(Stack)`\n  padding-left: 28px; // This value needs to be hardcoded because of the category icon size\n`\n\nconst StyledContainer = styled(Stack)`\n  ${NeutralButtonLink};\n  border-radius: ${({ theme }) => theme.radii.default};\n\n  &[data-has-no-expand='false'] {\n    cursor: pointer;\n  }\n  margin-top: ${({ theme }) => theme.space['0.25']};\n  padding: ${({ theme }) =>\n    `calc(${theme.space['0.25']} + ${theme.space['0.5']}) ${theme.space['1']}`};\n\n  &[data-has-sub-label='true'] {\n    padding: ${({ theme }) => `${theme.space['0.5']} ${theme.space['1']}`};\n  }\n\n  width: 100%;\n\n  &:hover[data-has-no-expand='false']:not([disabled]):not(\n      [data-is-active='true']\n    ),\n  &:focus[data-has-no-expand='false']:not([disabled]):not(\n      [data-is-active='true']\n    ) {\n    background-color: ${({ theme }) => theme.colors.neutral.backgroundWeak};\n  }\n  &[data-has-active-children='true'][data-has-no-expand='false']:not(\n      [disabled][data-is-active='true']\n    ) {\n    background-color: ${({ theme }) =>\n      theme.colors.neutral.backgroundWeakHover};\n    ${WrapText} {\n      color: ${({ theme }) => theme.colors.neutral.textWeakHover};\n    }\n\n    ${PinnedButton} {\n      opacity: 1;\n    }\n\n    &[data-is-pinnable='true'] {\n      ${StyledBadge} {\n        opacity: 0;\n      }\n    }\n  }\n\n  &[data-has-no-expand='false']:not([disabled]) {\n    &:hover,\n    &:focus,\n    &:active {\n      ${PinnedButton}, ${GrabIcon} {\n        opacity: 1;\n      }\n\n      ${StyledBadge} {\n        opacity: 0;\n      }\n    }\n  }\n\n  &:hover[data-has-children='false'][data-is-active='false']:not([disabled]) {\n    ${WrapText} {\n      color: ${({ theme }) => theme.colors.neutral.textWeakHover};\n    }\n  }\n\n  &:active[data-has-no-expand='false']:not([disabled]):not(\n      [data-is-active='true']\n    ) {\n    background-color: ${({ theme }) => theme.colors.neutral.backgroundHover};\n  }\n\n  &[data-is-active='true'],\n  &:hover[data-has-active='true'] {\n    background-color: ${({ theme }) => theme.colors.primary.background};\n\n    &:hover {\n      background-color: ${({ theme }) => theme.colors.primary.backgroundHover};\n    }\n  }\n\n  &[disabled] {\n    cursor: not-allowed;\n    background-color: unset;\n\n    ${WrapText} {\n      color: ${({ theme }) => theme.colors.neutral.textWeakDisabled};\n    }\n  }\n\n  &[data-animation='collapse'] {\n    animation: ${shrinkHeight} ${ANIMATION_DURATION}ms ease-in-out;\n    ${WrapText}, ${AnimatedIcon}, ${StyledBadge} {\n      animation: ${fadeIn} ${ANIMATION_DURATION}ms ease-in-out reverse;\n    }\n  }\n\n  &[data-animation='expand'] {\n    animation: ${shrinkHeight} ${ANIMATION_DURATION}ms ease-in-out reverse;\n    ${WrapText}, ${AnimatedIcon}, ${StyledBadge} {\n      animation: ${fadeIn} ${ANIMATION_DURATION}ms ease-in-out;\n    }\n\n    ${StyledStack} {\n      display: none;\n    }\n  }\n`\n\nconst MenuStack = styled(Stack)`\n  padding: ${({ theme }) => `0 ${theme.space['2']}`};\n  margin-top: ${({ theme }) => theme.space['0.25']};\n`\n\nconst ContainerCategoryIcon = styled(Stack)`\n  min-width: 20px;\n`\n\ntype ItemType = 'default' | 'pinned' | 'pinnedGroup'\n\ntype ItemProps = {\n  children?: ReactNode\n  /**\n   * Sets a category icon on the left of the item\n   */\n  categoryIcon?: ComponentProps<typeof CategoryIcon>['name']\n  categoryIconVariant?: ComponentProps<typeof CategoryIcon>['variant']\n  /**\n   * The label of the item that will be shown.\n   * It is also used as the key for pinning.\n   */\n  label: string\n  /**\n   * It should be a unique id and will be used for pin/unpin feature.\n   */\n  id: string\n  /**\n   * Text shown under the label with a lighter color and smaller font size\n   */\n  subLabel?: string\n  /**\n   * Badge is added on the right of the item. It is hidden on hover if pinned\n   * feature is enabled\n   */\n  badgeText?: string\n  /**\n   * Defined the sentiment of the badge according to Badge component from\n   * `@ultraviolet/ui`\n   */\n  badgeSentiment?: ComponentProps<typeof Badge>['sentiment']\n  href?: string\n  /**\n   * This function will be triggered on click of the item. If the item is expandable\n   * toggle will be passed with it.\n   */\n  onClick?: (toggle?: true | false) => void\n  onPinUnpinClick?: (event: MouseEvent<HTMLDivElement>) => void\n  /**\n   * This prop is used to control if the item is expanded or collapsed\n   */\n  toggle?: boolean\n  /**\n   * Set this to true if your current page is this item.\n   */\n  active?: boolean\n  /**\n   * If you want to remove pin button on your item use this prop\n   */\n  noPinButton?: boolean\n  /**\n   * You don't need to use this prop it's used internally to control the type of the item\n   */\n  type?: ItemType\n  /**\n   * You don't need to use this prop it's used internally to control if the item has a parent\n   */\n  hasParents?: boolean\n  /**\n   * You don't need to use this prop it's used internally for pinned item to be reorganized with drag and drop\n   */\n  index?: number\n  /**\n   * When the item has href it becomes a link if not it is a button.\n   * When using an external routing tool you might need to remove both of them and use\n   * a non focusable element. This option allows you to choose the tag of the\n   * item.\n   */\n  as?: keyof JSX.IntrinsicElements\n  /**\n   * Use this prop if you want to remove the expand behavior when the item\n   * has sub items.\n   */\n  noExpand?: boolean\n  disabled?: boolean\n}\n\nexport const Item = ({\n  children,\n  categoryIcon,\n  categoryIconVariant,\n  label,\n  subLabel,\n  badgeText,\n  badgeSentiment,\n  href,\n  onClick,\n  onPinUnpinClick,\n  toggle,\n  active,\n  noPinButton,\n  type = 'default',\n  hasParents,\n  as,\n  disabled,\n  noExpand = false,\n  index,\n  id,\n}: ItemProps) => {\n  const context = useNavigation()\n\n  if (!context) {\n    throw new Error(\n      'Navigation.Item can only be used inside a NavigationProvider.',\n    )\n  }\n\n  const {\n    expanded,\n    locales,\n    pinnedFeature,\n    pinItem,\n    unpinItem,\n    pinnedItems,\n    pinLimit,\n    animation,\n    registerItem,\n  } = context\n\n  useEffect(\n    () => {\n      if (type !== 'pinnedGroup') {\n        registerItem({ [id]: { label, active, onClick } })\n      }\n    },\n    // eslint-disable-next-line react-hooks/exhaustive-deps\n    [active, id, label, registerItem],\n  )\n\n  const [internalToggle, setToggle] = useState(toggle !== false)\n\n  const triggerToggle = useCallback(\n    (value: boolean) => {\n      setToggle(value)\n      onClick?.(internalToggle)\n    },\n    [internalToggle, onClick],\n  )\n\n  useEffect(() => {\n    if (animation === 'collapse') {\n      setToggle(false)\n    }\n\n    if (animation === 'expand') {\n      setTimeout(() => {\n        setToggle(toggle ?? true)\n      }, 1)\n    }\n  }, [animation, toggle])\n\n  const PaddedStack = noExpand || type === 'pinnedGroup' ? Stack : PaddingStack\n\n  const hasHrefAndNoChildren = href && !children\n  const hasPinnedFeatureAndNoChildren =\n    pinnedFeature && !children && !noPinButton\n  const isItemPinned = pinnedItems.includes(id)\n  const shouldShowPinnedButton = useMemo(() => {\n    if (href || disabled) return false\n\n    if (hasPinnedFeatureAndNoChildren && type !== 'default') {\n      return true\n    }\n\n    if (hasPinnedFeatureAndNoChildren) {\n      return true\n    }\n\n    return false\n  }, [disabled, hasPinnedFeatureAndNoChildren, href, type])\n\n  const hasActiveChildren = useMemo(() => {\n    if (!children) return false\n\n    return (\n      Children.map(children, child =>\n        isValidElement<ItemProps>(child) ? child.props?.active : false,\n      ) as boolean[]\n    ).includes(true)\n  }, [children])\n\n  const containerTag = useMemo(() => {\n    if (as) {\n      return as\n    }\n\n    if (hasHrefAndNoChildren) {\n      return 'a'\n    }\n\n    if (noExpand) {\n      return 'div'\n    }\n\n    return 'button'\n  }, [as, hasHrefAndNoChildren, noExpand])\n\n  const Container = StyledContainer.withComponent(containerTag)\n\n  const ariaExpanded = useMemo(() => {\n    if (hasHrefAndNoChildren && internalToggle) {\n      return true\n    }\n\n    if (hasHrefAndNoChildren && !internalToggle) {\n      return false\n    }\n\n    return undefined\n  }, [hasHrefAndNoChildren, internalToggle])\n\n  const isPinDisabled = pinnedItems.length >= pinLimit\n  const pinTooltipLocale = useMemo(() => {\n    if (isPinDisabled) {\n      return locales['navigation.pin.limit']\n    }\n\n    if (isItemPinned) {\n      return locales['navigation.unpin.tooltip']\n    }\n\n    return locales['navigation.pin.tooltip']\n  }, [isItemPinned, isPinDisabled, locales])\n\n  const onDragStartTrigger = (event: DragEvent<HTMLDivElement>) => {\n    event.dataTransfer.setData('text/plain', JSON.stringify({ label, index }))\n    // eslint-disable-next-line no-param-reassign\n    event.currentTarget.style.opacity = '0.5'\n  }\n\n  const onDragStopTrigger = (event: DragEvent<HTMLDivElement>) => {\n    // eslint-disable-next-line no-param-reassign\n    event.currentTarget.style.opacity = '1'\n  }\n\n  // This content is when the navigation is expanded\n  if (expanded || (!expanded && animation === 'expand')) {\n    const renderChildren = Children.map(children, child =>\n      isValidElement<ItemProps>(child)\n        ? cloneElement(child, {\n            hasParents: true,\n          })\n        : child,\n    )\n\n    return (\n      <>\n        <Container\n          gap={1}\n          direction=\"row\"\n          alignItems=\"center\"\n          justifyContent=\"space-between\"\n          data-has-sub-label={!!subLabel}\n          onClick={() => {\n            if (children) {\n              return triggerToggle(!internalToggle)\n            }\n\n            return onClick?.()\n          }}\n          aria-expanded={ariaExpanded}\n          href={href}\n          target={href ? '_blank' : undefined}\n          data-is-pinnable={shouldShowPinnedButton}\n          data-is-active={active}\n          data-animation={animation}\n          data-has-children={!!children}\n          data-has-active-children={hasActiveChildren}\n          data-has-no-expand={noExpand}\n          disabled={disabled}\n          draggable={type === 'pinned' && expanded}\n          onDragStart={(event: DragEvent<HTMLDivElement>) =>\n            expanded ? onDragStartTrigger(event) : undefined\n          }\n          onDragEnd={(event: DragEvent<HTMLDivElement>) =>\n            expanded ? onDragStopTrigger(event) : undefined\n          }\n          id={id}\n        >\n          <Stack\n            direction=\"row\"\n            gap={1}\n            alignItems=\"center\"\n            justifyContent=\"center\"\n          >\n            {categoryIcon ? (\n              <ContainerCategoryIcon\n                alignItems=\"center\"\n                justifyContent=\"center\"\n              >\n                <CategoryIcon\n                  name={categoryIcon}\n                  variant={active ? 'primary' : categoryIconVariant}\n                  disabled={disabled}\n                />\n              </ContainerCategoryIcon>\n            ) : null}\n            {type === 'pinned' && expanded ? (\n              <GrabIcon\n                name=\"drag-vertical\"\n                sentiment=\"neutral\"\n                prominence=\"weak\"\n                size=\"small\"\n                disabled={disabled}\n              />\n            ) : null}\n            <Stack>\n              <WrapText\n                as=\"span\"\n                variant=\"bodySmallStrong\"\n                sentiment={active ? 'primary' : 'neutral'}\n                prominence={\n                  (categoryIcon || !hasParents) && !active\n                    ? 'strong'\n                    : 'default'\n                }\n                animation={animation}\n                disabled={disabled}\n              >\n                {label}\n              </WrapText>\n              {subLabel ? (\n                <WrapText\n                  as=\"span\"\n                  variant=\"caption\"\n                  sentiment=\"neutral\"\n                  prominence=\"weak\"\n                  animation={animation}\n                  disabled={disabled}\n                  subLabel\n                >\n                  {subLabel}\n                </WrapText>\n              ) : null}\n            </Stack>\n          </Stack>\n          <Stack direction=\"row\" alignItems=\"center\" gap={href ? 1 : undefined}>\n            {badgeText || hasPinnedFeatureAndNoChildren ? (\n              <>\n                {badgeText ? (\n                  <StyledBadge\n                    sentiment={badgeSentiment}\n                    size=\"small\"\n                    prominence=\"strong\"\n                    disabled={disabled}\n                  >\n                    {badgeText}\n                  </StyledBadge>\n                ) : null}\n                {shouldShowPinnedButton ? (\n                  <Tooltip\n                    text={\n                      isItemPinned\n                        ? locales['navigation.unpin.tooltip']\n                        : pinTooltipLocale\n                    }\n                    placement=\"right\"\n                  >\n                    <RelativeDiv>\n                      <PinnedButton\n                        role=\"button\"\n                        size=\"xsmall\"\n                        variant=\"ghost\"\n                        sentiment={active ? 'primary' : 'neutral'}\n                        onClick={(event: MouseEvent<HTMLDivElement>) => {\n                          event.preventDefault()\n                          event.stopPropagation() // This is to avoid click spread to the parent and change the routing\n                          if (isItemPinned) {\n                            unpinItem(id)\n                          } else {\n                            pinItem(id)\n                          }\n                          onPinUnpinClick?.(event)\n                        }}\n                        disabled={isItemPinned ? false : isPinDisabled}\n                      >\n                        <StyledIcon\n                          size=\"large\"\n                          name={isItemPinned ? 'unpin' : 'pin'}\n                          variant={isItemPinned ? 'filled' : 'outlined'}\n                          disabled={isItemPinned ? false : isPinDisabled}\n                          sentiment={active ? 'primary' : 'neutral'}\n                          active={active}\n                        />\n                      </PinnedButton>\n                    </RelativeDiv>\n                  </Tooltip>\n                ) : null}\n              </>\n            ) : null}\n            {hasHrefAndNoChildren ? (\n              <AnimatedIcon\n                name=\"open-in-new\"\n                sentiment=\"neutral\"\n                prominence=\"default\"\n                disabled={disabled}\n              />\n            ) : null}\n            {children ? (\n              <Stack gap={1} direction=\"row\" alignItems=\"center\">\n                {!animation && !noExpand ? (\n                  <AnimatedIcon\n                    name={internalToggle ? 'arrow-down' : 'arrow-right'}\n                    sentiment=\"neutral\"\n                    prominence=\"weak\"\n                  />\n                ) : null}\n              </Stack>\n            ) : null}\n          </Stack>\n        </Container>\n        {children ? (\n          <>\n            {!noExpand ? (\n              <Expandable\n                opened={internalToggle}\n                animationDuration={\n                  animation ? ANIMATION_DURATION / 2 : undefined\n                }\n              >\n                <PaddedStack>{renderChildren}</PaddedStack>\n              </Expandable>\n            ) : (\n              <PaddedStack>{renderChildren}</PaddedStack>\n            )}\n          </>\n        ) : null}\n      </>\n    )\n  }\n\n  // This content is the menu of the navigation when collapsed\n  if (categoryIcon || (Children.count(children) > 0 && !hasParents)) {\n    return (\n      <MenuStack gap={1} alignItems=\"start\" justifyContent=\"start\">\n        {Children.count(children) > 0 ? (\n          <StyledMenu\n            triggerMethod=\"hover\"\n            dynamicDomRendering={false} // As we parse the children we don't need dynamic rendering\n            disclosure={\n              <Button\n                sentiment=\"neutral\"\n                variant={hasActiveChildren ? 'filled' : 'ghost'}\n                size=\"small\"\n                icon={!categoryIcon ? 'dots-horizontal' : undefined}\n              >\n                {categoryIcon ? (\n                  <Stack\n                    direction=\"row\"\n                    gap={1}\n                    alignItems=\"center\"\n                    justifyContent=\"center\"\n                  >\n                    <CategoryIcon\n                      name={categoryIcon}\n                      variant={active ? 'primary' : categoryIconVariant}\n                    />\n                  </Stack>\n                ) : null}\n              </Button>\n            }\n            placement=\"right\"\n          >\n            {Children.map(children, child =>\n              isValidElement<ItemProps>(child)\n                ? cloneElement(child, {\n                    hasParents: true,\n                  })\n                : child,\n            )}\n          </StyledMenu>\n        ) : (\n          <Tooltip text={label} placement=\"right\" tabIndex={-1}>\n            <Button\n              sentiment=\"neutral\"\n              variant={active ? 'filled' : 'ghost'}\n              size=\"small\"\n              onClick={() => onClick?.()}\n            >\n              <Stack\n                direction=\"row\"\n                gap={1}\n                alignItems=\"center\"\n                justifyContent=\"center\"\n              >\n                <CategoryIcon\n                  name={categoryIcon ?? 'console'}\n                  variant={active ? 'primary' : categoryIconVariant}\n                />\n              </Stack>\n            </Button>\n          </Tooltip>\n        )}\n      </MenuStack>\n    )\n  }\n\n  // This content is what is inside a menu item the navigation is collapsed\n  if (hasParents) {\n    return (\n      <StyledMenuItem\n        href={href}\n        onClick={() => {\n          onClick?.()\n        }}\n        borderless\n        active={active}\n        disabled={disabled}\n        sentiment={active ? 'primary' : 'neutral'}\n        isPinnable={shouldShowPinnedButton}\n      >\n        <Stack\n          gap={1}\n          direction=\"row\"\n          alignItems=\"center\"\n          justifyContent=\"space-between\"\n          flex={1}\n          width=\"100%\"\n        >\n          <WrapText as=\"span\" variant=\"bodySmall\">\n            {label}\n          </WrapText>\n          <Stack direction=\"row\">\n            {badgeText ? (\n              <StyledBadge\n                sentiment={badgeSentiment}\n                size=\"small\"\n                prominence=\"strong\"\n                disabled={disabled}\n              >\n                {badgeText}\n              </StyledBadge>\n            ) : null}\n            {hasHrefAndNoChildren ? (\n              <AnimatedIcon\n                name=\"open-in-new\"\n                sentiment=\"neutral\"\n                prominence=\"weak\"\n                disabled={disabled}\n              />\n            ) : null}\n            {shouldShowPinnedButton ? (\n              <Tooltip\n                text={\n                  isItemPinned\n                    ? locales['navigation.unpin.tooltip']\n                    : pinTooltipLocale\n                }\n                placement=\"right\"\n              >\n                <RelativeDiv>\n                  <PinnedButton\n                    role=\"button\"\n                    size=\"xsmall\"\n                    variant=\"ghost\"\n                    sentiment={active ? 'primary' : 'neutral'}\n                    onClick={(event: MouseEvent<HTMLDivElement>) => {\n                      event.preventDefault()\n                      event.stopPropagation() // This is to avoid click spread to the parent and change the routing\n                      if (isItemPinned) {\n                        unpinItem(id)\n                      } else {\n                        pinItem(id)\n                      }\n                      onPinUnpinClick?.(event)\n                    }}\n                    disabled={isItemPinned ? false : isPinDisabled}\n                  >\n                    <StyledIcon\n                      size=\"large\"\n                      name={isItemPinned ? 'unpin' : 'pin'}\n                      variant={isItemPinned ? 'filled' : 'outlined'}\n                      disabled={isItemPinned ? false : isPinDisabled}\n                      sentiment={active ? 'primary' : 'neutral'}\n                      active={active}\n                    />\n                  </PinnedButton>\n                </RelativeDiv>\n              </Tooltip>\n            ) : null}\n          </Stack>\n        </Stack>\n      </StyledMenuItem>\n    )\n  }\n\n  // This content is for when navigation is collapsed and we show an icon of link\n  if (!hasParents && href) {\n    return (\n      <Tooltip text={label} placement=\"right\">\n        <MenuStack gap={1} alignItems=\"start\" justifyContent=\"start\">\n          <Container\n            gap={1}\n            alignItems=\"center\"\n            justifyContent=\"center\"\n            href={href}\n            target=\"_blank\"\n          >\n            <AnimatedIcon\n              name=\"open-in-new\"\n              sentiment=\"neutral\"\n              prominence=\"weak\"\n            />\n          </Container>\n        </MenuStack>\n      </Tooltip>\n    )\n  }\n\n  return null\n}\n"]} */");
85
+ const StyledMenuItem = /* @__PURE__ */ _styled(MenuV2.Item, process.env.NODE_ENV === "production" ? {
86
+ shouldForwardProp: (prop) => !["isPinnable"].includes(prop),
87
+ target: "e134hokc8"
88
+ } : {
89
+ shouldForwardProp: (prop) => !["isPinnable"].includes(prop),
90
+ target: "e134hokc8",
91
+ label: "StyledMenuItem"
92
+ })("text-align:left;&:hover,&:focus,&:active{", PinnedButton, "{opacity:1;}", StyledBadge, "{opacity:", ({
93
+ isPinnable
94
+ }) => isPinnable ? 0 : 1, ";}}" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["/home/runner/work/ultraviolet/ultraviolet/packages/plus/src/components/Navigation/components/Item.tsx"],"names":[],"mappings":"AA4FE","file":"/home/runner/work/ultraviolet/ultraviolet/packages/plus/src/components/Navigation/components/Item.tsx","sourcesContent":["import { css } from '@emotion/react'\nimport styled from '@emotion/styled'\nimport { CategoryIcon, Icon } from '@ultraviolet/icons'\nimport {\n  Badge,\n  Button,\n  Expandable,\n  MenuV2,\n  Stack,\n  Text,\n  Tooltip,\n  fadeIn,\n} from '@ultraviolet/ui'\nimport type {\n  ComponentProps,\n  DragEvent,\n  JSX,\n  MouseEvent,\n  ReactNode,\n} from 'react'\nimport {\n  Children,\n  cloneElement,\n  isValidElement,\n  useCallback,\n  useEffect,\n  useMemo,\n  useState,\n} from 'react'\nimport { useNavigation } from '../NavigationProvider'\nimport { ANIMATION_DURATION, shrinkHeight } from '../constants'\n\nconst RelativeDiv = styled.div`\n  position: relative;\n`\n\nconst StyledIcon = styled(Icon, {\n  shouldForwardProp: prop => !['active'].includes(prop),\n})<{ active?: boolean }>`\n  position: absolute;\n  top: 0;\n  bottom: 0;\n  margin: auto 0;\n  padding: ${({ theme }) => theme.space['0.25']};\n  border-radius: ${({ theme }) => theme.radii.default};\n  &:hover {\n    background: ${({ theme }) => theme.colors.neutral.backgroundWeakHover};\n\n    ${({ active, theme }) => (active ? `background: ${theme.colors.primary.backgroundHover};` : null)}\n    }\n  }\n`\n\nconst NeutralButtonLink = css`\n  color: inherit;\n  text-decoration: none;\n  background-color: inherit;\n  border: none;\n  text-align: left;\n`\n\n// Pin button when the navigation is expanded\nconst LocalExpandButton = styled(Button)`\n  opacity: 0;\n  right: 0;\n  position: absolute;\n  left: -24px;\n  top: 0;\n  bottom: 0;\n  margin: auto;\n\n  &:hover,\n  &:focus,\n  &:active {\n    opacity: 1;\n  }\n`\n\nconst PinnedButton = LocalExpandButton.withComponent('div')\n\nconst GrabIcon = styled(Icon)`\n  opacity: 0;\n  margin: 0 ${({ theme }) => theme.space['0.25']};\n  cursor: grab;\n`\n\nconst StyledBadge = styled(Badge)``\n\nconst StyledMenuItem = styled(MenuV2.Item, {\n  shouldForwardProp: prop => !['isPinnable'].includes(prop),\n})<{\n  isPinnable?: boolean\n}>`\n  text-align: left;\n\n  &:hover,\n  &:focus,\n  &:active {\n    ${PinnedButton} {\n      opacity: 1;\n    }\n\n    ${StyledBadge} {\n      opacity: ${({ isPinnable }) => (isPinnable ? 0 : 1)};\n    }\n  }\n`\n\nconst StyledMenu = styled(MenuV2)`\n  width: 180px;\n`\n\nconst PaddingStack = styled(Stack)`\n  padding-left: 28px; // This value needs to be hardcoded because of the category icon size\n`\n\nconst AnimatedIcon = styled(Icon)``\n\nconst WrapText = styled(Text, {\n  shouldForwardProp: prop =>\n    !['animation', 'subLabel', 'textProminence'].includes(prop),\n})<{\n  animation?: 'collapse' | 'expand' | boolean\n  subLabel?: boolean\n}>`\n  overflow-wrap: ${({ animation }) => (animation ? 'normal' : 'anywhere')};\n  white-space: ${({ animation }) => (animation ? 'nowrap' : 'normal')};\n  overflow: hidden;\n  display: -webkit-box;\n  -webkit-box-orient: vertical;\n  -webkit-line-clamp: 2;\n  white-space: pre-wrap;\n`\n\nconst StyledStack = styled(Stack)`\n  padding-left: 28px; // This value needs to be hardcoded because of the category icon size\n`\n\nconst StyledContainer = styled(Stack)`\n  ${NeutralButtonLink};\n  border-radius: ${({ theme }) => theme.radii.default};\n\n  &[data-has-no-expand='false'] {\n    cursor: pointer;\n  }\n  margin-top: ${({ theme }) => theme.space['0.25']};\n  padding: ${({ theme }) =>\n    `calc(${theme.space['0.25']} + ${theme.space['0.5']}) ${theme.space['1']}`};\n\n  &[data-has-sub-label='true'] {\n    padding: ${({ theme }) => `${theme.space['0.5']} ${theme.space['1']}`};\n  }\n\n  width: 100%;\n\n  &:hover[data-has-no-expand='false']:not([disabled]):not(\n      [data-is-active='true']\n    ),\n  &:focus[data-has-no-expand='false']:not([disabled]):not(\n      [data-is-active='true']\n    ) {\n    background-color: ${({ theme }) => theme.colors.neutral.backgroundWeak};\n  }\n  &[data-has-active-children='true'][data-has-no-expand='false']:not(\n      [disabled][data-is-active='true']\n    ) {\n    background-color: ${({ theme }) =>\n      theme.colors.neutral.backgroundWeakHover};\n    ${WrapText} {\n      color: ${({ theme }) => theme.colors.neutral.textWeakHover};\n    }\n\n    ${PinnedButton} {\n      opacity: 1;\n    }\n\n    &[data-is-pinnable='true'] {\n      ${StyledBadge} {\n        opacity: 0;\n      }\n    }\n  }\n\n  &[data-has-no-expand='false']:not([disabled]) {\n    &:hover,\n    &:focus,\n    &:active {\n      ${PinnedButton}, ${GrabIcon} {\n        opacity: 1;\n      }\n\n      ${StyledBadge} {\n        opacity: 0;\n      }\n    }\n  }\n\n  &:hover[data-has-children='false'][data-is-active='false']:not([disabled]) {\n    ${WrapText} {\n      color: ${({ theme }) => theme.colors.neutral.textWeakHover};\n    }\n  }\n\n  &:active[data-has-no-expand='false']:not([disabled]):not(\n      [data-is-active='true']\n    ) {\n    background-color: ${({ theme }) => theme.colors.neutral.backgroundHover};\n  }\n\n  &[data-is-active='true'],\n  &:hover[data-has-active='true'] {\n    background-color: ${({ theme }) => theme.colors.primary.background};\n\n    &:hover {\n      background-color: ${({ theme }) => theme.colors.primary.backgroundHover};\n    }\n  }\n\n  &[disabled] {\n    cursor: not-allowed;\n    background-color: unset;\n\n    ${WrapText} {\n      color: ${({ theme }) => theme.colors.neutral.textWeakDisabled};\n    }\n  }\n\n  &[data-animation='collapse'] {\n    animation: ${shrinkHeight} ${ANIMATION_DURATION}ms ease-in-out;\n    ${WrapText}, ${AnimatedIcon}, ${StyledBadge} {\n      animation: ${fadeIn} ${ANIMATION_DURATION}ms ease-in-out reverse;\n    }\n  }\n\n  &[data-animation='expand'] {\n    animation: ${shrinkHeight} ${ANIMATION_DURATION}ms ease-in-out reverse;\n    ${WrapText}, ${AnimatedIcon}, ${StyledBadge} {\n      animation: ${fadeIn} ${ANIMATION_DURATION}ms ease-in-out;\n    }\n\n    ${StyledStack} {\n      display: none;\n    }\n  }\n`\n\nconst MenuStack = styled(Stack)`\n  padding: ${({ theme }) => `0 ${theme.space['2']}`};\n  margin-top: ${({ theme }) => theme.space['0.25']};\n`\n\nconst ContainerCategoryIcon = styled(Stack)`\n  min-width: 20px;\n`\n\ntype ItemType = 'default' | 'pinned' | 'pinnedGroup'\n\ntype ItemProps = {\n  children?: ReactNode\n  /**\n   * Sets a category icon on the left of the item\n   */\n  categoryIcon?: ComponentProps<typeof CategoryIcon>['name']\n  categoryIconVariant?: ComponentProps<typeof CategoryIcon>['variant']\n  /**\n   * The label of the item that will be shown.\n   * It is also used as the key for pinning.\n   */\n  label: string\n  /**\n   * It should be a unique id and will be used for pin/unpin feature.\n   */\n  id: string\n  /**\n   * Text shown under the label with a lighter color and smaller font size\n   */\n  subLabel?: string\n  /**\n   * Badge is added on the right of the item. It is hidden on hover if pinned\n   * feature is enabled\n   */\n  badgeText?: string\n  /**\n   * Defined the sentiment of the badge according to Badge component from\n   * `@ultraviolet/ui`\n   */\n  badgeSentiment?: ComponentProps<typeof Badge>['sentiment']\n  href?: string\n  /**\n   * This function will be triggered on click of the item. If the item is expandable\n   * toggle will be passed with it.\n   */\n  onClick?: (toggle?: true | false) => void\n  onPinUnpinClick?: (event: MouseEvent<HTMLDivElement>) => void\n  /**\n   * This prop is used to control if the item is expanded or collapsed\n   */\n  toggle?: boolean\n  /**\n   * Set this to true if your current page is this item.\n   */\n  active?: boolean\n  /**\n   * If you want to remove pin button on your item use this prop\n   */\n  noPinButton?: boolean\n  /**\n   * You don't need to use this prop it's used internally to control the type of the item\n   */\n  type?: ItemType\n  /**\n   * You don't need to use this prop it's used internally to control if the item has a parent\n   */\n  hasParents?: boolean\n  /**\n   * You don't need to use this prop it's used internally for pinned item to be reorganized with drag and drop\n   */\n  index?: number\n  /**\n   * When the item has href it becomes a link if not it is a button.\n   * When using an external routing tool you might need to remove both of them and use\n   * a non focusable element. This option allows you to choose the tag of the\n   * item.\n   */\n  as?: keyof JSX.IntrinsicElements\n  /**\n   * Use this prop if you want to remove the expand behavior when the item\n   * has sub items.\n   */\n  noExpand?: boolean\n  disabled?: boolean\n}\n\nexport const Item = ({\n  children,\n  categoryIcon,\n  categoryIconVariant,\n  label,\n  subLabel,\n  badgeText,\n  badgeSentiment,\n  href,\n  onClick,\n  onPinUnpinClick,\n  toggle,\n  active,\n  noPinButton,\n  type = 'default',\n  hasParents,\n  as,\n  disabled,\n  noExpand = false,\n  index,\n  id,\n}: ItemProps) => {\n  const context = useNavigation()\n\n  if (!context) {\n    throw new Error(\n      'Navigation.Item can only be used inside a NavigationProvider.',\n    )\n  }\n\n  const {\n    expanded,\n    locales,\n    pinnedFeature,\n    pinItem,\n    unpinItem,\n    pinnedItems,\n    pinLimit,\n    animation,\n    registerItem,\n  } = context\n\n  useEffect(\n    () => {\n      if (type !== 'pinnedGroup') {\n        registerItem({ [id]: { label, active, onClick } })\n      }\n    },\n    // eslint-disable-next-line react-hooks/exhaustive-deps\n    [active, id, label, registerItem],\n  )\n\n  const [internalToggle, setToggle] = useState(toggle !== false)\n\n  const triggerToggle = useCallback(\n    (value: boolean) => {\n      setToggle(value)\n      onClick?.(internalToggle)\n    },\n    [internalToggle, onClick],\n  )\n\n  useEffect(() => {\n    if (animation === 'collapse') {\n      setToggle(false)\n    }\n\n    if (animation === 'expand') {\n      setTimeout(() => {\n        setToggle(toggle ?? true)\n      }, 1)\n    }\n  }, [animation, toggle])\n\n  const PaddedStack = noExpand || type === 'pinnedGroup' ? Stack : PaddingStack\n\n  const hasHrefAndNoChildren = href && !children\n  const hasPinnedFeatureAndNoChildren =\n    pinnedFeature && !children && !noPinButton\n  const isItemPinned = pinnedItems.includes(id)\n  const shouldShowPinnedButton = useMemo(() => {\n    if (href || disabled) return false\n\n    if (hasPinnedFeatureAndNoChildren && type !== 'default') {\n      return true\n    }\n\n    if (hasPinnedFeatureAndNoChildren) {\n      return true\n    }\n\n    return false\n  }, [disabled, hasPinnedFeatureAndNoChildren, href, type])\n\n  const hasActiveChildren = useMemo(() => {\n    if (!children) return false\n\n    return (\n      Children.map(children, child =>\n        isValidElement<ItemProps>(child) ? child.props?.active : false,\n      ) as boolean[]\n    ).includes(true)\n  }, [children])\n\n  const containerTag = useMemo(() => {\n    if (as) {\n      return as\n    }\n\n    if (hasHrefAndNoChildren) {\n      return 'a'\n    }\n\n    if (noExpand) {\n      return 'div'\n    }\n\n    return 'button'\n  }, [as, hasHrefAndNoChildren, noExpand])\n\n  const Container = StyledContainer.withComponent(containerTag)\n\n  const ariaExpanded = useMemo(() => {\n    if (hasHrefAndNoChildren && internalToggle) {\n      return true\n    }\n\n    if (hasHrefAndNoChildren && !internalToggle) {\n      return false\n    }\n\n    return undefined\n  }, [hasHrefAndNoChildren, internalToggle])\n\n  const isPinDisabled = pinnedItems.length >= pinLimit\n  const pinTooltipLocale = useMemo(() => {\n    if (isPinDisabled) {\n      return locales['navigation.pin.limit']\n    }\n\n    if (isItemPinned) {\n      return locales['navigation.unpin.tooltip']\n    }\n\n    return locales['navigation.pin.tooltip']\n  }, [isItemPinned, isPinDisabled, locales])\n\n  const onDragStartTrigger = (event: DragEvent<HTMLDivElement>) => {\n    event.dataTransfer.setData('text/plain', JSON.stringify({ label, index }))\n    // eslint-disable-next-line no-param-reassign\n    event.currentTarget.style.opacity = '0.5'\n  }\n\n  const onDragStopTrigger = (event: DragEvent<HTMLDivElement>) => {\n    // eslint-disable-next-line no-param-reassign\n    event.currentTarget.style.opacity = '1'\n  }\n\n  // This content is when the navigation is expanded\n  if (expanded || (!expanded && animation === 'expand')) {\n    const renderChildren = Children.map(children, child =>\n      isValidElement<ItemProps>(child)\n        ? cloneElement(child, {\n            hasParents: true,\n          })\n        : child,\n    )\n\n    return (\n      <>\n        <Container\n          gap={1}\n          direction=\"row\"\n          alignItems=\"center\"\n          justifyContent=\"space-between\"\n          data-has-sub-label={!!subLabel}\n          onClick={() => {\n            if (children) {\n              return triggerToggle(!internalToggle)\n            }\n\n            return onClick?.()\n          }}\n          aria-expanded={ariaExpanded}\n          href={href}\n          target={href ? '_blank' : undefined}\n          data-is-pinnable={shouldShowPinnedButton}\n          data-is-active={active}\n          data-animation={animation}\n          data-has-children={!!children}\n          data-has-active-children={hasActiveChildren}\n          data-has-no-expand={noExpand}\n          disabled={disabled}\n          draggable={type === 'pinned' && expanded}\n          onDragStart={(event: DragEvent<HTMLDivElement>) =>\n            expanded ? onDragStartTrigger(event) : undefined\n          }\n          onDragEnd={(event: DragEvent<HTMLDivElement>) =>\n            expanded ? onDragStopTrigger(event) : undefined\n          }\n          id={id}\n        >\n          <Stack\n            direction=\"row\"\n            gap={1}\n            alignItems=\"center\"\n            justifyContent=\"center\"\n          >\n            {categoryIcon ? (\n              <ContainerCategoryIcon\n                alignItems=\"center\"\n                justifyContent=\"center\"\n              >\n                <CategoryIcon\n                  name={categoryIcon}\n                  variant={active ? 'primary' : categoryIconVariant}\n                  disabled={disabled}\n                />\n              </ContainerCategoryIcon>\n            ) : null}\n            {type === 'pinned' && expanded ? (\n              <GrabIcon\n                name=\"drag-vertical\"\n                sentiment=\"neutral\"\n                prominence=\"weak\"\n                size=\"small\"\n                disabled={disabled}\n              />\n            ) : null}\n            <Stack>\n              <WrapText\n                as=\"span\"\n                variant=\"bodySmallStrong\"\n                sentiment={active ? 'primary' : 'neutral'}\n                prominence={\n                  (categoryIcon || !hasParents) && !active\n                    ? 'strong'\n                    : 'default'\n                }\n                animation={animation}\n                disabled={disabled}\n              >\n                {label}\n              </WrapText>\n              {subLabel ? (\n                <WrapText\n                  as=\"span\"\n                  variant=\"caption\"\n                  sentiment=\"neutral\"\n                  prominence=\"weak\"\n                  animation={animation}\n                  disabled={disabled}\n                  subLabel\n                >\n                  {subLabel}\n                </WrapText>\n              ) : null}\n            </Stack>\n          </Stack>\n          <Stack direction=\"row\" alignItems=\"center\" gap={href ? 1 : undefined}>\n            {badgeText || hasPinnedFeatureAndNoChildren ? (\n              <>\n                {badgeText ? (\n                  <StyledBadge\n                    sentiment={badgeSentiment}\n                    size=\"small\"\n                    prominence=\"strong\"\n                    disabled={disabled}\n                  >\n                    {badgeText}\n                  </StyledBadge>\n                ) : null}\n                {shouldShowPinnedButton ? (\n                  <Tooltip\n                    text={\n                      isItemPinned\n                        ? locales['navigation.unpin.tooltip']\n                        : pinTooltipLocale\n                    }\n                    placement=\"right\"\n                  >\n                    <RelativeDiv>\n                      <PinnedButton\n                        role=\"button\"\n                        size=\"xsmall\"\n                        variant=\"ghost\"\n                        sentiment={active ? 'primary' : 'neutral'}\n                        onClick={(event: MouseEvent<HTMLDivElement>) => {\n                          event.preventDefault()\n                          event.stopPropagation() // This is to avoid click spread to the parent and change the routing\n                          if (isItemPinned) {\n                            unpinItem(id)\n                          } else {\n                            pinItem(id)\n                          }\n                          onPinUnpinClick?.(event)\n                        }}\n                        disabled={isItemPinned ? false : isPinDisabled}\n                      >\n                        <StyledIcon\n                          size=\"large\"\n                          name={isItemPinned ? 'unpin' : 'pin'}\n                          variant={isItemPinned ? 'filled' : 'outlined'}\n                          disabled={isItemPinned ? false : isPinDisabled}\n                          sentiment={active ? 'primary' : 'neutral'}\n                          active={active}\n                        />\n                      </PinnedButton>\n                    </RelativeDiv>\n                  </Tooltip>\n                ) : null}\n              </>\n            ) : null}\n            {hasHrefAndNoChildren ? (\n              <AnimatedIcon\n                name=\"open-in-new\"\n                sentiment=\"neutral\"\n                prominence=\"default\"\n                disabled={disabled}\n              />\n            ) : null}\n            {children ? (\n              <Stack gap={1} direction=\"row\" alignItems=\"center\">\n                {!animation && !noExpand ? (\n                  <AnimatedIcon\n                    name={internalToggle ? 'arrow-down' : 'arrow-right'}\n                    sentiment=\"neutral\"\n                    prominence=\"weak\"\n                  />\n                ) : null}\n              </Stack>\n            ) : null}\n          </Stack>\n        </Container>\n        {children ? (\n          <>\n            {!noExpand ? (\n              <Expandable\n                opened={internalToggle}\n                animationDuration={\n                  animation ? ANIMATION_DURATION / 2 : undefined\n                }\n              >\n                <PaddedStack>{renderChildren}</PaddedStack>\n              </Expandable>\n            ) : (\n              <PaddedStack>{renderChildren}</PaddedStack>\n            )}\n          </>\n        ) : null}\n      </>\n    )\n  }\n\n  // This content is the menu of the navigation when collapsed\n  if (categoryIcon || (Children.count(children) > 0 && !hasParents)) {\n    return (\n      <MenuStack gap={1} alignItems=\"start\" justifyContent=\"start\">\n        {Children.count(children) > 0 ? (\n          <StyledMenu\n            triggerMethod=\"hover\"\n            dynamicDomRendering={false} // As we parse the children we don't need dynamic rendering\n            disclosure={\n              <Button\n                sentiment=\"neutral\"\n                variant={hasActiveChildren ? 'filled' : 'ghost'}\n                size=\"small\"\n                icon={!categoryIcon ? 'dots-horizontal' : undefined}\n              >\n                {categoryIcon ? (\n                  <Stack\n                    direction=\"row\"\n                    gap={1}\n                    alignItems=\"center\"\n                    justifyContent=\"center\"\n                  >\n                    <CategoryIcon\n                      name={categoryIcon}\n                      variant={active ? 'primary' : categoryIconVariant}\n                    />\n                  </Stack>\n                ) : null}\n              </Button>\n            }\n            placement=\"right\"\n          >\n            {Children.map(children, child =>\n              isValidElement<ItemProps>(child)\n                ? cloneElement(child, {\n                    hasParents: true,\n                  })\n                : child,\n            )}\n          </StyledMenu>\n        ) : (\n          <Tooltip text={label} placement=\"right\" tabIndex={-1}>\n            <Button\n              sentiment=\"neutral\"\n              variant={active ? 'filled' : 'ghost'}\n              size=\"small\"\n              onClick={() => onClick?.()}\n            >\n              <Stack\n                direction=\"row\"\n                gap={1}\n                alignItems=\"center\"\n                justifyContent=\"center\"\n              >\n                <CategoryIcon\n                  name={categoryIcon ?? 'console'}\n                  variant={active ? 'primary' : categoryIconVariant}\n                />\n              </Stack>\n            </Button>\n          </Tooltip>\n        )}\n      </MenuStack>\n    )\n  }\n\n  // This content is what is inside a menu item the navigation is collapsed\n  if (hasParents) {\n    return (\n      <StyledMenuItem\n        href={href}\n        onClick={() => {\n          onClick?.()\n        }}\n        borderless\n        active={active}\n        disabled={disabled}\n        sentiment={active ? 'primary' : 'neutral'}\n        isPinnable={shouldShowPinnedButton}\n      >\n        <Stack\n          gap={1}\n          direction=\"row\"\n          alignItems=\"center\"\n          justifyContent=\"space-between\"\n          flex={1}\n          width=\"100%\"\n        >\n          <WrapText as=\"span\" variant=\"bodySmall\">\n            {label}\n          </WrapText>\n          <Stack direction=\"row\">\n            {badgeText ? (\n              <StyledBadge\n                sentiment={badgeSentiment}\n                size=\"small\"\n                prominence=\"strong\"\n                disabled={disabled}\n              >\n                {badgeText}\n              </StyledBadge>\n            ) : null}\n            {hasHrefAndNoChildren ? (\n              <AnimatedIcon\n                name=\"open-in-new\"\n                sentiment=\"neutral\"\n                prominence=\"weak\"\n                disabled={disabled}\n              />\n            ) : null}\n            {shouldShowPinnedButton ? (\n              <Tooltip\n                text={\n                  isItemPinned\n                    ? locales['navigation.unpin.tooltip']\n                    : pinTooltipLocale\n                }\n                placement=\"right\"\n              >\n                <RelativeDiv>\n                  <PinnedButton\n                    role=\"button\"\n                    size=\"xsmall\"\n                    variant=\"ghost\"\n                    sentiment={active ? 'primary' : 'neutral'}\n                    onClick={(event: MouseEvent<HTMLDivElement>) => {\n                      event.preventDefault()\n                      event.stopPropagation() // This is to avoid click spread to the parent and change the routing\n                      if (isItemPinned) {\n                        unpinItem(id)\n                      } else {\n                        pinItem(id)\n                      }\n                      onPinUnpinClick?.(event)\n                    }}\n                    disabled={isItemPinned ? false : isPinDisabled}\n                  >\n                    <StyledIcon\n                      size=\"large\"\n                      name={isItemPinned ? 'unpin' : 'pin'}\n                      variant={isItemPinned ? 'filled' : 'outlined'}\n                      disabled={isItemPinned ? false : isPinDisabled}\n                      sentiment={active ? 'primary' : 'neutral'}\n                      active={active}\n                    />\n                  </PinnedButton>\n                </RelativeDiv>\n              </Tooltip>\n            ) : null}\n          </Stack>\n        </Stack>\n      </StyledMenuItem>\n    )\n  }\n\n  // This content is for when navigation is collapsed and we show an icon of link\n  if (!hasParents && href) {\n    return (\n      <Tooltip text={label} placement=\"right\">\n        <MenuStack gap={1} alignItems=\"start\" justifyContent=\"start\">\n          <Container\n            gap={1}\n            alignItems=\"center\"\n            justifyContent=\"center\"\n            href={href}\n            target=\"_blank\"\n          >\n            <AnimatedIcon\n              name=\"open-in-new\"\n              sentiment=\"neutral\"\n              prominence=\"weak\"\n            />\n          </Container>\n        </MenuStack>\n      </Tooltip>\n    )\n  }\n\n  return null\n}\n"]} */"));
95
+ const StyledMenu = /* @__PURE__ */ _styled(MenuV2, process.env.NODE_ENV === "production" ? {
96
+ target: "e134hokc7"
97
+ } : {
98
+ target: "e134hokc7",
99
+ label: "StyledMenu"
100
+ })(process.env.NODE_ENV === "production" ? {
101
+ name: "educr3",
102
+ styles: "width:180px"
103
+ } : {
104
+ name: "educr3",
105
+ styles: "width:180px",
106
+ map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["/home/runner/work/ultraviolet/ultraviolet/packages/plus/src/components/Navigation/components/Item.tsx"],"names":[],"mappings":"AA4GiC","file":"/home/runner/work/ultraviolet/ultraviolet/packages/plus/src/components/Navigation/components/Item.tsx","sourcesContent":["import { css } from '@emotion/react'\nimport styled from '@emotion/styled'\nimport { CategoryIcon, Icon } from '@ultraviolet/icons'\nimport {\n  Badge,\n  Button,\n  Expandable,\n  MenuV2,\n  Stack,\n  Text,\n  Tooltip,\n  fadeIn,\n} from '@ultraviolet/ui'\nimport type {\n  ComponentProps,\n  DragEvent,\n  JSX,\n  MouseEvent,\n  ReactNode,\n} from 'react'\nimport {\n  Children,\n  cloneElement,\n  isValidElement,\n  useCallback,\n  useEffect,\n  useMemo,\n  useState,\n} from 'react'\nimport { useNavigation } from '../NavigationProvider'\nimport { ANIMATION_DURATION, shrinkHeight } from '../constants'\n\nconst RelativeDiv = styled.div`\n  position: relative;\n`\n\nconst StyledIcon = styled(Icon, {\n  shouldForwardProp: prop => !['active'].includes(prop),\n})<{ active?: boolean }>`\n  position: absolute;\n  top: 0;\n  bottom: 0;\n  margin: auto 0;\n  padding: ${({ theme }) => theme.space['0.25']};\n  border-radius: ${({ theme }) => theme.radii.default};\n  &:hover {\n    background: ${({ theme }) => theme.colors.neutral.backgroundWeakHover};\n\n    ${({ active, theme }) => (active ? `background: ${theme.colors.primary.backgroundHover};` : null)}\n    }\n  }\n`\n\nconst NeutralButtonLink = css`\n  color: inherit;\n  text-decoration: none;\n  background-color: inherit;\n  border: none;\n  text-align: left;\n`\n\n// Pin button when the navigation is expanded\nconst LocalExpandButton = styled(Button)`\n  opacity: 0;\n  right: 0;\n  position: absolute;\n  left: -24px;\n  top: 0;\n  bottom: 0;\n  margin: auto;\n\n  &:hover,\n  &:focus,\n  &:active {\n    opacity: 1;\n  }\n`\n\nconst PinnedButton = LocalExpandButton.withComponent('div')\n\nconst GrabIcon = styled(Icon)`\n  opacity: 0;\n  margin: 0 ${({ theme }) => theme.space['0.25']};\n  cursor: grab;\n`\n\nconst StyledBadge = styled(Badge)``\n\nconst StyledMenuItem = styled(MenuV2.Item, {\n  shouldForwardProp: prop => !['isPinnable'].includes(prop),\n})<{\n  isPinnable?: boolean\n}>`\n  text-align: left;\n\n  &:hover,\n  &:focus,\n  &:active {\n    ${PinnedButton} {\n      opacity: 1;\n    }\n\n    ${StyledBadge} {\n      opacity: ${({ isPinnable }) => (isPinnable ? 0 : 1)};\n    }\n  }\n`\n\nconst StyledMenu = styled(MenuV2)`\n  width: 180px;\n`\n\nconst PaddingStack = styled(Stack)`\n  padding-left: 28px; // This value needs to be hardcoded because of the category icon size\n`\n\nconst AnimatedIcon = styled(Icon)``\n\nconst WrapText = styled(Text, {\n  shouldForwardProp: prop =>\n    !['animation', 'subLabel', 'textProminence'].includes(prop),\n})<{\n  animation?: 'collapse' | 'expand' | boolean\n  subLabel?: boolean\n}>`\n  overflow-wrap: ${({ animation }) => (animation ? 'normal' : 'anywhere')};\n  white-space: ${({ animation }) => (animation ? 'nowrap' : 'normal')};\n  overflow: hidden;\n  display: -webkit-box;\n  -webkit-box-orient: vertical;\n  -webkit-line-clamp: 2;\n  white-space: pre-wrap;\n`\n\nconst StyledStack = styled(Stack)`\n  padding-left: 28px; // This value needs to be hardcoded because of the category icon size\n`\n\nconst StyledContainer = styled(Stack)`\n  ${NeutralButtonLink};\n  border-radius: ${({ theme }) => theme.radii.default};\n\n  &[data-has-no-expand='false'] {\n    cursor: pointer;\n  }\n  margin-top: ${({ theme }) => theme.space['0.25']};\n  padding: ${({ theme }) =>\n    `calc(${theme.space['0.25']} + ${theme.space['0.5']}) ${theme.space['1']}`};\n\n  &[data-has-sub-label='true'] {\n    padding: ${({ theme }) => `${theme.space['0.5']} ${theme.space['1']}`};\n  }\n\n  width: 100%;\n\n  &:hover[data-has-no-expand='false']:not([disabled]):not(\n      [data-is-active='true']\n    ),\n  &:focus[data-has-no-expand='false']:not([disabled]):not(\n      [data-is-active='true']\n    ) {\n    background-color: ${({ theme }) => theme.colors.neutral.backgroundWeak};\n  }\n  &[data-has-active-children='true'][data-has-no-expand='false']:not(\n      [disabled][data-is-active='true']\n    ) {\n    background-color: ${({ theme }) =>\n      theme.colors.neutral.backgroundWeakHover};\n    ${WrapText} {\n      color: ${({ theme }) => theme.colors.neutral.textWeakHover};\n    }\n\n    ${PinnedButton} {\n      opacity: 1;\n    }\n\n    &[data-is-pinnable='true'] {\n      ${StyledBadge} {\n        opacity: 0;\n      }\n    }\n  }\n\n  &[data-has-no-expand='false']:not([disabled]) {\n    &:hover,\n    &:focus,\n    &:active {\n      ${PinnedButton}, ${GrabIcon} {\n        opacity: 1;\n      }\n\n      ${StyledBadge} {\n        opacity: 0;\n      }\n    }\n  }\n\n  &:hover[data-has-children='false'][data-is-active='false']:not([disabled]) {\n    ${WrapText} {\n      color: ${({ theme }) => theme.colors.neutral.textWeakHover};\n    }\n  }\n\n  &:active[data-has-no-expand='false']:not([disabled]):not(\n      [data-is-active='true']\n    ) {\n    background-color: ${({ theme }) => theme.colors.neutral.backgroundHover};\n  }\n\n  &[data-is-active='true'],\n  &:hover[data-has-active='true'] {\n    background-color: ${({ theme }) => theme.colors.primary.background};\n\n    &:hover {\n      background-color: ${({ theme }) => theme.colors.primary.backgroundHover};\n    }\n  }\n\n  &[disabled] {\n    cursor: not-allowed;\n    background-color: unset;\n\n    ${WrapText} {\n      color: ${({ theme }) => theme.colors.neutral.textWeakDisabled};\n    }\n  }\n\n  &[data-animation='collapse'] {\n    animation: ${shrinkHeight} ${ANIMATION_DURATION}ms ease-in-out;\n    ${WrapText}, ${AnimatedIcon}, ${StyledBadge} {\n      animation: ${fadeIn} ${ANIMATION_DURATION}ms ease-in-out reverse;\n    }\n  }\n\n  &[data-animation='expand'] {\n    animation: ${shrinkHeight} ${ANIMATION_DURATION}ms ease-in-out reverse;\n    ${WrapText}, ${AnimatedIcon}, ${StyledBadge} {\n      animation: ${fadeIn} ${ANIMATION_DURATION}ms ease-in-out;\n    }\n\n    ${StyledStack} {\n      display: none;\n    }\n  }\n`\n\nconst MenuStack = styled(Stack)`\n  padding: ${({ theme }) => `0 ${theme.space['2']}`};\n  margin-top: ${({ theme }) => theme.space['0.25']};\n`\n\nconst ContainerCategoryIcon = styled(Stack)`\n  min-width: 20px;\n`\n\ntype ItemType = 'default' | 'pinned' | 'pinnedGroup'\n\ntype ItemProps = {\n  children?: ReactNode\n  /**\n   * Sets a category icon on the left of the item\n   */\n  categoryIcon?: ComponentProps<typeof CategoryIcon>['name']\n  categoryIconVariant?: ComponentProps<typeof CategoryIcon>['variant']\n  /**\n   * The label of the item that will be shown.\n   * It is also used as the key for pinning.\n   */\n  label: string\n  /**\n   * It should be a unique id and will be used for pin/unpin feature.\n   */\n  id: string\n  /**\n   * Text shown under the label with a lighter color and smaller font size\n   */\n  subLabel?: string\n  /**\n   * Badge is added on the right of the item. It is hidden on hover if pinned\n   * feature is enabled\n   */\n  badgeText?: string\n  /**\n   * Defined the sentiment of the badge according to Badge component from\n   * `@ultraviolet/ui`\n   */\n  badgeSentiment?: ComponentProps<typeof Badge>['sentiment']\n  href?: string\n  /**\n   * This function will be triggered on click of the item. If the item is expandable\n   * toggle will be passed with it.\n   */\n  onClick?: (toggle?: true | false) => void\n  onPinUnpinClick?: (event: MouseEvent<HTMLDivElement>) => void\n  /**\n   * This prop is used to control if the item is expanded or collapsed\n   */\n  toggle?: boolean\n  /**\n   * Set this to true if your current page is this item.\n   */\n  active?: boolean\n  /**\n   * If you want to remove pin button on your item use this prop\n   */\n  noPinButton?: boolean\n  /**\n   * You don't need to use this prop it's used internally to control the type of the item\n   */\n  type?: ItemType\n  /**\n   * You don't need to use this prop it's used internally to control if the item has a parent\n   */\n  hasParents?: boolean\n  /**\n   * You don't need to use this prop it's used internally for pinned item to be reorganized with drag and drop\n   */\n  index?: number\n  /**\n   * When the item has href it becomes a link if not it is a button.\n   * When using an external routing tool you might need to remove both of them and use\n   * a non focusable element. This option allows you to choose the tag of the\n   * item.\n   */\n  as?: keyof JSX.IntrinsicElements\n  /**\n   * Use this prop if you want to remove the expand behavior when the item\n   * has sub items.\n   */\n  noExpand?: boolean\n  disabled?: boolean\n}\n\nexport const Item = ({\n  children,\n  categoryIcon,\n  categoryIconVariant,\n  label,\n  subLabel,\n  badgeText,\n  badgeSentiment,\n  href,\n  onClick,\n  onPinUnpinClick,\n  toggle,\n  active,\n  noPinButton,\n  type = 'default',\n  hasParents,\n  as,\n  disabled,\n  noExpand = false,\n  index,\n  id,\n}: ItemProps) => {\n  const context = useNavigation()\n\n  if (!context) {\n    throw new Error(\n      'Navigation.Item can only be used inside a NavigationProvider.',\n    )\n  }\n\n  const {\n    expanded,\n    locales,\n    pinnedFeature,\n    pinItem,\n    unpinItem,\n    pinnedItems,\n    pinLimit,\n    animation,\n    registerItem,\n  } = context\n\n  useEffect(\n    () => {\n      if (type !== 'pinnedGroup') {\n        registerItem({ [id]: { label, active, onClick } })\n      }\n    },\n    // eslint-disable-next-line react-hooks/exhaustive-deps\n    [active, id, label, registerItem],\n  )\n\n  const [internalToggle, setToggle] = useState(toggle !== false)\n\n  const triggerToggle = useCallback(\n    (value: boolean) => {\n      setToggle(value)\n      onClick?.(internalToggle)\n    },\n    [internalToggle, onClick],\n  )\n\n  useEffect(() => {\n    if (animation === 'collapse') {\n      setToggle(false)\n    }\n\n    if (animation === 'expand') {\n      setTimeout(() => {\n        setToggle(toggle ?? true)\n      }, 1)\n    }\n  }, [animation, toggle])\n\n  const PaddedStack = noExpand || type === 'pinnedGroup' ? Stack : PaddingStack\n\n  const hasHrefAndNoChildren = href && !children\n  const hasPinnedFeatureAndNoChildren =\n    pinnedFeature && !children && !noPinButton\n  const isItemPinned = pinnedItems.includes(id)\n  const shouldShowPinnedButton = useMemo(() => {\n    if (href || disabled) return false\n\n    if (hasPinnedFeatureAndNoChildren && type !== 'default') {\n      return true\n    }\n\n    if (hasPinnedFeatureAndNoChildren) {\n      return true\n    }\n\n    return false\n  }, [disabled, hasPinnedFeatureAndNoChildren, href, type])\n\n  const hasActiveChildren = useMemo(() => {\n    if (!children) return false\n\n    return (\n      Children.map(children, child =>\n        isValidElement<ItemProps>(child) ? child.props?.active : false,\n      ) as boolean[]\n    ).includes(true)\n  }, [children])\n\n  const containerTag = useMemo(() => {\n    if (as) {\n      return as\n    }\n\n    if (hasHrefAndNoChildren) {\n      return 'a'\n    }\n\n    if (noExpand) {\n      return 'div'\n    }\n\n    return 'button'\n  }, [as, hasHrefAndNoChildren, noExpand])\n\n  const Container = StyledContainer.withComponent(containerTag)\n\n  const ariaExpanded = useMemo(() => {\n    if (hasHrefAndNoChildren && internalToggle) {\n      return true\n    }\n\n    if (hasHrefAndNoChildren && !internalToggle) {\n      return false\n    }\n\n    return undefined\n  }, [hasHrefAndNoChildren, internalToggle])\n\n  const isPinDisabled = pinnedItems.length >= pinLimit\n  const pinTooltipLocale = useMemo(() => {\n    if (isPinDisabled) {\n      return locales['navigation.pin.limit']\n    }\n\n    if (isItemPinned) {\n      return locales['navigation.unpin.tooltip']\n    }\n\n    return locales['navigation.pin.tooltip']\n  }, [isItemPinned, isPinDisabled, locales])\n\n  const onDragStartTrigger = (event: DragEvent<HTMLDivElement>) => {\n    event.dataTransfer.setData('text/plain', JSON.stringify({ label, index }))\n    // eslint-disable-next-line no-param-reassign\n    event.currentTarget.style.opacity = '0.5'\n  }\n\n  const onDragStopTrigger = (event: DragEvent<HTMLDivElement>) => {\n    // eslint-disable-next-line no-param-reassign\n    event.currentTarget.style.opacity = '1'\n  }\n\n  // This content is when the navigation is expanded\n  if (expanded || (!expanded && animation === 'expand')) {\n    const renderChildren = Children.map(children, child =>\n      isValidElement<ItemProps>(child)\n        ? cloneElement(child, {\n            hasParents: true,\n          })\n        : child,\n    )\n\n    return (\n      <>\n        <Container\n          gap={1}\n          direction=\"row\"\n          alignItems=\"center\"\n          justifyContent=\"space-between\"\n          data-has-sub-label={!!subLabel}\n          onClick={() => {\n            if (children) {\n              return triggerToggle(!internalToggle)\n            }\n\n            return onClick?.()\n          }}\n          aria-expanded={ariaExpanded}\n          href={href}\n          target={href ? '_blank' : undefined}\n          data-is-pinnable={shouldShowPinnedButton}\n          data-is-active={active}\n          data-animation={animation}\n          data-has-children={!!children}\n          data-has-active-children={hasActiveChildren}\n          data-has-no-expand={noExpand}\n          disabled={disabled}\n          draggable={type === 'pinned' && expanded}\n          onDragStart={(event: DragEvent<HTMLDivElement>) =>\n            expanded ? onDragStartTrigger(event) : undefined\n          }\n          onDragEnd={(event: DragEvent<HTMLDivElement>) =>\n            expanded ? onDragStopTrigger(event) : undefined\n          }\n          id={id}\n        >\n          <Stack\n            direction=\"row\"\n            gap={1}\n            alignItems=\"center\"\n            justifyContent=\"center\"\n          >\n            {categoryIcon ? (\n              <ContainerCategoryIcon\n                alignItems=\"center\"\n                justifyContent=\"center\"\n              >\n                <CategoryIcon\n                  name={categoryIcon}\n                  variant={active ? 'primary' : categoryIconVariant}\n                  disabled={disabled}\n                />\n              </ContainerCategoryIcon>\n            ) : null}\n            {type === 'pinned' && expanded ? (\n              <GrabIcon\n                name=\"drag-vertical\"\n                sentiment=\"neutral\"\n                prominence=\"weak\"\n                size=\"small\"\n                disabled={disabled}\n              />\n            ) : null}\n            <Stack>\n              <WrapText\n                as=\"span\"\n                variant=\"bodySmallStrong\"\n                sentiment={active ? 'primary' : 'neutral'}\n                prominence={\n                  (categoryIcon || !hasParents) && !active\n                    ? 'strong'\n                    : 'default'\n                }\n                animation={animation}\n                disabled={disabled}\n              >\n                {label}\n              </WrapText>\n              {subLabel ? (\n                <WrapText\n                  as=\"span\"\n                  variant=\"caption\"\n                  sentiment=\"neutral\"\n                  prominence=\"weak\"\n                  animation={animation}\n                  disabled={disabled}\n                  subLabel\n                >\n                  {subLabel}\n                </WrapText>\n              ) : null}\n            </Stack>\n          </Stack>\n          <Stack direction=\"row\" alignItems=\"center\" gap={href ? 1 : undefined}>\n            {badgeText || hasPinnedFeatureAndNoChildren ? (\n              <>\n                {badgeText ? (\n                  <StyledBadge\n                    sentiment={badgeSentiment}\n                    size=\"small\"\n                    prominence=\"strong\"\n                    disabled={disabled}\n                  >\n                    {badgeText}\n                  </StyledBadge>\n                ) : null}\n                {shouldShowPinnedButton ? (\n                  <Tooltip\n                    text={\n                      isItemPinned\n                        ? locales['navigation.unpin.tooltip']\n                        : pinTooltipLocale\n                    }\n                    placement=\"right\"\n                  >\n                    <RelativeDiv>\n                      <PinnedButton\n                        role=\"button\"\n                        size=\"xsmall\"\n                        variant=\"ghost\"\n                        sentiment={active ? 'primary' : 'neutral'}\n                        onClick={(event: MouseEvent<HTMLDivElement>) => {\n                          event.preventDefault()\n                          event.stopPropagation() // This is to avoid click spread to the parent and change the routing\n                          if (isItemPinned) {\n                            unpinItem(id)\n                          } else {\n                            pinItem(id)\n                          }\n                          onPinUnpinClick?.(event)\n                        }}\n                        disabled={isItemPinned ? false : isPinDisabled}\n                      >\n                        <StyledIcon\n                          size=\"large\"\n                          name={isItemPinned ? 'unpin' : 'pin'}\n                          variant={isItemPinned ? 'filled' : 'outlined'}\n                          disabled={isItemPinned ? false : isPinDisabled}\n                          sentiment={active ? 'primary' : 'neutral'}\n                          active={active}\n                        />\n                      </PinnedButton>\n                    </RelativeDiv>\n                  </Tooltip>\n                ) : null}\n              </>\n            ) : null}\n            {hasHrefAndNoChildren ? (\n              <AnimatedIcon\n                name=\"open-in-new\"\n                sentiment=\"neutral\"\n                prominence=\"default\"\n                disabled={disabled}\n              />\n            ) : null}\n            {children ? (\n              <Stack gap={1} direction=\"row\" alignItems=\"center\">\n                {!animation && !noExpand ? (\n                  <AnimatedIcon\n                    name={internalToggle ? 'arrow-down' : 'arrow-right'}\n                    sentiment=\"neutral\"\n                    prominence=\"weak\"\n                  />\n                ) : null}\n              </Stack>\n            ) : null}\n          </Stack>\n        </Container>\n        {children ? (\n          <>\n            {!noExpand ? (\n              <Expandable\n                opened={internalToggle}\n                animationDuration={\n                  animation ? ANIMATION_DURATION / 2 : undefined\n                }\n              >\n                <PaddedStack>{renderChildren}</PaddedStack>\n              </Expandable>\n            ) : (\n              <PaddedStack>{renderChildren}</PaddedStack>\n            )}\n          </>\n        ) : null}\n      </>\n    )\n  }\n\n  // This content is the menu of the navigation when collapsed\n  if (categoryIcon || (Children.count(children) > 0 && !hasParents)) {\n    return (\n      <MenuStack gap={1} alignItems=\"start\" justifyContent=\"start\">\n        {Children.count(children) > 0 ? (\n          <StyledMenu\n            triggerMethod=\"hover\"\n            dynamicDomRendering={false} // As we parse the children we don't need dynamic rendering\n            disclosure={\n              <Button\n                sentiment=\"neutral\"\n                variant={hasActiveChildren ? 'filled' : 'ghost'}\n                size=\"small\"\n                icon={!categoryIcon ? 'dots-horizontal' : undefined}\n              >\n                {categoryIcon ? (\n                  <Stack\n                    direction=\"row\"\n                    gap={1}\n                    alignItems=\"center\"\n                    justifyContent=\"center\"\n                  >\n                    <CategoryIcon\n                      name={categoryIcon}\n                      variant={active ? 'primary' : categoryIconVariant}\n                    />\n                  </Stack>\n                ) : null}\n              </Button>\n            }\n            placement=\"right\"\n          >\n            {Children.map(children, child =>\n              isValidElement<ItemProps>(child)\n                ? cloneElement(child, {\n                    hasParents: true,\n                  })\n                : child,\n            )}\n          </StyledMenu>\n        ) : (\n          <Tooltip text={label} placement=\"right\" tabIndex={-1}>\n            <Button\n              sentiment=\"neutral\"\n              variant={active ? 'filled' : 'ghost'}\n              size=\"small\"\n              onClick={() => onClick?.()}\n            >\n              <Stack\n                direction=\"row\"\n                gap={1}\n                alignItems=\"center\"\n                justifyContent=\"center\"\n              >\n                <CategoryIcon\n                  name={categoryIcon ?? 'console'}\n                  variant={active ? 'primary' : categoryIconVariant}\n                />\n              </Stack>\n            </Button>\n          </Tooltip>\n        )}\n      </MenuStack>\n    )\n  }\n\n  // This content is what is inside a menu item the navigation is collapsed\n  if (hasParents) {\n    return (\n      <StyledMenuItem\n        href={href}\n        onClick={() => {\n          onClick?.()\n        }}\n        borderless\n        active={active}\n        disabled={disabled}\n        sentiment={active ? 'primary' : 'neutral'}\n        isPinnable={shouldShowPinnedButton}\n      >\n        <Stack\n          gap={1}\n          direction=\"row\"\n          alignItems=\"center\"\n          justifyContent=\"space-between\"\n          flex={1}\n          width=\"100%\"\n        >\n          <WrapText as=\"span\" variant=\"bodySmall\">\n            {label}\n          </WrapText>\n          <Stack direction=\"row\">\n            {badgeText ? (\n              <StyledBadge\n                sentiment={badgeSentiment}\n                size=\"small\"\n                prominence=\"strong\"\n                disabled={disabled}\n              >\n                {badgeText}\n              </StyledBadge>\n            ) : null}\n            {hasHrefAndNoChildren ? (\n              <AnimatedIcon\n                name=\"open-in-new\"\n                sentiment=\"neutral\"\n                prominence=\"weak\"\n                disabled={disabled}\n              />\n            ) : null}\n            {shouldShowPinnedButton ? (\n              <Tooltip\n                text={\n                  isItemPinned\n                    ? locales['navigation.unpin.tooltip']\n                    : pinTooltipLocale\n                }\n                placement=\"right\"\n              >\n                <RelativeDiv>\n                  <PinnedButton\n                    role=\"button\"\n                    size=\"xsmall\"\n                    variant=\"ghost\"\n                    sentiment={active ? 'primary' : 'neutral'}\n                    onClick={(event: MouseEvent<HTMLDivElement>) => {\n                      event.preventDefault()\n                      event.stopPropagation() // This is to avoid click spread to the parent and change the routing\n                      if (isItemPinned) {\n                        unpinItem(id)\n                      } else {\n                        pinItem(id)\n                      }\n                      onPinUnpinClick?.(event)\n                    }}\n                    disabled={isItemPinned ? false : isPinDisabled}\n                  >\n                    <StyledIcon\n                      size=\"large\"\n                      name={isItemPinned ? 'unpin' : 'pin'}\n                      variant={isItemPinned ? 'filled' : 'outlined'}\n                      disabled={isItemPinned ? false : isPinDisabled}\n                      sentiment={active ? 'primary' : 'neutral'}\n                      active={active}\n                    />\n                  </PinnedButton>\n                </RelativeDiv>\n              </Tooltip>\n            ) : null}\n          </Stack>\n        </Stack>\n      </StyledMenuItem>\n    )\n  }\n\n  // This content is for when navigation is collapsed and we show an icon of link\n  if (!hasParents && href) {\n    return (\n      <Tooltip text={label} placement=\"right\">\n        <MenuStack gap={1} alignItems=\"start\" justifyContent=\"start\">\n          <Container\n            gap={1}\n            alignItems=\"center\"\n            justifyContent=\"center\"\n            href={href}\n            target=\"_blank\"\n          >\n            <AnimatedIcon\n              name=\"open-in-new\"\n              sentiment=\"neutral\"\n              prominence=\"weak\"\n            />\n          </Container>\n        </MenuStack>\n      </Tooltip>\n    )\n  }\n\n  return null\n}\n"]} */",
107
+ toString: _EMOTION_STRINGIFIED_CSS_ERROR__
108
+ });
109
+ const PaddingStack = /* @__PURE__ */ _styled(Stack, process.env.NODE_ENV === "production" ? {
110
+ target: "e134hokc6"
111
+ } : {
112
+ target: "e134hokc6",
113
+ label: "PaddingStack"
114
+ })(process.env.NODE_ENV === "production" ? {
115
+ name: "13feash",
116
+ styles: "padding-left:28px"
117
+ } : {
118
+ name: "13feash",
119
+ styles: "padding-left:28px",
120
+ map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["/home/runner/work/ultraviolet/ultraviolet/packages/plus/src/components/Navigation/components/Item.tsx"],"names":[],"mappings":"AAgHkC","file":"/home/runner/work/ultraviolet/ultraviolet/packages/plus/src/components/Navigation/components/Item.tsx","sourcesContent":["import { css } from '@emotion/react'\nimport styled from '@emotion/styled'\nimport { CategoryIcon, Icon } from '@ultraviolet/icons'\nimport {\n  Badge,\n  Button,\n  Expandable,\n  MenuV2,\n  Stack,\n  Text,\n  Tooltip,\n  fadeIn,\n} from '@ultraviolet/ui'\nimport type {\n  ComponentProps,\n  DragEvent,\n  JSX,\n  MouseEvent,\n  ReactNode,\n} from 'react'\nimport {\n  Children,\n  cloneElement,\n  isValidElement,\n  useCallback,\n  useEffect,\n  useMemo,\n  useState,\n} from 'react'\nimport { useNavigation } from '../NavigationProvider'\nimport { ANIMATION_DURATION, shrinkHeight } from '../constants'\n\nconst RelativeDiv = styled.div`\n  position: relative;\n`\n\nconst StyledIcon = styled(Icon, {\n  shouldForwardProp: prop => !['active'].includes(prop),\n})<{ active?: boolean }>`\n  position: absolute;\n  top: 0;\n  bottom: 0;\n  margin: auto 0;\n  padding: ${({ theme }) => theme.space['0.25']};\n  border-radius: ${({ theme }) => theme.radii.default};\n  &:hover {\n    background: ${({ theme }) => theme.colors.neutral.backgroundWeakHover};\n\n    ${({ active, theme }) => (active ? `background: ${theme.colors.primary.backgroundHover};` : null)}\n    }\n  }\n`\n\nconst NeutralButtonLink = css`\n  color: inherit;\n  text-decoration: none;\n  background-color: inherit;\n  border: none;\n  text-align: left;\n`\n\n// Pin button when the navigation is expanded\nconst LocalExpandButton = styled(Button)`\n  opacity: 0;\n  right: 0;\n  position: absolute;\n  left: -24px;\n  top: 0;\n  bottom: 0;\n  margin: auto;\n\n  &:hover,\n  &:focus,\n  &:active {\n    opacity: 1;\n  }\n`\n\nconst PinnedButton = LocalExpandButton.withComponent('div')\n\nconst GrabIcon = styled(Icon)`\n  opacity: 0;\n  margin: 0 ${({ theme }) => theme.space['0.25']};\n  cursor: grab;\n`\n\nconst StyledBadge = styled(Badge)``\n\nconst StyledMenuItem = styled(MenuV2.Item, {\n  shouldForwardProp: prop => !['isPinnable'].includes(prop),\n})<{\n  isPinnable?: boolean\n}>`\n  text-align: left;\n\n  &:hover,\n  &:focus,\n  &:active {\n    ${PinnedButton} {\n      opacity: 1;\n    }\n\n    ${StyledBadge} {\n      opacity: ${({ isPinnable }) => (isPinnable ? 0 : 1)};\n    }\n  }\n`\n\nconst StyledMenu = styled(MenuV2)`\n  width: 180px;\n`\n\nconst PaddingStack = styled(Stack)`\n  padding-left: 28px; // This value needs to be hardcoded because of the category icon size\n`\n\nconst AnimatedIcon = styled(Icon)``\n\nconst WrapText = styled(Text, {\n  shouldForwardProp: prop =>\n    !['animation', 'subLabel', 'textProminence'].includes(prop),\n})<{\n  animation?: 'collapse' | 'expand' | boolean\n  subLabel?: boolean\n}>`\n  overflow-wrap: ${({ animation }) => (animation ? 'normal' : 'anywhere')};\n  white-space: ${({ animation }) => (animation ? 'nowrap' : 'normal')};\n  overflow: hidden;\n  display: -webkit-box;\n  -webkit-box-orient: vertical;\n  -webkit-line-clamp: 2;\n  white-space: pre-wrap;\n`\n\nconst StyledStack = styled(Stack)`\n  padding-left: 28px; // This value needs to be hardcoded because of the category icon size\n`\n\nconst StyledContainer = styled(Stack)`\n  ${NeutralButtonLink};\n  border-radius: ${({ theme }) => theme.radii.default};\n\n  &[data-has-no-expand='false'] {\n    cursor: pointer;\n  }\n  margin-top: ${({ theme }) => theme.space['0.25']};\n  padding: ${({ theme }) =>\n    `calc(${theme.space['0.25']} + ${theme.space['0.5']}) ${theme.space['1']}`};\n\n  &[data-has-sub-label='true'] {\n    padding: ${({ theme }) => `${theme.space['0.5']} ${theme.space['1']}`};\n  }\n\n  width: 100%;\n\n  &:hover[data-has-no-expand='false']:not([disabled]):not(\n      [data-is-active='true']\n    ),\n  &:focus[data-has-no-expand='false']:not([disabled]):not(\n      [data-is-active='true']\n    ) {\n    background-color: ${({ theme }) => theme.colors.neutral.backgroundWeak};\n  }\n  &[data-has-active-children='true'][data-has-no-expand='false']:not(\n      [disabled][data-is-active='true']\n    ) {\n    background-color: ${({ theme }) =>\n      theme.colors.neutral.backgroundWeakHover};\n    ${WrapText} {\n      color: ${({ theme }) => theme.colors.neutral.textWeakHover};\n    }\n\n    ${PinnedButton} {\n      opacity: 1;\n    }\n\n    &[data-is-pinnable='true'] {\n      ${StyledBadge} {\n        opacity: 0;\n      }\n    }\n  }\n\n  &[data-has-no-expand='false']:not([disabled]) {\n    &:hover,\n    &:focus,\n    &:active {\n      ${PinnedButton}, ${GrabIcon} {\n        opacity: 1;\n      }\n\n      ${StyledBadge} {\n        opacity: 0;\n      }\n    }\n  }\n\n  &:hover[data-has-children='false'][data-is-active='false']:not([disabled]) {\n    ${WrapText} {\n      color: ${({ theme }) => theme.colors.neutral.textWeakHover};\n    }\n  }\n\n  &:active[data-has-no-expand='false']:not([disabled]):not(\n      [data-is-active='true']\n    ) {\n    background-color: ${({ theme }) => theme.colors.neutral.backgroundHover};\n  }\n\n  &[data-is-active='true'],\n  &:hover[data-has-active='true'] {\n    background-color: ${({ theme }) => theme.colors.primary.background};\n\n    &:hover {\n      background-color: ${({ theme }) => theme.colors.primary.backgroundHover};\n    }\n  }\n\n  &[disabled] {\n    cursor: not-allowed;\n    background-color: unset;\n\n    ${WrapText} {\n      color: ${({ theme }) => theme.colors.neutral.textWeakDisabled};\n    }\n  }\n\n  &[data-animation='collapse'] {\n    animation: ${shrinkHeight} ${ANIMATION_DURATION}ms ease-in-out;\n    ${WrapText}, ${AnimatedIcon}, ${StyledBadge} {\n      animation: ${fadeIn} ${ANIMATION_DURATION}ms ease-in-out reverse;\n    }\n  }\n\n  &[data-animation='expand'] {\n    animation: ${shrinkHeight} ${ANIMATION_DURATION}ms ease-in-out reverse;\n    ${WrapText}, ${AnimatedIcon}, ${StyledBadge} {\n      animation: ${fadeIn} ${ANIMATION_DURATION}ms ease-in-out;\n    }\n\n    ${StyledStack} {\n      display: none;\n    }\n  }\n`\n\nconst MenuStack = styled(Stack)`\n  padding: ${({ theme }) => `0 ${theme.space['2']}`};\n  margin-top: ${({ theme }) => theme.space['0.25']};\n`\n\nconst ContainerCategoryIcon = styled(Stack)`\n  min-width: 20px;\n`\n\ntype ItemType = 'default' | 'pinned' | 'pinnedGroup'\n\ntype ItemProps = {\n  children?: ReactNode\n  /**\n   * Sets a category icon on the left of the item\n   */\n  categoryIcon?: ComponentProps<typeof CategoryIcon>['name']\n  categoryIconVariant?: ComponentProps<typeof CategoryIcon>['variant']\n  /**\n   * The label of the item that will be shown.\n   * It is also used as the key for pinning.\n   */\n  label: string\n  /**\n   * It should be a unique id and will be used for pin/unpin feature.\n   */\n  id: string\n  /**\n   * Text shown under the label with a lighter color and smaller font size\n   */\n  subLabel?: string\n  /**\n   * Badge is added on the right of the item. It is hidden on hover if pinned\n   * feature is enabled\n   */\n  badgeText?: string\n  /**\n   * Defined the sentiment of the badge according to Badge component from\n   * `@ultraviolet/ui`\n   */\n  badgeSentiment?: ComponentProps<typeof Badge>['sentiment']\n  href?: string\n  /**\n   * This function will be triggered on click of the item. If the item is expandable\n   * toggle will be passed with it.\n   */\n  onClick?: (toggle?: true | false) => void\n  onPinUnpinClick?: (event: MouseEvent<HTMLDivElement>) => void\n  /**\n   * This prop is used to control if the item is expanded or collapsed\n   */\n  toggle?: boolean\n  /**\n   * Set this to true if your current page is this item.\n   */\n  active?: boolean\n  /**\n   * If you want to remove pin button on your item use this prop\n   */\n  noPinButton?: boolean\n  /**\n   * You don't need to use this prop it's used internally to control the type of the item\n   */\n  type?: ItemType\n  /**\n   * You don't need to use this prop it's used internally to control if the item has a parent\n   */\n  hasParents?: boolean\n  /**\n   * You don't need to use this prop it's used internally for pinned item to be reorganized with drag and drop\n   */\n  index?: number\n  /**\n   * When the item has href it becomes a link if not it is a button.\n   * When using an external routing tool you might need to remove both of them and use\n   * a non focusable element. This option allows you to choose the tag of the\n   * item.\n   */\n  as?: keyof JSX.IntrinsicElements\n  /**\n   * Use this prop if you want to remove the expand behavior when the item\n   * has sub items.\n   */\n  noExpand?: boolean\n  disabled?: boolean\n}\n\nexport const Item = ({\n  children,\n  categoryIcon,\n  categoryIconVariant,\n  label,\n  subLabel,\n  badgeText,\n  badgeSentiment,\n  href,\n  onClick,\n  onPinUnpinClick,\n  toggle,\n  active,\n  noPinButton,\n  type = 'default',\n  hasParents,\n  as,\n  disabled,\n  noExpand = false,\n  index,\n  id,\n}: ItemProps) => {\n  const context = useNavigation()\n\n  if (!context) {\n    throw new Error(\n      'Navigation.Item can only be used inside a NavigationProvider.',\n    )\n  }\n\n  const {\n    expanded,\n    locales,\n    pinnedFeature,\n    pinItem,\n    unpinItem,\n    pinnedItems,\n    pinLimit,\n    animation,\n    registerItem,\n  } = context\n\n  useEffect(\n    () => {\n      if (type !== 'pinnedGroup') {\n        registerItem({ [id]: { label, active, onClick } })\n      }\n    },\n    // eslint-disable-next-line react-hooks/exhaustive-deps\n    [active, id, label, registerItem],\n  )\n\n  const [internalToggle, setToggle] = useState(toggle !== false)\n\n  const triggerToggle = useCallback(\n    (value: boolean) => {\n      setToggle(value)\n      onClick?.(internalToggle)\n    },\n    [internalToggle, onClick],\n  )\n\n  useEffect(() => {\n    if (animation === 'collapse') {\n      setToggle(false)\n    }\n\n    if (animation === 'expand') {\n      setTimeout(() => {\n        setToggle(toggle ?? true)\n      }, 1)\n    }\n  }, [animation, toggle])\n\n  const PaddedStack = noExpand || type === 'pinnedGroup' ? Stack : PaddingStack\n\n  const hasHrefAndNoChildren = href && !children\n  const hasPinnedFeatureAndNoChildren =\n    pinnedFeature && !children && !noPinButton\n  const isItemPinned = pinnedItems.includes(id)\n  const shouldShowPinnedButton = useMemo(() => {\n    if (href || disabled) return false\n\n    if (hasPinnedFeatureAndNoChildren && type !== 'default') {\n      return true\n    }\n\n    if (hasPinnedFeatureAndNoChildren) {\n      return true\n    }\n\n    return false\n  }, [disabled, hasPinnedFeatureAndNoChildren, href, type])\n\n  const hasActiveChildren = useMemo(() => {\n    if (!children) return false\n\n    return (\n      Children.map(children, child =>\n        isValidElement<ItemProps>(child) ? child.props?.active : false,\n      ) as boolean[]\n    ).includes(true)\n  }, [children])\n\n  const containerTag = useMemo(() => {\n    if (as) {\n      return as\n    }\n\n    if (hasHrefAndNoChildren) {\n      return 'a'\n    }\n\n    if (noExpand) {\n      return 'div'\n    }\n\n    return 'button'\n  }, [as, hasHrefAndNoChildren, noExpand])\n\n  const Container = StyledContainer.withComponent(containerTag)\n\n  const ariaExpanded = useMemo(() => {\n    if (hasHrefAndNoChildren && internalToggle) {\n      return true\n    }\n\n    if (hasHrefAndNoChildren && !internalToggle) {\n      return false\n    }\n\n    return undefined\n  }, [hasHrefAndNoChildren, internalToggle])\n\n  const isPinDisabled = pinnedItems.length >= pinLimit\n  const pinTooltipLocale = useMemo(() => {\n    if (isPinDisabled) {\n      return locales['navigation.pin.limit']\n    }\n\n    if (isItemPinned) {\n      return locales['navigation.unpin.tooltip']\n    }\n\n    return locales['navigation.pin.tooltip']\n  }, [isItemPinned, isPinDisabled, locales])\n\n  const onDragStartTrigger = (event: DragEvent<HTMLDivElement>) => {\n    event.dataTransfer.setData('text/plain', JSON.stringify({ label, index }))\n    // eslint-disable-next-line no-param-reassign\n    event.currentTarget.style.opacity = '0.5'\n  }\n\n  const onDragStopTrigger = (event: DragEvent<HTMLDivElement>) => {\n    // eslint-disable-next-line no-param-reassign\n    event.currentTarget.style.opacity = '1'\n  }\n\n  // This content is when the navigation is expanded\n  if (expanded || (!expanded && animation === 'expand')) {\n    const renderChildren = Children.map(children, child =>\n      isValidElement<ItemProps>(child)\n        ? cloneElement(child, {\n            hasParents: true,\n          })\n        : child,\n    )\n\n    return (\n      <>\n        <Container\n          gap={1}\n          direction=\"row\"\n          alignItems=\"center\"\n          justifyContent=\"space-between\"\n          data-has-sub-label={!!subLabel}\n          onClick={() => {\n            if (children) {\n              return triggerToggle(!internalToggle)\n            }\n\n            return onClick?.()\n          }}\n          aria-expanded={ariaExpanded}\n          href={href}\n          target={href ? '_blank' : undefined}\n          data-is-pinnable={shouldShowPinnedButton}\n          data-is-active={active}\n          data-animation={animation}\n          data-has-children={!!children}\n          data-has-active-children={hasActiveChildren}\n          data-has-no-expand={noExpand}\n          disabled={disabled}\n          draggable={type === 'pinned' && expanded}\n          onDragStart={(event: DragEvent<HTMLDivElement>) =>\n            expanded ? onDragStartTrigger(event) : undefined\n          }\n          onDragEnd={(event: DragEvent<HTMLDivElement>) =>\n            expanded ? onDragStopTrigger(event) : undefined\n          }\n          id={id}\n        >\n          <Stack\n            direction=\"row\"\n            gap={1}\n            alignItems=\"center\"\n            justifyContent=\"center\"\n          >\n            {categoryIcon ? (\n              <ContainerCategoryIcon\n                alignItems=\"center\"\n                justifyContent=\"center\"\n              >\n                <CategoryIcon\n                  name={categoryIcon}\n                  variant={active ? 'primary' : categoryIconVariant}\n                  disabled={disabled}\n                />\n              </ContainerCategoryIcon>\n            ) : null}\n            {type === 'pinned' && expanded ? (\n              <GrabIcon\n                name=\"drag-vertical\"\n                sentiment=\"neutral\"\n                prominence=\"weak\"\n                size=\"small\"\n                disabled={disabled}\n              />\n            ) : null}\n            <Stack>\n              <WrapText\n                as=\"span\"\n                variant=\"bodySmallStrong\"\n                sentiment={active ? 'primary' : 'neutral'}\n                prominence={\n                  (categoryIcon || !hasParents) && !active\n                    ? 'strong'\n                    : 'default'\n                }\n                animation={animation}\n                disabled={disabled}\n              >\n                {label}\n              </WrapText>\n              {subLabel ? (\n                <WrapText\n                  as=\"span\"\n                  variant=\"caption\"\n                  sentiment=\"neutral\"\n                  prominence=\"weak\"\n                  animation={animation}\n                  disabled={disabled}\n                  subLabel\n                >\n                  {subLabel}\n                </WrapText>\n              ) : null}\n            </Stack>\n          </Stack>\n          <Stack direction=\"row\" alignItems=\"center\" gap={href ? 1 : undefined}>\n            {badgeText || hasPinnedFeatureAndNoChildren ? (\n              <>\n                {badgeText ? (\n                  <StyledBadge\n                    sentiment={badgeSentiment}\n                    size=\"small\"\n                    prominence=\"strong\"\n                    disabled={disabled}\n                  >\n                    {badgeText}\n                  </StyledBadge>\n                ) : null}\n                {shouldShowPinnedButton ? (\n                  <Tooltip\n                    text={\n                      isItemPinned\n                        ? locales['navigation.unpin.tooltip']\n                        : pinTooltipLocale\n                    }\n                    placement=\"right\"\n                  >\n                    <RelativeDiv>\n                      <PinnedButton\n                        role=\"button\"\n                        size=\"xsmall\"\n                        variant=\"ghost\"\n                        sentiment={active ? 'primary' : 'neutral'}\n                        onClick={(event: MouseEvent<HTMLDivElement>) => {\n                          event.preventDefault()\n                          event.stopPropagation() // This is to avoid click spread to the parent and change the routing\n                          if (isItemPinned) {\n                            unpinItem(id)\n                          } else {\n                            pinItem(id)\n                          }\n                          onPinUnpinClick?.(event)\n                        }}\n                        disabled={isItemPinned ? false : isPinDisabled}\n                      >\n                        <StyledIcon\n                          size=\"large\"\n                          name={isItemPinned ? 'unpin' : 'pin'}\n                          variant={isItemPinned ? 'filled' : 'outlined'}\n                          disabled={isItemPinned ? false : isPinDisabled}\n                          sentiment={active ? 'primary' : 'neutral'}\n                          active={active}\n                        />\n                      </PinnedButton>\n                    </RelativeDiv>\n                  </Tooltip>\n                ) : null}\n              </>\n            ) : null}\n            {hasHrefAndNoChildren ? (\n              <AnimatedIcon\n                name=\"open-in-new\"\n                sentiment=\"neutral\"\n                prominence=\"default\"\n                disabled={disabled}\n              />\n            ) : null}\n            {children ? (\n              <Stack gap={1} direction=\"row\" alignItems=\"center\">\n                {!animation && !noExpand ? (\n                  <AnimatedIcon\n                    name={internalToggle ? 'arrow-down' : 'arrow-right'}\n                    sentiment=\"neutral\"\n                    prominence=\"weak\"\n                  />\n                ) : null}\n              </Stack>\n            ) : null}\n          </Stack>\n        </Container>\n        {children ? (\n          <>\n            {!noExpand ? (\n              <Expandable\n                opened={internalToggle}\n                animationDuration={\n                  animation ? ANIMATION_DURATION / 2 : undefined\n                }\n              >\n                <PaddedStack>{renderChildren}</PaddedStack>\n              </Expandable>\n            ) : (\n              <PaddedStack>{renderChildren}</PaddedStack>\n            )}\n          </>\n        ) : null}\n      </>\n    )\n  }\n\n  // This content is the menu of the navigation when collapsed\n  if (categoryIcon || (Children.count(children) > 0 && !hasParents)) {\n    return (\n      <MenuStack gap={1} alignItems=\"start\" justifyContent=\"start\">\n        {Children.count(children) > 0 ? (\n          <StyledMenu\n            triggerMethod=\"hover\"\n            dynamicDomRendering={false} // As we parse the children we don't need dynamic rendering\n            disclosure={\n              <Button\n                sentiment=\"neutral\"\n                variant={hasActiveChildren ? 'filled' : 'ghost'}\n                size=\"small\"\n                icon={!categoryIcon ? 'dots-horizontal' : undefined}\n              >\n                {categoryIcon ? (\n                  <Stack\n                    direction=\"row\"\n                    gap={1}\n                    alignItems=\"center\"\n                    justifyContent=\"center\"\n                  >\n                    <CategoryIcon\n                      name={categoryIcon}\n                      variant={active ? 'primary' : categoryIconVariant}\n                    />\n                  </Stack>\n                ) : null}\n              </Button>\n            }\n            placement=\"right\"\n          >\n            {Children.map(children, child =>\n              isValidElement<ItemProps>(child)\n                ? cloneElement(child, {\n                    hasParents: true,\n                  })\n                : child,\n            )}\n          </StyledMenu>\n        ) : (\n          <Tooltip text={label} placement=\"right\" tabIndex={-1}>\n            <Button\n              sentiment=\"neutral\"\n              variant={active ? 'filled' : 'ghost'}\n              size=\"small\"\n              onClick={() => onClick?.()}\n            >\n              <Stack\n                direction=\"row\"\n                gap={1}\n                alignItems=\"center\"\n                justifyContent=\"center\"\n              >\n                <CategoryIcon\n                  name={categoryIcon ?? 'console'}\n                  variant={active ? 'primary' : categoryIconVariant}\n                />\n              </Stack>\n            </Button>\n          </Tooltip>\n        )}\n      </MenuStack>\n    )\n  }\n\n  // This content is what is inside a menu item the navigation is collapsed\n  if (hasParents) {\n    return (\n      <StyledMenuItem\n        href={href}\n        onClick={() => {\n          onClick?.()\n        }}\n        borderless\n        active={active}\n        disabled={disabled}\n        sentiment={active ? 'primary' : 'neutral'}\n        isPinnable={shouldShowPinnedButton}\n      >\n        <Stack\n          gap={1}\n          direction=\"row\"\n          alignItems=\"center\"\n          justifyContent=\"space-between\"\n          flex={1}\n          width=\"100%\"\n        >\n          <WrapText as=\"span\" variant=\"bodySmall\">\n            {label}\n          </WrapText>\n          <Stack direction=\"row\">\n            {badgeText ? (\n              <StyledBadge\n                sentiment={badgeSentiment}\n                size=\"small\"\n                prominence=\"strong\"\n                disabled={disabled}\n              >\n                {badgeText}\n              </StyledBadge>\n            ) : null}\n            {hasHrefAndNoChildren ? (\n              <AnimatedIcon\n                name=\"open-in-new\"\n                sentiment=\"neutral\"\n                prominence=\"weak\"\n                disabled={disabled}\n              />\n            ) : null}\n            {shouldShowPinnedButton ? (\n              <Tooltip\n                text={\n                  isItemPinned\n                    ? locales['navigation.unpin.tooltip']\n                    : pinTooltipLocale\n                }\n                placement=\"right\"\n              >\n                <RelativeDiv>\n                  <PinnedButton\n                    role=\"button\"\n                    size=\"xsmall\"\n                    variant=\"ghost\"\n                    sentiment={active ? 'primary' : 'neutral'}\n                    onClick={(event: MouseEvent<HTMLDivElement>) => {\n                      event.preventDefault()\n                      event.stopPropagation() // This is to avoid click spread to the parent and change the routing\n                      if (isItemPinned) {\n                        unpinItem(id)\n                      } else {\n                        pinItem(id)\n                      }\n                      onPinUnpinClick?.(event)\n                    }}\n                    disabled={isItemPinned ? false : isPinDisabled}\n                  >\n                    <StyledIcon\n                      size=\"large\"\n                      name={isItemPinned ? 'unpin' : 'pin'}\n                      variant={isItemPinned ? 'filled' : 'outlined'}\n                      disabled={isItemPinned ? false : isPinDisabled}\n                      sentiment={active ? 'primary' : 'neutral'}\n                      active={active}\n                    />\n                  </PinnedButton>\n                </RelativeDiv>\n              </Tooltip>\n            ) : null}\n          </Stack>\n        </Stack>\n      </StyledMenuItem>\n    )\n  }\n\n  // This content is for when navigation is collapsed and we show an icon of link\n  if (!hasParents && href) {\n    return (\n      <Tooltip text={label} placement=\"right\">\n        <MenuStack gap={1} alignItems=\"start\" justifyContent=\"start\">\n          <Container\n            gap={1}\n            alignItems=\"center\"\n            justifyContent=\"center\"\n            href={href}\n            target=\"_blank\"\n          >\n            <AnimatedIcon\n              name=\"open-in-new\"\n              sentiment=\"neutral\"\n              prominence=\"weak\"\n            />\n          </Container>\n        </MenuStack>\n      </Tooltip>\n    )\n  }\n\n  return null\n}\n"]} */",
121
+ toString: _EMOTION_STRINGIFIED_CSS_ERROR__
122
+ });
123
+ const AnimatedIcon = /* @__PURE__ */ _styled(Icon, process.env.NODE_ENV === "production" ? {
124
+ target: "e134hokc5"
125
+ } : {
126
+ target: "e134hokc5",
127
+ label: "AnimatedIcon"
128
+ })(process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["/home/runner/work/ultraviolet/ultraviolet/packages/plus/src/components/Navigation/components/Item.tsx"],"names":[],"mappings":"AAoHiC","file":"/home/runner/work/ultraviolet/ultraviolet/packages/plus/src/components/Navigation/components/Item.tsx","sourcesContent":["import { css } from '@emotion/react'\nimport styled from '@emotion/styled'\nimport { CategoryIcon, Icon } from '@ultraviolet/icons'\nimport {\n  Badge,\n  Button,\n  Expandable,\n  MenuV2,\n  Stack,\n  Text,\n  Tooltip,\n  fadeIn,\n} from '@ultraviolet/ui'\nimport type {\n  ComponentProps,\n  DragEvent,\n  JSX,\n  MouseEvent,\n  ReactNode,\n} from 'react'\nimport {\n  Children,\n  cloneElement,\n  isValidElement,\n  useCallback,\n  useEffect,\n  useMemo,\n  useState,\n} from 'react'\nimport { useNavigation } from '../NavigationProvider'\nimport { ANIMATION_DURATION, shrinkHeight } from '../constants'\n\nconst RelativeDiv = styled.div`\n  position: relative;\n`\n\nconst StyledIcon = styled(Icon, {\n  shouldForwardProp: prop => !['active'].includes(prop),\n})<{ active?: boolean }>`\n  position: absolute;\n  top: 0;\n  bottom: 0;\n  margin: auto 0;\n  padding: ${({ theme }) => theme.space['0.25']};\n  border-radius: ${({ theme }) => theme.radii.default};\n  &:hover {\n    background: ${({ theme }) => theme.colors.neutral.backgroundWeakHover};\n\n    ${({ active, theme }) => (active ? `background: ${theme.colors.primary.backgroundHover};` : null)}\n    }\n  }\n`\n\nconst NeutralButtonLink = css`\n  color: inherit;\n  text-decoration: none;\n  background-color: inherit;\n  border: none;\n  text-align: left;\n`\n\n// Pin button when the navigation is expanded\nconst LocalExpandButton = styled(Button)`\n  opacity: 0;\n  right: 0;\n  position: absolute;\n  left: -24px;\n  top: 0;\n  bottom: 0;\n  margin: auto;\n\n  &:hover,\n  &:focus,\n  &:active {\n    opacity: 1;\n  }\n`\n\nconst PinnedButton = LocalExpandButton.withComponent('div')\n\nconst GrabIcon = styled(Icon)`\n  opacity: 0;\n  margin: 0 ${({ theme }) => theme.space['0.25']};\n  cursor: grab;\n`\n\nconst StyledBadge = styled(Badge)``\n\nconst StyledMenuItem = styled(MenuV2.Item, {\n  shouldForwardProp: prop => !['isPinnable'].includes(prop),\n})<{\n  isPinnable?: boolean\n}>`\n  text-align: left;\n\n  &:hover,\n  &:focus,\n  &:active {\n    ${PinnedButton} {\n      opacity: 1;\n    }\n\n    ${StyledBadge} {\n      opacity: ${({ isPinnable }) => (isPinnable ? 0 : 1)};\n    }\n  }\n`\n\nconst StyledMenu = styled(MenuV2)`\n  width: 180px;\n`\n\nconst PaddingStack = styled(Stack)`\n  padding-left: 28px; // This value needs to be hardcoded because of the category icon size\n`\n\nconst AnimatedIcon = styled(Icon)``\n\nconst WrapText = styled(Text, {\n  shouldForwardProp: prop =>\n    !['animation', 'subLabel', 'textProminence'].includes(prop),\n})<{\n  animation?: 'collapse' | 'expand' | boolean\n  subLabel?: boolean\n}>`\n  overflow-wrap: ${({ animation }) => (animation ? 'normal' : 'anywhere')};\n  white-space: ${({ animation }) => (animation ? 'nowrap' : 'normal')};\n  overflow: hidden;\n  display: -webkit-box;\n  -webkit-box-orient: vertical;\n  -webkit-line-clamp: 2;\n  white-space: pre-wrap;\n`\n\nconst StyledStack = styled(Stack)`\n  padding-left: 28px; // This value needs to be hardcoded because of the category icon size\n`\n\nconst StyledContainer = styled(Stack)`\n  ${NeutralButtonLink};\n  border-radius: ${({ theme }) => theme.radii.default};\n\n  &[data-has-no-expand='false'] {\n    cursor: pointer;\n  }\n  margin-top: ${({ theme }) => theme.space['0.25']};\n  padding: ${({ theme }) =>\n    `calc(${theme.space['0.25']} + ${theme.space['0.5']}) ${theme.space['1']}`};\n\n  &[data-has-sub-label='true'] {\n    padding: ${({ theme }) => `${theme.space['0.5']} ${theme.space['1']}`};\n  }\n\n  width: 100%;\n\n  &:hover[data-has-no-expand='false']:not([disabled]):not(\n      [data-is-active='true']\n    ),\n  &:focus[data-has-no-expand='false']:not([disabled]):not(\n      [data-is-active='true']\n    ) {\n    background-color: ${({ theme }) => theme.colors.neutral.backgroundWeak};\n  }\n  &[data-has-active-children='true'][data-has-no-expand='false']:not(\n      [disabled][data-is-active='true']\n    ) {\n    background-color: ${({ theme }) =>\n      theme.colors.neutral.backgroundWeakHover};\n    ${WrapText} {\n      color: ${({ theme }) => theme.colors.neutral.textWeakHover};\n    }\n\n    ${PinnedButton} {\n      opacity: 1;\n    }\n\n    &[data-is-pinnable='true'] {\n      ${StyledBadge} {\n        opacity: 0;\n      }\n    }\n  }\n\n  &[data-has-no-expand='false']:not([disabled]) {\n    &:hover,\n    &:focus,\n    &:active {\n      ${PinnedButton}, ${GrabIcon} {\n        opacity: 1;\n      }\n\n      ${StyledBadge} {\n        opacity: 0;\n      }\n    }\n  }\n\n  &:hover[data-has-children='false'][data-is-active='false']:not([disabled]) {\n    ${WrapText} {\n      color: ${({ theme }) => theme.colors.neutral.textWeakHover};\n    }\n  }\n\n  &:active[data-has-no-expand='false']:not([disabled]):not(\n      [data-is-active='true']\n    ) {\n    background-color: ${({ theme }) => theme.colors.neutral.backgroundHover};\n  }\n\n  &[data-is-active='true'],\n  &:hover[data-has-active='true'] {\n    background-color: ${({ theme }) => theme.colors.primary.background};\n\n    &:hover {\n      background-color: ${({ theme }) => theme.colors.primary.backgroundHover};\n    }\n  }\n\n  &[disabled] {\n    cursor: not-allowed;\n    background-color: unset;\n\n    ${WrapText} {\n      color: ${({ theme }) => theme.colors.neutral.textWeakDisabled};\n    }\n  }\n\n  &[data-animation='collapse'] {\n    animation: ${shrinkHeight} ${ANIMATION_DURATION}ms ease-in-out;\n    ${WrapText}, ${AnimatedIcon}, ${StyledBadge} {\n      animation: ${fadeIn} ${ANIMATION_DURATION}ms ease-in-out reverse;\n    }\n  }\n\n  &[data-animation='expand'] {\n    animation: ${shrinkHeight} ${ANIMATION_DURATION}ms ease-in-out reverse;\n    ${WrapText}, ${AnimatedIcon}, ${StyledBadge} {\n      animation: ${fadeIn} ${ANIMATION_DURATION}ms ease-in-out;\n    }\n\n    ${StyledStack} {\n      display: none;\n    }\n  }\n`\n\nconst MenuStack = styled(Stack)`\n  padding: ${({ theme }) => `0 ${theme.space['2']}`};\n  margin-top: ${({ theme }) => theme.space['0.25']};\n`\n\nconst ContainerCategoryIcon = styled(Stack)`\n  min-width: 20px;\n`\n\ntype ItemType = 'default' | 'pinned' | 'pinnedGroup'\n\ntype ItemProps = {\n  children?: ReactNode\n  /**\n   * Sets a category icon on the left of the item\n   */\n  categoryIcon?: ComponentProps<typeof CategoryIcon>['name']\n  categoryIconVariant?: ComponentProps<typeof CategoryIcon>['variant']\n  /**\n   * The label of the item that will be shown.\n   * It is also used as the key for pinning.\n   */\n  label: string\n  /**\n   * It should be a unique id and will be used for pin/unpin feature.\n   */\n  id: string\n  /**\n   * Text shown under the label with a lighter color and smaller font size\n   */\n  subLabel?: string\n  /**\n   * Badge is added on the right of the item. It is hidden on hover if pinned\n   * feature is enabled\n   */\n  badgeText?: string\n  /**\n   * Defined the sentiment of the badge according to Badge component from\n   * `@ultraviolet/ui`\n   */\n  badgeSentiment?: ComponentProps<typeof Badge>['sentiment']\n  href?: string\n  /**\n   * This function will be triggered on click of the item. If the item is expandable\n   * toggle will be passed with it.\n   */\n  onClick?: (toggle?: true | false) => void\n  onPinUnpinClick?: (event: MouseEvent<HTMLDivElement>) => void\n  /**\n   * This prop is used to control if the item is expanded or collapsed\n   */\n  toggle?: boolean\n  /**\n   * Set this to true if your current page is this item.\n   */\n  active?: boolean\n  /**\n   * If you want to remove pin button on your item use this prop\n   */\n  noPinButton?: boolean\n  /**\n   * You don't need to use this prop it's used internally to control the type of the item\n   */\n  type?: ItemType\n  /**\n   * You don't need to use this prop it's used internally to control if the item has a parent\n   */\n  hasParents?: boolean\n  /**\n   * You don't need to use this prop it's used internally for pinned item to be reorganized with drag and drop\n   */\n  index?: number\n  /**\n   * When the item has href it becomes a link if not it is a button.\n   * When using an external routing tool you might need to remove both of them and use\n   * a non focusable element. This option allows you to choose the tag of the\n   * item.\n   */\n  as?: keyof JSX.IntrinsicElements\n  /**\n   * Use this prop if you want to remove the expand behavior when the item\n   * has sub items.\n   */\n  noExpand?: boolean\n  disabled?: boolean\n}\n\nexport const Item = ({\n  children,\n  categoryIcon,\n  categoryIconVariant,\n  label,\n  subLabel,\n  badgeText,\n  badgeSentiment,\n  href,\n  onClick,\n  onPinUnpinClick,\n  toggle,\n  active,\n  noPinButton,\n  type = 'default',\n  hasParents,\n  as,\n  disabled,\n  noExpand = false,\n  index,\n  id,\n}: ItemProps) => {\n  const context = useNavigation()\n\n  if (!context) {\n    throw new Error(\n      'Navigation.Item can only be used inside a NavigationProvider.',\n    )\n  }\n\n  const {\n    expanded,\n    locales,\n    pinnedFeature,\n    pinItem,\n    unpinItem,\n    pinnedItems,\n    pinLimit,\n    animation,\n    registerItem,\n  } = context\n\n  useEffect(\n    () => {\n      if (type !== 'pinnedGroup') {\n        registerItem({ [id]: { label, active, onClick } })\n      }\n    },\n    // eslint-disable-next-line react-hooks/exhaustive-deps\n    [active, id, label, registerItem],\n  )\n\n  const [internalToggle, setToggle] = useState(toggle !== false)\n\n  const triggerToggle = useCallback(\n    (value: boolean) => {\n      setToggle(value)\n      onClick?.(internalToggle)\n    },\n    [internalToggle, onClick],\n  )\n\n  useEffect(() => {\n    if (animation === 'collapse') {\n      setToggle(false)\n    }\n\n    if (animation === 'expand') {\n      setTimeout(() => {\n        setToggle(toggle ?? true)\n      }, 1)\n    }\n  }, [animation, toggle])\n\n  const PaddedStack = noExpand || type === 'pinnedGroup' ? Stack : PaddingStack\n\n  const hasHrefAndNoChildren = href && !children\n  const hasPinnedFeatureAndNoChildren =\n    pinnedFeature && !children && !noPinButton\n  const isItemPinned = pinnedItems.includes(id)\n  const shouldShowPinnedButton = useMemo(() => {\n    if (href || disabled) return false\n\n    if (hasPinnedFeatureAndNoChildren && type !== 'default') {\n      return true\n    }\n\n    if (hasPinnedFeatureAndNoChildren) {\n      return true\n    }\n\n    return false\n  }, [disabled, hasPinnedFeatureAndNoChildren, href, type])\n\n  const hasActiveChildren = useMemo(() => {\n    if (!children) return false\n\n    return (\n      Children.map(children, child =>\n        isValidElement<ItemProps>(child) ? child.props?.active : false,\n      ) as boolean[]\n    ).includes(true)\n  }, [children])\n\n  const containerTag = useMemo(() => {\n    if (as) {\n      return as\n    }\n\n    if (hasHrefAndNoChildren) {\n      return 'a'\n    }\n\n    if (noExpand) {\n      return 'div'\n    }\n\n    return 'button'\n  }, [as, hasHrefAndNoChildren, noExpand])\n\n  const Container = StyledContainer.withComponent(containerTag)\n\n  const ariaExpanded = useMemo(() => {\n    if (hasHrefAndNoChildren && internalToggle) {\n      return true\n    }\n\n    if (hasHrefAndNoChildren && !internalToggle) {\n      return false\n    }\n\n    return undefined\n  }, [hasHrefAndNoChildren, internalToggle])\n\n  const isPinDisabled = pinnedItems.length >= pinLimit\n  const pinTooltipLocale = useMemo(() => {\n    if (isPinDisabled) {\n      return locales['navigation.pin.limit']\n    }\n\n    if (isItemPinned) {\n      return locales['navigation.unpin.tooltip']\n    }\n\n    return locales['navigation.pin.tooltip']\n  }, [isItemPinned, isPinDisabled, locales])\n\n  const onDragStartTrigger = (event: DragEvent<HTMLDivElement>) => {\n    event.dataTransfer.setData('text/plain', JSON.stringify({ label, index }))\n    // eslint-disable-next-line no-param-reassign\n    event.currentTarget.style.opacity = '0.5'\n  }\n\n  const onDragStopTrigger = (event: DragEvent<HTMLDivElement>) => {\n    // eslint-disable-next-line no-param-reassign\n    event.currentTarget.style.opacity = '1'\n  }\n\n  // This content is when the navigation is expanded\n  if (expanded || (!expanded && animation === 'expand')) {\n    const renderChildren = Children.map(children, child =>\n      isValidElement<ItemProps>(child)\n        ? cloneElement(child, {\n            hasParents: true,\n          })\n        : child,\n    )\n\n    return (\n      <>\n        <Container\n          gap={1}\n          direction=\"row\"\n          alignItems=\"center\"\n          justifyContent=\"space-between\"\n          data-has-sub-label={!!subLabel}\n          onClick={() => {\n            if (children) {\n              return triggerToggle(!internalToggle)\n            }\n\n            return onClick?.()\n          }}\n          aria-expanded={ariaExpanded}\n          href={href}\n          target={href ? '_blank' : undefined}\n          data-is-pinnable={shouldShowPinnedButton}\n          data-is-active={active}\n          data-animation={animation}\n          data-has-children={!!children}\n          data-has-active-children={hasActiveChildren}\n          data-has-no-expand={noExpand}\n          disabled={disabled}\n          draggable={type === 'pinned' && expanded}\n          onDragStart={(event: DragEvent<HTMLDivElement>) =>\n            expanded ? onDragStartTrigger(event) : undefined\n          }\n          onDragEnd={(event: DragEvent<HTMLDivElement>) =>\n            expanded ? onDragStopTrigger(event) : undefined\n          }\n          id={id}\n        >\n          <Stack\n            direction=\"row\"\n            gap={1}\n            alignItems=\"center\"\n            justifyContent=\"center\"\n          >\n            {categoryIcon ? (\n              <ContainerCategoryIcon\n                alignItems=\"center\"\n                justifyContent=\"center\"\n              >\n                <CategoryIcon\n                  name={categoryIcon}\n                  variant={active ? 'primary' : categoryIconVariant}\n                  disabled={disabled}\n                />\n              </ContainerCategoryIcon>\n            ) : null}\n            {type === 'pinned' && expanded ? (\n              <GrabIcon\n                name=\"drag-vertical\"\n                sentiment=\"neutral\"\n                prominence=\"weak\"\n                size=\"small\"\n                disabled={disabled}\n              />\n            ) : null}\n            <Stack>\n              <WrapText\n                as=\"span\"\n                variant=\"bodySmallStrong\"\n                sentiment={active ? 'primary' : 'neutral'}\n                prominence={\n                  (categoryIcon || !hasParents) && !active\n                    ? 'strong'\n                    : 'default'\n                }\n                animation={animation}\n                disabled={disabled}\n              >\n                {label}\n              </WrapText>\n              {subLabel ? (\n                <WrapText\n                  as=\"span\"\n                  variant=\"caption\"\n                  sentiment=\"neutral\"\n                  prominence=\"weak\"\n                  animation={animation}\n                  disabled={disabled}\n                  subLabel\n                >\n                  {subLabel}\n                </WrapText>\n              ) : null}\n            </Stack>\n          </Stack>\n          <Stack direction=\"row\" alignItems=\"center\" gap={href ? 1 : undefined}>\n            {badgeText || hasPinnedFeatureAndNoChildren ? (\n              <>\n                {badgeText ? (\n                  <StyledBadge\n                    sentiment={badgeSentiment}\n                    size=\"small\"\n                    prominence=\"strong\"\n                    disabled={disabled}\n                  >\n                    {badgeText}\n                  </StyledBadge>\n                ) : null}\n                {shouldShowPinnedButton ? (\n                  <Tooltip\n                    text={\n                      isItemPinned\n                        ? locales['navigation.unpin.tooltip']\n                        : pinTooltipLocale\n                    }\n                    placement=\"right\"\n                  >\n                    <RelativeDiv>\n                      <PinnedButton\n                        role=\"button\"\n                        size=\"xsmall\"\n                        variant=\"ghost\"\n                        sentiment={active ? 'primary' : 'neutral'}\n                        onClick={(event: MouseEvent<HTMLDivElement>) => {\n                          event.preventDefault()\n                          event.stopPropagation() // This is to avoid click spread to the parent and change the routing\n                          if (isItemPinned) {\n                            unpinItem(id)\n                          } else {\n                            pinItem(id)\n                          }\n                          onPinUnpinClick?.(event)\n                        }}\n                        disabled={isItemPinned ? false : isPinDisabled}\n                      >\n                        <StyledIcon\n                          size=\"large\"\n                          name={isItemPinned ? 'unpin' : 'pin'}\n                          variant={isItemPinned ? 'filled' : 'outlined'}\n                          disabled={isItemPinned ? false : isPinDisabled}\n                          sentiment={active ? 'primary' : 'neutral'}\n                          active={active}\n                        />\n                      </PinnedButton>\n                    </RelativeDiv>\n                  </Tooltip>\n                ) : null}\n              </>\n            ) : null}\n            {hasHrefAndNoChildren ? (\n              <AnimatedIcon\n                name=\"open-in-new\"\n                sentiment=\"neutral\"\n                prominence=\"default\"\n                disabled={disabled}\n              />\n            ) : null}\n            {children ? (\n              <Stack gap={1} direction=\"row\" alignItems=\"center\">\n                {!animation && !noExpand ? (\n                  <AnimatedIcon\n                    name={internalToggle ? 'arrow-down' : 'arrow-right'}\n                    sentiment=\"neutral\"\n                    prominence=\"weak\"\n                  />\n                ) : null}\n              </Stack>\n            ) : null}\n          </Stack>\n        </Container>\n        {children ? (\n          <>\n            {!noExpand ? (\n              <Expandable\n                opened={internalToggle}\n                animationDuration={\n                  animation ? ANIMATION_DURATION / 2 : undefined\n                }\n              >\n                <PaddedStack>{renderChildren}</PaddedStack>\n              </Expandable>\n            ) : (\n              <PaddedStack>{renderChildren}</PaddedStack>\n            )}\n          </>\n        ) : null}\n      </>\n    )\n  }\n\n  // This content is the menu of the navigation when collapsed\n  if (categoryIcon || (Children.count(children) > 0 && !hasParents)) {\n    return (\n      <MenuStack gap={1} alignItems=\"start\" justifyContent=\"start\">\n        {Children.count(children) > 0 ? (\n          <StyledMenu\n            triggerMethod=\"hover\"\n            dynamicDomRendering={false} // As we parse the children we don't need dynamic rendering\n            disclosure={\n              <Button\n                sentiment=\"neutral\"\n                variant={hasActiveChildren ? 'filled' : 'ghost'}\n                size=\"small\"\n                icon={!categoryIcon ? 'dots-horizontal' : undefined}\n              >\n                {categoryIcon ? (\n                  <Stack\n                    direction=\"row\"\n                    gap={1}\n                    alignItems=\"center\"\n                    justifyContent=\"center\"\n                  >\n                    <CategoryIcon\n                      name={categoryIcon}\n                      variant={active ? 'primary' : categoryIconVariant}\n                    />\n                  </Stack>\n                ) : null}\n              </Button>\n            }\n            placement=\"right\"\n          >\n            {Children.map(children, child =>\n              isValidElement<ItemProps>(child)\n                ? cloneElement(child, {\n                    hasParents: true,\n                  })\n                : child,\n            )}\n          </StyledMenu>\n        ) : (\n          <Tooltip text={label} placement=\"right\" tabIndex={-1}>\n            <Button\n              sentiment=\"neutral\"\n              variant={active ? 'filled' : 'ghost'}\n              size=\"small\"\n              onClick={() => onClick?.()}\n            >\n              <Stack\n                direction=\"row\"\n                gap={1}\n                alignItems=\"center\"\n                justifyContent=\"center\"\n              >\n                <CategoryIcon\n                  name={categoryIcon ?? 'console'}\n                  variant={active ? 'primary' : categoryIconVariant}\n                />\n              </Stack>\n            </Button>\n          </Tooltip>\n        )}\n      </MenuStack>\n    )\n  }\n\n  // This content is what is inside a menu item the navigation is collapsed\n  if (hasParents) {\n    return (\n      <StyledMenuItem\n        href={href}\n        onClick={() => {\n          onClick?.()\n        }}\n        borderless\n        active={active}\n        disabled={disabled}\n        sentiment={active ? 'primary' : 'neutral'}\n        isPinnable={shouldShowPinnedButton}\n      >\n        <Stack\n          gap={1}\n          direction=\"row\"\n          alignItems=\"center\"\n          justifyContent=\"space-between\"\n          flex={1}\n          width=\"100%\"\n        >\n          <WrapText as=\"span\" variant=\"bodySmall\">\n            {label}\n          </WrapText>\n          <Stack direction=\"row\">\n            {badgeText ? (\n              <StyledBadge\n                sentiment={badgeSentiment}\n                size=\"small\"\n                prominence=\"strong\"\n                disabled={disabled}\n              >\n                {badgeText}\n              </StyledBadge>\n            ) : null}\n            {hasHrefAndNoChildren ? (\n              <AnimatedIcon\n                name=\"open-in-new\"\n                sentiment=\"neutral\"\n                prominence=\"weak\"\n                disabled={disabled}\n              />\n            ) : null}\n            {shouldShowPinnedButton ? (\n              <Tooltip\n                text={\n                  isItemPinned\n                    ? locales['navigation.unpin.tooltip']\n                    : pinTooltipLocale\n                }\n                placement=\"right\"\n              >\n                <RelativeDiv>\n                  <PinnedButton\n                    role=\"button\"\n                    size=\"xsmall\"\n                    variant=\"ghost\"\n                    sentiment={active ? 'primary' : 'neutral'}\n                    onClick={(event: MouseEvent<HTMLDivElement>) => {\n                      event.preventDefault()\n                      event.stopPropagation() // This is to avoid click spread to the parent and change the routing\n                      if (isItemPinned) {\n                        unpinItem(id)\n                      } else {\n                        pinItem(id)\n                      }\n                      onPinUnpinClick?.(event)\n                    }}\n                    disabled={isItemPinned ? false : isPinDisabled}\n                  >\n                    <StyledIcon\n                      size=\"large\"\n                      name={isItemPinned ? 'unpin' : 'pin'}\n                      variant={isItemPinned ? 'filled' : 'outlined'}\n                      disabled={isItemPinned ? false : isPinDisabled}\n                      sentiment={active ? 'primary' : 'neutral'}\n                      active={active}\n                    />\n                  </PinnedButton>\n                </RelativeDiv>\n              </Tooltip>\n            ) : null}\n          </Stack>\n        </Stack>\n      </StyledMenuItem>\n    )\n  }\n\n  // This content is for when navigation is collapsed and we show an icon of link\n  if (!hasParents && href) {\n    return (\n      <Tooltip text={label} placement=\"right\">\n        <MenuStack gap={1} alignItems=\"start\" justifyContent=\"start\">\n          <Container\n            gap={1}\n            alignItems=\"center\"\n            justifyContent=\"center\"\n            href={href}\n            target=\"_blank\"\n          >\n            <AnimatedIcon\n              name=\"open-in-new\"\n              sentiment=\"neutral\"\n              prominence=\"weak\"\n            />\n          </Container>\n        </MenuStack>\n      </Tooltip>\n    )\n  }\n\n  return null\n}\n"]} */");
129
+ const WrapText = /* @__PURE__ */ _styled(Text, process.env.NODE_ENV === "production" ? {
130
+ shouldForwardProp: (prop) => !["animation", "subLabel", "textProminence"].includes(prop),
131
+ target: "e134hokc4"
132
+ } : {
133
+ shouldForwardProp: (prop) => !["animation", "subLabel", "textProminence"].includes(prop),
134
+ target: "e134hokc4",
135
+ label: "WrapText"
136
+ })("overflow-wrap:", ({
137
+ animation
138
+ }) => animation ? "normal" : "anywhere", ";white-space:", ({
139
+ animation
140
+ }) => animation ? "nowrap" : "normal", ";overflow:hidden;display:-webkit-box;-webkit-box-orient:vertical;-webkit-line-clamp:2;white-space:pre-wrap;" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["/home/runner/work/ultraviolet/ultraviolet/packages/plus/src/components/Navigation/components/Item.tsx"],"names":[],"mappings":"AA4HE","file":"/home/runner/work/ultraviolet/ultraviolet/packages/plus/src/components/Navigation/components/Item.tsx","sourcesContent":["import { css } from '@emotion/react'\nimport styled from '@emotion/styled'\nimport { CategoryIcon, Icon } from '@ultraviolet/icons'\nimport {\n  Badge,\n  Button,\n  Expandable,\n  MenuV2,\n  Stack,\n  Text,\n  Tooltip,\n  fadeIn,\n} from '@ultraviolet/ui'\nimport type {\n  ComponentProps,\n  DragEvent,\n  JSX,\n  MouseEvent,\n  ReactNode,\n} from 'react'\nimport {\n  Children,\n  cloneElement,\n  isValidElement,\n  useCallback,\n  useEffect,\n  useMemo,\n  useState,\n} from 'react'\nimport { useNavigation } from '../NavigationProvider'\nimport { ANIMATION_DURATION, shrinkHeight } from '../constants'\n\nconst RelativeDiv = styled.div`\n  position: relative;\n`\n\nconst StyledIcon = styled(Icon, {\n  shouldForwardProp: prop => !['active'].includes(prop),\n})<{ active?: boolean }>`\n  position: absolute;\n  top: 0;\n  bottom: 0;\n  margin: auto 0;\n  padding: ${({ theme }) => theme.space['0.25']};\n  border-radius: ${({ theme }) => theme.radii.default};\n  &:hover {\n    background: ${({ theme }) => theme.colors.neutral.backgroundWeakHover};\n\n    ${({ active, theme }) => (active ? `background: ${theme.colors.primary.backgroundHover};` : null)}\n    }\n  }\n`\n\nconst NeutralButtonLink = css`\n  color: inherit;\n  text-decoration: none;\n  background-color: inherit;\n  border: none;\n  text-align: left;\n`\n\n// Pin button when the navigation is expanded\nconst LocalExpandButton = styled(Button)`\n  opacity: 0;\n  right: 0;\n  position: absolute;\n  left: -24px;\n  top: 0;\n  bottom: 0;\n  margin: auto;\n\n  &:hover,\n  &:focus,\n  &:active {\n    opacity: 1;\n  }\n`\n\nconst PinnedButton = LocalExpandButton.withComponent('div')\n\nconst GrabIcon = styled(Icon)`\n  opacity: 0;\n  margin: 0 ${({ theme }) => theme.space['0.25']};\n  cursor: grab;\n`\n\nconst StyledBadge = styled(Badge)``\n\nconst StyledMenuItem = styled(MenuV2.Item, {\n  shouldForwardProp: prop => !['isPinnable'].includes(prop),\n})<{\n  isPinnable?: boolean\n}>`\n  text-align: left;\n\n  &:hover,\n  &:focus,\n  &:active {\n    ${PinnedButton} {\n      opacity: 1;\n    }\n\n    ${StyledBadge} {\n      opacity: ${({ isPinnable }) => (isPinnable ? 0 : 1)};\n    }\n  }\n`\n\nconst StyledMenu = styled(MenuV2)`\n  width: 180px;\n`\n\nconst PaddingStack = styled(Stack)`\n  padding-left: 28px; // This value needs to be hardcoded because of the category icon size\n`\n\nconst AnimatedIcon = styled(Icon)``\n\nconst WrapText = styled(Text, {\n  shouldForwardProp: prop =>\n    !['animation', 'subLabel', 'textProminence'].includes(prop),\n})<{\n  animation?: 'collapse' | 'expand' | boolean\n  subLabel?: boolean\n}>`\n  overflow-wrap: ${({ animation }) => (animation ? 'normal' : 'anywhere')};\n  white-space: ${({ animation }) => (animation ? 'nowrap' : 'normal')};\n  overflow: hidden;\n  display: -webkit-box;\n  -webkit-box-orient: vertical;\n  -webkit-line-clamp: 2;\n  white-space: pre-wrap;\n`\n\nconst StyledStack = styled(Stack)`\n  padding-left: 28px; // This value needs to be hardcoded because of the category icon size\n`\n\nconst StyledContainer = styled(Stack)`\n  ${NeutralButtonLink};\n  border-radius: ${({ theme }) => theme.radii.default};\n\n  &[data-has-no-expand='false'] {\n    cursor: pointer;\n  }\n  margin-top: ${({ theme }) => theme.space['0.25']};\n  padding: ${({ theme }) =>\n    `calc(${theme.space['0.25']} + ${theme.space['0.5']}) ${theme.space['1']}`};\n\n  &[data-has-sub-label='true'] {\n    padding: ${({ theme }) => `${theme.space['0.5']} ${theme.space['1']}`};\n  }\n\n  width: 100%;\n\n  &:hover[data-has-no-expand='false']:not([disabled]):not(\n      [data-is-active='true']\n    ),\n  &:focus[data-has-no-expand='false']:not([disabled]):not(\n      [data-is-active='true']\n    ) {\n    background-color: ${({ theme }) => theme.colors.neutral.backgroundWeak};\n  }\n  &[data-has-active-children='true'][data-has-no-expand='false']:not(\n      [disabled][data-is-active='true']\n    ) {\n    background-color: ${({ theme }) =>\n      theme.colors.neutral.backgroundWeakHover};\n    ${WrapText} {\n      color: ${({ theme }) => theme.colors.neutral.textWeakHover};\n    }\n\n    ${PinnedButton} {\n      opacity: 1;\n    }\n\n    &[data-is-pinnable='true'] {\n      ${StyledBadge} {\n        opacity: 0;\n      }\n    }\n  }\n\n  &[data-has-no-expand='false']:not([disabled]) {\n    &:hover,\n    &:focus,\n    &:active {\n      ${PinnedButton}, ${GrabIcon} {\n        opacity: 1;\n      }\n\n      ${StyledBadge} {\n        opacity: 0;\n      }\n    }\n  }\n\n  &:hover[data-has-children='false'][data-is-active='false']:not([disabled]) {\n    ${WrapText} {\n      color: ${({ theme }) => theme.colors.neutral.textWeakHover};\n    }\n  }\n\n  &:active[data-has-no-expand='false']:not([disabled]):not(\n      [data-is-active='true']\n    ) {\n    background-color: ${({ theme }) => theme.colors.neutral.backgroundHover};\n  }\n\n  &[data-is-active='true'],\n  &:hover[data-has-active='true'] {\n    background-color: ${({ theme }) => theme.colors.primary.background};\n\n    &:hover {\n      background-color: ${({ theme }) => theme.colors.primary.backgroundHover};\n    }\n  }\n\n  &[disabled] {\n    cursor: not-allowed;\n    background-color: unset;\n\n    ${WrapText} {\n      color: ${({ theme }) => theme.colors.neutral.textWeakDisabled};\n    }\n  }\n\n  &[data-animation='collapse'] {\n    animation: ${shrinkHeight} ${ANIMATION_DURATION}ms ease-in-out;\n    ${WrapText}, ${AnimatedIcon}, ${StyledBadge} {\n      animation: ${fadeIn} ${ANIMATION_DURATION}ms ease-in-out reverse;\n    }\n  }\n\n  &[data-animation='expand'] {\n    animation: ${shrinkHeight} ${ANIMATION_DURATION}ms ease-in-out reverse;\n    ${WrapText}, ${AnimatedIcon}, ${StyledBadge} {\n      animation: ${fadeIn} ${ANIMATION_DURATION}ms ease-in-out;\n    }\n\n    ${StyledStack} {\n      display: none;\n    }\n  }\n`\n\nconst MenuStack = styled(Stack)`\n  padding: ${({ theme }) => `0 ${theme.space['2']}`};\n  margin-top: ${({ theme }) => theme.space['0.25']};\n`\n\nconst ContainerCategoryIcon = styled(Stack)`\n  min-width: 20px;\n`\n\ntype ItemType = 'default' | 'pinned' | 'pinnedGroup'\n\ntype ItemProps = {\n  children?: ReactNode\n  /**\n   * Sets a category icon on the left of the item\n   */\n  categoryIcon?: ComponentProps<typeof CategoryIcon>['name']\n  categoryIconVariant?: ComponentProps<typeof CategoryIcon>['variant']\n  /**\n   * The label of the item that will be shown.\n   * It is also used as the key for pinning.\n   */\n  label: string\n  /**\n   * It should be a unique id and will be used for pin/unpin feature.\n   */\n  id: string\n  /**\n   * Text shown under the label with a lighter color and smaller font size\n   */\n  subLabel?: string\n  /**\n   * Badge is added on the right of the item. It is hidden on hover if pinned\n   * feature is enabled\n   */\n  badgeText?: string\n  /**\n   * Defined the sentiment of the badge according to Badge component from\n   * `@ultraviolet/ui`\n   */\n  badgeSentiment?: ComponentProps<typeof Badge>['sentiment']\n  href?: string\n  /**\n   * This function will be triggered on click of the item. If the item is expandable\n   * toggle will be passed with it.\n   */\n  onClick?: (toggle?: true | false) => void\n  onPinUnpinClick?: (event: MouseEvent<HTMLDivElement>) => void\n  /**\n   * This prop is used to control if the item is expanded or collapsed\n   */\n  toggle?: boolean\n  /**\n   * Set this to true if your current page is this item.\n   */\n  active?: boolean\n  /**\n   * If you want to remove pin button on your item use this prop\n   */\n  noPinButton?: boolean\n  /**\n   * You don't need to use this prop it's used internally to control the type of the item\n   */\n  type?: ItemType\n  /**\n   * You don't need to use this prop it's used internally to control if the item has a parent\n   */\n  hasParents?: boolean\n  /**\n   * You don't need to use this prop it's used internally for pinned item to be reorganized with drag and drop\n   */\n  index?: number\n  /**\n   * When the item has href it becomes a link if not it is a button.\n   * When using an external routing tool you might need to remove both of them and use\n   * a non focusable element. This option allows you to choose the tag of the\n   * item.\n   */\n  as?: keyof JSX.IntrinsicElements\n  /**\n   * Use this prop if you want to remove the expand behavior when the item\n   * has sub items.\n   */\n  noExpand?: boolean\n  disabled?: boolean\n}\n\nexport const Item = ({\n  children,\n  categoryIcon,\n  categoryIconVariant,\n  label,\n  subLabel,\n  badgeText,\n  badgeSentiment,\n  href,\n  onClick,\n  onPinUnpinClick,\n  toggle,\n  active,\n  noPinButton,\n  type = 'default',\n  hasParents,\n  as,\n  disabled,\n  noExpand = false,\n  index,\n  id,\n}: ItemProps) => {\n  const context = useNavigation()\n\n  if (!context) {\n    throw new Error(\n      'Navigation.Item can only be used inside a NavigationProvider.',\n    )\n  }\n\n  const {\n    expanded,\n    locales,\n    pinnedFeature,\n    pinItem,\n    unpinItem,\n    pinnedItems,\n    pinLimit,\n    animation,\n    registerItem,\n  } = context\n\n  useEffect(\n    () => {\n      if (type !== 'pinnedGroup') {\n        registerItem({ [id]: { label, active, onClick } })\n      }\n    },\n    // eslint-disable-next-line react-hooks/exhaustive-deps\n    [active, id, label, registerItem],\n  )\n\n  const [internalToggle, setToggle] = useState(toggle !== false)\n\n  const triggerToggle = useCallback(\n    (value: boolean) => {\n      setToggle(value)\n      onClick?.(internalToggle)\n    },\n    [internalToggle, onClick],\n  )\n\n  useEffect(() => {\n    if (animation === 'collapse') {\n      setToggle(false)\n    }\n\n    if (animation === 'expand') {\n      setTimeout(() => {\n        setToggle(toggle ?? true)\n      }, 1)\n    }\n  }, [animation, toggle])\n\n  const PaddedStack = noExpand || type === 'pinnedGroup' ? Stack : PaddingStack\n\n  const hasHrefAndNoChildren = href && !children\n  const hasPinnedFeatureAndNoChildren =\n    pinnedFeature && !children && !noPinButton\n  const isItemPinned = pinnedItems.includes(id)\n  const shouldShowPinnedButton = useMemo(() => {\n    if (href || disabled) return false\n\n    if (hasPinnedFeatureAndNoChildren && type !== 'default') {\n      return true\n    }\n\n    if (hasPinnedFeatureAndNoChildren) {\n      return true\n    }\n\n    return false\n  }, [disabled, hasPinnedFeatureAndNoChildren, href, type])\n\n  const hasActiveChildren = useMemo(() => {\n    if (!children) return false\n\n    return (\n      Children.map(children, child =>\n        isValidElement<ItemProps>(child) ? child.props?.active : false,\n      ) as boolean[]\n    ).includes(true)\n  }, [children])\n\n  const containerTag = useMemo(() => {\n    if (as) {\n      return as\n    }\n\n    if (hasHrefAndNoChildren) {\n      return 'a'\n    }\n\n    if (noExpand) {\n      return 'div'\n    }\n\n    return 'button'\n  }, [as, hasHrefAndNoChildren, noExpand])\n\n  const Container = StyledContainer.withComponent(containerTag)\n\n  const ariaExpanded = useMemo(() => {\n    if (hasHrefAndNoChildren && internalToggle) {\n      return true\n    }\n\n    if (hasHrefAndNoChildren && !internalToggle) {\n      return false\n    }\n\n    return undefined\n  }, [hasHrefAndNoChildren, internalToggle])\n\n  const isPinDisabled = pinnedItems.length >= pinLimit\n  const pinTooltipLocale = useMemo(() => {\n    if (isPinDisabled) {\n      return locales['navigation.pin.limit']\n    }\n\n    if (isItemPinned) {\n      return locales['navigation.unpin.tooltip']\n    }\n\n    return locales['navigation.pin.tooltip']\n  }, [isItemPinned, isPinDisabled, locales])\n\n  const onDragStartTrigger = (event: DragEvent<HTMLDivElement>) => {\n    event.dataTransfer.setData('text/plain', JSON.stringify({ label, index }))\n    // eslint-disable-next-line no-param-reassign\n    event.currentTarget.style.opacity = '0.5'\n  }\n\n  const onDragStopTrigger = (event: DragEvent<HTMLDivElement>) => {\n    // eslint-disable-next-line no-param-reassign\n    event.currentTarget.style.opacity = '1'\n  }\n\n  // This content is when the navigation is expanded\n  if (expanded || (!expanded && animation === 'expand')) {\n    const renderChildren = Children.map(children, child =>\n      isValidElement<ItemProps>(child)\n        ? cloneElement(child, {\n            hasParents: true,\n          })\n        : child,\n    )\n\n    return (\n      <>\n        <Container\n          gap={1}\n          direction=\"row\"\n          alignItems=\"center\"\n          justifyContent=\"space-between\"\n          data-has-sub-label={!!subLabel}\n          onClick={() => {\n            if (children) {\n              return triggerToggle(!internalToggle)\n            }\n\n            return onClick?.()\n          }}\n          aria-expanded={ariaExpanded}\n          href={href}\n          target={href ? '_blank' : undefined}\n          data-is-pinnable={shouldShowPinnedButton}\n          data-is-active={active}\n          data-animation={animation}\n          data-has-children={!!children}\n          data-has-active-children={hasActiveChildren}\n          data-has-no-expand={noExpand}\n          disabled={disabled}\n          draggable={type === 'pinned' && expanded}\n          onDragStart={(event: DragEvent<HTMLDivElement>) =>\n            expanded ? onDragStartTrigger(event) : undefined\n          }\n          onDragEnd={(event: DragEvent<HTMLDivElement>) =>\n            expanded ? onDragStopTrigger(event) : undefined\n          }\n          id={id}\n        >\n          <Stack\n            direction=\"row\"\n            gap={1}\n            alignItems=\"center\"\n            justifyContent=\"center\"\n          >\n            {categoryIcon ? (\n              <ContainerCategoryIcon\n                alignItems=\"center\"\n                justifyContent=\"center\"\n              >\n                <CategoryIcon\n                  name={categoryIcon}\n                  variant={active ? 'primary' : categoryIconVariant}\n                  disabled={disabled}\n                />\n              </ContainerCategoryIcon>\n            ) : null}\n            {type === 'pinned' && expanded ? (\n              <GrabIcon\n                name=\"drag-vertical\"\n                sentiment=\"neutral\"\n                prominence=\"weak\"\n                size=\"small\"\n                disabled={disabled}\n              />\n            ) : null}\n            <Stack>\n              <WrapText\n                as=\"span\"\n                variant=\"bodySmallStrong\"\n                sentiment={active ? 'primary' : 'neutral'}\n                prominence={\n                  (categoryIcon || !hasParents) && !active\n                    ? 'strong'\n                    : 'default'\n                }\n                animation={animation}\n                disabled={disabled}\n              >\n                {label}\n              </WrapText>\n              {subLabel ? (\n                <WrapText\n                  as=\"span\"\n                  variant=\"caption\"\n                  sentiment=\"neutral\"\n                  prominence=\"weak\"\n                  animation={animation}\n                  disabled={disabled}\n                  subLabel\n                >\n                  {subLabel}\n                </WrapText>\n              ) : null}\n            </Stack>\n          </Stack>\n          <Stack direction=\"row\" alignItems=\"center\" gap={href ? 1 : undefined}>\n            {badgeText || hasPinnedFeatureAndNoChildren ? (\n              <>\n                {badgeText ? (\n                  <StyledBadge\n                    sentiment={badgeSentiment}\n                    size=\"small\"\n                    prominence=\"strong\"\n                    disabled={disabled}\n                  >\n                    {badgeText}\n                  </StyledBadge>\n                ) : null}\n                {shouldShowPinnedButton ? (\n                  <Tooltip\n                    text={\n                      isItemPinned\n                        ? locales['navigation.unpin.tooltip']\n                        : pinTooltipLocale\n                    }\n                    placement=\"right\"\n                  >\n                    <RelativeDiv>\n                      <PinnedButton\n                        role=\"button\"\n                        size=\"xsmall\"\n                        variant=\"ghost\"\n                        sentiment={active ? 'primary' : 'neutral'}\n                        onClick={(event: MouseEvent<HTMLDivElement>) => {\n                          event.preventDefault()\n                          event.stopPropagation() // This is to avoid click spread to the parent and change the routing\n                          if (isItemPinned) {\n                            unpinItem(id)\n                          } else {\n                            pinItem(id)\n                          }\n                          onPinUnpinClick?.(event)\n                        }}\n                        disabled={isItemPinned ? false : isPinDisabled}\n                      >\n                        <StyledIcon\n                          size=\"large\"\n                          name={isItemPinned ? 'unpin' : 'pin'}\n                          variant={isItemPinned ? 'filled' : 'outlined'}\n                          disabled={isItemPinned ? false : isPinDisabled}\n                          sentiment={active ? 'primary' : 'neutral'}\n                          active={active}\n                        />\n                      </PinnedButton>\n                    </RelativeDiv>\n                  </Tooltip>\n                ) : null}\n              </>\n            ) : null}\n            {hasHrefAndNoChildren ? (\n              <AnimatedIcon\n                name=\"open-in-new\"\n                sentiment=\"neutral\"\n                prominence=\"default\"\n                disabled={disabled}\n              />\n            ) : null}\n            {children ? (\n              <Stack gap={1} direction=\"row\" alignItems=\"center\">\n                {!animation && !noExpand ? (\n                  <AnimatedIcon\n                    name={internalToggle ? 'arrow-down' : 'arrow-right'}\n                    sentiment=\"neutral\"\n                    prominence=\"weak\"\n                  />\n                ) : null}\n              </Stack>\n            ) : null}\n          </Stack>\n        </Container>\n        {children ? (\n          <>\n            {!noExpand ? (\n              <Expandable\n                opened={internalToggle}\n                animationDuration={\n                  animation ? ANIMATION_DURATION / 2 : undefined\n                }\n              >\n                <PaddedStack>{renderChildren}</PaddedStack>\n              </Expandable>\n            ) : (\n              <PaddedStack>{renderChildren}</PaddedStack>\n            )}\n          </>\n        ) : null}\n      </>\n    )\n  }\n\n  // This content is the menu of the navigation when collapsed\n  if (categoryIcon || (Children.count(children) > 0 && !hasParents)) {\n    return (\n      <MenuStack gap={1} alignItems=\"start\" justifyContent=\"start\">\n        {Children.count(children) > 0 ? (\n          <StyledMenu\n            triggerMethod=\"hover\"\n            dynamicDomRendering={false} // As we parse the children we don't need dynamic rendering\n            disclosure={\n              <Button\n                sentiment=\"neutral\"\n                variant={hasActiveChildren ? 'filled' : 'ghost'}\n                size=\"small\"\n                icon={!categoryIcon ? 'dots-horizontal' : undefined}\n              >\n                {categoryIcon ? (\n                  <Stack\n                    direction=\"row\"\n                    gap={1}\n                    alignItems=\"center\"\n                    justifyContent=\"center\"\n                  >\n                    <CategoryIcon\n                      name={categoryIcon}\n                      variant={active ? 'primary' : categoryIconVariant}\n                    />\n                  </Stack>\n                ) : null}\n              </Button>\n            }\n            placement=\"right\"\n          >\n            {Children.map(children, child =>\n              isValidElement<ItemProps>(child)\n                ? cloneElement(child, {\n                    hasParents: true,\n                  })\n                : child,\n            )}\n          </StyledMenu>\n        ) : (\n          <Tooltip text={label} placement=\"right\" tabIndex={-1}>\n            <Button\n              sentiment=\"neutral\"\n              variant={active ? 'filled' : 'ghost'}\n              size=\"small\"\n              onClick={() => onClick?.()}\n            >\n              <Stack\n                direction=\"row\"\n                gap={1}\n                alignItems=\"center\"\n                justifyContent=\"center\"\n              >\n                <CategoryIcon\n                  name={categoryIcon ?? 'console'}\n                  variant={active ? 'primary' : categoryIconVariant}\n                />\n              </Stack>\n            </Button>\n          </Tooltip>\n        )}\n      </MenuStack>\n    )\n  }\n\n  // This content is what is inside a menu item the navigation is collapsed\n  if (hasParents) {\n    return (\n      <StyledMenuItem\n        href={href}\n        onClick={() => {\n          onClick?.()\n        }}\n        borderless\n        active={active}\n        disabled={disabled}\n        sentiment={active ? 'primary' : 'neutral'}\n        isPinnable={shouldShowPinnedButton}\n      >\n        <Stack\n          gap={1}\n          direction=\"row\"\n          alignItems=\"center\"\n          justifyContent=\"space-between\"\n          flex={1}\n          width=\"100%\"\n        >\n          <WrapText as=\"span\" variant=\"bodySmall\">\n            {label}\n          </WrapText>\n          <Stack direction=\"row\">\n            {badgeText ? (\n              <StyledBadge\n                sentiment={badgeSentiment}\n                size=\"small\"\n                prominence=\"strong\"\n                disabled={disabled}\n              >\n                {badgeText}\n              </StyledBadge>\n            ) : null}\n            {hasHrefAndNoChildren ? (\n              <AnimatedIcon\n                name=\"open-in-new\"\n                sentiment=\"neutral\"\n                prominence=\"weak\"\n                disabled={disabled}\n              />\n            ) : null}\n            {shouldShowPinnedButton ? (\n              <Tooltip\n                text={\n                  isItemPinned\n                    ? locales['navigation.unpin.tooltip']\n                    : pinTooltipLocale\n                }\n                placement=\"right\"\n              >\n                <RelativeDiv>\n                  <PinnedButton\n                    role=\"button\"\n                    size=\"xsmall\"\n                    variant=\"ghost\"\n                    sentiment={active ? 'primary' : 'neutral'}\n                    onClick={(event: MouseEvent<HTMLDivElement>) => {\n                      event.preventDefault()\n                      event.stopPropagation() // This is to avoid click spread to the parent and change the routing\n                      if (isItemPinned) {\n                        unpinItem(id)\n                      } else {\n                        pinItem(id)\n                      }\n                      onPinUnpinClick?.(event)\n                    }}\n                    disabled={isItemPinned ? false : isPinDisabled}\n                  >\n                    <StyledIcon\n                      size=\"large\"\n                      name={isItemPinned ? 'unpin' : 'pin'}\n                      variant={isItemPinned ? 'filled' : 'outlined'}\n                      disabled={isItemPinned ? false : isPinDisabled}\n                      sentiment={active ? 'primary' : 'neutral'}\n                      active={active}\n                    />\n                  </PinnedButton>\n                </RelativeDiv>\n              </Tooltip>\n            ) : null}\n          </Stack>\n        </Stack>\n      </StyledMenuItem>\n    )\n  }\n\n  // This content is for when navigation is collapsed and we show an icon of link\n  if (!hasParents && href) {\n    return (\n      <Tooltip text={label} placement=\"right\">\n        <MenuStack gap={1} alignItems=\"start\" justifyContent=\"start\">\n          <Container\n            gap={1}\n            alignItems=\"center\"\n            justifyContent=\"center\"\n            href={href}\n            target=\"_blank\"\n          >\n            <AnimatedIcon\n              name=\"open-in-new\"\n              sentiment=\"neutral\"\n              prominence=\"weak\"\n            />\n          </Container>\n        </MenuStack>\n      </Tooltip>\n    )\n  }\n\n  return null\n}\n"]} */"));
141
+ const StyledStack = /* @__PURE__ */ _styled(Stack, process.env.NODE_ENV === "production" ? {
142
+ target: "e134hokc3"
143
+ } : {
144
+ target: "e134hokc3",
145
+ label: "StyledStack"
146
+ })(process.env.NODE_ENV === "production" ? {
147
+ name: "13feash",
148
+ styles: "padding-left:28px"
149
+ } : {
150
+ name: "13feash",
151
+ styles: "padding-left:28px",
152
+ map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["/home/runner/work/ultraviolet/ultraviolet/packages/plus/src/components/Navigation/components/Item.tsx"],"names":[],"mappings":"AAsIiC","file":"/home/runner/work/ultraviolet/ultraviolet/packages/plus/src/components/Navigation/components/Item.tsx","sourcesContent":["import { css } from '@emotion/react'\nimport styled from '@emotion/styled'\nimport { CategoryIcon, Icon } from '@ultraviolet/icons'\nimport {\n  Badge,\n  Button,\n  Expandable,\n  MenuV2,\n  Stack,\n  Text,\n  Tooltip,\n  fadeIn,\n} from '@ultraviolet/ui'\nimport type {\n  ComponentProps,\n  DragEvent,\n  JSX,\n  MouseEvent,\n  ReactNode,\n} from 'react'\nimport {\n  Children,\n  cloneElement,\n  isValidElement,\n  useCallback,\n  useEffect,\n  useMemo,\n  useState,\n} from 'react'\nimport { useNavigation } from '../NavigationProvider'\nimport { ANIMATION_DURATION, shrinkHeight } from '../constants'\n\nconst RelativeDiv = styled.div`\n  position: relative;\n`\n\nconst StyledIcon = styled(Icon, {\n  shouldForwardProp: prop => !['active'].includes(prop),\n})<{ active?: boolean }>`\n  position: absolute;\n  top: 0;\n  bottom: 0;\n  margin: auto 0;\n  padding: ${({ theme }) => theme.space['0.25']};\n  border-radius: ${({ theme }) => theme.radii.default};\n  &:hover {\n    background: ${({ theme }) => theme.colors.neutral.backgroundWeakHover};\n\n    ${({ active, theme }) => (active ? `background: ${theme.colors.primary.backgroundHover};` : null)}\n    }\n  }\n`\n\nconst NeutralButtonLink = css`\n  color: inherit;\n  text-decoration: none;\n  background-color: inherit;\n  border: none;\n  text-align: left;\n`\n\n// Pin button when the navigation is expanded\nconst LocalExpandButton = styled(Button)`\n  opacity: 0;\n  right: 0;\n  position: absolute;\n  left: -24px;\n  top: 0;\n  bottom: 0;\n  margin: auto;\n\n  &:hover,\n  &:focus,\n  &:active {\n    opacity: 1;\n  }\n`\n\nconst PinnedButton = LocalExpandButton.withComponent('div')\n\nconst GrabIcon = styled(Icon)`\n  opacity: 0;\n  margin: 0 ${({ theme }) => theme.space['0.25']};\n  cursor: grab;\n`\n\nconst StyledBadge = styled(Badge)``\n\nconst StyledMenuItem = styled(MenuV2.Item, {\n  shouldForwardProp: prop => !['isPinnable'].includes(prop),\n})<{\n  isPinnable?: boolean\n}>`\n  text-align: left;\n\n  &:hover,\n  &:focus,\n  &:active {\n    ${PinnedButton} {\n      opacity: 1;\n    }\n\n    ${StyledBadge} {\n      opacity: ${({ isPinnable }) => (isPinnable ? 0 : 1)};\n    }\n  }\n`\n\nconst StyledMenu = styled(MenuV2)`\n  width: 180px;\n`\n\nconst PaddingStack = styled(Stack)`\n  padding-left: 28px; // This value needs to be hardcoded because of the category icon size\n`\n\nconst AnimatedIcon = styled(Icon)``\n\nconst WrapText = styled(Text, {\n  shouldForwardProp: prop =>\n    !['animation', 'subLabel', 'textProminence'].includes(prop),\n})<{\n  animation?: 'collapse' | 'expand' | boolean\n  subLabel?: boolean\n}>`\n  overflow-wrap: ${({ animation }) => (animation ? 'normal' : 'anywhere')};\n  white-space: ${({ animation }) => (animation ? 'nowrap' : 'normal')};\n  overflow: hidden;\n  display: -webkit-box;\n  -webkit-box-orient: vertical;\n  -webkit-line-clamp: 2;\n  white-space: pre-wrap;\n`\n\nconst StyledStack = styled(Stack)`\n  padding-left: 28px; // This value needs to be hardcoded because of the category icon size\n`\n\nconst StyledContainer = styled(Stack)`\n  ${NeutralButtonLink};\n  border-radius: ${({ theme }) => theme.radii.default};\n\n  &[data-has-no-expand='false'] {\n    cursor: pointer;\n  }\n  margin-top: ${({ theme }) => theme.space['0.25']};\n  padding: ${({ theme }) =>\n    `calc(${theme.space['0.25']} + ${theme.space['0.5']}) ${theme.space['1']}`};\n\n  &[data-has-sub-label='true'] {\n    padding: ${({ theme }) => `${theme.space['0.5']} ${theme.space['1']}`};\n  }\n\n  width: 100%;\n\n  &:hover[data-has-no-expand='false']:not([disabled]):not(\n      [data-is-active='true']\n    ),\n  &:focus[data-has-no-expand='false']:not([disabled]):not(\n      [data-is-active='true']\n    ) {\n    background-color: ${({ theme }) => theme.colors.neutral.backgroundWeak};\n  }\n  &[data-has-active-children='true'][data-has-no-expand='false']:not(\n      [disabled][data-is-active='true']\n    ) {\n    background-color: ${({ theme }) =>\n      theme.colors.neutral.backgroundWeakHover};\n    ${WrapText} {\n      color: ${({ theme }) => theme.colors.neutral.textWeakHover};\n    }\n\n    ${PinnedButton} {\n      opacity: 1;\n    }\n\n    &[data-is-pinnable='true'] {\n      ${StyledBadge} {\n        opacity: 0;\n      }\n    }\n  }\n\n  &[data-has-no-expand='false']:not([disabled]) {\n    &:hover,\n    &:focus,\n    &:active {\n      ${PinnedButton}, ${GrabIcon} {\n        opacity: 1;\n      }\n\n      ${StyledBadge} {\n        opacity: 0;\n      }\n    }\n  }\n\n  &:hover[data-has-children='false'][data-is-active='false']:not([disabled]) {\n    ${WrapText} {\n      color: ${({ theme }) => theme.colors.neutral.textWeakHover};\n    }\n  }\n\n  &:active[data-has-no-expand='false']:not([disabled]):not(\n      [data-is-active='true']\n    ) {\n    background-color: ${({ theme }) => theme.colors.neutral.backgroundHover};\n  }\n\n  &[data-is-active='true'],\n  &:hover[data-has-active='true'] {\n    background-color: ${({ theme }) => theme.colors.primary.background};\n\n    &:hover {\n      background-color: ${({ theme }) => theme.colors.primary.backgroundHover};\n    }\n  }\n\n  &[disabled] {\n    cursor: not-allowed;\n    background-color: unset;\n\n    ${WrapText} {\n      color: ${({ theme }) => theme.colors.neutral.textWeakDisabled};\n    }\n  }\n\n  &[data-animation='collapse'] {\n    animation: ${shrinkHeight} ${ANIMATION_DURATION}ms ease-in-out;\n    ${WrapText}, ${AnimatedIcon}, ${StyledBadge} {\n      animation: ${fadeIn} ${ANIMATION_DURATION}ms ease-in-out reverse;\n    }\n  }\n\n  &[data-animation='expand'] {\n    animation: ${shrinkHeight} ${ANIMATION_DURATION}ms ease-in-out reverse;\n    ${WrapText}, ${AnimatedIcon}, ${StyledBadge} {\n      animation: ${fadeIn} ${ANIMATION_DURATION}ms ease-in-out;\n    }\n\n    ${StyledStack} {\n      display: none;\n    }\n  }\n`\n\nconst MenuStack = styled(Stack)`\n  padding: ${({ theme }) => `0 ${theme.space['2']}`};\n  margin-top: ${({ theme }) => theme.space['0.25']};\n`\n\nconst ContainerCategoryIcon = styled(Stack)`\n  min-width: 20px;\n`\n\ntype ItemType = 'default' | 'pinned' | 'pinnedGroup'\n\ntype ItemProps = {\n  children?: ReactNode\n  /**\n   * Sets a category icon on the left of the item\n   */\n  categoryIcon?: ComponentProps<typeof CategoryIcon>['name']\n  categoryIconVariant?: ComponentProps<typeof CategoryIcon>['variant']\n  /**\n   * The label of the item that will be shown.\n   * It is also used as the key for pinning.\n   */\n  label: string\n  /**\n   * It should be a unique id and will be used for pin/unpin feature.\n   */\n  id: string\n  /**\n   * Text shown under the label with a lighter color and smaller font size\n   */\n  subLabel?: string\n  /**\n   * Badge is added on the right of the item. It is hidden on hover if pinned\n   * feature is enabled\n   */\n  badgeText?: string\n  /**\n   * Defined the sentiment of the badge according to Badge component from\n   * `@ultraviolet/ui`\n   */\n  badgeSentiment?: ComponentProps<typeof Badge>['sentiment']\n  href?: string\n  /**\n   * This function will be triggered on click of the item. If the item is expandable\n   * toggle will be passed with it.\n   */\n  onClick?: (toggle?: true | false) => void\n  onPinUnpinClick?: (event: MouseEvent<HTMLDivElement>) => void\n  /**\n   * This prop is used to control if the item is expanded or collapsed\n   */\n  toggle?: boolean\n  /**\n   * Set this to true if your current page is this item.\n   */\n  active?: boolean\n  /**\n   * If you want to remove pin button on your item use this prop\n   */\n  noPinButton?: boolean\n  /**\n   * You don't need to use this prop it's used internally to control the type of the item\n   */\n  type?: ItemType\n  /**\n   * You don't need to use this prop it's used internally to control if the item has a parent\n   */\n  hasParents?: boolean\n  /**\n   * You don't need to use this prop it's used internally for pinned item to be reorganized with drag and drop\n   */\n  index?: number\n  /**\n   * When the item has href it becomes a link if not it is a button.\n   * When using an external routing tool you might need to remove both of them and use\n   * a non focusable element. This option allows you to choose the tag of the\n   * item.\n   */\n  as?: keyof JSX.IntrinsicElements\n  /**\n   * Use this prop if you want to remove the expand behavior when the item\n   * has sub items.\n   */\n  noExpand?: boolean\n  disabled?: boolean\n}\n\nexport const Item = ({\n  children,\n  categoryIcon,\n  categoryIconVariant,\n  label,\n  subLabel,\n  badgeText,\n  badgeSentiment,\n  href,\n  onClick,\n  onPinUnpinClick,\n  toggle,\n  active,\n  noPinButton,\n  type = 'default',\n  hasParents,\n  as,\n  disabled,\n  noExpand = false,\n  index,\n  id,\n}: ItemProps) => {\n  const context = useNavigation()\n\n  if (!context) {\n    throw new Error(\n      'Navigation.Item can only be used inside a NavigationProvider.',\n    )\n  }\n\n  const {\n    expanded,\n    locales,\n    pinnedFeature,\n    pinItem,\n    unpinItem,\n    pinnedItems,\n    pinLimit,\n    animation,\n    registerItem,\n  } = context\n\n  useEffect(\n    () => {\n      if (type !== 'pinnedGroup') {\n        registerItem({ [id]: { label, active, onClick } })\n      }\n    },\n    // eslint-disable-next-line react-hooks/exhaustive-deps\n    [active, id, label, registerItem],\n  )\n\n  const [internalToggle, setToggle] = useState(toggle !== false)\n\n  const triggerToggle = useCallback(\n    (value: boolean) => {\n      setToggle(value)\n      onClick?.(internalToggle)\n    },\n    [internalToggle, onClick],\n  )\n\n  useEffect(() => {\n    if (animation === 'collapse') {\n      setToggle(false)\n    }\n\n    if (animation === 'expand') {\n      setTimeout(() => {\n        setToggle(toggle ?? true)\n      }, 1)\n    }\n  }, [animation, toggle])\n\n  const PaddedStack = noExpand || type === 'pinnedGroup' ? Stack : PaddingStack\n\n  const hasHrefAndNoChildren = href && !children\n  const hasPinnedFeatureAndNoChildren =\n    pinnedFeature && !children && !noPinButton\n  const isItemPinned = pinnedItems.includes(id)\n  const shouldShowPinnedButton = useMemo(() => {\n    if (href || disabled) return false\n\n    if (hasPinnedFeatureAndNoChildren && type !== 'default') {\n      return true\n    }\n\n    if (hasPinnedFeatureAndNoChildren) {\n      return true\n    }\n\n    return false\n  }, [disabled, hasPinnedFeatureAndNoChildren, href, type])\n\n  const hasActiveChildren = useMemo(() => {\n    if (!children) return false\n\n    return (\n      Children.map(children, child =>\n        isValidElement<ItemProps>(child) ? child.props?.active : false,\n      ) as boolean[]\n    ).includes(true)\n  }, [children])\n\n  const containerTag = useMemo(() => {\n    if (as) {\n      return as\n    }\n\n    if (hasHrefAndNoChildren) {\n      return 'a'\n    }\n\n    if (noExpand) {\n      return 'div'\n    }\n\n    return 'button'\n  }, [as, hasHrefAndNoChildren, noExpand])\n\n  const Container = StyledContainer.withComponent(containerTag)\n\n  const ariaExpanded = useMemo(() => {\n    if (hasHrefAndNoChildren && internalToggle) {\n      return true\n    }\n\n    if (hasHrefAndNoChildren && !internalToggle) {\n      return false\n    }\n\n    return undefined\n  }, [hasHrefAndNoChildren, internalToggle])\n\n  const isPinDisabled = pinnedItems.length >= pinLimit\n  const pinTooltipLocale = useMemo(() => {\n    if (isPinDisabled) {\n      return locales['navigation.pin.limit']\n    }\n\n    if (isItemPinned) {\n      return locales['navigation.unpin.tooltip']\n    }\n\n    return locales['navigation.pin.tooltip']\n  }, [isItemPinned, isPinDisabled, locales])\n\n  const onDragStartTrigger = (event: DragEvent<HTMLDivElement>) => {\n    event.dataTransfer.setData('text/plain', JSON.stringify({ label, index }))\n    // eslint-disable-next-line no-param-reassign\n    event.currentTarget.style.opacity = '0.5'\n  }\n\n  const onDragStopTrigger = (event: DragEvent<HTMLDivElement>) => {\n    // eslint-disable-next-line no-param-reassign\n    event.currentTarget.style.opacity = '1'\n  }\n\n  // This content is when the navigation is expanded\n  if (expanded || (!expanded && animation === 'expand')) {\n    const renderChildren = Children.map(children, child =>\n      isValidElement<ItemProps>(child)\n        ? cloneElement(child, {\n            hasParents: true,\n          })\n        : child,\n    )\n\n    return (\n      <>\n        <Container\n          gap={1}\n          direction=\"row\"\n          alignItems=\"center\"\n          justifyContent=\"space-between\"\n          data-has-sub-label={!!subLabel}\n          onClick={() => {\n            if (children) {\n              return triggerToggle(!internalToggle)\n            }\n\n            return onClick?.()\n          }}\n          aria-expanded={ariaExpanded}\n          href={href}\n          target={href ? '_blank' : undefined}\n          data-is-pinnable={shouldShowPinnedButton}\n          data-is-active={active}\n          data-animation={animation}\n          data-has-children={!!children}\n          data-has-active-children={hasActiveChildren}\n          data-has-no-expand={noExpand}\n          disabled={disabled}\n          draggable={type === 'pinned' && expanded}\n          onDragStart={(event: DragEvent<HTMLDivElement>) =>\n            expanded ? onDragStartTrigger(event) : undefined\n          }\n          onDragEnd={(event: DragEvent<HTMLDivElement>) =>\n            expanded ? onDragStopTrigger(event) : undefined\n          }\n          id={id}\n        >\n          <Stack\n            direction=\"row\"\n            gap={1}\n            alignItems=\"center\"\n            justifyContent=\"center\"\n          >\n            {categoryIcon ? (\n              <ContainerCategoryIcon\n                alignItems=\"center\"\n                justifyContent=\"center\"\n              >\n                <CategoryIcon\n                  name={categoryIcon}\n                  variant={active ? 'primary' : categoryIconVariant}\n                  disabled={disabled}\n                />\n              </ContainerCategoryIcon>\n            ) : null}\n            {type === 'pinned' && expanded ? (\n              <GrabIcon\n                name=\"drag-vertical\"\n                sentiment=\"neutral\"\n                prominence=\"weak\"\n                size=\"small\"\n                disabled={disabled}\n              />\n            ) : null}\n            <Stack>\n              <WrapText\n                as=\"span\"\n                variant=\"bodySmallStrong\"\n                sentiment={active ? 'primary' : 'neutral'}\n                prominence={\n                  (categoryIcon || !hasParents) && !active\n                    ? 'strong'\n                    : 'default'\n                }\n                animation={animation}\n                disabled={disabled}\n              >\n                {label}\n              </WrapText>\n              {subLabel ? (\n                <WrapText\n                  as=\"span\"\n                  variant=\"caption\"\n                  sentiment=\"neutral\"\n                  prominence=\"weak\"\n                  animation={animation}\n                  disabled={disabled}\n                  subLabel\n                >\n                  {subLabel}\n                </WrapText>\n              ) : null}\n            </Stack>\n          </Stack>\n          <Stack direction=\"row\" alignItems=\"center\" gap={href ? 1 : undefined}>\n            {badgeText || hasPinnedFeatureAndNoChildren ? (\n              <>\n                {badgeText ? (\n                  <StyledBadge\n                    sentiment={badgeSentiment}\n                    size=\"small\"\n                    prominence=\"strong\"\n                    disabled={disabled}\n                  >\n                    {badgeText}\n                  </StyledBadge>\n                ) : null}\n                {shouldShowPinnedButton ? (\n                  <Tooltip\n                    text={\n                      isItemPinned\n                        ? locales['navigation.unpin.tooltip']\n                        : pinTooltipLocale\n                    }\n                    placement=\"right\"\n                  >\n                    <RelativeDiv>\n                      <PinnedButton\n                        role=\"button\"\n                        size=\"xsmall\"\n                        variant=\"ghost\"\n                        sentiment={active ? 'primary' : 'neutral'}\n                        onClick={(event: MouseEvent<HTMLDivElement>) => {\n                          event.preventDefault()\n                          event.stopPropagation() // This is to avoid click spread to the parent and change the routing\n                          if (isItemPinned) {\n                            unpinItem(id)\n                          } else {\n                            pinItem(id)\n                          }\n                          onPinUnpinClick?.(event)\n                        }}\n                        disabled={isItemPinned ? false : isPinDisabled}\n                      >\n                        <StyledIcon\n                          size=\"large\"\n                          name={isItemPinned ? 'unpin' : 'pin'}\n                          variant={isItemPinned ? 'filled' : 'outlined'}\n                          disabled={isItemPinned ? false : isPinDisabled}\n                          sentiment={active ? 'primary' : 'neutral'}\n                          active={active}\n                        />\n                      </PinnedButton>\n                    </RelativeDiv>\n                  </Tooltip>\n                ) : null}\n              </>\n            ) : null}\n            {hasHrefAndNoChildren ? (\n              <AnimatedIcon\n                name=\"open-in-new\"\n                sentiment=\"neutral\"\n                prominence=\"default\"\n                disabled={disabled}\n              />\n            ) : null}\n            {children ? (\n              <Stack gap={1} direction=\"row\" alignItems=\"center\">\n                {!animation && !noExpand ? (\n                  <AnimatedIcon\n                    name={internalToggle ? 'arrow-down' : 'arrow-right'}\n                    sentiment=\"neutral\"\n                    prominence=\"weak\"\n                  />\n                ) : null}\n              </Stack>\n            ) : null}\n          </Stack>\n        </Container>\n        {children ? (\n          <>\n            {!noExpand ? (\n              <Expandable\n                opened={internalToggle}\n                animationDuration={\n                  animation ? ANIMATION_DURATION / 2 : undefined\n                }\n              >\n                <PaddedStack>{renderChildren}</PaddedStack>\n              </Expandable>\n            ) : (\n              <PaddedStack>{renderChildren}</PaddedStack>\n            )}\n          </>\n        ) : null}\n      </>\n    )\n  }\n\n  // This content is the menu of the navigation when collapsed\n  if (categoryIcon || (Children.count(children) > 0 && !hasParents)) {\n    return (\n      <MenuStack gap={1} alignItems=\"start\" justifyContent=\"start\">\n        {Children.count(children) > 0 ? (\n          <StyledMenu\n            triggerMethod=\"hover\"\n            dynamicDomRendering={false} // As we parse the children we don't need dynamic rendering\n            disclosure={\n              <Button\n                sentiment=\"neutral\"\n                variant={hasActiveChildren ? 'filled' : 'ghost'}\n                size=\"small\"\n                icon={!categoryIcon ? 'dots-horizontal' : undefined}\n              >\n                {categoryIcon ? (\n                  <Stack\n                    direction=\"row\"\n                    gap={1}\n                    alignItems=\"center\"\n                    justifyContent=\"center\"\n                  >\n                    <CategoryIcon\n                      name={categoryIcon}\n                      variant={active ? 'primary' : categoryIconVariant}\n                    />\n                  </Stack>\n                ) : null}\n              </Button>\n            }\n            placement=\"right\"\n          >\n            {Children.map(children, child =>\n              isValidElement<ItemProps>(child)\n                ? cloneElement(child, {\n                    hasParents: true,\n                  })\n                : child,\n            )}\n          </StyledMenu>\n        ) : (\n          <Tooltip text={label} placement=\"right\" tabIndex={-1}>\n            <Button\n              sentiment=\"neutral\"\n              variant={active ? 'filled' : 'ghost'}\n              size=\"small\"\n              onClick={() => onClick?.()}\n            >\n              <Stack\n                direction=\"row\"\n                gap={1}\n                alignItems=\"center\"\n                justifyContent=\"center\"\n              >\n                <CategoryIcon\n                  name={categoryIcon ?? 'console'}\n                  variant={active ? 'primary' : categoryIconVariant}\n                />\n              </Stack>\n            </Button>\n          </Tooltip>\n        )}\n      </MenuStack>\n    )\n  }\n\n  // This content is what is inside a menu item the navigation is collapsed\n  if (hasParents) {\n    return (\n      <StyledMenuItem\n        href={href}\n        onClick={() => {\n          onClick?.()\n        }}\n        borderless\n        active={active}\n        disabled={disabled}\n        sentiment={active ? 'primary' : 'neutral'}\n        isPinnable={shouldShowPinnedButton}\n      >\n        <Stack\n          gap={1}\n          direction=\"row\"\n          alignItems=\"center\"\n          justifyContent=\"space-between\"\n          flex={1}\n          width=\"100%\"\n        >\n          <WrapText as=\"span\" variant=\"bodySmall\">\n            {label}\n          </WrapText>\n          <Stack direction=\"row\">\n            {badgeText ? (\n              <StyledBadge\n                sentiment={badgeSentiment}\n                size=\"small\"\n                prominence=\"strong\"\n                disabled={disabled}\n              >\n                {badgeText}\n              </StyledBadge>\n            ) : null}\n            {hasHrefAndNoChildren ? (\n              <AnimatedIcon\n                name=\"open-in-new\"\n                sentiment=\"neutral\"\n                prominence=\"weak\"\n                disabled={disabled}\n              />\n            ) : null}\n            {shouldShowPinnedButton ? (\n              <Tooltip\n                text={\n                  isItemPinned\n                    ? locales['navigation.unpin.tooltip']\n                    : pinTooltipLocale\n                }\n                placement=\"right\"\n              >\n                <RelativeDiv>\n                  <PinnedButton\n                    role=\"button\"\n                    size=\"xsmall\"\n                    variant=\"ghost\"\n                    sentiment={active ? 'primary' : 'neutral'}\n                    onClick={(event: MouseEvent<HTMLDivElement>) => {\n                      event.preventDefault()\n                      event.stopPropagation() // This is to avoid click spread to the parent and change the routing\n                      if (isItemPinned) {\n                        unpinItem(id)\n                      } else {\n                        pinItem(id)\n                      }\n                      onPinUnpinClick?.(event)\n                    }}\n                    disabled={isItemPinned ? false : isPinDisabled}\n                  >\n                    <StyledIcon\n                      size=\"large\"\n                      name={isItemPinned ? 'unpin' : 'pin'}\n                      variant={isItemPinned ? 'filled' : 'outlined'}\n                      disabled={isItemPinned ? false : isPinDisabled}\n                      sentiment={active ? 'primary' : 'neutral'}\n                      active={active}\n                    />\n                  </PinnedButton>\n                </RelativeDiv>\n              </Tooltip>\n            ) : null}\n          </Stack>\n        </Stack>\n      </StyledMenuItem>\n    )\n  }\n\n  // This content is for when navigation is collapsed and we show an icon of link\n  if (!hasParents && href) {\n    return (\n      <Tooltip text={label} placement=\"right\">\n        <MenuStack gap={1} alignItems=\"start\" justifyContent=\"start\">\n          <Container\n            gap={1}\n            alignItems=\"center\"\n            justifyContent=\"center\"\n            href={href}\n            target=\"_blank\"\n          >\n            <AnimatedIcon\n              name=\"open-in-new\"\n              sentiment=\"neutral\"\n              prominence=\"weak\"\n            />\n          </Container>\n        </MenuStack>\n      </Tooltip>\n    )\n  }\n\n  return null\n}\n"]} */",
153
+ toString: _EMOTION_STRINGIFIED_CSS_ERROR__
154
+ });
155
+ const StyledContainer = /* @__PURE__ */ _styled(Stack, process.env.NODE_ENV === "production" ? {
156
+ target: "e134hokc2"
157
+ } : {
158
+ target: "e134hokc2",
159
+ label: "StyledContainer"
160
+ })(NeutralButtonLink, ";border-radius:", ({
161
+ theme
162
+ }) => theme.radii.default, ";&[data-has-no-expand='false']{cursor:pointer;}margin-top:", ({
163
+ theme
164
+ }) => theme.space["0.25"], ";padding:", ({
165
+ theme
166
+ }) => `calc(${theme.space["0.25"]} + ${theme.space["0.5"]}) ${theme.space["1"]}`, ";&[data-has-sub-label='true']{padding:", ({
167
+ theme
168
+ }) => `${theme.space["0.5"]} ${theme.space["1"]}`, ";}width:100%;&:hover[data-has-no-expand='false']:not([disabled]):not(\n [data-is-active='true']\n ),&:focus[data-has-no-expand='false']:not([disabled]):not(\n [data-is-active='true']\n ){background-color:", ({
169
+ theme
170
+ }) => theme.colors.neutral.backgroundWeak, ";}&[data-has-active-children='true'][data-has-no-expand='false']:not(\n [disabled][data-is-active='true']\n ){background-color:", ({
171
+ theme
172
+ }) => theme.colors.neutral.backgroundWeakHover, ";", WrapText, "{color:", ({
173
+ theme
174
+ }) => theme.colors.neutral.textWeakHover, ";}", PinnedButton, "{opacity:1;}&[data-is-pinnable='true']{", StyledBadge, "{opacity:0;}}}&[data-has-no-expand='false']:not([disabled]){&:hover,&:focus,&:active{", PinnedButton, ",", GrabIcon, "{opacity:1;}", StyledBadge, "{opacity:0;}}}&:hover[data-has-children='false'][data-is-active='false']:not([disabled]){", WrapText, "{color:", ({
175
+ theme
176
+ }) => theme.colors.neutral.textWeakHover, ";}}&:active[data-has-no-expand='false']:not([disabled]):not(\n [data-is-active='true']\n ){background-color:", ({
177
+ theme
178
+ }) => theme.colors.neutral.backgroundHover, ";}&[data-is-active='true'],&:hover[data-has-active='true']{background-color:", ({
179
+ theme
180
+ }) => theme.colors.primary.background, ";&:hover{background-color:", ({
181
+ theme
182
+ }) => theme.colors.primary.backgroundHover, ";}}&[disabled]{cursor:not-allowed;background-color:unset;", WrapText, "{color:", ({
183
+ theme
184
+ }) => theme.colors.neutral.textWeakDisabled, ";}}&[data-animation='collapse']{animation:", shrinkHeight, " ", ANIMATION_DURATION, "ms ease-in-out;", WrapText, ",", AnimatedIcon, ",", StyledBadge, "{animation:", fadeIn, " ", ANIMATION_DURATION, "ms ease-in-out reverse;}}&[data-animation='expand']{animation:", shrinkHeight, " ", ANIMATION_DURATION, "ms ease-in-out reverse;", WrapText, ",", AnimatedIcon, ",", StyledBadge, "{animation:", fadeIn, " ", ANIMATION_DURATION, "ms ease-in-out;}", StyledStack, "{display:none;}}" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["/home/runner/work/ultraviolet/ultraviolet/packages/plus/src/components/Navigation/components/Item.tsx"],"names":[],"mappings":"AA0IqC","file":"/home/runner/work/ultraviolet/ultraviolet/packages/plus/src/components/Navigation/components/Item.tsx","sourcesContent":["import { css } from '@emotion/react'\nimport styled from '@emotion/styled'\nimport { CategoryIcon, Icon } from '@ultraviolet/icons'\nimport {\n  Badge,\n  Button,\n  Expandable,\n  MenuV2,\n  Stack,\n  Text,\n  Tooltip,\n  fadeIn,\n} from '@ultraviolet/ui'\nimport type {\n  ComponentProps,\n  DragEvent,\n  JSX,\n  MouseEvent,\n  ReactNode,\n} from 'react'\nimport {\n  Children,\n  cloneElement,\n  isValidElement,\n  useCallback,\n  useEffect,\n  useMemo,\n  useState,\n} from 'react'\nimport { useNavigation } from '../NavigationProvider'\nimport { ANIMATION_DURATION, shrinkHeight } from '../constants'\n\nconst RelativeDiv = styled.div`\n  position: relative;\n`\n\nconst StyledIcon = styled(Icon, {\n  shouldForwardProp: prop => !['active'].includes(prop),\n})<{ active?: boolean }>`\n  position: absolute;\n  top: 0;\n  bottom: 0;\n  margin: auto 0;\n  padding: ${({ theme }) => theme.space['0.25']};\n  border-radius: ${({ theme }) => theme.radii.default};\n  &:hover {\n    background: ${({ theme }) => theme.colors.neutral.backgroundWeakHover};\n\n    ${({ active, theme }) => (active ? `background: ${theme.colors.primary.backgroundHover};` : null)}\n    }\n  }\n`\n\nconst NeutralButtonLink = css`\n  color: inherit;\n  text-decoration: none;\n  background-color: inherit;\n  border: none;\n  text-align: left;\n`\n\n// Pin button when the navigation is expanded\nconst LocalExpandButton = styled(Button)`\n  opacity: 0;\n  right: 0;\n  position: absolute;\n  left: -24px;\n  top: 0;\n  bottom: 0;\n  margin: auto;\n\n  &:hover,\n  &:focus,\n  &:active {\n    opacity: 1;\n  }\n`\n\nconst PinnedButton = LocalExpandButton.withComponent('div')\n\nconst GrabIcon = styled(Icon)`\n  opacity: 0;\n  margin: 0 ${({ theme }) => theme.space['0.25']};\n  cursor: grab;\n`\n\nconst StyledBadge = styled(Badge)``\n\nconst StyledMenuItem = styled(MenuV2.Item, {\n  shouldForwardProp: prop => !['isPinnable'].includes(prop),\n})<{\n  isPinnable?: boolean\n}>`\n  text-align: left;\n\n  &:hover,\n  &:focus,\n  &:active {\n    ${PinnedButton} {\n      opacity: 1;\n    }\n\n    ${StyledBadge} {\n      opacity: ${({ isPinnable }) => (isPinnable ? 0 : 1)};\n    }\n  }\n`\n\nconst StyledMenu = styled(MenuV2)`\n  width: 180px;\n`\n\nconst PaddingStack = styled(Stack)`\n  padding-left: 28px; // This value needs to be hardcoded because of the category icon size\n`\n\nconst AnimatedIcon = styled(Icon)``\n\nconst WrapText = styled(Text, {\n  shouldForwardProp: prop =>\n    !['animation', 'subLabel', 'textProminence'].includes(prop),\n})<{\n  animation?: 'collapse' | 'expand' | boolean\n  subLabel?: boolean\n}>`\n  overflow-wrap: ${({ animation }) => (animation ? 'normal' : 'anywhere')};\n  white-space: ${({ animation }) => (animation ? 'nowrap' : 'normal')};\n  overflow: hidden;\n  display: -webkit-box;\n  -webkit-box-orient: vertical;\n  -webkit-line-clamp: 2;\n  white-space: pre-wrap;\n`\n\nconst StyledStack = styled(Stack)`\n  padding-left: 28px; // This value needs to be hardcoded because of the category icon size\n`\n\nconst StyledContainer = styled(Stack)`\n  ${NeutralButtonLink};\n  border-radius: ${({ theme }) => theme.radii.default};\n\n  &[data-has-no-expand='false'] {\n    cursor: pointer;\n  }\n  margin-top: ${({ theme }) => theme.space['0.25']};\n  padding: ${({ theme }) =>\n    `calc(${theme.space['0.25']} + ${theme.space['0.5']}) ${theme.space['1']}`};\n\n  &[data-has-sub-label='true'] {\n    padding: ${({ theme }) => `${theme.space['0.5']} ${theme.space['1']}`};\n  }\n\n  width: 100%;\n\n  &:hover[data-has-no-expand='false']:not([disabled]):not(\n      [data-is-active='true']\n    ),\n  &:focus[data-has-no-expand='false']:not([disabled]):not(\n      [data-is-active='true']\n    ) {\n    background-color: ${({ theme }) => theme.colors.neutral.backgroundWeak};\n  }\n  &[data-has-active-children='true'][data-has-no-expand='false']:not(\n      [disabled][data-is-active='true']\n    ) {\n    background-color: ${({ theme }) =>\n      theme.colors.neutral.backgroundWeakHover};\n    ${WrapText} {\n      color: ${({ theme }) => theme.colors.neutral.textWeakHover};\n    }\n\n    ${PinnedButton} {\n      opacity: 1;\n    }\n\n    &[data-is-pinnable='true'] {\n      ${StyledBadge} {\n        opacity: 0;\n      }\n    }\n  }\n\n  &[data-has-no-expand='false']:not([disabled]) {\n    &:hover,\n    &:focus,\n    &:active {\n      ${PinnedButton}, ${GrabIcon} {\n        opacity: 1;\n      }\n\n      ${StyledBadge} {\n        opacity: 0;\n      }\n    }\n  }\n\n  &:hover[data-has-children='false'][data-is-active='false']:not([disabled]) {\n    ${WrapText} {\n      color: ${({ theme }) => theme.colors.neutral.textWeakHover};\n    }\n  }\n\n  &:active[data-has-no-expand='false']:not([disabled]):not(\n      [data-is-active='true']\n    ) {\n    background-color: ${({ theme }) => theme.colors.neutral.backgroundHover};\n  }\n\n  &[data-is-active='true'],\n  &:hover[data-has-active='true'] {\n    background-color: ${({ theme }) => theme.colors.primary.background};\n\n    &:hover {\n      background-color: ${({ theme }) => theme.colors.primary.backgroundHover};\n    }\n  }\n\n  &[disabled] {\n    cursor: not-allowed;\n    background-color: unset;\n\n    ${WrapText} {\n      color: ${({ theme }) => theme.colors.neutral.textWeakDisabled};\n    }\n  }\n\n  &[data-animation='collapse'] {\n    animation: ${shrinkHeight} ${ANIMATION_DURATION}ms ease-in-out;\n    ${WrapText}, ${AnimatedIcon}, ${StyledBadge} {\n      animation: ${fadeIn} ${ANIMATION_DURATION}ms ease-in-out reverse;\n    }\n  }\n\n  &[data-animation='expand'] {\n    animation: ${shrinkHeight} ${ANIMATION_DURATION}ms ease-in-out reverse;\n    ${WrapText}, ${AnimatedIcon}, ${StyledBadge} {\n      animation: ${fadeIn} ${ANIMATION_DURATION}ms ease-in-out;\n    }\n\n    ${StyledStack} {\n      display: none;\n    }\n  }\n`\n\nconst MenuStack = styled(Stack)`\n  padding: ${({ theme }) => `0 ${theme.space['2']}`};\n  margin-top: ${({ theme }) => theme.space['0.25']};\n`\n\nconst ContainerCategoryIcon = styled(Stack)`\n  min-width: 20px;\n`\n\ntype ItemType = 'default' | 'pinned' | 'pinnedGroup'\n\ntype ItemProps = {\n  children?: ReactNode\n  /**\n   * Sets a category icon on the left of the item\n   */\n  categoryIcon?: ComponentProps<typeof CategoryIcon>['name']\n  categoryIconVariant?: ComponentProps<typeof CategoryIcon>['variant']\n  /**\n   * The label of the item that will be shown.\n   * It is also used as the key for pinning.\n   */\n  label: string\n  /**\n   * It should be a unique id and will be used for pin/unpin feature.\n   */\n  id: string\n  /**\n   * Text shown under the label with a lighter color and smaller font size\n   */\n  subLabel?: string\n  /**\n   * Badge is added on the right of the item. It is hidden on hover if pinned\n   * feature is enabled\n   */\n  badgeText?: string\n  /**\n   * Defined the sentiment of the badge according to Badge component from\n   * `@ultraviolet/ui`\n   */\n  badgeSentiment?: ComponentProps<typeof Badge>['sentiment']\n  href?: string\n  /**\n   * This function will be triggered on click of the item. If the item is expandable\n   * toggle will be passed with it.\n   */\n  onClick?: (toggle?: true | false) => void\n  onPinUnpinClick?: (event: MouseEvent<HTMLDivElement>) => void\n  /**\n   * This prop is used to control if the item is expanded or collapsed\n   */\n  toggle?: boolean\n  /**\n   * Set this to true if your current page is this item.\n   */\n  active?: boolean\n  /**\n   * If you want to remove pin button on your item use this prop\n   */\n  noPinButton?: boolean\n  /**\n   * You don't need to use this prop it's used internally to control the type of the item\n   */\n  type?: ItemType\n  /**\n   * You don't need to use this prop it's used internally to control if the item has a parent\n   */\n  hasParents?: boolean\n  /**\n   * You don't need to use this prop it's used internally for pinned item to be reorganized with drag and drop\n   */\n  index?: number\n  /**\n   * When the item has href it becomes a link if not it is a button.\n   * When using an external routing tool you might need to remove both of them and use\n   * a non focusable element. This option allows you to choose the tag of the\n   * item.\n   */\n  as?: keyof JSX.IntrinsicElements\n  /**\n   * Use this prop if you want to remove the expand behavior when the item\n   * has sub items.\n   */\n  noExpand?: boolean\n  disabled?: boolean\n}\n\nexport const Item = ({\n  children,\n  categoryIcon,\n  categoryIconVariant,\n  label,\n  subLabel,\n  badgeText,\n  badgeSentiment,\n  href,\n  onClick,\n  onPinUnpinClick,\n  toggle,\n  active,\n  noPinButton,\n  type = 'default',\n  hasParents,\n  as,\n  disabled,\n  noExpand = false,\n  index,\n  id,\n}: ItemProps) => {\n  const context = useNavigation()\n\n  if (!context) {\n    throw new Error(\n      'Navigation.Item can only be used inside a NavigationProvider.',\n    )\n  }\n\n  const {\n    expanded,\n    locales,\n    pinnedFeature,\n    pinItem,\n    unpinItem,\n    pinnedItems,\n    pinLimit,\n    animation,\n    registerItem,\n  } = context\n\n  useEffect(\n    () => {\n      if (type !== 'pinnedGroup') {\n        registerItem({ [id]: { label, active, onClick } })\n      }\n    },\n    // eslint-disable-next-line react-hooks/exhaustive-deps\n    [active, id, label, registerItem],\n  )\n\n  const [internalToggle, setToggle] = useState(toggle !== false)\n\n  const triggerToggle = useCallback(\n    (value: boolean) => {\n      setToggle(value)\n      onClick?.(internalToggle)\n    },\n    [internalToggle, onClick],\n  )\n\n  useEffect(() => {\n    if (animation === 'collapse') {\n      setToggle(false)\n    }\n\n    if (animation === 'expand') {\n      setTimeout(() => {\n        setToggle(toggle ?? true)\n      }, 1)\n    }\n  }, [animation, toggle])\n\n  const PaddedStack = noExpand || type === 'pinnedGroup' ? Stack : PaddingStack\n\n  const hasHrefAndNoChildren = href && !children\n  const hasPinnedFeatureAndNoChildren =\n    pinnedFeature && !children && !noPinButton\n  const isItemPinned = pinnedItems.includes(id)\n  const shouldShowPinnedButton = useMemo(() => {\n    if (href || disabled) return false\n\n    if (hasPinnedFeatureAndNoChildren && type !== 'default') {\n      return true\n    }\n\n    if (hasPinnedFeatureAndNoChildren) {\n      return true\n    }\n\n    return false\n  }, [disabled, hasPinnedFeatureAndNoChildren, href, type])\n\n  const hasActiveChildren = useMemo(() => {\n    if (!children) return false\n\n    return (\n      Children.map(children, child =>\n        isValidElement<ItemProps>(child) ? child.props?.active : false,\n      ) as boolean[]\n    ).includes(true)\n  }, [children])\n\n  const containerTag = useMemo(() => {\n    if (as) {\n      return as\n    }\n\n    if (hasHrefAndNoChildren) {\n      return 'a'\n    }\n\n    if (noExpand) {\n      return 'div'\n    }\n\n    return 'button'\n  }, [as, hasHrefAndNoChildren, noExpand])\n\n  const Container = StyledContainer.withComponent(containerTag)\n\n  const ariaExpanded = useMemo(() => {\n    if (hasHrefAndNoChildren && internalToggle) {\n      return true\n    }\n\n    if (hasHrefAndNoChildren && !internalToggle) {\n      return false\n    }\n\n    return undefined\n  }, [hasHrefAndNoChildren, internalToggle])\n\n  const isPinDisabled = pinnedItems.length >= pinLimit\n  const pinTooltipLocale = useMemo(() => {\n    if (isPinDisabled) {\n      return locales['navigation.pin.limit']\n    }\n\n    if (isItemPinned) {\n      return locales['navigation.unpin.tooltip']\n    }\n\n    return locales['navigation.pin.tooltip']\n  }, [isItemPinned, isPinDisabled, locales])\n\n  const onDragStartTrigger = (event: DragEvent<HTMLDivElement>) => {\n    event.dataTransfer.setData('text/plain', JSON.stringify({ label, index }))\n    // eslint-disable-next-line no-param-reassign\n    event.currentTarget.style.opacity = '0.5'\n  }\n\n  const onDragStopTrigger = (event: DragEvent<HTMLDivElement>) => {\n    // eslint-disable-next-line no-param-reassign\n    event.currentTarget.style.opacity = '1'\n  }\n\n  // This content is when the navigation is expanded\n  if (expanded || (!expanded && animation === 'expand')) {\n    const renderChildren = Children.map(children, child =>\n      isValidElement<ItemProps>(child)\n        ? cloneElement(child, {\n            hasParents: true,\n          })\n        : child,\n    )\n\n    return (\n      <>\n        <Container\n          gap={1}\n          direction=\"row\"\n          alignItems=\"center\"\n          justifyContent=\"space-between\"\n          data-has-sub-label={!!subLabel}\n          onClick={() => {\n            if (children) {\n              return triggerToggle(!internalToggle)\n            }\n\n            return onClick?.()\n          }}\n          aria-expanded={ariaExpanded}\n          href={href}\n          target={href ? '_blank' : undefined}\n          data-is-pinnable={shouldShowPinnedButton}\n          data-is-active={active}\n          data-animation={animation}\n          data-has-children={!!children}\n          data-has-active-children={hasActiveChildren}\n          data-has-no-expand={noExpand}\n          disabled={disabled}\n          draggable={type === 'pinned' && expanded}\n          onDragStart={(event: DragEvent<HTMLDivElement>) =>\n            expanded ? onDragStartTrigger(event) : undefined\n          }\n          onDragEnd={(event: DragEvent<HTMLDivElement>) =>\n            expanded ? onDragStopTrigger(event) : undefined\n          }\n          id={id}\n        >\n          <Stack\n            direction=\"row\"\n            gap={1}\n            alignItems=\"center\"\n            justifyContent=\"center\"\n          >\n            {categoryIcon ? (\n              <ContainerCategoryIcon\n                alignItems=\"center\"\n                justifyContent=\"center\"\n              >\n                <CategoryIcon\n                  name={categoryIcon}\n                  variant={active ? 'primary' : categoryIconVariant}\n                  disabled={disabled}\n                />\n              </ContainerCategoryIcon>\n            ) : null}\n            {type === 'pinned' && expanded ? (\n              <GrabIcon\n                name=\"drag-vertical\"\n                sentiment=\"neutral\"\n                prominence=\"weak\"\n                size=\"small\"\n                disabled={disabled}\n              />\n            ) : null}\n            <Stack>\n              <WrapText\n                as=\"span\"\n                variant=\"bodySmallStrong\"\n                sentiment={active ? 'primary' : 'neutral'}\n                prominence={\n                  (categoryIcon || !hasParents) && !active\n                    ? 'strong'\n                    : 'default'\n                }\n                animation={animation}\n                disabled={disabled}\n              >\n                {label}\n              </WrapText>\n              {subLabel ? (\n                <WrapText\n                  as=\"span\"\n                  variant=\"caption\"\n                  sentiment=\"neutral\"\n                  prominence=\"weak\"\n                  animation={animation}\n                  disabled={disabled}\n                  subLabel\n                >\n                  {subLabel}\n                </WrapText>\n              ) : null}\n            </Stack>\n          </Stack>\n          <Stack direction=\"row\" alignItems=\"center\" gap={href ? 1 : undefined}>\n            {badgeText || hasPinnedFeatureAndNoChildren ? (\n              <>\n                {badgeText ? (\n                  <StyledBadge\n                    sentiment={badgeSentiment}\n                    size=\"small\"\n                    prominence=\"strong\"\n                    disabled={disabled}\n                  >\n                    {badgeText}\n                  </StyledBadge>\n                ) : null}\n                {shouldShowPinnedButton ? (\n                  <Tooltip\n                    text={\n                      isItemPinned\n                        ? locales['navigation.unpin.tooltip']\n                        : pinTooltipLocale\n                    }\n                    placement=\"right\"\n                  >\n                    <RelativeDiv>\n                      <PinnedButton\n                        role=\"button\"\n                        size=\"xsmall\"\n                        variant=\"ghost\"\n                        sentiment={active ? 'primary' : 'neutral'}\n                        onClick={(event: MouseEvent<HTMLDivElement>) => {\n                          event.preventDefault()\n                          event.stopPropagation() // This is to avoid click spread to the parent and change the routing\n                          if (isItemPinned) {\n                            unpinItem(id)\n                          } else {\n                            pinItem(id)\n                          }\n                          onPinUnpinClick?.(event)\n                        }}\n                        disabled={isItemPinned ? false : isPinDisabled}\n                      >\n                        <StyledIcon\n                          size=\"large\"\n                          name={isItemPinned ? 'unpin' : 'pin'}\n                          variant={isItemPinned ? 'filled' : 'outlined'}\n                          disabled={isItemPinned ? false : isPinDisabled}\n                          sentiment={active ? 'primary' : 'neutral'}\n                          active={active}\n                        />\n                      </PinnedButton>\n                    </RelativeDiv>\n                  </Tooltip>\n                ) : null}\n              </>\n            ) : null}\n            {hasHrefAndNoChildren ? (\n              <AnimatedIcon\n                name=\"open-in-new\"\n                sentiment=\"neutral\"\n                prominence=\"default\"\n                disabled={disabled}\n              />\n            ) : null}\n            {children ? (\n              <Stack gap={1} direction=\"row\" alignItems=\"center\">\n                {!animation && !noExpand ? (\n                  <AnimatedIcon\n                    name={internalToggle ? 'arrow-down' : 'arrow-right'}\n                    sentiment=\"neutral\"\n                    prominence=\"weak\"\n                  />\n                ) : null}\n              </Stack>\n            ) : null}\n          </Stack>\n        </Container>\n        {children ? (\n          <>\n            {!noExpand ? (\n              <Expandable\n                opened={internalToggle}\n                animationDuration={\n                  animation ? ANIMATION_DURATION / 2 : undefined\n                }\n              >\n                <PaddedStack>{renderChildren}</PaddedStack>\n              </Expandable>\n            ) : (\n              <PaddedStack>{renderChildren}</PaddedStack>\n            )}\n          </>\n        ) : null}\n      </>\n    )\n  }\n\n  // This content is the menu of the navigation when collapsed\n  if (categoryIcon || (Children.count(children) > 0 && !hasParents)) {\n    return (\n      <MenuStack gap={1} alignItems=\"start\" justifyContent=\"start\">\n        {Children.count(children) > 0 ? (\n          <StyledMenu\n            triggerMethod=\"hover\"\n            dynamicDomRendering={false} // As we parse the children we don't need dynamic rendering\n            disclosure={\n              <Button\n                sentiment=\"neutral\"\n                variant={hasActiveChildren ? 'filled' : 'ghost'}\n                size=\"small\"\n                icon={!categoryIcon ? 'dots-horizontal' : undefined}\n              >\n                {categoryIcon ? (\n                  <Stack\n                    direction=\"row\"\n                    gap={1}\n                    alignItems=\"center\"\n                    justifyContent=\"center\"\n                  >\n                    <CategoryIcon\n                      name={categoryIcon}\n                      variant={active ? 'primary' : categoryIconVariant}\n                    />\n                  </Stack>\n                ) : null}\n              </Button>\n            }\n            placement=\"right\"\n          >\n            {Children.map(children, child =>\n              isValidElement<ItemProps>(child)\n                ? cloneElement(child, {\n                    hasParents: true,\n                  })\n                : child,\n            )}\n          </StyledMenu>\n        ) : (\n          <Tooltip text={label} placement=\"right\" tabIndex={-1}>\n            <Button\n              sentiment=\"neutral\"\n              variant={active ? 'filled' : 'ghost'}\n              size=\"small\"\n              onClick={() => onClick?.()}\n            >\n              <Stack\n                direction=\"row\"\n                gap={1}\n                alignItems=\"center\"\n                justifyContent=\"center\"\n              >\n                <CategoryIcon\n                  name={categoryIcon ?? 'console'}\n                  variant={active ? 'primary' : categoryIconVariant}\n                />\n              </Stack>\n            </Button>\n          </Tooltip>\n        )}\n      </MenuStack>\n    )\n  }\n\n  // This content is what is inside a menu item the navigation is collapsed\n  if (hasParents) {\n    return (\n      <StyledMenuItem\n        href={href}\n        onClick={() => {\n          onClick?.()\n        }}\n        borderless\n        active={active}\n        disabled={disabled}\n        sentiment={active ? 'primary' : 'neutral'}\n        isPinnable={shouldShowPinnedButton}\n      >\n        <Stack\n          gap={1}\n          direction=\"row\"\n          alignItems=\"center\"\n          justifyContent=\"space-between\"\n          flex={1}\n          width=\"100%\"\n        >\n          <WrapText as=\"span\" variant=\"bodySmall\">\n            {label}\n          </WrapText>\n          <Stack direction=\"row\">\n            {badgeText ? (\n              <StyledBadge\n                sentiment={badgeSentiment}\n                size=\"small\"\n                prominence=\"strong\"\n                disabled={disabled}\n              >\n                {badgeText}\n              </StyledBadge>\n            ) : null}\n            {hasHrefAndNoChildren ? (\n              <AnimatedIcon\n                name=\"open-in-new\"\n                sentiment=\"neutral\"\n                prominence=\"weak\"\n                disabled={disabled}\n              />\n            ) : null}\n            {shouldShowPinnedButton ? (\n              <Tooltip\n                text={\n                  isItemPinned\n                    ? locales['navigation.unpin.tooltip']\n                    : pinTooltipLocale\n                }\n                placement=\"right\"\n              >\n                <RelativeDiv>\n                  <PinnedButton\n                    role=\"button\"\n                    size=\"xsmall\"\n                    variant=\"ghost\"\n                    sentiment={active ? 'primary' : 'neutral'}\n                    onClick={(event: MouseEvent<HTMLDivElement>) => {\n                      event.preventDefault()\n                      event.stopPropagation() // This is to avoid click spread to the parent and change the routing\n                      if (isItemPinned) {\n                        unpinItem(id)\n                      } else {\n                        pinItem(id)\n                      }\n                      onPinUnpinClick?.(event)\n                    }}\n                    disabled={isItemPinned ? false : isPinDisabled}\n                  >\n                    <StyledIcon\n                      size=\"large\"\n                      name={isItemPinned ? 'unpin' : 'pin'}\n                      variant={isItemPinned ? 'filled' : 'outlined'}\n                      disabled={isItemPinned ? false : isPinDisabled}\n                      sentiment={active ? 'primary' : 'neutral'}\n                      active={active}\n                    />\n                  </PinnedButton>\n                </RelativeDiv>\n              </Tooltip>\n            ) : null}\n          </Stack>\n        </Stack>\n      </StyledMenuItem>\n    )\n  }\n\n  // This content is for when navigation is collapsed and we show an icon of link\n  if (!hasParents && href) {\n    return (\n      <Tooltip text={label} placement=\"right\">\n        <MenuStack gap={1} alignItems=\"start\" justifyContent=\"start\">\n          <Container\n            gap={1}\n            alignItems=\"center\"\n            justifyContent=\"center\"\n            href={href}\n            target=\"_blank\"\n          >\n            <AnimatedIcon\n              name=\"open-in-new\"\n              sentiment=\"neutral\"\n              prominence=\"weak\"\n            />\n          </Container>\n        </MenuStack>\n      </Tooltip>\n    )\n  }\n\n  return null\n}\n"]} */"));
185
+ const MenuStack = /* @__PURE__ */ _styled(Stack, process.env.NODE_ENV === "production" ? {
186
+ target: "e134hokc1"
187
+ } : {
188
+ target: "e134hokc1",
189
+ label: "MenuStack"
190
+ })("padding:", ({
191
+ theme
192
+ }) => `0 ${theme.space["2"]}`, ";margin-top:", ({
193
+ theme
194
+ }) => theme.space["0.25"], ";" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["/home/runner/work/ultraviolet/ultraviolet/packages/plus/src/components/Navigation/components/Item.tsx"],"names":[],"mappings":"AAsP+B","file":"/home/runner/work/ultraviolet/ultraviolet/packages/plus/src/components/Navigation/components/Item.tsx","sourcesContent":["import { css } from '@emotion/react'\nimport styled from '@emotion/styled'\nimport { CategoryIcon, Icon } from '@ultraviolet/icons'\nimport {\n  Badge,\n  Button,\n  Expandable,\n  MenuV2,\n  Stack,\n  Text,\n  Tooltip,\n  fadeIn,\n} from '@ultraviolet/ui'\nimport type {\n  ComponentProps,\n  DragEvent,\n  JSX,\n  MouseEvent,\n  ReactNode,\n} from 'react'\nimport {\n  Children,\n  cloneElement,\n  isValidElement,\n  useCallback,\n  useEffect,\n  useMemo,\n  useState,\n} from 'react'\nimport { useNavigation } from '../NavigationProvider'\nimport { ANIMATION_DURATION, shrinkHeight } from '../constants'\n\nconst RelativeDiv = styled.div`\n  position: relative;\n`\n\nconst StyledIcon = styled(Icon, {\n  shouldForwardProp: prop => !['active'].includes(prop),\n})<{ active?: boolean }>`\n  position: absolute;\n  top: 0;\n  bottom: 0;\n  margin: auto 0;\n  padding: ${({ theme }) => theme.space['0.25']};\n  border-radius: ${({ theme }) => theme.radii.default};\n  &:hover {\n    background: ${({ theme }) => theme.colors.neutral.backgroundWeakHover};\n\n    ${({ active, theme }) => (active ? `background: ${theme.colors.primary.backgroundHover};` : null)}\n    }\n  }\n`\n\nconst NeutralButtonLink = css`\n  color: inherit;\n  text-decoration: none;\n  background-color: inherit;\n  border: none;\n  text-align: left;\n`\n\n// Pin button when the navigation is expanded\nconst LocalExpandButton = styled(Button)`\n  opacity: 0;\n  right: 0;\n  position: absolute;\n  left: -24px;\n  top: 0;\n  bottom: 0;\n  margin: auto;\n\n  &:hover,\n  &:focus,\n  &:active {\n    opacity: 1;\n  }\n`\n\nconst PinnedButton = LocalExpandButton.withComponent('div')\n\nconst GrabIcon = styled(Icon)`\n  opacity: 0;\n  margin: 0 ${({ theme }) => theme.space['0.25']};\n  cursor: grab;\n`\n\nconst StyledBadge = styled(Badge)``\n\nconst StyledMenuItem = styled(MenuV2.Item, {\n  shouldForwardProp: prop => !['isPinnable'].includes(prop),\n})<{\n  isPinnable?: boolean\n}>`\n  text-align: left;\n\n  &:hover,\n  &:focus,\n  &:active {\n    ${PinnedButton} {\n      opacity: 1;\n    }\n\n    ${StyledBadge} {\n      opacity: ${({ isPinnable }) => (isPinnable ? 0 : 1)};\n    }\n  }\n`\n\nconst StyledMenu = styled(MenuV2)`\n  width: 180px;\n`\n\nconst PaddingStack = styled(Stack)`\n  padding-left: 28px; // This value needs to be hardcoded because of the category icon size\n`\n\nconst AnimatedIcon = styled(Icon)``\n\nconst WrapText = styled(Text, {\n  shouldForwardProp: prop =>\n    !['animation', 'subLabel', 'textProminence'].includes(prop),\n})<{\n  animation?: 'collapse' | 'expand' | boolean\n  subLabel?: boolean\n}>`\n  overflow-wrap: ${({ animation }) => (animation ? 'normal' : 'anywhere')};\n  white-space: ${({ animation }) => (animation ? 'nowrap' : 'normal')};\n  overflow: hidden;\n  display: -webkit-box;\n  -webkit-box-orient: vertical;\n  -webkit-line-clamp: 2;\n  white-space: pre-wrap;\n`\n\nconst StyledStack = styled(Stack)`\n  padding-left: 28px; // This value needs to be hardcoded because of the category icon size\n`\n\nconst StyledContainer = styled(Stack)`\n  ${NeutralButtonLink};\n  border-radius: ${({ theme }) => theme.radii.default};\n\n  &[data-has-no-expand='false'] {\n    cursor: pointer;\n  }\n  margin-top: ${({ theme }) => theme.space['0.25']};\n  padding: ${({ theme }) =>\n    `calc(${theme.space['0.25']} + ${theme.space['0.5']}) ${theme.space['1']}`};\n\n  &[data-has-sub-label='true'] {\n    padding: ${({ theme }) => `${theme.space['0.5']} ${theme.space['1']}`};\n  }\n\n  width: 100%;\n\n  &:hover[data-has-no-expand='false']:not([disabled]):not(\n      [data-is-active='true']\n    ),\n  &:focus[data-has-no-expand='false']:not([disabled]):not(\n      [data-is-active='true']\n    ) {\n    background-color: ${({ theme }) => theme.colors.neutral.backgroundWeak};\n  }\n  &[data-has-active-children='true'][data-has-no-expand='false']:not(\n      [disabled][data-is-active='true']\n    ) {\n    background-color: ${({ theme }) =>\n      theme.colors.neutral.backgroundWeakHover};\n    ${WrapText} {\n      color: ${({ theme }) => theme.colors.neutral.textWeakHover};\n    }\n\n    ${PinnedButton} {\n      opacity: 1;\n    }\n\n    &[data-is-pinnable='true'] {\n      ${StyledBadge} {\n        opacity: 0;\n      }\n    }\n  }\n\n  &[data-has-no-expand='false']:not([disabled]) {\n    &:hover,\n    &:focus,\n    &:active {\n      ${PinnedButton}, ${GrabIcon} {\n        opacity: 1;\n      }\n\n      ${StyledBadge} {\n        opacity: 0;\n      }\n    }\n  }\n\n  &:hover[data-has-children='false'][data-is-active='false']:not([disabled]) {\n    ${WrapText} {\n      color: ${({ theme }) => theme.colors.neutral.textWeakHover};\n    }\n  }\n\n  &:active[data-has-no-expand='false']:not([disabled]):not(\n      [data-is-active='true']\n    ) {\n    background-color: ${({ theme }) => theme.colors.neutral.backgroundHover};\n  }\n\n  &[data-is-active='true'],\n  &:hover[data-has-active='true'] {\n    background-color: ${({ theme }) => theme.colors.primary.background};\n\n    &:hover {\n      background-color: ${({ theme }) => theme.colors.primary.backgroundHover};\n    }\n  }\n\n  &[disabled] {\n    cursor: not-allowed;\n    background-color: unset;\n\n    ${WrapText} {\n      color: ${({ theme }) => theme.colors.neutral.textWeakDisabled};\n    }\n  }\n\n  &[data-animation='collapse'] {\n    animation: ${shrinkHeight} ${ANIMATION_DURATION}ms ease-in-out;\n    ${WrapText}, ${AnimatedIcon}, ${StyledBadge} {\n      animation: ${fadeIn} ${ANIMATION_DURATION}ms ease-in-out reverse;\n    }\n  }\n\n  &[data-animation='expand'] {\n    animation: ${shrinkHeight} ${ANIMATION_DURATION}ms ease-in-out reverse;\n    ${WrapText}, ${AnimatedIcon}, ${StyledBadge} {\n      animation: ${fadeIn} ${ANIMATION_DURATION}ms ease-in-out;\n    }\n\n    ${StyledStack} {\n      display: none;\n    }\n  }\n`\n\nconst MenuStack = styled(Stack)`\n  padding: ${({ theme }) => `0 ${theme.space['2']}`};\n  margin-top: ${({ theme }) => theme.space['0.25']};\n`\n\nconst ContainerCategoryIcon = styled(Stack)`\n  min-width: 20px;\n`\n\ntype ItemType = 'default' | 'pinned' | 'pinnedGroup'\n\ntype ItemProps = {\n  children?: ReactNode\n  /**\n   * Sets a category icon on the left of the item\n   */\n  categoryIcon?: ComponentProps<typeof CategoryIcon>['name']\n  categoryIconVariant?: ComponentProps<typeof CategoryIcon>['variant']\n  /**\n   * The label of the item that will be shown.\n   * It is also used as the key for pinning.\n   */\n  label: string\n  /**\n   * It should be a unique id and will be used for pin/unpin feature.\n   */\n  id: string\n  /**\n   * Text shown under the label with a lighter color and smaller font size\n   */\n  subLabel?: string\n  /**\n   * Badge is added on the right of the item. It is hidden on hover if pinned\n   * feature is enabled\n   */\n  badgeText?: string\n  /**\n   * Defined the sentiment of the badge according to Badge component from\n   * `@ultraviolet/ui`\n   */\n  badgeSentiment?: ComponentProps<typeof Badge>['sentiment']\n  href?: string\n  /**\n   * This function will be triggered on click of the item. If the item is expandable\n   * toggle will be passed with it.\n   */\n  onClick?: (toggle?: true | false) => void\n  onPinUnpinClick?: (event: MouseEvent<HTMLDivElement>) => void\n  /**\n   * This prop is used to control if the item is expanded or collapsed\n   */\n  toggle?: boolean\n  /**\n   * Set this to true if your current page is this item.\n   */\n  active?: boolean\n  /**\n   * If you want to remove pin button on your item use this prop\n   */\n  noPinButton?: boolean\n  /**\n   * You don't need to use this prop it's used internally to control the type of the item\n   */\n  type?: ItemType\n  /**\n   * You don't need to use this prop it's used internally to control if the item has a parent\n   */\n  hasParents?: boolean\n  /**\n   * You don't need to use this prop it's used internally for pinned item to be reorganized with drag and drop\n   */\n  index?: number\n  /**\n   * When the item has href it becomes a link if not it is a button.\n   * When using an external routing tool you might need to remove both of them and use\n   * a non focusable element. This option allows you to choose the tag of the\n   * item.\n   */\n  as?: keyof JSX.IntrinsicElements\n  /**\n   * Use this prop if you want to remove the expand behavior when the item\n   * has sub items.\n   */\n  noExpand?: boolean\n  disabled?: boolean\n}\n\nexport const Item = ({\n  children,\n  categoryIcon,\n  categoryIconVariant,\n  label,\n  subLabel,\n  badgeText,\n  badgeSentiment,\n  href,\n  onClick,\n  onPinUnpinClick,\n  toggle,\n  active,\n  noPinButton,\n  type = 'default',\n  hasParents,\n  as,\n  disabled,\n  noExpand = false,\n  index,\n  id,\n}: ItemProps) => {\n  const context = useNavigation()\n\n  if (!context) {\n    throw new Error(\n      'Navigation.Item can only be used inside a NavigationProvider.',\n    )\n  }\n\n  const {\n    expanded,\n    locales,\n    pinnedFeature,\n    pinItem,\n    unpinItem,\n    pinnedItems,\n    pinLimit,\n    animation,\n    registerItem,\n  } = context\n\n  useEffect(\n    () => {\n      if (type !== 'pinnedGroup') {\n        registerItem({ [id]: { label, active, onClick } })\n      }\n    },\n    // eslint-disable-next-line react-hooks/exhaustive-deps\n    [active, id, label, registerItem],\n  )\n\n  const [internalToggle, setToggle] = useState(toggle !== false)\n\n  const triggerToggle = useCallback(\n    (value: boolean) => {\n      setToggle(value)\n      onClick?.(internalToggle)\n    },\n    [internalToggle, onClick],\n  )\n\n  useEffect(() => {\n    if (animation === 'collapse') {\n      setToggle(false)\n    }\n\n    if (animation === 'expand') {\n      setTimeout(() => {\n        setToggle(toggle ?? true)\n      }, 1)\n    }\n  }, [animation, toggle])\n\n  const PaddedStack = noExpand || type === 'pinnedGroup' ? Stack : PaddingStack\n\n  const hasHrefAndNoChildren = href && !children\n  const hasPinnedFeatureAndNoChildren =\n    pinnedFeature && !children && !noPinButton\n  const isItemPinned = pinnedItems.includes(id)\n  const shouldShowPinnedButton = useMemo(() => {\n    if (href || disabled) return false\n\n    if (hasPinnedFeatureAndNoChildren && type !== 'default') {\n      return true\n    }\n\n    if (hasPinnedFeatureAndNoChildren) {\n      return true\n    }\n\n    return false\n  }, [disabled, hasPinnedFeatureAndNoChildren, href, type])\n\n  const hasActiveChildren = useMemo(() => {\n    if (!children) return false\n\n    return (\n      Children.map(children, child =>\n        isValidElement<ItemProps>(child) ? child.props?.active : false,\n      ) as boolean[]\n    ).includes(true)\n  }, [children])\n\n  const containerTag = useMemo(() => {\n    if (as) {\n      return as\n    }\n\n    if (hasHrefAndNoChildren) {\n      return 'a'\n    }\n\n    if (noExpand) {\n      return 'div'\n    }\n\n    return 'button'\n  }, [as, hasHrefAndNoChildren, noExpand])\n\n  const Container = StyledContainer.withComponent(containerTag)\n\n  const ariaExpanded = useMemo(() => {\n    if (hasHrefAndNoChildren && internalToggle) {\n      return true\n    }\n\n    if (hasHrefAndNoChildren && !internalToggle) {\n      return false\n    }\n\n    return undefined\n  }, [hasHrefAndNoChildren, internalToggle])\n\n  const isPinDisabled = pinnedItems.length >= pinLimit\n  const pinTooltipLocale = useMemo(() => {\n    if (isPinDisabled) {\n      return locales['navigation.pin.limit']\n    }\n\n    if (isItemPinned) {\n      return locales['navigation.unpin.tooltip']\n    }\n\n    return locales['navigation.pin.tooltip']\n  }, [isItemPinned, isPinDisabled, locales])\n\n  const onDragStartTrigger = (event: DragEvent<HTMLDivElement>) => {\n    event.dataTransfer.setData('text/plain', JSON.stringify({ label, index }))\n    // eslint-disable-next-line no-param-reassign\n    event.currentTarget.style.opacity = '0.5'\n  }\n\n  const onDragStopTrigger = (event: DragEvent<HTMLDivElement>) => {\n    // eslint-disable-next-line no-param-reassign\n    event.currentTarget.style.opacity = '1'\n  }\n\n  // This content is when the navigation is expanded\n  if (expanded || (!expanded && animation === 'expand')) {\n    const renderChildren = Children.map(children, child =>\n      isValidElement<ItemProps>(child)\n        ? cloneElement(child, {\n            hasParents: true,\n          })\n        : child,\n    )\n\n    return (\n      <>\n        <Container\n          gap={1}\n          direction=\"row\"\n          alignItems=\"center\"\n          justifyContent=\"space-between\"\n          data-has-sub-label={!!subLabel}\n          onClick={() => {\n            if (children) {\n              return triggerToggle(!internalToggle)\n            }\n\n            return onClick?.()\n          }}\n          aria-expanded={ariaExpanded}\n          href={href}\n          target={href ? '_blank' : undefined}\n          data-is-pinnable={shouldShowPinnedButton}\n          data-is-active={active}\n          data-animation={animation}\n          data-has-children={!!children}\n          data-has-active-children={hasActiveChildren}\n          data-has-no-expand={noExpand}\n          disabled={disabled}\n          draggable={type === 'pinned' && expanded}\n          onDragStart={(event: DragEvent<HTMLDivElement>) =>\n            expanded ? onDragStartTrigger(event) : undefined\n          }\n          onDragEnd={(event: DragEvent<HTMLDivElement>) =>\n            expanded ? onDragStopTrigger(event) : undefined\n          }\n          id={id}\n        >\n          <Stack\n            direction=\"row\"\n            gap={1}\n            alignItems=\"center\"\n            justifyContent=\"center\"\n          >\n            {categoryIcon ? (\n              <ContainerCategoryIcon\n                alignItems=\"center\"\n                justifyContent=\"center\"\n              >\n                <CategoryIcon\n                  name={categoryIcon}\n                  variant={active ? 'primary' : categoryIconVariant}\n                  disabled={disabled}\n                />\n              </ContainerCategoryIcon>\n            ) : null}\n            {type === 'pinned' && expanded ? (\n              <GrabIcon\n                name=\"drag-vertical\"\n                sentiment=\"neutral\"\n                prominence=\"weak\"\n                size=\"small\"\n                disabled={disabled}\n              />\n            ) : null}\n            <Stack>\n              <WrapText\n                as=\"span\"\n                variant=\"bodySmallStrong\"\n                sentiment={active ? 'primary' : 'neutral'}\n                prominence={\n                  (categoryIcon || !hasParents) && !active\n                    ? 'strong'\n                    : 'default'\n                }\n                animation={animation}\n                disabled={disabled}\n              >\n                {label}\n              </WrapText>\n              {subLabel ? (\n                <WrapText\n                  as=\"span\"\n                  variant=\"caption\"\n                  sentiment=\"neutral\"\n                  prominence=\"weak\"\n                  animation={animation}\n                  disabled={disabled}\n                  subLabel\n                >\n                  {subLabel}\n                </WrapText>\n              ) : null}\n            </Stack>\n          </Stack>\n          <Stack direction=\"row\" alignItems=\"center\" gap={href ? 1 : undefined}>\n            {badgeText || hasPinnedFeatureAndNoChildren ? (\n              <>\n                {badgeText ? (\n                  <StyledBadge\n                    sentiment={badgeSentiment}\n                    size=\"small\"\n                    prominence=\"strong\"\n                    disabled={disabled}\n                  >\n                    {badgeText}\n                  </StyledBadge>\n                ) : null}\n                {shouldShowPinnedButton ? (\n                  <Tooltip\n                    text={\n                      isItemPinned\n                        ? locales['navigation.unpin.tooltip']\n                        : pinTooltipLocale\n                    }\n                    placement=\"right\"\n                  >\n                    <RelativeDiv>\n                      <PinnedButton\n                        role=\"button\"\n                        size=\"xsmall\"\n                        variant=\"ghost\"\n                        sentiment={active ? 'primary' : 'neutral'}\n                        onClick={(event: MouseEvent<HTMLDivElement>) => {\n                          event.preventDefault()\n                          event.stopPropagation() // This is to avoid click spread to the parent and change the routing\n                          if (isItemPinned) {\n                            unpinItem(id)\n                          } else {\n                            pinItem(id)\n                          }\n                          onPinUnpinClick?.(event)\n                        }}\n                        disabled={isItemPinned ? false : isPinDisabled}\n                      >\n                        <StyledIcon\n                          size=\"large\"\n                          name={isItemPinned ? 'unpin' : 'pin'}\n                          variant={isItemPinned ? 'filled' : 'outlined'}\n                          disabled={isItemPinned ? false : isPinDisabled}\n                          sentiment={active ? 'primary' : 'neutral'}\n                          active={active}\n                        />\n                      </PinnedButton>\n                    </RelativeDiv>\n                  </Tooltip>\n                ) : null}\n              </>\n            ) : null}\n            {hasHrefAndNoChildren ? (\n              <AnimatedIcon\n                name=\"open-in-new\"\n                sentiment=\"neutral\"\n                prominence=\"default\"\n                disabled={disabled}\n              />\n            ) : null}\n            {children ? (\n              <Stack gap={1} direction=\"row\" alignItems=\"center\">\n                {!animation && !noExpand ? (\n                  <AnimatedIcon\n                    name={internalToggle ? 'arrow-down' : 'arrow-right'}\n                    sentiment=\"neutral\"\n                    prominence=\"weak\"\n                  />\n                ) : null}\n              </Stack>\n            ) : null}\n          </Stack>\n        </Container>\n        {children ? (\n          <>\n            {!noExpand ? (\n              <Expandable\n                opened={internalToggle}\n                animationDuration={\n                  animation ? ANIMATION_DURATION / 2 : undefined\n                }\n              >\n                <PaddedStack>{renderChildren}</PaddedStack>\n              </Expandable>\n            ) : (\n              <PaddedStack>{renderChildren}</PaddedStack>\n            )}\n          </>\n        ) : null}\n      </>\n    )\n  }\n\n  // This content is the menu of the navigation when collapsed\n  if (categoryIcon || (Children.count(children) > 0 && !hasParents)) {\n    return (\n      <MenuStack gap={1} alignItems=\"start\" justifyContent=\"start\">\n        {Children.count(children) > 0 ? (\n          <StyledMenu\n            triggerMethod=\"hover\"\n            dynamicDomRendering={false} // As we parse the children we don't need dynamic rendering\n            disclosure={\n              <Button\n                sentiment=\"neutral\"\n                variant={hasActiveChildren ? 'filled' : 'ghost'}\n                size=\"small\"\n                icon={!categoryIcon ? 'dots-horizontal' : undefined}\n              >\n                {categoryIcon ? (\n                  <Stack\n                    direction=\"row\"\n                    gap={1}\n                    alignItems=\"center\"\n                    justifyContent=\"center\"\n                  >\n                    <CategoryIcon\n                      name={categoryIcon}\n                      variant={active ? 'primary' : categoryIconVariant}\n                    />\n                  </Stack>\n                ) : null}\n              </Button>\n            }\n            placement=\"right\"\n          >\n            {Children.map(children, child =>\n              isValidElement<ItemProps>(child)\n                ? cloneElement(child, {\n                    hasParents: true,\n                  })\n                : child,\n            )}\n          </StyledMenu>\n        ) : (\n          <Tooltip text={label} placement=\"right\" tabIndex={-1}>\n            <Button\n              sentiment=\"neutral\"\n              variant={active ? 'filled' : 'ghost'}\n              size=\"small\"\n              onClick={() => onClick?.()}\n            >\n              <Stack\n                direction=\"row\"\n                gap={1}\n                alignItems=\"center\"\n                justifyContent=\"center\"\n              >\n                <CategoryIcon\n                  name={categoryIcon ?? 'console'}\n                  variant={active ? 'primary' : categoryIconVariant}\n                />\n              </Stack>\n            </Button>\n          </Tooltip>\n        )}\n      </MenuStack>\n    )\n  }\n\n  // This content is what is inside a menu item the navigation is collapsed\n  if (hasParents) {\n    return (\n      <StyledMenuItem\n        href={href}\n        onClick={() => {\n          onClick?.()\n        }}\n        borderless\n        active={active}\n        disabled={disabled}\n        sentiment={active ? 'primary' : 'neutral'}\n        isPinnable={shouldShowPinnedButton}\n      >\n        <Stack\n          gap={1}\n          direction=\"row\"\n          alignItems=\"center\"\n          justifyContent=\"space-between\"\n          flex={1}\n          width=\"100%\"\n        >\n          <WrapText as=\"span\" variant=\"bodySmall\">\n            {label}\n          </WrapText>\n          <Stack direction=\"row\">\n            {badgeText ? (\n              <StyledBadge\n                sentiment={badgeSentiment}\n                size=\"small\"\n                prominence=\"strong\"\n                disabled={disabled}\n              >\n                {badgeText}\n              </StyledBadge>\n            ) : null}\n            {hasHrefAndNoChildren ? (\n              <AnimatedIcon\n                name=\"open-in-new\"\n                sentiment=\"neutral\"\n                prominence=\"weak\"\n                disabled={disabled}\n              />\n            ) : null}\n            {shouldShowPinnedButton ? (\n              <Tooltip\n                text={\n                  isItemPinned\n                    ? locales['navigation.unpin.tooltip']\n                    : pinTooltipLocale\n                }\n                placement=\"right\"\n              >\n                <RelativeDiv>\n                  <PinnedButton\n                    role=\"button\"\n                    size=\"xsmall\"\n                    variant=\"ghost\"\n                    sentiment={active ? 'primary' : 'neutral'}\n                    onClick={(event: MouseEvent<HTMLDivElement>) => {\n                      event.preventDefault()\n                      event.stopPropagation() // This is to avoid click spread to the parent and change the routing\n                      if (isItemPinned) {\n                        unpinItem(id)\n                      } else {\n                        pinItem(id)\n                      }\n                      onPinUnpinClick?.(event)\n                    }}\n                    disabled={isItemPinned ? false : isPinDisabled}\n                  >\n                    <StyledIcon\n                      size=\"large\"\n                      name={isItemPinned ? 'unpin' : 'pin'}\n                      variant={isItemPinned ? 'filled' : 'outlined'}\n                      disabled={isItemPinned ? false : isPinDisabled}\n                      sentiment={active ? 'primary' : 'neutral'}\n                      active={active}\n                    />\n                  </PinnedButton>\n                </RelativeDiv>\n              </Tooltip>\n            ) : null}\n          </Stack>\n        </Stack>\n      </StyledMenuItem>\n    )\n  }\n\n  // This content is for when navigation is collapsed and we show an icon of link\n  if (!hasParents && href) {\n    return (\n      <Tooltip text={label} placement=\"right\">\n        <MenuStack gap={1} alignItems=\"start\" justifyContent=\"start\">\n          <Container\n            gap={1}\n            alignItems=\"center\"\n            justifyContent=\"center\"\n            href={href}\n            target=\"_blank\"\n          >\n            <AnimatedIcon\n              name=\"open-in-new\"\n              sentiment=\"neutral\"\n              prominence=\"weak\"\n            />\n          </Container>\n        </MenuStack>\n      </Tooltip>\n    )\n  }\n\n  return null\n}\n"]} */"));
195
+ const ContainerCategoryIcon = /* @__PURE__ */ _styled(Stack, process.env.NODE_ENV === "production" ? {
196
+ target: "e134hokc0"
197
+ } : {
198
+ target: "e134hokc0",
199
+ label: "ContainerCategoryIcon"
200
+ })(process.env.NODE_ENV === "production" ? {
201
+ name: "d47oax",
202
+ styles: "min-width:20px"
203
+ } : {
204
+ name: "d47oax",
205
+ styles: "min-width:20px",
206
+ map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["/home/runner/work/ultraviolet/ultraviolet/packages/plus/src/components/Navigation/components/Item.tsx"],"names":[],"mappings":"AA2P2C","file":"/home/runner/work/ultraviolet/ultraviolet/packages/plus/src/components/Navigation/components/Item.tsx","sourcesContent":["import { css } from '@emotion/react'\nimport styled from '@emotion/styled'\nimport { CategoryIcon, Icon } from '@ultraviolet/icons'\nimport {\n  Badge,\n  Button,\n  Expandable,\n  MenuV2,\n  Stack,\n  Text,\n  Tooltip,\n  fadeIn,\n} from '@ultraviolet/ui'\nimport type {\n  ComponentProps,\n  DragEvent,\n  JSX,\n  MouseEvent,\n  ReactNode,\n} from 'react'\nimport {\n  Children,\n  cloneElement,\n  isValidElement,\n  useCallback,\n  useEffect,\n  useMemo,\n  useState,\n} from 'react'\nimport { useNavigation } from '../NavigationProvider'\nimport { ANIMATION_DURATION, shrinkHeight } from '../constants'\n\nconst RelativeDiv = styled.div`\n  position: relative;\n`\n\nconst StyledIcon = styled(Icon, {\n  shouldForwardProp: prop => !['active'].includes(prop),\n})<{ active?: boolean }>`\n  position: absolute;\n  top: 0;\n  bottom: 0;\n  margin: auto 0;\n  padding: ${({ theme }) => theme.space['0.25']};\n  border-radius: ${({ theme }) => theme.radii.default};\n  &:hover {\n    background: ${({ theme }) => theme.colors.neutral.backgroundWeakHover};\n\n    ${({ active, theme }) => (active ? `background: ${theme.colors.primary.backgroundHover};` : null)}\n    }\n  }\n`\n\nconst NeutralButtonLink = css`\n  color: inherit;\n  text-decoration: none;\n  background-color: inherit;\n  border: none;\n  text-align: left;\n`\n\n// Pin button when the navigation is expanded\nconst LocalExpandButton = styled(Button)`\n  opacity: 0;\n  right: 0;\n  position: absolute;\n  left: -24px;\n  top: 0;\n  bottom: 0;\n  margin: auto;\n\n  &:hover,\n  &:focus,\n  &:active {\n    opacity: 1;\n  }\n`\n\nconst PinnedButton = LocalExpandButton.withComponent('div')\n\nconst GrabIcon = styled(Icon)`\n  opacity: 0;\n  margin: 0 ${({ theme }) => theme.space['0.25']};\n  cursor: grab;\n`\n\nconst StyledBadge = styled(Badge)``\n\nconst StyledMenuItem = styled(MenuV2.Item, {\n  shouldForwardProp: prop => !['isPinnable'].includes(prop),\n})<{\n  isPinnable?: boolean\n}>`\n  text-align: left;\n\n  &:hover,\n  &:focus,\n  &:active {\n    ${PinnedButton} {\n      opacity: 1;\n    }\n\n    ${StyledBadge} {\n      opacity: ${({ isPinnable }) => (isPinnable ? 0 : 1)};\n    }\n  }\n`\n\nconst StyledMenu = styled(MenuV2)`\n  width: 180px;\n`\n\nconst PaddingStack = styled(Stack)`\n  padding-left: 28px; // This value needs to be hardcoded because of the category icon size\n`\n\nconst AnimatedIcon = styled(Icon)``\n\nconst WrapText = styled(Text, {\n  shouldForwardProp: prop =>\n    !['animation', 'subLabel', 'textProminence'].includes(prop),\n})<{\n  animation?: 'collapse' | 'expand' | boolean\n  subLabel?: boolean\n}>`\n  overflow-wrap: ${({ animation }) => (animation ? 'normal' : 'anywhere')};\n  white-space: ${({ animation }) => (animation ? 'nowrap' : 'normal')};\n  overflow: hidden;\n  display: -webkit-box;\n  -webkit-box-orient: vertical;\n  -webkit-line-clamp: 2;\n  white-space: pre-wrap;\n`\n\nconst StyledStack = styled(Stack)`\n  padding-left: 28px; // This value needs to be hardcoded because of the category icon size\n`\n\nconst StyledContainer = styled(Stack)`\n  ${NeutralButtonLink};\n  border-radius: ${({ theme }) => theme.radii.default};\n\n  &[data-has-no-expand='false'] {\n    cursor: pointer;\n  }\n  margin-top: ${({ theme }) => theme.space['0.25']};\n  padding: ${({ theme }) =>\n    `calc(${theme.space['0.25']} + ${theme.space['0.5']}) ${theme.space['1']}`};\n\n  &[data-has-sub-label='true'] {\n    padding: ${({ theme }) => `${theme.space['0.5']} ${theme.space['1']}`};\n  }\n\n  width: 100%;\n\n  &:hover[data-has-no-expand='false']:not([disabled]):not(\n      [data-is-active='true']\n    ),\n  &:focus[data-has-no-expand='false']:not([disabled]):not(\n      [data-is-active='true']\n    ) {\n    background-color: ${({ theme }) => theme.colors.neutral.backgroundWeak};\n  }\n  &[data-has-active-children='true'][data-has-no-expand='false']:not(\n      [disabled][data-is-active='true']\n    ) {\n    background-color: ${({ theme }) =>\n      theme.colors.neutral.backgroundWeakHover};\n    ${WrapText} {\n      color: ${({ theme }) => theme.colors.neutral.textWeakHover};\n    }\n\n    ${PinnedButton} {\n      opacity: 1;\n    }\n\n    &[data-is-pinnable='true'] {\n      ${StyledBadge} {\n        opacity: 0;\n      }\n    }\n  }\n\n  &[data-has-no-expand='false']:not([disabled]) {\n    &:hover,\n    &:focus,\n    &:active {\n      ${PinnedButton}, ${GrabIcon} {\n        opacity: 1;\n      }\n\n      ${StyledBadge} {\n        opacity: 0;\n      }\n    }\n  }\n\n  &:hover[data-has-children='false'][data-is-active='false']:not([disabled]) {\n    ${WrapText} {\n      color: ${({ theme }) => theme.colors.neutral.textWeakHover};\n    }\n  }\n\n  &:active[data-has-no-expand='false']:not([disabled]):not(\n      [data-is-active='true']\n    ) {\n    background-color: ${({ theme }) => theme.colors.neutral.backgroundHover};\n  }\n\n  &[data-is-active='true'],\n  &:hover[data-has-active='true'] {\n    background-color: ${({ theme }) => theme.colors.primary.background};\n\n    &:hover {\n      background-color: ${({ theme }) => theme.colors.primary.backgroundHover};\n    }\n  }\n\n  &[disabled] {\n    cursor: not-allowed;\n    background-color: unset;\n\n    ${WrapText} {\n      color: ${({ theme }) => theme.colors.neutral.textWeakDisabled};\n    }\n  }\n\n  &[data-animation='collapse'] {\n    animation: ${shrinkHeight} ${ANIMATION_DURATION}ms ease-in-out;\n    ${WrapText}, ${AnimatedIcon}, ${StyledBadge} {\n      animation: ${fadeIn} ${ANIMATION_DURATION}ms ease-in-out reverse;\n    }\n  }\n\n  &[data-animation='expand'] {\n    animation: ${shrinkHeight} ${ANIMATION_DURATION}ms ease-in-out reverse;\n    ${WrapText}, ${AnimatedIcon}, ${StyledBadge} {\n      animation: ${fadeIn} ${ANIMATION_DURATION}ms ease-in-out;\n    }\n\n    ${StyledStack} {\n      display: none;\n    }\n  }\n`\n\nconst MenuStack = styled(Stack)`\n  padding: ${({ theme }) => `0 ${theme.space['2']}`};\n  margin-top: ${({ theme }) => theme.space['0.25']};\n`\n\nconst ContainerCategoryIcon = styled(Stack)`\n  min-width: 20px;\n`\n\ntype ItemType = 'default' | 'pinned' | 'pinnedGroup'\n\ntype ItemProps = {\n  children?: ReactNode\n  /**\n   * Sets a category icon on the left of the item\n   */\n  categoryIcon?: ComponentProps<typeof CategoryIcon>['name']\n  categoryIconVariant?: ComponentProps<typeof CategoryIcon>['variant']\n  /**\n   * The label of the item that will be shown.\n   * It is also used as the key for pinning.\n   */\n  label: string\n  /**\n   * It should be a unique id and will be used for pin/unpin feature.\n   */\n  id: string\n  /**\n   * Text shown under the label with a lighter color and smaller font size\n   */\n  subLabel?: string\n  /**\n   * Badge is added on the right of the item. It is hidden on hover if pinned\n   * feature is enabled\n   */\n  badgeText?: string\n  /**\n   * Defined the sentiment of the badge according to Badge component from\n   * `@ultraviolet/ui`\n   */\n  badgeSentiment?: ComponentProps<typeof Badge>['sentiment']\n  href?: string\n  /**\n   * This function will be triggered on click of the item. If the item is expandable\n   * toggle will be passed with it.\n   */\n  onClick?: (toggle?: true | false) => void\n  onPinUnpinClick?: (event: MouseEvent<HTMLDivElement>) => void\n  /**\n   * This prop is used to control if the item is expanded or collapsed\n   */\n  toggle?: boolean\n  /**\n   * Set this to true if your current page is this item.\n   */\n  active?: boolean\n  /**\n   * If you want to remove pin button on your item use this prop\n   */\n  noPinButton?: boolean\n  /**\n   * You don't need to use this prop it's used internally to control the type of the item\n   */\n  type?: ItemType\n  /**\n   * You don't need to use this prop it's used internally to control if the item has a parent\n   */\n  hasParents?: boolean\n  /**\n   * You don't need to use this prop it's used internally for pinned item to be reorganized with drag and drop\n   */\n  index?: number\n  /**\n   * When the item has href it becomes a link if not it is a button.\n   * When using an external routing tool you might need to remove both of them and use\n   * a non focusable element. This option allows you to choose the tag of the\n   * item.\n   */\n  as?: keyof JSX.IntrinsicElements\n  /**\n   * Use this prop if you want to remove the expand behavior when the item\n   * has sub items.\n   */\n  noExpand?: boolean\n  disabled?: boolean\n}\n\nexport const Item = ({\n  children,\n  categoryIcon,\n  categoryIconVariant,\n  label,\n  subLabel,\n  badgeText,\n  badgeSentiment,\n  href,\n  onClick,\n  onPinUnpinClick,\n  toggle,\n  active,\n  noPinButton,\n  type = 'default',\n  hasParents,\n  as,\n  disabled,\n  noExpand = false,\n  index,\n  id,\n}: ItemProps) => {\n  const context = useNavigation()\n\n  if (!context) {\n    throw new Error(\n      'Navigation.Item can only be used inside a NavigationProvider.',\n    )\n  }\n\n  const {\n    expanded,\n    locales,\n    pinnedFeature,\n    pinItem,\n    unpinItem,\n    pinnedItems,\n    pinLimit,\n    animation,\n    registerItem,\n  } = context\n\n  useEffect(\n    () => {\n      if (type !== 'pinnedGroup') {\n        registerItem({ [id]: { label, active, onClick } })\n      }\n    },\n    // eslint-disable-next-line react-hooks/exhaustive-deps\n    [active, id, label, registerItem],\n  )\n\n  const [internalToggle, setToggle] = useState(toggle !== false)\n\n  const triggerToggle = useCallback(\n    (value: boolean) => {\n      setToggle(value)\n      onClick?.(internalToggle)\n    },\n    [internalToggle, onClick],\n  )\n\n  useEffect(() => {\n    if (animation === 'collapse') {\n      setToggle(false)\n    }\n\n    if (animation === 'expand') {\n      setTimeout(() => {\n        setToggle(toggle ?? true)\n      }, 1)\n    }\n  }, [animation, toggle])\n\n  const PaddedStack = noExpand || type === 'pinnedGroup' ? Stack : PaddingStack\n\n  const hasHrefAndNoChildren = href && !children\n  const hasPinnedFeatureAndNoChildren =\n    pinnedFeature && !children && !noPinButton\n  const isItemPinned = pinnedItems.includes(id)\n  const shouldShowPinnedButton = useMemo(() => {\n    if (href || disabled) return false\n\n    if (hasPinnedFeatureAndNoChildren && type !== 'default') {\n      return true\n    }\n\n    if (hasPinnedFeatureAndNoChildren) {\n      return true\n    }\n\n    return false\n  }, [disabled, hasPinnedFeatureAndNoChildren, href, type])\n\n  const hasActiveChildren = useMemo(() => {\n    if (!children) return false\n\n    return (\n      Children.map(children, child =>\n        isValidElement<ItemProps>(child) ? child.props?.active : false,\n      ) as boolean[]\n    ).includes(true)\n  }, [children])\n\n  const containerTag = useMemo(() => {\n    if (as) {\n      return as\n    }\n\n    if (hasHrefAndNoChildren) {\n      return 'a'\n    }\n\n    if (noExpand) {\n      return 'div'\n    }\n\n    return 'button'\n  }, [as, hasHrefAndNoChildren, noExpand])\n\n  const Container = StyledContainer.withComponent(containerTag)\n\n  const ariaExpanded = useMemo(() => {\n    if (hasHrefAndNoChildren && internalToggle) {\n      return true\n    }\n\n    if (hasHrefAndNoChildren && !internalToggle) {\n      return false\n    }\n\n    return undefined\n  }, [hasHrefAndNoChildren, internalToggle])\n\n  const isPinDisabled = pinnedItems.length >= pinLimit\n  const pinTooltipLocale = useMemo(() => {\n    if (isPinDisabled) {\n      return locales['navigation.pin.limit']\n    }\n\n    if (isItemPinned) {\n      return locales['navigation.unpin.tooltip']\n    }\n\n    return locales['navigation.pin.tooltip']\n  }, [isItemPinned, isPinDisabled, locales])\n\n  const onDragStartTrigger = (event: DragEvent<HTMLDivElement>) => {\n    event.dataTransfer.setData('text/plain', JSON.stringify({ label, index }))\n    // eslint-disable-next-line no-param-reassign\n    event.currentTarget.style.opacity = '0.5'\n  }\n\n  const onDragStopTrigger = (event: DragEvent<HTMLDivElement>) => {\n    // eslint-disable-next-line no-param-reassign\n    event.currentTarget.style.opacity = '1'\n  }\n\n  // This content is when the navigation is expanded\n  if (expanded || (!expanded && animation === 'expand')) {\n    const renderChildren = Children.map(children, child =>\n      isValidElement<ItemProps>(child)\n        ? cloneElement(child, {\n            hasParents: true,\n          })\n        : child,\n    )\n\n    return (\n      <>\n        <Container\n          gap={1}\n          direction=\"row\"\n          alignItems=\"center\"\n          justifyContent=\"space-between\"\n          data-has-sub-label={!!subLabel}\n          onClick={() => {\n            if (children) {\n              return triggerToggle(!internalToggle)\n            }\n\n            return onClick?.()\n          }}\n          aria-expanded={ariaExpanded}\n          href={href}\n          target={href ? '_blank' : undefined}\n          data-is-pinnable={shouldShowPinnedButton}\n          data-is-active={active}\n          data-animation={animation}\n          data-has-children={!!children}\n          data-has-active-children={hasActiveChildren}\n          data-has-no-expand={noExpand}\n          disabled={disabled}\n          draggable={type === 'pinned' && expanded}\n          onDragStart={(event: DragEvent<HTMLDivElement>) =>\n            expanded ? onDragStartTrigger(event) : undefined\n          }\n          onDragEnd={(event: DragEvent<HTMLDivElement>) =>\n            expanded ? onDragStopTrigger(event) : undefined\n          }\n          id={id}\n        >\n          <Stack\n            direction=\"row\"\n            gap={1}\n            alignItems=\"center\"\n            justifyContent=\"center\"\n          >\n            {categoryIcon ? (\n              <ContainerCategoryIcon\n                alignItems=\"center\"\n                justifyContent=\"center\"\n              >\n                <CategoryIcon\n                  name={categoryIcon}\n                  variant={active ? 'primary' : categoryIconVariant}\n                  disabled={disabled}\n                />\n              </ContainerCategoryIcon>\n            ) : null}\n            {type === 'pinned' && expanded ? (\n              <GrabIcon\n                name=\"drag-vertical\"\n                sentiment=\"neutral\"\n                prominence=\"weak\"\n                size=\"small\"\n                disabled={disabled}\n              />\n            ) : null}\n            <Stack>\n              <WrapText\n                as=\"span\"\n                variant=\"bodySmallStrong\"\n                sentiment={active ? 'primary' : 'neutral'}\n                prominence={\n                  (categoryIcon || !hasParents) && !active\n                    ? 'strong'\n                    : 'default'\n                }\n                animation={animation}\n                disabled={disabled}\n              >\n                {label}\n              </WrapText>\n              {subLabel ? (\n                <WrapText\n                  as=\"span\"\n                  variant=\"caption\"\n                  sentiment=\"neutral\"\n                  prominence=\"weak\"\n                  animation={animation}\n                  disabled={disabled}\n                  subLabel\n                >\n                  {subLabel}\n                </WrapText>\n              ) : null}\n            </Stack>\n          </Stack>\n          <Stack direction=\"row\" alignItems=\"center\" gap={href ? 1 : undefined}>\n            {badgeText || hasPinnedFeatureAndNoChildren ? (\n              <>\n                {badgeText ? (\n                  <StyledBadge\n                    sentiment={badgeSentiment}\n                    size=\"small\"\n                    prominence=\"strong\"\n                    disabled={disabled}\n                  >\n                    {badgeText}\n                  </StyledBadge>\n                ) : null}\n                {shouldShowPinnedButton ? (\n                  <Tooltip\n                    text={\n                      isItemPinned\n                        ? locales['navigation.unpin.tooltip']\n                        : pinTooltipLocale\n                    }\n                    placement=\"right\"\n                  >\n                    <RelativeDiv>\n                      <PinnedButton\n                        role=\"button\"\n                        size=\"xsmall\"\n                        variant=\"ghost\"\n                        sentiment={active ? 'primary' : 'neutral'}\n                        onClick={(event: MouseEvent<HTMLDivElement>) => {\n                          event.preventDefault()\n                          event.stopPropagation() // This is to avoid click spread to the parent and change the routing\n                          if (isItemPinned) {\n                            unpinItem(id)\n                          } else {\n                            pinItem(id)\n                          }\n                          onPinUnpinClick?.(event)\n                        }}\n                        disabled={isItemPinned ? false : isPinDisabled}\n                      >\n                        <StyledIcon\n                          size=\"large\"\n                          name={isItemPinned ? 'unpin' : 'pin'}\n                          variant={isItemPinned ? 'filled' : 'outlined'}\n                          disabled={isItemPinned ? false : isPinDisabled}\n                          sentiment={active ? 'primary' : 'neutral'}\n                          active={active}\n                        />\n                      </PinnedButton>\n                    </RelativeDiv>\n                  </Tooltip>\n                ) : null}\n              </>\n            ) : null}\n            {hasHrefAndNoChildren ? (\n              <AnimatedIcon\n                name=\"open-in-new\"\n                sentiment=\"neutral\"\n                prominence=\"default\"\n                disabled={disabled}\n              />\n            ) : null}\n            {children ? (\n              <Stack gap={1} direction=\"row\" alignItems=\"center\">\n                {!animation && !noExpand ? (\n                  <AnimatedIcon\n                    name={internalToggle ? 'arrow-down' : 'arrow-right'}\n                    sentiment=\"neutral\"\n                    prominence=\"weak\"\n                  />\n                ) : null}\n              </Stack>\n            ) : null}\n          </Stack>\n        </Container>\n        {children ? (\n          <>\n            {!noExpand ? (\n              <Expandable\n                opened={internalToggle}\n                animationDuration={\n                  animation ? ANIMATION_DURATION / 2 : undefined\n                }\n              >\n                <PaddedStack>{renderChildren}</PaddedStack>\n              </Expandable>\n            ) : (\n              <PaddedStack>{renderChildren}</PaddedStack>\n            )}\n          </>\n        ) : null}\n      </>\n    )\n  }\n\n  // This content is the menu of the navigation when collapsed\n  if (categoryIcon || (Children.count(children) > 0 && !hasParents)) {\n    return (\n      <MenuStack gap={1} alignItems=\"start\" justifyContent=\"start\">\n        {Children.count(children) > 0 ? (\n          <StyledMenu\n            triggerMethod=\"hover\"\n            dynamicDomRendering={false} // As we parse the children we don't need dynamic rendering\n            disclosure={\n              <Button\n                sentiment=\"neutral\"\n                variant={hasActiveChildren ? 'filled' : 'ghost'}\n                size=\"small\"\n                icon={!categoryIcon ? 'dots-horizontal' : undefined}\n              >\n                {categoryIcon ? (\n                  <Stack\n                    direction=\"row\"\n                    gap={1}\n                    alignItems=\"center\"\n                    justifyContent=\"center\"\n                  >\n                    <CategoryIcon\n                      name={categoryIcon}\n                      variant={active ? 'primary' : categoryIconVariant}\n                    />\n                  </Stack>\n                ) : null}\n              </Button>\n            }\n            placement=\"right\"\n          >\n            {Children.map(children, child =>\n              isValidElement<ItemProps>(child)\n                ? cloneElement(child, {\n                    hasParents: true,\n                  })\n                : child,\n            )}\n          </StyledMenu>\n        ) : (\n          <Tooltip text={label} placement=\"right\" tabIndex={-1}>\n            <Button\n              sentiment=\"neutral\"\n              variant={active ? 'filled' : 'ghost'}\n              size=\"small\"\n              onClick={() => onClick?.()}\n            >\n              <Stack\n                direction=\"row\"\n                gap={1}\n                alignItems=\"center\"\n                justifyContent=\"center\"\n              >\n                <CategoryIcon\n                  name={categoryIcon ?? 'console'}\n                  variant={active ? 'primary' : categoryIconVariant}\n                />\n              </Stack>\n            </Button>\n          </Tooltip>\n        )}\n      </MenuStack>\n    )\n  }\n\n  // This content is what is inside a menu item the navigation is collapsed\n  if (hasParents) {\n    return (\n      <StyledMenuItem\n        href={href}\n        onClick={() => {\n          onClick?.()\n        }}\n        borderless\n        active={active}\n        disabled={disabled}\n        sentiment={active ? 'primary' : 'neutral'}\n        isPinnable={shouldShowPinnedButton}\n      >\n        <Stack\n          gap={1}\n          direction=\"row\"\n          alignItems=\"center\"\n          justifyContent=\"space-between\"\n          flex={1}\n          width=\"100%\"\n        >\n          <WrapText as=\"span\" variant=\"bodySmall\">\n            {label}\n          </WrapText>\n          <Stack direction=\"row\">\n            {badgeText ? (\n              <StyledBadge\n                sentiment={badgeSentiment}\n                size=\"small\"\n                prominence=\"strong\"\n                disabled={disabled}\n              >\n                {badgeText}\n              </StyledBadge>\n            ) : null}\n            {hasHrefAndNoChildren ? (\n              <AnimatedIcon\n                name=\"open-in-new\"\n                sentiment=\"neutral\"\n                prominence=\"weak\"\n                disabled={disabled}\n              />\n            ) : null}\n            {shouldShowPinnedButton ? (\n              <Tooltip\n                text={\n                  isItemPinned\n                    ? locales['navigation.unpin.tooltip']\n                    : pinTooltipLocale\n                }\n                placement=\"right\"\n              >\n                <RelativeDiv>\n                  <PinnedButton\n                    role=\"button\"\n                    size=\"xsmall\"\n                    variant=\"ghost\"\n                    sentiment={active ? 'primary' : 'neutral'}\n                    onClick={(event: MouseEvent<HTMLDivElement>) => {\n                      event.preventDefault()\n                      event.stopPropagation() // This is to avoid click spread to the parent and change the routing\n                      if (isItemPinned) {\n                        unpinItem(id)\n                      } else {\n                        pinItem(id)\n                      }\n                      onPinUnpinClick?.(event)\n                    }}\n                    disabled={isItemPinned ? false : isPinDisabled}\n                  >\n                    <StyledIcon\n                      size=\"large\"\n                      name={isItemPinned ? 'unpin' : 'pin'}\n                      variant={isItemPinned ? 'filled' : 'outlined'}\n                      disabled={isItemPinned ? false : isPinDisabled}\n                      sentiment={active ? 'primary' : 'neutral'}\n                      active={active}\n                    />\n                  </PinnedButton>\n                </RelativeDiv>\n              </Tooltip>\n            ) : null}\n          </Stack>\n        </Stack>\n      </StyledMenuItem>\n    )\n  }\n\n  // This content is for when navigation is collapsed and we show an icon of link\n  if (!hasParents && href) {\n    return (\n      <Tooltip text={label} placement=\"right\">\n        <MenuStack gap={1} alignItems=\"start\" justifyContent=\"start\">\n          <Container\n            gap={1}\n            alignItems=\"center\"\n            justifyContent=\"center\"\n            href={href}\n            target=\"_blank\"\n          >\n            <AnimatedIcon\n              name=\"open-in-new\"\n              sentiment=\"neutral\"\n              prominence=\"weak\"\n            />\n          </Container>\n        </MenuStack>\n      </Tooltip>\n    )\n  }\n\n  return null\n}\n"]} */",
207
+ toString: _EMOTION_STRINGIFIED_CSS_ERROR__
208
+ });
207
209
  const Item = ({
208
210
  children,
209
211
  categoryIcon,
@@ -228,9 +230,7 @@ const Item = ({
228
230
  }) => {
229
231
  const context = useNavigation();
230
232
  if (!context) {
231
- throw new Error(
232
- "Navigation.Item can only be used inside a NavigationProvider."
233
- );
233
+ throw new Error("Navigation.Item can only be used inside a NavigationProvider.");
234
234
  }
235
235
  const {
236
236
  expanded,
@@ -246,20 +246,23 @@ const Item = ({
246
246
  useEffect(
247
247
  () => {
248
248
  if (type !== "pinnedGroup") {
249
- registerItem({ [id]: { label, active, onClick } });
249
+ registerItem({
250
+ [id]: {
251
+ label,
252
+ active,
253
+ onClick
254
+ }
255
+ });
250
256
  }
251
257
  },
252
258
  // eslint-disable-next-line react-hooks/exhaustive-deps
253
259
  [active, id, label, registerItem]
254
260
  );
255
261
  const [internalToggle, setToggle] = useState(toggle !== false);
256
- const triggerToggle = useCallback(
257
- (value) => {
258
- setToggle(value);
259
- onClick?.(internalToggle);
260
- },
261
- [internalToggle, onClick]
262
- );
262
+ const triggerToggle = useCallback((value) => {
263
+ setToggle(value);
264
+ onClick?.(internalToggle);
265
+ }, [internalToggle, onClick]);
263
266
  useEffect(() => {
264
267
  if (animation === "collapse") {
265
268
  setToggle(false);
@@ -288,10 +291,7 @@ const Item = ({
288
291
  const hasActiveChildren = useMemo(() => {
289
292
  if (!children)
290
293
  return false;
291
- return Children.map(
292
- children,
293
- (child) => isValidElement(child) ? child.props?.active : false
294
- ).includes(true);
294
+ return Children.map(children, (child) => isValidElement(child) ? child.props?.active : false).includes(true);
295
295
  }, [children]);
296
296
  const containerTag = useMemo(() => {
297
297
  if (as) {
@@ -305,7 +305,12 @@ const Item = ({
305
305
  }
306
306
  return "button";
307
307
  }, [as, hasHrefAndNoChildren, noExpand]);
308
- const Container = StyledContainer.withComponent(containerTag);
308
+ const Container = StyledContainer.withComponent(containerTag, process.env.NODE_ENV === "production" ? {
309
+ target: "e134hokc15"
310
+ } : {
311
+ target: "e134hokc15",
312
+ label: "Container"
313
+ });
309
314
  const ariaExpanded = useMemo(() => {
310
315
  if (hasHrefAndNoChildren && internalToggle) {
311
316
  return true;
@@ -326,192 +331,53 @@ const Item = ({
326
331
  return locales["navigation.pin.tooltip"];
327
332
  }, [isItemPinned, isPinDisabled, locales]);
328
333
  const onDragStartTrigger = (event) => {
329
- event.dataTransfer.setData("text/plain", JSON.stringify({ label, index }));
334
+ event.dataTransfer.setData("text/plain", JSON.stringify({
335
+ label,
336
+ index
337
+ }));
330
338
  event.currentTarget.style.opacity = "0.5";
331
339
  };
332
340
  const onDragStopTrigger = (event) => {
333
341
  event.currentTarget.style.opacity = "1";
334
342
  };
335
343
  if (expanded || !expanded && animation === "expand") {
336
- const renderChildren = Children.map(
337
- children,
338
- (child) => isValidElement(child) ? cloneElement(child, {
339
- hasParents: true
340
- }) : child
341
- );
344
+ const renderChildren = Children.map(children, (child) => isValidElement(child) ? cloneElement(child, {
345
+ hasParents: true
346
+ }) : child);
342
347
  return /* @__PURE__ */ jsxs(Fragment, { children: [
343
- /* @__PURE__ */ jsxs(
344
- Container,
345
- {
346
- gap: 1,
347
- direction: "row",
348
- alignItems: "center",
349
- justifyContent: "space-between",
350
- "data-has-sub-label": !!subLabel,
351
- onClick: () => {
352
- if (children) {
353
- return triggerToggle(!internalToggle);
354
- }
355
- return onClick?.();
356
- },
357
- "aria-expanded": ariaExpanded,
358
- href,
359
- target: href ? "_blank" : void 0,
360
- "data-is-pinnable": shouldShowPinnedButton,
361
- "data-is-active": active,
362
- "data-animation": animation,
363
- "data-has-children": !!children,
364
- "data-has-active-children": hasActiveChildren,
365
- "data-has-no-expand": noExpand,
366
- disabled,
367
- draggable: type === "pinned" && expanded,
368
- onDragStart: (event) => expanded ? onDragStartTrigger(event) : void 0,
369
- onDragEnd: (event) => expanded ? onDragStopTrigger(event) : void 0,
370
- id,
371
- children: [
372
- /* @__PURE__ */ jsxs(
373
- Stack,
374
- {
375
- direction: "row",
376
- gap: 1,
377
- alignItems: "center",
378
- justifyContent: "center",
379
- children: [
380
- categoryIcon ? /* @__PURE__ */ jsx(
381
- ContainerCategoryIcon,
382
- {
383
- alignItems: "center",
384
- justifyContent: "center",
385
- children: /* @__PURE__ */ jsx(
386
- CategoryIcon,
387
- {
388
- name: categoryIcon,
389
- variant: active ? "primary" : categoryIconVariant,
390
- disabled
391
- }
392
- )
393
- }
394
- ) : null,
395
- type === "pinned" && expanded ? /* @__PURE__ */ jsx(
396
- GrabIcon,
397
- {
398
- name: "drag-vertical",
399
- sentiment: "neutral",
400
- prominence: "weak",
401
- size: "small",
402
- disabled
403
- }
404
- ) : null,
405
- /* @__PURE__ */ jsxs(Stack, { children: [
406
- /* @__PURE__ */ jsx(
407
- WrapText,
408
- {
409
- as: "span",
410
- variant: "bodySmallStrong",
411
- sentiment: active ? "primary" : "neutral",
412
- prominence: (categoryIcon || !hasParents) && !active ? "strong" : "default",
413
- animation,
414
- disabled,
415
- children: label
416
- }
417
- ),
418
- subLabel ? /* @__PURE__ */ jsx(
419
- WrapText,
420
- {
421
- as: "span",
422
- variant: "caption",
423
- sentiment: "neutral",
424
- prominence: "weak",
425
- animation,
426
- disabled,
427
- subLabel: true,
428
- children: subLabel
429
- }
430
- ) : null
431
- ] })
432
- ]
433
- }
434
- ),
435
- /* @__PURE__ */ jsxs(Stack, { direction: "row", alignItems: "center", gap: href ? 1 : void 0, children: [
436
- badgeText || hasPinnedFeatureAndNoChildren ? /* @__PURE__ */ jsxs(Fragment, { children: [
437
- badgeText ? /* @__PURE__ */ jsx(
438
- StyledBadge,
439
- {
440
- sentiment: badgeSentiment,
441
- size: "small",
442
- prominence: "strong",
443
- disabled,
444
- children: badgeText
445
- }
446
- ) : null,
447
- shouldShowPinnedButton ? /* @__PURE__ */ jsx(
448
- Tooltip,
449
- {
450
- text: isItemPinned ? locales["navigation.unpin.tooltip"] : pinTooltipLocale,
451
- placement: "right",
452
- children: /* @__PURE__ */ jsx(RelativeDiv, { children: /* @__PURE__ */ jsx(
453
- PinnedButton,
454
- {
455
- role: "button",
456
- size: "xsmall",
457
- variant: "ghost",
458
- sentiment: active ? "primary" : "neutral",
459
- onClick: (event) => {
460
- event.preventDefault();
461
- event.stopPropagation();
462
- if (isItemPinned) {
463
- unpinItem(id);
464
- } else {
465
- pinItem(id);
466
- }
467
- onPinUnpinClick?.(event);
468
- },
469
- disabled: isItemPinned ? false : isPinDisabled,
470
- children: /* @__PURE__ */ jsx(
471
- StyledIcon,
472
- {
473
- size: "large",
474
- name: isItemPinned ? "unpin" : "pin",
475
- variant: isItemPinned ? "filled" : "outlined",
476
- disabled: isItemPinned ? false : isPinDisabled,
477
- sentiment: active ? "primary" : "neutral",
478
- active
479
- }
480
- )
481
- }
482
- ) })
483
- }
484
- ) : null
485
- ] }) : null,
486
- hasHrefAndNoChildren ? /* @__PURE__ */ jsx(
487
- AnimatedIcon,
488
- {
489
- name: "open-in-new",
490
- sentiment: "neutral",
491
- prominence: "default",
492
- disabled
493
- }
494
- ) : null,
495
- children ? /* @__PURE__ */ jsx(Stack, { gap: 1, direction: "row", alignItems: "center", children: !animation && !noExpand ? /* @__PURE__ */ jsx(
496
- AnimatedIcon,
497
- {
498
- name: internalToggle ? "arrow-down" : "arrow-right",
499
- sentiment: "neutral",
500
- prominence: "weak"
501
- }
502
- ) : null }) : null
503
- ] })
504
- ]
505
- }
506
- ),
507
- children ? /* @__PURE__ */ jsx(Fragment, { children: !noExpand ? /* @__PURE__ */ jsx(
508
- Expandable,
509
- {
510
- opened: internalToggle,
511
- animationDuration: animation ? ANIMATION_DURATION / 2 : void 0,
512
- children: /* @__PURE__ */ jsx(PaddedStack, { children: renderChildren })
348
+ /* @__PURE__ */ jsxs(Container, { gap: 1, direction: "row", alignItems: "center", justifyContent: "space-between", "data-has-sub-label": !!subLabel, onClick: () => {
349
+ if (children) {
350
+ return triggerToggle(!internalToggle);
513
351
  }
514
- ) : /* @__PURE__ */ jsx(PaddedStack, { children: renderChildren }) }) : null
352
+ return onClick?.();
353
+ }, "aria-expanded": ariaExpanded, href, target: href ? "_blank" : void 0, "data-is-pinnable": shouldShowPinnedButton, "data-is-active": active, "data-animation": animation, "data-has-children": !!children, "data-has-active-children": hasActiveChildren, "data-has-no-expand": noExpand, disabled, draggable: type === "pinned" && expanded, onDragStart: (event) => expanded ? onDragStartTrigger(event) : void 0, onDragEnd: (event) => expanded ? onDragStopTrigger(event) : void 0, id, children: [
354
+ /* @__PURE__ */ jsxs(Stack, { direction: "row", gap: 1, alignItems: "center", justifyContent: "center", children: [
355
+ categoryIcon ? /* @__PURE__ */ jsx(ContainerCategoryIcon, { alignItems: "center", justifyContent: "center", children: /* @__PURE__ */ jsx(CategoryIcon, { name: categoryIcon, variant: active ? "primary" : categoryIconVariant, disabled }) }) : null,
356
+ type === "pinned" && expanded ? /* @__PURE__ */ jsx(GrabIcon, { name: "drag-vertical", sentiment: "neutral", prominence: "weak", size: "small", disabled }) : null,
357
+ /* @__PURE__ */ jsxs(Stack, { children: [
358
+ /* @__PURE__ */ jsx(WrapText, { as: "span", variant: "bodySmallStrong", sentiment: active ? "primary" : "neutral", prominence: (categoryIcon || !hasParents) && !active ? "strong" : "default", animation, disabled, children: label }),
359
+ subLabel ? /* @__PURE__ */ jsx(WrapText, { as: "span", variant: "caption", sentiment: "neutral", prominence: "weak", animation, disabled, subLabel: true, children: subLabel }) : null
360
+ ] })
361
+ ] }),
362
+ /* @__PURE__ */ jsxs(Stack, { direction: "row", alignItems: "center", gap: href ? 1 : void 0, children: [
363
+ badgeText || hasPinnedFeatureAndNoChildren ? /* @__PURE__ */ jsxs(Fragment, { children: [
364
+ badgeText ? /* @__PURE__ */ jsx(StyledBadge, { sentiment: badgeSentiment, size: "small", prominence: "strong", disabled, children: badgeText }) : null,
365
+ shouldShowPinnedButton ? /* @__PURE__ */ jsx(Tooltip, { text: isItemPinned ? locales["navigation.unpin.tooltip"] : pinTooltipLocale, placement: "right", children: /* @__PURE__ */ jsx(RelativeDiv, { children: /* @__PURE__ */ jsx(PinnedButton, { role: "button", size: "xsmall", variant: "ghost", sentiment: active ? "primary" : "neutral", onClick: (event) => {
366
+ event.preventDefault();
367
+ event.stopPropagation();
368
+ if (isItemPinned) {
369
+ unpinItem(id);
370
+ } else {
371
+ pinItem(id);
372
+ }
373
+ onPinUnpinClick?.(event);
374
+ }, disabled: isItemPinned ? false : isPinDisabled, children: /* @__PURE__ */ jsx(StyledIcon, { size: "large", name: isItemPinned ? "unpin" : "pin", variant: isItemPinned ? "filled" : "outlined", disabled: isItemPinned ? false : isPinDisabled, sentiment: active ? "primary" : "neutral", active }) }) }) }) : null
375
+ ] }) : null,
376
+ hasHrefAndNoChildren ? /* @__PURE__ */ jsx(AnimatedIcon, { name: "open-in-new", sentiment: "neutral", prominence: "default", disabled }) : null,
377
+ children ? /* @__PURE__ */ jsx(Stack, { gap: 1, direction: "row", alignItems: "center", children: !animation && !noExpand ? /* @__PURE__ */ jsx(AnimatedIcon, { name: internalToggle ? "arrow-down" : "arrow-right", sentiment: "neutral", prominence: "weak" }) : null }) : null
378
+ ] })
379
+ ] }),
380
+ children ? /* @__PURE__ */ jsx(Fragment, { children: !noExpand ? /* @__PURE__ */ jsx(Expandable, { opened: internalToggle, animationDuration: animation ? ANIMATION_DURATION / 2 : void 0, children: /* @__PURE__ */ jsx(PaddedStack, { children: renderChildren }) }) : /* @__PURE__ */ jsx(PaddedStack, { children: renderChildren }) }) : null
515
381
  ] });
516
382
  }
517
383
  if (categoryIcon || Children.count(children) > 0 && !hasParents) {
@@ -520,173 +386,37 @@ const Item = ({
520
386
  {
521
387
  triggerMethod: "hover",
522
388
  dynamicDomRendering: false,
523
- disclosure: /* @__PURE__ */ jsx(
524
- Button,
525
- {
526
- sentiment: "neutral",
527
- variant: hasActiveChildren ? "filled" : "ghost",
528
- size: "small",
529
- icon: !categoryIcon ? "dots-horizontal" : void 0,
530
- children: categoryIcon ? /* @__PURE__ */ jsx(
531
- Stack,
532
- {
533
- direction: "row",
534
- gap: 1,
535
- alignItems: "center",
536
- justifyContent: "center",
537
- children: /* @__PURE__ */ jsx(
538
- CategoryIcon,
539
- {
540
- name: categoryIcon,
541
- variant: active ? "primary" : categoryIconVariant
542
- }
543
- )
544
- }
545
- ) : null
546
- }
547
- ),
389
+ disclosure: /* @__PURE__ */ jsx(Button, { sentiment: "neutral", variant: hasActiveChildren ? "filled" : "ghost", size: "small", icon: !categoryIcon ? "dots-horizontal" : void 0, children: categoryIcon ? /* @__PURE__ */ jsx(Stack, { direction: "row", gap: 1, alignItems: "center", justifyContent: "center", children: /* @__PURE__ */ jsx(CategoryIcon, { name: categoryIcon, variant: active ? "primary" : categoryIconVariant }) }) : null }),
548
390
  placement: "right",
549
- children: Children.map(
550
- children,
551
- (child) => isValidElement(child) ? cloneElement(child, {
552
- hasParents: true
553
- }) : child
554
- )
555
- }
556
- ) : /* @__PURE__ */ jsx(Tooltip, { text: label, placement: "right", tabIndex: -1, children: /* @__PURE__ */ jsx(
557
- Button,
558
- {
559
- sentiment: "neutral",
560
- variant: active ? "filled" : "ghost",
561
- size: "small",
562
- onClick: () => onClick?.(),
563
- children: /* @__PURE__ */ jsx(
564
- Stack,
565
- {
566
- direction: "row",
567
- gap: 1,
568
- alignItems: "center",
569
- justifyContent: "center",
570
- children: /* @__PURE__ */ jsx(
571
- CategoryIcon,
572
- {
573
- name: categoryIcon ?? "console",
574
- variant: active ? "primary" : categoryIconVariant
575
- }
576
- )
577
- }
578
- )
391
+ children: Children.map(children, (child) => isValidElement(child) ? cloneElement(child, {
392
+ hasParents: true
393
+ }) : child)
579
394
  }
580
- ) }) });
395
+ ) : /* @__PURE__ */ jsx(Tooltip, { text: label, placement: "right", tabIndex: -1, children: /* @__PURE__ */ jsx(Button, { sentiment: "neutral", variant: active ? "filled" : "ghost", size: "small", onClick: () => onClick?.(), children: /* @__PURE__ */ jsx(Stack, { direction: "row", gap: 1, alignItems: "center", justifyContent: "center", children: /* @__PURE__ */ jsx(CategoryIcon, { name: categoryIcon ?? "console", variant: active ? "primary" : categoryIconVariant }) }) }) }) });
581
396
  }
582
397
  if (hasParents) {
583
- return /* @__PURE__ */ jsx(
584
- StyledMenuItem,
585
- {
586
- href,
587
- onClick: () => {
588
- onClick?.();
589
- },
590
- borderless: true,
591
- active,
592
- disabled,
593
- sentiment: active ? "primary" : "neutral",
594
- isPinnable: shouldShowPinnedButton,
595
- children: /* @__PURE__ */ jsxs(
596
- Stack,
597
- {
598
- gap: 1,
599
- direction: "row",
600
- alignItems: "center",
601
- justifyContent: "space-between",
602
- flex: 1,
603
- width: "100%",
604
- children: [
605
- /* @__PURE__ */ jsx(WrapText, { as: "span", variant: "bodySmall", children: label }),
606
- /* @__PURE__ */ jsxs(Stack, { direction: "row", children: [
607
- badgeText ? /* @__PURE__ */ jsx(
608
- StyledBadge,
609
- {
610
- sentiment: badgeSentiment,
611
- size: "small",
612
- prominence: "strong",
613
- disabled,
614
- children: badgeText
615
- }
616
- ) : null,
617
- hasHrefAndNoChildren ? /* @__PURE__ */ jsx(
618
- AnimatedIcon,
619
- {
620
- name: "open-in-new",
621
- sentiment: "neutral",
622
- prominence: "weak",
623
- disabled
624
- }
625
- ) : null,
626
- shouldShowPinnedButton ? /* @__PURE__ */ jsx(
627
- Tooltip,
628
- {
629
- text: isItemPinned ? locales["navigation.unpin.tooltip"] : pinTooltipLocale,
630
- placement: "right",
631
- children: /* @__PURE__ */ jsx(RelativeDiv, { children: /* @__PURE__ */ jsx(
632
- PinnedButton,
633
- {
634
- role: "button",
635
- size: "xsmall",
636
- variant: "ghost",
637
- sentiment: active ? "primary" : "neutral",
638
- onClick: (event) => {
639
- event.preventDefault();
640
- event.stopPropagation();
641
- if (isItemPinned) {
642
- unpinItem(id);
643
- } else {
644
- pinItem(id);
645
- }
646
- onPinUnpinClick?.(event);
647
- },
648
- disabled: isItemPinned ? false : isPinDisabled,
649
- children: /* @__PURE__ */ jsx(
650
- StyledIcon,
651
- {
652
- size: "large",
653
- name: isItemPinned ? "unpin" : "pin",
654
- variant: isItemPinned ? "filled" : "outlined",
655
- disabled: isItemPinned ? false : isPinDisabled,
656
- sentiment: active ? "primary" : "neutral",
657
- active
658
- }
659
- )
660
- }
661
- ) })
662
- }
663
- ) : null
664
- ] })
665
- ]
398
+ return /* @__PURE__ */ jsx(StyledMenuItem, { href, onClick: () => {
399
+ onClick?.();
400
+ }, borderless: true, active, disabled, sentiment: active ? "primary" : "neutral", isPinnable: shouldShowPinnedButton, children: /* @__PURE__ */ jsxs(Stack, { gap: 1, direction: "row", alignItems: "center", justifyContent: "space-between", flex: 1, width: "100%", children: [
401
+ /* @__PURE__ */ jsx(WrapText, { as: "span", variant: "bodySmall", children: label }),
402
+ /* @__PURE__ */ jsxs(Stack, { direction: "row", children: [
403
+ badgeText ? /* @__PURE__ */ jsx(StyledBadge, { sentiment: badgeSentiment, size: "small", prominence: "strong", disabled, children: badgeText }) : null,
404
+ hasHrefAndNoChildren ? /* @__PURE__ */ jsx(AnimatedIcon, { name: "open-in-new", sentiment: "neutral", prominence: "weak", disabled }) : null,
405
+ shouldShowPinnedButton ? /* @__PURE__ */ jsx(Tooltip, { text: isItemPinned ? locales["navigation.unpin.tooltip"] : pinTooltipLocale, placement: "right", children: /* @__PURE__ */ jsx(RelativeDiv, { children: /* @__PURE__ */ jsx(PinnedButton, { role: "button", size: "xsmall", variant: "ghost", sentiment: active ? "primary" : "neutral", onClick: (event) => {
406
+ event.preventDefault();
407
+ event.stopPropagation();
408
+ if (isItemPinned) {
409
+ unpinItem(id);
410
+ } else {
411
+ pinItem(id);
666
412
  }
667
- )
668
- }
669
- );
413
+ onPinUnpinClick?.(event);
414
+ }, disabled: isItemPinned ? false : isPinDisabled, children: /* @__PURE__ */ jsx(StyledIcon, { size: "large", name: isItemPinned ? "unpin" : "pin", variant: isItemPinned ? "filled" : "outlined", disabled: isItemPinned ? false : isPinDisabled, sentiment: active ? "primary" : "neutral", active }) }) }) }) : null
415
+ ] })
416
+ ] }) });
670
417
  }
671
418
  if (!hasParents && href) {
672
- return /* @__PURE__ */ jsx(Tooltip, { text: label, placement: "right", children: /* @__PURE__ */ jsx(MenuStack, { gap: 1, alignItems: "start", justifyContent: "start", children: /* @__PURE__ */ jsx(
673
- Container,
674
- {
675
- gap: 1,
676
- alignItems: "center",
677
- justifyContent: "center",
678
- href,
679
- target: "_blank",
680
- children: /* @__PURE__ */ jsx(
681
- AnimatedIcon,
682
- {
683
- name: "open-in-new",
684
- sentiment: "neutral",
685
- prominence: "weak"
686
- }
687
- )
688
- }
689
- ) }) });
419
+ return /* @__PURE__ */ jsx(Tooltip, { text: label, placement: "right", children: /* @__PURE__ */ jsx(MenuStack, { gap: 1, alignItems: "start", justifyContent: "start", children: /* @__PURE__ */ jsx(Container, { gap: 1, alignItems: "center", justifyContent: "center", href, target: "_blank", children: /* @__PURE__ */ jsx(AnimatedIcon, { name: "open-in-new", sentiment: "neutral", prominence: "weak" }) }) }) });
690
420
  }
691
421
  return null;
692
422
  };