@codecademy/brand 3.24.0-alpha.c07ce0180c.0 → 3.25.0-alpha.55131b520a.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (25) hide show
  1. package/dist/AppHeader/AppHeaderElements/AppHeaderCatalogDropdown/index.d.ts +0 -1
  2. package/dist/AppHeader/AppHeaderElements/AppHeaderCatalogDropdown/index.js +10 -30
  3. package/dist/AppHeader/AppHeaderElements/AppHeaderDropdown/index.js +20 -36
  4. package/dist/AppHeader/AppHeaderElements/AppHeaderDropdownLinks/elements/AppHeaderDropdownLink.js +1 -4
  5. package/dist/AppHeader/AppHeaderElements/AppHeaderDropdownLinks/elements/AppHeaderMenuItem.js +1 -4
  6. package/dist/AppHeader/AppHeaderElements/AppHeaderDropdownLinks/elements/StyledAppHeaderLink.d.ts +1 -1
  7. package/dist/AppHeader/AppHeaderElements/AppHeaderDropdownLinks/elements/StyledAppHeaderLink.js +2 -4
  8. package/dist/AppHeader/AppHeaderElements/AppHeaderLinkSections/index.js +0 -0
  9. package/dist/AppHeader/AppHeaderElements/AppHeaderResourcesDropdown/index.d.ts +0 -1
  10. package/dist/AppHeader/AppHeaderElements/AppHeaderResourcesDropdown/index.js +10 -31
  11. package/dist/AppHeader/index.d.ts +0 -1
  12. package/dist/AppHeader/index.js +0 -2
  13. package/dist/AppHeader/shared/utils.d.ts +1 -2
  14. package/dist/AppHeader/shared/utils.js +2 -5
  15. package/dist/AppHeaderMobile/AppHeaderMainMenuMobile/index.d.ts +0 -1
  16. package/dist/AppHeaderMobile/AppHeaderMainMenuMobile/index.js +11 -18
  17. package/dist/AppHeaderMobile/AppHeaderSubMenuMobile/index.d.ts +0 -1
  18. package/dist/AppHeaderMobile/AppHeaderSubMenuMobile/index.js +19 -76
  19. package/dist/AppHeaderMobile/index.js +10 -38
  20. package/dist/GlobalHeader/index.d.ts +0 -1
  21. package/dist/GlobalHeader/index.js +46 -51
  22. package/dist/GlobalHeader/types.d.ts +0 -1
  23. package/dist/LayoutMenu/LayoutMenu.js +40 -20
  24. package/dist/LayoutMenu/LayoutMenuSection.js +5 -0
  25. package/package.json +1 -1
@@ -9,7 +9,6 @@ import { jsx as _jsx } from "react/jsx-runtime";
9
9
  export const mapAppHeaderItemToElement = ({
10
10
  action,
11
11
  item,
12
- isAnon,
13
12
  isStandalone,
14
13
  isTeams,
15
14
  redirectParam,
@@ -44,14 +43,12 @@ export const mapAppHeaderItemToElement = ({
44
43
  case 'catalog-dropdown':
45
44
  return /*#__PURE__*/_jsx(AppHeaderCatalogDropdown, {
46
45
  action: action,
47
- item: item,
48
- isAnon: isAnon
46
+ item: item
49
47
  });
50
48
  case 'resources-dropdown':
51
49
  return /*#__PURE__*/_jsx(AppHeaderResourcesDropdown, {
52
50
  action: action,
53
- item: item,
54
- isAnon: isAnon
51
+ item: item
55
52
  });
56
53
  case 'render-element':
57
54
  return item.renderElement();
@@ -4,6 +4,5 @@ export type AppHeaderMainMenuMobileProps = AppHeaderAction & {
4
4
  items: AppHeaderItem[];
5
5
  getItemType: (type: string | undefined) => void;
6
6
  isAnon: boolean;
7
- handleCloseMainMenu: () => void;
8
7
  };
9
8
  export declare const AppHeaderMainMenuMobile: React.FC<AppHeaderMainMenuMobileProps>;
@@ -1,11 +1,10 @@
1
1
  import _styled from "@emotion/styled/base";
2
2
  import { Box, ContentContainer, FillButton, Text, TextButton } from '@codecademy/gamut';
3
- import { css, states, theme } from '@codecademy/gamut-styles';
4
- import { useContext, useState } from 'react';
3
+ import { css, theme } from '@codecademy/gamut-styles';
4
+ import { 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 { GlobalNavRedesignContext } from '../../GlobalHeader';
9
8
  import { login, requestTeamsDemo, signUp, signUpTextButton } from '../../GlobalHeader/GlobalHeaderItems';
10
9
  import { AppHeaderSubNavMobile } from '../AppHeaderSubMenuMobile';
11
10
  import { MobileUlWrapper } from '../AppHeaderSubMenuMobile/elements';
@@ -18,24 +17,20 @@ const isBusinessPage = () => {
18
17
  const BackgroundWrapper = /*#__PURE__*/_styled(Box, {
19
18
  target: "emi0o3k0",
20
19
  label: "BackgroundWrapper"
21
- })(css({}), states({
22
- displayGlobalNavRedesign: {
23
- background: theme.colors.white,
24
- border: 1,
25
- borderColor: 'border-tertiary',
26
- borderRadius: 'lg',
27
- padding: '16px'
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":"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"]} */");
20
+ })(css({
21
+ background: theme.colors.white,
22
+ border: 1,
23
+ borderColor: 'border-tertiary',
24
+ borderRadius: 'lg',
25
+ padding: '16px'
26
+ }), process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../../src/AppHeaderMobile/AppHeaderMainMenuMobile/index.tsx"],"names":[],"mappings":"AAsC0B","file":"../../../src/AppHeaderMobile/AppHeaderMainMenuMobile/index.tsx","sourcesContent":["import {\n  Box,\n  ContentContainer,\n  FillButton,\n  Text,\n  TextButton,\n} from '@codecademy/gamut';\nimport { css, theme } from '@codecademy/gamut-styles';\nimport styled from '@emotion/styled';\nimport { 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  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  css({\n    background: theme.colors.white,\n    border: 1,\n    borderColor: 'border-tertiary',\n    borderRadius: 'lg',\n    padding: '16px',\n  })\n);\n\nexport type AppHeaderMainMenuMobileProps = AppHeaderAction & {\n  items: AppHeaderItem[];\n  getItemType: (type: string | undefined) => void;\n  isAnon: boolean;\n};\n\nexport const AppHeaderMainMenuMobile: React.FC<\n  AppHeaderMainMenuMobileProps\n> = ({ action, items, getItemType, isAnon }) => {\n  const [subMenuItem, setSubMenuItem] = useState<AppHeaderDropdownItem>();\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    />\n  ) : (\n    <ContentContainer\n      role=\"navigation\"\n      aria-label=\"site navigation\"\n      tabIndex={-1}\n    >\n      <BackgroundWrapper>\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
27
  export const AppHeaderMainMenuMobile = ({
31
28
  action,
32
29
  items,
33
30
  getItemType,
34
- isAnon,
35
- handleCloseMainMenu
31
+ isAnon
36
32
  }) => {
37
33
  const [subMenuItem, setSubMenuItem] = useState();
38
- const displayGlobalNavRedesign = useContext(GlobalNavRedesignContext);
39
34
  const openSubMenu = (event, item) => {
40
35
  action(event, item);
41
36
  setSubMenuItem(item);
@@ -98,14 +93,12 @@ export const AppHeaderMainMenuMobile = ({
98
93
  return subMenuItem ? /*#__PURE__*/_jsx(AppHeaderSubNavMobile, {
99
94
  handleCloseSubMenu: closeSubMenu,
100
95
  action: action,
101
- item: subMenuItem,
102
- handleCloseMainMenu: handleCloseMainMenu
96
+ item: subMenuItem
103
97
  }) : /*#__PURE__*/_jsx(ContentContainer, {
104
98
  role: "navigation",
105
99
  "aria-label": "site navigation",
106
100
  tabIndex: -1,
107
101
  children: /*#__PURE__*/_jsx(BackgroundWrapper, {
108
- displayGlobalNavRedesign: displayGlobalNavRedesign,
109
102
  children: /*#__PURE__*/_jsxs(MobileUlWrapper, {
110
103
  as: "ul",
111
104
  children: [items.map(item => mapItemToElement(item, action)), isAnon && /*#__PURE__*/_jsx("div", {
@@ -4,6 +4,5 @@ import { AppHeaderDropdownProps } from '../../AppHeader/AppHeaderElements/AppHea
4
4
  import { AppHeaderResourceDropdownProps } from '../../AppHeader/AppHeaderElements/AppHeaderResourcesDropdown';
5
5
  export type AppHeaderSubMenuMobileProps = (AppHeaderDropdownProps | AppHeaderCatalogDropdownProps | AppHeaderResourceDropdownProps) & {
6
6
  handleCloseSubMenu: () => void;
7
- handleCloseMainMenu: () => void;
8
7
  };
9
8
  export declare const AppHeaderSubNavMobile: React.FC<AppHeaderSubMenuMobileProps>;
@@ -1,34 +1,20 @@
1
1
  import _styled from "@emotion/styled/base";
2
2
  import { Anchor, Box, Menu, Text } from '@codecademy/gamut';
3
- import { ArrowChevronLeftIcon, ArrowLeftIcon } from '@codecademy/gamut-icons';
4
- import { css, states, theme, useCurrentMode } from '@codecademy/gamut-styles';
5
- import { useContext, useEffect, useRef } from 'react';
3
+ import { ArrowLeftIcon } from '@codecademy/gamut-icons';
4
+ import { css, states, theme } from '@codecademy/gamut-styles';
5
+ import { useEffect, useRef } from 'react';
6
6
  import * as React from 'react';
7
7
  import { CATALOG_NAV_SECTIONS } from '../../AppHeader/AppHeaderElements/AppHeaderCatalogDropdown/consts';
8
8
  import { MarketingBanner } from '../../AppHeader/AppHeaderElements/AppHeaderCatalogDropdown/MarketingBanner';
9
- import { AppHeaderCatalogSection } from '../../AppHeader/AppHeaderElements/AppHeaderCatalogSection';
10
9
  import { AppHeaderLinkSections } from '../../AppHeader/AppHeaderElements/AppHeaderLinkSections';
11
10
  import { AppHeaderListItem } from '../../AppHeader/AppHeaderElements/AppHeaderListItem';
12
11
  import { RESOURCES_NAV_SECTIONS } from '../../AppHeader/AppHeaderElements/AppHeaderResourcesDropdown/consts';
13
- import { AppHeaderResourcesSection } from '../../AppHeader/AppHeaderElements/AppHeaderResourcesSection';
14
12
  import { AppHeaderSection } from '../../AppHeader/AppHeaderElements/AppHeaderSection';
15
- import { GlobalNavRedesignContext } from '../../GlobalHeader';
16
- import { getHeaderResourcesList } from '../../lib/resourcesList';
17
13
  import { MobileSubMenuWrapper, MobileUlWrapper } from './elements';
18
14
  import { jsx as _jsx, jsxs as _jsxs } from "react/jsx-runtime";
19
15
  const StyledAnchor = /*#__PURE__*/_styled(Anchor, {
20
- target: "e1ch795o2",
21
- label: "StyledAnchor"
22
- })(css({
23
- alignItems: `center`,
24
- display: `flex`,
25
- my: 24,
26
- padding: 0,
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, 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
- const StyledStandardRedesignAnchor = /*#__PURE__*/_styled(Anchor, {
30
16
  target: "e1ch795o1",
31
- label: "StyledStandardRedesignAnchor"
17
+ label: "StyledAnchor"
32
18
  })(css({
33
19
  alignItems: `center`,
34
20
  display: `flex`,
@@ -36,12 +22,12 @@ const StyledStandardRedesignAnchor = /*#__PURE__*/_styled(Anchor, {
36
22
  py: 8,
37
23
  mt: 0,
38
24
  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, 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"]} */");
25
+ }), process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi4uLy4uLy4uL3NyYy9BcHBIZWFkZXJNb2JpbGUvQXBwSGVhZGVyU3ViTWVudU1vYmlsZS9pbmRleC50c3giXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBcUNxQiIsImZpbGUiOiIuLi8uLi8uLi9zcmMvQXBwSGVhZGVyTW9iaWxlL0FwcEhlYWRlclN1Yk1lbnVNb2JpbGUvaW5kZXgudHN4Iiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgQW5jaG9yLCBCb3gsIE1lbnUsIFRleHQgfSBmcm9tICdAY29kZWNhZGVteS9nYW11dCc7XG5pbXBvcnQgeyBBcnJvd0xlZnRJY29uIH0gZnJvbSAnQGNvZGVjYWRlbXkvZ2FtdXQtaWNvbnMnO1xuaW1wb3J0IHsgY3NzLCBzdGF0ZXMsIHRoZW1lIH0gZnJvbSAnQGNvZGVjYWRlbXkvZ2FtdXQtc3R5bGVzJztcbmltcG9ydCBzdHlsZWQgZnJvbSAnQGVtb3Rpb24vc3R5bGVkJztcbmltcG9ydCB7IHVzZUVmZmVjdCwgdXNlUmVmIH0gZnJvbSAncmVhY3QnO1xuaW1wb3J0ICogYXMgUmVhY3QgZnJvbSAncmVhY3QnO1xuXG5pbXBvcnQgeyBBcHBIZWFkZXJDYXRhbG9nRHJvcGRvd25Qcm9wcyB9IGZyb20gJy4uLy4uL0FwcEhlYWRlci9BcHBIZWFkZXJFbGVtZW50cy9BcHBIZWFkZXJDYXRhbG9nRHJvcGRvd24nO1xuaW1wb3J0IHsgQ0FUQUxPR19OQVZfU0VDVElPTlMgfSBmcm9tICcuLi8uLi9BcHBIZWFkZXIvQXBwSGVhZGVyRWxlbWVudHMvQXBwSGVhZGVyQ2F0YWxvZ0Ryb3Bkb3duL2NvbnN0cyc7XG5pbXBvcnQgeyBNYXJrZXRpbmdCYW5uZXIgfSBmcm9tICcuLi8uLi9BcHBIZWFkZXIvQXBwSGVhZGVyRWxlbWVudHMvQXBwSGVhZGVyQ2F0YWxvZ0Ryb3Bkb3duL01hcmtldGluZ0Jhbm5lcic7XG5pbXBvcnQgeyBBcHBIZWFkZXJEcm9wZG93blByb3BzIH0gZnJvbSAnLi4vLi4vQXBwSGVhZGVyL0FwcEhlYWRlckVsZW1lbnRzL0FwcEhlYWRlckRyb3Bkb3duJztcbmltcG9ydCB7IEFwcEhlYWRlckxpbmtTZWN0aW9ucyB9IGZyb20gJy4uLy4uL0FwcEhlYWRlci9BcHBIZWFkZXJFbGVtZW50cy9BcHBIZWFkZXJMaW5rU2VjdGlvbnMnO1xuaW1wb3J0IHsgQXBwSGVhZGVyTGlzdEl0ZW0gfSBmcm9tICcuLi8uLi9BcHBIZWFkZXIvQXBwSGVhZGVyRWxlbWVudHMvQXBwSGVhZGVyTGlzdEl0ZW0nO1xuaW1wb3J0IHsgQXBwSGVhZGVyUmVzb3VyY2VEcm9wZG93blByb3BzIH0gZnJvbSAnLi4vLi4vQXBwSGVhZGVyL0FwcEhlYWRlckVsZW1lbnRzL0FwcEhlYWRlclJlc291cmNlc0Ryb3Bkb3duJztcbmltcG9ydCB7IFJFU09VUkNFU19OQVZfU0VDVElPTlMgfSBmcm9tICcuLi8uLi9BcHBIZWFkZXIvQXBwSGVhZGVyRWxlbWVudHMvQXBwSGVhZGVyUmVzb3VyY2VzRHJvcGRvd24vY29uc3RzJztcbmltcG9ydCB7IEFwcEhlYWRlclNlY3Rpb24gfSBmcm9tICcuLi8uLi9BcHBIZWFkZXIvQXBwSGVhZGVyRWxlbWVudHMvQXBwSGVhZGVyU2VjdGlvbic7XG5pbXBvcnQge1xuICBBcHBIZWFkZXJDYXRhbG9nRHJvcGRvd25JdGVtLFxuICBBcHBIZWFkZXJDbGlja0hhbmRsZXIsXG4gIEFwcEhlYWRlckRyb3Bkb3duSXRlbSxcbiAgQXBwSGVhZGVyUmVzb3VyY2VzRHJvcGRvd25JdGVtLFxufSBmcm9tICcuLi8uLi9BcHBIZWFkZXIvc2hhcmVkJztcbmltcG9ydCB7IE1vYmlsZVN1Yk1lbnVXcmFwcGVyLCBNb2JpbGVVbFdyYXBwZXIgfSBmcm9tICcuL2VsZW1lbnRzJztcblxuZXhwb3J0IHR5cGUgQXBwSGVhZGVyU3ViTWVudU1vYmlsZVByb3BzID0gKFxuICB8IEFwcEhlYWRlckRyb3Bkb3duUHJvcHNcbiAgfCBBcHBIZWFkZXJDYXRhbG9nRHJvcGRvd25Qcm9wc1xuICB8IEFwcEhlYWRlclJlc291cmNlRHJvcGRvd25Qcm9wc1xuKSAmIHtcbiAgaGFuZGxlQ2xvc2VTdWJNZW51OiAoKSA9PiB2b2lkO1xufTtcblxudHlwZSBBcHBIZWFkZXJTZWN0aW9uSXRlbSA9XG4gIHwgQXBwSGVhZGVyRHJvcGRvd25JdGVtXG4gIHwgQXBwSGVhZGVyQ2F0YWxvZ0Ryb3Bkb3duSXRlbVxuICB8IEFwcEhlYWRlclJlc291cmNlc0Ryb3Bkb3duSXRlbTtcblxuY29uc3QgU3R5bGVkQW5jaG9yID0gc3R5bGVkKEFuY2hvcikoXG4gIGNzcyh7XG4gICAgYWxpZ25JdGVtczogYGNlbnRlcmAsXG4gICAgZGlzcGxheTogYGZsZXhgLFxuICAgIHdpZHRoOiAnY2FsYygxMDAlIC0gNjRweCknLFxuICAgIHB5OiA4LFxuICAgIG10OiAwLFxuICAgIG1iOiAxNixcbiAgfSlcbik7XG5cbmNvbnN0IEJhY2tncm91bmRXcmFwcGVyID0gc3R5bGVkKEJveCk8e1xuICBpc05vdENhdGFsb2dPclJlc291cmNlczogYm9vbGVhbjtcbn0+KFxuICBzdGF0ZXMoe1xuICAgIGlzTm90Q2F0YWxvZ09yUmVzb3VyY2VzOiB7XG4gICAgICBiYWNrZ3JvdW5kOiB0aGVtZS5jb2xvcnMud2hpdGUsXG4gICAgICBib3JkZXI6IDEsXG4gICAgICBib3JkZXJDb2xvcjogJ2JvcmRlci10ZXJ0aWFyeScsXG4gICAgICBib3JkZXJSYWRpdXM6ICdsZycsXG4gICAgICBwYWRkaW5nOiAnMTZweCcsXG4gICAgICBteDogMTYsXG4gICAgfSxcbiAgfSlcbik7XG5cbmNvbnN0IHJlbmRlckhlYWRlclNlY3Rpb24gPSAoXG4gIGl0ZW06IEFwcEhlYWRlclNlY3Rpb25JdGVtLFxuICBhY3Rpb246IEFwcEhlYWRlckNsaWNrSGFuZGxlcixcbiAgaGFuZGxlQ2xvc2VTdWJNZW51OiAoKSA9PiB2b2lkXG4pID0+IHtcbiAgc3dpdGNoIChpdGVtLnR5cGUpIHtcbiAgICBjYXNlICdjYXRhbG9nLWRyb3Bkb3duJzpcbiAgICAgIHJldHVybiAoXG4gICAgICAgIDxBcHBIZWFkZXJTZWN0aW9uXG4gICAgICAgICAgbmF2U2VjdGlvbnM9e0NBVEFMT0dfTkFWX1NFQ1RJT05TfVxuICAgICAgICAgIE1hcmtldGluZ0Jhbm5lcj17TWFya2V0aW5nQmFubmVyfVxuICAgICAgICAgIGlzTW9iaWxlXG4gICAgICAgICAgaGFuZGxlQ2xvc2U9e2hhbmRsZUNsb3NlU3ViTWVudX1cbiAgICAgICAgICB0eXBlPVwiY2F0YWxvZy1kcm9wZG93blwiXG4gICAgICAgIC8+XG4gICAgICApO1xuICAgIGNhc2UgJ3Jlc291cmNlcy1kcm9wZG93bic6XG4gICAgICByZXR1cm4gKFxuICAgICAgICA8QXBwSGVhZGVyU2VjdGlvblxuICAgICAgICAgIG5hdlNlY3Rpb25zPXtSRVNPVVJDRVNfTkFWX1NFQ1RJT05TfVxuICAgICAgICAgIGlzTW9iaWxlXG4gICAgICAgICAgaGFuZGxlQ2xvc2U9e2hhbmRsZUNsb3NlU3ViTWVudX1cbiAgICAgICAgICB0eXBlPVwicmVzb3VyY2VzLWRyb3Bkb3duXCJcbiAgICAgICAgLz5cbiAgICAgICk7XG4gICAgZGVmYXVsdDpcbiAgICAgIHJldHVybiA8QXBwSGVhZGVyTGlua1NlY3Rpb25zIGFjdGlvbj17YWN0aW9ufSBpdGVtPXtpdGVtfSBtb2JpbGUgLz47XG4gIH1cbn07XG5cbmV4cG9ydCBjb25zdCBBcHBIZWFkZXJTdWJOYXZNb2JpbGU6IFJlYWN0LkZDPEFwcEhlYWRlclN1Yk1lbnVNb2JpbGVQcm9wcz4gPSAoe1xuICBhY3Rpb24sXG4gIGhhbmRsZUNsb3NlU3ViTWVudSxcbiAgaXRlbSxcbn0pID0+IHtcbiAgY29uc3QgbWFpblVsV3JhcHBlciA9IHVzZVJlZjxIVE1MVUxpc3RFbGVtZW50PihudWxsKTtcblxuICB1c2VFZmZlY3QoKCkgPT4ge1xuICAgIGlmIChtYWluVWxXcmFwcGVyPy5jdXJyZW50KSB7XG4gICAgICBtYWluVWxXcmFwcGVyLmN1cnJlbnQuZm9jdXMoKTtcbiAgICB9XG4gIH0sIFtdKTtcblxuICBjb25zdCBpc1Byb2ZpbGVNZW51ID0gaXRlbS50eXBlID09PSAncHJvZmlsZS1kcm9wZG93bic7XG5cbiAgY29uc3QgaXNDYXRhbG9nT3JSZXNvdXJjZXNNZW51ID1cbiAgICBpdGVtLnR5cGUgPT09ICdjYXRhbG9nLWRyb3Bkb3duJyB8fCBpdGVtLnR5cGUgPT09ICdyZXNvdXJjZXMtZHJvcGRvd24nO1xuXG4gIGNvbnN0IHJlbmRlckJhY2tCdXR0b24gPSAoKSA9PiB7XG4gICAgaWYgKCFpc0NhdGFsb2dPclJlc291cmNlc01lbnUpIHtcbiAgICAgIHJldHVybiAoXG4gICAgICAgIDxBcHBIZWFkZXJMaXN0SXRlbT5cbiAgICAgICAgICA8U3R5bGVkQW5jaG9yXG4gICAgICAgICAgICBvbkNsaWNrPXtoYW5kbGVDbG9zZVN1Yk1lbnV9XG4gICAgICAgICAgICB2YXJpYW50PVwiaW50ZXJmYWNlXCJcbiAgICAgICAgICAgIGFzPVwiYnV0dG9uXCJcbiAgICAgICAgICA+XG4gICAgICAgICAgICA8QXJyb3dMZWZ0SWNvbiBzaXplPXsyNH0gYXJpYS1oaWRkZW4gLz5cbiAgICAgICAgICAgIDxUZXh0IHBsPXs4fT5CYWNrPC9UZXh0PlxuICAgICAgICAgIDwvU3R5bGVkQW5jaG9yPlxuICAgICAgICA8L0FwcEhlYWRlckxpc3RJdGVtPlxuICAgICAgKTtcbiAgICB9XG4gICAgcmV0dXJuIG51bGw7XG4gIH07XG5cbiAgcmV0dXJuIChcbiAgICA8QmFja2dyb3VuZFdyYXBwZXIgaXNOb3RDYXRhbG9nT3JSZXNvdXJjZXM9eyFpc0NhdGFsb2dPclJlc291cmNlc01lbnV9PlxuICAgICAgPE1vYmlsZVVsV3JhcHBlciByZWY9e21haW5VbFdyYXBwZXJ9IHRhYkluZGV4PXstMX0+XG4gICAgICAgIHtyZW5kZXJCYWNrQnV0dG9uKCl9XG4gICAgICAgIDxNb2JpbGVTdWJNZW51V3JhcHBlclxuICAgICAgICAgIGhhbmRsZUNsb3NlPXtoYW5kbGVDbG9zZVN1Yk1lbnV9XG4gICAgICAgICAgaXNNZW51Um9sZT17aXNQcm9maWxlTWVudX1cbiAgICAgICAgPlxuICAgICAgICAgIHshaXNDYXRhbG9nT3JSZXNvdXJjZXNNZW51ICYmIChcbiAgICAgICAgICAgIDxUZXh0IGFzPVwiaDFcIiBmb250U2l6ZT17MjB9IG1iPXsxNn0gbWw9ezB9PlxuICAgICAgICAgICAgICB7aXNQcm9maWxlTWVudSA/IGl0ZW0udXNlckRpc3BsYXlOYW1lIDogaXRlbS50ZXh0fVxuICAgICAgICAgICAgPC9UZXh0PlxuICAgICAgICAgICl9XG4gICAgICAgICAgPE1lbnVcbiAgICAgICAgICAgIHZhcmlhbnQ9XCJmaXhlZFwiXG4gICAgICAgICAgICBteD17aXNDYXRhbG9nT3JSZXNvdXJjZXNNZW51ID8geyBfOiAxNiwgc206IDMyIH0gOiAwfVxuICAgICAgICAgICAgd2lkdGg9XCJhdXRvXCJcbiAgICAgICAgICAgIGJnPVwidHJhbnNwYXJlbnRcIlxuICAgICAgICAgID5cbiAgICAgICAgICAgIHtyZW5kZXJIZWFkZXJTZWN0aW9uKGl0ZW0sIGFjdGlvbiwgaGFuZGxlQ2xvc2VTdWJNZW51KX1cbiAgICAgICAgICA8L01lbnU+XG4gICAgICAgIDwvTW9iaWxlU3ViTWVudVdyYXBwZXI+XG4gICAgICA8L01vYmlsZVVsV3JhcHBlcj5cbiAgICA8L0JhY2tncm91bmRXcmFwcGVyPlxuICApO1xufTtcbiJdfQ== */");
40
26
  const BackgroundWrapper = /*#__PURE__*/_styled(Box, {
41
27
  target: "e1ch795o0",
42
28
  label: "BackgroundWrapper"
43
29
  })(states({
44
- showStandardRedesign: {
30
+ isNotCatalogOrResources: {
45
31
  background: theme.colors.white,
46
32
  border: 1,
47
33
  borderColor: 'border-tertiary',
@@ -49,31 +35,23 @@ const BackgroundWrapper = /*#__PURE__*/_styled(Box, {
49
35
  padding: '16px',
50
36
  mx: 16
51
37
  }
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
- const renderHeaderSection = (item, action, handleCloseMainMenu, displayGlobalNavRedesign, handleCloseSubMenu) => {
38
+ }), process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi4uLy4uLy4uL3NyYy9BcHBIZWFkZXJNb2JpbGUvQXBwSGVhZGVyU3ViTWVudU1vYmlsZS9pbmRleC50c3giXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBZ0QwQiIsImZpbGUiOiIuLi8uLi8uLi9zcmMvQXBwSGVhZGVyTW9iaWxlL0FwcEhlYWRlclN1Yk1lbnVNb2JpbGUvaW5kZXgudHN4Iiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgQW5jaG9yLCBCb3gsIE1lbnUsIFRleHQgfSBmcm9tICdAY29kZWNhZGVteS9nYW11dCc7XG5pbXBvcnQgeyBBcnJvd0xlZnRJY29uIH0gZnJvbSAnQGNvZGVjYWRlbXkvZ2FtdXQtaWNvbnMnO1xuaW1wb3J0IHsgY3NzLCBzdGF0ZXMsIHRoZW1lIH0gZnJvbSAnQGNvZGVjYWRlbXkvZ2FtdXQtc3R5bGVzJztcbmltcG9ydCBzdHlsZWQgZnJvbSAnQGVtb3Rpb24vc3R5bGVkJztcbmltcG9ydCB7IHVzZUVmZmVjdCwgdXNlUmVmIH0gZnJvbSAncmVhY3QnO1xuaW1wb3J0ICogYXMgUmVhY3QgZnJvbSAncmVhY3QnO1xuXG5pbXBvcnQgeyBBcHBIZWFkZXJDYXRhbG9nRHJvcGRvd25Qcm9wcyB9IGZyb20gJy4uLy4uL0FwcEhlYWRlci9BcHBIZWFkZXJFbGVtZW50cy9BcHBIZWFkZXJDYXRhbG9nRHJvcGRvd24nO1xuaW1wb3J0IHsgQ0FUQUxPR19OQVZfU0VDVElPTlMgfSBmcm9tICcuLi8uLi9BcHBIZWFkZXIvQXBwSGVhZGVyRWxlbWVudHMvQXBwSGVhZGVyQ2F0YWxvZ0Ryb3Bkb3duL2NvbnN0cyc7XG5pbXBvcnQgeyBNYXJrZXRpbmdCYW5uZXIgfSBmcm9tICcuLi8uLi9BcHBIZWFkZXIvQXBwSGVhZGVyRWxlbWVudHMvQXBwSGVhZGVyQ2F0YWxvZ0Ryb3Bkb3duL01hcmtldGluZ0Jhbm5lcic7XG5pbXBvcnQgeyBBcHBIZWFkZXJEcm9wZG93blByb3BzIH0gZnJvbSAnLi4vLi4vQXBwSGVhZGVyL0FwcEhlYWRlckVsZW1lbnRzL0FwcEhlYWRlckRyb3Bkb3duJztcbmltcG9ydCB7IEFwcEhlYWRlckxpbmtTZWN0aW9ucyB9IGZyb20gJy4uLy4uL0FwcEhlYWRlci9BcHBIZWFkZXJFbGVtZW50cy9BcHBIZWFkZXJMaW5rU2VjdGlvbnMnO1xuaW1wb3J0IHsgQXBwSGVhZGVyTGlzdEl0ZW0gfSBmcm9tICcuLi8uLi9BcHBIZWFkZXIvQXBwSGVhZGVyRWxlbWVudHMvQXBwSGVhZGVyTGlzdEl0ZW0nO1xuaW1wb3J0IHsgQXBwSGVhZGVyUmVzb3VyY2VEcm9wZG93blByb3BzIH0gZnJvbSAnLi4vLi4vQXBwSGVhZGVyL0FwcEhlYWRlckVsZW1lbnRzL0FwcEhlYWRlclJlc291cmNlc0Ryb3Bkb3duJztcbmltcG9ydCB7IFJFU09VUkNFU19OQVZfU0VDVElPTlMgfSBmcm9tICcuLi8uLi9BcHBIZWFkZXIvQXBwSGVhZGVyRWxlbWVudHMvQXBwSGVhZGVyUmVzb3VyY2VzRHJvcGRvd24vY29uc3RzJztcbmltcG9ydCB7IEFwcEhlYWRlclNlY3Rpb24gfSBmcm9tICcuLi8uLi9BcHBIZWFkZXIvQXBwSGVhZGVyRWxlbWVudHMvQXBwSGVhZGVyU2VjdGlvbic7XG5pbXBvcnQge1xuICBBcHBIZWFkZXJDYXRhbG9nRHJvcGRvd25JdGVtLFxuICBBcHBIZWFkZXJDbGlja0hhbmRsZXIsXG4gIEFwcEhlYWRlckRyb3Bkb3duSXRlbSxcbiAgQXBwSGVhZGVyUmVzb3VyY2VzRHJvcGRvd25JdGVtLFxufSBmcm9tICcuLi8uLi9BcHBIZWFkZXIvc2hhcmVkJztcbmltcG9ydCB7IE1vYmlsZVN1Yk1lbnVXcmFwcGVyLCBNb2JpbGVVbFdyYXBwZXIgfSBmcm9tICcuL2VsZW1lbnRzJztcblxuZXhwb3J0IHR5cGUgQXBwSGVhZGVyU3ViTWVudU1vYmlsZVByb3BzID0gKFxuICB8IEFwcEhlYWRlckRyb3Bkb3duUHJvcHNcbiAgfCBBcHBIZWFkZXJDYXRhbG9nRHJvcGRvd25Qcm9wc1xuICB8IEFwcEhlYWRlclJlc291cmNlRHJvcGRvd25Qcm9wc1xuKSAmIHtcbiAgaGFuZGxlQ2xvc2VTdWJNZW51OiAoKSA9PiB2b2lkO1xufTtcblxudHlwZSBBcHBIZWFkZXJTZWN0aW9uSXRlbSA9XG4gIHwgQXBwSGVhZGVyRHJvcGRvd25JdGVtXG4gIHwgQXBwSGVhZGVyQ2F0YWxvZ0Ryb3Bkb3duSXRlbVxuICB8IEFwcEhlYWRlclJlc291cmNlc0Ryb3Bkb3duSXRlbTtcblxuY29uc3QgU3R5bGVkQW5jaG9yID0gc3R5bGVkKEFuY2hvcikoXG4gIGNzcyh7XG4gICAgYWxpZ25JdGVtczogYGNlbnRlcmAsXG4gICAgZGlzcGxheTogYGZsZXhgLFxuICAgIHdpZHRoOiAnY2FsYygxMDAlIC0gNjRweCknLFxuICAgIHB5OiA4LFxuICAgIG10OiAwLFxuICAgIG1iOiAxNixcbiAgfSlcbik7XG5cbmNvbnN0IEJhY2tncm91bmRXcmFwcGVyID0gc3R5bGVkKEJveCk8e1xuICBpc05vdENhdGFsb2dPclJlc291cmNlczogYm9vbGVhbjtcbn0+KFxuICBzdGF0ZXMoe1xuICAgIGlzTm90Q2F0YWxvZ09yUmVzb3VyY2VzOiB7XG4gICAgICBiYWNrZ3JvdW5kOiB0aGVtZS5jb2xvcnMud2hpdGUsXG4gICAgICBib3JkZXI6IDEsXG4gICAgICBib3JkZXJDb2xvcjogJ2JvcmRlci10ZXJ0aWFyeScsXG4gICAgICBib3JkZXJSYWRpdXM6ICdsZycsXG4gICAgICBwYWRkaW5nOiAnMTZweCcsXG4gICAgICBteDogMTYsXG4gICAgfSxcbiAgfSlcbik7XG5cbmNvbnN0IHJlbmRlckhlYWRlclNlY3Rpb24gPSAoXG4gIGl0ZW06IEFwcEhlYWRlclNlY3Rpb25JdGVtLFxuICBhY3Rpb246IEFwcEhlYWRlckNsaWNrSGFuZGxlcixcbiAgaGFuZGxlQ2xvc2VTdWJNZW51OiAoKSA9PiB2b2lkXG4pID0+IHtcbiAgc3dpdGNoIChpdGVtLnR5cGUpIHtcbiAgICBjYXNlICdjYXRhbG9nLWRyb3Bkb3duJzpcbiAgICAgIHJldHVybiAoXG4gICAgICAgIDxBcHBIZWFkZXJTZWN0aW9uXG4gICAgICAgICAgbmF2U2VjdGlvbnM9e0NBVEFMT0dfTkFWX1NFQ1RJT05TfVxuICAgICAgICAgIE1hcmtldGluZ0Jhbm5lcj17TWFya2V0aW5nQmFubmVyfVxuICAgICAgICAgIGlzTW9iaWxlXG4gICAgICAgICAgaGFuZGxlQ2xvc2U9e2hhbmRsZUNsb3NlU3ViTWVudX1cbiAgICAgICAgICB0eXBlPVwiY2F0YWxvZy1kcm9wZG93blwiXG4gICAgICAgIC8+XG4gICAgICApO1xuICAgIGNhc2UgJ3Jlc291cmNlcy1kcm9wZG93bic6XG4gICAgICByZXR1cm4gKFxuICAgICAgICA8QXBwSGVhZGVyU2VjdGlvblxuICAgICAgICAgIG5hdlNlY3Rpb25zPXtSRVNPVVJDRVNfTkFWX1NFQ1RJT05TfVxuICAgICAgICAgIGlzTW9iaWxlXG4gICAgICAgICAgaGFuZGxlQ2xvc2U9e2hhbmRsZUNsb3NlU3ViTWVudX1cbiAgICAgICAgICB0eXBlPVwicmVzb3VyY2VzLWRyb3Bkb3duXCJcbiAgICAgICAgLz5cbiAgICAgICk7XG4gICAgZGVmYXVsdDpcbiAgICAgIHJldHVybiA8QXBwSGVhZGVyTGlua1NlY3Rpb25zIGFjdGlvbj17YWN0aW9ufSBpdGVtPXtpdGVtfSBtb2JpbGUgLz47XG4gIH1cbn07XG5cbmV4cG9ydCBjb25zdCBBcHBIZWFkZXJTdWJOYXZNb2JpbGU6IFJlYWN0LkZDPEFwcEhlYWRlclN1Yk1lbnVNb2JpbGVQcm9wcz4gPSAoe1xuICBhY3Rpb24sXG4gIGhhbmRsZUNsb3NlU3ViTWVudSxcbiAgaXRlbSxcbn0pID0+IHtcbiAgY29uc3QgbWFpblVsV3JhcHBlciA9IHVzZVJlZjxIVE1MVUxpc3RFbGVtZW50PihudWxsKTtcblxuICB1c2VFZmZlY3QoKCkgPT4ge1xuICAgIGlmIChtYWluVWxXcmFwcGVyPy5jdXJyZW50KSB7XG4gICAgICBtYWluVWxXcmFwcGVyLmN1cnJlbnQuZm9jdXMoKTtcbiAgICB9XG4gIH0sIFtdKTtcblxuICBjb25zdCBpc1Byb2ZpbGVNZW51ID0gaXRlbS50eXBlID09PSAncHJvZmlsZS1kcm9wZG93bic7XG5cbiAgY29uc3QgaXNDYXRhbG9nT3JSZXNvdXJjZXNNZW51ID1cbiAgICBpdGVtLnR5cGUgPT09ICdjYXRhbG9nLWRyb3Bkb3duJyB8fCBpdGVtLnR5cGUgPT09ICdyZXNvdXJjZXMtZHJvcGRvd24nO1xuXG4gIGNvbnN0IHJlbmRlckJhY2tCdXR0b24gPSAoKSA9PiB7XG4gICAgaWYgKCFpc0NhdGFsb2dPclJlc291cmNlc01lbnUpIHtcbiAgICAgIHJldHVybiAoXG4gICAgICAgIDxBcHBIZWFkZXJMaXN0SXRlbT5cbiAgICAgICAgICA8U3R5bGVkQW5jaG9yXG4gICAgICAgICAgICBvbkNsaWNrPXtoYW5kbGVDbG9zZVN1Yk1lbnV9XG4gICAgICAgICAgICB2YXJpYW50PVwiaW50ZXJmYWNlXCJcbiAgICAgICAgICAgIGFzPVwiYnV0dG9uXCJcbiAgICAgICAgICA+XG4gICAgICAgICAgICA8QXJyb3dMZWZ0SWNvbiBzaXplPXsyNH0gYXJpYS1oaWRkZW4gLz5cbiAgICAgICAgICAgIDxUZXh0IHBsPXs4fT5CYWNrPC9UZXh0PlxuICAgICAgICAgIDwvU3R5bGVkQW5jaG9yPlxuICAgICAgICA8L0FwcEhlYWRlckxpc3RJdGVtPlxuICAgICAgKTtcbiAgICB9XG4gICAgcmV0dXJuIG51bGw7XG4gIH07XG5cbiAgcmV0dXJuIChcbiAgICA8QmFja2dyb3VuZFdyYXBwZXIgaXNOb3RDYXRhbG9nT3JSZXNvdXJjZXM9eyFpc0NhdGFsb2dPclJlc291cmNlc01lbnV9PlxuICAgICAgPE1vYmlsZVVsV3JhcHBlciByZWY9e21haW5VbFdyYXBwZXJ9IHRhYkluZGV4PXstMX0+XG4gICAgICAgIHtyZW5kZXJCYWNrQnV0dG9uKCl9XG4gICAgICAgIDxNb2JpbGVTdWJNZW51V3JhcHBlclxuICAgICAgICAgIGhhbmRsZUNsb3NlPXtoYW5kbGVDbG9zZVN1Yk1lbnV9XG4gICAgICAgICAgaXNNZW51Um9sZT17aXNQcm9maWxlTWVudX1cbiAgICAgICAgPlxuICAgICAgICAgIHshaXNDYXRhbG9nT3JSZXNvdXJjZXNNZW51ICYmIChcbiAgICAgICAgICAgIDxUZXh0IGFzPVwiaDFcIiBmb250U2l6ZT17MjB9IG1iPXsxNn0gbWw9ezB9PlxuICAgICAgICAgICAgICB7aXNQcm9maWxlTWVudSA/IGl0ZW0udXNlckRpc3BsYXlOYW1lIDogaXRlbS50ZXh0fVxuICAgICAgICAgICAgPC9UZXh0PlxuICAgICAgICAgICl9XG4gICAgICAgICAgPE1lbnVcbiAgICAgICAgICAgIHZhcmlhbnQ9XCJmaXhlZFwiXG4gICAgICAgICAgICBteD17aXNDYXRhbG9nT3JSZXNvdXJjZXNNZW51ID8geyBfOiAxNiwgc206IDMyIH0gOiAwfVxuICAgICAgICAgICAgd2lkdGg9XCJhdXRvXCJcbiAgICAgICAgICAgIGJnPVwidHJhbnNwYXJlbnRcIlxuICAgICAgICAgID5cbiAgICAgICAgICAgIHtyZW5kZXJIZWFkZXJTZWN0aW9uKGl0ZW0sIGFjdGlvbiwgaGFuZGxlQ2xvc2VTdWJNZW51KX1cbiAgICAgICAgICA8L01lbnU+XG4gICAgICAgIDwvTW9iaWxlU3ViTWVudVdyYXBwZXI+XG4gICAgICA8L01vYmlsZVVsV3JhcHBlcj5cbiAgICA8L0JhY2tncm91bmRXcmFwcGVyPlxuICApO1xufTtcbiJdfQ== */");
39
+ const renderHeaderSection = (item, action, handleCloseSubMenu) => {
54
40
  switch (item.type) {
55
41
  case 'catalog-dropdown':
56
- return displayGlobalNavRedesign ? /*#__PURE__*/_jsx(AppHeaderSection, {
42
+ return /*#__PURE__*/_jsx(AppHeaderSection, {
57
43
  navSections: CATALOG_NAV_SECTIONS,
58
44
  MarketingBanner: MarketingBanner,
59
45
  isMobile: true,
60
46
  handleClose: handleCloseSubMenu,
61
47
  type: "catalog-dropdown"
62
- }) : /*#__PURE__*/_jsx(AppHeaderCatalogSection, {
63
- action: action,
64
- item: item,
65
- handleClose: handleCloseMainMenu
66
48
  });
67
49
  case 'resources-dropdown':
68
- return displayGlobalNavRedesign ? /*#__PURE__*/_jsx(AppHeaderSection, {
50
+ return /*#__PURE__*/_jsx(AppHeaderSection, {
69
51
  navSections: RESOURCES_NAV_SECTIONS,
70
52
  isMobile: true,
71
53
  handleClose: handleCloseSubMenu,
72
54
  type: "resources-dropdown"
73
- }) : /*#__PURE__*/_jsx(AppHeaderResourcesSection, {
74
- action: action,
75
- handleClose: handleCloseMainMenu,
76
- resources: getHeaderResourcesList()
77
55
  });
78
56
  default:
79
57
  return /*#__PURE__*/_jsx(AppHeaderLinkSections, {
@@ -86,7 +64,6 @@ const renderHeaderSection = (item, action, handleCloseMainMenu, displayGlobalNav
86
64
  export const AppHeaderSubNavMobile = ({
87
65
  action,
88
66
  handleCloseSubMenu,
89
- handleCloseMainMenu,
90
67
  item
91
68
  }) => {
92
69
  const mainUlWrapper = useRef(null);
@@ -96,39 +73,11 @@ export const AppHeaderSubNavMobile = ({
96
73
  }
97
74
  }, []);
98
75
  const isProfileMenu = item.type === 'profile-dropdown';
99
- const displayGlobalNavRedesign = useContext(GlobalNavRedesignContext);
100
76
  const isCatalogOrResourcesMenu = item.type === 'catalog-dropdown' || item.type === 'resources-dropdown';
101
- const showLegacyDesign = !displayGlobalNavRedesign;
102
- const showCatalogOrResourceRedesign = displayGlobalNavRedesign && isCatalogOrResourcesMenu; // for redesigned catalog or resources menus
103
- const showStandardRedesign = displayGlobalNavRedesign && !isCatalogOrResourcesMenu; // for all other redesigned menus
104
-
105
77
  const renderBackButton = () => {
106
- if (showLegacyDesign) {
78
+ if (!isCatalogOrResourcesMenu) {
107
79
  return /*#__PURE__*/_jsx(AppHeaderListItem, {
108
80
  children: /*#__PURE__*/_jsxs(StyledAnchor, {
109
- onClick: handleCloseSubMenu,
110
- variant: "interface",
111
- as: "button",
112
- ml: {
113
- _: 16,
114
- xs: 32,
115
- sm: 64,
116
- md: 48
117
- },
118
- children: [/*#__PURE__*/_jsx(ArrowChevronLeftIcon, {
119
- size: 12,
120
- "aria-hidden": true
121
- }), /*#__PURE__*/_jsx(Text, {
122
- fontSize: 16,
123
- pl: 8,
124
- children: "Back to main navigation"
125
- })]
126
- })
127
- });
128
- }
129
- if (showStandardRedesign) {
130
- return /*#__PURE__*/_jsx(AppHeaderListItem, {
131
- children: /*#__PURE__*/_jsxs(StyledStandardRedesignAnchor, {
132
81
  onClick: handleCloseSubMenu,
133
82
  variant: "interface",
134
83
  as: "button",
@@ -144,35 +93,29 @@ export const AppHeaderSubNavMobile = ({
144
93
  }
145
94
  return null;
146
95
  };
147
- const colorMode = useCurrentMode();
148
96
  return /*#__PURE__*/_jsx(BackgroundWrapper, {
149
- showStandardRedesign: showStandardRedesign,
97
+ isNotCatalogOrResources: !isCatalogOrResourcesMenu,
150
98
  children: /*#__PURE__*/_jsxs(MobileUlWrapper, {
151
99
  ref: mainUlWrapper,
152
100
  tabIndex: -1,
153
101
  children: [renderBackButton(), /*#__PURE__*/_jsxs(MobileSubMenuWrapper, {
154
102
  handleClose: handleCloseSubMenu,
155
103
  isMenuRole: isProfileMenu,
156
- children: [!showCatalogOrResourceRedesign && /*#__PURE__*/_jsx(Text, {
104
+ children: [!isCatalogOrResourcesMenu && /*#__PURE__*/_jsx(Text, {
157
105
  as: "h1",
158
- fontSize: showLegacyDesign ? 22 : 20,
106
+ fontSize: 20,
159
107
  mb: 16,
160
- ml: showLegacyDesign ? {
161
- _: 16,
162
- xs: 32,
163
- sm: 64,
164
- md: 48
165
- } : 0,
108
+ ml: 0,
166
109
  children: isProfileMenu ? item.userDisplayName : item.text
167
110
  }), /*#__PURE__*/_jsx(Menu, {
168
111
  variant: "fixed",
169
- mx: showCatalogOrResourceRedesign ? {
112
+ mx: isCatalogOrResourcesMenu ? {
170
113
  _: 16,
171
114
  sm: 32
172
115
  } : 0,
173
- width: displayGlobalNavRedesign ? 'auto' : 'calc(100% - 16px)',
174
- bg: displayGlobalNavRedesign ? 'transparent' : colorMode === 'dark' ? 'navy-800' : 'white',
175
- children: renderHeaderSection(item, action, handleCloseMainMenu, displayGlobalNavRedesign, handleCloseSubMenu)
116
+ width: "auto",
117
+ bg: "transparent",
118
+ children: renderHeaderSection(item, action, handleCloseSubMenu)
176
119
  })]
177
120
  })]
178
121
  })