@codecademy/brand 3.28.0-alpha.0a9279111d.0 → 3.28.0-alpha.0f5fb538f5.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (28) hide show
  1. package/dist/AppHeader/AppHeaderElements/AppHeaderCatalogDropdown/MarketingBanner.d.ts +2 -1
  2. package/dist/AppHeader/AppHeaderElements/AppHeaderCatalogDropdown/MarketingBanner.js +3 -3
  3. package/dist/AppHeader/AppHeaderElements/AppHeaderCatalogDropdown/NavPanels.d.ts +1 -0
  4. package/dist/AppHeader/AppHeaderElements/AppHeaderCatalogDropdown/NavPanels.js +8 -5
  5. package/dist/AppHeader/AppHeaderElements/AppHeaderCatalogDropdown/consts.d.ts +2 -1
  6. package/dist/AppHeader/AppHeaderElements/AppHeaderCatalogDropdown/consts.js +52 -2
  7. package/dist/AppHeader/AppHeaderElements/AppHeaderCatalogDropdown/index.js +5 -4
  8. package/dist/AppHeader/AppHeaderElements/AppHeaderDietCard/index.js +7 -5
  9. package/dist/AppHeader/AppHeaderElements/AppHeaderSection/AppHeaderSection.test.js +193 -0
  10. package/dist/AppHeader/AppHeaderElements/AppHeaderSection/MobileBackButton.d.ts +25 -0
  11. package/dist/AppHeader/AppHeaderElements/AppHeaderSection/MobileBackButton.js +13 -2
  12. package/dist/AppHeader/AppHeaderElements/AppHeaderSection/MobileNavMenu.js +12 -3
  13. package/dist/AppHeader/AppHeaderElements/AppHeaderSection/NavSection.d.ts +21 -0
  14. package/dist/AppHeader/AppHeaderElements/AppHeaderSection/NavSection.js +206 -0
  15. package/dist/AppHeader/AppHeaderElements/AppHeaderSection/PanelLayout.d.ts +2 -1
  16. package/dist/AppHeader/AppHeaderElements/AppHeaderSection/PanelLayout.js +8 -0
  17. package/dist/AppHeader/AppHeaderElements/AppHeaderSection/elements.d.ts +2 -55
  18. package/dist/AppHeader/AppHeaderElements/AppHeaderSection/elements.js +18 -69
  19. package/dist/AppHeader/AppHeaderElements/AppHeaderSection/index.d.ts +10 -15
  20. package/dist/AppHeader/AppHeaderElements/AppHeaderSection/index.js +28 -89
  21. package/dist/AppHeaderMobile/AppHeaderSubMenuMobile/index.js +8 -6
  22. package/dist/GlobalHeader/context.d.ts +3 -1
  23. package/dist/GlobalHeader/context.js +19 -15
  24. package/dist/GlobalHeader/index.js +50 -47
  25. package/dist/GlobalHeader/types.d.ts +1 -0
  26. package/package.json +1 -1
  27. package/dist/AppHeader/AppHeaderElements/AppHeaderSection/NavTabs.d.ts +0 -20
  28. package/dist/AppHeader/AppHeaderElements/AppHeaderSection/NavTabs.js +0 -126
@@ -0,0 +1,206 @@
1
+ import _styled from "@emotion/styled/base";
2
+ function _EMOTION_STRINGIFIED_CSS_ERROR__() { return "You have tried to stringify object returned from `css` function. It isn't supposed to be used directly (e.g. as value of the `className` prop), but rather handed to emotion so it can handle it (e.g. as value of `css` prop)."; }
3
+ import { Box, FlexBox, Text } from '@codecademy/gamut';
4
+ import { ArrowChevronRightIcon } from '@codecademy/gamut-icons';
5
+ import { motion } from 'framer-motion';
6
+ import React, { useCallback, useContext, useEffect, useRef } from 'react';
7
+ import { useGlobalHeaderItemClick, useHighlightLiveLearningContext } from '../../../GlobalHeader/context';
8
+ import { AppHeaderDropdownContext } from '../AppHeaderDropdownProvider';
9
+ import { PopularBadge } from './elements';
10
+ import { NavIconButton } from './MobileBackButton';
11
+ import { jsx as _jsx, jsxs as _jsxs, Fragment as _Fragment } from "react/jsx-runtime";
12
+ const NavPanelContainer = /*#__PURE__*/_styled(Box, {
13
+ target: "ed97qwe5",
14
+ label: "NavPanelContainer"
15
+ })("border-radius:", ({
16
+ isFirst
17
+ }) => isFirst ? '0 8px 8px 8px' : '8px', ";@media (max-width: 1200px){border-radius:8px;}" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../../../src/AppHeader/AppHeaderElements/AppHeaderSection/NavSection.tsx"],"names":[],"mappings":"AAkC2D","file":"../../../../src/AppHeader/AppHeaderElements/AppHeaderSection/NavSection.tsx","sourcesContent":["import { Box, FlexBox, Text } from '@codecademy/gamut';\nimport { ArrowChevronRightIcon, GamutIconProps } from '@codecademy/gamut-icons';\nimport styled from '@emotion/styled';\nimport { motion } from 'framer-motion';\nimport React, {\n  PropsWithChildren,\n  useCallback,\n  useContext,\n  useEffect,\n  useRef,\n} from 'react';\n\nimport {\n  useGlobalHeaderItemClick,\n  useHighlightLiveLearningContext,\n} from '../../../GlobalHeader/context';\nimport {\n  AppHeaderCatalogDropdownItem,\n  AppHeaderResourcesDropdownItem,\n} from '../../shared';\nimport { AppHeaderDropdownContext } from '../AppHeaderDropdownProvider';\nimport { PopularBadge } from './elements';\nimport { NavIconButton } from './MobileBackButton';\n\ntype NavSectionProps = PropsWithChildren & {\n  item: AppHeaderCatalogDropdownItem | AppHeaderResourcesDropdownItem;\n  isActiveTab: boolean;\n  setActiveTab: (tab: number) => void;\n  icon?: React.ComponentType<GamutIconProps>;\n  text: string;\n  index: number;\n  tabIndex?: number;\n};\n\nconst NavPanelContainer = styled(Box)<{ isFirst: boolean }>`\n  border-radius: ${({ isFirst }) => (isFirst ? '0 8px 8px 8px' : '8px')};\n\n  @media (max-width: 1200px) {\n    border-radius: 8px;\n  }\n`;\n\nexport const NavigationButton = styled.button<{\n  isActive: boolean;\n  index: number;\n}>`\n  grid-column: 1;\n  grid-row: ${({ index }) => index + 1};\n  padding: 16px;\n  border: none;\n  border-radius: ${({ isActive }) => (isActive ? '8px 0 0 8px' : '8px')};\n  background: none;\n  cursor: pointer;\n  color: ${({ theme, isActive }) =>\n    isActive ? theme.colors.primary : theme.colors.text};\n  text-align: left;\n  width: ${({ isActive }) => (isActive ? '100%' : 'calc(100% - 8px)')};\n  height: 60px;\n  display: flex;\n  justify-content: space-between;\n  align-items: center;\n  background-color: ${({ isActive, theme }) =>\n    isActive ? theme.colors.background : theme.colors['gray-100']};\n\n  &:hover,\n  &:focus {\n    background-color: ${({ theme, isActive }) =>\n      isActive ? theme.colors.background : theme.colors['navy-100']};\n    color: ${({ theme }) => theme.colors.primary};\n  }\n`;\n\nconst OverflowText = styled(Text)`\n  text-overflow: ellipsis;\n  overflow: hidden;\n  white-space: nowrap;\n`;\n\nconst StyledArrowChevronRightIcon = styled(ArrowChevronRightIcon)<{\n  isActive: boolean;\n}>`\n  display: ${({ isActive }) => (isActive ? 'block' : 'none')};\n`;\n\nconst NavIconButtonContainer = styled(Box)<{\n  isActive: boolean;\n  index: number;\n}>`\n  background-color: ${({ theme, isActive }) =>\n    isActive ? theme.colors.background : theme.colors['gray-100']};\n  border-radius: ${({ isActive }) => (isActive ? '8px 0 0 8px' : '8px')};\n\n  grid-column: 1;\n  grid-row: ${({ index }) => index};\n  padding: 8px;\n`;\n\nconst PopularBadgeDot = styled(Box)`\n  background-color: ${({ theme }) => theme.colors['hyper-400']};\n  border-radius: 8px;\n  height: 16px;\n  width: 16px;\n  border: 2px solid ${({ theme }) => theme.colors['gray-100']};\n`;\n\nconst NavSection = ({\n  isActiveTab,\n  setActiveTab,\n  icon: Icon,\n  text,\n  index,\n  children,\n  item,\n  tabIndex,\n}: NavSectionProps) => {\n  const { globalHeaderItemClick } = useGlobalHeaderItemClick();\n  const displayHighlightLiveLearning = useHighlightLiveLearningContext();\n  const { setFirstItemRef } = useContext(AppHeaderDropdownContext);\n  const gridRow = index + 2; // +1 because of the back button\n  const buttonRef = useRef<HTMLButtonElement>(null);\n\n  useEffect(() => {\n    if (index === 0 && buttonRef.current) {\n      setFirstItemRef?.(buttonRef.current);\n    }\n  }, [index, setFirstItemRef]);\n\n  const onSelect = useCallback(\n    (e: React.MouseEvent) => {\n      globalHeaderItemClick(e, item);\n      setActiveTab(index);\n    },\n    [globalHeaderItemClick, item, index, setActiveTab]\n  );\n\n  const highlightLiveLearning =\n    item.id === 'live-learning' && displayHighlightLiveLearning;\n  const showPopularBadge = highlightLiveLearning && !isActiveTab;\n\n  return (\n    <>\n      <Box display={{ _: 'none', sm: 'grid' }}>\n        {/* nav button with text, sm and above */}\n        <NavigationButton\n          ref={buttonRef}\n          isActive={isActiveTab}\n          index={gridRow}\n          onClick={onSelect}\n          data-testid={`nav-section-${item.id}`}\n          aria-expanded={isActiveTab}\n          tabIndex={tabIndex}\n          aria-label={text}\n        >\n          <FlexBox gap={8} alignItems=\"center\">\n            {Icon && (\n              <Box height={24} width={24}>\n                <Icon size={24} />\n              </Box>\n            )}\n            <OverflowText\n              display={{ _: 'none', sm: 'inline-block' }}\n              maxWidth={{ _: '110px', md: 'none' }}\n            >\n              {text}\n            </OverflowText>\n          </FlexBox>\n          <Box display={{ _: 'none', sm: 'block' }}>\n            <StyledArrowChevronRightIcon isActive={isActiveTab} />\n          </Box>\n          {showPopularBadge && (\n            <Box display={{ _: 'none', sm: 'block' }}>\n              <PopularBadge variant=\"custom\" size=\"sm\" bg=\"hyper-400\">\n                Popular\n              </PopularBadge>\n            </Box>\n          )}\n        </NavigationButton>\n      </Box>\n      {/* nav button with icon, xs only */}\n      {Icon && (\n        <NavIconButtonContainer\n          isActive={isActiveTab}\n          display={{ _: 'none', xs: 'grid', sm: 'none' }}\n          index={gridRow}\n        >\n          <NavIconButton\n            onClick={onSelect}\n            icon={Icon}\n            tip={highlightLiveLearning ? 'Live learning (popular)' : text}\n            tipProps={{\n              alignment: 'right-center',\n              narrow: false,\n              placement: 'floating',\n            }}\n            aria-label={\n              highlightLiveLearning ? 'Live learning (popular)' : text\n            }\n          />\n          {showPopularBadge && (\n            <PopularBadgeDot position=\"absolute\" left=\"42px\" aria-hidden />\n          )}\n        </NavIconButtonContainer>\n      )}\n\n      <NavPanelContainer\n        isFirst={index === 0}\n        display={isActiveTab ? 'block' : 'none'}\n        gridColumn=\"2 / span 12\"\n        gridRow=\"1 / span 8\"\n        bg=\"background\"\n        px={32}\n        pt={16}\n        pb={24}\n      >\n        <motion.div\n          animate={{ opacity: isActiveTab ? 1 : 0 }}\n          transition={{ duration: 0.4, ease: 'easeInOut' }}\n        >\n          {children}\n        </motion.div>\n      </NavPanelContainer>\n    </>\n  );\n};\n\nexport default NavSection;\n"]} */"));
18
+ export const NavigationButton = /*#__PURE__*/_styled("button", {
19
+ target: "ed97qwe4",
20
+ label: "NavigationButton"
21
+ })("grid-column:1;grid-row:", ({
22
+ index
23
+ }) => index + 1, ";padding:16px;border:none;border-radius:", ({
24
+ isActive
25
+ }) => isActive ? '8px 0 0 8px' : '8px', ";background:none;cursor:pointer;color:", ({
26
+ theme,
27
+ isActive
28
+ }) => isActive ? theme.colors.primary : theme.colors.text, ";text-align:left;width:", ({
29
+ isActive
30
+ }) => isActive ? '100%' : 'calc(100% - 8px)', ";height:60px;display:flex;justify-content:space-between;align-items:center;background-color:", ({
31
+ isActive,
32
+ theme
33
+ }) => isActive ? theme.colors.background : theme.colors['gray-100'], ";&:hover,&:focus{background-color:", ({
34
+ theme,
35
+ isActive
36
+ }) => isActive ? theme.colors.background : theme.colors['navy-100'], ";color:", ({
37
+ theme
38
+ }) => theme.colors.primary, ";}" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../../../src/AppHeader/AppHeaderElements/AppHeaderSection/NavSection.tsx"],"names":[],"mappings":"AA6CE","file":"../../../../src/AppHeader/AppHeaderElements/AppHeaderSection/NavSection.tsx","sourcesContent":["import { Box, FlexBox, Text } from '@codecademy/gamut';\nimport { ArrowChevronRightIcon, GamutIconProps } from '@codecademy/gamut-icons';\nimport styled from '@emotion/styled';\nimport { motion } from 'framer-motion';\nimport React, {\n  PropsWithChildren,\n  useCallback,\n  useContext,\n  useEffect,\n  useRef,\n} from 'react';\n\nimport {\n  useGlobalHeaderItemClick,\n  useHighlightLiveLearningContext,\n} from '../../../GlobalHeader/context';\nimport {\n  AppHeaderCatalogDropdownItem,\n  AppHeaderResourcesDropdownItem,\n} from '../../shared';\nimport { AppHeaderDropdownContext } from '../AppHeaderDropdownProvider';\nimport { PopularBadge } from './elements';\nimport { NavIconButton } from './MobileBackButton';\n\ntype NavSectionProps = PropsWithChildren & {\n  item: AppHeaderCatalogDropdownItem | AppHeaderResourcesDropdownItem;\n  isActiveTab: boolean;\n  setActiveTab: (tab: number) => void;\n  icon?: React.ComponentType<GamutIconProps>;\n  text: string;\n  index: number;\n  tabIndex?: number;\n};\n\nconst NavPanelContainer = styled(Box)<{ isFirst: boolean }>`\n  border-radius: ${({ isFirst }) => (isFirst ? '0 8px 8px 8px' : '8px')};\n\n  @media (max-width: 1200px) {\n    border-radius: 8px;\n  }\n`;\n\nexport const NavigationButton = styled.button<{\n  isActive: boolean;\n  index: number;\n}>`\n  grid-column: 1;\n  grid-row: ${({ index }) => index + 1};\n  padding: 16px;\n  border: none;\n  border-radius: ${({ isActive }) => (isActive ? '8px 0 0 8px' : '8px')};\n  background: none;\n  cursor: pointer;\n  color: ${({ theme, isActive }) =>\n    isActive ? theme.colors.primary : theme.colors.text};\n  text-align: left;\n  width: ${({ isActive }) => (isActive ? '100%' : 'calc(100% - 8px)')};\n  height: 60px;\n  display: flex;\n  justify-content: space-between;\n  align-items: center;\n  background-color: ${({ isActive, theme }) =>\n    isActive ? theme.colors.background : theme.colors['gray-100']};\n\n  &:hover,\n  &:focus {\n    background-color: ${({ theme, isActive }) =>\n      isActive ? theme.colors.background : theme.colors['navy-100']};\n    color: ${({ theme }) => theme.colors.primary};\n  }\n`;\n\nconst OverflowText = styled(Text)`\n  text-overflow: ellipsis;\n  overflow: hidden;\n  white-space: nowrap;\n`;\n\nconst StyledArrowChevronRightIcon = styled(ArrowChevronRightIcon)<{\n  isActive: boolean;\n}>`\n  display: ${({ isActive }) => (isActive ? 'block' : 'none')};\n`;\n\nconst NavIconButtonContainer = styled(Box)<{\n  isActive: boolean;\n  index: number;\n}>`\n  background-color: ${({ theme, isActive }) =>\n    isActive ? theme.colors.background : theme.colors['gray-100']};\n  border-radius: ${({ isActive }) => (isActive ? '8px 0 0 8px' : '8px')};\n\n  grid-column: 1;\n  grid-row: ${({ index }) => index};\n  padding: 8px;\n`;\n\nconst PopularBadgeDot = styled(Box)`\n  background-color: ${({ theme }) => theme.colors['hyper-400']};\n  border-radius: 8px;\n  height: 16px;\n  width: 16px;\n  border: 2px solid ${({ theme }) => theme.colors['gray-100']};\n`;\n\nconst NavSection = ({\n  isActiveTab,\n  setActiveTab,\n  icon: Icon,\n  text,\n  index,\n  children,\n  item,\n  tabIndex,\n}: NavSectionProps) => {\n  const { globalHeaderItemClick } = useGlobalHeaderItemClick();\n  const displayHighlightLiveLearning = useHighlightLiveLearningContext();\n  const { setFirstItemRef } = useContext(AppHeaderDropdownContext);\n  const gridRow = index + 2; // +1 because of the back button\n  const buttonRef = useRef<HTMLButtonElement>(null);\n\n  useEffect(() => {\n    if (index === 0 && buttonRef.current) {\n      setFirstItemRef?.(buttonRef.current);\n    }\n  }, [index, setFirstItemRef]);\n\n  const onSelect = useCallback(\n    (e: React.MouseEvent) => {\n      globalHeaderItemClick(e, item);\n      setActiveTab(index);\n    },\n    [globalHeaderItemClick, item, index, setActiveTab]\n  );\n\n  const highlightLiveLearning =\n    item.id === 'live-learning' && displayHighlightLiveLearning;\n  const showPopularBadge = highlightLiveLearning && !isActiveTab;\n\n  return (\n    <>\n      <Box display={{ _: 'none', sm: 'grid' }}>\n        {/* nav button with text, sm and above */}\n        <NavigationButton\n          ref={buttonRef}\n          isActive={isActiveTab}\n          index={gridRow}\n          onClick={onSelect}\n          data-testid={`nav-section-${item.id}`}\n          aria-expanded={isActiveTab}\n          tabIndex={tabIndex}\n          aria-label={text}\n        >\n          <FlexBox gap={8} alignItems=\"center\">\n            {Icon && (\n              <Box height={24} width={24}>\n                <Icon size={24} />\n              </Box>\n            )}\n            <OverflowText\n              display={{ _: 'none', sm: 'inline-block' }}\n              maxWidth={{ _: '110px', md: 'none' }}\n            >\n              {text}\n            </OverflowText>\n          </FlexBox>\n          <Box display={{ _: 'none', sm: 'block' }}>\n            <StyledArrowChevronRightIcon isActive={isActiveTab} />\n          </Box>\n          {showPopularBadge && (\n            <Box display={{ _: 'none', sm: 'block' }}>\n              <PopularBadge variant=\"custom\" size=\"sm\" bg=\"hyper-400\">\n                Popular\n              </PopularBadge>\n            </Box>\n          )}\n        </NavigationButton>\n      </Box>\n      {/* nav button with icon, xs only */}\n      {Icon && (\n        <NavIconButtonContainer\n          isActive={isActiveTab}\n          display={{ _: 'none', xs: 'grid', sm: 'none' }}\n          index={gridRow}\n        >\n          <NavIconButton\n            onClick={onSelect}\n            icon={Icon}\n            tip={highlightLiveLearning ? 'Live learning (popular)' : text}\n            tipProps={{\n              alignment: 'right-center',\n              narrow: false,\n              placement: 'floating',\n            }}\n            aria-label={\n              highlightLiveLearning ? 'Live learning (popular)' : text\n            }\n          />\n          {showPopularBadge && (\n            <PopularBadgeDot position=\"absolute\" left=\"42px\" aria-hidden />\n          )}\n        </NavIconButtonContainer>\n      )}\n\n      <NavPanelContainer\n        isFirst={index === 0}\n        display={isActiveTab ? 'block' : 'none'}\n        gridColumn=\"2 / span 12\"\n        gridRow=\"1 / span 8\"\n        bg=\"background\"\n        px={32}\n        pt={16}\n        pb={24}\n      >\n        <motion.div\n          animate={{ opacity: isActiveTab ? 1 : 0 }}\n          transition={{ duration: 0.4, ease: 'easeInOut' }}\n        >\n          {children}\n        </motion.div>\n      </NavPanelContainer>\n    </>\n  );\n};\n\nexport default NavSection;\n"]} */"));
39
+ const OverflowText = /*#__PURE__*/_styled(Text, {
40
+ target: "ed97qwe3",
41
+ label: "OverflowText"
42
+ })(process.env.NODE_ENV === "production" ? {
43
+ name: "12wal98",
44
+ styles: "text-overflow:ellipsis;overflow:hidden;white-space:nowrap"
45
+ } : {
46
+ name: "12wal98",
47
+ styles: "text-overflow:ellipsis;overflow:hidden;white-space:nowrap/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../../../src/AppHeader/AppHeaderElements/AppHeaderSection/NavSection.tsx"],"names":[],"mappings":"AAwEiC","file":"../../../../src/AppHeader/AppHeaderElements/AppHeaderSection/NavSection.tsx","sourcesContent":["import { Box, FlexBox, Text } from '@codecademy/gamut';\nimport { ArrowChevronRightIcon, GamutIconProps } from '@codecademy/gamut-icons';\nimport styled from '@emotion/styled';\nimport { motion } from 'framer-motion';\nimport React, {\n  PropsWithChildren,\n  useCallback,\n  useContext,\n  useEffect,\n  useRef,\n} from 'react';\n\nimport {\n  useGlobalHeaderItemClick,\n  useHighlightLiveLearningContext,\n} from '../../../GlobalHeader/context';\nimport {\n  AppHeaderCatalogDropdownItem,\n  AppHeaderResourcesDropdownItem,\n} from '../../shared';\nimport { AppHeaderDropdownContext } from '../AppHeaderDropdownProvider';\nimport { PopularBadge } from './elements';\nimport { NavIconButton } from './MobileBackButton';\n\ntype NavSectionProps = PropsWithChildren & {\n  item: AppHeaderCatalogDropdownItem | AppHeaderResourcesDropdownItem;\n  isActiveTab: boolean;\n  setActiveTab: (tab: number) => void;\n  icon?: React.ComponentType<GamutIconProps>;\n  text: string;\n  index: number;\n  tabIndex?: number;\n};\n\nconst NavPanelContainer = styled(Box)<{ isFirst: boolean }>`\n  border-radius: ${({ isFirst }) => (isFirst ? '0 8px 8px 8px' : '8px')};\n\n  @media (max-width: 1200px) {\n    border-radius: 8px;\n  }\n`;\n\nexport const NavigationButton = styled.button<{\n  isActive: boolean;\n  index: number;\n}>`\n  grid-column: 1;\n  grid-row: ${({ index }) => index + 1};\n  padding: 16px;\n  border: none;\n  border-radius: ${({ isActive }) => (isActive ? '8px 0 0 8px' : '8px')};\n  background: none;\n  cursor: pointer;\n  color: ${({ theme, isActive }) =>\n    isActive ? theme.colors.primary : theme.colors.text};\n  text-align: left;\n  width: ${({ isActive }) => (isActive ? '100%' : 'calc(100% - 8px)')};\n  height: 60px;\n  display: flex;\n  justify-content: space-between;\n  align-items: center;\n  background-color: ${({ isActive, theme }) =>\n    isActive ? theme.colors.background : theme.colors['gray-100']};\n\n  &:hover,\n  &:focus {\n    background-color: ${({ theme, isActive }) =>\n      isActive ? theme.colors.background : theme.colors['navy-100']};\n    color: ${({ theme }) => theme.colors.primary};\n  }\n`;\n\nconst OverflowText = styled(Text)`\n  text-overflow: ellipsis;\n  overflow: hidden;\n  white-space: nowrap;\n`;\n\nconst StyledArrowChevronRightIcon = styled(ArrowChevronRightIcon)<{\n  isActive: boolean;\n}>`\n  display: ${({ isActive }) => (isActive ? 'block' : 'none')};\n`;\n\nconst NavIconButtonContainer = styled(Box)<{\n  isActive: boolean;\n  index: number;\n}>`\n  background-color: ${({ theme, isActive }) =>\n    isActive ? theme.colors.background : theme.colors['gray-100']};\n  border-radius: ${({ isActive }) => (isActive ? '8px 0 0 8px' : '8px')};\n\n  grid-column: 1;\n  grid-row: ${({ index }) => index};\n  padding: 8px;\n`;\n\nconst PopularBadgeDot = styled(Box)`\n  background-color: ${({ theme }) => theme.colors['hyper-400']};\n  border-radius: 8px;\n  height: 16px;\n  width: 16px;\n  border: 2px solid ${({ theme }) => theme.colors['gray-100']};\n`;\n\nconst NavSection = ({\n  isActiveTab,\n  setActiveTab,\n  icon: Icon,\n  text,\n  index,\n  children,\n  item,\n  tabIndex,\n}: NavSectionProps) => {\n  const { globalHeaderItemClick } = useGlobalHeaderItemClick();\n  const displayHighlightLiveLearning = useHighlightLiveLearningContext();\n  const { setFirstItemRef } = useContext(AppHeaderDropdownContext);\n  const gridRow = index + 2; // +1 because of the back button\n  const buttonRef = useRef<HTMLButtonElement>(null);\n\n  useEffect(() => {\n    if (index === 0 && buttonRef.current) {\n      setFirstItemRef?.(buttonRef.current);\n    }\n  }, [index, setFirstItemRef]);\n\n  const onSelect = useCallback(\n    (e: React.MouseEvent) => {\n      globalHeaderItemClick(e, item);\n      setActiveTab(index);\n    },\n    [globalHeaderItemClick, item, index, setActiveTab]\n  );\n\n  const highlightLiveLearning =\n    item.id === 'live-learning' && displayHighlightLiveLearning;\n  const showPopularBadge = highlightLiveLearning && !isActiveTab;\n\n  return (\n    <>\n      <Box display={{ _: 'none', sm: 'grid' }}>\n        {/* nav button with text, sm and above */}\n        <NavigationButton\n          ref={buttonRef}\n          isActive={isActiveTab}\n          index={gridRow}\n          onClick={onSelect}\n          data-testid={`nav-section-${item.id}`}\n          aria-expanded={isActiveTab}\n          tabIndex={tabIndex}\n          aria-label={text}\n        >\n          <FlexBox gap={8} alignItems=\"center\">\n            {Icon && (\n              <Box height={24} width={24}>\n                <Icon size={24} />\n              </Box>\n            )}\n            <OverflowText\n              display={{ _: 'none', sm: 'inline-block' }}\n              maxWidth={{ _: '110px', md: 'none' }}\n            >\n              {text}\n            </OverflowText>\n          </FlexBox>\n          <Box display={{ _: 'none', sm: 'block' }}>\n            <StyledArrowChevronRightIcon isActive={isActiveTab} />\n          </Box>\n          {showPopularBadge && (\n            <Box display={{ _: 'none', sm: 'block' }}>\n              <PopularBadge variant=\"custom\" size=\"sm\" bg=\"hyper-400\">\n                Popular\n              </PopularBadge>\n            </Box>\n          )}\n        </NavigationButton>\n      </Box>\n      {/* nav button with icon, xs only */}\n      {Icon && (\n        <NavIconButtonContainer\n          isActive={isActiveTab}\n          display={{ _: 'none', xs: 'grid', sm: 'none' }}\n          index={gridRow}\n        >\n          <NavIconButton\n            onClick={onSelect}\n            icon={Icon}\n            tip={highlightLiveLearning ? 'Live learning (popular)' : text}\n            tipProps={{\n              alignment: 'right-center',\n              narrow: false,\n              placement: 'floating',\n            }}\n            aria-label={\n              highlightLiveLearning ? 'Live learning (popular)' : text\n            }\n          />\n          {showPopularBadge && (\n            <PopularBadgeDot position=\"absolute\" left=\"42px\" aria-hidden />\n          )}\n        </NavIconButtonContainer>\n      )}\n\n      <NavPanelContainer\n        isFirst={index === 0}\n        display={isActiveTab ? 'block' : 'none'}\n        gridColumn=\"2 / span 12\"\n        gridRow=\"1 / span 8\"\n        bg=\"background\"\n        px={32}\n        pt={16}\n        pb={24}\n      >\n        <motion.div\n          animate={{ opacity: isActiveTab ? 1 : 0 }}\n          transition={{ duration: 0.4, ease: 'easeInOut' }}\n        >\n          {children}\n        </motion.div>\n      </NavPanelContainer>\n    </>\n  );\n};\n\nexport default NavSection;\n"]} */",
48
+ toString: _EMOTION_STRINGIFIED_CSS_ERROR__
49
+ });
50
+ const StyledArrowChevronRightIcon = /*#__PURE__*/_styled(ArrowChevronRightIcon, {
51
+ target: "ed97qwe2",
52
+ label: "StyledArrowChevronRightIcon"
53
+ })("display:", ({
54
+ isActive
55
+ }) => isActive ? 'block' : 'none', ";" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../../../src/AppHeader/AppHeaderElements/AppHeaderSection/NavSection.tsx"],"names":[],"mappings":"AAgFE","file":"../../../../src/AppHeader/AppHeaderElements/AppHeaderSection/NavSection.tsx","sourcesContent":["import { Box, FlexBox, Text } from '@codecademy/gamut';\nimport { ArrowChevronRightIcon, GamutIconProps } from '@codecademy/gamut-icons';\nimport styled from '@emotion/styled';\nimport { motion } from 'framer-motion';\nimport React, {\n  PropsWithChildren,\n  useCallback,\n  useContext,\n  useEffect,\n  useRef,\n} from 'react';\n\nimport {\n  useGlobalHeaderItemClick,\n  useHighlightLiveLearningContext,\n} from '../../../GlobalHeader/context';\nimport {\n  AppHeaderCatalogDropdownItem,\n  AppHeaderResourcesDropdownItem,\n} from '../../shared';\nimport { AppHeaderDropdownContext } from '../AppHeaderDropdownProvider';\nimport { PopularBadge } from './elements';\nimport { NavIconButton } from './MobileBackButton';\n\ntype NavSectionProps = PropsWithChildren & {\n  item: AppHeaderCatalogDropdownItem | AppHeaderResourcesDropdownItem;\n  isActiveTab: boolean;\n  setActiveTab: (tab: number) => void;\n  icon?: React.ComponentType<GamutIconProps>;\n  text: string;\n  index: number;\n  tabIndex?: number;\n};\n\nconst NavPanelContainer = styled(Box)<{ isFirst: boolean }>`\n  border-radius: ${({ isFirst }) => (isFirst ? '0 8px 8px 8px' : '8px')};\n\n  @media (max-width: 1200px) {\n    border-radius: 8px;\n  }\n`;\n\nexport const NavigationButton = styled.button<{\n  isActive: boolean;\n  index: number;\n}>`\n  grid-column: 1;\n  grid-row: ${({ index }) => index + 1};\n  padding: 16px;\n  border: none;\n  border-radius: ${({ isActive }) => (isActive ? '8px 0 0 8px' : '8px')};\n  background: none;\n  cursor: pointer;\n  color: ${({ theme, isActive }) =>\n    isActive ? theme.colors.primary : theme.colors.text};\n  text-align: left;\n  width: ${({ isActive }) => (isActive ? '100%' : 'calc(100% - 8px)')};\n  height: 60px;\n  display: flex;\n  justify-content: space-between;\n  align-items: center;\n  background-color: ${({ isActive, theme }) =>\n    isActive ? theme.colors.background : theme.colors['gray-100']};\n\n  &:hover,\n  &:focus {\n    background-color: ${({ theme, isActive }) =>\n      isActive ? theme.colors.background : theme.colors['navy-100']};\n    color: ${({ theme }) => theme.colors.primary};\n  }\n`;\n\nconst OverflowText = styled(Text)`\n  text-overflow: ellipsis;\n  overflow: hidden;\n  white-space: nowrap;\n`;\n\nconst StyledArrowChevronRightIcon = styled(ArrowChevronRightIcon)<{\n  isActive: boolean;\n}>`\n  display: ${({ isActive }) => (isActive ? 'block' : 'none')};\n`;\n\nconst NavIconButtonContainer = styled(Box)<{\n  isActive: boolean;\n  index: number;\n}>`\n  background-color: ${({ theme, isActive }) =>\n    isActive ? theme.colors.background : theme.colors['gray-100']};\n  border-radius: ${({ isActive }) => (isActive ? '8px 0 0 8px' : '8px')};\n\n  grid-column: 1;\n  grid-row: ${({ index }) => index};\n  padding: 8px;\n`;\n\nconst PopularBadgeDot = styled(Box)`\n  background-color: ${({ theme }) => theme.colors['hyper-400']};\n  border-radius: 8px;\n  height: 16px;\n  width: 16px;\n  border: 2px solid ${({ theme }) => theme.colors['gray-100']};\n`;\n\nconst NavSection = ({\n  isActiveTab,\n  setActiveTab,\n  icon: Icon,\n  text,\n  index,\n  children,\n  item,\n  tabIndex,\n}: NavSectionProps) => {\n  const { globalHeaderItemClick } = useGlobalHeaderItemClick();\n  const displayHighlightLiveLearning = useHighlightLiveLearningContext();\n  const { setFirstItemRef } = useContext(AppHeaderDropdownContext);\n  const gridRow = index + 2; // +1 because of the back button\n  const buttonRef = useRef<HTMLButtonElement>(null);\n\n  useEffect(() => {\n    if (index === 0 && buttonRef.current) {\n      setFirstItemRef?.(buttonRef.current);\n    }\n  }, [index, setFirstItemRef]);\n\n  const onSelect = useCallback(\n    (e: React.MouseEvent) => {\n      globalHeaderItemClick(e, item);\n      setActiveTab(index);\n    },\n    [globalHeaderItemClick, item, index, setActiveTab]\n  );\n\n  const highlightLiveLearning =\n    item.id === 'live-learning' && displayHighlightLiveLearning;\n  const showPopularBadge = highlightLiveLearning && !isActiveTab;\n\n  return (\n    <>\n      <Box display={{ _: 'none', sm: 'grid' }}>\n        {/* nav button with text, sm and above */}\n        <NavigationButton\n          ref={buttonRef}\n          isActive={isActiveTab}\n          index={gridRow}\n          onClick={onSelect}\n          data-testid={`nav-section-${item.id}`}\n          aria-expanded={isActiveTab}\n          tabIndex={tabIndex}\n          aria-label={text}\n        >\n          <FlexBox gap={8} alignItems=\"center\">\n            {Icon && (\n              <Box height={24} width={24}>\n                <Icon size={24} />\n              </Box>\n            )}\n            <OverflowText\n              display={{ _: 'none', sm: 'inline-block' }}\n              maxWidth={{ _: '110px', md: 'none' }}\n            >\n              {text}\n            </OverflowText>\n          </FlexBox>\n          <Box display={{ _: 'none', sm: 'block' }}>\n            <StyledArrowChevronRightIcon isActive={isActiveTab} />\n          </Box>\n          {showPopularBadge && (\n            <Box display={{ _: 'none', sm: 'block' }}>\n              <PopularBadge variant=\"custom\" size=\"sm\" bg=\"hyper-400\">\n                Popular\n              </PopularBadge>\n            </Box>\n          )}\n        </NavigationButton>\n      </Box>\n      {/* nav button with icon, xs only */}\n      {Icon && (\n        <NavIconButtonContainer\n          isActive={isActiveTab}\n          display={{ _: 'none', xs: 'grid', sm: 'none' }}\n          index={gridRow}\n        >\n          <NavIconButton\n            onClick={onSelect}\n            icon={Icon}\n            tip={highlightLiveLearning ? 'Live learning (popular)' : text}\n            tipProps={{\n              alignment: 'right-center',\n              narrow: false,\n              placement: 'floating',\n            }}\n            aria-label={\n              highlightLiveLearning ? 'Live learning (popular)' : text\n            }\n          />\n          {showPopularBadge && (\n            <PopularBadgeDot position=\"absolute\" left=\"42px\" aria-hidden />\n          )}\n        </NavIconButtonContainer>\n      )}\n\n      <NavPanelContainer\n        isFirst={index === 0}\n        display={isActiveTab ? 'block' : 'none'}\n        gridColumn=\"2 / span 12\"\n        gridRow=\"1 / span 8\"\n        bg=\"background\"\n        px={32}\n        pt={16}\n        pb={24}\n      >\n        <motion.div\n          animate={{ opacity: isActiveTab ? 1 : 0 }}\n          transition={{ duration: 0.4, ease: 'easeInOut' }}\n        >\n          {children}\n        </motion.div>\n      </NavPanelContainer>\n    </>\n  );\n};\n\nexport default NavSection;\n"]} */"));
56
+ const NavIconButtonContainer = /*#__PURE__*/_styled(Box, {
57
+ target: "ed97qwe1",
58
+ label: "NavIconButtonContainer"
59
+ })("background-color:", ({
60
+ theme,
61
+ isActive
62
+ }) => isActive ? theme.colors.background : theme.colors['gray-100'], ";border-radius:", ({
63
+ isActive
64
+ }) => isActive ? '8px 0 0 8px' : '8px', ";grid-column:1;grid-row:", ({
65
+ index
66
+ }) => index, ";padding:8px;" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../../../src/AppHeader/AppHeaderElements/AppHeaderSection/NavSection.tsx"],"names":[],"mappings":"AAuFE","file":"../../../../src/AppHeader/AppHeaderElements/AppHeaderSection/NavSection.tsx","sourcesContent":["import { Box, FlexBox, Text } from '@codecademy/gamut';\nimport { ArrowChevronRightIcon, GamutIconProps } from '@codecademy/gamut-icons';\nimport styled from '@emotion/styled';\nimport { motion } from 'framer-motion';\nimport React, {\n  PropsWithChildren,\n  useCallback,\n  useContext,\n  useEffect,\n  useRef,\n} from 'react';\n\nimport {\n  useGlobalHeaderItemClick,\n  useHighlightLiveLearningContext,\n} from '../../../GlobalHeader/context';\nimport {\n  AppHeaderCatalogDropdownItem,\n  AppHeaderResourcesDropdownItem,\n} from '../../shared';\nimport { AppHeaderDropdownContext } from '../AppHeaderDropdownProvider';\nimport { PopularBadge } from './elements';\nimport { NavIconButton } from './MobileBackButton';\n\ntype NavSectionProps = PropsWithChildren & {\n  item: AppHeaderCatalogDropdownItem | AppHeaderResourcesDropdownItem;\n  isActiveTab: boolean;\n  setActiveTab: (tab: number) => void;\n  icon?: React.ComponentType<GamutIconProps>;\n  text: string;\n  index: number;\n  tabIndex?: number;\n};\n\nconst NavPanelContainer = styled(Box)<{ isFirst: boolean }>`\n  border-radius: ${({ isFirst }) => (isFirst ? '0 8px 8px 8px' : '8px')};\n\n  @media (max-width: 1200px) {\n    border-radius: 8px;\n  }\n`;\n\nexport const NavigationButton = styled.button<{\n  isActive: boolean;\n  index: number;\n}>`\n  grid-column: 1;\n  grid-row: ${({ index }) => index + 1};\n  padding: 16px;\n  border: none;\n  border-radius: ${({ isActive }) => (isActive ? '8px 0 0 8px' : '8px')};\n  background: none;\n  cursor: pointer;\n  color: ${({ theme, isActive }) =>\n    isActive ? theme.colors.primary : theme.colors.text};\n  text-align: left;\n  width: ${({ isActive }) => (isActive ? '100%' : 'calc(100% - 8px)')};\n  height: 60px;\n  display: flex;\n  justify-content: space-between;\n  align-items: center;\n  background-color: ${({ isActive, theme }) =>\n    isActive ? theme.colors.background : theme.colors['gray-100']};\n\n  &:hover,\n  &:focus {\n    background-color: ${({ theme, isActive }) =>\n      isActive ? theme.colors.background : theme.colors['navy-100']};\n    color: ${({ theme }) => theme.colors.primary};\n  }\n`;\n\nconst OverflowText = styled(Text)`\n  text-overflow: ellipsis;\n  overflow: hidden;\n  white-space: nowrap;\n`;\n\nconst StyledArrowChevronRightIcon = styled(ArrowChevronRightIcon)<{\n  isActive: boolean;\n}>`\n  display: ${({ isActive }) => (isActive ? 'block' : 'none')};\n`;\n\nconst NavIconButtonContainer = styled(Box)<{\n  isActive: boolean;\n  index: number;\n}>`\n  background-color: ${({ theme, isActive }) =>\n    isActive ? theme.colors.background : theme.colors['gray-100']};\n  border-radius: ${({ isActive }) => (isActive ? '8px 0 0 8px' : '8px')};\n\n  grid-column: 1;\n  grid-row: ${({ index }) => index};\n  padding: 8px;\n`;\n\nconst PopularBadgeDot = styled(Box)`\n  background-color: ${({ theme }) => theme.colors['hyper-400']};\n  border-radius: 8px;\n  height: 16px;\n  width: 16px;\n  border: 2px solid ${({ theme }) => theme.colors['gray-100']};\n`;\n\nconst NavSection = ({\n  isActiveTab,\n  setActiveTab,\n  icon: Icon,\n  text,\n  index,\n  children,\n  item,\n  tabIndex,\n}: NavSectionProps) => {\n  const { globalHeaderItemClick } = useGlobalHeaderItemClick();\n  const displayHighlightLiveLearning = useHighlightLiveLearningContext();\n  const { setFirstItemRef } = useContext(AppHeaderDropdownContext);\n  const gridRow = index + 2; // +1 because of the back button\n  const buttonRef = useRef<HTMLButtonElement>(null);\n\n  useEffect(() => {\n    if (index === 0 && buttonRef.current) {\n      setFirstItemRef?.(buttonRef.current);\n    }\n  }, [index, setFirstItemRef]);\n\n  const onSelect = useCallback(\n    (e: React.MouseEvent) => {\n      globalHeaderItemClick(e, item);\n      setActiveTab(index);\n    },\n    [globalHeaderItemClick, item, index, setActiveTab]\n  );\n\n  const highlightLiveLearning =\n    item.id === 'live-learning' && displayHighlightLiveLearning;\n  const showPopularBadge = highlightLiveLearning && !isActiveTab;\n\n  return (\n    <>\n      <Box display={{ _: 'none', sm: 'grid' }}>\n        {/* nav button with text, sm and above */}\n        <NavigationButton\n          ref={buttonRef}\n          isActive={isActiveTab}\n          index={gridRow}\n          onClick={onSelect}\n          data-testid={`nav-section-${item.id}`}\n          aria-expanded={isActiveTab}\n          tabIndex={tabIndex}\n          aria-label={text}\n        >\n          <FlexBox gap={8} alignItems=\"center\">\n            {Icon && (\n              <Box height={24} width={24}>\n                <Icon size={24} />\n              </Box>\n            )}\n            <OverflowText\n              display={{ _: 'none', sm: 'inline-block' }}\n              maxWidth={{ _: '110px', md: 'none' }}\n            >\n              {text}\n            </OverflowText>\n          </FlexBox>\n          <Box display={{ _: 'none', sm: 'block' }}>\n            <StyledArrowChevronRightIcon isActive={isActiveTab} />\n          </Box>\n          {showPopularBadge && (\n            <Box display={{ _: 'none', sm: 'block' }}>\n              <PopularBadge variant=\"custom\" size=\"sm\" bg=\"hyper-400\">\n                Popular\n              </PopularBadge>\n            </Box>\n          )}\n        </NavigationButton>\n      </Box>\n      {/* nav button with icon, xs only */}\n      {Icon && (\n        <NavIconButtonContainer\n          isActive={isActiveTab}\n          display={{ _: 'none', xs: 'grid', sm: 'none' }}\n          index={gridRow}\n        >\n          <NavIconButton\n            onClick={onSelect}\n            icon={Icon}\n            tip={highlightLiveLearning ? 'Live learning (popular)' : text}\n            tipProps={{\n              alignment: 'right-center',\n              narrow: false,\n              placement: 'floating',\n            }}\n            aria-label={\n              highlightLiveLearning ? 'Live learning (popular)' : text\n            }\n          />\n          {showPopularBadge && (\n            <PopularBadgeDot position=\"absolute\" left=\"42px\" aria-hidden />\n          )}\n        </NavIconButtonContainer>\n      )}\n\n      <NavPanelContainer\n        isFirst={index === 0}\n        display={isActiveTab ? 'block' : 'none'}\n        gridColumn=\"2 / span 12\"\n        gridRow=\"1 / span 8\"\n        bg=\"background\"\n        px={32}\n        pt={16}\n        pb={24}\n      >\n        <motion.div\n          animate={{ opacity: isActiveTab ? 1 : 0 }}\n          transition={{ duration: 0.4, ease: 'easeInOut' }}\n        >\n          {children}\n        </motion.div>\n      </NavPanelContainer>\n    </>\n  );\n};\n\nexport default NavSection;\n"]} */"));
67
+ const PopularBadgeDot = /*#__PURE__*/_styled(Box, {
68
+ target: "ed97qwe0",
69
+ label: "PopularBadgeDot"
70
+ })("background-color:", ({
71
+ theme
72
+ }) => theme.colors['hyper-400'], ";border-radius:8px;height:16px;width:16px;border:2px solid ", ({
73
+ theme
74
+ }) => theme.colors['gray-100'], ";" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../../../src/AppHeader/AppHeaderElements/AppHeaderSection/NavSection.tsx"],"names":[],"mappings":"AAiGmC","file":"../../../../src/AppHeader/AppHeaderElements/AppHeaderSection/NavSection.tsx","sourcesContent":["import { Box, FlexBox, Text } from '@codecademy/gamut';\nimport { ArrowChevronRightIcon, GamutIconProps } from '@codecademy/gamut-icons';\nimport styled from '@emotion/styled';\nimport { motion } from 'framer-motion';\nimport React, {\n  PropsWithChildren,\n  useCallback,\n  useContext,\n  useEffect,\n  useRef,\n} from 'react';\n\nimport {\n  useGlobalHeaderItemClick,\n  useHighlightLiveLearningContext,\n} from '../../../GlobalHeader/context';\nimport {\n  AppHeaderCatalogDropdownItem,\n  AppHeaderResourcesDropdownItem,\n} from '../../shared';\nimport { AppHeaderDropdownContext } from '../AppHeaderDropdownProvider';\nimport { PopularBadge } from './elements';\nimport { NavIconButton } from './MobileBackButton';\n\ntype NavSectionProps = PropsWithChildren & {\n  item: AppHeaderCatalogDropdownItem | AppHeaderResourcesDropdownItem;\n  isActiveTab: boolean;\n  setActiveTab: (tab: number) => void;\n  icon?: React.ComponentType<GamutIconProps>;\n  text: string;\n  index: number;\n  tabIndex?: number;\n};\n\nconst NavPanelContainer = styled(Box)<{ isFirst: boolean }>`\n  border-radius: ${({ isFirst }) => (isFirst ? '0 8px 8px 8px' : '8px')};\n\n  @media (max-width: 1200px) {\n    border-radius: 8px;\n  }\n`;\n\nexport const NavigationButton = styled.button<{\n  isActive: boolean;\n  index: number;\n}>`\n  grid-column: 1;\n  grid-row: ${({ index }) => index + 1};\n  padding: 16px;\n  border: none;\n  border-radius: ${({ isActive }) => (isActive ? '8px 0 0 8px' : '8px')};\n  background: none;\n  cursor: pointer;\n  color: ${({ theme, isActive }) =>\n    isActive ? theme.colors.primary : theme.colors.text};\n  text-align: left;\n  width: ${({ isActive }) => (isActive ? '100%' : 'calc(100% - 8px)')};\n  height: 60px;\n  display: flex;\n  justify-content: space-between;\n  align-items: center;\n  background-color: ${({ isActive, theme }) =>\n    isActive ? theme.colors.background : theme.colors['gray-100']};\n\n  &:hover,\n  &:focus {\n    background-color: ${({ theme, isActive }) =>\n      isActive ? theme.colors.background : theme.colors['navy-100']};\n    color: ${({ theme }) => theme.colors.primary};\n  }\n`;\n\nconst OverflowText = styled(Text)`\n  text-overflow: ellipsis;\n  overflow: hidden;\n  white-space: nowrap;\n`;\n\nconst StyledArrowChevronRightIcon = styled(ArrowChevronRightIcon)<{\n  isActive: boolean;\n}>`\n  display: ${({ isActive }) => (isActive ? 'block' : 'none')};\n`;\n\nconst NavIconButtonContainer = styled(Box)<{\n  isActive: boolean;\n  index: number;\n}>`\n  background-color: ${({ theme, isActive }) =>\n    isActive ? theme.colors.background : theme.colors['gray-100']};\n  border-radius: ${({ isActive }) => (isActive ? '8px 0 0 8px' : '8px')};\n\n  grid-column: 1;\n  grid-row: ${({ index }) => index};\n  padding: 8px;\n`;\n\nconst PopularBadgeDot = styled(Box)`\n  background-color: ${({ theme }) => theme.colors['hyper-400']};\n  border-radius: 8px;\n  height: 16px;\n  width: 16px;\n  border: 2px solid ${({ theme }) => theme.colors['gray-100']};\n`;\n\nconst NavSection = ({\n  isActiveTab,\n  setActiveTab,\n  icon: Icon,\n  text,\n  index,\n  children,\n  item,\n  tabIndex,\n}: NavSectionProps) => {\n  const { globalHeaderItemClick } = useGlobalHeaderItemClick();\n  const displayHighlightLiveLearning = useHighlightLiveLearningContext();\n  const { setFirstItemRef } = useContext(AppHeaderDropdownContext);\n  const gridRow = index + 2; // +1 because of the back button\n  const buttonRef = useRef<HTMLButtonElement>(null);\n\n  useEffect(() => {\n    if (index === 0 && buttonRef.current) {\n      setFirstItemRef?.(buttonRef.current);\n    }\n  }, [index, setFirstItemRef]);\n\n  const onSelect = useCallback(\n    (e: React.MouseEvent) => {\n      globalHeaderItemClick(e, item);\n      setActiveTab(index);\n    },\n    [globalHeaderItemClick, item, index, setActiveTab]\n  );\n\n  const highlightLiveLearning =\n    item.id === 'live-learning' && displayHighlightLiveLearning;\n  const showPopularBadge = highlightLiveLearning && !isActiveTab;\n\n  return (\n    <>\n      <Box display={{ _: 'none', sm: 'grid' }}>\n        {/* nav button with text, sm and above */}\n        <NavigationButton\n          ref={buttonRef}\n          isActive={isActiveTab}\n          index={gridRow}\n          onClick={onSelect}\n          data-testid={`nav-section-${item.id}`}\n          aria-expanded={isActiveTab}\n          tabIndex={tabIndex}\n          aria-label={text}\n        >\n          <FlexBox gap={8} alignItems=\"center\">\n            {Icon && (\n              <Box height={24} width={24}>\n                <Icon size={24} />\n              </Box>\n            )}\n            <OverflowText\n              display={{ _: 'none', sm: 'inline-block' }}\n              maxWidth={{ _: '110px', md: 'none' }}\n            >\n              {text}\n            </OverflowText>\n          </FlexBox>\n          <Box display={{ _: 'none', sm: 'block' }}>\n            <StyledArrowChevronRightIcon isActive={isActiveTab} />\n          </Box>\n          {showPopularBadge && (\n            <Box display={{ _: 'none', sm: 'block' }}>\n              <PopularBadge variant=\"custom\" size=\"sm\" bg=\"hyper-400\">\n                Popular\n              </PopularBadge>\n            </Box>\n          )}\n        </NavigationButton>\n      </Box>\n      {/* nav button with icon, xs only */}\n      {Icon && (\n        <NavIconButtonContainer\n          isActive={isActiveTab}\n          display={{ _: 'none', xs: 'grid', sm: 'none' }}\n          index={gridRow}\n        >\n          <NavIconButton\n            onClick={onSelect}\n            icon={Icon}\n            tip={highlightLiveLearning ? 'Live learning (popular)' : text}\n            tipProps={{\n              alignment: 'right-center',\n              narrow: false,\n              placement: 'floating',\n            }}\n            aria-label={\n              highlightLiveLearning ? 'Live learning (popular)' : text\n            }\n          />\n          {showPopularBadge && (\n            <PopularBadgeDot position=\"absolute\" left=\"42px\" aria-hidden />\n          )}\n        </NavIconButtonContainer>\n      )}\n\n      <NavPanelContainer\n        isFirst={index === 0}\n        display={isActiveTab ? 'block' : 'none'}\n        gridColumn=\"2 / span 12\"\n        gridRow=\"1 / span 8\"\n        bg=\"background\"\n        px={32}\n        pt={16}\n        pb={24}\n      >\n        <motion.div\n          animate={{ opacity: isActiveTab ? 1 : 0 }}\n          transition={{ duration: 0.4, ease: 'easeInOut' }}\n        >\n          {children}\n        </motion.div>\n      </NavPanelContainer>\n    </>\n  );\n};\n\nexport default NavSection;\n"]} */"));
75
+ const NavSection = ({
76
+ isActiveTab,
77
+ setActiveTab,
78
+ icon: Icon,
79
+ text,
80
+ index,
81
+ children,
82
+ item,
83
+ tabIndex
84
+ }) => {
85
+ const {
86
+ globalHeaderItemClick
87
+ } = useGlobalHeaderItemClick();
88
+ const displayHighlightLiveLearning = useHighlightLiveLearningContext();
89
+ const {
90
+ setFirstItemRef
91
+ } = useContext(AppHeaderDropdownContext);
92
+ const gridRow = index + 2; // +1 because of the back button
93
+ const buttonRef = useRef(null);
94
+ useEffect(() => {
95
+ if (index === 0 && buttonRef.current) {
96
+ setFirstItemRef?.(buttonRef.current);
97
+ }
98
+ }, [index, setFirstItemRef]);
99
+ const onSelect = useCallback(e => {
100
+ globalHeaderItemClick(e, item);
101
+ setActiveTab(index);
102
+ }, [globalHeaderItemClick, item, index, setActiveTab]);
103
+ const highlightLiveLearning = item.id === 'live-learning' && displayHighlightLiveLearning;
104
+ const showPopularBadge = highlightLiveLearning && !isActiveTab;
105
+ return /*#__PURE__*/_jsxs(_Fragment, {
106
+ children: [/*#__PURE__*/_jsx(Box, {
107
+ display: {
108
+ _: 'none',
109
+ sm: 'grid'
110
+ },
111
+ children: /*#__PURE__*/_jsxs(NavigationButton, {
112
+ ref: buttonRef,
113
+ isActive: isActiveTab,
114
+ index: gridRow,
115
+ onClick: onSelect,
116
+ "data-testid": `nav-section-${item.id}`,
117
+ "aria-expanded": isActiveTab,
118
+ tabIndex: tabIndex,
119
+ "aria-label": text,
120
+ children: [/*#__PURE__*/_jsxs(FlexBox, {
121
+ gap: 8,
122
+ alignItems: "center",
123
+ children: [Icon && /*#__PURE__*/_jsx(Box, {
124
+ height: 24,
125
+ width: 24,
126
+ children: /*#__PURE__*/_jsx(Icon, {
127
+ size: 24
128
+ })
129
+ }), /*#__PURE__*/_jsx(OverflowText, {
130
+ display: {
131
+ _: 'none',
132
+ sm: 'inline-block'
133
+ },
134
+ maxWidth: {
135
+ _: '110px',
136
+ md: 'none'
137
+ },
138
+ children: text
139
+ })]
140
+ }), /*#__PURE__*/_jsx(Box, {
141
+ display: {
142
+ _: 'none',
143
+ sm: 'block'
144
+ },
145
+ children: /*#__PURE__*/_jsx(StyledArrowChevronRightIcon, {
146
+ isActive: isActiveTab
147
+ })
148
+ }), showPopularBadge && /*#__PURE__*/_jsx(Box, {
149
+ display: {
150
+ _: 'none',
151
+ sm: 'block'
152
+ },
153
+ children: /*#__PURE__*/_jsx(PopularBadge, {
154
+ variant: "custom",
155
+ size: "sm",
156
+ bg: "hyper-400",
157
+ children: "Popular"
158
+ })
159
+ })]
160
+ })
161
+ }), Icon && /*#__PURE__*/_jsxs(NavIconButtonContainer, {
162
+ isActive: isActiveTab,
163
+ display: {
164
+ _: 'none',
165
+ xs: 'grid',
166
+ sm: 'none'
167
+ },
168
+ index: gridRow,
169
+ children: [/*#__PURE__*/_jsx(NavIconButton, {
170
+ onClick: onSelect,
171
+ icon: Icon,
172
+ tip: highlightLiveLearning ? 'Live learning (popular)' : text,
173
+ tipProps: {
174
+ alignment: 'right-center',
175
+ narrow: false,
176
+ placement: 'floating'
177
+ },
178
+ "aria-label": highlightLiveLearning ? 'Live learning (popular)' : text
179
+ }), showPopularBadge && /*#__PURE__*/_jsx(PopularBadgeDot, {
180
+ position: "absolute",
181
+ left: "42px",
182
+ "aria-hidden": true
183
+ })]
184
+ }), /*#__PURE__*/_jsx(NavPanelContainer, {
185
+ isFirst: index === 0,
186
+ display: isActiveTab ? 'block' : 'none',
187
+ gridColumn: "2 / span 12",
188
+ gridRow: "1 / span 8",
189
+ bg: "background",
190
+ px: 32,
191
+ pt: 16,
192
+ pb: 24,
193
+ children: /*#__PURE__*/_jsx(motion.div, {
194
+ animate: {
195
+ opacity: isActiveTab ? 1 : 0
196
+ },
197
+ transition: {
198
+ duration: 0.4,
199
+ ease: 'easeInOut'
200
+ },
201
+ children: children
202
+ })
203
+ })]
204
+ });
205
+ };
206
+ export default NavSection;
@@ -4,6 +4,7 @@ type PanelLayoutProps = PropsWithChildren & {
4
4
  heading: string;
5
5
  description: ReactNode;
6
6
  linkItem?: AppHeaderLinkItem;
7
+ showPopularBadge?: boolean;
7
8
  };
8
- export declare const PanelLayout: ({ heading, description, linkItem, children, }: PanelLayoutProps) => import("react/jsx-runtime").JSX.Element;
9
+ export declare const PanelLayout: ({ heading, description, linkItem, showPopularBadge, children, }: PanelLayoutProps) => import("react/jsx-runtime").JSX.Element;
9
10
  export {};
@@ -3,11 +3,13 @@ import { ArrowLeftIcon, MiniArrowRightIcon } from '@codecademy/gamut-icons';
3
3
  import { useGlobalHeaderItemClick } from '../../../GlobalHeader/context';
4
4
  import { useAppHeaderDropdownContext } from '../AppHeaderDropdownProvider';
5
5
  import { useAppHeaderSectionContext } from './AppHeaderSectionContext';
6
+ import { PopularBadge } from './elements';
6
7
  import { jsx as _jsx, jsxs as _jsxs } from "react/jsx-runtime";
7
8
  export const PanelLayout = ({
8
9
  heading,
9
10
  description,
10
11
  linkItem,
12
+ showPopularBadge,
11
13
  children
12
14
  }) => {
13
15
  const {
@@ -55,6 +57,12 @@ export const PanelLayout = ({
55
57
  as: "h2",
56
58
  variant: "title-sm",
57
59
  children: heading
60
+ }), showPopularBadge && /*#__PURE__*/_jsx(PopularBadge, {
61
+ variant: "custom",
62
+ size: "base",
63
+ bg: "hyper-400",
64
+ ml: 16,
65
+ children: "Popular"
58
66
  })]
59
67
  }), /*#__PURE__*/_jsx(Text, {
60
68
  mb: 16,
@@ -6,7 +6,7 @@ export declare const StyledSection: import("@emotion/styled").StyledComponent<{
6
6
  } & {
7
7
  activePanelSelected: boolean;
8
8
  }, {}, {}>;
9
- export declare const NavTabContainer: import("@emotion/styled").StyledComponent<{
9
+ export declare const StyledGridBox: import("@emotion/styled").StyledComponent<{
10
10
  theme?: import("@emotion/react").Theme | undefined;
11
11
  as?: import("react").ElementType<any, keyof import("react").JSX.IntrinsicElements> | undefined;
12
12
  } & import("@codecademy/gamut/dist/Box/props").GridBoxProps & Pick<import("react").DetailedHTMLProps<import("react").HTMLAttributes<HTMLDivElement>, HTMLDivElement>, "content" | "translate" | "property" | "hidden" | "slot" | "style" | "title" | "suppressHydrationWarning" | "className" | "id" | "lang" | "role" | "tabIndex" | "aria-activedescendant" | "aria-atomic" | "aria-autocomplete" | "aria-braillelabel" | "aria-brailleroledescription" | "aria-busy" | "aria-checked" | "aria-colcount" | "aria-colindex" | "aria-colindextext" | "aria-colspan" | "aria-controls" | "aria-current" | "aria-describedby" | "aria-description" | "aria-details" | "aria-disabled" | "aria-dropeffect" | "aria-errormessage" | "aria-expanded" | "aria-flowto" | "aria-grabbed" | "aria-haspopup" | "aria-hidden" | "aria-invalid" | "aria-keyshortcuts" | "aria-label" | "aria-labelledby" | "aria-level" | "aria-live" | "aria-modal" | "aria-multiline" | "aria-multiselectable" | "aria-orientation" | "aria-owns" | "aria-placeholder" | "aria-posinset" | "aria-pressed" | "aria-readonly" | "aria-relevant" | "aria-required" | "aria-roledescription" | "aria-rowcount" | "aria-rowindex" | "aria-rowindextext" | "aria-rowspan" | "aria-selected" | "aria-setsize" | "aria-sort" | "aria-valuemax" | "aria-valuemin" | "aria-valuenow" | "aria-valuetext" | "children" | "dangerouslySetInnerHTML" | "onCopy" | "onCopyCapture" | "onCut" | "onCutCapture" | "onPaste" | "onPasteCapture" | "onCompositionEnd" | "onCompositionEndCapture" | "onCompositionStart" | "onCompositionStartCapture" | "onCompositionUpdate" | "onCompositionUpdateCapture" | "onFocus" | "onFocusCapture" | "onBlur" | "onBlurCapture" | "onChange" | "onChangeCapture" | "onBeforeInput" | "onBeforeInputCapture" | "onInput" | "onInputCapture" | "onReset" | "onResetCapture" | "onSubmit" | "onSubmitCapture" | "onInvalid" | "onInvalidCapture" | "onLoad" | "onLoadCapture" | "onError" | "onErrorCapture" | "onKeyDown" | "onKeyDownCapture" | "onKeyPress" | "onKeyPressCapture" | "onKeyUp" | "onKeyUpCapture" | "onAbort" | "onAbortCapture" | "onCanPlay" | "onCanPlayCapture" | "onCanPlayThrough" | "onCanPlayThroughCapture" | "onDurationChange" | "onDurationChangeCapture" | "onEmptied" | "onEmptiedCapture" | "onEncrypted" | "onEncryptedCapture" | "onEnded" | "onEndedCapture" | "onLoadedData" | "onLoadedDataCapture" | "onLoadedMetadata" | "onLoadedMetadataCapture" | "onLoadStart" | "onLoadStartCapture" | "onPause" | "onPauseCapture" | "onPlay" | "onPlayCapture" | "onPlaying" | "onPlayingCapture" | "onProgress" | "onProgressCapture" | "onRateChange" | "onRateChangeCapture" | "onResize" | "onResizeCapture" | "onSeeked" | "onSeekedCapture" | "onSeeking" | "onSeekingCapture" | "onStalled" | "onStalledCapture" | "onSuspend" | "onSuspendCapture" | "onTimeUpdate" | "onTimeUpdateCapture" | "onVolumeChange" | "onVolumeChangeCapture" | "onWaiting" | "onWaitingCapture" | "onAuxClick" | "onAuxClickCapture" | "onClick" | "onClickCapture" | "onContextMenu" | "onContextMenuCapture" | "onDoubleClick" | "onDoubleClickCapture" | "onDrag" | "onDragCapture" | "onDragEnd" | "onDragEndCapture" | "onDragEnter" | "onDragEnterCapture" | "onDragExit" | "onDragExitCapture" | "onDragLeave" | "onDragLeaveCapture" | "onDragOver" | "onDragOverCapture" | "onDragStart" | "onDragStartCapture" | "onDrop" | "onDropCapture" | "onMouseDown" | "onMouseDownCapture" | "onMouseEnter" | "onMouseLeave" | "onMouseMove" | "onMouseMoveCapture" | "onMouseOut" | "onMouseOutCapture" | "onMouseOver" | "onMouseOverCapture" | "onMouseUp" | "onMouseUpCapture" | "onSelect" | "onSelectCapture" | "onTouchCancel" | "onTouchCancelCapture" | "onTouchEnd" | "onTouchEndCapture" | "onTouchMove" | "onTouchMoveCapture" | "onTouchStart" | "onTouchStartCapture" | "onPointerDown" | "onPointerDownCapture" | "onPointerMove" | "onPointerMoveCapture" | "onPointerUp" | "onPointerUpCapture" | "onPointerCancel" | "onPointerCancelCapture" | "onPointerEnter" | "onPointerLeave" | "onPointerOver" | "onPointerOverCapture" | "onPointerOut" | "onPointerOutCapture" | "onGotPointerCapture" | "onGotPointerCaptureCapture" | "onLostPointerCapture" | "onLostPointerCaptureCapture" | "onScroll" | "onScrollCapture" | "onWheel" | "onWheelCapture" | "onAnimationStart" | "onAnimationStartCapture" | "onAnimationEnd" | "onAnimationEndCapture" | "onAnimationIteration" | "onAnimationIterationCapture" | "onTransitionEnd" | "onTransitionEndCapture" | "defaultChecked" | "defaultValue" | "suppressContentEditableWarning" | "accessKey" | "autoFocus" | "contentEditable" | "contextMenu" | "dir" | "draggable" | "nonce" | "spellCheck" | "radioGroup" | "about" | "datatype" | "inlist" | "prefix" | "rel" | "resource" | "rev" | "typeof" | "vocab" | "autoCapitalize" | "autoCorrect" | "autoSave" | "itemProp" | "itemScope" | "itemType" | "itemID" | "itemRef" | "results" | "security" | "unselectable" | "inputMode" | "is" | keyof import("react").ClassAttributes<HTMLDivElement>> & {
@@ -24,59 +24,6 @@ export declare const SmallMenuButton: import("@emotion/styled").StyledComponent<
24
24
  } & {
25
25
  index: number;
26
26
  }, import("react").DetailedHTMLProps<import("react").ButtonHTMLAttributes<HTMLButtonElement>, HTMLButtonElement>, {}>;
27
- export declare const OverflowText: import("@emotion/styled").StyledComponent<((Omit<{
28
- theme?: import("@emotion/react").Theme | undefined;
29
- as?: import("react").ElementType<any, keyof import("react").JSX.IntrinsicElements> | undefined;
30
- } & import("@codecademy/gamut").TextTruncateProps & Pick<import("react").DetailedHTMLProps<import("react").HTMLAttributes<HTMLSpanElement>, HTMLSpanElement>, "content" | "translate" | "property" | "hidden" | "slot" | "style" | "title" | "suppressHydrationWarning" | "className" | "id" | "lang" | "role" | "tabIndex" | "aria-activedescendant" | "aria-atomic" | "aria-autocomplete" | "aria-braillelabel" | "aria-brailleroledescription" | "aria-busy" | "aria-checked" | "aria-colcount" | "aria-colindex" | "aria-colindextext" | "aria-colspan" | "aria-controls" | "aria-current" | "aria-describedby" | "aria-description" | "aria-details" | "aria-disabled" | "aria-dropeffect" | "aria-errormessage" | "aria-expanded" | "aria-flowto" | "aria-grabbed" | "aria-haspopup" | "aria-hidden" | "aria-invalid" | "aria-keyshortcuts" | "aria-label" | "aria-labelledby" | "aria-level" | "aria-live" | "aria-modal" | "aria-multiline" | "aria-multiselectable" | "aria-orientation" | "aria-owns" | "aria-placeholder" | "aria-posinset" | "aria-pressed" | "aria-readonly" | "aria-relevant" | "aria-required" | "aria-roledescription" | "aria-rowcount" | "aria-rowindex" | "aria-rowindextext" | "aria-rowspan" | "aria-selected" | "aria-setsize" | "aria-sort" | "aria-valuemax" | "aria-valuemin" | "aria-valuenow" | "aria-valuetext" | "children" | "dangerouslySetInnerHTML" | "onCopy" | "onCopyCapture" | "onCut" | "onCutCapture" | "onPaste" | "onPasteCapture" | "onCompositionEnd" | "onCompositionEndCapture" | "onCompositionStart" | "onCompositionStartCapture" | "onCompositionUpdate" | "onCompositionUpdateCapture" | "onFocus" | "onFocusCapture" | "onBlur" | "onBlurCapture" | "onChange" | "onChangeCapture" | "onBeforeInput" | "onBeforeInputCapture" | "onInput" | "onInputCapture" | "onReset" | "onResetCapture" | "onSubmit" | "onSubmitCapture" | "onInvalid" | "onInvalidCapture" | "onLoad" | "onLoadCapture" | "onError" | "onErrorCapture" | "onKeyDown" | "onKeyDownCapture" | "onKeyPress" | "onKeyPressCapture" | "onKeyUp" | "onKeyUpCapture" | "onAbort" | "onAbortCapture" | "onCanPlay" | "onCanPlayCapture" | "onCanPlayThrough" | "onCanPlayThroughCapture" | "onDurationChange" | "onDurationChangeCapture" | "onEmptied" | "onEmptiedCapture" | "onEncrypted" | "onEncryptedCapture" | "onEnded" | "onEndedCapture" | "onLoadedData" | "onLoadedDataCapture" | "onLoadedMetadata" | "onLoadedMetadataCapture" | "onLoadStart" | "onLoadStartCapture" | "onPause" | "onPauseCapture" | "onPlay" | "onPlayCapture" | "onPlaying" | "onPlayingCapture" | "onProgress" | "onProgressCapture" | "onRateChange" | "onRateChangeCapture" | "onResize" | "onResizeCapture" | "onSeeked" | "onSeekedCapture" | "onSeeking" | "onSeekingCapture" | "onStalled" | "onStalledCapture" | "onSuspend" | "onSuspendCapture" | "onTimeUpdate" | "onTimeUpdateCapture" | "onVolumeChange" | "onVolumeChangeCapture" | "onWaiting" | "onWaitingCapture" | "onAuxClick" | "onAuxClickCapture" | "onClick" | "onClickCapture" | "onContextMenu" | "onContextMenuCapture" | "onDoubleClick" | "onDoubleClickCapture" | "onDrag" | "onDragCapture" | "onDragEnd" | "onDragEndCapture" | "onDragEnter" | "onDragEnterCapture" | "onDragExit" | "onDragExitCapture" | "onDragLeave" | "onDragLeaveCapture" | "onDragOver" | "onDragOverCapture" | "onDragStart" | "onDragStartCapture" | "onDrop" | "onDropCapture" | "onMouseDown" | "onMouseDownCapture" | "onMouseEnter" | "onMouseLeave" | "onMouseMove" | "onMouseMoveCapture" | "onMouseOut" | "onMouseOutCapture" | "onMouseOver" | "onMouseOverCapture" | "onMouseUp" | "onMouseUpCapture" | "onSelect" | "onSelectCapture" | "onTouchCancel" | "onTouchCancelCapture" | "onTouchEnd" | "onTouchEndCapture" | "onTouchMove" | "onTouchMoveCapture" | "onTouchStart" | "onTouchStartCapture" | "onPointerDown" | "onPointerDownCapture" | "onPointerMove" | "onPointerMoveCapture" | "onPointerUp" | "onPointerUpCapture" | "onPointerCancel" | "onPointerCancelCapture" | "onPointerEnter" | "onPointerLeave" | "onPointerOver" | "onPointerOverCapture" | "onPointerOut" | "onPointerOutCapture" | "onGotPointerCapture" | "onGotPointerCaptureCapture" | "onLostPointerCapture" | "onLostPointerCaptureCapture" | "onScroll" | "onScrollCapture" | "onWheel" | "onWheelCapture" | "onAnimationStart" | "onAnimationStartCapture" | "onAnimationEnd" | "onAnimationEndCapture" | "onAnimationIteration" | "onAnimationIterationCapture" | "onTransitionEnd" | "onTransitionEndCapture" | "defaultChecked" | "defaultValue" | "suppressContentEditableWarning" | "accessKey" | "autoFocus" | "contentEditable" | "contextMenu" | "dir" | "draggable" | "nonce" | "spellCheck" | "radioGroup" | "about" | "datatype" | "inlist" | "prefix" | "rel" | "resource" | "rev" | "typeof" | "vocab" | "autoCapitalize" | "autoCorrect" | "autoSave" | "itemProp" | "itemScope" | "itemType" | "itemID" | "itemRef" | "results" | "security" | "unselectable" | "inputMode" | "is" | keyof import("react").ClassAttributes<HTMLSpanElement>>, "ref"> | Omit<{
31
- theme?: import("@emotion/react").Theme | undefined;
32
- as?: import("react").ElementType<any, keyof import("react").JSX.IntrinsicElements> | undefined;
33
- } & import("@codecademy/gamut").TextNoTruncateProps & Pick<import("react").DetailedHTMLProps<import("react").HTMLAttributes<HTMLSpanElement>, HTMLSpanElement>, "content" | "translate" | "property" | "hidden" | "slot" | "style" | "title" | "suppressHydrationWarning" | "className" | "id" | "lang" | "role" | "tabIndex" | "aria-activedescendant" | "aria-atomic" | "aria-autocomplete" | "aria-braillelabel" | "aria-brailleroledescription" | "aria-busy" | "aria-checked" | "aria-colcount" | "aria-colindex" | "aria-colindextext" | "aria-colspan" | "aria-controls" | "aria-current" | "aria-describedby" | "aria-description" | "aria-details" | "aria-disabled" | "aria-dropeffect" | "aria-errormessage" | "aria-expanded" | "aria-flowto" | "aria-grabbed" | "aria-haspopup" | "aria-hidden" | "aria-invalid" | "aria-keyshortcuts" | "aria-label" | "aria-labelledby" | "aria-level" | "aria-live" | "aria-modal" | "aria-multiline" | "aria-multiselectable" | "aria-orientation" | "aria-owns" | "aria-placeholder" | "aria-posinset" | "aria-pressed" | "aria-readonly" | "aria-relevant" | "aria-required" | "aria-roledescription" | "aria-rowcount" | "aria-rowindex" | "aria-rowindextext" | "aria-rowspan" | "aria-selected" | "aria-setsize" | "aria-sort" | "aria-valuemax" | "aria-valuemin" | "aria-valuenow" | "aria-valuetext" | "children" | "dangerouslySetInnerHTML" | "onCopy" | "onCopyCapture" | "onCut" | "onCutCapture" | "onPaste" | "onPasteCapture" | "onCompositionEnd" | "onCompositionEndCapture" | "onCompositionStart" | "onCompositionStartCapture" | "onCompositionUpdate" | "onCompositionUpdateCapture" | "onFocus" | "onFocusCapture" | "onBlur" | "onBlurCapture" | "onChange" | "onChangeCapture" | "onBeforeInput" | "onBeforeInputCapture" | "onInput" | "onInputCapture" | "onReset" | "onResetCapture" | "onSubmit" | "onSubmitCapture" | "onInvalid" | "onInvalidCapture" | "onLoad" | "onLoadCapture" | "onError" | "onErrorCapture" | "onKeyDown" | "onKeyDownCapture" | "onKeyPress" | "onKeyPressCapture" | "onKeyUp" | "onKeyUpCapture" | "onAbort" | "onAbortCapture" | "onCanPlay" | "onCanPlayCapture" | "onCanPlayThrough" | "onCanPlayThroughCapture" | "onDurationChange" | "onDurationChangeCapture" | "onEmptied" | "onEmptiedCapture" | "onEncrypted" | "onEncryptedCapture" | "onEnded" | "onEndedCapture" | "onLoadedData" | "onLoadedDataCapture" | "onLoadedMetadata" | "onLoadedMetadataCapture" | "onLoadStart" | "onLoadStartCapture" | "onPause" | "onPauseCapture" | "onPlay" | "onPlayCapture" | "onPlaying" | "onPlayingCapture" | "onProgress" | "onProgressCapture" | "onRateChange" | "onRateChangeCapture" | "onResize" | "onResizeCapture" | "onSeeked" | "onSeekedCapture" | "onSeeking" | "onSeekingCapture" | "onStalled" | "onStalledCapture" | "onSuspend" | "onSuspendCapture" | "onTimeUpdate" | "onTimeUpdateCapture" | "onVolumeChange" | "onVolumeChangeCapture" | "onWaiting" | "onWaitingCapture" | "onAuxClick" | "onAuxClickCapture" | "onClick" | "onClickCapture" | "onContextMenu" | "onContextMenuCapture" | "onDoubleClick" | "onDoubleClickCapture" | "onDrag" | "onDragCapture" | "onDragEnd" | "onDragEndCapture" | "onDragEnter" | "onDragEnterCapture" | "onDragExit" | "onDragExitCapture" | "onDragLeave" | "onDragLeaveCapture" | "onDragOver" | "onDragOverCapture" | "onDragStart" | "onDragStartCapture" | "onDrop" | "onDropCapture" | "onMouseDown" | "onMouseDownCapture" | "onMouseEnter" | "onMouseLeave" | "onMouseMove" | "onMouseMoveCapture" | "onMouseOut" | "onMouseOutCapture" | "onMouseOver" | "onMouseOverCapture" | "onMouseUp" | "onMouseUpCapture" | "onSelect" | "onSelectCapture" | "onTouchCancel" | "onTouchCancelCapture" | "onTouchEnd" | "onTouchEndCapture" | "onTouchMove" | "onTouchMoveCapture" | "onTouchStart" | "onTouchStartCapture" | "onPointerDown" | "onPointerDownCapture" | "onPointerMove" | "onPointerMoveCapture" | "onPointerUp" | "onPointerUpCapture" | "onPointerCancel" | "onPointerCancelCapture" | "onPointerEnter" | "onPointerLeave" | "onPointerOver" | "onPointerOverCapture" | "onPointerOut" | "onPointerOutCapture" | "onGotPointerCapture" | "onGotPointerCaptureCapture" | "onLostPointerCapture" | "onLostPointerCaptureCapture" | "onScroll" | "onScrollCapture" | "onWheel" | "onWheelCapture" | "onAnimationStart" | "onAnimationStartCapture" | "onAnimationEnd" | "onAnimationEndCapture" | "onAnimationIteration" | "onAnimationIterationCapture" | "onTransitionEnd" | "onTransitionEndCapture" | "defaultChecked" | "defaultValue" | "suppressContentEditableWarning" | "accessKey" | "autoFocus" | "contentEditable" | "contextMenu" | "dir" | "draggable" | "nonce" | "spellCheck" | "radioGroup" | "about" | "datatype" | "inlist" | "prefix" | "rel" | "resource" | "rev" | "typeof" | "vocab" | "autoCapitalize" | "autoCorrect" | "autoSave" | "itemProp" | "itemScope" | "itemType" | "itemID" | "itemRef" | "results" | "security" | "unselectable" | "inputMode" | "is" | keyof import("react").ClassAttributes<HTMLSpanElement>>, "ref">) & import("react").RefAttributes<HTMLSpanElement>) & {
34
- theme?: import("@emotion/react").Theme;
35
- }, {}, {}>;
36
- export declare const StyledNavTabPanel: import("@emotion/styled").StyledComponent<{
37
- theme?: import("@emotion/react").Theme | undefined;
38
- as?: import("react").ElementType<any, keyof import("react").JSX.IntrinsicElements> | undefined;
39
- } & import("@codecademy/gamut").BoxProps & Pick<import("react").DetailedHTMLProps<import("react").HTMLAttributes<HTMLDivElement>, HTMLDivElement>, "content" | "translate" | "property" | "hidden" | "slot" | "style" | "title" | "suppressHydrationWarning" | "className" | "id" | "lang" | "role" | "tabIndex" | "aria-activedescendant" | "aria-atomic" | "aria-autocomplete" | "aria-braillelabel" | "aria-brailleroledescription" | "aria-busy" | "aria-checked" | "aria-colcount" | "aria-colindex" | "aria-colindextext" | "aria-colspan" | "aria-controls" | "aria-current" | "aria-describedby" | "aria-description" | "aria-details" | "aria-disabled" | "aria-dropeffect" | "aria-errormessage" | "aria-expanded" | "aria-flowto" | "aria-grabbed" | "aria-haspopup" | "aria-hidden" | "aria-invalid" | "aria-keyshortcuts" | "aria-label" | "aria-labelledby" | "aria-level" | "aria-live" | "aria-modal" | "aria-multiline" | "aria-multiselectable" | "aria-orientation" | "aria-owns" | "aria-placeholder" | "aria-posinset" | "aria-pressed" | "aria-readonly" | "aria-relevant" | "aria-required" | "aria-roledescription" | "aria-rowcount" | "aria-rowindex" | "aria-rowindextext" | "aria-rowspan" | "aria-selected" | "aria-setsize" | "aria-sort" | "aria-valuemax" | "aria-valuemin" | "aria-valuenow" | "aria-valuetext" | "children" | "dangerouslySetInnerHTML" | "onCopy" | "onCopyCapture" | "onCut" | "onCutCapture" | "onPaste" | "onPasteCapture" | "onCompositionEnd" | "onCompositionEndCapture" | "onCompositionStart" | "onCompositionStartCapture" | "onCompositionUpdate" | "onCompositionUpdateCapture" | "onFocus" | "onFocusCapture" | "onBlur" | "onBlurCapture" | "onChange" | "onChangeCapture" | "onBeforeInput" | "onBeforeInputCapture" | "onInput" | "onInputCapture" | "onReset" | "onResetCapture" | "onSubmit" | "onSubmitCapture" | "onInvalid" | "onInvalidCapture" | "onLoad" | "onLoadCapture" | "onError" | "onErrorCapture" | "onKeyDown" | "onKeyDownCapture" | "onKeyPress" | "onKeyPressCapture" | "onKeyUp" | "onKeyUpCapture" | "onAbort" | "onAbortCapture" | "onCanPlay" | "onCanPlayCapture" | "onCanPlayThrough" | "onCanPlayThroughCapture" | "onDurationChange" | "onDurationChangeCapture" | "onEmptied" | "onEmptiedCapture" | "onEncrypted" | "onEncryptedCapture" | "onEnded" | "onEndedCapture" | "onLoadedData" | "onLoadedDataCapture" | "onLoadedMetadata" | "onLoadedMetadataCapture" | "onLoadStart" | "onLoadStartCapture" | "onPause" | "onPauseCapture" | "onPlay" | "onPlayCapture" | "onPlaying" | "onPlayingCapture" | "onProgress" | "onProgressCapture" | "onRateChange" | "onRateChangeCapture" | "onResize" | "onResizeCapture" | "onSeeked" | "onSeekedCapture" | "onSeeking" | "onSeekingCapture" | "onStalled" | "onStalledCapture" | "onSuspend" | "onSuspendCapture" | "onTimeUpdate" | "onTimeUpdateCapture" | "onVolumeChange" | "onVolumeChangeCapture" | "onWaiting" | "onWaitingCapture" | "onAuxClick" | "onAuxClickCapture" | "onClick" | "onClickCapture" | "onContextMenu" | "onContextMenuCapture" | "onDoubleClick" | "onDoubleClickCapture" | "onDrag" | "onDragCapture" | "onDragEnd" | "onDragEndCapture" | "onDragEnter" | "onDragEnterCapture" | "onDragExit" | "onDragExitCapture" | "onDragLeave" | "onDragLeaveCapture" | "onDragOver" | "onDragOverCapture" | "onDragStart" | "onDragStartCapture" | "onDrop" | "onDropCapture" | "onMouseDown" | "onMouseDownCapture" | "onMouseEnter" | "onMouseLeave" | "onMouseMove" | "onMouseMoveCapture" | "onMouseOut" | "onMouseOutCapture" | "onMouseOver" | "onMouseOverCapture" | "onMouseUp" | "onMouseUpCapture" | "onSelect" | "onSelectCapture" | "onTouchCancel" | "onTouchCancelCapture" | "onTouchEnd" | "onTouchEndCapture" | "onTouchMove" | "onTouchMoveCapture" | "onTouchStart" | "onTouchStartCapture" | "onPointerDown" | "onPointerDownCapture" | "onPointerMove" | "onPointerMoveCapture" | "onPointerUp" | "onPointerUpCapture" | "onPointerCancel" | "onPointerCancelCapture" | "onPointerEnter" | "onPointerLeave" | "onPointerOver" | "onPointerOverCapture" | "onPointerOut" | "onPointerOutCapture" | "onGotPointerCapture" | "onGotPointerCaptureCapture" | "onLostPointerCapture" | "onLostPointerCaptureCapture" | "onScroll" | "onScrollCapture" | "onWheel" | "onWheelCapture" | "onAnimationStart" | "onAnimationStartCapture" | "onAnimationEnd" | "onAnimationEndCapture" | "onAnimationIteration" | "onAnimationIterationCapture" | "onTransitionEnd" | "onTransitionEndCapture" | "defaultChecked" | "defaultValue" | "suppressContentEditableWarning" | "accessKey" | "autoFocus" | "contentEditable" | "contextMenu" | "dir" | "draggable" | "nonce" | "spellCheck" | "radioGroup" | "about" | "datatype" | "inlist" | "prefix" | "rel" | "resource" | "rev" | "typeof" | "vocab" | "autoCapitalize" | "autoCorrect" | "autoSave" | "itemProp" | "itemScope" | "itemType" | "itemID" | "itemRef" | "results" | "security" | "unselectable" | "inputMode" | "is" | keyof import("react").ClassAttributes<HTMLDivElement>> & {
40
- theme?: import("@emotion/react").Theme;
41
- } & {
42
- isFirst: boolean;
43
- }, {}, {}>;
44
- export declare const NavigationButton: import("@emotion/styled").StyledComponent<{
45
- theme?: import("@emotion/react").Theme;
46
- as?: React.ElementType;
47
- } & {
48
- isActive: boolean;
49
- }, import("react").DetailedHTMLProps<import("react").ButtonHTMLAttributes<HTMLButtonElement>, HTMLButtonElement>, {}>;
50
- export declare const NavIconButtonContainer: import("@emotion/styled").StyledComponent<{
51
- theme?: import("@emotion/react").Theme | undefined;
52
- as?: import("react").ElementType<any, keyof import("react").JSX.IntrinsicElements> | undefined;
53
- } & import("@codecademy/gamut").BoxProps & Pick<import("react").DetailedHTMLProps<import("react").HTMLAttributes<HTMLDivElement>, HTMLDivElement>, "content" | "translate" | "property" | "hidden" | "slot" | "style" | "title" | "suppressHydrationWarning" | "className" | "id" | "lang" | "role" | "tabIndex" | "aria-activedescendant" | "aria-atomic" | "aria-autocomplete" | "aria-braillelabel" | "aria-brailleroledescription" | "aria-busy" | "aria-checked" | "aria-colcount" | "aria-colindex" | "aria-colindextext" | "aria-colspan" | "aria-controls" | "aria-current" | "aria-describedby" | "aria-description" | "aria-details" | "aria-disabled" | "aria-dropeffect" | "aria-errormessage" | "aria-expanded" | "aria-flowto" | "aria-grabbed" | "aria-haspopup" | "aria-hidden" | "aria-invalid" | "aria-keyshortcuts" | "aria-label" | "aria-labelledby" | "aria-level" | "aria-live" | "aria-modal" | "aria-multiline" | "aria-multiselectable" | "aria-orientation" | "aria-owns" | "aria-placeholder" | "aria-posinset" | "aria-pressed" | "aria-readonly" | "aria-relevant" | "aria-required" | "aria-roledescription" | "aria-rowcount" | "aria-rowindex" | "aria-rowindextext" | "aria-rowspan" | "aria-selected" | "aria-setsize" | "aria-sort" | "aria-valuemax" | "aria-valuemin" | "aria-valuenow" | "aria-valuetext" | "children" | "dangerouslySetInnerHTML" | "onCopy" | "onCopyCapture" | "onCut" | "onCutCapture" | "onPaste" | "onPasteCapture" | "onCompositionEnd" | "onCompositionEndCapture" | "onCompositionStart" | "onCompositionStartCapture" | "onCompositionUpdate" | "onCompositionUpdateCapture" | "onFocus" | "onFocusCapture" | "onBlur" | "onBlurCapture" | "onChange" | "onChangeCapture" | "onBeforeInput" | "onBeforeInputCapture" | "onInput" | "onInputCapture" | "onReset" | "onResetCapture" | "onSubmit" | "onSubmitCapture" | "onInvalid" | "onInvalidCapture" | "onLoad" | "onLoadCapture" | "onError" | "onErrorCapture" | "onKeyDown" | "onKeyDownCapture" | "onKeyPress" | "onKeyPressCapture" | "onKeyUp" | "onKeyUpCapture" | "onAbort" | "onAbortCapture" | "onCanPlay" | "onCanPlayCapture" | "onCanPlayThrough" | "onCanPlayThroughCapture" | "onDurationChange" | "onDurationChangeCapture" | "onEmptied" | "onEmptiedCapture" | "onEncrypted" | "onEncryptedCapture" | "onEnded" | "onEndedCapture" | "onLoadedData" | "onLoadedDataCapture" | "onLoadedMetadata" | "onLoadedMetadataCapture" | "onLoadStart" | "onLoadStartCapture" | "onPause" | "onPauseCapture" | "onPlay" | "onPlayCapture" | "onPlaying" | "onPlayingCapture" | "onProgress" | "onProgressCapture" | "onRateChange" | "onRateChangeCapture" | "onResize" | "onResizeCapture" | "onSeeked" | "onSeekedCapture" | "onSeeking" | "onSeekingCapture" | "onStalled" | "onStalledCapture" | "onSuspend" | "onSuspendCapture" | "onTimeUpdate" | "onTimeUpdateCapture" | "onVolumeChange" | "onVolumeChangeCapture" | "onWaiting" | "onWaitingCapture" | "onAuxClick" | "onAuxClickCapture" | "onClick" | "onClickCapture" | "onContextMenu" | "onContextMenuCapture" | "onDoubleClick" | "onDoubleClickCapture" | "onDrag" | "onDragCapture" | "onDragEnd" | "onDragEndCapture" | "onDragEnter" | "onDragEnterCapture" | "onDragExit" | "onDragExitCapture" | "onDragLeave" | "onDragLeaveCapture" | "onDragOver" | "onDragOverCapture" | "onDragStart" | "onDragStartCapture" | "onDrop" | "onDropCapture" | "onMouseDown" | "onMouseDownCapture" | "onMouseEnter" | "onMouseLeave" | "onMouseMove" | "onMouseMoveCapture" | "onMouseOut" | "onMouseOutCapture" | "onMouseOver" | "onMouseOverCapture" | "onMouseUp" | "onMouseUpCapture" | "onSelect" | "onSelectCapture" | "onTouchCancel" | "onTouchCancelCapture" | "onTouchEnd" | "onTouchEndCapture" | "onTouchMove" | "onTouchMoveCapture" | "onTouchStart" | "onTouchStartCapture" | "onPointerDown" | "onPointerDownCapture" | "onPointerMove" | "onPointerMoveCapture" | "onPointerUp" | "onPointerUpCapture" | "onPointerCancel" | "onPointerCancelCapture" | "onPointerEnter" | "onPointerLeave" | "onPointerOver" | "onPointerOverCapture" | "onPointerOut" | "onPointerOutCapture" | "onGotPointerCapture" | "onGotPointerCaptureCapture" | "onLostPointerCapture" | "onLostPointerCaptureCapture" | "onScroll" | "onScrollCapture" | "onWheel" | "onWheelCapture" | "onAnimationStart" | "onAnimationStartCapture" | "onAnimationEnd" | "onAnimationEndCapture" | "onAnimationIteration" | "onAnimationIterationCapture" | "onTransitionEnd" | "onTransitionEndCapture" | "defaultChecked" | "defaultValue" | "suppressContentEditableWarning" | "accessKey" | "autoFocus" | "contentEditable" | "contextMenu" | "dir" | "draggable" | "nonce" | "spellCheck" | "radioGroup" | "about" | "datatype" | "inlist" | "prefix" | "rel" | "resource" | "rev" | "typeof" | "vocab" | "autoCapitalize" | "autoCorrect" | "autoSave" | "itemProp" | "itemScope" | "itemType" | "itemID" | "itemRef" | "results" | "security" | "unselectable" | "inputMode" | "is" | keyof import("react").ClassAttributes<HTMLDivElement>> & {
54
- theme?: import("@emotion/react").Theme;
55
- } & {
56
- isActive: boolean;
57
- }, {}, {}>;
58
- export declare const NavIconButton: import("@emotion/styled").StyledComponent<((Omit<Omit<{
59
- theme?: import("@emotion/react").Theme | undefined;
60
- as?: import("react").ElementType<any, keyof import("react").JSX.IntrinsicElements> | undefined;
61
- } & {
62
- theme?: import("@emotion/react").Theme | undefined;
63
- } & Pick<import("react").DetailedHTMLProps<import("react").ButtonHTMLAttributes<HTMLButtonElement>, HTMLButtonElement>, "disabled" | "content" | "translate" | "property" | "hidden" | "form" | "slot" | "style" | "title" | "suppressHydrationWarning" | "className" | "id" | "lang" | "name" | "type" | "role" | "tabIndex" | "aria-activedescendant" | "aria-atomic" | "aria-autocomplete" | "aria-braillelabel" | "aria-brailleroledescription" | "aria-busy" | "aria-checked" | "aria-colcount" | "aria-colindex" | "aria-colindextext" | "aria-colspan" | "aria-controls" | "aria-current" | "aria-describedby" | "aria-description" | "aria-details" | "aria-disabled" | "aria-dropeffect" | "aria-errormessage" | "aria-expanded" | "aria-flowto" | "aria-grabbed" | "aria-haspopup" | "aria-hidden" | "aria-invalid" | "aria-keyshortcuts" | "aria-label" | "aria-labelledby" | "aria-level" | "aria-live" | "aria-modal" | "aria-multiline" | "aria-multiselectable" | "aria-orientation" | "aria-owns" | "aria-placeholder" | "aria-posinset" | "aria-pressed" | "aria-readonly" | "aria-relevant" | "aria-required" | "aria-roledescription" | "aria-rowcount" | "aria-rowindex" | "aria-rowindextext" | "aria-rowspan" | "aria-selected" | "aria-setsize" | "aria-sort" | "aria-valuemax" | "aria-valuemin" | "aria-valuenow" | "aria-valuetext" | "children" | "dangerouslySetInnerHTML" | "onCopy" | "onCopyCapture" | "onCut" | "onCutCapture" | "onPaste" | "onPasteCapture" | "onCompositionEnd" | "onCompositionEndCapture" | "onCompositionStart" | "onCompositionStartCapture" | "onCompositionUpdate" | "onCompositionUpdateCapture" | "onFocus" | "onFocusCapture" | "onBlur" | "onBlurCapture" | "onChange" | "onChangeCapture" | "onBeforeInput" | "onBeforeInputCapture" | "onInput" | "onInputCapture" | "onReset" | "onResetCapture" | "onSubmit" | "onSubmitCapture" | "onInvalid" | "onInvalidCapture" | "onLoad" | "onLoadCapture" | "onError" | "onErrorCapture" | "onKeyDown" | "onKeyDownCapture" | "onKeyPress" | "onKeyPressCapture" | "onKeyUp" | "onKeyUpCapture" | "onAbort" | "onAbortCapture" | "onCanPlay" | "onCanPlayCapture" | "onCanPlayThrough" | "onCanPlayThroughCapture" | "onDurationChange" | "onDurationChangeCapture" | "onEmptied" | "onEmptiedCapture" | "onEncrypted" | "onEncryptedCapture" | "onEnded" | "onEndedCapture" | "onLoadedData" | "onLoadedDataCapture" | "onLoadedMetadata" | "onLoadedMetadataCapture" | "onLoadStart" | "onLoadStartCapture" | "onPause" | "onPauseCapture" | "onPlay" | "onPlayCapture" | "onPlaying" | "onPlayingCapture" | "onProgress" | "onProgressCapture" | "onRateChange" | "onRateChangeCapture" | "onResize" | "onResizeCapture" | "onSeeked" | "onSeekedCapture" | "onSeeking" | "onSeekingCapture" | "onStalled" | "onStalledCapture" | "onSuspend" | "onSuspendCapture" | "onTimeUpdate" | "onTimeUpdateCapture" | "onVolumeChange" | "onVolumeChangeCapture" | "onWaiting" | "onWaitingCapture" | "onAuxClick" | "onAuxClickCapture" | "onClick" | "onClickCapture" | "onContextMenu" | "onContextMenuCapture" | "onDoubleClick" | "onDoubleClickCapture" | "onDrag" | "onDragCapture" | "onDragEnd" | "onDragEndCapture" | "onDragEnter" | "onDragEnterCapture" | "onDragExit" | "onDragExitCapture" | "onDragLeave" | "onDragLeaveCapture" | "onDragOver" | "onDragOverCapture" | "onDragStart" | "onDragStartCapture" | "onDrop" | "onDropCapture" | "onMouseDown" | "onMouseDownCapture" | "onMouseEnter" | "onMouseLeave" | "onMouseMove" | "onMouseMoveCapture" | "onMouseOut" | "onMouseOutCapture" | "onMouseOver" | "onMouseOverCapture" | "onMouseUp" | "onMouseUpCapture" | "onSelect" | "onSelectCapture" | "onTouchCancel" | "onTouchCancelCapture" | "onTouchEnd" | "onTouchEndCapture" | "onTouchMove" | "onTouchMoveCapture" | "onTouchStart" | "onTouchStartCapture" | "onPointerDown" | "onPointerDownCapture" | "onPointerMove" | "onPointerMoveCapture" | "onPointerUp" | "onPointerUpCapture" | "onPointerCancel" | "onPointerCancelCapture" | "onPointerEnter" | "onPointerLeave" | "onPointerOver" | "onPointerOverCapture" | "onPointerOut" | "onPointerOutCapture" | "onGotPointerCapture" | "onGotPointerCaptureCapture" | "onLostPointerCapture" | "onLostPointerCaptureCapture" | "onScroll" | "onScrollCapture" | "onWheel" | "onWheelCapture" | "onAnimationStart" | "onAnimationStartCapture" | "onAnimationEnd" | "onAnimationEndCapture" | "onAnimationIteration" | "onAnimationIterationCapture" | "onTransitionEnd" | "onTransitionEndCapture" | "defaultChecked" | "defaultValue" | "suppressContentEditableWarning" | "accessKey" | "autoFocus" | "contentEditable" | "contextMenu" | "dir" | "draggable" | "nonce" | "spellCheck" | "radioGroup" | "about" | "datatype" | "inlist" | "prefix" | "rel" | "resource" | "rev" | "typeof" | "vocab" | "autoCapitalize" | "autoCorrect" | "autoSave" | "itemProp" | "itemScope" | "itemType" | "itemID" | "itemRef" | "results" | "security" | "unselectable" | "inputMode" | "is" | keyof import("react").ClassAttributes<HTMLButtonElement> | "formAction" | "formEncType" | "formMethod" | "formNoValidate" | "formTarget" | "value">, "ref"> & import("react").RefAttributes<HTMLAnchorElement | HTMLButtonElement> & {
64
- theme?: import("@emotion/react").Theme | undefined;
65
- } & import("@codecademy/gamut/dist/Button/shared").ButtonBaseProps & import("@codecademy/gamut").IconComponentType & {
66
- 'aria-label'?: string | undefined;
67
- tip: string;
68
- tipProps?: Omit<import("@codecademy/gamut").ToolTipProps, "children" | "info"> | undefined;
69
- }, "ref"> | Omit<Omit<{
70
- theme?: import("@emotion/react").Theme | undefined;
71
- as?: import("react").ElementType<any, keyof import("react").JSX.IntrinsicElements> | undefined;
72
- } & {
73
- theme?: import("@emotion/react").Theme | undefined;
74
- } & Pick<import("react").DetailedHTMLProps<import("react").ButtonHTMLAttributes<HTMLButtonElement>, HTMLButtonElement>, "disabled" | "content" | "translate" | "property" | "hidden" | "form" | "slot" | "style" | "title" | "suppressHydrationWarning" | "className" | "id" | "lang" | "name" | "type" | "role" | "tabIndex" | "aria-activedescendant" | "aria-atomic" | "aria-autocomplete" | "aria-braillelabel" | "aria-brailleroledescription" | "aria-busy" | "aria-checked" | "aria-colcount" | "aria-colindex" | "aria-colindextext" | "aria-colspan" | "aria-controls" | "aria-current" | "aria-describedby" | "aria-description" | "aria-details" | "aria-disabled" | "aria-dropeffect" | "aria-errormessage" | "aria-expanded" | "aria-flowto" | "aria-grabbed" | "aria-haspopup" | "aria-hidden" | "aria-invalid" | "aria-keyshortcuts" | "aria-label" | "aria-labelledby" | "aria-level" | "aria-live" | "aria-modal" | "aria-multiline" | "aria-multiselectable" | "aria-orientation" | "aria-owns" | "aria-placeholder" | "aria-posinset" | "aria-pressed" | "aria-readonly" | "aria-relevant" | "aria-required" | "aria-roledescription" | "aria-rowcount" | "aria-rowindex" | "aria-rowindextext" | "aria-rowspan" | "aria-selected" | "aria-setsize" | "aria-sort" | "aria-valuemax" | "aria-valuemin" | "aria-valuenow" | "aria-valuetext" | "children" | "dangerouslySetInnerHTML" | "onCopy" | "onCopyCapture" | "onCut" | "onCutCapture" | "onPaste" | "onPasteCapture" | "onCompositionEnd" | "onCompositionEndCapture" | "onCompositionStart" | "onCompositionStartCapture" | "onCompositionUpdate" | "onCompositionUpdateCapture" | "onFocus" | "onFocusCapture" | "onBlur" | "onBlurCapture" | "onChange" | "onChangeCapture" | "onBeforeInput" | "onBeforeInputCapture" | "onInput" | "onInputCapture" | "onReset" | "onResetCapture" | "onSubmit" | "onSubmitCapture" | "onInvalid" | "onInvalidCapture" | "onLoad" | "onLoadCapture" | "onError" | "onErrorCapture" | "onKeyDown" | "onKeyDownCapture" | "onKeyPress" | "onKeyPressCapture" | "onKeyUp" | "onKeyUpCapture" | "onAbort" | "onAbortCapture" | "onCanPlay" | "onCanPlayCapture" | "onCanPlayThrough" | "onCanPlayThroughCapture" | "onDurationChange" | "onDurationChangeCapture" | "onEmptied" | "onEmptiedCapture" | "onEncrypted" | "onEncryptedCapture" | "onEnded" | "onEndedCapture" | "onLoadedData" | "onLoadedDataCapture" | "onLoadedMetadata" | "onLoadedMetadataCapture" | "onLoadStart" | "onLoadStartCapture" | "onPause" | "onPauseCapture" | "onPlay" | "onPlayCapture" | "onPlaying" | "onPlayingCapture" | "onProgress" | "onProgressCapture" | "onRateChange" | "onRateChangeCapture" | "onResize" | "onResizeCapture" | "onSeeked" | "onSeekedCapture" | "onSeeking" | "onSeekingCapture" | "onStalled" | "onStalledCapture" | "onSuspend" | "onSuspendCapture" | "onTimeUpdate" | "onTimeUpdateCapture" | "onVolumeChange" | "onVolumeChangeCapture" | "onWaiting" | "onWaitingCapture" | "onAuxClick" | "onAuxClickCapture" | "onClick" | "onClickCapture" | "onContextMenu" | "onContextMenuCapture" | "onDoubleClick" | "onDoubleClickCapture" | "onDrag" | "onDragCapture" | "onDragEnd" | "onDragEndCapture" | "onDragEnter" | "onDragEnterCapture" | "onDragExit" | "onDragExitCapture" | "onDragLeave" | "onDragLeaveCapture" | "onDragOver" | "onDragOverCapture" | "onDragStart" | "onDragStartCapture" | "onDrop" | "onDropCapture" | "onMouseDown" | "onMouseDownCapture" | "onMouseEnter" | "onMouseLeave" | "onMouseMove" | "onMouseMoveCapture" | "onMouseOut" | "onMouseOutCapture" | "onMouseOver" | "onMouseOverCapture" | "onMouseUp" | "onMouseUpCapture" | "onSelect" | "onSelectCapture" | "onTouchCancel" | "onTouchCancelCapture" | "onTouchEnd" | "onTouchEndCapture" | "onTouchMove" | "onTouchMoveCapture" | "onTouchStart" | "onTouchStartCapture" | "onPointerDown" | "onPointerDownCapture" | "onPointerMove" | "onPointerMoveCapture" | "onPointerUp" | "onPointerUpCapture" | "onPointerCancel" | "onPointerCancelCapture" | "onPointerEnter" | "onPointerLeave" | "onPointerOver" | "onPointerOverCapture" | "onPointerOut" | "onPointerOutCapture" | "onGotPointerCapture" | "onGotPointerCaptureCapture" | "onLostPointerCapture" | "onLostPointerCaptureCapture" | "onScroll" | "onScrollCapture" | "onWheel" | "onWheelCapture" | "onAnimationStart" | "onAnimationStartCapture" | "onAnimationEnd" | "onAnimationEndCapture" | "onAnimationIteration" | "onAnimationIterationCapture" | "onTransitionEnd" | "onTransitionEndCapture" | "defaultChecked" | "defaultValue" | "suppressContentEditableWarning" | "accessKey" | "autoFocus" | "contentEditable" | "contextMenu" | "dir" | "draggable" | "nonce" | "spellCheck" | "radioGroup" | "about" | "datatype" | "inlist" | "prefix" | "rel" | "resource" | "rev" | "typeof" | "vocab" | "autoCapitalize" | "autoCorrect" | "autoSave" | "itemProp" | "itemScope" | "itemType" | "itemID" | "itemRef" | "results" | "security" | "unselectable" | "inputMode" | "is" | keyof import("react").ClassAttributes<HTMLButtonElement> | "formAction" | "formEncType" | "formMethod" | "formNoValidate" | "formTarget" | "value"> & Pick<import("react").DetailedHTMLProps<import("react").AnchorHTMLAttributes<HTMLAnchorElement>, HTMLAnchorElement>, "content" | "translate" | "property" | "hidden" | "slot" | "style" | "title" | "suppressHydrationWarning" | "className" | "id" | "lang" | "media" | "target" | "type" | "role" | "tabIndex" | "href" | "aria-activedescendant" | "aria-atomic" | "aria-autocomplete" | "aria-braillelabel" | "aria-brailleroledescription" | "aria-busy" | "aria-checked" | "aria-colcount" | "aria-colindex" | "aria-colindextext" | "aria-colspan" | "aria-controls" | "aria-current" | "aria-describedby" | "aria-description" | "aria-details" | "aria-disabled" | "aria-dropeffect" | "aria-errormessage" | "aria-expanded" | "aria-flowto" | "aria-grabbed" | "aria-haspopup" | "aria-hidden" | "aria-invalid" | "aria-keyshortcuts" | "aria-label" | "aria-labelledby" | "aria-level" | "aria-live" | "aria-modal" | "aria-multiline" | "aria-multiselectable" | "aria-orientation" | "aria-owns" | "aria-placeholder" | "aria-posinset" | "aria-pressed" | "aria-readonly" | "aria-relevant" | "aria-required" | "aria-roledescription" | "aria-rowcount" | "aria-rowindex" | "aria-rowindextext" | "aria-rowspan" | "aria-selected" | "aria-setsize" | "aria-sort" | "aria-valuemax" | "aria-valuemin" | "aria-valuenow" | "aria-valuetext" | "children" | "dangerouslySetInnerHTML" | "onCopy" | "onCopyCapture" | "onCut" | "onCutCapture" | "onPaste" | "onPasteCapture" | "onCompositionEnd" | "onCompositionEndCapture" | "onCompositionStart" | "onCompositionStartCapture" | "onCompositionUpdate" | "onCompositionUpdateCapture" | "onFocus" | "onFocusCapture" | "onBlur" | "onBlurCapture" | "onChange" | "onChangeCapture" | "onBeforeInput" | "onBeforeInputCapture" | "onInput" | "onInputCapture" | "onReset" | "onResetCapture" | "onSubmit" | "onSubmitCapture" | "onInvalid" | "onInvalidCapture" | "onLoad" | "onLoadCapture" | "onError" | "onErrorCapture" | "onKeyDown" | "onKeyDownCapture" | "onKeyPress" | "onKeyPressCapture" | "onKeyUp" | "onKeyUpCapture" | "onAbort" | "onAbortCapture" | "onCanPlay" | "onCanPlayCapture" | "onCanPlayThrough" | "onCanPlayThroughCapture" | "onDurationChange" | "onDurationChangeCapture" | "onEmptied" | "onEmptiedCapture" | "onEncrypted" | "onEncryptedCapture" | "onEnded" | "onEndedCapture" | "onLoadedData" | "onLoadedDataCapture" | "onLoadedMetadata" | "onLoadedMetadataCapture" | "onLoadStart" | "onLoadStartCapture" | "onPause" | "onPauseCapture" | "onPlay" | "onPlayCapture" | "onPlaying" | "onPlayingCapture" | "onProgress" | "onProgressCapture" | "onRateChange" | "onRateChangeCapture" | "onResize" | "onResizeCapture" | "onSeeked" | "onSeekedCapture" | "onSeeking" | "onSeekingCapture" | "onStalled" | "onStalledCapture" | "onSuspend" | "onSuspendCapture" | "onTimeUpdate" | "onTimeUpdateCapture" | "onVolumeChange" | "onVolumeChangeCapture" | "onWaiting" | "onWaitingCapture" | "onAuxClick" | "onAuxClickCapture" | "onClick" | "onClickCapture" | "onContextMenu" | "onContextMenuCapture" | "onDoubleClick" | "onDoubleClickCapture" | "onDrag" | "onDragCapture" | "onDragEnd" | "onDragEndCapture" | "onDragEnter" | "onDragEnterCapture" | "onDragExit" | "onDragExitCapture" | "onDragLeave" | "onDragLeaveCapture" | "onDragOver" | "onDragOverCapture" | "onDragStart" | "onDragStartCapture" | "onDrop" | "onDropCapture" | "onMouseDown" | "onMouseDownCapture" | "onMouseEnter" | "onMouseLeave" | "onMouseMove" | "onMouseMoveCapture" | "onMouseOut" | "onMouseOutCapture" | "onMouseOver" | "onMouseOverCapture" | "onMouseUp" | "onMouseUpCapture" | "onSelect" | "onSelectCapture" | "onTouchCancel" | "onTouchCancelCapture" | "onTouchEnd" | "onTouchEndCapture" | "onTouchMove" | "onTouchMoveCapture" | "onTouchStart" | "onTouchStartCapture" | "onPointerDown" | "onPointerDownCapture" | "onPointerMove" | "onPointerMoveCapture" | "onPointerUp" | "onPointerUpCapture" | "onPointerCancel" | "onPointerCancelCapture" | "onPointerEnter" | "onPointerLeave" | "onPointerOver" | "onPointerOverCapture" | "onPointerOut" | "onPointerOutCapture" | "onGotPointerCapture" | "onGotPointerCaptureCapture" | "onLostPointerCapture" | "onLostPointerCaptureCapture" | "onScroll" | "onScrollCapture" | "onWheel" | "onWheelCapture" | "onAnimationStart" | "onAnimationStartCapture" | "onAnimationEnd" | "onAnimationEndCapture" | "onAnimationIteration" | "onAnimationIterationCapture" | "onTransitionEnd" | "onTransitionEndCapture" | "defaultChecked" | "defaultValue" | "suppressContentEditableWarning" | "accessKey" | "autoFocus" | "contentEditable" | "contextMenu" | "dir" | "draggable" | "nonce" | "spellCheck" | "radioGroup" | "about" | "datatype" | "inlist" | "prefix" | "rel" | "resource" | "rev" | "typeof" | "vocab" | "autoCapitalize" | "autoCorrect" | "autoSave" | "itemProp" | "itemScope" | "itemType" | "itemID" | "itemRef" | "results" | "security" | "unselectable" | "inputMode" | "is" | keyof import("react").ClassAttributes<HTMLAnchorElement> | "download" | "hrefLang" | "ping" | "referrerPolicy">, "ref"> & import("react").RefAttributes<HTMLAnchorElement | HTMLButtonElement> & {
75
- theme?: import("@emotion/react").Theme | undefined;
76
- } & import("@codecademy/gamut/dist/Button/shared").ButtonBaseProps & import("@codecademy/gamut").IconComponentType & {
77
- 'aria-label'?: string | undefined;
78
- tip: string;
79
- tipProps?: Omit<import("@codecademy/gamut").ToolTipProps, "children" | "info"> | undefined;
80
- }, "ref">) & import("react").RefAttributes<import("@codecademy/gamut").ButtonBaseElements>) & {
27
+ export declare const PopularBadge: import("@emotion/styled").StyledComponent<import("@codecademy/gamut").BadgeProps & {
81
28
  theme?: import("@emotion/react").Theme;
82
29
  }, {}, {}>;