@ultraviolet/plus 0.27.2 → 0.27.3

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
@@ -43,7 +43,7 @@ const RelativeDiv = /* @__PURE__ */ _styled__default.default("div", process.env.
43
43
  styles: "position:relative"
44
44
  } : {
45
45
  name: "bjn8wh",
46
- styles: "position:relative/*# 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":"AA+C8B","file":"/home/runner/work/ultraviolet/ultraviolet/packages/plus/src/components/Navigation/components/Item.tsx","sourcesContent":["'use client'\n\nimport { css } from '@emotion/react'\nimport styled from '@emotion/styled'\nimport {\n  ArrowDownIcon,\n  ArrowRightIcon,\n  DragIcon,\n  OpenInNewIcon,\n  PinOutlineIcon,\n  UnpinIcon,\n} from '@ultraviolet/icons'\nimport * as CategoryIcon from '@ultraviolet/icons/category'\nimport { ConsoleCategoryIcon } from '@ultraviolet/icons/category'\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  isValidElement,\n  memo,\n  useCallback,\n  useContext,\n  useEffect,\n  useMemo,\n  useReducer,\n} from 'react'\nimport type { PascalToCamelCaseWithoutSuffix } from '../../../types'\nimport { useNavigation } from '../NavigationProvider'\nimport { ANIMATION_DURATION, shrinkHeight } from '../constants'\nimport type { PinUnPinType } from '../types'\nimport { ItemContext, ItemProvider } from './ItemProvider'\n\nconst RelativeDiv = styled.div`\n  position: relative;\n`\n\nconst StyledPinIconOutline = styled(PinOutlineIcon, {\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 }) =>\n      active ? `background: ${theme.colors.primary.backgroundHover};` : null}\n  }\n`\n\nconst StyledUnpinIcon = StyledPinIconOutline.withComponent(UnpinIcon)\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(DragIcon)`\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  &: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(OpenInNewIcon)``\n\nconst WrapText = styled(Text)`\n  overflow-wrap: anywhere;\n  overflow: hidden;\n  display: -webkit-box;\n  -webkit-box-orient: vertical;\n  -webkit-line-clamp: 2;\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 }) => 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\"][data-animation-type=\"complex\"] {\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\"][data-animation-type=\"complex\"] {\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 StackIcon = styled(Stack)`\n  padding-top: ${({ theme }) => theme.space['0.5']};\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?: PascalToCamelCaseWithoutSuffix<\n    keyof typeof CategoryIcon,\n    'CategoryIcon'\n  >\n  categoryIconVariant?: ComponentProps<\n    (typeof CategoryIcon)['BaremetalCategoryIcon']\n  >['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?: HTMLAnchorElement['href']\n  target?: HTMLAnchorElement['target']\n  rel?: HTMLAnchorElement['rel']\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  onToggle?: (toggle: boolean) => void\n  onClickPinUnpin?: (parameters: PinUnPinType) => 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 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  'data-testid'?: string\n}\n\nconst onDragStopTrigger = (event: DragEvent<HTMLDivElement>) => {\n  // eslint-disable-next-line no-param-reassign\n  event.currentTarget.style.opacity = '1'\n}\n\nexport const Item = memo(\n  ({\n    children,\n    categoryIcon,\n    categoryIconVariant,\n    label,\n    subLabel,\n    badgeText,\n    badgeSentiment,\n    href,\n    target,\n    rel,\n    onToggle,\n    onClickPinUnpin,\n    toggle,\n    active,\n    noPinButton,\n    type = 'default',\n    as,\n    disabled,\n    noExpand = false,\n    index,\n    id,\n    'data-testid': dataTestId,\n  }: ItemProps) => {\n    const context = useNavigation()\n    if (!context) {\n      throw new Error(\n        'Navigation.Item can only be used inside a NavigationProvider.',\n      )\n    }\n\n    const itemProvider = useContext(ItemContext)\n    const hasParents = !!itemProvider\n\n    const {\n      expanded,\n      locales,\n      pinnedFeature,\n      pinItem,\n      unpinItem,\n      pinnedItems,\n      pinLimit,\n      animation,\n      registerItem,\n      shouldAnimate,\n      animationType,\n    } = context\n\n    useEffect(\n      () => {\n        if (type !== 'pinnedGroup') {\n          registerItem({ [id]: { label, active, onToggle, onClickPinUnpin } })\n        }\n      },\n      // eslint-disable-next-line react-hooks/exhaustive-deps\n      [active, id, label, registerItem],\n    )\n\n    const [internalExpanded, onToggleExpand] = useReducer(\n      prevState => !prevState,\n      Boolean(toggle),\n    )\n\n    const triggerToggle = useCallback(() => {\n      onToggleExpand()\n      onToggle?.(internalExpanded)\n    }, [internalExpanded, onToggle])\n\n    const PaddedStack =\n      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 = useMemo(\n      () => StyledContainer.withComponent(containerTag),\n      [containerTag],\n    )\n\n    const CategoryIconUsed = categoryIcon\n      ? CategoryIcon[\n          `${\n            categoryIcon.charAt(0).toUpperCase() + categoryIcon.slice(1)\n          }CategoryIcon` as keyof typeof CategoryIcon\n        ]\n      : null\n\n    const ArrowIcon = useMemo(\n      () => (internalExpanded ? ArrowDownIcon : ArrowRightIcon),\n      [internalExpanded],\n    )\n\n    const PinUnpinIcon = useMemo(\n      () => (isItemPinned ? StyledUnpinIcon : StyledPinIconOutline),\n      [isItemPinned],\n    )\n\n    const ariaExpanded = useMemo(() => {\n      if (hasHrefAndNoChildren && internalExpanded) {\n        return true\n      }\n\n      if (hasHrefAndNoChildren && !internalExpanded) {\n        return false\n      }\n\n      return undefined\n    }, [hasHrefAndNoChildren, internalExpanded])\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 onDragStart = useCallback(\n      (event: DragEvent<HTMLDivElement>) => {\n        if (expanded) {\n          event.dataTransfer.setData(\n            'text/plain',\n            JSON.stringify({ label, index }),\n          )\n          // eslint-disable-next-line no-param-reassign\n          event.currentTarget.style.opacity = '0.5'\n        }\n\n        return undefined\n      },\n      [expanded, index, label],\n    )\n\n    const onDragEnd = useCallback(\n      (event: DragEvent<HTMLDivElement>) =>\n        expanded ? onDragStopTrigger(event) : undefined,\n      [expanded],\n    )\n\n    // This content is when the navigation is expanded\n    if (expanded || (!expanded && animation === 'expand')) {\n      return (\n        <>\n          <Container\n            gap={1}\n            direction=\"row\"\n            alignItems={categoryIcon ? 'flex-start' : 'center'}\n            justifyContent=\"space-between\"\n            data-has-sub-label={!!subLabel}\n            onClick={triggerToggle}\n            aria-expanded={ariaExpanded}\n            href={href}\n            target={target}\n            rel={rel}\n            data-is-pinnable={shouldShowPinnedButton}\n            data-is-active={active}\n            data-animation={shouldAnimate ? animation : undefined}\n            data-animation-type={animationType}\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={onDragStart}\n            onDragEnd={onDragEnd}\n            id={id}\n            data-testid={dataTestId}\n          >\n            <Stack\n              direction=\"row\"\n              gap={1}\n              alignItems={categoryIcon ? 'flex-start' : 'center'}\n              justifyContent=\"center\"\n            >\n              {CategoryIconUsed ? (\n                <ContainerCategoryIcon\n                  alignItems=\"center\"\n                  justifyContent=\"center\"\n                >\n                  <CategoryIconUsed\n                    variant={active ? 'primary' : categoryIconVariant}\n                    disabled={disabled}\n                  />\n                </ContainerCategoryIcon>\n              ) : null}\n              {type === 'pinned' && expanded ? (\n                <GrabIcon\n                  sentiment=\"neutral\"\n                  prominence=\"weak\"\n                  size=\"small\"\n                  disabled={disabled}\n                />\n              ) : null}\n              <Stack>\n                {!animation ? (\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                    data-animation={animation}\n                    disabled={disabled}\n                    whiteSpace=\"pre-wrap\"\n                  >\n                    {label}\n                  </WrapText>\n                ) : null}\n                {subLabel && !animation ? (\n                  <WrapText\n                    as=\"span\"\n                    variant=\"caption\"\n                    sentiment=\"neutral\"\n                    prominence=\"weak\"\n                    data-animation={animation}\n                    disabled={disabled}\n                    whiteSpace=\"pre-wrap\"\n                  >\n                    {subLabel}\n                  </WrapText>\n                ) : null}\n              </Stack>\n            </Stack>\n            <Stack\n              direction=\"row\"\n              alignItems=\"center\"\n              gap={href ? 1 : undefined}\n            >\n              {badgeText || hasPinnedFeatureAndNoChildren ? (\n                <>\n                  {badgeText && !animation ? (\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                          aria-label={isItemPinned ? 'unpin' : 'pin'}\n                          size=\"xsmall\"\n                          variant=\"ghost\"\n                          sentiment={active ? 'primary' : 'neutral'}\n                          onClick={(event: MouseEvent<HTMLDivElement>) => {\n                            if (pinnedItems.length < pinLimit || isItemPinned) {\n                              event.preventDefault()\n                              event.stopPropagation() // This is to avoid click spread to the parent and change the routing\n                              let newValue: string[] | undefined\n                              if (isItemPinned) {\n                                newValue = unpinItem(id)\n                              } else {\n                                newValue = pinItem(id)\n                              }\n\n                              onClickPinUnpin?.({\n                                state: isItemPinned ? 'unpin' : 'pin',\n                                id,\n                                totalPinned: newValue,\n                              })\n                            }\n                          }}\n                          disabled={isItemPinned ? false : isPinDisabled}\n                        >\n                          <PinUnpinIcon\n                            size=\"medium\"\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 && target === '_blank' && !animation ? (\n                <AnimatedIcon\n                  sentiment=\"neutral\"\n                  prominence=\"default\"\n                  disabled={disabled}\n                />\n              ) : null}\n              {children ? (\n                <StackIcon gap={1} direction=\"row\" alignItems=\"center\">\n                  {!animation && !noExpand ? (\n                    <ArrowIcon sentiment=\"neutral\" prominence=\"weak\" />\n                  ) : null}\n                </StackIcon>\n              ) : null}\n            </Stack>\n          </Container>\n          {children ? (\n            <>\n              {!noExpand ? (\n                <ItemProvider>\n                  <Expandable opened={internalExpanded} animationDuration={0}>\n                    <PaddedStack width={animation ? '100%' : undefined}>\n                      {children}\n                    </PaddedStack>\n                  </Expandable>\n                </ItemProvider>\n              ) : (\n                <ItemProvider>\n                  <PaddedStack width={animation ? '100%' : undefined}>\n                    {children}\n                  </PaddedStack>\n                </ItemProvider>\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                  aria-label={label}\n                >\n                  {CategoryIconUsed ? (\n                    <Stack\n                      direction=\"row\"\n                      gap={1}\n                      alignItems=\"center\"\n                      justifyContent=\"center\"\n                    >\n                      <CategoryIconUsed\n                        variant={active ? 'primary' : categoryIconVariant}\n                      />\n                    </Stack>\n                  ) : null}\n                </Button>\n              }\n              placement=\"right\"\n            >\n              <ItemProvider>{children}</ItemProvider>\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                aria-label={label}\n              >\n                <Stack\n                  direction=\"row\"\n                  gap={1}\n                  alignItems=\"center\"\n                  justifyContent=\"center\"\n                >\n                  {CategoryIconUsed ? (\n                    <CategoryIconUsed\n                      variant={active ? 'primary' : categoryIconVariant}\n                    />\n                  ) : (\n                    <ConsoleCategoryIcon\n                      variant={active ? 'primary' : categoryIconVariant}\n                    />\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          target={target}\n          rel={rel}\n          borderless\n          active={active}\n          disabled={disabled}\n          sentiment={active ? 'primary' : 'neutral'}\n          isPinnable={shouldShowPinnedButton}\n          onClick={() => onToggle?.(!!active)}\n        >\n          <Stack\n            gap={1}\n            direction=\"row\"\n            alignItems=\"center\"\n            justifyContent=\"space-between\"\n            flex={1}\n            width=\"100%\"\n          >\n            {!animation ? (\n              <WrapText as=\"span\" variant=\"bodySmall\" whiteSpace=\"pre-wrap\">\n                {label}\n              </WrapText>\n            ) : null}\n            <Stack direction=\"row\">\n              {badgeText && !animation ? (\n                <StyledBadge\n                  sentiment={badgeSentiment}\n                  size=\"small\"\n                  prominence=\"strong\"\n                  disabled={disabled}\n                >\n                  {badgeText}\n                </StyledBadge>\n              ) : null}\n              {hasHrefAndNoChildren && target === '_blank' ? (\n                <AnimatedIcon\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                      aria-label={isItemPinned ? 'unpin' : 'pin'}\n                      variant=\"ghost\"\n                      sentiment={active ? 'primary' : 'neutral'}\n                      onClick={(event: MouseEvent<HTMLDivElement>) => {\n                        if (pinnedItems.length < pinLimit || isItemPinned) {\n                          event.preventDefault()\n                          event.stopPropagation() // This is to avoid click spread to the parent and change the routing\n\n                          let newValue: string[] | undefined\n                          if (isItemPinned) {\n                            newValue = unpinItem(id)\n                          } else {\n                            newValue = pinItem(id)\n                          }\n                          onClickPinUnpin?.({\n                            state: isItemPinned ? 'unpin' : 'pin',\n                            id,\n                            totalPinned: newValue,\n                          })\n                        }\n                      }}\n                      disabled={isItemPinned ? false : isPinDisabled}\n                    >\n                      <PinUnpinIcon\n                        size=\"medium\"\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={target}\n              rel={rel}\n            >\n              <AnimatedIcon sentiment=\"neutral\" prominence=\"weak\" />\n            </Container>\n          </MenuStack>\n        </Tooltip>\n      )\n    }\n\n    return null\n  },\n)\n"]} */",
46
+ styles: "position:relative/*# 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":"AA+C8B","file":"/home/runner/work/ultraviolet/ultraviolet/packages/plus/src/components/Navigation/components/Item.tsx","sourcesContent":["'use client'\n\nimport { css } from '@emotion/react'\nimport styled from '@emotion/styled'\nimport {\n  ArrowDownIcon,\n  ArrowRightIcon,\n  DragIcon,\n  OpenInNewIcon,\n  PinOutlineIcon,\n  UnpinIcon,\n} from '@ultraviolet/icons'\nimport * as CategoryIcon from '@ultraviolet/icons/category'\nimport { ConsoleCategoryIcon } from '@ultraviolet/icons/category'\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  isValidElement,\n  memo,\n  useCallback,\n  useContext,\n  useEffect,\n  useMemo,\n  useReducer,\n} from 'react'\nimport type { PascalToCamelCaseWithoutSuffix } from '../../../types'\nimport { useNavigation } from '../NavigationProvider'\nimport { ANIMATION_DURATION, shrinkHeight } from '../constants'\nimport type { PinUnPinType } from '../types'\nimport { ItemContext, ItemProvider } from './ItemProvider'\n\nconst RelativeDiv = styled.div`\n  position: relative;\n`\n\nconst StyledPinIconOutline = styled(PinOutlineIcon, {\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 }) =>\n      active ? `background: ${theme.colors.primary.backgroundHover};` : null}\n  }\n`\n\nconst StyledUnpinIcon = StyledPinIconOutline.withComponent(UnpinIcon)\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(DragIcon)`\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  &: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(OpenInNewIcon)``\n\nconst WrapText = styled(Text)`\n  overflow-wrap: anywhere;\n  overflow: hidden;\n  display: -webkit-box;\n  -webkit-box-orient: vertical;\n  -webkit-line-clamp: 2;\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 }) => 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\"][data-animation-type=\"complex\"] {\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\"][data-animation-type=\"complex\"] {\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 StackIcon = styled(Stack)`\n  padding-top: ${({ theme }) => theme.space['0.5']};\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?: PascalToCamelCaseWithoutSuffix<\n    keyof typeof CategoryIcon,\n    'CategoryIcon'\n  >\n  categoryIconVariant?: ComponentProps<\n    (typeof CategoryIcon)['BaremetalCategoryIcon']\n  >['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?: HTMLAnchorElement['href']\n  target?: HTMLAnchorElement['target']\n  rel?: HTMLAnchorElement['rel']\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  onToggle?: (toggle: boolean) => void\n  onClickPinUnpin?: (parameters: PinUnPinType) => 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 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  'data-testid'?: string\n}\n\nconst onDragStopTrigger = (event: DragEvent<HTMLDivElement>) => {\n  // eslint-disable-next-line no-param-reassign\n  event.currentTarget.style.opacity = '1'\n}\n\nexport const Item = memo(\n  ({\n    children,\n    categoryIcon,\n    categoryIconVariant,\n    label,\n    subLabel,\n    badgeText,\n    badgeSentiment,\n    href,\n    target,\n    rel,\n    onToggle,\n    onClickPinUnpin,\n    toggle,\n    active,\n    noPinButton,\n    type = 'default',\n    as,\n    disabled,\n    noExpand = false,\n    index,\n    id,\n    'data-testid': dataTestId,\n  }: ItemProps) => {\n    const context = useNavigation()\n    if (!context) {\n      throw new Error(\n        'Navigation.Item can only be used inside a NavigationProvider.',\n      )\n    }\n\n    const itemProvider = useContext(ItemContext)\n    const hasParents = !!itemProvider\n\n    const {\n      expanded,\n      locales,\n      pinnedFeature,\n      pinItem,\n      unpinItem,\n      pinnedItems,\n      pinLimit,\n      animation,\n      registerItem,\n      shouldAnimate,\n      animationType,\n    } = context\n\n    useEffect(\n      () => {\n        if (type !== 'pinnedGroup' && pinnedFeature) {\n          registerItem({ [id]: { label, active, onToggle, onClickPinUnpin } })\n        }\n      },\n      // eslint-disable-next-line react-hooks/exhaustive-deps\n      [active, id, label, registerItem],\n    )\n\n    const [internalExpanded, onToggleExpand] = useReducer(\n      prevState => !prevState,\n      Boolean(toggle),\n    )\n\n    const triggerToggle = useCallback(() => {\n      onToggleExpand()\n      onToggle?.(internalExpanded)\n    }, [internalExpanded, onToggle])\n\n    const PaddedStack =\n      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 = useMemo(\n      () => StyledContainer.withComponent(containerTag),\n      [containerTag],\n    )\n\n    const CategoryIconUsed = categoryIcon\n      ? CategoryIcon[\n          `${\n            categoryIcon.charAt(0).toUpperCase() + categoryIcon.slice(1)\n          }CategoryIcon` as keyof typeof CategoryIcon\n        ]\n      : null\n\n    const ArrowIcon = useMemo(\n      () => (internalExpanded ? ArrowDownIcon : ArrowRightIcon),\n      [internalExpanded],\n    )\n\n    const PinUnpinIcon = useMemo(\n      () => (isItemPinned ? StyledUnpinIcon : StyledPinIconOutline),\n      [isItemPinned],\n    )\n\n    const ariaExpanded = useMemo(() => {\n      if (hasHrefAndNoChildren && internalExpanded) {\n        return true\n      }\n\n      if (hasHrefAndNoChildren && !internalExpanded) {\n        return false\n      }\n\n      return undefined\n    }, [hasHrefAndNoChildren, internalExpanded])\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 onDragStart = useCallback(\n      (event: DragEvent<HTMLDivElement>) => {\n        if (expanded) {\n          event.dataTransfer.setData(\n            'text/plain',\n            JSON.stringify({ label, index }),\n          )\n          // eslint-disable-next-line no-param-reassign\n          event.currentTarget.style.opacity = '0.5'\n        }\n\n        return undefined\n      },\n      [expanded, index, label],\n    )\n\n    const onDragEnd = useCallback(\n      (event: DragEvent<HTMLDivElement>) =>\n        expanded ? onDragStopTrigger(event) : undefined,\n      [expanded],\n    )\n\n    // This content is when the navigation is expanded\n    if (expanded || (!expanded && animation === 'expand')) {\n      return (\n        <>\n          <Container\n            gap={1}\n            direction=\"row\"\n            alignItems={categoryIcon ? 'flex-start' : 'center'}\n            justifyContent=\"space-between\"\n            data-has-sub-label={!!subLabel}\n            onClick={triggerToggle}\n            aria-expanded={ariaExpanded}\n            href={href}\n            target={target}\n            rel={rel}\n            data-is-pinnable={shouldShowPinnedButton}\n            data-is-active={active}\n            data-animation={shouldAnimate ? animation : undefined}\n            data-animation-type={animationType}\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={onDragStart}\n            onDragEnd={onDragEnd}\n            id={id}\n            data-testid={dataTestId}\n          >\n            <Stack\n              direction=\"row\"\n              gap={1}\n              alignItems={categoryIcon ? 'flex-start' : 'center'}\n              justifyContent=\"center\"\n            >\n              {CategoryIconUsed ? (\n                <ContainerCategoryIcon\n                  alignItems=\"center\"\n                  justifyContent=\"center\"\n                >\n                  <CategoryIconUsed\n                    variant={active ? 'primary' : categoryIconVariant}\n                    disabled={disabled}\n                  />\n                </ContainerCategoryIcon>\n              ) : null}\n              {type === 'pinned' && expanded ? (\n                <GrabIcon\n                  sentiment=\"neutral\"\n                  prominence=\"weak\"\n                  size=\"small\"\n                  disabled={disabled}\n                />\n              ) : null}\n              <Stack>\n                {!animation ? (\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                    data-animation={animation}\n                    disabled={disabled}\n                    whiteSpace=\"pre-wrap\"\n                  >\n                    {label}\n                  </WrapText>\n                ) : null}\n                {subLabel && !animation ? (\n                  <WrapText\n                    as=\"span\"\n                    variant=\"caption\"\n                    sentiment=\"neutral\"\n                    prominence=\"weak\"\n                    data-animation={animation}\n                    disabled={disabled}\n                    whiteSpace=\"pre-wrap\"\n                  >\n                    {subLabel}\n                  </WrapText>\n                ) : null}\n              </Stack>\n            </Stack>\n            <Stack\n              direction=\"row\"\n              alignItems=\"center\"\n              gap={href ? 1 : undefined}\n            >\n              {badgeText || hasPinnedFeatureAndNoChildren ? (\n                <>\n                  {badgeText && !animation ? (\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                          aria-label={isItemPinned ? 'unpin' : 'pin'}\n                          size=\"xsmall\"\n                          variant=\"ghost\"\n                          sentiment={active ? 'primary' : 'neutral'}\n                          onClick={(event: MouseEvent<HTMLDivElement>) => {\n                            if (pinnedItems.length < pinLimit || isItemPinned) {\n                              event.preventDefault()\n                              event.stopPropagation() // This is to avoid click spread to the parent and change the routing\n                              let newValue: string[] | undefined\n                              if (isItemPinned) {\n                                newValue = unpinItem(id)\n                              } else {\n                                newValue = pinItem(id)\n                              }\n\n                              onClickPinUnpin?.({\n                                state: isItemPinned ? 'unpin' : 'pin',\n                                id,\n                                totalPinned: newValue,\n                              })\n                            }\n                          }}\n                          disabled={isItemPinned ? false : isPinDisabled}\n                        >\n                          <PinUnpinIcon\n                            size=\"medium\"\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 && target === '_blank' && !animation ? (\n                <AnimatedIcon\n                  sentiment=\"neutral\"\n                  prominence=\"default\"\n                  disabled={disabled}\n                />\n              ) : null}\n              {children ? (\n                <StackIcon gap={1} direction=\"row\" alignItems=\"center\">\n                  {!animation && !noExpand ? (\n                    <ArrowIcon sentiment=\"neutral\" prominence=\"weak\" />\n                  ) : null}\n                </StackIcon>\n              ) : null}\n            </Stack>\n          </Container>\n          {children ? (\n            <>\n              {!noExpand ? (\n                <ItemProvider>\n                  <Expandable opened={internalExpanded} animationDuration={0}>\n                    <PaddedStack width={animation ? '100%' : undefined}>\n                      {children}\n                    </PaddedStack>\n                  </Expandable>\n                </ItemProvider>\n              ) : (\n                <ItemProvider>\n                  <PaddedStack width={animation ? '100%' : undefined}>\n                    {children}\n                  </PaddedStack>\n                </ItemProvider>\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                  aria-label={label}\n                >\n                  {CategoryIconUsed ? (\n                    <Stack\n                      direction=\"row\"\n                      gap={1}\n                      alignItems=\"center\"\n                      justifyContent=\"center\"\n                    >\n                      <CategoryIconUsed\n                        variant={active ? 'primary' : categoryIconVariant}\n                      />\n                    </Stack>\n                  ) : null}\n                </Button>\n              }\n              placement=\"right\"\n            >\n              <ItemProvider>{children}</ItemProvider>\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                aria-label={label}\n              >\n                <Stack\n                  direction=\"row\"\n                  gap={1}\n                  alignItems=\"center\"\n                  justifyContent=\"center\"\n                >\n                  {CategoryIconUsed ? (\n                    <CategoryIconUsed\n                      variant={active ? 'primary' : categoryIconVariant}\n                    />\n                  ) : (\n                    <ConsoleCategoryIcon\n                      variant={active ? 'primary' : categoryIconVariant}\n                    />\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          target={target}\n          rel={rel}\n          borderless\n          active={active}\n          disabled={disabled}\n          sentiment={active ? 'primary' : 'neutral'}\n          isPinnable={shouldShowPinnedButton}\n          onClick={() => onToggle?.(!!active)}\n        >\n          <Stack\n            gap={1}\n            direction=\"row\"\n            alignItems=\"center\"\n            justifyContent=\"space-between\"\n            flex={1}\n            width=\"100%\"\n          >\n            {!animation ? (\n              <WrapText as=\"span\" variant=\"bodySmall\" whiteSpace=\"pre-wrap\">\n                {label}\n              </WrapText>\n            ) : null}\n            <Stack direction=\"row\">\n              {badgeText && !animation ? (\n                <StyledBadge\n                  sentiment={badgeSentiment}\n                  size=\"small\"\n                  prominence=\"strong\"\n                  disabled={disabled}\n                >\n                  {badgeText}\n                </StyledBadge>\n              ) : null}\n              {hasHrefAndNoChildren && target === '_blank' ? (\n                <AnimatedIcon\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                      aria-label={isItemPinned ? 'unpin' : 'pin'}\n                      variant=\"ghost\"\n                      sentiment={active ? 'primary' : 'neutral'}\n                      onClick={(event: MouseEvent<HTMLDivElement>) => {\n                        if (pinnedItems.length < pinLimit || isItemPinned) {\n                          event.preventDefault()\n                          event.stopPropagation() // This is to avoid click spread to the parent and change the routing\n\n                          let newValue: string[] | undefined\n                          if (isItemPinned) {\n                            newValue = unpinItem(id)\n                          } else {\n                            newValue = pinItem(id)\n                          }\n                          onClickPinUnpin?.({\n                            state: isItemPinned ? 'unpin' : 'pin',\n                            id,\n                            totalPinned: newValue,\n                          })\n                        }\n                      }}\n                      disabled={isItemPinned ? false : isPinDisabled}\n                    >\n                      <PinUnpinIcon\n                        size=\"medium\"\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={target}\n              rel={rel}\n            >\n              <AnimatedIcon sentiment=\"neutral\" prominence=\"weak\" />\n            </Container>\n          </MenuStack>\n        </Tooltip>\n      )\n    }\n\n    return null\n  },\n)\n"]} */",
47
47
  toString: _EMOTION_STRINGIFIED_CSS_ERROR__
48
48
  });
49
49
  const StyledPinIconOutline = /* @__PURE__ */ _styled__default.default(icons.PinOutlineIcon, process.env.NODE_ENV === "production" ? {
@@ -62,7 +62,7 @@ const StyledPinIconOutline = /* @__PURE__ */ _styled__default.default(icons.PinO
62
62
  }) => theme.colors.neutral.backgroundWeakHover, ";", ({
63
63
  active,
64
64
  theme
65
- }) => 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":"AAqDwB","file":"/home/runner/work/ultraviolet/ultraviolet/packages/plus/src/components/Navigation/components/Item.tsx","sourcesContent":["'use client'\n\nimport { css } from '@emotion/react'\nimport styled from '@emotion/styled'\nimport {\n  ArrowDownIcon,\n  ArrowRightIcon,\n  DragIcon,\n  OpenInNewIcon,\n  PinOutlineIcon,\n  UnpinIcon,\n} from '@ultraviolet/icons'\nimport * as CategoryIcon from '@ultraviolet/icons/category'\nimport { ConsoleCategoryIcon } from '@ultraviolet/icons/category'\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  isValidElement,\n  memo,\n  useCallback,\n  useContext,\n  useEffect,\n  useMemo,\n  useReducer,\n} from 'react'\nimport type { PascalToCamelCaseWithoutSuffix } from '../../../types'\nimport { useNavigation } from '../NavigationProvider'\nimport { ANIMATION_DURATION, shrinkHeight } from '../constants'\nimport type { PinUnPinType } from '../types'\nimport { ItemContext, ItemProvider } from './ItemProvider'\n\nconst RelativeDiv = styled.div`\n  position: relative;\n`\n\nconst StyledPinIconOutline = styled(PinOutlineIcon, {\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 }) =>\n      active ? `background: ${theme.colors.primary.backgroundHover};` : null}\n  }\n`\n\nconst StyledUnpinIcon = StyledPinIconOutline.withComponent(UnpinIcon)\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(DragIcon)`\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  &: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(OpenInNewIcon)``\n\nconst WrapText = styled(Text)`\n  overflow-wrap: anywhere;\n  overflow: hidden;\n  display: -webkit-box;\n  -webkit-box-orient: vertical;\n  -webkit-line-clamp: 2;\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 }) => 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\"][data-animation-type=\"complex\"] {\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\"][data-animation-type=\"complex\"] {\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 StackIcon = styled(Stack)`\n  padding-top: ${({ theme }) => theme.space['0.5']};\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?: PascalToCamelCaseWithoutSuffix<\n    keyof typeof CategoryIcon,\n    'CategoryIcon'\n  >\n  categoryIconVariant?: ComponentProps<\n    (typeof CategoryIcon)['BaremetalCategoryIcon']\n  >['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?: HTMLAnchorElement['href']\n  target?: HTMLAnchorElement['target']\n  rel?: HTMLAnchorElement['rel']\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  onToggle?: (toggle: boolean) => void\n  onClickPinUnpin?: (parameters: PinUnPinType) => 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 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  'data-testid'?: string\n}\n\nconst onDragStopTrigger = (event: DragEvent<HTMLDivElement>) => {\n  // eslint-disable-next-line no-param-reassign\n  event.currentTarget.style.opacity = '1'\n}\n\nexport const Item = memo(\n  ({\n    children,\n    categoryIcon,\n    categoryIconVariant,\n    label,\n    subLabel,\n    badgeText,\n    badgeSentiment,\n    href,\n    target,\n    rel,\n    onToggle,\n    onClickPinUnpin,\n    toggle,\n    active,\n    noPinButton,\n    type = 'default',\n    as,\n    disabled,\n    noExpand = false,\n    index,\n    id,\n    'data-testid': dataTestId,\n  }: ItemProps) => {\n    const context = useNavigation()\n    if (!context) {\n      throw new Error(\n        'Navigation.Item can only be used inside a NavigationProvider.',\n      )\n    }\n\n    const itemProvider = useContext(ItemContext)\n    const hasParents = !!itemProvider\n\n    const {\n      expanded,\n      locales,\n      pinnedFeature,\n      pinItem,\n      unpinItem,\n      pinnedItems,\n      pinLimit,\n      animation,\n      registerItem,\n      shouldAnimate,\n      animationType,\n    } = context\n\n    useEffect(\n      () => {\n        if (type !== 'pinnedGroup') {\n          registerItem({ [id]: { label, active, onToggle, onClickPinUnpin } })\n        }\n      },\n      // eslint-disable-next-line react-hooks/exhaustive-deps\n      [active, id, label, registerItem],\n    )\n\n    const [internalExpanded, onToggleExpand] = useReducer(\n      prevState => !prevState,\n      Boolean(toggle),\n    )\n\n    const triggerToggle = useCallback(() => {\n      onToggleExpand()\n      onToggle?.(internalExpanded)\n    }, [internalExpanded, onToggle])\n\n    const PaddedStack =\n      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 = useMemo(\n      () => StyledContainer.withComponent(containerTag),\n      [containerTag],\n    )\n\n    const CategoryIconUsed = categoryIcon\n      ? CategoryIcon[\n          `${\n            categoryIcon.charAt(0).toUpperCase() + categoryIcon.slice(1)\n          }CategoryIcon` as keyof typeof CategoryIcon\n        ]\n      : null\n\n    const ArrowIcon = useMemo(\n      () => (internalExpanded ? ArrowDownIcon : ArrowRightIcon),\n      [internalExpanded],\n    )\n\n    const PinUnpinIcon = useMemo(\n      () => (isItemPinned ? StyledUnpinIcon : StyledPinIconOutline),\n      [isItemPinned],\n    )\n\n    const ariaExpanded = useMemo(() => {\n      if (hasHrefAndNoChildren && internalExpanded) {\n        return true\n      }\n\n      if (hasHrefAndNoChildren && !internalExpanded) {\n        return false\n      }\n\n      return undefined\n    }, [hasHrefAndNoChildren, internalExpanded])\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 onDragStart = useCallback(\n      (event: DragEvent<HTMLDivElement>) => {\n        if (expanded) {\n          event.dataTransfer.setData(\n            'text/plain',\n            JSON.stringify({ label, index }),\n          )\n          // eslint-disable-next-line no-param-reassign\n          event.currentTarget.style.opacity = '0.5'\n        }\n\n        return undefined\n      },\n      [expanded, index, label],\n    )\n\n    const onDragEnd = useCallback(\n      (event: DragEvent<HTMLDivElement>) =>\n        expanded ? onDragStopTrigger(event) : undefined,\n      [expanded],\n    )\n\n    // This content is when the navigation is expanded\n    if (expanded || (!expanded && animation === 'expand')) {\n      return (\n        <>\n          <Container\n            gap={1}\n            direction=\"row\"\n            alignItems={categoryIcon ? 'flex-start' : 'center'}\n            justifyContent=\"space-between\"\n            data-has-sub-label={!!subLabel}\n            onClick={triggerToggle}\n            aria-expanded={ariaExpanded}\n            href={href}\n            target={target}\n            rel={rel}\n            data-is-pinnable={shouldShowPinnedButton}\n            data-is-active={active}\n            data-animation={shouldAnimate ? animation : undefined}\n            data-animation-type={animationType}\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={onDragStart}\n            onDragEnd={onDragEnd}\n            id={id}\n            data-testid={dataTestId}\n          >\n            <Stack\n              direction=\"row\"\n              gap={1}\n              alignItems={categoryIcon ? 'flex-start' : 'center'}\n              justifyContent=\"center\"\n            >\n              {CategoryIconUsed ? (\n                <ContainerCategoryIcon\n                  alignItems=\"center\"\n                  justifyContent=\"center\"\n                >\n                  <CategoryIconUsed\n                    variant={active ? 'primary' : categoryIconVariant}\n                    disabled={disabled}\n                  />\n                </ContainerCategoryIcon>\n              ) : null}\n              {type === 'pinned' && expanded ? (\n                <GrabIcon\n                  sentiment=\"neutral\"\n                  prominence=\"weak\"\n                  size=\"small\"\n                  disabled={disabled}\n                />\n              ) : null}\n              <Stack>\n                {!animation ? (\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                    data-animation={animation}\n                    disabled={disabled}\n                    whiteSpace=\"pre-wrap\"\n                  >\n                    {label}\n                  </WrapText>\n                ) : null}\n                {subLabel && !animation ? (\n                  <WrapText\n                    as=\"span\"\n                    variant=\"caption\"\n                    sentiment=\"neutral\"\n                    prominence=\"weak\"\n                    data-animation={animation}\n                    disabled={disabled}\n                    whiteSpace=\"pre-wrap\"\n                  >\n                    {subLabel}\n                  </WrapText>\n                ) : null}\n              </Stack>\n            </Stack>\n            <Stack\n              direction=\"row\"\n              alignItems=\"center\"\n              gap={href ? 1 : undefined}\n            >\n              {badgeText || hasPinnedFeatureAndNoChildren ? (\n                <>\n                  {badgeText && !animation ? (\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                          aria-label={isItemPinned ? 'unpin' : 'pin'}\n                          size=\"xsmall\"\n                          variant=\"ghost\"\n                          sentiment={active ? 'primary' : 'neutral'}\n                          onClick={(event: MouseEvent<HTMLDivElement>) => {\n                            if (pinnedItems.length < pinLimit || isItemPinned) {\n                              event.preventDefault()\n                              event.stopPropagation() // This is to avoid click spread to the parent and change the routing\n                              let newValue: string[] | undefined\n                              if (isItemPinned) {\n                                newValue = unpinItem(id)\n                              } else {\n                                newValue = pinItem(id)\n                              }\n\n                              onClickPinUnpin?.({\n                                state: isItemPinned ? 'unpin' : 'pin',\n                                id,\n                                totalPinned: newValue,\n                              })\n                            }\n                          }}\n                          disabled={isItemPinned ? false : isPinDisabled}\n                        >\n                          <PinUnpinIcon\n                            size=\"medium\"\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 && target === '_blank' && !animation ? (\n                <AnimatedIcon\n                  sentiment=\"neutral\"\n                  prominence=\"default\"\n                  disabled={disabled}\n                />\n              ) : null}\n              {children ? (\n                <StackIcon gap={1} direction=\"row\" alignItems=\"center\">\n                  {!animation && !noExpand ? (\n                    <ArrowIcon sentiment=\"neutral\" prominence=\"weak\" />\n                  ) : null}\n                </StackIcon>\n              ) : null}\n            </Stack>\n          </Container>\n          {children ? (\n            <>\n              {!noExpand ? (\n                <ItemProvider>\n                  <Expandable opened={internalExpanded} animationDuration={0}>\n                    <PaddedStack width={animation ? '100%' : undefined}>\n                      {children}\n                    </PaddedStack>\n                  </Expandable>\n                </ItemProvider>\n              ) : (\n                <ItemProvider>\n                  <PaddedStack width={animation ? '100%' : undefined}>\n                    {children}\n                  </PaddedStack>\n                </ItemProvider>\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                  aria-label={label}\n                >\n                  {CategoryIconUsed ? (\n                    <Stack\n                      direction=\"row\"\n                      gap={1}\n                      alignItems=\"center\"\n                      justifyContent=\"center\"\n                    >\n                      <CategoryIconUsed\n                        variant={active ? 'primary' : categoryIconVariant}\n                      />\n                    </Stack>\n                  ) : null}\n                </Button>\n              }\n              placement=\"right\"\n            >\n              <ItemProvider>{children}</ItemProvider>\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                aria-label={label}\n              >\n                <Stack\n                  direction=\"row\"\n                  gap={1}\n                  alignItems=\"center\"\n                  justifyContent=\"center\"\n                >\n                  {CategoryIconUsed ? (\n                    <CategoryIconUsed\n                      variant={active ? 'primary' : categoryIconVariant}\n                    />\n                  ) : (\n                    <ConsoleCategoryIcon\n                      variant={active ? 'primary' : categoryIconVariant}\n                    />\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          target={target}\n          rel={rel}\n          borderless\n          active={active}\n          disabled={disabled}\n          sentiment={active ? 'primary' : 'neutral'}\n          isPinnable={shouldShowPinnedButton}\n          onClick={() => onToggle?.(!!active)}\n        >\n          <Stack\n            gap={1}\n            direction=\"row\"\n            alignItems=\"center\"\n            justifyContent=\"space-between\"\n            flex={1}\n            width=\"100%\"\n          >\n            {!animation ? (\n              <WrapText as=\"span\" variant=\"bodySmall\" whiteSpace=\"pre-wrap\">\n                {label}\n              </WrapText>\n            ) : null}\n            <Stack direction=\"row\">\n              {badgeText && !animation ? (\n                <StyledBadge\n                  sentiment={badgeSentiment}\n                  size=\"small\"\n                  prominence=\"strong\"\n                  disabled={disabled}\n                >\n                  {badgeText}\n                </StyledBadge>\n              ) : null}\n              {hasHrefAndNoChildren && target === '_blank' ? (\n                <AnimatedIcon\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                      aria-label={isItemPinned ? 'unpin' : 'pin'}\n                      variant=\"ghost\"\n                      sentiment={active ? 'primary' : 'neutral'}\n                      onClick={(event: MouseEvent<HTMLDivElement>) => {\n                        if (pinnedItems.length < pinLimit || isItemPinned) {\n                          event.preventDefault()\n                          event.stopPropagation() // This is to avoid click spread to the parent and change the routing\n\n                          let newValue: string[] | undefined\n                          if (isItemPinned) {\n                            newValue = unpinItem(id)\n                          } else {\n                            newValue = pinItem(id)\n                          }\n                          onClickPinUnpin?.({\n                            state: isItemPinned ? 'unpin' : 'pin',\n                            id,\n                            totalPinned: newValue,\n                          })\n                        }\n                      }}\n                      disabled={isItemPinned ? false : isPinDisabled}\n                    >\n                      <PinUnpinIcon\n                        size=\"medium\"\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={target}\n              rel={rel}\n            >\n              <AnimatedIcon sentiment=\"neutral\" prominence=\"weak\" />\n            </Container>\n          </MenuStack>\n        </Tooltip>\n      )\n    }\n\n    return null\n  },\n)\n"]} */"));
65
+ }) => 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":"AAqDwB","file":"/home/runner/work/ultraviolet/ultraviolet/packages/plus/src/components/Navigation/components/Item.tsx","sourcesContent":["'use client'\n\nimport { css } from '@emotion/react'\nimport styled from '@emotion/styled'\nimport {\n  ArrowDownIcon,\n  ArrowRightIcon,\n  DragIcon,\n  OpenInNewIcon,\n  PinOutlineIcon,\n  UnpinIcon,\n} from '@ultraviolet/icons'\nimport * as CategoryIcon from '@ultraviolet/icons/category'\nimport { ConsoleCategoryIcon } from '@ultraviolet/icons/category'\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  isValidElement,\n  memo,\n  useCallback,\n  useContext,\n  useEffect,\n  useMemo,\n  useReducer,\n} from 'react'\nimport type { PascalToCamelCaseWithoutSuffix } from '../../../types'\nimport { useNavigation } from '../NavigationProvider'\nimport { ANIMATION_DURATION, shrinkHeight } from '../constants'\nimport type { PinUnPinType } from '../types'\nimport { ItemContext, ItemProvider } from './ItemProvider'\n\nconst RelativeDiv = styled.div`\n  position: relative;\n`\n\nconst StyledPinIconOutline = styled(PinOutlineIcon, {\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 }) =>\n      active ? `background: ${theme.colors.primary.backgroundHover};` : null}\n  }\n`\n\nconst StyledUnpinIcon = StyledPinIconOutline.withComponent(UnpinIcon)\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(DragIcon)`\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  &: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(OpenInNewIcon)``\n\nconst WrapText = styled(Text)`\n  overflow-wrap: anywhere;\n  overflow: hidden;\n  display: -webkit-box;\n  -webkit-box-orient: vertical;\n  -webkit-line-clamp: 2;\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 }) => 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\"][data-animation-type=\"complex\"] {\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\"][data-animation-type=\"complex\"] {\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 StackIcon = styled(Stack)`\n  padding-top: ${({ theme }) => theme.space['0.5']};\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?: PascalToCamelCaseWithoutSuffix<\n    keyof typeof CategoryIcon,\n    'CategoryIcon'\n  >\n  categoryIconVariant?: ComponentProps<\n    (typeof CategoryIcon)['BaremetalCategoryIcon']\n  >['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?: HTMLAnchorElement['href']\n  target?: HTMLAnchorElement['target']\n  rel?: HTMLAnchorElement['rel']\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  onToggle?: (toggle: boolean) => void\n  onClickPinUnpin?: (parameters: PinUnPinType) => 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 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  'data-testid'?: string\n}\n\nconst onDragStopTrigger = (event: DragEvent<HTMLDivElement>) => {\n  // eslint-disable-next-line no-param-reassign\n  event.currentTarget.style.opacity = '1'\n}\n\nexport const Item = memo(\n  ({\n    children,\n    categoryIcon,\n    categoryIconVariant,\n    label,\n    subLabel,\n    badgeText,\n    badgeSentiment,\n    href,\n    target,\n    rel,\n    onToggle,\n    onClickPinUnpin,\n    toggle,\n    active,\n    noPinButton,\n    type = 'default',\n    as,\n    disabled,\n    noExpand = false,\n    index,\n    id,\n    'data-testid': dataTestId,\n  }: ItemProps) => {\n    const context = useNavigation()\n    if (!context) {\n      throw new Error(\n        'Navigation.Item can only be used inside a NavigationProvider.',\n      )\n    }\n\n    const itemProvider = useContext(ItemContext)\n    const hasParents = !!itemProvider\n\n    const {\n      expanded,\n      locales,\n      pinnedFeature,\n      pinItem,\n      unpinItem,\n      pinnedItems,\n      pinLimit,\n      animation,\n      registerItem,\n      shouldAnimate,\n      animationType,\n    } = context\n\n    useEffect(\n      () => {\n        if (type !== 'pinnedGroup' && pinnedFeature) {\n          registerItem({ [id]: { label, active, onToggle, onClickPinUnpin } })\n        }\n      },\n      // eslint-disable-next-line react-hooks/exhaustive-deps\n      [active, id, label, registerItem],\n    )\n\n    const [internalExpanded, onToggleExpand] = useReducer(\n      prevState => !prevState,\n      Boolean(toggle),\n    )\n\n    const triggerToggle = useCallback(() => {\n      onToggleExpand()\n      onToggle?.(internalExpanded)\n    }, [internalExpanded, onToggle])\n\n    const PaddedStack =\n      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 = useMemo(\n      () => StyledContainer.withComponent(containerTag),\n      [containerTag],\n    )\n\n    const CategoryIconUsed = categoryIcon\n      ? CategoryIcon[\n          `${\n            categoryIcon.charAt(0).toUpperCase() + categoryIcon.slice(1)\n          }CategoryIcon` as keyof typeof CategoryIcon\n        ]\n      : null\n\n    const ArrowIcon = useMemo(\n      () => (internalExpanded ? ArrowDownIcon : ArrowRightIcon),\n      [internalExpanded],\n    )\n\n    const PinUnpinIcon = useMemo(\n      () => (isItemPinned ? StyledUnpinIcon : StyledPinIconOutline),\n      [isItemPinned],\n    )\n\n    const ariaExpanded = useMemo(() => {\n      if (hasHrefAndNoChildren && internalExpanded) {\n        return true\n      }\n\n      if (hasHrefAndNoChildren && !internalExpanded) {\n        return false\n      }\n\n      return undefined\n    }, [hasHrefAndNoChildren, internalExpanded])\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 onDragStart = useCallback(\n      (event: DragEvent<HTMLDivElement>) => {\n        if (expanded) {\n          event.dataTransfer.setData(\n            'text/plain',\n            JSON.stringify({ label, index }),\n          )\n          // eslint-disable-next-line no-param-reassign\n          event.currentTarget.style.opacity = '0.5'\n        }\n\n        return undefined\n      },\n      [expanded, index, label],\n    )\n\n    const onDragEnd = useCallback(\n      (event: DragEvent<HTMLDivElement>) =>\n        expanded ? onDragStopTrigger(event) : undefined,\n      [expanded],\n    )\n\n    // This content is when the navigation is expanded\n    if (expanded || (!expanded && animation === 'expand')) {\n      return (\n        <>\n          <Container\n            gap={1}\n            direction=\"row\"\n            alignItems={categoryIcon ? 'flex-start' : 'center'}\n            justifyContent=\"space-between\"\n            data-has-sub-label={!!subLabel}\n            onClick={triggerToggle}\n            aria-expanded={ariaExpanded}\n            href={href}\n            target={target}\n            rel={rel}\n            data-is-pinnable={shouldShowPinnedButton}\n            data-is-active={active}\n            data-animation={shouldAnimate ? animation : undefined}\n            data-animation-type={animationType}\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={onDragStart}\n            onDragEnd={onDragEnd}\n            id={id}\n            data-testid={dataTestId}\n          >\n            <Stack\n              direction=\"row\"\n              gap={1}\n              alignItems={categoryIcon ? 'flex-start' : 'center'}\n              justifyContent=\"center\"\n            >\n              {CategoryIconUsed ? (\n                <ContainerCategoryIcon\n                  alignItems=\"center\"\n                  justifyContent=\"center\"\n                >\n                  <CategoryIconUsed\n                    variant={active ? 'primary' : categoryIconVariant}\n                    disabled={disabled}\n                  />\n                </ContainerCategoryIcon>\n              ) : null}\n              {type === 'pinned' && expanded ? (\n                <GrabIcon\n                  sentiment=\"neutral\"\n                  prominence=\"weak\"\n                  size=\"small\"\n                  disabled={disabled}\n                />\n              ) : null}\n              <Stack>\n                {!animation ? (\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                    data-animation={animation}\n                    disabled={disabled}\n                    whiteSpace=\"pre-wrap\"\n                  >\n                    {label}\n                  </WrapText>\n                ) : null}\n                {subLabel && !animation ? (\n                  <WrapText\n                    as=\"span\"\n                    variant=\"caption\"\n                    sentiment=\"neutral\"\n                    prominence=\"weak\"\n                    data-animation={animation}\n                    disabled={disabled}\n                    whiteSpace=\"pre-wrap\"\n                  >\n                    {subLabel}\n                  </WrapText>\n                ) : null}\n              </Stack>\n            </Stack>\n            <Stack\n              direction=\"row\"\n              alignItems=\"center\"\n              gap={href ? 1 : undefined}\n            >\n              {badgeText || hasPinnedFeatureAndNoChildren ? (\n                <>\n                  {badgeText && !animation ? (\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                          aria-label={isItemPinned ? 'unpin' : 'pin'}\n                          size=\"xsmall\"\n                          variant=\"ghost\"\n                          sentiment={active ? 'primary' : 'neutral'}\n                          onClick={(event: MouseEvent<HTMLDivElement>) => {\n                            if (pinnedItems.length < pinLimit || isItemPinned) {\n                              event.preventDefault()\n                              event.stopPropagation() // This is to avoid click spread to the parent and change the routing\n                              let newValue: string[] | undefined\n                              if (isItemPinned) {\n                                newValue = unpinItem(id)\n                              } else {\n                                newValue = pinItem(id)\n                              }\n\n                              onClickPinUnpin?.({\n                                state: isItemPinned ? 'unpin' : 'pin',\n                                id,\n                                totalPinned: newValue,\n                              })\n                            }\n                          }}\n                          disabled={isItemPinned ? false : isPinDisabled}\n                        >\n                          <PinUnpinIcon\n                            size=\"medium\"\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 && target === '_blank' && !animation ? (\n                <AnimatedIcon\n                  sentiment=\"neutral\"\n                  prominence=\"default\"\n                  disabled={disabled}\n                />\n              ) : null}\n              {children ? (\n                <StackIcon gap={1} direction=\"row\" alignItems=\"center\">\n                  {!animation && !noExpand ? (\n                    <ArrowIcon sentiment=\"neutral\" prominence=\"weak\" />\n                  ) : null}\n                </StackIcon>\n              ) : null}\n            </Stack>\n          </Container>\n          {children ? (\n            <>\n              {!noExpand ? (\n                <ItemProvider>\n                  <Expandable opened={internalExpanded} animationDuration={0}>\n                    <PaddedStack width={animation ? '100%' : undefined}>\n                      {children}\n                    </PaddedStack>\n                  </Expandable>\n                </ItemProvider>\n              ) : (\n                <ItemProvider>\n                  <PaddedStack width={animation ? '100%' : undefined}>\n                    {children}\n                  </PaddedStack>\n                </ItemProvider>\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                  aria-label={label}\n                >\n                  {CategoryIconUsed ? (\n                    <Stack\n                      direction=\"row\"\n                      gap={1}\n                      alignItems=\"center\"\n                      justifyContent=\"center\"\n                    >\n                      <CategoryIconUsed\n                        variant={active ? 'primary' : categoryIconVariant}\n                      />\n                    </Stack>\n                  ) : null}\n                </Button>\n              }\n              placement=\"right\"\n            >\n              <ItemProvider>{children}</ItemProvider>\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                aria-label={label}\n              >\n                <Stack\n                  direction=\"row\"\n                  gap={1}\n                  alignItems=\"center\"\n                  justifyContent=\"center\"\n                >\n                  {CategoryIconUsed ? (\n                    <CategoryIconUsed\n                      variant={active ? 'primary' : categoryIconVariant}\n                    />\n                  ) : (\n                    <ConsoleCategoryIcon\n                      variant={active ? 'primary' : categoryIconVariant}\n                    />\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          target={target}\n          rel={rel}\n          borderless\n          active={active}\n          disabled={disabled}\n          sentiment={active ? 'primary' : 'neutral'}\n          isPinnable={shouldShowPinnedButton}\n          onClick={() => onToggle?.(!!active)}\n        >\n          <Stack\n            gap={1}\n            direction=\"row\"\n            alignItems=\"center\"\n            justifyContent=\"space-between\"\n            flex={1}\n            width=\"100%\"\n          >\n            {!animation ? (\n              <WrapText as=\"span\" variant=\"bodySmall\" whiteSpace=\"pre-wrap\">\n                {label}\n              </WrapText>\n            ) : null}\n            <Stack direction=\"row\">\n              {badgeText && !animation ? (\n                <StyledBadge\n                  sentiment={badgeSentiment}\n                  size=\"small\"\n                  prominence=\"strong\"\n                  disabled={disabled}\n                >\n                  {badgeText}\n                </StyledBadge>\n              ) : null}\n              {hasHrefAndNoChildren && target === '_blank' ? (\n                <AnimatedIcon\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                      aria-label={isItemPinned ? 'unpin' : 'pin'}\n                      variant=\"ghost\"\n                      sentiment={active ? 'primary' : 'neutral'}\n                      onClick={(event: MouseEvent<HTMLDivElement>) => {\n                        if (pinnedItems.length < pinLimit || isItemPinned) {\n                          event.preventDefault()\n                          event.stopPropagation() // This is to avoid click spread to the parent and change the routing\n\n                          let newValue: string[] | undefined\n                          if (isItemPinned) {\n                            newValue = unpinItem(id)\n                          } else {\n                            newValue = pinItem(id)\n                          }\n                          onClickPinUnpin?.({\n                            state: isItemPinned ? 'unpin' : 'pin',\n                            id,\n                            totalPinned: newValue,\n                          })\n                        }\n                      }}\n                      disabled={isItemPinned ? false : isPinDisabled}\n                    >\n                      <PinUnpinIcon\n                        size=\"medium\"\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={target}\n              rel={rel}\n            >\n              <AnimatedIcon sentiment=\"neutral\" prominence=\"weak\" />\n            </Container>\n          </MenuStack>\n        </Tooltip>\n      )\n    }\n\n    return null\n  },\n)\n"]} */"));
66
66
  const StyledUnpinIcon = StyledPinIconOutline.withComponent(icons.UnpinIcon, process.env.NODE_ENV === "production" ? {
67
67
  target: "e134hokc15"
68
68
  } : {
@@ -74,7 +74,7 @@ const NeutralButtonLink = process.env.NODE_ENV === "production" ? {
74
74
  styles: "color:inherit;text-decoration:none;background-color:inherit;border:none;text-align:left"
75
75
  } : {
76
76
  name: "1kb8ns1-NeutralButtonLink",
77
- styles: "color:inherit;text-decoration:none;background-color:inherit;border:none;text-align:left;label:NeutralButtonLink;/*# 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":"AAsE6B","file":"/home/runner/work/ultraviolet/ultraviolet/packages/plus/src/components/Navigation/components/Item.tsx","sourcesContent":["'use client'\n\nimport { css } from '@emotion/react'\nimport styled from '@emotion/styled'\nimport {\n  ArrowDownIcon,\n  ArrowRightIcon,\n  DragIcon,\n  OpenInNewIcon,\n  PinOutlineIcon,\n  UnpinIcon,\n} from '@ultraviolet/icons'\nimport * as CategoryIcon from '@ultraviolet/icons/category'\nimport { ConsoleCategoryIcon } from '@ultraviolet/icons/category'\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  isValidElement,\n  memo,\n  useCallback,\n  useContext,\n  useEffect,\n  useMemo,\n  useReducer,\n} from 'react'\nimport type { PascalToCamelCaseWithoutSuffix } from '../../../types'\nimport { useNavigation } from '../NavigationProvider'\nimport { ANIMATION_DURATION, shrinkHeight } from '../constants'\nimport type { PinUnPinType } from '../types'\nimport { ItemContext, ItemProvider } from './ItemProvider'\n\nconst RelativeDiv = styled.div`\n  position: relative;\n`\n\nconst StyledPinIconOutline = styled(PinOutlineIcon, {\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 }) =>\n      active ? `background: ${theme.colors.primary.backgroundHover};` : null}\n  }\n`\n\nconst StyledUnpinIcon = StyledPinIconOutline.withComponent(UnpinIcon)\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(DragIcon)`\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  &: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(OpenInNewIcon)``\n\nconst WrapText = styled(Text)`\n  overflow-wrap: anywhere;\n  overflow: hidden;\n  display: -webkit-box;\n  -webkit-box-orient: vertical;\n  -webkit-line-clamp: 2;\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 }) => 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\"][data-animation-type=\"complex\"] {\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\"][data-animation-type=\"complex\"] {\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 StackIcon = styled(Stack)`\n  padding-top: ${({ theme }) => theme.space['0.5']};\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?: PascalToCamelCaseWithoutSuffix<\n    keyof typeof CategoryIcon,\n    'CategoryIcon'\n  >\n  categoryIconVariant?: ComponentProps<\n    (typeof CategoryIcon)['BaremetalCategoryIcon']\n  >['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?: HTMLAnchorElement['href']\n  target?: HTMLAnchorElement['target']\n  rel?: HTMLAnchorElement['rel']\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  onToggle?: (toggle: boolean) => void\n  onClickPinUnpin?: (parameters: PinUnPinType) => 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 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  'data-testid'?: string\n}\n\nconst onDragStopTrigger = (event: DragEvent<HTMLDivElement>) => {\n  // eslint-disable-next-line no-param-reassign\n  event.currentTarget.style.opacity = '1'\n}\n\nexport const Item = memo(\n  ({\n    children,\n    categoryIcon,\n    categoryIconVariant,\n    label,\n    subLabel,\n    badgeText,\n    badgeSentiment,\n    href,\n    target,\n    rel,\n    onToggle,\n    onClickPinUnpin,\n    toggle,\n    active,\n    noPinButton,\n    type = 'default',\n    as,\n    disabled,\n    noExpand = false,\n    index,\n    id,\n    'data-testid': dataTestId,\n  }: ItemProps) => {\n    const context = useNavigation()\n    if (!context) {\n      throw new Error(\n        'Navigation.Item can only be used inside a NavigationProvider.',\n      )\n    }\n\n    const itemProvider = useContext(ItemContext)\n    const hasParents = !!itemProvider\n\n    const {\n      expanded,\n      locales,\n      pinnedFeature,\n      pinItem,\n      unpinItem,\n      pinnedItems,\n      pinLimit,\n      animation,\n      registerItem,\n      shouldAnimate,\n      animationType,\n    } = context\n\n    useEffect(\n      () => {\n        if (type !== 'pinnedGroup') {\n          registerItem({ [id]: { label, active, onToggle, onClickPinUnpin } })\n        }\n      },\n      // eslint-disable-next-line react-hooks/exhaustive-deps\n      [active, id, label, registerItem],\n    )\n\n    const [internalExpanded, onToggleExpand] = useReducer(\n      prevState => !prevState,\n      Boolean(toggle),\n    )\n\n    const triggerToggle = useCallback(() => {\n      onToggleExpand()\n      onToggle?.(internalExpanded)\n    }, [internalExpanded, onToggle])\n\n    const PaddedStack =\n      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 = useMemo(\n      () => StyledContainer.withComponent(containerTag),\n      [containerTag],\n    )\n\n    const CategoryIconUsed = categoryIcon\n      ? CategoryIcon[\n          `${\n            categoryIcon.charAt(0).toUpperCase() + categoryIcon.slice(1)\n          }CategoryIcon` as keyof typeof CategoryIcon\n        ]\n      : null\n\n    const ArrowIcon = useMemo(\n      () => (internalExpanded ? ArrowDownIcon : ArrowRightIcon),\n      [internalExpanded],\n    )\n\n    const PinUnpinIcon = useMemo(\n      () => (isItemPinned ? StyledUnpinIcon : StyledPinIconOutline),\n      [isItemPinned],\n    )\n\n    const ariaExpanded = useMemo(() => {\n      if (hasHrefAndNoChildren && internalExpanded) {\n        return true\n      }\n\n      if (hasHrefAndNoChildren && !internalExpanded) {\n        return false\n      }\n\n      return undefined\n    }, [hasHrefAndNoChildren, internalExpanded])\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 onDragStart = useCallback(\n      (event: DragEvent<HTMLDivElement>) => {\n        if (expanded) {\n          event.dataTransfer.setData(\n            'text/plain',\n            JSON.stringify({ label, index }),\n          )\n          // eslint-disable-next-line no-param-reassign\n          event.currentTarget.style.opacity = '0.5'\n        }\n\n        return undefined\n      },\n      [expanded, index, label],\n    )\n\n    const onDragEnd = useCallback(\n      (event: DragEvent<HTMLDivElement>) =>\n        expanded ? onDragStopTrigger(event) : undefined,\n      [expanded],\n    )\n\n    // This content is when the navigation is expanded\n    if (expanded || (!expanded && animation === 'expand')) {\n      return (\n        <>\n          <Container\n            gap={1}\n            direction=\"row\"\n            alignItems={categoryIcon ? 'flex-start' : 'center'}\n            justifyContent=\"space-between\"\n            data-has-sub-label={!!subLabel}\n            onClick={triggerToggle}\n            aria-expanded={ariaExpanded}\n            href={href}\n            target={target}\n            rel={rel}\n            data-is-pinnable={shouldShowPinnedButton}\n            data-is-active={active}\n            data-animation={shouldAnimate ? animation : undefined}\n            data-animation-type={animationType}\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={onDragStart}\n            onDragEnd={onDragEnd}\n            id={id}\n            data-testid={dataTestId}\n          >\n            <Stack\n              direction=\"row\"\n              gap={1}\n              alignItems={categoryIcon ? 'flex-start' : 'center'}\n              justifyContent=\"center\"\n            >\n              {CategoryIconUsed ? (\n                <ContainerCategoryIcon\n                  alignItems=\"center\"\n                  justifyContent=\"center\"\n                >\n                  <CategoryIconUsed\n                    variant={active ? 'primary' : categoryIconVariant}\n                    disabled={disabled}\n                  />\n                </ContainerCategoryIcon>\n              ) : null}\n              {type === 'pinned' && expanded ? (\n                <GrabIcon\n                  sentiment=\"neutral\"\n                  prominence=\"weak\"\n                  size=\"small\"\n                  disabled={disabled}\n                />\n              ) : null}\n              <Stack>\n                {!animation ? (\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                    data-animation={animation}\n                    disabled={disabled}\n                    whiteSpace=\"pre-wrap\"\n                  >\n                    {label}\n                  </WrapText>\n                ) : null}\n                {subLabel && !animation ? (\n                  <WrapText\n                    as=\"span\"\n                    variant=\"caption\"\n                    sentiment=\"neutral\"\n                    prominence=\"weak\"\n                    data-animation={animation}\n                    disabled={disabled}\n                    whiteSpace=\"pre-wrap\"\n                  >\n                    {subLabel}\n                  </WrapText>\n                ) : null}\n              </Stack>\n            </Stack>\n            <Stack\n              direction=\"row\"\n              alignItems=\"center\"\n              gap={href ? 1 : undefined}\n            >\n              {badgeText || hasPinnedFeatureAndNoChildren ? (\n                <>\n                  {badgeText && !animation ? (\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                          aria-label={isItemPinned ? 'unpin' : 'pin'}\n                          size=\"xsmall\"\n                          variant=\"ghost\"\n                          sentiment={active ? 'primary' : 'neutral'}\n                          onClick={(event: MouseEvent<HTMLDivElement>) => {\n                            if (pinnedItems.length < pinLimit || isItemPinned) {\n                              event.preventDefault()\n                              event.stopPropagation() // This is to avoid click spread to the parent and change the routing\n                              let newValue: string[] | undefined\n                              if (isItemPinned) {\n                                newValue = unpinItem(id)\n                              } else {\n                                newValue = pinItem(id)\n                              }\n\n                              onClickPinUnpin?.({\n                                state: isItemPinned ? 'unpin' : 'pin',\n                                id,\n                                totalPinned: newValue,\n                              })\n                            }\n                          }}\n                          disabled={isItemPinned ? false : isPinDisabled}\n                        >\n                          <PinUnpinIcon\n                            size=\"medium\"\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 && target === '_blank' && !animation ? (\n                <AnimatedIcon\n                  sentiment=\"neutral\"\n                  prominence=\"default\"\n                  disabled={disabled}\n                />\n              ) : null}\n              {children ? (\n                <StackIcon gap={1} direction=\"row\" alignItems=\"center\">\n                  {!animation && !noExpand ? (\n                    <ArrowIcon sentiment=\"neutral\" prominence=\"weak\" />\n                  ) : null}\n                </StackIcon>\n              ) : null}\n            </Stack>\n          </Container>\n          {children ? (\n            <>\n              {!noExpand ? (\n                <ItemProvider>\n                  <Expandable opened={internalExpanded} animationDuration={0}>\n                    <PaddedStack width={animation ? '100%' : undefined}>\n                      {children}\n                    </PaddedStack>\n                  </Expandable>\n                </ItemProvider>\n              ) : (\n                <ItemProvider>\n                  <PaddedStack width={animation ? '100%' : undefined}>\n                    {children}\n                  </PaddedStack>\n                </ItemProvider>\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                  aria-label={label}\n                >\n                  {CategoryIconUsed ? (\n                    <Stack\n                      direction=\"row\"\n                      gap={1}\n                      alignItems=\"center\"\n                      justifyContent=\"center\"\n                    >\n                      <CategoryIconUsed\n                        variant={active ? 'primary' : categoryIconVariant}\n                      />\n                    </Stack>\n                  ) : null}\n                </Button>\n              }\n              placement=\"right\"\n            >\n              <ItemProvider>{children}</ItemProvider>\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                aria-label={label}\n              >\n                <Stack\n                  direction=\"row\"\n                  gap={1}\n                  alignItems=\"center\"\n                  justifyContent=\"center\"\n                >\n                  {CategoryIconUsed ? (\n                    <CategoryIconUsed\n                      variant={active ? 'primary' : categoryIconVariant}\n                    />\n                  ) : (\n                    <ConsoleCategoryIcon\n                      variant={active ? 'primary' : categoryIconVariant}\n                    />\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          target={target}\n          rel={rel}\n          borderless\n          active={active}\n          disabled={disabled}\n          sentiment={active ? 'primary' : 'neutral'}\n          isPinnable={shouldShowPinnedButton}\n          onClick={() => onToggle?.(!!active)}\n        >\n          <Stack\n            gap={1}\n            direction=\"row\"\n            alignItems=\"center\"\n            justifyContent=\"space-between\"\n            flex={1}\n            width=\"100%\"\n          >\n            {!animation ? (\n              <WrapText as=\"span\" variant=\"bodySmall\" whiteSpace=\"pre-wrap\">\n                {label}\n              </WrapText>\n            ) : null}\n            <Stack direction=\"row\">\n              {badgeText && !animation ? (\n                <StyledBadge\n                  sentiment={badgeSentiment}\n                  size=\"small\"\n                  prominence=\"strong\"\n                  disabled={disabled}\n                >\n                  {badgeText}\n                </StyledBadge>\n              ) : null}\n              {hasHrefAndNoChildren && target === '_blank' ? (\n                <AnimatedIcon\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                      aria-label={isItemPinned ? 'unpin' : 'pin'}\n                      variant=\"ghost\"\n                      sentiment={active ? 'primary' : 'neutral'}\n                      onClick={(event: MouseEvent<HTMLDivElement>) => {\n                        if (pinnedItems.length < pinLimit || isItemPinned) {\n                          event.preventDefault()\n                          event.stopPropagation() // This is to avoid click spread to the parent and change the routing\n\n                          let newValue: string[] | undefined\n                          if (isItemPinned) {\n                            newValue = unpinItem(id)\n                          } else {\n                            newValue = pinItem(id)\n                          }\n                          onClickPinUnpin?.({\n                            state: isItemPinned ? 'unpin' : 'pin',\n                            id,\n                            totalPinned: newValue,\n                          })\n                        }\n                      }}\n                      disabled={isItemPinned ? false : isPinDisabled}\n                    >\n                      <PinUnpinIcon\n                        size=\"medium\"\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={target}\n              rel={rel}\n            >\n              <AnimatedIcon sentiment=\"neutral\" prominence=\"weak\" />\n            </Container>\n          </MenuStack>\n        </Tooltip>\n      )\n    }\n\n    return null\n  },\n)\n"]} */",
77
+ styles: "color:inherit;text-decoration:none;background-color:inherit;border:none;text-align:left;label:NeutralButtonLink;/*# 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":"AAsE6B","file":"/home/runner/work/ultraviolet/ultraviolet/packages/plus/src/components/Navigation/components/Item.tsx","sourcesContent":["'use client'\n\nimport { css } from '@emotion/react'\nimport styled from '@emotion/styled'\nimport {\n  ArrowDownIcon,\n  ArrowRightIcon,\n  DragIcon,\n  OpenInNewIcon,\n  PinOutlineIcon,\n  UnpinIcon,\n} from '@ultraviolet/icons'\nimport * as CategoryIcon from '@ultraviolet/icons/category'\nimport { ConsoleCategoryIcon } from '@ultraviolet/icons/category'\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  isValidElement,\n  memo,\n  useCallback,\n  useContext,\n  useEffect,\n  useMemo,\n  useReducer,\n} from 'react'\nimport type { PascalToCamelCaseWithoutSuffix } from '../../../types'\nimport { useNavigation } from '../NavigationProvider'\nimport { ANIMATION_DURATION, shrinkHeight } from '../constants'\nimport type { PinUnPinType } from '../types'\nimport { ItemContext, ItemProvider } from './ItemProvider'\n\nconst RelativeDiv = styled.div`\n  position: relative;\n`\n\nconst StyledPinIconOutline = styled(PinOutlineIcon, {\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 }) =>\n      active ? `background: ${theme.colors.primary.backgroundHover};` : null}\n  }\n`\n\nconst StyledUnpinIcon = StyledPinIconOutline.withComponent(UnpinIcon)\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(DragIcon)`\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  &: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(OpenInNewIcon)``\n\nconst WrapText = styled(Text)`\n  overflow-wrap: anywhere;\n  overflow: hidden;\n  display: -webkit-box;\n  -webkit-box-orient: vertical;\n  -webkit-line-clamp: 2;\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 }) => 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\"][data-animation-type=\"complex\"] {\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\"][data-animation-type=\"complex\"] {\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 StackIcon = styled(Stack)`\n  padding-top: ${({ theme }) => theme.space['0.5']};\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?: PascalToCamelCaseWithoutSuffix<\n    keyof typeof CategoryIcon,\n    'CategoryIcon'\n  >\n  categoryIconVariant?: ComponentProps<\n    (typeof CategoryIcon)['BaremetalCategoryIcon']\n  >['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?: HTMLAnchorElement['href']\n  target?: HTMLAnchorElement['target']\n  rel?: HTMLAnchorElement['rel']\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  onToggle?: (toggle: boolean) => void\n  onClickPinUnpin?: (parameters: PinUnPinType) => 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 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  'data-testid'?: string\n}\n\nconst onDragStopTrigger = (event: DragEvent<HTMLDivElement>) => {\n  // eslint-disable-next-line no-param-reassign\n  event.currentTarget.style.opacity = '1'\n}\n\nexport const Item = memo(\n  ({\n    children,\n    categoryIcon,\n    categoryIconVariant,\n    label,\n    subLabel,\n    badgeText,\n    badgeSentiment,\n    href,\n    target,\n    rel,\n    onToggle,\n    onClickPinUnpin,\n    toggle,\n    active,\n    noPinButton,\n    type = 'default',\n    as,\n    disabled,\n    noExpand = false,\n    index,\n    id,\n    'data-testid': dataTestId,\n  }: ItemProps) => {\n    const context = useNavigation()\n    if (!context) {\n      throw new Error(\n        'Navigation.Item can only be used inside a NavigationProvider.',\n      )\n    }\n\n    const itemProvider = useContext(ItemContext)\n    const hasParents = !!itemProvider\n\n    const {\n      expanded,\n      locales,\n      pinnedFeature,\n      pinItem,\n      unpinItem,\n      pinnedItems,\n      pinLimit,\n      animation,\n      registerItem,\n      shouldAnimate,\n      animationType,\n    } = context\n\n    useEffect(\n      () => {\n        if (type !== 'pinnedGroup' && pinnedFeature) {\n          registerItem({ [id]: { label, active, onToggle, onClickPinUnpin } })\n        }\n      },\n      // eslint-disable-next-line react-hooks/exhaustive-deps\n      [active, id, label, registerItem],\n    )\n\n    const [internalExpanded, onToggleExpand] = useReducer(\n      prevState => !prevState,\n      Boolean(toggle),\n    )\n\n    const triggerToggle = useCallback(() => {\n      onToggleExpand()\n      onToggle?.(internalExpanded)\n    }, [internalExpanded, onToggle])\n\n    const PaddedStack =\n      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 = useMemo(\n      () => StyledContainer.withComponent(containerTag),\n      [containerTag],\n    )\n\n    const CategoryIconUsed = categoryIcon\n      ? CategoryIcon[\n          `${\n            categoryIcon.charAt(0).toUpperCase() + categoryIcon.slice(1)\n          }CategoryIcon` as keyof typeof CategoryIcon\n        ]\n      : null\n\n    const ArrowIcon = useMemo(\n      () => (internalExpanded ? ArrowDownIcon : ArrowRightIcon),\n      [internalExpanded],\n    )\n\n    const PinUnpinIcon = useMemo(\n      () => (isItemPinned ? StyledUnpinIcon : StyledPinIconOutline),\n      [isItemPinned],\n    )\n\n    const ariaExpanded = useMemo(() => {\n      if (hasHrefAndNoChildren && internalExpanded) {\n        return true\n      }\n\n      if (hasHrefAndNoChildren && !internalExpanded) {\n        return false\n      }\n\n      return undefined\n    }, [hasHrefAndNoChildren, internalExpanded])\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 onDragStart = useCallback(\n      (event: DragEvent<HTMLDivElement>) => {\n        if (expanded) {\n          event.dataTransfer.setData(\n            'text/plain',\n            JSON.stringify({ label, index }),\n          )\n          // eslint-disable-next-line no-param-reassign\n          event.currentTarget.style.opacity = '0.5'\n        }\n\n        return undefined\n      },\n      [expanded, index, label],\n    )\n\n    const onDragEnd = useCallback(\n      (event: DragEvent<HTMLDivElement>) =>\n        expanded ? onDragStopTrigger(event) : undefined,\n      [expanded],\n    )\n\n    // This content is when the navigation is expanded\n    if (expanded || (!expanded && animation === 'expand')) {\n      return (\n        <>\n          <Container\n            gap={1}\n            direction=\"row\"\n            alignItems={categoryIcon ? 'flex-start' : 'center'}\n            justifyContent=\"space-between\"\n            data-has-sub-label={!!subLabel}\n            onClick={triggerToggle}\n            aria-expanded={ariaExpanded}\n            href={href}\n            target={target}\n            rel={rel}\n            data-is-pinnable={shouldShowPinnedButton}\n            data-is-active={active}\n            data-animation={shouldAnimate ? animation : undefined}\n            data-animation-type={animationType}\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={onDragStart}\n            onDragEnd={onDragEnd}\n            id={id}\n            data-testid={dataTestId}\n          >\n            <Stack\n              direction=\"row\"\n              gap={1}\n              alignItems={categoryIcon ? 'flex-start' : 'center'}\n              justifyContent=\"center\"\n            >\n              {CategoryIconUsed ? (\n                <ContainerCategoryIcon\n                  alignItems=\"center\"\n                  justifyContent=\"center\"\n                >\n                  <CategoryIconUsed\n                    variant={active ? 'primary' : categoryIconVariant}\n                    disabled={disabled}\n                  />\n                </ContainerCategoryIcon>\n              ) : null}\n              {type === 'pinned' && expanded ? (\n                <GrabIcon\n                  sentiment=\"neutral\"\n                  prominence=\"weak\"\n                  size=\"small\"\n                  disabled={disabled}\n                />\n              ) : null}\n              <Stack>\n                {!animation ? (\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                    data-animation={animation}\n                    disabled={disabled}\n                    whiteSpace=\"pre-wrap\"\n                  >\n                    {label}\n                  </WrapText>\n                ) : null}\n                {subLabel && !animation ? (\n                  <WrapText\n                    as=\"span\"\n                    variant=\"caption\"\n                    sentiment=\"neutral\"\n                    prominence=\"weak\"\n                    data-animation={animation}\n                    disabled={disabled}\n                    whiteSpace=\"pre-wrap\"\n                  >\n                    {subLabel}\n                  </WrapText>\n                ) : null}\n              </Stack>\n            </Stack>\n            <Stack\n              direction=\"row\"\n              alignItems=\"center\"\n              gap={href ? 1 : undefined}\n            >\n              {badgeText || hasPinnedFeatureAndNoChildren ? (\n                <>\n                  {badgeText && !animation ? (\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                          aria-label={isItemPinned ? 'unpin' : 'pin'}\n                          size=\"xsmall\"\n                          variant=\"ghost\"\n                          sentiment={active ? 'primary' : 'neutral'}\n                          onClick={(event: MouseEvent<HTMLDivElement>) => {\n                            if (pinnedItems.length < pinLimit || isItemPinned) {\n                              event.preventDefault()\n                              event.stopPropagation() // This is to avoid click spread to the parent and change the routing\n                              let newValue: string[] | undefined\n                              if (isItemPinned) {\n                                newValue = unpinItem(id)\n                              } else {\n                                newValue = pinItem(id)\n                              }\n\n                              onClickPinUnpin?.({\n                                state: isItemPinned ? 'unpin' : 'pin',\n                                id,\n                                totalPinned: newValue,\n                              })\n                            }\n                          }}\n                          disabled={isItemPinned ? false : isPinDisabled}\n                        >\n                          <PinUnpinIcon\n                            size=\"medium\"\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 && target === '_blank' && !animation ? (\n                <AnimatedIcon\n                  sentiment=\"neutral\"\n                  prominence=\"default\"\n                  disabled={disabled}\n                />\n              ) : null}\n              {children ? (\n                <StackIcon gap={1} direction=\"row\" alignItems=\"center\">\n                  {!animation && !noExpand ? (\n                    <ArrowIcon sentiment=\"neutral\" prominence=\"weak\" />\n                  ) : null}\n                </StackIcon>\n              ) : null}\n            </Stack>\n          </Container>\n          {children ? (\n            <>\n              {!noExpand ? (\n                <ItemProvider>\n                  <Expandable opened={internalExpanded} animationDuration={0}>\n                    <PaddedStack width={animation ? '100%' : undefined}>\n                      {children}\n                    </PaddedStack>\n                  </Expandable>\n                </ItemProvider>\n              ) : (\n                <ItemProvider>\n                  <PaddedStack width={animation ? '100%' : undefined}>\n                    {children}\n                  </PaddedStack>\n                </ItemProvider>\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                  aria-label={label}\n                >\n                  {CategoryIconUsed ? (\n                    <Stack\n                      direction=\"row\"\n                      gap={1}\n                      alignItems=\"center\"\n                      justifyContent=\"center\"\n                    >\n                      <CategoryIconUsed\n                        variant={active ? 'primary' : categoryIconVariant}\n                      />\n                    </Stack>\n                  ) : null}\n                </Button>\n              }\n              placement=\"right\"\n            >\n              <ItemProvider>{children}</ItemProvider>\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                aria-label={label}\n              >\n                <Stack\n                  direction=\"row\"\n                  gap={1}\n                  alignItems=\"center\"\n                  justifyContent=\"center\"\n                >\n                  {CategoryIconUsed ? (\n                    <CategoryIconUsed\n                      variant={active ? 'primary' : categoryIconVariant}\n                    />\n                  ) : (\n                    <ConsoleCategoryIcon\n                      variant={active ? 'primary' : categoryIconVariant}\n                    />\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          target={target}\n          rel={rel}\n          borderless\n          active={active}\n          disabled={disabled}\n          sentiment={active ? 'primary' : 'neutral'}\n          isPinnable={shouldShowPinnedButton}\n          onClick={() => onToggle?.(!!active)}\n        >\n          <Stack\n            gap={1}\n            direction=\"row\"\n            alignItems=\"center\"\n            justifyContent=\"space-between\"\n            flex={1}\n            width=\"100%\"\n          >\n            {!animation ? (\n              <WrapText as=\"span\" variant=\"bodySmall\" whiteSpace=\"pre-wrap\">\n                {label}\n              </WrapText>\n            ) : null}\n            <Stack direction=\"row\">\n              {badgeText && !animation ? (\n                <StyledBadge\n                  sentiment={badgeSentiment}\n                  size=\"small\"\n                  prominence=\"strong\"\n                  disabled={disabled}\n                >\n                  {badgeText}\n                </StyledBadge>\n              ) : null}\n              {hasHrefAndNoChildren && target === '_blank' ? (\n                <AnimatedIcon\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                      aria-label={isItemPinned ? 'unpin' : 'pin'}\n                      variant=\"ghost\"\n                      sentiment={active ? 'primary' : 'neutral'}\n                      onClick={(event: MouseEvent<HTMLDivElement>) => {\n                        if (pinnedItems.length < pinLimit || isItemPinned) {\n                          event.preventDefault()\n                          event.stopPropagation() // This is to avoid click spread to the parent and change the routing\n\n                          let newValue: string[] | undefined\n                          if (isItemPinned) {\n                            newValue = unpinItem(id)\n                          } else {\n                            newValue = pinItem(id)\n                          }\n                          onClickPinUnpin?.({\n                            state: isItemPinned ? 'unpin' : 'pin',\n                            id,\n                            totalPinned: newValue,\n                          })\n                        }\n                      }}\n                      disabled={isItemPinned ? false : isPinDisabled}\n                    >\n                      <PinUnpinIcon\n                        size=\"medium\"\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={target}\n              rel={rel}\n            >\n              <AnimatedIcon sentiment=\"neutral\" prominence=\"weak\" />\n            </Container>\n          </MenuStack>\n        </Tooltip>\n      )\n    }\n\n    return null\n  },\n)\n"]} */",
78
78
  toString: _EMOTION_STRINGIFIED_CSS_ERROR__
79
79
  };
80
80
  const LocalExpandButton = /* @__PURE__ */ _styled__default.default(ui.Button, process.env.NODE_ENV === "production" ? {
@@ -87,7 +87,7 @@ const LocalExpandButton = /* @__PURE__ */ _styled__default.default(ui.Button, pr
87
87
  styles: "opacity:0;right:0;position:absolute;left:-24px;top:0;bottom:0;margin:auto;&:hover,&:focus,&:active{opacity:1;}"
88
88
  } : {
89
89
  name: "9hkyle",
90
- styles: "opacity:0;right:0;position:absolute;left:-24px;top:0;bottom:0;margin:auto;&:hover,&:focus,&:active{opacity:1;}/*# 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":"AA+EwC","file":"/home/runner/work/ultraviolet/ultraviolet/packages/plus/src/components/Navigation/components/Item.tsx","sourcesContent":["'use client'\n\nimport { css } from '@emotion/react'\nimport styled from '@emotion/styled'\nimport {\n  ArrowDownIcon,\n  ArrowRightIcon,\n  DragIcon,\n  OpenInNewIcon,\n  PinOutlineIcon,\n  UnpinIcon,\n} from '@ultraviolet/icons'\nimport * as CategoryIcon from '@ultraviolet/icons/category'\nimport { ConsoleCategoryIcon } from '@ultraviolet/icons/category'\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  isValidElement,\n  memo,\n  useCallback,\n  useContext,\n  useEffect,\n  useMemo,\n  useReducer,\n} from 'react'\nimport type { PascalToCamelCaseWithoutSuffix } from '../../../types'\nimport { useNavigation } from '../NavigationProvider'\nimport { ANIMATION_DURATION, shrinkHeight } from '../constants'\nimport type { PinUnPinType } from '../types'\nimport { ItemContext, ItemProvider } from './ItemProvider'\n\nconst RelativeDiv = styled.div`\n  position: relative;\n`\n\nconst StyledPinIconOutline = styled(PinOutlineIcon, {\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 }) =>\n      active ? `background: ${theme.colors.primary.backgroundHover};` : null}\n  }\n`\n\nconst StyledUnpinIcon = StyledPinIconOutline.withComponent(UnpinIcon)\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(DragIcon)`\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  &: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(OpenInNewIcon)``\n\nconst WrapText = styled(Text)`\n  overflow-wrap: anywhere;\n  overflow: hidden;\n  display: -webkit-box;\n  -webkit-box-orient: vertical;\n  -webkit-line-clamp: 2;\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 }) => 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\"][data-animation-type=\"complex\"] {\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\"][data-animation-type=\"complex\"] {\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 StackIcon = styled(Stack)`\n  padding-top: ${({ theme }) => theme.space['0.5']};\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?: PascalToCamelCaseWithoutSuffix<\n    keyof typeof CategoryIcon,\n    'CategoryIcon'\n  >\n  categoryIconVariant?: ComponentProps<\n    (typeof CategoryIcon)['BaremetalCategoryIcon']\n  >['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?: HTMLAnchorElement['href']\n  target?: HTMLAnchorElement['target']\n  rel?: HTMLAnchorElement['rel']\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  onToggle?: (toggle: boolean) => void\n  onClickPinUnpin?: (parameters: PinUnPinType) => 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 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  'data-testid'?: string\n}\n\nconst onDragStopTrigger = (event: DragEvent<HTMLDivElement>) => {\n  // eslint-disable-next-line no-param-reassign\n  event.currentTarget.style.opacity = '1'\n}\n\nexport const Item = memo(\n  ({\n    children,\n    categoryIcon,\n    categoryIconVariant,\n    label,\n    subLabel,\n    badgeText,\n    badgeSentiment,\n    href,\n    target,\n    rel,\n    onToggle,\n    onClickPinUnpin,\n    toggle,\n    active,\n    noPinButton,\n    type = 'default',\n    as,\n    disabled,\n    noExpand = false,\n    index,\n    id,\n    'data-testid': dataTestId,\n  }: ItemProps) => {\n    const context = useNavigation()\n    if (!context) {\n      throw new Error(\n        'Navigation.Item can only be used inside a NavigationProvider.',\n      )\n    }\n\n    const itemProvider = useContext(ItemContext)\n    const hasParents = !!itemProvider\n\n    const {\n      expanded,\n      locales,\n      pinnedFeature,\n      pinItem,\n      unpinItem,\n      pinnedItems,\n      pinLimit,\n      animation,\n      registerItem,\n      shouldAnimate,\n      animationType,\n    } = context\n\n    useEffect(\n      () => {\n        if (type !== 'pinnedGroup') {\n          registerItem({ [id]: { label, active, onToggle, onClickPinUnpin } })\n        }\n      },\n      // eslint-disable-next-line react-hooks/exhaustive-deps\n      [active, id, label, registerItem],\n    )\n\n    const [internalExpanded, onToggleExpand] = useReducer(\n      prevState => !prevState,\n      Boolean(toggle),\n    )\n\n    const triggerToggle = useCallback(() => {\n      onToggleExpand()\n      onToggle?.(internalExpanded)\n    }, [internalExpanded, onToggle])\n\n    const PaddedStack =\n      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 = useMemo(\n      () => StyledContainer.withComponent(containerTag),\n      [containerTag],\n    )\n\n    const CategoryIconUsed = categoryIcon\n      ? CategoryIcon[\n          `${\n            categoryIcon.charAt(0).toUpperCase() + categoryIcon.slice(1)\n          }CategoryIcon` as keyof typeof CategoryIcon\n        ]\n      : null\n\n    const ArrowIcon = useMemo(\n      () => (internalExpanded ? ArrowDownIcon : ArrowRightIcon),\n      [internalExpanded],\n    )\n\n    const PinUnpinIcon = useMemo(\n      () => (isItemPinned ? StyledUnpinIcon : StyledPinIconOutline),\n      [isItemPinned],\n    )\n\n    const ariaExpanded = useMemo(() => {\n      if (hasHrefAndNoChildren && internalExpanded) {\n        return true\n      }\n\n      if (hasHrefAndNoChildren && !internalExpanded) {\n        return false\n      }\n\n      return undefined\n    }, [hasHrefAndNoChildren, internalExpanded])\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 onDragStart = useCallback(\n      (event: DragEvent<HTMLDivElement>) => {\n        if (expanded) {\n          event.dataTransfer.setData(\n            'text/plain',\n            JSON.stringify({ label, index }),\n          )\n          // eslint-disable-next-line no-param-reassign\n          event.currentTarget.style.opacity = '0.5'\n        }\n\n        return undefined\n      },\n      [expanded, index, label],\n    )\n\n    const onDragEnd = useCallback(\n      (event: DragEvent<HTMLDivElement>) =>\n        expanded ? onDragStopTrigger(event) : undefined,\n      [expanded],\n    )\n\n    // This content is when the navigation is expanded\n    if (expanded || (!expanded && animation === 'expand')) {\n      return (\n        <>\n          <Container\n            gap={1}\n            direction=\"row\"\n            alignItems={categoryIcon ? 'flex-start' : 'center'}\n            justifyContent=\"space-between\"\n            data-has-sub-label={!!subLabel}\n            onClick={triggerToggle}\n            aria-expanded={ariaExpanded}\n            href={href}\n            target={target}\n            rel={rel}\n            data-is-pinnable={shouldShowPinnedButton}\n            data-is-active={active}\n            data-animation={shouldAnimate ? animation : undefined}\n            data-animation-type={animationType}\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={onDragStart}\n            onDragEnd={onDragEnd}\n            id={id}\n            data-testid={dataTestId}\n          >\n            <Stack\n              direction=\"row\"\n              gap={1}\n              alignItems={categoryIcon ? 'flex-start' : 'center'}\n              justifyContent=\"center\"\n            >\n              {CategoryIconUsed ? (\n                <ContainerCategoryIcon\n                  alignItems=\"center\"\n                  justifyContent=\"center\"\n                >\n                  <CategoryIconUsed\n                    variant={active ? 'primary' : categoryIconVariant}\n                    disabled={disabled}\n                  />\n                </ContainerCategoryIcon>\n              ) : null}\n              {type === 'pinned' && expanded ? (\n                <GrabIcon\n                  sentiment=\"neutral\"\n                  prominence=\"weak\"\n                  size=\"small\"\n                  disabled={disabled}\n                />\n              ) : null}\n              <Stack>\n                {!animation ? (\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                    data-animation={animation}\n                    disabled={disabled}\n                    whiteSpace=\"pre-wrap\"\n                  >\n                    {label}\n                  </WrapText>\n                ) : null}\n                {subLabel && !animation ? (\n                  <WrapText\n                    as=\"span\"\n                    variant=\"caption\"\n                    sentiment=\"neutral\"\n                    prominence=\"weak\"\n                    data-animation={animation}\n                    disabled={disabled}\n                    whiteSpace=\"pre-wrap\"\n                  >\n                    {subLabel}\n                  </WrapText>\n                ) : null}\n              </Stack>\n            </Stack>\n            <Stack\n              direction=\"row\"\n              alignItems=\"center\"\n              gap={href ? 1 : undefined}\n            >\n              {badgeText || hasPinnedFeatureAndNoChildren ? (\n                <>\n                  {badgeText && !animation ? (\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                          aria-label={isItemPinned ? 'unpin' : 'pin'}\n                          size=\"xsmall\"\n                          variant=\"ghost\"\n                          sentiment={active ? 'primary' : 'neutral'}\n                          onClick={(event: MouseEvent<HTMLDivElement>) => {\n                            if (pinnedItems.length < pinLimit || isItemPinned) {\n                              event.preventDefault()\n                              event.stopPropagation() // This is to avoid click spread to the parent and change the routing\n                              let newValue: string[] | undefined\n                              if (isItemPinned) {\n                                newValue = unpinItem(id)\n                              } else {\n                                newValue = pinItem(id)\n                              }\n\n                              onClickPinUnpin?.({\n                                state: isItemPinned ? 'unpin' : 'pin',\n                                id,\n                                totalPinned: newValue,\n                              })\n                            }\n                          }}\n                          disabled={isItemPinned ? false : isPinDisabled}\n                        >\n                          <PinUnpinIcon\n                            size=\"medium\"\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 && target === '_blank' && !animation ? (\n                <AnimatedIcon\n                  sentiment=\"neutral\"\n                  prominence=\"default\"\n                  disabled={disabled}\n                />\n              ) : null}\n              {children ? (\n                <StackIcon gap={1} direction=\"row\" alignItems=\"center\">\n                  {!animation && !noExpand ? (\n                    <ArrowIcon sentiment=\"neutral\" prominence=\"weak\" />\n                  ) : null}\n                </StackIcon>\n              ) : null}\n            </Stack>\n          </Container>\n          {children ? (\n            <>\n              {!noExpand ? (\n                <ItemProvider>\n                  <Expandable opened={internalExpanded} animationDuration={0}>\n                    <PaddedStack width={animation ? '100%' : undefined}>\n                      {children}\n                    </PaddedStack>\n                  </Expandable>\n                </ItemProvider>\n              ) : (\n                <ItemProvider>\n                  <PaddedStack width={animation ? '100%' : undefined}>\n                    {children}\n                  </PaddedStack>\n                </ItemProvider>\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                  aria-label={label}\n                >\n                  {CategoryIconUsed ? (\n                    <Stack\n                      direction=\"row\"\n                      gap={1}\n                      alignItems=\"center\"\n                      justifyContent=\"center\"\n                    >\n                      <CategoryIconUsed\n                        variant={active ? 'primary' : categoryIconVariant}\n                      />\n                    </Stack>\n                  ) : null}\n                </Button>\n              }\n              placement=\"right\"\n            >\n              <ItemProvider>{children}</ItemProvider>\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                aria-label={label}\n              >\n                <Stack\n                  direction=\"row\"\n                  gap={1}\n                  alignItems=\"center\"\n                  justifyContent=\"center\"\n                >\n                  {CategoryIconUsed ? (\n                    <CategoryIconUsed\n                      variant={active ? 'primary' : categoryIconVariant}\n                    />\n                  ) : (\n                    <ConsoleCategoryIcon\n                      variant={active ? 'primary' : categoryIconVariant}\n                    />\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          target={target}\n          rel={rel}\n          borderless\n          active={active}\n          disabled={disabled}\n          sentiment={active ? 'primary' : 'neutral'}\n          isPinnable={shouldShowPinnedButton}\n          onClick={() => onToggle?.(!!active)}\n        >\n          <Stack\n            gap={1}\n            direction=\"row\"\n            alignItems=\"center\"\n            justifyContent=\"space-between\"\n            flex={1}\n            width=\"100%\"\n          >\n            {!animation ? (\n              <WrapText as=\"span\" variant=\"bodySmall\" whiteSpace=\"pre-wrap\">\n                {label}\n              </WrapText>\n            ) : null}\n            <Stack direction=\"row\">\n              {badgeText && !animation ? (\n                <StyledBadge\n                  sentiment={badgeSentiment}\n                  size=\"small\"\n                  prominence=\"strong\"\n                  disabled={disabled}\n                >\n                  {badgeText}\n                </StyledBadge>\n              ) : null}\n              {hasHrefAndNoChildren && target === '_blank' ? (\n                <AnimatedIcon\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                      aria-label={isItemPinned ? 'unpin' : 'pin'}\n                      variant=\"ghost\"\n                      sentiment={active ? 'primary' : 'neutral'}\n                      onClick={(event: MouseEvent<HTMLDivElement>) => {\n                        if (pinnedItems.length < pinLimit || isItemPinned) {\n                          event.preventDefault()\n                          event.stopPropagation() // This is to avoid click spread to the parent and change the routing\n\n                          let newValue: string[] | undefined\n                          if (isItemPinned) {\n                            newValue = unpinItem(id)\n                          } else {\n                            newValue = pinItem(id)\n                          }\n                          onClickPinUnpin?.({\n                            state: isItemPinned ? 'unpin' : 'pin',\n                            id,\n                            totalPinned: newValue,\n                          })\n                        }\n                      }}\n                      disabled={isItemPinned ? false : isPinDisabled}\n                    >\n                      <PinUnpinIcon\n                        size=\"medium\"\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={target}\n              rel={rel}\n            >\n              <AnimatedIcon sentiment=\"neutral\" prominence=\"weak\" />\n            </Container>\n          </MenuStack>\n        </Tooltip>\n      )\n    }\n\n    return null\n  },\n)\n"]} */",
90
+ styles: "opacity:0;right:0;position:absolute;left:-24px;top:0;bottom:0;margin:auto;&:hover,&:focus,&:active{opacity:1;}/*# 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":"AA+EwC","file":"/home/runner/work/ultraviolet/ultraviolet/packages/plus/src/components/Navigation/components/Item.tsx","sourcesContent":["'use client'\n\nimport { css } from '@emotion/react'\nimport styled from '@emotion/styled'\nimport {\n  ArrowDownIcon,\n  ArrowRightIcon,\n  DragIcon,\n  OpenInNewIcon,\n  PinOutlineIcon,\n  UnpinIcon,\n} from '@ultraviolet/icons'\nimport * as CategoryIcon from '@ultraviolet/icons/category'\nimport { ConsoleCategoryIcon } from '@ultraviolet/icons/category'\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  isValidElement,\n  memo,\n  useCallback,\n  useContext,\n  useEffect,\n  useMemo,\n  useReducer,\n} from 'react'\nimport type { PascalToCamelCaseWithoutSuffix } from '../../../types'\nimport { useNavigation } from '../NavigationProvider'\nimport { ANIMATION_DURATION, shrinkHeight } from '../constants'\nimport type { PinUnPinType } from '../types'\nimport { ItemContext, ItemProvider } from './ItemProvider'\n\nconst RelativeDiv = styled.div`\n  position: relative;\n`\n\nconst StyledPinIconOutline = styled(PinOutlineIcon, {\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 }) =>\n      active ? `background: ${theme.colors.primary.backgroundHover};` : null}\n  }\n`\n\nconst StyledUnpinIcon = StyledPinIconOutline.withComponent(UnpinIcon)\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(DragIcon)`\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  &: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(OpenInNewIcon)``\n\nconst WrapText = styled(Text)`\n  overflow-wrap: anywhere;\n  overflow: hidden;\n  display: -webkit-box;\n  -webkit-box-orient: vertical;\n  -webkit-line-clamp: 2;\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 }) => 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\"][data-animation-type=\"complex\"] {\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\"][data-animation-type=\"complex\"] {\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 StackIcon = styled(Stack)`\n  padding-top: ${({ theme }) => theme.space['0.5']};\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?: PascalToCamelCaseWithoutSuffix<\n    keyof typeof CategoryIcon,\n    'CategoryIcon'\n  >\n  categoryIconVariant?: ComponentProps<\n    (typeof CategoryIcon)['BaremetalCategoryIcon']\n  >['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?: HTMLAnchorElement['href']\n  target?: HTMLAnchorElement['target']\n  rel?: HTMLAnchorElement['rel']\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  onToggle?: (toggle: boolean) => void\n  onClickPinUnpin?: (parameters: PinUnPinType) => 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 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  'data-testid'?: string\n}\n\nconst onDragStopTrigger = (event: DragEvent<HTMLDivElement>) => {\n  // eslint-disable-next-line no-param-reassign\n  event.currentTarget.style.opacity = '1'\n}\n\nexport const Item = memo(\n  ({\n    children,\n    categoryIcon,\n    categoryIconVariant,\n    label,\n    subLabel,\n    badgeText,\n    badgeSentiment,\n    href,\n    target,\n    rel,\n    onToggle,\n    onClickPinUnpin,\n    toggle,\n    active,\n    noPinButton,\n    type = 'default',\n    as,\n    disabled,\n    noExpand = false,\n    index,\n    id,\n    'data-testid': dataTestId,\n  }: ItemProps) => {\n    const context = useNavigation()\n    if (!context) {\n      throw new Error(\n        'Navigation.Item can only be used inside a NavigationProvider.',\n      )\n    }\n\n    const itemProvider = useContext(ItemContext)\n    const hasParents = !!itemProvider\n\n    const {\n      expanded,\n      locales,\n      pinnedFeature,\n      pinItem,\n      unpinItem,\n      pinnedItems,\n      pinLimit,\n      animation,\n      registerItem,\n      shouldAnimate,\n      animationType,\n    } = context\n\n    useEffect(\n      () => {\n        if (type !== 'pinnedGroup' && pinnedFeature) {\n          registerItem({ [id]: { label, active, onToggle, onClickPinUnpin } })\n        }\n      },\n      // eslint-disable-next-line react-hooks/exhaustive-deps\n      [active, id, label, registerItem],\n    )\n\n    const [internalExpanded, onToggleExpand] = useReducer(\n      prevState => !prevState,\n      Boolean(toggle),\n    )\n\n    const triggerToggle = useCallback(() => {\n      onToggleExpand()\n      onToggle?.(internalExpanded)\n    }, [internalExpanded, onToggle])\n\n    const PaddedStack =\n      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 = useMemo(\n      () => StyledContainer.withComponent(containerTag),\n      [containerTag],\n    )\n\n    const CategoryIconUsed = categoryIcon\n      ? CategoryIcon[\n          `${\n            categoryIcon.charAt(0).toUpperCase() + categoryIcon.slice(1)\n          }CategoryIcon` as keyof typeof CategoryIcon\n        ]\n      : null\n\n    const ArrowIcon = useMemo(\n      () => (internalExpanded ? ArrowDownIcon : ArrowRightIcon),\n      [internalExpanded],\n    )\n\n    const PinUnpinIcon = useMemo(\n      () => (isItemPinned ? StyledUnpinIcon : StyledPinIconOutline),\n      [isItemPinned],\n    )\n\n    const ariaExpanded = useMemo(() => {\n      if (hasHrefAndNoChildren && internalExpanded) {\n        return true\n      }\n\n      if (hasHrefAndNoChildren && !internalExpanded) {\n        return false\n      }\n\n      return undefined\n    }, [hasHrefAndNoChildren, internalExpanded])\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 onDragStart = useCallback(\n      (event: DragEvent<HTMLDivElement>) => {\n        if (expanded) {\n          event.dataTransfer.setData(\n            'text/plain',\n            JSON.stringify({ label, index }),\n          )\n          // eslint-disable-next-line no-param-reassign\n          event.currentTarget.style.opacity = '0.5'\n        }\n\n        return undefined\n      },\n      [expanded, index, label],\n    )\n\n    const onDragEnd = useCallback(\n      (event: DragEvent<HTMLDivElement>) =>\n        expanded ? onDragStopTrigger(event) : undefined,\n      [expanded],\n    )\n\n    // This content is when the navigation is expanded\n    if (expanded || (!expanded && animation === 'expand')) {\n      return (\n        <>\n          <Container\n            gap={1}\n            direction=\"row\"\n            alignItems={categoryIcon ? 'flex-start' : 'center'}\n            justifyContent=\"space-between\"\n            data-has-sub-label={!!subLabel}\n            onClick={triggerToggle}\n            aria-expanded={ariaExpanded}\n            href={href}\n            target={target}\n            rel={rel}\n            data-is-pinnable={shouldShowPinnedButton}\n            data-is-active={active}\n            data-animation={shouldAnimate ? animation : undefined}\n            data-animation-type={animationType}\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={onDragStart}\n            onDragEnd={onDragEnd}\n            id={id}\n            data-testid={dataTestId}\n          >\n            <Stack\n              direction=\"row\"\n              gap={1}\n              alignItems={categoryIcon ? 'flex-start' : 'center'}\n              justifyContent=\"center\"\n            >\n              {CategoryIconUsed ? (\n                <ContainerCategoryIcon\n                  alignItems=\"center\"\n                  justifyContent=\"center\"\n                >\n                  <CategoryIconUsed\n                    variant={active ? 'primary' : categoryIconVariant}\n                    disabled={disabled}\n                  />\n                </ContainerCategoryIcon>\n              ) : null}\n              {type === 'pinned' && expanded ? (\n                <GrabIcon\n                  sentiment=\"neutral\"\n                  prominence=\"weak\"\n                  size=\"small\"\n                  disabled={disabled}\n                />\n              ) : null}\n              <Stack>\n                {!animation ? (\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                    data-animation={animation}\n                    disabled={disabled}\n                    whiteSpace=\"pre-wrap\"\n                  >\n                    {label}\n                  </WrapText>\n                ) : null}\n                {subLabel && !animation ? (\n                  <WrapText\n                    as=\"span\"\n                    variant=\"caption\"\n                    sentiment=\"neutral\"\n                    prominence=\"weak\"\n                    data-animation={animation}\n                    disabled={disabled}\n                    whiteSpace=\"pre-wrap\"\n                  >\n                    {subLabel}\n                  </WrapText>\n                ) : null}\n              </Stack>\n            </Stack>\n            <Stack\n              direction=\"row\"\n              alignItems=\"center\"\n              gap={href ? 1 : undefined}\n            >\n              {badgeText || hasPinnedFeatureAndNoChildren ? (\n                <>\n                  {badgeText && !animation ? (\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                          aria-label={isItemPinned ? 'unpin' : 'pin'}\n                          size=\"xsmall\"\n                          variant=\"ghost\"\n                          sentiment={active ? 'primary' : 'neutral'}\n                          onClick={(event: MouseEvent<HTMLDivElement>) => {\n                            if (pinnedItems.length < pinLimit || isItemPinned) {\n                              event.preventDefault()\n                              event.stopPropagation() // This is to avoid click spread to the parent and change the routing\n                              let newValue: string[] | undefined\n                              if (isItemPinned) {\n                                newValue = unpinItem(id)\n                              } else {\n                                newValue = pinItem(id)\n                              }\n\n                              onClickPinUnpin?.({\n                                state: isItemPinned ? 'unpin' : 'pin',\n                                id,\n                                totalPinned: newValue,\n                              })\n                            }\n                          }}\n                          disabled={isItemPinned ? false : isPinDisabled}\n                        >\n                          <PinUnpinIcon\n                            size=\"medium\"\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 && target === '_blank' && !animation ? (\n                <AnimatedIcon\n                  sentiment=\"neutral\"\n                  prominence=\"default\"\n                  disabled={disabled}\n                />\n              ) : null}\n              {children ? (\n                <StackIcon gap={1} direction=\"row\" alignItems=\"center\">\n                  {!animation && !noExpand ? (\n                    <ArrowIcon sentiment=\"neutral\" prominence=\"weak\" />\n                  ) : null}\n                </StackIcon>\n              ) : null}\n            </Stack>\n          </Container>\n          {children ? (\n            <>\n              {!noExpand ? (\n                <ItemProvider>\n                  <Expandable opened={internalExpanded} animationDuration={0}>\n                    <PaddedStack width={animation ? '100%' : undefined}>\n                      {children}\n                    </PaddedStack>\n                  </Expandable>\n                </ItemProvider>\n              ) : (\n                <ItemProvider>\n                  <PaddedStack width={animation ? '100%' : undefined}>\n                    {children}\n                  </PaddedStack>\n                </ItemProvider>\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                  aria-label={label}\n                >\n                  {CategoryIconUsed ? (\n                    <Stack\n                      direction=\"row\"\n                      gap={1}\n                      alignItems=\"center\"\n                      justifyContent=\"center\"\n                    >\n                      <CategoryIconUsed\n                        variant={active ? 'primary' : categoryIconVariant}\n                      />\n                    </Stack>\n                  ) : null}\n                </Button>\n              }\n              placement=\"right\"\n            >\n              <ItemProvider>{children}</ItemProvider>\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                aria-label={label}\n              >\n                <Stack\n                  direction=\"row\"\n                  gap={1}\n                  alignItems=\"center\"\n                  justifyContent=\"center\"\n                >\n                  {CategoryIconUsed ? (\n                    <CategoryIconUsed\n                      variant={active ? 'primary' : categoryIconVariant}\n                    />\n                  ) : (\n                    <ConsoleCategoryIcon\n                      variant={active ? 'primary' : categoryIconVariant}\n                    />\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          target={target}\n          rel={rel}\n          borderless\n          active={active}\n          disabled={disabled}\n          sentiment={active ? 'primary' : 'neutral'}\n          isPinnable={shouldShowPinnedButton}\n          onClick={() => onToggle?.(!!active)}\n        >\n          <Stack\n            gap={1}\n            direction=\"row\"\n            alignItems=\"center\"\n            justifyContent=\"space-between\"\n            flex={1}\n            width=\"100%\"\n          >\n            {!animation ? (\n              <WrapText as=\"span\" variant=\"bodySmall\" whiteSpace=\"pre-wrap\">\n                {label}\n              </WrapText>\n            ) : null}\n            <Stack direction=\"row\">\n              {badgeText && !animation ? (\n                <StyledBadge\n                  sentiment={badgeSentiment}\n                  size=\"small\"\n                  prominence=\"strong\"\n                  disabled={disabled}\n                >\n                  {badgeText}\n                </StyledBadge>\n              ) : null}\n              {hasHrefAndNoChildren && target === '_blank' ? (\n                <AnimatedIcon\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                      aria-label={isItemPinned ? 'unpin' : 'pin'}\n                      variant=\"ghost\"\n                      sentiment={active ? 'primary' : 'neutral'}\n                      onClick={(event: MouseEvent<HTMLDivElement>) => {\n                        if (pinnedItems.length < pinLimit || isItemPinned) {\n                          event.preventDefault()\n                          event.stopPropagation() // This is to avoid click spread to the parent and change the routing\n\n                          let newValue: string[] | undefined\n                          if (isItemPinned) {\n                            newValue = unpinItem(id)\n                          } else {\n                            newValue = pinItem(id)\n                          }\n                          onClickPinUnpin?.({\n                            state: isItemPinned ? 'unpin' : 'pin',\n                            id,\n                            totalPinned: newValue,\n                          })\n                        }\n                      }}\n                      disabled={isItemPinned ? false : isPinDisabled}\n                    >\n                      <PinUnpinIcon\n                        size=\"medium\"\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={target}\n              rel={rel}\n            >\n              <AnimatedIcon sentiment=\"neutral\" prominence=\"weak\" />\n            </Container>\n          </MenuStack>\n        </Tooltip>\n      )\n    }\n\n    return null\n  },\n)\n"]} */",
91
91
  toString: _EMOTION_STRINGIFIED_CSS_ERROR__
92
92
  });
93
93
  const PinnedButton = LocalExpandButton.withComponent("div", process.env.NODE_ENV === "production" ? {
@@ -103,13 +103,13 @@ const GrabIcon = /* @__PURE__ */ _styled__default.default(icons.DragIcon, proces
103
103
  label: "GrabIcon"
104
104
  })("opacity:0;margin:0 ", ({
105
105
  theme
106
- }) => 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":"AAiGiC","file":"/home/runner/work/ultraviolet/ultraviolet/packages/plus/src/components/Navigation/components/Item.tsx","sourcesContent":["'use client'\n\nimport { css } from '@emotion/react'\nimport styled from '@emotion/styled'\nimport {\n  ArrowDownIcon,\n  ArrowRightIcon,\n  DragIcon,\n  OpenInNewIcon,\n  PinOutlineIcon,\n  UnpinIcon,\n} from '@ultraviolet/icons'\nimport * as CategoryIcon from '@ultraviolet/icons/category'\nimport { ConsoleCategoryIcon } from '@ultraviolet/icons/category'\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  isValidElement,\n  memo,\n  useCallback,\n  useContext,\n  useEffect,\n  useMemo,\n  useReducer,\n} from 'react'\nimport type { PascalToCamelCaseWithoutSuffix } from '../../../types'\nimport { useNavigation } from '../NavigationProvider'\nimport { ANIMATION_DURATION, shrinkHeight } from '../constants'\nimport type { PinUnPinType } from '../types'\nimport { ItemContext, ItemProvider } from './ItemProvider'\n\nconst RelativeDiv = styled.div`\n  position: relative;\n`\n\nconst StyledPinIconOutline = styled(PinOutlineIcon, {\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 }) =>\n      active ? `background: ${theme.colors.primary.backgroundHover};` : null}\n  }\n`\n\nconst StyledUnpinIcon = StyledPinIconOutline.withComponent(UnpinIcon)\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(DragIcon)`\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  &: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(OpenInNewIcon)``\n\nconst WrapText = styled(Text)`\n  overflow-wrap: anywhere;\n  overflow: hidden;\n  display: -webkit-box;\n  -webkit-box-orient: vertical;\n  -webkit-line-clamp: 2;\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 }) => 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\"][data-animation-type=\"complex\"] {\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\"][data-animation-type=\"complex\"] {\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 StackIcon = styled(Stack)`\n  padding-top: ${({ theme }) => theme.space['0.5']};\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?: PascalToCamelCaseWithoutSuffix<\n    keyof typeof CategoryIcon,\n    'CategoryIcon'\n  >\n  categoryIconVariant?: ComponentProps<\n    (typeof CategoryIcon)['BaremetalCategoryIcon']\n  >['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?: HTMLAnchorElement['href']\n  target?: HTMLAnchorElement['target']\n  rel?: HTMLAnchorElement['rel']\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  onToggle?: (toggle: boolean) => void\n  onClickPinUnpin?: (parameters: PinUnPinType) => 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 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  'data-testid'?: string\n}\n\nconst onDragStopTrigger = (event: DragEvent<HTMLDivElement>) => {\n  // eslint-disable-next-line no-param-reassign\n  event.currentTarget.style.opacity = '1'\n}\n\nexport const Item = memo(\n  ({\n    children,\n    categoryIcon,\n    categoryIconVariant,\n    label,\n    subLabel,\n    badgeText,\n    badgeSentiment,\n    href,\n    target,\n    rel,\n    onToggle,\n    onClickPinUnpin,\n    toggle,\n    active,\n    noPinButton,\n    type = 'default',\n    as,\n    disabled,\n    noExpand = false,\n    index,\n    id,\n    'data-testid': dataTestId,\n  }: ItemProps) => {\n    const context = useNavigation()\n    if (!context) {\n      throw new Error(\n        'Navigation.Item can only be used inside a NavigationProvider.',\n      )\n    }\n\n    const itemProvider = useContext(ItemContext)\n    const hasParents = !!itemProvider\n\n    const {\n      expanded,\n      locales,\n      pinnedFeature,\n      pinItem,\n      unpinItem,\n      pinnedItems,\n      pinLimit,\n      animation,\n      registerItem,\n      shouldAnimate,\n      animationType,\n    } = context\n\n    useEffect(\n      () => {\n        if (type !== 'pinnedGroup') {\n          registerItem({ [id]: { label, active, onToggle, onClickPinUnpin } })\n        }\n      },\n      // eslint-disable-next-line react-hooks/exhaustive-deps\n      [active, id, label, registerItem],\n    )\n\n    const [internalExpanded, onToggleExpand] = useReducer(\n      prevState => !prevState,\n      Boolean(toggle),\n    )\n\n    const triggerToggle = useCallback(() => {\n      onToggleExpand()\n      onToggle?.(internalExpanded)\n    }, [internalExpanded, onToggle])\n\n    const PaddedStack =\n      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 = useMemo(\n      () => StyledContainer.withComponent(containerTag),\n      [containerTag],\n    )\n\n    const CategoryIconUsed = categoryIcon\n      ? CategoryIcon[\n          `${\n            categoryIcon.charAt(0).toUpperCase() + categoryIcon.slice(1)\n          }CategoryIcon` as keyof typeof CategoryIcon\n        ]\n      : null\n\n    const ArrowIcon = useMemo(\n      () => (internalExpanded ? ArrowDownIcon : ArrowRightIcon),\n      [internalExpanded],\n    )\n\n    const PinUnpinIcon = useMemo(\n      () => (isItemPinned ? StyledUnpinIcon : StyledPinIconOutline),\n      [isItemPinned],\n    )\n\n    const ariaExpanded = useMemo(() => {\n      if (hasHrefAndNoChildren && internalExpanded) {\n        return true\n      }\n\n      if (hasHrefAndNoChildren && !internalExpanded) {\n        return false\n      }\n\n      return undefined\n    }, [hasHrefAndNoChildren, internalExpanded])\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 onDragStart = useCallback(\n      (event: DragEvent<HTMLDivElement>) => {\n        if (expanded) {\n          event.dataTransfer.setData(\n            'text/plain',\n            JSON.stringify({ label, index }),\n          )\n          // eslint-disable-next-line no-param-reassign\n          event.currentTarget.style.opacity = '0.5'\n        }\n\n        return undefined\n      },\n      [expanded, index, label],\n    )\n\n    const onDragEnd = useCallback(\n      (event: DragEvent<HTMLDivElement>) =>\n        expanded ? onDragStopTrigger(event) : undefined,\n      [expanded],\n    )\n\n    // This content is when the navigation is expanded\n    if (expanded || (!expanded && animation === 'expand')) {\n      return (\n        <>\n          <Container\n            gap={1}\n            direction=\"row\"\n            alignItems={categoryIcon ? 'flex-start' : 'center'}\n            justifyContent=\"space-between\"\n            data-has-sub-label={!!subLabel}\n            onClick={triggerToggle}\n            aria-expanded={ariaExpanded}\n            href={href}\n            target={target}\n            rel={rel}\n            data-is-pinnable={shouldShowPinnedButton}\n            data-is-active={active}\n            data-animation={shouldAnimate ? animation : undefined}\n            data-animation-type={animationType}\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={onDragStart}\n            onDragEnd={onDragEnd}\n            id={id}\n            data-testid={dataTestId}\n          >\n            <Stack\n              direction=\"row\"\n              gap={1}\n              alignItems={categoryIcon ? 'flex-start' : 'center'}\n              justifyContent=\"center\"\n            >\n              {CategoryIconUsed ? (\n                <ContainerCategoryIcon\n                  alignItems=\"center\"\n                  justifyContent=\"center\"\n                >\n                  <CategoryIconUsed\n                    variant={active ? 'primary' : categoryIconVariant}\n                    disabled={disabled}\n                  />\n                </ContainerCategoryIcon>\n              ) : null}\n              {type === 'pinned' && expanded ? (\n                <GrabIcon\n                  sentiment=\"neutral\"\n                  prominence=\"weak\"\n                  size=\"small\"\n                  disabled={disabled}\n                />\n              ) : null}\n              <Stack>\n                {!animation ? (\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                    data-animation={animation}\n                    disabled={disabled}\n                    whiteSpace=\"pre-wrap\"\n                  >\n                    {label}\n                  </WrapText>\n                ) : null}\n                {subLabel && !animation ? (\n                  <WrapText\n                    as=\"span\"\n                    variant=\"caption\"\n                    sentiment=\"neutral\"\n                    prominence=\"weak\"\n                    data-animation={animation}\n                    disabled={disabled}\n                    whiteSpace=\"pre-wrap\"\n                  >\n                    {subLabel}\n                  </WrapText>\n                ) : null}\n              </Stack>\n            </Stack>\n            <Stack\n              direction=\"row\"\n              alignItems=\"center\"\n              gap={href ? 1 : undefined}\n            >\n              {badgeText || hasPinnedFeatureAndNoChildren ? (\n                <>\n                  {badgeText && !animation ? (\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                          aria-label={isItemPinned ? 'unpin' : 'pin'}\n                          size=\"xsmall\"\n                          variant=\"ghost\"\n                          sentiment={active ? 'primary' : 'neutral'}\n                          onClick={(event: MouseEvent<HTMLDivElement>) => {\n                            if (pinnedItems.length < pinLimit || isItemPinned) {\n                              event.preventDefault()\n                              event.stopPropagation() // This is to avoid click spread to the parent and change the routing\n                              let newValue: string[] | undefined\n                              if (isItemPinned) {\n                                newValue = unpinItem(id)\n                              } else {\n                                newValue = pinItem(id)\n                              }\n\n                              onClickPinUnpin?.({\n                                state: isItemPinned ? 'unpin' : 'pin',\n                                id,\n                                totalPinned: newValue,\n                              })\n                            }\n                          }}\n                          disabled={isItemPinned ? false : isPinDisabled}\n                        >\n                          <PinUnpinIcon\n                            size=\"medium\"\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 && target === '_blank' && !animation ? (\n                <AnimatedIcon\n                  sentiment=\"neutral\"\n                  prominence=\"default\"\n                  disabled={disabled}\n                />\n              ) : null}\n              {children ? (\n                <StackIcon gap={1} direction=\"row\" alignItems=\"center\">\n                  {!animation && !noExpand ? (\n                    <ArrowIcon sentiment=\"neutral\" prominence=\"weak\" />\n                  ) : null}\n                </StackIcon>\n              ) : null}\n            </Stack>\n          </Container>\n          {children ? (\n            <>\n              {!noExpand ? (\n                <ItemProvider>\n                  <Expandable opened={internalExpanded} animationDuration={0}>\n                    <PaddedStack width={animation ? '100%' : undefined}>\n                      {children}\n                    </PaddedStack>\n                  </Expandable>\n                </ItemProvider>\n              ) : (\n                <ItemProvider>\n                  <PaddedStack width={animation ? '100%' : undefined}>\n                    {children}\n                  </PaddedStack>\n                </ItemProvider>\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                  aria-label={label}\n                >\n                  {CategoryIconUsed ? (\n                    <Stack\n                      direction=\"row\"\n                      gap={1}\n                      alignItems=\"center\"\n                      justifyContent=\"center\"\n                    >\n                      <CategoryIconUsed\n                        variant={active ? 'primary' : categoryIconVariant}\n                      />\n                    </Stack>\n                  ) : null}\n                </Button>\n              }\n              placement=\"right\"\n            >\n              <ItemProvider>{children}</ItemProvider>\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                aria-label={label}\n              >\n                <Stack\n                  direction=\"row\"\n                  gap={1}\n                  alignItems=\"center\"\n                  justifyContent=\"center\"\n                >\n                  {CategoryIconUsed ? (\n                    <CategoryIconUsed\n                      variant={active ? 'primary' : categoryIconVariant}\n                    />\n                  ) : (\n                    <ConsoleCategoryIcon\n                      variant={active ? 'primary' : categoryIconVariant}\n                    />\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          target={target}\n          rel={rel}\n          borderless\n          active={active}\n          disabled={disabled}\n          sentiment={active ? 'primary' : 'neutral'}\n          isPinnable={shouldShowPinnedButton}\n          onClick={() => onToggle?.(!!active)}\n        >\n          <Stack\n            gap={1}\n            direction=\"row\"\n            alignItems=\"center\"\n            justifyContent=\"space-between\"\n            flex={1}\n            width=\"100%\"\n          >\n            {!animation ? (\n              <WrapText as=\"span\" variant=\"bodySmall\" whiteSpace=\"pre-wrap\">\n                {label}\n              </WrapText>\n            ) : null}\n            <Stack direction=\"row\">\n              {badgeText && !animation ? (\n                <StyledBadge\n                  sentiment={badgeSentiment}\n                  size=\"small\"\n                  prominence=\"strong\"\n                  disabled={disabled}\n                >\n                  {badgeText}\n                </StyledBadge>\n              ) : null}\n              {hasHrefAndNoChildren && target === '_blank' ? (\n                <AnimatedIcon\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                      aria-label={isItemPinned ? 'unpin' : 'pin'}\n                      variant=\"ghost\"\n                      sentiment={active ? 'primary' : 'neutral'}\n                      onClick={(event: MouseEvent<HTMLDivElement>) => {\n                        if (pinnedItems.length < pinLimit || isItemPinned) {\n                          event.preventDefault()\n                          event.stopPropagation() // This is to avoid click spread to the parent and change the routing\n\n                          let newValue: string[] | undefined\n                          if (isItemPinned) {\n                            newValue = unpinItem(id)\n                          } else {\n                            newValue = pinItem(id)\n                          }\n                          onClickPinUnpin?.({\n                            state: isItemPinned ? 'unpin' : 'pin',\n                            id,\n                            totalPinned: newValue,\n                          })\n                        }\n                      }}\n                      disabled={isItemPinned ? false : isPinDisabled}\n                    >\n                      <PinUnpinIcon\n                        size=\"medium\"\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={target}\n              rel={rel}\n            >\n              <AnimatedIcon sentiment=\"neutral\" prominence=\"weak\" />\n            </Container>\n          </MenuStack>\n        </Tooltip>\n      )\n    }\n\n    return null\n  },\n)\n"]} */"));
106
+ }) => 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":"AAiGiC","file":"/home/runner/work/ultraviolet/ultraviolet/packages/plus/src/components/Navigation/components/Item.tsx","sourcesContent":["'use client'\n\nimport { css } from '@emotion/react'\nimport styled from '@emotion/styled'\nimport {\n  ArrowDownIcon,\n  ArrowRightIcon,\n  DragIcon,\n  OpenInNewIcon,\n  PinOutlineIcon,\n  UnpinIcon,\n} from '@ultraviolet/icons'\nimport * as CategoryIcon from '@ultraviolet/icons/category'\nimport { ConsoleCategoryIcon } from '@ultraviolet/icons/category'\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  isValidElement,\n  memo,\n  useCallback,\n  useContext,\n  useEffect,\n  useMemo,\n  useReducer,\n} from 'react'\nimport type { PascalToCamelCaseWithoutSuffix } from '../../../types'\nimport { useNavigation } from '../NavigationProvider'\nimport { ANIMATION_DURATION, shrinkHeight } from '../constants'\nimport type { PinUnPinType } from '../types'\nimport { ItemContext, ItemProvider } from './ItemProvider'\n\nconst RelativeDiv = styled.div`\n  position: relative;\n`\n\nconst StyledPinIconOutline = styled(PinOutlineIcon, {\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 }) =>\n      active ? `background: ${theme.colors.primary.backgroundHover};` : null}\n  }\n`\n\nconst StyledUnpinIcon = StyledPinIconOutline.withComponent(UnpinIcon)\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(DragIcon)`\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  &: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(OpenInNewIcon)``\n\nconst WrapText = styled(Text)`\n  overflow-wrap: anywhere;\n  overflow: hidden;\n  display: -webkit-box;\n  -webkit-box-orient: vertical;\n  -webkit-line-clamp: 2;\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 }) => 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\"][data-animation-type=\"complex\"] {\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\"][data-animation-type=\"complex\"] {\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 StackIcon = styled(Stack)`\n  padding-top: ${({ theme }) => theme.space['0.5']};\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?: PascalToCamelCaseWithoutSuffix<\n    keyof typeof CategoryIcon,\n    'CategoryIcon'\n  >\n  categoryIconVariant?: ComponentProps<\n    (typeof CategoryIcon)['BaremetalCategoryIcon']\n  >['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?: HTMLAnchorElement['href']\n  target?: HTMLAnchorElement['target']\n  rel?: HTMLAnchorElement['rel']\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  onToggle?: (toggle: boolean) => void\n  onClickPinUnpin?: (parameters: PinUnPinType) => 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 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  'data-testid'?: string\n}\n\nconst onDragStopTrigger = (event: DragEvent<HTMLDivElement>) => {\n  // eslint-disable-next-line no-param-reassign\n  event.currentTarget.style.opacity = '1'\n}\n\nexport const Item = memo(\n  ({\n    children,\n    categoryIcon,\n    categoryIconVariant,\n    label,\n    subLabel,\n    badgeText,\n    badgeSentiment,\n    href,\n    target,\n    rel,\n    onToggle,\n    onClickPinUnpin,\n    toggle,\n    active,\n    noPinButton,\n    type = 'default',\n    as,\n    disabled,\n    noExpand = false,\n    index,\n    id,\n    'data-testid': dataTestId,\n  }: ItemProps) => {\n    const context = useNavigation()\n    if (!context) {\n      throw new Error(\n        'Navigation.Item can only be used inside a NavigationProvider.',\n      )\n    }\n\n    const itemProvider = useContext(ItemContext)\n    const hasParents = !!itemProvider\n\n    const {\n      expanded,\n      locales,\n      pinnedFeature,\n      pinItem,\n      unpinItem,\n      pinnedItems,\n      pinLimit,\n      animation,\n      registerItem,\n      shouldAnimate,\n      animationType,\n    } = context\n\n    useEffect(\n      () => {\n        if (type !== 'pinnedGroup' && pinnedFeature) {\n          registerItem({ [id]: { label, active, onToggle, onClickPinUnpin } })\n        }\n      },\n      // eslint-disable-next-line react-hooks/exhaustive-deps\n      [active, id, label, registerItem],\n    )\n\n    const [internalExpanded, onToggleExpand] = useReducer(\n      prevState => !prevState,\n      Boolean(toggle),\n    )\n\n    const triggerToggle = useCallback(() => {\n      onToggleExpand()\n      onToggle?.(internalExpanded)\n    }, [internalExpanded, onToggle])\n\n    const PaddedStack =\n      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 = useMemo(\n      () => StyledContainer.withComponent(containerTag),\n      [containerTag],\n    )\n\n    const CategoryIconUsed = categoryIcon\n      ? CategoryIcon[\n          `${\n            categoryIcon.charAt(0).toUpperCase() + categoryIcon.slice(1)\n          }CategoryIcon` as keyof typeof CategoryIcon\n        ]\n      : null\n\n    const ArrowIcon = useMemo(\n      () => (internalExpanded ? ArrowDownIcon : ArrowRightIcon),\n      [internalExpanded],\n    )\n\n    const PinUnpinIcon = useMemo(\n      () => (isItemPinned ? StyledUnpinIcon : StyledPinIconOutline),\n      [isItemPinned],\n    )\n\n    const ariaExpanded = useMemo(() => {\n      if (hasHrefAndNoChildren && internalExpanded) {\n        return true\n      }\n\n      if (hasHrefAndNoChildren && !internalExpanded) {\n        return false\n      }\n\n      return undefined\n    }, [hasHrefAndNoChildren, internalExpanded])\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 onDragStart = useCallback(\n      (event: DragEvent<HTMLDivElement>) => {\n        if (expanded) {\n          event.dataTransfer.setData(\n            'text/plain',\n            JSON.stringify({ label, index }),\n          )\n          // eslint-disable-next-line no-param-reassign\n          event.currentTarget.style.opacity = '0.5'\n        }\n\n        return undefined\n      },\n      [expanded, index, label],\n    )\n\n    const onDragEnd = useCallback(\n      (event: DragEvent<HTMLDivElement>) =>\n        expanded ? onDragStopTrigger(event) : undefined,\n      [expanded],\n    )\n\n    // This content is when the navigation is expanded\n    if (expanded || (!expanded && animation === 'expand')) {\n      return (\n        <>\n          <Container\n            gap={1}\n            direction=\"row\"\n            alignItems={categoryIcon ? 'flex-start' : 'center'}\n            justifyContent=\"space-between\"\n            data-has-sub-label={!!subLabel}\n            onClick={triggerToggle}\n            aria-expanded={ariaExpanded}\n            href={href}\n            target={target}\n            rel={rel}\n            data-is-pinnable={shouldShowPinnedButton}\n            data-is-active={active}\n            data-animation={shouldAnimate ? animation : undefined}\n            data-animation-type={animationType}\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={onDragStart}\n            onDragEnd={onDragEnd}\n            id={id}\n            data-testid={dataTestId}\n          >\n            <Stack\n              direction=\"row\"\n              gap={1}\n              alignItems={categoryIcon ? 'flex-start' : 'center'}\n              justifyContent=\"center\"\n            >\n              {CategoryIconUsed ? (\n                <ContainerCategoryIcon\n                  alignItems=\"center\"\n                  justifyContent=\"center\"\n                >\n                  <CategoryIconUsed\n                    variant={active ? 'primary' : categoryIconVariant}\n                    disabled={disabled}\n                  />\n                </ContainerCategoryIcon>\n              ) : null}\n              {type === 'pinned' && expanded ? (\n                <GrabIcon\n                  sentiment=\"neutral\"\n                  prominence=\"weak\"\n                  size=\"small\"\n                  disabled={disabled}\n                />\n              ) : null}\n              <Stack>\n                {!animation ? (\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                    data-animation={animation}\n                    disabled={disabled}\n                    whiteSpace=\"pre-wrap\"\n                  >\n                    {label}\n                  </WrapText>\n                ) : null}\n                {subLabel && !animation ? (\n                  <WrapText\n                    as=\"span\"\n                    variant=\"caption\"\n                    sentiment=\"neutral\"\n                    prominence=\"weak\"\n                    data-animation={animation}\n                    disabled={disabled}\n                    whiteSpace=\"pre-wrap\"\n                  >\n                    {subLabel}\n                  </WrapText>\n                ) : null}\n              </Stack>\n            </Stack>\n            <Stack\n              direction=\"row\"\n              alignItems=\"center\"\n              gap={href ? 1 : undefined}\n            >\n              {badgeText || hasPinnedFeatureAndNoChildren ? (\n                <>\n                  {badgeText && !animation ? (\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                          aria-label={isItemPinned ? 'unpin' : 'pin'}\n                          size=\"xsmall\"\n                          variant=\"ghost\"\n                          sentiment={active ? 'primary' : 'neutral'}\n                          onClick={(event: MouseEvent<HTMLDivElement>) => {\n                            if (pinnedItems.length < pinLimit || isItemPinned) {\n                              event.preventDefault()\n                              event.stopPropagation() // This is to avoid click spread to the parent and change the routing\n                              let newValue: string[] | undefined\n                              if (isItemPinned) {\n                                newValue = unpinItem(id)\n                              } else {\n                                newValue = pinItem(id)\n                              }\n\n                              onClickPinUnpin?.({\n                                state: isItemPinned ? 'unpin' : 'pin',\n                                id,\n                                totalPinned: newValue,\n                              })\n                            }\n                          }}\n                          disabled={isItemPinned ? false : isPinDisabled}\n                        >\n                          <PinUnpinIcon\n                            size=\"medium\"\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 && target === '_blank' && !animation ? (\n                <AnimatedIcon\n                  sentiment=\"neutral\"\n                  prominence=\"default\"\n                  disabled={disabled}\n                />\n              ) : null}\n              {children ? (\n                <StackIcon gap={1} direction=\"row\" alignItems=\"center\">\n                  {!animation && !noExpand ? (\n                    <ArrowIcon sentiment=\"neutral\" prominence=\"weak\" />\n                  ) : null}\n                </StackIcon>\n              ) : null}\n            </Stack>\n          </Container>\n          {children ? (\n            <>\n              {!noExpand ? (\n                <ItemProvider>\n                  <Expandable opened={internalExpanded} animationDuration={0}>\n                    <PaddedStack width={animation ? '100%' : undefined}>\n                      {children}\n                    </PaddedStack>\n                  </Expandable>\n                </ItemProvider>\n              ) : (\n                <ItemProvider>\n                  <PaddedStack width={animation ? '100%' : undefined}>\n                    {children}\n                  </PaddedStack>\n                </ItemProvider>\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                  aria-label={label}\n                >\n                  {CategoryIconUsed ? (\n                    <Stack\n                      direction=\"row\"\n                      gap={1}\n                      alignItems=\"center\"\n                      justifyContent=\"center\"\n                    >\n                      <CategoryIconUsed\n                        variant={active ? 'primary' : categoryIconVariant}\n                      />\n                    </Stack>\n                  ) : null}\n                </Button>\n              }\n              placement=\"right\"\n            >\n              <ItemProvider>{children}</ItemProvider>\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                aria-label={label}\n              >\n                <Stack\n                  direction=\"row\"\n                  gap={1}\n                  alignItems=\"center\"\n                  justifyContent=\"center\"\n                >\n                  {CategoryIconUsed ? (\n                    <CategoryIconUsed\n                      variant={active ? 'primary' : categoryIconVariant}\n                    />\n                  ) : (\n                    <ConsoleCategoryIcon\n                      variant={active ? 'primary' : categoryIconVariant}\n                    />\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          target={target}\n          rel={rel}\n          borderless\n          active={active}\n          disabled={disabled}\n          sentiment={active ? 'primary' : 'neutral'}\n          isPinnable={shouldShowPinnedButton}\n          onClick={() => onToggle?.(!!active)}\n        >\n          <Stack\n            gap={1}\n            direction=\"row\"\n            alignItems=\"center\"\n            justifyContent=\"space-between\"\n            flex={1}\n            width=\"100%\"\n          >\n            {!animation ? (\n              <WrapText as=\"span\" variant=\"bodySmall\" whiteSpace=\"pre-wrap\">\n                {label}\n              </WrapText>\n            ) : null}\n            <Stack direction=\"row\">\n              {badgeText && !animation ? (\n                <StyledBadge\n                  sentiment={badgeSentiment}\n                  size=\"small\"\n                  prominence=\"strong\"\n                  disabled={disabled}\n                >\n                  {badgeText}\n                </StyledBadge>\n              ) : null}\n              {hasHrefAndNoChildren && target === '_blank' ? (\n                <AnimatedIcon\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                      aria-label={isItemPinned ? 'unpin' : 'pin'}\n                      variant=\"ghost\"\n                      sentiment={active ? 'primary' : 'neutral'}\n                      onClick={(event: MouseEvent<HTMLDivElement>) => {\n                        if (pinnedItems.length < pinLimit || isItemPinned) {\n                          event.preventDefault()\n                          event.stopPropagation() // This is to avoid click spread to the parent and change the routing\n\n                          let newValue: string[] | undefined\n                          if (isItemPinned) {\n                            newValue = unpinItem(id)\n                          } else {\n                            newValue = pinItem(id)\n                          }\n                          onClickPinUnpin?.({\n                            state: isItemPinned ? 'unpin' : 'pin',\n                            id,\n                            totalPinned: newValue,\n                          })\n                        }\n                      }}\n                      disabled={isItemPinned ? false : isPinDisabled}\n                    >\n                      <PinUnpinIcon\n                        size=\"medium\"\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={target}\n              rel={rel}\n            >\n              <AnimatedIcon sentiment=\"neutral\" prominence=\"weak\" />\n            </Container>\n          </MenuStack>\n        </Tooltip>\n      )\n    }\n\n    return null\n  },\n)\n"]} */"));
107
107
  const StyledBadge = /* @__PURE__ */ _styled__default.default(ui.Badge, process.env.NODE_ENV === "production" ? {
108
108
  target: "e134hokc10"
109
109
  } : {
110
110
  target: "e134hokc10",
111
111
  label: "StyledBadge"
112
- })(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":"AAuGiC","file":"/home/runner/work/ultraviolet/ultraviolet/packages/plus/src/components/Navigation/components/Item.tsx","sourcesContent":["'use client'\n\nimport { css } from '@emotion/react'\nimport styled from '@emotion/styled'\nimport {\n  ArrowDownIcon,\n  ArrowRightIcon,\n  DragIcon,\n  OpenInNewIcon,\n  PinOutlineIcon,\n  UnpinIcon,\n} from '@ultraviolet/icons'\nimport * as CategoryIcon from '@ultraviolet/icons/category'\nimport { ConsoleCategoryIcon } from '@ultraviolet/icons/category'\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  isValidElement,\n  memo,\n  useCallback,\n  useContext,\n  useEffect,\n  useMemo,\n  useReducer,\n} from 'react'\nimport type { PascalToCamelCaseWithoutSuffix } from '../../../types'\nimport { useNavigation } from '../NavigationProvider'\nimport { ANIMATION_DURATION, shrinkHeight } from '../constants'\nimport type { PinUnPinType } from '../types'\nimport { ItemContext, ItemProvider } from './ItemProvider'\n\nconst RelativeDiv = styled.div`\n  position: relative;\n`\n\nconst StyledPinIconOutline = styled(PinOutlineIcon, {\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 }) =>\n      active ? `background: ${theme.colors.primary.backgroundHover};` : null}\n  }\n`\n\nconst StyledUnpinIcon = StyledPinIconOutline.withComponent(UnpinIcon)\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(DragIcon)`\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  &: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(OpenInNewIcon)``\n\nconst WrapText = styled(Text)`\n  overflow-wrap: anywhere;\n  overflow: hidden;\n  display: -webkit-box;\n  -webkit-box-orient: vertical;\n  -webkit-line-clamp: 2;\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 }) => 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\"][data-animation-type=\"complex\"] {\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\"][data-animation-type=\"complex\"] {\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 StackIcon = styled(Stack)`\n  padding-top: ${({ theme }) => theme.space['0.5']};\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?: PascalToCamelCaseWithoutSuffix<\n    keyof typeof CategoryIcon,\n    'CategoryIcon'\n  >\n  categoryIconVariant?: ComponentProps<\n    (typeof CategoryIcon)['BaremetalCategoryIcon']\n  >['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?: HTMLAnchorElement['href']\n  target?: HTMLAnchorElement['target']\n  rel?: HTMLAnchorElement['rel']\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  onToggle?: (toggle: boolean) => void\n  onClickPinUnpin?: (parameters: PinUnPinType) => 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 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  'data-testid'?: string\n}\n\nconst onDragStopTrigger = (event: DragEvent<HTMLDivElement>) => {\n  // eslint-disable-next-line no-param-reassign\n  event.currentTarget.style.opacity = '1'\n}\n\nexport const Item = memo(\n  ({\n    children,\n    categoryIcon,\n    categoryIconVariant,\n    label,\n    subLabel,\n    badgeText,\n    badgeSentiment,\n    href,\n    target,\n    rel,\n    onToggle,\n    onClickPinUnpin,\n    toggle,\n    active,\n    noPinButton,\n    type = 'default',\n    as,\n    disabled,\n    noExpand = false,\n    index,\n    id,\n    'data-testid': dataTestId,\n  }: ItemProps) => {\n    const context = useNavigation()\n    if (!context) {\n      throw new Error(\n        'Navigation.Item can only be used inside a NavigationProvider.',\n      )\n    }\n\n    const itemProvider = useContext(ItemContext)\n    const hasParents = !!itemProvider\n\n    const {\n      expanded,\n      locales,\n      pinnedFeature,\n      pinItem,\n      unpinItem,\n      pinnedItems,\n      pinLimit,\n      animation,\n      registerItem,\n      shouldAnimate,\n      animationType,\n    } = context\n\n    useEffect(\n      () => {\n        if (type !== 'pinnedGroup') {\n          registerItem({ [id]: { label, active, onToggle, onClickPinUnpin } })\n        }\n      },\n      // eslint-disable-next-line react-hooks/exhaustive-deps\n      [active, id, label, registerItem],\n    )\n\n    const [internalExpanded, onToggleExpand] = useReducer(\n      prevState => !prevState,\n      Boolean(toggle),\n    )\n\n    const triggerToggle = useCallback(() => {\n      onToggleExpand()\n      onToggle?.(internalExpanded)\n    }, [internalExpanded, onToggle])\n\n    const PaddedStack =\n      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 = useMemo(\n      () => StyledContainer.withComponent(containerTag),\n      [containerTag],\n    )\n\n    const CategoryIconUsed = categoryIcon\n      ? CategoryIcon[\n          `${\n            categoryIcon.charAt(0).toUpperCase() + categoryIcon.slice(1)\n          }CategoryIcon` as keyof typeof CategoryIcon\n        ]\n      : null\n\n    const ArrowIcon = useMemo(\n      () => (internalExpanded ? ArrowDownIcon : ArrowRightIcon),\n      [internalExpanded],\n    )\n\n    const PinUnpinIcon = useMemo(\n      () => (isItemPinned ? StyledUnpinIcon : StyledPinIconOutline),\n      [isItemPinned],\n    )\n\n    const ariaExpanded = useMemo(() => {\n      if (hasHrefAndNoChildren && internalExpanded) {\n        return true\n      }\n\n      if (hasHrefAndNoChildren && !internalExpanded) {\n        return false\n      }\n\n      return undefined\n    }, [hasHrefAndNoChildren, internalExpanded])\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 onDragStart = useCallback(\n      (event: DragEvent<HTMLDivElement>) => {\n        if (expanded) {\n          event.dataTransfer.setData(\n            'text/plain',\n            JSON.stringify({ label, index }),\n          )\n          // eslint-disable-next-line no-param-reassign\n          event.currentTarget.style.opacity = '0.5'\n        }\n\n        return undefined\n      },\n      [expanded, index, label],\n    )\n\n    const onDragEnd = useCallback(\n      (event: DragEvent<HTMLDivElement>) =>\n        expanded ? onDragStopTrigger(event) : undefined,\n      [expanded],\n    )\n\n    // This content is when the navigation is expanded\n    if (expanded || (!expanded && animation === 'expand')) {\n      return (\n        <>\n          <Container\n            gap={1}\n            direction=\"row\"\n            alignItems={categoryIcon ? 'flex-start' : 'center'}\n            justifyContent=\"space-between\"\n            data-has-sub-label={!!subLabel}\n            onClick={triggerToggle}\n            aria-expanded={ariaExpanded}\n            href={href}\n            target={target}\n            rel={rel}\n            data-is-pinnable={shouldShowPinnedButton}\n            data-is-active={active}\n            data-animation={shouldAnimate ? animation : undefined}\n            data-animation-type={animationType}\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={onDragStart}\n            onDragEnd={onDragEnd}\n            id={id}\n            data-testid={dataTestId}\n          >\n            <Stack\n              direction=\"row\"\n              gap={1}\n              alignItems={categoryIcon ? 'flex-start' : 'center'}\n              justifyContent=\"center\"\n            >\n              {CategoryIconUsed ? (\n                <ContainerCategoryIcon\n                  alignItems=\"center\"\n                  justifyContent=\"center\"\n                >\n                  <CategoryIconUsed\n                    variant={active ? 'primary' : categoryIconVariant}\n                    disabled={disabled}\n                  />\n                </ContainerCategoryIcon>\n              ) : null}\n              {type === 'pinned' && expanded ? (\n                <GrabIcon\n                  sentiment=\"neutral\"\n                  prominence=\"weak\"\n                  size=\"small\"\n                  disabled={disabled}\n                />\n              ) : null}\n              <Stack>\n                {!animation ? (\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                    data-animation={animation}\n                    disabled={disabled}\n                    whiteSpace=\"pre-wrap\"\n                  >\n                    {label}\n                  </WrapText>\n                ) : null}\n                {subLabel && !animation ? (\n                  <WrapText\n                    as=\"span\"\n                    variant=\"caption\"\n                    sentiment=\"neutral\"\n                    prominence=\"weak\"\n                    data-animation={animation}\n                    disabled={disabled}\n                    whiteSpace=\"pre-wrap\"\n                  >\n                    {subLabel}\n                  </WrapText>\n                ) : null}\n              </Stack>\n            </Stack>\n            <Stack\n              direction=\"row\"\n              alignItems=\"center\"\n              gap={href ? 1 : undefined}\n            >\n              {badgeText || hasPinnedFeatureAndNoChildren ? (\n                <>\n                  {badgeText && !animation ? (\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                          aria-label={isItemPinned ? 'unpin' : 'pin'}\n                          size=\"xsmall\"\n                          variant=\"ghost\"\n                          sentiment={active ? 'primary' : 'neutral'}\n                          onClick={(event: MouseEvent<HTMLDivElement>) => {\n                            if (pinnedItems.length < pinLimit || isItemPinned) {\n                              event.preventDefault()\n                              event.stopPropagation() // This is to avoid click spread to the parent and change the routing\n                              let newValue: string[] | undefined\n                              if (isItemPinned) {\n                                newValue = unpinItem(id)\n                              } else {\n                                newValue = pinItem(id)\n                              }\n\n                              onClickPinUnpin?.({\n                                state: isItemPinned ? 'unpin' : 'pin',\n                                id,\n                                totalPinned: newValue,\n                              })\n                            }\n                          }}\n                          disabled={isItemPinned ? false : isPinDisabled}\n                        >\n                          <PinUnpinIcon\n                            size=\"medium\"\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 && target === '_blank' && !animation ? (\n                <AnimatedIcon\n                  sentiment=\"neutral\"\n                  prominence=\"default\"\n                  disabled={disabled}\n                />\n              ) : null}\n              {children ? (\n                <StackIcon gap={1} direction=\"row\" alignItems=\"center\">\n                  {!animation && !noExpand ? (\n                    <ArrowIcon sentiment=\"neutral\" prominence=\"weak\" />\n                  ) : null}\n                </StackIcon>\n              ) : null}\n            </Stack>\n          </Container>\n          {children ? (\n            <>\n              {!noExpand ? (\n                <ItemProvider>\n                  <Expandable opened={internalExpanded} animationDuration={0}>\n                    <PaddedStack width={animation ? '100%' : undefined}>\n                      {children}\n                    </PaddedStack>\n                  </Expandable>\n                </ItemProvider>\n              ) : (\n                <ItemProvider>\n                  <PaddedStack width={animation ? '100%' : undefined}>\n                    {children}\n                  </PaddedStack>\n                </ItemProvider>\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                  aria-label={label}\n                >\n                  {CategoryIconUsed ? (\n                    <Stack\n                      direction=\"row\"\n                      gap={1}\n                      alignItems=\"center\"\n                      justifyContent=\"center\"\n                    >\n                      <CategoryIconUsed\n                        variant={active ? 'primary' : categoryIconVariant}\n                      />\n                    </Stack>\n                  ) : null}\n                </Button>\n              }\n              placement=\"right\"\n            >\n              <ItemProvider>{children}</ItemProvider>\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                aria-label={label}\n              >\n                <Stack\n                  direction=\"row\"\n                  gap={1}\n                  alignItems=\"center\"\n                  justifyContent=\"center\"\n                >\n                  {CategoryIconUsed ? (\n                    <CategoryIconUsed\n                      variant={active ? 'primary' : categoryIconVariant}\n                    />\n                  ) : (\n                    <ConsoleCategoryIcon\n                      variant={active ? 'primary' : categoryIconVariant}\n                    />\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          target={target}\n          rel={rel}\n          borderless\n          active={active}\n          disabled={disabled}\n          sentiment={active ? 'primary' : 'neutral'}\n          isPinnable={shouldShowPinnedButton}\n          onClick={() => onToggle?.(!!active)}\n        >\n          <Stack\n            gap={1}\n            direction=\"row\"\n            alignItems=\"center\"\n            justifyContent=\"space-between\"\n            flex={1}\n            width=\"100%\"\n          >\n            {!animation ? (\n              <WrapText as=\"span\" variant=\"bodySmall\" whiteSpace=\"pre-wrap\">\n                {label}\n              </WrapText>\n            ) : null}\n            <Stack direction=\"row\">\n              {badgeText && !animation ? (\n                <StyledBadge\n                  sentiment={badgeSentiment}\n                  size=\"small\"\n                  prominence=\"strong\"\n                  disabled={disabled}\n                >\n                  {badgeText}\n                </StyledBadge>\n              ) : null}\n              {hasHrefAndNoChildren && target === '_blank' ? (\n                <AnimatedIcon\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                      aria-label={isItemPinned ? 'unpin' : 'pin'}\n                      variant=\"ghost\"\n                      sentiment={active ? 'primary' : 'neutral'}\n                      onClick={(event: MouseEvent<HTMLDivElement>) => {\n                        if (pinnedItems.length < pinLimit || isItemPinned) {\n                          event.preventDefault()\n                          event.stopPropagation() // This is to avoid click spread to the parent and change the routing\n\n                          let newValue: string[] | undefined\n                          if (isItemPinned) {\n                            newValue = unpinItem(id)\n                          } else {\n                            newValue = pinItem(id)\n                          }\n                          onClickPinUnpin?.({\n                            state: isItemPinned ? 'unpin' : 'pin',\n                            id,\n                            totalPinned: newValue,\n                          })\n                        }\n                      }}\n                      disabled={isItemPinned ? false : isPinDisabled}\n                    >\n                      <PinUnpinIcon\n                        size=\"medium\"\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={target}\n              rel={rel}\n            >\n              <AnimatedIcon sentiment=\"neutral\" prominence=\"weak\" />\n            </Container>\n          </MenuStack>\n        </Tooltip>\n      )\n    }\n\n    return null\n  },\n)\n"]} */");
112
+ })(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":"AAuGiC","file":"/home/runner/work/ultraviolet/ultraviolet/packages/plus/src/components/Navigation/components/Item.tsx","sourcesContent":["'use client'\n\nimport { css } from '@emotion/react'\nimport styled from '@emotion/styled'\nimport {\n  ArrowDownIcon,\n  ArrowRightIcon,\n  DragIcon,\n  OpenInNewIcon,\n  PinOutlineIcon,\n  UnpinIcon,\n} from '@ultraviolet/icons'\nimport * as CategoryIcon from '@ultraviolet/icons/category'\nimport { ConsoleCategoryIcon } from '@ultraviolet/icons/category'\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  isValidElement,\n  memo,\n  useCallback,\n  useContext,\n  useEffect,\n  useMemo,\n  useReducer,\n} from 'react'\nimport type { PascalToCamelCaseWithoutSuffix } from '../../../types'\nimport { useNavigation } from '../NavigationProvider'\nimport { ANIMATION_DURATION, shrinkHeight } from '../constants'\nimport type { PinUnPinType } from '../types'\nimport { ItemContext, ItemProvider } from './ItemProvider'\n\nconst RelativeDiv = styled.div`\n  position: relative;\n`\n\nconst StyledPinIconOutline = styled(PinOutlineIcon, {\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 }) =>\n      active ? `background: ${theme.colors.primary.backgroundHover};` : null}\n  }\n`\n\nconst StyledUnpinIcon = StyledPinIconOutline.withComponent(UnpinIcon)\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(DragIcon)`\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  &: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(OpenInNewIcon)``\n\nconst WrapText = styled(Text)`\n  overflow-wrap: anywhere;\n  overflow: hidden;\n  display: -webkit-box;\n  -webkit-box-orient: vertical;\n  -webkit-line-clamp: 2;\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 }) => 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\"][data-animation-type=\"complex\"] {\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\"][data-animation-type=\"complex\"] {\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 StackIcon = styled(Stack)`\n  padding-top: ${({ theme }) => theme.space['0.5']};\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?: PascalToCamelCaseWithoutSuffix<\n    keyof typeof CategoryIcon,\n    'CategoryIcon'\n  >\n  categoryIconVariant?: ComponentProps<\n    (typeof CategoryIcon)['BaremetalCategoryIcon']\n  >['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?: HTMLAnchorElement['href']\n  target?: HTMLAnchorElement['target']\n  rel?: HTMLAnchorElement['rel']\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  onToggle?: (toggle: boolean) => void\n  onClickPinUnpin?: (parameters: PinUnPinType) => 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 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  'data-testid'?: string\n}\n\nconst onDragStopTrigger = (event: DragEvent<HTMLDivElement>) => {\n  // eslint-disable-next-line no-param-reassign\n  event.currentTarget.style.opacity = '1'\n}\n\nexport const Item = memo(\n  ({\n    children,\n    categoryIcon,\n    categoryIconVariant,\n    label,\n    subLabel,\n    badgeText,\n    badgeSentiment,\n    href,\n    target,\n    rel,\n    onToggle,\n    onClickPinUnpin,\n    toggle,\n    active,\n    noPinButton,\n    type = 'default',\n    as,\n    disabled,\n    noExpand = false,\n    index,\n    id,\n    'data-testid': dataTestId,\n  }: ItemProps) => {\n    const context = useNavigation()\n    if (!context) {\n      throw new Error(\n        'Navigation.Item can only be used inside a NavigationProvider.',\n      )\n    }\n\n    const itemProvider = useContext(ItemContext)\n    const hasParents = !!itemProvider\n\n    const {\n      expanded,\n      locales,\n      pinnedFeature,\n      pinItem,\n      unpinItem,\n      pinnedItems,\n      pinLimit,\n      animation,\n      registerItem,\n      shouldAnimate,\n      animationType,\n    } = context\n\n    useEffect(\n      () => {\n        if (type !== 'pinnedGroup' && pinnedFeature) {\n          registerItem({ [id]: { label, active, onToggle, onClickPinUnpin } })\n        }\n      },\n      // eslint-disable-next-line react-hooks/exhaustive-deps\n      [active, id, label, registerItem],\n    )\n\n    const [internalExpanded, onToggleExpand] = useReducer(\n      prevState => !prevState,\n      Boolean(toggle),\n    )\n\n    const triggerToggle = useCallback(() => {\n      onToggleExpand()\n      onToggle?.(internalExpanded)\n    }, [internalExpanded, onToggle])\n\n    const PaddedStack =\n      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 = useMemo(\n      () => StyledContainer.withComponent(containerTag),\n      [containerTag],\n    )\n\n    const CategoryIconUsed = categoryIcon\n      ? CategoryIcon[\n          `${\n            categoryIcon.charAt(0).toUpperCase() + categoryIcon.slice(1)\n          }CategoryIcon` as keyof typeof CategoryIcon\n        ]\n      : null\n\n    const ArrowIcon = useMemo(\n      () => (internalExpanded ? ArrowDownIcon : ArrowRightIcon),\n      [internalExpanded],\n    )\n\n    const PinUnpinIcon = useMemo(\n      () => (isItemPinned ? StyledUnpinIcon : StyledPinIconOutline),\n      [isItemPinned],\n    )\n\n    const ariaExpanded = useMemo(() => {\n      if (hasHrefAndNoChildren && internalExpanded) {\n        return true\n      }\n\n      if (hasHrefAndNoChildren && !internalExpanded) {\n        return false\n      }\n\n      return undefined\n    }, [hasHrefAndNoChildren, internalExpanded])\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 onDragStart = useCallback(\n      (event: DragEvent<HTMLDivElement>) => {\n        if (expanded) {\n          event.dataTransfer.setData(\n            'text/plain',\n            JSON.stringify({ label, index }),\n          )\n          // eslint-disable-next-line no-param-reassign\n          event.currentTarget.style.opacity = '0.5'\n        }\n\n        return undefined\n      },\n      [expanded, index, label],\n    )\n\n    const onDragEnd = useCallback(\n      (event: DragEvent<HTMLDivElement>) =>\n        expanded ? onDragStopTrigger(event) : undefined,\n      [expanded],\n    )\n\n    // This content is when the navigation is expanded\n    if (expanded || (!expanded && animation === 'expand')) {\n      return (\n        <>\n          <Container\n            gap={1}\n            direction=\"row\"\n            alignItems={categoryIcon ? 'flex-start' : 'center'}\n            justifyContent=\"space-between\"\n            data-has-sub-label={!!subLabel}\n            onClick={triggerToggle}\n            aria-expanded={ariaExpanded}\n            href={href}\n            target={target}\n            rel={rel}\n            data-is-pinnable={shouldShowPinnedButton}\n            data-is-active={active}\n            data-animation={shouldAnimate ? animation : undefined}\n            data-animation-type={animationType}\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={onDragStart}\n            onDragEnd={onDragEnd}\n            id={id}\n            data-testid={dataTestId}\n          >\n            <Stack\n              direction=\"row\"\n              gap={1}\n              alignItems={categoryIcon ? 'flex-start' : 'center'}\n              justifyContent=\"center\"\n            >\n              {CategoryIconUsed ? (\n                <ContainerCategoryIcon\n                  alignItems=\"center\"\n                  justifyContent=\"center\"\n                >\n                  <CategoryIconUsed\n                    variant={active ? 'primary' : categoryIconVariant}\n                    disabled={disabled}\n                  />\n                </ContainerCategoryIcon>\n              ) : null}\n              {type === 'pinned' && expanded ? (\n                <GrabIcon\n                  sentiment=\"neutral\"\n                  prominence=\"weak\"\n                  size=\"small\"\n                  disabled={disabled}\n                />\n              ) : null}\n              <Stack>\n                {!animation ? (\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                    data-animation={animation}\n                    disabled={disabled}\n                    whiteSpace=\"pre-wrap\"\n                  >\n                    {label}\n                  </WrapText>\n                ) : null}\n                {subLabel && !animation ? (\n                  <WrapText\n                    as=\"span\"\n                    variant=\"caption\"\n                    sentiment=\"neutral\"\n                    prominence=\"weak\"\n                    data-animation={animation}\n                    disabled={disabled}\n                    whiteSpace=\"pre-wrap\"\n                  >\n                    {subLabel}\n                  </WrapText>\n                ) : null}\n              </Stack>\n            </Stack>\n            <Stack\n              direction=\"row\"\n              alignItems=\"center\"\n              gap={href ? 1 : undefined}\n            >\n              {badgeText || hasPinnedFeatureAndNoChildren ? (\n                <>\n                  {badgeText && !animation ? (\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                          aria-label={isItemPinned ? 'unpin' : 'pin'}\n                          size=\"xsmall\"\n                          variant=\"ghost\"\n                          sentiment={active ? 'primary' : 'neutral'}\n                          onClick={(event: MouseEvent<HTMLDivElement>) => {\n                            if (pinnedItems.length < pinLimit || isItemPinned) {\n                              event.preventDefault()\n                              event.stopPropagation() // This is to avoid click spread to the parent and change the routing\n                              let newValue: string[] | undefined\n                              if (isItemPinned) {\n                                newValue = unpinItem(id)\n                              } else {\n                                newValue = pinItem(id)\n                              }\n\n                              onClickPinUnpin?.({\n                                state: isItemPinned ? 'unpin' : 'pin',\n                                id,\n                                totalPinned: newValue,\n                              })\n                            }\n                          }}\n                          disabled={isItemPinned ? false : isPinDisabled}\n                        >\n                          <PinUnpinIcon\n                            size=\"medium\"\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 && target === '_blank' && !animation ? (\n                <AnimatedIcon\n                  sentiment=\"neutral\"\n                  prominence=\"default\"\n                  disabled={disabled}\n                />\n              ) : null}\n              {children ? (\n                <StackIcon gap={1} direction=\"row\" alignItems=\"center\">\n                  {!animation && !noExpand ? (\n                    <ArrowIcon sentiment=\"neutral\" prominence=\"weak\" />\n                  ) : null}\n                </StackIcon>\n              ) : null}\n            </Stack>\n          </Container>\n          {children ? (\n            <>\n              {!noExpand ? (\n                <ItemProvider>\n                  <Expandable opened={internalExpanded} animationDuration={0}>\n                    <PaddedStack width={animation ? '100%' : undefined}>\n                      {children}\n                    </PaddedStack>\n                  </Expandable>\n                </ItemProvider>\n              ) : (\n                <ItemProvider>\n                  <PaddedStack width={animation ? '100%' : undefined}>\n                    {children}\n                  </PaddedStack>\n                </ItemProvider>\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                  aria-label={label}\n                >\n                  {CategoryIconUsed ? (\n                    <Stack\n                      direction=\"row\"\n                      gap={1}\n                      alignItems=\"center\"\n                      justifyContent=\"center\"\n                    >\n                      <CategoryIconUsed\n                        variant={active ? 'primary' : categoryIconVariant}\n                      />\n                    </Stack>\n                  ) : null}\n                </Button>\n              }\n              placement=\"right\"\n            >\n              <ItemProvider>{children}</ItemProvider>\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                aria-label={label}\n              >\n                <Stack\n                  direction=\"row\"\n                  gap={1}\n                  alignItems=\"center\"\n                  justifyContent=\"center\"\n                >\n                  {CategoryIconUsed ? (\n                    <CategoryIconUsed\n                      variant={active ? 'primary' : categoryIconVariant}\n                    />\n                  ) : (\n                    <ConsoleCategoryIcon\n                      variant={active ? 'primary' : categoryIconVariant}\n                    />\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          target={target}\n          rel={rel}\n          borderless\n          active={active}\n          disabled={disabled}\n          sentiment={active ? 'primary' : 'neutral'}\n          isPinnable={shouldShowPinnedButton}\n          onClick={() => onToggle?.(!!active)}\n        >\n          <Stack\n            gap={1}\n            direction=\"row\"\n            alignItems=\"center\"\n            justifyContent=\"space-between\"\n            flex={1}\n            width=\"100%\"\n          >\n            {!animation ? (\n              <WrapText as=\"span\" variant=\"bodySmall\" whiteSpace=\"pre-wrap\">\n                {label}\n              </WrapText>\n            ) : null}\n            <Stack direction=\"row\">\n              {badgeText && !animation ? (\n                <StyledBadge\n                  sentiment={badgeSentiment}\n                  size=\"small\"\n                  prominence=\"strong\"\n                  disabled={disabled}\n                >\n                  {badgeText}\n                </StyledBadge>\n              ) : null}\n              {hasHrefAndNoChildren && target === '_blank' ? (\n                <AnimatedIcon\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                      aria-label={isItemPinned ? 'unpin' : 'pin'}\n                      variant=\"ghost\"\n                      sentiment={active ? 'primary' : 'neutral'}\n                      onClick={(event: MouseEvent<HTMLDivElement>) => {\n                        if (pinnedItems.length < pinLimit || isItemPinned) {\n                          event.preventDefault()\n                          event.stopPropagation() // This is to avoid click spread to the parent and change the routing\n\n                          let newValue: string[] | undefined\n                          if (isItemPinned) {\n                            newValue = unpinItem(id)\n                          } else {\n                            newValue = pinItem(id)\n                          }\n                          onClickPinUnpin?.({\n                            state: isItemPinned ? 'unpin' : 'pin',\n                            id,\n                            totalPinned: newValue,\n                          })\n                        }\n                      }}\n                      disabled={isItemPinned ? false : isPinDisabled}\n                    >\n                      <PinUnpinIcon\n                        size=\"medium\"\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={target}\n              rel={rel}\n            >\n              <AnimatedIcon sentiment=\"neutral\" prominence=\"weak\" />\n            </Container>\n          </MenuStack>\n        </Tooltip>\n      )\n    }\n\n    return null\n  },\n)\n"]} */");
113
113
  const StyledMenuItem = /* @__PURE__ */ _styled__default.default(ui.MenuV2.Item, process.env.NODE_ENV === "production" ? {
114
114
  shouldForwardProp: (prop) => !["isPinnable"].includes(prop),
115
115
  target: "e134hokc9"
@@ -119,7 +119,7 @@ const StyledMenuItem = /* @__PURE__ */ _styled__default.default(ui.MenuV2.Item,
119
119
  label: "StyledMenuItem"
120
120
  })("text-align:left;&:hover,&:focus,&:active{", PinnedButton, "{opacity:1;}", StyledBadge, "{opacity:", ({
121
121
  isPinnable
122
- }) => 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":"AA6GE","file":"/home/runner/work/ultraviolet/ultraviolet/packages/plus/src/components/Navigation/components/Item.tsx","sourcesContent":["'use client'\n\nimport { css } from '@emotion/react'\nimport styled from '@emotion/styled'\nimport {\n  ArrowDownIcon,\n  ArrowRightIcon,\n  DragIcon,\n  OpenInNewIcon,\n  PinOutlineIcon,\n  UnpinIcon,\n} from '@ultraviolet/icons'\nimport * as CategoryIcon from '@ultraviolet/icons/category'\nimport { ConsoleCategoryIcon } from '@ultraviolet/icons/category'\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  isValidElement,\n  memo,\n  useCallback,\n  useContext,\n  useEffect,\n  useMemo,\n  useReducer,\n} from 'react'\nimport type { PascalToCamelCaseWithoutSuffix } from '../../../types'\nimport { useNavigation } from '../NavigationProvider'\nimport { ANIMATION_DURATION, shrinkHeight } from '../constants'\nimport type { PinUnPinType } from '../types'\nimport { ItemContext, ItemProvider } from './ItemProvider'\n\nconst RelativeDiv = styled.div`\n  position: relative;\n`\n\nconst StyledPinIconOutline = styled(PinOutlineIcon, {\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 }) =>\n      active ? `background: ${theme.colors.primary.backgroundHover};` : null}\n  }\n`\n\nconst StyledUnpinIcon = StyledPinIconOutline.withComponent(UnpinIcon)\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(DragIcon)`\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  &: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(OpenInNewIcon)``\n\nconst WrapText = styled(Text)`\n  overflow-wrap: anywhere;\n  overflow: hidden;\n  display: -webkit-box;\n  -webkit-box-orient: vertical;\n  -webkit-line-clamp: 2;\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 }) => 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\"][data-animation-type=\"complex\"] {\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\"][data-animation-type=\"complex\"] {\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 StackIcon = styled(Stack)`\n  padding-top: ${({ theme }) => theme.space['0.5']};\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?: PascalToCamelCaseWithoutSuffix<\n    keyof typeof CategoryIcon,\n    'CategoryIcon'\n  >\n  categoryIconVariant?: ComponentProps<\n    (typeof CategoryIcon)['BaremetalCategoryIcon']\n  >['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?: HTMLAnchorElement['href']\n  target?: HTMLAnchorElement['target']\n  rel?: HTMLAnchorElement['rel']\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  onToggle?: (toggle: boolean) => void\n  onClickPinUnpin?: (parameters: PinUnPinType) => 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 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  'data-testid'?: string\n}\n\nconst onDragStopTrigger = (event: DragEvent<HTMLDivElement>) => {\n  // eslint-disable-next-line no-param-reassign\n  event.currentTarget.style.opacity = '1'\n}\n\nexport const Item = memo(\n  ({\n    children,\n    categoryIcon,\n    categoryIconVariant,\n    label,\n    subLabel,\n    badgeText,\n    badgeSentiment,\n    href,\n    target,\n    rel,\n    onToggle,\n    onClickPinUnpin,\n    toggle,\n    active,\n    noPinButton,\n    type = 'default',\n    as,\n    disabled,\n    noExpand = false,\n    index,\n    id,\n    'data-testid': dataTestId,\n  }: ItemProps) => {\n    const context = useNavigation()\n    if (!context) {\n      throw new Error(\n        'Navigation.Item can only be used inside a NavigationProvider.',\n      )\n    }\n\n    const itemProvider = useContext(ItemContext)\n    const hasParents = !!itemProvider\n\n    const {\n      expanded,\n      locales,\n      pinnedFeature,\n      pinItem,\n      unpinItem,\n      pinnedItems,\n      pinLimit,\n      animation,\n      registerItem,\n      shouldAnimate,\n      animationType,\n    } = context\n\n    useEffect(\n      () => {\n        if (type !== 'pinnedGroup') {\n          registerItem({ [id]: { label, active, onToggle, onClickPinUnpin } })\n        }\n      },\n      // eslint-disable-next-line react-hooks/exhaustive-deps\n      [active, id, label, registerItem],\n    )\n\n    const [internalExpanded, onToggleExpand] = useReducer(\n      prevState => !prevState,\n      Boolean(toggle),\n    )\n\n    const triggerToggle = useCallback(() => {\n      onToggleExpand()\n      onToggle?.(internalExpanded)\n    }, [internalExpanded, onToggle])\n\n    const PaddedStack =\n      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 = useMemo(\n      () => StyledContainer.withComponent(containerTag),\n      [containerTag],\n    )\n\n    const CategoryIconUsed = categoryIcon\n      ? CategoryIcon[\n          `${\n            categoryIcon.charAt(0).toUpperCase() + categoryIcon.slice(1)\n          }CategoryIcon` as keyof typeof CategoryIcon\n        ]\n      : null\n\n    const ArrowIcon = useMemo(\n      () => (internalExpanded ? ArrowDownIcon : ArrowRightIcon),\n      [internalExpanded],\n    )\n\n    const PinUnpinIcon = useMemo(\n      () => (isItemPinned ? StyledUnpinIcon : StyledPinIconOutline),\n      [isItemPinned],\n    )\n\n    const ariaExpanded = useMemo(() => {\n      if (hasHrefAndNoChildren && internalExpanded) {\n        return true\n      }\n\n      if (hasHrefAndNoChildren && !internalExpanded) {\n        return false\n      }\n\n      return undefined\n    }, [hasHrefAndNoChildren, internalExpanded])\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 onDragStart = useCallback(\n      (event: DragEvent<HTMLDivElement>) => {\n        if (expanded) {\n          event.dataTransfer.setData(\n            'text/plain',\n            JSON.stringify({ label, index }),\n          )\n          // eslint-disable-next-line no-param-reassign\n          event.currentTarget.style.opacity = '0.5'\n        }\n\n        return undefined\n      },\n      [expanded, index, label],\n    )\n\n    const onDragEnd = useCallback(\n      (event: DragEvent<HTMLDivElement>) =>\n        expanded ? onDragStopTrigger(event) : undefined,\n      [expanded],\n    )\n\n    // This content is when the navigation is expanded\n    if (expanded || (!expanded && animation === 'expand')) {\n      return (\n        <>\n          <Container\n            gap={1}\n            direction=\"row\"\n            alignItems={categoryIcon ? 'flex-start' : 'center'}\n            justifyContent=\"space-between\"\n            data-has-sub-label={!!subLabel}\n            onClick={triggerToggle}\n            aria-expanded={ariaExpanded}\n            href={href}\n            target={target}\n            rel={rel}\n            data-is-pinnable={shouldShowPinnedButton}\n            data-is-active={active}\n            data-animation={shouldAnimate ? animation : undefined}\n            data-animation-type={animationType}\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={onDragStart}\n            onDragEnd={onDragEnd}\n            id={id}\n            data-testid={dataTestId}\n          >\n            <Stack\n              direction=\"row\"\n              gap={1}\n              alignItems={categoryIcon ? 'flex-start' : 'center'}\n              justifyContent=\"center\"\n            >\n              {CategoryIconUsed ? (\n                <ContainerCategoryIcon\n                  alignItems=\"center\"\n                  justifyContent=\"center\"\n                >\n                  <CategoryIconUsed\n                    variant={active ? 'primary' : categoryIconVariant}\n                    disabled={disabled}\n                  />\n                </ContainerCategoryIcon>\n              ) : null}\n              {type === 'pinned' && expanded ? (\n                <GrabIcon\n                  sentiment=\"neutral\"\n                  prominence=\"weak\"\n                  size=\"small\"\n                  disabled={disabled}\n                />\n              ) : null}\n              <Stack>\n                {!animation ? (\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                    data-animation={animation}\n                    disabled={disabled}\n                    whiteSpace=\"pre-wrap\"\n                  >\n                    {label}\n                  </WrapText>\n                ) : null}\n                {subLabel && !animation ? (\n                  <WrapText\n                    as=\"span\"\n                    variant=\"caption\"\n                    sentiment=\"neutral\"\n                    prominence=\"weak\"\n                    data-animation={animation}\n                    disabled={disabled}\n                    whiteSpace=\"pre-wrap\"\n                  >\n                    {subLabel}\n                  </WrapText>\n                ) : null}\n              </Stack>\n            </Stack>\n            <Stack\n              direction=\"row\"\n              alignItems=\"center\"\n              gap={href ? 1 : undefined}\n            >\n              {badgeText || hasPinnedFeatureAndNoChildren ? (\n                <>\n                  {badgeText && !animation ? (\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                          aria-label={isItemPinned ? 'unpin' : 'pin'}\n                          size=\"xsmall\"\n                          variant=\"ghost\"\n                          sentiment={active ? 'primary' : 'neutral'}\n                          onClick={(event: MouseEvent<HTMLDivElement>) => {\n                            if (pinnedItems.length < pinLimit || isItemPinned) {\n                              event.preventDefault()\n                              event.stopPropagation() // This is to avoid click spread to the parent and change the routing\n                              let newValue: string[] | undefined\n                              if (isItemPinned) {\n                                newValue = unpinItem(id)\n                              } else {\n                                newValue = pinItem(id)\n                              }\n\n                              onClickPinUnpin?.({\n                                state: isItemPinned ? 'unpin' : 'pin',\n                                id,\n                                totalPinned: newValue,\n                              })\n                            }\n                          }}\n                          disabled={isItemPinned ? false : isPinDisabled}\n                        >\n                          <PinUnpinIcon\n                            size=\"medium\"\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 && target === '_blank' && !animation ? (\n                <AnimatedIcon\n                  sentiment=\"neutral\"\n                  prominence=\"default\"\n                  disabled={disabled}\n                />\n              ) : null}\n              {children ? (\n                <StackIcon gap={1} direction=\"row\" alignItems=\"center\">\n                  {!animation && !noExpand ? (\n                    <ArrowIcon sentiment=\"neutral\" prominence=\"weak\" />\n                  ) : null}\n                </StackIcon>\n              ) : null}\n            </Stack>\n          </Container>\n          {children ? (\n            <>\n              {!noExpand ? (\n                <ItemProvider>\n                  <Expandable opened={internalExpanded} animationDuration={0}>\n                    <PaddedStack width={animation ? '100%' : undefined}>\n                      {children}\n                    </PaddedStack>\n                  </Expandable>\n                </ItemProvider>\n              ) : (\n                <ItemProvider>\n                  <PaddedStack width={animation ? '100%' : undefined}>\n                    {children}\n                  </PaddedStack>\n                </ItemProvider>\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                  aria-label={label}\n                >\n                  {CategoryIconUsed ? (\n                    <Stack\n                      direction=\"row\"\n                      gap={1}\n                      alignItems=\"center\"\n                      justifyContent=\"center\"\n                    >\n                      <CategoryIconUsed\n                        variant={active ? 'primary' : categoryIconVariant}\n                      />\n                    </Stack>\n                  ) : null}\n                </Button>\n              }\n              placement=\"right\"\n            >\n              <ItemProvider>{children}</ItemProvider>\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                aria-label={label}\n              >\n                <Stack\n                  direction=\"row\"\n                  gap={1}\n                  alignItems=\"center\"\n                  justifyContent=\"center\"\n                >\n                  {CategoryIconUsed ? (\n                    <CategoryIconUsed\n                      variant={active ? 'primary' : categoryIconVariant}\n                    />\n                  ) : (\n                    <ConsoleCategoryIcon\n                      variant={active ? 'primary' : categoryIconVariant}\n                    />\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          target={target}\n          rel={rel}\n          borderless\n          active={active}\n          disabled={disabled}\n          sentiment={active ? 'primary' : 'neutral'}\n          isPinnable={shouldShowPinnedButton}\n          onClick={() => onToggle?.(!!active)}\n        >\n          <Stack\n            gap={1}\n            direction=\"row\"\n            alignItems=\"center\"\n            justifyContent=\"space-between\"\n            flex={1}\n            width=\"100%\"\n          >\n            {!animation ? (\n              <WrapText as=\"span\" variant=\"bodySmall\" whiteSpace=\"pre-wrap\">\n                {label}\n              </WrapText>\n            ) : null}\n            <Stack direction=\"row\">\n              {badgeText && !animation ? (\n                <StyledBadge\n                  sentiment={badgeSentiment}\n                  size=\"small\"\n                  prominence=\"strong\"\n                  disabled={disabled}\n                >\n                  {badgeText}\n                </StyledBadge>\n              ) : null}\n              {hasHrefAndNoChildren && target === '_blank' ? (\n                <AnimatedIcon\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                      aria-label={isItemPinned ? 'unpin' : 'pin'}\n                      variant=\"ghost\"\n                      sentiment={active ? 'primary' : 'neutral'}\n                      onClick={(event: MouseEvent<HTMLDivElement>) => {\n                        if (pinnedItems.length < pinLimit || isItemPinned) {\n                          event.preventDefault()\n                          event.stopPropagation() // This is to avoid click spread to the parent and change the routing\n\n                          let newValue: string[] | undefined\n                          if (isItemPinned) {\n                            newValue = unpinItem(id)\n                          } else {\n                            newValue = pinItem(id)\n                          }\n                          onClickPinUnpin?.({\n                            state: isItemPinned ? 'unpin' : 'pin',\n                            id,\n                            totalPinned: newValue,\n                          })\n                        }\n                      }}\n                      disabled={isItemPinned ? false : isPinDisabled}\n                    >\n                      <PinUnpinIcon\n                        size=\"medium\"\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={target}\n              rel={rel}\n            >\n              <AnimatedIcon sentiment=\"neutral\" prominence=\"weak\" />\n            </Container>\n          </MenuStack>\n        </Tooltip>\n      )\n    }\n\n    return null\n  },\n)\n"]} */"));
122
+ }) => 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":"AA6GE","file":"/home/runner/work/ultraviolet/ultraviolet/packages/plus/src/components/Navigation/components/Item.tsx","sourcesContent":["'use client'\n\nimport { css } from '@emotion/react'\nimport styled from '@emotion/styled'\nimport {\n  ArrowDownIcon,\n  ArrowRightIcon,\n  DragIcon,\n  OpenInNewIcon,\n  PinOutlineIcon,\n  UnpinIcon,\n} from '@ultraviolet/icons'\nimport * as CategoryIcon from '@ultraviolet/icons/category'\nimport { ConsoleCategoryIcon } from '@ultraviolet/icons/category'\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  isValidElement,\n  memo,\n  useCallback,\n  useContext,\n  useEffect,\n  useMemo,\n  useReducer,\n} from 'react'\nimport type { PascalToCamelCaseWithoutSuffix } from '../../../types'\nimport { useNavigation } from '../NavigationProvider'\nimport { ANIMATION_DURATION, shrinkHeight } from '../constants'\nimport type { PinUnPinType } from '../types'\nimport { ItemContext, ItemProvider } from './ItemProvider'\n\nconst RelativeDiv = styled.div`\n  position: relative;\n`\n\nconst StyledPinIconOutline = styled(PinOutlineIcon, {\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 }) =>\n      active ? `background: ${theme.colors.primary.backgroundHover};` : null}\n  }\n`\n\nconst StyledUnpinIcon = StyledPinIconOutline.withComponent(UnpinIcon)\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(DragIcon)`\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  &: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(OpenInNewIcon)``\n\nconst WrapText = styled(Text)`\n  overflow-wrap: anywhere;\n  overflow: hidden;\n  display: -webkit-box;\n  -webkit-box-orient: vertical;\n  -webkit-line-clamp: 2;\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 }) => 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\"][data-animation-type=\"complex\"] {\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\"][data-animation-type=\"complex\"] {\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 StackIcon = styled(Stack)`\n  padding-top: ${({ theme }) => theme.space['0.5']};\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?: PascalToCamelCaseWithoutSuffix<\n    keyof typeof CategoryIcon,\n    'CategoryIcon'\n  >\n  categoryIconVariant?: ComponentProps<\n    (typeof CategoryIcon)['BaremetalCategoryIcon']\n  >['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?: HTMLAnchorElement['href']\n  target?: HTMLAnchorElement['target']\n  rel?: HTMLAnchorElement['rel']\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  onToggle?: (toggle: boolean) => void\n  onClickPinUnpin?: (parameters: PinUnPinType) => 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 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  'data-testid'?: string\n}\n\nconst onDragStopTrigger = (event: DragEvent<HTMLDivElement>) => {\n  // eslint-disable-next-line no-param-reassign\n  event.currentTarget.style.opacity = '1'\n}\n\nexport const Item = memo(\n  ({\n    children,\n    categoryIcon,\n    categoryIconVariant,\n    label,\n    subLabel,\n    badgeText,\n    badgeSentiment,\n    href,\n    target,\n    rel,\n    onToggle,\n    onClickPinUnpin,\n    toggle,\n    active,\n    noPinButton,\n    type = 'default',\n    as,\n    disabled,\n    noExpand = false,\n    index,\n    id,\n    'data-testid': dataTestId,\n  }: ItemProps) => {\n    const context = useNavigation()\n    if (!context) {\n      throw new Error(\n        'Navigation.Item can only be used inside a NavigationProvider.',\n      )\n    }\n\n    const itemProvider = useContext(ItemContext)\n    const hasParents = !!itemProvider\n\n    const {\n      expanded,\n      locales,\n      pinnedFeature,\n      pinItem,\n      unpinItem,\n      pinnedItems,\n      pinLimit,\n      animation,\n      registerItem,\n      shouldAnimate,\n      animationType,\n    } = context\n\n    useEffect(\n      () => {\n        if (type !== 'pinnedGroup' && pinnedFeature) {\n          registerItem({ [id]: { label, active, onToggle, onClickPinUnpin } })\n        }\n      },\n      // eslint-disable-next-line react-hooks/exhaustive-deps\n      [active, id, label, registerItem],\n    )\n\n    const [internalExpanded, onToggleExpand] = useReducer(\n      prevState => !prevState,\n      Boolean(toggle),\n    )\n\n    const triggerToggle = useCallback(() => {\n      onToggleExpand()\n      onToggle?.(internalExpanded)\n    }, [internalExpanded, onToggle])\n\n    const PaddedStack =\n      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 = useMemo(\n      () => StyledContainer.withComponent(containerTag),\n      [containerTag],\n    )\n\n    const CategoryIconUsed = categoryIcon\n      ? CategoryIcon[\n          `${\n            categoryIcon.charAt(0).toUpperCase() + categoryIcon.slice(1)\n          }CategoryIcon` as keyof typeof CategoryIcon\n        ]\n      : null\n\n    const ArrowIcon = useMemo(\n      () => (internalExpanded ? ArrowDownIcon : ArrowRightIcon),\n      [internalExpanded],\n    )\n\n    const PinUnpinIcon = useMemo(\n      () => (isItemPinned ? StyledUnpinIcon : StyledPinIconOutline),\n      [isItemPinned],\n    )\n\n    const ariaExpanded = useMemo(() => {\n      if (hasHrefAndNoChildren && internalExpanded) {\n        return true\n      }\n\n      if (hasHrefAndNoChildren && !internalExpanded) {\n        return false\n      }\n\n      return undefined\n    }, [hasHrefAndNoChildren, internalExpanded])\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 onDragStart = useCallback(\n      (event: DragEvent<HTMLDivElement>) => {\n        if (expanded) {\n          event.dataTransfer.setData(\n            'text/plain',\n            JSON.stringify({ label, index }),\n          )\n          // eslint-disable-next-line no-param-reassign\n          event.currentTarget.style.opacity = '0.5'\n        }\n\n        return undefined\n      },\n      [expanded, index, label],\n    )\n\n    const onDragEnd = useCallback(\n      (event: DragEvent<HTMLDivElement>) =>\n        expanded ? onDragStopTrigger(event) : undefined,\n      [expanded],\n    )\n\n    // This content is when the navigation is expanded\n    if (expanded || (!expanded && animation === 'expand')) {\n      return (\n        <>\n          <Container\n            gap={1}\n            direction=\"row\"\n            alignItems={categoryIcon ? 'flex-start' : 'center'}\n            justifyContent=\"space-between\"\n            data-has-sub-label={!!subLabel}\n            onClick={triggerToggle}\n            aria-expanded={ariaExpanded}\n            href={href}\n            target={target}\n            rel={rel}\n            data-is-pinnable={shouldShowPinnedButton}\n            data-is-active={active}\n            data-animation={shouldAnimate ? animation : undefined}\n            data-animation-type={animationType}\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={onDragStart}\n            onDragEnd={onDragEnd}\n            id={id}\n            data-testid={dataTestId}\n          >\n            <Stack\n              direction=\"row\"\n              gap={1}\n              alignItems={categoryIcon ? 'flex-start' : 'center'}\n              justifyContent=\"center\"\n            >\n              {CategoryIconUsed ? (\n                <ContainerCategoryIcon\n                  alignItems=\"center\"\n                  justifyContent=\"center\"\n                >\n                  <CategoryIconUsed\n                    variant={active ? 'primary' : categoryIconVariant}\n                    disabled={disabled}\n                  />\n                </ContainerCategoryIcon>\n              ) : null}\n              {type === 'pinned' && expanded ? (\n                <GrabIcon\n                  sentiment=\"neutral\"\n                  prominence=\"weak\"\n                  size=\"small\"\n                  disabled={disabled}\n                />\n              ) : null}\n              <Stack>\n                {!animation ? (\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                    data-animation={animation}\n                    disabled={disabled}\n                    whiteSpace=\"pre-wrap\"\n                  >\n                    {label}\n                  </WrapText>\n                ) : null}\n                {subLabel && !animation ? (\n                  <WrapText\n                    as=\"span\"\n                    variant=\"caption\"\n                    sentiment=\"neutral\"\n                    prominence=\"weak\"\n                    data-animation={animation}\n                    disabled={disabled}\n                    whiteSpace=\"pre-wrap\"\n                  >\n                    {subLabel}\n                  </WrapText>\n                ) : null}\n              </Stack>\n            </Stack>\n            <Stack\n              direction=\"row\"\n              alignItems=\"center\"\n              gap={href ? 1 : undefined}\n            >\n              {badgeText || hasPinnedFeatureAndNoChildren ? (\n                <>\n                  {badgeText && !animation ? (\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                          aria-label={isItemPinned ? 'unpin' : 'pin'}\n                          size=\"xsmall\"\n                          variant=\"ghost\"\n                          sentiment={active ? 'primary' : 'neutral'}\n                          onClick={(event: MouseEvent<HTMLDivElement>) => {\n                            if (pinnedItems.length < pinLimit || isItemPinned) {\n                              event.preventDefault()\n                              event.stopPropagation() // This is to avoid click spread to the parent and change the routing\n                              let newValue: string[] | undefined\n                              if (isItemPinned) {\n                                newValue = unpinItem(id)\n                              } else {\n                                newValue = pinItem(id)\n                              }\n\n                              onClickPinUnpin?.({\n                                state: isItemPinned ? 'unpin' : 'pin',\n                                id,\n                                totalPinned: newValue,\n                              })\n                            }\n                          }}\n                          disabled={isItemPinned ? false : isPinDisabled}\n                        >\n                          <PinUnpinIcon\n                            size=\"medium\"\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 && target === '_blank' && !animation ? (\n                <AnimatedIcon\n                  sentiment=\"neutral\"\n                  prominence=\"default\"\n                  disabled={disabled}\n                />\n              ) : null}\n              {children ? (\n                <StackIcon gap={1} direction=\"row\" alignItems=\"center\">\n                  {!animation && !noExpand ? (\n                    <ArrowIcon sentiment=\"neutral\" prominence=\"weak\" />\n                  ) : null}\n                </StackIcon>\n              ) : null}\n            </Stack>\n          </Container>\n          {children ? (\n            <>\n              {!noExpand ? (\n                <ItemProvider>\n                  <Expandable opened={internalExpanded} animationDuration={0}>\n                    <PaddedStack width={animation ? '100%' : undefined}>\n                      {children}\n                    </PaddedStack>\n                  </Expandable>\n                </ItemProvider>\n              ) : (\n                <ItemProvider>\n                  <PaddedStack width={animation ? '100%' : undefined}>\n                    {children}\n                  </PaddedStack>\n                </ItemProvider>\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                  aria-label={label}\n                >\n                  {CategoryIconUsed ? (\n                    <Stack\n                      direction=\"row\"\n                      gap={1}\n                      alignItems=\"center\"\n                      justifyContent=\"center\"\n                    >\n                      <CategoryIconUsed\n                        variant={active ? 'primary' : categoryIconVariant}\n                      />\n                    </Stack>\n                  ) : null}\n                </Button>\n              }\n              placement=\"right\"\n            >\n              <ItemProvider>{children}</ItemProvider>\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                aria-label={label}\n              >\n                <Stack\n                  direction=\"row\"\n                  gap={1}\n                  alignItems=\"center\"\n                  justifyContent=\"center\"\n                >\n                  {CategoryIconUsed ? (\n                    <CategoryIconUsed\n                      variant={active ? 'primary' : categoryIconVariant}\n                    />\n                  ) : (\n                    <ConsoleCategoryIcon\n                      variant={active ? 'primary' : categoryIconVariant}\n                    />\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          target={target}\n          rel={rel}\n          borderless\n          active={active}\n          disabled={disabled}\n          sentiment={active ? 'primary' : 'neutral'}\n          isPinnable={shouldShowPinnedButton}\n          onClick={() => onToggle?.(!!active)}\n        >\n          <Stack\n            gap={1}\n            direction=\"row\"\n            alignItems=\"center\"\n            justifyContent=\"space-between\"\n            flex={1}\n            width=\"100%\"\n          >\n            {!animation ? (\n              <WrapText as=\"span\" variant=\"bodySmall\" whiteSpace=\"pre-wrap\">\n                {label}\n              </WrapText>\n            ) : null}\n            <Stack direction=\"row\">\n              {badgeText && !animation ? (\n                <StyledBadge\n                  sentiment={badgeSentiment}\n                  size=\"small\"\n                  prominence=\"strong\"\n                  disabled={disabled}\n                >\n                  {badgeText}\n                </StyledBadge>\n              ) : null}\n              {hasHrefAndNoChildren && target === '_blank' ? (\n                <AnimatedIcon\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                      aria-label={isItemPinned ? 'unpin' : 'pin'}\n                      variant=\"ghost\"\n                      sentiment={active ? 'primary' : 'neutral'}\n                      onClick={(event: MouseEvent<HTMLDivElement>) => {\n                        if (pinnedItems.length < pinLimit || isItemPinned) {\n                          event.preventDefault()\n                          event.stopPropagation() // This is to avoid click spread to the parent and change the routing\n\n                          let newValue: string[] | undefined\n                          if (isItemPinned) {\n                            newValue = unpinItem(id)\n                          } else {\n                            newValue = pinItem(id)\n                          }\n                          onClickPinUnpin?.({\n                            state: isItemPinned ? 'unpin' : 'pin',\n                            id,\n                            totalPinned: newValue,\n                          })\n                        }\n                      }}\n                      disabled={isItemPinned ? false : isPinDisabled}\n                    >\n                      <PinUnpinIcon\n                        size=\"medium\"\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={target}\n              rel={rel}\n            >\n              <AnimatedIcon sentiment=\"neutral\" prominence=\"weak\" />\n            </Container>\n          </MenuStack>\n        </Tooltip>\n      )\n    }\n\n    return null\n  },\n)\n"]} */"));
123
123
  const StyledMenu = /* @__PURE__ */ _styled__default.default(ui.MenuV2, process.env.NODE_ENV === "production" ? {
124
124
  target: "e134hokc8"
125
125
  } : {
@@ -130,7 +130,7 @@ const StyledMenu = /* @__PURE__ */ _styled__default.default(ui.MenuV2, process.e
130
130
  styles: "width:180px"
131
131
  } : {
132
132
  name: "educr3",
133
- styles: "width:180px/*# 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":"AA4HiC","file":"/home/runner/work/ultraviolet/ultraviolet/packages/plus/src/components/Navigation/components/Item.tsx","sourcesContent":["'use client'\n\nimport { css } from '@emotion/react'\nimport styled from '@emotion/styled'\nimport {\n  ArrowDownIcon,\n  ArrowRightIcon,\n  DragIcon,\n  OpenInNewIcon,\n  PinOutlineIcon,\n  UnpinIcon,\n} from '@ultraviolet/icons'\nimport * as CategoryIcon from '@ultraviolet/icons/category'\nimport { ConsoleCategoryIcon } from '@ultraviolet/icons/category'\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  isValidElement,\n  memo,\n  useCallback,\n  useContext,\n  useEffect,\n  useMemo,\n  useReducer,\n} from 'react'\nimport type { PascalToCamelCaseWithoutSuffix } from '../../../types'\nimport { useNavigation } from '../NavigationProvider'\nimport { ANIMATION_DURATION, shrinkHeight } from '../constants'\nimport type { PinUnPinType } from '../types'\nimport { ItemContext, ItemProvider } from './ItemProvider'\n\nconst RelativeDiv = styled.div`\n  position: relative;\n`\n\nconst StyledPinIconOutline = styled(PinOutlineIcon, {\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 }) =>\n      active ? `background: ${theme.colors.primary.backgroundHover};` : null}\n  }\n`\n\nconst StyledUnpinIcon = StyledPinIconOutline.withComponent(UnpinIcon)\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(DragIcon)`\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  &: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(OpenInNewIcon)``\n\nconst WrapText = styled(Text)`\n  overflow-wrap: anywhere;\n  overflow: hidden;\n  display: -webkit-box;\n  -webkit-box-orient: vertical;\n  -webkit-line-clamp: 2;\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 }) => 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\"][data-animation-type=\"complex\"] {\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\"][data-animation-type=\"complex\"] {\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 StackIcon = styled(Stack)`\n  padding-top: ${({ theme }) => theme.space['0.5']};\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?: PascalToCamelCaseWithoutSuffix<\n    keyof typeof CategoryIcon,\n    'CategoryIcon'\n  >\n  categoryIconVariant?: ComponentProps<\n    (typeof CategoryIcon)['BaremetalCategoryIcon']\n  >['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?: HTMLAnchorElement['href']\n  target?: HTMLAnchorElement['target']\n  rel?: HTMLAnchorElement['rel']\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  onToggle?: (toggle: boolean) => void\n  onClickPinUnpin?: (parameters: PinUnPinType) => 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 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  'data-testid'?: string\n}\n\nconst onDragStopTrigger = (event: DragEvent<HTMLDivElement>) => {\n  // eslint-disable-next-line no-param-reassign\n  event.currentTarget.style.opacity = '1'\n}\n\nexport const Item = memo(\n  ({\n    children,\n    categoryIcon,\n    categoryIconVariant,\n    label,\n    subLabel,\n    badgeText,\n    badgeSentiment,\n    href,\n    target,\n    rel,\n    onToggle,\n    onClickPinUnpin,\n    toggle,\n    active,\n    noPinButton,\n    type = 'default',\n    as,\n    disabled,\n    noExpand = false,\n    index,\n    id,\n    'data-testid': dataTestId,\n  }: ItemProps) => {\n    const context = useNavigation()\n    if (!context) {\n      throw new Error(\n        'Navigation.Item can only be used inside a NavigationProvider.',\n      )\n    }\n\n    const itemProvider = useContext(ItemContext)\n    const hasParents = !!itemProvider\n\n    const {\n      expanded,\n      locales,\n      pinnedFeature,\n      pinItem,\n      unpinItem,\n      pinnedItems,\n      pinLimit,\n      animation,\n      registerItem,\n      shouldAnimate,\n      animationType,\n    } = context\n\n    useEffect(\n      () => {\n        if (type !== 'pinnedGroup') {\n          registerItem({ [id]: { label, active, onToggle, onClickPinUnpin } })\n        }\n      },\n      // eslint-disable-next-line react-hooks/exhaustive-deps\n      [active, id, label, registerItem],\n    )\n\n    const [internalExpanded, onToggleExpand] = useReducer(\n      prevState => !prevState,\n      Boolean(toggle),\n    )\n\n    const triggerToggle = useCallback(() => {\n      onToggleExpand()\n      onToggle?.(internalExpanded)\n    }, [internalExpanded, onToggle])\n\n    const PaddedStack =\n      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 = useMemo(\n      () => StyledContainer.withComponent(containerTag),\n      [containerTag],\n    )\n\n    const CategoryIconUsed = categoryIcon\n      ? CategoryIcon[\n          `${\n            categoryIcon.charAt(0).toUpperCase() + categoryIcon.slice(1)\n          }CategoryIcon` as keyof typeof CategoryIcon\n        ]\n      : null\n\n    const ArrowIcon = useMemo(\n      () => (internalExpanded ? ArrowDownIcon : ArrowRightIcon),\n      [internalExpanded],\n    )\n\n    const PinUnpinIcon = useMemo(\n      () => (isItemPinned ? StyledUnpinIcon : StyledPinIconOutline),\n      [isItemPinned],\n    )\n\n    const ariaExpanded = useMemo(() => {\n      if (hasHrefAndNoChildren && internalExpanded) {\n        return true\n      }\n\n      if (hasHrefAndNoChildren && !internalExpanded) {\n        return false\n      }\n\n      return undefined\n    }, [hasHrefAndNoChildren, internalExpanded])\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 onDragStart = useCallback(\n      (event: DragEvent<HTMLDivElement>) => {\n        if (expanded) {\n          event.dataTransfer.setData(\n            'text/plain',\n            JSON.stringify({ label, index }),\n          )\n          // eslint-disable-next-line no-param-reassign\n          event.currentTarget.style.opacity = '0.5'\n        }\n\n        return undefined\n      },\n      [expanded, index, label],\n    )\n\n    const onDragEnd = useCallback(\n      (event: DragEvent<HTMLDivElement>) =>\n        expanded ? onDragStopTrigger(event) : undefined,\n      [expanded],\n    )\n\n    // This content is when the navigation is expanded\n    if (expanded || (!expanded && animation === 'expand')) {\n      return (\n        <>\n          <Container\n            gap={1}\n            direction=\"row\"\n            alignItems={categoryIcon ? 'flex-start' : 'center'}\n            justifyContent=\"space-between\"\n            data-has-sub-label={!!subLabel}\n            onClick={triggerToggle}\n            aria-expanded={ariaExpanded}\n            href={href}\n            target={target}\n            rel={rel}\n            data-is-pinnable={shouldShowPinnedButton}\n            data-is-active={active}\n            data-animation={shouldAnimate ? animation : undefined}\n            data-animation-type={animationType}\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={onDragStart}\n            onDragEnd={onDragEnd}\n            id={id}\n            data-testid={dataTestId}\n          >\n            <Stack\n              direction=\"row\"\n              gap={1}\n              alignItems={categoryIcon ? 'flex-start' : 'center'}\n              justifyContent=\"center\"\n            >\n              {CategoryIconUsed ? (\n                <ContainerCategoryIcon\n                  alignItems=\"center\"\n                  justifyContent=\"center\"\n                >\n                  <CategoryIconUsed\n                    variant={active ? 'primary' : categoryIconVariant}\n                    disabled={disabled}\n                  />\n                </ContainerCategoryIcon>\n              ) : null}\n              {type === 'pinned' && expanded ? (\n                <GrabIcon\n                  sentiment=\"neutral\"\n                  prominence=\"weak\"\n                  size=\"small\"\n                  disabled={disabled}\n                />\n              ) : null}\n              <Stack>\n                {!animation ? (\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                    data-animation={animation}\n                    disabled={disabled}\n                    whiteSpace=\"pre-wrap\"\n                  >\n                    {label}\n                  </WrapText>\n                ) : null}\n                {subLabel && !animation ? (\n                  <WrapText\n                    as=\"span\"\n                    variant=\"caption\"\n                    sentiment=\"neutral\"\n                    prominence=\"weak\"\n                    data-animation={animation}\n                    disabled={disabled}\n                    whiteSpace=\"pre-wrap\"\n                  >\n                    {subLabel}\n                  </WrapText>\n                ) : null}\n              </Stack>\n            </Stack>\n            <Stack\n              direction=\"row\"\n              alignItems=\"center\"\n              gap={href ? 1 : undefined}\n            >\n              {badgeText || hasPinnedFeatureAndNoChildren ? (\n                <>\n                  {badgeText && !animation ? (\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                          aria-label={isItemPinned ? 'unpin' : 'pin'}\n                          size=\"xsmall\"\n                          variant=\"ghost\"\n                          sentiment={active ? 'primary' : 'neutral'}\n                          onClick={(event: MouseEvent<HTMLDivElement>) => {\n                            if (pinnedItems.length < pinLimit || isItemPinned) {\n                              event.preventDefault()\n                              event.stopPropagation() // This is to avoid click spread to the parent and change the routing\n                              let newValue: string[] | undefined\n                              if (isItemPinned) {\n                                newValue = unpinItem(id)\n                              } else {\n                                newValue = pinItem(id)\n                              }\n\n                              onClickPinUnpin?.({\n                                state: isItemPinned ? 'unpin' : 'pin',\n                                id,\n                                totalPinned: newValue,\n                              })\n                            }\n                          }}\n                          disabled={isItemPinned ? false : isPinDisabled}\n                        >\n                          <PinUnpinIcon\n                            size=\"medium\"\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 && target === '_blank' && !animation ? (\n                <AnimatedIcon\n                  sentiment=\"neutral\"\n                  prominence=\"default\"\n                  disabled={disabled}\n                />\n              ) : null}\n              {children ? (\n                <StackIcon gap={1} direction=\"row\" alignItems=\"center\">\n                  {!animation && !noExpand ? (\n                    <ArrowIcon sentiment=\"neutral\" prominence=\"weak\" />\n                  ) : null}\n                </StackIcon>\n              ) : null}\n            </Stack>\n          </Container>\n          {children ? (\n            <>\n              {!noExpand ? (\n                <ItemProvider>\n                  <Expandable opened={internalExpanded} animationDuration={0}>\n                    <PaddedStack width={animation ? '100%' : undefined}>\n                      {children}\n                    </PaddedStack>\n                  </Expandable>\n                </ItemProvider>\n              ) : (\n                <ItemProvider>\n                  <PaddedStack width={animation ? '100%' : undefined}>\n                    {children}\n                  </PaddedStack>\n                </ItemProvider>\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                  aria-label={label}\n                >\n                  {CategoryIconUsed ? (\n                    <Stack\n                      direction=\"row\"\n                      gap={1}\n                      alignItems=\"center\"\n                      justifyContent=\"center\"\n                    >\n                      <CategoryIconUsed\n                        variant={active ? 'primary' : categoryIconVariant}\n                      />\n                    </Stack>\n                  ) : null}\n                </Button>\n              }\n              placement=\"right\"\n            >\n              <ItemProvider>{children}</ItemProvider>\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                aria-label={label}\n              >\n                <Stack\n                  direction=\"row\"\n                  gap={1}\n                  alignItems=\"center\"\n                  justifyContent=\"center\"\n                >\n                  {CategoryIconUsed ? (\n                    <CategoryIconUsed\n                      variant={active ? 'primary' : categoryIconVariant}\n                    />\n                  ) : (\n                    <ConsoleCategoryIcon\n                      variant={active ? 'primary' : categoryIconVariant}\n                    />\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          target={target}\n          rel={rel}\n          borderless\n          active={active}\n          disabled={disabled}\n          sentiment={active ? 'primary' : 'neutral'}\n          isPinnable={shouldShowPinnedButton}\n          onClick={() => onToggle?.(!!active)}\n        >\n          <Stack\n            gap={1}\n            direction=\"row\"\n            alignItems=\"center\"\n            justifyContent=\"space-between\"\n            flex={1}\n            width=\"100%\"\n          >\n            {!animation ? (\n              <WrapText as=\"span\" variant=\"bodySmall\" whiteSpace=\"pre-wrap\">\n                {label}\n              </WrapText>\n            ) : null}\n            <Stack direction=\"row\">\n              {badgeText && !animation ? (\n                <StyledBadge\n                  sentiment={badgeSentiment}\n                  size=\"small\"\n                  prominence=\"strong\"\n                  disabled={disabled}\n                >\n                  {badgeText}\n                </StyledBadge>\n              ) : null}\n              {hasHrefAndNoChildren && target === '_blank' ? (\n                <AnimatedIcon\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                      aria-label={isItemPinned ? 'unpin' : 'pin'}\n                      variant=\"ghost\"\n                      sentiment={active ? 'primary' : 'neutral'}\n                      onClick={(event: MouseEvent<HTMLDivElement>) => {\n                        if (pinnedItems.length < pinLimit || isItemPinned) {\n                          event.preventDefault()\n                          event.stopPropagation() // This is to avoid click spread to the parent and change the routing\n\n                          let newValue: string[] | undefined\n                          if (isItemPinned) {\n                            newValue = unpinItem(id)\n                          } else {\n                            newValue = pinItem(id)\n                          }\n                          onClickPinUnpin?.({\n                            state: isItemPinned ? 'unpin' : 'pin',\n                            id,\n                            totalPinned: newValue,\n                          })\n                        }\n                      }}\n                      disabled={isItemPinned ? false : isPinDisabled}\n                    >\n                      <PinUnpinIcon\n                        size=\"medium\"\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={target}\n              rel={rel}\n            >\n              <AnimatedIcon sentiment=\"neutral\" prominence=\"weak\" />\n            </Container>\n          </MenuStack>\n        </Tooltip>\n      )\n    }\n\n    return null\n  },\n)\n"]} */",
133
+ styles: "width:180px/*# 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":"AA4HiC","file":"/home/runner/work/ultraviolet/ultraviolet/packages/plus/src/components/Navigation/components/Item.tsx","sourcesContent":["'use client'\n\nimport { css } from '@emotion/react'\nimport styled from '@emotion/styled'\nimport {\n  ArrowDownIcon,\n  ArrowRightIcon,\n  DragIcon,\n  OpenInNewIcon,\n  PinOutlineIcon,\n  UnpinIcon,\n} from '@ultraviolet/icons'\nimport * as CategoryIcon from '@ultraviolet/icons/category'\nimport { ConsoleCategoryIcon } from '@ultraviolet/icons/category'\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  isValidElement,\n  memo,\n  useCallback,\n  useContext,\n  useEffect,\n  useMemo,\n  useReducer,\n} from 'react'\nimport type { PascalToCamelCaseWithoutSuffix } from '../../../types'\nimport { useNavigation } from '../NavigationProvider'\nimport { ANIMATION_DURATION, shrinkHeight } from '../constants'\nimport type { PinUnPinType } from '../types'\nimport { ItemContext, ItemProvider } from './ItemProvider'\n\nconst RelativeDiv = styled.div`\n  position: relative;\n`\n\nconst StyledPinIconOutline = styled(PinOutlineIcon, {\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 }) =>\n      active ? `background: ${theme.colors.primary.backgroundHover};` : null}\n  }\n`\n\nconst StyledUnpinIcon = StyledPinIconOutline.withComponent(UnpinIcon)\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(DragIcon)`\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  &: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(OpenInNewIcon)``\n\nconst WrapText = styled(Text)`\n  overflow-wrap: anywhere;\n  overflow: hidden;\n  display: -webkit-box;\n  -webkit-box-orient: vertical;\n  -webkit-line-clamp: 2;\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 }) => 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\"][data-animation-type=\"complex\"] {\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\"][data-animation-type=\"complex\"] {\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 StackIcon = styled(Stack)`\n  padding-top: ${({ theme }) => theme.space['0.5']};\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?: PascalToCamelCaseWithoutSuffix<\n    keyof typeof CategoryIcon,\n    'CategoryIcon'\n  >\n  categoryIconVariant?: ComponentProps<\n    (typeof CategoryIcon)['BaremetalCategoryIcon']\n  >['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?: HTMLAnchorElement['href']\n  target?: HTMLAnchorElement['target']\n  rel?: HTMLAnchorElement['rel']\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  onToggle?: (toggle: boolean) => void\n  onClickPinUnpin?: (parameters: PinUnPinType) => 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 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  'data-testid'?: string\n}\n\nconst onDragStopTrigger = (event: DragEvent<HTMLDivElement>) => {\n  // eslint-disable-next-line no-param-reassign\n  event.currentTarget.style.opacity = '1'\n}\n\nexport const Item = memo(\n  ({\n    children,\n    categoryIcon,\n    categoryIconVariant,\n    label,\n    subLabel,\n    badgeText,\n    badgeSentiment,\n    href,\n    target,\n    rel,\n    onToggle,\n    onClickPinUnpin,\n    toggle,\n    active,\n    noPinButton,\n    type = 'default',\n    as,\n    disabled,\n    noExpand = false,\n    index,\n    id,\n    'data-testid': dataTestId,\n  }: ItemProps) => {\n    const context = useNavigation()\n    if (!context) {\n      throw new Error(\n        'Navigation.Item can only be used inside a NavigationProvider.',\n      )\n    }\n\n    const itemProvider = useContext(ItemContext)\n    const hasParents = !!itemProvider\n\n    const {\n      expanded,\n      locales,\n      pinnedFeature,\n      pinItem,\n      unpinItem,\n      pinnedItems,\n      pinLimit,\n      animation,\n      registerItem,\n      shouldAnimate,\n      animationType,\n    } = context\n\n    useEffect(\n      () => {\n        if (type !== 'pinnedGroup' && pinnedFeature) {\n          registerItem({ [id]: { label, active, onToggle, onClickPinUnpin } })\n        }\n      },\n      // eslint-disable-next-line react-hooks/exhaustive-deps\n      [active, id, label, registerItem],\n    )\n\n    const [internalExpanded, onToggleExpand] = useReducer(\n      prevState => !prevState,\n      Boolean(toggle),\n    )\n\n    const triggerToggle = useCallback(() => {\n      onToggleExpand()\n      onToggle?.(internalExpanded)\n    }, [internalExpanded, onToggle])\n\n    const PaddedStack =\n      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 = useMemo(\n      () => StyledContainer.withComponent(containerTag),\n      [containerTag],\n    )\n\n    const CategoryIconUsed = categoryIcon\n      ? CategoryIcon[\n          `${\n            categoryIcon.charAt(0).toUpperCase() + categoryIcon.slice(1)\n          }CategoryIcon` as keyof typeof CategoryIcon\n        ]\n      : null\n\n    const ArrowIcon = useMemo(\n      () => (internalExpanded ? ArrowDownIcon : ArrowRightIcon),\n      [internalExpanded],\n    )\n\n    const PinUnpinIcon = useMemo(\n      () => (isItemPinned ? StyledUnpinIcon : StyledPinIconOutline),\n      [isItemPinned],\n    )\n\n    const ariaExpanded = useMemo(() => {\n      if (hasHrefAndNoChildren && internalExpanded) {\n        return true\n      }\n\n      if (hasHrefAndNoChildren && !internalExpanded) {\n        return false\n      }\n\n      return undefined\n    }, [hasHrefAndNoChildren, internalExpanded])\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 onDragStart = useCallback(\n      (event: DragEvent<HTMLDivElement>) => {\n        if (expanded) {\n          event.dataTransfer.setData(\n            'text/plain',\n            JSON.stringify({ label, index }),\n          )\n          // eslint-disable-next-line no-param-reassign\n          event.currentTarget.style.opacity = '0.5'\n        }\n\n        return undefined\n      },\n      [expanded, index, label],\n    )\n\n    const onDragEnd = useCallback(\n      (event: DragEvent<HTMLDivElement>) =>\n        expanded ? onDragStopTrigger(event) : undefined,\n      [expanded],\n    )\n\n    // This content is when the navigation is expanded\n    if (expanded || (!expanded && animation === 'expand')) {\n      return (\n        <>\n          <Container\n            gap={1}\n            direction=\"row\"\n            alignItems={categoryIcon ? 'flex-start' : 'center'}\n            justifyContent=\"space-between\"\n            data-has-sub-label={!!subLabel}\n            onClick={triggerToggle}\n            aria-expanded={ariaExpanded}\n            href={href}\n            target={target}\n            rel={rel}\n            data-is-pinnable={shouldShowPinnedButton}\n            data-is-active={active}\n            data-animation={shouldAnimate ? animation : undefined}\n            data-animation-type={animationType}\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={onDragStart}\n            onDragEnd={onDragEnd}\n            id={id}\n            data-testid={dataTestId}\n          >\n            <Stack\n              direction=\"row\"\n              gap={1}\n              alignItems={categoryIcon ? 'flex-start' : 'center'}\n              justifyContent=\"center\"\n            >\n              {CategoryIconUsed ? (\n                <ContainerCategoryIcon\n                  alignItems=\"center\"\n                  justifyContent=\"center\"\n                >\n                  <CategoryIconUsed\n                    variant={active ? 'primary' : categoryIconVariant}\n                    disabled={disabled}\n                  />\n                </ContainerCategoryIcon>\n              ) : null}\n              {type === 'pinned' && expanded ? (\n                <GrabIcon\n                  sentiment=\"neutral\"\n                  prominence=\"weak\"\n                  size=\"small\"\n                  disabled={disabled}\n                />\n              ) : null}\n              <Stack>\n                {!animation ? (\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                    data-animation={animation}\n                    disabled={disabled}\n                    whiteSpace=\"pre-wrap\"\n                  >\n                    {label}\n                  </WrapText>\n                ) : null}\n                {subLabel && !animation ? (\n                  <WrapText\n                    as=\"span\"\n                    variant=\"caption\"\n                    sentiment=\"neutral\"\n                    prominence=\"weak\"\n                    data-animation={animation}\n                    disabled={disabled}\n                    whiteSpace=\"pre-wrap\"\n                  >\n                    {subLabel}\n                  </WrapText>\n                ) : null}\n              </Stack>\n            </Stack>\n            <Stack\n              direction=\"row\"\n              alignItems=\"center\"\n              gap={href ? 1 : undefined}\n            >\n              {badgeText || hasPinnedFeatureAndNoChildren ? (\n                <>\n                  {badgeText && !animation ? (\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                          aria-label={isItemPinned ? 'unpin' : 'pin'}\n                          size=\"xsmall\"\n                          variant=\"ghost\"\n                          sentiment={active ? 'primary' : 'neutral'}\n                          onClick={(event: MouseEvent<HTMLDivElement>) => {\n                            if (pinnedItems.length < pinLimit || isItemPinned) {\n                              event.preventDefault()\n                              event.stopPropagation() // This is to avoid click spread to the parent and change the routing\n                              let newValue: string[] | undefined\n                              if (isItemPinned) {\n                                newValue = unpinItem(id)\n                              } else {\n                                newValue = pinItem(id)\n                              }\n\n                              onClickPinUnpin?.({\n                                state: isItemPinned ? 'unpin' : 'pin',\n                                id,\n                                totalPinned: newValue,\n                              })\n                            }\n                          }}\n                          disabled={isItemPinned ? false : isPinDisabled}\n                        >\n                          <PinUnpinIcon\n                            size=\"medium\"\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 && target === '_blank' && !animation ? (\n                <AnimatedIcon\n                  sentiment=\"neutral\"\n                  prominence=\"default\"\n                  disabled={disabled}\n                />\n              ) : null}\n              {children ? (\n                <StackIcon gap={1} direction=\"row\" alignItems=\"center\">\n                  {!animation && !noExpand ? (\n                    <ArrowIcon sentiment=\"neutral\" prominence=\"weak\" />\n                  ) : null}\n                </StackIcon>\n              ) : null}\n            </Stack>\n          </Container>\n          {children ? (\n            <>\n              {!noExpand ? (\n                <ItemProvider>\n                  <Expandable opened={internalExpanded} animationDuration={0}>\n                    <PaddedStack width={animation ? '100%' : undefined}>\n                      {children}\n                    </PaddedStack>\n                  </Expandable>\n                </ItemProvider>\n              ) : (\n                <ItemProvider>\n                  <PaddedStack width={animation ? '100%' : undefined}>\n                    {children}\n                  </PaddedStack>\n                </ItemProvider>\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                  aria-label={label}\n                >\n                  {CategoryIconUsed ? (\n                    <Stack\n                      direction=\"row\"\n                      gap={1}\n                      alignItems=\"center\"\n                      justifyContent=\"center\"\n                    >\n                      <CategoryIconUsed\n                        variant={active ? 'primary' : categoryIconVariant}\n                      />\n                    </Stack>\n                  ) : null}\n                </Button>\n              }\n              placement=\"right\"\n            >\n              <ItemProvider>{children}</ItemProvider>\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                aria-label={label}\n              >\n                <Stack\n                  direction=\"row\"\n                  gap={1}\n                  alignItems=\"center\"\n                  justifyContent=\"center\"\n                >\n                  {CategoryIconUsed ? (\n                    <CategoryIconUsed\n                      variant={active ? 'primary' : categoryIconVariant}\n                    />\n                  ) : (\n                    <ConsoleCategoryIcon\n                      variant={active ? 'primary' : categoryIconVariant}\n                    />\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          target={target}\n          rel={rel}\n          borderless\n          active={active}\n          disabled={disabled}\n          sentiment={active ? 'primary' : 'neutral'}\n          isPinnable={shouldShowPinnedButton}\n          onClick={() => onToggle?.(!!active)}\n        >\n          <Stack\n            gap={1}\n            direction=\"row\"\n            alignItems=\"center\"\n            justifyContent=\"space-between\"\n            flex={1}\n            width=\"100%\"\n          >\n            {!animation ? (\n              <WrapText as=\"span\" variant=\"bodySmall\" whiteSpace=\"pre-wrap\">\n                {label}\n              </WrapText>\n            ) : null}\n            <Stack direction=\"row\">\n              {badgeText && !animation ? (\n                <StyledBadge\n                  sentiment={badgeSentiment}\n                  size=\"small\"\n                  prominence=\"strong\"\n                  disabled={disabled}\n                >\n                  {badgeText}\n                </StyledBadge>\n              ) : null}\n              {hasHrefAndNoChildren && target === '_blank' ? (\n                <AnimatedIcon\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                      aria-label={isItemPinned ? 'unpin' : 'pin'}\n                      variant=\"ghost\"\n                      sentiment={active ? 'primary' : 'neutral'}\n                      onClick={(event: MouseEvent<HTMLDivElement>) => {\n                        if (pinnedItems.length < pinLimit || isItemPinned) {\n                          event.preventDefault()\n                          event.stopPropagation() // This is to avoid click spread to the parent and change the routing\n\n                          let newValue: string[] | undefined\n                          if (isItemPinned) {\n                            newValue = unpinItem(id)\n                          } else {\n                            newValue = pinItem(id)\n                          }\n                          onClickPinUnpin?.({\n                            state: isItemPinned ? 'unpin' : 'pin',\n                            id,\n                            totalPinned: newValue,\n                          })\n                        }\n                      }}\n                      disabled={isItemPinned ? false : isPinDisabled}\n                    >\n                      <PinUnpinIcon\n                        size=\"medium\"\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={target}\n              rel={rel}\n            >\n              <AnimatedIcon sentiment=\"neutral\" prominence=\"weak\" />\n            </Container>\n          </MenuStack>\n        </Tooltip>\n      )\n    }\n\n    return null\n  },\n)\n"]} */",
134
134
  toString: _EMOTION_STRINGIFIED_CSS_ERROR__
135
135
  });
136
136
  const PaddingStack = /* @__PURE__ */ _styled__default.default(ui.Stack, process.env.NODE_ENV === "production" ? {
@@ -143,7 +143,7 @@ const PaddingStack = /* @__PURE__ */ _styled__default.default(ui.Stack, process.
143
143
  styles: "padding-left:28px"
144
144
  } : {
145
145
  name: "13feash",
146
- styles: "padding-left:28px/*# 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":"AAgIkC","file":"/home/runner/work/ultraviolet/ultraviolet/packages/plus/src/components/Navigation/components/Item.tsx","sourcesContent":["'use client'\n\nimport { css } from '@emotion/react'\nimport styled from '@emotion/styled'\nimport {\n  ArrowDownIcon,\n  ArrowRightIcon,\n  DragIcon,\n  OpenInNewIcon,\n  PinOutlineIcon,\n  UnpinIcon,\n} from '@ultraviolet/icons'\nimport * as CategoryIcon from '@ultraviolet/icons/category'\nimport { ConsoleCategoryIcon } from '@ultraviolet/icons/category'\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  isValidElement,\n  memo,\n  useCallback,\n  useContext,\n  useEffect,\n  useMemo,\n  useReducer,\n} from 'react'\nimport type { PascalToCamelCaseWithoutSuffix } from '../../../types'\nimport { useNavigation } from '../NavigationProvider'\nimport { ANIMATION_DURATION, shrinkHeight } from '../constants'\nimport type { PinUnPinType } from '../types'\nimport { ItemContext, ItemProvider } from './ItemProvider'\n\nconst RelativeDiv = styled.div`\n  position: relative;\n`\n\nconst StyledPinIconOutline = styled(PinOutlineIcon, {\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 }) =>\n      active ? `background: ${theme.colors.primary.backgroundHover};` : null}\n  }\n`\n\nconst StyledUnpinIcon = StyledPinIconOutline.withComponent(UnpinIcon)\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(DragIcon)`\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  &: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(OpenInNewIcon)``\n\nconst WrapText = styled(Text)`\n  overflow-wrap: anywhere;\n  overflow: hidden;\n  display: -webkit-box;\n  -webkit-box-orient: vertical;\n  -webkit-line-clamp: 2;\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 }) => 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\"][data-animation-type=\"complex\"] {\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\"][data-animation-type=\"complex\"] {\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 StackIcon = styled(Stack)`\n  padding-top: ${({ theme }) => theme.space['0.5']};\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?: PascalToCamelCaseWithoutSuffix<\n    keyof typeof CategoryIcon,\n    'CategoryIcon'\n  >\n  categoryIconVariant?: ComponentProps<\n    (typeof CategoryIcon)['BaremetalCategoryIcon']\n  >['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?: HTMLAnchorElement['href']\n  target?: HTMLAnchorElement['target']\n  rel?: HTMLAnchorElement['rel']\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  onToggle?: (toggle: boolean) => void\n  onClickPinUnpin?: (parameters: PinUnPinType) => 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 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  'data-testid'?: string\n}\n\nconst onDragStopTrigger = (event: DragEvent<HTMLDivElement>) => {\n  // eslint-disable-next-line no-param-reassign\n  event.currentTarget.style.opacity = '1'\n}\n\nexport const Item = memo(\n  ({\n    children,\n    categoryIcon,\n    categoryIconVariant,\n    label,\n    subLabel,\n    badgeText,\n    badgeSentiment,\n    href,\n    target,\n    rel,\n    onToggle,\n    onClickPinUnpin,\n    toggle,\n    active,\n    noPinButton,\n    type = 'default',\n    as,\n    disabled,\n    noExpand = false,\n    index,\n    id,\n    'data-testid': dataTestId,\n  }: ItemProps) => {\n    const context = useNavigation()\n    if (!context) {\n      throw new Error(\n        'Navigation.Item can only be used inside a NavigationProvider.',\n      )\n    }\n\n    const itemProvider = useContext(ItemContext)\n    const hasParents = !!itemProvider\n\n    const {\n      expanded,\n      locales,\n      pinnedFeature,\n      pinItem,\n      unpinItem,\n      pinnedItems,\n      pinLimit,\n      animation,\n      registerItem,\n      shouldAnimate,\n      animationType,\n    } = context\n\n    useEffect(\n      () => {\n        if (type !== 'pinnedGroup') {\n          registerItem({ [id]: { label, active, onToggle, onClickPinUnpin } })\n        }\n      },\n      // eslint-disable-next-line react-hooks/exhaustive-deps\n      [active, id, label, registerItem],\n    )\n\n    const [internalExpanded, onToggleExpand] = useReducer(\n      prevState => !prevState,\n      Boolean(toggle),\n    )\n\n    const triggerToggle = useCallback(() => {\n      onToggleExpand()\n      onToggle?.(internalExpanded)\n    }, [internalExpanded, onToggle])\n\n    const PaddedStack =\n      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 = useMemo(\n      () => StyledContainer.withComponent(containerTag),\n      [containerTag],\n    )\n\n    const CategoryIconUsed = categoryIcon\n      ? CategoryIcon[\n          `${\n            categoryIcon.charAt(0).toUpperCase() + categoryIcon.slice(1)\n          }CategoryIcon` as keyof typeof CategoryIcon\n        ]\n      : null\n\n    const ArrowIcon = useMemo(\n      () => (internalExpanded ? ArrowDownIcon : ArrowRightIcon),\n      [internalExpanded],\n    )\n\n    const PinUnpinIcon = useMemo(\n      () => (isItemPinned ? StyledUnpinIcon : StyledPinIconOutline),\n      [isItemPinned],\n    )\n\n    const ariaExpanded = useMemo(() => {\n      if (hasHrefAndNoChildren && internalExpanded) {\n        return true\n      }\n\n      if (hasHrefAndNoChildren && !internalExpanded) {\n        return false\n      }\n\n      return undefined\n    }, [hasHrefAndNoChildren, internalExpanded])\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 onDragStart = useCallback(\n      (event: DragEvent<HTMLDivElement>) => {\n        if (expanded) {\n          event.dataTransfer.setData(\n            'text/plain',\n            JSON.stringify({ label, index }),\n          )\n          // eslint-disable-next-line no-param-reassign\n          event.currentTarget.style.opacity = '0.5'\n        }\n\n        return undefined\n      },\n      [expanded, index, label],\n    )\n\n    const onDragEnd = useCallback(\n      (event: DragEvent<HTMLDivElement>) =>\n        expanded ? onDragStopTrigger(event) : undefined,\n      [expanded],\n    )\n\n    // This content is when the navigation is expanded\n    if (expanded || (!expanded && animation === 'expand')) {\n      return (\n        <>\n          <Container\n            gap={1}\n            direction=\"row\"\n            alignItems={categoryIcon ? 'flex-start' : 'center'}\n            justifyContent=\"space-between\"\n            data-has-sub-label={!!subLabel}\n            onClick={triggerToggle}\n            aria-expanded={ariaExpanded}\n            href={href}\n            target={target}\n            rel={rel}\n            data-is-pinnable={shouldShowPinnedButton}\n            data-is-active={active}\n            data-animation={shouldAnimate ? animation : undefined}\n            data-animation-type={animationType}\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={onDragStart}\n            onDragEnd={onDragEnd}\n            id={id}\n            data-testid={dataTestId}\n          >\n            <Stack\n              direction=\"row\"\n              gap={1}\n              alignItems={categoryIcon ? 'flex-start' : 'center'}\n              justifyContent=\"center\"\n            >\n              {CategoryIconUsed ? (\n                <ContainerCategoryIcon\n                  alignItems=\"center\"\n                  justifyContent=\"center\"\n                >\n                  <CategoryIconUsed\n                    variant={active ? 'primary' : categoryIconVariant}\n                    disabled={disabled}\n                  />\n                </ContainerCategoryIcon>\n              ) : null}\n              {type === 'pinned' && expanded ? (\n                <GrabIcon\n                  sentiment=\"neutral\"\n                  prominence=\"weak\"\n                  size=\"small\"\n                  disabled={disabled}\n                />\n              ) : null}\n              <Stack>\n                {!animation ? (\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                    data-animation={animation}\n                    disabled={disabled}\n                    whiteSpace=\"pre-wrap\"\n                  >\n                    {label}\n                  </WrapText>\n                ) : null}\n                {subLabel && !animation ? (\n                  <WrapText\n                    as=\"span\"\n                    variant=\"caption\"\n                    sentiment=\"neutral\"\n                    prominence=\"weak\"\n                    data-animation={animation}\n                    disabled={disabled}\n                    whiteSpace=\"pre-wrap\"\n                  >\n                    {subLabel}\n                  </WrapText>\n                ) : null}\n              </Stack>\n            </Stack>\n            <Stack\n              direction=\"row\"\n              alignItems=\"center\"\n              gap={href ? 1 : undefined}\n            >\n              {badgeText || hasPinnedFeatureAndNoChildren ? (\n                <>\n                  {badgeText && !animation ? (\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                          aria-label={isItemPinned ? 'unpin' : 'pin'}\n                          size=\"xsmall\"\n                          variant=\"ghost\"\n                          sentiment={active ? 'primary' : 'neutral'}\n                          onClick={(event: MouseEvent<HTMLDivElement>) => {\n                            if (pinnedItems.length < pinLimit || isItemPinned) {\n                              event.preventDefault()\n                              event.stopPropagation() // This is to avoid click spread to the parent and change the routing\n                              let newValue: string[] | undefined\n                              if (isItemPinned) {\n                                newValue = unpinItem(id)\n                              } else {\n                                newValue = pinItem(id)\n                              }\n\n                              onClickPinUnpin?.({\n                                state: isItemPinned ? 'unpin' : 'pin',\n                                id,\n                                totalPinned: newValue,\n                              })\n                            }\n                          }}\n                          disabled={isItemPinned ? false : isPinDisabled}\n                        >\n                          <PinUnpinIcon\n                            size=\"medium\"\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 && target === '_blank' && !animation ? (\n                <AnimatedIcon\n                  sentiment=\"neutral\"\n                  prominence=\"default\"\n                  disabled={disabled}\n                />\n              ) : null}\n              {children ? (\n                <StackIcon gap={1} direction=\"row\" alignItems=\"center\">\n                  {!animation && !noExpand ? (\n                    <ArrowIcon sentiment=\"neutral\" prominence=\"weak\" />\n                  ) : null}\n                </StackIcon>\n              ) : null}\n            </Stack>\n          </Container>\n          {children ? (\n            <>\n              {!noExpand ? (\n                <ItemProvider>\n                  <Expandable opened={internalExpanded} animationDuration={0}>\n                    <PaddedStack width={animation ? '100%' : undefined}>\n                      {children}\n                    </PaddedStack>\n                  </Expandable>\n                </ItemProvider>\n              ) : (\n                <ItemProvider>\n                  <PaddedStack width={animation ? '100%' : undefined}>\n                    {children}\n                  </PaddedStack>\n                </ItemProvider>\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                  aria-label={label}\n                >\n                  {CategoryIconUsed ? (\n                    <Stack\n                      direction=\"row\"\n                      gap={1}\n                      alignItems=\"center\"\n                      justifyContent=\"center\"\n                    >\n                      <CategoryIconUsed\n                        variant={active ? 'primary' : categoryIconVariant}\n                      />\n                    </Stack>\n                  ) : null}\n                </Button>\n              }\n              placement=\"right\"\n            >\n              <ItemProvider>{children}</ItemProvider>\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                aria-label={label}\n              >\n                <Stack\n                  direction=\"row\"\n                  gap={1}\n                  alignItems=\"center\"\n                  justifyContent=\"center\"\n                >\n                  {CategoryIconUsed ? (\n                    <CategoryIconUsed\n                      variant={active ? 'primary' : categoryIconVariant}\n                    />\n                  ) : (\n                    <ConsoleCategoryIcon\n                      variant={active ? 'primary' : categoryIconVariant}\n                    />\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          target={target}\n          rel={rel}\n          borderless\n          active={active}\n          disabled={disabled}\n          sentiment={active ? 'primary' : 'neutral'}\n          isPinnable={shouldShowPinnedButton}\n          onClick={() => onToggle?.(!!active)}\n        >\n          <Stack\n            gap={1}\n            direction=\"row\"\n            alignItems=\"center\"\n            justifyContent=\"space-between\"\n            flex={1}\n            width=\"100%\"\n          >\n            {!animation ? (\n              <WrapText as=\"span\" variant=\"bodySmall\" whiteSpace=\"pre-wrap\">\n                {label}\n              </WrapText>\n            ) : null}\n            <Stack direction=\"row\">\n              {badgeText && !animation ? (\n                <StyledBadge\n                  sentiment={badgeSentiment}\n                  size=\"small\"\n                  prominence=\"strong\"\n                  disabled={disabled}\n                >\n                  {badgeText}\n                </StyledBadge>\n              ) : null}\n              {hasHrefAndNoChildren && target === '_blank' ? (\n                <AnimatedIcon\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                      aria-label={isItemPinned ? 'unpin' : 'pin'}\n                      variant=\"ghost\"\n                      sentiment={active ? 'primary' : 'neutral'}\n                      onClick={(event: MouseEvent<HTMLDivElement>) => {\n                        if (pinnedItems.length < pinLimit || isItemPinned) {\n                          event.preventDefault()\n                          event.stopPropagation() // This is to avoid click spread to the parent and change the routing\n\n                          let newValue: string[] | undefined\n                          if (isItemPinned) {\n                            newValue = unpinItem(id)\n                          } else {\n                            newValue = pinItem(id)\n                          }\n                          onClickPinUnpin?.({\n                            state: isItemPinned ? 'unpin' : 'pin',\n                            id,\n                            totalPinned: newValue,\n                          })\n                        }\n                      }}\n                      disabled={isItemPinned ? false : isPinDisabled}\n                    >\n                      <PinUnpinIcon\n                        size=\"medium\"\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={target}\n              rel={rel}\n            >\n              <AnimatedIcon sentiment=\"neutral\" prominence=\"weak\" />\n            </Container>\n          </MenuStack>\n        </Tooltip>\n      )\n    }\n\n    return null\n  },\n)\n"]} */",
146
+ styles: "padding-left:28px/*# 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":"AAgIkC","file":"/home/runner/work/ultraviolet/ultraviolet/packages/plus/src/components/Navigation/components/Item.tsx","sourcesContent":["'use client'\n\nimport { css } from '@emotion/react'\nimport styled from '@emotion/styled'\nimport {\n  ArrowDownIcon,\n  ArrowRightIcon,\n  DragIcon,\n  OpenInNewIcon,\n  PinOutlineIcon,\n  UnpinIcon,\n} from '@ultraviolet/icons'\nimport * as CategoryIcon from '@ultraviolet/icons/category'\nimport { ConsoleCategoryIcon } from '@ultraviolet/icons/category'\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  isValidElement,\n  memo,\n  useCallback,\n  useContext,\n  useEffect,\n  useMemo,\n  useReducer,\n} from 'react'\nimport type { PascalToCamelCaseWithoutSuffix } from '../../../types'\nimport { useNavigation } from '../NavigationProvider'\nimport { ANIMATION_DURATION, shrinkHeight } from '../constants'\nimport type { PinUnPinType } from '../types'\nimport { ItemContext, ItemProvider } from './ItemProvider'\n\nconst RelativeDiv = styled.div`\n  position: relative;\n`\n\nconst StyledPinIconOutline = styled(PinOutlineIcon, {\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 }) =>\n      active ? `background: ${theme.colors.primary.backgroundHover};` : null}\n  }\n`\n\nconst StyledUnpinIcon = StyledPinIconOutline.withComponent(UnpinIcon)\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(DragIcon)`\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  &: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(OpenInNewIcon)``\n\nconst WrapText = styled(Text)`\n  overflow-wrap: anywhere;\n  overflow: hidden;\n  display: -webkit-box;\n  -webkit-box-orient: vertical;\n  -webkit-line-clamp: 2;\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 }) => 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\"][data-animation-type=\"complex\"] {\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\"][data-animation-type=\"complex\"] {\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 StackIcon = styled(Stack)`\n  padding-top: ${({ theme }) => theme.space['0.5']};\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?: PascalToCamelCaseWithoutSuffix<\n    keyof typeof CategoryIcon,\n    'CategoryIcon'\n  >\n  categoryIconVariant?: ComponentProps<\n    (typeof CategoryIcon)['BaremetalCategoryIcon']\n  >['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?: HTMLAnchorElement['href']\n  target?: HTMLAnchorElement['target']\n  rel?: HTMLAnchorElement['rel']\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  onToggle?: (toggle: boolean) => void\n  onClickPinUnpin?: (parameters: PinUnPinType) => 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 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  'data-testid'?: string\n}\n\nconst onDragStopTrigger = (event: DragEvent<HTMLDivElement>) => {\n  // eslint-disable-next-line no-param-reassign\n  event.currentTarget.style.opacity = '1'\n}\n\nexport const Item = memo(\n  ({\n    children,\n    categoryIcon,\n    categoryIconVariant,\n    label,\n    subLabel,\n    badgeText,\n    badgeSentiment,\n    href,\n    target,\n    rel,\n    onToggle,\n    onClickPinUnpin,\n    toggle,\n    active,\n    noPinButton,\n    type = 'default',\n    as,\n    disabled,\n    noExpand = false,\n    index,\n    id,\n    'data-testid': dataTestId,\n  }: ItemProps) => {\n    const context = useNavigation()\n    if (!context) {\n      throw new Error(\n        'Navigation.Item can only be used inside a NavigationProvider.',\n      )\n    }\n\n    const itemProvider = useContext(ItemContext)\n    const hasParents = !!itemProvider\n\n    const {\n      expanded,\n      locales,\n      pinnedFeature,\n      pinItem,\n      unpinItem,\n      pinnedItems,\n      pinLimit,\n      animation,\n      registerItem,\n      shouldAnimate,\n      animationType,\n    } = context\n\n    useEffect(\n      () => {\n        if (type !== 'pinnedGroup' && pinnedFeature) {\n          registerItem({ [id]: { label, active, onToggle, onClickPinUnpin } })\n        }\n      },\n      // eslint-disable-next-line react-hooks/exhaustive-deps\n      [active, id, label, registerItem],\n    )\n\n    const [internalExpanded, onToggleExpand] = useReducer(\n      prevState => !prevState,\n      Boolean(toggle),\n    )\n\n    const triggerToggle = useCallback(() => {\n      onToggleExpand()\n      onToggle?.(internalExpanded)\n    }, [internalExpanded, onToggle])\n\n    const PaddedStack =\n      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 = useMemo(\n      () => StyledContainer.withComponent(containerTag),\n      [containerTag],\n    )\n\n    const CategoryIconUsed = categoryIcon\n      ? CategoryIcon[\n          `${\n            categoryIcon.charAt(0).toUpperCase() + categoryIcon.slice(1)\n          }CategoryIcon` as keyof typeof CategoryIcon\n        ]\n      : null\n\n    const ArrowIcon = useMemo(\n      () => (internalExpanded ? ArrowDownIcon : ArrowRightIcon),\n      [internalExpanded],\n    )\n\n    const PinUnpinIcon = useMemo(\n      () => (isItemPinned ? StyledUnpinIcon : StyledPinIconOutline),\n      [isItemPinned],\n    )\n\n    const ariaExpanded = useMemo(() => {\n      if (hasHrefAndNoChildren && internalExpanded) {\n        return true\n      }\n\n      if (hasHrefAndNoChildren && !internalExpanded) {\n        return false\n      }\n\n      return undefined\n    }, [hasHrefAndNoChildren, internalExpanded])\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 onDragStart = useCallback(\n      (event: DragEvent<HTMLDivElement>) => {\n        if (expanded) {\n          event.dataTransfer.setData(\n            'text/plain',\n            JSON.stringify({ label, index }),\n          )\n          // eslint-disable-next-line no-param-reassign\n          event.currentTarget.style.opacity = '0.5'\n        }\n\n        return undefined\n      },\n      [expanded, index, label],\n    )\n\n    const onDragEnd = useCallback(\n      (event: DragEvent<HTMLDivElement>) =>\n        expanded ? onDragStopTrigger(event) : undefined,\n      [expanded],\n    )\n\n    // This content is when the navigation is expanded\n    if (expanded || (!expanded && animation === 'expand')) {\n      return (\n        <>\n          <Container\n            gap={1}\n            direction=\"row\"\n            alignItems={categoryIcon ? 'flex-start' : 'center'}\n            justifyContent=\"space-between\"\n            data-has-sub-label={!!subLabel}\n            onClick={triggerToggle}\n            aria-expanded={ariaExpanded}\n            href={href}\n            target={target}\n            rel={rel}\n            data-is-pinnable={shouldShowPinnedButton}\n            data-is-active={active}\n            data-animation={shouldAnimate ? animation : undefined}\n            data-animation-type={animationType}\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={onDragStart}\n            onDragEnd={onDragEnd}\n            id={id}\n            data-testid={dataTestId}\n          >\n            <Stack\n              direction=\"row\"\n              gap={1}\n              alignItems={categoryIcon ? 'flex-start' : 'center'}\n              justifyContent=\"center\"\n            >\n              {CategoryIconUsed ? (\n                <ContainerCategoryIcon\n                  alignItems=\"center\"\n                  justifyContent=\"center\"\n                >\n                  <CategoryIconUsed\n                    variant={active ? 'primary' : categoryIconVariant}\n                    disabled={disabled}\n                  />\n                </ContainerCategoryIcon>\n              ) : null}\n              {type === 'pinned' && expanded ? (\n                <GrabIcon\n                  sentiment=\"neutral\"\n                  prominence=\"weak\"\n                  size=\"small\"\n                  disabled={disabled}\n                />\n              ) : null}\n              <Stack>\n                {!animation ? (\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                    data-animation={animation}\n                    disabled={disabled}\n                    whiteSpace=\"pre-wrap\"\n                  >\n                    {label}\n                  </WrapText>\n                ) : null}\n                {subLabel && !animation ? (\n                  <WrapText\n                    as=\"span\"\n                    variant=\"caption\"\n                    sentiment=\"neutral\"\n                    prominence=\"weak\"\n                    data-animation={animation}\n                    disabled={disabled}\n                    whiteSpace=\"pre-wrap\"\n                  >\n                    {subLabel}\n                  </WrapText>\n                ) : null}\n              </Stack>\n            </Stack>\n            <Stack\n              direction=\"row\"\n              alignItems=\"center\"\n              gap={href ? 1 : undefined}\n            >\n              {badgeText || hasPinnedFeatureAndNoChildren ? (\n                <>\n                  {badgeText && !animation ? (\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                          aria-label={isItemPinned ? 'unpin' : 'pin'}\n                          size=\"xsmall\"\n                          variant=\"ghost\"\n                          sentiment={active ? 'primary' : 'neutral'}\n                          onClick={(event: MouseEvent<HTMLDivElement>) => {\n                            if (pinnedItems.length < pinLimit || isItemPinned) {\n                              event.preventDefault()\n                              event.stopPropagation() // This is to avoid click spread to the parent and change the routing\n                              let newValue: string[] | undefined\n                              if (isItemPinned) {\n                                newValue = unpinItem(id)\n                              } else {\n                                newValue = pinItem(id)\n                              }\n\n                              onClickPinUnpin?.({\n                                state: isItemPinned ? 'unpin' : 'pin',\n                                id,\n                                totalPinned: newValue,\n                              })\n                            }\n                          }}\n                          disabled={isItemPinned ? false : isPinDisabled}\n                        >\n                          <PinUnpinIcon\n                            size=\"medium\"\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 && target === '_blank' && !animation ? (\n                <AnimatedIcon\n                  sentiment=\"neutral\"\n                  prominence=\"default\"\n                  disabled={disabled}\n                />\n              ) : null}\n              {children ? (\n                <StackIcon gap={1} direction=\"row\" alignItems=\"center\">\n                  {!animation && !noExpand ? (\n                    <ArrowIcon sentiment=\"neutral\" prominence=\"weak\" />\n                  ) : null}\n                </StackIcon>\n              ) : null}\n            </Stack>\n          </Container>\n          {children ? (\n            <>\n              {!noExpand ? (\n                <ItemProvider>\n                  <Expandable opened={internalExpanded} animationDuration={0}>\n                    <PaddedStack width={animation ? '100%' : undefined}>\n                      {children}\n                    </PaddedStack>\n                  </Expandable>\n                </ItemProvider>\n              ) : (\n                <ItemProvider>\n                  <PaddedStack width={animation ? '100%' : undefined}>\n                    {children}\n                  </PaddedStack>\n                </ItemProvider>\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                  aria-label={label}\n                >\n                  {CategoryIconUsed ? (\n                    <Stack\n                      direction=\"row\"\n                      gap={1}\n                      alignItems=\"center\"\n                      justifyContent=\"center\"\n                    >\n                      <CategoryIconUsed\n                        variant={active ? 'primary' : categoryIconVariant}\n                      />\n                    </Stack>\n                  ) : null}\n                </Button>\n              }\n              placement=\"right\"\n            >\n              <ItemProvider>{children}</ItemProvider>\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                aria-label={label}\n              >\n                <Stack\n                  direction=\"row\"\n                  gap={1}\n                  alignItems=\"center\"\n                  justifyContent=\"center\"\n                >\n                  {CategoryIconUsed ? (\n                    <CategoryIconUsed\n                      variant={active ? 'primary' : categoryIconVariant}\n                    />\n                  ) : (\n                    <ConsoleCategoryIcon\n                      variant={active ? 'primary' : categoryIconVariant}\n                    />\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          target={target}\n          rel={rel}\n          borderless\n          active={active}\n          disabled={disabled}\n          sentiment={active ? 'primary' : 'neutral'}\n          isPinnable={shouldShowPinnedButton}\n          onClick={() => onToggle?.(!!active)}\n        >\n          <Stack\n            gap={1}\n            direction=\"row\"\n            alignItems=\"center\"\n            justifyContent=\"space-between\"\n            flex={1}\n            width=\"100%\"\n          >\n            {!animation ? (\n              <WrapText as=\"span\" variant=\"bodySmall\" whiteSpace=\"pre-wrap\">\n                {label}\n              </WrapText>\n            ) : null}\n            <Stack direction=\"row\">\n              {badgeText && !animation ? (\n                <StyledBadge\n                  sentiment={badgeSentiment}\n                  size=\"small\"\n                  prominence=\"strong\"\n                  disabled={disabled}\n                >\n                  {badgeText}\n                </StyledBadge>\n              ) : null}\n              {hasHrefAndNoChildren && target === '_blank' ? (\n                <AnimatedIcon\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                      aria-label={isItemPinned ? 'unpin' : 'pin'}\n                      variant=\"ghost\"\n                      sentiment={active ? 'primary' : 'neutral'}\n                      onClick={(event: MouseEvent<HTMLDivElement>) => {\n                        if (pinnedItems.length < pinLimit || isItemPinned) {\n                          event.preventDefault()\n                          event.stopPropagation() // This is to avoid click spread to the parent and change the routing\n\n                          let newValue: string[] | undefined\n                          if (isItemPinned) {\n                            newValue = unpinItem(id)\n                          } else {\n                            newValue = pinItem(id)\n                          }\n                          onClickPinUnpin?.({\n                            state: isItemPinned ? 'unpin' : 'pin',\n                            id,\n                            totalPinned: newValue,\n                          })\n                        }\n                      }}\n                      disabled={isItemPinned ? false : isPinDisabled}\n                    >\n                      <PinUnpinIcon\n                        size=\"medium\"\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={target}\n              rel={rel}\n            >\n              <AnimatedIcon sentiment=\"neutral\" prominence=\"weak\" />\n            </Container>\n          </MenuStack>\n        </Tooltip>\n      )\n    }\n\n    return null\n  },\n)\n"]} */",
147
147
  toString: _EMOTION_STRINGIFIED_CSS_ERROR__
148
148
  });
149
149
  const AnimatedIcon = /* @__PURE__ */ _styled__default.default(icons.OpenInNewIcon, process.env.NODE_ENV === "production" ? {
@@ -151,7 +151,7 @@ const AnimatedIcon = /* @__PURE__ */ _styled__default.default(icons.OpenInNewIco
151
151
  } : {
152
152
  target: "e134hokc6",
153
153
  label: "AnimatedIcon"
154
- })(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":"AAoI0C","file":"/home/runner/work/ultraviolet/ultraviolet/packages/plus/src/components/Navigation/components/Item.tsx","sourcesContent":["'use client'\n\nimport { css } from '@emotion/react'\nimport styled from '@emotion/styled'\nimport {\n  ArrowDownIcon,\n  ArrowRightIcon,\n  DragIcon,\n  OpenInNewIcon,\n  PinOutlineIcon,\n  UnpinIcon,\n} from '@ultraviolet/icons'\nimport * as CategoryIcon from '@ultraviolet/icons/category'\nimport { ConsoleCategoryIcon } from '@ultraviolet/icons/category'\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  isValidElement,\n  memo,\n  useCallback,\n  useContext,\n  useEffect,\n  useMemo,\n  useReducer,\n} from 'react'\nimport type { PascalToCamelCaseWithoutSuffix } from '../../../types'\nimport { useNavigation } from '../NavigationProvider'\nimport { ANIMATION_DURATION, shrinkHeight } from '../constants'\nimport type { PinUnPinType } from '../types'\nimport { ItemContext, ItemProvider } from './ItemProvider'\n\nconst RelativeDiv = styled.div`\n  position: relative;\n`\n\nconst StyledPinIconOutline = styled(PinOutlineIcon, {\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 }) =>\n      active ? `background: ${theme.colors.primary.backgroundHover};` : null}\n  }\n`\n\nconst StyledUnpinIcon = StyledPinIconOutline.withComponent(UnpinIcon)\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(DragIcon)`\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  &: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(OpenInNewIcon)``\n\nconst WrapText = styled(Text)`\n  overflow-wrap: anywhere;\n  overflow: hidden;\n  display: -webkit-box;\n  -webkit-box-orient: vertical;\n  -webkit-line-clamp: 2;\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 }) => 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\"][data-animation-type=\"complex\"] {\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\"][data-animation-type=\"complex\"] {\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 StackIcon = styled(Stack)`\n  padding-top: ${({ theme }) => theme.space['0.5']};\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?: PascalToCamelCaseWithoutSuffix<\n    keyof typeof CategoryIcon,\n    'CategoryIcon'\n  >\n  categoryIconVariant?: ComponentProps<\n    (typeof CategoryIcon)['BaremetalCategoryIcon']\n  >['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?: HTMLAnchorElement['href']\n  target?: HTMLAnchorElement['target']\n  rel?: HTMLAnchorElement['rel']\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  onToggle?: (toggle: boolean) => void\n  onClickPinUnpin?: (parameters: PinUnPinType) => 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 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  'data-testid'?: string\n}\n\nconst onDragStopTrigger = (event: DragEvent<HTMLDivElement>) => {\n  // eslint-disable-next-line no-param-reassign\n  event.currentTarget.style.opacity = '1'\n}\n\nexport const Item = memo(\n  ({\n    children,\n    categoryIcon,\n    categoryIconVariant,\n    label,\n    subLabel,\n    badgeText,\n    badgeSentiment,\n    href,\n    target,\n    rel,\n    onToggle,\n    onClickPinUnpin,\n    toggle,\n    active,\n    noPinButton,\n    type = 'default',\n    as,\n    disabled,\n    noExpand = false,\n    index,\n    id,\n    'data-testid': dataTestId,\n  }: ItemProps) => {\n    const context = useNavigation()\n    if (!context) {\n      throw new Error(\n        'Navigation.Item can only be used inside a NavigationProvider.',\n      )\n    }\n\n    const itemProvider = useContext(ItemContext)\n    const hasParents = !!itemProvider\n\n    const {\n      expanded,\n      locales,\n      pinnedFeature,\n      pinItem,\n      unpinItem,\n      pinnedItems,\n      pinLimit,\n      animation,\n      registerItem,\n      shouldAnimate,\n      animationType,\n    } = context\n\n    useEffect(\n      () => {\n        if (type !== 'pinnedGroup') {\n          registerItem({ [id]: { label, active, onToggle, onClickPinUnpin } })\n        }\n      },\n      // eslint-disable-next-line react-hooks/exhaustive-deps\n      [active, id, label, registerItem],\n    )\n\n    const [internalExpanded, onToggleExpand] = useReducer(\n      prevState => !prevState,\n      Boolean(toggle),\n    )\n\n    const triggerToggle = useCallback(() => {\n      onToggleExpand()\n      onToggle?.(internalExpanded)\n    }, [internalExpanded, onToggle])\n\n    const PaddedStack =\n      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 = useMemo(\n      () => StyledContainer.withComponent(containerTag),\n      [containerTag],\n    )\n\n    const CategoryIconUsed = categoryIcon\n      ? CategoryIcon[\n          `${\n            categoryIcon.charAt(0).toUpperCase() + categoryIcon.slice(1)\n          }CategoryIcon` as keyof typeof CategoryIcon\n        ]\n      : null\n\n    const ArrowIcon = useMemo(\n      () => (internalExpanded ? ArrowDownIcon : ArrowRightIcon),\n      [internalExpanded],\n    )\n\n    const PinUnpinIcon = useMemo(\n      () => (isItemPinned ? StyledUnpinIcon : StyledPinIconOutline),\n      [isItemPinned],\n    )\n\n    const ariaExpanded = useMemo(() => {\n      if (hasHrefAndNoChildren && internalExpanded) {\n        return true\n      }\n\n      if (hasHrefAndNoChildren && !internalExpanded) {\n        return false\n      }\n\n      return undefined\n    }, [hasHrefAndNoChildren, internalExpanded])\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 onDragStart = useCallback(\n      (event: DragEvent<HTMLDivElement>) => {\n        if (expanded) {\n          event.dataTransfer.setData(\n            'text/plain',\n            JSON.stringify({ label, index }),\n          )\n          // eslint-disable-next-line no-param-reassign\n          event.currentTarget.style.opacity = '0.5'\n        }\n\n        return undefined\n      },\n      [expanded, index, label],\n    )\n\n    const onDragEnd = useCallback(\n      (event: DragEvent<HTMLDivElement>) =>\n        expanded ? onDragStopTrigger(event) : undefined,\n      [expanded],\n    )\n\n    // This content is when the navigation is expanded\n    if (expanded || (!expanded && animation === 'expand')) {\n      return (\n        <>\n          <Container\n            gap={1}\n            direction=\"row\"\n            alignItems={categoryIcon ? 'flex-start' : 'center'}\n            justifyContent=\"space-between\"\n            data-has-sub-label={!!subLabel}\n            onClick={triggerToggle}\n            aria-expanded={ariaExpanded}\n            href={href}\n            target={target}\n            rel={rel}\n            data-is-pinnable={shouldShowPinnedButton}\n            data-is-active={active}\n            data-animation={shouldAnimate ? animation : undefined}\n            data-animation-type={animationType}\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={onDragStart}\n            onDragEnd={onDragEnd}\n            id={id}\n            data-testid={dataTestId}\n          >\n            <Stack\n              direction=\"row\"\n              gap={1}\n              alignItems={categoryIcon ? 'flex-start' : 'center'}\n              justifyContent=\"center\"\n            >\n              {CategoryIconUsed ? (\n                <ContainerCategoryIcon\n                  alignItems=\"center\"\n                  justifyContent=\"center\"\n                >\n                  <CategoryIconUsed\n                    variant={active ? 'primary' : categoryIconVariant}\n                    disabled={disabled}\n                  />\n                </ContainerCategoryIcon>\n              ) : null}\n              {type === 'pinned' && expanded ? (\n                <GrabIcon\n                  sentiment=\"neutral\"\n                  prominence=\"weak\"\n                  size=\"small\"\n                  disabled={disabled}\n                />\n              ) : null}\n              <Stack>\n                {!animation ? (\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                    data-animation={animation}\n                    disabled={disabled}\n                    whiteSpace=\"pre-wrap\"\n                  >\n                    {label}\n                  </WrapText>\n                ) : null}\n                {subLabel && !animation ? (\n                  <WrapText\n                    as=\"span\"\n                    variant=\"caption\"\n                    sentiment=\"neutral\"\n                    prominence=\"weak\"\n                    data-animation={animation}\n                    disabled={disabled}\n                    whiteSpace=\"pre-wrap\"\n                  >\n                    {subLabel}\n                  </WrapText>\n                ) : null}\n              </Stack>\n            </Stack>\n            <Stack\n              direction=\"row\"\n              alignItems=\"center\"\n              gap={href ? 1 : undefined}\n            >\n              {badgeText || hasPinnedFeatureAndNoChildren ? (\n                <>\n                  {badgeText && !animation ? (\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                          aria-label={isItemPinned ? 'unpin' : 'pin'}\n                          size=\"xsmall\"\n                          variant=\"ghost\"\n                          sentiment={active ? 'primary' : 'neutral'}\n                          onClick={(event: MouseEvent<HTMLDivElement>) => {\n                            if (pinnedItems.length < pinLimit || isItemPinned) {\n                              event.preventDefault()\n                              event.stopPropagation() // This is to avoid click spread to the parent and change the routing\n                              let newValue: string[] | undefined\n                              if (isItemPinned) {\n                                newValue = unpinItem(id)\n                              } else {\n                                newValue = pinItem(id)\n                              }\n\n                              onClickPinUnpin?.({\n                                state: isItemPinned ? 'unpin' : 'pin',\n                                id,\n                                totalPinned: newValue,\n                              })\n                            }\n                          }}\n                          disabled={isItemPinned ? false : isPinDisabled}\n                        >\n                          <PinUnpinIcon\n                            size=\"medium\"\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 && target === '_blank' && !animation ? (\n                <AnimatedIcon\n                  sentiment=\"neutral\"\n                  prominence=\"default\"\n                  disabled={disabled}\n                />\n              ) : null}\n              {children ? (\n                <StackIcon gap={1} direction=\"row\" alignItems=\"center\">\n                  {!animation && !noExpand ? (\n                    <ArrowIcon sentiment=\"neutral\" prominence=\"weak\" />\n                  ) : null}\n                </StackIcon>\n              ) : null}\n            </Stack>\n          </Container>\n          {children ? (\n            <>\n              {!noExpand ? (\n                <ItemProvider>\n                  <Expandable opened={internalExpanded} animationDuration={0}>\n                    <PaddedStack width={animation ? '100%' : undefined}>\n                      {children}\n                    </PaddedStack>\n                  </Expandable>\n                </ItemProvider>\n              ) : (\n                <ItemProvider>\n                  <PaddedStack width={animation ? '100%' : undefined}>\n                    {children}\n                  </PaddedStack>\n                </ItemProvider>\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                  aria-label={label}\n                >\n                  {CategoryIconUsed ? (\n                    <Stack\n                      direction=\"row\"\n                      gap={1}\n                      alignItems=\"center\"\n                      justifyContent=\"center\"\n                    >\n                      <CategoryIconUsed\n                        variant={active ? 'primary' : categoryIconVariant}\n                      />\n                    </Stack>\n                  ) : null}\n                </Button>\n              }\n              placement=\"right\"\n            >\n              <ItemProvider>{children}</ItemProvider>\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                aria-label={label}\n              >\n                <Stack\n                  direction=\"row\"\n                  gap={1}\n                  alignItems=\"center\"\n                  justifyContent=\"center\"\n                >\n                  {CategoryIconUsed ? (\n                    <CategoryIconUsed\n                      variant={active ? 'primary' : categoryIconVariant}\n                    />\n                  ) : (\n                    <ConsoleCategoryIcon\n                      variant={active ? 'primary' : categoryIconVariant}\n                    />\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          target={target}\n          rel={rel}\n          borderless\n          active={active}\n          disabled={disabled}\n          sentiment={active ? 'primary' : 'neutral'}\n          isPinnable={shouldShowPinnedButton}\n          onClick={() => onToggle?.(!!active)}\n        >\n          <Stack\n            gap={1}\n            direction=\"row\"\n            alignItems=\"center\"\n            justifyContent=\"space-between\"\n            flex={1}\n            width=\"100%\"\n          >\n            {!animation ? (\n              <WrapText as=\"span\" variant=\"bodySmall\" whiteSpace=\"pre-wrap\">\n                {label}\n              </WrapText>\n            ) : null}\n            <Stack direction=\"row\">\n              {badgeText && !animation ? (\n                <StyledBadge\n                  sentiment={badgeSentiment}\n                  size=\"small\"\n                  prominence=\"strong\"\n                  disabled={disabled}\n                >\n                  {badgeText}\n                </StyledBadge>\n              ) : null}\n              {hasHrefAndNoChildren && target === '_blank' ? (\n                <AnimatedIcon\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                      aria-label={isItemPinned ? 'unpin' : 'pin'}\n                      variant=\"ghost\"\n                      sentiment={active ? 'primary' : 'neutral'}\n                      onClick={(event: MouseEvent<HTMLDivElement>) => {\n                        if (pinnedItems.length < pinLimit || isItemPinned) {\n                          event.preventDefault()\n                          event.stopPropagation() // This is to avoid click spread to the parent and change the routing\n\n                          let newValue: string[] | undefined\n                          if (isItemPinned) {\n                            newValue = unpinItem(id)\n                          } else {\n                            newValue = pinItem(id)\n                          }\n                          onClickPinUnpin?.({\n                            state: isItemPinned ? 'unpin' : 'pin',\n                            id,\n                            totalPinned: newValue,\n                          })\n                        }\n                      }}\n                      disabled={isItemPinned ? false : isPinDisabled}\n                    >\n                      <PinUnpinIcon\n                        size=\"medium\"\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={target}\n              rel={rel}\n            >\n              <AnimatedIcon sentiment=\"neutral\" prominence=\"weak\" />\n            </Container>\n          </MenuStack>\n        </Tooltip>\n      )\n    }\n\n    return null\n  },\n)\n"]} */");
154
+ })(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":"AAoI0C","file":"/home/runner/work/ultraviolet/ultraviolet/packages/plus/src/components/Navigation/components/Item.tsx","sourcesContent":["'use client'\n\nimport { css } from '@emotion/react'\nimport styled from '@emotion/styled'\nimport {\n  ArrowDownIcon,\n  ArrowRightIcon,\n  DragIcon,\n  OpenInNewIcon,\n  PinOutlineIcon,\n  UnpinIcon,\n} from '@ultraviolet/icons'\nimport * as CategoryIcon from '@ultraviolet/icons/category'\nimport { ConsoleCategoryIcon } from '@ultraviolet/icons/category'\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  isValidElement,\n  memo,\n  useCallback,\n  useContext,\n  useEffect,\n  useMemo,\n  useReducer,\n} from 'react'\nimport type { PascalToCamelCaseWithoutSuffix } from '../../../types'\nimport { useNavigation } from '../NavigationProvider'\nimport { ANIMATION_DURATION, shrinkHeight } from '../constants'\nimport type { PinUnPinType } from '../types'\nimport { ItemContext, ItemProvider } from './ItemProvider'\n\nconst RelativeDiv = styled.div`\n  position: relative;\n`\n\nconst StyledPinIconOutline = styled(PinOutlineIcon, {\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 }) =>\n      active ? `background: ${theme.colors.primary.backgroundHover};` : null}\n  }\n`\n\nconst StyledUnpinIcon = StyledPinIconOutline.withComponent(UnpinIcon)\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(DragIcon)`\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  &: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(OpenInNewIcon)``\n\nconst WrapText = styled(Text)`\n  overflow-wrap: anywhere;\n  overflow: hidden;\n  display: -webkit-box;\n  -webkit-box-orient: vertical;\n  -webkit-line-clamp: 2;\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 }) => 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\"][data-animation-type=\"complex\"] {\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\"][data-animation-type=\"complex\"] {\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 StackIcon = styled(Stack)`\n  padding-top: ${({ theme }) => theme.space['0.5']};\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?: PascalToCamelCaseWithoutSuffix<\n    keyof typeof CategoryIcon,\n    'CategoryIcon'\n  >\n  categoryIconVariant?: ComponentProps<\n    (typeof CategoryIcon)['BaremetalCategoryIcon']\n  >['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?: HTMLAnchorElement['href']\n  target?: HTMLAnchorElement['target']\n  rel?: HTMLAnchorElement['rel']\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  onToggle?: (toggle: boolean) => void\n  onClickPinUnpin?: (parameters: PinUnPinType) => 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 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  'data-testid'?: string\n}\n\nconst onDragStopTrigger = (event: DragEvent<HTMLDivElement>) => {\n  // eslint-disable-next-line no-param-reassign\n  event.currentTarget.style.opacity = '1'\n}\n\nexport const Item = memo(\n  ({\n    children,\n    categoryIcon,\n    categoryIconVariant,\n    label,\n    subLabel,\n    badgeText,\n    badgeSentiment,\n    href,\n    target,\n    rel,\n    onToggle,\n    onClickPinUnpin,\n    toggle,\n    active,\n    noPinButton,\n    type = 'default',\n    as,\n    disabled,\n    noExpand = false,\n    index,\n    id,\n    'data-testid': dataTestId,\n  }: ItemProps) => {\n    const context = useNavigation()\n    if (!context) {\n      throw new Error(\n        'Navigation.Item can only be used inside a NavigationProvider.',\n      )\n    }\n\n    const itemProvider = useContext(ItemContext)\n    const hasParents = !!itemProvider\n\n    const {\n      expanded,\n      locales,\n      pinnedFeature,\n      pinItem,\n      unpinItem,\n      pinnedItems,\n      pinLimit,\n      animation,\n      registerItem,\n      shouldAnimate,\n      animationType,\n    } = context\n\n    useEffect(\n      () => {\n        if (type !== 'pinnedGroup' && pinnedFeature) {\n          registerItem({ [id]: { label, active, onToggle, onClickPinUnpin } })\n        }\n      },\n      // eslint-disable-next-line react-hooks/exhaustive-deps\n      [active, id, label, registerItem],\n    )\n\n    const [internalExpanded, onToggleExpand] = useReducer(\n      prevState => !prevState,\n      Boolean(toggle),\n    )\n\n    const triggerToggle = useCallback(() => {\n      onToggleExpand()\n      onToggle?.(internalExpanded)\n    }, [internalExpanded, onToggle])\n\n    const PaddedStack =\n      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 = useMemo(\n      () => StyledContainer.withComponent(containerTag),\n      [containerTag],\n    )\n\n    const CategoryIconUsed = categoryIcon\n      ? CategoryIcon[\n          `${\n            categoryIcon.charAt(0).toUpperCase() + categoryIcon.slice(1)\n          }CategoryIcon` as keyof typeof CategoryIcon\n        ]\n      : null\n\n    const ArrowIcon = useMemo(\n      () => (internalExpanded ? ArrowDownIcon : ArrowRightIcon),\n      [internalExpanded],\n    )\n\n    const PinUnpinIcon = useMemo(\n      () => (isItemPinned ? StyledUnpinIcon : StyledPinIconOutline),\n      [isItemPinned],\n    )\n\n    const ariaExpanded = useMemo(() => {\n      if (hasHrefAndNoChildren && internalExpanded) {\n        return true\n      }\n\n      if (hasHrefAndNoChildren && !internalExpanded) {\n        return false\n      }\n\n      return undefined\n    }, [hasHrefAndNoChildren, internalExpanded])\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 onDragStart = useCallback(\n      (event: DragEvent<HTMLDivElement>) => {\n        if (expanded) {\n          event.dataTransfer.setData(\n            'text/plain',\n            JSON.stringify({ label, index }),\n          )\n          // eslint-disable-next-line no-param-reassign\n          event.currentTarget.style.opacity = '0.5'\n        }\n\n        return undefined\n      },\n      [expanded, index, label],\n    )\n\n    const onDragEnd = useCallback(\n      (event: DragEvent<HTMLDivElement>) =>\n        expanded ? onDragStopTrigger(event) : undefined,\n      [expanded],\n    )\n\n    // This content is when the navigation is expanded\n    if (expanded || (!expanded && animation === 'expand')) {\n      return (\n        <>\n          <Container\n            gap={1}\n            direction=\"row\"\n            alignItems={categoryIcon ? 'flex-start' : 'center'}\n            justifyContent=\"space-between\"\n            data-has-sub-label={!!subLabel}\n            onClick={triggerToggle}\n            aria-expanded={ariaExpanded}\n            href={href}\n            target={target}\n            rel={rel}\n            data-is-pinnable={shouldShowPinnedButton}\n            data-is-active={active}\n            data-animation={shouldAnimate ? animation : undefined}\n            data-animation-type={animationType}\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={onDragStart}\n            onDragEnd={onDragEnd}\n            id={id}\n            data-testid={dataTestId}\n          >\n            <Stack\n              direction=\"row\"\n              gap={1}\n              alignItems={categoryIcon ? 'flex-start' : 'center'}\n              justifyContent=\"center\"\n            >\n              {CategoryIconUsed ? (\n                <ContainerCategoryIcon\n                  alignItems=\"center\"\n                  justifyContent=\"center\"\n                >\n                  <CategoryIconUsed\n                    variant={active ? 'primary' : categoryIconVariant}\n                    disabled={disabled}\n                  />\n                </ContainerCategoryIcon>\n              ) : null}\n              {type === 'pinned' && expanded ? (\n                <GrabIcon\n                  sentiment=\"neutral\"\n                  prominence=\"weak\"\n                  size=\"small\"\n                  disabled={disabled}\n                />\n              ) : null}\n              <Stack>\n                {!animation ? (\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                    data-animation={animation}\n                    disabled={disabled}\n                    whiteSpace=\"pre-wrap\"\n                  >\n                    {label}\n                  </WrapText>\n                ) : null}\n                {subLabel && !animation ? (\n                  <WrapText\n                    as=\"span\"\n                    variant=\"caption\"\n                    sentiment=\"neutral\"\n                    prominence=\"weak\"\n                    data-animation={animation}\n                    disabled={disabled}\n                    whiteSpace=\"pre-wrap\"\n                  >\n                    {subLabel}\n                  </WrapText>\n                ) : null}\n              </Stack>\n            </Stack>\n            <Stack\n              direction=\"row\"\n              alignItems=\"center\"\n              gap={href ? 1 : undefined}\n            >\n              {badgeText || hasPinnedFeatureAndNoChildren ? (\n                <>\n                  {badgeText && !animation ? (\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                          aria-label={isItemPinned ? 'unpin' : 'pin'}\n                          size=\"xsmall\"\n                          variant=\"ghost\"\n                          sentiment={active ? 'primary' : 'neutral'}\n                          onClick={(event: MouseEvent<HTMLDivElement>) => {\n                            if (pinnedItems.length < pinLimit || isItemPinned) {\n                              event.preventDefault()\n                              event.stopPropagation() // This is to avoid click spread to the parent and change the routing\n                              let newValue: string[] | undefined\n                              if (isItemPinned) {\n                                newValue = unpinItem(id)\n                              } else {\n                                newValue = pinItem(id)\n                              }\n\n                              onClickPinUnpin?.({\n                                state: isItemPinned ? 'unpin' : 'pin',\n                                id,\n                                totalPinned: newValue,\n                              })\n                            }\n                          }}\n                          disabled={isItemPinned ? false : isPinDisabled}\n                        >\n                          <PinUnpinIcon\n                            size=\"medium\"\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 && target === '_blank' && !animation ? (\n                <AnimatedIcon\n                  sentiment=\"neutral\"\n                  prominence=\"default\"\n                  disabled={disabled}\n                />\n              ) : null}\n              {children ? (\n                <StackIcon gap={1} direction=\"row\" alignItems=\"center\">\n                  {!animation && !noExpand ? (\n                    <ArrowIcon sentiment=\"neutral\" prominence=\"weak\" />\n                  ) : null}\n                </StackIcon>\n              ) : null}\n            </Stack>\n          </Container>\n          {children ? (\n            <>\n              {!noExpand ? (\n                <ItemProvider>\n                  <Expandable opened={internalExpanded} animationDuration={0}>\n                    <PaddedStack width={animation ? '100%' : undefined}>\n                      {children}\n                    </PaddedStack>\n                  </Expandable>\n                </ItemProvider>\n              ) : (\n                <ItemProvider>\n                  <PaddedStack width={animation ? '100%' : undefined}>\n                    {children}\n                  </PaddedStack>\n                </ItemProvider>\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                  aria-label={label}\n                >\n                  {CategoryIconUsed ? (\n                    <Stack\n                      direction=\"row\"\n                      gap={1}\n                      alignItems=\"center\"\n                      justifyContent=\"center\"\n                    >\n                      <CategoryIconUsed\n                        variant={active ? 'primary' : categoryIconVariant}\n                      />\n                    </Stack>\n                  ) : null}\n                </Button>\n              }\n              placement=\"right\"\n            >\n              <ItemProvider>{children}</ItemProvider>\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                aria-label={label}\n              >\n                <Stack\n                  direction=\"row\"\n                  gap={1}\n                  alignItems=\"center\"\n                  justifyContent=\"center\"\n                >\n                  {CategoryIconUsed ? (\n                    <CategoryIconUsed\n                      variant={active ? 'primary' : categoryIconVariant}\n                    />\n                  ) : (\n                    <ConsoleCategoryIcon\n                      variant={active ? 'primary' : categoryIconVariant}\n                    />\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          target={target}\n          rel={rel}\n          borderless\n          active={active}\n          disabled={disabled}\n          sentiment={active ? 'primary' : 'neutral'}\n          isPinnable={shouldShowPinnedButton}\n          onClick={() => onToggle?.(!!active)}\n        >\n          <Stack\n            gap={1}\n            direction=\"row\"\n            alignItems=\"center\"\n            justifyContent=\"space-between\"\n            flex={1}\n            width=\"100%\"\n          >\n            {!animation ? (\n              <WrapText as=\"span\" variant=\"bodySmall\" whiteSpace=\"pre-wrap\">\n                {label}\n              </WrapText>\n            ) : null}\n            <Stack direction=\"row\">\n              {badgeText && !animation ? (\n                <StyledBadge\n                  sentiment={badgeSentiment}\n                  size=\"small\"\n                  prominence=\"strong\"\n                  disabled={disabled}\n                >\n                  {badgeText}\n                </StyledBadge>\n              ) : null}\n              {hasHrefAndNoChildren && target === '_blank' ? (\n                <AnimatedIcon\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                      aria-label={isItemPinned ? 'unpin' : 'pin'}\n                      variant=\"ghost\"\n                      sentiment={active ? 'primary' : 'neutral'}\n                      onClick={(event: MouseEvent<HTMLDivElement>) => {\n                        if (pinnedItems.length < pinLimit || isItemPinned) {\n                          event.preventDefault()\n                          event.stopPropagation() // This is to avoid click spread to the parent and change the routing\n\n                          let newValue: string[] | undefined\n                          if (isItemPinned) {\n                            newValue = unpinItem(id)\n                          } else {\n                            newValue = pinItem(id)\n                          }\n                          onClickPinUnpin?.({\n                            state: isItemPinned ? 'unpin' : 'pin',\n                            id,\n                            totalPinned: newValue,\n                          })\n                        }\n                      }}\n                      disabled={isItemPinned ? false : isPinDisabled}\n                    >\n                      <PinUnpinIcon\n                        size=\"medium\"\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={target}\n              rel={rel}\n            >\n              <AnimatedIcon sentiment=\"neutral\" prominence=\"weak\" />\n            </Container>\n          </MenuStack>\n        </Tooltip>\n      )\n    }\n\n    return null\n  },\n)\n"]} */");
155
155
  const WrapText = /* @__PURE__ */ _styled__default.default(ui.Text, process.env.NODE_ENV === "production" ? {
156
156
  target: "e134hokc5"
157
157
  } : {
@@ -162,7 +162,7 @@ const WrapText = /* @__PURE__ */ _styled__default.default(ui.Text, process.env.N
162
162
  styles: "overflow-wrap:anywhere;overflow:hidden;display:-webkit-box;-webkit-box-orient:vertical;-webkit-line-clamp:2"
163
163
  } : {
164
164
  name: "16qfaam",
165
- styles: "overflow-wrap:anywhere;overflow:hidden;display:-webkit-box;-webkit-box-orient:vertical;-webkit-line-clamp:2/*# 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":"AAsI6B","file":"/home/runner/work/ultraviolet/ultraviolet/packages/plus/src/components/Navigation/components/Item.tsx","sourcesContent":["'use client'\n\nimport { css } from '@emotion/react'\nimport styled from '@emotion/styled'\nimport {\n  ArrowDownIcon,\n  ArrowRightIcon,\n  DragIcon,\n  OpenInNewIcon,\n  PinOutlineIcon,\n  UnpinIcon,\n} from '@ultraviolet/icons'\nimport * as CategoryIcon from '@ultraviolet/icons/category'\nimport { ConsoleCategoryIcon } from '@ultraviolet/icons/category'\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  isValidElement,\n  memo,\n  useCallback,\n  useContext,\n  useEffect,\n  useMemo,\n  useReducer,\n} from 'react'\nimport type { PascalToCamelCaseWithoutSuffix } from '../../../types'\nimport { useNavigation } from '../NavigationProvider'\nimport { ANIMATION_DURATION, shrinkHeight } from '../constants'\nimport type { PinUnPinType } from '../types'\nimport { ItemContext, ItemProvider } from './ItemProvider'\n\nconst RelativeDiv = styled.div`\n  position: relative;\n`\n\nconst StyledPinIconOutline = styled(PinOutlineIcon, {\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 }) =>\n      active ? `background: ${theme.colors.primary.backgroundHover};` : null}\n  }\n`\n\nconst StyledUnpinIcon = StyledPinIconOutline.withComponent(UnpinIcon)\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(DragIcon)`\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  &: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(OpenInNewIcon)``\n\nconst WrapText = styled(Text)`\n  overflow-wrap: anywhere;\n  overflow: hidden;\n  display: -webkit-box;\n  -webkit-box-orient: vertical;\n  -webkit-line-clamp: 2;\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 }) => 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\"][data-animation-type=\"complex\"] {\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\"][data-animation-type=\"complex\"] {\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 StackIcon = styled(Stack)`\n  padding-top: ${({ theme }) => theme.space['0.5']};\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?: PascalToCamelCaseWithoutSuffix<\n    keyof typeof CategoryIcon,\n    'CategoryIcon'\n  >\n  categoryIconVariant?: ComponentProps<\n    (typeof CategoryIcon)['BaremetalCategoryIcon']\n  >['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?: HTMLAnchorElement['href']\n  target?: HTMLAnchorElement['target']\n  rel?: HTMLAnchorElement['rel']\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  onToggle?: (toggle: boolean) => void\n  onClickPinUnpin?: (parameters: PinUnPinType) => 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 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  'data-testid'?: string\n}\n\nconst onDragStopTrigger = (event: DragEvent<HTMLDivElement>) => {\n  // eslint-disable-next-line no-param-reassign\n  event.currentTarget.style.opacity = '1'\n}\n\nexport const Item = memo(\n  ({\n    children,\n    categoryIcon,\n    categoryIconVariant,\n    label,\n    subLabel,\n    badgeText,\n    badgeSentiment,\n    href,\n    target,\n    rel,\n    onToggle,\n    onClickPinUnpin,\n    toggle,\n    active,\n    noPinButton,\n    type = 'default',\n    as,\n    disabled,\n    noExpand = false,\n    index,\n    id,\n    'data-testid': dataTestId,\n  }: ItemProps) => {\n    const context = useNavigation()\n    if (!context) {\n      throw new Error(\n        'Navigation.Item can only be used inside a NavigationProvider.',\n      )\n    }\n\n    const itemProvider = useContext(ItemContext)\n    const hasParents = !!itemProvider\n\n    const {\n      expanded,\n      locales,\n      pinnedFeature,\n      pinItem,\n      unpinItem,\n      pinnedItems,\n      pinLimit,\n      animation,\n      registerItem,\n      shouldAnimate,\n      animationType,\n    } = context\n\n    useEffect(\n      () => {\n        if (type !== 'pinnedGroup') {\n          registerItem({ [id]: { label, active, onToggle, onClickPinUnpin } })\n        }\n      },\n      // eslint-disable-next-line react-hooks/exhaustive-deps\n      [active, id, label, registerItem],\n    )\n\n    const [internalExpanded, onToggleExpand] = useReducer(\n      prevState => !prevState,\n      Boolean(toggle),\n    )\n\n    const triggerToggle = useCallback(() => {\n      onToggleExpand()\n      onToggle?.(internalExpanded)\n    }, [internalExpanded, onToggle])\n\n    const PaddedStack =\n      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 = useMemo(\n      () => StyledContainer.withComponent(containerTag),\n      [containerTag],\n    )\n\n    const CategoryIconUsed = categoryIcon\n      ? CategoryIcon[\n          `${\n            categoryIcon.charAt(0).toUpperCase() + categoryIcon.slice(1)\n          }CategoryIcon` as keyof typeof CategoryIcon\n        ]\n      : null\n\n    const ArrowIcon = useMemo(\n      () => (internalExpanded ? ArrowDownIcon : ArrowRightIcon),\n      [internalExpanded],\n    )\n\n    const PinUnpinIcon = useMemo(\n      () => (isItemPinned ? StyledUnpinIcon : StyledPinIconOutline),\n      [isItemPinned],\n    )\n\n    const ariaExpanded = useMemo(() => {\n      if (hasHrefAndNoChildren && internalExpanded) {\n        return true\n      }\n\n      if (hasHrefAndNoChildren && !internalExpanded) {\n        return false\n      }\n\n      return undefined\n    }, [hasHrefAndNoChildren, internalExpanded])\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 onDragStart = useCallback(\n      (event: DragEvent<HTMLDivElement>) => {\n        if (expanded) {\n          event.dataTransfer.setData(\n            'text/plain',\n            JSON.stringify({ label, index }),\n          )\n          // eslint-disable-next-line no-param-reassign\n          event.currentTarget.style.opacity = '0.5'\n        }\n\n        return undefined\n      },\n      [expanded, index, label],\n    )\n\n    const onDragEnd = useCallback(\n      (event: DragEvent<HTMLDivElement>) =>\n        expanded ? onDragStopTrigger(event) : undefined,\n      [expanded],\n    )\n\n    // This content is when the navigation is expanded\n    if (expanded || (!expanded && animation === 'expand')) {\n      return (\n        <>\n          <Container\n            gap={1}\n            direction=\"row\"\n            alignItems={categoryIcon ? 'flex-start' : 'center'}\n            justifyContent=\"space-between\"\n            data-has-sub-label={!!subLabel}\n            onClick={triggerToggle}\n            aria-expanded={ariaExpanded}\n            href={href}\n            target={target}\n            rel={rel}\n            data-is-pinnable={shouldShowPinnedButton}\n            data-is-active={active}\n            data-animation={shouldAnimate ? animation : undefined}\n            data-animation-type={animationType}\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={onDragStart}\n            onDragEnd={onDragEnd}\n            id={id}\n            data-testid={dataTestId}\n          >\n            <Stack\n              direction=\"row\"\n              gap={1}\n              alignItems={categoryIcon ? 'flex-start' : 'center'}\n              justifyContent=\"center\"\n            >\n              {CategoryIconUsed ? (\n                <ContainerCategoryIcon\n                  alignItems=\"center\"\n                  justifyContent=\"center\"\n                >\n                  <CategoryIconUsed\n                    variant={active ? 'primary' : categoryIconVariant}\n                    disabled={disabled}\n                  />\n                </ContainerCategoryIcon>\n              ) : null}\n              {type === 'pinned' && expanded ? (\n                <GrabIcon\n                  sentiment=\"neutral\"\n                  prominence=\"weak\"\n                  size=\"small\"\n                  disabled={disabled}\n                />\n              ) : null}\n              <Stack>\n                {!animation ? (\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                    data-animation={animation}\n                    disabled={disabled}\n                    whiteSpace=\"pre-wrap\"\n                  >\n                    {label}\n                  </WrapText>\n                ) : null}\n                {subLabel && !animation ? (\n                  <WrapText\n                    as=\"span\"\n                    variant=\"caption\"\n                    sentiment=\"neutral\"\n                    prominence=\"weak\"\n                    data-animation={animation}\n                    disabled={disabled}\n                    whiteSpace=\"pre-wrap\"\n                  >\n                    {subLabel}\n                  </WrapText>\n                ) : null}\n              </Stack>\n            </Stack>\n            <Stack\n              direction=\"row\"\n              alignItems=\"center\"\n              gap={href ? 1 : undefined}\n            >\n              {badgeText || hasPinnedFeatureAndNoChildren ? (\n                <>\n                  {badgeText && !animation ? (\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                          aria-label={isItemPinned ? 'unpin' : 'pin'}\n                          size=\"xsmall\"\n                          variant=\"ghost\"\n                          sentiment={active ? 'primary' : 'neutral'}\n                          onClick={(event: MouseEvent<HTMLDivElement>) => {\n                            if (pinnedItems.length < pinLimit || isItemPinned) {\n                              event.preventDefault()\n                              event.stopPropagation() // This is to avoid click spread to the parent and change the routing\n                              let newValue: string[] | undefined\n                              if (isItemPinned) {\n                                newValue = unpinItem(id)\n                              } else {\n                                newValue = pinItem(id)\n                              }\n\n                              onClickPinUnpin?.({\n                                state: isItemPinned ? 'unpin' : 'pin',\n                                id,\n                                totalPinned: newValue,\n                              })\n                            }\n                          }}\n                          disabled={isItemPinned ? false : isPinDisabled}\n                        >\n                          <PinUnpinIcon\n                            size=\"medium\"\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 && target === '_blank' && !animation ? (\n                <AnimatedIcon\n                  sentiment=\"neutral\"\n                  prominence=\"default\"\n                  disabled={disabled}\n                />\n              ) : null}\n              {children ? (\n                <StackIcon gap={1} direction=\"row\" alignItems=\"center\">\n                  {!animation && !noExpand ? (\n                    <ArrowIcon sentiment=\"neutral\" prominence=\"weak\" />\n                  ) : null}\n                </StackIcon>\n              ) : null}\n            </Stack>\n          </Container>\n          {children ? (\n            <>\n              {!noExpand ? (\n                <ItemProvider>\n                  <Expandable opened={internalExpanded} animationDuration={0}>\n                    <PaddedStack width={animation ? '100%' : undefined}>\n                      {children}\n                    </PaddedStack>\n                  </Expandable>\n                </ItemProvider>\n              ) : (\n                <ItemProvider>\n                  <PaddedStack width={animation ? '100%' : undefined}>\n                    {children}\n                  </PaddedStack>\n                </ItemProvider>\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                  aria-label={label}\n                >\n                  {CategoryIconUsed ? (\n                    <Stack\n                      direction=\"row\"\n                      gap={1}\n                      alignItems=\"center\"\n                      justifyContent=\"center\"\n                    >\n                      <CategoryIconUsed\n                        variant={active ? 'primary' : categoryIconVariant}\n                      />\n                    </Stack>\n                  ) : null}\n                </Button>\n              }\n              placement=\"right\"\n            >\n              <ItemProvider>{children}</ItemProvider>\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                aria-label={label}\n              >\n                <Stack\n                  direction=\"row\"\n                  gap={1}\n                  alignItems=\"center\"\n                  justifyContent=\"center\"\n                >\n                  {CategoryIconUsed ? (\n                    <CategoryIconUsed\n                      variant={active ? 'primary' : categoryIconVariant}\n                    />\n                  ) : (\n                    <ConsoleCategoryIcon\n                      variant={active ? 'primary' : categoryIconVariant}\n                    />\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          target={target}\n          rel={rel}\n          borderless\n          active={active}\n          disabled={disabled}\n          sentiment={active ? 'primary' : 'neutral'}\n          isPinnable={shouldShowPinnedButton}\n          onClick={() => onToggle?.(!!active)}\n        >\n          <Stack\n            gap={1}\n            direction=\"row\"\n            alignItems=\"center\"\n            justifyContent=\"space-between\"\n            flex={1}\n            width=\"100%\"\n          >\n            {!animation ? (\n              <WrapText as=\"span\" variant=\"bodySmall\" whiteSpace=\"pre-wrap\">\n                {label}\n              </WrapText>\n            ) : null}\n            <Stack direction=\"row\">\n              {badgeText && !animation ? (\n                <StyledBadge\n                  sentiment={badgeSentiment}\n                  size=\"small\"\n                  prominence=\"strong\"\n                  disabled={disabled}\n                >\n                  {badgeText}\n                </StyledBadge>\n              ) : null}\n              {hasHrefAndNoChildren && target === '_blank' ? (\n                <AnimatedIcon\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                      aria-label={isItemPinned ? 'unpin' : 'pin'}\n                      variant=\"ghost\"\n                      sentiment={active ? 'primary' : 'neutral'}\n                      onClick={(event: MouseEvent<HTMLDivElement>) => {\n                        if (pinnedItems.length < pinLimit || isItemPinned) {\n                          event.preventDefault()\n                          event.stopPropagation() // This is to avoid click spread to the parent and change the routing\n\n                          let newValue: string[] | undefined\n                          if (isItemPinned) {\n                            newValue = unpinItem(id)\n                          } else {\n                            newValue = pinItem(id)\n                          }\n                          onClickPinUnpin?.({\n                            state: isItemPinned ? 'unpin' : 'pin',\n                            id,\n                            totalPinned: newValue,\n                          })\n                        }\n                      }}\n                      disabled={isItemPinned ? false : isPinDisabled}\n                    >\n                      <PinUnpinIcon\n                        size=\"medium\"\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={target}\n              rel={rel}\n            >\n              <AnimatedIcon sentiment=\"neutral\" prominence=\"weak\" />\n            </Container>\n          </MenuStack>\n        </Tooltip>\n      )\n    }\n\n    return null\n  },\n)\n"]} */",
165
+ styles: "overflow-wrap:anywhere;overflow:hidden;display:-webkit-box;-webkit-box-orient:vertical;-webkit-line-clamp:2/*# 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":"AAsI6B","file":"/home/runner/work/ultraviolet/ultraviolet/packages/plus/src/components/Navigation/components/Item.tsx","sourcesContent":["'use client'\n\nimport { css } from '@emotion/react'\nimport styled from '@emotion/styled'\nimport {\n  ArrowDownIcon,\n  ArrowRightIcon,\n  DragIcon,\n  OpenInNewIcon,\n  PinOutlineIcon,\n  UnpinIcon,\n} from '@ultraviolet/icons'\nimport * as CategoryIcon from '@ultraviolet/icons/category'\nimport { ConsoleCategoryIcon } from '@ultraviolet/icons/category'\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  isValidElement,\n  memo,\n  useCallback,\n  useContext,\n  useEffect,\n  useMemo,\n  useReducer,\n} from 'react'\nimport type { PascalToCamelCaseWithoutSuffix } from '../../../types'\nimport { useNavigation } from '../NavigationProvider'\nimport { ANIMATION_DURATION, shrinkHeight } from '../constants'\nimport type { PinUnPinType } from '../types'\nimport { ItemContext, ItemProvider } from './ItemProvider'\n\nconst RelativeDiv = styled.div`\n  position: relative;\n`\n\nconst StyledPinIconOutline = styled(PinOutlineIcon, {\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 }) =>\n      active ? `background: ${theme.colors.primary.backgroundHover};` : null}\n  }\n`\n\nconst StyledUnpinIcon = StyledPinIconOutline.withComponent(UnpinIcon)\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(DragIcon)`\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  &: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(OpenInNewIcon)``\n\nconst WrapText = styled(Text)`\n  overflow-wrap: anywhere;\n  overflow: hidden;\n  display: -webkit-box;\n  -webkit-box-orient: vertical;\n  -webkit-line-clamp: 2;\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 }) => 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\"][data-animation-type=\"complex\"] {\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\"][data-animation-type=\"complex\"] {\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 StackIcon = styled(Stack)`\n  padding-top: ${({ theme }) => theme.space['0.5']};\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?: PascalToCamelCaseWithoutSuffix<\n    keyof typeof CategoryIcon,\n    'CategoryIcon'\n  >\n  categoryIconVariant?: ComponentProps<\n    (typeof CategoryIcon)['BaremetalCategoryIcon']\n  >['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?: HTMLAnchorElement['href']\n  target?: HTMLAnchorElement['target']\n  rel?: HTMLAnchorElement['rel']\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  onToggle?: (toggle: boolean) => void\n  onClickPinUnpin?: (parameters: PinUnPinType) => 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 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  'data-testid'?: string\n}\n\nconst onDragStopTrigger = (event: DragEvent<HTMLDivElement>) => {\n  // eslint-disable-next-line no-param-reassign\n  event.currentTarget.style.opacity = '1'\n}\n\nexport const Item = memo(\n  ({\n    children,\n    categoryIcon,\n    categoryIconVariant,\n    label,\n    subLabel,\n    badgeText,\n    badgeSentiment,\n    href,\n    target,\n    rel,\n    onToggle,\n    onClickPinUnpin,\n    toggle,\n    active,\n    noPinButton,\n    type = 'default',\n    as,\n    disabled,\n    noExpand = false,\n    index,\n    id,\n    'data-testid': dataTestId,\n  }: ItemProps) => {\n    const context = useNavigation()\n    if (!context) {\n      throw new Error(\n        'Navigation.Item can only be used inside a NavigationProvider.',\n      )\n    }\n\n    const itemProvider = useContext(ItemContext)\n    const hasParents = !!itemProvider\n\n    const {\n      expanded,\n      locales,\n      pinnedFeature,\n      pinItem,\n      unpinItem,\n      pinnedItems,\n      pinLimit,\n      animation,\n      registerItem,\n      shouldAnimate,\n      animationType,\n    } = context\n\n    useEffect(\n      () => {\n        if (type !== 'pinnedGroup' && pinnedFeature) {\n          registerItem({ [id]: { label, active, onToggle, onClickPinUnpin } })\n        }\n      },\n      // eslint-disable-next-line react-hooks/exhaustive-deps\n      [active, id, label, registerItem],\n    )\n\n    const [internalExpanded, onToggleExpand] = useReducer(\n      prevState => !prevState,\n      Boolean(toggle),\n    )\n\n    const triggerToggle = useCallback(() => {\n      onToggleExpand()\n      onToggle?.(internalExpanded)\n    }, [internalExpanded, onToggle])\n\n    const PaddedStack =\n      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 = useMemo(\n      () => StyledContainer.withComponent(containerTag),\n      [containerTag],\n    )\n\n    const CategoryIconUsed = categoryIcon\n      ? CategoryIcon[\n          `${\n            categoryIcon.charAt(0).toUpperCase() + categoryIcon.slice(1)\n          }CategoryIcon` as keyof typeof CategoryIcon\n        ]\n      : null\n\n    const ArrowIcon = useMemo(\n      () => (internalExpanded ? ArrowDownIcon : ArrowRightIcon),\n      [internalExpanded],\n    )\n\n    const PinUnpinIcon = useMemo(\n      () => (isItemPinned ? StyledUnpinIcon : StyledPinIconOutline),\n      [isItemPinned],\n    )\n\n    const ariaExpanded = useMemo(() => {\n      if (hasHrefAndNoChildren && internalExpanded) {\n        return true\n      }\n\n      if (hasHrefAndNoChildren && !internalExpanded) {\n        return false\n      }\n\n      return undefined\n    }, [hasHrefAndNoChildren, internalExpanded])\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 onDragStart = useCallback(\n      (event: DragEvent<HTMLDivElement>) => {\n        if (expanded) {\n          event.dataTransfer.setData(\n            'text/plain',\n            JSON.stringify({ label, index }),\n          )\n          // eslint-disable-next-line no-param-reassign\n          event.currentTarget.style.opacity = '0.5'\n        }\n\n        return undefined\n      },\n      [expanded, index, label],\n    )\n\n    const onDragEnd = useCallback(\n      (event: DragEvent<HTMLDivElement>) =>\n        expanded ? onDragStopTrigger(event) : undefined,\n      [expanded],\n    )\n\n    // This content is when the navigation is expanded\n    if (expanded || (!expanded && animation === 'expand')) {\n      return (\n        <>\n          <Container\n            gap={1}\n            direction=\"row\"\n            alignItems={categoryIcon ? 'flex-start' : 'center'}\n            justifyContent=\"space-between\"\n            data-has-sub-label={!!subLabel}\n            onClick={triggerToggle}\n            aria-expanded={ariaExpanded}\n            href={href}\n            target={target}\n            rel={rel}\n            data-is-pinnable={shouldShowPinnedButton}\n            data-is-active={active}\n            data-animation={shouldAnimate ? animation : undefined}\n            data-animation-type={animationType}\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={onDragStart}\n            onDragEnd={onDragEnd}\n            id={id}\n            data-testid={dataTestId}\n          >\n            <Stack\n              direction=\"row\"\n              gap={1}\n              alignItems={categoryIcon ? 'flex-start' : 'center'}\n              justifyContent=\"center\"\n            >\n              {CategoryIconUsed ? (\n                <ContainerCategoryIcon\n                  alignItems=\"center\"\n                  justifyContent=\"center\"\n                >\n                  <CategoryIconUsed\n                    variant={active ? 'primary' : categoryIconVariant}\n                    disabled={disabled}\n                  />\n                </ContainerCategoryIcon>\n              ) : null}\n              {type === 'pinned' && expanded ? (\n                <GrabIcon\n                  sentiment=\"neutral\"\n                  prominence=\"weak\"\n                  size=\"small\"\n                  disabled={disabled}\n                />\n              ) : null}\n              <Stack>\n                {!animation ? (\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                    data-animation={animation}\n                    disabled={disabled}\n                    whiteSpace=\"pre-wrap\"\n                  >\n                    {label}\n                  </WrapText>\n                ) : null}\n                {subLabel && !animation ? (\n                  <WrapText\n                    as=\"span\"\n                    variant=\"caption\"\n                    sentiment=\"neutral\"\n                    prominence=\"weak\"\n                    data-animation={animation}\n                    disabled={disabled}\n                    whiteSpace=\"pre-wrap\"\n                  >\n                    {subLabel}\n                  </WrapText>\n                ) : null}\n              </Stack>\n            </Stack>\n            <Stack\n              direction=\"row\"\n              alignItems=\"center\"\n              gap={href ? 1 : undefined}\n            >\n              {badgeText || hasPinnedFeatureAndNoChildren ? (\n                <>\n                  {badgeText && !animation ? (\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                          aria-label={isItemPinned ? 'unpin' : 'pin'}\n                          size=\"xsmall\"\n                          variant=\"ghost\"\n                          sentiment={active ? 'primary' : 'neutral'}\n                          onClick={(event: MouseEvent<HTMLDivElement>) => {\n                            if (pinnedItems.length < pinLimit || isItemPinned) {\n                              event.preventDefault()\n                              event.stopPropagation() // This is to avoid click spread to the parent and change the routing\n                              let newValue: string[] | undefined\n                              if (isItemPinned) {\n                                newValue = unpinItem(id)\n                              } else {\n                                newValue = pinItem(id)\n                              }\n\n                              onClickPinUnpin?.({\n                                state: isItemPinned ? 'unpin' : 'pin',\n                                id,\n                                totalPinned: newValue,\n                              })\n                            }\n                          }}\n                          disabled={isItemPinned ? false : isPinDisabled}\n                        >\n                          <PinUnpinIcon\n                            size=\"medium\"\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 && target === '_blank' && !animation ? (\n                <AnimatedIcon\n                  sentiment=\"neutral\"\n                  prominence=\"default\"\n                  disabled={disabled}\n                />\n              ) : null}\n              {children ? (\n                <StackIcon gap={1} direction=\"row\" alignItems=\"center\">\n                  {!animation && !noExpand ? (\n                    <ArrowIcon sentiment=\"neutral\" prominence=\"weak\" />\n                  ) : null}\n                </StackIcon>\n              ) : null}\n            </Stack>\n          </Container>\n          {children ? (\n            <>\n              {!noExpand ? (\n                <ItemProvider>\n                  <Expandable opened={internalExpanded} animationDuration={0}>\n                    <PaddedStack width={animation ? '100%' : undefined}>\n                      {children}\n                    </PaddedStack>\n                  </Expandable>\n                </ItemProvider>\n              ) : (\n                <ItemProvider>\n                  <PaddedStack width={animation ? '100%' : undefined}>\n                    {children}\n                  </PaddedStack>\n                </ItemProvider>\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                  aria-label={label}\n                >\n                  {CategoryIconUsed ? (\n                    <Stack\n                      direction=\"row\"\n                      gap={1}\n                      alignItems=\"center\"\n                      justifyContent=\"center\"\n                    >\n                      <CategoryIconUsed\n                        variant={active ? 'primary' : categoryIconVariant}\n                      />\n                    </Stack>\n                  ) : null}\n                </Button>\n              }\n              placement=\"right\"\n            >\n              <ItemProvider>{children}</ItemProvider>\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                aria-label={label}\n              >\n                <Stack\n                  direction=\"row\"\n                  gap={1}\n                  alignItems=\"center\"\n                  justifyContent=\"center\"\n                >\n                  {CategoryIconUsed ? (\n                    <CategoryIconUsed\n                      variant={active ? 'primary' : categoryIconVariant}\n                    />\n                  ) : (\n                    <ConsoleCategoryIcon\n                      variant={active ? 'primary' : categoryIconVariant}\n                    />\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          target={target}\n          rel={rel}\n          borderless\n          active={active}\n          disabled={disabled}\n          sentiment={active ? 'primary' : 'neutral'}\n          isPinnable={shouldShowPinnedButton}\n          onClick={() => onToggle?.(!!active)}\n        >\n          <Stack\n            gap={1}\n            direction=\"row\"\n            alignItems=\"center\"\n            justifyContent=\"space-between\"\n            flex={1}\n            width=\"100%\"\n          >\n            {!animation ? (\n              <WrapText as=\"span\" variant=\"bodySmall\" whiteSpace=\"pre-wrap\">\n                {label}\n              </WrapText>\n            ) : null}\n            <Stack direction=\"row\">\n              {badgeText && !animation ? (\n                <StyledBadge\n                  sentiment={badgeSentiment}\n                  size=\"small\"\n                  prominence=\"strong\"\n                  disabled={disabled}\n                >\n                  {badgeText}\n                </StyledBadge>\n              ) : null}\n              {hasHrefAndNoChildren && target === '_blank' ? (\n                <AnimatedIcon\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                      aria-label={isItemPinned ? 'unpin' : 'pin'}\n                      variant=\"ghost\"\n                      sentiment={active ? 'primary' : 'neutral'}\n                      onClick={(event: MouseEvent<HTMLDivElement>) => {\n                        if (pinnedItems.length < pinLimit || isItemPinned) {\n                          event.preventDefault()\n                          event.stopPropagation() // This is to avoid click spread to the parent and change the routing\n\n                          let newValue: string[] | undefined\n                          if (isItemPinned) {\n                            newValue = unpinItem(id)\n                          } else {\n                            newValue = pinItem(id)\n                          }\n                          onClickPinUnpin?.({\n                            state: isItemPinned ? 'unpin' : 'pin',\n                            id,\n                            totalPinned: newValue,\n                          })\n                        }\n                      }}\n                      disabled={isItemPinned ? false : isPinDisabled}\n                    >\n                      <PinUnpinIcon\n                        size=\"medium\"\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={target}\n              rel={rel}\n            >\n              <AnimatedIcon sentiment=\"neutral\" prominence=\"weak\" />\n            </Container>\n          </MenuStack>\n        </Tooltip>\n      )\n    }\n\n    return null\n  },\n)\n"]} */",
166
166
  toString: _EMOTION_STRINGIFIED_CSS_ERROR__
167
167
  });
168
168
  const StyledStack = /* @__PURE__ */ _styled__default.default(ui.Stack, process.env.NODE_ENV === "production" ? {
@@ -175,7 +175,7 @@ const StyledStack = /* @__PURE__ */ _styled__default.default(ui.Stack, process.e
175
175
  styles: "padding-left:28px"
176
176
  } : {
177
177
  name: "13feash",
178
- styles: "padding-left:28px/*# 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":"AA8IiC","file":"/home/runner/work/ultraviolet/ultraviolet/packages/plus/src/components/Navigation/components/Item.tsx","sourcesContent":["'use client'\n\nimport { css } from '@emotion/react'\nimport styled from '@emotion/styled'\nimport {\n  ArrowDownIcon,\n  ArrowRightIcon,\n  DragIcon,\n  OpenInNewIcon,\n  PinOutlineIcon,\n  UnpinIcon,\n} from '@ultraviolet/icons'\nimport * as CategoryIcon from '@ultraviolet/icons/category'\nimport { ConsoleCategoryIcon } from '@ultraviolet/icons/category'\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  isValidElement,\n  memo,\n  useCallback,\n  useContext,\n  useEffect,\n  useMemo,\n  useReducer,\n} from 'react'\nimport type { PascalToCamelCaseWithoutSuffix } from '../../../types'\nimport { useNavigation } from '../NavigationProvider'\nimport { ANIMATION_DURATION, shrinkHeight } from '../constants'\nimport type { PinUnPinType } from '../types'\nimport { ItemContext, ItemProvider } from './ItemProvider'\n\nconst RelativeDiv = styled.div`\n  position: relative;\n`\n\nconst StyledPinIconOutline = styled(PinOutlineIcon, {\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 }) =>\n      active ? `background: ${theme.colors.primary.backgroundHover};` : null}\n  }\n`\n\nconst StyledUnpinIcon = StyledPinIconOutline.withComponent(UnpinIcon)\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(DragIcon)`\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  &: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(OpenInNewIcon)``\n\nconst WrapText = styled(Text)`\n  overflow-wrap: anywhere;\n  overflow: hidden;\n  display: -webkit-box;\n  -webkit-box-orient: vertical;\n  -webkit-line-clamp: 2;\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 }) => 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\"][data-animation-type=\"complex\"] {\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\"][data-animation-type=\"complex\"] {\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 StackIcon = styled(Stack)`\n  padding-top: ${({ theme }) => theme.space['0.5']};\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?: PascalToCamelCaseWithoutSuffix<\n    keyof typeof CategoryIcon,\n    'CategoryIcon'\n  >\n  categoryIconVariant?: ComponentProps<\n    (typeof CategoryIcon)['BaremetalCategoryIcon']\n  >['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?: HTMLAnchorElement['href']\n  target?: HTMLAnchorElement['target']\n  rel?: HTMLAnchorElement['rel']\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  onToggle?: (toggle: boolean) => void\n  onClickPinUnpin?: (parameters: PinUnPinType) => 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 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  'data-testid'?: string\n}\n\nconst onDragStopTrigger = (event: DragEvent<HTMLDivElement>) => {\n  // eslint-disable-next-line no-param-reassign\n  event.currentTarget.style.opacity = '1'\n}\n\nexport const Item = memo(\n  ({\n    children,\n    categoryIcon,\n    categoryIconVariant,\n    label,\n    subLabel,\n    badgeText,\n    badgeSentiment,\n    href,\n    target,\n    rel,\n    onToggle,\n    onClickPinUnpin,\n    toggle,\n    active,\n    noPinButton,\n    type = 'default',\n    as,\n    disabled,\n    noExpand = false,\n    index,\n    id,\n    'data-testid': dataTestId,\n  }: ItemProps) => {\n    const context = useNavigation()\n    if (!context) {\n      throw new Error(\n        'Navigation.Item can only be used inside a NavigationProvider.',\n      )\n    }\n\n    const itemProvider = useContext(ItemContext)\n    const hasParents = !!itemProvider\n\n    const {\n      expanded,\n      locales,\n      pinnedFeature,\n      pinItem,\n      unpinItem,\n      pinnedItems,\n      pinLimit,\n      animation,\n      registerItem,\n      shouldAnimate,\n      animationType,\n    } = context\n\n    useEffect(\n      () => {\n        if (type !== 'pinnedGroup') {\n          registerItem({ [id]: { label, active, onToggle, onClickPinUnpin } })\n        }\n      },\n      // eslint-disable-next-line react-hooks/exhaustive-deps\n      [active, id, label, registerItem],\n    )\n\n    const [internalExpanded, onToggleExpand] = useReducer(\n      prevState => !prevState,\n      Boolean(toggle),\n    )\n\n    const triggerToggle = useCallback(() => {\n      onToggleExpand()\n      onToggle?.(internalExpanded)\n    }, [internalExpanded, onToggle])\n\n    const PaddedStack =\n      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 = useMemo(\n      () => StyledContainer.withComponent(containerTag),\n      [containerTag],\n    )\n\n    const CategoryIconUsed = categoryIcon\n      ? CategoryIcon[\n          `${\n            categoryIcon.charAt(0).toUpperCase() + categoryIcon.slice(1)\n          }CategoryIcon` as keyof typeof CategoryIcon\n        ]\n      : null\n\n    const ArrowIcon = useMemo(\n      () => (internalExpanded ? ArrowDownIcon : ArrowRightIcon),\n      [internalExpanded],\n    )\n\n    const PinUnpinIcon = useMemo(\n      () => (isItemPinned ? StyledUnpinIcon : StyledPinIconOutline),\n      [isItemPinned],\n    )\n\n    const ariaExpanded = useMemo(() => {\n      if (hasHrefAndNoChildren && internalExpanded) {\n        return true\n      }\n\n      if (hasHrefAndNoChildren && !internalExpanded) {\n        return false\n      }\n\n      return undefined\n    }, [hasHrefAndNoChildren, internalExpanded])\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 onDragStart = useCallback(\n      (event: DragEvent<HTMLDivElement>) => {\n        if (expanded) {\n          event.dataTransfer.setData(\n            'text/plain',\n            JSON.stringify({ label, index }),\n          )\n          // eslint-disable-next-line no-param-reassign\n          event.currentTarget.style.opacity = '0.5'\n        }\n\n        return undefined\n      },\n      [expanded, index, label],\n    )\n\n    const onDragEnd = useCallback(\n      (event: DragEvent<HTMLDivElement>) =>\n        expanded ? onDragStopTrigger(event) : undefined,\n      [expanded],\n    )\n\n    // This content is when the navigation is expanded\n    if (expanded || (!expanded && animation === 'expand')) {\n      return (\n        <>\n          <Container\n            gap={1}\n            direction=\"row\"\n            alignItems={categoryIcon ? 'flex-start' : 'center'}\n            justifyContent=\"space-between\"\n            data-has-sub-label={!!subLabel}\n            onClick={triggerToggle}\n            aria-expanded={ariaExpanded}\n            href={href}\n            target={target}\n            rel={rel}\n            data-is-pinnable={shouldShowPinnedButton}\n            data-is-active={active}\n            data-animation={shouldAnimate ? animation : undefined}\n            data-animation-type={animationType}\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={onDragStart}\n            onDragEnd={onDragEnd}\n            id={id}\n            data-testid={dataTestId}\n          >\n            <Stack\n              direction=\"row\"\n              gap={1}\n              alignItems={categoryIcon ? 'flex-start' : 'center'}\n              justifyContent=\"center\"\n            >\n              {CategoryIconUsed ? (\n                <ContainerCategoryIcon\n                  alignItems=\"center\"\n                  justifyContent=\"center\"\n                >\n                  <CategoryIconUsed\n                    variant={active ? 'primary' : categoryIconVariant}\n                    disabled={disabled}\n                  />\n                </ContainerCategoryIcon>\n              ) : null}\n              {type === 'pinned' && expanded ? (\n                <GrabIcon\n                  sentiment=\"neutral\"\n                  prominence=\"weak\"\n                  size=\"small\"\n                  disabled={disabled}\n                />\n              ) : null}\n              <Stack>\n                {!animation ? (\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                    data-animation={animation}\n                    disabled={disabled}\n                    whiteSpace=\"pre-wrap\"\n                  >\n                    {label}\n                  </WrapText>\n                ) : null}\n                {subLabel && !animation ? (\n                  <WrapText\n                    as=\"span\"\n                    variant=\"caption\"\n                    sentiment=\"neutral\"\n                    prominence=\"weak\"\n                    data-animation={animation}\n                    disabled={disabled}\n                    whiteSpace=\"pre-wrap\"\n                  >\n                    {subLabel}\n                  </WrapText>\n                ) : null}\n              </Stack>\n            </Stack>\n            <Stack\n              direction=\"row\"\n              alignItems=\"center\"\n              gap={href ? 1 : undefined}\n            >\n              {badgeText || hasPinnedFeatureAndNoChildren ? (\n                <>\n                  {badgeText && !animation ? (\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                          aria-label={isItemPinned ? 'unpin' : 'pin'}\n                          size=\"xsmall\"\n                          variant=\"ghost\"\n                          sentiment={active ? 'primary' : 'neutral'}\n                          onClick={(event: MouseEvent<HTMLDivElement>) => {\n                            if (pinnedItems.length < pinLimit || isItemPinned) {\n                              event.preventDefault()\n                              event.stopPropagation() // This is to avoid click spread to the parent and change the routing\n                              let newValue: string[] | undefined\n                              if (isItemPinned) {\n                                newValue = unpinItem(id)\n                              } else {\n                                newValue = pinItem(id)\n                              }\n\n                              onClickPinUnpin?.({\n                                state: isItemPinned ? 'unpin' : 'pin',\n                                id,\n                                totalPinned: newValue,\n                              })\n                            }\n                          }}\n                          disabled={isItemPinned ? false : isPinDisabled}\n                        >\n                          <PinUnpinIcon\n                            size=\"medium\"\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 && target === '_blank' && !animation ? (\n                <AnimatedIcon\n                  sentiment=\"neutral\"\n                  prominence=\"default\"\n                  disabled={disabled}\n                />\n              ) : null}\n              {children ? (\n                <StackIcon gap={1} direction=\"row\" alignItems=\"center\">\n                  {!animation && !noExpand ? (\n                    <ArrowIcon sentiment=\"neutral\" prominence=\"weak\" />\n                  ) : null}\n                </StackIcon>\n              ) : null}\n            </Stack>\n          </Container>\n          {children ? (\n            <>\n              {!noExpand ? (\n                <ItemProvider>\n                  <Expandable opened={internalExpanded} animationDuration={0}>\n                    <PaddedStack width={animation ? '100%' : undefined}>\n                      {children}\n                    </PaddedStack>\n                  </Expandable>\n                </ItemProvider>\n              ) : (\n                <ItemProvider>\n                  <PaddedStack width={animation ? '100%' : undefined}>\n                    {children}\n                  </PaddedStack>\n                </ItemProvider>\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                  aria-label={label}\n                >\n                  {CategoryIconUsed ? (\n                    <Stack\n                      direction=\"row\"\n                      gap={1}\n                      alignItems=\"center\"\n                      justifyContent=\"center\"\n                    >\n                      <CategoryIconUsed\n                        variant={active ? 'primary' : categoryIconVariant}\n                      />\n                    </Stack>\n                  ) : null}\n                </Button>\n              }\n              placement=\"right\"\n            >\n              <ItemProvider>{children}</ItemProvider>\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                aria-label={label}\n              >\n                <Stack\n                  direction=\"row\"\n                  gap={1}\n                  alignItems=\"center\"\n                  justifyContent=\"center\"\n                >\n                  {CategoryIconUsed ? (\n                    <CategoryIconUsed\n                      variant={active ? 'primary' : categoryIconVariant}\n                    />\n                  ) : (\n                    <ConsoleCategoryIcon\n                      variant={active ? 'primary' : categoryIconVariant}\n                    />\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          target={target}\n          rel={rel}\n          borderless\n          active={active}\n          disabled={disabled}\n          sentiment={active ? 'primary' : 'neutral'}\n          isPinnable={shouldShowPinnedButton}\n          onClick={() => onToggle?.(!!active)}\n        >\n          <Stack\n            gap={1}\n            direction=\"row\"\n            alignItems=\"center\"\n            justifyContent=\"space-between\"\n            flex={1}\n            width=\"100%\"\n          >\n            {!animation ? (\n              <WrapText as=\"span\" variant=\"bodySmall\" whiteSpace=\"pre-wrap\">\n                {label}\n              </WrapText>\n            ) : null}\n            <Stack direction=\"row\">\n              {badgeText && !animation ? (\n                <StyledBadge\n                  sentiment={badgeSentiment}\n                  size=\"small\"\n                  prominence=\"strong\"\n                  disabled={disabled}\n                >\n                  {badgeText}\n                </StyledBadge>\n              ) : null}\n              {hasHrefAndNoChildren && target === '_blank' ? (\n                <AnimatedIcon\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                      aria-label={isItemPinned ? 'unpin' : 'pin'}\n                      variant=\"ghost\"\n                      sentiment={active ? 'primary' : 'neutral'}\n                      onClick={(event: MouseEvent<HTMLDivElement>) => {\n                        if (pinnedItems.length < pinLimit || isItemPinned) {\n                          event.preventDefault()\n                          event.stopPropagation() // This is to avoid click spread to the parent and change the routing\n\n                          let newValue: string[] | undefined\n                          if (isItemPinned) {\n                            newValue = unpinItem(id)\n                          } else {\n                            newValue = pinItem(id)\n                          }\n                          onClickPinUnpin?.({\n                            state: isItemPinned ? 'unpin' : 'pin',\n                            id,\n                            totalPinned: newValue,\n                          })\n                        }\n                      }}\n                      disabled={isItemPinned ? false : isPinDisabled}\n                    >\n                      <PinUnpinIcon\n                        size=\"medium\"\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={target}\n              rel={rel}\n            >\n              <AnimatedIcon sentiment=\"neutral\" prominence=\"weak\" />\n            </Container>\n          </MenuStack>\n        </Tooltip>\n      )\n    }\n\n    return null\n  },\n)\n"]} */",
178
+ styles: "padding-left:28px/*# 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":"AA8IiC","file":"/home/runner/work/ultraviolet/ultraviolet/packages/plus/src/components/Navigation/components/Item.tsx","sourcesContent":["'use client'\n\nimport { css } from '@emotion/react'\nimport styled from '@emotion/styled'\nimport {\n  ArrowDownIcon,\n  ArrowRightIcon,\n  DragIcon,\n  OpenInNewIcon,\n  PinOutlineIcon,\n  UnpinIcon,\n} from '@ultraviolet/icons'\nimport * as CategoryIcon from '@ultraviolet/icons/category'\nimport { ConsoleCategoryIcon } from '@ultraviolet/icons/category'\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  isValidElement,\n  memo,\n  useCallback,\n  useContext,\n  useEffect,\n  useMemo,\n  useReducer,\n} from 'react'\nimport type { PascalToCamelCaseWithoutSuffix } from '../../../types'\nimport { useNavigation } from '../NavigationProvider'\nimport { ANIMATION_DURATION, shrinkHeight } from '../constants'\nimport type { PinUnPinType } from '../types'\nimport { ItemContext, ItemProvider } from './ItemProvider'\n\nconst RelativeDiv = styled.div`\n  position: relative;\n`\n\nconst StyledPinIconOutline = styled(PinOutlineIcon, {\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 }) =>\n      active ? `background: ${theme.colors.primary.backgroundHover};` : null}\n  }\n`\n\nconst StyledUnpinIcon = StyledPinIconOutline.withComponent(UnpinIcon)\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(DragIcon)`\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  &: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(OpenInNewIcon)``\n\nconst WrapText = styled(Text)`\n  overflow-wrap: anywhere;\n  overflow: hidden;\n  display: -webkit-box;\n  -webkit-box-orient: vertical;\n  -webkit-line-clamp: 2;\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 }) => 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\"][data-animation-type=\"complex\"] {\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\"][data-animation-type=\"complex\"] {\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 StackIcon = styled(Stack)`\n  padding-top: ${({ theme }) => theme.space['0.5']};\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?: PascalToCamelCaseWithoutSuffix<\n    keyof typeof CategoryIcon,\n    'CategoryIcon'\n  >\n  categoryIconVariant?: ComponentProps<\n    (typeof CategoryIcon)['BaremetalCategoryIcon']\n  >['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?: HTMLAnchorElement['href']\n  target?: HTMLAnchorElement['target']\n  rel?: HTMLAnchorElement['rel']\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  onToggle?: (toggle: boolean) => void\n  onClickPinUnpin?: (parameters: PinUnPinType) => 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 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  'data-testid'?: string\n}\n\nconst onDragStopTrigger = (event: DragEvent<HTMLDivElement>) => {\n  // eslint-disable-next-line no-param-reassign\n  event.currentTarget.style.opacity = '1'\n}\n\nexport const Item = memo(\n  ({\n    children,\n    categoryIcon,\n    categoryIconVariant,\n    label,\n    subLabel,\n    badgeText,\n    badgeSentiment,\n    href,\n    target,\n    rel,\n    onToggle,\n    onClickPinUnpin,\n    toggle,\n    active,\n    noPinButton,\n    type = 'default',\n    as,\n    disabled,\n    noExpand = false,\n    index,\n    id,\n    'data-testid': dataTestId,\n  }: ItemProps) => {\n    const context = useNavigation()\n    if (!context) {\n      throw new Error(\n        'Navigation.Item can only be used inside a NavigationProvider.',\n      )\n    }\n\n    const itemProvider = useContext(ItemContext)\n    const hasParents = !!itemProvider\n\n    const {\n      expanded,\n      locales,\n      pinnedFeature,\n      pinItem,\n      unpinItem,\n      pinnedItems,\n      pinLimit,\n      animation,\n      registerItem,\n      shouldAnimate,\n      animationType,\n    } = context\n\n    useEffect(\n      () => {\n        if (type !== 'pinnedGroup' && pinnedFeature) {\n          registerItem({ [id]: { label, active, onToggle, onClickPinUnpin } })\n        }\n      },\n      // eslint-disable-next-line react-hooks/exhaustive-deps\n      [active, id, label, registerItem],\n    )\n\n    const [internalExpanded, onToggleExpand] = useReducer(\n      prevState => !prevState,\n      Boolean(toggle),\n    )\n\n    const triggerToggle = useCallback(() => {\n      onToggleExpand()\n      onToggle?.(internalExpanded)\n    }, [internalExpanded, onToggle])\n\n    const PaddedStack =\n      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 = useMemo(\n      () => StyledContainer.withComponent(containerTag),\n      [containerTag],\n    )\n\n    const CategoryIconUsed = categoryIcon\n      ? CategoryIcon[\n          `${\n            categoryIcon.charAt(0).toUpperCase() + categoryIcon.slice(1)\n          }CategoryIcon` as keyof typeof CategoryIcon\n        ]\n      : null\n\n    const ArrowIcon = useMemo(\n      () => (internalExpanded ? ArrowDownIcon : ArrowRightIcon),\n      [internalExpanded],\n    )\n\n    const PinUnpinIcon = useMemo(\n      () => (isItemPinned ? StyledUnpinIcon : StyledPinIconOutline),\n      [isItemPinned],\n    )\n\n    const ariaExpanded = useMemo(() => {\n      if (hasHrefAndNoChildren && internalExpanded) {\n        return true\n      }\n\n      if (hasHrefAndNoChildren && !internalExpanded) {\n        return false\n      }\n\n      return undefined\n    }, [hasHrefAndNoChildren, internalExpanded])\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 onDragStart = useCallback(\n      (event: DragEvent<HTMLDivElement>) => {\n        if (expanded) {\n          event.dataTransfer.setData(\n            'text/plain',\n            JSON.stringify({ label, index }),\n          )\n          // eslint-disable-next-line no-param-reassign\n          event.currentTarget.style.opacity = '0.5'\n        }\n\n        return undefined\n      },\n      [expanded, index, label],\n    )\n\n    const onDragEnd = useCallback(\n      (event: DragEvent<HTMLDivElement>) =>\n        expanded ? onDragStopTrigger(event) : undefined,\n      [expanded],\n    )\n\n    // This content is when the navigation is expanded\n    if (expanded || (!expanded && animation === 'expand')) {\n      return (\n        <>\n          <Container\n            gap={1}\n            direction=\"row\"\n            alignItems={categoryIcon ? 'flex-start' : 'center'}\n            justifyContent=\"space-between\"\n            data-has-sub-label={!!subLabel}\n            onClick={triggerToggle}\n            aria-expanded={ariaExpanded}\n            href={href}\n            target={target}\n            rel={rel}\n            data-is-pinnable={shouldShowPinnedButton}\n            data-is-active={active}\n            data-animation={shouldAnimate ? animation : undefined}\n            data-animation-type={animationType}\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={onDragStart}\n            onDragEnd={onDragEnd}\n            id={id}\n            data-testid={dataTestId}\n          >\n            <Stack\n              direction=\"row\"\n              gap={1}\n              alignItems={categoryIcon ? 'flex-start' : 'center'}\n              justifyContent=\"center\"\n            >\n              {CategoryIconUsed ? (\n                <ContainerCategoryIcon\n                  alignItems=\"center\"\n                  justifyContent=\"center\"\n                >\n                  <CategoryIconUsed\n                    variant={active ? 'primary' : categoryIconVariant}\n                    disabled={disabled}\n                  />\n                </ContainerCategoryIcon>\n              ) : null}\n              {type === 'pinned' && expanded ? (\n                <GrabIcon\n                  sentiment=\"neutral\"\n                  prominence=\"weak\"\n                  size=\"small\"\n                  disabled={disabled}\n                />\n              ) : null}\n              <Stack>\n                {!animation ? (\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                    data-animation={animation}\n                    disabled={disabled}\n                    whiteSpace=\"pre-wrap\"\n                  >\n                    {label}\n                  </WrapText>\n                ) : null}\n                {subLabel && !animation ? (\n                  <WrapText\n                    as=\"span\"\n                    variant=\"caption\"\n                    sentiment=\"neutral\"\n                    prominence=\"weak\"\n                    data-animation={animation}\n                    disabled={disabled}\n                    whiteSpace=\"pre-wrap\"\n                  >\n                    {subLabel}\n                  </WrapText>\n                ) : null}\n              </Stack>\n            </Stack>\n            <Stack\n              direction=\"row\"\n              alignItems=\"center\"\n              gap={href ? 1 : undefined}\n            >\n              {badgeText || hasPinnedFeatureAndNoChildren ? (\n                <>\n                  {badgeText && !animation ? (\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                          aria-label={isItemPinned ? 'unpin' : 'pin'}\n                          size=\"xsmall\"\n                          variant=\"ghost\"\n                          sentiment={active ? 'primary' : 'neutral'}\n                          onClick={(event: MouseEvent<HTMLDivElement>) => {\n                            if (pinnedItems.length < pinLimit || isItemPinned) {\n                              event.preventDefault()\n                              event.stopPropagation() // This is to avoid click spread to the parent and change the routing\n                              let newValue: string[] | undefined\n                              if (isItemPinned) {\n                                newValue = unpinItem(id)\n                              } else {\n                                newValue = pinItem(id)\n                              }\n\n                              onClickPinUnpin?.({\n                                state: isItemPinned ? 'unpin' : 'pin',\n                                id,\n                                totalPinned: newValue,\n                              })\n                            }\n                          }}\n                          disabled={isItemPinned ? false : isPinDisabled}\n                        >\n                          <PinUnpinIcon\n                            size=\"medium\"\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 && target === '_blank' && !animation ? (\n                <AnimatedIcon\n                  sentiment=\"neutral\"\n                  prominence=\"default\"\n                  disabled={disabled}\n                />\n              ) : null}\n              {children ? (\n                <StackIcon gap={1} direction=\"row\" alignItems=\"center\">\n                  {!animation && !noExpand ? (\n                    <ArrowIcon sentiment=\"neutral\" prominence=\"weak\" />\n                  ) : null}\n                </StackIcon>\n              ) : null}\n            </Stack>\n          </Container>\n          {children ? (\n            <>\n              {!noExpand ? (\n                <ItemProvider>\n                  <Expandable opened={internalExpanded} animationDuration={0}>\n                    <PaddedStack width={animation ? '100%' : undefined}>\n                      {children}\n                    </PaddedStack>\n                  </Expandable>\n                </ItemProvider>\n              ) : (\n                <ItemProvider>\n                  <PaddedStack width={animation ? '100%' : undefined}>\n                    {children}\n                  </PaddedStack>\n                </ItemProvider>\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                  aria-label={label}\n                >\n                  {CategoryIconUsed ? (\n                    <Stack\n                      direction=\"row\"\n                      gap={1}\n                      alignItems=\"center\"\n                      justifyContent=\"center\"\n                    >\n                      <CategoryIconUsed\n                        variant={active ? 'primary' : categoryIconVariant}\n                      />\n                    </Stack>\n                  ) : null}\n                </Button>\n              }\n              placement=\"right\"\n            >\n              <ItemProvider>{children}</ItemProvider>\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                aria-label={label}\n              >\n                <Stack\n                  direction=\"row\"\n                  gap={1}\n                  alignItems=\"center\"\n                  justifyContent=\"center\"\n                >\n                  {CategoryIconUsed ? (\n                    <CategoryIconUsed\n                      variant={active ? 'primary' : categoryIconVariant}\n                    />\n                  ) : (\n                    <ConsoleCategoryIcon\n                      variant={active ? 'primary' : categoryIconVariant}\n                    />\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          target={target}\n          rel={rel}\n          borderless\n          active={active}\n          disabled={disabled}\n          sentiment={active ? 'primary' : 'neutral'}\n          isPinnable={shouldShowPinnedButton}\n          onClick={() => onToggle?.(!!active)}\n        >\n          <Stack\n            gap={1}\n            direction=\"row\"\n            alignItems=\"center\"\n            justifyContent=\"space-between\"\n            flex={1}\n            width=\"100%\"\n          >\n            {!animation ? (\n              <WrapText as=\"span\" variant=\"bodySmall\" whiteSpace=\"pre-wrap\">\n                {label}\n              </WrapText>\n            ) : null}\n            <Stack direction=\"row\">\n              {badgeText && !animation ? (\n                <StyledBadge\n                  sentiment={badgeSentiment}\n                  size=\"small\"\n                  prominence=\"strong\"\n                  disabled={disabled}\n                >\n                  {badgeText}\n                </StyledBadge>\n              ) : null}\n              {hasHrefAndNoChildren && target === '_blank' ? (\n                <AnimatedIcon\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                      aria-label={isItemPinned ? 'unpin' : 'pin'}\n                      variant=\"ghost\"\n                      sentiment={active ? 'primary' : 'neutral'}\n                      onClick={(event: MouseEvent<HTMLDivElement>) => {\n                        if (pinnedItems.length < pinLimit || isItemPinned) {\n                          event.preventDefault()\n                          event.stopPropagation() // This is to avoid click spread to the parent and change the routing\n\n                          let newValue: string[] | undefined\n                          if (isItemPinned) {\n                            newValue = unpinItem(id)\n                          } else {\n                            newValue = pinItem(id)\n                          }\n                          onClickPinUnpin?.({\n                            state: isItemPinned ? 'unpin' : 'pin',\n                            id,\n                            totalPinned: newValue,\n                          })\n                        }\n                      }}\n                      disabled={isItemPinned ? false : isPinDisabled}\n                    >\n                      <PinUnpinIcon\n                        size=\"medium\"\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={target}\n              rel={rel}\n            >\n              <AnimatedIcon sentiment=\"neutral\" prominence=\"weak\" />\n            </Container>\n          </MenuStack>\n        </Tooltip>\n      )\n    }\n\n    return null\n  },\n)\n"]} */",
179
179
  toString: _EMOTION_STRINGIFIED_CSS_ERROR__
180
180
  });
181
181
  const StyledContainer = /* @__PURE__ */ _styled__default.default(ui.Stack, process.env.NODE_ENV === "production" ? {
@@ -207,7 +207,7 @@ const StyledContainer = /* @__PURE__ */ _styled__default.default(ui.Stack, proce
207
207
  theme
208
208
  }) => theme.colors.primary.backgroundHover, ";}}&[disabled]{cursor:not-allowed;background-color:unset;", WrapText, "{color:", ({
209
209
  theme
210
- }) => theme.colors.neutral.textWeakDisabled, ';}}&[data-animation="collapse"][data-animation-type="complex"]{animation:', constants.shrinkHeight, " ", constants.ANIMATION_DURATION, "ms ease-in-out;", WrapText, ",", AnimatedIcon, ",", StyledBadge, "{animation:", ui.fadeIn, " ", constants.ANIMATION_DURATION, 'ms ease-in-out reverse;}}&[data-animation="expand"][data-animation-type="complex"]{animation:', constants.shrinkHeight, " ", constants.ANIMATION_DURATION, "ms ease-in-out reverse;", WrapText, ",", AnimatedIcon, ",", StyledBadge, "{animation:", ui.fadeIn, " ", constants.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":"AAkJqC","file":"/home/runner/work/ultraviolet/ultraviolet/packages/plus/src/components/Navigation/components/Item.tsx","sourcesContent":["'use client'\n\nimport { css } from '@emotion/react'\nimport styled from '@emotion/styled'\nimport {\n  ArrowDownIcon,\n  ArrowRightIcon,\n  DragIcon,\n  OpenInNewIcon,\n  PinOutlineIcon,\n  UnpinIcon,\n} from '@ultraviolet/icons'\nimport * as CategoryIcon from '@ultraviolet/icons/category'\nimport { ConsoleCategoryIcon } from '@ultraviolet/icons/category'\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  isValidElement,\n  memo,\n  useCallback,\n  useContext,\n  useEffect,\n  useMemo,\n  useReducer,\n} from 'react'\nimport type { PascalToCamelCaseWithoutSuffix } from '../../../types'\nimport { useNavigation } from '../NavigationProvider'\nimport { ANIMATION_DURATION, shrinkHeight } from '../constants'\nimport type { PinUnPinType } from '../types'\nimport { ItemContext, ItemProvider } from './ItemProvider'\n\nconst RelativeDiv = styled.div`\n  position: relative;\n`\n\nconst StyledPinIconOutline = styled(PinOutlineIcon, {\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 }) =>\n      active ? `background: ${theme.colors.primary.backgroundHover};` : null}\n  }\n`\n\nconst StyledUnpinIcon = StyledPinIconOutline.withComponent(UnpinIcon)\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(DragIcon)`\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  &: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(OpenInNewIcon)``\n\nconst WrapText = styled(Text)`\n  overflow-wrap: anywhere;\n  overflow: hidden;\n  display: -webkit-box;\n  -webkit-box-orient: vertical;\n  -webkit-line-clamp: 2;\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 }) => 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\"][data-animation-type=\"complex\"] {\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\"][data-animation-type=\"complex\"] {\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 StackIcon = styled(Stack)`\n  padding-top: ${({ theme }) => theme.space['0.5']};\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?: PascalToCamelCaseWithoutSuffix<\n    keyof typeof CategoryIcon,\n    'CategoryIcon'\n  >\n  categoryIconVariant?: ComponentProps<\n    (typeof CategoryIcon)['BaremetalCategoryIcon']\n  >['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?: HTMLAnchorElement['href']\n  target?: HTMLAnchorElement['target']\n  rel?: HTMLAnchorElement['rel']\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  onToggle?: (toggle: boolean) => void\n  onClickPinUnpin?: (parameters: PinUnPinType) => 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 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  'data-testid'?: string\n}\n\nconst onDragStopTrigger = (event: DragEvent<HTMLDivElement>) => {\n  // eslint-disable-next-line no-param-reassign\n  event.currentTarget.style.opacity = '1'\n}\n\nexport const Item = memo(\n  ({\n    children,\n    categoryIcon,\n    categoryIconVariant,\n    label,\n    subLabel,\n    badgeText,\n    badgeSentiment,\n    href,\n    target,\n    rel,\n    onToggle,\n    onClickPinUnpin,\n    toggle,\n    active,\n    noPinButton,\n    type = 'default',\n    as,\n    disabled,\n    noExpand = false,\n    index,\n    id,\n    'data-testid': dataTestId,\n  }: ItemProps) => {\n    const context = useNavigation()\n    if (!context) {\n      throw new Error(\n        'Navigation.Item can only be used inside a NavigationProvider.',\n      )\n    }\n\n    const itemProvider = useContext(ItemContext)\n    const hasParents = !!itemProvider\n\n    const {\n      expanded,\n      locales,\n      pinnedFeature,\n      pinItem,\n      unpinItem,\n      pinnedItems,\n      pinLimit,\n      animation,\n      registerItem,\n      shouldAnimate,\n      animationType,\n    } = context\n\n    useEffect(\n      () => {\n        if (type !== 'pinnedGroup') {\n          registerItem({ [id]: { label, active, onToggle, onClickPinUnpin } })\n        }\n      },\n      // eslint-disable-next-line react-hooks/exhaustive-deps\n      [active, id, label, registerItem],\n    )\n\n    const [internalExpanded, onToggleExpand] = useReducer(\n      prevState => !prevState,\n      Boolean(toggle),\n    )\n\n    const triggerToggle = useCallback(() => {\n      onToggleExpand()\n      onToggle?.(internalExpanded)\n    }, [internalExpanded, onToggle])\n\n    const PaddedStack =\n      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 = useMemo(\n      () => StyledContainer.withComponent(containerTag),\n      [containerTag],\n    )\n\n    const CategoryIconUsed = categoryIcon\n      ? CategoryIcon[\n          `${\n            categoryIcon.charAt(0).toUpperCase() + categoryIcon.slice(1)\n          }CategoryIcon` as keyof typeof CategoryIcon\n        ]\n      : null\n\n    const ArrowIcon = useMemo(\n      () => (internalExpanded ? ArrowDownIcon : ArrowRightIcon),\n      [internalExpanded],\n    )\n\n    const PinUnpinIcon = useMemo(\n      () => (isItemPinned ? StyledUnpinIcon : StyledPinIconOutline),\n      [isItemPinned],\n    )\n\n    const ariaExpanded = useMemo(() => {\n      if (hasHrefAndNoChildren && internalExpanded) {\n        return true\n      }\n\n      if (hasHrefAndNoChildren && !internalExpanded) {\n        return false\n      }\n\n      return undefined\n    }, [hasHrefAndNoChildren, internalExpanded])\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 onDragStart = useCallback(\n      (event: DragEvent<HTMLDivElement>) => {\n        if (expanded) {\n          event.dataTransfer.setData(\n            'text/plain',\n            JSON.stringify({ label, index }),\n          )\n          // eslint-disable-next-line no-param-reassign\n          event.currentTarget.style.opacity = '0.5'\n        }\n\n        return undefined\n      },\n      [expanded, index, label],\n    )\n\n    const onDragEnd = useCallback(\n      (event: DragEvent<HTMLDivElement>) =>\n        expanded ? onDragStopTrigger(event) : undefined,\n      [expanded],\n    )\n\n    // This content is when the navigation is expanded\n    if (expanded || (!expanded && animation === 'expand')) {\n      return (\n        <>\n          <Container\n            gap={1}\n            direction=\"row\"\n            alignItems={categoryIcon ? 'flex-start' : 'center'}\n            justifyContent=\"space-between\"\n            data-has-sub-label={!!subLabel}\n            onClick={triggerToggle}\n            aria-expanded={ariaExpanded}\n            href={href}\n            target={target}\n            rel={rel}\n            data-is-pinnable={shouldShowPinnedButton}\n            data-is-active={active}\n            data-animation={shouldAnimate ? animation : undefined}\n            data-animation-type={animationType}\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={onDragStart}\n            onDragEnd={onDragEnd}\n            id={id}\n            data-testid={dataTestId}\n          >\n            <Stack\n              direction=\"row\"\n              gap={1}\n              alignItems={categoryIcon ? 'flex-start' : 'center'}\n              justifyContent=\"center\"\n            >\n              {CategoryIconUsed ? (\n                <ContainerCategoryIcon\n                  alignItems=\"center\"\n                  justifyContent=\"center\"\n                >\n                  <CategoryIconUsed\n                    variant={active ? 'primary' : categoryIconVariant}\n                    disabled={disabled}\n                  />\n                </ContainerCategoryIcon>\n              ) : null}\n              {type === 'pinned' && expanded ? (\n                <GrabIcon\n                  sentiment=\"neutral\"\n                  prominence=\"weak\"\n                  size=\"small\"\n                  disabled={disabled}\n                />\n              ) : null}\n              <Stack>\n                {!animation ? (\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                    data-animation={animation}\n                    disabled={disabled}\n                    whiteSpace=\"pre-wrap\"\n                  >\n                    {label}\n                  </WrapText>\n                ) : null}\n                {subLabel && !animation ? (\n                  <WrapText\n                    as=\"span\"\n                    variant=\"caption\"\n                    sentiment=\"neutral\"\n                    prominence=\"weak\"\n                    data-animation={animation}\n                    disabled={disabled}\n                    whiteSpace=\"pre-wrap\"\n                  >\n                    {subLabel}\n                  </WrapText>\n                ) : null}\n              </Stack>\n            </Stack>\n            <Stack\n              direction=\"row\"\n              alignItems=\"center\"\n              gap={href ? 1 : undefined}\n            >\n              {badgeText || hasPinnedFeatureAndNoChildren ? (\n                <>\n                  {badgeText && !animation ? (\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                          aria-label={isItemPinned ? 'unpin' : 'pin'}\n                          size=\"xsmall\"\n                          variant=\"ghost\"\n                          sentiment={active ? 'primary' : 'neutral'}\n                          onClick={(event: MouseEvent<HTMLDivElement>) => {\n                            if (pinnedItems.length < pinLimit || isItemPinned) {\n                              event.preventDefault()\n                              event.stopPropagation() // This is to avoid click spread to the parent and change the routing\n                              let newValue: string[] | undefined\n                              if (isItemPinned) {\n                                newValue = unpinItem(id)\n                              } else {\n                                newValue = pinItem(id)\n                              }\n\n                              onClickPinUnpin?.({\n                                state: isItemPinned ? 'unpin' : 'pin',\n                                id,\n                                totalPinned: newValue,\n                              })\n                            }\n                          }}\n                          disabled={isItemPinned ? false : isPinDisabled}\n                        >\n                          <PinUnpinIcon\n                            size=\"medium\"\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 && target === '_blank' && !animation ? (\n                <AnimatedIcon\n                  sentiment=\"neutral\"\n                  prominence=\"default\"\n                  disabled={disabled}\n                />\n              ) : null}\n              {children ? (\n                <StackIcon gap={1} direction=\"row\" alignItems=\"center\">\n                  {!animation && !noExpand ? (\n                    <ArrowIcon sentiment=\"neutral\" prominence=\"weak\" />\n                  ) : null}\n                </StackIcon>\n              ) : null}\n            </Stack>\n          </Container>\n          {children ? (\n            <>\n              {!noExpand ? (\n                <ItemProvider>\n                  <Expandable opened={internalExpanded} animationDuration={0}>\n                    <PaddedStack width={animation ? '100%' : undefined}>\n                      {children}\n                    </PaddedStack>\n                  </Expandable>\n                </ItemProvider>\n              ) : (\n                <ItemProvider>\n                  <PaddedStack width={animation ? '100%' : undefined}>\n                    {children}\n                  </PaddedStack>\n                </ItemProvider>\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                  aria-label={label}\n                >\n                  {CategoryIconUsed ? (\n                    <Stack\n                      direction=\"row\"\n                      gap={1}\n                      alignItems=\"center\"\n                      justifyContent=\"center\"\n                    >\n                      <CategoryIconUsed\n                        variant={active ? 'primary' : categoryIconVariant}\n                      />\n                    </Stack>\n                  ) : null}\n                </Button>\n              }\n              placement=\"right\"\n            >\n              <ItemProvider>{children}</ItemProvider>\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                aria-label={label}\n              >\n                <Stack\n                  direction=\"row\"\n                  gap={1}\n                  alignItems=\"center\"\n                  justifyContent=\"center\"\n                >\n                  {CategoryIconUsed ? (\n                    <CategoryIconUsed\n                      variant={active ? 'primary' : categoryIconVariant}\n                    />\n                  ) : (\n                    <ConsoleCategoryIcon\n                      variant={active ? 'primary' : categoryIconVariant}\n                    />\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          target={target}\n          rel={rel}\n          borderless\n          active={active}\n          disabled={disabled}\n          sentiment={active ? 'primary' : 'neutral'}\n          isPinnable={shouldShowPinnedButton}\n          onClick={() => onToggle?.(!!active)}\n        >\n          <Stack\n            gap={1}\n            direction=\"row\"\n            alignItems=\"center\"\n            justifyContent=\"space-between\"\n            flex={1}\n            width=\"100%\"\n          >\n            {!animation ? (\n              <WrapText as=\"span\" variant=\"bodySmall\" whiteSpace=\"pre-wrap\">\n                {label}\n              </WrapText>\n            ) : null}\n            <Stack direction=\"row\">\n              {badgeText && !animation ? (\n                <StyledBadge\n                  sentiment={badgeSentiment}\n                  size=\"small\"\n                  prominence=\"strong\"\n                  disabled={disabled}\n                >\n                  {badgeText}\n                </StyledBadge>\n              ) : null}\n              {hasHrefAndNoChildren && target === '_blank' ? (\n                <AnimatedIcon\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                      aria-label={isItemPinned ? 'unpin' : 'pin'}\n                      variant=\"ghost\"\n                      sentiment={active ? 'primary' : 'neutral'}\n                      onClick={(event: MouseEvent<HTMLDivElement>) => {\n                        if (pinnedItems.length < pinLimit || isItemPinned) {\n                          event.preventDefault()\n                          event.stopPropagation() // This is to avoid click spread to the parent and change the routing\n\n                          let newValue: string[] | undefined\n                          if (isItemPinned) {\n                            newValue = unpinItem(id)\n                          } else {\n                            newValue = pinItem(id)\n                          }\n                          onClickPinUnpin?.({\n                            state: isItemPinned ? 'unpin' : 'pin',\n                            id,\n                            totalPinned: newValue,\n                          })\n                        }\n                      }}\n                      disabled={isItemPinned ? false : isPinDisabled}\n                    >\n                      <PinUnpinIcon\n                        size=\"medium\"\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={target}\n              rel={rel}\n            >\n              <AnimatedIcon sentiment=\"neutral\" prominence=\"weak\" />\n            </Container>\n          </MenuStack>\n        </Tooltip>\n      )\n    }\n\n    return null\n  },\n)\n"]} */"));
210
+ }) => theme.colors.neutral.textWeakDisabled, ';}}&[data-animation="collapse"][data-animation-type="complex"]{animation:', constants.shrinkHeight, " ", constants.ANIMATION_DURATION, "ms ease-in-out;", WrapText, ",", AnimatedIcon, ",", StyledBadge, "{animation:", ui.fadeIn, " ", constants.ANIMATION_DURATION, 'ms ease-in-out reverse;}}&[data-animation="expand"][data-animation-type="complex"]{animation:', constants.shrinkHeight, " ", constants.ANIMATION_DURATION, "ms ease-in-out reverse;", WrapText, ",", AnimatedIcon, ",", StyledBadge, "{animation:", ui.fadeIn, " ", constants.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":"AAkJqC","file":"/home/runner/work/ultraviolet/ultraviolet/packages/plus/src/components/Navigation/components/Item.tsx","sourcesContent":["'use client'\n\nimport { css } from '@emotion/react'\nimport styled from '@emotion/styled'\nimport {\n  ArrowDownIcon,\n  ArrowRightIcon,\n  DragIcon,\n  OpenInNewIcon,\n  PinOutlineIcon,\n  UnpinIcon,\n} from '@ultraviolet/icons'\nimport * as CategoryIcon from '@ultraviolet/icons/category'\nimport { ConsoleCategoryIcon } from '@ultraviolet/icons/category'\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  isValidElement,\n  memo,\n  useCallback,\n  useContext,\n  useEffect,\n  useMemo,\n  useReducer,\n} from 'react'\nimport type { PascalToCamelCaseWithoutSuffix } from '../../../types'\nimport { useNavigation } from '../NavigationProvider'\nimport { ANIMATION_DURATION, shrinkHeight } from '../constants'\nimport type { PinUnPinType } from '../types'\nimport { ItemContext, ItemProvider } from './ItemProvider'\n\nconst RelativeDiv = styled.div`\n  position: relative;\n`\n\nconst StyledPinIconOutline = styled(PinOutlineIcon, {\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 }) =>\n      active ? `background: ${theme.colors.primary.backgroundHover};` : null}\n  }\n`\n\nconst StyledUnpinIcon = StyledPinIconOutline.withComponent(UnpinIcon)\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(DragIcon)`\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  &: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(OpenInNewIcon)``\n\nconst WrapText = styled(Text)`\n  overflow-wrap: anywhere;\n  overflow: hidden;\n  display: -webkit-box;\n  -webkit-box-orient: vertical;\n  -webkit-line-clamp: 2;\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 }) => 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\"][data-animation-type=\"complex\"] {\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\"][data-animation-type=\"complex\"] {\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 StackIcon = styled(Stack)`\n  padding-top: ${({ theme }) => theme.space['0.5']};\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?: PascalToCamelCaseWithoutSuffix<\n    keyof typeof CategoryIcon,\n    'CategoryIcon'\n  >\n  categoryIconVariant?: ComponentProps<\n    (typeof CategoryIcon)['BaremetalCategoryIcon']\n  >['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?: HTMLAnchorElement['href']\n  target?: HTMLAnchorElement['target']\n  rel?: HTMLAnchorElement['rel']\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  onToggle?: (toggle: boolean) => void\n  onClickPinUnpin?: (parameters: PinUnPinType) => 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 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  'data-testid'?: string\n}\n\nconst onDragStopTrigger = (event: DragEvent<HTMLDivElement>) => {\n  // eslint-disable-next-line no-param-reassign\n  event.currentTarget.style.opacity = '1'\n}\n\nexport const Item = memo(\n  ({\n    children,\n    categoryIcon,\n    categoryIconVariant,\n    label,\n    subLabel,\n    badgeText,\n    badgeSentiment,\n    href,\n    target,\n    rel,\n    onToggle,\n    onClickPinUnpin,\n    toggle,\n    active,\n    noPinButton,\n    type = 'default',\n    as,\n    disabled,\n    noExpand = false,\n    index,\n    id,\n    'data-testid': dataTestId,\n  }: ItemProps) => {\n    const context = useNavigation()\n    if (!context) {\n      throw new Error(\n        'Navigation.Item can only be used inside a NavigationProvider.',\n      )\n    }\n\n    const itemProvider = useContext(ItemContext)\n    const hasParents = !!itemProvider\n\n    const {\n      expanded,\n      locales,\n      pinnedFeature,\n      pinItem,\n      unpinItem,\n      pinnedItems,\n      pinLimit,\n      animation,\n      registerItem,\n      shouldAnimate,\n      animationType,\n    } = context\n\n    useEffect(\n      () => {\n        if (type !== 'pinnedGroup' && pinnedFeature) {\n          registerItem({ [id]: { label, active, onToggle, onClickPinUnpin } })\n        }\n      },\n      // eslint-disable-next-line react-hooks/exhaustive-deps\n      [active, id, label, registerItem],\n    )\n\n    const [internalExpanded, onToggleExpand] = useReducer(\n      prevState => !prevState,\n      Boolean(toggle),\n    )\n\n    const triggerToggle = useCallback(() => {\n      onToggleExpand()\n      onToggle?.(internalExpanded)\n    }, [internalExpanded, onToggle])\n\n    const PaddedStack =\n      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 = useMemo(\n      () => StyledContainer.withComponent(containerTag),\n      [containerTag],\n    )\n\n    const CategoryIconUsed = categoryIcon\n      ? CategoryIcon[\n          `${\n            categoryIcon.charAt(0).toUpperCase() + categoryIcon.slice(1)\n          }CategoryIcon` as keyof typeof CategoryIcon\n        ]\n      : null\n\n    const ArrowIcon = useMemo(\n      () => (internalExpanded ? ArrowDownIcon : ArrowRightIcon),\n      [internalExpanded],\n    )\n\n    const PinUnpinIcon = useMemo(\n      () => (isItemPinned ? StyledUnpinIcon : StyledPinIconOutline),\n      [isItemPinned],\n    )\n\n    const ariaExpanded = useMemo(() => {\n      if (hasHrefAndNoChildren && internalExpanded) {\n        return true\n      }\n\n      if (hasHrefAndNoChildren && !internalExpanded) {\n        return false\n      }\n\n      return undefined\n    }, [hasHrefAndNoChildren, internalExpanded])\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 onDragStart = useCallback(\n      (event: DragEvent<HTMLDivElement>) => {\n        if (expanded) {\n          event.dataTransfer.setData(\n            'text/plain',\n            JSON.stringify({ label, index }),\n          )\n          // eslint-disable-next-line no-param-reassign\n          event.currentTarget.style.opacity = '0.5'\n        }\n\n        return undefined\n      },\n      [expanded, index, label],\n    )\n\n    const onDragEnd = useCallback(\n      (event: DragEvent<HTMLDivElement>) =>\n        expanded ? onDragStopTrigger(event) : undefined,\n      [expanded],\n    )\n\n    // This content is when the navigation is expanded\n    if (expanded || (!expanded && animation === 'expand')) {\n      return (\n        <>\n          <Container\n            gap={1}\n            direction=\"row\"\n            alignItems={categoryIcon ? 'flex-start' : 'center'}\n            justifyContent=\"space-between\"\n            data-has-sub-label={!!subLabel}\n            onClick={triggerToggle}\n            aria-expanded={ariaExpanded}\n            href={href}\n            target={target}\n            rel={rel}\n            data-is-pinnable={shouldShowPinnedButton}\n            data-is-active={active}\n            data-animation={shouldAnimate ? animation : undefined}\n            data-animation-type={animationType}\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={onDragStart}\n            onDragEnd={onDragEnd}\n            id={id}\n            data-testid={dataTestId}\n          >\n            <Stack\n              direction=\"row\"\n              gap={1}\n              alignItems={categoryIcon ? 'flex-start' : 'center'}\n              justifyContent=\"center\"\n            >\n              {CategoryIconUsed ? (\n                <ContainerCategoryIcon\n                  alignItems=\"center\"\n                  justifyContent=\"center\"\n                >\n                  <CategoryIconUsed\n                    variant={active ? 'primary' : categoryIconVariant}\n                    disabled={disabled}\n                  />\n                </ContainerCategoryIcon>\n              ) : null}\n              {type === 'pinned' && expanded ? (\n                <GrabIcon\n                  sentiment=\"neutral\"\n                  prominence=\"weak\"\n                  size=\"small\"\n                  disabled={disabled}\n                />\n              ) : null}\n              <Stack>\n                {!animation ? (\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                    data-animation={animation}\n                    disabled={disabled}\n                    whiteSpace=\"pre-wrap\"\n                  >\n                    {label}\n                  </WrapText>\n                ) : null}\n                {subLabel && !animation ? (\n                  <WrapText\n                    as=\"span\"\n                    variant=\"caption\"\n                    sentiment=\"neutral\"\n                    prominence=\"weak\"\n                    data-animation={animation}\n                    disabled={disabled}\n                    whiteSpace=\"pre-wrap\"\n                  >\n                    {subLabel}\n                  </WrapText>\n                ) : null}\n              </Stack>\n            </Stack>\n            <Stack\n              direction=\"row\"\n              alignItems=\"center\"\n              gap={href ? 1 : undefined}\n            >\n              {badgeText || hasPinnedFeatureAndNoChildren ? (\n                <>\n                  {badgeText && !animation ? (\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                          aria-label={isItemPinned ? 'unpin' : 'pin'}\n                          size=\"xsmall\"\n                          variant=\"ghost\"\n                          sentiment={active ? 'primary' : 'neutral'}\n                          onClick={(event: MouseEvent<HTMLDivElement>) => {\n                            if (pinnedItems.length < pinLimit || isItemPinned) {\n                              event.preventDefault()\n                              event.stopPropagation() // This is to avoid click spread to the parent and change the routing\n                              let newValue: string[] | undefined\n                              if (isItemPinned) {\n                                newValue = unpinItem(id)\n                              } else {\n                                newValue = pinItem(id)\n                              }\n\n                              onClickPinUnpin?.({\n                                state: isItemPinned ? 'unpin' : 'pin',\n                                id,\n                                totalPinned: newValue,\n                              })\n                            }\n                          }}\n                          disabled={isItemPinned ? false : isPinDisabled}\n                        >\n                          <PinUnpinIcon\n                            size=\"medium\"\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 && target === '_blank' && !animation ? (\n                <AnimatedIcon\n                  sentiment=\"neutral\"\n                  prominence=\"default\"\n                  disabled={disabled}\n                />\n              ) : null}\n              {children ? (\n                <StackIcon gap={1} direction=\"row\" alignItems=\"center\">\n                  {!animation && !noExpand ? (\n                    <ArrowIcon sentiment=\"neutral\" prominence=\"weak\" />\n                  ) : null}\n                </StackIcon>\n              ) : null}\n            </Stack>\n          </Container>\n          {children ? (\n            <>\n              {!noExpand ? (\n                <ItemProvider>\n                  <Expandable opened={internalExpanded} animationDuration={0}>\n                    <PaddedStack width={animation ? '100%' : undefined}>\n                      {children}\n                    </PaddedStack>\n                  </Expandable>\n                </ItemProvider>\n              ) : (\n                <ItemProvider>\n                  <PaddedStack width={animation ? '100%' : undefined}>\n                    {children}\n                  </PaddedStack>\n                </ItemProvider>\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                  aria-label={label}\n                >\n                  {CategoryIconUsed ? (\n                    <Stack\n                      direction=\"row\"\n                      gap={1}\n                      alignItems=\"center\"\n                      justifyContent=\"center\"\n                    >\n                      <CategoryIconUsed\n                        variant={active ? 'primary' : categoryIconVariant}\n                      />\n                    </Stack>\n                  ) : null}\n                </Button>\n              }\n              placement=\"right\"\n            >\n              <ItemProvider>{children}</ItemProvider>\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                aria-label={label}\n              >\n                <Stack\n                  direction=\"row\"\n                  gap={1}\n                  alignItems=\"center\"\n                  justifyContent=\"center\"\n                >\n                  {CategoryIconUsed ? (\n                    <CategoryIconUsed\n                      variant={active ? 'primary' : categoryIconVariant}\n                    />\n                  ) : (\n                    <ConsoleCategoryIcon\n                      variant={active ? 'primary' : categoryIconVariant}\n                    />\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          target={target}\n          rel={rel}\n          borderless\n          active={active}\n          disabled={disabled}\n          sentiment={active ? 'primary' : 'neutral'}\n          isPinnable={shouldShowPinnedButton}\n          onClick={() => onToggle?.(!!active)}\n        >\n          <Stack\n            gap={1}\n            direction=\"row\"\n            alignItems=\"center\"\n            justifyContent=\"space-between\"\n            flex={1}\n            width=\"100%\"\n          >\n            {!animation ? (\n              <WrapText as=\"span\" variant=\"bodySmall\" whiteSpace=\"pre-wrap\">\n                {label}\n              </WrapText>\n            ) : null}\n            <Stack direction=\"row\">\n              {badgeText && !animation ? (\n                <StyledBadge\n                  sentiment={badgeSentiment}\n                  size=\"small\"\n                  prominence=\"strong\"\n                  disabled={disabled}\n                >\n                  {badgeText}\n                </StyledBadge>\n              ) : null}\n              {hasHrefAndNoChildren && target === '_blank' ? (\n                <AnimatedIcon\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                      aria-label={isItemPinned ? 'unpin' : 'pin'}\n                      variant=\"ghost\"\n                      sentiment={active ? 'primary' : 'neutral'}\n                      onClick={(event: MouseEvent<HTMLDivElement>) => {\n                        if (pinnedItems.length < pinLimit || isItemPinned) {\n                          event.preventDefault()\n                          event.stopPropagation() // This is to avoid click spread to the parent and change the routing\n\n                          let newValue: string[] | undefined\n                          if (isItemPinned) {\n                            newValue = unpinItem(id)\n                          } else {\n                            newValue = pinItem(id)\n                          }\n                          onClickPinUnpin?.({\n                            state: isItemPinned ? 'unpin' : 'pin',\n                            id,\n                            totalPinned: newValue,\n                          })\n                        }\n                      }}\n                      disabled={isItemPinned ? false : isPinDisabled}\n                    >\n                      <PinUnpinIcon\n                        size=\"medium\"\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={target}\n              rel={rel}\n            >\n              <AnimatedIcon sentiment=\"neutral\" prominence=\"weak\" />\n            </Container>\n          </MenuStack>\n        </Tooltip>\n      )\n    }\n\n    return null\n  },\n)\n"]} */"));
211
211
  const MenuStack = /* @__PURE__ */ _styled__default.default(ui.Stack, process.env.NODE_ENV === "production" ? {
212
212
  target: "e134hokc2"
213
213
  } : {
@@ -217,7 +217,7 @@ const MenuStack = /* @__PURE__ */ _styled__default.default(ui.Stack, process.env
217
217
  theme
218
218
  }) => `0 ${theme.space["2"]}`, ";margin-top:", ({
219
219
  theme
220
- }) => 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":"AA6P+B","file":"/home/runner/work/ultraviolet/ultraviolet/packages/plus/src/components/Navigation/components/Item.tsx","sourcesContent":["'use client'\n\nimport { css } from '@emotion/react'\nimport styled from '@emotion/styled'\nimport {\n  ArrowDownIcon,\n  ArrowRightIcon,\n  DragIcon,\n  OpenInNewIcon,\n  PinOutlineIcon,\n  UnpinIcon,\n} from '@ultraviolet/icons'\nimport * as CategoryIcon from '@ultraviolet/icons/category'\nimport { ConsoleCategoryIcon } from '@ultraviolet/icons/category'\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  isValidElement,\n  memo,\n  useCallback,\n  useContext,\n  useEffect,\n  useMemo,\n  useReducer,\n} from 'react'\nimport type { PascalToCamelCaseWithoutSuffix } from '../../../types'\nimport { useNavigation } from '../NavigationProvider'\nimport { ANIMATION_DURATION, shrinkHeight } from '../constants'\nimport type { PinUnPinType } from '../types'\nimport { ItemContext, ItemProvider } from './ItemProvider'\n\nconst RelativeDiv = styled.div`\n  position: relative;\n`\n\nconst StyledPinIconOutline = styled(PinOutlineIcon, {\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 }) =>\n      active ? `background: ${theme.colors.primary.backgroundHover};` : null}\n  }\n`\n\nconst StyledUnpinIcon = StyledPinIconOutline.withComponent(UnpinIcon)\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(DragIcon)`\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  &: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(OpenInNewIcon)``\n\nconst WrapText = styled(Text)`\n  overflow-wrap: anywhere;\n  overflow: hidden;\n  display: -webkit-box;\n  -webkit-box-orient: vertical;\n  -webkit-line-clamp: 2;\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 }) => 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\"][data-animation-type=\"complex\"] {\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\"][data-animation-type=\"complex\"] {\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 StackIcon = styled(Stack)`\n  padding-top: ${({ theme }) => theme.space['0.5']};\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?: PascalToCamelCaseWithoutSuffix<\n    keyof typeof CategoryIcon,\n    'CategoryIcon'\n  >\n  categoryIconVariant?: ComponentProps<\n    (typeof CategoryIcon)['BaremetalCategoryIcon']\n  >['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?: HTMLAnchorElement['href']\n  target?: HTMLAnchorElement['target']\n  rel?: HTMLAnchorElement['rel']\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  onToggle?: (toggle: boolean) => void\n  onClickPinUnpin?: (parameters: PinUnPinType) => 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 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  'data-testid'?: string\n}\n\nconst onDragStopTrigger = (event: DragEvent<HTMLDivElement>) => {\n  // eslint-disable-next-line no-param-reassign\n  event.currentTarget.style.opacity = '1'\n}\n\nexport const Item = memo(\n  ({\n    children,\n    categoryIcon,\n    categoryIconVariant,\n    label,\n    subLabel,\n    badgeText,\n    badgeSentiment,\n    href,\n    target,\n    rel,\n    onToggle,\n    onClickPinUnpin,\n    toggle,\n    active,\n    noPinButton,\n    type = 'default',\n    as,\n    disabled,\n    noExpand = false,\n    index,\n    id,\n    'data-testid': dataTestId,\n  }: ItemProps) => {\n    const context = useNavigation()\n    if (!context) {\n      throw new Error(\n        'Navigation.Item can only be used inside a NavigationProvider.',\n      )\n    }\n\n    const itemProvider = useContext(ItemContext)\n    const hasParents = !!itemProvider\n\n    const {\n      expanded,\n      locales,\n      pinnedFeature,\n      pinItem,\n      unpinItem,\n      pinnedItems,\n      pinLimit,\n      animation,\n      registerItem,\n      shouldAnimate,\n      animationType,\n    } = context\n\n    useEffect(\n      () => {\n        if (type !== 'pinnedGroup') {\n          registerItem({ [id]: { label, active, onToggle, onClickPinUnpin } })\n        }\n      },\n      // eslint-disable-next-line react-hooks/exhaustive-deps\n      [active, id, label, registerItem],\n    )\n\n    const [internalExpanded, onToggleExpand] = useReducer(\n      prevState => !prevState,\n      Boolean(toggle),\n    )\n\n    const triggerToggle = useCallback(() => {\n      onToggleExpand()\n      onToggle?.(internalExpanded)\n    }, [internalExpanded, onToggle])\n\n    const PaddedStack =\n      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 = useMemo(\n      () => StyledContainer.withComponent(containerTag),\n      [containerTag],\n    )\n\n    const CategoryIconUsed = categoryIcon\n      ? CategoryIcon[\n          `${\n            categoryIcon.charAt(0).toUpperCase() + categoryIcon.slice(1)\n          }CategoryIcon` as keyof typeof CategoryIcon\n        ]\n      : null\n\n    const ArrowIcon = useMemo(\n      () => (internalExpanded ? ArrowDownIcon : ArrowRightIcon),\n      [internalExpanded],\n    )\n\n    const PinUnpinIcon = useMemo(\n      () => (isItemPinned ? StyledUnpinIcon : StyledPinIconOutline),\n      [isItemPinned],\n    )\n\n    const ariaExpanded = useMemo(() => {\n      if (hasHrefAndNoChildren && internalExpanded) {\n        return true\n      }\n\n      if (hasHrefAndNoChildren && !internalExpanded) {\n        return false\n      }\n\n      return undefined\n    }, [hasHrefAndNoChildren, internalExpanded])\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 onDragStart = useCallback(\n      (event: DragEvent<HTMLDivElement>) => {\n        if (expanded) {\n          event.dataTransfer.setData(\n            'text/plain',\n            JSON.stringify({ label, index }),\n          )\n          // eslint-disable-next-line no-param-reassign\n          event.currentTarget.style.opacity = '0.5'\n        }\n\n        return undefined\n      },\n      [expanded, index, label],\n    )\n\n    const onDragEnd = useCallback(\n      (event: DragEvent<HTMLDivElement>) =>\n        expanded ? onDragStopTrigger(event) : undefined,\n      [expanded],\n    )\n\n    // This content is when the navigation is expanded\n    if (expanded || (!expanded && animation === 'expand')) {\n      return (\n        <>\n          <Container\n            gap={1}\n            direction=\"row\"\n            alignItems={categoryIcon ? 'flex-start' : 'center'}\n            justifyContent=\"space-between\"\n            data-has-sub-label={!!subLabel}\n            onClick={triggerToggle}\n            aria-expanded={ariaExpanded}\n            href={href}\n            target={target}\n            rel={rel}\n            data-is-pinnable={shouldShowPinnedButton}\n            data-is-active={active}\n            data-animation={shouldAnimate ? animation : undefined}\n            data-animation-type={animationType}\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={onDragStart}\n            onDragEnd={onDragEnd}\n            id={id}\n            data-testid={dataTestId}\n          >\n            <Stack\n              direction=\"row\"\n              gap={1}\n              alignItems={categoryIcon ? 'flex-start' : 'center'}\n              justifyContent=\"center\"\n            >\n              {CategoryIconUsed ? (\n                <ContainerCategoryIcon\n                  alignItems=\"center\"\n                  justifyContent=\"center\"\n                >\n                  <CategoryIconUsed\n                    variant={active ? 'primary' : categoryIconVariant}\n                    disabled={disabled}\n                  />\n                </ContainerCategoryIcon>\n              ) : null}\n              {type === 'pinned' && expanded ? (\n                <GrabIcon\n                  sentiment=\"neutral\"\n                  prominence=\"weak\"\n                  size=\"small\"\n                  disabled={disabled}\n                />\n              ) : null}\n              <Stack>\n                {!animation ? (\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                    data-animation={animation}\n                    disabled={disabled}\n                    whiteSpace=\"pre-wrap\"\n                  >\n                    {label}\n                  </WrapText>\n                ) : null}\n                {subLabel && !animation ? (\n                  <WrapText\n                    as=\"span\"\n                    variant=\"caption\"\n                    sentiment=\"neutral\"\n                    prominence=\"weak\"\n                    data-animation={animation}\n                    disabled={disabled}\n                    whiteSpace=\"pre-wrap\"\n                  >\n                    {subLabel}\n                  </WrapText>\n                ) : null}\n              </Stack>\n            </Stack>\n            <Stack\n              direction=\"row\"\n              alignItems=\"center\"\n              gap={href ? 1 : undefined}\n            >\n              {badgeText || hasPinnedFeatureAndNoChildren ? (\n                <>\n                  {badgeText && !animation ? (\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                          aria-label={isItemPinned ? 'unpin' : 'pin'}\n                          size=\"xsmall\"\n                          variant=\"ghost\"\n                          sentiment={active ? 'primary' : 'neutral'}\n                          onClick={(event: MouseEvent<HTMLDivElement>) => {\n                            if (pinnedItems.length < pinLimit || isItemPinned) {\n                              event.preventDefault()\n                              event.stopPropagation() // This is to avoid click spread to the parent and change the routing\n                              let newValue: string[] | undefined\n                              if (isItemPinned) {\n                                newValue = unpinItem(id)\n                              } else {\n                                newValue = pinItem(id)\n                              }\n\n                              onClickPinUnpin?.({\n                                state: isItemPinned ? 'unpin' : 'pin',\n                                id,\n                                totalPinned: newValue,\n                              })\n                            }\n                          }}\n                          disabled={isItemPinned ? false : isPinDisabled}\n                        >\n                          <PinUnpinIcon\n                            size=\"medium\"\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 && target === '_blank' && !animation ? (\n                <AnimatedIcon\n                  sentiment=\"neutral\"\n                  prominence=\"default\"\n                  disabled={disabled}\n                />\n              ) : null}\n              {children ? (\n                <StackIcon gap={1} direction=\"row\" alignItems=\"center\">\n                  {!animation && !noExpand ? (\n                    <ArrowIcon sentiment=\"neutral\" prominence=\"weak\" />\n                  ) : null}\n                </StackIcon>\n              ) : null}\n            </Stack>\n          </Container>\n          {children ? (\n            <>\n              {!noExpand ? (\n                <ItemProvider>\n                  <Expandable opened={internalExpanded} animationDuration={0}>\n                    <PaddedStack width={animation ? '100%' : undefined}>\n                      {children}\n                    </PaddedStack>\n                  </Expandable>\n                </ItemProvider>\n              ) : (\n                <ItemProvider>\n                  <PaddedStack width={animation ? '100%' : undefined}>\n                    {children}\n                  </PaddedStack>\n                </ItemProvider>\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                  aria-label={label}\n                >\n                  {CategoryIconUsed ? (\n                    <Stack\n                      direction=\"row\"\n                      gap={1}\n                      alignItems=\"center\"\n                      justifyContent=\"center\"\n                    >\n                      <CategoryIconUsed\n                        variant={active ? 'primary' : categoryIconVariant}\n                      />\n                    </Stack>\n                  ) : null}\n                </Button>\n              }\n              placement=\"right\"\n            >\n              <ItemProvider>{children}</ItemProvider>\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                aria-label={label}\n              >\n                <Stack\n                  direction=\"row\"\n                  gap={1}\n                  alignItems=\"center\"\n                  justifyContent=\"center\"\n                >\n                  {CategoryIconUsed ? (\n                    <CategoryIconUsed\n                      variant={active ? 'primary' : categoryIconVariant}\n                    />\n                  ) : (\n                    <ConsoleCategoryIcon\n                      variant={active ? 'primary' : categoryIconVariant}\n                    />\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          target={target}\n          rel={rel}\n          borderless\n          active={active}\n          disabled={disabled}\n          sentiment={active ? 'primary' : 'neutral'}\n          isPinnable={shouldShowPinnedButton}\n          onClick={() => onToggle?.(!!active)}\n        >\n          <Stack\n            gap={1}\n            direction=\"row\"\n            alignItems=\"center\"\n            justifyContent=\"space-between\"\n            flex={1}\n            width=\"100%\"\n          >\n            {!animation ? (\n              <WrapText as=\"span\" variant=\"bodySmall\" whiteSpace=\"pre-wrap\">\n                {label}\n              </WrapText>\n            ) : null}\n            <Stack direction=\"row\">\n              {badgeText && !animation ? (\n                <StyledBadge\n                  sentiment={badgeSentiment}\n                  size=\"small\"\n                  prominence=\"strong\"\n                  disabled={disabled}\n                >\n                  {badgeText}\n                </StyledBadge>\n              ) : null}\n              {hasHrefAndNoChildren && target === '_blank' ? (\n                <AnimatedIcon\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                      aria-label={isItemPinned ? 'unpin' : 'pin'}\n                      variant=\"ghost\"\n                      sentiment={active ? 'primary' : 'neutral'}\n                      onClick={(event: MouseEvent<HTMLDivElement>) => {\n                        if (pinnedItems.length < pinLimit || isItemPinned) {\n                          event.preventDefault()\n                          event.stopPropagation() // This is to avoid click spread to the parent and change the routing\n\n                          let newValue: string[] | undefined\n                          if (isItemPinned) {\n                            newValue = unpinItem(id)\n                          } else {\n                            newValue = pinItem(id)\n                          }\n                          onClickPinUnpin?.({\n                            state: isItemPinned ? 'unpin' : 'pin',\n                            id,\n                            totalPinned: newValue,\n                          })\n                        }\n                      }}\n                      disabled={isItemPinned ? false : isPinDisabled}\n                    >\n                      <PinUnpinIcon\n                        size=\"medium\"\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={target}\n              rel={rel}\n            >\n              <AnimatedIcon sentiment=\"neutral\" prominence=\"weak\" />\n            </Container>\n          </MenuStack>\n        </Tooltip>\n      )\n    }\n\n    return null\n  },\n)\n"]} */"));
220
+ }) => 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":"AA6P+B","file":"/home/runner/work/ultraviolet/ultraviolet/packages/plus/src/components/Navigation/components/Item.tsx","sourcesContent":["'use client'\n\nimport { css } from '@emotion/react'\nimport styled from '@emotion/styled'\nimport {\n  ArrowDownIcon,\n  ArrowRightIcon,\n  DragIcon,\n  OpenInNewIcon,\n  PinOutlineIcon,\n  UnpinIcon,\n} from '@ultraviolet/icons'\nimport * as CategoryIcon from '@ultraviolet/icons/category'\nimport { ConsoleCategoryIcon } from '@ultraviolet/icons/category'\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  isValidElement,\n  memo,\n  useCallback,\n  useContext,\n  useEffect,\n  useMemo,\n  useReducer,\n} from 'react'\nimport type { PascalToCamelCaseWithoutSuffix } from '../../../types'\nimport { useNavigation } from '../NavigationProvider'\nimport { ANIMATION_DURATION, shrinkHeight } from '../constants'\nimport type { PinUnPinType } from '../types'\nimport { ItemContext, ItemProvider } from './ItemProvider'\n\nconst RelativeDiv = styled.div`\n  position: relative;\n`\n\nconst StyledPinIconOutline = styled(PinOutlineIcon, {\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 }) =>\n      active ? `background: ${theme.colors.primary.backgroundHover};` : null}\n  }\n`\n\nconst StyledUnpinIcon = StyledPinIconOutline.withComponent(UnpinIcon)\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(DragIcon)`\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  &: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(OpenInNewIcon)``\n\nconst WrapText = styled(Text)`\n  overflow-wrap: anywhere;\n  overflow: hidden;\n  display: -webkit-box;\n  -webkit-box-orient: vertical;\n  -webkit-line-clamp: 2;\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 }) => 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\"][data-animation-type=\"complex\"] {\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\"][data-animation-type=\"complex\"] {\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 StackIcon = styled(Stack)`\n  padding-top: ${({ theme }) => theme.space['0.5']};\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?: PascalToCamelCaseWithoutSuffix<\n    keyof typeof CategoryIcon,\n    'CategoryIcon'\n  >\n  categoryIconVariant?: ComponentProps<\n    (typeof CategoryIcon)['BaremetalCategoryIcon']\n  >['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?: HTMLAnchorElement['href']\n  target?: HTMLAnchorElement['target']\n  rel?: HTMLAnchorElement['rel']\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  onToggle?: (toggle: boolean) => void\n  onClickPinUnpin?: (parameters: PinUnPinType) => 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 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  'data-testid'?: string\n}\n\nconst onDragStopTrigger = (event: DragEvent<HTMLDivElement>) => {\n  // eslint-disable-next-line no-param-reassign\n  event.currentTarget.style.opacity = '1'\n}\n\nexport const Item = memo(\n  ({\n    children,\n    categoryIcon,\n    categoryIconVariant,\n    label,\n    subLabel,\n    badgeText,\n    badgeSentiment,\n    href,\n    target,\n    rel,\n    onToggle,\n    onClickPinUnpin,\n    toggle,\n    active,\n    noPinButton,\n    type = 'default',\n    as,\n    disabled,\n    noExpand = false,\n    index,\n    id,\n    'data-testid': dataTestId,\n  }: ItemProps) => {\n    const context = useNavigation()\n    if (!context) {\n      throw new Error(\n        'Navigation.Item can only be used inside a NavigationProvider.',\n      )\n    }\n\n    const itemProvider = useContext(ItemContext)\n    const hasParents = !!itemProvider\n\n    const {\n      expanded,\n      locales,\n      pinnedFeature,\n      pinItem,\n      unpinItem,\n      pinnedItems,\n      pinLimit,\n      animation,\n      registerItem,\n      shouldAnimate,\n      animationType,\n    } = context\n\n    useEffect(\n      () => {\n        if (type !== 'pinnedGroup' && pinnedFeature) {\n          registerItem({ [id]: { label, active, onToggle, onClickPinUnpin } })\n        }\n      },\n      // eslint-disable-next-line react-hooks/exhaustive-deps\n      [active, id, label, registerItem],\n    )\n\n    const [internalExpanded, onToggleExpand] = useReducer(\n      prevState => !prevState,\n      Boolean(toggle),\n    )\n\n    const triggerToggle = useCallback(() => {\n      onToggleExpand()\n      onToggle?.(internalExpanded)\n    }, [internalExpanded, onToggle])\n\n    const PaddedStack =\n      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 = useMemo(\n      () => StyledContainer.withComponent(containerTag),\n      [containerTag],\n    )\n\n    const CategoryIconUsed = categoryIcon\n      ? CategoryIcon[\n          `${\n            categoryIcon.charAt(0).toUpperCase() + categoryIcon.slice(1)\n          }CategoryIcon` as keyof typeof CategoryIcon\n        ]\n      : null\n\n    const ArrowIcon = useMemo(\n      () => (internalExpanded ? ArrowDownIcon : ArrowRightIcon),\n      [internalExpanded],\n    )\n\n    const PinUnpinIcon = useMemo(\n      () => (isItemPinned ? StyledUnpinIcon : StyledPinIconOutline),\n      [isItemPinned],\n    )\n\n    const ariaExpanded = useMemo(() => {\n      if (hasHrefAndNoChildren && internalExpanded) {\n        return true\n      }\n\n      if (hasHrefAndNoChildren && !internalExpanded) {\n        return false\n      }\n\n      return undefined\n    }, [hasHrefAndNoChildren, internalExpanded])\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 onDragStart = useCallback(\n      (event: DragEvent<HTMLDivElement>) => {\n        if (expanded) {\n          event.dataTransfer.setData(\n            'text/plain',\n            JSON.stringify({ label, index }),\n          )\n          // eslint-disable-next-line no-param-reassign\n          event.currentTarget.style.opacity = '0.5'\n        }\n\n        return undefined\n      },\n      [expanded, index, label],\n    )\n\n    const onDragEnd = useCallback(\n      (event: DragEvent<HTMLDivElement>) =>\n        expanded ? onDragStopTrigger(event) : undefined,\n      [expanded],\n    )\n\n    // This content is when the navigation is expanded\n    if (expanded || (!expanded && animation === 'expand')) {\n      return (\n        <>\n          <Container\n            gap={1}\n            direction=\"row\"\n            alignItems={categoryIcon ? 'flex-start' : 'center'}\n            justifyContent=\"space-between\"\n            data-has-sub-label={!!subLabel}\n            onClick={triggerToggle}\n            aria-expanded={ariaExpanded}\n            href={href}\n            target={target}\n            rel={rel}\n            data-is-pinnable={shouldShowPinnedButton}\n            data-is-active={active}\n            data-animation={shouldAnimate ? animation : undefined}\n            data-animation-type={animationType}\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={onDragStart}\n            onDragEnd={onDragEnd}\n            id={id}\n            data-testid={dataTestId}\n          >\n            <Stack\n              direction=\"row\"\n              gap={1}\n              alignItems={categoryIcon ? 'flex-start' : 'center'}\n              justifyContent=\"center\"\n            >\n              {CategoryIconUsed ? (\n                <ContainerCategoryIcon\n                  alignItems=\"center\"\n                  justifyContent=\"center\"\n                >\n                  <CategoryIconUsed\n                    variant={active ? 'primary' : categoryIconVariant}\n                    disabled={disabled}\n                  />\n                </ContainerCategoryIcon>\n              ) : null}\n              {type === 'pinned' && expanded ? (\n                <GrabIcon\n                  sentiment=\"neutral\"\n                  prominence=\"weak\"\n                  size=\"small\"\n                  disabled={disabled}\n                />\n              ) : null}\n              <Stack>\n                {!animation ? (\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                    data-animation={animation}\n                    disabled={disabled}\n                    whiteSpace=\"pre-wrap\"\n                  >\n                    {label}\n                  </WrapText>\n                ) : null}\n                {subLabel && !animation ? (\n                  <WrapText\n                    as=\"span\"\n                    variant=\"caption\"\n                    sentiment=\"neutral\"\n                    prominence=\"weak\"\n                    data-animation={animation}\n                    disabled={disabled}\n                    whiteSpace=\"pre-wrap\"\n                  >\n                    {subLabel}\n                  </WrapText>\n                ) : null}\n              </Stack>\n            </Stack>\n            <Stack\n              direction=\"row\"\n              alignItems=\"center\"\n              gap={href ? 1 : undefined}\n            >\n              {badgeText || hasPinnedFeatureAndNoChildren ? (\n                <>\n                  {badgeText && !animation ? (\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                          aria-label={isItemPinned ? 'unpin' : 'pin'}\n                          size=\"xsmall\"\n                          variant=\"ghost\"\n                          sentiment={active ? 'primary' : 'neutral'}\n                          onClick={(event: MouseEvent<HTMLDivElement>) => {\n                            if (pinnedItems.length < pinLimit || isItemPinned) {\n                              event.preventDefault()\n                              event.stopPropagation() // This is to avoid click spread to the parent and change the routing\n                              let newValue: string[] | undefined\n                              if (isItemPinned) {\n                                newValue = unpinItem(id)\n                              } else {\n                                newValue = pinItem(id)\n                              }\n\n                              onClickPinUnpin?.({\n                                state: isItemPinned ? 'unpin' : 'pin',\n                                id,\n                                totalPinned: newValue,\n                              })\n                            }\n                          }}\n                          disabled={isItemPinned ? false : isPinDisabled}\n                        >\n                          <PinUnpinIcon\n                            size=\"medium\"\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 && target === '_blank' && !animation ? (\n                <AnimatedIcon\n                  sentiment=\"neutral\"\n                  prominence=\"default\"\n                  disabled={disabled}\n                />\n              ) : null}\n              {children ? (\n                <StackIcon gap={1} direction=\"row\" alignItems=\"center\">\n                  {!animation && !noExpand ? (\n                    <ArrowIcon sentiment=\"neutral\" prominence=\"weak\" />\n                  ) : null}\n                </StackIcon>\n              ) : null}\n            </Stack>\n          </Container>\n          {children ? (\n            <>\n              {!noExpand ? (\n                <ItemProvider>\n                  <Expandable opened={internalExpanded} animationDuration={0}>\n                    <PaddedStack width={animation ? '100%' : undefined}>\n                      {children}\n                    </PaddedStack>\n                  </Expandable>\n                </ItemProvider>\n              ) : (\n                <ItemProvider>\n                  <PaddedStack width={animation ? '100%' : undefined}>\n                    {children}\n                  </PaddedStack>\n                </ItemProvider>\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                  aria-label={label}\n                >\n                  {CategoryIconUsed ? (\n                    <Stack\n                      direction=\"row\"\n                      gap={1}\n                      alignItems=\"center\"\n                      justifyContent=\"center\"\n                    >\n                      <CategoryIconUsed\n                        variant={active ? 'primary' : categoryIconVariant}\n                      />\n                    </Stack>\n                  ) : null}\n                </Button>\n              }\n              placement=\"right\"\n            >\n              <ItemProvider>{children}</ItemProvider>\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                aria-label={label}\n              >\n                <Stack\n                  direction=\"row\"\n                  gap={1}\n                  alignItems=\"center\"\n                  justifyContent=\"center\"\n                >\n                  {CategoryIconUsed ? (\n                    <CategoryIconUsed\n                      variant={active ? 'primary' : categoryIconVariant}\n                    />\n                  ) : (\n                    <ConsoleCategoryIcon\n                      variant={active ? 'primary' : categoryIconVariant}\n                    />\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          target={target}\n          rel={rel}\n          borderless\n          active={active}\n          disabled={disabled}\n          sentiment={active ? 'primary' : 'neutral'}\n          isPinnable={shouldShowPinnedButton}\n          onClick={() => onToggle?.(!!active)}\n        >\n          <Stack\n            gap={1}\n            direction=\"row\"\n            alignItems=\"center\"\n            justifyContent=\"space-between\"\n            flex={1}\n            width=\"100%\"\n          >\n            {!animation ? (\n              <WrapText as=\"span\" variant=\"bodySmall\" whiteSpace=\"pre-wrap\">\n                {label}\n              </WrapText>\n            ) : null}\n            <Stack direction=\"row\">\n              {badgeText && !animation ? (\n                <StyledBadge\n                  sentiment={badgeSentiment}\n                  size=\"small\"\n                  prominence=\"strong\"\n                  disabled={disabled}\n                >\n                  {badgeText}\n                </StyledBadge>\n              ) : null}\n              {hasHrefAndNoChildren && target === '_blank' ? (\n                <AnimatedIcon\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                      aria-label={isItemPinned ? 'unpin' : 'pin'}\n                      variant=\"ghost\"\n                      sentiment={active ? 'primary' : 'neutral'}\n                      onClick={(event: MouseEvent<HTMLDivElement>) => {\n                        if (pinnedItems.length < pinLimit || isItemPinned) {\n                          event.preventDefault()\n                          event.stopPropagation() // This is to avoid click spread to the parent and change the routing\n\n                          let newValue: string[] | undefined\n                          if (isItemPinned) {\n                            newValue = unpinItem(id)\n                          } else {\n                            newValue = pinItem(id)\n                          }\n                          onClickPinUnpin?.({\n                            state: isItemPinned ? 'unpin' : 'pin',\n                            id,\n                            totalPinned: newValue,\n                          })\n                        }\n                      }}\n                      disabled={isItemPinned ? false : isPinDisabled}\n                    >\n                      <PinUnpinIcon\n                        size=\"medium\"\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={target}\n              rel={rel}\n            >\n              <AnimatedIcon sentiment=\"neutral\" prominence=\"weak\" />\n            </Container>\n          </MenuStack>\n        </Tooltip>\n      )\n    }\n\n    return null\n  },\n)\n"]} */"));
221
221
  const StackIcon = /* @__PURE__ */ _styled__default.default(ui.Stack, process.env.NODE_ENV === "production" ? {
222
222
  target: "e134hokc1"
223
223
  } : {
@@ -225,7 +225,7 @@ const StackIcon = /* @__PURE__ */ _styled__default.default(ui.Stack, process.env
225
225
  label: "StackIcon"
226
226
  })("padding-top:", ({
227
227
  theme
228
- }) => theme.space["0.5"], ";" + (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":"AAkQ+B","file":"/home/runner/work/ultraviolet/ultraviolet/packages/plus/src/components/Navigation/components/Item.tsx","sourcesContent":["'use client'\n\nimport { css } from '@emotion/react'\nimport styled from '@emotion/styled'\nimport {\n  ArrowDownIcon,\n  ArrowRightIcon,\n  DragIcon,\n  OpenInNewIcon,\n  PinOutlineIcon,\n  UnpinIcon,\n} from '@ultraviolet/icons'\nimport * as CategoryIcon from '@ultraviolet/icons/category'\nimport { ConsoleCategoryIcon } from '@ultraviolet/icons/category'\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  isValidElement,\n  memo,\n  useCallback,\n  useContext,\n  useEffect,\n  useMemo,\n  useReducer,\n} from 'react'\nimport type { PascalToCamelCaseWithoutSuffix } from '../../../types'\nimport { useNavigation } from '../NavigationProvider'\nimport { ANIMATION_DURATION, shrinkHeight } from '../constants'\nimport type { PinUnPinType } from '../types'\nimport { ItemContext, ItemProvider } from './ItemProvider'\n\nconst RelativeDiv = styled.div`\n  position: relative;\n`\n\nconst StyledPinIconOutline = styled(PinOutlineIcon, {\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 }) =>\n      active ? `background: ${theme.colors.primary.backgroundHover};` : null}\n  }\n`\n\nconst StyledUnpinIcon = StyledPinIconOutline.withComponent(UnpinIcon)\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(DragIcon)`\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  &: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(OpenInNewIcon)``\n\nconst WrapText = styled(Text)`\n  overflow-wrap: anywhere;\n  overflow: hidden;\n  display: -webkit-box;\n  -webkit-box-orient: vertical;\n  -webkit-line-clamp: 2;\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 }) => 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\"][data-animation-type=\"complex\"] {\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\"][data-animation-type=\"complex\"] {\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 StackIcon = styled(Stack)`\n  padding-top: ${({ theme }) => theme.space['0.5']};\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?: PascalToCamelCaseWithoutSuffix<\n    keyof typeof CategoryIcon,\n    'CategoryIcon'\n  >\n  categoryIconVariant?: ComponentProps<\n    (typeof CategoryIcon)['BaremetalCategoryIcon']\n  >['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?: HTMLAnchorElement['href']\n  target?: HTMLAnchorElement['target']\n  rel?: HTMLAnchorElement['rel']\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  onToggle?: (toggle: boolean) => void\n  onClickPinUnpin?: (parameters: PinUnPinType) => 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 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  'data-testid'?: string\n}\n\nconst onDragStopTrigger = (event: DragEvent<HTMLDivElement>) => {\n  // eslint-disable-next-line no-param-reassign\n  event.currentTarget.style.opacity = '1'\n}\n\nexport const Item = memo(\n  ({\n    children,\n    categoryIcon,\n    categoryIconVariant,\n    label,\n    subLabel,\n    badgeText,\n    badgeSentiment,\n    href,\n    target,\n    rel,\n    onToggle,\n    onClickPinUnpin,\n    toggle,\n    active,\n    noPinButton,\n    type = 'default',\n    as,\n    disabled,\n    noExpand = false,\n    index,\n    id,\n    'data-testid': dataTestId,\n  }: ItemProps) => {\n    const context = useNavigation()\n    if (!context) {\n      throw new Error(\n        'Navigation.Item can only be used inside a NavigationProvider.',\n      )\n    }\n\n    const itemProvider = useContext(ItemContext)\n    const hasParents = !!itemProvider\n\n    const {\n      expanded,\n      locales,\n      pinnedFeature,\n      pinItem,\n      unpinItem,\n      pinnedItems,\n      pinLimit,\n      animation,\n      registerItem,\n      shouldAnimate,\n      animationType,\n    } = context\n\n    useEffect(\n      () => {\n        if (type !== 'pinnedGroup') {\n          registerItem({ [id]: { label, active, onToggle, onClickPinUnpin } })\n        }\n      },\n      // eslint-disable-next-line react-hooks/exhaustive-deps\n      [active, id, label, registerItem],\n    )\n\n    const [internalExpanded, onToggleExpand] = useReducer(\n      prevState => !prevState,\n      Boolean(toggle),\n    )\n\n    const triggerToggle = useCallback(() => {\n      onToggleExpand()\n      onToggle?.(internalExpanded)\n    }, [internalExpanded, onToggle])\n\n    const PaddedStack =\n      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 = useMemo(\n      () => StyledContainer.withComponent(containerTag),\n      [containerTag],\n    )\n\n    const CategoryIconUsed = categoryIcon\n      ? CategoryIcon[\n          `${\n            categoryIcon.charAt(0).toUpperCase() + categoryIcon.slice(1)\n          }CategoryIcon` as keyof typeof CategoryIcon\n        ]\n      : null\n\n    const ArrowIcon = useMemo(\n      () => (internalExpanded ? ArrowDownIcon : ArrowRightIcon),\n      [internalExpanded],\n    )\n\n    const PinUnpinIcon = useMemo(\n      () => (isItemPinned ? StyledUnpinIcon : StyledPinIconOutline),\n      [isItemPinned],\n    )\n\n    const ariaExpanded = useMemo(() => {\n      if (hasHrefAndNoChildren && internalExpanded) {\n        return true\n      }\n\n      if (hasHrefAndNoChildren && !internalExpanded) {\n        return false\n      }\n\n      return undefined\n    }, [hasHrefAndNoChildren, internalExpanded])\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 onDragStart = useCallback(\n      (event: DragEvent<HTMLDivElement>) => {\n        if (expanded) {\n          event.dataTransfer.setData(\n            'text/plain',\n            JSON.stringify({ label, index }),\n          )\n          // eslint-disable-next-line no-param-reassign\n          event.currentTarget.style.opacity = '0.5'\n        }\n\n        return undefined\n      },\n      [expanded, index, label],\n    )\n\n    const onDragEnd = useCallback(\n      (event: DragEvent<HTMLDivElement>) =>\n        expanded ? onDragStopTrigger(event) : undefined,\n      [expanded],\n    )\n\n    // This content is when the navigation is expanded\n    if (expanded || (!expanded && animation === 'expand')) {\n      return (\n        <>\n          <Container\n            gap={1}\n            direction=\"row\"\n            alignItems={categoryIcon ? 'flex-start' : 'center'}\n            justifyContent=\"space-between\"\n            data-has-sub-label={!!subLabel}\n            onClick={triggerToggle}\n            aria-expanded={ariaExpanded}\n            href={href}\n            target={target}\n            rel={rel}\n            data-is-pinnable={shouldShowPinnedButton}\n            data-is-active={active}\n            data-animation={shouldAnimate ? animation : undefined}\n            data-animation-type={animationType}\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={onDragStart}\n            onDragEnd={onDragEnd}\n            id={id}\n            data-testid={dataTestId}\n          >\n            <Stack\n              direction=\"row\"\n              gap={1}\n              alignItems={categoryIcon ? 'flex-start' : 'center'}\n              justifyContent=\"center\"\n            >\n              {CategoryIconUsed ? (\n                <ContainerCategoryIcon\n                  alignItems=\"center\"\n                  justifyContent=\"center\"\n                >\n                  <CategoryIconUsed\n                    variant={active ? 'primary' : categoryIconVariant}\n                    disabled={disabled}\n                  />\n                </ContainerCategoryIcon>\n              ) : null}\n              {type === 'pinned' && expanded ? (\n                <GrabIcon\n                  sentiment=\"neutral\"\n                  prominence=\"weak\"\n                  size=\"small\"\n                  disabled={disabled}\n                />\n              ) : null}\n              <Stack>\n                {!animation ? (\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                    data-animation={animation}\n                    disabled={disabled}\n                    whiteSpace=\"pre-wrap\"\n                  >\n                    {label}\n                  </WrapText>\n                ) : null}\n                {subLabel && !animation ? (\n                  <WrapText\n                    as=\"span\"\n                    variant=\"caption\"\n                    sentiment=\"neutral\"\n                    prominence=\"weak\"\n                    data-animation={animation}\n                    disabled={disabled}\n                    whiteSpace=\"pre-wrap\"\n                  >\n                    {subLabel}\n                  </WrapText>\n                ) : null}\n              </Stack>\n            </Stack>\n            <Stack\n              direction=\"row\"\n              alignItems=\"center\"\n              gap={href ? 1 : undefined}\n            >\n              {badgeText || hasPinnedFeatureAndNoChildren ? (\n                <>\n                  {badgeText && !animation ? (\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                          aria-label={isItemPinned ? 'unpin' : 'pin'}\n                          size=\"xsmall\"\n                          variant=\"ghost\"\n                          sentiment={active ? 'primary' : 'neutral'}\n                          onClick={(event: MouseEvent<HTMLDivElement>) => {\n                            if (pinnedItems.length < pinLimit || isItemPinned) {\n                              event.preventDefault()\n                              event.stopPropagation() // This is to avoid click spread to the parent and change the routing\n                              let newValue: string[] | undefined\n                              if (isItemPinned) {\n                                newValue = unpinItem(id)\n                              } else {\n                                newValue = pinItem(id)\n                              }\n\n                              onClickPinUnpin?.({\n                                state: isItemPinned ? 'unpin' : 'pin',\n                                id,\n                                totalPinned: newValue,\n                              })\n                            }\n                          }}\n                          disabled={isItemPinned ? false : isPinDisabled}\n                        >\n                          <PinUnpinIcon\n                            size=\"medium\"\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 && target === '_blank' && !animation ? (\n                <AnimatedIcon\n                  sentiment=\"neutral\"\n                  prominence=\"default\"\n                  disabled={disabled}\n                />\n              ) : null}\n              {children ? (\n                <StackIcon gap={1} direction=\"row\" alignItems=\"center\">\n                  {!animation && !noExpand ? (\n                    <ArrowIcon sentiment=\"neutral\" prominence=\"weak\" />\n                  ) : null}\n                </StackIcon>\n              ) : null}\n            </Stack>\n          </Container>\n          {children ? (\n            <>\n              {!noExpand ? (\n                <ItemProvider>\n                  <Expandable opened={internalExpanded} animationDuration={0}>\n                    <PaddedStack width={animation ? '100%' : undefined}>\n                      {children}\n                    </PaddedStack>\n                  </Expandable>\n                </ItemProvider>\n              ) : (\n                <ItemProvider>\n                  <PaddedStack width={animation ? '100%' : undefined}>\n                    {children}\n                  </PaddedStack>\n                </ItemProvider>\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                  aria-label={label}\n                >\n                  {CategoryIconUsed ? (\n                    <Stack\n                      direction=\"row\"\n                      gap={1}\n                      alignItems=\"center\"\n                      justifyContent=\"center\"\n                    >\n                      <CategoryIconUsed\n                        variant={active ? 'primary' : categoryIconVariant}\n                      />\n                    </Stack>\n                  ) : null}\n                </Button>\n              }\n              placement=\"right\"\n            >\n              <ItemProvider>{children}</ItemProvider>\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                aria-label={label}\n              >\n                <Stack\n                  direction=\"row\"\n                  gap={1}\n                  alignItems=\"center\"\n                  justifyContent=\"center\"\n                >\n                  {CategoryIconUsed ? (\n                    <CategoryIconUsed\n                      variant={active ? 'primary' : categoryIconVariant}\n                    />\n                  ) : (\n                    <ConsoleCategoryIcon\n                      variant={active ? 'primary' : categoryIconVariant}\n                    />\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          target={target}\n          rel={rel}\n          borderless\n          active={active}\n          disabled={disabled}\n          sentiment={active ? 'primary' : 'neutral'}\n          isPinnable={shouldShowPinnedButton}\n          onClick={() => onToggle?.(!!active)}\n        >\n          <Stack\n            gap={1}\n            direction=\"row\"\n            alignItems=\"center\"\n            justifyContent=\"space-between\"\n            flex={1}\n            width=\"100%\"\n          >\n            {!animation ? (\n              <WrapText as=\"span\" variant=\"bodySmall\" whiteSpace=\"pre-wrap\">\n                {label}\n              </WrapText>\n            ) : null}\n            <Stack direction=\"row\">\n              {badgeText && !animation ? (\n                <StyledBadge\n                  sentiment={badgeSentiment}\n                  size=\"small\"\n                  prominence=\"strong\"\n                  disabled={disabled}\n                >\n                  {badgeText}\n                </StyledBadge>\n              ) : null}\n              {hasHrefAndNoChildren && target === '_blank' ? (\n                <AnimatedIcon\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                      aria-label={isItemPinned ? 'unpin' : 'pin'}\n                      variant=\"ghost\"\n                      sentiment={active ? 'primary' : 'neutral'}\n                      onClick={(event: MouseEvent<HTMLDivElement>) => {\n                        if (pinnedItems.length < pinLimit || isItemPinned) {\n                          event.preventDefault()\n                          event.stopPropagation() // This is to avoid click spread to the parent and change the routing\n\n                          let newValue: string[] | undefined\n                          if (isItemPinned) {\n                            newValue = unpinItem(id)\n                          } else {\n                            newValue = pinItem(id)\n                          }\n                          onClickPinUnpin?.({\n                            state: isItemPinned ? 'unpin' : 'pin',\n                            id,\n                            totalPinned: newValue,\n                          })\n                        }\n                      }}\n                      disabled={isItemPinned ? false : isPinDisabled}\n                    >\n                      <PinUnpinIcon\n                        size=\"medium\"\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={target}\n              rel={rel}\n            >\n              <AnimatedIcon sentiment=\"neutral\" prominence=\"weak\" />\n            </Container>\n          </MenuStack>\n        </Tooltip>\n      )\n    }\n\n    return null\n  },\n)\n"]} */"));
228
+ }) => theme.space["0.5"], ";" + (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":"AAkQ+B","file":"/home/runner/work/ultraviolet/ultraviolet/packages/plus/src/components/Navigation/components/Item.tsx","sourcesContent":["'use client'\n\nimport { css } from '@emotion/react'\nimport styled from '@emotion/styled'\nimport {\n  ArrowDownIcon,\n  ArrowRightIcon,\n  DragIcon,\n  OpenInNewIcon,\n  PinOutlineIcon,\n  UnpinIcon,\n} from '@ultraviolet/icons'\nimport * as CategoryIcon from '@ultraviolet/icons/category'\nimport { ConsoleCategoryIcon } from '@ultraviolet/icons/category'\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  isValidElement,\n  memo,\n  useCallback,\n  useContext,\n  useEffect,\n  useMemo,\n  useReducer,\n} from 'react'\nimport type { PascalToCamelCaseWithoutSuffix } from '../../../types'\nimport { useNavigation } from '../NavigationProvider'\nimport { ANIMATION_DURATION, shrinkHeight } from '../constants'\nimport type { PinUnPinType } from '../types'\nimport { ItemContext, ItemProvider } from './ItemProvider'\n\nconst RelativeDiv = styled.div`\n  position: relative;\n`\n\nconst StyledPinIconOutline = styled(PinOutlineIcon, {\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 }) =>\n      active ? `background: ${theme.colors.primary.backgroundHover};` : null}\n  }\n`\n\nconst StyledUnpinIcon = StyledPinIconOutline.withComponent(UnpinIcon)\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(DragIcon)`\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  &: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(OpenInNewIcon)``\n\nconst WrapText = styled(Text)`\n  overflow-wrap: anywhere;\n  overflow: hidden;\n  display: -webkit-box;\n  -webkit-box-orient: vertical;\n  -webkit-line-clamp: 2;\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 }) => 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\"][data-animation-type=\"complex\"] {\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\"][data-animation-type=\"complex\"] {\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 StackIcon = styled(Stack)`\n  padding-top: ${({ theme }) => theme.space['0.5']};\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?: PascalToCamelCaseWithoutSuffix<\n    keyof typeof CategoryIcon,\n    'CategoryIcon'\n  >\n  categoryIconVariant?: ComponentProps<\n    (typeof CategoryIcon)['BaremetalCategoryIcon']\n  >['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?: HTMLAnchorElement['href']\n  target?: HTMLAnchorElement['target']\n  rel?: HTMLAnchorElement['rel']\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  onToggle?: (toggle: boolean) => void\n  onClickPinUnpin?: (parameters: PinUnPinType) => 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 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  'data-testid'?: string\n}\n\nconst onDragStopTrigger = (event: DragEvent<HTMLDivElement>) => {\n  // eslint-disable-next-line no-param-reassign\n  event.currentTarget.style.opacity = '1'\n}\n\nexport const Item = memo(\n  ({\n    children,\n    categoryIcon,\n    categoryIconVariant,\n    label,\n    subLabel,\n    badgeText,\n    badgeSentiment,\n    href,\n    target,\n    rel,\n    onToggle,\n    onClickPinUnpin,\n    toggle,\n    active,\n    noPinButton,\n    type = 'default',\n    as,\n    disabled,\n    noExpand = false,\n    index,\n    id,\n    'data-testid': dataTestId,\n  }: ItemProps) => {\n    const context = useNavigation()\n    if (!context) {\n      throw new Error(\n        'Navigation.Item can only be used inside a NavigationProvider.',\n      )\n    }\n\n    const itemProvider = useContext(ItemContext)\n    const hasParents = !!itemProvider\n\n    const {\n      expanded,\n      locales,\n      pinnedFeature,\n      pinItem,\n      unpinItem,\n      pinnedItems,\n      pinLimit,\n      animation,\n      registerItem,\n      shouldAnimate,\n      animationType,\n    } = context\n\n    useEffect(\n      () => {\n        if (type !== 'pinnedGroup' && pinnedFeature) {\n          registerItem({ [id]: { label, active, onToggle, onClickPinUnpin } })\n        }\n      },\n      // eslint-disable-next-line react-hooks/exhaustive-deps\n      [active, id, label, registerItem],\n    )\n\n    const [internalExpanded, onToggleExpand] = useReducer(\n      prevState => !prevState,\n      Boolean(toggle),\n    )\n\n    const triggerToggle = useCallback(() => {\n      onToggleExpand()\n      onToggle?.(internalExpanded)\n    }, [internalExpanded, onToggle])\n\n    const PaddedStack =\n      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 = useMemo(\n      () => StyledContainer.withComponent(containerTag),\n      [containerTag],\n    )\n\n    const CategoryIconUsed = categoryIcon\n      ? CategoryIcon[\n          `${\n            categoryIcon.charAt(0).toUpperCase() + categoryIcon.slice(1)\n          }CategoryIcon` as keyof typeof CategoryIcon\n        ]\n      : null\n\n    const ArrowIcon = useMemo(\n      () => (internalExpanded ? ArrowDownIcon : ArrowRightIcon),\n      [internalExpanded],\n    )\n\n    const PinUnpinIcon = useMemo(\n      () => (isItemPinned ? StyledUnpinIcon : StyledPinIconOutline),\n      [isItemPinned],\n    )\n\n    const ariaExpanded = useMemo(() => {\n      if (hasHrefAndNoChildren && internalExpanded) {\n        return true\n      }\n\n      if (hasHrefAndNoChildren && !internalExpanded) {\n        return false\n      }\n\n      return undefined\n    }, [hasHrefAndNoChildren, internalExpanded])\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 onDragStart = useCallback(\n      (event: DragEvent<HTMLDivElement>) => {\n        if (expanded) {\n          event.dataTransfer.setData(\n            'text/plain',\n            JSON.stringify({ label, index }),\n          )\n          // eslint-disable-next-line no-param-reassign\n          event.currentTarget.style.opacity = '0.5'\n        }\n\n        return undefined\n      },\n      [expanded, index, label],\n    )\n\n    const onDragEnd = useCallback(\n      (event: DragEvent<HTMLDivElement>) =>\n        expanded ? onDragStopTrigger(event) : undefined,\n      [expanded],\n    )\n\n    // This content is when the navigation is expanded\n    if (expanded || (!expanded && animation === 'expand')) {\n      return (\n        <>\n          <Container\n            gap={1}\n            direction=\"row\"\n            alignItems={categoryIcon ? 'flex-start' : 'center'}\n            justifyContent=\"space-between\"\n            data-has-sub-label={!!subLabel}\n            onClick={triggerToggle}\n            aria-expanded={ariaExpanded}\n            href={href}\n            target={target}\n            rel={rel}\n            data-is-pinnable={shouldShowPinnedButton}\n            data-is-active={active}\n            data-animation={shouldAnimate ? animation : undefined}\n            data-animation-type={animationType}\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={onDragStart}\n            onDragEnd={onDragEnd}\n            id={id}\n            data-testid={dataTestId}\n          >\n            <Stack\n              direction=\"row\"\n              gap={1}\n              alignItems={categoryIcon ? 'flex-start' : 'center'}\n              justifyContent=\"center\"\n            >\n              {CategoryIconUsed ? (\n                <ContainerCategoryIcon\n                  alignItems=\"center\"\n                  justifyContent=\"center\"\n                >\n                  <CategoryIconUsed\n                    variant={active ? 'primary' : categoryIconVariant}\n                    disabled={disabled}\n                  />\n                </ContainerCategoryIcon>\n              ) : null}\n              {type === 'pinned' && expanded ? (\n                <GrabIcon\n                  sentiment=\"neutral\"\n                  prominence=\"weak\"\n                  size=\"small\"\n                  disabled={disabled}\n                />\n              ) : null}\n              <Stack>\n                {!animation ? (\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                    data-animation={animation}\n                    disabled={disabled}\n                    whiteSpace=\"pre-wrap\"\n                  >\n                    {label}\n                  </WrapText>\n                ) : null}\n                {subLabel && !animation ? (\n                  <WrapText\n                    as=\"span\"\n                    variant=\"caption\"\n                    sentiment=\"neutral\"\n                    prominence=\"weak\"\n                    data-animation={animation}\n                    disabled={disabled}\n                    whiteSpace=\"pre-wrap\"\n                  >\n                    {subLabel}\n                  </WrapText>\n                ) : null}\n              </Stack>\n            </Stack>\n            <Stack\n              direction=\"row\"\n              alignItems=\"center\"\n              gap={href ? 1 : undefined}\n            >\n              {badgeText || hasPinnedFeatureAndNoChildren ? (\n                <>\n                  {badgeText && !animation ? (\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                          aria-label={isItemPinned ? 'unpin' : 'pin'}\n                          size=\"xsmall\"\n                          variant=\"ghost\"\n                          sentiment={active ? 'primary' : 'neutral'}\n                          onClick={(event: MouseEvent<HTMLDivElement>) => {\n                            if (pinnedItems.length < pinLimit || isItemPinned) {\n                              event.preventDefault()\n                              event.stopPropagation() // This is to avoid click spread to the parent and change the routing\n                              let newValue: string[] | undefined\n                              if (isItemPinned) {\n                                newValue = unpinItem(id)\n                              } else {\n                                newValue = pinItem(id)\n                              }\n\n                              onClickPinUnpin?.({\n                                state: isItemPinned ? 'unpin' : 'pin',\n                                id,\n                                totalPinned: newValue,\n                              })\n                            }\n                          }}\n                          disabled={isItemPinned ? false : isPinDisabled}\n                        >\n                          <PinUnpinIcon\n                            size=\"medium\"\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 && target === '_blank' && !animation ? (\n                <AnimatedIcon\n                  sentiment=\"neutral\"\n                  prominence=\"default\"\n                  disabled={disabled}\n                />\n              ) : null}\n              {children ? (\n                <StackIcon gap={1} direction=\"row\" alignItems=\"center\">\n                  {!animation && !noExpand ? (\n                    <ArrowIcon sentiment=\"neutral\" prominence=\"weak\" />\n                  ) : null}\n                </StackIcon>\n              ) : null}\n            </Stack>\n          </Container>\n          {children ? (\n            <>\n              {!noExpand ? (\n                <ItemProvider>\n                  <Expandable opened={internalExpanded} animationDuration={0}>\n                    <PaddedStack width={animation ? '100%' : undefined}>\n                      {children}\n                    </PaddedStack>\n                  </Expandable>\n                </ItemProvider>\n              ) : (\n                <ItemProvider>\n                  <PaddedStack width={animation ? '100%' : undefined}>\n                    {children}\n                  </PaddedStack>\n                </ItemProvider>\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                  aria-label={label}\n                >\n                  {CategoryIconUsed ? (\n                    <Stack\n                      direction=\"row\"\n                      gap={1}\n                      alignItems=\"center\"\n                      justifyContent=\"center\"\n                    >\n                      <CategoryIconUsed\n                        variant={active ? 'primary' : categoryIconVariant}\n                      />\n                    </Stack>\n                  ) : null}\n                </Button>\n              }\n              placement=\"right\"\n            >\n              <ItemProvider>{children}</ItemProvider>\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                aria-label={label}\n              >\n                <Stack\n                  direction=\"row\"\n                  gap={1}\n                  alignItems=\"center\"\n                  justifyContent=\"center\"\n                >\n                  {CategoryIconUsed ? (\n                    <CategoryIconUsed\n                      variant={active ? 'primary' : categoryIconVariant}\n                    />\n                  ) : (\n                    <ConsoleCategoryIcon\n                      variant={active ? 'primary' : categoryIconVariant}\n                    />\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          target={target}\n          rel={rel}\n          borderless\n          active={active}\n          disabled={disabled}\n          sentiment={active ? 'primary' : 'neutral'}\n          isPinnable={shouldShowPinnedButton}\n          onClick={() => onToggle?.(!!active)}\n        >\n          <Stack\n            gap={1}\n            direction=\"row\"\n            alignItems=\"center\"\n            justifyContent=\"space-between\"\n            flex={1}\n            width=\"100%\"\n          >\n            {!animation ? (\n              <WrapText as=\"span\" variant=\"bodySmall\" whiteSpace=\"pre-wrap\">\n                {label}\n              </WrapText>\n            ) : null}\n            <Stack direction=\"row\">\n              {badgeText && !animation ? (\n                <StyledBadge\n                  sentiment={badgeSentiment}\n                  size=\"small\"\n                  prominence=\"strong\"\n                  disabled={disabled}\n                >\n                  {badgeText}\n                </StyledBadge>\n              ) : null}\n              {hasHrefAndNoChildren && target === '_blank' ? (\n                <AnimatedIcon\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                      aria-label={isItemPinned ? 'unpin' : 'pin'}\n                      variant=\"ghost\"\n                      sentiment={active ? 'primary' : 'neutral'}\n                      onClick={(event: MouseEvent<HTMLDivElement>) => {\n                        if (pinnedItems.length < pinLimit || isItemPinned) {\n                          event.preventDefault()\n                          event.stopPropagation() // This is to avoid click spread to the parent and change the routing\n\n                          let newValue: string[] | undefined\n                          if (isItemPinned) {\n                            newValue = unpinItem(id)\n                          } else {\n                            newValue = pinItem(id)\n                          }\n                          onClickPinUnpin?.({\n                            state: isItemPinned ? 'unpin' : 'pin',\n                            id,\n                            totalPinned: newValue,\n                          })\n                        }\n                      }}\n                      disabled={isItemPinned ? false : isPinDisabled}\n                    >\n                      <PinUnpinIcon\n                        size=\"medium\"\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={target}\n              rel={rel}\n            >\n              <AnimatedIcon sentiment=\"neutral\" prominence=\"weak\" />\n            </Container>\n          </MenuStack>\n        </Tooltip>\n      )\n    }\n\n    return null\n  },\n)\n"]} */"));
229
229
  const ContainerCategoryIcon = /* @__PURE__ */ _styled__default.default(ui.Stack, process.env.NODE_ENV === "production" ? {
230
230
  target: "e134hokc0"
231
231
  } : {
@@ -236,7 +236,7 @@ const ContainerCategoryIcon = /* @__PURE__ */ _styled__default.default(ui.Stack,
236
236
  styles: "min-width:20px"
237
237
  } : {
238
238
  name: "d47oax",
239
- styles: "min-width:20px/*# 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":"AAsQ2C","file":"/home/runner/work/ultraviolet/ultraviolet/packages/plus/src/components/Navigation/components/Item.tsx","sourcesContent":["'use client'\n\nimport { css } from '@emotion/react'\nimport styled from '@emotion/styled'\nimport {\n  ArrowDownIcon,\n  ArrowRightIcon,\n  DragIcon,\n  OpenInNewIcon,\n  PinOutlineIcon,\n  UnpinIcon,\n} from '@ultraviolet/icons'\nimport * as CategoryIcon from '@ultraviolet/icons/category'\nimport { ConsoleCategoryIcon } from '@ultraviolet/icons/category'\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  isValidElement,\n  memo,\n  useCallback,\n  useContext,\n  useEffect,\n  useMemo,\n  useReducer,\n} from 'react'\nimport type { PascalToCamelCaseWithoutSuffix } from '../../../types'\nimport { useNavigation } from '../NavigationProvider'\nimport { ANIMATION_DURATION, shrinkHeight } from '../constants'\nimport type { PinUnPinType } from '../types'\nimport { ItemContext, ItemProvider } from './ItemProvider'\n\nconst RelativeDiv = styled.div`\n  position: relative;\n`\n\nconst StyledPinIconOutline = styled(PinOutlineIcon, {\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 }) =>\n      active ? `background: ${theme.colors.primary.backgroundHover};` : null}\n  }\n`\n\nconst StyledUnpinIcon = StyledPinIconOutline.withComponent(UnpinIcon)\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(DragIcon)`\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  &: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(OpenInNewIcon)``\n\nconst WrapText = styled(Text)`\n  overflow-wrap: anywhere;\n  overflow: hidden;\n  display: -webkit-box;\n  -webkit-box-orient: vertical;\n  -webkit-line-clamp: 2;\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 }) => 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\"][data-animation-type=\"complex\"] {\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\"][data-animation-type=\"complex\"] {\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 StackIcon = styled(Stack)`\n  padding-top: ${({ theme }) => theme.space['0.5']};\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?: PascalToCamelCaseWithoutSuffix<\n    keyof typeof CategoryIcon,\n    'CategoryIcon'\n  >\n  categoryIconVariant?: ComponentProps<\n    (typeof CategoryIcon)['BaremetalCategoryIcon']\n  >['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?: HTMLAnchorElement['href']\n  target?: HTMLAnchorElement['target']\n  rel?: HTMLAnchorElement['rel']\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  onToggle?: (toggle: boolean) => void\n  onClickPinUnpin?: (parameters: PinUnPinType) => 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 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  'data-testid'?: string\n}\n\nconst onDragStopTrigger = (event: DragEvent<HTMLDivElement>) => {\n  // eslint-disable-next-line no-param-reassign\n  event.currentTarget.style.opacity = '1'\n}\n\nexport const Item = memo(\n  ({\n    children,\n    categoryIcon,\n    categoryIconVariant,\n    label,\n    subLabel,\n    badgeText,\n    badgeSentiment,\n    href,\n    target,\n    rel,\n    onToggle,\n    onClickPinUnpin,\n    toggle,\n    active,\n    noPinButton,\n    type = 'default',\n    as,\n    disabled,\n    noExpand = false,\n    index,\n    id,\n    'data-testid': dataTestId,\n  }: ItemProps) => {\n    const context = useNavigation()\n    if (!context) {\n      throw new Error(\n        'Navigation.Item can only be used inside a NavigationProvider.',\n      )\n    }\n\n    const itemProvider = useContext(ItemContext)\n    const hasParents = !!itemProvider\n\n    const {\n      expanded,\n      locales,\n      pinnedFeature,\n      pinItem,\n      unpinItem,\n      pinnedItems,\n      pinLimit,\n      animation,\n      registerItem,\n      shouldAnimate,\n      animationType,\n    } = context\n\n    useEffect(\n      () => {\n        if (type !== 'pinnedGroup') {\n          registerItem({ [id]: { label, active, onToggle, onClickPinUnpin } })\n        }\n      },\n      // eslint-disable-next-line react-hooks/exhaustive-deps\n      [active, id, label, registerItem],\n    )\n\n    const [internalExpanded, onToggleExpand] = useReducer(\n      prevState => !prevState,\n      Boolean(toggle),\n    )\n\n    const triggerToggle = useCallback(() => {\n      onToggleExpand()\n      onToggle?.(internalExpanded)\n    }, [internalExpanded, onToggle])\n\n    const PaddedStack =\n      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 = useMemo(\n      () => StyledContainer.withComponent(containerTag),\n      [containerTag],\n    )\n\n    const CategoryIconUsed = categoryIcon\n      ? CategoryIcon[\n          `${\n            categoryIcon.charAt(0).toUpperCase() + categoryIcon.slice(1)\n          }CategoryIcon` as keyof typeof CategoryIcon\n        ]\n      : null\n\n    const ArrowIcon = useMemo(\n      () => (internalExpanded ? ArrowDownIcon : ArrowRightIcon),\n      [internalExpanded],\n    )\n\n    const PinUnpinIcon = useMemo(\n      () => (isItemPinned ? StyledUnpinIcon : StyledPinIconOutline),\n      [isItemPinned],\n    )\n\n    const ariaExpanded = useMemo(() => {\n      if (hasHrefAndNoChildren && internalExpanded) {\n        return true\n      }\n\n      if (hasHrefAndNoChildren && !internalExpanded) {\n        return false\n      }\n\n      return undefined\n    }, [hasHrefAndNoChildren, internalExpanded])\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 onDragStart = useCallback(\n      (event: DragEvent<HTMLDivElement>) => {\n        if (expanded) {\n          event.dataTransfer.setData(\n            'text/plain',\n            JSON.stringify({ label, index }),\n          )\n          // eslint-disable-next-line no-param-reassign\n          event.currentTarget.style.opacity = '0.5'\n        }\n\n        return undefined\n      },\n      [expanded, index, label],\n    )\n\n    const onDragEnd = useCallback(\n      (event: DragEvent<HTMLDivElement>) =>\n        expanded ? onDragStopTrigger(event) : undefined,\n      [expanded],\n    )\n\n    // This content is when the navigation is expanded\n    if (expanded || (!expanded && animation === 'expand')) {\n      return (\n        <>\n          <Container\n            gap={1}\n            direction=\"row\"\n            alignItems={categoryIcon ? 'flex-start' : 'center'}\n            justifyContent=\"space-between\"\n            data-has-sub-label={!!subLabel}\n            onClick={triggerToggle}\n            aria-expanded={ariaExpanded}\n            href={href}\n            target={target}\n            rel={rel}\n            data-is-pinnable={shouldShowPinnedButton}\n            data-is-active={active}\n            data-animation={shouldAnimate ? animation : undefined}\n            data-animation-type={animationType}\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={onDragStart}\n            onDragEnd={onDragEnd}\n            id={id}\n            data-testid={dataTestId}\n          >\n            <Stack\n              direction=\"row\"\n              gap={1}\n              alignItems={categoryIcon ? 'flex-start' : 'center'}\n              justifyContent=\"center\"\n            >\n              {CategoryIconUsed ? (\n                <ContainerCategoryIcon\n                  alignItems=\"center\"\n                  justifyContent=\"center\"\n                >\n                  <CategoryIconUsed\n                    variant={active ? 'primary' : categoryIconVariant}\n                    disabled={disabled}\n                  />\n                </ContainerCategoryIcon>\n              ) : null}\n              {type === 'pinned' && expanded ? (\n                <GrabIcon\n                  sentiment=\"neutral\"\n                  prominence=\"weak\"\n                  size=\"small\"\n                  disabled={disabled}\n                />\n              ) : null}\n              <Stack>\n                {!animation ? (\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                    data-animation={animation}\n                    disabled={disabled}\n                    whiteSpace=\"pre-wrap\"\n                  >\n                    {label}\n                  </WrapText>\n                ) : null}\n                {subLabel && !animation ? (\n                  <WrapText\n                    as=\"span\"\n                    variant=\"caption\"\n                    sentiment=\"neutral\"\n                    prominence=\"weak\"\n                    data-animation={animation}\n                    disabled={disabled}\n                    whiteSpace=\"pre-wrap\"\n                  >\n                    {subLabel}\n                  </WrapText>\n                ) : null}\n              </Stack>\n            </Stack>\n            <Stack\n              direction=\"row\"\n              alignItems=\"center\"\n              gap={href ? 1 : undefined}\n            >\n              {badgeText || hasPinnedFeatureAndNoChildren ? (\n                <>\n                  {badgeText && !animation ? (\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                          aria-label={isItemPinned ? 'unpin' : 'pin'}\n                          size=\"xsmall\"\n                          variant=\"ghost\"\n                          sentiment={active ? 'primary' : 'neutral'}\n                          onClick={(event: MouseEvent<HTMLDivElement>) => {\n                            if (pinnedItems.length < pinLimit || isItemPinned) {\n                              event.preventDefault()\n                              event.stopPropagation() // This is to avoid click spread to the parent and change the routing\n                              let newValue: string[] | undefined\n                              if (isItemPinned) {\n                                newValue = unpinItem(id)\n                              } else {\n                                newValue = pinItem(id)\n                              }\n\n                              onClickPinUnpin?.({\n                                state: isItemPinned ? 'unpin' : 'pin',\n                                id,\n                                totalPinned: newValue,\n                              })\n                            }\n                          }}\n                          disabled={isItemPinned ? false : isPinDisabled}\n                        >\n                          <PinUnpinIcon\n                            size=\"medium\"\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 && target === '_blank' && !animation ? (\n                <AnimatedIcon\n                  sentiment=\"neutral\"\n                  prominence=\"default\"\n                  disabled={disabled}\n                />\n              ) : null}\n              {children ? (\n                <StackIcon gap={1} direction=\"row\" alignItems=\"center\">\n                  {!animation && !noExpand ? (\n                    <ArrowIcon sentiment=\"neutral\" prominence=\"weak\" />\n                  ) : null}\n                </StackIcon>\n              ) : null}\n            </Stack>\n          </Container>\n          {children ? (\n            <>\n              {!noExpand ? (\n                <ItemProvider>\n                  <Expandable opened={internalExpanded} animationDuration={0}>\n                    <PaddedStack width={animation ? '100%' : undefined}>\n                      {children}\n                    </PaddedStack>\n                  </Expandable>\n                </ItemProvider>\n              ) : (\n                <ItemProvider>\n                  <PaddedStack width={animation ? '100%' : undefined}>\n                    {children}\n                  </PaddedStack>\n                </ItemProvider>\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                  aria-label={label}\n                >\n                  {CategoryIconUsed ? (\n                    <Stack\n                      direction=\"row\"\n                      gap={1}\n                      alignItems=\"center\"\n                      justifyContent=\"center\"\n                    >\n                      <CategoryIconUsed\n                        variant={active ? 'primary' : categoryIconVariant}\n                      />\n                    </Stack>\n                  ) : null}\n                </Button>\n              }\n              placement=\"right\"\n            >\n              <ItemProvider>{children}</ItemProvider>\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                aria-label={label}\n              >\n                <Stack\n                  direction=\"row\"\n                  gap={1}\n                  alignItems=\"center\"\n                  justifyContent=\"center\"\n                >\n                  {CategoryIconUsed ? (\n                    <CategoryIconUsed\n                      variant={active ? 'primary' : categoryIconVariant}\n                    />\n                  ) : (\n                    <ConsoleCategoryIcon\n                      variant={active ? 'primary' : categoryIconVariant}\n                    />\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          target={target}\n          rel={rel}\n          borderless\n          active={active}\n          disabled={disabled}\n          sentiment={active ? 'primary' : 'neutral'}\n          isPinnable={shouldShowPinnedButton}\n          onClick={() => onToggle?.(!!active)}\n        >\n          <Stack\n            gap={1}\n            direction=\"row\"\n            alignItems=\"center\"\n            justifyContent=\"space-between\"\n            flex={1}\n            width=\"100%\"\n          >\n            {!animation ? (\n              <WrapText as=\"span\" variant=\"bodySmall\" whiteSpace=\"pre-wrap\">\n                {label}\n              </WrapText>\n            ) : null}\n            <Stack direction=\"row\">\n              {badgeText && !animation ? (\n                <StyledBadge\n                  sentiment={badgeSentiment}\n                  size=\"small\"\n                  prominence=\"strong\"\n                  disabled={disabled}\n                >\n                  {badgeText}\n                </StyledBadge>\n              ) : null}\n              {hasHrefAndNoChildren && target === '_blank' ? (\n                <AnimatedIcon\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                      aria-label={isItemPinned ? 'unpin' : 'pin'}\n                      variant=\"ghost\"\n                      sentiment={active ? 'primary' : 'neutral'}\n                      onClick={(event: MouseEvent<HTMLDivElement>) => {\n                        if (pinnedItems.length < pinLimit || isItemPinned) {\n                          event.preventDefault()\n                          event.stopPropagation() // This is to avoid click spread to the parent and change the routing\n\n                          let newValue: string[] | undefined\n                          if (isItemPinned) {\n                            newValue = unpinItem(id)\n                          } else {\n                            newValue = pinItem(id)\n                          }\n                          onClickPinUnpin?.({\n                            state: isItemPinned ? 'unpin' : 'pin',\n                            id,\n                            totalPinned: newValue,\n                          })\n                        }\n                      }}\n                      disabled={isItemPinned ? false : isPinDisabled}\n                    >\n                      <PinUnpinIcon\n                        size=\"medium\"\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={target}\n              rel={rel}\n            >\n              <AnimatedIcon sentiment=\"neutral\" prominence=\"weak\" />\n            </Container>\n          </MenuStack>\n        </Tooltip>\n      )\n    }\n\n    return null\n  },\n)\n"]} */",
239
+ styles: "min-width:20px/*# 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":"AAsQ2C","file":"/home/runner/work/ultraviolet/ultraviolet/packages/plus/src/components/Navigation/components/Item.tsx","sourcesContent":["'use client'\n\nimport { css } from '@emotion/react'\nimport styled from '@emotion/styled'\nimport {\n  ArrowDownIcon,\n  ArrowRightIcon,\n  DragIcon,\n  OpenInNewIcon,\n  PinOutlineIcon,\n  UnpinIcon,\n} from '@ultraviolet/icons'\nimport * as CategoryIcon from '@ultraviolet/icons/category'\nimport { ConsoleCategoryIcon } from '@ultraviolet/icons/category'\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  isValidElement,\n  memo,\n  useCallback,\n  useContext,\n  useEffect,\n  useMemo,\n  useReducer,\n} from 'react'\nimport type { PascalToCamelCaseWithoutSuffix } from '../../../types'\nimport { useNavigation } from '../NavigationProvider'\nimport { ANIMATION_DURATION, shrinkHeight } from '../constants'\nimport type { PinUnPinType } from '../types'\nimport { ItemContext, ItemProvider } from './ItemProvider'\n\nconst RelativeDiv = styled.div`\n  position: relative;\n`\n\nconst StyledPinIconOutline = styled(PinOutlineIcon, {\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 }) =>\n      active ? `background: ${theme.colors.primary.backgroundHover};` : null}\n  }\n`\n\nconst StyledUnpinIcon = StyledPinIconOutline.withComponent(UnpinIcon)\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(DragIcon)`\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  &: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(OpenInNewIcon)``\n\nconst WrapText = styled(Text)`\n  overflow-wrap: anywhere;\n  overflow: hidden;\n  display: -webkit-box;\n  -webkit-box-orient: vertical;\n  -webkit-line-clamp: 2;\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 }) => 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\"][data-animation-type=\"complex\"] {\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\"][data-animation-type=\"complex\"] {\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 StackIcon = styled(Stack)`\n  padding-top: ${({ theme }) => theme.space['0.5']};\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?: PascalToCamelCaseWithoutSuffix<\n    keyof typeof CategoryIcon,\n    'CategoryIcon'\n  >\n  categoryIconVariant?: ComponentProps<\n    (typeof CategoryIcon)['BaremetalCategoryIcon']\n  >['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?: HTMLAnchorElement['href']\n  target?: HTMLAnchorElement['target']\n  rel?: HTMLAnchorElement['rel']\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  onToggle?: (toggle: boolean) => void\n  onClickPinUnpin?: (parameters: PinUnPinType) => 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 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  'data-testid'?: string\n}\n\nconst onDragStopTrigger = (event: DragEvent<HTMLDivElement>) => {\n  // eslint-disable-next-line no-param-reassign\n  event.currentTarget.style.opacity = '1'\n}\n\nexport const Item = memo(\n  ({\n    children,\n    categoryIcon,\n    categoryIconVariant,\n    label,\n    subLabel,\n    badgeText,\n    badgeSentiment,\n    href,\n    target,\n    rel,\n    onToggle,\n    onClickPinUnpin,\n    toggle,\n    active,\n    noPinButton,\n    type = 'default',\n    as,\n    disabled,\n    noExpand = false,\n    index,\n    id,\n    'data-testid': dataTestId,\n  }: ItemProps) => {\n    const context = useNavigation()\n    if (!context) {\n      throw new Error(\n        'Navigation.Item can only be used inside a NavigationProvider.',\n      )\n    }\n\n    const itemProvider = useContext(ItemContext)\n    const hasParents = !!itemProvider\n\n    const {\n      expanded,\n      locales,\n      pinnedFeature,\n      pinItem,\n      unpinItem,\n      pinnedItems,\n      pinLimit,\n      animation,\n      registerItem,\n      shouldAnimate,\n      animationType,\n    } = context\n\n    useEffect(\n      () => {\n        if (type !== 'pinnedGroup' && pinnedFeature) {\n          registerItem({ [id]: { label, active, onToggle, onClickPinUnpin } })\n        }\n      },\n      // eslint-disable-next-line react-hooks/exhaustive-deps\n      [active, id, label, registerItem],\n    )\n\n    const [internalExpanded, onToggleExpand] = useReducer(\n      prevState => !prevState,\n      Boolean(toggle),\n    )\n\n    const triggerToggle = useCallback(() => {\n      onToggleExpand()\n      onToggle?.(internalExpanded)\n    }, [internalExpanded, onToggle])\n\n    const PaddedStack =\n      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 = useMemo(\n      () => StyledContainer.withComponent(containerTag),\n      [containerTag],\n    )\n\n    const CategoryIconUsed = categoryIcon\n      ? CategoryIcon[\n          `${\n            categoryIcon.charAt(0).toUpperCase() + categoryIcon.slice(1)\n          }CategoryIcon` as keyof typeof CategoryIcon\n        ]\n      : null\n\n    const ArrowIcon = useMemo(\n      () => (internalExpanded ? ArrowDownIcon : ArrowRightIcon),\n      [internalExpanded],\n    )\n\n    const PinUnpinIcon = useMemo(\n      () => (isItemPinned ? StyledUnpinIcon : StyledPinIconOutline),\n      [isItemPinned],\n    )\n\n    const ariaExpanded = useMemo(() => {\n      if (hasHrefAndNoChildren && internalExpanded) {\n        return true\n      }\n\n      if (hasHrefAndNoChildren && !internalExpanded) {\n        return false\n      }\n\n      return undefined\n    }, [hasHrefAndNoChildren, internalExpanded])\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 onDragStart = useCallback(\n      (event: DragEvent<HTMLDivElement>) => {\n        if (expanded) {\n          event.dataTransfer.setData(\n            'text/plain',\n            JSON.stringify({ label, index }),\n          )\n          // eslint-disable-next-line no-param-reassign\n          event.currentTarget.style.opacity = '0.5'\n        }\n\n        return undefined\n      },\n      [expanded, index, label],\n    )\n\n    const onDragEnd = useCallback(\n      (event: DragEvent<HTMLDivElement>) =>\n        expanded ? onDragStopTrigger(event) : undefined,\n      [expanded],\n    )\n\n    // This content is when the navigation is expanded\n    if (expanded || (!expanded && animation === 'expand')) {\n      return (\n        <>\n          <Container\n            gap={1}\n            direction=\"row\"\n            alignItems={categoryIcon ? 'flex-start' : 'center'}\n            justifyContent=\"space-between\"\n            data-has-sub-label={!!subLabel}\n            onClick={triggerToggle}\n            aria-expanded={ariaExpanded}\n            href={href}\n            target={target}\n            rel={rel}\n            data-is-pinnable={shouldShowPinnedButton}\n            data-is-active={active}\n            data-animation={shouldAnimate ? animation : undefined}\n            data-animation-type={animationType}\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={onDragStart}\n            onDragEnd={onDragEnd}\n            id={id}\n            data-testid={dataTestId}\n          >\n            <Stack\n              direction=\"row\"\n              gap={1}\n              alignItems={categoryIcon ? 'flex-start' : 'center'}\n              justifyContent=\"center\"\n            >\n              {CategoryIconUsed ? (\n                <ContainerCategoryIcon\n                  alignItems=\"center\"\n                  justifyContent=\"center\"\n                >\n                  <CategoryIconUsed\n                    variant={active ? 'primary' : categoryIconVariant}\n                    disabled={disabled}\n                  />\n                </ContainerCategoryIcon>\n              ) : null}\n              {type === 'pinned' && expanded ? (\n                <GrabIcon\n                  sentiment=\"neutral\"\n                  prominence=\"weak\"\n                  size=\"small\"\n                  disabled={disabled}\n                />\n              ) : null}\n              <Stack>\n                {!animation ? (\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                    data-animation={animation}\n                    disabled={disabled}\n                    whiteSpace=\"pre-wrap\"\n                  >\n                    {label}\n                  </WrapText>\n                ) : null}\n                {subLabel && !animation ? (\n                  <WrapText\n                    as=\"span\"\n                    variant=\"caption\"\n                    sentiment=\"neutral\"\n                    prominence=\"weak\"\n                    data-animation={animation}\n                    disabled={disabled}\n                    whiteSpace=\"pre-wrap\"\n                  >\n                    {subLabel}\n                  </WrapText>\n                ) : null}\n              </Stack>\n            </Stack>\n            <Stack\n              direction=\"row\"\n              alignItems=\"center\"\n              gap={href ? 1 : undefined}\n            >\n              {badgeText || hasPinnedFeatureAndNoChildren ? (\n                <>\n                  {badgeText && !animation ? (\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                          aria-label={isItemPinned ? 'unpin' : 'pin'}\n                          size=\"xsmall\"\n                          variant=\"ghost\"\n                          sentiment={active ? 'primary' : 'neutral'}\n                          onClick={(event: MouseEvent<HTMLDivElement>) => {\n                            if (pinnedItems.length < pinLimit || isItemPinned) {\n                              event.preventDefault()\n                              event.stopPropagation() // This is to avoid click spread to the parent and change the routing\n                              let newValue: string[] | undefined\n                              if (isItemPinned) {\n                                newValue = unpinItem(id)\n                              } else {\n                                newValue = pinItem(id)\n                              }\n\n                              onClickPinUnpin?.({\n                                state: isItemPinned ? 'unpin' : 'pin',\n                                id,\n                                totalPinned: newValue,\n                              })\n                            }\n                          }}\n                          disabled={isItemPinned ? false : isPinDisabled}\n                        >\n                          <PinUnpinIcon\n                            size=\"medium\"\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 && target === '_blank' && !animation ? (\n                <AnimatedIcon\n                  sentiment=\"neutral\"\n                  prominence=\"default\"\n                  disabled={disabled}\n                />\n              ) : null}\n              {children ? (\n                <StackIcon gap={1} direction=\"row\" alignItems=\"center\">\n                  {!animation && !noExpand ? (\n                    <ArrowIcon sentiment=\"neutral\" prominence=\"weak\" />\n                  ) : null}\n                </StackIcon>\n              ) : null}\n            </Stack>\n          </Container>\n          {children ? (\n            <>\n              {!noExpand ? (\n                <ItemProvider>\n                  <Expandable opened={internalExpanded} animationDuration={0}>\n                    <PaddedStack width={animation ? '100%' : undefined}>\n                      {children}\n                    </PaddedStack>\n                  </Expandable>\n                </ItemProvider>\n              ) : (\n                <ItemProvider>\n                  <PaddedStack width={animation ? '100%' : undefined}>\n                    {children}\n                  </PaddedStack>\n                </ItemProvider>\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                  aria-label={label}\n                >\n                  {CategoryIconUsed ? (\n                    <Stack\n                      direction=\"row\"\n                      gap={1}\n                      alignItems=\"center\"\n                      justifyContent=\"center\"\n                    >\n                      <CategoryIconUsed\n                        variant={active ? 'primary' : categoryIconVariant}\n                      />\n                    </Stack>\n                  ) : null}\n                </Button>\n              }\n              placement=\"right\"\n            >\n              <ItemProvider>{children}</ItemProvider>\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                aria-label={label}\n              >\n                <Stack\n                  direction=\"row\"\n                  gap={1}\n                  alignItems=\"center\"\n                  justifyContent=\"center\"\n                >\n                  {CategoryIconUsed ? (\n                    <CategoryIconUsed\n                      variant={active ? 'primary' : categoryIconVariant}\n                    />\n                  ) : (\n                    <ConsoleCategoryIcon\n                      variant={active ? 'primary' : categoryIconVariant}\n                    />\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          target={target}\n          rel={rel}\n          borderless\n          active={active}\n          disabled={disabled}\n          sentiment={active ? 'primary' : 'neutral'}\n          isPinnable={shouldShowPinnedButton}\n          onClick={() => onToggle?.(!!active)}\n        >\n          <Stack\n            gap={1}\n            direction=\"row\"\n            alignItems=\"center\"\n            justifyContent=\"space-between\"\n            flex={1}\n            width=\"100%\"\n          >\n            {!animation ? (\n              <WrapText as=\"span\" variant=\"bodySmall\" whiteSpace=\"pre-wrap\">\n                {label}\n              </WrapText>\n            ) : null}\n            <Stack direction=\"row\">\n              {badgeText && !animation ? (\n                <StyledBadge\n                  sentiment={badgeSentiment}\n                  size=\"small\"\n                  prominence=\"strong\"\n                  disabled={disabled}\n                >\n                  {badgeText}\n                </StyledBadge>\n              ) : null}\n              {hasHrefAndNoChildren && target === '_blank' ? (\n                <AnimatedIcon\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                      aria-label={isItemPinned ? 'unpin' : 'pin'}\n                      variant=\"ghost\"\n                      sentiment={active ? 'primary' : 'neutral'}\n                      onClick={(event: MouseEvent<HTMLDivElement>) => {\n                        if (pinnedItems.length < pinLimit || isItemPinned) {\n                          event.preventDefault()\n                          event.stopPropagation() // This is to avoid click spread to the parent and change the routing\n\n                          let newValue: string[] | undefined\n                          if (isItemPinned) {\n                            newValue = unpinItem(id)\n                          } else {\n                            newValue = pinItem(id)\n                          }\n                          onClickPinUnpin?.({\n                            state: isItemPinned ? 'unpin' : 'pin',\n                            id,\n                            totalPinned: newValue,\n                          })\n                        }\n                      }}\n                      disabled={isItemPinned ? false : isPinDisabled}\n                    >\n                      <PinUnpinIcon\n                        size=\"medium\"\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={target}\n              rel={rel}\n            >\n              <AnimatedIcon sentiment=\"neutral\" prominence=\"weak\" />\n            </Container>\n          </MenuStack>\n        </Tooltip>\n      )\n    }\n\n    return null\n  },\n)\n"]} */",
240
240
  toString: _EMOTION_STRINGIFIED_CSS_ERROR__
241
241
  });
242
242
  const onDragStopTrigger = (event) => {
@@ -287,7 +287,7 @@ const Item = react.memo(({
287
287
  } = context;
288
288
  react.useEffect(
289
289
  () => {
290
- if (type !== "pinnedGroup") {
290
+ if (type !== "pinnedGroup" && pinnedFeature) {
291
291
  registerItem({
292
292
  [id]: {
293
293
  label,