@codecademy/brand 3.29.0-alpha.9e369d57a0.0 → 3.29.0-alpha.9e88d7b76a.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 (47) hide show
  1. package/dist/AppHeader/AppHeaderElements/AppHeaderCatalogDropdown/MarketingBanner.d.ts +1 -2
  2. package/dist/AppHeader/AppHeaderElements/AppHeaderCatalogDropdown/MarketingBanner.js +3 -3
  3. package/dist/AppHeader/AppHeaderElements/AppHeaderCatalogDropdown/NavPanels.d.ts +0 -1
  4. package/dist/AppHeader/AppHeaderElements/AppHeaderCatalogDropdown/NavPanels.js +2 -3
  5. package/dist/AppHeader/AppHeaderElements/AppHeaderCatalogDropdown/consts.d.ts +1 -0
  6. package/dist/AppHeader/AppHeaderElements/AppHeaderCatalogDropdown/consts.js +2 -1
  7. package/dist/AppHeader/AppHeaderElements/AppHeaderLinkSections/index.js +0 -0
  8. package/dist/AppHeader/AppHeaderElements/AppHeaderSection/MobileBackButton.d.ts +0 -25
  9. package/dist/AppHeader/AppHeaderElements/AppHeaderSection/MobileBackButton.js +2 -13
  10. package/dist/AppHeader/AppHeaderElements/AppHeaderSection/NavTabs.d.ts +20 -0
  11. package/dist/AppHeader/AppHeaderElements/AppHeaderSection/NavTabs.js +144 -0
  12. package/dist/AppHeader/AppHeaderElements/AppHeaderSection/elements.d.ts +63 -1
  13. package/dist/AppHeader/AppHeaderElements/AppHeaderSection/elements.js +81 -16
  14. package/dist/AppHeader/AppHeaderElements/AppHeaderSection/index.d.ts +16 -10
  15. package/dist/AppHeader/AppHeaderElements/AppHeaderSection/index.js +89 -28
  16. package/dist/DropdownButton/index.d.ts +3 -1
  17. package/dist/stories/Atoms/BetaSticker.stories.js +1 -0
  18. package/dist/stories/Molecules/AppBar.stories.d.ts +1 -0
  19. package/dist/stories/Molecules/AppBar.stories.js +2 -1
  20. package/dist/stories/Molecules/AppHeader/AppHeaderLink.stories.js +2 -0
  21. package/dist/stories/Molecules/AppHeader/AppHeaderLogo.stories.js +2 -1
  22. package/dist/stories/Molecules/Banner.stories.js +3 -0
  23. package/dist/stories/Molecules/CurriculumCard.stories.js +7 -0
  24. package/dist/stories/Molecules/EmptySection.stories.js +2 -1
  25. package/dist/stories/Molecules/EnhancedBanner.stories.js +1 -1
  26. package/dist/stories/Molecules/HubCard.stories.js +1 -0
  27. package/dist/stories/Molecules/NotificationList.stories.js +2 -1
  28. package/dist/stories/Molecules/Testimonial.stories.js +8 -4
  29. package/dist/stories/Organisms/GlobalFooter.stories.js +2 -1
  30. package/dist/stories/Organisms/GlobalHeader/About.stories.js +2 -1
  31. package/dist/stories/Organisms/GlobalHeader/Bootcamp.stories.js +2 -1
  32. package/dist/stories/Organisms/GlobalHeader/Enterprise.stories.js +2 -1
  33. package/dist/stories/Organisms/GlobalHeader/Simple.stories.js +2 -1
  34. package/dist/stories/Organisms/GlobalPage.stories.js +2 -0
  35. package/dist/stories/Organisms/LayoutMenu.stories.js +6 -3
  36. package/dist/stories/Organisms/LayoutMenuVariant.stories.js +4 -2
  37. package/dist/stories/Organisms/PageFeatures.stories.js +9 -1
  38. package/dist/stories/Organisms/PageHero.stories.js +20 -10
  39. package/dist/stories/Organisms/PagePrefooter.stories.js +8 -4
  40. package/dist/stories/Organisms/PageSingleFeature.stories.js +20 -10
  41. package/dist/stories/Organisms/PageVideoGallery.stories.js +10 -5
  42. package/dist/stories/Organisms/ScoreSummary.stories.js +8 -4
  43. package/dist/svg.d.ts +1 -0
  44. package/package.json +1 -2
  45. package/dist/AppHeader/AppHeaderElements/AppHeaderSection/AppHeaderSection.test.js +0 -193
  46. package/dist/AppHeader/AppHeaderElements/AppHeaderSection/NavSection.d.ts +0 -21
  47. package/dist/AppHeader/AppHeaderElements/AppHeaderSection/NavSection.js +0 -206
@@ -1,206 +0,0 @@
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;