@codecademy/gamut
68.5.068.5.1-alpha.a6e8fa.0
dist/Menu/elements.js~
dist/Menu/elements.jsModified+6−6
Index: package/dist/Menu/elements.js
===================================================================
--- package/dist/Menu/elements.js
+++ package/dist/Menu/elements.js
@@ -33,9 +33,9 @@
showBorder: {
border: 1,
borderRadius: 'sm'
}
-}), sharedStates, listProps, process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../src/Menu/elements.tsx"],"names":[],"mappings":"AA6CmB","file":"../../src/Menu/elements.tsx","sourcesContent":["import {\n  styledOptions,\n  system,\n  transitionConcat,\n} from '@codecademy/gamut-styles';\nimport { StyleProps, variance } from '@codecademy/variance';\nimport styled from '@emotion/styled';\nimport isObject from 'lodash/isObject';\nimport { ComponentProps, forwardRef } from 'react';\n\nimport { sharedStates } from '../Box/props';\nimport { resetStyles, Selectors } from '../ButtonBase/ButtonBase';\nimport { ToolTip, ToolTipProps } from '../Tip/ToolTip';\nimport { MenuItem } from './MenuItem';\n\nenum MenuItemSelectors {\n  OUTLINE = '&:after',\n  OUTLINE_FOCUS_VISIBLE = '&:focus-visible:after',\n}\n\ntype ListStyleProps = StyleProps<typeof listProps>;\n\ntype StyleStateProps = StyleProps<typeof sharedStates>;\n\nconst listProps = variance.compose(\n  system.layout,\n  system.typography,\n  system.space,\n  system.positioning,\n  system.border,\n  system.color\n);\n\nexport interface ListProps extends ListStyleProps, StyleStateProps {\n  /** How offset spacing should be */\n  spacing?: 'normal' | 'condensed';\n  /** Menu variants for specific use cases and styles */\n  variant?: 'popover' | 'fixed';\n  /** is root menu */\n  root?: boolean;\n  /** bordered */\n  as?: 'ul' | 'ol';\n  showBorder?: boolean;\n}\n\nconst StyledList = styled('ul', styledOptions<'ul'>())<ListProps>(\n  system.css({\n    listStyle: 'none',\n    width: 1,\n    bg: 'inherit',\n    display: 'inline-block',\n    pl: 24,\n    WebkitFontSmoothing: 'antialiased',\n    MozOsxFontSmoothing: 'grayscale',\n  }),\n  system.states({\n    root: {\n      bg: 'background',\n      p: 0,\n    },\n    showBorder: {\n      border: 1,\n      borderRadius: 'sm',\n    },\n  }),\n  sharedStates,\n  listProps\n);\n\nexport const List = forwardRef<\n  HTMLUListElement,\n  ComponentProps<typeof StyledList>\n>(({ context = true, m = 0, root = true, variant, ...rest }, ref) => (\n  <StyledList\n    context={context}\n    m={m}\n    ref={ref}\n    root={root}\n    showBorder={variant !== 'fixed'}\n    variant={variant}\n    {...rest}\n  />\n));\n\nconst interactiveVariants = system.variant({\n  base: {\n    display: 'flex',\n    alignItems: 'center',\n    cursor: 'pointer',\n    width: 1,\n    zIndex: 1,\n    px: 24,\n    py: 12,\n    position: 'relative',\n    transition: transitionConcat(\n      ['color', 'background-color', 'border-color'],\n      'fast',\n      'linear'\n    ),\n    [Selectors.FOCUS_VISIBLE]: {\n      outline: 'none',\n    },\n    [MenuItemSelectors.OUTLINE]: {\n      content: \"''\",\n      position: 'absolute',\n      inset: 4,\n      borderRadius: 'md',\n      border: 2,\n      borderColor: 'primary',\n      opacity: 0,\n      zIndex: -1,\n    },\n    [MenuItemSelectors.OUTLINE_FOCUS_VISIBLE]: {\n      opacity: 1,\n    },\n  },\n  variants: {\n    select: {\n      [Selectors.DISABLED]: {\n        pointerEvents: 'none',\n      },\n      [Selectors.HOVER]: {\n        bg: 'background-hover',\n      },\n    },\n    link: {\n      [Selectors.BEFORE]: {\n        bg: 'inherit',\n        position: 'absolute',\n        display: 'inline-block',\n        left: 0,\n        width: 6,\n      },\n      [Selectors.HOVER]: {\n        textColor: 'primary',\n      },\n    },\n  },\n});\n\nconst activeStates = system.states({\n  selected: {\n    bg: 'background-selected',\n  },\n  active: {\n    fontWeight: 700,\n  },\n  'active-navlink': {\n    fontWeight: 700,\n    bg: 'background-selected',\n    [Selectors.BEFORE]: {\n      content: \"''\",\n      bg: 'secondary',\n    },\n  },\n  // Is named isDisabled to avoid conflicts with the HTML `disabled` attribute\n  isDisabled: {\n    bg: 'inherit',\n    cursor: 'not-allowed',\n    fontWeight: 400,\n    textColor: 'text-disabled',\n    [Selectors.HOVER]: {\n      textColor: 'text-disabled',\n      textDecoration: 'none',\n    },\n    [Selectors.BEFORE]: {\n      content: \"''\",\n      bg: 'inherit',\n    },\n  },\n});\n\nconst sizeVariants = system.variant({\n  prop: 'spacing',\n  variants: {\n    condensed: {\n      lineHeight: 'title',\n      minHeight: 40,\n      py: 8,\n      fontSize: 14,\n      [Selectors.BEFORE]: {\n        minHeight: 40,\n      },\n    },\n    normal: {\n      fontSize: 16,\n      minHeight: 48,\n      [Selectors.BEFORE]: {\n        minHeight: 48,\n      },\n    },\n  },\n});\n\nexport interface ListItemProps\n  extends ListStyleProps,\n    StyleStateProps,\n    StyleProps<typeof interactiveVariants>,\n    StyleProps<typeof activeStates>,\n    StyleProps<typeof sizeVariants> {}\n\nexport const ListItem = styled('li', styledOptions<'li'>())<ListItemProps>(\n  interactiveVariants,\n  activeStates,\n  sizeVariants,\n  sharedStates,\n  listProps\n);\n\nexport interface ListLinkProps extends ListItemProps {\n  active?: boolean;\n  navlink?: boolean;\n}\n\nconst StyledListLink = styled('a', styledOptions<'a'>())<ListLinkProps>(\n  resetStyles,\n  interactiveVariants,\n  activeStates,\n  sizeVariants,\n  sharedStates,\n  listProps\n);\n\nexport const ListLink = forwardRef<\n  HTMLAnchorElement,\n  ComponentProps<typeof StyledListLink>\n>(({ zIndex = 1, ...rest }, ref) => (\n  <StyledListLink ref={ref} zIndex={zIndex} {...rest} />\n));\n\nexport const ListButton = styled(\n  'button',\n  styledOptions<'button'>()\n)<ListLinkProps>(\n  resetStyles,\n  interactiveVariants,\n  activeStates,\n  sizeVariants,\n  sharedStates,\n  listProps\n);\n\nexport const MenuToolTipWrapper: React.FC<\n  Pick<ComponentProps<typeof MenuItem>, 'children' | 'label'> & {\n    tipId: string;\n  }\n> = ({ children, label, tipId }) => {\n  if (!label) {\n    return <>{children}</>;\n  }\n\n  const defaultTipProps = {\n    placement: 'floating',\n    id: tipId,\n    inheritDims: true,\n    shouldRenderAriaTip: false,\n  };\n\n  const wrapperProps =\n    label && isObject(label)\n      ? {\n          ...defaultTipProps,\n          ...label,\n        }\n      : {\n          info: label,\n          ...defaultTipProps,\n        };\n\n  return <ToolTip {...(wrapperProps as ToolTipProps)}>{children}</ToolTip>;\n};\n"]} */");
+}), sharedStates, listProps, process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../src/Menu/elements.tsx"],"names":[],"mappings":"AA6CmB","file":"../../src/Menu/elements.tsx","sourcesContent":["import {\n  styledOptions,\n  system,\n  transitionConcat,\n} from '@codecademy/gamut-styles';\nimport { StyleProps, variance } from '@codecademy/variance';\nimport styled from '@emotion/styled';\nimport isObject from 'lodash/isObject';\nimport { ComponentProps, forwardRef } from 'react';\n\nimport { sharedStates } from '../Box/props';\nimport { resetStyles, Selectors } from '../ButtonBase/ButtonBase';\nimport { ToolTip, ToolTipProps } from '../Tip/ToolTip';\nimport { MenuItem } from './MenuItem';\n\nenum MenuItemSelectors {\n  OUTLINE = '&:after',\n  OUTLINE_FOCUS_VISIBLE = '&:focus-visible:after',\n}\n\ntype ListStyleProps = StyleProps<typeof listProps>;\n\ntype StyleStateProps = StyleProps<typeof sharedStates>;\n\nconst listProps = variance.compose(\n  system.layout,\n  system.typography,\n  system.space,\n  system.positioning,\n  system.border,\n  system.color\n);\n\nexport interface ListProps extends ListStyleProps, StyleStateProps {\n  /** How offset spacing should be */\n  spacing?: 'normal' | 'condensed';\n  /** Menu variants for specific use cases and styles */\n  variant?: 'popover' | 'fixed';\n  /** is root menu */\n  root?: boolean;\n  /** bordered */\n  as?: 'ul' | 'ol';\n  showBorder?: boolean;\n}\n\nconst StyledList = styled('ul', styledOptions<'ul'>())<ListProps>(\n  system.css({\n    listStyle: 'none',\n    width: 1,\n    bg: 'inherit',\n    display: 'inline-block',\n    pl: 24,\n    WebkitFontSmoothing: 'antialiased',\n    MozOsxFontSmoothing: 'grayscale',\n  }),\n  system.states({\n    root: {\n      bg: 'background',\n      p: 0,\n    },\n    showBorder: {\n      border: 1,\n      borderRadius: 'sm',\n    },\n  }),\n  sharedStates,\n  listProps\n);\n\nexport const List = forwardRef<\n  HTMLUListElement,\n  ComponentProps<typeof StyledList>\n>(({ context = true, m = 0, root = true, variant, ...rest }, ref) => (\n  <StyledList\n    context={context}\n    m={m}\n    ref={ref}\n    root={root}\n    showBorder={variant !== 'fixed'}\n    variant={variant}\n    {...rest}\n  />\n));\n\nconst interactiveVariants = system.variant({\n  base: {\n    display: 'flex',\n    alignItems: 'center',\n    cursor: 'pointer',\n    width: 1,\n    zIndex: 1,\n    px: 24,\n    py: 12,\n    position: 'relative',\n    transition: transitionConcat(\n      ['color', 'background-color', 'border-color'],\n      'fast',\n      'linear'\n    ),\n    [Selectors.FOCUS_VISIBLE]: {\n      outline: 'none',\n    },\n    [MenuItemSelectors.OUTLINE]: {\n      content: \"''\",\n      position: 'absolute',\n      inset: 4,\n      borderRadius: 'md',\n      border: 2,\n      borderColor: 'primary',\n      opacity: 0,\n      zIndex: -1,\n    },\n    [MenuItemSelectors.OUTLINE_FOCUS_VISIBLE]: {\n      opacity: 1,\n    },\n  },\n  variants: {\n    select: {\n      [Selectors.DISABLED]: {\n        pointerEvents: 'none',\n      },\n      [Selectors.HOVER]: {\n        bg: 'background-hover',\n      },\n    },\n    link: {\n      [Selectors.BEFORE]: {\n        bg: 'inherit',\n        position: 'absolute',\n        display: 'inline-block',\n        left: 0,\n        width: 6,\n      },\n      [Selectors.HOVER]: {\n        textColor: 'primary',\n      },\n    },\n  },\n});\n\nconst activeStates = system.states({\n  selected: {\n    bg: 'background-selected',\n  },\n  active: {\n    fontWeight: 'title',\n  },\n  'active-navlink': {\n    fontWeight: 'title',\n    bg: 'background-selected',\n    [Selectors.BEFORE]: {\n      content: \"''\",\n      bg: 'secondary',\n    },\n  },\n  // Is named isDisabled to avoid conflicts with the HTML `disabled` attribute\n  isDisabled: {\n    bg: 'inherit',\n    cursor: 'not-allowed',\n    fontWeight: 400,\n    textColor: 'text-disabled',\n    [Selectors.HOVER]: {\n      textColor: 'text-disabled',\n      textDecoration: 'none',\n    },\n    [Selectors.BEFORE]: {\n      content: \"''\",\n      bg: 'inherit',\n    },\n  },\n});\n\nconst sizeVariants = system.variant({\n  prop: 'spacing',\n  variants: {\n    condensed: {\n      lineHeight: 'title',\n      minHeight: 40,\n      py: 8,\n      fontSize: 14,\n      [Selectors.BEFORE]: {\n        minHeight: 40,\n      },\n    },\n    normal: {\n      fontSize: 16,\n      minHeight: 48,\n      [Selectors.BEFORE]: {\n        minHeight: 48,\n      },\n    },\n  },\n});\n\nexport interface ListItemProps\n  extends ListStyleProps,\n    StyleStateProps,\n    StyleProps<typeof interactiveVariants>,\n    StyleProps<typeof activeStates>,\n    StyleProps<typeof sizeVariants> {}\n\nexport const ListItem = styled('li', styledOptions<'li'>())<ListItemProps>(\n  interactiveVariants,\n  activeStates,\n  sizeVariants,\n  sharedStates,\n  listProps\n);\n\nexport interface ListLinkProps extends ListItemProps {\n  active?: boolean;\n  navlink?: boolean;\n}\n\nconst StyledListLink = styled('a', styledOptions<'a'>())<ListLinkProps>(\n  resetStyles,\n  interactiveVariants,\n  activeStates,\n  sizeVariants,\n  sharedStates,\n  listProps\n);\n\nexport const ListLink = forwardRef<\n  HTMLAnchorElement,\n  ComponentProps<typeof StyledListLink>\n>(({ zIndex = 1, ...rest }, ref) => (\n  <StyledListLink ref={ref} zIndex={zIndex} {...rest} />\n));\n\nexport const ListButton = styled(\n  'button',\n  styledOptions<'button'>()\n)<ListLinkProps>(\n  resetStyles,\n  interactiveVariants,\n  activeStates,\n  sizeVariants,\n  sharedStates,\n  listProps\n);\n\nexport const MenuToolTipWrapper: React.FC<\n  Pick<ComponentProps<typeof MenuItem>, 'children' | 'label'> & {\n    tipId: string;\n  }\n> = ({ children, label, tipId }) => {\n  if (!label) {\n    return <>{children}</>;\n  }\n\n  const defaultTipProps = {\n    placement: 'floating',\n    id: tipId,\n    inheritDims: true,\n    shouldRenderAriaTip: false,\n  };\n\n  const wrapperProps =\n    label && isObject(label)\n      ? {\n          ...defaultTipProps,\n          ...label,\n        }\n      : {\n          info: label,\n          ...defaultTipProps,\n        };\n\n  return <ToolTip {...(wrapperProps as ToolTipProps)}>{children}</ToolTip>;\n};\n"]} */");
export const List = /*#__PURE__*/forwardRef(({
context = true,
m = 0,
root = true,
@@ -105,12 +105,12 @@
selected: {
bg: 'background-selected'
},
active: {
- fontWeight: 700
+ fontWeight: 'title'
},
'active-navlink': {
- fontWeight: 700,
+ fontWeight: 'title',
bg: 'background-selected',
[Selectors.BEFORE]: {
content: "''",
bg: 'secondary'
@@ -155,13 +155,13 @@
});
export const ListItem = /*#__PURE__*/_styled('li', _extends({}, {
target: "e1dfahz22",
label: "ListItem"
-}, styledOptions()))(interactiveVariants, activeStates, sizeVariants, sharedStates, listProps, process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../src/Menu/elements.tsx"],"names":[],"mappings":"AAyMwB","file":"../../src/Menu/elements.tsx","sourcesContent":["import {\n  styledOptions,\n  system,\n  transitionConcat,\n} from '@codecademy/gamut-styles';\nimport { StyleProps, variance } from '@codecademy/variance';\nimport styled from '@emotion/styled';\nimport isObject from 'lodash/isObject';\nimport { ComponentProps, forwardRef } from 'react';\n\nimport { sharedStates } from '../Box/props';\nimport { resetStyles, Selectors } from '../ButtonBase/ButtonBase';\nimport { ToolTip, ToolTipProps } from '../Tip/ToolTip';\nimport { MenuItem } from './MenuItem';\n\nenum MenuItemSelectors {\n  OUTLINE = '&:after',\n  OUTLINE_FOCUS_VISIBLE = '&:focus-visible:after',\n}\n\ntype ListStyleProps = StyleProps<typeof listProps>;\n\ntype StyleStateProps = StyleProps<typeof sharedStates>;\n\nconst listProps = variance.compose(\n  system.layout,\n  system.typography,\n  system.space,\n  system.positioning,\n  system.border,\n  system.color\n);\n\nexport interface ListProps extends ListStyleProps, StyleStateProps {\n  /** How offset spacing should be */\n  spacing?: 'normal' | 'condensed';\n  /** Menu variants for specific use cases and styles */\n  variant?: 'popover' | 'fixed';\n  /** is root menu */\n  root?: boolean;\n  /** bordered */\n  as?: 'ul' | 'ol';\n  showBorder?: boolean;\n}\n\nconst StyledList = styled('ul', styledOptions<'ul'>())<ListProps>(\n  system.css({\n    listStyle: 'none',\n    width: 1,\n    bg: 'inherit',\n    display: 'inline-block',\n    pl: 24,\n    WebkitFontSmoothing: 'antialiased',\n    MozOsxFontSmoothing: 'grayscale',\n  }),\n  system.states({\n    root: {\n      bg: 'background',\n      p: 0,\n    },\n    showBorder: {\n      border: 1,\n      borderRadius: 'sm',\n    },\n  }),\n  sharedStates,\n  listProps\n);\n\nexport const List = forwardRef<\n  HTMLUListElement,\n  ComponentProps<typeof StyledList>\n>(({ context = true, m = 0, root = true, variant, ...rest }, ref) => (\n  <StyledList\n    context={context}\n    m={m}\n    ref={ref}\n    root={root}\n    showBorder={variant !== 'fixed'}\n    variant={variant}\n    {...rest}\n  />\n));\n\nconst interactiveVariants = system.variant({\n  base: {\n    display: 'flex',\n    alignItems: 'center',\n    cursor: 'pointer',\n    width: 1,\n    zIndex: 1,\n    px: 24,\n    py: 12,\n    position: 'relative',\n    transition: transitionConcat(\n      ['color', 'background-color', 'border-color'],\n      'fast',\n      'linear'\n    ),\n    [Selectors.FOCUS_VISIBLE]: {\n      outline: 'none',\n    },\n    [MenuItemSelectors.OUTLINE]: {\n      content: \"''\",\n      position: 'absolute',\n      inset: 4,\n      borderRadius: 'md',\n      border: 2,\n      borderColor: 'primary',\n      opacity: 0,\n      zIndex: -1,\n    },\n    [MenuItemSelectors.OUTLINE_FOCUS_VISIBLE]: {\n      opacity: 1,\n    },\n  },\n  variants: {\n    select: {\n      [Selectors.DISABLED]: {\n        pointerEvents: 'none',\n      },\n      [Selectors.HOVER]: {\n        bg: 'background-hover',\n      },\n    },\n    link: {\n      [Selectors.BEFORE]: {\n        bg: 'inherit',\n        position: 'absolute',\n        display: 'inline-block',\n        left: 0,\n        width: 6,\n      },\n      [Selectors.HOVER]: {\n        textColor: 'primary',\n      },\n    },\n  },\n});\n\nconst activeStates = system.states({\n  selected: {\n    bg: 'background-selected',\n  },\n  active: {\n    fontWeight: 700,\n  },\n  'active-navlink': {\n    fontWeight: 700,\n    bg: 'background-selected',\n    [Selectors.BEFORE]: {\n      content: \"''\",\n      bg: 'secondary',\n    },\n  },\n  // Is named isDisabled to avoid conflicts with the HTML `disabled` attribute\n  isDisabled: {\n    bg: 'inherit',\n    cursor: 'not-allowed',\n    fontWeight: 400,\n    textColor: 'text-disabled',\n    [Selectors.HOVER]: {\n      textColor: 'text-disabled',\n      textDecoration: 'none',\n    },\n    [Selectors.BEFORE]: {\n      content: \"''\",\n      bg: 'inherit',\n    },\n  },\n});\n\nconst sizeVariants = system.variant({\n  prop: 'spacing',\n  variants: {\n    condensed: {\n      lineHeight: 'title',\n      minHeight: 40,\n      py: 8,\n      fontSize: 14,\n      [Selectors.BEFORE]: {\n        minHeight: 40,\n      },\n    },\n    normal: {\n      fontSize: 16,\n      minHeight: 48,\n      [Selectors.BEFORE]: {\n        minHeight: 48,\n      },\n    },\n  },\n});\n\nexport interface ListItemProps\n  extends ListStyleProps,\n    StyleStateProps,\n    StyleProps<typeof interactiveVariants>,\n    StyleProps<typeof activeStates>,\n    StyleProps<typeof sizeVariants> {}\n\nexport const ListItem = styled('li', styledOptions<'li'>())<ListItemProps>(\n  interactiveVariants,\n  activeStates,\n  sizeVariants,\n  sharedStates,\n  listProps\n);\n\nexport interface ListLinkProps extends ListItemProps {\n  active?: boolean;\n  navlink?: boolean;\n}\n\nconst StyledListLink = styled('a', styledOptions<'a'>())<ListLinkProps>(\n  resetStyles,\n  interactiveVariants,\n  activeStates,\n  sizeVariants,\n  sharedStates,\n  listProps\n);\n\nexport const ListLink = forwardRef<\n  HTMLAnchorElement,\n  ComponentProps<typeof StyledListLink>\n>(({ zIndex = 1, ...rest }, ref) => (\n  <StyledListLink ref={ref} zIndex={zIndex} {...rest} />\n));\n\nexport const ListButton = styled(\n  'button',\n  styledOptions<'button'>()\n)<ListLinkProps>(\n  resetStyles,\n  interactiveVariants,\n  activeStates,\n  sizeVariants,\n  sharedStates,\n  listProps\n);\n\nexport const MenuToolTipWrapper: React.FC<\n  Pick<ComponentProps<typeof MenuItem>, 'children' | 'label'> & {\n    tipId: string;\n  }\n> = ({ children, label, tipId }) => {\n  if (!label) {\n    return <>{children}</>;\n  }\n\n  const defaultTipProps = {\n    placement: 'floating',\n    id: tipId,\n    inheritDims: true,\n    shouldRenderAriaTip: false,\n  };\n\n  const wrapperProps =\n    label && isObject(label)\n      ? {\n          ...defaultTipProps,\n          ...label,\n        }\n      : {\n          info: label,\n          ...defaultTipProps,\n        };\n\n  return <ToolTip {...(wrapperProps as ToolTipProps)}>{children}</ToolTip>;\n};\n"]} */");
+}, styledOptions()))(interactiveVariants, activeStates, sizeVariants, sharedStates, listProps, process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../src/Menu/elements.tsx"],"names":[],"mappings":"AAyMwB","file":"../../src/Menu/elements.tsx","sourcesContent":["import {\n  styledOptions,\n  system,\n  transitionConcat,\n} from '@codecademy/gamut-styles';\nimport { StyleProps, variance } from '@codecademy/variance';\nimport styled from '@emotion/styled';\nimport isObject from 'lodash/isObject';\nimport { ComponentProps, forwardRef } from 'react';\n\nimport { sharedStates } from '../Box/props';\nimport { resetStyles, Selectors } from '../ButtonBase/ButtonBase';\nimport { ToolTip, ToolTipProps } from '../Tip/ToolTip';\nimport { MenuItem } from './MenuItem';\n\nenum MenuItemSelectors {\n  OUTLINE = '&:after',\n  OUTLINE_FOCUS_VISIBLE = '&:focus-visible:after',\n}\n\ntype ListStyleProps = StyleProps<typeof listProps>;\n\ntype StyleStateProps = StyleProps<typeof sharedStates>;\n\nconst listProps = variance.compose(\n  system.layout,\n  system.typography,\n  system.space,\n  system.positioning,\n  system.border,\n  system.color\n);\n\nexport interface ListProps extends ListStyleProps, StyleStateProps {\n  /** How offset spacing should be */\n  spacing?: 'normal' | 'condensed';\n  /** Menu variants for specific use cases and styles */\n  variant?: 'popover' | 'fixed';\n  /** is root menu */\n  root?: boolean;\n  /** bordered */\n  as?: 'ul' | 'ol';\n  showBorder?: boolean;\n}\n\nconst StyledList = styled('ul', styledOptions<'ul'>())<ListProps>(\n  system.css({\n    listStyle: 'none',\n    width: 1,\n    bg: 'inherit',\n    display: 'inline-block',\n    pl: 24,\n    WebkitFontSmoothing: 'antialiased',\n    MozOsxFontSmoothing: 'grayscale',\n  }),\n  system.states({\n    root: {\n      bg: 'background',\n      p: 0,\n    },\n    showBorder: {\n      border: 1,\n      borderRadius: 'sm',\n    },\n  }),\n  sharedStates,\n  listProps\n);\n\nexport const List = forwardRef<\n  HTMLUListElement,\n  ComponentProps<typeof StyledList>\n>(({ context = true, m = 0, root = true, variant, ...rest }, ref) => (\n  <StyledList\n    context={context}\n    m={m}\n    ref={ref}\n    root={root}\n    showBorder={variant !== 'fixed'}\n    variant={variant}\n    {...rest}\n  />\n));\n\nconst interactiveVariants = system.variant({\n  base: {\n    display: 'flex',\n    alignItems: 'center',\n    cursor: 'pointer',\n    width: 1,\n    zIndex: 1,\n    px: 24,\n    py: 12,\n    position: 'relative',\n    transition: transitionConcat(\n      ['color', 'background-color', 'border-color'],\n      'fast',\n      'linear'\n    ),\n    [Selectors.FOCUS_VISIBLE]: {\n      outline: 'none',\n    },\n    [MenuItemSelectors.OUTLINE]: {\n      content: \"''\",\n      position: 'absolute',\n      inset: 4,\n      borderRadius: 'md',\n      border: 2,\n      borderColor: 'primary',\n      opacity: 0,\n      zIndex: -1,\n    },\n    [MenuItemSelectors.OUTLINE_FOCUS_VISIBLE]: {\n      opacity: 1,\n    },\n  },\n  variants: {\n    select: {\n      [Selectors.DISABLED]: {\n        pointerEvents: 'none',\n      },\n      [Selectors.HOVER]: {\n        bg: 'background-hover',\n      },\n    },\n    link: {\n      [Selectors.BEFORE]: {\n        bg: 'inherit',\n        position: 'absolute',\n        display: 'inline-block',\n        left: 0,\n        width: 6,\n      },\n      [Selectors.HOVER]: {\n        textColor: 'primary',\n      },\n    },\n  },\n});\n\nconst activeStates = system.states({\n  selected: {\n    bg: 'background-selected',\n  },\n  active: {\n    fontWeight: 'title',\n  },\n  'active-navlink': {\n    fontWeight: 'title',\n    bg: 'background-selected',\n    [Selectors.BEFORE]: {\n      content: \"''\",\n      bg: 'secondary',\n    },\n  },\n  // Is named isDisabled to avoid conflicts with the HTML `disabled` attribute\n  isDisabled: {\n    bg: 'inherit',\n    cursor: 'not-allowed',\n    fontWeight: 400,\n    textColor: 'text-disabled',\n    [Selectors.HOVER]: {\n      textColor: 'text-disabled',\n      textDecoration: 'none',\n    },\n    [Selectors.BEFORE]: {\n      content: \"''\",\n      bg: 'inherit',\n    },\n  },\n});\n\nconst sizeVariants = system.variant({\n  prop: 'spacing',\n  variants: {\n    condensed: {\n      lineHeight: 'title',\n      minHeight: 40,\n      py: 8,\n      fontSize: 14,\n      [Selectors.BEFORE]: {\n        minHeight: 40,\n      },\n    },\n    normal: {\n      fontSize: 16,\n      minHeight: 48,\n      [Selectors.BEFORE]: {\n        minHeight: 48,\n      },\n    },\n  },\n});\n\nexport interface ListItemProps\n  extends ListStyleProps,\n    StyleStateProps,\n    StyleProps<typeof interactiveVariants>,\n    StyleProps<typeof activeStates>,\n    StyleProps<typeof sizeVariants> {}\n\nexport const ListItem = styled('li', styledOptions<'li'>())<ListItemProps>(\n  interactiveVariants,\n  activeStates,\n  sizeVariants,\n  sharedStates,\n  listProps\n);\n\nexport interface ListLinkProps extends ListItemProps {\n  active?: boolean;\n  navlink?: boolean;\n}\n\nconst StyledListLink = styled('a', styledOptions<'a'>())<ListLinkProps>(\n  resetStyles,\n  interactiveVariants,\n  activeStates,\n  sizeVariants,\n  sharedStates,\n  listProps\n);\n\nexport const ListLink = forwardRef<\n  HTMLAnchorElement,\n  ComponentProps<typeof StyledListLink>\n>(({ zIndex = 1, ...rest }, ref) => (\n  <StyledListLink ref={ref} zIndex={zIndex} {...rest} />\n));\n\nexport const ListButton = styled(\n  'button',\n  styledOptions<'button'>()\n)<ListLinkProps>(\n  resetStyles,\n  interactiveVariants,\n  activeStates,\n  sizeVariants,\n  sharedStates,\n  listProps\n);\n\nexport const MenuToolTipWrapper: React.FC<\n  Pick<ComponentProps<typeof MenuItem>, 'children' | 'label'> & {\n    tipId: string;\n  }\n> = ({ children, label, tipId }) => {\n  if (!label) {\n    return <>{children}</>;\n  }\n\n  const defaultTipProps = {\n    placement: 'floating',\n    id: tipId,\n    inheritDims: true,\n    shouldRenderAriaTip: false,\n  };\n\n  const wrapperProps =\n    label && isObject(label)\n      ? {\n          ...defaultTipProps,\n          ...label,\n        }\n      : {\n          info: label,\n          ...defaultTipProps,\n        };\n\n  return <ToolTip {...(wrapperProps as ToolTipProps)}>{children}</ToolTip>;\n};\n"]} */");
const StyledListLink = /*#__PURE__*/_styled('a', _extends({}, {
target: "e1dfahz21",
label: "StyledListLink"
-}, styledOptions()))(resetStyles, interactiveVariants, activeStates, sizeVariants, sharedStates, listProps, process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../src/Menu/elements.tsx"],"names":[],"mappings":"AAsNuB","file":"../../src/Menu/elements.tsx","sourcesContent":["import {\n  styledOptions,\n  system,\n  transitionConcat,\n} from '@codecademy/gamut-styles';\nimport { StyleProps, variance } from '@codecademy/variance';\nimport styled from '@emotion/styled';\nimport isObject from 'lodash/isObject';\nimport { ComponentProps, forwardRef } from 'react';\n\nimport { sharedStates } from '../Box/props';\nimport { resetStyles, Selectors } from '../ButtonBase/ButtonBase';\nimport { ToolTip, ToolTipProps } from '../Tip/ToolTip';\nimport { MenuItem } from './MenuItem';\n\nenum MenuItemSelectors {\n  OUTLINE = '&:after',\n  OUTLINE_FOCUS_VISIBLE = '&:focus-visible:after',\n}\n\ntype ListStyleProps = StyleProps<typeof listProps>;\n\ntype StyleStateProps = StyleProps<typeof sharedStates>;\n\nconst listProps = variance.compose(\n  system.layout,\n  system.typography,\n  system.space,\n  system.positioning,\n  system.border,\n  system.color\n);\n\nexport interface ListProps extends ListStyleProps, StyleStateProps {\n  /** How offset spacing should be */\n  spacing?: 'normal' | 'condensed';\n  /** Menu variants for specific use cases and styles */\n  variant?: 'popover' | 'fixed';\n  /** is root menu */\n  root?: boolean;\n  /** bordered */\n  as?: 'ul' | 'ol';\n  showBorder?: boolean;\n}\n\nconst StyledList = styled('ul', styledOptions<'ul'>())<ListProps>(\n  system.css({\n    listStyle: 'none',\n    width: 1,\n    bg: 'inherit',\n    display: 'inline-block',\n    pl: 24,\n    WebkitFontSmoothing: 'antialiased',\n    MozOsxFontSmoothing: 'grayscale',\n  }),\n  system.states({\n    root: {\n      bg: 'background',\n      p: 0,\n    },\n    showBorder: {\n      border: 1,\n      borderRadius: 'sm',\n    },\n  }),\n  sharedStates,\n  listProps\n);\n\nexport const List = forwardRef<\n  HTMLUListElement,\n  ComponentProps<typeof StyledList>\n>(({ context = true, m = 0, root = true, variant, ...rest }, ref) => (\n  <StyledList\n    context={context}\n    m={m}\n    ref={ref}\n    root={root}\n    showBorder={variant !== 'fixed'}\n    variant={variant}\n    {...rest}\n  />\n));\n\nconst interactiveVariants = system.variant({\n  base: {\n    display: 'flex',\n    alignItems: 'center',\n    cursor: 'pointer',\n    width: 1,\n    zIndex: 1,\n    px: 24,\n    py: 12,\n    position: 'relative',\n    transition: transitionConcat(\n      ['color', 'background-color', 'border-color'],\n      'fast',\n      'linear'\n    ),\n    [Selectors.FOCUS_VISIBLE]: {\n      outline: 'none',\n    },\n    [MenuItemSelectors.OUTLINE]: {\n      content: \"''\",\n      position: 'absolute',\n      inset: 4,\n      borderRadius: 'md',\n      border: 2,\n      borderColor: 'primary',\n      opacity: 0,\n      zIndex: -1,\n    },\n    [MenuItemSelectors.OUTLINE_FOCUS_VISIBLE]: {\n      opacity: 1,\n    },\n  },\n  variants: {\n    select: {\n      [Selectors.DISABLED]: {\n        pointerEvents: 'none',\n      },\n      [Selectors.HOVER]: {\n        bg: 'background-hover',\n      },\n    },\n    link: {\n      [Selectors.BEFORE]: {\n        bg: 'inherit',\n        position: 'absolute',\n        display: 'inline-block',\n        left: 0,\n        width: 6,\n      },\n      [Selectors.HOVER]: {\n        textColor: 'primary',\n      },\n    },\n  },\n});\n\nconst activeStates = system.states({\n  selected: {\n    bg: 'background-selected',\n  },\n  active: {\n    fontWeight: 700,\n  },\n  'active-navlink': {\n    fontWeight: 700,\n    bg: 'background-selected',\n    [Selectors.BEFORE]: {\n      content: \"''\",\n      bg: 'secondary',\n    },\n  },\n  // Is named isDisabled to avoid conflicts with the HTML `disabled` attribute\n  isDisabled: {\n    bg: 'inherit',\n    cursor: 'not-allowed',\n    fontWeight: 400,\n    textColor: 'text-disabled',\n    [Selectors.HOVER]: {\n      textColor: 'text-disabled',\n      textDecoration: 'none',\n    },\n    [Selectors.BEFORE]: {\n      content: \"''\",\n      bg: 'inherit',\n    },\n  },\n});\n\nconst sizeVariants = system.variant({\n  prop: 'spacing',\n  variants: {\n    condensed: {\n      lineHeight: 'title',\n      minHeight: 40,\n      py: 8,\n      fontSize: 14,\n      [Selectors.BEFORE]: {\n        minHeight: 40,\n      },\n    },\n    normal: {\n      fontSize: 16,\n      minHeight: 48,\n      [Selectors.BEFORE]: {\n        minHeight: 48,\n      },\n    },\n  },\n});\n\nexport interface ListItemProps\n  extends ListStyleProps,\n    StyleStateProps,\n    StyleProps<typeof interactiveVariants>,\n    StyleProps<typeof activeStates>,\n    StyleProps<typeof sizeVariants> {}\n\nexport const ListItem = styled('li', styledOptions<'li'>())<ListItemProps>(\n  interactiveVariants,\n  activeStates,\n  sizeVariants,\n  sharedStates,\n  listProps\n);\n\nexport interface ListLinkProps extends ListItemProps {\n  active?: boolean;\n  navlink?: boolean;\n}\n\nconst StyledListLink = styled('a', styledOptions<'a'>())<ListLinkProps>(\n  resetStyles,\n  interactiveVariants,\n  activeStates,\n  sizeVariants,\n  sharedStates,\n  listProps\n);\n\nexport const ListLink = forwardRef<\n  HTMLAnchorElement,\n  ComponentProps<typeof StyledListLink>\n>(({ zIndex = 1, ...rest }, ref) => (\n  <StyledListLink ref={ref} zIndex={zIndex} {...rest} />\n));\n\nexport const ListButton = styled(\n  'button',\n  styledOptions<'button'>()\n)<ListLinkProps>(\n  resetStyles,\n  interactiveVariants,\n  activeStates,\n  sizeVariants,\n  sharedStates,\n  listProps\n);\n\nexport const MenuToolTipWrapper: React.FC<\n  Pick<ComponentProps<typeof MenuItem>, 'children' | 'label'> & {\n    tipId: string;\n  }\n> = ({ children, label, tipId }) => {\n  if (!label) {\n    return <>{children}</>;\n  }\n\n  const defaultTipProps = {\n    placement: 'floating',\n    id: tipId,\n    inheritDims: true,\n    shouldRenderAriaTip: false,\n  };\n\n  const wrapperProps =\n    label && isObject(label)\n      ? {\n          ...defaultTipProps,\n          ...label,\n        }\n      : {\n          info: label,\n          ...defaultTipProps,\n        };\n\n  return <ToolTip {...(wrapperProps as ToolTipProps)}>{children}</ToolTip>;\n};\n"]} */");
+}, styledOptions()))(resetStyles, interactiveVariants, activeStates, sizeVariants, sharedStates, listProps, process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../src/Menu/elements.tsx"],"names":[],"mappings":"AAsNuB","file":"../../src/Menu/elements.tsx","sourcesContent":["import {\n  styledOptions,\n  system,\n  transitionConcat,\n} from '@codecademy/gamut-styles';\nimport { StyleProps, variance } from '@codecademy/variance';\nimport styled from '@emotion/styled';\nimport isObject from 'lodash/isObject';\nimport { ComponentProps, forwardRef } from 'react';\n\nimport { sharedStates } from '../Box/props';\nimport { resetStyles, Selectors } from '../ButtonBase/ButtonBase';\nimport { ToolTip, ToolTipProps } from '../Tip/ToolTip';\nimport { MenuItem } from './MenuItem';\n\nenum MenuItemSelectors {\n  OUTLINE = '&:after',\n  OUTLINE_FOCUS_VISIBLE = '&:focus-visible:after',\n}\n\ntype ListStyleProps = StyleProps<typeof listProps>;\n\ntype StyleStateProps = StyleProps<typeof sharedStates>;\n\nconst listProps = variance.compose(\n  system.layout,\n  system.typography,\n  system.space,\n  system.positioning,\n  system.border,\n  system.color\n);\n\nexport interface ListProps extends ListStyleProps, StyleStateProps {\n  /** How offset spacing should be */\n  spacing?: 'normal' | 'condensed';\n  /** Menu variants for specific use cases and styles */\n  variant?: 'popover' | 'fixed';\n  /** is root menu */\n  root?: boolean;\n  /** bordered */\n  as?: 'ul' | 'ol';\n  showBorder?: boolean;\n}\n\nconst StyledList = styled('ul', styledOptions<'ul'>())<ListProps>(\n  system.css({\n    listStyle: 'none',\n    width: 1,\n    bg: 'inherit',\n    display: 'inline-block',\n    pl: 24,\n    WebkitFontSmoothing: 'antialiased',\n    MozOsxFontSmoothing: 'grayscale',\n  }),\n  system.states({\n    root: {\n      bg: 'background',\n      p: 0,\n    },\n    showBorder: {\n      border: 1,\n      borderRadius: 'sm',\n    },\n  }),\n  sharedStates,\n  listProps\n);\n\nexport const List = forwardRef<\n  HTMLUListElement,\n  ComponentProps<typeof StyledList>\n>(({ context = true, m = 0, root = true, variant, ...rest }, ref) => (\n  <StyledList\n    context={context}\n    m={m}\n    ref={ref}\n    root={root}\n    showBorder={variant !== 'fixed'}\n    variant={variant}\n    {...rest}\n  />\n));\n\nconst interactiveVariants = system.variant({\n  base: {\n    display: 'flex',\n    alignItems: 'center',\n    cursor: 'pointer',\n    width: 1,\n    zIndex: 1,\n    px: 24,\n    py: 12,\n    position: 'relative',\n    transition: transitionConcat(\n      ['color', 'background-color', 'border-color'],\n      'fast',\n      'linear'\n    ),\n    [Selectors.FOCUS_VISIBLE]: {\n      outline: 'none',\n    },\n    [MenuItemSelectors.OUTLINE]: {\n      content: \"''\",\n      position: 'absolute',\n      inset: 4,\n      borderRadius: 'md',\n      border: 2,\n      borderColor: 'primary',\n      opacity: 0,\n      zIndex: -1,\n    },\n    [MenuItemSelectors.OUTLINE_FOCUS_VISIBLE]: {\n      opacity: 1,\n    },\n  },\n  variants: {\n    select: {\n      [Selectors.DISABLED]: {\n        pointerEvents: 'none',\n      },\n      [Selectors.HOVER]: {\n        bg: 'background-hover',\n      },\n    },\n    link: {\n      [Selectors.BEFORE]: {\n        bg: 'inherit',\n        position: 'absolute',\n        display: 'inline-block',\n        left: 0,\n        width: 6,\n      },\n      [Selectors.HOVER]: {\n        textColor: 'primary',\n      },\n    },\n  },\n});\n\nconst activeStates = system.states({\n  selected: {\n    bg: 'background-selected',\n  },\n  active: {\n    fontWeight: 'title',\n  },\n  'active-navlink': {\n    fontWeight: 'title',\n    bg: 'background-selected',\n    [Selectors.BEFORE]: {\n      content: \"''\",\n      bg: 'secondary',\n    },\n  },\n  // Is named isDisabled to avoid conflicts with the HTML `disabled` attribute\n  isDisabled: {\n    bg: 'inherit',\n    cursor: 'not-allowed',\n    fontWeight: 400,\n    textColor: 'text-disabled',\n    [Selectors.HOVER]: {\n      textColor: 'text-disabled',\n      textDecoration: 'none',\n    },\n    [Selectors.BEFORE]: {\n      content: \"''\",\n      bg: 'inherit',\n    },\n  },\n});\n\nconst sizeVariants = system.variant({\n  prop: 'spacing',\n  variants: {\n    condensed: {\n      lineHeight: 'title',\n      minHeight: 40,\n      py: 8,\n      fontSize: 14,\n      [Selectors.BEFORE]: {\n        minHeight: 40,\n      },\n    },\n    normal: {\n      fontSize: 16,\n      minHeight: 48,\n      [Selectors.BEFORE]: {\n        minHeight: 48,\n      },\n    },\n  },\n});\n\nexport interface ListItemProps\n  extends ListStyleProps,\n    StyleStateProps,\n    StyleProps<typeof interactiveVariants>,\n    StyleProps<typeof activeStates>,\n    StyleProps<typeof sizeVariants> {}\n\nexport const ListItem = styled('li', styledOptions<'li'>())<ListItemProps>(\n  interactiveVariants,\n  activeStates,\n  sizeVariants,\n  sharedStates,\n  listProps\n);\n\nexport interface ListLinkProps extends ListItemProps {\n  active?: boolean;\n  navlink?: boolean;\n}\n\nconst StyledListLink = styled('a', styledOptions<'a'>())<ListLinkProps>(\n  resetStyles,\n  interactiveVariants,\n  activeStates,\n  sizeVariants,\n  sharedStates,\n  listProps\n);\n\nexport const ListLink = forwardRef<\n  HTMLAnchorElement,\n  ComponentProps<typeof StyledListLink>\n>(({ zIndex = 1, ...rest }, ref) => (\n  <StyledListLink ref={ref} zIndex={zIndex} {...rest} />\n));\n\nexport const ListButton = styled(\n  'button',\n  styledOptions<'button'>()\n)<ListLinkProps>(\n  resetStyles,\n  interactiveVariants,\n  activeStates,\n  sizeVariants,\n  sharedStates,\n  listProps\n);\n\nexport const MenuToolTipWrapper: React.FC<\n  Pick<ComponentProps<typeof MenuItem>, 'children' | 'label'> & {\n    tipId: string;\n  }\n> = ({ children, label, tipId }) => {\n  if (!label) {\n    return <>{children}</>;\n  }\n\n  const defaultTipProps = {\n    placement: 'floating',\n    id: tipId,\n    inheritDims: true,\n    shouldRenderAriaTip: false,\n  };\n\n  const wrapperProps =\n    label && isObject(label)\n      ? {\n          ...defaultTipProps,\n          ...label,\n        }\n      : {\n          info: label,\n          ...defaultTipProps,\n        };\n\n  return <ToolTip {...(wrapperProps as ToolTipProps)}>{children}</ToolTip>;\n};\n"]} */");
export const ListLink = /*#__PURE__*/forwardRef(({
zIndex = 1,
...rest
}, ref) => /*#__PURE__*/_jsx(StyledListLink, {
@@ -171,9 +171,9 @@
}));
export const ListButton = /*#__PURE__*/_styled('button', _extends({}, {
target: "e1dfahz20",
label: "ListButton"
-}, styledOptions()))(resetStyles, interactiveVariants, activeStates, sizeVariants, sharedStates, listProps, process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../src/Menu/elements.tsx"],"names":[],"mappings":"AAsO0B","file":"../../src/Menu/elements.tsx","sourcesContent":["import {\n  styledOptions,\n  system,\n  transitionConcat,\n} from '@codecademy/gamut-styles';\nimport { StyleProps, variance } from '@codecademy/variance';\nimport styled from '@emotion/styled';\nimport isObject from 'lodash/isObject';\nimport { ComponentProps, forwardRef } from 'react';\n\nimport { sharedStates } from '../Box/props';\nimport { resetStyles, Selectors } from '../ButtonBase/ButtonBase';\nimport { ToolTip, ToolTipProps } from '../Tip/ToolTip';\nimport { MenuItem } from './MenuItem';\n\nenum MenuItemSelectors {\n  OUTLINE = '&:after',\n  OUTLINE_FOCUS_VISIBLE = '&:focus-visible:after',\n}\n\ntype ListStyleProps = StyleProps<typeof listProps>;\n\ntype StyleStateProps = StyleProps<typeof sharedStates>;\n\nconst listProps = variance.compose(\n  system.layout,\n  system.typography,\n  system.space,\n  system.positioning,\n  system.border,\n  system.color\n);\n\nexport interface ListProps extends ListStyleProps, StyleStateProps {\n  /** How offset spacing should be */\n  spacing?: 'normal' | 'condensed';\n  /** Menu variants for specific use cases and styles */\n  variant?: 'popover' | 'fixed';\n  /** is root menu */\n  root?: boolean;\n  /** bordered */\n  as?: 'ul' | 'ol';\n  showBorder?: boolean;\n}\n\nconst StyledList = styled('ul', styledOptions<'ul'>())<ListProps>(\n  system.css({\n    listStyle: 'none',\n    width: 1,\n    bg: 'inherit',\n    display: 'inline-block',\n    pl: 24,\n    WebkitFontSmoothing: 'antialiased',\n    MozOsxFontSmoothing: 'grayscale',\n  }),\n  system.states({\n    root: {\n      bg: 'background',\n      p: 0,\n    },\n    showBorder: {\n      border: 1,\n      borderRadius: 'sm',\n    },\n  }),\n  sharedStates,\n  listProps\n);\n\nexport const List = forwardRef<\n  HTMLUListElement,\n  ComponentProps<typeof StyledList>\n>(({ context = true, m = 0, root = true, variant, ...rest }, ref) => (\n  <StyledList\n    context={context}\n    m={m}\n    ref={ref}\n    root={root}\n    showBorder={variant !== 'fixed'}\n    variant={variant}\n    {...rest}\n  />\n));\n\nconst interactiveVariants = system.variant({\n  base: {\n    display: 'flex',\n    alignItems: 'center',\n    cursor: 'pointer',\n    width: 1,\n    zIndex: 1,\n    px: 24,\n    py: 12,\n    position: 'relative',\n    transition: transitionConcat(\n      ['color', 'background-color', 'border-color'],\n      'fast',\n      'linear'\n    ),\n    [Selectors.FOCUS_VISIBLE]: {\n      outline: 'none',\n    },\n    [MenuItemSelectors.OUTLINE]: {\n      content: \"''\",\n      position: 'absolute',\n      inset: 4,\n      borderRadius: 'md',\n      border: 2,\n      borderColor: 'primary',\n      opacity: 0,\n      zIndex: -1,\n    },\n    [MenuItemSelectors.OUTLINE_FOCUS_VISIBLE]: {\n      opacity: 1,\n    },\n  },\n  variants: {\n    select: {\n      [Selectors.DISABLED]: {\n        pointerEvents: 'none',\n      },\n      [Selectors.HOVER]: {\n        bg: 'background-hover',\n      },\n    },\n    link: {\n      [Selectors.BEFORE]: {\n        bg: 'inherit',\n        position: 'absolute',\n        display: 'inline-block',\n        left: 0,\n        width: 6,\n      },\n      [Selectors.HOVER]: {\n        textColor: 'primary',\n      },\n    },\n  },\n});\n\nconst activeStates = system.states({\n  selected: {\n    bg: 'background-selected',\n  },\n  active: {\n    fontWeight: 700,\n  },\n  'active-navlink': {\n    fontWeight: 700,\n    bg: 'background-selected',\n    [Selectors.BEFORE]: {\n      content: \"''\",\n      bg: 'secondary',\n    },\n  },\n  // Is named isDisabled to avoid conflicts with the HTML `disabled` attribute\n  isDisabled: {\n    bg: 'inherit',\n    cursor: 'not-allowed',\n    fontWeight: 400,\n    textColor: 'text-disabled',\n    [Selectors.HOVER]: {\n      textColor: 'text-disabled',\n      textDecoration: 'none',\n    },\n    [Selectors.BEFORE]: {\n      content: \"''\",\n      bg: 'inherit',\n    },\n  },\n});\n\nconst sizeVariants = system.variant({\n  prop: 'spacing',\n  variants: {\n    condensed: {\n      lineHeight: 'title',\n      minHeight: 40,\n      py: 8,\n      fontSize: 14,\n      [Selectors.BEFORE]: {\n        minHeight: 40,\n      },\n    },\n    normal: {\n      fontSize: 16,\n      minHeight: 48,\n      [Selectors.BEFORE]: {\n        minHeight: 48,\n      },\n    },\n  },\n});\n\nexport interface ListItemProps\n  extends ListStyleProps,\n    StyleStateProps,\n    StyleProps<typeof interactiveVariants>,\n    StyleProps<typeof activeStates>,\n    StyleProps<typeof sizeVariants> {}\n\nexport const ListItem = styled('li', styledOptions<'li'>())<ListItemProps>(\n  interactiveVariants,\n  activeStates,\n  sizeVariants,\n  sharedStates,\n  listProps\n);\n\nexport interface ListLinkProps extends ListItemProps {\n  active?: boolean;\n  navlink?: boolean;\n}\n\nconst StyledListLink = styled('a', styledOptions<'a'>())<ListLinkProps>(\n  resetStyles,\n  interactiveVariants,\n  activeStates,\n  sizeVariants,\n  sharedStates,\n  listProps\n);\n\nexport const ListLink = forwardRef<\n  HTMLAnchorElement,\n  ComponentProps<typeof StyledListLink>\n>(({ zIndex = 1, ...rest }, ref) => (\n  <StyledListLink ref={ref} zIndex={zIndex} {...rest} />\n));\n\nexport const ListButton = styled(\n  'button',\n  styledOptions<'button'>()\n)<ListLinkProps>(\n  resetStyles,\n  interactiveVariants,\n  activeStates,\n  sizeVariants,\n  sharedStates,\n  listProps\n);\n\nexport const MenuToolTipWrapper: React.FC<\n  Pick<ComponentProps<typeof MenuItem>, 'children' | 'label'> & {\n    tipId: string;\n  }\n> = ({ children, label, tipId }) => {\n  if (!label) {\n    return <>{children}</>;\n  }\n\n  const defaultTipProps = {\n    placement: 'floating',\n    id: tipId,\n    inheritDims: true,\n    shouldRenderAriaTip: false,\n  };\n\n  const wrapperProps =\n    label && isObject(label)\n      ? {\n          ...defaultTipProps,\n          ...label,\n        }\n      : {\n          info: label,\n          ...defaultTipProps,\n        };\n\n  return <ToolTip {...(wrapperProps as ToolTipProps)}>{children}</ToolTip>;\n};\n"]} */");
+}, styledOptions()))(resetStyles, interactiveVariants, activeStates, sizeVariants, sharedStates, listProps, process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../src/Menu/elements.tsx"],"names":[],"mappings":"AAsO0B","file":"../../src/Menu/elements.tsx","sourcesContent":["import {\n  styledOptions,\n  system,\n  transitionConcat,\n} from '@codecademy/gamut-styles';\nimport { StyleProps, variance } from '@codecademy/variance';\nimport styled from '@emotion/styled';\nimport isObject from 'lodash/isObject';\nimport { ComponentProps, forwardRef } from 'react';\n\nimport { sharedStates } from '../Box/props';\nimport { resetStyles, Selectors } from '../ButtonBase/ButtonBase';\nimport { ToolTip, ToolTipProps } from '../Tip/ToolTip';\nimport { MenuItem } from './MenuItem';\n\nenum MenuItemSelectors {\n  OUTLINE = '&:after',\n  OUTLINE_FOCUS_VISIBLE = '&:focus-visible:after',\n}\n\ntype ListStyleProps = StyleProps<typeof listProps>;\n\ntype StyleStateProps = StyleProps<typeof sharedStates>;\n\nconst listProps = variance.compose(\n  system.layout,\n  system.typography,\n  system.space,\n  system.positioning,\n  system.border,\n  system.color\n);\n\nexport interface ListProps extends ListStyleProps, StyleStateProps {\n  /** How offset spacing should be */\n  spacing?: 'normal' | 'condensed';\n  /** Menu variants for specific use cases and styles */\n  variant?: 'popover' | 'fixed';\n  /** is root menu */\n  root?: boolean;\n  /** bordered */\n  as?: 'ul' | 'ol';\n  showBorder?: boolean;\n}\n\nconst StyledList = styled('ul', styledOptions<'ul'>())<ListProps>(\n  system.css({\n    listStyle: 'none',\n    width: 1,\n    bg: 'inherit',\n    display: 'inline-block',\n    pl: 24,\n    WebkitFontSmoothing: 'antialiased',\n    MozOsxFontSmoothing: 'grayscale',\n  }),\n  system.states({\n    root: {\n      bg: 'background',\n      p: 0,\n    },\n    showBorder: {\n      border: 1,\n      borderRadius: 'sm',\n    },\n  }),\n  sharedStates,\n  listProps\n);\n\nexport const List = forwardRef<\n  HTMLUListElement,\n  ComponentProps<typeof StyledList>\n>(({ context = true, m = 0, root = true, variant, ...rest }, ref) => (\n  <StyledList\n    context={context}\n    m={m}\n    ref={ref}\n    root={root}\n    showBorder={variant !== 'fixed'}\n    variant={variant}\n    {...rest}\n  />\n));\n\nconst interactiveVariants = system.variant({\n  base: {\n    display: 'flex',\n    alignItems: 'center',\n    cursor: 'pointer',\n    width: 1,\n    zIndex: 1,\n    px: 24,\n    py: 12,\n    position: 'relative',\n    transition: transitionConcat(\n      ['color', 'background-color', 'border-color'],\n      'fast',\n      'linear'\n    ),\n    [Selectors.FOCUS_VISIBLE]: {\n      outline: 'none',\n    },\n    [MenuItemSelectors.OUTLINE]: {\n      content: \"''\",\n      position: 'absolute',\n      inset: 4,\n      borderRadius: 'md',\n      border: 2,\n      borderColor: 'primary',\n      opacity: 0,\n      zIndex: -1,\n    },\n    [MenuItemSelectors.OUTLINE_FOCUS_VISIBLE]: {\n      opacity: 1,\n    },\n  },\n  variants: {\n    select: {\n      [Selectors.DISABLED]: {\n        pointerEvents: 'none',\n      },\n      [Selectors.HOVER]: {\n        bg: 'background-hover',\n      },\n    },\n    link: {\n      [Selectors.BEFORE]: {\n        bg: 'inherit',\n        position: 'absolute',\n        display: 'inline-block',\n        left: 0,\n        width: 6,\n      },\n      [Selectors.HOVER]: {\n        textColor: 'primary',\n      },\n    },\n  },\n});\n\nconst activeStates = system.states({\n  selected: {\n    bg: 'background-selected',\n  },\n  active: {\n    fontWeight: 'title',\n  },\n  'active-navlink': {\n    fontWeight: 'title',\n    bg: 'background-selected',\n    [Selectors.BEFORE]: {\n      content: \"''\",\n      bg: 'secondary',\n    },\n  },\n  // Is named isDisabled to avoid conflicts with the HTML `disabled` attribute\n  isDisabled: {\n    bg: 'inherit',\n    cursor: 'not-allowed',\n    fontWeight: 400,\n    textColor: 'text-disabled',\n    [Selectors.HOVER]: {\n      textColor: 'text-disabled',\n      textDecoration: 'none',\n    },\n    [Selectors.BEFORE]: {\n      content: \"''\",\n      bg: 'inherit',\n    },\n  },\n});\n\nconst sizeVariants = system.variant({\n  prop: 'spacing',\n  variants: {\n    condensed: {\n      lineHeight: 'title',\n      minHeight: 40,\n      py: 8,\n      fontSize: 14,\n      [Selectors.BEFORE]: {\n        minHeight: 40,\n      },\n    },\n    normal: {\n      fontSize: 16,\n      minHeight: 48,\n      [Selectors.BEFORE]: {\n        minHeight: 48,\n      },\n    },\n  },\n});\n\nexport interface ListItemProps\n  extends ListStyleProps,\n    StyleStateProps,\n    StyleProps<typeof interactiveVariants>,\n    StyleProps<typeof activeStates>,\n    StyleProps<typeof sizeVariants> {}\n\nexport const ListItem = styled('li', styledOptions<'li'>())<ListItemProps>(\n  interactiveVariants,\n  activeStates,\n  sizeVariants,\n  sharedStates,\n  listProps\n);\n\nexport interface ListLinkProps extends ListItemProps {\n  active?: boolean;\n  navlink?: boolean;\n}\n\nconst StyledListLink = styled('a', styledOptions<'a'>())<ListLinkProps>(\n  resetStyles,\n  interactiveVariants,\n  activeStates,\n  sizeVariants,\n  sharedStates,\n  listProps\n);\n\nexport const ListLink = forwardRef<\n  HTMLAnchorElement,\n  ComponentProps<typeof StyledListLink>\n>(({ zIndex = 1, ...rest }, ref) => (\n  <StyledListLink ref={ref} zIndex={zIndex} {...rest} />\n));\n\nexport const ListButton = styled(\n  'button',\n  styledOptions<'button'>()\n)<ListLinkProps>(\n  resetStyles,\n  interactiveVariants,\n  activeStates,\n  sizeVariants,\n  sharedStates,\n  listProps\n);\n\nexport const MenuToolTipWrapper: React.FC<\n  Pick<ComponentProps<typeof MenuItem>, 'children' | 'label'> & {\n    tipId: string;\n  }\n> = ({ children, label, tipId }) => {\n  if (!label) {\n    return <>{children}</>;\n  }\n\n  const defaultTipProps = {\n    placement: 'floating',\n    id: tipId,\n    inheritDims: true,\n    shouldRenderAriaTip: false,\n  };\n\n  const wrapperProps =\n    label && isObject(label)\n      ? {\n          ...defaultTipProps,\n          ...label,\n        }\n      : {\n          info: label,\n          ...defaultTipProps,\n        };\n\n  return <ToolTip {...(wrapperProps as ToolTipProps)}>{children}</ToolTip>;\n};\n"]} */");
export const MenuToolTipWrapper = ({
children,
label,
tipId