@codecademy/brand 3.22.0 → 3.23.0-alpha.36d073f3d1.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.
@@ -5,15 +5,15 @@ import { useContext, useState } from 'react';
5
5
  import * as React from 'react';
6
6
  import { AppHeaderLink } from '../../AppHeader/AppHeaderElements/AppHeaderLink';
7
7
  import { AppHeaderLinkSections } from '../../AppHeader/AppHeaderElements/AppHeaderLinkSections';
8
- import { BlpHeroExperimentContext, GlobalNavRedesignContext } from '../../GlobalHeader';
8
+ import { GlobalNavRedesignContext } from '../../GlobalHeader';
9
9
  import { login, requestTeamsDemo, signUp, signUpTextButton } from '../../GlobalHeader/GlobalHeaderItems';
10
10
  import { AppHeaderSubNavMobile } from '../AppHeaderSubMenuMobile';
11
11
  import { MobileUlWrapper } from '../AppHeaderSubMenuMobile/elements';
12
12
  import { AppHeaderSubMenuRow } from '../AppHeaderSubMenuTarget';
13
13
  import { jsx as _jsx, Fragment as _Fragment, jsxs as _jsxs } from "react/jsx-runtime";
14
- const isBusinessPageExperiment = isBlpHeroExperimentVariant => {
14
+ const isBusinessPage = () => {
15
15
  if (typeof window === 'undefined') return false;
16
- return (window.location.pathname === '/business' || window.location.pathname === '/business/pricing') && isBlpHeroExperimentVariant;
16
+ return window.location.pathname === '/business' || window.location.pathname === '/business/pricing';
17
17
  };
18
18
  const BackgroundWrapper = /*#__PURE__*/_styled(Box, {
19
19
  target: "emi0o3k0",
@@ -26,7 +26,7 @@ const BackgroundWrapper = /*#__PURE__*/_styled(Box, {
26
26
  borderRadius: 'lg',
27
27
  padding: '16px'
28
28
  }
29
- }), process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../../src/AppHeaderMobile/AppHeaderMainMenuMobile/index.tsx"],"names":[],"mappings":"AA6C0B","file":"../../../src/AppHeaderMobile/AppHeaderMainMenuMobile/index.tsx","sourcesContent":["import {\n  Box,\n  ContentContainer,\n  FillButton,\n  Text,\n  TextButton,\n} from '@codecademy/gamut';\nimport { css, states, theme } from '@codecademy/gamut-styles';\nimport styled from '@emotion/styled';\nimport { useContext, useState } from 'react';\nimport * as React from 'react';\n\nimport { AppHeaderLink } from '../../AppHeader/AppHeaderElements/AppHeaderLink';\nimport { AppHeaderLinkSections } from '../../AppHeader/AppHeaderElements/AppHeaderLinkSections';\nimport {\n  AppHeaderAction,\n  AppHeaderClickHandler,\n  AppHeaderDropdownItem,\n  AppHeaderItem,\n} from '../../AppHeader/shared';\nimport {\n  BlpHeroExperimentContext,\n  GlobalNavRedesignContext,\n} from '../../GlobalHeader';\nimport {\n  login,\n  requestTeamsDemo,\n  signUp,\n  signUpTextButton,\n} from '../../GlobalHeader/GlobalHeaderItems';\nimport { AppHeaderSubNavMobile } from '../AppHeaderSubMenuMobile';\nimport { MobileUlWrapper } from '../AppHeaderSubMenuMobile/elements';\nimport { AppHeaderSubMenuRow } from '../AppHeaderSubMenuTarget';\n\nconst isBusinessPageExperiment = (\n  isBlpHeroExperimentVariant: boolean\n): boolean => {\n  if (typeof window === 'undefined') return false;\n  return (\n    (window.location.pathname === '/business' ||\n      window.location.pathname === '/business/pricing') &&\n    isBlpHeroExperimentVariant\n  );\n};\n\nconst BackgroundWrapper = styled(Box)<{\n  displayGlobalNavRedesign: boolean;\n}>(\n  css({}),\n  states({\n    displayGlobalNavRedesign: {\n      background: theme.colors.white,\n      border: 1,\n      borderColor: 'border-tertiary',\n      borderRadius: 'lg',\n      padding: '16px',\n    },\n  })\n);\n\nexport type AppHeaderMainMenuMobileProps = AppHeaderAction & {\n  items: AppHeaderItem[];\n  getItemType: (type: string | undefined) => void;\n  isAnon: boolean;\n  handleCloseMainMenu: () => void;\n};\n\nexport const AppHeaderMainMenuMobile: React.FC<\n  AppHeaderMainMenuMobileProps\n> = ({ action, items, getItemType, isAnon, handleCloseMainMenu }) => {\n  const [subMenuItem, setSubMenuItem] = useState<AppHeaderDropdownItem>();\n  const isBlpHeroExperimentVariant = useContext(BlpHeroExperimentContext);\n  const displayGlobalNavRedesign = useContext(GlobalNavRedesignContext);\n\n  const openSubMenu = (\n    event: React.MouseEvent,\n    item: AppHeaderDropdownItem\n  ) => {\n    action(event, item);\n    setSubMenuItem(item);\n    getItemType(item.type);\n  };\n\n  const closeSubMenu = () => {\n    setSubMenuItem(undefined);\n    getItemType(undefined);\n  };\n\n  const mapItemToElement = (\n    item: AppHeaderItem,\n    action: AppHeaderClickHandler\n  ) => {\n    switch (item.type) {\n      case 'link':\n        return (\n          <AppHeaderLink action={action} item={item} key={item.id} mobile />\n        );\n      case 'dropdown':\n      case 'profile-dropdown':\n      case 'catalog-dropdown':\n      case 'resources-dropdown':\n        return (\n          <AppHeaderSubMenuRow\n            key={item.id}\n            item={item}\n            openSubMenu={openSubMenu}\n          />\n        );\n      case 'resources-simple-dropdown':\n        return (\n          <>\n            <Text as=\"h2\" fontSize={22} mt={16} mb={16}>\n              {item.text}\n            </Text>\n            <AppHeaderLinkSections action={action} item={item} mobile />\n          </>\n        );\n      case 'fill-button':\n        return (\n          <FillButton\n            data-testid={item.dataTestId}\n            href={item.href}\n            onClick={(event: React.MouseEvent) => action(event, item)}\n            mt={24}\n            key={item.id}\n          >\n            {item.text}\n          </FillButton>\n        );\n      case 'text-button':\n        return (\n          <TextButton\n            mt={16}\n            key={item.id}\n            data-testid={item.dataTestId}\n            href={item.href}\n            onClick={(event: React.MouseEvent) => action(event, item)}\n          >\n            {item.text}\n          </TextButton>\n        );\n      default:\n        return <></>;\n    }\n  };\n\n  return subMenuItem ? (\n    <AppHeaderSubNavMobile\n      handleCloseSubMenu={closeSubMenu}\n      action={action}\n      item={subMenuItem}\n      handleCloseMainMenu={handleCloseMainMenu}\n    />\n  ) : (\n    <ContentContainer\n      role=\"navigation\"\n      aria-label=\"site navigation\"\n      tabIndex={-1}\n    >\n      <BackgroundWrapper displayGlobalNavRedesign={displayGlobalNavRedesign}>\n        <MobileUlWrapper as=\"ul\">\n          {items.map((item) => mapItemToElement(item, action))}\n          {isAnon && (\n            <div\n              style={{\n                display: 'flex',\n                alignItems: 'baseline',\n                justifyContent: 'center',\n                paddingTop: '16px',\n                borderTop: '1px solid var(--border-tertiary)',\n              }}\n            >\n              {isBusinessPageExperiment(isBlpHeroExperimentVariant) ? (\n                <>\n                  <TextButton\n                    data-testid={signUpTextButton.dataTestId}\n                    href={signUpTextButton.href}\n                    onClick={(event: React.MouseEvent) =>\n                      action(event, signUpTextButton)\n                    }\n                    key={signUpTextButton.id}\n                  >\n                    {signUpTextButton.text}\n                  </TextButton>\n\n                  <FillButton\n                    data-testid={requestTeamsDemo.dataTestId}\n                    href={requestTeamsDemo.href}\n                    onClick={(event: React.MouseEvent) =>\n                      action(event, requestTeamsDemo)\n                    }\n                    key={requestTeamsDemo.id}\n                  >\n                    {requestTeamsDemo.text}\n                  </FillButton>\n                </>\n              ) : (\n                <>\n                  <FillButton\n                    data-testid={signUp.dataTestId}\n                    href={signUp.href}\n                    onClick={(event: React.MouseEvent) => action(event, signUp)}\n                    key={signUp.id}\n                  >\n                    {signUp.text}\n                  </FillButton>\n\n                  <TextButton\n                    key={login.id}\n                    data-testid={login.dataTestId}\n                    href={login.href}\n                    onClick={(event: React.MouseEvent) => action(event, login)}\n                  >\n                    {login.text}\n                  </TextButton>\n                </>\n              )}\n            </div>\n          )}\n        </MobileUlWrapper>\n      </BackgroundWrapper>\n    </ContentContainer>\n  );\n};\n"]} */");
29
+ }), process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../../src/AppHeaderMobile/AppHeaderMainMenuMobile/index.tsx"],"names":[],"mappings":"AAuC0B","file":"../../../src/AppHeaderMobile/AppHeaderMainMenuMobile/index.tsx","sourcesContent":["import {\n  Box,\n  ContentContainer,\n  FillButton,\n  Text,\n  TextButton,\n} from '@codecademy/gamut';\nimport { css, states, theme } from '@codecademy/gamut-styles';\nimport styled from '@emotion/styled';\nimport { useContext, useState } from 'react';\nimport * as React from 'react';\n\nimport { AppHeaderLink } from '../../AppHeader/AppHeaderElements/AppHeaderLink';\nimport { AppHeaderLinkSections } from '../../AppHeader/AppHeaderElements/AppHeaderLinkSections';\nimport {\n  AppHeaderAction,\n  AppHeaderClickHandler,\n  AppHeaderDropdownItem,\n  AppHeaderItem,\n} from '../../AppHeader/shared';\nimport { GlobalNavRedesignContext } from '../../GlobalHeader';\nimport {\n  login,\n  requestTeamsDemo,\n  signUp,\n  signUpTextButton,\n} from '../../GlobalHeader/GlobalHeaderItems';\nimport { AppHeaderSubNavMobile } from '../AppHeaderSubMenuMobile';\nimport { MobileUlWrapper } from '../AppHeaderSubMenuMobile/elements';\nimport { AppHeaderSubMenuRow } from '../AppHeaderSubMenuTarget';\n\nconst isBusinessPage = () => {\n  if (typeof window === 'undefined') return false;\n  return (\n    window.location.pathname === '/business' ||\n    window.location.pathname === '/business/pricing'\n  );\n};\n\nconst BackgroundWrapper = styled(Box)<{\n  displayGlobalNavRedesign: boolean;\n}>(\n  css({}),\n  states({\n    displayGlobalNavRedesign: {\n      background: theme.colors.white,\n      border: 1,\n      borderColor: 'border-tertiary',\n      borderRadius: 'lg',\n      padding: '16px',\n    },\n  })\n);\n\nexport type AppHeaderMainMenuMobileProps = AppHeaderAction & {\n  items: AppHeaderItem[];\n  getItemType: (type: string | undefined) => void;\n  isAnon: boolean;\n  handleCloseMainMenu: () => void;\n};\n\nexport const AppHeaderMainMenuMobile: React.FC<\n  AppHeaderMainMenuMobileProps\n> = ({ action, items, getItemType, isAnon, handleCloseMainMenu }) => {\n  const [subMenuItem, setSubMenuItem] = useState<AppHeaderDropdownItem>();\n  const displayGlobalNavRedesign = useContext(GlobalNavRedesignContext);\n\n  const openSubMenu = (\n    event: React.MouseEvent,\n    item: AppHeaderDropdownItem\n  ) => {\n    action(event, item);\n    setSubMenuItem(item);\n    getItemType(item.type);\n  };\n\n  const closeSubMenu = () => {\n    setSubMenuItem(undefined);\n    getItemType(undefined);\n  };\n\n  const mapItemToElement = (\n    item: AppHeaderItem,\n    action: AppHeaderClickHandler\n  ) => {\n    switch (item.type) {\n      case 'link':\n        return (\n          <AppHeaderLink action={action} item={item} key={item.id} mobile />\n        );\n      case 'dropdown':\n      case 'profile-dropdown':\n      case 'catalog-dropdown':\n      case 'resources-dropdown':\n        return (\n          <AppHeaderSubMenuRow\n            key={item.id}\n            item={item}\n            openSubMenu={openSubMenu}\n          />\n        );\n      case 'resources-simple-dropdown':\n        return (\n          <>\n            <Text as=\"h2\" fontSize={22} mt={16} mb={16}>\n              {item.text}\n            </Text>\n            <AppHeaderLinkSections action={action} item={item} mobile />\n          </>\n        );\n      case 'fill-button':\n        return (\n          <FillButton\n            data-testid={item.dataTestId}\n            href={item.href}\n            onClick={(event: React.MouseEvent) => action(event, item)}\n            mt={24}\n            key={item.id}\n          >\n            {item.text}\n          </FillButton>\n        );\n      case 'text-button':\n        return (\n          <TextButton\n            mt={16}\n            key={item.id}\n            data-testid={item.dataTestId}\n            href={item.href}\n            onClick={(event: React.MouseEvent) => action(event, item)}\n          >\n            {item.text}\n          </TextButton>\n        );\n      default:\n        return <></>;\n    }\n  };\n\n  return subMenuItem ? (\n    <AppHeaderSubNavMobile\n      handleCloseSubMenu={closeSubMenu}\n      action={action}\n      item={subMenuItem}\n      handleCloseMainMenu={handleCloseMainMenu}\n    />\n  ) : (\n    <ContentContainer\n      role=\"navigation\"\n      aria-label=\"site navigation\"\n      tabIndex={-1}\n    >\n      <BackgroundWrapper displayGlobalNavRedesign={displayGlobalNavRedesign}>\n        <MobileUlWrapper as=\"ul\">\n          {items.map((item) => mapItemToElement(item, action))}\n          {isAnon && (\n            <div\n              style={{\n                display: 'flex',\n                alignItems: 'baseline',\n                justifyContent: 'center',\n                paddingTop: '16px',\n                borderTop: '1px solid var(--border-tertiary)',\n              }}\n            >\n              {isBusinessPage() ? (\n                <>\n                  <TextButton\n                    data-testid={signUpTextButton.dataTestId}\n                    href={signUpTextButton.href}\n                    onClick={(event: React.MouseEvent) =>\n                      action(event, signUpTextButton)\n                    }\n                    key={signUpTextButton.id}\n                  >\n                    {signUpTextButton.text}\n                  </TextButton>\n\n                  <FillButton\n                    data-testid={requestTeamsDemo.dataTestId}\n                    href={requestTeamsDemo.href}\n                    onClick={(event: React.MouseEvent) =>\n                      action(event, requestTeamsDemo)\n                    }\n                    key={requestTeamsDemo.id}\n                  >\n                    {requestTeamsDemo.text}\n                  </FillButton>\n                </>\n              ) : (\n                <>\n                  <FillButton\n                    data-testid={signUp.dataTestId}\n                    href={signUp.href}\n                    onClick={(event: React.MouseEvent) => action(event, signUp)}\n                    key={signUp.id}\n                  >\n                    {signUp.text}\n                  </FillButton>\n\n                  <TextButton\n                    key={login.id}\n                    data-testid={login.dataTestId}\n                    href={login.href}\n                    onClick={(event: React.MouseEvent) => action(event, login)}\n                  >\n                    {login.text}\n                  </TextButton>\n                </>\n              )}\n            </div>\n          )}\n        </MobileUlWrapper>\n      </BackgroundWrapper>\n    </ContentContainer>\n  );\n};\n"]} */");
30
30
  export const AppHeaderMainMenuMobile = ({
31
31
  action,
32
32
  items,
@@ -35,7 +35,6 @@ export const AppHeaderMainMenuMobile = ({
35
35
  handleCloseMainMenu
36
36
  }) => {
37
37
  const [subMenuItem, setSubMenuItem] = useState();
38
- const isBlpHeroExperimentVariant = useContext(BlpHeroExperimentContext);
39
38
  const displayGlobalNavRedesign = useContext(GlobalNavRedesignContext);
40
39
  const openSubMenu = (event, item) => {
41
40
  action(event, item);
@@ -117,7 +116,7 @@ export const AppHeaderMainMenuMobile = ({
117
116
  paddingTop: '16px',
118
117
  borderTop: '1px solid var(--border-tertiary)'
119
118
  },
120
- children: isBusinessPageExperiment(isBlpHeroExperimentVariant) ? /*#__PURE__*/_jsxs(_Fragment, {
119
+ children: isBusinessPage() ? /*#__PURE__*/_jsxs(_Fragment, {
121
120
  children: [/*#__PURE__*/_jsx(TextButton, {
122
121
  "data-testid": signUpTextButton.dataTestId,
123
122
  href: signUpTextButton.href,
@@ -1,7 +1,7 @@
1
1
  import _styled from "@emotion/styled/base";
2
2
  import { Anchor, Box, Menu, Text } from '@codecademy/gamut';
3
3
  import { ArrowChevronLeftIcon, ArrowLeftIcon } from '@codecademy/gamut-icons';
4
- import { css, states, theme } from '@codecademy/gamut-styles';
4
+ import { css, states, theme, useCurrentMode } from '@codecademy/gamut-styles';
5
5
  import { useContext, useEffect, useRef } from 'react';
6
6
  import * as React from 'react';
7
7
  import { CATALOG_NAV_SECTIONS } from '../../AppHeader/AppHeaderElements/AppHeaderCatalogDropdown/consts';
@@ -25,7 +25,7 @@ const StyledAnchor = /*#__PURE__*/_styled(Anchor, {
25
25
  my: 24,
26
26
  padding: 0,
27
27
  width: 'calc(100% - 64px)'
28
- }), process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../../src/AppHeaderMobile/AppHeaderSubMenuMobile/index.tsx"],"names":[],"mappings":"AA0CqB","file":"../../../src/AppHeaderMobile/AppHeaderSubMenuMobile/index.tsx","sourcesContent":["import { Anchor, Box, Menu, Text } from '@codecademy/gamut';\nimport { ArrowChevronLeftIcon, ArrowLeftIcon } from '@codecademy/gamut-icons';\nimport { css, states, theme } from '@codecademy/gamut-styles';\nimport styled from '@emotion/styled';\nimport { useContext, useEffect, useRef } from 'react';\nimport * as React from 'react';\n\nimport { AppHeaderCatalogDropdownProps } from '../../AppHeader/AppHeaderElements/AppHeaderCatalogDropdown';\nimport { CATALOG_NAV_SECTIONS } from '../../AppHeader/AppHeaderElements/AppHeaderCatalogDropdown/consts';\nimport { MarketingBanner } from '../../AppHeader/AppHeaderElements/AppHeaderCatalogDropdown/MarketingBanner';\nimport { AppHeaderCatalogSection } from '../../AppHeader/AppHeaderElements/AppHeaderCatalogSection';\nimport { AppHeaderDropdownProps } from '../../AppHeader/AppHeaderElements/AppHeaderDropdown';\nimport { AppHeaderLinkSections } from '../../AppHeader/AppHeaderElements/AppHeaderLinkSections';\nimport { AppHeaderListItem } from '../../AppHeader/AppHeaderElements/AppHeaderListItem';\nimport { AppHeaderResourceDropdownProps } from '../../AppHeader/AppHeaderElements/AppHeaderResourcesDropdown';\nimport { RESOURCES_NAV_SECTIONS } from '../../AppHeader/AppHeaderElements/AppHeaderResourcesDropdown/consts';\nimport { AppHeaderResourcesSection } from '../../AppHeader/AppHeaderElements/AppHeaderResourcesSection';\nimport { AppHeaderSection } from '../../AppHeader/AppHeaderElements/AppHeaderSection';\nimport {\n  AppHeaderCatalogDropdownItem,\n  AppHeaderClickHandler,\n  AppHeaderDropdownItem,\n  AppHeaderResourcesDropdownItem,\n} from '../../AppHeader/shared';\nimport { GlobalNavRedesignContext } from '../../GlobalHeader';\nimport { getHeaderResourcesList } from '../../lib/resourcesList';\nimport { MobileSubMenuWrapper, MobileUlWrapper } from './elements';\n\nexport type AppHeaderSubMenuMobileProps = (\n  | AppHeaderDropdownProps\n  | AppHeaderCatalogDropdownProps\n  | AppHeaderResourceDropdownProps\n) & {\n  handleCloseSubMenu: () => void;\n  handleCloseMainMenu: () => void;\n};\n\ntype AppHeaderSectionItem =\n  | AppHeaderDropdownItem\n  | AppHeaderCatalogDropdownItem\n  | AppHeaderResourcesDropdownItem;\n\nconst StyledAnchor = styled(Anchor)(\n  css({\n    alignItems: `center`,\n    display: `flex`,\n    my: 24,\n    padding: 0,\n    width: 'calc(100% - 64px)',\n  })\n);\n\nconst StyledStandardRedesignAnchor = styled(Anchor)(\n  css({\n    alignItems: `center`,\n    display: `flex`,\n    width: 'calc(100% - 64px)',\n    py: 8,\n    mt: 0,\n    mb: 16,\n  })\n);\n\nconst BackgroundWrapper = styled(Box)<{\n  showStandardRedesign: boolean;\n}>(\n  states({\n    showStandardRedesign: {\n      background: theme.colors.white,\n      border: 1,\n      borderColor: 'border-tertiary',\n      borderRadius: 'lg',\n      padding: '16px',\n      mx: 16,\n    },\n  })\n);\n\nconst renderHeaderSection = (\n  item: AppHeaderSectionItem,\n  action: AppHeaderClickHandler,\n  handleCloseMainMenu: () => void,\n  displayGlobalNavRedesign: boolean,\n  handleCloseSubMenu: () => void\n) => {\n  switch (item.type) {\n    case 'catalog-dropdown':\n      return displayGlobalNavRedesign ? (\n        <AppHeaderSection\n          navSections={CATALOG_NAV_SECTIONS}\n          MarketingBanner={MarketingBanner}\n          isMobile\n          handleClose={handleCloseSubMenu}\n          type=\"catalog-dropdown\"\n        />\n      ) : (\n        <AppHeaderCatalogSection\n          action={action}\n          item={item}\n          handleClose={handleCloseMainMenu}\n        />\n      );\n    case 'resources-dropdown':\n      return displayGlobalNavRedesign ? (\n        <AppHeaderSection\n          navSections={RESOURCES_NAV_SECTIONS}\n          isMobile\n          handleClose={handleCloseSubMenu}\n          type=\"resources-dropdown\"\n        />\n      ) : (\n        <AppHeaderResourcesSection\n          action={action}\n          handleClose={handleCloseMainMenu}\n          resources={getHeaderResourcesList()}\n        />\n      );\n    default:\n      return <AppHeaderLinkSections action={action} item={item} mobile />;\n  }\n};\n\nexport const AppHeaderSubNavMobile: React.FC<AppHeaderSubMenuMobileProps> = ({\n  action,\n  handleCloseSubMenu,\n  handleCloseMainMenu,\n  item,\n}) => {\n  const mainUlWrapper = useRef<HTMLUListElement>(null);\n\n  useEffect(() => {\n    if (mainUlWrapper?.current) {\n      mainUlWrapper.current.focus();\n    }\n  }, []);\n\n  const isProfileMenu = item.type === 'profile-dropdown';\n  const displayGlobalNavRedesign = useContext(GlobalNavRedesignContext);\n\n  const isCatalogOrResourcesMenu =\n    item.type === 'catalog-dropdown' || item.type === 'resources-dropdown';\n\n  const showLegacyDesign = !displayGlobalNavRedesign;\n  const showCatalogOrResourceRedesign =\n    displayGlobalNavRedesign && isCatalogOrResourcesMenu; // for redesigned catalog or resources menus\n  const showStandardRedesign =\n    displayGlobalNavRedesign && !isCatalogOrResourcesMenu; // for all other redesigned menus\n\n  const renderBackButton = () => {\n    if (showLegacyDesign) {\n      return (\n        <AppHeaderListItem>\n          <StyledAnchor\n            onClick={handleCloseSubMenu}\n            variant=\"interface\"\n            as=\"button\"\n            ml={{ _: 16, xs: 32, sm: 64, md: 48 }}\n          >\n            <ArrowChevronLeftIcon size={12} aria-hidden />\n            <Text fontSize={16} pl={8}>\n              Back to main navigation\n            </Text>\n          </StyledAnchor>\n        </AppHeaderListItem>\n      );\n    }\n    if (showStandardRedesign) {\n      return (\n        <AppHeaderListItem>\n          <StyledStandardRedesignAnchor\n            onClick={handleCloseSubMenu}\n            variant=\"interface\"\n            as=\"button\"\n          >\n            <ArrowLeftIcon size={24} aria-hidden />\n            <Text pl={8}>Back</Text>\n          </StyledStandardRedesignAnchor>\n        </AppHeaderListItem>\n      );\n    }\n    return null;\n  };\n\n  return (\n    <BackgroundWrapper showStandardRedesign={showStandardRedesign}>\n      <MobileUlWrapper ref={mainUlWrapper} tabIndex={-1}>\n        {renderBackButton()}\n        <MobileSubMenuWrapper\n          handleClose={handleCloseSubMenu}\n          isMenuRole={isProfileMenu}\n        >\n          {!showCatalogOrResourceRedesign && (\n            <Text\n              as=\"h1\"\n              fontSize={showLegacyDesign ? 22 : 20}\n              mb={16}\n              ml={showLegacyDesign ? { _: 16, xs: 32, sm: 64, md: 48 } : 0}\n            >\n              {isProfileMenu ? item.userDisplayName : item.text}\n            </Text>\n          )}\n          <Menu\n            variant=\"fixed\"\n            mx={showCatalogOrResourceRedesign ? { _: 16, sm: 32 } : 0}\n            width={displayGlobalNavRedesign ? 'auto' : 'calc(100% - 16px)'}\n            bg={displayGlobalNavRedesign ? 'transparent' : 'white'}\n          >\n            {renderHeaderSection(\n              item,\n              action,\n              handleCloseMainMenu,\n              displayGlobalNavRedesign,\n              handleCloseSubMenu\n            )}\n          </Menu>\n        </MobileSubMenuWrapper>\n      </MobileUlWrapper>\n    </BackgroundWrapper>\n  );\n};\n"]} */");
28
+ }), process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../../src/AppHeaderMobile/AppHeaderSubMenuMobile/index.tsx"],"names":[],"mappings":"AA0CqB","file":"../../../src/AppHeaderMobile/AppHeaderSubMenuMobile/index.tsx","sourcesContent":["import { Anchor, Box, Menu, Text } from '@codecademy/gamut';\nimport { ArrowChevronLeftIcon, ArrowLeftIcon } from '@codecademy/gamut-icons';\nimport { css, states, theme, useCurrentMode } from '@codecademy/gamut-styles';\nimport styled from '@emotion/styled';\nimport { useContext, useEffect, useRef } from 'react';\nimport * as React from 'react';\n\nimport { AppHeaderCatalogDropdownProps } from '../../AppHeader/AppHeaderElements/AppHeaderCatalogDropdown';\nimport { CATALOG_NAV_SECTIONS } from '../../AppHeader/AppHeaderElements/AppHeaderCatalogDropdown/consts';\nimport { MarketingBanner } from '../../AppHeader/AppHeaderElements/AppHeaderCatalogDropdown/MarketingBanner';\nimport { AppHeaderCatalogSection } from '../../AppHeader/AppHeaderElements/AppHeaderCatalogSection';\nimport { AppHeaderDropdownProps } from '../../AppHeader/AppHeaderElements/AppHeaderDropdown';\nimport { AppHeaderLinkSections } from '../../AppHeader/AppHeaderElements/AppHeaderLinkSections';\nimport { AppHeaderListItem } from '../../AppHeader/AppHeaderElements/AppHeaderListItem';\nimport { AppHeaderResourceDropdownProps } from '../../AppHeader/AppHeaderElements/AppHeaderResourcesDropdown';\nimport { RESOURCES_NAV_SECTIONS } from '../../AppHeader/AppHeaderElements/AppHeaderResourcesDropdown/consts';\nimport { AppHeaderResourcesSection } from '../../AppHeader/AppHeaderElements/AppHeaderResourcesSection';\nimport { AppHeaderSection } from '../../AppHeader/AppHeaderElements/AppHeaderSection';\nimport {\n  AppHeaderCatalogDropdownItem,\n  AppHeaderClickHandler,\n  AppHeaderDropdownItem,\n  AppHeaderResourcesDropdownItem,\n} from '../../AppHeader/shared';\nimport { GlobalNavRedesignContext } from '../../GlobalHeader';\nimport { getHeaderResourcesList } from '../../lib/resourcesList';\nimport { MobileSubMenuWrapper, MobileUlWrapper } from './elements';\n\nexport type AppHeaderSubMenuMobileProps = (\n  | AppHeaderDropdownProps\n  | AppHeaderCatalogDropdownProps\n  | AppHeaderResourceDropdownProps\n) & {\n  handleCloseSubMenu: () => void;\n  handleCloseMainMenu: () => void;\n};\n\ntype AppHeaderSectionItem =\n  | AppHeaderDropdownItem\n  | AppHeaderCatalogDropdownItem\n  | AppHeaderResourcesDropdownItem;\n\nconst StyledAnchor = styled(Anchor)(\n  css({\n    alignItems: `center`,\n    display: `flex`,\n    my: 24,\n    padding: 0,\n    width: 'calc(100% - 64px)',\n  })\n);\n\nconst StyledStandardRedesignAnchor = styled(Anchor)(\n  css({\n    alignItems: `center`,\n    display: `flex`,\n    width: 'calc(100% - 64px)',\n    py: 8,\n    mt: 0,\n    mb: 16,\n  })\n);\n\nconst BackgroundWrapper = styled(Box)<{\n  showStandardRedesign: boolean;\n}>(\n  states({\n    showStandardRedesign: {\n      background: theme.colors.white,\n      border: 1,\n      borderColor: 'border-tertiary',\n      borderRadius: 'lg',\n      padding: '16px',\n      mx: 16,\n    },\n  })\n);\n\nconst renderHeaderSection = (\n  item: AppHeaderSectionItem,\n  action: AppHeaderClickHandler,\n  handleCloseMainMenu: () => void,\n  displayGlobalNavRedesign: boolean,\n  handleCloseSubMenu: () => void\n) => {\n  switch (item.type) {\n    case 'catalog-dropdown':\n      return displayGlobalNavRedesign ? (\n        <AppHeaderSection\n          navSections={CATALOG_NAV_SECTIONS}\n          MarketingBanner={MarketingBanner}\n          isMobile\n          handleClose={handleCloseSubMenu}\n          type=\"catalog-dropdown\"\n        />\n      ) : (\n        <AppHeaderCatalogSection\n          action={action}\n          item={item}\n          handleClose={handleCloseMainMenu}\n        />\n      );\n    case 'resources-dropdown':\n      return displayGlobalNavRedesign ? (\n        <AppHeaderSection\n          navSections={RESOURCES_NAV_SECTIONS}\n          isMobile\n          handleClose={handleCloseSubMenu}\n          type=\"resources-dropdown\"\n        />\n      ) : (\n        <AppHeaderResourcesSection\n          action={action}\n          handleClose={handleCloseMainMenu}\n          resources={getHeaderResourcesList()}\n        />\n      );\n    default:\n      return <AppHeaderLinkSections action={action} item={item} mobile />;\n  }\n};\n\nexport const AppHeaderSubNavMobile: React.FC<AppHeaderSubMenuMobileProps> = ({\n  action,\n  handleCloseSubMenu,\n  handleCloseMainMenu,\n  item,\n}) => {\n  const mainUlWrapper = useRef<HTMLUListElement>(null);\n\n  useEffect(() => {\n    if (mainUlWrapper?.current) {\n      mainUlWrapper.current.focus();\n    }\n  }, []);\n\n  const isProfileMenu = item.type === 'profile-dropdown';\n  const displayGlobalNavRedesign = useContext(GlobalNavRedesignContext);\n\n  const isCatalogOrResourcesMenu =\n    item.type === 'catalog-dropdown' || item.type === 'resources-dropdown';\n\n  const showLegacyDesign = !displayGlobalNavRedesign;\n  const showCatalogOrResourceRedesign =\n    displayGlobalNavRedesign && isCatalogOrResourcesMenu; // for redesigned catalog or resources menus\n  const showStandardRedesign =\n    displayGlobalNavRedesign && !isCatalogOrResourcesMenu; // for all other redesigned menus\n\n  const renderBackButton = () => {\n    if (showLegacyDesign) {\n      return (\n        <AppHeaderListItem>\n          <StyledAnchor\n            onClick={handleCloseSubMenu}\n            variant=\"interface\"\n            as=\"button\"\n            ml={{ _: 16, xs: 32, sm: 64, md: 48 }}\n          >\n            <ArrowChevronLeftIcon size={12} aria-hidden />\n            <Text fontSize={16} pl={8}>\n              Back to main navigation\n            </Text>\n          </StyledAnchor>\n        </AppHeaderListItem>\n      );\n    }\n    if (showStandardRedesign) {\n      return (\n        <AppHeaderListItem>\n          <StyledStandardRedesignAnchor\n            onClick={handleCloseSubMenu}\n            variant=\"interface\"\n            as=\"button\"\n          >\n            <ArrowLeftIcon size={24} aria-hidden />\n            <Text pl={8}>Back</Text>\n          </StyledStandardRedesignAnchor>\n        </AppHeaderListItem>\n      );\n    }\n    return null;\n  };\n\n  const colorMode = useCurrentMode();\n  return (\n    <BackgroundWrapper showStandardRedesign={showStandardRedesign}>\n      <MobileUlWrapper ref={mainUlWrapper} tabIndex={-1}>\n        {renderBackButton()}\n        <MobileSubMenuWrapper\n          handleClose={handleCloseSubMenu}\n          isMenuRole={isProfileMenu}\n        >\n          {!showCatalogOrResourceRedesign && (\n            <Text\n              as=\"h1\"\n              fontSize={showLegacyDesign ? 22 : 20}\n              mb={16}\n              ml={showLegacyDesign ? { _: 16, xs: 32, sm: 64, md: 48 } : 0}\n            >\n              {isProfileMenu ? item.userDisplayName : item.text}\n            </Text>\n          )}\n          <Menu\n            variant=\"fixed\"\n            mx={showCatalogOrResourceRedesign ? { _: 16, sm: 32 } : 0}\n            width={displayGlobalNavRedesign ? 'auto' : 'calc(100% - 16px)'}\n            bg={\n              displayGlobalNavRedesign\n                ? 'transparent'\n                : colorMode === 'dark'\n                ? 'navy-800'\n                : 'white'\n            }\n          >\n            {renderHeaderSection(\n              item,\n              action,\n              handleCloseMainMenu,\n              displayGlobalNavRedesign,\n              handleCloseSubMenu\n            )}\n          </Menu>\n        </MobileSubMenuWrapper>\n      </MobileUlWrapper>\n    </BackgroundWrapper>\n  );\n};\n"]} */");
29
29
  const StyledStandardRedesignAnchor = /*#__PURE__*/_styled(Anchor, {
30
30
  target: "e1ch795o1",
31
31
  label: "StyledStandardRedesignAnchor"
@@ -36,7 +36,7 @@ const StyledStandardRedesignAnchor = /*#__PURE__*/_styled(Anchor, {
36
36
  py: 8,
37
37
  mt: 0,
38
38
  mb: 16
39
- }), process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../../src/AppHeaderMobile/AppHeaderSubMenuMobile/index.tsx"],"names":[],"mappings":"AAoDqC","file":"../../../src/AppHeaderMobile/AppHeaderSubMenuMobile/index.tsx","sourcesContent":["import { Anchor, Box, Menu, Text } from '@codecademy/gamut';\nimport { ArrowChevronLeftIcon, ArrowLeftIcon } from '@codecademy/gamut-icons';\nimport { css, states, theme } from '@codecademy/gamut-styles';\nimport styled from '@emotion/styled';\nimport { useContext, useEffect, useRef } from 'react';\nimport * as React from 'react';\n\nimport { AppHeaderCatalogDropdownProps } from '../../AppHeader/AppHeaderElements/AppHeaderCatalogDropdown';\nimport { CATALOG_NAV_SECTIONS } from '../../AppHeader/AppHeaderElements/AppHeaderCatalogDropdown/consts';\nimport { MarketingBanner } from '../../AppHeader/AppHeaderElements/AppHeaderCatalogDropdown/MarketingBanner';\nimport { AppHeaderCatalogSection } from '../../AppHeader/AppHeaderElements/AppHeaderCatalogSection';\nimport { AppHeaderDropdownProps } from '../../AppHeader/AppHeaderElements/AppHeaderDropdown';\nimport { AppHeaderLinkSections } from '../../AppHeader/AppHeaderElements/AppHeaderLinkSections';\nimport { AppHeaderListItem } from '../../AppHeader/AppHeaderElements/AppHeaderListItem';\nimport { AppHeaderResourceDropdownProps } from '../../AppHeader/AppHeaderElements/AppHeaderResourcesDropdown';\nimport { RESOURCES_NAV_SECTIONS } from '../../AppHeader/AppHeaderElements/AppHeaderResourcesDropdown/consts';\nimport { AppHeaderResourcesSection } from '../../AppHeader/AppHeaderElements/AppHeaderResourcesSection';\nimport { AppHeaderSection } from '../../AppHeader/AppHeaderElements/AppHeaderSection';\nimport {\n  AppHeaderCatalogDropdownItem,\n  AppHeaderClickHandler,\n  AppHeaderDropdownItem,\n  AppHeaderResourcesDropdownItem,\n} from '../../AppHeader/shared';\nimport { GlobalNavRedesignContext } from '../../GlobalHeader';\nimport { getHeaderResourcesList } from '../../lib/resourcesList';\nimport { MobileSubMenuWrapper, MobileUlWrapper } from './elements';\n\nexport type AppHeaderSubMenuMobileProps = (\n  | AppHeaderDropdownProps\n  | AppHeaderCatalogDropdownProps\n  | AppHeaderResourceDropdownProps\n) & {\n  handleCloseSubMenu: () => void;\n  handleCloseMainMenu: () => void;\n};\n\ntype AppHeaderSectionItem =\n  | AppHeaderDropdownItem\n  | AppHeaderCatalogDropdownItem\n  | AppHeaderResourcesDropdownItem;\n\nconst StyledAnchor = styled(Anchor)(\n  css({\n    alignItems: `center`,\n    display: `flex`,\n    my: 24,\n    padding: 0,\n    width: 'calc(100% - 64px)',\n  })\n);\n\nconst StyledStandardRedesignAnchor = styled(Anchor)(\n  css({\n    alignItems: `center`,\n    display: `flex`,\n    width: 'calc(100% - 64px)',\n    py: 8,\n    mt: 0,\n    mb: 16,\n  })\n);\n\nconst BackgroundWrapper = styled(Box)<{\n  showStandardRedesign: boolean;\n}>(\n  states({\n    showStandardRedesign: {\n      background: theme.colors.white,\n      border: 1,\n      borderColor: 'border-tertiary',\n      borderRadius: 'lg',\n      padding: '16px',\n      mx: 16,\n    },\n  })\n);\n\nconst renderHeaderSection = (\n  item: AppHeaderSectionItem,\n  action: AppHeaderClickHandler,\n  handleCloseMainMenu: () => void,\n  displayGlobalNavRedesign: boolean,\n  handleCloseSubMenu: () => void\n) => {\n  switch (item.type) {\n    case 'catalog-dropdown':\n      return displayGlobalNavRedesign ? (\n        <AppHeaderSection\n          navSections={CATALOG_NAV_SECTIONS}\n          MarketingBanner={MarketingBanner}\n          isMobile\n          handleClose={handleCloseSubMenu}\n          type=\"catalog-dropdown\"\n        />\n      ) : (\n        <AppHeaderCatalogSection\n          action={action}\n          item={item}\n          handleClose={handleCloseMainMenu}\n        />\n      );\n    case 'resources-dropdown':\n      return displayGlobalNavRedesign ? (\n        <AppHeaderSection\n          navSections={RESOURCES_NAV_SECTIONS}\n          isMobile\n          handleClose={handleCloseSubMenu}\n          type=\"resources-dropdown\"\n        />\n      ) : (\n        <AppHeaderResourcesSection\n          action={action}\n          handleClose={handleCloseMainMenu}\n          resources={getHeaderResourcesList()}\n        />\n      );\n    default:\n      return <AppHeaderLinkSections action={action} item={item} mobile />;\n  }\n};\n\nexport const AppHeaderSubNavMobile: React.FC<AppHeaderSubMenuMobileProps> = ({\n  action,\n  handleCloseSubMenu,\n  handleCloseMainMenu,\n  item,\n}) => {\n  const mainUlWrapper = useRef<HTMLUListElement>(null);\n\n  useEffect(() => {\n    if (mainUlWrapper?.current) {\n      mainUlWrapper.current.focus();\n    }\n  }, []);\n\n  const isProfileMenu = item.type === 'profile-dropdown';\n  const displayGlobalNavRedesign = useContext(GlobalNavRedesignContext);\n\n  const isCatalogOrResourcesMenu =\n    item.type === 'catalog-dropdown' || item.type === 'resources-dropdown';\n\n  const showLegacyDesign = !displayGlobalNavRedesign;\n  const showCatalogOrResourceRedesign =\n    displayGlobalNavRedesign && isCatalogOrResourcesMenu; // for redesigned catalog or resources menus\n  const showStandardRedesign =\n    displayGlobalNavRedesign && !isCatalogOrResourcesMenu; // for all other redesigned menus\n\n  const renderBackButton = () => {\n    if (showLegacyDesign) {\n      return (\n        <AppHeaderListItem>\n          <StyledAnchor\n            onClick={handleCloseSubMenu}\n            variant=\"interface\"\n            as=\"button\"\n            ml={{ _: 16, xs: 32, sm: 64, md: 48 }}\n          >\n            <ArrowChevronLeftIcon size={12} aria-hidden />\n            <Text fontSize={16} pl={8}>\n              Back to main navigation\n            </Text>\n          </StyledAnchor>\n        </AppHeaderListItem>\n      );\n    }\n    if (showStandardRedesign) {\n      return (\n        <AppHeaderListItem>\n          <StyledStandardRedesignAnchor\n            onClick={handleCloseSubMenu}\n            variant=\"interface\"\n            as=\"button\"\n          >\n            <ArrowLeftIcon size={24} aria-hidden />\n            <Text pl={8}>Back</Text>\n          </StyledStandardRedesignAnchor>\n        </AppHeaderListItem>\n      );\n    }\n    return null;\n  };\n\n  return (\n    <BackgroundWrapper showStandardRedesign={showStandardRedesign}>\n      <MobileUlWrapper ref={mainUlWrapper} tabIndex={-1}>\n        {renderBackButton()}\n        <MobileSubMenuWrapper\n          handleClose={handleCloseSubMenu}\n          isMenuRole={isProfileMenu}\n        >\n          {!showCatalogOrResourceRedesign && (\n            <Text\n              as=\"h1\"\n              fontSize={showLegacyDesign ? 22 : 20}\n              mb={16}\n              ml={showLegacyDesign ? { _: 16, xs: 32, sm: 64, md: 48 } : 0}\n            >\n              {isProfileMenu ? item.userDisplayName : item.text}\n            </Text>\n          )}\n          <Menu\n            variant=\"fixed\"\n            mx={showCatalogOrResourceRedesign ? { _: 16, sm: 32 } : 0}\n            width={displayGlobalNavRedesign ? 'auto' : 'calc(100% - 16px)'}\n            bg={displayGlobalNavRedesign ? 'transparent' : 'white'}\n          >\n            {renderHeaderSection(\n              item,\n              action,\n              handleCloseMainMenu,\n              displayGlobalNavRedesign,\n              handleCloseSubMenu\n            )}\n          </Menu>\n        </MobileSubMenuWrapper>\n      </MobileUlWrapper>\n    </BackgroundWrapper>\n  );\n};\n"]} */");
39
+ }), process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../../src/AppHeaderMobile/AppHeaderSubMenuMobile/index.tsx"],"names":[],"mappings":"AAoDqC","file":"../../../src/AppHeaderMobile/AppHeaderSubMenuMobile/index.tsx","sourcesContent":["import { Anchor, Box, Menu, Text } from '@codecademy/gamut';\nimport { ArrowChevronLeftIcon, ArrowLeftIcon } from '@codecademy/gamut-icons';\nimport { css, states, theme, useCurrentMode } from '@codecademy/gamut-styles';\nimport styled from '@emotion/styled';\nimport { useContext, useEffect, useRef } from 'react';\nimport * as React from 'react';\n\nimport { AppHeaderCatalogDropdownProps } from '../../AppHeader/AppHeaderElements/AppHeaderCatalogDropdown';\nimport { CATALOG_NAV_SECTIONS } from '../../AppHeader/AppHeaderElements/AppHeaderCatalogDropdown/consts';\nimport { MarketingBanner } from '../../AppHeader/AppHeaderElements/AppHeaderCatalogDropdown/MarketingBanner';\nimport { AppHeaderCatalogSection } from '../../AppHeader/AppHeaderElements/AppHeaderCatalogSection';\nimport { AppHeaderDropdownProps } from '../../AppHeader/AppHeaderElements/AppHeaderDropdown';\nimport { AppHeaderLinkSections } from '../../AppHeader/AppHeaderElements/AppHeaderLinkSections';\nimport { AppHeaderListItem } from '../../AppHeader/AppHeaderElements/AppHeaderListItem';\nimport { AppHeaderResourceDropdownProps } from '../../AppHeader/AppHeaderElements/AppHeaderResourcesDropdown';\nimport { RESOURCES_NAV_SECTIONS } from '../../AppHeader/AppHeaderElements/AppHeaderResourcesDropdown/consts';\nimport { AppHeaderResourcesSection } from '../../AppHeader/AppHeaderElements/AppHeaderResourcesSection';\nimport { AppHeaderSection } from '../../AppHeader/AppHeaderElements/AppHeaderSection';\nimport {\n  AppHeaderCatalogDropdownItem,\n  AppHeaderClickHandler,\n  AppHeaderDropdownItem,\n  AppHeaderResourcesDropdownItem,\n} from '../../AppHeader/shared';\nimport { GlobalNavRedesignContext } from '../../GlobalHeader';\nimport { getHeaderResourcesList } from '../../lib/resourcesList';\nimport { MobileSubMenuWrapper, MobileUlWrapper } from './elements';\n\nexport type AppHeaderSubMenuMobileProps = (\n  | AppHeaderDropdownProps\n  | AppHeaderCatalogDropdownProps\n  | AppHeaderResourceDropdownProps\n) & {\n  handleCloseSubMenu: () => void;\n  handleCloseMainMenu: () => void;\n};\n\ntype AppHeaderSectionItem =\n  | AppHeaderDropdownItem\n  | AppHeaderCatalogDropdownItem\n  | AppHeaderResourcesDropdownItem;\n\nconst StyledAnchor = styled(Anchor)(\n  css({\n    alignItems: `center`,\n    display: `flex`,\n    my: 24,\n    padding: 0,\n    width: 'calc(100% - 64px)',\n  })\n);\n\nconst StyledStandardRedesignAnchor = styled(Anchor)(\n  css({\n    alignItems: `center`,\n    display: `flex`,\n    width: 'calc(100% - 64px)',\n    py: 8,\n    mt: 0,\n    mb: 16,\n  })\n);\n\nconst BackgroundWrapper = styled(Box)<{\n  showStandardRedesign: boolean;\n}>(\n  states({\n    showStandardRedesign: {\n      background: theme.colors.white,\n      border: 1,\n      borderColor: 'border-tertiary',\n      borderRadius: 'lg',\n      padding: '16px',\n      mx: 16,\n    },\n  })\n);\n\nconst renderHeaderSection = (\n  item: AppHeaderSectionItem,\n  action: AppHeaderClickHandler,\n  handleCloseMainMenu: () => void,\n  displayGlobalNavRedesign: boolean,\n  handleCloseSubMenu: () => void\n) => {\n  switch (item.type) {\n    case 'catalog-dropdown':\n      return displayGlobalNavRedesign ? (\n        <AppHeaderSection\n          navSections={CATALOG_NAV_SECTIONS}\n          MarketingBanner={MarketingBanner}\n          isMobile\n          handleClose={handleCloseSubMenu}\n          type=\"catalog-dropdown\"\n        />\n      ) : (\n        <AppHeaderCatalogSection\n          action={action}\n          item={item}\n          handleClose={handleCloseMainMenu}\n        />\n      );\n    case 'resources-dropdown':\n      return displayGlobalNavRedesign ? (\n        <AppHeaderSection\n          navSections={RESOURCES_NAV_SECTIONS}\n          isMobile\n          handleClose={handleCloseSubMenu}\n          type=\"resources-dropdown\"\n        />\n      ) : (\n        <AppHeaderResourcesSection\n          action={action}\n          handleClose={handleCloseMainMenu}\n          resources={getHeaderResourcesList()}\n        />\n      );\n    default:\n      return <AppHeaderLinkSections action={action} item={item} mobile />;\n  }\n};\n\nexport const AppHeaderSubNavMobile: React.FC<AppHeaderSubMenuMobileProps> = ({\n  action,\n  handleCloseSubMenu,\n  handleCloseMainMenu,\n  item,\n}) => {\n  const mainUlWrapper = useRef<HTMLUListElement>(null);\n\n  useEffect(() => {\n    if (mainUlWrapper?.current) {\n      mainUlWrapper.current.focus();\n    }\n  }, []);\n\n  const isProfileMenu = item.type === 'profile-dropdown';\n  const displayGlobalNavRedesign = useContext(GlobalNavRedesignContext);\n\n  const isCatalogOrResourcesMenu =\n    item.type === 'catalog-dropdown' || item.type === 'resources-dropdown';\n\n  const showLegacyDesign = !displayGlobalNavRedesign;\n  const showCatalogOrResourceRedesign =\n    displayGlobalNavRedesign && isCatalogOrResourcesMenu; // for redesigned catalog or resources menus\n  const showStandardRedesign =\n    displayGlobalNavRedesign && !isCatalogOrResourcesMenu; // for all other redesigned menus\n\n  const renderBackButton = () => {\n    if (showLegacyDesign) {\n      return (\n        <AppHeaderListItem>\n          <StyledAnchor\n            onClick={handleCloseSubMenu}\n            variant=\"interface\"\n            as=\"button\"\n            ml={{ _: 16, xs: 32, sm: 64, md: 48 }}\n          >\n            <ArrowChevronLeftIcon size={12} aria-hidden />\n            <Text fontSize={16} pl={8}>\n              Back to main navigation\n            </Text>\n          </StyledAnchor>\n        </AppHeaderListItem>\n      );\n    }\n    if (showStandardRedesign) {\n      return (\n        <AppHeaderListItem>\n          <StyledStandardRedesignAnchor\n            onClick={handleCloseSubMenu}\n            variant=\"interface\"\n            as=\"button\"\n          >\n            <ArrowLeftIcon size={24} aria-hidden />\n            <Text pl={8}>Back</Text>\n          </StyledStandardRedesignAnchor>\n        </AppHeaderListItem>\n      );\n    }\n    return null;\n  };\n\n  const colorMode = useCurrentMode();\n  return (\n    <BackgroundWrapper showStandardRedesign={showStandardRedesign}>\n      <MobileUlWrapper ref={mainUlWrapper} tabIndex={-1}>\n        {renderBackButton()}\n        <MobileSubMenuWrapper\n          handleClose={handleCloseSubMenu}\n          isMenuRole={isProfileMenu}\n        >\n          {!showCatalogOrResourceRedesign && (\n            <Text\n              as=\"h1\"\n              fontSize={showLegacyDesign ? 22 : 20}\n              mb={16}\n              ml={showLegacyDesign ? { _: 16, xs: 32, sm: 64, md: 48 } : 0}\n            >\n              {isProfileMenu ? item.userDisplayName : item.text}\n            </Text>\n          )}\n          <Menu\n            variant=\"fixed\"\n            mx={showCatalogOrResourceRedesign ? { _: 16, sm: 32 } : 0}\n            width={displayGlobalNavRedesign ? 'auto' : 'calc(100% - 16px)'}\n            bg={\n              displayGlobalNavRedesign\n                ? 'transparent'\n                : colorMode === 'dark'\n                ? 'navy-800'\n                : 'white'\n            }\n          >\n            {renderHeaderSection(\n              item,\n              action,\n              handleCloseMainMenu,\n              displayGlobalNavRedesign,\n              handleCloseSubMenu\n            )}\n          </Menu>\n        </MobileSubMenuWrapper>\n      </MobileUlWrapper>\n    </BackgroundWrapper>\n  );\n};\n"]} */");
40
40
  const BackgroundWrapper = /*#__PURE__*/_styled(Box, {
41
41
  target: "e1ch795o0",
42
42
  label: "BackgroundWrapper"
@@ -49,7 +49,7 @@ const BackgroundWrapper = /*#__PURE__*/_styled(Box, {
49
49
  padding: '16px',
50
50
  mx: 16
51
51
  }
52
- }), process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../../src/AppHeaderMobile/AppHeaderSubMenuMobile/index.tsx"],"names":[],"mappings":"AA+D0B","file":"../../../src/AppHeaderMobile/AppHeaderSubMenuMobile/index.tsx","sourcesContent":["import { Anchor, Box, Menu, Text } from '@codecademy/gamut';\nimport { ArrowChevronLeftIcon, ArrowLeftIcon } from '@codecademy/gamut-icons';\nimport { css, states, theme } from '@codecademy/gamut-styles';\nimport styled from '@emotion/styled';\nimport { useContext, useEffect, useRef } from 'react';\nimport * as React from 'react';\n\nimport { AppHeaderCatalogDropdownProps } from '../../AppHeader/AppHeaderElements/AppHeaderCatalogDropdown';\nimport { CATALOG_NAV_SECTIONS } from '../../AppHeader/AppHeaderElements/AppHeaderCatalogDropdown/consts';\nimport { MarketingBanner } from '../../AppHeader/AppHeaderElements/AppHeaderCatalogDropdown/MarketingBanner';\nimport { AppHeaderCatalogSection } from '../../AppHeader/AppHeaderElements/AppHeaderCatalogSection';\nimport { AppHeaderDropdownProps } from '../../AppHeader/AppHeaderElements/AppHeaderDropdown';\nimport { AppHeaderLinkSections } from '../../AppHeader/AppHeaderElements/AppHeaderLinkSections';\nimport { AppHeaderListItem } from '../../AppHeader/AppHeaderElements/AppHeaderListItem';\nimport { AppHeaderResourceDropdownProps } from '../../AppHeader/AppHeaderElements/AppHeaderResourcesDropdown';\nimport { RESOURCES_NAV_SECTIONS } from '../../AppHeader/AppHeaderElements/AppHeaderResourcesDropdown/consts';\nimport { AppHeaderResourcesSection } from '../../AppHeader/AppHeaderElements/AppHeaderResourcesSection';\nimport { AppHeaderSection } from '../../AppHeader/AppHeaderElements/AppHeaderSection';\nimport {\n  AppHeaderCatalogDropdownItem,\n  AppHeaderClickHandler,\n  AppHeaderDropdownItem,\n  AppHeaderResourcesDropdownItem,\n} from '../../AppHeader/shared';\nimport { GlobalNavRedesignContext } from '../../GlobalHeader';\nimport { getHeaderResourcesList } from '../../lib/resourcesList';\nimport { MobileSubMenuWrapper, MobileUlWrapper } from './elements';\n\nexport type AppHeaderSubMenuMobileProps = (\n  | AppHeaderDropdownProps\n  | AppHeaderCatalogDropdownProps\n  | AppHeaderResourceDropdownProps\n) & {\n  handleCloseSubMenu: () => void;\n  handleCloseMainMenu: () => void;\n};\n\ntype AppHeaderSectionItem =\n  | AppHeaderDropdownItem\n  | AppHeaderCatalogDropdownItem\n  | AppHeaderResourcesDropdownItem;\n\nconst StyledAnchor = styled(Anchor)(\n  css({\n    alignItems: `center`,\n    display: `flex`,\n    my: 24,\n    padding: 0,\n    width: 'calc(100% - 64px)',\n  })\n);\n\nconst StyledStandardRedesignAnchor = styled(Anchor)(\n  css({\n    alignItems: `center`,\n    display: `flex`,\n    width: 'calc(100% - 64px)',\n    py: 8,\n    mt: 0,\n    mb: 16,\n  })\n);\n\nconst BackgroundWrapper = styled(Box)<{\n  showStandardRedesign: boolean;\n}>(\n  states({\n    showStandardRedesign: {\n      background: theme.colors.white,\n      border: 1,\n      borderColor: 'border-tertiary',\n      borderRadius: 'lg',\n      padding: '16px',\n      mx: 16,\n    },\n  })\n);\n\nconst renderHeaderSection = (\n  item: AppHeaderSectionItem,\n  action: AppHeaderClickHandler,\n  handleCloseMainMenu: () => void,\n  displayGlobalNavRedesign: boolean,\n  handleCloseSubMenu: () => void\n) => {\n  switch (item.type) {\n    case 'catalog-dropdown':\n      return displayGlobalNavRedesign ? (\n        <AppHeaderSection\n          navSections={CATALOG_NAV_SECTIONS}\n          MarketingBanner={MarketingBanner}\n          isMobile\n          handleClose={handleCloseSubMenu}\n          type=\"catalog-dropdown\"\n        />\n      ) : (\n        <AppHeaderCatalogSection\n          action={action}\n          item={item}\n          handleClose={handleCloseMainMenu}\n        />\n      );\n    case 'resources-dropdown':\n      return displayGlobalNavRedesign ? (\n        <AppHeaderSection\n          navSections={RESOURCES_NAV_SECTIONS}\n          isMobile\n          handleClose={handleCloseSubMenu}\n          type=\"resources-dropdown\"\n        />\n      ) : (\n        <AppHeaderResourcesSection\n          action={action}\n          handleClose={handleCloseMainMenu}\n          resources={getHeaderResourcesList()}\n        />\n      );\n    default:\n      return <AppHeaderLinkSections action={action} item={item} mobile />;\n  }\n};\n\nexport const AppHeaderSubNavMobile: React.FC<AppHeaderSubMenuMobileProps> = ({\n  action,\n  handleCloseSubMenu,\n  handleCloseMainMenu,\n  item,\n}) => {\n  const mainUlWrapper = useRef<HTMLUListElement>(null);\n\n  useEffect(() => {\n    if (mainUlWrapper?.current) {\n      mainUlWrapper.current.focus();\n    }\n  }, []);\n\n  const isProfileMenu = item.type === 'profile-dropdown';\n  const displayGlobalNavRedesign = useContext(GlobalNavRedesignContext);\n\n  const isCatalogOrResourcesMenu =\n    item.type === 'catalog-dropdown' || item.type === 'resources-dropdown';\n\n  const showLegacyDesign = !displayGlobalNavRedesign;\n  const showCatalogOrResourceRedesign =\n    displayGlobalNavRedesign && isCatalogOrResourcesMenu; // for redesigned catalog or resources menus\n  const showStandardRedesign =\n    displayGlobalNavRedesign && !isCatalogOrResourcesMenu; // for all other redesigned menus\n\n  const renderBackButton = () => {\n    if (showLegacyDesign) {\n      return (\n        <AppHeaderListItem>\n          <StyledAnchor\n            onClick={handleCloseSubMenu}\n            variant=\"interface\"\n            as=\"button\"\n            ml={{ _: 16, xs: 32, sm: 64, md: 48 }}\n          >\n            <ArrowChevronLeftIcon size={12} aria-hidden />\n            <Text fontSize={16} pl={8}>\n              Back to main navigation\n            </Text>\n          </StyledAnchor>\n        </AppHeaderListItem>\n      );\n    }\n    if (showStandardRedesign) {\n      return (\n        <AppHeaderListItem>\n          <StyledStandardRedesignAnchor\n            onClick={handleCloseSubMenu}\n            variant=\"interface\"\n            as=\"button\"\n          >\n            <ArrowLeftIcon size={24} aria-hidden />\n            <Text pl={8}>Back</Text>\n          </StyledStandardRedesignAnchor>\n        </AppHeaderListItem>\n      );\n    }\n    return null;\n  };\n\n  return (\n    <BackgroundWrapper showStandardRedesign={showStandardRedesign}>\n      <MobileUlWrapper ref={mainUlWrapper} tabIndex={-1}>\n        {renderBackButton()}\n        <MobileSubMenuWrapper\n          handleClose={handleCloseSubMenu}\n          isMenuRole={isProfileMenu}\n        >\n          {!showCatalogOrResourceRedesign && (\n            <Text\n              as=\"h1\"\n              fontSize={showLegacyDesign ? 22 : 20}\n              mb={16}\n              ml={showLegacyDesign ? { _: 16, xs: 32, sm: 64, md: 48 } : 0}\n            >\n              {isProfileMenu ? item.userDisplayName : item.text}\n            </Text>\n          )}\n          <Menu\n            variant=\"fixed\"\n            mx={showCatalogOrResourceRedesign ? { _: 16, sm: 32 } : 0}\n            width={displayGlobalNavRedesign ? 'auto' : 'calc(100% - 16px)'}\n            bg={displayGlobalNavRedesign ? 'transparent' : 'white'}\n          >\n            {renderHeaderSection(\n              item,\n              action,\n              handleCloseMainMenu,\n              displayGlobalNavRedesign,\n              handleCloseSubMenu\n            )}\n          </Menu>\n        </MobileSubMenuWrapper>\n      </MobileUlWrapper>\n    </BackgroundWrapper>\n  );\n};\n"]} */");
52
+ }), process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../../src/AppHeaderMobile/AppHeaderSubMenuMobile/index.tsx"],"names":[],"mappings":"AA+D0B","file":"../../../src/AppHeaderMobile/AppHeaderSubMenuMobile/index.tsx","sourcesContent":["import { Anchor, Box, Menu, Text } from '@codecademy/gamut';\nimport { ArrowChevronLeftIcon, ArrowLeftIcon } from '@codecademy/gamut-icons';\nimport { css, states, theme, useCurrentMode } from '@codecademy/gamut-styles';\nimport styled from '@emotion/styled';\nimport { useContext, useEffect, useRef } from 'react';\nimport * as React from 'react';\n\nimport { AppHeaderCatalogDropdownProps } from '../../AppHeader/AppHeaderElements/AppHeaderCatalogDropdown';\nimport { CATALOG_NAV_SECTIONS } from '../../AppHeader/AppHeaderElements/AppHeaderCatalogDropdown/consts';\nimport { MarketingBanner } from '../../AppHeader/AppHeaderElements/AppHeaderCatalogDropdown/MarketingBanner';\nimport { AppHeaderCatalogSection } from '../../AppHeader/AppHeaderElements/AppHeaderCatalogSection';\nimport { AppHeaderDropdownProps } from '../../AppHeader/AppHeaderElements/AppHeaderDropdown';\nimport { AppHeaderLinkSections } from '../../AppHeader/AppHeaderElements/AppHeaderLinkSections';\nimport { AppHeaderListItem } from '../../AppHeader/AppHeaderElements/AppHeaderListItem';\nimport { AppHeaderResourceDropdownProps } from '../../AppHeader/AppHeaderElements/AppHeaderResourcesDropdown';\nimport { RESOURCES_NAV_SECTIONS } from '../../AppHeader/AppHeaderElements/AppHeaderResourcesDropdown/consts';\nimport { AppHeaderResourcesSection } from '../../AppHeader/AppHeaderElements/AppHeaderResourcesSection';\nimport { AppHeaderSection } from '../../AppHeader/AppHeaderElements/AppHeaderSection';\nimport {\n  AppHeaderCatalogDropdownItem,\n  AppHeaderClickHandler,\n  AppHeaderDropdownItem,\n  AppHeaderResourcesDropdownItem,\n} from '../../AppHeader/shared';\nimport { GlobalNavRedesignContext } from '../../GlobalHeader';\nimport { getHeaderResourcesList } from '../../lib/resourcesList';\nimport { MobileSubMenuWrapper, MobileUlWrapper } from './elements';\n\nexport type AppHeaderSubMenuMobileProps = (\n  | AppHeaderDropdownProps\n  | AppHeaderCatalogDropdownProps\n  | AppHeaderResourceDropdownProps\n) & {\n  handleCloseSubMenu: () => void;\n  handleCloseMainMenu: () => void;\n};\n\ntype AppHeaderSectionItem =\n  | AppHeaderDropdownItem\n  | AppHeaderCatalogDropdownItem\n  | AppHeaderResourcesDropdownItem;\n\nconst StyledAnchor = styled(Anchor)(\n  css({\n    alignItems: `center`,\n    display: `flex`,\n    my: 24,\n    padding: 0,\n    width: 'calc(100% - 64px)',\n  })\n);\n\nconst StyledStandardRedesignAnchor = styled(Anchor)(\n  css({\n    alignItems: `center`,\n    display: `flex`,\n    width: 'calc(100% - 64px)',\n    py: 8,\n    mt: 0,\n    mb: 16,\n  })\n);\n\nconst BackgroundWrapper = styled(Box)<{\n  showStandardRedesign: boolean;\n}>(\n  states({\n    showStandardRedesign: {\n      background: theme.colors.white,\n      border: 1,\n      borderColor: 'border-tertiary',\n      borderRadius: 'lg',\n      padding: '16px',\n      mx: 16,\n    },\n  })\n);\n\nconst renderHeaderSection = (\n  item: AppHeaderSectionItem,\n  action: AppHeaderClickHandler,\n  handleCloseMainMenu: () => void,\n  displayGlobalNavRedesign: boolean,\n  handleCloseSubMenu: () => void\n) => {\n  switch (item.type) {\n    case 'catalog-dropdown':\n      return displayGlobalNavRedesign ? (\n        <AppHeaderSection\n          navSections={CATALOG_NAV_SECTIONS}\n          MarketingBanner={MarketingBanner}\n          isMobile\n          handleClose={handleCloseSubMenu}\n          type=\"catalog-dropdown\"\n        />\n      ) : (\n        <AppHeaderCatalogSection\n          action={action}\n          item={item}\n          handleClose={handleCloseMainMenu}\n        />\n      );\n    case 'resources-dropdown':\n      return displayGlobalNavRedesign ? (\n        <AppHeaderSection\n          navSections={RESOURCES_NAV_SECTIONS}\n          isMobile\n          handleClose={handleCloseSubMenu}\n          type=\"resources-dropdown\"\n        />\n      ) : (\n        <AppHeaderResourcesSection\n          action={action}\n          handleClose={handleCloseMainMenu}\n          resources={getHeaderResourcesList()}\n        />\n      );\n    default:\n      return <AppHeaderLinkSections action={action} item={item} mobile />;\n  }\n};\n\nexport const AppHeaderSubNavMobile: React.FC<AppHeaderSubMenuMobileProps> = ({\n  action,\n  handleCloseSubMenu,\n  handleCloseMainMenu,\n  item,\n}) => {\n  const mainUlWrapper = useRef<HTMLUListElement>(null);\n\n  useEffect(() => {\n    if (mainUlWrapper?.current) {\n      mainUlWrapper.current.focus();\n    }\n  }, []);\n\n  const isProfileMenu = item.type === 'profile-dropdown';\n  const displayGlobalNavRedesign = useContext(GlobalNavRedesignContext);\n\n  const isCatalogOrResourcesMenu =\n    item.type === 'catalog-dropdown' || item.type === 'resources-dropdown';\n\n  const showLegacyDesign = !displayGlobalNavRedesign;\n  const showCatalogOrResourceRedesign =\n    displayGlobalNavRedesign && isCatalogOrResourcesMenu; // for redesigned catalog or resources menus\n  const showStandardRedesign =\n    displayGlobalNavRedesign && !isCatalogOrResourcesMenu; // for all other redesigned menus\n\n  const renderBackButton = () => {\n    if (showLegacyDesign) {\n      return (\n        <AppHeaderListItem>\n          <StyledAnchor\n            onClick={handleCloseSubMenu}\n            variant=\"interface\"\n            as=\"button\"\n            ml={{ _: 16, xs: 32, sm: 64, md: 48 }}\n          >\n            <ArrowChevronLeftIcon size={12} aria-hidden />\n            <Text fontSize={16} pl={8}>\n              Back to main navigation\n            </Text>\n          </StyledAnchor>\n        </AppHeaderListItem>\n      );\n    }\n    if (showStandardRedesign) {\n      return (\n        <AppHeaderListItem>\n          <StyledStandardRedesignAnchor\n            onClick={handleCloseSubMenu}\n            variant=\"interface\"\n            as=\"button\"\n          >\n            <ArrowLeftIcon size={24} aria-hidden />\n            <Text pl={8}>Back</Text>\n          </StyledStandardRedesignAnchor>\n        </AppHeaderListItem>\n      );\n    }\n    return null;\n  };\n\n  const colorMode = useCurrentMode();\n  return (\n    <BackgroundWrapper showStandardRedesign={showStandardRedesign}>\n      <MobileUlWrapper ref={mainUlWrapper} tabIndex={-1}>\n        {renderBackButton()}\n        <MobileSubMenuWrapper\n          handleClose={handleCloseSubMenu}\n          isMenuRole={isProfileMenu}\n        >\n          {!showCatalogOrResourceRedesign && (\n            <Text\n              as=\"h1\"\n              fontSize={showLegacyDesign ? 22 : 20}\n              mb={16}\n              ml={showLegacyDesign ? { _: 16, xs: 32, sm: 64, md: 48 } : 0}\n            >\n              {isProfileMenu ? item.userDisplayName : item.text}\n            </Text>\n          )}\n          <Menu\n            variant=\"fixed\"\n            mx={showCatalogOrResourceRedesign ? { _: 16, sm: 32 } : 0}\n            width={displayGlobalNavRedesign ? 'auto' : 'calc(100% - 16px)'}\n            bg={\n              displayGlobalNavRedesign\n                ? 'transparent'\n                : colorMode === 'dark'\n                ? 'navy-800'\n                : 'white'\n            }\n          >\n            {renderHeaderSection(\n              item,\n              action,\n              handleCloseMainMenu,\n              displayGlobalNavRedesign,\n              handleCloseSubMenu\n            )}\n          </Menu>\n        </MobileSubMenuWrapper>\n      </MobileUlWrapper>\n    </BackgroundWrapper>\n  );\n};\n"]} */");
53
53
  const renderHeaderSection = (item, action, handleCloseMainMenu, displayGlobalNavRedesign, handleCloseSubMenu) => {
54
54
  switch (item.type) {
55
55
  case 'catalog-dropdown':
@@ -144,6 +144,7 @@ export const AppHeaderSubNavMobile = ({
144
144
  }
145
145
  return null;
146
146
  };
147
+ const colorMode = useCurrentMode();
147
148
  return /*#__PURE__*/_jsx(BackgroundWrapper, {
148
149
  showStandardRedesign: showStandardRedesign,
149
150
  children: /*#__PURE__*/_jsxs(MobileUlWrapper, {
@@ -170,7 +171,7 @@ export const AppHeaderSubNavMobile = ({
170
171
  sm: 32
171
172
  } : 0,
172
173
  width: displayGlobalNavRedesign ? 'auto' : 'calc(100% - 16px)',
173
- bg: displayGlobalNavRedesign ? 'transparent' : 'white',
174
+ bg: displayGlobalNavRedesign ? 'transparent' : colorMode === 'dark' ? 'navy-800' : 'white',
174
175
  children: renderHeaderSection(item, action, handleCloseMainMenu, displayGlobalNavRedesign, handleCloseSubMenu)
175
176
  })]
176
177
  })]
@@ -1,28 +1,83 @@
1
- import { AppHeaderItem, FormattedAppHeaderItems, FormattedMobileAppHeaderItems } from '../AppHeader/shared';
1
+ import { FormattedAppHeaderItems, FormattedMobileAppHeaderItems } from '../AppHeader/shared';
2
2
  import { GlobalHeaderProps } from '.';
3
3
  import { User } from './types';
4
- export declare const anonDefaultHeaderItems: (hidePricing?: boolean, user?: User, isBlpHeroExperimentVariant?: boolean, isInRevampedBlpExperimentVariant?: boolean) => FormattedAppHeaderItems;
5
- export declare const anonDefaultMobileHeaderItems: (hidePricing?: boolean, user?: User, isBlpHeroExperimentVariant?: boolean, isInRevampedBlpExperimentVariant?: boolean) => FormattedMobileAppHeaderItems;
6
- export declare const anonLandingHeaderItems: (hidePricing?: boolean, user?: User, isInRevampedBlpExperimentVariant?: boolean) => FormattedAppHeaderItems;
7
- export declare const anonLandingMobileHeaderItems: (hidePricing?: boolean, user?: User, isInRevampedBlpExperimentVariant?: boolean) => FormattedMobileAppHeaderItems;
8
- export declare const anonLoginHeaderItems: (hidePricing?: boolean, user?: User, isInRevampedBlpExperimentVariant?: boolean) => FormattedAppHeaderItems;
9
- export declare const anonLoginMobileHeaderItems: (hidePricing?: boolean, user?: User, isInRevampedBlpExperimentVariant?: boolean) => FormattedMobileAppHeaderItems;
10
- export declare const anonSignupHeaderItems: (hidePricing?: boolean, user?: User, isInRevampedBlpExperimentVariant?: boolean) => FormattedAppHeaderItems;
11
- export declare const anonSignupMobileHeaderItems: (hidePricing?: boolean, user?: User, isInRevampedBlpExperimentVariant?: boolean) => FormattedMobileAppHeaderItems;
12
- export declare const freeHeaderItems: (user: User, hidePricing?: boolean, isInRevampedBlpExperimentVariant?: boolean) => FormattedAppHeaderItems;
13
- export declare const freeMobileHeaderItems: (user: User, hidePricing?: boolean, isInRevampedBlpExperimentVariant?: boolean) => FormattedMobileAppHeaderItems;
14
- export declare const enterpriseHeaderItems: (user: User, props: GlobalHeaderProps) => {
15
- left: AppHeaderItem[];
16
- right: never[];
17
- };
18
- export declare const proHeaderItems: (user: User) => FormattedAppHeaderItems;
19
- export declare const teamsHeaderItems: (user: User) => FormattedAppHeaderItems;
20
- export declare const enterpriseMobileHeaderItems: (user: User, props: GlobalHeaderProps) => FormattedMobileAppHeaderItems;
21
- export declare const proMobileHeaderItems: (user: User) => FormattedMobileAppHeaderItems;
22
- export declare const teamsMobileHeaderItems: (user: User) => FormattedMobileAppHeaderItems;
4
+ export declare const anonDefaultHeaderItems: ({ hidePricing, user, isInRevampedBlpExperimentVariant, }: {
5
+ hidePricing?: boolean;
6
+ user?: User;
7
+ isInRevampedBlpExperimentVariant?: boolean;
8
+ }) => FormattedAppHeaderItems;
9
+ export declare const anonDefaultMobileHeaderItems: ({ hidePricing, user, isInRevampedBlpExperimentVariant, }: {
10
+ hidePricing?: boolean;
11
+ user?: User;
12
+ isInRevampedBlpExperimentVariant?: boolean;
13
+ }) => FormattedMobileAppHeaderItems;
14
+ export declare const anonLandingHeaderItems: ({ hidePricing, user, isInRevampedBlpExperimentVariant, }: {
15
+ hidePricing?: boolean;
16
+ user?: User;
17
+ isInRevampedBlpExperimentVariant?: boolean;
18
+ }) => FormattedAppHeaderItems;
19
+ export declare const anonLandingMobileHeaderItems: ({ hidePricing, user, isInRevampedBlpExperimentVariant, }: {
20
+ hidePricing?: boolean;
21
+ user?: User;
22
+ isInRevampedBlpExperimentVariant?: boolean;
23
+ }) => FormattedMobileAppHeaderItems;
24
+ export declare const anonLoginHeaderItems: ({ hidePricing, user, isInRevampedBlpExperimentVariant, }: {
25
+ hidePricing?: boolean;
26
+ user?: User;
27
+ isInRevampedBlpExperimentVariant?: boolean;
28
+ }) => FormattedAppHeaderItems;
29
+ export declare const anonLoginMobileHeaderItems: ({ hidePricing, user, isInRevampedBlpExperimentVariant, }: {
30
+ hidePricing?: boolean;
31
+ user?: User;
32
+ isInRevampedBlpExperimentVariant?: boolean;
33
+ }) => FormattedMobileAppHeaderItems;
34
+ export declare const anonSignupHeaderItems: ({ hidePricing, user, isInRevampedBlpExperimentVariant, }: {
35
+ hidePricing?: boolean;
36
+ user?: User;
37
+ isInRevampedBlpExperimentVariant?: boolean;
38
+ }) => FormattedAppHeaderItems;
39
+ export declare const anonSignupMobileHeaderItems: ({ hidePricing, user, isInRevampedBlpExperimentVariant, }: {
40
+ hidePricing?: boolean;
41
+ user?: User;
42
+ isInRevampedBlpExperimentVariant?: boolean;
43
+ }) => FormattedMobileAppHeaderItems;
44
+ export declare const freeHeaderItems: ({ user, hidePricing, isInRevampedBlpExperimentVariant, }: {
45
+ user: User;
46
+ hidePricing?: boolean;
47
+ isInRevampedBlpExperimentVariant?: boolean;
48
+ }) => FormattedAppHeaderItems;
49
+ export declare const freeMobileHeaderItems: ({ user, hidePricing, isInRevampedBlpExperimentVariant, }: {
50
+ user: User;
51
+ hidePricing?: boolean;
52
+ isInRevampedBlpExperimentVariant?: boolean;
53
+ }) => FormattedMobileAppHeaderItems;
54
+ export declare const enterpriseHeaderItems: ({ user, props, }: {
55
+ user: User;
56
+ props: GlobalHeaderProps;
57
+ }) => FormattedAppHeaderItems;
58
+ export declare const proHeaderItems: ({ user, }: {
59
+ user: User;
60
+ }) => FormattedAppHeaderItems;
61
+ export declare const teamsHeaderItems: ({ user, }: {
62
+ user: User;
63
+ }) => FormattedAppHeaderItems;
64
+ export declare const enterpriseMobileHeaderItems: ({ user, props, }: {
65
+ user: User;
66
+ props: GlobalHeaderProps;
67
+ }) => FormattedMobileAppHeaderItems;
68
+ export declare const proMobileHeaderItems: ({ user, }: {
69
+ user: User;
70
+ }) => FormattedMobileAppHeaderItems;
71
+ export declare const teamsMobileHeaderItems: ({ user, }: {
72
+ user: User;
73
+ }) => FormattedMobileAppHeaderItems;
23
74
  export declare const loadingHeaderItems: FormattedAppHeaderItems;
24
75
  export declare const loadingMobileHeaderItems: FormattedMobileAppHeaderItems;
25
76
  export declare const simpleHeaderItems: FormattedAppHeaderItems;
26
77
  export declare const simpleMobileHeaderItems: FormattedMobileAppHeaderItems;
27
- export declare const simpleBootcampHeaderItems: (bootcampSlug: string) => FormattedAppHeaderItems;
28
- export declare const simpleBootcampMobileHeaderItems: (bootcampSlug: string) => FormattedMobileAppHeaderItems;
78
+ export declare const simpleBootcampHeaderItems: ({ bootcampSlug, }: {
79
+ bootcampSlug: string;
80
+ }) => FormattedAppHeaderItems;
81
+ export declare const simpleBootcampMobileHeaderItems: ({ bootcampSlug, }: {
82
+ bootcampSlug: string;
83
+ }) => FormattedMobileAppHeaderItems;
@@ -1,7 +1,7 @@
1
1
  import { addPayment, bootcampCta, businessSolutions, catalogDropdown, communityDropdown, enterpriseLogo, freeProfile, liveLearningHub, loading, login, logo, myHome, myPercipioHome, pricingDropdown, proProfile, requestTeamsDemo, resourcesDropdown, signUp, signUpTextButton, simpleResourcesDropdown, tryProForFree, unpausePro, upgradePlan, upgradeToPro } from './GlobalHeaderItems';
2
- const isBusinessPage = isBlpHeroExperimentVariant => {
2
+ const isBusinessPage = () => {
3
3
  if (typeof window === 'undefined') return false;
4
- return (window.location.pathname === '/business' || window.location.pathname === '/business/pricing') && Boolean(isBlpHeroExperimentVariant);
4
+ return window.location.pathname === '/business' || window.location.pathname === '/business/pricing';
5
5
  };
6
6
  const transformSimpleResourcesDropdownlabels = resourcesLabel => ({
7
7
  ...simpleResourcesDropdown,
@@ -11,14 +11,20 @@ const transformSimpleResourcesDropdownlabels = resourcesLabel => ({
11
11
  text: resourcesLabel?.[item.id] || item.text
12
12
  }))
13
13
  });
14
- const anonHeaderItems = (renderLogin, renderSignUp, hidePricing, user, isBlpHeroExperimentVariant, isInRevampedBlpExperimentVariant) => {
14
+ const anonHeaderItems = ({
15
+ renderLogin,
16
+ renderSignUp,
17
+ hidePricing,
18
+ user,
19
+ isInRevampedBlpExperimentVariant
20
+ }) => {
15
21
  const specialLogo = {
16
22
  ...logo,
17
23
  checkMini: true
18
24
  };
19
25
  const leftItems = [specialLogo, catalogDropdown(user?.hideCareerPaths), resourcesDropdown(), communityDropdown(), ...(hidePricing ? [] : [pricingDropdown(isInRevampedBlpExperimentVariant)]), liveLearningHub, businessSolutions];
20
26
  const rightItems = [];
21
- if (isBusinessPage(isBlpHeroExperimentVariant)) {
27
+ if (isBusinessPage()) {
22
28
  if (renderSignUp) {
23
29
  rightItems.push(signUpTextButton);
24
30
  }
@@ -38,14 +44,20 @@ const anonHeaderItems = (renderLogin, renderSignUp, hidePricing, user, isBlpHero
38
44
  right: rightItems
39
45
  };
40
46
  };
41
- const anonMobileHeaderItems = (renderLogin, renderSignUp, hidePricing, user, isBlpHeroExperimentVariant, isInRevampedBlpExperimentVariant) => {
47
+ const anonMobileHeaderItems = ({
48
+ renderLogin,
49
+ renderSignUp,
50
+ hidePricing,
51
+ user,
52
+ isInRevampedBlpExperimentVariant
53
+ }) => {
42
54
  const specialLogo = {
43
55
  ...logo,
44
56
  checkMini: true
45
57
  };
46
58
  const leftItems = [specialLogo];
47
59
  const rightItems = [];
48
- if (isBusinessPage(isBlpHeroExperimentVariant)) {
60
+ if (isBusinessPage()) {
49
61
  if (renderSignUp) {
50
62
  rightItems.push(signUpTextButton);
51
63
  }
@@ -67,31 +79,115 @@ const anonMobileHeaderItems = (renderLogin, renderSignUp, hidePricing, user, isB
67
79
  mainMenu: mainMenuItems
68
80
  };
69
81
  };
70
- export const anonDefaultHeaderItems = (hidePricing, user, isBlpHeroExperimentVariant, isInRevampedBlpExperimentVariant) => {
71
- return anonHeaderItems(true, true, hidePricing, user, isBlpHeroExperimentVariant, isInRevampedBlpExperimentVariant);
82
+ export const anonDefaultHeaderItems = ({
83
+ hidePricing,
84
+ user,
85
+ isInRevampedBlpExperimentVariant
86
+ }) => {
87
+ return anonHeaderItems({
88
+ renderLogin: true,
89
+ renderSignUp: true,
90
+ hidePricing,
91
+ user,
92
+ isInRevampedBlpExperimentVariant
93
+ });
72
94
  };
73
- export const anonDefaultMobileHeaderItems = (hidePricing, user, isBlpHeroExperimentVariant, isInRevampedBlpExperimentVariant) => {
74
- return anonMobileHeaderItems(true, true, hidePricing, user, isBlpHeroExperimentVariant, isInRevampedBlpExperimentVariant);
95
+ export const anonDefaultMobileHeaderItems = ({
96
+ hidePricing,
97
+ user,
98
+ isInRevampedBlpExperimentVariant
99
+ }) => {
100
+ return anonMobileHeaderItems({
101
+ renderLogin: true,
102
+ renderSignUp: true,
103
+ hidePricing,
104
+ user,
105
+ isInRevampedBlpExperimentVariant
106
+ });
75
107
  };
76
- export const anonLandingHeaderItems = (hidePricing, user, isInRevampedBlpExperimentVariant) => {
77
- return anonHeaderItems(true, false, hidePricing, user, false, isInRevampedBlpExperimentVariant);
108
+ export const anonLandingHeaderItems = ({
109
+ hidePricing,
110
+ user,
111
+ isInRevampedBlpExperimentVariant
112
+ }) => {
113
+ return anonHeaderItems({
114
+ renderLogin: true,
115
+ renderSignUp: false,
116
+ hidePricing,
117
+ user,
118
+ isInRevampedBlpExperimentVariant
119
+ });
78
120
  };
79
- export const anonLandingMobileHeaderItems = (hidePricing, user, isInRevampedBlpExperimentVariant) => {
80
- return anonMobileHeaderItems(true, false, hidePricing, user, false, isInRevampedBlpExperimentVariant);
121
+ export const anonLandingMobileHeaderItems = ({
122
+ hidePricing,
123
+ user,
124
+ isInRevampedBlpExperimentVariant
125
+ }) => {
126
+ return anonMobileHeaderItems({
127
+ renderLogin: true,
128
+ renderSignUp: false,
129
+ hidePricing,
130
+ user,
131
+ isInRevampedBlpExperimentVariant
132
+ });
81
133
  };
82
- export const anonLoginHeaderItems = (hidePricing, user, isInRevampedBlpExperimentVariant) => {
83
- return anonHeaderItems(false, true, hidePricing, user, false, isInRevampedBlpExperimentVariant);
134
+ export const anonLoginHeaderItems = ({
135
+ hidePricing,
136
+ user,
137
+ isInRevampedBlpExperimentVariant
138
+ }) => {
139
+ return anonHeaderItems({
140
+ renderLogin: false,
141
+ renderSignUp: true,
142
+ hidePricing,
143
+ user,
144
+ isInRevampedBlpExperimentVariant
145
+ });
84
146
  };
85
- export const anonLoginMobileHeaderItems = (hidePricing, user, isInRevampedBlpExperimentVariant) => {
86
- return anonMobileHeaderItems(false, true, hidePricing, user, false, isInRevampedBlpExperimentVariant);
147
+ export const anonLoginMobileHeaderItems = ({
148
+ hidePricing,
149
+ user,
150
+ isInRevampedBlpExperimentVariant
151
+ }) => {
152
+ return anonMobileHeaderItems({
153
+ renderLogin: false,
154
+ renderSignUp: true,
155
+ hidePricing,
156
+ user,
157
+ isInRevampedBlpExperimentVariant
158
+ });
87
159
  };
88
- export const anonSignupHeaderItems = (hidePricing, user, isInRevampedBlpExperimentVariant) => {
89
- return anonHeaderItems(true, false, hidePricing, user, false, isInRevampedBlpExperimentVariant);
160
+ export const anonSignupHeaderItems = ({
161
+ hidePricing,
162
+ user,
163
+ isInRevampedBlpExperimentVariant
164
+ }) => {
165
+ return anonHeaderItems({
166
+ renderLogin: true,
167
+ renderSignUp: false,
168
+ hidePricing,
169
+ user,
170
+ isInRevampedBlpExperimentVariant
171
+ });
90
172
  };
91
- export const anonSignupMobileHeaderItems = (hidePricing, user, isInRevampedBlpExperimentVariant) => {
92
- return anonMobileHeaderItems(true, false, hidePricing, user, false, isInRevampedBlpExperimentVariant);
173
+ export const anonSignupMobileHeaderItems = ({
174
+ hidePricing,
175
+ user,
176
+ isInRevampedBlpExperimentVariant
177
+ }) => {
178
+ return anonMobileHeaderItems({
179
+ renderLogin: true,
180
+ renderSignUp: false,
181
+ hidePricing,
182
+ user,
183
+ isInRevampedBlpExperimentVariant
184
+ });
93
185
  };
94
- export const freeHeaderItems = (user, hidePricing, isInRevampedBlpExperimentVariant) => {
186
+ export const freeHeaderItems = ({
187
+ user,
188
+ hidePricing,
189
+ isInRevampedBlpExperimentVariant
190
+ }) => {
95
191
  const specialLogo = {
96
192
  ...logo,
97
193
  checkMini: true
@@ -106,7 +202,11 @@ export const freeHeaderItems = (user, hidePricing, isInRevampedBlpExperimentVari
106
202
  right: rightItems
107
203
  };
108
204
  };
109
- export const freeMobileHeaderItems = (user, hidePricing, isInRevampedBlpExperimentVariant) => {
205
+ export const freeMobileHeaderItems = ({
206
+ user,
207
+ hidePricing,
208
+ isInRevampedBlpExperimentVariant
209
+ }) => {
110
210
  const specialLogo = {
111
211
  ...logo,
112
212
  checkMini: true
@@ -121,7 +221,10 @@ export const freeMobileHeaderItems = (user, hidePricing, isInRevampedBlpExperime
121
221
  mainMenu: mainMenuItems
122
222
  };
123
223
  };
124
- export const enterpriseHeaderItems = (user, props) => {
224
+ export const enterpriseHeaderItems = ({
225
+ user,
226
+ props
227
+ }) => {
125
228
  const {
126
229
  hideHeaderLinksInChromeless,
127
230
  hideHeaderResourcesDropdown,
@@ -134,7 +237,9 @@ export const enterpriseHeaderItems = (user, props) => {
134
237
  right: []
135
238
  };
136
239
  };
137
- export const proHeaderItems = user => {
240
+ export const proHeaderItems = ({
241
+ user
242
+ }) => {
138
243
  const leftItems = [logo, myHome, catalogDropdown(user?.hideCareerPaths), resourcesDropdown(), communityDropdown(), ...(user.isPlusUser ? [upgradePlan] : []), liveLearningHub, businessSolutions];
139
244
  const rightItems = [];
140
245
  rightItems.push(proProfile(user));
@@ -146,7 +251,9 @@ export const proHeaderItems = user => {
146
251
  right: rightItems
147
252
  };
148
253
  };
149
- export const teamsHeaderItems = user => {
254
+ export const teamsHeaderItems = ({
255
+ user
256
+ }) => {
150
257
  const leftItems = [logo, myHome, catalogDropdown(user?.hideCareerPaths), resourcesDropdown(), communityDropdown(), liveLearningHub];
151
258
  const rightItems = [];
152
259
  if (user.isAccountManager && user.inBusinessTrial && !user.hasBusinessSubscription) {
@@ -158,7 +265,10 @@ export const teamsHeaderItems = user => {
158
265
  right: rightItems
159
266
  };
160
267
  };
161
- export const enterpriseMobileHeaderItems = (user, props) => {
268
+ export const enterpriseMobileHeaderItems = ({
269
+ user,
270
+ props
271
+ }) => {
162
272
  const {
163
273
  hideHeaderLinksInChromeless,
164
274
  hideHeaderResourcesDropdown,
@@ -174,7 +284,9 @@ export const enterpriseMobileHeaderItems = (user, props) => {
174
284
  mainMenu: mainMenuItems
175
285
  };
176
286
  };
177
- export const proMobileHeaderItems = user => {
287
+ export const proMobileHeaderItems = ({
288
+ user
289
+ }) => {
178
290
  const leftItems = [logo];
179
291
  const rightItems = [];
180
292
  const mainMenuItems = [myHome, catalogDropdown(user?.hideCareerPaths), resourcesDropdown(), communityDropdown(), ...(user.isPlusUser ? [upgradePlan] : []), liveLearningHub, businessSolutions, proProfile(user)];
@@ -187,7 +299,9 @@ export const proMobileHeaderItems = user => {
187
299
  mainMenu: mainMenuItems
188
300
  };
189
301
  };
190
- export const teamsMobileHeaderItems = user => {
302
+ export const teamsMobileHeaderItems = ({
303
+ user
304
+ }) => {
191
305
  const leftItems = [logo];
192
306
  const rightItems = [];
193
307
  const mainMenuItems = [myHome, catalogDropdown(user?.hideCareerPaths), resourcesDropdown(), communityDropdown(), liveLearningHub, proProfile(user)];
@@ -218,13 +332,17 @@ export const simpleMobileHeaderItems = {
218
332
  right: [],
219
333
  mainMenu: []
220
334
  };
221
- export const simpleBootcampHeaderItems = bootcampSlug => {
335
+ export const simpleBootcampHeaderItems = ({
336
+ bootcampSlug
337
+ }) => {
222
338
  return {
223
339
  left: [logo],
224
340
  right: [bootcampCta(bootcampSlug)]
225
341
  };
226
342
  };
227
- export const simpleBootcampMobileHeaderItems = bootcampSlug => {
343
+ export const simpleBootcampMobileHeaderItems = ({
344
+ bootcampSlug
345
+ }) => {
228
346
  return {
229
347
  left: [logo],
230
348
  right: [bootcampCta(bootcampSlug)],
@@ -3,7 +3,6 @@ import { AnonHeader, EnterpriseHeader, FreeHeader, LoadingHeader, ProHeader, Sim
3
3
  export * from './types';
4
4
  export declare const LiveLearningHubContext: React.Context<boolean>;
5
5
  export declare const GlobalNavRedesignContext: React.Context<boolean>;
6
- export declare const BlpHeroExperimentContext: React.Context<boolean>;
7
6
  export declare const RevampedBlpExperimentContext: React.Context<boolean>;
8
7
  export type GlobalHeaderProps = AnonHeader | FreeHeader | ProHeader | EnterpriseHeader | TeamsHeader | LoadingHeader | SimpleHeader | SimpleBootcampHeader;
9
8
  export declare const GlobalHeader: React.FC<GlobalHeaderProps>;
@@ -9,7 +9,6 @@ import { jsx as _jsx, jsxs as _jsxs } from "react/jsx-runtime";
9
9
  export * from './types';
10
10
  export const LiveLearningHubContext = /*#__PURE__*/React.createContext(false);
11
11
  export const GlobalNavRedesignContext = /*#__PURE__*/React.createContext(false);
12
- export const BlpHeroExperimentContext = /*#__PURE__*/React.createContext(false);
13
12
  export const RevampedBlpExperimentContext = /*#__PURE__*/React.createContext(false);
14
13
 
15
14
  // Overloading getAppHeaderItems function to return different types based on mobile parameter
@@ -25,26 +24,84 @@ function getAppHeaderItems(props, mobile, dynamicDataLoading) {
25
24
  case 'anon':
26
25
  switch (props.variant) {
27
26
  case 'landing':
28
- return mobile ? anonLandingMobileHeaderItems(hidePricing, props.user, props.isInRevampedBlpExperimentVariant) : anonLandingHeaderItems(hidePricing, props.user, props.isInRevampedBlpExperimentVariant);
27
+ return mobile ? anonLandingMobileHeaderItems({
28
+ hidePricing,
29
+ user: props.user,
30
+ isInRevampedBlpExperimentVariant: props.isInRevampedBlpExperimentVariant
31
+ }) : anonLandingHeaderItems({
32
+ hidePricing,
33
+ user: props.user,
34
+ isInRevampedBlpExperimentVariant: props.isInRevampedBlpExperimentVariant
35
+ });
29
36
  case 'login':
30
- return mobile ? anonLoginMobileHeaderItems(hidePricing, props.user, props.isInRevampedBlpExperimentVariant) : anonLoginHeaderItems(hidePricing, props.user, props.isInRevampedBlpExperimentVariant);
37
+ return mobile ? anonLoginMobileHeaderItems({
38
+ hidePricing,
39
+ user: props.user,
40
+ isInRevampedBlpExperimentVariant: props.isInRevampedBlpExperimentVariant
41
+ }) : anonLoginHeaderItems({
42
+ hidePricing,
43
+ user: props.user,
44
+ isInRevampedBlpExperimentVariant: props.isInRevampedBlpExperimentVariant
45
+ });
31
46
  case 'signup':
32
- return mobile ? anonSignupMobileHeaderItems(hidePricing, props.user, props.isInRevampedBlpExperimentVariant) : anonSignupHeaderItems(hidePricing, props.user, props.isInRevampedBlpExperimentVariant);
47
+ return mobile ? anonSignupMobileHeaderItems({
48
+ hidePricing,
49
+ user: props.user,
50
+ isInRevampedBlpExperimentVariant: props.isInRevampedBlpExperimentVariant
51
+ }) : anonSignupHeaderItems({
52
+ hidePricing,
53
+ user: props.user,
54
+ isInRevampedBlpExperimentVariant: props.isInRevampedBlpExperimentVariant
55
+ });
33
56
  default:
34
- return mobile ? anonDefaultMobileHeaderItems(hidePricing, props.user, props.isBlpHeroExperimentVariant, props.isInRevampedBlpExperimentVariant) : anonDefaultHeaderItems(hidePricing, props.user, props.isBlpHeroExperimentVariant, props.isInRevampedBlpExperimentVariant);
57
+ return mobile ? anonDefaultMobileHeaderItems({
58
+ hidePricing,
59
+ user: props.user,
60
+ isInRevampedBlpExperimentVariant: props.isInRevampedBlpExperimentVariant
61
+ }) : anonDefaultHeaderItems({
62
+ hidePricing,
63
+ user: props.user,
64
+ isInRevampedBlpExperimentVariant: props.isInRevampedBlpExperimentVariant
65
+ });
35
66
  }
36
67
  case 'enterprise':
37
- return mobile ? enterpriseMobileHeaderItems(props.user, props) : enterpriseHeaderItems(props.user, props);
68
+ return mobile ? enterpriseMobileHeaderItems({
69
+ user: props.user,
70
+ props
71
+ }) : enterpriseHeaderItems({
72
+ user: props.user,
73
+ props
74
+ });
38
75
  case 'free':
39
- return mobile ? freeMobileHeaderItems(props.user, hidePricing, props.isInRevampedBlpExperimentVariant) : freeHeaderItems(props.user, hidePricing, props.isInRevampedBlpExperimentVariant);
76
+ return mobile ? freeMobileHeaderItems({
77
+ user: props.user,
78
+ hidePricing,
79
+ isInRevampedBlpExperimentVariant: props.isInRevampedBlpExperimentVariant
80
+ }) : freeHeaderItems({
81
+ user: props.user,
82
+ hidePricing,
83
+ isInRevampedBlpExperimentVariant: props.isInRevampedBlpExperimentVariant
84
+ });
40
85
  case 'pro':
41
- return mobile ? proMobileHeaderItems(props.user) : proHeaderItems(props.user);
86
+ return mobile ? proMobileHeaderItems({
87
+ user: props.user
88
+ }) : proHeaderItems({
89
+ user: props.user
90
+ });
42
91
  case 'teams':
43
- return mobile ? teamsMobileHeaderItems(props.user) : teamsHeaderItems(props.user);
92
+ return mobile ? teamsMobileHeaderItems({
93
+ user: props.user
94
+ }) : teamsHeaderItems({
95
+ user: props.user
96
+ });
44
97
  case 'simple':
45
98
  return mobile ? simpleMobileHeaderItems : simpleHeaderItems;
46
99
  case 'bootcamp':
47
- return mobile ? simpleBootcampMobileHeaderItems(props.bootcampSlug) : simpleBootcampHeaderItems(props.bootcampSlug);
100
+ return mobile ? simpleBootcampMobileHeaderItems({
101
+ bootcampSlug: props.bootcampSlug
102
+ }) : simpleBootcampHeaderItems({
103
+ bootcampSlug: props.bootcampSlug
104
+ });
48
105
  case 'loading':
49
106
  return mobile ? loadingMobileHeaderItems : loadingHeaderItems;
50
107
  }
@@ -75,56 +132,53 @@ export const GlobalHeader = props => {
75
132
  },
76
133
  children: /*#__PURE__*/_jsx(GlobalNavRedesignContext.Provider, {
77
134
  value: !!props.displayGlobalNavRedesign,
78
- children: /*#__PURE__*/_jsx(BlpHeroExperimentContext.Provider, {
79
- value: !!props.isBlpHeroExperimentVariant,
80
- children: /*#__PURE__*/_jsx(RevampedBlpExperimentContext.Provider, {
81
- value: !!props.isInRevampedBlpExperimentVariant,
82
- children: /*#__PURE__*/_jsx(GlobalHeaderItemClickContext.Provider, {
83
- value: {
84
- globalHeaderItemClick: combinedAction
85
- },
86
- children: /*#__PURE__*/_jsx(GlobalHeaderDynamicDataContext.Provider, {
87
- value: useMemo(() => ({
88
- globalHeaderDynamicData: dynamicData ?? null
89
- }), [dynamicData]),
90
- children: /*#__PURE__*/_jsxs(Box, {
91
- as: "header",
92
- position: "sticky",
93
- top: 0,
94
- zIndex: theme.elements.headerZ,
95
- overflow: {
96
- _: 'hidden',
97
- sm: 'visible'
98
- } // Prevent tooltip overflow on mobile
99
- ,
100
- children: [/*#__PURE__*/_jsx(AppHeader, {
101
- action: combinedAction,
102
- items: getAppHeaderItems(props, false, dynamicDataLoading ?? false),
103
- search: props.search,
104
- ...(props.type === 'anon' ? {
105
- redirectParam: props.redirectParam
106
- } : hideNotification ? {} : {
107
- notifications: props.notifications
108
- }),
109
- hideRightButtonDefaults: hideNotification,
110
- isAnon: props.type === 'anon',
111
- isTeams: props.type === 'teams',
112
- type: hideNotification ? 'enterprise' : 'standard'
113
- }), /*#__PURE__*/_jsx(AppHeaderMobile, {
114
- action: combinedAction,
115
- items: getAppHeaderItems(props, true, dynamicDataLoading ?? false),
116
- ...(props.type === 'anon' || hideNotification ? {} : {
117
- notifications: props.notifications
118
- }),
119
- search: props.search,
120
- redirectParam: props.type === 'anon' ? props.redirectParam : undefined,
121
- isEnterprise: props.type === 'enterprise',
122
- isAnon: props.type === 'anon',
123
- isSimple: props.type === 'simple',
124
- hideRightMenuButton: props.type === 'simple' || props.type === 'loading',
125
- navigationMenuFormattedLabel: props?.localizedLabels?.navigationMenuFormattedLabel
126
- }), props.children]
127
- })
135
+ children: /*#__PURE__*/_jsx(RevampedBlpExperimentContext.Provider, {
136
+ value: !!props.isInRevampedBlpExperimentVariant,
137
+ children: /*#__PURE__*/_jsx(GlobalHeaderItemClickContext.Provider, {
138
+ value: {
139
+ globalHeaderItemClick: combinedAction
140
+ },
141
+ children: /*#__PURE__*/_jsx(GlobalHeaderDynamicDataContext.Provider, {
142
+ value: useMemo(() => ({
143
+ globalHeaderDynamicData: dynamicData ?? null
144
+ }), [dynamicData]),
145
+ children: /*#__PURE__*/_jsxs(Box, {
146
+ as: "header",
147
+ position: "sticky",
148
+ top: 0,
149
+ zIndex: theme.elements.headerZ,
150
+ overflow: {
151
+ _: 'hidden',
152
+ sm: 'visible'
153
+ } // Prevent tooltip overflow on mobile
154
+ ,
155
+ children: [/*#__PURE__*/_jsx(AppHeader, {
156
+ action: combinedAction,
157
+ items: getAppHeaderItems(props, false, dynamicDataLoading ?? false),
158
+ search: props.search,
159
+ ...(props.type === 'anon' ? {
160
+ redirectParam: props.redirectParam
161
+ } : hideNotification ? {} : {
162
+ notifications: props.notifications
163
+ }),
164
+ hideRightButtonDefaults: hideNotification,
165
+ isAnon: props.type === 'anon',
166
+ isTeams: props.type === 'teams',
167
+ type: hideNotification ? 'enterprise' : 'standard'
168
+ }), /*#__PURE__*/_jsx(AppHeaderMobile, {
169
+ action: combinedAction,
170
+ items: getAppHeaderItems(props, true, dynamicDataLoading ?? false),
171
+ ...(props.type === 'anon' || hideNotification ? {} : {
172
+ notifications: props.notifications
173
+ }),
174
+ search: props.search,
175
+ redirectParam: props.type === 'anon' ? props.redirectParam : undefined,
176
+ isEnterprise: props.type === 'enterprise',
177
+ isAnon: props.type === 'anon',
178
+ isSimple: props.type === 'simple',
179
+ hideRightMenuButton: props.type === 'simple' || props.type === 'loading',
180
+ navigationMenuFormattedLabel: props?.localizedLabels?.navigationMenuFormattedLabel
181
+ }), props.children]
128
182
  })
129
183
  })
130
184
  })
@@ -32,7 +32,6 @@ interface BaseHeader extends WithChildrenProp, AppHeaderAction {
32
32
  localizedLabels?: localizedLabels;
33
33
  search: AppHeaderSearch;
34
34
  displayGlobalNavRedesign?: boolean;
35
- isBlpHeroExperimentVariant?: boolean;
36
35
  isInRevampedBlpExperimentVariant?: boolean;
37
36
  dynamicData?: GlobalHeaderDynamicData | null;
38
37
  dynamicDataLoading?: boolean;
package/package.json CHANGED
@@ -1,7 +1,7 @@
1
1
  {
2
2
  "name": "@codecademy/brand",
3
3
  "description": "Brand component library for Codecademy",
4
- "version": "3.22.0",
4
+ "version": "3.23.0-alpha.36d073f3d1.0",
5
5
  "author": "Codecademy Engineering <dev@codecademy.com>",
6
6
  "dependencies": {
7
7
  "@emotion/is-prop-valid": "^1.2.1",