@codecademy/brand 3.30.0-alpha.2ad52d9890.0 → 3.30.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.
- package/dist/AppHeader/AppHeaderElements/AppHeaderCatalogDropdown/MarketingBanner.d.ts +1 -2
- package/dist/AppHeader/AppHeaderElements/AppHeaderCatalogDropdown/MarketingBanner.js +3 -3
- package/dist/AppHeader/AppHeaderElements/AppHeaderCatalogDropdown/NavPanels.d.ts +0 -1
- package/dist/AppHeader/AppHeaderElements/AppHeaderCatalogDropdown/NavPanels.js +7 -8
- package/dist/AppHeader/AppHeaderElements/AppHeaderCatalogDropdown/consts.d.ts +1 -0
- package/dist/AppHeader/AppHeaderElements/AppHeaderCatalogDropdown/consts.js +2 -1
- package/dist/AppHeader/AppHeaderElements/AppHeaderSection/MobileBackButton.d.ts +0 -25
- package/dist/AppHeader/AppHeaderElements/AppHeaderSection/MobileBackButton.js +2 -13
- package/dist/AppHeader/AppHeaderElements/AppHeaderSection/NavTabs.d.ts +20 -0
- package/dist/AppHeader/AppHeaderElements/AppHeaderSection/NavTabs.js +144 -0
- package/dist/AppHeader/AppHeaderElements/AppHeaderSection/elements.d.ts +63 -1
- package/dist/AppHeader/AppHeaderElements/AppHeaderSection/elements.js +81 -16
- package/dist/AppHeader/AppHeaderElements/AppHeaderSection/index.d.ts +16 -10
- package/dist/AppHeader/AppHeaderElements/AppHeaderSection/index.js +89 -28
- package/dist/lib/catalogList/index.d.ts +1 -1
- package/dist/lib/catalogList/index.js +10 -1
- package/package.json +1 -1
- package/dist/AppHeader/AppHeaderElements/AppHeaderSection/AppHeaderSection.test.js +0 -193
- package/dist/AppHeader/AppHeaderElements/AppHeaderSection/NavSection.d.ts +0 -21
- 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;
|